schematex 0.1.1 → 0.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (196) hide show
  1. package/README.md +130 -15
  2. package/dist/api-bQZ98gkJ.d.cts +22 -0
  3. package/dist/api-bQZ98gkJ.d.ts +22 -0
  4. package/dist/browser.cjs +46 -0
  5. package/dist/browser.cjs.map +1 -0
  6. package/dist/browser.d.cts +27 -0
  7. package/dist/browser.d.ts +27 -0
  8. package/dist/browser.js +40 -0
  9. package/dist/browser.js.map +1 -0
  10. package/dist/{chunk-IX554O5K.js → chunk-2VNMKOUO.js} +90 -6
  11. package/dist/chunk-2VNMKOUO.js.map +1 -0
  12. package/dist/{chunk-LMFSHK45.js → chunk-4KYW63IK.js} +4 -3
  13. package/dist/{chunk-LMFSHK45.js.map → chunk-4KYW63IK.js.map} +1 -1
  14. package/dist/{chunk-FGPTCDUT.cjs → chunk-4S2WILLW.cjs} +5 -4
  15. package/dist/chunk-4S2WILLW.cjs.map +1 -0
  16. package/dist/{chunk-4G7ZIBHN.js → chunk-5SH5NUDW.js} +3 -2
  17. package/dist/{chunk-4G7ZIBHN.js.map → chunk-5SH5NUDW.js.map} +1 -1
  18. package/dist/{chunk-PDPHRZZT.js → chunk-5UV5VQ7J.js} +4 -3
  19. package/dist/chunk-5UV5VQ7J.js.map +1 -0
  20. package/dist/{chunk-VFQCTXOX.js → chunk-5YYAYW67.js} +4 -3
  21. package/dist/chunk-5YYAYW67.js.map +1 -0
  22. package/dist/{chunk-HGHWCB6K.js → chunk-6YMQSTFF.js} +4 -3
  23. package/dist/chunk-6YMQSTFF.js.map +1 -0
  24. package/dist/chunk-7HKXU7J2.cjs +4838 -0
  25. package/dist/chunk-7HKXU7J2.cjs.map +1 -0
  26. package/dist/{chunk-UHLYS3W5.cjs → chunk-7IRT3LOY.cjs} +5 -4
  27. package/dist/{chunk-UHLYS3W5.cjs.map → chunk-7IRT3LOY.cjs.map} +1 -1
  28. package/dist/{chunk-U5GGE6PJ.js → chunk-CJ2A3UEQ.js} +4 -3
  29. package/dist/chunk-CJ2A3UEQ.js.map +1 -0
  30. package/dist/chunk-CXHPP5BL.cjs +1880 -0
  31. package/dist/chunk-CXHPP5BL.cjs.map +1 -0
  32. package/dist/{chunk-N7KOXOMX.cjs → chunk-D7EHZFK4.cjs} +90 -5
  33. package/dist/chunk-D7EHZFK4.cjs.map +1 -0
  34. package/dist/{chunk-FDLZEKEB.js → chunk-GEPBET4L.js} +3 -2
  35. package/dist/chunk-GEPBET4L.js.map +1 -0
  36. package/dist/{chunk-4DBRNOPA.cjs → chunk-ISACNVFE.cjs} +5 -4
  37. package/dist/{chunk-4DBRNOPA.cjs.map → chunk-ISACNVFE.cjs.map} +1 -1
  38. package/dist/{chunk-ROFLJ74T.js → chunk-JDTB7IKL.js} +4 -3
  39. package/dist/chunk-JDTB7IKL.js.map +1 -0
  40. package/dist/{chunk-47ZC6EMJ.js → chunk-LCR3KOJV.js} +4 -3
  41. package/dist/{chunk-47ZC6EMJ.js.map → chunk-LCR3KOJV.js.map} +1 -1
  42. package/dist/{chunk-7FZSPKX3.cjs → chunk-LKOBOVNL.cjs} +6 -5
  43. package/dist/chunk-LKOBOVNL.cjs.map +1 -0
  44. package/dist/{chunk-34X3ZJ6E.cjs → chunk-LXNFVHDT.cjs} +3 -2
  45. package/dist/{chunk-34X3ZJ6E.cjs.map → chunk-LXNFVHDT.cjs.map} +1 -1
  46. package/dist/{chunk-XX4BKS7Y.js → chunk-M5B2UUNW.js} +4 -3
  47. package/dist/chunk-M5B2UUNW.js.map +1 -0
  48. package/dist/{chunk-XXU36667.js → chunk-PGALHQFF.js} +4 -3
  49. package/dist/chunk-PGALHQFF.js.map +1 -0
  50. package/dist/{chunk-ZX7QKZK2.cjs → chunk-QR7VTCI4.cjs} +28 -27
  51. package/dist/chunk-QR7VTCI4.cjs.map +1 -0
  52. package/dist/{chunk-3FTUWAXK.cjs → chunk-QSQX77S2.cjs} +5 -4
  53. package/dist/chunk-QSQX77S2.cjs.map +1 -0
  54. package/dist/chunk-UUPYTUGR.js +4833 -0
  55. package/dist/chunk-UUPYTUGR.js.map +1 -0
  56. package/dist/{chunk-BE5HNDA5.cjs → chunk-WYFXOXVK.cjs} +5 -4
  57. package/dist/{chunk-BE5HNDA5.cjs.map → chunk-WYFXOXVK.cjs.map} +1 -1
  58. package/dist/{chunk-5C7DPDHQ.js → chunk-X2BQKXMA.js} +28 -27
  59. package/dist/chunk-X2BQKXMA.js.map +1 -0
  60. package/dist/{chunk-XQ52ICHU.cjs → chunk-X7RPFTTR.cjs} +14 -13
  61. package/dist/chunk-X7RPFTTR.cjs.map +1 -0
  62. package/dist/{chunk-S6BK5DB6.cjs → chunk-XHZ7GXP2.cjs} +13 -12
  63. package/dist/chunk-XHZ7GXP2.cjs.map +1 -0
  64. package/dist/{chunk-DS47NTWZ.cjs → chunk-XVCAOGFL.cjs} +11 -10
  65. package/dist/chunk-XVCAOGFL.cjs.map +1 -0
  66. package/dist/{chunk-D4JTSPOL.js → chunk-YN467EEQ.js} +4 -3
  67. package/dist/chunk-YN467EEQ.js.map +1 -0
  68. package/dist/{chunk-CZRM7LT7.js → chunk-YQANC7HQ.js} +4 -3
  69. package/dist/chunk-YQANC7HQ.js.map +1 -0
  70. package/dist/{chunk-NYCIK4SU.cjs → chunk-YXIIWLLB.cjs} +13 -12
  71. package/dist/chunk-YXIIWLLB.cjs.map +1 -0
  72. package/dist/chunk-Z3WOHHG3.js +1873 -0
  73. package/dist/chunk-Z3WOHHG3.js.map +1 -0
  74. package/dist/{chunk-2UKC6ZCY.cjs → chunk-Z63XPA2V.cjs} +12 -11
  75. package/dist/chunk-Z63XPA2V.cjs.map +1 -0
  76. package/dist/{chunk-V6WO7RK7.cjs → chunk-ZNOD4VZT.cjs} +5 -4
  77. package/dist/chunk-ZNOD4VZT.cjs.map +1 -0
  78. package/dist/{chunk-3J7TFUOC.js → chunk-ZNZIL244.js} +4 -3
  79. package/dist/{chunk-3J7TFUOC.js.map → chunk-ZNZIL244.js.map} +1 -1
  80. package/dist/{chunk-2MQWZ2XY.cjs → chunk-ZO77FHBF.cjs} +3 -2
  81. package/dist/chunk-ZO77FHBF.cjs.map +1 -0
  82. package/dist/diagrams/blockdiagram/index.cjs +5 -5
  83. package/dist/diagrams/blockdiagram/index.d.cts +1 -1
  84. package/dist/diagrams/blockdiagram/index.d.ts +1 -1
  85. package/dist/diagrams/blockdiagram/index.js +1 -1
  86. package/dist/diagrams/circuit/index.cjs +8 -8
  87. package/dist/diagrams/circuit/index.d.cts +1 -1
  88. package/dist/diagrams/circuit/index.d.ts +1 -1
  89. package/dist/diagrams/circuit/index.js +2 -2
  90. package/dist/diagrams/ecomap/index.cjs +7 -7
  91. package/dist/diagrams/ecomap/index.d.cts +1 -1
  92. package/dist/diagrams/ecomap/index.d.ts +1 -1
  93. package/dist/diagrams/ecomap/index.js +2 -2
  94. package/dist/diagrams/entity/index.cjs +6 -6
  95. package/dist/diagrams/entity/index.d.cts +1 -1
  96. package/dist/diagrams/entity/index.d.ts +1 -1
  97. package/dist/diagrams/entity/index.js +2 -2
  98. package/dist/diagrams/fishbone/index.cjs +8 -8
  99. package/dist/diagrams/fishbone/index.d.cts +1 -1
  100. package/dist/diagrams/fishbone/index.d.ts +1 -1
  101. package/dist/diagrams/fishbone/index.js +2 -2
  102. package/dist/diagrams/flowchart/index.cjs +8 -8
  103. package/dist/diagrams/flowchart/index.d.cts +2 -2
  104. package/dist/diagrams/flowchart/index.d.ts +2 -2
  105. package/dist/diagrams/flowchart/index.js +2 -2
  106. package/dist/diagrams/genogram/index.cjs +9 -9
  107. package/dist/diagrams/genogram/index.d.cts +1 -1
  108. package/dist/diagrams/genogram/index.d.ts +1 -1
  109. package/dist/diagrams/genogram/index.js +2 -2
  110. package/dist/diagrams/ladder/index.cjs +6 -6
  111. package/dist/diagrams/ladder/index.d.cts +1 -1
  112. package/dist/diagrams/ladder/index.d.ts +1 -1
  113. package/dist/diagrams/ladder/index.js +2 -2
  114. package/dist/diagrams/logic/index.cjs +6 -6
  115. package/dist/diagrams/logic/index.d.cts +1 -1
  116. package/dist/diagrams/logic/index.d.ts +1 -1
  117. package/dist/diagrams/logic/index.js +2 -2
  118. package/dist/diagrams/orgchart/index.cjs +7 -7
  119. package/dist/diagrams/orgchart/index.d.cts +1 -1
  120. package/dist/diagrams/orgchart/index.d.ts +1 -1
  121. package/dist/diagrams/orgchart/index.js +2 -2
  122. package/dist/diagrams/pedigree/index.cjs +7 -7
  123. package/dist/diagrams/pedigree/index.d.cts +1 -1
  124. package/dist/diagrams/pedigree/index.d.ts +1 -1
  125. package/dist/diagrams/pedigree/index.js +2 -2
  126. package/dist/diagrams/phylo/index.cjs +7 -7
  127. package/dist/diagrams/phylo/index.d.cts +1 -1
  128. package/dist/diagrams/phylo/index.d.ts +1 -1
  129. package/dist/diagrams/phylo/index.js +2 -2
  130. package/dist/diagrams/sld/index.cjs +6 -6
  131. package/dist/diagrams/sld/index.d.cts +1 -1
  132. package/dist/diagrams/sld/index.d.ts +1 -1
  133. package/dist/diagrams/sld/index.js +2 -2
  134. package/dist/diagrams/sociogram/index.cjs +6 -6
  135. package/dist/diagrams/sociogram/index.d.cts +1 -1
  136. package/dist/diagrams/sociogram/index.d.ts +1 -1
  137. package/dist/diagrams/sociogram/index.js +2 -2
  138. package/dist/diagrams/timing/index.cjs +4 -4
  139. package/dist/diagrams/timing/index.d.cts +1 -1
  140. package/dist/diagrams/timing/index.d.ts +1 -1
  141. package/dist/diagrams/timing/index.js +1 -1
  142. package/dist/diagrams/venn/index.cjs +9 -9
  143. package/dist/diagrams/venn/index.d.cts +1 -1
  144. package/dist/diagrams/venn/index.d.ts +1 -1
  145. package/dist/diagrams/venn/index.js +2 -2
  146. package/dist/export.cjs +87 -0
  147. package/dist/export.cjs.map +1 -0
  148. package/dist/export.d.cts +38 -0
  149. package/dist/export.d.ts +38 -0
  150. package/dist/export.js +83 -0
  151. package/dist/export.js.map +1 -0
  152. package/dist/{index-BXefHVce.d.cts → index-SSGpCggE.d.cts} +52 -3
  153. package/dist/{index-BSlza1YY.d.ts → index-ga04CTBI.d.ts} +52 -3
  154. package/dist/index.cjs +65 -1948
  155. package/dist/index.cjs.map +1 -1
  156. package/dist/index.d.cts +7 -12
  157. package/dist/index.d.ts +7 -12
  158. package/dist/index.js +19 -1942
  159. package/dist/index.js.map +1 -1
  160. package/dist/react.cjs +56 -0
  161. package/dist/react.cjs.map +1 -0
  162. package/dist/react.d.cts +24 -0
  163. package/dist/react.d.ts +24 -0
  164. package/dist/react.js +54 -0
  165. package/dist/react.js.map +1 -0
  166. package/dist/{types-DqfcYkcY.d.ts → types-BcPhMdHd.d.cts} +6 -2
  167. package/dist/{types-DqfcYkcY.d.cts → types-BcPhMdHd.d.ts} +6 -2
  168. package/package.json +34 -4
  169. package/dist/chunk-2MQWZ2XY.cjs.map +0 -1
  170. package/dist/chunk-2UKC6ZCY.cjs.map +0 -1
  171. package/dist/chunk-3FTUWAXK.cjs.map +0 -1
  172. package/dist/chunk-5C7DPDHQ.js.map +0 -1
  173. package/dist/chunk-7FZSPKX3.cjs.map +0 -1
  174. package/dist/chunk-ADOXGKAK.js +0 -1251
  175. package/dist/chunk-ADOXGKAK.js.map +0 -1
  176. package/dist/chunk-CZRM7LT7.js.map +0 -1
  177. package/dist/chunk-D4JTSPOL.js.map +0 -1
  178. package/dist/chunk-DS47NTWZ.cjs.map +0 -1
  179. package/dist/chunk-FDLZEKEB.js.map +0 -1
  180. package/dist/chunk-FGPTCDUT.cjs.map +0 -1
  181. package/dist/chunk-HGHWCB6K.js.map +0 -1
  182. package/dist/chunk-IX554O5K.js.map +0 -1
  183. package/dist/chunk-MDICUK6F.cjs +0 -1258
  184. package/dist/chunk-MDICUK6F.cjs.map +0 -1
  185. package/dist/chunk-N7KOXOMX.cjs.map +0 -1
  186. package/dist/chunk-NYCIK4SU.cjs.map +0 -1
  187. package/dist/chunk-PDPHRZZT.js.map +0 -1
  188. package/dist/chunk-ROFLJ74T.js.map +0 -1
  189. package/dist/chunk-S6BK5DB6.cjs.map +0 -1
  190. package/dist/chunk-U5GGE6PJ.js.map +0 -1
  191. package/dist/chunk-V6WO7RK7.cjs.map +0 -1
  192. package/dist/chunk-VFQCTXOX.js.map +0 -1
  193. package/dist/chunk-XQ52ICHU.cjs.map +0 -1
  194. package/dist/chunk-XX4BKS7Y.js.map +0 -1
  195. package/dist/chunk-XXU36667.js.map +0 -1
  196. package/dist/chunk-ZX7QKZK2.cjs.map +0 -1
package/README.md CHANGED
@@ -1,10 +1,11 @@
1
1
  <p align="center">
2
- <strong>SchemaTex</strong><br>
3
- <em>Standards-as-code for professional diagrams.</em>
2
+ <strong>Schematex</strong><br>
3
+ <em>Every diagram a doctor, engineer, or lawyer would actually use.</em><br>
4
+ <em>Free. Fully open source. Made for AI.</em>
4
5
  </p>
5
6
 
6
7
  <p align="center">
7
- McGoldrick genograms · NSGC pedigrees · IEC 61131-3 ladder logic · IEEE 315 single-line diagrams · Newick phylogenetic trees · Moreno sociograms · and 7 more — all from a tiny text DSL, with zero runtime dependencies.
8
+ McGoldrick genograms · NSGC pedigrees · IEC 61131-3 ladder logic · IEEE 315 single-line diagrams · Newick phylogenetic trees · Howard-Raiffa decision trees · Moreno sociograms · and more — all from a tiny text DSL, with zero runtime dependencies.
8
9
  </p>
9
10
 
10
11
  <p align="center">
@@ -22,18 +23,23 @@
22
23
  <a href="./LICENSE"><img src="https://img.shields.io/badge/license-AGPL--3.0-blue" alt="license"></a>
23
24
  </p>
24
25
 
26
+ <p align="center">
27
+ <img src="./website/public/hero-demo.gif" alt="Schematex demo — genogram, pedigree, ladder logic, phylo, entity structure, fishbone, circuit, ecomap, timing" width="720">
28
+ </p>
29
+
25
30
  ---
26
31
 
27
- **SchemaTex** is the open-source rendering engine for diagrams that follow real industry standards. Thirteen diagram families across four domains:
32
+ **Schematex** is the open-source rendering engine for the diagrams professionals actually use medical, electrical, legal, and analytical. 20 diagram families across five domains:
28
33
 
29
34
  - 👪 **Relationships** — genograms, ecomaps, pedigrees, sociograms, phylogenetic trees
30
35
  - ⚡ **Electrical & Industrial** — ladder logic, single-line diagrams, circuit schematics, logic gates, timing, block diagrams
31
36
  - 🏢 **Corporate & Legal** — entity structures, cap tables
32
- - 🐟 **Causality & Analysis** — fishbone / Ishikawa
37
+ - 🐟 **Causality & Analysis** — fishbone / Ishikawa, decision trees (Howard-Raiffa EV · CART/sklearn · taxonomy)
38
+ - 📅 **Timelines** — proportional / equidistant / log axis · swimlane · gantt · lollipop · BC dates · geological Ma scale
33
39
 
34
- Mermaid draws generic flowcharts. SchemaTex draws the diagrams your domain experts actually sign off on — a genogram a genetic counselor accepts clinically, ladder logic that maps 1:1 to IEC 61131-3, a cap table that survives a Series A review.
40
+ Mermaid draws generic flowcharts. Schematex draws the diagrams doctors, engineers, and lawyers actually use — a genogram a genetic counselor accepts clinically, ladder logic that maps 1:1 to IEC 61131-3, a cap table that survives a Series A review.
35
41
 
36
- **Zero runtime dependencies** · 📐 **10+ industry standards** · 🤖 **LLM-native DSL** · 🌱 **SSR-ready pure SVG**
42
+ 🆓 **Free & fully open source** · 📐 **10+ industry standards** · 🤖 **Made for AI** · 🌱 **SSR-ready pure SVG · Zero deps**
37
43
 
38
44
  ## Install
39
45
 
@@ -64,7 +70,7 @@ import { render } from 'schematex/genogram';
64
70
 
65
71
  ## Gallery
66
72
 
67
- Thirteen diagram types, one unified pipeline. **Try any of these live at [schematex.dev/playground](https://schematex.dev/playground).**
73
+ 20 diagram types, one unified pipeline. **Try any of these live at [schematex.dev/playground](https://schematex.dev/playground).**
68
74
 
69
75
  ### 👪 Genogram — *McGoldrick family-systems standard*
70
76
 
@@ -378,6 +384,101 @@ algo : "Core Update penalty" : "Weak E-E-A-T signals" : "SGE traffic diversion"
378
384
 
379
385
  [Fishbone syntax →](https://schematex.dev/docs/fishbone)
380
386
 
387
+ ### 🌳 Decision Tree — *Howard-Raiffa · CART/sklearn · Taxonomy*
388
+
389
+ Three modes in one DSL. Decision analysis with EV rollback (Howard-Raiffa), ML tree visualization (sklearn `plot_tree` style), and yes/no taxonomy trees. Diagonal edge routing, payoff-aligned columns, optimal-path highlighting.
390
+
391
+ **Decision analysis — EV rollback:**
392
+ ```
393
+ decisiontree:decision "Oil drilling"
394
+
395
+ decision "Drill or sell rights?"
396
+ choice "Sell rights"
397
+ end payoff=90000 "Guaranteed sale"
398
+ choice "Drill"
399
+ chance "Well outcome"
400
+ prob 0.3 end payoff=500000 "Major strike"
401
+ prob 0.5 end payoff=50000 "Minor strike"
402
+ prob 0.2 end payoff=-200000 "Dry hole"
403
+ ```
404
+
405
+ **ML tree — sklearn CART style:**
406
+ ```
407
+ decisiontree:ml "Iris classification"
408
+ classes: setosa, versicolor, virginica
409
+ impurity: gini
410
+ branchLabels: relation
411
+
412
+ split feature=petal_width op=<= threshold=0.8 samples=120 value=[50,35,35] gini=0.66
413
+ true leaf samples=50 value=[50,0,0] gini=0 class=setosa
414
+ false split feature=petal_width op=<= threshold=1.75 samples=70 value=[0,35,35] gini=0.5
415
+ true leaf samples=36 value=[0,32,4] gini=0.198 class=versicolor
416
+ false leaf samples=34 value=[0,3,31] gini=0.162 class=virginica
417
+ ```
418
+
419
+ **Taxonomy — yes/no classification:**
420
+ ```
421
+ decisiontree:taxonomy "ED Triage Level"
422
+ direction: left-right
423
+
424
+ q "Airway compromise?"
425
+ yes: a "Level 1 — Resuscitation"
426
+ no: q "Vital signs unstable?"
427
+ yes: a "Level 2 — Emergent"
428
+ no: q "Multiple resources needed?"
429
+ yes: a "Level 3 — Urgent"
430
+ no: a "Level 4/5 — Less urgent"
431
+ ```
432
+
433
+ [Decision Tree syntax →](https://schematex.dev/docs/decisiontree)
434
+
435
+ ---
436
+
437
+ ### 📅 Timeline
438
+
439
+ Historical events, biographical lifelines, product roadmaps, and geological timescales on a proportional / equidistant / log axis. Three visual styles: **swimlane** (multi-track biographies), **gantt** (project plan with pins + category lanes + legend), and **lollipop** (alternating above/below cards on a center axis). Supports BC/AD dates, quarter dates (`2026-Q1`), and geological mega-year (`Ma`) scale.
440
+
441
+ ```
442
+ timeline "Apollo program"
443
+
444
+ 1961-05-25: milestone "Kennedy Moon speech"
445
+ 1967-01-27: "Apollo 1 fire"
446
+ 1968-12-21 - 1968-12-27: "Apollo 8 — first lunar orbit"
447
+ 1969-07-16 - 1969-07-24: "Apollo 11 — Moon landing" [icon:🚀]
448
+ 1970-04-11 - 1970-04-17: "Apollo 13 — abort"
449
+ 1972-12-07 - 1972-12-19: "Apollo 17 — last crewed Moon mission"
450
+ ```
451
+
452
+ ```
453
+ timeline "Brand story"
454
+ config: style = lollipop
455
+
456
+ era 2015 - 2019: "Scrappy startup"
457
+ era 2019 - 2023: "Scale-up"
458
+ era 2023 - 2027: "Enterprise era"
459
+
460
+ 2015: "Founded in a coffee shop" [icon:☕]
461
+ 2017: milestone "First 1000 users" [icon:👥]
462
+ 2019: "Series A" [icon:💰]
463
+ 2021: "Opened NYC office" [icon:🏙]
464
+ 2023: milestone "Crossed $50M ARR" [icon:📊]
465
+ 2025: "Acquired Acme Inc." [icon:🤝]
466
+ ```
467
+
468
+ ```
469
+ timeline "Q2 Launch plan"
470
+ config: style = gantt
471
+
472
+ 2026-04-01: milestone "Kickoff"
473
+ 2026-06-30: milestone "GA launch" [icon:🚀]
474
+
475
+ 2026-04-01 - 2026-04-30: "Research & specs" [category: "Design"]
476
+ 2026-04-10 - 2026-06-10: "API build" [category: "Eng"]
477
+ 2026-05-15 - 2026-06-25: "Campaign prep" [category: "Marketing"]
478
+ ```
479
+
480
+ [Timeline syntax →](https://schematex.dev/docs/timeline)
481
+
381
482
  ## Why SchemaTex?
382
483
 
383
484
  **Generic flowchart tools can't draw professional diagrams.** Every diagram domain has published standards — symbol conventions, layout rules, labelling grammars — and when you ignore them, domain experts reject the output:
@@ -413,22 +514,36 @@ Written by humans, shaped by what LLMs get wrong.
413
514
  ## API
414
515
 
415
516
  ```ts
416
- // Universal entry — dispatches by first keyword
517
+ // Universal entry — auto-detects diagram type from first keyword
417
518
  import { render, parse } from 'schematex';
418
519
 
419
- render(text: string, config?: SchematexConfig): string;
420
- parse(text: string, config?: SchematexConfig): AST;
520
+ const svg = render(text, config?); // → SVG string
521
+ const ast = parse(text, config?); // AST (JSON-serializable)
522
+
523
+ // Per-diagram tree-shaking
524
+ import { render } from 'schematex/genogram';
525
+
526
+ // Browser DOM
527
+ import { renderToElement, renderToContainer } from 'schematex/browser';
528
+ container.appendChild(renderToElement(dsl));
529
+
530
+ // React
531
+ import { SchematexDiagram } from 'schematex/react';
532
+ // <SchematexDiagram dsl="genogram ..." theme="monochrome" />
421
533
 
422
- // Per-diagram (tree-shakable)
423
- import { render as renderGenogram } from 'schematex/genogram';
424
- import { render as renderLadder } from 'schematex/ladder';
534
+ // Export (browser Canvas)
535
+ import { svgToPngBlob, downloadBlob, printSvgAsPdf } from 'schematex/export';
536
+ const blob = await svgToPngBlob(svg, { scale: 2 });
537
+ downloadBlob(blob, 'diagram.png');
425
538
  ```
426
539
 
427
540
  See the [API reference →](https://schematex.dev/docs/api).
428
541
 
429
542
  ## Ecosystem
430
543
 
431
- - **React** — `@schematex/react` *(coming soon)*
544
+ - **React** — `schematex/react` `<SchematexDiagram dsl="..." />` component
545
+ - **Browser** — `schematex/browser` — `renderToElement()` / `renderToContainer()`
546
+ - **Export** — `schematex/export` — PNG (@2×) + print-to-PDF via browser Canvas
432
547
  - **Obsidian** — code-block renderer plugin *(coming soon)*
433
548
  - **Markdown-it / remark** — diagram fence support *(coming soon)*
434
549
  - **CLI** — `npx schematex input.txt > output.svg` *(coming soon)*
@@ -0,0 +1,22 @@
1
+ interface SchematexConfig {
2
+ type?: "genogram" | "ecomap" | "pedigree" | "phylo" | "sociogram" | "timing" | "logic" | "circuit" | "blockdiagram" | "ladder" | "sld" | "entity" | "fishbone" | "venn" | "flowchart" | "mindmap" | "matrix" | "orgchart" | "decisiontree" | "timeline";
3
+ width?: number;
4
+ height?: number;
5
+ padding?: number;
6
+ theme?: string;
7
+ fontFamily?: string;
8
+ }
9
+ /**
10
+ * Parse DSL text to the diagram's AST and return it as a plain object.
11
+ * Useful for JSON serialization, programmatic inspection, or custom renderers.
12
+ *
13
+ * @example
14
+ * ```ts
15
+ * const ast = parse('genogram\n alice [female]');
16
+ * console.log(JSON.stringify(ast, null, 2));
17
+ * ```
18
+ */
19
+ declare function parse(text: string, config?: SchematexConfig): unknown;
20
+ declare function render(text: string, config?: SchematexConfig): string;
21
+
22
+ export { type SchematexConfig as S, parse as p, render as r };
@@ -0,0 +1,22 @@
1
+ interface SchematexConfig {
2
+ type?: "genogram" | "ecomap" | "pedigree" | "phylo" | "sociogram" | "timing" | "logic" | "circuit" | "blockdiagram" | "ladder" | "sld" | "entity" | "fishbone" | "venn" | "flowchart" | "mindmap" | "matrix" | "orgchart" | "decisiontree" | "timeline";
3
+ width?: number;
4
+ height?: number;
5
+ padding?: number;
6
+ theme?: string;
7
+ fontFamily?: string;
8
+ }
9
+ /**
10
+ * Parse DSL text to the diagram's AST and return it as a plain object.
11
+ * Useful for JSON serialization, programmatic inspection, or custom renderers.
12
+ *
13
+ * @example
14
+ * ```ts
15
+ * const ast = parse('genogram\n alice [female]');
16
+ * console.log(JSON.stringify(ast, null, 2));
17
+ * ```
18
+ */
19
+ declare function parse(text: string, config?: SchematexConfig): unknown;
20
+ declare function render(text: string, config?: SchematexConfig): string;
21
+
22
+ export { type SchematexConfig as S, parse as p, render as r };
@@ -0,0 +1,46 @@
1
+ 'use strict';
2
+
3
+ var chunk7HKXU7J2_cjs = require('./chunk-7HKXU7J2.cjs');
4
+ require('./chunk-7IRT3LOY.cjs');
5
+ require('./chunk-4S2WILLW.cjs');
6
+ require('./chunk-LXNFVHDT.cjs');
7
+ require('./chunk-ISACNVFE.cjs');
8
+ require('./chunk-QR7VTCI4.cjs');
9
+ require('./chunk-ZNOD4VZT.cjs');
10
+ require('./chunk-LKOBOVNL.cjs');
11
+ require('./chunk-QSQX77S2.cjs');
12
+ require('./chunk-CXHPP5BL.cjs');
13
+ require('./chunk-Z63XPA2V.cjs');
14
+ require('./chunk-XHZ7GXP2.cjs');
15
+ require('./chunk-XVCAOGFL.cjs');
16
+ require('./chunk-X7RPFTTR.cjs');
17
+ require('./chunk-YXIIWLLB.cjs');
18
+ require('./chunk-ZO77FHBF.cjs');
19
+ require('./chunk-WYFXOXVK.cjs');
20
+ require('./chunk-D7EHZFK4.cjs');
21
+ require('./chunk-HDKDQAEQ.cjs');
22
+
23
+ // src/browser.ts
24
+ function renderToElement(text, config) {
25
+ const svgString = chunk7HKXU7J2_cjs.render(text, config);
26
+ const parser = new DOMParser();
27
+ const doc = parser.parseFromString(svgString, "image/svg+xml");
28
+ const el = doc.documentElement;
29
+ const parseError = doc.querySelector("parsererror");
30
+ if (parseError) {
31
+ throw new Error(`SVG parse error: ${parseError.textContent}`);
32
+ }
33
+ return el;
34
+ }
35
+ function renderToContainer(text, container, config) {
36
+ container.innerHTML = chunk7HKXU7J2_cjs.render(text, config);
37
+ }
38
+
39
+ Object.defineProperty(exports, "render", {
40
+ enumerable: true,
41
+ get: function () { return chunk7HKXU7J2_cjs.render; }
42
+ });
43
+ exports.renderToContainer = renderToContainer;
44
+ exports.renderToElement = renderToElement;
45
+ //# sourceMappingURL=browser.cjs.map
46
+ //# sourceMappingURL=browser.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/browser.ts"],"names":["render"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAmBO,SAAS,eAAA,CACd,MACA,MAAA,EACe;AACf,EAAA,MAAM,SAAA,GAAYA,wBAAA,CAAO,IAAA,EAAM,MAAM,CAAA;AACrC,EAAA,MAAM,MAAA,GAAS,IAAI,SAAA,EAAU;AAC7B,EAAA,MAAM,GAAA,GAAM,MAAA,CAAO,eAAA,CAAgB,SAAA,EAAW,eAAe,CAAA;AAC7D,EAAA,MAAM,KAAK,GAAA,CAAI,eAAA;AACf,EAAA,MAAM,UAAA,GAAa,GAAA,CAAI,aAAA,CAAc,aAAa,CAAA;AAClD,EAAA,IAAI,UAAA,EAAY;AACd,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,iBAAA,EAAoB,UAAA,CAAW,WAAW,CAAA,CAAE,CAAA;AAAA,EAC9D;AACA,EAAA,OAAO,EAAA;AACT;AAKO,SAAS,iBAAA,CACd,IAAA,EACA,SAAA,EACA,MAAA,EACM;AACN,EAAA,SAAA,CAAU,SAAA,GAAYA,wBAAA,CAAO,IAAA,EAAM,MAAM,CAAA;AAC3C","file":"browser.cjs","sourcesContent":["/**\n * Browser-specific utilities for Schematex.\n *\n * These APIs require a DOM environment. Do not import in SSR/Node contexts.\n *\n * @example\n * ```ts\n * import { renderToElement, renderToContainer } from 'schematex/browser';\n *\n * const svg = renderToElement('genogram\\n alice [female]');\n * document.getElementById('diagram')!.appendChild(svg);\n * ```\n */\n\nimport { render, type SchematexConfig } from \"./core/api\";\n\n/**\n * Render DSL text to a live `SVGSVGElement` ready to insert into the DOM.\n */\nexport function renderToElement(\n text: string,\n config?: SchematexConfig\n): SVGSVGElement {\n const svgString = render(text, config);\n const parser = new DOMParser();\n const doc = parser.parseFromString(svgString, \"image/svg+xml\");\n const el = doc.documentElement;\n const parseError = doc.querySelector(\"parsererror\");\n if (parseError) {\n throw new Error(`SVG parse error: ${parseError.textContent}`);\n }\n return el as unknown as SVGSVGElement;\n}\n\n/**\n * Render DSL text and inject SVG into a container element (replaces innerHTML).\n */\nexport function renderToContainer(\n text: string,\n container: Element,\n config?: SchematexConfig\n): void {\n container.innerHTML = render(text, config);\n}\n\nexport { render, type SchematexConfig } from \"./core/api\";\n"]}
@@ -0,0 +1,27 @@
1
+ import { S as SchematexConfig } from './api-bQZ98gkJ.cjs';
2
+ export { r as render } from './api-bQZ98gkJ.cjs';
3
+
4
+ /**
5
+ * Browser-specific utilities for Schematex.
6
+ *
7
+ * These APIs require a DOM environment. Do not import in SSR/Node contexts.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * import { renderToElement, renderToContainer } from 'schematex/browser';
12
+ *
13
+ * const svg = renderToElement('genogram\n alice [female]');
14
+ * document.getElementById('diagram')!.appendChild(svg);
15
+ * ```
16
+ */
17
+
18
+ /**
19
+ * Render DSL text to a live `SVGSVGElement` ready to insert into the DOM.
20
+ */
21
+ declare function renderToElement(text: string, config?: SchematexConfig): SVGSVGElement;
22
+ /**
23
+ * Render DSL text and inject SVG into a container element (replaces innerHTML).
24
+ */
25
+ declare function renderToContainer(text: string, container: Element, config?: SchematexConfig): void;
26
+
27
+ export { SchematexConfig, renderToContainer, renderToElement };
@@ -0,0 +1,27 @@
1
+ import { S as SchematexConfig } from './api-bQZ98gkJ.js';
2
+ export { r as render } from './api-bQZ98gkJ.js';
3
+
4
+ /**
5
+ * Browser-specific utilities for Schematex.
6
+ *
7
+ * These APIs require a DOM environment. Do not import in SSR/Node contexts.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * import { renderToElement, renderToContainer } from 'schematex/browser';
12
+ *
13
+ * const svg = renderToElement('genogram\n alice [female]');
14
+ * document.getElementById('diagram')!.appendChild(svg);
15
+ * ```
16
+ */
17
+
18
+ /**
19
+ * Render DSL text to a live `SVGSVGElement` ready to insert into the DOM.
20
+ */
21
+ declare function renderToElement(text: string, config?: SchematexConfig): SVGSVGElement;
22
+ /**
23
+ * Render DSL text and inject SVG into a container element (replaces innerHTML).
24
+ */
25
+ declare function renderToContainer(text: string, container: Element, config?: SchematexConfig): void;
26
+
27
+ export { SchematexConfig, renderToContainer, renderToElement };
@@ -0,0 +1,40 @@
1
+ import { render } from './chunk-UUPYTUGR.js';
2
+ export { render } from './chunk-UUPYTUGR.js';
3
+ import './chunk-LCR3KOJV.js';
4
+ import './chunk-PGALHQFF.js';
5
+ import './chunk-5SH5NUDW.js';
6
+ import './chunk-ZNZIL244.js';
7
+ import './chunk-X2BQKXMA.js';
8
+ import './chunk-M5B2UUNW.js';
9
+ import './chunk-6YMQSTFF.js';
10
+ import './chunk-JDTB7IKL.js';
11
+ import './chunk-Z3WOHHG3.js';
12
+ import './chunk-YN467EEQ.js';
13
+ import './chunk-CJ2A3UEQ.js';
14
+ import './chunk-4KYW63IK.js';
15
+ import './chunk-YQANC7HQ.js';
16
+ import './chunk-5UV5VQ7J.js';
17
+ import './chunk-GEPBET4L.js';
18
+ import './chunk-5YYAYW67.js';
19
+ import './chunk-2VNMKOUO.js';
20
+ import './chunk-KLJEK547.js';
21
+
22
+ // src/browser.ts
23
+ function renderToElement(text, config) {
24
+ const svgString = render(text, config);
25
+ const parser = new DOMParser();
26
+ const doc = parser.parseFromString(svgString, "image/svg+xml");
27
+ const el = doc.documentElement;
28
+ const parseError = doc.querySelector("parsererror");
29
+ if (parseError) {
30
+ throw new Error(`SVG parse error: ${parseError.textContent}`);
31
+ }
32
+ return el;
33
+ }
34
+ function renderToContainer(text, container, config) {
35
+ container.innerHTML = render(text, config);
36
+ }
37
+
38
+ export { renderToContainer, renderToElement };
39
+ //# sourceMappingURL=browser.js.map
40
+ //# sourceMappingURL=browser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/browser.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAmBO,SAAS,eAAA,CACd,MACA,MAAA,EACe;AACf,EAAA,MAAM,SAAA,GAAY,MAAA,CAAO,IAAA,EAAM,MAAM,CAAA;AACrC,EAAA,MAAM,MAAA,GAAS,IAAI,SAAA,EAAU;AAC7B,EAAA,MAAM,GAAA,GAAM,MAAA,CAAO,eAAA,CAAgB,SAAA,EAAW,eAAe,CAAA;AAC7D,EAAA,MAAM,KAAK,GAAA,CAAI,eAAA;AACf,EAAA,MAAM,UAAA,GAAa,GAAA,CAAI,aAAA,CAAc,aAAa,CAAA;AAClD,EAAA,IAAI,UAAA,EAAY;AACd,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,iBAAA,EAAoB,UAAA,CAAW,WAAW,CAAA,CAAE,CAAA;AAAA,EAC9D;AACA,EAAA,OAAO,EAAA;AACT;AAKO,SAAS,iBAAA,CACd,IAAA,EACA,SAAA,EACA,MAAA,EACM;AACN,EAAA,SAAA,CAAU,SAAA,GAAY,MAAA,CAAO,IAAA,EAAM,MAAM,CAAA;AAC3C","file":"browser.js","sourcesContent":["/**\n * Browser-specific utilities for Schematex.\n *\n * These APIs require a DOM environment. Do not import in SSR/Node contexts.\n *\n * @example\n * ```ts\n * import { renderToElement, renderToContainer } from 'schematex/browser';\n *\n * const svg = renderToElement('genogram\\n alice [female]');\n * document.getElementById('diagram')!.appendChild(svg);\n * ```\n */\n\nimport { render, type SchematexConfig } from \"./core/api\";\n\n/**\n * Render DSL text to a live `SVGSVGElement` ready to insert into the DOM.\n */\nexport function renderToElement(\n text: string,\n config?: SchematexConfig\n): SVGSVGElement {\n const svgString = render(text, config);\n const parser = new DOMParser();\n const doc = parser.parseFromString(svgString, \"image/svg+xml\");\n const el = doc.documentElement;\n const parseError = doc.querySelector(\"parsererror\");\n if (parseError) {\n throw new Error(`SVG parse error: ${parseError.textContent}`);\n }\n return el as unknown as SVGSVGElement;\n}\n\n/**\n * Render DSL text and inject SVG into a container element (replaces innerHTML).\n */\nexport function renderToContainer(\n text: string,\n container: Element,\n config?: SchematexConfig\n): void {\n container.innerHTML = render(text, config);\n}\n\nexport { render, type SchematexConfig } from \"./core/api\";\n"]}
@@ -178,15 +178,30 @@ var VENN_TOKENS = {
178
178
  };
179
179
  var DEFAULT_MINDMAP = {
180
180
  centralFill: "#0f172a",
181
- branchPalette: DEFAULT_PALETTE
181
+ branchPalette: DEFAULT_PALETTE,
182
+ codeFg: "#be185d",
183
+ codeBg: "#fdf2f8",
184
+ linkColor: "#2563eb",
185
+ checkboxStroke: "#64748b",
186
+ checkboxFill: "#10b981"
182
187
  };
183
188
  var MONOCHROME_MINDMAP = {
184
189
  centralFill: "#000000",
185
- branchPalette: ["#000000"]
190
+ branchPalette: ["#000000"],
191
+ codeFg: "#000000",
192
+ codeBg: "#e5e5e5",
193
+ linkColor: "#000000",
194
+ checkboxStroke: "#000000",
195
+ checkboxFill: "#000000"
186
196
  };
187
197
  var DARK_MINDMAP = {
188
198
  centralFill: "#cdd6f4",
189
- branchPalette: DARK_PALETTE
199
+ branchPalette: DARK_PALETTE,
200
+ codeFg: "#f5c2e7",
201
+ codeBg: "#313244",
202
+ linkColor: "#89b4fa",
203
+ checkboxStroke: "#a6adc8",
204
+ checkboxFill: "#a6e3a1"
190
205
  };
191
206
  var MINDMAP_TOKENS = {
192
207
  default: DEFAULT_MINDMAP,
@@ -281,6 +296,75 @@ function resolveMindmapTheme(name) {
281
296
  const themeName = name in BASE_THEMES ? name : "default";
282
297
  return { ...BASE_THEMES[themeName], ...MINDMAP_TOKENS[themeName] };
283
298
  }
299
+ var DEFAULT_TIMELINE = {
300
+ axis: "#334155",
301
+ axisLabel: "#475569",
302
+ eraLabel: "#0f172a",
303
+ eraOpacity: 0.55,
304
+ eraPlotOpacity: 0.14,
305
+ laneStripe: "#f1f5f9",
306
+ laneStripeOpacity: 0.6,
307
+ categoryPalette: DEFAULT_PALETTE,
308
+ markerRing: "#2563eb",
309
+ markerFill: "#ffffff",
310
+ milestoneFill: "#d97706",
311
+ pinShaft: "#94a3b8",
312
+ cardBg: "#ffffff",
313
+ cardStroke: "#cbd5e1",
314
+ cardText: "#0f172a",
315
+ cardShadow: "rgba(15,23,42,0.08)",
316
+ legendBg: "#f8fafc",
317
+ legendStroke: "#e2e8f0"
318
+ };
319
+ var MONOCHROME_TIMELINE = {
320
+ axis: "#000000",
321
+ axisLabel: "#333333",
322
+ eraLabel: "#000000",
323
+ eraOpacity: 0.2,
324
+ eraPlotOpacity: 0.08,
325
+ laneStripe: "#f0f0f0",
326
+ laneStripeOpacity: 0.6,
327
+ categoryPalette: MONOCHROME_PALETTE,
328
+ markerRing: "#000000",
329
+ markerFill: "#ffffff",
330
+ milestoneFill: "#000000",
331
+ pinShaft: "#888888",
332
+ cardBg: "#ffffff",
333
+ cardStroke: "#000000",
334
+ cardText: "#000000",
335
+ cardShadow: "rgba(0,0,0,0.06)",
336
+ legendBg: "#ffffff",
337
+ legendStroke: "#000000"
338
+ };
339
+ var DARK_TIMELINE = {
340
+ axis: "#cdd6f4",
341
+ axisLabel: "#9399b2",
342
+ eraLabel: "#cdd6f4",
343
+ eraOpacity: 0.5,
344
+ eraPlotOpacity: 0.18,
345
+ laneStripe: "#313244",
346
+ laneStripeOpacity: 0.5,
347
+ categoryPalette: DARK_PALETTE,
348
+ markerRing: "#89b4fa",
349
+ markerFill: "#1e1e2e",
350
+ milestoneFill: "#fab387",
351
+ pinShaft: "#6c7086",
352
+ cardBg: "#313244",
353
+ cardStroke: "#45475a",
354
+ cardText: "#cdd6f4",
355
+ cardShadow: "rgba(0,0,0,0.35)",
356
+ legendBg: "#181825",
357
+ legendStroke: "#45475a"
358
+ };
359
+ var TIMELINE_TOKENS = {
360
+ default: DEFAULT_TIMELINE,
361
+ monochrome: MONOCHROME_TIMELINE,
362
+ dark: DARK_TIMELINE
363
+ };
364
+ function resolveTimelineTheme(name) {
365
+ const themeName = name in BASE_THEMES ? name : "default";
366
+ return { ...BASE_THEMES[themeName], ...TIMELINE_TOKENS[themeName] };
367
+ }
284
368
  function resolveBaseTheme(name) {
285
369
  return BASE_THEMES[name] ?? BASE_THEMES["default"];
286
370
  }
@@ -341,6 +425,6 @@ function cssCustomProperties(theme) {
341
425
  --schematex-stroke-thick: ${STROKE_WIDTH.thick};`;
342
426
  }
343
427
 
344
- export { BASE_THEMES, BIOLOGY_TOKENS, FONT_SIZE, PERSON_TOKENS, STROKE_WIDTH, VENN_TOKENS, cssCustomProperties, resolveBaseTheme, resolveBiologyTheme, resolveFishboneTheme, resolveFlowchartTheme, resolveGenogramTheme, resolveIndustrialTheme, resolveMindmapTheme, resolvePersonTheme, resolveVennTheme };
345
- //# sourceMappingURL=chunk-IX554O5K.js.map
346
- //# sourceMappingURL=chunk-IX554O5K.js.map
428
+ export { BASE_THEMES, BIOLOGY_TOKENS, FONT_SIZE, PERSON_TOKENS, STROKE_WIDTH, VENN_TOKENS, cssCustomProperties, resolveBaseTheme, resolveBiologyTheme, resolveFishboneTheme, resolveFlowchartTheme, resolveGenogramTheme, resolveIndustrialTheme, resolveMindmapTheme, resolvePersonTheme, resolveTimelineTheme, resolveVennTheme };
429
+ //# sourceMappingURL=chunk-2VNMKOUO.js.map
430
+ //# sourceMappingURL=chunk-2VNMKOUO.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/core/theme.ts"],"names":[],"mappings":"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","file":"chunk-2VNMKOUO.js","sourcesContent":["/**\n * Shared design-token system for all Schematex diagram renderers.\n *\n * Two-layer architecture:\n * 1. BaseTheme — universal tokens every diagram uses\n * 2. Semantic extensions — diagram-family tokens (PersonTokens, BiologyTokens, …)\n *\n * Three built-in presets: default, monochrome, dark.\n * All tokens are also exposed as CSS custom properties (--schematex-*)\n * so consumers can override them.\n */\n\n// ─── Theme Name ────────────────────────────────────────────\n\nexport type ThemeName = \"default\" | \"monochrome\" | \"dark\";\n\n// ─── Base Theme ────────────────────────────────────────────\n\nexport interface BaseTheme {\n bg: string;\n text: string;\n textMuted: string;\n stroke: string;\n fill: string;\n fillMuted: string;\n /** Emphasis / interactive / link color. Use for net labels, focus, selected. */\n accent: string;\n positive: string;\n negative: string;\n /** Mid-gray. Use for muted strokes, neutral-valence edges, dashed separators. */\n neutral: string;\n warn: string;\n /** Category palette — 8 distinguishable colors for ecomap systems, sociogram groups, etc. */\n palette: readonly string[];\n}\n\n// ─── Diagram-Family Semantic Extensions ────────────────────\n\nexport interface PersonTokens {\n maleFill: string;\n femaleFill: string;\n unknownFill: string;\n deceasedMark: string;\n conditionFill: string;\n}\n\nexport interface BiologyTokens {\n cladeColors: readonly string[];\n supportGood: string;\n supportMedium: string;\n supportWarn: string;\n supportBad: string;\n}\n\n/**\n * Tokens for set-theory diagrams (Venn / Euler). Paletteof set fills is\n * tuned slightly softer than BaseTheme to blend nicely under\n * `mix-blend-mode: multiply`.\n */\nexport interface VennTokens {\n vennSetColors: readonly string[];\n vennBlendMode: \"multiply\" | \"screen\" | \"none\";\n vennSetOpacity: number;\n vennSetStroke: string;\n vennLabelColor: string;\n vennCountColor: string;\n vennLeaderColor: string;\n}\n\n/**\n * Tokens for industrial / compliance diagrams (circuit, ladder, SLD, logic gate).\n * These diagrams must stay monochrome under IEEE 315 / IEC 61131-3 standards, so\n * `default` and `monochrome` resolve to pure black-on-white. `dark` is the only\n * variant that shifts — it inverts luminance (light-on-dark) for dark-mode UI.\n * No colorful variant is exposed by design.\n */\nexport interface IndustrialTokens {\n bg: string;\n stroke: string;\n strokeHeavy: string;\n text: string;\n textMuted: string;\n /** Reserved accent for net/bus labels (not for body lines). */\n accent: string;\n /** Fault/missing-symbol indicator. */\n error: string;\n}\n\n/**\n * Tokens for flowchart semantic node classes. Kept separate from BaseTheme so\n * the class-fill palette can be themed without touching structural tokens.\n */\nexport interface FlowchartClassPair {\n fill: string;\n stroke: string;\n text: string;\n}\n\nexport interface FlowchartTokens {\n stadiumFill: string;\n diamondFill: string;\n roundFill: string;\n classes: {\n start: FlowchartClassPair;\n process: FlowchartClassPair;\n decision: FlowchartClassPair;\n success: FlowchartClassPair;\n danger: FlowchartClassPair;\n neutral: FlowchartClassPair;\n };\n}\n\n/**\n * Tokens for knowledge / brainstorming diagrams (mindmap).\n * Pure color tokens — stroke widths live in mindmap-internal constants.\n */\nexport interface MindmapTokens {\n centralFill: string;\n branchPalette: readonly string[];\n /** Inline `code` foreground/background. */\n codeFg: string;\n codeBg: string;\n /** Link color (with underline). */\n linkColor: string;\n /** Checkbox stroke color (unchecked state). */\n checkboxStroke: string;\n /** Checkbox fill when checked. */\n checkboxFill: string;\n}\n\n/**\n * Tokens for timeline diagrams. Palette-driven so categories/tracks share\n * colors with the rest of the diagram family (ecomap/sociogram/phylo).\n * Era bands and card surfaces use theme-neutral tints so no magic hex codes\n * leak into the renderer.\n */\nexport interface TimelineTokens {\n axis: string;\n axisLabel: string;\n eraLabel: string;\n eraOpacity: number;\n eraPlotOpacity: number;\n /** Alternating lane stripe fill. */\n laneStripe: string;\n laneStripeOpacity: number;\n /** Category / task bar palette. Cycled by `category` (fallback to trackIdx). */\n categoryPalette: readonly string[];\n /** Point/milestone ring — defaults to accent but configurable. */\n markerRing: string;\n markerFill: string;\n milestoneFill: string;\n /** Gantt vertical pin shaft. */\n pinShaft: string;\n /** Lollipop card. */\n cardBg: string;\n cardStroke: string;\n cardText: string;\n cardShadow: string;\n /** Gantt legend chip background. */\n legendBg: string;\n legendStroke: string;\n}\n\n// ─── Resolved Theme ────────────────────────────────────────\n\nexport type ResolvedTheme<T = object> = BaseTheme & T;\n\n// ─── Built-in Presets ──────────────────────────────────────\n\n/**\n * Unified 8-color category palettes. Single source of truth for every\n * diagram family — ecomap systems, sociogram groups, phylo clades, fishbone\n * bones, Venn sets all cycle through the same colors per theme.\n * Default uses Tailwind 600; dark uses Catppuccin Mocha; mono uses greys.\n */\nconst DEFAULT_PALETTE = [\n \"#2563eb\", // blue-600\n \"#059669\", // emerald-600\n \"#d97706\", // amber-600\n \"#7c3aed\", // violet-600\n \"#dc2626\", // red-600\n \"#0891b2\", // cyan-600\n \"#db2777\", // pink-600\n \"#475569\", // slate-600\n] as const;\n\nconst MONOCHROME_PALETTE = [\n \"#1f2937\",\n \"#374151\",\n \"#4b5563\",\n \"#6b7280\",\n \"#9ca3af\",\n \"#7a7a7a\",\n \"#525252\",\n \"#262626\",\n] as const;\n\nconst DARK_PALETTE = [\n \"#89b4fa\", // blue\n \"#a6e3a1\", // green\n \"#fab387\", // peach\n \"#cba6f7\", // mauve\n \"#f38ba8\", // red\n \"#94e2d5\", // teal\n \"#f5c2e7\", // pink\n \"#89dceb\", // sky\n] as const;\n\nconst DEFAULT_THEME: BaseTheme = {\n bg: \"#ffffff\",\n text: \"#0f172a\",\n textMuted: \"#475569\",\n stroke: \"#334155\",\n fill: \"#ffffff\",\n fillMuted: \"#f1f5f9\",\n accent: \"#2563eb\",\n positive: \"#059669\",\n negative: \"#dc2626\",\n neutral: \"#94a3b8\",\n warn: \"#d97706\",\n palette: DEFAULT_PALETTE,\n};\n\nconst MONOCHROME_THEME: BaseTheme = {\n bg: \"#ffffff\",\n text: \"#000000\",\n textMuted: \"#555555\",\n stroke: \"#000000\",\n fill: \"#ffffff\",\n fillMuted: \"#f0f0f0\",\n accent: \"#000000\",\n positive: \"#000000\",\n negative: \"#000000\",\n neutral: \"#888888\",\n warn: \"#000000\",\n palette: MONOCHROME_PALETTE,\n};\n\nconst DARK_THEME: BaseTheme = {\n bg: \"#1e1e2e\",\n text: \"#cdd6f4\",\n textMuted: \"#7f849c\",\n stroke: \"#cdd6f4\",\n fill: \"#313244\",\n fillMuted: \"#45475a\",\n accent: \"#89b4fa\",\n positive: \"#a6e3a1\",\n negative: \"#f38ba8\",\n neutral: \"#6c7086\",\n warn: \"#fab387\",\n palette: DARK_PALETTE,\n};\n\nexport const BASE_THEMES: Record<ThemeName, BaseTheme> = {\n default: DEFAULT_THEME,\n monochrome: MONOCHROME_THEME,\n dark: DARK_THEME,\n};\n\n// ─── Person Tokens Per Theme ───────────────────────────────\n\nconst DEFAULT_PERSON: PersonTokens = {\n maleFill: \"#dbeafe\",\n femaleFill: \"#fce7f3\",\n unknownFill: \"#f5f5f5\",\n deceasedMark: \"#b71c1c\",\n conditionFill: \"#1565c0\",\n};\n\nconst MONOCHROME_PERSON: PersonTokens = {\n maleFill: \"#ffffff\",\n femaleFill: \"#ffffff\",\n unknownFill: \"#ffffff\",\n deceasedMark: \"#000000\",\n conditionFill: \"#000000\",\n};\n\nconst DARK_PERSON: PersonTokens = {\n maleFill: \"#1e3a5f\",\n femaleFill: \"#3e1f3e\",\n unknownFill: \"#45475a\",\n deceasedMark: \"#f38ba8\",\n conditionFill: \"#89b4fa\",\n};\n\nexport const PERSON_TOKENS: Record<ThemeName, PersonTokens> = {\n default: DEFAULT_PERSON,\n monochrome: MONOCHROME_PERSON,\n dark: DARK_PERSON,\n};\n\n// ─── Biology Tokens Per Theme ──────────────────────────────\n\nconst DEFAULT_BIOLOGY: BiologyTokens = {\n cladeColors: DEFAULT_PALETTE,\n supportGood: \"#059669\",\n supportMedium: \"#ca8a04\",\n supportWarn: \"#d97706\",\n supportBad: \"#dc2626\",\n};\n\nconst MONOCHROME_BIOLOGY: BiologyTokens = {\n cladeColors: MONOCHROME_PALETTE,\n supportGood: \"#000000\",\n supportMedium: \"#555555\",\n supportWarn: \"#888888\",\n supportBad: \"#aaaaaa\",\n};\n\nconst DARK_BIOLOGY: BiologyTokens = {\n cladeColors: DARK_PALETTE,\n supportGood: \"#a6e3a1\",\n supportMedium: \"#f9e2af\",\n supportWarn: \"#fab387\",\n supportBad: \"#f38ba8\",\n};\n\nexport const BIOLOGY_TOKENS: Record<ThemeName, BiologyTokens> = {\n default: DEFAULT_BIOLOGY,\n monochrome: MONOCHROME_BIOLOGY,\n dark: DARK_BIOLOGY,\n};\n\n// ─── Venn Tokens Per Theme ─────────────────────────────────\n\nconst DEFAULT_VENN: VennTokens = {\n vennSetColors: DEFAULT_PALETTE,\n vennBlendMode: \"multiply\",\n vennSetOpacity: 0.38,\n vennSetStroke: \"#94a3b8\",\n vennLabelColor: \"#0f172a\",\n vennCountColor: \"#0f172a\",\n vennLeaderColor: \"#64748b\",\n};\n\nconst MONOCHROME_VENN: VennTokens = {\n vennSetColors: [\"#999999\", \"#999999\", \"#999999\", \"#999999\", \"#999999\", \"#999999\", \"#999999\", \"#999999\"],\n vennBlendMode: \"none\",\n vennSetOpacity: 0.22,\n vennSetStroke: \"#000000\",\n vennLabelColor: \"#000000\",\n vennCountColor: \"#000000\",\n vennLeaderColor: \"#444444\",\n};\n\nconst DARK_VENN: VennTokens = {\n vennSetColors: DARK_PALETTE,\n vennBlendMode: \"screen\",\n vennSetOpacity: 0.55,\n vennSetStroke: \"#585b70\",\n vennLabelColor: \"#cdd6f4\",\n vennCountColor: \"#f9e2af\",\n vennLeaderColor: \"#7f849c\",\n};\n\nexport const VENN_TOKENS: Record<ThemeName, VennTokens> = {\n default: DEFAULT_VENN,\n monochrome: MONOCHROME_VENN,\n dark: DARK_VENN,\n};\n\n// ─── Mindmap Tokens Per Theme ──────────────────────────────\n\n// Kept as its own struct so the mindmap palette can diverge from BaseTheme\n// later if we want (e.g., a softer / more organic set of branch colors).\n// Today the values mirror BaseTheme.palette so mindmap visually belongs with\n// the rest of the diagram family.\n\nconst DEFAULT_MINDMAP: MindmapTokens = {\n centralFill: \"#0f172a\",\n branchPalette: DEFAULT_PALETTE,\n codeFg: \"#be185d\",\n codeBg: \"#fdf2f8\",\n linkColor: \"#2563eb\",\n checkboxStroke: \"#64748b\",\n checkboxFill: \"#10b981\",\n};\n\nconst MONOCHROME_MINDMAP: MindmapTokens = {\n centralFill: \"#000000\",\n branchPalette: [\"#000000\"],\n codeFg: \"#000000\",\n codeBg: \"#e5e5e5\",\n linkColor: \"#000000\",\n checkboxStroke: \"#000000\",\n checkboxFill: \"#000000\",\n};\n\nconst DARK_MINDMAP: MindmapTokens = {\n centralFill: \"#cdd6f4\",\n branchPalette: DARK_PALETTE,\n codeFg: \"#f5c2e7\",\n codeBg: \"#313244\",\n linkColor: \"#89b4fa\",\n checkboxStroke: \"#a6adc8\",\n checkboxFill: \"#a6e3a1\",\n};\n\nexport const MINDMAP_TOKENS: Record<ThemeName, MindmapTokens> = {\n default: DEFAULT_MINDMAP,\n monochrome: MONOCHROME_MINDMAP,\n dark: DARK_MINDMAP,\n};\n\n// ─── Industrial Tokens Per Theme ───────────────────────────\n\nconst DEFAULT_INDUSTRIAL: IndustrialTokens = {\n bg: \"#ffffff\",\n stroke: \"#222222\",\n strokeHeavy: \"#111111\",\n text: \"#111111\",\n textMuted: \"#555555\",\n accent: \"#1d4e89\",\n error: \"#cc0000\",\n};\n\nconst MONOCHROME_INDUSTRIAL: IndustrialTokens = {\n bg: \"#ffffff\",\n stroke: \"#000000\",\n strokeHeavy: \"#000000\",\n text: \"#000000\",\n textMuted: \"#333333\",\n accent: \"#000000\",\n error: \"#000000\",\n};\n\n// Dark = inverted luminance only. No colorful semantics — still compliance-grade.\nconst DARK_INDUSTRIAL: IndustrialTokens = {\n bg: \"#1e1e2e\",\n stroke: \"#cdd6f4\",\n strokeHeavy: \"#ffffff\",\n text: \"#cdd6f4\",\n textMuted: \"#9399b2\",\n accent: \"#89b4fa\",\n error: \"#f38ba8\",\n};\n\nexport const INDUSTRIAL_TOKENS: Record<ThemeName, IndustrialTokens> = {\n default: DEFAULT_INDUSTRIAL,\n monochrome: MONOCHROME_INDUSTRIAL,\n dark: DARK_INDUSTRIAL,\n};\n\nexport function resolveIndustrialTheme(name: string): ResolvedTheme<IndustrialTokens> {\n const themeName = (name in BASE_THEMES ? name : \"default\") as ThemeName;\n return { ...BASE_THEMES[themeName], ...INDUSTRIAL_TOKENS[themeName] };\n}\n\n// ─── Flowchart Tokens Per Theme ────────────────────────────\n\nconst DEFAULT_FLOWCHART: FlowchartTokens = {\n stadiumFill: \"#dbeafe\",\n diamondFill: \"#fef3c7\",\n roundFill: \"#dcfce7\",\n classes: {\n start: { fill: \"#f0ece0\", stroke: \"#9a8b6a\", text: \"#5c4e2e\" },\n process: { fill: \"#e8e4ff\", stroke: \"#8b7dd8\", text: \"#4c3a8f\" },\n decision: { fill: \"#fde8c8\", stroke: \"#d4985c\", text: \"#8a5a1f\" },\n success: { fill: \"#d4f0e0\", stroke: \"#7bc19a\", text: \"#1e5a3a\" },\n danger: { fill: \"#fbe0dc\", stroke: \"#d89181\", text: \"#8a3525\" },\n neutral: { fill: \"#ececec\", stroke: \"#a0a0a0\", text: \"#555555\" },\n },\n};\n\nconst MONOCHROME_FLOWCHART: FlowchartTokens = {\n stadiumFill: \"#ffffff\",\n diamondFill: \"#ffffff\",\n roundFill: \"#ffffff\",\n classes: {\n start: { fill: \"#ffffff\", stroke: \"#000000\", text: \"#000000\" },\n process: { fill: \"#ffffff\", stroke: \"#000000\", text: \"#000000\" },\n decision: { fill: \"#ffffff\", stroke: \"#000000\", text: \"#000000\" },\n success: { fill: \"#ffffff\", stroke: \"#000000\", text: \"#000000\" },\n danger: { fill: \"#ffffff\", stroke: \"#000000\", text: \"#000000\" },\n neutral: { fill: \"#ffffff\", stroke: \"#000000\", text: \"#000000\" },\n },\n};\n\nconst DARK_FLOWCHART: FlowchartTokens = {\n stadiumFill: \"#1e3a5f\",\n diamondFill: \"#3a3a2a\",\n roundFill: \"#1f3a2a\",\n classes: {\n start: { fill: \"#3a3326\", stroke: \"#c9b88a\", text: \"#f5e7c7\" },\n process: { fill: \"#2e2a52\", stroke: \"#a89ee0\", text: \"#d9d2ff\" },\n decision: { fill: \"#3a2d1a\", stroke: \"#d4985c\", text: \"#f2d5a8\" },\n success: { fill: \"#1e3a2a\", stroke: \"#7bc19a\", text: \"#cdefd8\" },\n danger: { fill: \"#3a231f\", stroke: \"#d89181\", text: \"#f2d0c8\" },\n neutral: { fill: \"#313244\", stroke: \"#7f849c\", text: \"#cdd6f4\" },\n },\n};\n\nexport const FLOWCHART_TOKENS: Record<ThemeName, FlowchartTokens> = {\n default: DEFAULT_FLOWCHART,\n monochrome: MONOCHROME_FLOWCHART,\n dark: DARK_FLOWCHART,\n};\n\nexport function resolveFlowchartTheme(name: string): ResolvedTheme<FlowchartTokens> {\n const themeName = (name in BASE_THEMES ? name : \"default\") as ThemeName;\n return { ...BASE_THEMES[themeName], ...FLOWCHART_TOKENS[themeName] };\n}\n\nexport function resolveMindmapTheme(name: string): ResolvedTheme<MindmapTokens> {\n const themeName = (name in BASE_THEMES ? name : \"default\") as ThemeName;\n return { ...BASE_THEMES[themeName], ...MINDMAP_TOKENS[themeName] };\n}\n\n// ─── Timeline Tokens Per Theme ─────────────────────────────\n\nconst DEFAULT_TIMELINE: TimelineTokens = {\n axis: \"#334155\",\n axisLabel: \"#475569\",\n eraLabel: \"#0f172a\",\n eraOpacity: 0.55,\n eraPlotOpacity: 0.14,\n laneStripe: \"#f1f5f9\",\n laneStripeOpacity: 0.6,\n categoryPalette: DEFAULT_PALETTE,\n markerRing: \"#2563eb\",\n markerFill: \"#ffffff\",\n milestoneFill: \"#d97706\",\n pinShaft: \"#94a3b8\",\n cardBg: \"#ffffff\",\n cardStroke: \"#cbd5e1\",\n cardText: \"#0f172a\",\n cardShadow: \"rgba(15,23,42,0.08)\",\n legendBg: \"#f8fafc\",\n legendStroke: \"#e2e8f0\",\n};\n\nconst MONOCHROME_TIMELINE: TimelineTokens = {\n axis: \"#000000\",\n axisLabel: \"#333333\",\n eraLabel: \"#000000\",\n eraOpacity: 0.2,\n eraPlotOpacity: 0.08,\n laneStripe: \"#f0f0f0\",\n laneStripeOpacity: 0.6,\n categoryPalette: MONOCHROME_PALETTE,\n markerRing: \"#000000\",\n markerFill: \"#ffffff\",\n milestoneFill: \"#000000\",\n pinShaft: \"#888888\",\n cardBg: \"#ffffff\",\n cardStroke: \"#000000\",\n cardText: \"#000000\",\n cardShadow: \"rgba(0,0,0,0.06)\",\n legendBg: \"#ffffff\",\n legendStroke: \"#000000\",\n};\n\nconst DARK_TIMELINE: TimelineTokens = {\n axis: \"#cdd6f4\",\n axisLabel: \"#9399b2\",\n eraLabel: \"#cdd6f4\",\n eraOpacity: 0.5,\n eraPlotOpacity: 0.18,\n laneStripe: \"#313244\",\n laneStripeOpacity: 0.5,\n categoryPalette: DARK_PALETTE,\n markerRing: \"#89b4fa\",\n markerFill: \"#1e1e2e\",\n milestoneFill: \"#fab387\",\n pinShaft: \"#6c7086\",\n cardBg: \"#313244\",\n cardStroke: \"#45475a\",\n cardText: \"#cdd6f4\",\n cardShadow: \"rgba(0,0,0,0.35)\",\n legendBg: \"#181825\",\n legendStroke: \"#45475a\",\n};\n\nexport const TIMELINE_TOKENS: Record<ThemeName, TimelineTokens> = {\n default: DEFAULT_TIMELINE,\n monochrome: MONOCHROME_TIMELINE,\n dark: DARK_TIMELINE,\n};\n\nexport function resolveTimelineTheme(name: string): ResolvedTheme<TimelineTokens> {\n const themeName = (name in BASE_THEMES ? name : \"default\") as ThemeName;\n return { ...BASE_THEMES[themeName], ...TIMELINE_TOKENS[themeName] };\n}\n\n// ─── Theme Resolution ──────────────────────────────────────\n\nexport function resolveBaseTheme(name: string): BaseTheme {\n return BASE_THEMES[name as ThemeName] ?? BASE_THEMES[\"default\"];\n}\n\nexport function resolvePersonTheme(name: string): ResolvedTheme<PersonTokens> {\n const themeName = (name in BASE_THEMES ? name : \"default\") as ThemeName;\n return { ...BASE_THEMES[themeName], ...PERSON_TOKENS[themeName] };\n}\n\nexport function resolveBiologyTheme(name: string): ResolvedTheme<BiologyTokens> {\n const themeName = (name in BASE_THEMES ? name : \"default\") as ThemeName;\n return { ...BASE_THEMES[themeName], ...BIOLOGY_TOKENS[themeName] };\n}\n\n/**\n * Fishbone uses BaseTheme directly — its bone colors come from `theme.palette`.\n * Kept as a named resolver so callers don't have to know that.\n */\nexport function resolveFishboneTheme(name: string): BaseTheme {\n return resolveBaseTheme(name);\n}\n\nexport function resolveVennTheme(name: string): ResolvedTheme<VennTokens> {\n const themeName = (name in BASE_THEMES ? name : \"default\") as ThemeName;\n return { ...BASE_THEMES[themeName], ...VENN_TOKENS[themeName] };\n}\n\n// ─── Genogram Theme Aliases ────────────────────────────────\n\nconst GENOGRAM_ALIASES: Record<string, ThemeName> = {\n clinical: \"monochrome\",\n colorful: \"default\",\n mono: \"monochrome\",\n bw: \"monochrome\",\n};\n\nexport function resolveGenogramTheme(name: string): ResolvedTheme<PersonTokens> {\n const resolved = GENOGRAM_ALIASES[name] ?? name;\n return resolvePersonTheme(resolved);\n}\n\n// ─── Font Sizes ────────────────────────────────────────────\n\n/**\n * Three-tier typography scale. Diagram-specific font sizes (e.g., 14px section\n * labels, 20px hero titles) live as local constants inside their renderer.\n */\nexport const FONT_SIZE = {\n title: 16,\n label: 12,\n small: 9,\n} as const;\n\n// ─── Stroke Widths ─────────────────────────────────────────\n\n/**\n * Three-tier stroke scale. Anything in between is a local constant in the\n * diagram that needs it.\n * thin — hairlines, ticks, secondary gridlines\n * normal — default body strokes (shapes, edges)\n * thick — emphasis (proband index, star node, center shape)\n */\nexport const STROKE_WIDTH = {\n thin: 1,\n normal: 2,\n thick: 3,\n} as const;\n\n// ─── Spacing ───────────────────────────────────────────────\n\nexport const SPACING = {\n labelGap: 4,\n tipLabelGap: 6,\n titleOffset: 30,\n} as const;\n\n// ─── Font Family ───────────────────────────────────────────\n\nexport const DEFAULT_FONT_FAMILY = \"system-ui, -apple-system, sans-serif\";\n\n// ─── CSS Custom Properties ─────────────────────────────────\n\nexport function cssCustomProperties(theme?: BaseTheme): string {\n const t = theme ?? BASE_THEMES[\"default\"];\n return `\n --schematex-bg: ${t.bg};\n --schematex-text: ${t.text};\n --schematex-text-muted: ${t.textMuted};\n --schematex-stroke: ${t.stroke};\n --schematex-fill: ${t.fill};\n --schematex-fill-muted: ${t.fillMuted};\n --schematex-accent: ${t.accent};\n --schematex-positive: ${t.positive};\n --schematex-negative: ${t.negative};\n --schematex-neutral: ${t.neutral};\n --schematex-warn: ${t.warn};\n --schematex-font-title: ${FONT_SIZE.title}px;\n --schematex-font-label: ${FONT_SIZE.label}px;\n --schematex-font-small: ${FONT_SIZE.small}px;\n --schematex-stroke-thin: ${STROKE_WIDTH.thin};\n --schematex-stroke-normal: ${STROKE_WIDTH.normal};\n --schematex-stroke-thick: ${STROKE_WIDTH.thick};`;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { resolvePersonTheme, STROKE_WIDTH, cssCustomProperties } from './chunk-IX554O5K.js';
1
+ import { resolvePersonTheme, STROKE_WIDTH, cssCustomProperties } from './chunk-2VNMKOUO.js';
2
2
  import { title, desc, svgRoot, el, rect, path, defs, line, group, text, polygon, circle } from './chunk-KLJEK547.js';
3
3
 
4
4
  // src/diagrams/pedigree/parser.ts
@@ -1004,6 +1004,7 @@ var pedigree = {
1004
1004
  const firstLine = text2.trim().split("\n")[0]?.trim().toLowerCase() ?? "";
1005
1005
  return firstLine === "pedigree" || firstLine.startsWith("pedigree ");
1006
1006
  },
1007
+ parse: parsePedigree,
1007
1008
  render(text2, config) {
1008
1009
  const ast = parsePedigree(text2);
1009
1010
  const layoutConfig = {
@@ -1024,5 +1025,5 @@ var pedigree = {
1024
1025
  };
1025
1026
 
1026
1027
  export { PedigreeParseError, layoutPedigree, parsePedigree, pedigree, renderPedigree };
1027
- //# sourceMappingURL=chunk-LMFSHK45.js.map
1028
- //# sourceMappingURL=chunk-LMFSHK45.js.map
1028
+ //# sourceMappingURL=chunk-4KYW63IK.js.map
1029
+ //# sourceMappingURL=chunk-4KYW63IK.js.map