@tscircuit/core 0.0.330 → 0.0.331
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/dist/index.d.ts +2 -1
- package/dist/index.js +31 -0
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -5,7 +5,7 @@ export { createElement } from 'react';
|
|
|
5
5
|
import * as zod from 'zod';
|
|
6
6
|
import { z, ZodType } from 'zod';
|
|
7
7
|
import { symbols, SchSymbol, BaseSymbolName } from 'schematic-symbols';
|
|
8
|
-
import { PcbTraceError, PcbPlacementError, PcbManualEditConflictError, LayerRef, AnyCircuitElement, AnySourceComponent, PcbTrace, RouteHintPoint, CircuitJson } from 'circuit-json';
|
|
8
|
+
import { PcbTraceError, PcbPlacementError, PcbManualEditConflictError, LayerRef, AnyCircuitElement, AnySourceComponent, PcbTraceRoutePoint, PcbTrace, RouteHintPoint, CircuitJson } from 'circuit-json';
|
|
9
9
|
import { Matrix } from 'transformation-matrix';
|
|
10
10
|
import { SoupUtilObjects } from '@tscircuit/soup-util';
|
|
11
11
|
import * as _tscircuit_layout from '@tscircuit/layout';
|
|
@@ -662,6 +662,7 @@ declare class Trace extends PrimitiveComponent<typeof traceProps> implements Tra
|
|
|
662
662
|
_isExplicitlyConnectedToNet(net: Net): boolean;
|
|
663
663
|
doInitialCreateNetsFromProps(): void;
|
|
664
664
|
doInitialSourceTraceRender(): void;
|
|
665
|
+
_insertErrorIfTraceIsOutsideBoard(mergedRoute: PcbTraceRoutePoint[], ports: Port[]): void;
|
|
665
666
|
doInitialPcbTraceRender(): void;
|
|
666
667
|
_doInitialSchematicTraceRenderWithDisplayLabel(): void;
|
|
667
668
|
private _isSymbolToChipConnection;
|
package/dist/index.js
CHANGED
|
@@ -3634,6 +3634,22 @@ var pushEdgesOfSchematicTraceToPreventOverlap = ({
|
|
|
3634
3634
|
}
|
|
3635
3635
|
};
|
|
3636
3636
|
|
|
3637
|
+
// lib/utils/is-route-outside-board.ts
|
|
3638
|
+
var isRouteOutsideBoard = (mergedRoute, { db }) => {
|
|
3639
|
+
const pcbBoard = db.pcb_board.list()[0];
|
|
3640
|
+
if (pcbBoard.outline) {
|
|
3641
|
+
return true;
|
|
3642
|
+
}
|
|
3643
|
+
const boardWidth = pcbBoard.width;
|
|
3644
|
+
const boardHeight = pcbBoard.height;
|
|
3645
|
+
const boardCenterX = pcbBoard.center.x;
|
|
3646
|
+
const boardCenterY = pcbBoard.center.y;
|
|
3647
|
+
const outsideBoard = mergedRoute.some((point) => {
|
|
3648
|
+
return point.x < boardCenterX - boardWidth / 2 || point.y < boardCenterY - boardHeight / 2 || point.x > boardCenterX + boardWidth / 2 || point.y > boardCenterY + boardHeight / 2;
|
|
3649
|
+
});
|
|
3650
|
+
return outsideBoard;
|
|
3651
|
+
};
|
|
3652
|
+
|
|
3637
3653
|
// lib/components/primitive-components/Trace/Trace.ts
|
|
3638
3654
|
var portToObjective = (port) => {
|
|
3639
3655
|
const portPosition = port._getGlobalPcbPositionAfterLayout();
|
|
@@ -3790,6 +3806,20 @@ searched component ${targetComponent.getString()}, which has ports: ${targetComp
|
|
|
3790
3806
|
});
|
|
3791
3807
|
this.source_trace_id = trace.source_trace_id;
|
|
3792
3808
|
}
|
|
3809
|
+
_insertErrorIfTraceIsOutsideBoard(mergedRoute, ports) {
|
|
3810
|
+
const { db } = this.root;
|
|
3811
|
+
const isOutsideBoard = isRouteOutsideBoard(mergedRoute, { db });
|
|
3812
|
+
if (isOutsideBoard) {
|
|
3813
|
+
db.pcb_trace_error.insert({
|
|
3814
|
+
error_type: "pcb_trace_error",
|
|
3815
|
+
source_trace_id: this.source_trace_id,
|
|
3816
|
+
message: `Trace ${this.getString()} routed outside the board boundaries.`,
|
|
3817
|
+
pcb_trace_id: this.pcb_trace_id,
|
|
3818
|
+
pcb_component_ids: [],
|
|
3819
|
+
pcb_port_ids: ports.map((p) => p.pcb_port_id)
|
|
3820
|
+
});
|
|
3821
|
+
}
|
|
3822
|
+
}
|
|
3793
3823
|
doInitialPcbTraceRender() {
|
|
3794
3824
|
if (this.root?.pcbDisabled) return;
|
|
3795
3825
|
const { db } = this.root;
|
|
@@ -4061,6 +4091,7 @@ searched component ${targetComponent.getString()}, which has ports: ${targetComp
|
|
|
4061
4091
|
});
|
|
4062
4092
|
}
|
|
4063
4093
|
}
|
|
4094
|
+
this._insertErrorIfTraceIsOutsideBoard(mergedRoute, ports);
|
|
4064
4095
|
}
|
|
4065
4096
|
_doInitialSchematicTraceRenderWithDisplayLabel() {
|
|
4066
4097
|
if (this.root?.schematicDisabled) return;
|