Add simple tree graph mode #4

Merged
pierre merged 16 commits from simple_tree into master 2023-08-26 14:00:00 +00:00
2 changed files with 32 additions and 9 deletions
Showing only changes of commit 1c15fd17db - Show all commits

View File

@ -26,6 +26,5 @@ export function getTextWidth(text: string, font: string) {
if (!ref.has(c)) ref.set(c, computeTextWidth(c, font)); if (!ref.has(c)) ref.set(c, computeTextWidth(c, font));
size += ref.get(c)!; size += ref.get(c)!;
} }
console.log(text, size);
return size; return size;
} }

View File

@ -48,7 +48,7 @@ function buildSimpleDownTreeNode(
): SimpleTreeNode { ): SimpleTreeNode {
if (depth === 0) throw new Error("Too much recursion reached!"); if (depth === 0) throw new Error("Too much recursion reached!");
const lastCouple = tree.couples?.[tree.couples?.length ?? 0]; const lastCouple = tree.couples?.[tree.couples?.length - 1 ?? 0];
// Preprocess children // Preprocess children
let childrenToProcess = tree.down; let childrenToProcess = tree.down;
@ -137,9 +137,11 @@ export function SimpleFamilyTree(p: {
function NodeArea(p: { function NodeArea(p: {
x: number; x: number;
y: number; y: number;
parentLinkDestX?: number;
parentLinkDestY?: number;
node: SimpleTreeNode; node: SimpleTreeNode;
}): React.ReactElement { }): React.ReactElement {
const couple_x_offset = const parent_x_offset =
p.x + p.x +
Math.floor( Math.floor(
(p.node.width - (p.node.width -
@ -152,16 +154,38 @@ function NodeArea(p: {
let downXOffset = p.x; let downXOffset = p.x;
let endFirstFaceX =
parent_x_offset +
Math.floor((memberCardWidth(p.node.member) - FACE_WIDTH) / 2) +
FACE_WIDTH;
let beginingOfSecondCardX =
parent_x_offset + memberCardWidth(p.node.member) + SPOUSE_SPACING;
let middleParentFaceY = p.y + Math.floor(FACE_HEIGHT / 2);
return ( return (
<> <>
<MemberCard x={couple_x_offset} y={p.y} member={p.node.member} /> <MemberCard x={parent_x_offset} y={p.y} member={p.node.member} />
{p.node.spouse && ( {p.node.spouse && (
<>
{/* Couple link */}
<path
className="link"
fill="none"
stroke="#000"
d={`M${endFirstFaceX} ${middleParentFaceY} H ${
beginingOfSecondCardX + memberCardWidth(p.node.spouse.member) / 2
}`}
></path>
<MemberCard <MemberCard
x={couple_x_offset + memberCardWidth(p.node.member) + SPOUSE_SPACING} x={beginingOfSecondCardX}
y={p.y} y={p.y}
member={p.node.spouse.member} member={p.node.spouse.member}
/> />
</>
)} )}
{p.node.down.map((n) => { {p.node.down.map((n) => {