schematex 0.1.0
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.
- package/LICENSE +661 -0
- package/README.md +379 -0
- package/dist/chunk-2MQWZ2XY.cjs +453 -0
- package/dist/chunk-2MQWZ2XY.cjs.map +1 -0
- package/dist/chunk-2UKC6ZCY.cjs +1803 -0
- package/dist/chunk-2UKC6ZCY.cjs.map +1 -0
- package/dist/chunk-34X3ZJ6E.cjs +783 -0
- package/dist/chunk-34X3ZJ6E.cjs.map +1 -0
- package/dist/chunk-3FTUWAXK.cjs +1220 -0
- package/dist/chunk-3FTUWAXK.cjs.map +1 -0
- package/dist/chunk-3J7TFUOC.js +745 -0
- package/dist/chunk-3J7TFUOC.js.map +1 -0
- package/dist/chunk-47ZC6EMJ.js +1009 -0
- package/dist/chunk-47ZC6EMJ.js.map +1 -0
- package/dist/chunk-4DBRNOPA.cjs +750 -0
- package/dist/chunk-4DBRNOPA.cjs.map +1 -0
- package/dist/chunk-4G7ZIBHN.js +778 -0
- package/dist/chunk-4G7ZIBHN.js.map +1 -0
- package/dist/chunk-5C7DPDHQ.js +1321 -0
- package/dist/chunk-5C7DPDHQ.js.map +1 -0
- package/dist/chunk-ADOXGKAK.js +1251 -0
- package/dist/chunk-ADOXGKAK.js.map +1 -0
- package/dist/chunk-BE5HNDA5.cjs +874 -0
- package/dist/chunk-BE5HNDA5.cjs.map +1 -0
- package/dist/chunk-CZRM7LT7.js +889 -0
- package/dist/chunk-CZRM7LT7.js.map +1 -0
- package/dist/chunk-D4JTSPOL.js +1795 -0
- package/dist/chunk-D4JTSPOL.js.map +1 -0
- package/dist/chunk-DS47NTWZ.cjs +1034 -0
- package/dist/chunk-DS47NTWZ.cjs.map +1 -0
- package/dist/chunk-FDLZEKEB.js +449 -0
- package/dist/chunk-FDLZEKEB.js.map +1 -0
- package/dist/chunk-FGPTCDUT.cjs +1851 -0
- package/dist/chunk-FGPTCDUT.cjs.map +1 -0
- package/dist/chunk-HDKDQAEQ.cjs +86 -0
- package/dist/chunk-HDKDQAEQ.cjs.map +1 -0
- package/dist/chunk-IX554O5K.js +346 -0
- package/dist/chunk-IX554O5K.js.map +1 -0
- package/dist/chunk-KLJEK547.js +71 -0
- package/dist/chunk-KLJEK547.js.map +1 -0
- package/dist/chunk-LMFSHK45.js +1028 -0
- package/dist/chunk-LMFSHK45.js.map +1 -0
- package/dist/chunk-MDICUK6F.cjs +1258 -0
- package/dist/chunk-MDICUK6F.cjs.map +1 -0
- package/dist/chunk-N7KOXOMX.cjs +363 -0
- package/dist/chunk-N7KOXOMX.cjs.map +1 -0
- package/dist/chunk-NYCIK4SU.cjs +775 -0
- package/dist/chunk-NYCIK4SU.cjs.map +1 -0
- package/dist/chunk-PDPHRZZT.js +770 -0
- package/dist/chunk-PDPHRZZT.js.map +1 -0
- package/dist/chunk-ROFLJ74T.js +1212 -0
- package/dist/chunk-ROFLJ74T.js.map +1 -0
- package/dist/chunk-S6BK5DB6.cjs +845 -0
- package/dist/chunk-S6BK5DB6.cjs.map +1 -0
- package/dist/chunk-U4I37IBN.js +874 -0
- package/dist/chunk-U4I37IBN.js.map +1 -0
- package/dist/chunk-U5GGE6PJ.js +839 -0
- package/dist/chunk-U5GGE6PJ.js.map +1 -0
- package/dist/chunk-UHLYS3W5.cjs +1015 -0
- package/dist/chunk-UHLYS3W5.cjs.map +1 -0
- package/dist/chunk-URSKIHSY.cjs +881 -0
- package/dist/chunk-URSKIHSY.cjs.map +1 -0
- package/dist/chunk-V6WO7RK7.cjs +1056 -0
- package/dist/chunk-V6WO7RK7.cjs.map +1 -0
- package/dist/chunk-VFQCTXOX.js +869 -0
- package/dist/chunk-VFQCTXOX.js.map +1 -0
- package/dist/chunk-XQ52ICHU.cjs +895 -0
- package/dist/chunk-XQ52ICHU.cjs.map +1 -0
- package/dist/chunk-XX4BKS7Y.js +1051 -0
- package/dist/chunk-XX4BKS7Y.js.map +1 -0
- package/dist/chunk-XXU36667.js +1844 -0
- package/dist/chunk-XXU36667.js.map +1 -0
- package/dist/chunk-ZX7QKZK2.cjs +1326 -0
- package/dist/chunk-ZX7QKZK2.cjs.map +1 -0
- package/dist/diagrams/blockdiagram/index.cjs +25 -0
- package/dist/diagrams/blockdiagram/index.cjs.map +1 -0
- package/dist/diagrams/blockdiagram/index.d.cts +67 -0
- package/dist/diagrams/blockdiagram/index.d.ts +67 -0
- package/dist/diagrams/blockdiagram/index.js +4 -0
- package/dist/diagrams/blockdiagram/index.js.map +1 -0
- package/dist/diagrams/circuit/index.cjs +34 -0
- package/dist/diagrams/circuit/index.cjs.map +1 -0
- package/dist/diagrams/circuit/index.d.cts +138 -0
- package/dist/diagrams/circuit/index.d.ts +138 -0
- package/dist/diagrams/circuit/index.js +5 -0
- package/dist/diagrams/circuit/index.js.map +1 -0
- package/dist/diagrams/ecomap/index.cjs +30 -0
- package/dist/diagrams/ecomap/index.cjs.map +1 -0
- package/dist/diagrams/ecomap/index.d.cts +15 -0
- package/dist/diagrams/ecomap/index.d.ts +15 -0
- package/dist/diagrams/ecomap/index.js +5 -0
- package/dist/diagrams/ecomap/index.js.map +1 -0
- package/dist/diagrams/entity/index.cjs +26 -0
- package/dist/diagrams/entity/index.cjs.map +1 -0
- package/dist/diagrams/entity/index.d.cts +54 -0
- package/dist/diagrams/entity/index.d.ts +54 -0
- package/dist/diagrams/entity/index.js +5 -0
- package/dist/diagrams/entity/index.js.map +1 -0
- package/dist/diagrams/fishbone/index.cjs +34 -0
- package/dist/diagrams/fishbone/index.cjs.map +1 -0
- package/dist/diagrams/fishbone/index.d.cts +185 -0
- package/dist/diagrams/fishbone/index.d.ts +185 -0
- package/dist/diagrams/fishbone/index.js +5 -0
- package/dist/diagrams/fishbone/index.js.map +1 -0
- package/dist/diagrams/flowchart/index.cjs +34 -0
- package/dist/diagrams/flowchart/index.cjs.map +1 -0
- package/dist/diagrams/flowchart/index.d.cts +2 -0
- package/dist/diagrams/flowchart/index.d.ts +2 -0
- package/dist/diagrams/flowchart/index.js +5 -0
- package/dist/diagrams/flowchart/index.js.map +1 -0
- package/dist/diagrams/genogram/index.cjs +38 -0
- package/dist/diagrams/genogram/index.cjs.map +1 -0
- package/dist/diagrams/genogram/index.d.cts +20 -0
- package/dist/diagrams/genogram/index.d.ts +20 -0
- package/dist/diagrams/genogram/index.js +5 -0
- package/dist/diagrams/genogram/index.js.map +1 -0
- package/dist/diagrams/ladder/index.cjs +26 -0
- package/dist/diagrams/ladder/index.cjs.map +1 -0
- package/dist/diagrams/ladder/index.d.cts +49 -0
- package/dist/diagrams/ladder/index.d.ts +49 -0
- package/dist/diagrams/ladder/index.js +5 -0
- package/dist/diagrams/ladder/index.js.map +1 -0
- package/dist/diagrams/logic/index.cjs +26 -0
- package/dist/diagrams/logic/index.cjs.map +1 -0
- package/dist/diagrams/logic/index.d.cts +73 -0
- package/dist/diagrams/logic/index.d.ts +73 -0
- package/dist/diagrams/logic/index.js +5 -0
- package/dist/diagrams/logic/index.js.map +1 -0
- package/dist/diagrams/orgchart/index.cjs +30 -0
- package/dist/diagrams/orgchart/index.cjs.map +1 -0
- package/dist/diagrams/orgchart/index.d.cts +100 -0
- package/dist/diagrams/orgchart/index.d.ts +100 -0
- package/dist/diagrams/orgchart/index.js +5 -0
- package/dist/diagrams/orgchart/index.js.map +1 -0
- package/dist/diagrams/pedigree/index.cjs +30 -0
- package/dist/diagrams/pedigree/index.cjs.map +1 -0
- package/dist/diagrams/pedigree/index.d.cts +15 -0
- package/dist/diagrams/pedigree/index.d.ts +15 -0
- package/dist/diagrams/pedigree/index.js +5 -0
- package/dist/diagrams/pedigree/index.js.map +1 -0
- package/dist/diagrams/phylo/index.cjs +30 -0
- package/dist/diagrams/phylo/index.cjs.map +1 -0
- package/dist/diagrams/phylo/index.d.cts +32 -0
- package/dist/diagrams/phylo/index.d.ts +32 -0
- package/dist/diagrams/phylo/index.js +5 -0
- package/dist/diagrams/phylo/index.js.map +1 -0
- package/dist/diagrams/sld/index.cjs +26 -0
- package/dist/diagrams/sld/index.cjs.map +1 -0
- package/dist/diagrams/sld/index.d.cts +58 -0
- package/dist/diagrams/sld/index.d.ts +58 -0
- package/dist/diagrams/sld/index.js +5 -0
- package/dist/diagrams/sld/index.js.map +1 -0
- package/dist/diagrams/sociogram/index.cjs +26 -0
- package/dist/diagrams/sociogram/index.cjs.map +1 -0
- package/dist/diagrams/sociogram/index.d.cts +76 -0
- package/dist/diagrams/sociogram/index.d.ts +76 -0
- package/dist/diagrams/sociogram/index.js +5 -0
- package/dist/diagrams/sociogram/index.js.map +1 -0
- package/dist/diagrams/timing/index.cjs +21 -0
- package/dist/diagrams/timing/index.cjs.map +1 -0
- package/dist/diagrams/timing/index.d.cts +9 -0
- package/dist/diagrams/timing/index.d.ts +9 -0
- package/dist/diagrams/timing/index.js +4 -0
- package/dist/diagrams/timing/index.js.map +1 -0
- package/dist/diagrams/venn/index.cjs +38 -0
- package/dist/diagrams/venn/index.cjs.map +1 -0
- package/dist/diagrams/venn/index.d.cts +69 -0
- package/dist/diagrams/venn/index.d.ts +69 -0
- package/dist/diagrams/venn/index.js +5 -0
- package/dist/diagrams/venn/index.js.map +1 -0
- package/dist/index-BSlza1YY.d.ts +150 -0
- package/dist/index-BXefHVce.d.cts +150 -0
- package/dist/index.cjs +2033 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +29 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.js +1944 -0
- package/dist/index.js.map +1 -0
- package/dist/types-DqfcYkcY.d.cts +741 -0
- package/dist/types-DqfcYkcY.d.ts +741 -0
- package/package.json +163 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/diagrams/pedigree/parser.ts","../src/diagrams/pedigree/layout.ts","../src/diagrams/pedigree/renderer.ts","../src/diagrams/pedigree/index.ts"],"names":["line","text","propsStr","resolvePersonTheme","title","desc","svgRoot","el","rect","path","defs","cssCustomProperties","STROKE_WIDTH","group","circle","polygon"],"mappings":"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","file":"chunk-DS47NTWZ.cjs","sourcesContent":["import type {\n DiagramAST,\n Individual,\n Relationship,\n RelationshipType,\n GeneticStatus,\n IndividualMarker,\n LegendEntry,\n ConditionFill,\n} from \"../../core/types\";\n\n// ─── ParseError ─────────────────────────────────────────────\n\nexport class PedigreeParseError extends Error {\n constructor(message: string, public line: number) {\n super(`Line ${line}: ${message}`);\n this.name = \"PedigreeParseError\";\n }\n}\n\n// ─── Couple operators ───────────────────────────────────────\n\nconst COUPLE_OPS: Array<{ token: string; type: RelationshipType }> = [\n { token: \"-/-\", type: \"separated\" },\n { token: \"==\", type: \"consanguineous\" },\n { token: \"--\", type: \"married\" },\n { token: \"~\", type: \"cohabiting\" },\n];\n\nconst VALID_SEX = new Set([\"male\", \"female\", \"unknown\", \"amab\", \"afab\", \"uaab\"]);\nconst GENETIC_STATUSES = new Set([\n \"affected\",\n \"carrier\",\n \"carrier-x\",\n \"obligate-carrier\",\n \"presymptomatic\",\n \"unaffected\",\n]);\nconst MARKERS = new Set([\"proband\", \"consultand\", \"evaluated\"]);\nconst VALID_STATUS = new Set([\"deceased\", \"stillborn\", \"pregnancy\", \"sab\", \"tab\", \"ectopic\"]);\n\n// ─── Public API ────────────────────────────────────────────\n\nexport function parsePedigree(text: string): DiagramAST {\n const rawLines = text.split(\"\\n\");\n let i = 0;\n\n while (i < rawLines.length && rawLines[i].trim() === \"\") i++;\n if (i >= rawLines.length) throw new PedigreeParseError(\"Empty input\", 1);\n\n const headerLine = rawLines[i].trim();\n const headerMatch = headerLine.match(/^pedigree\\s*(?:\"([^\"]*)\")?$/i);\n if (!headerMatch) throw new PedigreeParseError(\"Expected 'pedigree' header\", i + 1);\n\n const metadata: Record<string, string> = {};\n if (headerMatch[1]) metadata.title = headerMatch[1];\n i++;\n\n const legend: LegendEntry[] = [];\n const individualsMap = new Map<string, Individual>();\n const relationships: Relationship[] = [];\n\n while (i < rawLines.length) {\n const raw = rawLines[i];\n const trimmed = raw.trim();\n\n if (trimmed === \"\" || trimmed.startsWith(\"#\") || trimmed.startsWith(\"//\")) {\n i++;\n continue;\n }\n\n // Legend definition\n const legendMatch = trimmed.match(\n /^legend:\\s*([a-zA-Z][a-zA-Z0-9_-]*)\\s*=\\s*\"([^\"]*)\"\\s*(?:\\(\\s*fill:\\s*([a-zA-Z-]+)\\s*\\))?$/\n );\n if (legendMatch) {\n legend.push({\n id: legendMatch[1],\n label: legendMatch[2],\n fill: (legendMatch[3] as ConditionFill) ?? \"full\",\n });\n i++;\n continue;\n }\n\n // Couple line\n const coupleMatch = detectCoupleOp(trimmed);\n if (coupleMatch) {\n const { leftId, op, rightRaw } = coupleMatch;\n const lineNum = i + 1;\n\n const { id: rightId, propsStr: rightProps } = parseIdWithProps(rightRaw);\n const leftKey = leftId.toLowerCase();\n const rightKey = rightId.toLowerCase();\n\n if (!individualsMap.has(leftKey)) {\n throw new PedigreeParseError(`Unknown individual '${leftId}'`, lineNum);\n }\n\n if (rightProps) {\n individualsMap.set(rightKey, buildIndividual(rightId, rightProps, lineNum));\n } else if (!individualsMap.has(rightKey)) {\n throw new PedigreeParseError(`Unknown individual '${rightId}'`, lineNum);\n }\n\n relationships.push({ type: op.type, from: leftKey, to: rightKey });\n\n const coupleIndent = leadingSpaces(raw);\n i++;\n\n // Children (indented under couple)\n while (i < rawLines.length) {\n const childLine = rawLines[i];\n const childTrimmed = childLine.trim();\n\n if (childTrimmed === \"\" || childTrimmed.startsWith(\"#\")) {\n i++;\n continue;\n }\n\n if (leadingSpaces(childLine) <= coupleIndent) break;\n\n const childLineNum = i + 1;\n const { id: childId, propsStr } = parseIdWithProps(childTrimmed);\n const childKey = childId.toLowerCase();\n\n individualsMap.set(childKey, buildIndividual(childId, propsStr, childLineNum));\n\n const coupleKey = `${leftKey}+${rightKey}`;\n relationships.push({ type: \"parent-child\", from: coupleKey, to: childKey });\n\n i++;\n }\n continue;\n }\n\n // Individual definition\n const { id, propsStr } = parseIdWithProps(trimmed);\n const key = id.toLowerCase();\n const ind = buildIndividual(id, propsStr, i + 1);\n const existing = individualsMap.get(key);\n if (existing) {\n individualsMap.set(key, mergeIndividual(existing, ind));\n } else {\n individualsMap.set(key, ind);\n }\n i++;\n }\n\n return {\n type: \"pedigree\",\n individuals: Array.from(individualsMap.values()),\n relationships,\n metadata: Object.keys(metadata).length > 0 ? metadata : undefined,\n legend: legend.length > 0 ? legend : undefined,\n };\n}\n\n// ─── Helpers ────────────────────────────────────────────────\n\nfunction leadingSpaces(line: string): number {\n const m = line.match(/^(\\s*)/);\n return m ? m[1].length : 0;\n}\n\nfunction detectCoupleOp(trimmed: string): { leftId: string; op: typeof COUPLE_OPS[0]; rightRaw: string } | null {\n for (const op of COUPLE_OPS) {\n let bracketDepth = 0;\n for (let j = 0; j < trimmed.length; j++) {\n if (trimmed[j] === \"[\") bracketDepth++;\n if (trimmed[j] === \"]\") bracketDepth--;\n if (bracketDepth > 0) continue;\n\n if (trimmed.substring(j, j + op.token.length) === op.token) {\n const left = trimmed.substring(0, j).trim();\n const right = trimmed.substring(j + op.token.length).trim();\n if (left && right && /^[a-zA-Z][a-zA-Z0-9_-]*$/.test(left)) {\n return { leftId: left, op, rightRaw: right };\n }\n }\n }\n }\n return null;\n}\n\nfunction parseIdWithProps(raw: string): { id: string; propsStr: string | null } {\n const bracketIdx = raw.indexOf(\"[\");\n if (bracketIdx === -1) return { id: raw.trim(), propsStr: null };\n const id = raw.substring(0, bracketIdx).trim();\n const endBracket = raw.lastIndexOf(\"]\");\n const propsStr = raw.substring(bracketIdx + 1, endBracket === -1 ? raw.length : endBracket);\n return { id, propsStr };\n}\n\nfunction splitProps(propsStr: string): string[] {\n const result: string[] = [];\n let current = \"\";\n let parenDepth = 0;\n for (const ch of propsStr) {\n if (ch === \"(\") parenDepth++;\n if (ch === \")\") parenDepth--;\n if (ch === \",\" && parenDepth === 0) {\n result.push(current);\n current = \"\";\n } else {\n current += ch;\n }\n }\n if (current.trim()) result.push(current);\n return result;\n}\n\nfunction buildIndividual(id: string, propsStr: string | null, _lineNum: number): Individual {\n const ind: Individual = {\n id: id.toLowerCase(),\n label: id,\n sex: \"unknown\",\n status: \"alive\",\n };\n\n if (!propsStr) return ind;\n\n const tokens = splitProps(propsStr);\n for (const rawToken of tokens) {\n const token = rawToken.trim();\n const lower = token.toLowerCase();\n\n if (VALID_SEX.has(lower)) {\n ind.sex = lower === \"amab\" ? \"male\" : lower === \"afab\" ? \"female\" : lower === \"uaab\" ? \"unknown\" : lower as Individual[\"sex\"];\n } else if (VALID_STATUS.has(lower)) {\n ind.status = lower as Individual[\"status\"];\n } else if (GENETIC_STATUSES.has(lower)) {\n ind.geneticStatus = lower as GeneticStatus;\n } else if (MARKERS.has(lower)) {\n if (!ind.markers) ind.markers = [];\n ind.markers.push(lower as IndividualMarker);\n } else if (/^\\d{4}$/.test(lower)) {\n ind.birthYear = parseInt(token, 10);\n } else if (lower.startsWith(\"affected:\")) {\n ind.geneticStatus = \"affected\";\n const traits = token.substring(\"affected:\".length).trim().split(\"+\").map(t => t.trim());\n ind.conditions = traits.map(t => ({ label: t, fill: \"full\" as ConditionFill }));\n } else if (token.includes(\":\")) {\n const colonIdx = token.indexOf(\":\");\n const key = token.substring(0, colonIdx).trim().toLowerCase();\n const value = token.substring(colonIdx + 1).trim().replace(/^\"|\"$/g, \"\");\n if (key === \"label\") {\n ind.label = value;\n } else {\n if (!ind.properties) ind.properties = {};\n ind.properties[key] = value;\n }\n }\n }\n\n return ind;\n}\n\nfunction mergeIndividual(existing: Individual, incoming: Individual): Individual {\n return {\n ...existing,\n sex: incoming.sex !== \"unknown\" ? incoming.sex : existing.sex,\n status: incoming.status !== \"alive\" ? incoming.status : existing.status,\n birthYear: incoming.birthYear ?? existing.birthYear,\n geneticStatus: incoming.geneticStatus ?? existing.geneticStatus,\n markers: incoming.markers ?? existing.markers,\n conditions: incoming.conditions ?? existing.conditions,\n properties: { ...existing.properties, ...incoming.properties },\n };\n}\n","import type {\n DiagramAST,\n Individual,\n Relationship,\n RelationshipType,\n LayoutConfig,\n LayoutResult,\n LayoutNode,\n LayoutEdge,\n} from \"../../core/types\";\n\n// ─── Internal types ─────────────────────────────────────────\n\ninterface FamilyUnit {\n id: string;\n partners: [string, string];\n relationship: RelationshipType;\n children: string[];\n}\n\ninterface LayoutGraph {\n individuals: Map<string, Individual>;\n familyUnits: FamilyUnit[];\n generations: Map<string, number>;\n childOf: Map<string, string>;\n}\n\n// ─── Constants ─────────────────────────────────────────────\n\nconst LABEL_HEIGHT = 20;\nconst LABEL_GAP = 6;\nconst GEN_LABEL_MARGIN = 50;\n\n// ─── Public API ─────────────────────────────────────────────\n\nexport function layoutPedigree(\n ast: DiagramAST,\n config: LayoutConfig\n): LayoutResult {\n const graph = buildGraph(ast);\n assignGenerations(graph);\n const ordered = orderNodesInGenerations(graph);\n const positions = assignPositions(ordered, graph, config);\n const edges = computeEdges(graph, positions, config);\n return packageResult(positions, edges, graph, config);\n}\n\n// ─── Step 1: Build graph ────────────────────────────────────\n\nfunction buildGraph(ast: DiagramAST): LayoutGraph {\n const individuals = new Map<string, Individual>();\n for (const ind of ast.individuals) individuals.set(ind.id, ind);\n\n const familyUnits: FamilyUnit[] = [];\n const childOf = new Map<string, string>();\n\n const coupleRels = ast.relationships.filter(\n (r) => r.type === \"married\" || r.type === \"separated\" ||\n r.type === \"consanguineous\" || r.type === \"cohabiting\"\n );\n\n for (const rel of coupleRels) {\n const fuId = `${rel.from}+${rel.to}`;\n const indA = individuals.get(rel.from);\n const indB = individuals.get(rel.to);\n\n let partners: [string, string];\n if (indA && indB) {\n if (indA.sex === \"male\" && indB.sex === \"female\") {\n partners = [rel.from, rel.to];\n } else if (indA.sex === \"female\" && indB.sex === \"male\") {\n partners = [rel.to, rel.from];\n } else {\n partners = [rel.from, rel.to];\n }\n } else {\n partners = [rel.from, rel.to];\n }\n\n const children: string[] = [];\n for (const r of ast.relationships) {\n if (r.type === \"parent-child\" && r.from === fuId) {\n children.push(r.to);\n childOf.set(r.to, fuId);\n }\n }\n\n children.sort((a, b) => {\n const ia = individuals.get(a);\n const ib = individuals.get(b);\n return (ia?.birthYear ?? 9999) - (ib?.birthYear ?? 9999);\n });\n\n familyUnits.push({ id: fuId, partners, relationship: rel.type, children });\n }\n\n return { individuals, familyUnits, generations: new Map(), childOf };\n}\n\n// ─── Step 2: Assign generations ─────────────────────────────\n\nfunction assignGenerations(graph: LayoutGraph): void {\n const { individuals, familyUnits, childOf, generations } = graph;\n const allIds = Array.from(individuals.keys());\n const roots = allIds.filter((id) => !childOf.has(id));\n\n if (roots.length === 0 && allIds.length > 0) {\n for (const id of allIds) generations.set(id, 0);\n return;\n }\n\n for (const root of roots) {\n if (!generations.has(root)) generations.set(root, 0);\n }\n\n let changed = true;\n while (changed) {\n changed = false;\n for (const fu of familyUnits) {\n const gen0 = generations.get(fu.partners[0]);\n const gen1 = generations.get(fu.partners[1]);\n\n let partnerGen: number;\n if (gen0 !== undefined && gen1 !== undefined) {\n partnerGen = Math.max(gen0, gen1);\n if (gen0 !== partnerGen) { generations.set(fu.partners[0], partnerGen); changed = true; }\n if (gen1 !== partnerGen) { generations.set(fu.partners[1], partnerGen); changed = true; }\n } else if (gen0 !== undefined) {\n partnerGen = gen0;\n generations.set(fu.partners[1], partnerGen); changed = true;\n } else if (gen1 !== undefined) {\n partnerGen = gen1;\n generations.set(fu.partners[0], partnerGen); changed = true;\n } else {\n continue;\n }\n\n for (const childId of fu.children) {\n const childGen = partnerGen + 1;\n const existing = generations.get(childId);\n if (existing === undefined || existing < childGen) {\n generations.set(childId, childGen);\n changed = true;\n }\n }\n }\n }\n\n for (const id of allIds) {\n if (!generations.has(id)) generations.set(id, 0);\n }\n}\n\n// ─── Step 3: Order nodes ───────────────────────────────────\n\ninterface OrderedGeneration {\n index: number;\n nodeIds: string[];\n}\n\nfunction orderNodesInGenerations(graph: LayoutGraph): OrderedGeneration[] {\n const genGroups = new Map<number, string[]>();\n for (const [id, gen] of graph.generations) {\n const grp = genGroups.get(gen) ?? [];\n grp.push(id);\n genGroups.set(gen, grp);\n }\n\n const genIndices = Array.from(genGroups.keys()).sort((a, b) => a - b);\n const result: OrderedGeneration[] = [];\n\n for (const genIdx of genIndices) {\n const nodeIds = genGroups.get(genIdx) ?? [];\n result.push({ index: genIdx, nodeIds: orderGeneration(nodeIds, graph) });\n }\n\n return result;\n}\n\nfunction orderGeneration(nodeIds: string[], graph: LayoutGraph): string[] {\n if (nodeIds.length <= 1) return [...nodeIds];\n\n const nodeSet = new Set(nodeIds);\n const placed = new Set<string>();\n const ordered: string[] = [];\n\n const fuInGen = graph.familyUnits.filter(\n (fu) => nodeSet.has(fu.partners[0]) || nodeSet.has(fu.partners[1])\n );\n\n for (const fu of fuInGen) {\n for (const p of fu.partners) {\n if (nodeSet.has(p) && !placed.has(p)) {\n ordered.push(p);\n placed.add(p);\n }\n }\n }\n\n for (const id of nodeIds) {\n if (!placed.has(id)) {\n ordered.push(id);\n placed.add(id);\n }\n }\n\n return ordered;\n}\n\n// ─── Step 4: Assign positions ──────────────────────────────\n\ninterface NodePosition {\n id: string;\n x: number;\n y: number;\n generation: number;\n}\n\nfunction assignPositions(\n orderedGens: OrderedGeneration[],\n graph: LayoutGraph,\n config: LayoutConfig\n): Map<string, NodePosition> {\n const positions = new Map<string, NodePosition>();\n const { nodeWidth, nodeSpacingX } = config;\n const half = nodeWidth / 2;\n const coupleGap = nodeWidth + nodeSpacingX * 0.6;\n const familyGap = nodeWidth + nodeSpacingX * 1.5;\n const genStepY = config.nodeHeight + LABEL_HEIGHT + LABEL_GAP + config.nodeSpacingY;\n\n for (const gen of orderedGens) {\n const y = gen.index * genStepY + half;\n const segments = buildSegments(gen.nodeIds, graph);\n\n let xCursor = GEN_LABEL_MARGIN + half;\n for (let s = 0; s < segments.length; s++) {\n const seg = segments[s];\n if (s > 0) xCursor += familyGap;\n\n if (seg.type === \"couple\") {\n positions.set(seg.ids[0], { id: seg.ids[0], x: xCursor, y, generation: gen.index });\n xCursor += coupleGap;\n positions.set(seg.ids[1], { id: seg.ids[1], x: xCursor, y, generation: gen.index });\n } else {\n positions.set(seg.ids[0], { id: seg.ids[0], x: xCursor, y, generation: gen.index });\n }\n }\n }\n\n resolveOverlaps(positions, orderedGens, config);\n centerChildrenUnderParents(positions, graph, config);\n resolveOverlaps(positions, orderedGens, config);\n\n return positions;\n}\n\ninterface Segment {\n type: \"couple\" | \"single\";\n ids: string[];\n}\n\nfunction buildSegments(nodeIds: string[], graph: LayoutGraph): Segment[] {\n const nodeSet = new Set(nodeIds);\n const segments: Segment[] = [];\n const placed = new Set<string>();\n\n for (const id of nodeIds) {\n if (placed.has(id)) continue;\n\n const fu = graph.familyUnits.find(\n (f) =>\n (f.partners[0] === id || f.partners[1] === id) &&\n !placed.has(f.partners[0]) &&\n !placed.has(f.partners[1]) &&\n nodeSet.has(f.partners[0]) &&\n nodeSet.has(f.partners[1])\n );\n\n if (fu) {\n segments.push({ type: \"couple\", ids: [fu.partners[0], fu.partners[1]] });\n placed.add(fu.partners[0]);\n placed.add(fu.partners[1]);\n } else {\n segments.push({ type: \"single\", ids: [id] });\n placed.add(id);\n }\n }\n\n return segments;\n}\n\nfunction centerChildrenUnderParents(\n positions: Map<string, NodePosition>,\n graph: LayoutGraph,\n config: LayoutConfig\n): void {\n const coupleGap = config.nodeSpacingX + config.nodeWidth;\n\n const personToFUs = new Map<string, FamilyUnit[]>();\n for (const fu of graph.familyUnits) {\n for (const p of fu.partners) {\n const arr = personToFUs.get(p) ?? [];\n arr.push(fu);\n personToFUs.set(p, arr);\n }\n }\n\n for (let pass = 0; pass < 3; pass++) {\n for (const fu of graph.familyUnits) {\n if (fu.children.length === 0) continue;\n\n const posA = positions.get(fu.partners[0]);\n const posB = positions.get(fu.partners[1]);\n if (!posA || !posB) continue;\n\n const parentMidX = (posA.x + posB.x) / 2;\n const childSpacing = config.nodeSpacingX + config.nodeWidth;\n\n const sortedChildren = [...fu.children].sort((a, b) => {\n const ia = graph.individuals.get(a);\n const ib = graph.individuals.get(b);\n return (ia?.birthYear ?? 9999) - (ib?.birthYear ?? 9999);\n });\n\n if (sortedChildren.length > 1) {\n // Calculate per-gap spacing: add room for married-in spouses\n const gaps: number[] = [];\n for (let j = 0; j < sortedChildren.length - 1; j++) {\n let gap = childSpacing;\n\n // If the RIGHT child has a spouse placed to their LEFT\n const nextChild = sortedChildren[j + 1];\n const nextFUs = personToFUs.get(nextChild) ?? [];\n for (const cfu of nextFUs) {\n const pid = cfu.partners[0] === nextChild ? cfu.partners[1] : cfu.partners[0];\n const cInd = graph.individuals.get(nextChild);\n const pInd = graph.individuals.get(pid);\n if (!(cInd?.sex === \"male\" || (cInd?.sex !== \"female\" && pInd?.sex === \"female\"))) {\n gap += coupleGap;\n }\n }\n\n // If the LEFT child has a spouse placed to their RIGHT\n const currChild = sortedChildren[j];\n const currFUs = personToFUs.get(currChild) ?? [];\n for (const cfu of currFUs) {\n const pid = cfu.partners[0] === currChild ? cfu.partners[1] : cfu.partners[0];\n const cInd = graph.individuals.get(currChild);\n const pInd = graph.individuals.get(pid);\n if (cInd?.sex === \"male\" || (cInd?.sex !== \"female\" && pInd?.sex === \"female\")) {\n gap += coupleGap;\n }\n }\n\n gaps.push(gap);\n }\n\n const totalWidth = gaps.reduce((s, g) => s + g, 0);\n const startX = parentMidX - totalWidth / 2;\n let cx = startX;\n for (let j = 0; j < sortedChildren.length; j++) {\n const pos = positions.get(sortedChildren[j]);\n if (pos) pos.x = cx;\n if (j < gaps.length) cx += gaps[j];\n }\n } else {\n const pos = positions.get(sortedChildren[0]);\n if (pos) pos.x = parentMidX;\n }\n\n for (const childId of fu.children) {\n const childPos = positions.get(childId);\n if (!childPos) continue;\n const childFUs = personToFUs.get(childId) ?? [];\n for (const childFU of childFUs) {\n const partnerId = childFU.partners[0] === childId ? childFU.partners[1] : childFU.partners[0];\n const partnerPos = positions.get(partnerId);\n if (!partnerPos) continue;\n const childInd = graph.individuals.get(childId);\n const partnerInd = graph.individuals.get(partnerId);\n if (childInd?.sex === \"male\" || (childInd?.sex !== \"female\" && partnerInd?.sex === \"female\")) {\n partnerPos.x = childPos.x + coupleGap;\n } else {\n partnerPos.x = childPos.x - coupleGap;\n }\n }\n }\n }\n }\n}\n\nfunction resolveOverlaps(\n positions: Map<string, NodePosition>,\n orderedGens: OrderedGeneration[],\n config: LayoutConfig\n): void {\n const minGap = config.nodeWidth + config.nodeSpacingX;\n\n for (const gen of orderedGens) {\n const genNodes = gen.nodeIds\n .map((id) => positions.get(id))\n .filter((p): p is NodePosition => p !== undefined);\n genNodes.sort((a, b) => a.x - b.x);\n\n for (let j = 1; j < genNodes.length; j++) {\n const gap = genNodes[j].x - genNodes[j - 1].x;\n if (gap < minGap) {\n const shift = minGap - gap;\n for (let k = j; k < genNodes.length; k++) genNodes[k].x += shift;\n }\n }\n }\n\n let minX = Infinity;\n for (const pos of positions.values()) {\n if (pos.x < minX) minX = pos.x;\n }\n const minAllowed = GEN_LABEL_MARGIN + config.nodeWidth / 2;\n if (minX < minAllowed) {\n const shift = minAllowed - minX;\n for (const pos of positions.values()) pos.x += shift;\n }\n}\n\n// ─── Step 5: Compute edges ─────────────────────────────────\n\nfunction computeEdges(\n graph: LayoutGraph,\n positions: Map<string, NodePosition>,\n config: LayoutConfig\n): LayoutEdge[] {\n const edges: LayoutEdge[] = [];\n const half = config.nodeWidth / 2;\n const dropY_offset = config.nodeHeight / 2 + LABEL_HEIGHT + LABEL_GAP + config.nodeSpacingY * 0.35;\n\n for (const fu of graph.familyUnits) {\n const posA = positions.get(fu.partners[0]);\n const posB = positions.get(fu.partners[1]);\n if (!posA || !posB) continue;\n\n const leftPos = posA.x < posB.x ? posA : posB;\n const rightPos = posA.x < posB.x ? posB : posA;\n const leftId = posA.x < posB.x ? fu.partners[0] : fu.partners[1];\n const rightId = posA.x < posB.x ? fu.partners[1] : fu.partners[0];\n\n const coupleRel: Relationship = { type: fu.relationship, from: leftId, to: rightId };\n const couplePath = `M ${leftPos.x + half} ${leftPos.y} L ${rightPos.x - half} ${rightPos.y}`;\n edges.push({ from: leftId, to: rightId, relationship: coupleRel, path: couplePath });\n\n // Consanguinity: add second parallel line\n if (fu.relationship === \"consanguineous\") {\n const offset = 3;\n const consPath = `M ${leftPos.x + half} ${leftPos.y + offset} L ${rightPos.x - half} ${rightPos.y + offset}`;\n edges.push({\n from: leftId, to: rightId,\n relationship: { type: \"consanguineous\", from: leftId, to: rightId, label: \"_double\" },\n path: consPath,\n });\n }\n\n if (fu.children.length > 0) {\n const midX = (posA.x + posB.x) / 2;\n const coupleY = posA.y;\n const dropY = coupleY + dropY_offset;\n\n const childPositions = fu.children\n .map((cid) => ({ id: cid, pos: positions.get(cid) }))\n .filter((c): c is { id: string; pos: NodePosition } => c.pos !== undefined);\n\n if (childPositions.length === 0) continue;\n childPositions.sort((a, b) => a.pos.x - b.pos.x);\n\n const leftX = childPositions[0].pos.x;\n const rightX = childPositions[childPositions.length - 1].pos.x;\n\n edges.push({\n from: fu.partners[0], to: fu.partners[1],\n relationship: { type: \"parent-child\", from: fu.id, to: \"_drop\" },\n path: `M ${midX} ${coupleY} L ${midX} ${dropY}`,\n });\n\n if (childPositions.length > 1) {\n edges.push({\n from: fu.partners[0], to: fu.partners[1],\n relationship: { type: \"parent-child\", from: fu.id, to: \"_sibship\" },\n path: `M ${leftX} ${dropY} L ${rightX} ${dropY}`,\n });\n }\n\n for (const child of childPositions) {\n const childTop = child.pos.y - config.nodeHeight / 2;\n const childPath = childPositions.length === 1\n ? `M ${midX} ${coupleY} L ${midX} ${childTop}`\n : `M ${child.pos.x} ${dropY} L ${child.pos.x} ${childTop}`;\n\n edges.push({\n from: fu.id, to: child.id,\n relationship: { type: \"parent-child\", from: fu.id, to: child.id },\n path: childPath,\n });\n }\n }\n }\n\n return edges;\n}\n\n// ─── Step 6: Package result ─────────────────────────────────\n\nfunction packageResult(\n positions: Map<string, NodePosition>,\n edges: LayoutEdge[],\n graph: LayoutGraph,\n config: LayoutConfig\n): LayoutResult {\n const padding = 40;\n const nodes: LayoutNode[] = [];\n\n for (const [id, pos] of positions) {\n const ind = graph.individuals.get(id);\n if (!ind) continue;\n nodes.push({\n id,\n x: pos.x - config.nodeWidth / 2 + padding,\n y: pos.y - config.nodeHeight / 2 + padding,\n width: config.nodeWidth,\n height: config.nodeHeight,\n generation: pos.generation,\n individual: ind,\n });\n }\n\n const shiftedEdges = edges.map((e) => ({\n ...e,\n path: shiftPath(e.path, padding, padding),\n }));\n\n let maxX = 0;\n let maxY = 0;\n let minX = Infinity;\n for (const node of nodes) {\n const cx = node.x + node.width / 2;\n const labelText = node.individual.label || node.individual.id;\n const labelHalfWidth = labelText.length * 3.8;\n const right = Math.max(node.x + node.width, cx + labelHalfWidth);\n const left = Math.min(node.x, cx - labelHalfWidth);\n const bottom = node.y + node.height;\n if (right > maxX) maxX = right;\n if (bottom > maxY) maxY = bottom;\n if (left < minX) minX = left;\n }\n\n if (minX < 0) {\n const shift = -minX;\n for (const node of nodes) {\n node.x += shift;\n }\n for (const edge of shiftedEdges) {\n edge.path = shiftPath(edge.path, shift, 0);\n }\n maxX += shift;\n }\n\n return {\n width: maxX + padding,\n height: maxY + padding + LABEL_GAP + LABEL_HEIGHT + 10,\n nodes,\n edges: shiftedEdges,\n };\n}\n\nfunction shiftPath(pathData: string, dx: number, dy: number): string {\n return pathData.replace(\n /([ML])\\s*([\\d.-]+)\\s+([\\d.-]+)/g,\n (_match, cmd: string, xStr: string, yStr: string) => {\n const x = parseFloat(xStr) + dx;\n const y = parseFloat(yStr) + dy;\n return `${cmd} ${x} ${y}`;\n }\n );\n}\n","import type {\n LayoutResult,\n LayoutNode,\n LayoutEdge,\n RenderConfig,\n Individual,\n LegendEntry,\n DiagramAST,\n} from \"../../core/types\";\nimport {\n svgRoot,\n el,\n group,\n rect,\n circle,\n polygon,\n line,\n text,\n title,\n desc,\n defs,\n path,\n} from \"../../core/svg\";\nimport { cssCustomProperties, resolvePersonTheme, STROKE_WIDTH, type ResolvedTheme, type PersonTokens } from \"../../core/theme\";\n\n// ─── Public API ─────────────────────────────────────────────\n\nexport function renderPedigree(\n layout: LayoutResult,\n config: RenderConfig,\n ast?: DiagramAST\n): string {\n const t = resolvePersonTheme(config.theme);\n const defsStr = buildDefs(layout.nodes, t);\n const styleStr = buildStyles(config, t);\n\n const genGroups = groupByGeneration(layout.nodes);\n const edgeLayers = renderEdges(layout.edges);\n const nodeLayers = renderNodes(genGroups);\n const labelLayer = renderLabels(layout.nodes, genGroups, config);\n const genLabels = renderGenerationLabels(genGroups, config);\n\n const nodeCount = layout.nodes.length;\n const genCount = genGroups.size;\n\n const diagramTitle = ast?.metadata?.title ?? \"Pedigree\";\n\n const children = [\n title(diagramTitle),\n desc(`Pedigree chart with ${nodeCount} individuals across ${genCount} generations`),\n defsStr,\n styleStr,\n genLabels,\n edgeLayers,\n ...nodeLayers,\n labelLayer,\n ];\n\n if (ast?.legend && ast.legend.length > 0) {\n children.push(renderLegend(ast.legend, layout, config, t));\n }\n\n return svgRoot(\n {\n viewBox: `0 0 ${layout.width} ${layout.height}`,\n class: \"schematex-diagram schematex-pedigree\",\n width: layout.width,\n height: layout.height,\n },\n children\n );\n}\n\n// ─── Defs ──────────────────────────────────────────────────\n\nfunction buildDefs(nodes: LayoutNode[], t: ResolvedTheme<PersonTokens>): string {\n const children: string[] = [];\n const needs = new Set<string>();\n\n for (const n of nodes) {\n const gs = n.individual.geneticStatus;\n if (gs) needs.add(gs);\n }\n\n if (needs.has(\"carrier\")) {\n children.push(\n el(\"clipPath\", { id: \"schematex-pedigree-clip-carrier-rect\" }, [\n rect({ x: \"0\", y: \"0\", width: \"50%\", height: \"100%\" }),\n ]),\n el(\"clipPath\", { id: \"schematex-pedigree-clip-carrier-circle\" }, [\n rect({ x: \"-50\", y: \"-50\", width: \"50\", height: \"100\" }),\n ])\n );\n }\n\n // Proband arrow marker\n children.push(\n el(\"marker\", {\n id: \"schematex-pedigree-proband-arrow\",\n viewBox: \"0 0 10 10\",\n refX: \"0\",\n refY: \"5\",\n markerWidth: \"8\",\n markerHeight: \"8\",\n orient: \"auto-start-reverse\",\n }, [\n path({ d: \"M 0 0 L 10 5 L 0 10 z\", fill: t.stroke }),\n ])\n );\n\n return defs(children);\n}\n\n// ─── Styles ────────────────────────────────────────────────\n\nfunction buildStyles(config: RenderConfig, t: ResolvedTheme<PersonTokens>): string {\n const css = `\n.schematex-pedigree {${cssCustomProperties(t)}\n background: ${t.bg};\n}\n.schematex-pedigree-shape { fill: ${t.fill}; stroke: ${t.stroke}; stroke-width: ${STROKE_WIDTH.normal}; stroke-linejoin: round; }\n.schematex-pedigree-label { font-family: ${config.fontFamily}; font-size: ${config.fontSize}px; text-anchor: middle; fill: ${t.text}; }\n.schematex-pedigree-gen-label { font-family: ${config.fontFamily}; font-size: 14px; font-weight: bold; fill: ${t.text}; text-anchor: middle; }\n.schematex-pedigree-edge { stroke: ${t.stroke}; stroke-width: ${STROKE_WIDTH.normal}; fill: none; stroke-linecap: round; stroke-linejoin: round; }\n.schematex-pedigree-deceased-mark { stroke: ${t.deceasedMark}; stroke-width: ${STROKE_WIDTH.normal}; stroke-linecap: round; }\n.schematex-pedigree-affected-fill { fill: ${t.conditionFill}; }\n.schematex-pedigree-carrier-fill { fill: ${t.conditionFill}; }\n.schematex-pedigree-carrier-x-dot { fill: ${t.conditionFill}; }\n.schematex-pedigree-presymptomatic-mark { stroke: ${t.conditionFill}; stroke-width: ${STROKE_WIDTH.normal}; }\n.schematex-pedigree-proband-arrow-line { stroke: ${t.stroke}; stroke-width: ${STROKE_WIDTH.normal}; fill: none; marker-end: url(#schematex-pedigree-proband-arrow); }\n.schematex-pedigree-proband-label { font-family: ${config.fontFamily}; font-size: 10px; font-weight: bold; fill: ${t.stroke}; }\n.schematex-pedigree-legend { font-family: ${config.fontFamily}; font-size: 11px; fill: ${t.text}; }\n.schematex-pedigree-legend-box { fill: ${t.fill}; stroke: ${t.neutral}; stroke-width: 1; }\n`;\n return el(\"style\", {}, css);\n}\n\n// ─── Edges ─────────────────────────────────────────────────\n\nfunction renderEdges(edges: LayoutEdge[]): string {\n const children: string[] = [];\n\n for (const edge of edges) {\n const relType = edge.relationship.type;\n const cssClass = `schematex-pedigree-edge schematex-pedigree-edge-${relType}`;\n\n const elements: string[] = [\n el(\"path\", { d: edge.path, class: \"schematex-pedigree-edge-path\" }),\n ];\n\n if (relType === \"separated\") {\n const mid = pathMidpoint(edge.path);\n if (mid) {\n elements.push(\n line({\n x1: mid.x - 4, y1: mid.y - 6,\n x2: mid.x + 4, y2: mid.y + 6,\n class: \"schematex-pedigree-edge\",\n })\n );\n }\n }\n\n children.push(\n group({ class: cssClass, \"data-from\": edge.from, \"data-to\": edge.to }, elements)\n );\n }\n\n return group({ class: \"schematex-pedigree-edges\" }, children);\n}\n\nfunction pathMidpoint(pathData: string): { x: number; y: number } | null {\n const coords = pathData.match(/[\\d.-]+/g);\n if (!coords || coords.length < 4) return null;\n return {\n x: (parseFloat(coords[0]) + parseFloat(coords[2])) / 2,\n y: (parseFloat(coords[1]) + parseFloat(coords[3])) / 2,\n };\n}\n\n// ─── Nodes ─────────────────────────────────────────────────\n\nfunction groupByGeneration(nodes: LayoutNode[]): Map<number, LayoutNode[]> {\n const groups = new Map<number, LayoutNode[]>();\n for (const node of nodes) {\n const grp = groups.get(node.generation) ?? [];\n grp.push(node);\n groups.set(node.generation, grp);\n }\n return groups;\n}\n\nfunction renderNodes(genGroups: Map<number, LayoutNode[]>): string[] {\n const layers: string[] = [];\n const sortedGens = Array.from(genGroups.keys()).sort((a, b) => a - b);\n\n for (const genIdx of sortedGens) {\n const nodes = genGroups.get(genIdx) ?? [];\n const nodeElements: string[] = [];\n\n for (const node of nodes) {\n const cx = node.x + node.width / 2;\n const cy = node.y + node.height / 2;\n nodeElements.push(renderPedigreeSymbol(node.individual, cx, cy, node.width));\n }\n\n layers.push(\n group(\n { class: `schematex-pedigree-generation schematex-pedigree-generation-${genIdx}`, \"data-generation\": genIdx },\n nodeElements\n )\n );\n }\n\n return layers;\n}\n\nfunction renderPedigreeSymbol(\n ind: Individual,\n x: number,\n y: number,\n size: number\n): string {\n const half = size / 2;\n const classes = [\"schematex-pedigree-node\", `schematex-pedigree-${ind.sex === \"other\" ? \"unknown\" : ind.sex}`];\n if (ind.status === \"deceased\") classes.push(\"schematex-pedigree-deceased\");\n if (ind.geneticStatus) classes.push(`schematex-pedigree-${ind.geneticStatus}`);\n\n const titleText = formatTitle(ind);\n const children: string[] = [title(titleText)];\n\n // Base shape\n children.push(baseShape(ind.sex, half));\n\n // Genetic status fills\n const gs = ind.geneticStatus;\n if (gs === \"affected\") {\n children.push(affectedFill(ind.sex, half));\n } else if (gs === \"carrier\") {\n children.push(carrierFill(ind.sex, half));\n } else if (gs === \"carrier-x\" || gs === \"obligate-carrier\") {\n children.push(carrierDot(half));\n }\n\n // Presymptomatic vertical line\n if (gs === \"presymptomatic\") {\n children.push(\n line({ x1: 0, y1: -half, x2: 0, y2: half, class: \"schematex-pedigree-presymptomatic-mark\" })\n );\n }\n\n // Deceased: diagonal slash (pedigree uses / not X)\n if (ind.status === \"deceased\") {\n const ext = ind.sex === \"female\" ? half * 0.707 : half;\n children.push(\n line({ x1: ext, y1: -ext, x2: -ext, y2: ext, class: \"schematex-pedigree-deceased-mark\" })\n );\n }\n\n // Proband arrow\n if (ind.markers?.includes(\"proband\")) {\n const arrowLen = 20;\n children.push(\n line({\n x1: -half - arrowLen, y1: half + arrowLen,\n x2: -half - 2, y2: half + 2,\n class: \"schematex-pedigree-proband-arrow-line\",\n }),\n text(\n { x: -half - arrowLen - 4, y: half + arrowLen + 4, class: \"schematex-pedigree-proband-label\", \"text-anchor\": \"end\" },\n \"P\"\n )\n );\n }\n\n // Consultand arrow\n if (ind.markers?.includes(\"consultand\")) {\n const arrowLen = 20;\n children.push(\n line({\n x1: -half - arrowLen, y1: half + arrowLen,\n x2: -half - 2, y2: half + 2,\n class: \"schematex-pedigree-proband-arrow-line\",\n }),\n text(\n { x: -half - arrowLen - 4, y: half + arrowLen + 4, class: \"schematex-pedigree-proband-label\", \"text-anchor\": \"end\" },\n \"C\"\n )\n );\n }\n\n // Evaluated marker\n if (ind.markers?.includes(\"evaluated\")) {\n children.push(\n text(\n { x: 0, y: -half - 4, class: \"schematex-pedigree-proband-label\", \"text-anchor\": \"middle\" },\n \"E\"\n )\n );\n }\n\n return group(\n {\n class: classes.join(\" \"),\n \"data-individual-id\": ind.id,\n transform: `translate(${x}, ${y})`,\n },\n children\n );\n}\n\nfunction baseShape(sex: Individual[\"sex\"], half: number): string {\n switch (sex) {\n case \"male\":\n return rect({ x: -half, y: -half, width: half * 2, height: half * 2, class: \"schematex-pedigree-shape\" });\n case \"female\":\n return circle({ cx: 0, cy: 0, r: half, class: \"schematex-pedigree-shape\" });\n default:\n return polygon({ points: `0,${-half} ${half},0 0,${half} ${-half},0`, class: \"schematex-pedigree-shape\" });\n }\n}\n\nfunction affectedFill(sex: Individual[\"sex\"], half: number): string {\n const attrs = { class: \"schematex-pedigree-affected-fill\" };\n switch (sex) {\n case \"male\":\n return rect({ x: -half, y: -half, width: half * 2, height: half * 2, ...attrs });\n case \"female\":\n return circle({ cx: 0, cy: 0, r: half, ...attrs });\n default:\n return polygon({ points: `0,${-half} ${half},0 0,${half} ${-half},0`, ...attrs });\n }\n}\n\nfunction carrierFill(sex: Individual[\"sex\"], half: number): string {\n const clipSuffix = sex === \"female\" ? \"circle\" : \"rect\";\n const attrs = {\n class: \"schematex-pedigree-carrier-fill\",\n \"clip-path\": `url(#schematex-pedigree-clip-carrier-${clipSuffix})`,\n };\n switch (sex) {\n case \"male\":\n return rect({ x: -half, y: -half, width: half * 2, height: half * 2, ...attrs });\n case \"female\":\n return circle({ cx: 0, cy: 0, r: half, ...attrs });\n default:\n return polygon({ points: `0,${-half} ${half},0 0,${half} ${-half},0`, ...attrs });\n }\n}\n\nfunction carrierDot(half: number): string {\n return circle({ cx: 0, cy: 0, r: half * 0.15, class: \"schematex-pedigree-carrier-x-dot\" });\n}\n\nfunction formatTitle(ind: Individual): string {\n const name = ind.label.charAt(0).toUpperCase() + ind.label.slice(1);\n if (ind.geneticStatus && ind.geneticStatus !== \"unaffected\") {\n return `${name} (${ind.geneticStatus})`;\n }\n return name;\n}\n\n// ─── Labels ────────────────────────────────────────────────\n\nfunction renderLabels(\n nodes: LayoutNode[],\n genGroups: Map<number, LayoutNode[]>,\n config: RenderConfig\n): string {\n const labels: string[] = [];\n\n // Build per-generation numbering\n const genNumbering = new Map<string, string>();\n const sortedGens = Array.from(genGroups.keys()).sort((a, b) => a - b);\n for (const genIdx of sortedGens) {\n const genNodes = genGroups.get(genIdx) ?? [];\n const sorted = [...genNodes].sort((a, b) => a.x - b.x);\n const romanNum = toRoman(genIdx + 1);\n for (let i = 0; i < sorted.length; i++) {\n genNumbering.set(sorted[i].id, `${romanNum}-${i + 1}`);\n }\n }\n\n for (const node of nodes) {\n const ind = node.individual;\n const cx = node.x + node.width / 2;\n const labelY = node.y + node.height + 6 + config.fontSize;\n\n const pedigreeId = genNumbering.get(ind.id) ?? ind.id;\n const displayLabel = ind.label !== ind.id ? ind.label : pedigreeId;\n\n labels.push(\n text(\n { x: cx, y: labelY, class: \"schematex-pedigree-label\", \"data-individual-id\": ind.id },\n displayLabel\n )\n );\n }\n\n return group({ class: \"schematex-pedigree-labels\" }, labels);\n}\n\n// ─── Generation Labels ─────────────────────────────────────\n\nfunction renderGenerationLabels(\n genGroups: Map<number, LayoutNode[]>,\n _config: RenderConfig\n): string {\n const labels: string[] = [];\n const sortedGens = Array.from(genGroups.keys()).sort((a, b) => a - b);\n\n for (const genIdx of sortedGens) {\n const nodes = genGroups.get(genIdx) ?? [];\n if (nodes.length === 0) continue;\n\n const midY = nodes[0].y + nodes[0].height / 2;\n const roman = toRoman(genIdx + 1);\n\n labels.push(\n text(\n { x: 25, y: midY + 5, class: \"schematex-pedigree-gen-label\" },\n roman\n )\n );\n }\n\n return group({ class: \"schematex-pedigree-generation-labels\" }, labels);\n}\n\n// ─── Legend ────────────────────────────────────────────────\n\nfunction renderLegend(\n legendEntries: LegendEntry[],\n layout: LayoutResult,\n _config: RenderConfig,\n t: ResolvedTheme<PersonTokens>\n): string {\n const boxW = 160;\n const rowH = 22;\n const boxH = 30 + legendEntries.length * rowH;\n const x = layout.width - boxW - 20;\n const y = layout.height - boxH - 20;\n\n const children: string[] = [\n rect({ x, y, width: boxW, height: boxH, rx: 4, ry: 4, class: \"schematex-pedigree-legend-box\" }),\n text({ x: x + boxW / 2, y: y + 18, class: \"schematex-pedigree-legend\", \"text-anchor\": \"middle\", \"font-weight\": \"bold\" }, \"Legend\"),\n ];\n\n for (let i = 0; i < legendEntries.length; i++) {\n const entry = legendEntries[i];\n const ry = y + 30 + i * rowH;\n const swatchSize = 14;\n\n children.push(\n rect({\n x: x + 10,\n y: ry,\n width: swatchSize,\n height: swatchSize,\n fill: t.conditionFill,\n stroke: t.stroke,\n \"stroke-width\": \"1\",\n }),\n text({ x: x + 30, y: ry + 11, class: \"schematex-pedigree-legend\" }, entry.label)\n );\n }\n\n return group({ class: \"schematex-pedigree-legend-group\" }, children);\n}\n\n// ─── Helpers ───────────────────────────────────────────────\n\nfunction toRoman(n: number): string {\n const vals = [1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1];\n const syms = [\"M\", \"CM\", \"D\", \"CD\", \"C\", \"XC\", \"L\", \"XL\", \"X\", \"IX\", \"V\", \"IV\", \"I\"];\n let result = \"\";\n for (let i = 0; i < vals.length; i++) {\n while (n >= vals[i]) {\n result += syms[i];\n n -= vals[i];\n }\n }\n return result;\n}\n","import type { DiagramPlugin, RenderConfig } from \"../../core/types\";\nimport { parsePedigree, PedigreeParseError } from \"./parser\";\nimport { layoutPedigree } from \"./layout\";\nimport { renderPedigree } from \"./renderer\";\n\nexport const pedigree: DiagramPlugin = {\n type: \"pedigree\",\n\n detect(text: string): boolean {\n const firstLine = text.trim().split(\"\\n\")[0]?.trim().toLowerCase() ?? \"\";\n return firstLine === \"pedigree\" || firstLine.startsWith(\"pedigree \");\n },\n\n render(text: string, config?: RenderConfig): string {\n const ast = parsePedigree(text);\n const layoutConfig = {\n nodeSpacingX: 80,\n nodeSpacingY: 100,\n nodeWidth: 40,\n nodeHeight: 40,\n };\n const layout = layoutPedigree(ast, layoutConfig);\n const renderConfig: RenderConfig = {\n fontFamily: config?.fontFamily ?? \"system-ui, -apple-system, sans-serif\",\n fontSize: config?.fontSize ?? 12,\n theme: config?.theme ?? \"default\",\n padding: config?.padding ?? 20,\n };\n return renderPedigree(layout, renderConfig, ast);\n },\n};\n\nexport { parsePedigree, PedigreeParseError, layoutPedigree, renderPedigree };\n"]}
|
|
@@ -0,0 +1,449 @@
|
|
|
1
|
+
import { el, text, group, svgRoot, title, desc, defs } from './chunk-KLJEK547.js';
|
|
2
|
+
|
|
3
|
+
// src/diagrams/timing/parser.ts
|
|
4
|
+
var TimingParseError = class extends Error {
|
|
5
|
+
constructor(message) {
|
|
6
|
+
super(message);
|
|
7
|
+
this.name = "TimingParseError";
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
var VALID_STATES = /^[01xzpPnNhHlLudD=\.23456789]+$/;
|
|
11
|
+
function splitDataList(rest) {
|
|
12
|
+
const trimmed = rest.trim();
|
|
13
|
+
const m = trimmed.match(/^(\S+)\s*(.*)$/);
|
|
14
|
+
if (!m) return { wave: trimmed, data: [] };
|
|
15
|
+
const wave = m[1];
|
|
16
|
+
const remainder = m[2].trim();
|
|
17
|
+
if (!remainder) return { wave, data: [] };
|
|
18
|
+
const data = [];
|
|
19
|
+
let r = remainder.replace(/^data\s*:\s*/, "").trim();
|
|
20
|
+
if (r.startsWith("[") && r.endsWith("]")) r = r.slice(1, -1);
|
|
21
|
+
const re = /"([^"]*)"/g;
|
|
22
|
+
let match;
|
|
23
|
+
while ((match = re.exec(r)) !== null) data.push(match[1]);
|
|
24
|
+
return { wave, data };
|
|
25
|
+
}
|
|
26
|
+
function parseTiming(text2) {
|
|
27
|
+
const lines = text2.split("\n").map((l) => l.replace(/\r$/, ""));
|
|
28
|
+
const signals = [];
|
|
29
|
+
let title2;
|
|
30
|
+
let hscale;
|
|
31
|
+
let currentGroup = null;
|
|
32
|
+
for (const raw of lines) {
|
|
33
|
+
const line = raw.trim();
|
|
34
|
+
if (!line || line.startsWith("#")) continue;
|
|
35
|
+
if (/^timing\b/i.test(line)) {
|
|
36
|
+
const titleMatch = line.match(/"([^"]*)"/);
|
|
37
|
+
if (titleMatch) title2 = titleMatch[1];
|
|
38
|
+
const hs = line.match(/hscale\s*:\s*(\d+(?:\.\d+)?)/);
|
|
39
|
+
if (hs) hscale = parseFloat(hs[1]);
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
42
|
+
const groupOpen = line.match(/^\[([^\]]+)\]$/) || line.match(/^group\s+"([^"]+)"\s*\{?$/);
|
|
43
|
+
if (groupOpen) {
|
|
44
|
+
currentGroup = { label: groupOpen[1], signals: [] };
|
|
45
|
+
signals.push(currentGroup);
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
if (line === "}") {
|
|
49
|
+
currentGroup = null;
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
if (line === "---") {
|
|
53
|
+
currentGroup = null;
|
|
54
|
+
continue;
|
|
55
|
+
}
|
|
56
|
+
const sigMatch = line.match(/^([^:]+):\s*(.+)$/);
|
|
57
|
+
if (sigMatch) {
|
|
58
|
+
const name = sigMatch[1].trim();
|
|
59
|
+
const { wave, data } = splitDataList(sigMatch[2]);
|
|
60
|
+
if (!VALID_STATES.test(wave)) {
|
|
61
|
+
throw new TimingParseError(`Invalid wave string "${wave}" for signal ${name}`);
|
|
62
|
+
}
|
|
63
|
+
const signal = { name, wave, data: data.length ? data : void 0 };
|
|
64
|
+
if (currentGroup) currentGroup.signals.push(signal);
|
|
65
|
+
else signals.push(signal);
|
|
66
|
+
continue;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
return { type: "timing", title: title2, hscale, signals };
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// src/diagrams/timing/renderer.ts
|
|
73
|
+
var NAME_W = 120;
|
|
74
|
+
var SIG_H = 36;
|
|
75
|
+
var PAD_TOP = 12;
|
|
76
|
+
var PAD_BOT = 12;
|
|
77
|
+
var PAD_V = 6;
|
|
78
|
+
var DEFAULT_PW = 40;
|
|
79
|
+
var GROUP_LABEL_H = 22;
|
|
80
|
+
function flatten(items, indent = 0) {
|
|
81
|
+
const out = [];
|
|
82
|
+
for (const item of items) {
|
|
83
|
+
if ("wave" in item) {
|
|
84
|
+
out.push({ kind: "signal", signal: item, indent });
|
|
85
|
+
} else {
|
|
86
|
+
out.push({ kind: "group", label: item.label, indent });
|
|
87
|
+
out.push(...flatten(item.signals, indent + 1));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return out;
|
|
91
|
+
}
|
|
92
|
+
function renderWave(signal, ctx) {
|
|
93
|
+
const { pw, yHi, yLo, yMid } = ctx;
|
|
94
|
+
const wave = signal.wave;
|
|
95
|
+
const paths = [];
|
|
96
|
+
const busRects = [];
|
|
97
|
+
const busTexts = [];
|
|
98
|
+
const xPatchRects = [];
|
|
99
|
+
const zLines = [];
|
|
100
|
+
let prev = "none";
|
|
101
|
+
let prevChar = "";
|
|
102
|
+
let busStartX = 0;
|
|
103
|
+
let busIndex = 0;
|
|
104
|
+
let dataIdx = 0;
|
|
105
|
+
let linePath = "";
|
|
106
|
+
const startLine = (x, y) => {
|
|
107
|
+
if (linePath) paths.push(linePath);
|
|
108
|
+
linePath = `M ${x},${y}`;
|
|
109
|
+
};
|
|
110
|
+
const extendLineTo = (x, y) => {
|
|
111
|
+
linePath += ` L ${x},${y}`;
|
|
112
|
+
};
|
|
113
|
+
const flushLine = () => {
|
|
114
|
+
if (linePath) {
|
|
115
|
+
paths.push(linePath);
|
|
116
|
+
linePath = "";
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
const closeBus = (x) => {
|
|
120
|
+
const start = busStartX;
|
|
121
|
+
const end = x;
|
|
122
|
+
const inset = Math.min(5, (end - start) / 2);
|
|
123
|
+
const d = `M ${start + inset},${yHi} L ${end - inset},${yHi} L ${end},${yMid} L ${end - inset},${yLo} L ${start + inset},${yLo} L ${start},${yMid} Z`;
|
|
124
|
+
busRects.push(
|
|
125
|
+
el("path", { class: "schematex-timing-bus", d, "data-bus-index": String(busIndex) })
|
|
126
|
+
);
|
|
127
|
+
const label = signal.data?.[dataIdx] ?? "";
|
|
128
|
+
if (label) {
|
|
129
|
+
busTexts.push(
|
|
130
|
+
text(
|
|
131
|
+
{
|
|
132
|
+
x: (start + end) / 2,
|
|
133
|
+
y: yMid + 4,
|
|
134
|
+
class: "schematex-timing-bus-label",
|
|
135
|
+
"text-anchor": "middle"
|
|
136
|
+
},
|
|
137
|
+
label
|
|
138
|
+
)
|
|
139
|
+
);
|
|
140
|
+
}
|
|
141
|
+
dataIdx++;
|
|
142
|
+
busIndex++;
|
|
143
|
+
};
|
|
144
|
+
for (let i = 0; i < wave.length; i++) {
|
|
145
|
+
const ch = wave[i];
|
|
146
|
+
const x = i * pw;
|
|
147
|
+
const xNext = x + pw;
|
|
148
|
+
const effective = ch === "." ? prevChar : ch;
|
|
149
|
+
switch (effective) {
|
|
150
|
+
case "0":
|
|
151
|
+
case "l":
|
|
152
|
+
case "L": {
|
|
153
|
+
if (prev === "bus") closeBus(x);
|
|
154
|
+
if (prev === "x" || prev === "z" || prev === "none" || prev === "bus") {
|
|
155
|
+
flushLine();
|
|
156
|
+
startLine(x, yLo);
|
|
157
|
+
} else if (prev === "hi") {
|
|
158
|
+
extendLineTo(x, yLo);
|
|
159
|
+
}
|
|
160
|
+
extendLineTo(xNext, yLo);
|
|
161
|
+
prev = "lo";
|
|
162
|
+
break;
|
|
163
|
+
}
|
|
164
|
+
case "1":
|
|
165
|
+
case "h":
|
|
166
|
+
case "H": {
|
|
167
|
+
if (prev === "bus") closeBus(x);
|
|
168
|
+
if (prev === "x" || prev === "z" || prev === "none" || prev === "bus") {
|
|
169
|
+
flushLine();
|
|
170
|
+
startLine(x, yHi);
|
|
171
|
+
} else if (prev === "lo") {
|
|
172
|
+
extendLineTo(x, yHi);
|
|
173
|
+
}
|
|
174
|
+
extendLineTo(xNext, yHi);
|
|
175
|
+
prev = "hi";
|
|
176
|
+
break;
|
|
177
|
+
}
|
|
178
|
+
case "p":
|
|
179
|
+
case "P": {
|
|
180
|
+
if (prev === "bus") closeBus(x);
|
|
181
|
+
flushLine();
|
|
182
|
+
startLine(x, yLo);
|
|
183
|
+
extendLineTo(x, yHi);
|
|
184
|
+
extendLineTo(x + pw / 2, yHi);
|
|
185
|
+
extendLineTo(x + pw / 2, yLo);
|
|
186
|
+
extendLineTo(xNext, yLo);
|
|
187
|
+
flushLine();
|
|
188
|
+
prev = "lo";
|
|
189
|
+
break;
|
|
190
|
+
}
|
|
191
|
+
case "n":
|
|
192
|
+
case "N": {
|
|
193
|
+
if (prev === "bus") closeBus(x);
|
|
194
|
+
flushLine();
|
|
195
|
+
startLine(x, yHi);
|
|
196
|
+
extendLineTo(x, yLo);
|
|
197
|
+
extendLineTo(x + pw / 2, yLo);
|
|
198
|
+
extendLineTo(x + pw / 2, yHi);
|
|
199
|
+
extendLineTo(xNext, yHi);
|
|
200
|
+
flushLine();
|
|
201
|
+
prev = "hi";
|
|
202
|
+
break;
|
|
203
|
+
}
|
|
204
|
+
case "u": {
|
|
205
|
+
if (prev === "bus") closeBus(x);
|
|
206
|
+
flushLine();
|
|
207
|
+
startLine(x, yLo);
|
|
208
|
+
extendLineTo(xNext, yHi);
|
|
209
|
+
prev = "hi";
|
|
210
|
+
break;
|
|
211
|
+
}
|
|
212
|
+
case "d": {
|
|
213
|
+
if (prev === "bus") closeBus(x);
|
|
214
|
+
flushLine();
|
|
215
|
+
startLine(x, yHi);
|
|
216
|
+
extendLineTo(xNext, yLo);
|
|
217
|
+
prev = "lo";
|
|
218
|
+
break;
|
|
219
|
+
}
|
|
220
|
+
case "z": {
|
|
221
|
+
if (prev === "bus") closeBus(x);
|
|
222
|
+
flushLine();
|
|
223
|
+
zLines.push(
|
|
224
|
+
el("line", {
|
|
225
|
+
x1: x,
|
|
226
|
+
y1: yMid,
|
|
227
|
+
x2: xNext,
|
|
228
|
+
y2: yMid,
|
|
229
|
+
class: "schematex-timing-hiz"
|
|
230
|
+
})
|
|
231
|
+
);
|
|
232
|
+
prev = "z";
|
|
233
|
+
break;
|
|
234
|
+
}
|
|
235
|
+
case "x": {
|
|
236
|
+
if (prev === "bus") closeBus(x);
|
|
237
|
+
flushLine();
|
|
238
|
+
xPatchRects.push(
|
|
239
|
+
el("rect", {
|
|
240
|
+
x,
|
|
241
|
+
y: yHi,
|
|
242
|
+
width: pw,
|
|
243
|
+
height: yLo - yHi,
|
|
244
|
+
class: "schematex-timing-unknown",
|
|
245
|
+
fill: "url(#schematex-timing-xhatch)"
|
|
246
|
+
})
|
|
247
|
+
);
|
|
248
|
+
prev = "x";
|
|
249
|
+
break;
|
|
250
|
+
}
|
|
251
|
+
case "=":
|
|
252
|
+
case "2":
|
|
253
|
+
case "3":
|
|
254
|
+
case "4":
|
|
255
|
+
case "5":
|
|
256
|
+
case "6":
|
|
257
|
+
case "7":
|
|
258
|
+
case "8":
|
|
259
|
+
case "9": {
|
|
260
|
+
const isContinuation = ch === ".";
|
|
261
|
+
if (!isContinuation && prev === "bus") closeBus(x);
|
|
262
|
+
if (prev !== "bus" || !isContinuation) {
|
|
263
|
+
flushLine();
|
|
264
|
+
busStartX = x;
|
|
265
|
+
}
|
|
266
|
+
prev = "bus";
|
|
267
|
+
break;
|
|
268
|
+
}
|
|
269
|
+
default: {
|
|
270
|
+
flushLine();
|
|
271
|
+
xPatchRects.push(
|
|
272
|
+
el("rect", {
|
|
273
|
+
x,
|
|
274
|
+
y: yHi,
|
|
275
|
+
width: pw,
|
|
276
|
+
height: yLo - yHi,
|
|
277
|
+
class: "schematex-timing-unknown",
|
|
278
|
+
fill: "url(#schematex-timing-xhatch)"
|
|
279
|
+
})
|
|
280
|
+
);
|
|
281
|
+
prev = "x";
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
prevChar = effective;
|
|
285
|
+
}
|
|
286
|
+
if (prev === "bus") closeBus(wave.length * pw);
|
|
287
|
+
flushLine();
|
|
288
|
+
const waveSvg = paths.map((d) => el("path", { class: "schematex-timing-wave", d })).concat(xPatchRects, zLines, busRects).join("");
|
|
289
|
+
return { svg: waveSvg, labels: busTexts.join("") };
|
|
290
|
+
}
|
|
291
|
+
function renderTiming(ast) {
|
|
292
|
+
const pw = DEFAULT_PW * (ast.hscale ?? 1);
|
|
293
|
+
const rows = flatten(ast.signals);
|
|
294
|
+
const maxWaveLen = Math.max(
|
|
295
|
+
1,
|
|
296
|
+
...rows.filter((r) => r.kind === "signal").map((r) => r.signal.wave.length)
|
|
297
|
+
);
|
|
298
|
+
const waveAreaW = maxWaveLen * pw;
|
|
299
|
+
const width = NAME_W + waveAreaW + 20;
|
|
300
|
+
let y = PAD_TOP;
|
|
301
|
+
const rowYs = [];
|
|
302
|
+
for (const r of rows) {
|
|
303
|
+
rowYs.push(y);
|
|
304
|
+
y += r.kind === "group" ? GROUP_LABEL_H : SIG_H;
|
|
305
|
+
}
|
|
306
|
+
const height = y + PAD_BOT + 10;
|
|
307
|
+
const waveSvgs = [];
|
|
308
|
+
const labelSvgs = [];
|
|
309
|
+
const nameSvgs = [];
|
|
310
|
+
const gridLines = [];
|
|
311
|
+
for (let i = 0; i <= maxWaveLen; i++) {
|
|
312
|
+
const xg = NAME_W + i * pw;
|
|
313
|
+
gridLines.push(
|
|
314
|
+
el("line", {
|
|
315
|
+
x1: xg,
|
|
316
|
+
y1: PAD_TOP,
|
|
317
|
+
x2: xg,
|
|
318
|
+
y2: height - PAD_BOT,
|
|
319
|
+
class: "schematex-timing-grid"
|
|
320
|
+
})
|
|
321
|
+
);
|
|
322
|
+
}
|
|
323
|
+
for (let i = 0; i < rows.length; i++) {
|
|
324
|
+
const row = rows[i];
|
|
325
|
+
const ry = rowYs[i];
|
|
326
|
+
if (row.kind === "group") {
|
|
327
|
+
nameSvgs.push(
|
|
328
|
+
text(
|
|
329
|
+
{
|
|
330
|
+
x: 6 + row.indent * 10,
|
|
331
|
+
y: ry + GROUP_LABEL_H - 6,
|
|
332
|
+
class: "schematex-timing-group-label"
|
|
333
|
+
},
|
|
334
|
+
row.label
|
|
335
|
+
)
|
|
336
|
+
);
|
|
337
|
+
continue;
|
|
338
|
+
}
|
|
339
|
+
const signal = row.signal;
|
|
340
|
+
const yHi = ry + PAD_V;
|
|
341
|
+
const yLo = ry + SIG_H - PAD_V;
|
|
342
|
+
const yMid = ry + SIG_H / 2;
|
|
343
|
+
const activeLow = signal.name.startsWith("~") || signal.name.startsWith("/");
|
|
344
|
+
const displayName = activeLow ? signal.name.slice(1) : signal.name;
|
|
345
|
+
nameSvgs.push(
|
|
346
|
+
text(
|
|
347
|
+
{
|
|
348
|
+
x: NAME_W - 8,
|
|
349
|
+
y: yMid + 4,
|
|
350
|
+
class: activeLow ? "schematex-timing-name schematex-timing-name-activelow" : "schematex-timing-name",
|
|
351
|
+
"text-anchor": "end"
|
|
352
|
+
},
|
|
353
|
+
displayName
|
|
354
|
+
)
|
|
355
|
+
);
|
|
356
|
+
const { svg, labels } = renderWave(signal, {
|
|
357
|
+
pw,
|
|
358
|
+
yHi,
|
|
359
|
+
yLo,
|
|
360
|
+
yMid});
|
|
361
|
+
waveSvgs.push(
|
|
362
|
+
group(
|
|
363
|
+
{
|
|
364
|
+
transform: `translate(${NAME_W}, 0)`,
|
|
365
|
+
"data-signal": signal.name
|
|
366
|
+
},
|
|
367
|
+
[svg]
|
|
368
|
+
)
|
|
369
|
+
);
|
|
370
|
+
labelSvgs.push(
|
|
371
|
+
group({ transform: `translate(${NAME_W}, 0)` }, [labels])
|
|
372
|
+
);
|
|
373
|
+
}
|
|
374
|
+
const xhatch = el(
|
|
375
|
+
"pattern",
|
|
376
|
+
{
|
|
377
|
+
id: "schematex-timing-xhatch",
|
|
378
|
+
patternUnits: "userSpaceOnUse",
|
|
379
|
+
width: 6,
|
|
380
|
+
height: 6
|
|
381
|
+
},
|
|
382
|
+
[
|
|
383
|
+
el("rect", { x: 0, y: 0, width: 6, height: 6, fill: "#f5f5f5" }),
|
|
384
|
+
el("path", {
|
|
385
|
+
d: "M 0,6 L 6,0 M -1,1 L 1,-1 M 5,7 L 7,5",
|
|
386
|
+
stroke: "#999",
|
|
387
|
+
"stroke-width": 0.8
|
|
388
|
+
})
|
|
389
|
+
]
|
|
390
|
+
);
|
|
391
|
+
const css = `
|
|
392
|
+
.schematex-timing { background: #fff; font-family: system-ui, -apple-system, sans-serif; }
|
|
393
|
+
.schematex-timing-name { font: 12px monospace; fill: #111; }
|
|
394
|
+
.schematex-timing-name-activelow { text-decoration: overline; }
|
|
395
|
+
.schematex-timing-group-label { font: bold 12px sans-serif; fill: #111; }
|
|
396
|
+
.schematex-timing-wave { stroke: #111; stroke-width: 1.75; fill: none; stroke-linejoin: miter; stroke-linecap: square; }
|
|
397
|
+
.schematex-timing-bus { fill: none; stroke: #111; stroke-width: 1.5; }
|
|
398
|
+
.schematex-timing-bus-label { font: 11px monospace; fill: #111; }
|
|
399
|
+
.schematex-timing-unknown { stroke: #555; stroke-width: 0.5; }
|
|
400
|
+
.schematex-timing-hiz { stroke: #555; stroke-width: 1.5; stroke-dasharray: 4 3; }
|
|
401
|
+
.schematex-timing-grid { stroke: #eee; stroke-width: 0.5; }
|
|
402
|
+
`.trim();
|
|
403
|
+
return svgRoot(
|
|
404
|
+
{
|
|
405
|
+
class: "schematex-timing",
|
|
406
|
+
viewBox: `0 0 ${width} ${height}`,
|
|
407
|
+
width,
|
|
408
|
+
height,
|
|
409
|
+
role: "img",
|
|
410
|
+
"data-diagram-type": "timing"
|
|
411
|
+
},
|
|
412
|
+
[
|
|
413
|
+
title(ast.title ?? "Timing Diagram"),
|
|
414
|
+
desc(`Digital timing diagram with ${rows.filter((r) => r.kind === "signal").length} signals`),
|
|
415
|
+
defs([xhatch, el("style", {}, css)]),
|
|
416
|
+
group({ class: "schematex-timing-grid-g" }, gridLines),
|
|
417
|
+
group({ class: "schematex-timing-waves" }, waveSvgs),
|
|
418
|
+
group({ class: "schematex-timing-labels" }, labelSvgs),
|
|
419
|
+
group({ class: "schematex-timing-names" }, nameSvgs),
|
|
420
|
+
ast.title ? text(
|
|
421
|
+
{
|
|
422
|
+
x: width / 2,
|
|
423
|
+
y: 14,
|
|
424
|
+
"text-anchor": "middle",
|
|
425
|
+
class: "schematex-timing-title",
|
|
426
|
+
style: "font: bold 13px sans-serif; fill: #333;"
|
|
427
|
+
},
|
|
428
|
+
ast.title
|
|
429
|
+
) : ""
|
|
430
|
+
]
|
|
431
|
+
);
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
// src/diagrams/timing/index.ts
|
|
435
|
+
var timing = {
|
|
436
|
+
type: "timing",
|
|
437
|
+
detect(text2) {
|
|
438
|
+
const first = text2.trim().split("\n")[0]?.trim().toLowerCase() ?? "";
|
|
439
|
+
return first.startsWith("timing");
|
|
440
|
+
},
|
|
441
|
+
render(text2) {
|
|
442
|
+
const ast = parseTiming(text2);
|
|
443
|
+
return renderTiming(ast);
|
|
444
|
+
}
|
|
445
|
+
};
|
|
446
|
+
|
|
447
|
+
export { parseTiming, renderTiming, timing };
|
|
448
|
+
//# sourceMappingURL=chunk-FDLZEKEB.js.map
|
|
449
|
+
//# sourceMappingURL=chunk-FDLZEKEB.js.map
|