-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
-
37
-
38
-
39
-
40
-
41
-
42
-
43
-
44
-
45
import type * as figma from "../figma.js";
/**
* Measure bounding box for nodes.
*/
export class BoundingBoxMeasurement {
#minX = Infinity;
#maxX = -Infinity;
#minY = Infinity;
#maxY = -Infinity;
/**
* Add a node to the measurement.
*/
addNode(node: figma.Node & figma.HasBoundingBox): void {
if (node.visible === false) {
return;
}
const box = node.absoluteRenderBounds || node.absoluteBoundingBox;
this.#minX = Math.min(this.#minX, box.x);
this.#maxX = Math.max(this.#maxX, box.x + box.width);
this.#minY = Math.min(this.#minY, box.y);
this.#maxY = Math.max(this.#maxY, box.y + box.height);
}
/**
* Returns a bounding box for added nodes.
*/
measure(): figma.Rectangle {
return {
x: Number.isFinite(this.#minX) ? this.#minX : NaN,
y: Number.isFinite(this.#minY) ? this.#minY : NaN,
width:
Number.isFinite(this.#maxX) && Number.isFinite(this.#minX)
? this.#maxX - this.#minX
: NaN,
height:
Number.isFinite(this.#maxY) && Number.isFinite(this.#minY)
? this.#maxY - this.#minY
: NaN,
};
}
}