@tscircuit/eval 0.0.806 → 0.0.807

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.
@@ -625,9 +625,9 @@ ${t52.width.toFixed(2)}x${t52.height.toFixed(2)}`,layer:`z${t52.availableZ.join(
625
625
  `),GC=t52=>Math.min(1,Math.max(0,t52)),qC=(t52,e5,n4)=>Math.round(t52+(e5-t52)*n4),JC=({r:t52,g:e5,b:n4,a:o4})=>`rgba(${t52}, ${e5}, ${n4}, ${o4})`,KC=(t52,e5)=>{let n4=t52.problem.routeMetadata?.[e5];return n4?.connectionId??n4?.mutuallyConnectedNetworkId??`route-${e5}`},QC=t52=>typeof t52.centerRouteId=="number",tT=(t52,e5)=>QC(t52)?e5===t52.centerRouteId?1:.5:1,eT=(t52,e5)=>{let n4=t52.match(/^(rgba|hsla)\((.*),\s*([0-9]*\.?[0-9]+)\)$/);if(!n4)return t52;let[,o4,i3,s3]=n4,r5=GC(Number(s3)*e5);return`${o4}(${i3}, ${Number(r5.toFixed(3))})`},nT=(t52,e5,n4=.8)=>((t53,e6,n5=.8)=>{let o4=`${t53.problem.routeNet[e6]}:${KC(t53,e6)}`,i3=0;for(let t54=0;t54<o4.length;t54++)i3=17777*o4.charCodeAt(t54)+((i3<<5)-i3);return`hsla(${Math.abs(i3)%360}, 70%, 50%, ${n5})`})(t52,e5,n4*tT(t52,e5)),oT=(t52,e5)=>`net: ${t52.problem.routeNet[e5]}`,iT=(t52,e5)=>{let n4=t52.topology.regionMetadata?.[e5],o4=n4?.polygon;if(Array.isArray(o4)&&o4.length>=3){let t53=o4.map(t54=>t54.x),e6=o4.map(t54=>t54.y);return{minX:Math.min(...t53),maxX:Math.max(...t53),minY:Math.min(...e6),maxY:Math.max(...e6)}}let i3=n4?.bounds;if(i3&&typeof i3.minX=="number"&&typeof i3.maxX=="number"&&typeof i3.minY=="number"&&typeof i3.maxY=="number")return i3;let s3=t52.topology.regionWidth[e5],r5=t52.topology.regionHeight[e5],a3=t52.topology.regionCenterX[e5],c4=t52.topology.regionCenterY[e5];return{minX:a3-s3/2,maxX:a3+s3/2,minY:c4-r5/2,maxY:c4+r5/2}},sT2=(t52,e5)=>({x:t52.topology.regionCenterX[e5],y:t52.topology.regionCenterY[e5]}),rT=(t52,e5)=>{let n4=t52.topology.regionMetadata?.[e5],o4=Array.isArray(n4?.availableZ)?n4.availableZ.filter(t53=>typeof t53=="number"&&Number.isInteger(t53)&&t53>=0):[];if(o4.length>0)return bC(o4)??"z0";let i3=xC(t52.topology.regionAvailableZMask?.[e5]??0);if(i3.length>0)return bC(i3)??"z0";let s3=[...new Set((t52.topology.regionIncidentPorts[e5]??[]).map(e6=>t52.topology.portZ[e6]))].sort((t53,e6)=>t53-e6);return bC(s3)??"z0"},aT=(t52,e5)=>{let n4=t52.state.regionIntersectionCaches[e5],o4=n4?.existingRegionCost??0,i3=t52.state.regionCongestionCost[e5]??0,s3=t52.problem.regionNetId[e5];return ZC(`region: region-${e5}`,`net: ${s3===-1?"free":`${s3}`}`,t52.getAdditionalRegionLabel(e5),`cost: ${o4.toFixed(3)}`,`congestion: ${i3.toFixed(3)}`,`same layer X: ${n4?.existingSameLayerIntersections??0}`,`trans X: ${n4?.existingCrossingLayerIntersections??0}`,`entry exit X: ${n4?.existingEntryExitLayerChanges??0}`)},cT2=(t52,e5)=>{let n4=t52.topology.regionMetadata?.[e5];return n4?.isConnectionRegion?{r:255,g:100,b:255,a:.6}:n4?.isThroughJumper?{r:100,g:200,b:100,a:.5}:n4?.isPad?{r:255,g:200,b:100,a:.5}:n4?.layer==="bottom"?{r:52,g:152,b:219,a:.08}:{r:200,g:200,b:255,a:.1}},lT=(t52,e5)=>{let n4=cT2(t52,e5),o4=GC(t52.state.regionIntersectionCaches[e5]?.existingRegionCost??0),i3=Math.pow(o4,.8);return JC((r5=HC,a3=i3,{r:qC((s3=n4).r,r5.r,a3),g:qC(s3.g,r5.g,a3),b:qC(s3.b,r5.b,a3),a:Number((s3.a+(r5.a-s3.a)*a3).toFixed(3))}));var s3,r5,a3},hT=(t52,e5)=>{let n4=((t53,e6)=>({x:t53.topology.portX[e6],y:t53.topology.portY[e6]}))(t52,e5),o4=.005*t52.topology.portZ[e5];return{x:n4.x+o4,y:n4.y+o4}},dT=hT,uT=(t52,e5)=>bC([t52.topology.portZ[e5]])??"z0",pT2=(t52,e5)=>{let n4=t52.topology.portMetadata?.[e5];return`port: ${n4?.serializedPortId??n4?.portId??`port-${e5}`}`},mT=(t52,e5,n4)=>{if(n4!==void 0)return`net: ${t52.problem.routeNet[n4]}`;let o4=t52.state.portAssignment[e5];if(o4>=0)return`net: ${o4}`;let i3=new Set;for(let n5=0;n5<t52.problem.routeCount;n5++)t52.problem.routeStartPort[n5]!==e5&&t52.problem.routeEndPort[n5]!==e5||i3.add(t52.problem.routeNet[n5]);return i3.size!==0?`net: ${Array.from(i3).sort((t53,e6)=>t53-e6).join(", ")}`:void 0},gT=(t52,e5)=>`z: ${t52.topology.portZ[e5]}`,fT=(t52,e5,n4)=>{let o4=t52.topology.portZ[e5],i3=t52.topology.portZ[n4];return o4===i3?`z: ${o4}`:`z: ${o4} -> ${i3}`},_T2=(t52,e5)=>fT(t52,t52.problem.routeStartPort[e5],t52.problem.routeEndPort[e5]),yT=(t52,e5,n4)=>ZC(pT2(t52,e5),((t53,e6)=>{let n5=t53.topology.incidentPortRegion[e6]?.[0],o4=t53.topology.incidentPortRegion[e6]?.[1];return`connects: region-${n5??"?"} <-> region-${o4??"?"}`})(t52,e5),mT(t52,e5,n4)),bT=(t52,e5,n4,o4)=>{let i3=t52.topology.portZ[n4];return i3!==t52.topology.portZ[o4]?{strokeColor:eT("rgba(22, 160, 133, 0.95)",tT(t52,e5)),strokeDash:"2 4 2"}:i3>0?{strokeColor:eT("rgba(52, 152, 219, 0.95)",tT(t52,e5)),strokeDash:"3 2"}:{strokeColor:nT(t52,e5)}},xT=(t52,e5)=>{for(let n4=0;n4<t52.problem.routeCount;n4++)if(t52.problem.routeStartPort[n4]===e5||t52.problem.routeEndPort[n4]===e5)return!0;return!1},vT=(t52,e5,n4)=>{let o4=((t53,e6)=>{let n5=new Set;for(let o6=0;o6<e6.length;o6++)if(e6[o6]===1)for(let e7 of t53.topology.incidentPortRegion[o6]??[])n5.add(e7);return n5})(t52,n4),i3="rgba(245, 158, 11, 0.95)",s3="rgba(245, 158, 11, 0.08)";for(let n5 of o4){let o6=t52.topology.regionMetadata?.[n5],r5=o6?.polygon,a3=iT(t52,n5),c4=sT2(t52,n5),l4=a3.maxX-a3.minX,h6=a3.maxY-a3.minY,d4=rT(t52,n5),u5=ZC("section region",aT(t52,n5));Array.isArray(r5)&&r5.length>=3?e5.polygons.push({points:r5,fill:s3,stroke:i3,strokeWidth:2,layer:d4,label:u5}):e5.rects.push({center:c4,width:Math.max(l4-XC,.05),height:Math.max(h6-XC,.05),fill:s3,stroke:i3,layer:d4,label:u5})}for(let o6=0;o6<n4.length;o6++)n4[o6]===1&&e5.circles.push({center:dT(t52,o6),radius:.07,fill:"rgba(251, 191, 36, 0.18)",stroke:i3,layer:uT(t52,o6),label:ZC(yT(t52,o6),gT(t52,o6),"section port")})},ST=(t52,e5={})=>{let n4={arrows:[],circles:[],infiniteLines:[],lines:[],points:[],polygons:[],rects:[],texts:[],title:"Tiny HyperGraph",coordinateSystem:"cartesian"},o4=((t53,e6)=>{if(!e6?.highlightSectionMask)return;let n5=e6.sectionPortMask??t53.problem.portSectionMask;if(n5.length!==t53.topology.portCount)return;let o6=0,i4=0;for(let t54=0;t54<n5.length;t54++)n5[t54]===1?o6+=1:i4+=1;return o6!==0&&i4!==0?n5:void 0})(t52,e5);for(let e6=0;e6<t52.topology.regionCount;e6++){let o6=t52.topology.regionMetadata?.[e6],i4=o6?.polygon,s4=iT(t52,e6),r5=sT2(t52,e6),a3=s4.maxX-s4.minX,c4=s4.maxY-s4.minY,l4=rT(t52,e6),h6=JC(cT2(t52,e6));Array.isArray(i4)&&i4.length>=3?n4.polygons.push({points:i4,fill:h6,layer:l4}):n4.rects.push({center:r5,width:Math.max(a3-XC,.05),height:Math.max(c4-XC,.05),fill:lT(t52,e6),layer:l4,label:aT(t52,e6)})}if(((t53,e6)=>{for(let n5=0;n5<t53.problem.routeCount;n5++){let o6=t53.problem.routeStartPort[n5],i4=t53.problem.routeEndPort[n5],s4=hT(t53,o6),r5=hT(t53,i4),a3=nT(t53,n5),c4=KC(t53,n5),l4=oT(t53,n5);e6.points.push({x:s4.x,y:s4.y,color:a3,layer:uT(t53,o6),label:ZC(`route: ${c4}`,l4,"endpoint: start",pT2(t53,o6),gT(t53,o6))}),e6.points.push({x:r5.x,y:r5.y,color:a3,layer:uT(t53,i4),label:ZC(`route: ${c4}`,l4,"endpoint: end",pT2(t53,i4),gT(t53,i4))})}})(t52,n4),t52.iterations===0){for(let t53 of n4.polygons)t53.stroke="rgba(128, 128, 128, 0.5)";for(let t53 of n4.rects)t53.stroke="rgba(128, 128, 128, 0.5)"}if(t52.iterations===0){for(let i4=0;i4<t52.topology.portCount;i4++){let s4=o4?.[i4]===1;e5.showOnlySectionPortsOnIdle&&!s4||n4.circles.push({center:dT(t52,i4),radius:.05,fill:t52.topology.portZ[i4]>0?"rgba(52, 152, 219, 0.55)":"rgba(128, 128, 128, 0.5)",layer:uT(t52,i4),label:ZC(yT(t52,i4),gT(t52,i4))})}e5.showInitialRouteHints!==!1&&((t53,e6)=>{for(let n5=0;n5<t53.problem.routeCount;n5++){let o6=t53.problem.routeStartPort[n5],i4=t53.problem.routeEndPort[n5],s4=hT(t53,o6),r5=hT(t53,i4),a3={x:(s4.x+r5.x)/2,y:(s4.y+r5.y)/2};e6.lines.push({points:[s4,r5],strokeColor:nT(t53,n5),strokeDash:"3 3",label:ZC(KC(t53,n5),_T2(t53,n5))}),e6.points.push({x:a3.x,y:a3.y,color:nT(t53,n5,1),label:ZC(KC(t53,n5),_T2(t53,n5))})}})(t52,n4)}else((t53,e6)=>{for(let n5=0;n5<t53.state.regionSegments.length;n5++){let o6=t53.state.regionSegments[n5]??[];for(let[i4,s4,r5]of o6)e6.lines.push({points:[hT(t53,s4),hT(t53,r5)],label:ZC(`route: ${KC(t53,i4)}`,`region: region-${n5}`,fT(t53,s4,r5)),...bT(t53,i4,s4,r5)})}})(t52,n4),((t53,e6)=>{let n5=new Set;for(let o6=0;o6<t53.state.regionSegments.length;o6++){let i4=t53.state.regionSegments[o6]??[];for(let[o7,s4,r5]of i4)for(let i5 of[s4,r5]){let s5=`${o7}:${i5}`;if(n5.has(s5))continue;n5.add(s5);let r6=hT(t53,i5);e6.points.push({x:r6.x,y:r6.y,color:nT(t53,o7,1),layer:uT(t53,i5),label:ZC(`route: ${KC(t53,o7)}`,pT2(t53,i5),mT(t53,i5,o7),gT(t53,i5))})}}})(t52,n4),(t53=>QC(t53)&&t53.showUnassignedPortsInVisualization===!0)(t52)&&((t53,e6)=>{for(let n5=0;n5<t53.topology.portCount;n5++)t53.state.portAssignment[n5]>=0||xT(t53,n5)||e6.circles.push({center:dT(t53,n5),radius:.04,fill:t53.topology.portZ[n5]>0?"rgba(52, 152, 219, 0.2)":"rgba(128, 128, 128, 0.2)",stroke:t53.topology.portZ[n5]>0?"rgba(52, 152, 219, 0.6)":"rgba(128, 128, 128, 0.6)",layer:uT(t53,n5),label:ZC(yT(t53,n5),gT(t53,n5),"state: unassigned")})})(t52,n4),QC(t52)||(((t53,e6)=>{let n5=t53.state.currentRouteId;if(n5===void 0||t53.solved)return;let o6=t53.problem.routeStartPort[n5],i4=t53.problem.routeEndPort[n5],s4=hT(t53,o6),r5=hT(t53,i4),a3=nT(t53,n5),c4=KC(t53,n5);e6.lines.push({points:[s4,r5],strokeColor:a3,strokeDash:"10 5",label:ZC(c4,_T2(t53,n5))})})(t52,n4),((t53,e6)=>{if(t53.solved)return;let n5=t53.state.currentRouteId,o6=t53.state.candidateQueue.toArray().sort((t54,e7)=>t54.f-e7.f).slice(0,10);for(let i5=0;i5<o6.length;i5++){let s5=o6[i5],r6=hT(t53,s5.portId),a3=i5===0;e6.points.push({x:r6.x,y:r6.y,color:a3?"green":"rgba(128, 128, 128, 0.25)",layer:uT(t53,s5.portId),label:ZC(yT(t53,s5.portId,n5),gT(t53,s5.portId),`g: ${s5.g.toFixed(2)}`,`h: ${s5.h.toFixed(2)}`,`f: ${s5.f.toFixed(2)}`)})}let i4=o6[0];if(!i4)return;let s4=[],r5=i4;for(;r5;)s4.unshift(hT(t53,r5.portId)),r5=r5.prevCandidate;s4.length>1&&e6.lines.push({points:s4,strokeColor:n5!==void 0?nT(t53,n5):"rgba(0, 160, 120, 0.9)"})})(t52,n4));o4&&vT(t52,n4,o4),((t53,e6)=>{if(t53.failed)for(let n5 of t53.getNeverSuccessfullyRoutedRoutes()){let{routeId:o6,connectionId:i4,attempts:s4,startPortId:r5,endPortId:a3}=n5,c4=oT(t53,o6),l4=dT(t53,r5),h6=dT(t53,a3),d4=ZC(`never routed: ${i4}`,`attempts: ${s4}`,c4,n5.startRegionId?`startRegionId: ${n5.startRegionId}`:void 0,n5.endRegionId?`endRegionId: ${n5.endRegionId}`:void 0);e6.lines.push({points:[{x:0,y:0},{x:l4.x,y:l4.y}],strokeColor:WC,strokeDash:UC,layer:uT(t53,r5),label:ZC(d4,"origin guide","endpoint: start")}),e6.circles.push({center:l4,radius:1,fill:VC,stroke:WC,layer:uT(t53,r5),label:ZC(d4,"endpoint: start",pT2(t53,r5),gT(t53,r5))}),e6.lines.push({points:[{x:0,y:0},{x:h6.x,y:h6.y}],strokeColor:WC,strokeDash:UC,layer:uT(t53,a3),label:ZC(d4,"origin guide","endpoint: end")}),e6.circles.push({center:h6,radius:1,fill:VC,stroke:WC,layer:uT(t53,a3),label:ZC(d4,"endpoint: end",pT2(t53,a3),gT(t53,a3))})}})(t52,n4);let i3=t52.state.unroutedRoutes.length+(t52.state.currentRouteId===void 0?0:1),s3=o4?o4.reduce((t53,e6)=>t53+ +(e6===1),0):0;return n4.title=["Tiny HyperGraph",`iter=${t52.iterations}`,`pending=${i3}`,o4?`sectionPorts=${s3}`:void 0,t52.failed?"failed":t52.solved?"solved":"running"].filter(Boolean).join(" | "),n4},IT=()=>({netIds:new Int32Array(0),lesserAngles:new Int32Array(0),greaterAngles:new Int32Array(0),layerMasks:new Int32Array(0),existingCrossingLayerIntersections:0,existingSameLayerIntersections:0,existingEntryExitLayerChanges:0,existingRegionCost:0,existingSegmentCount:0}),PT=(t52,e5)=>{e5&&(e5.minViaPadDiameter!==void 0&&(t52.minViaPadDiameter=e5.minViaPadDiameter),e5.DISTANCE_TO_COST!==void 0&&(t52.DISTANCE_TO_COST=e5.DISTANCE_TO_COST),e5.RIP_THRESHOLD_START!==void 0&&(t52.RIP_THRESHOLD_START=e5.RIP_THRESHOLD_START),e5.RIP_THRESHOLD_END!==void 0&&(t52.RIP_THRESHOLD_END=e5.RIP_THRESHOLD_END),e5.RIP_THRESHOLD_RAMP_ATTEMPTS!==void 0&&(t52.RIP_THRESHOLD_RAMP_ATTEMPTS=e5.RIP_THRESHOLD_RAMP_ATTEMPTS),e5.RIP_CONGESTION_REGION_COST_FACTOR!==void 0&&(t52.RIP_CONGESTION_REGION_COST_FACTOR=e5.RIP_CONGESTION_REGION_COST_FACTOR),e5.MAX_ITERATIONS!==void 0&&(t52.MAX_ITERATIONS=e5.MAX_ITERATIONS),e5.VERBOSE!==void 0&&(t52.VERBOSE=e5.VERBOSE),e5.STATIC_REACHABILITY_PRECHECK!==void 0&&(t52.STATIC_REACHABILITY_PRECHECK=e5.STATIC_REACHABILITY_PRECHECK),e5.STATIC_REACHABILITY_PRECHECK_MAX_HOPS!==void 0&&(t52.STATIC_REACHABILITY_PRECHECK_MAX_HOPS=e5.STATIC_REACHABILITY_PRECHECK_MAX_HOPS))},MT=t52=>({minViaPadDiameter:t52.minViaPadDiameter,DISTANCE_TO_COST:t52.DISTANCE_TO_COST,RIP_THRESHOLD_START:t52.RIP_THRESHOLD_START,RIP_THRESHOLD_END:t52.RIP_THRESHOLD_END,RIP_THRESHOLD_RAMP_ATTEMPTS:t52.RIP_THRESHOLD_RAMP_ATTEMPTS,RIP_CONGESTION_REGION_COST_FACTOR:t52.RIP_CONGESTION_REGION_COST_FACTOR,MAX_ITERATIONS:t52.MAX_ITERATIONS,VERBOSE:t52.VERBOSE,STATIC_REACHABILITY_PRECHECK:t52.STATIC_REACHABILITY_PRECHECK,STATIC_REACHABILITY_PRECHECK_MAX_HOPS:t52.STATIC_REACHABILITY_PRECHECK_MAX_HOPS}),NT2=(t52,e5)=>t52.f-e5.f,CT=class extends Tt2{constructor(t52,e5,n4){super();__publicField(this,"topology");__publicField(this,"problem");__publicField(this,"state");__publicField(this,"_problemSetup");__publicField(this,"routeAttemptCountByRouteId");__publicField(this,"routeSuccessCountByRouteId");__publicField(this,"hasLoggedNeverSuccessfullyRoutedRoutes",!1);__publicField(this,"segmentGeometryScratch",{lesserAngle:0,greaterAngle:0,layerMask:0,entryExitLayerChanges:0});__publicField(this,"DISTANCE_TO_COST",.05);__publicField(this,"minViaPadDiameter",RC);__publicField(this,"RIP_THRESHOLD_START",.05);__publicField(this,"RIP_THRESHOLD_END",.8);__publicField(this,"RIP_THRESHOLD_RAMP_ATTEMPTS",50);__publicField(this,"RIP_CONGESTION_REGION_COST_FACTOR",.1);__publicField(this,"MAX_ITERATIONS",1e6);__publicField(this,"VERBOSE",!1);__publicField(this,"STATIC_REACHABILITY_PRECHECK",!0);__publicField(this,"STATIC_REACHABILITY_PRECHECK_MAX_HOPS",16);this.topology=t52,this.problem=e5,PT(this,n4),this.state={portAssignment:new Int32Array(t52.portCount).fill(-1),regionSegments:Array.from({length:t52.regionCount},()=>[]),regionIntersectionCaches:Array.from({length:t52.regionCount},()=>IT()),currentRouteId:void 0,currentRouteNetId:void 0,unroutedRoutes:YC2(e5.routeCount),candidateQueue:new LC([],NT2),candidateBestCostByHopId:new Float64Array(t52.portCount*t52.regionCount),candidateBestCostGenerationByHopId:new Uint32Array(t52.portCount*t52.regionCount),candidateBestCostGeneration:1,goalPortId:-1,ripCount:0,regionCongestionCost:new Float64Array(t52.regionCount).fill(0)},this.routeAttemptCountByRouteId=new Uint32Array(e5.routeCount),this.routeSuccessCountByRouteId=new Uint32Array(e5.routeCount)}get problemSetup(){return this._problemSetup||(this._problemSetup=this.computeProblemSetup()),this._problemSetup}computeProblemSetup(){let{topology:t52,problem:e5}=this,n4=t52.portX,o4=t52.portY,i3=new Float64Array(t52.portCount*e5.routeCount),s3=Array.from({length:t52.portCount},()=>new Set);for(let r5=0;r5<e5.routeCount;r5++){s3[e5.routeStartPort[r5]].add(e5.routeNet[r5]),s3[e5.routeEndPort[r5]].add(e5.routeNet[r5]);let a3=e5.routeEndPort[r5],c4=n4[a3],l4=o4[a3];for(let s4=0;s4<t52.portCount;s4++){let t53=n4[s4]-c4,a4=o4[s4]-l4;i3[s4*e5.routeCount+r5]=Math.hypot(t53,a4)*this.DISTANCE_TO_COST}}return{portHCostToEndOfRoute:i3,portEndpointNetIds:s3}}_setup(){if(this.problemSetup,this.STATIC_REACHABILITY_PRECHECK){let t52=BC({topology:this.topology,problem:this.problem,problemSetup:this.problemSetup,portAssignment:this.state.portAssignment,routeIds:this.state.unroutedRoutes,maxPrecheckHops:Math.max(0,this.STATIC_REACHABILITY_PRECHECK_MAX_HOPS),getStartingNextRegionId:(t53,e5)=>this.getStartingNextRegionId(t53,e5),getRouteSummary:t53=>this.getRouteSummary(t53)});t52.length>0&&(this.failed=!0,this.error=(t53=>{let e5=t53.slice(0,5).map(t54=>{let e6=t54.pointIds.length>=2?`${t54.pointIds[0]}->${t54.pointIds[1]}`:`${t54.startPortId}->${t54.endPortId}`;return`${t54.connectionId} (${e6})`}).join(", "),n4=t53.length-5;return["Static reachability precheck failed:",`${t53.length} route(s) have no legal path under the current reservation and start-region rules`,n4>0?`${e5}, +${n4} more`:e5].join(" ")})(t52),this.stats={...this.stats,staticallyUnroutableRouteCount:t52.length})}}_step(){let{problem:t52,topology:e5,state:n4}=this;if(n4.currentRouteId===void 0){if(n4.unroutedRoutes.length===0)return void this.onAllRoutesRouted();n4.currentRouteId=n4.unroutedRoutes.shift(),n4.currentRouteNetId=t52.routeNet[n4.currentRouteId],this.routeAttemptCountByRouteId[n4.currentRouteId]+=1,this.resetCandidateBestCosts();let e6=t52.routeStartPort[n4.currentRouteId];n4.candidateQueue.clear();let o6=this.getStartingNextRegionId(n4.currentRouteId,e6);if(o6===void 0)return this.failed=!0,void(this.error=`Start port ${e6} has no incident regions`);this.setCandidateBestCost(this.getHopId(e6,o6),0),n4.candidateQueue.queue({nextRegionId:o6,portId:e6,f:0,g:0,h:0}),n4.goalPortId=t52.routeEndPort[n4.currentRouteId]}let o4=n4.candidateQueue.dequeue();if(!o4)return void this.onOutOfCandidates();let i3=this.getHopId(o4.portId,o4.nextRegionId);if(o4.g>this.getCandidateBestCost(i3)||this.isRegionReservedForDifferentNet(o4.nextRegionId))return;let s3=e5.regionIncidentPorts[o4.nextRegionId];for(let i4 of s3){let s4=n4.portAssignment[i4];if(this.isPortReservedForDifferentNet(i4))continue;if(i4===n4.goalPortId){if(s4!==-1&&s4!==n4.currentRouteNetId)continue;return void this.onPathFound(o4)}if(s4!==-1&&s4!==n4.currentRouteNetId||i4===o4.portId||t52.portSectionMask[i4]===0)continue;let r5=this.computeG(o4,i4);if(!Number.isFinite(r5))continue;let a3=this.computeH(i4),c4=e5.incidentPortRegion[i4][0]===o4.nextRegionId?e5.incidentPortRegion[i4][1]:e5.incidentPortRegion[i4][0];if(c4===void 0||this.isRegionReservedForDifferentNet(c4))continue;let l4={prevRegionId:o4.nextRegionId,nextRegionId:c4,portId:i4,g:r5,h:a3,f:r5+a3,prevCandidate:o4};if(i4===n4.goalPortId)return void this.onPathFound(l4);let h6=this.getHopId(i4,c4);r5>=this.getCandidateBestCost(h6)||(this.setCandidateBestCost(h6,r5),n4.candidateQueue.queue(l4))}}resetCandidateBestCosts(){let{state:t52}=this;if(t52.candidateBestCostGeneration===4294967295)return t52.candidateBestCostGenerationByHopId.fill(0),void(t52.candidateBestCostGeneration=1);t52.candidateBestCostGeneration+=1}getCandidateBestCost(t52){let{state:e5}=this;return e5.candidateBestCostGenerationByHopId[t52]===e5.candidateBestCostGeneration?e5.candidateBestCostByHopId[t52]:Number.POSITIVE_INFINITY}setCandidateBestCost(t52,e5){let{state:n4}=this;n4.candidateBestCostGenerationByHopId[t52]=n4.candidateBestCostGeneration,n4.candidateBestCostByHopId[t52]=e5}getHopId(t52,e5){return t52*this.topology.regionCount+e5}getStartingNextRegionId(t52,e5){let n4=this.topology.incidentPortRegion[e5]??[],o4=this.problem.routeNet[t52];return n4.find(t53=>this.problem.regionNetId[t53]===-1)??n4.find(t53=>this.problem.regionNetId[t53]===o4)??n4[0]}isPortReservedForDifferentNet(t52){let e5=this.problemSetup.portEndpointNetIds[t52];if(!e5)return!1;for(let t53 of e5)if(t53!==this.state.currentRouteNetId)return!0;return!1}isRegionReservedForDifferentNet(t52){let e5=this.problem.regionNetId[t52];return e5!==-1&&e5!==this.state.currentRouteNetId}isKnownSingleLayerRegion(t52){let e5=this.topology.regionAvailableZMask?.[t52]??0;return EC(e5)}computeRegionCostForRegion(t52,e5,n4,o4,i3){return((t53,e6,n5,o6,i4,s3,r5=0,a3=.3)=>AC(t53*e6,n5,o6,i4,s3,r5,a3))(this.topology.regionWidth[t52],this.topology.regionHeight[t52],e5,n4,o4,i3,this.topology.regionAvailableZMask?.[t52]??0,this.minViaPadDiameter)}populateSegmentGeometryScratch(t52,e5,n4){let{topology:o4}=this,i3=this.segmentGeometryScratch,s3=o4.incidentPortRegion[e5],r5=o4.incidentPortRegion[n4],a3=s3[0]===t52||s3[1]!==t52?o4.portAngleForRegion1[e5]:o4.portAngleForRegion2?.[e5]??o4.portAngleForRegion1[e5],c4=r5[0]===t52||r5[1]!==t52?o4.portAngleForRegion1[n4]:o4.portAngleForRegion2?.[n4]??o4.portAngleForRegion1[n4],l4=o4.portZ[e5],h6=o4.portZ[n4];return i3.lesserAngle=a3<c4?a3:c4,i3.greaterAngle=a3<c4?c4:a3,i3.layerMask=1<<l4|1<<h6,i3.entryExitLayerChanges=l4!==h6?1:0,i3}appendSegmentToRegionCache(t52,e5,n4){let{topology:o4,state:i3}=this,s3=i3.regionIntersectionCaches[t52],r5=this.populateSegmentGeometryScratch(t52,e5,n4),[a3,c4,l4]=OC(s3,i3.currentRouteNetId,r5.lesserAngle,r5.greaterAngle,r5.layerMask,r5.entryExitLayerChanges),h6=s3.netIds.length+1,d4=new Int32Array(h6);d4.set(s3.netIds),d4[h6-1]=i3.currentRouteNetId;let u5=new Int32Array(h6);u5.set(s3.lesserAngles),u5[h6-1]=r5.lesserAngle;let p4=new Int32Array(h6);p4.set(s3.greaterAngles),p4[h6-1]=r5.greaterAngle;let m4=new Int32Array(h6);m4.set(s3.layerMasks),m4[h6-1]=r5.layerMask;let g6=s3.existingSameLayerIntersections+a3,f3=s3.existingCrossingLayerIntersections+c4,_4=s3.existingEntryExitLayerChanges+l4,y4=u5.length;i3.regionIntersectionCaches[t52]={netIds:d4,lesserAngles:u5,greaterAngles:p4,layerMasks:m4,existingSameLayerIntersections:g6,existingCrossingLayerIntersections:f3,existingEntryExitLayerChanges:_4,existingSegmentCount:y4,existingRegionCost:this.computeRegionCostForRegion(t52,g6,f3,_4,y4)}}getSolvedPathSegments(t52){let{state:e5}=this,n4=[],o4=t52;for(;o4;)n4.unshift(o4),o4=o4.prevCandidate;let i3=[];for(let t53=1;t53<n4.length;t53++)i3.push({regionId:n4[t53-1].nextRegionId,fromPortId:n4[t53-1].portId,toPortId:n4[t53].portId});let s3=n4[n4.length-1];return s3&&s3.portId!==e5.goalPortId&&i3.push({regionId:s3.nextRegionId,fromPortId:s3.portId,toPortId:e5.goalPortId}),i3}resetRoutingStateForRerip(){let{topology:t52,problem:e5,state:n4}=this;n4.portAssignment.fill(-1),n4.regionSegments=Array.from({length:t52.regionCount},()=>[]),n4.regionIntersectionCaches=Array.from({length:t52.regionCount},()=>IT()),n4.currentRouteNetId=void 0,n4.currentRouteId=void 0,n4.unroutedRoutes=kC(YC2(e5.routeCount),n4.ripCount),n4.candidateQueue.clear(),this.resetCandidateBestCosts(),n4.goalPortId=-1}getMaxRegionCost(){let{topology:t52,state:e5}=this,n4=0;for(let o4=0;o4<t52.regionCount;o4++){let t53=e5.regionIntersectionCaches[o4]?.existingRegionCost??0;n4=Math.max(n4,t53)}return n4}getRouteMetadata(t52){return this.problem.routeMetadata?.[t52]}getRouteConnectionId(t52){let e5=this.getRouteMetadata(t52)?.connectionId;return typeof e5=="string"?e5:`route-${t52}`}getRouteSummary(t52){return(({problem:t53,routeId:e5,getRouteMetadata:n4,getRouteConnectionId:o4})=>{let i3=n4?.(e5)??DC(t53,e5);return{routeId:e5,connectionId:o4?.(e5)??jC(t53,e5),startPortId:t53.routeStartPort[e5],endPortId:t53.routeEndPort[e5],startRegionId:typeof i3?.startRegionId=="string"?i3.startRegionId:void 0,endRegionId:typeof i3?.endRegionId=="string"?i3.endRegionId:void 0,pointIds:zC(i3)}})({problem:this.problem,routeId:t52,getRouteMetadata:t53=>this.getRouteMetadata(t53),getRouteConnectionId:t53=>this.getRouteConnectionId(t53)})}getAdditionalRegionLabel(t52){}getNeverSuccessfullyRoutedRoutes(){let t52=[];for(let e5=0;e5<this.problem.routeCount;e5++){let n4=this.routeAttemptCountByRouteId[e5];n4===0||this.routeSuccessCountByRouteId[e5]>0||t52.push({...this.getRouteSummary(e5),attempts:n4})}return t52}logNeverSuccessfullyRoutedRoutes(){if(!this.VERBOSE||this.hasLoggedNeverSuccessfullyRoutedRoutes)return;let t52=this.getNeverSuccessfullyRoutedRoutes();if(this.hasLoggedNeverSuccessfullyRoutedRoutes=!0,t52.length!==0){console.log(["[TinyHyperGraphSolver:never-routed-summary]",`count=${t52.length}`].join(" "));for(let e5 of t52){let t53=e5.pointIds.length>=2?`${e5.pointIds[0]}->${e5.pointIds[1]}`:"unknown";console.log(["[TinyHyperGraphSolver:never-routed]",`routeId=${e5.routeId}`,`connectionId=${e5.connectionId}`,`attempts=${e5.attempts}`,`pointPath=${t53}`,`startRegionId=${e5.startRegionId??"unknown"}`,`endRegionId=${e5.endRegionId??"unknown"}`].join(" "))}}}logRipEvent(t52,e5,n4={}){this.VERBOSE&&console.log(["[TinyHyperGraphSolver:rip]",`ripCount=${this.state.ripCount}`,`maxRegionCostBeforeRip=${e5.toFixed(3)}`,`reason=${t52}`,...Object.entries(n4).map(([t53,e6])=>`${t53}=${typeof e6=="number"?Number.isInteger(e6)?String(e6):e6.toFixed(3):e6}`)].join(" "))}onAllRoutesRouted(){let{topology:t52,state:e5}=this,n4=this.RIP_THRESHOLD_RAMP_ATTEMPTS<=0?1:Math.min(1,e5.ripCount/this.RIP_THRESHOLD_RAMP_ATTEMPTS),o4=this.RIP_THRESHOLD_START+(this.RIP_THRESHOLD_END-this.RIP_THRESHOLD_START)*n4,i3=[],s3=new Float64Array(t52.regionCount),r5=0;for(let n5=0;n5<t52.regionCount;n5++){let t53=e5.regionIntersectionCaches[n5]?.existingRegionCost??0;s3[n5]=t53,r5=Math.max(r5,t53),t53>o4&&i3.push(n5)}if(this.stats={...this.stats,currentRipThreshold:o4,hotRegionCount:i3.length,maxRegionCost:r5,ripCount:e5.ripCount},i3.length===0||e5.ripCount>=this.RIP_THRESHOLD_RAMP_ATTEMPTS)this.solved=!0;else{for(let n5=0;n5<t52.regionCount;n5++)e5.regionCongestionCost[n5]+=s3[n5]*this.RIP_CONGESTION_REGION_COST_FACTOR;e5.ripCount+=1,this.resetRoutingStateForRerip(),this.stats={...this.stats,ripCount:e5.ripCount,maxRegionCostBeforeRip:r5,reripRegionCount:i3.length},this.logRipEvent("hot_regions",r5,{hotRegionCount:i3.length,currentRipThreshold:o4})}}onOutOfCandidates(){let{topology:t52,state:e5}=this,n4=e5.currentRouteId,o4=this.getMaxRegionCost();for(let n5=0;n5<t52.regionCount;n5++){let t53=e5.regionIntersectionCaches[n5]?.existingRegionCost??0;e5.regionCongestionCost[n5]+=t53*this.RIP_CONGESTION_REGION_COST_FACTOR}e5.ripCount+=1,this.resetRoutingStateForRerip(),this.stats={...this.stats,ripCount:e5.ripCount,maxRegionCost:o4,maxRegionCostBeforeRip:o4,reripReason:"out_of_candidates"},this.logRipEvent("out_of_candidates",o4,{...n4===void 0?{}:{routeId:n4,connectionId:this.getRouteConnectionId(n4)}})}onPathFound(t52){let{state:e5}=this,n4=e5.currentRouteId;if(n4===void 0)return;this.routeSuccessCountByRouteId[n4]+=1;let o4=this.getSolvedPathSegments(t52);for(let{regionId:t53,fromPortId:i3,toPortId:s3}of o4)e5.regionSegments[t53].push([n4,i3,s3]),e5.portAssignment[i3]=e5.currentRouteNetId,e5.portAssignment[s3]=e5.currentRouteNetId,this.appendSegmentToRegionCache(t53,i3,s3);e5.candidateQueue.clear(),e5.currentRouteNetId=void 0,e5.currentRouteId=void 0}computeG(t52,e5){let{topology:n4,state:o4}=this,i3=t52.nextRegionId,s3=o4.regionIntersectionCaches[i3],r5=this.populateSegmentGeometryScratch(i3,t52.portId,e5),[a3,c4,l4]=OC(s3,o4.currentRouteNetId,r5.lesserAngle,r5.greaterAngle,r5.layerMask,r5.entryExitLayerChanges);if(a3>0&&this.isKnownSingleLayerRegion(i3))return Number.POSITIVE_INFINITY;let h6=this.computeRegionCostForRegion(i3,s3.existingSameLayerIntersections+a3,s3.existingCrossingLayerIntersections+c4,s3.existingEntryExitLayerChanges+l4,s3.existingSegmentCount+1)-s3.existingRegionCost;return t52.g+h6+o4.regionCongestionCost[i3]}tryFinalAcceptance(){let t52=this.getNeverSuccessfullyRoutedRoutes();this.stats={...this.stats,neverSuccessfullyRoutedRouteCount:t52.length},this.logNeverSuccessfullyRoutedRoutes()}computeH(t52){return this.problemSetup.portHCostToEndOfRoute[t52*this.problem.routeCount+this.state.currentRouteId]}visualize(){return ST(this)}getOutput(){return wC(this)}},TT=t52=>{let e5=typeof t52.d?.netId=="number"?t52.d.netId:typeof t52.d?.NetId=="number"?t52.d.NetId:void 0;return Number.isFinite(e5)?e5:void 0},wT=t52=>{let e5=new Set;for(let n5 of t52.connections??[])e5.add(n5.startRegionId),e5.add(n5.endRegionId);let n4=new Set(t52.regions.filter(t53=>(t54=>{if(t54.d?._containsObstacle!==!0)return!1;if(t54.d?._containsTarget!==!0)return!0;let e6=TT(t54);return e6===void 0||e6===-1})(t53)&&!e5.has(t53.regionId)).map(t53=>t53.regionId));if(n4.size===0)return t52;let o4=t52.ports.filter(t53=>!n4.has(t53.region1Id)&&!n4.has(t53.region2Id)),i3=(t52.connections??[]).find(t53=>n4.has(t53.startRegionId)||n4.has(t53.endRegionId));if(i3)throw new Error(`Connection "${i3.connectionId}" references full-obstacle region`);return{...t52,regions:t52.regions.filter(t53=>!n4.has(t53.regionId)),ports:o4}},RT=t52=>{let e5=t52.d?.bounds;if(e5)return e5;let n4=t52.d?.center,o4=t52.d?.width,i3=t52.d?.height;return n4&&typeof n4.x=="number"&&typeof n4.y=="number"&&typeof o4=="number"&&typeof i3=="number"?{minX:n4.x-o4/2,maxX:n4.x+o4/2,minY:n4.y-i3/2,maxY:n4.y+i3/2}:{minX:0,maxX:0,minY:0,maxY:0}},ET=t52=>Number(t52.d?.x??0),AT=t52=>Number(t52.d?.y??0),OT=(t52,e5)=>{if(!e5)return 0;let n4=RT(e5),o4=ET(t52),i3=AT(t52),s3=n4.minX<=o4&&o4<=n4.maxX,r5=n4.minY<=i3&&i3<=n4.maxY;if(r5&&o4>=n4.maxX){let t53=Math.max(n4.maxY-n4.minY,1e-9),e6=(i3-n4.minY)/t53;return Math.round(9e3*e6)}if(s3&&i3>=n4.maxY){let t53=Math.max(n4.maxX-n4.minX,1e-9),e6=(n4.maxX-o4)/t53;return 9e3+Math.round(9e3*e6)}if(r5&&o4<=n4.minX){let t53=Math.max(n4.maxY-n4.minY,1e-9),e6=(n4.maxY-i3)/t53;return 18e3+Math.round(9e3*e6)}if(s3&&i3<=n4.minY){let t53=Math.max(n4.maxX-n4.minX,1e-9),e6=(o4-n4.minX)/t53;return 27e3+Math.round(9e3*e6)}let a3=Math.abs(o4-n4.minX),c4=Math.abs(o4-n4.maxX),l4=Math.abs(i3-n4.minY),h6=Math.abs(i3-n4.maxY),d4=Math.min(a3,c4,l4,h6),u5=Math.max(n4.maxX-n4.minX,1e-9),p4=Math.max(n4.maxY-n4.minY,1e-9);if(d4===c4){let t53=(i3-n4.minY)/p4;return Math.round(9e3*t53)}if(d4===h6){let t53=(n4.maxX-o4)/u5;return 9e3+Math.round(9e3*t53)}if(d4===a3){let t53=(n4.maxY-i3)/p4;return 18e3+Math.round(9e3*t53)}let m4=(o4-n4.minX)/u5;return 27e3+Math.round(9e3*m4)},LT2=(t52,e5)=>{if(t52)return[...t52.pointIds].sort((t53,n4)=>{let o4=e5.get(t53),i3=e5.get(n4),s3=Number(o4?.d?.distToCentermostPortOnZ??Number.POSITIVE_INFINITY),r5=Number(i3?.d?.distToCentermostPortOnZ??Number.POSITIVE_INFINITY);if(s3!==r5)return s3-r5;let a3=Number(o4?.d?.z??0),c4=Number(i3?.d?.z??0);return a3!==c4?a3-c4:t53.localeCompare(n4)})[0]},kT=t52=>{let e5=wT(t52),n4=new Map,o4=new Map,i3=new Map,s3=new Map((e5.solvedRoutes??[]).map(t53=>[t53.connection.connectionId,t53]));e5.regions.forEach((t53,e6)=>{n4.set(t53.regionId,e6)}),e5.ports.forEach((t53,e6)=>{o4.set(t53.portId,e6),i3.set(t53.portId,t53)});let r5=e5.regions.length,a3=e5.ports.length,c4=e5.regions.map(t53=>t53.pointIds.map(t54=>o4.get(t54)).filter(t54=>t54!==void 0)),l4=Array.from({length:a3},()=>[]),h6=new Float64Array(r5),d4=new Float64Array(r5),u5=new Float64Array(r5),p4=new Float64Array(r5),m4=new Int32Array(r5),g6=new Int32Array(r5).fill(-1),f3=new Int8Array(r5);e5.regions.forEach((t53,e6)=>{let n5=(t54=>{let e7=RT(t54),n6=typeof t54.d?.width=="number"?t54.d.width:e7.maxX-e7.minX,o7=typeof t54.d?.height=="number"?t54.d.height:e7.maxY-e7.minY;return{centerX:typeof t54.d?.center?.x=="number"?t54.d.center.x:(e7.minX+e7.maxX)/2,centerY:typeof t54.d?.center?.y=="number"?t54.d.center.y:(e7.minY+e7.maxY)/2,width:n6,height:o7}})(t53);h6[e6]=n5.width,d4[e6]=n5.height,u5[e6]=n5.centerX,p4[e6]=n5.centerY,m4[e6]=(t54=>{let e7=t54.d?.availableZ;if(!Array.isArray(e7))return 0;let n6=0;for(let t55 of e7)!Number.isInteger(t55)||t55<0||t55>=31||(n6|=1<<t55);return n6})(t53);let o6=TT(t53);o6!==void 0&&(g6[e6]=o6,f3[e6]=1)});let _4=new Int32Array(a3),y4=new Int32Array(a3),b3=new Float64Array(a3),x4=new Float64Array(a3),v4=new Int32Array(a3);e5.ports.forEach((t53,o6)=>{let i4=n4.get(t53.region1Id),s4=n4.get(t53.region2Id);if(i4===void 0||s4===void 0)throw new Error(`Port "${t53.portId}" references missing regions "${t53.region1Id}" or "${t53.region2Id}"`);l4[o6]=[i4,s4],b3[o6]=ET(t53),x4[o6]=AT(t53),v4[o6]=(t54=>{let e6=Number(t54.d?.z??0);return Number.isFinite(e6)?e6:0})(t53),_4[o6]=OT(t53,e5.regions[i4]),y4[o6]=OT(t53,e5.regions[s4])});let S3=e5.regions.map((t53,e6)=>((t54,e7)=>{let n5=t54.d&&typeof t54.d=="object"&&!Array.isArray(t54.d)?{...t54.d}:{value:t54.d};return n5.layer=e7,Object.defineProperty(n5,"serializedRegionId",{value:t54.regionId,enumerable:!1,configurable:!0,writable:!0}),n5})(t53,(t54=>bC(xC(m4[t54]))??bC((c4[t54]??[]).map(t55=>v4[t55]))??"z0")(e6))),I4=e5.ports.map((t53,e6)=>((t54,e7)=>{let n5=t54.d&&typeof t54.d=="object"&&!Array.isArray(t54.d)?{...t54.d}:{value:t54.d};return n5.layer=e7,Object.defineProperty(n5,"serializedPortId",{value:t54.portId,enumerable:!1,configurable:!0,writable:!0}),n5})(t53,bC([v4[e6]])??"z0")),P4=e5.connections??[],M4=new Map,N4=0,C4=t53=>{let e6=t53.mutuallyConnectedNetworkId??t53.connectionId,n5=M4.get(e6);return n5===void 0&&(n5=N4++,M4.set(e6,n5)),n5},T4=Array.from({length:r5},()=>new Set),w4=(t53,e6)=>{let o6=n4.get(t53);if(o6===void 0)throw new Error(`Connection references missing region "${t53}"`);T4[o6].add(e6)};P4.forEach(t53=>{let e6=C4(t53);w4(t53.startRegionId,e6),w4(t53.endRegionId,e6)}),T4.forEach((t53,e6)=>{f3[e6]!==1&&t53.size===1&&(g6[e6]=[...t53][0])});let R3=P4.map(t53=>{let n5=s3.get(t53.connectionId),o6=((t54,e6)=>t54.ports.filter(t55=>t55.region1Id===e6.startRegionId&&t55.region2Id===e6.endRegionId||t55.region2Id===e6.startRegionId&&t55.region1Id===e6.endRegionId).map(t55=>t55.portId))(e5,t53);return{connection:t53,solvedRoute:n5,sharedPortIds:o6}}).filter(({solvedRoute:t53,sharedPortIds:e6})=>e6.length===0||(t53?.path.length??0)>1),E3=R3.length,A4=new Int8Array(a3).fill(1),O3=new Int32Array(E3),L3=new Int32Array(E3),k4=new Int32Array(E3);R3.forEach(({connection:t53,solvedRoute:n5},s4)=>{let r6=LT2(e5.regions.find(e6=>e6.regionId===t53.startRegionId),i3),a4=LT2(e5.regions.find(e6=>e6.regionId===t53.endRegionId),i3),c5=n5?.path[0]?.portId??r6,l5=n5?.path[n5.path.length-1]?.portId??a4,h7=c5!==void 0?o4.get(c5):void 0,d5=l5!==void 0?o4.get(l5):void 0;if(h7===void 0||d5===void 0)throw new Error(`Connection "${t53.connectionId}" could not be mapped to route endpoints`);O3[s4]=h7,L3[s4]=d5,k4[s4]=C4(t53)});let D4={portCount:a3,regionCount:r5,regionIncidentPorts:c4,incidentPortRegion:l4,regionWidth:h6,regionHeight:d4,regionCenterX:u5,regionCenterY:p4,regionAvailableZMask:m4,regionMetadata:S3,portAngleForRegion1:_4,portAngleForRegion2:y4,portX:b3,portY:x4,portZ:v4,portMetadata:I4},z4={routeCount:E3,portSectionMask:A4,routeMetadata:R3.map(({connection:t53})=>t53),routeStartPort:O3,routeEndPort:L3,routeNet:k4,regionNetId:g6},j4=[],F4=[];for(let{solvedRoute:t53}of R3){if(!t53){j4.push([]),F4.push([]);continue}let e6=[],i4=[];for(let s4=1;s4<t53.path.length;s4++){let r6=t53.path[s4-1],a4=t53.path[s4],c5=r6?.portId,l5=a4?.portId,h7=c5!==void 0?o4.get(c5):void 0,d5=l5!==void 0?o4.get(l5):void 0;if(h7===void 0||d5===void 0)continue;let u6=typeof r6?.nextRegionId=="string"?r6.nextRegionId:typeof a4?.lastRegionId=="string"?a4.lastRegionId:void 0;e6.push([h7,d5]),i4.push(u6!==void 0?n4.get(u6):void 0)}j4.push(e6),F4.push(i4)}return{topology:D4,problem:z4,solution:{solvedRoutePathSegments:j4,solvedRoutePathRegionIds:F4}}},DT=(t52,e5)=>{PT(t52,e5),e5&&(e5.MAX_RIPS!==void 0&&(t52.MAX_RIPS=e5.MAX_RIPS),e5.MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT!==void 0&&(t52.MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT=e5.MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT),e5.EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST!==void 0&&(t52.EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST=e5.EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST))},zT=t52=>t52.map(t53=>t53.map(([t54,e5,n4])=>[t54,e5,n4])),jT2=t52=>({netIds:new Int32Array(t52.netIds),lesserAngles:new Int32Array(t52.lesserAngles),greaterAngles:new Int32Array(t52.greaterAngles),layerMasks:new Int32Array(t52.layerMasks),existingCrossingLayerIntersections:t52.existingCrossingLayerIntersections,existingSameLayerIntersections:t52.existingSameLayerIntersections,existingEntryExitLayerChanges:t52.existingEntryExitLayerChanges,existingRegionCost:t52.existingRegionCost,existingSegmentCount:t52.existingSegmentCount}),FT=t52=>({portAssignment:new Int32Array(t52.portAssignment),regionSegments:zT(t52.regionSegments),regionIntersectionCaches:t52.regionIntersectionCaches.map(jT2)}),$T=(t52,e5)=>{let n4=FT(e5);t52.state.portAssignment=n4.portAssignment,t52.state.regionSegments=n4.regionSegments,t52.state.regionIntersectionCaches=n4.regionIntersectionCaches},BT=t52=>{let e5=0,n4=0;for(let o4=0;o4<t52.length;o4++){let i3=t52[o4]?.existingRegionCost??0;e5=Math.max(e5,i3),n4+=i3}return{maxRegionCost:e5,totalRegionCost:n4}},YT2=(t52,e5)=>t52.maxRegionCost!==e5.maxRegionCost?t52.maxRegionCost-e5.maxRegionCost:t52.totalRegionCost-e5.totalRegionCost,XT=(t52,e5,n4)=>{let o4=t52.incidentPortRegion[e5]??[],i3=t52.incidentPortRegion[n4]??[],s3=o4.find(t53=>i3.includes(t53));if(s3===void 0)throw new Error(`Ports ${e5} and ${n4} do not share a region`);return s3},HT=(t52,e5,n4,o4)=>{let i3=n4.solvedRoutePathSegments[o4]??[],s3=n4.solvedRoutePathRegionIds?.[o4]??[],r5=e5.routeStartPort[o4],a3=e5.routeEndPort[o4];if(i3.length===0){if(r5===a3)return{orderedPortIds:[r5],orderedRegionIds:[]};throw new Error(`Route ${o4} does not have an existing solved path`)}let c4=new Map;i3.forEach(([t53,e6],n5)=>{let o6={segmentIndex:n5,fromPortId:t53,toPortId:e6,regionId:s3[n5]},i4=c4.get(t53)??[];i4.push(o6),c4.set(t53,i4);let r6=c4.get(e6)??[];r6.push(o6),c4.set(e6,r6)});let l4=[r5],h6=[],d4=new Set,u5,p4=r5;for(;p4!==a3;){let e6=(c4.get(p4)??[]).filter(({segmentIndex:t53,fromPortId:e7,toPortId:n6})=>d4.has(t53)?!1:(e7===p4?n6:e7)!==u5);if(e6.length!==1)throw new Error(`Route ${o4} is not a single ordered path from ${r5} to ${a3}`);let n5=e6[0],i4=n5.fromPortId===p4?n5.toPortId:n5.fromPortId;d4.add(n5.segmentIndex),h6.push(n5.regionId??XT(t52,n5.fromPortId,n5.toPortId)),l4.push(i4),u5=p4,p4=i4}if(d4.size!==i3.length)throw new Error(`Route ${o4} contains disconnected solved segments`);return{orderedPortIds:l4,orderedRegionIds:h6}},WT=(t52,e5,n4,o4)=>{let i3=new CT(t52,e5,o4);return((t53,e6)=>{t53.state.portAssignment.fill(-1),t53.state.regionSegments=Array.from({length:t53.topology.regionCount},()=>[]),t53.state.regionIntersectionCaches=Array.from({length:t53.topology.regionCount},()=>IT()),t53.state.currentRouteId=void 0,t53.state.currentRouteNetId=void 0,t53.state.unroutedRoutes=[],t53.state.candidateQueue.clear(),t53.resetCandidateBestCosts(),t53.state.goalPortId=-1,t53.state.ripCount=0,t53.state.regionCongestionCost.fill(0);for(let n5=0;n5<e6.length;n5++)for(let[o6,i4,s3]of e6[n5]??[])t53.state.currentRouteNetId=t53.problem.routeNet[o6],t53.state.regionSegments[n5].push([o6,i4,s3]),t53.state.portAssignment[i4]=t53.state.currentRouteNetId,t53.state.portAssignment[s3]=t53.state.currentRouteNetId,t53.appendSegmentToRegionCache(n5,i4,s3);t53.state.currentRouteId=void 0,t53.state.currentRouteNetId=void 0,t53.solved=!0,t53.failed=!1,t53.error=null})(i3,n4),i3},VT=(t52,e5,n4)=>{let o4=new Int32Array(e5.routeStartPort),i3=new Int32Array(e5.routeEndPort),s3=Array.from({length:e5.routeCount},(t53,e6)=>({routeId:e6,fixedSegments:[]})),r5=[];for(let a3=0;a3<e5.routeCount;a3++){let c4=s3[a3],{orderedPortIds:l4,orderedRegionIds:h6}=HT(t52,e5,n4,a3),d4=[],u5;for(let t53=0;t53<l4.length;t53++){let n5=l4[t53],o6=e5.portSectionMask[n5]===1;o6&&u5===void 0?u5=t53:o6||u5===void 0||(d4.push({startIndex:u5,endIndex:t53-1}),u5=void 0)}if(u5!==void 0&&d4.push({startIndex:u5,endIndex:l4.length-1}),d4.length===0){for(let t53=1;t53<l4.length;t53++)c4.fixedSegments.push({regionId:h6[t53-1],fromPortId:l4[t53-1],toPortId:l4[t53]});continue}if(d4.length>1)throw new Error(`Route ${a3} enters the section multiple times; only one contiguous section span is currently supported`);let p4=d4[0],m4=Math.max(0,p4.startIndex-1),g6=Math.min(l4.length-1,p4.endIndex+1);if(g6<=m4)throw new Error(`Route ${a3} does not have a valid section span`);for(let t53=1;t53<=m4;t53++)c4.fixedSegments.push({regionId:h6[t53-1],fromPortId:l4[t53-1],toPortId:l4[t53]});for(let t53=g6+1;t53<l4.length;t53++)c4.fixedSegments.push({regionId:h6[t53-1],fromPortId:l4[t53-1],toPortId:l4[t53]});c4.activeStartPortId=l4[m4],c4.activeEndPortId=l4[g6],c4.forcedStartRegionId=h6[m4],o4[a3]=c4.activeStartPortId,i3[a3]=c4.activeEndPortId,r5.push(a3)}return{sectionProblem:{routeCount:e5.routeCount,portSectionMask:new Int8Array(e5.portSectionMask),routeMetadata:e5.routeMetadata,routeStartPort:o4,routeEndPort:i3,routeNet:new Int32Array(e5.routeNet),regionNetId:new Int32Array(e5.regionNetId)},routePlans:s3,activeRouteIds:r5}},UT=(t52,e5,n4)=>VT(t52,e5,n4).activeRouteIds,ZT=class extends CT{constructor(t52,e5,n4,o4,i3,s3,r5,a3){super(t52,e5,a3);__publicField(this,"routePlans");__publicField(this,"activeRouteIds");__publicField(this,"mutableRegionIds");__publicField(this,"immutableRegionSummary");__publicField(this,"baselineSummary");__publicField(this,"bestSnapshot");__publicField(this,"fixedSnapshot");__publicField(this,"bestSummary");__publicField(this,"baselineBeatRipCount");__publicField(this,"previousBestMaxRegionCost",Number.POSITIVE_INFINITY);__publicField(this,"ripsSinceBestMaxRegionCostImprovement",0);__publicField(this,"MAX_RIPS",Number.POSITIVE_INFINITY);__publicField(this,"MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT",Number.POSITIVE_INFINITY);__publicField(this,"EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST",Number.POSITIVE_INFINITY);this.routePlans=n4,this.activeRouteIds=o4,this.mutableRegionIds=i3,this.immutableRegionSummary=s3,this.baselineSummary=r5,DT(this,a3),this.state.unroutedRoutes=[...o4],this.applyFixedSegments(),this.fixedSnapshot=FT({portAssignment:this.state.portAssignment,regionSegments:this.state.regionSegments,regionIntersectionCaches:this.state.regionIntersectionCaches})}applyFixedSegments(){for(let t52 of this.routePlans)for(let{regionId:e5,fromPortId:n4,toPortId:o4}of t52.fixedSegments)this.state.currentRouteNetId=this.problem.routeNet[t52.routeId],this.state.regionSegments[e5].push([t52.routeId,n4,o4]),this.state.portAssignment[n4]=this.state.currentRouteNetId,this.state.portAssignment[o4]=this.state.currentRouteNetId,this.appendSegmentToRegionCache(e5,n4,o4);this.state.currentRouteId=void 0,this.state.currentRouteNetId=void 0}captureBestState(t52){this.bestSummary&&YT2(t52,this.bestSummary)>=0||(this.bestSummary=t52,this.bestSnapshot=FT({portAssignment:this.state.portAssignment,regionSegments:this.state.regionSegments,regionIntersectionCaches:this.state.regionIntersectionCaches}))}restoreBestState(){this.bestSnapshot&&($T(this,this.bestSnapshot),this.state.currentRouteId=void 0,this.state.currentRouteNetId=void 0,this.state.unroutedRoutes=[],this.state.candidateQueue.clear(),this.resetCandidateBestCosts(),this.state.goalPortId=-1)}getStartingNextRegionId(t52,e5){let n4=this.routePlans[t52]?.forcedStartRegionId;return n4!==void 0?n4:super.getStartingNextRegionId(t52,e5)}resetRoutingStateForRerip(){if(!this.fixedSnapshot)return super.resetRoutingStateForRerip(),this.state.unroutedRoutes=kC([...this.activeRouteIds],this.state.ripCount),void this.applyFixedSegments();$T(this,this.fixedSnapshot),this.state.currentRouteId=void 0,this.state.currentRouteNetId=void 0,this.state.unroutedRoutes=kC([...this.activeRouteIds],this.state.ripCount),this.state.candidateQueue.clear(),this.resetCandidateBestCosts(),this.state.goalPortId=-1}onAllRoutesRouted(){let{state:t52}=this,e5=Math.min(this.MAX_RIPS,this.RIP_THRESHOLD_RAMP_ATTEMPTS),n4=e5<=0?1:Math.min(1,t52.ripCount/e5),o4=this.RIP_THRESHOLD_START+(this.RIP_THRESHOLD_END-this.RIP_THRESHOLD_START)*n4,i3=[],s3=new Float64Array(this.mutableRegionIds.length),r5=0,a3=0;for(let e6=0;e6<this.mutableRegionIds.length;e6++){let n5=this.mutableRegionIds[e6],c5=t52.regionIntersectionCaches[n5]?.existingRegionCost??0;s3[e6]=c5,r5=Math.max(r5,c5),a3+=c5,c5>o4&&i3.push(n5)}let c4=Math.max(this.immutableRegionSummary.maxRegionCost,r5),l4=this.immutableRegionSummary.totalRegionCost+a3;this.captureBestState({maxRegionCost:c4,totalRegionCost:l4});let h6=this.bestSummary??{maxRegionCost:c4,totalRegionCost:l4};if(h6.maxRegionCost<this.previousBestMaxRegionCost-Number.EPSILON?(this.previousBestMaxRegionCost=h6.maxRegionCost,this.ripsSinceBestMaxRegionCostImprovement=0):this.ripsSinceBestMaxRegionCostImprovement+=1,this.baselineBeatRipCount===void 0&&h6.maxRegionCost<this.baselineSummary.maxRegionCost-Number.EPSILON&&(this.baselineBeatRipCount=t52.ripCount),this.stats={...this.stats,activeRouteCount:this.activeRouteIds.length,currentRipThreshold:o4,hotRegionCount:i3.length,maxRegionCost:c4,totalRegionCost:l4,bestMaxRegionCost:h6.maxRegionCost,bestTotalRegionCost:h6.totalRegionCost,ripCount:t52.ripCount},i3.length===0||t52.ripCount>=e5||this.ripsSinceBestMaxRegionCostImprovement>=this.MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT||this.baselineBeatRipCount!==void 0&&t52.ripCount-this.baselineBeatRipCount>=this.EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST)return this.restoreBestState(),void(this.solved=!0);for(let e6=0;e6<this.mutableRegionIds.length;e6++){let n5=this.mutableRegionIds[e6];t52.regionCongestionCost[n5]+=s3[e6]*this.RIP_CONGESTION_REGION_COST_FACTOR}t52.ripCount+=1,this.resetRoutingStateForRerip(),this.stats={...this.stats,ripCount:t52.ripCount,reripRegionCount:i3.length}}onOutOfCandidates(){let{state:t52}=this;for(let e5 of this.mutableRegionIds){let n4=t52.regionIntersectionCaches[e5]?.existingRegionCost??0;t52.regionCongestionCost[e5]+=n4*this.RIP_CONGESTION_REGION_COST_FACTOR}t52.ripCount+=1,this.resetRoutingStateForRerip(),this.stats={...this.stats,ripCount:t52.ripCount,reripReason:"out_of_candidates"}}tryFinalAcceptance(){this.bestSnapshot?(this.restoreBestState(),this.solved=!0):super.tryFinalAcceptance()}visualize(){return ST(this,{highlightSectionMask:!0,showInitialRouteHints:!1,showOnlySectionPortsOnIdle:!0})}},GT2=class extends Tt2{constructor(t52,e5,n4,o4){super();__publicField(this,"topology");__publicField(this,"problem");__publicField(this,"initialSolution");__publicField(this,"baselineSolver");__publicField(this,"baselineSummary");__publicField(this,"sectionBaselineSummary");__publicField(this,"outsideSectionBaselineSummary");__publicField(this,"sectionRegionIds");__publicField(this,"optimizedSolver");__publicField(this,"sectionSolver");__publicField(this,"activeRouteIds",[]);__publicField(this,"DISTANCE_TO_COST",.05);__publicField(this,"minViaPadDiameter",RC);__publicField(this,"VERBOSE",!1);__publicField(this,"RIP_THRESHOLD_START",.05);__publicField(this,"RIP_THRESHOLD_END",.8);__publicField(this,"RIP_THRESHOLD_RAMP_ATTEMPTS",50);__publicField(this,"MAX_RIPS",Number.POSITIVE_INFINITY);__publicField(this,"MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT",10);__publicField(this,"EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST",10);__publicField(this,"RIP_CONGESTION_REGION_COST_FACTOR",.1);__publicField(this,"MAX_ITERATIONS",1e6);__publicField(this,"STATIC_REACHABILITY_PRECHECK",!1);__publicField(this,"STATIC_REACHABILITY_PRECHECK_MAX_HOPS",16);this.topology=t52,this.problem=e5,this.initialSolution=n4,DT(this,o4),this.baselineSolver=((t53,e6,n5,o6)=>{let i3=Array.from({length:t53.regionCount},()=>[]);for(let o7=0;o7<e6.routeCount;o7++){let{orderedPortIds:s3,orderedRegionIds:r5}=HT(t53,e6,n5,o7);for(let t54=1;t54<s3.length;t54++){let e7=s3[t54-1],n6=s3[t54];i3[r5[t54-1]].push([o7,e7,n6])}}return WT(t53,e6,i3,o6)})(t52,e5,n4,MT(this)),this.baselineSummary=BT(this.baselineSolver.state.regionIntersectionCaches),this.sectionRegionIds=((t53,e6)=>{let n5=new Set;for(let o6=0;o6<e6.portSectionMask.length;o6++)if(e6.portSectionMask[o6]===1)for(let e7 of t53.incidentPortRegion[o6]??[])n5.add(e7);return[...n5]})(t52,e5),this.sectionBaselineSummary=((t53,e6)=>{let n5=0,o6=0;for(let i3 of e6){let e7=t53[i3]?.existingRegionCost??0;n5=Math.max(n5,e7),o6+=e7}return{maxRegionCost:n5,totalRegionCost:o6}})(this.baselineSolver.state.regionIntersectionCaches,this.sectionRegionIds),this.outsideSectionBaselineSummary=((t53,e6)=>{let n5=new Set(e6),o6=0,i3=0;for(let e7=0;e7<t53.length;e7++){if(n5.has(e7))continue;let s3=t53[e7]?.existingRegionCost??0;o6=Math.max(o6,s3),i3+=s3}return{maxRegionCost:o6,totalRegionCost:i3}})(this.baselineSolver.state.regionIntersectionCaches,this.sectionRegionIds),this.applySectionRipPolicy()}applySectionRipPolicy(){this.RIP_THRESHOLD_START=.05,this.RIP_THRESHOLD_END=Math.max(this.RIP_THRESHOLD_START,this.sectionBaselineSummary.maxRegionCost),this.MAX_RIPS=Math.min(this.MAX_RIPS,20)}_setup(){this.applySectionRipPolicy();let{sectionProblem:t52,routePlans:e5,activeRouteIds:n4}=VT(this.topology,this.problem,this.initialSolution);if(this.activeRouteIds=n4,n4.length===0)return this.optimizedSolver=this.baselineSolver,this.stats={...this.stats,activeRouteCount:0,initialMaxRegionCost:this.baselineSummary.maxRegionCost,finalMaxRegionCost:this.baselineSummary.maxRegionCost,optimized:!1},void(this.solved=!0);var o4;this.sectionSolver=new ZT(this.topology,t52,e5,n4,this.sectionRegionIds,this.outsideSectionBaselineSummary,this.baselineSummary,{...MT(o4=this),MAX_RIPS:o4.MAX_RIPS,MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT:o4.MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT,EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST:o4.EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST}),this.activeSubSolver=this.sectionSolver,this.stats={...this.stats,sectionBaselineMaxRegionCost:this.sectionBaselineSummary.maxRegionCost,sectionBaselineTotalRegionCost:this.sectionBaselineSummary.totalRegionCost,effectiveRipThresholdStart:this.RIP_THRESHOLD_START,effectiveRipThresholdEnd:this.RIP_THRESHOLD_END,effectiveMaxRips:this.MAX_RIPS}}_step(){if(!this.sectionSolver)return void(this.solved=!0);if(this.sectionSolver.step(),this.stats={...this.stats,...this.sectionSolver.stats,activeRouteCount:this.activeRouteIds.length},this.sectionSolver.failed)return this.error=this.sectionSolver.error,void(this.failed=!0);if(!this.sectionSolver.solved)return;let t52=WT(this.topology,this.problem,zT(this.sectionSolver.state.regionSegments),MT(this)),e5=BT(t52.state.regionIntersectionCaches),n4=YT2(e5,this.baselineSummary)<0;this.optimizedSolver=n4?t52:this.baselineSolver;let o4=n4?e5:this.baselineSummary;this.stats={...this.stats,initialMaxRegionCost:this.baselineSummary.maxRegionCost,initialTotalRegionCost:this.baselineSummary.totalRegionCost,candidateMaxRegionCost:e5.maxRegionCost,candidateTotalRegionCost:e5.totalRegionCost,finalMaxRegionCost:o4.maxRegionCost,finalTotalRegionCost:o4.totalRegionCost,optimized:n4},this.solved=!0}getSolvedSolver(){if(!this.solved||this.failed||!this.optimizedSolver)throw new Error("TinyHyperGraphSectionSolver does not have a solved output yet");return this.optimizedSolver}visualize(){return this.optimizedSolver?ST(this.optimizedSolver,{highlightSectionMask:!0}):this.sectionSolver?this.sectionSolver.visualize():ST(this.baselineSolver,{highlightSectionMask:!0,showInitialRouteHints:!1,showOnlySectionPortsOnIdle:!0})}getOutput(){return this.getSolvedSolver().getOutput()}},qT=["self-touch","onehop-all","onehop-touch","twohop-all","twohop-touch"],JT2={"self-all":0,"self-touch":0,"onehop-all":1,"onehop-touch":1,"twohop-all":2,"twohop-touch":2,"threehop-all":3,"threehop-touch":3,"fourhop-all":4,"fourhop-touch":4},KT2=(t52,e5)=>{let n4=new Set(e5);for(let o4 of e5)for(let e6 of t52.regionIncidentPorts[o4]??[])for(let o6 of t52.incidentPortRegion[e6]??[])n4.add(o6);return[...n4]},QT=(t52,e5,n4)=>{let o4=[...new Set(e5)];for(let e6=0;e6<n4;e6+=1)o4=KT2(t52,o4);return o4},tw=(t52,e5,n4)=>e5.flatMap(e6=>n4.map(n5=>((t53,e7,n6)=>({label:`hot-${e7}-${n6}`,family:n6,regionIds:QT(t53,[e7],JT2[n6]),portSelectionRule:n6.endsWith("-all")?"all-incident-regions-selected":"touches-selected-region"}))(t52,e6,n5))),ew={RIP_THRESHOLD_RAMP_ATTEMPTS:5},nw={DISTANCE_TO_COST:.05,RIP_THRESHOLD_RAMP_ATTEMPTS:16,RIP_CONGESTION_REGION_COST_FACTOR:.1,MAX_ITERATIONS:1e6,MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT:6,EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST:Number.POSITIVE_INFINITY},ow=t52=>t52.state.regionIntersectionCaches.reduce((t53,e5)=>Math.max(t53,e5.existingRegionCost),0),iw=(t52,e5)=>{let n4=kT(t52),o4=new GT2(n4.topology,n4.problem,n4.solution,e5);return ow(o4.baselineSolver)},sw=(t52,e5,n4)=>{let o4=new Set(e5);return Int8Array.from({length:t52.portCount},(e6,i3)=>{let s3=t52.incidentPortRegion[i3]??[];return n4==="touches-selected-region"?s3.some(t53=>o4.has(t53))?1:0:s3.length>0&&s3.every(t53=>o4.has(t53))?1:0})},rw=(t52,e5)=>({routeCount:t52.routeCount,portSectionMask:e5,routeMetadata:t52.routeMetadata,routeStartPort:new Int32Array(t52.routeStartPort),routeEndPort:new Int32Array(t52.routeEndPort),routeNet:new Int32Array(t52.routeNet),regionNetId:new Int32Array(t52.regionNetId)}),aw=(t52,e5,n4,o4,i3,s3)=>{let r5=performance.now(),a3=performance.now(),c4=new GT2(e5,n4,o4,s3),l4=ow(c4.baselineSolver),h6=performance.now()-a3,d4,u5,p4=l4,m4=new Int8Array(e5.portCount),g6=0,f3=0,_4=0,y4=0,b3=0,x4=0,v4=0,S3=new Set,I4=i3?.maxHotRegions??s3.MAX_HOT_REGIONS??2;for(let r6 of((t53,e6,n5,o6)=>{let i4=t53.state.regionIntersectionCaches.map((t54,e7)=>({regionId:e7,regionCost:t54.existingRegionCost})).filter(({regionCost:t54})=>t54>0).sort((t54,e7)=>e7.regionCost-t54.regionCost).slice(0,n5).map(({regionId:t54})=>t54);return tw(e6,i4,o6)})(t52,e5,I4,i3?.candidateFamilies??[...qT])){let t53=rw(n4,sw(e5,r6.regionIds,r6.portSelectionRule));g6+=1;let i4=t53.portSectionMask.join(",");if(S3.has(i4))_4+=1;else{S3.add(i4);try{let n5=performance.now(),i5=UT(e5,t53,o4);if(y4+=performance.now()-n5,i5.length===0)continue;f3+=1;let a4=performance.now(),c5=new GT2(e5,t53,o4,s3);b3+=performance.now()-a4;let l5=performance.now();if(c5.solve(),x4+=performance.now()-l5,c5.failed||!c5.solved)continue;if(Number(c5.stats.finalMaxRegionCost??ow(c5.getSolvedSolver()))<p4-1e-9){let e6=performance.now(),n6=iw(c5.getOutput(),s3);v4+=performance.now()-e6,n6<p4-1e-9&&(p4=n6,m4=new Int8Array(t53.portSectionMask),d4=r6.label,u5=r6.family)}}catch{}}}return{portSectionMask:m4,baselineMaxRegionCost:l4,finalMaxRegionCost:p4,generatedCandidateCount:g6,candidateCount:f3,duplicateCandidateCount:_4,totalMs:performance.now()-r5,baselineEvaluationMs:h6,candidateEligibilityMs:y4,candidateInitMs:b3,candidateSolveMs:x4,candidateReplayScoreMs:v4,winningCandidateLabel:d4,winningCandidateFamily:u5}},cw2=class extends Rt2{constructor(){super(...arguments);__publicField(this,"initialVisualizationSolver");__publicField(this,"selectedSectionMask");__publicField(this,"selectedSectionCandidateLabel");__publicField(this,"selectedSectionCandidateFamily");__publicField(this,"pipelineDef",[{solverName:"solveGraph",solverClass:CT,getConstructorParams:t52=>{let{topology:e5,problem:n4}=t52.loadHyperGraph(t52.inputProblem.serializedHyperGraph);return[e5,n4,t52.getSolveGraphOptions()]}},{solverName:"optimizeSection",solverClass:GT2,getConstructorParams:t52=>t52.getSectionStageParams()}])}loadHyperGraph(t52){return kT(t52)}getSolveGraphOptions(){return{...ew,...this.inputProblem.minViaPadDiameter===void 0?{}:{minViaPadDiameter:this.inputProblem.minViaPadDiameter},...this.inputProblem.solveGraphOptions}}getSectionSolverOptions(){return{...nw,...this.inputProblem.minViaPadDiameter===void 0?{}:{minViaPadDiameter:this.inputProblem.minViaPadDiameter},...this.inputProblem.sectionSolverOptions}}getSectionStageParams(){let t52=this.getStageOutput("solveGraph");if(!t52)throw new Error("solveGraph did not produce a solved serialized hypergraph");let e5=this.getSolver("solveGraph");if(!e5)throw new Error("solveGraph solver is unavailable");let n4=this.getSectionSolverOptions(),{topology:o4,problem:i3,solution:s3}=this.loadHyperGraph(t52),r5=this.inputProblem.createSectionMask?this.inputProblem.createSectionMask({serializedHyperGraph:this.inputProblem.serializedHyperGraph,solvedSerializedHyperGraph:t52,solvedSolver:e5,topology:o4,problem:i3,solution:s3}):(()=>{let t53=aw(e5,o4,i3,s3,this.inputProblem.sectionSearchConfig,n4);return this.selectedSectionCandidateLabel=t53.winningCandidateLabel,this.selectedSectionCandidateFamily=t53.winningCandidateFamily,this.stats={...this.stats,sectionSearchGeneratedCandidateCount:t53.generatedCandidateCount,sectionSearchCandidateCount:t53.candidateCount,sectionSearchDuplicateCandidateCount:t53.duplicateCandidateCount,sectionSearchBaselineMaxRegionCost:t53.baselineMaxRegionCost,sectionSearchFinalMaxRegionCost:t53.finalMaxRegionCost,sectionSearchDelta:t53.baselineMaxRegionCost-t53.finalMaxRegionCost,selectedSectionCandidateLabel:t53.winningCandidateLabel??null,selectedSectionCandidateFamily:t53.winningCandidateFamily??null,sectionSearchMs:t53.totalMs,sectionSearchBaselineEvaluationMs:t53.baselineEvaluationMs,sectionSearchCandidateEligibilityMs:t53.candidateEligibilityMs,sectionSearchCandidateInitMs:t53.candidateInitMs,sectionSearchCandidateSolveMs:t53.candidateSolveMs,sectionSearchCandidateReplayScoreMs:t53.candidateReplayScoreMs},t53.portSectionMask})();return this.selectedSectionMask=new Int8Array(r5),i3.portSectionMask=new Int8Array(r5),this.stats={...this.stats,sectionMaskPortCount:[...r5].filter(t53=>t53===1).length},[o4,i3,s3,n4]}getInitialVisualizationSolver(){if(!this.initialVisualizationSolver){let{topology:t52,problem:e5}=this.loadHyperGraph(this.inputProblem.serializedHyperGraph);this.initialVisualizationSolver=new CT(t52,e5,this.getSolveGraphOptions())}return this.initialVisualizationSolver}initialVisualize(){return this.getInitialVisualizationSolver().visualize()}visualize(){return this.iterations===0?this.initialVisualize()??super.visualize():super.visualize()}getOutput(){return this.getStageOutput("optimizeSection")??this.getStageOutput("solveGraph")??null}},lw=(new Int32Array(0),1e-6),hw2={DISTANCE_TO_COST:.05,RIP_THRESHOLD_START:.05,RIP_THRESHOLD_END:.8,RIP_CONGESTION_REGION_COST_FACTOR:.1},dw2={DISTANCE_TO_COST:.05,RIP_THRESHOLD_START:.05,RIP_THRESHOLD_END:.8,RIP_CONGESTION_REGION_COST_FACTOR:.1,MAX_RIPS_WITHOUT_MAX_REGION_COST_IMPROVEMENT:6,EXTRA_RIPS_AFTER_BEATING_BASELINE_MAX_REGION_COST:Number.POSITIVE_INFINITY},uw=t52=>Math.max(t52,.01),pw=t52=>Number.isFinite(t52)?{minViaPadDiameter:t52}:{},mw=(t52,e5)=>{let n4=uw(t52);return{...hw2,...pw(e5),RIP_THRESHOLD_RAMP_ATTEMPTS:Math.ceil(10*n4),MAX_ITERATIONS:Math.ceil(1e7*n4)}},gw=(t52,e5)=>{let n4=uw(t52);return{...dw2,...pw(e5),RIP_THRESHOLD_RAMP_ATTEMPTS:Math.ceil(16*n4),MAX_ITERATIONS:Math.ceil(1e6*n4)}},fw2=t52=>(t52.solveGraphOptions?.MAX_ITERATIONS??1e6)+(t52.sectionSolverOptions?.MAX_ITERATIONS??1e6)+1e6,_w=(t52,e5)=>t52.simpleRouteConnection?.pointsToConnect[e5],yw=t52=>{let e5=_w(t52.routeMetadata,t52.endpointIndex);if(!e5)return t52.fallbackZ;let n4=io2(e5).map(e6=>xo2(e6,t52.layerCount));return t52.regionAvailableZ.find(t53=>n4.includes(t53))??t52.fallbackZ},bw2=class extends cw2{constructor(t52){super(t52);__publicField(this,"configuredSolvers",new WeakSet);this.MAX_ITERATIONS=fw2(t52)}_step(){try{super._step()}catch(t52){if(this.tryAcceptSolveGraphWithoutSerializedOutput(t52)||this.trySkipOptimizeSection(t52))return;throw t52}this.configureSolver(this.activeSubSolver)}getInitialVisualizationSolver(){let t52=super.getInitialVisualizationSolver();return this.configureSolver(t52),t52}getSolvedTinySolver(){let t52=this.getSolver("optimizeSection");if(t52?.solved&&!t52.failed)return t52.getSolvedSolver();let e5=this.getSolver("solveGraph");if(e5?.solved&&!e5.failed)return e5;throw new Error("TinyHyperGraph section pipeline does not have a solved graph")}configureSolver(t52){t52&&!this.configuredSolvers.has(t52)&&((t52 instanceof GT2||t52 instanceof CT)&&(t53=>{let e5=new Map;for(let n4=0;n4<t53.problem.routeNet.length;n4++){let o4=t53.problem.routeMetadata?.[n4],i3=o4?.mutuallyConnectedNetworkId??o4?.connectionId;typeof i3=="string"&&e5.set(i3,t53.problem.routeNet[n4])}for(let n4=0;n4<t53.problem.regionNetId.length;n4++){let o4=t53.topology.regionMetadata?.[n4]?._tinyTerminalNetId;if(typeof o4!="string")continue;let i3=e5.get(o4);i3!==void 0&&(t53.problem.regionNetId[n4]=i3)}})(t52),this.configuredSolvers.add(t52))}trySkipOptimizeSection(t52){if(this.getCurrentStageName()!=="optimizeSection")return!1;let e5=this.getStageOutput("solveGraph");return!!e5&&(this.pipelineOutputs.optimizeSection=e5,this.finishWithExistingSolverState({sectionOptimizationSkipped:!0,sectionOptimizationError:t52 instanceof Error?t52.message:String(t52)}),!0)}tryAcceptSolveGraphWithoutSerializedOutput(t52){if(this.getCurrentStageName()!=="solveGraph")return!1;let e5=this.getSolver("solveGraph");return!(!e5?.solved||e5.failed)&&(this.finishWithExistingSolverState({solveGraphSerializationSkipped:!0,sectionOptimizationSkipped:!0,sectionOptimizationError:t52 instanceof Error?t52.message:String(t52)}),!0)}finishWithExistingSolverState(t52){this.currentPipelineStageIndex=this.pipelineDef.length,this.activeSubSolver=null,this.solved=!0,this.failed=!1,this.error=null,this.stats={...this.stats,...t52}}},xw=class extends Ao2{constructor(t52){super();__publicField(this,"params");__publicField(this,"tinyPipelineSolver");__publicField(this,"inputNodeWithPortPoints");__publicField(this,"originalRegionById");__publicField(this,"originalRegionIds");this.params=t52;let e5=(t53=>{let e6=t53.graph.regions.map(t54=>({regionId:t54.regionId,pointIds:t54.ports.map(t55=>t55.d.portId),d:t54.d})),n5=t53.graph.ports.map(t54=>({portId:t54.d.portId,region1Id:t54.region1.regionId,region2Id:t54.region2.regionId,d:t54.d})),o6=t53.connections.map(t54=>({connectionId:t54.connectionId,mutuallyConnectedNetworkId:t54.mutuallyConnectedNetworkId??t54.connectionId,startRegionId:t54.startRegion.regionId,endRegionId:t54.endRegion.regionId,simpleRouteConnection:t54.simpleRouteConnection})),i4=[];for(let o7 of t53.connections){let s4={connectionId:o7.connectionId,mutuallyConnectedNetworkId:o7.mutuallyConnectedNetworkId??o7.connectionId,simpleRouteConnection:o7.simpleRouteConnection},r5=_w(s4,0),a3=_w(s4,1),c4=o7.startRegion.d.availableZ[0]??0,l4=o7.endRegion.d.availableZ[0]??0,h6=yw({routeMetadata:s4,endpointIndex:0,fallbackZ:c4,regionAvailableZ:o7.startRegion.d.availableZ,layerCount:t53.layerCount}),d4=yw({routeMetadata:s4,endpointIndex:1,fallbackZ:l4,regionAvailableZ:o7.endRegion.d.availableZ,layerCount:t53.layerCount}),u5=`tiny-terminal:start-region:${o7.connectionId}`,p4=`tiny-terminal:end-region:${o7.connectionId}`,m4=`tiny-terminal:start-port:${o7.connectionId}`,g6=`tiny-terminal:end-port:${o7.connectionId}`;e6.push({regionId:u5,pointIds:[m4],d:{capacityMeshNodeId:u5,center:{x:r5?.x??o7.startRegion.d.center.x,y:r5?.y??o7.startRegion.d.center.y},width:lw,height:lw,availableZ:[h6],_containsTarget:!0,_tinyTerminal:!0,_tinyTerminalNetId:o7.mutuallyConnectedNetworkId??o7.connectionId}}),e6.push({regionId:p4,pointIds:[g6],d:{capacityMeshNodeId:p4,center:{x:a3?.x??o7.endRegion.d.center.x,y:a3?.y??o7.endRegion.d.center.y},width:lw,height:lw,availableZ:[d4],_containsTarget:!0,_tinyTerminal:!0,_tinyTerminalNetId:o7.mutuallyConnectedNetworkId??o7.connectionId}}),n5.push({portId:m4,region1Id:o7.startRegion.regionId,region2Id:u5,d:{portId:m4,x:r5?.x??o7.startRegion.d.center.x,y:r5?.y??o7.startRegion.d.center.y,z:h6,distToCentermostPortOnZ:0,_tinyTerminal:!0}}),n5.push({portId:g6,region1Id:o7.endRegion.regionId,region2Id:p4,d:{portId:g6,x:a3?.x??o7.endRegion.d.center.x,y:a3?.y??o7.endRegion.d.center.y,z:d4,distToCentermostPortOnZ:0,_tinyTerminal:!0}});let f3=e6.find(t54=>t54.regionId===o7.startRegion.regionId),_4=e6.find(t54=>t54.regionId===o7.endRegion.regionId);f3?.pointIds.push(m4),_4?.pointIds.push(g6),i4.push({connection:{connectionId:o7.connectionId},path:[{portId:m4},{portId:g6}]})}return{regions:e6,ports:n5,connections:o6,solvedRoutes:i4}})(t52),n4=(o4=e5,i3=t52.effort,s3=t52.minViaPadDiameter,{serializedHyperGraph:o4,solveGraphOptions:mw(i3,s3),sectionSolverOptions:gw(i3,s3)});var o4,i3,s3;this.tinyPipelineSolver=new bw2(n4),this.MAX_ITERATIONS=fw2(n4),this.originalRegionById=new Map(t52.graph.regions.map(t53=>[t53.regionId,t53])),this.originalRegionIds=new Set(this.originalRegionById.keys()),this.inputNodeWithPortPoints=t52.graph.regions.map(t53=>({capacityMeshNodeId:t53.d.capacityMeshNodeId,center:t53.d.center,width:t53.d.width,height:t53.d.height,portPoints:t53.ports.map(t54=>{let e6=t54.d.regions.some(t55=>!!t55.d._offBoardConnectionId);return{portPointId:t54.d.portId,x:t54.d.x,y:t54.d.y,z:t54.d.z,connectionNodeIds:t54.d.regions.map(t55=>t55.regionId),distToCentermostPortOnZ:t54.d.distToCentermostPortOnZ,connectsToOffBoardNode:e6}}),availableZ:t53.d.availableZ,_containsObstacle:t53.d._containsObstacle,_containsTarget:t53.d._containsTarget,_offBoardConnectionId:t53.d._offBoardConnectionId,_offBoardConnectedCapacityMeshNodeIds:t53.d._offBoardConnectedCapacityMeshNodeIds}))}getSolverName(){return"TinyHypergraphPortPointPathingSolver"}_step(){try{this.tinyPipelineSolver.step()}catch(t53){throw this.error=`${this.getSolverName()} error: ${t53}`,this.failed=!0,t53}let t52=this.tinyPipelineSolver.getSolver("optimizeSection"),e5=this.getCurrentTinySolver();this.solved=this.tinyPipelineSolver.solved,this.failed=this.tinyPipelineSolver.failed,this.error=this.tinyPipelineSolver.error??null,this.progress=this.tinyPipelineSolver.progress,this.stats={...this.tinyPipelineSolver.stats??{},...e5?.stats??{},...t52?.stats??{},currentStage:this.tinyPipelineSolver.getCurrentStageName(),stageStats:this.tinyPipelineSolver.getStageStats()},this.activeSubSolver=this.tinyPipelineSolver.activeSubSolver??null}preview(){return this.visualize()}getCurrentTinySolver(){let t52=this.tinyPipelineSolver.getSolver("optimizeSection");return t52?.solved&&!t52.failed?t52.getSolvedSolver():this.tinyPipelineSolver.getSolver("solveGraph")||void 0}getSolvedTinySolver(){return this.tinyPipelineSolver.getSolvedTinySolver()}getRouteMetadata(t52,e5){return t52.problem.routeMetadata?.[e5]}createAssignedPortPoint(t52,e5,n4){let o4=this.getRouteMetadata(t52,e5),i3=o4?(t53=>t53.simpleRouteConnection?.name??t53.connectionId)(o4):`route-${e5}`,s3=o4?(t53=>t53.simpleRouteConnection?.rootConnectionName??t53.mutuallyConnectedNetworkId)(o4):void 0,r5=t52.topology.portMetadata?.[n4];return{portPointId:String(r5?.portId??`tiny-port-${n4}`),x:t52.topology.portX[n4],y:t52.topology.portY[n4],z:t52.topology.portZ[n4],connectionName:i3,rootConnectionName:s3}}getOutput(){let t52=this.getSolvedTinySolver(),e5=[],n4=t52.state.regionSegments,o4=t52.topology.regionMetadata??[];for(let i3=0;i3<n4.length;i3++){let s3=o4[i3]?.capacityMeshNodeId;if(!s3||!this.originalRegionIds.has(s3))continue;let r5=this.originalRegionById.get(s3);if(!r5)continue;let a3=n4[i3].flatMap(([e6,n5,o6])=>[this.createAssignedPortPoint(t52,e6,n5),this.createAssignedPortPoint(t52,e6,o6)]);a3.length!==0&&e5.push({capacityMeshNodeId:r5.d.capacityMeshNodeId,center:r5.d.center,width:r5.d.width,height:r5.d.height,portPoints:a3,availableZ:r5.d.availableZ})}return{nodesWithPortPoints:e5,inputNodeWithPortPoints:this.inputNodeWithPortPoints}}computeNodePf(t52){let e5=this.getOutput().nodesWithPortPoints.find(e6=>e6.capacityMeshNodeId===t52.capacityMeshNodeId),n4=this.originalRegionById.get(t52.capacityMeshNodeId);if(!e5||!n4)return null;let o4=Ts2(e5);return Es2(n4.d,o4.numSameLayerCrossings,o4.numEntryExitLayerChanges,o4.numTransitionPairCrossings)}tryFinalAcceptance(){}getConstructorParams(){return[this.params]}visualize(){return this.tinyPipelineSolver.visualize()}},vw={};a(vw,{all_layers:()=>zR,any_circuit_element:()=>AO,any_soup_element:()=>OO,any_source_component:()=>wR2,base_circuit_json_error:()=>Zw,battery_capacity:()=>Fw,brep_shape:()=>SE,cad_component:()=>gO,capacitance:()=>Cw,circuit_json_footprint_load_error:()=>qA,current:()=>Ow,distance:()=>Aw,duration_ms:()=>Lw,experiment_type:()=>MO,external_footprint_load_error:()=>GA,frequency:()=>Ew,getZodPrefixedIdWithDefault:()=>Ww,inductance:()=>Tw,layer_ref:()=>FR2,layer_string:()=>jR,length:()=>Rw,ms:()=>Dw,ninePointAnchor:()=>Vw,pcbRenderLayer:()=>Uw,pcb_autorouting_error:()=>KA,pcb_board:()=>yA,pcb_breakout_point:()=>tO,pcb_component:()=>NE,pcb_component_invalid_layer_error:()=>hO,pcb_component_outside_board_error:()=>lO,pcb_copper_pour:()=>cO,pcb_copper_pour_brep:()=>rO,pcb_copper_pour_polygon:()=>aO,pcb_copper_pour_rect:()=>sO,pcb_copper_text:()=>NA,pcb_courtyard_outline:()=>pO,pcb_courtyard_polygon:()=>mO,pcb_courtyard_rect:()=>uO,pcb_cutout:()=>UA,pcb_cutout_circle:()=>HA,pcb_cutout_path:()=>VA,pcb_cutout_polygon:()=>WA,pcb_cutout_rect:()=>XA,pcb_fabrication_note_dimension:()=>LA,pcb_fabrication_note_path:()=>AA,pcb_fabrication_note_rect:()=>OA,pcb_fabrication_note_text:()=>EA,pcb_footprint_overlap_error:()=>$A,pcb_ground_plane:()=>eO,pcb_ground_plane_region:()=>nO,pcb_group:()=>JA,pcb_hole:()=>FE2,pcb_hole_circle_or_square_shape:()=>AE,pcb_hole_circle_shape:()=>TE2,pcb_hole_oval_shape:()=>LE2,pcb_hole_pill_shape:()=>DE,pcb_hole_rect_shape:()=>RE2,pcb_hole_rotated_pill_shape:()=>jE,pcb_keepout:()=>BA,pcb_manual_edit_conflict_warning:()=>QA,pcb_missing_footprint_error:()=>ZA,pcb_net:()=>fA,pcb_note_dimension:()=>FA,pcb_note_line:()=>jA,pcb_note_path:()=>zA,pcb_note_rect:()=>DA,pcb_note_text:()=>kA,pcb_panel:()=>bA,pcb_panelization_placement_error:()=>vA,pcb_placement_error:()=>xA,pcb_plated_hole:()=>VE,pcb_port:()=>UE,pcb_port_not_connected_error:()=>gA,pcb_port_not_matched_error:()=>mA,pcb_route_hint:()=>IE,pcb_route_hints:()=>PE,pcb_silkscreen_circle:()=>TA,pcb_silkscreen_line:()=>IA,pcb_silkscreen_oval:()=>wA,pcb_silkscreen_path:()=>PA,pcb_silkscreen_pill:()=>RA,pcb_silkscreen_rect:()=>CA,pcb_silkscreen_text:()=>MA,pcb_smtpad:()=>tA,pcb_smtpad_pill:()=>JE,pcb_solder_paste:()=>rA,pcb_text:()=>aA,pcb_thermal_spoke:()=>oO,pcb_trace:()=>dA,pcb_trace_error:()=>uA,pcb_trace_hint:()=>SA,pcb_trace_missing_error:()=>pA,pcb_trace_route_point:()=>hA,pcb_trace_route_point_via:()=>lA,pcb_trace_route_point_wire:()=>cA,pcb_via:()=>_A,pcb_via_clearance_error:()=>dO,point:()=>$w,point3:()=>Yw,point_with_bulge:()=>xE,port_arrangement:()=>GR,position:()=>Bw,position3:()=>Xw,resistance:()=>Nw,ring:()=>vE,rotation:()=>jw,route_hint_point:()=>ME,schematic_arc:()=>eE,schematic_box:()=>HR,schematic_circle:()=>tE,schematic_component:()=>qR,schematic_component_port_arrangement_by_sides:()=>ZR,schematic_component_port_arrangement_by_size:()=>UR,schematic_debug_line:()=>dE,schematic_debug_object:()=>pE,schematic_debug_object_base:()=>lE,schematic_debug_point:()=>uE,schematic_debug_rect:()=>hE,schematic_error:()=>aE,schematic_group:()=>fE,schematic_layout_error:()=>cE,schematic_line:()=>KR,schematic_manual_edit_conflict_warning:()=>gE,schematic_net_label:()=>rE,schematic_path:()=>WR,schematic_pin_styles:()=>VR,schematic_port:()=>sE,schematic_rect:()=>QR,schematic_sheet:()=>bE,schematic_symbol:()=>JR,schematic_table:()=>_E,schematic_table_cell:()=>yE,schematic_text:()=>iE,schematic_trace:()=>nE,schematic_voltage_probe:()=>mE,simulation_ac_current_source:()=>IO,simulation_ac_voltage_source:()=>bO,simulation_current_source:()=>PO,simulation_dc_current_source:()=>SO,simulation_dc_voltage_source:()=>yO,simulation_experiment:()=>NO,simulation_op_amp:()=>EO,simulation_switch:()=>TO,simulation_transient_voltage_graph:()=>CO,simulation_unknown_experiment_error:()=>RO,simulation_voltage_probe:()=>wO,simulation_voltage_source:()=>xO,size:()=>Hw,source_board:()=>kR2,source_component_base:()=>qw,source_component_internal_connection:()=>ER,source_failed_to_create_component_error:()=>SR,source_group:()=>OR,source_interconnect:()=>CR,source_manually_placed_via:()=>BR,source_missing_property_error:()=>vR2,source_net:()=>LR,source_pcb_ground_plane:()=>DR,source_pin_missing_trace_warning:()=>MR,source_pin_must_be_connected_error:()=>YR,source_port:()=>RR,source_project_metadata:()=>xR,source_property_ignored_warning:()=>PR,source_simple_battery:()=>aR,source_simple_capacitor:()=>Jw,source_simple_chip:()=>oR,source_simple_crystal:()=>dR,source_simple_current_source:()=>sR,source_simple_diode:()=>Qw,source_simple_fiducial:()=>tR,source_simple_ground:()=>nR,source_simple_inductor:()=>cR,source_simple_led:()=>eR,source_simple_mosfet:()=>_R,source_simple_op_amp:()=>yR,source_simple_pin_header:()=>uR2,source_simple_pinout:()=>pR,source_simple_potentiometer:()=>hR2,source_simple_power_source:()=>iR,source_simple_push_button:()=>lR,source_simple_resistor:()=>Kw,source_simple_resonator:()=>mR,source_simple_switch:()=>bR,source_simple_test_point:()=>fR,source_simple_transistor:()=>gR2,source_simple_voltage_probe:()=>NR,source_simple_voltage_source:()=>TR,source_trace:()=>AR2,source_trace_not_connected_error:()=>IR,supplier_name:()=>Gw,time:()=>kw,timestamp:()=>zw,unknown_error_finding_part:()=>XR2,visible_layer:()=>$R2,voltage:()=>ww,wave_shape:()=>fO});var Sw={Hz:{baseUnit:"Hz",variants:{MHz:1e6,kHz:1e3,Hz:1}},g:{baseUnit:"g",variants:{kg:1e3,g:1}},\u03A9:{baseUnit:"\u03A9",variants:{m\u03A9:.001,\u03A9:1,k\u03A9:1e3,K\u03A9:1e3,kohm:1e3,M\u03A9:1e6,G\u03A9:1e9,T\u03A9:1e12}},V:{baseUnit:"V",variants:{mV:.001,V:1,kV:1e3,KV:1e3,MV:1e6,GV:1e9,TV:1e12}},A:{baseUnit:"A",variants:{\u00B5A:1e-6,mA:.001,ma:.001,A:1,kA:1e3,MA:1e6}},F:{baseUnit:"F",variants:{pF:1e-12,nF:1e-9,\u00B5F:1e-6,uF:1e-6,mF:.001,F:1}},ml:{baseUnit:"ml",variants:{ml:1,mL:1,l:1e3,L:1e3}},deg:{baseUnit:"deg",variants:{rad:180/Math.PI}},ms:{baseUnit:"ms",variants:{fs:1e-12,ps:1e-9,ns:1e-6,us:.001,\u00B5s:.001,ms:1,s:1e3}},mm:{baseUnit:"mm",variants:{nm:1e-6,\u00B5m:.001,um:.001,mm:1,cm:10,dm:100,m:1e3,km:1e6,in:25.4,ft:304.8,IN:25.4,FT:304.8,yd:914.4,mi:1609344,mil:.0254}}},Iw=new Set;for(let[t52,e5]of Object.entries(Sw)){Iw.add(t52);for(let t53 of Object.keys(e5.variants))Iw.add(t53)}var Pw={tera:1e12,T:1e12,giga:1e9,G:1e9,mega:1e6,M:1e6,kilo:1e3,k:1e3,deci:.1,d:.1,centi:.01,c:.01,milli:.001,m:.001,micro:1e-6,u:1e-6,\u00B5:1e-6,nano:1e-9,n:1e-9,pico:1e-12,p:1e-12};function Mw(t52){if(t52==null)return{parsedUnit:null,unitOfValue:null,value:null};if(typeof t52=="string"&&t52.match(/^-?[\d\.]+$/))return{value:Number.parseFloat(t52),parsedUnit:null,unitOfValue:null};if(typeof t52=="number")return{value:t52,parsedUnit:null,unitOfValue:null};if(typeof t52=="object"&&"x"in t52&&"y"in t52){let{parsedUnit:e6,unitOfValue:n5}=Mw(t52.x),o6=Mw(t52.x),i4=Mw(t52.y);return o6.value===null||i4.value===null?{parsedUnit:null,unitOfValue:null,value:null}:{parsedUnit:e6,unitOfValue:n5,value:{x:o6.value,y:i4.value}}}let e5=t52.toString().split("").reverse().join(""),n4=e5.match(/[^\d\s]+/)?.[0];if(!n4)throw new Error(`Could not determine unit: "${t52}"`);let o4=n4.split("").reverse().join(""),i3=t52.slice(0,-o4.length);if(o4 in Pw&&!Iw.has(o4)){let t53=Pw[o4];return{parsedUnit:null,unitOfValue:null,value:Number.parseFloat(i3)*t53}}let{baseUnit:s3,conversionFactor:r5}=(function(t53){for(let[e6,n5]of Object.entries(Sw))if(t53 in n5.variants)return{baseUnit:n5.baseUnit,conversionFactor:n5.variants[t53]};return{baseUnit:t53,conversionFactor:1}})(o4);return{parsedUnit:o4,unitOfValue:s3,value:r5*Number.parseFloat(i3)}}var Nw=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value),Cw=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value).transform(t52=>Number.parseFloat(t52.toPrecision(12))),Tw=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value),ww=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value),Rw=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value),Ew=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value),Aw=Rw,Ow=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value),Lw=Zm2.string().or(Zm2.number()).transform(t52=>Mw(t52).value),kw=Lw,Dw=Lw,zw=Zm2.string().datetime(),jw=Zm2.string().or(Zm2.number()).transform(t52=>typeof t52=="number"?t52:t52.endsWith("deg")?Number.parseFloat(t52.split("deg")[0]):t52.endsWith("rad")?180*Number.parseFloat(t52.split("rad")[0])/Math.PI:Number.parseFloat(t52)),Fw=Zm2.number().or(Zm2.string().endsWith("mAh")).transform(t52=>{if(typeof t52=="string"){let e5=t52.replace("mAh",""),n4=Number.parseFloat(e5);if(Number.isNaN(n4))throw new Error("Invalid capacity");return n4}return t52}).describe("Battery capacity in mAh"),$w=Zm2.object({x:Aw,y:Aw}),Bw=$w,Yw=Zm2.object({x:Aw,y:Aw,z:Aw}),Xw=Yw,Hw=Zm2.object({width:Zm2.number(),height:Zm2.number()}),Ww=t52=>Zm2.string().optional().default(()=>`${t52}_${(t53=>{let e5="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";return Array.from({length:t53},()=>e5[Math.floor(62*Math.random())]).join("")})(10)}`),Vw=Zm2.enum(["top_left","top_center","top_right","center_left","center","center_right","bottom_left","bottom_center","bottom_right"]),Uw=Zm2.enum(["top_silkscreen","bottom_silkscreen","top_copper","bottom_copper","top_soldermask","bottom_soldermask","top_fabrication_note","bottom_fabrication_note","top_user_note","bottom_user_note","inner1_copper","inner2_copper","inner3_copper","inner4_copper","inner5_copper","inner6_copper","edge_cuts","drill"]),Zw=Zm2.object({error_type:Zm2.string(),message:Zm2.string(),is_fatal:Zm2.boolean().optional()}),Gw=Zm2.enum(["jlcpcb","macrofab","pcbway","digikey","mouser","lcsc"]),qw=Zm2.object({type:Zm2.literal("source_component"),ftype:Zm2.string().optional(),source_component_id:Zm2.string(),name:Zm2.string(),manufacturer_part_number:Zm2.string().optional(),supplier_part_numbers:Zm2.record(Gw,Zm2.array(Zm2.string())).optional(),display_value:Zm2.string().optional(),display_name:Zm2.string().optional(),are_pins_interchangeable:Zm2.boolean().optional(),internally_connected_source_port_ids:Zm2.array(Zm2.array(Zm2.string())).optional(),source_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}),Jw=qw.extend({ftype:Zm2.literal("simple_capacitor"),capacitance:Cw,max_voltage_rating:ww.optional(),display_capacitance:Zm2.string().optional(),max_decoupling_trace_length:Aw.optional()}),Kw=qw.extend({ftype:Zm2.literal("simple_resistor"),resistance:Nw,display_resistance:Zm2.string().optional()}),Qw=qw.extend({ftype:Zm2.literal("simple_diode")}),tR=qw.extend({ftype:Zm2.literal("simple_fiducial")}),eR=Qw.extend({ftype:Zm2.literal("simple_led"),color:Zm2.string().optional(),wavelength:Zm2.string().optional()}),nR=qw.extend({ftype:Zm2.literal("simple_ground")}),oR=qw.extend({ftype:Zm2.literal("simple_chip")}),iR=qw.extend({ftype:Zm2.literal("simple_power_source"),voltage:ww}),sR=qw.extend({ftype:Zm2.literal("simple_current_source"),current:Ow,frequency:Ew.optional(),peak_to_peak_current:Ow.optional(),wave_shape:Zm2.enum(["sine","square","triangle","sawtooth","dc"]).optional().default("dc"),phase:Zm2.number().optional(),duty_cycle:Zm2.number().min(0).max(1).optional()}),rR=qw.extend({ftype:Zm2.literal("simple_fuse"),current_rating_amps:Zm2.number().describe("Nominal current in amps the fuse is rated for"),voltage_rating_volts:Zm2.number().describe("Voltage rating in volts, e.g. \xB15V would be 5")}),aR=qw.extend({ftype:Zm2.literal("simple_battery"),capacity:Fw}),cR=qw.extend({ftype:Zm2.literal("simple_inductor"),inductance:Tw,max_current_rating:Zm2.number().optional()}),lR=qw.extend({ftype:Zm2.literal("simple_push_button")}),hR2=qw.extend({ftype:Zm2.literal("simple_potentiometer"),max_resistance:Nw}),dR=qw.extend({ftype:Zm2.literal("simple_crystal"),frequency:Zm2.number().describe("Frequency in Hz"),load_capacitance:Zm2.number().optional().describe("Load capacitance in pF"),pin_variant:Zm2.enum(["two_pin","four_pin"]).optional()}),uR2=qw.extend({ftype:Zm2.literal("simple_pin_header"),pin_count:Zm2.number(),gender:Zm2.enum(["male","female"]).optional().default("male")}),pR=qw.extend({ftype:Zm2.literal("simple_pinout")}),mR=qw.extend({ftype:Zm2.literal("simple_resonator"),load_capacitance:Cw,equivalent_series_resistance:Nw.optional(),frequency:Ew}),gR2=qw.extend({ftype:Zm2.literal("simple_transistor"),transistor_type:Zm2.enum(["npn","pnp"])}),fR=qw.extend({ftype:Zm2.literal("simple_test_point"),footprint_variant:Zm2.enum(["pad","through_hole"]).optional(),pad_shape:Zm2.enum(["rect","circle"]).optional(),pad_diameter:Zm2.union([Zm2.number(),Zm2.string()]).optional(),hole_diameter:Zm2.union([Zm2.number(),Zm2.string()]).optional(),width:Zm2.union([Zm2.number(),Zm2.string()]).optional(),height:Zm2.union([Zm2.number(),Zm2.string()]).optional()}),_R=qw.extend({ftype:Zm2.literal("simple_mosfet"),channel_type:Zm2.enum(["n","p"]),mosfet_mode:Zm2.enum(["enhancement","depletion"])}),yR=qw.extend({ftype:Zm2.literal("simple_op_amp")}),bR=qw.extend({ftype:Zm2.literal("simple_switch")}),xR=Zm2.object({type:Zm2.literal("source_project_metadata"),name:Zm2.string().optional(),software_used_string:Zm2.string().optional(),project_url:Zm2.string().optional(),created_at:zw.optional()}),vR2=Zw.extend({type:Zm2.literal("source_missing_property_error"),source_missing_property_error_id:Ww("source_missing_property_error"),source_component_id:Zm2.string(),property_name:Zm2.string(),subcircuit_id:Zm2.string().optional(),error_type:Zm2.literal("source_missing_property_error").default("source_missing_property_error")}).describe("The source code is missing a property"),SR=Zw.extend({type:Zm2.literal("source_failed_to_create_component_error"),source_failed_to_create_component_error_id:Ww("source_failed_to_create_component_error"),error_type:Zm2.literal("source_failed_to_create_component_error").default("source_failed_to_create_component_error"),component_name:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),parent_source_component_id:Zm2.string().optional(),pcb_center:Zm2.object({x:Zm2.number().optional(),y:Zm2.number().optional()}).optional(),schematic_center:Zm2.object({x:Zm2.number().optional(),y:Zm2.number().optional()}).optional()}).describe("Error emitted when a component fails to be constructed"),IR=Zw.extend({type:Zm2.literal("source_trace_not_connected_error"),source_trace_not_connected_error_id:Ww("source_trace_not_connected_error"),error_type:Zm2.literal("source_trace_not_connected_error").default("source_trace_not_connected_error"),subcircuit_id:Zm2.string().optional(),source_group_id:Zm2.string().optional(),source_trace_id:Zm2.string().optional(),connected_source_port_ids:Zm2.array(Zm2.string()).optional(),selectors_not_found:Zm2.array(Zm2.string()).optional()}).describe("Occurs when a source trace selector does not match any ports"),PR=Zm2.object({type:Zm2.literal("source_property_ignored_warning"),source_property_ignored_warning_id:Ww("source_property_ignored_warning"),source_component_id:Zm2.string(),property_name:Zm2.string(),subcircuit_id:Zm2.string().optional(),error_type:Zm2.literal("source_property_ignored_warning").default("source_property_ignored_warning"),message:Zm2.string()}).describe("The source property was ignored"),MR=Zm2.object({type:Zm2.literal("source_pin_missing_trace_warning"),source_pin_missing_trace_warning_id:Ww("source_pin_missing_trace_warning"),warning_type:Zm2.literal("source_pin_missing_trace_warning").default("source_pin_missing_trace_warning"),message:Zm2.string(),source_component_id:Zm2.string(),source_port_id:Zm2.string(),subcircuit_id:Zm2.string().optional()}).describe("Warning emitted when a source component pin is missing a trace connection"),NR=qw.extend({ftype:Zm2.literal("simple_voltage_probe")}),CR=qw.extend({ftype:Zm2.literal("interconnect")}),TR=qw.extend({ftype:Zm2.literal("simple_voltage_source"),voltage:ww,frequency:Ew.optional(),peak_to_peak_voltage:ww.optional(),wave_shape:Zm2.enum(["sinewave","square","triangle","sawtooth"]).optional(),phase:jw.optional(),duty_cycle:Zm2.number().optional().describe("Duty cycle as a fraction (0 to 1)")}),wR2=Zm2.union([Kw,Jw,Qw,tR,eR,nR,oR,iR,sR,aR,cR,lR,hR2,dR,uR2,pR,mR,bR,gR2,fR,_R,yR,rR,NR,CR,TR,xR,vR2,SR,IR,PR,MR]),RR=Zm2.object({type:Zm2.literal("source_port"),pin_number:Zm2.number().optional(),port_hints:Zm2.array(Zm2.string()).optional(),name:Zm2.string(),source_port_id:Zm2.string(),source_component_id:Zm2.string().optional(),source_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),subcircuit_connectivity_map_key:Zm2.string().optional(),must_be_connected:Zm2.boolean().optional()}),ER=Zm2.object({type:Zm2.literal("source_component_internal_connection"),source_component_internal_connection_id:Zm2.string(),source_component_id:Zm2.string(),source_port_ids:Zm2.array(Zm2.string()),subcircuit_id:Zm2.string().optional()}),AR2=Zm2.object({type:Zm2.literal("source_trace"),source_trace_id:Zm2.string(),connected_source_port_ids:Zm2.array(Zm2.string()),connected_source_net_ids:Zm2.array(Zm2.string()),subcircuit_id:Zm2.string().optional(),subcircuit_connectivity_map_key:Zm2.string().optional(),max_length:Zm2.number().optional(),min_trace_thickness:Zm2.number().optional(),display_name:Zm2.string().optional()}),OR=Zm2.object({type:Zm2.literal("source_group"),source_group_id:Zm2.string(),subcircuit_id:Zm2.string().optional(),parent_subcircuit_id:Zm2.string().optional(),parent_source_group_id:Zm2.string().optional(),is_subcircuit:Zm2.boolean().optional(),show_as_schematic_box:Zm2.boolean().optional(),name:Zm2.string().optional(),was_automatically_named:Zm2.boolean().optional()}),LR=Zm2.object({type:Zm2.literal("source_net"),source_net_id:Zm2.string(),name:Zm2.string(),member_source_group_ids:Zm2.array(Zm2.string()),is_power:Zm2.boolean().optional(),is_ground:Zm2.boolean().optional(),is_digital_signal:Zm2.boolean().optional(),is_analog_signal:Zm2.boolean().optional(),is_positive_voltage_source:Zm2.boolean().optional(),trace_width:Zm2.number().optional(),subcircuit_id:Zm2.string().optional(),subcircuit_connectivity_map_key:Zm2.string().optional()}),kR2=Zm2.object({type:Zm2.literal("source_board"),source_board_id:Zm2.string(),source_group_id:Zm2.string(),title:Zm2.string().optional()}).describe("Defines a board in the source domain"),DR=Zm2.object({type:Zm2.literal("source_pcb_ground_plane"),source_pcb_ground_plane_id:Zm2.string(),source_group_id:Zm2.string(),source_net_id:Zm2.string(),subcircuit_id:Zm2.string().optional()}).describe("Defines a ground plane in the source domain"),zR=["top","bottom","inner1","inner2","inner3","inner4","inner5","inner6"],jR=Zm2.enum(zR),FR2=jR.or(Zm2.object({name:jR})).transform(t52=>typeof t52=="string"?t52:t52.name),$R2=Zm2.enum(["top","bottom"]),BR=Zm2.object({type:Zm2.literal("source_manually_placed_via"),source_manually_placed_via_id:Zm2.string(),source_group_id:Zm2.string(),source_net_id:Zm2.string(),subcircuit_id:Zm2.string().optional(),source_trace_id:Zm2.string().optional()}).describe("Defines a via that is manually placed in the source domain"),YR=Zw.extend({type:Zm2.literal("source_pin_must_be_connected_error"),source_pin_must_be_connected_error_id:Ww("source_pin_must_be_connected_error"),error_type:Zm2.literal("source_pin_must_be_connected_error").default("source_pin_must_be_connected_error"),source_component_id:Zm2.string(),source_port_id:Zm2.string(),subcircuit_id:Zm2.string().optional()}).describe("Error emitted when a pin with mustBeConnected attribute is not connected to any trace"),XR2=Zw.extend({type:Zm2.literal("unknown_error_finding_part"),unknown_error_finding_part_id:Ww("unknown_error_finding_part"),error_type:Zm2.literal("unknown_error_finding_part").default("unknown_error_finding_part"),source_component_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}).describe("Error emitted when an unexpected error occurs while finding a part"),HR=Zm2.object({type:Zm2.literal("schematic_box"),schematic_component_id:Zm2.string().optional(),schematic_symbol_id:Zm2.string().optional(),width:Aw,height:Aw,is_dashed:Zm2.boolean().default(!1),x:Aw,y:Aw,subcircuit_id:Zm2.string().optional()}).describe("Draws a box on the schematic"),WR=Zm2.object({type:Zm2.literal("schematic_path"),schematic_path_id:Ww("schematic_path"),schematic_component_id:Zm2.string().optional(),schematic_symbol_id:Zm2.string().optional(),fill_color:Zm2.enum(["red","blue"]).optional(),is_filled:Zm2.boolean().optional(),stroke_width:Aw.nullable().optional(),stroke_color:Zm2.string().optional(),points:Zm2.array($w),subcircuit_id:Zm2.string().optional()}),VR=Zm2.record(Zm2.object({left_margin:Rw.optional(),right_margin:Rw.optional(),top_margin:Rw.optional(),bottom_margin:Rw.optional()})),UR=Zm2.object({left_size:Zm2.number(),right_size:Zm2.number(),top_size:Zm2.number().optional(),bottom_size:Zm2.number().optional()}),ZR=Zm2.object({left_side:Zm2.object({pins:Zm2.array(Zm2.number()),direction:Zm2.enum(["top-to-bottom","bottom-to-top"]).optional()}).optional(),right_side:Zm2.object({pins:Zm2.array(Zm2.number()),direction:Zm2.enum(["top-to-bottom","bottom-to-top"]).optional()}).optional(),top_side:Zm2.object({pins:Zm2.array(Zm2.number()),direction:Zm2.enum(["left-to-right","right-to-left"]).optional()}).optional(),bottom_side:Zm2.object({pins:Zm2.array(Zm2.number()),direction:Zm2.enum(["left-to-right","right-to-left"]).optional()}).optional()}),GR=Zm2.union([UR,ZR]),qR=Zm2.object({type:Zm2.literal("schematic_component"),size:Hw,center:$w,source_component_id:Zm2.string().optional(),schematic_component_id:Zm2.string(),schematic_symbol_id:Zm2.string().optional(),pin_spacing:Rw.optional(),pin_styles:VR.optional(),box_width:Rw.optional(),symbol_name:Zm2.string().optional(),port_arrangement:GR.optional(),port_labels:Zm2.record(Zm2.string()).optional(),symbol_display_value:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),schematic_group_id:Zm2.string().optional(),is_schematic_group:Zm2.boolean().optional(),source_group_id:Zm2.string().optional(),is_box_with_pins:Zm2.boolean().optional().default(!0)}),JR=Zm2.object({type:Zm2.literal("schematic_symbol"),schematic_symbol_id:Zm2.string(),name:Zm2.string().optional()}).describe("Defines a named schematic symbol that can be referenced by components."),KR=Zm2.object({type:Zm2.literal("schematic_line"),schematic_line_id:Ww("schematic_line"),schematic_component_id:Zm2.string().optional(),schematic_symbol_id:Zm2.string().optional(),x1:Aw,y1:Aw,x2:Aw,y2:Aw,stroke_width:Aw.nullable().optional(),color:Zm2.string().default("#000000"),is_dashed:Zm2.boolean().default(!1),subcircuit_id:Zm2.string().optional()}).describe("Draws a styled line on the schematic"),QR=Zm2.object({type:Zm2.literal("schematic_rect"),schematic_rect_id:Ww("schematic_rect"),schematic_component_id:Zm2.string().optional(),schematic_symbol_id:Zm2.string().optional(),center:$w,width:Aw,height:Aw,rotation:jw.default(0),stroke_width:Aw.nullable().optional(),color:Zm2.string().default("#000000"),is_filled:Zm2.boolean().default(!1),fill_color:Zm2.string().optional(),is_dashed:Zm2.boolean().default(!1),subcircuit_id:Zm2.string().optional()}).describe("Draws a styled rectangle on the schematic"),tE=Zm2.object({type:Zm2.literal("schematic_circle"),schematic_circle_id:Ww("schematic_circle"),schematic_component_id:Zm2.string().optional(),schematic_symbol_id:Zm2.string().optional(),center:$w,radius:Aw,stroke_width:Aw.nullable().optional(),color:Zm2.string().default("#000000"),is_filled:Zm2.boolean().default(!1),fill_color:Zm2.string().optional(),is_dashed:Zm2.boolean().default(!1),subcircuit_id:Zm2.string().optional()}).describe("Draws a styled circle on the schematic"),eE=Zm2.object({type:Zm2.literal("schematic_arc"),schematic_arc_id:Ww("schematic_arc"),schematic_component_id:Zm2.string().optional(),schematic_symbol_id:Zm2.string().optional(),center:$w,radius:Aw,start_angle_degrees:jw,end_angle_degrees:jw,direction:Zm2.enum(["clockwise","counterclockwise"]).default("counterclockwise"),stroke_width:Aw.nullable().optional(),color:Zm2.string().default("#000000"),is_dashed:Zm2.boolean().default(!1),subcircuit_id:Zm2.string().optional()}).describe("Draws a styled arc on the schematic"),nE=Zm2.object({type:Zm2.literal("schematic_trace"),schematic_trace_id:Zm2.string(),source_trace_id:Zm2.string().optional(),junctions:Zm2.array(Zm2.object({x:Zm2.number(),y:Zm2.number()})),edges:Zm2.array(Zm2.object({from:Zm2.object({x:Zm2.number(),y:Zm2.number()}),to:Zm2.object({x:Zm2.number(),y:Zm2.number()}),is_crossing:Zm2.boolean().optional(),from_schematic_port_id:Zm2.string().optional(),to_schematic_port_id:Zm2.string().optional()})),subcircuit_id:Zm2.string().optional(),subcircuit_connectivity_map_key:Zm2.string().optional()}),oE=Zm2.enum(["center","left","right","top","bottom"]),iE=Zm2.object({type:Zm2.literal("schematic_text"),schematic_component_id:Zm2.string().optional(),schematic_symbol_id:Zm2.string().optional(),schematic_text_id:Zm2.string(),text:Zm2.string(),font_size:Zm2.number().default(.18),position:Zm2.object({x:Aw,y:Aw}),rotation:Zm2.number().default(0),anchor:Zm2.union([oE.describe("legacy"),Vw]).default("center"),color:Zm2.string().default("#000000"),subcircuit_id:Zm2.string().optional()}),sE=Zm2.object({type:Zm2.literal("schematic_port"),schematic_port_id:Zm2.string(),source_port_id:Zm2.string(),schematic_component_id:Zm2.string().optional(),center:$w,facing_direction:Zm2.enum(["up","down","left","right"]).optional(),distance_from_component_edge:Zm2.number().optional(),side_of_component:Zm2.enum(["top","bottom","left","right"]).optional(),true_ccw_index:Zm2.number().optional(),pin_number:Zm2.number().optional(),display_pin_label:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),is_connected:Zm2.boolean().optional(),has_input_arrow:Zm2.boolean().optional(),has_output_arrow:Zm2.boolean().optional(),is_drawn_with_inversion_circle:Zm2.boolean().optional()}).describe("Defines a port on a schematic component"),rE=Zm2.object({type:Zm2.literal("schematic_net_label"),schematic_net_label_id:Ww("schematic_net_label"),schematic_trace_id:Zm2.string().optional(),source_trace_id:Zm2.string().optional(),source_net_id:Zm2.string(),center:$w,anchor_position:$w.optional(),anchor_side:Zm2.enum(["top","bottom","left","right"]),text:Zm2.string(),symbol_name:Zm2.string().optional(),is_movable:Zm2.boolean().optional(),subcircuit_id:Zm2.string().optional()}),aE=Zw.extend({type:Zm2.literal("schematic_error"),schematic_error_id:Zm2.string(),error_type:Zm2.literal("schematic_port_not_found").default("schematic_port_not_found"),subcircuit_id:Zm2.string().optional()}).describe("Defines a schematic error on the schematic"),cE=Zw.extend({type:Zm2.literal("schematic_layout_error"),schematic_layout_error_id:Ww("schematic_layout_error"),error_type:Zm2.literal("schematic_layout_error").default("schematic_layout_error"),source_group_id:Zm2.string(),schematic_group_id:Zm2.string(),subcircuit_id:Zm2.string().optional()}).describe("Error emitted when schematic layout fails for a group"),lE=Zm2.object({type:Zm2.literal("schematic_debug_object"),label:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}),hE=lE.extend({shape:Zm2.literal("rect"),center:$w,size:Hw}),dE=lE.extend({shape:Zm2.literal("line"),start:$w,end:$w}),uE=lE.extend({shape:Zm2.literal("point"),center:$w}),pE=Zm2.discriminatedUnion("shape",[hE,dE,uE]),mE=Zm2.object({type:Zm2.literal("schematic_voltage_probe"),schematic_voltage_probe_id:Zm2.string(),source_component_id:Zm2.string().optional(),name:Zm2.string().optional(),position:$w,schematic_trace_id:Zm2.string(),voltage:ww.optional(),subcircuit_id:Zm2.string().optional(),color:Zm2.string().optional(),label_alignment:Vw.optional()}).describe("Defines a voltage probe measurement point on a schematic trace"),gE=Zm2.object({type:Zm2.literal("schematic_manual_edit_conflict_warning"),schematic_manual_edit_conflict_warning_id:Ww("schematic_manual_edit_conflict_warning"),warning_type:Zm2.literal("schematic_manual_edit_conflict_warning").default("schematic_manual_edit_conflict_warning"),message:Zm2.string(),schematic_component_id:Zm2.string(),schematic_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),source_component_id:Zm2.string()}).describe("Warning emitted when a component has both manual placement and explicit schX/schY coordinates"),fE=Zm2.object({type:Zm2.literal("schematic_group"),schematic_group_id:Ww("schematic_group"),source_group_id:Zm2.string(),is_subcircuit:Zm2.boolean().optional(),subcircuit_id:Zm2.string().optional(),width:Rw,height:Rw,center:$w,schematic_component_ids:Zm2.array(Zm2.string()),show_as_schematic_box:Zm2.boolean().optional(),name:Zm2.string().optional(),description:Zm2.string().optional()}).describe("Defines a group of components on the schematic"),_E=Zm2.object({type:Zm2.literal("schematic_table"),schematic_table_id:Ww("schematic_table"),anchor_position:$w,column_widths:Zm2.array(Aw),row_heights:Zm2.array(Aw),cell_padding:Aw.optional(),border_width:Aw.optional(),subcircuit_id:Zm2.string().optional(),schematic_component_id:Zm2.string().optional(),anchor:Vw.optional()}).describe("Defines a table on the schematic"),yE=Zm2.object({type:Zm2.literal("schematic_table_cell"),schematic_table_cell_id:Ww("schematic_table_cell"),schematic_table_id:Zm2.string(),start_row_index:Zm2.number(),end_row_index:Zm2.number(),start_column_index:Zm2.number(),end_column_index:Zm2.number(),text:Zm2.string().optional(),center:$w,width:Aw,height:Aw,horizontal_align:Zm2.enum(["left","center","right"]).optional(),vertical_align:Zm2.enum(["top","middle","bottom"]).optional(),font_size:Aw.optional(),subcircuit_id:Zm2.string().optional()}).describe("Defines a cell within a schematic_table"),bE=Zm2.object({type:Zm2.literal("schematic_sheet"),schematic_sheet_id:Ww("schematic_sheet"),name:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}).describe("Defines a schematic sheet or page that components can be placed on"),xE=Zm2.object({x:Aw,y:Aw,bulge:Zm2.number().optional()}),vE=Zm2.object({vertices:Zm2.array(xE)}),SE=Zm2.object({outer_ring:vE,inner_rings:Zm2.array(vE).default([])}),IE=Zm2.object({x:Aw,y:Aw,via:Zm2.boolean().optional(),via_to_layer:FR2.optional()}),PE=Zm2.array(IE),ME=Zm2.object({x:Aw,y:Aw,via:Zm2.boolean().optional(),to_layer:FR2.optional(),trace_width:Aw.optional()}),NE=Zm2.object({type:Zm2.literal("pcb_component"),pcb_component_id:Ww("pcb_component"),source_component_id:Zm2.string(),center:$w,layer:FR2,rotation:jw,display_offset_x:Zm2.string().optional().describe("How to display the x offset for this part, usually corresponding with how the user specified it"),display_offset_y:Zm2.string().optional().describe("How to display the y offset for this part, usually corresponding with how the user specified it"),width:Rw,height:Rw,do_not_place:Zm2.boolean().optional(),subcircuit_id:Zm2.string().optional(),pcb_group_id:Zm2.string().optional(),position_mode:Zm2.enum(["packed","relative_to_group_anchor","none"]).optional(),positioned_relative_to_pcb_group_id:Zm2.string().optional(),positioned_relative_to_pcb_board_id:Zm2.string().optional(),obstructs_within_bounds:Zm2.boolean().default(!0).describe("Does this component take up all the space within its bounds on a layer. This is generally true except for when separated pin headers are being represented by a single component (in which case, chips can be placed between the pin headers) or for tall modules where chips fit underneath")}).describe("Defines a component on the PCB"),CE=Zm2.object({type:Zm2.literal("pcb_hole"),pcb_hole_id:Ww("pcb_hole"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),pcb_component_id:Zm2.string().optional(),hole_shape:Zm2.literal("circle"),hole_diameter:Zm2.number(),x:Aw,y:Aw,is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),TE2=CE.describe("Defines a circular hole on the PCB"),wE=Zm2.object({type:Zm2.literal("pcb_hole"),pcb_hole_id:Ww("pcb_hole"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),pcb_component_id:Zm2.string().optional(),hole_shape:Zm2.literal("rect"),hole_width:Zm2.number(),hole_height:Zm2.number(),x:Aw,y:Aw,is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),RE2=wE.describe("Defines a rectangular (square-capable) hole on the PCB. Use equal width/height for square."),EE2=Zm2.object({type:Zm2.literal("pcb_hole"),pcb_hole_id:Ww("pcb_hole"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),pcb_component_id:Zm2.string().optional(),hole_shape:Zm2.enum(["circle","square"]),hole_diameter:Zm2.number(),x:Aw,y:Aw,is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),AE=EE2.describe("Defines a circular or square hole on the PCB"),OE=Zm2.object({type:Zm2.literal("pcb_hole"),pcb_hole_id:Ww("pcb_hole"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),pcb_component_id:Zm2.string().optional(),hole_shape:Zm2.literal("oval"),hole_width:Zm2.number(),hole_height:Zm2.number(),x:Aw,y:Aw,is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),LE2=OE.describe("Defines an oval hole on the PCB"),kE=Zm2.object({type:Zm2.literal("pcb_hole"),pcb_hole_id:Ww("pcb_hole"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),pcb_component_id:Zm2.string().optional(),hole_shape:Zm2.literal("pill"),hole_width:Zm2.number(),hole_height:Zm2.number(),x:Aw,y:Aw,is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),DE=kE.describe("Defines a pill-shaped hole on the PCB"),zE=Zm2.object({type:Zm2.literal("pcb_hole"),pcb_hole_id:Ww("pcb_hole"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),pcb_component_id:Zm2.string().optional(),hole_shape:Zm2.literal("rotated_pill"),hole_width:Zm2.number(),hole_height:Zm2.number(),x:Aw,y:Aw,ccw_rotation:jw,is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),jE=zE.describe("Defines a rotated pill-shaped hole on the PCB"),FE2=EE2.or(OE).or(kE).or(zE).or(CE).or(wE),$E=Zm2.object({type:Zm2.literal("pcb_plated_hole"),shape:Zm2.literal("circle"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),outer_diameter:Zm2.number(),hole_diameter:Zm2.number(),is_covered_with_solder_mask:Zm2.boolean().optional(),x:Aw,y:Aw,layers:Zm2.array(FR2),port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),pcb_plated_hole_id:Ww("pcb_plated_hole"),soldermask_margin:Zm2.number().optional()}),BE=Zm2.object({type:Zm2.literal("pcb_plated_hole"),shape:Zm2.enum(["oval","pill"]),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),outer_width:Zm2.number(),outer_height:Zm2.number(),hole_width:Zm2.number(),hole_height:Zm2.number(),is_covered_with_solder_mask:Zm2.boolean().optional(),x:Aw,y:Aw,ccw_rotation:jw,layers:Zm2.array(FR2),port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),pcb_plated_hole_id:Ww("pcb_plated_hole"),soldermask_margin:Zm2.number().optional()}),YE2=Zm2.object({type:Zm2.literal("pcb_plated_hole"),shape:Zm2.literal("circular_hole_with_rect_pad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),hole_shape:Zm2.literal("circle"),pad_shape:Zm2.literal("rect"),hole_diameter:Zm2.number(),rect_pad_width:Zm2.number(),rect_pad_height:Zm2.number(),rect_border_radius:Zm2.number().optional(),hole_offset_x:Aw.default(0),hole_offset_y:Aw.default(0),is_covered_with_solder_mask:Zm2.boolean().optional(),x:Aw,y:Aw,layers:Zm2.array(FR2),port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),pcb_plated_hole_id:Ww("pcb_plated_hole"),soldermask_margin:Zm2.number().optional()}),XE=Zm2.object({type:Zm2.literal("pcb_plated_hole"),shape:Zm2.literal("pill_hole_with_rect_pad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),hole_shape:Zm2.literal("pill"),pad_shape:Zm2.literal("rect"),hole_width:Zm2.number(),hole_height:Zm2.number(),rect_pad_width:Zm2.number(),rect_pad_height:Zm2.number(),rect_border_radius:Zm2.number().optional(),hole_offset_x:Aw.default(0),hole_offset_y:Aw.default(0),is_covered_with_solder_mask:Zm2.boolean().optional(),x:Aw,y:Aw,layers:Zm2.array(FR2),port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),pcb_plated_hole_id:Ww("pcb_plated_hole"),soldermask_margin:Zm2.number().optional()}),HE=Zm2.object({type:Zm2.literal("pcb_plated_hole"),shape:Zm2.literal("rotated_pill_hole_with_rect_pad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),hole_shape:Zm2.literal("rotated_pill"),pad_shape:Zm2.literal("rect"),hole_width:Zm2.number(),hole_height:Zm2.number(),hole_ccw_rotation:jw,rect_pad_width:Zm2.number(),rect_pad_height:Zm2.number(),rect_border_radius:Zm2.number().optional(),rect_ccw_rotation:jw,hole_offset_x:Aw.default(0),hole_offset_y:Aw.default(0),is_covered_with_solder_mask:Zm2.boolean().optional(),x:Aw,y:Aw,layers:Zm2.array(FR2),port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),pcb_plated_hole_id:Ww("pcb_plated_hole"),soldermask_margin:Zm2.number().optional()}),WE=Zm2.object({type:Zm2.literal("pcb_plated_hole"),shape:Zm2.literal("hole_with_polygon_pad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),hole_shape:Zm2.enum(["circle","oval","pill","rotated_pill"]),hole_diameter:Zm2.number().optional(),hole_width:Zm2.number().optional(),hole_height:Zm2.number().optional(),pad_outline:Zm2.array(Zm2.object({x:Aw,y:Aw})).min(3),hole_offset_x:Aw.default(0),hole_offset_y:Aw.default(0),is_covered_with_solder_mask:Zm2.boolean().optional(),x:Aw,y:Aw,layers:Zm2.array(FR2),port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),pcb_plated_hole_id:Ww("pcb_plated_hole"),soldermask_margin:Zm2.number().optional(),ccw_rotation:jw.optional()}),VE=Zm2.union([$E,BE,YE2,XE,HE,WE]),UE=Zm2.object({type:Zm2.literal("pcb_port"),pcb_port_id:Ww("pcb_port"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),source_port_id:Zm2.string(),pcb_component_id:Zm2.string().optional(),x:Aw,y:Aw,layers:Zm2.array(FR2),is_board_pinout:Zm2.boolean().optional()}).describe("Defines a port on the PCB"),ZE=Zm2.object({type:Zm2.literal("pcb_smtpad"),shape:Zm2.literal("circle"),pcb_smtpad_id:Ww("pcb_smtpad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,radius:Zm2.number(),layer:FR2,port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),GE2=Zm2.object({type:Zm2.literal("pcb_smtpad"),shape:Zm2.literal("rect"),pcb_smtpad_id:Ww("pcb_smtpad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),rect_border_radius:Zm2.number().optional(),corner_radius:Zm2.number().optional(),layer:FR2,port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional(),soldermask_margin_left:Zm2.number().optional(),soldermask_margin_top:Zm2.number().optional(),soldermask_margin_right:Zm2.number().optional(),soldermask_margin_bottom:Zm2.number().optional()}),qE=Zm2.object({type:Zm2.literal("pcb_smtpad"),shape:Zm2.literal("rotated_rect"),pcb_smtpad_id:Ww("pcb_smtpad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),rect_border_radius:Zm2.number().optional(),corner_radius:Zm2.number().optional(),ccw_rotation:jw,layer:FR2,port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional(),soldermask_margin_left:Zm2.number().optional(),soldermask_margin_top:Zm2.number().optional(),soldermask_margin_right:Zm2.number().optional(),soldermask_margin_bottom:Zm2.number().optional()}),JE=Zm2.object({type:Zm2.literal("pcb_smtpad"),shape:Zm2.literal("pill"),pcb_smtpad_id:Ww("pcb_smtpad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),radius:Zm2.number(),layer:FR2,port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),KE=Zm2.object({type:Zm2.literal("pcb_smtpad"),shape:Zm2.literal("rotated_pill"),pcb_smtpad_id:Ww("pcb_smtpad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),radius:Zm2.number(),ccw_rotation:jw,layer:FR2,port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),QE=Zm2.object({type:Zm2.literal("pcb_smtpad"),shape:Zm2.literal("polygon"),pcb_smtpad_id:Ww("pcb_smtpad"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),points:Zm2.array($w),layer:FR2,port_hints:Zm2.array(Zm2.string()).optional(),pcb_component_id:Zm2.string().optional(),pcb_port_id:Zm2.string().optional(),is_covered_with_solder_mask:Zm2.boolean().optional(),soldermask_margin:Zm2.number().optional()}),tA=Zm2.discriminatedUnion("shape",[ZE,GE2,qE,KE,JE,QE]).describe("Defines an SMT pad on the PCB"),eA=Zm2.object({type:Zm2.literal("pcb_solder_paste"),shape:Zm2.literal("circle"),pcb_solder_paste_id:Ww("pcb_solder_paste"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,radius:Zm2.number(),layer:FR2,pcb_component_id:Zm2.string().optional(),pcb_smtpad_id:Zm2.string().optional()}),nA=Zm2.object({type:Zm2.literal("pcb_solder_paste"),shape:Zm2.literal("rect"),pcb_solder_paste_id:Ww("pcb_solder_paste"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),layer:FR2,pcb_component_id:Zm2.string().optional(),pcb_smtpad_id:Zm2.string().optional()}),oA=Zm2.object({type:Zm2.literal("pcb_solder_paste"),shape:Zm2.literal("pill"),pcb_solder_paste_id:Ww("pcb_solder_paste"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),radius:Zm2.number(),layer:FR2,pcb_component_id:Zm2.string().optional(),pcb_smtpad_id:Zm2.string().optional()}),iA=Zm2.object({type:Zm2.literal("pcb_solder_paste"),shape:Zm2.literal("rotated_rect"),pcb_solder_paste_id:Ww("pcb_solder_paste"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),ccw_rotation:Aw,layer:FR2,pcb_component_id:Zm2.string().optional(),pcb_smtpad_id:Zm2.string().optional()}),sA=Zm2.object({type:Zm2.literal("pcb_solder_paste"),shape:Zm2.literal("oval"),pcb_solder_paste_id:Ww("pcb_solder_paste"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),x:Aw,y:Aw,width:Zm2.number(),height:Zm2.number(),layer:FR2,pcb_component_id:Zm2.string().optional(),pcb_smtpad_id:Zm2.string().optional()}),rA=Zm2.union([eA,nA,oA,iA,sA]).describe("Defines solderpaste on the PCB"),aA=Zm2.object({type:Zm2.literal("pcb_text"),pcb_text_id:Ww("pcb_text"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),text:Zm2.string(),center:$w,layer:FR2,width:Rw,height:Rw,lines:Zm2.number(),align:Zm2.enum(["bottom-left"])}).describe("Defines text on the PCB"),cA=Zm2.object({route_type:Zm2.literal("wire"),x:Aw,y:Aw,width:Aw,start_pcb_port_id:Zm2.string().optional(),end_pcb_port_id:Zm2.string().optional(),layer:FR2}),lA=Zm2.object({route_type:Zm2.literal("via"),x:Aw,y:Aw,hole_diameter:Aw.optional(),outer_diameter:Aw.optional(),from_layer:Zm2.string(),to_layer:Zm2.string()}),hA=Zm2.union([cA,lA]),dA=Zm2.object({type:Zm2.literal("pcb_trace"),source_trace_id:Zm2.string().optional(),pcb_component_id:Zm2.string().optional(),pcb_trace_id:Ww("pcb_trace"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),route_thickness_mode:Zm2.enum(["constant","interpolated"]).default("constant").optional(),route_order_index:Zm2.number().optional(),should_round_corners:Zm2.boolean().optional(),trace_length:Zm2.number().optional(),highlight_color:Zm2.string().optional(),route:Zm2.array(hA)}).describe("Defines a trace on the PCB"),uA=Zw.extend({type:Zm2.literal("pcb_trace_error"),pcb_trace_error_id:Ww("pcb_trace_error"),error_type:Zm2.literal("pcb_trace_error").default("pcb_trace_error"),center:$w.optional(),pcb_trace_id:Zm2.string(),source_trace_id:Zm2.string(),pcb_component_ids:Zm2.array(Zm2.string()),pcb_port_ids:Zm2.array(Zm2.string()),subcircuit_id:Zm2.string().optional()}).describe("Defines a trace error on the PCB"),pA=Zw.extend({type:Zm2.literal("pcb_trace_missing_error"),pcb_trace_missing_error_id:Ww("pcb_trace_missing_error"),error_type:Zm2.literal("pcb_trace_missing_error").default("pcb_trace_missing_error"),center:$w.optional(),source_trace_id:Zm2.string(),pcb_component_ids:Zm2.array(Zm2.string()),pcb_port_ids:Zm2.array(Zm2.string()),subcircuit_id:Zm2.string().optional()}).describe("Defines an error when a source trace has no corresponding PCB trace"),mA=Zw.extend({type:Zm2.literal("pcb_port_not_matched_error"),pcb_error_id:Ww("pcb_error"),error_type:Zm2.literal("pcb_port_not_matched_error").default("pcb_port_not_matched_error"),pcb_component_ids:Zm2.array(Zm2.string()),subcircuit_id:Zm2.string().optional()}).describe("Defines a trace error on the PCB where a port is not matched"),gA=Zw.extend({type:Zm2.literal("pcb_port_not_connected_error"),pcb_port_not_connected_error_id:Ww("pcb_port_not_connected_error"),error_type:Zm2.literal("pcb_port_not_connected_error").default("pcb_port_not_connected_error"),pcb_port_ids:Zm2.array(Zm2.string()),pcb_component_ids:Zm2.array(Zm2.string()),subcircuit_id:Zm2.string().optional()}).describe("Defines an error when a pcb port is not connected to any trace"),fA=Zm2.object({type:Zm2.literal("pcb_net"),pcb_net_id:Ww("pcb_net"),source_net_id:Zm2.string().optional(),highlight_color:Zm2.string().optional()}).describe("Defines a net on the PCB"),_A=Zm2.object({type:Zm2.literal("pcb_via"),pcb_via_id:Ww("pcb_via"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),subcircuit_connectivity_map_key:Zm2.string().optional(),x:Aw,y:Aw,outer_diameter:Aw.default("0.6mm"),hole_diameter:Aw.default("0.25mm"),from_layer:FR2.optional(),to_layer:FR2.optional(),layers:Zm2.array(FR2),pcb_trace_id:Zm2.string().optional(),net_is_assignable:Zm2.boolean().optional(),net_assigned:Zm2.boolean().optional(),is_tented:Zm2.boolean().optional()}).describe("Defines a via on the PCB"),yA=Zm2.object({type:Zm2.literal("pcb_board"),pcb_board_id:Ww("pcb_board"),pcb_panel_id:Zm2.string().optional(),is_subcircuit:Zm2.boolean().optional(),subcircuit_id:Zm2.string().optional(),width:Rw.optional(),height:Rw.optional(),center:$w,display_offset_x:Zm2.string().optional().describe("How to display the x offset for this board, usually corresponding with how the user specified it"),display_offset_y:Zm2.string().optional().describe("How to display the y offset for this board, usually corresponding with how the user specified it"),thickness:Rw.optional().default(1.4),num_layers:Zm2.number().optional().default(4),outline:Zm2.array($w).optional(),shape:Zm2.enum(["rect","polygon"]).optional(),material:Zm2.enum(["fr4","fr1"]).default("fr4"),anchor_position:$w.optional(),anchor_alignment:Vw.optional(),position_mode:Zm2.enum(["relative_to_panel_anchor","none"]).optional()}).describe("Defines the board outline of the PCB"),bA=Zm2.object({type:Zm2.literal("pcb_panel"),pcb_panel_id:Ww("pcb_panel"),width:Rw,height:Rw,center:$w,covered_with_solder_mask:Zm2.boolean().optional().default(!0)}).describe("Defines a PCB panel that can contain multiple boards"),xA=Zw.extend({type:Zm2.literal("pcb_placement_error"),pcb_placement_error_id:Ww("pcb_placement_error"),error_type:Zm2.literal("pcb_placement_error").default("pcb_placement_error"),subcircuit_id:Zm2.string().optional()}).describe("Defines a placement error on the PCB"),vA=Zw.extend({type:Zm2.literal("pcb_panelization_placement_error"),pcb_panelization_placement_error_id:Ww("pcb_panelization_placement_error"),error_type:Zm2.literal("pcb_panelization_placement_error").default("pcb_panelization_placement_error"),pcb_panel_id:Zm2.string().optional(),pcb_board_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}).describe("Defines a panelization placement error on the PCB"),SA=Zm2.object({type:Zm2.literal("pcb_trace_hint"),pcb_trace_hint_id:Ww("pcb_trace_hint"),pcb_port_id:Zm2.string(),pcb_component_id:Zm2.string(),route:Zm2.array(ME),subcircuit_id:Zm2.string().optional()}).describe("A hint that can be used during generation of a PCB trace"),IA=Zm2.object({type:Zm2.literal("pcb_silkscreen_line"),pcb_silkscreen_line_id:Ww("pcb_silkscreen_line"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),stroke_width:Aw.default("0.1mm"),x1:Aw,y1:Aw,x2:Aw,y2:Aw,layer:$R2}).describe("Defines a silkscreen line on the PCB"),PA=Zm2.object({type:Zm2.literal("pcb_silkscreen_path"),pcb_silkscreen_path_id:Ww("pcb_silkscreen_path"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),layer:$R2,route:Zm2.array($w),stroke_width:Rw}).describe("Defines a silkscreen path on the PCB"),MA=Zm2.object({type:Zm2.literal("pcb_silkscreen_text"),pcb_silkscreen_text_id:Ww("pcb_silkscreen_text"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),font:Zm2.literal("tscircuit2024").default("tscircuit2024"),font_size:Aw.default("0.2mm"),pcb_component_id:Zm2.string(),text:Zm2.string(),is_knockout:Zm2.boolean().default(!1).optional(),knockout_padding:Zm2.object({left:Rw,top:Rw,bottom:Rw,right:Rw}).default({left:"0.2mm",top:"0.2mm",bottom:"0.2mm",right:"0.2mm"}).optional(),ccw_rotation:Zm2.number().optional(),layer:FR2,is_mirrored:Zm2.boolean().default(!1).optional(),anchor_position:$w.default({x:0,y:0}),anchor_alignment:Vw.default("center")}).describe("Defines silkscreen text on the PCB"),NA=Zm2.object({type:Zm2.literal("pcb_copper_text"),pcb_copper_text_id:Ww("pcb_copper_text"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),font:Zm2.literal("tscircuit2024").default("tscircuit2024"),font_size:Aw.default("0.2mm"),pcb_component_id:Zm2.string(),text:Zm2.string(),is_knockout:Zm2.boolean().default(!1).optional(),knockout_padding:Zm2.object({left:Rw,top:Rw,bottom:Rw,right:Rw}).default({left:"0.2mm",top:"0.2mm",bottom:"0.2mm",right:"0.2mm"}).optional(),ccw_rotation:Zm2.number().optional(),layer:FR2,is_mirrored:Zm2.boolean().default(!1).optional(),anchor_position:$w.default({x:0,y:0}),anchor_alignment:Vw.default("center")}).describe("Defines copper text on the PCB"),CA=Zm2.object({type:Zm2.literal("pcb_silkscreen_rect"),pcb_silkscreen_rect_id:Ww("pcb_silkscreen_rect"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,width:Rw,height:Rw,layer:FR2,stroke_width:Rw.default("1mm"),corner_radius:Rw.optional(),is_filled:Zm2.boolean().default(!0).optional(),has_stroke:Zm2.boolean().optional(),is_stroke_dashed:Zm2.boolean().optional(),ccw_rotation:Zm2.number().optional()}).describe("Defines a silkscreen rect on the PCB"),TA=Zm2.object({type:Zm2.literal("pcb_silkscreen_circle"),pcb_silkscreen_circle_id:Ww("pcb_silkscreen_circle"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,radius:Rw,layer:$R2,stroke_width:Rw.default("1mm")}).describe("Defines a silkscreen circle on the PCB"),wA=Zm2.object({type:Zm2.literal("pcb_silkscreen_oval"),pcb_silkscreen_oval_id:Ww("pcb_silkscreen_oval"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,radius_x:Aw,radius_y:Aw,layer:$R2,ccw_rotation:jw.optional()}).describe("Defines a silkscreen oval on the PCB"),RA=Zm2.object({type:Zm2.literal("pcb_silkscreen_pill"),pcb_silkscreen_pill_id:Ww("pcb_silkscreen_pill"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,width:Rw,height:Rw,layer:FR2,ccw_rotation:Zm2.number().optional()}).describe("Defines a silkscreen pill on the PCB"),EA=Zm2.object({type:Zm2.literal("pcb_fabrication_note_text"),pcb_fabrication_note_text_id:Ww("pcb_fabrication_note_text"),subcircuit_id:Zm2.string().optional(),pcb_group_id:Zm2.string().optional(),font:Zm2.literal("tscircuit2024").default("tscircuit2024"),font_size:Aw.default("1mm"),pcb_component_id:Zm2.string(),text:Zm2.string(),layer:$R2,anchor_position:$w.default({x:0,y:0}),anchor_alignment:Zm2.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),color:Zm2.string().optional()}).describe("Defines a fabrication note in text on the PCB, useful for leaving notes for assemblers or fabricators"),AA=Zm2.object({type:Zm2.literal("pcb_fabrication_note_path"),pcb_fabrication_note_path_id:Ww("pcb_fabrication_note_path"),pcb_component_id:Zm2.string(),subcircuit_id:Zm2.string().optional(),layer:FR2,route:Zm2.array($w),stroke_width:Rw,color:Zm2.string().optional()}).describe("Defines a fabrication path on the PCB for fabricators or assemblers"),OA=Zm2.object({type:Zm2.literal("pcb_fabrication_note_rect"),pcb_fabrication_note_rect_id:Ww("pcb_fabrication_note_rect"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,width:Rw,height:Rw,layer:$R2,stroke_width:Rw.default("0.1mm"),corner_radius:Rw.optional(),is_filled:Zm2.boolean().optional(),has_stroke:Zm2.boolean().optional(),is_stroke_dashed:Zm2.boolean().optional(),color:Zm2.string().optional()}).describe("Defines a fabrication note rectangle on the PCB"),LA=Zm2.object({type:Zm2.literal("pcb_fabrication_note_dimension"),pcb_fabrication_note_dimension_id:Ww("pcb_fabrication_note_dimension"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),layer:$R2,from:$w,to:$w,text:Zm2.string().optional(),text_ccw_rotation:Zm2.number().optional(),offset:Rw.optional(),offset_distance:Rw.optional(),offset_direction:Zm2.object({x:Zm2.number(),y:Zm2.number()}).optional(),font:Zm2.literal("tscircuit2024").default("tscircuit2024"),font_size:Rw.default("1mm"),color:Zm2.string().optional(),arrow_size:Rw.default("1mm")}).describe("Defines a measurement annotation within PCB fabrication notes"),kA=Zm2.object({type:Zm2.literal("pcb_note_text"),pcb_note_text_id:Ww("pcb_note_text"),pcb_component_id:Zm2.string().optional(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),name:Zm2.string().optional(),font:Zm2.literal("tscircuit2024").default("tscircuit2024"),font_size:Aw.default("1mm"),text:Zm2.string().optional(),anchor_position:$w.default({x:0,y:0}),anchor_alignment:Zm2.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),color:Zm2.string().optional()}).describe("Defines a documentation note in text on the PCB"),DA=Zm2.object({type:Zm2.literal("pcb_note_rect"),pcb_note_rect_id:Ww("pcb_note_rect"),pcb_component_id:Zm2.string().optional(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),name:Zm2.string().optional(),text:Zm2.string().optional(),center:$w,width:Rw,height:Rw,stroke_width:Rw.default("0.1mm"),corner_radius:Rw.optional(),is_filled:Zm2.boolean().optional(),has_stroke:Zm2.boolean().optional(),is_stroke_dashed:Zm2.boolean().optional(),color:Zm2.string().optional()}).describe("Defines a rectangular documentation note on the PCB"),zA=Zm2.object({type:Zm2.literal("pcb_note_path"),pcb_note_path_id:Ww("pcb_note_path"),pcb_component_id:Zm2.string().optional(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),name:Zm2.string().optional(),text:Zm2.string().optional(),route:Zm2.array($w),stroke_width:Rw.default("0.1mm"),color:Zm2.string().optional()}).describe("Defines a polyline documentation note on the PCB"),jA=Zm2.object({type:Zm2.literal("pcb_note_line"),pcb_note_line_id:Ww("pcb_note_line"),pcb_component_id:Zm2.string().optional(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),name:Zm2.string().optional(),text:Zm2.string().optional(),x1:Aw,y1:Aw,x2:Aw,y2:Aw,stroke_width:Aw.default("0.1mm"),color:Zm2.string().optional(),is_dashed:Zm2.boolean().optional()}).describe("Defines a straight documentation note line on the PCB"),FA=Zm2.object({type:Zm2.literal("pcb_note_dimension"),pcb_note_dimension_id:Ww("pcb_note_dimension"),pcb_component_id:Zm2.string().optional(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),name:Zm2.string().optional(),from:$w,to:$w,text:Zm2.string().optional(),text_ccw_rotation:Zm2.number().optional(),offset_distance:Rw.optional(),offset_direction:Zm2.object({x:Zm2.number(),y:Zm2.number()}).optional(),font:Zm2.literal("tscircuit2024").default("tscircuit2024"),font_size:Rw.default("1mm"),color:Zm2.string().optional(),arrow_size:Rw.default("1mm")}).describe("Defines a measurement annotation within PCB documentation notes"),$A=Zw.extend({type:Zm2.literal("pcb_footprint_overlap_error"),pcb_error_id:Ww("pcb_error"),error_type:Zm2.literal("pcb_footprint_overlap_error").default("pcb_footprint_overlap_error"),pcb_smtpad_ids:Zm2.array(Zm2.string()).optional(),pcb_plated_hole_ids:Zm2.array(Zm2.string()).optional(),pcb_hole_ids:Zm2.array(Zm2.string()).optional(),pcb_keepout_ids:Zm2.array(Zm2.string()).optional()}).describe("Error emitted when a pcb footprint overlaps with another element"),BA=Zm2.object({type:Zm2.literal("pcb_keepout"),shape:Zm2.literal("rect"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,width:Aw,height:Aw,pcb_keepout_id:Zm2.string(),layers:Zm2.array(Zm2.string()),description:Zm2.string().optional()}).or(Zm2.object({type:Zm2.literal("pcb_keepout"),shape:Zm2.literal("circle"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,radius:Aw,pcb_keepout_id:Zm2.string(),layers:Zm2.array(Zm2.string()),description:Zm2.string().optional()})),YA=Zm2.object({type:Zm2.literal("pcb_cutout"),pcb_cutout_id:Ww("pcb_cutout"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),pcb_board_id:Zm2.string().optional(),pcb_panel_id:Zm2.string().optional()}),XA=YA.extend({shape:Zm2.literal("rect"),center:$w,width:Rw,height:Rw,rotation:jw.optional(),corner_radius:Rw.optional()}),HA=YA.extend({shape:Zm2.literal("circle"),center:$w,radius:Rw}),WA=YA.extend({shape:Zm2.literal("polygon"),points:Zm2.array($w)}),VA=YA.extend({shape:Zm2.literal("path"),route:Zm2.array($w),slot_width:Rw,slot_length:Rw.optional(),space_between_slots:Rw.optional(),slot_corner_radius:Rw.optional()}),UA=Zm2.discriminatedUnion("shape",[XA,HA,WA,VA]).describe("Defines a cutout on the PCB, removing board material."),ZA=Zw.extend({type:Zm2.literal("pcb_missing_footprint_error"),pcb_missing_footprint_error_id:Ww("pcb_missing_footprint_error"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),error_type:Zm2.literal("pcb_missing_footprint_error").default("pcb_missing_footprint_error"),source_component_id:Zm2.string()}).describe("Defines a missing footprint error on the PCB"),GA=Zw.extend({type:Zm2.literal("external_footprint_load_error"),external_footprint_load_error_id:Ww("external_footprint_load_error"),pcb_component_id:Zm2.string(),source_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),footprinter_string:Zm2.string().optional(),error_type:Zm2.literal("external_footprint_load_error").default("external_footprint_load_error")}).describe("Defines an error when an external footprint fails to load"),qA=Zw.extend({type:Zm2.literal("circuit_json_footprint_load_error"),circuit_json_footprint_load_error_id:Ww("circuit_json_footprint_load_error"),pcb_component_id:Zm2.string(),source_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),error_type:Zm2.literal("circuit_json_footprint_load_error").default("circuit_json_footprint_load_error"),circuit_json:Zm2.array(Zm2.any()).optional()}).describe("Defines an error when a circuit JSON footprint fails to load"),JA=Zm2.object({type:Zm2.literal("pcb_group"),pcb_group_id:Ww("pcb_group"),source_group_id:Zm2.string(),is_subcircuit:Zm2.boolean().optional(),subcircuit_id:Zm2.string().optional(),width:Rw.optional(),height:Rw.optional(),center:$w,display_offset_x:Zm2.string().optional().describe("How to display the x offset for this group, usually corresponding with how the user specified it"),display_offset_y:Zm2.string().optional().describe("How to display the y offset for this group, usually corresponding with how the user specified it"),outline:Zm2.array($w).optional(),anchor_position:$w.optional(),anchor_alignment:Vw.default("center"),position_mode:Zm2.enum(["packed","relative_to_group_anchor","none"]).optional(),positioned_relative_to_pcb_group_id:Zm2.string().optional(),positioned_relative_to_pcb_board_id:Zm2.string().optional(),pcb_component_ids:Zm2.array(Zm2.string()),child_layout_mode:Zm2.enum(["packed","none"]).optional(),name:Zm2.string().optional(),description:Zm2.string().optional(),layout_mode:Zm2.string().optional(),autorouter_configuration:Zm2.object({trace_clearance:Rw}).optional(),autorouter_used_string:Zm2.string().optional()}).describe("Defines a group of components on the PCB"),KA=Zw.extend({type:Zm2.literal("pcb_autorouting_error"),pcb_error_id:Ww("pcb_autorouting_error"),error_type:Zm2.literal("pcb_autorouting_error").default("pcb_autorouting_error"),subcircuit_id:Zm2.string().optional()}).describe("The autorouting has failed to route a portion of the board"),QA=Zm2.object({type:Zm2.literal("pcb_manual_edit_conflict_warning"),pcb_manual_edit_conflict_warning_id:Ww("pcb_manual_edit_conflict_warning"),warning_type:Zm2.literal("pcb_manual_edit_conflict_warning").default("pcb_manual_edit_conflict_warning"),message:Zm2.string(),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),source_component_id:Zm2.string()}).describe("Warning emitted when a component has both manual placement and explicit pcbX/pcbY coordinates"),tO=Zm2.object({type:Zm2.literal("pcb_breakout_point"),pcb_breakout_point_id:Ww("pcb_breakout_point"),pcb_group_id:Zm2.string(),subcircuit_id:Zm2.string().optional(),source_trace_id:Zm2.string().optional(),source_port_id:Zm2.string().optional(),source_net_id:Zm2.string().optional(),x:Aw,y:Aw}).describe("Defines a routing target within a pcb_group for a source_trace or source_net"),eO=Zm2.object({type:Zm2.literal("pcb_ground_plane"),pcb_ground_plane_id:Ww("pcb_ground_plane"),source_pcb_ground_plane_id:Zm2.string(),source_net_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}).describe("Defines a ground plane on the PCB"),nO=Zm2.object({type:Zm2.literal("pcb_ground_plane_region"),pcb_ground_plane_region_id:Ww("pcb_ground_plane_region"),pcb_ground_plane_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),layer:FR2,points:Zm2.array($w)}).describe("Defines a polygon region of a ground plane"),oO=Zm2.object({type:Zm2.literal("pcb_thermal_spoke"),pcb_thermal_spoke_id:Ww("pcb_thermal_spoke"),pcb_ground_plane_id:Zm2.string(),shape:Zm2.string(),spoke_count:Zm2.number(),spoke_thickness:Aw,spoke_inner_diameter:Aw,spoke_outer_diameter:Aw,pcb_plated_hole_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}).describe("Pattern for connecting a ground plane to a plated hole"),iO=Zm2.object({type:Zm2.literal("pcb_copper_pour"),pcb_copper_pour_id:Ww("pcb_copper_pour"),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),layer:FR2,source_net_id:Zm2.string().optional(),covered_with_solder_mask:Zm2.boolean().optional().default(!0)}),sO=iO.extend({shape:Zm2.literal("rect"),center:$w,width:Rw,height:Rw,rotation:jw.optional()}),rO=iO.extend({shape:Zm2.literal("brep"),brep_shape:SE}),aO=iO.extend({shape:Zm2.literal("polygon"),points:Zm2.array($w)}),cO=Zm2.discriminatedUnion("shape",[sO,rO,aO]).describe("Defines a copper pour on the PCB."),lO=Zw.extend({type:Zm2.literal("pcb_component_outside_board_error"),pcb_component_outside_board_error_id:Ww("pcb_component_outside_board_error"),error_type:Zm2.literal("pcb_component_outside_board_error").default("pcb_component_outside_board_error"),pcb_component_id:Zm2.string(),pcb_board_id:Zm2.string(),component_center:$w,component_bounds:Zm2.object({min_x:Zm2.number(),max_x:Zm2.number(),min_y:Zm2.number(),max_y:Zm2.number()}),subcircuit_id:Zm2.string().optional(),source_component_id:Zm2.string().optional()}).describe("Error emitted when a PCB component is placed outside the board boundaries"),hO=Zw.extend({type:Zm2.literal("pcb_component_invalid_layer_error"),pcb_component_invalid_layer_error_id:Ww("pcb_component_invalid_layer_error"),error_type:Zm2.literal("pcb_component_invalid_layer_error").default("pcb_component_invalid_layer_error"),pcb_component_id:Zm2.string().optional(),source_component_id:Zm2.string(),layer:FR2,subcircuit_id:Zm2.string().optional()}).describe("Error emitted when a component is placed on an invalid layer (components can only be on 'top' or 'bottom' layers)"),dO=Zw.extend({type:Zm2.literal("pcb_via_clearance_error"),pcb_error_id:Ww("pcb_error"),error_type:Zm2.literal("pcb_via_clearance_error").default("pcb_via_clearance_error"),pcb_via_ids:Zm2.array(Zm2.string()).min(2),minimum_clearance:Aw.optional(),actual_clearance:Aw.optional(),pcb_center:Zm2.object({x:Zm2.number().optional(),y:Zm2.number().optional()}).optional(),subcircuit_id:Zm2.string().optional()}).describe("Error emitted when vias are closer than the allowed clearance"),uO=Zm2.object({type:Zm2.literal("pcb_courtyard_rect"),pcb_courtyard_rect_id:Ww("pcb_courtyard_rect"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),center:$w,width:Rw,height:Rw,layer:$R2,color:Zm2.string().optional()}).describe("Defines a courtyard rectangle on the PCB"),pO=Zm2.object({type:Zm2.literal("pcb_courtyard_outline"),pcb_courtyard_outline_id:Ww("pcb_courtyard_outline"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),layer:$R2,outline:Zm2.array($w).min(2),stroke_width:Rw.default("0.1mm"),is_closed:Zm2.boolean().optional(),is_stroke_dashed:Zm2.boolean().optional(),color:Zm2.string().optional()}).describe("Defines a courtyard outline on the PCB"),mO=Zm2.object({type:Zm2.literal("pcb_courtyard_polygon"),pcb_courtyard_polygon_id:Ww("pcb_courtyard_polygon"),pcb_component_id:Zm2.string(),pcb_group_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),layer:$R2,points:Zm2.array($w).min(3),color:Zm2.string().optional()}).describe("Defines a courtyard polygon on the PCB"),gO=Zm2.object({type:Zm2.literal("cad_component"),cad_component_id:Zm2.string(),pcb_component_id:Zm2.string(),source_component_id:Zm2.string(),position:Yw,rotation:Yw.optional(),size:Yw.optional(),layer:FR2.optional(),subcircuit_id:Zm2.string().optional(),footprinter_string:Zm2.string().optional(),model_obj_url:Zm2.string().optional(),model_stl_url:Zm2.string().optional(),model_3mf_url:Zm2.string().optional(),model_gltf_url:Zm2.string().optional(),model_glb_url:Zm2.string().optional(),model_step_url:Zm2.string().optional(),model_wrl_url:Zm2.string().optional(),model_unit_to_mm_scale_factor:Zm2.number().optional(),model_jscad:Zm2.any().optional(),show_as_translucent_model:Zm2.boolean().optional(),anchor_alignment:Zm2.enum(["center","xy_center_z_board"]).optional().default("center")}).describe("Defines a component on the PCB"),fO=Zm2.enum(["sinewave","square","triangle","sawtooth"]),_O=Zm2.union([Zm2.string(),Zm2.number()]).transform(t52=>typeof t52=="string"?t52.endsWith("%")?parseFloat(t52.slice(0,-1))/100:parseFloat(t52):t52).pipe(Zm2.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),yO=Zm2.object({type:Zm2.literal("simulation_voltage_source"),simulation_voltage_source_id:Ww("simulation_voltage_source"),is_dc_source:Zm2.literal(!0).optional().default(!0),positive_source_port_id:Zm2.string().optional(),negative_source_port_id:Zm2.string().optional(),positive_source_net_id:Zm2.string().optional(),negative_source_net_id:Zm2.string().optional(),voltage:ww}).describe("Defines a DC voltage source for simulation"),bO=Zm2.object({type:Zm2.literal("simulation_voltage_source"),simulation_voltage_source_id:Ww("simulation_voltage_source"),is_dc_source:Zm2.literal(!1),terminal1_source_port_id:Zm2.string().optional(),terminal2_source_port_id:Zm2.string().optional(),terminal1_source_net_id:Zm2.string().optional(),terminal2_source_net_id:Zm2.string().optional(),voltage:ww.optional(),frequency:Ew.optional(),peak_to_peak_voltage:ww.optional(),wave_shape:fO.optional(),phase:jw.optional(),duty_cycle:_O.optional()}).describe("Defines an AC voltage source for simulation"),xO=Zm2.union([yO,bO]).describe("Defines a voltage source for simulation"),vO=Zm2.union([Zm2.string(),Zm2.number()]).transform(t52=>typeof t52=="string"?t52.endsWith("%")?parseFloat(t52.slice(0,-1))/100:parseFloat(t52):t52).pipe(Zm2.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),SO=Zm2.object({type:Zm2.literal("simulation_current_source"),simulation_current_source_id:Ww("simulation_current_source"),is_dc_source:Zm2.literal(!0).optional().default(!0),positive_source_port_id:Zm2.string().optional(),negative_source_port_id:Zm2.string().optional(),positive_source_net_id:Zm2.string().optional(),negative_source_net_id:Zm2.string().optional(),current:Ow}).describe("Defines a DC current source for simulation"),IO=Zm2.object({type:Zm2.literal("simulation_current_source"),simulation_current_source_id:Ww("simulation_current_source"),is_dc_source:Zm2.literal(!1),terminal1_source_port_id:Zm2.string().optional(),terminal2_source_port_id:Zm2.string().optional(),terminal1_source_net_id:Zm2.string().optional(),terminal2_source_net_id:Zm2.string().optional(),current:Ow.optional(),frequency:Ew.optional(),peak_to_peak_current:Ow.optional(),wave_shape:fO.optional(),phase:jw.optional(),duty_cycle:vO.optional()}).describe("Defines an AC current source for simulation"),PO=Zm2.union([SO,IO]).describe("Defines a current source for simulation"),MO=Zm2.union([Zm2.literal("spice_dc_sweep"),Zm2.literal("spice_dc_operating_point"),Zm2.literal("spice_transient_analysis"),Zm2.literal("spice_ac_analysis")]),NO=Zm2.object({type:Zm2.literal("simulation_experiment"),simulation_experiment_id:Ww("simulation_experiment"),name:Zm2.string(),experiment_type:MO,time_per_step:Lw.optional(),start_time_ms:Dw.optional(),end_time_ms:Dw.optional()}).describe("Defines a simulation experiment configuration"),CO=Zm2.object({type:Zm2.literal("simulation_transient_voltage_graph"),simulation_transient_voltage_graph_id:Ww("simulation_transient_voltage_graph"),simulation_experiment_id:Zm2.string(),timestamps_ms:Zm2.array(Zm2.number()).optional(),voltage_levels:Zm2.array(Zm2.number()),source_component_id:Zm2.string().optional(),subcircuit_connectivity_map_key:Zm2.string().optional(),time_per_step:Lw,start_time_ms:Dw,end_time_ms:Dw,name:Zm2.string().optional(),color:Zm2.string().optional()}).describe("Stores voltage measurements over time for a simulation"),TO=Zm2.object({type:Zm2.literal("simulation_switch"),simulation_switch_id:Ww("simulation_switch"),source_component_id:Zm2.string().optional(),closes_at:Dw.optional(),opens_at:Dw.optional(),starts_closed:Zm2.boolean().optional(),switching_frequency:Ew.optional()}).describe("Defines a switch for simulation timing control"),wO=Zm2.object({type:Zm2.literal("simulation_voltage_probe"),simulation_voltage_probe_id:Ww("simulation_voltage_probe"),source_component_id:Zm2.string().optional(),name:Zm2.string().optional(),signal_input_source_port_id:Zm2.string().optional(),signal_input_source_net_id:Zm2.string().optional(),reference_input_source_port_id:Zm2.string().optional(),reference_input_source_net_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional(),color:Zm2.string().optional()}).describe("Defines a voltage probe for simulation. If a reference input is not provided, it measures against ground. If a reference input is provided, it measures the differential voltage between two points.").superRefine((t52,e5)=>{if(t52.reference_input_source_port_id||t52.reference_input_source_net_id){let n4=!!t52.signal_input_source_port_id||!!t52.reference_input_source_port_id,o4=!!t52.signal_input_source_net_id||!!t52.reference_input_source_net_id;n4&&o4?e5.addIssue({code:Zm2.ZodIssueCode.custom,message:"Cannot mix port and net connections in a differential probe."}):n4?t52.signal_input_source_port_id&&t52.reference_input_source_port_id||e5.addIssue({code:Zm2.ZodIssueCode.custom,message:"Differential port probe requires both signal_input_source_port_id and reference_input_source_port_id."}):o4&&(t52.signal_input_source_net_id&&t52.reference_input_source_net_id||e5.addIssue({code:Zm2.ZodIssueCode.custom,message:"Differential net probe requires both signal_input_source_net_id and reference_input_source_net_id."}))}else!!t52.signal_input_source_port_id==!!t52.signal_input_source_net_id&&e5.addIssue({code:Zm2.ZodIssueCode.custom,message:"A voltage probe must have exactly one of signal_input_source_port_id or signal_input_source_net_id."})}),RO=Zw.extend({type:Zm2.literal("simulation_unknown_experiment_error"),simulation_unknown_experiment_error_id:Ww("simulation_unknown_experiment_error"),error_type:Zm2.literal("simulation_unknown_experiment_error").default("simulation_unknown_experiment_error"),simulation_experiment_id:Zm2.string().optional(),subcircuit_id:Zm2.string().optional()}).describe("An unknown error occurred during the simulation experiment."),EO=Zm2.object({type:Zm2.literal("simulation_op_amp"),simulation_op_amp_id:Ww("simulation_op_amp"),source_component_id:Zm2.string().optional(),inverting_input_source_port_id:Zm2.string(),non_inverting_input_source_port_id:Zm2.string(),output_source_port_id:Zm2.string(),positive_supply_source_port_id:Zm2.string(),negative_supply_source_port_id:Zm2.string()}).describe("Defines a simple ideal operational amplifier for simulation"),AO=Zm2.union([AR2,RR,ER,wR2,LR,OR,oR,Jw,Qw,eR,Kw,iR,aR,cR,uR2,pR,mR,bR,gR2,fR,_R,yR,hR2,lR,DR,BR,kR2,xR,IR,MR,YR,XR2,NE,FE2,ZA,GA,qA,QA,VE,BA,UE,fA,aA,dA,_A,tA,rA,yA,bA,JA,SA,IA,PA,MA,RA,NA,CA,TA,wA,uA,pA,xA,vA,mA,gA,dO,AA,EA,OA,LA,kA,DA,zA,jA,FA,KA,$A,tO,UA,eO,nO,oO,cO,lO,hO,uO,pO,mO,HR,iE,KR,QR,tE,eE,qR,JR,sE,nE,WR,aE,cE,rE,pE,mE,gE,fE,bE,_E,yE,gO,xO,PO,NO,CO,TO,wO,RO,EO]),OO=AO;function LO(t52,e5,n4){if(!e5||!n4)return;let o4=t52.get(e5);o4||(o4=new Set,t52.set(e5,o4)),o4.add(n4);let i3=t52.get(n4);i3||(i3=new Set,t52.set(n4,i3)),i3.add(e5)}var kO=(t52,e5={})=>{let n4=t52,o4=n4._internal_store;if(!o4){o4={counts:{},editCount:0},n4._internal_store=o4;for(let t53 of n4){let e6=t53.type,n5=t53[`${e6}_id`];if(!n5)continue;let i4=Number.parseInt(n5.split("_").pop());Number.isNaN(i4)||(o4.counts[e6]=Math.max(o4.counts[e6]??0,i4))}}let i3=new Proxy({},{get:(t53,s3)=>{if(s3==="toArray")return()=>(n4.editCount=o4.editCount,n4);if(s3==="editCount")return o4.editCount;if(s3==="subtree")return t54=>kO((function(t55,e6){if(!e6.subcircuit_id&&!e6.source_group_id)return[...t55];let n5=e6;if(e6.subcircuit_id){let o7=new Set([e6.subcircuit_id]),i5=new Map,s5=new Map;for(let e7 of t55)if(e7.type==="source_group"){let t56=e7.source_group_id,n6=e7.subcircuit_id;n6&&s5.set(t56,n6);let o8=e7.parent_source_group_id;o8&&(i5.has(o8)||i5.set(o8,[]),i5.get(o8).push(t56))}let r7;for(let[t56,n6]of s5)if(n6===e6.subcircuit_id){r7=t56;break}if(r7){let t56=e7=>{let n6=i5.get(e7)||[];for(let e8 of n6){let n7=s5.get(e8);n7&&o7.add(n7),t56(e8)}};t56(r7),n5={...e6,subcircuit_ids:Array.from(o7)}}}let o6=new Map;for(let e7 of t55){let t56=e7[`${e7.type}_id`];typeof t56=="string"&&o6.set(t56,e7)}let i4=new Map;for(let e7 of t55){let t56=Object.entries(e7);for(let[n6,s5]of t56)if(n6!=="parent_source_group_id"){if(n6.endsWith("_id")&&typeof s5=="string")LO(i4,e7,o6.get(s5));else if(n6.endsWith("_ids")&&Array.isArray(s5))for(let t57 of s5)typeof t57=="string"&&LO(i4,e7,o6.get(t57))}}let s4=[],r6=new Set;for(let e7 of t55){let t56=!1;(n5.subcircuit_id&&"subcircuit_id"in e7&&e7.subcircuit_id===n5.subcircuit_id||n5.subcircuit_ids&&"subcircuit_id"in e7&&e7.subcircuit_id&&n5.subcircuit_ids.includes(e7.subcircuit_id)||n5.source_group_id&&"source_group_id"in e7&&e7.source_group_id===n5.source_group_id||n5.source_group_id&&"member_source_group_ids"in e7&&Array.isArray(e7.member_source_group_ids)&&e7.member_source_group_ids.includes(n5.source_group_id))&&(t56=!0),t56&&(s4.push(e7),r6.add(e7))}for(;s4.length>0;){let t56=s4.shift(),e7=i4.get(t56);if(e7)for(let t57 of e7)r6.has(t57)||(r6.add(t57),s4.push(t57))}return t55.filter(t56=>r6.has(t56))})(n4,t54),e5);if(s3==="insert")return t54=>{var _a362;let i4=t54.type;if(!i4)throw new Error("insert requires an element with a type");(_a362=o4.counts)[i4]??(_a362[i4]=-1),o4.counts[i4]++;let s4=o4.counts[i4],r6={...t54,type:i4,[`${i4}_id`]:`${i4}_${s4}`};return e5.validateInserts&&(vw[i4]??OO).parse(r6),n4.push(r6),o4.editCount++,r6};if(s3==="insertAll")return t54=>t54.map(t55=>i3.insert(t55));let r5=s3;return{get:t54=>n4.find(e6=>e6.type===r5&&e6[`${r5}_id`]===t54),getUsing:t54=>{let e6=Object.keys(t54);if(e6.length!==1)throw new Error("getUsing requires exactly one key, e.g. { pcb_component_id }");let o6=e6[0],i4=o6.replace("_id",""),s4=n4.find(e7=>e7.type===i4&&e7[o6]===t54[o6]);return s4?n4.find(t55=>t55.type===r5&&t55[`${r5}_id`]===s4[`${r5}_id`]):null},getWhere:t54=>{let e6=Object.keys(t54);return n4.find(n5=>n5.type===r5&&e6.every(e7=>n5[e7]===t54[e7]))},list:t54=>{let e6=t54?Object.keys(t54):[];return n4.filter(n5=>n5.type===r5&&e6.every(e7=>n5[e7]===t54[e7]))},insert:t54=>{var _a362;(_a362=o4.counts)[r5]??(_a362[r5]=-1),o4.counts[r5]++;let i4=o4.counts[r5],s4={type:r5,[`${r5}_id`]:`${r5}_${i4}`,...t54};return e5.validateInserts&&(vw[r5]??OO).parse(s4),n4.push(s4),o4.editCount++,s4},delete:t54=>{let e6=n4.find(e7=>e7[`${r5}_id`]===t54);e6&&(n4.splice(n4.indexOf(e6),1),o4.editCount++)},update:(t54,e6)=>{let i4=n4.find(e7=>e7.type===r5&&e7[`${r5}_id`]===t54);return i4?(Object.assign(i4,e6),o4.editCount++,i4):null},select:t54=>{if(r5==="source_component")return n4.find(e6=>e6.type==="source_component"&&e6.name===t54.replace(/\./g,""));if(r5==="pcb_port"||r5==="source_port"||r5==="schematic_port"){let[e6,o6]=t54.replace(/\./g,"").split(/[\s\>]+/),i4=n4.find(t55=>t55.type==="source_component"&&t55.name===e6);if(!i4)return null;let s4=n4.find(t55=>t55.type==="source_port"&&t55.source_component_id===i4.source_component_id&&(t55.name===o6||(t55.port_hints??[]).includes(o6)));if(!s4)return null;if(r5==="source_port")return s4;if(r5==="pcb_port")return n4.find(t55=>t55.type==="pcb_port"&&t55.source_port_id===s4.source_port_id);if(r5==="schematic_port")return n4.find(t55=>t55.type==="schematic_port"&&t55.source_port_id===s4.source_port_id)}}}}});return i3};function DO(t52){let e5=t52.type;return`${e5}:${t52[`${e5}_id`]}`}kO.unparsed=kO;var zO=(t52,e5={})=>{let n4=t52._internal_store_indexed;if(!n4){n4={counts:{},editCount:0,indexes:{}};for(let e6 of t52){let t53=e6.type,o6=e6[`${t53}_id`];if(!o6)continue;let i4=Number.parseInt(o6.split("_").pop()||"");Number.isNaN(i4)||(n4.counts[t53]=Math.max(n4.counts[t53]??0,i4))}let o4=e5.indexConfig||{},i3=n4.indexes;if(o4.byId&&(i3.byId=new Map),o4.byType&&(i3.byType=new Map),o4.byRelation&&(i3.byRelation=new Map),o4.bySubcircuit&&(i3.bySubcircuit=new Map),o4.byCustomField&&o4.byCustomField.length>0){i3.byCustomField=new Map;for(let t53 of o4.byCustomField)i3.byCustomField.set(t53,new Map)}for(let e6 of t52){if(o4.byId){let t53=DO(e6);i3.byId.set(t53,e6)}if(o4.byType){let t53=i3.byType.get(e6.type)||[];t53.push(e6),i3.byType.set(e6.type,t53)}if(o4.byRelation){let t53=Object.entries(e6);for(let[n5,o6]of t53)if(n5.endsWith("_id")&&n5!==`${e6.type}_id`&&typeof o6=="string"){let t54=i3.byRelation.get(n5)||new Map,s3=t54.get(o6)||[];s3.push(e6),t54.set(o6,s3),i3.byRelation.set(n5,t54)}}if(o4.bySubcircuit&&"subcircuit_id"in e6){let t53=e6.subcircuit_id;if(t53&&typeof t53=="string"){let n5=i3.bySubcircuit.get(t53)||[];n5.push(e6),i3.bySubcircuit.set(t53,n5)}}if(o4.byCustomField&&i3.byCustomField){for(let t53 of o4.byCustomField)if(t53 in e6){let n5=e6[t53];if(n5!==void 0&&(typeof n5=="string"||typeof n5=="number")){let o6=String(n5),s3=i3.byCustomField.get(t53),r5=s3.get(o6)||[];r5.push(e6),s3.set(o6,r5)}}}}t52._internal_store_indexed=n4}return new Proxy({},{get:(o4,i3)=>{if(i3==="toArray")return()=>(t52.editCount=n4.editCount,t52);if(i3==="editCount")return n4.editCount;let s3=i3;return{get:o6=>{let i4=e5.indexConfig||{};return i4.byId&&n4.indexes.byId?n4.indexes.byId.get(`${s3}:${o6}`)||null:i4.byType&&n4.indexes.byType?(n4.indexes.byType.get(s3)||[]).find(t53=>t53[`${s3}_id`]===o6)||null:t52.find(t53=>t53.type===s3&&t53[`${s3}_id`]===o6)||null},getUsing:o6=>{let i4=e5.indexConfig||{},r5=Object.keys(o6);if(r5.length!==1)throw new Error("getUsing requires exactly one key, e.g. { pcb_component_id }");let a3=r5[0],c4=a3.replace("_id","");if(i4.byRelation&&n4.indexes.byRelation){let e6=n4.indexes.byRelation.get(a3);if(e6){let r6=(e6.get(o6[a3])||[]).find(t53=>t53.type===c4);if(!r6)return null;let l5=r6[`${s3}_id`];return i4.byId&&n4.indexes.byId?n4.indexes.byId.get(`${s3}:${l5}`)||null:i4.byType&&n4.indexes.byType?(n4.indexes.byType.get(s3)||[]).find(t53=>t53[`${s3}_id`]===l5)||null:t52.find(t53=>t53.type===s3&&t53[`${s3}_id`]===l5)||null}}let l4=t52.find(t53=>t53.type===c4&&t53[a3]===o6[a3]);return l4&&t52.find(t53=>t53.type===s3&&t53[`${s3}_id`]===l4[`${s3}_id`])||null},getWhere:o6=>{let i4=e5.indexConfig||{},r5=Object.keys(o6);if(r5.length===1&&i4.byCustomField&&n4.indexes.byCustomField){let t53=r5[0],e6=n4.indexes.byCustomField.get(t53);if(e6){let n5=String(o6[t53]);return(e6.get(n5)||[]).find(t54=>t54.type===s3)||null}}if("subcircuit_id"in o6&&i4.bySubcircuit&&n4.indexes.bySubcircuit){let t53=o6.subcircuit_id;return(n4.indexes.bySubcircuit.get(t53)||[]).find(t54=>t54.type===s3&&r5.every(e6=>t54[e6]===o6[e6]))||null}return i4.byType&&n4.indexes.byType?(n4.indexes.byType.get(s3)||[]).find(t53=>r5.every(e6=>t53[e6]===o6[e6]))||null:t52.find(t53=>t53.type===s3&&r5.every(e6=>t53[e6]===o6[e6]))||null},list:o6=>{let i4=e5.indexConfig||{},r5=o6?Object.keys(o6):[];if(r5.length===0&&i4.byType&&n4.indexes.byType)return n4.indexes.byType.get(s3)||[];if(r5.length===1&&r5[0]==="subcircuit_id"&&i4.bySubcircuit&&n4.indexes.bySubcircuit){let t53=o6.subcircuit_id;return(n4.indexes.bySubcircuit.get(t53)||[]).filter(t54=>t54.type===s3)}let a3;return a3=i4.byType&&n4.indexes.byType?n4.indexes.byType.get(s3)||[]:t52.filter(t53=>t53.type===s3),r5.length>0?a3.filter(t53=>r5.every(e6=>t53[e6]===o6[e6])):a3},insert:o6=>{var _a362;(_a362=n4.counts)[s3]??(_a362[s3]=-1),n4.counts[s3]++;let i4=n4.counts[s3],r5={type:s3,[`${s3}_id`]:`${s3}_${i4}`,...o6};e5.validateInserts&&(vw[s3]??OO).parse(r5),t52.push(r5),n4.editCount++;let a3=e5.indexConfig||{};if(a3.byId&&n4.indexes.byId){let t53=DO(r5);n4.indexes.byId.set(t53,r5)}if(a3.byType&&n4.indexes.byType){let t53=n4.indexes.byType.get(s3)||[];t53.push(r5),n4.indexes.byType.set(s3,t53)}if(a3.byRelation&&n4.indexes.byRelation){let t53=Object.entries(r5);for(let[e6,o7]of t53)if(e6.endsWith("_id")&&e6!==`${r5.type}_id`&&typeof o7=="string"){let t54=n4.indexes.byRelation.get(e6)||new Map,i5=t54.get(o7)||[];i5.push(r5),t54.set(o7,i5),n4.indexes.byRelation.set(e6,t54)}}if(a3.bySubcircuit&&n4.indexes.bySubcircuit&&"subcircuit_id"in r5){let t53=r5.subcircuit_id;if(t53&&typeof t53=="string"){let e6=n4.indexes.bySubcircuit.get(t53)||[];e6.push(r5),n4.indexes.bySubcircuit.set(t53,e6)}}if(a3.byCustomField&&n4.indexes.byCustomField){for(let t53 of a3.byCustomField)if(t53 in r5){let e6=r5[t53];if(e6!==void 0&&(typeof e6=="string"||typeof e6=="number")){let o7=String(e6),i5=n4.indexes.byCustomField.get(t53),s4=i5.get(o7)||[];s4.push(r5),i5.set(o7,s4)}}}return r5},delete:o6=>{let i4=e5.indexConfig||{},r5;if(i4.byId&&n4.indexes.byId?r5=n4.indexes.byId.get(`${s3}:${o6}`):i4.byType&&n4.indexes.byType?r5=(n4.indexes.byType.get(s3)||[]).find(t54=>t54[`${s3}_id`]===o6):r5=t52.find(t53=>t53[`${s3}_id`]===o6),!r5)return;let a3=t52.indexOf(r5);if(a3>=0&&(t52.splice(a3,1),n4.editCount++),i4.byId&&n4.indexes.byId){let t53=DO(r5);n4.indexes.byId.delete(t53)}if(i4.byType&&n4.indexes.byType){let t53=(n4.indexes.byType.get(s3)||[]).filter(t54=>t54[`${s3}_id`]!==o6);n4.indexes.byType.set(s3,t53)}if(i4.byRelation&&n4.indexes.byRelation)for(let[t53,e6]of n4.indexes.byRelation.entries())for(let[t54,n5]of e6.entries()){let o7=n5.filter(t55=>t55!==r5);o7.length===0?e6.delete(t54):e6.set(t54,o7)}if(i4.bySubcircuit&&n4.indexes.bySubcircuit&&"subcircuit_id"in r5){let t53=r5.subcircuit_id;if(t53){let e6=(n4.indexes.bySubcircuit.get(t53)||[]).filter(t54=>t54!==r5);e6.length===0?n4.indexes.bySubcircuit.delete(t53):n4.indexes.bySubcircuit.set(t53,e6)}}if(i4.byCustomField&&n4.indexes.byCustomField)for(let t53 of n4.indexes.byCustomField.values())for(let[e6,n5]of t53.entries()){let o7=n5.filter(t54=>t54!==r5);o7.length===0?t53.delete(e6):t53.set(e6,o7)}},update:(o6,i4)=>{let r5=e5.indexConfig||{},a3;if(r5.byId&&n4.indexes.byId?a3=n4.indexes.byId.get(`${s3}:${o6}`):r5.byType&&n4.indexes.byType?a3=(n4.indexes.byType.get(s3)||[]).find(t54=>t54[`${s3}_id`]===o6):a3=t52.find(t53=>t53.type===s3&&t53[`${s3}_id`]===o6),!a3)return null;if(r5.byRelation&&n4.indexes.byRelation){let t53=Object.entries(a3);for(let[e6,o7]of t53)if(e6.endsWith("_id")&&e6!==`${a3.type}_id`&&typeof o7=="string"&&e6 in i4&&i4[e6]!==o7){let t54=n4.indexes.byRelation.get(e6);if(t54){let e7=(t54.get(o7)||[]).filter(t55=>t55!==a3);e7.length===0?t54.delete(o7):t54.set(o7,e7)}}}if(r5.bySubcircuit&&n4.indexes.bySubcircuit&&"subcircuit_id"in a3&&"subcircuit_id"in i4){let t53=a3.subcircuit_id;if(t53!==i4.subcircuit_id){let e6=(n4.indexes.bySubcircuit.get(t53)||[]).filter(t54=>t54!==a3);e6.length===0?n4.indexes.bySubcircuit.delete(t53):n4.indexes.bySubcircuit.set(t53,e6)}}if(r5.byCustomField&&n4.indexes.byCustomField){for(let t53 of r5.byCustomField)if(t53 in a3&&t53 in i4&&a3[t53]!==i4[t53]){let e6=n4.indexes.byCustomField.get(t53);if(e6){let n5=String(a3[t53]),o7=(e6.get(n5)||[]).filter(t54=>t54!==a3);o7.length===0?e6.delete(n5):e6.set(n5,o7)}}}if(Object.assign(a3,i4),n4.editCount++,r5.byRelation&&n4.indexes.byRelation){let t53=Object.entries(a3);for(let[e6,o7]of t53)if(e6.endsWith("_id")&&e6!==`${a3.type}_id`&&typeof o7=="string"&&e6 in i4){let t54=n4.indexes.byRelation.get(e6)||new Map,i5=t54.get(o7)||[];i5.includes(a3)||(i5.push(a3),t54.set(o7,i5),n4.indexes.byRelation.set(e6,t54))}}if(r5.bySubcircuit&&n4.indexes.bySubcircuit&&"subcircuit_id"in a3&&"subcircuit_id"in i4){let t53=a3.subcircuit_id;if(t53&&typeof t53=="string"){let e6=n4.indexes.bySubcircuit.get(t53)||[];e6.includes(a3)||(e6.push(a3),n4.indexes.bySubcircuit.set(t53,e6))}}if(r5.byCustomField&&n4.indexes.byCustomField){for(let t53 of r5.byCustomField)if(t53 in a3&&t53 in i4){let e6=a3[t53];if(e6!==void 0&&(typeof e6=="string"||typeof e6=="number")){let o7=String(e6),i5=n4.indexes.byCustomField.get(t53),s4=i5.get(o7)||[];s4.includes(a3)||(s4.push(a3),i5.set(o7,s4))}}}return a3},select:e6=>{if(s3==="source_component")return t52.find(t53=>t53.type==="source_component"&&t53.name===e6.replace(/\./g,""))||null;if(s3==="pcb_port"||s3==="source_port"||s3==="schematic_port"){let[n5,o6]=e6.replace(/\./g,"").split(/[\s\>]+/),i4=t52.find(t53=>t53.type==="source_component"&&t53.name===n5);if(!i4)return null;let r5=t52.find(t53=>t53.type==="source_port"&&t53.source_component_id===i4.source_component_id&&(t53.name===o6||(t53.port_hints??[]).includes(o6)));if(!r5)return null;if(s3==="source_port")return r5;if(s3==="pcb_port")return t52.find(t53=>t53.type==="pcb_port"&&t53.source_port_id===r5.source_port_id)||null;if(s3==="schematic_port")return t52.find(t53=>t53.type==="schematic_port"&&t53.source_port_id===r5.source_port_id)||null}return null}}}})};zO.unparsed=zO;var jO=t52=>{let e5=t52.obstacles.filter(e6=>!((t53,e7)=>{return!(t54=>(t54.connectedTo?.length??0)>0||(t54.offBoardConnectsTo?.length??0)>0||t54.netIsAssignable===!0)(t53)&&(e7.outline&&e7.outline.length>=3?!Me2(t53,e7.outline):(n5={minX:t53.center.x-t53.width/2,maxX:t53.center.x+t53.width/2,minY:t53.center.y-t53.height/2,maxY:t53.center.y+t53.height/2},o6=e7.bounds,n5.maxX<o6.minX||o6.maxX<n5.minX||n5.maxY<o6.minY||o6.maxY<n5.minY));var n5,o6})(e6,t52)),n4=e5.length!==t52.obstacles.length,o4=n4&&t52.outline&&t52.outline.length>=3?(t53=>{if(t53.width&&t53.height&&t53.center){let e7=t53.width/2,n6=t53.height/2;return{minX:t53.center.x-e7,minY:t53.center.y-n6,maxX:t53.center.x+e7,maxY:t53.center.y+n6,width:t53.width,height:t53.height,center:{x:t53.center.x,y:t53.center.y}}}if(!t53.outline||t53.outline.length===0)throw new Error("Unable to compute board bounds. pcb_board must include width/height/center or a non-empty outline.");let e6=Number.POSITIVE_INFINITY,n5=Number.POSITIVE_INFINITY,o6=Number.NEGATIVE_INFINITY,i3=Number.NEGATIVE_INFINITY;for(let s4 of t53.outline)e6=Math.min(e6,s4.x),n5=Math.min(n5,s4.y),o6=Math.max(o6,s4.x),i3=Math.max(i3,s4.y);let s3=o6-e6,r5=i3-n5;return{minX:e6,minY:n5,maxX:o6,maxY:i3,width:s3,height:r5,center:{x:e6+s3/2,y:n5+r5/2}}})({type:"pcb_board",pcb_board_id:"__autorouting_board_outline__",center:{x:0,y:0},thickness:1,num_layers:t52.layerCount,material:"fr4",outline:t52.outline}):t52.bounds;return n4?{...t52,obstacles:e5,bounds:o4}:t52},FO=(t52,e5)=>{try{return bt(e5,t52)}catch(e6){return console.error(e6),t52}},$O=t52=>t52.rootConnectionName??t52.connectionName,BO=(t52,e5,n4=.001)=>Math.abs(t52.x-e5.x)<=n4&&Math.abs(t52.y-e5.y)<=n4,YO=(t52,e5)=>({minX:t52.center.x-t52.width/2+e5,maxX:t52.center.x+t52.width/2-e5,minY:t52.center.y-t52.height/2+e5,maxY:t52.center.y+t52.height/2-e5}),XO=(t52,e5)=>({x:t52.x-e5.x,y:t52.y-e5.y}),HO=(t52,e5)=>t52.x*e5.x+t52.y*e5.y,WO=(t52,e5,n4)=>({x:t52.x+(e5.x-t52.x)*n4,y:t52.y+(e5.y-t52.y)*n4}),VO=(t52,e5,n4=1e-6)=>{let o4=e5.end.x-e5.start.x,i3=e5.end.y-e5.start.y,s3=o4*o4+i3*i3;if(s3<=n4)return{x:e5.start.x,y:e5.start.y,t:0};let r5=((t52.x-e5.start.x)*o4+(t52.y-e5.start.y)*i3)/s3,a3=(c4=r5,Math.max(0,Math.min(c4,1)));var c4;return{x:e5.start.x+o4*a3,y:e5.start.y+i3*a3,t:a3}},UO=(t52,e5,n4=1e-6)=>{let o4=XO(t52.end,t52.start),i3=XO(e5.end,e5.start),s3=XO(t52.start,e5.start),r5=HO(o4,o4),a3=HO(o4,i3),c4=HO(i3,i3),l4=HO(o4,s3),h6=HO(i3,s3),d4=r5*c4-a3*a3,u5=n4,p4,m4,g6=d4,f3=d4;d4<=u5?(p4=0,g6=1,m4=h6,f3=c4):(p4=a3*h6-c4*l4,m4=r5*h6-a3*l4,p4<0?(p4=0,m4=h6,f3=c4):p4>g6&&(p4=g6,m4=h6+a3,f3=c4)),m4<0?(m4=0,-l4<0?p4=0:-l4>r5?p4=g6:(p4=-l4,g6=r5)):m4>f3&&(m4=f3,-l4+a3<0?p4=0:-l4+a3>r5?p4=g6:(p4=-l4+a3,g6=r5));let _4=Math.abs(p4)<=u5?0:p4/g6,y4=Math.abs(m4)<=u5?0:m4/f3,b3=WO(t52.start,t52.end,_4),x4=WO(e5.start,e5.end,y4),v4=VO(t52.start,e5,n4),S3=VO(t52.end,e5,n4),I4=VO(e5.start,t52,n4),P4=VO(e5.end,t52,n4);return[{leftT:_4,rightT:y4,leftPoint:b3,rightPoint:x4},{leftT:0,rightT:v4.t,leftPoint:t52.start,rightPoint:v4},{leftT:1,rightT:S3.t,leftPoint:t52.end,rightPoint:S3},{leftT:I4.t,rightT:0,leftPoint:I4,rightPoint:e5.start},{leftT:P4.t,rightT:1,leftPoint:P4,rightPoint:e5.end}].sort((t53,e6)=>Math.hypot(t53.leftPoint.x-t53.rightPoint.x,t53.leftPoint.y-t53.rightPoint.y)-Math.hypot(e6.leftPoint.x-e6.rightPoint.x,e6.leftPoint.y-e6.rightPoint.y))},ZO=class{constructor(){__publicField(this,"MAX_ITERATIONS",1e3);__publicField(this,"solved",!1);__publicField(this,"failed",!1);__publicField(this,"iterations",0);__publicField(this,"progress",0);__publicField(this,"error",null);__publicField(this,"activeSubSolver");__publicField(this,"failedSubSolvers");__publicField(this,"timeToSolve");__publicField(this,"stats",{});__publicField(this,"pendingEffects");__publicField(this,"cacheHit");__publicField(this,"cacheKey");__publicField(this,"cacheToSolveSpaceTransform")}getSolverName(){return this.constructor.name}step(){if(!this.solved&&!this.failed){this.iterations++;try{this._step()}catch(t52){throw this.error=`${this.getSolverName()} error: ${t52}`,console.error(this.error),this.failed=!0,t52}!this.solved&&this.iterations>this.MAX_ITERATIONS&&this.tryFinalAcceptance(),!this.solved&&this.iterations>this.MAX_ITERATIONS&&(this.error=`${this.getSolverName()} ran out of iterations (MAX_ITERATIONS=${this.MAX_ITERATIONS})`,this.failed=!0),"computeProgress"in this&&(this.progress=this.computeProgress())}}_step(){}getConstructorParams(){throw new Error("getConstructorParams not implemented")}solve(){let t52=Date.now();for(;!this.solved&&!this.failed;)this.step();let e5=Date.now();this.timeToSolve=e5-t52}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}preview(){return{lines:[],points:[],rects:[],circles:[]}}},GO=.2,qO=.4,JO=.65+.05,KO=.03,QO=1e3,tL=1e-6,eL=.015,nL=t52=>Math.round(t52*QO)/QO,oL=(t52,e5)=>({x:t52.x-e5.x,y:t52.y-e5.y}),iL=(t52,e5)=>({x:t52.x*e5,y:t52.y*e5}),sL=(t52,e5)=>t52.x*e5.x+t52.y*e5.y,rL=(t52,e5,n4)=>({x:t52.x+(e5.x-t52.x)*n4,y:t52.y+(e5.y-t52.y)*n4}),aL=t52=>Math.max(0,Math.min(t52,1)),cL=(t52,e5,n4)=>Math.max(e5,Math.min(t52,n4)),lL=(t52,e5)=>{let n4=(t53=>Math.hypot(t53.x,t53.y))(t52);return n4<=e5||n4<=tL?t52:iL(t52,e5/n4)},hL=(t52,e5=0)=>({minX:t52.center.x-t52.width/2-e5,maxX:t52.center.x+t52.width/2+e5,minY:t52.center.y-t52.height/2-e5,maxY:t52.center.y+t52.height/2+e5}),dL=(t52,e5,n4=0)=>{let o4=hL(e5,n4);return t52.x>=o4.minX&&t52.x<=o4.maxX&&t52.y>=o4.minY&&t52.y<=o4.maxY},uL2=(t52,e5,n4)=>{let o4=[...t52.route.map(({x:t53,y:e6})=>({x:t53,y:e6})),...t52.vias.map(({x:t53,y:e6})=>({x:t53,y:e6}))];for(let t53=0;t53<e5.length;t53++){let i3=e5[t53];if(o4.every(t54=>dL(t54,i3,n4)))return t53}return-1},pL=(t52,e5,n4,o4)=>{let i3=((t53,e6,n5)=>{let o6=Math.min(Math.abs(t53.originalX-n5.minX),Math.abs(n5.maxX-t53.originalX)),i4=Math.min(Math.abs(t53.originalY-n5.minY),Math.abs(n5.maxY-t53.originalY));return Math.abs(o6-i4)<=tL?Math.abs(e6.x-t53.x)>=Math.abs(e6.y-t53.y)?"y":"x":o6<i4?"y":"x"})(t52,e5,n4);return lL(i3==="x"?{x:1.1*(t52.x-e5.x)*o4,y:0}:{x:0,y:1.1*(t52.y-e5.y)*o4},.06*o4)},mL=(t52,e5,n4,o4,i3=3.5,s3=.2,r5=.4)=>{let a3=Math.max(t52,0);if(a3>=r5)return 0;let c4=a3/s3;if(c4<1){let t53=1-c4;return e5*t53**3*(1+t53*i3)}let l4=(a3-s3)/Math.max(r5-s3,tL),h6=e5*n4*Math.exp(-l4*o4);return h6<1e-5?0:h6},gL2=(t52,e5)=>{let n4=t52.boundaryPadding>0?.001:0,o4=e5.minX+t52.boundaryPadding+n4,i3=e5.maxX-t52.boundaryPadding-n4,s3=e5.minY+t52.boundaryPadding+n4,r5=e5.maxY-t52.boundaryPadding-n4;t52.x=cL(t52.x,o4,i3),t52.y=cL(t52.y,s3,r5)},fL=(t52,e5)=>{for(let n4 of t52)for(let t53 of n4.nodes)gL2(t53,e5)},_L=t52=>t52.kind==="via"?.4:.25,yL=t52=>(t52.kind,.5),bL=t52=>t52.kind==="via"?12:3.5,xL=t52=>t52.kind==="via"?.18:.06,vL2=t52=>t52.kind==="via"?1.35:1.05,SL=(t52,e5)=>t52.kind==="via"?3*e5:e5,IL=(t52,e5,n4,o4)=>{let i3=2*e5;t52[i3]=(t52[i3]??0)+n4,t52[i3+1]=(t52[i3+1]??0)+o4},PL=(t52,e5,n4,o4,i3,s3)=>{if(t52.fixed||IL(o4,t52.node.forceIndex,e5,n4),!t52.fixed&&i3&&s3!==void 0){let t53=2*s3;i3[t53]=(i3[t53]??0)+e5,i3[t53+1]=(i3[t53+1]??0)+n4}},ML=(t52,e5,n4,o4,i3=.5)=>{let{startNode:s3,endNode:r5}=t52,a3=1-aL(i3),c4=aL(i3),l4=s3.fixed?0:a3,h6=r5.fixed?0:c4,d4=l4+h6;if(!(d4<=tL)){if(!s3.fixed&&l4>0){let t53=l4/d4;IL(o4,s3.forceIndex,e5*t53,n4*t53)}if(!r5.fixed&&h6>0){let t53=h6/d4;IL(o4,r5.forceIndex,e5*t53,n4*t53)}}},NL=(t52,e5,n4,o4,i3)=>{if(e5.fixed)return{x:0,y:0};let{minX:s3,maxX:r5,minY:a3,maxY:c4}=t52,l4=(t53=>t53.kind==="via"?.65:GO)(e5),h6=(t53=>t53.kind==="via"?JO:qO)(e5),d4=(t53=>t53.kind==="via"?.015:.08)(e5),u5=(t53=>t53.kind==="via"?80:20)(e5),p4=bL(e5);return{x:mL(n4-s3,KO,d4,u5,p4,l4,h6)*i3-mL(r5-n4,KO,d4,u5,p4,l4,h6)*i3,y:mL(o4-a3,KO,d4,u5,p4,l4,h6)*i3-mL(c4-o4,KO,d4,u5,p4,l4,h6)*i3}},CL=t52=>{if(t52.length===0)return null;let e5=new Ot2(t52.length);for(let n4 of t52){let{startNode:t53,endNode:o4}=n4;e5.add(Math.min(t53.x,o4.x),Math.min(t53.y,o4.y),Math.max(t53.x,o4.x),Math.max(t53.y,o4.y))}return e5.finish(),{index:e5,segments:t52}},TL=t52=>{let e5=new Map,n4=new Map;for(let e6 of t52){let t53=n4.get(e6.z)??[];t53.push(e6),n4.set(e6.z,t53)}for(let[t53,o4]of n4){let n5=CL(o4);n5&&e5.set(t53,n5)}return{byLayer:e5}},wL2=(t52,e5,n4,o4,i3)=>{let s3=t53=>({candidateIndexes:t53.index.search(n4-i3,o4-i3,n4+i3,o4+i3),segments:t53.segments});if(e5.kind==="point"){let n5=t52.byLayer.get(e5.z);return n5?[s3(n5)]:[]}let r5=[];for(let e6 of t52.byLayer.values())r5.push(s3(e6));return r5},RL=t52=>{let e5=[];for(let n4=0;n4<t52.route.length-1;n4+=1){let o4=t52.route[n4],i3=t52.route[n4+1];if(!o4||!i3||o4.z===i3.z||Math.abs(o4.x-i3.x)>tL||Math.abs(o4.y-i3.y)>tL)continue;let s3=e5.at(-1),r5={x:nL(o4.x),y:nL(o4.y)};s3&&s3.x===r5.x&&s3.y===r5.y||e5.push(r5)}return e5},EL=t52=>{let e5=[];for(let n4=0;n4<t52.length;n4+=1){let o4=t52[n4];if(!o4)continue;let i3=new Set;for(let t53=0;t53<o4.route.length-1;t53+=1){let s3=o4.route[t53],r5=o4.route[t53+1];if(!s3||!r5||s3.z===r5.z||!BO(s3,r5))continue;let a3=[t53,t53+1];for(let e6=t53-1;e6>=0;e6-=1){let t54=o4.route[e6];if(!t54||!BO(t54,s3))break;a3.push(e6)}for(let e6=t53+2;e6<o4.route.length;e6+=1){let t54=o4.route[e6];if(!t54||!BO(t54,s3))break;a3.push(e6)}let c4=[...new Set(a3)].sort((t54,e6)=>t54-e6),l4=!1;for(let t54 of c4)if(i3.has(t54)){l4=!0;break}if(!l4){for(let t54 of c4)i3.add(t54);e5.push({routeIndex:n4,rootConnectionName:$O(o4),pointIndexes:c4,x:s3.x,y:s3.y,radius:(o4.viaDiameter??.3)/2,movable:!c4.includes(0)&&!c4.includes(o4.route.length-1)})}}}return e5},AL2=t52=>{let e5=[];for(let n4=0;n4<t52.length;n4+=1){let o4=t52[n4];if(o4)for(let t53=0;t53<o4.route.length-1;t53+=1){let i3=o4.route[t53],s3=o4.route[t53+1];i3&&s3&&(i3.z!==s3.z||BO(i3,s3)||e5.push({routeIndex:n4,rootConnectionName:$O(o4),startIndex:t53,endIndex:t53+1,start:i3,end:s3,z:i3.z,traceRadius:(o4.traceThickness??.1)/2}))}}return e5},OL=t52=>{let{routes:e5,via:n4,dx:o4,dy:i3,node:s3}=t52;if(!n4.movable)return!1;n4.x+=o4,n4.y+=i3,((t53,e6)=>{let n5=YO(e6,t53.radius+tL);t53.x=cL(t53.x,n5.minX,n5.maxX),t53.y=cL(t53.y,n5.minY,n5.maxY)})(n4,s3);let r5=e5[n4.routeIndex];if(!r5)return!1;for(let t53 of n4.pointIndexes){let e6=r5.route[t53];e6&&(e6.x=n4.x,e6.y=n4.y)}return!0},LL=t52=>{let{routes:e5,node:n4,vias:o4}=t52,i3=!1;for(let t53=0;t53<o4.length;t53+=1){let s3=o4[t53];if(s3)for(let r5=t53+1;r5<o4.length;r5+=1){let a3=o4[r5];if(!a3)continue;let c4=s3.radius+a3.radius+.1+eL,l4=s3.x-a3.x,h6=s3.y-a3.y,d4=Math.hypot(l4,h6),u5=c4-d4;if(u5<=0)continue;let p4=1.61803398875*(97*t53+13*r5),m4=d4>tL?l4/d4:Math.cos(p4),g6=d4>tL?h6/d4:Math.sin(p4),f3=Number(s3.movable)+Number(a3.movable);if(f3===0)continue;let _4=Math.min(.04,u5/f3);i3=OL({routes:e5,via:s3,dx:m4*_4,dy:g6*_4,node:n4})||i3,i3=OL({routes:e5,via:a3,dx:-m4*_4,dy:-g6*_4,node:n4})||i3}}return i3},kL=t52=>{let{routes:e5,node:n4,vias:o4,segments:i3}=t52,s3=!1;for(let t53=0;t53<o4.length;t53+=1){let r5=o4[t53];if(r5?.movable)for(let o6 of i3){if(r5.rootConnectionName===o6.rootConnectionName)continue;let i4=VO(r5,o6),a3=r5.x-i4.x,c4=r5.y-i4.y,l4=Math.hypot(a3,c4),h6=r5.radius+o6.traceRadius+.1+eL-l4;if(h6<=0)continue;let d4=o6.end.x-o6.start.x,u5=o6.end.y-o6.start.y,p4=Math.hypot(d4,u5),m4=t53%2==0?1:-1,g6=l4>tL?a3/l4:p4>tL?-u5/p4*m4:1,f3=l4>tL?c4/l4:p4>tL?d4/p4*m4:0,_4=Math.min(.04,h6);s3=OL({routes:e5,via:r5,dx:g6*_4,dy:f3*_4,node:n4})||s3}}return s3},DL=t52=>{let{routes:e5,routeIndex:n4,pointIndex:o4,dx:i3,dy:s3,node:r5}=t52,a3=e5[n4];if(!a3||o4<=0||o4>=a3.route.length-1)return!1;let c4=((t53,e6,n5=.001)=>{let o6=t53[e6];if(!o6)return[];let i4=[e6];for(let s4=e6-1;s4>=0;s4-=1){let e7=t53[s4];if(!e7||!BO(e7,o6,n5))break;i4.push(s4)}for(let s4=e6+1;s4<t53.length;s4+=1){let e7=t53[s4];if(!e7||!BO(e7,o6,n5))break;i4.push(s4)}return[...new Set(i4)]})(a3.route,o4);if(c4.includes(0)||c4.includes(a3.route.length-1))return!1;let l4=YO(r5,tL),h6=!1;for(let t53 of c4){let e6=a3.route[t53];e6&&(e6.x=cL(e6.x+i3,l4.minX,l4.maxX),e6.y=cL(e6.y+s3,l4.minY,l4.maxY),h6=!0)}return h6},zL=t52=>{let{routes:e5,segment:n4,dx:o4,dy:i3,node:s3,t:r5}=t52,a3=1-aL(r5),c4=aL(r5),l4=DL({routes:e5,routeIndex:n4.routeIndex,pointIndex:n4.startIndex,dx:o4*a3,dy:i3*a3,node:s3}),h6=DL({routes:e5,routeIndex:n4.routeIndex,pointIndex:n4.endIndex,dx:o4*c4,dy:i3*c4,node:s3});return l4||h6},jL=t52=>{let{routes:e5,node:n4,segments:o4}=t52,i3=!1;for(let t53=0;t53<o4.length;t53+=1){let s3=o4[t53];if(s3)for(let r5=t53+1;r5<o4.length;r5+=1){let a3=o4[r5];if(!a3||s3.z!==a3.z||s3.rootConnectionName===a3.rootConnectionName)continue;let[c4]=UO(s3,a3);if(!c4)continue;let l4=c4.leftPoint.x-c4.rightPoint.x,h6=c4.leftPoint.y-c4.rightPoint.y,d4=Math.hypot(l4,h6),u5=s3.traceRadius+a3.traceRadius+.1+eL-d4;if(u5<=0)continue;let p4=s3.end.x-s3.start.x,m4=s3.end.y-s3.start.y,g6=Math.hypot(p4,m4),f3=(t53+r5)%2==0?1:-1,_4=d4>tL?l4/d4:g6>tL?-m4/g6*f3:1,y4=d4>tL?h6/d4:g6>tL?p4/g6*f3:0,b3=Math.min(.025,u5/2);i3=zL({routes:e5,segment:s3,dx:_4*b3,dy:y4*b3,node:n4,t:c4.leftT})||i3,i3=zL({routes:e5,segment:a3,dx:-_4*b3,dy:-y4*b3,node:n4,t:c4.rightT})||i3}}return i3},FL=(t52,e5,n4,o4,i3,s3=3,r5=.02)=>{for(let a3=0;a3<s3;a3+=1){i3.fill(0);let s4=TL(o4);for(let t53=0;t53<n4.length;t53+=1){let e6=n4[t53];if(!e6||e6.kind!=="via")continue;let o6=e6.node;for(let s5=t53+1;s5<n4.length;s5+=1){let c4=n4[s5];if(!c4||c4.kind!=="via"||e6.rootConnectionName===c4.rootConnectionName)continue;let l4=c4.node,h6=o6.x-l4.x,d4=o6.y-l4.y;if(Math.abs(h6)>=GO||Math.abs(d4)>=GO)continue;let u5=Math.hypot(h6,d4),p4=GO-u5;if(p4<=0)continue;let m4=0,g6=0;if(u5>tL){let t54=1/u5;m4=h6*t54,g6=d4*t54}else{let e7=1.61803398875*(1009*a3+97*t53+13*s5);m4=Math.cos(e7),g6=Math.sin(e7)}let f3=Math.min(r5,.9*p4),_4=m4*f3,y4=g6*f3;PL(e6,_4,y4,i3),PL(c4,-_4,-y4,i3)}}for(let t53=0;t53<n4.length;t53+=1){let e6=n4[t53];if(!e6)continue;let o6=e6.node,c4=_L(e6),l4=wL2(s4,e6,o6.x,o6.y,c4);for(let n5 of l4)for(let s5 of n5.candidateIndexes){let l5=n5.segments[s5];if(!l5||e6.rootConnectionName===l5.rootConnectionName)continue;let{startNode:h6,endNode:d4}=l5,u5=d4.x-h6.x,p4=d4.y-h6.y,m4=u5*u5+p4*p4;if(m4<=tL)continue;let g6=o6.x-h6.x,f3=o6.y-h6.y,_4=aL((g6*u5+f3*p4)/m4),y4=h6.x+u5*_4,b3=h6.y+p4*_4,x4=o6.x-y4,v4=o6.y-b3,S3=Math.hypot(x4,v4),I4=c4-S3;if(I4<=0)continue;let P4=1009*a3+97*t53+13*l5.obstacleIndex,M4=0,N4=0;if(S3>tL){let t54=1/S3;M4=x4*t54,N4=v4*t54}else{let t54=-p4,e7=u5,n6=Math.hypot(t54,e7);if(n6>tL){let o7=(P4%2==0?1:-1)/n6;M4=t54*o7,N4=e7*o7}else{let t55=1.61803398875*P4;M4=Math.cos(t55),N4=Math.sin(t55)}}let C4=Math.min(SL(e6,r5),I4*vL2(e6)),T4=M4*C4,w4=N4*C4;PL(e6,T4,w4,i3),ML(l5,-T4,-w4,i3,_4)}}for(let t53=0;t53<e5.length;t53+=1){let n5=e5[t53];if(n5)for(let t54=0;t54<n5.nodes.length;t54+=1){let e6=n5.nodes[t54];if(!e6||e6.fixed)continue;let o6=2*e6.forceIndex,s5=i3[o6]??0,a4=i3[o6+1]??0,c4=Math.hypot(s5,a4);if(c4>r5&&c4>tL){let t55=r5/c4;s5*=t55,a4*=t55}e6.x+=s5,e6.y+=a4}}fL(e5,t52)}},$L=(t52,e5,n4,o4)=>{let{mutableRoutes:i3,totalNodeCount:s3}=(t53=>{let e6=0;return{mutableRoutes:t53.map(t54=>{let n5=[],o6=new Int32Array(t54.route.length);o6.fill(-1);for(let i4=0;i4<t54.route.length;i4+=1){let s4=t54.route[i4];if(!s4)continue;let r6=t54.route[i4-1],a4=n5.at(-1),c5=n5.length-1;a4&&r6&&r6.x===s4.x&&r6.y===s4.y?(r6.z!==s4.z&&(a4.boundaryPadding=Math.max(a4.boundaryPadding,t54.viaDiameter/2)),a4.pointIndexes.push(i4),o6[i4]=c5):(n5.push({x:s4.x,y:s4.y,originalX:s4.x,originalY:s4.y,boundaryPadding:0,pointIndexes:[i4],fixed:i4===0||i4===t54.route.length-1,forceIndex:e6}),o6[i4]=n5.length-1,e6+=1)}return{route:t54,rootConnectionName:t54.rootConnectionName??t54.connectionName,nodes:n5,pointNodeIndexes:o6}}),totalNodeCount:e6}})(e5),r5=(t53=>{let e6=[];for(let n5=0;n5<t53.length;n5+=1){let o6=t53[n5];if(o6)for(let t54=0;t54<o6.nodes.length;t54+=1){let i4=o6.nodes[t54],s4=i4?.pointIndexes[0],r6=s4===void 0?void 0:o6.route.route[s4];i4&&r6&&(i4.pointIndexes.length>1?e6.push({kind:"via",routeIndex:n5,rootConnectionName:o6.rootConnectionName,node:i4,fixed:i4.fixed}):e6.push({kind:"point",routeIndex:n5,rootConnectionName:o6.rootConnectionName,node:i4,z:r6.z,fixed:i4.fixed}))}}return e6})(i3),a3=(t53=>{let e6=[];for(let n5=0;n5<t53.length;n5+=1){let o6=t53[n5];if(o6)for(let t54=0;t54<o6.nodes.length-1;t54+=1){let n6=o6.nodes[t54],i4=o6.nodes[t54+1],s4=n6?.pointIndexes[0],r6=s4===void 0?void 0:o6.route.route[s4];n6&&i4&&r6&&e6.push({obstacleIndex:e6.length,rootConnectionName:o6.rootConnectionName,z:r6.z,startNode:n6,endNode:i4})}}return e6})(i3),c4=new Float64Array(2*s3),l4=new Float64Array(2*s3),h6=o4?.includeForceVectors??!0;fL(i3,t52);let d4=[];for(let e6=0;e6<n4;e6+=1){let o6=n4<=1?0:e6/Math.max(n4-1,1),s4=.25+.75*(1-o6),u6=1-o6,p4=h6&&e6===n4-1,m4=p4?new Float64Array(2*r5.length):void 0;c4.fill(0);for(let t53=0;t53<r5.length;t53+=1){let e7=r5[t53];if(!e7||e7.kind!=="via")continue;let n5=e7.node;for(let o7=t53+1;o7<r5.length;o7+=1){let i4=r5[o7];if(!i4||i4.kind!=="via"||e7.rootConnectionName===i4.rootConnectionName)continue;let a4=i4.node,l5=n5.x-a4.x,h7=n5.y-a4.y;if(Math.abs(l5)>=qO||Math.abs(h7)>=qO)continue;let d5=Math.hypot(l5,h7),u7=0,p5=0;if(d5>tL){let t54=1/d5;u7=l5*t54,p5=h7*t54}else{let e8=1.61803398875*(97*t53+13*o7);u7=Math.cos(e8),p5=Math.sin(e8)}let g7=mL(d5,.034,.08,18)*s4;if(g7<=0)continue;let f3=u7*g7,_4=p5*g7;PL(e7,f3,_4,c4,m4,t53),PL(i4,-f3,-_4,c4,m4,o7)}}let g6=TL(a3);for(let t53=0;t53<r5.length;t53+=1){let e7=r5[t53];if(!e7)continue;let n5=e7.node,o7=yL(e7),i4=wL2(g6,e7,n5.x,n5.y,o7);for(let r6 of i4)for(let i5 of r6.candidateIndexes){let a4=r6.segments[i5];if(!a4||e7.rootConnectionName===a4.rootConnectionName)continue;let{startNode:l5,endNode:h7}=a4,d5=h7.x-l5.x,u7=h7.y-l5.y,p5=d5*d5+u7*u7;if(p5<=tL)continue;let g7=n5.x-l5.x,f3=n5.y-l5.y,_4=aL((g7*d5+f3*u7)/p5),y4=l5.x+d5*_4,b3=l5.y+u7*_4,x4=n5.x-y4,v4=n5.y-b3,S3=Math.hypot(x4,v4),I4=97*t53+13*a4.obstacleIndex,P4=0,M4=0;if(S3>tL){let t54=1/S3;P4=x4*t54,M4=v4*t54}else{let t54=-u7,e8=d5,n6=Math.hypot(t54,e8);if(n6>tL){let o8=(I4%2==0?1:-1)/n6;P4=t54*o8,M4=e8*o8}else{let t55=1.61803398875*I4;P4=Math.cos(t55),M4=Math.sin(t55)}}let N4=mL(S3,xL(e7),.08,18,bL(e7),_L(e7),o7)*s4;if(N4<=0)continue;let C4=P4*N4,T4=M4*N4;PL(e7,C4,T4,c4,m4,t53),ML(a4,-C4,-T4,c4,_4)}}p4&&(d4=new Array(r5.length));for(let e7=0;e7<r5.length;e7+=1){let n5=r5[e7];if(!n5)continue;let o7=n5.node,i4=NL(t52,n5,o7.x,o7.y,s4);if(PL(n5,i4.x,i4.y,c4,m4,e7),p4&&m4){let t53=2*e7;d4[e7]={kind:n5.kind,routeIndex:n5.routeIndex,rootConnectionName:n5.rootConnectionName,x:o7.x,y:o7.y,dx:m4[t53]??0,dy:m4[t53+1]??0}}}for(let e7=0;e7<i3.length;e7+=1){let n5=i3[e7];if(!n5)continue;let o7=n5.nodes.length-2;for(let e8=0;e8<n5.nodes.length;e8+=1){let i4=n5.nodes[e8];if(!i4||i4.fixed)continue;let r6=2*i4.forceIndex,a4=(c4[r6]??0)+.14*(i4.originalX-i4.x),l5=(c4[r6+1]??0)+.14*(i4.originalY-i4.y),h7=0,d5=0,p5=0,m6=0,g7=n5.nodes[e8-1],f3=n5.nodes[e8+1];if(g7||f3){let t53=0,e10=0,n6=0;if(g7&&(t53+=g7.x,e10+=g7.y,n6+=1),f3&&(t53+=f3.x,e10+=f3.y,n6+=1),n6>0){let o8=1/n6;a4+=.22*(t53*o8-i4.x),l5+=.22*(e10*o8-i4.y)}}if(g7&&f3&&u6>0){let t53=oL(f3,g7),e10=sL(t53,t53);if(e10>tL){let n6=aL(sL(oL(i4,g7),t53)/e10),o8=rL(g7,f3,n6),s5=lL(iL(oL(o8,i4),.55*u6),.02*u6);h7=s5.x,d5=s5.y}}if(u6>0){if(e8===1&&g7?.fixed){let e10=pL(g7,i4,t52,u6);p5+=e10.x,m6+=e10.y}if(e8===o7&&f3?.fixed){let e10=pL(f3,i4,t52,u6);p5+=e10.x,m6+=e10.y}}let _4=.85*a4*s4,y4=.85*l5*s4,b3=Math.hypot(_4,y4),x4=.012*s4;if(b3>x4&&b3>tL){let t53=x4/b3;_4*=t53,y4*=t53}i4.x+=_4+h7+p5,i4.y+=y4+d5+m6}}fL(i3,t52),FL(t52,i3,r5,a3,l4,3,.02)}return FL(t52,i3,r5,a3,l4,8,.03),{routes:(t53=>t53.map(({route:t54,nodes:e6,pointNodeIndexes:n5})=>{let o6=t54.route.map((t55,o7)=>{let i5=n5[o7]??-1,s4=i5>=0?e6[i5]:void 0;return s4?{...t55,x:nL(s4.x),y:nL(s4.y)}:t55}),i4={...t54,route:o6,vias:[]};return i4.vias=RL(i4),i4}))(i3),forceVectors:d4,stepsCompleted:n4}},BL=class extends ZO{constructor(t52){super();__publicField(this,"sampleEntries");__publicField(this,"originalHdRoutes");__publicField(this,"originalNodeWithPortPoints");__publicField(this,"colorMap");__publicField(this,"totalStepsPerNode");__publicField(this,"nodeAssignmentMargin");__publicField(this,"improvedRoutesByIndex",new Map);__publicField(this,"activeSampleIndex",0);__publicField(this,"latestVisualization",{});this.originalHdRoutes=t52.hdRoutes,this.originalNodeWithPortPoints=t52.nodeWithPortPoints,this.colorMap=t52.colorMap??{},this.totalStepsPerNode=t52.totalStepsPerNode??60,this.nodeAssignmentMargin=t52.nodeAssignmentMargin??.2;let e5=new Map;for(let n4=0;n4<t52.hdRoutes.length;n4++){let o4=uL2(t52.hdRoutes[n4],t52.nodeWithPortPoints,this.nodeAssignmentMargin);if(o4===-1)continue;let i3=e5.get(o4)??[];i3.push(n4),e5.set(o4,i3)}this.sampleEntries=Array.from(e5.entries()).map(([e6,n4])=>({node:t52.nodeWithPortPoints[e6],routeIndexes:n4})),this.MAX_ITERATIONS=Math.max(10*this.sampleEntries.length,1e3),this.stats={nodeAssignmentMargin:this.nodeAssignmentMargin,sampleCount:this.sampleEntries.length,improvedNodeCount:0,improvedRouteCount:0,totalStepsPerNode:this.totalStepsPerNode}}getSolverName(){return"HighDensityForceImproveSolver"}getConstructorParams(){return[{nodeWithPortPoints:this.originalNodeWithPortPoints,hdRoutes:this.originalHdRoutes,totalStepsPerNode:this.totalStepsPerNode,nodeAssignmentMargin:this.nodeAssignmentMargin,colorMap:this.colorMap}]}_step(){let t52=this.sampleEntries[this.activeSampleIndex];if(!t52)return void(this.solved=!0);let e5=hL(t52.node),n4=t52.routeIndexes.map(t53=>this.originalHdRoutes[t53]),o4=$L(e5,n4,this.totalStepsPerNode,{includeForceVectors:!0});((t53,e6)=>{for(let n5=0;n5<10;n5+=1){let n6=EL(e6),o6=AL2(e6),i3=LL({routes:e6,node:t53,vias:n6}),s3=kL({routes:e6,node:t53,vias:n6,segments:o6}),r5=jL({routes:e6,node:t53,segments:o6});if(!i3&&!s3&&!r5)break}for(let t54 of e6)t54.vias=RL(t54)})(t52.node,o4.routes);for(let e6=0;e6<t52.routeIndexes.length;e6++)this.improvedRoutesByIndex.set(t52.routeIndexes[e6],o4.routes[e6]);this.latestVisualization=YL({node:t52.node,routes:o4.routes,forceVectors:o4.forceVectors,colorMap:this.colorMap}),this.activeSampleIndex+=1,this.stats={nodeAssignmentMargin:this.nodeAssignmentMargin,sampleCount:this.sampleEntries.length,improvedNodeCount:this.activeSampleIndex,improvedRouteCount:this.improvedRoutesByIndex.size,totalStepsPerNode:this.totalStepsPerNode},this.activeSampleIndex>=this.sampleEntries.length&&(this.solved=!0)}getOutput(){return this.originalHdRoutes.map((t52,e5)=>this.improvedRoutesByIndex.get(e5)??t52)}visualize(){return this.solved?YL({routes:this.getOutput(),colorMap:this.colorMap}):this.latestVisualization}},YL=t52=>{let e5=[],n4=[],o4=[];t52.node&&o4.push({center:t52.node.center,width:t52.node.width,height:t52.node.height,stroke:"rgba(14,165,233,0.7)",fill:"rgba(14,165,233,0.04)",label:t52.node.capacityMeshNodeId});for(let o6 of t52.routes){let i3=t52.colorMap?.[o6.connectionName]??"#0ea5e9";for(let t53=0;t53<o6.route.length-1;t53++){let n5=o6.route[t53],s3=o6.route[t53+1];n5.z===s3.z&&e5.push({points:[{x:n5.x,y:n5.y},{x:s3.x,y:s3.y}],strokeColor:n5.z===0?i3:FO(i3,.5),strokeWidth:o6.traceThickness,layer:`z${n5.z}`,strokeDash:n5.z!==0?[.1,.3]:void 0})}for(let t53 of o6.vias)n4.push({center:{x:t53.x,y:t53.y},radius:o6.viaDiameter/2,stroke:i3,fill:"rgba(14,165,233,0.12)"})}for(let n5 of t52.forceVectors??[])e5.push({points:[{x:n5.x,y:n5.y},{x:n5.x+5*n5.dx,y:n5.y+5*n5.dy}],strokeColor:"rgba(244,63,94,0.85)",strokeWidth:.06,strokeDash:[.08,.08]});return{lines:e5,circles:n4,rects:o4}};function XL(t52,e5){return t52.x>=e5.center.x-e5.width/2&&t52.x<=e5.center.x+e5.width/2&&t52.y>=e5.center.y-e5.height/2&&t52.y<=e5.center.y+e5.height/2}var HL="escape-via:",WL=1e-4,VL=t52=>t52.obstacleId??[t52.layers.join("."),t52.center.x.toFixed(4),t52.center.y.toFixed(4),t52.width.toFixed(4),t52.height.toFixed(4)].join(":"),UL=(t52,e5,n4=1e-4)=>ge2(t52,e5)<=n4,ZL=class extends Ao2{constructor(t52,e5={}){super();__publicField(this,"ogSrj");__publicField(this,"viaDiameter");__publicField(this,"viaRadius");__publicField(this,"minTraceWidth");__publicField(this,"obstacleMargin");__publicField(this,"escapeOffset");__publicField(this,"requiredTraceClearance");__publicField(this,"requiredViaToViaClearance");__publicField(this,"outputSrj");__publicField(this,"escapeViaMetadataByPointId");__publicField(this,"createdEscapeVias");__publicField(this,"nextEscapeViaIndex",0);this.ogSrj=t52,this.viaDiameter=e5.viaDiameter??Mo2(t52).padDiameter,this.viaRadius=this.viaDiameter/2,this.minTraceWidth=e5.minTraceWidth??t52.minTraceWidth,this.obstacleMargin=e5.obstacleMargin??t52.defaultObstacleMargin??.15,this.escapeOffset=this.viaRadius+Math.max(this.minTraceWidth/2,this.obstacleMargin),this.requiredTraceClearance=this.minTraceWidth/2+this.obstacleMargin/2,this.requiredViaToViaClearance=this.viaDiameter+this.obstacleMargin,this.outputSrj=t52,this.escapeViaMetadataByPointId=new Map,this.createdEscapeVias=[]}getSolverName(){return"EscapeViaLocationSolver"}getConnectionNetIds(t52){return new Set([t52.name,t52.rootConnectionName,t52.netConnectionName,...t52.mergedConnectionNames??[]].filter(t53=>!!t53))}obstacleMatchesConnectionNet(t52,e5){return t52.connectedTo.some(t53=>e5.has(t53))}getObstacleZs(t52){return t52.zLayers&&t52.zLayers.length>0?t52.zLayers:t52.layers.map(t53=>xo2(t53,this.ogSrj.layerCount))}getViaSpanLayers(t52,e5){let n4=xo2(t52,this.ogSrj.layerCount),o4=xo2(e5,this.ogSrj.layerCount),i3=Math.min(n4,o4),s3=Math.max(n4,o4),r5=Array.from({length:s3-i3+1},(t53,e6)=>i3+e6);return{zLayers:r5,layers:r5.map(t53=>so2(t53,this.ogSrj.layerCount))}}createEscapeViaObstacle(t52){let{escapeVia:e5,connectionNetIds:n4}=t52,{layers:o4,zLayers:i3}=this.getViaSpanLayers(e5.sourceLayer,e5.targetLayer);return{obstacleId:`escape-via-obstacle:${e5.pointId}`,type:"rect",layers:o4,zLayers:i3,center:{x:e5.x,y:e5.y},width:this.viaDiameter,height:this.viaDiameter,connectedTo:Array.from(n4)}}selectSourceObstacle(t52){let{point:e5,sourceLayer:n4,connectionNetIds:o4}=t52;return this.ogSrj.obstacles.filter(t53=>!t53.isCopperPour&&t53.layers.includes(n4)&&XL(e5,t53)).sort((t53,n5)=>{let i3=t53.connectedTo.includes(e5.pointId??"")||t53.connectedTo.includes(e5.pcb_port_id??"")||this.obstacleMatchesConnectionNet(t53,o4);return i3!==(n5.connectedTo.includes(e5.pointId??"")||n5.connectedTo.includes(e5.pcb_port_id??"")||this.obstacleMatchesConnectionNet(n5,o4))?i3?-1:1:t53.width*t53.height-n5.width*n5.height})[0]}getCandidatePositions(t52,e5){if(!e5)return this.dedupeCandidatePositions([{x:t52.x+this.escapeOffset,y:t52.y},{x:t52.x-this.escapeOffset,y:t52.y},{x:t52.x,y:t52.y+this.escapeOffset},{x:t52.x,y:t52.y-this.escapeOffset},{x:t52.x+this.escapeOffset,y:t52.y+this.escapeOffset},{x:t52.x+this.escapeOffset,y:t52.y-this.escapeOffset},{x:t52.x-this.escapeOffset,y:t52.y+this.escapeOffset},{x:t52.x-this.escapeOffset,y:t52.y-this.escapeOffset}]);let n4=e5.center.x-e5.width/2,o4=e5.center.x+e5.width/2,i3=e5.center.y-e5.height/2,s3=e5.center.y+e5.height/2,r5=n4-this.escapeOffset,a3=o4+this.escapeOffset,c4=i3-this.escapeOffset,l4=s3+this.escapeOffset,h6=this.getEdgeSamples(i3,s3,t52.y),d4=this.getEdgeSamples(n4,o4,t52.x),u5=[];for(let t53 of h6)u5.push({x:r5,y:t53},{x:a3,y:t53});for(let t53 of d4)u5.push({x:t53,y:c4},{x:t53,y:l4});return this.dedupeCandidatePositions(u5)}dedupeCandidatePositions(t52){let e5=[];for(let n4 of t52)e5.some(t53=>UL(t53,n4))||e5.push(n4);return e5}pushEdgeSample(t52,e5,n4,o4){let i3=Math.max(n4,Math.min(o4,e5));t52.some(t53=>Math.abs(t53-i3)<=WL)||t52.push(i3)}getEdgeSamples(t52,e5,n4){let o4=[],i3=e5-t52;if(this.pushEdgeSample(o4,n4,t52,e5),i3<=WL)return o4;this.pushEdgeSample(o4,t52,t52,e5),this.pushEdgeSample(o4,e5,t52,e5),this.pushEdgeSample(o4,(t52+e5)/2,t52,e5);let s3=Math.max(t52,Math.min(e5,n4)),r5=Math.max(this.requiredViaToViaClearance,WL),a3=Math.ceil(i3/r5);for(let n5=1;n5<=a3;n5++){let i4=n5*r5;this.pushEdgeSample(o4,s3+i4,t52,e5),this.pushEdgeSample(o4,s3-i4,t52,e5)}return o4}isInsideBoard(t52){return t52.x>=this.ogSrj.bounds.minX+this.viaRadius&&t52.x<=this.ogSrj.bounds.maxX-this.viaRadius&&t52.y>=this.ogSrj.bounds.minY+this.viaRadius&&t52.y<=this.ogSrj.bounds.maxY-this.viaRadius&&(!(this.ogSrj.outline&&this.ogSrj.outline.length>=3)||Rr2(t52,this.ogSrj.outline))}hasClearEscapePath(t52){let{sourcePoint:e5,candidate:n4,sourceLayer:o4,sourceObstacle:i3}=t52;if(this.ogSrj.outline&&this.ogSrj.outline.length>=3&&Er2({start:e5,end:n4,polygon:this.ogSrj.outline,margin:this.requiredTraceClearance}))return!1;for(let t53 of this.ogSrj.obstacles){if(t53===i3||!t53.layers.includes(o4))continue;if(XL(n4,t53))return!1;let s3=$a2(t53);if(Math.min(...s3.map(t54=>vr2(e5,n4,t54.start,t54.end)))+WL<this.requiredTraceClearance)return!1}return!0}getBoardBoundarySegments(){if(this.ogSrj.outline&&this.ogSrj.outline.length>=3)return this.ogSrj.outline.map((t53,e6)=>({start:t53,end:this.ogSrj.outline[(e6+1)%this.ogSrj.outline.length]}));let{minX:t52,maxX:e5,minY:n4,maxY:o4}=this.ogSrj.bounds;return[{start:{x:t52,y:n4},end:{x:e5,y:n4}},{start:{x:e5,y:n4},end:{x:e5,y:o4}},{start:{x:e5,y:o4},end:{x:t52,y:o4}},{start:{x:t52,y:o4},end:{x:t52,y:n4}}]}getRayProbeDistance(){let{minX:t52,maxX:e5,minY:n4,maxY:o4}=this.ogSrj.bounds;return 2*Math.hypot(e5-t52,o4-n4)+this.viaDiameter}getRayIntersectionDistance(t52){let{rayStart:e5,rayEnd:n4,segmentStart:o4,segmentEnd:i3}=t52;if(!de2(e5,n4,o4,i3))return null;let s3=fe2(e5,n4,o4,i3);if(!s3)return null;let r5=ge2(e5,s3);return r5<=WL?null:r5}getProjectedFreeSpace(t52){let{sourcePoint:e5,candidate:n4}=t52,o4=n4.x-e5.x,i3=n4.y-e5.y;return Math.abs(o4)<=WL||Math.abs(i3)<=WL?this.getProjectedFreeSpaceAlongDirection({...t52,direction:{x:o4,y:i3},travelDistance:ge2(e5,n4)}):Math.min(this.getProjectedFreeSpaceAlongDirection({...t52,direction:{x:0,y:Math.sign(i3)},travelDistance:Math.abs(i3)}),this.getProjectedFreeSpaceAlongDirection({...t52,direction:{x:Math.sign(o4),y:Math.sign(i3)},travelDistance:ge2(e5,n4)}),this.getProjectedFreeSpaceAlongDirection({...t52,direction:{x:Math.sign(o4),y:0},travelDistance:Math.abs(o4)}))}getProjectedFreeSpaceAlongDirection(t52){let{sourcePoint:e5,sourceLayer:n4,sourceObstacle:o4,direction:i3,travelDistance:s3}=t52,r5=Math.hypot(i3.x,i3.y);if(r5<=WL||s3<=WL)return 0;let a3=this.getRayProbeDistance(),c4=i3.x/r5,l4=i3.y/r5,h6={x:e5.x+c4*a3,y:e5.y+l4*a3},d4=Number.POSITIVE_INFINITY;for(let t53 of this.ogSrj.obstacles)if(t53!==o4&&t53.layers.includes(n4))for(let n5 of $a2(t53)){let t54=this.getRayIntersectionDistance({rayStart:e5,rayEnd:h6,segmentStart:n5.start,segmentEnd:n5.end});t54!==null&&(d4=Math.min(d4,t54))}for(let t53 of this.getBoardBoundarySegments()){let n5=this.getRayIntersectionDistance({rayStart:e5,rayEnd:h6,segmentStart:t53.start,segmentEnd:t53.end});n5!==null&&(d4=Math.min(d4,n5))}return Number.isFinite(d4)?Math.max(0,d4-s3):0}getMinBlockingClearance(t52){let{candidate:e5,connectionNetIds:n4,sourceZ:o4,targetZ:i3}=t52,s3=Math.min(o4,i3),r5=Math.max(o4,i3),a3=Number.POSITIVE_INFINITY;for(let t53 of this.ogSrj.obstacles){let n5=this.getObstacleZs(t53);if(!n5.some(t54=>t54>=s3&&t54<=r5)||t53.isCopperPour&&!n5.includes(o4))continue;let i4=_e2(e5,t53)-this.viaRadius;if(a3=Math.min(a3,i4),a3+WL<this.obstacleMargin)return a3}return a3}getMinPlacedEscapeViaClearance(t52){let e5=Number.POSITIVE_INFINITY;for(let n4 of this.createdEscapeVias){let o4=ge2(t52,n4)-this.viaDiameter;if(e5=Math.min(e5,o4),e5+WL<this.obstacleMargin)return e5}return e5}selectPointOwner(t52){let{point:e5,groupConnections:n4,matchingCopperPours:o4}=t52,i3=Qs2(e5),s3=n4.map(t53=>({connection:t53,pointIndex:t53.pointsToConnect.findIndex(t54=>Qs2(t54)===i3)})).filter(t53=>t53.pointIndex!==-1);return s3.length===0?null:(s3.sort((t53,e6)=>{let n5=o4.some(e7=>this.obstacleMatchesConnectionNet(e7,this.getConnectionNetIds(t53.connection)));return n5!==o4.some(t54=>this.obstacleMatchesConnectionNet(t54,this.getConnectionNetIds(e6.connection)))?n5?-1:1:t53.pointIndex-e6.pointIndex}),s3[0])}findBestEscapeViaCandidate(t52){let{connection:e5,point:n4,pointIndex:o4,matchingCopperPours:i3,connectionNetIds:s3,sourceObstacle:r5}=t52;if(!no2(n4))return null;let a3=n4.layer,c4=xo2(a3,this.ogSrj.layerCount),l4=r5??this.selectSourceObstacle({point:n4,sourceLayer:a3,connectionNetIds:s3}),h6=this.getCandidatePositions(n4,l4),d4=null;for(let t53 of i3){let i4=t53.layers[0];if(!i4||i4===a3)continue;let r6=xo2(i4,this.ogSrj.layerCount),u5=VL(t53);for(let p4 of h6){if(!this.isInsideBoard(p4)||!XL(p4,t53)||!this.hasClearEscapePath({sourcePoint:n4,candidate:p4,sourceLayer:a3,sourceObstacle:l4}))continue;let h7=this.getMinBlockingClearance({candidate:p4,connectionNetIds:s3,sourceZ:c4,targetZ:r6});if(h7+WL<this.obstacleMargin)continue;let m4=this.getMinPlacedEscapeViaClearance(p4);if(m4+WL<this.obstacleMargin)continue;let g6=this.getProjectedFreeSpace({sourcePoint:n4,candidate:p4,sourceLayer:a3,sourceObstacle:l4}),f3=Math.min(g6,3),_4=100*h7-ge2(n4,p4)-.5*Math.abs(r6-c4)+2*f3+(Number.isFinite(m4)?10*Math.min(m4,this.requiredViaToViaClearance):0);(!d4||_4>d4.score)&&(d4={pointId:`${HL}${e5.name}:${n4.pointId??`p${o4}`}:${i4}:${this.nextEscapeViaIndex++}`,x:p4.x,y:p4.y,connectionName:e5.name,rootConnectionName:e5.rootConnectionName??e5.name,sourcePointIndex:o4,sourcePointId:n4.pointId,sourceLayer:a3,targetLayer:i4,targetPourKey:u5,score:_4})}}return d4}buildPointPlacementPlans(t52){let{mergedConnection:e5,groupConnections:n4,matchingCopperPours:o4,connectionNetIds:i3}=t52,s3=[];for(let t53 of e5.pointsToConnect){let e6=this.selectPointOwner({point:t53,groupConnections:n4,matchingCopperPours:o4});if(!e6)continue;let r5=no2(t53)?this.selectSourceObstacle({point:t53,sourceLayer:t53.layer,connectionNetIds:i3}):void 0,a3=no2(t53)?this.getCandidatePositions(t53,r5).length:0;s3.push({point:t53,pointOwner:e6,sourceObstacle:r5,candidateCount:a3})}return s3.sort((t53,e6)=>{if(t53.candidateCount!==e6.candidateCount)return t53.candidateCount-e6.candidateCount;let n5=(t53.sourceObstacle?.width??0)*(t53.sourceObstacle?.height??0),o6=(e6.sourceObstacle?.width??0)*(e6.sourceObstacle?.height??0);return n5!==o6?n5-o6:t53.pointOwner.pointIndex-e6.pointOwner.pointIndex})}_step(){let t52=this.ogSrj.obstacles.filter(t53=>t53.isCopperPour),e5=this.ogSrj.connections,n4=new Map(e5.map(t53=>[t53.name,t53])),o4=e5.map(t53=>structuredClone(t53)),i3=new Map(o4.map(t53=>[t53.name,t53])),s3=structuredClone(this.ogSrj.obstacles),r5=tr2([...e5]);for(let e6 of r5){let o6=(e6.mergedConnectionNames??[e6.name]).map(t53=>n4.get(t53)).filter(t53=>t53!==void 0);if(o6.length===0)continue;let r6=new Set;for(let t53 of o6)for(let e7 of this.getConnectionNetIds(t53))r6.add(e7);let a3=t52.filter(t53=>this.obstacleMatchesConnectionNet(t53,r6));if(a3.length===0)continue;let c4=new Map,l4=new Map,h6=this.buildPointPlacementPlans({mergedConnection:e6,groupConnections:o6,matchingCopperPours:a3,connectionNetIds:r6});for(let{point:t53,pointOwner:e7,sourceObstacle:n5}of h6){let o7=this.findBestEscapeViaCandidate({connection:e7.connection,point:t53,pointIndex:e7.pointIndex,matchingCopperPours:a3,connectionNetIds:r6,sourceObstacle:n5});if(!o7)continue;let h7=i3.get(e7.connection.name);if(!h7||h7.pointsToConnect.some(t54=>no2(t54)&&t54.layer===o7.sourceLayer&&UL(t54,o7)))continue;h7.pointsToConnect.push({x:o7.x,y:o7.y,layer:o7.sourceLayer,pointId:o7.pointId,terminalVia:{toLayer:o7.targetLayer,viaDiameter:this.viaDiameter}}),this.escapeViaMetadataByPointId.set(o7.pointId,o7),this.createdEscapeVias.push(o7),s3.push(this.createEscapeViaObstacle({escapeVia:o7,connectionNetIds:this.getConnectionNetIds(e7.connection)}));let d4=c4.get(o7.targetPourKey);d4?d4.push(o7.pointId):c4.set(o7.targetPourKey,[o7.pointId]),l4.has(o7.targetPourKey)||l4.set(o7.targetPourKey,e7.connection.name)}for(let[t53,e7]of c4.entries()){if(e7.length<=1)continue;let n5=l4.get(t53);if(!n5)continue;let o7=i3.get(n5);o7&&(o7.externallyConnectedPointIds=[...o7.externallyConnectedPointIds??[],e7])}}this.outputSrj={...structuredClone(this.ogSrj),connections:o4,obstacles:s3},this.solved=!0}getOutputSimpleRouteJson(){return structuredClone(this.outputSrj)}getEscapeViaMetadataByPointId(){return new Map(this.escapeViaMetadataByPointId)}visualize(){return{title:"Escape Via Location Solver",points:this.outputSrj.connections.flatMap(t52=>t52.pointsToConnect.map(e5=>({x:e5.x,y:e5.y,color:e5.pointId?.startsWith(HL)===!0?"#0f766e":"#dc2626",label:e5.pointId?.startsWith(HL)===!0?`${t52.name}
626
626
  escape via`:t52.name}))),lines:this.createdEscapeVias.map(t52=>{let e5=this.outputSrj.connections.find(e6=>e6.name===t52.connectionName)?.pointsToConnect[t52.sourcePointIndex]??null;return{points:e5?[{x:e5.x,y:e5.y},{x:t52.x,y:t52.y}]:[{x:t52.x,y:t52.y}],strokeColor:"#0f766e"}}),circles:this.createdEscapeVias.map(t52=>({center:{x:t52.x,y:t52.y},radius:this.viaRadius,strokeColor:"#0f766e",label:`${t52.connectionName}
627
627
  ${t52.targetLayer}`})),rects:this.outputSrj.obstacles.filter(t52=>!t52.isCopperPour).map(t52=>({...t52,fill:"rgba(220,38,38,0.12)"}))}}},GL=t52=>({...t52}),qL=t52=>({...t52,route:t52.route?.map(GL),vias:t52.vias?.map(t53=>({...t53}))}),JL=t52=>t52.map(qL),KL="#0000FF",QL=.15,tk=1e-6,ek=.1,nk=["top","bottom","left","right"],ok=t52=>t52.x*t52.x+t52.y*t52.y,ik=(t52,e5)=>({x:t52.x-e5.x,y:t52.y-e5.y}),sk=(t52,e5,n4)=>{let o4=ik(n4,e5),i3=ok(o4);if(i3<=tk)return Math.sqrt(ok(ik(t52,e5)));let s3=(a3=ik(t52,e5),c4=o4,r5=(a3.x*c4.x+a3.y*c4.y)/i3,Math.max(0,Math.min(1,r5)));var r5,a3,c4;let l4={x:e5.x+o4.x*s3,y:e5.y+o4.y*s3};return Math.sqrt(ok(ik(t52,l4)))},rk=t52=>t52?.z===1?"bottom":"top",ak=(t52,e5,n4)=>(t52.z??0)===(e5.z??0)&&(e5.z??0)===(n4.z??0)&&(t52.x===e5.x&&e5.x===n4.x||t52.y===e5.y&&e5.y===n4.y),ck=(t52,e5,n4)=>{let o4=n4?.get(t52);if(o4)return o4;let i3=t52.route??[],s3=t52.traceThickness??QL,r5=Number.POSITIVE_INFINITY,a3=Number.POSITIVE_INFINITY,c4=Number.NEGATIVE_INFINITY,l4=Number.NEGATIVE_INFINITY,h6=!1,d4=(t53,e6,n5)=>{r5=Math.min(r5,t53-n5),a3=Math.min(a3,e6-n5),c4=Math.max(c4,t53+n5),l4=Math.max(l4,e6+n5),h6=!0},u5={segments:[],segmentsByLayer:{top:[],bottom:[]},vias:(t52.vias??[]).map(n5=>{let o6=(n5.diameter??t52.viaDiameter??.3)/2;return d4(n5.x,n5.y,o6),{center:{x:n5.x,y:n5.y},radius:o6,routeIndex:e5}}),bounds:{minX:0,minY:0,maxX:0,maxY:0}};for(let t53=0;t53<i3.length-1;){let n5=i3[t53],o6=t53+1,r6=i3[o6],a4=s3/2;for(n5&&d4(n5.x,n5.y,a4),r6&&d4(r6.x,r6.y,a4);o6<i3.length-1;){let t54=i3[o6],e6=i3[o6+1];if(!n5||!t54||!e6||rk(n5)!==rk(t54)||rk(t54)!==rk(e6)||!ak(n5,t54,e6))break;o6+=1,r6=e6,d4(e6.x,e6.y,a4)}if(!n5||!r6){t53+=1;continue}let c5=rk(n5),l5={start:n5,end:r6,routeIndex:e5,pointIndex:t53,endPointIndex:o6,thickness:s3,halfThickness:a4,layer:c5,minX:Math.min(n5.x,r6.x)-a4,maxX:Math.max(n5.x,r6.x)+a4,minY:Math.min(n5.y,r6.y)-a4,maxY:Math.max(n5.y,r6.y)+a4};u5.segments.push(l5),u5.segmentsByLayer[c5].push(l5),t53=o6}if(!h6)for(let t53 of i3)d4(t53.x,t53.y,s3/2);return u5.bounds=h6?{minX:r5,minY:a3,maxX:c4,maxY:l4}:{minX:0,minY:0,maxX:0,maxY:0},n4?.set(t52,u5),u5},lk=(t52,e5,n4)=>e5.x<=Math.max(t52.x,n4.x)+tk&&e5.x>=Math.min(t52.x,n4.x)-tk&&e5.y<=Math.max(t52.y,n4.y)+tk&&e5.y>=Math.min(t52.y,n4.y)-tk,hk=(t52,e5,n4)=>(e5.y-t52.y)*(n4.x-e5.x)-(e5.x-t52.x)*(n4.y-e5.y),dk=(t52,e5,n4,o4)=>((t53,e6,n5,o6)=>{let i3=hk(t53,e6,n5),s3=hk(t53,e6,o6),r5=hk(n5,o6,t53),a3=hk(n5,o6,e6);return!!(Math.abs(i3)<=tk&&lk(t53,n5,e6))||!!(Math.abs(s3)<=tk&&lk(t53,o6,e6))||!!(Math.abs(r5)<=tk&&lk(n5,t53,o6))||!!(Math.abs(a3)<=tk&&lk(n5,e6,o6))||i3>0!=s3>0&&r5>0!=a3>0})(t52,e5,n4,o4)?0:Math.min(sk(t52,n4,o4),sk(e5,n4,o4),sk(n4,t52,e5),sk(o4,t52,e5)),uk=(t52,e5)=>Math.abs(t52.x-e5.x)<=tk&&Math.abs(t52.y-e5.y)<=tk,pk=(t52,e5)=>uk(t52.start,e5.start)||uk(t52.start,e5.end)||uk(t52.end,e5.start)||uk(t52.end,e5.end),mk=t52=>{if(!t52)return[];let e5=[t52.connectionName,t52.rootConnectionName].filter(t53=>!!t53);return Array.from(new Set(e5))},gk=(t52,e5)=>{let n4=mk(t52),o4=mk(e5);return n4.length!==0&&o4.length!==0&&n4.some(t53=>o4.includes(t53))},fk=(t52,e5,n4)=>t52.minX-n4<=e5.maxX&&t52.maxX+n4>=e5.minX&&t52.minY-n4<=e5.maxY&&t52.maxY+n4>=e5.minY,_k=(t52,e5,n4)=>{let o4=n4+t52.halfThickness+e5.halfThickness-tk;return t52.minX-n4<=e5.maxX&&t52.maxX+n4>=e5.minX&&t52.minY-n4<=e5.maxY&&t52.maxY+n4>=e5.minY&&o4>0},yk=(t52,e5,n4,o4)=>{let i3=o4+n4.halfThickness+e5-tk,s3=t52.x-i3,r5=t52.x+i3,a3=t52.y-i3,c4=t52.y+i3;return s3<=n4.maxX&&r5>=n4.minX&&a3<=n4.maxY&&c4>=n4.minY},bk=(t52,e5)=>{let n4=new WeakMap,o4=t52.map((t53,e6)=>ck(t53,e6,n4)),i3=[],s3=new Set,r5=t53=>{s3.has(t53.label)||(s3.add(t53.label),i3.push(t53))};for(let n5=0;n5<o4.length;n5+=1){let i4=o4[n5];if(i4)for(let s4=n5+1;s4<o4.length;s4+=1){let a3=o4[s4];if(a3&&!gk(t52[n5],t52[s4])&&fk(i4.bounds,a3.bounds,e5)){for(let t53 of["top","bottom"]){let o6=i4.segmentsByLayer[t53],c4=a3.segmentsByLayer[t53];for(let i5 of o6)for(let o7 of c4){if(pk(i5,o7)||!_k(i5,o7,e5))continue;let a4=e5+(i5.thickness+o7.thickness)/2-tk;dk(i5.start,i5.end,o7.start,o7.end)>=a4||r5({center:{x:(Math.max(i5.minX-e5,o7.minX-e5)+Math.min(i5.maxX+e5,o7.maxX+e5))/2,y:(Math.max(i5.minY-e5,o7.minY-e5)+Math.min(i5.maxY+e5,o7.maxY+e5))/2},label:`trace-violation:${n5}:s${i5.pointIndex}:${s4}:s${o7.pointIndex}:${t53}`})}}for(let t53 of i4.segments)for(let[o6,i5]of a3.vias.entries()){if(!yk(i5.center,i5.radius,t53,e5))continue;let a4=e5+t53.halfThickness+i5.radius-tk;sk(i5.center,t53.start,t53.end)>=a4||r5({center:i5.center,label:`trace-violation:${n5}:s${t53.pointIndex}:${s4}:v${o6}`})}for(let t53 of a3.segments)for(let[o6,a4]of i4.vias.entries()){if(!yk(a4.center,a4.radius,t53,e5))continue;let i5=e5+t53.halfThickness+a4.radius-tk;sk(a4.center,t53.start,t53.end)>=i5||r5({center:a4.center,label:`trace-violation:${n5}:v${o6}:${s4}:s${t53.pointIndex}`})}}}}return(t53=>{let e6=[];for(let n5 of t53){let t54=e6.find(t55=>{return e7=t55.center,o6=n5.center,Math.hypot(e7.x-o6.x,e7.y-o6.y)<=.28;var e7,o6});t54?(t54.center={x:(t54.center.x*t54.count+n5.center.x)/(t54.count+1),y:(t54.center.y*t54.count+n5.center.y)/(t54.count+1)},t54.labels.push(n5.label),t54.count+=1):e6.push({center:n5.center,labels:[n5.label],count:1})}return e6.map((t54,e7)=>({center:t54.center,radius:Math.min(.3,.2+.035*Math.sqrt(t54.count-1)),stroke:"#f59e0b",fill:"rgba(245, 158, 11, 0.46)",label:t54.count===1?t54.labels[0]:`trace-violations:${e7}:count-${t54.count}`}))})(i3)},xk=({routeIndexes:t52,layers:e5,routePointIndexes:n4})=>`${t52[0]}:${e5[0]}:${n4[0].join(",")}:${t52[1]}:${e5[1]}:${n4[1].join(",")}`,vk=(t52,e5,n4,o4,i3,s3,r5)=>{let a3=((t53,e6,n5,o6,i4,s4)=>t53<n5?`${t53}:${e6}:${i4.join(",")}:${n5}:${o6}:${s4.join(",")}`:`${n5}:${o6}:${s4.join(",")}:${t53}:${e6}:${i4.join(",")}`)(e5,n4,o4,i3,s3,r5),c4=t52.get(a3);if(c4){let[t53,n5]=e5<o4?[s3,r5]:[r5,s3];for(let e6 of t53)c4.routePointIndexes[0].includes(e6)||c4.routePointIndexes[0].push(e6);for(let t54 of n5)c4.routePointIndexes[1].includes(t54)||c4.routePointIndexes[1].push(t54);return c4.routePointIndexes[0].sort((t54,e6)=>t54-e6),void c4.routePointIndexes[1].sort((t54,e6)=>t54-e6)}e5<o4?t52.set(a3,{routeIndexes:[e5,o4],layers:[n4,i3],routePointIndexes:[[...new Set(s3)].sort((t53,e6)=>t53-e6),[...new Set(r5)].sort((t53,e6)=>t53-e6)]}):t52.set(a3,{routeIndexes:[o4,e5],layers:[i3,n4],routePointIndexes:[[...new Set(r5)].sort((t53,e6)=>t53-e6),[...new Set(s3)].sort((t53,e6)=>t53-e6)]})},Sk=t52=>{let e5=[];for(let n4=t52.pointIndex;n4<=t52.endPointIndex;n4+=1)e5.push(n4);return e5},Ik=(t52,e5)=>!e5||t52.some(t53=>e5.has(t53)),Pk=(t52,e5)=>{let n4=t52.route??[],o4=[];for(let t53=0;t53<n4.length;t53+=1){let i3=n4[t53];i3&&Math.abs(i3.x-e5.center.x)<=tk&&Math.abs(i3.y-e5.center.y)<=tk&&o4.push(t53)}return o4},Mk=(t52,e5,n4)=>t52.minX-n4<=e5.maxX&&t52.maxX+n4>=e5.minX&&t52.minY-n4<=e5.maxY&&t52.maxY+n4>=e5.minY,Nk=(t52,e5,n4)=>{let o4=n4+t52.halfThickness+e5.halfThickness-tk;return t52.minX-n4<=e5.maxX&&t52.maxX+n4>=e5.minX&&t52.minY-n4<=e5.maxY&&t52.maxY+n4>=e5.minY&&o4>0},Ck=(t52,e5,n4,o4)=>{let i3=o4+n4.halfThickness+e5-tk,s3=t52.x-i3,r5=t52.x+i3,a3=t52.y-i3,c4=t52.y+i3;return s3<=n4.maxX&&r5>=n4.minX&&a3<=n4.maxY&&c4>=n4.minY},Tk=(t52,e5,n4)=>{let o4=n4+t52.radius+e5.radius-tk;return Math.abs(t52.center.x-e5.center.x)<=o4&&Math.abs(t52.center.y-e5.center.y)<=o4},wk=(t52,e5,n4,o4,i3)=>{let s3=t52.map((t53,e6)=>ck(t53,e6,o4)),r5=new Map;if(e5.size===0)return[];let a3=Array.from(e5),c4=new Map,l4=t53=>{let e6=c4.get(t53);if(e6)return e6;let o6=s3[t53];if(!o6)return[];let i4=[];for(let e7=0;e7<s3.length;e7+=1){if(e7===t53)continue;let r6=s3[e7];r6&&Mk(o6.bounds,r6.bounds,n4)&&i4.push(e7)}return c4.set(t53,i4),i4};for(let t53 of a3){let o6=s3[t53];if(!o6)continue;let a4=l4(t53),c5=i3?.get(t53);for(let l5 of o6.segments){let o7=Sk(l5);if(Ik(o7,c5))for(let c6 of a4){if(t53>c6&&e5.has(c6))continue;let a6=s3[c6];if(!a6)continue;let h6=i3?.get(c6),d4=a6.segmentsByLayer[l5.layer];for(let t54 of d4){let e6=Sk(t54);if(!Ik(e6,h6)||pk(l5,t54)||!Nk(l5,t54,n4))continue;let i4=n4+(l5.thickness+t54.thickness)/2-tk;dk(l5.start,l5.end,t54.start,t54.end)<i4&&vk(r5,l5.routeIndex,l5.layer,t54.routeIndex,t54.layer,o7,e6)}}}}for(let o6 of a3){let a4=s3[o6];if(!a4)continue;let c5=l4(o6),h6=i3?.get(o6);for(let l5 of a4.vias){let a6=Pk(t52[l5.routeIndex],l5);if(Ik(a6,h6))for(let t53 of c5){if(o6>t53&&e5.has(t53))continue;let c6=s3[t53];if(!c6)continue;let h7=i3?.get(t53);for(let t54 of c6.segments){let e6=Sk(t54);if(!Ik(e6,h7)||!Ck(l5.center,l5.radius,t54,n4))continue;let o7=n4+t54.thickness/2+l5.radius-tk;sk(l5.center,t54.start,t54.end)<o7&&vk(r5,t54.routeIndex,t54.layer,l5.routeIndex,"via",e6,a6)}}}}for(let e6 of a3){let o6=s3[e6];if(!o6)continue;let a4=l4(e6),c5=i3?.get(e6);for(let e7 of o6.segments){let o7=Sk(e7);if(Ik(o7,c5))for(let c6 of a4){let a6=s3[c6];if(!a6)continue;let l5=i3?.get(c6);for(let i4 of a6.vias){let s4=Pk(t52[i4.routeIndex],i4);if(!Ik(s4,l5)||!Ck(i4.center,i4.radius,e7,n4))continue;let a7=n4+e7.thickness/2+i4.radius-tk;sk(i4.center,e7.start,e7.end)<a7&&vk(r5,e7.routeIndex,e7.layer,i4.routeIndex,"via",o7,s4)}}}}for(let o6 of a3){let a4=s3[o6];if(!a4)continue;let c5=l4(o6),h6=i3?.get(o6);for(let l5 of a4.vias){let a6=Pk(t52[l5.routeIndex],l5);if(Ik(a6,h6))for(let h7 of c5){if(o6>h7&&e5.has(h7))continue;let c6=s3[h7];if(!c6)continue;let d4=i3?.get(h7);for(let e6 of c6.vias){let o7=Pk(t52[e6.routeIndex],e6);if(!Ik(o7,d4)||!Tk(l5,e6,n4))continue;let i4=n4+l5.radius+e6.radius-tk;Math.hypot(l5.center.x-e6.center.x,l5.center.y-e6.center.y)<i4&&vk(r5,l5.routeIndex,"via",e6.routeIndex,"via",a6,o7)}}}}return Array.from(r5.values())},Rk=(t52,e5)=>t52.x>=e5.minX-tk&&t52.x<=e5.maxX+tk&&t52.y>=e5.minY-tk&&t52.y<=e5.maxY+tk,Ek=(t52,e5,n4)=>{switch(e5){case"left":return{minX:t52.minX,maxX:t52.minX+n4,minY:t52.minY,maxY:t52.maxY};case"right":return{minX:t52.maxX-n4,maxX:t52.maxX,minY:t52.minY,maxY:t52.maxY};case"top":return{minX:t52.minX,maxX:t52.maxX,minY:t52.maxY-n4,maxY:t52.maxY};case"bottom":return{minX:t52.minX,maxX:t52.maxX,minY:t52.minY,maxY:t52.minY+n4}}},Ak=(t52,e5,n4)=>{let o4=e5.x-t52.x,i3=e5.y-t52.y,s3=0,r5=1,a3=(t53,e6)=>{if(Math.abs(t53)<=tk)return e6>=-1e-6;let n5=e6/t53;return t53<0?!(n5>r5)&&(n5>s3&&(s3=n5),!0):!(n5<s3)&&(n5<r5&&(r5=n5),!0)};if(!(a3(-o4,t52.x-n4.minX)&&a3(o4,n4.maxX-t52.x)&&a3(-i3,t52.y-n4.minY)&&a3(i3,n4.maxY-t52.y)))return 0;let c4=Math.hypot(o4,i3);return Math.max(0,r5-s3)*c4},Ok=(t52,e5)=>nk.filter(n4=>{switch(n4){case"left":return Math.abs(t52.x-e5.minX)<=tk;case"right":return Math.abs(t52.x-e5.maxX)<=tk;case"top":return Math.abs(t52.y-e5.maxY)<=tk;case"bottom":return Math.abs(t52.y-e5.minY)<=tk}return!1}),Lk=(t52,e5)=>{let n4=[];return t52.x<e5.minX-tk&&n4.push("left"),t52.x>e5.maxX+tk&&n4.push("right"),t52.y>e5.maxY+tk&&n4.push("top"),t52.y<e5.minY-tk&&n4.push("bottom"),n4},kk=(t52,e5,n4)=>{let o4=e5.x-t52.x,i3=e5.y-t52.y;switch(n4){case"left":case"right":return Math.abs(o4)<=tk&&Math.abs(i3)>tk;case"top":case"bottom":return Math.abs(i3)<=tk&&Math.abs(o4)>tk}},Dk=(t52,e5,n4)=>{let o4=[],i3=Math.max(n4,tk),s3=Math.min(.1,i3/4);for(let n5=0;n5<t52.length;n5+=1){let r5=t52[n5],a3=r5?.route??[];for(let t53=0;t53<a3.length-1;t53+=1){let c4=a3[t53],l4=a3[t53+1];if(!c4||!l4)continue;let h6=Lk(c4,e5),d4=Lk(l4,e5),u5=Ok(c4,e5),p4=Ok(l4,e5),m4=nk.filter(t54=>!(Ak(c4,l4,Ek(e5,t54,i3))<=s3)&&!!kk(c4,l4,t54)),g6=!Rk(c4,e5)||!Rk(l4,e5),f3=Array.from(new Set([...m4,...h6,...d4]));(g6||f3.length!==0)&&o4.push({routeIndex:n5,connectionName:r5.connectionName??r5.rootConnectionName??`route-${n5}`,segmentIndex:t53,touchedSides:f3,startSides:u5,endSides:p4,start:c4,end:l4})}}return o4},zk=t52=>t52?.center&&t52.width&&t52.height?{minX:t52.center.x-t52.width/2,maxX:t52.center.x+t52.width/2,minY:t52.center.y-t52.height/2,maxY:t52.center.y+t52.height/2,width:t52.width,height:t52.height,center:t52.center}:null,jk=t52=>t52==="bottom"?KL:"#FF0000",Fk=t52=>{let e5=t52.route??[],n4=[];if(e5.length<2)return n4;let o4=rk(e5[0]),i3=[e5[0]];for(let s3=1;s3<e5.length;s3+=1){let r5=e5[s3],a3=rk(r5);a3===o4?i3.push(r5):(i3.length>=2&&n4.push({points:i3,strokeColor:jk(o4),strokeWidth:t52.traceThickness??QL,label:t52.connectionName??"route"}),o4=a3,i3=[e5[s3-1],r5])}return i3.length>=2&&n4.push({points:i3,strokeColor:jk(o4),strokeWidth:t52.traceThickness??QL,label:t52.connectionName??"route"}),n4},$k=(t52,e5)=>({title:`HighDensityRepair02 Initial State (margin=${e5})`,routes:t52}),Bk=t52=>{let e5=[];for(let n4 of t52){let t53=e5[e5.length-1];t53&&t53.z===n4.z&&uk(t53,n4)||e5.push(n4)}return e5},Yk=(t52,e5,n4)=>{let o4=Math.max(0,t52.minX-e5.maxX,e5.minX-t52.maxX),i3=Math.max(0,t52.minY-e5.maxY,e5.minY-t52.maxY);return Math.hypot(o4,i3)<=n4+tk},Xk=(t52,e5)=>{let n4=Number.POSITIVE_INFINITY;for(let o4 of t52.segments)for(let t53 of e5.segments){if(o4.layer!==t53.layer)continue;let e6=dk(o4.start,o4.end,t53.start,t53.end)-(o4.thickness+t53.thickness)/2;n4=Math.min(n4,e6)}return n4},Hk=({currentRoutes:t52,candidateRoutes:e5,candidateRouteIndexes:n4,maximumAllowedClearance:o4})=>{let i3=new WeakMap,s3=new WeakMap,r5=[],a3=Array.from(n4).sort((t53,e6)=>t53-e6),c4=t52.map((t53,e6)=>ck(t53,e6,i3)),l4=e5.map((t53,e6)=>ck(t53,e6,s3)),h6=new Set;for(let t53 of a3)for(let n5=0;n5<e5.length;n5+=1){if(n5===t53)continue;let e6=Math.min(t53,n5),i4=Math.max(t53,n5),s4=`${e6}:${i4}`;if(h6.has(s4))continue;h6.add(s4);let a4=l4[e6],d4=l4[i4];if(!a4||!d4||!Yk(a4.bounds,d4.bounds,o4))continue;let u5=Xk(a4,d4);if(!Number.isFinite(u5)||u5>o4+tk||!c4[e6]||!c4[i4])continue;let p4=Xk(c4[e6],c4[i4]);!Number.isFinite(p4)||u5>=p4-tk||r5.push({routeIndexes:[e6,i4],previousClearance:p4,nextClearance:u5})}return r5},Wk=.001,Vk=(t52,e5)=>t52.map(t53=>{let n4=t53.route??[];return n4.length===0?t53:{...t53,route:n4.map((t54,o4)=>o4===0||o4===n4.length-1?((t55,e6)=>{let n5={...t55};return Math.abs(n5.x-e6.minX)<=Wk?n5.x=e6.minX:Math.abs(n5.x-e6.maxX)<=Wk&&(n5.x=e6.maxX),Math.abs(n5.y-e6.minY)<=Wk?n5.y=e6.minY:Math.abs(n5.y-e6.maxY)<=Wk&&(n5.y=e6.maxY),n5})(t54,e5):t54)}}),Uk=(t52,e5)=>Array.from(e5).flatMap(e6=>Fk(t52[e6]).map(t53=>({...t53,strokeColor:"#000000",strokeWidth:t53.strokeWidth,label:`candidate:${t53.label}`}))),Zk=(t52,e5,n4,o4,i3)=>{let s3="rgba(0, 0, 0, 0)";switch(e5){case"left":return{center:{x:t52.minX+n4/2,y:t52.center.y},width:n4,height:t52.height,stroke:s3,fill:o4,label:i3};case"right":return{center:{x:t52.maxX-n4/2,y:t52.center.y},width:n4,height:t52.height,stroke:s3,fill:o4,label:i3};case"top":return{center:{x:t52.center.x,y:t52.maxY-n4/2},width:t52.width,height:n4,stroke:s3,fill:o4,label:i3};case"bottom":return{center:{x:t52.center.x,y:t52.minY+n4/2},width:t52.width,height:n4,stroke:s3,fill:o4,label:i3}}},Gk=({routes:t52,candidateRoutes:e5,candidateRouteIndexes:n4,originalRoutes:o4,boundary:i3,side:s3,margin:r5,rejected:a3,rejectionReason:c4})=>{let l4=Array.from(n4).map(t53=>e5[t53].connectionName??`route-${t53}`);return{title:a3?`${s3} move rejected (${c4})`:`${s3} move accepted`,routes:a3?t52:e5,originalRoutes:o4,activeSide:s3,candidateRouteNames:l4,overlayLines:a3?Uk(e5,n4):[],overlayRects:[Zk(i3,s3,r5,a3?"rgba(220, 38, 38, 0.14)":"rgba(16, 185, 129, 0.14)",a3?`rejected:${s3}`:`accepted:${s3}`)]}},qk=(t52,e5,n4,o4)=>{let i3=(t52?.adjacentObstacles??[]).some(t53=>((t54,e6,n5,o6)=>{let i4=(t55=>t55.center&&t55.width&&t55.height?{minX:t55.center.x-t55.width/2,maxX:t55.center.x+t55.width/2,minY:t55.center.y-t55.height/2,maxY:t55.center.y+t55.height/2}:null)(t54);if(!i4)return!1;switch(n5){case"left":return i4.maxX>=e6.minX-tk&&i4.minX<=e6.minX+o6+tk;case"right":return i4.minX<=e6.maxX+tk&&i4.maxX>=e6.maxX-o6-tk;case"top":return i4.minY<=e6.maxY+tk&&i4.maxY>=e6.maxY-o6-tk;case"bottom":return i4.maxY>=e6.minY-tk&&i4.minY<=e6.minY+o6+tk}})(t53,e5,n4,o4));return{hasObstacle:i3,moveAmount:i3?o4:o4/2}},Jk=({start:t52,end:e5,side:n4,boundary:o4,amount:i3,targetAxisValue:s3})=>{let r5=(({side:t53,boundary:e6,amount:n5,targetAxisValue:o6})=>{let i4=o6??(()=>{switch(t53){case"left":return e6.minX+n5;case"right":return e6.maxX-n5;case"top":return e6.maxY-n5;case"bottom":return e6.minY+n5}})();switch(t53){case"left":case"right":return Math.min(Math.max(i4,e6.minX),e6.maxX);case"top":case"bottom":return Math.min(Math.max(i4,e6.minY),e6.maxY)}})({side:n4,boundary:o4,amount:i3,targetAxisValue:s3});switch(n4){case"left":case"right":return Bk([t52,{x:r5,y:t52.y,z:t52.z},{x:r5,y:e5.y,z:e5.z},e5]);case"top":case"bottom":return Bk([t52,{x:t52.x,y:r5,z:t52.z},{x:e5.x,y:r5,z:e5.z},e5])}},Kk=(t52,e5,n4,o4,i3,s3,r5,a3=!1)=>{let c4=t52.route??[];if(c4.length<2||e5.length===0)return qL(t52);let l4=a3?i3:Math.max(i3,s3),h6=((t53,e6)=>{switch(t53){case"left":return{x:e6,y:0};case"right":return{x:-e6,y:0};case"top":return{x:0,y:-e6};case"bottom":return{x:0,y:e6}}})(o4,l4);if(a3||(t52.vias?.length??0)>0||c4.length>2){let n5=qL(t52),o6=n5.route??[];for(let t53 of e5){let e6=o6[t53];e6&&(o6[t53]={...e6,x:e6.x+h6.x,y:e6.y+h6.y})}for(let o7 of n5.vias??[])e5.some(e6=>{let n6=t52.route?.[e6];return!!n6&&uk(n6,o7)})&&(o7.x+=h6.x,o7.y+=h6.y);return n5}let d4=qL(t52);if(c4.length===2&&e5.length===2&&e5[0]===0&&e5[1]===1){let e6=c4[0],i4=c4[1];return qL({...t52,route:Jk({start:e6,end:i4,side:o4,boundary:n4,amount:l4,targetAxisValue:r5})})}return d4},Qk=(t52,e5,n4)=>{switch(n4){case"left":return t52.x-e5.minX;case"right":return e5.maxX-t52.x;case"top":return e5.maxY-t52.y;case"bottom":return t52.y-e5.minY}},tD=(t52,e5,n4)=>{let o4=(t53=>{let e6=t53.route??[];if(e6.length===0)return[];let n5=[];for(let t54=0;t54<e6.length;t54+=1){let o6=e6[t54];if(!o6)continue;t54===0||t54===e6.length-1||n5.push(o6);let i3=e6[t54+1];i3&&n5.push({x:(o6.x+i3.x)/2,y:(o6.y+i3.y)/2})}return n5})(t52);return o4.length===0?Number.POSITIVE_INFINITY:o4.reduce((t53,o6)=>Math.min(t53,Qk(o6,e5,n4)),Number.POSITIVE_INFINITY)},eD=(t52,e5,n4=[])=>{let o4=t52.route??[],i3=[],s3=new Set,r5=e5.length===0||e5.includes("via");if(o4.length===2)return[0,1];let a3=t53=>{if(t53<=0||t53>=o4.length-1||s3.has(t53))return;let n5=o4[t53];n5&&(r5||e5.includes(rk(n5)))&&(s3.add(t53),i3.push(t53))};if(n4.length>0)for(let t53 of n4)a3(t53);else for(let t53=1;t53<o4.length-1;t53+=1)a3(t53);for(let t53=0;t53<i3.length;t53+=1){let e6=i3[t53],n5=o4[e6];if(n5)for(let t54=1;t54<o4.length-1;t54+=1){if(s3.has(t54))continue;let e7=o4[t54];e7&&e7.z!==n5.z&&uk(e7,n5)&&(s3.add(t54),i3.push(t54))}}return i3.sort((t53,e6)=>t53-e6),i3},nD=(t52,e5)=>Math.max(0,...(t52.route??[]).map(t53=>Math.max(e5.minX-t53.x,t53.x-e5.maxX,e5.minY-t53.y,t53.y-e5.maxY,0))),oD=(t52,e5,n4,o4)=>Qk(t52,e5,n4)<=o4+tk,iD=(t52,e5,n4,o4)=>{let i3=t52.route??[],s3=[],r5=new Set,a3=1,c4=i3.length-2;for(;a3<i3.length-1&&uk(i3[a3],i3[0]);)a3+=1;for(;c4>0&&uk(i3[c4],i3[i3.length-1]);)c4-=1;for(let t53=a3;t53<=c4;t53+=1)oD(i3[t53],e5,n4,o4)&&(r5.add(t53),s3.push(t53));for(let t53=0;t53<s3.length;t53+=1){let e6=i3[s3[t53]];if(e6)for(let t54=a3;t54<=c4;t54+=1){if(r5.has(t54))continue;let n5=i3[t54];n5&&n5.z!==e6.z&&uk(n5,e6)&&(r5.add(t54),s3.push(t54))}}return s3.length===0&&i3.length===2&&i3.some(t53=>oD(t53,e5,n4,o4))?[0,1]:(s3.sort((t53,e6)=>t53-e6),s3)},sD=(t52,e5,n4)=>{let o4=t52.route??[],i3=n4===0?o4[0]:o4[o4.length-1];return i3?nk.filter(t53=>Qk(i3,e5,t53)<=tk):[]},rD=(t52,e5,n4)=>{let o4=t52.route??[],i3=e5.route??[];if(o4.length===0||i3.length===0)return!0;for(let e6 of[0,-1]){let o6=sD(t52,n4,e6);if(o6.length===0)continue;let s3=e6===0?i3[0]:i3[i3.length-1];if(!s3)return!1;for(let t53 of o6)if(Qk(s3,n4,t53)>tk)return!1}return!0},aD=(t52,e5)=>Math.hypot(e5.x-t52.x,e5.y-t52.y),cD=(t52,e5,n4,o4)=>{let i3=t52.route??[];if(i3.length===0)return"none";let s3=!1;for(let t53=0;t53<i3.length;t53+=1){let r5=i3[t53];if(r5&&oD(r5,e5,n4,o4)){if(t53!==0&&t53!==i3.length-1)return"interior";s3=!0}}for(let t53=0;t53<i3.length-1;t53+=1){let s4=i3[t53],r5=i3[t53+1];if(s4&&r5&&oD(s4,e5,n4,o4)&&oD(r5,e5,n4,o4)&&!(aD(s4,r5)<=tk))return"interior"}return s3?"endpoint":"none"},lD=({currentRoutes:t52,routeIndex:e5,side:n4,moveSide:o4=n4,boundary:i3,margin:s3,moveAmount:r5,geometryCache:a3})=>{let c4=t52[e5],l4=(c4.route?.length??0)===2,h6=iD(c4,i3,n4,s3);if(h6.length===0)return null;let d4=new Set,u5=new Map,p4=new Set,m4=t52.slice(),g6=!1,f3="overlap",_4=new Set([e5]),y4=new Map([[e5,new Set]]),b3=new Map([[e5,new Set]]),x4=[e5],v4=0,S3=null,I4=null,P4=null,M4=null,N4=t53=>new Set(t53.map(t54=>xk(t54))),C4=()=>S3||(S3=wk(t52,d4,s3,a3,u5),S3),T4=()=>P4||(P4=wk(t52,d4,0,a3,u5),P4),w4=()=>M4||(M4=wk(m4,d4,0,a3,u5),M4);for(;v4<x4.length&&!g6;){let c5=x4[v4];if(v4+=1,_4.delete(c5),d4.has(c5))continue;let l5=m4[c5],h7=Array.from(y4.get(c5)??[]),T6=Array.from(b3.get(c5)??[]);y4.delete(c5),b3.delete(c5);let w5=c5===e5?iD(l5,i3,n4,s3):eD(l5,h7,T6);if(w5.length===0){if(c5===e5)return null;g6=!0,f3="eventual-overlap";break}let R3=l5.route??[],E3=c5===e5?void 0:o4==="left"||o4==="right"?(R3[w5[0]]?.x??0)+(o4==="left"?r5:-r5):(R3[w5[0]]?.y??0)+(o4==="top"?-r5:r5);m4[c5]=Kk(l5,w5,i3,o4,r5,s3,E3,c5!==e5),d4.add(c5),u5.set(c5,new Set(w5)),S3=null,I4=null,P4=null,M4=null,(l5.route?.length??0)===2&&p4.add(c5);let A4=nD(t52[c5],i3);if(nD(m4[c5],i3)>A4+1e-6){g6=!0,f3="boundary";break}if(!rD(t52[c5],m4[c5],i3)){g6=!0,f3="endpoint-boundary";break}let O3=wk(m4,new Set([c5]),s3,a3,new Map([[c5,new Set(w5)]]));for(let t53 of O3){if(N4(C4()).has(xk(t53)))continue;let[e6,n5]=t53.routeIndexes,o6=d4.has(e6),i4=d4.has(n5);if(o6&&i4)continue;let s4=o6?n5:e6,r6=o6?t53.layers[1]:t53.layers[0],a4=o6?t53.routePointIndexes[1]:t53.routePointIndexes[0];if(d4.has(s4)||_4.has(s4)){if(_4.has(s4)){let t54=y4.get(s4)??new Set;t54.add(r6),y4.set(s4,t54);let e7=b3.get(s4)??new Set;for(let t55 of a4)e7.add(t55);b3.set(s4,e7)}}else _4.add(s4),x4.push(s4),y4.set(s4,new Set([r6])),b3.set(s4,new Set(a4))}}if(!g6&&d4.size>1){let t53=N4(C4()),e6=N4(I4||(I4=wk(m4,d4,s3,a3,u5),I4));for(let n5 of e6)if(!t53.has(n5)){g6=!0,f3="eventual-overlap";break}}if(!g6&&d4.size>1){let t53=N4(T4()),e6=N4(w4());for(let n5 of e6)if(!t53.has(n5)){g6=!0,f3="eventual-overlap";break}}if(!g6){let e6=new Set(wk(t52,d4,0,a3).map(t53=>xk(t53))),n5=wk(m4,d4,0,a3);for(let t53 of n5){let n6=xk(t53);if(!e6.has(n6)){g6=!0,f3="eventual-overlap";break}}}return g6||(({currentRoutes:t53,candidateRoutes:e7,candidateRouteIndexes:n5,boundary:o6,activeSide:i4})=>{let s4=nk.filter(t54=>t54!==i4),r6=[];for(let i5 of n5){let n6=t53[i5],a4=e7[i5];if(n6&&a4)for(let t54 of s4){let e8=tD(n6,o6,t54),s5=tD(a4,o6,t54);e8>tk&&s5<=tk&&r6.push({routeIndex:i5,side:t54,previousClearance:e8,nextClearance:s5})}}return r6})({currentRoutes:t52,candidateRoutes:m4,candidateRouteIndexes:d4,boundary:i3,activeSide:n4}).length>0&&(g6=!0,f3="boundary-touch"),g6||(({currentRoutes:t53,candidateRoutes:e7,candidateRouteIndexes:n5,geometryCache:o6,currentConflicts:i4,candidateConflicts:s4})=>{let r6=i4??wk(t53,n5,0,o6),a4=s4??wk(e7,n5,0,o6),c5=new Set(r6.map(t54=>xk(t54)));return a4.filter(t54=>{let o7=xk(t54);if(c5.has(o7))return!1;let[i5,s5]=t54.routeIndexes,[r7,a6]=t54.layers,l5=n5.has(i5),h7=n5.has(s5);if(l5&&h7)return!1;let d5=l5?a6:r7,u6=e7[l5?s5:i5];return!!u6&&eD(u6,[d5]).length===0})})({currentRoutes:t52,candidateRoutes:m4,candidateRouteIndexes:d4,geometryCache:a3,currentConflicts:T4(),candidateConflicts:w4()}).length>0&&(g6=!0,f3="fixed-trace-touch"),g6||Hk({currentRoutes:t52,candidateRoutes:m4,candidateRouteIndexes:d4,maximumAllowedClearance:Math.min(s3/2,ek)}).length>0&&(g6=!0,f3="trace-clearance"),!g6&&((t53,e6,n5,o6,i4,s4)=>Array.from(n5).some(n6=>{let r6=t53[n6],a4=e6[n6];return nk.filter(t54=>t54!==i4).some(t54=>{let e7=cD(r6,o6,t54,s4),n7=cD(a4,o6,t54,s4);return e7==="none"&&n7!=="none"})}))(t52,m4,d4,i3,n4,s3)&&(g6=!0,f3="side-regression"),{isTwoPointRoute:l4,movableIndexes:h6,candidateRouteIndexes:d4,movedTwoPointRouteIndexes:p4,candidateRoutes:m4,rejected:g6,rejectionReason:f3}},hD=(t52,e5,n4,o4,i3)=>{let s3=t52.route??[];if(e5.length===0)return null;if(o4==="top"||o4==="bottom"){let t53=e5.reduce((t54,e6)=>t54+(s3[e6]?.x??n4.center.x),0)/e5.length;return t53<n4.center.x-i3/2?"right":t53>n4.center.x+i3/2?"left":null}let r5=e5.reduce((t53,e6)=>t53+(s3[e6]?.y??n4.center.y),0)/e5.length;return r5>n4.center.y+i3/2?"bottom":r5<n4.center.y-i3/2?"top":null},dD=({side:t52,sample:e5,boundary:n4,margin:o4,repairedRoutes:i3,frames:s3,captureProgressFrames:r5,lockedTwoPointRoutes:a3,geometryCache:c4,allowTwoPointWithoutObstacle:l4=!1})=>{let{hasObstacle:h6,moveAmount:d4}=qk(e5,n4,t52,o4);r5&&s3.push(((t53,e6,n5,o6,i4,s4)=>({title:`${n5} boundary analysis: move=${i4.toFixed(3)} (${s4?"obstacle-side":"clear-side"})`,routes:t53,activeSide:n5,overlayRects:[Zk(e6,n5,o6,"rgba(245, 158, 11, 0.16)",`strip:${n5}`)]}))(JL(i3),n4,t52,o4,d4,h6));let u5=new Set,p4=0;for(let e6=0;e6<i3.length;e6+=1){if(u5.has(e6)||a3.has(e6))continue;let m4=i3[e6];if((m4.route?.length??0)===2&&!h6&&!l4)continue;let g6=lD({currentRoutes:i3,routeIndex:e6,side:t52,boundary:n4,margin:o4,moveAmount:d4,geometryCache:c4});if(g6){if(g6.rejected){let s4=hD(m4,g6.movableIndexes,n4,t52,o4);if(s4){let r6=lD({currentRoutes:i3,routeIndex:e6,side:t52,moveSide:s4,boundary:n4,margin:o4,moveAmount:d4,geometryCache:c4});r6&&!r6.rejected&&(g6=r6)}}if(r5&&s3.push(Gk({routes:JL(i3),candidateRoutes:g6.candidateRoutes,candidateRouteIndexes:g6.candidateRouteIndexes,originalRoutes:g6.rejected?void 0:Array.from(g6.candidateRouteIndexes).map(t53=>qL(i3[t53])),boundary:n4,side:t52,margin:o4,rejected:g6.rejected,rejectionReason:g6.rejectionReason})),!g6.rejected){i3.splice(0,i3.length,...g6.candidateRoutes);for(let t53 of g6.movedTwoPointRouteIndexes)a3.add(t53);p4+=1}u5.add(e6)}}return{movesAccepted:p4}},uD=(t52,e5,n4,o4)=>oD(t52,e5,n4,o4),pD=(t52,e5,n4,o4)=>{switch(n4){case"left":return{...t52,x:Math.min(e5.minX+o4,e5.maxX)};case"right":return{...t52,x:Math.max(e5.maxX-o4,e5.minX)};case"top":return{...t52,y:Math.max(e5.maxY-o4,e5.minY)};case"bottom":return{...t52,y:Math.min(e5.minY+o4,e5.maxY)}}},mD=t52=>`${t52.routeIndexes[0]}:${t52.layers[0]}:${t52.routeIndexes[1]}:${t52.layers[1]}`,gD=t52=>{if(!t52)return[];let e5=[t52.connectionName,t52.rootConnectionName].filter(t53=>!!t53);return Array.from(new Set(e5))},fD=(t52,e5)=>{let n4=gD(t52),o4=gD(e5);return n4.length!==0&&o4.length!==0&&n4.some(t53=>o4.includes(t53))},_D=(t52,e5,n4)=>t52?Dk([t52],e5,n4).length:0,yD=(t52,e5,n4,o4)=>{let i3=new Set(wk(t52,new Set([n4]),o4).map(xk));return wk(e5,new Set([n4]),o4).some(t53=>!i3.has(xk(t53)))},bD=(t52,e5,n4)=>Dk(t52,e5,n4).length,xD=t52=>{if(!t52)return[];let e5=[t52.connectionName,t52.rootConnectionName].filter(t53=>!!t53);return Array.from(new Set(e5))},vD=(t52,e5)=>wk(t52,new Set(t52.map((t53,e6)=>e6)),ek,e5).filter(e6=>!(e6.layers[0]==="via"&&e6.layers[1]==="via"||((t53,e7)=>{let n4=xD(t53),o4=xD(e7);return n4.length!==0&&o4.length!==0&&n4.some(t54=>o4.includes(t54))})(t52[e6.routeIndexes[0]],t52[e6.routeIndexes[1]]))).length,SD=t52=>{let e5=nk;return[...e5.slice(t52%e5.length),...e5.slice(0,t52%e5.length)]},ID=(t52,e5,n4=!1)=>{let o4=zk(t52?.nodeWithPortPoints),i3=o4?((t53,e6)=>t53.map(t54=>{let n5=t54.route??[],o6=!1,i4=n5.map(t55=>{let n6=t55.x,i5=t55.y;return n6<e6.minX?n6=e6.minX:n6>e6.maxX&&(n6=e6.maxX),i5<e6.minY?i5=e6.minY:i5>e6.maxY&&(i5=e6.maxY),n6===t55.x&&i5===t55.y?t55:(o6=!0,{...t55,x:n6,y:i5})});return o6?{...t54,route:i4}:t54}))(Vk(JL(t52?.nodeHdRoutes??[]),o4),o4):JL(t52?.nodeHdRoutes??[]),s3=Math.max(e5??.4,.05),r5=JL(i3);if(!o4)return{boundary:null,baseRoutes:i3,repairedRoutes:r5,margin:s3,frames:[{title:"HighDensityRepair02 Missing Boundary",routes:r5}]};let a3=n4?[$k(JL(r5),s3)]:[],c4=new WeakMap,l4=bD(r5,o4,s3);for(let e6=0;e6<1;e6+=1){let i4=new Set,h7=0;for(let l5 of SD(e6)){let{movesAccepted:d6}=dD({side:l5,sample:t52,boundary:o4,frames:a3,margin:s3,repairedRoutes:r5,captureProgressFrames:n4,lockedTwoPointRoutes:i4,geometryCache:c4,allowTwoPointWithoutObstacle:e6>=1});h7+=d6}let d5=bD(r5,o4,s3);if(h7===0||d5===0||d5>=l4)break;l4=d5}let h6=JL(r5),d4=vD(r5,c4);return(({routes:t53,boundary:e6,margin:n5,geometryCache:o6})=>{let i4=Dk(t53,e6,n5);if(i4.length===0)return{movesAccepted:0};let s4=new Map;for(let t54 of i4){let e7=s4.get(t54.routeIndex)??new Set;for(let n6 of t54.touchedSides)e7.add(n6);s4.set(t54.routeIndex,e7)}let r6=[8e-6,.01,n5/4,n5/2,n5+8e-6],a4=0,c5=(i5,s5,r7)=>{let a6=s5.route??[];if(a6.length<2)return!1;let c6={...s5,route:Bk(a6)};if((c6.route?.length??0)<2)return!1;let l6=t53.slice();if(l6[i5]=c6,_D(l6[i5],e6,n5)>=r7)return!1;let h8=e7=>fD(t53[e7.routeIndexes[0]],t53[e7.routeIndexes[1]]),d6=new Set(wk(t53,new Set([i5]),0,o6).filter(t54=>!h8(t54)).map(mD));return!wk(l6,new Set([i5]),0,o6).filter(t54=>!h8(t54)).some(t54=>!d6.has(mD(t54)))&&!(Hk({currentRoutes:t53,candidateRoutes:l6,candidateRouteIndexes:new Set([i5]),maximumAllowedClearance:Math.min(n5/2,ek)}).filter(e7=>!fD(t53[e7.routeIndexes[0]],t53[e7.routeIndexes[1]])).length>0||(t53[i5]=c6,0))},l5=(n6,o7,i5,s5)=>{if(o7.length===0)return!1;for(let a6 of r6){let r7=t53[n6],l6=qL(r7),h8=l6.route??[],d6=!1;for(let t54 of o7){let n7=h8[t54];n7&&(h8[t54]=pD(n7,e6,i5,a6),d6=!0)}if(!d6)return!1;if(c5(n6,l6,s5))return!0}return!1},h7=(t54,n6)=>{let o7=[];return n6==="top"||n6==="bottom"?(Math.abs(t54.x-e6.minX)<=tk&&o7.push("left"),Math.abs(t54.x-e6.maxX)<=tk&&o7.push("right")):(Math.abs(t54.y-e6.minY)<=tk&&o7.push("bottom"),Math.abs(t54.y-e6.maxY)<=tk&&o7.push("top")),o7},d5=(o7,i5,s5)=>{let a6=t53[o7],l6=a6.route??[];if(l6.length!==2)return!1;let[d6,u5]=l6;if(!uD(d6,e6,i5,n5)||!uD(u5,e6,i5,n5))return!1;let p4=h7(d6,i5),m4=h7(u5,i5);for(let t54 of r6){let n6=pD(d6,e6,i5,t54),r7=pD(u5,e6,i5,t54);for(let o8 of p4)n6=pD(n6,e6,o8,t54);for(let n7 of m4)r7=pD(r7,e6,n7,t54);let l7={...a6,route:[d6,n6,r7,u5]};if(c5(o7,l7,s5))return!0}return!1};for(let[o7,i5]of s4)if(t53[o7])for(let s5 of i5){let i6=!0;for(;i6;){i6=!1;let r7=t53[o7].route??[];if(r7.length===2){let i7=_D(t53[o7],e6,n5);i7>0&&d5(o7,s5,i7)&&(a4+=1);break}if(r7.length<3)break;let c6=_D(t53[o7],e6,n5);if(c6===0)break;let h8=[];for(let t54=1;t54<r7.length-1;t54+=1){let o8=r7[t54];o8&&uD(o8,e6,s5,n5)&&h8.push(t54)}if(h8.length===0)break;if(l5(o7,h8,s5,c6)){a4+=1,i6=!0;continue}let u5=!1,p4=c6,m4=0;for(;m4<h8.length;){let i7=m4;for(;i7+1<h8.length&&h8[i7+1]===h8[i7]+1;)i7+=1;l5(o7,h8.slice(m4,i7+1),s5,p4)&&(a4+=1,u5=!0,p4=_D(t53[o7],e6,n5)),m4=i7+1}if(!u5){let i7=t53[o7].route??[],r8=c6;for(let c7=1;c7<i7.length-1;c7+=1){let h10=i7[c7];h10&&uD(h10,e6,s5,n5)&&l5(o7,[c7],s5,r8)&&(a4+=1,u5=!0,r8=_D(t53[o7],e6,n5))}}u5&&(i6=!0)}}for(let[o7,i5]of s4){let s5=t53[o7];if(!s5)continue;let r7=s5.route??[];if(r7.length<=2)continue;let c6=_D(t53[o7],e6,n5);if(c6!==0)for(let l6 of i5){if(!r7.every(t54=>uD(t54,e6,l6,n5)))continue;let i6=r7[0]?.z;if(!r7.every(t54=>t54.z===i6))continue;let h8={...s5,route:[r7[0],r7[r7.length-1]]},u5=t53[o7];t53[o7]=h8,d5(o7,l6,c6)?a4+=1:t53[o7]=u5;break}}})({routes:h6,boundary:o4,margin:s3,geometryCache:c4}),vD(h6,c4)<=d4&&r5.splice(0,r5.length,...h6),(({routes:t53,boundary:e6,clearanceMargin:n5})=>{for(let o6=0;o6<t53.length;o6+=1){let i4=t53[o6];if((i4.route??[]).length<=2)continue;let s4=n5,r6=Math.max(e6.width/2-tk,0),a4=Math.max(e6.height/2-tk,0),c5=Math.min(s4,r6),l5=Math.min(s4,a4),h7=qL(i4),d5=h7.route??[],u5=!1;for(let t54=1;t54<d5.length-1;t54+=1){let n6=d5[t54];if(!n6)continue;let o7=Math.min(Math.max(n6.x,e6.minX+c5),e6.maxX-c5),i5=Math.min(Math.max(n6.y,e6.minY+l5),e6.maxY-l5);(Math.abs(o7-n6.x)>tk||Math.abs(i5-n6.y)>tk)&&(n6.x=o7,n6.y=i5,u5=!0)}if(!u5||(h7.route=Bk(d5),(h7.route?.length??0)<2))continue;let p4=JL(t53);p4[o6]=h7;let m4=yD(t53,p4,o6,0),g6=yD(t53,p4,o6,n5),f3=Hk({currentRoutes:t53,candidateRoutes:p4,candidateRouteIndexes:new Set([o6]),maximumAllowedClearance:n5}).length>0;m4||g6||f3||(t53[o6]=h7)}})({routes:r5,boundary:o4,clearanceMargin:s3}),a3.push(((t53,e6,n5)=>({title:`HighDensityRepair02 Final State (margin=${n5})`,routes:t53,originalRoutes:e6}))(JL(r5),JL(i3),s3)),{boundary:o4,baseRoutes:i3,repairedRoutes:r5,frames:a3,margin:s3}},PD=class extends Tt2{constructor(t52={}){super();__publicField(this,"params");__publicField(this,"frames",[]);__publicField(this,"currentFrameIndex",0);__publicField(this,"showBoundryViolationMarkers");__publicField(this,"repairedRoutes",[]);this.params=t52,this.showBoundryViolationMarkers=t52.showBoundryViolationMarkers??!1}_setup(){this.buildFrames();let t52=this.getCurrentBoundryViolationCount(),e5=this.getCurrentTraceViolationCount();this.stats={boundryViolationCount:t52,traceViolationCount:e5,margin:this.params.margin??.4,frames:this.frames.length,currentFrame:this.currentFrameIndex}}_step(){if(this.frames.length<=1){let t53=this.getCurrentBoundryViolationCount(),e6=this.getCurrentTraceViolationCount();return this.showBoundryViolationMarkers=!0,this.stats={...this.stats,boundryViolationCount:t53,traceViolationCount:e6},void(this.solved=!0)}this.currentFrameIndex<this.frames.length-1&&(this.currentFrameIndex+=1);let t52=this.getCurrentBoundryViolationCount(),e5=this.getCurrentTraceViolationCount();this.stats={boundryViolationCount:t52,traceViolationCount:e5,margin:this.params.margin??.4,frames:this.frames.length,currentFrame:this.currentFrameIndex,title:this.frames[this.currentFrameIndex]?.title},this.currentFrameIndex>=this.frames.length-1&&(this.showBoundryViolationMarkers=!0,this.solved=!0)}getConstructorParams(){return[this.params]}getOutput(){let t52=this.getCurrentTraceViolationCount();return{margin:this.params.margin??.4,repairedRoutes:this.repairedRoutes,frameCount:this.frames.length,traceViolationCount:t52}}setShowBoundryViolationMarkers(t52){this.showBoundryViolationMarkers=t52}buildFrames(){let t52=ID(this.params.sample,this.params.margin,this.params.captureProgressFrames??!1);this.frames=t52.frames,this.repairedRoutes=t52.repairedRoutes}getCurrentFrame(){let t52=this.params.sample;return this.frames[this.currentFrameIndex]??{title:"HighDensityRepair02",routes:JL(t52?.nodeHdRoutes??[])}}getBoundryViolationsForFrame(t52){let e5=zk(this.params.sample?.nodeWithPortPoints);return e5?Dk(t52.routes,e5,this.params.margin??.4):[]}getCurrentBoundryViolationCount(){return this.getBoundryViolationsForFrame(this.getCurrentFrame()).length}getRouteNetNames(t52){if(!t52)return[];let e5=[t52.connectionName,t52.rootConnectionName].filter(t53=>!!t53);return Array.from(new Set(e5))}areRoutesSameNet(t52,e5){let n4=this.getRouteNetNames(t52),o4=this.getRouteNetNames(e5);return n4.length!==0&&o4.length!==0&&n4.some(t53=>o4.includes(t53))}getCurrentTraceViolationCount(){let t52=this.getCurrentFrame().routes,e5=new Set(t52.map((t53,e6)=>e6));return wk(t52,e5,ek).filter(e6=>!(e6.layers[0]==="via"&&e6.layers[1]==="via"||this.areRoutesSameNet(t52[e6.routeIndexes[0]],t52[e6.routeIndexes[1]]))).length}visualize(){let t52=this.params.sample,e5=t52?.nodeWithPortPoints,n4=t52?.adjacentObstacles??[],o4=this.getCurrentFrame(),i3=zk(e5),s3=i3&&e5?.capacityMeshNodeId?[{center:i3.center,width:i3.width,height:i3.height,stroke:"#1d4ed8",fill:"rgba(29, 78, 216, 0.08)",label:e5.capacityMeshNodeId}]:i3?[{center:i3.center,width:i3.width,height:i3.height,stroke:"#1d4ed8",fill:"rgba(29, 78, 216, 0.08)",label:"capacity-node"}]:[],r5=n4.filter(t53=>t53.center&&t53.width&&t53.height).map((t53,e6)=>({center:t53.center,width:t53.width,height:t53.height,stroke:t53.type==="oval"?"#a855f7":"#dc2626",fill:t53.type==="oval"?"rgba(168, 85, 247, 0.12)":"rgba(220, 38, 38, 0.08)",label:t53.type?`obstacle:${t53.type}:${e6}`:`obstacle:${e6}`})),a3=this.showBoundryViolationMarkers&&i3?this.getBoundryViolationsForFrame(o4).map(t53=>{let e6=t53.end.x-t53.start.x,n5=t53.end.y-t53.start.y,o6=Math.max(Math.hypot(e6,n5),.2),i4=Math.abs(e6)>=Math.abs(n5);return{center:{x:(t53.start.x+t53.end.x)/2,y:(t53.start.y+t53.end.y)/2},width:i4?o6:.18,height:i4?.18:o6,stroke:"#b45309",fill:"rgba(250, 204, 21, 0.45)",label:`boundry-violation:${t53.routeIndex}:${t53.segmentIndex}`}}):[],c4=this.showBoundryViolationMarkers?bk(o4.routes,ek):[],l4=[...(e5?.portPoints??[]).map(t53=>({x:t53.x,y:t53.y,color:"#0f766e",label:t53.connectionName??t53.portPointId??"port-point"})),...o4.routes.flatMap(t53=>t53.route??[]).map(t53=>({x:t53.x,y:t53.y,color:rk(t53)==="bottom"?KL:"#0ea5e9",label:""})),...o4.overlayPoints??[]],h6=[...(o4.originalRoutes??[]).flatMap(t53=>Fk(t53).map(t54=>({...t54,strokeColor:"#111111",strokeWidth:Math.max(.6*t54.strokeWidth,.05),label:`original:${t54.label}`}))),...o4.routes.filter(t53=>(t53.route?.length??0)>=2).flatMap(t53=>Fk(t53)),...o4.overlayLines??[]],d4=o4.routes.flatMap(t53=>(t53.vias??[]).map(e6=>({center:{x:e6.x,y:e6.y},radius:(e6.diameter??t53.viaDiameter??.3)/2,stroke:"#7c3aed",fill:"rgba(124, 58, 237, 0.2)",label:t53.connectionName?`via:${t53.connectionName}`:"via"})));return d4.push(...c4),{coordinateSystem:"cartesian",title:o4.title,rects:[...s3,...r5,...o4.overlayRects??[],...a3],points:l4,lines:h6,circles:d4,arrows:o4.overlayArrows}}},MD=(t52,e5=0)=>({minX:t52.center.x-t52.width/2-e5,maxX:t52.center.x+t52.width/2+e5,minY:t52.center.y-t52.height/2-e5,maxY:t52.center.y+t52.height/2+e5}),ND=(t52,e5,n4=0)=>{let o4=MD(e5,n4);return t52.x>=o4.minX&&t52.x<=o4.maxX&&t52.y>=o4.minY&&t52.y<=o4.maxY},CD=(t52,e5)=>t52.route.length>0&&e5.some(e6=>(t53=>(t53.zLayers?.length??t53.layers?.length??0)>1)(e6)&&((t53,e7)=>t53.connectedTo.includes(e7.connectionName)||e7.rootConnectionName!==void 0&&t53.connectedTo.includes(e7.rootConnectionName))(e6,t52)&&t52.route.every(t53=>((t54,e7)=>{let n4=e7.width/2,o4=e7.height/2;return Math.abs(t54.x-e7.center.x)<=n4&&Math.abs(t54.y-e7.center.y)<=o4})(t53,e6))),TD=(t52,e5,n4)=>{let o4=[...t52.route.map(({x:t53,y:e6})=>({x:t53,y:e6})),...t52.vias.map(({x:t53,y:e6})=>({x:t53,y:e6}))];for(let t53=0;t53<e5.length;t53++){let i3=e5[t53];if(o4.every(t54=>ND(t54,i3,n4)))return t53}return-1},wD=(t52,e5)=>({connectionName:t52.connectionName??e5.connectionName,rootConnectionName:t52.rootConnectionName??e5.rootConnectionName,traceThickness:t52.traceThickness??e5.traceThickness,viaDiameter:t52.viaDiameter??e5.viaDiameter,route:t52.route?.map(t53=>({x:t53.x,y:t53.y,z:t53.z??0}))??e5.route,vias:t52.vias?.map(t53=>({x:t53.x,y:t53.y}))??e5.vias,jumpers:e5.jumpers}),RD=(t52,e5,n4)=>{let o4=MD(t52,n4);return e5.search(o4).filter(t53=>{return e6=o4,n5=(t54=>({minX:t54.center.x-t54.width/2,maxX:t54.center.x+t54.width/2,minY:t54.center.y-t54.height/2,maxY:t54.center.y+t54.height/2}))(t53),e6.minX<=n5.maxX&&e6.maxX>=n5.minX&&e6.minY<=n5.maxY&&e6.maxY>=n5.minY;var e6,n5}).map(t53=>({type:t53.type,center:t53.center,width:t53.width,height:t53.height}))},ED=class extends Ao2{constructor(t52){super();__publicField(this,"repairMargin");__publicField(this,"sampleEntries");__publicField(this,"originalHdRoutes");__publicField(this,"originalNodeWithPortPoints");__publicField(this,"originalObstacles");__publicField(this,"obstacleSHI");__publicField(this,"colorMap");__publicField(this,"repairedRoutesByIndex",new Map);__publicField(this,"activeSampleIndex",0);__publicField(this,"activeSubSolver",null);__publicField(this,"latestVisualization",{});this.repairMargin=t52.repairMargin??.2,this.originalHdRoutes=t52.hdRoutes,this.originalNodeWithPortPoints=t52.nodeWithPortPoints,this.originalObstacles=t52.obstacles,this.obstacleSHI=new fr2("flatbush",this.originalObstacles),this.colorMap=t52.colorMap??{};let e5=new Map;for(let n4=0;n4<t52.hdRoutes.length;n4++){if(CD(t52.hdRoutes[n4],t52.obstacles))continue;let o4=TD(t52.hdRoutes[n4],t52.nodeWithPortPoints,this.repairMargin);if(o4===-1)continue;let i3=e5.get(o4)??[];i3.push(n4),e5.set(o4,i3)}this.sampleEntries=Array.from(e5.entries()).map(([e6,n4])=>{let o4=t52.nodeWithPortPoints[e6];return{node:o4,routeIndexes:n4,sample:{nodeWithPortPoints:{capacityMeshNodeId:o4.capacityMeshNodeId,center:o4.center,width:o4.width,height:o4.height,portPoints:o4.portPoints.map(t53=>({x:t53.x,y:t53.y,z:t53.z,connectionName:t53.connectionName,portPointId:t53.portPointId}))},nodeHdRoutes:n4.map(e7=>{return{capacityMeshNodeId:void 0,connectionName:(n5=t52.hdRoutes[e7]).connectionName,rootConnectionName:n5.rootConnectionName,route:n5.route.map(t53=>({x:t53.x,y:t53.y,z:t53.z})),traceThickness:n5.traceThickness,vias:n5.vias.map(t53=>({x:t53.x,y:t53.y,diameter:n5.viaDiameter})),viaDiameter:n5.viaDiameter};var n5}),adjacentObstacles:RD(o4,this.obstacleSHI,this.repairMargin)}}}),this.MAX_ITERATIONS=Math.max(1e3*this.sampleEntries.length,1e5),this.stats={sampleCount:this.sampleEntries.length,repairedNodeCount:0,repairedRouteCount:0}}getSolverName(){return"Pipeline4HighDensityRepairSolver"}getConstructorParams(){return[{nodeWithPortPoints:this.sampleEntries.map(t52=>t52.node),hdRoutes:this.originalHdRoutes,obstacles:this.originalObstacles,repairMargin:this.repairMargin,colorMap:this.colorMap}]}_step(){let t52=this.sampleEntries[this.activeSampleIndex];if(t52){if(this.activeSubSolver){if(this.activeSubSolver.step(),this.latestVisualization=this.activeSubSolver.visualize(),this.activeSubSolver.failed)return this.failed=!0,this.error=this.activeSubSolver.error??`High density repair failed for node ${t52.node.capacityMeshNodeId}`,void(this.activeSubSolver=null);if(!this.activeSubSolver.solved)return;let e5=this.activeSubSolver.getOutput().repairedRoutes;for(let n4=0;n4<t52.routeIndexes.length;n4++){let o4=t52.routeIndexes[n4],i3=this.originalHdRoutes[o4],s3=e5[n4];this.repairedRoutesByIndex.set(o4,s3?wD(s3,i3):i3)}return this.activeSubSolver=null,this.activeSampleIndex+=1,this.stats={sampleCount:this.sampleEntries.length,repairedNodeCount:this.activeSampleIndex,repairedRouteCount:this.repairedRoutesByIndex.size},void(this.activeSampleIndex>=this.sampleEntries.length&&(this.solved=!0))}this.activeSubSolver=new PD({sample:t52.sample,margin:this.repairMargin}),this.latestVisualization=this.activeSubSolver.visualize()}else this.solved=!0}getOutput(){return this.originalHdRoutes.map((t52,e5)=>this.repairedRoutesByIndex.get(e5)??t52)}visualize(){if(this.activeSubSolver)return this.activeSubSolver.visualize();if(!this.solved)return this.latestVisualization;let t52=[],e5=[];for(let n4 of this.getOutput()){let o4=this.colorMap[n4.connectionName]??"#0ea5e9";for(let e6=0;e6<n4.route.length-1;e6++){let i3=n4.route[e6],s3=n4.route[e6+1];i3.z===s3.z&&t52.push({points:[{x:i3.x,y:i3.y},{x:s3.x,y:s3.y}],strokeColor:i3.z===0?o4:go2(o4,.5),strokeWidth:n4.traceThickness,layer:`z${i3.z}`,strokeDash:i3.z!==0?[.1,.3]:void 0})}for(let t53 of n4.vias)e5.push({center:{x:t53.x,y:t53.y},radius:n4.viaDiameter/2,stroke:o4,fill:"rgba(14,165,233,0.12)"})}return{title:"Pipeline4 High Density Repair",lines:t52,circles:e5}}},AD=1e5,OD=.001,LD=class extends Ao2{constructor(t52){super();__publicField(this,"mergedHdRoute");__publicField(this,"remainingHdRoutes");__publicField(this,"start");__publicField(this,"end");__publicField(this,"colorMap");if(this.remainingHdRoutes=[...t52.hdRoutes],this.colorMap=t52.colorMap??{},t52.hdRoutes.length===0){this.start=t52.start,this.end=t52.end;let e6=[{x:t52.start.x,y:t52.start.y,z:t52.start.z}],n5=[];return t52.start.z!==t52.end.z&&(e6.push({x:t52.start.x,y:t52.start.y,z:t52.end.z}),n5.push({x:t52.start.x,y:t52.start.y})),e6.push({x:t52.end.x,y:t52.end.y,z:t52.end.z}),this.mergedHdRoute={connectionName:t52.connectionName,rootConnectionName:t52.hdRoutes[0]?.rootConnectionName,route:e6,vias:n5,jumpers:[],viaDiameter:t52.defaultViaDiameter??.3,traceThickness:t52.defaultTraceThickness??.15},void(this.solved=!0)}let e5=1/0,n4=t52.hdRoutes[0],o4="start-to-end";for(let i4 of t52.hdRoutes){let s4=i4.route[0],r6=i4.route[i4.route.length-1],a3=ge2(t52.start,s4),c4=ge2(t52.start,r6),l4=ge2(t52.end,s4),h6=ge2(t52.end,r6),d4=Math.min(a3,c4,l4,h6);d4<e5&&(e5=d4,n4=i4,o4=Math.min(l4,h6)<Math.min(a3,c4)?"end-to-start":"start-to-end")}o4==="start-to-end"?(this.start=t52.start,this.end=t52.end):(this.start=t52.end,this.end=t52.start);let i3=n4.route[0],s3=n4.route[n4.route.length-1],r5=ge2(this.start,i3)<=ge2(this.start,s3)?i3:s3;this.mergedHdRoute={connectionName:t52.connectionName,rootConnectionName:n4.rootConnectionName,route:[{x:this.start.x,y:this.start.y,z:r5.z}],vias:[],jumpers:[],viaDiameter:n4.viaDiameter,traceThickness:n4.traceThickness}}getSolverName(){return"SingleHighDensityRouteStitchSolver3"}getDisjointedRoute(){for(let t52 of this.remainingHdRoutes)if([t52.route[0],t52.route[t52.route.length-1]].some(e5=>!this.remainingHdRoutes.some(n4=>n4===t52?!1:[n4.route[0],n4.route[n4.route.length-1]].some(t53=>t53.z===e5.z&&ge2(e5,t53)<.001))))return{firstRoute:t52};return{firstRoute:this.remainingHdRoutes[0]}}_step(){if(this.remainingHdRoutes.length===0){let t53=this.mergedHdRoute.route[this.mergedHdRoute.route.length-1];return ge2(t53,this.end)>OD&&ge2(t53,this.end)<=1.25&&this.mergedHdRoute.route.push({x:this.end.x,y:this.end.y,z:t53.z}),void(this.solved=!0)}let t52=this.mergedHdRoute.route[this.mergedHdRoute.route.length-1],e5=-1,n4="first",o4=1/0;for(let i4=0;i4<this.remainingHdRoutes.length;i4++){let s4=this.remainingHdRoutes[i4],r5=s4.route[0],a3=s4.route[s4.route.length-1],c4=ge2(t52,r5),l4=ge2(t52,a3),h6=1/0;t52.z===r5.z?c4<OD?h6=c4:c4<=1&&(h6=AD+c4):c4<OD&&(h6=1e3+c4),h6<o4&&(o4=h6,e5=i4,n4="first");let d4=1/0;t52.z===a3.z?l4<OD?d4=l4:l4<=1&&(d4=AD+l4):l4<OD&&(d4=1e3+l4),d4<o4&&(o4=d4,e5=i4,n4="last")}if(e5===-1)return void(this.remainingHdRoutes=[]);let i3=this.remainingHdRoutes[e5],s3;this.remainingHdRoutes.splice(e5,1),s3=n4==="first"?i3.route:(t53=>{let e6=[...t53].reverse().map(t54=>{let{toNextSegmentType:e7,...n5}=t54;return n5});for(let n5=0;n5<t53.length-1;n5++){let o6=t53[n5]?.toNextSegmentType;if(!o6)continue;let i4=t53.length-n5-2;e6[i4]={...e6[i4],toNextSegmentType:o6}}return e6})(i3.route),s3.length>0&&ge2(t52,s3[0])<OD&&t52.z===s3[0].z?(s3[0].toNextSegmentType&&(t52.toNextSegmentType=s3[0].toNextSegmentType),this.mergedHdRoute.route.push(...s3.slice(1))):this.mergedHdRoute.route.push(...s3),this.mergedHdRoute.vias.push(...i3.vias),i3.jumpers&&this.mergedHdRoute.jumpers.push(...i3.jumpers)}visualize(){let t52={points:[],lines:[],circles:[],rects:[],title:"Single High Density Route Stitch Solver 3"};if(t52.points?.push({x:this.start.x,y:this.start.y,color:"green",label:"Start"},{x:this.end.x,y:this.end.y,color:"red",label:"End"}),this.mergedHdRoute&&this.mergedHdRoute.route.length>1){t52.lines?.push({points:this.mergedHdRoute.route.map(t53=>({x:t53.x,y:t53.y})),strokeColor:"green"});for(let e5 of this.mergedHdRoute.route)t52.points?.push({x:e5.x,y:e5.y,color:"green"});for(let e5 of this.mergedHdRoute.vias)t52.circles?.push({center:{x:e5.x,y:e5.y},radius:this.mergedHdRoute.viaDiameter/2,fill:"green"});if(this.mergedHdRoute.jumpers&&this.mergedHdRoute.jumpers.length>0){let e5=ar2(this.mergedHdRoute.jumpers,{color:"green",label:this.mergedHdRoute.connectionName});t52.rects.push(...e5.rects??[]),t52.lines.push(...e5.lines??[])}}for(let e5 of this.remainingHdRoutes){t52.lines?.push({points:e5.route.map(t53=>({x:t53.x,y:t53.y})),strokeColor:"orange"});for(let n4 of e5.route)t52.points?.push({x:n4.x,y:n4.y,color:"orange"});for(let n4 of e5.vias)t52.circles?.push({center:{x:n4.x,y:n4.y},radius:e5.viaDiameter/2,fill:"orange"});if(e5.jumpers&&e5.jumpers.length>0){let n4=ar2(e5.jumpers,{color:"orange",label:e5.connectionName});t52.rects.push(...n4.rects??[]),t52.lines.push(...n4.lines??[])}}return t52}},kD=class extends Ao2{constructor(t52){super();__publicField(this,"unsolvedRoutes");__publicField(this,"activeSolver",null);__publicField(this,"mergedHdRoutes",[]);__publicField(this,"colorMap",{});__publicField(this,"defaultTraceThickness");__publicField(this,"defaultViaDiameter");__publicField(this,"endpointClusters",new Map);this.colorMap=t52.colorMap??{};let e5=t52.hdRoutes[0];this.defaultTraceThickness=e5?.traceThickness??.15,this.defaultViaDiameter=e5?.viaDiameter??t52.defaultViaDiameter??.3;let n4=new sr2({}),o4=[],i3=new Map;for(let e6=0;e6<t52.hdRoutes.length;e6++){let n5=t52.hdRoutes[e6],i4=n5.route[0],s4=n5.route[n5.route.length-1];o4.push([`route_island_${e6}`,this.getEndpointKey(n5.connectionName,i4),this.getEndpointKey(n5.connectionName,s4)])}n4.addConnections(o4);for(let t53 of o4)for(let e6 of t53.slice(1))i3.set(e6,(i3.get(e6)??0)+1);this.unsolvedRoutes=[];let s3=Array.from(new Set(Object.values(n4.idToNetMap)));for(let e6 of s3){let o6=n4.getIdsConnectedToNet(e6),s4=t52.hdRoutes.filter((t53,e7)=>o6.includes(`route_island_${e7}`));if(s4.length===0)continue;let r6=t52.connections.find(t53=>t53.name===s4[0].connectionName),a3=s4.flatMap(t53=>[t53.route[0],t53.route[t53.route.length-1]]),c4=new Map,l4=[];for(let t53 of a3){let e7=this.getEndpointKey(s4[0].connectionName,t53);c4.has(e7)||c4.set(e7,t53),i3.get(e7)===1&&l4.push(t53)}let h6=l4.length>0?l4:[...c4.values()];if(h6.length===0)continue;let d4,u5;h6.length>=2?({start:d4,end:u5}=this.selectIslandEndpoints({possibleEndpoints:h6,globalStart:{...r6.pointsToConnect[0],z:xo2(oo2(r6.pointsToConnect[0]),t52.layerCount)},globalEnd:{...r6.pointsToConnect[1],z:xo2(oo2(r6.pointsToConnect[1]),t52.layerCount)}}),ge2(d4,r6.pointsToConnect[1])<ge2(u5,r6.pointsToConnect[0])&&([d4,u5]=[u5,d4])):(d4={...r6.pointsToConnect[0],z:xo2(oo2(r6.pointsToConnect[0]),t52.layerCount)},u5={...r6.pointsToConnect[1],z:xo2(oo2(r6.pointsToConnect[1]),t52.layerCount)});let p4=this.selectRoutesAlongEndpointPath(s4[0].connectionName,s4,d4,u5);this.unsolvedRoutes.push({connectionName:s4[0].connectionName,hdRoutes:p4,start:d4,end:u5})}let r5=new Map;for(let t53 of this.unsolvedRoutes){let e6=r5.get(t53.connectionName);e6?e6.push(t53):r5.set(t53.connectionName,[t53])}this.unsolvedRoutes=Array.from(r5.entries()).flatMap(([e6,n5])=>{let o6=n5.some(t53=>t53.hdRoutes.some(t54=>t54.route.length<2)),i4=n5.length>1&&this.hasStitchableGapBetweenUnsolvedRoutes(n5);if(!o6&&!i4)return n5;let s4=t52.connections.find(t53=>t53.name===e6);if(!s4)return n5;let r6={...s4.pointsToConnect[0],z:xo2(oo2(s4.pointsToConnect[0]),t52.layerCount)},a3={...s4.pointsToConnect[1],z:xo2(oo2(s4.pointsToConnect[1]),t52.layerCount)},c4=n5.flatMap(t53=>t53.hdRoutes);return[{connectionName:e6,hdRoutes:this.selectRoutesAlongEndpointPath(e6,c4,r6,a3),start:r6,end:a3}]}),this.MAX_ITERATIONS=1e5}getSolverName(){return"MultipleHighDensityRouteStitchSolver3"}getEndpointKey(t52,e5){let n4=this.endpointClusters.get(t52)??[],o4,i3=1/0;for(let t53 of n4){if(t53.point.z!==e5.z)continue;let n5=ge2(t53.point,e5);n5<=.1&&n5<i3&&(o4=t53,i3=n5)}if(o4)return o4.key;let s3=`${t52}:endpoint_${n4.length}`;return n4.push({key:s3,point:{x:e5.x,y:e5.y,z:e5.z}}),this.endpointClusters.set(t52,n4),s3}getClosestEndpointHash(t52,e5,n4){let o4=null,i3=1/0;for(let s3 of e5){let e6=[s3.route[0],s3.route[s3.route.length-1]];for(let s4 of e6){let e7=ge2(n4,s4);e7<i3&&(i3=e7,o4=this.getEndpointKey(t52,s4))}}return o4}selectRoutesAlongEndpointPath(t52,e5,n4,o4){if(e5.length<=2)return e5;let i3=this.getClosestEndpointHash(t52,e5,n4),s3=this.getClosestEndpointHash(t52,e5,o4);if(!i3||!s3||i3===s3)return e5;let r5=new Map;for(let n5=0;n5<e5.length;n5++){let o6=e5[n5],i4=this.getEndpointKey(t52,o6.route[0]),s4=this.getEndpointKey(t52,o6.route[o6.route.length-1]),a4=r5.get(i4)??[];a4.push({nextHash:s4,routeIndex:n5}),r5.set(i4,a4);let c5=r5.get(s4)??[];c5.push({nextHash:i4,routeIndex:n5}),r5.set(s4,c5)}let a3=[i3],c4=new Set([i3]),l4=new Map;for(;a3.length>0;){let t53=a3.shift();if(t53===s3)break;for(let e6 of r5.get(t53)??[])c4.has(e6.nextHash)||(c4.add(e6.nextHash),l4.set(e6.nextHash,{prevHash:t53,routeIndex:e6.routeIndex}),a3.push(e6.nextHash))}if(!c4.has(s3))return e5;let h6=new Set,d4=s3;for(;d4!==i3;){let t53=l4.get(d4);if(!t53)return e5;h6.add(t53.routeIndex),d4=t53.prevHash}return h6.size===0?e5:e5.filter((t53,e6)=>h6.has(e6))}selectIslandEndpoints(t52){let e5=t52.possibleEndpoints.reduce((e6,n5)=>ge2(n5,t52.globalStart)<ge2(e6,t52.globalStart)?n5:e6),n4=t52.possibleEndpoints.filter(t53=>t53!==e5),o4=(n4.length>0?n4:t52.possibleEndpoints).reduce((e6,n5)=>ge2(n5,t52.globalEnd)<ge2(e6,t52.globalEnd)?n5:e6);return{start:e5,end:o4}}hasStitchableGapBetweenUnsolvedRoutes(t52){for(let e5=0;e5<t52.length;e5++)for(let n4=e5+1;n4<t52.length;n4++){let o4=[t52[e5].start,t52[e5].end],i3=[t52[n4].start,t52[n4].end];for(let t53 of o4)for(let e6 of i3)if(t53.z===e6.z&&ge2(t53,e6)<=1)return!0}return!1}_step(){if(this.activeSolver)return this.activeSolver.step(),void(this.activeSolver.solved?(this.activeSolver instanceof LD&&this.mergedHdRoutes.push(this.activeSolver.mergedHdRoute),this.activeSolver=null):this.activeSolver.failed&&(this.failed=!0,this.error=this.activeSolver.error));let t52=this.unsolvedRoutes.pop();t52?this.activeSolver=new LD({connectionName:t52.connectionName,hdRoutes:t52.hdRoutes,start:t52.start,end:t52.end,colorMap:this.colorMap,defaultTraceThickness:this.defaultTraceThickness,defaultViaDiameter:this.defaultViaDiameter}):this.solved=!0}visualize(){let t52={points:[],lines:[],circles:[],rects:[],title:"Multiple High Density Route Stitch Solver 3"};if(this.activeSolver){let e5=this.activeSolver.visualize();e5.points?.length&&t52.points?.push(...e5.points),e5.lines?.length&&t52.lines?.push(...e5.lines),e5.circles?.length&&t52.circles?.push(...e5.circles),e5.rects?.length&&(t52.rects||(t52.rects=[]),t52.rects.push(...e5.rects))}for(let[e5,n4]of this.mergedHdRoutes.entries()){let o4=this.colorMap[n4.connectionName]??`hsl(120, 100%, ${40+10*e5%40}%)`;for(let e6=0;e6<n4.route.length-1;e6++){let i3=n4.route[e6],s3=n4.route[e6+1],r5=i3.z!==0?go2(o4,.5):o4;t52.lines?.push({points:[{x:i3.x,y:i3.y},{x:s3.x,y:s3.y}],strokeColor:r5,strokeWidth:n4.traceThickness})}for(let e6 of n4.route){let n5=e6.z!==0?go2(o4,.5):o4;t52.points?.push({x:e6.x,y:e6.y,color:n5})}for(let e6 of n4.vias)t52.circles?.push({center:{x:e6.x,y:e6.y},radius:n4.viaDiameter/2,fill:o4});if(n4.jumpers&&n4.jumpers.length>0){let e6=ar2(n4.jumpers,{color:o4,label:n4.connectionName});t52.rects.push(...e6.rects??[]),t52.lines.push(...e6.lines??[])}}return t52}},DD=t52=>{let e5=t52.ccwRotationDegrees;return typeof e5!="number"||!Number.isFinite(e5)||(t53=>{let e6=(t54=>(t54%360+360)%360)(t53);return[0,90,180,270].some(t54=>Math.min(Math.abs(e6-t54),360-Math.abs(e6-t54))<=.01)})(e5)?[t52]:(function(t53,e6=2){let{center:n4,width:o4,height:i3,rotation:s3}=t53,r5=[],a3=s3*Math.PI/180,c4=Math.cos(a3),l4=Math.sin(a3),h6=(s3%360+360)%360;if(i3<=o4?h6>=45&&h6<135||h6>=225&&h6<315:h6>=135&&h6<225||h6>=315||h6<45){let t54=o4/e6;for(let o6=0;o6<e6;o6++){let s4=(o6-e6/2+.5)*t54,a4=-s4*c4,h7=-s4*l4,d4=1.1*t54,u5=Math.abs(i3*c4)+Math.abs(t54*l4);r5.push({center:{x:n4.x+a4,y:n4.y+h7},width:d4,height:u5})}}else{let t54=i3/e6;for(let i4=0;i4<e6;i4++){let s4=(i4-e6/2+.5)*t54,a4=-s4*l4,h7=s4*c4,d4=Math.abs(o4*c4)+Math.abs(t54*l4),u5=1.1*t54;r5.push({center:{x:n4.x+a4,y:n4.y+h7},width:d4,height:u5})}}return r5})({center:t52.center,width:t52.width,height:t52.height,rotation:e5}).map(n4=>({...t52,center:n4.center,width:n4.width,height:n4.height,ccwRotationDegrees:e5}))};function zD(t52,e5,n4,o4={}){return{solverName:t52,solverClass:e5,getConstructorParams:n4,onSolved:o4.onSolved}}var jD=class extends Ao2{constructor(t52,e5={}){super();__publicField(this,"srj");__publicField(this,"opts");__publicField(this,"escapeViaLocationSolver");__publicField(this,"netToPointPairsSolver");__publicField(this,"nodeSolver");__publicField(this,"nodeDimensionSubdivisionSolver");__publicField(this,"nodeTargetMerger");__publicField(this,"edgeSolver");__publicField(this,"colorMap");__publicField(this,"highDensityRouteSolver");__publicField(this,"highDensityForceImproveSolver");__publicField(this,"highDensityRepairSolver");__publicField(this,"highDensityStitchSolver");__publicField(this,"globalDrcForceImproveSolver");__publicField(this,"singleLayerNodeMerger");__publicField(this,"strawSolver");__publicField(this,"deadEndSolver");__publicField(this,"traceSimplificationSolver");__publicField(this,"availableSegmentPointSolver");__publicField(this,"portPointPathingSolver");__publicField(this,"multiSectionPortPointOptimizer");__publicField(this,"uniformPortDistributionSolver");__publicField(this,"traceWidthSolver");__publicField(this,"necessaryCrampedPortPointSolver");__publicField(this,"viaDiameter");__publicField(this,"viaHoleDiameter");__publicField(this,"minTraceWidth");__publicField(this,"effort");__publicField(this,"maxNodeDimension");__publicField(this,"maxNodeRatio");__publicField(this,"minNodeArea");__publicField(this,"startTimeOfPhase");__publicField(this,"endTimeOfPhase");__publicField(this,"timeSpentOnPhase");__publicField(this,"activeSubSolver",null);__publicField(this,"connMap");__publicField(this,"srjWithEscapeViaLocations");__publicField(this,"srjWithPointPairs");__publicField(this,"capacityNodes",null);__publicField(this,"capacityEdges",null);__publicField(this,"highDensityNodePortPoints");__publicField(this,"cacheProvider",null);__publicField(this,"pipelineDef",[zD("escapeViaLocationSolver",ZL,t52=>[t52.srj,{viaDiameter:t52.viaDiameter,minTraceWidth:t52.minTraceWidth,obstacleMargin:t52.srj.defaultObstacleMargin??.15}],{onSolved:t52=>{t52.srjWithEscapeViaLocations=t52.escapeViaLocationSolver?.getOutputSimpleRouteJson()}}),zD("netToPointPairsSolver",ir2,t52=>[t52.srjWithEscapeViaLocations??t52.srj,t52.colorMap],{onSolved:t52=>{t52.srjWithPointPairs=t52.netToPointPairsSolver?.getNewSimpleRouteJson(),t52.colorMap=mo2(t52.srjWithPointPairs,this.connMap),t52.connMap=Eo2(t52.srjWithPointPairs)}}),zD("nodeSolver",jn2,t52=>[{simpleRouteJson:t52.srjWithPointPairs}],{onSolved:t52=>{t52.capacityNodes=t52.nodeSolver?.getOutput().meshNodes??[]}}),zD("nodeDimensionSubdivisionSolver",yC,t52=>[t52.capacityNodes,t52.maxNodeDimension,t52.maxNodeRatio,t52.minNodeArea],{onSolved:t52=>{t52.capacityNodes=t52.nodeDimensionSubdivisionSolver?.outputNodes??[]}}),zD("edgeSolver",jo2,t52=>[t52.capacityNodes],{onSolved:t52=>{t52.capacityEdges=t52.edgeSolver?.edges}}),zD("availableSegmentPointSolver",Lo2,t52=>[{nodes:t52.capacityNodes,edges:t52.capacityEdges||[],traceWidth:t52.minTraceWidth,colorMap:t52.colorMap,shouldReturnCrampedPortPoints:!0}]),zD("necessaryCrampedPortPointSolver",vm2,t52=>[{capacityMeshNodes:t52.capacityNodes,sharedEdgeSegments:t52.availableSegmentPointSolver.getOutput(),simpleRouteJson:t52.srjWithPointPairs,numberOfCrampedPortPointsToKeep:5}]),zD("portPointPathingSolver",xw,t52=>{let e5=t52.necessaryCrampedPortPointSolver?.getOutput()??t52.availableSegmentPointSolver.getOutput(),{graph:n4,connections:o4}=Pm2({capacityMeshNodes:t52.capacityNodes,layerCount:t52.srj.layerCount,segmentPortPoints:e5.flatMap(t53=>t53.portPoints),simpleRouteJsonConnections:t52.srjWithPointPairs.connections});return[{graph:n4,connections:o4,layerCount:t52.srj.layerCount,effort:t52.effort,minViaPadDiameter:t52.viaDiameter,flags:{FORCE_CENTER_FIRST:!0,RIPPING_ENABLED:!0},weights:{SHUFFLE_SEED:0,MEMORY_PF_FACTOR:4,CENTER_OFFSET_DIST_PENALTY_FACTOR:0,CENTER_OFFSET_FOCUS_SHIFT:0,NODE_PF_FACTOR:0,LAYER_CHANGE_COST:0,RIPPING_PF_COST:0,NODE_PF_MAX_PENALTY:100,BASE_CANDIDATE_COST:.6,MAX_ITERATIONS_PER_PATH:0,RANDOM_WALK_DISTANCE:0,START_RIPPING_PF_THRESHOLD:.3,END_RIPPING_PF_THRESHOLD:1,MAX_RIPS:1e3,RANDOM_RIP_FRACTION:.3,STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR:4,GREEDY_MULTIPLIER:.7,MIN_ALLOWED_BOARD_SCORE:-1e4}}]}),zD("uniformPortDistributionSolver",to2,t52=>[{nodeWithPortPoints:t52.portPointPathingSolver?.getOutput().nodesWithPortPoints??[],inputNodesWithPortPoints:t52.portPointPathingSolver?.getOutput().inputNodeWithPortPoints??[],minTraceWidth:t52.minTraceWidth,obstacles:t52.srj.obstacles,layerCount:t52.srj.layerCount}]),zD("highDensityRouteSolver",Ss2,t52=>{let e5=t52.uniformPortDistributionSolver?.getOutput()??[],n4=t52.portPointPathingSolver?.getOutput().nodesWithPortPoints??[],o4=e5.length>0?e5:n4;return t52.highDensityNodePortPoints=structuredClone(o4),[{nodePortPoints:o4,nodePfById:new Map((t52.portPointPathingSolver?.getOutput().inputNodeWithPortPoints??[]).map(e6=>[e6.capacityMeshNodeId,t52.portPointPathingSolver?.computeNodePf(e6)??null])),colorMap:t52.colorMap,connMap:t52.connMap,viaDiameter:t52.viaDiameter,traceWidth:t52.minTraceWidth,obstacleMargin:t52.srj.defaultObstacleMargin??.15,obstacles:t52.srj.obstacles,layerCount:t52.srj.layerCount}]}),zD("highDensityForceImproveSolver",BL,t52=>[{nodeWithPortPoints:t52.highDensityNodePortPoints??[],hdRoutes:t52.highDensityRouteSolver.routes,colorMap:t52.colorMap,totalStepsPerNode:Math.max(20,Math.round(60*t52.effort)),nodeAssignmentMargin:t52.srj.defaultObstacleMargin??.2}]),zD("highDensityRepairSolver",ED,t52=>[{nodeWithPortPoints:t52.highDensityNodePortPoints??[],hdRoutes:t52.highDensityForceImproveSolver?.getOutput()??t52.highDensityRouteSolver.routes,obstacles:t52.srj.obstacles,colorMap:t52.colorMap,repairMargin:t52.srj.defaultObstacleMargin??.2}]),zD("highDensityStitchSolver",kD,t52=>[{connections:t52.srjWithPointPairs.connections,hdRoutes:t52.highDensityRepairSolver?.getOutput()??t52.highDensityForceImproveSolver?.getOutput()??t52.highDensityRouteSolver.routes,colorMap:t52.colorMap,layerCount:t52.srj.layerCount,defaultViaDiameter:t52.viaDiameter}]),zD("traceSimplificationSolver",jr2,t52=>[{hdRoutes:t52.highDensityStitchSolver.mergedHdRoutes,obstacles:t52.srj.obstacles,connMap:t52.connMap,colorMap:t52.colorMap,outline:t52.srj.outline,defaultViaDiameter:t52.viaDiameter,layerCount:t52.srj.layerCount,minTraceToPadEdgeClearance:t52.srj.minTraceToPadEdgeClearance,iterations:2}]),zD("traceWidthSolver",Fr2,t52=>[{hdRoutes:t52.traceSimplificationSolver.simplifiedHdRoutes,obstacles:t52.srj.obstacles,connMap:t52.connMap,colorMap:t52.colorMap,minTraceWidth:t52.minTraceWidth,connection:t52.srj.connections,obstacleMargin:t52.srj.minTraceToPadEdgeClearance??.15,layerCount:t52.srj.layerCount}]),zD("globalDrcForceImproveSolver",_C,t52=>[{srj:t52.srjWithPointPairs,hdRoutes:t52.traceWidthSolver.getHdRoutesWithWidths(),effort:t52.effort}])]);__publicField(this,"currentPipelineStepIndex",0);this.srj=t52,this.opts=e5,this.srj=jO(t52),this.srj=(t53=>{let e6=[];for(let n5 of t53.obstacles){let t54=DD(n5);e6.push(...t54)}return{...t53,obstacles:e6}})(this.srj),this.opts={...e5},this.MAX_ITERATIONS=1e8;let n4=Mo2(this.srj);this.viaDiameter=n4.padDiameter,this.viaHoleDiameter=n4.holeDiameter,this.minTraceWidth=this.srj.minTraceWidth;let o4=this.opts;if(this.effort=o4.effort??1,this.maxNodeDimension=o4.maxNodeDimension??16,this.maxNodeRatio=o4.maxNodeRatio??6,this.minNodeArea=o4.minNodeArea??.1**2,o4.capacityDepth===void 0){let t53=this.srj.bounds.maxX-this.srj.bounds.minX,e6=this.srj.bounds.maxY-this.srj.bounds.minY,n5=Math.max(t53,e6),i3=o4.targetMinCapacity??.5;o4.capacityDepth=Rs2(n5,i3)}this.connMap=Eo2(this.srj),this.colorMap=mo2(this.srj,this.connMap),this.cacheProvider=o4.cacheProvider===void 0?Xn2():o4.cacheProvider===null?null:o4.cacheProvider,this.startTimeOfPhase={},this.endTimeOfPhase={},this.timeSpentOnPhase={}}getConstructorParams(){return[this.srj,this.opts]}_step(){let t52=this.pipelineDef[this.currentPipelineStepIndex];if(!t52)return void(this.solved=!0);if(this.activeSubSolver)return this.activeSubSolver.step(),void(this.activeSubSolver.solved?(this.endTimeOfPhase[t52.solverName]=performance.now(),this.timeSpentOnPhase[t52.solverName]=this.endTimeOfPhase[t52.solverName]-this.startTimeOfPhase[t52.solverName],t52.onSolved?.(this),this.activeSubSolver=null,this.currentPipelineStepIndex++):this.activeSubSolver.failed&&(this.error=this.activeSubSolver?.error,this.failed=!0,this.activeSubSolver=null));let e5=t52.getConstructorParams(this);this.activeSubSolver=new t52.solverClass(...e5),this[t52.solverName]=this.activeSubSolver,this.timeSpentOnPhase[t52.solverName]=0,this.startTimeOfPhase[t52.solverName]=performance.now()}solveUntilPhase(t52){for(;this.getCurrentPhase()!==t52;)this.step()}getCurrentPhase(){return this.pipelineDef[this.currentPipelineStepIndex]?.solverName??"none"}visualize(){if(!this.solved&&this.activeSubSolver)return this.activeSubSolver.visualize();let t52=this.escapeViaLocationSolver?.visualize(),e5=this.netToPointPairsSolver?.visualize(),n4=this.nodeSolver?.visualize(),o4=this.nodeDimensionSubdivisionSolver?.visualize(),i3=this.nodeTargetMerger?.visualize(),s3=this.singleLayerNodeMerger?.visualize(),r5=this.strawSolver?.visualize(),a3=this.edgeSolver?.visualize(),c4=this.deadEndSolver?.visualize(),l4=this.availableSegmentPointSolver?.visualize(),h6=this.portPointPathingSolver?.visualize(),d4=this.multiSectionPortPointOptimizer?.visualize(),u5=this.uniformPortDistributionSolver?.visualize(),p4=this.highDensityRouteSolver?.visualize(),m4=this.highDensityForceImproveSolver?.visualize(),g6=this.highDensityRepairSolver?.visualize(),f3=this.highDensityStitchSolver?.visualize(),_4=this.traceSimplificationSolver?.visualize(),y4=this.necessaryCrampedPortPointSolver?.visualize(),b3=(this.highDensityRouteSolver?.visualize(),this.srj.outline),x4=[];if(x4.push({points:[{x:this.srj.bounds?.minX??-50,y:this.srj.bounds?.minY??-50},{x:this.srj.bounds?.maxX??50,y:this.srj.bounds?.minY??-50},{x:this.srj.bounds?.maxX??50,y:this.srj.bounds?.maxY??50},{x:this.srj.bounds?.minX??-50,y:this.srj.bounds?.maxY??50},{x:this.srj.bounds?.minX??-50,y:this.srj.bounds?.minY??-50}],strokeColor:"rgba(255,0,0,0.25)"}),b3&&b3.length>=2){let t53=b3.map(t54=>({x:t54.x,y:t54.y}));t53.push({...t53[0]}),x4.push({points:t53,strokeColor:"rgba(0, 136, 255, 0.95)"})}let v4=bo2(this.srj),S3={points:[...this.srj.connections.flatMap(t53=>t53.pointsToConnect.map(e6=>({...e6,layer:So2(e6,this.srj.layerCount),label:`${t53.name} ${e6.pcb_port_id??""}`})))],rects:[...(this.srj.obstacles??[]).filter(t53=>!t53.isCopperPour).map(t53=>({...t53,fill:t53.layers?.includes("top")?"rgba(255,0,0,0.25)":t53.layers?.includes("bottom")?"rgba(0,0,255,0.25)":"rgba(255,0,0,0.25)",layer:Io2(t53,this.srj.layerCount),label:v4(t53)}))],lines:x4},I4=[S3,t52,e5,n4,o4,i3,s3,r5,a3,c4,l4,y4,h6,d4,u5,p4?Fo2(S3,p4):null,m4,g6,f3,_4,this.solved?Fo2(S3,Co2(this.getOutputSimpleRouteJson())):null].filter(Boolean);return Fo2(...I4)}preview(){if(this.highDensityRouteSolver){let t52=[];for(let e5=this.highDensityRouteSolver.routes.length-1;e5>=0;e5--){let n4=this.highDensityRouteSolver.routes[e5];if(t52.push({points:n4.route.map(t53=>({x:t53.x,y:t53.y})),strokeColor:this.colorMap[n4.connectionName]}),t52.length>200)break}return{lines:t52}}return this.portPointPathingSolver?this.portPointPathingSolver.preview():this.netToPointPairsSolver?this.netToPointPairsSolver.visualize():this.escapeViaLocationSolver?this.escapeViaLocationSolver.visualize():{}}_getOutputHdRoutes(){return this.globalDrcForceImproveSolver?.getOutput()??this.traceWidthSolver?.getHdRoutesWithWidths()??this.traceSimplificationSolver?.simplifiedHdRoutes??this.highDensityStitchSolver.mergedHdRoutes}getOutputSimplifiedPcbTraces(){if(!this.solved||!this.highDensityRouteSolver)throw new Error("Cannot get output before solving is complete");let t52=[],e5=this._getOutputHdRoutes();for(let n4 of this.netToPointPairsSolver?.newConnections??[]){let o4=n4.netConnectionName??this.srj.connections.find(t53=>t53.name===n4.name)?.netConnectionName,i3=e5.filter(t53=>t53.connectionName===n4.name);for(let e6=0;e6<i3.length;e6++){let s3=i3[e6],r5={type:"pcb_trace",pcb_trace_id:`${n4.name}_${e6}`,connection_name:o4??n4.rootConnectionName??n4.name,route:uo2(s3,this.srj.layerCount,{connectionPoints:n4.pointsToConnect,defaultViaHoleDiameter:this.viaHoleDiameter,obstacles:this.srj.obstacles,connMap:this.connMap})};t52.push(r5)}}return t52}getOutputSimpleRouteJson(){return{...this.srj,traces:this.getOutputSimplifiedPcbTraces()}}},FD=t52=>/\/solve\/?$/.test(t52)?t52.replace(/\/+$/,""):`${t52.replace(/\/+$/,"")}/solve`,$D=(t52,e5,n4)=>{let o4=(t53=>{let e6=new Map;for(let n5 of t53.portPoints)n5.rootConnectionName&&!e6.has(n5.connectionName)&&e6.set(n5.connectionName,n5.rootConnectionName);return e6})(t52);return e5.map(t53=>({connectionName:t53.connectionName,rootConnectionName:t53.rootConnectionName??o4.get(t53.connectionName)??void 0,traceThickness:t53.traceThickness??n4.traceWidth,viaDiameter:t53.viaDiameter??n4.viaDiameter,route:(t53.route??[]).map(t54=>({x:t54.x,y:t54.y,z:t54.z,...t54.insideJumperPad?{insideJumperPad:!0}:{}})),vias:(t53.vias??[]).map(t54=>({x:t54.x,y:t54.y})),...t53.jumpers?{jumpers:t53.jumpers}:{}}))},BD=(t52,e5)=>{if(t52.length===0)return null;let n4=Math.min(Math.max(e5,0),1),o4=(t52.length-1)*n4,i3=Math.floor(o4),s3=Math.ceil(o4),r5=t52[i3],a3=t52[s3];return i3===s3?r5:r5+(a3-r5)*(o4-i3)},YD=t52=>new Set(t52.portPoints.map(t53=>t53.connectionName)).size,XD=t52=>!(YD(t52)<3)&&(t52.availableZ?.length??0)!==1,HD=t52=>t52?.MULTI_HEAD_POLYLINE_SOLVER?"MultiHeadPolyLineIntraNodeSolver3":t52?.CLOSED_FORM_SINGLE_TRANSITION?"SingleTransitionIntraNodeSolver":t52?.CLOSED_FORM_TWO_TRACE_SAME_LAYER?"TwoCrossingRoutesHighDensitySolver":t52?.CLOSED_FORM_TWO_TRACE_TRANSITION_CROSSING?"SingleTransitionCrossingRouteSolver":t52?.HIGH_DENSITY_A01?"HighDensitySolverA01":t52?.HIGH_DENSITY_A03?"HighDensitySolverA03":"SingleHighDensityRouteSolver6_VertHorzLayer_FutureCost",WD=t52=>{if(t52 instanceof di2){let e6=HD(t52.hyperParameters);return t52.cacheHit?`${e6} [cached]`:e6}if(t52 instanceof ai2)return HD(t52.hyperParameters);if(t52&&typeof t52=="object"&&"getSolverName"in t52&&typeof t52.getSolverName=="function")return t52.getSolverName();let e5=t52?.constructor;return typeof e5?.name=="string"?e5.name:"unknown"},VD=t52=>t52.winningSolver?WD(t52.winningSolver):WD(t52),UD=class extends Ao2{constructor({nodePortPoints:t52,colorMap:e5,connMap:n4,viaDiameter:o4,traceWidth:i3,obstacleMargin:s3,obstacles:r5,layerCount:a3,nodePfById:c4,hdCacheBaseUrl:l4,fetchImpl:h6}){super();__publicField(this,"unsolvedNodePortPoints");__publicField(this,"colorMap");__publicField(this,"connMap");__publicField(this,"viaDiameter");__publicField(this,"traceWidth");__publicField(this,"obstacleMargin");__publicField(this,"obstacles");__publicField(this,"layerCount");__publicField(this,"hdCacheBaseUrl");__publicField(this,"fetchImpl");__publicField(this,"nodePfById");__publicField(this,"routes",[]);__publicField(this,"nodeSolveMetadataById",new Map);__publicField(this,"launchedRemoteSolves",!1);__publicField(this,"solvedRoutesByNodeIndex",new Map);__publicField(this,"failedNodeResults",[]);__publicField(this,"remoteResponseMeasurements",[]);this.unsolvedNodePortPoints=t52,this.colorMap=e5??{},this.connMap=n4,this.viaDiameter=o4??.3,this.traceWidth=i3??.15,this.obstacleMargin=s3??.15,this.obstacles=r5??[],this.layerCount=a3??2,this.hdCacheBaseUrl=l4??"https://hd-cache.tscircuit.com",this.fetchImpl=(h6??globalThis.fetch).bind(globalThis),this.nodePfById=c4 instanceof Map?new Map(c4):new Map(Object.entries(c4??{})),this.pendingEffects=[],this.stats={localDirectNodeCount:0,localSolvedNodeCount:0,localFallbackNodeCount:0,remoteFallbackNodeCount:0,remoteRequestsStarted:0,remoteRequestsCompleted:0,remoteResponseSampleCount:0,remoteKOrderSampleCount:0,slowestRemoteResponseMs:null,slowestRemoteResponseNodeId:null,p50RemoteResponseMs:null,p50RemoteKOrder:null,p95RemoteKOrder:null,remoteSources:{}}}getSolverName(){return"Pipeline5HdCacheHighDensitySolver"}computeProgress(){return this.unsolvedNodePortPoints.length===0?1:this.nodeSolveMetadataById.size/this.unsolvedNodePortPoints.length}solveNodeLocally(t52,e5,n4={}){let o4=new vs2({nodeWithPortPoints:t52,colorMap:this.colorMap,connMap:this.connMap,viaDiameter:this.viaDiameter,traceWidth:this.traceWidth,obstacleMargin:this.obstacleMargin,obstacles:this.obstacles,layerCount:this.layerCount});if(o4.solve(),o4.failed){let e6=o4.error??`Local intra-node solver failed for ${t52.capacityMeshNodeId}`,i4=YD(t52);return this.failedNodeResults.push({node:t52,error:n4.remoteFailure&&n4.resolution==="local-fallback"?`Remote solve failed (${n4.remoteFailure}); local fallback failed (${e6})`:e6}),void this.recordNodeSolveMetadata(t52,{status:"failed",resolution:"failed",solverType:VD(o4),supervisorType:o4.getSolverName(),iterations:o4.iterations,pairCount:i4,routeCount:0,remoteAttempt:n4.resolution==="local-fallback"?{attempted:!0,endpoint:FD(this.hdCacheBaseUrl),source:"error",durationMs:n4.remoteDurationMs,error:n4.remoteFailure??e6}:{attempted:!1},error:e6})}this.solvedRoutesByNodeIndex.set(e5,o4.solvedRoutes);let i3=YD(t52);this.recordNodeSolveMetadata(t52,{status:"solved",resolution:n4.resolution??"local",solverType:VD(o4),supervisorType:o4.getSolverName(),iterations:o4.iterations,pairCount:i3,routeCount:o4.solvedRoutes.length,remoteAttempt:n4.resolution==="local-fallback"?{attempted:!0,endpoint:FD(this.hdCacheBaseUrl),source:"error",durationMs:n4.remoteDurationMs,error:n4.remoteFailure}:{attempted:!1}}),n4.resolution==="local-fallback"?(this.stats.localFallbackNodeCount+=1,this.stats.remoteFallbackNodeCount+=1):this.stats.localDirectNodeCount+=1,this.stats.localSolvedNodeCount+=1}async solveNodeViaHdCache(t52,e5){let n4=FD(this.hdCacheBaseUrl),o4={"content-type":"application/json"},i3={nodeWithPortPoints:t52},s3=JSON.stringify(i3),r5=Date.now(),a3,c4,l4,h6=null,d4=null;try{let i4=await this.fetchImpl(n4,{method:"POST",headers:o4,body:s3});if(a3=i4.status,c4=i4.ok,l4=await i4.text(),h6=Date.now()-r5,d4=l4?JSON.parse(l4):null,!i4.ok)throw new Error(d4?.message??l4??`hd-cache request failed with status ${i4.status}`);if(!d4?.ok||d4.routes===null)throw new Error(d4?.message??`hd-cache returned no routes for ${t52.capacityMeshNodeId}`);let u6=$D(t52,d4.routes,{traceWidth:this.traceWidth,viaDiameter:this.viaDiameter});this.solvedRoutesByNodeIndex.set(e5,u6),this.recordNodeSolveMetadata(t52,{status:"solved",resolution:"remote",solverType:`hd-cache.tscircuit.com [${d4.source}]`,iterations:null,pairCount:YD(t52),routeCount:u6.length,remoteAttempt:{attempted:!0,endpoint:FD(this.hdCacheBaseUrl),source:d4.source,durationMs:h6}}),this.recordRemoteSource(d4.source)}catch(u6){h6??(h6=Date.now()-r5);let p4=(t53=>t53 instanceof Error?t53.message:String(t53))(u6);this.recordFailedHdCacheRequest({nodeId:t52.capacityMeshNodeId,pairCount:YD(t52),failedAt:new Date().toISOString(),durationMs:h6,error:p4,url:n4,request:{method:"POST",headers:o4,body:s3,bodyJson:i3},response:a3!==void 0||c4!==void 0||l4!==void 0||d4!==null?{status:a3,ok:c4,text:l4,body:d4}:void 0}),this.recordRemoteSource("error"),this.solveNodeLocally(t52,e5,{resolution:"local-fallback",remoteFailure:p4,remoteDurationMs:h6})}finally{this.recordRemoteResponseMetrics(t52.capacityMeshNodeId,h6??Date.now()-r5,(u5=d4?.kOrder,typeof u5=="number"&&Number.isFinite(u5)?d4.kOrder:null)),this.stats.remoteRequestsCompleted+=1}var u5}launchRemoteSolves(){let t52=[];this.unsolvedNodePortPoints.forEach((e5,n4)=>{if(!XD(e5))return void this.solveNodeLocally(e5,n4);let o4={name:`hd-cache:${e5.capacityMeshNodeId}`,promise:Promise.resolve()};o4.promise=this.solveNodeViaHdCache(e5,n4).finally(()=>{this.pendingEffects=this.pendingEffects?.filter(t53=>t53!==o4)}),t52.push(o4)}),this.pendingEffects=t52,this.stats.remoteRequestsStarted=t52.length}recordRemoteSource(t52){this.stats.remoteSources[t52]=(this.stats.remoteSources[t52]??0)+1}recordRemoteResponseMetrics(t52,e5,n4){this.remoteResponseMeasurements.push({nodeId:t52,durationMs:e5,kOrder:n4}),this.stats.remoteResponseSampleCount=this.remoteResponseMeasurements.length,this.stats.remoteKOrderSampleCount=this.remoteResponseMeasurements.filter(t53=>t53.kOrder!==null).length;let o4=null;for(let t53 of this.remoteResponseMeasurements)(!o4||t53.durationMs>o4.durationMs)&&(o4=t53);this.stats.slowestRemoteResponseMs=o4?.durationMs??null,this.stats.slowestRemoteResponseNodeId=o4?.nodeId??null;let i3=this.remoteResponseMeasurements.map(t53=>t53.durationMs).sort((t53,e6)=>t53-e6);this.stats.p50RemoteResponseMs=BD(i3,.5);let s3=this.remoteResponseMeasurements.map(t53=>t53.kOrder).filter(t53=>t53!==null).sort((t53,e6)=>t53-e6);this.stats.p50RemoteKOrder=BD(s3,.5),this.stats.p95RemoteKOrder=BD(s3,.95)}recordFailedHdCacheRequest(t52){let e5=(()=>{if(typeof window>"u")return null;let t53=window;return Array.isArray(t53.__FAILED_HD_CACHE_REQUESTS)||(t53.__FAILED_HD_CACHE_REQUESTS=[]),t53.__FAILED_HD_CACHE_REQUESTS})();e5&&e5.push(t52)}recordNodeSolveMetadata(t52,e5){this.nodeSolveMetadataById.set(t52.capacityMeshNodeId,{...e5,node:t52,nodePf:this.nodePfById.get(t52.capacityMeshNodeId)??null})}ensureFailedNodeMetadata(){for(let t52 of this.failedNodeResults)this.nodeSolveMetadataById.has(t52.node.capacityMeshNodeId)||this.recordNodeSolveMetadata(t52.node,{status:"failed",resolution:"failed",solverType:"unknown",iterations:null,pairCount:YD(t52.node),routeCount:0,remoteAttempt:{attempted:XD(t52.node),source:"error",error:t52.error},error:t52.error})}getVisibleRoutes(){if(this.solved)return this.routes;let t52=[];for(let e5=0;e5<this.unsolvedNodePortPoints.length;e5++)t52.push(...this.solvedRoutesByNodeIndex.get(e5)??[]);return t52}createNodeMarkerLabel(t52,e5){return["hd_node_marker",`node: ${t52}`,`status: ${e5.status}`,`resolution: ${e5.resolution}`,`solver: ${e5.solverType}`,...e5.supervisorType?[`supervisor: ${e5.supervisorType}`]:[],...e5.iterations!==null?[`iterations: ${e5.iterations}`]:[],`pairCount: ${e5.pairCount}`,`routes: ${e5.routeCount}`,`nodePf: ${e5.nodePf??"n/a"}`,"remoteAttempted: "+(e5.remoteAttempt.attempted?"yes":"no"),...e5.remoteAttempt.source?[`remoteSource: ${e5.remoteAttempt.source}`]:[],...e5.remoteAttempt.durationMs!==void 0?[`remoteDurationMs: ${e5.remoteAttempt.durationMs}`]:[],...e5.remoteAttempt.error?[`remoteError: ${e5.remoteAttempt.error}`]:[],`portPoints: ${e5.node.portPoints.length}`,...e5.error?[`error: ${e5.error}`]:[]].join(`
628
- `)}_step(){if(!this.launchedRemoteSolves)return this.launchedRemoteSolves=!0,void this.launchRemoteSolves();if(!((this.pendingEffects?.length??0)>0)){if(this.failedNodeResults.length>0){this.ensureFailedNodeMetadata();let t52=this.failedNodeResults[0];return this.failed=!0,void(this.error=`Failed to solve ${this.failedNodeResults.length} nodes via hd-cache. First failure: ${t52?.node.capacityMeshNodeId} (${t52?.error})`)}this.routes=[];for(let t52=0;t52<this.unsolvedNodePortPoints.length;t52++)this.routes.push(...this.solvedRoutesByNodeIndex.get(t52)??[]);this.solved=!0}}visualize(){let t52={lines:[],points:[],rects:[],circles:[]};for(let e5 of this.getVisibleRoutes()){let n4=$o2(e5.route,e5.connectionName,this.colorMap[e5.connectionName]);for(let o4 of n4)t52.lines.push({points:o4.points,label:o4.connectionName,strokeColor:o4.z===0?o4.color:go2(o4.color,.75),layer:`z${o4.z}`,strokeWidth:e5.traceThickness,strokeDash:o4.z!==0?"10, 5":void 0});for(let n5 of e5.vias)t52.circles.push({center:n5,layer:"z0,1",radius:e5.viaDiameter/2,fill:this.colorMap[e5.connectionName],label:`${e5.connectionName} via`})}for(let[e5,n4]of this.nodeSolveMetadataById){let o4=n4.node.center.x-n4.node.width/2,i3=n4.node.center.x+n4.node.width/2,s3=n4.node.center.y-n4.node.height/2,r5=n4.node.center.y+n4.node.height/2,a3=this.createNodeMarkerLabel(e5,n4),c4=n4.status==="solved"?"blue":"red",l4=n4.status==="solved"?.03:.08;if(t52.lines.push({points:[{x:o4,y:s3},{x:i3,y:s3}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3},{points:[{x:i3,y:s3},{x:i3,y:r5}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3},{points:[{x:i3,y:r5},{x:o4,y:r5}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3},{points:[{x:o4,y:r5},{x:o4,y:s3}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3}),n4.status==="solved")t52.points.push({x:n4.node.center.x,y:n4.node.center.y,color:c4,layer:"hd_node_markers",label:a3});else{t52.lines.push({points:[{x:0,y:0},{x:n4.node.center.x,y:n4.node.center.y}],layer:"hd_failed_node_guides",strokeColor:c4,strokeDash:"8, 6",strokeWidth:.05,label:a3});let e6=Math.max(n4.node.width,1.2),o6=Math.max(n4.node.height,1.2),i4=e6/2,s4=o6/2;t52.rects.push({center:n4.node.center,layer:"hd_node_markers",width:e6,height:o6,fill:"rgba(255, 0, 0, 0.3)",stroke:c4,label:a3}),t52.circles.push({center:n4.node.center,radius:Math.max(.6*Math.max(e6,o6),1.1),layer:"hd_node_markers",fill:"rgba(255, 0, 0, 0.08)",stroke:c4,label:a3}),t52.lines.push({points:[{x:n4.node.center.x-i4,y:n4.node.center.y-s4},{x:n4.node.center.x+i4,y:n4.node.center.y+s4}],layer:"hd_node_markers",strokeColor:c4,strokeWidth:.16,label:a3},{points:[{x:n4.node.center.x-i4,y:n4.node.center.y+s4},{x:n4.node.center.x+i4,y:n4.node.center.y-s4}],layer:"hd_node_markers",strokeColor:c4,strokeWidth:.16,label:a3})}}return t52}},ZD=class extends jD{constructor(t52,e5={}){super(t52,{...e5,maxNodeDimension:e5.maxNodeDimension??7,maxNodeRatio:e5.maxNodeRatio??4});__publicField(this,"hdCacheBaseUrl");__publicField(this,"hdCacheFetch");this.hdCacheBaseUrl=e5.hdCacheBaseUrl??"https://hd-cache.tscircuit.com",this.hdCacheFetch=e5.hdCacheFetch,this.replaceHighDensityPipelineStep()}replaceHighDensityPipelineStep(){let t52=this.pipelineDef.findIndex(t53=>t53.solverName==="highDensityRouteSolver");if(t52===-1)throw new Error("Pipeline4 highDensityRouteSolver step is missing");this.pipelineDef[t52]={...this.pipelineDef[t52],solverClass:UD,getConstructorParams:t53=>{let e5=t53.uniformPortDistributionSolver?.getOutput()??[],n4=t53.portPointPathingSolver?.getOutput().nodesWithPortPoints??[],o4=e5.length>0?e5:n4;return t53.highDensityNodePortPoints=structuredClone(o4),[{nodePortPoints:o4,nodePfById:new Map((t53.portPointPathingSolver?.getOutput().inputNodeWithPortPoints??[]).map(e6=>[e6.capacityMeshNodeId,t53.portPointPathingSolver?.computeNodePf(e6)??null])),colorMap:t53.colorMap,connMap:t53.connMap,viaDiameter:t53.viaDiameter,traceWidth:t53.minTraceWidth,obstacleMargin:t53.srj.defaultObstacleMargin??.15,obstacles:t53.srj.obstacles,layerCount:t53.srj.layerCount,hdCacheBaseUrl:t53.hdCacheBaseUrl,fetchImpl:t53.hdCacheFetch}]}}}async stepAsync(){if(this.solved||this.failed)return;this.step();let t52=(t53=>{let e5=[],n4=t53;for(;n4;)e5.push(n4),n4=n4.activeSubSolver;for(let t54=e5.length-1;t54>=0;t54--){let n5=e5[t54]?.pendingEffects?.filter(Boolean)??[];if(n5.length>0)return n5}return[]})(this);t52.length!==0&&(await Promise.race(t52.map(t53=>t53.promise.then(()=>t53.name,()=>t53.name))),this.solved||this.failed||this.step())}async solveAsync(){let t52=Date.now();for(;!this.solved&&!this.failed;)await this.stepAsync();this.timeToSolve=Date.now()-t52}solve(){throw new Error("AutoroutingPipelineSolver5_HdCache requires async execution. Use solveAsync() or stepAsync().")}};var qD=Math.PI/2;var Pz=.1,Mz=.15,Nz=Pz+Mz,Cz=3*Nz/4;var rj=c(w3(),1);var LF=(Number.POSITIVE_INFINITY,1e-9);var s$=(new Int32Array(0),t52=>(t52.ccwRotationDegrees??0)*Math.PI/180);init_dist();var import_debug11=__toESM(require_browser(),1);var BaseSolver2=class{constructor(){__publicField(this,"MAX_ITERATIONS",1e5);__publicField(this,"solved",!1);__publicField(this,"failed",!1);__publicField(this,"iterations",0);__publicField(this,"progress",0);__publicField(this,"error",null);__publicField(this,"activeSubSolver");__publicField(this,"failedSubSolvers");__publicField(this,"timeToSolve");__publicField(this,"stats",{});__publicField(this,"_setupDone",!1)}setup(){this._setupDone||(this._setup(),this._setupDone=!0)}_setup(){}step(){if(this._setupDone||this.setup(),!this.solved&&!this.failed){this.iterations++;try{this._step()}catch(e5){throw this.error=`${this.constructor.name} error: ${e5}`,console.error(this.error),this.failed=!0,e5}!this.solved&&this.iterations>=this.MAX_ITERATIONS&&this.tryFinalAcceptance(),!this.solved&&this.iterations>=this.MAX_ITERATIONS&&(this.error=`${this.constructor.name} ran out of iterations`,console.error(this.error),this.failed=!0),"computeProgress"in this&&(this.progress=this.computeProgress())}}_step(){}getConstructorParams(){throw new Error("getConstructorParams not implemented")}getOutput(){return null}solve(){let startTime=Date.now();for(;!this.solved&&!this.failed;)this.step();let endTime=Date.now();this.timeToSolve=endTime-startTime}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}preview(){return{lines:[],points:[],rects:[],circles:[]}}};var BasePipelineSolver=class extends BaseSolver2{constructor(inputProblem){super();__publicField(this,"startTimeOfPhase",{});__publicField(this,"endTimeOfPhase",{});__publicField(this,"timeSpentOnPhase",{});__publicField(this,"firstIterationOfPhase",{});__publicField(this,"currentPipelineStepIndex",0);__publicField(this,"inputProblem");__publicField(this,"pipelineOutputs",{});this.inputProblem=inputProblem,this.MAX_ITERATIONS=1e6}_step(){let pipelineStepDef=this.pipelineDef[this.currentPipelineStepIndex];if(!pipelineStepDef){this.solved=!0;return}if(this.activeSubSolver){if(this.activeSubSolver.step(),this.activeSubSolver.solved){this.endTimeOfPhase[pipelineStepDef.solverName]=performance.now(),this.timeSpentOnPhase[pipelineStepDef.solverName]=this.endTimeOfPhase[pipelineStepDef.solverName]-this.startTimeOfPhase[pipelineStepDef.solverName];let output=this.activeSubSolver.getOutput();output!==null&&(this.pipelineOutputs[pipelineStepDef.solverName]=output),pipelineStepDef.onSolved?.(this),this.activeSubSolver=null,this.currentPipelineStepIndex++}else this.activeSubSolver.failed&&(this.error=this.activeSubSolver?.error,this.failed=!0,this.activeSubSolver=null);return}let constructorParams=pipelineStepDef.getConstructorParams(this);this.activeSubSolver=new pipelineStepDef.solverClass(...constructorParams),this[pipelineStepDef.solverName]=this.activeSubSolver,this.timeSpentOnPhase[pipelineStepDef.solverName]=0,this.startTimeOfPhase[pipelineStepDef.solverName]=performance.now(),this.firstIterationOfPhase[pipelineStepDef.solverName]=this.iterations}solveUntilPhase(phase){for(;this.getCurrentPhase().toLowerCase()!==phase.toLowerCase()&&(this.step(),!(this.failed||this.solved)););}getCurrentPhase(){return this.pipelineDef[this.currentPipelineStepIndex]?.solverName??"none"}getPhaseProgress(){let totalPhases=this.pipelineDef.length;if(totalPhases===0)return 1;let currentPhaseProgress=this.activeSubSolver?.progress??0;return(this.currentPipelineStepIndex+currentPhaseProgress)/totalPhases}getPhaseStats(){let stats={};for(let step of this.pipelineDef){let timeSpent=this.timeSpentOnPhase[step.solverName]||0,firstIteration=this.firstIterationOfPhase[step.solverName]||0,currentIteration=this.iterations,iterations=step.solverName===this.getCurrentPhase()?currentIteration-firstIteration:0,completed=this.currentPipelineStepIndex>this.pipelineDef.findIndex(s3=>s3.solverName===step.solverName);stats[step.solverName]={timeSpent,iterations,completed}}return stats}visualize(){if(!this.solved&&this.activeSubSolver)return this.activeSubSolver.visualize();let visualizations=this.pipelineDef.map((step,stepIndex)=>{let viz=this[step.solverName]?.visualize();if(!viz)return null;for(let rect of viz.rects??[])rect.step=stepIndex;for(let point7 of viz.points??[])point7.step=stepIndex;for(let circle2 of viz.circles??[])circle2.step=stepIndex;for(let text of viz.texts??[])text.step=stepIndex;for(let line2 of viz.lines??[])line2.step=stepIndex;return viz}).filter(Boolean);return visualizations.length===0?{points:[],rects:[],lines:[],circles:[],texts:[]}:visualizations.length===1?visualizations[0]:{points:visualizations.flatMap(v4=>v4.points||[]),rects:visualizations.flatMap(v4=>v4.rects||[]),lines:visualizations.flatMap(v4=>v4.lines||[]),circles:visualizations.flatMap(v4=>v4.circles||[]),texts:visualizations.flatMap(v4=>v4.texts||[])}}preview(){return this.activeSubSolver?this.activeSubSolver.preview():super.preview()}computeProgress(){return this.getPhaseProgress()}getStepOutput(stepName){return this.pipelineOutputs[stepName]}getAllOutputs(){return{...this.pipelineOutputs}}hasStepOutput(stepName){return stepName in this.pipelineOutputs}getSolver(stepName){return this[stepName]}};init_dist6();var rotatePoint=(point7,angle,origin={x:0,y:0})=>{let cos6=Math.cos(angle),sin6=Math.sin(angle),dx3=point7.x-origin.x,dy3=point7.y-origin.y;return{x:origin.x+dx3*cos6-dy3*sin6,y:origin.y+dx3*sin6+dy3*cos6}},setPackedComponentPadCenters=packedComponent=>{packedComponent.pads=packedComponent.pads.map(pad2=>{let rotated=rotatePoint(pad2.offset,packedComponent.ccwRotationOffset*Math.PI/180),normalizedRotation=(packedComponent.ccwRotationOffset%360+360)%360;return{...pad2,size:normalizedRotation===90||normalizedRotation===270?{x:pad2.size.y,y:pad2.size.x}:pad2.size,absoluteCenter:{x:packedComponent.center.x+rotated.x,y:packedComponent.center.y+rotated.y}}})};function sortComponentQueue({components,packOrderStrategy,packFirst=[]}){let packFirstMap=new Map;return packFirst.forEach((componentId,index)=>{packFirstMap.set(componentId,index)}),[...components].sort((a3,b3)=>{let aPackFirstIndex=packFirstMap.get(a3.componentId),bPackFirstIndex=packFirstMap.get(b3.componentId);return aPackFirstIndex!==void 0&&bPackFirstIndex!==void 0?aPackFirstIndex-bPackFirstIndex:aPackFirstIndex!==void 0?-1:bPackFirstIndex!==void 0?1:packOrderStrategy==="largest_to_smallest"?b3.pads.length-a3.pads.length:a3.pads.length-b3.pads.length})}var combineBounds=bounds=>{let minX=Math.min(...bounds.map(b3=>b3.minX)),minY=Math.min(...bounds.map(b3=>b3.minY)),maxX=Math.max(...bounds.map(b3=>b3.maxX)),maxY=Math.max(...bounds.map(b3=>b3.maxY));return{minX,minY,maxX,maxY}},getComponentBounds=(component,minGap=0)=>{let bounds={minX:1/0,maxX:-1/0,minY:1/0,maxY:-1/0};return component.pads.forEach(pad2=>{let hw3=pad2.size.x/2,hh3=pad2.size.y/2;[{x:pad2.offset.x-hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y+hh3},{x:pad2.offset.x-hw3,y:pad2.offset.y+hh3}].forEach(corner=>{let world=rotatePoint(corner,component.ccwRotationOffset*Math.PI/180),x4=world.x+component.center.x,y4=world.y+component.center.y;bounds.minX=Math.min(bounds.minX,x4),bounds.maxX=Math.max(bounds.maxX,x4),bounds.minY=Math.min(bounds.minY,y4),bounds.maxY=Math.max(bounds.maxY,y4)})}),{minX:bounds.minX-minGap,maxX:bounds.maxX+minGap,minY:bounds.minY-minGap,maxY:bounds.maxY+minGap}},cross2=(O3,A4,B4)=>(A4.x-O3.x)*(B4.y-O3.y)-(A4.y-O3.y)*(B4.x-O3.x);function simplifyCollinearSegments(outline,tolerance=1e-10){if(outline.length<=1)return outline;let simplified=[],currentSegmentStart=outline[0][0],currentSegmentEnd=outline[0][1];for(let i3=1;i3<outline.length;i3++){let nextSegment=outline[i3],[nextStart,nextEnd]=nextSegment,connectionTolerance=1e-9;if(!(Math.abs(currentSegmentEnd.x-nextStart.x)<connectionTolerance&&Math.abs(currentSegmentEnd.y-nextStart.y)<connectionTolerance)){simplified.push([currentSegmentStart,currentSegmentEnd]),currentSegmentStart=nextStart,currentSegmentEnd=nextEnd;continue}let crossProduct=cross2(currentSegmentStart,currentSegmentEnd,nextEnd),segLen1=Math.hypot(currentSegmentEnd.x-currentSegmentStart.x,currentSegmentEnd.y-currentSegmentStart.y),segLen2=Math.hypot(nextEnd.x-currentSegmentEnd.x,nextEnd.y-currentSegmentEnd.y),scaledTolerance=Math.max(tolerance,tolerance*segLen1*segLen2);Math.abs(crossProduct)<scaledTolerance||(simplified.push([currentSegmentStart,currentSegmentEnd]),currentSegmentStart=nextStart),currentSegmentEnd=nextEnd}if(outline.length>2){let firstSegment=simplified[0],lastSegmentCandidate=[currentSegmentStart,currentSegmentEnd];if(firstSegment&&simplified.length>0)if(Math.abs(currentSegmentEnd.x-firstSegment[0].x)<1e-9&&Math.abs(currentSegmentEnd.y-firstSegment[0].y)<1e-9){let crossProduct=cross2(currentSegmentStart,currentSegmentEnd,firstSegment[1]),segLen1=Math.hypot(currentSegmentEnd.x-currentSegmentStart.x,currentSegmentEnd.y-currentSegmentStart.y),segLen2=Math.hypot(firstSegment[1].x-currentSegmentEnd.x,firstSegment[1].y-currentSegmentEnd.y),scaledTolerance=Math.max(tolerance,tolerance*segLen1*segLen2);Math.abs(crossProduct)<scaledTolerance?simplified[0]=[currentSegmentStart,firstSegment[1]]:simplified.push(lastSegmentCandidate)}else simplified.push(lastSegmentCandidate);else simplified.push(lastSegmentCandidate)}else simplified.push([currentSegmentStart,currentSegmentEnd]);return simplified}function signedArea(points){let area=0;for(let i3=0;i3<points.length;i3++){let j4=(i3+1)%points.length,pi3=points[i3],pj=points[j4];area+=pi3.x*pj.y,area-=pj.x*pi3.y}return area/2}function extractFacePoints(face){let points=[],edge=face.first;if(!edge)return points;do{let shp=edge.shape,ps3=shp.start??shp.ps;points.push({x:ps3.x,y:ps3.y}),edge=edge.next}while(edge!==face.first);return points}function parseFlattenPolygonLoops(polygon2){let obstacleFreeLoops=[],obstacleContainingLoops=[],faces=Array.from(polygon2.faces);for(let face of faces){let points=extractFacePoints(face);if(points.length<3)continue;let area=signedArea(points);area>0?obstacleFreeLoops.push(points):area<0&&obstacleContainingLoops.push(points)}return{obstacleFreeLoops,obstacleContainingLoops}}function pointsToSegments(points){let segments=[];for(let i3=0;i3<points.length;i3++){let p12=points[i3],p22=points[(i3+1)%points.length];segments.push([p12,p22])}return segments}function parseFlattenPolygonSegments(polygon2){let loops=parseFlattenPolygonLoops(polygon2);return{obstacleFreeLoops:loops.obstacleFreeLoops.map(pointsToSegments),obstacleContainingLoops:loops.obstacleContainingLoops.map(pointsToSegments)}}var createPadPolygons=(component,minGap)=>component.pads.map(pad2=>{let hw3=pad2.size.x/2+minGap,hh3=pad2.size.y/2+minGap,worldCorners=[{x:pad2.offset.x-hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y+hh3},{x:pad2.offset.x-hw3,y:pad2.offset.y+hh3}].map(corner=>{let rotated=rotatePoint(corner,component.ccwRotationOffset*Math.PI/180);return{x:rotated.x+component.center.x,y:rotated.y+component.center.y}}),arr=worldCorners.map(({x:x4,y:y4})=>[x4,y4]),poly=new Flatten.Polygon(arr),xs3=worldCorners.map(p4=>p4.x),ys3=worldCorners.map(p4=>p4.y),bbox={minX:Math.min(...xs3),minY:Math.min(...ys3),maxX:Math.max(...xs3),maxY:Math.max(...ys3)};return{poly,bbox}}),createObstaclePolygons=(obstacles,minGap)=>obstacles.map(obs=>{let hw3=obs.width/2+minGap,hh3=obs.height/2+minGap,cx3=obs.absoluteCenter.x,cy3=obs.absoluteCenter.y,worldCorners=[{x:cx3-hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3+hh3},{x:cx3-hw3,y:cy3+hh3}],arr=worldCorners.map(({x:x4,y:y4})=>[x4,y4]),poly=new Flatten.Polygon(arr),xs3=worldCorners.map(p4=>p4.x),ys3=worldCorners.map(p4=>p4.y),bbox={minX:Math.min(...xs3),minY:Math.min(...ys3),maxX:Math.max(...xs3),maxY:Math.max(...ys3)};return{poly,bbox}}),constructOutlinesFromPackedComponents=(components,opts={})=>{let{minGap=0,obstacles=[]}=opts;if(components.length===0&&obstacles.length===0)return[];let componentBounds=components.map(c4=>getComponentBounds(c4,minGap)),obstacleBounds=obstacles.map(o4=>({minX:o4.absoluteCenter.x-o4.width/2-minGap,minY:o4.absoluteCenter.y-o4.height/2-minGap,maxX:o4.absoluteCenter.x+o4.width/2+minGap,maxY:o4.absoluteCenter.y+o4.height/2+minGap})),bounds=combineBounds([...componentBounds,...obstacleBounds]),allPadShapes=[];for(let component of components){let padShapes=createPadPolygons(component,minGap);allPadShapes.push(...padShapes)}let obstacleShapes=createObstaclePolygons(obstacles,minGap);if(allPadShapes.push(...obstacleShapes),allPadShapes.length===0)return[];let keptPadPolys=filterPadShapes(allPadShapes).map(s3=>s3.poly),A4=new Flatten.Polygon(new Flatten.Box(bounds.minX,bounds.minY,bounds.maxX,bounds.maxY)),B4=A4.clone();for(let poly of keptPadPolys)try{A4=Flatten.BooleanOperations.subtract(A4,poly)}catch{}let union2=null;try{union2=Flatten.BooleanOperations.subtract(B4,A4)}catch{try{if(keptPadPolys.length>0){let U3=keptPadPolys[0];for(let i3=1;i3<keptPadPolys.length;i3++)try{U3=Flatten.BooleanOperations.unify(U3,keptPadPolys[i3])}catch{}union2=U3}}catch{union2=null}}if(!union2)return[];let parsed=parseFlattenPolygonSegments(union2);return[...parsed.obstacleFreeLoops.map(outline=>simplifyCollinearSegments(outline)),...parsed.obstacleContainingLoops.map(outline=>simplifyCollinearSegments(outline))].filter(outline=>outline.length>=3)};function filterPadShapes(allPadShapes){let areaOfBox=b3=>Math.max(0,b3.maxX-b3.minX)*Math.max(0,b3.maxY-b3.minY),containsBox=(outer,inner,eps=1e-9)=>outer.minX-eps<=inner.minX&&outer.minY-eps<=inner.minY&&outer.maxX+eps>=inner.maxX&&outer.maxY+eps>=inner.maxY,sortedByAreaDesc=[...allPadShapes].sort((a3,b3)=>areaOfBox(b3.bbox)-areaOfBox(a3.bbox)),filtered=[];for(let shape of sortedByAreaDesc){let w4=shape.bbox.maxX-shape.bbox.minX,h6=shape.bbox.maxY-shape.bbox.minY;if(!(w4>1e-12&&h6>1e-12))continue;let contained=!1;for(let kept of filtered)if(containsBox(kept.bbox,shape.bbox)){contained=!0;break}contained||filtered.push(shape)}return filtered}var makeNumbersRounded=obj=>typeof obj=="number"?Math.round(obj*100)/100:typeof obj=="object"?Object.fromEntries(Object.entries(obj).map(([key,value])=>[key,makeNumbersRounded(value)])):obj,BaseSolver3=class{constructor(){__publicField(this,"MAX_ITERATIONS",1e5);__publicField(this,"solved",!1);__publicField(this,"failed",!1);__publicField(this,"iterations",0);__publicField(this,"progress",0);__publicField(this,"error",null);__publicField(this,"activeSubSolver");__publicField(this,"failedSubSolvers");__publicField(this,"timeToSolve");__publicField(this,"stats",{});__publicField(this,"_setupDone",!1)}getSolverName(){return this.constructor.name}setup(){this._setupDone||(this._setup(),this._setupDone=!0)}step(){if(this._setupDone||this.setup(),!this.solved&&!this.failed){this.iterations++;try{this._step()}catch(e5){throw this.error=`${this.getSolverName()} error: ${e5}`,console.error(this.error),this.failed=!0,e5}!this.solved&&this.iterations>this.MAX_ITERATIONS&&this.tryFinalAcceptance(),!this.solved&&this.iterations>this.MAX_ITERATIONS&&(this.error=`${this.getSolverName()} ran out of iterations`,console.error(this.error),this.failed=!0),"computeProgress"in this&&(this.progress=this.computeProgress())}}_setup(){}_step(){}getConstructorParams(){throw new Error("getConstructorParams not implemented")}solve(){let startTime=Date.now();for(;!this.solved&&!this.failed;)this.step();let endTime=Date.now();this.timeToSolve=endTime-startTime}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}getOutput(){return null}preview(){return{lines:[],points:[],rects:[],circles:[]}}noisySolve(){let startTime=Date.now();for(;!this.solved&&!this.failed;)this.step(),console.log(JSON.stringify(makeNumbersRounded(this.visualize())));let endTime=Date.now();this.timeToSolve=endTime-startTime}},MultiOffsetIrlsSolver=class extends BaseSolver3{constructor(params){super();__publicField(this,"offsetPadPoints");__publicField(this,"targetPointMap");__publicField(this,"currentPosition");__publicField(this,"constraintFn");__publicField(this,"epsilon");__publicField(this,"useSquaredDistance");__publicField(this,"optimalPosition");__publicField(this,"initialPosition");this.offsetPadPoints=[...params.offsetPadPoints],this.targetPointMap=new Map(params.targetPointMap),this.initialPosition={...params.initialPosition},this.currentPosition={...params.initialPosition},this.constraintFn=params.constraintFn,this.epsilon=params.epsilon??1e-6,this.useSquaredDistance=params.useSquaredDistance??!1,this.MAX_ITERATIONS=params.maxIterations??100}getSolverName(){return"MultiOffsetIrlsSolver"}getConstructorParams(){return{offsetPadPoints:this.offsetPadPoints.map(pad2=>({...pad2})),targetPointMap:new Map(this.targetPointMap),initialPosition:this.initialPosition,constraintFn:this.constraintFn,epsilon:this.epsilon,useSquaredDistance:this.useSquaredDistance,maxIterations:this.MAX_ITERATIONS}}_setup(){this.currentPosition={...this.initialPosition},this.optimalPosition=void 0,(!Array.from(this.targetPointMap.values()).some(targets=>targets.length>0)||this.offsetPadPoints.length===0)&&(this.optimalPosition={...this.currentPosition},this.solved=!0)}_step(){if(this.offsetPadPoints.length===0)return;let{x:currentX,y:currentY}=this.currentPosition,weightedSumX=0,weightedSumY=0,totalWeight=0;for(let pad2 of this.offsetPadPoints){let targetPoints=this.targetPointMap.get(pad2.id)||[];if(targetPoints.length===0)continue;let padX=currentX+pad2.offsetX,padY=currentY+pad2.offsetY;for(let targetPoint of targetPoints){let dx22=padX-targetPoint.x,dy22=padY-targetPoint.y,distance8=Math.sqrt(dx22*dx22+dy22*dy22),weight;this.useSquaredDistance?weight=1:weight=distance8<this.epsilon?1e6:1/distance8;let targetForCurrentPos={x:targetPoint.x-pad2.offsetX,y:targetPoint.y-pad2.offsetY};weightedSumX+=weight*targetForCurrentPos.x,weightedSumY+=weight*targetForCurrentPos.y,totalWeight+=weight}}let newPosition={x:totalWeight>0?weightedSumX/totalWeight:currentX,y:totalWeight>0?weightedSumY/totalWeight:currentY},constrainedPosition=this.constraintFn?this.constraintFn(newPosition):newPosition,dx3=constrainedPosition.x-currentX,dy3=constrainedPosition.y-currentY;if(Math.sqrt(dx3*dx3+dy3*dy3)<this.epsilon){this.optimalPosition={...constrainedPosition},this.solved=!0;return}this.currentPosition=constrainedPosition}getBestPosition(){return this.optimalPosition||this.currentPosition}getOffsetPadPositions(){let currentPos=this.getBestPosition(),padPositions=new Map;for(let pad2 of this.offsetPadPoints)padPositions.set(pad2.id,{x:currentPos.x+pad2.offsetX,y:currentPos.y+pad2.offsetY});return padPositions}getOffsetPadPosition(padId){return this.getOffsetPadPositions().get(padId)}getTotalDistance(position4){let pos=position4||this.getBestPosition(),totalDistance=0;for(let pad2 of this.offsetPadPoints){let padPosition={x:pos.x+pad2.offsetX,y:pos.y+pad2.offsetY},targetPoints=this.targetPointMap.get(pad2.id)||[];for(let target of targetPoints){let dx3=padPosition.x-target.x,dy3=padPosition.y-target.y;this.useSquaredDistance?totalDistance+=dx3*dx3+dy3*dy3:totalDistance+=Math.sqrt(dx3*dx3+dy3*dy3)}}return totalDistance}getDistanceForPad(padId,position4){let pos=position4||this.getBestPosition(),pad2=this.offsetPadPoints.find(p4=>p4.id===padId);if(!pad2)return 0;let padPosition={x:pos.x+pad2.offsetX,y:pos.y+pad2.offsetY};return(this.targetPointMap.get(padId)||[]).reduce((sum,target)=>{let dx3=padPosition.x-target.x,dy3=padPosition.y-target.y;return this.useSquaredDistance?sum+(dx3*dx3+dy3*dy3):sum+Math.sqrt(dx3*dx3+dy3*dy3)},0)}computeProgress(){if(this.offsetPadPoints.length===0)return 1;let initialDistance=this.getTotalDistance(this.initialPosition),currentDistance=this.getTotalDistance();if(initialDistance===0)return 1;let improvement=Math.max(0,initialDistance-currentDistance);return Math.min(1,improvement/initialDistance)}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]},colors=["#4CAF50","#2196F3","#FF9800","#9C27B0","#F44336","#607D8B"],currentPos=this.getBestPosition();for(let i3=0;i3<this.offsetPadPoints.length;i3++){let pad2=this.offsetPadPoints[i3];if(!pad2)continue;let color=colors[i3%colors.length],targetPoints=this.targetPointMap.get(pad2.id)||[],padPosition={x:currentPos.x+pad2.offsetX,y:currentPos.y+pad2.offsetY};for(let point7 of targetPoints)graphics.points.push({...point7,color});for(let point7 of targetPoints)graphics.lines.push({points:[padPosition,point7],strokeColor:color});graphics.points.push({x:padPosition.x,y:padPosition.y,color})}return graphics.points.push({...this.currentPosition,color:"#f44336"}),this.optimalPosition&&graphics.points.push({...this.optimalPosition,color:"rgba(76, 175, 80, 0.3)"}),graphics}getOutput(){return this.optimalPosition??this.currentPosition}},TwoPhaseIrlsSolver=class extends BaseSolver3{constructor(params){super();__publicField(this,"offsetPadPoints");__publicField(this,"targetPointMap");__publicField(this,"constraintFn");__publicField(this,"currentPosition");__publicField(this,"optimalPosition");__publicField(this,"initialPosition");__publicField(this,"phase1Epsilon");__publicField(this,"phase2Epsilon");__publicField(this,"maxIterations");__publicField(this,"phase1Solver");__publicField(this,"phase2Solver");__publicField(this,"currentPhase",1);__publicField(this,"phase1Position");__publicField(this,"closestTargetPadId");__publicField(this,"closestTargetPoint");this.offsetPadPoints=[...params.offsetPadPoints],this.targetPointMap=new Map(params.targetPointMap),this.initialPosition={...params.initialPosition},this.currentPosition={...params.initialPosition},this.constraintFn=params.constraintFn,this.phase1Epsilon=params.phase1Epsilon??params.epsilon??1e-6,this.phase2Epsilon=params.phase2Epsilon??params.epsilon??1e-6,this.maxIterations=params.maxIterations??100}getSolverName(){return"TwoPhaseIrlsSolver"}getConstructorParams(){return{offsetPadPoints:this.offsetPadPoints.map(pad2=>({...pad2})),targetPointMap:new Map(this.targetPointMap),initialPosition:this.initialPosition,constraintFn:this.constraintFn,phase1Epsilon:this.phase1Epsilon,phase2Epsilon:this.phase2Epsilon,maxIterations:this.maxIterations}}_setup(){if(this.currentPosition={...this.initialPosition},this.optimalPosition=void 0,this.currentPhase=1,this.phase1Position=void 0,this.closestTargetPadId=void 0,this.closestTargetPoint=void 0,!Array.from(this.targetPointMap.values()).some(targets=>targets.length>0)||this.offsetPadPoints.length===0){this.optimalPosition={...this.currentPosition},this.solved=!0;return}this.phase1Solver=new MultiOffsetIrlsSolver({offsetPadPoints:this.offsetPadPoints,targetPointMap:this.targetPointMap,initialPosition:this.initialPosition,constraintFn:this.constraintFn,epsilon:this.phase1Epsilon,maxIterations:this.maxIterations,useSquaredDistance:!0}),this.phase1Solver.setup()}_step(){this.currentPhase===1?this.stepPhase1():this.stepPhase2()}stepPhase1(){this.phase1Solver&&(this.phase1Solver.step(),this.currentPosition=this.phase1Solver.getBestPosition(),this.phase1Solver.solved?(this.phase1Position=this.phase1Solver.getBestPosition(),this.setupPhase2()):this.phase1Solver.failed&&(this.failed=!0,this.error=`Phase 1 failed: ${this.phase1Solver.error}`))}setupPhase2(){if(!this.phase1Position)return;let minDistance=1/0,closestPadId,closestTarget;for(let pad2 of this.offsetPadPoints){let targetPoints=this.targetPointMap.get(pad2.id)||[];if(targetPoints.length===0)continue;let padX=this.phase1Position.x+pad2.offsetX,padY=this.phase1Position.y+pad2.offsetY;for(let targetPoint of targetPoints){let dx3=padX-targetPoint.x,dy3=padY-targetPoint.y,distance8=Math.sqrt(dx3*dx3+dy3*dy3);distance8<minDistance&&(minDistance=distance8,closestPadId=pad2.id,closestTarget=targetPoint)}}if(this.closestTargetPadId=closestPadId,this.closestTargetPoint=closestTarget,!closestPadId||!closestTarget){this.optimalPosition=this.phase1Position,this.solved=!0;return}let phase2TargetMap=new Map;phase2TargetMap.set(closestPadId,[closestTarget]),this.phase2Solver=new MultiOffsetIrlsSolver({offsetPadPoints:this.offsetPadPoints,targetPointMap:phase2TargetMap,initialPosition:this.phase1Position,constraintFn:this.constraintFn,epsilon:this.phase2Epsilon,maxIterations:this.maxIterations,useSquaredDistance:!1}),this.phase2Solver.setup(),this.currentPhase=2}stepPhase2(){this.phase2Solver&&(this.phase2Solver.step(),this.currentPosition=this.phase2Solver.getBestPosition(),this.phase2Solver.solved?(this.optimalPosition=this.phase2Solver.getBestPosition(),this.solved=!0):this.phase2Solver.failed&&(this.failed=!0,this.error=`Phase 2 failed: ${this.phase2Solver.error}`))}getBestPosition(){return this.optimalPosition||this.currentPosition}getOffsetPadPositions(){let currentPos=this.getBestPosition(),padPositions=new Map;for(let pad2 of this.offsetPadPoints)padPositions.set(pad2.id,{x:currentPos.x+pad2.offsetX,y:currentPos.y+pad2.offsetY});return padPositions}getTotalDistance(position4){let pos=position4||this.getBestPosition(),totalDistance=0;for(let pad2 of this.offsetPadPoints){let padPosition={x:pos.x+pad2.offsetX,y:pos.y+pad2.offsetY},targetPoints=this.targetPointMap.get(pad2.id)||[];for(let target of targetPoints){let dx3=padPosition.x-target.x,dy3=padPosition.y-target.y;totalDistance+=dx3*dx3+dy3*dy3}}return totalDistance}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]};if(graphics.points.push({...this.currentPosition,color:this.currentPhase===1?"#FF6B6B":"#4ECDC4",label:`Phase ${this.currentPhase}`}),this.phase1Position&&this.currentPhase===2&&graphics.points.push({...this.phase1Position,color:"rgba(255, 107, 107, 0.5)",label:"Phase 1 result"}),this.closestTargetPoint&&this.closestTargetPadId){graphics.points.push({...this.closestTargetPoint,color:"#FFA500",label:`Closest target (${this.closestTargetPadId})`});let closestPad=this.offsetPadPoints.find(p4=>p4.id===this.closestTargetPadId);if(closestPad){let currentPos=this.getBestPosition(),padPos={x:currentPos.x+closestPad.offsetX,y:currentPos.y+closestPad.offsetY};graphics.lines.push({points:[padPos,this.closestTargetPoint],strokeColor:"#FFA500"})}}let activeSolver=this.currentPhase===1?this.phase1Solver:this.phase2Solver;if(activeSolver){let solverViz=activeSolver.visualize(),phaseColor=this.currentPhase===1?"rgba(255, 107, 107, 0.7)":"rgba(76, 205, 196, 0.7)";if(solverViz.lines){let modifiedLines=solverViz.lines.map(line2=>({...line2,strokeColor:phaseColor}));graphics.lines.push(...modifiedLines)}solverViz.points&&graphics.points.push(...solverViz.points),solverViz.rects&&graphics.rects.push(...solverViz.rects),solverViz.circles&&graphics.circles.push(...solverViz.circles)}return this.optimalPosition&&graphics.points.push({...this.optimalPosition,color:"rgba(76, 175, 80, 0.8)",label:"Final optimal position"}),graphics}getOutput(){return this.optimalPosition??this.currentPosition}};function isStrongConnection(pad1Id,pad2Id,weightedConnections){return!weightedConnections||weightedConnections.length===0?!0:weightedConnections.some(wc3=>wc3.padIds.includes(pad1Id)&&wc3.padIds.includes(pad2Id))}var createColorMapFromStrings=strings=>{let colorMap2={};for(let i3=0;i3<strings.length;i3++)colorMap2[strings[i3]]=`hsl(${i3*300/strings.length}, 100%, 50%)`;return colorMap2},getColorForString=(string,alpha=1)=>`hsl(${string.split("").reduce((acc,char)=>acc*31+char.charCodeAt(0),0)%360}, 100%, 50%, ${alpha})`;function getOutwardNormal(outlineSegment,ccwFullOutline){let[p12,p22]=outlineSegment,dx3=p22.x-p12.x,dy3=p22.y-p12.y,len=Math.hypot(dx3,dy3);if(len===0)return{x:0,y:1};let dirX=dx3/len,dirY=dy3/len,left={x:-dirY,y:dirX},right={x:dirY,y:-dirX},verts=[];if(ccwFullOutline.length>0){verts.push(ccwFullOutline[0][0]);for(let seg of ccwFullOutline)verts.push(seg[1])}let signedArea22=(()=>{let a3=0;for(let i3=0;i3<verts.length;i3++){let v12=verts[i3],v22=verts[(i3+1)%verts.length];a3+=v12.x*v22.y-v22.x*v12.y}return a3/2})(),geometricOutward=signedArea22>0?right:left;return signedArea22<0?{x:-geometricOutward.x,y:-geometricOutward.y}:geometricOutward}var LargestRectOutsideOutlineFromPointSolver=class extends BaseSolver2{constructor(params){super();__publicField(this,"ccwFullOutline");__publicField(this,"origin");__publicField(this,"globalBounds");__publicField(this,"largestRect",null);__publicField(this,"mode");this.ccwFullOutline=params.ccwFullOutline,this.origin=params.origin,this.globalBounds=params.globalBounds,this.mode=params.mode??"outside"}getSolverName(){return"LargestRectOutsideOutlineFromPointSolver"}getConstructorParams(){return{ccwFullOutline:this.ccwFullOutline,origin:this.origin,globalBounds:this.globalBounds,mode:this.mode}}_setup(){}_step(){this.largestRect=this.computeLargestRect(),this.solved=!0}computeLargestRect(){let edges=this.makeEdges(this.ccwFullOutline),bounds={x:this.globalBounds.minX,y:this.globalBounds.minY,w:this.globalBounds.maxX-this.globalBounds.minX,h:this.globalBounds.maxY-this.globalBounds.minY};return this.largestRectContainingPointRegion(edges,this.origin,bounds,this.mode)}almostEqual(a3,b3,eps=1e-9){return Math.abs(a3-b3)<=eps}makeEdges(poly){let edges=[];for(let i3=0;i3<poly.length;i3++){let a3=poly[i3],b3=poly[(i3+1)%poly.length];!a3||!b3||this.almostEqual(a3.x,b3.x)&&this.almostEqual(a3.y,b3.y)||edges.push([a3,b3])}return edges}isVertical(e5){return this.almostEqual(e5[0].x,e5[1].x)}isHorizontal(e5){return this.almostEqual(e5[0].y,e5[1].y)}scanlineIntervalsAtY(edges,y02){let xs3=[];for(let e5 of edges){if(!this.isVertical(e5))continue;let y12=e5[0].y,y22=e5[1].y,x4=e5[0].x,ymin=Math.min(y12,y22),ymax=Math.max(y12,y22);ymin<=y02&&y02<ymax&&xs3.push(x4)}xs3.sort((a3,b3)=>a3-b3);let intervals=[];for(let i3=0;i3+1<xs3.length;i3+=2){let x12=xs3[i3],x22=xs3[i3+1];x12!==void 0&&x22!==void 0&&intervals.push([x12,x22])}return intervals}clipIntervals(intervals,a3,b3){let out=[];for(let[L3,R3]of intervals){let l4=Math.max(a3,L3),r5=Math.min(b3,R3);r5>l4&&out.push([l4,r5])}return out}regionIntervalsAtY(edges,y02,bx1,bx22,mode){let inside2=this.clipIntervals(this.scanlineIntervalsAtY(edges,y02),bx1,bx22);if(mode==="inside")return inside2;let outs=[],prev=bx1;for(let[L3,R3]of inside2)L3>prev&&outs.push([prev,L3]),prev=Math.max(prev,R3);return prev<bx22&&outs.push([prev,bx22]),outs}largestRectContainingPointRegion(edges,p4,bounds,mode){let BX1=bounds.x,BX2=bounds.x+bounds.w,BY1=bounds.y,BY2=bounds.y+bounds.h,interval=this.regionIntervalsAtY(edges,p4.y,BX1,BX2,mode).find(([xL2,xR2])=>xL2-1e-9<=p4.x&&p4.x<=xR2+1e-9);if(!interval)return null;let[X_L,X_R]=interval,xset=new Set([X_L,X_R]);for(let e5 of edges){if(!this.isVertical(e5))continue;let x4=e5[0].x;X_L<x4&&x4<X_R&&xset.add(x4)}let xs3=Array.from(xset).sort((a3,b3)=>a3-b3),m4=xs3.length-1;if(m4<=0)return null;let top=Array(m4).fill(-1/0),bot=Array(m4).fill(1/0);for(let i3=0;i3<m4;i3++){let xi3=xs3[i3],xi1=xs3[i3+1];if(xi3===void 0||xi1===void 0)continue;let xm3=.5*(xi3+xi1);xset.has(xm3)&&(xm3+=1e-6);let minAbove=BY2,maxBelow=BY1;for(let e5 of edges){if(!this.isHorizontal(e5))continue;let y4=e5[0].y,x12=Math.min(e5[0].x,e5[1].x),x22=Math.max(e5[0].x,e5[1].x);x12-1e-9<=xm3&&xm3<=x22+1e-9&&(y4>p4.y&&(minAbove=Math.min(minAbove,y4)),y4<p4.y&&(maxBelow=Math.max(maxBelow,y4)))}maxBelow<minAbove?(top[i3]=minAbove,bot[i3]=maxBelow):(top[i3]=-1/0,bot[i3]=1/0)}let s02=-1;for(let i3=0;i3<m4;i3++){let xi3=xs3[i3],xi1=xs3[i3+1];if(!(xi3===void 0||xi1===void 0)&&xi3-1e-9<=p4.x&&p4.x<=xi1+1e-9){s02=i3;break}}if(s02===-1)return null;let best=null,bestArea=-1;for(let i3=0;i3<=s02;i3++){let minTop=1/0,maxBot=-1/0;for(let j4=i3;j4<m4;j4++){let topJ=top[j4],botJ=bot[j4];if(topJ===void 0||botJ===void 0||(minTop=Math.min(minTop,topJ),maxBot=Math.max(maxBot,botJ),j4<s02))continue;let height=Math.max(0,minTop-maxBot);if(height<=0)continue;let xi3=xs3[i3],xj1=xs3[j4+1];if(xi3===void 0||xj1===void 0)continue;let width=xj1-xi3,area=width*height;area>bestArea&&(bestArea=area,best={x:xi3,y:maxBot,w:width,h:height})}}return best}getLargestRect(){return this.solved||this.solve(),this.largestRect}getLargestRectBounds(){return this.solved||this.solve(),this.largestRect?{minX:this.largestRect.x,minY:this.largestRect.y,maxX:this.largestRect.x+this.largestRect.w,maxY:this.largestRect.y+this.largestRect.h}:{minX:0,minY:0,maxX:0,maxY:0}}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]};for(let i3=0;i3<this.ccwFullOutline.length;i3++){let p12=this.ccwFullOutline[i3],p22=this.ccwFullOutline[(i3+1)%this.ccwFullOutline.length];p12&&p22&&graphics.lines.push({points:[p12,p22],strokeColor:"rgba(0,0,0,0.5)"})}return graphics.lines.push({points:[...this.ccwFullOutline,this.ccwFullOutline[0]],strokeColor:"rgba(200, 200, 200, 0.5)",strokeDash:[10,5]}),graphics.circles.push({center:this.origin,radius:.05,fill:"#f44336",label:"Origin"}),this.largestRect&&graphics.rects.push({center:{x:this.largestRect.x+this.largestRect.w/2,y:this.largestRect.y+this.largestRect.h/2},width:this.largestRect.w,height:this.largestRect.h,fill:"rgba(0, 255, 0, 0.3)",stroke:"#4CAF50",label:`Largest Rectangle (Area: ${(this.largestRect.w*this.largestRect.h).toFixed(3)})`}),graphics}getOutput(){return this.largestRect??null}},getInputComponentBounds=(component,{rotationDegrees=0})=>{let bounds={minX:1/0,maxX:-1/0,minY:1/0,maxY:-1/0};for(let pad2 of component.pads){let hw3=pad2.size.x/2,hh3=pad2.size.y/2,localCorners=[{x:pad2.offset.x-hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y+hh3},{x:pad2.offset.x-hw3,y:pad2.offset.y+hh3}];for(let corner of localCorners){let world=rotatePoint(corner,rotationDegrees*Math.PI/180),x4=world.x,y4=world.y;bounds.minX=Math.min(bounds.minX,x4),bounds.maxX=Math.max(bounds.maxX,x4),bounds.minY=Math.min(bounds.minY,y4),bounds.maxY=Math.max(bounds.maxY,y4)}}return{minX:bounds.minX,maxX:bounds.maxX,minY:bounds.minY,maxY:bounds.maxY}},expandSegment=(segment2,amount)=>{let[p12,p22]=segment2,direction2={x:p22.x-p12.x,y:p22.y-p12.y},normalizedDirection=normalizeVector(direction2);return[{x:p12.x-normalizedDirection.x*amount,y:p12.y-normalizedDirection.y*amount},{x:p22.x+normalizedDirection.x*amount,y:p22.y+normalizedDirection.y*amount}]};function normalizeVector(direction2){let length4=Math.hypot(direction2.x,direction2.y);return{x:direction2.x/length4,y:direction2.y/length4}}function isPointInPolygon2(point7,polygon2){if(polygon2.length<3)return!1;let inside2=!1,n4=polygon2.length,poly=[...polygon2];(poly[0].x!==poly[n4-1].x||poly[0].y!==poly[n4-1].y)&&poly.push({...poly[0]});for(let i3=0,j4=poly.length-1;i3<poly.length;j4=i3++){let xi3=poly[i3].x,yi3=poly[i3].y,xj=poly[j4].x,yj=poly[j4].y;yi3>point7.y!=yj>point7.y&&point7.x<(xj-xi3)*(point7.y-yi3)/(yj-yi3)+xi3&&(inside2=!inside2)}return inside2}var OutlineSegmentCandidatePointSolver=class extends BaseSolver2{constructor(params){super();__publicField(this,"outlineSegment");__publicField(this,"viableOutlineSegment",null);__publicField(this,"ccwFullOutline");__publicField(this,"componentRotationDegrees");__publicField(this,"packStrategy");__publicField(this,"minGap");__publicField(this,"obstacles");__publicField(this,"packedComponents");__publicField(this,"componentToPack");__publicField(this,"viableBounds");__publicField(this,"globalBounds");__publicField(this,"boundaryOutline");__publicField(this,"weightedConnections");__publicField(this,"optimalPosition");__publicField(this,"irlsSolver");__publicField(this,"twoPhaseIrlsSolver");__publicField(this,"largestRectBounds");__publicField(this,"largestRectMidPoint");__publicField(this,"largestRectOrigin");this.outlineSegment=params.outlineSegment,this.ccwFullOutline=params.ccwFullOutline,this.componentRotationDegrees=params.componentRotationDegrees,this.packStrategy=params.packStrategy,this.minGap=params.minGap,this.packedComponents=params.packedComponents,this.componentToPack=params.componentToPack,this.obstacles=params.obstacles??[],this.globalBounds=params.globalBounds,this.boundaryOutline=params.boundaryOutline,this.weightedConnections=params.weightedConnections}getSolverName(){return"OutlineSegmentCandidatePointSolver"}getConstructorParams(){return{outlineSegment:this.outlineSegment,ccwFullOutline:this.ccwFullOutline,componentRotationDegrees:this.componentRotationDegrees,packStrategy:this.packStrategy,minGap:this.minGap,packedComponents:this.packedComponents,componentToPack:this.componentToPack,obstacles:this.obstacles,globalBounds:this.globalBounds,boundaryOutline:this.boundaryOutline,weightedConnections:this.weightedConnections}}_getOutlineBoundsWithMargin(params={}){let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let[p12,p22]of this.ccwFullOutline)minX=Math.min(minX,p12.x,p22.x),minY=Math.min(minY,p12.y,p22.y),maxX=Math.max(maxX,p12.x,p22.x),maxY=Math.max(maxY,p12.y,p22.y);let margin=params.margin??0;return{minX:minX-margin,minY:minY-margin,maxX:maxX+margin,maxY:maxY+margin}}_setup(){let{offsetPadPoints,targetPointMap}=this.getNetworkTargetPointMappings(),[p12,p22]=this.outlineSegment,constraintFn=point7=>{let projectedPoint=this.projectPointOntoSegment(point7,this.viableOutlineSegment);return this.adjustPositionForOutlineCollision(projectedPoint)},outwardNormal=getOutwardNormal(this.outlineSegment,this.ccwFullOutline),componentBounds=getInputComponentBounds(this.componentToPack,{rotationDegrees:this.componentRotationDegrees}),packedComponentBoundsWithMargin=this._getOutlineBoundsWithMargin({margin:Math.max(componentBounds.maxX-componentBounds.minX,componentBounds.maxY-componentBounds.minY)*2+this.minGap*2});this.largestRectMidPoint={x:(p12.x+p22.x)/2,y:(p12.y+p22.y)/2},this.largestRectOrigin={x:this.largestRectMidPoint.x+outwardNormal.x*1e-4,y:this.largestRectMidPoint.y+outwardNormal.y*1e-4};let outlinePoints=this.ccwFullOutline.flatMap(([p4])=>p4),signedArea22=0;for(let i3=0;i3<outlinePoints.length;i3++){let p122=outlinePoints[i3],p222=outlinePoints[(i3+1)%outlinePoints.length];signedArea22+=p122.x*p222.y-p222.x*p122.y}signedArea22/=2;let rectSearchMode=signedArea22<0?"inside":"outside",largestRectSolverParams={ccwFullOutline:outlinePoints,globalBounds:packedComponentBoundsWithMargin,origin:this.largestRectOrigin,mode:rectSearchMode},largestRectSolver=new LargestRectOutsideOutlineFromPointSolver(largestRectSolverParams);largestRectSolver.solve();let largestRectBounds=largestRectSolver.getLargestRectBounds();this.largestRectBounds=largestRectBounds;let segmentNormAbs={x:Math.abs(Math.sign(this.outlineSegment[1].x-this.outlineSegment[0].x)),y:Math.abs(Math.sign(this.outlineSegment[1].y-this.outlineSegment[0].y))},viableBounds={minX:largestRectBounds.minX-componentBounds.minX*segmentNormAbs.x,minY:largestRectBounds.minY-componentBounds.minY*segmentNormAbs.y,maxX:largestRectBounds.maxX-componentBounds.maxX*segmentNormAbs.x,maxY:largestRectBounds.maxY-componentBounds.maxY*segmentNormAbs.y};if(this.boundaryOutline&&this.boundaryOutline.length>=3){let boundaryMinX=1/0,boundaryMinY=1/0,boundaryMaxX=-1/0,boundaryMaxY=-1/0;for(let point7 of this.boundaryOutline)boundaryMinX=Math.min(boundaryMinX,point7.x),boundaryMinY=Math.min(boundaryMinY,point7.y),boundaryMaxX=Math.max(boundaryMaxX,point7.x),boundaryMaxY=Math.max(boundaryMaxY,point7.y);viableBounds={minX:Math.max(viableBounds.minX,boundaryMinX-componentBounds.minX),minY:Math.max(viableBounds.minY,boundaryMinY-componentBounds.minY),maxX:Math.min(viableBounds.maxX,boundaryMaxX-componentBounds.maxX),maxY:Math.min(viableBounds.maxY,boundaryMaxY-componentBounds.maxY)}}this.viableBounds=viableBounds;let viableBoundsWidth=viableBounds.maxX-viableBounds.minX,viableBoundsHeight=viableBounds.maxY-viableBounds.minY,componentBoundsWidth=componentBounds.maxX-componentBounds.minX,componentBoundsHeight=componentBounds.maxY-componentBounds.minY;if(viableBoundsWidth<componentBoundsWidth||viableBoundsHeight<componentBoundsHeight){this.failed=!0,this.error="There is nowhere for the component to fit along this outline section";return}let segmentLength=Math.hypot(p22.x-p12.x,p22.y-p12.y),expandedOutlineSegment=expandSegment(this.outlineSegment,segmentLength),[s12,s22]=expandedOutlineSegment;this.viableOutlineSegment=[{x:clamp(s12.x,viableBounds.minX,viableBounds.maxX),y:clamp(s12.y,viableBounds.minY,viableBounds.maxY)},{x:clamp(s22.x,viableBounds.minX,viableBounds.maxX),y:clamp(s22.y,viableBounds.minY,viableBounds.maxY)}];let[vp1,vp22]=this.viableOutlineSegment,initialPosition=this.adjustPositionForOutlineCollision({x:(vp1.x+vp22.x)/2,y:(vp1.y+vp22.y)/2});this.packStrategy==="minimum_closest_sum_squared_distance"?this.twoPhaseIrlsSolver=new TwoPhaseIrlsSolver({offsetPadPoints,targetPointMap,initialPosition,constraintFn,epsilon:1e-6,maxIterations:50}):this.irlsSolver=new MultiOffsetIrlsSolver({offsetPadPoints,targetPointMap,initialPosition,constraintFn,epsilon:1e-6,maxIterations:50,useSquaredDistance:this.packStrategy==="minimum_sum_squared_distance_to_network"})}_step(){let activeSolver=this.irlsSolver||this.twoPhaseIrlsSolver;if(!activeSolver){this.solved=!0;return}if(activeSolver.step(),activeSolver.solved){let rawPosition=activeSolver.getBestPosition();this.optimalPosition=rawPosition,this.solved=!0}else activeSolver.failed&&(this.failed=!0,this.error=activeSolver.error)}getNetworkTargetPointMappings(){let rotatedPads=this.getRotatedComponentPads(),offsetPadPoints=rotatedPads.map(pad2=>({id:pad2.padId,offsetX:pad2.offset.x,offsetY:pad2.offset.y})),targetPointMap=new Map;for(let pad2 of rotatedPads){let targetPoints=[];for(let packedComponent of this.packedComponents)for(let packedPad of packedComponent.pads)if(packedPad.networkId===pad2.networkId){if(!isStrongConnection(pad2.padId,packedPad.padId,this.weightedConnections))continue;targetPoints.push({...packedPad.absoluteCenter,networkId:packedPad.networkId})}targetPointMap.set(pad2.padId,targetPoints)}return{offsetPadPoints,targetPointMap}}projectPointOntoSegment(point7,segment2){let[p12,p22]=segment2,segmentX=p22.x-p12.x,segmentY=p22.y-p12.y,pointX=point7.x-p12.x,pointY=point7.y-p12.y,segmentLengthSq=segmentX*segmentX+segmentY*segmentY;if(segmentLengthSq===0)return{x:p12.x,y:p12.y};let t52=Math.max(0,Math.min(1,(pointX*segmentX+pointY*segmentY)/segmentLengthSq));return{x:p12.x+t52*segmentX,y:p12.y+t52*segmentY}}getRotatedComponentPads(){let rotationRadians=this.componentRotationDegrees*Math.PI/180;return this.componentToPack.pads.map(pad2=>({...pad2,size:(this.componentRotationDegrees+90)%180===0?{x:pad2.size.y,y:pad2.size.x}:pad2.size,offset:rotatePoint(pad2.offset,rotationRadians)}))}createTemporaryPackedComponent(center2){let rotationRadians=this.componentRotationDegrees*Math.PI/180,flipWidthHeight=(this.componentRotationDegrees+90)%180===0;return{componentId:this.componentToPack.componentId,center:center2,ccwRotationOffset:this.componentRotationDegrees,pads:this.componentToPack.pads.map(pad2=>{let rotatedOffset=rotatePoint(pad2.offset,rotationRadians);return{...pad2,size:{x:flipWidthHeight?pad2.size.y:pad2.size.x,y:flipWidthHeight?pad2.size.x:pad2.size.y},absoluteCenter:{x:center2.x+rotatedOffset.x,y:center2.y+rotatedOffset.y}}})}}adjustPositionForOutlineCollision(center2){let tempComponent=this.createTemporaryPackedComponent(center2),bounds=getComponentBounds(tempComponent,0),outwardNormal=getOutwardNormal(this.outlineSegment,this.ccwFullOutline),isHorizontalNormal=Math.abs(outwardNormal.x)>Math.abs(outwardNormal.y),isVerticalNormal=!isHorizontalNormal,adjustedCenter=center2;if(isHorizontalNormal){let isXPlusFacing=outwardNormal.x>0;isXPlusFacing?adjustedCenter={x:bounds.maxX,y:center2.y}:!isXPlusFacing&&(adjustedCenter={x:bounds.minX,y:center2.y})}else if(isVerticalNormal){let isYPlusFacing=outwardNormal.y>0;isYPlusFacing?adjustedCenter={x:center2.x,y:bounds.maxY}:!isYPlusFacing&&(adjustedCenter={x:center2.x,y:bounds.minY})}if(this.boundaryOutline&&this.boundaryOutline.length>=3){let adjustedComponent=this.createTemporaryPackedComponent(adjustedCenter),adjustedBounds=getComponentBounds(adjustedComponent,0),allPadsInside=adjustedComponent.pads.every(pad2=>isPointInPolygon2(pad2.absoluteCenter,this.boundaryOutline)),cornersInside=[{x:adjustedBounds.minX,y:adjustedBounds.minY},{x:adjustedBounds.minX,y:adjustedBounds.maxY},{x:adjustedBounds.maxX,y:adjustedBounds.minY},{x:adjustedBounds.maxX,y:adjustedBounds.maxY}].every(corner=>isPointInPolygon2(corner,this.boundaryOutline));(!allPadsInside||!cornersInside)&&this.viableBounds&&(adjustedCenter={x:clamp(adjustedCenter.x,this.viableBounds.minX,this.viableBounds.maxX),y:clamp(adjustedCenter.y,this.viableBounds.minY,this.viableBounds.maxY)})}return adjustedCenter}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]};if(this.obstacles&&this.obstacles.length>0)for(let obstacle of this.obstacles)graphics.rects.push({center:obstacle.absoluteCenter,width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});if(this.globalBounds&&graphics.lines.push({points:[{x:this.globalBounds.minX,y:this.globalBounds.minY},{x:this.globalBounds.minX,y:this.globalBounds.maxY},{x:this.globalBounds.maxX,y:this.globalBounds.maxY},{x:this.globalBounds.maxX,y:this.globalBounds.minY},{x:this.globalBounds.minX,y:this.globalBounds.minY}],strokeColor:"rgba(255,0,255,0.5)",strokeDash:"2 2"}),this.boundaryOutline&&this.boundaryOutline.length){let outlinePoints=[...this.boundaryOutline];outlinePoints.length>0&&(outlinePoints[0].x!==outlinePoints[outlinePoints.length-1].x||outlinePoints[0].y!==outlinePoints[outlinePoints.length-1].y)&&outlinePoints.push({...outlinePoints[0]}),graphics.lines.push({points:outlinePoints,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}if(this.viableBounds&&graphics.rects.push({center:{x:(this.viableBounds.minX+this.viableBounds.maxX)/2,y:(this.viableBounds.minY+this.viableBounds.maxY)/2},width:this.viableBounds.maxX-this.viableBounds.minX,height:this.viableBounds.maxY-this.viableBounds.minY,fill:"rgba(0,255,0,0.1)",label:"Viable Bounds"}),this.largestRectBounds&&graphics.rects.push({center:{x:(this.largestRectBounds.minX+this.largestRectBounds.maxX)/2,y:(this.largestRectBounds.minY+this.largestRectBounds.maxY)/2},width:this.largestRectBounds.maxX-this.largestRectBounds.minX,height:this.largestRectBounds.maxY-this.largestRectBounds.minY,fill:"rgba(255,0,255,0.4)"}),this.largestRectMidPoint&&graphics.points.push({...this.largestRectMidPoint,label:"Largest Rect Mid Point",color:"rgba(128,0,255,1)"}),this.largestRectOrigin&&graphics.points.push({...this.largestRectOrigin,label:"Largest Rect Origin",color:"rgba(255,0,128,1)"}),this.viableOutlineSegment){let[p12,p22]=this.viableOutlineSegment;graphics.lines.push({points:[p12,p22],strokeColor:"#2196F3"})}let[osp1,osp2]=this.outlineSegment;graphics.lines.push({points:[osp1,osp2],strokeColor:"rgba(255,0,0,1)",strokeDash:"3 3"});for(let[p12,p22]of this.ccwFullOutline)graphics.lines.push({points:[p12,p22],strokeColor:"rgba(0,0,0,0.5)",strokeDash:"4 4"});for(let component of this.packedComponents)for(let pad2 of component.pads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:getColorForString(pad2.networkId,.5),stroke:"#333",label:`${pad2.padId} (${pad2.networkId})`});let pos=this.optimalPosition??this.irlsSolver?.currentPosition??this.twoPhaseIrlsSolver?.currentPosition??{x:0,y:0},rotatedPads=this.getRotatedComponentPads();for(let pad2 of rotatedPads){let padPos={x:pos.x+pad2.offset.x,y:pos.y+pad2.offset.y};graphics.rects.push({center:padPos,width:pad2.size.x,height:pad2.size.y,fill:this.failed?"rgba(255,0,0,0.5)":getColorForString(pad2.networkId,.5),label:`${pad2.padId} (${pad2.networkId})`});for(let packedComponent of this.packedComponents)for(let packedPad of packedComponent.pads)if(packedPad.networkId===pad2.networkId){let isStrong=isStrongConnection(pad2.padId,packedPad.padId,this.weightedConnections);graphics.lines.push({points:[padPos,packedPad.absoluteCenter],strokeColor:pad2.networkId==="VCC"?"#FF6B6B":"#4ECDC4",strokeDash:isStrong?void 0:"4 2",label:`${pad2.networkId} ${isStrong?"strong":"weak"}`})}}let activeSolver=this.irlsSolver||this.twoPhaseIrlsSolver;if(activeSolver){let currentPos=activeSolver.currentPosition;graphics.points.push({...currentPos,color:"#f44336"});let solverViz=activeSolver.visualize();solverViz.lines&&graphics.lines.push(...solverViz.lines),solverViz.circles&&graphics.circles.push(...solverViz.circles),solverViz.rects&&graphics.rects.push(...solverViz.rects),solverViz.points&&graphics.points.push(...solverViz.points)}return this.optimalPosition&&graphics.points.push({...this.optimalPosition,color:"rgba(76, 175, 80, 0.3)"}),graphics}getOutput(){return this.optimalPosition??null}},getGraphicsFromPackOutput=packOutput=>{let rects=[],lines=[];if(packOutput.boundaryOutline&&packOutput.boundaryOutline.length){let outlinePoints=[...packOutput.boundaryOutline];outlinePoints.length>0&&(outlinePoints[0].x!==outlinePoints[outlinePoints.length-1].x||outlinePoints[0].y!==outlinePoints[outlinePoints.length-1].y)&&outlinePoints.push({...outlinePoints[0]}),lines.push({points:outlinePoints,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}let allNetworkIds=Array.from(new Set(packOutput.components.flatMap(c4=>c4.pads.map(p4=>p4.networkId)))),colorMap2=createColorMapFromStrings(allNetworkIds);if(packOutput.obstacles&&packOutput.obstacles.length>0)for(let obstacle of packOutput.obstacles)rects.push({center:{x:obstacle.absoluteCenter.x,y:obstacle.absoluteCenter.y},width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});for(let component of packOutput.components){let bounds=getComponentBounds(component),width=bounds.maxX-bounds.minX,height=bounds.maxY-bounds.minY,isStatic=!!component.isStatic,rect={center:{x:component.center.x,y:component.center.y},width,height,fill:isStatic?"rgba(33, 150, 243, 0.25)":"rgba(0,0,0,0.25)",stroke:isStatic?"rgba(33, 150, 243, 0.6)":void 0,label:[component.componentId,`ccwRotationOffset: ${component.ccwRotationOffset.toFixed(1)}\xB0`].join(`
629
- `)};rects.push(rect);for(let pad2 of component.pads){let{absoluteCenter,size:size3,padId,networkId}=pad2,padRect={center:{x:absoluteCenter.x,y:absoluteCenter.y},width:size3.x,height:size3.y,label:`${padId} ${networkId}`,fill:"rgba(255,0,0,0.8)"};rects.push(padRect)}}for(let netId of allNetworkIds){let padsOnNet=packOutput.components.flatMap(c4=>c4.pads.filter(p4=>p4.networkId===netId));for(let i3=0;i3<padsOnNet.length;i3++)for(let j4=i3+1;j4<padsOnNet.length;j4++){let pad1=padsOnNet[i3],pad2=padsOnNet[j4],isStrong=isStrongConnection(pad1.padId,pad2.padId,packOutput.weightedConnections);lines.push({points:[pad1.absoluteCenter,pad2.absoluteCenter],strokeColor:colorMap2[netId],strokeDash:isStrong?void 0:"4 2"})}}return{coordinateSystem:"cartesian",rects,lines}};function checkOverlapWithPackedComponents({component,packedComponents,minGap}){let allPackedPadBoxes=packedComponents.flatMap(c4=>c4.pads.map(p4=>({center:{x:p4.absoluteCenter.x,y:p4.absoluteCenter.y},width:p4.size.x,height:p4.size.y}))),newComponentPadBoxes=component.pads.map(p4=>({center:{x:p4.absoluteCenter.x,y:p4.absoluteCenter.y},width:p4.size.x,height:p4.size.y}));for(let newComponentPadBox of newComponentPadBoxes)for(let packedPadBox of allPackedPadBoxes){let{distance:boxDist}=computeDistanceBetweenBoxes(newComponentPadBox,packedPadBox);if(boxDist+1e-6<minGap)return{hasOverlap:!0,gapDistance:boxDist}}return{hasOverlap:!1}}var SingleComponentPackSolver=class extends BaseSolver2{constructor(params){super();__publicField(this,"componentToPack");__publicField(this,"packedComponents");__publicField(this,"packPlacementStrategy");__publicField(this,"minGap");__publicField(this,"obstacles");__publicField(this,"boundaryOutline");__publicField(this,"weightedConnections");__publicField(this,"currentPhase","outline");__publicField(this,"outlines",[]);__publicField(this,"queuedOutlineSegments",[]);__publicField(this,"currentSegmentIndex",0);__publicField(this,"currentRotationIndex",0);__publicField(this,"activeSubSolver",null);__publicField(this,"candidateResults",[]);__publicField(this,"rejectedCandidates",[]);__publicField(this,"bestCandidate");__publicField(this,"outputPackedComponent");__publicField(this,"bounds");this.componentToPack=params.componentToPack,this.packedComponents=params.packedComponents,this.packPlacementStrategy=params.packPlacementStrategy,this.minGap=params.minGap??0,this.obstacles=params.obstacles??[],this.bounds=params.bounds,this.boundaryOutline=params.boundaryOutline,this.weightedConnections=params.weightedConnections}getSolverName(){return"SingleComponentPackSolver"}_setup(){super._setup(),this.currentPhase="outline",this.outlines=[],this.queuedOutlineSegments=[],this.candidateResults=[],this.activeSubSolver=void 0,this.currentSegmentIndex=0,this.currentRotationIndex=0}_step(){if(!(this.solved||this.failed))switch(this.currentPhase){case"outline":this.executeOutlinePhase();break;case"segment_candidate":this.executeSegmentCandidatePhase();break;case"evaluate":this.executeEvaluatePhase();break}}executeOutlinePhase(){if(this.packedComponents.length===0){let availableRotations2=this.componentToPack.availableRotationDegrees??[0,90,180,270],position4={x:0,y:0},rotation5=availableRotations2[0]??0,candidate=this.createPackedComponent(position4,rotation5);if(!(this.obstacles??[]).some(obs=>{let obsBox={center:{x:obs.absoluteCenter.x,y:obs.absoluteCenter.y},width:obs.width,height:obs.height};return candidate.pads.some(p4=>{let padBox={center:{x:p4.absoluteCenter.x,y:p4.absoluteCenter.y},width:p4.size.x,height:p4.size.y},{distance:distance8}=computeDistanceBetweenBoxes(padBox,obsBox);return distance8+1e-6<this.minGap})})){this.outputPackedComponent=candidate,this.solved=!0;return}}this.outlines=constructOutlinesFromPackedComponents(this.packedComponents,{minGap:this.minGap,obstacles:this.obstacles});let availableRotations=this.componentToPack.availableRotationDegrees??[0,90,180,270];for(let segmentIndex=0;segmentIndex<this.outlines.length;segmentIndex++){let outline=this.outlines[segmentIndex];for(let i3=0;i3<outline.length;i3++){let segment2=outline[i3];this.queuedOutlineSegments.push({segment:segment2,availableRotations:[...availableRotations],segmentIndex:segmentIndex*1e3+i3,ccwFullOutline:outline})}}if(this.boundaryOutline&&this.boundaryOutline.length>=3){let boundarySegments=[];for(let i3=0;i3<this.boundaryOutline.length;i3++){let p12=this.boundaryOutline[i3],p22=this.boundaryOutline[(i3+1)%this.boundaryOutline.length];boundarySegments.push([p12,p22])}let boundaryOutlineIndex=this.outlines.length;for(let i3=0;i3<boundarySegments.length;i3++){let segment2=boundarySegments[i3];this.queuedOutlineSegments.push({segment:segment2,availableRotations:[...availableRotations],segmentIndex:boundaryOutlineIndex*1e3+i3,ccwFullOutline:boundarySegments})}}let obstacleOutlineIndex=this.outlines.length+1;for(let obstacle of this.obstacles){let hw3=obstacle.width/2+this.minGap,hh3=obstacle.height/2+this.minGap,cx3=obstacle.absoluteCenter.x,cy3=obstacle.absoluteCenter.y,obstacleCorners=[{x:cx3-hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3+hh3},{x:cx3-hw3,y:cy3+hh3}],obstacleSegments=[[obstacleCorners[0],obstacleCorners[1]],[obstacleCorners[1],obstacleCorners[2]],[obstacleCorners[2],obstacleCorners[3]],[obstacleCorners[3],obstacleCorners[0]]];for(let i3=0;i3<obstacleSegments.length;i3++){let segment2=obstacleSegments[i3];this.queuedOutlineSegments.push({segment:segment2,availableRotations:[...availableRotations],segmentIndex:obstacleOutlineIndex*1e3+i3,ccwFullOutline:obstacleSegments})}obstacleOutlineIndex++}this.currentPhase="segment_candidate",this.currentSegmentIndex=0,this.currentRotationIndex=0}executeSegmentCandidatePhase(){if(this.activeSubSolver?.solved||this.activeSubSolver?.failed){let queuedSegment=this.queuedOutlineSegments[this.currentSegmentIndex],rotation5=queuedSegment.availableRotations[this.currentRotationIndex],distance8=1/0,optimalPosition;if(this.activeSubSolver.solved&&this.activeSubSolver.optimalPosition){optimalPosition=this.activeSubSolver.optimalPosition;let candidateComponent=this.createPackedComponent(optimalPosition,rotation5),{hasOverlap,gapDistance}=checkOverlapWithPackedComponents({component:candidateComponent,packedComponents:this.packedComponents,minGap:this.minGap}),minObstacleGapDistance=1/0,tooCloseToObstacles=(this.obstacles??[]).some(obs=>{let obsBox={center:{x:obs.absoluteCenter.x,y:obs.absoluteCenter.y},width:obs.width,height:obs.height};return candidateComponent.pads.some(p4=>{let padBox={center:{x:p4.absoluteCenter.x,y:p4.absoluteCenter.y},width:p4.size.x,height:p4.size.y},{distance:distance24}=computeDistanceBetweenBoxes(padBox,obsBox);return minObstacleGapDistance=Math.min(minObstacleGapDistance,distance24),distance24+1e-6<this.minGap})}),outsideBounds=!1;if(this.bounds){let componentBounds=getComponentBounds(candidateComponent,0);outsideBounds=componentBounds.minX<this.bounds.minX||componentBounds.maxX>this.bounds.maxX||componentBounds.minY<this.bounds.minY||componentBounds.maxY>this.bounds.maxY}let outsideBoundaryOutline=!1;if(this.boundaryOutline&&this.boundaryOutline.length>=3){let componentBounds=getComponentBounds(candidateComponent,0),allPadsInside=candidateComponent.pads.every(pad2=>isPointInPolygon2(pad2.absoluteCenter,this.boundaryOutline)),cornersInside=[{x:componentBounds.minX,y:componentBounds.minY},{x:componentBounds.minX,y:componentBounds.maxY},{x:componentBounds.maxX,y:componentBounds.minY},{x:componentBounds.maxX,y:componentBounds.maxY}].every(corner=>isPointInPolygon2(corner,this.boundaryOutline));outsideBoundaryOutline=!allPadsInside||!cornersInside}distance8=this.calculateDistance(optimalPosition,rotation5),hasOverlap?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance}):tooCloseToObstacles?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance:minObstacleGapDistance}):outsideBounds?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance:-1}):outsideBoundaryOutline?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance:-1}):this.candidateResults.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex})}this.currentRotationIndex++,this.activeSubSolver=void 0}for(;!this.activeSubSolver;){if(this.currentSegmentIndex>=this.queuedOutlineSegments.length){this.currentPhase="evaluate";return}let queuedSegment=this.queuedOutlineSegments[this.currentSegmentIndex];if(this.currentRotationIndex>=queuedSegment.availableRotations.length){this.currentSegmentIndex++,this.currentRotationIndex=0;continue}let rotation5=queuedSegment.availableRotations[this.currentRotationIndex];this.activeSubSolver=new OutlineSegmentCandidatePointSolver({outlineSegment:queuedSegment.segment,ccwFullOutline:queuedSegment.ccwFullOutline,componentRotationDegrees:rotation5,packStrategy:this.packPlacementStrategy,minGap:this.minGap,packedComponents:this.packedComponents,componentToPack:this.componentToPack,obstacles:this.obstacles,globalBounds:this.bounds,boundaryOutline:this.boundaryOutline,weightedConnections:this.weightedConnections}),this.activeSubSolver.setup();break}this.activeSubSolver.step()}executeEvaluatePhase(){if(this.candidateResults.length===0){this.failed=!0,this.error="No valid candidates found";return}this.candidateResults.sort((a3,b3)=>a3.distance-b3.distance),this.bestCandidate=this.candidateResults[0],this.bestCandidate.optimalPosition&&(this.outputPackedComponent=this.createPackedComponent(this.bestCandidate.optimalPosition,this.bestCandidate.rotation)),this.solved=!0}calculateDistance(position4,rotation5){let tempComponent=this.createPackedComponent(position4,rotation5),totalDistance=0,useSquaredDistance=this.packPlacementStrategy==="minimum_sum_squared_distance_to_network"||this.packPlacementStrategy==="minimum_closest_sum_squared_distance";for(let pad2 of tempComponent.pads){let minDistanceToNetwork=1/0;for(let packedComponent of this.packedComponents)for(let packedPad of packedComponent.pads)if(packedPad.networkId===pad2.networkId){if(!isStrongConnection(pad2.padId,packedPad.padId,this.weightedConnections))continue;let dx3=pad2.absoluteCenter.x-packedPad.absoluteCenter.x,dy3=pad2.absoluteCenter.y-packedPad.absoluteCenter.y,dist=Math.sqrt(dx3*dx3+dy3*dy3);minDistanceToNetwork=Math.min(minDistanceToNetwork,dist)}minDistanceToNetwork<1/0&&(totalDistance+=useSquaredDistance?minDistanceToNetwork*minDistanceToNetwork:minDistanceToNetwork)}return totalDistance}createPackedComponent(position4,rotation5){let component={...this.componentToPack,center:position4,ccwRotationOffset:rotation5,pads:this.componentToPack.pads.map(pad2=>({...pad2,absoluteCenter:{x:0,y:0}}))};return setPackedComponentPadCenters(component),component}visualize(){if(this.activeSubSolver)return this.activeSubSolver.visualize();let graphics=getGraphicsFromPackOutput({components:this.packedComponents,minGap:this.minGap,packOrderStrategy:"largest_to_smallest",packPlacementStrategy:this.packPlacementStrategy});if(graphics.points??(graphics.points=[]),graphics.lines??(graphics.lines=[]),graphics.rects??(graphics.rects=[]),graphics.texts??(graphics.texts=[]),graphics.circles??(graphics.circles=[]),this.obstacles&&this.obstacles.length>0)for(let obstacle of this.obstacles)graphics.rects.push({center:obstacle.absoluteCenter,width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});if(this.bounds&&graphics.lines.push({points:[{x:this.bounds.minX,y:this.bounds.minY},{x:this.bounds.minX,y:this.bounds.maxY},{x:this.bounds.maxX,y:this.bounds.maxY},{x:this.bounds.maxX,y:this.bounds.minY},{x:this.bounds.minX,y:this.bounds.minY}],strokeColor:"rgba(0,0,0,0.5)",strokeDash:"2 2"}),this.boundaryOutline&&this.boundaryOutline.length){let outlinePoints=[...this.boundaryOutline];outlinePoints.length>0&&(outlinePoints[0].x!==outlinePoints[outlinePoints.length-1].x||outlinePoints[0].y!==outlinePoints[outlinePoints.length-1].y)&&outlinePoints.push({...outlinePoints[0]}),graphics.lines.push({points:outlinePoints,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}switch(this.currentPhase){case"outline":this.visualizeOutlinePhase(graphics);break;case"segment_candidate":this.visualizeSegmentCandidatePhase(graphics);break;case"evaluate":this.visualizeEvaluatePhase(graphics);break}return graphics}visualizeOutlinePhase(graphics){for(let outline of this.outlines)for(let segment2 of outline){let[p12,p22]=segment2;graphics.lines.push({points:[p12,p22],strokeColor:"#ff4444"})}for(let i3=0;i3<this.outlines.length;i3++){let outline=this.outlines[i3];for(let u5=0;u5<outline.length;u5++){let[p12,p22]=outline[u5];graphics.points.push({x:p12.x,y:p12.y,label:`outlines [${i3}] [${u5}]`,color:"#ff4444"})}}}visualizeSegmentCandidatePhase(graphics){if(this.visualizeOutlinePhase(graphics),this.activeSubSolver){let subSolverViz=this.activeSubSolver.visualize();subSolverViz.lines&&graphics.lines.push(...subSolverViz.lines),subSolverViz.points&&graphics.points.push(...subSolverViz.points),subSolverViz.rects&&graphics.rects.push(...subSolverViz.rects),subSolverViz.circles&&graphics.circles.push(...subSolverViz.circles??[])}else for(let i3=0;i3<this.candidateResults.length;i3++){let candidate=this.candidateResults[i3];if(candidate.optimalPosition){let tempComponent=this.createPackedComponent(candidate.optimalPosition,candidate.rotation);for(let pad2 of tempComponent.pads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:"rgba(255,165,0,0.3)",stroke:"rgba(255,165,0,0.8)",strokeWidth:1});graphics.points.push({x:candidate.optimalPosition.x,y:candidate.optimalPosition.y,label:`c${i3}, d=${candidate.distance.toFixed(3)}`,color:"rgba(255,165,0,0.8)"})}}}visualizeEvaluatePhase(graphics){this.visualizeOutlinePhase(graphics);for(let i3=0;i3<this.candidateResults.length;i3++){let candidate=this.candidateResults[i3];if(!candidate.optimalPosition)continue;let step=i3,isBest=step===0;graphics.points.push({x:candidate.optimalPosition.x,y:candidate.optimalPosition.y,label:`step=${step}, d=${candidate.distance.toFixed(3)}`,color:isBest?"rgba(0,255,0,0.8)":"rgba(255,165,0,0.6)"})}for(let i3=0;i3<this.rejectedCandidates.length;i3++){let candidate=this.rejectedCandidates[i3];candidate.optimalPosition&&graphics.points.push({x:candidate.optimalPosition.x,y:candidate.optimalPosition.y,label:`rejected, d=${candidate.distance.toFixed(3)}
630
- gap_distance=${candidate.gapDistance}`,color:"rgba(255,0,0,0.8)"})}if(this.outputPackedComponent)for(let pad2 of this.outputPackedComponent.pads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:"rgba(0,255,0,0.7)"})}getResult(){return this.outputPackedComponent}getOutput(){return this.getResult()}getConstructorParams(){return{componentToPack:this.componentToPack,packedComponents:this.packedComponents,packPlacementStrategy:this.packPlacementStrategy,minGap:this.minGap,obstacles:this.obstacles,bounds:this.bounds,boundaryOutline:this.boundaryOutline,weightedConnections:this.weightedConnections}}};function getPolygonCentroid(points){if(points.length<3){let sumX=points.reduce((sum,p4)=>sum+p4.x,0),sumY=points.reduce((sum,p4)=>sum+p4.y,0);return{x:sumX/points.length,y:sumY/points.length}}let signedArea22=0,cx3=0,cy3=0;for(let i3=0;i3<points.length;i3++){let p12=points[i3],p22=points[(i3+1)%points.length],crossProduct=p12.x*p22.y-p22.x*p12.y;signedArea22+=crossProduct,cx3+=(p12.x+p22.x)*crossProduct,cy3+=(p12.y+p22.y)*crossProduct}if(signedArea22*=.5,Math.abs(signedArea22)<1e-10){let sumX=points.reduce((sum,p4)=>sum+p4.x,0),sumY=points.reduce((sum,p4)=>sum+p4.y,0);return{x:sumX/points.length,y:sumY/points.length}}return cx3/=6*signedArea22,cy3/=6*signedArea22,{x:cx3,y:cy3}}var PackSolver2=class extends BaseSolver2{constructor(packInput){super();__publicField(this,"packInput");__publicField(this,"unpackedComponentQueue",[]);__publicField(this,"packedComponents",[]);__publicField(this,"componentToPack");this.packInput=packInput}getSolverName(){return"PackSolver2"}getConstructorParams(){return this.packInput}_setup(){let{components,packOrderStrategy,packFirst=[]}=this.packInput,validComponents=components.filter(component=>component.pads.length===0?!1:component.pads.every(pad2=>Number.isFinite(pad2.size.x)&&Number.isFinite(pad2.size.y)&&pad2.size.x>0&&pad2.size.y>0)),staticComponents=validComponents.filter(component=>component.isStatic),dynamicComponents=validComponents.filter(component=>!component.isStatic);this.packedComponents=staticComponents.map(component=>{let packedComponent={...component,center:component.center??{x:0,y:0},ccwRotationOffset:component.ccwRotationOffset??0,pads:component.pads.map(pad2=>({...pad2,absoluteCenter:pad2.absoluteCenter??{x:0,y:0}}))};return setPackedComponentPadCenters(packedComponent),packedComponent}),this.unpackedComponentQueue=sortComponentQueue({components:dynamicComponents,packOrderStrategy,packFirst})}packFirstComponent(){let firstComponentToPack=this.unpackedComponentQueue.shift(),initialPosition={x:0,y:0};this.packInput.boundaryOutline&&this.packInput.boundaryOutline.length>=3&&(initialPosition=getPolygonCentroid(this.packInput.boundaryOutline));let newPackedComponent={...firstComponentToPack,center:initialPosition,ccwRotationOffset:0,pads:firstComponentToPack.pads.map(p4=>({...p4,absoluteCenter:{x:0,y:0}}))};setPackedComponentPadCenters(newPackedComponent);let obstacles=this.packInput.obstacles??[],tooCloseToObstacles=obstacles.some(obs=>{let obsBox={center:{x:obs.absoluteCenter.x,y:obs.absoluteCenter.y},width:obs.width,height:obs.height};return newPackedComponent.pads.some(p4=>{let padBox={center:{x:p4.absoluteCenter.x,y:p4.absoluteCenter.y},width:p4.size.x,height:p4.size.y},{distance:distance8}=computeDistanceBetweenBoxes(padBox,obsBox);return distance8+1e-6<this.packInput.minGap})}),outsideBoundaryOutline=!1;if(this.packInput.boundaryOutline&&this.packInput.boundaryOutline.length>=3){let componentBounds=getComponentBounds(newPackedComponent,0),allPadsInside=newPackedComponent.pads.every(pad2=>isPointInPolygon2(pad2.absoluteCenter,this.packInput.boundaryOutline)),cornersInside=[{x:componentBounds.minX,y:componentBounds.minY},{x:componentBounds.minX,y:componentBounds.maxY},{x:componentBounds.maxX,y:componentBounds.minY},{x:componentBounds.maxX,y:componentBounds.maxY}].every(corner=>isPointInPolygon2(corner,this.packInput.boundaryOutline));outsideBoundaryOutline=!allPadsInside||!cornersInside}if(!tooCloseToObstacles&&!outsideBoundaryOutline){this.packedComponents.push(newPackedComponent);return}let fallbackSolver=new SingleComponentPackSolver({packedComponents:[],componentToPack:firstComponentToPack,packPlacementStrategy:this.packInput.packPlacementStrategy,minGap:this.packInput.minGap,obstacles,bounds:this.packInput.bounds,boundaryOutline:this.packInput.boundaryOutline,weightedConnections:this.packInput.weightedConnections});fallbackSolver.solve();let result=fallbackSolver.getResult();result?this.packedComponents.push(result):this.packedComponents.push(newPackedComponent)}_step(){if(!(this.solved||this.failed)){if(this.packedComponents.length===0){if(this.unpackedComponentQueue.length===0){this.solved=!0;return}this.packFirstComponent();return}if(!this.activeSubSolver){if(this.unpackedComponentQueue.length===0){this.solved=!0;return}if(this.componentToPack=this.unpackedComponentQueue.shift(),!this.componentToPack){this.solved=!0;return}this.activeSubSolver=new SingleComponentPackSolver({packedComponents:this.packedComponents,componentToPack:this.componentToPack,packPlacementStrategy:this.packInput.packPlacementStrategy,minGap:this.packInput.minGap,obstacles:this.packInput.obstacles??[],bounds:this.packInput.bounds,boundaryOutline:this.packInput.boundaryOutline,weightedConnections:this.packInput.weightedConnections}),this.activeSubSolver.setup()}if(this.activeSubSolver.step(),this.activeSubSolver.failed){this.failed=!0;return}if(this.activeSubSolver.solved){let result=this.activeSubSolver.getResult();if(result)this.packedComponents.push(result);else{let packedComponent={...this.componentToPack,center:{x:0,y:0},ccwRotationOffset:0,pads:this.componentToPack.pads.map(p4=>({...p4,absoluteCenter:{x:0,y:0}}))};setPackedComponentPadCenters(packedComponent),this.packedComponents.push(packedComponent)}this.componentToPack=void 0,this.activeSubSolver=void 0}}}visualize(){if(this.activeSubSolver)return this.activeSubSolver.visualize();let graphics={coordinateSystem:"cartesian",title:"Pack Solver 2",points:[],lines:[],rects:[],circles:[],texts:[],arrows:[]};if(this.packInput.obstacles&&this.packInput.obstacles.length>0)for(let obstacle of this.packInput.obstacles)graphics.rects.push({center:obstacle.absoluteCenter,width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});if(this.packInput.bounds&&graphics.lines.push({points:[{x:this.packInput.bounds.minX,y:this.packInput.bounds.minY},{x:this.packInput.bounds.minX,y:this.packInput.bounds.maxY},{x:this.packInput.bounds.maxX,y:this.packInput.bounds.maxY},{x:this.packInput.bounds.maxX,y:this.packInput.bounds.minY},{x:this.packInput.bounds.minX,y:this.packInput.bounds.minY}],strokeColor:"rgba(0,0,0,0.5)",strokeDash:"2 2"}),this.packInput.boundaryOutline&&this.packInput.boundaryOutline.length){let points=[...this.packInput.boundaryOutline];points.length>0&&(points[0].x!==points[points.length-1].x||points[0].y!==points[points.length-1].y)&&points.push({...points[0]}),graphics.lines.push({points,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}if(this.packedComponents.length===0)for(let component of this.unpackedComponentQueue)for(let pad2 of component.pads)graphics.rects.push({center:{x:0,y:0},width:pad2.size.x,height:pad2.size.y,fill:"rgba(0,0,0,0.1)"});let allPads=this.packedComponents.flatMap(c4=>c4.pads),networkToPadMap=new Map;for(let pad2 of allPads)pad2.networkId&&networkToPadMap.set(pad2.networkId,[...networkToPadMap.get(pad2.networkId)||[],pad2]);for(let pad2 of allPads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:"rgba(255,0,0,0.5)"});for(let[networkId,pads]of networkToPadMap.entries())for(let i3=0;i3<pads.length;i3++)for(let j4=i3+1;j4<pads.length;j4++){let pad1=pads[i3],pad2=pads[j4];graphics.lines.push({points:[pad1.absoluteCenter,pad2.absoluteCenter],strokeColor:getColorForString(networkId,.5)})}return graphics}getOutput(){return{packedComponents:this.packedComponents,unpackedComponents:this.unpackedComponentQueue}}},pack=input2=>{let solver=new PackSolver2(input2);return solver.solve(),{...input2,components:solver.packedComponents}},getPolygonBoundingBox=points=>{if(!points||points.length===0)return{minX:0,maxX:0,minY:0,maxY:0};let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let point7 of points)minX=Math.min(minX,point7.x),maxX=Math.max(maxX,point7.x),minY=Math.min(minY,point7.y),maxY=Math.max(maxY,point7.y);return{minX,maxX,minY,maxY}},extractPadInfos=(pcbComponent,db2,getNetworkId)=>{let out=[],pushPad=({padId,pcbPortId,sx:sx3,sy:sy3,x:x4,y:y4})=>out.push({padId,networkId:getNetworkId(pcbPortId),size:{x:sx3,y:sy3},absoluteCenter:{x:x4,y:y4},pcbPortId});for(let via of db2.pcb_via.list({pcb_component_id:pcbComponent.pcb_component_id}))pushPad({padId:via.pcb_via_id,pcbPortId:via.pcb_port_id,sx:via.outer_diameter??via.hole_diameter??0,sy:via.outer_diameter??via.hole_diameter??0,x:via.x,y:via.y});for(let ph3 of db2.pcb_plated_hole.list({pcb_component_id:pcbComponent.pcb_component_id}))switch(ph3.shape){case"circle":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.outer_diameter??ph3.hole_diameter??0,sy:ph3.outer_diameter??ph3.hole_diameter??0,x:ph3.x,y:ph3.y});break}case"oval":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.outer_width,sy:ph3.outer_height,x:ph3.x,y:ph3.y});break}case"circular_hole_with_rect_pad":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.rect_pad_width,sy:ph3.rect_pad_height,x:ph3.x,y:ph3.y});break}case"pill":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.outer_width,sy:ph3.outer_height,x:ph3.x,y:ph3.y});break}case"pill_hole_with_rect_pad":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.rect_pad_width,sy:ph3.rect_pad_height,x:ph3.x,y:ph3.y});break}default:{console.warn(`Unsupported plated hole shape ${ph3.shape}`);break}}for(let sp3 of db2.pcb_smtpad.list({pcb_component_id:pcbComponent.pcb_component_id}))switch(sp3.shape){case"rect":{pushPad({padId:sp3.pcb_smtpad_id,pcbPortId:sp3.pcb_port_id,sx:sp3.width??0,sy:sp3.height??0,x:sp3.x,y:sp3.y});break}case"circle":{pushPad({padId:sp3.pcb_smtpad_id,pcbPortId:sp3.pcb_port_id,sx:sp3.radius*2,sy:sp3.radius*2,x:sp3.x,y:sp3.y});break}case"polygon":{if(sp3.points&&sp3.points.length>0){let{minX,maxX,minY,maxY}=getPolygonBoundingBox(sp3.points),width=maxX-minX,height=maxY-minY,centerX=(minX+maxX)/2,centerY=(minY+maxY)/2;pushPad({padId:sp3.pcb_smtpad_id,pcbPortId:sp3.pcb_port_id,sx:width,sy:height,x:centerX,y:centerY})}else console.warn(`Polygon pad ${sp3.pcb_smtpad_id} has no points`);break}}return out},getElementOutsideTree=(db2,tree)=>{let componentIdsInTree=new Set,collectComponentIds=node=>{if(node){if(node.nodeType==="component"){let pcbId=node.otherChildElements?.[0]?.pcb_component_id;pcbId&&componentIdsInTree.add(pcbId)}for(let child of node.childNodes??[])collectComponentIds(child)}};collectComponentIds(tree);let outside=[];for(let ph3 of db2.pcb_plated_hole.list({})){if(!("pcb_component_id"in ph3)||!ph3.pcb_component_id){outside.push(ph3);continue}componentIdsInTree.has(ph3.pcb_component_id)||outside.push(ph3)}for(let hole of db2.pcb_hole.list({}))outside.push(hole);return outside},getObstacleFromElement=element=>{if(element.type==="pcb_plated_hole"&&element.shape==="circular_hole_with_rect_pad"){let{rect_pad_height,rect_pad_width,x:x4,y:y4}=element;return{obstacleId:element.pcb_plated_hole_id,absoluteCenter:{x:x4,y:y4},width:rect_pad_width,height:rect_pad_height}}if(element.type==="pcb_hole"){let{x:x4,y:y4,pcb_hole_id}=element,width="hole_diameter"in element?element.hole_diameter:element.hole_width,height="hole_diameter"in element?element.hole_diameter:element.hole_height;return{obstacleId:pcb_hole_id,absoluteCenter:{x:x4,y:y4},width,height}}},buildPackedComponent=(pcbComponents,componentId,db2,getNetworkId,shouldAddInnerObstacles,sourcePortToPadIds=new Map,chipMarginsMap={},isStatic=!1)=>{let padInfos=pcbComponents.flatMap(pc3=>{let pads2=extractPadInfos(pc3,db2,getNetworkId),margins=chipMarginsMap[pc3.pcb_component_id];return margins?pads2.map(p4=>({...p4,size:{x:p4.size.x+margins.left+margins.right,y:p4.size.y+margins.top+margins.bottom},absoluteCenter:{x:p4.absoluteCenter.x+(margins.right-margins.left)/2,y:p4.absoluteCenter.y+(margins.top-margins.bottom)/2}})):pads2}),minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let p4 of padInfos)minX=Math.min(minX,p4.absoluteCenter.x-p4.size.x/2),maxX=Math.max(maxX,p4.absoluteCenter.x+p4.size.x/2),minY=Math.min(minY,p4.absoluteCenter.y-p4.size.y/2),maxY=Math.max(maxY,p4.absoluteCenter.y+p4.size.y/2);let center2={x:(minX+maxX)/2,y:(minY+maxY)/2},pads=padInfos.map(p4=>({padId:p4.padId,networkId:p4.networkId,type:"rect",size:p4.size,absoluteCenter:p4.absoluteCenter,offset:{x:p4.absoluteCenter.x-center2.x,y:p4.absoluteCenter.y-center2.y}}));for(let padInfo of padInfos){if(!padInfo.pcbPortId)continue;let sourcePortId=db2.pcb_port.get(padInfo.pcbPortId)?.source_port_id;if(!sourcePortId)continue;let existingPadIds=sourcePortToPadIds.get(sourcePortId)??[];existingPadIds.push(padInfo.padId),sourcePortToPadIds.set(sourcePortId,existingPadIds)}if(shouldAddInnerObstacles){let innerPad={padId:`${componentId}-inner`,networkId:`${componentId}-inner`,type:"rect",size:{x:maxX-minX,y:maxY-minY},absoluteCenter:center2,offset:{x:0,y:0}};pads.push(innerPad)}return{componentId,isStatic,center:center2,ccwRotationOffset:0,pads}},collectPcbComponents=(node,db2)=>{if(node.nodeType==="component"){let pcbId=node.otherChildElements[0]?.pcb_component_id;return pcbId?[db2.pcb_component.get(pcbId)]:[]}return node.childNodes.flatMap(n4=>collectPcbComponents(n4,db2))},convertCircuitJsonToPackOutput=(circuitJson,opts={})=>{let packOutput={components:[],minGap:0,packOrderStrategy:"largest_to_smallest",packPlacementStrategy:"shortest_connection_along_outline",obstacles:opts.obstacles??[]},tree=getCircuitJsonTree(circuitJson,{source_group_id:opts.source_group_id}),db2=cju_default(circuitJson),unnamedCounter=0,sourcePortToPadIds=new Map,elementsOutsideTree=getElementOutsideTree(db2,tree),pcbBoard=circuitJson.find(item=>item.type==="pcb_board");pcbBoard?.outline&&(packOutput.boundaryOutline=pcbBoard.outline);let getNetworkId=pcbPortId=>{if(pcbPortId){let pcbPort=db2.pcb_port.get(pcbPortId);if(pcbPort){let sourcePort=db2.source_port.get(pcbPort.source_port_id);if(sourcePort?.subcircuit_connectivity_map_key)return sourcePort.subcircuit_connectivity_map_key}}return`unnamed${unnamedCounter++}`},topLevelNodes=tree.childNodes??[],collectRelativeToGroupAnchorComponents=node=>{let relativeComponents2=[];if(node.nodeType==="component"){let pcbComponent=node.otherChildElements.find(e5=>e5.type==="pcb_component");pcbComponent&&pcbComponent.position_mode==="relative_to_group_anchor"&&relativeComponents2.push(pcbComponent)}for(let child of node.childNodes??[])relativeComponents2.push(...collectRelativeToGroupAnchorComponents(child));return relativeComponents2},staticComponentIds=new Set(opts.staticPcbComponentIds??[]);for(let node of topLevelNodes)if(node.nodeType==="component"){let pcbComponent=node.otherChildElements.find(e5=>e5.type==="pcb_component");if(!pcbComponent||pcbComponent.position_mode==="relative_to_group_anchor")continue;let shouldAddInnerObstaclesForComp=opts.shouldAddInnerObstacles??!1;pcbComponent.obstructs_within_bounds===!0?shouldAddInnerObstaclesForComp=!0:pcbComponent.obstructs_within_bounds===!1&&(shouldAddInnerObstaclesForComp=!1),packOutput.components.push(buildPackedComponent([pcbComponent],pcbComponent.pcb_component_id,db2,getNetworkId,shouldAddInnerObstaclesForComp,sourcePortToPadIds,opts.chipMarginsMap,staticComponentIds.has(pcbComponent.pcb_component_id)))}else if(node.nodeType==="group"){let pcbComps=collectPcbComponents(node,db2);if(!pcbComps.length)continue;let compId=node.sourceGroup?.source_group_id??node.sourceGroup?.name??`group_${packOutput.components.length}`;packOutput.components.push(buildPackedComponent(pcbComps,compId,db2,getNetworkId,void 0,sourcePortToPadIds,opts.chipMarginsMap,staticComponentIds.has(compId)))}let relativeComponents=topLevelNodes.flatMap(node=>collectRelativeToGroupAnchorComponents(node));for(let pcbComponent of relativeComponents){let padInfos=extractPadInfos(pcbComponent,db2,getNetworkId);if(padInfos.length===0)continue;let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let pad2 of padInfos)minX=Math.min(minX,pad2.absoluteCenter.x-pad2.size.x/2),maxX=Math.max(maxX,pad2.absoluteCenter.x+pad2.size.x/2),minY=Math.min(minY,pad2.absoluteCenter.y-pad2.size.y/2),maxY=Math.max(maxY,pad2.absoluteCenter.y+pad2.size.y/2);let center2={x:(minX+maxX)/2,y:(minY+maxY)/2},width=maxX-minX,height=maxY-minY;packOutput.obstacles.push({obstacleId:pcbComponent.pcb_component_id,absoluteCenter:center2,width,height})}for(let element of elementsOutsideTree){let obstacle=getObstacleFromElement(element);obstacle&&packOutput.obstacles.push(obstacle)}let weightedConnections=[],seenConnections=new Set,sourceTraces=typeof db2.source_trace.list=="function"?db2.source_trace.list():circuitJson.filter(item=>item.type==="source_trace");for(let sourceTrace of sourceTraces){let connectedPorts=sourceTrace.connected_source_port_ids||[],connectedNets=sourceTrace.connected_source_net_ids||[];if(!(connectedPorts.length===2&&connectedNets.length===0))continue;let[portA,portB]=connectedPorts,padIdsA=portA?sourcePortToPadIds.get(portA)??[]:[],padIdsB=portB?sourcePortToPadIds.get(portB)??[]:[];for(let padA of padIdsA)for(let padB of padIdsB){let connectionKey=[padA,padB].sort().join("--");seenConnections.has(connectionKey)||(weightedConnections.push({padIds:[padA,padB],weight:1,ignoreWeakConnections:!0}),seenConnections.add(connectionKey))}}return weightedConnections.length>0&&(packOutput.weightedConnections=weightedConnections),packOutput},convertPackOutputToPackInput=packed=>{let strippedComponents=packed.components.map(pc3=>({...pc3.isStatic?{...pc3,pads:pc3.pads.map(pad2=>({...pad2}))}:{componentId:pc3.componentId,availableRotationDegrees:pc3.availableRotationDegrees,pads:pc3.pads.map(({absoluteCenter:_ac,...rest})=>rest)}}));return{...packed,components:strippedComponents}};async function Module(moduleArg={}){var moduleRtn,Module2=moduleArg,ENVIRONMENT_IS_WEB=!!globalThis.window,ENVIRONMENT_IS_WORKER=!!globalThis.WorkerGlobalScope,ENVIRONMENT_IS_NODE=globalThis.process?.versions?.node&&globalThis.process?.type!="renderer";if(ENVIRONMENT_IS_NODE){let{createRequire}=await import("module");var require2=createRequire(import.meta.url)}var _ManifoldInitialized=!1;Module2.setup=function(){if(_ManifoldInitialized)return;_ManifoldInitialized=!0,Module2.initTBB();function toVec(vec,list,f3=(x4=>x4)){if(list)for(let x4 of list)vec.push_back(f3(x4));return vec}function fromVec(vec,f3=(x4=>x4)){let result=[],size3=vec.size();for(let i3=0;i3<size3;i3++)result.push(f3(vec.get(i3)));return result}function vec2polygons(vec,f3=(x4=>x4)){let result=[],nPoly=vec.size();for(let i3=0;i3<nPoly;i3++){let v4=vec.get(i3),nPts=v4.size(),poly=[];for(let j4=0;j4<nPts;j4++)poly.push(f3(v4.get(j4)));result.push(poly)}return result}function polygons2vec(polygons){return polygons[0].length<3&&(polygons=[polygons]),toVec(new Module2.Vector2_vec2,polygons,poly=>toVec(new Module2.Vector_vec2,poly,p4=>p4 instanceof Array?{x:p4[0],y:p4[1]}:p4))}function disposePolygons(polygonsVec){for(let i3=0;i3<polygonsVec.size();i3++)polygonsVec.get(i3).delete();polygonsVec.delete()}function vararg2vec2(vec){return vec[0]instanceof Array?{x:vec[0][0],y:vec[0][1]}:typeof vec[0]=="number"?{x:vec[0]||0,y:vec[1]||0}:vec[0]}function vararg2vec3(vec){return vec[0]instanceof Array?{x:vec[0][0],y:vec[0][1],z:vec[0][2]}:typeof vec[0]=="number"?{x:vec[0]||0,y:vec[1]||0,z:vec[2]||0}:vec[0]}function fillRuleToInt(fillRule){return fillRule=="EvenOdd"?0:fillRule=="NonZero"?1:fillRule=="Negative"?3:2}function joinTypeToInt(joinType){return joinType=="Round"?1:joinType=="Miter"?2:0}let CrossSectionCtor=Module2.CrossSection;function cross4(polygons,fillRule="Positive"){if(polygons instanceof CrossSectionCtor)return polygons;{let polygonsVec=polygons2vec(polygons),cs3=new CrossSectionCtor(polygonsVec,fillRuleToInt(fillRule));return disposePolygons(polygonsVec),cs3}}Module2.CrossSection.prototype.translate=function(...vec){return this._Translate(vararg2vec2(vec))},Module2.CrossSection.prototype.scale=function(vec){return typeof vec=="number"?this._Scale({x:vec,y:vec}):this._Scale(vararg2vec2([vec]))},Module2.CrossSection.prototype.mirror=function(vec){return this._Mirror(vararg2vec2([vec]))},Module2.CrossSection.prototype.warp=function(func){let wasmFuncPtr=addFunction(function(vec2Ptr){let x4=getValue(vec2Ptr,"double"),y4=getValue(vec2Ptr+8,"double"),vert=[x4,y4];func(vert),setValue(vec2Ptr,vert[0],"double"),setValue(vec2Ptr+8,vert[1],"double")},"vi"),out2=this._Warp(wasmFuncPtr);return removeFunction(wasmFuncPtr),out2},Module2.CrossSection.prototype.decompose=function(){let vec=this._Decompose(),result=fromVec(vec);return vec.delete(),result},Module2.CrossSection.prototype.bounds=function(){let result=this._Bounds();return{min:["x","y"].map(f3=>result.min[f3]),max:["x","y"].map(f3=>result.max[f3])}},Module2.CrossSection.prototype.offset=function(delta,joinType="Round",miterLimit=2,circularSegments=0){return this._Offset(delta,joinTypeToInt(joinType),miterLimit,circularSegments)},Module2.CrossSection.prototype.simplify=function(epsilon=1e-6){return this._Simplify(epsilon)},Module2.CrossSection.prototype.extrude=function(height,nDivisions=0,twistDegrees=0,scaleTop=[1,1],center2=!1){scaleTop=vararg2vec2([scaleTop]);let man=Module2._Extrude(this._ToPolygons(),height,nDivisions,twistDegrees,scaleTop);return center2?man.translate([0,0,-height/2]):man},Module2.CrossSection.prototype.revolve=function(circularSegments=0,revolveDegrees=360){return Module2._Revolve(this._ToPolygons(),circularSegments,revolveDegrees)},Module2.CrossSection.prototype.add=function(other){return this._add(cross4(other))},Module2.CrossSection.prototype.subtract=function(other){return this._subtract(cross4(other))},Module2.CrossSection.prototype.intersect=function(other){return this._intersect(cross4(other))},Module2.CrossSection.prototype.toPolygons=function(){let vec=this._ToPolygons(),result=vec2polygons(vec,v4=>[v4.x,v4.y]);return vec.delete(),result},Module2.Manifold.prototype.smoothOut=function(minSharpAngle=60,minSmoothness=0){return this._SmoothOut(minSharpAngle,minSmoothness)},Module2.Manifold.prototype.warp=function(func){let wasmFuncPtr=addFunction(function(vec3Ptr){let x4=getValue(vec3Ptr,"double"),y4=getValue(vec3Ptr+8,"double"),z4=getValue(vec3Ptr+16,"double"),vert=[x4,y4,z4];func(vert),setValue(vec3Ptr,vert[0],"double"),setValue(vec3Ptr+8,vert[1],"double"),setValue(vec3Ptr+16,vert[2],"double")},"vi"),out2=this._Warp(wasmFuncPtr);removeFunction(wasmFuncPtr);let status=out2.status();if(status!=="NoError")throw new Module2.ManifoldError(status);return out2},Module2.Manifold.prototype.calculateNormals=function(normalIdx,minSharpAngle=60){return this._CalculateNormals(normalIdx,minSharpAngle)},Module2.Manifold.prototype.setProperties=function(numProp,func){let oldNumProp=this.numProp(),wasmFuncPtr=addFunction(function(newPtr,vec3Ptr,oldPtr){let newProp=[];for(let i3=0;i3<numProp;++i3)newProp[i3]=getValue(newPtr+8*i3,"double");let pos=[];for(let i3=0;i3<3;++i3)pos[i3]=getValue(vec3Ptr+8*i3,"double");let oldProp=[];for(let i3=0;i3<oldNumProp;++i3)oldProp[i3]=getValue(oldPtr+8*i3,"double");func(newProp,pos,oldProp);for(let i3=0;i3<numProp;++i3)setValue(newPtr+8*i3,newProp[i3],"double")},"viii"),out2=this._SetProperties(numProp,wasmFuncPtr);return removeFunction(wasmFuncPtr),out2},Module2.Manifold.prototype.translate=function(...vec){return this._Translate(vararg2vec3(vec))},Module2.Manifold.prototype.rotate=function(xOrVec,y4,z4){return Array.isArray(xOrVec)?this._Rotate(...xOrVec):this._Rotate(xOrVec,y4||0,z4||0)},Module2.Manifold.prototype.scale=function(vec){return typeof vec=="number"?this._Scale({x:vec,y:vec,z:vec}):this._Scale(vararg2vec3([vec]))},Module2.Manifold.prototype.mirror=function(vec){return this._Mirror(vararg2vec3([vec]))},Module2.Manifold.prototype.trimByPlane=function(normal,offset=0){return this._TrimByPlane(vararg2vec3([normal]),offset)},Module2.Manifold.prototype.slice=function(height=0){let polygonsVec=this._Slice(height),result=new CrossSectionCtor(polygonsVec,fillRuleToInt("Positive"));return disposePolygons(polygonsVec),result},Module2.Manifold.prototype.project=function(){let polygonsVec=this._Project(),result=new CrossSectionCtor(polygonsVec,fillRuleToInt("Positive"));return disposePolygons(polygonsVec),result},Module2.Manifold.prototype.split=function(manifold){let vec=this._Split(manifold),result=fromVec(vec);return vec.delete(),result},Module2.Manifold.prototype.splitByPlane=function(normal,offset=0){let vec=this._SplitByPlane(vararg2vec3([normal]),offset),result=fromVec(vec);return vec.delete(),result},Module2.Manifold.prototype.decompose=function(){let vec=this._Decompose(),result=fromVec(vec);return vec.delete(),result},Module2.Manifold.prototype.boundingBox=function(){let result=this._boundingBox();return{min:["x","y","z"].map(f3=>result.min[f3]),max:["x","y","z"].map(f3=>result.max[f3])}},Module2.Manifold.prototype.simplify=function(tolerance=0){return this._Simplify(tolerance)};class Mesh{constructor({numProp=3,triVerts=new Uint32Array,vertProperties=new Float32Array,mergeFromVert,mergeToVert,runIndex,runOriginalID,faceID,halfedgeTangent,runTransform,tolerance=0}={}){this.numProp=numProp,this.triVerts=triVerts,this.vertProperties=vertProperties,this.mergeFromVert=mergeFromVert,this.mergeToVert=mergeToVert,this.runIndex=runIndex,this.runOriginalID=runOriginalID,this.faceID=faceID,this.halfedgeTangent=halfedgeTangent,this.runTransform=runTransform,this.tolerance=tolerance}get numTri(){return this.triVerts.length/3}get numVert(){return this.vertProperties.length/this.numProp}get numRun(){return this.runOriginalID.length}merge(){let{changed,mesh}=Module2._Merge(this);return Object.assign(this,{...mesh}),changed}verts(tri){return this.triVerts.subarray(3*tri,3*(tri+1))}position(vert){return this.vertProperties.subarray(this.numProp*vert,this.numProp*vert+3)}extras(vert){return this.vertProperties.subarray(this.numProp*vert+3,this.numProp*(vert+1))}tangent(halfedge){return this.halfedgeTangent.subarray(4*halfedge,4*(halfedge+1))}transform(run2){let mat4=new Array(16);for(let col of[0,1,2,3])for(let row of[0,1,2])mat4[4*col+row]=this.runTransform[12*run2+3*col+row];return mat4[15]=1,mat4}}Module2.Mesh=Mesh,Module2.Manifold.prototype.getMesh=function(normalIdx=-1){return new Mesh(this._GetMeshJS(normalIdx))},Module2.ManifoldError=function(code,...args){let message="Unknown error";switch(code){case"NonFiniteVertex":message="Non-finite vertex";break;case"NotManifold":message="Not manifold";break;case"VertexOutOfBounds":message="Vertex index out of bounds";break;case"PropertiesWrongLength":message="Properties have wrong length";break;case"MissingPositionProperties":message="Less than three properties";break;case"MergeVectorsDifferentLengths":message="Merge vectors have different lengths";break;case"MergeIndexOutOfBounds":message="Merge index out of bounds";break;case"TransformWrongLength":message="Transform vector has wrong length";break;case"RunIndexWrongLength":message="Run index vector has wrong length";break;case"FaceIDWrongLength":message="Face ID vector has wrong length";case"InvalidConstruction":message="Manifold constructed with invalid parameters"}let base=Error.apply(this,[message,...args]);base.name=this.name="ManifoldError",this.message=base.message,this.stack=base.stack,this.code=code},Module2.ManifoldError.prototype=Object.create(Error.prototype,{constructor:{value:Module2.ManifoldError,writable:!0,configurable:!0}}),Module2.CrossSection=function(polygons,fillRule="Positive"){let polygonsVec=polygons2vec(polygons),cs3=new CrossSectionCtor(polygonsVec,fillRuleToInt(fillRule));return disposePolygons(polygonsVec),cs3},Module2.CrossSection.ofPolygons=function(polygons,fillRule="Positive"){return new Module2.CrossSection(polygons,fillRule)},Module2.CrossSection.square=function(...args){let size3;args.length==0?size3={x:1,y:1}:typeof args[0]=="number"?size3={x:args[0],y:args[0]}:size3=vararg2vec2(args);let center2=args[1]||!1;return Module2._Square(size3,center2)},Module2.CrossSection.circle=function(radius,circularSegments=0){return Module2._Circle(radius,circularSegments)};function crossSectionBatchbool(name){return function(...args){args.length==1&&(args=args[0]);let v4=new Module2.Vector_crossSection;for(let cs3 of args)v4.push_back(cross4(cs3));let result=Module2["_crossSection"+name](v4);return v4.delete(),result}}Module2.CrossSection.compose=crossSectionBatchbool("Compose"),Module2.CrossSection.union=crossSectionBatchbool("UnionN"),Module2.CrossSection.difference=crossSectionBatchbool("DifferenceN"),Module2.CrossSection.intersection=crossSectionBatchbool("IntersectionN");function pushVec2(vec,ps3){toVec(vec,ps3,p4=>p4 instanceof Array?{x:p4[0],y:p4[1]}:p4)}Module2.CrossSection.hull=function(...args){args.length==1&&(args=args[0]);let pts=new Module2.Vector_vec2;for(let cs3 of args)if(cs3 instanceof CrossSectionCtor)Module2._crossSectionCollectVertices(pts,cs3);else if(cs3 instanceof Array&&cs3.length==2&&typeof cs3[0]=="number")pts.push_back({x:cs3[0],y:cs3[1]});else if(cs3.x)pts.push_back(cs3);else{let polys=cs3[0].length==2&&typeof cs3[0][0]=="number"||cs3[0].x?[cs3]:cs3;for(let poly of polys)pushVec2(pts,poly)}let result=Module2._crossSectionHullPoints(pts);return pts.delete(),result},Module2.CrossSection.prototype=Object.create(CrossSectionCtor.prototype),Object.defineProperty(Module2.CrossSection,Symbol.hasInstance,{get:()=>t52=>t52 instanceof CrossSectionCtor});let ManifoldCtor=Module2.Manifold;Module2.Manifold=function(mesh){let manifold=new ManifoldCtor(mesh),status=manifold.status();if(status!=="NoError")throw new Module2.ManifoldError(status);return manifold},Module2.Manifold.ofMesh=function(mesh){return new Module2.Manifold(mesh)},Module2.Manifold.tetrahedron=function(){return Module2._Tetrahedron()},Module2.Manifold.cube=function(...args){let size3;args.length==0?size3={x:1,y:1,z:1}:typeof args[0]=="number"?size3={x:args[0],y:args[0],z:args[0]}:size3=vararg2vec3(args);let center2=args[1]||!1;return Module2._Cube(size3,center2)},Module2.Manifold.cylinder=function(height,radiusLow,radiusHigh=-1,circularSegments=0,center2=!1){return Module2._Cylinder(height,radiusLow,radiusHigh,circularSegments,center2)},Module2.Manifold.sphere=function(radius,circularSegments=0){return Module2._Sphere(radius,circularSegments)},Module2.Manifold.smooth=function(mesh,sharpenedEdges=[]){let sharp=new Module2.Vector_smoothness;toVec(sharp,sharpenedEdges);let result=Module2._Smooth(mesh,sharp);return sharp.delete(),result},Module2.Manifold.extrude=function(polygons,height,nDivisions=0,twistDegrees=0,scaleTop=[1,1],center2=!1){return(polygons instanceof CrossSectionCtor?polygons:Module2.CrossSection(polygons,"Positive")).extrude(height,nDivisions,twistDegrees,scaleTop,center2)},Module2.Manifold.revolve=function(polygons,circularSegments=0,revolveDegrees=360){return(polygons instanceof CrossSectionCtor?polygons:Module2.CrossSection(polygons,"Positive")).revolve(circularSegments,revolveDegrees)},Module2.Manifold.reserveIDs=function(n4){return Module2._ReserveIDs(n4)};function manifoldBatchbool(name){return function(...args){args.length==1&&(args=args[0]);let v4=new Module2.Vector_manifold;for(let m4 of args)v4.push_back(m4);let result=Module2["_manifold"+name+"N"](v4);return v4.delete(),result}}Module2.Manifold.union=manifoldBatchbool("Union"),Module2.Manifold.compose=Module2.Manifold.union,Module2.Manifold.difference=manifoldBatchbool("Difference"),Module2.Manifold.intersection=manifoldBatchbool("Intersection"),Module2.Manifold.levelSet=function(sdf,bounds,edgeLength,level=0,tolerance=-1){let bounds2={min:{x:bounds.min[0],y:bounds.min[1],z:bounds.min[2]},max:{x:bounds.max[0],y:bounds.max[1],z:bounds.max[2]}},wasmFuncPtr=addFunction(function(vec3Ptr){let x4=getValue(vec3Ptr,"double"),y4=getValue(vec3Ptr+8,"double"),z4=getValue(vec3Ptr+16,"double");return sdf([x4,y4,z4])},"di"),out2=Module2._LevelSet(wasmFuncPtr,bounds2,edgeLength,level,tolerance);return removeFunction(wasmFuncPtr),out2};function pushVec3(vec,ps3){toVec(vec,ps3,p4=>p4 instanceof Array?{x:p4[0],y:p4[1],z:p4[2]}:p4)}Module2.Manifold.hull=function(...args){args.length==1&&(args=args[0]);let pts=new Module2.Vector_vec3;for(let m4 of args)m4 instanceof ManifoldCtor?Module2._manifoldCollectVertices(pts,m4):m4 instanceof Array&&m4.length==3&&typeof m4[0]=="number"?pts.push_back({x:m4[0],y:m4[1],z:m4[2]}):m4.x?pts.push_back(m4):pushVec3(pts,m4);let result=Module2._manifoldHullPoints(pts);return pts.delete(),result},Module2.Manifold.prototype=Object.create(ManifoldCtor.prototype),Object.defineProperty(Module2.Manifold,Symbol.hasInstance,{get:()=>t52=>t52 instanceof ManifoldCtor}),Module2.triangulate=function(polygons,epsilon=-1,allowConvex=!0){let polygonsVec=polygons2vec(polygons),result=fromVec(Module2._Triangulate(polygonsVec,epsilon,allowConvex),x4=>[x4[0],x4[1],x4[2]]);return disposePolygons(polygonsVec),result}};var arguments_=[],thisProgram="./this.program",quit_=(status,toThrow)=>{throw toThrow},_scriptName=import.meta.url,scriptDirectory="";function locateFile(path){return Module2.locateFile?Module2.locateFile(path,scriptDirectory):scriptDirectory+path}var readAsync,readBinary;if(ENVIRONMENT_IS_NODE){var fs3=require2("node:fs");_scriptName.startsWith("file:")&&(scriptDirectory=require2("node:path").dirname(require2("node:url").fileURLToPath(_scriptName))+"/"),readBinary=filename=>{filename=isFileURI(filename)?new URL(filename):filename;var ret=fs3.readFileSync(filename);return ret},readAsync=async(filename,binary=!0)=>{filename=isFileURI(filename)?new URL(filename):filename;var ret=fs3.readFileSync(filename,binary?void 0:"utf8");return ret},process.argv.length>1&&(thisProgram=process.argv[1].replace(/\\/g,"/")),arguments_=process.argv.slice(2),quit_=(status,toThrow)=>{throw process.exitCode=status,toThrow}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){try{scriptDirectory=new URL(".",_scriptName).href}catch{}ENVIRONMENT_IS_WORKER&&(readBinary=url2=>{var xhr=new XMLHttpRequest;return xhr.open("GET",url2,!1),xhr.responseType="arraybuffer",xhr.send(null),new Uint8Array(xhr.response)}),readAsync=async url2=>{if(isFileURI(url2))return new Promise((resolve,reject)=>{var xhr=new XMLHttpRequest;xhr.open("GET",url2,!0),xhr.responseType="arraybuffer",xhr.onload=()=>{if(xhr.status==200||xhr.status==0&&xhr.response){resolve(xhr.response);return}reject(xhr.status)},xhr.onerror=reject,xhr.send(null)});var response=await fetch(url2,{credentials:"same-origin"});if(response.ok)return response.arrayBuffer();throw new Error(response.status+" : "+response.url)}}var out=console.log.bind(console),err=console.error.bind(console),wasmBinary,ABORT=!1,isFileURI=filename=>filename.startsWith("file://"),readyPromiseResolve,readyPromiseReject,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64,HEAP64,HEAPU64,runtimeInitialized=!1;function updateMemoryViews(){var b3=wasmMemory.buffer;HEAP8=new Int8Array(b3),HEAP16=new Int16Array(b3),HEAPU8=new Uint8Array(b3),HEAPU16=new Uint16Array(b3),HEAP32=new Int32Array(b3),HEAPU32=new Uint32Array(b3),HEAPF32=new Float32Array(b3),HEAPF64=new Float64Array(b3),HEAP64=new BigInt64Array(b3),HEAPU64=new BigUint64Array(b3)}function preRun(){if(Module2.preRun)for(typeof Module2.preRun=="function"&&(Module2.preRun=[Module2.preRun]);Module2.preRun.length;)addOnPreRun(Module2.preRun.shift());callRuntimeCallbacks(onPreRuns)}function initRuntime(){runtimeInitialized=!0,wasmExports.J()}function postRun(){if(Module2.postRun)for(typeof Module2.postRun=="function"&&(Module2.postRun=[Module2.postRun]);Module2.postRun.length;)addOnPostRun(Module2.postRun.shift());callRuntimeCallbacks(onPostRuns)}function abort(what){Module2.onAbort?.(what),what="Aborted("+what+")",err(what),ABORT=!0,what+=". Build with -sASSERTIONS for more info.";var e5=new WebAssembly.RuntimeError(what);throw readyPromiseReject?.(e5),e5}var wasmBinaryFile;function findWasmBinary(){return Module2.locateFile?locateFile("manifold.wasm"):new URL("manifold.wasm",import.meta.url).href}function getBinarySync(file){if(file==wasmBinaryFile&&wasmBinary)return new Uint8Array(wasmBinary);if(readBinary)return readBinary(file);throw"both async and sync fetching of the wasm failed"}async function getWasmBinary(binaryFile){if(!wasmBinary)try{var response=await readAsync(binaryFile);return new Uint8Array(response)}catch{}return getBinarySync(binaryFile)}async function instantiateArrayBuffer(binaryFile,imports){try{var binary=await getWasmBinary(binaryFile),instance=await WebAssembly.instantiate(binary,imports);return instance}catch(reason){err(`failed to asynchronously prepare wasm: ${reason}`),abort(reason)}}async function instantiateAsync(binary,binaryFile,imports){if(!binary&&!isFileURI(binaryFile)&&!ENVIRONMENT_IS_NODE)try{var response=fetch(binaryFile,{credentials:"same-origin"}),instantiationResult=await WebAssembly.instantiateStreaming(response,imports);return instantiationResult}catch(reason){err(`wasm streaming compile failed: ${reason}`),err("falling back to ArrayBuffer instantiation")}return instantiateArrayBuffer(binaryFile,imports)}function getWasmImports(){var imports={a:wasmImports};return imports}async function createWasm(){function receiveInstance(instance,module){return wasmExports=instance.exports,wasmExports=applySignatureConversions(wasmExports),assignWasmExports(wasmExports),updateMemoryViews(),wasmExports}function receiveInstantiationResult(result2){return receiveInstance(result2.instance)}var info=getWasmImports();if(Module2.instantiateWasm)return new Promise((resolve,reject)=>{Module2.instantiateWasm(info,(inst,mod)=>{resolve(receiveInstance(inst,mod))})});wasmBinaryFile??(wasmBinaryFile=findWasmBinary());var result=await instantiateAsync(wasmBinary,wasmBinaryFile,info),exports=receiveInstantiationResult(result);return exports}class ExitStatus{constructor(status){__publicField(this,"name","ExitStatus");this.message=`Program terminated with exit(${status})`,this.status=status}}var callRuntimeCallbacks=callbacks=>{for(;callbacks.length>0;)callbacks.shift()(Module2)},onPostRuns=[],addOnPostRun=cb3=>onPostRuns.push(cb3),onPreRuns=[],addOnPreRun=cb3=>onPreRuns.push(cb3);function getValue(ptr,type="i8"){switch(type.endsWith("*")&&(type="*"),type){case"i1":return HEAP8[ptr>>>0];case"i8":return HEAP8[ptr>>>0];case"i16":return HEAP16[ptr>>>1>>>0];case"i32":return HEAP32[ptr>>>2>>>0];case"i64":return HEAP64[ptr>>>3>>>0];case"float":return HEAPF32[ptr>>>2>>>0];case"double":return HEAPF64[ptr>>>3>>>0];case"*":return HEAPU32[ptr>>>2>>>0];default:abort(`invalid type for getValue: ${type}`)}}var noExitRuntime=!0;function setValue(ptr,value,type="i8"){switch(type.endsWith("*")&&(type="*"),type){case"i1":HEAP8[ptr>>>0]=value;break;case"i8":HEAP8[ptr>>>0]=value;break;case"i16":HEAP16[ptr>>>1>>>0]=value;break;case"i32":HEAP32[ptr>>>2>>>0]=value;break;case"i64":HEAP64[ptr>>>3>>>0]=BigInt(value);break;case"float":HEAPF32[ptr>>>2>>>0]=value;break;case"double":HEAPF64[ptr>>>3>>>0]=value;break;case"*":HEAPU32[ptr>>>2>>>0]=value;break;default:abort(`invalid type for setValue: ${type}`)}}class ExceptionInfo{constructor(excPtr){this.excPtr=excPtr,this.ptr=excPtr-24}set_type(type){HEAPU32[this.ptr+4>>>2>>>0]=type}get_type(){return HEAPU32[this.ptr+4>>>2>>>0]}set_destructor(destructor){HEAPU32[this.ptr+8>>>2>>>0]=destructor}get_destructor(){return HEAPU32[this.ptr+8>>>2>>>0]}set_caught(caught){caught=caught?1:0,HEAP8[this.ptr+12>>>0]=caught}get_caught(){return HEAP8[this.ptr+12>>>0]!=0}set_rethrown(rethrown){rethrown=rethrown?1:0,HEAP8[this.ptr+13>>>0]=rethrown}get_rethrown(){return HEAP8[this.ptr+13>>>0]!=0}init(type,destructor){this.set_adjusted_ptr(0),this.set_type(type),this.set_destructor(destructor)}set_adjusted_ptr(adjustedPtr){HEAPU32[this.ptr+16>>>2>>>0]=adjustedPtr}get_adjusted_ptr(){return HEAPU32[this.ptr+16>>>2>>>0]}}var exceptionLast=0,uncaughtExceptionCount=0;function ___cxa_throw(ptr,type,destructor){ptr>>>=0,type>>>=0,destructor>>>=0;var info=new ExceptionInfo(ptr);throw info.init(type,destructor),exceptionLast=ptr,uncaughtExceptionCount++,exceptionLast}var __abort_js=()=>abort(""),structRegistrations={},runDestructors=destructors=>{for(;destructors.length;){var ptr=destructors.pop(),del=destructors.pop();del(ptr)}};function readPointer(pointer){return this.fromWireType(HEAPU32[pointer>>>2>>>0])}var awaitingDependencies={},registeredTypes={},typeDependencies={},InternalError=class extends Error{constructor(message){super(message),this.name="InternalError"}},throwInternalError=message=>{throw new InternalError(message)},whenDependentTypesAreResolved=(myTypes,dependentTypes,getTypeConverters)=>{myTypes.forEach(type=>typeDependencies[type]=dependentTypes);function onComplete(typeConverters2){var myTypeConverters=getTypeConverters(typeConverters2);myTypeConverters.length!==myTypes.length&&throwInternalError("Mismatched type converter count");for(var i3=0;i3<myTypes.length;++i3)registerType(myTypes[i3],myTypeConverters[i3])}var typeConverters=new Array(dependentTypes.length),unregisteredTypes=[],registered=0;for(let[i3,dt3]of dependentTypes.entries())registeredTypes.hasOwnProperty(dt3)?typeConverters[i3]=registeredTypes[dt3]:(unregisteredTypes.push(dt3),awaitingDependencies.hasOwnProperty(dt3)||(awaitingDependencies[dt3]=[]),awaitingDependencies[dt3].push(()=>{typeConverters[i3]=registeredTypes[dt3],++registered,registered===unregisteredTypes.length&&onComplete(typeConverters)}));unregisteredTypes.length===0&&onComplete(typeConverters)},__embind_finalize_value_object=function(structType){structType>>>=0;var reg=structRegistrations[structType];delete structRegistrations[structType];var rawConstructor=reg.rawConstructor,rawDestructor=reg.rawDestructor,fieldRecords=reg.fields,fieldTypes=fieldRecords.map(field=>field.getterReturnType).concat(fieldRecords.map(field=>field.setterArgumentType));whenDependentTypesAreResolved([structType],fieldTypes,fieldTypes2=>{var fields={};for(var[i3,field]of fieldRecords.entries()){let getterReturnType=fieldTypes2[i3],getter=field.getter,getterContext=field.getterContext,setterArgumentType=fieldTypes2[i3+fieldRecords.length],setter=field.setter,setterContext=field.setterContext;fields[field.fieldName]={read:ptr=>getterReturnType.fromWireType(getter(getterContext,ptr)),write:(ptr,o4)=>{var destructors=[];setter(setterContext,ptr,setterArgumentType.toWireType(destructors,o4)),runDestructors(destructors)},optional:getterReturnType.optional}}return[{name:reg.name,fromWireType:ptr=>{var rv2={};for(var i4 in fields)rv2[i4]=fields[i4].read(ptr);return rawDestructor(ptr),rv2},toWireType:(destructors,o4)=>{for(var fieldName in fields)if(!(fieldName in o4)&&!fields[fieldName].optional)throw new TypeError(`Missing field: "${fieldName}"`);var ptr=rawConstructor();for(fieldName in fields)fields[fieldName].write(ptr,o4[fieldName]);return destructors!==null&&destructors.push(rawDestructor,ptr),ptr},readValueFromPointer:readPointer,destructorFunction:rawDestructor}]})},AsciiToString=ptr=>{ptr>>>=0;for(var str="";;){var ch3=HEAPU8[ptr++>>>0];if(!ch3)return str;str+=String.fromCharCode(ch3)}},BindingError=class extends Error{constructor(message){super(message),this.name="BindingError"}},throwBindingError=message=>{throw new BindingError(message)};function sharedRegisterType(rawType,registeredInstance,options={}){var name=registeredInstance.name;if(rawType||throwBindingError(`type "${name}" must have a positive integer typeid pointer`),registeredTypes.hasOwnProperty(rawType)){if(options.ignoreDuplicateRegistrations)return;throwBindingError(`Cannot register type '${name}' twice`)}if(registeredTypes[rawType]=registeredInstance,delete typeDependencies[rawType],awaitingDependencies.hasOwnProperty(rawType)){var callbacks=awaitingDependencies[rawType];delete awaitingDependencies[rawType],callbacks.forEach(cb3=>cb3())}}function registerType(rawType,registeredInstance,options={}){return sharedRegisterType(rawType,registeredInstance,options)}var integerReadValueFromPointer=(name,width,signed)=>{switch(width){case 1:return signed?pointer=>HEAP8[pointer>>>0]:pointer=>HEAPU8[pointer>>>0];case 2:return signed?pointer=>HEAP16[pointer>>>1>>>0]:pointer=>HEAPU16[pointer>>>1>>>0];case 4:return signed?pointer=>HEAP32[pointer>>>2>>>0]:pointer=>HEAPU32[pointer>>>2>>>0];case 8:return signed?pointer=>HEAP64[pointer>>>3>>>0]:pointer=>HEAPU64[pointer>>>3>>>0];default:throw new TypeError(`invalid integer width (${width}): ${name}`)}},__embind_register_bigint=function(primitiveType,name,size3,minRange,maxRange){primitiveType>>>=0,name>>>=0,size3>>>=0,name=AsciiToString(name);let isUnsignedType=minRange===0n,fromWireType=value=>value;if(isUnsignedType){let bitSize=size3*8;fromWireType=value=>BigInt.asUintN(bitSize,value),maxRange=fromWireType(maxRange)}registerType(primitiveType,{name,fromWireType,toWireType:(destructors,value)=>(typeof value=="number"&&(value=BigInt(value)),value),readValueFromPointer:integerReadValueFromPointer(name,size3,!isUnsignedType),destructorFunction:null})};function __embind_register_bool(rawType,name,trueValue,falseValue){rawType>>>=0,name>>>=0,name=AsciiToString(name),registerType(rawType,{name,fromWireType:function(wt3){return!!wt3},toWireType:function(destructors,o4){return o4?trueValue:falseValue},readValueFromPointer:function(pointer){return this.fromWireType(HEAPU8[pointer>>>0])},destructorFunction:null})}var shallowCopyInternalPointer=o4=>({count:o4.count,deleteScheduled:o4.deleteScheduled,preservePointerOnDelete:o4.preservePointerOnDelete,ptr:o4.ptr,ptrType:o4.ptrType,smartPtr:o4.smartPtr,smartPtrType:o4.smartPtrType}),throwInstanceAlreadyDeleted=obj=>{function getInstanceTypeName(handle){return handle.$$.ptrType.registeredClass.name}throwBindingError(getInstanceTypeName(obj)+" instance already deleted")},finalizationRegistry=!1,detachFinalizer=handle=>{},runDestructor=$$=>{$$.smartPtr?$$.smartPtrType.rawDestructor($$.smartPtr):$$.ptrType.registeredClass.rawDestructor($$.ptr)},releaseClassHandle=$$=>{$$.count.value-=1;var toDelete=$$.count.value===0;toDelete&&runDestructor($$)},attachFinalizer=handle=>globalThis.FinalizationRegistry?(finalizationRegistry=new FinalizationRegistry(info=>{releaseClassHandle(info.$$)}),attachFinalizer=handle2=>{var $$=handle2.$$,hasSmartPtr=!!$$.smartPtr;if(hasSmartPtr){var info={$$};finalizationRegistry.register(handle2,info,handle2)}return handle2},detachFinalizer=handle2=>finalizationRegistry.unregister(handle2),attachFinalizer(handle)):(attachFinalizer=handle2=>handle2,handle),deletionQueue=[],flushPendingDeletes=()=>{for(;deletionQueue.length;){var obj=deletionQueue.pop();obj.$$.deleteScheduled=!1,obj.delete()}},delayFunction,init_ClassHandle=()=>{let proto=ClassHandle.prototype;Object.assign(proto,{isAliasOf(other){if(!(this instanceof ClassHandle)||!(other instanceof ClassHandle))return!1;var leftClass=this.$$.ptrType.registeredClass,left=this.$$.ptr;other.$$=other.$$;for(var rightClass=other.$$.ptrType.registeredClass,right=other.$$.ptr;leftClass.baseClass;)left=leftClass.upcast(left),leftClass=leftClass.baseClass;for(;rightClass.baseClass;)right=rightClass.upcast(right),rightClass=rightClass.baseClass;return leftClass===rightClass&&left===right},clone(){if(this.$$.ptr||throwInstanceAlreadyDeleted(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var clone=attachFinalizer(Object.create(Object.getPrototypeOf(this),{$$:{value:shallowCopyInternalPointer(this.$$)}}));return clone.$$.count.value+=1,clone.$$.deleteScheduled=!1,clone},delete(){this.$$.ptr||throwInstanceAlreadyDeleted(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&throwBindingError("Object already scheduled for deletion"),detachFinalizer(this),releaseClassHandle(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)},isDeleted(){return!this.$$.ptr},deleteLater(){return this.$$.ptr||throwInstanceAlreadyDeleted(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&throwBindingError("Object already scheduled for deletion"),deletionQueue.push(this),deletionQueue.length===1&&delayFunction&&delayFunction(flushPendingDeletes),this.$$.deleteScheduled=!0,this}});let symbolDispose=Symbol.dispose;symbolDispose&&(proto[symbolDispose]=proto.delete)};function ClassHandle(){}var createNamedFunction=(name,func)=>Object.defineProperty(func,"name",{value:name}),registeredPointers={},ensureOverloadTable=(proto,methodName,humanName)=>{if(proto[methodName].overloadTable===void 0){var prevFunc=proto[methodName];proto[methodName]=function(...args){return proto[methodName].overloadTable.hasOwnProperty(args.length)||throwBindingError(`Function '${humanName}' called with an invalid number of arguments (${args.length}) - expects one of (${proto[methodName].overloadTable})!`),proto[methodName].overloadTable[args.length].apply(this,args)},proto[methodName].overloadTable=[],proto[methodName].overloadTable[prevFunc.argCount]=prevFunc}},exposePublicSymbol=(name,value,numArguments)=>{Module2.hasOwnProperty(name)?((numArguments===void 0||Module2[name].overloadTable!==void 0&&Module2[name].overloadTable[numArguments]!==void 0)&&throwBindingError(`Cannot register public name '${name}' twice`),ensureOverloadTable(Module2,name,name),Module2[name].overloadTable.hasOwnProperty(numArguments)&&throwBindingError(`Cannot register multiple overloads of a function with the same number of arguments (${numArguments})!`),Module2[name].overloadTable[numArguments]=value):(Module2[name]=value,Module2[name].argCount=numArguments)},char_0=48,char_9=57,makeLegalFunctionName=name=>{name=name.replace(/[^a-zA-Z0-9_]/g,"$");var f3=name.charCodeAt(0);return f3>=char_0&&f3<=char_9?`_${name}`:name};function RegisteredClass(name,constructor,instancePrototype,rawDestructor,baseClass,getActualType,upcast,downcast){this.name=name,this.constructor=constructor,this.instancePrototype=instancePrototype,this.rawDestructor=rawDestructor,this.baseClass=baseClass,this.getActualType=getActualType,this.upcast=upcast,this.downcast=downcast,this.pureVirtualFunctions=[]}var upcastPointer=(ptr,ptrClass,desiredClass)=>{for(;ptrClass!==desiredClass;)ptrClass.upcast||throwBindingError(`Expected null or instance of ${desiredClass.name}, got an instance of ${ptrClass.name}`),ptr=ptrClass.upcast(ptr),ptrClass=ptrClass.baseClass;return ptr},embindRepr=v4=>{if(v4===null)return"null";var t52=typeof v4;return t52==="object"||t52==="array"||t52==="function"?v4.toString():""+v4};function constNoSmartPtrRawPointerToWireType(destructors,handle){if(handle===null)return this.isReference&&throwBindingError(`null is not a valid ${this.name}`),0;handle.$$||throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`),handle.$$.ptr||throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);var handleClass=handle.$$.ptrType.registeredClass,ptr=upcastPointer(handle.$$.ptr,handleClass,this.registeredClass);return ptr}function genericPointerToWireType(destructors,handle){var ptr;if(handle===null)return this.isReference&&throwBindingError(`null is not a valid ${this.name}`),this.isSmartPointer?(ptr=this.rawConstructor(),destructors!==null&&destructors.push(this.rawDestructor,ptr),ptr):0;(!handle||!handle.$$)&&throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`),handle.$$.ptr||throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&handle.$$.ptrType.isConst&&throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType?handle.$$.smartPtrType.name:handle.$$.ptrType.name} to parameter type ${this.name}`);var handleClass=handle.$$.ptrType.registeredClass;if(ptr=upcastPointer(handle.$$.ptr,handleClass,this.registeredClass),this.isSmartPointer)switch(handle.$$.smartPtr===void 0&&throwBindingError("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:handle.$$.smartPtrType===this?ptr=handle.$$.smartPtr:throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType?handle.$$.smartPtrType.name:handle.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:ptr=handle.$$.smartPtr;break;case 2:if(handle.$$.smartPtrType===this)ptr=handle.$$.smartPtr;else{var clonedHandle=handle.clone();ptr=this.rawShare(ptr,Emval.toHandle(()=>clonedHandle.delete())),destructors!==null&&destructors.push(this.rawDestructor,ptr)}break;default:throwBindingError("Unsupported sharing policy")}return ptr}function nonConstNoSmartPtrRawPointerToWireType(destructors,handle){if(handle===null)return this.isReference&&throwBindingError(`null is not a valid ${this.name}`),0;handle.$$||throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`),handle.$$.ptr||throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`),handle.$$.ptrType.isConst&&throwBindingError(`Cannot convert argument of type ${handle.$$.ptrType.name} to parameter type ${this.name}`);var handleClass=handle.$$.ptrType.registeredClass,ptr=upcastPointer(handle.$$.ptr,handleClass,this.registeredClass);return ptr}var downcastPointer=(ptr,ptrClass,desiredClass)=>{if(ptrClass===desiredClass)return ptr;if(desiredClass.baseClass===void 0)return null;var rv2=downcastPointer(ptr,ptrClass,desiredClass.baseClass);return rv2===null?null:desiredClass.downcast(rv2)},registeredInstances={},getBasestPointer=(class_,ptr)=>{for(ptr===void 0&&throwBindingError("ptr should not be undefined");class_.baseClass;)ptr=class_.upcast(ptr),class_=class_.baseClass;return ptr},getInheritedInstance=(class_,ptr)=>(ptr=getBasestPointer(class_,ptr),registeredInstances[ptr]),makeClassHandle=(prototype,record)=>{(!record.ptrType||!record.ptr)&&throwInternalError("makeClassHandle requires ptr and ptrType");var hasSmartPtrType=!!record.smartPtrType,hasSmartPtr=!!record.smartPtr;return hasSmartPtrType!==hasSmartPtr&&throwInternalError("Both smartPtrType and smartPtr must be specified"),record.count={value:1},attachFinalizer(Object.create(prototype,{$$:{value:record,writable:!0}}))};function RegisteredPointer_fromWireType(ptr){var rawPointer=this.getPointee(ptr);if(!rawPointer)return this.destructor(ptr),null;var registeredInstance=getInheritedInstance(this.registeredClass,rawPointer);if(registeredInstance!==void 0){if(registeredInstance.$$.count.value===0)return registeredInstance.$$.ptr=rawPointer,registeredInstance.$$.smartPtr=ptr,registeredInstance.clone();var rv2=registeredInstance.clone();return this.destructor(ptr),rv2}function makeDefaultHandle(){return this.isSmartPointer?makeClassHandle(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:rawPointer,smartPtrType:this,smartPtr:ptr}):makeClassHandle(this.registeredClass.instancePrototype,{ptrType:this,ptr})}var actualType=this.registeredClass.getActualType(rawPointer),registeredPointerRecord=registeredPointers[actualType];if(!registeredPointerRecord)return makeDefaultHandle.call(this);var toType;this.isConst?toType=registeredPointerRecord.constPointerType:toType=registeredPointerRecord.pointerType;var dp3=downcastPointer(rawPointer,this.registeredClass,toType.registeredClass);return dp3===null?makeDefaultHandle.call(this):this.isSmartPointer?makeClassHandle(toType.registeredClass.instancePrototype,{ptrType:toType,ptr:dp3,smartPtrType:this,smartPtr:ptr}):makeClassHandle(toType.registeredClass.instancePrototype,{ptrType:toType,ptr:dp3})}var init_RegisteredPointer=()=>{Object.assign(RegisteredPointer.prototype,{getPointee(ptr){return this.rawGetPointee&&(ptr=this.rawGetPointee(ptr)),ptr},destructor(ptr){this.rawDestructor?.(ptr)},readValueFromPointer:readPointer,fromWireType:RegisteredPointer_fromWireType})};function RegisteredPointer(name,registeredClass,isReference,isConst,isSmartPointer,pointeeType,sharingPolicy,rawGetPointee,rawConstructor,rawShare,rawDestructor){this.name=name,this.registeredClass=registeredClass,this.isReference=isReference,this.isConst=isConst,this.isSmartPointer=isSmartPointer,this.pointeeType=pointeeType,this.sharingPolicy=sharingPolicy,this.rawGetPointee=rawGetPointee,this.rawConstructor=rawConstructor,this.rawShare=rawShare,this.rawDestructor=rawDestructor,!isSmartPointer&&registeredClass.baseClass===void 0?isConst?(this.toWireType=constNoSmartPtrRawPointerToWireType,this.destructorFunction=null):(this.toWireType=nonConstNoSmartPtrRawPointerToWireType,this.destructorFunction=null):this.toWireType=genericPointerToWireType}var replacePublicSymbol=(name,value,numArguments)=>{Module2.hasOwnProperty(name)||throwInternalError("Replacing nonexistent public symbol"),Module2[name].overloadTable!==void 0&&numArguments!==void 0?Module2[name].overloadTable[numArguments]=value:(Module2[name]=value,Module2[name].argCount=numArguments)},getWasmTableEntry=funcPtr=>wasmTable.get(funcPtr),dynCall=(sig,ptr,args=[],promising=!1)=>{var func=getWasmTableEntry(ptr),rtn=func(...args);function convert(rtn2){return sig[0]=="p"?rtn2>>>0:rtn2}return convert(rtn)},getDynCaller=(sig,ptr,promising=!1)=>(...args)=>dynCall(sig,ptr,args,promising),embind__requireFunction=(signature,rawFunction,isAsync3=!1)=>{signature=AsciiToString(signature);function makeDynCaller(){if(signature.includes("p"))return getDynCaller(signature,rawFunction,isAsync3);var rtn=getWasmTableEntry(rawFunction);return rtn}var fp3=makeDynCaller();return typeof fp3!="function"&&throwBindingError(`unknown function pointer with signature ${signature}: ${rawFunction}`),fp3};class UnboundTypeError extends Error{}var getTypeName=type=>{var ptr=___getTypeName(type),rv2=AsciiToString(ptr);return _free(ptr),rv2},throwUnboundTypeError=(message,types)=>{var unboundTypes=[],seen={};function visit(type){if(!seen[type]&&!registeredTypes[type]){if(typeDependencies[type]){typeDependencies[type].forEach(visit);return}unboundTypes.push(type),seen[type]=!0}}throw types.forEach(visit),new UnboundTypeError(`${message}: `+unboundTypes.map(getTypeName).join([", "]))};function __embind_register_class(rawType,rawPointerType,rawConstPointerType,baseClassRawType,getActualTypeSignature,getActualType,upcastSignature,upcast,downcastSignature,downcast,name,destructorSignature,rawDestructor){rawType>>>=0,rawPointerType>>>=0,rawConstPointerType>>>=0,baseClassRawType>>>=0,getActualTypeSignature>>>=0,getActualType>>>=0,upcastSignature>>>=0,upcast>>>=0,downcastSignature>>>=0,downcast>>>=0,name>>>=0,destructorSignature>>>=0,rawDestructor>>>=0,name=AsciiToString(name),getActualType=embind__requireFunction(getActualTypeSignature,getActualType),upcast&&(upcast=embind__requireFunction(upcastSignature,upcast)),downcast&&(downcast=embind__requireFunction(downcastSignature,downcast)),rawDestructor=embind__requireFunction(destructorSignature,rawDestructor);var legalFunctionName=makeLegalFunctionName(name);exposePublicSymbol(legalFunctionName,function(){throwUnboundTypeError(`Cannot construct ${name} due to unbound types`,[baseClassRawType])}),whenDependentTypesAreResolved([rawType,rawPointerType,rawConstPointerType],baseClassRawType?[baseClassRawType]:[],base=>{var _a362;base=base[0];var baseClass,basePrototype;baseClassRawType?(baseClass=base.registeredClass,basePrototype=baseClass.instancePrototype):basePrototype=ClassHandle.prototype;var constructor=createNamedFunction(name,function(...args){if(Object.getPrototypeOf(this)!==instancePrototype)throw new BindingError(`Use 'new' to construct ${name}`);if(registeredClass.constructor_body===void 0)throw new BindingError(`${name} has no accessible constructor`);var body=registeredClass.constructor_body[args.length];if(body===void 0)throw new BindingError(`Tried to invoke ctor of ${name} with invalid number of parameters (${args.length}) - expected (${Object.keys(registeredClass.constructor_body).toString()}) parameters instead!`);return body.apply(this,args)}),instancePrototype=Object.create(basePrototype,{constructor:{value:constructor}});constructor.prototype=instancePrototype;var registeredClass=new RegisteredClass(name,constructor,instancePrototype,rawDestructor,baseClass,getActualType,upcast,downcast);registeredClass.baseClass&&((_a362=registeredClass.baseClass).__derivedClasses??(_a362.__derivedClasses=[]),registeredClass.baseClass.__derivedClasses.push(registeredClass));var referenceConverter=new RegisteredPointer(name,registeredClass,!0,!1,!1),pointerConverter=new RegisteredPointer(name+"*",registeredClass,!1,!1,!1),constPointerConverter=new RegisteredPointer(name+" const*",registeredClass,!1,!0,!1);return registeredPointers[rawType]={pointerType:pointerConverter,constPointerType:constPointerConverter},replacePublicSymbol(legalFunctionName,constructor),[referenceConverter,pointerConverter,constPointerConverter]})}var heap32VectorToArray=(count,firstElement)=>{for(var array2=[],i3=0;i3<count;i3++)array2.push(HEAPU32[firstElement+i3*4>>>2>>>0]);return array2};function usesDestructorStack(argTypes){for(var i3=1;i3<argTypes.length;++i3)if(argTypes[i3]!==null&&argTypes[i3].destructorFunction===void 0)return!0;return!1}function createJsInvoker(argTypes,isClassMethodFunc,returns,isAsync3){var needsDestructorStack=usesDestructorStack(argTypes),argCount=argTypes.length-2,argsList=[],argsListWired=["fn"];isClassMethodFunc&&argsListWired.push("thisWired");for(var i3=0;i3<argCount;++i3)argsList.push(`arg${i3}`),argsListWired.push(`arg${i3}Wired`);argsList=argsList.join(","),argsListWired=argsListWired.join(",");var invokerFnBody=`return function (${argsList}) {
628
+ `)}_step(){if(!this.launchedRemoteSolves)return this.launchedRemoteSolves=!0,void this.launchRemoteSolves();if(!((this.pendingEffects?.length??0)>0)){if(this.failedNodeResults.length>0){this.ensureFailedNodeMetadata();let t52=this.failedNodeResults[0];return this.failed=!0,void(this.error=`Failed to solve ${this.failedNodeResults.length} nodes via hd-cache. First failure: ${t52?.node.capacityMeshNodeId} (${t52?.error})`)}this.routes=[];for(let t52=0;t52<this.unsolvedNodePortPoints.length;t52++)this.routes.push(...this.solvedRoutesByNodeIndex.get(t52)??[]);this.solved=!0}}visualize(){let t52={lines:[],points:[],rects:[],circles:[]};for(let e5 of this.getVisibleRoutes()){let n4=$o2(e5.route,e5.connectionName,this.colorMap[e5.connectionName]);for(let o4 of n4)t52.lines.push({points:o4.points,label:o4.connectionName,strokeColor:o4.z===0?o4.color:go2(o4.color,.75),layer:`z${o4.z}`,strokeWidth:e5.traceThickness,strokeDash:o4.z!==0?"10, 5":void 0});for(let n5 of e5.vias)t52.circles.push({center:n5,layer:"z0,1",radius:e5.viaDiameter/2,fill:this.colorMap[e5.connectionName],label:`${e5.connectionName} via`})}for(let[e5,n4]of this.nodeSolveMetadataById){let o4=n4.node.center.x-n4.node.width/2,i3=n4.node.center.x+n4.node.width/2,s3=n4.node.center.y-n4.node.height/2,r5=n4.node.center.y+n4.node.height/2,a3=this.createNodeMarkerLabel(e5,n4),c4=n4.status==="solved"?"blue":"red",l4=n4.status==="solved"?.03:.08;if(t52.lines.push({points:[{x:o4,y:s3},{x:i3,y:s3}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3},{points:[{x:i3,y:s3},{x:i3,y:r5}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3},{points:[{x:i3,y:r5},{x:o4,y:r5}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3},{points:[{x:o4,y:r5},{x:o4,y:s3}],layer:"hd_node_boundaries",strokeColor:c4,strokeDash:"6, 4",strokeWidth:l4,label:a3}),n4.status==="solved")t52.points.push({x:n4.node.center.x,y:n4.node.center.y,color:c4,layer:"hd_node_markers",label:a3});else{t52.lines.push({points:[{x:0,y:0},{x:n4.node.center.x,y:n4.node.center.y}],layer:"hd_failed_node_guides",strokeColor:c4,strokeDash:"8, 6",strokeWidth:.05,label:a3});let e6=Math.max(n4.node.width,1.2),o6=Math.max(n4.node.height,1.2),i4=e6/2,s4=o6/2;t52.rects.push({center:n4.node.center,layer:"hd_node_markers",width:e6,height:o6,fill:"rgba(255, 0, 0, 0.3)",stroke:c4,label:a3}),t52.circles.push({center:n4.node.center,radius:Math.max(.6*Math.max(e6,o6),1.1),layer:"hd_node_markers",fill:"rgba(255, 0, 0, 0.08)",stroke:c4,label:a3}),t52.lines.push({points:[{x:n4.node.center.x-i4,y:n4.node.center.y-s4},{x:n4.node.center.x+i4,y:n4.node.center.y+s4}],layer:"hd_node_markers",strokeColor:c4,strokeWidth:.16,label:a3},{points:[{x:n4.node.center.x-i4,y:n4.node.center.y+s4},{x:n4.node.center.x+i4,y:n4.node.center.y-s4}],layer:"hd_node_markers",strokeColor:c4,strokeWidth:.16,label:a3})}}return t52}},ZD=class extends jD{constructor(t52,e5={}){super(t52,{...e5,maxNodeDimension:e5.maxNodeDimension??7,maxNodeRatio:e5.maxNodeRatio??4});__publicField(this,"hdCacheBaseUrl");__publicField(this,"hdCacheFetch");this.hdCacheBaseUrl=e5.hdCacheBaseUrl??"https://hd-cache.tscircuit.com",this.hdCacheFetch=e5.hdCacheFetch,this.replaceHighDensityPipelineStep()}replaceHighDensityPipelineStep(){let t52=this.pipelineDef.findIndex(t53=>t53.solverName==="highDensityRouteSolver");if(t52===-1)throw new Error("Pipeline4 highDensityRouteSolver step is missing");this.pipelineDef[t52]={...this.pipelineDef[t52],solverClass:UD,getConstructorParams:t53=>{let e5=t53.uniformPortDistributionSolver?.getOutput()??[],n4=t53.portPointPathingSolver?.getOutput().nodesWithPortPoints??[],o4=e5.length>0?e5:n4;return t53.highDensityNodePortPoints=structuredClone(o4),[{nodePortPoints:o4,nodePfById:new Map((t53.portPointPathingSolver?.getOutput().inputNodeWithPortPoints??[]).map(e6=>[e6.capacityMeshNodeId,t53.portPointPathingSolver?.computeNodePf(e6)??null])),colorMap:t53.colorMap,connMap:t53.connMap,viaDiameter:t53.viaDiameter,traceWidth:t53.minTraceWidth,obstacleMargin:t53.srj.defaultObstacleMargin??.15,obstacles:t53.srj.obstacles,layerCount:t53.srj.layerCount,hdCacheBaseUrl:t53.hdCacheBaseUrl,fetchImpl:t53.hdCacheFetch}]}}}async stepAsync(){if(this.solved||this.failed)return;this.step();let t52=(t53=>{let e5=[],n4=t53;for(;n4;)e5.push(n4),n4=n4.activeSubSolver;for(let t54=e5.length-1;t54>=0;t54--){let n5=e5[t54]?.pendingEffects?.filter(Boolean)??[];if(n5.length>0)return n5}return[]})(this);t52.length!==0&&(await Promise.race(t52.map(t53=>t53.promise.then(()=>t53.name,()=>t53.name))),this.solved||this.failed||this.step())}async solveAsync(){let t52=Date.now();for(;!this.solved&&!this.failed;)await this.stepAsync();this.timeToSolve=Date.now()-t52}solve(){throw new Error("AutoroutingPipelineSolver5_HdCache requires async execution. Use solveAsync() or stepAsync().")}};var qD=Math.PI/2;var Pz=.1,Mz=.15,Nz=Pz+Mz,Cz=3*Nz/4;var rj=c(w3(),1);var LF=(Number.POSITIVE_INFINITY,1e-9);var s$=(new Int32Array(0),t52=>(t52.ccwRotationDegrees??0)*Math.PI/180);init_dist();var import_debug11=__toESM(require_browser(),1);var BaseSolver2=class{constructor(){__publicField(this,"MAX_ITERATIONS",1e5);__publicField(this,"solved",!1);__publicField(this,"failed",!1);__publicField(this,"iterations",0);__publicField(this,"progress",0);__publicField(this,"error",null);__publicField(this,"activeSubSolver");__publicField(this,"failedSubSolvers");__publicField(this,"timeToSolve");__publicField(this,"stats",{});__publicField(this,"_setupDone",!1)}setup(){this._setupDone||(this._setup(),this._setupDone=!0)}_setup(){}step(){if(this._setupDone||this.setup(),!this.solved&&!this.failed){this.iterations++;try{this._step()}catch(e5){throw this.error=`${this.constructor.name} error: ${e5}`,console.error(this.error),this.failed=!0,e5}!this.solved&&this.iterations>=this.MAX_ITERATIONS&&this.tryFinalAcceptance(),!this.solved&&this.iterations>=this.MAX_ITERATIONS&&(this.error=`${this.constructor.name} ran out of iterations`,console.error(this.error),this.failed=!0),"computeProgress"in this&&(this.progress=this.computeProgress())}}_step(){}getConstructorParams(){throw new Error("getConstructorParams not implemented")}getOutput(){return null}solve(){let startTime=Date.now();for(;!this.solved&&!this.failed;)this.step();let endTime=Date.now();this.timeToSolve=endTime-startTime}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}preview(){return{lines:[],points:[],rects:[],circles:[]}}};var BasePipelineSolver=class extends BaseSolver2{constructor(inputProblem){super();__publicField(this,"startTimeOfPhase",{});__publicField(this,"endTimeOfPhase",{});__publicField(this,"timeSpentOnPhase",{});__publicField(this,"firstIterationOfPhase",{});__publicField(this,"currentPipelineStepIndex",0);__publicField(this,"inputProblem");__publicField(this,"pipelineOutputs",{});this.inputProblem=inputProblem,this.MAX_ITERATIONS=1e6}_step(){let pipelineStepDef=this.pipelineDef[this.currentPipelineStepIndex];if(!pipelineStepDef){this.solved=!0;return}if(this.activeSubSolver){if(this.activeSubSolver.step(),this.activeSubSolver.solved){this.endTimeOfPhase[pipelineStepDef.solverName]=performance.now(),this.timeSpentOnPhase[pipelineStepDef.solverName]=this.endTimeOfPhase[pipelineStepDef.solverName]-this.startTimeOfPhase[pipelineStepDef.solverName];let output=this.activeSubSolver.getOutput();output!==null&&(this.pipelineOutputs[pipelineStepDef.solverName]=output),pipelineStepDef.onSolved?.(this),this.activeSubSolver=null,this.currentPipelineStepIndex++}else this.activeSubSolver.failed&&(this.error=this.activeSubSolver?.error,this.failed=!0,this.activeSubSolver=null);return}let constructorParams=pipelineStepDef.getConstructorParams(this);this.activeSubSolver=new pipelineStepDef.solverClass(...constructorParams),this[pipelineStepDef.solverName]=this.activeSubSolver,this.timeSpentOnPhase[pipelineStepDef.solverName]=0,this.startTimeOfPhase[pipelineStepDef.solverName]=performance.now(),this.firstIterationOfPhase[pipelineStepDef.solverName]=this.iterations}solveUntilPhase(phase){for(;this.getCurrentPhase().toLowerCase()!==phase.toLowerCase()&&(this.step(),!(this.failed||this.solved)););}getCurrentPhase(){return this.pipelineDef[this.currentPipelineStepIndex]?.solverName??"none"}getPhaseProgress(){let totalPhases=this.pipelineDef.length;if(totalPhases===0)return 1;let currentPhaseProgress=this.activeSubSolver?.progress??0;return(this.currentPipelineStepIndex+currentPhaseProgress)/totalPhases}getPhaseStats(){let stats={};for(let step of this.pipelineDef){let timeSpent=this.timeSpentOnPhase[step.solverName]||0,firstIteration=this.firstIterationOfPhase[step.solverName]||0,currentIteration=this.iterations,iterations=step.solverName===this.getCurrentPhase()?currentIteration-firstIteration:0,completed=this.currentPipelineStepIndex>this.pipelineDef.findIndex(s3=>s3.solverName===step.solverName);stats[step.solverName]={timeSpent,iterations,completed}}return stats}visualize(){if(!this.solved&&this.activeSubSolver)return this.activeSubSolver.visualize();let visualizations=this.pipelineDef.map((step,stepIndex)=>{let viz=this[step.solverName]?.visualize();if(!viz)return null;for(let rect of viz.rects??[])rect.step=stepIndex;for(let point7 of viz.points??[])point7.step=stepIndex;for(let circle2 of viz.circles??[])circle2.step=stepIndex;for(let text of viz.texts??[])text.step=stepIndex;for(let line2 of viz.lines??[])line2.step=stepIndex;return viz}).filter(Boolean);return visualizations.length===0?{points:[],rects:[],lines:[],circles:[],texts:[]}:visualizations.length===1?visualizations[0]:{points:visualizations.flatMap(v4=>v4.points||[]),rects:visualizations.flatMap(v4=>v4.rects||[]),lines:visualizations.flatMap(v4=>v4.lines||[]),circles:visualizations.flatMap(v4=>v4.circles||[]),texts:visualizations.flatMap(v4=>v4.texts||[])}}preview(){return this.activeSubSolver?this.activeSubSolver.preview():super.preview()}computeProgress(){return this.getPhaseProgress()}getStepOutput(stepName){return this.pipelineOutputs[stepName]}getAllOutputs(){return{...this.pipelineOutputs}}hasStepOutput(stepName){return stepName in this.pipelineOutputs}getSolver(stepName){return this[stepName]}};init_dist6();var rotatePoint=(point7,angle,origin={x:0,y:0})=>{let cos6=Math.cos(angle),sin6=Math.sin(angle),dx3=point7.x-origin.x,dy3=point7.y-origin.y;return{x:origin.x+dx3*cos6-dy3*sin6,y:origin.y+dx3*sin6+dy3*cos6}},setPackedComponentPadCenters=packedComponent=>{packedComponent.pads=packedComponent.pads.map(pad2=>{let rotated=rotatePoint(pad2.offset,packedComponent.ccwRotationOffset*Math.PI/180),normalizedRotation=(packedComponent.ccwRotationOffset%360+360)%360;return{...pad2,size:normalizedRotation===90||normalizedRotation===270?{x:pad2.size.y,y:pad2.size.x}:pad2.size,absoluteCenter:{x:packedComponent.center.x+rotated.x,y:packedComponent.center.y+rotated.y}}})};function sortComponentQueue({components,packOrderStrategy,packFirst=[]}){let packFirstMap=new Map;return packFirst.forEach((componentId,index)=>{packFirstMap.set(componentId,index)}),[...components].sort((a3,b3)=>{let aPackFirstIndex=packFirstMap.get(a3.componentId),bPackFirstIndex=packFirstMap.get(b3.componentId);return aPackFirstIndex!==void 0&&bPackFirstIndex!==void 0?aPackFirstIndex-bPackFirstIndex:aPackFirstIndex!==void 0?-1:bPackFirstIndex!==void 0?1:packOrderStrategy==="largest_to_smallest"?b3.pads.length-a3.pads.length:a3.pads.length-b3.pads.length})}var combineBounds=bounds=>{let minX=Math.min(...bounds.map(b3=>b3.minX)),minY=Math.min(...bounds.map(b3=>b3.minY)),maxX=Math.max(...bounds.map(b3=>b3.maxX)),maxY=Math.max(...bounds.map(b3=>b3.maxY));return{minX,minY,maxX,maxY}};function expandRotatedRectIntoBounds(opts){let{bounds,center:center2,width,height,angleRad}=opts,tx3=opts.translate?.x??0,ty3=opts.translate?.y??0,hw3=width/2,hh3=height/2,corners=[{x:center2.x-hw3,y:center2.y-hh3},{x:center2.x+hw3,y:center2.y-hh3},{x:center2.x+hw3,y:center2.y+hh3},{x:center2.x-hw3,y:center2.y+hh3}];for(let corner of corners){let rotated=rotatePoint(corner,angleRad),x4=rotated.x+tx3,y4=rotated.y+ty3;bounds.minX=Math.min(bounds.minX,x4),bounds.maxX=Math.max(bounds.maxX,x4),bounds.minY=Math.min(bounds.minY,y4),bounds.maxY=Math.max(bounds.maxY,y4)}}var getComponentBounds=(component,minGap=0)=>{let bounds={minX:1/0,maxX:-1/0,minY:1/0,maxY:-1/0},angleRad=component.ccwRotationOffset*Math.PI/180;for(let pad2 of component.pads)expandRotatedRectIntoBounds({bounds,center:pad2.offset,width:pad2.size.x,height:pad2.size.y,angleRad,translate:component.center});return component.courtyard&&expandRotatedRectIntoBounds({bounds,center:component.courtyard.offsetFromCenter,width:component.courtyard.width,height:component.courtyard.height,angleRad,translate:component.center}),{minX:bounds.minX-minGap,maxX:bounds.maxX+minGap,minY:bounds.minY-minGap,maxY:bounds.maxY+minGap}},cross2=(O3,A4,B4)=>(A4.x-O3.x)*(B4.y-O3.y)-(A4.y-O3.y)*(B4.x-O3.x);function simplifyCollinearSegments(outline,tolerance=1e-10){if(outline.length<=1)return outline;let simplified=[],currentSegmentStart=outline[0][0],currentSegmentEnd=outline[0][1];for(let i3=1;i3<outline.length;i3++){let nextSegment=outline[i3],[nextStart,nextEnd]=nextSegment,connectionTolerance=1e-9;if(!(Math.abs(currentSegmentEnd.x-nextStart.x)<connectionTolerance&&Math.abs(currentSegmentEnd.y-nextStart.y)<connectionTolerance)){simplified.push([currentSegmentStart,currentSegmentEnd]),currentSegmentStart=nextStart,currentSegmentEnd=nextEnd;continue}let crossProduct=cross2(currentSegmentStart,currentSegmentEnd,nextEnd),segLen1=Math.hypot(currentSegmentEnd.x-currentSegmentStart.x,currentSegmentEnd.y-currentSegmentStart.y),segLen2=Math.hypot(nextEnd.x-currentSegmentEnd.x,nextEnd.y-currentSegmentEnd.y),scaledTolerance=Math.max(tolerance,tolerance*segLen1*segLen2);Math.abs(crossProduct)<scaledTolerance||(simplified.push([currentSegmentStart,currentSegmentEnd]),currentSegmentStart=nextStart),currentSegmentEnd=nextEnd}if(outline.length>2){let firstSegment=simplified[0],lastSegmentCandidate=[currentSegmentStart,currentSegmentEnd];if(firstSegment&&simplified.length>0)if(Math.abs(currentSegmentEnd.x-firstSegment[0].x)<1e-9&&Math.abs(currentSegmentEnd.y-firstSegment[0].y)<1e-9){let crossProduct=cross2(currentSegmentStart,currentSegmentEnd,firstSegment[1]),segLen1=Math.hypot(currentSegmentEnd.x-currentSegmentStart.x,currentSegmentEnd.y-currentSegmentStart.y),segLen2=Math.hypot(firstSegment[1].x-currentSegmentEnd.x,firstSegment[1].y-currentSegmentEnd.y),scaledTolerance=Math.max(tolerance,tolerance*segLen1*segLen2);Math.abs(crossProduct)<scaledTolerance?simplified[0]=[currentSegmentStart,firstSegment[1]]:simplified.push(lastSegmentCandidate)}else simplified.push(lastSegmentCandidate);else simplified.push(lastSegmentCandidate)}else simplified.push([currentSegmentStart,currentSegmentEnd]);return simplified}function signedArea(points){let area=0;for(let i3=0;i3<points.length;i3++){let j4=(i3+1)%points.length,pi3=points[i3],pj=points[j4];area+=pi3.x*pj.y,area-=pj.x*pi3.y}return area/2}function extractFacePoints(face){let points=[],edge=face.first;if(!edge)return points;do{let shp=edge.shape,ps3=shp.start??shp.ps;points.push({x:ps3.x,y:ps3.y}),edge=edge.next}while(edge!==face.first);return points}function parseFlattenPolygonLoops(polygon2){let obstacleFreeLoops=[],obstacleContainingLoops=[],faces=Array.from(polygon2.faces);for(let face of faces){let points=extractFacePoints(face);if(points.length<3)continue;let area=signedArea(points);area>0?obstacleFreeLoops.push(points):area<0&&obstacleContainingLoops.push(points)}return{obstacleFreeLoops,obstacleContainingLoops}}function pointsToSegments(points){let segments=[];for(let i3=0;i3<points.length;i3++){let p12=points[i3],p22=points[(i3+1)%points.length];segments.push([p12,p22])}return segments}function parseFlattenPolygonSegments(polygon2){let loops=parseFlattenPolygonLoops(polygon2);return{obstacleFreeLoops:loops.obstacleFreeLoops.map(pointsToSegments),obstacleContainingLoops:loops.obstacleContainingLoops.map(pointsToSegments)}}var createCourtyardPolygon=opts=>{let{component,courtyard,minGap}=opts,hw3=courtyard.width/2+minGap,hh3=courtyard.height/2+minGap,worldCorners=[{x:courtyard.offsetFromCenter.x-hw3,y:courtyard.offsetFromCenter.y-hh3},{x:courtyard.offsetFromCenter.x+hw3,y:courtyard.offsetFromCenter.y-hh3},{x:courtyard.offsetFromCenter.x+hw3,y:courtyard.offsetFromCenter.y+hh3},{x:courtyard.offsetFromCenter.x-hw3,y:courtyard.offsetFromCenter.y+hh3}].map(corner=>{let rotated=rotatePoint(corner,component.ccwRotationOffset*Math.PI/180);return{x:rotated.x+component.center.x,y:rotated.y+component.center.y}}),arr=worldCorners.map(({x:x4,y:y4})=>[x4,y4]),poly=new Flatten.Polygon(arr),xs3=worldCorners.map(p4=>p4.x),ys3=worldCorners.map(p4=>p4.y),bbox={minX:Math.min(...xs3),minY:Math.min(...ys3),maxX:Math.max(...xs3),maxY:Math.max(...ys3)};return{poly,bbox}},createPadPolygons=(component,minGap)=>component.pads.map(pad2=>{let hw3=pad2.size.x/2+minGap,hh3=pad2.size.y/2+minGap,worldCorners=[{x:pad2.offset.x-hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y-hh3},{x:pad2.offset.x+hw3,y:pad2.offset.y+hh3},{x:pad2.offset.x-hw3,y:pad2.offset.y+hh3}].map(corner=>{let rotated=rotatePoint(corner,component.ccwRotationOffset*Math.PI/180);return{x:rotated.x+component.center.x,y:rotated.y+component.center.y}}),arr=worldCorners.map(({x:x4,y:y4})=>[x4,y4]),poly=new Flatten.Polygon(arr),xs3=worldCorners.map(p4=>p4.x),ys3=worldCorners.map(p4=>p4.y),bbox={minX:Math.min(...xs3),minY:Math.min(...ys3),maxX:Math.max(...xs3),maxY:Math.max(...ys3)};return{poly,bbox}}),createObstaclePolygons=(obstacles,minGap)=>obstacles.map(obs=>{let hw3=obs.width/2+minGap,hh3=obs.height/2+minGap,cx3=obs.absoluteCenter.x,cy3=obs.absoluteCenter.y,worldCorners=[{x:cx3-hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3+hh3},{x:cx3-hw3,y:cy3+hh3}],arr=worldCorners.map(({x:x4,y:y4})=>[x4,y4]),poly=new Flatten.Polygon(arr),xs3=worldCorners.map(p4=>p4.x),ys3=worldCorners.map(p4=>p4.y),bbox={minX:Math.min(...xs3),minY:Math.min(...ys3),maxX:Math.max(...xs3),maxY:Math.max(...ys3)};return{poly,bbox}}),constructOutlinesFromPackedComponents=(components,opts={})=>{let{minGap=0,obstacles=[]}=opts;if(components.length===0&&obstacles.length===0)return[];let componentBounds=components.map(c4=>getComponentBounds(c4,minGap)),obstacleBounds=obstacles.map(o4=>({minX:o4.absoluteCenter.x-o4.width/2-minGap,minY:o4.absoluteCenter.y-o4.height/2-minGap,maxX:o4.absoluteCenter.x+o4.width/2+minGap,maxY:o4.absoluteCenter.y+o4.height/2+minGap})),bounds=combineBounds([...componentBounds,...obstacleBounds]),allPadShapes=[];for(let component of components)if(component.courtyard)allPadShapes.push(createCourtyardPolygon({component,courtyard:component.courtyard,minGap}));else{let padShapes=createPadPolygons(component,minGap);allPadShapes.push(...padShapes)}let obstacleShapes=createObstaclePolygons(obstacles,minGap);if(allPadShapes.push(...obstacleShapes),allPadShapes.length===0)return[];let keptPadPolys=filterPadShapes(allPadShapes).map(s3=>s3.poly),A4=new Flatten.Polygon(new Flatten.Box(bounds.minX,bounds.minY,bounds.maxX,bounds.maxY)),B4=A4.clone();for(let poly of keptPadPolys)try{A4=Flatten.BooleanOperations.subtract(A4,poly)}catch{}let union2=null;try{union2=Flatten.BooleanOperations.subtract(B4,A4)}catch{try{if(keptPadPolys.length>0){let U3=keptPadPolys[0];for(let i3=1;i3<keptPadPolys.length;i3++)try{U3=Flatten.BooleanOperations.unify(U3,keptPadPolys[i3])}catch{}union2=U3}}catch{union2=null}}if(!union2)return[];let parsed=parseFlattenPolygonSegments(union2);return[...parsed.obstacleFreeLoops.map(outline=>simplifyCollinearSegments(outline)),...parsed.obstacleContainingLoops.map(outline=>simplifyCollinearSegments(outline))].filter(outline=>outline.length>=3)};function filterPadShapes(allPadShapes){let areaOfBox=b3=>Math.max(0,b3.maxX-b3.minX)*Math.max(0,b3.maxY-b3.minY),containsBox=(outer,inner,eps=1e-9)=>outer.minX-eps<=inner.minX&&outer.minY-eps<=inner.minY&&outer.maxX+eps>=inner.maxX&&outer.maxY+eps>=inner.maxY,sortedByAreaDesc=[...allPadShapes].sort((a3,b3)=>areaOfBox(b3.bbox)-areaOfBox(a3.bbox)),filtered=[];for(let shape of sortedByAreaDesc){let w4=shape.bbox.maxX-shape.bbox.minX,h6=shape.bbox.maxY-shape.bbox.minY;if(!(w4>1e-12&&h6>1e-12))continue;let contained=!1;for(let kept of filtered)if(containsBox(kept.bbox,shape.bbox)){contained=!0;break}contained||filtered.push(shape)}return filtered}var makeNumbersRounded=obj=>typeof obj=="number"?Math.round(obj*100)/100:typeof obj=="object"?Object.fromEntries(Object.entries(obj).map(([key,value])=>[key,makeNumbersRounded(value)])):obj,BaseSolver3=class{constructor(){__publicField(this,"MAX_ITERATIONS",1e5);__publicField(this,"solved",!1);__publicField(this,"failed",!1);__publicField(this,"iterations",0);__publicField(this,"progress",0);__publicField(this,"error",null);__publicField(this,"activeSubSolver");__publicField(this,"failedSubSolvers");__publicField(this,"timeToSolve");__publicField(this,"stats",{});__publicField(this,"_setupDone",!1)}getSolverName(){return this.constructor.name}setup(){this._setupDone||(this._setup(),this._setupDone=!0)}step(){if(this._setupDone||this.setup(),!this.solved&&!this.failed){this.iterations++;try{this._step()}catch(e5){throw this.error=`${this.getSolverName()} error: ${e5}`,console.error(this.error),this.failed=!0,e5}!this.solved&&this.iterations>this.MAX_ITERATIONS&&this.tryFinalAcceptance(),!this.solved&&this.iterations>this.MAX_ITERATIONS&&(this.error=`${this.getSolverName()} ran out of iterations`,console.error(this.error),this.failed=!0),"computeProgress"in this&&(this.progress=this.computeProgress())}}_setup(){}_step(){}getConstructorParams(){throw new Error("getConstructorParams not implemented")}solve(){let startTime=Date.now();for(;!this.solved&&!this.failed;)this.step();let endTime=Date.now();this.timeToSolve=endTime-startTime}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}getOutput(){return null}preview(){return{lines:[],points:[],rects:[],circles:[]}}noisySolve(){let startTime=Date.now();for(;!this.solved&&!this.failed;)this.step(),console.log(JSON.stringify(makeNumbersRounded(this.visualize())));let endTime=Date.now();this.timeToSolve=endTime-startTime}},MultiOffsetIrlsSolver=class extends BaseSolver3{constructor(params){super();__publicField(this,"offsetPadPoints");__publicField(this,"targetPointMap");__publicField(this,"currentPosition");__publicField(this,"constraintFn");__publicField(this,"epsilon");__publicField(this,"useSquaredDistance");__publicField(this,"optimalPosition");__publicField(this,"initialPosition");this.offsetPadPoints=[...params.offsetPadPoints],this.targetPointMap=new Map(params.targetPointMap),this.initialPosition={...params.initialPosition},this.currentPosition={...params.initialPosition},this.constraintFn=params.constraintFn,this.epsilon=params.epsilon??1e-6,this.useSquaredDistance=params.useSquaredDistance??!1,this.MAX_ITERATIONS=params.maxIterations??100}getSolverName(){return"MultiOffsetIrlsSolver"}getConstructorParams(){return{offsetPadPoints:this.offsetPadPoints.map(pad2=>({...pad2})),targetPointMap:new Map(this.targetPointMap),initialPosition:this.initialPosition,constraintFn:this.constraintFn,epsilon:this.epsilon,useSquaredDistance:this.useSquaredDistance,maxIterations:this.MAX_ITERATIONS}}_setup(){this.currentPosition={...this.initialPosition},this.optimalPosition=void 0,(!Array.from(this.targetPointMap.values()).some(targets=>targets.length>0)||this.offsetPadPoints.length===0)&&(this.optimalPosition={...this.currentPosition},this.solved=!0)}_step(){if(this.offsetPadPoints.length===0)return;let{x:currentX,y:currentY}=this.currentPosition,weightedSumX=0,weightedSumY=0,totalWeight=0;for(let pad2 of this.offsetPadPoints){let targetPoints=this.targetPointMap.get(pad2.id)||[];if(targetPoints.length===0)continue;let padX=currentX+pad2.offsetX,padY=currentY+pad2.offsetY;for(let targetPoint of targetPoints){let dx22=padX-targetPoint.x,dy22=padY-targetPoint.y,distance8=Math.sqrt(dx22*dx22+dy22*dy22),weight;this.useSquaredDistance?weight=1:weight=distance8<this.epsilon?1e6:1/distance8;let targetForCurrentPos={x:targetPoint.x-pad2.offsetX,y:targetPoint.y-pad2.offsetY};weightedSumX+=weight*targetForCurrentPos.x,weightedSumY+=weight*targetForCurrentPos.y,totalWeight+=weight}}let newPosition={x:totalWeight>0?weightedSumX/totalWeight:currentX,y:totalWeight>0?weightedSumY/totalWeight:currentY},constrainedPosition=this.constraintFn?this.constraintFn(newPosition):newPosition,dx3=constrainedPosition.x-currentX,dy3=constrainedPosition.y-currentY;if(Math.sqrt(dx3*dx3+dy3*dy3)<this.epsilon){this.optimalPosition={...constrainedPosition},this.solved=!0;return}this.currentPosition=constrainedPosition}getBestPosition(){return this.optimalPosition||this.currentPosition}getOffsetPadPositions(){let currentPos=this.getBestPosition(),padPositions=new Map;for(let pad2 of this.offsetPadPoints)padPositions.set(pad2.id,{x:currentPos.x+pad2.offsetX,y:currentPos.y+pad2.offsetY});return padPositions}getOffsetPadPosition(padId){return this.getOffsetPadPositions().get(padId)}getTotalDistance(position4){let pos=position4||this.getBestPosition(),totalDistance=0;for(let pad2 of this.offsetPadPoints){let padPosition={x:pos.x+pad2.offsetX,y:pos.y+pad2.offsetY},targetPoints=this.targetPointMap.get(pad2.id)||[];for(let target of targetPoints){let dx3=padPosition.x-target.x,dy3=padPosition.y-target.y;this.useSquaredDistance?totalDistance+=dx3*dx3+dy3*dy3:totalDistance+=Math.sqrt(dx3*dx3+dy3*dy3)}}return totalDistance}getDistanceForPad(padId,position4){let pos=position4||this.getBestPosition(),pad2=this.offsetPadPoints.find(p4=>p4.id===padId);if(!pad2)return 0;let padPosition={x:pos.x+pad2.offsetX,y:pos.y+pad2.offsetY};return(this.targetPointMap.get(padId)||[]).reduce((sum,target)=>{let dx3=padPosition.x-target.x,dy3=padPosition.y-target.y;return this.useSquaredDistance?sum+(dx3*dx3+dy3*dy3):sum+Math.sqrt(dx3*dx3+dy3*dy3)},0)}computeProgress(){if(this.offsetPadPoints.length===0)return 1;let initialDistance=this.getTotalDistance(this.initialPosition),currentDistance=this.getTotalDistance();if(initialDistance===0)return 1;let improvement=Math.max(0,initialDistance-currentDistance);return Math.min(1,improvement/initialDistance)}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]},colors=["#4CAF50","#2196F3","#FF9800","#9C27B0","#F44336","#607D8B"],currentPos=this.getBestPosition();for(let i3=0;i3<this.offsetPadPoints.length;i3++){let pad2=this.offsetPadPoints[i3];if(!pad2)continue;let color=colors[i3%colors.length],targetPoints=this.targetPointMap.get(pad2.id)||[],padPosition={x:currentPos.x+pad2.offsetX,y:currentPos.y+pad2.offsetY};for(let point7 of targetPoints)graphics.points.push({...point7,color});for(let point7 of targetPoints)graphics.lines.push({points:[padPosition,point7],strokeColor:color});graphics.points.push({x:padPosition.x,y:padPosition.y,color})}return graphics.points.push({...this.currentPosition,color:"#f44336"}),this.optimalPosition&&graphics.points.push({...this.optimalPosition,color:"rgba(76, 175, 80, 0.3)"}),graphics}getOutput(){return this.optimalPosition??this.currentPosition}},TwoPhaseIrlsSolver=class extends BaseSolver3{constructor(params){super();__publicField(this,"offsetPadPoints");__publicField(this,"targetPointMap");__publicField(this,"constraintFn");__publicField(this,"currentPosition");__publicField(this,"optimalPosition");__publicField(this,"initialPosition");__publicField(this,"phase1Epsilon");__publicField(this,"phase2Epsilon");__publicField(this,"maxIterations");__publicField(this,"phase1Solver");__publicField(this,"phase2Solver");__publicField(this,"currentPhase",1);__publicField(this,"phase1Position");__publicField(this,"closestTargetPadId");__publicField(this,"closestTargetPoint");this.offsetPadPoints=[...params.offsetPadPoints],this.targetPointMap=new Map(params.targetPointMap),this.initialPosition={...params.initialPosition},this.currentPosition={...params.initialPosition},this.constraintFn=params.constraintFn,this.phase1Epsilon=params.phase1Epsilon??params.epsilon??1e-6,this.phase2Epsilon=params.phase2Epsilon??params.epsilon??1e-6,this.maxIterations=params.maxIterations??100}getSolverName(){return"TwoPhaseIrlsSolver"}getConstructorParams(){return{offsetPadPoints:this.offsetPadPoints.map(pad2=>({...pad2})),targetPointMap:new Map(this.targetPointMap),initialPosition:this.initialPosition,constraintFn:this.constraintFn,phase1Epsilon:this.phase1Epsilon,phase2Epsilon:this.phase2Epsilon,maxIterations:this.maxIterations}}_setup(){if(this.currentPosition={...this.initialPosition},this.optimalPosition=void 0,this.currentPhase=1,this.phase1Position=void 0,this.closestTargetPadId=void 0,this.closestTargetPoint=void 0,!Array.from(this.targetPointMap.values()).some(targets=>targets.length>0)||this.offsetPadPoints.length===0){this.optimalPosition={...this.currentPosition},this.solved=!0;return}this.phase1Solver=new MultiOffsetIrlsSolver({offsetPadPoints:this.offsetPadPoints,targetPointMap:this.targetPointMap,initialPosition:this.initialPosition,constraintFn:this.constraintFn,epsilon:this.phase1Epsilon,maxIterations:this.maxIterations,useSquaredDistance:!0}),this.phase1Solver.setup()}_step(){this.currentPhase===1?this.stepPhase1():this.stepPhase2()}stepPhase1(){this.phase1Solver&&(this.phase1Solver.step(),this.currentPosition=this.phase1Solver.getBestPosition(),this.phase1Solver.solved?(this.phase1Position=this.phase1Solver.getBestPosition(),this.setupPhase2()):this.phase1Solver.failed&&(this.failed=!0,this.error=`Phase 1 failed: ${this.phase1Solver.error}`))}setupPhase2(){if(!this.phase1Position)return;let minDistance=1/0,closestPadId,closestTarget;for(let pad2 of this.offsetPadPoints){let targetPoints=this.targetPointMap.get(pad2.id)||[];if(targetPoints.length===0)continue;let padX=this.phase1Position.x+pad2.offsetX,padY=this.phase1Position.y+pad2.offsetY;for(let targetPoint of targetPoints){let dx3=padX-targetPoint.x,dy3=padY-targetPoint.y,distance8=Math.sqrt(dx3*dx3+dy3*dy3);distance8<minDistance&&(minDistance=distance8,closestPadId=pad2.id,closestTarget=targetPoint)}}if(this.closestTargetPadId=closestPadId,this.closestTargetPoint=closestTarget,!closestPadId||!closestTarget){this.optimalPosition=this.phase1Position,this.solved=!0;return}let phase2TargetMap=new Map;phase2TargetMap.set(closestPadId,[closestTarget]),this.phase2Solver=new MultiOffsetIrlsSolver({offsetPadPoints:this.offsetPadPoints,targetPointMap:phase2TargetMap,initialPosition:this.phase1Position,constraintFn:this.constraintFn,epsilon:this.phase2Epsilon,maxIterations:this.maxIterations,useSquaredDistance:!1}),this.phase2Solver.setup(),this.currentPhase=2}stepPhase2(){this.phase2Solver&&(this.phase2Solver.step(),this.currentPosition=this.phase2Solver.getBestPosition(),this.phase2Solver.solved?(this.optimalPosition=this.phase2Solver.getBestPosition(),this.solved=!0):this.phase2Solver.failed&&(this.failed=!0,this.error=`Phase 2 failed: ${this.phase2Solver.error}`))}getBestPosition(){return this.optimalPosition||this.currentPosition}getOffsetPadPositions(){let currentPos=this.getBestPosition(),padPositions=new Map;for(let pad2 of this.offsetPadPoints)padPositions.set(pad2.id,{x:currentPos.x+pad2.offsetX,y:currentPos.y+pad2.offsetY});return padPositions}getTotalDistance(position4){let pos=position4||this.getBestPosition(),totalDistance=0;for(let pad2 of this.offsetPadPoints){let padPosition={x:pos.x+pad2.offsetX,y:pos.y+pad2.offsetY},targetPoints=this.targetPointMap.get(pad2.id)||[];for(let target of targetPoints){let dx3=padPosition.x-target.x,dy3=padPosition.y-target.y;totalDistance+=dx3*dx3+dy3*dy3}}return totalDistance}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]};if(graphics.points.push({...this.currentPosition,color:this.currentPhase===1?"#FF6B6B":"#4ECDC4",label:`Phase ${this.currentPhase}`}),this.phase1Position&&this.currentPhase===2&&graphics.points.push({...this.phase1Position,color:"rgba(255, 107, 107, 0.5)",label:"Phase 1 result"}),this.closestTargetPoint&&this.closestTargetPadId){graphics.points.push({...this.closestTargetPoint,color:"#FFA500",label:`Closest target (${this.closestTargetPadId})`});let closestPad=this.offsetPadPoints.find(p4=>p4.id===this.closestTargetPadId);if(closestPad){let currentPos=this.getBestPosition(),padPos={x:currentPos.x+closestPad.offsetX,y:currentPos.y+closestPad.offsetY};graphics.lines.push({points:[padPos,this.closestTargetPoint],strokeColor:"#FFA500"})}}let activeSolver=this.currentPhase===1?this.phase1Solver:this.phase2Solver;if(activeSolver){let solverViz=activeSolver.visualize(),phaseColor=this.currentPhase===1?"rgba(255, 107, 107, 0.7)":"rgba(76, 205, 196, 0.7)";if(solverViz.lines){let modifiedLines=solverViz.lines.map(line2=>({...line2,strokeColor:phaseColor}));graphics.lines.push(...modifiedLines)}solverViz.points&&graphics.points.push(...solverViz.points),solverViz.rects&&graphics.rects.push(...solverViz.rects),solverViz.circles&&graphics.circles.push(...solverViz.circles)}return this.optimalPosition&&graphics.points.push({...this.optimalPosition,color:"rgba(76, 175, 80, 0.8)",label:"Final optimal position"}),graphics}getOutput(){return this.optimalPosition??this.currentPosition}};function isStrongConnection(pad1Id,pad2Id,weightedConnections){return!weightedConnections||weightedConnections.length===0?!0:weightedConnections.some(wc3=>wc3.padIds.includes(pad1Id)&&wc3.padIds.includes(pad2Id))}var createColorMapFromStrings=strings=>{let colorMap2={};for(let i3=0;i3<strings.length;i3++)colorMap2[strings[i3]]=`hsl(${i3*300/strings.length}, 100%, 50%)`;return colorMap2},getColorForString=(string,alpha=1)=>`hsl(${string.split("").reduce((acc,char)=>acc*31+char.charCodeAt(0),0)%360}, 100%, 50%, ${alpha})`;function getOutwardNormal(outlineSegment,ccwFullOutline){let[p12,p22]=outlineSegment,dx3=p22.x-p12.x,dy3=p22.y-p12.y,len=Math.hypot(dx3,dy3);if(len===0)return{x:0,y:1};let dirX=dx3/len,dirY=dy3/len,left={x:-dirY,y:dirX},right={x:dirY,y:-dirX},verts=[];if(ccwFullOutline.length>0){verts.push(ccwFullOutline[0][0]);for(let seg of ccwFullOutline)verts.push(seg[1])}let signedArea22=(()=>{let a3=0;for(let i3=0;i3<verts.length;i3++){let v12=verts[i3],v22=verts[(i3+1)%verts.length];a3+=v12.x*v22.y-v22.x*v12.y}return a3/2})(),geometricOutward=signedArea22>0?right:left;return signedArea22<0?{x:-geometricOutward.x,y:-geometricOutward.y}:geometricOutward}var LargestRectOutsideOutlineFromPointSolver=class extends BaseSolver2{constructor(params){super();__publicField(this,"ccwFullOutline");__publicField(this,"origin");__publicField(this,"globalBounds");__publicField(this,"largestRect",null);__publicField(this,"mode");this.ccwFullOutline=params.ccwFullOutline,this.origin=params.origin,this.globalBounds=params.globalBounds,this.mode=params.mode??"outside"}getSolverName(){return"LargestRectOutsideOutlineFromPointSolver"}getConstructorParams(){return{ccwFullOutline:this.ccwFullOutline,origin:this.origin,globalBounds:this.globalBounds,mode:this.mode}}_setup(){}_step(){this.largestRect=this.computeLargestRect(),this.solved=!0}computeLargestRect(){let edges=this.makeEdges(this.ccwFullOutline),bounds={x:this.globalBounds.minX,y:this.globalBounds.minY,w:this.globalBounds.maxX-this.globalBounds.minX,h:this.globalBounds.maxY-this.globalBounds.minY};return this.largestRectContainingPointRegion(edges,this.origin,bounds,this.mode)}almostEqual(a3,b3,eps=1e-9){return Math.abs(a3-b3)<=eps}makeEdges(poly){let edges=[];for(let i3=0;i3<poly.length;i3++){let a3=poly[i3],b3=poly[(i3+1)%poly.length];!a3||!b3||this.almostEqual(a3.x,b3.x)&&this.almostEqual(a3.y,b3.y)||edges.push([a3,b3])}return edges}isVertical(e5){return this.almostEqual(e5[0].x,e5[1].x)}isHorizontal(e5){return this.almostEqual(e5[0].y,e5[1].y)}scanlineIntervalsAtY(edges,y02){let xs3=[];for(let e5 of edges){if(!this.isVertical(e5))continue;let y12=e5[0].y,y22=e5[1].y,x4=e5[0].x,ymin=Math.min(y12,y22),ymax=Math.max(y12,y22);ymin<=y02&&y02<ymax&&xs3.push(x4)}xs3.sort((a3,b3)=>a3-b3);let intervals=[];for(let i3=0;i3+1<xs3.length;i3+=2){let x12=xs3[i3],x22=xs3[i3+1];x12!==void 0&&x22!==void 0&&intervals.push([x12,x22])}return intervals}clipIntervals(intervals,a3,b3){let out=[];for(let[L3,R3]of intervals){let l4=Math.max(a3,L3),r5=Math.min(b3,R3);r5>l4&&out.push([l4,r5])}return out}regionIntervalsAtY(edges,y02,bx1,bx22,mode){let inside2=this.clipIntervals(this.scanlineIntervalsAtY(edges,y02),bx1,bx22);if(mode==="inside")return inside2;let outs=[],prev=bx1;for(let[L3,R3]of inside2)L3>prev&&outs.push([prev,L3]),prev=Math.max(prev,R3);return prev<bx22&&outs.push([prev,bx22]),outs}largestRectContainingPointRegion(edges,p4,bounds,mode){let BX1=bounds.x,BX2=bounds.x+bounds.w,BY1=bounds.y,BY2=bounds.y+bounds.h,interval=this.regionIntervalsAtY(edges,p4.y,BX1,BX2,mode).find(([xL2,xR2])=>xL2-1e-9<=p4.x&&p4.x<=xR2+1e-9);if(!interval)return null;let[X_L,X_R]=interval,xset=new Set([X_L,X_R]);for(let e5 of edges){if(!this.isVertical(e5))continue;let x4=e5[0].x;X_L<x4&&x4<X_R&&xset.add(x4)}let xs3=Array.from(xset).sort((a3,b3)=>a3-b3),m4=xs3.length-1;if(m4<=0)return null;let top=Array(m4).fill(-1/0),bot=Array(m4).fill(1/0);for(let i3=0;i3<m4;i3++){let xi3=xs3[i3],xi1=xs3[i3+1];if(xi3===void 0||xi1===void 0)continue;let xm3=.5*(xi3+xi1);xset.has(xm3)&&(xm3+=1e-6);let minAbove=BY2,maxBelow=BY1;for(let e5 of edges){if(!this.isHorizontal(e5))continue;let y4=e5[0].y,x12=Math.min(e5[0].x,e5[1].x),x22=Math.max(e5[0].x,e5[1].x);x12-1e-9<=xm3&&xm3<=x22+1e-9&&(y4>p4.y&&(minAbove=Math.min(minAbove,y4)),y4<p4.y&&(maxBelow=Math.max(maxBelow,y4)))}maxBelow<minAbove?(top[i3]=minAbove,bot[i3]=maxBelow):(top[i3]=-1/0,bot[i3]=1/0)}let s02=-1;for(let i3=0;i3<m4;i3++){let xi3=xs3[i3],xi1=xs3[i3+1];if(!(xi3===void 0||xi1===void 0)&&xi3-1e-9<=p4.x&&p4.x<=xi1+1e-9){s02=i3;break}}if(s02===-1)return null;let best=null,bestArea=-1;for(let i3=0;i3<=s02;i3++){let minTop=1/0,maxBot=-1/0;for(let j4=i3;j4<m4;j4++){let topJ=top[j4],botJ=bot[j4];if(topJ===void 0||botJ===void 0||(minTop=Math.min(minTop,topJ),maxBot=Math.max(maxBot,botJ),j4<s02))continue;let height=Math.max(0,minTop-maxBot);if(height<=0)continue;let xi3=xs3[i3],xj1=xs3[j4+1];if(xi3===void 0||xj1===void 0)continue;let width=xj1-xi3,area=width*height;area>bestArea&&(bestArea=area,best={x:xi3,y:maxBot,w:width,h:height})}}return best}getLargestRect(){return this.solved||this.solve(),this.largestRect}getLargestRectBounds(){return this.solved||this.solve(),this.largestRect?{minX:this.largestRect.x,minY:this.largestRect.y,maxX:this.largestRect.x+this.largestRect.w,maxY:this.largestRect.y+this.largestRect.h}:{minX:0,minY:0,maxX:0,maxY:0}}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]};for(let i3=0;i3<this.ccwFullOutline.length;i3++){let p12=this.ccwFullOutline[i3],p22=this.ccwFullOutline[(i3+1)%this.ccwFullOutline.length];p12&&p22&&graphics.lines.push({points:[p12,p22],strokeColor:"rgba(0,0,0,0.5)"})}return graphics.lines.push({points:[...this.ccwFullOutline,this.ccwFullOutline[0]],strokeColor:"rgba(200, 200, 200, 0.5)",strokeDash:[10,5]}),graphics.circles.push({center:this.origin,radius:.05,fill:"#f44336",label:"Origin"}),this.largestRect&&graphics.rects.push({center:{x:this.largestRect.x+this.largestRect.w/2,y:this.largestRect.y+this.largestRect.h/2},width:this.largestRect.w,height:this.largestRect.h,fill:"rgba(0, 255, 0, 0.3)",stroke:"#4CAF50",label:`Largest Rectangle (Area: ${(this.largestRect.w*this.largestRect.h).toFixed(3)})`}),graphics}getOutput(){return this.largestRect??null}},getInputComponentBounds=(component,{rotationDegrees=0})=>{let bounds={minX:1/0,maxX:-1/0,minY:1/0,maxY:-1/0},angleRad=rotationDegrees*Math.PI/180;for(let pad2 of component.pads)expandRotatedRectIntoBounds({bounds,center:pad2.offset,width:pad2.size.x,height:pad2.size.y,angleRad});return component.courtyard&&expandRotatedRectIntoBounds({bounds,center:component.courtyard.offsetFromCenter,width:component.courtyard.width,height:component.courtyard.height,angleRad}),bounds},expandSegment=(segment2,amount)=>{let[p12,p22]=segment2,direction2={x:p22.x-p12.x,y:p22.y-p12.y},normalizedDirection=normalizeVector(direction2);return[{x:p12.x-normalizedDirection.x*amount,y:p12.y-normalizedDirection.y*amount},{x:p22.x+normalizedDirection.x*amount,y:p22.y+normalizedDirection.y*amount}]};function normalizeVector(direction2){let length4=Math.hypot(direction2.x,direction2.y);return{x:direction2.x/length4,y:direction2.y/length4}}function isPointInPolygon2(point7,polygon2){if(polygon2.length<3)return!1;let inside2=!1,n4=polygon2.length,poly=[...polygon2];(poly[0].x!==poly[n4-1].x||poly[0].y!==poly[n4-1].y)&&poly.push({...poly[0]});for(let i3=0,j4=poly.length-1;i3<poly.length;j4=i3++){let xi3=poly[i3].x,yi3=poly[i3].y,xj=poly[j4].x,yj=poly[j4].y;yi3>point7.y!=yj>point7.y&&point7.x<(xj-xi3)*(point7.y-yi3)/(yj-yi3)+xi3&&(inside2=!inside2)}return inside2}var OutlineSegmentCandidatePointSolver=class extends BaseSolver2{constructor(params){super();__publicField(this,"outlineSegment");__publicField(this,"viableOutlineSegment",null);__publicField(this,"ccwFullOutline");__publicField(this,"componentRotationDegrees");__publicField(this,"packStrategy");__publicField(this,"minGap");__publicField(this,"obstacles");__publicField(this,"packedComponents");__publicField(this,"componentToPack");__publicField(this,"viableBounds");__publicField(this,"globalBounds");__publicField(this,"boundaryOutline");__publicField(this,"weightedConnections");__publicField(this,"optimalPosition");__publicField(this,"irlsSolver");__publicField(this,"twoPhaseIrlsSolver");__publicField(this,"largestRectBounds");__publicField(this,"largestRectMidPoint");__publicField(this,"largestRectOrigin");this.outlineSegment=params.outlineSegment,this.ccwFullOutline=params.ccwFullOutline,this.componentRotationDegrees=params.componentRotationDegrees,this.packStrategy=params.packStrategy,this.minGap=params.minGap,this.packedComponents=params.packedComponents,this.componentToPack=params.componentToPack,this.obstacles=params.obstacles??[],this.globalBounds=params.globalBounds,this.boundaryOutline=params.boundaryOutline,this.weightedConnections=params.weightedConnections}getSolverName(){return"OutlineSegmentCandidatePointSolver"}getConstructorParams(){return{outlineSegment:this.outlineSegment,ccwFullOutline:this.ccwFullOutline,componentRotationDegrees:this.componentRotationDegrees,packStrategy:this.packStrategy,minGap:this.minGap,packedComponents:this.packedComponents,componentToPack:this.componentToPack,obstacles:this.obstacles,globalBounds:this.globalBounds,boundaryOutline:this.boundaryOutline,weightedConnections:this.weightedConnections}}_getOutlineBoundsWithMargin(params={}){let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let[p12,p22]of this.ccwFullOutline)minX=Math.min(minX,p12.x,p22.x),minY=Math.min(minY,p12.y,p22.y),maxX=Math.max(maxX,p12.x,p22.x),maxY=Math.max(maxY,p12.y,p22.y);let margin=params.margin??0;return{minX:minX-margin,minY:minY-margin,maxX:maxX+margin,maxY:maxY+margin}}_setup(){let{offsetPadPoints,targetPointMap}=this.getNetworkTargetPointMappings(),[p12,p22]=this.outlineSegment,constraintFn=point7=>{let projectedPoint=this.projectPointOntoSegment(point7,this.viableOutlineSegment);return this.adjustPositionForOutlineCollision(projectedPoint)},outwardNormal=getOutwardNormal(this.outlineSegment,this.ccwFullOutline),componentBounds=getInputComponentBounds(this.componentToPack,{rotationDegrees:this.componentRotationDegrees}),packedComponentBoundsWithMargin=this._getOutlineBoundsWithMargin({margin:Math.max(componentBounds.maxX-componentBounds.minX,componentBounds.maxY-componentBounds.minY)*2+this.minGap*2});this.largestRectMidPoint={x:(p12.x+p22.x)/2,y:(p12.y+p22.y)/2},this.largestRectOrigin={x:this.largestRectMidPoint.x+outwardNormal.x*1e-4,y:this.largestRectMidPoint.y+outwardNormal.y*1e-4};let outlinePoints=this.ccwFullOutline.flatMap(([p4])=>p4),signedArea22=0;for(let i3=0;i3<outlinePoints.length;i3++){let p122=outlinePoints[i3],p222=outlinePoints[(i3+1)%outlinePoints.length];signedArea22+=p122.x*p222.y-p222.x*p122.y}signedArea22/=2;let rectSearchMode=signedArea22<0?"inside":"outside",largestRectSolverParams={ccwFullOutline:outlinePoints,globalBounds:packedComponentBoundsWithMargin,origin:this.largestRectOrigin,mode:rectSearchMode},largestRectSolver=new LargestRectOutsideOutlineFromPointSolver(largestRectSolverParams);largestRectSolver.solve();let largestRectBounds=largestRectSolver.getLargestRectBounds();this.largestRectBounds=largestRectBounds;let segmentNormAbs={x:Math.abs(Math.sign(this.outlineSegment[1].x-this.outlineSegment[0].x)),y:Math.abs(Math.sign(this.outlineSegment[1].y-this.outlineSegment[0].y))},viableBounds={minX:largestRectBounds.minX-componentBounds.minX*segmentNormAbs.x,minY:largestRectBounds.minY-componentBounds.minY*segmentNormAbs.y,maxX:largestRectBounds.maxX-componentBounds.maxX*segmentNormAbs.x,maxY:largestRectBounds.maxY-componentBounds.maxY*segmentNormAbs.y};if(this.boundaryOutline&&this.boundaryOutline.length>=3){let boundaryMinX=1/0,boundaryMinY=1/0,boundaryMaxX=-1/0,boundaryMaxY=-1/0;for(let point7 of this.boundaryOutline)boundaryMinX=Math.min(boundaryMinX,point7.x),boundaryMinY=Math.min(boundaryMinY,point7.y),boundaryMaxX=Math.max(boundaryMaxX,point7.x),boundaryMaxY=Math.max(boundaryMaxY,point7.y);viableBounds={minX:Math.max(viableBounds.minX,boundaryMinX-componentBounds.minX),minY:Math.max(viableBounds.minY,boundaryMinY-componentBounds.minY),maxX:Math.min(viableBounds.maxX,boundaryMaxX-componentBounds.maxX),maxY:Math.min(viableBounds.maxY,boundaryMaxY-componentBounds.maxY)}}this.viableBounds=viableBounds;let viableBoundsWidth=viableBounds.maxX-viableBounds.minX,viableBoundsHeight=viableBounds.maxY-viableBounds.minY,componentBoundsWidth=componentBounds.maxX-componentBounds.minX,componentBoundsHeight=componentBounds.maxY-componentBounds.minY;if(viableBoundsWidth<componentBoundsWidth||viableBoundsHeight<componentBoundsHeight){this.failed=!0,this.error="There is nowhere for the component to fit along this outline section";return}let segmentLength=Math.hypot(p22.x-p12.x,p22.y-p12.y),expandedOutlineSegment=expandSegment(this.outlineSegment,segmentLength),[s12,s22]=expandedOutlineSegment;this.viableOutlineSegment=[{x:clamp(s12.x,viableBounds.minX,viableBounds.maxX),y:clamp(s12.y,viableBounds.minY,viableBounds.maxY)},{x:clamp(s22.x,viableBounds.minX,viableBounds.maxX),y:clamp(s22.y,viableBounds.minY,viableBounds.maxY)}];let[vp1,vp22]=this.viableOutlineSegment,initialPosition=this.adjustPositionForOutlineCollision({x:(vp1.x+vp22.x)/2,y:(vp1.y+vp22.y)/2});this.packStrategy==="minimum_closest_sum_squared_distance"?this.twoPhaseIrlsSolver=new TwoPhaseIrlsSolver({offsetPadPoints,targetPointMap,initialPosition,constraintFn,epsilon:1e-6,maxIterations:50}):this.irlsSolver=new MultiOffsetIrlsSolver({offsetPadPoints,targetPointMap,initialPosition,constraintFn,epsilon:1e-6,maxIterations:50,useSquaredDistance:this.packStrategy==="minimum_sum_squared_distance_to_network"})}_step(){let activeSolver=this.irlsSolver||this.twoPhaseIrlsSolver;if(!activeSolver){this.solved=!0;return}if(activeSolver.step(),activeSolver.solved){let rawPosition=activeSolver.getBestPosition();this.optimalPosition=rawPosition,this.solved=!0}else activeSolver.failed&&(this.failed=!0,this.error=activeSolver.error)}getNetworkTargetPointMappings(){let rotatedPads=this.getRotatedComponentPads(),offsetPadPoints=rotatedPads.map(pad2=>({id:pad2.padId,offsetX:pad2.offset.x,offsetY:pad2.offset.y})),targetPointMap=new Map;for(let pad2 of rotatedPads){let targetPoints=[];for(let packedComponent of this.packedComponents)for(let packedPad of packedComponent.pads)if(packedPad.networkId===pad2.networkId){if(!isStrongConnection(pad2.padId,packedPad.padId,this.weightedConnections))continue;targetPoints.push({...packedPad.absoluteCenter,networkId:packedPad.networkId})}targetPointMap.set(pad2.padId,targetPoints)}return{offsetPadPoints,targetPointMap}}projectPointOntoSegment(point7,segment2){let[p12,p22]=segment2,segmentX=p22.x-p12.x,segmentY=p22.y-p12.y,pointX=point7.x-p12.x,pointY=point7.y-p12.y,segmentLengthSq=segmentX*segmentX+segmentY*segmentY;if(segmentLengthSq===0)return{x:p12.x,y:p12.y};let t52=Math.max(0,Math.min(1,(pointX*segmentX+pointY*segmentY)/segmentLengthSq));return{x:p12.x+t52*segmentX,y:p12.y+t52*segmentY}}getRotatedComponentPads(){let rotationRadians=this.componentRotationDegrees*Math.PI/180;return this.componentToPack.pads.map(pad2=>({...pad2,size:(this.componentRotationDegrees+90)%180===0?{x:pad2.size.y,y:pad2.size.x}:pad2.size,offset:rotatePoint(pad2.offset,rotationRadians)}))}createTemporaryPackedComponent(center2){let rotationRadians=this.componentRotationDegrees*Math.PI/180,flipWidthHeight=(this.componentRotationDegrees+90)%180===0;return{componentId:this.componentToPack.componentId,center:center2,ccwRotationOffset:this.componentRotationDegrees,pads:this.componentToPack.pads.map(pad2=>{let rotatedOffset=rotatePoint(pad2.offset,rotationRadians);return{...pad2,size:{x:flipWidthHeight?pad2.size.y:pad2.size.x,y:flipWidthHeight?pad2.size.x:pad2.size.y},absoluteCenter:{x:center2.x+rotatedOffset.x,y:center2.y+rotatedOffset.y}}}),courtyard:this.componentToPack.courtyard}}adjustPositionForOutlineCollision(center2){let tempComponent=this.createTemporaryPackedComponent(center2),bounds=getComponentBounds(tempComponent,0),outwardNormal=getOutwardNormal(this.outlineSegment,this.ccwFullOutline),isHorizontalNormal=Math.abs(outwardNormal.x)>Math.abs(outwardNormal.y),isVerticalNormal=!isHorizontalNormal,adjustedCenter=center2;if(isHorizontalNormal){let isXPlusFacing=outwardNormal.x>0;isXPlusFacing?adjustedCenter={x:bounds.maxX,y:center2.y}:!isXPlusFacing&&(adjustedCenter={x:bounds.minX,y:center2.y})}else if(isVerticalNormal){let isYPlusFacing=outwardNormal.y>0;isYPlusFacing?adjustedCenter={x:center2.x,y:bounds.maxY}:!isYPlusFacing&&(adjustedCenter={x:center2.x,y:bounds.minY})}if(this.boundaryOutline&&this.boundaryOutline.length>=3){let adjustedComponent=this.createTemporaryPackedComponent(adjustedCenter),adjustedBounds=getComponentBounds(adjustedComponent,0),allPadsInside=adjustedComponent.pads.every(pad2=>isPointInPolygon2(pad2.absoluteCenter,this.boundaryOutline)),cornersInside=[{x:adjustedBounds.minX,y:adjustedBounds.minY},{x:adjustedBounds.minX,y:adjustedBounds.maxY},{x:adjustedBounds.maxX,y:adjustedBounds.minY},{x:adjustedBounds.maxX,y:adjustedBounds.maxY}].every(corner=>isPointInPolygon2(corner,this.boundaryOutline));(!allPadsInside||!cornersInside)&&this.viableBounds&&(adjustedCenter={x:clamp(adjustedCenter.x,this.viableBounds.minX,this.viableBounds.maxX),y:clamp(adjustedCenter.y,this.viableBounds.minY,this.viableBounds.maxY)})}return adjustedCenter}visualize(){let graphics={lines:[],points:[],rects:[],circles:[]};if(this.obstacles&&this.obstacles.length>0)for(let obstacle of this.obstacles)graphics.rects.push({center:obstacle.absoluteCenter,width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});if(this.globalBounds&&graphics.lines.push({points:[{x:this.globalBounds.minX,y:this.globalBounds.minY},{x:this.globalBounds.minX,y:this.globalBounds.maxY},{x:this.globalBounds.maxX,y:this.globalBounds.maxY},{x:this.globalBounds.maxX,y:this.globalBounds.minY},{x:this.globalBounds.minX,y:this.globalBounds.minY}],strokeColor:"rgba(255,0,255,0.5)",strokeDash:"2 2"}),this.boundaryOutline&&this.boundaryOutline.length){let outlinePoints=[...this.boundaryOutline];outlinePoints.length>0&&(outlinePoints[0].x!==outlinePoints[outlinePoints.length-1].x||outlinePoints[0].y!==outlinePoints[outlinePoints.length-1].y)&&outlinePoints.push({...outlinePoints[0]}),graphics.lines.push({points:outlinePoints,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}if(this.viableBounds&&graphics.rects.push({center:{x:(this.viableBounds.minX+this.viableBounds.maxX)/2,y:(this.viableBounds.minY+this.viableBounds.maxY)/2},width:this.viableBounds.maxX-this.viableBounds.minX,height:this.viableBounds.maxY-this.viableBounds.minY,fill:"rgba(0,255,0,0.1)",label:"Viable Bounds"}),this.largestRectBounds&&graphics.rects.push({center:{x:(this.largestRectBounds.minX+this.largestRectBounds.maxX)/2,y:(this.largestRectBounds.minY+this.largestRectBounds.maxY)/2},width:this.largestRectBounds.maxX-this.largestRectBounds.minX,height:this.largestRectBounds.maxY-this.largestRectBounds.minY,fill:"rgba(255,0,255,0.4)"}),this.largestRectMidPoint&&graphics.points.push({...this.largestRectMidPoint,label:"Largest Rect Mid Point",color:"rgba(128,0,255,1)"}),this.largestRectOrigin&&graphics.points.push({...this.largestRectOrigin,label:"Largest Rect Origin",color:"rgba(255,0,128,1)"}),this.viableOutlineSegment){let[p12,p22]=this.viableOutlineSegment;graphics.lines.push({points:[p12,p22],strokeColor:"#2196F3"})}let[osp1,osp2]=this.outlineSegment;graphics.lines.push({points:[osp1,osp2],strokeColor:"rgba(255,0,0,1)",strokeDash:"3 3"});for(let[p12,p22]of this.ccwFullOutline)graphics.lines.push({points:[p12,p22],strokeColor:"rgba(0,0,0,0.5)",strokeDash:"4 4"});for(let component of this.packedComponents)for(let pad2 of component.pads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:getColorForString(pad2.networkId,.5),stroke:"#333",label:`${pad2.padId} (${pad2.networkId})`});let pos=this.optimalPosition??this.irlsSolver?.currentPosition??this.twoPhaseIrlsSolver?.currentPosition??{x:0,y:0},rotatedPads=this.getRotatedComponentPads();for(let pad2 of rotatedPads){let padPos={x:pos.x+pad2.offset.x,y:pos.y+pad2.offset.y};graphics.rects.push({center:padPos,width:pad2.size.x,height:pad2.size.y,fill:this.failed?"rgba(255,0,0,0.5)":getColorForString(pad2.networkId,.5),label:`${pad2.padId} (${pad2.networkId})`});for(let packedComponent of this.packedComponents)for(let packedPad of packedComponent.pads)if(packedPad.networkId===pad2.networkId){let isStrong=isStrongConnection(pad2.padId,packedPad.padId,this.weightedConnections);graphics.lines.push({points:[padPos,packedPad.absoluteCenter],strokeColor:pad2.networkId==="VCC"?"#FF6B6B":"#4ECDC4",strokeDash:isStrong?void 0:"4 2",label:`${pad2.networkId} ${isStrong?"strong":"weak"}`})}}let activeSolver=this.irlsSolver||this.twoPhaseIrlsSolver;if(activeSolver){let currentPos=activeSolver.currentPosition;graphics.points.push({...currentPos,color:"#f44336"});let solverViz=activeSolver.visualize();solverViz.lines&&graphics.lines.push(...solverViz.lines),solverViz.circles&&graphics.circles.push(...solverViz.circles),solverViz.rects&&graphics.rects.push(...solverViz.rects),solverViz.points&&graphics.points.push(...solverViz.points)}return this.optimalPosition&&graphics.points.push({...this.optimalPosition,color:"rgba(76, 175, 80, 0.3)"}),graphics}getOutput(){return this.optimalPosition??null}},getGraphicsFromPackOutput=packOutput=>{let rects=[],lines=[];if(packOutput.boundaryOutline&&packOutput.boundaryOutline.length){let outlinePoints=[...packOutput.boundaryOutline];outlinePoints.length>0&&(outlinePoints[0].x!==outlinePoints[outlinePoints.length-1].x||outlinePoints[0].y!==outlinePoints[outlinePoints.length-1].y)&&outlinePoints.push({...outlinePoints[0]}),lines.push({points:outlinePoints,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}let allNetworkIds=Array.from(new Set(packOutput.components.flatMap(c4=>c4.pads.map(p4=>p4.networkId)))),colorMap2=createColorMapFromStrings(allNetworkIds);if(packOutput.obstacles&&packOutput.obstacles.length>0)for(let obstacle of packOutput.obstacles)rects.push({center:{x:obstacle.absoluteCenter.x,y:obstacle.absoluteCenter.y},width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});for(let component of packOutput.components){let bounds=getComponentBounds(component),width=bounds.maxX-bounds.minX,height=bounds.maxY-bounds.minY,isStatic=!!component.isStatic,rect={center:{x:component.center.x,y:component.center.y},width,height,fill:isStatic?"rgba(33, 150, 243, 0.25)":"rgba(0,0,0,0.25)",stroke:isStatic?"rgba(33, 150, 243, 0.6)":void 0,label:[component.componentId,`ccwRotationOffset: ${component.ccwRotationOffset.toFixed(1)}\xB0`].join(`
629
+ `)};rects.push(rect);for(let pad2 of component.pads){let{absoluteCenter,size:size3,padId,networkId}=pad2,padRect={center:{x:absoluteCenter.x,y:absoluteCenter.y},width:size3.x,height:size3.y,label:`${padId} ${networkId}`,fill:"rgba(255,0,0,0.8)"};rects.push(padRect)}}for(let netId of allNetworkIds){let padsOnNet=packOutput.components.flatMap(c4=>c4.pads.filter(p4=>p4.networkId===netId));for(let i3=0;i3<padsOnNet.length;i3++)for(let j4=i3+1;j4<padsOnNet.length;j4++){let pad1=padsOnNet[i3],pad2=padsOnNet[j4],isStrong=isStrongConnection(pad1.padId,pad2.padId,packOutput.weightedConnections);lines.push({points:[pad1.absoluteCenter,pad2.absoluteCenter],strokeColor:colorMap2[netId],strokeDash:isStrong?void 0:"4 2"})}}return{coordinateSystem:"cartesian",rects,lines}};function getComponentCollisionBoxes(component){if(component.courtyard){let courtyard=component.courtyard,angleRad=component.ccwRotationOffset*Math.PI/180,rotatedOffset=rotatePoint(courtyard.offsetFromCenter,angleRad),normalizedDeg=(component.ccwRotationOffset%360+360)%360,swapDims=normalizedDeg===90||normalizedDeg===270,width=courtyard.width,height=courtyard.height;return swapDims&&(width=courtyard.height,height=courtyard.width),[{center:{x:component.center.x+rotatedOffset.x,y:component.center.y+rotatedOffset.y},width,height}]}return component.pads.map(p4=>({center:{x:p4.absoluteCenter.x,y:p4.absoluteCenter.y},width:p4.size.x,height:p4.size.y}))}function checkOverlapWithPackedComponents({component,packedComponents,minGap}){let allPackedBoxes=packedComponents.flatMap(c4=>getComponentCollisionBoxes(c4)),newComponentBoxes=getComponentCollisionBoxes(component);for(let newBox of newComponentBoxes)for(let packedBox of allPackedBoxes){let{distance:boxDist}=computeDistanceBetweenBoxes(newBox,packedBox);if(boxDist+1e-6<minGap)return{hasOverlap:!0,gapDistance:boxDist}}return{hasOverlap:!1}}var SingleComponentPackSolver=class extends BaseSolver2{constructor(params){super();__publicField(this,"componentToPack");__publicField(this,"packedComponents");__publicField(this,"packPlacementStrategy");__publicField(this,"minGap");__publicField(this,"obstacles");__publicField(this,"boundaryOutline");__publicField(this,"weightedConnections");__publicField(this,"currentPhase","outline");__publicField(this,"outlines",[]);__publicField(this,"queuedOutlineSegments",[]);__publicField(this,"currentSegmentIndex",0);__publicField(this,"currentRotationIndex",0);__publicField(this,"activeSubSolver",null);__publicField(this,"candidateResults",[]);__publicField(this,"rejectedCandidates",[]);__publicField(this,"bestCandidate");__publicField(this,"outputPackedComponent");__publicField(this,"bounds");this.componentToPack=params.componentToPack,this.packedComponents=params.packedComponents,this.packPlacementStrategy=params.packPlacementStrategy,this.minGap=params.minGap??0,this.obstacles=params.obstacles??[],this.bounds=params.bounds,this.boundaryOutline=params.boundaryOutline,this.weightedConnections=params.weightedConnections}getSolverName(){return"SingleComponentPackSolver"}_setup(){super._setup(),this.currentPhase="outline",this.outlines=[],this.queuedOutlineSegments=[],this.candidateResults=[],this.activeSubSolver=void 0,this.currentSegmentIndex=0,this.currentRotationIndex=0}_step(){if(!(this.solved||this.failed))switch(this.currentPhase){case"outline":this.executeOutlinePhase();break;case"segment_candidate":this.executeSegmentCandidatePhase();break;case"evaluate":this.executeEvaluatePhase();break}}executeOutlinePhase(){if(this.packedComponents.length===0){let availableRotations2=this.componentToPack.availableRotationDegrees??[0,90,180,270],position4={x:0,y:0},rotation5=availableRotations2[0]??0,candidate=this.createPackedComponent(position4,rotation5),candidateBoxes=getComponentCollisionBoxes(candidate);if(!(this.obstacles??[]).some(obs=>{let obsBox={center:{x:obs.absoluteCenter.x,y:obs.absoluteCenter.y},width:obs.width,height:obs.height};return candidateBoxes.some(box2=>{let{distance:distance8}=computeDistanceBetweenBoxes(box2,obsBox);return distance8+1e-6<this.minGap})})){this.outputPackedComponent=candidate,this.solved=!0;return}}this.outlines=constructOutlinesFromPackedComponents(this.packedComponents,{minGap:this.minGap,obstacles:this.obstacles});let availableRotations=this.componentToPack.availableRotationDegrees??[0,90,180,270];for(let segmentIndex=0;segmentIndex<this.outlines.length;segmentIndex++){let outline=this.outlines[segmentIndex];for(let i3=0;i3<outline.length;i3++){let segment2=outline[i3];this.queuedOutlineSegments.push({segment:segment2,availableRotations:[...availableRotations],segmentIndex:segmentIndex*1e3+i3,ccwFullOutline:outline})}}if(this.boundaryOutline&&this.boundaryOutline.length>=3){let boundarySegments=[];for(let i3=0;i3<this.boundaryOutline.length;i3++){let p12=this.boundaryOutline[i3],p22=this.boundaryOutline[(i3+1)%this.boundaryOutline.length];boundarySegments.push([p12,p22])}let boundaryOutlineIndex=this.outlines.length;for(let i3=0;i3<boundarySegments.length;i3++){let segment2=boundarySegments[i3];this.queuedOutlineSegments.push({segment:segment2,availableRotations:[...availableRotations],segmentIndex:boundaryOutlineIndex*1e3+i3,ccwFullOutline:boundarySegments})}}let obstacleOutlineIndex=this.outlines.length+1;for(let obstacle of this.obstacles){let hw3=obstacle.width/2+this.minGap,hh3=obstacle.height/2+this.minGap,cx3=obstacle.absoluteCenter.x,cy3=obstacle.absoluteCenter.y,obstacleCorners=[{x:cx3-hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3-hh3},{x:cx3+hw3,y:cy3+hh3},{x:cx3-hw3,y:cy3+hh3}],obstacleSegments=[[obstacleCorners[0],obstacleCorners[1]],[obstacleCorners[1],obstacleCorners[2]],[obstacleCorners[2],obstacleCorners[3]],[obstacleCorners[3],obstacleCorners[0]]];for(let i3=0;i3<obstacleSegments.length;i3++){let segment2=obstacleSegments[i3];this.queuedOutlineSegments.push({segment:segment2,availableRotations:[...availableRotations],segmentIndex:obstacleOutlineIndex*1e3+i3,ccwFullOutline:obstacleSegments})}obstacleOutlineIndex++}this.currentPhase="segment_candidate",this.currentSegmentIndex=0,this.currentRotationIndex=0}executeSegmentCandidatePhase(){if(this.activeSubSolver?.solved||this.activeSubSolver?.failed){let queuedSegment=this.queuedOutlineSegments[this.currentSegmentIndex],rotation5=queuedSegment.availableRotations[this.currentRotationIndex],distance8=1/0,optimalPosition;if(this.activeSubSolver.solved&&this.activeSubSolver.optimalPosition){optimalPosition=this.activeSubSolver.optimalPosition;let candidateComponent=this.createPackedComponent(optimalPosition,rotation5),{hasOverlap,gapDistance}=checkOverlapWithPackedComponents({component:candidateComponent,packedComponents:this.packedComponents,minGap:this.minGap}),minObstacleGapDistance=1/0,candidateCollisionBoxes=getComponentCollisionBoxes(candidateComponent),tooCloseToObstacles=(this.obstacles??[]).some(obs=>{let obsBox={center:{x:obs.absoluteCenter.x,y:obs.absoluteCenter.y},width:obs.width,height:obs.height};return candidateCollisionBoxes.some(box2=>{let{distance:distance24}=computeDistanceBetweenBoxes(box2,obsBox);return minObstacleGapDistance=Math.min(minObstacleGapDistance,distance24),distance24+1e-6<this.minGap})}),outsideBounds=!1;if(this.bounds){let componentBounds=getComponentBounds(candidateComponent,0);outsideBounds=componentBounds.minX<this.bounds.minX||componentBounds.maxX>this.bounds.maxX||componentBounds.minY<this.bounds.minY||componentBounds.maxY>this.bounds.maxY}let outsideBoundaryOutline=!1;if(this.boundaryOutline&&this.boundaryOutline.length>=3){let componentBounds=getComponentBounds(candidateComponent,0),allPadsInside=candidateComponent.pads.every(pad2=>isPointInPolygon2(pad2.absoluteCenter,this.boundaryOutline)),cornersInside=[{x:componentBounds.minX,y:componentBounds.minY},{x:componentBounds.minX,y:componentBounds.maxY},{x:componentBounds.maxX,y:componentBounds.minY},{x:componentBounds.maxX,y:componentBounds.maxY}].every(corner=>isPointInPolygon2(corner,this.boundaryOutline));outsideBoundaryOutline=!allPadsInside||!cornersInside}distance8=this.calculateDistance(optimalPosition,rotation5),hasOverlap?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance}):tooCloseToObstacles?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance:minObstacleGapDistance}):outsideBounds?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance:-1}):outsideBoundaryOutline?this.rejectedCandidates.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex,gapDistance:-1}):this.candidateResults.push({segment:queuedSegment.segment,rotation:rotation5,optimalPosition,distance:distance8,segmentIndex:queuedSegment.segmentIndex,rotationIndex:this.currentRotationIndex})}this.currentRotationIndex++,this.activeSubSolver=void 0}for(;!this.activeSubSolver;){if(this.currentSegmentIndex>=this.queuedOutlineSegments.length){this.currentPhase="evaluate";return}let queuedSegment=this.queuedOutlineSegments[this.currentSegmentIndex];if(this.currentRotationIndex>=queuedSegment.availableRotations.length){this.currentSegmentIndex++,this.currentRotationIndex=0;continue}let rotation5=queuedSegment.availableRotations[this.currentRotationIndex];this.activeSubSolver=new OutlineSegmentCandidatePointSolver({outlineSegment:queuedSegment.segment,ccwFullOutline:queuedSegment.ccwFullOutline,componentRotationDegrees:rotation5,packStrategy:this.packPlacementStrategy,minGap:this.minGap,packedComponents:this.packedComponents,componentToPack:this.componentToPack,obstacles:this.obstacles,globalBounds:this.bounds,boundaryOutline:this.boundaryOutline,weightedConnections:this.weightedConnections}),this.activeSubSolver.setup();break}this.activeSubSolver.step()}executeEvaluatePhase(){if(this.candidateResults.length===0){this.failed=!0,this.error="No valid candidates found";return}this.candidateResults.sort((a3,b3)=>a3.distance-b3.distance),this.bestCandidate=this.candidateResults[0],this.bestCandidate.optimalPosition&&(this.outputPackedComponent=this.createPackedComponent(this.bestCandidate.optimalPosition,this.bestCandidate.rotation)),this.solved=!0}calculateDistance(position4,rotation5){let tempComponent=this.createPackedComponent(position4,rotation5),totalDistance=0,useSquaredDistance=this.packPlacementStrategy==="minimum_sum_squared_distance_to_network"||this.packPlacementStrategy==="minimum_closest_sum_squared_distance";for(let pad2 of tempComponent.pads){let minDistanceToNetwork=1/0;for(let packedComponent of this.packedComponents)for(let packedPad of packedComponent.pads)if(packedPad.networkId===pad2.networkId){if(!isStrongConnection(pad2.padId,packedPad.padId,this.weightedConnections))continue;let dx3=pad2.absoluteCenter.x-packedPad.absoluteCenter.x,dy3=pad2.absoluteCenter.y-packedPad.absoluteCenter.y,dist=Math.sqrt(dx3*dx3+dy3*dy3);minDistanceToNetwork=Math.min(minDistanceToNetwork,dist)}minDistanceToNetwork<1/0&&(totalDistance+=useSquaredDistance?minDistanceToNetwork*minDistanceToNetwork:minDistanceToNetwork)}return totalDistance}createPackedComponent(position4,rotation5){let component={...this.componentToPack,center:position4,ccwRotationOffset:rotation5,pads:this.componentToPack.pads.map(pad2=>({...pad2,absoluteCenter:{x:0,y:0}}))};return setPackedComponentPadCenters(component),component}visualize(){if(this.activeSubSolver)return this.activeSubSolver.visualize();let graphics=getGraphicsFromPackOutput({components:this.packedComponents,minGap:this.minGap,packOrderStrategy:"largest_to_smallest",packPlacementStrategy:this.packPlacementStrategy});if(graphics.points??(graphics.points=[]),graphics.lines??(graphics.lines=[]),graphics.rects??(graphics.rects=[]),graphics.texts??(graphics.texts=[]),graphics.circles??(graphics.circles=[]),this.obstacles&&this.obstacles.length>0)for(let obstacle of this.obstacles)graphics.rects.push({center:obstacle.absoluteCenter,width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});if(this.bounds&&graphics.lines.push({points:[{x:this.bounds.minX,y:this.bounds.minY},{x:this.bounds.minX,y:this.bounds.maxY},{x:this.bounds.maxX,y:this.bounds.maxY},{x:this.bounds.maxX,y:this.bounds.minY},{x:this.bounds.minX,y:this.bounds.minY}],strokeColor:"rgba(0,0,0,0.5)",strokeDash:"2 2"}),this.boundaryOutline&&this.boundaryOutline.length){let outlinePoints=[...this.boundaryOutline];outlinePoints.length>0&&(outlinePoints[0].x!==outlinePoints[outlinePoints.length-1].x||outlinePoints[0].y!==outlinePoints[outlinePoints.length-1].y)&&outlinePoints.push({...outlinePoints[0]}),graphics.lines.push({points:outlinePoints,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}switch(this.currentPhase){case"outline":this.visualizeOutlinePhase(graphics);break;case"segment_candidate":this.visualizeSegmentCandidatePhase(graphics);break;case"evaluate":this.visualizeEvaluatePhase(graphics);break}return graphics}visualizeOutlinePhase(graphics){for(let outline of this.outlines)for(let segment2 of outline){let[p12,p22]=segment2;graphics.lines.push({points:[p12,p22],strokeColor:"#ff4444"})}for(let i3=0;i3<this.outlines.length;i3++){let outline=this.outlines[i3];for(let u5=0;u5<outline.length;u5++){let[p12,p22]=outline[u5];graphics.points.push({x:p12.x,y:p12.y,label:`outlines [${i3}] [${u5}]`,color:"#ff4444"})}}}visualizeSegmentCandidatePhase(graphics){if(this.visualizeOutlinePhase(graphics),this.activeSubSolver){let subSolverViz=this.activeSubSolver.visualize();subSolverViz.lines&&graphics.lines.push(...subSolverViz.lines),subSolverViz.points&&graphics.points.push(...subSolverViz.points),subSolverViz.rects&&graphics.rects.push(...subSolverViz.rects),subSolverViz.circles&&graphics.circles.push(...subSolverViz.circles??[])}else for(let i3=0;i3<this.candidateResults.length;i3++){let candidate=this.candidateResults[i3];if(candidate.optimalPosition){let tempComponent=this.createPackedComponent(candidate.optimalPosition,candidate.rotation);for(let pad2 of tempComponent.pads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:"rgba(255,165,0,0.3)",stroke:"rgba(255,165,0,0.8)",strokeWidth:1});graphics.points.push({x:candidate.optimalPosition.x,y:candidate.optimalPosition.y,label:`c${i3}, d=${candidate.distance.toFixed(3)}`,color:"rgba(255,165,0,0.8)"})}}}visualizeEvaluatePhase(graphics){this.visualizeOutlinePhase(graphics);for(let i3=0;i3<this.candidateResults.length;i3++){let candidate=this.candidateResults[i3];if(!candidate.optimalPosition)continue;let step=i3,isBest=step===0;graphics.points.push({x:candidate.optimalPosition.x,y:candidate.optimalPosition.y,label:`step=${step}, d=${candidate.distance.toFixed(3)}`,color:isBest?"rgba(0,255,0,0.8)":"rgba(255,165,0,0.6)"})}for(let i3=0;i3<this.rejectedCandidates.length;i3++){let candidate=this.rejectedCandidates[i3];candidate.optimalPosition&&graphics.points.push({x:candidate.optimalPosition.x,y:candidate.optimalPosition.y,label:`rejected, d=${candidate.distance.toFixed(3)}
630
+ gap_distance=${candidate.gapDistance}`,color:"rgba(255,0,0,0.8)"})}if(this.outputPackedComponent)for(let pad2 of this.outputPackedComponent.pads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:"rgba(0,255,0,0.7)"})}getResult(){return this.outputPackedComponent}getOutput(){return this.getResult()}getConstructorParams(){return{componentToPack:this.componentToPack,packedComponents:this.packedComponents,packPlacementStrategy:this.packPlacementStrategy,minGap:this.minGap,obstacles:this.obstacles,bounds:this.bounds,boundaryOutline:this.boundaryOutline,weightedConnections:this.weightedConnections}}};function getPolygonCentroid(points){if(points.length<3){let sumX=points.reduce((sum,p4)=>sum+p4.x,0),sumY=points.reduce((sum,p4)=>sum+p4.y,0);return{x:sumX/points.length,y:sumY/points.length}}let signedArea22=0,cx3=0,cy3=0;for(let i3=0;i3<points.length;i3++){let p12=points[i3],p22=points[(i3+1)%points.length],crossProduct=p12.x*p22.y-p22.x*p12.y;signedArea22+=crossProduct,cx3+=(p12.x+p22.x)*crossProduct,cy3+=(p12.y+p22.y)*crossProduct}if(signedArea22*=.5,Math.abs(signedArea22)<1e-10){let sumX=points.reduce((sum,p4)=>sum+p4.x,0),sumY=points.reduce((sum,p4)=>sum+p4.y,0);return{x:sumX/points.length,y:sumY/points.length}}return cx3/=6*signedArea22,cy3/=6*signedArea22,{x:cx3,y:cy3}}var PackSolver2=class extends BaseSolver2{constructor(packInput){super();__publicField(this,"packInput");__publicField(this,"unpackedComponentQueue",[]);__publicField(this,"packedComponents",[]);__publicField(this,"componentToPack");this.packInput=packInput}getSolverName(){return"PackSolver2"}getConstructorParams(){return this.packInput}_setup(){let{components,packOrderStrategy,packFirst=[]}=this.packInput,validComponents=components.filter(component=>component.pads.length===0?!1:component.pads.every(pad2=>Number.isFinite(pad2.size.x)&&Number.isFinite(pad2.size.y)&&pad2.size.x>0&&pad2.size.y>0)),staticComponents=validComponents.filter(component=>component.isStatic),dynamicComponents=validComponents.filter(component=>!component.isStatic);this.packedComponents=staticComponents.map(component=>{let packedComponent={...component,center:component.center??{x:0,y:0},ccwRotationOffset:component.ccwRotationOffset??0,pads:component.pads.map(pad2=>({...pad2,absoluteCenter:pad2.absoluteCenter??{x:0,y:0}}))};return setPackedComponentPadCenters(packedComponent),packedComponent}),this.unpackedComponentQueue=sortComponentQueue({components:dynamicComponents,packOrderStrategy,packFirst})}packFirstComponent(){let firstComponentToPack=this.unpackedComponentQueue.shift(),initialPosition={x:0,y:0};this.packInput.boundaryOutline&&this.packInput.boundaryOutline.length>=3&&(initialPosition=getPolygonCentroid(this.packInput.boundaryOutline));let newPackedComponent={...firstComponentToPack,center:initialPosition,ccwRotationOffset:0,pads:firstComponentToPack.pads.map(p4=>({...p4,absoluteCenter:{x:0,y:0}}))};setPackedComponentPadCenters(newPackedComponent);let obstacles=this.packInput.obstacles??[],newComponentBoxes=getComponentCollisionBoxes(newPackedComponent),tooCloseToObstacles=obstacles.some(obs=>{let obsBox={center:{x:obs.absoluteCenter.x,y:obs.absoluteCenter.y},width:obs.width,height:obs.height};return newComponentBoxes.some(box2=>{let{distance:distance8}=computeDistanceBetweenBoxes(box2,obsBox);return distance8+1e-6<this.packInput.minGap})}),outsideBoundaryOutline=!1;if(this.packInput.boundaryOutline&&this.packInput.boundaryOutline.length>=3){let componentBounds=getComponentBounds(newPackedComponent,0),allPadsInside=newPackedComponent.pads.every(pad2=>isPointInPolygon2(pad2.absoluteCenter,this.packInput.boundaryOutline)),cornersInside=[{x:componentBounds.minX,y:componentBounds.minY},{x:componentBounds.minX,y:componentBounds.maxY},{x:componentBounds.maxX,y:componentBounds.minY},{x:componentBounds.maxX,y:componentBounds.maxY}].every(corner=>isPointInPolygon2(corner,this.packInput.boundaryOutline));outsideBoundaryOutline=!allPadsInside||!cornersInside}if(!tooCloseToObstacles&&!outsideBoundaryOutline){this.packedComponents.push(newPackedComponent);return}let fallbackSolver=new SingleComponentPackSolver({packedComponents:[],componentToPack:firstComponentToPack,packPlacementStrategy:this.packInput.packPlacementStrategy,minGap:this.packInput.minGap,obstacles,bounds:this.packInput.bounds,boundaryOutline:this.packInput.boundaryOutline,weightedConnections:this.packInput.weightedConnections});fallbackSolver.solve();let result=fallbackSolver.getResult();result?this.packedComponents.push(result):this.packedComponents.push(newPackedComponent)}_step(){if(!(this.solved||this.failed)){if(this.packedComponents.length===0){if(this.unpackedComponentQueue.length===0){this.solved=!0;return}this.packFirstComponent();return}if(!this.activeSubSolver){if(this.unpackedComponentQueue.length===0){this.solved=!0;return}if(this.componentToPack=this.unpackedComponentQueue.shift(),!this.componentToPack){this.solved=!0;return}this.activeSubSolver=new SingleComponentPackSolver({packedComponents:this.packedComponents,componentToPack:this.componentToPack,packPlacementStrategy:this.packInput.packPlacementStrategy,minGap:this.packInput.minGap,obstacles:this.packInput.obstacles??[],bounds:this.packInput.bounds,boundaryOutline:this.packInput.boundaryOutline,weightedConnections:this.packInput.weightedConnections}),this.activeSubSolver.setup()}if(this.activeSubSolver.step(),this.activeSubSolver.failed){this.failed=!0;return}if(this.activeSubSolver.solved){let result=this.activeSubSolver.getResult();if(result)this.packedComponents.push(result);else{let packedComponent={...this.componentToPack,center:{x:0,y:0},ccwRotationOffset:0,pads:this.componentToPack.pads.map(p4=>({...p4,absoluteCenter:{x:0,y:0}}))};setPackedComponentPadCenters(packedComponent),this.packedComponents.push(packedComponent)}this.componentToPack=void 0,this.activeSubSolver=void 0}}}visualize(){if(this.activeSubSolver)return this.activeSubSolver.visualize();let graphics={coordinateSystem:"cartesian",title:"Pack Solver 2",points:[],lines:[],rects:[],circles:[],texts:[],arrows:[]};if(this.packInput.obstacles&&this.packInput.obstacles.length>0)for(let obstacle of this.packInput.obstacles)graphics.rects.push({center:obstacle.absoluteCenter,width:obstacle.width,height:obstacle.height,fill:"rgba(0,0,0,0.1)",stroke:"#555",label:obstacle.obstacleId});if(this.packInput.bounds&&graphics.lines.push({points:[{x:this.packInput.bounds.minX,y:this.packInput.bounds.minY},{x:this.packInput.bounds.minX,y:this.packInput.bounds.maxY},{x:this.packInput.bounds.maxX,y:this.packInput.bounds.maxY},{x:this.packInput.bounds.maxX,y:this.packInput.bounds.minY},{x:this.packInput.bounds.minX,y:this.packInput.bounds.minY}],strokeColor:"rgba(0,0,0,0.5)",strokeDash:"2 2"}),this.packInput.boundaryOutline&&this.packInput.boundaryOutline.length){let points=[...this.packInput.boundaryOutline];points.length>0&&(points[0].x!==points[points.length-1].x||points[0].y!==points[points.length-1].y)&&points.push({...points[0]}),graphics.lines.push({points,strokeColor:"rgba(0, 0, 255, 0.5)",strokeDash:"4 2"})}if(this.packedComponents.length===0)for(let component of this.unpackedComponentQueue)for(let pad2 of component.pads)graphics.rects.push({center:{x:0,y:0},width:pad2.size.x,height:pad2.size.y,fill:"rgba(0,0,0,0.1)"});let allPads=this.packedComponents.flatMap(c4=>c4.pads),networkToPadMap=new Map;for(let pad2 of allPads)pad2.networkId&&networkToPadMap.set(pad2.networkId,[...networkToPadMap.get(pad2.networkId)||[],pad2]);for(let pad2 of allPads)graphics.rects.push({center:pad2.absoluteCenter,width:pad2.size.x,height:pad2.size.y,fill:"rgba(255,0,0,0.5)"});for(let[networkId,pads]of networkToPadMap.entries())for(let i3=0;i3<pads.length;i3++)for(let j4=i3+1;j4<pads.length;j4++){let pad1=pads[i3],pad2=pads[j4];graphics.lines.push({points:[pad1.absoluteCenter,pad2.absoluteCenter],strokeColor:getColorForString(networkId,.5)})}return graphics}getOutput(){return{packedComponents:this.packedComponents,unpackedComponents:this.unpackedComponentQueue}}},pack=input2=>{let solver=new PackSolver2(input2);return solver.solve(),{...input2,components:solver.packedComponents}},getPolygonBoundingBox=points=>{if(!points||points.length===0)return{minX:0,maxX:0,minY:0,maxY:0};let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let point7 of points)minX=Math.min(minX,point7.x),maxX=Math.max(maxX,point7.x),minY=Math.min(minY,point7.y),maxY=Math.max(maxY,point7.y);return{minX,maxX,minY,maxY}},extractPadInfos=(pcbComponent,db2,getNetworkId)=>{let out=[],pushPad=({padId,pcbPortId,sx:sx3,sy:sy3,x:x4,y:y4})=>out.push({padId,networkId:getNetworkId(pcbPortId),size:{x:sx3,y:sy3},absoluteCenter:{x:x4,y:y4},pcbPortId});for(let via of db2.pcb_via.list({pcb_component_id:pcbComponent.pcb_component_id}))pushPad({padId:via.pcb_via_id,pcbPortId:via.pcb_port_id,sx:via.outer_diameter??via.hole_diameter??0,sy:via.outer_diameter??via.hole_diameter??0,x:via.x,y:via.y});for(let ph3 of db2.pcb_plated_hole.list({pcb_component_id:pcbComponent.pcb_component_id}))switch(ph3.shape){case"circle":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.outer_diameter??ph3.hole_diameter??0,sy:ph3.outer_diameter??ph3.hole_diameter??0,x:ph3.x,y:ph3.y});break}case"oval":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.outer_width,sy:ph3.outer_height,x:ph3.x,y:ph3.y});break}case"circular_hole_with_rect_pad":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.rect_pad_width,sy:ph3.rect_pad_height,x:ph3.x,y:ph3.y});break}case"pill":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.outer_width,sy:ph3.outer_height,x:ph3.x,y:ph3.y});break}case"pill_hole_with_rect_pad":{pushPad({padId:ph3.pcb_plated_hole_id,pcbPortId:ph3.pcb_port_id,sx:ph3.rect_pad_width,sy:ph3.rect_pad_height,x:ph3.x,y:ph3.y});break}default:{console.warn(`Unsupported plated hole shape ${ph3.shape}`);break}}for(let sp3 of db2.pcb_smtpad.list({pcb_component_id:pcbComponent.pcb_component_id}))switch(sp3.shape){case"rect":{pushPad({padId:sp3.pcb_smtpad_id,pcbPortId:sp3.pcb_port_id,sx:sp3.width??0,sy:sp3.height??0,x:sp3.x,y:sp3.y});break}case"circle":{pushPad({padId:sp3.pcb_smtpad_id,pcbPortId:sp3.pcb_port_id,sx:sp3.radius*2,sy:sp3.radius*2,x:sp3.x,y:sp3.y});break}case"polygon":{if(sp3.points&&sp3.points.length>0){let{minX,maxX,minY,maxY}=getPolygonBoundingBox(sp3.points),width=maxX-minX,height=maxY-minY,centerX=(minX+maxX)/2,centerY=(minY+maxY)/2;pushPad({padId:sp3.pcb_smtpad_id,pcbPortId:sp3.pcb_port_id,sx:width,sy:height,x:centerX,y:centerY})}else console.warn(`Polygon pad ${sp3.pcb_smtpad_id} has no points`);break}}return out},getElementOutsideTree=(db2,tree)=>{let componentIdsInTree=new Set,collectComponentIds=node=>{if(node){if(node.nodeType==="component"){let pcbId=node.otherChildElements?.[0]?.pcb_component_id;pcbId&&componentIdsInTree.add(pcbId)}for(let child of node.childNodes??[])collectComponentIds(child)}};collectComponentIds(tree);let outside=[];for(let ph3 of db2.pcb_plated_hole.list({})){if(!("pcb_component_id"in ph3)||!ph3.pcb_component_id){outside.push(ph3);continue}componentIdsInTree.has(ph3.pcb_component_id)||outside.push(ph3)}for(let hole of db2.pcb_hole.list({}))outside.push(hole);return outside},getObstacleFromElement=element=>{if(element.type==="pcb_plated_hole"&&element.shape==="circular_hole_with_rect_pad"){let{rect_pad_height,rect_pad_width,x:x4,y:y4}=element;return{obstacleId:element.pcb_plated_hole_id,absoluteCenter:{x:x4,y:y4},width:rect_pad_width,height:rect_pad_height}}if(element.type==="pcb_hole"){let{x:x4,y:y4,pcb_hole_id}=element,width="hole_diameter"in element?element.hole_diameter:element.hole_width,height="hole_diameter"in element?element.hole_diameter:element.hole_height;return{obstacleId:pcb_hole_id,absoluteCenter:{x:x4,y:y4},width,height}}},extractCourtyardForComponent=opts=>{let{db:db2,pcbComponentIds,componentCenter}=opts,idSet=new Set(pcbComponentIds),minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0,found=!1;for(let rect of db2.pcb_courtyard_rect.list())idSet.has(rect.pcb_component_id)&&(minX=Math.min(minX,rect.center.x-rect.width/2),maxX=Math.max(maxX,rect.center.x+rect.width/2),minY=Math.min(minY,rect.center.y-rect.height/2),maxY=Math.max(maxY,rect.center.y+rect.height/2),found=!0);for(let polygon2 of db2.pcb_courtyard_polygon.list())if(idSet.has(polygon2.pcb_component_id)){for(let pt3 of polygon2.points)minX=Math.min(minX,pt3.x),maxX=Math.max(maxX,pt3.x),minY=Math.min(minY,pt3.y),maxY=Math.max(maxY,pt3.y);found=!0}for(let outline of db2.pcb_courtyard_outline.list())if(idSet.has(outline.pcb_component_id)){for(let pt3 of outline.outline)minX=Math.min(minX,pt3.x),maxX=Math.max(maxX,pt3.x),minY=Math.min(minY,pt3.y),maxY=Math.max(maxY,pt3.y);found=!0}for(let circle2 of db2.pcb_courtyard_circle.list())idSet.has(circle2.pcb_component_id)&&(minX=Math.min(minX,circle2.center.x-circle2.radius),maxX=Math.max(maxX,circle2.center.x+circle2.radius),minY=Math.min(minY,circle2.center.y-circle2.radius),maxY=Math.max(maxY,circle2.center.y+circle2.radius),found=!0);if(!found)return;let courtyardCenterX=(minX+maxX)/2,courtyardCenterY=(minY+maxY)/2;return{offsetFromCenter:{x:courtyardCenterX-componentCenter.x,y:courtyardCenterY-componentCenter.y},width:maxX-minX,height:maxY-minY}},buildPackedComponent=(pcbComponents,componentId,db2,getNetworkId,shouldAddInnerObstacles,sourcePortToPadIds=new Map,chipMarginsMap={},isStatic=!1)=>{let padInfos=pcbComponents.flatMap(pc3=>{let pads2=extractPadInfos(pc3,db2,getNetworkId),margins=chipMarginsMap[pc3.pcb_component_id];return margins?pads2.map(p4=>({...p4,size:{x:p4.size.x+margins.left+margins.right,y:p4.size.y+margins.top+margins.bottom},absoluteCenter:{x:p4.absoluteCenter.x+(margins.right-margins.left)/2,y:p4.absoluteCenter.y+(margins.top-margins.bottom)/2}})):pads2}),minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let p4 of padInfos)minX=Math.min(minX,p4.absoluteCenter.x-p4.size.x/2),maxX=Math.max(maxX,p4.absoluteCenter.x+p4.size.x/2),minY=Math.min(minY,p4.absoluteCenter.y-p4.size.y/2),maxY=Math.max(maxY,p4.absoluteCenter.y+p4.size.y/2);let center2={x:(minX+maxX)/2,y:(minY+maxY)/2},pads=padInfos.map(p4=>({padId:p4.padId,networkId:p4.networkId,type:"rect",size:p4.size,absoluteCenter:p4.absoluteCenter,offset:{x:p4.absoluteCenter.x-center2.x,y:p4.absoluteCenter.y-center2.y}}));for(let padInfo of padInfos){if(!padInfo.pcbPortId)continue;let sourcePortId=db2.pcb_port.get(padInfo.pcbPortId)?.source_port_id;if(!sourcePortId)continue;let existingPadIds=sourcePortToPadIds.get(sourcePortId)??[];existingPadIds.push(padInfo.padId),sourcePortToPadIds.set(sourcePortId,existingPadIds)}if(shouldAddInnerObstacles){let innerPad={padId:`${componentId}-inner`,networkId:`${componentId}-inner`,type:"rect",size:{x:maxX-minX,y:maxY-minY},absoluteCenter:center2,offset:{x:0,y:0}};pads.push(innerPad)}let courtyard=extractCourtyardForComponent({db:db2,pcbComponentIds:pcbComponents.map(pc3=>pc3.pcb_component_id),componentCenter:center2});return{componentId,isStatic,center:center2,ccwRotationOffset:0,pads,courtyard}},collectPcbComponents=(node,db2)=>{if(node.nodeType==="component"){let pcbId=node.otherChildElements[0]?.pcb_component_id;return pcbId?[db2.pcb_component.get(pcbId)]:[]}return node.childNodes.flatMap(n4=>collectPcbComponents(n4,db2))},convertCircuitJsonToPackOutput=(circuitJson,opts={})=>{let packOutput={components:[],minGap:0,packOrderStrategy:"largest_to_smallest",packPlacementStrategy:"shortest_connection_along_outline",obstacles:opts.obstacles??[]},tree=getCircuitJsonTree(circuitJson,{source_group_id:opts.source_group_id}),db2=cju_default(circuitJson),unnamedCounter=0,sourcePortToPadIds=new Map,elementsOutsideTree=getElementOutsideTree(db2,tree),pcbBoard=circuitJson.find(item=>item.type==="pcb_board");pcbBoard?.outline&&(packOutput.boundaryOutline=pcbBoard.outline);let getNetworkId=pcbPortId=>{if(pcbPortId){let pcbPort=db2.pcb_port.get(pcbPortId);if(pcbPort){let sourcePort=db2.source_port.get(pcbPort.source_port_id);if(sourcePort?.subcircuit_connectivity_map_key)return sourcePort.subcircuit_connectivity_map_key}}return`unnamed${unnamedCounter++}`},topLevelNodes=tree.childNodes??[],collectRelativeToGroupAnchorComponents=node=>{let relativeComponents2=[];if(node.nodeType==="component"){let pcbComponent=node.otherChildElements.find(e5=>e5.type==="pcb_component");pcbComponent&&pcbComponent.position_mode==="relative_to_group_anchor"&&relativeComponents2.push(pcbComponent)}for(let child of node.childNodes??[])relativeComponents2.push(...collectRelativeToGroupAnchorComponents(child));return relativeComponents2},staticComponentIds=new Set(opts.staticPcbComponentIds??[]);for(let node of topLevelNodes)if(node.nodeType==="component"){let pcbComponent=node.otherChildElements.find(e5=>e5.type==="pcb_component");if(!pcbComponent||pcbComponent.position_mode==="relative_to_group_anchor")continue;let shouldAddInnerObstaclesForComp=opts.shouldAddInnerObstacles??!1;pcbComponent.obstructs_within_bounds===!0?shouldAddInnerObstaclesForComp=!0:pcbComponent.obstructs_within_bounds===!1&&(shouldAddInnerObstaclesForComp=!1),packOutput.components.push(buildPackedComponent([pcbComponent],pcbComponent.pcb_component_id,db2,getNetworkId,shouldAddInnerObstaclesForComp,sourcePortToPadIds,opts.chipMarginsMap,staticComponentIds.has(pcbComponent.pcb_component_id)))}else if(node.nodeType==="group"){let pcbComps=collectPcbComponents(node,db2);if(!pcbComps.length)continue;let compId=node.sourceGroup?.source_group_id??node.sourceGroup?.name??`group_${packOutput.components.length}`;packOutput.components.push(buildPackedComponent(pcbComps,compId,db2,getNetworkId,void 0,sourcePortToPadIds,opts.chipMarginsMap,staticComponentIds.has(compId)))}let relativeComponents=topLevelNodes.flatMap(node=>collectRelativeToGroupAnchorComponents(node));for(let pcbComponent of relativeComponents){let padInfos=extractPadInfos(pcbComponent,db2,getNetworkId);if(padInfos.length===0)continue;let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let pad2 of padInfos)minX=Math.min(minX,pad2.absoluteCenter.x-pad2.size.x/2),maxX=Math.max(maxX,pad2.absoluteCenter.x+pad2.size.x/2),minY=Math.min(minY,pad2.absoluteCenter.y-pad2.size.y/2),maxY=Math.max(maxY,pad2.absoluteCenter.y+pad2.size.y/2);let center2={x:(minX+maxX)/2,y:(minY+maxY)/2},width=maxX-minX,height=maxY-minY;packOutput.obstacles.push({obstacleId:pcbComponent.pcb_component_id,absoluteCenter:center2,width,height})}for(let element of elementsOutsideTree){let obstacle=getObstacleFromElement(element);obstacle&&packOutput.obstacles.push(obstacle)}let weightedConnections=[],seenConnections=new Set,sourceTraces=typeof db2.source_trace.list=="function"?db2.source_trace.list():circuitJson.filter(item=>item.type==="source_trace");for(let sourceTrace of sourceTraces){let connectedPorts=sourceTrace.connected_source_port_ids||[],connectedNets=sourceTrace.connected_source_net_ids||[];if(!(connectedPorts.length===2&&connectedNets.length===0))continue;let[portA,portB]=connectedPorts,padIdsA=portA?sourcePortToPadIds.get(portA)??[]:[],padIdsB=portB?sourcePortToPadIds.get(portB)??[]:[];for(let padA of padIdsA)for(let padB of padIdsB){let connectionKey=[padA,padB].sort().join("--");seenConnections.has(connectionKey)||(weightedConnections.push({padIds:[padA,padB],weight:1,ignoreWeakConnections:!0}),seenConnections.add(connectionKey))}}return weightedConnections.length>0&&(packOutput.weightedConnections=weightedConnections),packOutput},convertPackOutputToPackInput=packed=>{let strippedComponents=packed.components.map(pc3=>({...pc3.isStatic?{...pc3,pads:pc3.pads.map(pad2=>({...pad2}))}:{componentId:pc3.componentId,availableRotationDegrees:pc3.availableRotationDegrees,pads:pc3.pads.map(({absoluteCenter:_ac,...rest})=>rest),courtyard:pc3.courtyard}}));return{...packed,components:strippedComponents}};async function Module(moduleArg={}){var moduleRtn,Module2=moduleArg,ENVIRONMENT_IS_WEB=!!globalThis.window,ENVIRONMENT_IS_WORKER=!!globalThis.WorkerGlobalScope,ENVIRONMENT_IS_NODE=globalThis.process?.versions?.node&&globalThis.process?.type!="renderer";if(ENVIRONMENT_IS_NODE){let{createRequire}=await import("module");var require2=createRequire(import.meta.url)}var _ManifoldInitialized=!1;Module2.setup=function(){if(_ManifoldInitialized)return;_ManifoldInitialized=!0,Module2.initTBB();function toVec(vec,list,f3=(x4=>x4)){if(list)for(let x4 of list)vec.push_back(f3(x4));return vec}function fromVec(vec,f3=(x4=>x4)){let result=[],size3=vec.size();for(let i3=0;i3<size3;i3++)result.push(f3(vec.get(i3)));return result}function vec2polygons(vec,f3=(x4=>x4)){let result=[],nPoly=vec.size();for(let i3=0;i3<nPoly;i3++){let v4=vec.get(i3),nPts=v4.size(),poly=[];for(let j4=0;j4<nPts;j4++)poly.push(f3(v4.get(j4)));result.push(poly)}return result}function polygons2vec(polygons){return polygons[0].length<3&&(polygons=[polygons]),toVec(new Module2.Vector2_vec2,polygons,poly=>toVec(new Module2.Vector_vec2,poly,p4=>p4 instanceof Array?{x:p4[0],y:p4[1]}:p4))}function disposePolygons(polygonsVec){for(let i3=0;i3<polygonsVec.size();i3++)polygonsVec.get(i3).delete();polygonsVec.delete()}function vararg2vec2(vec){return vec[0]instanceof Array?{x:vec[0][0],y:vec[0][1]}:typeof vec[0]=="number"?{x:vec[0]||0,y:vec[1]||0}:vec[0]}function vararg2vec3(vec){return vec[0]instanceof Array?{x:vec[0][0],y:vec[0][1],z:vec[0][2]}:typeof vec[0]=="number"?{x:vec[0]||0,y:vec[1]||0,z:vec[2]||0}:vec[0]}function fillRuleToInt(fillRule){return fillRule=="EvenOdd"?0:fillRule=="NonZero"?1:fillRule=="Negative"?3:2}function joinTypeToInt(joinType){return joinType=="Round"?1:joinType=="Miter"?2:0}let CrossSectionCtor=Module2.CrossSection;function cross4(polygons,fillRule="Positive"){if(polygons instanceof CrossSectionCtor)return polygons;{let polygonsVec=polygons2vec(polygons),cs3=new CrossSectionCtor(polygonsVec,fillRuleToInt(fillRule));return disposePolygons(polygonsVec),cs3}}Module2.CrossSection.prototype.translate=function(...vec){return this._Translate(vararg2vec2(vec))},Module2.CrossSection.prototype.scale=function(vec){return typeof vec=="number"?this._Scale({x:vec,y:vec}):this._Scale(vararg2vec2([vec]))},Module2.CrossSection.prototype.mirror=function(vec){return this._Mirror(vararg2vec2([vec]))},Module2.CrossSection.prototype.warp=function(func){let wasmFuncPtr=addFunction(function(vec2Ptr){let x4=getValue(vec2Ptr,"double"),y4=getValue(vec2Ptr+8,"double"),vert=[x4,y4];func(vert),setValue(vec2Ptr,vert[0],"double"),setValue(vec2Ptr+8,vert[1],"double")},"vi"),out2=this._Warp(wasmFuncPtr);return removeFunction(wasmFuncPtr),out2},Module2.CrossSection.prototype.decompose=function(){let vec=this._Decompose(),result=fromVec(vec);return vec.delete(),result},Module2.CrossSection.prototype.bounds=function(){let result=this._Bounds();return{min:["x","y"].map(f3=>result.min[f3]),max:["x","y"].map(f3=>result.max[f3])}},Module2.CrossSection.prototype.offset=function(delta,joinType="Round",miterLimit=2,circularSegments=0){return this._Offset(delta,joinTypeToInt(joinType),miterLimit,circularSegments)},Module2.CrossSection.prototype.simplify=function(epsilon=1e-6){return this._Simplify(epsilon)},Module2.CrossSection.prototype.extrude=function(height,nDivisions=0,twistDegrees=0,scaleTop=[1,1],center2=!1){scaleTop=vararg2vec2([scaleTop]);let man=Module2._Extrude(this._ToPolygons(),height,nDivisions,twistDegrees,scaleTop);return center2?man.translate([0,0,-height/2]):man},Module2.CrossSection.prototype.revolve=function(circularSegments=0,revolveDegrees=360){return Module2._Revolve(this._ToPolygons(),circularSegments,revolveDegrees)},Module2.CrossSection.prototype.add=function(other){return this._add(cross4(other))},Module2.CrossSection.prototype.subtract=function(other){return this._subtract(cross4(other))},Module2.CrossSection.prototype.intersect=function(other){return this._intersect(cross4(other))},Module2.CrossSection.prototype.toPolygons=function(){let vec=this._ToPolygons(),result=vec2polygons(vec,v4=>[v4.x,v4.y]);return vec.delete(),result},Module2.Manifold.prototype.smoothOut=function(minSharpAngle=60,minSmoothness=0){return this._SmoothOut(minSharpAngle,minSmoothness)},Module2.Manifold.prototype.warp=function(func){let wasmFuncPtr=addFunction(function(vec3Ptr){let x4=getValue(vec3Ptr,"double"),y4=getValue(vec3Ptr+8,"double"),z4=getValue(vec3Ptr+16,"double"),vert=[x4,y4,z4];func(vert),setValue(vec3Ptr,vert[0],"double"),setValue(vec3Ptr+8,vert[1],"double"),setValue(vec3Ptr+16,vert[2],"double")},"vi"),out2=this._Warp(wasmFuncPtr);removeFunction(wasmFuncPtr);let status=out2.status();if(status!=="NoError")throw new Module2.ManifoldError(status);return out2},Module2.Manifold.prototype.calculateNormals=function(normalIdx,minSharpAngle=60){return this._CalculateNormals(normalIdx,minSharpAngle)},Module2.Manifold.prototype.setProperties=function(numProp,func){let oldNumProp=this.numProp(),wasmFuncPtr=addFunction(function(newPtr,vec3Ptr,oldPtr){let newProp=[];for(let i3=0;i3<numProp;++i3)newProp[i3]=getValue(newPtr+8*i3,"double");let pos=[];for(let i3=0;i3<3;++i3)pos[i3]=getValue(vec3Ptr+8*i3,"double");let oldProp=[];for(let i3=0;i3<oldNumProp;++i3)oldProp[i3]=getValue(oldPtr+8*i3,"double");func(newProp,pos,oldProp);for(let i3=0;i3<numProp;++i3)setValue(newPtr+8*i3,newProp[i3],"double")},"viii"),out2=this._SetProperties(numProp,wasmFuncPtr);return removeFunction(wasmFuncPtr),out2},Module2.Manifold.prototype.translate=function(...vec){return this._Translate(vararg2vec3(vec))},Module2.Manifold.prototype.rotate=function(xOrVec,y4,z4){return Array.isArray(xOrVec)?this._Rotate(...xOrVec):this._Rotate(xOrVec,y4||0,z4||0)},Module2.Manifold.prototype.scale=function(vec){return typeof vec=="number"?this._Scale({x:vec,y:vec,z:vec}):this._Scale(vararg2vec3([vec]))},Module2.Manifold.prototype.mirror=function(vec){return this._Mirror(vararg2vec3([vec]))},Module2.Manifold.prototype.trimByPlane=function(normal,offset=0){return this._TrimByPlane(vararg2vec3([normal]),offset)},Module2.Manifold.prototype.slice=function(height=0){let polygonsVec=this._Slice(height),result=new CrossSectionCtor(polygonsVec,fillRuleToInt("Positive"));return disposePolygons(polygonsVec),result},Module2.Manifold.prototype.project=function(){let polygonsVec=this._Project(),result=new CrossSectionCtor(polygonsVec,fillRuleToInt("Positive"));return disposePolygons(polygonsVec),result},Module2.Manifold.prototype.split=function(manifold){let vec=this._Split(manifold),result=fromVec(vec);return vec.delete(),result},Module2.Manifold.prototype.splitByPlane=function(normal,offset=0){let vec=this._SplitByPlane(vararg2vec3([normal]),offset),result=fromVec(vec);return vec.delete(),result},Module2.Manifold.prototype.decompose=function(){let vec=this._Decompose(),result=fromVec(vec);return vec.delete(),result},Module2.Manifold.prototype.boundingBox=function(){let result=this._boundingBox();return{min:["x","y","z"].map(f3=>result.min[f3]),max:["x","y","z"].map(f3=>result.max[f3])}},Module2.Manifold.prototype.simplify=function(tolerance=0){return this._Simplify(tolerance)};class Mesh{constructor({numProp=3,triVerts=new Uint32Array,vertProperties=new Float32Array,mergeFromVert,mergeToVert,runIndex,runOriginalID,faceID,halfedgeTangent,runTransform,tolerance=0}={}){this.numProp=numProp,this.triVerts=triVerts,this.vertProperties=vertProperties,this.mergeFromVert=mergeFromVert,this.mergeToVert=mergeToVert,this.runIndex=runIndex,this.runOriginalID=runOriginalID,this.faceID=faceID,this.halfedgeTangent=halfedgeTangent,this.runTransform=runTransform,this.tolerance=tolerance}get numTri(){return this.triVerts.length/3}get numVert(){return this.vertProperties.length/this.numProp}get numRun(){return this.runOriginalID.length}merge(){let{changed,mesh}=Module2._Merge(this);return Object.assign(this,{...mesh}),changed}verts(tri){return this.triVerts.subarray(3*tri,3*(tri+1))}position(vert){return this.vertProperties.subarray(this.numProp*vert,this.numProp*vert+3)}extras(vert){return this.vertProperties.subarray(this.numProp*vert+3,this.numProp*(vert+1))}tangent(halfedge){return this.halfedgeTangent.subarray(4*halfedge,4*(halfedge+1))}transform(run2){let mat4=new Array(16);for(let col of[0,1,2,3])for(let row of[0,1,2])mat4[4*col+row]=this.runTransform[12*run2+3*col+row];return mat4[15]=1,mat4}}Module2.Mesh=Mesh,Module2.Manifold.prototype.getMesh=function(normalIdx=-1){return new Mesh(this._GetMeshJS(normalIdx))},Module2.ManifoldError=function(code,...args){let message="Unknown error";switch(code){case"NonFiniteVertex":message="Non-finite vertex";break;case"NotManifold":message="Not manifold";break;case"VertexOutOfBounds":message="Vertex index out of bounds";break;case"PropertiesWrongLength":message="Properties have wrong length";break;case"MissingPositionProperties":message="Less than three properties";break;case"MergeVectorsDifferentLengths":message="Merge vectors have different lengths";break;case"MergeIndexOutOfBounds":message="Merge index out of bounds";break;case"TransformWrongLength":message="Transform vector has wrong length";break;case"RunIndexWrongLength":message="Run index vector has wrong length";break;case"FaceIDWrongLength":message="Face ID vector has wrong length";case"InvalidConstruction":message="Manifold constructed with invalid parameters"}let base=Error.apply(this,[message,...args]);base.name=this.name="ManifoldError",this.message=base.message,this.stack=base.stack,this.code=code},Module2.ManifoldError.prototype=Object.create(Error.prototype,{constructor:{value:Module2.ManifoldError,writable:!0,configurable:!0}}),Module2.CrossSection=function(polygons,fillRule="Positive"){let polygonsVec=polygons2vec(polygons),cs3=new CrossSectionCtor(polygonsVec,fillRuleToInt(fillRule));return disposePolygons(polygonsVec),cs3},Module2.CrossSection.ofPolygons=function(polygons,fillRule="Positive"){return new Module2.CrossSection(polygons,fillRule)},Module2.CrossSection.square=function(...args){let size3;args.length==0?size3={x:1,y:1}:typeof args[0]=="number"?size3={x:args[0],y:args[0]}:size3=vararg2vec2(args);let center2=args[1]||!1;return Module2._Square(size3,center2)},Module2.CrossSection.circle=function(radius,circularSegments=0){return Module2._Circle(radius,circularSegments)};function crossSectionBatchbool(name){return function(...args){args.length==1&&(args=args[0]);let v4=new Module2.Vector_crossSection;for(let cs3 of args)v4.push_back(cross4(cs3));let result=Module2["_crossSection"+name](v4);return v4.delete(),result}}Module2.CrossSection.compose=crossSectionBatchbool("Compose"),Module2.CrossSection.union=crossSectionBatchbool("UnionN"),Module2.CrossSection.difference=crossSectionBatchbool("DifferenceN"),Module2.CrossSection.intersection=crossSectionBatchbool("IntersectionN");function pushVec2(vec,ps3){toVec(vec,ps3,p4=>p4 instanceof Array?{x:p4[0],y:p4[1]}:p4)}Module2.CrossSection.hull=function(...args){args.length==1&&(args=args[0]);let pts=new Module2.Vector_vec2;for(let cs3 of args)if(cs3 instanceof CrossSectionCtor)Module2._crossSectionCollectVertices(pts,cs3);else if(cs3 instanceof Array&&cs3.length==2&&typeof cs3[0]=="number")pts.push_back({x:cs3[0],y:cs3[1]});else if(cs3.x)pts.push_back(cs3);else{let polys=cs3[0].length==2&&typeof cs3[0][0]=="number"||cs3[0].x?[cs3]:cs3;for(let poly of polys)pushVec2(pts,poly)}let result=Module2._crossSectionHullPoints(pts);return pts.delete(),result},Module2.CrossSection.prototype=Object.create(CrossSectionCtor.prototype),Object.defineProperty(Module2.CrossSection,Symbol.hasInstance,{get:()=>t52=>t52 instanceof CrossSectionCtor});let ManifoldCtor=Module2.Manifold;Module2.Manifold=function(mesh){let manifold=new ManifoldCtor(mesh),status=manifold.status();if(status!=="NoError")throw new Module2.ManifoldError(status);return manifold},Module2.Manifold.ofMesh=function(mesh){return new Module2.Manifold(mesh)},Module2.Manifold.tetrahedron=function(){return Module2._Tetrahedron()},Module2.Manifold.cube=function(...args){let size3;args.length==0?size3={x:1,y:1,z:1}:typeof args[0]=="number"?size3={x:args[0],y:args[0],z:args[0]}:size3=vararg2vec3(args);let center2=args[1]||!1;return Module2._Cube(size3,center2)},Module2.Manifold.cylinder=function(height,radiusLow,radiusHigh=-1,circularSegments=0,center2=!1){return Module2._Cylinder(height,radiusLow,radiusHigh,circularSegments,center2)},Module2.Manifold.sphere=function(radius,circularSegments=0){return Module2._Sphere(radius,circularSegments)},Module2.Manifold.smooth=function(mesh,sharpenedEdges=[]){let sharp=new Module2.Vector_smoothness;toVec(sharp,sharpenedEdges);let result=Module2._Smooth(mesh,sharp);return sharp.delete(),result},Module2.Manifold.extrude=function(polygons,height,nDivisions=0,twistDegrees=0,scaleTop=[1,1],center2=!1){return(polygons instanceof CrossSectionCtor?polygons:Module2.CrossSection(polygons,"Positive")).extrude(height,nDivisions,twistDegrees,scaleTop,center2)},Module2.Manifold.revolve=function(polygons,circularSegments=0,revolveDegrees=360){return(polygons instanceof CrossSectionCtor?polygons:Module2.CrossSection(polygons,"Positive")).revolve(circularSegments,revolveDegrees)},Module2.Manifold.reserveIDs=function(n4){return Module2._ReserveIDs(n4)};function manifoldBatchbool(name){return function(...args){args.length==1&&(args=args[0]);let v4=new Module2.Vector_manifold;for(let m4 of args)v4.push_back(m4);let result=Module2["_manifold"+name+"N"](v4);return v4.delete(),result}}Module2.Manifold.union=manifoldBatchbool("Union"),Module2.Manifold.compose=Module2.Manifold.union,Module2.Manifold.difference=manifoldBatchbool("Difference"),Module2.Manifold.intersection=manifoldBatchbool("Intersection"),Module2.Manifold.levelSet=function(sdf,bounds,edgeLength,level=0,tolerance=-1){let bounds2={min:{x:bounds.min[0],y:bounds.min[1],z:bounds.min[2]},max:{x:bounds.max[0],y:bounds.max[1],z:bounds.max[2]}},wasmFuncPtr=addFunction(function(vec3Ptr){let x4=getValue(vec3Ptr,"double"),y4=getValue(vec3Ptr+8,"double"),z4=getValue(vec3Ptr+16,"double");return sdf([x4,y4,z4])},"di"),out2=Module2._LevelSet(wasmFuncPtr,bounds2,edgeLength,level,tolerance);return removeFunction(wasmFuncPtr),out2};function pushVec3(vec,ps3){toVec(vec,ps3,p4=>p4 instanceof Array?{x:p4[0],y:p4[1],z:p4[2]}:p4)}Module2.Manifold.hull=function(...args){args.length==1&&(args=args[0]);let pts=new Module2.Vector_vec3;for(let m4 of args)m4 instanceof ManifoldCtor?Module2._manifoldCollectVertices(pts,m4):m4 instanceof Array&&m4.length==3&&typeof m4[0]=="number"?pts.push_back({x:m4[0],y:m4[1],z:m4[2]}):m4.x?pts.push_back(m4):pushVec3(pts,m4);let result=Module2._manifoldHullPoints(pts);return pts.delete(),result},Module2.Manifold.prototype=Object.create(ManifoldCtor.prototype),Object.defineProperty(Module2.Manifold,Symbol.hasInstance,{get:()=>t52=>t52 instanceof ManifoldCtor}),Module2.triangulate=function(polygons,epsilon=-1,allowConvex=!0){let polygonsVec=polygons2vec(polygons),result=fromVec(Module2._Triangulate(polygonsVec,epsilon,allowConvex),x4=>[x4[0],x4[1],x4[2]]);return disposePolygons(polygonsVec),result}};var arguments_=[],thisProgram="./this.program",quit_=(status,toThrow)=>{throw toThrow},_scriptName=import.meta.url,scriptDirectory="";function locateFile(path){return Module2.locateFile?Module2.locateFile(path,scriptDirectory):scriptDirectory+path}var readAsync,readBinary;if(ENVIRONMENT_IS_NODE){var fs3=require2("node:fs");_scriptName.startsWith("file:")&&(scriptDirectory=require2("node:path").dirname(require2("node:url").fileURLToPath(_scriptName))+"/"),readBinary=filename=>{filename=isFileURI(filename)?new URL(filename):filename;var ret=fs3.readFileSync(filename);return ret},readAsync=async(filename,binary=!0)=>{filename=isFileURI(filename)?new URL(filename):filename;var ret=fs3.readFileSync(filename,binary?void 0:"utf8");return ret},process.argv.length>1&&(thisProgram=process.argv[1].replace(/\\/g,"/")),arguments_=process.argv.slice(2),quit_=(status,toThrow)=>{throw process.exitCode=status,toThrow}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){try{scriptDirectory=new URL(".",_scriptName).href}catch{}ENVIRONMENT_IS_WORKER&&(readBinary=url2=>{var xhr=new XMLHttpRequest;return xhr.open("GET",url2,!1),xhr.responseType="arraybuffer",xhr.send(null),new Uint8Array(xhr.response)}),readAsync=async url2=>{if(isFileURI(url2))return new Promise((resolve,reject)=>{var xhr=new XMLHttpRequest;xhr.open("GET",url2,!0),xhr.responseType="arraybuffer",xhr.onload=()=>{if(xhr.status==200||xhr.status==0&&xhr.response){resolve(xhr.response);return}reject(xhr.status)},xhr.onerror=reject,xhr.send(null)});var response=await fetch(url2,{credentials:"same-origin"});if(response.ok)return response.arrayBuffer();throw new Error(response.status+" : "+response.url)}}var out=console.log.bind(console),err=console.error.bind(console),wasmBinary,ABORT=!1,isFileURI=filename=>filename.startsWith("file://"),readyPromiseResolve,readyPromiseReject,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64,HEAP64,HEAPU64,runtimeInitialized=!1;function updateMemoryViews(){var b3=wasmMemory.buffer;HEAP8=new Int8Array(b3),HEAP16=new Int16Array(b3),HEAPU8=new Uint8Array(b3),HEAPU16=new Uint16Array(b3),HEAP32=new Int32Array(b3),HEAPU32=new Uint32Array(b3),HEAPF32=new Float32Array(b3),HEAPF64=new Float64Array(b3),HEAP64=new BigInt64Array(b3),HEAPU64=new BigUint64Array(b3)}function preRun(){if(Module2.preRun)for(typeof Module2.preRun=="function"&&(Module2.preRun=[Module2.preRun]);Module2.preRun.length;)addOnPreRun(Module2.preRun.shift());callRuntimeCallbacks(onPreRuns)}function initRuntime(){runtimeInitialized=!0,wasmExports.J()}function postRun(){if(Module2.postRun)for(typeof Module2.postRun=="function"&&(Module2.postRun=[Module2.postRun]);Module2.postRun.length;)addOnPostRun(Module2.postRun.shift());callRuntimeCallbacks(onPostRuns)}function abort(what){Module2.onAbort?.(what),what="Aborted("+what+")",err(what),ABORT=!0,what+=". Build with -sASSERTIONS for more info.";var e5=new WebAssembly.RuntimeError(what);throw readyPromiseReject?.(e5),e5}var wasmBinaryFile;function findWasmBinary(){return Module2.locateFile?locateFile("manifold.wasm"):new URL("manifold.wasm",import.meta.url).href}function getBinarySync(file){if(file==wasmBinaryFile&&wasmBinary)return new Uint8Array(wasmBinary);if(readBinary)return readBinary(file);throw"both async and sync fetching of the wasm failed"}async function getWasmBinary(binaryFile){if(!wasmBinary)try{var response=await readAsync(binaryFile);return new Uint8Array(response)}catch{}return getBinarySync(binaryFile)}async function instantiateArrayBuffer(binaryFile,imports){try{var binary=await getWasmBinary(binaryFile),instance=await WebAssembly.instantiate(binary,imports);return instance}catch(reason){err(`failed to asynchronously prepare wasm: ${reason}`),abort(reason)}}async function instantiateAsync(binary,binaryFile,imports){if(!binary&&!isFileURI(binaryFile)&&!ENVIRONMENT_IS_NODE)try{var response=fetch(binaryFile,{credentials:"same-origin"}),instantiationResult=await WebAssembly.instantiateStreaming(response,imports);return instantiationResult}catch(reason){err(`wasm streaming compile failed: ${reason}`),err("falling back to ArrayBuffer instantiation")}return instantiateArrayBuffer(binaryFile,imports)}function getWasmImports(){var imports={a:wasmImports};return imports}async function createWasm(){function receiveInstance(instance,module){return wasmExports=instance.exports,wasmExports=applySignatureConversions(wasmExports),assignWasmExports(wasmExports),updateMemoryViews(),wasmExports}function receiveInstantiationResult(result2){return receiveInstance(result2.instance)}var info=getWasmImports();if(Module2.instantiateWasm)return new Promise((resolve,reject)=>{Module2.instantiateWasm(info,(inst,mod)=>{resolve(receiveInstance(inst,mod))})});wasmBinaryFile??(wasmBinaryFile=findWasmBinary());var result=await instantiateAsync(wasmBinary,wasmBinaryFile,info),exports=receiveInstantiationResult(result);return exports}class ExitStatus{constructor(status){__publicField(this,"name","ExitStatus");this.message=`Program terminated with exit(${status})`,this.status=status}}var callRuntimeCallbacks=callbacks=>{for(;callbacks.length>0;)callbacks.shift()(Module2)},onPostRuns=[],addOnPostRun=cb3=>onPostRuns.push(cb3),onPreRuns=[],addOnPreRun=cb3=>onPreRuns.push(cb3);function getValue(ptr,type="i8"){switch(type.endsWith("*")&&(type="*"),type){case"i1":return HEAP8[ptr>>>0];case"i8":return HEAP8[ptr>>>0];case"i16":return HEAP16[ptr>>>1>>>0];case"i32":return HEAP32[ptr>>>2>>>0];case"i64":return HEAP64[ptr>>>3>>>0];case"float":return HEAPF32[ptr>>>2>>>0];case"double":return HEAPF64[ptr>>>3>>>0];case"*":return HEAPU32[ptr>>>2>>>0];default:abort(`invalid type for getValue: ${type}`)}}var noExitRuntime=!0;function setValue(ptr,value,type="i8"){switch(type.endsWith("*")&&(type="*"),type){case"i1":HEAP8[ptr>>>0]=value;break;case"i8":HEAP8[ptr>>>0]=value;break;case"i16":HEAP16[ptr>>>1>>>0]=value;break;case"i32":HEAP32[ptr>>>2>>>0]=value;break;case"i64":HEAP64[ptr>>>3>>>0]=BigInt(value);break;case"float":HEAPF32[ptr>>>2>>>0]=value;break;case"double":HEAPF64[ptr>>>3>>>0]=value;break;case"*":HEAPU32[ptr>>>2>>>0]=value;break;default:abort(`invalid type for setValue: ${type}`)}}class ExceptionInfo{constructor(excPtr){this.excPtr=excPtr,this.ptr=excPtr-24}set_type(type){HEAPU32[this.ptr+4>>>2>>>0]=type}get_type(){return HEAPU32[this.ptr+4>>>2>>>0]}set_destructor(destructor){HEAPU32[this.ptr+8>>>2>>>0]=destructor}get_destructor(){return HEAPU32[this.ptr+8>>>2>>>0]}set_caught(caught){caught=caught?1:0,HEAP8[this.ptr+12>>>0]=caught}get_caught(){return HEAP8[this.ptr+12>>>0]!=0}set_rethrown(rethrown){rethrown=rethrown?1:0,HEAP8[this.ptr+13>>>0]=rethrown}get_rethrown(){return HEAP8[this.ptr+13>>>0]!=0}init(type,destructor){this.set_adjusted_ptr(0),this.set_type(type),this.set_destructor(destructor)}set_adjusted_ptr(adjustedPtr){HEAPU32[this.ptr+16>>>2>>>0]=adjustedPtr}get_adjusted_ptr(){return HEAPU32[this.ptr+16>>>2>>>0]}}var exceptionLast=0,uncaughtExceptionCount=0;function ___cxa_throw(ptr,type,destructor){ptr>>>=0,type>>>=0,destructor>>>=0;var info=new ExceptionInfo(ptr);throw info.init(type,destructor),exceptionLast=ptr,uncaughtExceptionCount++,exceptionLast}var __abort_js=()=>abort(""),structRegistrations={},runDestructors=destructors=>{for(;destructors.length;){var ptr=destructors.pop(),del=destructors.pop();del(ptr)}};function readPointer(pointer){return this.fromWireType(HEAPU32[pointer>>>2>>>0])}var awaitingDependencies={},registeredTypes={},typeDependencies={},InternalError=class extends Error{constructor(message){super(message),this.name="InternalError"}},throwInternalError=message=>{throw new InternalError(message)},whenDependentTypesAreResolved=(myTypes,dependentTypes,getTypeConverters)=>{myTypes.forEach(type=>typeDependencies[type]=dependentTypes);function onComplete(typeConverters2){var myTypeConverters=getTypeConverters(typeConverters2);myTypeConverters.length!==myTypes.length&&throwInternalError("Mismatched type converter count");for(var i3=0;i3<myTypes.length;++i3)registerType(myTypes[i3],myTypeConverters[i3])}var typeConverters=new Array(dependentTypes.length),unregisteredTypes=[],registered=0;for(let[i3,dt3]of dependentTypes.entries())registeredTypes.hasOwnProperty(dt3)?typeConverters[i3]=registeredTypes[dt3]:(unregisteredTypes.push(dt3),awaitingDependencies.hasOwnProperty(dt3)||(awaitingDependencies[dt3]=[]),awaitingDependencies[dt3].push(()=>{typeConverters[i3]=registeredTypes[dt3],++registered,registered===unregisteredTypes.length&&onComplete(typeConverters)}));unregisteredTypes.length===0&&onComplete(typeConverters)},__embind_finalize_value_object=function(structType){structType>>>=0;var reg=structRegistrations[structType];delete structRegistrations[structType];var rawConstructor=reg.rawConstructor,rawDestructor=reg.rawDestructor,fieldRecords=reg.fields,fieldTypes=fieldRecords.map(field=>field.getterReturnType).concat(fieldRecords.map(field=>field.setterArgumentType));whenDependentTypesAreResolved([structType],fieldTypes,fieldTypes2=>{var fields={};for(var[i3,field]of fieldRecords.entries()){let getterReturnType=fieldTypes2[i3],getter=field.getter,getterContext=field.getterContext,setterArgumentType=fieldTypes2[i3+fieldRecords.length],setter=field.setter,setterContext=field.setterContext;fields[field.fieldName]={read:ptr=>getterReturnType.fromWireType(getter(getterContext,ptr)),write:(ptr,o4)=>{var destructors=[];setter(setterContext,ptr,setterArgumentType.toWireType(destructors,o4)),runDestructors(destructors)},optional:getterReturnType.optional}}return[{name:reg.name,fromWireType:ptr=>{var rv2={};for(var i4 in fields)rv2[i4]=fields[i4].read(ptr);return rawDestructor(ptr),rv2},toWireType:(destructors,o4)=>{for(var fieldName in fields)if(!(fieldName in o4)&&!fields[fieldName].optional)throw new TypeError(`Missing field: "${fieldName}"`);var ptr=rawConstructor();for(fieldName in fields)fields[fieldName].write(ptr,o4[fieldName]);return destructors!==null&&destructors.push(rawDestructor,ptr),ptr},readValueFromPointer:readPointer,destructorFunction:rawDestructor}]})},AsciiToString=ptr=>{ptr>>>=0;for(var str="";;){var ch3=HEAPU8[ptr++>>>0];if(!ch3)return str;str+=String.fromCharCode(ch3)}},BindingError=class extends Error{constructor(message){super(message),this.name="BindingError"}},throwBindingError=message=>{throw new BindingError(message)};function sharedRegisterType(rawType,registeredInstance,options={}){var name=registeredInstance.name;if(rawType||throwBindingError(`type "${name}" must have a positive integer typeid pointer`),registeredTypes.hasOwnProperty(rawType)){if(options.ignoreDuplicateRegistrations)return;throwBindingError(`Cannot register type '${name}' twice`)}if(registeredTypes[rawType]=registeredInstance,delete typeDependencies[rawType],awaitingDependencies.hasOwnProperty(rawType)){var callbacks=awaitingDependencies[rawType];delete awaitingDependencies[rawType],callbacks.forEach(cb3=>cb3())}}function registerType(rawType,registeredInstance,options={}){return sharedRegisterType(rawType,registeredInstance,options)}var integerReadValueFromPointer=(name,width,signed)=>{switch(width){case 1:return signed?pointer=>HEAP8[pointer>>>0]:pointer=>HEAPU8[pointer>>>0];case 2:return signed?pointer=>HEAP16[pointer>>>1>>>0]:pointer=>HEAPU16[pointer>>>1>>>0];case 4:return signed?pointer=>HEAP32[pointer>>>2>>>0]:pointer=>HEAPU32[pointer>>>2>>>0];case 8:return signed?pointer=>HEAP64[pointer>>>3>>>0]:pointer=>HEAPU64[pointer>>>3>>>0];default:throw new TypeError(`invalid integer width (${width}): ${name}`)}},__embind_register_bigint=function(primitiveType,name,size3,minRange,maxRange){primitiveType>>>=0,name>>>=0,size3>>>=0,name=AsciiToString(name);let isUnsignedType=minRange===0n,fromWireType=value=>value;if(isUnsignedType){let bitSize=size3*8;fromWireType=value=>BigInt.asUintN(bitSize,value),maxRange=fromWireType(maxRange)}registerType(primitiveType,{name,fromWireType,toWireType:(destructors,value)=>(typeof value=="number"&&(value=BigInt(value)),value),readValueFromPointer:integerReadValueFromPointer(name,size3,!isUnsignedType),destructorFunction:null})};function __embind_register_bool(rawType,name,trueValue,falseValue){rawType>>>=0,name>>>=0,name=AsciiToString(name),registerType(rawType,{name,fromWireType:function(wt3){return!!wt3},toWireType:function(destructors,o4){return o4?trueValue:falseValue},readValueFromPointer:function(pointer){return this.fromWireType(HEAPU8[pointer>>>0])},destructorFunction:null})}var shallowCopyInternalPointer=o4=>({count:o4.count,deleteScheduled:o4.deleteScheduled,preservePointerOnDelete:o4.preservePointerOnDelete,ptr:o4.ptr,ptrType:o4.ptrType,smartPtr:o4.smartPtr,smartPtrType:o4.smartPtrType}),throwInstanceAlreadyDeleted=obj=>{function getInstanceTypeName(handle){return handle.$$.ptrType.registeredClass.name}throwBindingError(getInstanceTypeName(obj)+" instance already deleted")},finalizationRegistry=!1,detachFinalizer=handle=>{},runDestructor=$$=>{$$.smartPtr?$$.smartPtrType.rawDestructor($$.smartPtr):$$.ptrType.registeredClass.rawDestructor($$.ptr)},releaseClassHandle=$$=>{$$.count.value-=1;var toDelete=$$.count.value===0;toDelete&&runDestructor($$)},attachFinalizer=handle=>globalThis.FinalizationRegistry?(finalizationRegistry=new FinalizationRegistry(info=>{releaseClassHandle(info.$$)}),attachFinalizer=handle2=>{var $$=handle2.$$,hasSmartPtr=!!$$.smartPtr;if(hasSmartPtr){var info={$$};finalizationRegistry.register(handle2,info,handle2)}return handle2},detachFinalizer=handle2=>finalizationRegistry.unregister(handle2),attachFinalizer(handle)):(attachFinalizer=handle2=>handle2,handle),deletionQueue=[],flushPendingDeletes=()=>{for(;deletionQueue.length;){var obj=deletionQueue.pop();obj.$$.deleteScheduled=!1,obj.delete()}},delayFunction,init_ClassHandle=()=>{let proto=ClassHandle.prototype;Object.assign(proto,{isAliasOf(other){if(!(this instanceof ClassHandle)||!(other instanceof ClassHandle))return!1;var leftClass=this.$$.ptrType.registeredClass,left=this.$$.ptr;other.$$=other.$$;for(var rightClass=other.$$.ptrType.registeredClass,right=other.$$.ptr;leftClass.baseClass;)left=leftClass.upcast(left),leftClass=leftClass.baseClass;for(;rightClass.baseClass;)right=rightClass.upcast(right),rightClass=rightClass.baseClass;return leftClass===rightClass&&left===right},clone(){if(this.$$.ptr||throwInstanceAlreadyDeleted(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var clone=attachFinalizer(Object.create(Object.getPrototypeOf(this),{$$:{value:shallowCopyInternalPointer(this.$$)}}));return clone.$$.count.value+=1,clone.$$.deleteScheduled=!1,clone},delete(){this.$$.ptr||throwInstanceAlreadyDeleted(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&throwBindingError("Object already scheduled for deletion"),detachFinalizer(this),releaseClassHandle(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)},isDeleted(){return!this.$$.ptr},deleteLater(){return this.$$.ptr||throwInstanceAlreadyDeleted(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&throwBindingError("Object already scheduled for deletion"),deletionQueue.push(this),deletionQueue.length===1&&delayFunction&&delayFunction(flushPendingDeletes),this.$$.deleteScheduled=!0,this}});let symbolDispose=Symbol.dispose;symbolDispose&&(proto[symbolDispose]=proto.delete)};function ClassHandle(){}var createNamedFunction=(name,func)=>Object.defineProperty(func,"name",{value:name}),registeredPointers={},ensureOverloadTable=(proto,methodName,humanName)=>{if(proto[methodName].overloadTable===void 0){var prevFunc=proto[methodName];proto[methodName]=function(...args){return proto[methodName].overloadTable.hasOwnProperty(args.length)||throwBindingError(`Function '${humanName}' called with an invalid number of arguments (${args.length}) - expects one of (${proto[methodName].overloadTable})!`),proto[methodName].overloadTable[args.length].apply(this,args)},proto[methodName].overloadTable=[],proto[methodName].overloadTable[prevFunc.argCount]=prevFunc}},exposePublicSymbol=(name,value,numArguments)=>{Module2.hasOwnProperty(name)?((numArguments===void 0||Module2[name].overloadTable!==void 0&&Module2[name].overloadTable[numArguments]!==void 0)&&throwBindingError(`Cannot register public name '${name}' twice`),ensureOverloadTable(Module2,name,name),Module2[name].overloadTable.hasOwnProperty(numArguments)&&throwBindingError(`Cannot register multiple overloads of a function with the same number of arguments (${numArguments})!`),Module2[name].overloadTable[numArguments]=value):(Module2[name]=value,Module2[name].argCount=numArguments)},char_0=48,char_9=57,makeLegalFunctionName=name=>{name=name.replace(/[^a-zA-Z0-9_]/g,"$");var f3=name.charCodeAt(0);return f3>=char_0&&f3<=char_9?`_${name}`:name};function RegisteredClass(name,constructor,instancePrototype,rawDestructor,baseClass,getActualType,upcast,downcast){this.name=name,this.constructor=constructor,this.instancePrototype=instancePrototype,this.rawDestructor=rawDestructor,this.baseClass=baseClass,this.getActualType=getActualType,this.upcast=upcast,this.downcast=downcast,this.pureVirtualFunctions=[]}var upcastPointer=(ptr,ptrClass,desiredClass)=>{for(;ptrClass!==desiredClass;)ptrClass.upcast||throwBindingError(`Expected null or instance of ${desiredClass.name}, got an instance of ${ptrClass.name}`),ptr=ptrClass.upcast(ptr),ptrClass=ptrClass.baseClass;return ptr},embindRepr=v4=>{if(v4===null)return"null";var t52=typeof v4;return t52==="object"||t52==="array"||t52==="function"?v4.toString():""+v4};function constNoSmartPtrRawPointerToWireType(destructors,handle){if(handle===null)return this.isReference&&throwBindingError(`null is not a valid ${this.name}`),0;handle.$$||throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`),handle.$$.ptr||throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);var handleClass=handle.$$.ptrType.registeredClass,ptr=upcastPointer(handle.$$.ptr,handleClass,this.registeredClass);return ptr}function genericPointerToWireType(destructors,handle){var ptr;if(handle===null)return this.isReference&&throwBindingError(`null is not a valid ${this.name}`),this.isSmartPointer?(ptr=this.rawConstructor(),destructors!==null&&destructors.push(this.rawDestructor,ptr),ptr):0;(!handle||!handle.$$)&&throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`),handle.$$.ptr||throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&handle.$$.ptrType.isConst&&throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType?handle.$$.smartPtrType.name:handle.$$.ptrType.name} to parameter type ${this.name}`);var handleClass=handle.$$.ptrType.registeredClass;if(ptr=upcastPointer(handle.$$.ptr,handleClass,this.registeredClass),this.isSmartPointer)switch(handle.$$.smartPtr===void 0&&throwBindingError("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:handle.$$.smartPtrType===this?ptr=handle.$$.smartPtr:throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType?handle.$$.smartPtrType.name:handle.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:ptr=handle.$$.smartPtr;break;case 2:if(handle.$$.smartPtrType===this)ptr=handle.$$.smartPtr;else{var clonedHandle=handle.clone();ptr=this.rawShare(ptr,Emval.toHandle(()=>clonedHandle.delete())),destructors!==null&&destructors.push(this.rawDestructor,ptr)}break;default:throwBindingError("Unsupported sharing policy")}return ptr}function nonConstNoSmartPtrRawPointerToWireType(destructors,handle){if(handle===null)return this.isReference&&throwBindingError(`null is not a valid ${this.name}`),0;handle.$$||throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`),handle.$$.ptr||throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`),handle.$$.ptrType.isConst&&throwBindingError(`Cannot convert argument of type ${handle.$$.ptrType.name} to parameter type ${this.name}`);var handleClass=handle.$$.ptrType.registeredClass,ptr=upcastPointer(handle.$$.ptr,handleClass,this.registeredClass);return ptr}var downcastPointer=(ptr,ptrClass,desiredClass)=>{if(ptrClass===desiredClass)return ptr;if(desiredClass.baseClass===void 0)return null;var rv2=downcastPointer(ptr,ptrClass,desiredClass.baseClass);return rv2===null?null:desiredClass.downcast(rv2)},registeredInstances={},getBasestPointer=(class_,ptr)=>{for(ptr===void 0&&throwBindingError("ptr should not be undefined");class_.baseClass;)ptr=class_.upcast(ptr),class_=class_.baseClass;return ptr},getInheritedInstance=(class_,ptr)=>(ptr=getBasestPointer(class_,ptr),registeredInstances[ptr]),makeClassHandle=(prototype,record)=>{(!record.ptrType||!record.ptr)&&throwInternalError("makeClassHandle requires ptr and ptrType");var hasSmartPtrType=!!record.smartPtrType,hasSmartPtr=!!record.smartPtr;return hasSmartPtrType!==hasSmartPtr&&throwInternalError("Both smartPtrType and smartPtr must be specified"),record.count={value:1},attachFinalizer(Object.create(prototype,{$$:{value:record,writable:!0}}))};function RegisteredPointer_fromWireType(ptr){var rawPointer=this.getPointee(ptr);if(!rawPointer)return this.destructor(ptr),null;var registeredInstance=getInheritedInstance(this.registeredClass,rawPointer);if(registeredInstance!==void 0){if(registeredInstance.$$.count.value===0)return registeredInstance.$$.ptr=rawPointer,registeredInstance.$$.smartPtr=ptr,registeredInstance.clone();var rv2=registeredInstance.clone();return this.destructor(ptr),rv2}function makeDefaultHandle(){return this.isSmartPointer?makeClassHandle(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:rawPointer,smartPtrType:this,smartPtr:ptr}):makeClassHandle(this.registeredClass.instancePrototype,{ptrType:this,ptr})}var actualType=this.registeredClass.getActualType(rawPointer),registeredPointerRecord=registeredPointers[actualType];if(!registeredPointerRecord)return makeDefaultHandle.call(this);var toType;this.isConst?toType=registeredPointerRecord.constPointerType:toType=registeredPointerRecord.pointerType;var dp3=downcastPointer(rawPointer,this.registeredClass,toType.registeredClass);return dp3===null?makeDefaultHandle.call(this):this.isSmartPointer?makeClassHandle(toType.registeredClass.instancePrototype,{ptrType:toType,ptr:dp3,smartPtrType:this,smartPtr:ptr}):makeClassHandle(toType.registeredClass.instancePrototype,{ptrType:toType,ptr:dp3})}var init_RegisteredPointer=()=>{Object.assign(RegisteredPointer.prototype,{getPointee(ptr){return this.rawGetPointee&&(ptr=this.rawGetPointee(ptr)),ptr},destructor(ptr){this.rawDestructor?.(ptr)},readValueFromPointer:readPointer,fromWireType:RegisteredPointer_fromWireType})};function RegisteredPointer(name,registeredClass,isReference,isConst,isSmartPointer,pointeeType,sharingPolicy,rawGetPointee,rawConstructor,rawShare,rawDestructor){this.name=name,this.registeredClass=registeredClass,this.isReference=isReference,this.isConst=isConst,this.isSmartPointer=isSmartPointer,this.pointeeType=pointeeType,this.sharingPolicy=sharingPolicy,this.rawGetPointee=rawGetPointee,this.rawConstructor=rawConstructor,this.rawShare=rawShare,this.rawDestructor=rawDestructor,!isSmartPointer&&registeredClass.baseClass===void 0?isConst?(this.toWireType=constNoSmartPtrRawPointerToWireType,this.destructorFunction=null):(this.toWireType=nonConstNoSmartPtrRawPointerToWireType,this.destructorFunction=null):this.toWireType=genericPointerToWireType}var replacePublicSymbol=(name,value,numArguments)=>{Module2.hasOwnProperty(name)||throwInternalError("Replacing nonexistent public symbol"),Module2[name].overloadTable!==void 0&&numArguments!==void 0?Module2[name].overloadTable[numArguments]=value:(Module2[name]=value,Module2[name].argCount=numArguments)},getWasmTableEntry=funcPtr=>wasmTable.get(funcPtr),dynCall=(sig,ptr,args=[],promising=!1)=>{var func=getWasmTableEntry(ptr),rtn=func(...args);function convert(rtn2){return sig[0]=="p"?rtn2>>>0:rtn2}return convert(rtn)},getDynCaller=(sig,ptr,promising=!1)=>(...args)=>dynCall(sig,ptr,args,promising),embind__requireFunction=(signature,rawFunction,isAsync3=!1)=>{signature=AsciiToString(signature);function makeDynCaller(){if(signature.includes("p"))return getDynCaller(signature,rawFunction,isAsync3);var rtn=getWasmTableEntry(rawFunction);return rtn}var fp3=makeDynCaller();return typeof fp3!="function"&&throwBindingError(`unknown function pointer with signature ${signature}: ${rawFunction}`),fp3};class UnboundTypeError extends Error{}var getTypeName=type=>{var ptr=___getTypeName(type),rv2=AsciiToString(ptr);return _free(ptr),rv2},throwUnboundTypeError=(message,types)=>{var unboundTypes=[],seen={};function visit(type){if(!seen[type]&&!registeredTypes[type]){if(typeDependencies[type]){typeDependencies[type].forEach(visit);return}unboundTypes.push(type),seen[type]=!0}}throw types.forEach(visit),new UnboundTypeError(`${message}: `+unboundTypes.map(getTypeName).join([", "]))};function __embind_register_class(rawType,rawPointerType,rawConstPointerType,baseClassRawType,getActualTypeSignature,getActualType,upcastSignature,upcast,downcastSignature,downcast,name,destructorSignature,rawDestructor){rawType>>>=0,rawPointerType>>>=0,rawConstPointerType>>>=0,baseClassRawType>>>=0,getActualTypeSignature>>>=0,getActualType>>>=0,upcastSignature>>>=0,upcast>>>=0,downcastSignature>>>=0,downcast>>>=0,name>>>=0,destructorSignature>>>=0,rawDestructor>>>=0,name=AsciiToString(name),getActualType=embind__requireFunction(getActualTypeSignature,getActualType),upcast&&(upcast=embind__requireFunction(upcastSignature,upcast)),downcast&&(downcast=embind__requireFunction(downcastSignature,downcast)),rawDestructor=embind__requireFunction(destructorSignature,rawDestructor);var legalFunctionName=makeLegalFunctionName(name);exposePublicSymbol(legalFunctionName,function(){throwUnboundTypeError(`Cannot construct ${name} due to unbound types`,[baseClassRawType])}),whenDependentTypesAreResolved([rawType,rawPointerType,rawConstPointerType],baseClassRawType?[baseClassRawType]:[],base=>{var _a362;base=base[0];var baseClass,basePrototype;baseClassRawType?(baseClass=base.registeredClass,basePrototype=baseClass.instancePrototype):basePrototype=ClassHandle.prototype;var constructor=createNamedFunction(name,function(...args){if(Object.getPrototypeOf(this)!==instancePrototype)throw new BindingError(`Use 'new' to construct ${name}`);if(registeredClass.constructor_body===void 0)throw new BindingError(`${name} has no accessible constructor`);var body=registeredClass.constructor_body[args.length];if(body===void 0)throw new BindingError(`Tried to invoke ctor of ${name} with invalid number of parameters (${args.length}) - expected (${Object.keys(registeredClass.constructor_body).toString()}) parameters instead!`);return body.apply(this,args)}),instancePrototype=Object.create(basePrototype,{constructor:{value:constructor}});constructor.prototype=instancePrototype;var registeredClass=new RegisteredClass(name,constructor,instancePrototype,rawDestructor,baseClass,getActualType,upcast,downcast);registeredClass.baseClass&&((_a362=registeredClass.baseClass).__derivedClasses??(_a362.__derivedClasses=[]),registeredClass.baseClass.__derivedClasses.push(registeredClass));var referenceConverter=new RegisteredPointer(name,registeredClass,!0,!1,!1),pointerConverter=new RegisteredPointer(name+"*",registeredClass,!1,!1,!1),constPointerConverter=new RegisteredPointer(name+" const*",registeredClass,!1,!0,!1);return registeredPointers[rawType]={pointerType:pointerConverter,constPointerType:constPointerConverter},replacePublicSymbol(legalFunctionName,constructor),[referenceConverter,pointerConverter,constPointerConverter]})}var heap32VectorToArray=(count,firstElement)=>{for(var array2=[],i3=0;i3<count;i3++)array2.push(HEAPU32[firstElement+i3*4>>>2>>>0]);return array2};function usesDestructorStack(argTypes){for(var i3=1;i3<argTypes.length;++i3)if(argTypes[i3]!==null&&argTypes[i3].destructorFunction===void 0)return!0;return!1}function createJsInvoker(argTypes,isClassMethodFunc,returns,isAsync3){var needsDestructorStack=usesDestructorStack(argTypes),argCount=argTypes.length-2,argsList=[],argsListWired=["fn"];isClassMethodFunc&&argsListWired.push("thisWired");for(var i3=0;i3<argCount;++i3)argsList.push(`arg${i3}`),argsListWired.push(`arg${i3}Wired`);argsList=argsList.join(","),argsListWired=argsListWired.join(",");var invokerFnBody=`return function (${argsList}) {
631
631
  `;needsDestructorStack&&(invokerFnBody+=`var destructors = [];
632
632
  `);var dtorStack=needsDestructorStack?"destructors":"null",args1=["humanName","throwBindingError","invoker","fn","runDestructors","fromRetWire","toClassParamWire"];isClassMethodFunc&&(invokerFnBody+=`var thisWired = toClassParamWire(${dtorStack}, this);
633
633
  `);for(var i3=0;i3<argCount;++i3){var argName=`toArg${i3}Wire`;invokerFnBody+=`var arg${i3}Wired = ${argName}(${dtorStack}, arg${i3});
@@ -688,7 +688,7 @@ ${err.message}`):err}}let nNodes=ckt.nodes.count()-1;for(let i3=0;i3<ckt.V.lengt
688
688
  ${error2.stack}`),asyncEffect.complete=!0;let root2=this._getRootCircuit();root2&&root2.emit("asyncEffect:end",{asyncEffectId,effectName,componentDisplayName:this.getString(),phase:asyncEffect.phase,error:error2.toString()})})}_emitRenderLifecycleEvent(phase,startOrEnd){debug6(`${phase}:${startOrEnd} ${this.getString()}`);let granular_event_type=`renderable:renderLifecycle:${phase}:${startOrEnd}`,eventPayload={renderId:this._renderId,componentDisplayName:this.getString(),type:granular_event_type},root=this._getRootCircuit();root&&(root.emit(granular_event_type,eventPayload),root.emit("renderable:renderLifecycle:anyEvent",{...eventPayload,type:granular_event_type}))}getString(){return this.constructor.name}_hasIncompleteAsyncEffects(){return this._asyncEffects.some(effect=>!effect.complete)?!0:this.children.some(child=>typeof child._hasIncompleteAsyncEffects=="function"?child._hasIncompleteAsyncEffects():!1)}_hasIncompleteAsyncEffectsInSubtreeForPhase(phase){for(let e5 of this._asyncEffects)if(!e5.complete&&e5.phase===phase)return!0;for(let child of this.children)if(child._hasIncompleteAsyncEffectsInSubtreeForPhase(phase))return!0;return!1}_hasIncompleteAsyncEffectsForPhase(phase){let root=this._getRootCircuit();return root?._hasIncompleteAsyncEffectsForPhase?root._hasIncompleteAsyncEffectsForPhase(phase):this._hasIncompleteAsyncEffectsInSubtreeForPhase(phase)}getCurrentRenderPhase(){return this._currentRenderPhase}getRenderGraph(){return{id:this._renderId,currentPhase:this._currentRenderPhase,renderPhaseStates:this.renderPhaseStates,shouldBeRemoved:this.shouldBeRemoved,children:this.children.map(child=>child.getRenderGraph())}}getTopLevelRenderable(){let current3=this;for(;current3.parent&&current3.parent instanceof _Renderable;)current3=current3.parent;return current3}runRenderCycle(){for(let renderPhase of orderedRenderPhases)this.runRenderPhaseForChildren(renderPhase),this.runRenderPhase(renderPhase)}runRenderPhase(phase){this._currentRenderPhase=phase;let phaseState=this.renderPhaseStates[phase],isInitialized=phaseState.initialized,isDirty3=phaseState.dirty;if(!isInitialized&&this.shouldBeRemoved)return;if(this.shouldBeRemoved&&isInitialized){this._emitRenderLifecycleEvent(phase,"start"),this?.[`remove${phase}`]?.(),phaseState.initialized=!1,phaseState.dirty=!1,this._emitRenderLifecycleEvent(phase,"end");return}let prevPhaseIndex=renderPhaseIndexMap.get(phase)-1;if(prevPhaseIndex>=0){let prevPhase=orderedRenderPhases[prevPhaseIndex];if(this._asyncEffects.filter(e5=>e5.phase===prevPhase).some(e5=>!e5.complete))return}let deps=asyncPhaseDependencies[phase]||[];if(deps.length>0){for(let depPhase of deps)if(this._hasIncompleteAsyncEffectsForPhase(depPhase))return}if(this._emitRenderLifecycleEvent(phase,"start"),isInitialized){isDirty3&&(this?.[`update${phase}`]?.(),phaseState.dirty=!1),this._emitRenderLifecycleEvent(phase,"end");return}phaseState.dirty=!1,this?.[`doInitial${phase}`]?.(),phaseState.initialized=!0,this._emitRenderLifecycleEvent(phase,"end")}runRenderPhaseForChildren(phase){for(let child of this.children)"_isIsolatedSubcircuit"in this&&this._isIsolatedSubcircuit&&"doInitialRenderIsolatedSubcircuits"in this&&phase==="RenderIsolatedSubcircuits"||(child.runRenderPhaseForChildren(phase),child.runRenderPhase(phase))}_getRootCircuit(){return"root"in this?this.root??null:null}renderError(message){throw typeof message=="string"?new Error(message):new Error(JSON.stringify(message,null,2))}},InvalidProps=class extends Error{constructor(componentName,originalProps,formattedError){let message,propsWithError=Object.keys(formattedError).filter(k4=>k4!=="_errors"),invalidPinLabelMessages=[],pinLabels=originalProps.pinLabels;if(pinLabels)for(let[pin,labelOrLabels]of Object.entries(pinLabels)){let labels=Array.isArray(labelOrLabels)?labelOrLabels:[labelOrLabels];for(let label of labels)typeof label=="string"&&(label.startsWith(" ")||label.endsWith(" "))&&invalidPinLabelMessages.push(`pinLabels.${pin} ("${label}" has leading or trailing spaces)`)}let propMessage=propsWithError.map(k4=>k4==="pinLabels"&&invalidPinLabelMessages.length>0?invalidPinLabelMessages.join(", "):formattedError[k4]._errors[0]?`${k4} (${formattedError[k4]._errors[0]})`:`${k4} (${JSON.stringify(formattedError[k4])})`).join(", ");"name"in originalProps?message=`Invalid props for ${componentName} "${originalProps.name}": ${propMessage}`:"footprint"in originalProps&&typeof originalProps.footprint=="string"?message=`Invalid props for ${componentName} (unnamed ${originalProps.footprint} component): ${propMessage}`:message=`Invalid props for ${componentName} (unnamed): ${propMessage}`;super(message);__publicField(this,"componentName");__publicField(this,"originalProps");__publicField(this,"formattedError");this.componentName=componentName,this.originalProps=originalProps,this.formattedError=formattedError}},defaultUnits={mm:1};function evaluateCalcString(input2,options){let{knownVariables,units:userUnits}=options,units={...defaultUnits,...userUnits??{}},expr=normalizeLegacyBoundsIdentifierCase(extractExpression(input2)),tokens=tokenize2(expr,units);return parseExpression(tokens,knownVariables)}function extractCalcIdentifiers(input2){let expr=normalizeLegacyBoundsIdentifierCase(extractExpression(input2));return tokenize2(expr,defaultUnits).filter(token=>token.type==="identifier").map(token=>token.value)}function normalizeLegacyBoundsIdentifierCase(expr){let legacyBoundNameToCamelCase={minx:"minX",maxx:"maxX",miny:"minY",maxy:"maxY"};return expr.replace(/\.(minx|maxx|miny|maxy)\b/gi,(match2,boundName)=>`.${legacyBoundNameToCamelCase[String(boundName).toLowerCase()]??match2.slice(1)}`)}function extractExpression(raw){let trimmed=raw.trim();if(!trimmed.toLowerCase().startsWith("calc"))return trimmed;let match2=trimmed.match(/^calc\s*\((.*)\)$/is);if(!match2)throw new Error(`Invalid calc() expression: "${raw}"`);return match2[1].trim()}function tokenize2(expr,units){let tokens=[],i3=0,isDigit2=ch3=>ch3>="0"&&ch3<="9",isIdentStart=ch3=>ch3>="A"&&ch3<="Z"||ch3>="a"&&ch3<="z"||ch3==="_",isIdentChar=ch3=>isIdentStart(ch3)||isDigit2(ch3)||ch3===".";for(;i3<expr.length;){let ch3=expr[i3];if(ch3===" "||ch3===" "||ch3===`
689
689
  `||ch3==="\r"){i3++;continue}if(isDigit2(ch3)||ch3==="."&&i3+1<expr.length&&isDigit2(expr[i3+1])){let start=i3;for(i3++;i3<expr.length;){let c4=expr[i3];if(isDigit2(c4)||c4===".")i3++;else break}let numberText=expr.slice(start,i3),num=Number(numberText);if(Number.isNaN(num))throw new Error(`Invalid number: "${numberText}"`);let unitStart=i3;for(;i3<expr.length&&/[A-Za-z]/.test(expr[i3]);)i3++;if(i3>unitStart){let unitText=expr.slice(unitStart,i3),factor=units[unitText];if(factor==null)throw new Error(`Unknown unit: "${unitText}"`);num*=factor}tokens.push({type:"number",value:num});continue}if(isIdentStart(ch3)){let start=i3;for(i3++;i3<expr.length&&isIdentChar(expr[i3]);)i3++;let ident=expr.slice(start,i3);tokens.push({type:"identifier",value:ident});continue}if(ch3==="("||ch3===")"){tokens.push({type:"paren",value:ch3}),i3++;continue}if(ch3==="+"||ch3==="-"||ch3==="*"||ch3==="/"){tokens.push({type:"operator",value:ch3}),i3++;continue}throw new Error(`Unexpected character "${ch3}" in expression "${expr}"`)}return tokens}function parseExpression(tokens,vars){let index=0,peek=()=>tokens[index],consume=()=>tokens[index++],parsePrimary=()=>{let token=peek();if(!token)throw new Error("Unexpected end of expression");if(token.type==="number")return consume(),token.value;if(token.type==="identifier"){consume();let value=vars[token.value];if(value==null)throw new Error(`Unknown variable: "${token.value}"`);return value}if(token.type==="paren"&&token.value==="("){consume();let value=parseExpr(),next2=peek();if(!next2||next2.type!=="paren"||next2.value!==")")throw new Error('Expected ")"');return consume(),value}throw new Error(`Unexpected token "${token.value}"`)},parseFactor=()=>{let token=peek();if(token&&token.type==="operator"&&(token.value==="+"||token.value==="-")){consume();let value=parseFactor();return token.value==="+"?value:-value}return parsePrimary()},parseTerm=()=>{let value=parseFactor();for(;;){let token=peek();if(!token||token.type!=="operator"||token.value!=="*"&&token.value!=="/")break;consume();let rhs=parseFactor();token.value==="*"?value*=rhs:value/=rhs}return value},parseExpr=()=>{let value=parseTerm();for(;;){let token=peek();if(!token||token.type!=="operator"||token.value!=="+"&&token.value!=="-")break;consume();let rhs=parseTerm();token.value==="+"?value+=rhs:value-=rhs}return value},result=parseExpr();if(index<tokens.length){let leftover=tokens.slice(index).map(t52=>"value"in t52?t52.value:"?").join(" ");throw new Error(`Unexpected tokens at end of expression: ${leftover}`)}return result}function setSubcircuitPcbComponentCalcVariables(params){let{vars,componentName,position:position4,size:size3}=params;vars[`${componentName}.x`]=position4.x,vars[`${componentName}.y`]=position4.y,vars[`${componentName}.width`]=size3.width,vars[`${componentName}.height`]=size3.height,vars[`${componentName}.minX`]=position4.x-size3.width/2,vars[`${componentName}.maxX`]=position4.x+size3.width/2,vars[`${componentName}.minY`]=position4.y-size3.height/2,vars[`${componentName}.maxY`]=position4.y+size3.height/2}function getSubcircuitPcbCalcVariables(db2){let vars={};for(let sourceComponent of db2.source_component.list()){if(!sourceComponent.name)continue;let pcbComponent=db2.pcb_component.getWhere({source_component_id:sourceComponent.source_component_id});pcbComponent&&setSubcircuitPcbComponentCalcVariables({vars,componentName:sourceComponent.name,position:{x:pcbComponent.center.x,y:pcbComponent.center.y},size:{width:pcbComponent.width??0,height:pcbComponent.height??0}})}return vars}var directionToVector={from_left:{x:-1,y:0},from_right:{x:1,y:0},from_front:{x:0,y:1},from_back:{x:0,y:-1}},isFootprintFlipped=params=>{let{componentLayer,originalLayer}=params;return componentLayer==="bottom"!=(originalLayer==="bottom")},transformFootprintInsertionDirection=params=>{let{insertionDirection,rotationDegrees=0,isFlipped=!1}=params;if(!insertionDirection)return;if(insertionDirection==="from_above")return insertionDirection;let baseVector=directionToVector[insertionDirection],angleRadians=normalizeDegrees(rotationDegrees)*Math.PI/180,rotatedVector={x:baseVector.x*Math.cos(angleRadians)-baseVector.y*Math.sin(angleRadians),y:baseVector.x*Math.sin(angleRadians)+baseVector.y*Math.cos(angleRadians)},finalVector=isFlipped?{x:rotatedVector.x,y:-rotatedVector.y}:rotatedVector;return Math.abs(finalVector.x)>=Math.abs(finalVector.y)?finalVector.x>=0?"from_right":"from_left":finalVector.y>=0?"from_front":"from_back"};function convertPcbStyleToPcbSx(pcbStyle2){if(!pcbStyle2)return;let sx3={};if(pcbStyle2.silkscreenFontSize!==void 0&&(sx3["& silkscreentext"]={fontSize:pcbStyle2.silkscreenFontSize}),Object.keys(sx3).length!==0)return sx3}function getResolvedPcbSx({parentResolvedPcbSx,pcbStyle:pcbStyle2,ownPcbSx}){let styleSx=convertPcbStyleToPcbSx(pcbStyle2),result={},allKeys=new Set;if(parentResolvedPcbSx)for(let k4 of Object.keys(parentResolvedPcbSx))allKeys.add(k4);if(styleSx)for(let k4 of Object.keys(styleSx))allKeys.add(k4);if(ownPcbSx)for(let k4 of Object.keys(ownPcbSx))allKeys.add(k4);for(let key of allKeys)result[key]={...parentResolvedPcbSx?.[key],...styleSx?.[key],...ownPcbSx?.[key]};return result}function isMatchingSelector(component,selector){let idMatch=selector.match(/^#(\w+)/);if(idMatch)return component.props.id===idMatch[1];let classMatch=selector.match(/^\.(\w+)/);if(classMatch)return component.isMatchingNameOrAlias(classMatch[1]);let[type,...conditions]=selector.split(/(?=[#.[])/);return type==="pin"&&(type="port"),type&&type!=="*"&&component.lowercaseComponentName!==type.toLowerCase()?!1:conditions.every(condition=>{if(condition.startsWith("#"))return component.props.id===condition.slice(1);if(condition.startsWith("."))return component.isMatchingNameOrAlias(condition.slice(1));let match2=condition.match(/\[(\w+)=['"]?(.+?)['"]?\]/);if(!match2)return!0;let[,prop,value]=match2;return component.props[prop].toString()===value})}var cssSelectPrimitiveComponentAdapter={isTag:node=>!0,getParent:node=>node.parent,getChildren:node=>node.children,getName:node=>node.lowercaseComponentName,getAttributeValue:(node,name)=>{if(name==="class"&&"getNameAndAliases"in node)return node.getNameAndAliases().join(" ");if(name==="name"&&node._parsedProps?.name)return node._parsedProps.name;if(node._parsedProps&&name in node._parsedProps){let value=node._parsedProps[name];return typeof value=="string"?value:value!=null?String(value):null}if(name in node){let value=node[name];return typeof value=="string"?value:value!=null?String(value):null}let reverseMap=node._attributeLowerToCamelNameMap;if(reverseMap){let camelCaseName=reverseMap[name];if(camelCaseName&&camelCaseName in node){let value=node[camelCaseName];return typeof value=="string"?value:value!=null?String(value):null}}return null},hasAttrib:(node,name)=>{if(name==="class")return!!node._parsedProps?.name;if(node._parsedProps&&name in node._parsedProps||name in node)return!0;let reverseMap=node._attributeLowerToCamelNameMap;if(reverseMap){let camelCaseName=reverseMap[name];if(camelCaseName&&camelCaseName in node)return!0}return!1},getSiblings:node=>node.parent?node.parent.children:[],prevElementSibling:node=>{if(!node.parent)return null;let siblings=node.parent.children,idx=siblings.indexOf(node);return idx>0?siblings[idx-1]:null},getText:()=>"",removeSubsets:nodes=>nodes.filter((node,i3)=>!nodes.some((other,j4)=>i3!==j4&&other!==node&&other.getDescendants().includes(node))),existsOne:(test,nodes)=>nodes.some(test),findAll:(test,nodes)=>{let result=[],recurse=node=>{test(node)&&result.push(node);for(let child of node.children)recurse(child)};for(let node of nodes)recurse(node);return result},findOne:(test,nodes)=>{for(let node of nodes){if(test(node))return node;let children=node.children;if(children.length>0){let result=cssSelectPrimitiveComponentAdapter.findOne(test,children);if(result)return result}}return null},equals:(a3,b3)=>a3._renderId===b3._renderId,isHovered:elem=>!1,isVisited:elem=>!1,isActive:elem=>!1},cssSelectPrimitiveComponentAdapterWithoutSubcircuits={...cssSelectPrimitiveComponentAdapter,getChildren:node=>node.children.filter(c4=>!c4.isSubcircuit)},cssSelectPrimitiveComponentAdapterOnlySubcircuits={...cssSelectPrimitiveComponentAdapter,getChildren:node=>node.children.filter(c4=>c4.isSubcircuit)},buildPlusMinusNetErrorMessage=(selector,component)=>{let netName=selector.split("net.")[1]?.split(/[ >]/)[0]??selector;return`Net names cannot contain "+" or "-" (component "${component?.componentName??"Unknown component"}" received "${netName}" via "${selector}"). Try using underscores instead, e.g. VCC_P`},preprocessSelector=(selector,component)=>{if(/net\.[^\s>]*\./.test(selector))throw new Error('Net names cannot contain a period, try using "sel.net..." to autocomplete with conventional net names, e.g. V3_3');if(/net\.[^\s>]*[+-]/.test(selector))throw new Error(buildPlusMinusNetErrorMessage(selector,component));if(/net\.[0-9]/.test(selector)){let match2=selector.match(/net\.([^ >]+)/),netName=match2?match2[1]:"";throw new Error(`Net name "${netName}" cannot start with a number, try using a prefix like "VBUS1"`)}return selector.replace(/ pin(?=[\d.])/g," port").replace(/ subcircuit\./g," group[isSubcircuit=true]").replace(/([^ ])\>([^ ])/g,"$1 > $2").replace(/(^|[ >])(?!pin\.)(?!port\.)(?!net\.)([A-Z][A-Za-z0-9_-]*)\.([A-Za-z0-9_-]+)/g,(_4,sep,name,pin)=>{let pinPart=/^\d+$/.test(pin)?`pin${pin}`:pin;return`${sep}.${name} > .${pinPart}`}).trim()},cssSelectOptionsInsideSubcircuit={adapter:cssSelectPrimitiveComponentAdapterWithoutSubcircuits,cacheResults:!0},PrimitiveComponent2=class extends Renderable{constructor(props){super(props);__publicField(this,"parent",null);__publicField(this,"children");__publicField(this,"childrenPendingRemoval");__publicField(this,"props");__publicField(this,"_parsedProps");__publicField(this,"externallyAddedAliases");__publicField(this,"isPrimitiveContainer",!1);__publicField(this,"canHaveTextChildren",!1);__publicField(this,"source_group_id",null);__publicField(this,"source_component_id",null);__publicField(this,"schematic_component_id",null);__publicField(this,"pcb_component_id",null);__publicField(this,"cad_component_id",null);__publicField(this,"_reportedInvalidPcbCalcWarnings",new Set);__publicField(this,"fallbackUnassignedName");__publicField(this,"_cachedSelectAllQueries",new Map);__publicField(this,"_cachedSelectOneQueries",new Map);this.children=[],this.childrenPendingRemoval=[],this.props=props??{},this.externallyAddedAliases=[];let parsePropsResult=("partial"in this.config.zodProps?this.config.zodProps.partial({name:!0}):this.config.zodProps).safeParse(props??{});if(parsePropsResult.success)this._parsedProps=parsePropsResult.data;else throw new InvalidProps(this.lowercaseComponentName,this.props,parsePropsResult.error.format())}get config(){return{componentName:"",zodProps:external_exports.object({}).passthrough()}}get componentName(){return this.config.componentName}getInheritedProperty(propertyName){let current3=this;for(;current3;){if(current3._parsedProps&&propertyName in current3._parsedProps)return current3._parsedProps[propertyName];current3=current3.parent}if(this.root?.platform&&propertyName in this.root.platform)return this.root.platform[propertyName]}getInheritedMergedProperty(propertyName){let parentPropertyObject=this.parent?.getInheritedMergedProperty?.(propertyName),myPropertyObject=this._parsedProps?.[propertyName];return{...parentPropertyObject,...myPropertyObject}}getResolvedPcbSx(){return getResolvedPcbSx({parentResolvedPcbSx:this.parent?.getResolvedPcbSx?.(),pcbStyle:this._parsedProps?.pcbStyle,ownPcbSx:this._parsedProps?.pcbSx})}get lowercaseComponentName(){return this.componentName.toLowerCase()}get isSubcircuit(){return!!this.props.subcircuit||this.lowercaseComponentName==="group"&&this?.parent?.isRootCircuit}get isGroup(){return this.lowercaseComponentName==="group"}get name(){return this._parsedProps.name??this.fallbackUnassignedName}_reportInvalidComponentPropertyError(propertyName,message){!this.root||this._reportedInvalidPcbCalcWarnings.has(propertyName)||(this.root.db.source_invalid_component_property_error.insert({source_component_id:this.source_component_id||"",property_name:propertyName,message,error_type:"source_invalid_component_property_error"}),this._reportedInvalidPcbCalcWarnings.add(propertyName))}setProps(props){let newProps=this.config.zodProps.parse({...this.props,...props}),oldProps=this.props;this.props=newProps,this._parsedProps=this.config.zodProps.parse(props),this.onPropsChange({oldProps,newProps,changedProps:Object.keys(props)}),this.parent?.onChildChanged?.(this)}_getPcbRotationBeforeLayout(){let{pcbRotation}=this.props;return typeof pcbRotation=="string"?parseFloat(pcbRotation):pcbRotation??null}getResolvedPcbPositionProp(){return{pcbX:this._resolvePcbCoordinate(this._parsedProps.pcbX,"pcbX"),pcbY:this._resolvePcbCoordinate(this._parsedProps.pcbY,"pcbY")}}doInitialValidatePcbCoordinates(){if(this.root?.pcbDisabled)return;let rawProps=this.props,rawPcbX=rawProps.pcbX,rawPcbY=rawProps.pcbY;this._validatePcbCoordinateReferences({rawValue:rawPcbX,axis:"pcbX",propertyName:"pcbX"}),this._validatePcbCoordinateReferences({rawValue:rawPcbY,axis:"pcbY",propertyName:"pcbY"})}_validatePcbCoordinateReferences(params){let{rawValue,axis,propertyName=axis}=params;if(typeof rawValue!="string")return;let allowComponentVariables=!(this._isNormalComponent===!0)&&!this._isInsideFootprint(),calcIdentifiers=[];try{calcIdentifiers=extractCalcIdentifiers(rawValue)}catch{this._reportInvalidComponentPropertyError(propertyName,`Invalid ${propertyName} value for ${this.componentName}: Invalid calc() expression. expression="${rawValue}"`);return}calcIdentifiers.some(identifier=>!identifier.startsWith("board."))&&!allowComponentVariables&&this._reportInvalidComponentPropertyError(propertyName,`Invalid ${propertyName} value for ${this.componentName}: component-relative calc references are not supported for footprint elements (${this.componentName}); ${propertyName} will be ignored. expression="${rawValue}"`)}_resolvePcbCoordinate(rawValue,axis,options={}){if(rawValue==null)return 0;let propertyName=options.propertyName??axis;if(typeof rawValue=="number")return Number.isFinite(rawValue)?rawValue:0;if(typeof rawValue!="string")throw new Error(`Invalid ${axis} value for ${this.componentName}: ${String(rawValue)}`);let allowBoardVariables=options.allowBoardVariables??this._shouldAllowBoardVariablesByDefault(),isNormalComponent=this._isNormalComponent===!0,allowComponentVariables=options.allowComponentVariables??(!isNormalComponent&&!this._isInsideFootprint()),includesBoardVariable=rawValue.includes("board."),knownVariables={};if(allowBoardVariables){let board=this._getBoard(),boardVariables=board?._getBoardCalcVariables()??{};if(includesBoardVariable&&!board)return this._reportInvalidComponentPropertyError(propertyName,`Invalid ${propertyName} value for ${this.componentName}: no board found for board.* variables. expression="${rawValue}"`),0;if(includesBoardVariable&&board&&Object.keys(boardVariables).length===0)return this._reportInvalidComponentPropertyError(propertyName,`Invalid ${propertyName} value for ${this.componentName}: Cannot do calculations based on board size when the board is auto-sized. expression="${rawValue}"`),0;Object.assign(knownVariables,boardVariables)}if(allowComponentVariables){let db2=this.root?.db;db2&&Object.assign(knownVariables,getSubcircuitPcbCalcVariables(db2)),Object.assign(knownVariables,options.componentVariables??{})}try{return extractCalcIdentifiers(rawValue).some(identifier=>!identifier.startsWith("board."))&&!allowComponentVariables?(this._isInsideFootprint()&&this.root&&!this._reportedInvalidPcbCalcWarnings.has(axis)&&(this.root.db.source_invalid_component_property_error.insert({source_component_id:this.source_component_id||"",property_name:axis,message:`component-relative calc references are not supported for footprint elements (${this.componentName}); ${axis} will be ignored. expression="${rawValue}"`,error_type:"source_invalid_component_property_error"}),this._reportedInvalidPcbCalcWarnings.add(axis)),0):evaluateCalcString(rawValue,{knownVariables})}catch(error2){let message=error2 instanceof Error?error2.message:String(error2);return this._reportInvalidComponentPropertyError(propertyName,`Invalid ${propertyName} value for ${this.componentName}: ${message}. expression="${rawValue}"`),0}}_shouldAllowBoardVariablesByDefault(){return this._isNormalComponent===!0?!0:!this._isInsideFootprint()&&!this._isInsideNonBoardSubcircuit()}_isInsideFootprint(){let current3=this.parent;for(;current3;){if(current3.componentName==="Footprint")return!0;current3=current3.parent}return!1}_isInsideNonBoardSubcircuit(){let current3=this.parent;for(;current3;){let componentName=current3.componentName;if(componentName==="Board"||componentName==="MountedBoard")return!1;if(current3.isSubcircuit)return!0;current3=current3.parent}return!1}_hasUserDefinedPcbPosition(){let props=this._parsedProps;return props.pcbX!==void 0||props.pcbY!==void 0||props.pcbLeftEdgeX!==void 0||props.pcbRightEdgeX!==void 0||props.pcbTopEdgeY!==void 0||props.pcbBottomEdgeY!==void 0}resolvePcbCoordinate(params){let{rawValue,axis,allowBoardVariables,allowComponentVariables,componentVariables,propertyName}=params;return this._resolvePcbCoordinate(rawValue,axis,{allowBoardVariables,allowComponentVariables,componentVariables,propertyName})}computePcbPropsTransform(){let rotation42=this._getPcbRotationBeforeLayout()??0,{pcbX,pcbY}=this.getResolvedPcbPositionProp();return compose2(translate2(pcbX,pcbY),rotate2(rotation42*Math.PI/180))}_computePcbGlobalTransformBeforeLayout(){let manualPlacement=this.getSubcircuit()._getPcbManualPlacementForComponent(this);if(manualPlacement&&this.props.pcbX===void 0&&this.props.pcbY===void 0){let rotation42=this._getPcbRotationBeforeLayout()??0;return compose2(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),compose2(translate2(manualPlacement.x,manualPlacement.y),rotate2(rotation42*Math.PI/180)))}if(this.isPcbPrimitive){let{isFlipped}=this._getPcbPrimitiveFlippedHelpers();if(isFlipped)return compose2(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),flipY(),this.computePcbPropsTransform())}return compose2(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),this.computePcbPropsTransform())}_getEnclosingFootprint(){let current3=this.parent;for(;current3;){if(current3.componentName==="Footprint")return current3;current3=current3.parent}return null}getPrimitiveContainer(){return this.isPrimitiveContainer?this:this.parent?.getPrimitiveContainer?.()??null}_getSymbolAncestor(){let container=this.getPrimitiveContainer();return container?.componentName==="Symbol"?container:null}getParentNormalComponent(){let current3=this.parent;for(;current3;){if(current3.isPrimitiveContainer&&current3.doInitialPcbComponentRender)return current3;current3=current3.parent}return null}getCollapsedSchematicBoxAncestor(){let current3=this.parent;for(;current3;){if(current3.componentName==="Group"&&current3._parsedProps?.showAsSchematicBox)return current3;current3=current3.parent}return null}_resolveText(){let text=this._parsedProps.text;if(!text)return"";if(!text.includes("{NAME}")&&!text.includes("{REF}")&&!text.includes("{REFERENCE}"))return text;let refdes=this.getParentNormalComponent()?.name;return refdes?text.replace(/\{NAME\}/g,refdes).replace(/\{REF\}/g,refdes).replace(/\{REFERENCE\}/g,refdes):text}emitSolderMaskMarginWarning(isCoveredWithSolderMask,solderMaskMargin){if(isCoveredWithSolderMask&&solderMaskMargin!==void 0){let parentNormalComponent=this.getParentNormalComponent();parentNormalComponent?.source_component_id&&this.root.db.source_property_ignored_warning.insert({source_component_id:parentNormalComponent.source_component_id,property_name:"solderMaskMargin",message:"solderMaskMargin is set but coveredWithSolderMask is true. When a component is fully covered with solder mask, a margin doesn't apply.",error_type:"source_property_ignored_warning"})}}_getPcbCircuitJsonBounds(){return{center:{x:0,y:0},bounds:{left:0,top:0,right:0,bottom:0},width:0,height:0}}_getPcbPrimitiveFlippedHelpers(){let container=this.getPrimitiveContainer(),footprint=this.componentName==="Footprint"?this:this._getEnclosingFootprint(),isFlipped=container?isFootprintFlipped({componentLayer:container._parsedProps.layer,originalLayer:footprint?._parsedProps.originalLayer}):!1;return{isFlipped,maybeFlipLayer:layer=>isFlipped?layer==="top"?"bottom":"top":layer}}_setPositionFromLayout(newCenter){throw new Error(`_setPositionFromLayout not implemented for ${this.componentName}`)}computeSchematicPropsTransform(){let{_parsedProps:props}=this;return compose2(translate2(props.schX??0,props.schY??0))}computeSchematicGlobalTransform(){let manualPlacementTransform=this._getSchematicGlobalManualPlacementTransform(this);return manualPlacementTransform||compose2(this.parent?.computeSchematicGlobalTransform?.()??identity(),this.computeSchematicPropsTransform())}_getSchematicSymbolName(){let{_parsedProps:props}=this,base_symbol_name=this.config.schematicSymbolName,orientationRotationMap={horizontal:0,pos_left:0,neg_right:0,pos_right:180,neg_left:180,pos_top:270,neg_bottom:90,vertical:270,pos_bottom:90,neg_top:90},normalizedRotation=props.schOrientation!==void 0?orientationRotationMap[props.schOrientation]:props.schRotation;if(normalizedRotation===void 0&&(normalizedRotation=0),normalizedRotation=normalizedRotation%360,normalizedRotation<0&&(normalizedRotation+=360),props.schRotation!==void 0&&normalizedRotation%90!==0)throw new Error(`Schematic rotation ${props.schRotation} is not supported for ${this.componentName}`);let symbol_name_horz=`${base_symbol_name}_horz`,symbol_name_vert=`${base_symbol_name}_vert`,symbol_name_up=`${base_symbol_name}_up`,symbol_name_down=`${base_symbol_name}_down`,symbol_name_left=`${base_symbol_name}_left`,symbol_name_right=`${base_symbol_name}_right`;if(symbol_name_right in Vf&&normalizedRotation===0)return symbol_name_right;if(symbol_name_up in Vf&&normalizedRotation===90)return symbol_name_up;if(symbol_name_left in Vf&&normalizedRotation===180)return symbol_name_left;if(symbol_name_down in Vf&&normalizedRotation===270)return symbol_name_down;if(symbol_name_horz in Vf&&(normalizedRotation===0||normalizedRotation===180))return symbol_name_horz;if(symbol_name_vert in Vf&&(normalizedRotation===90||normalizedRotation===270))return symbol_name_vert;if(base_symbol_name in Vf)return base_symbol_name}_getSchematicSymbolNameOrThrow(){let symbol_name=this._getSchematicSymbolName();if(!symbol_name)throw new Error(`No schematic symbol found (given: "${this.config.schematicSymbolName}")`);return symbol_name}getSchematicSymbol(){let symbol_name=this._getSchematicSymbolName();return symbol_name?Vf[symbol_name]??null:null}_getPcbManualPlacementForComponent(component){if(!this.isSubcircuit)return null;let manualEdits=this.props.manualEdits;if(!manualEdits)return null;let placementConfigPositions=manualEdits?.pcb_placements;if(!placementConfigPositions)return null;for(let position4 of placementConfigPositions)if(isMatchingSelector(component,position4.selector)||component.props.name===position4.selector)return applyToPoint2(this._computePcbGlobalTransformBeforeLayout(),position4.center);return null}_getSchematicManualPlacementForComponent(component){if(!this.isSubcircuit)return null;let manualEdits=this.props.manualEdits;if(!manualEdits)return null;let placementConfigPositions=manualEdits.schematic_placements;if(!placementConfigPositions)return null;for(let position4 of placementConfigPositions)if(isMatchingSelector(component,position4.selector)||component.props.name===position4.selector)return applyToPoint2(this.computeSchematicGlobalTransform(),position4.center);return null}_getSchematicGlobalManualPlacementTransform(component){let manualEdits=this.getSubcircuit()?._parsedProps.manualEdits;if(!manualEdits)return null;for(let position4 of manualEdits.schematic_placements??[])if((isMatchingSelector(component,position4.selector)||component.props.name===position4.selector)&&position4.relative_to==="group_center")return compose2(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),translate2(position4.center.x,position4.center.y));return null}_getGlobalPcbPositionBeforeLayout(){return applyToPoint2(this._computePcbGlobalTransformBeforeLayout(),{x:0,y:0})}_getGlobalSchematicPositionBeforeLayout(){return applyToPoint2(this.computeSchematicGlobalTransform(),{x:0,y:0})}_getBoard(){let current3=this;for(;current3;){let maybePrimitive=current3,componentName=maybePrimitive.componentName;if(componentName==="Board"||componentName==="MountedBoard")return maybePrimitive;current3=current3.parent??null}return this.root?._getBoard()}get root(){return this.parent?.root??null}onAddToParent(parent){this.parent=parent}onPropsChange(params){}onChildChanged(child){this.parent?.onChildChanged?.(child)}add(component){let textContent2=component.__text;if(typeof textContent2=="string"){if(this.canHaveTextChildren||textContent2.trim()==="")return;throw new Error(`Invalid JSX Element: Expected a React component but received text "${textContent2}"`)}if(Object.keys(component).length!==0){if(component.lowercaseComponentName==="panel")throw new Error("<panel> must be a root-level element");if(!component.onAddToParent)throw new Error(`Invalid JSX Element: Expected a React component but received "${JSON.stringify(component)}"`);component.onAddToParent(this),component.parent=this,this.children.push(component)}}addAll(components){for(let component of components)this.add(component)}remove(component){this.children=this.children.filter(c4=>c4!==component),this.childrenPendingRemoval.push(component),component.shouldBeRemoved=!0}getSubcircuitSelector(){let name=this.name,endPart=name?`${this.lowercaseComponentName}.${name}`:this.lowercaseComponentName;return!this.parent||this.parent.isSubcircuit?endPart:`${this.parent.getSubcircuitSelector()} > ${endPart}`}getFullPathSelector(){let name=this.name,endPart=name?`${this.lowercaseComponentName}.${name}`:this.lowercaseComponentName,parentSelector=this.parent?.getFullPathSelector?.();return parentSelector?`${parentSelector} > ${endPart}`:endPart}getNameAndAliases(){return[this.name,...this._parsedProps.portHints??[]].filter(Boolean)}isMatchingNameOrAlias(name){return this.getNameAndAliases().includes(name)}isMatchingAnyOf(aliases2){return this.getNameAndAliases().some(a3=>aliases2.map(a22=>a22.toString()).includes(a3))}getPcbSize(){throw new Error(`getPcbSize not implemented for ${this.componentName}`)}doesSelectorMatch(selector){let myTypeNames=[this.componentName,this.lowercaseComponentName],myClassNames=[this.name].filter(Boolean),parts=selector.trim().split(/\> /)[0],firstPart=parts[0];return parts.length>1?!1:!!(selector==="*"||selector[0]==="#"&&selector.slice(1)===this.props.id||selector[0]==="."&&myClassNames.includes(selector.slice(1))||/^[a-zA-Z0-9_]/.test(firstPart)&&myTypeNames.includes(firstPart))}getSubcircuit(){if(this.isSubcircuit)return this;let group=this.parent?.getSubcircuit?.();if(!group)throw new Error("Component is not inside an opaque group (no board?)");return group}getGroup(){return this.isGroup?this:this.parent?.getGroup?.()??null}doInitialAssignNameToUnnamedComponents(){this._parsedProps.name||(this.fallbackUnassignedName=this.getSubcircuit().getNextAvailableName(this))}doInitialOptimizeSelectorCache(){if(!this.isSubcircuit)return;let ports=this.selectAll("port"),isValidShorthandName=name=>/^[A-Za-z_][A-Za-z0-9_-]*$/.test(name);for(let port of ports){let parentAliases=(port.getParentNormalComponent?.()??port.parent)?.getNameAndAliases(),portAliases=port.getNameAndAliases();if(parentAliases)for(let parentAlias of parentAliases)for(let portAlias of portAliases){let selectors=[`.${parentAlias} > .${portAlias}`,`.${parentAlias} .${portAlias}`];isValidShorthandName(parentAlias)&&isValidShorthandName(portAlias)&&selectors.push(`${parentAlias}.${portAlias}`);for(let selector of selectors){let ar3=this._cachedSelectAllQueries.get(selector);ar3?ar3.push(port):this._cachedSelectAllQueries.set(selector,[port])}}}for(let[selector,ports2]of this._cachedSelectAllQueries.entries())ports2.length===1&&this._cachedSelectOneQueries.set(selector,ports2[0])}selectAll(selectorRaw){if(this._cachedSelectAllQueries.has(selectorRaw))return this._cachedSelectAllQueries.get(selectorRaw);let selector=preprocessSelector(selectorRaw,this),result=selectAll(selector,this,cssSelectOptionsInsideSubcircuit);if(result.length>0)return this._cachedSelectAllQueries.set(selectorRaw,result),result;let[firstpart,...rest]=selector.split(" "),subcircuit=selectOne(firstpart,this,{adapter:cssSelectPrimitiveComponentAdapterOnlySubcircuits});if(!subcircuit)return[];let result2=subcircuit.selectAll(rest.join(" "));return this._cachedSelectAllQueries.set(selectorRaw,result2),result2}selectOne(selectorRaw,options){if(this._cachedSelectOneQueries.has(selectorRaw))return this._cachedSelectOneQueries.get(selectorRaw);let selector=preprocessSelector(selectorRaw,this);options?.port&&(options.type="port");let result=null;if(options?.type&&(result=selectAll(selector,this,cssSelectOptionsInsideSubcircuit).find(n4=>n4.lowercaseComponentName===options.type)),options?.type||(result??(result=selectOne(selector,this,cssSelectOptionsInsideSubcircuit))),result)return this._cachedSelectOneQueries.set(selectorRaw,result),result;let[firstpart,...rest]=selector.split(" "),subcircuit=selectOne(firstpart,this,{adapter:cssSelectPrimitiveComponentAdapterOnlySubcircuits});return subcircuit?(result=subcircuit.selectOne(rest.join(" "),options),this._cachedSelectOneQueries.set(selectorRaw,result),result):null}getAvailablePcbLayers(){if(this.isPcbPrimitive){let{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers();return"layer"in this._parsedProps||this.componentName==="SmtPad"?[maybeFlipLayer(this._parsedProps.layer??"top")]:"layers"in this._parsedProps?this._parsedProps.layers:this.componentName==="PlatedHole"?[...this.root?._getBoard()?.allLayers??["top","bottom"]]:[]}return[]}getDescendants(){let descendants=[];for(let child of this.children)descendants.push(child),descendants.push(...child.getDescendants());return descendants}getSelectableDescendants(){let descendants=[];for(let child of this.children)child.isSubcircuit?descendants.push(child):(descendants.push(child),descendants.push(...child.getSelectableDescendants()));return descendants}_getPrimaryPinCount(){return 0}_getSchematicBoxDimensions(){return null}_getSchematicBoxComponentDimensions(){if(this.getSchematicSymbol()||!this.config.shouldRenderAsSchematicBox)return null;let{_parsedProps:props}=this;return{schWidth:props.schWidth,schHeight:props.schHeight}}renderError(message){if(typeof message=="string")return super.renderError(message);switch(message.type){case"pcb_placement_error":this.root?.db.pcb_placement_error.insert(message);break;case"pcb_via_clearance_error":this.root?.db.pcb_via_clearance_error.insert(message);break;case"pcb_trace_error":this.root?.db.pcb_trace_error.insert(message);break;case"pcb_manual_edit_conflict_warning":this.root?.db.pcb_manual_edit_conflict_warning.insert(message);break;default:this.root?.db.pcb_placement_error.insert(message)}}getString(){let{lowercaseComponentName:cname,_parsedProps:props,parent}=this;return props?.pinNumber!==void 0&&parent?.props?.name&&props?.name?`<${cname}#${this._renderId}(pin:${props.pinNumber} .${parent?.props.name}>.${props.name}) />`:parent?.props?.name&&props?.name?`<${cname}#${this._renderId}(.${parent?.props.name}>.${props?.name}) />`:props?.from&&props?.to?`<${cname}#${this._renderId}(from:${props.from} to:${props?.to}) />`:props?.name?`<${cname}#${this._renderId} name=".${props?.name}" />`:props?.portHints?`<${cname}#${this._renderId}(${props.portHints.map(ph3=>`.${ph3}`).join(", ")}) />`:`<${cname}#${this._renderId} />`}getDisplayName(){return this.name?`${this.lowercaseComponentName} "${this.name}"`:`${this.lowercaseComponentName} (unnamed)`}get[Symbol.toStringTag](){return this.getString()}[Symbol.for("nodejs.util.inspect.custom")](){return this.getString()}};function pairs2(arr){let result=[];for(let i3=0;i3<arr.length-1;i3++)result.push([arr[i3],arr[i3+1]]);return result}var Net=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"source_net_id");__publicField(this,"subcircuit_connectivity_map_key",null)}get config(){return{componentName:"Net",zodProps:netProps}}getPortSelector(){return`net.${this.props.name}`}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,isGround=props.name.startsWith("GND"),isPositiveVoltageSource=props.name.startsWith("V"),net=db2.source_net.insert({name:props.name,member_source_group_ids:[],is_ground:isGround,is_power:isPositiveVoltageSource,is_positive_voltage_source:isPositiveVoltageSource});this.source_net_id=net.source_net_id}doInitialSourceParentAttachment(){let subcircuit=this.getSubcircuit();if(!subcircuit)return;let{db:db2}=this.root;db2.source_net.update(this.source_net_id,{subcircuit_id:subcircuit.subcircuit_id})}getAllConnectedPorts(){let allPorts=this.getSubcircuit().selectAll("port"),connectedPorts=[];for(let port of allPorts){let traces=port._getDirectlyConnectedTraces();for(let trace of traces)if(trace._isExplicitlyConnectedToNet(this)){connectedPorts.push(port);break}}return connectedPorts}_getAllDirectlyConnectedTraces(){let allTraces=this.getSubcircuit().selectAll("trace"),connectedTraces=[];for(let trace of allTraces)trace._isExplicitlyConnectedToNet(this)&&connectedTraces.push(trace);return connectedTraces}doInitialPcbRouteNetIslands(){if(this.root?.pcbDisabled||this.getSubcircuit()._parsedProps.routingDisabled||this.getSubcircuit()._isInflatedFromCircuitJson||this.getSubcircuit()._getAutorouterConfig().groupMode!=="sequential-trace")return;let{db:db2}=this.root,{_parsedProps:props}=this,traces=this._getAllDirectlyConnectedTraces().filter(trace=>(trace._portsRoutedOnPcb?.length??0)>0),islands=[];for(let trace of traces){let tracePorts=trace._portsRoutedOnPcb,traceIsland=islands.find(island=>tracePorts.some(port=>island.ports.includes(port)));if(!traceIsland){islands.push({ports:[...tracePorts],traces:[trace]});continue}traceIsland.traces.push(trace),traceIsland.ports.push(...tracePorts)}if(islands.length===0)return;let islandPairs=pairs2(islands);for(let[A4,B4]of islandPairs){let Apositions=A4.ports.map(port=>port._getGlobalPcbPositionBeforeLayout()),Bpositions=B4.ports.map(port=>port._getGlobalPcbPositionBeforeLayout()),closestDist=1/0,closestPair=[-1,-1];for(let i3=0;i3<Apositions.length;i3++){let Apos=Apositions[i3];for(let j4=0;j4<Bpositions.length;j4++){let Bpos=Bpositions[j4],dist=Math.sqrt((Apos.x-Bpos.x)**2+(Apos.y-Bpos.y)**2);dist<closestDist&&(closestDist=dist,closestPair=[i3,j4])}}let Aport=A4.ports[closestPair[0]],Bport=B4.ports[closestPair[1]],pcbElements=db2.toArray().filter(elm=>elm.type==="pcb_smtpad"||elm.type==="pcb_trace"||elm.type==="pcb_plated_hole"||elm.type==="pcb_hole"||elm.type==="source_port"||elm.type==="pcb_port"),{solution}=autoroute2(pcbElements.concat([{type:"source_trace",source_trace_id:"__net_trace_tmp",connected_source_port_ids:[Aport.source_port_id,Bport.source_port_id]}])),trace=solution[0];if(!trace){this.renderError({pcb_trace_error_id:"",pcb_trace_id:"__net_trace_tmp",pcb_component_ids:[Aport.pcb_component_id,Bport.pcb_component_id].filter(Boolean),pcb_port_ids:[Aport.pcb_port_id,Bport.pcb_port_id].filter(Boolean),type:"pcb_trace_error",error_type:"pcb_trace_error",message:`Failed to route net islands for "${this.getString()}"`,source_trace_id:"__net_trace_tmp"});return}db2.pcb_trace.insert(trace)}}renderError(message){if(typeof message=="string")return super.renderError(message);this.root?.db.pcb_trace_error.insert(message)}},createNetsFromProps=(component,props)=>{for(let prop of props)if(typeof prop=="string"&&prop.startsWith("net.")){if(/net\.[^\s>]*\./.test(prop))throw new Error('Net names cannot contain a period, try using "sel.net..." to autocomplete with conventional net names, e.g. V3_3');if(/net\.[^\s>]*[+-]/.test(prop)){let netName=prop.split("net.")[1],message=`Net names cannot contain "+" or "-" (component "${component.componentName}" received "${netName}" via "${prop}"). Try using underscores instead, e.g. VCC_P`;throw new Error(message)}if(/net\.[0-9]/.test(prop)){let netName=prop.split("net.")[1];throw new Error(`Net name "${netName}" cannot start with a number, try using a prefix like "VBUS1"`)}let subcircuit=component.getSubcircuit();if(!subcircuit.selectOne(prop)){let net=new Net({name:prop.split("net.")[1]});subcircuit.add(net)}}},getDistance3=(a3,b3)=>{let aPos="_getGlobalPcbPositionBeforeLayout"in a3?a3._getGlobalPcbPositionBeforeLayout():a3,bPos="_getGlobalPcbPositionBeforeLayout"in b3?b3._getGlobalPcbPositionBeforeLayout():b3;return Math.sqrt((aPos.x-bPos.x)**2+(aPos.y-bPos.y)**2)};function getClosest(point62,candidates){if(candidates.length===0)throw new Error("No candidates given to getClosest method");let closest=candidates[0],closestDist=1/0;for(let candidate of candidates){let dist=getDistance3(point62,candidate);dist<closestDist&&(closest=candidate,closestDist=dist)}return closest}var countComplexElements=(junctions,edges)=>{let count=0;count+=junctions.length??0,count+=edges.filter(edge=>edge.is_crossing).length;for(let i3=1;i3<edges.length;i3++){let prev=edges[i3-1],curr=edges[i3],prevVertical=Math.abs(prev.from.x-prev.to.x)<.01,currVertical=Math.abs(curr.from.x-curr.to.x)<.01;prevVertical!==currVertical&&count++}return count},getEnteringEdgeFromDirection=direction2=>({up:"bottom",down:"top",left:"right",right:"left"})[direction2]??null,getStubEdges=({firstEdge,firstEdgePort,firstDominantDirection,lastEdge,lastEdgePort,lastDominantDirection})=>{if(firstEdge&&firstEdgePort)return getStubEdges({lastEdge:{from:firstEdge.to,to:firstEdge.from},lastEdgePort:firstEdgePort,lastDominantDirection:firstDominantDirection}).reverse().map(e5=>({from:e5.to,to:e5.from}));let edges=[];if(lastEdge&&lastEdgePort){let intermediatePoint={x:lastEdge.to.x,y:lastEdge.to.y};lastDominantDirection==="left"||lastDominantDirection==="right"?(intermediatePoint.x=lastEdgePort.position.x,edges.push({from:lastEdge.to,to:{...intermediatePoint}}),edges.push({from:intermediatePoint,to:{...lastEdgePort.position}})):(intermediatePoint.y=lastEdgePort.position.y,edges.push({from:lastEdge.to,to:{...intermediatePoint}}),edges.push({from:intermediatePoint,to:{...lastEdgePort.position}}))}return edges=edges.filter(e5=>distance2(e5.from,e5.to)>.01),edges};function tryNow(fn3){try{return[fn3(),null]}catch(e5){return[null,e5]}}var getMaxLengthFromConnectedCapacitors=(ports,{db:db2})=>{let capacitorMaxLengths=ports.map(port=>{let sourcePort=db2.source_port.get(port.source_port_id);if(!sourcePort?.source_component_id)return null;let sourceComponent=db2.source_component.get(sourcePort.source_component_id);return sourceComponent?.ftype==="simple_capacitor"?sourceComponent.max_decoupling_trace_length:null}).filter(length7=>length7!==null);if(capacitorMaxLengths.length!==0)return Math.min(...capacitorMaxLengths)};function getTraceDisplayName({ports,nets}){if(ports.length>=2)return`${ports[0]?.selector} to ${ports[1]?.selector}`;if(ports.length===1&&nets.length===1)return`${ports[0]?.selector} to net.${nets[0]._parsedProps.name}`}var getPcbBoardOutlinePolygon=pcbBoard=>pcbBoard.outline&&pcbBoard.outline.length>0?new Polygon$1(pcbBoard.outline.map(p4=>point4(p4.x,p4.y))):new Polygon$1(new Box(pcbBoard.center.x-pcbBoard.width/2,pcbBoard.center.y-pcbBoard.height/2,pcbBoard.center.x+pcbBoard.width/2,pcbBoard.center.y+pcbBoard.height/2).toPoints()),isRouteOutsideBoard=({mergedRoute,db:db2,pcbBoardId})=>{let pcbBoard=db2.pcb_board.get(pcbBoardId);if(!pcbBoard)return!1;let boardOutlinePolygon=getPcbBoardOutlinePolygon(pcbBoard);return!mergedRoute.flat().every(routePoint=>boardOutlinePolygon.contains(point4(routePoint.x,routePoint.y)))},isCloseTo2=(a3,b3)=>Math.abs(a3-b3)<1e-4,getObstaclesFromRoute2=(route,source_trace_id,{viaDiameter=.5}={})=>{let obstacles=[];for(let i3=0;i3<route.length-1;i3++){let[start,end]=[route[i3],route[i3+1]],prev=i3-1>=0?route[i3-1]:null,isHorz=isCloseTo2(start.y,end.y),isVert=isCloseTo2(start.x,end.x);if(!isHorz&&!isVert)throw new Error(`getObstaclesFromTrace currently only supports horizontal and vertical traces (not diagonals) Conflicting trace: ${source_trace_id}, start: (${start.x}, ${start.y}), end: (${end.x}, ${end.y})`);let obstacle={type:"rect",layers:[start.layer],center:{x:(start.x+end.x)/2,y:(start.y+end.y)/2},width:isHorz?Math.abs(start.x-end.x):.1,height:isVert?Math.abs(start.y-end.y):.1,connectedTo:[source_trace_id]};if(obstacles.push(obstacle),prev&&prev.layer===start.layer&&start.layer!==end.layer){let via={type:"rect",layers:[start.layer,end.layer],center:{x:start.x,y:start.y},connectedTo:[source_trace_id],width:viaDiameter,height:viaDiameter};obstacles.push(via)}}return obstacles};function fillPolygonWithRects(polygon2,options={}){if(polygon2.length<3)return[];let{rectHeight=.1}=options,rects=[],yCoords=polygon2.map(p4=>p4.y),minY=Math.min(...yCoords),maxY=Math.max(...yCoords);for(let y4=minY;y4<maxY;y4+=rectHeight){let scanlineY=y4+rectHeight/2,intersections=[];for(let i3=0;i3<polygon2.length;i3++){let p12=polygon2[i3],p22=polygon2[(i3+1)%polygon2.length];if(p12.y<=scanlineY&&p22.y>scanlineY||p22.y<=scanlineY&&p12.y>scanlineY){let x4=(scanlineY-p12.y)*(p22.x-p12.x)/(p22.y-p12.y)+p12.x;intersections.push(x4)}}intersections.sort((a3,b3)=>a3-b3);for(let i3=0;i3<intersections.length;i3+=2)if(i3+1<intersections.length){let x12=intersections[i3],width=intersections[i3+1]-x12;width>1e-6&&rects.push({center:{x:x12+width/2,y:scanlineY},width,height:rectHeight})}}return rects}function fillCircleWithRects(circle2,options={}){let{center:center2,radius}=circle2,{rectHeight=.1}=options,rects=[],numSlices=Math.ceil(radius*2/rectHeight);for(let i3=0;i3<numSlices;i3++){let y4=center2.y-radius+(i3+.5)*rectHeight,dy3=y4-center2.y,halfWidth=Math.sqrt(radius*radius-dy3*dy3);halfWidth>0&&rects.push({center:{x:center2.x,y:y4},width:halfWidth*2,height:rectHeight})}return rects}var EVERY_LAYER2=["top","inner1","inner2","bottom"],QUARTER_TURN_TOLERANCE_DEGREES=.01,getAxisAlignedRectFromRotatedRect=rotatedRect=>{let normalizedRotation=(rotatedRect.rotation%360+360)%360,axisAlignedAngles=[0,90,180,270];for(let angle of axisAlignedAngles){if(Math.min(Math.abs(normalizedRotation-angle),360-Math.abs(normalizedRotation-angle))>QUARTER_TURN_TOLERANCE_DEGREES)continue;let isVertical3=angle===90||angle===270;return{center:rotatedRect.center,width:isVertical3?rotatedRect.height:rotatedRect.width,height:isVertical3?rotatedRect.width:rotatedRect.height}}return null},getObstaclesFromCircuitJson2=(soup,connMap)=>{let withNetId=idList=>connMap?idList.concat(idList.map(id2=>connMap?.getNetConnectedToId(id2)).filter(Boolean)):idList,obstacles=[];for(let element of soup)if(element.type==="pcb_smtpad")if(element.shape==="circle")obstacles.push({type:"oval",layers:[element.layer],center:{x:element.x,y:element.y},width:element.radius*2,height:element.radius*2,connectedTo:withNetId([element.pcb_smtpad_id])});else if(element.shape==="rect")obstacles.push({type:"rect",layers:[element.layer],center:{x:element.x,y:element.y},width:element.width,height:element.height,connectedTo:withNetId([element.pcb_smtpad_id])});else if(element.shape==="rotated_rect"){let rotatedRect={center:{x:element.x,y:element.y},width:element.width,height:element.height,rotation:element.ccw_rotation},rect=getAxisAlignedRectFromRotatedRect(rotatedRect)??rotatedRect;obstacles.push({type:"rect",layers:[element.layer],center:rect.center,width:rect.width,height:rect.height,ccwRotationDegrees:element.ccw_rotation,connectedTo:withNetId([element.pcb_smtpad_id])})}else(element.shape==="pill"||element.shape==="rotated_pill")&&obstacles.push({type:"rect",layers:[element.layer],center:{x:element.x,y:element.y},width:element.width,height:element.height,...element.shape==="rotated_pill"?{ccwRotationDegrees:element.ccw_rotation}:{},connectedTo:withNetId([element.pcb_smtpad_id])});else if(element.type==="pcb_keepout")element.shape==="circle"?obstacles.push({type:"oval",layers:element.layers,center:{x:element.center.x,y:element.center.y},width:element.radius*2,height:element.radius*2,connectedTo:[]}):element.shape==="rect"&&obstacles.push({type:"rect",layers:element.layers,center:{x:element.center.x,y:element.center.y},width:element.width,height:element.height,connectedTo:[]});else if(element.type==="pcb_cutout"){if(element.shape==="rect")obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:element.center.x,y:element.center.y},width:element.width,height:element.height,connectedTo:[]});else if(element.shape==="circle"){let approximatingRects=fillCircleWithRects({center:element.center,radius:element.radius},{rectHeight:.6});for(let rect of approximatingRects)obstacles.push({type:"rect",layers:EVERY_LAYER2,center:rect.center,width:rect.width,height:rect.height,connectedTo:[]})}else if(element.shape==="polygon"){let approximatingRects=fillPolygonWithRects(element.points,{rectHeight:.6});for(let rect of approximatingRects)obstacles.push({type:"rect",layers:EVERY_LAYER2,center:rect.center,width:rect.width,height:rect.height,connectedTo:[]})}}else if(element.type==="pcb_hole")element.hole_shape==="oval"?obstacles.push({type:"oval",center:{x:element.x,y:element.y},width:element.hole_width,height:element.hole_height,connectedTo:[]}):element.hole_shape==="pill"||element.hole_shape==="rotated_pill"?obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.hole_width,height:element.hole_height,...element.hole_shape==="rotated_pill"?{ccwRotationDegrees:element.ccw_rotation}:{},connectedTo:[]}):element.hole_shape==="rect"?obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.hole_width,height:element.hole_height,connectedTo:[]}):element.hole_shape==="square"?obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.hole_diameter,height:element.hole_diameter,connectedTo:[]}):(element.hole_shape==="round"||element.hole_shape==="circle")&&obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.hole_diameter,height:element.hole_diameter,connectedTo:[]});else if(element.type==="pcb_plated_hole"){if(element.shape==="circle")obstacles.push({type:"oval",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.outer_diameter,height:element.outer_diameter,connectedTo:withNetId([element.pcb_plated_hole_id])});else if(element.shape==="circular_hole_with_rect_pad")obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.rect_pad_width,height:element.rect_pad_height,connectedTo:withNetId([element.pcb_plated_hole_id])});else if(element.shape==="oval")obstacles.push({type:"oval",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.outer_width,height:element.outer_height,connectedTo:withNetId([element.pcb_plated_hole_id])});else if(element.shape==="pill")obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:element.x,y:element.y},width:element.outer_width,height:element.outer_height,ccwRotationDegrees:element.ccw_rotation,connectedTo:withNetId([element.pcb_plated_hole_id])});else if(element.shape==="hole_with_polygon_pad"&&"pad_outline"in element&&element.pad_outline&&element.pad_outline.length>0){let xs3=element.pad_outline.map(p4=>element.x+p4.x),ys3=element.pad_outline.map(p4=>element.y+p4.y),minX=Math.min(...xs3),maxX=Math.max(...xs3),minY=Math.min(...ys3),maxY=Math.max(...ys3),centerX=(minX+maxX)/2,centerY=(minY+maxY)/2;obstacles.push({type:"rect",layers:EVERY_LAYER2,center:{x:centerX,y:centerY},width:maxX-minX,height:maxY-minY,connectedTo:withNetId([element.pcb_plated_hole_id])})}}else if(element.type==="pcb_trace"){let traceObstacles=getObstaclesFromRoute2(element.route.map(rp3=>({x:rp3.x,y:rp3.y,layer:"layer"in rp3?rp3.layer:rp3.from_layer})),element.source_trace_id);obstacles.push(...traceObstacles)}else if(element.type==="pcb_via"){let netIsAssignable=!!(element.net_is_assignable??element.netIsAssignable);obstacles.push({type:"rect",layers:element.layers,center:{x:element.x,y:element.y},connectedTo:withNetId([element.pcb_via_id]),width:element.outer_diameter,height:element.outer_diameter,netIsAssignable:netIsAssignable||void 0})}return obstacles},computeSchematicNetLabelCenter=({anchor_position,anchor_side,text,font_size=.18})=>{let charWidth=.1*(font_size/.18),width=text.length*charWidth,height=font_size,center2={...anchor_position};switch(anchor_side){case"right":center2.x-=width/2;break;case"left":center2.x+=width/2;break;case"top":center2.y-=height/2;break;case"bottom":center2.y+=height/2;break}return center2},getOtherSchematicTraces=({db:db2,source_trace_id,sameNetOnly,differentNetOnly})=>{!sameNetOnly&&!differentNetOnly&&(differentNetOnly=!0);let mySourceTrace=db2.source_trace.get(source_trace_id),traces=[];for(let otherSchematicTrace of db2.schematic_trace.list()){if(otherSchematicTrace.source_trace_id===source_trace_id)continue;let isSameNet=db2.source_trace.get(otherSchematicTrace.source_trace_id)?.subcircuit_connectivity_map_key===mySourceTrace.subcircuit_connectivity_map_key;differentNetOnly&&isSameNet||sameNetOnly&&!isSameNet||traces.push(otherSchematicTrace)}return traces},createSchematicTraceCrossingSegments=({edges:inputEdges,otherEdges})=>{let edges=[...inputEdges];for(let i3=0;i3<edges.length;i3++){if(i3>2e3)throw new Error("Over 2000 iterations spent inside createSchematicTraceCrossingSegments, you have triggered an infinite loop, please report this!");let edge=edges[i3],edgeOrientation=Math.abs(edge.from.x-edge.to.x)<.01?"vertical":edge.from.y===edge.to.y?"horizontal":"not-orthogonal";if(edgeOrientation==="not-orthogonal")continue;let otherEdgesIntersections=[];for(let otherEdge of otherEdges){let otherOrientation=otherEdge.from.x===otherEdge.to.x?"vertical":otherEdge.from.y===otherEdge.to.y?"horizontal":"not-orthogonal";if(otherOrientation==="not-orthogonal"||edgeOrientation===otherOrientation)continue;if(doesLineIntersectLine([edge.from,edge.to],[otherEdge.from,otherEdge.to],{lineThickness:.01})){let intersectX=edgeOrientation==="vertical"?edge.from.x:otherEdge.from.x,intersectY=edgeOrientation==="vertical"?otherEdge.from.y:edge.from.y,crossingPoint2={x:intersectX,y:intersectY};otherEdgesIntersections.push({otherEdge,crossingPoint:crossingPoint2,distanceFromEdgeFrom:distance2(edge.from,crossingPoint2)})}}if(otherEdgesIntersections.length===0)continue;let closestIntersection=otherEdgesIntersections[0];for(let intersection of otherEdgesIntersections)intersection.distanceFromEdgeFrom<closestIntersection.distanceFromEdgeFrom&&(closestIntersection=intersection);let crossingPoint=closestIntersection.crossingPoint,crossingSegmentLength=.075;if(crossingPoint.x===edge.from.x&&crossingPoint.y===edge.from.y)continue;let crossingUnitVec=getUnitVectorFromPointAToB(edge.from,crossingPoint),beforeCrossing={x:crossingPoint.x-crossingUnitVec.x*crossingSegmentLength/2,y:crossingPoint.y-crossingUnitVec.y*crossingSegmentLength/2},afterCrossing={x:crossingPoint.x+crossingUnitVec.x*crossingSegmentLength/2,y:crossingPoint.y+crossingUnitVec.y*crossingSegmentLength/2},overshot=distance2(afterCrossing,edge.to)<crossingSegmentLength,newEdges=[{from:edge.from,to:beforeCrossing},{from:beforeCrossing,to:afterCrossing,is_crossing:!0},{from:afterCrossing,to:edge.to}];edges.splice(i3,1,...newEdges),i3+=newEdges.length-2,overshot&&i3++}return edges},TOLERANCE=.001,isPointWithinEdge=(point62,edge)=>{let minX=Math.min(edge.from.x,edge.to.x),maxX=Math.max(edge.from.x,edge.to.x),minY=Math.min(edge.from.y,edge.to.y),maxY=Math.max(edge.from.y,edge.to.y);return point62.x>=minX&&point62.x<=maxX&&point62.y>=minY&&point62.y<=maxY},getEdgeOrientation=edge=>{let isVertical3=Math.abs(edge.from.x-edge.to.x)<TOLERANCE,isHorizontal2=Math.abs(edge.from.y-edge.to.y)<TOLERANCE;return isVertical3?"vertical":isHorizontal2?"horizontal":"diagonal"},getIntersectionPoint=(edge1,edge2)=>{let orientation1=getEdgeOrientation(edge1),orientation22=getEdgeOrientation(edge2);if(orientation1===orientation22)return null;if(orientation1==="vertical"&&orientation22==="horizontal"||orientation1==="horizontal"&&orientation22==="vertical"){let verticalEdge=orientation1==="vertical"?edge1:edge2,horizontalEdge=orientation1==="horizontal"?edge1:edge2,x22=verticalEdge.from.x,y22=horizontalEdge.from.y,intersection2={x:x22,y:y22};return isPointWithinEdge(intersection2,edge1)&&isPointWithinEdge(intersection2,edge2)?intersection2:null}if(orientation1==="vertical"||orientation22==="vertical"){let verticalEdge=orientation1==="vertical"?edge1:edge2,diagonalEdge=orientation1==="vertical"?edge2:edge1,x22=verticalEdge.from.x,m4=(diagonalEdge.to.y-diagonalEdge.from.y)/(diagonalEdge.to.x-diagonalEdge.from.x),b3=diagonalEdge.from.y-m4*diagonalEdge.from.x,y22=m4*x22+b3,intersection2={x:x22,y:y22};return isPointWithinEdge(intersection2,edge1)&&isPointWithinEdge(intersection2,edge2)?intersection2:null}let m12=(edge1.to.y-edge1.from.y)/(edge1.to.x-edge1.from.x),b12=edge1.from.y-m12*edge1.from.x,m22=(edge2.to.y-edge2.from.y)/(edge2.to.x-edge2.from.x),b22=edge2.from.y-m22*edge2.from.x;if(Math.abs(m12-m22)<TOLERANCE)return null;let x4=(b22-b12)/(m12-m22),y4=m12*x4+b12,intersection={x:x4,y:y4};return isPointWithinEdge(intersection,edge1)&&isPointWithinEdge(intersection,edge2)?intersection:null},createSchematicTraceJunctions=({edges:myEdges,db:db2,source_trace_id})=>{let otherEdges=getOtherSchematicTraces({db:db2,source_trace_id,sameNetOnly:!0}).flatMap(t52=>t52.edges),junctions=new Map;for(let myEdge of myEdges)for(let otherEdge of otherEdges){let intersection=getIntersectionPoint(myEdge,otherEdge);if(intersection){let key=`${intersection.x.toFixed(6)},${intersection.y.toFixed(6)}`;junctions.has(key)||junctions.set(key,intersection)}}return Array.from(junctions.values())};function normalizeAngle(angle){let normalized=angle%360;return normalized<0?normalized+360:normalized}function isAngleBetween(angle,start,end,direction2){return direction2==="counterclockwise"?end>=start?angle>=start&&angle<=end:angle>=start||angle<=end:end<=start?angle<=start&&angle>=end:angle<=start||angle>=end}function getArcBounds(elm){let center2=elm.center,radius=elm.radius,startAngle=elm.start_angle_degrees,endAngle=elm.end_angle_degrees,direction2=elm.direction??"counterclockwise";if(!center2||typeof center2.x!="number"||typeof center2.y!="number"||typeof radius!="number"||typeof startAngle!="number"||typeof endAngle!="number")return null;let start=normalizeAngle(startAngle),end=normalizeAngle(endAngle),consideredAngles=new Set([start,end]),cardinalAngles=[0,90,180,270];for(let cardinal of cardinalAngles)isAngleBetween(cardinal,start,end,direction2)&&consideredAngles.add(cardinal);let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let angle of consideredAngles){let radians=angle*Math.PI/180,x4=center2.x+radius*Math.cos(radians),y4=center2.y+radius*Math.sin(radians);minX=Math.min(minX,x4),maxX=Math.max(maxX,x4),minY=Math.min(minY,y4),maxY=Math.max(maxY,y4)}return!Number.isFinite(minX)||!Number.isFinite(minY)?null:{minX,maxX,minY,maxY}}function getBoundsForSchematic(db2){let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let elm of db2){let cx3,cy3,w4,h6;if(elm.type==="schematic_component")cx3=elm.center?.x,cy3=elm.center?.y,w4=elm.size?.width,h6=elm.size?.height;else if(elm.type==="schematic_box")cx3=elm.x,cy3=elm.y,w4=elm.width,h6=elm.height;else if(elm.type==="schematic_port")cx3=elm.center?.x,cy3=elm.center?.y,w4=.2,h6=.2;else if(elm.type==="schematic_text")cx3=elm.position?.x,cy3=elm.position?.y,w4=(elm.text?.length??0)*.1,h6=.2;else if(elm.type==="schematic_line"){let x12=elm.x1??0,y12=elm.y1??0,x22=elm.x2??0,y22=elm.y2??0;cx3=(x12+x22)/2,cy3=(y12+y22)/2,w4=Math.abs(x22-x12),h6=Math.abs(y22-y12)}else if(elm.type==="schematic_rect")cx3=elm.center?.x,cy3=elm.center?.y,w4=elm.width,h6=elm.height;else if(elm.type==="schematic_circle"){cx3=elm.center?.x,cy3=elm.center?.y;let radius=elm.radius;typeof radius=="number"&&(w4=radius*2,h6=radius*2)}else if(elm.type==="schematic_arc"){let bounds=getArcBounds(elm);bounds&&(minX=Math.min(minX,bounds.minX),maxX=Math.max(maxX,bounds.maxX),minY=Math.min(minY,bounds.minY),maxY=Math.max(maxY,bounds.maxY));continue}else if(elm.type==="schematic_path"){let points=elm.points;if(Array.isArray(points))for(let point62 of points)typeof point62.x=="number"&&typeof point62.y=="number"&&(minX=Math.min(minX,point62.x),maxX=Math.max(maxX,point62.x),minY=Math.min(minY,point62.y),maxY=Math.max(maxY,point62.y));continue}typeof cx3=="number"&&typeof cy3=="number"&&typeof w4=="number"&&typeof h6=="number"&&(minX=Math.min(minX,cx3-w4/2),maxX=Math.max(maxX,cx3+w4/2),minY=Math.min(minY,cy3-h6/2),maxY=Math.max(maxY,cy3+h6/2))}return{minX,maxX,minY,maxY}}function getObstaclesFromBounds(bounds,opts={}){let{minX,maxX,minY,maxY}=bounds,PADDING=opts.padding??1;if(!isFinite(minX)||!isFinite(maxX)||!isFinite(minY)||!isFinite(maxY))return[];let left=minX-PADDING,right=maxX+PADDING,top=maxY+PADDING,bottom=minY-PADDING,thickness=.01;return[{type:"rect",layers:["top"],center:{x:(left+right)/2,y:top},width:right-left,height:thickness,connectedTo:[]},{type:"rect",layers:["top"],center:{x:(left+right)/2,y:bottom},width:right-left,height:thickness,connectedTo:[]},{type:"rect",layers:["top"],center:{x:left,y:(top+bottom)/2},width:thickness,height:top-bottom,connectedTo:[]},{type:"rect",layers:["top"],center:{x:right,y:(top+bottom)/2},width:thickness,height:top-bottom,connectedTo:[]}]}var getSchematicObstaclesForTrace=trace=>{let db2=trace.root.db,connectedPorts=trace._findConnectedPorts().ports??[],connectedPortIds=new Set(connectedPorts.map(p4=>p4.schematic_port_id)),obstacles=[];for(let elm of db2.toArray()){if(elm.type==="schematic_component"){let isSymbol3=!!elm.symbol_name,dominateAxis=elm.size.width>elm.size.height?"horz":"vert";obstacles.push({type:"rect",layers:["top"],center:elm.center,width:elm.size.width+(isSymbol3&&dominateAxis==="horz"?-.5:0),height:elm.size.height+(isSymbol3&&dominateAxis==="vert"?-.5:0),connectedTo:[]})}if(elm.type==="schematic_port"){if(connectedPortIds.has(elm.schematic_port_id))continue;let dirVec=elm.facing_direction?getUnitVectorFromDirection(elm.facing_direction):{x:0,y:0};obstacles.push({type:"rect",layers:["top"],center:{x:elm.center.x-dirVec.x*.1,y:elm.center.y-dirVec.y*.1},width:.1+Math.abs(dirVec.x)*.3,height:.1+Math.abs(dirVec.y)*.3,connectedTo:[]})}elm.type==="schematic_text"&&obstacles.push({type:"rect",layers:["top"],center:elm.position,width:(elm.text?.length??0)*.1,height:.2,connectedTo:[]}),elm.type==="schematic_box"&&obstacles.push({type:"rect",layers:["top"],center:{x:elm.x,y:elm.y},width:elm.width,height:elm.height,connectedTo:[]})}let bounds=getBoundsForSchematic(db2.toArray());return obstacles.push(...getObstaclesFromBounds(bounds,{padding:1})),obstacles},pushEdgesOfSchematicTraceToPreventOverlap=({edges,db:db2,source_trace_id})=>{let mySourceTrace=db2.source_trace.get(source_trace_id),otherEdges=getOtherSchematicTraces({db:db2,source_trace_id,differentNetOnly:!0}).flatMap(t52=>t52.edges),edgeOrientation=edge=>{let{from,to:to3}=edge;return from.x===to3.x?"vertical":"horizontal"};for(let mySegment of edges){let mySegmentOrientation=edgeOrientation(mySegment),findOverlappingParallelSegment=()=>otherEdges.find(otherEdge=>edgeOrientation(otherEdge)===mySegmentOrientation&&doesLineIntersectLine([mySegment.from,mySegment.to],[otherEdge.from,otherEdge.to],{lineThickness:.05})),overlappingParallelSegmentFromOtherTrace=findOverlappingParallelSegment();for(;overlappingParallelSegmentFromOtherTrace;)mySegmentOrientation==="horizontal"?(mySegment.from.y+=.1,mySegment.to.y+=.1):(mySegment.from.x+=.1,mySegment.to.x+=.1),overlappingParallelSegmentFromOtherTrace=findOverlappingParallelSegment()}},convertFacingDirectionToElbowDirection=facingDirection=>{switch(facingDirection){case"up":return"y+";case"down":return"y-";case"left":return"x-";case"right":return"x+";default:}},autorouterVersion=package_default.version??"unknown",AutorouterError=class extends Error{constructor(message){super(`${message} (capacity-autorouter@${autorouterVersion})`),this.name="AutorouterError"}},TraceConnectionError=class extends Error{constructor(errorData){super(errorData.message);__publicField(this,"errorData");this.errorData=errorData,this.name="TraceConnectionError"}},Trace_doInitialSchematicTraceRender=trace=>{if(trace.root?._featureMspSchematicTraceRouting||trace._couldNotFindPort||trace.root?.schematicDisabled||trace.getCollapsedSchematicBoxAncestor())return;let{db:db2}=trace.root,{_parsedProps:props,parent}=trace;if(!parent)throw new Error("Trace has no parent");let allPortsFound,connectedPorts;try{let result=trace._findConnectedPorts();allPortsFound=result.allPortsFound,connectedPorts=result.portsWithSelectors??[]}catch(error2){if(error2 instanceof TraceConnectionError){db2.source_trace_not_connected_error.insert({...error2.errorData,error_type:"source_trace_not_connected_error"});return}throw error2}let{netsWithSelectors}=trace._findConnectedNets();if(!allPortsFound)return;let portPairKey=connectedPorts.map(p4=>p4.port.schematic_port_id).sort().join(","),board=trace.root?._getBoard();if(board?._connectedSchematicPortPairs&&board._connectedSchematicPortPairs.has(portPairKey))return;let connection={name:trace.source_trace_id,pointsToConnect:[]},obstacles=getSchematicObstaclesForTrace(trace),portsWithPosition=connectedPorts.filter(({port})=>port.schematic_port_id!==null).map(({port})=>({port,position:port._getGlobalSchematicPositionAfterLayout(),schematic_port_id:port.schematic_port_id??void 0,facingDirection:port.facingDirection}));if(portsWithPosition.length===1&&netsWithSelectors.length===1){let net=netsWithSelectors[0].net,{port,position:anchorPos}=portsWithPosition[0],connectedNetLabel=trace.getSubcircuit().selectAll("netlabel").find(nl3=>{let conn=nl3._parsedProps.connection??nl3._parsedProps.connectsTo;return conn?Array.isArray(conn)?conn.some(selector=>trace.getSubcircuit().selectOne(selector,{port:!0})===port):trace.getSubcircuit().selectOne(conn,{port:!0})===port:!1});if(!connectedNetLabel){let dbNetLabel=db2.schematic_net_label.getWhere({source_trace_id:trace.source_trace_id});dbNetLabel&&(connectedNetLabel=dbNetLabel)}if(connectedNetLabel){let labelPos="_getGlobalSchematicPositionBeforeLayout"in connectedNetLabel?connectedNetLabel._getGlobalSchematicPositionBeforeLayout():connectedNetLabel.anchor_position,edges2=[];anchorPos.x===labelPos.x||anchorPos.y===labelPos.y?edges2.push({from:anchorPos,to:labelPos}):(edges2.push({from:anchorPos,to:{x:labelPos.x,y:anchorPos.y}}),edges2.push({from:{x:labelPos.x,y:anchorPos.y},to:labelPos}));let dbTrace2=db2.schematic_trace.insert({source_trace_id:trace.source_trace_id,edges:edges2,junctions:[],subcircuit_connectivity_map_key:trace.subcircuit_connectivity_map_key??void 0});trace.schematic_trace_id=dbTrace2.schematic_trace_id;return}if(trace.props.schDisplayLabel){let side2=getEnteringEdgeFromDirection(port.facingDirection)??"bottom";db2.schematic_net_label.insert({text:trace.props.schDisplayLabel,source_net_id:net.source_net_id,anchor_position:anchorPos,center:computeSchematicNetLabelCenter({anchor_position:anchorPos,anchor_side:side2,text:trace.props.schDisplayLabel}),anchor_side:side2});return}let side=getEnteringEdgeFromDirection(port.facingDirection)??"bottom",netLabel=db2.schematic_net_label.insert({text:net._parsedProps.name,source_net_id:net.source_net_id,anchor_position:anchorPos,center:computeSchematicNetLabelCenter({anchor_position:anchorPos,anchor_side:side,text:net._parsedProps.name}),anchor_side:side});return}if(trace.props.schDisplayLabel&&("from"in trace.props&&"to"in trace.props||"path"in trace.props)){trace._doInitialSchematicTraceRenderWithDisplayLabel();return}if(portsWithPosition.length<2)return;let edges=(()=>{let elbowEdges=[];for(let i3=0;i3<portsWithPosition.length-1;i3++){let start=portsWithPosition[i3],end=portsWithPosition[i3+1],path=calculateElbow({x:start.position.x,y:start.position.y,facingDirection:convertFacingDirectionToElbowDirection(start.facingDirection)},{x:end.position.x,y:end.position.y,facingDirection:convertFacingDirectionToElbowDirection(end.facingDirection)});for(let j4=0;j4<path.length-1;j4++)elbowEdges.push({from:path[j4],to:path[j4+1]})}let doesSegmentIntersectRect2=(edge,rect)=>{let halfW=rect.width/2,halfH=rect.height/2,left=rect.center.x-halfW,right=rect.center.x+halfW,top=rect.center.y-halfH,bottom=rect.center.y+halfH,inRect=p4=>p4.x>=left&&p4.x<=right&&p4.y>=top&&p4.y<=bottom;return inRect(edge.from)||inRect(edge.to)?!0:[[{x:left,y:top},{x:right,y:top}],[{x:right,y:top},{x:right,y:bottom}],[{x:right,y:bottom},{x:left,y:bottom}],[{x:left,y:bottom},{x:left,y:top}]].some(r5=>doesLineIntersectLine([edge.from,edge.to],r5,{lineThickness:0}))};for(let edge of elbowEdges)for(let obstacle of obstacles)if(doesSegmentIntersectRect2(edge,obstacle))return null;return elbowEdges})();edges&&edges.length===0&&(edges=null),connection.pointsToConnect=portsWithPosition.map(({position:position4})=>({...position4,layer:"top"}));let bounds=computeObstacleBounds(obstacles),BOUNDS_MARGIN=2,simpleRouteJsonInput={minTraceWidth:.1,obstacles,connections:[connection],bounds:{minX:bounds.minX-BOUNDS_MARGIN,maxX:bounds.maxX+BOUNDS_MARGIN,minY:bounds.minY-BOUNDS_MARGIN,maxY:bounds.maxY+BOUNDS_MARGIN},layerCount:1},Autorouter=MultilayerIjump,skipOtherTraceInteraction=!1;if(trace.getSubcircuit().props._schDirectLineRoutingEnabled&&(Autorouter=DirectLineRouter,skipOtherTraceInteraction=!0),!edges){let results=new Autorouter({input:simpleRouteJsonInput,MAX_ITERATIONS:100,OBSTACLE_MARGIN:.1,isRemovePathLoopsEnabled:!0,isShortenPathWithShortcutsEnabled:!0,marginsWithCosts:[{margin:1,enterCost:0,travelCostFactor:1},{margin:.3,enterCost:0,travelCostFactor:1},{margin:.2,enterCost:0,travelCostFactor:2},{margin:.1,enterCost:0,travelCostFactor:3}]}).solveAndMapToTraces();if(results.length===0){if(trace._isSymbolToChipConnection()||trace._isSymbolToSymbolConnection()||trace._isChipToChipConnection()){trace._doInitialSchematicTraceRenderWithDisplayLabel();return}results=new DirectLineRouter({input:simpleRouteJsonInput}).solveAndMapToTraces(),skipOtherTraceInteraction=!0}let[{route}]=results;edges=[];let wireAndViaRoutes=route.filter(r5=>r5.route_type==="wire"||r5.route_type==="via");for(let i3=0;i3<wireAndViaRoutes.length-1;i3++)edges.push({from:wireAndViaRoutes[i3],to:wireAndViaRoutes[i3+1]})}let source_trace_id=trace.source_trace_id,junctions=[];if(!skipOtherTraceInteraction){pushEdgesOfSchematicTraceToPreventOverlap({edges,db:db2,source_trace_id});let otherEdges=getOtherSchematicTraces({db:db2,source_trace_id,differentNetOnly:!0}).flatMap(t52=>t52.edges);edges=createSchematicTraceCrossingSegments({edges,otherEdges}),junctions=createSchematicTraceJunctions({edges,db:db2,source_trace_id:trace.source_trace_id})}if(!edges||edges.length===0)return;let lastEdge=edges[edges.length-1],lastEdgePort=portsWithPosition[portsWithPosition.length-1],lastDominantDirection=getDominantDirection(lastEdge);edges.push(...getStubEdges({lastEdge,lastEdgePort,lastDominantDirection}));let firstEdge=edges[0],firstEdgePort=portsWithPosition[0],firstDominantDirection=getDominantDirection(firstEdge);if(edges.unshift(...getStubEdges({firstEdge,firstEdgePort,firstDominantDirection})),!trace.source_trace_id)throw new Error("Missing source_trace_id for schematic trace insertion.");if(trace.getSubcircuit()._parsedProps.schTraceAutoLabelEnabled&&countComplexElements(junctions,edges)>=5&&(trace._isSymbolToChipConnection()||trace._isSymbolToSymbolConnection()||trace._isChipToChipConnection())){trace._doInitialSchematicTraceRenderWithDisplayLabel();return}let dbTrace=db2.schematic_trace.insert({source_trace_id:trace.source_trace_id,edges,junctions,subcircuit_connectivity_map_key:trace.subcircuit_connectivity_map_key??void 0});trace.schematic_trace_id=dbTrace.schematic_trace_id;for(let{port}of connectedPorts)port.schematic_port_id&&db2.schematic_port.update(port.schematic_port_id,{is_connected:!0});board?._connectedSchematicPortPairs&&board._connectedSchematicPortPairs.add(portPairKey)};function getTraceLength(route){let totalLength=0;for(let i3=0;i3<route.length;i3++){let point62=route[i3];if(point62.route_type==="wire"){let nextPoint=route[i3+1];if(nextPoint){let dx3=nextPoint.x-point62.x,dy3=nextPoint.y-point62.y;totalLength+=Math.sqrt(dx3*dx3+dy3*dy3)}}else point62.route_type==="via"&&(totalLength+=1.6)}return totalLength}var DEFAULT_VIA_HOLE_DIAMETER=.2,DEFAULT_VIA_PAD_DIAMETER=.3,parseDistance=(value,fallback)=>{if(value===void 0)return fallback;if(typeof value=="number")return value;let parsed=parseFloat(value);return Number.isFinite(parsed)?parsed:fallback},getViaDiameterDefaults=pcbStyle2=>({holeDiameter:parseDistance(pcbStyle2?.viaHoleDiameter,DEFAULT_VIA_HOLE_DIAMETER),padDiameter:parseDistance(pcbStyle2?.viaPadDiameter,DEFAULT_VIA_PAD_DIAMETER)}),getViaDiameterDefaultsWithOverrides=(overrides,pcbStyle2)=>{let defaults=getViaDiameterDefaults(pcbStyle2);return{holeDiameter:overrides.holeDiameter??defaults.holeDiameter,padDiameter:overrides.padDiameter??defaults.padDiameter}},areAllPcbPrimitivesOverlapping=pcbPrimitives=>{if(pcbPrimitives.length<=1)return!0;let bounds=pcbPrimitives.map(p4=>{let circuitBounds=p4._getPcbCircuitJsonBounds();return{left:circuitBounds.bounds.left,right:circuitBounds.bounds.right,top:circuitBounds.bounds.top,bottom:circuitBounds.bounds.bottom}}),overlaps=Array(bounds.length).fill(!1).map(()=>Array(bounds.length).fill(!1));for(let i3=0;i3<bounds.length;i3++)for(let j4=i3+1;j4<bounds.length;j4++){let a3=bounds[i3],b3=bounds[j4];overlaps[i3][j4]=overlaps[j4][i3]=!(a3.right<b3.left||a3.left>b3.right||a3.bottom>b3.top||a3.top<b3.bottom)}let visited=new Set,dfs=node=>{visited.add(node);for(let i3=0;i3<bounds.length;i3++)overlaps[node][i3]&&!visited.has(i3)&&dfs(i3)};return dfs(0),visited.size===bounds.length};function formatPcbPrimitiveForError(component){let aliases2=(component._parsedProps?.portHints??[]).filter(Boolean);return aliases2.length>0?`<${component.lowercaseComponentName}(${aliases2.map(alias=>`.${alias}`).join(", ")}) />`:`<${component.lowercaseComponentName} />`}function getPcbSelectorErrorForTracePort(selector,port){let pcbMatches=port.matchedComponents.filter(c4=>c4.isPcbPrimitive),parentName=port.getParentNormalComponent()?.props.name??port.parent?.props.name??"unknown",parentNormalComponent=port.getParentNormalComponent(),selectorToken=selector.trim().split(/\s+|>/).filter(Boolean).at(-1)?.replace(/^port\./,"").replace(/^\./,"");if(selectorToken&&!/^(pin)?\d+$/.test(selectorToken)){let siblingPorts=(parentNormalComponent?.children??[]).filter(child=>child.componentName==="Port"&&child.isMatchingAnyOf([selectorToken])),matchingPortsAreInternallyConnected=(parentNormalComponent?._getInternallyConnectedPins?.()??[]).some(group=>siblingPorts.every(siblingPort=>group.includes(siblingPort)));if(siblingPorts.length>1&&!matchingPortsAreInternallyConnected){let rawPinSelectors2=Array.from(new Set(siblingPorts.flatMap(siblingPort=>siblingPort.getNameAndAliases().filter(alias=>/^pin\d+$/.test(alias)).map(alias=>`${parentName}.${alias}`)))),suggestion=rawPinSelectors2.length>0?` Use a raw pin selector like ${rawPinSelectors2.map(s3=>`"${s3}"`).join(" or ")}.`:"",siblingPcbMatches=siblingPorts.flatMap(siblingPort=>siblingPort.matchedComponents.filter(component=>component.isPcbPrimitive));return`Trace selector "${selector}" resolved to "${parentName}.${port.props.name}", but alias "${selectorToken}" matches multiple PCB pads: ${siblingPcbMatches.map(component=>formatPcbPrimitiveForError(component)).join(", ")}.${suggestion}`}}if(port.pcb_port_id)return null;let rawPinSelectors=Array.from(new Set(port.getNameAndAliases().filter(alias=>/^pin\d+$/.test(alias)).map(alias=>`${parentName}.${alias}`)));if(pcbMatches.length>1&&!areAllPcbPrimitivesOverlapping(pcbMatches)){let suggestion=rawPinSelectors.length>0?` Use a raw pin selector like ${rawPinSelectors.map(s3=>`"${s3}"`).join(" or ")}.`:"";return`Trace selector "${selector}" resolved to "${parentName}.${port.props.name}", but that target maps to multiple non-overlapping PCB pads: ${pcbMatches.map(c4=>formatPcbPrimitiveForError(c4)).join(", ")}.${suggestion}`}return null}var jlcMinTolerances2={min_trace_width:.1,min_via_hole_edge_to_via_hole_edge_clearance:.1,min_plated_hole_drill_edge_to_drill_edge_clearance:.15,min_trace_to_pad_edge_clearance:.1,min_pad_edge_to_pad_edge_clearance:.1,min_board_edge_clearance:.2,min_via_hole_diameter:.2,min_via_pad_diameter:.3},portToObjective=port=>({...port._getGlobalPcbPositionAfterLayout(),layers:port.getAvailablePcbLayers()}),SHOULD_USE_SINGLE_LAYER_ROUTING=!1;function Trace_doInitialPcbTraceRender(trace){if(trace.root?.pcbDisabled)return;let{db:db2}=trace.root,{_parsedProps:props,parent}=trace,subcircuit=trace.getSubcircuit();if(!parent)throw new Error("Trace has no parent");if(subcircuit._parsedProps.routingDisabled||subcircuit._isInflatedFromCircuitJson)return;let cachedRoute=subcircuit._parsedProps.pcbRouteCache?.pcbTraces;if(cachedRoute){let pcb_trace22=db2.pcb_trace.insert({route:cachedRoute.flatMap(trace2=>trace2.route),source_trace_id:trace.source_trace_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:trace.getGroup()?.pcb_group_id??void 0});trace.pcb_trace_id=pcb_trace22.pcb_trace_id;return}if(props.pcbPath&&props.pcbPath.length>0||props.pcbStraightLine||!subcircuit._shouldUseTraceByTraceRouting())return;let allPortsFound,ports,portsWithSelectors;try{let connectedPorts=trace._findConnectedPorts();allPortsFound=connectedPorts.allPortsFound,ports=connectedPorts.ports??[],portsWithSelectors=connectedPorts.portsWithSelectors??[]}catch(error2){if(error2 instanceof TraceConnectionError){db2.source_trace_not_connected_error.insert({...error2.errorData,error_type:"source_trace_not_connected_error"}),trace._couldNotFindPort=!0;return}throw error2}let portsConnectedOnPcbViaNet=[];if(!allPortsFound)return;let pcbSelectorError=portsWithSelectors.map(({selector,port})=>getPcbSelectorErrorForTracePort(selector,port)).find(Boolean);if(pcbSelectorError){db2.pcb_trace_error.insert({error_type:"pcb_trace_error",source_trace_id:trace.source_trace_id,message:pcbSelectorError,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:ports.map(p4=>p4.pcb_port_id).filter(Boolean)});return}let portsWithoutMatchedPcbPrimitive=[];for(let port of ports)port._hasMatchedPcbPrimitive()||portsWithoutMatchedPcbPrimitive.push(port);if(portsWithoutMatchedPcbPrimitive.length>0){db2.pcb_trace_error.insert({error_type:"pcb_trace_error",source_trace_id:trace.source_trace_id,message:`Some ports did not have a matching PCB primitive (e.g. a pad or plated hole), this can happen if a footprint is missing. As a result, ${trace} wasn't routed. Missing ports: ${portsWithoutMatchedPcbPrimitive.map(p4=>p4.getString()).join(", ")}`,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:portsWithoutMatchedPcbPrimitive.map(p4=>p4.pcb_port_id).filter(Boolean)});return}let nets=trace._findConnectedNets().netsWithSelectors;if(ports.length===0&&nets.length===2){trace.renderError("Trace connects two nets, we haven't implemented a way to route this yet");return}else if(ports.length===1&&nets.length===1){let port=ports[0],otherPortsInNet=nets[0].net.getAllConnectedPorts().filter(p4=>p4!==port);if(otherPortsInNet.length===0){console.log("Nothing to connect this port to, the net is empty. TODO should emit a warning!");return}let closestPortInNet=getClosest(port,otherPortsInNet);portsConnectedOnPcbViaNet.push(closestPortInNet),ports.push(closestPortInNet)}else if(ports.length>1&&nets.length>=1){trace.renderError("Trace has more than one port and one or more nets, we don't currently support this type of complex trace routing");return}let hints=ports.flatMap(port=>port.matchedComponents.filter(c4=>c4.componentName==="TraceHint")),pcbRouteHints=(trace._parsedProps.pcbRouteHints??[]).concat(hints.flatMap(h6=>h6.getPcbRouteHints()));if(ports.length>2){trace.renderError(`Trace has more than two ports (${ports.map(p4=>p4.getString()).join(", ")}), routing between more than two ports for a single trace is not implemented`);return}if(trace.getSubcircuit().selectAll("trace").filter(trace2=>trace2.renderPhaseStates.PcbTraceRender.initialized).some(trace2=>trace2._portsRoutedOnPcb.length===ports.length&&trace2._portsRoutedOnPcb.every(portRoutedByOtherTrace=>ports.includes(portRoutedByOtherTrace))))return;let orderedRouteObjectives=[];pcbRouteHints.length===0?orderedRouteObjectives=[portToObjective(ports[0]),portToObjective(ports[1])]:orderedRouteObjectives=[portToObjective(ports[0]),...pcbRouteHints,portToObjective(ports[1])];let candidateLayerCombinations=findPossibleTraceLayerCombinations(orderedRouteObjectives);if(SHOULD_USE_SINGLE_LAYER_ROUTING&&candidateLayerCombinations.length===0){trace.renderError(`Could not find a common layer (using hints) for trace ${trace.getString()}`);return}let connMap=getFullConnectivityMapFromCircuitJson(trace.root.db.toArray()),[obstacles,errGettingObstacles]=tryNow(()=>getObstaclesFromCircuitJson2(trace.root.db.toArray()));if(errGettingObstacles){trace.renderError({type:"pcb_trace_error",error_type:"pcb_trace_error",pcb_trace_error_id:trace.pcb_trace_id,message:`Error getting obstacles for autorouting: ${errGettingObstacles.message}`,source_trace_id:trace.source_trace_id,center:{x:0,y:0},pcb_port_ids:ports.map(p4=>p4.pcb_port_id),pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[]});return}for(let obstacle of obstacles)if(obstacle.connectedTo.length>0){let netId=connMap.getNetConnectedToId(obstacle.connectedTo[0]);netId&&obstacle.connectedTo.push(netId)}let orderedRoutePoints=[];if(candidateLayerCombinations.length===0)orderedRoutePoints=orderedRouteObjectives;else{let candidateLayerSelections=candidateLayerCombinations[0].layer_path;orderedRoutePoints=orderedRouteObjectives.map((t52,idx)=>t52.via?{...t52,via_to_layer:candidateLayerSelections[idx]}:{...t52,layers:[candidateLayerSelections[idx]]})}orderedRoutePoints[0].pcb_port_id=ports[0].pcb_port_id,orderedRoutePoints[orderedRoutePoints.length-1].pcb_port_id=ports[1].pcb_port_id;let routes=[];for(let[a3,b3]of pairs2(orderedRoutePoints)){let dominantLayer="via_to_layer"in a3?a3.via_to_layer:null,BOUNDS_MARGIN=2,aLayer="layers"in a3&&a3.layers.length===1?a3.layers[0]:dominantLayer??"top",bLayer="layers"in b3&&b3.layers.length===1?b3.layers[0]:dominantLayer??"top",pcbPortA="pcb_port_id"in a3?a3.pcb_port_id:null,pcbPortB="pcb_port_id"in b3?b3.pcb_port_id:null,minTraceWidth=trace._getExplicitTraceThickness()??trace.getSubcircuit()._parsedProps.minTraceWidth??jlcMinTolerances2.min_trace_width,ijump=new MultilayerIjump({OBSTACLE_MARGIN:minTraceWidth*2,isRemovePathLoopsEnabled:!0,optimizeWithGoalBoxes:!!(pcbPortA&&pcbPortB),connMap,input:{obstacles,minTraceWidth,connections:[{name:trace.source_trace_id,pointsToConnect:[{...a3,layer:aLayer,pcb_port_id:pcbPortA},{...b3,layer:bLayer,pcb_port_id:pcbPortB}]}],layerCount:trace.getSubcircuit()._getSubcircuitLayerCount(),bounds:{minX:Math.min(a3.x,b3.x)-BOUNDS_MARGIN,maxX:Math.max(a3.x,b3.x)+BOUNDS_MARGIN,minY:Math.min(a3.y,b3.y)-BOUNDS_MARGIN,maxY:Math.max(a3.y,b3.y)+BOUNDS_MARGIN}}}),traces=null;try{traces=ijump.solveAndMapToTraces()}catch(e5){trace.renderError({type:"pcb_trace_error",pcb_trace_error_id:trace.source_trace_id,error_type:"pcb_trace_error",message:`error solving route: ${e5.message}`,source_trace_id:trace.pcb_trace_id,center:{x:(a3.x+b3.x)/2,y:(a3.y+b3.y)/2},pcb_port_ids:ports.map(p4=>p4.pcb_port_id),pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:ports.map(p4=>p4.pcb_component_id)})}if(!traces)return;if(traces.length===0){trace.renderError({type:"pcb_trace_error",error_type:"pcb_trace_error",pcb_trace_error_id:trace.pcb_trace_id,message:`Could not find a route for ${trace}`,source_trace_id:trace.source_trace_id,center:{x:(a3.x+b3.x)/2,y:(a3.y+b3.y)/2},pcb_port_ids:ports.map(p4=>p4.pcb_port_id),pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:ports.map(p4=>p4.pcb_component_id)});return}let[autoroutedTrace]=traces;dominantLayer&&(autoroutedTrace.route=autoroutedTrace.route.map(p4=>(p4.route_type==="wire"&&!p4.layer&&(p4.layer=dominantLayer),p4))),pcbPortA&&autoroutedTrace.route[0].route_type==="wire"&&(autoroutedTrace.route[0].start_pcb_port_id=pcbPortA);let lastRoutePoint=autoroutedTrace.route[autoroutedTrace.route.length-1];pcbPortB&&lastRoutePoint.route_type==="wire"&&(lastRoutePoint.end_pcb_port_id=pcbPortB),routes.push(autoroutedTrace.route)}let mergedRoute=mergeRoutes(routes),traceLength=getTraceLength(mergedRoute),pcbStyle2=trace.getInheritedMergedProperty("pcbStyle"),{holeDiameter,padDiameter}=getViaDiameterDefaults(pcbStyle2),pcb_trace3=db2.pcb_trace.insert({route:mergedRoute,source_trace_id:trace.source_trace_id,subcircuit_id:trace.getSubcircuit()?.subcircuit_id,trace_length:traceLength});trace._portsRoutedOnPcb=ports,trace.pcb_trace_id=pcb_trace3.pcb_trace_id;for(let point62 of mergedRoute)point62.route_type==="via"&&db2.pcb_via.insert({pcb_trace_id:pcb_trace3.pcb_trace_id,x:point62.x,y:point62.y,hole_diameter:holeDiameter,outer_diameter:padDiameter,layers:[point62.from_layer,point62.to_layer],from_layer:point62.from_layer,to_layer:point62.to_layer});trace._insertErrorIfTraceIsOutsideBoard(mergedRoute,ports)}function computeLineRectIntersection(params){let{lineStart,lineEnd,rectCenter,rectWidth,rectHeight}=params,left=rectCenter.x-rectWidth/2,right=rectCenter.x+rectWidth/2,top=rectCenter.y+rectHeight/2,bottom=rectCenter.y-rectHeight/2,dx3=lineEnd.x-lineStart.x,dy3=lineEnd.y-lineStart.y,intersections=[];if(dx3!==0){let t52=(left-lineStart.x)/dx3;if(t52>=0&&t52<=1){let y4=lineStart.y+t52*dy3;y4>=bottom&&y4<=top&&intersections.push({x:left,y:y4,t:t52})}}if(dx3!==0){let t52=(right-lineStart.x)/dx3;if(t52>=0&&t52<=1){let y4=lineStart.y+t52*dy3;y4>=bottom&&y4<=top&&intersections.push({x:right,y:y4,t:t52})}}if(dy3!==0){let t52=(bottom-lineStart.y)/dy3;if(t52>=0&&t52<=1){let x4=lineStart.x+t52*dx3;x4>=left&&x4<=right&&intersections.push({x:x4,y:bottom,t:t52})}}if(dy3!==0){let t52=(top-lineStart.y)/dy3;if(t52>=0&&t52<=1){let x4=lineStart.x+t52*dx3;x4>=left&&x4<=right&&intersections.push({x:x4,y:top,t:t52})}}return intersections.length===0?null:(intersections.sort((a3,b3)=>a3.t-b3.t),{x:intersections[0].x,y:intersections[0].y})}function computeLineCircleIntersection(params){let{lineStart,lineEnd,circleCenter,circleRadius}=params,x12=lineStart.x-circleCenter.x,y12=lineStart.y-circleCenter.y,x22=lineEnd.x-circleCenter.x,y22=lineEnd.y-circleCenter.y,dx3=x22-x12,dy3=y22-y12,a3=dx3*dx3+dy3*dy3,b3=2*(x12*dx3+y12*dy3),c4=x12*x12+y12*y12-circleRadius*circleRadius,discriminant=b3*b3-4*a3*c4;if(discriminant<0)return null;let sqrtDisc=Math.sqrt(discriminant),t110=(-b3-sqrtDisc)/(2*a3),t210=(-b3+sqrtDisc)/(2*a3),t52=null;return t110>=0&&t110<=1?t52=t110:t210>=0&&t210<=1&&(t52=t210),t52===null?null:{x:lineStart.x+t52*dx3,y:lineStart.y+t52*dy3}}function clipTraceEndAtPad(params){let{traceStart,traceEnd,traceWidth,port}=params,pcbPrimitive=port.matchedComponents.find(c4=>c4.isPcbPrimitive);if(!pcbPrimitive)return traceEnd;let padBounds=pcbPrimitive._getPcbCircuitJsonBounds(),padWidth=padBounds.width,padHeight=padBounds.height,padCenter=padBounds.center,smallestPadDimension=Math.min(padWidth,padHeight);if(traceWidth<=smallestPadDimension/2)return traceEnd;let clippedPoint=null;if(pcbPrimitive.componentName==="SmtPad"){let smtPad=pcbPrimitive,padShape=smtPad._parsedProps.shape;if(padShape==="circle"){let radius=smtPad._parsedProps.radius;clippedPoint=computeLineCircleIntersection({lineStart:traceStart,lineEnd:traceEnd,circleCenter:padCenter,circleRadius:radius})}else(padShape==="rect"||padShape==="rotated_rect"||padShape==="pill"||padShape==="polygon")&&(clippedPoint=computeLineRectIntersection({lineStart:traceStart,lineEnd:traceEnd,rectCenter:padCenter,rectWidth:padWidth,rectHeight:padHeight}))}else if(pcbPrimitive.componentName==="PlatedHole"){let platedHole=pcbPrimitive;if(platedHole._parsedProps.shape==="circle"){let outerDiameter=platedHole._parsedProps.outerDiameter;clippedPoint=computeLineCircleIntersection({lineStart:traceStart,lineEnd:traceEnd,circleCenter:padCenter,circleRadius:outerDiameter/2})}else clippedPoint=computeLineRectIntersection({lineStart:traceStart,lineEnd:traceEnd,rectCenter:padCenter,rectWidth:padWidth,rectHeight:padHeight})}return clippedPoint??traceEnd}function Trace_doInitialPcbManualTraceRender(trace){if(trace.root?.pcbDisabled)return;let{db:db2}=trace.root,{_parsedProps:props}=trace,subcircuit=trace.getSubcircuit(),hasPcbPath=props.pcbPath!==void 0,wantsStraightLine=!!props.pcbStraightLine;if(!hasPcbPath&&!wantsStraightLine)return;let allPortsFound,ports,portsWithSelectors;try{let connectedPorts=trace._findConnectedPorts();allPortsFound=connectedPorts.allPortsFound,ports=connectedPorts.ports??[],portsWithSelectors=connectedPorts.portsWithSelectors??[]}catch(error2){if(error2 instanceof TraceConnectionError){db2.source_trace_not_connected_error.insert({...error2.errorData,error_type:"source_trace_not_connected_error"}),trace._couldNotFindPort=!0;return}throw error2}if(!allPortsFound)return;let pcbSelectorError=portsWithSelectors.map(({selector,port})=>getPcbSelectorErrorForTracePort(selector,port)).find(Boolean);if(pcbSelectorError){db2.pcb_trace_error.insert({error_type:"pcb_trace_error",source_trace_id:trace.source_trace_id,message:pcbSelectorError,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:ports.map(p4=>p4.pcb_port_id).filter(Boolean)});return}let portsWithoutMatchedPcbPrimitive=[];for(let port of ports)port._hasMatchedPcbPrimitive()||portsWithoutMatchedPcbPrimitive.push(port);if(portsWithoutMatchedPcbPrimitive.length>0){db2.pcb_trace_error.insert({error_type:"pcb_trace_error",source_trace_id:trace.source_trace_id,message:`Some ports did not have a matching PCB primitive (e.g. a pad or plated hole), this can happen if a footprint is missing. As a result, ${trace} wasn't routed. Missing ports: ${portsWithoutMatchedPcbPrimitive.map(p4=>p4.getString()).join(", ")}`,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:portsWithoutMatchedPcbPrimitive.map(p4=>p4.pcb_port_id).filter(Boolean)});return}let width=trace._getExplicitTraceThickness()??trace.getSubcircuit()._parsedProps.minTraceWidth??jlcMinTolerances2.min_trace_width;if(wantsStraightLine&&!hasPcbPath){if(!ports||ports.length<2){trace.renderError("pcbStraightLine requires exactly two connected ports");return}let[startPort,endPort]=ports,startLayers=startPort.getAvailablePcbLayers(),endLayers=endPort.getAvailablePcbLayers(),layer2=startLayers.find(layer3=>endLayers.includes(layer3))??startLayers[0]??endLayers[0]??"top",startPos=startPort._getGlobalPcbPositionAfterLayout(),endPos=endPort._getGlobalPcbPositionAfterLayout(),clippedStartPos=clipTraceEndAtPad({traceStart:endPos,traceEnd:startPos,traceWidth:width,port:startPort}),clippedEndPos=clipTraceEndAtPad({traceStart:startPos,traceEnd:endPos,traceWidth:width,port:endPort}),route2=[{route_type:"wire",x:clippedStartPos.x,y:clippedStartPos.y,width,layer:layer2,start_pcb_port_id:startPort.pcb_port_id},{route_type:"wire",x:clippedEndPos.x,y:clippedEndPos.y,width,layer:layer2,end_pcb_port_id:endPort.pcb_port_id}],traceLength2=getTraceLength(route2),pcb_trace22=db2.pcb_trace.insert({route:route2,source_trace_id:trace.source_trace_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:trace.getGroup()?.pcb_group_id??void 0,trace_length:traceLength2});trace._portsRoutedOnPcb=ports,trace.pcb_trace_id=pcb_trace22.pcb_trace_id,trace._insertErrorIfTraceIsOutsideBoard(route2,ports);return}if(!props.pcbPath)return;let anchorPort;props.pcbPathRelativeTo&&(anchorPort=portsWithSelectors.find(p4=>p4.selector===props.pcbPathRelativeTo)?.port,anchorPort||(anchorPort=trace.getSubcircuit().selectOne(props.pcbPathRelativeTo))),anchorPort||(anchorPort=ports[0]);let otherPort=ports.find(p4=>p4!==anchorPort)??ports[1],currentLayer=anchorPort.getAvailablePcbLayers()[0]||"top",anchorPos=anchorPort._getGlobalPcbPositionAfterLayout(),otherPos=otherPort._getGlobalPcbPositionAfterLayout(),route=[];route.push({route_type:"wire",x:anchorPos.x,y:anchorPos.y,width,layer:currentLayer,start_pcb_port_id:anchorPort.pcb_port_id});let transform6=subcircuit._isInflatedFromCircuitJson?trace._computePcbGlobalTransformBeforeLayout():anchorPort?._computePcbGlobalTransformBeforeLayout?.()||identity(),pcbPath2=props.pcbPath;for(let pt3 of pcbPath2){let coordinates,isGlobalPosition=!1,isViaPoint2=typeof pt3!="string"&&pt3.via,viaFromLayer,viaToLayer;if(typeof pt3=="string"){let resolvedPort=trace.getSubcircuit().selectOne(pt3,{type:"port"});if(!resolvedPort){db2.pcb_trace_error.insert({error_type:"pcb_trace_error",source_trace_id:trace.source_trace_id,message:`Could not resolve pcbPath selector "${pt3}" for ${trace}`,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:[]});continue}let pcbTargetError=getPcbSelectorErrorForTracePort(pt3,resolvedPort);if(pcbTargetError){db2.pcb_trace_error.insert({error_type:"pcb_trace_error",source_trace_id:trace.source_trace_id,message:pcbTargetError,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:[]});return}let portPos=resolvedPort._getGlobalPcbPositionAfterLayout();coordinates={x:portPos.x,y:portPos.y},isGlobalPosition=!0}else coordinates={x:pt3.x,y:pt3.y},isGlobalPosition=!1,pt3.via&&(viaFromLayer=pt3.fromLayer??currentLayer,viaToLayer=pt3.toLayer);let finalCoordinates=isGlobalPosition?coordinates:applyToPoint2(transform6,coordinates);isViaPoint2?(route.push({route_type:"via",x:finalCoordinates.x,y:finalCoordinates.y,from_layer:viaFromLayer??currentLayer,to_layer:viaToLayer??currentLayer}),currentLayer=viaToLayer??currentLayer):route.push({route_type:"wire",x:finalCoordinates.x,y:finalCoordinates.y,width,layer:currentLayer})}route.push({route_type:"wire",x:otherPos.x,y:otherPos.y,width,layer:currentLayer,end_pcb_port_id:otherPort.pcb_port_id});let traceLength=getTraceLength(route),pcb_trace3=db2.pcb_trace.insert({route,source_trace_id:trace.source_trace_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:trace.getGroup()?.pcb_group_id??void 0,trace_length:traceLength}),pcbStyle2=trace.getInheritedMergedProperty("pcbStyle"),{holeDiameter,padDiameter}=getViaDiameterDefaults(pcbStyle2);for(let point62 of route)point62.route_type==="via"&&db2.pcb_via.insert({pcb_trace_id:pcb_trace3.pcb_trace_id,x:point62.x,y:point62.y,hole_diameter:holeDiameter,outer_diameter:padDiameter,layers:[point62.from_layer,point62.to_layer],from_layer:point62.from_layer,to_layer:point62.to_layer});trace._portsRoutedOnPcb=ports,trace.pcb_trace_id=pcb_trace3.pcb_trace_id,trace._insertErrorIfTraceIsOutsideBoard(route,ports)}function Trace__doInitialSchematicTraceRenderWithDisplayLabel(trace){if(trace.root?.schematicDisabled)return;let{db:db2}=trace.root,{_parsedProps:props,parent}=trace;if(!parent)throw new Error("Trace has no parent");let{allPortsFound,portsWithSelectors:connectedPorts}=trace._findConnectedPorts();if(!allPortsFound)return;let portsWithPosition=connectedPorts.map(({port})=>({port,position:port._getGlobalSchematicPositionAfterLayout(),schematic_port_id:port.schematic_port_id,facingDirection:port.facingDirection}));if(portsWithPosition.length<2)throw new Error("Expected at least two ports in portsWithPosition.");let fromPortName,toPortName,fromAnchorPos=portsWithPosition[0].position,fromPort=portsWithPosition[0].port;if("path"in trace.props){if(trace.props.path.length!==2)throw new Error("Invalid 'path': Must contain exactly two elements.");[fromPortName,toPortName]=trace.props.path}else{if(!("from"in trace.props&&"to"in trace.props))throw new Error("Missing 'from' or 'to' properties in props.");fromPortName=trace.props.from,toPortName=trace.props.to}if(!fromPort.source_port_id)throw new Error(`Missing source_port_id for the 'from' port (${fromPortName}).`);let toAnchorPos=portsWithPosition[1].position,toPort=portsWithPosition[1].port;if(!toPort.source_port_id)throw new Error(`Missing source_port_id for the 'to' port (${toPortName}).`);let existingFromNetLabel=db2.schematic_net_label.list().find(label=>label.source_net_id===fromPort.source_port_id),existingToNetLabel=db2.schematic_net_label.list().find(label=>label.source_net_id===toPort.source_port_id),[firstPort,secondPort]=connectedPorts.map(({port})=>port),pinFullName=firstPort.parent?.config.shouldRenderAsSchematicBox?`${firstPort?.parent?.props.name}_${firstPort?.props.name}`:`${secondPort?.parent?.props.name}_${secondPort?.props.name}`,netLabelText=trace.props.schDisplayLabel??pinFullName;if(existingFromNetLabel&&existingFromNetLabel.text!==netLabelText&&(existingFromNetLabel.text=`${netLabelText} / ${existingFromNetLabel.text}`),existingToNetLabel&&existingToNetLabel?.text!==netLabelText&&(existingToNetLabel.text=`${netLabelText} / ${existingToNetLabel.text}`),!existingToNetLabel){let toSide=getEnteringEdgeFromDirection(toPort.facingDirection)??"bottom";db2.schematic_net_label.insert({text:trace.props.schDisplayLabel??pinFullName,source_net_id:toPort.source_port_id,anchor_position:toAnchorPos,center:computeSchematicNetLabelCenter({anchor_position:toAnchorPos,anchor_side:toSide,text:trace.props.schDisplayLabel??pinFullName}),anchor_side:toSide})}if(!existingFromNetLabel){let fromSide=getEnteringEdgeFromDirection(fromPort.facingDirection)??"bottom";db2.schematic_net_label.insert({text:trace.props.schDisplayLabel??pinFullName,source_net_id:fromPort.source_port_id,anchor_position:fromAnchorPos,center:computeSchematicNetLabelCenter({anchor_position:fromAnchorPos,anchor_side:fromSide,text:trace.props.schDisplayLabel??pinFullName}),anchor_side:fromSide})}}function Trace__findConnectedPorts(trace){let{_parsedProps:props,parent}=trace;if(!parent)throw new Error("Trace has no parent");let portSelectors=trace.getTracePortPathSelectors(),resolveImplicitSinglePort=selector=>{if(selector.lastIndexOf(".")>selector.lastIndexOf(" "))return null;let targetComponent=trace.getSubcircuit().selectOne(selector);if(!targetComponent&&!/[.#\[]/.test(selector)&&(targetComponent=trace.getSubcircuit().selectOne(`.${selector}`)),!targetComponent)return null;let ports=targetComponent.children.filter(c4=>c4.componentName==="Port");return ports.length===1?ports[0]:null},portsWithSelectors=portSelectors.map(selector=>({selector,port:trace.getSubcircuit().selectOne(selector,{type:"port"})??resolveImplicitSinglePort(selector)}));for(let{selector,port}of portsWithSelectors)if(!port){let parentSelector,portToken,dotIndex=selector.lastIndexOf(".");if(dotIndex!==-1&&dotIndex>selector.lastIndexOf(" "))parentSelector=selector.slice(0,dotIndex),portToken=selector.slice(dotIndex+1);else{let match2=selector.match(/^(.*[ >])?([^ >]+)$/);parentSelector=match2?.[1]?.trim()??"",portToken=match2?.[2]??selector}let targetComponent=parentSelector?trace.getSubcircuit().selectOne(parentSelector):null;if(!targetComponent&&parentSelector&&!/[.#\[]/.test(parentSelector)&&(targetComponent=trace.getSubcircuit().selectOne(`.${parentSelector}`)),!targetComponent){let errorMessage2=parentSelector?`Could not find port for selector "${selector}". Component "${parentSelector}" not found`:`Could not find port for selector "${selector}"`,subcircuit2=trace.getSubcircuit(),sourceGroup2=subcircuit2.getGroup();throw new TraceConnectionError({error_type:"source_trace_not_connected_error",message:errorMessage2,subcircuit_id:subcircuit2.subcircuit_id??void 0,source_group_id:sourceGroup2?.source_group_id??void 0,source_trace_id:trace.source_trace_id??void 0,selectors_not_found:[selector]})}let ports=targetComponent.children.filter(c4=>c4.componentName==="Port"),portLabel=portToken.includes(".")?portToken.split(".").pop()??"":portToken,portNames=ports.flatMap(c4=>c4.getNameAndAliases()),hasCustomLabels=portNames.some(n4=>!/^(pin\d+|\d+)$/.test(n4)),labelList=Array.from(new Set(portNames)).join(", "),detail;ports.length===0?detail="It has no ports":hasCustomLabels?detail=`It has [${labelList}]`:detail=`It has ${ports.length} pins and no pinLabels (consider adding pinLabels)`;let errorMessage=`Could not find port for selector "${selector}". Component "${targetComponent.props.name??parentSelector}" found, but does not have pin "${portLabel}". ${detail}`,subcircuit=trace.getSubcircuit(),sourceGroup=subcircuit.getGroup();throw new TraceConnectionError({error_type:"source_trace_not_connected_error",message:errorMessage,subcircuit_id:subcircuit.subcircuit_id??void 0,source_group_id:sourceGroup?.source_group_id??void 0,source_trace_id:trace.source_trace_id??void 0,selectors_not_found:[selector]})}return portsWithSelectors.some(p4=>!p4.port)?{allPortsFound:!1}:{allPortsFound:!0,portsWithSelectors,ports:portsWithSelectors.map(({port})=>port)}}var Trace3=class extends PrimitiveComponent2{constructor(props){super(props);__publicField(this,"source_trace_id",null);__publicField(this,"pcb_trace_id",null);__publicField(this,"schematic_trace_id",null);__publicField(this,"_portsRoutedOnPcb");__publicField(this,"subcircuit_connectivity_map_key",null);__publicField(this,"_traceConnectionHash",null);__publicField(this,"_couldNotFindPort");this._portsRoutedOnPcb=[]}_getExplicitTraceThickness(){return this._parsedProps.thickness??this._parsedProps.width}get config(){return{zodProps:traceProps,componentName:"Trace"}}_getTracePortOrNetSelectorListFromProps(){return"from"in this.props&&"to"in this.props?[typeof this.props.from=="string"?this.props.from:this.props.from.getPortSelector(),typeof this.props.to=="string"?this.props.to:this.props.to.getPortSelector()]:"path"in this.props?this.props.path.map(p4=>typeof p4=="string"?p4:p4.getPortSelector()):[]}getTracePortPathSelectors(){return this._getTracePortOrNetSelectorListFromProps().filter(selector=>!selector.includes("net."))}getTracePathNetSelectors(){return this._getTracePortOrNetSelectorListFromProps().filter(selector=>selector.includes("net."))}_findConnectedPorts(){return Trace__findConnectedPorts(this)}_resolveNet(selector){let direct=this.getSubcircuit().selectOne(selector,{type:"net"});if(direct)return direct;let match2=selector.match(/^net\.(.+)$/),netName=match2?match2[1]:null;if(!netName)return null;let board=this.root?._getBoard();return board?board.getDescendants().find(d4=>d4.componentName==="Net"&&d4._parsedProps.name===netName)||null:(this.renderError(`Could not find a <board> ancestor for ${this}, so net "${selector}" cannot be resolved`),null)}_findConnectedNets(){let netsWithSelectors=this.getTracePathNetSelectors().map(selector=>({selector,net:this._resolveNet(selector)})),undefinedNets=netsWithSelectors.filter(n4=>!n4.net);return undefinedNets.length>0&&this.renderError(`Could not find net for selector "${undefinedNets[0].selector}" inside ${this}`),{netsWithSelectors,nets:netsWithSelectors.map(n4=>n4.net)}}_getAllTracesConnectedToSameNet(){let traces=this.getSubcircuit().selectAll("trace"),myNets=this._findConnectedNets().nets,myPorts=this._findConnectedPorts().ports??[];return traces.filter(t52=>{if(t52===this)return!1;let tNets=t52._findConnectedNets().nets,tPorts=t52._findConnectedPorts().ports??[];return tNets.some(n4=>myNets.includes(n4))||tPorts.some(p4=>myPorts.includes(p4))})}_isExplicitlyConnectedToPort(port){let{allPortsFound,portsWithSelectors:portsWithMetadata}=this._findConnectedPorts();return allPortsFound?portsWithMetadata.map(p4=>p4.port).includes(port):!1}_isExplicitlyConnectedToNet(net){return this._findConnectedNets().nets.includes(net)}doInitialCreateNetsFromProps(){createNetsFromProps(this,this.getTracePathNetSelectors())}_computeTraceConnectionHash(){let{allPortsFound,ports}=this._findConnectedPorts();return!allPortsFound||!ports?null:[...ports].sort((a3,b3)=>(a3.pcb_port_id||"").localeCompare(b3.pcb_port_id||"")).map(p4=>p4.pcb_port_id).join(",")}doInitialSourceTraceRender(){let{db:db2}=this.root,{_parsedProps:props,parent}=this;if(!parent){this.renderError("Trace has no parent");return}let allPortsFound,ports;try{let result=this._findConnectedPorts();allPortsFound=result.allPortsFound,ports=result.portsWithSelectors??[]}catch(error2){if(error2 instanceof TraceConnectionError){db2.source_trace_not_connected_error.insert({...error2.errorData,error_type:"source_trace_not_connected_error"}),this._couldNotFindPort=!0;return}throw error2}if(!allPortsFound)return;this._traceConnectionHash=this._computeTraceConnectionHash();let existingTrace=db2.source_trace.list().find(t52=>t52.subcircuit_connectivity_map_key===this.subcircuit_connectivity_map_key&&t52.connected_source_port_ids.sort().join(",")===this._traceConnectionHash);if(existingTrace){this.source_trace_id=existingTrace.source_trace_id;return}let nets=this._findConnectedNets().nets,displayName=getTraceDisplayName({ports,nets}),trace=db2.source_trace.insert({connected_source_port_ids:ports.map(p4=>p4.port.source_port_id),connected_source_net_ids:nets.map(n4=>n4.source_net_id),subcircuit_id:this.getSubcircuit()?.subcircuit_id,max_length:getMaxLengthFromConnectedCapacitors(ports.map(p4=>p4.port),{db:db2})??props.maxLength,display_name:displayName,min_trace_thickness:this._getExplicitTraceThickness()});this.source_trace_id=trace.source_trace_id}_insertErrorIfTraceIsOutsideBoard(mergedRoute,ports){let{db:db2}=this.root,board=this._getBoard();if(!board)return;let pcbBoardId=board.pcb_board_id;if(!pcbBoardId)return;isRouteOutsideBoard({mergedRoute,db:db2,pcbBoardId})&&db2.pcb_trace_error.insert({error_type:"pcb_trace_error",source_trace_id:this.source_trace_id,message:`Trace ${this.getString()} routed outside the board boundaries.`,pcb_trace_id:this.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:ports.map(p4=>p4.pcb_port_id)})}doInitialPcbManualTraceRender(){Trace_doInitialPcbManualTraceRender(this)}doInitialPcbTraceRender(){Trace_doInitialPcbTraceRender(this)}_doInitialSchematicTraceRenderWithDisplayLabel(){Trace__doInitialSchematicTraceRenderWithDisplayLabel(this)}_isSymbolToChipConnection(){let{allPortsFound,ports}=this._findConnectedPorts();if(!allPortsFound||ports.length!==2)return!1;let[port1,port2]=ports;if(!port1?.parent||!port2?.parent)return!1;let isPort1Chip=port1.parent.config.shouldRenderAsSchematicBox,isPort2Chip=port2.parent.config.shouldRenderAsSchematicBox;return isPort1Chip&&!isPort2Chip||!isPort1Chip&&isPort2Chip}_isSymbolToSymbolConnection(){let{allPortsFound,ports}=this._findConnectedPorts();if(!allPortsFound||ports.length!==2)return!1;let[port1,port2]=ports;if(!port1?.parent||!port2?.parent)return!1;let isPort1Symbol=!port1.parent.config.shouldRenderAsSchematicBox,isPort2Symbol=!port2.parent.config.shouldRenderAsSchematicBox;return isPort1Symbol&&isPort2Symbol}_isChipToChipConnection(){let{allPortsFound,ports}=this._findConnectedPorts();if(!allPortsFound||ports.length!==2)return!1;let[port1,port2]=ports;if(!port1?.parent||!port2?.parent)return!1;let isPort1Chip=port1.parent.config.shouldRenderAsSchematicBox,isPort2Chip=port2.parent.config.shouldRenderAsSchematicBox;return isPort1Chip&&isPort2Chip}doInitialSchematicTraceRender(){Trace_doInitialSchematicTraceRender(this)}},catalogue={},extendCatalogue=objects=>{let altKeys=Object.fromEntries(Object.entries(objects).map(([key,v4])=>[key.toLowerCase(),v4]));Object.assign(catalogue,objects),Object.assign(catalogue,altKeys)},ErrorPlaceholderComponent=class extends PrimitiveComponent2{constructor(props,error2){super(props);let resolveCoordinate=(value,axis)=>{if(typeof value=="number")return value;if(typeof value=="string")try{return this._resolvePcbCoordinate(value,axis,{allowBoardVariables:!1})}catch{return 0}return 0};this._parsedProps={...props,error:error2,type:props.type||"unknown",component_name:props.name,error_type:"source_failed_to_create_component_error",message:error2 instanceof Error?error2.message:String(error2),pcbX:resolveCoordinate(props.pcbX,"pcbX"),pcbY:resolveCoordinate(props.pcbY,"pcbY"),schX:props.schX,schY:props.schY}}formatErrorDetails(){let selectorValue=this._parsedProps.selector??this._parsedProps.selectors??this._parsedProps.in??this._parsedProps.within,selectorText=selectorValue===void 0?void 0:typeof selectorValue=="string"?selectorValue:this.safeStringify(selectorValue),propsText=this.safeStringify(this._parsedProps);return{selectorText,propsText}}safeStringify(value){let seen=new WeakSet,json=JSON.stringify(value,(_key,item)=>{if(typeof item=="bigint")return item.toString();if(typeof item=="function")return`[Function ${item.name||"anonymous"}]`;if(typeof item=="symbol")return item.toString();if(typeof item=="object"&&item!==null){if(seen.has(item))return"[Circular]";seen.add(item)}return item},2);return json?json.length>2e3?`${json.slice(0,2e3)}\u2026`:json:"undefined"}get config(){return{componentName:"ErrorPlaceholder",zodProps:external_exports.object({}).passthrough()}}doInitialSourceRender(){if(this.root?.db){let pcbPosition2=this._getGlobalPcbPositionBeforeLayout(),schematicPosition=this._getGlobalSchematicPositionBeforeLayout(),{selectorText,propsText}=this.formatErrorDetails(),messageDetails=[selectorText?`Within selector: ${selectorText}`:null,`Props: ${propsText}`].filter(Boolean).join(" "),baseMessage=`Could not create ${this._parsedProps.componentType??"component"}${this._parsedProps.name?` "${this._parsedProps.name}"`:""}. ${this._parsedProps.error?.formattedError?._errors?.join("; ")||this._parsedProps.message}`;this.root.db.source_failed_to_create_component_error.insert({component_name:this._parsedProps.component_name,error_type:"source_failed_to_create_component_error",message:`${baseMessage}${messageDetails?` Details: ${messageDetails}`:""}`,pcb_center:pcbPosition2,schematic_center:schematicPosition})}}};function createErrorPlaceholderComponent(props,error2){return new ErrorPlaceholderComponent(props,error2)}function prepare(object,state2){let instance=object;return instance.__tsci={...state2},object}var hostConfig={supportsMutation:!0,createInstance(type,props){let target=catalogue[type];if(!target)throw Object.keys(catalogue).length===0?new Error("No components registered in catalogue, did you forget to import lib/register-catalogue in your test file?"):new Error(`Unsupported component type "${type}". No element with this name is registered in the @tscircuit/core catalogue. Check for typos or see https://docs.tscircuit.com/category/built-in-elements for a list of valid components. To add your own component, see docs/CREATING_NEW_COMPONENTS.md`);try{return prepare(new target(props),{})}catch(error2){return createErrorPlaceholderComponent({...props,componentType:type},error2)}},createTextInstance(text){return{__text:text}},appendInitialChild(parentInstance,child){parentInstance.add(child)},appendChild(parentInstance,child){parentInstance.add(child)},appendChildToContainer(container,child){container.add(child)},finalizeInitialChildren(){return!1},prepareUpdate(){return null},shouldSetTextContent(){return!1},getRootHostContext(){return{}},getChildHostContext(){return{}},prepareForCommit(){return null},resetAfterCommit(){},commitMount(){},commitUpdate(){},removeChild(){},clearContainer(){},supportsPersistence:!1,getPublicInstance(instance){return instance},preparePortalMount(containerInfo){throw new Error("Function not implemented.")},scheduleTimeout(fn3,delay){throw new Error("Function not implemented.")},cancelTimeout(id2){throw new Error("Function not implemented.")},noTimeout:void 0,isPrimaryRenderer:!1,getInstanceFromNode(node){throw new Error("Function not implemented.")},beforeActiveInstanceBlur(){throw new Error("Function not implemented.")},afterActiveInstanceBlur(){throw new Error("Function not implemented.")},prepareScopeUpdate:(scopeInstance,instance)=>{throw new Error("Function not implemented.")},getInstanceFromScope:scopeInstance=>{throw new Error("Function not implemented.")},detachDeletedInstance:node=>{throw new Error("Function not implemented.")},getCurrentEventPriority:()=>import_constants.DefaultEventPriority,getCurrentUpdatePriority:()=>import_constants.DefaultEventPriority,resolveUpdatePriority:()=>import_constants.DefaultEventPriority,setCurrentUpdatePriority:()=>{},maySuspendCommit:()=>!1,supportsHydration:!1},reconciler=(0,import_react_reconciler.default)(hostConfig),createInstanceFromReactElement=reactElm=>{let rootContainer={children:[],props:{name:"$root"},add(instance){instance.parent=this,this.children.push(instance)},computePcbGlobalTransform(){return identity()}},containerErrors=[],container=reconciler.createContainer(rootContainer,0,null,!1,null,"tsci",error2=>{console.log("Error in createContainer"),console.error(error2),containerErrors.push(error2)},null);if(reconciler.updateContainerSync(reactElm,container,null,()=>{}),reconciler.flushSyncWork(),containerErrors.length>0)throw containerErrors[0];let rootInstance=reconciler.getPublicRootInstance(container);return rootInstance||rootContainer.children[0]},PIN_LABELS_KEY_RE=/^(?:pin)?(\d+)$/,getPinNumberFromPinLabelsKey=pinKey=>{let match2=pinKey.match(PIN_LABELS_KEY_RE);return match2?Number.parseInt(match2[1],10):null},parsePinNumberFromLabelsOrThrow=(pinNumberOrLabel,pinLabels)=>{if(typeof pinNumberOrLabel=="number")return pinNumberOrLabel;let directPinNumber=getPinNumberFromPinLabelsKey(pinNumberOrLabel);if(directPinNumber!==null)return directPinNumber;if(pinNumberOrLabel.startsWith("pin"))throw new Error(`Invalid pinLabels key "${pinNumberOrLabel}". Expected "pin\${number}" (e.g. pin1, pin2).`);if(!pinLabels)throw new Error(`No pin labels provided and pin number or label is not a number: "${pinNumberOrLabel}"`);for(let pinNumberKey in pinLabels)if((Array.isArray(pinLabels[pinNumberKey])?pinLabels[pinNumberKey]:[pinLabels[pinNumberKey]]).includes(pinNumberOrLabel)){let pinNumber=getPinNumberFromPinLabelsKey(pinNumberKey);if(pinNumber===null)throw new Error(`Invalid pinLabels key "${pinNumberKey}". Expected "pin\${number}" (e.g. pin1, pin2).`);return pinNumber}throw new Error(`No pin labels provided and pin number or label is not a number: "${pinNumberOrLabel}"`)},underscorifyPinStyles=(pinStyles,pinLabels)=>{if(!pinStyles)return;let underscorePinStyles={},mergedStyles={};for(let[pinNameOrLabel,pinStyle]of Object.entries(pinStyles)){let pinNumber=parsePinNumberFromLabelsOrThrow(pinNameOrLabel,pinLabels);mergedStyles[pinNumber]={...mergedStyles[pinNumber],...pinStyle}}for(let[pinNumber,pinStyle]of Object.entries(mergedStyles)){let pinKey=`pin${pinNumber}`;underscorePinStyles[pinKey]={bottom_margin:pinStyle.bottomMargin,left_margin:pinStyle.leftMargin,right_margin:pinStyle.rightMargin,top_margin:pinStyle.topMargin}}return underscorePinStyles},underscorifyPortArrangement=portArrangement=>{if(portArrangement){if("leftSide"in portArrangement||"rightSide"in portArrangement||"topSide"in portArrangement||"bottomSide"in portArrangement)return{left_side:portArrangement.leftSide,right_side:portArrangement.rightSide,top_side:portArrangement.topSide,bottom_side:portArrangement.bottomSide};if("leftPinCount"in portArrangement||"rightPinCount"in portArrangement||"topPinCount"in portArrangement||"bottomPinCount"in portArrangement)return{left_size:portArrangement.leftPinCount,right_size:portArrangement.rightPinCount,top_size:portArrangement.topPinCount,bottom_size:portArrangement.bottomPinCount};if("leftSize"in portArrangement||"rightSize"in portArrangement||"topSize"in portArrangement||"bottomSize"in portArrangement)return{left_size:portArrangement.leftSize,right_size:portArrangement.rightSize,top_size:portArrangement.topSize,bottom_size:portArrangement.bottomSize}}},CourtyardCircle=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_courtyard_circle_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"CourtyardCircle",zodProps:courtyardCircleProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for CourtyardCircle. Must be "top" or "bottom".`);let subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_courtyard_circle3=db2.pcb_courtyard_circle.insert({pcb_component_id,layer,center:{x:position4.x,y:position4.y},radius:props.radius,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_courtyard_circle_id=pcb_courtyard_circle3.pcb_courtyard_circle_id}getPcbSize(){let{_parsedProps:props}=this,diameter=props.radius*2;return{width:diameter,height:diameter}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_courtyard_circle_id)return;let circle2=db2.pcb_courtyard_circle.get(this.pcb_courtyard_circle_id);circle2&&db2.pcb_courtyard_circle.update(this.pcb_courtyard_circle_id,{center:{x:circle2.center.x+deltaX,y:circle2.center.y+deltaY}})}},CourtyardOutline=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_courtyard_outline_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"CourtyardOutline",zodProps:courtyardOutlineProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for CourtyardOutline. Must be "top" or "bottom".`);let transform6=this._computePcbGlobalTransformBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_courtyard_outline3=db2.pcb_courtyard_outline.insert({pcb_component_id,layer,outline:props.outline.map(p4=>{let transformedPosition=applyToPoint2(transform6,{x:p4.x,y:p4.y});return{x:transformedPosition.x,y:transformedPosition.y}}),subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_courtyard_outline_id=pcb_courtyard_outline3.pcb_courtyard_outline_id}_setPositionFromLayout(newCenter){let{db:db2}=this.root,currentOutline=db2.pcb_courtyard_outline.get(this.pcb_courtyard_outline_id);if(!currentOutline)return;let currentCenterX=0,currentCenterY=0;for(let point62 of currentOutline.outline)currentCenterX+=point62.x,currentCenterY+=point62.y;currentCenterX/=currentOutline.outline.length,currentCenterY/=currentOutline.outline.length;let offsetX=newCenter.x-currentCenterX,offsetY=newCenter.y-currentCenterY,newOutline=currentOutline.outline.map(point62=>({x:point62.x+offsetX,y:point62.y+offsetY}));db2.pcb_courtyard_outline.update(this.pcb_courtyard_outline_id,{outline:newOutline})}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_courtyard_outline_id)return;let outline=db2.pcb_courtyard_outline.get(this.pcb_courtyard_outline_id);outline&&db2.pcb_courtyard_outline.update(this.pcb_courtyard_outline_id,{outline:outline.outline.map(p4=>({x:p4.x+deltaX,y:p4.y+deltaY}))})}getPcbSize(){let{_parsedProps:props}=this;if(!props.outline||props.outline.length===0)return{width:0,height:0};let bounds=getBoundsFromPoints(props.outline);return bounds?{width:bounds.maxX-bounds.minX,height:bounds.maxY-bounds.minY}:{width:0,height:0}}},CourtyardRect=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_courtyard_rect_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"CourtyardRect",zodProps:courtyardRectProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer,isFlipped}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for CourtyardRect. Must be "top" or "bottom".`);let subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,ccw_rotation=(decomposeTSR2(this._computePcbGlobalTransformBeforeLayout()).rotation.angle*180/Math.PI%360+360)%360;isFlipped&&(ccw_rotation=(180-ccw_rotation+360)%360);let pcb_courtyard_rect3=db2.pcb_courtyard_rect.insert({pcb_component_id,layer,center:{x:position4.x,y:position4.y},width:props.width,height:props.height,ccw_rotation:ccw_rotation||void 0,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_courtyard_rect_id=pcb_courtyard_rect3.pcb_courtyard_rect_id}getPcbSize(){let{_parsedProps:props}=this;return{width:props.width,height:props.height}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_courtyard_rect_id)return;let rect=db2.pcb_courtyard_rect.get(this.pcb_courtyard_rect_id);rect&&db2.pcb_courtyard_rect.update(this.pcb_courtyard_rect_id,{center:{x:rect.center.x+deltaX,y:rect.center.y+deltaY}})}},Cutout=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_cutout_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"Cutout",zodProps:cutoutProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,subcircuit=this.getSubcircuit(),pcb_group_id=this.getGroup()?.pcb_group_id??void 0,globalPosition=this._getGlobalPcbPositionBeforeLayout(),parentRotation=this.getPrimitiveContainer()?._parsedProps.pcbRotation??0,inserted_pcb_cutout;if(props.shape==="rect"){let rotationDeg=typeof parentRotation=="string"?parseInt(parentRotation.replace("deg",""),10):parentRotation,isRotated90=Math.abs(rotationDeg%180)===90,rectData={shape:"rect",center:globalPosition,width:isRotated90?props.height:props.width,height:isRotated90?props.width:props.height,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id};inserted_pcb_cutout=db2.pcb_cutout.insert(rectData)}else if(props.shape==="circle"){let circleData={shape:"circle",center:globalPosition,radius:props.radius,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id};inserted_pcb_cutout=db2.pcb_cutout.insert(circleData)}else if(props.shape==="polygon"){let transform6=this._computePcbGlobalTransformBeforeLayout(),polygonData={shape:"polygon",points:props.points.map(p4=>applyToPoint2(transform6,p4)),subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id};inserted_pcb_cutout=db2.pcb_cutout.insert(polygonData)}inserted_pcb_cutout&&(this.pcb_cutout_id=inserted_pcb_cutout.pcb_cutout_id)}getPcbSize(){let{_parsedProps:props}=this;if(props.shape==="rect")return{width:props.width,height:props.height};if(props.shape==="circle")return{width:props.radius*2,height:props.radius*2};if(props.shape==="polygon"){if(props.points.length===0)return{width:0,height:0};let minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0;for(let point62 of props.points)minX=Math.min(minX,point62.x),maxX=Math.max(maxX,point62.x),minY=Math.min(minY,point62.y),maxY=Math.max(maxY,point62.y);return{width:maxX-minX,height:maxY-minY}}return{width:0,height:0}}_getPcbCircuitJsonBounds(){if(!this.pcb_cutout_id)return super._getPcbCircuitJsonBounds();let{db:db2}=this.root,cutout=db2.pcb_cutout.get(this.pcb_cutout_id);if(!cutout)return super._getPcbCircuitJsonBounds();if(cutout.shape==="rect")return{center:cutout.center,bounds:{left:cutout.center.x-cutout.width/2,top:cutout.center.y+cutout.height/2,right:cutout.center.x+cutout.width/2,bottom:cutout.center.y-cutout.height/2},width:cutout.width,height:cutout.height};if(cutout.shape==="circle")return{center:cutout.center,bounds:{left:cutout.center.x-cutout.radius,top:cutout.center.y+cutout.radius,right:cutout.center.x+cutout.radius,bottom:cutout.center.y-cutout.radius},width:cutout.radius*2,height:cutout.radius*2};if(cutout.shape==="polygon"){if(cutout.points.length===0)return super._getPcbCircuitJsonBounds();let minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0;for(let point62 of cutout.points)minX=Math.min(minX,point62.x),maxX=Math.max(maxX,point62.x),minY=Math.min(minY,point62.y),maxY=Math.max(maxY,point62.y);return{center:{x:(minX+maxX)/2,y:(minY+maxY)/2},bounds:{left:minX,top:maxY,right:maxX,bottom:minY},width:maxX-minX,height:maxY-minY}}return super._getPcbCircuitJsonBounds()}_setPositionFromLayout(newCenter){if(!this.pcb_cutout_id)return;let{db:db2}=this.root,cutout=db2.pcb_cutout.get(this.pcb_cutout_id);if(cutout){if(cutout.shape==="rect"||cutout.shape==="circle")db2.pcb_cutout.update(this.pcb_cutout_id,{...cutout,center:newCenter});else if(cutout.shape==="polygon"){let oldCenter=this._getPcbCircuitJsonBounds().center,dx3=newCenter.x-oldCenter.x,dy3=newCenter.y-oldCenter.y,newPoints=cutout.points.map(p4=>({x:p4.x+dx3,y:p4.y+dy3}));db2.pcb_cutout.update(this.pcb_cutout_id,{...cutout,points:newPoints})}}}_moveCircuitJsonElements({deltaX,deltaY}){if(!this.pcb_cutout_id)return;let{db:db2}=this.root,cutout=db2.pcb_cutout.get(this.pcb_cutout_id);cutout&&(cutout.shape==="rect"||cutout.shape==="circle"?db2.pcb_cutout.update(this.pcb_cutout_id,{center:{x:cutout.center.x+deltaX,y:cutout.center.y+deltaY}}):cutout.shape==="polygon"&&db2.pcb_cutout.update(this.pcb_cutout_id,{points:cutout.points.map(p4=>({x:p4.x+deltaX,y:p4.y+deltaY}))}))}},FabricationNotePath=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"fabrication_note_path_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"FabricationNotePath",zodProps:fabricationNotePathProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,subcircuit=this.getSubcircuit(),{_parsedProps:props}=this,layer=props.layer??"top";if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for SilkscreenPath. Must be "top" or "bottom".`);let transform6=this._computePcbGlobalTransformBeforeLayout(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,fabrication_note_path=db2.pcb_fabrication_note_path.insert({pcb_component_id,layer,color:props.color,route:props.route.map(p4=>{let transformedPosition=applyToPoint2(transform6,{x:p4.x,y:p4.y});return{...p4,x:transformedPosition.x,y:transformedPosition.y}}),stroke_width:props.strokeWidth??.1,subcircuit_id:subcircuit?.subcircuit_id??void 0});this.fabrication_note_path_id=fabrication_note_path.pcb_fabrication_note_path_id}getPcbSize(){let{_parsedProps:props}=this;if(props.route.length===0)return{width:0,height:0};let xs3=props.route.map(point62=>typeof point62.x=="string"?parseFloat(point62.x):point62.x),ys3=props.route.map(point62=>typeof point62.y=="string"?parseFloat(point62.y):point62.y),minX=Math.min(...xs3),maxX=Math.max(...xs3),minY=Math.min(...ys3),maxY=Math.max(...ys3);return{width:maxX-minX,height:maxY-minY}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.fabrication_note_path_id)return;let path=db2.pcb_fabrication_note_path.get(this.fabrication_note_path_id);path&&db2.pcb_fabrication_note_path.update(this.fabrication_note_path_id,{route:path.route.map(p4=>({...p4,x:p4.x+deltaX,y:p4.y+deltaY}))})}},FabricationNoteRect=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"fabrication_note_rect_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"FabricationNoteRect",zodProps:fabricationNoteRectProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for FabricationNoteRect. Must be "top" or "bottom".`);let pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,subcircuit=this.getSubcircuit(),hasStroke=props.hasStroke??(props.strokeWidth!==void 0&&props.strokeWidth!==null),fabrication_note_rect=db2.pcb_fabrication_note_rect.insert({pcb_component_id,layer,color:props.color,center:{x:position4.x,y:position4.y},width:props.width,height:props.height,stroke_width:props.strokeWidth??1,is_filled:props.isFilled??!1,has_stroke:hasStroke,is_stroke_dashed:props.isStrokeDashed??!1,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,corner_radius:props.cornerRadius??void 0});this.fabrication_note_rect_id=fabrication_note_rect.pcb_fabrication_note_rect_id}getPcbSize(){let{_parsedProps:props}=this;return{width:props.width,height:props.height}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.fabrication_note_rect_id)return;let rect=db2.pcb_fabrication_note_rect.get(this.fabrication_note_rect_id);rect&&db2.pcb_fabrication_note_rect.update(this.fabrication_note_rect_id,{center:{x:rect.center.x+deltaX,y:rect.center.y+deltaY}})}};function normalizeTextForCircuitJson(text){return text.replace(/\\n/g,`
690
690
  `)}function parseSegment(seg){let bracketIdx=seg.indexOf("[");if(bracketIdx===-1)return{tag:seg};let tag=seg.slice(0,bracketIdx),m4=seg.slice(bracketIdx+1,seg.lastIndexOf("]")).match(/^(\w+)(\^=|\$=|=)['"]?(.*?)['"]?$/);return m4?{tag,attrName:m4[1],attrOp:m4[2],attrValue:m4[3]}:{tag}}function componentMatchesSegment(component,seg){if(component.lowercaseComponentName!==seg.tag)return!1;if(!seg.attrName)return!0;let attrVal=component.props?.[seg.attrName];if(attrVal===void 0)return!1;let valStr=String(attrVal);switch(seg.attrOp){case"^=":return valStr.startsWith(seg.attrValue);case"$=":return valStr.endsWith(seg.attrValue);case"=":return valStr===seg.attrValue;default:return!1}}function matchesCompoundSelector(component,segments){if(!componentMatchesSegment(component,segments[segments.length-1]))return!1;let segIdx=segments.length-2,current3=component.parent;for(;segIdx>=0&&current3;)componentMatchesSegment(current3,segments[segIdx])&&segIdx--,current3=current3.parent;return segIdx<0}function resolvePcbProperty({propertyName,resolvedPcbSx,pathFromAmpersand,component}){if(!resolvedPcbSx)return;let result,bestSpecificity=0;for(let[key,entry]of Object.entries(resolvedPcbSx)){if(!entry||!(propertyName in entry))continue;let selectorBody=key.startsWith("& ")?key.slice(2):key;if(selectorBody===pathFromAmpersand){1>bestSpecificity&&(bestSpecificity=1,result=entry[propertyName]);continue}if(!component)continue;let segments=selectorBody.split(/\s+/).map(parseSegment);if(!(segments.length<2)&&matchesCompoundSelector(component,segments)){let specificity=segments.length;specificity>bestSpecificity&&(bestSpecificity=specificity,result=entry[propertyName])}}return result}var FabricationNoteText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_fabrication_note_text_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"FabricationNoteText",zodProps:fabricationNoteTextProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),container=this.getPrimitiveContainer(),subcircuit=this.getSubcircuit();if(resolvePcbProperty({propertyName:"visibility",resolvedPcbSx:this.getResolvedPcbSx(),pathFromAmpersand:"fabricationnotetext",component:this})==="hidden")return;let pcb_fabrication_note_text3=db2.pcb_fabrication_note_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:position4.x,y:position4.y},font:props.font??"tscircuit2024",font_size:props.fontSize??1,layer:"top",color:props.color,text:normalizeTextForCircuitJson(props.text??""),pcb_component_id:container.pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_fabrication_note_text_id=pcb_fabrication_note_text3.pcb_fabrication_note_text_id}getPcbSize(){let{_parsedProps:props}=this,fontSize=typeof props.fontSize=="string"?parseFloat(props.fontSize):props.fontSize??1,charWidth=fontSize*.6;return{width:(props.text??"").length*charWidth,height:fontSize}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(this.pcb_fabrication_note_text_id){let text=db2.pcb_fabrication_note_text.get(this.pcb_fabrication_note_text_id);text&&db2.pcb_fabrication_note_text.update(this.pcb_fabrication_note_text_id,{anchor_position:{x:text.anchor_position.x+deltaX,y:text.anchor_position.y+deltaY}})}}},Hole=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_hole_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"Hole",zodProps:holeProps}}getPcbSize(){let{_parsedProps:props}=this,isPill=props.shape==="pill",isRect=props.shape==="rect";return isPill?{width:props.width,height:props.height}:isRect?{width:props.width,height:props.height}:{width:props.diameter,height:props.diameter}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,subcircuit=this.getSubcircuit(),position4=this._getGlobalPcbPositionBeforeLayout(),soldermaskMargin=props.solderMaskMargin,isCoveredWithSolderMask=props.coveredWithSolderMask??!1,pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id;if(this.emitSolderMaskMarginWarning(isCoveredWithSolderMask,soldermaskMargin),props.shape==="pill")if(props.pcbRotation&&props.pcbRotation!==0){let inserted_hole=db2.pcb_hole.insert({pcb_component_id,type:"pcb_hole",hole_shape:"rotated_pill",hole_width:props.width,hole_height:props.height,x:position4.x,y:position4.y,ccw_rotation:props.pcbRotation,soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0});this.pcb_hole_id=inserted_hole.pcb_hole_id}else{let inserted_hole=db2.pcb_hole.insert({pcb_component_id,type:"pcb_hole",hole_shape:"pill",hole_width:props.width,hole_height:props.height,x:position4.x,y:position4.y,soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0});this.pcb_hole_id=inserted_hole.pcb_hole_id}else if(props.shape==="rect"){let inserted_hole=db2.pcb_hole.insert({pcb_component_id,type:"pcb_hole",hole_shape:"rect",hole_width:props.width,hole_height:props.height,x:position4.x,y:position4.y,soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0});this.pcb_hole_id=inserted_hole.pcb_hole_id}else{let inserted_hole=db2.pcb_hole.insert({pcb_component_id,type:"pcb_hole",hole_shape:"circle",hole_diameter:props.diameter,x:position4.x,y:position4.y,soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0});this.pcb_hole_id=inserted_hole.pcb_hole_id}}_getPcbCircuitJsonBounds(){let{db:db2}=this.root,hole=db2.pcb_hole.get(this.pcb_hole_id),size3=this.getPcbSize();return{center:{x:hole.x,y:hole.y},bounds:{left:hole.x-size3.width/2,top:hole.y-size3.height/2,right:hole.x+size3.width/2,bottom:hole.y+size3.height/2},width:size3.width,height:size3.height}}_setPositionFromLayout(newCenter){let{db:db2}=this.root;db2.pcb_hole.update(this.pcb_hole_id,{x:newCenter.x,y:newCenter.y})}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_hole_id)return;let hole=db2.pcb_hole.get(this.pcb_hole_id);hole&&db2.pcb_hole.update(this.pcb_hole_id,{x:hole.x+deltaX,y:hole.y+deltaY})}},Keepout=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_keepout_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"Keepout",zodProps:pcbKeepoutProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let subcircuit=this.getSubcircuit(),{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),decomposedMat=decomposeTSR2(this._computePcbGlobalTransformBeforeLayout()),isRotated90=Math.abs(decomposedMat.rotation.angle*(180/Math.PI)-90)%180<.01,pcb_keepout3=null;props.shape==="circle"?pcb_keepout3=db2.pcb_keepout.insert({layers:["top"],shape:"circle",radius:props.radius,center:{x:position4.x,y:position4.y},subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0}):props.shape==="rect"&&(pcb_keepout3=db2.pcb_keepout.insert({layers:["top"],shape:"rect",...isRotated90?{width:props.height,height:props.width}:{width:props.width,height:props.height},center:{x:position4.x,y:position4.y},subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0})),pcb_keepout3&&(this.pcb_keepout_id=pcb_keepout3.pcb_keepout_id)}getPcbSize(){let{_parsedProps:props}=this;return props.shape==="circle"?{width:props.radius*2,height:props.radius*2}:props.shape==="rect"?{width:props.width,height:props.height}:{width:0,height:0}}},PcbNoteLine=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_note_line_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"PcbNoteLine",zodProps:pcbNoteLineProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,subcircuit=this.getSubcircuit(),group=this.getGroup(),transform6=this._computePcbGlobalTransformBeforeLayout(),start=applyToPoint2(transform6,{x:props.x1,y:props.y1}),end=applyToPoint2(transform6,{x:props.x2,y:props.y2}),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id??void 0,pcb_note_line3=db2.pcb_note_line.insert({pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:group?.pcb_group_id??void 0,x1:start.x,y1:start.y,x2:end.x,y2:end.y,layer:props.layer==="bottom"?"bottom":"top",stroke_width:props.strokeWidth??.1,color:props.color,is_dashed:props.isDashed});this.pcb_note_line_id=pcb_note_line3.pcb_note_line_id}getPcbSize(){let{_parsedProps:props}=this;return{width:Math.abs(props.x2-props.x1),height:Math.abs(props.y2-props.y1)}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_note_line_id)return;let line2=db2.pcb_note_line.get(this.pcb_note_line_id);line2&&db2.pcb_note_line.update(this.pcb_note_line_id,{x1:line2.x1+deltaX,y1:line2.y1+deltaY,x2:line2.x2+deltaX,y2:line2.y2+deltaY})}},PcbNotePath=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_note_path_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"PcbNotePath",zodProps:pcbNotePathProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform6=this._computePcbGlobalTransformBeforeLayout(),subcircuit=this.getSubcircuit(),group=this.getGroup(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id??void 0,transformedRoute=props.route.map(point62=>{let{x:x4,y:y4,...rest}=point62,numericX=typeof x4=="string"?parseFloat(x4):x4,numericY=typeof y4=="string"?parseFloat(y4):y4,transformed=applyToPoint2(transform6,{x:numericX,y:numericY});return{...rest,x:transformed.x,y:transformed.y}}),pcb_note_path3=db2.pcb_note_path.insert({pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:group?.pcb_group_id??void 0,route:transformedRoute,layer:props.layer==="bottom"?"bottom":"top",stroke_width:props.strokeWidth??.1,color:props.color});this.pcb_note_path_id=pcb_note_path3.pcb_note_path_id}getPcbSize(){let{_parsedProps:props}=this;if(props.route.length===0)return{width:0,height:0};let xs3=props.route.map(point62=>typeof point62.x=="string"?parseFloat(point62.x):point62.x),ys3=props.route.map(point62=>typeof point62.y=="string"?parseFloat(point62.y):point62.y),minX=Math.min(...xs3),maxX=Math.max(...xs3),minY=Math.min(...ys3),maxY=Math.max(...ys3);return{width:maxX-minX,height:maxY-minY}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_note_path_id)return;let path=db2.pcb_note_path.get(this.pcb_note_path_id);path&&db2.pcb_note_path.update(this.pcb_note_path_id,{route:path.route.map(p4=>({...p4,x:p4.x+deltaX,y:p4.y+deltaY}))})}},PcbNoteRect=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_note_rect_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"PcbNoteRect",zodProps:pcbNoteRectProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform6=this._computePcbGlobalTransformBeforeLayout(),center2=applyToPoint2(transform6,{x:0,y:0}),subcircuit=this.getSubcircuit(),group=this.getGroup(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id??void 0,pcb_note_rect3=db2.pcb_note_rect.insert({pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:group?.pcb_group_id??void 0,center:center2,width:props.width,height:props.height,layer:props.layer==="bottom"?"bottom":"top",stroke_width:props.strokeWidth??.1,is_filled:props.isFilled??!1,has_stroke:props.hasStroke??!0,is_stroke_dashed:props.isStrokeDashed??!1,color:props.color,corner_radius:props.cornerRadius??void 0});this.pcb_note_rect_id=pcb_note_rect3.pcb_note_rect_id}getPcbSize(){let{_parsedProps:props}=this,width=typeof props.width=="string"?parseFloat(props.width):props.width,height=typeof props.height=="string"?parseFloat(props.height):props.height;return{width,height}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_note_rect_id)return;let rect=db2.pcb_note_rect.get(this.pcb_note_rect_id);rect&&db2.pcb_note_rect.update(this.pcb_note_rect_id,{center:{x:rect.center.x+deltaX,y:rect.center.y+deltaY}})}},PcbNoteText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_note_text_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"PcbNoteText",zodProps:pcbNoteTextProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform6=this._computePcbGlobalTransformBeforeLayout(),anchorPosition=applyToPoint2(transform6,{x:0,y:0}),subcircuit=this.getSubcircuit(),group=this.getGroup(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id??void 0,pcb_note_text3=db2.pcb_note_text.insert({pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:group?.pcb_group_id??void 0,font:props.font??"tscircuit2024",font_size:props.fontSize??1,text:normalizeTextForCircuitJson(props.text),anchor_position:anchorPosition,anchor_alignment:props.anchorAlignment??"center",layer:props.layer==="bottom"?"bottom":"top",color:props.color});this.pcb_note_text_id=pcb_note_text3.pcb_note_text_id}getPcbSize(){let{_parsedProps:props}=this,fontSize=typeof props.fontSize=="string"?parseFloat(props.fontSize):props.fontSize??1,charWidth=fontSize*.6;return{width:props.text.length*charWidth,height:fontSize}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_note_text_id)return;let text=db2.pcb_note_text.get(this.pcb_note_text_id);text&&db2.pcb_note_text.update(this.pcb_note_text_id,{anchor_position:{x:text.anchor_position.x+deltaX,y:text.anchor_position.y+deltaY}})}},pcbTraceProps2=external_exports.object({route:external_exports.array(pcb_trace_route_point),source_trace_id:external_exports.string().optional()}),PcbTrace=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_trace_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"PcbTrace",zodProps:pcbTraceProps2}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,container=this.getPrimitiveContainer(),subcircuit=this.getSubcircuit(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),parentTransform=this._computePcbGlobalTransformBeforeLayout(),transformedRoute=props.route.map(point62=>{let{x:x4,y:y4,...restOfPoint}=point62,transformedPoint=applyToPoint2(parentTransform,{x:x4,y:y4});return point62.route_type==="wire"&&point62.layer?{...transformedPoint,...restOfPoint,layer:maybeFlipLayer(point62.layer)}:{...transformedPoint,...restOfPoint}}),pcb_trace3=db2.pcb_trace.insert({pcb_component_id:container.pcb_component_id,source_trace_id:props.source_trace_id,route:transformedRoute,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_trace_id=pcb_trace3.pcb_trace_id}getPcbSize(){let{_parsedProps:props}=this;if(!props.route||props.route.length===0)return{width:0,height:0};let minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0;for(let point62 of props.route)minX=Math.min(minX,point62.x),maxX=Math.max(maxX,point62.x),minY=Math.min(minY,point62.y),maxY=Math.max(maxY,point62.y),point62.route_type==="wire"&&(minX=Math.min(minX,point62.x-point62.width/2),maxX=Math.max(maxX,point62.x+point62.width/2),minY=Math.min(minY,point62.y-point62.width/2),maxY=Math.max(maxY,point62.y+point62.width/2));return minX===1/0||maxX===-1/0||minY===1/0||maxY===-1/0?{width:0,height:0}:{width:maxX-minX,height:maxY-minY}}};function getPcbPrimitiveBoundsBeforeRender(primitive){try{let center2=primitive._getGlobalPcbPositionBeforeLayout(),size3=primitive.getPcbSize();return{left:center2.x-size3.width/2,right:center2.x+size3.width/2,top:center2.y+size3.height/2,bottom:center2.y-size3.height/2}}catch{return null}}function doPcbPrimitivesOverlapBeforeRender(a3,b3){let aBounds=getPcbPrimitiveBoundsBeforeRender(a3),bBounds=getPcbPrimitiveBoundsBeforeRender(b3);return!aBounds||!bBounds?!1:!(aBounds.right<bBounds.left||aBounds.left>bBounds.right||aBounds.bottom>bBounds.top||aBounds.top<bBounds.bottom)}function getConnectedPcbPrimitiveClustersBeforeRender(primitives){let clusters=[],visited=new Set;for(let primitive of primitives){if(visited.has(primitive))continue;let cluster=[],stack=[primitive];for(visited.add(primitive);stack.length>0;){let current3=stack.pop();cluster.push(current3);for(let candidate of primitives)visited.has(candidate)||doPcbPrimitivesOverlapBeforeRender(current3,candidate)&&(visited.add(candidate),stack.push(candidate))}clusters.push(cluster)}return clusters}var getPinNumberFromHints=hints=>{for(let hint of hints){let normalizedHint=hint.toString();if(/^(pin)?\d+$/.test(normalizedHint))return Number.parseInt(normalizedHint.replace(/^pin/,""))}return null};function selectPortForPcbPrimitive(ports,primitive,hints){let pinNumber=getPinNumberFromHints(hints),matchingPorts=ports.filter(port=>port.isMatchingAnyOf(hints));if(matchingPorts.length===0)return null;let pinMatchedPorts=pinNumber===null?matchingPorts:matchingPorts.filter(port=>port._parsedProps.pinNumber===pinNumber||port._primaryPinNumber===pinNumber),candidates=pinMatchedPorts.length>0?pinMatchedPorts:matchingPorts,overlappingPort=candidates.find(port=>port.matchedComponents.some(component=>component.isPcbPrimitive&&doPcbPrimitivesOverlapBeforeRender(component,primitive)));return overlappingPort||(candidates.find(port=>!port.matchedComponents.some(component=>component.isPcbPrimitive))??candidates[0])}var PlatedHole=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_plated_hole_id",null);__publicField(this,"matchedPort",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"PlatedHole",zodProps:platedHoleProps}}getAvailablePcbLayers(){return["top","inner1","inner2","bottom"]}getPcbSize(){let{_parsedProps:props}=this;if(props.shape==="circle")return{width:props.outerDiameter,height:props.outerDiameter};if(props.shape==="oval"||props.shape==="pill")return{width:props.outerWidth,height:props.outerHeight};if(props.shape==="circular_hole_with_rect_pad")return{width:props.rectPadWidth,height:props.rectPadHeight};if(props.shape==="pill_hole_with_rect_pad")return{width:props.rectPadWidth,height:props.rectPadHeight};if(props.shape==="hole_with_polygon_pad"){if(!props.padOutline||props.padOutline.length===0)throw new Error("padOutline is required for hole_with_polygon_pad shape");let xs3=props.padOutline.map(p4=>typeof p4.x=="number"?p4.x:parseFloat(String(p4.x))),ys3=props.padOutline.map(p4=>typeof p4.y=="number"?p4.y:parseFloat(String(p4.y))),minX=Math.min(...xs3),maxX=Math.max(...xs3),minY=Math.min(...ys3),maxY=Math.max(...ys3);return{width:maxX-minX,height:maxY-minY}}throw new Error(`getPcbSize for shape "${props.shape}" not implemented for ${this.componentName}`)}_getPcbCircuitJsonBounds(){let{db:db2}=this.root,platedHole=db2.pcb_plated_hole.get(this.pcb_plated_hole_id),size3=this.getPcbSize();return{center:{x:platedHole.x,y:platedHole.y},bounds:{left:platedHole.x-size3.width/2,top:platedHole.y+size3.height/2,right:platedHole.x+size3.width/2,bottom:platedHole.y-size3.height/2},width:size3.width,height:size3.height}}_setPositionFromLayout(newCenter){let{db:db2}=this.root;db2.pcb_plated_hole.update(this.pcb_plated_hole_id,{x:newCenter.x,y:newCenter.y}),this.matchedPort?._setPositionFromLayout(newCenter)}doInitialPortMatching(){let parentPorts=this.getPrimitiveContainer()?.selectAll("port");if(!this._parsedProps.portHints)return;let port=selectPortForPcbPrimitive(parentPorts,this,this._parsedProps.portHints);port&&(this.matchedPort=port,port.registerMatch(this))}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,subcircuit=this.getSubcircuit(),soldermaskMargin=props.solderMaskMargin,isCoveredWithSolderMask=props.coveredWithSolderMask??!1;this.emitSolderMaskMarginWarning(isCoveredWithSolderMask,soldermaskMargin);let finalRotationDegrees=(decomposeTSR2(this._computePcbGlobalTransformBeforeLayout()).rotation.angle*180/Math.PI%360+360)%360;if(props.shape==="circle"){let pcb_plated_hole3=db2.pcb_plated_hole.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,outer_diameter:props.outerDiameter,hole_diameter:props.holeDiameter,shape:"circle",port_hints:this.getNameAndAliases(),x:position4.x,y:position4.y,layers:["top","bottom"],soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_plated_hole_id=pcb_plated_hole3.pcb_plated_hole_id,db2.pcb_solder_paste.insert({layer:"top",shape:"circle",radius:props.outerDiameter/2,x:position4.x,y:position4.y,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}),db2.pcb_solder_paste.insert({layer:"bottom",shape:"circle",radius:props.outerDiameter/2,x:position4.x,y:position4.y,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0})}else if(props.shape==="pill"&&props.rectPad){let pcb_plated_hole3=db2.pcb_plated_hole.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,outer_width:props.outerWidth,outer_height:props.outerHeight,hole_width:props.holeWidth,hole_height:props.holeHeight,shape:"rotated_pill_hole_with_rect_pad",type:"pcb_plated_hole",port_hints:this.getNameAndAliases(),pcb_plated_hole_id:this.pcb_plated_hole_id,x:position4.x,y:position4.y,layers:["top","bottom"],soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,hole_shape:"rotated_pill",pad_shape:"rect",hole_ccw_rotation:finalRotationDegrees,rect_ccw_rotation:finalRotationDegrees,rect_pad_width:props.outerWidth,rect_pad_height:props.outerHeight,hole_offset_x:props.holeOffsetX,hole_offset_y:props.holeOffsetY});this.pcb_plated_hole_id=pcb_plated_hole3.pcb_plated_hole_id}else if(props.shape==="pill"||props.shape==="oval"){let pcb_plated_hole3=db2.pcb_plated_hole.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,outer_width:props.outerWidth,outer_height:props.outerHeight,hole_width:props.holeWidth,hole_height:props.holeHeight,shape:props.shape,port_hints:this.getNameAndAliases(),x:position4.x,y:position4.y,layers:["top","bottom"],soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,ccw_rotation:finalRotationDegrees});this.pcb_plated_hole_id=pcb_plated_hole3.pcb_plated_hole_id,db2.pcb_solder_paste.insert({layer:"top",shape:props.shape,width:props.outerWidth,height:props.outerHeight,x:position4.x,y:position4.y,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}),db2.pcb_solder_paste.insert({layer:"bottom",shape:props.shape,width:props.outerWidth,height:props.outerHeight,x:position4.x,y:position4.y,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0})}else if(props.shape==="circular_hole_with_rect_pad"){let pcb_plated_hole3=db2.pcb_plated_hole.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,hole_diameter:props.holeDiameter,rect_pad_width:props.rectPadWidth,rect_pad_height:props.rectPadHeight,shape:"circular_hole_with_rect_pad",port_hints:this.getNameAndAliases(),x:position4.x,y:position4.y,layers:["top","bottom"],soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,hole_offset_x:props.holeOffsetX,hole_offset_y:props.holeOffsetY,rect_border_radius:props.rectBorderRadius??0,rect_ccw_rotation:finalRotationDegrees});this.pcb_plated_hole_id=pcb_plated_hole3.pcb_plated_hole_id}else if(props.shape==="pill_hole_with_rect_pad")if(finalRotationDegrees!==0){let pcb_plated_hole3=db2.pcb_plated_hole.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,hole_width:props.holeWidth,hole_height:props.holeHeight,rect_pad_width:props.rectPadWidth,rect_pad_height:props.rectPadHeight,hole_offset_x:props.holeOffsetX,hole_offset_y:props.holeOffsetY,shape:"rotated_pill_hole_with_rect_pad",type:"pcb_plated_hole",hole_shape:"rotated_pill",pad_shape:"rect",hole_ccw_rotation:finalRotationDegrees,rect_ccw_rotation:finalRotationDegrees,rect_border_radius:props.rectBorderRadius,port_hints:this.getNameAndAliases(),x:position4.x,y:position4.y,layers:["top","bottom"],soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_plated_hole_id=pcb_plated_hole3.pcb_plated_hole_id}else{let pcb_plated_hole3=db2.pcb_plated_hole.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,hole_width:props.holeWidth,hole_height:props.holeHeight,rect_pad_width:props.rectPadWidth,rect_pad_height:props.rectPadHeight,hole_offset_x:props.holeOffsetX,hole_offset_y:props.holeOffsetY,shape:"pill_hole_with_rect_pad",rect_border_radius:props.rectBorderRadius,port_hints:this.getNameAndAliases(),x:position4.x,y:position4.y,layers:["top","bottom"],soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_plated_hole_id=pcb_plated_hole3.pcb_plated_hole_id}else if(props.shape==="hole_with_polygon_pad"){let padOutline=(props.padOutline||[]).map(point62=>{let x4=typeof point62.x=="number"?point62.x:parseFloat(String(point62.x)),y4=typeof point62.y=="number"?point62.y:parseFloat(String(point62.y));return{x:x4,y:y4}}),pcb_plated_hole3=db2.pcb_plated_hole.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,shape:"hole_with_polygon_pad",hole_shape:props.holeShape||"circle",hole_diameter:props.holeDiameter,hole_width:props.holeWidth,hole_height:props.holeHeight,pad_outline:padOutline,hole_offset_x:typeof props.holeOffsetX=="number"?props.holeOffsetX:parseFloat(String(props.holeOffsetX||0)),hole_offset_y:typeof props.holeOffsetY=="number"?props.holeOffsetY:parseFloat(String(props.holeOffsetY||0)),port_hints:this.getNameAndAliases(),x:position4.x,y:position4.y,layers:["top","bottom"],soldermask_margin:soldermaskMargin,is_covered_with_solder_mask:isCoveredWithSolderMask,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_plated_hole_id=pcb_plated_hole3.pcb_plated_hole_id}}doInitialPcbPortAttachment(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;db2.pcb_plated_hole.update(this.pcb_plated_hole_id,{pcb_port_id:this.matchedPort?.pcb_port_id})}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_plated_hole_id)return;let hole=db2.pcb_plated_hole.get(this.pcb_plated_hole_id);if(hole){let newCenter={x:hole.x+deltaX,y:hole.y+deltaY};this._setPositionFromLayout(newCenter)}}},SilkscreenCircle=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_silkscreen_circle_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"SilkscreenCircle",zodProps:silkscreenCircleProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for SilkscreenCircle. Must be "top" or "bottom".`);let subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_circle3=db2.pcb_silkscreen_circle.insert({pcb_component_id,layer,center:{x:position4.x,y:position4.y},radius:props.radius,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,stroke_width:props.strokeWidth??.1});this.pcb_silkscreen_circle_id=pcb_silkscreen_circle3.pcb_silkscreen_circle_id}getPcbSize(){let{_parsedProps:props}=this,diameter=props.radius*2;return{width:diameter,height:diameter}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_silkscreen_circle_id)return;let circle2=db2.pcb_silkscreen_circle.get(this.pcb_silkscreen_circle_id);circle2&&db2.pcb_silkscreen_circle.update(this.pcb_silkscreen_circle_id,{center:{x:circle2.center.x+deltaX,y:circle2.center.y+deltaY}})}},SilkscreenLine=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_silkscreen_line_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"SilkscreenLine",zodProps:silkscreenLineProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for SilkscreenLine. Must be "top" or "bottom".`);let subcircuit=this.getSubcircuit(),transform6=this._computePcbGlobalTransformBeforeLayout(),p12=applyToPoint2(transform6,{x:props.x1,y:props.y1}),p22=applyToPoint2(transform6,{x:props.x2,y:props.y2}),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_line3=db2.pcb_silkscreen_line.insert({pcb_component_id,layer,x1:p12.x,y1:p12.y,x2:p22.x,y2:p22.y,stroke_width:props.strokeWidth??.1,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0});this.pcb_silkscreen_line_id=pcb_silkscreen_line3.pcb_silkscreen_line_id}getPcbSize(){let{_parsedProps:props}=this,width=Math.abs(props.x2-props.x1),height=Math.abs(props.y2-props.y1);return{width,height}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_silkscreen_line_id)return;let line2=db2.pcb_silkscreen_line.get(this.pcb_silkscreen_line_id);line2&&db2.pcb_silkscreen_line.update(this.pcb_silkscreen_line_id,{x1:line2.x1+deltaX,y1:line2.y1+deltaY,x2:line2.x2+deltaX,y2:line2.y2+deltaY})}},SilkscreenPath=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_silkscreen_path_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"SilkscreenPath",zodProps:silkscreenPathProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for SilkscreenPath. Must be "top" or "bottom".`);let transform6=this._computePcbGlobalTransformBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_path3=db2.pcb_silkscreen_path.insert({pcb_component_id,layer,route:props.route.map(p4=>{let transformedPosition=applyToPoint2(transform6,{x:p4.x,y:p4.y});return{...p4,x:transformedPosition.x,y:transformedPosition.y}}),stroke_width:props.strokeWidth??.1,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_silkscreen_path_id=pcb_silkscreen_path3.pcb_silkscreen_path_id}_setPositionFromLayout(newCenter){let{db:db2}=this.root,{_parsedProps:props}=this,currentPath=db2.pcb_silkscreen_path.get(this.pcb_silkscreen_path_id);if(!currentPath)return;let currentCenterX=0,currentCenterY=0;for(let point62 of currentPath.route)currentCenterX+=point62.x,currentCenterY+=point62.y;currentCenterX/=currentPath.route.length,currentCenterY/=currentPath.route.length;let offsetX=newCenter.x-currentCenterX,offsetY=newCenter.y-currentCenterY,newRoute=currentPath.route.map(point62=>({...point62,x:point62.x+offsetX,y:point62.y+offsetY}));db2.pcb_silkscreen_path.update(this.pcb_silkscreen_path_id,{route:newRoute})}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_silkscreen_path_id)return;let path=db2.pcb_silkscreen_path.get(this.pcb_silkscreen_path_id);path&&db2.pcb_silkscreen_path.update(this.pcb_silkscreen_path_id,{route:path.route.map(p4=>({...p4,x:p4.x+deltaX,y:p4.y+deltaY}))})}getPcbSize(){let{_parsedProps:props}=this;if(!props.route||props.route.length===0)return{width:0,height:0};let minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0;for(let point62 of props.route)minX=Math.min(minX,point62.x),maxX=Math.max(maxX,point62.x),minY=Math.min(minY,point62.y),maxY=Math.max(maxY,point62.y);return{width:maxX-minX,height:maxY-minY}}},SilkscreenRect=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_silkscreen_rect_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"SilkscreenRect",zodProps:silkscreenRectProps}}_isRotated90Degrees(){let globalTransform=this._computePcbGlobalTransformBeforeLayout(),normalizedRotationDegrees=(decomposeTSR2(globalTransform).rotation.angle*180/Math.PI%360+360)%360,rotationTolerance=.01;return Math.abs(normalizedRotationDegrees-90)<rotationTolerance||Math.abs(normalizedRotationDegrees-270)<rotationTolerance}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for SilkscreenRect. Must be "top" or "bottom".`);let subcircuit=this.getSubcircuit(),position4=this._getGlobalPcbPositionBeforeLayout(),isRotated90Degrees=this._isRotated90Degrees(),finalWidth=isRotated90Degrees?props.height:props.width,finalHeight=isRotated90Degrees?props.width:props.height,pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_rect3=db2.pcb_silkscreen_rect.insert({pcb_component_id,layer,center:{x:position4.x,y:position4.y},width:finalWidth,height:finalHeight,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this?.getGroup()?.pcb_group_id??void 0,stroke_width:props.strokeWidth??.1,is_filled:props.filled??!1,corner_radius:props.cornerRadius??void 0});this.pcb_silkscreen_rect_id=pcb_silkscreen_rect3.pcb_silkscreen_rect_id}getPcbSize(){let{_parsedProps:props}=this;return this._isRotated90Degrees()?{width:props.height,height:props.width}:{width:props.width,height:props.height}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_silkscreen_rect_id)return;let rect=db2.pcb_silkscreen_rect.get(this.pcb_silkscreen_rect_id);rect&&db2.pcb_silkscreen_rect.update(this.pcb_silkscreen_rect_id,{center:{x:rect.center.x+deltaX,y:rect.center.y+deltaY}})}},SilkscreenText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_silkscreen_text_ids",[]);__publicField(this,"isPcbPrimitive",!0);__publicField(this,"_footprinterFontSize")}get config(){return{componentName:"SilkscreenText",zodProps:silkscreenTextProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,container=this.getPrimitiveContainer(),{maybeFlipLayer,isFlipped}=this._getPcbPrimitiveFlippedHelpers(),subcircuit=this.getSubcircuit(),rotation42=0;if(props.pcbRotation!==void 0&&props.pcbRotation!==0)rotation42=props.pcbRotation;else{let globalTransform=this._computePcbGlobalTransformBeforeLayout();rotation42=decomposeTSR2(globalTransform).rotation.angle*180/Math.PI}isFlipped&&(rotation42=(rotation42+180)%360);let uniqueLayers=new Set(props.layers);props.layer&&uniqueLayers.add(props.layer);let targetLayers=uniqueLayers.size>0?Array.from(uniqueLayers):["top"],resolvedPcbSxFontSize=resolvePcbProperty({propertyName:"fontSize",resolvedPcbSx:this.getResolvedPcbSx(),pathFromAmpersand:"silkscreentext",component:this}),resolvedPcbSxPcbX=resolvePcbProperty({propertyName:"pcbX",resolvedPcbSx:this.getResolvedPcbSx(),pathFromAmpersand:"silkscreentext",component:this}),resolvedPcbSxPcbY=resolvePcbProperty({propertyName:"pcbY",resolvedPcbSx:this.getResolvedPcbSx(),pathFromAmpersand:"silkscreentext",component:this}),fontSize=props.fontSize??resolvedPcbSxFontSize??this.getInheritedProperty("pcbStyle")?.silkscreenFontSize??this._footprinterFontSize??1,position4=(resolvedPcbSxPcbX!==void 0||resolvedPcbSxPcbY!==void 0)&&this._footprinterFontSize!==void 0?applyToPoint2(compose2(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),isFlipped?flipY():identity()),{x:this.resolvePcbCoordinate({rawValue:resolvedPcbSxPcbX??props.pcbX??0,axis:"pcbX"}),y:this.resolvePcbCoordinate({rawValue:resolvedPcbSxPcbY??props.pcbY??0,axis:"pcbY"})}):this._getGlobalPcbPositionBeforeLayout(),uniformPadding=props.knockoutPadding??0,knockoutPadding=props.knockoutPadding!==void 0||props.knockoutPaddingLeft!==void 0||props.knockoutPaddingRight!==void 0||props.knockoutPaddingTop!==void 0||props.knockoutPaddingBottom!==void 0?{left:props.knockoutPaddingLeft??uniformPadding,right:props.knockoutPaddingRight??uniformPadding,top:props.knockoutPaddingTop??uniformPadding,bottom:props.knockoutPaddingBottom??uniformPadding}:void 0,text=this._resolveText();for(let layer of targetLayers){let pcb_silkscreen_text3=db2.pcb_silkscreen_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:position4.x,y:position4.y},font:props.font??"tscircuit2024",font_size:fontSize,layer:maybeFlipLayer(layer),text:normalizeTextForCircuitJson(text),ccw_rotation:rotation42,pcb_component_id:container.pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,is_knockout:props.isKnockout,knockout_padding:knockoutPadding});this.pcb_silkscreen_text_ids.push(pcb_silkscreen_text3.pcb_silkscreen_text_id)}}getPcbSize(){let{_parsedProps:props}=this,resolvedPcbSxFontSize=resolvePcbProperty({propertyName:"fontSize",resolvedPcbSx:this.getResolvedPcbSx(),pathFromAmpersand:"silkscreentext",component:this}),fontSize=props.fontSize??resolvedPcbSxFontSize??this.getInheritedProperty("pcbStyle")?.silkscreenFontSize??this._footprinterFontSize??1,textWidth=this._resolveText().length*fontSize,textHeight=fontSize;return{width:textWidth*fontSize,height:textHeight*fontSize}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;for(let id2 of this.pcb_silkscreen_text_ids){let text=db2.pcb_silkscreen_text.get(id2);text&&db2.pcb_silkscreen_text.update(id2,{anchor_position:{x:text.anchor_position.x+deltaX,y:text.anchor_position.y+deltaY}})}}};function getAxisAlignedSizeFromRotatedRect({width,height,ccwRotationDegrees}){let angleRad=ccwRotationDegrees*Math.PI/180,cosAngle=Math.cos(angleRad),sinAngle=Math.sin(angleRad),w22=width/2,h22=height/2,xExtent=Math.abs(w22*cosAngle)+Math.abs(h22*sinAngle),yExtent=Math.abs(w22*sinAngle)+Math.abs(h22*cosAngle);return{width:xExtent*2,height:yExtent*2,xExtent,yExtent}}var SmtPad=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_smtpad_id",null);__publicField(this,"matchedPort",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"SmtPad",zodProps:smtPadProps}}getPcbSize(){let{_parsedProps:props}=this;if(props.shape==="circle")return{width:props.radius*2,height:props.radius*2};if(props.shape==="rect")return{width:props.width,height:props.height};if(props.shape==="rotated_rect"){let{width,height}=getAxisAlignedSizeFromRotatedRect({width:props.width,height:props.height,ccwRotationDegrees:props.ccwRotation??0});return{width,height}}if(props.shape==="polygon"){let points=props.points,xs3=points.map(p4=>p4.x),ys3=points.map(p4=>p4.y),minX=Math.min(...xs3),maxX=Math.max(...xs3),minY=Math.min(...ys3),maxY=Math.max(...ys3);return{width:maxX-minX,height:maxY-minY}}if(props.shape==="pill")return{width:props.width,height:props.height};throw new Error(`getPcbSize for shape "${props.shape}" not implemented for ${this.componentName}`)}doInitialPortMatching(){let parentPorts=this.getPrimitiveContainer()?.selectAll("port");if(!this.props.portHints)return;let port=selectPortForPcbPrimitive(parentPorts,this,this.props.portHints);port&&(this.matchedPort=port,port.registerMatch(this))}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,isCoveredWithSolderMask=props.coveredWithSolderMask??!1,shouldCreateSolderPaste=!isCoveredWithSolderMask,soldermaskMargin=props.solderMaskMargin;this.emitSolderMaskMarginWarning(isCoveredWithSolderMask,soldermaskMargin);let subcircuit=this.getSubcircuit(),position4=this._getGlobalPcbPositionBeforeLayout(),globalTransform=this._computePcbGlobalTransformBeforeLayout(),normalizedRotationDegrees=(decomposeTSR2(this._computePcbGlobalTransformBeforeLayout()).rotation.angle*180/Math.PI%360+360)%360,rotationTolerance=.01,isAxisAligned=Math.abs(normalizedRotationDegrees)<rotationTolerance||Math.abs(normalizedRotationDegrees-180)<rotationTolerance||Math.abs(normalizedRotationDegrees-360)<rotationTolerance,isRotated90Degrees=Math.abs(normalizedRotationDegrees-90)<rotationTolerance||Math.abs(normalizedRotationDegrees-270)<rotationTolerance,finalRotationDegrees=Math.abs(normalizedRotationDegrees-360)<rotationTolerance?0:normalizedRotationDegrees,transformRotationBeforeFlip=finalRotationDegrees,{maybeFlipLayer,isFlipped}=this._getPcbPrimitiveFlippedHelpers();isFlipped&&(finalRotationDegrees=(360-finalRotationDegrees+360)%360);let portHints2=props.portHints?.map(ph3=>ph3.toString())??[],pcb_smtpad3=null,pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id;if(props.shape==="circle")pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"circle",radius:props.radius,port_hints:portHints2,is_covered_with_solder_mask:isCoveredWithSolderMask,soldermask_margin:soldermaskMargin,x:position4.x,y:position4.y,subcircuit_id:subcircuit?.subcircuit_id??void 0}),shouldCreateSolderPaste&&db2.pcb_solder_paste.insert({layer:pcb_smtpad3.layer,shape:"circle",radius:pcb_smtpad3.radius*.7,x:pcb_smtpad3.x,y:pcb_smtpad3.y,pcb_component_id:pcb_smtpad3.pcb_component_id,pcb_smtpad_id:pcb_smtpad3.pcb_smtpad_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});else if(props.shape==="rect")!isAxisAligned&&!isRotated90Degrees?pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"rotated_rect",width:props.width,height:props.height,corner_radius:props.cornerRadius??void 0,x:position4.x,y:position4.y,ccw_rotation:finalRotationDegrees,port_hints:portHints2,is_covered_with_solder_mask:isCoveredWithSolderMask,soldermask_margin:soldermaskMargin,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}):pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"rect",width:isRotated90Degrees?props.height:props.width,height:isRotated90Degrees?props.width:props.height,corner_radius:props.cornerRadius??void 0,port_hints:portHints2,is_covered_with_solder_mask:isCoveredWithSolderMask,soldermask_margin:soldermaskMargin,x:position4.x,y:position4.y,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}),shouldCreateSolderPaste&&(pcb_smtpad3.shape==="rect"?db2.pcb_solder_paste.insert({layer:maybeFlipLayer(props.layer??"top"),shape:"rect",width:pcb_smtpad3.width*.7,height:pcb_smtpad3.height*.7,x:pcb_smtpad3.x,y:pcb_smtpad3.y,pcb_component_id:pcb_smtpad3.pcb_component_id,pcb_smtpad_id:pcb_smtpad3.pcb_smtpad_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}):pcb_smtpad3.shape==="rotated_rect"&&db2.pcb_solder_paste.insert({layer:maybeFlipLayer(props.layer??"top"),shape:"rotated_rect",width:pcb_smtpad3.width*.7,height:pcb_smtpad3.height*.7,x:pcb_smtpad3.x,y:pcb_smtpad3.y,ccw_rotation:pcb_smtpad3.ccw_rotation,pcb_component_id:pcb_smtpad3.pcb_component_id,pcb_smtpad_id:pcb_smtpad3.pcb_smtpad_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}));else if(props.shape==="rotated_rect"){let baseRotation=props.ccwRotation??0,combinedRotationBeforeFlip=(transformRotationBeforeFlip+baseRotation+360)%360,padRotation=isFlipped?(360-combinedRotationBeforeFlip+360)%360:combinedRotationBeforeFlip;pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"rotated_rect",width:props.width,height:props.height,corner_radius:props.cornerRadius??void 0,x:position4.x,y:position4.y,ccw_rotation:padRotation,port_hints:portHints2,is_covered_with_solder_mask:isCoveredWithSolderMask,soldermask_margin:soldermaskMargin,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}),shouldCreateSolderPaste&&db2.pcb_solder_paste.insert({layer:maybeFlipLayer(props.layer??"top"),shape:"rotated_rect",width:pcb_smtpad3.width*.7,height:pcb_smtpad3.height*.7,x:position4.x,y:position4.y,ccw_rotation:padRotation,pcb_component_id,pcb_smtpad_id:pcb_smtpad3.pcb_smtpad_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0})}else if(props.shape==="polygon"){let transformedPoints=props.points.map(point62=>{let transformed=applyToPoint2(globalTransform,{x:distance.parse(point62.x),y:distance.parse(point62.y)});return{x:transformed.x,y:transformed.y}});pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"polygon",points:transformedPoints,port_hints:portHints2,is_covered_with_solder_mask:isCoveredWithSolderMask,soldermask_margin:soldermaskMargin,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0})}else props.shape==="pill"&&(finalRotationDegrees!==0?pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"rotated_pill",x:position4.x,y:position4.y,radius:props.radius,height:props.height,width:props.width,ccw_rotation:finalRotationDegrees,port_hints:portHints2,is_covered_with_solder_mask:isCoveredWithSolderMask,soldermask_margin:soldermaskMargin,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}):pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"pill",x:position4.x,y:position4.y,radius:props.radius,height:props.height,width:props.width,port_hints:portHints2,is_covered_with_solder_mask:isCoveredWithSolderMask,soldermask_margin:soldermaskMargin,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}));pcb_smtpad3&&(this.pcb_smtpad_id=pcb_smtpad3.pcb_smtpad_id)}doInitialPcbPortAttachment(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;db2.pcb_smtpad.update(this.pcb_smtpad_id,{pcb_port_id:this.matchedPort?.pcb_port_id})}_getPcbCircuitJsonBounds(){let{db:db2}=this.root,smtpad2=db2.pcb_smtpad.get(this.pcb_smtpad_id);if(smtpad2.shape==="rect")return{center:{x:smtpad2.x,y:smtpad2.y},bounds:{left:smtpad2.x-smtpad2.width/2,top:smtpad2.y+smtpad2.height/2,right:smtpad2.x+smtpad2.width/2,bottom:smtpad2.y-smtpad2.height/2},width:smtpad2.width,height:smtpad2.height};if(smtpad2.shape==="rotated_rect"){let{width,height,xExtent,yExtent}=getAxisAlignedSizeFromRotatedRect({width:smtpad2.width,height:smtpad2.height,ccwRotationDegrees:smtpad2.ccw_rotation});return{center:{x:smtpad2.x,y:smtpad2.y},bounds:{left:smtpad2.x-xExtent,right:smtpad2.x+xExtent,top:smtpad2.y-yExtent,bottom:smtpad2.y+yExtent},width,height}}if(smtpad2.shape==="circle")return{center:{x:smtpad2.x,y:smtpad2.y},bounds:{left:smtpad2.x-smtpad2.radius,top:smtpad2.y-smtpad2.radius,right:smtpad2.x+smtpad2.radius,bottom:smtpad2.y+smtpad2.radius},width:smtpad2.radius*2,height:smtpad2.radius*2};if(smtpad2.shape==="polygon"){let points=smtpad2.points,xs3=points.map(p4=>p4.x),ys3=points.map(p4=>p4.y),minX=Math.min(...xs3),maxX=Math.max(...xs3),minY=Math.min(...ys3),maxY=Math.max(...ys3);return{center:{x:(minX+maxX)/2,y:(minY+maxY)/2},bounds:{left:minX,top:maxY,right:maxX,bottom:minY},width:maxX-minX,height:maxY-minY}}if(smtpad2.shape==="pill"){let halfWidth=smtpad2.width/2,halfHeight=smtpad2.height/2;return{center:{x:smtpad2.x,y:smtpad2.y},bounds:{left:smtpad2.x-halfWidth,top:smtpad2.y-halfHeight,right:smtpad2.x+halfWidth,bottom:smtpad2.y+halfHeight},width:smtpad2.width,height:smtpad2.height}}if(smtpad2.shape==="rotated_pill"){let{width,height,xExtent,yExtent}=getAxisAlignedSizeFromRotatedRect({width:smtpad2.width,height:smtpad2.height,ccwRotationDegrees:smtpad2.ccw_rotation});return{center:{x:smtpad2.x,y:smtpad2.y},bounds:{left:smtpad2.x-xExtent,right:smtpad2.x+xExtent,top:smtpad2.y-yExtent,bottom:smtpad2.y+yExtent},width,height}}throw new Error(`circuitJson bounds calculation not implemented for shape "${smtpad2.shape}"`)}_setPositionFromLayout(newCenter){let{db:db2}=this.root;db2.pcb_smtpad.update(this.pcb_smtpad_id,{x:newCenter.x,y:newCenter.y});let solderPaste=db2.pcb_solder_paste.list().find(elm=>elm.pcb_smtpad_id===this.pcb_smtpad_id);solderPaste&&db2.pcb_solder_paste.update(solderPaste.pcb_solder_paste_id,{x:newCenter.x,y:newCenter.y}),this.matchedPort?._setPositionFromLayout(newCenter)}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_smtpad_id)return;let pad2=db2.pcb_smtpad.get(this.pcb_smtpad_id);if(pad2.shape==="rect"||pad2.shape==="circle"||pad2.shape==="rotated_rect"||pad2.shape==="pill"||pad2.shape==="rotated_pill")this._setPositionFromLayout({x:pad2.x+deltaX,y:pad2.y+deltaY});else if(pad2.shape==="polygon"){db2.pcb_smtpad.update(this.pcb_smtpad_id,{points:pad2.points.map(p4=>({x:p4.x+deltaX,y:p4.y+deltaY}))});let newCenter={x:this._getPcbCircuitJsonBounds().center.x+deltaX/2,y:this._getPcbCircuitJsonBounds().center.y+deltaY/2};this.matchedPort?._setPositionFromLayout(newCenter)}}},createPinrowSilkscreenText=({elm,pinLabels,layer,readableRotation,anchorAlignment})=>{let pinNum=elm.text.replace(/[{}]/g,"").toLowerCase(),label=pinNum;if(Array.isArray(pinLabels)){let index=parseInt(pinNum.replace(/[^\d]/g,""),10)-1;label=String(pinLabels[index]??pinNum)}else typeof pinLabels=="object"&&(label=String(pinLabels[pinNum]??pinNum));let silkscreenText=new SilkscreenText({anchorAlignment:anchorAlignment||"center",text:label??pinNum,layer:layer||"top",pcbX:isNaN(elm.anchor_position.x)?0:elm.anchor_position.x,pcbY:elm.anchor_position.y,pcbRotation:readableRotation??0});return silkscreenText._footprinterFontSize=elm.font_size+.2,silkscreenText},calculateCcwRotation=(componentRotationStr,elementCcwRotation)=>{let componentAngle=parseInt(componentRotationStr||"0",10),totalRotation;return elementCcwRotation!=null?totalRotation=elementCcwRotation-componentAngle:totalRotation=componentAngle,(totalRotation%360+360)%360},createComponentsFromCircuitJson=({componentName,componentRotation,footprinterString,pinLabels,pcbPinLabels},circuitJson)=>{let components=[];for(let elm of circuitJson)if(elm.type==="pcb_smtpad"&&elm.shape==="rect")components.push(new SmtPad({pcbX:elm.x,pcbY:elm.y,layer:elm.layer,shape:"rect",height:elm.height,width:elm.width,portHints:elm.port_hints,rectBorderRadius:elm.rect_border_radius}));else if(elm.type==="pcb_smtpad"&&elm.shape==="circle")components.push(new SmtPad({pcbX:elm.x,pcbY:elm.y,layer:elm.layer,shape:"circle",radius:elm.radius,portHints:elm.port_hints}));else if(elm.type==="pcb_smtpad"&&elm.shape==="pill")components.push(new SmtPad({shape:"pill",height:elm.height,width:elm.width,radius:elm.radius,portHints:elm.port_hints,pcbX:elm.x,pcbY:elm.y,layer:elm.layer}));else if(elm.type==="pcb_smtpad"&&elm.shape==="polygon")components.push(new SmtPad({shape:"polygon",points:elm.points,portHints:elm.port_hints,layer:elm.layer}));else if(elm.type==="pcb_silkscreen_path")components.push(new SilkscreenPath({layer:elm.layer,route:elm.route,strokeWidth:elm.stroke_width}));else if(elm.type==="pcb_plated_hole")elm.shape==="circle"?components.push(new PlatedHole({pcbX:elm.x,pcbY:elm.y,shape:"circle",holeDiameter:elm.hole_diameter,outerDiameter:elm.outer_diameter,portHints:elm.port_hints})):elm.shape==="circular_hole_with_rect_pad"?components.push(new PlatedHole({pcbX:elm.x,pcbY:elm.y,shape:"circular_hole_with_rect_pad",holeDiameter:elm.hole_diameter,rectPadHeight:elm.rect_pad_height,rectPadWidth:elm.rect_pad_width,portHints:elm.port_hints,rectBorderRadius:elm.rect_border_radius,holeOffsetX:elm.hole_offset_x,holeOffsetY:elm.hole_offset_y})):elm.shape==="pill"||elm.shape==="oval"?components.push(new PlatedHole({pcbX:elm.x,pcbY:elm.y,shape:elm.shape,holeWidth:elm.hole_width,holeHeight:elm.hole_height,outerWidth:elm.outer_width,outerHeight:elm.outer_height,portHints:elm.port_hints})):elm.shape==="pill_hole_with_rect_pad"?components.push(new PlatedHole({pcbX:elm.x,pcbY:elm.y,shape:"pill_hole_with_rect_pad",holeShape:"pill",padShape:"rect",holeWidth:elm.hole_width,holeHeight:elm.hole_height,rectPadWidth:elm.rect_pad_width,rectPadHeight:elm.rect_pad_height,rectBorderRadius:elm.rect_border_radius,portHints:elm.port_hints,holeOffsetX:elm.hole_offset_x,holeOffsetY:elm.hole_offset_y})):elm.shape==="rotated_pill_hole_with_rect_pad"?components.push(new PlatedHole({pcbX:elm.x,pcbY:elm.y,shape:"pill_hole_with_rect_pad",holeShape:"pill",padShape:"rect",holeWidth:elm.hole_width,holeHeight:elm.hole_height,rectPadWidth:elm.rect_pad_width,rectPadHeight:elm.rect_pad_height,rectBorderRadius:elm.rect_border_radius,portHints:elm.port_hints,holeOffsetX:elm.hole_offset_x,holeOffsetY:elm.hole_offset_y,pcbRotation:elm.hole_ccw_rotation})):elm.shape==="hole_with_polygon_pad"&&components.push(new PlatedHole({pcbX:elm.x,pcbY:elm.y,shape:"hole_with_polygon_pad",holeShape:elm.hole_shape||"circle",holeDiameter:elm.hole_diameter,holeWidth:elm.hole_width,holeHeight:elm.hole_height,padOutline:elm.pad_outline||[],holeOffsetX:elm.hole_offset_x,holeOffsetY:elm.hole_offset_y,portHints:elm.port_hints}));else if(elm.type==="pcb_keepout"&&elm.shape==="circle")components.push(new Keepout({pcbX:elm.center.x,pcbY:elm.center.y,shape:"circle",radius:elm.radius}));else if(elm.type==="pcb_keepout"&&elm.shape==="rect")components.push(new Keepout({pcbX:elm.center.x,pcbY:elm.center.y,shape:"rect",width:elm.width,height:elm.height}));else if(elm.type==="pcb_hole"&&elm.hole_shape==="circle")components.push(new Hole({pcbX:elm.x,pcbY:elm.y,diameter:elm.hole_diameter}));else if(elm.type==="pcb_hole"&&elm.hole_shape==="rect")components.push(new Hole({pcbX:elm.x,pcbY:elm.y,shape:"rect",width:elm.hole_width,height:elm.hole_height}));else if(elm.type==="pcb_hole"&&elm.hole_shape==="pill")components.push(new Hole({pcbX:elm.x,pcbY:elm.y,shape:"pill",width:elm.hole_width,height:elm.hole_height}));else if(elm.type==="pcb_hole"&&elm.hole_shape==="rotated_pill")components.push(new Hole({pcbX:elm.x,pcbY:elm.y,shape:"pill",width:elm.hole_width,height:elm.hole_height,pcbRotation:elm.ccw_rotation}));else if(elm.type==="pcb_cutout")elm.shape==="rect"?components.push(new Cutout({pcbX:elm.center.x,pcbY:elm.center.y,shape:"rect",width:elm.width,height:elm.height})):elm.shape==="circle"?components.push(new Cutout({pcbX:elm.center.x,pcbY:elm.center.y,shape:"circle",radius:elm.radius})):elm.shape==="polygon"&&components.push(new Cutout({shape:"polygon",points:elm.points}));else if(elm.type==="pcb_silkscreen_text"){let ccwRotation=calculateCcwRotation(componentRotation,elm.ccw_rotation);if(footprinterString?.includes("pinrow")&&elm.text.includes("PIN"))components.push(createPinrowSilkscreenText({elm,pinLabels:pcbPinLabels??pinLabels??{},layer:elm.layer,readableRotation:ccwRotation,anchorAlignment:elm.anchor_alignment}));else{let silkscreenText=new SilkscreenText({anchorAlignment:elm.anchor_alignment||"center",text:componentName||elm.text,pcbX:Number.isNaN(elm.anchor_position.x)?0:elm.anchor_position.x,pcbY:elm.anchor_position.y,pcbRotation:ccwRotation??0});silkscreenText._footprinterFontSize=elm.font_size+.2,components.push(silkscreenText)}}else elm.type==="pcb_trace"?components.push(new PcbTrace({route:elm.route})):elm.type==="pcb_silkscreen_rect"?components.push(new SilkscreenRect({pcbX:elm.center.x,pcbY:elm.center.y,width:elm.width,height:elm.height,layer:elm.layer,strokeWidth:elm.stroke_width,filled:elm.is_filled,cornerRadius:elm.corner_radius})):elm.type==="pcb_silkscreen_circle"?components.push(new SilkscreenCircle({pcbX:elm.center.x,pcbY:elm.center.y,radius:elm.radius,layer:elm.layer,strokeWidth:elm.stroke_width})):elm.type==="pcb_silkscreen_line"?components.push(new SilkscreenLine({x1:elm.x1,y1:elm.y1,x2:elm.x2,y2:elm.y2,layer:elm.layer,strokeWidth:elm.stroke_width})):elm.type==="pcb_fabrication_note_text"?components.push(new FabricationNoteText({pcbX:elm.anchor_position.x,pcbY:elm.anchor_position.y,text:elm.text,fontSize:elm.font_size,anchorAlignment:elm.anchor_alignment,color:elm.color,font:elm.font})):elm.type==="pcb_fabrication_note_path"?components.push(new FabricationNotePath({route:elm.route,strokeWidth:elm.stroke_width,color:elm.color,layer:elm.layer})):elm.type==="pcb_fabrication_note_rect"?components.push(new FabricationNoteRect({pcbX:elm.center.x,pcbY:elm.center.y,width:elm.width,height:elm.height,strokeWidth:elm.stroke_width,isFilled:elm.is_filled,color:elm.color,layer:elm.layer,cornerRadius:elm.corner_radius,hasStroke:elm.has_stroke,isStrokeDashed:elm.is_stroke_dashed})):elm.type==="pcb_note_text"?components.push(new PcbNoteText({pcbX:elm.anchor_position.x,pcbY:elm.anchor_position.y,text:elm.text??"",fontSize:elm.font_size,anchorAlignment:elm.anchor_alignment,color:elm.color,font:elm.font})):elm.type==="pcb_note_rect"?components.push(new PcbNoteRect({pcbX:elm.center.x,pcbY:elm.center.y,width:elm.width,height:elm.height,strokeWidth:elm.stroke_width,isFilled:elm.is_filled,color:elm.color,cornerRadius:elm.corner_radius,hasStroke:elm.has_stroke,isStrokeDashed:elm.is_stroke_dashed})):elm.type==="pcb_note_path"?components.push(new PcbNotePath({route:elm.route,strokeWidth:elm.stroke_width,color:elm.color})):elm.type==="pcb_note_line"?components.push(new PcbNoteLine({x1:elm.x1,y1:elm.y1,x2:elm.x2,y2:elm.y2,strokeWidth:elm.stroke_width,color:elm.color,isDashed:elm.is_dashed})):elm.type==="pcb_courtyard_rect"?components.push(new CourtyardRect({pcbX:elm.center.x,pcbY:elm.center.y,width:elm.width,height:elm.height,layer:elm.layer})):elm.type==="pcb_courtyard_circle"?components.push(new CourtyardCircle({pcbX:elm.center.x,pcbY:elm.center.y,radius:elm.radius,layer:elm.layer})):elm.type==="pcb_courtyard_outline"&&components.push(new CourtyardOutline({outline:elm.outline,layer:elm.layer}));return components};function filterPinLabels(pinLabels){if(!pinLabels)return{validPinLabels:pinLabels,invalidPinLabelsMessages:[]};let validPinLabels={},invalidPinLabelsMessages=[];for(let[pin,labelOrLabels]of Object.entries(pinLabels)){let labels=Array.isArray(labelOrLabels)?labelOrLabels.slice():[labelOrLabels],validLabels=[];for(let label of labels)isValidPinLabel(pin,label)?validLabels.push(label):invalidPinLabelsMessages.push(`Invalid pin label: ${pin} = '${label}' - excluding from component. Pin labels can only contain letters, numbers and underscores.`);validLabels.length>0&&(validPinLabels[pin]=Array.isArray(labelOrLabels)?validLabels:validLabels[0])}return{validPinLabels:Object.keys(validPinLabels).length>0?validPinLabels:void 0,invalidPinLabelsMessages}}function isValidPinLabel(pin,label){try{let testProps={name:"test",footprint:"test",pinLabels:{[pin]:label}};return chipProps.safeParse(testProps).success}catch{return!1}}var NON_PHYSICAL_PCB_PRIMITIVE_PREFIXES=["Silkscreen","PcbNote","Courtyard","FabricationNote"];function getBoundsOfPcbComponents(components){let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0,hasValidComponents=!1;for(let child of components)if(child.isPcbPrimitive&&!NON_PHYSICAL_PCB_PRIMITIVE_PREFIXES.some(prefix=>child.componentName.startsWith(prefix))){let{x:x4,y:y4}=child._getGlobalPcbPositionBeforeLayout(),{width:width2,height:height2}=child.getPcbSize();minX=Math.min(minX,x4-width2/2),minY=Math.min(minY,y4-height2/2),maxX=Math.max(maxX,x4+width2/2),maxY=Math.max(maxY,y4+height2/2),hasValidComponents=!0}else if(child.children.length>0){let childBounds=getBoundsOfPcbComponents(child.children);(childBounds.width>0||childBounds.height>0)&&(minX=Math.min(minX,childBounds.minX),minY=Math.min(minY,childBounds.minY),maxX=Math.max(maxX,childBounds.maxX),maxY=Math.max(maxY,childBounds.maxY),hasValidComponents=!0)}if(!hasValidComponents)return{minX:0,minY:0,maxX:0,maxY:0,width:0,height:0};let width=maxX-minX,height=maxY-minY;return width<0&&(width=0),height<0&&(height=0),{minX,minY,maxX,maxY,width,height}}function getRelativeDirection(pointA,pointB){let dx3=pointB.x-pointA.x,dy3=pointB.y-pointA.y;return Math.abs(dx3)>Math.abs(dy3)?dx3>=0?"right":"left":dy3>=0?"up":"down"}var stringProxy=new Proxy({},{get:(target,prop)=>prop}),FTYPE=stringProxy,SCHEMATIC_COMPONENT_OUTLINE_COLOR="rgba(132, 0, 0)",SCHEMATIC_COMPONENT_OUTLINE_STROKE_WIDTH=.12,getCenterOfPcbPrimitives=pcbPrimitives=>{if(pcbPrimitives.length===0)throw new Error("Cannot get center of empty PCB primitives array");let positions=pcbPrimitives.map(p4=>p4._getPcbCircuitJsonBounds().center).filter(Boolean),sumX=positions.reduce((sum,pos)=>sum+pos.x,0),sumY=positions.reduce((sum,pos)=>sum+pos.y,0);return{x:sumX/positions.length,y:sumY/positions.length}},applyPinAttributesToSourcePort=(sourcePortProps,attributes2)=>{attributes2.mustBeConnected!==void 0&&(sourcePortProps.must_be_connected=attributes2.mustBeConnected),attributes2.providesPower!==void 0&&(sourcePortProps.provides_power=attributes2.providesPower),attributes2.requiresPower!==void 0&&(sourcePortProps.requires_power=attributes2.requiresPower),attributes2.providesGround!==void 0&&(sourcePortProps.provides_ground=attributes2.providesGround),attributes2.requiresGround!==void 0&&(sourcePortProps.requires_ground=attributes2.requiresGround),attributes2.providesVoltage!==void 0&&(sourcePortProps.provides_voltage=attributes2.providesVoltage),attributes2.requiresVoltage!==void 0&&(sourcePortProps.requires_voltage=attributes2.requiresVoltage),attributes2.doNotConnect!==void 0&&(sourcePortProps.do_not_connect=attributes2.doNotConnect),attributes2.includeInBoardPinout!==void 0&&(sourcePortProps.include_in_board_pinout=attributes2.includeInBoardPinout),attributes2.canUseInternalPullup!==void 0&&(sourcePortProps.can_use_internal_pullup=attributes2.canUseInternalPullup),attributes2.isUsingInternalPullup!==void 0&&(sourcePortProps.is_using_internal_pullup=attributes2.isUsingInternalPullup),attributes2.needsExternalPullup!==void 0&&(sourcePortProps.needs_external_pullup=attributes2.needsExternalPullup),attributes2.canUseInternalPulldown!==void 0&&(sourcePortProps.can_use_internal_pulldown=attributes2.canUseInternalPulldown),attributes2.isUsingInternalPulldown!==void 0&&(sourcePortProps.is_using_internal_pulldown=attributes2.isUsingInternalPulldown),attributes2.needsExternalPulldown!==void 0&&(sourcePortProps.needs_external_pulldown=attributes2.needsExternalPulldown),attributes2.canUseOpenDrain!==void 0&&(sourcePortProps.can_use_open_drain=attributes2.canUseOpenDrain),attributes2.isUsingOpenDrain!==void 0&&(sourcePortProps.is_using_open_drain=attributes2.isUsingOpenDrain),attributes2.canUsePushPull!==void 0&&(sourcePortProps.can_use_push_pull=attributes2.canUsePushPull),attributes2.isUsingPushPull!==void 0&&(sourcePortProps.is_using_push_pull=attributes2.isUsingPushPull),attributes2.shouldHaveDecouplingCapacitor!==void 0&&(sourcePortProps.should_have_decoupling_capacitor=attributes2.shouldHaveDecouplingCapacitor),attributes2.recommendedDecouplingCapacitorCapacitance!==void 0&&(sourcePortProps.recommended_decoupling_capacitor_capacitance=attributes2.recommendedDecouplingCapacitorCapacitance)},portProps2=external_exports.object({name:external_exports.string().optional(),pinNumber:external_exports.number().optional(),schStemLength:external_exports.number().optional(),aliases:external_exports.array(external_exports.string()).optional(),layer:external_exports.string().optional(),layers:external_exports.array(external_exports.string()).optional(),schX:external_exports.number().optional(),schY:external_exports.number().optional(),direction:external_exports.enum(["up","down","left","right"]).optional(),connectsTo:external_exports.union([external_exports.string(),external_exports.array(external_exports.string())]).optional()}),Port=class extends PrimitiveComponent2{constructor(props,opts={}){if(!props.name&&props.pinNumber!==void 0&&(props.name=`pin${props.pinNumber}`),!props.name)throw new Error("Port must have a name or a pinNumber");super(props);__publicField(this,"source_port_id",null);__publicField(this,"pcb_port_id",null);__publicField(this,"schematic_port_id",null);__publicField(this,"schematic_stem_line_id",null);__publicField(this,"schematicSymbolPortDef",null);__publicField(this,"matchedComponents");__publicField(this,"_isPrimaryPort",!0);__publicField(this,"_primaryPinNumber",null);__publicField(this,"facingDirection",null);__publicField(this,"originDescription",null);opts.originDescription&&(this.originDescription=opts.originDescription),this.matchedComponents=[]}get config(){return{componentName:"Port",zodProps:portProps2}}isGroupPort(){return this.parent?.componentName==="Group"}isComponentPort(){return!this.isGroupPort()}_getConnectedPortsFromConnectsTo(){let{_parsedProps:props}=this,connectsTo=props.connectsTo;if(!connectsTo)return[];let connectedPorts=[],connectsToArray=Array.isArray(connectsTo)?connectsTo:[connectsTo];for(let connection of connectsToArray){let port=this.getSubcircuit().selectOne(connection,{type:"port"});port&&connectedPorts.push(port)}return connectedPorts}_isBoardPinoutFromAttributes(){let parent=this.parent;if(parent?._parsedProps?.pinAttributes){let pinAttributes=parent._parsedProps.pinAttributes;for(let alias of this.getNameAndAliases())if(pinAttributes[alias]?.includeInBoardPinout)return!0}}_getGlobalPcbPositionBeforeLayout(){let matchedPcbElm=this.matchedComponents.find(c4=>c4.isPcbPrimitive),parentComponent=this.parent;if(parentComponent&&!parentComponent.props.footprint)throw new Error(`${parentComponent.componentName} "${parentComponent.props.name}" does not have a footprint. Add a footprint prop, e.g. <${parentComponent.componentName.toLowerCase()} footprint="..." />`);if(!matchedPcbElm)throw new Error(`Port ${this} has no matching PCB primitives. This often means the footprint's pads lack matching port hints.`);return matchedPcbElm?._getGlobalPcbPositionBeforeLayout()??{x:0,y:0}}_getPcbCircuitJsonBounds(){if(!this.pcb_port_id)return super._getPcbCircuitJsonBounds();let{db:db2}=this.root,pcb_port3=db2.pcb_port.get(this.pcb_port_id);return{center:{x:pcb_port3.x,y:pcb_port3.y},bounds:{left:0,top:0,right:0,bottom:0},width:0,height:0}}_getGlobalPcbPositionAfterLayout(){return this._getPcbCircuitJsonBounds().center}_getPortsInternallyConnectedToThisPort(){let parent=this.parent;if(!parent||!parent._getInternallyConnectedPins)return[];let internallyConnectedPorts=parent._getInternallyConnectedPins();for(let ports of internallyConnectedPorts)if(ports.some(port=>port===this))return ports;return[]}_hasSchematicPort(){let{schX,schY}=this._parsedProps;if(schX!==void 0&&schY!==void 0)return!0;let parentNormalComponent=this.getParentNormalComponent();if(parentNormalComponent?.getSchematicSymbol())return!!(this.schematicSymbolPortDef||this._getPortsInternallyConnectedToThisPort().some(p4=>p4.schematicSymbolPortDef));let parentBoxDim=parentNormalComponent?._getSchematicBoxDimensions();return!!(parentBoxDim&&this._parsedProps.pinNumber!==void 0&&parentBoxDim.getPortPositionByPinNumber(this._parsedProps.pinNumber))}_getGlobalSchematicPositionBeforeLayout(){let{schX,schY}=this._parsedProps;if(schX!==void 0&&schY!==void 0)return{x:schX,y:schY};let parentNormalComponent=this.getParentNormalComponent(),symbol=parentNormalComponent?.getSchematicSymbol();if(symbol){let schematicSymbolPortDef=this.schematicSymbolPortDef;if(!schematicSymbolPortDef&&(schematicSymbolPortDef=this._getPortsInternallyConnectedToThisPort().find(p4=>p4.schematicSymbolPortDef)?.schematicSymbolPortDef??null,!schematicSymbolPortDef))throw new Error(`Couldn't find schematicSymbolPortDef for port ${this.getString()}, searched internally connected ports and none had a schematicSymbolPortDef. Why are we trying to get the schematic position of this port?`);let transform6=compose2(parentNormalComponent.computeSchematicGlobalTransform(),translate2(-symbol.center.x,-symbol.center.y));return applyToPoint2(transform6,schematicSymbolPortDef)}let parentBoxDim=parentNormalComponent?._getSchematicBoxDimensions();if(parentBoxDim&&this._parsedProps.pinNumber!==void 0){let localPortPosition=parentBoxDim.getPortPositionByPinNumber(this._parsedProps.pinNumber);if(!localPortPosition)throw new Error(`Couldn't find position for schematic_port for port ${this.getString()} inside of the schematic box`);return applyToPoint2(parentNormalComponent.computeSchematicGlobalTransform(),localPortPosition)}throw new Error(`Couldn't find position for schematic_port for port ${this.getString()}`)}_getGlobalSchematicPositionAfterLayout(){let{db:db2}=this.root;if(!this.schematic_port_id)throw new Error(`Can't get schematic port position after layout for "${this.getString()}", no schematic_port_id`);let schematic_port3=db2.schematic_port.get(this.schematic_port_id);if(!schematic_port3)throw new Error(`Schematic port not found when trying to get post-layout position: ${this.schematic_port_id}`);return schematic_port3.center}registerMatch(component){this.matchedComponents.push(component)}getNameAndAliases(){let{_parsedProps:props}=this;return Array.from(new Set([...props.name?[props.name]:[],...props.aliases??[],...typeof props.pinNumber=="number"?[`pin${props.pinNumber}`,props.pinNumber.toString()]:[],...this.externallyAddedAliases??[]]))}_getMatchingPinAttributes(){let parentProps=this.parent?._parsedProps,pinAttributes=parentProps?.pinAttributes,noConnect=parentProps?.noConnect,matches=[];for(let alias of this.getNameAndAliases()){if(pinAttributes){let attributes2=pinAttributes[alias];attributes2&&matches.push(attributes2)}noConnect?.includes(alias)&&matches.push({doNotConnect:!0})}return matches.length===0?[]:matches}_shouldIncludeInBoardPinout(){return this._getMatchingPinAttributes().some(attributes2=>attributes2.includeInBoardPinout===!0)}isMatchingPort(port){return this.isMatchingAnyOf(port.getNameAndAliases())}getPortSelector(){return`.${(this.getParentNormalComponent()??this.parent)?.props.name} > port.${this.props.name}`}getAvailablePcbLayers(){let{layer,layers}=this._parsedProps;return layers||(layer?[layer]:Array.from(new Set(this.matchedComponents.flatMap(c4=>c4.getAvailablePcbLayers()))))}_getDirectlyConnectedTraces(){return this.getSubcircuit().selectAll("trace").filter(trace=>!trace._couldNotFindPort).filter(trace=>trace._isExplicitlyConnectedToPort(this))}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,port_hints=this.getNameAndAliases(),parentNormalComponent=this.getParentNormalComponent(),source_component_id=(this.parent?.source_component_id?this.parent:parentNormalComponent)?.source_component_id??null,pinAttributes=this._getMatchingPinAttributes(),portAttributesFromParent={};for(let attributes2 of pinAttributes)applyPinAttributesToSourcePort(portAttributesFromParent,attributes2);let source_port3=db2.source_port.insert({name:props.name,pin_number:props.pinNumber,port_hints,source_component_id,subcircuit_id:this.getSubcircuit()?.subcircuit_id,...portAttributesFromParent});this.source_port_id=source_port3.source_port_id}doInitialSourceParentAttachment(){let{db:db2}=this.root,parentNormalComponent=this.getParentNormalComponent(),parentWithSourceId=this.parent?.source_component_id?this.parent:parentNormalComponent;if(this.isGroupPort()){db2.source_port.update(this.source_port_id,{source_component_id:null,subcircuit_id:this.getSubcircuit()?.subcircuit_id});return}if(!parentWithSourceId?.source_component_id)throw new Error(`${this.getString()} has no parent source component (parent: ${this.parent?.getString()})`);db2.source_port.update(this.source_port_id,{source_component_id:parentWithSourceId.source_component_id,subcircuit_id:this.getSubcircuit()?.subcircuit_id}),this.source_component_id=parentWithSourceId.source_component_id}doInitialPcbPortRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{matchedComponents}=this;if(this.isGroupPort()){let connectedPorts=this._getConnectedPortsFromConnectsTo();if(connectedPorts.length===0)return;let connectedPort=connectedPorts[0];if(!connectedPort.pcb_port_id)return;let connectedPcbPort=db2.pcb_port.get(connectedPort.pcb_port_id),matchCenter2={x:connectedPcbPort.x,y:connectedPcbPort.y},subcircuit=this.getSubcircuit(),pcb_port3=db2.pcb_port.insert({pcb_component_id:void 0,layers:connectedPort.getAvailablePcbLayers(),subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,...matchCenter2,source_port_id:this.source_port_id,is_board_pinout:!1});this.pcb_port_id=pcb_port3.pcb_port_id;return}let parentNormalComponent=this.getParentNormalComponent(),parentWithPcbComponentId=this.parent?.pcb_component_id?this.parent:parentNormalComponent;if(!parentWithPcbComponentId?.pcb_component_id)throw new Error(`${this.getString()} has no parent pcb component, cannot render pcb_port (parent: ${this.parent?.getString()}, parentNormalComponent: ${parentNormalComponent?.getString()})`);let pcbMatches=matchedComponents.filter(c4=>c4.isPcbPrimitive);if(pcbMatches.length===0)return;let matchCenter=null;if(pcbMatches.length===1&&(matchCenter=pcbMatches[0]._getPcbCircuitJsonBounds().center),pcbMatches.length>1){if(!areAllPcbPrimitivesOverlapping(pcbMatches)){let portName=this.props.name,componentName=this.getParentNormalComponent()?.props.name??"unknown",altAliases=this.getNameAndAliases().filter(h6=>h6!==portName),altMsg=altAliases.length>0?` (consider using alternate aliases: ${altAliases.join(", ")})`:"";db2.source_ambiguous_port_reference.insert({error_type:"source_ambiguous_port_reference",message:`${componentName}.${portName} is ambiguous: ${componentName}.${portName} references multiple non-overlapping pads: ${pcbMatches.map(c4=>c4.getString()).join(", ")}${altMsg}`,source_port_id:this.source_port_id??void 0,source_component_id:this.getParentNormalComponent()?.source_component_id??void 0});return}matchCenter=getCenterOfPcbPrimitives(pcbMatches)}if(matchCenter){let subcircuit=this.getSubcircuit(),isBoardPinout=this._shouldIncludeInBoardPinout(),pcb_port3=db2.pcb_port.insert({pcb_component_id:parentWithPcbComponentId.pcb_component_id,layers:this.getAvailablePcbLayers(),subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,...isBoardPinout?{is_board_pinout:!0}:{},...matchCenter,source_port_id:this.source_port_id,is_board_pinout:this._isBoardPinoutFromAttributes()});this.pcb_port_id=pcb_port3.pcb_port_id}else{let pcbMatch=pcbMatches[0];throw new Error(`${pcbMatch.getString()} does not have a center or _getGlobalPcbPositionBeforeLayout method (needed for pcb_port placement)`)}}updatePcbPortRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(this.pcb_port_id)return;if(this.isGroupPort()){let connectedPorts=this._getConnectedPortsFromConnectsTo();if(connectedPorts.length===0)return;let connectedPort=connectedPorts[0];if(!connectedPort.pcb_port_id)return;let connectedPcbPort=db2.pcb_port.get(connectedPort.pcb_port_id),matchCenter2={x:connectedPcbPort.x,y:connectedPcbPort.y},subcircuit2=this.getSubcircuit(),pcb_port22=db2.pcb_port.insert({pcb_component_id:void 0,layers:connectedPort.getAvailablePcbLayers(),subcircuit_id:subcircuit2?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,...matchCenter2,source_port_id:this.source_port_id,is_board_pinout:!1});this.pcb_port_id=pcb_port22.pcb_port_id;return}let pcbMatches=this.matchedComponents.filter(c4=>c4.isPcbPrimitive);if(pcbMatches.length===0)return;let matchCenter=null;if(pcbMatches.length===1&&(matchCenter=pcbMatches[0]._getPcbCircuitJsonBounds().center),pcbMatches.length>1)try{areAllPcbPrimitivesOverlapping(pcbMatches)&&(matchCenter=getCenterOfPcbPrimitives(pcbMatches))}catch{}if(!matchCenter)return;let parentNormalComponent=this.getParentNormalComponent(),parentWithPcbComponentId=this.parent?.pcb_component_id?this.parent:parentNormalComponent,subcircuit=this.getSubcircuit(),isBoardPinout=this._shouldIncludeInBoardPinout(),pcb_port3=db2.pcb_port.insert({pcb_component_id:parentWithPcbComponentId?.pcb_component_id,layers:this.getAvailablePcbLayers(),subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,...isBoardPinout?{is_board_pinout:!0}:{},...matchCenter,source_port_id:this.source_port_id,is_board_pinout:this._isBoardPinoutFromAttributes()});this.pcb_port_id=pcb_port3.pcb_port_id}_getBestDisplayPinLabel(){let{db:db2}=this.root,sourcePort=db2.source_port.get(this.source_port_id),labelHints=[];for(let portHint of sourcePort?.port_hints??[])portHint.match(/^(pin)?\d+$/)||portHint.match(/^(left|right)/)&&!sourcePort?.name.match(/^(left|right)/)||labelHints.push(portHint);if(this.getParentNormalComponent()?.props?.showPinAliases&&labelHints.length>0)return labelHints.join("/");if(labelHints.length>0)return labelHints[0]}doInitialSchematicPortRender(){let collapsedAncestor=this.getCollapsedSchematicBoxAncestor();if(collapsedAncestor&&this.parent!==collapsedAncestor)return;let{db:db2}=this.root,{_parsedProps:props}=this,{schX,schY}=props,container=schX!==void 0&&schY!==void 0?this.getParentNormalComponent():this.getPrimitiveContainer();if(!container||!this._hasSchematicPort())return;let containerCenter=container._getGlobalSchematicPositionBeforeLayout(),portCenter=this._getGlobalSchematicPositionBeforeLayout(),localPortInfo=null,containerDims=container._getSchematicBoxDimensions();containerDims&&props.pinNumber!==void 0&&(localPortInfo=containerDims.getPortPositionByPinNumber(props.pinNumber)),this.getSubcircuit().props._schDebugObjectsEnabled&&db2.schematic_debug_object.insert({shape:"rect",center:portCenter,size:{width:.1,height:.1},label:"obstacle"}),localPortInfo?.side?this.facingDirection={left:"left",right:"right",top:"up",bottom:"down"}[localPortInfo.side]:this.facingDirection=getRelativeDirection(containerCenter,portCenter);let bestDisplayPinLabel=this._getBestDisplayPinLabel(),parentNormalComponent=this.getParentNormalComponent(),sideOfComponent=localPortInfo?.side??(props.direction==="up"?"top":props.direction==="down"?"bottom":props.direction),schematicPortInsertProps={type:"schematic_port",schematic_component_id:parentNormalComponent?.schematic_component_id,center:portCenter,source_port_id:this.source_port_id,facing_direction:this.facingDirection,distance_from_component_edge:props.schStemLength??.4,side_of_component:sideOfComponent,pin_number:props.pinNumber,true_ccw_index:localPortInfo?.trueIndex,display_pin_label:bestDisplayPinLabel,is_connected:!1};for(let attributes2 of this._getMatchingPinAttributes())attributes2.requiresPower&&(schematicPortInsertProps.has_input_arrow=!0),attributes2.providesPower&&(schematicPortInsertProps.has_output_arrow=!0);let schematic_port3=db2.schematic_port.insert(schematicPortInsertProps);if(this.schematic_port_id=schematic_port3.schematic_port_id,props.schStemLength!==void 0&&props.schStemLength!==0){let{schStemLength,direction:direction2}=props,x22=portCenter.x,y22=portCenter.y;direction2==="right"?x22-=schStemLength:direction2==="left"?x22+=schStemLength:direction2==="up"?y22-=schStemLength:direction2==="down"&&(y22+=schStemLength);let stemLine=db2.schematic_line.insert({schematic_component_id:parentNormalComponent?.schematic_component_id,x1:portCenter.x,y1:portCenter.y,x2:x22,y2:y22,stroke_width:.02,color:SCHEMATIC_COMPONENT_OUTLINE_COLOR,is_dashed:!1});this.schematic_stem_line_id=stemLine.schematic_line_id}}doInitialSchematicSymbolResize(){if(this.root?.schematicDisabled||!this.schematic_port_id)return;let transform6=this._getSymbolAncestor()?.getUserCoordinateToResizedSymbolTransform();if(!transform6)return;let{db:db2}=this.root,schPort=db2.schematic_port.get(this.schematic_port_id);if(schPort){let newCenter=applyToPoint2(transform6,schPort.center);if(db2.schematic_port.update(this.schematic_port_id,{center:newCenter}),this.schematic_stem_line_id){let line2=db2.schematic_line.get(this.schematic_stem_line_id);if(line2){let p12=applyToPoint2(transform6,{x:line2.x1,y:line2.y1}),p22=applyToPoint2(transform6,{x:line2.x2,y:line2.y2});db2.schematic_line.update(this.schematic_stem_line_id,{x1:p12.x,y1:p12.y,x2:p22.x,y2:p22.y});let scaledStemLength=Math.sqrt((p12.x-p22.x)**2+(p12.y-p22.y)**2);db2.schematic_port.update(this.schematic_port_id,{distance_from_component_edge:scaledStemLength})}}}}_getSubcircuitConnectivityKey(){return this.root?.db.source_port.get(this.source_port_id)?.subcircuit_connectivity_map_key}_setPositionFromLayout(newCenter){let{db:db2}=this.root;this.pcb_port_id&&db2.pcb_port.update(this.pcb_port_id,{x:newCenter.x,y:newCenter.y})}_hasMatchedPcbPrimitive(){return this.matchedComponents.some(c4=>c4.isPcbPrimitive)}_getNetLabelText(){return`${this.parent?.props.name}_${this.props.name}`}},getPinNumberFromLabels=labels=>{let pinNumber=labels.find(p4=>/^(pin)?\d+$/.test(p4));return pinNumber?Number.parseInt(pinNumber.replace(/^pin/,"")):null};function getPortFromHints(hints,opts){let pinNumber=getPinNumberFromLabels(hints);if(!pinNumber)return null;let aliases2=[...hints.filter(p4=>p4.toString()!==pinNumber.toString()&&p4!==`pin${pinNumber}`&&p4.trim()!==""),...opts?.additionalAliases?.[`pin${pinNumber}`]??[]];return new Port({pinNumber,aliases:aliases2})}function getPinsFromSideDefinition(sideDefinition){return sideDefinition?Array.isArray(sideDefinition)?sideDefinition:sideDefinition.pins??[]:[]}var hasExplicitPinMapping=pa3=>{for(let side of["leftSide","rightSide","topSide","bottomSide"])if(side in pa3&&typeof pa3[side]=="number")throw new Error(`A number was specified for "${side}", you probably meant to use "size" not "side"`);return"leftSide"in pa3||"rightSide"in pa3||"topSide"in pa3||"bottomSide"in pa3},getSizeOfSidesFromPortArrangement=pa3=>{if(hasExplicitPinMapping(pa3))return{leftSize:getPinsFromSideDefinition(pa3.leftSide).length,rightSize:getPinsFromSideDefinition(pa3.rightSide).length,topSize:getPinsFromSideDefinition(pa3.topSide).length,bottomSize:getPinsFromSideDefinition(pa3.bottomSide).length};let{leftSize=0,rightSize=0,topSize=0,bottomSize=0}=pa3;return{leftSize,rightSize,topSize,bottomSize}},DEFAULT_SCHEMATIC_BOX_PADDING_MM=.4;function isExplicitPinMappingArrangement(arrangement){let a3=arrangement;return a3.leftSide!==void 0||a3.rightSide!==void 0||a3.topSide!==void 0||a3.bottomSide!==void 0}var getAllDimensionsForSchematicBox=params=>{let portDistanceFromEdge=params.portDistanceFromEdge??.4,sidePinCounts=params.schPortArrangement?getSizeOfSidesFromPortArrangement(params.schPortArrangement):null,sideLengths={left:0,right:0,top:0,bottom:0},pinCount=params.pinCount??null;if(pinCount===null)if(sidePinCounts)pinCount=sidePinCounts.leftSize+sidePinCounts.rightSize+sidePinCounts.topSize;else throw new Error("Could not determine pin count for the schematic box");if(pinCount&&!sidePinCounts){let rightSize=Math.floor(pinCount/2);sidePinCounts={leftSize:pinCount-rightSize,rightSize,topSize:0,bottomSize:0}}sidePinCounts||(sidePinCounts={leftSize:0,rightSize:0,topSize:0,bottomSize:0});let getPinNumberUsingSideIndex=({side,sideIndex,truePinIndex:truePinIndex2})=>{if(!params.schPortArrangement||!isExplicitPinMappingArrangement(params.schPortArrangement))return truePinIndex2+1;let normalCcwDirection={left:"top-to-bottom",bottom:"left-to-right",right:"bottom-to-top",top:"right-to-left"}[side],directionAlongSide=params.schPortArrangement?.[`${side}Side`]?.direction??normalCcwDirection,pinsDefinitionForSide=params.schPortArrangement?.[`${side}Side`]?.pins,sideIndexWithDirectionCorrection=sideIndex;return directionAlongSide!==normalCcwDirection&&(sideIndexWithDirectionCorrection=pinsDefinitionForSide.length-sideIndex-1),parsePinNumberFromLabelsOrThrow(pinsDefinitionForSide[sideIndexWithDirectionCorrection],params.pinLabels)},orderedTruePorts=[],currentDistanceFromEdge=0,truePinIndex=0;for(let sideIndex=0;sideIndex<sidePinCounts.leftSize;sideIndex++){let pinNumber=getPinNumberUsingSideIndex({side:"left",sideIndex,truePinIndex}),pinStyle=params.numericSchPinStyle?.[`pin${pinNumber}`]??params.numericSchPinStyle?.[pinNumber];pinStyle?.topMargin&&(currentDistanceFromEdge+=pinStyle.topMargin),orderedTruePorts.push({trueIndex:truePinIndex,pinNumber,side:"left",distanceFromOrthogonalEdge:currentDistanceFromEdge}),pinStyle?.bottomMargin&&(currentDistanceFromEdge+=pinStyle.bottomMargin),sideIndex===sidePinCounts.leftSize-1?sideLengths.left=currentDistanceFromEdge:currentDistanceFromEdge+=params.schPinSpacing,truePinIndex++}currentDistanceFromEdge=0;for(let sideIndex=0;sideIndex<sidePinCounts.bottomSize;sideIndex++){let pinNumber=getPinNumberUsingSideIndex({side:"bottom",sideIndex,truePinIndex}),pinStyle=params.numericSchPinStyle?.[`pin${pinNumber}`]??params.numericSchPinStyle?.[pinNumber];pinStyle?.leftMargin&&(currentDistanceFromEdge+=pinStyle.leftMargin),orderedTruePorts.push({trueIndex:truePinIndex,pinNumber,side:"bottom",distanceFromOrthogonalEdge:currentDistanceFromEdge}),pinStyle?.rightMargin&&(currentDistanceFromEdge+=pinStyle.rightMargin),sideIndex===sidePinCounts.bottomSize-1?sideLengths.bottom=currentDistanceFromEdge:currentDistanceFromEdge+=params.schPinSpacing,truePinIndex++}currentDistanceFromEdge=0;for(let sideIndex=0;sideIndex<sidePinCounts.rightSize;sideIndex++){let pinNumber=getPinNumberUsingSideIndex({side:"right",sideIndex,truePinIndex}),pinStyle=params.numericSchPinStyle?.[`pin${pinNumber}`]??params.numericSchPinStyle?.[pinNumber];pinStyle?.bottomMargin&&(currentDistanceFromEdge+=pinStyle.bottomMargin),orderedTruePorts.push({trueIndex:truePinIndex,pinNumber,side:"right",distanceFromOrthogonalEdge:currentDistanceFromEdge}),pinStyle?.topMargin&&(currentDistanceFromEdge+=pinStyle.topMargin),sideIndex===sidePinCounts.rightSize-1?sideLengths.right=currentDistanceFromEdge:currentDistanceFromEdge+=params.schPinSpacing,truePinIndex++}currentDistanceFromEdge=0;for(let sideIndex=0;sideIndex<sidePinCounts.topSize;sideIndex++){let pinNumber=getPinNumberUsingSideIndex({side:"top",sideIndex,truePinIndex}),pinStyle=params.numericSchPinStyle?.[`pin${pinNumber}`]??params.numericSchPinStyle?.[pinNumber];pinStyle?.rightMargin&&(currentDistanceFromEdge+=pinStyle.rightMargin),orderedTruePorts.push({trueIndex:truePinIndex,pinNumber,side:"top",distanceFromOrthogonalEdge:currentDistanceFromEdge}),pinStyle?.leftMargin&&(currentDistanceFromEdge+=pinStyle.leftMargin),sideIndex===sidePinCounts.topSize-1?sideLengths.top=currentDistanceFromEdge:currentDistanceFromEdge+=params.schPinSpacing,truePinIndex++}let resolvedSchWidth=params.schWidth;if(resolvedSchWidth===void 0){resolvedSchWidth=Math.max(sideLengths.top+DEFAULT_SCHEMATIC_BOX_PADDING_MM,sideLengths.bottom+DEFAULT_SCHEMATIC_BOX_PADDING_MM),params.pinLabels&&orderedTruePorts.filter(p4=>p4.side==="left"||p4.side==="right").some(p4=>params.pinLabels?.[`pin${p4.pinNumber}`]||params.pinLabels?.[p4.pinNumber])&&(resolvedSchWidth=Math.max(resolvedSchWidth,.5));let labelWidth=params.pinLabels?Math.max(...Object.values(params.pinLabels).map(label=>label.length*.1)):0,LABEL_PADDING=labelWidth>0?1.1:0;resolvedSchWidth=Math.max(resolvedSchWidth,labelWidth+LABEL_PADDING)}let schHeight=params.schHeight;schHeight||(schHeight=Math.max(sideLengths.left+DEFAULT_SCHEMATIC_BOX_PADDING_MM,sideLengths.right+DEFAULT_SCHEMATIC_BOX_PADDING_MM));let trueEdgePositions={left:{x:-resolvedSchWidth/2-portDistanceFromEdge,y:sideLengths.left/2},bottom:{x:-sideLengths.bottom/2,y:-schHeight/2-portDistanceFromEdge},right:{x:resolvedSchWidth/2+portDistanceFromEdge,y:-sideLengths.right/2},top:{x:sideLengths.top/2,y:schHeight/2+portDistanceFromEdge}},trueEdgeTraversalDirections={left:{x:0,y:-1},right:{x:0,y:1},top:{x:-1,y:0},bottom:{x:1,y:0}},truePortsWithPositions=orderedTruePorts.map(p4=>{let{distanceFromOrthogonalEdge,side}=p4,edgePos=trueEdgePositions[side],edgeDir=trueEdgeTraversalDirections[side];return{x:edgePos.x+distanceFromOrthogonalEdge*edgeDir.x,y:edgePos.y+distanceFromOrthogonalEdge*edgeDir.y,...p4}});return{getPortPositionByPinNumber(pinNumber){let port=truePortsWithPositions.find(p4=>p4.pinNumber.toString()===pinNumber.toString());return port||null},getSize(){return{width:resolvedSchWidth,height:schHeight}},getSizeIncludingPins(){return{width:resolvedSchWidth+(sidePinCounts.leftSize||sidePinCounts.rightSize?.4:0),height:schHeight+(sidePinCounts.topSize||sidePinCounts.bottomSize?.4:0)}},pinCount}},getNumericSchPinStyle=(pinStyles,pinLabels)=>{if(!pinStyles)return;let numericPinStyles={};for(let[pinNameOrLabel,pinStyle]of Object.entries(pinStyles)){let pinNumber=parsePinNumberFromLabelsOrThrow(pinNameOrLabel,pinLabels),leftMargin=pinStyle.marginLeft??pinStyle.leftMargin,rightMargin=pinStyle.marginRight??pinStyle.rightMargin,topMargin=pinStyle.marginTop??pinStyle.topMargin,bottomMargin=pinStyle.marginBottom??pinStyle.bottomMargin,nextStyle={...numericPinStyles[`pin${pinNumber}`]??{}};leftMargin!==void 0&&(nextStyle.leftMargin=distance.parse(leftMargin)),rightMargin!==void 0&&(nextStyle.rightMargin=distance.parse(rightMargin)),topMargin!==void 0&&(nextStyle.topMargin=distance.parse(topMargin)),bottomMargin!==void 0&&(nextStyle.bottomMargin=distance.parse(bottomMargin)),numericPinStyles[`pin${pinNumber}`]=nextStyle}return numericPinStyles},CadAssembly=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isPrimitiveContainer",!0)}get config(){return{componentName:"CadAssembly",zodProps:cadassemblyProps}}},getFileExtension=filename=>{if(!filename)return null;let fragmentMatch=filename.match(/#ext=(\w+)$/);if(fragmentMatch)return fragmentMatch[1].toLowerCase();let sanitized=filename.split("?")[0].split("#")[0],lastSegment=sanitized.split("/").pop()??sanitized;return lastSegment.includes(".")?lastSegment.split(".").pop()?.toLowerCase()??null:null},joinUrlPath=(base,path)=>{let trimmedBase=base.replace(/\/+$/,""),trimmedPath=path.replace(/^\/+/,"");return`${trimmedBase}/${trimmedPath}`},constructAssetUrl=(targetUrl,baseUrl)=>{if(!baseUrl||!targetUrl.startsWith("/"))return targetUrl;try{let baseUrlObj=new URL(baseUrl);return baseUrlObj.pathname!=="/"&&targetUrl.startsWith(baseUrlObj.pathname)?new URL(targetUrl,baseUrlObj.origin).toString():joinUrlPath(baseUrl,targetUrl)}catch{return targetUrl}},rotation2=external_exports.union([external_exports.number(),external_exports.string()]),rotation3=external_exports.object({x:rotation2,y:rotation2,z:rotation2}),CadModel=class extends PrimitiveComponent2{get config(){return{componentName:"CadModel",zodProps:cadmodelProps}}doInitialCadModelRender(){let parent=this._findParentWithPcbComponent();if(!parent||!parent.pcb_component_id)return;let{db:db2}=this.root,{boardThickness=0}=parent._getBoard()??{},bounds=parent._getPcbCircuitJsonBounds(),pcb_component3=db2.pcb_component.get(parent.pcb_component_id),props=this._parsedProps;if(!props||typeof props.modelUrl!="string"&&typeof props.stepUrl!="string")return;let parentTransform=parent._computePcbGlobalTransformBeforeLayout(),accumulatedRotation=decomposeTSR2(parentTransform).rotation.angle*180/Math.PI,sourceRotationOffset=props.pcbRotationOffset??props.rotationOffset,rotationOffset=rotation3.parse({x:0,y:0,z:0});if(typeof sourceRotationOffset=="number")rotationOffset.z=Number(sourceRotationOffset);else if(typeof sourceRotationOffset=="object"){let parsed=rotation3.parse(sourceRotationOffset);rotationOffset.x=Number(parsed.x),rotationOffset.y=Number(parsed.y),rotationOffset.z=Number(parsed.z)}let{pcbX,pcbY}=this.getResolvedPcbPositionProp(),positionOffset=point32.parse({x:pcbX,y:pcbY,z:props.pcbZ??0,...typeof props.positionOffset=="object"?props.positionOffset:{}}),zOffsetFromSurface=props.zOffsetFromSurface!==void 0?distance.parse(props.zOffsetFromSurface):0,layer=parent.props.layer==="bottom"?"bottom":"top",ext=props.modelUrl?getFileExtension(props.modelUrl):void 0,modelUrlWithoutExtFragment=props.modelUrl?.replace(/#ext=\w+$/,""),urlProps={};if(ext==="stl"?urlProps.model_stl_url=this._addCachebustToModelUrl(modelUrlWithoutExtFragment):ext==="obj"?urlProps.model_obj_url=this._addCachebustToModelUrl(modelUrlWithoutExtFragment):ext==="gltf"?urlProps.model_gltf_url=this._addCachebustToModelUrl(modelUrlWithoutExtFragment):ext==="glb"?urlProps.model_glb_url=this._addCachebustToModelUrl(modelUrlWithoutExtFragment):ext==="step"||ext==="stp"?urlProps.model_step_url=this._addCachebustToModelUrl(modelUrlWithoutExtFragment):ext==="wrl"||ext==="vrml"?urlProps.model_wrl_url=this._addCachebustToModelUrl(modelUrlWithoutExtFragment):urlProps.model_stl_url=this._addCachebustToModelUrl(modelUrlWithoutExtFragment),props.stepUrl){let transformed=this._addCachebustToModelUrl(props.stepUrl);transformed&&(urlProps.model_step_url=transformed)}let cad=db2.cad_component.insert({position:{x:bounds.center.x+Number(positionOffset.x),y:bounds.center.y+Number(positionOffset.y),z:(layer==="bottom"?-boardThickness/2:boardThickness/2)+(layer==="bottom"?-zOffsetFromSurface:zOffsetFromSurface)+Number(positionOffset.z)},rotation:{x:Number(rotationOffset.x),y:(layer==="top"?0:180)+Number(rotationOffset.y),z:layer==="bottom"?-(accumulatedRotation+Number(rotationOffset.z))+180:accumulatedRotation+Number(rotationOffset.z)},pcb_component_id:parent.pcb_component_id,model_board_normal_direction:props.modelBoardNormalDirection,model_origin_alignment:"center_of_component_on_board_surface",anchor_alignment:"center_of_component_on_board_surface",model_origin_position:props.modelOriginPosition,source_component_id:parent.source_component_id,model_unit_to_mm_scale_factor:typeof props.modelUnitToMmScale=="number"?props.modelUnitToMmScale:void 0,show_as_translucent_model:props.showAsTranslucentModel??parent._parsedProps.showAsTranslucentModel,...urlProps});this.cad_component_id=cad.cad_component_id}_findParentWithPcbComponent(){let p4=this.parent;for(;p4&&!p4.pcb_component_id;)p4=p4.parent;return p4}_addCachebustToModelUrl(url2){if(!url2)return url2;let baseUrl=this.root?.platform?.projectBaseUrl,transformedUrl=constructAssetUrl(url2,baseUrl);if(!transformedUrl.includes("modelcdn.tscircuit.com"))return transformedUrl;let origin=this.root?.getClientOrigin()??"";return`${transformedUrl}${transformedUrl.includes("?")?"&":"?"}cachebust_origin=${encodeURIComponent(origin)}`}},debug22=(0,import_debug9.default)("tscircuit:core:footprint"),Footprint=class extends PrimitiveComponent2{get config(){return{componentName:"Footprint",zodProps:footprintProps}}doInitialPcbFootprintLayout(){if(this.root?.pcbDisabled)return;let constraints=this.children.filter(child=>child.componentName==="Constraint");if(constraints.length===0)return;let{isFlipped}=this._getPcbPrimitiveFlippedHelpers(),maybeFlipLeftRight=props=>isFlipped&&"left"in props&&"right"in props?{...props,left:props.right,right:props.left}:props,involvedComponents=constraints.flatMap(constraint=>constraint._getAllReferencedComponents().componentsWithSelectors).map(({component,selector,componentSelector,edge})=>({component,selector,componentSelector,edge,bounds:component._getPcbCircuitJsonBounds()}));if(involvedComponents.some(c4=>c4.edge))throw new Error("edge constraints not implemented yet for footprint layout, contributions welcome!");function getComponentDetails(selector){return involvedComponents.find(({selector:s3})=>s3===selector)}let solver=new Solver,kVars={};function getKVar(name){return name in kVars||(kVars[name]=new Variable(name),solver.addEditVariable(kVars[name],Strength.weak)),kVars[name]}for(let{selector,bounds:bounds2}of involvedComponents){let kvx=getKVar(`${selector}_x`),kvy=getKVar(`${selector}_y`);solver.suggestValue(kvx,bounds2.center.x),solver.suggestValue(kvy,bounds2.center.y)}for(let constraint of constraints){let props=constraint._parsedProps;if("xDist"in props){let{xDist,left,right,edgeToEdge,centerToCenter}=maybeFlipLeftRight(props),leftVar=getKVar(`${left}_x`),rightVar=getKVar(`${right}_x`),leftBounds=getComponentDetails(left)?.bounds,rightBounds=getComponentDetails(right)?.bounds;if(centerToCenter){let expr=new Expression(rightVar,[-1,leftVar]);solver.addConstraint(new Constraint(expr,Operator.Eq,props.xDist,Strength.required))}else if(edgeToEdge){let expr=new Expression(rightVar,-rightBounds.width/2,[-1,leftVar],-leftBounds.width/2);solver.addConstraint(new Constraint(expr,Operator.Eq,props.xDist,Strength.required))}}else if("yDist"in props){let{yDist,top,bottom,edgeToEdge,centerToCenter}=props,topVar=getKVar(`${top}_y`),bottomVar=getKVar(`${bottom}_y`),topBounds=getComponentDetails(top)?.bounds,bottomBounds=getComponentDetails(bottom)?.bounds;if(centerToCenter){let expr=new Expression(topVar,[-1,bottomVar]);solver.addConstraint(new Constraint(expr,Operator.Eq,props.yDist,Strength.required))}else if(edgeToEdge){let expr=new Expression(topVar,topBounds.height/2,[-1,bottomVar],-bottomBounds.height/2);solver.addConstraint(new Constraint(expr,Operator.Eq,props.yDist,Strength.required))}}else if("sameY"in props){let{for:selectors}=props;if(selectors.length<2)continue;let vars=selectors.map(selector=>getKVar(`${selector}_y`)),expr=new Expression(...vars.slice(1));solver.addConstraint(new Constraint(expr,Operator.Eq,vars[0],Strength.required))}else if("sameX"in props){let{for:selectors}=props;if(selectors.length<2)continue;let vars=selectors.map(selector=>getKVar(`${selector}_x`)),expr=new Expression(...vars.slice(1));solver.addConstraint(new Constraint(expr,Operator.Eq,vars[0],Strength.required))}}solver.updateVariables(),debug22.enabled&&(console.log("Solution to layout constraints:"),console.table(Object.entries(kVars).map(([key,kvar])=>({var:key,val:kvar.value()}))));let bounds={left:1/0,right:-1/0,top:-1/0,bottom:1/0};for(let{selector,bounds:{width,height}}of involvedComponents){let kvx=getKVar(`${selector}_x`),kvy=getKVar(`${selector}_y`),newLeft=kvx.value()-width/2,newRight=kvx.value()+width/2,newTop=kvy.value()+height/2,newBottom=kvy.value()-height/2;bounds.left=Math.min(bounds.left,newLeft),bounds.right=Math.max(bounds.right,newRight),bounds.top=Math.max(bounds.top,newTop),bounds.bottom=Math.min(bounds.bottom,newBottom)}let globalOffset={x:-(bounds.right+bounds.left)/2,y:-(bounds.top+bounds.bottom)/2},containerPos=this.getPrimitiveContainer()._getGlobalPcbPositionBeforeLayout();globalOffset.x+=containerPos.x,globalOffset.y+=containerPos.y;for(let{component,selector}of involvedComponents){let kvx=getKVar(`${selector}_x`),kvy=getKVar(`${selector}_y`);component._setPositionFromLayout({x:kvx.value()+globalOffset.x,y:kvy.value()+globalOffset.y})}}},NormalComponent__getMinimumFlexContainerSize=component=>{let{db:db2}=component.root;if(component.pcb_component_id){let pcbComponent=db2.pcb_component.get(component.pcb_component_id);return pcbComponent?{width:pcbComponent.width,height:pcbComponent.height}:null}if(component.pcb_group_id){let pcbGroup=db2.pcb_group.get(component.pcb_group_id);if(!pcbGroup)return null;if(pcbGroup.outline&&pcbGroup.outline.length>0){let bounds=getBoundsFromPoints(pcbGroup.outline);return bounds?{width:bounds.maxX-bounds.minX,height:bounds.maxY-bounds.minY}:null}return{width:pcbGroup.width??0,height:pcbGroup.height??0}}return null},NormalComponent__repositionOnPcb=(component,position4)=>{let{db:db2}=component.root,allCircuitJson=db2.toArray();if(component.pcb_component_id){repositionPcbComponentTo(allCircuitJson,component.pcb_component_id,position4);return}if(component.source_group_id){repositionPcbGroupTo(allCircuitJson,component.source_group_id,position4);return}throw new Error(`Cannot reposition component ${component.getString()}: no pcb_component_id or source_group_id`)};function NormalComponent_doInitialPcbComponentAnchorAlignment(component){if(component.root?.pcbDisabled||!component.pcb_component_id)return;let{pcbX,pcbY}=component._parsedProps,pcbPositionAnchor=component.props?.pcbPositionAnchor;if(!pcbPositionAnchor||pcbX===void 0&&pcbY===void 0)return;let bounds=getBoundsOfPcbComponents(component.children);if(bounds.width===0||bounds.height===0)return;let currentCenter={...{x:(bounds.minX+bounds.maxX)/2,y:(bounds.minY+bounds.maxY)/2}},anchorPos=null;if(new Set(["center","top_left","top_center","top_right","center_left","center_right","bottom_left","bottom_center","bottom_right"]).has(pcbPositionAnchor)){let b3={left:bounds.minX,right:bounds.maxX,top:bounds.minY,bottom:bounds.maxY};switch(pcbPositionAnchor){case"center":anchorPos=currentCenter;break;case"top_left":anchorPos={x:b3.left,y:b3.top};break;case"top_center":anchorPos={x:currentCenter.x,y:b3.top};break;case"top_right":anchorPos={x:b3.right,y:b3.top};break;case"center_left":anchorPos={x:b3.left,y:currentCenter.y};break;case"center_right":anchorPos={x:b3.right,y:currentCenter.y};break;case"bottom_left":anchorPos={x:b3.left,y:b3.bottom};break;case"bottom_center":anchorPos={x:currentCenter.x,y:b3.bottom};break;case"bottom_right":anchorPos={x:b3.right,y:b3.bottom};break}}else try{let port=component.portMap[pcbPositionAnchor];port&&(anchorPos=port._getGlobalPcbPositionBeforeLayout())}catch{}if(!anchorPos)return;let newCenter={...currentCenter};pcbX!==void 0&&(newCenter.x+=pcbX-anchorPos.x),pcbY!==void 0&&(newCenter.y+=pcbY-anchorPos.y),(Math.abs(newCenter.x-currentCenter.x)>1e-6||Math.abs(newCenter.y-currentCenter.y)>1e-6)&&component._repositionOnPcb(newCenter)}var isHttpUrl=s3=>s3.startsWith("http://")||s3.startsWith("https://"),parseLibraryFootprintRef=s3=>{if(isHttpUrl(s3))return null;let idx=s3.indexOf(":");if(idx<=0)return null;let footprintLib=s3.slice(0,idx),footprintName=s3.slice(idx+1);return!footprintLib||!footprintName?null:{footprintLib,footprintName}},isStaticAssetPath=s3=>s3.startsWith("/")||s3.startsWith("./"),resolveStaticFileImportDebug=(0,import_debug10.default)("tscircuit:core:resolveStaticFileImport");async function resolveStaticFileImport(path,platform){if(!path)return path;let normalizedPath=path.startsWith("./")?path.slice(1):path,resolver=platform?.resolveProjectStaticFileImportUrl;if(resolver&&(path.startsWith("/")||path.startsWith("./")))try{let resolved=await resolver(normalizedPath);if(resolved)return resolved}catch(error2){resolveStaticFileImportDebug("failed to resolve static file via platform resolver",error2)}return constructAssetUrl(normalizedPath,platform?.projectBaseUrl)}function NormalComponent_doInitialPcbFootprintStringRender(component,queueAsyncEffect){let{footprint}=component.props;if(footprint??(footprint=component._getImpliedFootprintString?.()),!footprint)return;let{pcbRotation,pinLabels,pcbPinLabels}=component.props,fileExtension=getFileExtension(String(footprint)),footprintParser=fileExtension?component.root?.platform?.footprintFileParserMap?.[fileExtension]:null;if(typeof footprint=="string"&&(isHttpUrl(footprint)||isStaticAssetPath(footprint))&&footprintParser){if(component._hasStartedFootprintUrlLoad)return;component._hasStartedFootprintUrlLoad=!0,queueAsyncEffect("load-footprint-from-platform-file-parser",async()=>{let footprintUrl=isHttpUrl(footprint)?footprint:await resolveStaticFileImport(footprint,component.root?.platform);try{let result=await footprintParser.loadFromUrl(footprintUrl),fpComponents=createComponentsFromCircuitJson({componentName:component.name,componentRotation:pcbRotation,footprinterString:footprintUrl,pinLabels,pcbPinLabels},result.footprintCircuitJson);component.addAll(fpComponents),component._markDirty("InitializePortsFromChildren")}catch(err){let db2=component.root?.db;if(db2&&component.source_component_id&&component.pcb_component_id){let subcircuit=component.getSubcircuit(),errorMsg=`${component.getString()} failed to load footprint "${footprintUrl}": `+(err instanceof Error?err.message:String(err)),errorObj=external_footprint_load_error.parse({type:"external_footprint_load_error",message:errorMsg,pcb_component_id:component.pcb_component_id,source_component_id:component.source_component_id,subcircuit_id:subcircuit.subcircuit_id??void 0,pcb_group_id:component.getGroup()?.pcb_group_id??void 0,footprinter_string:footprintUrl});db2.external_footprint_load_error.insert(errorObj)}throw err}});return}if(typeof footprint=="string"&&isHttpUrl(footprint)){if(component._hasStartedFootprintUrlLoad)return;component._hasStartedFootprintUrlLoad=!0;let url2=footprint;queueAsyncEffect("load-footprint-url",async()=>{try{let res2=await fetch(url2);if(!res2.ok)throw new Error(`Failed to fetch footprint: ${res2.status}`);let soup=await res2.json(),fpComponents=createComponentsFromCircuitJson({componentName:component.name,componentRotation:pcbRotation,footprinterString:url2,pinLabels,pcbPinLabels},soup);component.addAll(fpComponents),component._markDirty("InitializePortsFromChildren")}catch(err){let db2=component.root?.db;if(db2&&component.source_component_id&&component.pcb_component_id){let subcircuit=component.getSubcircuit(),errorMsg=`${component.getString()} failed to load external footprint "${url2}": `+(err instanceof Error?err.message:String(err)),errorObj=external_footprint_load_error.parse({type:"external_footprint_load_error",message:errorMsg,pcb_component_id:component.pcb_component_id,source_component_id:component.source_component_id,subcircuit_id:subcircuit.subcircuit_id??void 0,pcb_group_id:component.getGroup()?.pcb_group_id??void 0,footprinter_string:url2});db2.external_footprint_load_error.insert(errorObj)}throw err}});return}if(typeof footprint=="string"){let libRef=parseLibraryFootprintRef(footprint);if(!libRef||component._hasStartedFootprintUrlLoad)return;component._hasStartedFootprintUrlLoad=!0;let libMap=component.root?.platform?.footprintLibraryMap?.[libRef.footprintLib],resolverFn;if(typeof libMap=="function"&&(resolverFn=libMap),!resolverFn)return;queueAsyncEffect("load-lib-footprint",async()=>{try{let result=await resolverFn(libRef.footprintName),circuitJson=null;if(Array.isArray(result)?circuitJson=result:Array.isArray(result.footprintCircuitJson)&&(circuitJson=result.footprintCircuitJson),!circuitJson)return;let fpComponents=createComponentsFromCircuitJson({componentName:component.name,componentRotation:pcbRotation,footprinterString:footprint,pinLabels,pcbPinLabels},circuitJson),fpWrapper=new Footprint({src:footprint});for(let c4 of fpComponents)fpWrapper.add(c4);component.add(fpWrapper),!Array.isArray(result)&&result.cadModel&&(component._asyncFootprintCadModel=result.cadModel);for(let child of component.children)child.componentName==="Port"&&child._markDirty?.("PcbPortRender");component._markDirty("InitializePortsFromChildren")}catch(err){let db2=component.root?.db;if(db2&&component.source_component_id&&component.pcb_component_id){let subcircuit=component.getSubcircuit(),errorMsg=`${component.getString()} failed to load external footprint "${footprint}": `+(err instanceof Error?err.message:String(err)),errorObj=external_footprint_load_error.parse({type:"external_footprint_load_error",message:errorMsg,pcb_component_id:component.pcb_component_id,source_component_id:component.source_component_id,subcircuit_id:subcircuit.subcircuit_id??void 0,pcb_group_id:component.getGroup()?.pcb_group_id??void 0,footprinter_string:footprint});db2.external_footprint_load_error.insert(errorObj)}throw err}});return}if(!(0,import_react3.isValidElement)(footprint)&&footprint.componentName==="Footprint"&&component.add(footprint),Array.isArray(footprint)&&!(0,import_react3.isValidElement)(footprint)&&footprint.length>0){try{let fpComponents=createComponentsFromCircuitJson({componentName:component.name,componentRotation:pcbRotation,footprinterString:"",pinLabels,pcbPinLabels},footprint);component.addAll(fpComponents)}catch(err){let db2=component.root?.db;if(db2&&component.source_component_id&&component.pcb_component_id){let subcircuit=component.getSubcircuit(),errorMsg=`${component.getString()} failed to load json footprint: `+(err instanceof Error?err.message:String(err)),errorObj=circuit_json_footprint_load_error.parse({type:"circuit_json_footprint_load_error",message:errorMsg,pcb_component_id:component.pcb_component_id,source_component_id:component.source_component_id,subcircuit_id:subcircuit.subcircuit_id??void 0,pcb_group_id:component.getGroup()?.pcb_group_id??void 0});db2.circuit_json_footprint_load_error.insert(errorObj)}throw err}return}}function getPcbTextBounds(text){let fontSize=text.font_size,textWidth=text.text.length*fontSize*.6,textHeight=fontSize,anchorAlignment=text.anchor_alignment||"center",centerX=text.anchor_position.x,centerY=text.anchor_position.y;switch(anchorAlignment){case"top_left":centerX=text.anchor_position.x+textWidth/2,centerY=text.anchor_position.y+textHeight/2;break;case"top_center":centerX=text.anchor_position.x,centerY=text.anchor_position.y+textHeight/2;break;case"top_right":centerX=text.anchor_position.x-textWidth/2,centerY=text.anchor_position.y+textHeight/2;break;case"center_left":centerX=text.anchor_position.x+textWidth/2,centerY=text.anchor_position.y;break;case"center":centerX=text.anchor_position.x,centerY=text.anchor_position.y;break;case"center_right":centerX=text.anchor_position.x-textWidth/2,centerY=text.anchor_position.y;break;case"bottom_left":centerX=text.anchor_position.x+textWidth/2,centerY=text.anchor_position.y-textHeight/2;break;case"bottom_center":centerX=text.anchor_position.x,centerY=text.anchor_position.y-textHeight/2;break;case"bottom_right":centerX=text.anchor_position.x-textWidth/2,centerY=text.anchor_position.y-textHeight/2;break;default:centerX=text.anchor_position.x,centerY=text.anchor_position.y;break}return{x:centerX-textWidth/2,y:centerY-textHeight/2,width:textWidth,height:textHeight}}function NormalComponent_doInitialSilkscreenOverlapAdjustment(component){if(!component._adjustSilkscreenTextAutomatically||component.root?.pcbDisabled||!component.pcb_component_id)return;let{db:db2}=component.root,componentCenter=component._getPcbCircuitJsonBounds().center,silkscreenTexts=db2.pcb_silkscreen_text.list({pcb_component_id:component.pcb_component_id}).filter(text=>text.text===component.name);if(silkscreenTexts.length===0)return;let obstacleBounds=component.getSubcircuit().selectAll("[_isNormalComponent=true]").filter(comp=>comp!==component&&comp.pcb_component_id).map(comp=>{let bounds=comp._getPcbCircuitJsonBounds(),box2={center:bounds.center,width:bounds.width,height:bounds.height};return getBoundingBox(box2)});for(let silkscreenText of silkscreenTexts){let currentPosition=silkscreenText.anchor_position,textBounds=getPcbTextBounds(silkscreenText),textBox={center:{x:textBounds.x+textBounds.width/2,y:textBounds.y+textBounds.height/2},width:textBounds.width,height:textBounds.height},textBoundsBox=getBoundingBox(textBox);if(!obstacleBounds.some(obstacle=>doBoundsOverlap(textBoundsBox,obstacle)))continue;let flippedX=2*componentCenter.x-currentPosition.x,flippedY=2*componentCenter.y-currentPosition.y,flippedTextBox={center:{x:flippedX,y:flippedY},width:textBounds.width,height:textBounds.height},flippedTextBounds=getBoundingBox(flippedTextBox);obstacleBounds.some(obstacle=>doBoundsOverlap(flippedTextBounds,obstacle))||db2.pcb_silkscreen_text.update(silkscreenText.pcb_silkscreen_text_id,{anchor_position:{x:flippedX,y:flippedY}})}}var NormalComponent_doInitialSourceDesignRuleChecks=component=>{let{db:db2}=component.root;if(!component.source_component_id)return;let ports=component.selectAll("port"),traces=db2.source_trace.list(),connected=new Set;for(let trace of traces)for(let id2 of trace.connected_source_port_ids)connected.add(id2);let internalGroups=component._getInternallyConnectedPins();for(let group of internalGroups)if(group.some(p4=>p4.source_port_id&&connected.has(p4.source_port_id)))for(let p4 of group)p4.source_port_id&&connected.add(p4.source_port_id);for(let port of ports)!port.source_port_id||!shouldCheckPortForMissingTrace(component,port)||db2.source_port.get(port.source_port_id)?.do_not_connect||connected.has(port.source_port_id)||db2.source_pin_missing_trace_warning.insert({message:`Port ${port.getNameAndAliases()[0]} on ${component.props.name} is missing a trace`,source_component_id:component.source_component_id,source_port_id:port.source_port_id,subcircuit_id:component.getSubcircuit().subcircuit_id??void 0,warning_type:"source_pin_missing_trace_warning"})},shouldCheckPortForMissingTrace=(component,port)=>{if(component.config.componentName==="Interconnect")return!1;if(component.config.componentName==="Chip"){let pinAttributes=component.props.pinAttributes;if(!pinAttributes)return!1;for(let alias of port.getNameAndAliases()){let attrs=pinAttributes[alias];if(attrs?.requiresPower||attrs?.requiresGround||attrs?.requiresVoltage!==void 0)return!0}return!1}return!0},SUPPLIER_FOOTPRINT_IOU_WARNING_THRESHOLD=.8,supplierNames=supplierProps.shape.supplierPartNumbers.unwrap().keySchema.options,isCopperElement=elm=>elm.type==="pcb_smtpad"||elm.type==="pcb_plated_hole",isValidBounds=bounds=>Number.isFinite(bounds.minX)&&Number.isFinite(bounds.minY)&&Number.isFinite(bounds.maxX)&&Number.isFinite(bounds.maxY)&&bounds.maxX>bounds.minX&&bounds.maxY>bounds.minY,getCopperBounds=elements=>{let copperElements=elements.filter(isCopperElement);if(copperElements.length===0)return null;let bounds=getBoundsOfPcbElements(copperElements);return isValidBounds(bounds)?bounds:null},getBoundsSize=bounds=>({width:bounds.maxX-bounds.minX,height:bounds.maxY-bounds.minY}),getCenteredBoundsIou=(boundsA,boundsB,opts)=>{let sizeA=getBoundsSize(boundsA),sizeB=getBoundsSize(boundsB),bWidth=opts?.rotateB?sizeB.height:sizeB.width,bHeight=opts?.rotateB?sizeB.width:sizeB.height,intersectionWidth=Math.min(sizeA.width,bWidth),intersectionHeight=Math.min(sizeA.height,bHeight),intersectionArea=intersectionWidth*intersectionHeight,unionArea=sizeA.width*sizeA.height+bWidth*bHeight-intersectionArea;return unionArea<=0?0:intersectionArea/unionArea},getBestBoundsIou=(localBounds,supplierBounds)=>Math.max(getCenteredBoundsIou(localBounds,supplierBounds),getCenteredBoundsIou(localBounds,supplierBounds,{rotateB:!0})),getSupplierPartCandidates=supplierPartNumbers=>{if(!supplierPartNumbers)return[];let candidates=[];for(let supplierName of supplierNames){let partNumbers=supplierPartNumbers[supplierName];if(Array.isArray(partNumbers))for(let supplierPartNumber of partNumbers)supplierPartNumber&&candidates.push({supplierName,supplierPartNumber})}return candidates};function NormalComponent_doInitialSupplierFootprintMismatchWarning(component){if(component.root?.pcbDisabled||component.props.doNotPlace||component.props.footprint===void 0||component.getInheritedProperty("bomDisabled")||component.getInheritedProperty("partsEngineDisabled"))return;let partsEngine2=component.getInheritedProperty("partsEngine");if(!partsEngine2?.fetchPartCircuitJson)return;let{db:db2}=component.root,sourceComponent=db2.source_component.get(component.source_component_id);if(!sourceComponent?.supplier_part_numbers||!component.pcb_component_id||component._hasStartedSupplierFootprintMismatchWarningCheck)return;let supplierPartCandidates=getSupplierPartCandidates(sourceComponent.supplier_part_numbers);if(supplierPartCandidates.length===0)return;let localCopperElements=[...db2.pcb_smtpad.list({pcb_component_id:component.pcb_component_id}),...db2.pcb_plated_hole.list({pcb_component_id:component.pcb_component_id})],localBounds=getCopperBounds(localCopperElements);localBounds&&(component._hasStartedSupplierFootprintMismatchWarningCheck=!0,component._queueAsyncEffect("check-supplier-footprint-mismatch",async()=>{let{db:db22}=component.root,fetchPartCircuitJson=partsEngine2.fetchPartCircuitJson;for(let supplierPartCandidate of supplierPartCandidates){let{supplierName,supplierPartNumber}=supplierPartCandidate;try{let supplierCircuitJson=await Promise.resolve(fetchPartCircuitJson({supplierPartNumber}))??null;if(!supplierCircuitJson?.length)continue;let supplierBounds=getCopperBounds(supplierCircuitJson);if(!supplierBounds)continue;let footprintCopperIou=getBestBoundsIou(localBounds,supplierBounds);if(footprintCopperIou>=SUPPLIER_FOOTPRINT_IOU_WARNING_THRESHOLD)return;let footprintLabel=typeof component.props.footprint=="string"?`"${component.props.footprint}"`:"the provided footprint",roundedIou=Number(footprintCopperIou.toFixed(4)),warning=supplier_footprint_mismatch_warning.parse({type:"supplier_footprint_mismatch_warning",message:`${component.getString()} footprint ${footprintLabel} does not match supplier footprint ${supplierName}:${supplierPartNumber} (copper IoU ${roundedIou}).`,source_component_id:component.source_component_id,pcb_component_id:component.pcb_component_id,pcb_group_id:component.getGroup()?.pcb_group_id??void 0,subcircuit_id:component.getSubcircuit()?.subcircuit_id??void 0,supplier_name:supplierName,supplier_part_number:supplierPartNumber,footprint_copper_intersection_over_union:roundedIou});db22.supplier_footprint_mismatch_warning.insert(warning);return}catch(error2){let errorMessage=error2 instanceof Error?error2.message:String(error2),errorObj=unknown_error_finding_part.parse({type:"unknown_error_finding_part",message:`Failed to fetch supplier footprint for ${component.getString()} (${supplierName}:${supplierPartNumber}): ${errorMessage}`,source_component_id:component.source_component_id,subcircuit_id:component.getSubcircuit()?.subcircuit_id});db22.unknown_error_finding_part.insert(errorObj);return}}}))}var canMergePortDefinitions=(a3,b3)=>{let aPinNumber=a3._parsedProps.pinNumber,bPinNumber=b3._parsedProps.pinNumber;return aPinNumber!==void 0&&bPinNumber!==void 0&&aPinNumber!==bPinNumber?!1:a3.isMatchingAnyOf(b3.getNameAndAliases())},hasExactSameMembers=(a3,b3)=>{let sortedA=a3.toSorted(),sortedB=b3.toSorted();return sortedA.length===sortedB.length&&sortedA.every((name,index)=>name===sortedB[index])},getPinNumberedName=port=>port.getNameAndAliases().find(alias=>/^pin\d+$/.test(alias))??null,getPortReferenceName=(port,portNameCounts)=>{if(!port._isPrimaryPort&&port.props.name||port.props.name&&(portNameCounts.get(port.props.name)??0)<=1)return port.props.name;let pinNumberedName=getPinNumberedName(port);return pinNumberedName||(port.props.name??null)};function inferInternallyConnectedPinNamesFromPorts(ports,inferredInternallyConnectedPinNames){let portsByAlias=new Map;for(let port of ports)for(let alias of new Set(port.getNameAndAliases()))/^(pin)?\d+$/.test(alias)||!port._isPrimaryPort&&alias===port.props.name||(portsByAlias.has(alias)||portsByAlias.set(alias,[]),portsByAlias.get(alias).push(port));for(let aliasPorts of portsByAlias.values()){let uniquePorts=Array.from(new Set(aliasPorts));if(uniquePorts.length<2)continue;let portNameCounts=new Map;for(let port of uniquePorts)port.props.name&&portNameCounts.set(port.props.name,(portNameCounts.get(port.props.name)??0)+1);let portNames=uniquePorts.map(port=>getPortReferenceName(port,portNameCounts)).filter(portName=>!!portName),uniquePortNames=Array.from(new Set(portNames));uniquePortNames.length<2||inferredInternallyConnectedPinNames.some(group=>hasExactSameMembers(group,uniquePortNames))||inferredInternallyConnectedPinNames.push(uniquePortNames)}}function getPrimaryPortsFromPortHintGroups(portHintGroups,opts){let implicitPinNumber=1,entriesByPinNumber=new Map;for(let portHintGroup of portHintGroups){let filteredPortHints=portHintGroup.hints.filter(hint=>hint&&hint.trim()!=="");if(filteredPortHints.length===0)continue;let portHintsList=filteredPortHints;portHintsList.some(hint=>hint.startsWith("pin")||/^(?:pin)?\d+$/.test(hint))||(portHintsList=[...portHintsList,`pin${implicitPinNumber}`]),implicitPinNumber++;let newPort=getPortFromHints(portHintsList,opts);if(!newPort)continue;newPort.originDescription=portHintGroup.originDescription;let pinNumber=newPort._parsedProps.pinNumber;pinNumber!==void 0&&(entriesByPinNumber.has(pinNumber)||entriesByPinNumber.set(pinNumber,[]),entriesByPinNumber.get(pinNumber).push({port:newPort,component:portHintGroup.component}))}let ports=[];for(let[pinNumber,entries]of entriesByPinNumber){let mergeAliases=(target,source)=>{let mergedAliases=source.getNameAndAliases().filter(alias=>!target.getNameAndAliases().includes(alias));target.externallyAddedAliases.push(...mergedAliases)},primaryPort=entries[0].port,componentEntries=entries.filter(entry=>!!entry.component);if(componentEntries.length!==entries.length){for(let entry of entries.slice(1))mergeAliases(primaryPort,entry.port);ports.push(primaryPort);continue}let clusters=getConnectedPcbPrimitiveClustersBeforeRender(componentEntries.map(entry=>entry.component));if(clusters.length<=1){for(let entry of entries.slice(1))mergeAliases(primaryPort,entry.port);ports.push(primaryPort);continue}let internallyConnectedPinNames=[primaryPort.props.name];for(let[clusterIndex,cluster]of clusters.entries()){let clusterEntries=componentEntries.filter(entry=>cluster.includes(entry.component));if(clusterIndex===0){for(let entry of clusterEntries.slice(1))mergeAliases(primaryPort,entry.port);ports.push(primaryPort);continue}let internalPort=new Port({name:`pin${pinNumber}_internal_${clusterIndex}`,aliases:primaryPort.getNameAndAliases()});internalPort._isPrimaryPort=!1,internalPort._primaryPinNumber=pinNumber,internalPort.originDescription=`implicitInternalPhysicalPort:pin${pinNumber}:${clusterIndex}`;for(let entry of clusterEntries)mergeAliases(internalPort,entry.port);internallyConnectedPinNames.push(internalPort.props.name),ports.push(internalPort)}opts?.inferredInternallyConnectedPinNames?.push(internallyConnectedPinNames)}return opts?.inferredInternallyConnectedPinNames&&inferInternallyConnectedPinNamesFromPorts(ports,opts.inferredInternallyConnectedPinNames),ports}var debug32=(0,import_debug6.default)("tscircuit:core"),rotation32=external_exports.object({x:rotation,y:rotation,z:rotation}),NormalComponent3=class extends PrimitiveComponent2{constructor(props){let filteredProps={...props},invalidPinLabelsMessages=[];if(filteredProps.pinLabels&&!Array.isArray(filteredProps.pinLabels)){let{validPinLabels,invalidPinLabelsMessages:messages}=filterPinLabels(filteredProps.pinLabels);filteredProps.pinLabels=validPinLabels,invalidPinLabelsMessages=messages}super(filteredProps);__publicField(this,"reactSubtrees",[]);__publicField(this,"_impliedFootprint");__publicField(this,"_resolvedPcbCalcOffsetX");__publicField(this,"_resolvedPcbCalcOffsetY");__publicField(this,"isPrimitiveContainer",!0);__publicField(this,"_isNormalComponent",!0);__publicField(this,"_attributeLowerToCamelNameMap",{_isnormalcomponent:"_isNormalComponent"});__publicField(this,"_asyncSupplierPartNumbers");__publicField(this,"_asyncFootprintCadModel");__publicField(this,"_isCadModelChild");__publicField(this,"_inferredInternallyConnectedPinNames",[]);__publicField(this,"pcb_missing_footprint_error_id");__publicField(this,"_hasStartedFootprintUrlLoad",!1);__publicField(this,"_hasStartedSupplierFootprintMismatchWarningCheck",!1);__publicField(this,"_invalidFootprintPropMessages",[]);__publicField(this,"_invalidPinLabelMessages",[]);__publicField(this,"_adjustSilkscreenTextAutomatically",!1);if(filteredProps.pinLabels&&!Array.isArray(filteredProps.pinLabels)){let invalidPinKey=Object.keys(filteredProps.pinLabels).find(pinKey=>getPinNumberFromPinLabelsKey(pinKey)===null);if(invalidPinKey)throw new InvalidProps(this.lowercaseComponentName,this.props,{_errors:[],pinLabels:{_errors:[`Invalid pinLabels key "${invalidPinKey}". Expected "pin\${number}" (e.g. pin1, pin2).`]}})}this._invalidPinLabelMessages=invalidPinLabelsMessages,this._addChildrenFromStringFootprint(),this.initPorts()}get defaultInternallyConnectedPinNames(){return[]}get internallyConnectedPinNames(){return[...this._parsedProps.internallyConnectedPins??this.defaultInternallyConnectedPinNames,...this._inferredInternallyConnectedPinNames].map(pinGroup=>pinGroup.map(pin=>typeof pin=="number"?`pin${pin}`:pin))}doInitialSourceNameDuplicateComponentRemoval(){if(!this.name)return;let root=this.root;if((this.getSubcircuit().getNormalComponentNameMap?.()?.get(this.props.name)??[]).filter(component=>component!==this&&component.renderPhaseStates.SourceNameDuplicateComponentRemoval.initialized).length>0){let pcbPosition2=this._getGlobalPcbPositionBeforeLayout(),schematicPosition=this._getGlobalSchematicPositionBeforeLayout();root.db.source_failed_to_create_component_error.insert({component_name:this.name,error_type:"source_failed_to_create_component_error",message:`Cannot create component "${this.name}": A component with the same name already exists`,pcb_center:pcbPosition2,schematic_center:schematicPosition}),this.shouldBeRemoved=!0;let childrenToRemove=[...this.children];for(let child of childrenToRemove)this.remove(child)}}initPorts(opts={}){if(this.root?.schematicDisabled)return;this._inferredInternallyConnectedPinNames=[];let{config}=this,portsToCreate=[],schPortArrangement=this._getSchematicPortArrangement();if(schPortArrangement&&!this._parsedProps.pinLabels){for(let side in schPortArrangement){let pins=schPortArrangement[side].pins;if(Array.isArray(pins))for(let pinNumberOrLabel of pins){let pinNumber=parsePinNumberFromLabelsOrThrow(pinNumberOrLabel,this._parsedProps.pinLabels);portsToCreate.push(new Port({pinNumber,aliases:opts.additionalAliases?.[`pin${pinNumber}`]??[]},{originDescription:`schPortArrangement:${side}`}))}}let sides=["left","right","top","bottom"],pinNum=1;for(let side of sides){let size3=schPortArrangement[`${side}Size`];for(let i3=0;i3<size3;i3++)portsToCreate.push(new Port({pinNumber:pinNum++,aliases:opts.additionalAliases?.[`pin${pinNum}`]??[]},{originDescription:`schPortArrangement:${side}`}))}}let pinLabels=this._parsedProps.pinLabels;if(pinLabels)for(let[pinKey,label]of Object.entries(pinLabels)){let pinNumber=getPinNumberFromPinLabelsKey(pinKey);if(pinNumber===null)throw new Error(`Invalid pinLabels key "${pinKey}". Expected "pin\${number}" (e.g. pin1, pin2).`);let existingPort=portsToCreate.find(p4=>p4._parsedProps.pinNumber===pinNumber),primaryLabel=Array.isArray(label)?label[0]:label,otherLabels=Array.isArray(label)?label.slice(1):[];existingPort?(existingPort.externallyAddedAliases.push(primaryLabel,...otherLabels),existingPort.props.name=primaryLabel):(existingPort=new Port({pinNumber,name:primaryLabel,aliases:[...otherLabels,...opts.additionalAliases?.[`pin${pinNumber}`]??[]]},{originDescription:`pinLabels:pin${pinNumber}`}),portsToCreate.push(existingPort))}if(config.schematicSymbolName&&!opts.ignoreSymbolPorts){let sym=Vf[this._getSchematicSymbolNameOrThrow()];if(!sym)return;for(let symPort of sym.ports){let pinNumber=getPinNumberFromLabels(symPort.labels);if(!pinNumber)continue;let existingPort=portsToCreate.find(p4=>p4._parsedProps.pinNumber===Number(pinNumber));if(existingPort)existingPort.schematicSymbolPortDef=symPort;else{let port=getPortFromHints(symPort.labels.concat(opts.additionalAliases?.[`pin${pinNumber}`]??[]));port&&(port.originDescription=`schematicSymbol:labels[0]:${symPort.labels[0]}`,port.schematicSymbolPortDef=symPort,portsToCreate.push(port))}}this.addAll(portsToCreate)}if(!this._getSchematicPortArrangement()){let hasReactSymbol=(0,import_react2.isValidElement)(this.props.symbol),symbolAlreadyAdded=this.children.some(c4=>c4.componentName==="Symbol");if(!(hasReactSymbol&&!symbolAlreadyAdded)){let portsFromFootprint=this.getPortsFromFootprint({...opts,collectInferredInternallyConnectedPins:!0}),existingPorts=this._getAllPortsFromChildren();for(let port of portsFromFootprint){if(!port._isPrimaryPort){portsToCreate.push(port);continue}let matchingPort=existingPorts.find(p4=>canMergePortDefinitions(p4,port))??portsToCreate.find(p4=>canMergePortDefinitions(p4,port));if(matchingPort){let mergedAliases=port.getNameAndAliases().filter(alias=>!matchingPort.getNameAndAliases().includes(alias));matchingPort.externallyAddedAliases.push(...mergedAliases)}else portsToCreate.push(port)}}}let requiredPinCount=opts.pinCount??this._getPrimaryPinCount()??0;for(let pn3=1;pn3<=requiredPinCount;pn3++){if(portsToCreate.find(p4=>p4._parsedProps.pinNumber===pn3))continue;if(!schPortArrangement){portsToCreate.push(new Port({pinNumber:pn3,aliases:opts.additionalAliases?.[`pin${pn3}`]??[]}));continue}let explicitlyListedPinNumbersInSchPortArrangement=[...getPinsFromSideDefinition(schPortArrangement.leftSide),...getPinsFromSideDefinition(schPortArrangement.rightSide),...getPinsFromSideDefinition(schPortArrangement.topSide),...getPinsFromSideDefinition(schPortArrangement.bottomSide)].map(pn22=>parsePinNumberFromLabelsOrThrow(pn22,this._parsedProps.pinLabels));["leftSize","rightSize","topSize","bottomSize","leftPinCount","rightPinCount","topPinCount","bottomPinCount"].some(key=>key in schPortArrangement)&&(explicitlyListedPinNumbersInSchPortArrangement=Array.from({length:this._getPrimaryPinCount()},(_4,i3)=>i3+1)),explicitlyListedPinNumbersInSchPortArrangement.includes(pn3)&&portsToCreate.push(new Port({pinNumber:pn3,aliases:opts.additionalAliases?.[`pin${pn3}`]??[]},{originDescription:`notOtherwiseAddedButDeducedFromPinCount:${pn3}`}))}inferInternallyConnectedPinNamesFromPorts(Array.from(new Set([...this._getAllPortsFromChildren(),...portsToCreate])),this._inferredInternallyConnectedPinNames),portsToCreate.length>0&&this.addAll(portsToCreate)}_getImpliedFootprintString(){return null}_addChildrenFromStringFootprint(){let{pcbRotation,pinLabels,pcbPinLabels}=this.props,{footprint}=this.props;if(footprint??(footprint=this._getImpliedFootprintString?.()),!!footprint&&typeof footprint=="string"){if(isHttpUrl(footprint)||isStaticAssetPath(footprint)||parseLibraryFootprintRef(footprint))return;let fpCircuitJson;try{fpCircuitJson=fp.string(footprint).soup()}catch(error2){this._queueInvalidFootprintPropMessage(footprint,error2);return}let fpComponents=createComponentsFromCircuitJson({componentName:this.name??this.componentName,componentRotation:pcbRotation,footprinterString:footprint,pinLabels,pcbPinLabels},fpCircuitJson);this.addAll(fpComponents)}}get portMap(){return new Proxy({},{get:(target,prop)=>{let port=this.children.find(c4=>c4.componentName==="Port"&&c4.isMatchingNameOrAlias(prop));if(!port)throw new Error(`There was an issue finding the port "${prop.toString()}" inside of a ${this.componentName} component with name: "${this.props.name}". This is a bug in @tscircuit/core`);return port}})}getInstanceForReactElement(element){for(let subtree of this.reactSubtrees)if(subtree.element===element)return subtree.component;return null}doInitialSourceRender(){let ftype=this.config.sourceFtype;if(!ftype)return;let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype,name:this.name,manufacturer_part_number:props.manufacturerPartNumber??props.mfn,supplier_part_numbers:props.supplierPartNumbers,display_name:props.displayName});this.source_component_id=source_component.source_component_id}doInitialSourceParentAttachment(){let{db:db2}=this.root,internallyConnectedSourcePortIds=this._getInternallyConnectedPins().map(ports=>ports.map(port=>port.source_port_id).filter(id2=>id2!==null)).filter(sourcePortIds=>sourcePortIds.length>=2);this.source_component_id&&internallyConnectedSourcePortIds.length>0&&db2.source_component.update(this.source_component_id,{internally_connected_source_port_ids:internallyConnectedSourcePortIds});for(let sourcePortIds of internallyConnectedSourcePortIds)db2.source_component_internal_connection.insert({source_component_id:this.source_component_id,subcircuit_id:this.getSubcircuit()?.subcircuit_id,source_port_ids:sourcePortIds})}doInitialSchematicComponentRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root;if(this._invalidPinLabelMessages?.length&&this.root?.db)for(let message of this._invalidPinLabelMessages){let property_name="pinLabels",match2=message.match(/^Invalid pin label:\s*([^=]+)=\s*'([^']+)'/);match2&&(property_name=`pinLabels['${match2[2]}']`),this.root.db.source_property_ignored_warning.insert({source_component_id:this.source_component_id,property_name,message,error_type:"source_property_ignored_warning"})}this._parsedProps.schPinSpacing!==void 0&&this.root?.db&&this.root.db.source_property_ignored_warning.insert({source_component_id:this.source_component_id,property_name:"schPinSpacing",error_type:"source_property_ignored_warning",message:"schPinSpacing is deprecated and will be ignored. Pin spacing is always 0.2."});let{schematicSymbolName}=this.config,{_parsedProps:props}=this;props.symbol&&(0,import_react2.isValidElement)(props.symbol)?this._doInitialSchematicComponentRenderWithReactSymbol(props.symbol):schematicSymbolName?this._doInitialSchematicComponentRenderWithSymbol():this._getSchematicBoxDimensions()&&this._doInitialSchematicComponentRenderWithSchematicBoxDimensions();let manualPlacement=this.getSubcircuit()?._getSchematicManualPlacementForComponent(this);if(this.schematic_component_id&&(this.props.schX!==void 0||this.props.schY!==void 0)&&manualPlacement){if(!this.schematic_component_id)return;let warning=schematic_manual_edit_conflict_warning.parse({type:"schematic_manual_edit_conflict_warning",schematic_manual_edit_conflict_warning_id:`schematic_manual_edit_conflict_${this.source_component_id}`,message:`${this.getString()} has both manual placement and prop coordinates. schX and schY will be used. Remove schX/schY or clear the manual placement.`,schematic_component_id:this.schematic_component_id,source_component_id:this.source_component_id,subcircuit_id:this.getSubcircuit()?.subcircuit_id});db2.schematic_manual_edit_conflict_warning.insert(warning)}}_getSchematicSymbolDisplayValue(){}_getInternallyConnectedPins(){if(this.internallyConnectedPinNames.length===0)return[];let internallyConnectedPorts=[];for(let netPortNames of this.internallyConnectedPinNames){let ports=[];for(let portName of netPortNames)ports.push(this.portMap[portName]);internallyConnectedPorts.push(ports)}return internallyConnectedPorts}_doInitialSchematicComponentRenderWithSymbol(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,symbol_name=this._getSchematicSymbolNameOrThrow(),symbol=Vf[symbol_name],center2=this._getGlobalSchematicPositionBeforeLayout();if(symbol){let schematic_component22=db2.schematic_component.insert({center:center2,size:{...symbol.size},source_component_id:this.source_component_id,is_box_with_pins:!0,symbol_name,symbol_display_value:this._getSchematicSymbolDisplayValue()});this.schematic_component_id=schematic_component22.schematic_component_id}}_doInitialSchematicComponentRenderWithReactSymbol(symbolElement){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,center2=this._getGlobalSchematicPositionBeforeLayout(),schematic_component22=db2.schematic_component.insert({center:center2,size:{width:0,height:0},source_component_id:this.source_component_id,symbol_display_value:this._getSchematicSymbolDisplayValue(),is_box_with_pins:!1});this.schematic_component_id=schematic_component22.schematic_component_id}_doInitialSchematicComponentRenderWithSchematicBoxDimensions(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,dimensions=this._getSchematicBoxDimensions(),primaryPortLabels={};if(Array.isArray(props.pinLabels))props.pinLabels.forEach((label,index)=>{primaryPortLabels[String(index+1)]=label});else for(let[port,label]of Object.entries(props.pinLabels??{}))primaryPortLabels[port]=Array.isArray(label)?label[0]:label;let center2=this._getGlobalSchematicPositionBeforeLayout(),schPortArrangement=this._getSchematicPortArrangement(),schematic_component22=db2.schematic_component.insert({center:center2,rotation:props.schRotation??0,size:dimensions.getSize(),port_arrangement:underscorifyPortArrangement(schPortArrangement),pin_spacing:.2,pin_styles:underscorifyPinStyles(props.schPinStyle,props.pinLabels),port_labels:primaryPortLabels,source_component_id:this.source_component_id}),hasTopOrBottomPins=schPortArrangement?.topSide!==void 0||schPortArrangement?.bottomSide!==void 0,schematic_box_width=dimensions?.getSize().width,schematic_box_height=dimensions?.getSize().height,manufacturer_part_number_schematic_text=db2.schematic_text.insert({text:props.manufacturerPartNumber??"",schematic_component_id:schematic_component22.schematic_component_id,anchor:"left",rotation:0,position:{x:hasTopOrBottomPins?center2.x+(schematic_box_width??0)/2+.1:center2.x-(schematic_box_width??0)/2,y:hasTopOrBottomPins?center2.y+(schematic_box_height??0)/2+.35:center2.y-(schematic_box_height??0)/2-.13},color:"#006464",font_size:.18}),component_name_text=db2.schematic_text.insert({text:props.displayName??props.name??"",schematic_component_id:schematic_component22.schematic_component_id,anchor:"left",rotation:0,position:{x:hasTopOrBottomPins?center2.x+(schematic_box_width??0)/2+.1:center2.x-(schematic_box_width??0)/2,y:hasTopOrBottomPins?center2.y+(schematic_box_height??0)/2+.55:center2.y+(schematic_box_height??0)/2+.13},color:"#006464",font_size:.18});this.schematic_component_id=schematic_component22.schematic_component_id}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,subcircuit=this.getSubcircuit(),componentLayer=props.layer??"top";if(componentLayer!=="top"&&componentLayer!=="bottom"){let error2=pcb_component_invalid_layer_error.parse({type:"pcb_component_invalid_layer_error",message:`Component cannot be placed on layer '${componentLayer}'. Components can only be placed on 'top' or 'bottom' layers.`,source_component_id:this.source_component_id,layer:componentLayer,subcircuit_id:subcircuit.subcircuit_id??void 0});db2.pcb_component_invalid_layer_error.insert(error2)}let globalTransformRotation=this.getGlobalTransformRotation(),pcb_component3=db2.pcb_component.insert({center:this._getGlobalPcbPositionBeforeLayout(),width:0,height:0,layer:componentLayer==="top"||componentLayer==="bottom"?componentLayer:"top",rotation:props.pcbRotation??globalTransformRotation,insertion_direction:this._getPcbComponentInsertionDirection(componentLayer,globalTransformRotation),source_component_id:this.source_component_id,subcircuit_id:subcircuit.subcircuit_id??void 0,do_not_place:props.doNotPlace??!1,obstructs_within_bounds:props.obstructsWithinBounds??!0,metadata:props.kicadFootprintMetadata?{kicad_footprint:props.kicadFootprintMetadata}:void 0}),footprint=props.footprint??this._getImpliedFootprintString(),hasFootprintChild=this.children.some(c4=>c4.componentName==="Footprint");if(!footprint&&!hasFootprintChild&&!this.isGroup){let footprint_error=db2.pcb_missing_footprint_error.insert({message:`No footprint specified for component: ${this.getString()}`,source_component_id:`${this.source_component_id}`,error_type:"pcb_missing_footprint_error"});this.pcb_missing_footprint_error_id=footprint_error.pcb_missing_footprint_error_id}this.pcb_component_id=pcb_component3.pcb_component_id;let manualPlacement=this.getSubcircuit()._getPcbManualPlacementForComponent(this);if((this.props.pcbX!==void 0||this.props.pcbY!==void 0)&&manualPlacement){let warning=pcb_manual_edit_conflict_warning.parse({type:"pcb_manual_edit_conflict_warning",pcb_manual_edit_conflict_warning_id:`pcb_manual_edit_conflict_${this.source_component_id}`,message:`${this.getString()} has both manual placement and prop coordinates. pcbX and pcbY will be used. Remove pcbX/pcbY or clear the manual placement.`,pcb_component_id:this.pcb_component_id,source_component_id:this.source_component_id,subcircuit_id:subcircuit.subcircuit_id??void 0});db2.pcb_manual_edit_conflict_warning.insert(warning)}}doInitialPcbComponentSizeCalculation(){if(this.root?.pcbDisabled||!this.pcb_component_id)return;let{db:db2}=this.root,bounds=getBoundsOfPcbComponents(this.children);if(bounds.width===0||bounds.height===0)return;let center2={x:(bounds.minX+bounds.maxX)/2,y:(bounds.minY+bounds.maxY)/2};db2.pcb_component.update(this.pcb_component_id,{center:center2,width:bounds.width,height:bounds.height})}updatePcbComponentSizeCalculation(){this.doInitialPcbComponentSizeCalculation()}doInitialSchematicComponentSizeCalculation(){if(this.root?.schematicDisabled||!this.schematic_component_id)return;let{db:db2}=this.root;if(!db2.schematic_component.get(this.schematic_component_id))return;let schematicElements=[],collectSchematicPrimitives=children=>{for(let child of children){if(child.isSchematicPrimitive&&child.componentName==="SchematicLine"){let line2=db2.schematic_line.get(child.schematic_line_id);line2&&schematicElements.push(line2)}if(child.isSchematicPrimitive&&child.componentName==="SchematicRect"){let rect=db2.schematic_rect.get(child.schematic_rect_id);rect&&schematicElements.push(rect)}if(child.isSchematicPrimitive&&child.componentName==="SchematicCircle"){let circle2=db2.schematic_circle.get(child.schematic_circle_id);circle2&&schematicElements.push(circle2)}if(child.isSchematicPrimitive&&child.componentName==="SchematicArc"){let arc2=db2.schematic_arc.get(child.schematic_arc_id);arc2&&schematicElements.push(arc2)}if(child.isSchematicPrimitive&&child.componentName==="SchematicText"){let text=db2.schematic_text.get(child.schematic_text_id);text&&schematicElements.push(text)}if(child.isSchematicPrimitive&&child.componentName==="SchematicPath"){let pathIds=child.schematic_path_ids;if(pathIds)for(let pathId of pathIds){let path=db2.schematic_path.get(pathId);path&&schematicElements.push(path)}}child.children&&child.children.length>0&&collectSchematicPrimitives(child.children)}};if(collectSchematicPrimitives(this.children),schematicElements.length===0)return;let bounds=getBoundsForSchematic(schematicElements),width=Math.abs(bounds.maxX-bounds.minX),height=Math.abs(bounds.maxY-bounds.minY);if(width===0&&height===0)return;let centerX=(bounds.minX+bounds.maxX)/2,centerY=(bounds.minY+bounds.maxY)/2;db2.schematic_component.update(this.schematic_component_id,{center:{x:centerX,y:centerY},size:{width,height}})}updateSchematicComponentSizeCalculation(){this.doInitialSchematicComponentSizeCalculation()}doInitialPcbComponentAnchorAlignment(){NormalComponent_doInitialPcbComponentAnchorAlignment(this)}updatePcbComponentAnchorAlignment(){this.doInitialPcbComponentAnchorAlignment()}_renderReactSubtree(element){let component=createInstanceFromReactElement(element);return{element,component}}doInitialInitializePortsFromChildren(){this.initPorts()}updateInitializePortsFromChildren(){this.initPorts()}getGlobalTransformRotation(){let globalTransform=this._computePcbGlobalTransformBeforeLayout();return decomposeTSR2(globalTransform).rotation.angle*180/Math.PI}_getFootprintMetadataForPcbComponent(){let footprintChild=this.children.find(c4=>c4.componentName==="Footprint");if(footprintChild)return{insertionDirection:footprintChild._parsedProps.insertionDirection,originalLayer:footprintChild._parsedProps.originalLayer};let footprint=this.props.footprint;if((0,import_react2.isValidElement)(footprint)){let footprintProps2=footprint.props;return{insertionDirection:footprintProps2.insertionDirection,originalLayer:footprintProps2.originalLayer}}if(footprint?.componentName==="Footprint")return{insertionDirection:footprint._parsedProps?.insertionDirection??footprint.props?.insertionDirection,originalLayer:footprint._parsedProps?.originalLayer??footprint.props?.originalLayer}}_getPcbComponentInsertionDirection(componentLayer,rotationDegrees=this.getGlobalTransformRotation()){let footprintMetadata=this._getFootprintMetadataForPcbComponent();if(footprintMetadata?.insertionDirection)return transformFootprintInsertionDirection({insertionDirection:footprintMetadata.insertionDirection,rotationDegrees,isFlipped:isFootprintFlipped({componentLayer,originalLayer:footprintMetadata.originalLayer})})}doInitialReactSubtreesRender(){let fpElm=this.props.footprint;(0,import_react2.isValidElement)(fpElm)&&(this.children.some(c4=>c4.componentName==="Footprint")||this.add(fpElm));let symElm=this.props.symbol;(0,import_react2.isValidElement)(symElm)&&(this.children.some(c4=>c4.componentName==="Symbol")||this.add(symElm));let cmElm=this.props.cadModel;if((0,import_react2.isValidElement)(cmElm)){this._isCadModelChild=!0;let hasCadAssemblyChild=this.children.some(c4=>c4.componentName==="CadAssembly"),hasCadModelChild=this.children.some(c4=>c4.componentName==="CadModel");!hasCadAssemblyChild&&!hasCadModelChild&&this.add(cmElm)}}doInitialPcbFootprintStringRender(){NormalComponent_doInitialPcbFootprintStringRender(this,(name,effect)=>this._queueAsyncEffect(name,effect))}_getAllPortsFromChildren(){let ports=[],collectPorts=component=>{component.componentName==="Port"&&ports.push(component);for(let child of component.children)collectPorts(child)};for(let child of this.children)collectPorts(child);return ports}_hasExistingPortExactly(port1){return this._getAllPortsFromChildren().some(port2=>{let aliases1=port1.getNameAndAliases(),aliases2=port2.getNameAndAliases();return aliases1.length===aliases2.length&&aliases1.every(alias=>aliases2.includes(alias))})}_hasMatchingPort(port1){let existingPorts=this._getAllPortsFromChildren(),pinNumber1=port1._parsedProps.pinNumber;return pinNumber1===void 0?!1:existingPorts.some(port2=>port2._parsedProps.pinNumber===pinNumber1)}add(componentOrElm){let component;if((0,import_react2.isValidElement)(componentOrElm)){let subtree=this._renderReactSubtree(componentOrElm);this.reactSubtrees.push(subtree),component=subtree.component}else component=componentOrElm;if(component.componentName==="Port"){if(this._hasExistingPortExactly(component))return;if(this._hasMatchingPort(component)){debug32(`Skipping port ${component} because a matching port already exists`);return}}super.add(component)}getPortsFromFootprint(opts){let inferredInternallyConnectedPinNames;opts?.collectInferredInternallyConnectedPins&&(inferredInternallyConnectedPinNames=this._inferredInternallyConnectedPinNames);let primaryPortOpts={...opts,inferredInternallyConnectedPinNames},{footprint}=this.props;if(typeof footprint=="string"&&parseLibraryFootprintRef(footprint)&&this.children.some(c4=>c4.componentName==="Footprint")?footprint=this.children.find(c4=>c4.componentName==="Footprint"):(!footprint||(0,import_react2.isValidElement)(footprint))&&(footprint=this.children.find(c4=>c4.componentName==="Footprint")),typeof footprint=="string"){if(isHttpUrl(footprint))return[];if(isStaticAssetPath(footprint))return[];if(parseLibraryFootprintRef(footprint))return[];let fpCircuitJson;try{fpCircuitJson=fp.string(footprint).soup()}catch(error2){return this._queueInvalidFootprintPropMessage(footprint,error2),[]}return getPrimaryPortsFromPortHintGroups(fpCircuitJson.flatMap(elm=>"port_hints"in elm&&elm.port_hints?[{hints:elm.port_hints,originDescription:`footprint:string:${footprint}:port_hints[0]:${elm.port_hints[0]}`}]:[]),primaryPortOpts)}if(!(0,import_react2.isValidElement)(footprint)&&footprint&&footprint.componentName==="Footprint")return getPrimaryPortsFromPortHintGroups(footprint.children.flatMap(fpChild=>fpChild.props.portHints?[{hints:fpChild.props.portHints,originDescription:`footprint:${footprint}`,component:fpChild}]:[]),primaryPortOpts);let newPorts=[];if(!footprint){for(let child of this.children)if(child.props.portHints&&child.isPcbPrimitive){let port=getPortFromHints(child.props.portHints);port&&newPorts.push(port)}}return newPorts}_queueInvalidFootprintPropMessage(footprint,error2){let rawErrorMessage=error2 instanceof Error?error2.message:String(error2),helpfulHint=footprint.includes("/")&&!footprint.includes(":")?` If this is a KiCad footprint, use "kicad:${footprint}".`:"",message=`Invalid footprint prop on ${this.getDisplayName()}: "${footprint}".${helpfulHint} Parser details: ${rawErrorMessage}`;this._invalidFootprintPropMessages.includes(message)||this._invalidFootprintPropMessages.push(message)}_insertInvalidFootprintPropErrors(){for(let message of this._invalidFootprintPropMessages)this.root.db.source_invalid_component_property_error.insert({source_component_id:this.source_component_id||"",property_name:"footprint",message,error_type:"source_invalid_component_property_error"});this._invalidFootprintPropMessages=[]}getPortsFromSchematicSymbol(){if(this.root?.schematicDisabled)return[];let{config}=this;if(!config.schematicSymbolName)return[];let symbol=Vf[config.schematicSymbolName];if(!symbol)return[];let newPorts=[];for(let symbolPort of symbol.ports){let port=getPortFromHints(symbolPort.labels);port&&(port.schematicSymbolPortDef=symbolPort,newPorts.push(port))}return newPorts}doInitialCreateNetsFromProps(){this._createNetsFromProps(this._getNetsFromConnectionsProp())}_getNetsFromConnectionsProp(){let{_parsedProps:props}=this,propsWithConnections=[];if(props.connections)for(let[pinName,target]of Object.entries(props.connections)){let targets=Array.isArray(target)?target:[target];for(let targetPath of targets)propsWithConnections.push(String(targetPath))}return propsWithConnections}_createNetsFromProps(propsWithConnections){createNetsFromProps(this,propsWithConnections)}_getPcbCircuitJsonBounds(){let{db:db2}=this.root;if(!this.pcb_component_id)return super._getPcbCircuitJsonBounds();let pcb_component3=db2.pcb_component.get(this.pcb_component_id);return{center:{x:pcb_component3.center.x,y:pcb_component3.center.y},bounds:{left:pcb_component3.center.x-pcb_component3.width/2,top:pcb_component3.center.y-pcb_component3.height/2,right:pcb_component3.center.x+pcb_component3.width/2,bottom:pcb_component3.center.y+pcb_component3.height/2},width:pcb_component3.width,height:pcb_component3.height}}_getPinCountFromSchematicPortArrangement(){let schPortArrangement=this._getSchematicPortArrangement();if(!schPortArrangement)return 0;if(!isExplicitPinMappingArrangement(schPortArrangement))return(schPortArrangement.leftSize??schPortArrangement.leftPinCount??0)+(schPortArrangement.rightSize??schPortArrangement.rightPinCount??0)+(schPortArrangement.topSize??schPortArrangement.topPinCount??0)+(schPortArrangement.bottomSize??schPortArrangement.bottomPinCount??0);let{leftSide,rightSide,topSide,bottomSide}=schPortArrangement;return Math.max(...leftSide?.pins??[],...rightSide?.pins??[],...topSide?.pins??[],...bottomSide?.pins??[])}_getPrimaryPinCount(){if(this._getSchematicPortArrangement())return this._getPinCountFromSchematicPortArrangement();let portsFromFootprint=this.getPortsFromFootprint();if(portsFromFootprint.length>0)return portsFromFootprint.filter(port=>port._isPrimaryPort).length;let{pinLabels}=this._parsedProps;if(pinLabels){if(Array.isArray(pinLabels))return pinLabels.length;let pinNumbers=Object.keys(pinLabels).map(k4=>getPinNumberFromPinLabelsKey(k4)).filter(n4=>n4!==null&&!Number.isNaN(n4));return pinNumbers.length>0?Math.max(...pinNumbers):Object.keys(pinLabels).length}return 0}_getSchematicPortArrangement(){return this._parsedProps.schPinArrangement??this._parsedProps.schPortArrangement}_getPinLabelsFromPorts(){let ports=this.selectAll("port"),pinLabels={};for(let port of ports){let pinNumber=port.props.pinNumber;if(pinNumber!==void 0){let bestLabel=port._getBestDisplayPinLabel();bestLabel&&(pinLabels[`pin${pinNumber}`]=bestLabel)}}return pinLabels}_getSchematicBoxDimensions(){if(this.getSchematicSymbol()||!this.config.shouldRenderAsSchematicBox&&!this._parsedProps?.showAsSchematicBox)return null;let{_parsedProps:props}=this,pinCount=this._getPrimaryPinCount(),pinSpacing=.2,allPinLabels={...this._getPinLabelsFromPorts(),...props.pinLabels};return getAllDimensionsForSchematicBox({schWidth:props.schWidth,schHeight:props.schHeight,schPinSpacing:pinSpacing,numericSchPinStyle:getNumericSchPinStyle(props.schPinStyle,allPinLabels),pinCount,schPortArrangement:this._getSchematicPortArrangement(),pinLabels:allPinLabels})}getFootprinterString(){return typeof this._parsedProps.footprint=="string"?this._parsedProps.footprint:null}doInitialCadModelRender(){if(this._isCadModelChild||this.props.doNotPlace)return;let{db:db2}=this.root,{boardThickness=0}=this._getBoard()??{},cadModelProp2=this._parsedProps.cadModel,cadModel=cadModelProp2===void 0?this._asyncFootprintCadModel:cadModelProp2,footprint=this.getFootprinterString()??this._getImpliedFootprintString();if(!this.pcb_component_id||!cadModel&&!footprint||cadModel===null)return;let bounds=this._getPcbCircuitJsonBounds();if(typeof cadModel=="string")throw new Error("String cadModel not yet implemented");let sourceRotationOffset=cadModel?.pcbRotationOffset??cadModel?.rotationOffset,rotationOffset=rotation32.parse({x:0,y:0,z:typeof sourceRotationOffset=="number"?sourceRotationOffset:0,...typeof sourceRotationOffset=="object"?sourceRotationOffset:{}}),positionOffset=point3.parse({x:0,y:0,z:0,...typeof cadModel?.positionOffset=="object"?cadModel.positionOffset:{}}),zOffsetFromSurface=cadModel&&typeof cadModel=="object"&&"zOffsetFromSurface"in cadModel&&cadModel.zOffsetFromSurface!==void 0?distance.parse(cadModel.zOffsetFromSurface):0,computedLayer=this.props.layer==="bottom"?"bottom":"top",pcbComponent=db2.pcb_component.get(this.pcb_component_id),globalTransform=this._computePcbGlobalTransformBeforeLayout(),preLayoutRotation=decomposeTSR2(globalTransform).rotation.angle*180/Math.PI,totalRotation=pcbComponent?.position_mode==="packed"?pcbComponent.rotation??preLayoutRotation:preLayoutRotation,isBottomLayer=computedLayer==="bottom",rotationWithOffset=totalRotation+(rotationOffset.z??0),cadRotationZ=normalizeDegrees(rotationWithOffset),cad_model=db2.cad_component.insert({position:{x:bounds.center.x+positionOffset.x,y:bounds.center.y+positionOffset.y,z:(computedLayer==="bottom"?-boardThickness/2:boardThickness/2)+(computedLayer==="bottom"?-zOffsetFromSurface:zOffsetFromSurface)+positionOffset.z},rotation:{x:rotationOffset.x,y:rotationOffset.y+(isBottomLayer?180:0),z:normalizeDegrees(isBottomLayer?-cadRotationZ:cadRotationZ)},pcb_component_id:this.pcb_component_id,source_component_id:this.source_component_id,model_stl_url:"stlUrl"in(cadModel??{})?this._addCachebustToModelUrl(cadModel.stlUrl):void 0,model_obj_url:"objUrl"in(cadModel??{})?this._addCachebustToModelUrl(cadModel.objUrl):void 0,model_mtl_url:"mtlUrl"in(cadModel??{})?this._addCachebustToModelUrl(cadModel.mtlUrl):void 0,model_gltf_url:"gltfUrl"in(cadModel??{})?this._addCachebustToModelUrl(cadModel.gltfUrl):void 0,model_glb_url:"glbUrl"in(cadModel??{})?this._addCachebustToModelUrl(cadModel.glbUrl):void 0,model_step_url:"stepUrl"in(cadModel??{})?this._addCachebustToModelUrl(cadModel.stepUrl):void 0,model_wrl_url:"wrlUrl"in(cadModel??{})?this._addCachebustToModelUrl(cadModel.wrlUrl):void 0,model_jscad:"jscad"in(cadModel??{})?cadModel.jscad:void 0,model_unit_to_mm_scale_factor:typeof cadModel?.modelUnitToMmScale=="number"?cadModel.modelUnitToMmScale:void 0,model_board_normal_direction:cadModel?.modelBoardNormalDirection,model_origin_alignment:"center_of_component_on_board_surface",anchor_alignment:"center_of_component_on_board_surface",model_origin_position:cadModel?.modelOriginPosition,footprinter_string:typeof footprint=="string"&&!cadModel?footprint:void 0,show_as_translucent_model:this._parsedProps.showAsTranslucentModel});this.cad_component_id=cad_model.cad_component_id}_addCachebustToModelUrl(url2){if(!url2||!url2.includes("modelcdn.tscircuit.com"))return url2;let origin=this.root?.getClientOrigin()??"";return`${url2}${url2.includes("?")?"&":"?"}cachebust_origin=${encodeURIComponent(origin)}`}_getPartsEngineCacheKey(source_component,footprinterString){return JSON.stringify({ftype:source_component.ftype,name:source_component.name,manufacturer_part_number:source_component.manufacturer_part_number,footprinterString})}async _getSupplierPartNumbers(partsEngine2,source_component,footprinterString){if(this.props.doNotPlace)return{};let cacheEngine=this.root?.platform?.localCacheEngine,cacheKey=this._getPartsEngineCacheKey(source_component,footprinterString);if(cacheEngine){let cached=await cacheEngine.getItem(cacheKey);if(cached)try{return JSON.parse(cached)}catch{}}let result=await Promise.resolve(partsEngine2.findPart({sourceComponent:source_component,footprinterString}));if(typeof result=="string"){if(result.includes("<!DOCTYPE")||result.includes("<html"))throw new Error(`Failed to fetch supplier part numbers: Received HTML response instead of JSON. Response starts with: ${result.substring(0,100)}`);if(result==="Not found")return{};throw new Error(`Invalid supplier part numbers format: Expected object but got string: "${result}"`)}if(!result||Array.isArray(result)||typeof result!="object"){let actualType=result===null?"null":Array.isArray(result)?"array":typeof result;throw new Error(`Invalid supplier part numbers format: Expected object but got ${actualType}`)}let supplierPartNumbers=result;if(cacheEngine)try{await cacheEngine.setItem(cacheKey,JSON.stringify(supplierPartNumbers))}catch{}return supplierPartNumbers}doInitialPartsEngineRender(){if(this.props.doNotPlace||this.getInheritedProperty("bomDisabled")||this.getInheritedProperty("partsEngineDisabled"))return;let partsEngine2=this.getInheritedProperty("partsEngine");if(!partsEngine2)return;let{db:db2}=this.root,source_component=db2.source_component.get(this.source_component_id);if(!source_component||source_component.supplier_part_numbers)return;let footprinterString;this.props.footprint&&typeof this.props.footprint=="string"&&(footprinterString=this.props.footprint);let supplierPartNumbersMaybePromise=this._getSupplierPartNumbers(partsEngine2,source_component,footprinterString);if(!(supplierPartNumbersMaybePromise instanceof Promise)){db2.source_component.update(this.source_component_id,{supplier_part_numbers:supplierPartNumbersMaybePromise});return}this._queueAsyncEffect("get-supplier-part-numbers",async()=>{await supplierPartNumbersMaybePromise.then(supplierPartNumbers=>{this._asyncSupplierPartNumbers=supplierPartNumbers,this._markDirty("PartsEngineRender")}).catch(error2=>{this._asyncSupplierPartNumbers={};let errorObj=unknown_error_finding_part.parse({type:"unknown_error_finding_part",message:`Failed to fetch supplier part numbers for ${this.getString()}: ${error2.message}`,source_component_id:this.source_component_id,subcircuit_id:this.getSubcircuit()?.subcircuit_id});db2.unknown_error_finding_part.insert(errorObj),this._markDirty("PartsEngineRender")})})}updatePartsEngineRender(){if(this.props.doNotPlace||this.getInheritedProperty("bomDisabled")||this.getInheritedProperty("partsEngineDisabled"))return;let{db:db2}=this.root,source_component=db2.source_component.get(this.source_component_id);if(source_component&&!source_component.supplier_part_numbers&&this._asyncSupplierPartNumbers){db2.source_component.update(this.source_component_id,{supplier_part_numbers:this._asyncSupplierPartNumbers});return}}doInitialSupplierFootprintMismatchWarning(){NormalComponent_doInitialSupplierFootprintMismatchWarning(this)}updateSupplierFootprintMismatchWarning(){this.doInitialSupplierFootprintMismatchWarning()}doInitialAssignFallbackProps(){let{_parsedProps:props}=this;props.connections&&!this.name&&(this.fallbackUnassignedName=this.getSubcircuit().getNextAvailableName(this))}doInitialCreateTracesFromProps(){this._createTracesFromConnectionsProp()}_createTracesFromConnectionsProp(){let{_parsedProps:props}=this;if(props.connections)for(let[pinName,target]of Object.entries(props.connections)){let targets=Array.isArray(target)?target:[target];for(let targetPath of targets)this.add(new Trace3({from:`.${this.name} > .${pinName}`,to:String(targetPath)}))}}doInitialSourceDesignRuleChecks(){NormalComponent_doInitialSourceDesignRuleChecks(this)}doInitialSourceComponentPropertyValidation(){this._insertInvalidFootprintPropErrors()}doInitialValidatePcbCoordinates(){if(super.doInitialValidatePcbCoordinates(),this.root?.pcbDisabled)return;let props=this._parsedProps,rawProps=this.props,pcbLeftEdgeX=typeof rawProps.pcbLeftEdgeX=="string"?rawProps.pcbLeftEdgeX:props.pcbLeftEdgeX??rawProps.pcbLeftEdgeX,pcbRightEdgeX=typeof rawProps.pcbRightEdgeX=="string"?rawProps.pcbRightEdgeX:props.pcbRightEdgeX??rawProps.pcbRightEdgeX,pcbTopEdgeY=typeof rawProps.pcbTopEdgeY=="string"?rawProps.pcbTopEdgeY:props.pcbTopEdgeY??rawProps.pcbTopEdgeY,pcbBottomEdgeY=typeof rawProps.pcbBottomEdgeY=="string"?rawProps.pcbBottomEdgeY:props.pcbBottomEdgeY??rawProps.pcbBottomEdgeY;(props.pcbX!==void 0||props.pcbY!==void 0||pcbLeftEdgeX!==void 0||pcbRightEdgeX!==void 0||pcbTopEdgeY!==void 0||pcbBottomEdgeY!==void 0)&&(pcbLeftEdgeX!==void 0&&this._validatePcbCoordinateReferences({rawValue:pcbLeftEdgeX,axis:"pcbX",propertyName:"pcbLeftEdgeX"}),pcbRightEdgeX!==void 0&&this._validatePcbCoordinateReferences({rawValue:pcbRightEdgeX,axis:"pcbX",propertyName:"pcbRightEdgeX"}),pcbTopEdgeY!==void 0&&this._validatePcbCoordinateReferences({rawValue:pcbTopEdgeY,axis:"pcbY",propertyName:"pcbTopEdgeY"}),pcbBottomEdgeY!==void 0&&this._validatePcbCoordinateReferences({rawValue:pcbBottomEdgeY,axis:"pcbY",propertyName:"pcbBottomEdgeY"}))}doInitialPcbLayout(){if(this.root?.pcbDisabled||!this.pcb_component_id)return;let{db:db2}=this.root,props=this._parsedProps,rawProps=this.props,pcbLeftEdgeX=props.pcbLeftEdgeX??rawProps.pcbLeftEdgeX,pcbRightEdgeX=props.pcbRightEdgeX??rawProps.pcbRightEdgeX,pcbTopEdgeY=props.pcbTopEdgeY??rawProps.pcbTopEdgeY,pcbBottomEdgeY=props.pcbBottomEdgeY??rawProps.pcbBottomEdgeY;if(!(props.pcbX!==void 0||props.pcbY!==void 0||pcbLeftEdgeX!==void 0||pcbRightEdgeX!==void 0||pcbTopEdgeY!==void 0||pcbBottomEdgeY!==void 0))return;if(pcbLeftEdgeX!==void 0&&pcbRightEdgeX!==void 0)throw new Error(`${this.componentName} cannot set both pcbLeftEdgeX and pcbRightEdgeX`);if(pcbTopEdgeY!==void 0&&pcbBottomEdgeY!==void 0)throw new Error(`${this.componentName} cannot set both pcbTopEdgeY and pcbBottomEdgeY`);let pcbComponent=db2.pcb_component.get(this.pcb_component_id),componentWidth=pcbComponent?.width??0,componentHeight=pcbComponent?.height??0,positionedRelativeToGroupId=this.getGroup()?.pcb_group_id??void 0,positionedRelativeToBoardId=positionedRelativeToGroupId?void 0:this._getBoard()?.pcb_board_id??void 0,resolvedPcbX=this._resolvedPcbCalcOffsetX??(props.pcbX!==void 0?this._resolvePcbCoordinate(props.pcbX,"pcbX"):pcbLeftEdgeX!==void 0?this._resolvePcbCoordinate(pcbLeftEdgeX,"pcbX",{propertyName:"pcbLeftEdgeX"})+componentWidth/2:pcbRightEdgeX!==void 0?this._resolvePcbCoordinate(pcbRightEdgeX,"pcbX",{propertyName:"pcbRightEdgeX"})-componentWidth/2:void 0),resolvedPcbY=this._resolvedPcbCalcOffsetY??(props.pcbY!==void 0?this._resolvePcbCoordinate(props.pcbY,"pcbY"):pcbTopEdgeY!==void 0?this._resolvePcbCoordinate(pcbTopEdgeY,"pcbY",{propertyName:"pcbTopEdgeY"})-componentHeight/2:pcbBottomEdgeY!==void 0?this._resolvePcbCoordinate(pcbBottomEdgeY,"pcbY",{propertyName:"pcbBottomEdgeY"})+componentHeight/2:void 0);db2.pcb_component.update(this.pcb_component_id,{position_mode:"relative_to_group_anchor",positioned_relative_to_pcb_group_id:positionedRelativeToGroupId,positioned_relative_to_pcb_board_id:positionedRelativeToBoardId,display_offset_x:resolvedPcbX,display_offset_y:resolvedPcbY})}_getMinimumFlexContainerSize(){return NormalComponent__getMinimumFlexContainerSize(this)}_repositionOnPcb(position4){return NormalComponent__repositionOnPcb(this,position4)}doInitialSilkscreenOverlapAdjustment(){return NormalComponent_doInitialSilkscreenOverlapAdjustment(this)}isRelativelyPositioned(){let rawProps=this.props;return this._parsedProps.pcbX!==void 0||this._parsedProps.pcbY!==void 0||this._parsedProps.pcbLeftEdgeX!==void 0||this._parsedProps.pcbRightEdgeX!==void 0||this._parsedProps.pcbTopEdgeY!==void 0||this._parsedProps.pcbBottomEdgeY!==void 0||rawProps.pcbLeftEdgeX!==void 0||rawProps.pcbRightEdgeX!==void 0||rawProps.pcbTopEdgeY!==void 0||rawProps.pcbBottomEdgeY!==void 0}},getDescendantSubcircuitIds=(db2,root_subcircuit_id)=>{let groups=db2.source_group.list(),result=[],findDescendants=parentId=>{let children=groups.filter(group=>group.parent_subcircuit_id===parentId);for(let child of children)child.subcircuit_id&&(result.push(child.subcircuit_id),findDescendants(child.subcircuit_id))};return findDescendants(root_subcircuit_id),result},getBoardCenterFromAnchor=({boardAnchorPosition,boardAnchorAlignment,width,height})=>{let{x:ax3,y:ay3}=boardAnchorPosition,cx3=ax3,cy3=ay3;switch(boardAnchorAlignment){case"top_left":cx3=ax3+width/2,cy3=ay3-height/2;break;case"top_right":cx3=ax3-width/2,cy3=ay3-height/2;break;case"bottom_left":cx3=ax3+width/2,cy3=ay3+height/2;break;case"bottom_right":cx3=ax3-width/2,cy3=ay3+height/2;break;case"top":cx3=ax3,cy3=ay3-height/2;break;case"bottom":cx3=ax3,cy3=ay3+height/2;break;case"left":cx3=ax3+width/2,cy3=ay3;break;case"right":cx3=ax3-width/2,cy3=ay3;break;default:break}return{x:cx3,y:cy3}};function inflatePcbBoard(pcbBoard,inflatorContext){let{subcircuit}=inflatorContext;if(subcircuit.lowercaseComponentName==="board"||subcircuit.lowercaseComponentName==="mountedboard"||subcircuit.parent?.lowercaseComponentName==="board")return;let boardProps2={name:"inflated_board"};pcbBoard.width&&(boardProps2.width=pcbBoard.width),pcbBoard.height&&(boardProps2.height=pcbBoard.height),pcbBoard.center&&(boardProps2.pcbX=pcbBoard.center.x,boardProps2.pcbY=pcbBoard.center.y),pcbBoard.outline&&(boardProps2.outline=pcbBoard.outline),pcbBoard.thickness&&(boardProps2.thickness=pcbBoard.thickness),pcbBoard.material&&(boardProps2.material=pcbBoard.material);let board=new Board(boardProps2);return board.pcb_board_id=pcbBoard.pcb_board_id,subcircuit.add(board),board}var Capacitor=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"_adjustSilkscreenTextAutomatically",!0)}get config(){return{componentName:"Capacitor",schematicSymbolName:this.props.polarized?"capacitor_polarized":this.props.symbolName??"capacitor",zodProps:capacitorProps,sourceFtype:FTYPE.simple_capacitor}}initPorts(){typeof this.props.footprint=="string"?super.initPorts({additionalAliases:{pin1:["anode","pos"],pin2:["cathode","neg"]}}):super.initPorts()}_getSchematicSymbolDisplayValue(){let inputCapacitance=this.props.capacitance,capacitanceDisplay=typeof inputCapacitance=="string"?inputCapacitance:`${formatSiUnit(this._parsedProps.capacitance)}F`;return this._parsedProps.schShowRatings&&this._parsedProps.maxVoltageRating?`${capacitanceDisplay}/${formatSiUnit(this._parsedProps.maxVoltageRating)}V`:capacitanceDisplay}doInitialCreateNetsFromProps(){this._createNetsFromProps([this.props.decouplingFor,this.props.decouplingTo,...this._getNetsFromConnectionsProp()])}doInitialCreateTracesFromProps(){this.props.decouplingFor&&this.props.decouplingTo&&(this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.1`,to:this.props.decouplingFor})),this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.2`,to:this.props.decouplingTo}))),this._createTracesFromConnectionsProp()}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_capacitor",name:this.name,manufacturer_part_number:props.manufacturerPartNumber??props.mfn,supplier_part_numbers:props.supplierPartNumbers,capacitance:props.capacitance,max_voltage_rating:props.maxVoltageRating,max_decoupling_trace_length:props.maxDecouplingTraceLength,display_capacitance:this._getSchematicSymbolDisplayValue(),are_pins_interchangeable:!props.polarized,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},extractPcbPrimitivesFromCircuitJson=({pcbComponent,db:db2,componentName})=>{let componentCenter=pcbComponent.center||{x:0,y:0},componentRotation=pcbComponent.rotation||0,absoluteToComponentRelativeTransform=inverse2(compose2(translate2(componentCenter.x,componentCenter.y),rotate2(componentRotation*Math.PI/180))),relativeElements=db2.toArray().filter(elm=>"pcb_component_id"in elm&&elm.pcb_component_id===pcbComponent.pcb_component_id),clonedRelativeElements=structuredClone(relativeElements);return transformPCBElements(clonedRelativeElements,absoluteToComponentRelativeTransform),createComponentsFromCircuitJson({componentName,componentRotation:"0deg"},clonedRelativeElements)},inflateFootprintComponent=(pcbElm,inflatorContext)=>{let{injectionDb,normalComponent}=inflatorContext;if(!normalComponent)return null;let primitives=extractPcbPrimitivesFromCircuitJson({pcbComponent:pcbElm,db:injectionDb,componentName:normalComponent.name});if(primitives.length===0)return null;let footprint=new Footprint({});return footprint.addAll(primitives),footprint},getInflatedPcbPlacement=({pcbComponent,sourceGroupId,inflatorContext})=>{if(!pcbComponent?.center)return{pcbX:void 0,pcbY:void 0};if(sourceGroupId){let parentPcbGroup=inflatorContext.injectionDb.pcb_group.getWhere({source_group_id:sourceGroupId});if(parentPcbGroup?.anchor_position)return{pcbX:pcbComponent.center.x-parentPcbGroup.anchor_position.x,pcbY:pcbComponent.center.y-parentPcbGroup.anchor_position.y}}return{pcbX:pcbComponent.center.x,pcbY:pcbComponent.center.y}};function inflateSourceCapacitor(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),capacitor=new Capacitor({name:sourceElm.name,capacitance:sourceElm.capacitance,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:capacitor});footprint&&capacitor.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(capacitor):subcircuit.add(capacitor)}var Chip=class extends NormalComponent3{constructor(props){super(props);__publicField(this,"schematicBoxDimensions",null)}get config(){return{componentName:"Chip",zodProps:chipProps,shouldRenderAsSchematicBox:!0}}initPorts(opts={}){super.initPorts(opts);let{_parsedProps:props}=this;if(props.externallyConnectedPins){let requiredPorts=new Set;for(let[pin1,pin2]of props.externallyConnectedPins)requiredPorts.add(pin1),requiredPorts.add(pin2);for(let pinIdentifier of requiredPorts)if(!this.children.find(child=>child instanceof Port&&child.isMatchingAnyOf([pinIdentifier]))){let pinMatch=pinIdentifier.match(/^pin(\d+)$/);if(pinMatch){let pinNumber=parseInt(pinMatch[1]);this.add(new Port({pinNumber,aliases:[pinIdentifier]}))}else this.add(new Port({name:pinIdentifier,aliases:[pinIdentifier]}))}}}doInitialSchematicComponentRender(){let{_parsedProps:props}=this;props?.noSchematicRepresentation!==!0&&super.doInitialSchematicComponentRender()}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_chip",name:this.name,manufacturer_part_number:props.manufacturerPartNumber,supplier_part_numbers:props.supplierPartNumbers,display_name:props.displayName});this.source_component_id=source_component.source_component_id}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),footprint=props.footprint??this._getImpliedFootprintString(),hasFootprintChild=this.children.some(c4=>c4.componentName==="Footprint");if(!footprint&&!hasFootprintChild&&!this._hasStartedFootprintUrlLoad){let footprint_error=db2.pcb_missing_footprint_error.insert({message:`No footprint specified for component: ${this.getString()}`,source_component_id:`${this.source_component_id}`,error_type:"pcb_missing_footprint_error"});this.pcb_missing_footprint_error_id=footprint_error.pcb_missing_footprint_error_id}let componentLayer=props.layer??"top";if(componentLayer!=="top"&&componentLayer!=="bottom"){let subcircuit=this.getSubcircuit(),error2=pcb_component_invalid_layer_error.parse({type:"pcb_component_invalid_layer_error",message:`Component cannot be placed on layer '${componentLayer}'. Components can only be placed on 'top' or 'bottom' layers.`,source_component_id:this.source_component_id,layer:componentLayer,subcircuit_id:subcircuit.subcircuit_id??void 0});db2.pcb_component_invalid_layer_error.insert(error2)}let globalTransformRotation=this.getGlobalTransformRotation(),pcb_component3=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:componentLayer==="top"||componentLayer==="bottom"?componentLayer:"top",rotation:props.pcbRotation??globalTransformRotation,insertion_direction:this._getPcbComponentInsertionDirection(componentLayer,globalTransformRotation),source_component_id:this.source_component_id,subcircuit_id:this.getSubcircuit().subcircuit_id??void 0,do_not_place:props.doNotPlace??!1,obstructs_within_bounds:props.obstructsWithinBounds??!0,is_allowed_to_be_off_board:props.allowOffBoard??!1,metadata:props.kicadFootprintMetadata?{kicad_footprint:props.kicadFootprintMetadata}:void 0});this.pcb_component_id=pcb_component3.pcb_component_id}doInitialCreateTracesFromProps(){let{_parsedProps:props}=this;if(props.externallyConnectedPins)for(let[pin1,pin2]of props.externallyConnectedPins)this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.${pin1}`,to:`${this.getSubcircuitSelector()} > port.${pin2}`}));this._createTracesFromConnectionsProp()}doInitialSimulationRender(){let{db:db2}=this.root,{pinAttributes}=this.props;if(!pinAttributes)return;let powerPort=null,groundPort=null,voltage3,ports=this.selectAll("port");for(let port of ports)for(let alias of port.getNameAndAliases())if(pinAttributes[alias]){let attributes2=pinAttributes[alias];attributes2.providesPower&&(powerPort=port,voltage3=attributes2.providesVoltage),attributes2.providesGround&&(groundPort=port)}if(!powerPort||!groundPort||voltage3===void 0)return;let powerSourcePort=db2.source_port.get(powerPort.source_port_id);if(!powerSourcePort?.subcircuit_connectivity_map_key)return;let groundSourcePort=db2.source_port.get(groundPort.source_port_id);if(!groundSourcePort?.subcircuit_connectivity_map_key)return;let powerNet=db2.source_net.getWhere({subcircuit_connectivity_map_key:powerSourcePort.subcircuit_connectivity_map_key}),groundNet=db2.source_net.getWhere({subcircuit_connectivity_map_key:groundSourcePort.subcircuit_connectivity_map_key});!powerNet||!groundNet||db2.simulation_voltage_source.insert({type:"simulation_voltage_source",positive_source_port_id:powerPort.source_port_id,positive_source_net_id:powerNet.source_net_id,negative_source_port_id:groundPort.source_port_id,negative_source_net_id:groundNet.source_net_id,voltage:voltage3})}},mapInternallyConnectedSourcePortIdsToPinLabels=(sourcePortIds,inflatorContext)=>{if(!sourcePortIds||sourcePortIds.length===0)return;let{injectionDb}=inflatorContext,mapped=sourcePortIds.map(group=>group.map(sourcePortId=>{let port=injectionDb.source_port.get(sourcePortId);return port?port.pin_number!==void 0&&port.pin_number!==null?`pin${port.pin_number}`:port.name:null}).filter(value=>value!==null)).filter(group=>group.length>0);return mapped.length>0?mapped:void 0},inflateSourceChip=(sourceElm,inflatorContext)=>{let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),schematicElm=injectionDb.schematic_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),internallyConnectedPins=mapInternallyConnectedSourcePortIdsToPinLabels(sourceElm.internally_connected_source_port_ids,inflatorContext),footprinterString=cadElm?.footprinter_string??null,{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),chip=new Chip({name:sourceElm.name,manufacturerPartNumber:sourceElm.manufacturer_part_number,supplierPartNumbers:sourceElm.supplier_part_numbers??void 0,pinLabels:schematicElm?.port_labels??void 0,schWidth:schematicElm?.size?.width,schHeight:schematicElm?.size?.height,schPinSpacing:schematicElm?.pin_spacing,schX:schematicElm?.center?.x,schY:schematicElm?.center?.y,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds,internallyConnectedPins});if(footprinterString&&(Object.assign(chip.props,{footprint:footprinterString}),Object.assign(chip._parsedProps,{footprint:footprinterString})),pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:chip});footprint&&chip.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(chip):subcircuit.add(chip)},Diode=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"pos",this.portMap.pin1);__publicField(this,"anode",this.portMap.pin1);__publicField(this,"neg",this.portMap.pin2);__publicField(this,"cathode",this.portMap.pin2)}get config(){let symbolMap={schottky:"schottky_diode",avalanche:"avalanche_diode",zener:"zener_diode",photodiode:"photodiode"},variantSymbol=this.props.schottky?"schottky":this.props.avalanche?"avalanche":this.props.zener?"zener":this.props.photo?"photodiode":null;return{schematicSymbolName:variantSymbol?symbolMap[variantSymbol]:this.props.symbolName??"diode",componentName:"Diode",zodProps:diodeProps,sourceFtype:"simple_diode"}}initPorts(){super.initPorts({additionalAliases:{pin1:["anode","pos","left"],pin2:["cathode","neg","right"]}})}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_diode",name:this.name,manufacturer_part_number:props.manufacturerPartNumber??props.mfn,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!1,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourceDiode(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),diode2=new Diode({name:sourceElm.name,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:diode2});footprint&&diode2.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(diode2):subcircuit.add(diode2)}var SOLVERS={PackSolver2,AutoroutingPipelineSolver:jD,AssignableAutoroutingPipeline2:ac2,AssignableAutoroutingPipeline3:_m2,AutoroutingPipeline1_OriginalUnravel:Oa2,AutoroutingPipelineSolver3_HgPortPointPathing:Am2,AutoroutingPipelineSolver4:jD,AutoroutingPipelineSolver5:ZD,CopperPourPipelineSolver},TscircuitAutorouter=class{constructor(input2,options={}){__publicField(this,"input");__publicField(this,"isRouting",!1);__publicField(this,"solver");__publicField(this,"eventHandlers",{complete:[],error:[],progress:[]});__publicField(this,"cycleCount",0);__publicField(this,"stepDelay");__publicField(this,"timeoutId");this.input=input2;let{capacityDepth,targetMinCapacity,stepDelay=0,useAssignableSolver=!1,useAutoJumperSolver=!1,autorouterVersion:autorouterVersion2,effort,onSolverStarted}=options,solverName;autorouterVersion2==="v1"?solverName="AutoroutingPipeline1_OriginalUnravel":autorouterVersion2==="v3"?solverName="AutoroutingPipelineSolver3_HgPortPointPathing":autorouterVersion2==="v4"||autorouterVersion2==="latest"?solverName="AutoroutingPipelineSolver4":autorouterVersion2==="v5"?solverName="AutoroutingPipelineSolver5":useAutoJumperSolver?solverName="AssignableAutoroutingPipeline3":useAssignableSolver?solverName="AssignableAutoroutingPipeline2":solverName="AutoroutingPipelineSolver4";let SolverClass=SOLVERS[solverName];this.solver=new SolverClass(input2,{capacityDepth,targetMinCapacity,cacheProvider:null,effort}),onSolverStarted?.({solverName,solverParams:{input:input2,options:{capacityDepth,targetMinCapacity,cacheProvider:null,effort}}}),this.stepDelay=stepDelay}start(){this.isRouting||(this.isRouting=!0,this.cycleCount=0,this.runCycleAndQueueNextCycle())}async stepSolver(){if("stepAsync"in this.solver&&typeof this.solver.stepAsync=="function"){await this.solver.stepAsync();return}this.solver.step()}async runCycleAndQueueNextCycle(){if(this.isRouting)try{if(this.solver.solved||this.solver.failed){this.solver.failed?this.emitEvent({type:"error",error:new AutorouterError(this.solver.error||"Routing failed")}):this.emitEvent({type:"complete",traces:this.solver.getOutputSimpleRouteJson().traces||[]}),this.isRouting=!1;return}let startTime=Date.now(),startIterations=this.solver.iterations;for(;Date.now()-startTime<250&&!this.solver.failed&&!this.solver.solved;)await this.stepSolver();let iterationsPerSecond=(this.solver.iterations-startIterations)/(Date.now()-startTime)*1e3;this.cycleCount++;let debugGraphics=this.solver?.preview()||void 0,progress=this.solver.progress;this.emitEvent({type:"progress",steps:this.cycleCount,iterationsPerSecond,progress,phase:this.solver.getCurrentPhase(),debugGraphics}),this.stepDelay>0?this.timeoutId=setTimeout(()=>{this.runCycleAndQueueNextCycle()},this.stepDelay):this.timeoutId=setTimeout(()=>{this.runCycleAndQueueNextCycle()},0)}catch(error2){this.emitEvent({type:"error",error:error2 instanceof Error?new AutorouterError(error2.message):new AutorouterError(String(error2))}),this.isRouting=!1}}stop(){this.isRouting&&(this.isRouting=!1,this.timeoutId!==void 0&&(clearTimeout(this.timeoutId),this.timeoutId=void 0))}on(event,callback){event==="complete"?this.eventHandlers.complete.push(callback):event==="error"?this.eventHandlers.error.push(callback):event==="progress"&&this.eventHandlers.progress.push(callback)}emitEvent(event){if(event.type==="complete")for(let handler of this.eventHandlers.complete)handler(event);else if(event.type==="error")for(let handler of this.eventHandlers.error)handler(event);else if(event.type==="progress")for(let handler of this.eventHandlers.progress)handler(event)}solveSync(){if(this.solver.solve(),this.solver.failed)throw new AutorouterError(this.solver.error||"Routing failed");return this.solver.getOutputSimpleRouteJson().traces||[]}getConnectedOffboardObstacles(){return"getConnectedOffboardObstacles"in this.solver?this.solver.getConnectedOffboardObstacles():{}}},createSourceTracesFromOffboardConnections=({db:db2,connectedOffboardObstacles,simpleRouteJson,subcircuit_id})=>{if(Object.keys(connectedOffboardObstacles).length===0)return;let pcbElementIdToSourcePortId=new Map;for(let pcbPort of db2.pcb_port.list())if(pcbPort.source_port_id){let smtpad2=db2.pcb_smtpad.getWhere({pcb_port_id:pcbPort.pcb_port_id});smtpad2&&pcbElementIdToSourcePortId.set(smtpad2.pcb_smtpad_id,pcbPort.source_port_id);let platedHole=db2.pcb_plated_hole.getWhere({pcb_port_id:pcbPort.pcb_port_id});platedHole&&pcbElementIdToSourcePortId.set(platedHole.pcb_plated_hole_id,pcbPort.source_port_id)}let obstacleById=new Map;for(let obstacle of simpleRouteJson.obstacles)obstacle.obstacleId&&obstacleById.set(obstacle.obstacleId,obstacle);let connectionGroups=new Map;for(let[obstacleId,rootConnectionName]of Object.entries(connectedOffboardObstacles))connectionGroups.has(rootConnectionName)||connectionGroups.set(rootConnectionName,[]),connectionGroups.get(rootConnectionName).push(obstacleId);for(let[rootConnectionName,obstacleIds]of connectionGroups){let sourcePortIds=new Set;for(let obstacleId of obstacleIds){let obstacle=obstacleById.get(obstacleId);if(obstacle)for(let connectedId of obstacle.connectedTo){let sourcePortId=pcbElementIdToSourcePortId.get(connectedId);sourcePortId&&sourcePortIds.add(sourcePortId)}}if(sourcePortIds.size<2)continue;let sourcePortIdArray=Array.from(sourcePortIds);db2.source_trace.list().some(trace=>{let tracePortIds=new Set(trace.connected_source_port_ids);return sourcePortIdArray.every(id2=>tracePortIds.has(id2))})||db2.source_trace.insert({connected_source_port_ids:sourcePortIdArray,connected_source_net_ids:[],subcircuit_id:subcircuit_id??void 0,display_name:`offboard_${rootConnectionName}`})}};function getPresetAutoroutingConfig(autorouterConfig2){let defaults={serverUrl:"https://registry-api.tscircuit.com",serverMode:"job",serverCacheEnabled:!0};if(typeof autorouterConfig2=="object"&&!autorouterConfig2.preset)return{local:!(autorouterConfig2.serverUrl||autorouterConfig2.serverMode||autorouterConfig2.serverCacheEnabled),...defaults,...autorouterConfig2};let preset=typeof autorouterConfig2=="object"?autorouterConfig2.preset:autorouterConfig2,providedConfig=typeof autorouterConfig2=="object"?autorouterConfig2:{};switch(typeof preset=="string"?preset.replace(/_/g,"-"):preset){case"auto-local":return{local:!0,groupMode:"subcircuit"};case"sequential-trace":return{local:!0,groupMode:"sequential-trace"};case"subcircuit":return{local:!0,groupMode:"subcircuit"};case"auto-cloud":{let{preset:_preset,local:_local,groupMode:_groupMode,...rest}=providedConfig;return{local:!1,groupMode:"subcircuit",...defaults,...rest}}case"laser-prefab":{let{preset:_preset,local:_local,groupMode:_groupMode,...rest}=providedConfig;return{local:!0,groupMode:"subcircuit",preset:"laser_prefab",...rest}}case"auto-jumper":{let{preset:_preset,local:_local,groupMode:_groupMode,...rest}=providedConfig;return{local:!0,groupMode:"subcircuit",preset:"auto_jumper",...rest}}default:return{local:!0,groupMode:"subcircuit"}}}var applyPcbEditEventsToManualEditsFile=({circuitJson,editEvents,manualEditsFile})=>{let updatedManualEditsFile={...manualEditsFile,pcb_placements:[...manualEditsFile.pcb_placements??[]]};for(let editEvent of editEvents)if(editEvent.edit_event_type==="edit_pcb_component_location"){let{pcb_component_id,new_center}=editEvent,pcb_component3=su2(circuitJson).pcb_component.get(pcb_component_id);if(!pcb_component3)continue;let source_component=su2(circuitJson).source_component.get(pcb_component3.source_component_id);if(!source_component)continue;let existingPlacementIndex=updatedManualEditsFile.pcb_placements?.findIndex(p4=>p4.selector===source_component.name),newPlacement={selector:source_component.name,center:new_center,relative_to:"group_center"};existingPlacementIndex>=0?updatedManualEditsFile.pcb_placements[existingPlacementIndex]=newPlacement:updatedManualEditsFile.pcb_placements.push(newPlacement)}return updatedManualEditsFile},applySchematicEditEventsToManualEditsFile=({circuitJson,editEvents,manualEditsFile})=>{let updatedManualEditsFile={...manualEditsFile,schematic_placements:[...manualEditsFile.schematic_placements??[]]};for(let editEvent of editEvents)if(editEvent.edit_event_type==="edit_schematic_component_location"){let{schematic_component_id,new_center}=editEvent,schematic_component22=su2(circuitJson).schematic_component.get(schematic_component_id);if(!schematic_component22||!schematic_component22.source_component_id)continue;let source_component=su2(circuitJson).source_component.get(schematic_component22.source_component_id);if(!source_component)continue;let existingPlacementIndex=updatedManualEditsFile.schematic_placements?.findIndex(p4=>p4.selector===source_component.name),newPlacement={selector:source_component.name,center:new_center,relative_to:"group_center"};existingPlacementIndex>=0?updatedManualEditsFile.schematic_placements[existingPlacementIndex]=newPlacement:updatedManualEditsFile.schematic_placements.push(newPlacement)}return updatedManualEditsFile},applyEditEventsToManualEditsFile=({circuitJson,editEvents,manualEditsFile})=>{let schematicEditEvents=editEvents.filter(event=>event.edit_event_type==="edit_schematic_component_location"),pcbEditEvents=editEvents.filter(event=>event.edit_event_type==="edit_pcb_component_location"),updatedManualEditsFile=manualEditsFile;return schematicEditEvents.length>0&&(updatedManualEditsFile=applySchematicEditEventsToManualEditsFile({circuitJson,editEvents:schematicEditEvents,manualEditsFile:updatedManualEditsFile})),pcbEditEvents.length>0&&(updatedManualEditsFile=applyPcbEditEventsToManualEditsFile({circuitJson,editEvents:pcbEditEvents,manualEditsFile:updatedManualEditsFile})),updatedManualEditsFile},applyTraceHintEditEvent=(circuitJson,edit_event)=>{if(su2(circuitJson).pcb_trace_hint.get(edit_event.pcb_trace_hint_id))circuitJson=circuitJson.map(e5=>e5.pcb_trace_hint_id===edit_event.pcb_trace_hint_id?{...e5,route:edit_event.route}:e5);else{let pcbPort=su2(circuitJson).pcb_port.get(edit_event.pcb_port_id);circuitJson=circuitJson.filter(e5=>!(e5.type==="pcb_trace_hint"&&e5.pcb_port_id===edit_event.pcb_port_id)).concat([{type:"pcb_trace_hint",pcb_trace_hint_id:edit_event.pcb_trace_hint_id,route:edit_event.route,pcb_port_id:edit_event.pcb_port_id,pcb_component_id:pcbPort?.pcb_component_id}])}return circuitJson},applyEditEvents=({circuitJson,editEvents})=>{circuitJson=JSON.parse(JSON.stringify(circuitJson));for(let editEvent of editEvents)if(editEvent.edit_event_type==="edit_pcb_component_location"){let component=circuitJson.find(e5=>e5.type==="pcb_component"&&e5.pcb_component_id===editEvent.pcb_component_id);if((!component||component.center.x!==editEvent.new_center.x||component.center.y!==editEvent.new_center.y)&&editEvent.original_center){let mat=translate2(editEvent.new_center.x-editEvent.original_center.x,editEvent.new_center.y-editEvent.original_center.y);circuitJson=circuitJson.map(e5=>e5.pcb_component_id!==editEvent.pcb_component_id?e5:transformPCBElement(e5,mat))}}else editEvent.edit_event_type==="edit_schematic_component_location"?circuitJson=circuitJson.map(e5=>e5.type==="schematic_component"&&e5.schematic_component_id===editEvent.schematic_component_id?{...e5,center:editEvent.new_center}:e5):editEvent.edit_event_type==="edit_pcb_trace_hint"&&(circuitJson=applyTraceHintEditEvent(circuitJson,editEvent));return circuitJson},COPPER_POUR_RECT_HEIGHT=.5,dedupeStrings=values=>Array.from(new Set(values.filter(value=>!!value))),getLayerName=layer=>typeof layer=="string"?layer:layer.name,createCopperPourObstacle=({layer,connectedTo,center:center2,width,height})=>({type:"rect",layers:[layer],center:center2,width,height,connectedTo,isCopperPour:!0}),getCopperPourBoundary=({outline,group,board})=>outline&&outline.length>=3?outline:group?.outline&&group.outline.length>=3?group.outline:board?.outline&&board.outline.length>=3?board.outline:null,getCopperPourBoundsRect=({group,board})=>group?.width&&group.height?{center:group.center,width:group.width,height:group.height}:board?.width&&board.height?{center:board.center,width:board.width,height:board.height}:null,getCopperPourConnectedTo=(net,connMap)=>dedupeStrings([net.source_net_id,net.subcircuit_connectivity_map_key,net.source_net_id?connMap.getNetConnectedToId(net.source_net_id):null]),getUnbrokenCopperPourObstacles=({connMap,subcircuitComponent,board,group})=>{if(!subcircuitComponent)return[];let obstacles=[],copperPours=subcircuitComponent.selectAll("copperpour");for(let copperPour of copperPours){let props=copperPour._parsedProps;if(!props.unbroken)continue;let net=copperPour.getSubcircuit().selectOne(props.connectsTo);if(!net?.source_net_id)continue;let layer=getLayerName(props.layer),connectedTo=getCopperPourConnectedTo(net,connMap);if(connectedTo.length===0)continue;let boundary=getCopperPourBoundary({outline:props.outline,group,board});if(boundary){let rects=fillPolygonWithRects(boundary,{rectHeight:COPPER_POUR_RECT_HEIGHT});if(rects.length>0){obstacles.push(...rects.map(rect=>createCopperPourObstacle({layer,connectedTo,center:rect.center,width:rect.width,height:rect.height})));continue}}let boundsRect=getCopperPourBoundsRect({group,board});boundsRect&&obstacles.push(createCopperPourObstacle({layer,connectedTo,center:boundsRect.center,width:boundsRect.width,height:boundsRect.height}))}return obstacles},getSimpleRouteJsonFromCircuitJson=({db:db2,circuitJson,subcircuit_id,minTraceWidth,minTraceToPadEdgeClearance,nominalTraceWidth,subcircuitComponent})=>{if(!db2&&circuitJson&&(db2=su2(circuitJson)),!db2)throw new Error("db or circuitJson is required");let traceHints=db2.pcb_trace_hint.list(),relevantSubcircuitIds=subcircuit_id?new Set([subcircuit_id]):null;if(subcircuit_id){let descendantSubcircuitIds=getDescendantSubcircuitIds(db2,subcircuit_id);for(let id2 of descendantSubcircuitIds)relevantSubcircuitIds.add(id2)}let subcircuitElements=(circuitJson??db2.toArray()).filter(e5=>!subcircuit_id||"subcircuit_id"in e5&&relevantSubcircuitIds.has(e5.subcircuit_id)),board=null;if(subcircuit_id){let source_group_id=subcircuit_id.replace(/^subcircuit_/,""),source_board3=db2.source_board.getWhere({source_group_id});source_board3&&(board=db2.pcb_board.getWhere({source_board_id:source_board3.source_board_id}))}board||(board=db2.pcb_board.list()[0]),db2=su2(subcircuitElements);let pcbGroup=subcircuit_id?db2.pcb_group.getWhere({subcircuit_id}):void 0,connMap=getFullConnectivityMapFromCircuitJson(subcircuitElements),obstacles=getObstaclesFromCircuitJson2([...db2.pcb_component.list(),...db2.pcb_smtpad.list(),...db2.pcb_plated_hole.list(),...db2.pcb_hole.list(),...db2.pcb_via.list(),...db2.pcb_cutout.list()].filter(e5=>!subcircuit_id||relevantSubcircuitIds?.has(e5.subcircuit_id)),connMap);obstacles.push(...getUnbrokenCopperPourObstacles({connMap,subcircuitComponent,board,group:pcbGroup}));for(let obstacle of obstacles){let additionalIds=obstacle.connectedTo.flatMap(id2=>connMap.getIdsConnectedToNet(id2));obstacle.connectedTo.push(...additionalIds)}let internalConnections=db2.source_component_internal_connection.list(),sourcePortIdToInternalConnectionId=new Map;for(let ic3 of internalConnections)for(let sourcePortId of ic3.source_port_ids)sourcePortIdToInternalConnectionId.set(sourcePortId,ic3.source_component_internal_connection_id);let pcbElementIdToSourcePortId=new Map;for(let pcbPort of db2.pcb_port.list())if(pcbPort.source_port_id){let smtpad2=db2.pcb_smtpad.getWhere({pcb_port_id:pcbPort.pcb_port_id});smtpad2&&pcbElementIdToSourcePortId.set(smtpad2.pcb_smtpad_id,pcbPort.source_port_id);let platedHole=db2.pcb_plated_hole.getWhere({pcb_port_id:pcbPort.pcb_port_id});platedHole&&pcbElementIdToSourcePortId.set(platedHole.pcb_plated_hole_id,pcbPort.source_port_id)}for(let obstacle of obstacles)for(let connectedId of obstacle.connectedTo){let sourcePortId=pcbElementIdToSourcePortId.get(connectedId);if(sourcePortId){let internalConnectionId=sourcePortIdToInternalConnectionId.get(sourcePortId);if(internalConnectionId){obstacle.offBoardConnectsTo=[internalConnectionId],obstacle.netIsAssignable=!0;break}}}let allPoints=obstacles.flatMap(o4=>[{x:o4.center.x-o4.width/2,y:o4.center.y-o4.height/2},{x:o4.center.x+o4.width/2,y:o4.center.y+o4.height/2}]).concat(board?.outline??[]),bounds;if(board&&!board.outline?bounds={minX:board.center.x-board.width/2,maxX:board.center.x+board.width/2,minY:board.center.y-board.height/2,maxY:board.center.y+board.height/2}:bounds={minX:Math.min(...allPoints.map(p4=>p4.x))-1,maxX:Math.max(...allPoints.map(p4=>p4.x))+1,minY:Math.min(...allPoints.map(p4=>p4.y))-1,maxY:Math.max(...allPoints.map(p4=>p4.y))+1},pcbGroup?.width&&pcbGroup.height){let groupBounds={minX:pcbGroup.center.x-pcbGroup.width/2,maxX:pcbGroup.center.x+pcbGroup.width/2,minY:pcbGroup.center.y-pcbGroup.height/2,maxY:pcbGroup.center.y+pcbGroup.height/2};bounds={minX:Math.min(bounds.minX,groupBounds.minX),maxX:Math.max(bounds.maxX,groupBounds.maxX),minY:Math.min(bounds.minY,groupBounds.minY),maxY:Math.max(bounds.maxY,groupBounds.maxY)}}let routedTraceIds=new Set(db2.pcb_trace.list().map(t52=>t52.source_trace_id).filter(id2=>!!id2)),directTraceConnections=db2.source_trace.list().filter(trace=>!routedTraceIds.has(trace.source_trace_id)).map(trace=>{let connectedPorts=trace.connected_source_port_ids.map(id2=>{let source_port3=db2.source_port.get(id2),pcb_port3=db2.pcb_port.getWhere({source_port_id:id2});return{...source_port3,...pcb_port3}});if(connectedPorts.length<2)return null;let[portA,portB]=connectedPorts;if(portA.x===void 0||portA.y===void 0)return console.error(`(source_port_id: ${portA.source_port_id}) for trace ${trace.source_trace_id} does not have x/y coordinates. Skipping this trace.`),null;if(portB.x===void 0||portB.y===void 0)return console.error(`(source_port_id: ${portB.source_port_id}) for trace ${trace.source_trace_id} does not have x/y coordinates. Skipping this trace.`),null;let layerA=portA.layers?.[0]??"top",layerB=portB.layers?.[0]??"top",matchingHints=traceHints.filter(hint=>hint.pcb_port_id===portA.pcb_port_id||hint.pcb_port_id===portB.pcb_port_id),hintPoints=[];for(let hint of matchingHints){let layer=db2.pcb_port.get(hint.pcb_port_id)?.layers?.[0]??"top";for(let pt3 of hint.route)hintPoints.push({x:pt3.x,y:pt3.y,layer})}return{name:trace.source_trace_id??connMap.getNetConnectedToId(trace.source_trace_id)??"",source_trace_id:trace.source_trace_id,nominalTraceWidth:trace.min_trace_thickness,width:trace.min_trace_thickness,pointsToConnect:[{x:portA.x,y:portA.y,layer:layerA,pointId:portA.pcb_port_id,pcb_port_id:portA.pcb_port_id},...hintPoints,{x:portB.x,y:portB.y,layer:layerB,pointId:portB.pcb_port_id,pcb_port_id:portB.pcb_port_id}]}}).filter(c4=>c4!==null),directTraceConnectionsById=new Map(directTraceConnections.map(c4=>[c4.source_trace_id,c4])),source_nets=db2.source_net.list().filter(e5=>!subcircuit_id||relevantSubcircuitIds?.has(e5.subcircuit_id)),connectionsFromNets=[];for(let net of source_nets){let connectedSourceTraces=db2.source_trace.list().filter(st3=>st3.connected_source_net_ids?.includes(net.source_net_id)),nominalTraceWidthFromConnectedTraces;for(let sourceTrace of connectedSourceTraces)sourceTrace.min_trace_thickness!==void 0&&(nominalTraceWidthFromConnectedTraces=Math.max(nominalTraceWidthFromConnectedTraces??0,sourceTrace.min_trace_thickness));connectionsFromNets.push({name:net.source_net_id??connMap.getNetConnectedToId(net.source_net_id),nominalTraceWidth:nominalTraceWidthFromConnectedTraces,width:nominalTraceWidthFromConnectedTraces,pointsToConnect:connectedSourceTraces.flatMap(st3=>db2.pcb_port.list().filter(p4=>st3.connected_source_port_ids.includes(p4.source_port_id)).map(p4=>({x:p4.x,y:p4.y,layer:p4.layers?.[0]??"top",pointId:p4.pcb_port_id,pcb_port_id:p4.pcb_port_id})))})}let breakoutPoints=db2.pcb_breakout_point.list().filter(bp3=>!subcircuit_id||relevantSubcircuitIds?.has(bp3.subcircuit_id)),connectionsFromBreakoutPoints=[],breakoutTraceConnectionsById=new Map;for(let bp3 of breakoutPoints){let pt3={x:bp3.x,y:bp3.y,layer:"top"};if(bp3.source_trace_id){let conn=directTraceConnectionsById.get(bp3.source_trace_id)??breakoutTraceConnectionsById.get(bp3.source_trace_id);if(conn)conn.pointsToConnect.push(pt3);else{let newConn={name:bp3.source_trace_id,source_trace_id:bp3.source_trace_id,pointsToConnect:[pt3]};connectionsFromBreakoutPoints.push(newConn),breakoutTraceConnectionsById.set(bp3.source_trace_id,newConn)}}else if(bp3.source_net_id){let conn=connectionsFromNets.find(c4=>c4.name===bp3.source_net_id);conn?conn.pointsToConnect.push(pt3):connectionsFromBreakoutPoints.push({name:bp3.source_net_id,pointsToConnect:[pt3]})}else if(bp3.source_port_id){let pcb_port3=db2.pcb_port.getWhere({source_port_id:bp3.source_port_id});pcb_port3&&connectionsFromBreakoutPoints.push({name:bp3.source_port_id,source_trace_id:void 0,pointsToConnect:[{x:pcb_port3.x,y:pcb_port3.y,layer:pcb_port3.layers?.[0]??"top",pointId:pcb_port3.pcb_port_id,pcb_port_id:pcb_port3.pcb_port_id},pt3]})}}let allConns=[...directTraceConnections,...connectionsFromNets,...connectionsFromBreakoutPoints],pointIdToConn=new Map;for(let conn of allConns)for(let pt3 of conn.pointsToConnect)pt3.pointId&&pointIdToConn.set(pt3.pointId,conn);let existingTraces=db2.pcb_trace.list().filter(t52=>!subcircuit_id||relevantSubcircuitIds?.has(t52.subcircuit_id));for(let tr3 of existingTraces){let tracePortIds=new Set;for(let seg of tr3.route)seg.start_pcb_port_id&&tracePortIds.add(seg.start_pcb_port_id),seg.end_pcb_port_id&&tracePortIds.add(seg.end_pcb_port_id);if(tracePortIds.size<2)continue;let firstId=tracePortIds.values().next().value;if(!firstId)continue;let conn=pointIdToConn.get(firstId);conn&&[...tracePortIds].every(pid=>pointIdToConn.get(pid)===conn)&&(conn.externallyConnectedPointIds??(conn.externallyConnectedPointIds=[]),conn.externallyConnectedPointIds.push([...tracePortIds]))}return{simpleRouteJson:{bounds,obstacles,connections:allConns,layerCount:board?.num_layers??2,minTraceWidth:minTraceWidth??board?.min_trace_width??.1,minViaDiameter:board?.min_via_pad_diameter,minViaHoleDiameter:board?.min_via_hole_diameter,minViaPadDiameter:board?.min_via_pad_diameter,min_via_hole_diameter:board?.min_via_hole_diameter,min_via_pad_diameter:board?.min_via_pad_diameter,minTraceToPadEdgeClearance:minTraceToPadEdgeClearance??board?.min_trace_to_pad_edge_clearance,nominalTraceWidth,outline:board?.outline?.map(point62=>({...point62}))},connMap}},getPhaseTimingsFromRenderEvents=renderEvents=>{let phaseTimings={};if(!renderEvents)return phaseTimings;for(let renderPhase of orderedRenderPhases)phaseTimings[renderPhase]=0;let startEvents=new Map;for(let event of renderEvents){let[,,phase,eventType]=event.type.split(":");if(eventType==="start"){startEvents.set(`${phase}:${event.renderId}`,event);continue}if(eventType==="end"){let startEvent=startEvents.get(`${phase}:${event.renderId}`);if(startEvent){let duration=event.createdAt-startEvent.createdAt;phaseTimings[phase]=(phaseTimings[phase]||0)+duration}}}return phaseTimings},normalizePinLabels=inputPinLabels=>{let unqInputPinLabels=inputPinLabels.map(labels=>[...new Set(labels)]),result=unqInputPinLabels.map(()=>[]),desiredNumbers=unqInputPinLabels.map(()=>null);for(let i3=0;i3<unqInputPinLabels.length;i3++)for(let label of unqInputPinLabels[i3])if(/^\d+$/.test(label)){desiredNumbers[i3]=Number.parseInt(label);break}let highestPinNumber=0,alreadyAcceptedDesiredNumbers=new Set;for(let i3=0;i3<desiredNumbers.length;i3++){let desiredNumber=desiredNumbers[i3];if(desiredNumber===null||desiredNumber<1)continue;if(!alreadyAcceptedDesiredNumbers.has(desiredNumber)){alreadyAcceptedDesiredNumbers.add(desiredNumber),result[i3].push(`pin${desiredNumber}`),highestPinNumber=Math.max(highestPinNumber,desiredNumber);continue}let existingAltsForPin=0;for(let label of result[i3])label.startsWith(`pin${desiredNumber}_alt`)&&existingAltsForPin++;result[i3].push(`pin${desiredNumber}_alt${existingAltsForPin+1}`)}for(let i3=0;i3<result.length;i3++)result[i3][0]?.includes("_alt")&&(highestPinNumber++,result[i3].unshift(`pin${highestPinNumber}`));for(let i3=0;i3<result.length;i3++)result[i3].length===0&&(highestPinNumber++,result[i3].push(`pin${highestPinNumber}`));let totalLabelCounts={};for(let inputLabels of unqInputPinLabels)for(let label of inputLabels)/^\d+$/.test(label)||(totalLabelCounts[label]=(totalLabelCounts[label]??0)+1);let incrementalLabelCounts={};for(let i3=0;i3<unqInputPinLabels.length;i3++){let inputLabels=unqInputPinLabels[i3];for(let label of inputLabels)/^\d+$/.test(label)||(totalLabelCounts[label]===1?result[i3].push(label):(incrementalLabelCounts[label]=(incrementalLabelCounts[label]??0)+1,result[i3].push(`${label}${incrementalLabelCounts[label]}`)))}return result},TraceHint=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"matchedPort",null)}get config(){return{componentName:"TraceHint",zodProps:traceHintProps}}doInitialPortMatching(){let{db:db2}=this.root,{_parsedProps:props,parent}=this;if(!parent)return;if(parent.componentName==="Trace"){this.renderError(`Port inference inside trace is not yet supported (${this})`);return}if(!parent)throw new Error("TraceHint has no parent");if(!props.for){this.renderError(`TraceHint has no for property (${this})`);return}let port=parent.selectOne(props.for,{type:"port"});port||this.renderError(`${this} could not find port for selector "${props.for}"`),this.matchedPort=port,port.registerMatch(this)}getPcbRouteHints(){let{_parsedProps:props}=this,offsets=props.offset?[props.offset]:props.offsets;if(!offsets)return[];let globalTransform=this._computePcbGlobalTransformBeforeLayout();return offsets.map(offset=>({...applyToPoint2(globalTransform,offset),via:offset.via,to_layer:offset.to_layer,trace_width:offset.trace_width}))}doInitialPcbTraceHintRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this;db2.pcb_trace_hint.insert({pcb_component_id:this.matchedPort?.pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,route:this.getPcbRouteHints()})}},SUPPORTED_COMPONENT_FIELDS=new Set(["x","y","minx","maxx","miny","maxy","width","height"]);function Group_doInitialPcbCalcPlacementResolution(group){if(group.root?.pcbDisabled||!group.isSubcircuit)return;let{db:db2}=group.root,normalComponentNameMap=group.getNormalComponentNameMap?.()??new Map,allNormalComponents=collectNormalComponentsInSubcircuit(group),namedComponentVars={};for(let component of allNormalComponents)updateVarsForNamedComponent(component,namedComponentVars);let candidatesByName=new Map,inDegree=new Map,dependents=new Map;for(let component of allNormalComponents){if(!shouldResolvePlacementInCalcPhase(component))continue;let refs=getComponentRefsForCalcPlacement(component);if(!component.name)throw new Error(`Invalid pcb position expression for ${component.getString()}: component-relative calc requires the component to have a name`);candidatesByName.set(component.name,{component,refs}),inDegree.set(component.name,0)}for(let[candidateName,candidate]of candidatesByName.entries()){let referencedCandidateNames=new Set;for(let token of candidate.refs){let{referencePath,field}=parseComponentReferenceToken(token);if(!SUPPORTED_COMPONENT_FIELDS.has(field))throw new Error(`Invalid pcb position expression for ${candidate.component.getString()}: unsupported component field "${field}" in "${token}"`);let referencedComponentName=resolveReferencedComponentName({token,referencePath,candidate,normalComponentNameMap});candidatesByName.has(referencedComponentName)&&referencedComponentName!==candidateName&&referencedCandidateNames.add(referencedComponentName)}for(let referencedComponentName of referencedCandidateNames)inDegree.set(candidateName,(inDegree.get(candidateName)??0)+1),dependents.has(referencedComponentName)||dependents.set(referencedComponentName,new Set),dependents.get(referencedComponentName).add(candidateName)}let queue=[...inDegree.entries()].filter(([,degree])=>degree===0).map(([name])=>name),resolvedCount=0;for(;queue.length>0;){let name=queue.shift(),candidate=candidatesByName.get(name);if(candidate){resolveCandidatePlacement(candidate.component,namedComponentVars),resolvedCount++;for(let dependentName of dependents.get(name)??[]){let nextDegree=(inDegree.get(dependentName)??0)-1;inDegree.set(dependentName,nextDegree),nextDegree===0&&queue.push(dependentName)}}}if(resolvedCount<candidatesByName.size){let unresolvedNames=[...candidatesByName.keys()].filter(name=>(inDegree.get(name)??0)>0);throw new Error(`Circular pcb position calc references detected among: ${unresolvedNames.join(", ")}`)}function resolveCandidatePlacement(component,componentVars){if(!component.pcb_component_id)return;let pcbComponent=db2.pcb_component.get(component.pcb_component_id);if(!pcbComponent)return;let rawPcbX=component._parsedProps.pcbX,rawPcbY=component._parsedProps.pcbY,rawComponentProps=component.props,rawPcbLeftEdgeX=component._parsedProps.pcbLeftEdgeX??rawComponentProps.pcbLeftEdgeX,rawPcbRightEdgeX=component._parsedProps.pcbRightEdgeX??rawComponentProps.pcbRightEdgeX,rawPcbTopEdgeY=component._parsedProps.pcbTopEdgeY??rawComponentProps.pcbTopEdgeY,rawPcbBottomEdgeY=component._parsedProps.pcbBottomEdgeY??rawComponentProps.pcbBottomEdgeY;if(rawPcbLeftEdgeX!==void 0&&rawPcbRightEdgeX!==void 0)throw new Error(`${component.componentName} cannot set both pcbLeftEdgeX and pcbRightEdgeX`);if(rawPcbTopEdgeY!==void 0&&rawPcbBottomEdgeY!==void 0)throw new Error(`${component.componentName} cannot set both pcbTopEdgeY and pcbBottomEdgeY`);let componentWidth=pcbComponent.width??0,componentHeight=pcbComponent.height??0,nextCenter={x:pcbComponent.center.x,y:pcbComponent.center.y};if(rawPcbX!==void 0){let resolvedPcbX=component.resolvePcbCoordinate({rawValue:rawPcbX,axis:"pcbX",allowComponentVariables:!0,componentVariables:componentVars});component._resolvedPcbCalcOffsetX=resolvedPcbX,nextCenter.x=resolvedPcbX}else if(rawPcbLeftEdgeX!==void 0){let resolvedPcbX=component.resolvePcbCoordinate({rawValue:rawPcbLeftEdgeX,axis:"pcbX",allowComponentVariables:!0,componentVariables:componentVars,propertyName:"pcbLeftEdgeX"})+componentWidth/2;component._resolvedPcbCalcOffsetX=resolvedPcbX,nextCenter.x=resolvedPcbX}else if(rawPcbRightEdgeX!==void 0){let resolvedPcbX=component.resolvePcbCoordinate({rawValue:rawPcbRightEdgeX,axis:"pcbX",allowComponentVariables:!0,componentVariables:componentVars,propertyName:"pcbRightEdgeX"})-componentWidth/2;component._resolvedPcbCalcOffsetX=resolvedPcbX,nextCenter.x=resolvedPcbX}if(rawPcbY!==void 0){let resolvedPcbY=component.resolvePcbCoordinate({rawValue:rawPcbY,axis:"pcbY",allowComponentVariables:!0,componentVariables:componentVars});component._resolvedPcbCalcOffsetY=resolvedPcbY,nextCenter.y=resolvedPcbY}else if(rawPcbTopEdgeY!==void 0){let resolvedPcbY=component.resolvePcbCoordinate({rawValue:rawPcbTopEdgeY,axis:"pcbY",allowComponentVariables:!0,componentVariables:componentVars,propertyName:"pcbTopEdgeY"})-componentHeight/2;component._resolvedPcbCalcOffsetY=resolvedPcbY,nextCenter.y=resolvedPcbY}else if(rawPcbBottomEdgeY!==void 0){let resolvedPcbY=component.resolvePcbCoordinate({rawValue:rawPcbBottomEdgeY,axis:"pcbY",allowComponentVariables:!0,componentVariables:componentVars,propertyName:"pcbBottomEdgeY"})+componentHeight/2;component._resolvedPcbCalcOffsetY=resolvedPcbY,nextCenter.y=resolvedPcbY}component._repositionOnPcb(nextCenter),updateVarsForNamedComponent(component,componentVars)}}function shouldResolvePlacementInCalcPhase(component){let parsedProps=component._parsedProps,rawProps=component.props,pcbX=parsedProps.pcbX,pcbY=parsedProps.pcbY,pcbLeftEdgeX=parsedProps.pcbLeftEdgeX??rawProps.pcbLeftEdgeX,pcbRightEdgeX=parsedProps.pcbRightEdgeX??rawProps.pcbRightEdgeX,pcbTopEdgeY=parsedProps.pcbTopEdgeY??rawProps.pcbTopEdgeY,pcbBottomEdgeY=parsedProps.pcbBottomEdgeY??rawProps.pcbBottomEdgeY;return pcbLeftEdgeX!==void 0||pcbRightEdgeX!==void 0||pcbTopEdgeY!==void 0||pcbBottomEdgeY!==void 0?!0:typeof pcbX=="string"||typeof pcbY=="string"}function collectNormalComponentsInSubcircuit(group){let components=[],walk=node=>{node._isNormalComponent&&components.push(node);for(let child of node.children)child.isSubcircuit||walk(child)};for(let child of group.children)child.isSubcircuit||walk(child);return components}function getComponentRefsForCalcPlacement(component){let refs=new Set,rawPcbX=component._parsedProps.pcbX,rawPcbY=component._parsedProps.pcbY,rawComponentProps=component.props,rawPcbLeftEdgeX=component._parsedProps.pcbLeftEdgeX??rawComponentProps.pcbLeftEdgeX,rawPcbRightEdgeX=component._parsedProps.pcbRightEdgeX??rawComponentProps.pcbRightEdgeX,rawPcbTopEdgeY=component._parsedProps.pcbTopEdgeY??rawComponentProps.pcbTopEdgeY,rawPcbBottomEdgeY=component._parsedProps.pcbBottomEdgeY??rawComponentProps.pcbBottomEdgeY,addRefs=rawValue=>{if(typeof rawValue!="string")return;let identifiers=extractCalcIdentifiers(rawValue);for(let identifier of identifiers)identifier.startsWith("board.")||refs.add(identifier)};return addRefs(rawPcbX),addRefs(rawPcbY),addRefs(rawPcbLeftEdgeX),addRefs(rawPcbRightEdgeX),addRefs(rawPcbTopEdgeY),addRefs(rawPcbBottomEdgeY),refs}function parseComponentReferenceToken(token){let dotIndex=token.lastIndexOf(".");if(dotIndex<=0||dotIndex===token.length-1)throw new Error(`Invalid component reference token: "${token}"`);return{referencePath:token.slice(0,dotIndex),field:token.slice(dotIndex+1).toLowerCase()}}function resolveReferencedComponentName(params){let{token,referencePath,candidate,normalComponentNameMap}=params,directComponents=normalComponentNameMap.get(referencePath);if(directComponents&&directComponents.length>0){if(directComponents.length>1)throw new Error(`Invalid pcb position expression for ${candidate.component.getString()}: ambiguous component reference "${referencePath}" in "${token}"`);return referencePath}let bestMatch=null;for(let componentName of normalComponentNameMap.keys())referencePath.startsWith(`${componentName}.`)&&(!bestMatch||componentName.length>bestMatch.length)&&(bestMatch=componentName);if(!bestMatch)throw new Error(`Invalid pcb position expression for ${candidate.component.getString()}: unknown component reference "${referencePath}" in "${token}"`);return bestMatch}function updateVarsForNamedComponent(component,vars){if(!component.name||!component.pcb_component_id||!component.root)return;let pcbComponent=component.root.db.pcb_component.get(component.pcb_component_id);if(!pcbComponent)return;let width=pcbComponent.width??0,height=pcbComponent.height??0,x4=pcbComponent.center.x,y4=pcbComponent.center.y;setSubcircuitPcbComponentCalcVariables({vars,componentName:component.name,position:{x:x4,y:y4},size:{width,height}});let padElementsByReference=collectPadElementsByReference(component);for(let[referencePath,elements]of padElementsByReference.entries()){let bounds=getBoundsOfPcbElements(elements),minX=bounds.minX,maxX=bounds.maxX,minY=bounds.minY,maxY=bounds.maxY;vars[`${referencePath}.x`]=(minX+maxX)/2,vars[`${referencePath}.y`]=(minY+maxY)/2,vars[`${referencePath}.width`]=maxX-minX,vars[`${referencePath}.height`]=maxY-minY,vars[`${referencePath}.minX`]=minX,vars[`${referencePath}.maxX`]=maxX,vars[`${referencePath}.minY`]=minY,vars[`${referencePath}.maxY`]=maxY}}function collectPadElementsByReference(component){let refsToElements=new Map;if(!component.name||!component.pcb_component_id||!component.root)return refsToElements;let{db:db2}=component.root,padElements=[...db2.pcb_smtpad.list({pcb_component_id:component.pcb_component_id}),...db2.pcb_plated_hole.list({pcb_component_id:component.pcb_component_id})];for(let pad2 of padElements){let aliases2=new Set;for(let hint of pad2.port_hints??[])typeof hint=="string"&&hint.length>0&&aliases2.add(hint);let pcbPortId=pad2.pcb_port_id;if(pcbPortId){let pcbPort=db2.pcb_port.get(pcbPortId),sourcePort=pcbPort?.source_port_id?db2.source_port.get(pcbPort.source_port_id):null;sourcePort?.name&&aliases2.add(sourcePort.name),sourcePort?.pin_number!=null&&aliases2.add(`pin${sourcePort.pin_number}`)}for(let alias of aliases2){let referencePath=`${component.name}.${alias}`;refsToElements.has(referencePath)||refsToElements.set(referencePath,[]),refsToElements.get(referencePath).push(pad2)}}return refsToElements}function Group_doInitialPcbComponentAnchorAlignment(group){if(group.root?.pcbDisabled||!group.pcb_group_id)return;let pcbPositionAnchor=group._parsedProps?.pcbPositionAnchor;if(!pcbPositionAnchor)return;let targetPosition=group._getGlobalPcbPositionBeforeLayout(),{pcbX,pcbY}=group._parsedProps;if(pcbX===void 0&&pcbY===void 0)return;let{db:db2}=group.root,pcbGroup=db2.pcb_group.get(group.pcb_group_id);if(!pcbGroup)return;let width=pcbGroup.width,height=pcbGroup.height,{center:center2}=pcbGroup;if(pcbGroup.outline&&pcbGroup.outline.length>0){let bounds2=getBoundsFromPoints(pcbGroup.outline);bounds2&&(width=bounds2.maxX-bounds2.minX,height=bounds2.maxY-bounds2.minY)}if(!width||!height)return;let bounds={left:center2.x-width/2,right:center2.x+width/2,top:center2.y+height/2,bottom:center2.y-height/2},currentCenter={...center2},anchorPos=null;if(new Set(["center","top_left","top_center","top_right","center_left","center_right","bottom_left","bottom_center","bottom_right"]).has(pcbPositionAnchor))switch(pcbPositionAnchor){case"center":anchorPos=currentCenter;break;case"top_left":anchorPos={x:bounds.left,y:bounds.top};break;case"top_center":anchorPos={x:currentCenter.x,y:bounds.top};break;case"top_right":anchorPos={x:bounds.right,y:bounds.top};break;case"center_left":anchorPos={x:bounds.left,y:currentCenter.y};break;case"center_right":anchorPos={x:bounds.right,y:currentCenter.y};break;case"bottom_left":anchorPos={x:bounds.left,y:bounds.bottom};break;case"bottom_center":anchorPos={x:currentCenter.x,y:bounds.bottom};break;case"bottom_right":anchorPos={x:bounds.right,y:bounds.bottom};break}if(!anchorPos)return;let newCenter={...currentCenter};targetPosition.x!==void 0&&(newCenter.x+=targetPosition.x-anchorPos.x),targetPosition.y!==void 0&&(newCenter.y+=targetPosition.y-anchorPos.y),(Math.abs(newCenter.x-currentCenter.x)>1e-6||Math.abs(newCenter.y-currentCenter.y)>1e-6)&&(group._repositionOnPcb(newCenter),db2.pcb_group.update(group.pcb_group_id,{center:newCenter})),db2.pcb_group.update(group.pcb_group_id,{anchor_position:targetPosition,anchor_alignment:pcbPositionAnchor,display_offset_x:pcbX,display_offset_y:pcbY})}var Group_doInitialPcbLayoutFlex=group=>{let{db:db2}=group.root,{_parsedProps:props}=group,pcbChildren=group.children.filter(c4=>c4.pcb_component_id||c4.pcb_group_id);if(pcbChildren.some(child=>{let childProps=child._parsedProps;return childProps?.pcbX!==void 0||childProps?.pcbY!==void 0}))return;let rawJustify=props.pcbJustifyContent??props.justifyContent,rawAlign=props.pcbAlignItems??props.alignItems,rawGap=props.pcbFlexGap??props.pcbGap??props.gap,direction2=props.pcbFlexDirection??"row",justifyContent={start:"flex-start",end:"flex-end","flex-start":"flex-start","flex-end":"flex-end",stretch:"space-between","space-between":"space-between","space-around":"space-around","space-evenly":"space-evenly",center:"center"}[rawJustify??"space-between"],alignItems={start:"flex-start",end:"flex-end","flex-start":"flex-start","flex-end":"flex-end",stretch:"stretch",center:"center"}[rawAlign??"center"];if(!justifyContent)throw new Error(`Invalid justifyContent value: "${rawJustify}"`);if(!alignItems)throw new Error(`Invalid alignItems value: "${rawAlign}"`);let rowGap=0,columnGap=0;typeof rawGap=="object"?(rowGap=rawGap.y??0,columnGap=rawGap.x??0):typeof rawGap=="number"?(rowGap=rawGap,columnGap=rawGap):typeof rawGap=="string"&&(rowGap=length.parse(rawGap),columnGap=length.parse(rawGap));let minFlexContainer,width=props.width??props.pcbWidth??void 0,height=props.height??props.pcbHeight??void 0;(width===void 0||height===void 0)&&(minFlexContainer=getMinimumFlexContainer(pcbChildren.map(child=>child._getMinimumFlexContainerSize()).filter(size3=>size3!==null),{alignItems,justifyContent,direction:direction2,rowGap,columnGap}),width=minFlexContainer.width,height=minFlexContainer.height);let flexBox=new RootFlexBox(width,height,{alignItems,justifyContent,direction:direction2,rowGap,columnGap});for(let child of pcbChildren){let size3=child._getMinimumFlexContainerSize();flexBox.addChild({metadata:child,width:size3?.width??0,height:size3?.height??0,flexBasis:size3?direction2==="row"?size3.width:size3.height:void 0})}flexBox.build();let bounds={minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0,width:0,height:0};for(let child of flexBox.children)bounds.minX=Math.min(bounds.minX,child.position.x),bounds.minY=Math.min(bounds.minY,child.position.y),bounds.maxX=Math.max(bounds.maxX,child.position.x+child.size.width),bounds.maxY=Math.max(bounds.maxY,child.position.y+child.size.height);bounds.width=bounds.maxX-bounds.minX,bounds.height=bounds.maxY-bounds.minY;let groupCenter=group._getGlobalPcbPositionBeforeLayout(),offset={x:groupCenter.x-(bounds.maxX+bounds.minX)/2,y:groupCenter.y-(bounds.maxY+bounds.minY)/2};for(let child of flexBox.children)child.metadata._repositionOnPcb({x:child.position.x+child.size.width/2+offset.x,y:child.position.y+child.size.height/2+offset.y});db2.pcb_group.update(group.pcb_group_id,{width:bounds.width,height:bounds.height,center:groupCenter})},MIN_GAP=1;function Group_doInitialPcbLayoutGrid(group){let{db:db2}=group.root,props=group._parsedProps,pcbChildren=getPcbChildren(group);if(pcbChildren.length===0)return;let childDimensions=calculateChildDimensions({db:db2,pcbChildren}),gridConfig=parseGridConfiguration(props),gridLayout=createGridLayout({props,pcbChildren,childDimensions,gridConfig}),cssGrid=createCssGrid({pcbChildren,childDimensions,gridLayout,gridConfig}),{itemCoordinates}=cssGrid.layout();positionChildren({db:db2,group,pcbChildren,itemCoordinates,gridLayout}),updateGroupDimensions({db:db2,group,props,gridLayout})}function getPcbChildren(group){return group.children.filter(child=>child.pcb_component_id||child.pcb_group_id)}function calculateChildDimensions(params){let{db:db2,pcbChildren}=params,maxWidth=0,maxHeight=0;for(let child of pcbChildren){let width=0,height=0;if(child.pcb_group_id){let pcbGroup=db2.pcb_group.get(child.pcb_group_id);width=pcbGroup?.width??0,height=pcbGroup?.height??0}else if(child.pcb_component_id){let pcbComp=db2.pcb_component.get(child.pcb_component_id);width=pcbComp?.width??0,height=pcbComp?.height??0}maxWidth=Math.max(maxWidth,width),maxHeight=Math.max(maxHeight,height)}return{width:maxWidth,height:maxHeight}}function parseGridConfiguration(props){let cols=props.pcbGridCols??props.gridCols??props.pcbLayout?.grid?.cols,rows=props.pcbGridRows??props.pcbLayout?.grid?.rows,templateColumns=props.pcbGridTemplateColumns,templateRows=props.pcbGridTemplateRows,parseGap=gapValue=>gapValue===void 0?MIN_GAP:typeof gapValue=="number"?gapValue:length.parse(gapValue),gridGapOption=props.pcbGridGap??props.gridGap??props.pcbLayout?.gridGap,rowGapOption=props.pcbGridRowGap??props.gridRowGap??props.pcbLayout?.gridRowGap,colGapOption=props.pcbGridColumnGap??props.gridColumnGap??props.pcbLayout?.gridColumnGap,gapX=MIN_GAP,gapY=MIN_GAP;if(rowGapOption!==void 0||colGapOption!==void 0){let fallbackX=typeof gridGapOption=="object"?gridGapOption?.x:gridGapOption,fallbackY=typeof gridGapOption=="object"?gridGapOption?.y:gridGapOption;gapX=parseGap(colGapOption??fallbackX),gapY=parseGap(rowGapOption??fallbackY)}else if(typeof gridGapOption=="object"&&gridGapOption!==null)gapX=parseGap(gridGapOption.x),gapY=parseGap(gridGapOption.y);else{let gap=parseGap(gridGapOption);gapX=gap,gapY=gap}return{cols,rows,gapX,gapY,templateColumns,templateRows}}function createGridLayout(params){let{props,pcbChildren,childDimensions,gridConfig}=params;return props.pcbGridTemplateColumns||props.pcbGridTemplateRows?createTemplateBasedLayout({props,gridConfig,pcbChildren,childDimensions}):createDefaultLayout({gridConfig,pcbChildren,childDimensions})}function createTemplateBasedLayout(params){let{props,gridConfig,pcbChildren,childDimensions}=params,gridTemplateColumns=props.pcbGridTemplateColumns??"",gridTemplateRows=props.pcbGridTemplateRows??"",extractRepeatCount=template=>{let match2=template.match(/repeat\((\d+),/);return match2?parseInt(match2[1]):Math.ceil(Math.sqrt(pcbChildren.length))},numCols=props.pcbGridTemplateColumns?extractRepeatCount(gridTemplateColumns):Math.ceil(Math.sqrt(pcbChildren.length)),numRows=props.pcbGridTemplateRows?extractRepeatCount(gridTemplateRows):Math.ceil(pcbChildren.length/numCols),containerWidth=numCols*childDimensions.width+Math.max(0,numCols-1)*gridConfig.gapX,containerHeight=numRows*childDimensions.height+Math.max(0,numRows-1)*gridConfig.gapY;return{gridTemplateColumns,gridTemplateRows,containerWidth,containerHeight}}function createDefaultLayout(params){let{gridConfig,pcbChildren,childDimensions}=params,numCols,numRows;gridConfig.cols!==void 0&&gridConfig.rows!==void 0?(numCols=gridConfig.cols,numRows=gridConfig.rows):gridConfig.cols!==void 0?(numCols=gridConfig.cols,numRows=Math.ceil(pcbChildren.length/numCols)):gridConfig.rows!==void 0?(numRows=gridConfig.rows,numCols=Math.ceil(pcbChildren.length/numRows)):(numCols=Math.ceil(Math.sqrt(pcbChildren.length)),numRows=Math.ceil(pcbChildren.length/numCols)),numCols=Math.max(1,numCols),numRows=Math.max(1,numRows);let containerWidth=numCols*childDimensions.width+Math.max(0,numCols-1)*gridConfig.gapX,containerHeight=numRows*childDimensions.height+Math.max(0,numRows-1)*gridConfig.gapY,gridTemplateColumns=`repeat(${numCols}, ${childDimensions.width}px)`,gridTemplateRows=`repeat(${numRows}, ${childDimensions.height}px)`;return{gridTemplateColumns,gridTemplateRows,containerWidth,containerHeight}}function createCssGrid(params){let{pcbChildren,childDimensions,gridLayout,gridConfig}=params,gridChildren=pcbChildren.map((child,index)=>({key:child.getString()||`child-${index}`,contentWidth:childDimensions.width,contentHeight:childDimensions.height}));return new CssGrid({containerWidth:gridLayout.containerWidth,containerHeight:gridLayout.containerHeight,gridTemplateColumns:gridLayout.gridTemplateColumns,gridTemplateRows:gridLayout.gridTemplateRows,gap:[gridConfig.gapY,gridConfig.gapX],children:gridChildren})}function positionChildren(params){let{db:db2,group,pcbChildren,itemCoordinates,gridLayout}=params,groupCenter=group._getGlobalPcbPositionBeforeLayout(),allCircuitJson=db2.toArray();for(let i3=0;i3<pcbChildren.length;i3++){let child=pcbChildren[i3],childKey=child.getString()||`child-${i3}`,coordinates=itemCoordinates[childKey];if(!coordinates){console.warn(`PCB grid layout: No coordinates found for child ${childKey}`);continue}let targetX=groupCenter.x-gridLayout.containerWidth/2+coordinates.x+coordinates.width/2,targetY=groupCenter.y+gridLayout.containerHeight/2-coordinates.y-coordinates.height/2;if(child.pcb_component_id)repositionPcbComponentTo(allCircuitJson,child.pcb_component_id,{x:targetX,y:targetY});else{let groupChild=child;groupChild.pcb_group_id&&groupChild.source_group_id&&repositionPcbGroupTo(allCircuitJson,groupChild.source_group_id,{x:targetX,y:targetY})}}}function updateGroupDimensions(params){let{db:db2,group,props,gridLayout}=params;if(group.pcb_group_id){let groupCenter=group._getGlobalPcbPositionBeforeLayout();db2.pcb_group.update(group.pcb_group_id,{width:props.width??gridLayout.containerWidth,height:props.height??gridLayout.containerHeight,center:groupCenter})}}var applyComponentConstraintClusters=(group,packInput)=>{let constraints=group.children.filter(c4=>c4.componentName==="Constraint"&&c4._parsedProps.pcb),clusterByRoot=new Map,parent={},find2=x4=>(parent[x4]!==x4&&(parent[x4]=find2(parent[x4])),parent[x4]),union2=(a3,b3)=>{let ra3=find2(a3),rb2=find2(b3);ra3!==rb2&&(parent[rb2]=ra3)},makeSet=x4=>{x4 in parent||(parent[x4]=x4)},getIdFromSelector=sel2=>{let name=sel2.startsWith(".")?sel2.slice(1):sel2;return group.children.find(c4=>c4.name===name)?.pcb_component_id??void 0};for(let constraint of constraints){let props=constraint._parsedProps;if("left"in props&&"right"in props){let a3=getIdFromSelector(props.left),b3=getIdFromSelector(props.right);a3&&b3&&(makeSet(a3),makeSet(b3),union2(a3,b3))}else if("top"in props&&"bottom"in props){let a3=getIdFromSelector(props.top),b3=getIdFromSelector(props.bottom);a3&&b3&&(makeSet(a3),makeSet(b3),union2(a3,b3))}else if("for"in props&&Array.isArray(props.for)){let ids=props.for.map(s3=>getIdFromSelector(s3)).filter(s3=>!!s3);for(let id2 of ids)makeSet(id2);for(let i3=1;i3<ids.length;i3++)union2(ids[0],ids[i3])}}for(let id2 of Object.keys(parent)){let rootId=find2(id2);clusterByRoot.has(rootId)||clusterByRoot.set(rootId,{componentIds:[],constraints:[]}),clusterByRoot.get(rootId).componentIds.push(id2)}for(let constraint of constraints){let props=constraint._parsedProps,compId;if("left"in props?compId=getIdFromSelector(props.left):"top"in props?compId=getIdFromSelector(props.top):"for"in props&&(compId=getIdFromSelector(props.for[0])),!compId)continue;let root=find2(compId);clusterByRoot.get(root)?.constraints.push(constraint)}let clusterMap={},packCompById=Object.fromEntries(packInput.components.map(c4=>[c4.componentId,c4]));for(let[rootId,info]of clusterByRoot.entries()){if(info.componentIds.length<=1)continue;let solver=new Solver,kVars={},getVar=(id2,axis)=>{let key=`${id2}_${axis}`;return kVars[key]||(kVars[key]=new Variable(key)),kVars[key]},anchor=info.componentIds[0];solver.addConstraint(new Constraint(getVar(anchor,"x"),Operator.Eq,0,Strength.required)),solver.addConstraint(new Constraint(getVar(anchor,"y"),Operator.Eq,0,Strength.required));for(let constraint of info.constraints){let props=constraint._parsedProps;if("xDist"in props){let left=getIdFromSelector(props.left),right=getIdFromSelector(props.right);left&&right&&solver.addConstraint(new Constraint(new Expression(getVar(right,"x"),[-1,getVar(left,"x")]),Operator.Eq,props.xDist,Strength.required))}else if("yDist"in props){let top=getIdFromSelector(props.top),bottom=getIdFromSelector(props.bottom);top&&bottom&&solver.addConstraint(new Constraint(new Expression(getVar(top,"y"),[-1,getVar(bottom,"y")]),Operator.Eq,props.yDist,Strength.required))}else if("sameX"in props&&Array.isArray(props.for)){let ids=props.for.map(s3=>getIdFromSelector(s3)).filter(s3=>!!s3);if(ids.length>1){let base=getVar(ids[0],"x");for(let i3=1;i3<ids.length;i3++)solver.addConstraint(new Constraint(new Expression(getVar(ids[i3],"x"),[-1,base]),Operator.Eq,0,Strength.required))}}else if("sameY"in props&&Array.isArray(props.for)){let ids=props.for.map(s3=>getIdFromSelector(s3)).filter(s3=>!!s3);if(ids.length>1){let base=getVar(ids[0],"y");for(let i3=1;i3<ids.length;i3++)solver.addConstraint(new Constraint(new Expression(getVar(ids[i3],"y"),[-1,base]),Operator.Eq,0,Strength.required))}}}solver.updateVariables();let positions={};for(let id2 of info.componentIds)positions[id2]={x:getVar(id2,"x").value(),y:getVar(id2,"y").value()};let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let id2 of info.componentIds){let comp=packCompById[id2],pos=positions[id2];if(comp)for(let pad2 of comp.pads){let ax3=pos.x+pad2.offset.x,ay3=pos.y+pad2.offset.y;minX=Math.min(minX,ax3-pad2.size.x/2),maxX=Math.max(maxX,ax3+pad2.size.x/2),minY=Math.min(minY,ay3-pad2.size.y/2),maxY=Math.max(maxY,ay3+pad2.size.y/2)}}let clusterCenter={x:(minX+maxX)/2,y:(minY+maxY)/2},mergedPads=[],relCenters={};for(let id2 of info.componentIds){let comp=packCompById[id2],pos=positions[id2];if(comp){relCenters[id2]={x:pos.x-clusterCenter.x,y:pos.y-clusterCenter.y};for(let pad2 of comp.pads)mergedPads.push({padId:pad2.padId,networkId:pad2.networkId,type:pad2.type,size:pad2.size,offset:{x:pos.x+pad2.offset.x-clusterCenter.x,y:pos.y+pad2.offset.y-clusterCenter.y}})}}packInput.components=packInput.components.filter(c4=>!info.componentIds.includes(c4.componentId)),packInput.components.push({componentId:info.componentIds[0],pads:mergedPads,availableRotationDegrees:[0]}),info.relativeCenters=relCenters,clusterMap[info.componentIds[0]]=info}return clusterMap},updateCadRotation=({db:db2,pcbComponentId,rotationDegrees,layer})=>{if(rotationDegrees==null||!db2?.cad_component?.list)return;let cadComponent=db2.cad_component.getWhere({pcb_component_id:pcbComponentId});if(!cadComponent)return;let delta=layer?.toLowerCase?.()==="bottom"?-rotationDegrees:rotationDegrees,currentRotationZ=cadComponent.rotation?.z??0,nextRotation={...cadComponent.rotation??{x:0,y:0,z:0},z:normalizeDegrees(currentRotationZ+delta)};db2.cad_component.update(cadComponent.cad_component_id,{rotation:nextRotation}),cadComponent.rotation=nextRotation},isDescendantGroup=(db2,groupId,ancestorId)=>{if(groupId===ancestorId)return!0;let group=db2.source_group.get(groupId);return!group||!group.parent_source_group_id?!1:isDescendantGroup(db2,group.parent_source_group_id,ancestorId)},applyPackOutput=(group,packOutput,clusterMap)=>{let{db:db2}=group.root;for(let packedComponent of packOutput.components){let{center:center2,componentId,ccwRotationOffset,ccwRotationDegrees}=packedComponent,cluster=clusterMap[componentId];if(cluster){let rotationDegrees2=ccwRotationDegrees??ccwRotationOffset??0,angleRad=rotationDegrees2*Math.PI/180;for(let memberId of cluster.componentIds){let rel=cluster.relativeCenters[memberId];if(!rel)continue;db2.pcb_component.update(memberId,{position_mode:"packed"});let rotatedRel={x:rel.x*Math.cos(angleRad)-rel.y*Math.sin(angleRad),y:rel.x*Math.sin(angleRad)+rel.y*Math.cos(angleRad)},member=db2.pcb_component.get(memberId);if(!member)continue;let originalCenter2=member.center,transformMatrix2=compose2(group._computePcbGlobalTransformBeforeLayout(),translate2(center2.x+rotatedRel.x,center2.y+rotatedRel.y),rotate2(angleRad),translate2(-originalCenter2.x,-originalCenter2.y)),related=db2.toArray().filter(elm=>"pcb_component_id"in elm&&elm.pcb_component_id===memberId);transformPCBElements(related,transformMatrix2),updateCadRotation({db:db2,pcbComponentId:memberId,rotationDegrees:rotationDegrees2,layer:member.layer})}continue}let pcbComponent=db2.pcb_component.get(componentId);if(pcbComponent){db2.pcb_component.update(componentId,{position_mode:"packed"});let currentGroupId=group.source_group_id,componentGroupId=db2.source_component.get(pcbComponent.source_component_id)?.source_group_id;if(componentGroupId!==void 0&&!isDescendantGroup(db2,componentGroupId,currentGroupId))continue;let originalCenter2=pcbComponent.center,rotationDegrees2=ccwRotationDegrees??ccwRotationOffset??0,transformMatrix2=compose2(group._computePcbGlobalTransformBeforeLayout(),translate2(center2.x,center2.y),rotate2(rotationDegrees2*Math.PI/180),translate2(-originalCenter2.x,-originalCenter2.y)),related=db2.toArray().filter(elm=>"pcb_component_id"in elm&&elm.pcb_component_id===componentId);transformPCBElements(related,transformMatrix2),updateCadRotation({db:db2,pcbComponentId:componentId,rotationDegrees:rotationDegrees2,layer:pcbComponent.layer});continue}let pcbGroup=db2.pcb_group.list().find(g6=>g6.source_group_id===componentId);if(!pcbGroup)continue;let originalCenter=pcbGroup.center,rotationDegrees=ccwRotationDegrees??ccwRotationOffset??0,transformMatrix=compose2(group._computePcbGlobalTransformBeforeLayout(),translate2(center2.x,center2.y),rotate2(rotationDegrees*Math.PI/180),translate2(-originalCenter.x,-originalCenter.y)),relatedElements=db2.toArray().filter(elm=>{if("source_group_id"in elm&&elm.source_group_id&&(elm.source_group_id===componentId||isDescendantGroup(db2,elm.source_group_id,componentId)))return!0;if("source_component_id"in elm&&elm.source_component_id){let sourceComponent=db2.source_component.get(elm.source_component_id);if(sourceComponent?.source_group_id&&(sourceComponent.source_group_id===componentId||isDescendantGroup(db2,sourceComponent.source_group_id,componentId)))return!0}if("pcb_component_id"in elm&&elm.pcb_component_id){let pcbComp=db2.pcb_component.get(elm.pcb_component_id);if(pcbComp?.source_component_id){let sourceComp=db2.source_component.get(pcbComp.source_component_id);if(sourceComp?.source_group_id&&(sourceComp.source_group_id===componentId||isDescendantGroup(db2,sourceComp.source_group_id,componentId)))return!0}}return!1});for(let elm of relatedElements)elm.type==="pcb_component"&&db2.pcb_component.update(elm.pcb_component_id,{position_mode:"packed"});transformPCBElements(relatedElements,transformMatrix),db2.pcb_group.update(pcbGroup.pcb_group_id,{center:center2})}},DEFAULT_MIN_GAP="1mm",debug42=(0,import_debug12.default)("Group_doInitialPcbLayoutPack"),Group_doInitialPcbLayoutPack=group=>{let{db:db2}=group.root,{_parsedProps:props}=group;group.root?.emit("packing:start",{subcircuit_id:group.subcircuit_id,componentDisplayName:group.getString()});let{packOrderStrategy,packPlacementStrategy,gap:gapProp,pcbGap,pcbPackGap}=props,gap=pcbPackGap??pcbGap??gapProp,gapMm=length.parse(gap??DEFAULT_MIN_GAP),chipMarginsMap={},staticPcbComponentIds=new Set,collectMargins=comp=>{if(comp?.pcb_component_id&&comp?._parsedProps){let props2=comp._parsedProps,left=length.parse(props2.pcbMarginLeft??props2.pcbMarginX??0),right=length.parse(props2.pcbMarginRight??props2.pcbMarginX??0),top=length.parse(props2.pcbMarginTop??props2.pcbMarginY??0),bottom=length.parse(props2.pcbMarginBottom??props2.pcbMarginY??0);(left||right||top||bottom)&&(chipMarginsMap[comp.pcb_component_id]={left,right,top,bottom})}comp?.children&&comp.children.forEach(collectMargins)};collectMargins(group);let excludedPcbGroupIds=new Set;for(let child of group.children){let childIsGroupOrNormalComponent=child;childIsGroupOrNormalComponent._isNormalComponent&&childIsGroupOrNormalComponent.isRelativelyPositioned?.()&&(childIsGroupOrNormalComponent.pcb_component_id&&staticPcbComponentIds.add(childIsGroupOrNormalComponent.pcb_component_id),childIsGroupOrNormalComponent.pcb_group_id&&excludedPcbGroupIds.add(childIsGroupOrNormalComponent.pcb_group_id))}let isDescendantGroup2=(db22,groupId,ancestorId)=>{if(groupId===ancestorId)return!0;let group2=db22.source_group.get(groupId);return!group2||!group2.parent_source_group_id?!1:isDescendantGroup2(db22,group2.parent_source_group_id,ancestorId)};if(excludedPcbGroupIds.size>0)for(let element of db2.toArray()){if(element.type!=="pcb_component")continue;let sourceComponent=db2.source_component.get(element.source_component_id);if(sourceComponent?.source_group_id)for(let groupId of excludedPcbGroupIds)isDescendantGroup2(db2,sourceComponent.source_group_id,groupId)&&staticPcbComponentIds.add(element.pcb_component_id)}let filteredCircuitJson=db2.toArray(),bounds;if(props.width!==void 0&&props.height!==void 0){let widthMm=length.parse(props.width),heightMm=length.parse(props.height);bounds={minX:-widthMm/2,maxX:widthMm/2,minY:-heightMm/2,maxY:heightMm/2}}let packInput={...convertPackOutputToPackInput(convertCircuitJsonToPackOutput(filteredCircuitJson,{source_group_id:group.source_group_id,chipMarginsMap,staticPcbComponentIds:Array.from(staticPcbComponentIds)})),orderStrategy:packOrderStrategy??"largest_to_smallest",placementStrategy:packPlacementStrategy??"minimum_sum_squared_distance_to_network",minGap:gapMm,bounds},clusterMap=applyComponentConstraintClusters(group,packInput);debug42.enabled&&(group.root?.emit("debug:logOutput",{type:"debug:logOutput",name:`packInput-circuitjson-${group.name}`,content:JSON.stringify(db2.toArray())}),group.root?.emit("debug:logOutput",{type:"debug:logOutput",name:`packInput-${group.name}`,content:packInput}));let packOutput;try{let solver=new PackSolver2(packInput);group.root?.emit("solver:started",{type:"solver:started",solverName:"PackSolver2",solverParams:solver.getConstructorParams(),componentName:group.getString()}),solver.solve(),packOutput={...packInput,components:solver.packedComponents}}catch(error2){throw group.root?.emit("packing:error",{subcircuit_id:group.subcircuit_id,componentDisplayName:group.getString(),error:{message:error2 instanceof Error?error2.message:String(error2)}}),error2}if(debug42.enabled&&global?.debugGraphics){let graphics=getGraphicsFromPackOutput(packOutput);graphics.title=`packOutput-${group.name}`,global.debugGraphics?.push(graphics)}applyPackOutput(group,packOutput,clusterMap),group.root?.emit("packing:end",{subcircuit_id:group.subcircuit_id,componentDisplayName:group.getString()})},getSizeOfTreeNodeChild=(db2,child)=>{let{sourceComponent,sourceGroup}=child;if(child.nodeType==="component"){let schComponent=db2.schematic_component.getWhere({source_component_id:sourceComponent?.source_component_id});return schComponent?.size?{width:schComponent.size.width,height:schComponent.size.height}:null}if(child.nodeType==="group"){let schGroup=db2.schematic_group.getWhere({source_group_id:sourceGroup?.source_group_id});if(schGroup?.width&&schGroup?.height)return{width:schGroup.width,height:schGroup.height};let groupComponents=db2.schematic_component.list({schematic_group_id:schGroup?.schematic_group_id}),minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0;for(let comp of groupComponents)if(comp.center&&comp.size){let halfWidth=comp.size.width/2,halfHeight=comp.size.height/2;minX=Math.min(minX,comp.center.x-halfWidth),maxX=Math.max(maxX,comp.center.x+halfWidth),minY=Math.min(minY,comp.center.y-halfHeight),maxY=Math.max(maxY,comp.center.y+halfHeight)}let groupWidth=maxX-minX,groupHeight=maxY-minY;return{width:groupWidth,height:groupHeight}}return null},Group_doInitialSchematicLayoutFlex=group=>{let{db:db2}=group.root,props=group._parsedProps,tree=getCircuitJsonTree(db2.toArray(),{source_group_id:group.source_group_id}),rawJustify=props.schJustifyContent??props.justifyContent,rawAlign=props.schAlignItems??props.alignItems,rawGap=props.schFlexGap??props.schGap??props.gap,direction2=props.schFlexDirection??"row",justifyContent={start:"flex-start",end:"flex-end","flex-start":"flex-start","flex-end":"flex-end",stretch:"space-between","space-between":"space-between","space-around":"space-around","space-evenly":"space-evenly",center:"center"}[rawJustify??"space-between"],alignItems={start:"flex-start",end:"flex-end","flex-start":"flex-start","flex-end":"flex-end",stretch:"stretch",center:"center"}[rawAlign??"center"];if(!justifyContent)throw new Error(`Invalid justifyContent value: "${rawJustify}"`);if(!alignItems)throw new Error(`Invalid alignItems value: "${rawAlign}"`);let rowGap=0,columnGap=0;typeof rawGap=="object"?(rowGap=rawGap.y??0,columnGap=rawGap.x??0):typeof rawGap=="number"?(rowGap=rawGap,columnGap=rawGap):typeof rawGap=="string"&&(rowGap=length.parse(rawGap),columnGap=length.parse(rawGap));let minFlexContainer,width=props.width??props.schWidth??void 0,height=props.height??props.schHeight??void 0;(width===void 0||height===void 0)&&(minFlexContainer=getMinimumFlexContainer(tree.childNodes.map(child=>getSizeOfTreeNodeChild(db2,child)).filter(size3=>size3!==null),{alignItems,justifyContent,direction:direction2,rowGap,columnGap}),width=minFlexContainer.width,height=minFlexContainer.height);let flexBox=new RootFlexBox(width,height,{alignItems,justifyContent,direction:direction2,rowGap,columnGap});for(let child of tree.childNodes){let size3=getSizeOfTreeNodeChild(db2,child);flexBox.addChild({metadata:child,width:size3?.width??0,height:size3?.height??0,flexBasis:size3?direction2==="row"?size3.width:size3.height:void 0})}flexBox.build();let bounds={minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0,width:0,height:0};for(let child of flexBox.children)bounds.minX=Math.min(bounds.minX,child.position.x),bounds.minY=Math.min(bounds.minY,child.position.y),bounds.maxX=Math.max(bounds.maxX,child.position.x+child.size.width),bounds.maxY=Math.max(bounds.maxY,child.position.y+child.size.height);bounds.width=bounds.maxX-bounds.minX,bounds.height=bounds.maxY-bounds.minY;let offset={x:-(bounds.maxX+bounds.minX)/2,y:-(bounds.maxY+bounds.minY)/2},allCircuitJson=db2.toArray();for(let child of flexBox.children){let{sourceComponent,sourceGroup}=child.metadata;if(sourceComponent){let schComponent=db2.schematic_component.getWhere({source_component_id:sourceComponent.source_component_id});if(!schComponent)continue;repositionSchematicComponentTo(allCircuitJson,schComponent.schematic_component_id,{x:child.position.x+child.size.width/2+offset.x,y:child.position.y+child.size.height/2+offset.y})}if(sourceGroup){if(!db2.schematic_group.getWhere({source_group_id:sourceGroup.source_group_id}))continue;repositionSchematicGroupTo(allCircuitJson,sourceGroup.source_group_id,{x:child.position.x+child.size.width/2+offset.x,y:child.position.y+child.size.height/2+offset.y})}}group.schematic_group_id&&db2.schematic_group.update(group.schematic_group_id,{width:bounds.width,height:bounds.height})};function updateSchematicPrimitivesForLayoutShift({db:db2,schematicComponentId,deltaX,deltaY}){let rects=db2.schematic_rect.list({schematic_component_id:schematicComponentId});for(let rect of rects)rect.center.x+=deltaX,rect.center.y+=deltaY;let lines=db2.schematic_line.list({schematic_component_id:schematicComponentId});for(let line2 of lines)line2.x1+=deltaX,line2.y1+=deltaY,line2.x2+=deltaX,line2.y2+=deltaY;let circles=db2.schematic_circle.list({schematic_component_id:schematicComponentId});for(let circle2 of circles)circle2.center.x+=deltaX,circle2.center.y+=deltaY;let arcs=db2.schematic_arc.list({schematic_component_id:schematicComponentId});for(let arc2 of arcs)arc2.center.x+=deltaX,arc2.center.y+=deltaY;let paths=db2.schematic_path.list({schematic_component_id:schematicComponentId});for(let path of paths)for(let point62 of path.points)point62.x+=deltaX,point62.y+=deltaY}function Group_doInitialSchematicLayoutGrid(group){let{db:db2}=group.root,props=group._parsedProps,schematicChildren=group.children.filter(child=>{let isExplicitlyPositioned=child._parsedProps?.schX!==void 0||child._parsedProps?.schY!==void 0;return child.schematic_component_id&&!isExplicitlyPositioned});if(schematicChildren.length===0)return;let maxCellWidth=0,maxCellHeight=0;for(let child of schematicChildren){let schComp=db2.schematic_component.get(child.schematic_component_id);schComp?.size&&(maxCellWidth=Math.max(maxCellWidth,schComp.size.width),maxCellHeight=Math.max(maxCellHeight,schComp.size.height))}maxCellWidth===0&&schematicChildren.length>0&&(maxCellWidth=1),maxCellHeight===0&&schematicChildren.length>0&&(maxCellHeight=1);let gridColsOption=props.gridCols,gridRowsOption,gridGapOption=props.gridGap,gridRowGapOption=props.gridRowGap,gridColumnGapOption=props.gridColumnGap;props.schLayout?.grid&&(gridColsOption=props.schLayout.grid.cols??gridColsOption,gridRowsOption=props.schLayout.grid.rows,gridGapOption=props.schLayout.gridGap??gridGapOption,gridRowGapOption=props.schLayout.gridRowGap??gridRowGapOption,gridColumnGapOption=props.schLayout.gridColumnGap??gridColumnGapOption);let numCols,numRows;gridColsOption!==void 0&&gridRowsOption!==void 0?(numCols=gridColsOption,numRows=gridRowsOption):gridColsOption!==void 0?(numCols=gridColsOption,numRows=Math.ceil(schematicChildren.length/numCols)):gridRowsOption!==void 0?(numRows=gridRowsOption,numCols=Math.ceil(schematicChildren.length/numRows)):(numCols=Math.ceil(Math.sqrt(schematicChildren.length)),numRows=Math.ceil(schematicChildren.length/numCols)),numCols===0&&schematicChildren.length>0&&(numCols=1),numRows===0&&schematicChildren.length>0&&(numRows=schematicChildren.length);let gridGapX,gridGapY,parseGap=val=>{if(val!==void 0)return typeof val=="number"?val:length.parse(val)};if(gridRowGapOption!==void 0||gridColumnGapOption!==void 0){let fallbackX=typeof gridGapOption=="object"&&gridGapOption!==null?gridGapOption.x:gridGapOption,fallbackY=typeof gridGapOption=="object"&&gridGapOption!==null?gridGapOption.y:gridGapOption;gridGapX=parseGap(gridColumnGapOption??fallbackX)??1,gridGapY=parseGap(gridRowGapOption??fallbackY)??1}else if(typeof gridGapOption=="number")gridGapX=gridGapOption,gridGapY=gridGapOption;else if(typeof gridGapOption=="string"){let parsed=length.parse(gridGapOption);gridGapX=parsed,gridGapY=parsed}else if(typeof gridGapOption=="object"&&gridGapOption!==null){let xRaw=gridGapOption.x,yRaw=gridGapOption.y;gridGapX=typeof xRaw=="number"?xRaw:length.parse(xRaw??"0mm"),gridGapY=typeof yRaw=="number"?yRaw:length.parse(yRaw??"0mm")}else gridGapX=1,gridGapY=1;let totalGridWidth=numCols*maxCellWidth+Math.max(0,numCols-1)*gridGapX,totalGridHeight=numRows*maxCellHeight+Math.max(0,numRows-1)*gridGapY,groupCenter=group._getGlobalSchematicPositionBeforeLayout(),firstCellCenterX=groupCenter.x-totalGridWidth/2+maxCellWidth/2,firstCellCenterY=groupCenter.y+totalGridHeight/2-maxCellHeight/2;for(let i3=0;i3<schematicChildren.length;i3++){let child=schematicChildren[i3];if(!child.schematic_component_id)continue;let row=Math.floor(i3/numCols),col=i3%numCols;if(row>=numRows||col>=numCols){console.warn(`Schematic grid layout: Child ${child.getString()} at index ${i3} (row ${row}, col ${col}) exceeds specified grid dimensions (${numRows}x${numCols}). Skipping placement.`);continue}let targetCellCenterX=firstCellCenterX+col*(maxCellWidth+gridGapX),targetCellCenterY=firstCellCenterY-row*(maxCellHeight+gridGapY),schComp=db2.schematic_component.get(child.schematic_component_id);if(schComp){let oldChildCenter=schComp.center,newChildCenter={x:targetCellCenterX,y:targetCellCenterY};db2.schematic_component.update(child.schematic_component_id,{center:newChildCenter});let deltaX=newChildCenter.x-oldChildCenter.x,deltaY=newChildCenter.y-oldChildCenter.y,schPorts=db2.schematic_port.list({schematic_component_id:child.schematic_component_id});for(let port of schPorts)db2.schematic_port.update(port.schematic_port_id,{center:{x:port.center.x+deltaX,y:port.center.y+deltaY}});let schTexts=db2.schematic_text.list({schematic_component_id:child.schematic_component_id});for(let text of schTexts)db2.schematic_text.update(text.schematic_text_id,{position:{x:text.position.x+deltaX,y:text.position.y+deltaY}});updateSchematicPrimitivesForLayoutShift({db:db2,schematicComponentId:child.schematic_component_id,deltaX,deltaY})}}group.schematic_group_id&&db2.schematic_group.update(group.schematic_group_id,{width:totalGridWidth,height:totalGridHeight,center:groupCenter})}var debug52=(0,import_debug13.default)("Group_doInitialSchematicLayoutMatchAdapt");function Group_doInitialSchematicLayoutMatchAdapt(group){let{db:db2}=group.root,subtreeCircuitJson=buildSubtree(db2.toArray(),{source_group_id:group.source_group_id}),bpcGraphBeforeGeneratedNetLabels=convertCircuitJsonToBpc(subtreeCircuitJson);debug52.enabled&&global?.debugGraphics&&global.debugGraphics?.push(getGraphicsForBpcGraph(bpcGraphBeforeGeneratedNetLabels,{title:`floatingBpcGraph-${group.name}`}));let floatingGraph=convertCircuitJsonToBpc(subtreeCircuitJson),floatingGraphNoNotConnected={boxes:floatingGraph.boxes,pins:floatingGraph.pins.map(p4=>({...p4,color:p4.color.replace("not_connected","normal")}))},{result:laidOutBpcGraph}=layoutSchematicGraphVariants([{variantName:"default",floatingGraph},{variantName:"noNotConnected",floatingGraph:floatingGraphNoNotConnected}],{singletonKeys:["vcc/2","gnd/2"],centerPinColors:["netlabel_center","component_center"],floatingBoxIdsWithMutablePinOffsets:new Set(floatingGraph.boxes.filter(box2=>floatingGraph.pins.filter(p4=>p4.boxId===box2.boxId).filter(bp3=>!bp3.color.includes("center")).length<=2).map(b3=>b3.boxId)),corpus:{}});debug52.enabled&&global?.debugGraphics&&global.debugGraphics?.push(getGraphicsForBpcGraph(laidOutBpcGraph,{title:`laidOutBpcGraph-${group.name}`}));let groupOffset=group._getGlobalSchematicPositionBeforeLayout();for(let box2 of laidOutBpcGraph.boxes){if(!box2.center)continue;let schematic_component22=db2.schematic_component.get(box2.boxId);if(schematic_component22){let newCenter={x:box2.center.x+groupOffset.x,y:box2.center.y+groupOffset.y},ports=db2.schematic_port.list({schematic_component_id:schematic_component22.schematic_component_id}),texts=db2.schematic_text.list({schematic_component_id:schematic_component22.schematic_component_id}),positionDelta={x:newCenter.x-schematic_component22.center.x,y:newCenter.y-schematic_component22.center.y};for(let port of ports)port.center.x+=positionDelta.x,port.center.y+=positionDelta.y;for(let text of texts)text.position.x+=positionDelta.x,text.position.y+=positionDelta.y;updateSchematicPrimitivesForLayoutShift({db:db2,schematicComponentId:schematic_component22.schematic_component_id,deltaX:positionDelta.x,deltaY:positionDelta.y}),schematic_component22.center=newCenter;continue}let schematic_net_label3=db2.schematic_net_label.get(box2.boxId);if(schematic_net_label3){let pin=laidOutBpcGraph.pins.find(p4=>p4.boxId===box2.boxId&&p4.color==="netlabel_center");if(!pin)throw new Error(`No pin found for net label: ${box2.boxId}`);let finalCenter={x:box2.center.x+groupOffset.x,y:box2.center.y+groupOffset.y};schematic_net_label3.center=finalCenter,schematic_net_label3.anchor_position={x:finalCenter.x+pin.offset.x,y:finalCenter.y+pin.offset.y};continue}console.error(`No schematic element found for box: ${box2.boxId}. This is a bug in the matchAdapt binding with @tscircuit/core`)}}var debug62=(0,import_debug14.default)("Group_doInitialSchematicLayoutMatchpack");function facingDirectionToSide(facingDirection){switch(facingDirection){case"up":return"y+";case"down":return"y-";case"left":return"x-";case"right":return"x+";default:return"y+"}}function rotateDirection2(direction2,degrees){let directions=["right","up","left","down"],currentIndex=directions.indexOf(direction2);if(currentIndex===-1)return direction2;let steps=Math.round(degrees/90),newIndex=(currentIndex+steps)%4;return directions[newIndex<0?newIndex+4:newIndex]}function isTreeChildExplicitlyPositioned(treeChild,group){if(treeChild.nodeType==="component"&&treeChild.sourceComponent){let component=group.children.find(groupChild=>groupChild.source_component_id===treeChild.sourceComponent?.source_component_id);return component?._parsedProps?.schX!==void 0||component?._parsedProps?.schY!==void 0}if(treeChild.nodeType==="group"&&treeChild.sourceGroup){let nestedGroup=group.children.find(groupChild=>groupChild.source_group_id===treeChild.sourceGroup?.source_group_id);return nestedGroup?._parsedProps?.schX!==void 0||nestedGroup?._parsedProps?.schY!==void 0}return!1}function getTreeChildChipId(child,index){return child.nodeType==="component"&&child.sourceComponent?child.sourceComponent.name||`chip_${index}`:child.nodeType==="group"&&child.sourceGroup?child.sourceGroup.name||`group_${index}`:null}function convertTreeToInputProblem(tree,db2,group){let problem={chipMap:{},chipPinMap:{},netMap:{},pinStrongConnMap:{},netConnMap:{},chipGap:.6,decouplingCapsGap:.4,partitionGap:1.2};debug62(`[${group.name}] Processing ${tree.childNodes.length} child nodes for input problem`),tree.childNodes.forEach((child,index)=>{if(isTreeChildExplicitlyPositioned(child,group)){debug62(`[${group.name}] Skipping explicitly positioned child ${index} from matchpack`);return}if(debug62(`[${group.name}] Processing child ${index}: nodeType=${child.nodeType}`),child.nodeType==="component"?debug62(`[${group.name}] - Component: ${child.sourceComponent?.name}`):child.nodeType==="group"&&debug62(`[${group.name}] - Group: ${child.sourceGroup?.name}`),child.nodeType==="component"&&child.sourceComponent){let chipId=getTreeChildChipId(child,index),schematicComponent=db2.schematic_component.getWhere({source_component_id:child.sourceComponent.source_component_id});if(!schematicComponent)return;let component=group.children.find(groupChild=>groupChild.source_component_id===child.sourceComponent?.source_component_id),availableRotations=[0,90,180,270];component?._parsedProps?.schOrientation&&(availableRotations=[0]),component?._parsedProps?.schRotation!==void 0&&(availableRotations=[0]),component?._parsedProps?.facingDirection&&(availableRotations=[0]),component?._parsedProps?.schFacingDirection&&(availableRotations=[0]),component?.componentName==="Chip"&&(availableRotations=[0]);let marginLeft=component?._parsedProps?.schMarginLeft??component?._parsedProps?.schMarginX??0,marginRight=component?._parsedProps?.schMarginRight??component?._parsedProps?.schMarginX??0,marginTop=component?._parsedProps?.schMarginTop??component?._parsedProps?.schMarginY??0,marginBottom=component?._parsedProps?.schMarginBottom??component?._parsedProps?.schMarginY??0;component?.config.shouldRenderAsSchematicBox&&(marginTop+=.4,marginBottom+=.4);let marginXShift=(marginRight-marginLeft)/2,marginYShift=(marginTop-marginBottom)/2;problem.chipMap[chipId]={chipId,pins:[],size:{x:(schematicComponent.size?.width||1)+marginLeft+marginRight,y:(schematicComponent.size?.height||1)+marginTop+marginBottom},availableRotations};let ports=db2.schematic_port.list({schematic_component_id:schematicComponent.schematic_component_id});for(let port of ports){let sourcePort=db2.source_port.get(port.source_port_id);if(!sourcePort)continue;let pinId=`${chipId}.${sourcePort.pin_number||sourcePort.name||port.schematic_port_id}`;problem.chipMap[chipId].pins.push(pinId);let side=facingDirectionToSide(port.facing_direction);problem.chipPinMap[pinId]={pinId,offset:{x:(port.center?.x||0)-(schematicComponent.center.x||0)+marginXShift,y:(port.center?.y||0)-(schematicComponent.center.y||0)+marginYShift},side}}}else if(child.nodeType==="group"&&child.sourceGroup){let groupId=getTreeChildChipId(child,index);debug62(`[${group.name}] Processing nested group: ${groupId}`);let schematicGroup=db2.schematic_group?.getWhere?.({source_group_id:child.sourceGroup.source_group_id}),groupInstance=group.children.find(groupChild=>groupChild.source_group_id===child.sourceGroup?.source_group_id);if(debug62(`[${group.name}] Found schematic_group for ${groupId}:`,schematicGroup),schematicGroup){debug62(`[${group.name}] Treating group ${groupId} as composite chip`);let groupComponents=db2.schematic_component.list({schematic_group_id:schematicGroup.schematic_group_id});debug62(`[${group.name}] Group ${groupId} has ${groupComponents.length} components:`,groupComponents.map(c4=>c4.source_component_id));let minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0,hasValidBounds=!1;for(let comp of groupComponents)if(comp.center&&comp.size){hasValidBounds=!0;let halfWidth=comp.size.width/2,halfHeight=comp.size.height/2;minX=Math.min(minX,comp.center.x-halfWidth),maxX=Math.max(maxX,comp.center.x+halfWidth),minY=Math.min(minY,comp.center.y-halfHeight),maxY=Math.max(maxY,comp.center.y+halfHeight)}let marginLeft=groupInstance?._parsedProps?.schMarginLeft??groupInstance?._parsedProps?.schMarginX??0,marginRight=groupInstance?._parsedProps?.schMarginRight??groupInstance?._parsedProps?.schMarginX??0,marginTop=groupInstance?._parsedProps?.schMarginTop??groupInstance?._parsedProps?.schMarginY??0,marginBottom=groupInstance?._parsedProps?.schMarginBottom??groupInstance?._parsedProps?.schMarginY??0,marginXShift=(marginRight-marginLeft)/2,marginYShift=(marginTop-marginBottom)/2,groupWidth=(hasValidBounds?maxX-minX:2)+marginLeft+marginRight,groupHeight=(hasValidBounds?maxY-minY:2)+marginTop+marginBottom;debug62(`[${group.name}] Group ${groupId} computed size: ${groupWidth} x ${groupHeight}`);let groupPins=[];for(let comp of groupComponents){let ports=db2.schematic_port.list({schematic_component_id:comp.schematic_component_id});for(let port of ports){let sourcePort=db2.source_port.get(port.source_port_id);if(!sourcePort)continue;let pinId=`${groupId}.${sourcePort.pin_number||sourcePort.name||port.schematic_port_id}`;groupPins.push(pinId);let groupCenter=schematicGroup.center||{x:0,y:0},side=facingDirectionToSide(port.facing_direction);problem.chipPinMap[pinId]={pinId,offset:{x:(port.center?.x||0)-groupCenter.x+marginXShift,y:(port.center?.y||0)-groupCenter.y+marginYShift},side}}}debug62(`[${group.name}] Group ${groupId} has ${groupPins.length} pins:`,groupPins),problem.chipMap[groupId]={chipId:groupId,pins:groupPins,size:{x:groupWidth,y:groupHeight}},debug62(`[${group.name}] Added group ${groupId} to chipMap`)}else debug62(`[${group.name}] Warning: No schematic_group found for group ${groupId}`)}}),debug62(`[${group.name}] Creating connections using connectivity keys`);let connectivityGroups=new Map;for(let[chipId,chip]of Object.entries(problem.chipMap))for(let pinId of chip.pins){let pinNumber=pinId.split(".").pop(),treeNode=tree.childNodes.find(child=>getTreeChildChipId(child,tree.childNodes.indexOf(child))===chipId);if(treeNode?.nodeType==="group"&&treeNode.sourceGroup){let schematicGroup=db2.schematic_group?.getWhere?.({source_group_id:treeNode.sourceGroup.source_group_id});if(schematicGroup){let groupComponents=db2.schematic_component.list({schematic_group_id:schematicGroup.schematic_group_id});for(let comp of groupComponents){let sourcePorts=db2.source_port.list({source_component_id:comp.source_component_id});for(let sourcePort of sourcePorts){let portNumber=sourcePort.pin_number||sourcePort.name;if(String(portNumber)===String(pinNumber))if(sourcePort.subcircuit_connectivity_map_key){let connectivityKey=sourcePort.subcircuit_connectivity_map_key;connectivityGroups.has(connectivityKey)||connectivityGroups.set(connectivityKey,[]),connectivityGroups.get(connectivityKey).push(pinId),debug62(`[${group.name}] \u2713 Pin ${pinId} has connectivity key: ${connectivityKey}`)}else debug62(`[${group.name}] Pin ${pinId} has no connectivity key`)}}}}else if(treeNode?.nodeType==="component"&&treeNode.sourceComponent){let sourcePorts=db2.source_port.list({source_component_id:treeNode.sourceComponent.source_component_id});for(let sourcePort of sourcePorts){let portNumber=sourcePort.pin_number||sourcePort.name;if(String(portNumber)===String(pinNumber)&&sourcePort.subcircuit_connectivity_map_key){let connectivityKey=sourcePort.subcircuit_connectivity_map_key;connectivityGroups.has(connectivityKey)||connectivityGroups.set(connectivityKey,[]),connectivityGroups.get(connectivityKey).push(pinId),debug62(`[${group.name}] Pin ${pinId} has connectivity key: ${connectivityKey}`)}}}}debug62(`[${group.name}] Found ${connectivityGroups.size} connectivity groups:`,Array.from(connectivityGroups.entries()).map(([key,pins])=>({key,pins})));for(let[connectivityKey,pins]of connectivityGroups)if(pins.length>=2){let tracesWithThisKey=db2.source_trace.list().filter(trace=>trace.subcircuit_connectivity_map_key===connectivityKey),hasNetConnections=tracesWithThisKey.some(trace=>trace.connected_source_net_ids&&trace.connected_source_net_ids.length>0),hasDirectConnections=tracesWithThisKey.some(trace=>trace.connected_source_port_ids&&trace.connected_source_port_ids.length>=2);if(debug62(`[${group.name}] Connectivity ${connectivityKey}: hasNetConnections=${hasNetConnections}, hasDirectConnections=${hasDirectConnections}`),hasDirectConnections){for(let trace of tracesWithThisKey)if(trace.connected_source_port_ids&&trace.connected_source_port_ids.length>=2){let directlyConnectedPins=[];for(let portId of trace.connected_source_port_ids)for(let pinId of pins){let pinNumber=pinId.split(".").pop(),sourcePort=db2.source_port.get(portId);if(sourcePort&&String(sourcePort.pin_number||sourcePort.name)===String(pinNumber)){let chipId=pinId.split(".")[0],treeNode=tree.childNodes.find(child=>getTreeChildChipId(child,tree.childNodes.indexOf(child))===chipId);treeNode?.nodeType==="component"&&treeNode.sourceComponent&&db2.source_port.list({source_component_id:treeNode.sourceComponent.source_component_id}).some(p4=>p4.source_port_id===portId)&&directlyConnectedPins.push(pinId)}}for(let i3=0;i3<directlyConnectedPins.length;i3++)for(let j4=i3+1;j4<directlyConnectedPins.length;j4++){let pin1=directlyConnectedPins[i3],pin2=directlyConnectedPins[j4];problem.pinStrongConnMap[`${pin1}-${pin2}`]=!0,problem.pinStrongConnMap[`${pin2}-${pin1}`]=!0,debug62(`[${group.name}] Created strong connection: ${pin1} <-> ${pin2}`)}}}if(hasNetConnections){let source_net3=db2.source_net.getWhere({subcircuit_connectivity_map_key:connectivityKey}),isGround=source_net3?.is_ground??!1,isPositiveVoltageSource=source_net3?.is_power??!1;problem.netMap[connectivityKey]={netId:connectivityKey,isGround,isPositiveVoltageSource};for(let pinId of pins)problem.netConnMap[`${pinId}-${connectivityKey}`]=!0;debug62(`[${group.name}] Created net ${connectivityKey} with ${pins.length} pins:`,pins)}}return problem}function Group_doInitialSchematicLayoutMatchPack(group){let{db:db2}=group.root,tree=getCircuitJsonTree(db2.toArray(),{source_group_id:group.source_group_id});if(debug62(`[${group.name}] Starting matchpack layout with ${tree.childNodes.length} children`),debug62(`[${group.name}] Tree structure:`,JSON.stringify(tree,null,2)),tree.childNodes.length<=1){debug62(`[${group.name}] Only ${tree.childNodes.length} children, skipping layout`);return}debug62("Converting circuit tree to InputProblem...");let inputProblem=convertTreeToInputProblem(tree,db2,group);debug62.enabled&&group.root?.emit("debug:logOutput",{type:"debug:logOutput",name:`matchpack-input-problem-${group.name}`,content:JSON.stringify(inputProblem,null,2)});let solver=new LayoutPipelineSolver(inputProblem);if(debug62("Starting LayoutPipelineSolver..."),debug62.enabled&&global?.debugGraphics){let initialViz=solver.visualize();global.debugGraphics.push({...initialViz,title:`matchpack-initial-${group.name}`})}if(solver.solve(),debug62(`Solver completed in ${solver.iterations} iterations`),debug62(`Solved: ${solver.solved}, Failed: ${solver.failed}`),solver.failed)throw debug62(`Solver failed with error: ${solver.error}`),new Error(`Matchpack layout solver failed: ${solver.error}`);let outputLayout=solver.getOutputLayout();if(debug62("OutputLayout:",JSON.stringify(outputLayout,null,2)),debug62("Solver completed successfully:",!solver.failed),debug62.enabled&&global?.debugGraphics){let finalViz=solver.visualize();global.debugGraphics.push({...finalViz,title:`matchpack-final-${group.name}`})}let overlaps=solver.checkForOverlaps(outputLayout);if(overlaps.length>0){debug62(`Warning: Found ${overlaps.length} overlapping components:`);for(let overlap of overlaps)debug62(` ${overlap.chip1} overlaps ${overlap.chip2} (area: ${overlap.overlapArea})`)}let groupOffset=group._getGlobalSchematicPositionBeforeLayout();debug62(`Group offset: x=${groupOffset.x}, y=${groupOffset.y}`),debug62(`Applying layout results for ${Object.keys(outputLayout.chipPlacements).length} chip placements`);for(let[chipId,placement]of Object.entries(outputLayout.chipPlacements)){debug62(`Processing placement for chip: ${chipId} at (${placement.x}, ${placement.y})`);let treeNode=tree.childNodes.find(child=>{let expectedChipId=getTreeChildChipId(child,tree.childNodes.indexOf(child)),matches=expectedChipId===chipId;return debug62(` Checking child ${expectedChipId}: matches=${matches}`),matches});if(!treeNode){debug62(`Warning: No tree node found for chip: ${chipId}`),debug62("Available tree nodes:",tree.childNodes.map((child,idx)=>({type:child.nodeType,name:child.nodeType==="component"?child.sourceComponent?.name:child.sourceGroup?.name,expectedChipId:getTreeChildChipId(child,idx)})));continue}let newCenter={x:placement.x+groupOffset.x,y:placement.y+groupOffset.y};if(treeNode.nodeType==="component"&&treeNode.sourceComponent){let schematicComponent=db2.schematic_component.getWhere({source_component_id:treeNode.sourceComponent.source_component_id});if(schematicComponent){debug62(`Moving component ${chipId} to (${newCenter.x}, ${newCenter.y})`);let ports=db2.schematic_port.list({schematic_component_id:schematicComponent.schematic_component_id}),texts=db2.schematic_text.list({schematic_component_id:schematicComponent.schematic_component_id}),positionDelta={x:newCenter.x-schematicComponent.center.x,y:newCenter.y-schematicComponent.center.y};for(let port of ports)port.center.x+=positionDelta.x,port.center.y+=positionDelta.y;for(let text of texts)text.position.x+=positionDelta.x,text.position.y+=positionDelta.y;if(updateSchematicPrimitivesForLayoutShift({db:db2,schematicComponentId:schematicComponent.schematic_component_id,deltaX:positionDelta.x,deltaY:positionDelta.y}),schematicComponent.center=newCenter,placement.ccwRotationDegrees!==0){debug62(`Component ${chipId} has rotation: ${placement.ccwRotationDegrees}\xB0`);let normalizedRotation=(Math.round(placement.ccwRotationDegrees)%360+360)%360;if((normalizedRotation===90||normalizedRotation===270)&&schematicComponent.size){let prevWidth=schematicComponent.size.width;schematicComponent.size.width=schematicComponent.size.height,schematicComponent.size.height=prevWidth}let angleRad=placement.ccwRotationDegrees*Math.PI/180,cos6=Math.cos(angleRad),sin6=Math.sin(angleRad);for(let port of ports){let dx3=port.center.x-newCenter.x,dy3=port.center.y-newCenter.y,rotatedDx=dx3*cos6-dy3*sin6,rotatedDy=dx3*sin6+dy3*cos6;port.center.x=newCenter.x+rotatedDx,port.center.y=newCenter.y+rotatedDy;let originalDirection=port.facing_direction||"right";port.facing_direction=rotateDirection2(originalDirection,placement.ccwRotationDegrees),port.side_of_component=(port.facing_direction==="up"?"top":port.facing_direction==="down"?"bottom":port.facing_direction)||port.side_of_component}for(let text of texts){let dx3=text.position.x-newCenter.x,dy3=text.position.y-newCenter.y,rotatedDx=dx3*cos6-dy3*sin6,rotatedDy=dx3*sin6+dy3*cos6;text.position.x=newCenter.x+rotatedDx,text.position.y=newCenter.y+rotatedDy}if(schematicComponent.symbol_name){let schematicSymbolDirection=schematicComponent.symbol_name.match(/_(right|left|up|down)$/);schematicSymbolDirection&&(schematicComponent.symbol_name=schematicComponent.symbol_name.replace(schematicSymbolDirection[0],`_${rotateDirection2(schematicSymbolDirection[1],placement.ccwRotationDegrees)}`));let schematicSymbolOrientation=schematicComponent.symbol_name.match(/_(horz|vert)$/);if(schematicSymbolOrientation){let normalizedRotation2=(placement.ccwRotationDegrees%360+360)%360;(normalizedRotation2===90||normalizedRotation2===270)&&(schematicComponent.symbol_name=schematicComponent.symbol_name.replace(schematicSymbolOrientation[0],schematicSymbolOrientation[1]==="horz"?"_vert":"_horz"))}}}}}else if(treeNode.nodeType==="group"&&treeNode.sourceGroup){let schematicGroup=db2.schematic_group?.getWhere?.({source_group_id:treeNode.sourceGroup.source_group_id});if(schematicGroup){debug62(`Moving group ${chipId} to (${newCenter.x}, ${newCenter.y}) from (${schematicGroup.center?.x}, ${schematicGroup.center?.y})`);let groupComponents=db2.schematic_component.list({schematic_group_id:schematicGroup.schematic_group_id});debug62(`Group ${chipId} has ${groupComponents.length} components to move`);let oldCenter=schematicGroup.center||{x:0,y:0},positionDelta={x:newCenter.x-oldCenter.x,y:newCenter.y-oldCenter.y};debug62(`Position delta for group ${chipId}: (${positionDelta.x}, ${positionDelta.y})`);for(let component of groupComponents)if(component.center){let oldComponentCenter={...component.center};component.center.x+=positionDelta.x,component.center.y+=positionDelta.y,debug62(`Moved component ${component.source_component_id} from (${oldComponentCenter.x}, ${oldComponentCenter.y}) to (${component.center.x}, ${component.center.y})`);let ports=db2.schematic_port.list({schematic_component_id:component.schematic_component_id}),texts=db2.schematic_text.list({schematic_component_id:component.schematic_component_id});for(let port of ports)port.center&&(port.center.x+=positionDelta.x,port.center.y+=positionDelta.y);for(let text of texts)text.position&&(text.position.x+=positionDelta.x,text.position.y+=positionDelta.y)}schematicGroup.center=newCenter,debug62(`Updated group ${chipId} center to (${newCenter.x}, ${newCenter.y})`)}}}debug62("Matchpack layout completed successfully")}var parsePinNumberFromPortName=name=>{if(!name)return null;let match2=name.match(/^pin(\d+)$/i)??name.match(/^(\d+)$/);if(!match2)return null;let pinNumber=Number(match2[1]);return Number.isFinite(pinNumber)&&pinNumber>0?pinNumber:null},getDirectGroupPorts=group=>group.children.filter(child=>child.componentName==="Port"),normalizeGroupSchematicBoxPorts=group=>{let{db:db2}=group.root,ports=getDirectGroupPorts(group);for(let port of ports){if(port._parsedProps.pinNumber!==void 0)continue;let pinNumber=parsePinNumberFromPortName(port._parsedProps.name);pinNumber!==null&&(port._parsedProps.pinNumber=pinNumber)}let usedPinNumbers=new Set(ports.map(port=>port._parsedProps.pinNumber).filter(pinNumber=>pinNumber!==void 0)),nextPinNumber=1;for(let port of ports){if(port._parsedProps.pinNumber===void 0){for(;usedPinNumbers.has(nextPinNumber);)nextPinNumber++;port._parsedProps.pinNumber=nextPinNumber,usedPinNumbers.add(nextPinNumber)}port.source_port_id&&db2.source_port.update(port.source_port_id,{pin_number:port._parsedProps.pinNumber,port_hints:port.getNameAndAliases()})}},getGroupSchematicBoxPinLabels=group=>{let pinLabels={};for(let port of getDirectGroupPorts(group)){let pinNumber=port._parsedProps.pinNumber,name=port._parsedProps.name;pinNumber===void 0||!name||name===`pin${pinNumber}`||name===String(pinNumber)||(pinLabels[`pin${pinNumber}`]=name)}return pinLabels},Group_doInitialSchematicBoxComponentRender=group=>{if(group.root?.schematicDisabled)return;let{db:db2}=group.root,props=group._parsedProps;props.schPinSpacing!==void 0&&db2.source_property_ignored_warning.insert({source_component_id:group.source_group_id??"",property_name:"schPinSpacing",error_type:"source_property_ignored_warning",message:"schPinSpacing is deprecated and will be ignored. Pin spacing is always 0.2."}),normalizeGroupSchematicBoxPorts(group);let dimensions=group._getSchematicBoxDimensions();if(!dimensions)return;let center2=group._getGlobalSchematicPositionBeforeLayout(),size3=dimensions.getSize(),portLabels=group._getPinLabelsFromPorts(),schPortArrangement=group._getSchematicPortArrangement(),schematicComponent=db2.schematic_component.insert({center:center2,size:size3,source_group_id:group.source_group_id,schematic_group_id:group.schematic_group_id??void 0,subcircuit_id:group.subcircuit_id??group.getSubcircuit()?.subcircuit_id??void 0,is_schematic_group:!0,is_box_with_pins:!0,port_arrangement:underscorifyPortArrangement(schPortArrangement),pin_spacing:.2,pin_styles:underscorifyPinStyles(props.schPinStyle,portLabels),port_labels:portLabels});group.schematic_component_id=schematicComponent.schematic_component_id,group.schematic_group_id&&db2.schematic_group.update(group.schematic_group_id,{center:center2,width:size3.width,height:size3.height,schematic_component_ids:[schematicComponent.schematic_component_id]});let title=props.schTitle??props.name;title&&db2.schematic_text.insert({text:title,schematic_component_id:schematicComponent.schematic_component_id,anchor:"left",rotation:0,position:{x:center2.x-size3.width/2,y:center2.y+size3.height/2+.13},color:"#006464",font_size:.18})};function createSchematicTraceSolverInputProblem(group){let{db:db2}=group.root,sckToSourceNet=new Map,sckToUserNetId=new Map,allScks=new Set,displayLabelTraces=group.selectAll("trace").filter(t52=>t52._parsedProps?.schDisplayLabel),childGroups=group.selectAll("group"),allSchematicGroupIds=[group.schematic_group_id,...childGroups.map(a3=>a3.schematic_group_id)],schematicComponents=db2.schematic_component.list().filter(a3=>allSchematicGroupIds.includes(a3.schematic_group_id)),chips=[],pinIdToSchematicPortId=new Map,schematicPortIdToPinId=new Map;for(let schematicComponent of schematicComponents){let chipId=schematicComponent.schematic_component_id,pins=[],sourceComponent=db2.source_component.getWhere({source_component_id:schematicComponent.source_component_id}),schematicPorts=db2.schematic_port.list({schematic_component_id:schematicComponent.schematic_component_id});for(let schematicPort of schematicPorts){let pinId=`${sourceComponent?.name??schematicComponent.schematic_component_id}.${schematicPort.pin_number}`;pinIdToSchematicPortId.set(pinId,schematicPort.schematic_port_id),schematicPortIdToPinId.set(schematicPort.schematic_port_id,pinId)}for(let schematicPort of schematicPorts){let pinId=schematicPortIdToPinId.get(schematicPort.schematic_port_id);pins.push({pinId,x:schematicPort.center.x,y:schematicPort.center.y})}chips.push({chipId,center:schematicComponent.center,width:schematicComponent.size.width,height:schematicComponent.size.height,pins})}let allSourceAndSchematicPortIdsInScope=new Set,schPortIdToSourcePortId=new Map,sourcePortIdToSchPortId=new Map,userNetIdToSck=new Map;for(let sc2 of schematicComponents){let ports=db2.schematic_port.list({schematic_component_id:sc2.schematic_component_id});for(let sp3 of ports)allSourceAndSchematicPortIdsInScope.add(sp3.schematic_port_id),sp3.source_port_id&&(schPortIdToSourcePortId.set(sp3.schematic_port_id,sp3.source_port_id),sourcePortIdToSchPortId.set(sp3.source_port_id,sp3.schematic_port_id))}let allowedSubcircuitIds=new Set;group.subcircuit_id&&allowedSubcircuitIds.add(group.subcircuit_id);for(let cg3 of childGroups)cg3.subcircuit_id&&allowedSubcircuitIds.add(cg3.subcircuit_id);let externalNetIds=db2.source_trace.list().filter(st3=>{if(st3.subcircuit_id===group.subcircuit_id)return!0;for(let source_port_id of st3.connected_source_port_ids)if(sourcePortIdToSchPortId.has(source_port_id))return!0;return!1}).flatMap(st3=>st3.connected_source_net_ids);for(let netId of externalNetIds){let net=db2.source_net.get(netId);net?.subcircuit_id&&allowedSubcircuitIds.add(net.subcircuit_id)}let directConnections=[],pairKeyToSourceTraceId=new Map;for(let st3 of db2.source_trace.list()){if(st3.subcircuit_id&&!allowedSubcircuitIds.has(st3.subcircuit_id))continue;let connected=(st3.connected_source_port_ids??[]).map(srcId=>sourcePortIdToSchPortId.get(srcId)).filter(sourcePortId=>!!sourcePortId&&allSourceAndSchematicPortIdsInScope.has(sourcePortId));if(connected.length>=2){let[a3,b3]=connected.slice(0,2),pairKey=[a3,b3].sort().join("::");if(!pairKeyToSourceTraceId.has(pairKey)){pairKeyToSourceTraceId.set(pairKey,st3.source_trace_id);let userNetId=st3.display_name??st3.source_trace_id;st3.subcircuit_connectivity_map_key&&(allScks.add(st3.subcircuit_connectivity_map_key),userNetIdToSck.set(userNetId,st3.subcircuit_connectivity_map_key),sckToUserNetId.set(st3.subcircuit_connectivity_map_key,userNetId)),directConnections.push({pinIds:[a3,b3].map(id2=>schematicPortIdToPinId.get(id2)),netId:userNetId})}}}let netConnections=[];for(let net of db2.source_net.list().filter(n4=>!n4.subcircuit_id||allowedSubcircuitIds.has(n4.subcircuit_id)))net.subcircuit_connectivity_map_key&&(allScks.add(net.subcircuit_connectivity_map_key),sckToSourceNet.set(net.subcircuit_connectivity_map_key,net));let sckToPinIds=new Map;for(let[schId,srcPortId]of schPortIdToSourcePortId){let sp3=db2.source_port.get(srcPortId);if(!sp3?.subcircuit_connectivity_map_key)continue;let sck=sp3.subcircuit_connectivity_map_key;allScks.add(sck),sckToPinIds.has(sck)||sckToPinIds.set(sck,[]),sckToPinIds.get(sck).push(schId)}for(let[subcircuitConnectivityKey,schematicPortIds]of sckToPinIds){let sourceNet=sckToSourceNet.get(subcircuitConnectivityKey);if(sourceNet&&schematicPortIds.length>=2){let userNetId=String(sourceNet.name||sourceNet.source_net_id||subcircuitConnectivityKey);userNetIdToSck.set(userNetId,subcircuitConnectivityKey),sckToUserNetId.set(subcircuitConnectivityKey,userNetId);let charWidth=.1*(.18/.18),netLabelWidth=Number((String(userNetId).length*charWidth).toFixed(2));netConnections.push({netId:userNetId,pinIds:schematicPortIds.map(portId=>schematicPortIdToPinId.get(portId)),netLabelWidth})}}let availableNetLabelOrientations=(()=>{let netToAllowedOrientations={},presentNetIds=new Set(netConnections.map(nc3=>nc3.netId));for(let net of db2.source_net.list().filter(n4=>!n4.subcircuit_id||allowedSubcircuitIds.has(n4.subcircuit_id)))net.name&&presentNetIds.has(net.name)&&(net.is_ground||net.name.toLowerCase().startsWith("gnd")?netToAllowedOrientations[net.name]=["y-"]:net.is_power||net.name.toLowerCase().startsWith("v")?netToAllowedOrientations[net.name]=["y+"]:netToAllowedOrientations[net.name]=["x-","x+"]);return netToAllowedOrientations})();return{inputProblem:{chips,directConnections,netConnections,availableNetLabelOrientations,maxMspPairDistance:group._parsedProps.schMaxTraceDistance??2.4},pinIdToSchematicPortId,pairKeyToSourceTraceId,sckToSourceNet,sckToUserNetId,userNetIdToSck,allSourceAndSchematicPortIdsInScope,schPortIdToSourcePortId,displayLabelTraces,allScks}}var TOL=1e-6;function isHorizontalEdge(edge){let dx3=Math.abs(edge.to.x-edge.from.x),dy3=Math.abs(edge.to.y-edge.from.y);return dx3>=dy3}function length6(a3,b3){return Math.hypot(b3.x-a3.x,b3.y-a3.y)}function pointAt(a3,b3,t52){return{x:a3.x+(b3.x-a3.x)*t52,y:a3.y+(b3.y-a3.y)*t52}}function paramAlong(a3,b3,p4){let L3=length6(a3,b3);if(L3<TOL)return 0;let t52=((p4.x-a3.x)*(b3.x-a3.x)+(p4.y-a3.y)*(b3.y-a3.y))/((b3.x-a3.x)*(b3.x-a3.x)+(b3.y-a3.y)*(b3.y-a3.y));return Math.max(0,Math.min(1,t52))*L3}function cross3(ax3,ay3,bx3,by3){return ax3*by3-ay3*bx3}function segmentIntersection(p12,p22,q12,q22){let r5={x:p22.x-p12.x,y:p22.y-p12.y},s3={x:q22.x-q12.x,y:q22.y-q12.y},rxs=cross3(r5.x,r5.y,s3.x,s3.y),q_p={x:q12.x-p12.x,y:q12.y-p12.y},q_pxr=cross3(q_p.x,q_p.y,r5.x,r5.y);if(Math.abs(rxs)<TOL&&Math.abs(q_pxr)<TOL||Math.abs(rxs)<TOL&&Math.abs(q_pxr)>=TOL)return null;let t52=cross3(q_p.x,q_p.y,s3.x,s3.y)/rxs,u5=cross3(q_p.x,q_p.y,r5.x,r5.y)/rxs;return t52<-TOL||t52>1+TOL||u5<-TOL||u5>1+TOL?null:{x:p12.x+t52*r5.x,y:p12.y+t52*r5.y}}function mergeIntervals(intervals,tol=TOL){if(intervals.length===0)return intervals;intervals.sort((a3,b3)=>a3.start-b3.start);let merged=[],cur={...intervals[0]};for(let i3=1;i3<intervals.length;i3++){let nxt=intervals[i3];nxt.start<=cur.end+tol?cur.end=Math.max(cur.end,nxt.end):(merged.push(cur),cur={...nxt})}return merged.push(cur),merged}function splitEdgeByCrossings(edge,crossingDistances,crossLen){let L3=length6(edge.from,edge.to);if(L3<TOL||crossingDistances.length===0)return[edge];let half=crossLen/2,rawIntervals=crossingDistances.map(d4=>({start:Math.max(0,d4-half),end:Math.min(L3,d4+half)})).filter(iv2=>iv2.end-iv2.start>TOL),intervals=mergeIntervals(rawIntervals),result=[],cursor=0,dir2={x:edge.to.x-edge.from.x,y:edge.to.y-edge.from.y},addSeg=(d02,d12,isCrossing)=>{if(d12-d02<=TOL)return;let t02=d02/L3,t110=d12/L3;result.push({from:pointAt(edge.from,edge.to,t02),to:pointAt(edge.from,edge.to,t110),...isCrossing?{is_crossing:!0}:{}})};for(let iv2 of intervals)iv2.start-cursor>TOL&&addSeg(cursor,iv2.start,!1),addSeg(iv2.start,iv2.end,!0),cursor=iv2.end;return L3-cursor>TOL&&addSeg(cursor,L3,!1),result.length>0?result:[edge]}function computeCrossings(traces,opts={}){let crossLen=opts.crossSegmentLength??.075,tol=opts.tolerance??TOL,crossingsByEdge=new Map,keyOf=ref=>`${ref.traceIdx}:${ref.edgeIdx}`,getEdge=ref=>traces[ref.traceIdx].edges[ref.edgeIdx];for(let ti3=0;ti3<traces.length;ti3++){let A4=traces[ti3];for(let ei3=0;ei3<A4.edges.length;ei3++){let eA2=A4.edges[ei3];for(let tj=ti3;tj<traces.length;tj++){let B4=traces[tj];for(let ej=tj===ti3?ei3+1:0;ej<B4.edges.length;ej++){let eB=B4.edges[ej],P4=segmentIntersection(eA2.from,eA2.to,eB.from,eB.to);if(!P4)continue;let LA2=length6(eA2.from,eA2.to),LB=length6(eB.from,eB.to);if(LA2<tol||LB<tol)continue;let dA2=paramAlong(eA2.from,eA2.to,P4),dB=paramAlong(eB.from,eB.to,P4),nearEndpointA=dA2<=tol||Math.abs(LA2-dA2)<=tol||Number.isNaN(dA2),nearEndpointB=dB<=tol||Math.abs(LB-dB)<=tol||Number.isNaN(dB);if(!nearEndpointA&&!nearEndpointB){let aIsHorizontal=isHorizontalEdge(eA2),bIsHorizontal=isHorizontalEdge(eB),assignToA;if(aIsHorizontal!==bIsHorizontal)assignToA=aIsHorizontal;else{let ax3=Math.abs(eA2.to.x-eA2.from.x),ay3=Math.abs(eA2.to.y-eA2.from.y),bx3=Math.abs(eB.to.x-eB.from.x),by3=Math.abs(eB.to.y-eB.from.y),aScore=ax3-ay3,bScore=bx3-by3;assignToA=aScore===bScore?!0:aScore>bScore}let chosenKey=keyOf({traceIdx:assignToA?ti3:tj,edgeIdx:assignToA?ei3:ej}),chosenList=crossingsByEdge.get(chosenKey)??[];chosenList.push(assignToA?dA2:dB),crossingsByEdge.set(chosenKey,chosenList)}}}}}let out=traces.map(t52=>({source_trace_id:t52.source_trace_id,edges:[]}));for(let ti3=0;ti3<traces.length;ti3++){let trace=traces[ti3];for(let ei3=0;ei3<trace.edges.length;ei3++){let eRefKey=keyOf({traceIdx:ti3,edgeIdx:ei3}),splittingDistances=crossingsByEdge.get(eRefKey)??[];if(splittingDistances.length===0){out[ti3].edges.push(trace.edges[ei3]);continue}let uniqueSorted=Array.from(new Set(splittingDistances.map(d4=>Number(d4.toFixed(6))))).sort((a3,b3)=>a3-b3),split=splitEdgeByCrossings(trace.edges[ei3],uniqueSorted,crossLen);out[ti3].edges.push(...split)}}return out}var TOL2=1e-6;function nearlyEqual(a3,b3,tol=TOL2){return Math.abs(a3-b3)<=tol}function pointEq(a3,b3,tol=TOL2){return nearlyEqual(a3.x,b3.x,tol)&&nearlyEqual(a3.y,b3.y,tol)}function onSegment4(p4,a3,b3,tol=TOL2){let minX=Math.min(a3.x,b3.x)-tol,maxX=Math.max(a3.x,b3.x)+tol,minY=Math.min(a3.y,b3.y)-tol,maxY=Math.max(a3.y,b3.y)+tol;return p4.x<minX||p4.x>maxX||p4.y<minY||p4.y>maxY?!1:Math.abs((b3.x-a3.x)*(p4.y-a3.y)-(b3.y-a3.y)*(p4.x-a3.x))<=tol}function dedupePoints(points,tol=TOL2){let map=new Map;for(let p4 of points){let key=`${p4.x.toFixed(6)},${p4.y.toFixed(6)}`;map.has(key)||map.set(key,p4)}return Array.from(map.values())}function edgeVec(e5){return{x:e5.to.x-e5.from.x,y:e5.to.y-e5.from.y}}function isParallel(e12,e22,tol=TOL2){let v12=edgeVec(e12),v22=edgeVec(e22),L12=Math.hypot(v12.x,v12.y),L22=Math.hypot(v22.x,v22.y);if(L12<tol||L22<tol)return!0;let cross22=v12.x*v22.y-v12.y*v22.x;return Math.abs(cross22)<=tol*L12*L22}function incidentEdgesAtPoint(trace,p4,tol=TOL2){return trace.edges.filter(e5=>pointEq(e5.from,p4,tol)||pointEq(e5.to,p4,tol))}function nearestEndpointOnTrace(trace,p4,tol=TOL2){for(let e5 of trace.edges){if(pointEq(e5.from,p4,tol))return e5.from;if(pointEq(e5.to,p4,tol))return e5.to}return null}function edgeDirectionFromPoint(e5,p4,tol=TOL2){let other=pointEq(e5.from,p4,tol)||nearlyEqual(e5.from.x,p4.x,tol)&&nearlyEqual(e5.from.y,p4.y,tol)?e5.to:e5.from,dx3=other.x-p4.x,dy3=other.y-p4.y;return Math.abs(dx3)<tol&&Math.abs(dy3)<tol?null:Math.abs(dx3)>=Math.abs(dy3)?dx3>=0?"right":"left":dy3>=0?"up":"down"}function getCornerOrientationAtPoint(trace,p4,tol=TOL2){let incident=incidentEdgesAtPoint(trace,p4,tol);if(incident.length<2)return null;let dirs=incident.map(e5=>edgeDirectionFromPoint(e5,p4,tol)),hasUp=dirs.includes("up"),hasDown=dirs.includes("down"),hasLeft=dirs.includes("left"),hasRight=dirs.includes("right"),vertical=hasUp?"up":hasDown?"down":null,horizontal=hasRight?"right":hasLeft?"left":null;return vertical&&horizontal?`${vertical}-${horizontal}`:null}function computeJunctions(traces,opts={}){let tol=opts.tolerance??TOL2,result={};for(let t52 of traces)result[t52.source_trace_id]=[];let endpointsByTrace=traces.map(t52=>{let pts=[];for(let e5 of t52.edges)pts.push(e5.from,e5.to);return dedupePoints(pts,tol)});for(let i3=0;i3<traces.length;i3++){let A4=traces[i3],AEnds=endpointsByTrace[i3];for(let j4=i3+1;j4<traces.length;j4++){let B4=traces[j4],BEnds=endpointsByTrace[j4];for(let pa3 of AEnds)for(let pb2 of BEnds)if(pointEq(pa3,pb2,tol)){let aEdgesAtP=incidentEdgesAtPoint(A4,pa3,tol),bEdgesAtP=incidentEdgesAtPoint(B4,pb2,tol),hasCorner=aEdgesAtP.some(eA2=>bEdgesAtP.some(eB=>!isParallel(eA2,eB,tol))),aCorner=getCornerOrientationAtPoint(A4,pa3,tol),bCorner=getCornerOrientationAtPoint(B4,pb2,tol);hasCorner&&!(aCorner!==null&&bCorner!==null&&aCorner===bCorner)&&(result[A4.source_trace_id].push(pa3),A4.source_trace_id!==B4.source_trace_id&&result[B4.source_trace_id].push(pb2))}for(let pa3 of AEnds)for(let eB of B4.edges)if(onSegment4(pa3,eB.from,eB.to,tol)){let hasCorner=incidentEdgesAtPoint(A4,pa3,tol).some(eA2=>!isParallel(eA2,eB,tol)),aCorner=getCornerOrientationAtPoint(A4,pa3,tol),bEndpointNearPa=nearestEndpointOnTrace(B4,pa3,tol*1e3),bCorner=bEndpointNearPa?getCornerOrientationAtPoint(B4,bEndpointNearPa,tol):null;hasCorner&&!(aCorner!==null&&bCorner!==null&&aCorner===bCorner)&&(result[A4.source_trace_id].push(pa3),A4.source_trace_id!==B4.source_trace_id&&result[B4.source_trace_id].push(pa3))}for(let pb2 of BEnds)for(let eA2 of A4.edges)if(onSegment4(pb2,eA2.from,eA2.to,tol)){let hasCorner=incidentEdgesAtPoint(B4,pb2,tol).some(eB=>!isParallel(eA2,eB,tol)),bCorner=getCornerOrientationAtPoint(B4,pb2,tol),aEndpointNearPb=nearestEndpointOnTrace(A4,pb2,tol*1e3),aCorner=aEndpointNearPb?getCornerOrientationAtPoint(A4,aEndpointNearPb,tol):null;hasCorner&&!(aCorner!==null&&bCorner!==null&&aCorner===bCorner)&&(result[B4.source_trace_id].push(pb2),A4.source_trace_id!==B4.source_trace_id&&result[A4.source_trace_id].push(pb2))}}}for(let id2 of Object.keys(result))result[id2]=dedupePoints(result[id2],tol);return result}var debug7=(0,import_debug16.default)("Group_doInitialSchematicTraceRender");function applyTracesFromSolverOutput(args){let{group,solver,pinIdToSchematicPortId,userNetIdToSck}=args,{db:db2}=group.root,traces=solver.traceCleanupSolver?.getOutput().traces??solver.traceLabelOverlapAvoidanceSolver?.getOutput().traces??solver.schematicTraceLinesSolver?.solvedTracePaths,pendingTraces=[];debug7(`Traces inside SchematicTraceSolver output: ${(traces??[]).length}`);for(let solvedTracePath of traces??[]){let points=solvedTracePath?.tracePath;if(!Array.isArray(points)||points.length<2){debug7(`Skipping trace ${solvedTracePath?.pinIds.join(",")} because it has less than 2 points`);continue}let edges=[];for(let i3=0;i3<points.length-1;i3++)edges.push({from:{x:points[i3].x,y:points[i3].y},to:{x:points[i3+1].x,y:points[i3+1].y}});let source_trace_id=null,subcircuit_connectivity_map_key;if(Array.isArray(solvedTracePath?.pins)&&solvedTracePath.pins.length===2){let pA2=pinIdToSchematicPortId.get(solvedTracePath.pins[0]?.pinId),pB=pinIdToSchematicPortId.get(solvedTracePath.pins[1]?.pinId);if(pA2&&pB){for(let schPid of[pA2,pB])db2.schematic_port.get(schPid)&&db2.schematic_port.update(schPid,{is_connected:!0});subcircuit_connectivity_map_key=userNetIdToSck.get(String(solvedTracePath.userNetId))}}source_trace_id||(source_trace_id=`solver_${solvedTracePath?.mspPairId}`,subcircuit_connectivity_map_key=userNetIdToSck.get(String(solvedTracePath.userNetId))),pendingTraces.push({source_trace_id,edges,subcircuit_connectivity_map_key})}debug7(`Applying ${pendingTraces.length} traces from SchematicTraceSolver output`);let withCrossings=computeCrossings(pendingTraces.map(t52=>({source_trace_id:t52.source_trace_id,edges:t52.edges}))),junctionsById=computeJunctions(withCrossings);for(let t52 of withCrossings)db2.schematic_trace.insert({source_trace_id:t52.source_trace_id,edges:t52.edges,junctions:junctionsById[t52.source_trace_id]??[],subcircuit_connectivity_map_key:pendingTraces.find(p4=>p4.source_trace_id===t52.source_trace_id)?.subcircuit_connectivity_map_key})}var oppositeSide2=input2=>{switch(input2){case"x+":return"left";case"x-":return"right";case"y+":return"bottom";case"y-":return"top";case"left":return"right";case"top":return"bottom";case"right":return"left";case"bottom":return"top"}},getNetNameFromPorts=ports=>{for(let port of ports){let traces=port._getDirectlyConnectedTraces();for(let trace of traces){let displayLabel=trace._parsedProps.schDisplayLabel;if(displayLabel)return{name:displayLabel,wasAssignedDisplayLabel:!0}}}return{name:ports.map(p4=>p4._getNetLabelText()).join("/"),wasAssignedDisplayLabel:!1}},debug8=(0,import_debug17.default)("Group_doInitialSchematicTraceRender");function applyNetLabelPlacements(args){let{group,solver,sckToSourceNet,allScks,allSourceAndSchematicPortIdsInScope,schPortIdToSourcePortId,userNetIdToSck,pinIdToSchematicPortId,schematicPortIdsWithPreExistingNetLabels,schematicPortIdsWithRoutedTraces}=args,{db:db2}=group.root,netLabelPlacements=solver.netLabelPlacementSolver?.netLabelPlacements??solver.traceLabelOverlapAvoidanceSolver?.getOutput().netLabelPlacements??[],globalConnMap=solver.mspConnectionPairSolver.globalConnMap;for(let placement of netLabelPlacements){debug8(`processing placement: ${placement.netId}`);let placementUserNetId=globalConnMap.getIdsConnectedToNet(placement.globalConnNetId).find(id2=>userNetIdToSck.get(id2)),placementSck=userNetIdToSck.get(placementUserNetId),anchor_position=placement.anchorPoint,orientation4=placement.orientation,anchor_side=oppositeSide2(orientation4),sourceNet=placementSck?sckToSourceNet.get(placementSck):void 0,schPortIds=placement.pinIds.map(pinId=>pinIdToSchematicPortId.get(pinId));if(schPortIds.some(schPortId=>schematicPortIdsWithPreExistingNetLabels.has(schPortId))){debug8(`skipping net label placement for "${placement.netId}" REASON:schematic port has pre-existing net label`);continue}if(sourceNet){let text2=sourceNet.name,center22=computeSchematicNetLabelCenter({anchor_position,anchor_side,text:text2});db2.schematic_net_label.insert({text:text2,anchor_position,center:center22,anchor_side,...sourceNet?.source_net_id?{source_net_id:sourceNet.source_net_id}:{}});continue}let ports=group.selectAll("port").filter(p4=>p4._getSubcircuitConnectivityKey()===placementSck),{name:text,wasAssignedDisplayLabel}=getNetNameFromPorts(ports);if(!wasAssignedDisplayLabel&&schPortIds.some(schPortId=>schematicPortIdsWithRoutedTraces.has(schPortId))){debug8(`skipping net label placement for "${placement.netId}" REASON:schematic port has routed traces and no display label`);continue}let center2=computeSchematicNetLabelCenter({anchor_position,anchor_side,text});db2.schematic_net_label.insert({text,anchor_position,center:center2,anchor_side})}}var insertNetLabelsForPortsMissingTrace=({allSourceAndSchematicPortIdsInScope,group,schPortIdToSourcePortId,sckToSourceNet:connKeyToNet,pinIdToSchematicPortId,schematicPortIdsWithPreExistingNetLabels})=>{let{db:db2}=group.root;for(let schOrSrcPortId of Array.from(allSourceAndSchematicPortIdsInScope)){let schPort=db2.schematic_port.get(schOrSrcPortId);if(!schPort||schPort.is_connected)continue;let srcPortId=schPortIdToSourcePortId.get(schOrSrcPortId);if(!srcPortId)continue;let key=db2.source_port.get(srcPortId)?.subcircuit_connectivity_map_key;if(!key)continue;let sourceNet=connKeyToNet.get(key);if(!sourceNet||db2.schematic_net_label.list().some(nl3=>Math.abs(nl3.anchor_position.x-schPort.center.x)<.1&&Math.abs(nl3.anchor_position.y-schPort.center.y)<.1?sourceNet.source_net_id&&nl3.source_net_id?nl3.source_net_id===sourceNet.source_net_id:nl3.text===(sourceNet.name||key):!1))continue;let text=sourceNet.name||sourceNet.source_net_id||key,side=getEnteringEdgeFromDirection(schPort.facing_direction||"right")||"right",center2=computeSchematicNetLabelCenter({anchor_position:schPort.center,anchor_side:side,text});db2.schematic_net_label.insert({text,anchor_position:schPort.center,center:center2,anchor_side:side,...sourceNet.source_net_id?{source_net_id:sourceNet.source_net_id}:{}})}},getSchematicPortIdsWithAssignedNetLabels=group=>{let schematicPortIdsWithNetLabels=new Set,netLabels=group.selectAll("netlabel");for(let netLabel of netLabels){let netLabelPorts=netLabel._getConnectedPorts();for(let port of netLabelPorts)port.schematic_port_id&&schematicPortIdsWithNetLabels.add(port.schematic_port_id)}return schematicPortIdsWithNetLabels},getSchematicPortIdsWithRoutedTraces=({solver,pinIdToSchematicPortId})=>{let solvedTraces=solver.schematicTraceLinesSolver.solvedTracePaths,schematicPortIdsWithRoutedTraces=new Set;for(let solvedTrace of solvedTraces)for(let pinId of solvedTrace.pinIds){let schPortId=pinIdToSchematicPortId.get(pinId);schPortId&&schematicPortIdsWithRoutedTraces.add(schPortId)}return schematicPortIdsWithRoutedTraces},debug9=(0,import_debug15.default)("Group_doInitialSchematicTraceRender"),Group_doInitialSchematicTraceRender=group=>{if(!group.root?._featureMspSchematicTraceRouting||!group.isSubcircuit||group.root?.schematicDisabled)return;let{inputProblem,pinIdToSchematicPortId,pairKeyToSourceTraceId,sckToSourceNet,allSourceAndSchematicPortIdsInScope,schPortIdToSourcePortId,displayLabelTraces,allScks,userNetIdToSck}=createSchematicTraceSolverInputProblem(group);if(inputProblem.chips.length===0)return;let schematicPortIdsWithPreExistingNetLabels=getSchematicPortIdsWithAssignedNetLabels(group);if(!(inputProblem.directConnections.length>0||inputProblem.netConnections.length>0)){insertNetLabelsForPortsMissingTrace({group,allSourceAndSchematicPortIdsInScope,schPortIdToSourcePortId,sckToSourceNet,pinIdToSchematicPortId,schematicPortIdsWithPreExistingNetLabels});return}debug9.enabled&&group.root?.emit("debug:logOutput",{type:"debug:logOutput",name:"group-trace-render-input-problem",content:JSON.stringify(inputProblem,null,2)});let solver=new SchematicTracePipelineSolver(inputProblem);solver.solve();let schematicPortIdsWithRoutedTraces=getSchematicPortIdsWithRoutedTraces({solver,pinIdToSchematicPortId});applyTracesFromSolverOutput({group,solver,pinIdToSchematicPortId,userNetIdToSck}),applyNetLabelPlacements({group,solver,sckToSourceNet,allSourceAndSchematicPortIdsInScope,schPortIdToSourcePortId,pinIdToSchematicPortId,allScks,userNetIdToSck,schematicPortIdsWithPreExistingNetLabels,schematicPortIdsWithRoutedTraces}),insertNetLabelsForPortsMissingTrace({group,allSourceAndSchematicPortIdsInScope,schPortIdToSourcePortId,sckToSourceNet,pinIdToSchematicPortId,schematicPortIdsWithPreExistingNetLabels})},getSpiceyEngine=()=>({async simulate(spiceString){let simulation_experiment_id="spice-experiment-1",{circuit:parsedCircuit,tran}=simulate(spiceString);return{simulationResultCircuitJson:spiceyTranToVGraphs(tran,parsedCircuit,simulation_experiment_id)}}}),SIMULATION_COLOR_PALETTE=["rgb(0, 150, 0)","rgb(0, 0, 220)","rgb(220, 0, 0)","rgb(0, 160, 160)","rgb(180, 0, 180)","rgb(170, 140, 0)","rgb(220, 120, 0)","rgb(128, 128, 128)","rgb(100, 0, 180)","rgb(140, 70, 0)","rgb(220, 80, 120)","rgb(0, 120, 220)","rgb(0, 120, 120)","rgb(120, 0, 0)","rgb(0, 0, 132)","rgb(80, 80, 80)"],idToColorMap=new Map,colorIndex=0;function getSimulationColorForId(id2){if(idToColorMap.has(id2))return idToColorMap.get(id2);let color=SIMULATION_COLOR_PALETTE[colorIndex];return colorIndex=(colorIndex+1)%SIMULATION_COLOR_PALETTE.length,idToColorMap.set(id2,color),color}function resetSimulationColorState(){idToColorMap.clear(),colorIndex=0}function getTransientVoltageGraphNamesFromSpiceNetlist(spiceNetlist){let graphNames=[];for(let printStatement of spiceNetlist.printStatements){let match2=printStatement.match(/^\.PRINT\s+TRAN\s+(.+)$/i);if(match2)for(let voltageExpression of match2[1].match(/V\(([^)]+)\)/g)??[]){let nodeList=voltageExpression.slice(2,-1);graphNames.push(nodeList.replace(",","-"))}}return graphNames}var debug10=(0,import_debug18.default)("tscircuit:core:Group_doInitialSimulationSpiceEngineRender");function Group_doInitialSimulationSpiceEngineRender(group){if(!group.isSubcircuit)return;let{root}=group;if(!root)return;let analogSims=group.selectAll("analogsimulation");if(analogSims.length===0)return;let voltageProbes=group.selectAll("voltageprobe");resetSimulationColorState();let spiceEngineMap={...root.platform?.spiceEngineMap};spiceEngineMap.spicey||(spiceEngineMap.spicey=getSpiceyEngine());let circuitJson=root.db.toArray(),spiceString,spiceNetlist;try{spiceNetlist=circuitJsonToSpice(circuitJson),spiceString=spiceNetlist.toSpiceString(),debug10(`Generated SPICE string:
691
- ${spiceString}`)}catch(error2){debug10(`Failed to convert circuit JSON to SPICE: ${error2}`);return}let graphNameToProbe=new Map;for(let probe of voltageProbes)probe.finalProbeName&&graphNameToProbe.set(probe.finalProbeName,probe);let voltageProbesById=new Map(voltageProbes.filter(probe=>probe.simulation_voltage_probe_id).map(probe=>[probe.simulation_voltage_probe_id,probe])),orderedSimulationProbes=root.db.simulation_voltage_probe.list().filter(probe=>voltageProbesById.has(probe.simulation_voltage_probe_id)),graphNamesFromNetlist=getTransientVoltageGraphNamesFromSpiceNetlist(spiceNetlist);if(graphNamesFromNetlist.length===orderedSimulationProbes.length)for(let[index,simulationProbe]of orderedSimulationProbes.entries()){let probe=voltageProbesById.get(simulationProbe.simulation_voltage_probe_id),graphName=graphNamesFromNetlist[index];probe&&graphName&&graphNameToProbe.set(graphName,probe)}else debug10(`Skipping probe-to-graph order mapping because counts differ: probes=${orderedSimulationProbes.length} graphNames=${graphNamesFromNetlist.length}`);for(let analogSim of analogSims){let engineName=analogSim._parsedProps.spiceEngine??"spicey",spiceEngine2=spiceEngineMap[engineName];if(!spiceEngine2)throw new Error(`SPICE engine "${engineName}" not found in platform config. Available engines: ${JSON.stringify(Object.keys(spiceEngineMap).filter(k4=>k4!=="spicey"))}`);let effectId=`spice-simulation-${engineName}-${analogSim.source_component_id}`;debug10(`Queueing simulation for spice engine: ${engineName} (id: ${effectId})`),group._queueAsyncEffect(effectId,async()=>{try{debug10(`Running simulation with engine: ${engineName}`);let result=await spiceEngine2.simulate(spiceString);debug10(`Simulation completed, received ${result.simulationResultCircuitJson.length} elements`);let simulationExperiment=root.db.simulation_experiment.list()[0];if(!simulationExperiment){debug10("No simulation experiment found, skipping result insertion");return}for(let element of result.simulationResultCircuitJson){if(element.type==="simulation_transient_voltage_graph"){element.simulation_experiment_id=simulationExperiment.simulation_experiment_id;let probeMatch=element.name?graphNameToProbe.get(element.name):void 0;probeMatch&&(element.color=probeMatch.color)}let elementType=element.type;elementType&&root.db[elementType]?(root.db[elementType].insert(element),debug10(`Inserted ${elementType} into database`)):(debug10(`Warning: Unknown element type ${elementType}, adding to raw db`),root.db._addElement(element))}group._markDirty("SimulationSpiceEngineRender")}catch(error2){debug10(`Simulation failed for engine ${engineName}: ${error2}`);let simulationExperiment=root.db.simulation_experiment.list()[0];root.db.simulation_unknown_experiment_error.insert({simulation_experiment_id:simulationExperiment?.simulation_experiment_id,error_type:"simulation_unknown_experiment_error",message:error2 instanceof Error?error2.message:String(error2)})}})}}function Group_doInitialSourceAddConnectivityMapKey(group){if(!group.isSubcircuit)return;let{db:db2}=group.root,traces=group.selectAll("trace"),vias=group.selectAll("via"),nets=group.selectAll("net"),connMap=new ConnectivityMap({});connMap.addConnections(traces.map(t52=>{let source_trace3=db2.source_trace.get(t52.source_trace_id);return source_trace3?[source_trace3.source_trace_id,...source_trace3.connected_source_port_ids,...source_trace3.connected_source_net_ids]:null}).filter(c4=>c4!==null));let sourceNets=db2.source_net.list().filter(net=>net.subcircuit_id===group.subcircuit_id);for(let sourceNet of sourceNets)connMap.addConnections([[sourceNet.source_net_id]]);let{name:subcircuitName}=group._parsedProps;for(let trace of traces){if(!trace.source_trace_id)continue;let connNetId=connMap.getNetConnectedToId(trace.source_trace_id);connNetId&&(trace.subcircuit_connectivity_map_key=`${subcircuitName??`unnamedsubcircuit${group._renderId}`}_${connNetId}`,db2.source_trace.update(trace.source_trace_id,{subcircuit_connectivity_map_key:trace.subcircuit_connectivity_map_key}))}let allSourcePortIds=new Set;for(let trace of traces){if(!trace.source_trace_id)continue;let source_trace3=db2.source_trace.get(trace.source_trace_id);if(source_trace3)for(let id2 of source_trace3.connected_source_port_ids)allSourcePortIds.add(id2)}for(let portId of allSourcePortIds){let connNetId=connMap.getNetConnectedToId(portId);if(!connNetId)continue;let connectivityMapKey=`${subcircuitName??`unnamedsubcircuit${group._renderId}`}_${connNetId}`;db2.source_port.update(portId,{subcircuit_connectivity_map_key:connectivityMapKey})}let allSourceNetIds=new Set;for(let trace of traces){if(!trace.source_trace_id)continue;let source_trace3=db2.source_trace.get(trace.source_trace_id);if(source_trace3)for(let source_net_id of source_trace3.connected_source_net_ids)allSourceNetIds.add(source_net_id)}for(let sourceNet of sourceNets)allSourceNetIds.add(sourceNet.source_net_id);for(let netId of allSourceNetIds){let connNetId=connMap.getNetConnectedToId(netId);if(!connNetId)continue;let connectivityMapKey=`${subcircuitName??`unnamedsubcircuit${group._renderId}`}_${connNetId}`;db2.source_net.update(netId,{subcircuit_connectivity_map_key:connectivityMapKey});let netInstance=nets.find(n4=>n4.source_net_id===netId);netInstance&&(netInstance.subcircuit_connectivity_map_key=connectivityMapKey)}for(let via of vias){let connectedNetOrTrace=via._getConnectedNetOrTrace();connectedNetOrTrace&&connectedNetOrTrace.subcircuit_connectivity_map_key&&(via.subcircuit_connectivity_map_key=connectedNetOrTrace.subcircuit_connectivity_map_key)}}function getPhaseSortValue(routingPhaseIndex){return routingPhaseIndex===null?Number.POSITIVE_INFINITY:routingPhaseIndex}function compareRoutingPhasePlans(a3,b3){return getPhaseSortValue(a3.routingPhaseIndex)-getPhaseSortValue(b3.routingPhaseIndex)}function getOrCreateRoutingPhasePlan(plansByPhaseIndex,routingPhaseIndex){let plan=plansByPhaseIndex.get(routingPhaseIndex);return plan||(plan={routingPhaseIndex,nets:[],traces:[]},plansByPhaseIndex.set(routingPhaseIndex,plan)),plan}function getNetRoutingPhaseIndex(net){return net.props.routingPhaseIndex??null}function getTraceRoutingPhaseIndex(trace){let traceRoutingPhaseIndex=trace.props.routingPhaseIndex;if(traceRoutingPhaseIndex!==void 0)return traceRoutingPhaseIndex;let routingPhaseIndex=null,connectedNets=trace._findConnectedNets().nets;for(let net of connectedNets){let netRoutingPhaseIndex=net.props.routingPhaseIndex;typeof netRoutingPhaseIndex=="number"&&(routingPhaseIndex===null||netRoutingPhaseIndex<routingPhaseIndex)&&(routingPhaseIndex=netRoutingPhaseIndex)}return routingPhaseIndex}function Group_getRoutingPhasePlans(group){let traces=group.selectAll("trace"),nets=group.selectAll("net");if(traces.length===0&&nets.length===0)return[];let plansByPhaseIndex=new Map;for(let net of nets){let routingPhaseIndex=getNetRoutingPhaseIndex(net);getOrCreateRoutingPhasePlan(plansByPhaseIndex,routingPhaseIndex).nets.push(net)}for(let trace of traces){let routingPhaseIndex=getTraceRoutingPhaseIndex(trace);getOrCreateRoutingPhasePlan(plansByPhaseIndex,routingPhaseIndex).traces.push(trace)}return Array.from(plansByPhaseIndex.values()).sort(compareRoutingPhasePlans)}function isWirePoint(point62){return point62.route_type==="wire"}function isViaPoint(point62){return point62.route_type==="via"}function isJumperPoint(point62){return point62.route_type==="jumper"}function getTraceConnectionName(trace){return trace.connection_name??trace.pcb_trace_id}function getWireWidth(start,end){return isWirePoint(start)?start.width:isWirePoint(end)?end.width:.1}function getSegmentLayer(start,end){return isWirePoint(start)?start.layer:isWirePoint(end)?end.layer:isJumperPoint(start)?start.layer:isJumperPoint(end)?end.layer:null}function getRoutePointX(point62){return isJumperPoint(point62)?null:point62.x}function getRoutePointY(point62){return isJumperPoint(point62)?null:point62.y}function createWireObstacle(start,end,connectedTo,obstacleIndex){let startX=getRoutePointX(start),startY=getRoutePointY(start),endX=getRoutePointX(end),endY=getRoutePointY(end),layer=getSegmentLayer(start,end);if(startX===null||startY===null||endX===null||endY===null||!layer)return null;let width=getWireWidth(start,end),dx3=Math.abs(startX-endX),dy3=Math.abs(startY-endY);return{obstacleId:`${connectedTo}_phase_obstacle_${obstacleIndex}`,type:"rect",layers:[layer],center:{x:(startX+endX)/2,y:(startY+endY)/2},width:dx3+width,height:dy3+width,connectedTo:[connectedTo]}}function createJumperObstacle(point62,connectedTo,obstacleIndex){let dx3=Math.abs(point62.start.x-point62.end.x),dy3=Math.abs(point62.start.y-point62.end.y),width=.6;return{obstacleId:`${connectedTo}_phase_jumper_obstacle_${obstacleIndex}`,type:"rect",layers:[point62.layer],center:{x:(point62.start.x+point62.end.x)/2,y:(point62.start.y+point62.end.y)/2},width:dx3+width,height:dy3+width,connectedTo:[connectedTo]}}function createViaObstacle(point62,connectedTo,obstacleIndex){return{obstacleId:`${connectedTo}_phase_via_obstacle_${obstacleIndex}`,type:"rect",layers:[point62.from_layer,point62.to_layer],center:{x:point62.x,y:point62.y},width:.6,height:.6,connectedTo:[connectedTo]}}function addTraceObstacles(obstacles,trace){let connectedTo=getTraceConnectionName(trace);for(let routeIndex=0;routeIndex<trace.route.length;routeIndex++){let routePoint=trace.route[routeIndex];if(isViaPoint(routePoint)?obstacles.push(createViaObstacle(routePoint,connectedTo,routeIndex)):isJumperPoint(routePoint)&&obstacles.push(createJumperObstacle(routePoint,connectedTo,routeIndex)),routeIndex===trace.route.length-1)continue;let nextPoint=trace.route[routeIndex+1],obstacle=createWireObstacle(routePoint,nextPoint,connectedTo,routeIndex);obstacle&&obstacles.push(obstacle)}}function connectionIsInRoutingPhase(connection,phasePlan){for(let trace of phasePlan.traces)if(trace.source_trace_id&&(connection.source_trace_id===trace.source_trace_id||connection.name===trace.source_trace_id))return!0;for(let net of phasePlan.nets)if(net.source_net_id&&connection.name===net.source_net_id)return!0;return!1}function Group_hasPhasedAutorouting(routingPhasePlans){for(let plan of routingPhasePlans)if(plan.routingPhaseIndex!==null)return!0;return!1}function Group_filterSimpleRouteJsonForPhase(simpleRouteJson,phasePlan){let connections=[];for(let connection of simpleRouteJson.connections)connectionIsInRoutingPhase(connection,phasePlan)&&connections.push(connection);return{...simpleRouteJson,connections}}function Group_getObstaclesFromRoutedTraces(traces){let obstacles=[];for(let trace of traces)addTraceObstacles(obstacles,trace);return obstacles}function getJumperPadInfos(db2){let padInfos=[],jumperSmtpads=db2.pcb_smtpad.list().filter(pad2=>{let component=db2.pcb_component.get(pad2.pcb_component_id);return component?db2.source_component.get(component.source_component_id)?.name?.startsWith("__autoplaced_jumper"):!1});for(let smtpad2 of jumperSmtpads)if(smtpad2.shape!=="polygon"&&smtpad2.pcb_port_id){if(smtpad2.shape==="rect"||smtpad2.shape==="rotated_rect"){let halfWidth=smtpad2.width/2,halfHeight=smtpad2.height/2;padInfos.push({pcb_port_id:smtpad2.pcb_port_id,x:smtpad2.x,y:smtpad2.y,minX:smtpad2.x-halfWidth,maxX:smtpad2.x+halfWidth,minY:smtpad2.y-halfHeight,maxY:smtpad2.y+halfHeight})}else if(smtpad2.shape==="circle"){let radius=smtpad2.radius;padInfos.push({pcb_port_id:smtpad2.pcb_port_id,x:smtpad2.x,y:smtpad2.y,minX:smtpad2.x-radius,maxX:smtpad2.x+radius,minY:smtpad2.y-radius,maxY:smtpad2.y+radius})}}return padInfos}function findJumperPortAtPosition(padInfos,x4,y4,tolerance=.01){for(let pad2 of padInfos)if(Math.abs(pad2.x-x4)<tolerance&&Math.abs(pad2.y-y4)<tolerance)return pad2.pcb_port_id}function findJumperPortContainingPoint(padInfos,x4,y4){for(let pad2 of padInfos)if(x4>=pad2.minX&&x4<=pad2.maxX&&y4>=pad2.minY&&y4<=pad2.maxY)return pad2}function splitRouteAtJumperPads(route,padInfos){if(route.length===0||padInfos.length===0)return[route];let segments=[],currentSegment=[];for(let i3=0;i3<route.length;i3++){let point62=route[i3];if(currentSegment.push(point62),point62.route_type==="wire"&&i3>0&&i3<route.length-1){let padInfo=findJumperPortContainingPoint(padInfos,point62.x,point62.y);if(padInfo){point62.end_pcb_port_id||(point62.end_pcb_port_id=padInfo.pcb_port_id),segments.push(currentSegment);let newStartPoint={...point62};delete newStartPoint.end_pcb_port_id,newStartPoint.start_pcb_port_id||(newStartPoint.start_pcb_port_id=padInfo.pcb_port_id),currentSegment=[newStartPoint]}}}return currentSegment.length>0&&segments.push(currentSegment),segments}function addPortIdsToTracesAtJumperPads(segments,db2){let padInfos=getJumperPadInfos(db2);if(padInfos.length===0)return segments;let result=[];for(let segment2 of segments){let subSegments=splitRouteAtJumperPads(segment2,padInfos);for(let subSegment of subSegments)if(subSegment.length>0){let firstPoint=subSegment[0],lastPoint=subSegment[subSegment.length-1];if(firstPoint.route_type==="wire"&&!firstPoint.start_pcb_port_id){let portId=findJumperPortAtPosition(padInfos,firstPoint.x,firstPoint.y);portId&&(firstPoint.start_pcb_port_id=portId)}if(lastPoint.route_type==="wire"&&!lastPoint.end_pcb_port_id){let portId=findJumperPortAtPosition(padInfos,lastPoint.x,lastPoint.y);portId&&(lastPoint.end_pcb_port_id=portId)}result.push(subSegment)}}return result}function groupPadsByInternalConnection(pads,orientation4){let groups=[];for(let pad2 of pads){let key=orientation4==="vertical"?pad2.center.y:pad2.center.x,foundGroup=!1;for(let group of groups){let groupKey=orientation4==="vertical"?group[0].center.y:group[0].center.x;if(Math.abs(key-groupKey)<.01){group.push(pad2),foundGroup=!0;break}}foundGroup||groups.push([pad2])}return groups.filter(g6=>g6.length>=2)}function insertAutoplacedJumpers(params){let{db:db2,output_jumpers,subcircuit_id}=params;for(let jumperIndex=0;jumperIndex<output_jumpers.length;jumperIndex++){let jumper=output_jumpers[jumperIndex],sourceComponent=db2.source_component.insert({ftype:"simple_chip",name:`__autoplaced_jumper_${jumperIndex}`,supplier_part_numbers:{}}),rotation42=jumper.orientation==="horizontal"?0:90,firstPadLayer=jumper.pads[0]?.layer||jumper.pads[0]?.layers?.[0]||"top",pcbComponent=db2.pcb_component.insert({source_component_id:sourceComponent.source_component_id,center:jumper.center,rotation:rotation42,layer:firstPadLayer,width:jumper.width||0,height:jumper.height||0,obstructs_within_bounds:!1}),padData=[];for(let padIndex=0;padIndex<jumper.pads.length;padIndex++){let pad2=jumper.pads[padIndex],pinNumber=padIndex+1,sourcePort=db2.source_port.insert({source_component_id:sourceComponent.source_component_id,name:`pin${pinNumber}`,pin_number:pinNumber}),padLayer=pad2.layer||pad2.layers?.[0]||"top",pcbPort=db2.pcb_port.insert({pcb_component_id:pcbComponent.pcb_component_id,source_port_id:sourcePort.source_port_id,x:pad2.center.x,y:pad2.center.y,layers:[padLayer]}),pcbSmtpad=db2.pcb_smtpad.insert({pcb_component_id:pcbComponent.pcb_component_id,pcb_port_id:pcbPort.pcb_port_id,shape:"rect",x:pad2.center.x,y:pad2.center.y,width:pad2.width,height:pad2.height,layer:padLayer});padData.push({pad:pad2,sourcePortId:sourcePort.source_port_id,pcbSmtpadId:pcbSmtpad.pcb_smtpad_id})}let internalGroups=groupPadsByInternalConnection(jumper.pads,jumper.orientation);for(let group of internalGroups){let sourcePortIds=[];for(let groupPad of group){let padInfo=padData.find(p4=>Math.abs(p4.pad.center.x-groupPad.center.x)<.01&&Math.abs(p4.pad.center.y-groupPad.center.y)<.01);padInfo&&sourcePortIds.push(padInfo.sourcePortId)}sourcePortIds.length>=2&&db2.source_component_internal_connection.insert({source_component_id:sourceComponent.source_component_id,subcircuit_id:subcircuit_id??void 0,source_port_ids:sourcePortIds})}}}function splitPcbTracesOnJumperSegments(route){let jumperRoutes=route.filter(p4=>p4.route_type==="jumper"),wireAndViaRoutes=route.filter(p4=>p4.route_type!=="jumper");if(jumperRoutes.length===0)return null;let splitRanges=[];for(let jumperRoute of jumperRoutes){let jumperStart=jumperRoute.start,jumperEnd=jumperRoute.end,startIdx=-1,endIdx=-1,minStartDist=1/0,minEndDist=1/0;for(let i3=0;i3<wireAndViaRoutes.length;i3++){let p4=wireAndViaRoutes[i3];if(p4.route_type!=="wire")continue;let distToStart=Math.hypot(p4.x-jumperStart.x,p4.y-jumperStart.y),distToEnd=Math.hypot(p4.x-jumperEnd.x,p4.y-jumperEnd.y);distToStart<minStartDist&&(minStartDist=distToStart,startIdx=i3),distToEnd<minEndDist&&(minEndDist=distToEnd,endIdx=i3)}startIdx>endIdx&&([startIdx,endIdx]=[endIdx,startIdx]),startIdx>=0&&endIdx>=0&&startIdx!==endIdx&&splitRanges.push({startIdx,endIdx})}splitRanges.sort((a3,b3)=>a3.startIdx-b3.startIdx);let segments=[],currentStart=0;for(let range2 of splitRanges)currentStart<range2.startIdx&&segments.push(wireAndViaRoutes.slice(currentStart,range2.startIdx+1)),currentStart=range2.endIdx;return currentStart<wireAndViaRoutes.length&&segments.push(wireAndViaRoutes.slice(currentStart)),segments}function computeCenterFromAnchorPosition(anchorPosition,ctx){let{width,height,pcbAnchorAlignment}=ctx;if(!pcbAnchorAlignment)return anchorPosition;let alignment=pcbAnchorAlignment;if(typeof width!="number"||typeof height!="number")return console.log("width or height is not a number"),anchorPosition;let ax3=anchorPosition.x,ay3=anchorPosition.y;switch(alignment){case"top_left":return{x:ax3+width/2,y:ay3-height/2};case"top_center":return{x:ax3,y:ay3-height/2};case"top_right":return{x:ax3-width/2,y:ay3-height/2};case"center_left":return{x:ax3+width/2,y:ay3};case"center_right":return{x:ax3-width/2,y:ay3};case"bottom_left":return{x:ax3+width/2,y:ay3+height/2};case"bottom_center":return{x:ax3,y:ay3+height/2};case"bottom_right":return{x:ax3-width/2,y:ay3+height/2};default:return anchorPosition}}var Group6=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"pcb_group_id",null);__publicField(this,"schematic_group_id",null);__publicField(this,"subcircuit_id",null);__publicField(this,"_hasStartedAsyncAutorouting",!1);__publicField(this,"_isInflatedFromCircuitJson",!1);__publicField(this,"_isolatedCircuitJson",null);__publicField(this,"_normalComponentNameMap",null);__publicField(this,"_asyncAutoroutingResult",null);__publicField(this,"unnamedElementCounter",{})}get _isIsolatedSubcircuit(){return!!this.getInheritedProperty("_subcircuitCachingEnabled")}getNormalComponentNameMap(){if(this._normalComponentNameMap)return this._normalComponentNameMap;let nameMap=new Map,collectNamedComponents=component=>{if(component._isNormalComponent&&component.name){let componentsWithSameName=nameMap.get(component.name);componentsWithSameName?componentsWithSameName.push(component):nameMap.set(component.name,[component])}for(let child of component.children)child.isSubcircuit||collectNamedComponents(child)};for(let child of this.children)child.isSubcircuit||collectNamedComponents(child);return this._normalComponentNameMap=nameMap,nameMap}get config(){return{zodProps:groupProps,componentName:"Group"}}_ensureSchematicBoxPortsFromConnections(){if(this._parsedProps?.showAsSchematicBox&&this._parsedProps?.connections)for(let[pinName,target]of Object.entries(this._parsedProps.connections)){if(this.children.find(child=>child.componentName==="Port"&&child.isMatchingAnyOf([pinName])))continue;let pinNumberMatch=pinName.match(/^pin(\d+)$/i)??pinName.match(/^(\d+)$/),pinNumber=pinNumberMatch?Number(pinNumberMatch[1]):void 0;this.add(new Port({name:pinName,pinNumber,connectsTo:target}))}}doInitialInitializePortsFromChildren(){super.doInitialInitializePortsFromChildren(),this._ensureSchematicBoxPortsFromConnections()}updateInitializePortsFromChildren(){super.updateInitializePortsFromChildren(),this._ensureSchematicBoxPortsFromConnections()}_getPrimaryPinCount(){let superPinCount=super._getPrimaryPinCount();if(!this._parsedProps?.showAsSchematicBox)return superPinCount;let directPortPinNumbers=this.children.filter(child=>child.componentName==="Port").map(port=>port._parsedProps.pinNumber).filter(pinNumber=>pinNumber!==void 0);return directPortPinNumbers.length===0?superPinCount:Math.max(superPinCount,...directPortPinNumbers)}_getPinLabelsFromPorts(){return this._parsedProps?.showAsSchematicBox?getGroupSchematicBoxPinLabels(this):super._getPinLabelsFromPorts()}doInitialSourceGroupRender(){let{db:db2}=this.root,hasExplicitName=typeof this._parsedProps.name=="string"&&this._parsedProps.name.length>0,source_group3=db2.source_group.insert({name:this.name,is_subcircuit:this.isSubcircuit,was_automatically_named:!hasExplicitName});this.source_group_id=source_group3.source_group_id,this.isSubcircuit&&(this.subcircuit_id=`subcircuit_${source_group3.source_group_id}`,db2.source_group.update(source_group3.source_group_id,{subcircuit_id:this.subcircuit_id}))}doInitialSourceRender(){let{db:db2}=this.root;for(let child of this.children)db2.source_component.update(child.source_component_id,{source_group_id:this.source_group_id})}doInitialSourceParentAttachment(){let{db:db2}=this.root,parentGroup=this.parent?.getGroup?.();if(parentGroup?.source_group_id&&db2.source_group.update(this.source_group_id,{parent_source_group_id:parentGroup.source_group_id}),!this.isSubcircuit)return;let parent_subcircuit_id=this.parent?.getSubcircuit?.()?.subcircuit_id;parent_subcircuit_id&&db2.source_group.update(this.source_group_id,{parent_subcircuit_id})}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,groupProps2=props,hasOutline=groupProps2.outline&&groupProps2.outline.length>0,numericOutline=hasOutline?groupProps2.outline.map(point62=>({x:distance.parse(point62.x),y:distance.parse(point62.y)})):void 0,ctx=this.props,anchorPosition=this._getGlobalPcbPositionBeforeLayout(),center2=computeCenterFromAnchorPosition(anchorPosition,ctx),pcb_group3=db2.pcb_group.insert({is_subcircuit:this.isSubcircuit,subcircuit_id:this.subcircuit_id??this.getSubcircuit()?.subcircuit_id,name:this.name,anchor_position:anchorPosition,center:center2,...hasOutline?{outline:numericOutline}:{width:0,height:0},pcb_component_ids:[],source_group_id:this.source_group_id,autorouter_configuration:props.autorouter?{trace_clearance:props.autorouter.traceClearance}:void 0,anchor_alignment:props.pcbAnchorAlignment??null});this.pcb_group_id=pcb_group3.pcb_group_id;for(let child of this.children)db2.pcb_component.update(child.pcb_component_id,{pcb_group_id:pcb_group3.pcb_group_id})}doInitialPcbPrimitiveRender(){this.calculatePcbGroupBounds()}calculatePcbGroupBounds(){if(!this.pcb_group_id||this.root?.pcbDisabled)return;let{db:db2}=this.root,props=this._parsedProps,hasOutline=props.outline&&props.outline.length>0,hasExplicitPositioning=this._parsedProps.pcbX!==void 0||this._parsedProps.pcbY!==void 0;if(hasOutline){let numericOutline=props.outline.map(point62=>({x:distance.parse(point62.x),y:distance.parse(point62.y)})),outlineBounds=getBoundsFromPoints(numericOutline);if(!outlineBounds)return;let centerX2=(outlineBounds.minX+outlineBounds.maxX)/2,centerY2=(outlineBounds.minY+outlineBounds.maxY)/2,center22=hasExplicitPositioning?db2.pcb_group.get(this.pcb_group_id)?.center??{x:centerX2,y:centerY2}:{x:centerX2,y:centerY2};db2.pcb_group.update(this.pcb_group_id,{center:center22});return}let bounds=getBoundsOfPcbComponents(this.children),width=bounds.width,height=bounds.height,centerX=(bounds.minX+bounds.maxX)/2,centerY=(bounds.minY+bounds.maxY)/2;if(this.isSubcircuit){let{padLeft,padRight,padTop,padBottom}=this._resolvePcbPadding();width+=padLeft+padRight,height+=padTop+padBottom,centerX+=(padRight-padLeft)/2,centerY+=(padTop-padBottom)/2}let center2=hasExplicitPositioning?db2.pcb_group.get(this.pcb_group_id)?.center??{x:centerX,y:centerY}:{x:centerX,y:centerY};db2.pcb_group.update(this.pcb_group_id,{width:Number(props.width??width),height:Number(props.height??height),center:center2})}updatePcbPrimitiveRender(){this.calculatePcbGroupBounds()}getNextAvailableName(elm){var _a362,_b3;return(_a362=this.unnamedElementCounter)[_b3=elm.lowercaseComponentName]??(_a362[_b3]=1),`unnamed_${elm.lowercaseComponentName}${this.unnamedElementCounter[elm.lowercaseComponentName]++}`}_resolvePcbPadding(){let props=this._parsedProps,layout=props.pcbLayout,getPaddingValue=key=>{let layoutValue=layout?.[key],propsValue=props[key];if(typeof layoutValue=="number")return layoutValue;if(typeof propsValue=="number")return propsValue},generalPadding=getPaddingValue("padding")??0,paddingX=getPaddingValue("paddingX"),paddingY=getPaddingValue("paddingY"),padLeft=getPaddingValue("paddingLeft")??paddingX??generalPadding,padRight=getPaddingValue("paddingRight")??paddingX??generalPadding,padTop=getPaddingValue("paddingTop")??paddingY??generalPadding,padBottom=getPaddingValue("paddingBottom")??paddingY??generalPadding;return{padLeft,padRight,padTop,padBottom}}doInitialCreateTraceHintsFromProps(){let{_parsedProps:props}=this,{db:db2}=this.root,groupProps2=props;if(!this.isSubcircuit)return;let manualTraceHints=groupProps2.manualEdits?.manual_trace_hints;if(manualTraceHints)for(let manualTraceHint of manualTraceHints)this.add(new TraceHint({for:manualTraceHint.pcb_port_selector,offsets:manualTraceHint.offsets}))}doInitialSourceAddConnectivityMapKey(){Group_doInitialSourceAddConnectivityMapKey(this)}_areChildSubcircuitsRouted(){let subcircuitChildren=this.selectAll("group").filter(g6=>g6.isSubcircuit);for(let subcircuitChild of subcircuitChildren)if(subcircuitChild._shouldRouteAsync()&&!subcircuitChild._asyncAutoroutingResult)return!1;return!0}_shouldRouteAsync(){let autorouter=this._getAutorouterConfig();return autorouter.groupMode==="sequential-trace"?!1:!!(autorouter.local&&autorouter.groupMode==="subcircuit"||!autorouter.local)}_getRoutingPhasePlans(){return Group_getRoutingPhasePlans(this)}_hasTracesToRoute(){let debug112=(0,import_debug11.default)("tscircuit:core:_hasTracesToRoute"),routingPhasePlans=this._getRoutingPhasePlans(),traceCount=0;for(let routingPhasePlan of routingPhasePlans)traceCount+=routingPhasePlan.traces.length;return debug112(`[${this.getString()}] has ${traceCount} traces to route`),traceCount>0}async _runEffectMakeHttpAutoroutingRequest(){let{db:db2}=this.root,debug112=(0,import_debug11.default)("tscircuit:core:_runEffectMakeHttpAutoroutingRequest"),props=this._parsedProps,autorouterConfig2=this._getAutorouterConfig(),serverUrl=autorouterConfig2.serverUrl,serverMode=autorouterConfig2.serverMode,fetchWithDebug=(url2,options)=>(debug112("fetching",url2),options.headers&&(options.headers["Tscircuit-Core-Version"]=this.root?.getCoreVersion()),fetch(url2,options)),pcbAndSourceCircuitJson=this.root.db.toArray().filter(element=>element.type.startsWith("source_")||element.type.startsWith("pcb_"));if(serverMode==="solve-endpoint"){if(this.props.autorouter?.inputFormat==="simplified"){let{autorouting_result:autorouting_result2}=await fetchWithDebug(`${serverUrl}/autorouting/solve`,{method:"POST",body:JSON.stringify({input_simple_route_json:getSimpleRouteJsonFromCircuitJson({db:db2,minTraceWidth:Number(props.minTraceWidth??.15),nominalTraceWidth:this.props.nominalTraceWidth,subcircuit_id:this.subcircuit_id,subcircuitComponent:this}).simpleRouteJson,subcircuit_id:this.subcircuit_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());this._asyncAutoroutingResult=autorouting_result2,this._markDirty("PcbTraceRender");return}let{autorouting_result}=await fetchWithDebug(`${serverUrl}/autorouting/solve`,{method:"POST",body:JSON.stringify({input_circuit_json:pcbAndSourceCircuitJson,subcircuit_id:this.subcircuit_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());this._asyncAutoroutingResult=autorouting_result,this._markDirty("PcbTraceRender");return}let{autorouting_job}=await fetchWithDebug(`${serverUrl}/autorouting/jobs/create`,{method:"POST",body:JSON.stringify({input_circuit_json:pcbAndSourceCircuitJson,provider:"freerouting",autostart:!0,display_name:this.root?.name,subcircuit_id:this.subcircuit_id,server_cache_enabled:autorouterConfig2.serverCacheEnabled}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());for(;;){let{autorouting_job:job}=await fetchWithDebug(`${serverUrl}/autorouting/jobs/get`,{method:"POST",body:JSON.stringify({autorouting_job_id:autorouting_job.autorouting_job_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());if(job.is_finished){let{autorouting_job_output}=await fetchWithDebug(`${serverUrl}/autorouting/jobs/get_output`,{method:"POST",body:JSON.stringify({autorouting_job_id:autorouting_job.autorouting_job_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());this._asyncAutoroutingResult={output_pcb_traces:autorouting_job_output.output_pcb_traces},this._markDirty("PcbTraceRender");break}if(job.has_error){let err=new AutorouterError(`Autorouting job failed: ${JSON.stringify(job.error)}`);throw db2.pcb_autorouting_error.insert({pcb_error_id:autorouting_job.autorouting_job_id,error_type:"pcb_autorouting_error",message:err.message}),err}await new Promise(resolve=>setTimeout(resolve,100))}}async _runLocalAutorouting(){let{db:db2}=this.root,props=this._parsedProps,debug112=(0,import_debug11.default)("tscircuit:core:_runLocalAutorouting");debug112(`[${this.getString()}] starting local autorouting`);let autorouterConfig2=this._getAutorouterConfig(),isLaserPrefabPreset=this._isLaserPrefabAutorouter(autorouterConfig2),isAutoJumperPreset=this._isAutoJumperAutorouter(autorouterConfig2),isSingleLayerBoard=this._getSubcircuitLayerCount()===1,{simpleRouteJson:baseSimpleRouteJson}=getSimpleRouteJsonFromCircuitJson({db:db2,minTraceWidth:Number(props.minTraceWidth??.15),nominalTraceWidth:Number(props.nominalTraceWidth),subcircuit_id:this.subcircuit_id,subcircuitComponent:this}),routingPhasePlans=this._getRoutingPhasePlans(),hasPhasedAutorouting=Group_hasPhasedAutorouting(routingPhasePlans),outputTraces=[],outputJumpers=[];for(let routingPhasePlan of routingPhasePlans){let simpleRouteJson=baseSimpleRouteJson;if(hasPhasedAutorouting&&(simpleRouteJson=Group_filterSimpleRouteJsonForPhase(baseSimpleRouteJson,routingPhasePlan),simpleRouteJson.obstacles=[...simpleRouteJson.obstacles,...Group_getObstaclesFromRoutedTraces(outputTraces)]),hasPhasedAutorouting&&simpleRouteJson.connections.length===0)continue;if(isAutoJumperPreset&&(simpleRouteJson.allowJumpers=!0,autorouterConfig2.availableJumperTypes&&(simpleRouteJson.availableJumperTypes=autorouterConfig2.availableJumperTypes)),debug112.enabled&&global.debugOutputArray?.push({name:`simpleroutejson-${this.props.name}.json`,obj:simpleRouteJson}),debug112.enabled){let graphicsObject=Co2(simpleRouteJson);graphicsObject.title=`autorouting-${this.props.name}`,global.debugGraphics?.push(graphicsObject)}this.root?.emit("autorouting:start",{subcircuit_id:this.subcircuit_id,componentDisplayName:this.getString(),simpleRouteJson});let autorouter;if(autorouterConfig2.algorithmFn)autorouter=await autorouterConfig2.algorithmFn(simpleRouteJson);else{let autorouterVersion2=this.props.autorouterVersion,effortLevel=this.props.autorouterEffortLevel,effort=effortLevel?Number.parseInt(effortLevel.replace("x",""),10):void 0;autorouter=new TscircuitAutorouter(simpleRouteJson,{capacityDepth:this.props.autorouter?.capacityDepth,targetMinCapacity:this.props.autorouter?.targetMinCapacity,useAssignableSolver:isLaserPrefabPreset||isSingleLayerBoard,useAutoJumperSolver:isAutoJumperPreset,autorouterVersion:autorouterVersion2,effort,onSolverStarted:({solverName,solverParams})=>this.root?.emit("solver:started",{type:"solver:started",solverName,solverParams,componentName:this.getString()})})}let routingPromise=new Promise((resolve,reject)=>{autorouter.on("complete",event=>{debug112(`[${this.getString()}] local autorouting complete`),resolve(event.traces)}),autorouter.on("error",event=>{debug112(`[${this.getString()}] local autorouting error: ${event.error.message}`),reject(event.error)})});autorouter.on("progress",event=>{this.root?.emit("autorouting:progress",{subcircuit_id:this.subcircuit_id,componentDisplayName:this.getString(),...event})}),autorouter.start();try{let traces=await routingPromise;if(autorouter.getConnectedOffboardObstacles){let connectedOffboardObstacles=autorouter.getConnectedOffboardObstacles();createSourceTracesFromOffboardConnections({db:db2,connectedOffboardObstacles,simpleRouteJson,subcircuit_id:this.subcircuit_id})}let solver=autorouter.solver;solver?.getOutputJumpers&&outputJumpers.push(...solver.getOutputJumpers()||[]),outputTraces.push(...traces)}catch(error2){let{db:db22}=this.root;throw db22.pcb_autorouting_error.insert({pcb_error_id:`pcb_autorouter_error_subcircuit_${this.subcircuit_id}`,error_type:"pcb_autorouting_error",message:error2 instanceof Error?error2.message:String(error2)}),this.root?.emit("autorouting:error",{subcircuit_id:this.subcircuit_id,componentDisplayName:this.getString(),error:{message:error2 instanceof Error?error2.message:String(error2)},simpleRouteJson}),error2}finally{autorouter.stop()}}this._asyncAutoroutingResult={output_pcb_traces:outputTraces,output_jumpers:outputJumpers},this._markDirty("PcbTraceRender")}_startAsyncAutorouting(){this._hasStartedAsyncAutorouting||(this._hasStartedAsyncAutorouting=!0,this._getAutorouterConfig().local?this._queueAsyncEffect("capacity-mesh-autorouting",async()=>this._runLocalAutorouting()):this._queueAsyncEffect("make-http-autorouting-request",async()=>this._runEffectMakeHttpAutoroutingRequest()))}doInitialPcbTraceRender(){let debug112=(0,import_debug11.default)("tscircuit:core:doInitialPcbTraceRender");if(this.isSubcircuit&&!this.root?.pcbDisabled&&!(this.root?.pcbRoutingDisabled||this.getInheritedProperty("routingDisabled"))&&!this._isInflatedFromCircuitJson&&!this._shouldUseTraceByTraceRouting()){if(!this._areChildSubcircuitsRouted()){debug112(`[${this.getString()}] child subcircuits are not routed, skipping async autorouting until subcircuits routed`);return}debug112(`[${this.getString()}] no child subcircuits to wait for, initiating async routing`),this._hasTracesToRoute()&&this._startAsyncAutorouting()}}doInitialSchematicTraceRender(){this._parsedProps.showAsSchematicBox||Group_doInitialSchematicTraceRender(this)}updatePcbTraceRender(){let debug112=(0,import_debug11.default)("tscircuit:core:updatePcbTraceRender");if(debug112(`[${this.getString()}] updating...`),!this.isSubcircuit||this._isInflatedFromCircuitJson)return;if(this._shouldRouteAsync()&&this._hasTracesToRoute()&&!this._hasStartedAsyncAutorouting){this._areChildSubcircuitsRouted()&&(debug112(`[${this.getString()}] child subcircuits are now routed, starting async autorouting`),this._startAsyncAutorouting());return}if(!this._asyncAutoroutingResult||this._shouldUseTraceByTraceRouting())return;let{db:db2}=this.root;if(this._asyncAutoroutingResult.output_simple_route_json){debug112(`[${this.getString()}] updating PCB traces from simple route json (${this._asyncAutoroutingResult.output_simple_route_json.traces?.length} traces)`),this._updatePcbTraceRenderFromSimpleRouteJson();return}if(this._asyncAutoroutingResult.output_pcb_traces){debug112(`[${this.getString()}] updating PCB traces from ${this._asyncAutoroutingResult.output_pcb_traces.length} traces`),this._updatePcbTraceRenderFromPcbTraces();return}}_updatePcbTraceRenderFromSimpleRouteJson(){let{db:db2}=this.root,{traces:routedTraces}=this._asyncAutoroutingResult.output_simple_route_json;if(routedTraces)for(let routedTrace of routedTraces){let pcb_trace3=db2.pcb_trace.insert({subcircuit_id:this.subcircuit_id,route:routedTrace.route})}}_updatePcbTraceRenderFromPcbTraces(){let{output_pcb_traces,output_jumpers}=this._asyncAutoroutingResult;if(!output_pcb_traces)return;let{db:db2}=this.root,pcbStyle2=this.getInheritedMergedProperty("pcbStyle"),{holeDiameter,padDiameter}=getViaDiameterDefaults(pcbStyle2),board=db2.pcb_board.list()[0],routedViaHoleDiameter=board?.min_via_hole_diameter??holeDiameter,routedViaPadDiameter=board?.min_via_pad_diameter??padDiameter;output_jumpers&&output_jumpers.length>0&&insertAutoplacedJumpers({db:db2,output_jumpers,subcircuit_id:this.subcircuit_id});for(let pcb_trace3 of output_pcb_traces){if(pcb_trace3.type!=="pcb_trace")continue;if(pcb_trace3.subcircuit_id=this.subcircuit_id,pcb_trace3.connection_name){let sourceTraceId=pcb_trace3.connection_name;pcb_trace3.source_trace_id=sourceTraceId}let segments=splitPcbTracesOnJumperSegments(pcb_trace3.route);segments===null&&(segments=[pcb_trace3.route]);let processedSegments=addPortIdsToTracesAtJumperPads(segments,db2);for(let segment2 of processedSegments)segment2.length>0&&db2.pcb_trace.insert({...pcb_trace3,route:segment2})}for(let pcb_trace3 of output_pcb_traces)if(pcb_trace3.type!=="pcb_via"&&pcb_trace3.type==="pcb_trace"){for(let point62 of pcb_trace3.route)if(point62.route_type==="via"){let routedViaPoint=point62;db2.pcb_via.insert({pcb_trace_id:pcb_trace3.pcb_trace_id,x:point62.x,y:point62.y,hole_diameter:routedViaPoint.via_hole_diameter??routedViaPoint.hole_diameter??routedViaHoleDiameter,outer_diameter:routedViaPoint.via_diameter??routedViaPoint.outer_diameter??routedViaPadDiameter,layers:[point62.from_layer,point62.to_layer],from_layer:point62.from_layer,to_layer:point62.to_layer})}}}doInitialSchematicComponentRender(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,schematic_group3=db2.schematic_group.insert({is_subcircuit:this.isSubcircuit,subcircuit_id:this.subcircuit_id,name:this.name,center:this._getGlobalSchematicPositionBeforeLayout(),width:0,height:0,schematic_component_ids:[],source_group_id:this.source_group_id,show_as_schematic_box:props.showAsSchematicBox??!1});this.schematic_group_id=schematic_group3.schematic_group_id,props.showAsSchematicBox&&Group_doInitialSchematicBoxComponentRender(this);for(let child of this.children)child._parsedProps?.showAsSchematicBox||child.schematic_component_id&&db2.schematic_component.update(child.schematic_component_id,{schematic_group_id:schematic_group3.schematic_group_id})}_getSchematicLayoutMode(){let props=this._parsedProps,schAutoLayoutEnabled=props.schAutoLayoutEnabled??!1;if(props.schLayout?.layoutMode==="none"||props.schLayout?.layoutMode==="relative")return"relative";if(props.schLayout?.matchAdapt)return"match-adapt";if(props.schLayout?.flex)return"flex";if(props.schLayout?.grid)return"grid";if(props.schMatchAdapt)return"match-adapt";if(props.schFlex)return"flex";if(props.schGrid)return"grid";if(props.matchAdapt)return"match-adapt";if(props.flex)return"flex";if(props.grid)return"grid";if(props.relative||props.schRelative)return"relative";let anyLayoutChildHasSchCoords=this.children.some(child=>{let cProps=child._parsedProps;return(child.source_component_id!==null||child.source_group_id!==null)&&(cProps?.schX!==void 0||cProps?.schY!==void 0)}),hasManualEdits=(props.manualEdits?.schematic_placements?.length??0)>0;return schAutoLayoutEnabled&&!hasManualEdits||!anyLayoutChildHasSchCoords&&!hasManualEdits?"match-adapt":"relative"}doInitialSchematicLayout(){if(this._parsedProps.showAsSchematicBox){this._insertSchematicBorder();return}let schematicLayoutMode=this._getSchematicLayoutMode();schematicLayoutMode==="match-adapt"&&this._doInitialSchematicLayoutMatchpack(),schematicLayoutMode==="grid"&&this._doInitialSchematicLayoutGrid(),schematicLayoutMode==="flex"&&this._doInitialSchematicLayoutFlex(),this._insertSchematicBorder()}_doInitialSchematicLayoutMatchAdapt(){Group_doInitialSchematicLayoutMatchAdapt(this)}_doInitialSchematicLayoutMatchpack(){Group_doInitialSchematicLayoutMatchPack(this)}_doInitialSchematicLayoutGrid(){Group_doInitialSchematicLayoutGrid(this)}_doInitialSchematicLayoutFlex(){Group_doInitialSchematicLayoutFlex(this)}_getPcbLayoutMode(){let props=this._parsedProps,rawProps=this.props;if(this._isInflatedFromCircuitJson||props.pcbRelative)return"none";if(props.pcbLayout?.matchAdapt)return"match-adapt";if(props.pcbLayout?.flex)return"flex";if(props.pcbLayout?.grid)return"grid";if(props.pcbLayout?.pack)return"pack";if(props.pcbFlex)return"flex";if(props.pcbGrid)return"grid";if(props.pcbPack||props.pack)return"pack";if(props.matchAdapt)return"match-adapt";if(props.flex)return"flex";if(props.grid)return"grid";let groupHasCoords=props.pcbX!==void 0||props.pcbY!==void 0||props.pcbLeftEdgeX!==void 0||props.pcbRightEdgeX!==void 0||props.pcbTopEdgeY!==void 0||props.pcbBottomEdgeY!==void 0||rawProps.pcbLeftEdgeX!==void 0||rawProps.pcbRightEdgeX!==void 0||rawProps.pcbTopEdgeY!==void 0||rawProps.pcbBottomEdgeY!==void 0,hasManualEdits=(props.manualEdits?.pcb_placements?.length??0)>0,unpositionedDirectChildrenCount=this.children.reduce((count,child)=>{if(!child.pcb_component_id&&!child.pcb_group_id)return count;let childProps=child._parsedProps,rawChildProps=child.props,hasCoords=childProps?.pcbX!==void 0||childProps?.pcbY!==void 0||childProps?.pcbLeftEdgeX!==void 0||childProps?.pcbRightEdgeX!==void 0||childProps?.pcbTopEdgeY!==void 0||childProps?.pcbBottomEdgeY!==void 0||rawChildProps?.pcbLeftEdgeX!==void 0||rawChildProps?.pcbRightEdgeX!==void 0||rawChildProps?.pcbTopEdgeY!==void 0||rawChildProps?.pcbBottomEdgeY!==void 0;return count+(hasCoords?0:1)},0);return!hasManualEdits&&unpositionedDirectChildrenCount>1?"pack":"none"}doInitialPcbLayout(){if(this.root?.pcbDisabled)return;if(this.pcb_group_id){let{db:db2}=this.root,props=this._parsedProps;if(props.pcbX!==void 0||props.pcbY!==void 0){let parentGroup=this.parent?.getGroup?.(),pcbParentGroupId=parentGroup?.pcb_group_id?db2.pcb_group.get(parentGroup.pcb_group_id)?.pcb_group_id:void 0,positionedRelativeToBoardId=pcbParentGroupId?void 0:this._getBoard()?.pcb_board_id??void 0;db2.pcb_group.update(this.pcb_group_id,{position_mode:"relative_to_group_anchor",positioned_relative_to_pcb_group_id:pcbParentGroupId,positioned_relative_to_pcb_board_id:positionedRelativeToBoardId,display_offset_x:props.pcbX,display_offset_y:props.pcbY})}}let pcbLayoutMode=this._getPcbLayoutMode();pcbLayoutMode==="grid"?this._doInitialPcbLayoutGrid():pcbLayoutMode==="pack"?this._doInitialPcbLayoutPack():pcbLayoutMode==="flex"&&this._doInitialPcbLayoutFlex()}_doInitialPcbLayoutGrid(){Group_doInitialPcbLayoutGrid(this)}_doInitialPcbLayoutPack(){Group_doInitialPcbLayoutPack(this)}_doInitialPcbLayoutFlex(){Group_doInitialPcbLayoutFlex(this)}_insertSchematicBorder(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,props=this._parsedProps;if(!props.border)return;let width=typeof props.schWidth=="number"?props.schWidth:void 0,height=typeof props.schHeight=="number"?props.schHeight:void 0,paddingGeneral=typeof props.schPadding=="number"?props.schPadding:0,paddingLeft=typeof props.schPaddingLeft=="number"?props.schPaddingLeft:paddingGeneral,paddingRight=typeof props.schPaddingRight=="number"?props.schPaddingRight:paddingGeneral,paddingTop=typeof props.schPaddingTop=="number"?props.schPaddingTop:paddingGeneral,paddingBottom=typeof props.schPaddingBottom=="number"?props.schPaddingBottom:paddingGeneral,schematicGroup=this.schematic_group_id?db2.schematic_group.get(this.schematic_group_id):null;if(schematicGroup&&(width===void 0&&typeof schematicGroup.width=="number"&&(width=schematicGroup.width),height===void 0&&typeof schematicGroup.height=="number"&&(height=schematicGroup.height)),width===void 0||height===void 0)return;let center2=schematicGroup?.center??this._getGlobalSchematicPositionBeforeLayout(),left=center2.x-width/2-paddingLeft,bottom=center2.y-height/2-paddingBottom,finalWidth=width+paddingLeft+paddingRight,finalHeight=height+paddingTop+paddingBottom;db2.schematic_box.insert({width:finalWidth,height:finalHeight,x:left,y:bottom,is_dashed:props.border?.dashed??!1})}_determineSideFromPosition(port,component){if(!port.center||!component.center)return"left";let dx3=port.center.x-component.center.x,dy3=port.center.y-component.center.y;return Math.abs(dx3)>Math.abs(dy3)?dx3>0?"right":"left":dy3>0?"bottom":"top"}_calculateSchematicBounds(boxes){if(boxes.length===0)return{minX:0,maxX:0,minY:0,maxY:0};let minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0;for(let box2 of boxes)minX=Math.min(minX,box2.centerX),maxX=Math.max(maxX,box2.centerX),minY=Math.min(minY,box2.centerY),maxY=Math.max(maxY,box2.centerY);let padding=2;return{minX:minX-padding,maxX:maxX+padding,minY:minY-padding,maxY:maxY+padding}}_getAutorouterConfig(){let autorouter=this._parsedProps.autorouter||this.getInheritedProperty("autorouter");return getPresetAutoroutingConfig(autorouter)}_isLaserPrefabAutorouter(autorouterConfig2=this._getAutorouterConfig()){let autorouterProp2=this.props.autorouter,normalize3=value=>value?.replace(/-/g,"_")??value;return autorouterConfig2.preset==="laser_prefab"?!0:typeof autorouterProp2=="string"?normalize3(autorouterProp2)==="laser_prefab":typeof autorouterProp2=="object"&&autorouterProp2?normalize3(autorouterProp2.preset)==="laser_prefab":!1}_isAutoJumperAutorouter(autorouterConfig2=this._getAutorouterConfig()){let autorouterProp2=this.props.autorouter,normalize3=value=>value?.replace(/-/g,"_")??value;return autorouterConfig2.preset==="auto_jumper"?!0:typeof autorouterProp2=="string"?normalize3(autorouterProp2)==="auto_jumper":typeof autorouterProp2=="object"&&autorouterProp2?normalize3(autorouterProp2.preset)==="auto_jumper":!1}_getSubcircuitLayerCount(){let layers=this.getInheritedProperty("layers");return typeof layers=="number"?layers:2}_shouldUseTraceByTraceRouting(){return this._getAutorouterConfig().groupMode==="sequential-trace"}doInitialPcbDesignRuleChecks(){if(this.root?.pcbDisabled||this.root?.pcbRoutingDisabled||this.getInheritedProperty("routingDisabled"))return;let{db:db2}=this.root;if(this.isSubcircuit){let subcircuitComponentsByName=new Map;for(let child of this.children)if(!child.isSubcircuit&&child._parsedProps.name){let components=subcircuitComponentsByName.get(child._parsedProps.name)||[];components.push(child),subcircuitComponentsByName.set(child._parsedProps.name,components)}for(let[name,components]of subcircuitComponentsByName.entries())components.length>1&&db2.pcb_trace_error.insert({error_type:"pcb_trace_error",message:`Multiple components found with name "${name}" in subcircuit "${this.name||"unnamed"}". Component names must be unique within a subcircuit.`,source_trace_id:"",pcb_trace_id:"",pcb_component_ids:components.map(c4=>c4.pcb_component_id).filter(Boolean),pcb_port_ids:[]})}}doInitialSchematicReplaceNetLabelsWithSymbols(){if(this.root?.schematicDisabled||!this.isSubcircuit)return;let{db:db2}=this.root,subtree=db2;for(let nl3 of subtree.schematic_net_label.list()){let net=subtree.source_net.get(nl3.source_net_id),text=nl3.text||net?.name||"";if(nl3.anchor_side==="top"&&/^gnd/i.test(text)){subtree.schematic_net_label.update(nl3.schematic_net_label_id,{symbol_name:"rail_down"});continue}nl3.anchor_side==="bottom"&&/^v/i.test(text)&&subtree.schematic_net_label.update(nl3.schematic_net_label_id,{symbol_name:"rail_up"})}}doInitialSimulationSpiceEngineRender(){Group_doInitialSimulationSpiceEngineRender(this)}doInitialPcbComponentAnchorAlignment(){Group_doInitialPcbComponentAnchorAlignment(this)}updatePcbComponentAnchorAlignment(){this.doInitialPcbComponentAnchorAlignment()}doInitialPcbCalcPlacementResolution(){Group_doInitialPcbCalcPlacementResolution(this)}updatePcbCalcPlacementResolution(){this.doInitialPcbCalcPlacementResolution()}_getMinimumFlexContainerSize(){return super._getMinimumFlexContainerSize()}_repositionOnPcb(position4){return super._repositionOnPcb(position4)}};function inflateSourceGroup(sourceGroup,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbGroup=injectionDb.pcb_group.getWhere({source_group_id:sourceGroup.source_group_id}),groupProps2={name:sourceGroup.name??`inflated_group_${sourceGroup.source_group_id}`};if(pcbGroup?.position_mode==="relative_to_group_anchor"&&pcbGroup.anchor_position){let baseAnchor={x:0,y:0};if(sourceGroup.parent_source_group_id){let parentPcbGroup=injectionDb.pcb_group.getWhere({source_group_id:sourceGroup.parent_source_group_id});parentPcbGroup?.anchor_position&&(baseAnchor=parentPcbGroup.anchor_position)}groupProps2.pcbX=pcbGroup.anchor_position.x-baseAnchor.x,groupProps2.pcbY=pcbGroup.anchor_position.y-baseAnchor.y}pcbGroup?.anchor_alignment&&(groupProps2.pcbAnchorAlignment=pcbGroup.anchor_alignment);let group=new Group6(groupProps2);return group._isInflatedFromCircuitJson=!0,group.source_group_id=sourceGroup.source_group_id,groupsMap&&groupsMap.set(sourceGroup.source_group_id,group),sourceGroup.parent_source_group_id&&groupsMap?.has(sourceGroup.parent_source_group_id)?groupsMap.get(sourceGroup.parent_source_group_id).add(group):subcircuit.add(group),group}var Inductor=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"_adjustSilkscreenTextAutomatically",!0)}get config(){return{componentName:"Inductor",schematicSymbolName:this.props.symbolName??"inductor",zodProps:inductorProps,sourceFtype:FTYPE.simple_inductor}}_getSchematicSymbolDisplayValue(){return`${formatSiUnit(this._parsedProps.inductance)}H`}initPorts(){super.initPorts({additionalAliases:{pin1:["anode","pos","left"],pin2:["cathode","neg","right"]}})}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({name:this.name,ftype:FTYPE.simple_inductor,inductance:this.props.inductance,display_inductance:this._getSchematicSymbolDisplayValue(),supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourceInductor(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),inductor=new Inductor({name:sourceElm.name,inductance:sourceElm.inductance,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:inductor});footprint&&inductor.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(inductor):subcircuit.add(inductor)}function inflateSourcePort(sourcePort,inflatorContext){let{injectionDb,subcircuit}=inflatorContext;if(sourcePort.source_component_id!==null)return;let pcbPortFromInjection=injectionDb.pcb_port.getWhere({source_port_id:sourcePort.source_port_id}),port=new Port({name:sourcePort.name,pinNumber:sourcePort.pin_number});subcircuit.add(port),port.source_port_id=sourcePort.source_port_id;let root=subcircuit.root;if(root&&pcbPortFromInjection){let{db:db2}=root,pcb_port3=db2.pcb_port.insert({pcb_component_id:void 0,layers:pcbPortFromInjection.layers,subcircuit_id:subcircuit.subcircuit_id??void 0,pcb_group_id:subcircuit.getGroup()?.pcb_group_id??void 0,x:pcbPortFromInjection.x,y:pcbPortFromInjection.y,source_port_id:sourcePort.source_port_id,is_board_pinout:!1});port.pcb_port_id=pcb_port3.pcb_port_id}}var PushButton=class extends NormalComponent3{get config(){return{componentName:"PushButton",schematicSymbolName:this.props.symbolName??"push_button_normally_open_momentary",zodProps:pushButtonProps,sourceFtype:FTYPE.simple_push_button}}get defaultInternallyConnectedPinNames(){return[]}initPorts(){super.initPorts({pinCount:2,ignoreSymbolPorts:!0});let symbol=Vf[this._getSchematicSymbolNameOrThrow()],symPort1=symbol.ports.find(p4=>p4.labels.includes("1")),symPort2=symbol.ports.find(p4=>p4.labels.includes("2")),ports=this.selectAll("port"),pin1Port=ports.find(p4=>p4.props.pinNumber===1),pin2Port=ports.find(p4=>p4.props.pinNumber===2),pin3Port=ports.find(p4=>p4.props.pinNumber===3),pin4Port=ports.find(p4=>p4.props.pinNumber===4),{internallyConnectedPins}=this._parsedProps;pin1Port.schematicSymbolPortDef=symPort1,(!internallyConnectedPins||internallyConnectedPins.length===0)&&(pin2Port.schematicSymbolPortDef=symPort2);for(let[pn3,port]of[[2,pin2Port],[3,pin3Port],[4,pin4Port]]){let internallyConnectedRow=internallyConnectedPins?.find(([pin1,pin2])=>pin1===`pin${pn3}`||pin2===`pin${pn3}`);if(!internallyConnectedRow){port.schematicSymbolPortDef=symPort2;break}(internallyConnectedRow?.[0]===`pin${pn3}`?internallyConnectedRow[1]:internallyConnectedRow?.[0])!=="pin1"&&(port.schematicSymbolPortDef=symPort2)}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({name:this.name,ftype:FTYPE.simple_push_button,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourcePushButton(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),pushButton=new PushButton({name:sourceElm.name,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:pushButton});footprint&&pushButton.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(pushButton):subcircuit.add(pushButton)}var Resistor=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"_adjustSilkscreenTextAutomatically",!0)}get config(){return{componentName:"Resistor",schematicSymbolName:this.props.symbolName??"boxresistor",zodProps:resistorProps,sourceFtype:"simple_resistor"}}initPorts(){super.initPorts({additionalAliases:{pin1:["anode","pos","left"],pin2:["cathode","neg","right"]}})}_getSchematicSymbolDisplayValue(){return`${formatSiUnit(this._parsedProps.resistance)}\u03A9`}doInitialCreateNetsFromProps(){this._createNetsFromProps([this.props.pullupFor,this.props.pullupTo,this.props.pulldownFor,this.props.pulldownTo,...this._getNetsFromConnectionsProp()])}doInitialCreateTracesFromProps(){this.props.pullupFor&&this.props.pullupTo&&(this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.1`,to:this.props.pullupFor})),this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.2`,to:this.props.pullupTo}))),this.props.pulldownFor&&this.props.pulldownTo&&(this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.1`,to:this.props.pulldownFor})),this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.2`,to:this.props.pulldownTo}))),this._createTracesFromConnectionsProp()}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_resistor",name:this.name,manufacturer_part_number:props.manufacturerPartNumber??props.mfn,supplier_part_numbers:props.supplierPartNumbers,resistance:props.resistance,display_resistance:this._getSchematicSymbolDisplayValue(),are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourceResistor(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),resistor=new Resistor({name:sourceElm.name,resistance:sourceElm.resistance,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:resistor});footprint&&resistor.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(resistor):subcircuit.add(resistor)}function pcbTraceRouteToPcbPath(route){if(route.length<=2)return[];let firstPoint=route[0],lastPoint=route[route.length-1];return route.slice(1,-1).filter(point62=>{let isSameAsFirst=point62.x===firstPoint.x&&point62.y===firstPoint.y,isSameAsLast=point62.x===lastPoint.x&&point62.y===lastPoint.y;return!isSameAsFirst&&!isSameAsLast}).map(point62=>point62.route_type==="via"?{x:point62.x,y:point62.y,via:!0,fromLayer:point62.from_layer,toLayer:point62.to_layer}:{x:point62.x,y:point62.y})}var getSelectorPath=(component,inflatorContext)=>{let{injectionDb,subcircuit,groupsMap}=inflatorContext,path_parts=[],currentGroupId=component.source_group_id;for(;currentGroupId&&currentGroupId!==subcircuit.source_group_id;){let sourceGroup=injectionDb.source_group.get(currentGroupId),groupInstance=groupsMap?.get(currentGroupId);if(!sourceGroup||!groupInstance)break;let groupName=groupInstance.props.name??groupInstance.fallbackUnassignedName;path_parts.unshift(`.${groupName}`),currentGroupId=sourceGroup.parent_source_group_id}return path_parts.push(`.${component.name}`),path_parts.join(" > ")};function inflateSourceTrace(sourceTrace,inflatorContext){let{injectionDb,subcircuit}=inflatorContext,connectedSelectors=[];for(let sourcePortId of sourceTrace.connected_source_port_ids){let sourcePort=injectionDb.source_port.get(sourcePortId);if(!sourcePort)continue;let selector;if(sourcePort.source_component_id){let sourceComponent=injectionDb.source_component.get(sourcePort.source_component_id);sourceComponent&&(selector=`${getSelectorPath({name:sourceComponent.name,source_group_id:sourceComponent.source_group_id},inflatorContext)} > .${sourcePort.name}`)}else selector=`.${sourcePort.name}`;selector&&connectedSelectors.push(selector)}for(let sourceNetId of sourceTrace.connected_source_net_ids){let sourceNet=injectionDb.source_net.get(sourceNetId);sourceNet&&connectedSelectors.push(`net.${sourceNet.name}`)}if(connectedSelectors.length<2)return;let pcbTrace=injectionDb.pcb_trace.getWhere({source_trace_id:sourceTrace.source_trace_id}),pcbPath2;pcbTrace&&(pcbPath2=pcbTraceRouteToPcbPath(pcbTrace.route));let traceWidth=sourceTrace.min_trace_thickness;if(!traceWidth&&pcbTrace?.route){let wirePoint=pcbTrace.route.find(pt3=>pt3.route_type==="wire");wirePoint&&wirePoint.route_type==="wire"&&(traceWidth=wirePoint.width)}let traceProps2={path:connectedSelectors};traceWidth!==void 0&&(traceProps2.thickness=traceWidth),pcbPath2&&pcbPath2.length>0?traceProps2.pcbPath=pcbPath2:pcbTrace&&(traceProps2.pcbStraightLine=!0);let trace=new Trace3(traceProps2);subcircuit.add(trace)}var Transistor=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"emitter",this.portMap.pin1);__publicField(this,"collector",this.portMap.pin2);__publicField(this,"base",this.portMap.pin3)}get config(){let baseSymbolName=this.props.type==="npn"?"npn_bipolar_transistor":"pnp_bipolar_transistor";return{componentName:"Transistor",schematicSymbolName:this.props.symbolName??baseSymbolName,zodProps:transistorProps,sourceFtype:"simple_transistor",shouldRenderAsSchematicBox:!1}}initPorts(){let pinAliases={pin1:["collector","c"],pin2:["emitter","e"],pin3:["base","b"]};super.initPorts({pinCount:3,additionalAliases:pinAliases})}doInitialCreateNetsFromProps(){this._createNetsFromProps([...this._getNetsFromConnectionsProp()])}doInitialCreateTracesFromProps(){this._createTracesFromConnectionsProp()}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_transistor",name:this.name,transistor_type:props.type,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourceTransistor(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),transistor=new Transistor({name:sourceElm.name,type:sourceElm.transistor_type,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:transistor});footprint&&transistor.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(transistor):subcircuit.add(transistor)}function inflateStandalonePcbPrimitives(inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,standalonePrimitiveTypes=["pcb_silkscreen_rect","pcb_silkscreen_circle","pcb_silkscreen_line","pcb_silkscreen_path","pcb_silkscreen_text","pcb_fabrication_note_text","pcb_fabrication_note_path","pcb_fabrication_note_rect","pcb_note_text","pcb_note_rect","pcb_note_path","pcb_note_line"],standalonePrimitives=injectionDb.toArray().filter(elm=>standalonePrimitiveTypes.includes(elm.type)&&"pcb_component_id"in elm&&(elm.pcb_component_id===null||elm.pcb_component_id===void 0));if(standalonePrimitives.length===0)return;let components=createComponentsFromCircuitJson({componentName:"",componentRotation:"0deg"},standalonePrimitives);for(let component of components)subcircuit.add(component)}var inflateCircuitJson=(target,circuitJson,children)=>{if(!circuitJson)return;let injectionDb=cju_default(circuitJson);if(circuitJson&&children?.length>0)throw new Error("Component cannot have both circuitJson and children");let inflationCtx={injectionDb,subcircuit:target,groupsMap:new Map},sourceGroups=injectionDb.source_group.list(),renderedGroupIds=new Set,groupsToRender=[...sourceGroups];for(;groupsToRender.length>0;){let groupIndex=groupsToRender.findIndex(g6=>!g6.parent_source_group_id||renderedGroupIds.has(g6.parent_source_group_id));if(groupIndex===-1){let remainingIds=groupsToRender.map(g6=>g6.source_group_id).join(", ");throw new Error(`Cannot inflate source_groups: cyclic dependency or missing parent detected. Remaining groups: ${remainingIds}`)}let groupToRender=groupsToRender[groupIndex];inflateSourceGroup(groupToRender,inflationCtx),renderedGroupIds.add(groupToRender.source_group_id),groupsToRender.splice(groupIndex,1)}let pcbBoards=injectionDb.pcb_board.list();for(let pcbBoard of pcbBoards)inflatePcbBoard(pcbBoard,inflationCtx);let sourceComponents=injectionDb.source_component.list();for(let sourceComponent of sourceComponents)switch(sourceComponent.ftype){case"simple_resistor":inflateSourceResistor(sourceComponent,inflationCtx);break;case"simple_capacitor":inflateSourceCapacitor(sourceComponent,inflationCtx);break;case"simple_inductor":inflateSourceInductor(sourceComponent,inflationCtx);break;case"simple_diode":inflateSourceDiode(sourceComponent,inflationCtx);break;case"simple_chip":inflateSourceChip(sourceComponent,inflationCtx);break;case"simple_transistor":inflateSourceTransistor(sourceComponent,inflationCtx);break;case"simple_push_button":inflateSourcePushButton(sourceComponent,inflationCtx);break;default:throw new Error(`No inflator implemented for source component ftype: "${sourceComponent.ftype}"`)}let sourcePorts=injectionDb.source_port.list();for(let sourcePort of sourcePorts)inflateSourcePort(sourcePort,inflationCtx);let sourceTraces=injectionDb.source_trace.list();for(let sourceTrace of sourceTraces)inflateSourceTrace(sourceTrace,inflationCtx);inflateStandalonePcbPrimitives(inflationCtx)},package_default3={name:"@tscircuit/core",type:"module",version:"0.0.1212",types:"dist/index.d.ts",main:"dist/index.js",module:"dist/index.js",exports:{".":{import:"./dist/index.js",types:"./dist/index.d.ts"}},files:["dist"],repository:{type:"git",url:"https://github.com/tscircuit/core"},scripts:{build:"tsup-node",format:"biome format . --write","measure-bundle":"howfat -r table .","pkg-pr-new-release":"bunx pkg-pr-new publish --comment=off --peerDeps","smoke-test:dist":"bun run scripts/smoke-tests/test-dist-simple-circuit.tsx","build:benchmarking":"bun build --experimental-html ./benchmarking/website/index.html --outdir ./benchmarking-dist","build:benchmarking:watch":`chokidar "./{benchmarking,lib}/**/*.{ts,tsx}" -c 'bun build --experimental-html ./benchmarking/website/index.html --outdir ./benchmarking-dist'`,"start:benchmarking":'concurrently "bun run build:benchmarking:watch" "live-server ./benchmarking-dist"',"generate-test-plan":"bun run scripts/generate-test-plan.ts"},devDependencies:{"@biomejs/biome":"^1.8.3","@resvg/resvg-js":"^2.6.2","@tscircuit/alphabet":"0.0.25","@tscircuit/capacity-autorouter":"^0.0.485","@tscircuit/checks":"0.0.125","@tscircuit/circuit-json-util":"^0.0.94","@tscircuit/common":"^0.0.20","@tscircuit/copper-pour-solver":"^0.0.29","@tscircuit/footprinter":"^0.0.351","@tscircuit/infer-cable-insertion-point":"^0.0.2","@tscircuit/infgrid-ijump-astar":"^0.0.35","@tscircuit/jlcpcb-manufacturing-specs":"git+https://github.com/tscircuit/jlcpcb-manufacturing-specs#e08af159db01a37db007e33f0a7268d0e4a279a5","@tscircuit/log-soup":"^1.0.2","@tscircuit/matchpack":"^0.0.16","@tscircuit/math-utils":"^0.0.36","@tscircuit/miniflex":"^0.0.4","@tscircuit/ngspice-spice-engine":"^0.0.8","@tscircuit/props":"^0.0.513","@tscircuit/schematic-match-adapt":"^0.0.16","@tscircuit/schematic-trace-solver":"^0.0.51","@tscircuit/solver-utils":"^0.0.3","@tscircuit/soup-util":"^0.0.41","@types/bun":"^1.2.16","@types/debug":"^4.1.12","@types/react":"^19.1.8","@types/react-dom":"^19.1.6","@types/react-reconciler":"^0.28.9","bpc-graph":"^0.0.57","bun-match-svg":"0.0.12","calculate-elbow":"^0.0.12","chokidar-cli":"^3.0.0","circuit-json":"^0.0.421","circuit-json-to-bpc":"^0.0.13","circuit-json-to-connectivity-map":"^0.0.23","circuit-json-to-gltf":"^0.0.96","circuit-json-to-simple-3d":"^0.0.9","circuit-json-to-spice":"^0.0.34","circuit-to-svg":"^0.0.345",concurrently:"^9.1.2","connectivity-map":"^1.0.0",debug:"^4.3.6","eecircuit-engine":"^1.5.6",flatbush:"^4.5.0","graphics-debug":"^0.0.89",howfat:"^0.3.8","live-server":"^1.2.2","looks-same":"^9.0.1",minicssgrid:"^0.0.9","pkg-pr-new":"^0.0.37",poppygl:"^0.0.16",react:"^19.1.0","react-dom":"^19.1.0","schematic-symbols":"^0.0.208",spicey:"^0.0.14","ts-expect":"^1.3.0",tsup:"^8.2.4"},peerDependencies:{"@tscircuit/capacity-autorouter":"*","@tscircuit/checks":"*","@tscircuit/circuit-json-util":"*","@tscircuit/footprinter":"*","@tscircuit/infgrid-ijump-astar":"*","@tscircuit/math-utils":"*","@tscircuit/props":"*","@tscircuit/schematic-match-adapt":"*","circuit-json-to-bpc":"*","bpc-graph":"*","@tscircuit/matchpack":"*","circuit-json":"*","circuit-json-to-connectivity-map":"*","schematic-symbols":"*",typescript:"^5.0.0"},dependencies:{"@flatten-js/core":"^1.6.2","@lume/kiwi":"^0.4.3","calculate-packing":"0.0.71","css-select":"5.1.0","format-si-unit":"^0.0.3",nanoid:"^5.0.7","performance-now":"^2.1.0","react-reconciler":"^0.32.0","svg-path-commander":"^2.1.11","transformation-matrix":"^2.16.1",zod:"^3.25.67"}},IsolatedCircuit=class{constructor({platform,projectUrl,cachedSubcircuits,pendingSubcircuitRenders}={}){__publicField(this,"firstChild",null);__publicField(this,"children");__publicField(this,"db");__publicField(this,"root",null);__publicField(this,"isRootCircuit",!1);__publicField(this,"cachedSubcircuits");__publicField(this,"pendingSubcircuitRenders");__publicField(this,"_schematicDisabledOverride");__publicField(this,"pcbDisabled",!1);__publicField(this,"pcbRoutingDisabled",!1);__publicField(this,"_featureMspSchematicTraceRouting",!0);__publicField(this,"name");__publicField(this,"platform");__publicField(this,"projectUrl");__publicField(this,"_hasRenderedAtleastOnce",!1);__publicField(this,"_asyncEffectIdsByPhase",new Map);__publicField(this,"_asyncEffectPhaseById",new Map);__publicField(this,"_runningAsyncEffectsById",new Map);__publicField(this,"_eventListeners",{});this.children=[],this.db=su2([]),this.platform=platform,this.projectUrl=projectUrl,this.pcbDisabled=platform?.pcbDisabled??!1,this.pcbRoutingDisabled=platform?.routingDisabled??!1,this.cachedSubcircuits=cachedSubcircuits,this.pendingSubcircuitRenders=pendingSubcircuitRenders,this.root=this}get schematicDisabled(){return this._schematicDisabledOverride!==void 0?this._schematicDisabledOverride:this.platform?.schematicDisabled!==void 0?this.platform.schematicDisabled:this._getBoard()?._parsedProps?.schematicDisabled??!1}set schematicDisabled(value){this._schematicDisabledOverride=value}add(componentOrElm){let component;(0,import_react4.isValidElement)(componentOrElm)?component=createInstanceFromReactElement(componentOrElm):component=componentOrElm,this.children.push(component)}setPlatform(platform){this.platform={...this.platform,...platform},platform.pcbDisabled!==void 0&&(this.pcbDisabled=platform.pcbDisabled),platform.routingDisabled!==void 0&&(this.pcbRoutingDisabled=platform.routingDisabled)}_getBoard(){let directBoard=this.children.find(c4=>c4.componentName==="Board");if(directBoard)return directBoard}_guessRootComponent(){if(this.firstChild)return;if(this.children.length===0)throw new Error("Not able to guess root component: IsolatedCircuit has no children (use circuit.add(...))");let panels=this.children.filter(child=>child.lowercaseComponentName==="panel");if(panels.length>1)throw new Error("Only one <panel> is allowed per circuit");if(panels.length===1){if(this.children.length!==1)throw new Error("<panel> must be the root element of the circuit");this.firstChild=panels[0];return}if(this.children.length===1&&this.children[0].isGroup){this.firstChild=this.children[0];return}let group=new Group6({subcircuit:!0});group.parent=this,group.addAll(this.children),this.children=[group],this.firstChild=group}render(){this.firstChild||this._guessRootComponent();let{firstChild,db:db2}=this;if(!firstChild)throw new Error("IsolatedCircuit has no root component");firstChild.parent=this,firstChild.runRenderCycle(),this._hasRenderedAtleastOnce=!0}async renderUntilSettled(){for(this.db.source_project_metadata.list()?.[0]||this.db.source_project_metadata.insert({software_used_string:`@tscircuit/core@${this.getCoreVersion()}`,...this.projectUrl?{project_url:this.projectUrl}:{}}),this.render();this._hasIncompleteAsyncEffects();)await new Promise(resolve=>setTimeout(resolve,100)),this.render();this.emit("renderComplete")}_hasIncompleteAsyncEffects(){return this._asyncEffectPhaseById.size>0?!0:this.children.some(child=>child._hasIncompleteAsyncEffects())}_hasIncompleteAsyncEffectsForPhase(phase){return(this._asyncEffectIdsByPhase.get(phase)?.size??0)>0}getRunningAsyncEffects(){return Array.from(this._runningAsyncEffectsById.values())}getCircuitJson(){return this._hasRenderedAtleastOnce||this.render(),this.db.toArray()}toJson(){return this.getCircuitJson()}async getSvg(options){let circuitToSvg=await Promise.resolve().then(()=>(init_dist8(),dist_exports3)).catch(e5=>{throw new Error(`To use circuit.getSvg, you must install the "circuit-to-svg" package.
691
+ ${spiceString}`)}catch(error2){debug10(`Failed to convert circuit JSON to SPICE: ${error2}`);return}let graphNameToProbe=new Map;for(let probe of voltageProbes)probe.finalProbeName&&graphNameToProbe.set(probe.finalProbeName,probe);let voltageProbesById=new Map(voltageProbes.filter(probe=>probe.simulation_voltage_probe_id).map(probe=>[probe.simulation_voltage_probe_id,probe])),orderedSimulationProbes=root.db.simulation_voltage_probe.list().filter(probe=>voltageProbesById.has(probe.simulation_voltage_probe_id)),graphNamesFromNetlist=getTransientVoltageGraphNamesFromSpiceNetlist(spiceNetlist);if(graphNamesFromNetlist.length===orderedSimulationProbes.length)for(let[index,simulationProbe]of orderedSimulationProbes.entries()){let probe=voltageProbesById.get(simulationProbe.simulation_voltage_probe_id),graphName=graphNamesFromNetlist[index];probe&&graphName&&graphNameToProbe.set(graphName,probe)}else debug10(`Skipping probe-to-graph order mapping because counts differ: probes=${orderedSimulationProbes.length} graphNames=${graphNamesFromNetlist.length}`);for(let analogSim of analogSims){let engineName=analogSim._parsedProps.spiceEngine??"spicey",spiceEngine2=spiceEngineMap[engineName];if(!spiceEngine2)throw new Error(`SPICE engine "${engineName}" not found in platform config. Available engines: ${JSON.stringify(Object.keys(spiceEngineMap).filter(k4=>k4!=="spicey"))}`);let effectId=`spice-simulation-${engineName}-${analogSim.source_component_id}`;debug10(`Queueing simulation for spice engine: ${engineName} (id: ${effectId})`),group._queueAsyncEffect(effectId,async()=>{try{debug10(`Running simulation with engine: ${engineName}`);let result=await spiceEngine2.simulate(spiceString);debug10(`Simulation completed, received ${result.simulationResultCircuitJson.length} elements`);let simulationExperiment=root.db.simulation_experiment.list()[0];if(!simulationExperiment){debug10("No simulation experiment found, skipping result insertion");return}for(let element of result.simulationResultCircuitJson){if(element.type==="simulation_transient_voltage_graph"){element.simulation_experiment_id=simulationExperiment.simulation_experiment_id;let probeMatch=element.name?graphNameToProbe.get(element.name):void 0;probeMatch&&(element.color=probeMatch.color)}let elementType=element.type;elementType&&root.db[elementType]?(root.db[elementType].insert(element),debug10(`Inserted ${elementType} into database`)):(debug10(`Warning: Unknown element type ${elementType}, adding to raw db`),root.db._addElement(element))}group._markDirty("SimulationSpiceEngineRender")}catch(error2){debug10(`Simulation failed for engine ${engineName}: ${error2}`);let simulationExperiment=root.db.simulation_experiment.list()[0];root.db.simulation_unknown_experiment_error.insert({simulation_experiment_id:simulationExperiment?.simulation_experiment_id,error_type:"simulation_unknown_experiment_error",message:error2 instanceof Error?error2.message:String(error2)})}})}}function Group_doInitialSourceAddConnectivityMapKey(group){if(!group.isSubcircuit)return;let{db:db2}=group.root,traces=group.selectAll("trace"),vias=group.selectAll("via"),nets=group.selectAll("net"),connMap=new ConnectivityMap({});connMap.addConnections(traces.map(t52=>{let source_trace3=db2.source_trace.get(t52.source_trace_id);return source_trace3?[source_trace3.source_trace_id,...source_trace3.connected_source_port_ids,...source_trace3.connected_source_net_ids]:null}).filter(c4=>c4!==null));let sourceNets=db2.source_net.list().filter(net=>net.subcircuit_id===group.subcircuit_id);for(let sourceNet of sourceNets)connMap.addConnections([[sourceNet.source_net_id]]);let{name:subcircuitName}=group._parsedProps;for(let trace of traces){if(!trace.source_trace_id)continue;let connNetId=connMap.getNetConnectedToId(trace.source_trace_id);connNetId&&(trace.subcircuit_connectivity_map_key=`${subcircuitName??`unnamedsubcircuit${group._renderId}`}_${connNetId}`,db2.source_trace.update(trace.source_trace_id,{subcircuit_connectivity_map_key:trace.subcircuit_connectivity_map_key}))}let allSourcePortIds=new Set;for(let trace of traces){if(!trace.source_trace_id)continue;let source_trace3=db2.source_trace.get(trace.source_trace_id);if(source_trace3)for(let id2 of source_trace3.connected_source_port_ids)allSourcePortIds.add(id2)}for(let portId of allSourcePortIds){let connNetId=connMap.getNetConnectedToId(portId);if(!connNetId)continue;let connectivityMapKey=`${subcircuitName??`unnamedsubcircuit${group._renderId}`}_${connNetId}`;db2.source_port.update(portId,{subcircuit_connectivity_map_key:connectivityMapKey})}let allSourceNetIds=new Set;for(let trace of traces){if(!trace.source_trace_id)continue;let source_trace3=db2.source_trace.get(trace.source_trace_id);if(source_trace3)for(let source_net_id of source_trace3.connected_source_net_ids)allSourceNetIds.add(source_net_id)}for(let sourceNet of sourceNets)allSourceNetIds.add(sourceNet.source_net_id);for(let netId of allSourceNetIds){let connNetId=connMap.getNetConnectedToId(netId);if(!connNetId)continue;let connectivityMapKey=`${subcircuitName??`unnamedsubcircuit${group._renderId}`}_${connNetId}`;db2.source_net.update(netId,{subcircuit_connectivity_map_key:connectivityMapKey});let netInstance=nets.find(n4=>n4.source_net_id===netId);netInstance&&(netInstance.subcircuit_connectivity_map_key=connectivityMapKey)}for(let via of vias){let connectedNetOrTrace=via._getConnectedNetOrTrace();connectedNetOrTrace&&connectedNetOrTrace.subcircuit_connectivity_map_key&&(via.subcircuit_connectivity_map_key=connectedNetOrTrace.subcircuit_connectivity_map_key)}}function getPhaseSortValue(routingPhaseIndex){return routingPhaseIndex===null?Number.POSITIVE_INFINITY:routingPhaseIndex}function compareRoutingPhasePlans(a3,b3){return getPhaseSortValue(a3.routingPhaseIndex)-getPhaseSortValue(b3.routingPhaseIndex)}function getOrCreateRoutingPhasePlan(plansByPhaseIndex,routingPhaseIndex){let plan=plansByPhaseIndex.get(routingPhaseIndex);return plan||(plan={routingPhaseIndex,nets:[],traces:[]},plansByPhaseIndex.set(routingPhaseIndex,plan)),plan}function getNetRoutingPhaseIndex(net){return net.props.routingPhaseIndex??null}function getTraceRoutingPhaseIndex(trace){let traceRoutingPhaseIndex=trace.props.routingPhaseIndex;if(traceRoutingPhaseIndex!==void 0)return traceRoutingPhaseIndex;let routingPhaseIndex=null,connectedNets=trace._findConnectedNets().nets;for(let net of connectedNets){let netRoutingPhaseIndex=net.props.routingPhaseIndex;typeof netRoutingPhaseIndex=="number"&&(routingPhaseIndex===null||netRoutingPhaseIndex<routingPhaseIndex)&&(routingPhaseIndex=netRoutingPhaseIndex)}return routingPhaseIndex}function Group_getRoutingPhasePlans(group){let traces=group.selectAll("trace"),nets=group.selectAll("net");if(traces.length===0&&nets.length===0)return[];let plansByPhaseIndex=new Map;for(let net of nets){let routingPhaseIndex=getNetRoutingPhaseIndex(net);getOrCreateRoutingPhasePlan(plansByPhaseIndex,routingPhaseIndex).nets.push(net)}for(let trace of traces){let routingPhaseIndex=getTraceRoutingPhaseIndex(trace);getOrCreateRoutingPhasePlan(plansByPhaseIndex,routingPhaseIndex).traces.push(trace)}return Array.from(plansByPhaseIndex.values()).sort(compareRoutingPhasePlans)}function isWirePoint(point62){return point62.route_type==="wire"}function isViaPoint(point62){return point62.route_type==="via"}function isJumperPoint(point62){return point62.route_type==="jumper"}function getTraceConnectionName(trace){return trace.connection_name??trace.pcb_trace_id}function getWireWidth(start,end){return isWirePoint(start)?start.width:isWirePoint(end)?end.width:.1}function getSegmentLayer(start,end){return isWirePoint(start)?start.layer:isWirePoint(end)?end.layer:isJumperPoint(start)?start.layer:isJumperPoint(end)?end.layer:null}function getRoutePointX(point62){return isJumperPoint(point62)?null:point62.x}function getRoutePointY(point62){return isJumperPoint(point62)?null:point62.y}function createWireObstacle(start,end,connectedTo,obstacleIndex){let startX=getRoutePointX(start),startY=getRoutePointY(start),endX=getRoutePointX(end),endY=getRoutePointY(end),layer=getSegmentLayer(start,end);if(startX===null||startY===null||endX===null||endY===null||!layer)return null;let width=getWireWidth(start,end),dx3=Math.abs(startX-endX),dy3=Math.abs(startY-endY);return{obstacleId:`${connectedTo}_phase_obstacle_${obstacleIndex}`,type:"rect",layers:[layer],center:{x:(startX+endX)/2,y:(startY+endY)/2},width:dx3+width,height:dy3+width,connectedTo:[connectedTo]}}function createJumperObstacle(point62,connectedTo,obstacleIndex){let dx3=Math.abs(point62.start.x-point62.end.x),dy3=Math.abs(point62.start.y-point62.end.y),width=.6;return{obstacleId:`${connectedTo}_phase_jumper_obstacle_${obstacleIndex}`,type:"rect",layers:[point62.layer],center:{x:(point62.start.x+point62.end.x)/2,y:(point62.start.y+point62.end.y)/2},width:dx3+width,height:dy3+width,connectedTo:[connectedTo]}}function createViaObstacle(point62,connectedTo,obstacleIndex){return{obstacleId:`${connectedTo}_phase_via_obstacle_${obstacleIndex}`,type:"rect",layers:[point62.from_layer,point62.to_layer],center:{x:point62.x,y:point62.y},width:.6,height:.6,connectedTo:[connectedTo]}}function addTraceObstacles(obstacles,trace){let connectedTo=getTraceConnectionName(trace);for(let routeIndex=0;routeIndex<trace.route.length;routeIndex++){let routePoint=trace.route[routeIndex];if(isViaPoint(routePoint)?obstacles.push(createViaObstacle(routePoint,connectedTo,routeIndex)):isJumperPoint(routePoint)&&obstacles.push(createJumperObstacle(routePoint,connectedTo,routeIndex)),routeIndex===trace.route.length-1)continue;let nextPoint=trace.route[routeIndex+1],obstacle=createWireObstacle(routePoint,nextPoint,connectedTo,routeIndex);obstacle&&obstacles.push(obstacle)}}function connectionIsInRoutingPhase(connection,phasePlan){for(let trace of phasePlan.traces)if(trace.source_trace_id&&(connection.source_trace_id===trace.source_trace_id||connection.name===trace.source_trace_id))return!0;for(let net of phasePlan.nets)if(net.source_net_id&&connection.name===net.source_net_id)return!0;return!1}function Group_hasPhasedAutorouting(routingPhasePlans){for(let plan of routingPhasePlans)if(plan.routingPhaseIndex!==null)return!0;return!1}function Group_filterSimpleRouteJsonForPhase(simpleRouteJson,phasePlan){let connections=[];for(let connection of simpleRouteJson.connections)connectionIsInRoutingPhase(connection,phasePlan)&&connections.push(connection);return{...simpleRouteJson,connections}}function Group_getObstaclesFromRoutedTraces(traces){let obstacles=[];for(let trace of traces)addTraceObstacles(obstacles,trace);return obstacles}function getJumperPadInfos(db2){let padInfos=[],jumperSmtpads=db2.pcb_smtpad.list().filter(pad2=>{let component=db2.pcb_component.get(pad2.pcb_component_id);return component?db2.source_component.get(component.source_component_id)?.name?.startsWith("__autoplaced_jumper"):!1});for(let smtpad2 of jumperSmtpads)if(smtpad2.shape!=="polygon"&&smtpad2.pcb_port_id){if(smtpad2.shape==="rect"||smtpad2.shape==="rotated_rect"){let halfWidth=smtpad2.width/2,halfHeight=smtpad2.height/2;padInfos.push({pcb_port_id:smtpad2.pcb_port_id,x:smtpad2.x,y:smtpad2.y,minX:smtpad2.x-halfWidth,maxX:smtpad2.x+halfWidth,minY:smtpad2.y-halfHeight,maxY:smtpad2.y+halfHeight})}else if(smtpad2.shape==="circle"){let radius=smtpad2.radius;padInfos.push({pcb_port_id:smtpad2.pcb_port_id,x:smtpad2.x,y:smtpad2.y,minX:smtpad2.x-radius,maxX:smtpad2.x+radius,minY:smtpad2.y-radius,maxY:smtpad2.y+radius})}}return padInfos}function findJumperPortAtPosition(padInfos,x4,y4,tolerance=.01){for(let pad2 of padInfos)if(Math.abs(pad2.x-x4)<tolerance&&Math.abs(pad2.y-y4)<tolerance)return pad2.pcb_port_id}function findJumperPortContainingPoint(padInfos,x4,y4){for(let pad2 of padInfos)if(x4>=pad2.minX&&x4<=pad2.maxX&&y4>=pad2.minY&&y4<=pad2.maxY)return pad2}function splitRouteAtJumperPads(route,padInfos){if(route.length===0||padInfos.length===0)return[route];let segments=[],currentSegment=[];for(let i3=0;i3<route.length;i3++){let point62=route[i3];if(currentSegment.push(point62),point62.route_type==="wire"&&i3>0&&i3<route.length-1){let padInfo=findJumperPortContainingPoint(padInfos,point62.x,point62.y);if(padInfo){point62.end_pcb_port_id||(point62.end_pcb_port_id=padInfo.pcb_port_id),segments.push(currentSegment);let newStartPoint={...point62};delete newStartPoint.end_pcb_port_id,newStartPoint.start_pcb_port_id||(newStartPoint.start_pcb_port_id=padInfo.pcb_port_id),currentSegment=[newStartPoint]}}}return currentSegment.length>0&&segments.push(currentSegment),segments}function addPortIdsToTracesAtJumperPads(segments,db2){let padInfos=getJumperPadInfos(db2);if(padInfos.length===0)return segments;let result=[];for(let segment2 of segments){let subSegments=splitRouteAtJumperPads(segment2,padInfos);for(let subSegment of subSegments)if(subSegment.length>0){let firstPoint=subSegment[0],lastPoint=subSegment[subSegment.length-1];if(firstPoint.route_type==="wire"&&!firstPoint.start_pcb_port_id){let portId=findJumperPortAtPosition(padInfos,firstPoint.x,firstPoint.y);portId&&(firstPoint.start_pcb_port_id=portId)}if(lastPoint.route_type==="wire"&&!lastPoint.end_pcb_port_id){let portId=findJumperPortAtPosition(padInfos,lastPoint.x,lastPoint.y);portId&&(lastPoint.end_pcb_port_id=portId)}result.push(subSegment)}}return result}function groupPadsByInternalConnection(pads,orientation4){let groups=[];for(let pad2 of pads){let key=orientation4==="vertical"?pad2.center.y:pad2.center.x,foundGroup=!1;for(let group of groups){let groupKey=orientation4==="vertical"?group[0].center.y:group[0].center.x;if(Math.abs(key-groupKey)<.01){group.push(pad2),foundGroup=!0;break}}foundGroup||groups.push([pad2])}return groups.filter(g6=>g6.length>=2)}function insertAutoplacedJumpers(params){let{db:db2,output_jumpers,subcircuit_id}=params;for(let jumperIndex=0;jumperIndex<output_jumpers.length;jumperIndex++){let jumper=output_jumpers[jumperIndex],sourceComponent=db2.source_component.insert({ftype:"simple_chip",name:`__autoplaced_jumper_${jumperIndex}`,supplier_part_numbers:{}}),rotation42=jumper.orientation==="horizontal"?0:90,firstPadLayer=jumper.pads[0]?.layer||jumper.pads[0]?.layers?.[0]||"top",pcbComponent=db2.pcb_component.insert({source_component_id:sourceComponent.source_component_id,center:jumper.center,rotation:rotation42,layer:firstPadLayer,width:jumper.width||0,height:jumper.height||0,obstructs_within_bounds:!1}),padData=[];for(let padIndex=0;padIndex<jumper.pads.length;padIndex++){let pad2=jumper.pads[padIndex],pinNumber=padIndex+1,sourcePort=db2.source_port.insert({source_component_id:sourceComponent.source_component_id,name:`pin${pinNumber}`,pin_number:pinNumber}),padLayer=pad2.layer||pad2.layers?.[0]||"top",pcbPort=db2.pcb_port.insert({pcb_component_id:pcbComponent.pcb_component_id,source_port_id:sourcePort.source_port_id,x:pad2.center.x,y:pad2.center.y,layers:[padLayer]}),pcbSmtpad=db2.pcb_smtpad.insert({pcb_component_id:pcbComponent.pcb_component_id,pcb_port_id:pcbPort.pcb_port_id,shape:"rect",x:pad2.center.x,y:pad2.center.y,width:pad2.width,height:pad2.height,layer:padLayer});padData.push({pad:pad2,sourcePortId:sourcePort.source_port_id,pcbSmtpadId:pcbSmtpad.pcb_smtpad_id})}let internalGroups=groupPadsByInternalConnection(jumper.pads,jumper.orientation);for(let group of internalGroups){let sourcePortIds=[];for(let groupPad of group){let padInfo=padData.find(p4=>Math.abs(p4.pad.center.x-groupPad.center.x)<.01&&Math.abs(p4.pad.center.y-groupPad.center.y)<.01);padInfo&&sourcePortIds.push(padInfo.sourcePortId)}sourcePortIds.length>=2&&db2.source_component_internal_connection.insert({source_component_id:sourceComponent.source_component_id,subcircuit_id:subcircuit_id??void 0,source_port_ids:sourcePortIds})}}}function splitPcbTracesOnJumperSegments(route){let jumperRoutes=route.filter(p4=>p4.route_type==="jumper"),wireAndViaRoutes=route.filter(p4=>p4.route_type!=="jumper");if(jumperRoutes.length===0)return null;let splitRanges=[];for(let jumperRoute of jumperRoutes){let jumperStart=jumperRoute.start,jumperEnd=jumperRoute.end,startIdx=-1,endIdx=-1,minStartDist=1/0,minEndDist=1/0;for(let i3=0;i3<wireAndViaRoutes.length;i3++){let p4=wireAndViaRoutes[i3];if(p4.route_type!=="wire")continue;let distToStart=Math.hypot(p4.x-jumperStart.x,p4.y-jumperStart.y),distToEnd=Math.hypot(p4.x-jumperEnd.x,p4.y-jumperEnd.y);distToStart<minStartDist&&(minStartDist=distToStart,startIdx=i3),distToEnd<minEndDist&&(minEndDist=distToEnd,endIdx=i3)}startIdx>endIdx&&([startIdx,endIdx]=[endIdx,startIdx]),startIdx>=0&&endIdx>=0&&startIdx!==endIdx&&splitRanges.push({startIdx,endIdx})}splitRanges.sort((a3,b3)=>a3.startIdx-b3.startIdx);let segments=[],currentStart=0;for(let range2 of splitRanges)currentStart<range2.startIdx&&segments.push(wireAndViaRoutes.slice(currentStart,range2.startIdx+1)),currentStart=range2.endIdx;return currentStart<wireAndViaRoutes.length&&segments.push(wireAndViaRoutes.slice(currentStart)),segments}function computeCenterFromAnchorPosition(anchorPosition,ctx){let{width,height,pcbAnchorAlignment}=ctx;if(!pcbAnchorAlignment)return anchorPosition;let alignment=pcbAnchorAlignment;if(typeof width!="number"||typeof height!="number")return console.log("width or height is not a number"),anchorPosition;let ax3=anchorPosition.x,ay3=anchorPosition.y;switch(alignment){case"top_left":return{x:ax3+width/2,y:ay3-height/2};case"top_center":return{x:ax3,y:ay3-height/2};case"top_right":return{x:ax3-width/2,y:ay3-height/2};case"center_left":return{x:ax3+width/2,y:ay3};case"center_right":return{x:ax3-width/2,y:ay3};case"bottom_left":return{x:ax3+width/2,y:ay3+height/2};case"bottom_center":return{x:ax3,y:ay3+height/2};case"bottom_right":return{x:ax3-width/2,y:ay3+height/2};default:return anchorPosition}}var Group6=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"pcb_group_id",null);__publicField(this,"schematic_group_id",null);__publicField(this,"subcircuit_id",null);__publicField(this,"_hasStartedAsyncAutorouting",!1);__publicField(this,"_isInflatedFromCircuitJson",!1);__publicField(this,"_isolatedCircuitJson",null);__publicField(this,"_normalComponentNameMap",null);__publicField(this,"_asyncAutoroutingResult",null);__publicField(this,"unnamedElementCounter",{})}get _isIsolatedSubcircuit(){return!!this.getInheritedProperty("_subcircuitCachingEnabled")}getNormalComponentNameMap(){if(this._normalComponentNameMap)return this._normalComponentNameMap;let nameMap=new Map,collectNamedComponents=component=>{if(component._isNormalComponent&&component.name){let componentsWithSameName=nameMap.get(component.name);componentsWithSameName?componentsWithSameName.push(component):nameMap.set(component.name,[component])}for(let child of component.children)child.isSubcircuit||collectNamedComponents(child)};for(let child of this.children)child.isSubcircuit||collectNamedComponents(child);return this._normalComponentNameMap=nameMap,nameMap}get config(){return{zodProps:groupProps,componentName:"Group"}}_ensureSchematicBoxPortsFromConnections(){if(this._parsedProps?.showAsSchematicBox&&this._parsedProps?.connections)for(let[pinName,target]of Object.entries(this._parsedProps.connections)){if(this.children.find(child=>child.componentName==="Port"&&child.isMatchingAnyOf([pinName])))continue;let pinNumberMatch=pinName.match(/^pin(\d+)$/i)??pinName.match(/^(\d+)$/),pinNumber=pinNumberMatch?Number(pinNumberMatch[1]):void 0;this.add(new Port({name:pinName,pinNumber,connectsTo:target}))}}doInitialInitializePortsFromChildren(){super.doInitialInitializePortsFromChildren(),this._ensureSchematicBoxPortsFromConnections()}updateInitializePortsFromChildren(){super.updateInitializePortsFromChildren(),this._ensureSchematicBoxPortsFromConnections()}_getPrimaryPinCount(){let superPinCount=super._getPrimaryPinCount();if(!this._parsedProps?.showAsSchematicBox)return superPinCount;let directPortPinNumbers=this.children.filter(child=>child.componentName==="Port").map(port=>port._parsedProps.pinNumber).filter(pinNumber=>pinNumber!==void 0);return directPortPinNumbers.length===0?superPinCount:Math.max(superPinCount,...directPortPinNumbers)}_getPinLabelsFromPorts(){return this._parsedProps?.showAsSchematicBox?getGroupSchematicBoxPinLabels(this):super._getPinLabelsFromPorts()}doInitialSourceGroupRender(){let{db:db2}=this.root,hasExplicitName=typeof this._parsedProps.name=="string"&&this._parsedProps.name.length>0,source_group3=db2.source_group.insert({name:this.name,is_subcircuit:this.isSubcircuit,was_automatically_named:!hasExplicitName});this.source_group_id=source_group3.source_group_id,this.isSubcircuit&&(this.subcircuit_id=`subcircuit_${source_group3.source_group_id}`,db2.source_group.update(source_group3.source_group_id,{subcircuit_id:this.subcircuit_id}))}doInitialSourceRender(){let{db:db2}=this.root;for(let child of this.children)db2.source_component.update(child.source_component_id,{source_group_id:this.source_group_id})}doInitialSourceParentAttachment(){let{db:db2}=this.root,parentGroup=this.parent?.getGroup?.();if(parentGroup?.source_group_id&&db2.source_group.update(this.source_group_id,{parent_source_group_id:parentGroup.source_group_id}),!this.isSubcircuit)return;let parent_subcircuit_id=this.parent?.getSubcircuit?.()?.subcircuit_id;parent_subcircuit_id&&db2.source_group.update(this.source_group_id,{parent_subcircuit_id})}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,groupProps2=props,hasOutline=groupProps2.outline&&groupProps2.outline.length>0,numericOutline=hasOutline?groupProps2.outline.map(point62=>({x:distance.parse(point62.x),y:distance.parse(point62.y)})):void 0,ctx=this.props,anchorPosition=this._getGlobalPcbPositionBeforeLayout(),center2=computeCenterFromAnchorPosition(anchorPosition,ctx),pcb_group3=db2.pcb_group.insert({is_subcircuit:this.isSubcircuit,subcircuit_id:this.subcircuit_id??this.getSubcircuit()?.subcircuit_id,name:this.name,anchor_position:anchorPosition,center:center2,...hasOutline?{outline:numericOutline}:{width:0,height:0},pcb_component_ids:[],source_group_id:this.source_group_id,autorouter_configuration:props.autorouter?{trace_clearance:props.autorouter.traceClearance}:void 0,anchor_alignment:props.pcbAnchorAlignment??null});this.pcb_group_id=pcb_group3.pcb_group_id;for(let child of this.children)db2.pcb_component.update(child.pcb_component_id,{pcb_group_id:pcb_group3.pcb_group_id})}doInitialPcbPrimitiveRender(){this.calculatePcbGroupBounds()}calculatePcbGroupBounds(){if(!this.pcb_group_id||this.root?.pcbDisabled)return;let{db:db2}=this.root,props=this._parsedProps,hasOutline=props.outline&&props.outline.length>0,hasExplicitPositioning=this._parsedProps.pcbX!==void 0||this._parsedProps.pcbY!==void 0;if(hasOutline){let numericOutline=props.outline.map(point62=>({x:distance.parse(point62.x),y:distance.parse(point62.y)})),outlineBounds=getBoundsFromPoints(numericOutline);if(!outlineBounds)return;let centerX2=(outlineBounds.minX+outlineBounds.maxX)/2,centerY2=(outlineBounds.minY+outlineBounds.maxY)/2,center22=hasExplicitPositioning?db2.pcb_group.get(this.pcb_group_id)?.center??{x:centerX2,y:centerY2}:{x:centerX2,y:centerY2};db2.pcb_group.update(this.pcb_group_id,{center:center22});return}let bounds=getBoundsOfPcbComponents(this.children),width=bounds.width,height=bounds.height,centerX=(bounds.minX+bounds.maxX)/2,centerY=(bounds.minY+bounds.maxY)/2;if(this.isSubcircuit){let{padLeft,padRight,padTop,padBottom}=this._resolvePcbPadding();width+=padLeft+padRight,height+=padTop+padBottom,centerX+=(padRight-padLeft)/2,centerY+=(padTop-padBottom)/2}let center2=hasExplicitPositioning?db2.pcb_group.get(this.pcb_group_id)?.center??{x:centerX,y:centerY}:{x:centerX,y:centerY};db2.pcb_group.update(this.pcb_group_id,{width:Number(props.width??width),height:Number(props.height??height),center:center2})}updatePcbPrimitiveRender(){this.calculatePcbGroupBounds()}getNextAvailableName(elm){var _a362,_b3;return(_a362=this.unnamedElementCounter)[_b3=elm.lowercaseComponentName]??(_a362[_b3]=1),`unnamed_${elm.lowercaseComponentName}${this.unnamedElementCounter[elm.lowercaseComponentName]++}`}_resolvePcbPadding(){let props=this._parsedProps,layout=props.pcbLayout,getPaddingValue=key=>{let layoutValue=layout?.[key],propsValue=props[key];if(typeof layoutValue=="number")return layoutValue;if(typeof propsValue=="number")return propsValue},generalPadding=getPaddingValue("padding")??0,paddingX=getPaddingValue("paddingX"),paddingY=getPaddingValue("paddingY"),padLeft=getPaddingValue("paddingLeft")??paddingX??generalPadding,padRight=getPaddingValue("paddingRight")??paddingX??generalPadding,padTop=getPaddingValue("paddingTop")??paddingY??generalPadding,padBottom=getPaddingValue("paddingBottom")??paddingY??generalPadding;return{padLeft,padRight,padTop,padBottom}}doInitialCreateTraceHintsFromProps(){let{_parsedProps:props}=this,{db:db2}=this.root,groupProps2=props;if(!this.isSubcircuit)return;let manualTraceHints=groupProps2.manualEdits?.manual_trace_hints;if(manualTraceHints)for(let manualTraceHint of manualTraceHints)this.add(new TraceHint({for:manualTraceHint.pcb_port_selector,offsets:manualTraceHint.offsets}))}doInitialSourceAddConnectivityMapKey(){Group_doInitialSourceAddConnectivityMapKey(this)}_areChildSubcircuitsRouted(){let subcircuitChildren=this.selectAll("group").filter(g6=>g6.isSubcircuit);for(let subcircuitChild of subcircuitChildren)if(subcircuitChild._shouldRouteAsync()&&!subcircuitChild._asyncAutoroutingResult)return!1;return!0}_shouldRouteAsync(){let autorouter=this._getAutorouterConfig();return autorouter.groupMode==="sequential-trace"?!1:!!(autorouter.local&&autorouter.groupMode==="subcircuit"||!autorouter.local)}_getRoutingPhasePlans(){return Group_getRoutingPhasePlans(this)}_hasTracesToRoute(){let debug112=(0,import_debug11.default)("tscircuit:core:_hasTracesToRoute"),routingPhasePlans=this._getRoutingPhasePlans(),traceCount=0;for(let routingPhasePlan of routingPhasePlans)traceCount+=routingPhasePlan.traces.length;return debug112(`[${this.getString()}] has ${traceCount} traces to route`),traceCount>0}async _runEffectMakeHttpAutoroutingRequest(){let{db:db2}=this.root,debug112=(0,import_debug11.default)("tscircuit:core:_runEffectMakeHttpAutoroutingRequest"),props=this._parsedProps,autorouterConfig2=this._getAutorouterConfig(),serverUrl=autorouterConfig2.serverUrl,serverMode=autorouterConfig2.serverMode,fetchWithDebug=(url2,options)=>(debug112("fetching",url2),options.headers&&(options.headers["Tscircuit-Core-Version"]=this.root?.getCoreVersion()),fetch(url2,options)),pcbAndSourceCircuitJson=this.root.db.toArray().filter(element=>element.type.startsWith("source_")||element.type.startsWith("pcb_"));if(serverMode==="solve-endpoint"){if(this.props.autorouter?.inputFormat==="simplified"){let{autorouting_result:autorouting_result2}=await fetchWithDebug(`${serverUrl}/autorouting/solve`,{method:"POST",body:JSON.stringify({input_simple_route_json:getSimpleRouteJsonFromCircuitJson({db:db2,minTraceWidth:Number(props.minTraceWidth??.15),nominalTraceWidth:this.props.nominalTraceWidth,subcircuit_id:this.subcircuit_id,subcircuitComponent:this}).simpleRouteJson,subcircuit_id:this.subcircuit_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());this._asyncAutoroutingResult=autorouting_result2,this._markDirty("PcbTraceRender");return}let{autorouting_result}=await fetchWithDebug(`${serverUrl}/autorouting/solve`,{method:"POST",body:JSON.stringify({input_circuit_json:pcbAndSourceCircuitJson,subcircuit_id:this.subcircuit_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());this._asyncAutoroutingResult=autorouting_result,this._markDirty("PcbTraceRender");return}let{autorouting_job}=await fetchWithDebug(`${serverUrl}/autorouting/jobs/create`,{method:"POST",body:JSON.stringify({input_circuit_json:pcbAndSourceCircuitJson,provider:"freerouting",autostart:!0,display_name:this.root?.name,subcircuit_id:this.subcircuit_id,server_cache_enabled:autorouterConfig2.serverCacheEnabled}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());for(;;){let{autorouting_job:job}=await fetchWithDebug(`${serverUrl}/autorouting/jobs/get`,{method:"POST",body:JSON.stringify({autorouting_job_id:autorouting_job.autorouting_job_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());if(job.is_finished){let{autorouting_job_output}=await fetchWithDebug(`${serverUrl}/autorouting/jobs/get_output`,{method:"POST",body:JSON.stringify({autorouting_job_id:autorouting_job.autorouting_job_id}),headers:{"Content-Type":"application/json"}}).then(r5=>r5.json());this._asyncAutoroutingResult={output_pcb_traces:autorouting_job_output.output_pcb_traces},this._markDirty("PcbTraceRender");break}if(job.has_error){let err=new AutorouterError(`Autorouting job failed: ${JSON.stringify(job.error)}`);throw db2.pcb_autorouting_error.insert({pcb_error_id:autorouting_job.autorouting_job_id,error_type:"pcb_autorouting_error",message:err.message}),err}await new Promise(resolve=>setTimeout(resolve,100))}}async _runLocalAutorouting(){let{db:db2}=this.root,props=this._parsedProps,debug112=(0,import_debug11.default)("tscircuit:core:_runLocalAutorouting");debug112(`[${this.getString()}] starting local autorouting`);let autorouterConfig2=this._getAutorouterConfig(),isLaserPrefabPreset=this._isLaserPrefabAutorouter(autorouterConfig2),isAutoJumperPreset=this._isAutoJumperAutorouter(autorouterConfig2),isSingleLayerBoard=this._getSubcircuitLayerCount()===1,{simpleRouteJson:baseSimpleRouteJson}=getSimpleRouteJsonFromCircuitJson({db:db2,minTraceWidth:Number(props.minTraceWidth??.15),nominalTraceWidth:Number(props.nominalTraceWidth),subcircuit_id:this.subcircuit_id,subcircuitComponent:this}),routingPhasePlans=this._getRoutingPhasePlans(),hasPhasedAutorouting=Group_hasPhasedAutorouting(routingPhasePlans),outputTraces=[],outputJumpers=[];for(let routingPhasePlan of routingPhasePlans){let simpleRouteJson=baseSimpleRouteJson;if(hasPhasedAutorouting&&(simpleRouteJson=Group_filterSimpleRouteJsonForPhase(baseSimpleRouteJson,routingPhasePlan),simpleRouteJson.obstacles=[...simpleRouteJson.obstacles,...Group_getObstaclesFromRoutedTraces(outputTraces)]),hasPhasedAutorouting&&simpleRouteJson.connections.length===0)continue;if(isAutoJumperPreset&&(simpleRouteJson.allowJumpers=!0,autorouterConfig2.availableJumperTypes&&(simpleRouteJson.availableJumperTypes=autorouterConfig2.availableJumperTypes)),debug112.enabled&&global.debugOutputArray?.push({name:`simpleroutejson-${this.props.name}.json`,obj:simpleRouteJson}),debug112.enabled){let graphicsObject=Co2(simpleRouteJson);graphicsObject.title=`autorouting-${this.props.name}`,global.debugGraphics?.push(graphicsObject)}this.root?.emit("autorouting:start",{subcircuit_id:this.subcircuit_id,componentDisplayName:this.getString(),simpleRouteJson});let autorouter;if(autorouterConfig2.algorithmFn)autorouter=await autorouterConfig2.algorithmFn(simpleRouteJson);else{let autorouterVersion2=this.props.autorouterVersion,effortLevel=this.props.autorouterEffortLevel,effort=effortLevel?Number.parseInt(effortLevel.replace("x",""),10):void 0;autorouter=new TscircuitAutorouter(simpleRouteJson,{capacityDepth:this.props.autorouter?.capacityDepth,targetMinCapacity:this.props.autorouter?.targetMinCapacity,useAssignableSolver:isLaserPrefabPreset||isSingleLayerBoard,useAutoJumperSolver:isAutoJumperPreset,autorouterVersion:autorouterVersion2,effort,onSolverStarted:({solverName,solverParams})=>this.root?.emit("solver:started",{type:"solver:started",solverName,solverParams,componentName:this.getString()})})}let routingPromise=new Promise((resolve,reject)=>{autorouter.on("complete",event=>{debug112(`[${this.getString()}] local autorouting complete`),resolve(event.traces)}),autorouter.on("error",event=>{debug112(`[${this.getString()}] local autorouting error: ${event.error.message}`),reject(event.error)})});autorouter.on("progress",event=>{this.root?.emit("autorouting:progress",{subcircuit_id:this.subcircuit_id,componentDisplayName:this.getString(),...event})}),autorouter.start();try{let traces=await routingPromise;if(autorouter.getConnectedOffboardObstacles){let connectedOffboardObstacles=autorouter.getConnectedOffboardObstacles();createSourceTracesFromOffboardConnections({db:db2,connectedOffboardObstacles,simpleRouteJson,subcircuit_id:this.subcircuit_id})}let solver=autorouter.solver;solver?.getOutputJumpers&&outputJumpers.push(...solver.getOutputJumpers()||[]),outputTraces.push(...traces)}catch(error2){let{db:db22}=this.root;throw db22.pcb_autorouting_error.insert({pcb_error_id:`pcb_autorouter_error_subcircuit_${this.subcircuit_id}`,error_type:"pcb_autorouting_error",message:error2 instanceof Error?error2.message:String(error2)}),this.root?.emit("autorouting:error",{subcircuit_id:this.subcircuit_id,componentDisplayName:this.getString(),error:{message:error2 instanceof Error?error2.message:String(error2)},simpleRouteJson}),error2}finally{autorouter.stop()}}this._asyncAutoroutingResult={output_pcb_traces:outputTraces,output_jumpers:outputJumpers},this._markDirty("PcbTraceRender")}_startAsyncAutorouting(){this._hasStartedAsyncAutorouting||(this._hasStartedAsyncAutorouting=!0,this._getAutorouterConfig().local?this._queueAsyncEffect("capacity-mesh-autorouting",async()=>this._runLocalAutorouting()):this._queueAsyncEffect("make-http-autorouting-request",async()=>this._runEffectMakeHttpAutoroutingRequest()))}doInitialPcbTraceRender(){let debug112=(0,import_debug11.default)("tscircuit:core:doInitialPcbTraceRender");if(this.isSubcircuit&&!this.root?.pcbDisabled&&!(this.root?.pcbRoutingDisabled||this.getInheritedProperty("routingDisabled"))&&!this._isInflatedFromCircuitJson&&!this._shouldUseTraceByTraceRouting()){if(!this._areChildSubcircuitsRouted()){debug112(`[${this.getString()}] child subcircuits are not routed, skipping async autorouting until subcircuits routed`);return}debug112(`[${this.getString()}] no child subcircuits to wait for, initiating async routing`),this._hasTracesToRoute()&&this._startAsyncAutorouting()}}doInitialSchematicTraceRender(){this._parsedProps.showAsSchematicBox||Group_doInitialSchematicTraceRender(this)}updatePcbTraceRender(){let debug112=(0,import_debug11.default)("tscircuit:core:updatePcbTraceRender");if(debug112(`[${this.getString()}] updating...`),!this.isSubcircuit||this._isInflatedFromCircuitJson)return;if(this._shouldRouteAsync()&&this._hasTracesToRoute()&&!this._hasStartedAsyncAutorouting){this._areChildSubcircuitsRouted()&&(debug112(`[${this.getString()}] child subcircuits are now routed, starting async autorouting`),this._startAsyncAutorouting());return}if(!this._asyncAutoroutingResult||this._shouldUseTraceByTraceRouting())return;let{db:db2}=this.root;if(this._asyncAutoroutingResult.output_simple_route_json){debug112(`[${this.getString()}] updating PCB traces from simple route json (${this._asyncAutoroutingResult.output_simple_route_json.traces?.length} traces)`),this._updatePcbTraceRenderFromSimpleRouteJson();return}if(this._asyncAutoroutingResult.output_pcb_traces){debug112(`[${this.getString()}] updating PCB traces from ${this._asyncAutoroutingResult.output_pcb_traces.length} traces`),this._updatePcbTraceRenderFromPcbTraces();return}}_updatePcbTraceRenderFromSimpleRouteJson(){let{db:db2}=this.root,{traces:routedTraces}=this._asyncAutoroutingResult.output_simple_route_json;if(routedTraces)for(let routedTrace of routedTraces){let pcb_trace3=db2.pcb_trace.insert({subcircuit_id:this.subcircuit_id,route:routedTrace.route})}}_updatePcbTraceRenderFromPcbTraces(){let{output_pcb_traces,output_jumpers}=this._asyncAutoroutingResult;if(!output_pcb_traces)return;let{db:db2}=this.root,pcbStyle2=this.getInheritedMergedProperty("pcbStyle"),{holeDiameter,padDiameter}=getViaDiameterDefaults(pcbStyle2),board=db2.pcb_board.list()[0],routedViaHoleDiameter=board?.min_via_hole_diameter??holeDiameter,routedViaPadDiameter=board?.min_via_pad_diameter??padDiameter;output_jumpers&&output_jumpers.length>0&&insertAutoplacedJumpers({db:db2,output_jumpers,subcircuit_id:this.subcircuit_id});for(let pcb_trace3 of output_pcb_traces){if(pcb_trace3.type!=="pcb_trace")continue;if(pcb_trace3.subcircuit_id=this.subcircuit_id,pcb_trace3.connection_name){let sourceTraceId=pcb_trace3.connection_name;pcb_trace3.source_trace_id=sourceTraceId}let segments=splitPcbTracesOnJumperSegments(pcb_trace3.route);segments===null&&(segments=[pcb_trace3.route]);let processedSegments=addPortIdsToTracesAtJumperPads(segments,db2);for(let segment2 of processedSegments)segment2.length>0&&db2.pcb_trace.insert({...pcb_trace3,route:segment2})}for(let pcb_trace3 of output_pcb_traces)if(pcb_trace3.type!=="pcb_via"&&pcb_trace3.type==="pcb_trace"){for(let point62 of pcb_trace3.route)if(point62.route_type==="via"){let routedViaPoint=point62;db2.pcb_via.insert({pcb_trace_id:pcb_trace3.pcb_trace_id,x:point62.x,y:point62.y,hole_diameter:routedViaPoint.via_hole_diameter??routedViaPoint.hole_diameter??routedViaHoleDiameter,outer_diameter:routedViaPoint.via_diameter??routedViaPoint.outer_diameter??routedViaPadDiameter,layers:[point62.from_layer,point62.to_layer],from_layer:point62.from_layer,to_layer:point62.to_layer})}}}doInitialSchematicComponentRender(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,schematic_group3=db2.schematic_group.insert({is_subcircuit:this.isSubcircuit,subcircuit_id:this.subcircuit_id,name:this.name,center:this._getGlobalSchematicPositionBeforeLayout(),width:0,height:0,schematic_component_ids:[],source_group_id:this.source_group_id,show_as_schematic_box:props.showAsSchematicBox??!1});this.schematic_group_id=schematic_group3.schematic_group_id,props.showAsSchematicBox&&Group_doInitialSchematicBoxComponentRender(this);for(let child of this.children)child._parsedProps?.showAsSchematicBox||child.schematic_component_id&&db2.schematic_component.update(child.schematic_component_id,{schematic_group_id:schematic_group3.schematic_group_id})}_getSchematicLayoutMode(){let props=this._parsedProps,schAutoLayoutEnabled=props.schAutoLayoutEnabled??!1;if(props.schLayout?.layoutMode==="none"||props.schLayout?.layoutMode==="relative")return"relative";if(props.schLayout?.matchAdapt)return"match-adapt";if(props.schLayout?.flex)return"flex";if(props.schLayout?.grid)return"grid";if(props.schMatchAdapt)return"match-adapt";if(props.schFlex)return"flex";if(props.schGrid)return"grid";if(props.matchAdapt)return"match-adapt";if(props.flex)return"flex";if(props.grid)return"grid";if(props.relative||props.schRelative)return"relative";let anyLayoutChildHasSchCoords=this.children.some(child=>{let cProps=child._parsedProps;return(child.source_component_id!==null||child.source_group_id!==null)&&(cProps?.schX!==void 0||cProps?.schY!==void 0)}),hasManualEdits=(props.manualEdits?.schematic_placements?.length??0)>0;return schAutoLayoutEnabled&&!hasManualEdits||!anyLayoutChildHasSchCoords&&!hasManualEdits?"match-adapt":"relative"}doInitialSchematicLayout(){if(this._parsedProps.showAsSchematicBox){this._insertSchematicBorder();return}let schematicLayoutMode=this._getSchematicLayoutMode();schematicLayoutMode==="match-adapt"&&this._doInitialSchematicLayoutMatchpack(),schematicLayoutMode==="grid"&&this._doInitialSchematicLayoutGrid(),schematicLayoutMode==="flex"&&this._doInitialSchematicLayoutFlex(),this._insertSchematicBorder()}_doInitialSchematicLayoutMatchAdapt(){Group_doInitialSchematicLayoutMatchAdapt(this)}_doInitialSchematicLayoutMatchpack(){Group_doInitialSchematicLayoutMatchPack(this)}_doInitialSchematicLayoutGrid(){Group_doInitialSchematicLayoutGrid(this)}_doInitialSchematicLayoutFlex(){Group_doInitialSchematicLayoutFlex(this)}_getPcbLayoutMode(){let props=this._parsedProps,rawProps=this.props;if(this._isInflatedFromCircuitJson||props.pcbRelative)return"none";if(props.pcbLayout?.matchAdapt)return"match-adapt";if(props.pcbLayout?.flex)return"flex";if(props.pcbLayout?.grid)return"grid";if(props.pcbLayout?.pack)return"pack";if(props.pcbFlex)return"flex";if(props.pcbGrid)return"grid";if(props.pcbPack||props.pack)return"pack";if(props.matchAdapt)return"match-adapt";if(props.flex)return"flex";if(props.grid)return"grid";let groupHasCoords=props.pcbX!==void 0||props.pcbY!==void 0||props.pcbLeftEdgeX!==void 0||props.pcbRightEdgeX!==void 0||props.pcbTopEdgeY!==void 0||props.pcbBottomEdgeY!==void 0||rawProps.pcbLeftEdgeX!==void 0||rawProps.pcbRightEdgeX!==void 0||rawProps.pcbTopEdgeY!==void 0||rawProps.pcbBottomEdgeY!==void 0,hasManualEdits=(props.manualEdits?.pcb_placements?.length??0)>0,unpositionedDirectChildrenCount=this.children.reduce((count,child)=>{if(!child.pcb_component_id&&!child.pcb_group_id)return count;let childProps=child._parsedProps,rawChildProps=child.props,hasCoords=childProps?.pcbX!==void 0||childProps?.pcbY!==void 0||childProps?.pcbLeftEdgeX!==void 0||childProps?.pcbRightEdgeX!==void 0||childProps?.pcbTopEdgeY!==void 0||childProps?.pcbBottomEdgeY!==void 0||rawChildProps?.pcbLeftEdgeX!==void 0||rawChildProps?.pcbRightEdgeX!==void 0||rawChildProps?.pcbTopEdgeY!==void 0||rawChildProps?.pcbBottomEdgeY!==void 0;return count+(hasCoords?0:1)},0);return!hasManualEdits&&unpositionedDirectChildrenCount>1?"pack":"none"}doInitialPcbLayout(){if(this.root?.pcbDisabled)return;if(this.pcb_group_id){let{db:db2}=this.root,props=this._parsedProps;if(props.pcbX!==void 0||props.pcbY!==void 0){let parentGroup=this.parent?.getGroup?.(),pcbParentGroupId=parentGroup?.pcb_group_id?db2.pcb_group.get(parentGroup.pcb_group_id)?.pcb_group_id:void 0,positionedRelativeToBoardId=pcbParentGroupId?void 0:this._getBoard()?.pcb_board_id??void 0;db2.pcb_group.update(this.pcb_group_id,{position_mode:"relative_to_group_anchor",positioned_relative_to_pcb_group_id:pcbParentGroupId,positioned_relative_to_pcb_board_id:positionedRelativeToBoardId,display_offset_x:props.pcbX,display_offset_y:props.pcbY})}}let pcbLayoutMode=this._getPcbLayoutMode();pcbLayoutMode==="grid"?this._doInitialPcbLayoutGrid():pcbLayoutMode==="pack"?this._doInitialPcbLayoutPack():pcbLayoutMode==="flex"&&this._doInitialPcbLayoutFlex()}_doInitialPcbLayoutGrid(){Group_doInitialPcbLayoutGrid(this)}_doInitialPcbLayoutPack(){Group_doInitialPcbLayoutPack(this)}_doInitialPcbLayoutFlex(){Group_doInitialPcbLayoutFlex(this)}_insertSchematicBorder(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,props=this._parsedProps;if(!props.border)return;let width=typeof props.schWidth=="number"?props.schWidth:void 0,height=typeof props.schHeight=="number"?props.schHeight:void 0,paddingGeneral=typeof props.schPadding=="number"?props.schPadding:0,paddingLeft=typeof props.schPaddingLeft=="number"?props.schPaddingLeft:paddingGeneral,paddingRight=typeof props.schPaddingRight=="number"?props.schPaddingRight:paddingGeneral,paddingTop=typeof props.schPaddingTop=="number"?props.schPaddingTop:paddingGeneral,paddingBottom=typeof props.schPaddingBottom=="number"?props.schPaddingBottom:paddingGeneral,schematicGroup=this.schematic_group_id?db2.schematic_group.get(this.schematic_group_id):null;if(schematicGroup&&(width===void 0&&typeof schematicGroup.width=="number"&&(width=schematicGroup.width),height===void 0&&typeof schematicGroup.height=="number"&&(height=schematicGroup.height)),width===void 0||height===void 0)return;let center2=schematicGroup?.center??this._getGlobalSchematicPositionBeforeLayout(),left=center2.x-width/2-paddingLeft,bottom=center2.y-height/2-paddingBottom,finalWidth=width+paddingLeft+paddingRight,finalHeight=height+paddingTop+paddingBottom;db2.schematic_box.insert({width:finalWidth,height:finalHeight,x:left,y:bottom,is_dashed:props.border?.dashed??!1})}_determineSideFromPosition(port,component){if(!port.center||!component.center)return"left";let dx3=port.center.x-component.center.x,dy3=port.center.y-component.center.y;return Math.abs(dx3)>Math.abs(dy3)?dx3>0?"right":"left":dy3>0?"bottom":"top"}_calculateSchematicBounds(boxes){if(boxes.length===0)return{minX:0,maxX:0,minY:0,maxY:0};let minX=1/0,maxX=-1/0,minY=1/0,maxY=-1/0;for(let box2 of boxes)minX=Math.min(minX,box2.centerX),maxX=Math.max(maxX,box2.centerX),minY=Math.min(minY,box2.centerY),maxY=Math.max(maxY,box2.centerY);let padding=2;return{minX:minX-padding,maxX:maxX+padding,minY:minY-padding,maxY:maxY+padding}}_getAutorouterConfig(){let autorouter=this._parsedProps.autorouter||this.getInheritedProperty("autorouter");return getPresetAutoroutingConfig(autorouter)}_isLaserPrefabAutorouter(autorouterConfig2=this._getAutorouterConfig()){let autorouterProp2=this.props.autorouter,normalize3=value=>value?.replace(/-/g,"_")??value;return autorouterConfig2.preset==="laser_prefab"?!0:typeof autorouterProp2=="string"?normalize3(autorouterProp2)==="laser_prefab":typeof autorouterProp2=="object"&&autorouterProp2?normalize3(autorouterProp2.preset)==="laser_prefab":!1}_isAutoJumperAutorouter(autorouterConfig2=this._getAutorouterConfig()){let autorouterProp2=this.props.autorouter,normalize3=value=>value?.replace(/-/g,"_")??value;return autorouterConfig2.preset==="auto_jumper"?!0:typeof autorouterProp2=="string"?normalize3(autorouterProp2)==="auto_jumper":typeof autorouterProp2=="object"&&autorouterProp2?normalize3(autorouterProp2.preset)==="auto_jumper":!1}_getSubcircuitLayerCount(){let layers=this.getInheritedProperty("layers");return typeof layers=="number"?layers:2}_shouldUseTraceByTraceRouting(){return this._getAutorouterConfig().groupMode==="sequential-trace"}doInitialPcbDesignRuleChecks(){if(this.root?.pcbDisabled||this.root?.pcbRoutingDisabled||this.getInheritedProperty("routingDisabled"))return;let{db:db2}=this.root;if(this.isSubcircuit){let subcircuitComponentsByName=new Map;for(let child of this.children)if(!child.isSubcircuit&&child._parsedProps.name){let components=subcircuitComponentsByName.get(child._parsedProps.name)||[];components.push(child),subcircuitComponentsByName.set(child._parsedProps.name,components)}for(let[name,components]of subcircuitComponentsByName.entries())components.length>1&&db2.pcb_trace_error.insert({error_type:"pcb_trace_error",message:`Multiple components found with name "${name}" in subcircuit "${this.name||"unnamed"}". Component names must be unique within a subcircuit.`,source_trace_id:"",pcb_trace_id:"",pcb_component_ids:components.map(c4=>c4.pcb_component_id).filter(Boolean),pcb_port_ids:[]})}}doInitialSchematicReplaceNetLabelsWithSymbols(){if(this.root?.schematicDisabled||!this.isSubcircuit)return;let{db:db2}=this.root,subtree=db2;for(let nl3 of subtree.schematic_net_label.list()){let net=subtree.source_net.get(nl3.source_net_id),text=nl3.text||net?.name||"";if(nl3.anchor_side==="top"&&/^gnd/i.test(text)){subtree.schematic_net_label.update(nl3.schematic_net_label_id,{symbol_name:"rail_down"});continue}nl3.anchor_side==="bottom"&&/^v/i.test(text)&&subtree.schematic_net_label.update(nl3.schematic_net_label_id,{symbol_name:"rail_up"})}}doInitialSimulationSpiceEngineRender(){Group_doInitialSimulationSpiceEngineRender(this)}doInitialPcbComponentAnchorAlignment(){Group_doInitialPcbComponentAnchorAlignment(this)}updatePcbComponentAnchorAlignment(){this.doInitialPcbComponentAnchorAlignment()}doInitialPcbCalcPlacementResolution(){Group_doInitialPcbCalcPlacementResolution(this)}updatePcbCalcPlacementResolution(){this.doInitialPcbCalcPlacementResolution()}_getMinimumFlexContainerSize(){return super._getMinimumFlexContainerSize()}_repositionOnPcb(position4){return super._repositionOnPcb(position4)}};function inflateSourceGroup(sourceGroup,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbGroup=injectionDb.pcb_group.getWhere({source_group_id:sourceGroup.source_group_id}),groupProps2={name:sourceGroup.name??`inflated_group_${sourceGroup.source_group_id}`};if(pcbGroup?.position_mode==="relative_to_group_anchor"&&pcbGroup.anchor_position){let baseAnchor={x:0,y:0};if(sourceGroup.parent_source_group_id){let parentPcbGroup=injectionDb.pcb_group.getWhere({source_group_id:sourceGroup.parent_source_group_id});parentPcbGroup?.anchor_position&&(baseAnchor=parentPcbGroup.anchor_position)}groupProps2.pcbX=pcbGroup.anchor_position.x-baseAnchor.x,groupProps2.pcbY=pcbGroup.anchor_position.y-baseAnchor.y}pcbGroup?.anchor_alignment&&(groupProps2.pcbAnchorAlignment=pcbGroup.anchor_alignment);let group=new Group6(groupProps2);return group._isInflatedFromCircuitJson=!0,group.source_group_id=sourceGroup.source_group_id,groupsMap&&groupsMap.set(sourceGroup.source_group_id,group),sourceGroup.parent_source_group_id&&groupsMap?.has(sourceGroup.parent_source_group_id)?groupsMap.get(sourceGroup.parent_source_group_id).add(group):subcircuit.add(group),group}var Inductor=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"_adjustSilkscreenTextAutomatically",!0)}get config(){return{componentName:"Inductor",schematicSymbolName:this.props.symbolName??"inductor",zodProps:inductorProps,sourceFtype:FTYPE.simple_inductor}}_getSchematicSymbolDisplayValue(){return`${formatSiUnit(this._parsedProps.inductance)}H`}initPorts(){super.initPorts({additionalAliases:{pin1:["anode","pos","left"],pin2:["cathode","neg","right"]}})}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({name:this.name,ftype:FTYPE.simple_inductor,inductance:this.props.inductance,display_inductance:this._getSchematicSymbolDisplayValue(),supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourceInductor(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),inductor=new Inductor({name:sourceElm.name,inductance:sourceElm.inductance,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:inductor});footprint&&inductor.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(inductor):subcircuit.add(inductor)}function inflateSourcePort(sourcePort,inflatorContext){let{injectionDb,subcircuit}=inflatorContext;if(sourcePort.source_component_id!==null)return;let pcbPortFromInjection=injectionDb.pcb_port.getWhere({source_port_id:sourcePort.source_port_id}),port=new Port({name:sourcePort.name,pinNumber:sourcePort.pin_number});subcircuit.add(port),port.source_port_id=sourcePort.source_port_id;let root=subcircuit.root;if(root&&pcbPortFromInjection){let{db:db2}=root,pcb_port3=db2.pcb_port.insert({pcb_component_id:void 0,layers:pcbPortFromInjection.layers,subcircuit_id:subcircuit.subcircuit_id??void 0,pcb_group_id:subcircuit.getGroup()?.pcb_group_id??void 0,x:pcbPortFromInjection.x,y:pcbPortFromInjection.y,source_port_id:sourcePort.source_port_id,is_board_pinout:!1});port.pcb_port_id=pcb_port3.pcb_port_id}}var PushButton=class extends NormalComponent3{get config(){return{componentName:"PushButton",schematicSymbolName:this.props.symbolName??"push_button_normally_open_momentary",zodProps:pushButtonProps,sourceFtype:FTYPE.simple_push_button}}get defaultInternallyConnectedPinNames(){return[]}initPorts(){super.initPorts({pinCount:2,ignoreSymbolPorts:!0});let symbol=Vf[this._getSchematicSymbolNameOrThrow()],symPort1=symbol.ports.find(p4=>p4.labels.includes("1")),symPort2=symbol.ports.find(p4=>p4.labels.includes("2")),ports=this.selectAll("port"),pin1Port=ports.find(p4=>p4.props.pinNumber===1),pin2Port=ports.find(p4=>p4.props.pinNumber===2),pin3Port=ports.find(p4=>p4.props.pinNumber===3),pin4Port=ports.find(p4=>p4.props.pinNumber===4),{internallyConnectedPins}=this._parsedProps;pin1Port.schematicSymbolPortDef=symPort1,(!internallyConnectedPins||internallyConnectedPins.length===0)&&(pin2Port.schematicSymbolPortDef=symPort2);for(let[pn3,port]of[[2,pin2Port],[3,pin3Port],[4,pin4Port]]){let internallyConnectedRow=internallyConnectedPins?.find(([pin1,pin2])=>pin1===`pin${pn3}`||pin2===`pin${pn3}`);if(!internallyConnectedRow){port.schematicSymbolPortDef=symPort2;break}(internallyConnectedRow?.[0]===`pin${pn3}`?internallyConnectedRow[1]:internallyConnectedRow?.[0])!=="pin1"&&(port.schematicSymbolPortDef=symPort2)}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({name:this.name,ftype:FTYPE.simple_push_button,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourcePushButton(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),pushButton=new PushButton({name:sourceElm.name,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:pushButton});footprint&&pushButton.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(pushButton):subcircuit.add(pushButton)}var Resistor=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"_adjustSilkscreenTextAutomatically",!0)}get config(){return{componentName:"Resistor",schematicSymbolName:this.props.symbolName??"boxresistor",zodProps:resistorProps,sourceFtype:"simple_resistor"}}initPorts(){super.initPorts({additionalAliases:{pin1:["anode","pos","left"],pin2:["cathode","neg","right"]}})}_getSchematicSymbolDisplayValue(){return`${formatSiUnit(this._parsedProps.resistance)}\u03A9`}doInitialCreateNetsFromProps(){this._createNetsFromProps([this.props.pullupFor,this.props.pullupTo,this.props.pulldownFor,this.props.pulldownTo,...this._getNetsFromConnectionsProp()])}doInitialCreateTracesFromProps(){this.props.pullupFor&&this.props.pullupTo&&(this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.1`,to:this.props.pullupFor})),this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.2`,to:this.props.pullupTo}))),this.props.pulldownFor&&this.props.pulldownTo&&(this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.1`,to:this.props.pulldownFor})),this.add(new Trace3({from:`${this.getSubcircuitSelector()} > port.2`,to:this.props.pulldownTo}))),this._createTracesFromConnectionsProp()}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_resistor",name:this.name,manufacturer_part_number:props.manufacturerPartNumber??props.mfn,supplier_part_numbers:props.supplierPartNumbers,resistance:props.resistance,display_resistance:this._getSchematicSymbolDisplayValue(),are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourceResistor(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),resistor=new Resistor({name:sourceElm.name,resistance:sourceElm.resistance,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:resistor});footprint&&resistor.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(resistor):subcircuit.add(resistor)}function pcbTraceRouteToPcbPath(route){if(route.length<=2)return[];let firstPoint=route[0],lastPoint=route[route.length-1];return route.slice(1,-1).filter(point62=>{let isSameAsFirst=point62.x===firstPoint.x&&point62.y===firstPoint.y,isSameAsLast=point62.x===lastPoint.x&&point62.y===lastPoint.y;return!isSameAsFirst&&!isSameAsLast}).map(point62=>point62.route_type==="via"?{x:point62.x,y:point62.y,via:!0,fromLayer:point62.from_layer,toLayer:point62.to_layer}:{x:point62.x,y:point62.y})}var getSelectorPath=(component,inflatorContext)=>{let{injectionDb,subcircuit,groupsMap}=inflatorContext,path_parts=[],currentGroupId=component.source_group_id;for(;currentGroupId&&currentGroupId!==subcircuit.source_group_id;){let sourceGroup=injectionDb.source_group.get(currentGroupId),groupInstance=groupsMap?.get(currentGroupId);if(!sourceGroup||!groupInstance)break;let groupName=groupInstance.props.name??groupInstance.fallbackUnassignedName;path_parts.unshift(`.${groupName}`),currentGroupId=sourceGroup.parent_source_group_id}return path_parts.push(`.${component.name}`),path_parts.join(" > ")};function inflateSourceTrace(sourceTrace,inflatorContext){let{injectionDb,subcircuit}=inflatorContext,connectedSelectors=[];for(let sourcePortId of sourceTrace.connected_source_port_ids){let sourcePort=injectionDb.source_port.get(sourcePortId);if(!sourcePort)continue;let selector;if(sourcePort.source_component_id){let sourceComponent=injectionDb.source_component.get(sourcePort.source_component_id);sourceComponent&&(selector=`${getSelectorPath({name:sourceComponent.name,source_group_id:sourceComponent.source_group_id},inflatorContext)} > .${sourcePort.name}`)}else selector=`.${sourcePort.name}`;selector&&connectedSelectors.push(selector)}for(let sourceNetId of sourceTrace.connected_source_net_ids){let sourceNet=injectionDb.source_net.get(sourceNetId);sourceNet&&connectedSelectors.push(`net.${sourceNet.name}`)}if(connectedSelectors.length<2)return;let pcbTrace=injectionDb.pcb_trace.getWhere({source_trace_id:sourceTrace.source_trace_id}),pcbPath2;pcbTrace&&(pcbPath2=pcbTraceRouteToPcbPath(pcbTrace.route));let traceWidth=sourceTrace.min_trace_thickness;if(!traceWidth&&pcbTrace?.route){let wirePoint=pcbTrace.route.find(pt3=>pt3.route_type==="wire");wirePoint&&wirePoint.route_type==="wire"&&(traceWidth=wirePoint.width)}let traceProps2={path:connectedSelectors};traceWidth!==void 0&&(traceProps2.thickness=traceWidth),pcbPath2&&pcbPath2.length>0?traceProps2.pcbPath=pcbPath2:pcbTrace&&(traceProps2.pcbStraightLine=!0);let trace=new Trace3(traceProps2);subcircuit.add(trace)}var Transistor=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"emitter",this.portMap.pin1);__publicField(this,"collector",this.portMap.pin2);__publicField(this,"base",this.portMap.pin3)}get config(){let baseSymbolName=this.props.type==="npn"?"npn_bipolar_transistor":"pnp_bipolar_transistor";return{componentName:"Transistor",schematicSymbolName:this.props.symbolName??baseSymbolName,zodProps:transistorProps,sourceFtype:"simple_transistor",shouldRenderAsSchematicBox:!1}}initPorts(){let pinAliases={pin1:["collector","c"],pin2:["emitter","e"],pin3:["base","b"]};super.initPorts({pinCount:3,additionalAliases:pinAliases})}doInitialCreateNetsFromProps(){this._createNetsFromProps([...this._getNetsFromConnectionsProp()])}doInitialCreateTracesFromProps(){this._createTracesFromConnectionsProp()}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_transistor",name:this.name,transistor_type:props.type,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function inflateSourceTransistor(sourceElm,inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,pcbElm=injectionDb.pcb_component.getWhere({source_component_id:sourceElm.source_component_id}),cadElm=injectionDb.cad_component.getWhere({source_component_id:sourceElm.source_component_id}),{pcbX,pcbY}=getInflatedPcbPlacement({pcbComponent:pcbElm,sourceGroupId:sourceElm.source_group_id,inflatorContext}),transistor=new Transistor({name:sourceElm.name,type:sourceElm.transistor_type,layer:pcbElm?.layer,pcbX,pcbY,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});if(pcbElm){let footprint=inflateFootprintComponent(pcbElm,{...inflatorContext,normalComponent:transistor});footprint&&transistor.add(footprint)}sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(transistor):subcircuit.add(transistor)}function inflateStandalonePcbPrimitives(inflatorContext){let{injectionDb,subcircuit,groupsMap}=inflatorContext,standalonePrimitiveTypes=["pcb_silkscreen_rect","pcb_silkscreen_circle","pcb_silkscreen_line","pcb_silkscreen_path","pcb_silkscreen_text","pcb_fabrication_note_text","pcb_fabrication_note_path","pcb_fabrication_note_rect","pcb_note_text","pcb_note_rect","pcb_note_path","pcb_note_line"],standalonePrimitives=injectionDb.toArray().filter(elm=>standalonePrimitiveTypes.includes(elm.type)&&"pcb_component_id"in elm&&(elm.pcb_component_id===null||elm.pcb_component_id===void 0));if(standalonePrimitives.length===0)return;let components=createComponentsFromCircuitJson({componentName:"",componentRotation:"0deg"},standalonePrimitives);for(let component of components)subcircuit.add(component)}var inflateCircuitJson=(target,circuitJson,children)=>{if(!circuitJson)return;let injectionDb=cju_default(circuitJson);if(circuitJson&&children?.length>0)throw new Error("Component cannot have both circuitJson and children");let inflationCtx={injectionDb,subcircuit:target,groupsMap:new Map},sourceGroups=injectionDb.source_group.list(),renderedGroupIds=new Set,groupsToRender=[...sourceGroups];for(;groupsToRender.length>0;){let groupIndex=groupsToRender.findIndex(g6=>!g6.parent_source_group_id||renderedGroupIds.has(g6.parent_source_group_id));if(groupIndex===-1){let remainingIds=groupsToRender.map(g6=>g6.source_group_id).join(", ");throw new Error(`Cannot inflate source_groups: cyclic dependency or missing parent detected. Remaining groups: ${remainingIds}`)}let groupToRender=groupsToRender[groupIndex];inflateSourceGroup(groupToRender,inflationCtx),renderedGroupIds.add(groupToRender.source_group_id),groupsToRender.splice(groupIndex,1)}let pcbBoards=injectionDb.pcb_board.list();for(let pcbBoard of pcbBoards)inflatePcbBoard(pcbBoard,inflationCtx);let sourceComponents=injectionDb.source_component.list();for(let sourceComponent of sourceComponents)switch(sourceComponent.ftype){case"simple_resistor":inflateSourceResistor(sourceComponent,inflationCtx);break;case"simple_capacitor":inflateSourceCapacitor(sourceComponent,inflationCtx);break;case"simple_inductor":inflateSourceInductor(sourceComponent,inflationCtx);break;case"simple_diode":inflateSourceDiode(sourceComponent,inflationCtx);break;case"simple_chip":inflateSourceChip(sourceComponent,inflationCtx);break;case"simple_transistor":inflateSourceTransistor(sourceComponent,inflationCtx);break;case"simple_push_button":inflateSourcePushButton(sourceComponent,inflationCtx);break;default:throw new Error(`No inflator implemented for source component ftype: "${sourceComponent.ftype}"`)}let sourcePorts=injectionDb.source_port.list();for(let sourcePort of sourcePorts)inflateSourcePort(sourcePort,inflationCtx);let sourceTraces=injectionDb.source_trace.list();for(let sourceTrace of sourceTraces)inflateSourceTrace(sourceTrace,inflationCtx);inflateStandalonePcbPrimitives(inflationCtx)},package_default3={name:"@tscircuit/core",type:"module",version:"0.0.1213",types:"dist/index.d.ts",main:"dist/index.js",module:"dist/index.js",exports:{".":{import:"./dist/index.js",types:"./dist/index.d.ts"}},files:["dist"],repository:{type:"git",url:"https://github.com/tscircuit/core"},scripts:{build:"tsup-node",format:"biome format . --write","measure-bundle":"howfat -r table .","pkg-pr-new-release":"bunx pkg-pr-new publish --comment=off --peerDeps","smoke-test:dist":"bun run scripts/smoke-tests/test-dist-simple-circuit.tsx","build:benchmarking":"bun build --experimental-html ./benchmarking/website/index.html --outdir ./benchmarking-dist","build:benchmarking:watch":`chokidar "./{benchmarking,lib}/**/*.{ts,tsx}" -c 'bun build --experimental-html ./benchmarking/website/index.html --outdir ./benchmarking-dist'`,"start:benchmarking":'concurrently "bun run build:benchmarking:watch" "live-server ./benchmarking-dist"',"generate-test-plan":"bun run scripts/generate-test-plan.ts"},devDependencies:{"@biomejs/biome":"^1.8.3","@resvg/resvg-js":"^2.6.2","@tscircuit/alphabet":"0.0.25","@tscircuit/capacity-autorouter":"^0.0.485","@tscircuit/checks":"0.0.125","@tscircuit/circuit-json-util":"^0.0.94","@tscircuit/common":"^0.0.20","@tscircuit/copper-pour-solver":"^0.0.29","@tscircuit/footprinter":"^0.0.351","@tscircuit/infer-cable-insertion-point":"^0.0.2","@tscircuit/infgrid-ijump-astar":"^0.0.35","@tscircuit/jlcpcb-manufacturing-specs":"git+https://github.com/tscircuit/jlcpcb-manufacturing-specs#e08af159db01a37db007e33f0a7268d0e4a279a5","@tscircuit/log-soup":"^1.0.2","@tscircuit/matchpack":"^0.0.16","@tscircuit/math-utils":"^0.0.36","@tscircuit/miniflex":"^0.0.4","@tscircuit/ngspice-spice-engine":"^0.0.8","@tscircuit/props":"^0.0.513","@tscircuit/schematic-match-adapt":"^0.0.16","@tscircuit/schematic-trace-solver":"^0.0.51","@tscircuit/solver-utils":"^0.0.3","@tscircuit/soup-util":"^0.0.41","@types/bun":"^1.2.16","@types/debug":"^4.1.12","@types/react":"^19.1.8","@types/react-dom":"^19.1.6","@types/react-reconciler":"^0.28.9","bpc-graph":"^0.0.57","bun-match-svg":"0.0.12","calculate-elbow":"^0.0.12","chokidar-cli":"^3.0.0","circuit-json":"^0.0.421","circuit-json-to-bpc":"^0.0.13","circuit-json-to-connectivity-map":"^0.0.23","circuit-json-to-gltf":"^0.0.96","circuit-json-to-simple-3d":"^0.0.9","circuit-json-to-spice":"^0.0.34","circuit-to-svg":"^0.0.345",concurrently:"^9.1.2","connectivity-map":"^1.0.0",debug:"^4.3.6","eecircuit-engine":"^1.5.6",flatbush:"^4.5.0","graphics-debug":"^0.0.89",howfat:"^0.3.8","live-server":"^1.2.2","looks-same":"^9.0.1",minicssgrid:"^0.0.9","pkg-pr-new":"^0.0.37",poppygl:"^0.0.16",react:"^19.1.0","react-dom":"^19.1.0","schematic-symbols":"^0.0.208",spicey:"^0.0.14","ts-expect":"^1.3.0",tsup:"^8.2.4"},peerDependencies:{"@tscircuit/capacity-autorouter":"*","@tscircuit/checks":"*","@tscircuit/circuit-json-util":"*","@tscircuit/footprinter":"*","@tscircuit/infgrid-ijump-astar":"*","@tscircuit/math-utils":"*","@tscircuit/props":"*","@tscircuit/schematic-match-adapt":"*","circuit-json-to-bpc":"*","bpc-graph":"*","@tscircuit/matchpack":"*","circuit-json":"*","circuit-json-to-connectivity-map":"*","schematic-symbols":"*",typescript:"^5.0.0"},dependencies:{"@flatten-js/core":"^1.6.2","@lume/kiwi":"^0.4.3","calculate-packing":"0.0.72","css-select":"5.1.0","format-si-unit":"^0.0.3",nanoid:"^5.0.7","performance-now":"^2.1.0","react-reconciler":"^0.32.0","svg-path-commander":"^2.1.11","transformation-matrix":"^2.16.1",zod:"^3.25.67"}},IsolatedCircuit=class{constructor({platform,projectUrl,cachedSubcircuits,pendingSubcircuitRenders}={}){__publicField(this,"firstChild",null);__publicField(this,"children");__publicField(this,"db");__publicField(this,"root",null);__publicField(this,"isRootCircuit",!1);__publicField(this,"cachedSubcircuits");__publicField(this,"pendingSubcircuitRenders");__publicField(this,"_schematicDisabledOverride");__publicField(this,"pcbDisabled",!1);__publicField(this,"pcbRoutingDisabled",!1);__publicField(this,"_featureMspSchematicTraceRouting",!0);__publicField(this,"name");__publicField(this,"platform");__publicField(this,"projectUrl");__publicField(this,"_hasRenderedAtleastOnce",!1);__publicField(this,"_asyncEffectIdsByPhase",new Map);__publicField(this,"_asyncEffectPhaseById",new Map);__publicField(this,"_runningAsyncEffectsById",new Map);__publicField(this,"_eventListeners",{});this.children=[],this.db=su2([]),this.platform=platform,this.projectUrl=projectUrl,this.pcbDisabled=platform?.pcbDisabled??!1,this.pcbRoutingDisabled=platform?.routingDisabled??!1,this.cachedSubcircuits=cachedSubcircuits,this.pendingSubcircuitRenders=pendingSubcircuitRenders,this.root=this}get schematicDisabled(){return this._schematicDisabledOverride!==void 0?this._schematicDisabledOverride:this.platform?.schematicDisabled!==void 0?this.platform.schematicDisabled:this._getBoard()?._parsedProps?.schematicDisabled??!1}set schematicDisabled(value){this._schematicDisabledOverride=value}add(componentOrElm){let component;(0,import_react4.isValidElement)(componentOrElm)?component=createInstanceFromReactElement(componentOrElm):component=componentOrElm,this.children.push(component)}setPlatform(platform){this.platform={...this.platform,...platform},platform.pcbDisabled!==void 0&&(this.pcbDisabled=platform.pcbDisabled),platform.routingDisabled!==void 0&&(this.pcbRoutingDisabled=platform.routingDisabled)}_getBoard(){let directBoard=this.children.find(c4=>c4.componentName==="Board");if(directBoard)return directBoard}_guessRootComponent(){if(this.firstChild)return;if(this.children.length===0)throw new Error("Not able to guess root component: IsolatedCircuit has no children (use circuit.add(...))");let panels=this.children.filter(child=>child.lowercaseComponentName==="panel");if(panels.length>1)throw new Error("Only one <panel> is allowed per circuit");if(panels.length===1){if(this.children.length!==1)throw new Error("<panel> must be the root element of the circuit");this.firstChild=panels[0];return}if(this.children.length===1&&this.children[0].isGroup){this.firstChild=this.children[0];return}let group=new Group6({subcircuit:!0});group.parent=this,group.addAll(this.children),this.children=[group],this.firstChild=group}render(){this.firstChild||this._guessRootComponent();let{firstChild,db:db2}=this;if(!firstChild)throw new Error("IsolatedCircuit has no root component");firstChild.parent=this,firstChild.runRenderCycle(),this._hasRenderedAtleastOnce=!0}async renderUntilSettled(){for(this.db.source_project_metadata.list()?.[0]||this.db.source_project_metadata.insert({software_used_string:`@tscircuit/core@${this.getCoreVersion()}`,...this.projectUrl?{project_url:this.projectUrl}:{}}),this.render();this._hasIncompleteAsyncEffects();)await new Promise(resolve=>setTimeout(resolve,100)),this.render();this.emit("renderComplete")}_hasIncompleteAsyncEffects(){return this._asyncEffectPhaseById.size>0?!0:this.children.some(child=>child._hasIncompleteAsyncEffects())}_hasIncompleteAsyncEffectsForPhase(phase){return(this._asyncEffectIdsByPhase.get(phase)?.size??0)>0}getRunningAsyncEffects(){return Array.from(this._runningAsyncEffectsById.values())}getCircuitJson(){return this._hasRenderedAtleastOnce||this.render(),this.db.toArray()}toJson(){return this.getCircuitJson()}async getSvg(options){let circuitToSvg=await Promise.resolve().then(()=>(init_dist8(),dist_exports3)).catch(e5=>{throw new Error(`To use circuit.getSvg, you must install the "circuit-to-svg" package.
692
692
 
693
693
  "${e5.message}"`)});if(options.view==="pcb")return circuitToSvg.convertCircuitJsonToPcbSvg(this.getCircuitJson());if(options.view==="schematic")return circuitToSvg.convertCircuitJsonToSchematicSvg(this.getCircuitJson());throw new Error(`Invalid view: ${options.view}`)}getCoreVersion(){let[major,minor,patch]=package_default3.version.split(".").map(Number);return`${major}.${minor}.${patch+1}`}async preview(previewNameOrOpts){let previewOpts=typeof previewNameOrOpts=="object"?previewNameOrOpts:{previewName:previewNameOrOpts};throw new Error("project.preview is not yet implemented")}computeSchematicGlobalTransform(){return identity()}_computePcbGlobalTransformBeforeLayout(){return identity()}selectAll(selector){return this._guessRootComponent(),this.firstChild?.selectAll(selector)??[]}selectOne(selector,opts){return this._guessRootComponent(),this.firstChild?.selectOne(selector,opts)??null}emit(event,...args){if(event==="asyncEffect:start"?this._registerAsyncEffectStart(args[0]):event==="asyncEffect:end"&&this._registerAsyncEffectEnd(args[0]),!!this._eventListeners[event])for(let listener of this._eventListeners[event])listener(...args)}on(event,listener){this._eventListeners[event]||(this._eventListeners[event]=[]),this._eventListeners[event].push(listener)}removeListener(event,listener){this._eventListeners[event]&&(this._eventListeners[event]=this._eventListeners[event].filter(l4=>l4!==listener))}enableDebug(debug112){typeof debug112=="string"?import_debug19.default.enable(debug112):(debug112===null||debug112===!1)&&import_debug19.default.disable()}getClientOrigin(){return typeof window<"u"&&window.location?window.location.origin:typeof self<"u"&&self.location?self.location.origin:""}_registerAsyncEffectStart(payload){if(!payload?.asyncEffectId||!payload.phase)return;let{asyncEffectId,phase}=payload,existingPhase=this._asyncEffectPhaseById.get(asyncEffectId);existingPhase&&existingPhase!==phase&&this._asyncEffectIdsByPhase.get(existingPhase)?.delete(asyncEffectId),this._asyncEffectIdsByPhase.has(phase)||this._asyncEffectIdsByPhase.set(phase,new Set),this._asyncEffectIdsByPhase.get(phase).add(asyncEffectId),this._asyncEffectPhaseById.set(asyncEffectId,phase),this._runningAsyncEffectsById.set(asyncEffectId,{asyncEffectId,effectName:payload.effectName,componentDisplayName:payload.componentDisplayName,phase,error:payload.error})}_registerAsyncEffectEnd(payload){if(!payload?.asyncEffectId)return;let{asyncEffectId}=payload,phase=this._asyncEffectPhaseById.get(asyncEffectId)??payload.phase;if(phase){let phaseSet=this._asyncEffectIdsByPhase.get(phase);phaseSet?.delete(asyncEffectId),phaseSet&&phaseSet.size===0&&this._asyncEffectIdsByPhase.delete(phase)}this._asyncEffectPhaseById.delete(asyncEffectId),this._runningAsyncEffectsById.delete(asyncEffectId)}};function Subcircuit_doInitialRenderIsolatedSubcircuits(subcircuit){if(!subcircuit._isIsolatedSubcircuit||subcircuit._isolatedCircuitJson||!subcircuit.getSubcircuitPropHash)return;let propHash=subcircuit.getSubcircuitPropHash(),cachedSubcircuits=subcircuit.root?.cachedSubcircuits,pendingSubcircuitRenders=subcircuit.root?.pendingSubcircuitRenders,cached=cachedSubcircuits?.get(propHash);if(cached){subcircuit._isolatedCircuitJson=cached,subcircuit.children=[],subcircuit._normalComponentNameMap=null;return}let childrenToRender=[...subcircuit.children];subcircuit.children=[],subcircuit._normalComponentNameMap=null;let parentRoot=subcircuit.root;subcircuit._queueAsyncEffect("render-isolated-subcircuit",async()=>{let cachedResult=cachedSubcircuits?.get(propHash);if(cachedResult){subcircuit._isolatedCircuitJson=cachedResult;return}let pendingRenderPromise=pendingSubcircuitRenders?.get(propHash);if(pendingRenderPromise){subcircuit._isolatedCircuitJson=await pendingRenderPromise;return}let resolveRender,rejectRender,renderPromise=new Promise((resolve,reject)=>{resolveRender=resolve,rejectRender=reject});pendingSubcircuitRenders?.set(propHash,renderPromise);try{let isolatedCircuit=new IsolatedCircuit({platform:{...parentRoot.platform,pcbDisabled:parentRoot.pcbDisabled,schematicDisabled:parentRoot.schematicDisabled},cachedSubcircuits,pendingSubcircuitRenders});for(let child of childrenToRender)isolatedCircuit.add(child);await isolatedCircuit.renderUntilSettled();let circuitJson=isolatedCircuit.getCircuitJson();cachedSubcircuits?.set(propHash,circuitJson),subcircuit._isolatedCircuitJson=circuitJson,resolveRender(circuitJson)}catch(error2){throw rejectRender(error2 instanceof Error?error2:new Error(String(error2))),error2}finally{pendingSubcircuitRenders?.delete(propHash)}})}var EXCLUDED_PROPS=new Set(["name","key","pcbX","pcbY","schX","schY","pcbLeftEdgeX","pcbRightEdgeX","pcbTopEdgeY","pcbBottomEdgeY","pcbRotation","schRotation"]);function safeSerialize(value,seen=new WeakSet){if(value===null)return"null";if(value===void 0)return"undefined";let type=typeof value;if(type==="string")return`"${value}"`;if(type==="number"||type==="boolean")return String(value);if(type==="function")return"[function]";if(type==="symbol")return"[symbol]";if(type==="object"){if(seen.has(value))return"[circular]";if(seen.add(value),value.$$typeof!==void 0){let elementType=typeof value.type=="string"?value.type:value.type?.name||"[component]",propsStr=value.props?safeSerialize(value.props,seen):"{}";return`ReactElement(${elementType},${propsStr})`}return Array.isArray(value)?`[${value.map(v4=>safeSerialize(v4,seen)).join(",")}]`:`{${Object.keys(value).sort().map(k4=>`${k4}:${safeSerialize(value[k4],seen)}`).join(",")}}`}return String(value)}function getHashableProps(props){let result={},keys=Object.keys(props).sort();for(let key of keys)!EXCLUDED_PROPS.has(key)&&props[key]!==void 0&&(result[key]=props[key]);return result}function getChildrenHashData(children){return children.map(child=>({componentName:child.componentName,props:getHashableProps(child.props??{}),children:getChildrenHashData(child.children)}))}function fnv1aHash(str){let hash=2166136261;for(let i3=0;i3<str.length;i3++)hash^=str.charCodeAt(i3),hash=Math.imul(hash,16777619);return hash>>>0}function computeHash(data){let serialized=safeSerialize(data),hash1=fnv1aHash(serialized),hash2=fnv1aHash(serialized+hash1.toString());return hash1.toString(16).padStart(8,"0")+hash2.toString(16).padStart(8,"0")}function Subcircuit_getSubcircuitPropHash(subcircuit){let hashableData={props:getHashableProps(subcircuit.props??{}),children:getChildrenHashData(subcircuit.children)};return computeHash(hashableData)}var MIN_EFFECTIVE_BORDER_RADIUS_MM=.01,getRoundedRectOutline=(width,height,radius)=>{let w22=width/2,h22=height/2,r5=Math.min(radius,w22,h22);if(r5<MIN_EFFECTIVE_BORDER_RADIUS_MM)return[{x:-w22,y:-h22},{x:w22,y:-h22},{x:w22,y:h22},{x:-w22,y:h22}];let segments=Math.max(1,Math.ceil(Math.PI/2*r5/.1)),step=Math.PI/2/segments,outline=[];outline.push({x:-w22+r5,y:-h22}),outline.push({x:w22-r5,y:-h22});for(let i3=1;i3<=segments;i3++){let theta=-Math.PI/2+i3*step;outline.push({x:w22-r5+r5*Math.cos(theta),y:-h22+r5+r5*Math.sin(theta)})}outline.push({x:w22,y:h22-r5});for(let i3=1;i3<=segments;i3++){let theta=0+i3*step;outline.push({x:w22-r5+r5*Math.cos(theta),y:h22-r5+r5*Math.sin(theta)})}outline.push({x:-w22+r5,y:h22});for(let i3=1;i3<=segments;i3++){let theta=Math.PI/2+i3*step;outline.push({x:-w22+r5+r5*Math.cos(theta),y:h22-r5+r5*Math.sin(theta)})}outline.push({x:-w22,y:-h22+r5});for(let i3=1;i3<=segments;i3++){let theta=Math.PI+i3*step;outline.push({x:-w22+r5+r5*Math.cos(theta),y:-h22+r5+r5*Math.sin(theta)})}return outline},Board=class extends Group6{constructor(){super(...arguments);__publicField(this,"pcb_board_id",null);__publicField(this,"source_board_id",null);__publicField(this,"_drcChecksComplete",!1);__publicField(this,"_drcChecksInProgress",!1);__publicField(this,"_connectedSchematicPortPairs",new Set);__publicField(this,"_panelPositionOffset",null)}get isSubcircuit(){return!0}get isGroup(){return!0}get config(){return{componentName:"Board",zodProps:boardProps}}get boardThickness(){return this._parsedProps.thickness??1.4}get allLayers(){let layerCount=this._parsedProps.layers??2;return layerCount===1?["top"]:layerCount===4?["top","bottom","inner1","inner2"]:["top","bottom"]}_getSubcircuitLayerCount(){return this._parsedProps.layers??2}_computePcbGlobalTransformBeforeLayout(){if(this._panelPositionOffset){let parentTransform=this.parent?._computePcbGlobalTransformBeforeLayout?.()??{a:1,b:0,c:0,d:1,e:0,f:0};return compose2(parentTransform,translate2(this._panelPositionOffset.x,this._panelPositionOffset.y))}return super._computePcbGlobalTransformBeforeLayout()}_getBoardCalcVariables(){let{_parsedProps:props}=this;if((props.width==null||props.height==null)&&!props.outline)return{};let dbBoard=this.pcb_board_id?this.root?.db.pcb_board.get(this.pcb_board_id):null,width=dbBoard?.width??props.width,height=dbBoard?.height??props.height;if((width==null||height==null)&&props.outline?.length){let outlineBounds=getBoundsFromPoints(props.outline);outlineBounds&&(width??(width=outlineBounds.maxX-outlineBounds.minX),height??(height=outlineBounds.maxY-outlineBounds.minY))}let{pcbX,pcbY}=this.getResolvedPcbPositionProp(),center2=dbBoard?.center??{x:pcbX+(props.outlineOffsetX??0),y:pcbY+(props.outlineOffsetY??0)},resolvedWidth=width??0,resolvedHeight=height??0;return{"board.minX":center2.x-resolvedWidth/2,"board.maxX":center2.x+resolvedWidth/2,"board.minY":center2.y-resolvedHeight/2,"board.maxY":center2.y+resolvedHeight/2}}doInitialPcbBoardAutoSize(){if(this.root?.pcbDisabled||!this.pcb_board_id)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalPcbPositionBeforeLayout(),pcbBoard=db2.pcb_board.get(this.pcb_board_id);if(pcbBoard?.width&&pcbBoard?.height||pcbBoard?.outline&&pcbBoard.outline.length>0)return;let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0,descendantIds=getDescendantSubcircuitIds(db2,this.subcircuit_id),allowedSubcircuitIds=new Set([this.subcircuit_id,...descendantIds]),allPcbComponents=db2.pcb_component.list().filter(c4=>c4.subcircuit_id&&allowedSubcircuitIds.has(c4.subcircuit_id)),allPcbGroups=db2.pcb_group.list().filter(g6=>g6.subcircuit_id&&allowedSubcircuitIds.has(g6.subcircuit_id)),hasComponents=!1,updateBounds=(center22,width,height)=>{width===0||height===0||(hasComponents=!0,minX=Math.min(minX,center22.x-width/2),minY=Math.min(minY,center22.y-height/2),maxX=Math.max(maxX,center22.x+width/2),maxY=Math.max(maxY,center22.y+height/2))};for(let pcbComponent of allPcbComponents)updateBounds(pcbComponent.center,pcbComponent.width,pcbComponent.height);for(let pcbGroup of allPcbGroups){let width=pcbGroup.width??0,height=pcbGroup.height??0;if(pcbGroup.outline&&pcbGroup.outline.length>0){let bounds=getBoundsFromPoints(pcbGroup.outline);bounds&&(width=bounds.maxX-bounds.minX,height=bounds.maxY-bounds.minY)}updateBounds(pcbGroup.center,width,height)}if(props.boardAnchorPosition){let{x:x4,y:y4}=props.boardAnchorPosition;minX=Math.min(minX,x4),minY=Math.min(minY,y4),maxX=Math.max(maxX,x4),maxY=Math.max(maxY,y4)}let padding=2,computedWidth=hasComponents?maxX-minX+padding*2:0,computedHeight=hasComponents?maxY-minY+padding*2:0,center2={x:hasComponents?(minX+maxX)/2+(props.outlineOffsetX??0):(props.outlineOffsetX??0)+globalPos.x,y:hasComponents?(minY+maxY)/2+(props.outlineOffsetY??0):(props.outlineOffsetY??0)+globalPos.y},finalWidth=props.width??computedWidth,finalHeight=props.height??computedHeight,outline=props.outline;!outline&&props.borderRadius!=null&&finalWidth>0&&finalHeight>0&&(outline=getRoundedRectOutline(finalWidth,finalHeight,props.borderRadius));let update={width:finalWidth,height:finalHeight,center:center2};outline&&(update.outline=outline.map(point62=>({x:point62.x+(props.outlineOffsetX??0),y:point62.y+(props.outlineOffsetY??0)}))),db2.pcb_board.update(this.pcb_board_id,update)}updatePcbBoardAutoSize(){this.doInitialPcbBoardAutoSize()}_addBoardInformationToSilkscreen(){let platform=this.root?.platform;if(!platform?.printBoardInformationToSilkscreen)return;let pcbBoard=this.root.db.pcb_board.get(this.pcb_board_id);if(!pcbBoard)return;let boardInformation=[];if(platform.projectName&&boardInformation.push(platform.projectName),platform.version&&boardInformation.push(`v${platform.version}`),platform.url&&boardInformation.push(platform.url),boardInformation.length===0)return;let text=boardInformation.join(`
694
694
  `),position4={x:pcbBoard.center.x+pcbBoard.width/2-.25,y:pcbBoard.center.y-pcbBoard.height/2+1};this.root.db.pcb_silkscreen_text.insert({pcb_component_id:this.pcb_board_id,layer:"top",font:"tscircuit2024",font_size:.45,text,ccw_rotation:0,anchor_alignment:"bottom_right",anchor_position:position4})}doInitialSourceRender(){let nestedBoard=this.getDescendants().find(d4=>d4.lowercaseComponentName==="board");if(nestedBoard)throw new Error(`Nested boards are not supported: found board "${nestedBoard.name}" inside board "${this.name}"`);super.doInitialSourceRender();let{db:db2}=this.root,source_board3=db2.source_board.insert({source_group_id:this.source_group_id,title:this.props.title||this.props.name});this.source_board_id=source_board3.source_board_id}getSubcircuitPropHash(){return Subcircuit_getSubcircuitPropHash(this)}doInitialRenderIsolatedSubcircuits(){Subcircuit_doInitialRenderIsolatedSubcircuits(this)}doInitialInflateSubcircuitCircuitJson(){let isolatedJson=this._isolatedCircuitJson;if(isolatedJson){this._isInflatedFromCircuitJson=!0,this._isolatedCircuitJson=null,inflateCircuitJson(this,isolatedJson,[]);return}let{circuitJson,children}=this._parsedProps;circuitJson&&(this._isInflatedFromCircuitJson=!0),inflateCircuitJson(this,circuitJson,children)}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,pcbBoardFromCircuitJson=props.circuitJson?.find(elm=>elm.type==="pcb_board"),computedWidth=props.width??pcbBoardFromCircuitJson?.width??0,computedHeight=props.height??pcbBoardFromCircuitJson?.height??0,globalPos=this._getGlobalPcbPositionBeforeLayout(),center2={x:globalPos.x+(props.outlineOffsetX??0),y:globalPos.y+(props.outlineOffsetY??0)},{boardAnchorPosition,boardAnchorAlignment}=props;if(boardAnchorPosition&&(center2=getBoardCenterFromAnchor({boardAnchorPosition,boardAnchorAlignment:boardAnchorAlignment??"center",width:computedWidth,height:computedHeight})),props.outline){let xValues=props.outline.map(point62=>point62.x),yValues=props.outline.map(point62=>point62.y),minX=Math.min(...xValues),maxX=Math.max(...xValues),minY=Math.min(...yValues),maxY=Math.max(...yValues);computedWidth=maxX-minX,computedHeight=maxY-minY}let outline=props.outline;!outline&&props.borderRadius!=null&&computedWidth>0&&computedHeight>0&&(outline=getRoundedRectOutline(computedWidth,computedHeight,props.borderRadius));let outlineTranslation={x:0,y:0};if(outline&&outline.length>0&&(this.parent?.lowercaseComponentName==="panel"||this.parent?.lowercaseComponentName==="subpanel")){let outlineBounds=getBoundsFromPoints(outline);if(outlineBounds){let outlineCenterX=(outlineBounds.minX+outlineBounds.maxX)/2,outlineCenterY=(outlineBounds.minY+outlineBounds.maxY)/2;outlineTranslation={x:center2.x-outlineCenterX,y:center2.y-outlineCenterY}}}let subcircuitProps2=this.getSubcircuit()._parsedProps,pcb_board3=db2.pcb_board.insert({source_board_id:this.source_board_id,center:center2,thickness:this.boardThickness,num_layers:this.allLayers.length,width:computedWidth,height:computedHeight,outline:outline?.map(point62=>({x:point62.x+(props.outlineOffsetX??0)+outlineTranslation.x,y:point62.y+(props.outlineOffsetY??0)+outlineTranslation.y})),material:props.material,min_trace_width:subcircuitProps2.minTraceWidth??jlcMinTolerances2.min_trace_width,min_via_hole_diameter:subcircuitProps2.minViaHoleDiameter??jlcMinTolerances2.min_via_hole_diameter,min_via_pad_diameter:subcircuitProps2.minViaPadDiameter??jlcMinTolerances2.min_via_pad_diameter,min_via_hole_edge_to_via_hole_edge_clearance:subcircuitProps2.minViaHoleEdgeToViaHoleEdgeClearance??jlcMinTolerances2.min_via_hole_edge_to_via_hole_edge_clearance,min_trace_to_pad_edge_clearance:subcircuitProps2.minTraceToPadEdgeClearance??jlcMinTolerances2.min_trace_to_pad_edge_clearance,min_pad_edge_to_pad_edge_clearance:subcircuitProps2.minPadEdgeToPadEdgeClearance??jlcMinTolerances2.min_pad_edge_to_pad_edge_clearance,min_plated_hole_drill_edge_to_drill_edge_clearance:subcircuitProps2.minPlatedHoleDrillEdgeToDrillEdgeClearance??jlcMinTolerances2.min_plated_hole_drill_edge_to_drill_edge_clearance,min_board_edge_clearance:subcircuitProps2.minBoardEdgeClearance??jlcMinTolerances2.min_board_edge_clearance});this.pcb_board_id=pcb_board3.pcb_board_id,this._addBoardInformationToSilkscreen()}removePcbComponentRender(){let{db:db2}=this.root;this.pcb_board_id&&(db2.pcb_board.delete(this.pcb_board_id),this.pcb_board_id=null)}doInitialPcbDesignRuleChecks(){this.root?.pcbDisabled||(super.doInitialPcbDesignRuleChecks(),this.updatePcbDesignRuleChecks())}updatePcbDesignRuleChecks(){let{db:db2}=this.root,routingDisabled=this.root?.pcbRoutingDisabled||this.getInheritedProperty("routingDisabled"),pcbDisabled=this.root?.pcbDisabled,drcChecksDisabled=this.root?.platform?.drcChecksDisabled??this.getInheritedProperty("drcChecksDisabled"),netlistDrcChecksDisabled=this.root?.platform?.netlistDrcChecksDisabled??this.getInheritedProperty("netlistDrcChecksDisabled"),pinSpecificationDrcChecksDisabled=this.getInheritedProperty("pinSpecificationDrcChecksDisabled"),placementDrcChecksDisabled=this.root?.platform?.placementDrcChecksDisabled??this.getInheritedProperty("placementDrcChecksDisabled"),routingDrcChecksDisabled=this.root?.platform?.routingDrcChecksDisabled??this.getInheritedProperty("routingDrcChecksDisabled"),shouldRunNetlistChecks=!drcChecksDisabled&&!netlistDrcChecksDisabled,shouldRunPinSpecificationChecks=!drcChecksDisabled&&!pinSpecificationDrcChecksDisabled,shouldRunPlacementChecks=!drcChecksDisabled&&!pcbDisabled&&!placementDrcChecksDisabled,shouldRunRoutingChecks=!drcChecksDisabled&&!pcbDisabled&&!routingDisabled&&!routingDrcChecksDisabled;if(shouldRunRoutingChecks&&this._hasIncompleteAsyncEffectsInSubtreeForPhase("PcbTraceRender"))return;let hasTracesToRoute=this._hasTracesToRoute();if(shouldRunRoutingChecks&&hasTracesToRoute&&!this._areChildSubcircuitsRouted()||this._drcChecksComplete||this._drcChecksInProgress)return;let runDrcChecks=async circuitJson=>{let checksToRun=[];shouldRunRoutingChecks&&checksToRun.push(runAllRoutingChecks(circuitJson)),shouldRunPlacementChecks&&checksToRun.push(runAllPlacementChecks(circuitJson)),shouldRunNetlistChecks&&checksToRun.push(runAllNetlistChecks(circuitJson)),shouldRunPinSpecificationChecks&&checksToRun.push(runAllPinSpecificationChecks(circuitJson));let checkResults=await Promise.all(checksToRun);db2.insertAll(checkResults.flat())},subcircuitCircuitJson=db2.subtree({subcircuit_id:this.subcircuit_id}).toArray();this._drcChecksInProgress=!0,this._queueAsyncEffect("board:drc-checks",async()=>{try{await runDrcChecks(subcircuitCircuitJson),this._drcChecksComplete=!0}finally{this._drcChecksInProgress=!1}})}_emitRenderLifecycleEvent(phase,startOrEnd){super._emitRenderLifecycleEvent(phase,startOrEnd),startOrEnd==="start"&&this.root?.emit("board:renderPhaseStarted",{renderId:this._renderId,phase})}_repositionOnPcb(position4){let{db:db2}=this.root,pcbBoard=this.pcb_board_id?db2.pcb_board.get(this.pcb_board_id):null,oldPos=pcbBoard?.center;if(!oldPos){this.pcb_board_id&&db2.pcb_board.update(this.pcb_board_id,{center:position4});return}let deltaX=position4.x-oldPos.x,deltaY=position4.y-oldPos.y;if(!(Math.abs(deltaX)<1e-6&&Math.abs(deltaY)<1e-6)&&this.pcb_board_id&&(db2.pcb_board.update(this.pcb_board_id,{center:position4}),pcbBoard?.outline)){let outlineBounds=getBoundsFromPoints(pcbBoard.outline);if(outlineBounds){let oldOutlineCenter={x:(outlineBounds.minX+outlineBounds.maxX)/2,y:(outlineBounds.minY+outlineBounds.maxY)/2},outlineDeltaX=position4.x-oldOutlineCenter.x,outlineDeltaY=position4.y-oldOutlineCenter.y,newOutline=pcbBoard.outline.map(p4=>({x:p4.x+outlineDeltaX,y:p4.y+outlineDeltaY}));db2.pcb_board.update(this.pcb_board_id,{outline:newOutline})}}}},Subcircuit=class extends Group6{constructor(props){super({...props,subcircuit:!0})}getSubcircuitPropHash(){return Subcircuit_getSubcircuitPropHash(this)}doInitialRenderIsolatedSubcircuits(){Subcircuit_doInitialRenderIsolatedSubcircuits(this)}doInitialInflateSubcircuitCircuitJson(){let isolatedJson=this._isolatedCircuitJson;if(isolatedJson){this._isInflatedFromCircuitJson=!0,this._isolatedCircuitJson=null,inflateCircuitJson(this,isolatedJson,[]);return}let{circuitJson,children}=this._parsedProps;circuitJson&&(this._isInflatedFromCircuitJson=!0),inflateCircuitJson(this,circuitJson,children)}},MountedBoard=class extends Subcircuit{constructor(){super(...arguments);__publicField(this,"pcb_board_id",null);__publicField(this,"_connectedSchematicPortPairs",new Set)}get config(){return{componentName:"MountedBoard",zodProps:mountedboardProps}}get boardThickness(){return 1.4}get allLayers(){return["top","bottom"]}_getBoardCalcVariables(){return this._findCarrierBoard()?._getBoardCalcVariables()??{}}_findCarrierBoard(){let current3=this.parent;for(;current3;){if(current3 instanceof Board)return current3;current3=current3.parent}return null}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalPcbPositionBeforeLayout(),pcb_board3=db2.pcb_board.insert({center:{x:globalPos.x,y:globalPos.y},width:props.width??0,height:props.height??0,is_mounted_to_carrier_board:!0});this.pcb_board_id=pcb_board3.pcb_board_id}doInitialPcbBoardAutoSize(){if(!this.pcb_board_id||!this.root)return;let carrierBoard=this._findCarrierBoard();carrierBoard?.pcb_board_id&&this.root.db.pcb_board.update(this.pcb_board_id,{carrier_pcb_board_id:carrierBoard.pcb_board_id})}},DEFAULT_TAB_LENGTH=5,DEFAULT_TAB_WIDTH=2,generateCutoutsAndMousebitesForOutline=(outline,options)=>{let{gapLength,cutoutWidth,mouseBites,mouseBiteHoleDiameter,mouseBiteHoleSpacing}=options,tabCutouts=[],mouseBiteHoles=[];if(outline.length<2)return{tabCutouts,mouseBiteHoles};let outlinePolygon=new Polygon$1(outline.map(p4=>point4(p4.x,p4.y))),is_ccw;if(outline.length>2){let p02=point4(outline[0].x,outline[0].y),p12=point4(outline[1].x,outline[1].y),segmentDir=vector$1(p02,p12).normalize(),normalToLeft=segmentDir.rotate(Math.PI/2),testPoint=p02.translate(segmentDir.multiply(segment(p02,p12).length/2)).translate(normalToLeft.multiply(.01));is_ccw=outlinePolygon.contains(testPoint)}else is_ccw=outlinePolygon.area()>0;for(let i3=0;i3<outline.length;i3++){let p1_=outline[i3],p2_=outline[(i3+1)%outline.length];if(!p1_||!p2_)continue;let p12=point4(p1_.x,p1_.y),p22=point4(p2_.x,p2_.y),segment2=segment(p12,p22),segmentLength=segment2.length;if(segmentLength<1e-6)continue;let segmentVec=vector$1(p12,p22),segmentDir=segmentVec.normalize(),normalVec=segmentDir.rotate(Math.PI/2),testPoint=segment2.middle().translate(normalVec.multiply(.01));outlinePolygon.contains(testPoint)&&(normalVec=normalVec.multiply(-1));let numBitesInGap=2,totalBitesLength=numBitesInGap*mouseBiteHoleDiameter+(numBitesInGap-1)*mouseBiteHoleSpacing,effectiveGapLength;mouseBites?effectiveGapLength=totalBitesLength:effectiveGapLength=gapLength,effectiveGapLength=Math.min(effectiveGapLength,segmentLength*.9);let gapStartDist=(segmentLength-effectiveGapLength)/2,gapEndDist=gapStartDist+effectiveGapLength;if(mouseBites){let holeAndSpacing=mouseBiteHoleDiameter+mouseBiteHoleSpacing;if(effectiveGapLength>=totalBitesLength&&holeAndSpacing>0){let firstBiteCenterOffsetInGap=(effectiveGapLength-totalBitesLength)/2+mouseBiteHoleDiameter/2,firstBiteDistFromP1=gapStartDist+firstBiteCenterOffsetInGap;for(let k4=0;k4<numBitesInGap;k4++){let biteDist=firstBiteDistFromP1+k4*holeAndSpacing,pos=p12.translate(segmentDir.multiply(biteDist));mouseBiteHoles.push({x:pos.x,y:pos.y})}}}let p_prev_=outline[(i3-1+outline.length)%outline.length],p_next_=outline[(i3+2)%outline.length],start_ext=0,end_ext=0;if(p_prev_&&p_next_){let vec_in_p1=vector$1(point4(p_prev_.x,p_prev_.y),p12),p1_cross=vec_in_p1.cross(segmentVec),is_p1_convex=is_ccw?p1_cross>1e-9:p1_cross<-1e-9,vec_out_p2=vector$1(p22,point4(p_next_.x,p_next_.y)),p2_cross=segmentVec.cross(vec_out_p2),is_p2_convex=is_ccw?p2_cross>1e-9:p2_cross<-1e-9;if(is_p1_convex){let angle=vec_in_p1.angleTo(segmentVec);angle>Math.PI&&(angle=2*Math.PI-angle),start_ext=cutoutWidth*Math.tan(angle/2)}else start_ext=0;if(is_p2_convex){let angle=segmentVec.angleTo(vec_out_p2);angle>Math.PI&&(angle=2*Math.PI-angle),end_ext=cutoutWidth*Math.tan(angle/2)}else end_ext=0}let cutoutParts=[{start:0-start_ext,end:gapStartDist},{start:gapEndDist,end:segmentLength+end_ext}],extrusion=normalVec.multiply(cutoutWidth);for(let part of cutoutParts){let partLength=part.end-part.start;if(partLength<1e-6)continue;let center2=p12.translate(segmentDir.multiply(part.start+partLength/2)).translate(extrusion.multiply(.5)),width=partLength,height=cutoutWidth,rotationDeg=segmentDir.slope*180/Math.PI;tabCutouts.push({type:"pcb_cutout",shape:"rect",center:{x:center2.x,y:center2.y},width,height,rotation:rotationDeg,corner_radius:cutoutWidth/2})}}return{tabCutouts,mouseBiteHoles}};function generatePanelTabsAndMouseBites(boards,options){let finalTabCutouts=[],allMouseBites=[],{tabWidth,tabLength,mouseBites:useMouseBites}=options,boardDimensions=[];for(let board of boards)if(board.width&&board.height)boardDimensions.push(Math.min(board.width,board.height));else if(board.outline&&board.outline.length>0){let outlinePolygon=new Polygon$1(board.outline.map(p4=>point4(p4.x,p4.y))),area=Math.abs(outlinePolygon.area());area>0&&boardDimensions.push(Math.sqrt(area))}if(boardDimensions.length>0){let scaleFactor=Math.min(...boardDimensions)/20;tabWidth=Math.min(tabWidth,DEFAULT_TAB_WIDTH*Math.max(scaleFactor,.3)),tabLength=Math.min(tabLength,DEFAULT_TAB_LENGTH*Math.max(scaleFactor,.3))}let processedBoards=boards.map(board=>{if((!board.outline||board.outline.length===0)&&board.width&&board.height){let w22=board.width/2,h22=board.height/2;return{...board,outline:[{x:board.center.x-w22,y:board.center.y-h22},{x:board.center.x+w22,y:board.center.y-h22},{x:board.center.x+w22,y:board.center.y+h22},{x:board.center.x-w22,y:board.center.y+h22}]}}return board});for(let board of processedBoards)if(board.outline&&board.outline.length>0){let mouseBiteDiameter2=tabWidth*.45,mouseBiteSpacing=mouseBiteDiameter2*.1,generated=generateCutoutsAndMousebitesForOutline(board.outline,{gapLength:tabLength,cutoutWidth:tabWidth,mouseBites:useMouseBites,mouseBiteHoleDiameter:mouseBiteDiameter2,mouseBiteHoleSpacing:mouseBiteSpacing});finalTabCutouts.push(...generated.tabCutouts),allMouseBites.push(...generated.mouseBiteHoles)}let tabCutouts=finalTabCutouts.map((tab,index)=>({...tab,pcb_cutout_id:`panel_tab_${index}`})),mouseBiteDiameter=tabWidth*.45,mouseBiteHoles=allMouseBites.map((bite,index)=>({type:"pcb_hole",pcb_hole_id:`panel_mouse_bite_${index}`,hole_shape:"circle",hole_diameter:mouseBiteDiameter,x:bite.x,y:bite.y}));return{tabCutouts,mouseBiteHoles}}var getBoardDimensionsFromProps=board=>{let props=board._parsedProps,width=props.width!=null?distance.parse(props.width):void 0,height=props.height!=null?distance.parse(props.height):void 0;if((width===void 0||height===void 0)&&props.outline?.length){let outlineBounds=getBoundsFromPoints(props.outline);outlineBounds&&(width??(width=outlineBounds.maxX-outlineBounds.minX),height??(height=outlineBounds.maxY-outlineBounds.minY))}if((width===void 0||height===void 0)&&props.circuitJson?.length){let pcbBoardFromJson=props.circuitJson.find(elm=>elm.type==="pcb_board");pcbBoardFromJson&&(width??(width=pcbBoardFromJson.width),height??(height=pcbBoardFromJson.height))}return{width:width??0,height:height??0}};function packIntoGrid({items,db:db2,row,col,cellWidth,cellHeight,boardGap,availablePanelWidth,availablePanelHeight}){let itemsWithDims=items.map(item=>{let dims=getItemDimensions(item,db2);return{item,width:dims.width,height:dims.height}}).filter(item=>!(item.width===0&&item.height===0));if(itemsWithDims.length===0)return{positions:[],gridWidth:0,gridHeight:0};let cols,rows,minCellWidth=cellWidth?distance.parse(cellWidth):0,minCellHeight=cellHeight?distance.parse(cellHeight):0;if(col!==void 0)cols=col,rows=row??Math.ceil(itemsWithDims.length/cols);else if(row!==void 0)rows=row,cols=Math.ceil(itemsWithDims.length/rows);else if(availablePanelWidth!==void 0&&availablePanelHeight!==void 0){let maxItemWidth=Math.max(...itemsWithDims.map(b3=>b3.width),minCellWidth),maxItemHeight=Math.max(...itemsWithDims.map(b3=>b3.height),minCellHeight),maxCols=Math.max(1,Math.floor((availablePanelWidth+boardGap)/(maxItemWidth+boardGap))),maxRows=Math.max(1,Math.floor((availablePanelHeight+boardGap)/(maxItemHeight+boardGap)));cols=maxCols,rows=Math.ceil(itemsWithDims.length/cols),rows>maxRows&&(rows=maxRows,cols=Math.ceil(itemsWithDims.length/rows),cols>maxCols&&(cols=maxCols,rows=Math.ceil(itemsWithDims.length/cols))),cols=Math.max(1,cols),rows=Math.max(1,rows)}else cols=Math.ceil(Math.sqrt(itemsWithDims.length)),rows=Math.ceil(itemsWithDims.length/cols);let colWidths=Array(cols).fill(0),rowHeights=Array(rows).fill(0);itemsWithDims.forEach((item,i3)=>{let colIdx=i3%cols,rowIdx=Math.floor(i3/cols);rowIdx<rowHeights.length&&item.height>rowHeights[rowIdx]&&(rowHeights[rowIdx]=item.height),colIdx<colWidths.length&&item.width>colWidths[colIdx]&&(colWidths[colIdx]=item.width)});for(let i3=0;i3<colWidths.length;i3++)colWidths[i3]=Math.max(colWidths[i3],minCellWidth);for(let i3=0;i3<rowHeights.length;i3++)rowHeights[i3]=Math.max(rowHeights[i3],minCellHeight);let gridWidth=colWidths.reduce((a3,b3)=>a3+b3,0)+(cols>1?(cols-1)*boardGap:0),gridHeight=rowHeights.reduce((a3,b3)=>a3+b3,0)+(rows>1?(rows-1)*boardGap:0),startX=-gridWidth/2,startY=-gridHeight/2,colXOffsets=[startX];for(let i3=1;i3<cols;i3++)colXOffsets.push(colXOffsets[i3-1]+colWidths[i3-1]+boardGap);let rowYOffsets=[startY];for(let i3=1;i3<rows;i3++)rowYOffsets.push(rowYOffsets[i3-1]+rowHeights[i3-1]+boardGap);let positions=[];return itemsWithDims.forEach((itemWithDims,i3)=>{let colIdx=i3%cols,rowIdx=Math.floor(i3/cols);if(rowIdx>=rowYOffsets.length||colIdx>=colXOffsets.length)return;let x4=colXOffsets[colIdx]+colWidths[colIdx]/2,y4=rowYOffsets[rowIdx]+rowHeights[rowIdx]/2;positions.push({item:itemWithDims.item,pos:{x:x4,y:y4}})}),{positions,gridWidth,gridHeight}}function getItemDimensions(item,db2){if(item.componentName==="Board"){let board=item;if(db2&&board.pcb_board_id){let pcbBoard=db2.pcb_board.get(board.pcb_board_id);if(pcbBoard?.width!==void 0&&pcbBoard?.height!==void 0)return{width:pcbBoard.width,height:pcbBoard.height}}return getBoardDimensionsFromProps(board)}if(item.componentName==="Subpanel"){let subpanel=item,props=subpanel._parsedProps;if(props.width!==void 0&&props.height!==void 0)return{width:distance.parse(props.width),height:distance.parse(props.height)};let directBoards=subpanel._getDirectBoardChildren();if(directBoards.length===0){let allBoards=subpanel._getAllBoardInstances();if(allBoards.length===0)return{width:0,height:0};let minX=1/0,minY=1/0,maxX=-1/0,maxY=-1/0;for(let board of allBoards){let dims=getBoardDimensionsFromProps(board);if(dims.width===0||dims.height===0)continue;let offset=board._panelPositionOffset??{x:0,y:0};minX=Math.min(minX,offset.x-dims.width/2),maxX=Math.max(maxX,offset.x+dims.width/2),minY=Math.min(minY,offset.y-dims.height/2),maxY=Math.max(maxY,offset.y+dims.height/2)}return minX===1/0?{width:0,height:0}:{width:maxX-minX,height:maxY-minY}}if(directBoards.length===1)return getBoardDimensionsFromProps(directBoards[0]);if(subpanel._cachedGridWidth>0&&subpanel._cachedGridHeight>0){let edgePadding=distance.parse(props.edgePadding??5);return{width:subpanel._cachedGridWidth+edgePadding*2,height:subpanel._cachedGridHeight+edgePadding*2}}let totalWidth=0,totalHeight=0;for(let board of directBoards){let dims=getBoardDimensionsFromProps(board);totalWidth=Math.max(totalWidth,dims.width),totalHeight=Math.max(totalHeight,dims.height)}return{width:totalWidth,height:totalHeight}}return{width:0,height:0}}var Subpanel=class _Subpanel extends Group6{constructor(){super(...arguments);__publicField(this,"pcb_panel_id",null);__publicField(this,"_tabsAndMouseBitesGenerated",!1);__publicField(this,"_cachedGridWidth",0);__publicField(this,"_cachedGridHeight",0);__publicField(this,"_panelPositionOffset",null)}get config(){return{componentName:"Subpanel",zodProps:subpanelProps}}get _errorComponentName(){return this.componentName.toLowerCase()}get isGroup(){return!0}get isSubcircuit(){return!0}_getPcbLayoutMode(){return"none"}doInitialSchematicComponentRender(){}doInitialSchematicLayout(){}doInitialSchematicTraceRender(){}add(component){if(component.lowercaseComponentName!=="board"&&component.lowercaseComponentName!=="subpanel")throw new Error(`<${this._errorComponentName}> can only contain <board> or <subpanel> elements`);super.add(component)}_computePcbGlobalTransformBeforeLayout(){if(this._panelPositionOffset){let parentTransform=this.parent?._computePcbGlobalTransformBeforeLayout?.()??identity();return compose2(parentTransform,translate2(this._panelPositionOffset.x,this._panelPositionOffset.y))}return super._computePcbGlobalTransformBeforeLayout()}_getAllBoardInstances(){let boards=[];for(let child of this.children)child instanceof Board?boards.push(child):child instanceof _Subpanel&&boards.push(...child._getAllBoardInstances());return boards}_containsBoards(){for(let child of this.children)if(child.componentName==="Board"||child.componentName==="Subpanel"&&"_containsBoards"in child&&child._containsBoards())return!0;return!1}_getDirectBoardChildren(){return this.children.filter(c4=>c4 instanceof Board)}doInitialPanelBoardLayout(){if(this.root?.pcbDisabled)return;let layoutMode=this._parsedProps.layoutMode??"none",gridItems=this.children.filter(c4=>c4 instanceof Board||c4 instanceof _Subpanel);if(layoutMode!=="none")for(let child of gridItems)child instanceof Board&&child._hasUserDefinedPcbPosition()&&this.root.db.source_property_ignored_warning.insert({source_component_id:child.source_component_id,property_name:"pcbX/pcbY",message:`Board has manual positioning but ${this._errorComponentName} layout mode is "${layoutMode}". Manual positioning will be ignored.`,error_type:"source_property_ignored_warning"});if(layoutMode==="none"&&gridItems.length>1&&gridItems.filter(c4=>!c4._hasUserDefinedPcbPosition()).length>1&&this.root.db.pcb_placement_error.insert({error_type:"pcb_placement_error",message:`Multiple boards/subpanels in ${this._errorComponentName} without positions. When layoutMode="none", each item must have explicit positioning. Use layoutMode="grid" for automatic positioning.`}),layoutMode!=="grid")return;let tabWidth=this._parsedProps.tabWidth??DEFAULT_TAB_WIDTH,boardGap=this._parsedProps.boardGap??tabWidth,availablePanelWidth,availablePanelHeight,hasExplicitRowOrCol=this._parsedProps.row!==void 0||this._parsedProps.col!==void 0,hasExplicitWidth=this._parsedProps.width!==void 0,hasExplicitHeight=this._parsedProps.height!==void 0;if(!hasExplicitRowOrCol&&hasExplicitWidth&&hasExplicitHeight){let{edgePadding:edgePaddingProp,edgePaddingLeft:edgePaddingLeftProp,edgePaddingRight:edgePaddingRightProp,edgePaddingTop:edgePaddingTopProp,edgePaddingBottom:edgePaddingBottomProp}=this._parsedProps,edgePadding=distance.parse(edgePaddingProp??5),edgePaddingLeft=distance.parse(edgePaddingLeftProp??edgePadding),edgePaddingRight=distance.parse(edgePaddingRightProp??edgePadding),edgePaddingTop=distance.parse(edgePaddingTopProp??edgePadding),edgePaddingBottom=distance.parse(edgePaddingBottomProp??edgePadding),panelWidth=distance.parse(this._parsedProps.width),panelHeight=distance.parse(this._parsedProps.height);availablePanelWidth=panelWidth-edgePaddingLeft-edgePaddingRight,availablePanelHeight=panelHeight-edgePaddingTop-edgePaddingBottom}let{positions,gridWidth,gridHeight}=packIntoGrid({items:gridItems,row:this._parsedProps.row,col:this._parsedProps.col,cellWidth:this._parsedProps.cellWidth,cellHeight:this._parsedProps.cellHeight,boardGap,availablePanelHeight,availablePanelWidth});this._cachedGridWidth=gridWidth,this._cachedGridHeight=gridHeight;for(let{item,pos}of positions)item._panelPositionOffset=pos}doInitialPanelLayout(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if((this._parsedProps.layoutMode??"none")==="grid"){for(let child of this.children)if(child instanceof Board){if(!child.pcb_board_id||!child._panelPositionOffset)continue;db2.pcb_board.update(child.pcb_board_id,{position_mode:"relative_to_panel_anchor",display_offset_x:`${child._panelPositionOffset.x}mm`,display_offset_y:`${child._panelPositionOffset.y}mm`})}else if(child instanceof _Subpanel&&child._panelPositionOffset)for(let board of child._getAllBoardInstances()){if(!board.pcb_board_id)continue;let boardOffset=board._panelPositionOffset??{x:0,y:0};db2.pcb_board.update(board.pcb_board_id,{position_mode:"relative_to_panel_anchor",display_offset_x:`${child._panelPositionOffset.x+boardOffset.x}mm`,display_offset_y:`${child._panelPositionOffset.y+boardOffset.y}mm`})}this._updatePanelDimensions()}else{let panelGlobalPos=this._getGlobalPcbPositionBeforeLayout();for(let board of this._getDirectBoardChildren()){if(!board.pcb_board_id)continue;let boardDb=db2.pcb_board.get(board.pcb_board_id);if(!boardDb)continue;let relativeX=boardDb.center.x-panelGlobalPos.x,relativeY=boardDb.center.y-panelGlobalPos.y;db2.pcb_board.update(board.pcb_board_id,{position_mode:"relative_to_panel_anchor",display_offset_x:`${relativeX}mm`,display_offset_y:`${relativeY}mm`})}}this._generateTabsAndMouseBites()}_updatePanelDimensions(){let{db:db2}=this.root,hasExplicitWidth=this._parsedProps.width!==void 0,hasExplicitHeight=this._parsedProps.height!==void 0,gridWidth=this._cachedGridWidth,gridHeight=this._cachedGridHeight;if(this.pcb_group_id){if(hasExplicitWidth&&hasExplicitHeight)db2.pcb_group.update(this.pcb_group_id,{width:distance.parse(this._parsedProps.width),height:distance.parse(this._parsedProps.height)});else if(gridWidth>0||gridHeight>0){let{edgePadding:edgePaddingProp,edgePaddingLeft:edgePaddingLeftProp,edgePaddingRight:edgePaddingRightProp,edgePaddingTop:edgePaddingTopProp,edgePaddingBottom:edgePaddingBottomProp}=this._parsedProps,edgePadding=distance.parse(edgePaddingProp??5),edgePaddingLeft=distance.parse(edgePaddingLeftProp??edgePadding),edgePaddingRight=distance.parse(edgePaddingRightProp??edgePadding),edgePaddingTop=distance.parse(edgePaddingTopProp??edgePadding),edgePaddingBottom=distance.parse(edgePaddingBottomProp??edgePadding);db2.pcb_group.update(this.pcb_group_id,{width:hasExplicitWidth?distance.parse(this._parsedProps.width):gridWidth+edgePaddingLeft+edgePaddingRight,height:hasExplicitHeight?distance.parse(this._parsedProps.height):gridHeight+edgePaddingTop+edgePaddingBottom})}}}_generateTabsAndMouseBites(){if(this._tabsAndMouseBitesGenerated)return;let{db:db2}=this.root,props=this._parsedProps,panelizationMethod=props.panelizationMethod??"none",childBoardInstances=this._getAllBoardInstances();if(panelizationMethod!=="none"){let childBoardIds=childBoardInstances.map(c4=>c4.pcb_board_id).filter(id2=>!!id2),boardsInPanel=db2.pcb_board.list().filter(b3=>childBoardIds.includes(b3.pcb_board_id));if(boardsInPanel.length===0)return;let tabWidth=props.tabWidth??DEFAULT_TAB_WIDTH,boardGap=props.boardGap??tabWidth,{tabCutouts,mouseBiteHoles}=generatePanelTabsAndMouseBites(boardsInPanel,{boardGap,tabWidth,tabLength:props.tabLength??DEFAULT_TAB_LENGTH,mouseBites:props.mouseBites??!0});for(let tabCutout of tabCutouts)db2.pcb_cutout.insert(tabCutout);for(let mouseBiteHole of mouseBiteHoles)db2.pcb_hole.insert(mouseBiteHole)}this._tabsAndMouseBitesGenerated=!0}doInitialPcbComponentRender(){if(!this.root?.pcbDisabled){if(!this._containsBoards())throw new Error(`<${this._errorComponentName}> must contain at least one <board>`);super.doInitialPcbComponentRender()}}},Panel=class extends Subpanel{get config(){return{componentName:"Panel",zodProps:panelProps}}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;if(!this._containsBoards())throw new Error(`<${this._errorComponentName}> must contain at least one <board>`);let{db:db2}=this.root,props=this._parsedProps,inserted=db2.pcb_panel.insert({width:props.width!==void 0?distance.parse(props.width):0,height:props.height!==void 0?distance.parse(props.height):0,thickness:1.6,center:this._getGlobalPcbPositionBeforeLayout(),covered_with_solder_mask:!(props.noSolderMask??!1)});this.pcb_panel_id=inserted.pcb_panel_id}_updatePanelDimensions(){let{db:db2}=this.root,hasExplicitWidth=this._parsedProps.width!==void 0,hasExplicitHeight=this._parsedProps.height!==void 0,gridWidth=this._cachedGridWidth,gridHeight=this._cachedGridHeight;if(this.pcb_panel_id){if(hasExplicitWidth&&hasExplicitHeight)db2.pcb_panel.update(this.pcb_panel_id,{width:distance.parse(this._parsedProps.width),height:distance.parse(this._parsedProps.height)});else if(gridWidth>0||gridHeight>0){let{edgePadding:edgePaddingProp,edgePaddingLeft:edgePaddingLeftProp,edgePaddingRight:edgePaddingRightProp,edgePaddingTop:edgePaddingTopProp,edgePaddingBottom:edgePaddingBottomProp}=this._parsedProps,edgePadding=distance.parse(edgePaddingProp??5),edgePaddingLeft=distance.parse(edgePaddingLeftProp??edgePadding),edgePaddingRight=distance.parse(edgePaddingRightProp??edgePadding),edgePaddingTop=distance.parse(edgePaddingTopProp??edgePadding),edgePaddingBottom=distance.parse(edgePaddingBottomProp??edgePadding);db2.pcb_panel.update(this.pcb_panel_id,{width:hasExplicitWidth?distance.parse(this._parsedProps.width):gridWidth+edgePaddingLeft+edgePaddingRight,height:hasExplicitHeight?distance.parse(this._parsedProps.height):gridHeight+edgePaddingTop+edgePaddingBottom})}}}updatePcbComponentRender(){if(this.root?.pcbDisabled||!this.pcb_panel_id)return;let{db:db2}=this.root,props=this._parsedProps,currentPanel=db2.pcb_panel.get(this.pcb_panel_id);db2.pcb_panel.update(this.pcb_panel_id,{width:props.width!==void 0?distance.parse(props.width):currentPanel?.width,height:props.height!==void 0?distance.parse(props.height):currentPanel?.height,center:this._getGlobalPcbPositionBeforeLayout(),covered_with_solder_mask:!(props.noSolderMask??!1)})}removePcbComponentRender(){this.pcb_panel_id&&(this.root?.db.pcb_panel.delete(this.pcb_panel_id),this.pcb_panel_id=null)}},Pinout=class extends Chip{constructor(props){super(props)}get config(){return{...super.config,componentName:"Pinout",zodProps:pinoutProps}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_pinout",name:this.name,manufacturer_part_number:props.manufacturerPartNumber,supplier_part_numbers:props.supplierPartNumbers,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},Fuse=class extends NormalComponent3{get config(){return{componentName:"fuse",schematicSymbolName:this.props.symbolName??"fuse",zodProps:fuseProps,sourceFtype:FTYPE.simple_fuse}}_getSchematicSymbolDisplayValue(){let rawCurrent=this._parsedProps.currentRating,rawVoltage=this._parsedProps.voltageRating,current3=typeof rawCurrent=="string"?parseFloat(rawCurrent):rawCurrent,voltage3=typeof rawVoltage=="string"?parseFloat(rawVoltage):rawVoltage;return`${formatSiUnit(current3)}A / ${formatSiUnit(voltage3)}V`}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,currentRating=typeof props.currentRating=="string"?parseFloat(props.currentRating):props.currentRating,voltageRating=typeof props.voltageRating=="string"?parseFloat(props.voltageRating):props.voltageRating,source_component=db2.source_component.insert({name:this.name,ftype:FTYPE.simple_fuse,current_rating_amps:currentRating,voltage_rating_volts:voltageRating,display_current_rating:`${formatSiUnit(currentRating)}A`,display_voltage_rating:`${formatSiUnit(voltageRating)}V`,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},Jumper=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"schematicDimensions",null)}get config(){return{schematicSymbolName:void 0,componentName:"Jumper",zodProps:jumperProps,shouldRenderAsSchematicBox:!0}}_getSchematicPortArrangement(){let arrangement=super._getSchematicPortArrangement();if(arrangement&&Object.keys(arrangement).length>0)return arrangement;let pinCount=this._parsedProps.pinCount??(Array.isArray(this._parsedProps.pinLabels)?this._parsedProps.pinLabels.length:this._parsedProps.pinLabels?Object.keys(this._parsedProps.pinLabels).length:this.getPortsFromFootprint().length),direction2=this._parsedProps.schDirection??"right";return{leftSize:direction2==="left"?pinCount:0,rightSize:direction2==="right"?pinCount:0}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),source_component=db2.source_component.insert({ftype:"simple_chip",name:this.name,manufacturer_part_number:props.manufacturerPartNumber,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),globalTransformRotation=this.getGlobalTransformRotation(),pcb_component3=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:props.layer??"top",rotation:props.pcbRotation??globalTransformRotation,insertion_direction:this._getPcbComponentInsertionDirection(props.layer??"top",globalTransformRotation),source_component_id:this.source_component_id,subcircuit_id:this.getSubcircuit().subcircuit_id??void 0,do_not_place:props.doNotPlace??!1,obstructs_within_bounds:props.obstructsWithinBounds??!0,metadata:props.kicadFootprintMetadata?{kicad_footprint:props.kicadFootprintMetadata}:void 0});this.pcb_component_id=pcb_component3.pcb_component_id}doInitialPcbTraceRender(){let{db:db2}=this.root,pcb_ports=db2.pcb_port.list({pcb_component_id:this.pcb_component_id}),pinLabelToPortId={};for(let i3=0;i3<pcb_ports.length;i3++){let port=pcb_ports[i3],sourcePort=db2.source_port.get(port.source_port_id),pinLabel="";if(typeof sourcePort?.pin_number=="number")pinLabel=sourcePort.pin_number.toString();else if(Array.isArray(sourcePort?.port_hints)){let matchedHint=sourcePort.port_hints.find(h6=>/^(pin)?\d+$/.test(h6));matchedHint&&(/^pin\d+$/.test(matchedHint)?pinLabel=matchedHint.replace(/^pin/,""):pinLabel=matchedHint)}pinLabelToPortId[pinLabel]=port.pcb_port_id}let traces=db2.pcb_trace.list({pcb_component_id:this.pcb_component_id}),updatePortId=portId=>{if(portId&&typeof portId=="string"&&portId.startsWith("{PIN")){let pin=portId.replace("{PIN","").replace("}","");return pinLabelToPortId[pin]||portId}return portId};for(let trace of traces)if(trace.route)for(let segment2 of trace.route)segment2.route_type==="wire"&&(segment2.start_pcb_port_id=updatePortId(segment2.start_pcb_port_id),segment2.end_pcb_port_id=updatePortId(segment2.end_pcb_port_id))}},INTERCONNECT_STANDARD_FOOTPRINTS={"0402":"0402","0603":"0603","0805":"0805",1206:"1206"},Interconnect=class extends NormalComponent3{get config(){return{componentName:"Interconnect",zodProps:interconnectProps,shouldRenderAsSchematicBox:!0,sourceFtype:"interconnect"}}get defaultInternallyConnectedPinNames(){let{standard}=this._parsedProps;return standard&&INTERCONNECT_STANDARD_FOOTPRINTS[standard]?[["pin1","pin2"]]:[]}_getImpliedFootprintString(){let{standard}=this._parsedProps;return standard?INTERCONNECT_STANDARD_FOOTPRINTS[standard]??null:null}doInitialSourceRender(){let{db:db2}=this.root,source_component=db2.source_component.insert({ftype:"interconnect",name:this.name,are_pins_interchangeable:!0,display_name:this._parsedProps.displayName});this.source_component_id=source_component.source_component_id}doInitialSourceParentAttachment(){let{db:db2}=this.root,internallyConnectedPorts=this._getInternallyConnectedPins();for(let ports of internallyConnectedPorts){let sourcePortIds=ports.map(port=>port.source_port_id).filter(id2=>id2!==null);sourcePortIds.length>=2&&db2.source_component_internal_connection.insert({source_component_id:this.source_component_id,subcircuit_id:this.getSubcircuit()?.subcircuit_id,source_port_ids:sourcePortIds})}}},SolderJumper=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"schematicDimensions",null)}_getPinNumberFromBridgedPinName(pinName){return this.selectOne(`port.${pinName}`,{type:"port"})?._parsedProps.pinNumber??null}get defaultInternallyConnectedPinNames(){if(this._parsedProps.bridged){let pins=this.children.filter(c4=>c4.componentName==="Port").map(p4=>p4.name);return pins.length>0?[pins]:[]}return this._parsedProps.bridgedPins??[]}get config(){let props=this._parsedProps??this.props,resolvedPinCount=props.pinCount;if(props.pinCount==null&&!props.footprint&&(resolvedPinCount=2),props.pinCount==null){let nums=(props.bridgedPins??[]).flat().map(p_str=>this._getPinNumberFromBridgedPinName(p_str)).filter(n4=>n4!==null),maxPinFromBridged=nums.length>0?Math.max(...nums):0,pinCountFromLabels=props.pinLabels?Object.keys(props.pinLabels).length:0,finalPinCount=Math.max(maxPinFromBridged,pinCountFromLabels);(finalPinCount===2||finalPinCount===3)&&(resolvedPinCount=finalPinCount),resolvedPinCount==null&&props.footprint&&[2,3].includes(this.getPortsFromFootprint().length)&&(resolvedPinCount=this.getPortsFromFootprint().length)}let symbolName="";resolvedPinCount?symbolName+=`solderjumper${resolvedPinCount}`:symbolName="solderjumper";let bridgedPinNumbers=[];return Array.isArray(props.bridgedPins)&&props.bridgedPins.length>0?bridgedPinNumbers=Array.from(new Set(props.bridgedPins.flat().map(pinName=>this._getPinNumberFromBridgedPinName(pinName)).filter(n4=>n4!==null))).sort((a3,b3)=>a3-b3):props.bridged&&resolvedPinCount&&(bridgedPinNumbers=Array.from({length:resolvedPinCount},(_4,i3)=>i3+1)),bridgedPinNumbers.length>0&&(symbolName+=`_bridged${bridgedPinNumbers.join("")}`),{schematicSymbolName:props.symbolName??symbolName,componentName:"SolderJumper",zodProps:solderjumperProps,shouldRenderAsSchematicBox:!0}}_getSchematicPortArrangement(){let arrangement=super._getSchematicPortArrangement();if(arrangement&&Object.keys(arrangement).length>0)return arrangement;let pinCount=this._parsedProps.pinCount??(Array.isArray(this._parsedProps.pinLabels)?this._parsedProps.pinLabels.length:this._parsedProps.pinLabels?Object.keys(this._parsedProps.pinLabels).length:this.getPortsFromFootprint().length);pinCount==null&&!this._parsedProps.footprint&&(pinCount=2);let direction2=this._parsedProps.schDirection??"right";return{leftSize:direction2==="left"?pinCount:0,rightSize:direction2==="right"?pinCount:0}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),source_component=db2.source_component.insert({ftype:"simple_chip",name:this.name,manufacturer_part_number:props.manufacturerPartNumber,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),globalTransformRotation=this.getGlobalTransformRotation(),pcb_component3=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:props.layer??"top",rotation:props.pcbRotation??globalTransformRotation,insertion_direction:this._getPcbComponentInsertionDirection(props.layer??"top",globalTransformRotation),source_component_id:this.source_component_id,subcircuit_id:this.getSubcircuit().subcircuit_id??void 0,do_not_place:props.doNotPlace??!1,obstructs_within_bounds:props.obstructsWithinBounds??!0,metadata:props.kicadFootprintMetadata?{kicad_footprint:props.kicadFootprintMetadata}:void 0});this.pcb_component_id=pcb_component3.pcb_component_id}doInitialPcbTraceRender(){let{db:db2}=this.root,pcb_ports=db2.pcb_port.list({pcb_component_id:this.pcb_component_id}),pinLabelToPortId={};for(let i3=0;i3<pcb_ports.length;i3++){let port=pcb_ports[i3],sourcePort=db2.source_port.get(port.source_port_id),pinLabel="";if(typeof sourcePort?.pin_number=="number")pinLabel=sourcePort.pin_number.toString();else if(Array.isArray(sourcePort?.port_hints)){let matchedHint=sourcePort.port_hints.find(h6=>/^(pin)?\d+$/.test(h6));matchedHint&&(/^pin\d+$/.test(matchedHint)?pinLabel=matchedHint.replace(/^pin/,""):pinLabel=matchedHint)}pinLabelToPortId[pinLabel]=port.pcb_port_id}let traces=db2.pcb_trace.list({pcb_component_id:this.pcb_component_id}),updatePortId=portId=>{if(portId&&typeof portId=="string"&&portId.startsWith("{PIN")){let pin=portId.replace("{PIN","").replace("}","");return pinLabelToPortId[pin]||portId}return portId};for(let trace of traces)if(trace.route)for(let segment2 of trace.route)segment2.route_type==="wire"&&(segment2.start_pcb_port_id=updatePortId(segment2.start_pcb_port_id),segment2.end_pcb_port_id=updatePortId(segment2.end_pcb_port_id))}},Led=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"pos",this.portMap.pin1);__publicField(this,"anode",this.portMap.pin1);__publicField(this,"neg",this.portMap.pin2);__publicField(this,"cathode",this.portMap.pin2)}get config(){let symbolMap={laser:"laser_diode"},variantSymbol=this.props.laser?"laser":null;return{schematicSymbolName:variantSymbol?symbolMap[variantSymbol]:this.props.symbolName??"led",componentName:"Led",zodProps:ledProps,sourceFtype:"simple_led"}}initPorts(){super.initPorts({additionalAliases:{pin1:["anode","pos","left"],pin2:["cathode","neg","right"]}})}_getSchematicSymbolDisplayValue(){return this._parsedProps.schDisplayValue||this._parsedProps.color||void 0}getFootprinterString(){let baseFootprint=super.getFootprinterString();return baseFootprint&&this.props.color?`${baseFootprint}_color(${this.props.color})`:baseFootprint}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_led",name:this.name,wave_length:props.wavelength,color:props.color,symbol_display_value:this._getSchematicSymbolDisplayValue(),manufacturer_part_number:props.manufacturerPartNumber??props.mfn,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!1,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},PowerSource=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"pos",this.portMap.pin1);__publicField(this,"positive",this.portMap.pin1);__publicField(this,"neg",this.portMap.pin2);__publicField(this,"negative",this.portMap.pin2)}get config(){return{schematicSymbolName:this.props.symbolName??"power_factor_meter_horz",componentName:"PowerSource",zodProps:powerSourceProps,sourceFtype:"simple_power_source"}}initPorts(){this.add(new Port({name:"pin1",pinNumber:1,aliases:["positive","pos"]})),this.add(new Port({name:"pin2",pinNumber:2,aliases:["negative","neg"]}))}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_power_source",name:this.name,voltage:props.voltage,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!1,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},VoltageSource=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"terminal1",this.portMap.terminal1);__publicField(this,"terminal2",this.portMap.terminal2)}get config(){return{componentName:"VoltageSource",schematicSymbolName:this.props.waveShape==="square"?"square_wave":"ac_voltmeter",zodProps:voltageSourceProps,sourceFtype:"simple_voltage_source"}}runRenderPhaseForChildren(phase){if(!phase.startsWith("Pcb"))for(let child of this.children)child.runRenderPhaseForChildren(phase),child.runRenderPhase(phase)}doInitialPcbComponentRender(){let hasExplicitPcbPosition=this._hasUserDefinedPcbPosition();if(!this._parsedProps.footprint){if(!hasExplicitPcbPosition)return;throw new Error("VoltageSource requires a footprint when pcbX/pcbY or pcb edge position props are used")}super.doInitialPcbComponentRender()}initPorts(){super.initPorts({additionalAliases:{pin1:["terminal1"],pin2:["terminal2"]}})}_getSchematicSymbolDisplayValue(){let{voltage:voltage3,frequency:frequency22}=this._parsedProps,parts=[];return voltage3!==void 0&&parts.push(`${formatSiUnit(voltage3)}V`),frequency22!==void 0&&parts.push(`${formatSiUnit(frequency22)}Hz`),parts.length>0?parts.join(" "):void 0}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_voltage_source",name:this.name,voltage:props.voltage,frequency:props.frequency,peak_to_peak_voltage:props.peakToPeakVoltage,wave_shape:props.waveShape,phase:props.phase,duty_cycle:props.dutyCycle,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}doInitialSimulationRender(){let{db:db2}=this.root,{_parsedProps:props}=this,terminal1Port=this.portMap.terminal1,terminal2Port=this.portMap.terminal2;db2.simulation_voltage_source.insert({type:"simulation_voltage_source",is_dc_source:!1,terminal1_source_port_id:terminal1Port.source_port_id,terminal2_source_port_id:terminal2Port.source_port_id,voltage:props.voltage,frequency:props.frequency,peak_to_peak_voltage:props.peakToPeakVoltage,wave_shape:props.waveShape,phase:props.phase,duty_cycle:props.dutyCycle})}},CurrentSource=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"pos",this.portMap.pos);__publicField(this,"neg",this.portMap.neg)}get config(){return{componentName:"CurrentSource",schematicSymbolName:"current_source",zodProps:currentSourceProps,sourceFtype:"simple_current_source"}}runRenderPhaseForChildren(phase){if(!phase.startsWith("Pcb"))for(let child of this.children)child.runRenderPhaseForChildren(phase),child.runRenderPhase(phase)}doInitialPcbComponentRender(){let hasExplicitPcbPosition=this._hasUserDefinedPcbPosition();if(!this._parsedProps.footprint){if(!hasExplicitPcbPosition)return;throw new Error("CurrentSource requires a footprint when pcbX/pcbY or pcb edge position props are used")}super.doInitialPcbComponentRender()}initPorts(){super.initPorts({additionalAliases:{pin1:["pos"],pin2:["neg"]}})}_getSchematicSymbolDisplayValue(){let{current:current3,frequency:frequency22,peakToPeakCurrent}=this._parsedProps,parts=[];return current3!==void 0&&parts.push(`${formatSiUnit(current3)}A`),peakToPeakCurrent!==void 0&&parts.push(`${formatSiUnit(peakToPeakCurrent)}A p-p`),frequency22!==void 0&&parts.push(`${formatSiUnit(frequency22)}Hz`),parts.length>0?parts.join(" "):void 0}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_current_source",name:this.name,current:props.current,frequency:props.frequency,peak_to_peak_current:props.peakToPeakCurrent,wave_shape:props.waveShape,phase:props.phase,duty_cycle:props.dutyCycle,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}doInitialSimulationRender(){let{db:db2}=this.root,{_parsedProps:props}=this,isAc=props.frequency!==void 0||props.peakToPeakCurrent!==void 0||props.waveShape!==void 0,posPort=this.portMap.pos,negPort=this.portMap.neg;if(isAc)db2.simulation_current_source.insert({type:"simulation_current_source",is_dc_source:!1,terminal1_source_port_id:posPort.source_port_id,terminal2_source_port_id:negPort.source_port_id,current:props.current,frequency:props.frequency,peak_to_peak_current:props.peakToPeakCurrent,wave_shape:props.waveShape,phase:props.phase,duty_cycle:props.dutyCycle});else{if(props.current===void 0)return;db2.simulation_current_source.insert({type:"simulation_current_source",is_dc_source:!0,positive_source_port_id:posPort.source_port_id,negative_source_port_id:negPort.source_port_id,current:props.current})}}},edgeSpecifiers=["leftedge","rightedge","topedge","bottomedge","center"],Constraint3=class extends PrimitiveComponent2{get config(){return{componentName:"Constraint",zodProps:constraintProps}}constructor(props){if(super(props),("xdist"in props||"ydist"in props)&&!("edgeToEdge"in props)&&!("centerToCenter"in props))throw new Error(`edgeToEdge, centerToCenter must be set for xDist or yDist for ${this}`);if("for"in props&&props.for.length<2)throw new Error(`"for" must have at least two selectors for ${this}`)}_getAllReferencedComponents(){let componentsWithSelectors=[],container=this.getPrimitiveContainer();function addComponentFromSelector(selector){let maybeEdge=selector.split(" ").pop(),edge=edgeSpecifiers.includes(maybeEdge)?maybeEdge:void 0,componentSelector=edge?selector.replace(` ${edge}`,""):selector,component=container.selectOne(componentSelector,{pcbPrimitive:!0});component&&componentsWithSelectors.push({selector,component,componentSelector,edge})}for(let key of["left","right","top","bottom"])key in this._parsedProps&&addComponentFromSelector(this._parsedProps[key]);if("for"in this._parsedProps)for(let selector of this._parsedProps.for)addComponentFromSelector(selector);return{componentsWithSelectors}}},FabricationNoteDimension=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"fabrication_note_dimension_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"FabricationNoteDimension",zodProps:fabricationNoteDimensionProps}}_resolvePoint(input2,transform6){if(typeof input2=="string"){let target=this.getSubcircuit().selectOne(input2);return target?target._getGlobalPcbPositionBeforeLayout():(this.renderError(`FabricationNoteDimension could not find selector "${input2}"`),applyToPoint2(transform6,{x:0,y:0}))}let numericX=typeof input2.x=="string"?parseFloat(input2.x):input2.x,numericY=typeof input2.y=="string"?parseFloat(input2.y):input2.y;return applyToPoint2(transform6,{x:numericX,y:numericY})}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform6=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(props.from,transform6),to3=this._resolvePoint(props.to,transform6),subcircuit=this.getSubcircuit(),group=this.getGroup(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),layer=maybeFlipLayer(props.layer??"top");if(layer!=="top"&&layer!=="bottom")throw new Error(`Invalid layer "${layer}" for FabricationNoteDimension. Must be "top" or "bottom".`);let pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,text=props.text??this._formatDistanceText({from,to:to3,units:props.units??"mm"}),fabrication_note_dimension=db2.pcb_fabrication_note_dimension.insert({pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:group?.pcb_group_id??void 0,layer,from,to:to3,text,offset:props.offset,font:props.font??"tscircuit2024",font_size:props.fontSize??1,color:props.color,arrow_size:props.arrowSize??1});this.fabrication_note_dimension_id=fabrication_note_dimension.pcb_fabrication_note_dimension_id}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.fabrication_note_dimension_id)return;let dimension=db2.pcb_fabrication_note_dimension.get(this.fabrication_note_dimension_id);dimension&&db2.pcb_fabrication_note_dimension.update(this.fabrication_note_dimension_id,{from:{x:dimension.from.x+deltaX,y:dimension.from.y+deltaY},to:{x:dimension.to.x+deltaX,y:dimension.to.y+deltaY}})}getPcbSize(){let transform6=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(this._parsedProps.from,transform6),to3=this._resolvePoint(this._parsedProps.to,transform6);return{width:Math.abs(to3.x-from.x),height:Math.abs(to3.y-from.y)}}_formatDistanceText({from,to:to3,units}){let dx3=to3.x-from.x,dy3=to3.y-from.y,distanceInMillimeters=Math.sqrt(dx3*dx3+dy3*dy3),distanceInUnits=units==="in"?distanceInMillimeters/25.4:distanceInMillimeters,roundedDistance=Math.round(distanceInUnits);if(Math.abs(distanceInUnits-roundedDistance)<1e-9)return`${roundedDistance}${units}`;let decimalPlaces=units==="in"?3:2;return`${units==="in"?Number(distanceInUnits.toFixed(decimalPlaces)).toString():distanceInUnits.toFixed(decimalPlaces)}${units}`}},PcbNoteDimension=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_note_dimension_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"PcbNoteDimension",zodProps:pcbNoteDimensionProps}}_resolvePoint(input2,transform6){if(typeof input2=="string"){let target=this.getSubcircuit().selectOne(`.${input2}`);if(!target)return this.renderError(`PcbNoteDimension could not find selector "${input2}"`),applyToPoint2(transform6,{x:0,y:0});let targetPcbComponentId=target.pcb_component_id,root=this.root;if(targetPcbComponentId&&root){let pcbComponent=root.db.pcb_component.get(targetPcbComponentId);if(pcbComponent?.center)return{x:pcbComponent.center.x,y:pcbComponent.center.y}}return target._getGlobalPcbPositionBeforeLayout()}let numericX=typeof input2.x=="string"?parseFloat(input2.x):input2.x,numericY=typeof input2.y=="string"?parseFloat(input2.y):input2.y;return applyToPoint2(transform6,{x:numericX,y:numericY})}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform6=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(props.from,transform6),to3=this._resolvePoint(props.to,transform6),subcircuit=this.getSubcircuit(),group=this.getGroup(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id??void 0,text=props.text??this._formatDistanceText({from,to:to3,units:props.units??"mm"}),pcb_note_dimension3=db2.pcb_note_dimension.insert({pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:group?.pcb_group_id??void 0,from,to:to3,text,font:props.font??"tscircuit2024",font_size:props.fontSize??1,layer:props.layer==="bottom"?"bottom":"top",color:props.color,arrow_size:props.arrowSize??1});this.pcb_note_dimension_id=pcb_note_dimension3.pcb_note_dimension_id}doInitialPcbLayout(){let root=this.root;if(!root||root.pcbDisabled||!this.pcb_note_dimension_id)return;let{db:db2}=root,transform6=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(this._parsedProps.from,transform6),to3=this._resolvePoint(this._parsedProps.to,transform6);db2.pcb_note_dimension.update(this.pcb_note_dimension_id,{from,to:to3})}getPcbSize(){let transform6=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(this._parsedProps.from,transform6),to3=this._resolvePoint(this._parsedProps.to,transform6);return{width:Math.abs(to3.x-from.x),height:Math.abs(to3.y-from.y)}}_formatDistanceText({from,to:to3,units}){let dx3=to3.x-from.x,dy3=to3.y-from.y,distanceInMillimeters=Math.sqrt(dx3*dx3+dy3*dy3),distanceInUnits=units==="in"?distanceInMillimeters/25.4:distanceInMillimeters,roundedDistance=Math.round(distanceInUnits);if(Math.abs(distanceInUnits-roundedDistance)<1e-9)return`${roundedDistance}${units}`;let decimalPlaces=units==="in"?3:2;return`${units==="in"?Number(distanceInUnits.toFixed(decimalPlaces)).toString():distanceInUnits.toFixed(decimalPlaces)}${units}`}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_note_dimension_id)return;let dimension=db2.pcb_note_dimension.get(this.pcb_note_dimension_id);dimension&&db2.pcb_note_dimension.update(this.pcb_note_dimension_id,{from:{x:dimension.from.x+deltaX,y:dimension.from.y+deltaY},to:{x:dimension.to.x+deltaX,y:dimension.to.y+deltaY}})}},Breakout=class extends Group6{constructor(props){super({...props,subcircuit:!0})}doInitialPcbPrimitiveRender(){if(super.doInitialPcbPrimitiveRender(),this.root?.pcbDisabled)return;let{db:db2}=this.root,props=this._parsedProps;if(!this.pcb_group_id)return;let pcb_group3=db2.pcb_group.get(this.pcb_group_id),padLeft=props.paddingLeft??props.padding??0,padRight=props.paddingRight??props.padding??0,padTop=props.paddingTop??props.padding??0,padBottom=props.paddingBottom??props.padding??0;db2.pcb_group.update(this.pcb_group_id,{width:(pcb_group3.width??0)+padLeft+padRight,height:(pcb_group3.height??0)+padTop+padBottom,center:{x:pcb_group3.center.x+(padRight-padLeft)/2,y:pcb_group3.center.y+(padTop-padBottom)/2}})}},BreakoutPoint=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_breakout_point_id",null);__publicField(this,"matchedPort",null);__publicField(this,"matchedNet",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"BreakoutPoint",zodProps:breakoutPointProps}}_matchConnection(){let{connection}=this._parsedProps,subcircuit=this.getSubcircuit();subcircuit&&(this.matchedPort=subcircuit.selectOne(connection,{type:"port"}),this.matchedPort||(this.matchedNet=subcircuit.selectOne(connection,{type:"net"})),!this.matchedPort&&!this.matchedNet&&this.renderError(`Could not find connection target "${connection}"`))}_getSourceTraceIdForPort(port){let{db:db2}=this.root;return db2.source_trace.list().find(st3=>st3.connected_source_port_ids.includes(port.source_port_id))?.source_trace_id}_getSourceNetIdForPort(port){let{db:db2}=this.root;return db2.source_trace.list().find(st3=>st3.connected_source_port_ids.includes(port.source_port_id))?.connected_source_net_ids[0]}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;this._matchConnection();let position4=this._getGlobalPcbPositionBeforeLayout(),group=this.parent?.getGroup(),subcircuit=this.getSubcircuit();if(!group||!group.pcb_group_id)return;let pcb_breakout_point3=db2.pcb_breakout_point.insert({pcb_group_id:group.pcb_group_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,source_port_id:this.matchedPort?.source_port_id??void 0,source_trace_id:this.matchedPort?this._getSourceTraceIdForPort(this.matchedPort):void 0,source_net_id:this.matchedNet?this.matchedNet.source_net_id:this.matchedPort?this._getSourceNetIdForPort(this.matchedPort):void 0,x:position4.x,y:position4.y});this.pcb_breakout_point_id=pcb_breakout_point3.pcb_breakout_point_id}_getPcbCircuitJsonBounds(){let position4=this._getGlobalPcbPositionBeforeLayout();return{center:{x:position4.x,y:position4.y},bounds:{left:position4.x,top:position4.y,right:position4.x,bottom:position4.y},width:0,height:0}}_setPositionFromLayout(newCenter){let{db:db2}=this.root;this.pcb_breakout_point_id&&db2.pcb_breakout_point.update(this.pcb_breakout_point_id,{x:newCenter.x,y:newCenter.y})}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_breakout_point_id)return;let point62=db2.pcb_breakout_point.get(this.pcb_breakout_point_id);point62&&db2.pcb_breakout_point.update(this.pcb_breakout_point_id,{x:point62.x+deltaX,y:point62.y+deltaY})}getPcbSize(){return{width:0,height:0}}},NetLabel=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"source_net_label_id")}get config(){return{componentName:"NetLabel",zodProps:netLabelProps}}_getAnchorSide(){let{_parsedProps:props}=this;if(props.anchorSide)return props.anchorSide;if(!this._resolveConnectsTo())return"right";let anchorPos=this._getGlobalSchematicPositionBeforeLayout(),connectedPorts=this._getConnectedPorts();if(connectedPorts.length===0)return"right";let connectedPortPosition=connectedPorts[0]._getGlobalSchematicPositionBeforeLayout(),dx3=connectedPortPosition.x-anchorPos.x,dy3=connectedPortPosition.y-anchorPos.y;if(Math.abs(dx3)>Math.abs(dy3)){if(dx3>0)return"right";if(dx3<0)return"left"}else{if(dy3>0)return"top";if(dy3<0)return"bottom"}return"right"}_getConnectedPorts(){let connectsTo=this._resolveConnectsTo();if(!connectsTo)return[];let connectedPorts=[];for(let connection of connectsTo){let port=this.getSubcircuit().selectOne(connection);port&&connectedPorts.push(port)}return connectedPorts}computeSchematicPropsTransform(){let{_parsedProps:props}=this;if(props.schX===void 0&&props.schY===void 0){let connectedPorts=this._getConnectedPorts();if(connectedPorts.length>0){let portPos=connectedPorts[0]._getGlobalSchematicPositionBeforeLayout(),parentCenter=applyToPoint2(this.parent?.computeSchematicGlobalTransform?.()??identity(),{x:0,y:0});return translate2(portPos.x-parentCenter.x,portPos.y-parentCenter.y)}}return super.computeSchematicPropsTransform()}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,anchorPos=this._getGlobalSchematicPositionBeforeLayout(),net=this.getSubcircuit().selectOne(`net.${this._getNetName()}`),anchorSide=props.anchorSide??"right",center2=computeSchematicNetLabelCenter({anchor_position:anchorPos,anchor_side:anchorSide,text:props.net}),netLabel=db2.schematic_net_label.insert({text:props.net,source_net_id:net.source_net_id,anchor_position:anchorPos,center:center2,anchor_side:this._getAnchorSide()});this.source_net_label_id=netLabel.source_net_id}_resolveConnectsTo(){let{_parsedProps:props}=this,connectsTo=props.connectsTo??props.connection;if(Array.isArray(connectsTo))return connectsTo;if(typeof connectsTo=="string")return[connectsTo]}_getNetName(){let{_parsedProps:props}=this;return props.net}doInitialCreateNetsFromProps(){let{_parsedProps:props}=this;props.net&&createNetsFromProps(this,[`net.${props.net}`])}doInitialCreateTracesFromNetLabels(){if(this.root?.schematicDisabled)return;let connectsTo=this._resolveConnectsTo();if(connectsTo)for(let connection of connectsTo)this.add(new Trace3({from:connection,to:`net.${this._getNetName()}`}))}doInitialSchematicTraceRender(){if(!this.root?._featureMspSchematicTraceRouting||this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,connectsTo=this._resolveConnectsTo();if(!connectsTo||connectsTo.length===0)return;let anchorPos=this._getGlobalSchematicPositionBeforeLayout(),anchorSide=this._getAnchorSide(),anchorFacing={left:"x-",right:"x+",top:"y+",bottom:"y-"}[anchorSide],net=this.getSubcircuit().selectOne(`net.${this._getNetName()}`);for(let connection of connectsTo){let port=this.getSubcircuit().selectOne(connection,{type:"port"});if(!port||!port.schematic_port_id)continue;let existingTraceForThisConnection=!1;if(net?.source_net_id){let candidateSourceTrace=db2.source_trace.list().find(st3=>st3.connected_source_net_ids?.includes(net.source_net_id)&&st3.connected_source_port_ids?.includes(port.source_port_id??""));if(candidateSourceTrace&&(existingTraceForThisConnection=db2.schematic_trace.list().some(t52=>t52.source_trace_id===candidateSourceTrace.source_trace_id)),existingTraceForThisConnection)continue}let portPos=port._getGlobalSchematicPositionAfterLayout(),portFacing=convertFacingDirectionToElbowDirection(port.facingDirection??"right")??"x+",path=calculateElbow({x:portPos.x,y:portPos.y,facingDirection:portFacing},{x:anchorPos.x,y:anchorPos.y,facingDirection:anchorFacing});if(!Array.isArray(path)||path.length<2)continue;let edges=[];for(let i3=0;i3<path.length-1;i3++)edges.push({from:{x:path[i3].x,y:path[i3].y},to:{x:path[i3+1].x,y:path[i3+1].y}});let source_trace_id,subcircuit_connectivity_map_key;if(net?.source_net_id&&port.source_port_id){let st3=db2.source_trace.list().find(s3=>s3.connected_source_net_ids?.includes(net.source_net_id)&&s3.connected_source_port_ids?.includes(port.source_port_id));source_trace_id=st3?.source_trace_id,subcircuit_connectivity_map_key=st3?.subcircuit_connectivity_map_key||db2.source_net.get(net.source_net_id)?.subcircuit_connectivity_map_key}db2.schematic_trace.insert({source_trace_id,edges,junctions:[],subcircuit_connectivity_map_key}),db2.schematic_port.update(port.schematic_port_id,{is_connected:!0})}}},Fiducial=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_smtpad_id",null);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"Fiducial",zodProps:fiducialProps,sourceFtype:"simple_fiducial"}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position4=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_smtpad3=db2.pcb_smtpad.insert({pcb_component_id,layer:maybeFlipLayer(props.layer||"top"),shape:"circle",x:position4.x,y:position4.y,radius:distance.parse(props.padDiameter)/2,soldermask_margin:props.soldermaskPullback?distance.parse(props.soldermaskPullback):distance.parse(props.padDiameter)/2,is_covered_with_solder_mask:!0});this.pcb_smtpad_id=pcb_smtpad3.pcb_smtpad_id}getPcbSize(){let{_parsedProps:props}=this,d4=distance.parse(props.padDiameter);return{width:d4,height:d4}}_setPositionFromLayout(newCenter){if(!this.pcb_smtpad_id)return;let{db:db2}=this.root;db2.pcb_smtpad.update(this.pcb_smtpad_id,{x:newCenter.x,y:newCenter.y})}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_smtpad_id)return;let pad2=db2.pcb_smtpad.get(this.pcb_smtpad_id);pad2&&(pad2.shape==="rect"||pad2.shape==="circle"||pad2.shape==="rotated_rect"||pad2.shape==="pill"?this._setPositionFromLayout({x:pad2.x+deltaX,y:pad2.y+deltaY}):pad2.shape==="polygon"&&db2.pcb_smtpad.update(this.pcb_smtpad_id,{points:pad2.points.map(p4=>({x:p4.x+deltaX,y:p4.y+deltaY}))}))}},Via=class extends PrimitiveComponent2{constructor(props){super(props);__publicField(this,"pcb_via_id",null);__publicField(this,"matchedPort",null);__publicField(this,"isPcbPrimitive",!0);__publicField(this,"source_manually_placed_via_id",null);__publicField(this,"subcircuit_connectivity_map_key",null);let layers=this._getLayers();this._parsedProps.layers=layers,this.initPorts()}get config(){return{componentName:"Via",zodProps:viaProps}}getAvailablePcbLayers(){return["top","inner1","inner2","bottom"]}_getResolvedViaDiameters(pcbStyle2){return getViaDiameterDefaultsWithOverrides({holeDiameter:this._parsedProps.holeDiameter,padDiameter:this._parsedProps.outerDiameter},pcbStyle2)}getPcbSize(){let pcbStyle2=this.getInheritedMergedProperty("pcbStyle"),{padDiameter}=this._getResolvedViaDiameters(pcbStyle2);return{width:padDiameter,height:padDiameter}}_getPcbCircuitJsonBounds(){let{db:db2}=this.root,via=db2.pcb_via.get(this.pcb_via_id),size3=this.getPcbSize();return{center:{x:via.x,y:via.y},bounds:{left:via.x-size3.width/2,top:via.y-size3.height/2,right:via.x+size3.width/2,bottom:via.y+size3.height/2},width:size3.width,height:size3.height}}_setPositionFromLayout(newCenter){let{db:db2}=this.root;db2.pcb_via.update(this.pcb_via_id,{x:newCenter.x,y:newCenter.y})}_getLayers(){let{fromLayer="top",toLayer="bottom"}=this._parsedProps;return fromLayer===toLayer?[fromLayer]:[fromLayer,toLayer]}initPorts(){let layers=this._parsedProps.layers;for(let layer of layers){let port2=new Port({name:layer,layer});port2.registerMatch(this),this.add(port2)}let port=new Port({name:"pin1"});port.registerMatch(this),this.add(port)}_getConnectedNetOrTrace(){let connectsTo=this._parsedProps.connectsTo;if(!connectsTo)return null;let subcircuit=this.getSubcircuit(),selectors=Array.isArray(connectsTo)?connectsTo:[connectsTo];for(let selector of selectors)if(selector.startsWith("net.")){let net=subcircuit.selectOne(selector,{type:"net"});if(net)return net}return null}doInitialPcbComponentRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,pcbStyle2=this.getInheritedMergedProperty("pcbStyle"),{padDiameter}=this._getResolvedViaDiameters(pcbStyle2),position4=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component3=db2.pcb_component.insert({center:position4,width:padDiameter,height:padDiameter,layer:this._parsedProps.fromLayer??"top",rotation:0,source_component_id:this.source_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,obstructs_within_bounds:!0});this.pcb_component_id=pcb_component3.pcb_component_id}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,group=this.getGroup(),subcircuit=this.getSubcircuit(),source_via=db2.source_manually_placed_via.insert({source_group_id:group?.source_group_id,source_net_id:props.net??"",subcircuit_id:subcircuit?.subcircuit_id??void 0});this.source_component_id=source_via.source_manually_placed_via_id}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,pcbStyle2=this.getInheritedMergedProperty("pcbStyle"),{holeDiameter,padDiameter}=this._getResolvedViaDiameters(pcbStyle2),position4=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_via3=db2.pcb_via.insert({x:position4.x,y:position4.y,hole_diameter:holeDiameter,outer_diameter:padDiameter,layers:["bottom","top"],from_layer:this._parsedProps.fromLayer||"bottom",to_layer:this._parsedProps.toLayer||"top",subcircuit_id:subcircuit?.subcircuit_id??void 0,subcircuit_connectivity_map_key:this.subcircuit_connectivity_map_key??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0,net_is_assignable:this._parsedProps.netIsAssignable??void 0});this.pcb_via_id=pcb_via3.pcb_via_id;let connected=this._getConnectedNetOrTrace();connected&&"source_net_id"in connected&&connected.source_net_id&&db2.pcb_via.update(this.pcb_via_id,{pcb_trace_id:connected.source_net_id})}},EPSILON3=1e-9,isWireRoutePoint=routePoint=>routePoint.route_type==="wire",isPointOnSegment4=(p4,a3,b3)=>{let cross22=(p4.y-a3.y)*(b3.x-a3.x)-(p4.x-a3.x)*(b3.y-a3.y);if(Math.abs(cross22)>EPSILON3)return!1;let dot=(p4.x-a3.x)*(b3.x-a3.x)+(p4.y-a3.y)*(b3.y-a3.y);if(dot<-EPSILON3)return!1;let squaredLength=(b3.x-a3.x)**2+(b3.y-a3.y)**2;return!(dot-squaredLength>EPSILON3)},isPointInRing=(point62,ring3)=>{if(ring3.length<3)return!1;let inside2=!1,previous=ring3[ring3.length-1];for(let current3 of ring3){if(isPointOnSegment4(point62,previous,current3))return!0;current3.y>point62.y!=previous.y>point62.y&&point62.x<(previous.x-current3.x)*(point62.y-current3.y)/(previous.y-current3.y)+current3.x&&(inside2=!inside2),previous=current3}return inside2},isPointInRectPour=(p4,pour)=>{let{center:center2,width,height}=pour,rotationRad=(pour.rotation??0)*Math.PI/180,cosR=Math.cos(-rotationRad),sinR=Math.sin(-rotationRad),dx3=p4.x-center2.x,dy3=p4.y-center2.y,localX=dx3*cosR-dy3*sinR,localY=dx3*sinR+dy3*cosR;return Math.abs(localX)<=width/2+EPSILON3&&Math.abs(localY)<=height/2+EPSILON3},isPointInBrepPour=(p4,pour)=>{let outerRing=pour.brep_shape.outer_ring.vertices.map(v4=>({x:v4.x,y:v4.y}));if(!isPointInRing(p4,outerRing))return!1;for(let innerRing of pour.brep_shape.inner_rings){let points=innerRing.vertices.map(v4=>({x:v4.x,y:v4.y}));if(isPointInRing(p4,points))return!1}return!0},isPointInCopperPour=(point62,pour)=>pour.shape==="rect"?isPointInRectPour(point62,pour):pour.shape==="brep"?isPointInBrepPour(point62,pour):!1,isTraceConnectedToSourceNet=(trace,sourceNetId,sourceTraceById)=>{if(trace.source_trace_id===sourceNetId)return!0;if(!trace.source_trace_id)return!1;let sourceTrace=sourceTraceById.get(trace.source_trace_id);return sourceTrace?sourceTrace.connected_source_net_ids.includes(sourceNetId):!1},isSegmentFullyInsideCopperPour=(start,end,pour)=>{let dx3=end.x-start.x,dy3=end.y-start.y;return Math.hypot(dx3,dy3)<=EPSILON3?!1:[0,.25,.5,.75,1].every(t52=>isPointInCopperPour({x:start.x+dx3*t52,y:start.y+dy3*t52},pour))},markTraceSegmentsInsideCopperPour=({db:db2,copperPour})=>{if(!copperPour.source_net_id)return;let sourceTraceById=new Map(db2.source_trace.list().map(sourceTrace=>[sourceTrace.source_trace_id,sourceTrace]));for(let trace of db2.pcb_trace.list()){if(!isTraceConnectedToSourceNet(trace,copperPour.source_net_id,sourceTraceById))continue;let routeChanged=!1,nextRoute=trace.route.map(routePoint=>({...routePoint}));for(let i3=0;i3<nextRoute.length-1;i3++){let fromRoutePoint=nextRoute[i3],toRoutePoint=nextRoute[i3+1];!fromRoutePoint||!toRoutePoint||!isWireRoutePoint(fromRoutePoint)||!isWireRoutePoint(toRoutePoint)||fromRoutePoint.layer!==copperPour.layer||toRoutePoint.layer!==copperPour.layer||isSegmentFullyInsideCopperPour({x:fromRoutePoint.x,y:fromRoutePoint.y},{x:toRoutePoint.x,y:toRoutePoint.y},copperPour)&&(fromRoutePoint.is_inside_copper_pour=!0,fromRoutePoint.copper_pour_id=copperPour.pcb_copper_pour_id,toRoutePoint.is_inside_copper_pour=!0,toRoutePoint.copper_pour_id=copperPour.pcb_copper_pour_id,routeChanged=!0)}routeChanged&&db2.pcb_trace.update(trace.pcb_trace_id,{route:nextRoute})}},CopperPour=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"CopperPour",zodProps:copperPourProps}}getPcbSize(){return{width:0,height:0}}doInitialCreateNetsFromProps(){let{_parsedProps:props}=this;createNetsFromProps(this,[props.connectsTo])}doInitialPcbCopperPourRender(){this.root?.pcbDisabled||this._queueAsyncEffect("PcbCopperPourRender",async()=>{let{db:db2}=this.root,{_parsedProps:props}=this,net=this.getSubcircuit().selectOne(props.connectsTo);if(!net||!net.source_net_id){this.renderError(`Net "${props.connectsTo}" not found for copper pour`);return}let subcircuit=this.getSubcircuit(),circuitJson=db2.toArray(),sourceNet=circuitJson.find(elm=>elm.type==="source_net"&&elm.name===net.name),connectivityMap=getFullConnectivityMapFromCircuitJson(circuitJson),connectedNetId=sourceNet?.source_net_id??net.source_net_id,pourConnectivityKey=(connectedNetId?connectivityMap.getNetConnectedToId(connectedNetId):void 0)||sourceNet?.subcircuit_connectivity_map_key||"",clearance=props.clearance??.2,inputProblem=convertCircuitJsonToInputProblem(circuitJson,{layer:props.layer,pour_connectivity_key:pourConnectivityKey,pad_margin:props.padMargin??clearance,trace_margin:props.traceMargin??clearance,board_edge_margin:props.boardEdgeMargin??clearance,cutout_margin:props.cutoutMargin??clearance,outline:props.outline});await initializeManifoldGeometry();let solver=new CopperPourPipelineSolver(inputProblem);this.root.emit("solver:started",{solverName:"CopperPourPipelineSolver",solverParams:inputProblem,componentName:this.props.name});let{brep_shapes}=solver.getOutput(),coveredWithSolderMask=props.coveredWithSolderMask??!1;for(let brep_shape3 of brep_shapes){let insertedPour=db2.pcb_copper_pour.insert({shape:"brep",layer:props.layer,brep_shape:brep_shape3,source_net_id:net.source_net_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,covered_with_solder_mask:coveredWithSolderMask});markTraceSegmentsInsideCopperPour({db:db2,copperPour:insertedPour})}})}},CopperText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isPcbPrimitive",!0);__publicField(this,"pcb_copper_text_id",null)}get config(){return{componentName:"CopperText",zodProps:copperTextProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,container=this.getPrimitiveContainer(),position4=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_copper_text3=db2.pcb_copper_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:position4.x,y:position4.y},font:"tscircuit2024",font_size:props.fontSize,layer:props.layer??"top",text:normalizeTextForCircuitJson(props.text),ccw_rotation:props.pcbRotation,is_mirrored:props.mirrored,is_knockout:props.knockout,pcb_component_id:container.pcb_component_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0});this.pcb_copper_text_id=pcb_copper_text3.pcb_copper_text_id}getPcbSize(){let{_parsedProps:props}=this,fontSize=props.fontSize??1,textWidth=(props.text??"").length*fontSize,textHeight=fontSize;return{width:textWidth*fontSize,height:textHeight*fontSize}}_moveCircuitJsonElements({deltaX,deltaY}){if(this.root?.pcbDisabled)return;let{db:db2}=this.root;if(!this.pcb_copper_text_id)return;let text=db2.pcb_copper_text.get(this.pcb_copper_text_id);text&&db2.pcb_copper_text.update(this.pcb_copper_text_id,{anchor_position:{x:text.anchor_position.x+deltaX,y:text.anchor_position.y+deltaY}})}},Battery=class extends NormalComponent3{get config(){return{componentName:"Battery",schematicSymbolName:this.props.symbolName??"battery",zodProps:batteryProps,sourceFtype:"simple_power_source"}}initPorts(){super.initPorts({additionalAliases:{pin1:["anode","pos","left"],pin2:["cathode","neg","right"]}})}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({name:this.name,ftype:"simple_power_source",capacity:props.capacity,supplier_part_numbers:props.supplierPartNumbers,are_pins_interchangeable:!1,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},STANDARD_USB_C_PIN_LABELS=[{label:"GND1",aliases:[]},{label:"VBUS1",aliases:[]},{label:"CC1",aliases:[]},{label:"DP1",aliases:[]},{label:"DM1",aliases:["DN1"]},{label:"SBU1",aliases:[]},{label:"SBU2",aliases:[]},{label:"DM2",aliases:["DN2"]},{label:"DP2",aliases:[]},{label:"CC2",aliases:[]},{label:"VBUS2",aliases:[]},{label:"GND2",aliases:[]},{label:"SHELL1",aliases:["MH1","EH1","MOUNT1"]},{label:"SHELL2",aliases:["MH2","EH2","MOUNT2"]},{label:"SHELL3",aliases:["MH3","EH3","MOUNT3"]},{label:"SHELL4",aliases:["MH4","EH4","MOUNT4"]}],PIN_NUMBER_HINT_PATTERN=/^(?:pin)?(\d+)$/i,dedupeHintsPreservingOrder=hints=>Array.from(new Set(hints)),convertCircuitJsonToUsbCStandardCircuitJson=partCircuitJson=>{let unassignedPorts=[];for(let elm of partCircuitJson){if(elm.type!=="source_port")continue;let pinNumber=elm.pin_number;if(typeof pinNumber!="number")continue;let upperCaseHints=new Set;for(let hint of elm.port_hints??[])upperCaseHints.add(hint.trim().toUpperCase());unassignedPorts.push({pinKey:`pin${pinNumber}`,upperCaseHints})}let canonicalHintsByPin={};for(let{label,aliases:aliases2}of STANDARD_USB_C_PIN_LABELS){let canonicalAndAliasHintsUpper=[label,...aliases2].map(s3=>s3.toUpperCase()),matchIndex=unassignedPorts.findIndex(port=>canonicalAndAliasHintsUpper.some(hint=>port.upperCaseHints.has(hint)));if(matchIndex===-1)continue;let{pinKey}=unassignedPorts[matchIndex];canonicalHintsByPin[pinKey]=[label],unassignedPorts.splice(matchIndex,1)}return Object.keys(canonicalHintsByPin).length===0?partCircuitJson:partCircuitJson.map(elm=>{if(!("port_hints"in elm)||!Array.isArray(elm.port_hints))return elm;let originalHints=elm.port_hints.filter(h6=>typeof h6=="string").map(h6=>h6.trim()).filter(h6=>h6.length>0);if(originalHints.length===0)return elm;let pinKeys=new Set;elm.type==="source_port"&&typeof elm.pin_number=="number"&&pinKeys.add(`pin${elm.pin_number}`);for(let hint of originalHints){let matchedPin=hint.match(PIN_NUMBER_HINT_PATTERN);matchedPin&&pinKeys.add(`pin${Number.parseInt(matchedPin[1],10)}`)}let canonicalHintsToAdd=[];for(let pinKey of pinKeys)canonicalHintsToAdd.push(...canonicalHintsByPin[pinKey]??[]);return canonicalHintsToAdd.length===0?elm:{...elm,port_hints:dedupeHintsPreservingOrder([...originalHints,...canonicalHintsToAdd])}})},extractCadModelFromCircuitJson=circuitJson=>{let cadComponent=circuitJson.find(elm=>elm.type==="cad_component");if(!cadComponent)return;let cadModelCandidate={stlUrl:cadComponent.model_stl_url,objUrl:cadComponent.model_obj_url,gltfUrl:cadComponent.model_gltf_url,glbUrl:cadComponent.model_glb_url,stepUrl:cadComponent.model_step_url,wrlUrl:cadComponent.model_wrl_url,modelOriginPosition:cadComponent.model_origin_position??void 0,modelUnitToMmScale:cadComponent.model_unit_to_mm_scale_factor,modelBoardNormalDirection:cadComponent.model_board_normal_direction,size:cadComponent.size??void 0,rotationOffset:cadComponent.rotation??void 0,positionOffset:cadComponent.position??void 0,showAsTranslucentModel:cadComponent.show_as_translucent_model};if(!cadModelCandidate.stlUrl&&!cadModelCandidate.objUrl&&!cadModelCandidate.gltfUrl&&!cadModelCandidate.glbUrl&&!cadModelCandidate.stepUrl&&!cadModelCandidate.wrlUrl&&!cadComponent.model_jscad)return;cadComponent.model_jscad&&typeof cadComponent.model_jscad=="object"&&(cadModelCandidate.jscad=cadComponent.model_jscad);let parsedCadModel=cadModelProp.safeParse(cadModelCandidate);return parsedCadModel.success?parsedCadModel.data:void 0},INNER_SYMBOL_SCALE_FACTOR=.5,INNER_SYMBOL_LEFT_SHIFT_FACTOR=.15;function insertInnerSymbolInSchematicBox(connector,symbol){if(!connector.schematic_component_id||!connector.root)return;let{db:db2}=connector.root,schematicComponent=db2.schematic_component.get(connector.schematic_component_id);if(!schematicComponent||schematicComponent.symbol_name)return;let targetWidth=schematicComponent.size.width*INNER_SYMBOL_SCALE_FACTOR,targetHeight=schematicComponent.size.height*INNER_SYMBOL_SCALE_FACTOR,scaleFactor=Math.min(targetWidth/symbol.size.width,targetHeight/symbol.size.height);if(!Number.isFinite(scaleFactor)||scaleFactor<=0)return;let subcircuit_id=connector.getSubcircuit()?.subcircuit_id??void 0,center2=schematicComponent.center,symbolCenter=symbol.center,centerOffsetX=-schematicComponent.size.width*INNER_SYMBOL_LEFT_SHIFT_FACTOR,transformPoint=point62=>({x:center2.x+centerOffsetX+(point62.x-symbolCenter.x)*scaleFactor,y:center2.y+(point62.y-symbolCenter.y)*scaleFactor});for(let primitive of symbol.primitives)if(primitive.type==="path"){let points=primitive.points.map(transformPoint);if(primitive.closed&&points.length>1){let first=points[0],last=points[points.length-1];(first.x!==last.x||first.y!==last.y)&&points.push(first)}db2.schematic_path.insert({schematic_component_id:connector.schematic_component_id,points,is_filled:primitive.fill??!1,fill_color:primitive.fill?SCHEMATIC_COMPONENT_OUTLINE_COLOR:void 0,stroke_width:.02,subcircuit_id})}else if(primitive.type==="circle")db2.schematic_circle.insert({schematic_component_id:connector.schematic_component_id,center:transformPoint({x:primitive.x,y:primitive.y}),radius:primitive.radius*scaleFactor,stroke_width:.02,color:SCHEMATIC_COMPONENT_OUTLINE_COLOR,is_filled:primitive.fill,fill_color:primitive.fill?SCHEMATIC_COMPONENT_OUTLINE_COLOR:void 0,is_dashed:!1,subcircuit_id});else if(primitive.type==="box"){let topLeft=transformPoint({x:primitive.x,y:primitive.y}),bottomRight=transformPoint({x:primitive.x+primitive.width,y:primitive.y+primitive.height});db2.schematic_rect.insert({schematic_component_id:connector.schematic_component_id,center:{x:(topLeft.x+bottomRight.x)/2,y:(topLeft.y+bottomRight.y)/2},width:Math.abs(bottomRight.x-topLeft.x),height:Math.abs(bottomRight.y-topLeft.y),stroke_width:.02,color:SCHEMATIC_COMPONENT_OUTLINE_COLOR,is_filled:!1,is_dashed:!1,rotation:0,subcircuit_id})}}var USB_C_SIGNAL_LABELS_IN_ORDER=["VBUS1","VBUS2","CC1","CC2","DP1","DP2","DM1","DM2","SBU1","SBU2","GND1","GND2"],USB_C_SHELL_LABELS_IN_ORDER=["SHELL1","SHELL2","SHELL3","SHELL4"],USB_C_CANONICAL_LABELS_IN_ORDER=[...USB_C_SIGNAL_LABELS_IN_ORDER,...USB_C_SHELL_LABELS_IN_ORDER],USB_C_CANONICAL_LABELS=new Set([...USB_C_CANONICAL_LABELS_IN_ORDER]),USB_C_DEFAULT_SCH_PIN_STYLE_BY_LABEL=[["CC1",{marginTop:.15}],["DP1",{marginTop:.15}],["SBU1",{marginTop:.15}],["GND1",{marginTop:.15}],["SHELL4",{marginRight:.15}]],Connector=class extends Chip{_getConnectorProps(){return this._parsedProps}_hasExplicitFootprint(){return this._getConnectorProps().footprint!==void 0||this.children.some(child=>child.componentName==="Footprint")}_shouldUseStandardPartsEngineCircuitJsonFlow(){return!(!this._getConnectorProps().standard||this._hasExplicitFootprint()||this.getInheritedProperty("partsEngineDisabled"))}_insertStandardConnectorCircuitJsonError(standard,message){let{db:db2}=this.root,errorObj=unknown_error_finding_part.parse({type:"unknown_error_finding_part",message:`Failed to fetch circuit JSON for ${this.getString()} (standard="${standard}"): ${message}`,source_component_id:this.source_component_id??void 0,subcircuit_id:this.getSubcircuit()?.subcircuit_id??void 0});db2.unknown_error_finding_part.insert(errorObj)}_getSupplierPartNumbersToTry(supplierPartNumbers){let partNumbers=[];for(let supplier of Object.keys(supplierPartNumbers??{})){let nums=supplierPartNumbers?.[supplier];Array.isArray(nums)&&nums.length>0&&partNumbers.push(nums[0])}return partNumbers}async _tryFetchPartCircuitJson(fetchPartCircuitJson,params){let maybeCircuitJson=await Promise.resolve(fetchPartCircuitJson(params))??null;return Array.isArray(maybeCircuitJson)&&maybeCircuitJson.length>0?maybeCircuitJson:null}async _fetchStandardConnectorCircuitJson(fetchPartCircuitJson,supplierPartNumbers,manufacturerPartNumber){for(let supplierPartNumber of this._getSupplierPartNumbersToTry(supplierPartNumbers)){let circuitJson=await this._tryFetchPartCircuitJson(fetchPartCircuitJson,{supplierPartNumber});if(circuitJson)return circuitJson}return manufacturerPartNumber?this._tryFetchPartCircuitJson(fetchPartCircuitJson,{manufacturerPartNumber}):null}_addConnectorFootprintFromCircuitJson(standard,circuitJson){let props=this._getConnectorProps(),standardizedCircuitJson=standard==="usb_c"?convertCircuitJsonToUsbCStandardCircuitJson(circuitJson):circuitJson,fpComponents=createComponentsFromCircuitJson({componentName:this.name,componentRotation:String(props.pcbRotation??0),footprinterString:`standard:${standard}`,pinLabels:props.pinLabels,pcbPinLabels:props.pcbPinLabels},standardizedCircuitJson),fetchedCadModel=extractCadModelFromCircuitJson(standardizedCircuitJson);fetchedCadModel&&(this._asyncFootprintCadModel=fetchedCadModel),this.addAll(fpComponents),this._markDirty("InitializePortsFromChildren")}_getUsbCCanonicalLabelToPinNumberMap(){let labelToPinNumber=new Map,ports=this.selectAll("port");for(let port of ports){let pinNumber=port.props.pinNumber;if(typeof pinNumber=="number")for(let alias of port.getNameAndAliases()){let normalizedAlias=alias.trim().toUpperCase();if(!USB_C_CANONICAL_LABELS.has(normalizedAlias))continue;let label=normalizedAlias;labelToPinNumber.has(label)||labelToPinNumber.set(label,pinNumber)}}return labelToPinNumber}_getSchematicPortArrangement(){let arrangement=super._getSchematicPortArrangement();if(arrangement&&Object.keys(arrangement).length>0||this._getConnectorProps().standard!=="usb_c")return arrangement;let labelToPinNumber=this._getUsbCCanonicalLabelToPinNumberMap(),rightPins=USB_C_SIGNAL_LABELS_IN_ORDER.map(label=>labelToPinNumber.get(label)).filter(pin=>typeof pin=="number"),bottomPins=USB_C_SHELL_LABELS_IN_ORDER.map(label=>labelToPinNumber.get(label)).filter(pin=>typeof pin=="number");if(rightPins.length===0&&bottomPins.length===0)return arrangement;let canonicalArrangement={};return rightPins.length>0&&(canonicalArrangement.rightSide={pins:rightPins,direction:"top-to-bottom"}),bottomPins.length>0&&(canonicalArrangement.bottomSide={pins:bottomPins,direction:"left-to-right"}),canonicalArrangement}_getSchematicBoxDimensions(){if(this._getConnectorProps().standard!=="usb_c")return super._getSchematicBoxDimensions();if(this.getSchematicSymbol()||!this.config.shouldRenderAsSchematicBox)return null;let{_parsedProps:props}=this,pinCount=this._getPrimaryPinCount(),pinSpacing=.2,allPinLabels={...this._getPinLabelsFromPorts()};if(props.pinLabels)for(let[k4,v4]of Object.entries(props.pinLabels))typeof v4=="string"&&(allPinLabels[k4]=v4);let labelToPinNumber=this._getUsbCCanonicalLabelToPinNumberMap(),resolvedDefaultSchPinStyle={};for(let[label,style]of USB_C_DEFAULT_SCH_PIN_STYLE_BY_LABEL){let pinNumber=labelToPinNumber.get(label);typeof pinNumber=="number"&&(resolvedDefaultSchPinStyle[`pin${pinNumber}`]=style)}let mergedSchPinStyle={...resolvedDefaultSchPinStyle,...props.schPinStyle??{}},schPortArrangement=this._getSchematicPortArrangement();return getAllDimensionsForSchematicBox({schWidth:props.schWidth,schHeight:props.schHeight,schPinSpacing:pinSpacing,numericSchPinStyle:getNumericSchPinStyle(mergedSchPinStyle,allPinLabels),pinCount,schPortArrangement:schPortArrangement??void 0,pinLabels:allPinLabels})}get config(){return{componentName:"Connector",zodProps:connectorProps,shouldRenderAsSchematicBox:!0}}doInitialSourceRender(){let{db:db2}=this.root,props=this._getConnectorProps(),manufacturerPartNumber=props.manufacturerPartNumber??props.mfn,source_component=db2.source_component.insert({ftype:"simple_connector",name:this.name,manufacturer_part_number:manufacturerPartNumber,supplier_part_numbers:props.supplierPartNumbers,display_name:props.displayName,standard:props.standard});this.source_component_id=source_component.source_component_id,props.standard&&!manufacturerPartNumber&&db2.source_missing_manufacturer_part_number_warning.insert({source_component_id:this.source_component_id,standard:props.standard,subcircuit_id:this.getSubcircuit()?.subcircuit_id??void 0,warning_type:"source_missing_manufacturer_part_number_warning",message:`${this.getString()} has standard="${props.standard}" but no manufacturerPartNumber (mfn). Add mfn if you do not want the USB-C part to change in future.`})}_isUsingStandardPartsEngineCircuitJsonFlow(){return this._shouldUseStandardPartsEngineCircuitJsonFlow()?!!this.getInheritedProperty("partsEngine")?.fetchPartCircuitJson:!1}doInitialFetchPartFootprint(){let props=this._getConnectorProps(),standard=props.standard;if(!standard||!this._shouldUseStandardPartsEngineCircuitJsonFlow()||this._hasStartedFootprintUrlLoad)return;let partsEngine2=this.getInheritedProperty("partsEngine");if(partsEngine2&&!partsEngine2.fetchPartCircuitJson){this._insertStandardConnectorCircuitJsonError(standard,"partsEngine.fetchPartCircuitJson is not configured");return}let fetchPartCircuitJson=partsEngine2?.fetchPartCircuitJson;if(!fetchPartCircuitJson)return;this._hasStartedFootprintUrlLoad=!0;let sourceComponentForQuery={type:"source_component",ftype:"simple_connector",name:this.name,manufacturer_part_number:props.manufacturerPartNumber??props.mfn,standard};this._queueAsyncEffect("load-standard-connector-circuit-json",async()=>{let{db:db2}=this.root;try{let supplierPartNumbers=await this._getSupplierPartNumbers(partsEngine2,sourceComponentForQuery,`standard:${standard}`);this.source_component_id&&db2.source_component.update(this.source_component_id,{supplier_part_numbers:supplierPartNumbers});let circuitJson=await this._fetchStandardConnectorCircuitJson(fetchPartCircuitJson,supplierPartNumbers,sourceComponentForQuery.manufacturer_part_number);if(!circuitJson)return;this._addConnectorFootprintFromCircuitJson(standard,circuitJson)}catch(error2){this._insertStandardConnectorCircuitJsonError(standard,error2.message)}})}doInitialPartsEngineRender(){this._isUsingStandardPartsEngineCircuitJsonFlow()||super.doInitialPartsEngineRender()}updatePartsEngineRender(){this._isUsingStandardPartsEngineCircuitJsonFlow()||super.updatePartsEngineRender()}doInitialSchematicComponentRender(){if(super.doInitialSchematicComponentRender(),!this.root?.schematicDisabled&&this.schematic_component_id&&this._getConnectorProps().standard==="usb_c"){let usbcSymbol=Vf.usbc;usbcSymbol&&insertInnerSymbolInSchematicBox(this,usbcSymbol)}}doInitialPcbComponentSizeCalculation(){if(super.doInitialPcbComponentSizeCalculation(),this.root?.pcbDisabled||!this.pcb_component_id||!this.source_component_id)return;let{db:db2}=this.root,connectorCircuitJson=db2.toArray().filter(elm=>elm.type==="pcb_component"?elm.pcb_component_id===this.pcb_component_id:elm.type==="source_component"?elm.source_component_id===this.source_component_id:"pcb_component_id"in elm&&elm.pcb_component_id===this.pcb_component_id||"source_component_id"in elm&&elm.source_component_id===this.source_component_id);if(connectorCircuitJson.length===0)return;let inferredInsertionCenter=guessCableInsertCenter(connectorCircuitJson);db2.pcb_component.update(this.pcb_component_id,{cable_insertion_center:{x:inferredInsertionCenter.x,y:inferredInsertionCenter.y}})}},PinHeader=class extends NormalComponent3{_getPcbRotationBeforeLayout(){let orientationRotation=this.props.pcbOrientation==="vertical"?-90:0;return(super._getPcbRotationBeforeLayout()??0)+orientationRotation}get config(){return{componentName:"PinHeader",zodProps:pinHeaderProps,shouldRenderAsSchematicBox:!0}}_getImpliedFootprintString(){let pinCount=this._parsedProps.pinCount??(Array.isArray(this._parsedProps.pinLabels)?this._parsedProps.pinLabels.length:this._parsedProps.pinLabels?Object.keys(this._parsedProps.pinLabels).length:0),holeDiameter=this._parsedProps.holeDiameter,platedDiameter=this._parsedProps.platedDiameter,pitch=this._parsedProps.pitch,showSilkscreenPinLabels=this._parsedProps.showSilkscreenPinLabels,rows=this._parsedProps.doubleRow?2:1;if(pinCount>0){let footprintString;if(pitch)!holeDiameter&&!platedDiameter?footprintString=`pinrow${pinCount}_p${pitch}`:footprintString=`pinrow${pinCount}_p${pitch}_id${holeDiameter}_od${platedDiameter}`;else if(!holeDiameter&&!platedDiameter)footprintString=`pinrow${pinCount}`;else return null;return showSilkscreenPinLabels!==!0&&(footprintString+="_nopinlabels"),rows>1&&(footprintString+=`_rows${rows}`),footprintString}return null}initPorts(){let pinCount=this._parsedProps.pinCount??(Array.isArray(this._parsedProps.pinLabels)?this._parsedProps.pinLabels.length:this._parsedProps.pinLabels?Object.keys(this._parsedProps.pinLabels).length:1);for(let i3=1;i3<=pinCount;i3++){let rawLabel=Array.isArray(this._parsedProps.pinLabels)?this._parsedProps.pinLabels[i3-1]:this._parsedProps.pinLabels?.[`pin${i3}`];if(rawLabel){let primaryLabel=Array.isArray(rawLabel)?rawLabel[0]:rawLabel,otherLabels=Array.isArray(rawLabel)?rawLabel.slice(1):[];this.add(new Port({pinNumber:i3,name:primaryLabel,aliases:[`pin${i3}`,...otherLabels]}))}else this.add(new Port({pinNumber:i3,name:`pin${i3}`}))}}_getSchematicPortArrangement(){let pinCount=this._parsedProps.pinCount??1,facingDirection=this._parsedProps.schFacingDirection??this._parsedProps.facingDirection??"right",schPinArrangement=this._parsedProps.schPinArrangement;return facingDirection==="left"?{leftSide:{direction:schPinArrangement?.leftSide?.direction??"top-to-bottom",pins:schPinArrangement?.leftSide?.pins??Array.from({length:pinCount},(_4,i3)=>`pin${i3+1}`)}}:{rightSide:{direction:schPinArrangement?.rightSide?.direction??"top-to-bottom",pins:schPinArrangement?.rightSide?.pins??Array.from({length:pinCount},(_4,i3)=>`pin${i3+1}`)}}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_pin_header",name:this.name,supplier_part_numbers:props.supplierPartNumbers,pin_count:props.pinCount,gender:props.gender,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}};function getResonatorSymbolName(variant){switch(variant){case"two_ground_pins":return"crystal_4pin";case"ground_pin":return"resonator";case"no_ground":return"crystal";default:return"crystal"}}var Resonator=class extends NormalComponent3{get config(){return{componentName:"Resonator",schematicSymbolName:this.props.symbolName??getResonatorSymbolName(this.props.pinVariant),zodProps:resonatorProps,shouldRenderAsSchematicBox:!1}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,pinVariant=props.pinVariant||"no_ground",source_component=db2.source_component.insert({ftype:"simple_resonator",name:this.name,frequency:props.frequency,load_capacitance:props.loadCapacitance,supplier_part_numbers:props.supplierPartNumbers,pin_variant:pinVariant,are_pins_interchangeable:pinVariant==="no_ground"||pinVariant==="ground_pin",display_name:props.displayName});this.source_component_id=source_component.source_component_id}_getSchematicSymbolDisplayValue(){let freqDisplay=`${formatSiUnit(this._parsedProps.frequency)}Hz`;return this._parsedProps.loadCapacitance?`${freqDisplay} / ${formatSiUnit(this._parsedProps.loadCapacitance)}F`:freqDisplay}};function getPotentiometerSymbolName(variant){switch(variant){case"three_pin":return"potentiometer3";case"two_pin":return"potentiometer2";default:return"potentiometer2"}}var Potentiometer=class extends NormalComponent3{get config(){return{componentName:"Potentiometer",schematicSymbolName:this.props.symbolName??getPotentiometerSymbolName(this.props.pinVariant),zodProps:potentiometerProps,shouldRenderAsSchematicBox:!1}}_getSchematicSymbolDisplayValue(){return`${formatSiUnit(this._parsedProps.maxResistance)}\u03A9`}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,pinVariant=props.pinVariant||"two_pin",source_component=db2.source_component.insert({ftype:"simple_potentiometer",name:this.name,max_resistance:props.maxResistance,pin_variant:pinVariant,are_pins_interchangeable:pinVariant==="two_pin",display_name:props.displayName,display_max_resistance:this._getSchematicSymbolDisplayValue()});this.source_component_id=source_component.source_component_id}},Crystal=class extends NormalComponent3{get config(){return{schematicSymbolName:this.props.symbolName??(this.props.pinVariant==="four_pin"?"crystal_4pin":"crystal"),componentName:"Crystal",zodProps:crystalProps,sourceFtype:"simple_crystal"}}initPorts(){let additionalAliases=this.props.pinVariant==="four_pin"?{pin1:["left1","1"],pin2:["top1","2","gnd1"],pin3:["right1","3"],pin4:["bottom1","4","gnd2"]}:{pin1:["pos","left"],pin2:["neg","right"]};super.initPorts({additionalAliases})}_getSchematicSymbolDisplayValue(){let freqDisplay=`${formatSiUnit(this._parsedProps.frequency)}Hz`;return this._parsedProps.loadCapacitance?`${freqDisplay} / ${formatSiUnit(this._parsedProps.loadCapacitance)}F`:freqDisplay}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({name:this.name,ftype:"simple_crystal",frequency:props.frequency,load_capacitance:props.loadCapacitance,pin_variant:props.pinVariant||"two_pin",are_pins_interchangeable:(props.pinVariant||"two_pin")==="two_pin",display_name:props.displayName});this.source_component_id=source_component.source_component_id}},Mosfet=class extends NormalComponent3{get config(){let mosfetMode=this.props.mosfetMode==="depletion"?"d":"e",baseSymbolName=`${this.props.channelType}_channel_${mosfetMode}_mosfet_transistor`;return{componentName:"Mosfet",schematicSymbolName:this.props.symbolName??baseSymbolName,zodProps:mosfetProps,shouldRenderAsSchematicBox:!1}}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_mosfet",name:this.name,mosfet_mode:props.mosfetMode,channel_type:props.channelType,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},OpAmp=class extends NormalComponent3{constructor(){super(...arguments);__publicField(this,"inverting_input",this.portMap.inverting_input);__publicField(this,"non_inverting_input",this.portMap.non_inverting_input);__publicField(this,"output",this.portMap.output);__publicField(this,"positive_supply",this.portMap.positive_supply);__publicField(this,"negative_supply",this.portMap.negative_supply)}get config(){let hasPowerConnections=this.props.connections?.positive_supply||this.props.connections?.negative_supply;return{componentName:"OpAmp",schematicSymbolName:this.props.symbolName?this.props.symbolName:hasPowerConnections?"opamp_with_power":"opamp_no_power",zodProps:opampProps,sourceFtype:"simple_op_amp"}}initPorts(){super.initPorts({pinCount:5,additionalAliases:{pin1:["non_inverting_input"],pin2:["inverting_input"],pin3:["output"],pin4:["positive_supply","vcc","vdd"],pin5:["negative_supply","vee","vss","gnd"]}})}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,source_component=db2.source_component.insert({ftype:"simple_op_amp",name:this.name,supplier_part_numbers:props.supplierPartNumbers,display_name:props.displayName});this.source_component_id=source_component.source_component_id}doInitialSimulationRender(){let{db:db2}=this.root,invertingInputPort=this.portMap.inverting_input,nonInvertingInputPort=this.portMap.non_inverting_input,outputPort=this.portMap.output,positiveSupplyPort=this.portMap.positive_supply,negativeSupplyPort=this.portMap.negative_supply;!invertingInputPort?.source_port_id||!nonInvertingInputPort?.source_port_id||!outputPort?.source_port_id||!positiveSupplyPort?.source_port_id||!negativeSupplyPort?.source_port_id||db2.simulation_op_amp.insert({type:"simulation_op_amp",source_component_id:this.source_component_id,inverting_input_source_port_id:invertingInputPort.source_port_id,non_inverting_input_source_port_id:nonInvertingInputPort.source_port_id,output_source_port_id:outputPort.source_port_id,positive_supply_source_port_id:positiveSupplyPort.source_port_id,negative_supply_source_port_id:negativeSupplyPort.source_port_id})}};function hasSimProps(props){return props.simSwitchFrequency!==void 0||props.simCloseAt!==void 0||props.simOpenAt!==void 0||props.simStartClosed!==void 0||props.simStartOpen!==void 0}var Switch=class extends NormalComponent3{_getSwitchType(){let props=this._parsedProps;return props?props.dpdt?"dpdt":props.spst?"spst":props.spdt?"spdt":props.dpst?"dpst":props.type??"spst":"spst"}get config(){let switchType=this._getSwitchType(),isNormallyClosed=this._parsedProps?.isNormallyClosed??!1,symbolMap={spst:isNormallyClosed?"spst_normally_closed_switch":"spst_switch",spdt:isNormallyClosed?"spdt_normally_closed_switch":"spdt_switch",dpst:isNormallyClosed?"dpst_normally_closed_switch":"dpst_switch",dpdt:isNormallyClosed?"dpdt_normally_closed_switch":"dpdt_switch"};return{componentName:"Switch",schematicSymbolName:this.props.symbolName??symbolMap[switchType],zodProps:switchProps,shouldRenderAsSchematicBox:!1}}doInitialSourceRender(){let{db:db2}=this.root,props=this._parsedProps??{},source_component=db2.source_component.insert({ftype:"simple_switch",name:this.name,are_pins_interchangeable:this._getSwitchType()==="spst",display_name:props?.displayName});this.source_component_id=source_component.source_component_id}doInitialSimulationRender(){let{_parsedProps:props}=this;if(!hasSimProps(props))return;let{db:db2}=this.root,simulationSwitch={type:"simulation_switch",source_component_id:this.source_component_id||""};props.simSwitchFrequency!==void 0&&(simulationSwitch.switching_frequency=frequency.parse(props.simSwitchFrequency)),props.simCloseAt!==void 0&&(simulationSwitch.closes_at=ms.parse(props.simCloseAt)),props.simOpenAt!==void 0&&(simulationSwitch.opens_at=ms.parse(props.simOpenAt)),props.simStartOpen!==void 0&&(simulationSwitch.starts_closed=!props.simStartOpen),props.simStartClosed!==void 0&&(simulationSwitch.starts_closed=props.simStartClosed),db2.simulation_switch.insert(simulationSwitch)}},TESTPOINT_DEFAULTS={HOLE_DIAMETER:.5,SMT_CIRCLE_DIAMETER:1.2,SMT_RECT_SIZE:2},TestPoint=class extends NormalComponent3{get config(){return{componentName:"TestPoint",schematicSymbolName:this.props.symbolName??"testpoint",zodProps:testpointProps,sourceFtype:FTYPE.simple_test_point}}_getPropsWithDefaults(){let{padShape,holeDiameter,footprintVariant,padDiameter,width,height}=this._parsedProps;return!footprintVariant&&holeDiameter&&(footprintVariant="through_hole"),footprintVariant??(footprintVariant="through_hole"),padShape??(padShape="circle"),footprintVariant==="pad"?padShape==="circle"?padDiameter??(padDiameter=TESTPOINT_DEFAULTS.SMT_CIRCLE_DIAMETER):padShape==="rect"&&(width??(width=TESTPOINT_DEFAULTS.SMT_RECT_SIZE),height??(height=width)):footprintVariant==="through_hole"&&(holeDiameter??(holeDiameter=TESTPOINT_DEFAULTS.HOLE_DIAMETER)),{padShape,holeDiameter,footprintVariant,padDiameter,width,height}}_getImpliedFootprintString(){let{padShape,holeDiameter,footprintVariant,padDiameter,width,height}=this._getPropsWithDefaults();if(footprintVariant==="through_hole")return`platedhole_d${holeDiameter}`;if(footprintVariant==="pad"){if(padShape==="circle")return`smtpad_circle_d${padDiameter}`;if(padShape==="rect")return`smtpad_rect_w${width}_h${height}`}throw new Error(`Footprint variant "${footprintVariant}" with pad shape "${padShape}" not implemented`)}doInitialSourceRender(){let{db:db2}=this.root,{_parsedProps:props}=this,{padShape,holeDiameter,footprintVariant,padDiameter,width,height}=this._getPropsWithDefaults(),source_component=db2.source_component.insert({ftype:FTYPE.simple_test_point,name:this.name,supplier_part_numbers:props.supplierPartNumbers,footprint_variant:footprintVariant,pad_shape:padShape,pad_diameter:padDiameter,hole_diameter:holeDiameter,width,height,are_pins_interchangeable:!0,display_name:props.displayName});this.source_component_id=source_component.source_component_id}},SchematicText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"schematic_text_id")}get config(){return{componentName:"SchematicText",zodProps:schematicTextProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_symbol_id=this._getSymbolAncestor()?.schematic_symbol_id,text=this._resolveText(),schematic_text3=db2.schematic_text.insert({schematic_symbol_id,anchor:props.anchor??"center",text:normalizeTextForCircuitJson(text),font_size:props.fontSize,color:props.color||"#000000",position:{x:globalPos.x,y:globalPos.y},rotation:props.schRotation??0});this.schematic_text_id=schematic_text3.schematic_text_id}doInitialSchematicSymbolResize(){if(this.root?.schematicDisabled||!this.schematic_text_id)return;let transform6=this._getSymbolAncestor()?.getUserCoordinateToResizedSymbolTransform();if(!transform6)return;let{db:db2}=this.root,text=db2.schematic_text.get(this.schematic_text_id);if(!text)return;let newPosition=applyToPoint2(transform6,text.position);db2.schematic_text.update(this.schematic_text_id,{position:{x:newPosition.x,y:newPosition.y}})}},SchematicLine=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"schematic_line_id")}get config(){return{componentName:"SchematicLine",zodProps:schematicLineProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_symbol_id=this._getSymbolAncestor()?.schematic_symbol_id,schematic_line3=db2.schematic_line.insert({schematic_component_id,schematic_symbol_id,x1:props.x1+globalPos.x,y1:props.y1+globalPos.y,x2:props.x2+globalPos.x,y2:props.y2+globalPos.y,stroke_width:props.strokeWidth??SCHEMATIC_COMPONENT_OUTLINE_STROKE_WIDTH,color:props.color??SCHEMATIC_COMPONENT_OUTLINE_COLOR,is_dashed:!1,subcircuit_id:this.getSubcircuit().subcircuit_id??void 0});this.schematic_line_id=schematic_line3.schematic_line_id}doInitialSchematicSymbolResize(){if(this.root?.schematicDisabled||!this.schematic_line_id)return;let transform6=this._getSymbolAncestor()?.getUserCoordinateToResizedSymbolTransform();if(!transform6)return;let{db:db2}=this.root,line2=db2.schematic_line.get(this.schematic_line_id);if(!line2)return;let p12=applyToPoint2(transform6,{x:line2.x1,y:line2.y1}),p22=applyToPoint2(transform6,{x:line2.x2,y:line2.y2});db2.schematic_line.update(this.schematic_line_id,{x1:p12.x,y1:p12.y,x2:p22.x,y2:p22.y})}},SchematicRect=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"schematic_rect_id")}get config(){return{componentName:"SchematicRect",zodProps:schematicRectProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_symbol_id=this._getSymbolAncestor()?.schematic_symbol_id,schematic_rect3=db2.schematic_rect.insert({schematic_symbol_id,center:{x:globalPos.x,y:globalPos.y},width:props.width,height:props.height,stroke_width:props.strokeWidth??SCHEMATIC_COMPONENT_OUTLINE_STROKE_WIDTH,color:props.color??SCHEMATIC_COMPONENT_OUTLINE_COLOR,is_filled:props.isFilled,schematic_component_id,is_dashed:props.isDashed,rotation:props.rotation??0,subcircuit_id:this.getSubcircuit().subcircuit_id??void 0});this.schematic_rect_id=schematic_rect3.schematic_rect_id}doInitialSchematicSymbolResize(){if(this.root?.schematicDisabled||!this.schematic_rect_id)return;let transform6=this._getSymbolAncestor()?.getUserCoordinateToResizedSymbolTransform();if(!transform6)return;let{db:db2}=this.root,rect=db2.schematic_rect.get(this.schematic_rect_id);if(!rect)return;let topLeft=applyToPoint2(transform6,{x:rect.center.x-rect.width/2,y:rect.center.y+rect.height/2}),bottomRight=applyToPoint2(transform6,{x:rect.center.x+rect.width/2,y:rect.center.y-rect.height/2}),newWidth=Math.abs(bottomRight.x-topLeft.x),newHeight=Math.abs(topLeft.y-bottomRight.y),newCenter={x:(topLeft.x+bottomRight.x)/2,y:(topLeft.y+bottomRight.y)/2};db2.schematic_rect.update(this.schematic_rect_id,{center:newCenter,width:newWidth,height:newHeight})}},SchematicArc=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"schematic_arc_id")}get config(){return{componentName:"SchematicArc",zodProps:schematicArcProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_symbol_id=this._getSymbolAncestor()?.schematic_symbol_id,schematic_arc3=db2.schematic_arc.insert({schematic_component_id,schematic_symbol_id,center:{x:props.center.x+globalPos.x,y:props.center.y+globalPos.y},radius:props.radius,start_angle_degrees:props.startAngleDegrees,end_angle_degrees:props.endAngleDegrees,direction:props.direction,stroke_width:props.strokeWidth??SCHEMATIC_COMPONENT_OUTLINE_STROKE_WIDTH,color:props.color??SCHEMATIC_COMPONENT_OUTLINE_COLOR,is_dashed:props.isDashed,subcircuit_id:this.getSubcircuit().subcircuit_id??void 0});this.schematic_arc_id=schematic_arc3.schematic_arc_id}doInitialSchematicSymbolResize(){if(this.root?.schematicDisabled||!this.schematic_arc_id)return;let transform6=this._getSymbolAncestor()?.getUserCoordinateToResizedSymbolTransform();if(!transform6)return;let{db:db2}=this.root,arc2=db2.schematic_arc.get(this.schematic_arc_id);if(!arc2)return;let newCenter=applyToPoint2(transform6,arc2.center),edgePoint=applyToPoint2(transform6,{x:arc2.center.x+arc2.radius,y:arc2.center.y}),newRadius=Math.abs(edgePoint.x-newCenter.x);db2.schematic_arc.update(this.schematic_arc_id,{center:{x:newCenter.x,y:newCenter.y},radius:newRadius})}},SchematicCircle=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"schematic_circle_id")}get config(){return{componentName:"SchematicCircle",zodProps:schematicCircleProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_symbol_id=this._getSymbolAncestor()?.schematic_symbol_id,schematic_circle3=db2.schematic_circle.insert({schematic_component_id,schematic_symbol_id,center:{x:props.center.x+globalPos.x,y:props.center.y+globalPos.y},radius:props.radius,stroke_width:props.strokeWidth??SCHEMATIC_COMPONENT_OUTLINE_STROKE_WIDTH,color:props.color??SCHEMATIC_COMPONENT_OUTLINE_COLOR,is_filled:props.isFilled,fill_color:props.fillColor,is_dashed:props.isDashed,subcircuit_id:this.getSubcircuit().subcircuit_id??void 0});this.schematic_circle_id=schematic_circle3.schematic_circle_id}doInitialSchematicSymbolResize(){if(this.root?.schematicDisabled||!this.schematic_circle_id)return;let transform6=this._getSymbolAncestor()?.getUserCoordinateToResizedSymbolTransform();if(!transform6)return;let{db:db2}=this.root,circle2=db2.schematic_circle.get(this.schematic_circle_id);if(!circle2)return;let newCenter=applyToPoint2(transform6,circle2.center),edgePoint=applyToPoint2(transform6,{x:circle2.center.x+circle2.radius,y:circle2.center.y}),newRadius=Math.abs(edgePoint.x-newCenter.x);db2.schematic_circle.update(this.schematic_circle_id,{center:{x:newCenter.x,y:newCenter.y},radius:newRadius})}};function sampleCurveSegment(segmentPath,samplesPerUnit){let commander=new src_default(segmentPath),length7=commander.getTotalLength(),numSamples=Math.max(2,Math.ceil(length7*samplesPerUnit)),points=[];for(let i3=1;i3<=numSamples;i3++){let t52=i3/numSamples*length7,point62=commander.getPointAtLength(t52);points.push({x:point62.x,y:point62.y})}return points}function svgPathToPoints(svgPath,samplesPerUnit=10){let pathCommander=new src_default(svgPath);pathCommander.toAbsolute();let segments=pathCommander.segments,result=[],currentPoints=[],currentX=0,currentY=0,subpathStartX=0,subpathStartY=0;for(let segment2 of segments)switch(segment2[0]){case"M":{currentPoints.length>0&&result.push(currentPoints),currentX=segment2[1],currentY=segment2[2],subpathStartX=currentX,subpathStartY=currentY,currentPoints=[{x:currentX,y:currentY}];break}case"L":{currentX=segment2[1],currentY=segment2[2],currentPoints.push({x:currentX,y:currentY});break}case"H":{currentX=segment2[1],currentPoints.push({x:currentX,y:currentY});break}case"V":{currentY=segment2[1],currentPoints.push({x:currentX,y:currentY});break}case"Z":{(currentX!==subpathStartX||currentY!==subpathStartY)&&currentPoints.push({x:subpathStartX,y:subpathStartY}),currentX=subpathStartX,currentY=subpathStartY;break}case"C":{let endX=segment2[5],endY=segment2[6],segmentPath=`M ${currentX} ${currentY} C ${segment2[1]} ${segment2[2]} ${segment2[3]} ${segment2[4]} ${endX} ${endY}`,sampledPoints=sampleCurveSegment(segmentPath,samplesPerUnit);currentPoints.push(...sampledPoints),currentX=endX,currentY=endY;break}case"S":{let endX=segment2[3],endY=segment2[4],segmentPath=`M ${currentX} ${currentY} S ${segment2[1]} ${segment2[2]} ${endX} ${endY}`,sampledPoints=sampleCurveSegment(segmentPath,samplesPerUnit);currentPoints.push(...sampledPoints),currentX=endX,currentY=endY;break}case"Q":{let endX=segment2[3],endY=segment2[4],segmentPath=`M ${currentX} ${currentY} Q ${segment2[1]} ${segment2[2]} ${endX} ${endY}`,sampledPoints=sampleCurveSegment(segmentPath,samplesPerUnit);currentPoints.push(...sampledPoints),currentX=endX,currentY=endY;break}case"T":{let endX=segment2[1],endY=segment2[2],segmentPath=`M ${currentX} ${currentY} T ${endX} ${endY}`,sampledPoints=sampleCurveSegment(segmentPath,samplesPerUnit);currentPoints.push(...sampledPoints),currentX=endX,currentY=endY;break}case"A":{let endX=segment2[6],endY=segment2[7],segmentPath=`M ${currentX} ${currentY} A ${segment2[1]} ${segment2[2]} ${segment2[3]} ${segment2[4]} ${segment2[5]} ${endX} ${endY}`,sampledPoints=sampleCurveSegment(segmentPath,samplesPerUnit);currentPoints.push(...sampledPoints),currentX=endX,currentY=endY;break}}return currentPoints.length>0&&result.push(currentPoints),result.map(points=>{let deduped=[];for(let point62 of points)(deduped.length===0||Math.abs(deduped[deduped.length-1].x-point62.x)>1e-9||Math.abs(deduped[deduped.length-1].y-point62.y)>1e-9)&&deduped.push(point62);return deduped})}var SchematicPath=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"schematic_path_ids",[])}get config(){return{componentName:"SchematicPath",zodProps:schematicPathProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_symbol_id=this._getSymbolAncestor()?.schematic_symbol_id,subcircuit_id=this.getSubcircuit().subcircuit_id??void 0;if(this.schematic_path_ids=[],props.svgPath){let subpaths=svgPathToPoints(props.svgPath);for(let subpathPoints of subpaths){let schematic_path3=db2.schematic_path.insert({schematic_component_id,schematic_symbol_id,points:subpathPoints.map(point62=>({x:point62.x+globalPos.x,y:point62.y+globalPos.y})),is_filled:props.isFilled,fill_color:props.fillColor,stroke_color:props.strokeColor,stroke_width:props.strokeWidth,subcircuit_id});this.schematic_path_ids.push(schematic_path3.schematic_path_id)}}else if(props.points&&props.points.length>0){let schematic_path3=db2.schematic_path.insert({schematic_component_id,schematic_symbol_id,points:props.points.map(point62=>({x:point62.x+globalPos.x,y:point62.y+globalPos.y})),is_filled:props.isFilled,fill_color:props.fillColor,stroke_color:props.strokeColor,stroke_width:props.strokeWidth,subcircuit_id});this.schematic_path_ids.push(schematic_path3.schematic_path_id)}}doInitialSchematicSymbolResize(){if(this.root?.schematicDisabled||this.schematic_path_ids.length===0)return;let transform6=this._getSymbolAncestor()?.getUserCoordinateToResizedSymbolTransform();if(!transform6)return;let{db:db2}=this.root;for(let pathId of this.schematic_path_ids){let path=db2.schematic_path.get(pathId);if(!path)continue;let newPoints=path.points.map(point62=>{let transformed=applyToPoint2(transform6,point62);return{x:transformed.x,y:transformed.y}});db2.schematic_path.update(pathId,{points:newPoints})}}};function getTitleAnchorAndPosition({anchor,x:x4,y:y4,width,height,isInside}){switch(anchor){case"top_left":return{x:x4,y:y4+height,textAnchor:isInside?"top_left":"bottom_left"};case"top_center":return{x:x4+width/2,y:y4+height,textAnchor:isInside?"top_center":"bottom_center"};case"top_right":return{x:x4+width,y:y4+height,textAnchor:isInside?"top_right":"bottom_right"};case"center_left":return{x:x4,y:y4+height/2,textAnchor:isInside?"center_left":"center_right"};case"center":return{x:x4+width/2,y:y4+height/2,textAnchor:"center"};case"center_right":return{x:x4+width,y:y4+height/2,textAnchor:isInside?"center_right":"center_left"};case"bottom_left":return{x:x4,y:y4,textAnchor:isInside?"bottom_left":"top_left"};case"bottom_center":return{x:x4+width/2,y:y4,textAnchor:isInside?"bottom_center":"top_center"};case"bottom_right":return{x:x4+width,y:y4,textAnchor:isInside?"bottom_right":"top_right"};default:return{x:x4+width/2,y:y4+height,textAnchor:"center"}}}var SchematicBox=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0)}get config(){return{componentName:"SchematicBox",zodProps:schematicBoxProps,shouldRenderAsSchematicBox:!0}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,basePadding=.6,generalPadding=typeof props.padding=="number"?props.padding:0,paddingTop=typeof props.paddingTop=="number"?props.paddingTop:generalPadding,paddingBottom=typeof props.paddingBottom=="number"?props.paddingBottom:generalPadding,paddingLeft=typeof props.paddingLeft=="number"?props.paddingLeft:generalPadding,paddingRight=typeof props.paddingRight=="number"?props.paddingRight:generalPadding,hasOverlay=props.overlay&&props.overlay.length>0,hasFixedSize=typeof props.width=="number"&&typeof props.height=="number",width,height,x4,y4,centerX,centerY;if(hasOverlay){let portsWithPosition=props.overlay.map(selector=>({selector,port:this.getSubcircuit().selectOne(selector,{type:"port"})})).filter(({port})=>port!=null).map(({port})=>({position:port._getGlobalSchematicPositionAfterLayout()}));if(portsWithPosition.length===0)return;let xs3=portsWithPosition.map(p4=>p4.position.x),ys3=portsWithPosition.map(p4=>p4.position.y),minX=Math.min(...xs3),maxX=Math.max(...xs3),minY=Math.min(...ys3),maxY=Math.max(...ys3),rawWidth=maxX-minX,rawHeight=maxY-minY,defaultHorizontalPadding=rawWidth===0?basePadding:0,defaultVerticalPadding=rawHeight===0?basePadding:0,finalPaddingLeft=paddingLeft+defaultHorizontalPadding/2,finalPaddingRight=paddingRight+defaultHorizontalPadding/2,finalPaddingTop=paddingTop+defaultVerticalPadding/2,finalPaddingBottom=paddingBottom+defaultVerticalPadding/2,left=minX-finalPaddingLeft,right=maxX+finalPaddingRight,top=minY-finalPaddingBottom,bottom=maxY+finalPaddingTop;width=right-left,height=bottom-top,x4=left+(props.schX??0),y4=top+(props.schY??0),centerX=x4+width/2,centerY=y4+height/2}else if(hasFixedSize){width=props.width,height=props.height;let center2=this._getGlobalSchematicPositionBeforeLayout();centerX=center2.x,centerY=center2.y,x4=centerX-width/2,y4=centerY-height/2}else return;if(db2.schematic_box.insert({height,width,x:x4,y:y4,is_dashed:props.strokeStyle==="dashed"}),props.title){let isInside=props.titleInside,TITLE_PADDING=.1,anchor=props.titleAlignment,anchorPos=getTitleAnchorAndPosition({anchor,x:x4,y:y4,width,height,isInside}),titleOffsetY,titleOffsetX,textAnchor=anchorPos.textAnchor;isInside?(titleOffsetY=anchor.includes("top")?-TITLE_PADDING:anchor.includes("bottom")?TITLE_PADDING:0,titleOffsetX=anchor.includes("left")?TITLE_PADDING:anchor.includes("right")?-TITLE_PADDING:0):(titleOffsetY=anchor.includes("top")?TITLE_PADDING:anchor.includes("bottom")?-TITLE_PADDING:0,titleOffsetX=anchor.includes("center_left")?-TITLE_PADDING:anchor.includes("center_right")?TITLE_PADDING:0);let titleX=anchorPos.x+titleOffsetX,titleY=anchorPos.y+titleOffsetY;db2.schematic_text.insert({anchor:textAnchor,text:props.title,font_size:props.titleFontSize??.18,color:props.titleColor??"#000000",position:{x:titleX,y:titleY},rotation:0})}}},SchematicTable=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"schematic_table_id",null)}get config(){return{componentName:"SchematicTable",zodProps:schematicTableProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled||this.getCollapsedSchematicBoxAncestor())return;let{db:db2}=this.root,{_parsedProps:props}=this,rows=this.children.filter(c4=>c4.componentName==="SchematicRow");if(rows.length===0)return;let grid4=[],maxCols=0;for(let row of rows){let cells=row.children.filter(c4=>c4.componentName==="SchematicCell");maxCols=Math.max(maxCols,cells.length)}for(let i3=0;i3<rows.length;i3++)grid4[i3]=[];for(let i3=0;i3<rows.length;i3++){let cells=rows[i3].children.filter(c4=>c4.componentName==="SchematicCell"),k4=0;for(let j4=0;j4<cells.length;j4++){for(;grid4[i3][k4];)k4++;let cell=cells[j4],colSpan=cell._parsedProps.colSpan??1,rowSpan=cell._parsedProps.rowSpan??1;for(let r5=0;r5<rowSpan;r5++)for(let c4=0;c4<colSpan;c4++)grid4[i3+r5]||(grid4[i3+r5]=[]),grid4[i3+r5][k4+c4]=cell;k4+=colSpan}}maxCols=Math.max(0,...grid4.map(r5=>r5.length));let rowHeights=rows.map((row,i3)=>row._parsedProps.height??1),colWidths=Array.from({length:maxCols},(_4,j4)=>{let maxWidth=0;for(let i3=0;i3<rows.length;i3++){let cell=grid4[i3]?.[j4];if(cell){let text=cell._parsedProps.text??cell._parsedProps.children,cellWidth=cell._parsedProps.width??(text?.length??2)*.5;cellWidth>maxWidth&&(maxWidth=cellWidth)}}return maxWidth||10}),anchorPos=this._getGlobalSchematicPositionBeforeLayout(),table=db2.schematic_table.insert({anchor_position:anchorPos,column_widths:colWidths,row_heights:rowHeights,cell_padding:props.cellPadding,border_width:props.borderWidth,anchor:props.anchor,subcircuit_id:this.getSubcircuit()?.subcircuit_id||"",schematic_component_id:this.parent?.schematic_component_id||""});this.schematic_table_id=table.schematic_table_id;let processedCells=new Set,yOffset=0;for(let i3=0;i3<rows.length;i3++){let xOffset=0;for(let j4=0;j4<maxCols;j4++){let cell=grid4[i3]?.[j4];if(cell&&!processedCells.has(cell)){processedCells.add(cell);let cellProps=cell._parsedProps,rowSpan=cellProps.rowSpan??1,colSpan=cellProps.colSpan??1,cellWidth=0;for(let c4=0;c4<colSpan;c4++)cellWidth+=colWidths[j4+c4];let cellHeight=0;for(let r5=0;r5<rowSpan;r5++)cellHeight+=rowHeights[i3+r5];db2.schematic_table_cell.insert({schematic_table_id:this.schematic_table_id,start_row_index:i3,end_row_index:i3+rowSpan-1,start_column_index:j4,end_column_index:j4+colSpan-1,text:cellProps.text??cellProps.children,center:{x:anchorPos.x+xOffset+cellWidth/2,y:anchorPos.y-yOffset-cellHeight/2},width:cellWidth,height:cellHeight,horizontal_align:cellProps.horizontalAlign,vertical_align:cellProps.verticalAlign,font_size:cellProps.fontSize??props.fontSize,subcircuit_id:this.getSubcircuit()?.subcircuit_id||""})}colWidths[j4]&&(xOffset+=colWidths[j4])}yOffset+=rowHeights[i3]}}},SchematicRow=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0)}get config(){return{componentName:"SchematicRow",zodProps:schematicRowProps}}},SchematicCell=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0);__publicField(this,"canHaveTextChildren",!0)}get config(){return{componentName:"SchematicCell",zodProps:schematicCellProps}}},SymbolComponent=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isPrimitiveContainer",!0);__publicField(this,"schematic_symbol_id");__publicField(this,"userCoordinateToResizedSymbolTransformMat");__publicField(this,"schematicSymbolBoundsInUserCoordinates")}get config(){return{componentName:"Symbol",zodProps:symbolProps}}hasExplicitSize(){let{_parsedProps:props}=this;return props.width!==void 0||props.height!==void 0}doInitialSymbolContainerRender(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,kicadSymbolMetadata4=this.getParentNormalComponent()?._parsedProps?.kicadSymbolMetadata,schematic_symbol3=db2.schematic_symbol.insert({name:props.name,metadata:kicadSymbolMetadata4?{kicad_symbol:kicadSymbolMetadata4}:void 0});this.schematic_symbol_id=schematic_symbol3.schematic_symbol_id}getSchematicSymbolBounds(){return this.schematicSymbolBoundsInUserCoordinates?this.schematicSymbolBoundsInUserCoordinates:(this._computeSchematicSymbolBounds(),this.schematicSymbolBoundsInUserCoordinates??null)}getUserCoordinateToResizedSymbolTransform(){return this.hasExplicitSize()?this.userCoordinateToResizedSymbolTransformMat?this.userCoordinateToResizedSymbolTransformMat:(this._computeUserCoordinateToResizedSymbolTransform(),this.userCoordinateToResizedSymbolTransformMat??null):null}_computeSchematicSymbolBounds(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,schematicElements=[];for(let child of this.children){if(child.componentName==="Port"){let portId=child.schematic_port_id;if(portId){let port=db2.schematic_port.get(portId);port&&schematicElements.push(port)}continue}if(child.isSchematicPrimitive){if(child.componentName==="SchematicLine"){let line2=db2.schematic_line.get(child.schematic_line_id);line2&&schematicElements.push(line2)}else if(child.componentName==="SchematicRect"){let rect=db2.schematic_rect.get(child.schematic_rect_id);rect&&schematicElements.push(rect)}else if(child.componentName==="SchematicCircle"){let circle2=db2.schematic_circle.get(child.schematic_circle_id);circle2&&schematicElements.push(circle2)}else if(child.componentName==="SchematicArc"){let arc2=db2.schematic_arc.get(child.schematic_arc_id);arc2&&schematicElements.push(arc2)}else if(child.componentName==="SchematicText"){let text=db2.schematic_text.get(child.schematic_text_id);text&&schematicElements.push(text)}else if(child.componentName==="SchematicPath"){let pathIds=child.schematic_path_ids;if(pathIds)for(let pathId of pathIds){let path=db2.schematic_path.get(pathId);path&&schematicElements.push(path)}}}}if(schematicElements.length===0)return;let bounds=getBoundsForSchematic(schematicElements);this.schematicSymbolBoundsInUserCoordinates=bounds}_computeUserCoordinateToResizedSymbolTransform(){let bounds=this.getSchematicSymbolBounds();if(!bounds)return;let{_parsedProps:props}=this,targetWidth=props.width,targetHeight=props.height;if(targetWidth===void 0&&targetHeight===void 0)return;let currentWidth=bounds.maxX-bounds.minX,currentHeight=bounds.maxY-bounds.minY;if(currentWidth===0&&currentHeight===0)return;let currentCenterX=(bounds.minX+bounds.maxX)/2,currentCenterY=(bounds.minY+bounds.maxY)/2,scaleX=targetWidth!==void 0&&currentWidth>0?targetWidth/currentWidth:1,scaleY=targetHeight!==void 0&&currentHeight>0?targetHeight/currentHeight:1,globalPos=this._getGlobalSchematicPositionBeforeLayout();this.userCoordinateToResizedSymbolTransformMat=compose2(translate2(globalPos.x,globalPos.y),scale2(scaleX,scaleY),translate2(-currentCenterX,-currentCenterY))}},AnalogSimulation=class extends PrimitiveComponent2{get config(){return{componentName:"AnalogSimulation",zodProps:analogSimulationProps}}doInitialSimulationRender(){let{db:db2}=this.root,{duration,timePerStep}=this._parsedProps,durationMs=duration||10,timePerStepMs=timePerStep||.01;db2.simulation_experiment.insert({name:"spice_transient_analysis",experiment_type:"spice_transient_analysis",end_time_ms:durationMs,time_per_step:timePerStepMs})}};function getLabelBounds(probePosition,labelText,alignment,labelOffset=.3){let labelWidth=Math.max(labelText.length*.1,.3),labelHeightWithPadding=.25+.2,anchorX=probePosition.x,anchorY=probePosition.y,offsetMultiplier=labelOffset+labelWidth/2;alignment.includes("top")?anchorY+=offsetMultiplier:alignment.includes("bottom")&&(anchorY-=offsetMultiplier),alignment.includes("right")?anchorX+=offsetMultiplier:alignment.includes("left")&&(anchorX-=offsetMultiplier);let minX,maxX,minY,maxY;return alignment.includes("left")?(minX=anchorX,maxX=anchorX+labelWidth):alignment.includes("right")?(minX=anchorX-labelWidth,maxX=anchorX):(minX=anchorX-labelWidth/2,maxX=anchorX+labelWidth/2),alignment.includes("top")?(minY=anchorY-labelHeightWithPadding,maxY=anchorY):alignment.includes("bottom")?(minY=anchorY,maxY=anchorY+labelHeightWithPadding):(minY=anchorY-labelHeightWithPadding/2,maxY=anchorY+labelHeightWithPadding/2),{minX,maxX,minY,maxY}}function getElementBounds(elm){let cx3,cy3,w4,h6;if(elm.type==="schematic_component")cx3=elm.center?.x,cy3=elm.center?.y,w4=elm.size?.width,h6=elm.size?.height;else if(elm.type==="schematic_text")cx3=elm.position?.x,cy3=elm.position?.y,w4=(elm.text?.length??0)*.1,h6=.2;else return null;return typeof cx3=="number"&&typeof cy3=="number"&&typeof w4=="number"&&typeof h6=="number"?{minX:cx3-w4/2,maxX:cx3+w4/2,minY:cy3-h6/2,maxY:cy3+h6/2}:null}function getOverlapArea(a3,b3){if(!doBoundsOverlap(a3,b3))return 0;let overlapWidth=Math.min(a3.maxX,b3.maxX)-Math.max(a3.minX,b3.minX),overlapHeight=Math.min(a3.maxY,b3.maxY)-Math.max(a3.minY,b3.minY);return overlapWidth*overlapHeight}function selectBestLabelAlignment({probePosition,labelText,schematicElements,defaultAlignment="top_right"}){let orderedAlignments=[defaultAlignment,...["top_right","top_left","bottom_right","bottom_left","top_center","bottom_center","center_right","center_left"].filter(a3=>a3!==defaultAlignment)],bestAlignment=defaultAlignment,minOverlapArea=1/0;for(let alignment of orderedAlignments){let labelBounds=getLabelBounds(probePosition,labelText,alignment),totalOverlapArea=0;for(let element of schematicElements){let elementBounds=getElementBounds(element);elementBounds&&(totalOverlapArea+=getOverlapArea(labelBounds,elementBounds))}if(totalOverlapArea===0)return alignment;totalOverlapArea<minOverlapArea&&(minOverlapArea=totalOverlapArea,bestAlignment=alignment)}return bestAlignment}var VoltageProbe=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"simulation_voltage_probe_id",null);__publicField(this,"schematic_voltage_probe_id",null);__publicField(this,"finalProbeName",null);__publicField(this,"color",null)}get config(){return{componentName:"VoltageProbe",zodProps:voltageProbeProps}}doInitialSimulationRender(){let{db:db2}=this.root,{connectsTo,name,referenceTo,color}=this._parsedProps,subcircuit=this.getSubcircuit();if(!subcircuit){this.renderError("VoltageProbe must be inside a subcircuit");return}let targets=Array.isArray(connectsTo)?connectsTo:[connectsTo];if(targets.length!==1){this.renderError("VoltageProbe must connect to exactly one port or net");return}let targetSelector=targets[0],port=subcircuit.selectOne(targetSelector,{type:"port"}),net=port?null:subcircuit.selectOne(targetSelector,{type:"net"});if(net&&net.componentName!=="Net"){this.renderError(`VoltageProbe connection target "${targetSelector}" resolved to a non-net component "${net.componentName}".`);return}if(!port&&!net){this.renderError(`VoltageProbe could not find connection target "${targetSelector}"`);return}let connectedId=port?.source_port_id??net?.source_net_id;if(!connectedId){this.renderError("Could not identify connected source for VoltageProbe");return}let referencePort=null,referenceNet=null;if(referenceTo){let referenceTargets=Array.isArray(referenceTo)?referenceTo:[referenceTo];if(referenceTargets.length!==1){this.renderError("VoltageProbe must reference exactly one port or net");return}let referenceSelector=referenceTargets[0];if(referencePort=subcircuit.selectOne(referenceSelector,{type:"port"}),referenceNet=referencePort?null:subcircuit.selectOne(referenceSelector,{type:"net"}),referenceNet&&referenceNet.componentName!=="Net"){this.renderError(`VoltageProbe reference target "${referenceSelector}" resolved to a non-net component "${referenceNet.componentName}".`);return}if(!referencePort&&!referenceNet){this.renderError(`VoltageProbe could not find reference target "${referenceSelector}"`);return}}this.color=color??getSimulationColorForId(connectedId);let finalName=name;finalName||(finalName=targets[0].split(" > ").map(s3=>s3.replace(/^\./,"")).join(".")),this.finalProbeName=finalName??null;let{simulation_voltage_probe_id}=db2.simulation_voltage_probe.insert({name:finalName,signal_input_source_port_id:port?.source_port_id??void 0,signal_input_source_net_id:net?.source_net_id??void 0,reference_input_source_port_id:referencePort?.source_port_id??void 0,reference_input_source_net_id:referenceNet?.source_net_id??void 0,subcircuit_id:subcircuit.subcircuit_id||void 0,color:this.color});this.simulation_voltage_probe_id=simulation_voltage_probe_id}doInitialSchematicReplaceNetLabelsWithSymbols(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{connectsTo,name}=this._parsedProps,subcircuit=this.getSubcircuit();if(!subcircuit)return;let targets=Array.isArray(connectsTo)?connectsTo:[connectsTo];if(targets.length!==1)return;let targetSelector=targets[0],port=subcircuit.selectOne(targetSelector,{type:"port"});if(!port||!port.schematic_port_id)return;let position4=port._getGlobalSchematicPositionAfterLayout(),targetTraceId=null;for(let trace of db2.schematic_trace.list()){for(let edge of trace.edges)if(Math.abs(edge.from.x-position4.x)<1e-6&&Math.abs(edge.from.y-position4.y)<1e-6||Math.abs(edge.to.x-position4.x)<1e-6&&Math.abs(edge.to.y-position4.y)<1e-6){targetTraceId=trace.schematic_trace_id;break}if(targetTraceId)break}if(!targetTraceId)return;let probeName=this.finalProbeName,labelAlignment=selectBestLabelAlignment({probePosition:position4,labelText:probeName,schematicElements:[...db2.schematic_component.list(),...db2.schematic_text.list()],defaultAlignment:"top_right"}),schematic_voltage_probe3=db2.schematic_voltage_probe.insert({name:probeName,position:position4,schematic_trace_id:targetTraceId,subcircuit_id:subcircuit.subcircuit_id||void 0,color:this.color??void 0,label_alignment:labelAlignment});this.schematic_voltage_probe_id=schematic_voltage_probe3.schematic_voltage_probe_id}},RootCircuit=class extends IsolatedCircuit{constructor({platform,projectUrl}={}){super({platform,projectUrl,cachedSubcircuits:new Map,pendingSubcircuitRenders:new Map});__publicField(this,"isRootCircuit",!0);this.root=this}},Project=RootCircuit,Circuit=RootCircuit,useRenderedCircuit=reactElements=>{let[isLoading,setIsLoading]=import_react5.default.useState(!0),[error2,setError]=import_react5.default.useState(null),[circuit,setCircuit]=import_react5.default.useState(),[circuitJson,setCircuitJson]=import_react5.default.useState();return import_react5.default.useEffect(()=>{setIsLoading(!0),setError(null),reactElements&&setTimeout(()=>{try{let circuit2=new RootCircuit;circuit2.add(reactElements),setCircuit(circuit2),setCircuitJson(circuit2.toJson())}catch(error22){setError(error22)}setIsLoading(!1)},1)},[reactElements]),{isLoading,error:error2,circuit,circuitJson}},createUseComponent=(Component2,pins)=>(name,props)=>{let pinLabelsFlatArray=[];Array.isArray(pins)?pinLabelsFlatArray.push(...pins.flat()):typeof pins=="object"&&pinLabelsFlatArray.push(...Object.values(pins).flat(),...Object.keys(pins));let R3=props2=>{if(props2?.name&&props2.name!==name)throw new Error(`Component name mismatch. Hook name: ${name}, Component prop name: ${props2.name}`);let combinedProps={...props,...props2,name},tracesToCreate=[];for(let portLabel of pinLabelsFlatArray)if(combinedProps[portLabel]){let from=`.${name} > .${portLabel}`,to3=combinedProps[portLabel];tracesToCreate.push({from,to:to3}),delete combinedProps[portLabel]}return(0,import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment,{children:[(0,import_jsx_runtime.jsx)(Component2,{...combinedProps}),tracesToCreate.map((trace,i3)=>(0,import_jsx_runtime.jsx)("trace",{...trace},i3))]})};for(let port of pinLabelsFlatArray)R3[port]=`.${name} > .${port}`;return R3},useCapacitor=createUseComponent(props=>(0,import_jsx_runtime2.jsx)("capacitor",{...props}),capacitorPins),useChip=pinLabels=>createUseComponent(props=>(0,import_jsx_runtime3.jsx)("chip",{pinLabels,...props}),pinLabels),useDiode=createUseComponent(props=>(0,import_jsx_runtime4.jsx)("diode",{...props}),diodePins),useLed=createUseComponent(props=>(0,import_jsx_runtime5.jsx)("led",{...props}),ledPins),useResistor=createUseComponent(props=>(0,import_jsx_runtime6.jsx)("resistor",{...props}),resistorPins),sel=new Proxy(refdes=>new Proxy({},{get:(_4,pin)=>`.${refdes} > .${pin}`}),{get:(_4,prop1)=>{let fn3=(...args)=>{let chipFnOrPinType=args[0];return new Proxy({},{get:(_22,pinName)=>`.${prop1} > .${pinName}`})};return new Proxy(fn3,{get:(_22,prop2)=>prop1==="net"?`net.${prop2}`:prop1==="subcircuit"?new Proxy({},{get:(_32,prop3)=>new Proxy({},{get:(_42,prop4)=>`subcircuit.${prop2} > .${prop3} > .${prop4}`})}):`.${prop1} > .${prop2}`,apply:(target,_22,args)=>prop1==="net"?new Proxy({},{get:(_32,netName)=>`net.${netName}`}):new Proxy({},{get:(_32,pinOrSubComponentName)=>{let pinResult=`.${prop1} > .${pinOrSubComponentName}`;return["U","J","CN"].some(p4=>prop1.startsWith(p4))?pinResult:new Proxy(new String(pinResult),{get:(_42,nestedProp)=>typeof nestedProp=="symbol"||nestedProp==="toString"?()=>pinResult:`.${prop1} > .${pinOrSubComponentName} > .${nestedProp}`})}})})}});extendCatalogue(components_exports);extendCatalogue({Bug:Chip});var React=__toESM(require_react(),1),ReactJsxRuntime=__toESM(require_jsx_runtime(),1);var dist_exports5={};__export(dist_exports5,{default:()=>mm_default2,mil2mm:()=>mil2mm,mm:()=>mm4,mmStr:()=>mmStr});var unitToMm2={in:25.4,inch:25.4,mil:.0254,mm:1,m:1e3,cm:10,ft:304.8,feet:304.8},mmNumberFormatter=new Intl.NumberFormat("en-US",{useGrouping:!1,notation:"standard",maximumFractionDigits:12}),mm4=n4=>{let unit=typeof n4=="number"?"mm":n4.replace(/^[^a-zA-Z]+/g,"").toLowerCase();unit||(unit="mm");let val=typeof n4=="number"?n4:Number.parseFloat(n4.split(unit)[0]);if(unit in unitToMm2)return val*unitToMm2[unit];throw new Error(`Unsupported unit: ${unit}`)},mmStr=n4=>`${mmNumberFormatter.format(mm4(n4))}mm`,mil2mm=mil=>typeof mil=="number"?mm4(`${mil}mil`):mil.match(/^\d+$/)?mm4(`${mil}mil`):mm4(mil),mm_default2=mm4;var __defProp6=Object.defineProperty,__export4=(target,all)=>{for(var name in all)__defProp6(target,name,{get:all[name],enumerable:!0})},dist_exports6={};__export4(dist_exports6,{all_layers:()=>all_layers2,any_circuit_element:()=>any_circuit_element2,any_soup_element:()=>any_soup_element2,any_source_component:()=>any_source_component2,asset:()=>asset2,base_circuit_json_error:()=>base_circuit_json_error2,battery_capacity:()=>battery_capacity2,brep_shape:()=>brep_shape2,cadModelDefaultDirectionMap:()=>cadModelDefaultDirectionMap2,cad_component:()=>cad_component2,cad_model_axis_directions:()=>cad_model_axis_directions2,cad_model_formats:()=>cad_model_formats2,capacitance:()=>capacitance2,circuit_json_footprint_load_error:()=>circuit_json_footprint_load_error2,current:()=>current2,distance:()=>distance7,duration_ms:()=>duration_ms2,experiment_type:()=>experiment_type2,external_footprint_load_error:()=>external_footprint_load_error2,frequency:()=>frequency2,getZodPrefixedIdWithDefault:()=>getZodPrefixedIdWithDefault2,inductance:()=>inductance2,kicadAt:()=>kicadAt3,kicadEffects:()=>kicadEffects3,kicadFont:()=>kicadFont3,kicadFootprintAttributes:()=>kicadFootprintAttributes3,kicadFootprintMetadata:()=>kicadFootprintMetadata3,kicadFootprintModel:()=>kicadFootprintModel3,kicadFootprintPad:()=>kicadFootprintPad3,kicadFootprintProperties:()=>kicadFootprintProperties3,kicadProperty:()=>kicadProperty3,kicadSymbolEffects:()=>kicadSymbolEffects3,kicadSymbolMetadata:()=>kicadSymbolMetadata3,kicadSymbolPinNames:()=>kicadSymbolPinNames3,kicadSymbolPinNumbers:()=>kicadSymbolPinNumbers3,kicadSymbolProperties:()=>kicadSymbolProperties3,kicadSymbolProperty:()=>kicadSymbolProperty3,layer_ref:()=>layer_ref2,layer_string:()=>layer_string2,length:()=>length3,ms:()=>ms4,ninePointAnchor:()=>ninePointAnchor3,pcbRenderLayer:()=>pcbRenderLayer2,pcb_autorouting_error:()=>pcb_autorouting_error2,pcb_board:()=>pcb_board2,pcb_breakout_point:()=>pcb_breakout_point2,pcb_component:()=>pcb_component2,pcb_component_invalid_layer_error:()=>pcb_component_invalid_layer_error2,pcb_component_not_on_board_edge_error:()=>pcb_component_not_on_board_edge_error2,pcb_component_outside_board_error:()=>pcb_component_outside_board_error2,pcb_connector_not_in_accessible_orientation_warning:()=>pcb_connector_not_in_accessible_orientation_warning2,pcb_copper_pour:()=>pcb_copper_pour2,pcb_copper_pour_brep:()=>pcb_copper_pour_brep2,pcb_copper_pour_polygon:()=>pcb_copper_pour_polygon2,pcb_copper_pour_rect:()=>pcb_copper_pour_rect2,pcb_copper_text:()=>pcb_copper_text2,pcb_courtyard_circle:()=>pcb_courtyard_circle2,pcb_courtyard_outline:()=>pcb_courtyard_outline2,pcb_courtyard_overlap_error:()=>pcb_courtyard_overlap_error2,pcb_courtyard_polygon:()=>pcb_courtyard_polygon2,pcb_courtyard_rect:()=>pcb_courtyard_rect2,pcb_cutout:()=>pcb_cutout2,pcb_cutout_circle:()=>pcb_cutout_circle2,pcb_cutout_path:()=>pcb_cutout_path2,pcb_cutout_polygon:()=>pcb_cutout_polygon2,pcb_cutout_rect:()=>pcb_cutout_rect2,pcb_fabrication_note_dimension:()=>pcb_fabrication_note_dimension2,pcb_fabrication_note_path:()=>pcb_fabrication_note_path2,pcb_fabrication_note_rect:()=>pcb_fabrication_note_rect2,pcb_fabrication_note_text:()=>pcb_fabrication_note_text2,pcb_footprint_overlap_error:()=>pcb_footprint_overlap_error2,pcb_ground_plane:()=>pcb_ground_plane2,pcb_ground_plane_region:()=>pcb_ground_plane_region2,pcb_group:()=>pcb_group2,pcb_hole:()=>pcb_hole2,pcb_hole_circle_or_square_shape:()=>pcb_hole_circle_or_square_shape2,pcb_hole_circle_shape:()=>pcb_hole_circle_shape2,pcb_hole_oval_shape:()=>pcb_hole_oval_shape2,pcb_hole_pill_shape:()=>pcb_hole_pill_shape2,pcb_hole_rect_shape:()=>pcb_hole_rect_shape2,pcb_hole_rotated_pill_shape:()=>pcb_hole_rotated_pill_shape2,pcb_keepout:()=>pcb_keepout2,pcb_manual_edit_conflict_warning:()=>pcb_manual_edit_conflict_warning2,pcb_missing_footprint_error:()=>pcb_missing_footprint_error2,pcb_net:()=>pcb_net2,pcb_note_dimension:()=>pcb_note_dimension2,pcb_note_line:()=>pcb_note_line2,pcb_note_path:()=>pcb_note_path2,pcb_note_rect:()=>pcb_note_rect2,pcb_note_text:()=>pcb_note_text2,pcb_panel:()=>pcb_panel2,pcb_panelization_placement_error:()=>pcb_panelization_placement_error2,pcb_placement_error:()=>pcb_placement_error2,pcb_plated_hole:()=>pcb_plated_hole2,pcb_port:()=>pcb_port2,pcb_port_not_connected_error:()=>pcb_port_not_connected_error2,pcb_port_not_matched_error:()=>pcb_port_not_matched_error2,pcb_route_hint:()=>pcb_route_hint2,pcb_route_hints:()=>pcb_route_hints2,pcb_silkscreen_circle:()=>pcb_silkscreen_circle2,pcb_silkscreen_line:()=>pcb_silkscreen_line2,pcb_silkscreen_oval:()=>pcb_silkscreen_oval2,pcb_silkscreen_path:()=>pcb_silkscreen_path2,pcb_silkscreen_pill:()=>pcb_silkscreen_pill2,pcb_silkscreen_rect:()=>pcb_silkscreen_rect2,pcb_silkscreen_text:()=>pcb_silkscreen_text2,pcb_smtpad:()=>pcb_smtpad2,pcb_smtpad_pill:()=>pcb_smtpad_pill2,pcb_solder_paste:()=>pcb_solder_paste2,pcb_text:()=>pcb_text2,pcb_thermal_spoke:()=>pcb_thermal_spoke2,pcb_trace:()=>pcb_trace2,pcb_trace_error:()=>pcb_trace_error2,pcb_trace_hint:()=>pcb_trace_hint2,pcb_trace_missing_error:()=>pcb_trace_missing_error2,pcb_trace_route_point:()=>pcb_trace_route_point2,pcb_trace_route_point_via:()=>pcb_trace_route_point_via2,pcb_trace_route_point_wire:()=>pcb_trace_route_point_wire2,pcb_via:()=>pcb_via2,pcb_via_clearance_error:()=>pcb_via_clearance_error2,point:()=>point5,point3:()=>point33,point_with_bulge:()=>point_with_bulge2,port_arrangement:()=>port_arrangement2,position:()=>position2,position3:()=>position32,resistance:()=>resistance2,ring:()=>ring2,rotation:()=>rotation4,route_hint_point:()=>route_hint_point2,schematic_arc:()=>schematic_arc2,schematic_box:()=>schematic_box2,schematic_circle:()=>schematic_circle2,schematic_component:()=>schematic_component2,schematic_component_port_arrangement_by_sides:()=>schematic_component_port_arrangement_by_sides2,schematic_component_port_arrangement_by_size:()=>schematic_component_port_arrangement_by_size2,schematic_debug_line:()=>schematic_debug_line2,schematic_debug_object:()=>schematic_debug_object2,schematic_debug_object_base:()=>schematic_debug_object_base2,schematic_debug_point:()=>schematic_debug_point2,schematic_debug_rect:()=>schematic_debug_rect2,schematic_error:()=>schematic_error2,schematic_group:()=>schematic_group2,schematic_layout_error:()=>schematic_layout_error2,schematic_line:()=>schematic_line2,schematic_manual_edit_conflict_warning:()=>schematic_manual_edit_conflict_warning2,schematic_net_label:()=>schematic_net_label2,schematic_path:()=>schematic_path2,schematic_pin_styles:()=>schematic_pin_styles2,schematic_port:()=>schematic_port2,schematic_rect:()=>schematic_rect2,schematic_sheet:()=>schematic_sheet2,schematic_symbol:()=>schematic_symbol2,schematic_table:()=>schematic_table2,schematic_table_cell:()=>schematic_table_cell2,schematic_text:()=>schematic_text2,schematic_trace:()=>schematic_trace2,schematic_voltage_probe:()=>schematic_voltage_probe2,simulation_ac_current_source:()=>simulation_ac_current_source2,simulation_ac_voltage_source:()=>simulation_ac_voltage_source2,simulation_current_source:()=>simulation_current_source2,simulation_dc_current_source:()=>simulation_dc_current_source2,simulation_dc_voltage_source:()=>simulation_dc_voltage_source2,simulation_experiment:()=>simulation_experiment2,simulation_op_amp:()=>simulation_op_amp2,simulation_switch:()=>simulation_switch2,simulation_transient_voltage_graph:()=>simulation_transient_voltage_graph2,simulation_unknown_experiment_error:()=>simulation_unknown_experiment_error2,simulation_voltage_probe:()=>simulation_voltage_probe2,simulation_voltage_source:()=>simulation_voltage_source2,size:()=>size2,source_ambiguous_port_reference:()=>source_ambiguous_port_reference2,source_board:()=>source_board2,source_component_base:()=>source_component_base2,source_component_internal_connection:()=>source_component_internal_connection2,source_component_pins_underspecified_warning:()=>source_component_pins_underspecified_warning2,source_failed_to_create_component_error:()=>source_failed_to_create_component_error2,source_group:()=>source_group2,source_i2c_misconfigured_error:()=>source_i2c_misconfigured_error2,source_interconnect:()=>source_interconnect2,source_invalid_component_property_error:()=>source_invalid_component_property_error2,source_manually_placed_via:()=>source_manually_placed_via2,source_missing_property_error:()=>source_missing_property_error2,source_net:()=>source_net2,source_no_ground_pin_defined_warning:()=>source_no_ground_pin_defined_warning2,source_no_power_pin_defined_warning:()=>source_no_power_pin_defined_warning2,source_pcb_ground_plane:()=>source_pcb_ground_plane2,source_pin_attributes:()=>source_pin_attributes2,source_pin_missing_trace_warning:()=>source_pin_missing_trace_warning2,source_pin_must_be_connected_error:()=>source_pin_must_be_connected_error2,source_port:()=>source_port2,source_project_metadata:()=>source_project_metadata2,source_property_ignored_warning:()=>source_property_ignored_warning2,source_simple_battery:()=>source_simple_battery2,source_simple_capacitor:()=>source_simple_capacitor2,source_simple_chip:()=>source_simple_chip2,source_simple_connector:()=>source_simple_connector2,source_simple_crystal:()=>source_simple_crystal2,source_simple_current_source:()=>source_simple_current_source2,source_simple_diode:()=>source_simple_diode2,source_simple_fiducial:()=>source_simple_fiducial2,source_simple_ground:()=>source_simple_ground2,source_simple_inductor:()=>source_simple_inductor2,source_simple_led:()=>source_simple_led2,source_simple_mosfet:()=>source_simple_mosfet2,source_simple_op_amp:()=>source_simple_op_amp2,source_simple_pin_header:()=>source_simple_pin_header2,source_simple_pinout:()=>source_simple_pinout2,source_simple_potentiometer:()=>source_simple_potentiometer2,source_simple_power_source:()=>source_simple_power_source2,source_simple_push_button:()=>source_simple_push_button2,source_simple_resistor:()=>source_simple_resistor2,source_simple_resonator:()=>source_simple_resonator2,source_simple_switch:()=>source_simple_switch2,source_simple_test_point:()=>source_simple_test_point2,source_simple_transistor:()=>source_simple_transistor2,source_simple_voltage_probe:()=>source_simple_voltage_probe2,source_simple_voltage_source:()=>source_simple_voltage_source2,source_trace:()=>source_trace2,source_trace_not_connected_error:()=>source_trace_not_connected_error2,supplier_name:()=>supplier_name2,time:()=>time2,timestamp:()=>timestamp2,unknown_error_finding_part:()=>unknown_error_finding_part2,visible_layer:()=>visible_layer2,voltage:()=>voltage2,wave_shape:()=>wave_shape2});var external_exports2={};__export4(external_exports2,{BRAND:()=>BRAND2,DIRTY:()=>DIRTY2,EMPTY_PATH:()=>EMPTY_PATH2,INVALID:()=>INVALID2,NEVER:()=>NEVER2,OK:()=>OK2,ParseStatus:()=>ParseStatus2,Schema:()=>ZodType2,ZodAny:()=>ZodAny2,ZodArray:()=>ZodArray2,ZodBigInt:()=>ZodBigInt2,ZodBoolean:()=>ZodBoolean2,ZodBranded:()=>ZodBranded2,ZodCatch:()=>ZodCatch2,ZodDate:()=>ZodDate2,ZodDefault:()=>ZodDefault2,ZodDiscriminatedUnion:()=>ZodDiscriminatedUnion2,ZodEffects:()=>ZodEffects2,ZodEnum:()=>ZodEnum2,ZodError:()=>ZodError2,ZodFirstPartyTypeKind:()=>ZodFirstPartyTypeKind2,ZodFunction:()=>ZodFunction2,ZodIntersection:()=>ZodIntersection2,ZodIssueCode:()=>ZodIssueCode2,ZodLazy:()=>ZodLazy2,ZodLiteral:()=>ZodLiteral2,ZodMap:()=>ZodMap2,ZodNaN:()=>ZodNaN2,ZodNativeEnum:()=>ZodNativeEnum2,ZodNever:()=>ZodNever2,ZodNull:()=>ZodNull2,ZodNullable:()=>ZodNullable2,ZodNumber:()=>ZodNumber2,ZodObject:()=>ZodObject2,ZodOptional:()=>ZodOptional2,ZodParsedType:()=>ZodParsedType2,ZodPipeline:()=>ZodPipeline2,ZodPromise:()=>ZodPromise2,ZodReadonly:()=>ZodReadonly2,ZodRecord:()=>ZodRecord2,ZodSchema:()=>ZodType2,ZodSet:()=>ZodSet2,ZodString:()=>ZodString2,ZodSymbol:()=>ZodSymbol2,ZodTransformer:()=>ZodEffects2,ZodTuple:()=>ZodTuple2,ZodType:()=>ZodType2,ZodUndefined:()=>ZodUndefined2,ZodUnion:()=>ZodUnion2,ZodUnknown:()=>ZodUnknown2,ZodVoid:()=>ZodVoid2,addIssueToContext:()=>addIssueToContext2,any:()=>anyType2,array:()=>arrayType2,bigint:()=>bigIntType2,boolean:()=>booleanType2,coerce:()=>coerce2,custom:()=>custom2,date:()=>dateType2,datetimeRegex:()=>datetimeRegex2,defaultErrorMap:()=>en_default2,discriminatedUnion:()=>discriminatedUnionType2,effect:()=>effectsType2,enum:()=>enumType2,function:()=>functionType2,getErrorMap:()=>getErrorMap2,getParsedType:()=>getParsedType2,instanceof:()=>instanceOfType2,intersection:()=>intersectionType2,isAborted:()=>isAborted2,isAsync:()=>isAsync2,isDirty:()=>isDirty2,isValid:()=>isValid2,late:()=>late2,lazy:()=>lazyType2,literal:()=>literalType2,makeIssue:()=>makeIssue2,map:()=>mapType2,nan:()=>nanType2,nativeEnum:()=>nativeEnumType2,never:()=>neverType2,null:()=>nullType2,nullable:()=>nullableType2,number:()=>numberType2,object:()=>objectType2,objectUtil:()=>objectUtil2,oboolean:()=>oboolean2,onumber:()=>onumber2,optional:()=>optionalType2,ostring:()=>ostring2,pipeline:()=>pipelineType2,preprocess:()=>preprocessType2,promise:()=>promiseType2,quotelessJson:()=>quotelessJson2,record:()=>recordType2,set:()=>setType2,setErrorMap:()=>setErrorMap2,strictObject:()=>strictObjectType2,string:()=>stringType2,symbol:()=>symbolType2,transformer:()=>effectsType2,tuple:()=>tupleType2,undefined:()=>undefinedType2,union:()=>unionType2,unknown:()=>unknownType2,util:()=>util2,void:()=>voidType2});var util2;(function(util22){util22.assertEqual=_4=>{};function assertIs(_arg){}util22.assertIs=assertIs;function assertNever(_x3){throw new Error}util22.assertNever=assertNever,util22.arrayToEnum=items=>{let obj={};for(let item of items)obj[item]=item;return obj},util22.getValidEnumValues=obj=>{let validKeys=util22.objectKeys(obj).filter(k4=>typeof obj[obj[k4]]!="number"),filtered={};for(let k4 of validKeys)filtered[k4]=obj[k4];return util22.objectValues(filtered)},util22.objectValues=obj=>util22.objectKeys(obj).map(function(e5){return obj[e5]}),util22.objectKeys=typeof Object.keys=="function"?obj=>Object.keys(obj):object=>{let keys=[];for(let key in object)Object.prototype.hasOwnProperty.call(object,key)&&keys.push(key);return keys},util22.find=(arr,checker)=>{for(let item of arr)if(checker(item))return item},util22.isInteger=typeof Number.isInteger=="function"?val=>Number.isInteger(val):val=>typeof val=="number"&&Number.isFinite(val)&&Math.floor(val)===val;function joinValues(array2,separator=" | "){return array2.map(val=>typeof val=="string"?`'${val}'`:val).join(separator)}util22.joinValues=joinValues,util22.jsonStringifyReplacer=(_4,value)=>typeof value=="bigint"?value.toString():value})(util2||(util2={}));var objectUtil2;(function(objectUtil22){objectUtil22.mergeShapes=(first,second)=>({...first,...second})})(objectUtil2||(objectUtil2={}));var ZodParsedType2=util2.arrayToEnum(["string","nan","number","integer","float","boolean","date","bigint","symbol","function","undefined","null","array","object","unknown","promise","void","never","map","set"]),getParsedType2=data=>{switch(typeof data){case"undefined":return ZodParsedType2.undefined;case"string":return ZodParsedType2.string;case"number":return Number.isNaN(data)?ZodParsedType2.nan:ZodParsedType2.number;case"boolean":return ZodParsedType2.boolean;case"function":return ZodParsedType2.function;case"bigint":return ZodParsedType2.bigint;case"symbol":return ZodParsedType2.symbol;case"object":return Array.isArray(data)?ZodParsedType2.array:data===null?ZodParsedType2.null:data.then&&typeof data.then=="function"&&data.catch&&typeof data.catch=="function"?ZodParsedType2.promise:typeof Map<"u"&&data instanceof Map?ZodParsedType2.map:typeof Set<"u"&&data instanceof Set?ZodParsedType2.set:typeof Date<"u"&&data instanceof Date?ZodParsedType2.date:ZodParsedType2.object;default:return ZodParsedType2.unknown}},ZodIssueCode2=util2.arrayToEnum(["invalid_type","invalid_literal","custom","invalid_union","invalid_union_discriminator","invalid_enum_value","unrecognized_keys","invalid_arguments","invalid_return_type","invalid_date","invalid_string","too_small","too_big","invalid_intersection_types","not_multiple_of","not_finite"]),quotelessJson2=obj=>JSON.stringify(obj,null,2).replace(/"([^"]+)":/g,"$1:"),ZodError2=class _ZodError extends Error{get errors(){return this.issues}constructor(issues){super(),this.issues=[],this.addIssue=sub=>{this.issues=[...this.issues,sub]},this.addIssues=(subs=[])=>{this.issues=[...this.issues,...subs]};let actualProto=new.target.prototype;Object.setPrototypeOf?Object.setPrototypeOf(this,actualProto):this.__proto__=actualProto,this.name="ZodError",this.issues=issues}format(_mapper){let mapper=_mapper||function(issue){return issue.message},fieldErrors={_errors:[]},processError=error2=>{for(let issue of error2.issues)if(issue.code==="invalid_union")issue.unionErrors.map(processError);else if(issue.code==="invalid_return_type")processError(issue.returnTypeError);else if(issue.code==="invalid_arguments")processError(issue.argumentsError);else if(issue.path.length===0)fieldErrors._errors.push(mapper(issue));else{let curr=fieldErrors,i3=0;for(;i3<issue.path.length;){let el3=issue.path[i3];i3===issue.path.length-1?(curr[el3]=curr[el3]||{_errors:[]},curr[el3]._errors.push(mapper(issue))):curr[el3]=curr[el3]||{_errors:[]},curr=curr[el3],i3++}}};return processError(this),fieldErrors}static assert(value){if(!(value instanceof _ZodError))throw new Error(`Not a ZodError: ${value}`)}toString(){return this.message}get message(){return JSON.stringify(this.issues,util2.jsonStringifyReplacer,2)}get isEmpty(){return this.issues.length===0}flatten(mapper=issue=>issue.message){let fieldErrors={},formErrors=[];for(let sub of this.issues)if(sub.path.length>0){let firstEl=sub.path[0];fieldErrors[firstEl]=fieldErrors[firstEl]||[],fieldErrors[firstEl].push(mapper(sub))}else formErrors.push(mapper(sub));return{formErrors,fieldErrors}}get formErrors(){return this.flatten()}};ZodError2.create=issues=>new ZodError2(issues);var errorMap2=(issue,_ctx)=>{let message;switch(issue.code){case ZodIssueCode2.invalid_type:issue.received===ZodParsedType2.undefined?message="Required":message=`Expected ${issue.expected}, received ${issue.received}`;break;case ZodIssueCode2.invalid_literal:message=`Invalid literal value, expected ${JSON.stringify(issue.expected,util2.jsonStringifyReplacer)}`;break;case ZodIssueCode2.unrecognized_keys:message=`Unrecognized key(s) in object: ${util2.joinValues(issue.keys,", ")}`;break;case ZodIssueCode2.invalid_union:message="Invalid input";break;case ZodIssueCode2.invalid_union_discriminator:message=`Invalid discriminator value. Expected ${util2.joinValues(issue.options)}`;break;case ZodIssueCode2.invalid_enum_value:message=`Invalid enum value. Expected ${util2.joinValues(issue.options)}, received '${issue.received}'`;break;case ZodIssueCode2.invalid_arguments:message="Invalid function arguments";break;case ZodIssueCode2.invalid_return_type:message="Invalid function return type";break;case ZodIssueCode2.invalid_date:message="Invalid date";break;case ZodIssueCode2.invalid_string:typeof issue.validation=="object"?"includes"in issue.validation?(message=`Invalid input: must include "${issue.validation.includes}"`,typeof issue.validation.position=="number"&&(message=`${message} at one or more positions greater than or equal to ${issue.validation.position}`)):"startsWith"in issue.validation?message=`Invalid input: must start with "${issue.validation.startsWith}"`:"endsWith"in issue.validation?message=`Invalid input: must end with "${issue.validation.endsWith}"`:util2.assertNever(issue.validation):issue.validation!=="regex"?message=`Invalid ${issue.validation}`:message="Invalid";break;case ZodIssueCode2.too_small:issue.type==="array"?message=`Array must contain ${issue.exact?"exactly":issue.inclusive?"at least":"more than"} ${issue.minimum} element(s)`:issue.type==="string"?message=`String must contain ${issue.exact?"exactly":issue.inclusive?"at least":"over"} ${issue.minimum} character(s)`:issue.type==="number"?message=`Number must be ${issue.exact?"exactly equal to ":issue.inclusive?"greater than or equal to ":"greater than "}${issue.minimum}`:issue.type==="bigint"?message=`Number must be ${issue.exact?"exactly equal to ":issue.inclusive?"greater than or equal to ":"greater than "}${issue.minimum}`:issue.type==="date"?message=`Date must be ${issue.exact?"exactly equal to ":issue.inclusive?"greater than or equal to ":"greater than "}${new Date(Number(issue.minimum))}`:message="Invalid input";break;case ZodIssueCode2.too_big:issue.type==="array"?message=`Array must contain ${issue.exact?"exactly":issue.inclusive?"at most":"less than"} ${issue.maximum} element(s)`:issue.type==="string"?message=`String must contain ${issue.exact?"exactly":issue.inclusive?"at most":"under"} ${issue.maximum} character(s)`:issue.type==="number"?message=`Number must be ${issue.exact?"exactly":issue.inclusive?"less than or equal to":"less than"} ${issue.maximum}`:issue.type==="bigint"?message=`BigInt must be ${issue.exact?"exactly":issue.inclusive?"less than or equal to":"less than"} ${issue.maximum}`:issue.type==="date"?message=`Date must be ${issue.exact?"exactly":issue.inclusive?"smaller than or equal to":"smaller than"} ${new Date(Number(issue.maximum))}`:message="Invalid input";break;case ZodIssueCode2.custom:message="Invalid input";break;case ZodIssueCode2.invalid_intersection_types:message="Intersection results could not be merged";break;case ZodIssueCode2.not_multiple_of:message=`Number must be a multiple of ${issue.multipleOf}`;break;case ZodIssueCode2.not_finite:message="Number must be finite";break;default:message=_ctx.defaultError,util2.assertNever(issue)}return{message}},en_default2=errorMap2,overrideErrorMap2=en_default2;function setErrorMap2(map){overrideErrorMap2=map}function getErrorMap2(){return overrideErrorMap2}var makeIssue2=params=>{let{data,path,errorMaps,issueData}=params,fullPath=[...path,...issueData.path||[]],fullIssue={...issueData,path:fullPath};if(issueData.message!==void 0)return{...issueData,path:fullPath,message:issueData.message};let errorMessage="",maps=errorMaps.filter(m4=>!!m4).slice().reverse();for(let map of maps)errorMessage=map(fullIssue,{data,defaultError:errorMessage}).message;return{...issueData,path:fullPath,message:errorMessage}},EMPTY_PATH2=[];function addIssueToContext2(ctx,issueData){let overrideMap=getErrorMap2(),issue=makeIssue2({issueData,data:ctx.data,path:ctx.path,errorMaps:[ctx.common.contextualErrorMap,ctx.schemaErrorMap,overrideMap,overrideMap===en_default2?void 0:en_default2].filter(x4=>!!x4)});ctx.common.issues.push(issue)}var ParseStatus2=class _ParseStatus{constructor(){this.value="valid"}dirty(){this.value==="valid"&&(this.value="dirty")}abort(){this.value!=="aborted"&&(this.value="aborted")}static mergeArray(status,results){let arrayValue=[];for(let s3 of results){if(s3.status==="aborted")return INVALID2;s3.status==="dirty"&&status.dirty(),arrayValue.push(s3.value)}return{status:status.value,value:arrayValue}}static async mergeObjectAsync(status,pairs22){let syncPairs=[];for(let pair of pairs22){let key=await pair.key,value=await pair.value;syncPairs.push({key,value})}return _ParseStatus.mergeObjectSync(status,syncPairs)}static mergeObjectSync(status,pairs22){let finalObject={};for(let pair of pairs22){let{key,value}=pair;if(key.status==="aborted"||value.status==="aborted")return INVALID2;key.status==="dirty"&&status.dirty(),value.status==="dirty"&&status.dirty(),key.value!=="__proto__"&&(typeof value.value<"u"||pair.alwaysSet)&&(finalObject[key.value]=value.value)}return{status:status.value,value:finalObject}}},INVALID2=Object.freeze({status:"aborted"}),DIRTY2=value=>({status:"dirty",value}),OK2=value=>({status:"valid",value}),isAborted2=x4=>x4.status==="aborted",isDirty2=x4=>x4.status==="dirty",isValid2=x4=>x4.status==="valid",isAsync2=x4=>typeof Promise<"u"&&x4 instanceof Promise,errorUtil2;(function(errorUtil22){errorUtil22.errToObj=message=>typeof message=="string"?{message}:message||{},errorUtil22.toString=message=>typeof message=="string"?message:message?.message})(errorUtil2||(errorUtil2={}));var ParseInputLazyPath2=class{constructor(parent,value,path,key){this._cachedPath=[],this.parent=parent,this.data=value,this._path=path,this._key=key}get path(){return this._cachedPath.length||(Array.isArray(this._key)?this._cachedPath.push(...this._path,...this._key):this._cachedPath.push(...this._path,this._key)),this._cachedPath}},handleResult2=(ctx,result)=>{if(isValid2(result))return{success:!0,data:result.value};if(!ctx.common.issues.length)throw new Error("Validation failed but no issues detected.");return{success:!1,get error(){if(this._error)return this._error;let error2=new ZodError2(ctx.common.issues);return this._error=error2,this._error}}};function processCreateParams2(params){if(!params)return{};let{errorMap:errorMap22,invalid_type_error,required_error,description}=params;if(errorMap22&&(invalid_type_error||required_error))throw new Error(`Can't use "invalid_type_error" or "required_error" in conjunction with custom error map.`);return errorMap22?{errorMap:errorMap22,description}:{errorMap:(iss,ctx)=>{let{message}=params;return iss.code==="invalid_enum_value"?{message:message??ctx.defaultError}:typeof ctx.data>"u"?{message:message??required_error??ctx.defaultError}:iss.code!=="invalid_type"?{message:ctx.defaultError}:{message:message??invalid_type_error??ctx.defaultError}},description}}var ZodType2=class{get description(){return this._def.description}_getType(input2){return getParsedType2(input2.data)}_getOrReturnCtx(input2,ctx){return ctx||{common:input2.parent.common,data:input2.data,parsedType:getParsedType2(input2.data),schemaErrorMap:this._def.errorMap,path:input2.path,parent:input2.parent}}_processInputParams(input2){return{status:new ParseStatus2,ctx:{common:input2.parent.common,data:input2.data,parsedType:getParsedType2(input2.data),schemaErrorMap:this._def.errorMap,path:input2.path,parent:input2.parent}}}_parseSync(input2){let result=this._parse(input2);if(isAsync2(result))throw new Error("Synchronous parse encountered promise.");return result}_parseAsync(input2){let result=this._parse(input2);return Promise.resolve(result)}parse(data,params){let result=this.safeParse(data,params);if(result.success)return result.data;throw result.error}safeParse(data,params){let ctx={common:{issues:[],async:params?.async??!1,contextualErrorMap:params?.errorMap},path:params?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data,parsedType:getParsedType2(data)},result=this._parseSync({data,path:ctx.path,parent:ctx});return handleResult2(ctx,result)}"~validate"(data){let ctx={common:{issues:[],async:!!this["~standard"].async},path:[],schemaErrorMap:this._def.errorMap,parent:null,data,parsedType:getParsedType2(data)};if(!this["~standard"].async)try{let result=this._parseSync({data,path:[],parent:ctx});return isValid2(result)?{value:result.value}:{issues:ctx.common.issues}}catch(err){err?.message?.toLowerCase()?.includes("encountered")&&(this["~standard"].async=!0),ctx.common={issues:[],async:!0}}return this._parseAsync({data,path:[],parent:ctx}).then(result=>isValid2(result)?{value:result.value}:{issues:ctx.common.issues})}async parseAsync(data,params){let result=await this.safeParseAsync(data,params);if(result.success)return result.data;throw result.error}async safeParseAsync(data,params){let ctx={common:{issues:[],contextualErrorMap:params?.errorMap,async:!0},path:params?.path||[],schemaErrorMap:this._def.errorMap,parent:null,data,parsedType:getParsedType2(data)},maybeAsyncResult=this._parse({data,path:ctx.path,parent:ctx}),result=await(isAsync2(maybeAsyncResult)?maybeAsyncResult:Promise.resolve(maybeAsyncResult));return handleResult2(ctx,result)}refine(check,message){let getIssueProperties=val=>typeof message=="string"||typeof message>"u"?{message}:typeof message=="function"?message(val):message;return this._refinement((val,ctx)=>{let result=check(val),setError=()=>ctx.addIssue({code:ZodIssueCode2.custom,...getIssueProperties(val)});return typeof Promise<"u"&&result instanceof Promise?result.then(data=>data?!0:(setError(),!1)):result?!0:(setError(),!1)})}refinement(check,refinementData){return this._refinement((val,ctx)=>check(val)?!0:(ctx.addIssue(typeof refinementData=="function"?refinementData(val,ctx):refinementData),!1))}_refinement(refinement){return new ZodEffects2({schema:this,typeName:ZodFirstPartyTypeKind2.ZodEffects,effect:{type:"refinement",refinement}})}superRefine(refinement){return this._refinement(refinement)}constructor(def){this.spa=this.safeParseAsync,this._def=def,this.parse=this.parse.bind(this),this.safeParse=this.safeParse.bind(this),this.parseAsync=this.parseAsync.bind(this),this.safeParseAsync=this.safeParseAsync.bind(this),this.spa=this.spa.bind(this),this.refine=this.refine.bind(this),this.refinement=this.refinement.bind(this),this.superRefine=this.superRefine.bind(this),this.optional=this.optional.bind(this),this.nullable=this.nullable.bind(this),this.nullish=this.nullish.bind(this),this.array=this.array.bind(this),this.promise=this.promise.bind(this),this.or=this.or.bind(this),this.and=this.and.bind(this),this.transform=this.transform.bind(this),this.brand=this.brand.bind(this),this.default=this.default.bind(this),this.catch=this.catch.bind(this),this.describe=this.describe.bind(this),this.pipe=this.pipe.bind(this),this.readonly=this.readonly.bind(this),this.isNullable=this.isNullable.bind(this),this.isOptional=this.isOptional.bind(this),this["~standard"]={version:1,vendor:"zod",validate:data=>this["~validate"](data)}}optional(){return ZodOptional2.create(this,this._def)}nullable(){return ZodNullable2.create(this,this._def)}nullish(){return this.nullable().optional()}array(){return ZodArray2.create(this)}promise(){return ZodPromise2.create(this,this._def)}or(option){return ZodUnion2.create([this,option],this._def)}and(incoming){return ZodIntersection2.create(this,incoming,this._def)}transform(transform22){return new ZodEffects2({...processCreateParams2(this._def),schema:this,typeName:ZodFirstPartyTypeKind2.ZodEffects,effect:{type:"transform",transform:transform22}})}default(def){let defaultValueFunc=typeof def=="function"?def:()=>def;return new ZodDefault2({...processCreateParams2(this._def),innerType:this,defaultValue:defaultValueFunc,typeName:ZodFirstPartyTypeKind2.ZodDefault})}brand(){return new ZodBranded2({typeName:ZodFirstPartyTypeKind2.ZodBranded,type:this,...processCreateParams2(this._def)})}catch(def){let catchValueFunc=typeof def=="function"?def:()=>def;return new ZodCatch2({...processCreateParams2(this._def),innerType:this,catchValue:catchValueFunc,typeName:ZodFirstPartyTypeKind2.ZodCatch})}describe(description){let This=this.constructor;return new This({...this._def,description})}pipe(target){return ZodPipeline2.create(this,target)}readonly(){return ZodReadonly2.create(this)}isOptional(){return this.safeParse(void 0).success}isNullable(){return this.safeParse(null).success}},cuidRegex2=/^c[^\s-]{8,}$/i,cuid2Regex2=/^[0-9a-z]+$/,ulidRegex2=/^[0-9A-HJKMNP-TV-Z]{26}$/i,uuidRegex2=/^[0-9a-fA-F]{8}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{12}$/i,nanoidRegex2=/^[a-z0-9_-]{21}$/i,jwtRegex2=/^[A-Za-z0-9-_]+\.[A-Za-z0-9-_]+\.[A-Za-z0-9-_]*$/,durationRegex2=/^[-+]?P(?!$)(?:(?:[-+]?\d+Y)|(?:[-+]?\d+[.,]\d+Y$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:(?:[-+]?\d+W)|(?:[-+]?\d+[.,]\d+W$))?(?:(?:[-+]?\d+D)|(?:[-+]?\d+[.,]\d+D$))?(?:T(?=[\d+-])(?:(?:[-+]?\d+H)|(?:[-+]?\d+[.,]\d+H$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:[-+]?\d+(?:[.,]\d+)?S)?)??$/,emailRegex2=/^(?!\.)(?!.*\.\.)([A-Z0-9_'+\-\.]*)[A-Z0-9_+-]@([A-Z0-9][A-Z0-9\-]*\.)+[A-Z]{2,}$/i,_emojiRegex2="^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$",emojiRegex2,ipv4Regex2=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/,ipv4CidrRegex2=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/(3[0-2]|[12]?[0-9])$/,ipv6Regex2=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))$/,ipv6CidrRegex2=/^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/,base64Regex2=/^([0-9a-zA-Z+/]{4})*(([0-9a-zA-Z+/]{2}==)|([0-9a-zA-Z+/]{3}=))?$/,base64urlRegex2=/^([0-9a-zA-Z-_]{4})*(([0-9a-zA-Z-_]{2}(==)?)|([0-9a-zA-Z-_]{3}(=)?))?$/,dateRegexSource2="((\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-((0[13578]|1[02])-(0[1-9]|[12]\\d|3[01])|(0[469]|11)-(0[1-9]|[12]\\d|30)|(02)-(0[1-9]|1\\d|2[0-8])))",dateRegex2=new RegExp(`^${dateRegexSource2}$`);function timeRegexSource2(args){let secondsRegexSource="[0-5]\\d";args.precision?secondsRegexSource=`${secondsRegexSource}\\.\\d{${args.precision}}`:args.precision==null&&(secondsRegexSource=`${secondsRegexSource}(\\.\\d+)?`);let secondsQuantifier=args.precision?"+":"?";return`([01]\\d|2[0-3]):[0-5]\\d(:${secondsRegexSource})${secondsQuantifier}`}function timeRegex2(args){return new RegExp(`^${timeRegexSource2(args)}$`)}function datetimeRegex2(args){let regex=`${dateRegexSource2}T${timeRegexSource2(args)}`,opts=[];return opts.push(args.local?"Z?":"Z"),args.offset&&opts.push("([+-]\\d{2}:?\\d{2})"),regex=`${regex}(${opts.join("|")})`,new RegExp(`^${regex}$`)}function isValidIP2(ip3,version2){return!!((version2==="v4"||!version2)&&ipv4Regex2.test(ip3)||(version2==="v6"||!version2)&&ipv6Regex2.test(ip3))}function isValidJWT2(jwt,alg){if(!jwtRegex2.test(jwt))return!1;try{let[header]=jwt.split(".");if(!header)return!1;let base64=header.replace(/-/g,"+").replace(/_/g,"/").padEnd(header.length+(4-header.length%4)%4,"="),decoded=JSON.parse(atob(base64));return!(typeof decoded!="object"||decoded===null||"typ"in decoded&&decoded?.typ!=="JWT"||!decoded.alg||alg&&decoded.alg!==alg)}catch{return!1}}function isValidCidr2(ip3,version2){return!!((version2==="v4"||!version2)&&ipv4CidrRegex2.test(ip3)||(version2==="v6"||!version2)&&ipv6CidrRegex2.test(ip3))}var ZodString2=class _ZodString extends ZodType2{_parse(input2){if(this._def.coerce&&(input2.data=String(input2.data)),this._getType(input2)!==ZodParsedType2.string){let ctx2=this._getOrReturnCtx(input2);return addIssueToContext2(ctx2,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.string,received:ctx2.parsedType}),INVALID2}let status=new ParseStatus2,ctx;for(let check of this._def.checks)if(check.kind==="min")input2.data.length<check.value&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,minimum:check.value,type:"string",inclusive:!0,exact:!1,message:check.message}),status.dirty());else if(check.kind==="max")input2.data.length>check.value&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,maximum:check.value,type:"string",inclusive:!0,exact:!1,message:check.message}),status.dirty());else if(check.kind==="length"){let tooBig=input2.data.length>check.value,tooSmall=input2.data.length<check.value;(tooBig||tooSmall)&&(ctx=this._getOrReturnCtx(input2,ctx),tooBig?addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,maximum:check.value,type:"string",inclusive:!0,exact:!0,message:check.message}):tooSmall&&addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,minimum:check.value,type:"string",inclusive:!0,exact:!0,message:check.message}),status.dirty())}else if(check.kind==="email")emailRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"email",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty());else if(check.kind==="emoji")emojiRegex2||(emojiRegex2=new RegExp(_emojiRegex2,"u")),emojiRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"emoji",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty());else if(check.kind==="uuid")uuidRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"uuid",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty());else if(check.kind==="nanoid")nanoidRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"nanoid",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty());else if(check.kind==="cuid")cuidRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"cuid",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty());else if(check.kind==="cuid2")cuid2Regex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"cuid2",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty());else if(check.kind==="ulid")ulidRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"ulid",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty());else if(check.kind==="url")try{new URL(input2.data)}catch{ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"url",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty()}else check.kind==="regex"?(check.regex.lastIndex=0,check.regex.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"regex",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty())):check.kind==="trim"?input2.data=input2.data.trim():check.kind==="includes"?input2.data.includes(check.value,check.position)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_string,validation:{includes:check.value,position:check.position},message:check.message}),status.dirty()):check.kind==="toLowerCase"?input2.data=input2.data.toLowerCase():check.kind==="toUpperCase"?input2.data=input2.data.toUpperCase():check.kind==="startsWith"?input2.data.startsWith(check.value)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_string,validation:{startsWith:check.value},message:check.message}),status.dirty()):check.kind==="endsWith"?input2.data.endsWith(check.value)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_string,validation:{endsWith:check.value},message:check.message}),status.dirty()):check.kind==="datetime"?datetimeRegex2(check).test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_string,validation:"datetime",message:check.message}),status.dirty()):check.kind==="date"?dateRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_string,validation:"date",message:check.message}),status.dirty()):check.kind==="time"?timeRegex2(check).test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_string,validation:"time",message:check.message}),status.dirty()):check.kind==="duration"?durationRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"duration",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty()):check.kind==="ip"?isValidIP2(input2.data,check.version)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"ip",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty()):check.kind==="jwt"?isValidJWT2(input2.data,check.alg)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"jwt",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty()):check.kind==="cidr"?isValidCidr2(input2.data,check.version)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"cidr",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty()):check.kind==="base64"?base64Regex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"base64",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty()):check.kind==="base64url"?base64urlRegex2.test(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{validation:"base64url",code:ZodIssueCode2.invalid_string,message:check.message}),status.dirty()):util2.assertNever(check);return{status:status.value,value:input2.data}}_regex(regex,validation,message){return this.refinement(data=>regex.test(data),{validation,code:ZodIssueCode2.invalid_string,...errorUtil2.errToObj(message)})}_addCheck(check){return new _ZodString({...this._def,checks:[...this._def.checks,check]})}email(message){return this._addCheck({kind:"email",...errorUtil2.errToObj(message)})}url(message){return this._addCheck({kind:"url",...errorUtil2.errToObj(message)})}emoji(message){return this._addCheck({kind:"emoji",...errorUtil2.errToObj(message)})}uuid(message){return this._addCheck({kind:"uuid",...errorUtil2.errToObj(message)})}nanoid(message){return this._addCheck({kind:"nanoid",...errorUtil2.errToObj(message)})}cuid(message){return this._addCheck({kind:"cuid",...errorUtil2.errToObj(message)})}cuid2(message){return this._addCheck({kind:"cuid2",...errorUtil2.errToObj(message)})}ulid(message){return this._addCheck({kind:"ulid",...errorUtil2.errToObj(message)})}base64(message){return this._addCheck({kind:"base64",...errorUtil2.errToObj(message)})}base64url(message){return this._addCheck({kind:"base64url",...errorUtil2.errToObj(message)})}jwt(options){return this._addCheck({kind:"jwt",...errorUtil2.errToObj(options)})}ip(options){return this._addCheck({kind:"ip",...errorUtil2.errToObj(options)})}cidr(options){return this._addCheck({kind:"cidr",...errorUtil2.errToObj(options)})}datetime(options){return typeof options=="string"?this._addCheck({kind:"datetime",precision:null,offset:!1,local:!1,message:options}):this._addCheck({kind:"datetime",precision:typeof options?.precision>"u"?null:options?.precision,offset:options?.offset??!1,local:options?.local??!1,...errorUtil2.errToObj(options?.message)})}date(message){return this._addCheck({kind:"date",message})}time(options){return typeof options=="string"?this._addCheck({kind:"time",precision:null,message:options}):this._addCheck({kind:"time",precision:typeof options?.precision>"u"?null:options?.precision,...errorUtil2.errToObj(options?.message)})}duration(message){return this._addCheck({kind:"duration",...errorUtil2.errToObj(message)})}regex(regex,message){return this._addCheck({kind:"regex",regex,...errorUtil2.errToObj(message)})}includes(value,options){return this._addCheck({kind:"includes",value,position:options?.position,...errorUtil2.errToObj(options?.message)})}startsWith(value,message){return this._addCheck({kind:"startsWith",value,...errorUtil2.errToObj(message)})}endsWith(value,message){return this._addCheck({kind:"endsWith",value,...errorUtil2.errToObj(message)})}min(minLength,message){return this._addCheck({kind:"min",value:minLength,...errorUtil2.errToObj(message)})}max(maxLength,message){return this._addCheck({kind:"max",value:maxLength,...errorUtil2.errToObj(message)})}length(len,message){return this._addCheck({kind:"length",value:len,...errorUtil2.errToObj(message)})}nonempty(message){return this.min(1,errorUtil2.errToObj(message))}trim(){return new _ZodString({...this._def,checks:[...this._def.checks,{kind:"trim"}]})}toLowerCase(){return new _ZodString({...this._def,checks:[...this._def.checks,{kind:"toLowerCase"}]})}toUpperCase(){return new _ZodString({...this._def,checks:[...this._def.checks,{kind:"toUpperCase"}]})}get isDatetime(){return!!this._def.checks.find(ch3=>ch3.kind==="datetime")}get isDate(){return!!this._def.checks.find(ch3=>ch3.kind==="date")}get isTime(){return!!this._def.checks.find(ch3=>ch3.kind==="time")}get isDuration(){return!!this._def.checks.find(ch3=>ch3.kind==="duration")}get isEmail(){return!!this._def.checks.find(ch3=>ch3.kind==="email")}get isURL(){return!!this._def.checks.find(ch3=>ch3.kind==="url")}get isEmoji(){return!!this._def.checks.find(ch3=>ch3.kind==="emoji")}get isUUID(){return!!this._def.checks.find(ch3=>ch3.kind==="uuid")}get isNANOID(){return!!this._def.checks.find(ch3=>ch3.kind==="nanoid")}get isCUID(){return!!this._def.checks.find(ch3=>ch3.kind==="cuid")}get isCUID2(){return!!this._def.checks.find(ch3=>ch3.kind==="cuid2")}get isULID(){return!!this._def.checks.find(ch3=>ch3.kind==="ulid")}get isIP(){return!!this._def.checks.find(ch3=>ch3.kind==="ip")}get isCIDR(){return!!this._def.checks.find(ch3=>ch3.kind==="cidr")}get isBase64(){return!!this._def.checks.find(ch3=>ch3.kind==="base64")}get isBase64url(){return!!this._def.checks.find(ch3=>ch3.kind==="base64url")}get minLength(){let min=null;for(let ch3 of this._def.checks)ch3.kind==="min"&&(min===null||ch3.value>min)&&(min=ch3.value);return min}get maxLength(){let max=null;for(let ch3 of this._def.checks)ch3.kind==="max"&&(max===null||ch3.value<max)&&(max=ch3.value);return max}};ZodString2.create=params=>new ZodString2({checks:[],typeName:ZodFirstPartyTypeKind2.ZodString,coerce:params?.coerce??!1,...processCreateParams2(params)});function floatSafeRemainder2(val,step){let valDecCount=(val.toString().split(".")[1]||"").length,stepDecCount=(step.toString().split(".")[1]||"").length,decCount=valDecCount>stepDecCount?valDecCount:stepDecCount,valInt=Number.parseInt(val.toFixed(decCount).replace(".","")),stepInt=Number.parseInt(step.toFixed(decCount).replace(".",""));return valInt%stepInt/10**decCount}var ZodNumber2=class _ZodNumber extends ZodType2{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte,this.step=this.multipleOf}_parse(input2){if(this._def.coerce&&(input2.data=Number(input2.data)),this._getType(input2)!==ZodParsedType2.number){let ctx2=this._getOrReturnCtx(input2);return addIssueToContext2(ctx2,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.number,received:ctx2.parsedType}),INVALID2}let ctx,status=new ParseStatus2;for(let check of this._def.checks)check.kind==="int"?util2.isInteger(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:"integer",received:"float",message:check.message}),status.dirty()):check.kind==="min"?(check.inclusive?input2.data<check.value:input2.data<=check.value)&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,minimum:check.value,type:"number",inclusive:check.inclusive,exact:!1,message:check.message}),status.dirty()):check.kind==="max"?(check.inclusive?input2.data>check.value:input2.data>=check.value)&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,maximum:check.value,type:"number",inclusive:check.inclusive,exact:!1,message:check.message}),status.dirty()):check.kind==="multipleOf"?floatSafeRemainder2(input2.data,check.value)!==0&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.not_multiple_of,multipleOf:check.value,message:check.message}),status.dirty()):check.kind==="finite"?Number.isFinite(input2.data)||(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.not_finite,message:check.message}),status.dirty()):util2.assertNever(check);return{status:status.value,value:input2.data}}gte(value,message){return this.setLimit("min",value,!0,errorUtil2.toString(message))}gt(value,message){return this.setLimit("min",value,!1,errorUtil2.toString(message))}lte(value,message){return this.setLimit("max",value,!0,errorUtil2.toString(message))}lt(value,message){return this.setLimit("max",value,!1,errorUtil2.toString(message))}setLimit(kind,value,inclusive,message){return new _ZodNumber({...this._def,checks:[...this._def.checks,{kind,value,inclusive,message:errorUtil2.toString(message)}]})}_addCheck(check){return new _ZodNumber({...this._def,checks:[...this._def.checks,check]})}int(message){return this._addCheck({kind:"int",message:errorUtil2.toString(message)})}positive(message){return this._addCheck({kind:"min",value:0,inclusive:!1,message:errorUtil2.toString(message)})}negative(message){return this._addCheck({kind:"max",value:0,inclusive:!1,message:errorUtil2.toString(message)})}nonpositive(message){return this._addCheck({kind:"max",value:0,inclusive:!0,message:errorUtil2.toString(message)})}nonnegative(message){return this._addCheck({kind:"min",value:0,inclusive:!0,message:errorUtil2.toString(message)})}multipleOf(value,message){return this._addCheck({kind:"multipleOf",value,message:errorUtil2.toString(message)})}finite(message){return this._addCheck({kind:"finite",message:errorUtil2.toString(message)})}safe(message){return this._addCheck({kind:"min",inclusive:!0,value:Number.MIN_SAFE_INTEGER,message:errorUtil2.toString(message)})._addCheck({kind:"max",inclusive:!0,value:Number.MAX_SAFE_INTEGER,message:errorUtil2.toString(message)})}get minValue(){let min=null;for(let ch3 of this._def.checks)ch3.kind==="min"&&(min===null||ch3.value>min)&&(min=ch3.value);return min}get maxValue(){let max=null;for(let ch3 of this._def.checks)ch3.kind==="max"&&(max===null||ch3.value<max)&&(max=ch3.value);return max}get isInt(){return!!this._def.checks.find(ch3=>ch3.kind==="int"||ch3.kind==="multipleOf"&&util2.isInteger(ch3.value))}get isFinite(){let max=null,min=null;for(let ch3 of this._def.checks){if(ch3.kind==="finite"||ch3.kind==="int"||ch3.kind==="multipleOf")return!0;ch3.kind==="min"?(min===null||ch3.value>min)&&(min=ch3.value):ch3.kind==="max"&&(max===null||ch3.value<max)&&(max=ch3.value)}return Number.isFinite(min)&&Number.isFinite(max)}};ZodNumber2.create=params=>new ZodNumber2({checks:[],typeName:ZodFirstPartyTypeKind2.ZodNumber,coerce:params?.coerce||!1,...processCreateParams2(params)});var ZodBigInt2=class _ZodBigInt extends ZodType2{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte}_parse(input2){if(this._def.coerce)try{input2.data=BigInt(input2.data)}catch{return this._getInvalidInput(input2)}if(this._getType(input2)!==ZodParsedType2.bigint)return this._getInvalidInput(input2);let ctx,status=new ParseStatus2;for(let check of this._def.checks)check.kind==="min"?(check.inclusive?input2.data<check.value:input2.data<=check.value)&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,type:"bigint",minimum:check.value,inclusive:check.inclusive,message:check.message}),status.dirty()):check.kind==="max"?(check.inclusive?input2.data>check.value:input2.data>=check.value)&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,type:"bigint",maximum:check.value,inclusive:check.inclusive,message:check.message}),status.dirty()):check.kind==="multipleOf"?input2.data%check.value!==BigInt(0)&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.not_multiple_of,multipleOf:check.value,message:check.message}),status.dirty()):util2.assertNever(check);return{status:status.value,value:input2.data}}_getInvalidInput(input2){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.bigint,received:ctx.parsedType}),INVALID2}gte(value,message){return this.setLimit("min",value,!0,errorUtil2.toString(message))}gt(value,message){return this.setLimit("min",value,!1,errorUtil2.toString(message))}lte(value,message){return this.setLimit("max",value,!0,errorUtil2.toString(message))}lt(value,message){return this.setLimit("max",value,!1,errorUtil2.toString(message))}setLimit(kind,value,inclusive,message){return new _ZodBigInt({...this._def,checks:[...this._def.checks,{kind,value,inclusive,message:errorUtil2.toString(message)}]})}_addCheck(check){return new _ZodBigInt({...this._def,checks:[...this._def.checks,check]})}positive(message){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!1,message:errorUtil2.toString(message)})}negative(message){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!1,message:errorUtil2.toString(message)})}nonpositive(message){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!0,message:errorUtil2.toString(message)})}nonnegative(message){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!0,message:errorUtil2.toString(message)})}multipleOf(value,message){return this._addCheck({kind:"multipleOf",value,message:errorUtil2.toString(message)})}get minValue(){let min=null;for(let ch3 of this._def.checks)ch3.kind==="min"&&(min===null||ch3.value>min)&&(min=ch3.value);return min}get maxValue(){let max=null;for(let ch3 of this._def.checks)ch3.kind==="max"&&(max===null||ch3.value<max)&&(max=ch3.value);return max}};ZodBigInt2.create=params=>new ZodBigInt2({checks:[],typeName:ZodFirstPartyTypeKind2.ZodBigInt,coerce:params?.coerce??!1,...processCreateParams2(params)});var ZodBoolean2=class extends ZodType2{_parse(input2){if(this._def.coerce&&(input2.data=!!input2.data),this._getType(input2)!==ZodParsedType2.boolean){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.boolean,received:ctx.parsedType}),INVALID2}return OK2(input2.data)}};ZodBoolean2.create=params=>new ZodBoolean2({typeName:ZodFirstPartyTypeKind2.ZodBoolean,coerce:params?.coerce||!1,...processCreateParams2(params)});var ZodDate2=class _ZodDate extends ZodType2{_parse(input2){if(this._def.coerce&&(input2.data=new Date(input2.data)),this._getType(input2)!==ZodParsedType2.date){let ctx2=this._getOrReturnCtx(input2);return addIssueToContext2(ctx2,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.date,received:ctx2.parsedType}),INVALID2}if(Number.isNaN(input2.data.getTime())){let ctx2=this._getOrReturnCtx(input2);return addIssueToContext2(ctx2,{code:ZodIssueCode2.invalid_date}),INVALID2}let status=new ParseStatus2,ctx;for(let check of this._def.checks)check.kind==="min"?input2.data.getTime()<check.value&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,message:check.message,inclusive:!0,exact:!1,minimum:check.value,type:"date"}),status.dirty()):check.kind==="max"?input2.data.getTime()>check.value&&(ctx=this._getOrReturnCtx(input2,ctx),addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,message:check.message,inclusive:!0,exact:!1,maximum:check.value,type:"date"}),status.dirty()):util2.assertNever(check);return{status:status.value,value:new Date(input2.data.getTime())}}_addCheck(check){return new _ZodDate({...this._def,checks:[...this._def.checks,check]})}min(minDate,message){return this._addCheck({kind:"min",value:minDate.getTime(),message:errorUtil2.toString(message)})}max(maxDate,message){return this._addCheck({kind:"max",value:maxDate.getTime(),message:errorUtil2.toString(message)})}get minDate(){let min=null;for(let ch3 of this._def.checks)ch3.kind==="min"&&(min===null||ch3.value>min)&&(min=ch3.value);return min!=null?new Date(min):null}get maxDate(){let max=null;for(let ch3 of this._def.checks)ch3.kind==="max"&&(max===null||ch3.value<max)&&(max=ch3.value);return max!=null?new Date(max):null}};ZodDate2.create=params=>new ZodDate2({checks:[],coerce:params?.coerce||!1,typeName:ZodFirstPartyTypeKind2.ZodDate,...processCreateParams2(params)});var ZodSymbol2=class extends ZodType2{_parse(input2){if(this._getType(input2)!==ZodParsedType2.symbol){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.symbol,received:ctx.parsedType}),INVALID2}return OK2(input2.data)}};ZodSymbol2.create=params=>new ZodSymbol2({typeName:ZodFirstPartyTypeKind2.ZodSymbol,...processCreateParams2(params)});var ZodUndefined2=class extends ZodType2{_parse(input2){if(this._getType(input2)!==ZodParsedType2.undefined){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.undefined,received:ctx.parsedType}),INVALID2}return OK2(input2.data)}};ZodUndefined2.create=params=>new ZodUndefined2({typeName:ZodFirstPartyTypeKind2.ZodUndefined,...processCreateParams2(params)});var ZodNull2=class extends ZodType2{_parse(input2){if(this._getType(input2)!==ZodParsedType2.null){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.null,received:ctx.parsedType}),INVALID2}return OK2(input2.data)}};ZodNull2.create=params=>new ZodNull2({typeName:ZodFirstPartyTypeKind2.ZodNull,...processCreateParams2(params)});var ZodAny2=class extends ZodType2{constructor(){super(...arguments),this._any=!0}_parse(input2){return OK2(input2.data)}};ZodAny2.create=params=>new ZodAny2({typeName:ZodFirstPartyTypeKind2.ZodAny,...processCreateParams2(params)});var ZodUnknown2=class extends ZodType2{constructor(){super(...arguments),this._unknown=!0}_parse(input2){return OK2(input2.data)}};ZodUnknown2.create=params=>new ZodUnknown2({typeName:ZodFirstPartyTypeKind2.ZodUnknown,...processCreateParams2(params)});var ZodNever2=class extends ZodType2{_parse(input2){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.never,received:ctx.parsedType}),INVALID2}};ZodNever2.create=params=>new ZodNever2({typeName:ZodFirstPartyTypeKind2.ZodNever,...processCreateParams2(params)});var ZodVoid2=class extends ZodType2{_parse(input2){if(this._getType(input2)!==ZodParsedType2.undefined){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.void,received:ctx.parsedType}),INVALID2}return OK2(input2.data)}};ZodVoid2.create=params=>new ZodVoid2({typeName:ZodFirstPartyTypeKind2.ZodVoid,...processCreateParams2(params)});var ZodArray2=class _ZodArray extends ZodType2{_parse(input2){let{ctx,status}=this._processInputParams(input2),def=this._def;if(ctx.parsedType!==ZodParsedType2.array)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.array,received:ctx.parsedType}),INVALID2;if(def.exactLength!==null){let tooBig=ctx.data.length>def.exactLength.value,tooSmall=ctx.data.length<def.exactLength.value;(tooBig||tooSmall)&&(addIssueToContext2(ctx,{code:tooBig?ZodIssueCode2.too_big:ZodIssueCode2.too_small,minimum:tooSmall?def.exactLength.value:void 0,maximum:tooBig?def.exactLength.value:void 0,type:"array",inclusive:!0,exact:!0,message:def.exactLength.message}),status.dirty())}if(def.minLength!==null&&ctx.data.length<def.minLength.value&&(addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,minimum:def.minLength.value,type:"array",inclusive:!0,exact:!1,message:def.minLength.message}),status.dirty()),def.maxLength!==null&&ctx.data.length>def.maxLength.value&&(addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,maximum:def.maxLength.value,type:"array",inclusive:!0,exact:!1,message:def.maxLength.message}),status.dirty()),ctx.common.async)return Promise.all([...ctx.data].map((item,i3)=>def.type._parseAsync(new ParseInputLazyPath2(ctx,item,ctx.path,i3)))).then(result2=>ParseStatus2.mergeArray(status,result2));let result=[...ctx.data].map((item,i3)=>def.type._parseSync(new ParseInputLazyPath2(ctx,item,ctx.path,i3)));return ParseStatus2.mergeArray(status,result)}get element(){return this._def.type}min(minLength,message){return new _ZodArray({...this._def,minLength:{value:minLength,message:errorUtil2.toString(message)}})}max(maxLength,message){return new _ZodArray({...this._def,maxLength:{value:maxLength,message:errorUtil2.toString(message)}})}length(len,message){return new _ZodArray({...this._def,exactLength:{value:len,message:errorUtil2.toString(message)}})}nonempty(message){return this.min(1,message)}};ZodArray2.create=(schema,params)=>new ZodArray2({type:schema,minLength:null,maxLength:null,exactLength:null,typeName:ZodFirstPartyTypeKind2.ZodArray,...processCreateParams2(params)});function deepPartialify2(schema){if(schema instanceof ZodObject2){let newShape={};for(let key in schema.shape){let fieldSchema=schema.shape[key];newShape[key]=ZodOptional2.create(deepPartialify2(fieldSchema))}return new ZodObject2({...schema._def,shape:()=>newShape})}else return schema instanceof ZodArray2?new ZodArray2({...schema._def,type:deepPartialify2(schema.element)}):schema instanceof ZodOptional2?ZodOptional2.create(deepPartialify2(schema.unwrap())):schema instanceof ZodNullable2?ZodNullable2.create(deepPartialify2(schema.unwrap())):schema instanceof ZodTuple2?ZodTuple2.create(schema.items.map(item=>deepPartialify2(item))):schema}var ZodObject2=class _ZodObject extends ZodType2{constructor(){super(...arguments),this._cached=null,this.nonstrict=this.passthrough,this.augment=this.extend}_getCached(){if(this._cached!==null)return this._cached;let shape=this._def.shape(),keys=util2.objectKeys(shape);return this._cached={shape,keys},this._cached}_parse(input2){if(this._getType(input2)!==ZodParsedType2.object){let ctx2=this._getOrReturnCtx(input2);return addIssueToContext2(ctx2,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.object,received:ctx2.parsedType}),INVALID2}let{status,ctx}=this._processInputParams(input2),{shape,keys:shapeKeys}=this._getCached(),extraKeys=[];if(!(this._def.catchall instanceof ZodNever2&&this._def.unknownKeys==="strip"))for(let key in ctx.data)shapeKeys.includes(key)||extraKeys.push(key);let pairs22=[];for(let key of shapeKeys){let keyValidator=shape[key],value=ctx.data[key];pairs22.push({key:{status:"valid",value:key},value:keyValidator._parse(new ParseInputLazyPath2(ctx,value,ctx.path,key)),alwaysSet:key in ctx.data})}if(this._def.catchall instanceof ZodNever2){let unknownKeys=this._def.unknownKeys;if(unknownKeys==="passthrough")for(let key of extraKeys)pairs22.push({key:{status:"valid",value:key},value:{status:"valid",value:ctx.data[key]}});else if(unknownKeys==="strict")extraKeys.length>0&&(addIssueToContext2(ctx,{code:ZodIssueCode2.unrecognized_keys,keys:extraKeys}),status.dirty());else if(unknownKeys!=="strip")throw new Error("Internal ZodObject error: invalid unknownKeys value.")}else{let catchall=this._def.catchall;for(let key of extraKeys){let value=ctx.data[key];pairs22.push({key:{status:"valid",value:key},value:catchall._parse(new ParseInputLazyPath2(ctx,value,ctx.path,key)),alwaysSet:key in ctx.data})}}return ctx.common.async?Promise.resolve().then(async()=>{let syncPairs=[];for(let pair of pairs22){let key=await pair.key,value=await pair.value;syncPairs.push({key,value,alwaysSet:pair.alwaysSet})}return syncPairs}).then(syncPairs=>ParseStatus2.mergeObjectSync(status,syncPairs)):ParseStatus2.mergeObjectSync(status,pairs22)}get shape(){return this._def.shape()}strict(message){return errorUtil2.errToObj,new _ZodObject({...this._def,unknownKeys:"strict",...message!==void 0?{errorMap:(issue,ctx)=>{let defaultError=this._def.errorMap?.(issue,ctx).message??ctx.defaultError;return issue.code==="unrecognized_keys"?{message:errorUtil2.errToObj(message).message??defaultError}:{message:defaultError}}}:{}})}strip(){return new _ZodObject({...this._def,unknownKeys:"strip"})}passthrough(){return new _ZodObject({...this._def,unknownKeys:"passthrough"})}extend(augmentation){return new _ZodObject({...this._def,shape:()=>({...this._def.shape(),...augmentation})})}merge(merging){return new _ZodObject({unknownKeys:merging._def.unknownKeys,catchall:merging._def.catchall,shape:()=>({...this._def.shape(),...merging._def.shape()}),typeName:ZodFirstPartyTypeKind2.ZodObject})}setKey(key,schema){return this.augment({[key]:schema})}catchall(index){return new _ZodObject({...this._def,catchall:index})}pick(mask){let shape={};for(let key of util2.objectKeys(mask))mask[key]&&this.shape[key]&&(shape[key]=this.shape[key]);return new _ZodObject({...this._def,shape:()=>shape})}omit(mask){let shape={};for(let key of util2.objectKeys(this.shape))mask[key]||(shape[key]=this.shape[key]);return new _ZodObject({...this._def,shape:()=>shape})}deepPartial(){return deepPartialify2(this)}partial(mask){let newShape={};for(let key of util2.objectKeys(this.shape)){let fieldSchema=this.shape[key];mask&&!mask[key]?newShape[key]=fieldSchema:newShape[key]=fieldSchema.optional()}return new _ZodObject({...this._def,shape:()=>newShape})}required(mask){let newShape={};for(let key of util2.objectKeys(this.shape))if(mask&&!mask[key])newShape[key]=this.shape[key];else{let newField=this.shape[key];for(;newField instanceof ZodOptional2;)newField=newField._def.innerType;newShape[key]=newField}return new _ZodObject({...this._def,shape:()=>newShape})}keyof(){return createZodEnum2(util2.objectKeys(this.shape))}};ZodObject2.create=(shape,params)=>new ZodObject2({shape:()=>shape,unknownKeys:"strip",catchall:ZodNever2.create(),typeName:ZodFirstPartyTypeKind2.ZodObject,...processCreateParams2(params)});ZodObject2.strictCreate=(shape,params)=>new ZodObject2({shape:()=>shape,unknownKeys:"strict",catchall:ZodNever2.create(),typeName:ZodFirstPartyTypeKind2.ZodObject,...processCreateParams2(params)});ZodObject2.lazycreate=(shape,params)=>new ZodObject2({shape,unknownKeys:"strip",catchall:ZodNever2.create(),typeName:ZodFirstPartyTypeKind2.ZodObject,...processCreateParams2(params)});var ZodUnion2=class extends ZodType2{_parse(input2){let{ctx}=this._processInputParams(input2),options=this._def.options;function handleResults(results){for(let result of results)if(result.result.status==="valid")return result.result;for(let result of results)if(result.result.status==="dirty")return ctx.common.issues.push(...result.ctx.common.issues),result.result;let unionErrors=results.map(result=>new ZodError2(result.ctx.common.issues));return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_union,unionErrors}),INVALID2}if(ctx.common.async)return Promise.all(options.map(async option=>{let childCtx={...ctx,common:{...ctx.common,issues:[]},parent:null};return{result:await option._parseAsync({data:ctx.data,path:ctx.path,parent:childCtx}),ctx:childCtx}})).then(handleResults);{let dirty,issues=[];for(let option of options){let childCtx={...ctx,common:{...ctx.common,issues:[]},parent:null},result=option._parseSync({data:ctx.data,path:ctx.path,parent:childCtx});if(result.status==="valid")return result;result.status==="dirty"&&!dirty&&(dirty={result,ctx:childCtx}),childCtx.common.issues.length&&issues.push(childCtx.common.issues)}if(dirty)return ctx.common.issues.push(...dirty.ctx.common.issues),dirty.result;let unionErrors=issues.map(issues2=>new ZodError2(issues2));return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_union,unionErrors}),INVALID2}}get options(){return this._def.options}};ZodUnion2.create=(types,params)=>new ZodUnion2({options:types,typeName:ZodFirstPartyTypeKind2.ZodUnion,...processCreateParams2(params)});var getDiscriminator2=type=>type instanceof ZodLazy2?getDiscriminator2(type.schema):type instanceof ZodEffects2?getDiscriminator2(type.innerType()):type instanceof ZodLiteral2?[type.value]:type instanceof ZodEnum2?type.options:type instanceof ZodNativeEnum2?util2.objectValues(type.enum):type instanceof ZodDefault2?getDiscriminator2(type._def.innerType):type instanceof ZodUndefined2?[void 0]:type instanceof ZodNull2?[null]:type instanceof ZodOptional2?[void 0,...getDiscriminator2(type.unwrap())]:type instanceof ZodNullable2?[null,...getDiscriminator2(type.unwrap())]:type instanceof ZodBranded2||type instanceof ZodReadonly2?getDiscriminator2(type.unwrap()):type instanceof ZodCatch2?getDiscriminator2(type._def.innerType):[],ZodDiscriminatedUnion2=class _ZodDiscriminatedUnion extends ZodType2{_parse(input2){let{ctx}=this._processInputParams(input2);if(ctx.parsedType!==ZodParsedType2.object)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.object,received:ctx.parsedType}),INVALID2;let discriminator=this.discriminator,discriminatorValue=ctx.data[discriminator],option=this.optionsMap.get(discriminatorValue);return option?ctx.common.async?option._parseAsync({data:ctx.data,path:ctx.path,parent:ctx}):option._parseSync({data:ctx.data,path:ctx.path,parent:ctx}):(addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_union_discriminator,options:Array.from(this.optionsMap.keys()),path:[discriminator]}),INVALID2)}get discriminator(){return this._def.discriminator}get options(){return this._def.options}get optionsMap(){return this._def.optionsMap}static create(discriminator,options,params){let optionsMap=new Map;for(let type of options){let discriminatorValues=getDiscriminator2(type.shape[discriminator]);if(!discriminatorValues.length)throw new Error(`A discriminator value for key \`${discriminator}\` could not be extracted from all schema options`);for(let value of discriminatorValues){if(optionsMap.has(value))throw new Error(`Discriminator property ${String(discriminator)} has duplicate value ${String(value)}`);optionsMap.set(value,type)}}return new _ZodDiscriminatedUnion({typeName:ZodFirstPartyTypeKind2.ZodDiscriminatedUnion,discriminator,options,optionsMap,...processCreateParams2(params)})}};function mergeValues2(a3,b3){let aType=getParsedType2(a3),bType=getParsedType2(b3);if(a3===b3)return{valid:!0,data:a3};if(aType===ZodParsedType2.object&&bType===ZodParsedType2.object){let bKeys=util2.objectKeys(b3),sharedKeys=util2.objectKeys(a3).filter(key=>bKeys.indexOf(key)!==-1),newObj={...a3,...b3};for(let key of sharedKeys){let sharedValue=mergeValues2(a3[key],b3[key]);if(!sharedValue.valid)return{valid:!1};newObj[key]=sharedValue.data}return{valid:!0,data:newObj}}else if(aType===ZodParsedType2.array&&bType===ZodParsedType2.array){if(a3.length!==b3.length)return{valid:!1};let newArray=[];for(let index=0;index<a3.length;index++){let itemA=a3[index],itemB=b3[index],sharedValue=mergeValues2(itemA,itemB);if(!sharedValue.valid)return{valid:!1};newArray.push(sharedValue.data)}return{valid:!0,data:newArray}}else return aType===ZodParsedType2.date&&bType===ZodParsedType2.date&&+a3==+b3?{valid:!0,data:a3}:{valid:!1}}var ZodIntersection2=class extends ZodType2{_parse(input2){let{status,ctx}=this._processInputParams(input2),handleParsed=(parsedLeft,parsedRight)=>{if(isAborted2(parsedLeft)||isAborted2(parsedRight))return INVALID2;let merged=mergeValues2(parsedLeft.value,parsedRight.value);return merged.valid?((isDirty2(parsedLeft)||isDirty2(parsedRight))&&status.dirty(),{status:status.value,value:merged.data}):(addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_intersection_types}),INVALID2)};return ctx.common.async?Promise.all([this._def.left._parseAsync({data:ctx.data,path:ctx.path,parent:ctx}),this._def.right._parseAsync({data:ctx.data,path:ctx.path,parent:ctx})]).then(([left,right])=>handleParsed(left,right)):handleParsed(this._def.left._parseSync({data:ctx.data,path:ctx.path,parent:ctx}),this._def.right._parseSync({data:ctx.data,path:ctx.path,parent:ctx}))}};ZodIntersection2.create=(left,right,params)=>new ZodIntersection2({left,right,typeName:ZodFirstPartyTypeKind2.ZodIntersection,...processCreateParams2(params)});var ZodTuple2=class _ZodTuple extends ZodType2{_parse(input2){let{status,ctx}=this._processInputParams(input2);if(ctx.parsedType!==ZodParsedType2.array)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.array,received:ctx.parsedType}),INVALID2;if(ctx.data.length<this._def.items.length)return addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,minimum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),INVALID2;!this._def.rest&&ctx.data.length>this._def.items.length&&(addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,maximum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),status.dirty());let items=[...ctx.data].map((item,itemIndex)=>{let schema=this._def.items[itemIndex]||this._def.rest;return schema?schema._parse(new ParseInputLazyPath2(ctx,item,ctx.path,itemIndex)):null}).filter(x4=>!!x4);return ctx.common.async?Promise.all(items).then(results=>ParseStatus2.mergeArray(status,results)):ParseStatus2.mergeArray(status,items)}get items(){return this._def.items}rest(rest){return new _ZodTuple({...this._def,rest})}};ZodTuple2.create=(schemas,params)=>{if(!Array.isArray(schemas))throw new Error("You must pass an array of schemas to z.tuple([ ... ])");return new ZodTuple2({items:schemas,typeName:ZodFirstPartyTypeKind2.ZodTuple,rest:null,...processCreateParams2(params)})};var ZodRecord2=class _ZodRecord extends ZodType2{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(input2){let{status,ctx}=this._processInputParams(input2);if(ctx.parsedType!==ZodParsedType2.object)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.object,received:ctx.parsedType}),INVALID2;let pairs22=[],keyType=this._def.keyType,valueType=this._def.valueType;for(let key in ctx.data)pairs22.push({key:keyType._parse(new ParseInputLazyPath2(ctx,key,ctx.path,key)),value:valueType._parse(new ParseInputLazyPath2(ctx,ctx.data[key],ctx.path,key)),alwaysSet:key in ctx.data});return ctx.common.async?ParseStatus2.mergeObjectAsync(status,pairs22):ParseStatus2.mergeObjectSync(status,pairs22)}get element(){return this._def.valueType}static create(first,second,third){return second instanceof ZodType2?new _ZodRecord({keyType:first,valueType:second,typeName:ZodFirstPartyTypeKind2.ZodRecord,...processCreateParams2(third)}):new _ZodRecord({keyType:ZodString2.create(),valueType:first,typeName:ZodFirstPartyTypeKind2.ZodRecord,...processCreateParams2(second)})}},ZodMap2=class extends ZodType2{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(input2){let{status,ctx}=this._processInputParams(input2);if(ctx.parsedType!==ZodParsedType2.map)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.map,received:ctx.parsedType}),INVALID2;let keyType=this._def.keyType,valueType=this._def.valueType,pairs22=[...ctx.data.entries()].map(([key,value],index)=>({key:keyType._parse(new ParseInputLazyPath2(ctx,key,ctx.path,[index,"key"])),value:valueType._parse(new ParseInputLazyPath2(ctx,value,ctx.path,[index,"value"]))}));if(ctx.common.async){let finalMap=new Map;return Promise.resolve().then(async()=>{for(let pair of pairs22){let key=await pair.key,value=await pair.value;if(key.status==="aborted"||value.status==="aborted")return INVALID2;(key.status==="dirty"||value.status==="dirty")&&status.dirty(),finalMap.set(key.value,value.value)}return{status:status.value,value:finalMap}})}else{let finalMap=new Map;for(let pair of pairs22){let key=pair.key,value=pair.value;if(key.status==="aborted"||value.status==="aborted")return INVALID2;(key.status==="dirty"||value.status==="dirty")&&status.dirty(),finalMap.set(key.value,value.value)}return{status:status.value,value:finalMap}}}};ZodMap2.create=(keyType,valueType,params)=>new ZodMap2({valueType,keyType,typeName:ZodFirstPartyTypeKind2.ZodMap,...processCreateParams2(params)});var ZodSet2=class _ZodSet extends ZodType2{_parse(input2){let{status,ctx}=this._processInputParams(input2);if(ctx.parsedType!==ZodParsedType2.set)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.set,received:ctx.parsedType}),INVALID2;let def=this._def;def.minSize!==null&&ctx.data.size<def.minSize.value&&(addIssueToContext2(ctx,{code:ZodIssueCode2.too_small,minimum:def.minSize.value,type:"set",inclusive:!0,exact:!1,message:def.minSize.message}),status.dirty()),def.maxSize!==null&&ctx.data.size>def.maxSize.value&&(addIssueToContext2(ctx,{code:ZodIssueCode2.too_big,maximum:def.maxSize.value,type:"set",inclusive:!0,exact:!1,message:def.maxSize.message}),status.dirty());let valueType=this._def.valueType;function finalizeSet(elements2){let parsedSet=new Set;for(let element of elements2){if(element.status==="aborted")return INVALID2;element.status==="dirty"&&status.dirty(),parsedSet.add(element.value)}return{status:status.value,value:parsedSet}}let elements=[...ctx.data.values()].map((item,i3)=>valueType._parse(new ParseInputLazyPath2(ctx,item,ctx.path,i3)));return ctx.common.async?Promise.all(elements).then(elements2=>finalizeSet(elements2)):finalizeSet(elements)}min(minSize,message){return new _ZodSet({...this._def,minSize:{value:minSize,message:errorUtil2.toString(message)}})}max(maxSize,message){return new _ZodSet({...this._def,maxSize:{value:maxSize,message:errorUtil2.toString(message)}})}size(size22,message){return this.min(size22,message).max(size22,message)}nonempty(message){return this.min(1,message)}};ZodSet2.create=(valueType,params)=>new ZodSet2({valueType,minSize:null,maxSize:null,typeName:ZodFirstPartyTypeKind2.ZodSet,...processCreateParams2(params)});var ZodFunction2=class _ZodFunction extends ZodType2{constructor(){super(...arguments),this.validate=this.implement}_parse(input2){let{ctx}=this._processInputParams(input2);if(ctx.parsedType!==ZodParsedType2.function)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.function,received:ctx.parsedType}),INVALID2;function makeArgsIssue(args,error2){return makeIssue2({data:args,path:ctx.path,errorMaps:[ctx.common.contextualErrorMap,ctx.schemaErrorMap,getErrorMap2(),en_default2].filter(x4=>!!x4),issueData:{code:ZodIssueCode2.invalid_arguments,argumentsError:error2}})}function makeReturnsIssue(returns,error2){return makeIssue2({data:returns,path:ctx.path,errorMaps:[ctx.common.contextualErrorMap,ctx.schemaErrorMap,getErrorMap2(),en_default2].filter(x4=>!!x4),issueData:{code:ZodIssueCode2.invalid_return_type,returnTypeError:error2}})}let params={errorMap:ctx.common.contextualErrorMap},fn3=ctx.data;if(this._def.returns instanceof ZodPromise2){let me3=this;return OK2(async function(...args){let error2=new ZodError2([]),parsedArgs=await me3._def.args.parseAsync(args,params).catch(e5=>{throw error2.addIssue(makeArgsIssue(args,e5)),error2}),result=await Reflect.apply(fn3,this,parsedArgs);return await me3._def.returns._def.type.parseAsync(result,params).catch(e5=>{throw error2.addIssue(makeReturnsIssue(result,e5)),error2})})}else{let me3=this;return OK2(function(...args){let parsedArgs=me3._def.args.safeParse(args,params);if(!parsedArgs.success)throw new ZodError2([makeArgsIssue(args,parsedArgs.error)]);let result=Reflect.apply(fn3,this,parsedArgs.data),parsedReturns=me3._def.returns.safeParse(result,params);if(!parsedReturns.success)throw new ZodError2([makeReturnsIssue(result,parsedReturns.error)]);return parsedReturns.data})}}parameters(){return this._def.args}returnType(){return this._def.returns}args(...items){return new _ZodFunction({...this._def,args:ZodTuple2.create(items).rest(ZodUnknown2.create())})}returns(returnType){return new _ZodFunction({...this._def,returns:returnType})}implement(func){return this.parse(func)}strictImplement(func){return this.parse(func)}static create(args,returns,params){return new _ZodFunction({args:args||ZodTuple2.create([]).rest(ZodUnknown2.create()),returns:returns||ZodUnknown2.create(),typeName:ZodFirstPartyTypeKind2.ZodFunction,...processCreateParams2(params)})}},ZodLazy2=class extends ZodType2{get schema(){return this._def.getter()}_parse(input2){let{ctx}=this._processInputParams(input2);return this._def.getter()._parse({data:ctx.data,path:ctx.path,parent:ctx})}};ZodLazy2.create=(getter,params)=>new ZodLazy2({getter,typeName:ZodFirstPartyTypeKind2.ZodLazy,...processCreateParams2(params)});var ZodLiteral2=class extends ZodType2{_parse(input2){if(input2.data!==this._def.value){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{received:ctx.data,code:ZodIssueCode2.invalid_literal,expected:this._def.value}),INVALID2}return{status:"valid",value:input2.data}}get value(){return this._def.value}};ZodLiteral2.create=(value,params)=>new ZodLiteral2({value,typeName:ZodFirstPartyTypeKind2.ZodLiteral,...processCreateParams2(params)});function createZodEnum2(values,params){return new ZodEnum2({values,typeName:ZodFirstPartyTypeKind2.ZodEnum,...processCreateParams2(params)})}var ZodEnum2=class _ZodEnum extends ZodType2{_parse(input2){if(typeof input2.data!="string"){let ctx=this._getOrReturnCtx(input2),expectedValues=this._def.values;return addIssueToContext2(ctx,{expected:util2.joinValues(expectedValues),received:ctx.parsedType,code:ZodIssueCode2.invalid_type}),INVALID2}if(this._cache||(this._cache=new Set(this._def.values)),!this._cache.has(input2.data)){let ctx=this._getOrReturnCtx(input2),expectedValues=this._def.values;return addIssueToContext2(ctx,{received:ctx.data,code:ZodIssueCode2.invalid_enum_value,options:expectedValues}),INVALID2}return OK2(input2.data)}get options(){return this._def.values}get enum(){let enumValues={};for(let val of this._def.values)enumValues[val]=val;return enumValues}get Values(){let enumValues={};for(let val of this._def.values)enumValues[val]=val;return enumValues}get Enum(){let enumValues={};for(let val of this._def.values)enumValues[val]=val;return enumValues}extract(values,newDef=this._def){return _ZodEnum.create(values,{...this._def,...newDef})}exclude(values,newDef=this._def){return _ZodEnum.create(this.options.filter(opt2=>!values.includes(opt2)),{...this._def,...newDef})}};ZodEnum2.create=createZodEnum2;var ZodNativeEnum2=class extends ZodType2{_parse(input2){let nativeEnumValues=util2.getValidEnumValues(this._def.values),ctx=this._getOrReturnCtx(input2);if(ctx.parsedType!==ZodParsedType2.string&&ctx.parsedType!==ZodParsedType2.number){let expectedValues=util2.objectValues(nativeEnumValues);return addIssueToContext2(ctx,{expected:util2.joinValues(expectedValues),received:ctx.parsedType,code:ZodIssueCode2.invalid_type}),INVALID2}if(this._cache||(this._cache=new Set(util2.getValidEnumValues(this._def.values))),!this._cache.has(input2.data)){let expectedValues=util2.objectValues(nativeEnumValues);return addIssueToContext2(ctx,{received:ctx.data,code:ZodIssueCode2.invalid_enum_value,options:expectedValues}),INVALID2}return OK2(input2.data)}get enum(){return this._def.values}};ZodNativeEnum2.create=(values,params)=>new ZodNativeEnum2({values,typeName:ZodFirstPartyTypeKind2.ZodNativeEnum,...processCreateParams2(params)});var ZodPromise2=class extends ZodType2{unwrap(){return this._def.type}_parse(input2){let{ctx}=this._processInputParams(input2);if(ctx.parsedType!==ZodParsedType2.promise&&ctx.common.async===!1)return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.promise,received:ctx.parsedType}),INVALID2;let promisified=ctx.parsedType===ZodParsedType2.promise?ctx.data:Promise.resolve(ctx.data);return OK2(promisified.then(data=>this._def.type.parseAsync(data,{path:ctx.path,errorMap:ctx.common.contextualErrorMap})))}};ZodPromise2.create=(schema,params)=>new ZodPromise2({type:schema,typeName:ZodFirstPartyTypeKind2.ZodPromise,...processCreateParams2(params)});var ZodEffects2=class extends ZodType2{innerType(){return this._def.schema}sourceType(){return this._def.schema._def.typeName===ZodFirstPartyTypeKind2.ZodEffects?this._def.schema.sourceType():this._def.schema}_parse(input2){let{status,ctx}=this._processInputParams(input2),effect=this._def.effect||null,checkCtx={addIssue:arg=>{addIssueToContext2(ctx,arg),arg.fatal?status.abort():status.dirty()},get path(){return ctx.path}};if(checkCtx.addIssue=checkCtx.addIssue.bind(checkCtx),effect.type==="preprocess"){let processed=effect.transform(ctx.data,checkCtx);if(ctx.common.async)return Promise.resolve(processed).then(async processed2=>{if(status.value==="aborted")return INVALID2;let result=await this._def.schema._parseAsync({data:processed2,path:ctx.path,parent:ctx});return result.status==="aborted"?INVALID2:result.status==="dirty"||status.value==="dirty"?DIRTY2(result.value):result});{if(status.value==="aborted")return INVALID2;let result=this._def.schema._parseSync({data:processed,path:ctx.path,parent:ctx});return result.status==="aborted"?INVALID2:result.status==="dirty"||status.value==="dirty"?DIRTY2(result.value):result}}if(effect.type==="refinement"){let executeRefinement=acc=>{let result=effect.refinement(acc,checkCtx);if(ctx.common.async)return Promise.resolve(result);if(result instanceof Promise)throw new Error("Async refinement encountered during synchronous parse operation. Use .parseAsync instead.");return acc};if(ctx.common.async===!1){let inner=this._def.schema._parseSync({data:ctx.data,path:ctx.path,parent:ctx});return inner.status==="aborted"?INVALID2:(inner.status==="dirty"&&status.dirty(),executeRefinement(inner.value),{status:status.value,value:inner.value})}else return this._def.schema._parseAsync({data:ctx.data,path:ctx.path,parent:ctx}).then(inner=>inner.status==="aborted"?INVALID2:(inner.status==="dirty"&&status.dirty(),executeRefinement(inner.value).then(()=>({status:status.value,value:inner.value}))))}if(effect.type==="transform")if(ctx.common.async===!1){let base=this._def.schema._parseSync({data:ctx.data,path:ctx.path,parent:ctx});if(!isValid2(base))return INVALID2;let result=effect.transform(base.value,checkCtx);if(result instanceof Promise)throw new Error("Asynchronous transform encountered during synchronous parse operation. Use .parseAsync instead.");return{status:status.value,value:result}}else return this._def.schema._parseAsync({data:ctx.data,path:ctx.path,parent:ctx}).then(base=>isValid2(base)?Promise.resolve(effect.transform(base.value,checkCtx)).then(result=>({status:status.value,value:result})):INVALID2);util2.assertNever(effect)}};ZodEffects2.create=(schema,effect,params)=>new ZodEffects2({schema,typeName:ZodFirstPartyTypeKind2.ZodEffects,effect,...processCreateParams2(params)});ZodEffects2.createWithPreprocess=(preprocess,schema,params)=>new ZodEffects2({schema,effect:{type:"preprocess",transform:preprocess},typeName:ZodFirstPartyTypeKind2.ZodEffects,...processCreateParams2(params)});var ZodOptional2=class extends ZodType2{_parse(input2){return this._getType(input2)===ZodParsedType2.undefined?OK2(void 0):this._def.innerType._parse(input2)}unwrap(){return this._def.innerType}};ZodOptional2.create=(type,params)=>new ZodOptional2({innerType:type,typeName:ZodFirstPartyTypeKind2.ZodOptional,...processCreateParams2(params)});var ZodNullable2=class extends ZodType2{_parse(input2){return this._getType(input2)===ZodParsedType2.null?OK2(null):this._def.innerType._parse(input2)}unwrap(){return this._def.innerType}};ZodNullable2.create=(type,params)=>new ZodNullable2({innerType:type,typeName:ZodFirstPartyTypeKind2.ZodNullable,...processCreateParams2(params)});var ZodDefault2=class extends ZodType2{_parse(input2){let{ctx}=this._processInputParams(input2),data=ctx.data;return ctx.parsedType===ZodParsedType2.undefined&&(data=this._def.defaultValue()),this._def.innerType._parse({data,path:ctx.path,parent:ctx})}removeDefault(){return this._def.innerType}};ZodDefault2.create=(type,params)=>new ZodDefault2({innerType:type,typeName:ZodFirstPartyTypeKind2.ZodDefault,defaultValue:typeof params.default=="function"?params.default:()=>params.default,...processCreateParams2(params)});var ZodCatch2=class extends ZodType2{_parse(input2){let{ctx}=this._processInputParams(input2),newCtx={...ctx,common:{...ctx.common,issues:[]}},result=this._def.innerType._parse({data:newCtx.data,path:newCtx.path,parent:{...newCtx}});return isAsync2(result)?result.then(result2=>({status:"valid",value:result2.status==="valid"?result2.value:this._def.catchValue({get error(){return new ZodError2(newCtx.common.issues)},input:newCtx.data})})):{status:"valid",value:result.status==="valid"?result.value:this._def.catchValue({get error(){return new ZodError2(newCtx.common.issues)},input:newCtx.data})}}removeCatch(){return this._def.innerType}};ZodCatch2.create=(type,params)=>new ZodCatch2({innerType:type,typeName:ZodFirstPartyTypeKind2.ZodCatch,catchValue:typeof params.catch=="function"?params.catch:()=>params.catch,...processCreateParams2(params)});var ZodNaN2=class extends ZodType2{_parse(input2){if(this._getType(input2)!==ZodParsedType2.nan){let ctx=this._getOrReturnCtx(input2);return addIssueToContext2(ctx,{code:ZodIssueCode2.invalid_type,expected:ZodParsedType2.nan,received:ctx.parsedType}),INVALID2}return{status:"valid",value:input2.data}}};ZodNaN2.create=params=>new ZodNaN2({typeName:ZodFirstPartyTypeKind2.ZodNaN,...processCreateParams2(params)});var BRAND2=Symbol("zod_brand"),ZodBranded2=class extends ZodType2{_parse(input2){let{ctx}=this._processInputParams(input2),data=ctx.data;return this._def.type._parse({data,path:ctx.path,parent:ctx})}unwrap(){return this._def.type}},ZodPipeline2=class _ZodPipeline extends ZodType2{_parse(input2){let{status,ctx}=this._processInputParams(input2);if(ctx.common.async)return(async()=>{let inResult=await this._def.in._parseAsync({data:ctx.data,path:ctx.path,parent:ctx});return inResult.status==="aborted"?INVALID2:inResult.status==="dirty"?(status.dirty(),DIRTY2(inResult.value)):this._def.out._parseAsync({data:inResult.value,path:ctx.path,parent:ctx})})();{let inResult=this._def.in._parseSync({data:ctx.data,path:ctx.path,parent:ctx});return inResult.status==="aborted"?INVALID2:inResult.status==="dirty"?(status.dirty(),{status:"dirty",value:inResult.value}):this._def.out._parseSync({data:inResult.value,path:ctx.path,parent:ctx})}}static create(a3,b3){return new _ZodPipeline({in:a3,out:b3,typeName:ZodFirstPartyTypeKind2.ZodPipeline})}},ZodReadonly2=class extends ZodType2{_parse(input2){let result=this._def.innerType._parse(input2),freeze=data=>(isValid2(data)&&(data.value=Object.freeze(data.value)),data);return isAsync2(result)?result.then(data=>freeze(data)):freeze(result)}unwrap(){return this._def.innerType}};ZodReadonly2.create=(type,params)=>new ZodReadonly2({innerType:type,typeName:ZodFirstPartyTypeKind2.ZodReadonly,...processCreateParams2(params)});function cleanParams2(params,data){let p4=typeof params=="function"?params(data):typeof params=="string"?{message:params}:params;return typeof p4=="string"?{message:p4}:p4}function custom2(check,_params={},fatal){return check?ZodAny2.create().superRefine((data,ctx)=>{let r5=check(data);if(r5 instanceof Promise)return r5.then(r22=>{if(!r22){let params=cleanParams2(_params,data),_fatal=params.fatal??fatal??!0;ctx.addIssue({code:"custom",...params,fatal:_fatal})}});if(!r5){let params=cleanParams2(_params,data),_fatal=params.fatal??fatal??!0;ctx.addIssue({code:"custom",...params,fatal:_fatal})}}):ZodAny2.create()}var late2={object:ZodObject2.lazycreate},ZodFirstPartyTypeKind2;(function(ZodFirstPartyTypeKind22){ZodFirstPartyTypeKind22.ZodString="ZodString",ZodFirstPartyTypeKind22.ZodNumber="ZodNumber",ZodFirstPartyTypeKind22.ZodNaN="ZodNaN",ZodFirstPartyTypeKind22.ZodBigInt="ZodBigInt",ZodFirstPartyTypeKind22.ZodBoolean="ZodBoolean",ZodFirstPartyTypeKind22.ZodDate="ZodDate",ZodFirstPartyTypeKind22.ZodSymbol="ZodSymbol",ZodFirstPartyTypeKind22.ZodUndefined="ZodUndefined",ZodFirstPartyTypeKind22.ZodNull="ZodNull",ZodFirstPartyTypeKind22.ZodAny="ZodAny",ZodFirstPartyTypeKind22.ZodUnknown="ZodUnknown",ZodFirstPartyTypeKind22.ZodNever="ZodNever",ZodFirstPartyTypeKind22.ZodVoid="ZodVoid",ZodFirstPartyTypeKind22.ZodArray="ZodArray",ZodFirstPartyTypeKind22.ZodObject="ZodObject",ZodFirstPartyTypeKind22.ZodUnion="ZodUnion",ZodFirstPartyTypeKind22.ZodDiscriminatedUnion="ZodDiscriminatedUnion",ZodFirstPartyTypeKind22.ZodIntersection="ZodIntersection",ZodFirstPartyTypeKind22.ZodTuple="ZodTuple",ZodFirstPartyTypeKind22.ZodRecord="ZodRecord",ZodFirstPartyTypeKind22.ZodMap="ZodMap",ZodFirstPartyTypeKind22.ZodSet="ZodSet",ZodFirstPartyTypeKind22.ZodFunction="ZodFunction",ZodFirstPartyTypeKind22.ZodLazy="ZodLazy",ZodFirstPartyTypeKind22.ZodLiteral="ZodLiteral",ZodFirstPartyTypeKind22.ZodEnum="ZodEnum",ZodFirstPartyTypeKind22.ZodEffects="ZodEffects",ZodFirstPartyTypeKind22.ZodNativeEnum="ZodNativeEnum",ZodFirstPartyTypeKind22.ZodOptional="ZodOptional",ZodFirstPartyTypeKind22.ZodNullable="ZodNullable",ZodFirstPartyTypeKind22.ZodDefault="ZodDefault",ZodFirstPartyTypeKind22.ZodCatch="ZodCatch",ZodFirstPartyTypeKind22.ZodPromise="ZodPromise",ZodFirstPartyTypeKind22.ZodBranded="ZodBranded",ZodFirstPartyTypeKind22.ZodPipeline="ZodPipeline",ZodFirstPartyTypeKind22.ZodReadonly="ZodReadonly"})(ZodFirstPartyTypeKind2||(ZodFirstPartyTypeKind2={}));var instanceOfType2=(cls,params={message:`Input not instance of ${cls.name}`})=>custom2(data=>data instanceof cls,params),stringType2=ZodString2.create,numberType2=ZodNumber2.create,nanType2=ZodNaN2.create,bigIntType2=ZodBigInt2.create,booleanType2=ZodBoolean2.create,dateType2=ZodDate2.create,symbolType2=ZodSymbol2.create,undefinedType2=ZodUndefined2.create,nullType2=ZodNull2.create,anyType2=ZodAny2.create,unknownType2=ZodUnknown2.create,neverType2=ZodNever2.create,voidType2=ZodVoid2.create,arrayType2=ZodArray2.create,objectType2=ZodObject2.create,strictObjectType2=ZodObject2.strictCreate,unionType2=ZodUnion2.create,discriminatedUnionType2=ZodDiscriminatedUnion2.create,intersectionType2=ZodIntersection2.create,tupleType2=ZodTuple2.create,recordType2=ZodRecord2.create,mapType2=ZodMap2.create,setType2=ZodSet2.create,functionType2=ZodFunction2.create,lazyType2=ZodLazy2.create,literalType2=ZodLiteral2.create,enumType2=ZodEnum2.create,nativeEnumType2=ZodNativeEnum2.create,promiseType2=ZodPromise2.create,effectsType2=ZodEffects2.create,optionalType2=ZodOptional2.create,nullableType2=ZodNullable2.create,preprocessType2=ZodEffects2.createWithPreprocess,pipelineType2=ZodPipeline2.create,ostring2=()=>stringType2().optional(),onumber2=()=>numberType2().optional(),oboolean2=()=>booleanType2().optional(),coerce2={string:arg=>ZodString2.create({...arg,coerce:!0}),number:arg=>ZodNumber2.create({...arg,coerce:!0}),boolean:arg=>ZodBoolean2.create({...arg,coerce:!0}),bigint:arg=>ZodBigInt2.create({...arg,coerce:!0}),date:arg=>ZodDate2.create({...arg,coerce:!0})},NEVER2=INVALID2,unitMappings2={Hz:{baseUnit:"Hz",variants:{MHz:1e6,kHz:1e3,Hz:1}},g:{baseUnit:"g",variants:{kg:1e3,g:1}},\u03A9:{baseUnit:"\u03A9",variants:{m\u03A9:.001,\u03A9:1,k\u03A9:1e3,K\u03A9:1e3,kohm:1e3,M\u03A9:1e6,G\u03A9:1e9,T\u03A9:1e12}},V:{baseUnit:"V",variants:{mV:.001,V:1,kV:1e3,KV:1e3,MV:1e6,GV:1e9,TV:1e12}},A:{baseUnit:"A",variants:{\u00B5A:1e-6,mA:.001,ma:.001,A:1,kA:1e3,MA:1e6}},F:{baseUnit:"F",variants:{pF:1e-12,nF:1e-9,\u00B5F:1e-6,uF:1e-6,mF:.001,F:1}},ml:{baseUnit:"ml",variants:{ml:1,mL:1,l:1e3,L:1e3}},deg:{baseUnit:"deg",variants:{rad:180/Math.PI}},ms:{baseUnit:"ms",variants:{fs:1e-12,ps:1e-9,ns:1e-6,us:.001,\u00B5s:.001,ms:1,s:1e3}},mm:{baseUnit:"mm",variants:{nm:1e-6,\u00B5m:.001,um:.001,mm:1,cm:10,dm:100,m:1e3,km:1e6,in:25.4,ft:304.8,IN:25.4,FT:304.8,yd:914.4,mi:1609344,mil:.0254}}},unitMappingAndVariantSuffixes2=new Set;for(let[baseUnit,info]of Object.entries(unitMappings2)){unitMappingAndVariantSuffixes2.add(baseUnit);for(let variant of Object.keys(info.variants))unitMappingAndVariantSuffixes2.add(variant)}function getBaseTscircuitUnit2(unit){for(let[baseUnit,info]of Object.entries(unitMappings2))if(unit in info.variants)return{baseUnit:info.baseUnit,conversionFactor:info.variants[unit]};return{baseUnit:unit,conversionFactor:1}}var si_prefix_multiplier2={tera:1e12,T:1e12,giga:1e9,G:1e9,mega:1e6,M:1e6,kilo:1e3,k:1e3,deci:.1,d:.1,centi:.01,c:.01,milli:.001,m:.001,micro:1e-6,u:1e-6,\u00B5:1e-6,nano:1e-9,n:1e-9,pico:1e-12,p:1e-12};function parseAndConvertSiUnit2(v4){if(v4==null)return{parsedUnit:null,unitOfValue:null,value:null};if(typeof v4=="string"&&v4.match(/^-?[\d\.]+$/))return{value:Number.parseFloat(v4),parsedUnit:null,unitOfValue:null};if(typeof v4=="number")return{value:v4,parsedUnit:null,unitOfValue:null};if(typeof v4=="object"&&"x"in v4&&"y"in v4){let{parsedUnit,unitOfValue}=parseAndConvertSiUnit2(v4.x),xResult=parseAndConvertSiUnit2(v4.x),yResult=parseAndConvertSiUnit2(v4.y);return xResult.value===null||yResult.value===null?{parsedUnit:null,unitOfValue:null,value:null}:{parsedUnit,unitOfValue,value:{x:xResult.value,y:yResult.value}}}let unit_reversed=v4.toString().split("").reverse().join("").match(/[^\d\s]+/)?.[0];if(!unit_reversed)throw new Error(`Could not determine unit: "${v4}"`);let unit=unit_reversed.split("").reverse().join(""),numberPart=v4.slice(0,-unit.length);if(unit in si_prefix_multiplier2&&!unitMappingAndVariantSuffixes2.has(unit)){let siMultiplier=si_prefix_multiplier2[unit];return{parsedUnit:null,unitOfValue:null,value:Number.parseFloat(numberPart)*siMultiplier}}let{baseUnit,conversionFactor}=getBaseTscircuitUnit2(unit);return{parsedUnit:unit,unitOfValue:baseUnit,value:conversionFactor*Number.parseFloat(numberPart)}}var resistance2=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value),capacitance2=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value).transform(value=>Number.parseFloat(value.toPrecision(12))),inductance2=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value),voltage2=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value),length3=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value),frequency2=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value),distance7=length3,current2=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value),duration_ms2=external_exports2.string().or(external_exports2.number()).transform(v4=>parseAndConvertSiUnit2(v4).value),time2=duration_ms2,ms4=duration_ms2,timestamp2=external_exports2.string().datetime(),rotation4=external_exports2.string().or(external_exports2.number()).transform(arg=>typeof arg=="number"?arg:arg.endsWith("deg")?Number.parseFloat(arg.split("deg")[0]):arg.endsWith("rad")?Number.parseFloat(arg.split("rad")[0])*180/Math.PI:Number.parseFloat(arg)),battery_capacity2=external_exports2.number().or(external_exports2.string().endsWith("mAh")).transform(v4=>{if(typeof v4=="string"){let valString=v4.replace("mAh",""),num=Number.parseFloat(valString);if(Number.isNaN(num))throw new Error("Invalid capacity");return num}return v4}).describe("Battery capacity in mAh"),expectTypesMatch3=shouldBe=>{};expectTypesMatch3("extra props b");expectTypesMatch3("missing props b");expectTypesMatch3(!0);expectTypesMatch3("mismatched prop types: a");var expectStringUnionsMatch2=shouldBe=>{};expectStringUnionsMatch2(!0);expectStringUnionsMatch2('T1 has extra: "c", T2 has extra: "d"');expectStringUnionsMatch2('T1 has extra: "c"');expectStringUnionsMatch2('T2 has extra: "c"');expectStringUnionsMatch2('T1 has extra: "d", T2 has extra: "c"');expectStringUnionsMatch2(!0);var point5=external_exports2.object({x:distance7,y:distance7}),position2=point5;expectTypesMatch3(!0);expectTypesMatch3(!0);var point33=external_exports2.object({x:distance7,y:distance7,z:distance7}),position32=point33;expectTypesMatch3(!0);var size2=external_exports2.object({width:external_exports2.number(),height:external_exports2.number()});expectTypesMatch3(!0);var randomId2=length4=>{let chars2="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";return Array.from({length:length4},()=>chars2[Math.floor(Math.random()*chars2.length)]).join("")},getZodPrefixedIdWithDefault2=prefix=>external_exports2.string().optional().default(()=>`${prefix}_${randomId2(10)}`),ninePointAnchor3=external_exports2.enum(["top_left","top_center","top_right","center_left","center","center_right","bottom_left","bottom_center","bottom_right"]);expectTypesMatch3(!0);var pcbRenderLayer2=external_exports2.enum(["top_silkscreen","bottom_silkscreen","top_copper","bottom_copper","top_soldermask","bottom_soldermask","top_fabrication_note","bottom_fabrication_note","top_user_note","bottom_user_note","top_courtyard","bottom_courtyard","inner1_copper","inner2_copper","inner3_copper","inner4_copper","inner5_copper","inner6_copper","edge_cuts","drill"]);expectTypesMatch3(!0);var asset2=external_exports2.object({project_relative_path:external_exports2.string(),url:external_exports2.string(),mimetype:external_exports2.string()});expectTypesMatch3(!0);var kicadAt3=point5.extend({rotation:rotation4.optional()});expectTypesMatch3(!0);var kicadFont3=external_exports2.object({size:point5.optional(),thickness:distance7.optional()});expectTypesMatch3(!0);var kicadEffects3=external_exports2.object({font:kicadFont3.optional()});expectTypesMatch3(!0);var kicadProperty3=external_exports2.object({value:external_exports2.string(),at:kicadAt3.optional(),layer:external_exports2.string().optional(),uuid:external_exports2.string().optional(),hide:external_exports2.boolean().optional(),effects:kicadEffects3.optional()});expectTypesMatch3(!0);var kicadFootprintProperties3=external_exports2.object({Reference:kicadProperty3.optional(),Value:kicadProperty3.optional(),Datasheet:kicadProperty3.optional(),Description:kicadProperty3.optional()});expectTypesMatch3(!0);var kicadFootprintAttributes3=external_exports2.object({through_hole:external_exports2.boolean().optional(),smd:external_exports2.boolean().optional(),exclude_from_pos_files:external_exports2.boolean().optional(),exclude_from_bom:external_exports2.boolean().optional()});expectTypesMatch3(!0);var kicadFootprintPad3=external_exports2.object({name:external_exports2.string(),type:external_exports2.string(),shape:external_exports2.string().optional(),at:kicadAt3.optional(),size:point5.optional(),drill:distance7.optional(),layers:external_exports2.array(external_exports2.string()).optional(),removeUnusedLayers:external_exports2.boolean().optional(),uuid:external_exports2.string().optional()});expectTypesMatch3(!0);var kicadFootprintModel3=external_exports2.object({path:external_exports2.string(),offset:point33.optional(),scale:point33.optional(),rotate:point33.optional()});expectTypesMatch3(!0);var kicadFootprintMetadata3=external_exports2.object({footprintName:external_exports2.string().optional(),version:external_exports2.union([external_exports2.number(),external_exports2.string()]).optional(),generator:external_exports2.string().optional(),generatorVersion:external_exports2.union([external_exports2.number(),external_exports2.string()]).optional(),layer:external_exports2.string().optional(),properties:kicadFootprintProperties3.optional(),attributes:kicadFootprintAttributes3.optional(),pads:external_exports2.array(kicadFootprintPad3).optional(),embeddedFonts:external_exports2.boolean().optional(),model:kicadFootprintModel3.optional()});expectTypesMatch3(!0);var kicadSymbolPinNumbers3=external_exports2.object({hide:external_exports2.boolean().optional()});expectTypesMatch3(!0);var kicadSymbolPinNames3=external_exports2.object({offset:distance7.optional(),hide:external_exports2.boolean().optional()});expectTypesMatch3(!0);var kicadSymbolEffects3=external_exports2.object({font:kicadFont3.optional(),justify:external_exports2.union([external_exports2.string(),external_exports2.array(external_exports2.string())]).optional(),hide:external_exports2.boolean().optional()});expectTypesMatch3(!0);var kicadSymbolProperty3=external_exports2.object({value:external_exports2.string(),id:external_exports2.union([external_exports2.number(),external_exports2.string()]).optional(),at:kicadAt3.optional(),effects:kicadSymbolEffects3.optional()});expectTypesMatch3(!0);var kicadSymbolProperties3=external_exports2.object({Reference:kicadSymbolProperty3.optional(),Value:kicadSymbolProperty3.optional(),Footprint:kicadSymbolProperty3.optional(),Datasheet:kicadSymbolProperty3.optional(),Description:kicadSymbolProperty3.optional(),ki_keywords:kicadSymbolProperty3.optional(),ki_fp_filters:kicadSymbolProperty3.optional()});expectTypesMatch3(!0);var kicadSymbolMetadata3=external_exports2.object({symbolName:external_exports2.string().optional(),extends:external_exports2.string().optional(),pinNumbers:kicadSymbolPinNumbers3.optional(),pinNames:kicadSymbolPinNames3.optional(),excludeFromSim:external_exports2.boolean().optional(),inBom:external_exports2.boolean().optional(),onBoard:external_exports2.boolean().optional(),properties:kicadSymbolProperties3.optional(),embeddedFonts:external_exports2.boolean().optional()});expectTypesMatch3(!0);var base_circuit_json_error2=external_exports2.object({error_type:external_exports2.string(),message:external_exports2.string(),is_fatal:external_exports2.boolean().optional()});expectTypesMatch3(!0);var supplier_name2=external_exports2.enum(["jlcpcb","macrofab","pcbway","digikey","mouser","lcsc"]);expectTypesMatch3(!0);var source_component_base2=external_exports2.object({type:external_exports2.literal("source_component"),ftype:external_exports2.string().optional(),source_component_id:external_exports2.string(),name:external_exports2.string(),manufacturer_part_number:external_exports2.string().optional(),supplier_part_numbers:external_exports2.record(supplier_name2,external_exports2.array(external_exports2.string())).optional(),display_value:external_exports2.string().optional(),display_name:external_exports2.string().optional(),are_pins_interchangeable:external_exports2.boolean().optional(),internally_connected_source_port_ids:external_exports2.array(external_exports2.array(external_exports2.string())).optional(),source_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()});expectTypesMatch3(!0);var source_simple_capacitor2=source_component_base2.extend({ftype:external_exports2.literal("simple_capacitor"),capacitance:capacitance2,max_voltage_rating:voltage2.optional(),display_capacitance:external_exports2.string().optional(),max_decoupling_trace_length:distance7.optional()});expectTypesMatch3(!0);var source_simple_resistor2=source_component_base2.extend({ftype:external_exports2.literal("simple_resistor"),resistance:resistance2,display_resistance:external_exports2.string().optional()});expectTypesMatch3(!0);var source_simple_diode2=source_component_base2.extend({ftype:external_exports2.literal("simple_diode")});expectTypesMatch3(!0);var source_simple_fiducial2=source_component_base2.extend({ftype:external_exports2.literal("simple_fiducial")});expectTypesMatch3(!0);var source_simple_led2=source_simple_diode2.extend({ftype:external_exports2.literal("simple_led"),color:external_exports2.string().optional(),wavelength:external_exports2.string().optional()});expectTypesMatch3(!0);var source_simple_ground2=source_component_base2.extend({ftype:external_exports2.literal("simple_ground")});expectTypesMatch3(!0);var source_simple_chip2=source_component_base2.extend({ftype:external_exports2.literal("simple_chip")});expectTypesMatch3(!0);var source_simple_power_source2=source_component_base2.extend({ftype:external_exports2.literal("simple_power_source"),voltage:voltage2});expectTypesMatch3(!0);var source_simple_current_source2=source_component_base2.extend({ftype:external_exports2.literal("simple_current_source"),current:current2,frequency:frequency2.optional(),peak_to_peak_current:current2.optional(),wave_shape:external_exports2.enum(["sine","square","triangle","sawtooth","dc"]).optional().default("dc"),phase:external_exports2.number().optional(),duty_cycle:external_exports2.number().min(0).max(1).optional()});expectTypesMatch3(!0);var source_pin_attributes2=external_exports2.object({must_be_connected:external_exports2.boolean().optional(),provides_power:external_exports2.boolean().optional(),requires_power:external_exports2.boolean().optional(),provides_ground:external_exports2.boolean().optional(),requires_ground:external_exports2.boolean().optional(),provides_voltage:external_exports2.union([external_exports2.string(),external_exports2.number()]).optional(),requires_voltage:external_exports2.union([external_exports2.string(),external_exports2.number()]).optional(),do_not_connect:external_exports2.boolean().optional(),include_in_board_pinout:external_exports2.boolean().optional(),can_use_internal_pullup:external_exports2.boolean().optional(),is_using_internal_pullup:external_exports2.boolean().optional(),needs_external_pullup:external_exports2.boolean().optional(),can_use_internal_pulldown:external_exports2.boolean().optional(),is_using_internal_pulldown:external_exports2.boolean().optional(),needs_external_pulldown:external_exports2.boolean().optional(),can_use_open_drain:external_exports2.boolean().optional(),is_using_open_drain:external_exports2.boolean().optional(),can_use_push_pull:external_exports2.boolean().optional(),is_using_push_pull:external_exports2.boolean().optional(),should_have_decoupling_capacitor:external_exports2.boolean().optional(),recommended_decoupling_capacitor_capacitance:external_exports2.union([external_exports2.string(),external_exports2.number()]).optional(),is_configured_for_i2c_sda:external_exports2.boolean().optional(),is_configured_for_i2c_scl:external_exports2.boolean().optional(),is_configured_for_spi_mosi:external_exports2.boolean().optional(),is_configured_for_spi_miso:external_exports2.boolean().optional(),is_configured_for_spi_sck:external_exports2.boolean().optional(),is_configured_for_spi_cs:external_exports2.boolean().optional(),is_configured_for_uart_tx:external_exports2.boolean().optional(),is_configured_for_uart_rx:external_exports2.boolean().optional(),supports_i2c_sda:external_exports2.boolean().optional(),supports_i2c_scl:external_exports2.boolean().optional(),supports_spi_mosi:external_exports2.boolean().optional(),supports_spi_miso:external_exports2.boolean().optional(),supports_spi_sck:external_exports2.boolean().optional(),supports_spi_cs:external_exports2.boolean().optional(),supports_uart_tx:external_exports2.boolean().optional(),supports_uart_rx:external_exports2.boolean().optional()});expectTypesMatch3(!0);var source_simple_fuse2=source_component_base2.extend({ftype:external_exports2.literal("simple_fuse"),current_rating_amps:external_exports2.number().describe("Nominal current in amps the fuse is rated for"),voltage_rating_volts:external_exports2.number().describe("Voltage rating in volts, e.g. \xB15V would be 5")});expectTypesMatch3(!0);var source_simple_battery2=source_component_base2.extend({ftype:external_exports2.literal("simple_battery"),capacity:battery_capacity2});expectTypesMatch3(!0);var source_simple_inductor2=source_component_base2.extend({ftype:external_exports2.literal("simple_inductor"),inductance:inductance2,max_current_rating:external_exports2.number().optional()});expectTypesMatch3(!0);var source_simple_push_button2=source_component_base2.extend({ftype:external_exports2.literal("simple_push_button")});expectTypesMatch3(!0);var source_simple_potentiometer2=source_component_base2.extend({ftype:external_exports2.literal("simple_potentiometer"),max_resistance:resistance2,display_max_resistance:external_exports2.string().optional()});expectTypesMatch3(!0);var source_simple_crystal2=source_component_base2.extend({ftype:external_exports2.literal("simple_crystal"),frequency:external_exports2.number().describe("Frequency in Hz"),load_capacitance:external_exports2.number().optional().describe("Load capacitance in pF"),pin_variant:external_exports2.enum(["two_pin","four_pin"]).optional()});expectTypesMatch3(!0);var source_simple_pin_header2=source_component_base2.extend({ftype:external_exports2.literal("simple_pin_header"),pin_count:external_exports2.number(),gender:external_exports2.enum(["male","female"]).optional().default("male")});expectTypesMatch3(!0);var source_simple_connector2=source_component_base2.extend({ftype:external_exports2.literal("simple_connector"),standard:external_exports2.enum(["usb_c","m2"]).optional()});expectTypesMatch3(!0);var source_simple_pinout2=source_component_base2.extend({ftype:external_exports2.literal("simple_pinout")});expectTypesMatch3(!0);var source_simple_resonator2=source_component_base2.extend({ftype:external_exports2.literal("simple_resonator"),load_capacitance:capacitance2,equivalent_series_resistance:resistance2.optional(),frequency:frequency2});expectTypesMatch3(!0);var source_simple_transistor2=source_component_base2.extend({ftype:external_exports2.literal("simple_transistor"),transistor_type:external_exports2.enum(["npn","pnp"])});expectTypesMatch3(!0);var source_simple_test_point2=source_component_base2.extend({ftype:external_exports2.literal("simple_test_point"),footprint_variant:external_exports2.enum(["pad","through_hole"]).optional(),pad_shape:external_exports2.enum(["rect","circle"]).optional(),pad_diameter:external_exports2.union([external_exports2.number(),external_exports2.string()]).optional(),hole_diameter:external_exports2.union([external_exports2.number(),external_exports2.string()]).optional(),width:external_exports2.union([external_exports2.number(),external_exports2.string()]).optional(),height:external_exports2.union([external_exports2.number(),external_exports2.string()]).optional()});expectTypesMatch3(!0);var source_simple_mosfet2=source_component_base2.extend({ftype:external_exports2.literal("simple_mosfet"),channel_type:external_exports2.enum(["n","p"]),mosfet_mode:external_exports2.enum(["enhancement","depletion"])});expectTypesMatch3(!0);var source_simple_op_amp2=source_component_base2.extend({ftype:external_exports2.literal("simple_op_amp")});expectTypesMatch3(!0);var source_simple_switch2=source_component_base2.extend({ftype:external_exports2.literal("simple_switch")});expectTypesMatch3(!0);var source_project_metadata2=external_exports2.object({type:external_exports2.literal("source_project_metadata"),name:external_exports2.string().optional(),software_used_string:external_exports2.string().optional(),project_url:external_exports2.string().optional(),created_at:timestamp2.optional()});expectTypesMatch3(!0);var source_missing_property_error2=base_circuit_json_error2.extend({type:external_exports2.literal("source_missing_property_error"),source_missing_property_error_id:getZodPrefixedIdWithDefault2("source_missing_property_error"),source_component_id:external_exports2.string(),property_name:external_exports2.string(),subcircuit_id:external_exports2.string().optional(),error_type:external_exports2.literal("source_missing_property_error").default("source_missing_property_error")}).describe("The source code is missing a property");expectTypesMatch3(!0);var source_failed_to_create_component_error2=base_circuit_json_error2.extend({type:external_exports2.literal("source_failed_to_create_component_error"),source_failed_to_create_component_error_id:getZodPrefixedIdWithDefault2("source_failed_to_create_component_error"),error_type:external_exports2.literal("source_failed_to_create_component_error").default("source_failed_to_create_component_error"),component_name:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),parent_source_component_id:external_exports2.string().optional(),pcb_center:external_exports2.object({x:external_exports2.number().optional(),y:external_exports2.number().optional()}).optional(),schematic_center:external_exports2.object({x:external_exports2.number().optional(),y:external_exports2.number().optional()}).optional()}).describe("Error emitted when a component fails to be constructed");expectTypesMatch3(!0);var source_invalid_component_property_error2=base_circuit_json_error2.extend({type:external_exports2.literal("source_invalid_component_property_error"),source_invalid_component_property_error_id:getZodPrefixedIdWithDefault2("source_invalid_component_property_error"),source_component_id:external_exports2.string(),property_name:external_exports2.string(),property_value:external_exports2.unknown().optional(),expected_format:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),error_type:external_exports2.literal("source_invalid_component_property_error").default("source_invalid_component_property_error")}).describe("The source component property is invalid");expectTypesMatch3(!0);var source_trace_not_connected_error2=base_circuit_json_error2.extend({type:external_exports2.literal("source_trace_not_connected_error"),source_trace_not_connected_error_id:getZodPrefixedIdWithDefault2("source_trace_not_connected_error"),error_type:external_exports2.literal("source_trace_not_connected_error").default("source_trace_not_connected_error"),subcircuit_id:external_exports2.string().optional(),source_group_id:external_exports2.string().optional(),source_trace_id:external_exports2.string().optional(),connected_source_port_ids:external_exports2.array(external_exports2.string()).optional(),selectors_not_found:external_exports2.array(external_exports2.string()).optional()}).describe("Occurs when a source trace selector does not match any ports");expectTypesMatch3(!0);var source_property_ignored_warning2=external_exports2.object({type:external_exports2.literal("source_property_ignored_warning"),source_property_ignored_warning_id:getZodPrefixedIdWithDefault2("source_property_ignored_warning"),source_component_id:external_exports2.string(),property_name:external_exports2.string(),subcircuit_id:external_exports2.string().optional(),error_type:external_exports2.literal("source_property_ignored_warning").default("source_property_ignored_warning"),message:external_exports2.string()}).describe("The source property was ignored");expectTypesMatch3(!0);var source_pin_missing_trace_warning2=external_exports2.object({type:external_exports2.literal("source_pin_missing_trace_warning"),source_pin_missing_trace_warning_id:getZodPrefixedIdWithDefault2("source_pin_missing_trace_warning"),warning_type:external_exports2.literal("source_pin_missing_trace_warning").default("source_pin_missing_trace_warning"),message:external_exports2.string(),source_component_id:external_exports2.string(),source_port_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional()}).describe("Warning emitted when a source component pin is missing a trace connection");expectTypesMatch3(!0);var source_simple_voltage_probe2=source_component_base2.extend({ftype:external_exports2.literal("simple_voltage_probe")});expectTypesMatch3(!0);var source_interconnect2=source_component_base2.extend({ftype:external_exports2.literal("interconnect")});expectTypesMatch3(!0);var source_i2c_misconfigured_error2=base_circuit_json_error2.extend({type:external_exports2.literal("source_i2c_misconfigured_error"),source_i2c_misconfigured_error_id:getZodPrefixedIdWithDefault2("source_i2c_misconfigured_error"),error_type:external_exports2.literal("source_i2c_misconfigured_error").default("source_i2c_misconfigured_error"),source_port_ids:external_exports2.array(external_exports2.string())}).describe("Error emitted when incompatible I2C pins (e.g. SDA and SCL) are connected to the same net");expectTypesMatch3(!0);var source_simple_voltage_source2=source_component_base2.extend({ftype:external_exports2.literal("simple_voltage_source"),voltage:voltage2,frequency:frequency2.optional(),peak_to_peak_voltage:voltage2.optional(),wave_shape:external_exports2.enum(["sinewave","square","triangle","sawtooth"]).optional(),phase:rotation4.optional(),duty_cycle:external_exports2.number().optional().describe("Duty cycle as a fraction (0 to 1)")});expectTypesMatch3(!0);var any_source_component2=external_exports2.union([source_simple_resistor2,source_simple_capacitor2,source_simple_diode2,source_simple_fiducial2,source_simple_led2,source_simple_ground2,source_simple_chip2,source_simple_power_source2,source_simple_current_source2,source_simple_battery2,source_simple_inductor2,source_simple_push_button2,source_simple_potentiometer2,source_simple_crystal2,source_simple_pin_header2,source_simple_connector2,source_simple_pinout2,source_simple_resonator2,source_simple_switch2,source_simple_transistor2,source_simple_test_point2,source_simple_mosfet2,source_simple_op_amp2,source_simple_fuse2,source_simple_voltage_probe2,source_interconnect2,source_simple_voltage_source2,source_project_metadata2,source_missing_property_error2,source_invalid_component_property_error2,source_failed_to_create_component_error2,source_trace_not_connected_error2,source_property_ignored_warning2,source_pin_missing_trace_warning2,source_i2c_misconfigured_error2]);expectTypesMatch3(!0);var source_port2=external_exports2.object({type:external_exports2.literal("source_port"),pin_number:external_exports2.number().optional(),port_hints:external_exports2.array(external_exports2.string()).optional(),name:external_exports2.string(),source_port_id:external_exports2.string(),source_component_id:external_exports2.string().optional(),source_group_id:external_exports2.string().optional(),most_frequently_referenced_by_name:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),subcircuit_connectivity_map_key:external_exports2.string().optional()}).merge(source_pin_attributes2);expectTypesMatch3(!0);var source_component_internal_connection2=external_exports2.object({type:external_exports2.literal("source_component_internal_connection"),source_component_internal_connection_id:external_exports2.string(),source_component_id:external_exports2.string(),source_port_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()});expectTypesMatch3(!0);var source_trace2=external_exports2.object({type:external_exports2.literal("source_trace"),source_trace_id:external_exports2.string(),connected_source_port_ids:external_exports2.array(external_exports2.string()),connected_source_net_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional(),subcircuit_connectivity_map_key:external_exports2.string().optional(),max_length:external_exports2.number().optional(),min_trace_thickness:external_exports2.number().optional(),display_name:external_exports2.string().optional()});expectTypesMatch3(!0);var source_group2=external_exports2.object({type:external_exports2.literal("source_group"),source_group_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional(),parent_subcircuit_id:external_exports2.string().optional(),parent_source_group_id:external_exports2.string().optional(),is_subcircuit:external_exports2.boolean().optional(),show_as_schematic_box:external_exports2.boolean().optional(),name:external_exports2.string().optional(),was_automatically_named:external_exports2.boolean().optional()});expectTypesMatch3(!0);var source_net2=external_exports2.object({type:external_exports2.literal("source_net"),source_net_id:external_exports2.string(),name:external_exports2.string(),member_source_group_ids:external_exports2.array(external_exports2.string()),is_power:external_exports2.boolean().optional(),is_ground:external_exports2.boolean().optional(),is_digital_signal:external_exports2.boolean().optional(),is_analog_signal:external_exports2.boolean().optional(),is_positive_voltage_source:external_exports2.boolean().optional(),trace_width:external_exports2.number().optional(),subcircuit_id:external_exports2.string().optional(),subcircuit_connectivity_map_key:external_exports2.string().optional()});expectTypesMatch3(!0);var source_board2=external_exports2.object({type:external_exports2.literal("source_board"),source_board_id:external_exports2.string(),source_group_id:external_exports2.string(),title:external_exports2.string().optional()}).describe("Defines a board in the source domain");expectTypesMatch3(!0);var source_ambiguous_port_reference2=base_circuit_json_error2.extend({type:external_exports2.literal("source_ambiguous_port_reference"),source_ambiguous_port_reference_id:getZodPrefixedIdWithDefault2("source_ambiguous_port_reference"),error_type:external_exports2.literal("source_ambiguous_port_reference").default("source_ambiguous_port_reference"),source_port_id:external_exports2.string().optional(),source_component_id:external_exports2.string().optional()}).describe("Error emitted when a port hint matches multiple non-overlapping pads, making the port reference ambiguous");expectTypesMatch3(!0);var source_pcb_ground_plane2=external_exports2.object({type:external_exports2.literal("source_pcb_ground_plane"),source_pcb_ground_plane_id:external_exports2.string(),source_group_id:external_exports2.string(),source_net_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional()}).describe("Defines a ground plane in the source domain");expectTypesMatch3(!0);var all_layers2=["top","bottom","inner1","inner2","inner3","inner4","inner5","inner6"],layer_string2=external_exports2.enum(all_layers2),layer_ref2=layer_string2.or(external_exports2.object({name:layer_string2})).transform(layer=>typeof layer=="string"?layer:layer.name);expectTypesMatch3(!0);var visible_layer2=external_exports2.enum(["top","bottom"]),source_manually_placed_via2=external_exports2.object({type:external_exports2.literal("source_manually_placed_via"),source_manually_placed_via_id:external_exports2.string(),source_group_id:external_exports2.string(),source_net_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional(),source_trace_id:external_exports2.string().optional()}).describe("Defines a via that is manually placed in the source domain");expectTypesMatch3(!0);var source_no_power_pin_defined_warning2=external_exports2.object({type:external_exports2.literal("source_no_power_pin_defined_warning"),source_no_power_pin_defined_warning_id:getZodPrefixedIdWithDefault2("source_no_power_pin_defined_warning"),warning_type:external_exports2.literal("source_no_power_pin_defined_warning").default("source_no_power_pin_defined_warning"),message:external_exports2.string(),source_component_id:external_exports2.string(),source_port_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()}).describe("Warning emitted when a chip has no source ports with requires_power=true");expectTypesMatch3(!0);var source_no_ground_pin_defined_warning2=external_exports2.object({type:external_exports2.literal("source_no_ground_pin_defined_warning"),source_no_ground_pin_defined_warning_id:getZodPrefixedIdWithDefault2("source_no_ground_pin_defined_warning"),warning_type:external_exports2.literal("source_no_ground_pin_defined_warning").default("source_no_ground_pin_defined_warning"),message:external_exports2.string(),source_component_id:external_exports2.string(),source_port_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()}).describe("Warning emitted when a chip has no source ports marked as ground pins");expectTypesMatch3(!0);var source_component_pins_underspecified_warning2=external_exports2.object({type:external_exports2.literal("source_component_pins_underspecified_warning"),source_component_pins_underspecified_warning_id:getZodPrefixedIdWithDefault2("source_component_pins_underspecified_warning"),warning_type:external_exports2.literal("source_component_pins_underspecified_warning").default("source_component_pins_underspecified_warning"),message:external_exports2.string(),source_component_id:external_exports2.string(),source_port_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()}).describe("Warning emitted when all ports on a source component are underspecified");expectTypesMatch3(!0);var source_pin_must_be_connected_error2=base_circuit_json_error2.extend({type:external_exports2.literal("source_pin_must_be_connected_error"),source_pin_must_be_connected_error_id:getZodPrefixedIdWithDefault2("source_pin_must_be_connected_error"),error_type:external_exports2.literal("source_pin_must_be_connected_error").default("source_pin_must_be_connected_error"),source_component_id:external_exports2.string(),source_port_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional()}).describe("Error emitted when a pin with mustBeConnected attribute is not connected to any trace");expectTypesMatch3(!0);var unknown_error_finding_part2=base_circuit_json_error2.extend({type:external_exports2.literal("unknown_error_finding_part"),unknown_error_finding_part_id:getZodPrefixedIdWithDefault2("unknown_error_finding_part"),error_type:external_exports2.literal("unknown_error_finding_part").default("unknown_error_finding_part"),source_component_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}).describe("Error emitted when an unexpected error occurs while finding a part");expectTypesMatch3(!0);var schematic_box2=external_exports2.object({type:external_exports2.literal("schematic_box"),schematic_component_id:external_exports2.string().optional(),schematic_symbol_id:external_exports2.string().optional(),width:distance7,height:distance7,is_dashed:external_exports2.boolean().default(!1),x:distance7,y:distance7,subcircuit_id:external_exports2.string().optional()}).describe("Draws a box on the schematic");expectTypesMatch3(!0);var schematic_path2=external_exports2.object({type:external_exports2.literal("schematic_path"),schematic_path_id:getZodPrefixedIdWithDefault2("schematic_path"),schematic_component_id:external_exports2.string().optional(),schematic_symbol_id:external_exports2.string().optional(),fill_color:external_exports2.string().optional(),is_filled:external_exports2.boolean().optional(),stroke_width:distance7.nullable().optional(),stroke_color:external_exports2.string().optional(),points:external_exports2.array(point5),subcircuit_id:external_exports2.string().optional()});expectTypesMatch3(!0);var schematic_pin_styles2=external_exports2.record(external_exports2.object({left_margin:length3.optional(),right_margin:length3.optional(),top_margin:length3.optional(),bottom_margin:length3.optional()})),schematic_component_port_arrangement_by_size2=external_exports2.object({left_size:external_exports2.number(),right_size:external_exports2.number(),top_size:external_exports2.number().optional(),bottom_size:external_exports2.number().optional()});expectTypesMatch3(!0);var schematic_component_port_arrangement_by_sides2=external_exports2.object({left_side:external_exports2.object({pins:external_exports2.array(external_exports2.number()),direction:external_exports2.enum(["top-to-bottom","bottom-to-top"]).optional()}).optional(),right_side:external_exports2.object({pins:external_exports2.array(external_exports2.number()),direction:external_exports2.enum(["top-to-bottom","bottom-to-top"]).optional()}).optional(),top_side:external_exports2.object({pins:external_exports2.array(external_exports2.number()),direction:external_exports2.enum(["left-to-right","right-to-left"]).optional()}).optional(),bottom_side:external_exports2.object({pins:external_exports2.array(external_exports2.number()),direction:external_exports2.enum(["left-to-right","right-to-left"]).optional()}).optional()});expectTypesMatch3(!0);var port_arrangement2=external_exports2.union([schematic_component_port_arrangement_by_size2,schematic_component_port_arrangement_by_sides2]),schematic_component2=external_exports2.object({type:external_exports2.literal("schematic_component"),size:size2,center:point5,source_component_id:external_exports2.string().optional(),schematic_component_id:external_exports2.string(),schematic_symbol_id:external_exports2.string().optional(),pin_spacing:length3.optional(),pin_styles:schematic_pin_styles2.optional(),box_width:length3.optional(),symbol_name:external_exports2.string().optional(),port_arrangement:port_arrangement2.optional(),port_labels:external_exports2.record(external_exports2.string()).optional(),symbol_display_value:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),schematic_group_id:external_exports2.string().optional(),is_schematic_group:external_exports2.boolean().optional(),source_group_id:external_exports2.string().optional(),is_box_with_pins:external_exports2.boolean().optional().default(!0)});expectTypesMatch3(!0);var schematicSymbolMetadata2=external_exports2.object({kicad_symbol:kicadSymbolMetadata3.optional()}).catchall(external_exports2.unknown()),schematic_symbol2=external_exports2.object({type:external_exports2.literal("schematic_symbol"),schematic_symbol_id:external_exports2.string(),name:external_exports2.string().optional(),metadata:schematicSymbolMetadata2.optional()}).describe("Defines a named schematic symbol that can be referenced by components.");expectTypesMatch3(!0);var schematic_line2=external_exports2.object({type:external_exports2.literal("schematic_line"),schematic_line_id:getZodPrefixedIdWithDefault2("schematic_line"),schematic_component_id:external_exports2.string().optional(),schematic_symbol_id:external_exports2.string().optional(),x1:distance7,y1:distance7,x2:distance7,y2:distance7,stroke_width:distance7.nullable().optional(),color:external_exports2.string().default("#000000"),is_dashed:external_exports2.boolean().default(!1),subcircuit_id:external_exports2.string().optional()}).describe("Draws a styled line on the schematic");expectTypesMatch3(!0);var schematic_rect2=external_exports2.object({type:external_exports2.literal("schematic_rect"),schematic_rect_id:getZodPrefixedIdWithDefault2("schematic_rect"),schematic_component_id:external_exports2.string().optional(),schematic_symbol_id:external_exports2.string().optional(),center:point5,width:distance7,height:distance7,rotation:rotation4.default(0),stroke_width:distance7.nullable().optional(),color:external_exports2.string().default("#000000"),is_filled:external_exports2.boolean().default(!1),fill_color:external_exports2.string().optional(),is_dashed:external_exports2.boolean().default(!1),subcircuit_id:external_exports2.string().optional()}).describe("Draws a styled rectangle on the schematic");expectTypesMatch3(!0);var schematic_circle2=external_exports2.object({type:external_exports2.literal("schematic_circle"),schematic_circle_id:getZodPrefixedIdWithDefault2("schematic_circle"),schematic_component_id:external_exports2.string().optional(),schematic_symbol_id:external_exports2.string().optional(),center:point5,radius:distance7,stroke_width:distance7.nullable().optional(),color:external_exports2.string().default("#000000"),is_filled:external_exports2.boolean().default(!1),fill_color:external_exports2.string().optional(),is_dashed:external_exports2.boolean().default(!1),subcircuit_id:external_exports2.string().optional()}).describe("Draws a styled circle on the schematic");expectTypesMatch3(!0);var schematic_arc2=external_exports2.object({type:external_exports2.literal("schematic_arc"),schematic_arc_id:getZodPrefixedIdWithDefault2("schematic_arc"),schematic_component_id:external_exports2.string().optional(),schematic_symbol_id:external_exports2.string().optional(),center:point5,radius:distance7,start_angle_degrees:rotation4,end_angle_degrees:rotation4,direction:external_exports2.enum(["clockwise","counterclockwise"]).default("counterclockwise"),stroke_width:distance7.nullable().optional(),color:external_exports2.string().default("#000000"),is_dashed:external_exports2.boolean().default(!1),subcircuit_id:external_exports2.string().optional()}).describe("Draws a styled arc on the schematic");expectTypesMatch3(!0);var schematic_trace2=external_exports2.object({type:external_exports2.literal("schematic_trace"),schematic_trace_id:external_exports2.string(),source_trace_id:external_exports2.string().optional(),junctions:external_exports2.array(external_exports2.object({x:external_exports2.number(),y:external_exports2.number()})),edges:external_exports2.array(external_exports2.object({from:external_exports2.object({x:external_exports2.number(),y:external_exports2.number()}),to:external_exports2.object({x:external_exports2.number(),y:external_exports2.number()}),is_crossing:external_exports2.boolean().optional(),from_schematic_port_id:external_exports2.string().optional(),to_schematic_port_id:external_exports2.string().optional()})),subcircuit_id:external_exports2.string().optional(),subcircuit_connectivity_map_key:external_exports2.string().optional()});expectTypesMatch3(!0);var fivePointAnchor3=external_exports2.enum(["center","left","right","top","bottom"]);expectTypesMatch3(!0);var schematic_text2=external_exports2.object({type:external_exports2.literal("schematic_text"),schematic_component_id:external_exports2.string().optional(),schematic_symbol_id:external_exports2.string().optional(),schematic_text_id:external_exports2.string(),text:external_exports2.string(),font_size:external_exports2.number().default(.18),position:external_exports2.object({x:distance7,y:distance7}),rotation:external_exports2.number().default(0),anchor:external_exports2.union([fivePointAnchor3.describe("legacy"),ninePointAnchor3]).default("center"),color:external_exports2.string().default("#000000"),subcircuit_id:external_exports2.string().optional()});expectTypesMatch3(!0);var schematic_port2=external_exports2.object({type:external_exports2.literal("schematic_port"),schematic_port_id:external_exports2.string(),source_port_id:external_exports2.string(),schematic_component_id:external_exports2.string().optional(),center:point5,facing_direction:external_exports2.enum(["up","down","left","right"]).optional(),distance_from_component_edge:external_exports2.number().optional(),side_of_component:external_exports2.enum(["top","bottom","left","right"]).optional(),true_ccw_index:external_exports2.number().optional(),pin_number:external_exports2.number().optional(),display_pin_label:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),is_connected:external_exports2.boolean().optional(),has_input_arrow:external_exports2.boolean().optional(),has_output_arrow:external_exports2.boolean().optional(),is_drawn_with_inversion_circle:external_exports2.boolean().optional()}).describe("Defines a port on a schematic component");expectTypesMatch3(!0);var schematic_net_label2=external_exports2.object({type:external_exports2.literal("schematic_net_label"),schematic_net_label_id:getZodPrefixedIdWithDefault2("schematic_net_label"),schematic_trace_id:external_exports2.string().optional(),source_trace_id:external_exports2.string().optional(),source_net_id:external_exports2.string(),center:point5,anchor_position:point5.optional(),anchor_side:external_exports2.enum(["top","bottom","left","right"]),text:external_exports2.string(),symbol_name:external_exports2.string().optional(),is_movable:external_exports2.boolean().optional(),subcircuit_id:external_exports2.string().optional()});expectTypesMatch3(!0);var schematic_error2=base_circuit_json_error2.extend({type:external_exports2.literal("schematic_error"),schematic_error_id:external_exports2.string(),error_type:external_exports2.literal("schematic_port_not_found").default("schematic_port_not_found"),subcircuit_id:external_exports2.string().optional()}).describe("Defines a schematic error on the schematic");expectTypesMatch3(!0);var schematic_layout_error2=base_circuit_json_error2.extend({type:external_exports2.literal("schematic_layout_error"),schematic_layout_error_id:getZodPrefixedIdWithDefault2("schematic_layout_error"),error_type:external_exports2.literal("schematic_layout_error").default("schematic_layout_error"),source_group_id:external_exports2.string(),schematic_group_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional()}).describe("Error emitted when schematic layout fails for a group");expectTypesMatch3(!0);var schematic_debug_object_base2=external_exports2.object({type:external_exports2.literal("schematic_debug_object"),label:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}),schematic_debug_rect2=schematic_debug_object_base2.extend({shape:external_exports2.literal("rect"),center:point5,size:size2}),schematic_debug_line2=schematic_debug_object_base2.extend({shape:external_exports2.literal("line"),start:point5,end:point5}),schematic_debug_point2=schematic_debug_object_base2.extend({shape:external_exports2.literal("point"),center:point5}),schematic_debug_object2=external_exports2.discriminatedUnion("shape",[schematic_debug_rect2,schematic_debug_line2,schematic_debug_point2]);expectTypesMatch3(!0);var schematic_voltage_probe2=external_exports2.object({type:external_exports2.literal("schematic_voltage_probe"),schematic_voltage_probe_id:external_exports2.string(),source_component_id:external_exports2.string().optional(),name:external_exports2.string().optional(),position:point5,schematic_trace_id:external_exports2.string(),voltage:voltage2.optional(),subcircuit_id:external_exports2.string().optional(),color:external_exports2.string().optional(),label_alignment:ninePointAnchor3.optional()}).describe("Defines a voltage probe measurement point on a schematic trace");expectTypesMatch3(!0);var schematic_manual_edit_conflict_warning2=external_exports2.object({type:external_exports2.literal("schematic_manual_edit_conflict_warning"),schematic_manual_edit_conflict_warning_id:getZodPrefixedIdWithDefault2("schematic_manual_edit_conflict_warning"),warning_type:external_exports2.literal("schematic_manual_edit_conflict_warning").default("schematic_manual_edit_conflict_warning"),message:external_exports2.string(),schematic_component_id:external_exports2.string(),schematic_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),source_component_id:external_exports2.string()}).describe("Warning emitted when a component has both manual placement and explicit schX/schY coordinates");expectTypesMatch3(!0);var schematic_group2=external_exports2.object({type:external_exports2.literal("schematic_group"),schematic_group_id:getZodPrefixedIdWithDefault2("schematic_group"),source_group_id:external_exports2.string(),is_subcircuit:external_exports2.boolean().optional(),subcircuit_id:external_exports2.string().optional(),width:length3,height:length3,center:point5,schematic_component_ids:external_exports2.array(external_exports2.string()),show_as_schematic_box:external_exports2.boolean().optional(),name:external_exports2.string().optional(),description:external_exports2.string().optional()}).describe("Defines a group of components on the schematic");expectTypesMatch3(!0);var schematic_table2=external_exports2.object({type:external_exports2.literal("schematic_table"),schematic_table_id:getZodPrefixedIdWithDefault2("schematic_table"),anchor_position:point5,column_widths:external_exports2.array(distance7),row_heights:external_exports2.array(distance7),cell_padding:distance7.optional(),border_width:distance7.optional(),subcircuit_id:external_exports2.string().optional(),schematic_component_id:external_exports2.string().optional(),anchor:ninePointAnchor3.optional()}).describe("Defines a table on the schematic");expectTypesMatch3(!0);var schematic_table_cell2=external_exports2.object({type:external_exports2.literal("schematic_table_cell"),schematic_table_cell_id:getZodPrefixedIdWithDefault2("schematic_table_cell"),schematic_table_id:external_exports2.string(),start_row_index:external_exports2.number(),end_row_index:external_exports2.number(),start_column_index:external_exports2.number(),end_column_index:external_exports2.number(),text:external_exports2.string().optional(),center:point5,width:distance7,height:distance7,horizontal_align:external_exports2.enum(["left","center","right"]).optional(),vertical_align:external_exports2.enum(["top","middle","bottom"]).optional(),font_size:distance7.optional(),subcircuit_id:external_exports2.string().optional()}).describe("Defines a cell within a schematic_table");expectTypesMatch3(!0);var schematic_sheet2=external_exports2.object({type:external_exports2.literal("schematic_sheet"),schematic_sheet_id:getZodPrefixedIdWithDefault2("schematic_sheet"),name:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}).describe("Defines a schematic sheet or page that components can be placed on");expectTypesMatch3(!0);var point_with_bulge2=external_exports2.object({x:distance7,y:distance7,bulge:external_exports2.number().optional()});expectTypesMatch3(!0);var ring2=external_exports2.object({vertices:external_exports2.array(point_with_bulge2)});expectTypesMatch3(!0);var brep_shape2=external_exports2.object({outer_ring:ring2,inner_rings:external_exports2.array(ring2).default([])});expectTypesMatch3(!0);var pcb_route_hint2=external_exports2.object({x:distance7,y:distance7,via:external_exports2.boolean().optional(),via_to_layer:layer_ref2.optional()}),pcb_route_hints2=external_exports2.array(pcb_route_hint2);expectTypesMatch3(!0);expectTypesMatch3(!0);var route_hint_point2=external_exports2.object({x:distance7,y:distance7,via:external_exports2.boolean().optional(),to_layer:layer_ref2.optional(),trace_width:distance7.optional()});expectTypesMatch3(!0);var pcb_component2=external_exports2.object({type:external_exports2.literal("pcb_component"),pcb_component_id:getZodPrefixedIdWithDefault2("pcb_component"),source_component_id:external_exports2.string(),center:point5,layer:layer_ref2,rotation:rotation4,display_offset_x:external_exports2.string().optional().describe("How to display the x offset for this part, usually corresponding with how the user specified it"),display_offset_y:external_exports2.string().optional().describe("How to display the y offset for this part, usually corresponding with how the user specified it"),width:length3,height:length3,do_not_place:external_exports2.boolean().optional(),is_allowed_to_be_off_board:external_exports2.boolean().optional(),subcircuit_id:external_exports2.string().optional(),pcb_group_id:external_exports2.string().optional(),position_mode:external_exports2.enum(["packed","relative_to_group_anchor","relative_to_another_component","none"]).optional(),anchor_position:point5.optional(),anchor_alignment:ninePointAnchor3.optional(),positioned_relative_to_pcb_group_id:external_exports2.string().optional(),positioned_relative_to_pcb_board_id:external_exports2.string().optional(),cable_insertion_center:point5.optional(),metadata:external_exports2.object({kicad_footprint:kicadFootprintMetadata3.optional()}).optional(),obstructs_within_bounds:external_exports2.boolean().default(!0).describe("Does this component take up all the space within its bounds on a layer. This is generally true except for when separated pin headers are being represented by a single component (in which case, chips can be placed between the pin headers) or for tall modules where chips fit underneath")}).describe("Defines a component on the PCB");expectTypesMatch3(!0);var pcb_hole_circle2=external_exports2.object({type:external_exports2.literal("pcb_hole"),pcb_hole_id:getZodPrefixedIdWithDefault2("pcb_hole"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),pcb_component_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("circle"),hole_diameter:external_exports2.number(),x:distance7,y:distance7,is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_hole_circle_shape2=pcb_hole_circle2.describe("Defines a circular hole on the PCB");expectTypesMatch3(!0);var pcb_hole_rect2=external_exports2.object({type:external_exports2.literal("pcb_hole"),pcb_hole_id:getZodPrefixedIdWithDefault2("pcb_hole"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),pcb_component_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("rect"),hole_width:external_exports2.number(),hole_height:external_exports2.number(),x:distance7,y:distance7,is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_hole_rect_shape2=pcb_hole_rect2.describe("Defines a rectangular (square-capable) hole on the PCB. Use equal width/height for square.");expectTypesMatch3(!0);var pcb_hole_circle_or_square2=external_exports2.object({type:external_exports2.literal("pcb_hole"),pcb_hole_id:getZodPrefixedIdWithDefault2("pcb_hole"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),pcb_component_id:external_exports2.string().optional(),hole_shape:external_exports2.enum(["circle","square"]),hole_diameter:external_exports2.number(),x:distance7,y:distance7,is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_hole_circle_or_square_shape2=pcb_hole_circle_or_square2.describe("Defines a circular or square hole on the PCB");expectTypesMatch3(!0);var pcb_hole_oval2=external_exports2.object({type:external_exports2.literal("pcb_hole"),pcb_hole_id:getZodPrefixedIdWithDefault2("pcb_hole"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),pcb_component_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("oval"),hole_width:external_exports2.number(),hole_height:external_exports2.number(),x:distance7,y:distance7,is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_hole_oval_shape2=pcb_hole_oval2.describe("Defines an oval hole on the PCB");expectTypesMatch3(!0);var pcb_hole_pill2=external_exports2.object({type:external_exports2.literal("pcb_hole"),pcb_hole_id:getZodPrefixedIdWithDefault2("pcb_hole"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),pcb_component_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("pill"),hole_width:external_exports2.number(),hole_height:external_exports2.number(),x:distance7,y:distance7,is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_hole_pill_shape2=pcb_hole_pill2.describe("Defines a pill-shaped hole on the PCB");expectTypesMatch3(!0);var pcb_hole_rotated_pill2=external_exports2.object({type:external_exports2.literal("pcb_hole"),pcb_hole_id:getZodPrefixedIdWithDefault2("pcb_hole"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),pcb_component_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("rotated_pill"),hole_width:external_exports2.number(),hole_height:external_exports2.number(),x:distance7,y:distance7,ccw_rotation:rotation4,is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_hole_rotated_pill_shape2=pcb_hole_rotated_pill2.describe("Defines a rotated pill-shaped hole on the PCB");expectTypesMatch3(!0);var pcb_hole2=pcb_hole_circle_or_square2.or(pcb_hole_oval2).or(pcb_hole_pill2).or(pcb_hole_rotated_pill2).or(pcb_hole_circle2).or(pcb_hole_rect2),pcb_plated_hole_circle2=external_exports2.object({type:external_exports2.literal("pcb_plated_hole"),shape:external_exports2.literal("circle"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),outer_diameter:external_exports2.number(),hole_diameter:external_exports2.number(),is_covered_with_solder_mask:external_exports2.boolean().optional(),x:distance7,y:distance7,layers:external_exports2.array(layer_ref2),port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),pcb_plated_hole_id:getZodPrefixedIdWithDefault2("pcb_plated_hole"),soldermask_margin:external_exports2.number().optional()}),pcb_plated_hole_oval2=external_exports2.object({type:external_exports2.literal("pcb_plated_hole"),shape:external_exports2.enum(["oval","pill"]),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),outer_width:external_exports2.number(),outer_height:external_exports2.number(),hole_width:external_exports2.number(),hole_height:external_exports2.number(),is_covered_with_solder_mask:external_exports2.boolean().optional(),x:distance7,y:distance7,ccw_rotation:rotation4,layers:external_exports2.array(layer_ref2),port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),pcb_plated_hole_id:getZodPrefixedIdWithDefault2("pcb_plated_hole"),soldermask_margin:external_exports2.number().optional()}),pcb_circular_hole_with_rect_pad2=external_exports2.object({type:external_exports2.literal("pcb_plated_hole"),shape:external_exports2.literal("circular_hole_with_rect_pad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("circle"),pad_shape:external_exports2.literal("rect"),hole_diameter:external_exports2.number(),rect_pad_width:external_exports2.number(),rect_pad_height:external_exports2.number(),rect_border_radius:external_exports2.number().optional(),hole_offset_x:distance7.default(0),hole_offset_y:distance7.default(0),is_covered_with_solder_mask:external_exports2.boolean().optional(),x:distance7,y:distance7,layers:external_exports2.array(layer_ref2),port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),pcb_plated_hole_id:getZodPrefixedIdWithDefault2("pcb_plated_hole"),soldermask_margin:external_exports2.number().optional(),rect_ccw_rotation:rotation4.optional()}),pcb_pill_hole_with_rect_pad2=external_exports2.object({type:external_exports2.literal("pcb_plated_hole"),shape:external_exports2.literal("pill_hole_with_rect_pad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("pill"),pad_shape:external_exports2.literal("rect"),hole_width:external_exports2.number(),hole_height:external_exports2.number(),rect_pad_width:external_exports2.number(),rect_pad_height:external_exports2.number(),rect_border_radius:external_exports2.number().optional(),hole_offset_x:distance7.default(0),hole_offset_y:distance7.default(0),is_covered_with_solder_mask:external_exports2.boolean().optional(),x:distance7,y:distance7,layers:external_exports2.array(layer_ref2),port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),pcb_plated_hole_id:getZodPrefixedIdWithDefault2("pcb_plated_hole"),soldermask_margin:external_exports2.number().optional()}),pcb_rotated_pill_hole_with_rect_pad2=external_exports2.object({type:external_exports2.literal("pcb_plated_hole"),shape:external_exports2.literal("rotated_pill_hole_with_rect_pad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),hole_shape:external_exports2.literal("rotated_pill"),pad_shape:external_exports2.literal("rect"),hole_width:external_exports2.number(),hole_height:external_exports2.number(),hole_ccw_rotation:rotation4,rect_pad_width:external_exports2.number(),rect_pad_height:external_exports2.number(),rect_border_radius:external_exports2.number().optional(),rect_ccw_rotation:rotation4,hole_offset_x:distance7.default(0),hole_offset_y:distance7.default(0),is_covered_with_solder_mask:external_exports2.boolean().optional(),x:distance7,y:distance7,layers:external_exports2.array(layer_ref2),port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),pcb_plated_hole_id:getZodPrefixedIdWithDefault2("pcb_plated_hole"),soldermask_margin:external_exports2.number().optional()}),pcb_hole_with_polygon_pad2=external_exports2.object({type:external_exports2.literal("pcb_plated_hole"),shape:external_exports2.literal("hole_with_polygon_pad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),hole_shape:external_exports2.enum(["circle","oval","pill","rotated_pill"]),hole_diameter:external_exports2.number().optional(),hole_width:external_exports2.number().optional(),hole_height:external_exports2.number().optional(),pad_outline:external_exports2.array(external_exports2.object({x:distance7,y:distance7})).min(3),hole_offset_x:distance7.default(0),hole_offset_y:distance7.default(0),is_covered_with_solder_mask:external_exports2.boolean().optional(),x:distance7,y:distance7,layers:external_exports2.array(layer_ref2),port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),pcb_plated_hole_id:getZodPrefixedIdWithDefault2("pcb_plated_hole"),soldermask_margin:external_exports2.number().optional(),ccw_rotation:rotation4.optional()}),pcb_plated_hole2=external_exports2.union([pcb_plated_hole_circle2,pcb_plated_hole_oval2,pcb_circular_hole_with_rect_pad2,pcb_pill_hole_with_rect_pad2,pcb_rotated_pill_hole_with_rect_pad2,pcb_hole_with_polygon_pad2]);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);var pcb_port2=external_exports2.object({type:external_exports2.literal("pcb_port"),pcb_port_id:getZodPrefixedIdWithDefault2("pcb_port"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),source_port_id:external_exports2.string(),pcb_component_id:external_exports2.string().optional(),x:distance7,y:distance7,layers:external_exports2.array(layer_ref2),is_board_pinout:external_exports2.boolean().optional()}).describe("Defines a port on the PCB");expectTypesMatch3(!0);var pcb_smtpad_circle2=external_exports2.object({type:external_exports2.literal("pcb_smtpad"),shape:external_exports2.literal("circle"),pcb_smtpad_id:getZodPrefixedIdWithDefault2("pcb_smtpad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,radius:external_exports2.number(),layer:layer_ref2,port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_smtpad_rect2=external_exports2.object({type:external_exports2.literal("pcb_smtpad"),shape:external_exports2.literal("rect"),pcb_smtpad_id:getZodPrefixedIdWithDefault2("pcb_smtpad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),rect_border_radius:external_exports2.number().optional(),corner_radius:external_exports2.number().optional(),layer:layer_ref2,port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional(),soldermask_margin_left:external_exports2.number().optional(),soldermask_margin_top:external_exports2.number().optional(),soldermask_margin_right:external_exports2.number().optional(),soldermask_margin_bottom:external_exports2.number().optional()}),pcb_smtpad_rotated_rect2=external_exports2.object({type:external_exports2.literal("pcb_smtpad"),shape:external_exports2.literal("rotated_rect"),pcb_smtpad_id:getZodPrefixedIdWithDefault2("pcb_smtpad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),rect_border_radius:external_exports2.number().optional(),corner_radius:external_exports2.number().optional(),ccw_rotation:rotation4,layer:layer_ref2,port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional(),soldermask_margin_left:external_exports2.number().optional(),soldermask_margin_top:external_exports2.number().optional(),soldermask_margin_right:external_exports2.number().optional(),soldermask_margin_bottom:external_exports2.number().optional()}),pcb_smtpad_pill2=external_exports2.object({type:external_exports2.literal("pcb_smtpad"),shape:external_exports2.literal("pill"),pcb_smtpad_id:getZodPrefixedIdWithDefault2("pcb_smtpad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),radius:external_exports2.number(),layer:layer_ref2,port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_smtpad_rotated_pill2=external_exports2.object({type:external_exports2.literal("pcb_smtpad"),shape:external_exports2.literal("rotated_pill"),pcb_smtpad_id:getZodPrefixedIdWithDefault2("pcb_smtpad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),radius:external_exports2.number(),ccw_rotation:rotation4,layer:layer_ref2,port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_smtpad_polygon2=external_exports2.object({type:external_exports2.literal("pcb_smtpad"),shape:external_exports2.literal("polygon"),pcb_smtpad_id:getZodPrefixedIdWithDefault2("pcb_smtpad"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),points:external_exports2.array(point5),layer:layer_ref2,port_hints:external_exports2.array(external_exports2.string()).optional(),pcb_component_id:external_exports2.string().optional(),pcb_port_id:external_exports2.string().optional(),is_covered_with_solder_mask:external_exports2.boolean().optional(),soldermask_margin:external_exports2.number().optional()}),pcb_smtpad2=external_exports2.discriminatedUnion("shape",[pcb_smtpad_circle2,pcb_smtpad_rect2,pcb_smtpad_rotated_rect2,pcb_smtpad_rotated_pill2,pcb_smtpad_pill2,pcb_smtpad_polygon2]).describe("Defines an SMT pad on the PCB");expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);var pcb_solder_paste_circle2=external_exports2.object({type:external_exports2.literal("pcb_solder_paste"),shape:external_exports2.literal("circle"),pcb_solder_paste_id:getZodPrefixedIdWithDefault2("pcb_solder_paste"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,radius:external_exports2.number(),layer:layer_ref2,pcb_component_id:external_exports2.string().optional(),pcb_smtpad_id:external_exports2.string().optional()}),pcb_solder_paste_rect2=external_exports2.object({type:external_exports2.literal("pcb_solder_paste"),shape:external_exports2.literal("rect"),pcb_solder_paste_id:getZodPrefixedIdWithDefault2("pcb_solder_paste"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),layer:layer_ref2,pcb_component_id:external_exports2.string().optional(),pcb_smtpad_id:external_exports2.string().optional()}),pcb_solder_paste_pill2=external_exports2.object({type:external_exports2.literal("pcb_solder_paste"),shape:external_exports2.literal("pill"),pcb_solder_paste_id:getZodPrefixedIdWithDefault2("pcb_solder_paste"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),radius:external_exports2.number(),layer:layer_ref2,pcb_component_id:external_exports2.string().optional(),pcb_smtpad_id:external_exports2.string().optional()}),pcb_solder_paste_rotated_rect2=external_exports2.object({type:external_exports2.literal("pcb_solder_paste"),shape:external_exports2.literal("rotated_rect"),pcb_solder_paste_id:getZodPrefixedIdWithDefault2("pcb_solder_paste"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),ccw_rotation:distance7,layer:layer_ref2,pcb_component_id:external_exports2.string().optional(),pcb_smtpad_id:external_exports2.string().optional()}),pcb_solder_paste_oval2=external_exports2.object({type:external_exports2.literal("pcb_solder_paste"),shape:external_exports2.literal("oval"),pcb_solder_paste_id:getZodPrefixedIdWithDefault2("pcb_solder_paste"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),x:distance7,y:distance7,width:external_exports2.number(),height:external_exports2.number(),layer:layer_ref2,pcb_component_id:external_exports2.string().optional(),pcb_smtpad_id:external_exports2.string().optional()}),pcb_solder_paste2=external_exports2.union([pcb_solder_paste_circle2,pcb_solder_paste_rect2,pcb_solder_paste_pill2,pcb_solder_paste_rotated_rect2,pcb_solder_paste_oval2]).describe("Defines solderpaste on the PCB");expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);var pcb_text2=external_exports2.object({type:external_exports2.literal("pcb_text"),pcb_text_id:getZodPrefixedIdWithDefault2("pcb_text"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),text:external_exports2.string(),center:point5,layer:layer_ref2,width:length3,height:length3,lines:external_exports2.number(),align:external_exports2.enum(["bottom-left"])}).describe("Defines text on the PCB");expectTypesMatch3(!0);var pcb_trace_route_point_wire2=external_exports2.object({route_type:external_exports2.literal("wire"),x:distance7,y:distance7,width:distance7,copper_pour_id:external_exports2.string().optional(),is_inside_copper_pour:external_exports2.boolean().optional(),start_pcb_port_id:external_exports2.string().optional(),end_pcb_port_id:external_exports2.string().optional(),layer:layer_ref2}),pcb_trace_route_point_via2=external_exports2.object({route_type:external_exports2.literal("via"),x:distance7,y:distance7,copper_pour_id:external_exports2.string().optional(),is_inside_copper_pour:external_exports2.boolean().optional(),hole_diameter:distance7.optional(),outer_diameter:distance7.optional(),from_layer:external_exports2.string(),to_layer:external_exports2.string()}),pcb_trace_route_point2=external_exports2.union([pcb_trace_route_point_wire2,pcb_trace_route_point_via2]),pcb_trace2=external_exports2.object({type:external_exports2.literal("pcb_trace"),source_trace_id:external_exports2.string().optional(),pcb_component_id:external_exports2.string().optional(),pcb_trace_id:getZodPrefixedIdWithDefault2("pcb_trace"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),route_thickness_mode:external_exports2.enum(["constant","interpolated"]).default("constant").optional(),route_order_index:external_exports2.number().optional(),should_round_corners:external_exports2.boolean().optional(),trace_length:external_exports2.number().optional(),highlight_color:external_exports2.string().optional(),route:external_exports2.array(pcb_trace_route_point2)}).describe("Defines a trace on the PCB");expectTypesMatch3(!0);expectTypesMatch3(!0);var pcb_trace_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_trace_error"),pcb_trace_error_id:getZodPrefixedIdWithDefault2("pcb_trace_error"),error_type:external_exports2.literal("pcb_trace_error").default("pcb_trace_error"),center:point5.optional(),pcb_trace_id:external_exports2.string(),source_trace_id:external_exports2.string(),pcb_component_ids:external_exports2.array(external_exports2.string()),pcb_port_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()}).describe("Defines a trace error on the PCB");expectTypesMatch3(!0);var pcb_trace_missing_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_trace_missing_error"),pcb_trace_missing_error_id:getZodPrefixedIdWithDefault2("pcb_trace_missing_error"),error_type:external_exports2.literal("pcb_trace_missing_error").default("pcb_trace_missing_error"),center:point5.optional(),source_trace_id:external_exports2.string(),pcb_component_ids:external_exports2.array(external_exports2.string()),pcb_port_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()}).describe("Defines an error when a source trace has no corresponding PCB trace");expectTypesMatch3(!0);var pcb_port_not_matched_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_port_not_matched_error"),pcb_error_id:getZodPrefixedIdWithDefault2("pcb_error"),error_type:external_exports2.literal("pcb_port_not_matched_error").default("pcb_port_not_matched_error"),pcb_component_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()}).describe("Defines a trace error on the PCB where a port is not matched");expectTypesMatch3(!0);var pcb_port_not_connected_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_port_not_connected_error"),pcb_port_not_connected_error_id:getZodPrefixedIdWithDefault2("pcb_port_not_connected_error"),error_type:external_exports2.literal("pcb_port_not_connected_error").default("pcb_port_not_connected_error"),pcb_port_ids:external_exports2.array(external_exports2.string()),pcb_component_ids:external_exports2.array(external_exports2.string()),subcircuit_id:external_exports2.string().optional()}).describe("Defines an error when a pcb port is not connected to any trace");expectTypesMatch3(!0);var pcb_net2=external_exports2.object({type:external_exports2.literal("pcb_net"),pcb_net_id:getZodPrefixedIdWithDefault2("pcb_net"),source_net_id:external_exports2.string().optional(),highlight_color:external_exports2.string().optional()}).describe("Defines a net on the PCB");expectTypesMatch3(!0);var pcb_via2=external_exports2.object({type:external_exports2.literal("pcb_via"),pcb_via_id:getZodPrefixedIdWithDefault2("pcb_via"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),subcircuit_connectivity_map_key:external_exports2.string().optional(),x:distance7,y:distance7,outer_diameter:distance7.default("0.6mm"),hole_diameter:distance7.default("0.25mm"),from_layer:layer_ref2.optional(),to_layer:layer_ref2.optional(),layers:external_exports2.array(layer_ref2),pcb_trace_id:external_exports2.string().optional(),net_is_assignable:external_exports2.boolean().optional(),net_assigned:external_exports2.boolean().optional(),is_tented:external_exports2.boolean().optional()}).describe("Defines a via on the PCB");expectTypesMatch3(!0);var pcb_board2=external_exports2.object({type:external_exports2.literal("pcb_board"),pcb_board_id:getZodPrefixedIdWithDefault2("pcb_board"),pcb_panel_id:external_exports2.string().optional(),carrier_pcb_board_id:external_exports2.string().optional(),is_subcircuit:external_exports2.boolean().optional(),subcircuit_id:external_exports2.string().optional(),is_mounted_to_carrier_board:external_exports2.boolean().optional(),width:length3.optional(),height:length3.optional(),center:point5,display_offset_x:external_exports2.string().optional().describe("How to display the x offset for this board, usually corresponding with how the user specified it"),display_offset_y:external_exports2.string().optional().describe("How to display the y offset for this board, usually corresponding with how the user specified it"),thickness:length3.optional().default(1.4),num_layers:external_exports2.number().optional().default(4),outline:external_exports2.array(point5).optional(),shape:external_exports2.enum(["rect","polygon"]).optional(),material:external_exports2.enum(["fr4","fr1"]).default("fr4"),anchor_position:point5.optional(),anchor_alignment:ninePointAnchor3.optional(),position_mode:external_exports2.enum(["relative_to_panel_anchor","none"]).optional()}).describe("Defines the board outline of the PCB");expectTypesMatch3(!0);var pcb_panel2=external_exports2.object({type:external_exports2.literal("pcb_panel"),pcb_panel_id:getZodPrefixedIdWithDefault2("pcb_panel"),width:length3,height:length3,center:point5,covered_with_solder_mask:external_exports2.boolean().optional().default(!0)}).describe("Defines a PCB panel that can contain multiple boards");expectTypesMatch3(!0);var pcb_placement_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_placement_error"),pcb_placement_error_id:getZodPrefixedIdWithDefault2("pcb_placement_error"),error_type:external_exports2.literal("pcb_placement_error").default("pcb_placement_error"),subcircuit_id:external_exports2.string().optional()}).describe("Defines a placement error on the PCB");expectTypesMatch3(!0);var pcb_panelization_placement_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_panelization_placement_error"),pcb_panelization_placement_error_id:getZodPrefixedIdWithDefault2("pcb_panelization_placement_error"),error_type:external_exports2.literal("pcb_panelization_placement_error").default("pcb_panelization_placement_error"),pcb_panel_id:external_exports2.string().optional(),pcb_board_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}).describe("Defines a panelization placement error on the PCB");expectTypesMatch3(!0);var pcb_trace_hint2=external_exports2.object({type:external_exports2.literal("pcb_trace_hint"),pcb_trace_hint_id:getZodPrefixedIdWithDefault2("pcb_trace_hint"),pcb_port_id:external_exports2.string(),pcb_component_id:external_exports2.string(),route:external_exports2.array(route_hint_point2),subcircuit_id:external_exports2.string().optional()}).describe("A hint that can be used during generation of a PCB trace");expectTypesMatch3(!0);var pcb_silkscreen_line2=external_exports2.object({type:external_exports2.literal("pcb_silkscreen_line"),pcb_silkscreen_line_id:getZodPrefixedIdWithDefault2("pcb_silkscreen_line"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),stroke_width:distance7.default("0.1mm"),x1:distance7,y1:distance7,x2:distance7,y2:distance7,layer:visible_layer2}).describe("Defines a silkscreen line on the PCB");expectTypesMatch3(!0);var pcb_silkscreen_path2=external_exports2.object({type:external_exports2.literal("pcb_silkscreen_path"),pcb_silkscreen_path_id:getZodPrefixedIdWithDefault2("pcb_silkscreen_path"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),layer:visible_layer2,route:external_exports2.array(point5),stroke_width:length3}).describe("Defines a silkscreen path on the PCB");expectTypesMatch3(!0);var pcb_silkscreen_text2=external_exports2.object({type:external_exports2.literal("pcb_silkscreen_text"),pcb_silkscreen_text_id:getZodPrefixedIdWithDefault2("pcb_silkscreen_text"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),font:external_exports2.literal("tscircuit2024").default("tscircuit2024"),font_size:distance7.default("0.2mm"),pcb_component_id:external_exports2.string(),text:external_exports2.string(),is_knockout:external_exports2.boolean().default(!1).optional(),knockout_padding:external_exports2.object({left:length3,top:length3,bottom:length3,right:length3}).default({left:"0.2mm",top:"0.2mm",bottom:"0.2mm",right:"0.2mm"}).optional(),ccw_rotation:external_exports2.number().optional(),layer:layer_ref2,is_mirrored:external_exports2.boolean().default(!1).optional(),anchor_position:point5.default({x:0,y:0}),anchor_alignment:ninePointAnchor3.default("center")}).describe("Defines silkscreen text on the PCB");expectTypesMatch3(!0);var pcb_copper_text2=external_exports2.object({type:external_exports2.literal("pcb_copper_text"),pcb_copper_text_id:getZodPrefixedIdWithDefault2("pcb_copper_text"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),font:external_exports2.literal("tscircuit2024").default("tscircuit2024"),font_size:distance7.default("0.2mm"),pcb_component_id:external_exports2.string(),text:external_exports2.string(),is_knockout:external_exports2.boolean().default(!1).optional(),knockout_padding:external_exports2.object({left:length3,top:length3,bottom:length3,right:length3}).default({left:"0.2mm",top:"0.2mm",bottom:"0.2mm",right:"0.2mm"}).optional(),ccw_rotation:external_exports2.number().optional(),layer:layer_ref2,is_mirrored:external_exports2.boolean().default(!1).optional(),anchor_position:point5.default({x:0,y:0}),anchor_alignment:ninePointAnchor3.default("center")}).describe("Defines copper text on the PCB");expectTypesMatch3(!0);var pcb_silkscreen_rect2=external_exports2.object({type:external_exports2.literal("pcb_silkscreen_rect"),pcb_silkscreen_rect_id:getZodPrefixedIdWithDefault2("pcb_silkscreen_rect"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,width:length3,height:length3,layer:layer_ref2,stroke_width:length3.default("1mm"),corner_radius:length3.optional(),is_filled:external_exports2.boolean().default(!0).optional(),has_stroke:external_exports2.boolean().optional(),is_stroke_dashed:external_exports2.boolean().optional(),ccw_rotation:external_exports2.number().optional()}).describe("Defines a silkscreen rect on the PCB");expectTypesMatch3(!0);var pcb_silkscreen_circle2=external_exports2.object({type:external_exports2.literal("pcb_silkscreen_circle"),pcb_silkscreen_circle_id:getZodPrefixedIdWithDefault2("pcb_silkscreen_circle"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,radius:length3,layer:visible_layer2,stroke_width:length3.default("1mm")}).describe("Defines a silkscreen circle on the PCB");expectTypesMatch3(!0);var pcb_silkscreen_oval2=external_exports2.object({type:external_exports2.literal("pcb_silkscreen_oval"),pcb_silkscreen_oval_id:getZodPrefixedIdWithDefault2("pcb_silkscreen_oval"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,radius_x:distance7,radius_y:distance7,layer:visible_layer2,ccw_rotation:rotation4.optional()}).describe("Defines a silkscreen oval on the PCB");expectTypesMatch3(!0);var pcb_silkscreen_pill2=external_exports2.object({type:external_exports2.literal("pcb_silkscreen_pill"),pcb_silkscreen_pill_id:getZodPrefixedIdWithDefault2("pcb_silkscreen_pill"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,width:length3,height:length3,layer:layer_ref2,ccw_rotation:external_exports2.number().optional()}).describe("Defines a silkscreen pill on the PCB");expectTypesMatch3(!0);var pcb_fabrication_note_text2=external_exports2.object({type:external_exports2.literal("pcb_fabrication_note_text"),pcb_fabrication_note_text_id:getZodPrefixedIdWithDefault2("pcb_fabrication_note_text"),subcircuit_id:external_exports2.string().optional(),pcb_group_id:external_exports2.string().optional(),font:external_exports2.literal("tscircuit2024").default("tscircuit2024"),font_size:distance7.default("1mm"),pcb_component_id:external_exports2.string(),text:external_exports2.string(),layer:visible_layer2,anchor_position:point5.default({x:0,y:0}),anchor_alignment:external_exports2.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),color:external_exports2.string().optional()}).describe("Defines a fabrication note in text on the PCB, useful for leaving notes for assemblers or fabricators");expectTypesMatch3(!0);var pcb_fabrication_note_path2=external_exports2.object({type:external_exports2.literal("pcb_fabrication_note_path"),pcb_fabrication_note_path_id:getZodPrefixedIdWithDefault2("pcb_fabrication_note_path"),pcb_component_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional(),layer:layer_ref2,route:external_exports2.array(point5),stroke_width:length3,color:external_exports2.string().optional()}).describe("Defines a fabrication path on the PCB for fabricators or assemblers");expectTypesMatch3(!0);var pcb_fabrication_note_rect2=external_exports2.object({type:external_exports2.literal("pcb_fabrication_note_rect"),pcb_fabrication_note_rect_id:getZodPrefixedIdWithDefault2("pcb_fabrication_note_rect"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,width:length3,height:length3,layer:visible_layer2,stroke_width:length3.default("0.1mm"),corner_radius:length3.optional(),is_filled:external_exports2.boolean().optional(),has_stroke:external_exports2.boolean().optional(),is_stroke_dashed:external_exports2.boolean().optional(),color:external_exports2.string().optional()}).describe("Defines a fabrication note rectangle on the PCB");expectTypesMatch3(!0);var pcb_fabrication_note_dimension2=external_exports2.object({type:external_exports2.literal("pcb_fabrication_note_dimension"),pcb_fabrication_note_dimension_id:getZodPrefixedIdWithDefault2("pcb_fabrication_note_dimension"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),layer:visible_layer2,from:point5,to:point5,text:external_exports2.string().optional(),text_ccw_rotation:external_exports2.number().optional(),offset:length3.optional(),offset_distance:length3.optional(),offset_direction:external_exports2.object({x:external_exports2.number(),y:external_exports2.number()}).optional(),font:external_exports2.literal("tscircuit2024").default("tscircuit2024"),font_size:length3.default("1mm"),color:external_exports2.string().optional(),arrow_size:length3.default("1mm")}).describe("Defines a measurement annotation within PCB fabrication notes");expectTypesMatch3(!0);var pcb_note_text2=external_exports2.object({type:external_exports2.literal("pcb_note_text"),pcb_note_text_id:getZodPrefixedIdWithDefault2("pcb_note_text"),pcb_component_id:external_exports2.string().optional(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),name:external_exports2.string().optional(),font:external_exports2.literal("tscircuit2024").default("tscircuit2024"),font_size:distance7.default("1mm"),text:external_exports2.string().optional(),anchor_position:point5.default({x:0,y:0}),anchor_alignment:external_exports2.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),color:external_exports2.string().optional()}).describe("Defines a documentation note in text on the PCB");expectTypesMatch3(!0);var pcb_note_rect2=external_exports2.object({type:external_exports2.literal("pcb_note_rect"),pcb_note_rect_id:getZodPrefixedIdWithDefault2("pcb_note_rect"),pcb_component_id:external_exports2.string().optional(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),name:external_exports2.string().optional(),text:external_exports2.string().optional(),center:point5,width:length3,height:length3,stroke_width:length3.default("0.1mm"),corner_radius:length3.optional(),is_filled:external_exports2.boolean().optional(),has_stroke:external_exports2.boolean().optional(),is_stroke_dashed:external_exports2.boolean().optional(),color:external_exports2.string().optional()}).describe("Defines a rectangular documentation note on the PCB");expectTypesMatch3(!0);var pcb_note_path2=external_exports2.object({type:external_exports2.literal("pcb_note_path"),pcb_note_path_id:getZodPrefixedIdWithDefault2("pcb_note_path"),pcb_component_id:external_exports2.string().optional(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),name:external_exports2.string().optional(),text:external_exports2.string().optional(),route:external_exports2.array(point5),stroke_width:length3.default("0.1mm"),color:external_exports2.string().optional()}).describe("Defines a polyline documentation note on the PCB");expectTypesMatch3(!0);var pcb_note_line2=external_exports2.object({type:external_exports2.literal("pcb_note_line"),pcb_note_line_id:getZodPrefixedIdWithDefault2("pcb_note_line"),pcb_component_id:external_exports2.string().optional(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),name:external_exports2.string().optional(),text:external_exports2.string().optional(),x1:distance7,y1:distance7,x2:distance7,y2:distance7,stroke_width:distance7.default("0.1mm"),color:external_exports2.string().optional(),is_dashed:external_exports2.boolean().optional()}).describe("Defines a straight documentation note line on the PCB");expectTypesMatch3(!0);var pcb_note_dimension2=external_exports2.object({type:external_exports2.literal("pcb_note_dimension"),pcb_note_dimension_id:getZodPrefixedIdWithDefault2("pcb_note_dimension"),pcb_component_id:external_exports2.string().optional(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),name:external_exports2.string().optional(),from:point5,to:point5,text:external_exports2.string().optional(),text_ccw_rotation:external_exports2.number().optional(),offset_distance:length3.optional(),offset_direction:external_exports2.object({x:external_exports2.number(),y:external_exports2.number()}).optional(),font:external_exports2.literal("tscircuit2024").default("tscircuit2024"),font_size:length3.default("1mm"),color:external_exports2.string().optional(),arrow_size:length3.default("1mm")}).describe("Defines a measurement annotation within PCB documentation notes");expectTypesMatch3(!0);var pcb_footprint_overlap_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_footprint_overlap_error"),pcb_error_id:getZodPrefixedIdWithDefault2("pcb_error"),error_type:external_exports2.literal("pcb_footprint_overlap_error").default("pcb_footprint_overlap_error"),pcb_smtpad_ids:external_exports2.array(external_exports2.string()).optional(),pcb_plated_hole_ids:external_exports2.array(external_exports2.string()).optional(),pcb_hole_ids:external_exports2.array(external_exports2.string()).optional(),pcb_keepout_ids:external_exports2.array(external_exports2.string()).optional()}).describe("Error emitted when a pcb footprint overlaps with another element");expectTypesMatch3(!0);var pcb_courtyard_overlap_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_courtyard_overlap_error"),pcb_error_id:getZodPrefixedIdWithDefault2("pcb_error"),error_type:external_exports2.literal("pcb_courtyard_overlap_error").default("pcb_courtyard_overlap_error"),pcb_component_ids:external_exports2.tuple([external_exports2.string(),external_exports2.string()])}).describe("Error emitted when the courtyard (CrtYd) of one PCB component overlaps with the courtyard of another");expectTypesMatch3(!0);var pcb_keepout2=external_exports2.object({type:external_exports2.literal("pcb_keepout"),shape:external_exports2.literal("rect"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,width:distance7,height:distance7,pcb_keepout_id:external_exports2.string(),layers:external_exports2.array(external_exports2.string()),description:external_exports2.string().optional()}).or(external_exports2.object({type:external_exports2.literal("pcb_keepout"),shape:external_exports2.literal("circle"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,radius:distance7,pcb_keepout_id:external_exports2.string(),layers:external_exports2.array(external_exports2.string()),description:external_exports2.string().optional()}));expectTypesMatch3(!0);var pcb_cutout_base2=external_exports2.object({type:external_exports2.literal("pcb_cutout"),pcb_cutout_id:getZodPrefixedIdWithDefault2("pcb_cutout"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),pcb_board_id:external_exports2.string().optional(),pcb_panel_id:external_exports2.string().optional()}),pcb_cutout_rect2=pcb_cutout_base2.extend({shape:external_exports2.literal("rect"),center:point5,width:length3,height:length3,rotation:rotation4.optional(),corner_radius:length3.optional()});expectTypesMatch3(!0);var pcb_cutout_circle2=pcb_cutout_base2.extend({shape:external_exports2.literal("circle"),center:point5,radius:length3});expectTypesMatch3(!0);var pcb_cutout_polygon2=pcb_cutout_base2.extend({shape:external_exports2.literal("polygon"),points:external_exports2.array(point5)});expectTypesMatch3(!0);var pcb_cutout_path2=pcb_cutout_base2.extend({shape:external_exports2.literal("path"),route:external_exports2.array(point5),slot_width:length3,slot_length:length3.optional(),space_between_slots:length3.optional(),slot_corner_radius:length3.optional()});expectTypesMatch3(!0);var pcb_cutout2=external_exports2.discriminatedUnion("shape",[pcb_cutout_rect2,pcb_cutout_circle2,pcb_cutout_polygon2,pcb_cutout_path2]).describe("Defines a cutout on the PCB, removing board material.");expectTypesMatch3(!0);var pcb_missing_footprint_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_missing_footprint_error"),pcb_missing_footprint_error_id:getZodPrefixedIdWithDefault2("pcb_missing_footprint_error"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),error_type:external_exports2.literal("pcb_missing_footprint_error").default("pcb_missing_footprint_error"),source_component_id:external_exports2.string()}).describe("Defines a missing footprint error on the PCB");expectTypesMatch3(!0);var external_footprint_load_error2=base_circuit_json_error2.extend({type:external_exports2.literal("external_footprint_load_error"),external_footprint_load_error_id:getZodPrefixedIdWithDefault2("external_footprint_load_error"),pcb_component_id:external_exports2.string(),source_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),footprinter_string:external_exports2.string().optional(),error_type:external_exports2.literal("external_footprint_load_error").default("external_footprint_load_error")}).describe("Defines an error when an external footprint fails to load");expectTypesMatch3(!0);var circuit_json_footprint_load_error2=base_circuit_json_error2.extend({type:external_exports2.literal("circuit_json_footprint_load_error"),circuit_json_footprint_load_error_id:getZodPrefixedIdWithDefault2("circuit_json_footprint_load_error"),pcb_component_id:external_exports2.string(),source_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),error_type:external_exports2.literal("circuit_json_footprint_load_error").default("circuit_json_footprint_load_error"),circuit_json:external_exports2.array(external_exports2.any()).optional()}).describe("Defines an error when a circuit JSON footprint fails to load");expectTypesMatch3(!0);var pcb_group2=external_exports2.object({type:external_exports2.literal("pcb_group"),pcb_group_id:getZodPrefixedIdWithDefault2("pcb_group"),source_group_id:external_exports2.string(),is_subcircuit:external_exports2.boolean().optional(),subcircuit_id:external_exports2.string().optional(),width:length3.optional(),height:length3.optional(),center:point5,display_offset_x:external_exports2.string().optional().describe("How to display the x offset for this group, usually corresponding with how the user specified it"),display_offset_y:external_exports2.string().optional().describe("How to display the y offset for this group, usually corresponding with how the user specified it"),outline:external_exports2.array(point5).optional(),anchor_position:point5.optional(),anchor_alignment:ninePointAnchor3.default("center"),position_mode:external_exports2.enum(["packed","relative_to_group_anchor","none"]).optional(),positioned_relative_to_pcb_group_id:external_exports2.string().optional(),positioned_relative_to_pcb_board_id:external_exports2.string().optional(),pcb_component_ids:external_exports2.array(external_exports2.string()),child_layout_mode:external_exports2.enum(["packed","none"]).optional(),name:external_exports2.string().optional(),description:external_exports2.string().optional(),layout_mode:external_exports2.string().optional(),autorouter_configuration:external_exports2.object({trace_clearance:length3}).optional(),autorouter_used_string:external_exports2.string().optional()}).describe("Defines a group of components on the PCB");expectTypesMatch3(!0);var pcb_autorouting_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_autorouting_error"),pcb_error_id:getZodPrefixedIdWithDefault2("pcb_autorouting_error"),error_type:external_exports2.literal("pcb_autorouting_error").default("pcb_autorouting_error"),subcircuit_id:external_exports2.string().optional()}).describe("The autorouting has failed to route a portion of the board");expectTypesMatch3(!0);var pcb_manual_edit_conflict_warning2=external_exports2.object({type:external_exports2.literal("pcb_manual_edit_conflict_warning"),pcb_manual_edit_conflict_warning_id:getZodPrefixedIdWithDefault2("pcb_manual_edit_conflict_warning"),warning_type:external_exports2.literal("pcb_manual_edit_conflict_warning").default("pcb_manual_edit_conflict_warning"),message:external_exports2.string(),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),source_component_id:external_exports2.string()}).describe("Warning emitted when a component has both manual placement and explicit pcbX/pcbY coordinates");expectTypesMatch3(!0);var connectorOrientationDirection2=external_exports2.enum(["x-","x+","y+","y-"]),pcb_connector_not_in_accessible_orientation_warning2=external_exports2.object({type:external_exports2.literal("pcb_connector_not_in_accessible_orientation_warning"),pcb_connector_not_in_accessible_orientation_warning_id:getZodPrefixedIdWithDefault2("pcb_connector_not_in_accessible_orientation_warning"),warning_type:external_exports2.literal("pcb_connector_not_in_accessible_orientation_warning").default("pcb_connector_not_in_accessible_orientation_warning"),message:external_exports2.string(),pcb_component_id:external_exports2.string(),source_component_id:external_exports2.string().optional(),pcb_board_id:external_exports2.string().optional(),facing_direction:connectorOrientationDirection2,recommended_facing_direction:connectorOrientationDirection2,subcircuit_id:external_exports2.string().optional()}).describe("Warning emitted when a connector PCB component is facing inward toward the board and should be reoriented to an outward-facing direction");expectTypesMatch3(!0);var pcb_breakout_point2=external_exports2.object({type:external_exports2.literal("pcb_breakout_point"),pcb_breakout_point_id:getZodPrefixedIdWithDefault2("pcb_breakout_point"),pcb_group_id:external_exports2.string(),subcircuit_id:external_exports2.string().optional(),source_trace_id:external_exports2.string().optional(),source_port_id:external_exports2.string().optional(),source_net_id:external_exports2.string().optional(),x:distance7,y:distance7}).describe("Defines a routing target within a pcb_group for a source_trace or source_net");expectTypesMatch3(!0);var pcb_ground_plane2=external_exports2.object({type:external_exports2.literal("pcb_ground_plane"),pcb_ground_plane_id:getZodPrefixedIdWithDefault2("pcb_ground_plane"),source_pcb_ground_plane_id:external_exports2.string(),source_net_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}).describe("Defines a ground plane on the PCB");expectTypesMatch3(!0);var pcb_ground_plane_region2=external_exports2.object({type:external_exports2.literal("pcb_ground_plane_region"),pcb_ground_plane_region_id:getZodPrefixedIdWithDefault2("pcb_ground_plane_region"),pcb_ground_plane_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),layer:layer_ref2,points:external_exports2.array(point5)}).describe("Defines a polygon region of a ground plane");expectTypesMatch3(!0);var pcb_thermal_spoke2=external_exports2.object({type:external_exports2.literal("pcb_thermal_spoke"),pcb_thermal_spoke_id:getZodPrefixedIdWithDefault2("pcb_thermal_spoke"),pcb_ground_plane_id:external_exports2.string(),shape:external_exports2.string(),spoke_count:external_exports2.number(),spoke_thickness:distance7,spoke_inner_diameter:distance7,spoke_outer_diameter:distance7,pcb_plated_hole_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}).describe("Pattern for connecting a ground plane to a plated hole");expectTypesMatch3(!0);var pcb_copper_pour_base2=external_exports2.object({type:external_exports2.literal("pcb_copper_pour"),pcb_copper_pour_id:getZodPrefixedIdWithDefault2("pcb_copper_pour"),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),layer:layer_ref2,source_net_id:external_exports2.string().optional(),covered_with_solder_mask:external_exports2.boolean().optional().default(!0)}),pcb_copper_pour_rect2=pcb_copper_pour_base2.extend({shape:external_exports2.literal("rect"),center:point5,width:length3,height:length3,rotation:rotation4.optional()});expectTypesMatch3(!0);var pcb_copper_pour_brep2=pcb_copper_pour_base2.extend({shape:external_exports2.literal("brep"),brep_shape:brep_shape2});expectTypesMatch3(!0);var pcb_copper_pour_polygon2=pcb_copper_pour_base2.extend({shape:external_exports2.literal("polygon"),points:external_exports2.array(point5)});expectTypesMatch3(!0);var pcb_copper_pour2=external_exports2.discriminatedUnion("shape",[pcb_copper_pour_rect2,pcb_copper_pour_brep2,pcb_copper_pour_polygon2]).describe("Defines a copper pour on the PCB.");expectTypesMatch3(!0);var pcb_component_outside_board_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_component_outside_board_error"),pcb_component_outside_board_error_id:getZodPrefixedIdWithDefault2("pcb_component_outside_board_error"),error_type:external_exports2.literal("pcb_component_outside_board_error").default("pcb_component_outside_board_error"),pcb_component_id:external_exports2.string(),pcb_board_id:external_exports2.string(),component_center:point5,component_bounds:external_exports2.object({min_x:external_exports2.number(),max_x:external_exports2.number(),min_y:external_exports2.number(),max_y:external_exports2.number()}),subcircuit_id:external_exports2.string().optional(),source_component_id:external_exports2.string().optional()}).describe("Error emitted when a PCB component is placed outside the board boundaries");expectTypesMatch3(!0);var pcb_component_not_on_board_edge_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_component_not_on_board_edge_error"),pcb_component_not_on_board_edge_error_id:getZodPrefixedIdWithDefault2("pcb_component_not_on_board_edge_error"),error_type:external_exports2.literal("pcb_component_not_on_board_edge_error").default("pcb_component_not_on_board_edge_error"),pcb_component_id:external_exports2.string(),pcb_board_id:external_exports2.string(),component_center:point5,pad_to_nearest_board_edge_distance:external_exports2.number(),source_component_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}).describe("Error emitted when a component that must be placed on the board edge is centered away from the edge");expectTypesMatch3(!0);var pcb_component_invalid_layer_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_component_invalid_layer_error"),pcb_component_invalid_layer_error_id:getZodPrefixedIdWithDefault2("pcb_component_invalid_layer_error"),error_type:external_exports2.literal("pcb_component_invalid_layer_error").default("pcb_component_invalid_layer_error"),pcb_component_id:external_exports2.string().optional(),source_component_id:external_exports2.string(),layer:layer_ref2,subcircuit_id:external_exports2.string().optional()}).describe("Error emitted when a component is placed on an invalid layer (components can only be on 'top' or 'bottom' layers)");expectTypesMatch3(!0);var pcb_via_clearance_error2=base_circuit_json_error2.extend({type:external_exports2.literal("pcb_via_clearance_error"),pcb_error_id:getZodPrefixedIdWithDefault2("pcb_error"),error_type:external_exports2.literal("pcb_via_clearance_error").default("pcb_via_clearance_error"),pcb_via_ids:external_exports2.array(external_exports2.string()).min(2),minimum_clearance:distance7.optional(),actual_clearance:distance7.optional(),pcb_center:external_exports2.object({x:external_exports2.number().optional(),y:external_exports2.number().optional()}).optional(),subcircuit_id:external_exports2.string().optional()}).describe("Error emitted when vias are closer than the allowed clearance");expectTypesMatch3(!0);var pcb_courtyard_rect2=external_exports2.object({type:external_exports2.literal("pcb_courtyard_rect"),pcb_courtyard_rect_id:getZodPrefixedIdWithDefault2("pcb_courtyard_rect"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,width:length3,height:length3,layer:visible_layer2,ccw_rotation:rotation4.optional(),color:external_exports2.string().optional()}).describe("Defines a courtyard rectangle on the PCB");expectTypesMatch3(!0);var pcb_courtyard_outline2=external_exports2.object({type:external_exports2.literal("pcb_courtyard_outline"),pcb_courtyard_outline_id:getZodPrefixedIdWithDefault2("pcb_courtyard_outline"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),layer:visible_layer2,outline:external_exports2.array(point5).min(2)}).describe("Defines a courtyard outline on the PCB");expectTypesMatch3(!0);var pcb_courtyard_polygon2=external_exports2.object({type:external_exports2.literal("pcb_courtyard_polygon"),pcb_courtyard_polygon_id:getZodPrefixedIdWithDefault2("pcb_courtyard_polygon"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),layer:visible_layer2,points:external_exports2.array(point5).min(3),color:external_exports2.string().optional()}).describe("Defines a courtyard polygon on the PCB");expectTypesMatch3(!0);var pcb_courtyard_circle2=external_exports2.object({type:external_exports2.literal("pcb_courtyard_circle"),pcb_courtyard_circle_id:getZodPrefixedIdWithDefault2("pcb_courtyard_circle"),pcb_component_id:external_exports2.string(),pcb_group_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),center:point5,radius:length3,layer:visible_layer2,color:external_exports2.string().optional()}).describe("Defines a courtyard circle on the PCB");expectTypesMatch3(!0);var cad_model_formats2=["obj","stl","3mf","gltf","glb","step","wrl"],cad_model_axis_directions2=["x+","x-","y+","y-","z+","z-"],cadModelDefaultDirectionMap2={obj:"z+",stl:"z+","3mf":"z+",gltf:"y+",glb:"y+",step:"z+",wrl:"y+"},cad_component2=external_exports2.object({type:external_exports2.literal("cad_component"),cad_component_id:external_exports2.string(),pcb_component_id:external_exports2.string(),source_component_id:external_exports2.string(),position:point33,rotation:point33.optional(),size:point33.optional(),layer:layer_ref2.optional(),subcircuit_id:external_exports2.string().optional(),footprinter_string:external_exports2.string().optional(),model_obj_url:external_exports2.string().optional(),model_stl_url:external_exports2.string().optional(),model_3mf_url:external_exports2.string().optional(),model_gltf_url:external_exports2.string().optional(),model_glb_url:external_exports2.string().optional(),model_step_url:external_exports2.string().optional(),model_wrl_url:external_exports2.string().optional(),model_asset:asset2.optional(),model_unit_to_mm_scale_factor:external_exports2.number().optional(),model_board_normal_direction:external_exports2.enum(cad_model_axis_directions2).optional().describe(`The direction in the model's coordinate space that is considered "up" or "coming out of the board surface"`),model_origin_position:point33.optional(),model_origin_alignment:external_exports2.enum(["unknown","center","center_of_component_on_board_surface","bottom_center_of_component"]).optional(),model_object_fit:external_exports2.enum(["contain_within_bounds","fill_bounds"]).optional().default("contain_within_bounds"),model_jscad:external_exports2.any().optional(),show_as_translucent_model:external_exports2.boolean().optional(),anchor_alignment:external_exports2.enum(["center","center_of_component_on_board_surface"]).optional().default("center")}).describe("Defines a component on the PCB");expectTypesMatch3(!0);var wave_shape2=external_exports2.enum(["sinewave","square","triangle","sawtooth"]),percentage4=external_exports2.union([external_exports2.string(),external_exports2.number()]).transform(val=>typeof val=="string"?val.endsWith("%")?parseFloat(val.slice(0,-1))/100:parseFloat(val):val).pipe(external_exports2.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),simulation_dc_voltage_source2=external_exports2.object({type:external_exports2.literal("simulation_voltage_source"),simulation_voltage_source_id:getZodPrefixedIdWithDefault2("simulation_voltage_source"),is_dc_source:external_exports2.literal(!0).optional().default(!0),positive_source_port_id:external_exports2.string().optional(),negative_source_port_id:external_exports2.string().optional(),positive_source_net_id:external_exports2.string().optional(),negative_source_net_id:external_exports2.string().optional(),voltage:voltage2}).describe("Defines a DC voltage source for simulation"),simulation_ac_voltage_source2=external_exports2.object({type:external_exports2.literal("simulation_voltage_source"),simulation_voltage_source_id:getZodPrefixedIdWithDefault2("simulation_voltage_source"),is_dc_source:external_exports2.literal(!1),terminal1_source_port_id:external_exports2.string().optional(),terminal2_source_port_id:external_exports2.string().optional(),terminal1_source_net_id:external_exports2.string().optional(),terminal2_source_net_id:external_exports2.string().optional(),voltage:voltage2.optional(),frequency:frequency2.optional(),peak_to_peak_voltage:voltage2.optional(),wave_shape:wave_shape2.optional(),phase:rotation4.optional(),duty_cycle:percentage4.optional()}).describe("Defines an AC voltage source for simulation"),simulation_voltage_source2=external_exports2.union([simulation_dc_voltage_source2,simulation_ac_voltage_source2]).describe("Defines a voltage source for simulation");expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);var percentage23=external_exports2.union([external_exports2.string(),external_exports2.number()]).transform(val=>typeof val=="string"?val.endsWith("%")?parseFloat(val.slice(0,-1))/100:parseFloat(val):val).pipe(external_exports2.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),simulation_dc_current_source2=external_exports2.object({type:external_exports2.literal("simulation_current_source"),simulation_current_source_id:getZodPrefixedIdWithDefault2("simulation_current_source"),is_dc_source:external_exports2.literal(!0).optional().default(!0),positive_source_port_id:external_exports2.string().optional(),negative_source_port_id:external_exports2.string().optional(),positive_source_net_id:external_exports2.string().optional(),negative_source_net_id:external_exports2.string().optional(),current:current2}).describe("Defines a DC current source for simulation"),simulation_ac_current_source2=external_exports2.object({type:external_exports2.literal("simulation_current_source"),simulation_current_source_id:getZodPrefixedIdWithDefault2("simulation_current_source"),is_dc_source:external_exports2.literal(!1),terminal1_source_port_id:external_exports2.string().optional(),terminal2_source_port_id:external_exports2.string().optional(),terminal1_source_net_id:external_exports2.string().optional(),terminal2_source_net_id:external_exports2.string().optional(),current:current2.optional(),frequency:frequency2.optional(),peak_to_peak_current:current2.optional(),wave_shape:wave_shape2.optional(),phase:rotation4.optional(),duty_cycle:percentage23.optional()}).describe("Defines an AC current source for simulation"),simulation_current_source2=external_exports2.union([simulation_dc_current_source2,simulation_ac_current_source2]).describe("Defines a current source for simulation");expectTypesMatch3(!0);expectTypesMatch3(!0);expectTypesMatch3(!0);var experiment_type2=external_exports2.union([external_exports2.literal("spice_dc_sweep"),external_exports2.literal("spice_dc_operating_point"),external_exports2.literal("spice_transient_analysis"),external_exports2.literal("spice_ac_analysis")]),simulation_experiment2=external_exports2.object({type:external_exports2.literal("simulation_experiment"),simulation_experiment_id:getZodPrefixedIdWithDefault2("simulation_experiment"),name:external_exports2.string(),experiment_type:experiment_type2,time_per_step:duration_ms2.optional(),start_time_ms:ms4.optional(),end_time_ms:ms4.optional()}).describe("Defines a simulation experiment configuration");expectTypesMatch3(!0);var simulation_transient_voltage_graph2=external_exports2.object({type:external_exports2.literal("simulation_transient_voltage_graph"),simulation_transient_voltage_graph_id:getZodPrefixedIdWithDefault2("simulation_transient_voltage_graph"),simulation_experiment_id:external_exports2.string(),timestamps_ms:external_exports2.array(external_exports2.number()).optional(),voltage_levels:external_exports2.array(external_exports2.number()),source_component_id:external_exports2.string().optional(),subcircuit_connectivity_map_key:external_exports2.string().optional(),time_per_step:duration_ms2,start_time_ms:ms4,end_time_ms:ms4,name:external_exports2.string().optional(),color:external_exports2.string().optional()}).describe("Stores voltage measurements over time for a simulation");expectTypesMatch3(!0);var simulation_switch2=external_exports2.object({type:external_exports2.literal("simulation_switch"),simulation_switch_id:getZodPrefixedIdWithDefault2("simulation_switch"),source_component_id:external_exports2.string().optional(),closes_at:ms4.optional(),opens_at:ms4.optional(),starts_closed:external_exports2.boolean().optional(),switching_frequency:frequency2.optional()}).describe("Defines a switch for simulation timing control");expectTypesMatch3(!0);var simulation_voltage_probe2=external_exports2.object({type:external_exports2.literal("simulation_voltage_probe"),simulation_voltage_probe_id:getZodPrefixedIdWithDefault2("simulation_voltage_probe"),source_component_id:external_exports2.string().optional(),name:external_exports2.string().optional(),signal_input_source_port_id:external_exports2.string().optional(),signal_input_source_net_id:external_exports2.string().optional(),reference_input_source_port_id:external_exports2.string().optional(),reference_input_source_net_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional(),color:external_exports2.string().optional()}).describe("Defines a voltage probe for simulation. If a reference input is not provided, it measures against ground. If a reference input is provided, it measures the differential voltage between two points.").superRefine((data,ctx)=>{if(data.reference_input_source_port_id||data.reference_input_source_net_id){let has_ports=!!data.signal_input_source_port_id||!!data.reference_input_source_port_id,has_nets=!!data.signal_input_source_net_id||!!data.reference_input_source_net_id;has_ports&&has_nets?ctx.addIssue({code:external_exports2.ZodIssueCode.custom,message:"Cannot mix port and net connections in a differential probe."}):has_ports?(!data.signal_input_source_port_id||!data.reference_input_source_port_id)&&ctx.addIssue({code:external_exports2.ZodIssueCode.custom,message:"Differential port probe requires both signal_input_source_port_id and reference_input_source_port_id."}):has_nets&&(!data.signal_input_source_net_id||!data.reference_input_source_net_id)&&ctx.addIssue({code:external_exports2.ZodIssueCode.custom,message:"Differential net probe requires both signal_input_source_net_id and reference_input_source_net_id."})}else!!data.signal_input_source_port_id==!!data.signal_input_source_net_id&&ctx.addIssue({code:external_exports2.ZodIssueCode.custom,message:"A voltage probe must have exactly one of signal_input_source_port_id or signal_input_source_net_id."})});expectTypesMatch3(!0);var simulation_unknown_experiment_error2=base_circuit_json_error2.extend({type:external_exports2.literal("simulation_unknown_experiment_error"),simulation_unknown_experiment_error_id:getZodPrefixedIdWithDefault2("simulation_unknown_experiment_error"),error_type:external_exports2.literal("simulation_unknown_experiment_error").default("simulation_unknown_experiment_error"),simulation_experiment_id:external_exports2.string().optional(),subcircuit_id:external_exports2.string().optional()}).describe("An unknown error occurred during the simulation experiment.");expectTypesMatch3(!0);var simulation_op_amp2=external_exports2.object({type:external_exports2.literal("simulation_op_amp"),simulation_op_amp_id:getZodPrefixedIdWithDefault2("simulation_op_amp"),source_component_id:external_exports2.string().optional(),inverting_input_source_port_id:external_exports2.string(),non_inverting_input_source_port_id:external_exports2.string(),output_source_port_id:external_exports2.string(),positive_supply_source_port_id:external_exports2.string(),negative_supply_source_port_id:external_exports2.string()}).describe("Defines a simple ideal operational amplifier for simulation");expectTypesMatch3(!0);var any_circuit_element2=external_exports2.union([source_trace2,source_port2,source_component_internal_connection2,any_source_component2,source_net2,source_group2,source_simple_chip2,source_simple_capacitor2,source_simple_diode2,source_simple_led2,source_simple_resistor2,source_simple_power_source2,source_simple_battery2,source_simple_inductor2,source_simple_pin_header2,source_simple_pinout2,source_simple_resonator2,source_simple_switch2,source_simple_transistor2,source_simple_test_point2,source_simple_mosfet2,source_simple_op_amp2,source_simple_potentiometer2,source_simple_push_button2,source_pcb_ground_plane2,source_manually_placed_via2,source_board2,source_project_metadata2,source_invalid_component_property_error2,source_trace_not_connected_error2,source_pin_missing_trace_warning2,source_no_power_pin_defined_warning2,source_no_ground_pin_defined_warning2,source_component_pins_underspecified_warning2,source_pin_must_be_connected_error2,unknown_error_finding_part2,source_i2c_misconfigured_error2,source_ambiguous_port_reference2,pcb_component2,pcb_hole2,pcb_missing_footprint_error2,external_footprint_load_error2,circuit_json_footprint_load_error2,pcb_manual_edit_conflict_warning2,pcb_connector_not_in_accessible_orientation_warning2,pcb_plated_hole2,pcb_keepout2,pcb_port2,pcb_net2,pcb_text2,pcb_trace2,pcb_via2,pcb_smtpad2,pcb_solder_paste2,pcb_board2,pcb_panel2,pcb_group2,pcb_trace_hint2,pcb_silkscreen_line2,pcb_silkscreen_path2,pcb_silkscreen_text2,pcb_silkscreen_pill2,pcb_copper_text2,pcb_silkscreen_rect2,pcb_silkscreen_circle2,pcb_silkscreen_oval2,pcb_trace_error2,pcb_trace_missing_error2,pcb_placement_error2,pcb_panelization_placement_error2,pcb_port_not_matched_error2,pcb_port_not_connected_error2,pcb_via_clearance_error2,pcb_fabrication_note_path2,pcb_fabrication_note_text2,pcb_fabrication_note_rect2,pcb_fabrication_note_dimension2,pcb_note_text2,pcb_note_rect2,pcb_note_path2,pcb_note_line2,pcb_note_dimension2,pcb_autorouting_error2,pcb_footprint_overlap_error2,pcb_courtyard_overlap_error2,pcb_breakout_point2,pcb_cutout2,pcb_ground_plane2,pcb_ground_plane_region2,pcb_thermal_spoke2,pcb_copper_pour2,pcb_component_outside_board_error2,pcb_component_not_on_board_edge_error2,pcb_component_invalid_layer_error2,pcb_courtyard_rect2,pcb_courtyard_outline2,pcb_courtyard_polygon2,pcb_courtyard_circle2,schematic_box2,schematic_text2,schematic_line2,schematic_rect2,schematic_circle2,schematic_arc2,schematic_component2,schematic_symbol2,schematic_port2,schematic_trace2,schematic_path2,schematic_error2,schematic_layout_error2,schematic_net_label2,schematic_debug_object2,schematic_voltage_probe2,schematic_manual_edit_conflict_warning2,schematic_group2,schematic_sheet2,schematic_table2,schematic_table_cell2,cad_component2,simulation_voltage_source2,simulation_current_source2,simulation_experiment2,simulation_transient_voltage_graph2,simulation_switch2,simulation_voltage_probe2,simulation_unknown_experiment_error2,simulation_op_amp2]),any_soup_element2=any_circuit_element2;expectTypesMatch3(!0);expectStringUnionsMatch2(!0);function applyToPoint4(matrix2,point23){return Array.isArray(point23)?[matrix2.a*point23[0]+matrix2.c*point23[1]+matrix2.e,matrix2.b*point23[0]+matrix2.d*point23[1]+matrix2.f]:{x:matrix2.a*point23.x+matrix2.c*point23.y+matrix2.e,y:matrix2.b*point23.x+matrix2.d*point23.y+matrix2.f}}function isUndefined4(val){return typeof val>"u"}function translate4(tx3,ty3=0){return{a:1,c:0,e:tx3,b:0,d:1,f:ty3}}function transform4(...matrices){matrices=Array.isArray(matrices[0])?matrices[0]:matrices;let multiply=(m12,m22)=>({a:m12.a*m22.a+m12.c*m22.b,c:m12.a*m22.c+m12.c*m22.d,e:m12.a*m22.e+m12.c*m22.f+m12.e,b:m12.b*m22.a+m12.d*m22.b,d:m12.b*m22.c+m12.d*m22.d,f:m12.b*m22.e+m12.d*m22.f+m12.f});switch(matrices.length){case 0:throw new Error("no matrices provided");case 1:return matrices[0];case 2:return multiply(matrices[0],matrices[1]);default:{let[m12,m22,...rest]=matrices,m4=multiply(m12,m22);return transform4(m4,...rest)}}}function compose4(...matrices){return transform4(...matrices)}var{cos:cos5,sin:sin5,PI:PI6}=Math;function scale4(sx3,sy3=void 0,cx3=void 0,cy3=void 0){isUndefined4(sy3)&&(sy3=sx3);let scaleMatrix={a:sx3,c:0,e:0,b:0,d:sy3,f:0};return isUndefined4(cx3)||isUndefined4(cy3)?scaleMatrix:transform4([translate4(cx3,cy3),scaleMatrix,translate4(-cx3,-cy3)])}var{tan:tan5}=Math;function peg$subclass3(child,parent){function C4(){this.constructor=child}C4.prototype=parent.prototype,child.prototype=new C4}function peg$SyntaxError3(message,expected,found,location){var self2=Error.call(this,message);return Object.setPrototypeOf&&Object.setPrototypeOf(self2,peg$SyntaxError3.prototype),self2.expected=expected,self2.found=found,self2.location=location,self2.name="SyntaxError",self2}peg$subclass3(peg$SyntaxError3,Error);function peg$padEnd3(str,targetLength,padString){return padString=padString||" ",str.length>targetLength?str:(targetLength-=str.length,padString+=padString.repeat(targetLength),str+padString.slice(0,targetLength))}peg$SyntaxError3.prototype.format=function(sources){var str="Error: "+this.message;if(this.location){var src=null,k4;for(k4=0;k4<sources.length;k4++)if(sources[k4].source===this.location.source){src=sources[k4].text.split(/\r\n|\n|\r/g);break}var s3=this.location.start,offset_s=this.location.source&&typeof this.location.source.offset=="function"?this.location.source.offset(s3):s3,loc=this.location.source+":"+offset_s.line+":"+offset_s.column;if(src){var e5=this.location.end,filler=peg$padEnd3("",offset_s.line.toString().length," "),line2=src[s3.line-1],last=s3.line===e5.line?e5.column:line2.length+1,hatLen=last-s3.column||1;str+=`