@tscircuit/eval 0.0.586 → 0.0.587
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/blob-url.js +1 -1
- package/dist/webworker/entrypoint.js +4 -4
- package/package.json +3 -3
|
@@ -357,7 +357,7 @@ svg { font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif; }
|
|
|
357
357
|
fieldset[disabled]:not(fieldset[disabled] legend:first-of-type *)
|
|
358
358
|
)`,enabled:":not(:disabled)",checked:":is(:is(input[type=radio], input[type=checkbox])[checked], option:selected)",required:":is(input, select, textarea)[required]",optional:":is(input, select, textarea):not([required])",selected:"option:is([selected], select:not([multiple]):not(:has(> option[selected])) > :first-of-type)",checkbox:"[type=checkbox]",file:"[type=file]",password:"[type=password]",radio:"[type=radio]",reset:"[type=reset]",image:"[type=image]",submit:"[type=submit]",parent:":not(:empty)",header:":is(h1, h2, h3, h4, h5, h6)",button:":is(button, input[type=button])",input:":is(input, textarea, select, button)",text:"input:is(:not([type!='']), [type=text])"};var import_boolbase4=__toESM(require_boolbase(),1);var PLACEHOLDER_ELEMENT={};function ensureIsTag(next2,adapter){return next2===import_boolbase4.default.falseFunc?import_boolbase4.default.falseFunc:elem=>adapter.isTag(elem)&&next2(elem)}function getNextSiblings(elem,adapter){let siblings=adapter.getSiblings(elem);if(siblings.length<=1)return[];let elemIndex=siblings.indexOf(elem);return elemIndex<0||elemIndex===siblings.length-1?[]:siblings.slice(elemIndex+1).filter(adapter.isTag)}function copyOptions(options){return{xmlMode:!!options.xmlMode,lowerCaseAttributeNames:!!options.lowerCaseAttributeNames,lowerCaseTags:!!options.lowerCaseTags,quirksMode:!!options.quirksMode,cacheResults:!!options.cacheResults,pseudos:options.pseudos,adapter:options.adapter,equals:options.equals}}var is2=(next2,token,options,context,compileToken2)=>{let func=compileToken2(token,copyOptions(options),context);return func===import_boolbase4.default.trueFunc?next2:func===import_boolbase4.default.falseFunc?import_boolbase4.default.falseFunc:elem=>func(elem)&&next2(elem)},subselects={is:is2,matches:is2,where:is2,not(next2,token,options,context,compileToken2){let func=compileToken2(token,copyOptions(options),context);return func===import_boolbase4.default.falseFunc?next2:func===import_boolbase4.default.trueFunc?import_boolbase4.default.falseFunc:elem=>!func(elem)&&next2(elem)},has(next2,subselect,options,_context,compileToken2){let{adapter}=options,opts=copyOptions(options);opts.relativeSelector=!0;let context=subselect.some(s3=>s3.some(isTraversal2))?[PLACEHOLDER_ELEMENT]:void 0,compiled=compileToken2(subselect,opts,context);if(compiled===import_boolbase4.default.falseFunc)return import_boolbase4.default.falseFunc;let hasElement=ensureIsTag(compiled,adapter);if(context&&compiled!==import_boolbase4.default.trueFunc){let{shouldTestNextSiblings=!1}=compiled;return elem=>{if(!next2(elem))return!1;context[0]=elem;let childs=adapter.getChildren(elem),nextElements=shouldTestNextSiblings?[...childs,...getNextSiblings(elem,adapter)]:childs;return adapter.existsOne(hasElement,nextElements)}}return elem=>next2(elem)&&adapter.existsOne(hasElement,adapter.getChildren(elem))}};function compilePseudoSelector(next2,selector,options,context,compileToken2){var _a359;let{name,data}=selector;if(Array.isArray(data)){if(!(name in subselects))throw new Error(`Unknown pseudo-class :${name}(${data})`);return subselects[name](next2,data,options,context,compileToken2)}let userPseudo=(_a359=options.pseudos)===null||_a359===void 0?void 0:_a359[name],stringPseudo=typeof userPseudo=="string"?userPseudo:aliases[name];if(typeof stringPseudo=="string"){if(data!=null)throw new Error(`Pseudo ${name} doesn't have any arguments`);let alias=parse(stringPseudo);return subselects.is(next2,alias,options,context,compileToken2)}if(typeof userPseudo=="function")return verifyPseudoArgs(userPseudo,name,data,1),elem=>userPseudo(elem,data)&&next2(elem);if(name in filters)return filters[name](next2,data,options,context);if(name in pseudos){let pseudo=pseudos[name];return verifyPseudoArgs(pseudo,name,data,2),elem=>pseudo(elem,options,data)&&next2(elem)}throw new Error(`Unknown pseudo-class :${name}`)}function getElementParent(node,adapter){let parent=adapter.getParent(node);return parent&&adapter.isTag(parent)?parent:null}function compileGeneralSelector(next2,selector,options,context,compileToken2){let{adapter,equals}=options;switch(selector.type){case SelectorType.PseudoElement:throw new Error("Pseudo-elements are not supported by css-select");case SelectorType.ColumnCombinator:throw new Error("Column combinators are not yet supported by css-select");case SelectorType.Attribute:{if(selector.namespace!=null)throw new Error("Namespaced attributes are not yet supported by css-select");return(!options.xmlMode||options.lowerCaseAttributeNames)&&(selector.name=selector.name.toLowerCase()),attributeRules[selector.action](next2,selector,options)}case SelectorType.Pseudo:return compilePseudoSelector(next2,selector,options,context,compileToken2);case SelectorType.Tag:{if(selector.namespace!=null)throw new Error("Namespaced tag names are not yet supported by css-select");let{name}=selector;return(!options.xmlMode||options.lowerCaseTags)&&(name=name.toLowerCase()),function(elem){return adapter.getName(elem)===name&&next2(elem)}}case SelectorType.Descendant:{if(options.cacheResults===!1||typeof WeakSet>"u")return function(elem){let current2=elem;for(;current2=getElementParent(current2,adapter);)if(next2(current2))return!0;return!1};let isFalseCache=new WeakSet;return function(elem){let current2=elem;for(;current2=getElementParent(current2,adapter);)if(!isFalseCache.has(current2)){if(adapter.isTag(current2)&&next2(current2))return!0;isFalseCache.add(current2)}return!1}}case"_flexibleDescendant":return function(elem){let current2=elem;do if(next2(current2))return!0;while(current2=getElementParent(current2,adapter));return!1};case SelectorType.Parent:return function(elem){return adapter.getChildren(elem).some(elem2=>adapter.isTag(elem2)&&next2(elem2))};case SelectorType.Child:return function(elem){let parent=adapter.getParent(elem);return parent!=null&&adapter.isTag(parent)&&next2(parent)};case SelectorType.Sibling:return function(elem){let siblings=adapter.getSiblings(elem);for(let i3=0;i3<siblings.length;i3++){let currentSibling=siblings[i3];if(equals(elem,currentSibling))break;if(adapter.isTag(currentSibling)&&next2(currentSibling))return!0}return!1};case SelectorType.Adjacent:return adapter.prevElementSibling?function(elem){let previous=adapter.prevElementSibling(elem);return previous!=null&&next2(previous)}:function(elem){let siblings=adapter.getSiblings(elem),lastElement;for(let i3=0;i3<siblings.length;i3++){let currentSibling=siblings[i3];if(equals(elem,currentSibling))break;adapter.isTag(currentSibling)&&(lastElement=currentSibling)}return!!lastElement&&next2(lastElement)};case SelectorType.Universal:{if(selector.namespace!=null&&selector.namespace!=="*")throw new Error("Namespaced universal selectors are not yet supported by css-select");return next2}}}function compile2(selector,options,context){let next2=compileUnsafe(selector,options,context);return ensureIsTag(next2,options.adapter)}function compileUnsafe(selector,options,context){let token=typeof selector=="string"?parse(selector):selector;return compileToken(token,options,context)}function includesScopePseudo(t5){return t5.type===SelectorType.Pseudo&&(t5.name==="scope"||Array.isArray(t5.data)&&t5.data.some(data=>data.some(includesScopePseudo)))}var DESCENDANT_TOKEN={type:SelectorType.Descendant},FLEXIBLE_DESCENDANT_TOKEN={type:"_flexibleDescendant"},SCOPE_TOKEN={type:SelectorType.Pseudo,name:"scope",data:null};function absolutize(token,{adapter},context){let hasContext=!!context?.every(e4=>{let parent=adapter.isTag(e4)&&adapter.getParent(e4);return e4===PLACEHOLDER_ELEMENT||parent&&adapter.isTag(parent)});for(let t5 of token){if(!(t5.length>0&&isTraversal2(t5[0])&&t5[0].type!==SelectorType.Descendant))if(hasContext&&!t5.some(includesScopePseudo))t5.unshift(DESCENDANT_TOKEN);else continue;t5.unshift(SCOPE_TOKEN)}}function compileToken(token,options,context){var _a359;token.forEach(sortByProcedure),context=(_a359=options.context)!==null&&_a359!==void 0?_a359:context;let isArrayContext=Array.isArray(context),finalContext=context&&(Array.isArray(context)?context:[context]);if(options.relativeSelector!==!1)absolutize(token,options,finalContext);else if(token.some(t5=>t5.length>0&&isTraversal2(t5[0])))throw new Error("Relative selectors are not allowed when the `relativeSelector` option is disabled");let shouldTestNextSiblings=!1,query=token.map(rules=>{if(rules.length>=2){let[first,second]=rules;first.type!==SelectorType.Pseudo||first.name!=="scope"||(isArrayContext&&second.type===SelectorType.Descendant?rules[1]=FLEXIBLE_DESCENDANT_TOKEN:(second.type===SelectorType.Adjacent||second.type===SelectorType.Sibling)&&(shouldTestNextSiblings=!0))}return compileRules(rules,options,finalContext)}).reduce(reduceRules,import_boolbase5.default.falseFunc);return query.shouldTestNextSiblings=shouldTestNextSiblings,query}function compileRules(rules,options,context){var _a359;return rules.reduce((previous,rule)=>previous===import_boolbase5.default.falseFunc?import_boolbase5.default.falseFunc:compileGeneralSelector(previous,rule,options,context,compileToken),(_a359=options.rootFunc)!==null&&_a359!==void 0?_a359:import_boolbase5.default.trueFunc)}function reduceRules(a2,b3){return b3===import_boolbase5.default.falseFunc||a2===import_boolbase5.default.trueFunc?a2:a2===import_boolbase5.default.falseFunc||b3===import_boolbase5.default.trueFunc?b3:function(elem){return a2(elem)||b3(elem)}}var defaultEquals=(a2,b3)=>a2===b3,defaultOptions={adapter:esm_exports2,equals:defaultEquals};function convertOptionFormats(options){var _a359,_b2,_c2,_d;let opts=options??defaultOptions;return(_a359=opts.adapter)!==null&&_a359!==void 0||(opts.adapter=esm_exports2),(_b2=opts.equals)!==null&&_b2!==void 0||(opts.equals=(_d=(_c2=opts.adapter)===null||_c2===void 0?void 0:_c2.equals)!==null&&_d!==void 0?_d:defaultEquals),opts}function wrapCompile(func){return function(selector,options,context){let opts=convertOptionFormats(options);return func(selector,opts,context)}}var compile3=wrapCompile(compile2),_compileUnsafe=wrapCompile(compileUnsafe),_compileToken=wrapCompile(compileToken);function getSelectorFunc(searchFunc){return function(query,elements,options){let opts=convertOptionFormats(options);typeof query!="function"&&(query=compileUnsafe(query,opts,elements));let filteredElements=prepareContext(elements,opts.adapter,query.shouldTestNextSiblings);return searchFunc(query,filteredElements,opts)}}function prepareContext(elems,adapter,shouldTestNextSiblings=!1){return shouldTestNextSiblings&&(elems=appendNextSiblings(elems,adapter)),Array.isArray(elems)?adapter.removeSubsets(elems):adapter.getChildren(elems)}function appendNextSiblings(elem,adapter){let elems=Array.isArray(elem)?elem.slice(0):[elem],elemsLength=elems.length;for(let i3=0;i3<elemsLength;i3++){let nextSiblings=getNextSiblings(elems[i3],adapter);elems.push(...nextSiblings)}return elems}var selectAll=getSelectorFunc((query,elems,options)=>query===import_boolbase6.default.falseFunc||!elems||elems.length===0?[]:options.adapter.findAll(query,elems)),selectOne=getSelectorFunc((query,elems,options)=>query===import_boolbase6.default.falseFunc||!elems||elems.length===0?null:options.adapter.findOne(query,elems));init_zod();init_dist();init_zod();var import_debug=__toESM(require_browser(),1);init_dist();var import_debug2=__toESM(require_browser(),1),import_debug3=__toESM(require_browser(),1);init_dist();init_src();init_parsel();var su=(soup,options={})=>{let internalStore=soup._internal_store;if(!internalStore){internalStore={counts:{}},soup._internal_store=internalStore;for(let elm of soup){let type=elm.type,idVal=elm[`${type}_id`];if(!idVal)continue;let idNum=Number.parseInt(idVal.split("_").pop());Number.isNaN(idNum)||(internalStore.counts[type]=Math.max(internalStore.counts[type]??0,idNum))}}return new Proxy({},{get:(proxy_target,component_type)=>component_type==="toArray"?()=>soup:{get:id2=>soup.find(e4=>e4.type===component_type&&e4[`${component_type}_id`]===id2),getUsing:using=>{let keys=Object.keys(using);if(keys.length!==1)throw new Error("getUsing requires exactly one key, e.g. { pcb_component_id }");let join_key=keys[0],join_type=join_key.replace("_id",""),joiner=soup.find(e4=>e4.type===join_type&&e4[join_key]===using[join_key]);return joiner?soup.find(e4=>e4.type===component_type&&e4[`${component_type}_id`]===joiner[`${component_type}_id`]):null},getWhere:where=>{let keys=Object.keys(where);return soup.find(e4=>e4.type===component_type&&keys.every(key=>e4[key]===where[key]))},list:where=>{let keys=where?Object.keys(where):[];return soup.filter(e4=>e4.type===component_type&&keys.every(key=>e4[key]===where[key]))},insert:elm=>{var _a359;(_a359=internalStore.counts)[component_type]??(_a359[component_type]=-1),internalStore.counts[component_type]++;let index=internalStore.counts[component_type],newElm={type:component_type,[`${component_type}_id`]:`${component_type}_${index}`,...elm};return options.validateInserts&&(dist_exports[component_type]??any_soup_element).parse(newElm),soup.push(newElm),newElm},delete:id2=>{let elm=soup.find(e4=>e4[`${component_type}_id`]===id2);elm&&soup.splice(soup.indexOf(elm),1)},update:(id2,newProps)=>{let elm=soup.find(e4=>e4.type===component_type&&e4[`${component_type}_id`]===id2);if(elm)return Object.assign(elm,newProps),elm},select:selector=>{if(component_type==="source_component")return soup.find(e4=>e4.type==="source_component"&&e4.name===selector.replace(/\./g,""));if(component_type==="pcb_port"||component_type==="source_port"||component_type==="schematic_port"){let[component_name,port_selector]=selector.replace(/\./g,"").split(/[\s\>]+/),source_component=soup.find(e4=>e4.type==="source_component"&&e4.name===component_name);if(!source_component)return null;let source_port2=soup.find(e4=>e4.type==="source_port"&&e4.source_component_id===source_component.source_component_id&&(e4.name===port_selector||(e4.port_hints??[]).includes(port_selector)));if(!source_port2)return null;if(component_type==="source_port")return source_port2;if(component_type==="pcb_port")return soup.find(e4=>e4.type==="pcb_port"&&e4.source_port_id===source_port2.source_port_id);if(component_type==="schematic_port")return soup.find(e4=>e4.type==="schematic_port"&&e4.source_port_id===source_port2.source_port_id)}}}})};su.unparsed=su;var su_default=su;var import_performance_now=__toESM(require_performance_now(),1);init_dist4();function getBoundingBox2(box2){let halfWidth=box2.width/2,halfHeight=box2.height/2;return{minX:box2.center.x-halfWidth,maxX:box2.center.x+halfWidth,minY:box2.center.y-halfHeight,maxY:box2.center.y+halfHeight}}function computeManhattanDistanceBetweenBoxes(boxA,boxB){let a2=getBoundingBox2(boxA),b3=getBoundingBox2(boxB),dx2=Math.max(a2.minX-b3.maxX,b3.minX-a2.maxX,0),dy2=Math.max(a2.minY-b3.maxY,b3.minY-a2.maxY,0),pointA={x:0,y:0},pointB={x:0,y:0};return dx2===0&&dy2===0?{distance:0,pointA:boxA.center,pointB:boxB.center}:(pointA.x=clamp2(boxA.center.x,b3.minX,b3.maxX),pointA.y=clamp2(boxA.center.y,b3.minY,b3.maxY),pointB.x=clamp2(boxB.center.x,a2.minX,a2.maxX),pointB.y=clamp2(boxB.center.y,a2.minY,a2.maxY),{distance:Math.hypot(pointA.x-pointB.x,pointA.y-pointB.y),pointA,pointB})}function computeDistanceBetweenBoxes2(boxA,boxB){return computeManhattanDistanceBetweenBoxes(boxA,boxB)}function computeGapBetweenBoxes(boxA,boxB){let a2=getBoundingBox2(boxA),b3=getBoundingBox2(boxB),dx2=Math.max(a2.minX-b3.maxX,b3.minX-a2.maxX,0),dy2=Math.max(a2.minY-b3.maxY,b3.minY-a2.maxY,0);return Math.hypot(dx2,dy2)}function clamp2(value,min,max){return Math.max(min,Math.min(max,value))}function findNearestPointsBetweenBoxSets2(boxSetA,boxSetB){let minDistance=Number.POSITIVE_INFINITY,nearestPointA={x:0,y:0},nearestPointB={x:0,y:0};for(let boxA of boxSetA)for(let boxB of boxSetB){let{distance:distance8,pointA,pointB}=computeManhattanDistanceBetweenBoxes(boxA,boxB);distance8<minDistance&&(minDistance=distance8,nearestPointA=pointA,nearestPointB=pointB)}return{pointA:nearestPointA,pointB:nearestPointB,distance:minDistance}}init_dist4();init_dist4();var urlAlphabet="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var nanoid=(size2=21)=>{let id2="",bytes=crypto.getRandomValues(new Uint8Array(size2|=0));for(;size2--;)id2+=urlAlphabet[bytes[size2]&63];return id2};init_dist4();var manDist=(a2,b3)=>Math.abs(a2.x-b3.x)+Math.abs(a2.y-b3.y),dirFromAToB=(a2,b3)=>{let dx2=b3.x-a2.x,dy2=b3.y-a2.y;return Math.abs(dx2)>Math.abs(dy2)?{dx:Math.sign(dx2),dy:0}:{dx:0,dy:Math.sign(dy2)}},distAlongDir=(A4,B3,dir)=>Math.abs(A4.x-B3.x)*Math.abs(dir.dx)+Math.abs(A4.y-B3.y)*Math.abs(dir.dy),nodeName=(node,GRID_STEP=.1)=>`${Math.round(node.x/GRID_STEP)},${Math.round(node.y/GRID_STEP)}`,isCloseTo=(a2,b3)=>Math.abs(a2-b3)<1e-4,getObstaclesFromRoute=(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=isCloseTo(start.y,end.y),isVert=isCloseTo(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},ObstacleList=class{constructor(obstacles){__publicField(this,"obstacles");__publicField(this,"GRID_STEP",.1);this.obstacles=obstacles.map(obstacle=>({...obstacle,left:obstacle.center.x-obstacle.width/2,right:obstacle.center.x+obstacle.width/2,top:obstacle.center.y+obstacle.height/2,bottom:obstacle.center.y-obstacle.height/2}))}getObstacleAt(x3,y3,m3){m3??(m3=this.GRID_STEP);for(let obstacle of this.obstacles){let halfWidth=obstacle.width/2+m3,halfHeight=obstacle.height/2+m3;if(x3>=obstacle.center.x-halfWidth&&x3<=obstacle.center.x+halfWidth&&y3>=obstacle.center.y-halfHeight&&y3<=obstacle.center.y+halfHeight)return obstacle}return null}isObstacleAt(x3,y3,m3){return this.getObstacleAt(x3,y3,m3)!==null}getDirectionDistancesToNearestObstacle(x3,y3){let{GRID_STEP}=this,result={left:1/0,top:1/0,bottom:1/0,right:1/0};for(let obstacle of this.obstacles)if(obstacle.type==="rect"){let left=obstacle.center.x-obstacle.width/2-GRID_STEP,right=obstacle.center.x+obstacle.width/2+GRID_STEP,top=obstacle.center.y+obstacle.height/2+GRID_STEP,bottom=obstacle.center.y-obstacle.height/2-GRID_STEP;y3>=bottom&&y3<=top&&x3>left&&(result.left=Math.min(result.left,x3-right)),y3>=bottom&&y3<=top&&x3<right&&(result.right=Math.min(result.right,left-x3)),x3>=left&&x3<=right&&y3<top&&(result.top=Math.min(result.top,bottom-y3)),x3>=left&&x3<=right&&y3>bottom&&(result.bottom=Math.min(result.bottom,y3-top))}return result}getOrthoDirectionCollisionInfo(point6,dir,{margin=0}={}){let{x:x3,y:y3}=point6,{dx:dx2,dy:dy2}=dir,minDistance=1/0,collisionObstacle=null;for(let obstacle of this.obstacles){let leftMargin=obstacle.left-margin,rightMargin=obstacle.right+margin,topMargin=obstacle.top+margin,bottomMargin=obstacle.bottom-margin,distance8=null;dx2===1&&dy2===0?y3>bottomMargin&&y3<topMargin&&x3<obstacle.left&&(distance8=obstacle.left-x3):dx2===-1&&dy2===0?y3>bottomMargin&&y3<topMargin&&x3>obstacle.right&&(distance8=x3-obstacle.right):dx2===0&&dy2===1?x3>leftMargin&&x3<rightMargin&&y3<obstacle.bottom&&(distance8=obstacle.bottom-y3):dx2===0&&dy2===-1&&x3>leftMargin&&x3<rightMargin&&y3>obstacle.top&&(distance8=y3-obstacle.top),distance8!==null&&distance8<minDistance&&(minDistance=distance8,collisionObstacle=obstacle)}return{dx:dx2,dy:dy2,wallDistance:minDistance,obstacle:collisionObstacle}}getObstaclesOverlappingRegion(region){let obstacles=[];for(let obstacle of this.obstacles){let{left,right,top,bottom}=obstacle;left<=region.maxX&&right>=region.minX&&top<=region.maxY&&bottom>=region.minY&&obstacles.push(obstacle)}return obstacles}};function removePathLoops(path){if(path.length<4)return path;let result=[{...path[0]}],currentLayer=path[0].layer;for(let i3=1;i3<path.length;i3++){let currentSegment={start:path[i3-1],end:path[i3]},isVia=path[i3].route_type==="via"||path[i3-1].route_type==="via";if(path[i3].layer!==currentLayer||isVia){result.push({...path[i3]}),currentLayer=path[i3].layer;continue}let intersectionFound=!1,intersectionPoint=null,intersectionIndex=-1;for(let j3=0;j3<result.length-1;j3++){let previousSegment={start:result[j3],end:result[j3+1]};if(previousSegment.start.layer===currentSegment.start.layer&&previousSegment.start.layer===currentSegment.start.layer){let intersection=findIntersection(previousSegment,currentSegment);if(intersection){intersectionFound=!0,intersectionPoint={...intersection,layer:currentLayer},intersectionIndex=j3;break}}}intersectionFound&&intersectionPoint&&(result.splice(intersectionIndex+1),result.push(intersectionPoint));let lastPoint=result[result.length-1];(lastPoint.x!==path[i3].x||lastPoint.y!==path[i3].y)&&result.push(path[i3])}return result}function findIntersection(segment1,segment2){if(segment1.start.x===segment1.end.x&&segment2.start.x===segment2.end.x||segment1.start.y===segment1.end.y&&segment2.start.y===segment2.end.y)return null;let intersectionPoint;if(segment1.start.x===segment1.end.x){let x3=segment1.start.x,y3=segment2.start.y;intersectionPoint={...segment1.start,x:x3,y:y3}}else{let x3=segment2.start.x,y3=segment1.start.y;intersectionPoint={...segment1.start,x:x3,y:y3}}return isPointInSegment(intersectionPoint,segment1)&&isPointInSegment(intersectionPoint,segment2)?intersectionPoint:null}function isPointInSegment(point6,segment2){return point6.x>=Math.min(segment2.start.x,segment2.end.x)&&point6.x<=Math.max(segment2.start.x,segment2.end.x)&&point6.y>=Math.min(segment2.start.y,segment2.end.y)&&point6.y<=Math.max(segment2.start.y,segment2.end.y)}function addViasWhenLayerChanges(route){let newRoute=[route[0]];for(let i3=1;i3<route.length-1;i3++){let[prev,current2,next2]=[route[i3-1],route[i3],route[i3+1]];newRoute.push(current2),!(current2.route_type!=="wire"||prev.route_type!=="wire"||next2.route_type!=="wire")&&prev.layer===current2.layer&¤t2.layer!==next2.layer&&newRoute.push({route_type:"via",from_layer:current2.layer,to_layer:next2.layer,x:current2.x,y:current2.y})}return newRoute.push(route[route.length-1]),newRoute}var debug=(0,import_debug2.default)("autorouter:shortenPathWithShortcuts");function shortenPathWithShortcuts(route,checkIfObstacleBetweenPoints){if(route.length<=2)return route;let shortened=[route[0]];for(let i3=1;i3<route.length;i3++){let currentSegment={start:shortened[shortened.length-1],end:route[i3]},skipToIndex=-1,currentSegmentIsVertical=currentSegment.start.x===currentSegment.end.x,currentSegmentIsHorizontal=currentSegment.start.y===currentSegment.end.y;for(let j3=i3+1;j3<route.length;j3++){if(j3<=skipToIndex)continue;let futureSegment={start:route[j3],end:route[j3+1]};if(!futureSegment.end)continue;let futureSegmentIsVertical=futureSegment.start.x===futureSegment.end.x,futureSegmentIsHorizontal=futureSegment.start.y===futureSegment.end.y,bothVertical=currentSegmentIsVertical&&futureSegmentIsVertical,bothHorizontal=currentSegmentIsHorizontal&&futureSegmentIsHorizontal;if(bothHorizontal&&bothVertical||!(bothVertical||bothHorizontal))continue;let overlapping=!1,currentMinX=Math.min(currentSegment.start.x,currentSegment.end.x),currentMaxX=Math.max(currentSegment.start.x,currentSegment.end.x),futureMinX=Math.min(futureSegment.start.x,futureSegment.end.x),futureMaxX=Math.max(futureSegment.start.x,futureSegment.end.x),currentMinY=Math.min(currentSegment.start.y,currentSegment.end.y),currentMaxY=Math.max(currentSegment.start.y,currentSegment.end.y),futureMinY=Math.min(futureSegment.start.y,futureSegment.end.y),futureMaxY=Math.max(futureSegment.start.y,futureSegment.end.y);if(bothHorizontal?overlapping=currentMinX<=futureMaxX&¤tMaxX>=futureMinX:bothVertical&&(overlapping=currentMinY<=futureMaxY&¤tMaxY>=futureMinY),!overlapping)continue;let candidateShortcuts=[],pointBeforeShortcut=shortened[shortened.length-1],pointAfterShortcut=route[j3+2];if(!pointAfterShortcut)continue;bothHorizontal&&futureMinX<currentMaxX&&pointAfterShortcut.x===futureMinX&&candidateShortcuts.push({x:futureMinX,y:currentSegment.start.y,layer:currentSegment.start.layer}),bothHorizontal&&futureMaxX>currentMinX&&pointAfterShortcut.x===futureMaxX&&candidateShortcuts.push({x:futureMaxX,y:currentSegment.start.y,layer:currentSegment.start.layer}),bothVertical&&futureMinY<currentMaxY&&pointAfterShortcut.y===futureMinY&&candidateShortcuts.push({x:currentSegment.start.x,y:futureMinY,layer:currentSegment.start.layer}),bothVertical&&futureMaxY>currentMinY&&pointAfterShortcut.y===futureMaxY&&candidateShortcuts.push({x:currentSegment.start.x,y:futureMaxY,layer:currentSegment.start.layer});let shortcutPoint=null;for(let candidateShortcut of candidateShortcuts)if(!(checkIfObstacleBetweenPoints(pointBeforeShortcut,candidateShortcut)||checkIfObstacleBetweenPoints(pointAfterShortcut,candidateShortcut))){shortcutPoint=candidateShortcut;break}if(shortcutPoint){shortened.push(shortcutPoint),i3=j3+1,skipToIndex=j3+1;break}}skipToIndex===-1&&shortened.push(route[i3])}return shortened[shortened.length-1]!==route[route.length-1]&&shortened.push(route[route.length-1]),shortened}var debug2=(0,import_debug.default)("autorouting-dataset:astar"),GeneralizedAstarAutorouter=class{constructor(opts){__publicField(this,"openSet",[]);__publicField(this,"closedSet",new Set);__publicField(this,"debug",!1);__publicField(this,"debugSolutions");__publicField(this,"debugMessage",null);__publicField(this,"debugTraceCount",0);__publicField(this,"input");__publicField(this,"obstacles");__publicField(this,"allObstacles");__publicField(this,"startNode");__publicField(this,"goalPoint");__publicField(this,"GRID_STEP");__publicField(this,"OBSTACLE_MARGIN");__publicField(this,"MAX_ITERATIONS");__publicField(this,"isRemovePathLoopsEnabled");__publicField(this,"isShortenPathWithShortcutsEnabled");__publicField(this,"GREEDY_MULTIPLIER",1.1);__publicField(this,"iterations",-1);this.input=opts.input,this.allObstacles=opts.input.obstacles,this.startNode=opts.startNode,this.goalPoint=opts.goalPoint?{l:0,...opts.goalPoint}:void 0,this.GRID_STEP=opts.GRID_STEP??.1,this.OBSTACLE_MARGIN=opts.OBSTACLE_MARGIN??.15,this.MAX_ITERATIONS=opts.MAX_ITERATIONS??100,this.debug=opts.debug??debug2.enabled,this.isRemovePathLoopsEnabled=opts.isRemovePathLoopsEnabled??!1,this.isShortenPathWithShortcutsEnabled=opts.isShortenPathWithShortcutsEnabled??!1,this.debug&&(debug2.enabled=!0),debug2.enabled&&(this.debugSolutions={},this.debugMessage="")}getNeighbors(node){return[]}isSameNode(a2,b3){return manDist(a2,b3)<this.GRID_STEP}computeG(current2,neighbor){return current2.g+manDist(current2,neighbor)}computeH(node){return manDist(node,this.goalPoint)}getNodeName(node){return nodeName(node,this.GRID_STEP)}solveOneStep(){this.iterations+=1;let{openSet,closedSet,GRID_STEP,goalPoint}=this;openSet.sort((a2,b3)=>a2.f-b3.f);let current2=openSet.shift();if(this.computeH(current2)<=GRID_STEP*2)return{solved:!0,current:current2,newNeighbors:[]};this.closedSet.add(this.getNodeName(current2));let newNeighbors=[];for(let neighbor of this.getNeighbors(current2)){if(closedSet.has(this.getNodeName(neighbor)))continue;let tentativeG=this.computeG(current2,neighbor),existingNeighbor=this.openSet.find(n3=>this.isSameNode(n3,neighbor));if(!existingNeighbor||tentativeG<existingNeighbor.g){let h2=this.computeH(neighbor),f2=tentativeG+h2*this.GREEDY_MULTIPLIER,neighborNode={...neighbor,g:tentativeG,h:h2,f:f2,obstacleHit:neighbor.obstacleHit??void 0,manDistFromParent:manDist(current2,neighbor),nodesInPath:current2.nodesInPath+1,parent:current2,enterMarginCost:neighbor.enterMarginCost,travelMarginCostFactor:neighbor.travelMarginCostFactor};openSet.push(neighborNode),newNeighbors.push(neighborNode)}}return debug2.enabled&&(openSet.sort((a2,b3)=>a2.f-b3.f),this.drawDebugSolution({current:current2,newNeighbors})),{solved:!1,current:current2,newNeighbors}}getStartNode(connection){return{x:connection.pointsToConnect[0].x,y:connection.pointsToConnect[0].y,manDistFromParent:0,f:0,g:0,h:0,nodesInPath:0,parent:null}}layerToIndex(layer){return 0}indexToLayer(index){return"top"}preprocessConnectionBeforeSolving(connection){return connection}solveConnection(connection){if(connection.pointsToConnect.length>2)throw new Error("GeneralizedAstarAutorouter doesn't currently support 2+ points in a connection");connection=this.preprocessConnectionBeforeSolving(connection);let{pointsToConnect}=connection;for(this.iterations=0,this.closedSet=new Set,this.startNode=this.getStartNode(connection),this.goalPoint={...pointsToConnect[pointsToConnect.length-1],l:this.layerToIndex(pointsToConnect[pointsToConnect.length-1].layer)},this.openSet=[this.startNode];this.iterations<this.MAX_ITERATIONS;){let{solved,current:current2}=this.solveOneStep();if(solved){let route=[],node=current2;for(;node;){let l2=node.l;route.unshift({x:node.x,y:node.y,layer:l2!==void 0?this.indexToLayer(l2):pointsToConnect[0].layer}),node=node.parent}return debug2.enabled&&(this.debugMessage+=`t${this.debugTraceCount}: ${this.iterations} iterations
|
|
359
359
|
`),this.isRemovePathLoopsEnabled&&(route=removePathLoops(route)),this.isShortenPathWithShortcutsEnabled&&(route=shortenPathWithShortcuts(route,(A4,B3)=>{if(A4.x===B3.x&&A4.y===B3.y)return!1;let collision=this.obstacles.getOrthoDirectionCollisionInfo({x:A4.x,y:A4.y,l:this.layerToIndex(A4.layer)??0},{dx:Math.sign(B3.x-A4.x),dy:Math.sign(B3.y-A4.y),dl:0},{margin:.05}),dist3=Math.sqrt((A4.x-B3.x)**2+(A4.y-B3.y)**2);return collision.wallDistance<dist3})),{solved:!0,route,connectionName:connection.name}}if(this.openSet.length===0)break}return debug2.enabled&&(this.debugMessage+=`t${this.debugTraceCount}: ${this.iterations} iterations (failed)
|
|
360
|
-
`),{solved:!1,connectionName:connection.name}}createObstacleList({dominantLayer,connection,obstaclesFromTraces}){return new ObstacleList(this.allObstacles.filter(obstacle=>!obstacle.connectedTo.includes(connection.name)).filter(obstacle=>obstacle.layers.includes(dominantLayer)).concat(obstaclesFromTraces??[]))}postprocessConnectionSolveResult(connection,result){return result}solve(){let solutions=[],obstaclesFromTraces=[];this.debugTraceCount=0;for(let connection of this.input.connections){let dominantLayer=connection.pointsToConnect[0].layer??"top";this.debugTraceCount+=1,this.obstacles=this.createObstacleList({dominantLayer,connection,obstaclesFromTraces});let result=this.solveConnection(connection);result=this.postprocessConnectionSolveResult(connection,result),solutions.push(result),debug2.enabled&&this.drawDebugTraceObstacles(obstaclesFromTraces),result.solved&&obstaclesFromTraces.push(...getObstaclesFromRoute(result.route.map(p2=>({x:p2.x,y:p2.y,layer:p2.layer??dominantLayer})),connection.name))}return solutions}solveAndMapToTraces(){return this.solve().flatMap(solution=>solution.solved?[{type:"pcb_trace",pcb_trace_id:`pcb_trace_for_${solution.connectionName}`,route:addViasWhenLayerChanges(solution.route.map(point6=>({route_type:"wire",x:point6.x,y:point6.y,width:this.input.minTraceWidth,layer:point6.layer})))}]:[])}getDebugGroup(){let dgn=`t${this.debugTraceCount}_iter[${this.iterations-1}]`;return this.iterations<30||this.iterations<100&&this.iterations%10===0||this.iterations<1e3&&this.iterations%100===0||!this.debugSolutions?dgn:null}drawDebugTraceObstacles(obstacles){let{debugTraceCount,debugSolutions}=this;for(let key in debugSolutions)key.startsWith(`t${debugTraceCount}_`)&&debugSolutions[key].push(...obstacles.map((obstacle,i3)=>({type:"pcb_smtpad",pcb_component_id:"",layer:obstacle.layers[0],width:obstacle.width,shape:"rect",x:obstacle.center.x,y:obstacle.center.y,pcb_smtpad_id:`trace_obstacle_${i3}`,height:obstacle.height})))}drawDebugSolution({current:current2,newNeighbors}){let debugGroup=this.getDebugGroup();if(!debugGroup)return;let{openSet,debugTraceCount,debugSolutions}=this;debugSolutions[debugGroup]??(debugSolutions[debugGroup]=[]);let debugSolution=debugSolutions[debugGroup];debugSolution.push({type:"pcb_fabrication_note_text",pcb_fabrication_note_text_id:`debug_note_${current2.x}_${current2.y}`,font:"tscircuit2024",font_size:.25,text:"X"+(current2.l!==void 0?current2.l:""),pcb_component_id:"",layer:"top",anchor_position:{x:current2.x,y:current2.y},anchor_alignment:"center"});for(let i3=0;i3<openSet.length;i3++){let node=openSet[i3];debugSolution.push({type:"pcb_fabrication_note_path",pcb_component_id:"",pcb_fabrication_note_path_id:`note_path_${node.x}_${node.y}`,layer:"top",route:[[0,.05],[.05,0],[0,-.05],[-.05,0],[0,.05]].map(([dx2,dy2])=>({x:node.x+dx2,y:node.y+dy2})),stroke_width:.01}),debugSolution.push({type:"pcb_fabrication_note_text",pcb_fabrication_note_text_id:`debug_note_${node.x}_${node.y}`,font:"tscircuit2024",font_size:.03,text:i3.toString(),pcb_component_id:"",layer:"top",anchor_position:{x:node.x,y:node.y},anchor_alignment:"center"})}if(current2.parent){let path=[],p2=current2;for(;p2;)path.unshift(p2),p2=p2.parent;debugSolution.push({type:"pcb_fabrication_note_path",pcb_component_id:"",pcb_fabrication_note_path_id:`note_path_${current2.x}_${current2.y}`,layer:"top",route:path,stroke_width:.01})}}},debug3=(0,import_debug3.default)("autorouting-dataset:infinite-grid-ijump-astar:get-distance-to-overcome-obstacle");function getDistanceToOvercomeObstacle({node,travelDir,wallDir,obstacle,obstacles,obstaclesInRow=0,OBSTACLE_MARGIN=.15,SHOULD_DETECT_CONJOINED_OBSTACLES=!1,MAX_CONJOINED_OBSTACLES=20}){let distToOvercomeObstacle;if(travelDir.dx===0?travelDir.dy>0?distToOvercomeObstacle=obstacle.center.y+obstacle.height/2-node.y:distToOvercomeObstacle=node.y-(obstacle.center.y-obstacle.height/2):travelDir.dx>0?distToOvercomeObstacle=obstacle.center.x+obstacle.width/2-node.x:distToOvercomeObstacle=node.x-(obstacle.center.x-obstacle.width/2),distToOvercomeObstacle+=OBSTACLE_MARGIN,SHOULD_DETECT_CONJOINED_OBSTACLES&&obstaclesInRow<MAX_CONJOINED_OBSTACLES){let obstacleAtEnd=obstacles.getObstacleAt(node.x+travelDir.dx*distToOvercomeObstacle+wallDir.dx*(wallDir.wallDistance+.001),node.y+travelDir.dy*distToOvercomeObstacle+wallDir.dy*(wallDir.wallDistance+.001));if(obstacleAtEnd===obstacle)return distToOvercomeObstacle;if(obstacleAtEnd&&obstacleAtEnd.type==="rect"){let extendingAlongXAxis=travelDir.dy===0,o1OrthoDim=extendingAlongXAxis?obstacle.height:obstacle.width;if((extendingAlongXAxis?obstacleAtEnd.height:obstacleAtEnd.width)>o1OrthoDim)return debug3("next obstacle on path is bigger, not trying to overcome it"),distToOvercomeObstacle;let endObstacleDistToOvercome=getDistanceToOvercomeObstacle({node:{x:node.x+travelDir.dx*distToOvercomeObstacle,y:node.y+travelDir.dy*distToOvercomeObstacle},travelDir,wallDir,obstacle:obstacleAtEnd,obstacles,obstaclesInRow:obstaclesInRow+1,SHOULD_DETECT_CONJOINED_OBSTACLES,MAX_CONJOINED_OBSTACLES,OBSTACLE_MARGIN});distToOvercomeObstacle+=endObstacleDistToOvercome}}return distToOvercomeObstacle}var IJumpAutorouter=class extends GeneralizedAstarAutorouter{constructor(){super(...arguments);__publicField(this,"MAX_ITERATIONS",200)}getNeighbors(node){let obstacles=this.obstacles,goalPoint=this.goalPoint,forwardDir;node.parent?forwardDir=dirFromAToB(node.parent,node):forwardDir=dirFromAToB(node,goalPoint);let travelDirs1=[{dx:0,dy:1},{dx:1,dy:0},{dx:0,dy:-1},{dx:-1,dy:0}].filter(dir=>dir.dx===forwardDir.dx*-1&&dir.dy===forwardDir.dy*-1?!1:!(dir.dx===forwardDir.dx&&dir.dy===forwardDir.dy&&node.parent?.obstacleHit)).map(dir=>obstacles.getOrthoDirectionCollisionInfo(node,dir,{margin:this.OBSTACLE_MARGIN})).filter(dir=>dir.wallDistance>=this.OBSTACLE_MARGIN),travelDirs2=[];for(let travelDir of travelDirs1){let overcomeDistance=null;node?.obstacleHit&&(overcomeDistance=getDistanceToOvercomeObstacle({node,travelDir,wallDir:{...forwardDir,wallDistance:this.OBSTACLE_MARGIN},obstacle:node.obstacleHit,obstacles,OBSTACLE_MARGIN:this.OBSTACLE_MARGIN,SHOULD_DETECT_CONJOINED_OBSTACLES:!0}));let goalDistAlongTravelDir=distAlongDir(node,goalPoint,travelDir),isGoalInTravelDir=(travelDir.dx===0||Math.sign(goalPoint.x-node.x)===travelDir.dx)&&(travelDir.dy===0||Math.sign(goalPoint.y-node.y)===travelDir.dy);goalDistAlongTravelDir<travelDir.wallDistance&&goalDistAlongTravelDir>0&&isGoalInTravelDir?travelDirs2.push({...travelDir,travelDistance:goalDistAlongTravelDir}):overcomeDistance!==null&&overcomeDistance<travelDir.wallDistance?travelDirs2.push({...travelDir,travelDistance:overcomeDistance}):travelDir.wallDistance!==1/0&&travelDirs2.push({...travelDir,travelDistance:travelDir.wallDistance-this.OBSTACLE_MARGIN})}return travelDirs2.filter(dir=>!obstacles.isObstacleAt(node.x+dir.dx*dir.travelDistance,node.y+dir.dy*dir.travelDistance)).map(dir=>({x:node.x+dir.dx*dir.travelDistance,y:node.y+dir.dy*dir.travelDistance,obstacleHit:dir.obstacle}))}};function generateApproximatingRects(rotatedRect,numRects=4){let{center:center2,width,height,rotation:rotation4}=rotatedRect,rects=[],angleRad=rotation4*Math.PI/180,cosAngle=Math.cos(angleRad),sinAngle=Math.sin(angleRad),normalizedRotation=(rotation4%360+360)%360;if(height<=width?normalizedRotation>=45&&normalizedRotation<135||normalizedRotation>=225&&normalizedRotation<315:normalizedRotation>=135&&normalizedRotation<225||normalizedRotation>=315||normalizedRotation<45){let sliceWidth=width/numRects;for(let i3=0;i3<numRects;i3++){let x3=(i3-numRects/2+.5)*sliceWidth,rotatedX=-x3*cosAngle,rotatedY=-x3*sinAngle,coverageWidth=sliceWidth*1.1,coverageHeight=Math.abs(height*cosAngle)+Math.abs(sliceWidth*sinAngle);rects.push({center:{x:center2.x+rotatedX,y:center2.y+rotatedY},width:coverageWidth,height:coverageHeight})}}else{let sliceHeight=height/numRects;for(let i3=0;i3<numRects;i3++){let y3=(i3-numRects/2+.5)*sliceHeight,rotatedX=-y3*sinAngle,rotatedY=y3*cosAngle,coverageWidth=Math.abs(width*cosAngle)+Math.abs(sliceHeight*sinAngle),coverageHeight=sliceHeight*1.1;rects.push({center:{x:center2.x+rotatedX,y:center2.y+rotatedY},width:coverageWidth,height:coverageHeight})}}return rects}var EVERY_LAYER=["top","inner1","inner2","bottom"],getObstaclesFromCircuitJson=(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},approximatingRects=generateApproximatingRects(rotatedRect);for(let rect of approximatingRects)obstacles.push({type:"rect",layers:[element.layer],center:rect.center,width:rect.width,height:rect.height,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_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==="square"?obstacles.push({type:"rect",layers:EVERY_LAYER,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_LAYER,center:{x:element.x,y:element.y},width:element.hole_diameter,height:element.hole_diameter,connectedTo:[]});else if(element.type==="pcb_plated_hole")element.shape==="circle"?obstacles.push({type:"oval",layers:EVERY_LAYER,center:{x:element.x,y:element.y},width:element.outer_diameter,height:element.outer_diameter,connectedTo:withNetId([element.pcb_plated_hole_id])}):(element.shape==="oval"||element.shape==="pill")&&obstacles.push({type:"oval",layers:EVERY_LAYER,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.type==="pcb_trace"){let traceObstacles=getObstaclesFromRoute(element.route.map(rp2=>({x:rp2.x,y:rp2.y,layer:"layer"in rp2?rp2.layer:rp2.from_layer})),element.source_trace_id);obstacles.push(...traceObstacles)}else element.type==="pcb_via"&&obstacles.push({type:"rect",layers:element.layers,center:{x:element.x,y:element.y},connectedTo:[],width:element.outer_diameter,height:element.outer_diameter});return obstacles};function getAlternativeGoalBoxes(params){let{pcbConnMap,goalElementId}=params;if(!goalElementId.startsWith("pcb_port_"))throw new Error(`Currently alternative goal boxes must have a goal id with prefix "pcb_port_" (got ${goalElementId})`);let goalTraces=pcbConnMap.getAllTracesConnectedToPort(goalElementId);return getObstaclesFromCircuitJson(goalTraces).map(obs=>({...obs,connectedTo:[goalElementId]}))}var getConnectionWithAlternativeGoalBoxes=params=>{let{connection,pcbConnMap}=params;if(connection.pointsToConnect.length!==2)throw new Error(`Connection must have exactly 2 points for alternative goal boxes (got ${connection.pointsToConnect.length})`);let[a2,b3]=connection.pointsToConnect;if(!a2.pcb_port_id||!b3.pcb_port_id)throw new Error(`Connection points must have pcb_port_id for alternative goal box calculation (got ${a2.pcb_port_id} and ${b3.pcb_port_id})`);let goalBoxesA=getAlternativeGoalBoxes({goalElementId:a2.pcb_port_id,pcbConnMap}).concat([{center:a2,width:.01,height:.01,connectedTo:[a2.pcb_port_id],layers:[a2.layer],type:"rect"}]),goalBoxesB=getAlternativeGoalBoxes({goalElementId:b3.pcb_port_id,pcbConnMap}).concat([{center:b3,width:.01,height:.01,connectedTo:[b3.pcb_port_id],layers:[b3.layer],type:"rect"}]);if(goalBoxesA.length<=1&&goalBoxesB.length<=1)return{...connection,startPoint:a2,endPoint:b3,goalBoxes:[]};let nearestPoints=findNearestPointsBetweenBoxSets2(goalBoxesA,goalBoxesB),startPoint,endPoint,goalBoxes;return goalBoxesA.length>=goalBoxesB.length?(startPoint={...b3,...nearestPoints.pointB},endPoint={...a2,...nearestPoints.pointA},goalBoxes=goalBoxesA):(startPoint={...a2,...nearestPoints.pointA},endPoint={...b3,...nearestPoints.pointB},goalBoxes=goalBoxesB),{startPoint,endPoint,goalBoxes,name:connection.name,pointsToConnect:[startPoint,endPoint]}},getSimpleRouteJson=(circuitJson,opts={})=>{let routeJson={minTraceWidth:.1};routeJson.layerCount=opts.layerCount??1,routeJson.obstacles=getObstaclesFromCircuitJson(circuitJson,opts.connMap),routeJson.connections=[];for(let element of circuitJson)if(element.type==="source_trace"){if(circuitJson.some(e4=>e4.type==="pcb_trace"&&e4.source_trace_id===element.source_trace_id))continue;let connection={name:element.source_trace_id,pointsToConnect:element.connected_source_port_ids.map(portId=>{let pcb_port2=su_default(circuitJson).pcb_port.getWhere({source_port_id:portId});if(!pcb_port2)throw new Error(`Could not find pcb_port for source_port_id "${portId}"`);return{x:pcb_port2.x,y:pcb_port2.y,layer:pcb_port2.layers?.[0]??"top",pcb_port_id:pcb_port2.pcb_port_id}})};if(opts.optimizeWithGoalBoxes){let pcbConnMap=new PcbConnectivityMap(circuitJson);connection=getConnectionWithAlternativeGoalBoxes({connection,pcbConnMap})}routeJson.connections.push(connection),markObstaclesAsConnected(routeJson.obstacles,connection.pointsToConnect,connection.name)}let bounds={minX:1/0,maxX:-1/0,minY:1/0,maxY:-1/0};for(let obstacle of routeJson.obstacles)bounds.minX=Math.min(bounds.minX,obstacle.center.x-obstacle.width/2),bounds.maxX=Math.max(bounds.maxX,obstacle.center.x+obstacle.width/2),bounds.minY=Math.min(bounds.minY,obstacle.center.y-obstacle.height/2),bounds.maxY=Math.max(bounds.maxY,obstacle.center.y+obstacle.height/2);for(let connection of routeJson.connections)for(let point6 of connection.pointsToConnect)bounds.minX=Math.min(bounds.minX,point6.x),bounds.maxX=Math.max(bounds.maxX,point6.x),bounds.minY=Math.min(bounds.minY,point6.y),bounds.maxY=Math.max(bounds.maxY,point6.y);return routeJson.bounds=bounds,routeJson},markObstaclesAsConnected=(obstacles,pointsToConnect,connectionName)=>{for(let point6 of pointsToConnect)for(let obstacle of obstacles)isPointInsideObstacle(point6,obstacle)&&obstacle.connectedTo.push(connectionName)};function isPointInsideObstacle(point6,obstacle){let halfWidth=obstacle.width/2,halfHeight=obstacle.height/2;if(obstacle.type==="rect")return point6.x>=obstacle.center.x-halfWidth&&point6.x<=obstacle.center.x+halfWidth&&point6.y>=obstacle.center.y-halfHeight&&point6.y<=obstacle.center.y+halfHeight;if(obstacle.type==="oval"){let normalizedX=(point6.x-obstacle.center.x)/halfWidth,normalizedY=(point6.y-obstacle.center.y)/halfHeight;return normalizedX*normalizedX+normalizedY*normalizedY<=1}return!1}function dirFromAToB2(nodeA,nodeB){let dx2=nodeB.x>nodeA.x?1:nodeB.x<nodeA.x?-1:0,dy2=nodeB.y>nodeA.y?1:nodeB.y<nodeA.y?-1:0,dl2=nodeB.l>nodeA.l?1:nodeB.l<nodeA.l?-1:0;return{dx:dx2,dy:dy2,dl:dl2}}var LAYER_COUNT_INDEX_MAP={1:["top"],2:["top","bottom"],4:["top","inner1","inner2","bottom"]},getLayerNamesForLayerCount=layerCount=>LAYER_COUNT_INDEX_MAP[layerCount];function getLayerIndex(layerCount,layer){let index=LAYER_COUNT_INDEX_MAP[layerCount].indexOf(layer);if(index===-1)throw new Error(`Invalid layer for getLayerIndex (for layerCount === ${layerCount}): "${layer}"`);return index}function indexToLayer(layerCount,index){let layer=LAYER_COUNT_INDEX_MAP[layerCount][index];if(!layer)throw new Error(`Invalid index for indexToLayer (for layerCount === ${layerCount}): "${index}"`);return layer}var ObstacleList3d=class extends ObstacleList{constructor(layerCount,obstacles){super([]);__publicField(this,"obstacles");__publicField(this,"GRID_STEP",.1);__publicField(this,"layerCount");this.layerCount=layerCount;let availableLayers=getLayerNamesForLayerCount(layerCount);this.obstacles=obstacles.flatMap(obstacle=>obstacle.layers.filter(layer=>availableLayers.includes(layer)).map(layer=>({...obstacle,left:obstacle.center.x-obstacle.width/2,right:obstacle.center.x+obstacle.width/2,top:obstacle.center.y+obstacle.height/2,bottom:obstacle.center.y-obstacle.height/2,l:getLayerIndex(layerCount,layer)})))}getObstacleAt(x3,y3,l2,m3){m3??(m3=this.GRID_STEP);for(let obstacle of this.obstacles){if(obstacle.l!==l2)continue;let halfWidth=obstacle.width/2+m3,halfHeight=obstacle.height/2+m3;if(x3>=obstacle.center.x-halfWidth&&x3<=obstacle.center.x+halfWidth&&y3>=obstacle.center.y-halfHeight&&y3<=obstacle.center.y+halfHeight)return obstacle}return null}isObstacleAt(x3,y3,l2,m3){return this.getObstacleAt(x3,y3,l2,m3)!==null}getDirectionDistancesToNearestObstacle3d(x3,y3,l2){let{GRID_STEP}=this,result={left:1/0,top:1/0,bottom:1/0,right:1/0};for(let obstacle of this.obstacles)if(obstacle.l===l2&&obstacle.type==="rect"){let left=obstacle.center.x-obstacle.width/2-GRID_STEP,right=obstacle.center.x+obstacle.width/2+GRID_STEP,top=obstacle.center.y+obstacle.height/2+GRID_STEP,bottom=obstacle.center.y-obstacle.height/2-GRID_STEP;y3>=bottom&&y3<=top&&x3>left&&(result.left=Math.min(result.left,x3-right)),y3>=bottom&&y3<=top&&x3<right&&(result.right=Math.min(result.right,left-x3)),x3>=left&&x3<=right&&y3<top&&(result.top=Math.min(result.top,bottom-y3)),x3>=left&&x3<=right&&y3>bottom&&(result.bottom=Math.min(result.bottom,y3-top))}return result}getOrthoDirectionCollisionInfo(point6,dir,{margin=0}={}){let{x:x3,y:y3,l:l2}=point6,{dx:dx2,dy:dy2,dl:dl2}=dir,minDistance=1/0,collisionObstacle=null;if(dl2!==0){let newLayer=l2+dl2;return this.isObstacleAt(x3,y3,newLayer,margin)?(minDistance=1,collisionObstacle=this.getObstacleAt(x3,y3,newLayer,margin)):minDistance=1,{dx:dx2,dy:dy2,dl:dl2,wallDistance:minDistance,obstacle:collisionObstacle}}else{for(let obstacle of this.obstacles){if(obstacle.l!==l2)continue;let leftMargin=obstacle.left-margin,rightMargin=obstacle.right+margin,topMargin=obstacle.top+margin,bottomMargin=obstacle.bottom-margin,distance8=null;dx2===1&&dy2===0?y3>bottomMargin&&y3<topMargin&&x3<obstacle.left&&(distance8=obstacle.left-x3):dx2===-1&&dy2===0?y3>bottomMargin&&y3<topMargin&&x3>obstacle.right&&(distance8=x3-obstacle.right):dx2===0&&dy2===1?x3>leftMargin&&x3<rightMargin&&y3<obstacle.bottom&&(distance8=obstacle.bottom-y3):dx2===0&&dy2===-1&&x3>leftMargin&&x3<rightMargin&&y3>obstacle.top&&(distance8=y3-obstacle.top),distance8!==null&&distance8<minDistance&&(minDistance=distance8,collisionObstacle=obstacle)}return{dx:dx2,dy:dy2,dl:0,wallDistance:minDistance,obstacle:collisionObstacle}}}getObstaclesOverlappingRegion(region){let obstacles=[];for(let obstacle of this.obstacles){if(obstacle.l!==region.l)continue;let{left,right,top,bottom}=obstacle;left<=region.maxX&&right>=region.minX&&top>=region.minY&&bottom<=region.maxY&&obstacles.push(obstacle)}return obstacles}},MultilayerIjump=class extends GeneralizedAstarAutorouter{constructor(opts){super(opts);__publicField(this,"MAX_ITERATIONS",500);__publicField(this,"VIA_COST",4);__publicField(this,"VIA_DIAMETER",.5);__publicField(this,"allowLayerChange",!0);__publicField(this,"layerCount");__publicField(this,"obstacles");__publicField(this,"optimizeWithGoalBoxes");__publicField(this,"connMap");__publicField(this,"pcbConnMap");__publicField(this,"GOAL_RUSH_FACTOR",1.1);__publicField(this,"defaultGoalViaMargin",.5);__publicField(this,"marginsWithCosts");this.layerCount=opts.input.layerCount??2,this.MAX_ITERATIONS=opts.MAX_ITERATIONS??this.MAX_ITERATIONS,this.VIA_COST=opts.VIA_COST??this.VIA_COST,this.connMap=opts.connMap,this.pcbConnMap=opts.pcbConnMap??new PcbConnectivityMap,this.optimizeWithGoalBoxes=opts.optimizeWithGoalBoxes??!1,this.obstacles=null,this.marginsWithCosts=opts.marginsWithCosts??[{margin:1,enterCost:0,travelCostFactor:1},{margin:this.OBSTACLE_MARGIN,enterCost:10,travelCostFactor:2}]}get largestMargin(){return this.marginsWithCosts[0].margin}preprocessConnectionBeforeSolving(connection){return this.optimizeWithGoalBoxes?getConnectionWithAlternativeGoalBoxes({connection,pcbConnMap:this.pcbConnMap}):connection}postprocessConnectionSolveResult(connection,result){if(!result.solved)return result;if(this.optimizeWithGoalBoxes){let traceRoute=result.route.map(rp2=>({x:rp2.x,y:rp2.y,route_type:"wire",layer:rp2.layer,width:this.input.minTraceWidth}));traceRoute[0].start_pcb_port_id=connection.pointsToConnect[0].pcb_port_id,traceRoute[traceRoute.length-1].end_pcb_port_id=connection.pointsToConnect[1].pcb_port_id,this.pcbConnMap.addTrace({type:"pcb_trace",pcb_trace_id:`postprocess_trace_${nanoid(8)}`,route:traceRoute})}return result}createObstacleList({dominantLayer,connection,obstaclesFromTraces}){let bestConnectionId=this.connMap?this.connMap.getNetConnectedToId(connection.name):connection.name;if(!bestConnectionId)throw new Error(`The connection.name "${connection.name}" wasn't present in the full connectivity map`);return new ObstacleList3d(this.layerCount,this.allObstacles.filter(obstacle=>!obstacle.connectedTo.includes(bestConnectionId)).concat(obstaclesFromTraces??[]))}computeG(current2,neighbor){let cost=current2.g+manDist(current2,neighbor)*(current2.travelMarginCostFactor??1)+(neighbor.enterMarginCost??0);return(neighbor.l??current2.l!==-1??-1)&&(cost+=this.VIA_COST),cost}computeH(node){let dx2=Math.abs(node.x-this.goalPoint.x),dy2=Math.abs(node.y-this.goalPoint.y),dl2=Math.abs(node.l-this.goalPoint.l);return(dx2+dy2)**this.GOAL_RUSH_FACTOR+dl2*this.VIA_COST}getStartNode(connection){return{...super.getStartNode(connection),l:this.layerToIndex(connection.pointsToConnect[0].layer)}}layerToIndex(layer){return getLayerIndex(this.layerCount,layer)}indexToLayer(index){return indexToLayer(this.layerCount,index)}getNodeName(node){return`${nodeName(node,this.GRID_STEP)}-${node.l??0}`}hasSpaceForVia(layers,point6){return layers.every(l2=>this.obstacles.getObstaclesOverlappingRegion({minX:point6.x-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,minY:point6.y-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,maxX:point6.x+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,maxY:point6.y+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,l:l2}).length===0)}getNeighborsSurroundingGoal(node){let obstacles=this.obstacles,goalPoint=this.goalPoint,neighbors=[],travelDirs=[{dx:1,dy:0,dl:0},{dx:-1,dy:0,dl:0},{dx:0,dy:1,dl:0},{dx:0,dy:-1,dl:0}],travelDistance=this.VIA_DIAMETER+this.OBSTACLE_MARGIN+this.defaultGoalViaMargin;for(let dir of travelDirs){let candidateNeighbor={x:node.x+dir.dx*travelDistance,y:node.y+dir.dy*travelDistance,l:node.l+dir.dl,obstacleHit:null};this.hasSpaceForVia([node.l,goalPoint.l],candidateNeighbor)&&neighbors.push(candidateNeighbor)}return neighbors}getNeighbors(node){let obstacles=this.obstacles,goalPoint=this.goalPoint,goalDistIgnoringLayer=manDist(node,goalPoint);if(goalDistIgnoringLayer<=this.OBSTACLE_MARGIN)return this.getNeighborsSurroundingGoal(node);let forwardDir;node.parent?forwardDir=dirFromAToB2(node.parent,node):forwardDir=dirFromAToB2(node,goalPoint);let travelDirs1=[{dx:0,dy:1,dl:0},{dx:1,dy:0,dl:0},{dx:0,dy:-1,dl:0},{dx:-1,dy:0,dl:0}],isFarEnoughFromGoalToChangeLayer=goalDistIgnoringLayer>this.VIA_DIAMETER+this.OBSTACLE_MARGIN,isFarEnoughFromStartToChangeLayer=manDist(node,this.startNode)>this.VIA_DIAMETER+this.OBSTACLE_MARGIN;this.allowLayerChange&&isFarEnoughFromGoalToChangeLayer&&isFarEnoughFromStartToChangeLayer&&(node.l<this.layerCount-1&&travelDirs1.push({dx:0,dy:0,dl:1}),node.l>0&&travelDirs1.push({dx:0,dy:0,dl:-1}));let travelDirs2=travelDirs1.filter(dir=>dir.dx===forwardDir.dx*-1&&dir.dy===forwardDir.dy*-1&&dir.dl===forwardDir.dl*-1?!1:!(dir.dx===forwardDir.dx&&dir.dy===forwardDir.dy&&dir.dl===forwardDir.dl&&node.parent?.obstacleHit)).map(dir=>obstacles.getOrthoDirectionCollisionInfo(node,dir,{margin:this.OBSTACLE_MARGIN})).filter(dir=>!(dir.wallDistance<this.OBSTACLE_MARGIN)),travelDirs3=[];for(let travelDir of travelDirs2){let isDownVia=travelDir.dx===0&&travelDir.dy===0&&travelDir.dl===1,isUpVia=travelDir.dx===0&&travelDir.dy===0&&travelDir.dl===-1;if((isDownVia||isUpVia)&&![node.l,node.l+travelDir.dl].every(l2=>obstacles.getObstaclesOverlappingRegion({minX:node.x-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,minY:node.y-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,maxX:node.x+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,maxY:node.y+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,l:l2}).length===0))continue;if(isDownVia){node.l<this.layerCount-1&&travelDirs3.push({...travelDir,travelDistance:0,enterMarginCost:0,travelMarginCostFactor:1});continue}if(isUpVia){node.l>0&&travelDirs3.push({...travelDir,travelDistance:0,enterMarginCost:0,travelMarginCostFactor:1});continue}let overcomeDistance=null;node?.obstacleHit&&(overcomeDistance=getDistanceToOvercomeObstacle({node,travelDir,wallDir:{...forwardDir,wallDistance:this.OBSTACLE_MARGIN},obstacle:node.obstacleHit,obstacles,OBSTACLE_MARGIN:this.OBSTACLE_MARGIN,SHOULD_DETECT_CONJOINED_OBSTACLES:!0}));let goalDistAlongTravelDir=distAlongDir(node,goalPoint,travelDir),isGoalInTravelDir=(travelDir.dx===0||Math.sign(goalPoint.x-node.x)===travelDir.dx)&&(travelDir.dy===0||Math.sign(goalPoint.y-node.y)===travelDir.dy);if(goalDistAlongTravelDir<travelDir.wallDistance&&goalDistAlongTravelDir>0&&isGoalInTravelDir){let isGoalOnSameLayer=node.l===goalPoint.l,stopShortDistance=0;!isGoalOnSameLayer&&Math.abs(goalDistAlongTravelDir-goalDistIgnoringLayer)<this.GRID_STEP&&(stopShortDistance=this.VIA_DIAMETER+this.OBSTACLE_MARGIN+this.defaultGoalViaMargin),travelDirs3.push({...travelDir,travelDistance:goalDistAlongTravelDir-stopShortDistance,enterMarginCost:0,travelMarginCostFactor:1})}else if(overcomeDistance!==null&&overcomeDistance<travelDir.wallDistance){for(let{margin,enterCost,travelCostFactor}of this.marginsWithCosts)overcomeDistance-this.OBSTACLE_MARGIN+margin*2<travelDir.wallDistance&&travelDirs3.push({...travelDir,travelDistance:overcomeDistance-this.OBSTACLE_MARGIN+margin,enterMarginCost:enterCost,travelMarginCostFactor:travelCostFactor});if(travelDir.wallDistance===1/0)travelDirs3.push({...travelDir,travelDistance:goalDistAlongTravelDir,enterMarginCost:0,travelMarginCostFactor:1});else if(travelDir.wallDistance>this.largestMargin)for(let{margin,enterCost,travelCostFactor}of this.marginsWithCosts)travelDir.wallDistance>this.largestMargin+margin&&travelDirs3.push({...travelDir,travelDistance:travelDir.wallDistance-margin,enterMarginCost:enterCost,travelMarginCostFactor:travelCostFactor})}else if(travelDir.wallDistance!==1/0)for(let{margin,enterCost,travelCostFactor}of this.marginsWithCosts)travelDir.wallDistance>margin&&travelDirs3.push({...travelDir,travelDistance:travelDir.wallDistance-margin,enterMarginCost:enterCost,travelMarginCostFactor:travelCostFactor})}return travelDirs3.map(dir=>({x:node.x+dir.dx*dir.travelDistance,y:node.y+dir.dy*dir.travelDistance,l:node.l+dir.dl,obstacleHit:dir.obstacle,travelMarginCostFactor:dir.travelMarginCostFactor,enterMarginCost:dir.enterMarginCost}))}};function autoroute2(soup){let input2=getSimpleRouteJson(soup),autorouter=new IJumpAutorouter({input:input2});return{solution:autorouter.solveAndMapToTraces(),debugSolutions:autorouter.debugSolutions,debugMessage:autorouter.debugMessage}}init_zod();init_zod();init_dist();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_dist();init_zod();init_zod();init_dist();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();var expectTypesMatch2=shouldBe=>{};expectTypesMatch2("extra props b");expectTypesMatch2("missing props b");expectTypesMatch2(!0);expectTypesMatch2("property a has mismatched types");var direction=external_exports.enum(["up","down","left","right"]),directionAlongEdge=external_exports.enum(["top-to-bottom","left-to-right","bottom-to-top","right-to-left"]);expectTypesMatch2(!0);expectTypesMatch2(!0);var portHints=external_exports.array(external_exports.string().or(external_exports.number()));expectTypesMatch2(!0);var calcString=external_exports.string().regex(/^calc\(.*\)$/),distance3=distance,pcbCoordinate=calcString.or(distance),point32=external_exports.object({x:distance,y:distance,z:distance}),rotationPoint3=external_exports.object({x:external_exports.union([external_exports.number(),external_exports.string()]),y:external_exports.union([external_exports.number(),external_exports.string()]),z:external_exports.union([external_exports.number(),external_exports.string()])}),cadModelBase=external_exports.object({rotationOffset:external_exports.number().or(rotationPoint3).optional(),positionOffset:point32.optional(),size:point32.optional(),modelUnitToMmScale:distance3.optional(),zOffsetFromSurface:distance3.optional()});expectTypesMatch2(!0);var cadModelStl=cadModelBase.extend({stlUrl:external_exports.string()}),cadModelObj=cadModelBase.extend({objUrl:external_exports.string(),mtlUrl:external_exports.string().optional()}),cadModelGltf=cadModelBase.extend({gltfUrl:external_exports.string()}),cadModelGlb=cadModelBase.extend({glbUrl:external_exports.string()}),cadModelStep=cadModelBase.extend({stepUrl:external_exports.string()}),cadModelWrl=cadModelBase.extend({wrlUrl:external_exports.string()}),cadModelJscad=cadModelBase.extend({jscad:external_exports.record(external_exports.any())}),cadModelProp=external_exports.union([external_exports.null(),external_exports.string(),external_exports.custom(v4=>v4&&typeof v4=="object"&&"type"in v4&&"props"in v4),cadModelStl,cadModelObj,cadModelGltf,cadModelGlb,cadModelStep,cadModelWrl,cadModelJscad]);expectTypesMatch2(!0);var footprintProp=external_exports.custom(v4=>!0),pcbStyle=external_exports.object({silkscreenFontSize:distance.optional(),viaPadDiameter:distance.optional(),viaHoleDiameter:distance.optional(),silkscreenTextPosition:external_exports.union([external_exports.enum(["centered","outside","none"]),external_exports.object({offsetX:external_exports.number(),offsetY:external_exports.number()})]).optional(),silkscreenTextVisibility:external_exports.enum(["hidden","visible","inherit"]).optional()});expectTypesMatch2(!0);var schStyle=external_exports.object({defaultPassiveSize:external_exports.union([external_exports.enum(["xs","sm","md"]),distance]).optional(),defaultCapacitorOrientation:external_exports.enum(["vertical","none"]).optional()});expectTypesMatch2(!0);var symbolProp=external_exports.custom(v4=>!0),pcbLayoutProps=external_exports.object({pcbX:pcbCoordinate.optional(),pcbY:pcbCoordinate.optional(),pcbLeftEdgeX:pcbCoordinate.optional(),pcbRightEdgeX:pcbCoordinate.optional(),pcbTopEdgeY:pcbCoordinate.optional(),pcbBottomEdgeY:pcbCoordinate.optional(),pcbOffsetX:distance.optional(),pcbOffsetY:distance.optional(),pcbRotation:rotation.optional(),pcbPositionAnchor:external_exports.string().optional(),pcbPositionMode:external_exports.enum(["relative_to_group_anchor","auto","relative_to_board_anchor","relative_to_component_anchor"]).optional(),layer:layer_ref.optional(),pcbMarginTop:distance.optional(),pcbMarginRight:distance.optional(),pcbMarginBottom:distance.optional(),pcbMarginLeft:distance.optional(),pcbMarginX:distance.optional(),pcbMarginY:distance.optional(),pcbStyle:pcbStyle.optional(),pcbRelative:external_exports.boolean().optional(),relative:external_exports.boolean().optional()});expectTypesMatch2(!0);var commonLayoutProps=external_exports.object({pcbX:pcbCoordinate.optional(),pcbY:pcbCoordinate.optional(),pcbLeftEdgeX:pcbCoordinate.optional(),pcbRightEdgeX:pcbCoordinate.optional(),pcbTopEdgeY:pcbCoordinate.optional(),pcbBottomEdgeY:pcbCoordinate.optional(),pcbOffsetX:distance.optional(),pcbOffsetY:distance.optional(),pcbRotation:rotation.optional(),pcbPositionAnchor:external_exports.string().optional(),pcbPositionMode:external_exports.enum(["relative_to_group_anchor","auto","relative_to_board_anchor","relative_to_component_anchor"]).optional(),pcbMarginTop:distance.optional(),pcbMarginRight:distance.optional(),pcbMarginBottom:distance.optional(),pcbMarginLeft:distance.optional(),pcbMarginX:distance.optional(),pcbMarginY:distance.optional(),pcbStyle:pcbStyle.optional(),schMarginTop:distance.optional(),schMarginRight:distance.optional(),schMarginBottom:distance.optional(),schMarginLeft:distance.optional(),schMarginX:distance.optional(),schMarginY:distance.optional(),schX:distance.optional(),schY:distance.optional(),schRotation:rotation.optional(),layer:layer_ref.optional(),footprint:footprintProp.optional(),symbol:symbolProp.optional(),schStyle:schStyle.optional(),relative:external_exports.boolean().optional(),schRelative:external_exports.boolean().optional(),pcbRelative:external_exports.boolean().optional()});expectTypesMatch2(!0);var supplierProps=external_exports.object({supplierPartNumbers:external_exports.record(supplier_name,external_exports.array(external_exports.string())).optional()});expectTypesMatch2(!0);var pinAttributeMap=external_exports.object({providesPower:external_exports.boolean().optional(),requiresPower:external_exports.boolean().optional(),providesGround:external_exports.boolean().optional(),requiresGround:external_exports.boolean().optional(),providesVoltage:external_exports.union([external_exports.string(),external_exports.number()]).optional(),requiresVoltage:external_exports.union([external_exports.string(),external_exports.number()]).optional(),doNotConnect:external_exports.boolean().optional(),includeInBoardPinout:external_exports.boolean().optional(),highlightColor:external_exports.string().optional(),mustBeConnected:external_exports.boolean().optional()});expectTypesMatch2(!0);var commonComponentProps=commonLayoutProps.merge(supplierProps).extend({key:external_exports.any().optional(),name:external_exports.string(),cadModel:cadModelProp.optional(),children:external_exports.any().optional(),symbolName:external_exports.string().optional(),doNotPlace:external_exports.boolean().optional(),obstructsWithinBounds:external_exports.boolean().optional().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"),showAsTranslucentModel:external_exports.boolean().optional().describe("Whether to show this component's CAD model as translucent in the 3D viewer."),pinAttributes:external_exports.record(external_exports.string(),pinAttributeMap).optional()});expectTypesMatch2(!0);var lrPins=["pin1","left","pin2","right"],lrPolarPins=["pin1","left","anode","pos","pin2","right","cathode","neg"],distanceOrMultiplier=distance.or(external_exports.enum(["2x","3x","4x"]));var schematicOrientation=external_exports.enum(["vertical","horizontal","pos_top","pos_bottom","pos_left","pos_right","neg_top","neg_bottom","neg_left","neg_right"]).describe("horizontal means pins go 1->2 rightward and vertical means pins go 1->2 downward (generally, positive on top)");expectTypesMatch2(!0);var explicitPinSideDefinition=external_exports.object({pins:external_exports.array(external_exports.union([external_exports.number(),external_exports.string()])),direction:external_exports.union([external_exports.literal("top-to-bottom"),external_exports.literal("left-to-right"),external_exports.literal("bottom-to-top"),external_exports.literal("right-to-left")])}),schematicPortArrangement=external_exports.object({leftSize:external_exports.number().optional().describe("@deprecated, use leftPinCount"),topSize:external_exports.number().optional().describe("@deprecated, use topPinCount"),rightSize:external_exports.number().optional().describe("@deprecated, use rightPinCount"),bottomSize:external_exports.number().optional().describe("@deprecated, use bottomPinCount"),leftPinCount:external_exports.number().optional(),rightPinCount:external_exports.number().optional(),topPinCount:external_exports.number().optional(),bottomPinCount:external_exports.number().optional(),leftSide:explicitPinSideDefinition.optional(),rightSide:explicitPinSideDefinition.optional(),topSide:explicitPinSideDefinition.optional(),bottomSide:explicitPinSideDefinition.optional()}),schematicPinArrangement=schematicPortArrangement;expectTypesMatch2(!0);var schematicPinStyle=external_exports.record(external_exports.object({marginLeft:distance.optional(),marginRight:distance.optional(),marginTop:distance.optional(),marginBottom:distance.optional(),leftMargin:distance.optional(),rightMargin:distance.optional(),topMargin:distance.optional(),bottomMargin:distance.optional()}));expectTypesMatch2(!0);var schematicPinLabel=external_exports.string().regex(/^[A-Za-z0-9_]+$/),schematicSymbolSize=distance.or(external_exports.enum(["xs","sm","default","md"])).describe("distance between pin1 and pin2 of the schematic symbol"),ninePointAnchor2=external_exports.enum(["top_left","top_center","top_right","center_left","center","center_right","bottom_left","bottom_center","bottom_right"]),point2=external_exports.object({x:distance,y:distance}),base_manual_edit_event=external_exports.object({edit_event_id:external_exports.string(),in_progress:external_exports.boolean().optional(),created_at:external_exports.number()});expectTypesMatch2(!0);var edit_pcb_component_location_event=base_manual_edit_event.extend({pcb_edit_event_type:external_exports.literal("edit_component_location").describe("deprecated"),edit_event_type:external_exports.literal("edit_pcb_component_location"),pcb_component_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var edit_trace_hint_event=base_manual_edit_event.extend({pcb_edit_event_type:external_exports.literal("edit_trace_hint").describe("deprecated"),edit_event_type:external_exports.literal("edit_pcb_trace_hint").optional(),pcb_port_id:external_exports.string(),pcb_trace_hint_id:external_exports.string().optional(),route:external_exports.array(external_exports.object({x:external_exports.number(),y:external_exports.number(),via:external_exports.boolean().optional()}))});expectTypesMatch2(!0);var edit_schematic_component_location_event=base_manual_edit_event.extend({edit_event_type:external_exports.literal("edit_schematic_component_location"),schematic_component_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var edit_pcb_group_location_event=base_manual_edit_event.extend({edit_event_type:external_exports.literal("edit_pcb_group_location"),pcb_group_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var edit_schematic_group_location_event=base_manual_edit_event.extend({edit_event_type:external_exports.literal("edit_schematic_group_location"),schematic_group_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var manual_edit_event=external_exports.union([edit_pcb_component_location_event,edit_trace_hint_event,edit_schematic_component_location_event]);expectTypesMatch2(!0);var manual_pcb_placement=external_exports.object({selector:external_exports.string(),relative_to:external_exports.string().optional().default("group_center").describe("Can be a selector or 'group_center'"),center:point});expectTypesMatch2(!0);var manual_trace_hint=external_exports.object({pcb_port_selector:external_exports.string(),offsets:external_exports.array(route_hint_point)});expectTypesMatch2(!0);var manual_schematic_placement=external_exports.object({selector:external_exports.string(),relative_to:external_exports.string().optional().default("group_center").describe("Can be a selector or 'group_center'"),center:point});expectTypesMatch2(!0);var manual_edits_file=external_exports.object({pcb_placements:external_exports.array(manual_pcb_placement).optional(),manual_trace_hints:external_exports.array(manual_trace_hint).optional(),schematic_placements:external_exports.array(manual_schematic_placement).optional()});expectTypesMatch2(!0);var connectionTarget=external_exports.string().or(external_exports.array(external_exports.string()).readonly()).or(external_exports.array(external_exports.string())),createConnectionsProp=labels=>external_exports.record(external_exports.enum(labels),connectionTarget),layoutConfig=external_exports.object({layoutMode:external_exports.enum(["grid","flex","match-adapt","relative","none"]).optional(),position:external_exports.enum(["absolute","relative"]).optional(),grid:external_exports.boolean().optional(),gridCols:external_exports.number().or(external_exports.string()).optional(),gridRows:external_exports.number().or(external_exports.string()).optional(),gridTemplateRows:external_exports.string().optional(),gridTemplateColumns:external_exports.string().optional(),gridTemplate:external_exports.string().optional(),gridGap:external_exports.number().or(external_exports.string()).optional(),gridRowGap:external_exports.number().or(external_exports.string()).optional(),gridColumnGap:external_exports.number().or(external_exports.string()).optional(),flex:external_exports.boolean().or(external_exports.string()).optional(),flexDirection:external_exports.enum(["row","column"]).optional(),alignItems:external_exports.enum(["start","center","end","stretch"]).optional(),justifyContent:external_exports.enum(["start","center","end","stretch","space-between","space-around","space-evenly"]).optional(),flexRow:external_exports.boolean().optional(),flexColumn:external_exports.boolean().optional(),gap:external_exports.number().or(external_exports.string()).optional(),pack:external_exports.boolean().optional().describe("Pack the contents of this group using a packing strategy"),packOrderStrategy:external_exports.enum(["largest_to_smallest","first_to_last","highest_to_lowest_pin_count"]).optional(),packPlacementStrategy:external_exports.enum(["shortest_connection_along_outline"]).optional(),padding:length.optional(),paddingLeft:length.optional(),paddingRight:length.optional(),paddingTop:length.optional(),paddingBottom:length.optional(),paddingX:length.optional(),paddingY:length.optional(),width:length.optional(),height:length.optional(),matchAdapt:external_exports.boolean().optional(),matchAdaptTemplate:external_exports.any().optional()});expectTypesMatch2(!0);var border=external_exports.object({strokeWidth:length.optional(),dashed:external_exports.boolean().optional(),solid:external_exports.boolean().optional()}),pcbAnchorAlignmentAutocomplete=external_exports.custom(value=>typeof value=="string"),autorouterConfig=external_exports.object({serverUrl:external_exports.string().optional(),inputFormat:external_exports.enum(["simplified","circuit-json"]).optional(),serverMode:external_exports.enum(["job","solve-endpoint"]).optional(),serverCacheEnabled:external_exports.boolean().optional(),cache:external_exports.custom(v4=>!0).optional(),traceClearance:length.optional(),groupMode:external_exports.enum(["sequential_trace","subcircuit","sequential-trace"]).optional(),algorithmFn:external_exports.custom(v4=>typeof v4=="function"||v4===void 0).optional(),preset:external_exports.enum(["sequential_trace","subcircuit","auto","auto_local","auto_cloud","auto_jumper","tscircuit_beta","freerouting","laser_prefab","auto-jumper","sequential-trace","auto-local","auto-cloud"]).optional(),local:external_exports.boolean().optional()}),autorouterPreset=external_exports.union([external_exports.literal("sequential_trace"),external_exports.literal("subcircuit"),external_exports.literal("auto"),external_exports.literal("auto_local"),external_exports.literal("auto_cloud"),external_exports.literal("auto_jumper"),external_exports.literal("tscircuit_beta"),external_exports.literal("freerouting"),external_exports.literal("laser_prefab"),external_exports.literal("auto-jumper"),external_exports.literal("sequential-trace"),external_exports.literal("auto-local"),external_exports.literal("auto-cloud")]),autorouterString=external_exports.string(),autorouterProp=external_exports.union([autorouterConfig,autorouterPreset,autorouterString]),autorouterEffortLevel=external_exports.enum(["1x","2x","5x","10x","100x"]),baseGroupProps=commonLayoutProps.extend({name:external_exports.string().optional(),children:external_exports.any().optional(),schTitle:external_exports.string().optional(),key:external_exports.any().optional(),showAsSchematicBox:external_exports.boolean().optional(),connections:external_exports.record(external_exports.string(),connectionTarget.optional()).optional(),schPinArrangement:schematicPinArrangement.optional(),schPinSpacing:length.optional(),schPinStyle:schematicPinStyle.optional(),...layoutConfig.shape,grid:layoutConfig.shape.grid.describe("@deprecated use pcbGrid"),flex:layoutConfig.shape.flex.describe("@deprecated use pcbFlex"),pcbGrid:external_exports.boolean().optional(),pcbGridCols:external_exports.number().or(external_exports.string()).optional(),pcbGridRows:external_exports.number().or(external_exports.string()).optional(),pcbGridTemplateRows:external_exports.string().optional(),pcbGridTemplateColumns:external_exports.string().optional(),pcbGridTemplate:external_exports.string().optional(),pcbGridGap:external_exports.number().or(external_exports.string()).optional(),pcbGridRowGap:external_exports.number().or(external_exports.string()).optional(),pcbGridColumnGap:external_exports.number().or(external_exports.string()).optional(),pcbFlex:external_exports.boolean().or(external_exports.string()).optional(),pcbFlexGap:external_exports.number().or(external_exports.string()).optional(),pcbFlexDirection:external_exports.enum(["row","column"]).optional(),pcbAlignItems:external_exports.enum(["start","center","end","stretch"]).optional(),pcbJustifyContent:external_exports.enum(["start","center","end","stretch","space-between","space-around","space-evenly"]).optional(),pcbFlexRow:external_exports.boolean().optional(),pcbFlexColumn:external_exports.boolean().optional(),pcbGap:external_exports.number().or(external_exports.string()).optional(),pcbPack:external_exports.boolean().optional(),pcbPackGap:external_exports.number().or(external_exports.string()).optional(),schGrid:external_exports.boolean().optional(),schGridCols:external_exports.number().or(external_exports.string()).optional(),schGridRows:external_exports.number().or(external_exports.string()).optional(),schGridTemplateRows:external_exports.string().optional(),schGridTemplateColumns:external_exports.string().optional(),schGridTemplate:external_exports.string().optional(),schGridGap:external_exports.number().or(external_exports.string()).optional(),schGridRowGap:external_exports.number().or(external_exports.string()).optional(),schGridColumnGap:external_exports.number().or(external_exports.string()).optional(),schFlex:external_exports.boolean().or(external_exports.string()).optional(),schFlexGap:external_exports.number().or(external_exports.string()).optional(),schFlexDirection:external_exports.enum(["row","column"]).optional(),schAlignItems:external_exports.enum(["start","center","end","stretch"]).optional(),schJustifyContent:external_exports.enum(["start","center","end","stretch","space-between","space-around","space-evenly"]).optional(),schFlexRow:external_exports.boolean().optional(),schFlexColumn:external_exports.boolean().optional(),schGap:external_exports.number().or(external_exports.string()).optional(),schPack:external_exports.boolean().optional(),schMatchAdapt:external_exports.boolean().optional(),pcbWidth:length.optional(),pcbHeight:length.optional(),minTraceWidth:length.optional(),nominalTraceWidth:length.optional(),schWidth:length.optional(),schHeight:length.optional(),pcbLayout:layoutConfig.optional(),schLayout:layoutConfig.optional(),cellBorder:border.nullable().optional(),border:border.nullable().optional(),schPadding:length.optional(),schPaddingLeft:length.optional(),schPaddingRight:length.optional(),schPaddingTop:length.optional(),schPaddingBottom:length.optional(),pcbPadding:length.optional(),pcbPaddingLeft:length.optional(),pcbPaddingRight:length.optional(),pcbPaddingTop:length.optional(),pcbPaddingBottom:length.optional(),pcbAnchorAlignment:pcbAnchorAlignmentAutocomplete.optional()}),partsEngine=external_exports.custom(v4=>"findPart"in v4),subcircuitGroupProps=baseGroupProps.extend({manualEdits:manual_edits_file.optional(),schAutoLayoutEnabled:external_exports.boolean().optional(),schTraceAutoLabelEnabled:external_exports.boolean().optional(),schMaxTraceDistance:distance.optional(),routingDisabled:external_exports.boolean().optional(),bomDisabled:external_exports.boolean().optional(),defaultTraceWidth:length.optional(),minTraceWidth:length.optional(),nominalTraceWidth:length.optional(),partsEngine:partsEngine.optional(),pcbRouteCache:external_exports.custom(v4=>!0).optional(),autorouter:autorouterProp.optional(),autorouterEffortLevel:autorouterEffortLevel.optional(),autorouterVersion:external_exports.enum(["v1","v2","latest"]).optional(),square:external_exports.boolean().optional(),emptyArea:external_exports.string().optional(),filledArea:external_exports.string().optional(),width:distance.optional(),height:distance.optional(),outline:external_exports.array(point2).optional(),outlineOffsetX:distance.optional(),outlineOffsetY:distance.optional(),circuitJson:external_exports.array(external_exports.any()).optional()}),subcircuitGroupPropsWithBool=subcircuitGroupProps.extend({subcircuit:external_exports.literal(!0)}),groupProps=external_exports.discriminatedUnion("subcircuit",[baseGroupProps.extend({subcircuit:external_exports.literal(!1).optional()}),subcircuitGroupPropsWithBool]);expectTypesMatch2(!0);expectTypesMatch2(!0);expectTypesMatch2(!0);expectTypesMatch2(!0);var boardColor=external_exports.custom(value=>typeof value=="string"),boardProps=subcircuitGroupProps.omit({connections:!0}).extend({material:external_exports.enum(["fr4","fr1"]).default("fr4"),layers:external_exports.union([external_exports.literal(1),external_exports.literal(2),external_exports.literal(4),external_exports.literal(6),external_exports.literal(8)]).default(2),borderRadius:distance3.optional(),thickness:distance3.optional(),boardAnchorPosition:point2.optional(),anchorAlignment:ninePointAnchor2.optional(),boardAnchorAlignment:ninePointAnchor2.optional().describe("Prefer using anchorAlignment when possible"),title:external_exports.string().optional(),solderMaskColor:boardColor.optional(),topSolderMaskColor:boardColor.optional(),bottomSolderMaskColor:boardColor.optional(),silkscreenColor:boardColor.optional(),topSilkscreenColor:boardColor.optional(),bottomSilkscreenColor:boardColor.optional(),doubleSidedAssembly:external_exports.boolean().optional().default(!1),schematicDisabled:external_exports.boolean().optional()});expectTypesMatch2(!0);var panelProps=baseGroupProps.omit({width:!0,height:!0,layoutMode:!0,children:!0}).extend({width:distance3.optional(),height:distance3.optional(),children:external_exports.any().optional(),anchorAlignment:ninePointAnchor2.optional(),noSolderMask:external_exports.boolean().optional(),panelizationMethod:external_exports.enum(["tab-routing","none"]).optional(),boardGap:distance3.optional(),layoutMode:external_exports.enum(["grid","pack","none"]).optional(),row:external_exports.number().optional(),col:external_exports.number().optional(),cellWidth:distance3.optional(),cellHeight:distance3.optional(),tabWidth:distance3.optional(),tabLength:distance3.optional(),mouseBites:external_exports.boolean().optional(),edgePadding:distance3.optional(),edgePaddingLeft:distance3.optional(),edgePaddingRight:distance3.optional(),edgePaddingTop:distance3.optional(),edgePaddingBottom:distance3.optional()});expectTypesMatch2(!0);expectTypesMatch2(!0);var breakoutProps=subcircuitGroupProps.extend({padding:distance.optional(),paddingLeft:distance.optional(),paddingRight:distance.optional(),paddingTop:distance.optional(),paddingBottom:distance.optional()});expectTypesMatch2(!0);var connectionTarget2=external_exports.string().or(external_exports.array(external_exports.string()).readonly()).or(external_exports.array(external_exports.string())),connectionsProp=external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget2)),pinLabelsProp=external_exports.record(schematicPinLabel,schematicPinLabel.or(external_exports.array(schematicPinLabel).readonly()).or(external_exports.array(schematicPinLabel)));expectTypesMatch2(!0);var pinCompatibleVariant=external_exports.object({manufacturerPartNumber:external_exports.string().optional(),supplierPartNumber:external_exports.record(supplier_name,external_exports.array(external_exports.string())).optional()}),chipProps=commonComponentProps.extend({manufacturerPartNumber:external_exports.string().optional(),pinLabels:pinLabelsProp.optional(),showPinAliases:external_exports.boolean().optional(),pcbPinLabels:external_exports.record(external_exports.string(),external_exports.string()).optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional(),externallyConnectedPins:external_exports.array(external_exports.array(external_exports.string())).optional(),schPinArrangement:schematicPortArrangement.optional(),schPortArrangement:schematicPortArrangement.optional(),pinCompatibleVariants:external_exports.array(pinCompatibleVariant).optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional(),noSchematicRepresentation:external_exports.boolean().optional(),connections:connectionsProp.optional()});expectTypesMatch2(!0);var pinoutProps=chipProps;expectTypesMatch2(!0);var jumperProps=commonComponentProps.extend({manufacturerPartNumber:external_exports.string().optional(),pinLabels:external_exports.record(external_exports.number().or(schematicPinLabel),schematicPinLabel.or(external_exports.array(schematicPinLabel))).optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional(),schDirection:external_exports.enum(["left","right"]).optional(),schPinArrangement:schematicPinArrangement.optional(),schPortArrangement:schematicPortArrangement.optional(),pcbPinLabels:external_exports.record(external_exports.string(),external_exports.string()).optional(),pinCount:external_exports.union([external_exports.literal(2),external_exports.literal(3)]).optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional(),connections:external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget)).optional()});expectTypesMatch2(!0);var solderjumperProps=jumperProps.extend({bridgedPins:external_exports.array(external_exports.array(external_exports.string())).optional(),bridged:external_exports.boolean().optional()});expectTypesMatch2(!0);var connectorProps=commonComponentProps.extend({manufacturerPartNumber:external_exports.string().optional(),pinLabels:external_exports.record(external_exports.number().or(schematicPinLabel),schematicPinLabel.or(external_exports.array(schematicPinLabel))).optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional(),schDirection:external_exports.enum(["left","right"]).optional(),schPortArrangement:schematicPortArrangement.optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional(),standard:external_exports.enum(["usb_c","m2"]).optional()});expectTypesMatch2(!0);var interconnectProps=commonComponentProps.extend({standard:external_exports.enum(["TSC0001_36P_XALT_2025_11","0805","0603","1206"]).optional(),pinLabels:external_exports.record(external_exports.number().or(schematicPinLabel),schematicPinLabel.or(external_exports.array(schematicPinLabel))).optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional()});expectTypesMatch2(!0);var fuseProps=commonComponentProps.extend({currentRating:external_exports.union([external_exports.number(),external_exports.string()]),voltageRating:external_exports.union([external_exports.number(),external_exports.string()]).optional(),schShowRatings:external_exports.boolean().optional(),schOrientation:schematicOrientation.optional(),connections:external_exports.record(external_exports.string(),external_exports.union([external_exports.string(),external_exports.array(external_exports.string()).readonly(),external_exports.array(external_exports.string())])).optional()}),distanceHiddenUndefined=external_exports.custom().transform(a2=>{if(a2!==void 0)return distance.parse(a2)}),platedHoleProps=external_exports.discriminatedUnion("shape",[pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("circle"),holeDiameter:distance,outerDiameter:distance,padDiameter:distance.optional().describe("Diameter of the copper pad"),portHints:portHints.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("oval"),outerWidth:distance,outerHeight:distance,holeWidth:distanceHiddenUndefined,holeHeight:distanceHiddenUndefined,innerWidth:distance.optional().describe("DEPRECATED use holeWidth"),innerHeight:distance.optional().describe("DEPRECATED use holeHeight"),portHints:portHints.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("pill"),rectPad:external_exports.boolean().optional(),outerWidth:distance,outerHeight:distance,holeWidth:distanceHiddenUndefined,holeHeight:distanceHiddenUndefined,innerWidth:distance.optional().describe("DEPRECATED use holeWidth"),innerHeight:distance.optional().describe("DEPRECATED use holeHeight"),portHints:portHints.optional(),holeOffsetX:distance.optional(),holeOffsetY:distance.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("circular_hole_with_rect_pad"),holeDiameter:distance,rectPadWidth:distance,rectPadHeight:distance,rectBorderRadius:distance.optional(),holeShape:external_exports.literal("circle").optional(),padShape:external_exports.literal("rect").optional(),portHints:portHints.optional(),holeOffsetX:distance.optional(),holeOffsetY:distance.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("pill_hole_with_rect_pad"),holeShape:external_exports.literal("pill").optional(),padShape:external_exports.literal("rect").optional(),holeWidth:distance,holeHeight:distance,rectPadWidth:distance,rectPadHeight:distance,portHints:portHints.optional(),holeOffsetX:distance.optional(),holeOffsetY:distance.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("hole_with_polygon_pad"),holeShape:external_exports.enum(["circle","oval","pill","rotated_pill"]),holeDiameter:distance.optional(),holeWidth:distance.optional(),holeHeight:distance.optional(),padOutline:external_exports.array(point2),holeOffsetX:distance,holeOffsetY:distance,portHints:portHints.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()})]).refine(a2=>("innerWidth"in a2&&a2.innerWidth!==void 0&&(a2.holeWidth??(a2.holeWidth=a2.innerWidth)),"innerHeight"in a2&&a2.innerHeight!==void 0&&(a2.holeHeight??(a2.holeHeight=a2.innerHeight)),a2));expectTypesMatch2(!0);var resistorPinLabels=["pin1","pin2","pos","neg"],resistorProps=commonComponentProps.extend({resistance,pullupFor:external_exports.string().optional(),pullupTo:external_exports.string().optional(),pulldownFor:external_exports.string().optional(),pulldownTo:external_exports.string().optional(),schOrientation:schematicOrientation.optional(),schSize:schematicSymbolSize.optional(),connections:createConnectionsProp(resistorPinLabels).optional()}),resistorPins=lrPins;expectTypesMatch2(!0);var potentiometerProps=commonComponentProps.extend({maxResistance:resistance,pinVariant:external_exports.enum(["two_pin","three_pin"]).optional()});expectTypesMatch2(!0);var crystalPins=lrPins,crystalProps=commonComponentProps.extend({frequency,loadCapacitance:capacitance,manufacturerPartNumber:external_exports.string().optional(),mpn:external_exports.string().optional(),pinVariant:external_exports.enum(["two_pin","four_pin"]).optional(),schOrientation:schematicOrientation.optional(),connections:createConnectionsProp(crystalPins).optional()});expectTypesMatch2(!0);var resonatorProps=commonComponentProps.extend({frequency,loadCapacitance:capacitance,pinVariant:external_exports.enum(["no_ground","ground_pin","two_ground_pins"]).optional()});expectTypesMatch2(!0);var stampboardProps=boardProps.extend({leftPinCount:external_exports.number().optional(),rightPinCount:external_exports.number().optional(),topPinCount:external_exports.number().optional(),bottomPinCount:external_exports.number().optional(),leftPins:external_exports.array(external_exports.string()).optional(),rightPins:external_exports.array(external_exports.string()).optional(),topPins:external_exports.array(external_exports.string()).optional(),bottomPins:external_exports.array(external_exports.string()).optional(),pinPitch:distance.optional(),innerHoles:external_exports.boolean().optional()});expectTypesMatch2(!0);var capacitorPinLabels=["pin1","pin2","pos","neg","anode","cathode"],capacitorProps=commonComponentProps.extend({capacitance,maxVoltageRating:voltage.optional(),schShowRatings:external_exports.boolean().optional().default(!1),polarized:external_exports.boolean().optional().default(!1),decouplingFor:external_exports.string().optional(),decouplingTo:external_exports.string().optional(),bypassFor:external_exports.string().optional(),bypassTo:external_exports.string().optional(),maxDecouplingTraceLength:external_exports.number().optional(),schOrientation:schematicOrientation.optional(),schSize:schematicSymbolSize.optional(),connections:createConnectionsProp(capacitorPinLabels).optional()}),capacitorPins=lrPolarPins;expectTypesMatch2(!0);var netProps=external_exports.object({name:external_exports.string(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),highlightColor:external_exports.string().optional(),isPowerNet:external_exports.boolean().optional(),isGroundNet:external_exports.boolean().optional()});expectTypesMatch2(!0);var fiducialProps=commonComponentProps.extend({soldermaskPullback:distance3.optional(),padDiameter:distance3.optional()});expectTypesMatch2(!0);var constrainedLayoutProps=external_exports.object({name:external_exports.string().optional(),pcbOnly:external_exports.boolean().optional(),schOnly:external_exports.boolean().optional()});expectTypesMatch2(!0);var pcbXDistConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),xDist:distance3,left:external_exports.string(),right:external_exports.string(),edgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var pcbYDistConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),yDist:distance3,top:external_exports.string(),bottom:external_exports.string(),edgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var pcbSameYConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),sameY:external_exports.literal(!0).optional(),for:external_exports.array(external_exports.string())});expectTypesMatch2(!0);var pcbSameXConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),sameX:external_exports.literal(!0).optional(),for:external_exports.array(external_exports.string())});expectTypesMatch2(!0);var constraintProps=external_exports.union([pcbXDistConstraintProps,pcbYDistConstraintProps,pcbSameYConstraintProps,pcbSameXConstraintProps]);expectTypesMatch2(!0);var rectCutoutProps=pcbLayoutProps.omit({layer:!0,pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("rect"),width:distance3,height:distance3});expectTypesMatch2(!0);var circleCutoutProps=pcbLayoutProps.omit({layer:!0,pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("circle"),radius:distance3});expectTypesMatch2(!0);var polygonCutoutProps=pcbLayoutProps.omit({layer:!0,pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("polygon"),points:external_exports.array(point2)});expectTypesMatch2(!0);var cutoutProps=external_exports.discriminatedUnion("shape",[rectCutoutProps,circleCutoutProps,polygonCutoutProps]),rectSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("rect"),width:distance3,height:distance3,rectBorderRadius:distance3.optional(),cornerRadius:distance3.optional(),portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var rotatedRectSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("rotated_rect"),width:distance3,height:distance3,ccwRotation:external_exports.number(),cornerRadius:distance3.optional(),portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var circleSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("circle"),radius:distance3,portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var pillSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("pill"),width:distance3,height:distance3,radius:distance3,portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var polygonSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("polygon"),points:external_exports.array(point2),portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var smtPadProps=external_exports.discriminatedUnion("shape",[circleSmtPadProps,rectSmtPadProps,rotatedRectSmtPadProps,pillSmtPadProps,polygonSmtPadProps]);expectTypesMatch2(!0);var rectSolderPasteProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({shape:external_exports.literal("rect"),width:distance3,height:distance3});expectTypesMatch2(!0);var circleSolderPasteProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({shape:external_exports.literal("circle"),radius:distance3});expectTypesMatch2(!0);var solderPasteProps=external_exports.union([circleSolderPasteProps,rectSolderPasteProps]);expectTypesMatch2(!0);var circleHoleProps=pcbLayoutProps.extend({name:external_exports.string().optional(),shape:external_exports.literal("circle").optional(),diameter:distance3.optional(),radius:distance3.optional(),solderMaskMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional()}).transform(d3=>({...d3,diameter:d3.diameter??2*d3.radius,radius:d3.radius??d3.diameter/2})),pillHoleProps=pcbLayoutProps.extend({name:external_exports.string().optional(),shape:external_exports.literal("pill"),width:distance3,height:distance3,solderMaskMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),rectHoleProps=pcbLayoutProps.extend({name:external_exports.string().optional(),shape:external_exports.literal("rect"),width:distance3,height:distance3,solderMaskMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),holeProps=external_exports.union([circleHoleProps,pillHoleProps,rectHoleProps]);expectTypesMatch2(!0);var portRef=external_exports.union([external_exports.string(),external_exports.custom(v4=>!!v4.getPortSelector)]),pcbPath=external_exports.array(external_exports.union([point2,external_exports.string()])),baseTraceProps=external_exports.object({key:external_exports.string().optional(),thickness:distance.optional(),width:distance.optional().describe("Alias for trace thickness"),schematicRouteHints:external_exports.array(point2).optional(),pcbRouteHints:external_exports.array(route_hint_point).optional(),pcbPathRelativeTo:external_exports.string().optional(),pcbPath:pcbPath.optional(),pcbPaths:external_exports.array(pcbPath).optional(),pcbStraightLine:external_exports.boolean().optional().describe("Draw a straight pcb trace between the connected points"),schDisplayLabel:external_exports.string().optional(),schStroke:external_exports.string().optional(),highlightColor:external_exports.string().optional(),maxLength:distance.optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional()}),traceProps=external_exports.union([baseTraceProps.extend({path:external_exports.array(portRef)}),baseTraceProps.extend({from:portRef,to:portRef})]),footprintProps=external_exports.object({children:external_exports.any().optional(),originalLayer:layer_ref.default("top").optional(),circuitJson:external_exports.array(external_exports.any()).optional()});expectTypesMatch2(!0);var symbolProps=external_exports.object({originalFacingDirection:external_exports.enum(["up","down","left","right"]).default("right").optional()});expectTypesMatch2(!0);var capacity=external_exports.number().or(external_exports.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"),batteryProps=commonComponentProps.extend({capacity:capacity.optional(),voltage:voltage.optional(),standard:external_exports.enum(["AA","AAA","9V","CR2032","18650","C"]).optional(),schOrientation:schematicOrientation.optional()});expectTypesMatch2(!0);var pcbOrientation=external_exports.enum(["vertical","horizontal"]).describe("vertical means pins go 1->2 downward and horizontal means pins go 1->2 rightward");expectTypesMatch2(!0);var pinHeaderProps=commonComponentProps.extend({pinCount:external_exports.number(),pitch:distance.optional(),schFacingDirection:external_exports.enum(["up","down","left","right"]).optional(),gender:external_exports.enum(["male","female","unpopulated"]).optional().default("male"),showSilkscreenPinLabels:external_exports.boolean().optional(),pcbPinLabels:external_exports.record(external_exports.string(),external_exports.string()).optional(),doubleRow:external_exports.boolean().optional(),rightAngle:external_exports.boolean().optional(),pcbOrientation:pcbOrientation.optional(),holeDiameter:distance.optional(),platedDiameter:distance.optional(),pinLabels:external_exports.record(external_exports.string(),schematicPinLabel).or(external_exports.array(schematicPinLabel)).optional(),connections:external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget)).optional(),facingDirection:external_exports.enum(["left","right"]).optional(),schPinArrangement:schematicPinArrangement.optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional()});expectTypesMatch2(!0);var netAliasProps=external_exports.object({net:external_exports.string().optional(),connection:external_exports.string().optional(),schX:distance3.optional(),schY:distance3.optional(),schRotation:rotation.optional(),anchorSide:external_exports.enum(["left","top","right","bottom"]).optional()});expectTypesMatch2(!0);var netLabelProps=external_exports.object({net:external_exports.string().optional(),connection:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),schX:distance3.optional(),schY:distance3.optional(),schRotation:rotation.optional(),anchorSide:external_exports.enum(["left","top","right","bottom"]).optional()});expectTypesMatch2(!0);var pushButtonProps=chipProps.extend({});expectTypesMatch2(!0);expectTypesMatch2(!0);var spiceEngine=external_exports.custom(value=>typeof value=="string"),analogSimulationProps=external_exports.object({simulationType:external_exports.literal("spice_transient_analysis").default("spice_transient_analysis"),duration:ms.optional(),timePerStep:ms.optional(),spiceEngine:spiceEngine.optional()});expectTypesMatch2(!0);var transistorPinsLabels=["pin1","pin2","pin3","emitter","collector","base","gate","source","drain"],transistorProps=commonComponentProps.extend({type:external_exports.enum(["npn","pnp","bjt","jfet","mosfet","igbt"]),connections:createConnectionsProp(transistorPinsLabels).optional()});expectTypesMatch2(!0);var mosfetProps=commonComponentProps.extend({channelType:external_exports.enum(["n","p"]),mosfetMode:external_exports.enum(["enhancement","depletion"])});expectTypesMatch2(!0);var opampPinLabels=["inverting_input","non_inverting_input","output","positive_supply","negative_supply"],opampProps=commonComponentProps.extend({connections:createConnectionsProp(opampPinLabels).optional()});expectTypesMatch2(!0);var inductorPins=lrPins,inductorProps=commonComponentProps.extend({inductance,maxCurrentRating:external_exports.union([external_exports.string(),external_exports.number()]).optional(),schOrientation:schematicOrientation.optional(),connections:createConnectionsProp(inductorPins).optional()});expectTypesMatch2(!0);var diodeConnectionKeys=external_exports.enum(["anode","cathode","pin1","pin2","pos","neg"]),connectionTarget3=external_exports.string().or(external_exports.array(external_exports.string()).readonly()).or(external_exports.array(external_exports.string())),connectionsProp2=external_exports.record(diodeConnectionKeys,connectionTarget3),diodeVariant=external_exports.enum(["standard","schottky","zener","avalanche","photo","tvs"]),diodeProps=commonComponentProps.extend({connections:connectionsProp2.optional(),variant:diodeVariant.optional().default("standard"),standard:external_exports.boolean().optional(),schottky:external_exports.boolean().optional(),zener:external_exports.boolean().optional(),avalanche:external_exports.boolean().optional(),photo:external_exports.boolean().optional(),tvs:external_exports.boolean().optional(),schOrientation:schematicOrientation.optional()}).superRefine((data,ctx)=>{if([data.standard,data.schottky,data.zener,data.avalanche,data.photo,data.tvs].filter(Boolean).length>1)return ctx.addIssue({code:external_exports.ZodIssueCode.custom,message:"Exactly one diode variant must be enabled",path:[]}),external_exports.INVALID}).transform(data=>{let result={...data,standard:!1,schottky:!1,zener:!1,avalanche:!1,photo:!1,tvs:!1};if(data.standard)result.standard=!0;else if(data.schottky)result.schottky=!0;else if(data.zener)result.zener=!0;else if(data.photo)result.photo=!0;else if(data.tvs)result.tvs=!0;else switch(data.variant){case"standard":result.standard=!0;break;case"schottky":result.schottky=!0;break;case"zener":result.zener=!0;break;case"avalanche":result.avalanche=!0;break;case"photo":result.photo=!0;break;case"tvs":result.tvs=!0;break;default:result.standard=!0}return result}),diodePins=lrPolarPins;expectTypesMatch2(!0);var ledProps=commonComponentProps.extend({color:external_exports.string().optional(),wavelength:external_exports.string().optional(),schDisplayValue:external_exports.string().optional(),schOrientation:schematicOrientation.optional(),connections:createConnectionsProp(lrPolarPins).optional(),laser:external_exports.boolean().optional()}),ledPins=lrPolarPins,switchProps=commonComponentProps.extend({type:external_exports.enum(["spst","spdt","dpst","dpdt"]).optional(),isNormallyClosed:external_exports.boolean().optional().default(!1),spst:external_exports.boolean().optional(),spdt:external_exports.boolean().optional(),dpst:external_exports.boolean().optional(),dpdt:external_exports.boolean().optional(),simSwitchFrequency:frequency.optional(),simCloseAt:ms.optional(),simOpenAt:ms.optional(),simStartClosed:external_exports.boolean().optional(),simStartOpen:external_exports.boolean().optional(),connections:external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget)).optional()}).transform(props=>{let updatedProps={...props};switch(updatedProps.dpdt?updatedProps.type="dpdt":updatedProps.spst?updatedProps.type="spst":updatedProps.spdt?updatedProps.type="spdt":updatedProps.dpst&&(updatedProps.type="dpst"),updatedProps.type){case"spdt":updatedProps.spdt=!0;break;case"spst":updatedProps.spst=!0;break;case"dpst":updatedProps.dpst=!0;break;case"dpdt":updatedProps.dpdt=!0;break}return updatedProps});expectTypesMatch2(!0);var fabricationNoteTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:external_exports.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var fabricationNoteRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({width:distance,height:distance,strokeWidth:distance.optional(),isFilled:external_exports.boolean().optional(),hasStroke:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional(),cornerRadius:distance.optional()}),fabricationNotePathProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({route:external_exports.array(route_hint_point),strokeWidth:length.optional(),color:external_exports.string().optional()}),dimensionTarget=external_exports.union([external_exports.string(),point2]),fabricationNoteDimensionProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({from:dimensionTarget,to:dimensionTarget,text:external_exports.string().optional(),offset:distance.optional(),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional(),arrowSize:distance.optional(),units:external_exports.enum(["in","mm"]).optional(),outerEdgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional(),innerEdgeToEdge:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var pcbTraceProps=external_exports.object({layer:external_exports.string().optional(),thickness:distance.optional(),route:external_exports.array(route_hint_point)}),viaProps=commonLayoutProps.extend({name:external_exports.string().optional(),fromLayer:layer_ref,toLayer:layer_ref,holeDiameter:distance.optional(),outerDiameter:distance.optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),netIsAssignable:external_exports.boolean().optional()});expectTypesMatch2(!0);var testpointConnectionsProp=external_exports.object({pin1:connectionTarget}).strict(),testpointProps=commonComponentProps.extend({connections:testpointConnectionsProp.optional(),footprintVariant:external_exports.enum(["pad","through_hole"]).optional(),padShape:external_exports.enum(["rect","circle"]).optional().default("circle"),padDiameter:distance.optional(),holeDiameter:distance.optional(),width:distance.optional(),height:distance.optional()}).refine(props=>props.footprintVariant!=="through_hole"||props.holeDiameter!==void 0,{message:"holeDiameter is required for through_hole testpoints"});expectTypesMatch2(!0);var breakoutPointProps=pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({connection:external_exports.string()});expectTypesMatch2(!0);var pcbKeepoutProps=external_exports.union([pcbLayoutProps.omit({pcbRotation:!0}).extend({shape:external_exports.literal("circle"),radius:distance}),pcbLayoutProps.extend({shape:external_exports.literal("rect"),width:distance,height:distance})]),courtyardRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({width:distance,height:distance,strokeWidth:distance.optional(),isFilled:external_exports.boolean().optional(),hasStroke:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional()}),courtyardOutlineProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({outline:external_exports.array(point2),strokeWidth:length.optional(),isClosed:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional()}),copperPourProps=external_exports.object({name:external_exports.string().optional(),layer:layer_ref,connectsTo:external_exports.string(),padMargin:distance3.optional(),traceMargin:distance3.optional(),clearance:distance3.optional(),boardEdgeMargin:distance3.optional(),cutoutMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional().default(!0)});expectTypesMatch2(!0);var cadassemblyProps=external_exports.object({originalLayer:layer_ref.default("top").optional(),children:external_exports.any().optional()});expectTypesMatch2(!0);var pcbPosition=external_exports.object({pcbX:pcbCoordinate.optional(),pcbY:pcbCoordinate.optional(),pcbLeftEdgeX:pcbCoordinate.optional(),pcbRightEdgeX:pcbCoordinate.optional(),pcbTopEdgeY:pcbCoordinate.optional(),pcbBottomEdgeY:pcbCoordinate.optional(),pcbOffsetX:distance3.optional(),pcbOffsetY:distance3.optional(),pcbZ:distance3.optional()}),cadModelBaseWithUrl=cadModelBase.extend({modelUrl:external_exports.string(),stepUrl:external_exports.string().optional()}),cadModelObject=cadModelBaseWithUrl.merge(pcbPosition);expectTypesMatch2(!0);var cadmodelProps=external_exports.union([external_exports.null(),external_exports.string(),cadModelObject]),powerSourceProps=commonComponentProps.extend({voltage}),voltageSourcePinLabels=["pin1","pin2","pos","neg"],percentage3=external_exports.union([external_exports.string(),external_exports.number()]).transform(val=>typeof val=="string"?val.endsWith("%")?parseFloat(val.slice(0,-1))/100:parseFloat(val):val).pipe(external_exports.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),voltageSourceProps=commonComponentProps.extend({voltage:voltage.optional(),frequency:frequency.optional(),peakToPeakVoltage:voltage.optional(),waveShape:external_exports.enum(["sinewave","square","triangle","sawtooth"]).optional(),phase:rotation.optional(),dutyCycle:percentage3.optional(),connections:createConnectionsProp(voltageSourcePinLabels).optional()});expectTypesMatch2(!0);var currentSourcePinLabels=["pin1","pin2","pos","neg"],percentage22=external_exports.union([external_exports.string(),external_exports.number()]).transform(val=>typeof val=="string"?val.endsWith("%")?parseFloat(val.slice(0,-1))/100:parseFloat(val):val).pipe(external_exports.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),currentSourceProps=commonComponentProps.extend({current:current.optional(),frequency:frequency.optional(),peakToPeakCurrent:current.optional(),waveShape:external_exports.enum(["sinewave","square","triangle","sawtooth"]).optional(),phase:rotation.optional(),dutyCycle:percentage22.optional(),connections:createConnectionsProp(currentSourcePinLabels).optional()});expectTypesMatch2(!0);var voltageProbeProps=commonComponentProps.omit({name:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string(),referenceTo:external_exports.string().optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var schematicArcProps=external_exports.object({center:point,radius:distance,startAngleDegrees:rotation,endAngleDegrees:rotation,direction:external_exports.enum(["clockwise","counterclockwise"]).default("counterclockwise"),strokeWidth:distance.optional(),color:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1)});expectTypesMatch2(!0);var toolingrailProps=external_exports.object({children:external_exports.any().optional()});expectTypesMatch2(!0);var schematicBoxProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),width:distance.optional(),height:distance.optional(),overlay:external_exports.array(external_exports.string()).optional(),padding:distance.optional(),paddingLeft:distance.optional(),paddingRight:distance.optional(),paddingTop:distance.optional(),paddingBottom:distance.optional(),title:external_exports.string().optional(),titleAlignment:ninePointAnchor2.default("top_left"),titleColor:external_exports.string().optional(),titleFontSize:distance.optional(),titleInside:external_exports.boolean().default(!1),strokeStyle:external_exports.enum(["solid","dashed"]).default("solid")}).refine(elm=>elm.width!==void 0&&elm.height!==void 0||Array.isArray(elm.overlay)&&elm.overlay.length>0,{message:"Must provide either both `width` and `height`, or a non-empty `overlay` array."}).refine(elm=>!(elm.width!==void 0&&elm.height!==void 0&&Array.isArray(elm.overlay)&&elm.overlay.length>0),{message:"Cannot provide both `width`/`height` and `overlay` at the same time."});expectTypesMatch2(!0);var schematicCircleProps=external_exports.object({center:point,radius:distance,strokeWidth:distance.optional(),color:external_exports.string().optional(),isFilled:external_exports.boolean().optional().default(!1),fillColor:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1)});expectTypesMatch2(!0);var schematicRectProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),width:distance,height:distance,rotation:rotation.default(0),strokeWidth:distance.optional(),color:external_exports.string().optional(),isFilled:external_exports.boolean().optional().default(!1),fillColor:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1),cornerRadius:distance.optional()});expectTypesMatch2(!0);var schematicLineProps=external_exports.object({x1:distance,y1:distance,x2:distance,y2:distance,strokeWidth:distance.optional(),color:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1)});expectTypesMatch2(!0);var fivePointAnchor2=external_exports.enum(["center","left","right","top","bottom"]),schematicTextProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),text:external_exports.string(),fontSize:external_exports.number().default(1),anchor:external_exports.union([fivePointAnchor2.describe("legacy"),ninePointAnchor2]).default("center"),color:external_exports.string().default("#000000"),schRotation:rotation.default(0)});expectTypesMatch2(!0);var schematicPathProps=external_exports.object({points:external_exports.array(point),isFilled:external_exports.boolean().optional().default(!1),fillColor:external_exports.enum(["red","blue"]).optional()});expectTypesMatch2(!0);var schematicTableProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),children:external_exports.any().optional(),cellPadding:distance.optional(),borderWidth:distance.optional(),anchor:ninePointAnchor2.optional(),fontSize:distance.optional()});expectTypesMatch2(!0);var schematicRowProps=external_exports.object({children:external_exports.any().optional(),height:distance.optional()});expectTypesMatch2(!0);var schematicCellProps=external_exports.object({children:external_exports.string().optional(),horizontalAlign:external_exports.enum(["left","center","right"]).optional(),verticalAlign:external_exports.enum(["top","middle","bottom"]).optional(),fontSize:distance.optional(),rowSpan:external_exports.number().optional(),colSpan:external_exports.number().optional(),width:distance.optional(),text:external_exports.string().optional()});expectTypesMatch2(!0);var copperTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:ninePointAnchor2.default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),layers:external_exports.array(layer_ref).optional(),knockout:external_exports.boolean().optional(),mirrored:external_exports.boolean().optional()}),silkscreenTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:ninePointAnchor2.default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),isKnockout:external_exports.boolean().optional(),knockoutPadding:length.optional(),knockoutPaddingLeft:length.optional(),knockoutPaddingRight:length.optional(),knockoutPaddingTop:length.optional(),knockoutPaddingBottom:length.optional(),layers:external_exports.array(layer_ref).optional()}),silkscreenPathProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({route:external_exports.array(route_hint_point),strokeWidth:length.optional()}),silkscreenLineProps=pcbLayoutProps.omit({pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({strokeWidth:distance,x1:distance,y1:distance,x2:distance,y2:distance}),silkscreenRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({filled:external_exports.boolean().default(!0).optional(),stroke:external_exports.enum(["dashed","solid","none"]).optional(),strokeWidth:distance.optional(),width:distance,height:distance,cornerRadius:distance.optional()}),silkscreenCircleProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({isFilled:external_exports.boolean().optional(),isOutline:external_exports.boolean().optional(),strokeWidth:distance.optional(),radius:distance}),routeHintPointProps=external_exports.object({x:distance,y:distance,via:external_exports.boolean().optional(),toLayer:layer_ref.optional()}),traceHintProps=external_exports.object({for:external_exports.string().optional().describe("Selector for the port you're targeting, not required if you're inside a trace"),order:external_exports.number().optional(),offset:route_hint_point.or(routeHintPointProps).optional(),offsets:external_exports.array(route_hint_point).or(external_exports.array(routeHintPointProps)).optional(),traceWidth:external_exports.number().optional()}),portProps=commonLayoutProps.extend({name:external_exports.string(),pinNumber:external_exports.number().optional(),aliases:external_exports.array(external_exports.string()).optional(),direction,connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional()}),pcbNoteTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:external_exports.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var pcbNoteRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({width:distance,height:distance,strokeWidth:distance.optional(),isFilled:external_exports.boolean().optional(),hasStroke:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional(),cornerRadius:distance.optional()});expectTypesMatch2(!0);var pcbNotePathProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({route:external_exports.array(route_hint_point),strokeWidth:length.optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var pcbNoteLineProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({x1:distance,y1:distance,x2:distance,y2:distance,strokeWidth:distance.optional(),color:external_exports.string().optional(),isDashed:external_exports.boolean().optional()});expectTypesMatch2(!0);var dimensionTarget2=external_exports.union([external_exports.string(),point2]),pcbNoteDimensionProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({from:dimensionTarget2,to:dimensionTarget2,text:external_exports.string().optional(),offset:distance.optional(),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional(),arrowSize:distance.optional(),units:external_exports.enum(["in","mm"]).optional(),outerEdgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional(),innerEdgeToEdge:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var unvalidatedCircuitJson=external_exports.array(external_exports.any()).describe("Circuit JSON"),footprintLibraryResult=external_exports.object({footprintCircuitJson:external_exports.array(external_exports.any()),cadModel:cadModelProp.optional()}),pathToCircuitJsonFn=external_exports.function().args(external_exports.string()).returns(external_exports.promise(footprintLibraryResult)).or(external_exports.function().args(external_exports.string(),external_exports.object({resolvedPcbStyle:pcbStyle.optional()}).optional()).returns(external_exports.promise(footprintLibraryResult))).describe("A function that takes a path and returns Circuit JSON"),footprintFileParserEntry=external_exports.object({loadFromUrl:external_exports.function().args(external_exports.string()).returns(external_exports.promise(footprintLibraryResult)).describe("A function that takes a footprint file URL and returns Circuit JSON")}),spiceEngineSimulationResult=external_exports.object({engineVersionString:external_exports.string().optional(),simulationResultCircuitJson:unvalidatedCircuitJson}),spiceEngineZod=external_exports.object({simulate:external_exports.function().args(external_exports.string()).returns(external_exports.promise(spiceEngineSimulationResult)).describe("A function that takes a SPICE string and returns a simulation result")}),defaultSpiceEngine=external_exports.custom(value=>typeof value=="string"),autorouterInstance=external_exports.object({run:external_exports.function().args().returns(external_exports.promise(external_exports.unknown())).describe("Run the autorouter"),getOutputSimpleRouteJson:external_exports.function().args().returns(external_exports.promise(external_exports.any())).describe("Get the resulting SimpleRouteJson")}),autorouterDefinition=external_exports.object({createAutorouter:external_exports.function().args(external_exports.any(),external_exports.any().optional()).returns(external_exports.union([autorouterInstance,external_exports.promise(autorouterInstance)])).describe("Create an autorouter instance")}),platformConfig=external_exports.object({partsEngine:partsEngine.optional(),autorouter:autorouterProp.optional(),autorouterMap:external_exports.record(external_exports.string(),autorouterDefinition).optional(),registryApiUrl:external_exports.string().optional(),cloudAutorouterUrl:external_exports.string().optional(),projectName:external_exports.string().optional(),projectBaseUrl:external_exports.string().optional(),version:external_exports.string().optional(),url:external_exports.string().optional(),printBoardInformationToSilkscreen:external_exports.boolean().optional(),includeBoardFiles:external_exports.array(external_exports.string()).describe('The board files to automatically build with "tsci build", defaults to ["**/*.circuit.tsx"]. Can be an array of files or globs').optional(),snapshotsDir:external_exports.string().describe('The directory where snapshots are stored for "tsci snapshot", defaults to "tests/__snapshots__"').optional(),defaultSpiceEngine:defaultSpiceEngine.optional(),localCacheEngine:external_exports.any().optional(),pcbDisabled:external_exports.boolean().optional(),schematicDisabled:external_exports.boolean().optional(),partsEngineDisabled:external_exports.boolean().optional(),spiceEngineMap:external_exports.record(external_exports.string(),spiceEngineZod).optional(),footprintLibraryMap:external_exports.record(external_exports.string(),external_exports.union([pathToCircuitJsonFn,external_exports.record(external_exports.string(),external_exports.union([unvalidatedCircuitJson,pathToCircuitJsonFn]))])).optional(),footprintFileParserMap:external_exports.record(external_exports.string(),footprintFileParserEntry).optional(),resolveProjectStaticFileImportUrl:external_exports.function().args(external_exports.string()).returns(external_exports.promise(external_exports.string())).describe("A function that returns a string URL for static files for the project").optional()});expectTypesMatch2(!0);var platformConfigObject=platformConfig,projectConfig=platformConfigObject.pick({projectName:!0,projectBaseUrl:!0,version:!0,url:!0,printBoardInformationToSilkscreen:!0,includeBoardFiles:!0,snapshotsDir:!0,defaultSpiceEngine:!0});expectTypesMatch2(!0);init_dist();init_zod();init_dist();init_dist();init_dist();init_dist2();init_zod();var import_react2=__toESM(require_react(),1);init_dist2();init_zod();function createMap(){return new IndexedMap}var IndexedMap=class _IndexedMap{constructor(){__publicField(this,"index",{});__publicField(this,"array",[])}size(){return this.array.length}empty(){return this.array.length===0}itemAt(index){return this.array[index]}contains(key){return this.index[key.id()]!==void 0}find(key){let i3=this.index[key.id()];return i3===void 0?void 0:this.array[i3]}setDefault(key,factory){let i3=this.index[key.id()];if(i3===void 0){let pair=new Pair(key,factory());return this.index[key.id()]=this.array.length,this.array.push(pair),pair}else return this.array[i3]}insert(key,value){let pair=new Pair(key,value),i3=this.index[key.id()];return i3===void 0?(this.index[key.id()]=this.array.length,this.array.push(pair)):this.array[i3]=pair,pair}erase(key){let i3=this.index[key.id()];if(i3===void 0)return;this.index[key.id()]=void 0;let pair=this.array[i3],last=this.array.pop();return pair!==last&&(this.array[i3]=last,this.index[last.first.id()]=i3),pair}copy(){let copy=new _IndexedMap;for(let i3=0;i3<this.array.length;i3++){let pair=this.array[i3].copy();copy.array[i3]=pair,copy.index[pair.first.id()]=i3}return copy}},Pair=class _Pair{constructor(first,second){__publicField(this,"first");__publicField(this,"second");this.first=first,this.second=second}copy(){return new _Pair(this.first,this.second)}};var Variable=class{constructor(name=""){__publicField(this,"_name");__publicField(this,"_value",0);__publicField(this,"_context",null);__publicField(this,"_id",VarId++);this._name=name}id(){return this._id}name(){return this._name}setName(name){this._name=name}context(){return this._context}setContext(context){this._context=context}value(){return this._value}setValue(value){this._value=value}plus(value){return new Expression(this,value)}minus(value){return new Expression(this,typeof value=="number"?-value:[-1,value])}multiply(coefficient){return new Expression([coefficient,this])}divide(coefficient){return new Expression([1/coefficient,this])}toJSON(){return{name:this._name,value:this._value}}toString(){return this._context+"["+this._name+":"+this._value+"]"}},VarId=0;var Expression=class _Expression{constructor(){__publicField(this,"_terms");__publicField(this,"_constant");let parsed=parseArgs(arguments);this._terms=parsed.terms,this._constant=parsed.constant}terms(){return this._terms}constant(){return this._constant}value(){let result=this._constant;for(let i3=0,n3=this._terms.size();i3<n3;i3++){let pair=this._terms.itemAt(i3);result+=pair.first.value()*pair.second}return result}plus(value){return new _Expression(this,value)}minus(value){return new _Expression(this,typeof value=="number"?-value:[-1,value])}multiply(coefficient){return new _Expression([coefficient,this])}divide(coefficient){return new _Expression([1/coefficient,this])}isConstant(){return this._terms.size()==0}toString(){let result=this._terms.array.map(function(pair){return pair.second+"*"+pair.first.toString()}).join(" + ");return!this.isConstant()&&this._constant!==0&&(result+=" + "),result+=this._constant,result}};function parseArgs(args){let constant=0,factory=()=>0,terms=createMap();for(let i3=0,n3=args.length;i3<n3;++i3){let item=args[i3];if(typeof item=="number")constant+=item;else if(item instanceof Variable)terms.setDefault(item,factory).second+=1;else if(item instanceof Expression){constant+=item.constant();let terms2=item.terms();for(let j3=0,k4=terms2.size();j3<k4;j3++){let termPair=terms2.itemAt(j3);terms.setDefault(termPair.first,factory).second+=termPair.second}}else if(item instanceof Array){if(item.length!==2)throw new Error("array must have length 2");let value=item[0],value2=item[1];if(typeof value!="number")throw new Error("array item 0 must be a number");if(value2 instanceof Variable)terms.setDefault(value2,factory).second+=value;else if(value2 instanceof Expression){constant+=value2.constant()*value;let terms2=value2.terms();for(let j3=0,k4=terms2.size();j3<k4;j3++){let termPair=terms2.itemAt(j3);terms.setDefault(termPair.first,factory).second+=termPair.second*value}}else throw new Error("array item 1 must be a variable or expression")}else throw new Error("invalid Expression argument: "+item)}return{terms,constant}}var _Strength=class _Strength{static create(a2,b3,c3,w4=1){let result=0;return result+=Math.max(0,Math.min(1e3,a2*w4))*1e6,result+=Math.max(0,Math.min(1e3,b3*w4))*1e3,result+=Math.max(0,Math.min(1e3,c3*w4)),result}static clip(value){return Math.max(0,Math.min(_Strength.required,value))}};__publicField(_Strength,"required",_Strength.create(1e3,1e3,1e3)),__publicField(_Strength,"strong",_Strength.create(1,0,0)),__publicField(_Strength,"medium",_Strength.create(0,1,0)),__publicField(_Strength,"weak",_Strength.create(0,0,1));var Strength=_Strength;var Operator;(function(Operator2){Operator2[Operator2.Le=0]="Le",Operator2[Operator2.Ge=1]="Ge",Operator2[Operator2.Eq=2]="Eq"})(Operator||(Operator={}));var Constraint=class{constructor(expression,operator,rhs,strength=Strength.required){__publicField(this,"_expression");__publicField(this,"_operator");__publicField(this,"_strength");__publicField(this,"_id",CnId++);this._operator=operator,this._strength=Strength.clip(strength),rhs===void 0&&expression instanceof Expression?this._expression=expression:this._expression=expression.minus(rhs)}id(){return this._id}expression(){return this._expression}op(){return this._operator}strength(){return this._strength}toString(){return this._expression.toString()+" "+["<=",">=","="][this._operator]+" 0 ("+this._strength.toString()+")"}},CnId=0;var Solver=class{constructor(){__publicField(this,"maxIterations",1e3);__publicField(this,"_cnMap",createCnMap());__publicField(this,"_rowMap",createRowMap());__publicField(this,"_varMap",createVarMap());__publicField(this,"_editMap",createEditMap());__publicField(this,"_infeasibleRows",[]);__publicField(this,"_objective",new Row);__publicField(this,"_artificial",null);__publicField(this,"_idTick",0)}createConstraint(lhs,operator,rhs,strength=Strength.required){let cn3=new Constraint(lhs,operator,rhs,strength);return this.addConstraint(cn3),cn3}addConstraint(constraint){if(this._cnMap.find(constraint)!==void 0)throw new Error("duplicate constraint");let data=this._createRow(constraint),row=data.row,tag=data.tag,subject=this._chooseSubject(row,tag);if(subject.type()===SymbolType.Invalid&&row.allDummies())if(nearZero(row.constant()))subject=tag.marker;else throw new Error("unsatisfiable constraint");if(subject.type()===SymbolType.Invalid){if(!this._addWithArtificialVariable(row))throw new Error("unsatisfiable constraint")}else row.solveFor(subject),this._substitute(subject,row),this._rowMap.insert(subject,row);this._cnMap.insert(constraint,tag),this._optimize(this._objective)}removeConstraint(constraint){let cnPair=this._cnMap.erase(constraint);if(cnPair===void 0)throw new Error("unknown constraint");this._removeConstraintEffects(constraint,cnPair.second);let marker=cnPair.second.marker,rowPair=this._rowMap.erase(marker);if(rowPair===void 0){let leaving=this._getMarkerLeavingSymbol(marker);if(leaving.type()===SymbolType.Invalid)throw new Error("failed to find leaving row");rowPair=this._rowMap.erase(leaving),rowPair.second.solveForEx(leaving,marker),this._substitute(marker,rowPair.second)}this._optimize(this._objective)}hasConstraint(constraint){return this._cnMap.contains(constraint)}getConstraints(){return this._cnMap.array.map(({first})=>first)}addEditVariable(variable,strength){if(this._editMap.find(variable)!==void 0)throw new Error("duplicate edit variable");if(strength=Strength.clip(strength),strength===Strength.required)throw new Error("bad required strength");let expr=new Expression(variable),cn3=new Constraint(expr,Operator.Eq,void 0,strength);this.addConstraint(cn3);let info={tag:this._cnMap.find(cn3).second,constraint:cn3,constant:0};this._editMap.insert(variable,info)}removeEditVariable(variable){let editPair=this._editMap.erase(variable);if(editPair===void 0)throw new Error("unknown edit variable");this.removeConstraint(editPair.second.constraint)}hasEditVariable(variable){return this._editMap.contains(variable)}suggestValue(variable,value){let editPair=this._editMap.find(variable);if(editPair===void 0)throw new Error("unknown edit variable");let rows=this._rowMap,info=editPair.second,delta=value-info.constant;info.constant=value;let marker=info.tag.marker,rowPair=rows.find(marker);if(rowPair!==void 0){rowPair.second.add(-delta)<0&&this._infeasibleRows.push(marker),this._dualOptimize();return}let other=info.tag.other;if(rowPair=rows.find(other),rowPair!==void 0){rowPair.second.add(delta)<0&&this._infeasibleRows.push(other),this._dualOptimize();return}for(let i3=0,n3=rows.size();i3<n3;++i3){let rowPair2=rows.itemAt(i3),row=rowPair2.second,coeff=row.coefficientFor(marker);coeff!==0&&row.add(delta*coeff)<0&&rowPair2.first.type()!==SymbolType.External&&this._infeasibleRows.push(rowPair2.first)}this._dualOptimize()}updateVariables(){let vars=this._varMap,rows=this._rowMap;for(let i3=0,n3=vars.size();i3<n3;++i3){let pair=vars.itemAt(i3),rowPair=rows.find(pair.second);rowPair!==void 0?pair.first.setValue(rowPair.second.constant()):pair.first.setValue(0)}}_getVarSymbol(variable){let factory=()=>this._makeSymbol(SymbolType.External);return this._varMap.setDefault(variable,factory).second}_createRow(constraint){let expr=constraint.expression(),row=new Row(expr.constant()),terms=expr.terms();for(let i3=0,n3=terms.size();i3<n3;++i3){let termPair=terms.itemAt(i3);if(!nearZero(termPair.second)){let symbol=this._getVarSymbol(termPair.first),basicPair=this._rowMap.find(symbol);basicPair!==void 0?row.insertRow(basicPair.second,termPair.second):row.insertSymbol(symbol,termPair.second)}}let objective=this._objective,strength=constraint.strength(),tag={marker:INVALID_SYMBOL,other:INVALID_SYMBOL};switch(constraint.op()){case Operator.Le:case Operator.Ge:{let coeff=constraint.op()===Operator.Le?1:-1,slack=this._makeSymbol(SymbolType.Slack);if(tag.marker=slack,row.insertSymbol(slack,coeff),strength<Strength.required){let error=this._makeSymbol(SymbolType.Error);tag.other=error,row.insertSymbol(error,-coeff),objective.insertSymbol(error,strength)}break}case Operator.Eq:{if(strength<Strength.required){let errplus=this._makeSymbol(SymbolType.Error),errminus=this._makeSymbol(SymbolType.Error);tag.marker=errplus,tag.other=errminus,row.insertSymbol(errplus,-1),row.insertSymbol(errminus,1),objective.insertSymbol(errplus,strength),objective.insertSymbol(errminus,strength)}else{let dummy=this._makeSymbol(SymbolType.Dummy);tag.marker=dummy,row.insertSymbol(dummy)}break}}return row.constant()<0&&row.reverseSign(),{row,tag}}_chooseSubject(row,tag){let cells=row.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3);if(pair.first.type()===SymbolType.External)return pair.first}let type=tag.marker.type();return(type===SymbolType.Slack||type===SymbolType.Error)&&row.coefficientFor(tag.marker)<0?tag.marker:(type=tag.other.type(),(type===SymbolType.Slack||type===SymbolType.Error)&&row.coefficientFor(tag.other)<0?tag.other:INVALID_SYMBOL)}_addWithArtificialVariable(row){let art=this._makeSymbol(SymbolType.Slack);this._rowMap.insert(art,row.copy()),this._artificial=row.copy(),this._optimize(this._artificial);let success=nearZero(this._artificial.constant());this._artificial=null;let pair=this._rowMap.erase(art);if(pair!==void 0){let basicRow=pair.second;if(basicRow.isConstant())return success;let entering=this._anyPivotableSymbol(basicRow);if(entering.type()===SymbolType.Invalid)return!1;basicRow.solveForEx(art,entering),this._substitute(entering,basicRow),this._rowMap.insert(entering,basicRow)}let rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3)rows.itemAt(i3).second.removeSymbol(art);return this._objective.removeSymbol(art),success}_substitute(symbol,row){let rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3){let pair=rows.itemAt(i3);pair.second.substitute(symbol,row),pair.second.constant()<0&&pair.first.type()!==SymbolType.External&&this._infeasibleRows.push(pair.first)}this._objective.substitute(symbol,row),this._artificial&&this._artificial.substitute(symbol,row)}_optimize(objective){let iterations=0;for(;iterations<this.maxIterations;){let entering=this._getEnteringSymbol(objective);if(entering.type()===SymbolType.Invalid)return;let leaving=this._getLeavingSymbol(entering);if(leaving.type()===SymbolType.Invalid)throw new Error("the objective is unbounded");let row=this._rowMap.erase(leaving).second;row.solveForEx(leaving,entering),this._substitute(entering,row),this._rowMap.insert(entering,row),iterations++}throw new Error("solver iterations exceeded")}_dualOptimize(){let rows=this._rowMap,infeasible=this._infeasibleRows;for(;infeasible.length!==0;){let leaving=infeasible.pop(),pair=rows.find(leaving);if(pair!==void 0&&pair.second.constant()<0){let entering=this._getDualEnteringSymbol(pair.second);if(entering.type()===SymbolType.Invalid)throw new Error("dual optimize failed");let row=pair.second;rows.erase(leaving),row.solveForEx(leaving,entering),this._substitute(entering,row),rows.insert(entering,row)}}}_getEnteringSymbol(objective){let cells=objective.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3),symbol=pair.first;if(pair.second<0&&symbol.type()!==SymbolType.Dummy)return symbol}return INVALID_SYMBOL}_getDualEnteringSymbol(row){let ratio=Number.MAX_VALUE,entering=INVALID_SYMBOL,cells=row.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3),symbol=pair.first,c3=pair.second;if(c3>0&&symbol.type()!==SymbolType.Dummy){let r4=this._objective.coefficientFor(symbol)/c3;r4<ratio&&(ratio=r4,entering=symbol)}}return entering}_getLeavingSymbol(entering){let ratio=Number.MAX_VALUE,found=INVALID_SYMBOL,rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3){let pair=rows.itemAt(i3),symbol=pair.first;if(symbol.type()!==SymbolType.External){let row=pair.second,temp=row.coefficientFor(entering);if(temp<0){let temp_ratio=-row.constant()/temp;temp_ratio<ratio&&(ratio=temp_ratio,found=symbol)}}}return found}_getMarkerLeavingSymbol(marker){let dmax=Number.MAX_VALUE,r12=dmax,r22=dmax,invalid=INVALID_SYMBOL,first=invalid,second=invalid,third=invalid,rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3){let pair=rows.itemAt(i3),row=pair.second,c3=row.coefficientFor(marker);if(c3===0)continue;let symbol=pair.first;if(symbol.type()===SymbolType.External)third=symbol;else if(c3<0){let r4=-row.constant()/c3;r4<r12&&(r12=r4,first=symbol)}else{let r4=row.constant()/c3;r4<r22&&(r22=r4,second=symbol)}}return first!==invalid?first:second!==invalid?second:third}_removeConstraintEffects(cn3,tag){tag.marker.type()===SymbolType.Error&&this._removeMarkerEffects(tag.marker,cn3.strength()),tag.other.type()===SymbolType.Error&&this._removeMarkerEffects(tag.other,cn3.strength())}_removeMarkerEffects(marker,strength){let pair=this._rowMap.find(marker);pair!==void 0?this._objective.insertRow(pair.second,-strength):this._objective.insertSymbol(marker,-strength)}_anyPivotableSymbol(row){let cells=row.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3),type=pair.first.type();if(type===SymbolType.Slack||type===SymbolType.Error)return pair.first}return INVALID_SYMBOL}_makeSymbol(type){return new Symbol2(type,this._idTick++)}};function nearZero(value){let eps=1e-8;return value<0?-value<eps:value<eps}function createCnMap(){return createMap()}function createRowMap(){return createMap()}function createVarMap(){return createMap()}function createEditMap(){return createMap()}var SymbolType;(function(SymbolType2){SymbolType2[SymbolType2.Invalid=0]="Invalid",SymbolType2[SymbolType2.External=1]="External",SymbolType2[SymbolType2.Slack=2]="Slack",SymbolType2[SymbolType2.Error=3]="Error",SymbolType2[SymbolType2.Dummy=4]="Dummy"})(SymbolType||(SymbolType={}));var Symbol2=class{constructor(type,id2){__publicField(this,"_id");__publicField(this,"_type");this._id=id2,this._type=type}id(){return this._id}type(){return this._type}},INVALID_SYMBOL=new Symbol2(SymbolType.Invalid,-1),Row=class _Row{constructor(constant=0){__publicField(this,"_cellMap",createMap());__publicField(this,"_constant");this._constant=constant}cells(){return this._cellMap}constant(){return this._constant}isConstant(){return this._cellMap.empty()}allDummies(){let cells=this._cellMap;for(let i3=0,n3=cells.size();i3<n3;++i3)if(cells.itemAt(i3).first.type()!==SymbolType.Dummy)return!1;return!0}copy(){let theCopy=new _Row(this._constant);return theCopy._cellMap=this._cellMap.copy(),theCopy}add(value){return this._constant+=value}insertSymbol(symbol,coefficient=1){let pair=this._cellMap.setDefault(symbol,()=>0);nearZero(pair.second+=coefficient)&&this._cellMap.erase(symbol)}insertRow(other,coefficient=1){this._constant+=other._constant*coefficient;let cells=other._cellMap;for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3);this.insertSymbol(pair.first,pair.second*coefficient)}}removeSymbol(symbol){this._cellMap.erase(symbol)}reverseSign(){this._constant=-this._constant;let cells=this._cellMap;for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3);pair.second=-pair.second}}solveFor(symbol){let cells=this._cellMap,coeff=-1/cells.erase(symbol).second;this._constant*=coeff;for(let i3=0,n3=cells.size();i3<n3;++i3)cells.itemAt(i3).second*=coeff}solveForEx(lhs,rhs){this.insertSymbol(lhs,-1),this.solveFor(rhs)}coefficientFor(symbol){let pair=this._cellMap.find(symbol);return pair!==void 0?pair.second:0}substitute(symbol,row){let pair=this._cellMap.erase(symbol);pair!==void 0&&this.insertRow(row,pair.second)}};var import_debug8=__toESM(require_browser(),1);init_zod();init_dist();init_dist();init_dist4();var dist_exports2={};__export(dist_exports2,{areBoundsCompletelyInsidePolygon:()=>areBoundsCompletelyInsidePolygon,areBoundsOverlappingPolygon:()=>areBoundsOverlappingPolygon,boundsAreaOverlap:()=>boundsAreaOverlap,boundsDistance:()=>boundsDistance,boundsIntersection:()=>boundsIntersection,clamp:()=>clamp2,computeDistanceBetweenBoxes:()=>computeDistanceBetweenBoxes2,computeGapBetweenBoxes:()=>computeGapBetweenBoxes,computeManhattanDistanceBetweenBoxes:()=>computeManhattanDistanceBetweenBoxes,distSq:()=>distSq,distance:()=>distance4,doBoundsOverlap:()=>doBoundsOverlap,doSegmentsIntersect:()=>doSegmentsIntersect2,doesLineIntersectLine:()=>doesLineIntersectLine2,doesSegmentIntersectRect:()=>doesSegmentIntersectRect,findNearestPointsBetweenBoxSets:()=>findNearestPointsBetweenBoxSets2,getBoundingBox:()=>getBoundingBox2,getBoundsFromPoints:()=>getBoundsFromPoints,getSegmentIntersection:()=>getSegmentIntersection,getUnitVectorFromDirection:()=>getUnitVectorFromDirection2,getUnitVectorFromPointAToB:()=>getUnitVectorFromPointAToB2,grid:()=>grid2,isPointInsidePolygon:()=>isPointInsidePolygon,isRectCompletelyInsidePolygon:()=>isRectCompletelyInsidePolygon,isRectOverlappingPolygon:()=>isRectOverlappingPolygon,midpoint:()=>midpoint,normalizeDegrees:()=>normalizeDegrees,onSegment:()=>onSegment2,orientation:()=>orientation2,pointToBoundsDistance:()=>pointToBoundsDistance,pointToBoxDistance:()=>pointToBoxDistance,pointToSegmentClosestPoint:()=>pointToSegmentClosestPoint,pointToSegmentDistance:()=>pointToSegmentDistance2,range:()=>range,segmentToBoundsMinDistance:()=>segmentToBoundsMinDistance,segmentToBoxMinDistance:()=>segmentToBoxMinDistance,segmentToCircleMinDistance:()=>segmentToCircleMinDistance,segmentToSegmentMinDistance:()=>segmentToSegmentMinDistance});function doesLineIntersectLine2([a12,a2],[b12,b22],{lineThickness=0}={}){return lineThickness===0?doSegmentsIntersect2(a12,a2,b12,b22):segmentsDistance2(a12,a2,b12,b22)<=lineThickness}function doSegmentsIntersect2(p12,q12,p2,q22){let o12=orientation2(p12,q12,p2),o22=orientation2(p12,q12,q22),o32=orientation2(p2,q22,p12),o4=orientation2(p2,q22,q12);return!!(o12!==o22&&o32!==o4||o12===0&&onSegment2(p12,p2,q12)||o22===0&&onSegment2(p12,q22,q12)||o32===0&&onSegment2(p2,p12,q22)||o4===0&&onSegment2(p2,q12,q22))}function orientation2(p2,q4,r4){let val=(q4.y-p2.y)*(r4.x-q4.x)-(q4.x-p2.x)*(r4.y-q4.y);return val===0?0:val>0?1:2}function onSegment2(p2,q4,r4){return q4.x<=Math.max(p2.x,r4.x)&&q4.x>=Math.min(p2.x,r4.x)&&q4.y<=Math.max(p2.y,r4.y)&&q4.y>=Math.min(p2.y,r4.y)}function segmentsDistance2(a12,a2,b12,b22){if(a12.x===a2.x&&a12.y===a2.y)return pointToSegmentDistance2(a12,b12,b22);if(b12.x===b22.x&&b12.y===b22.y)return pointToSegmentDistance2(b12,a12,a2);if(doSegmentsIntersect2(a12,a2,b12,b22))return 0;let distances=[pointToSegmentDistance2(a12,b12,b22),pointToSegmentDistance2(a2,b12,b22),pointToSegmentDistance2(b12,a12,a2),pointToSegmentDistance2(b22,a12,a2)];return Math.min(...distances)}function pointToSegmentDistance2(p2,v4,w4){let l2=(w4.x-v4.x)**2+(w4.y-v4.y)**2;if(l2===0)return distance4(p2,v4);let t5=((p2.x-v4.x)*(w4.x-v4.x)+(p2.y-v4.y)*(w4.y-v4.y))/l2;t5=Math.max(0,Math.min(1,t5));let projection={x:v4.x+t5*(w4.x-v4.x),y:v4.y+t5*(w4.y-v4.y)};return distance4(p2,projection)}function distance4(p12,p2){let dx2=p12.x-p2.x,dy2=p12.y-p2.y;return Math.sqrt(dx2*dx2+dy2*dy2)}function getSegmentIntersection(a2,b3,u4,v4){let dx1=b3.x-a2.x,dy1=b3.y-a2.y,dx2=v4.x-u4.x,dy2=v4.y-u4.y,dx3=a2.x-u4.x,dy3=a2.y-u4.y,denominator=dx1*dy2-dy1*dx2;if(Math.abs(denominator)<1e-10)return null;let t5=(dy3*dx2-dx3*dy2)/denominator,s3=(dx1*dy3-dy1*dx3)/denominator,epsilon=1e-9;if(t5>=-epsilon&&t5<=1+epsilon&&s3>=-epsilon&&s3<=1+epsilon){let intersectionX=a2.x+t5*dx1,intersectionY=a2.y+t5*dy1;return{x:intersectionX,y:intersectionY}}return null}function doesSegmentIntersectRect(a2,b3,rect){let pointInside=p2=>p2.x>=rect.minX&&p2.x<=rect.maxX&&p2.y>=rect.minY&&p2.y<=rect.maxY;if(pointInside(a2)||pointInside(b3))return!0;let topLeft={x:rect.minX,y:rect.minY},topRight={x:rect.maxX,y:rect.minY},bottomLeft={x:rect.minX,y:rect.maxY},bottomRight={x:rect.maxX,y:rect.maxY};return doSegmentsIntersect2(a2,b3,topLeft,topRight)||doSegmentsIntersect2(a2,b3,topRight,bottomRight)||doSegmentsIntersect2(a2,b3,bottomRight,bottomLeft)||doSegmentsIntersect2(a2,b3,bottomLeft,topLeft)}function segmentToSegmentMinDistance(a2,b3,u4,v4){if(a2.x===b3.x&&a2.y===b3.y)return pointToSegmentDistance2(a2,u4,v4);if(u4.x===v4.x&&u4.y===v4.y)return pointToSegmentDistance2(u4,a2,b3);if(doSegmentsIntersect2(a2,b3,u4,v4))return 0;let distances=[pointToSegmentDistance2(a2,u4,v4),pointToSegmentDistance2(b3,u4,v4),pointToSegmentDistance2(u4,a2,b3),pointToSegmentDistance2(v4,a2,b3)];return Math.min(...distances)}function segmentToBoundsMinDistance(a2,b3,bounds){let topLeft={x:bounds.minX,y:bounds.minY},topRight={x:bounds.maxX,y:bounds.minY},bottomLeft={x:bounds.minX,y:bounds.maxY},bottomRight={x:bounds.maxX,y:bounds.maxY};if(doSegmentsIntersect2(a2,b3,topLeft,topRight)||doSegmentsIntersect2(a2,b3,topRight,bottomRight)||doSegmentsIntersect2(a2,b3,bottomRight,bottomLeft)||doSegmentsIntersect2(a2,b3,bottomLeft,topLeft)||a2.x>=bounds.minX&&a2.x<=bounds.maxX&&a2.y>=bounds.minY&&a2.y<=bounds.maxY&&b3.x>=bounds.minX&&b3.x<=bounds.maxX&&b3.y>=bounds.minY&&b3.y<=bounds.maxY)return 0;let distances=[pointToSegmentDistance2(topLeft,a2,b3),pointToSegmentDistance2(topRight,a2,b3),pointToSegmentDistance2(bottomLeft,a2,b3),pointToSegmentDistance2(bottomRight,a2,b3)];if(a2.x>=bounds.minX&&a2.x<=bounds.maxX&&a2.y>=bounds.minY&&a2.y<=bounds.maxY||b3.x>=bounds.minX&&b3.x<=bounds.maxX&&b3.y>=bounds.minY&&b3.y<=bounds.maxY)return 0;if(a2.x<bounds.minX||a2.x>bounds.maxX||a2.y<bounds.minY||a2.y>bounds.maxY){let closestX=clamp2(a2.x,bounds.minX,bounds.maxX),closestY=clamp2(a2.y,bounds.minY,bounds.maxY);distances.push(distance4(a2,{x:closestX,y:closestY}))}if(b3.x<bounds.minX||b3.x>bounds.maxX||b3.y<bounds.minY||b3.y>bounds.maxY){let closestX=clamp2(b3.x,bounds.minX,bounds.maxX),closestY=clamp2(b3.y,bounds.minY,bounds.maxY);distances.push(distance4(b3,{x:closestX,y:closestY}))}return Math.min(...distances)}function segmentToBoxMinDistance(a2,b3,box2){let halfWidth=box2.width/2,halfHeight=box2.height/2,bounds={minX:box2.center.x-halfWidth,maxX:box2.center.x+halfWidth,minY:box2.center.y-halfHeight,maxY:box2.center.y+halfHeight};return segmentToBoundsMinDistance(a2,b3,bounds)}function segmentToCircleMinDistance(a2,b3,circle2){let circleCenter={x:circle2.x,y:circle2.y};if(a2.x===b3.x&&a2.y===b3.y)return Math.max(0,distance4(a2,circleCenter)-circle2.radius);let ab2={x:b3.x-a2.x,y:b3.y-a2.y},ac2={x:circleCenter.x-a2.x,y:circleCenter.y-a2.y},abLengthSq=ab2.x*ab2.x+ab2.y*ab2.y,t5=Math.max(0,Math.min(1,(ab2.x*ac2.x+ab2.y*ac2.y)/abLengthSq)),closestPoint={x:a2.x+t5*ab2.x,y:a2.y+t5*ab2.y},distToCenter=distance4(closestPoint,circleCenter);return Math.max(0,distToCenter-circle2.radius)}function pointToSegmentClosestPoint(p2,a2,b3){let dx_ab=b3.x-a2.x,dy_ab=b3.y-a2.y,l2=dx_ab*dx_ab+dy_ab*dy_ab;if(l2===0)return{x:a2.x,y:a2.y};let t5=((p2.x-a2.x)*dx_ab+(p2.y-a2.y)*dy_ab)/l2;return t5=Math.max(0,Math.min(1,t5)),{x:a2.x+t5*dx_ab,y:a2.y+t5*dy_ab}}function normalizeDegrees(angle){return(angle%360+360)%360}function pointToBoxDistance(p2,box2){let halfWidth=box2.width/2,halfHeight=box2.height/2,minX=box2.center.x-halfWidth,maxX=box2.center.x+halfWidth,minY=box2.center.y-halfHeight,maxY=box2.center.y+halfHeight;if(p2.x>=minX&&p2.x<=maxX&&p2.y>=minY&&p2.y<=maxY)return 0;let closestX=clamp2(p2.x,minX,maxX),closestY=clamp2(p2.y,minY,maxY);return distance4(p2,{x:closestX,y:closestY})}function pointToBoundsDistance(p2,bounds){if(p2.x>=bounds.minX&&p2.x<=bounds.maxX&&p2.y>=bounds.minY&&p2.y<=bounds.maxY)return 0;let closestX=clamp2(p2.x,bounds.minX,bounds.maxX),closestY=clamp2(p2.y,bounds.minY,bounds.maxY);return distance4(p2,{x:closestX,y:closestY})}function midpoint(p12,p2){return{x:(p12.x+p2.x)/2,y:(p12.y+p2.y)/2}}function distSq(p12,p2){let dx2=p12.x-p2.x,dy2=p12.y-p2.y;return dx2*dx2+dy2*dy2}var universalRectToBounds=rect=>{if("minX"in rect)return rect;let halfWidth=rect.width/2,halfHeight=rect.height/2;return{minX:rect.center.x-halfWidth,minY:rect.center.y-halfHeight,maxX:rect.center.x+halfWidth,maxY:rect.center.y+halfHeight}},getBoundsCorners=bounds=>[{x:bounds.minX,y:bounds.minY},{x:bounds.maxX,y:bounds.minY},{x:bounds.maxX,y:bounds.maxY},{x:bounds.minX,y:bounds.maxY}],getPolygonEdges=polygon2=>{let edges=[];for(let i3=0;i3<polygon2.length;i3++){let start=polygon2[i3],end=polygon2[(i3+1)%polygon2.length];edges.push([start,end])}return edges},isPointOnSegment=(point6,start,end)=>{let cross3=(point6.y-start.y)*(end.x-start.x)-(point6.x-start.x)*(end.y-start.y);if(Math.abs(cross3)>1e-9)return!1;let dot=(point6.x-start.x)*(end.x-start.x)+(point6.y-start.y)*(end.y-start.y);if(dot<0)return!1;let squaredLength=(end.x-start.x)**2+(end.y-start.y)**2;return!(dot>squaredLength)},isPointInsideBounds=(point6,bounds)=>point6.x>=bounds.minX&&point6.x<=bounds.maxX&&point6.y>=bounds.minY&&point6.y<=bounds.maxY,isPointInsidePolygon=(point6,polygon2)=>{if(polygon2.length<3)return!1;let edges=getPolygonEdges(polygon2);for(let[start,end]of edges)if(isPointOnSegment(point6,start,end))return!0;let inside2=!1;for(let i3=0,j3=polygon2.length-1;i3<polygon2.length;j3=i3++){let xi3=polygon2[i3].x,yi3=polygon2[i3].y,xj=polygon2[j3].x,yj=polygon2[j3].y;yi3>point6.y!=yj>point6.y&&point6.x<(xj-xi3)*(point6.y-yi3)/(yj-yi3)+xi3&&(inside2=!inside2)}return inside2},doesPolygonIntersectBounds=(bounds,polygon2)=>{let boundsCorners=getBoundsCorners(bounds),boundsEdges=[[boundsCorners[0],boundsCorners[1]],[boundsCorners[1],boundsCorners[2]],[boundsCorners[2],boundsCorners[3]],[boundsCorners[3],boundsCorners[0]]],polygonEdges=getPolygonEdges(polygon2);for(let[start,end]of polygonEdges)for(let[rectStart,rectEnd]of boundsEdges)if(doSegmentsIntersect2(start,end,rectStart,rectEnd))return!0;return!1},areBoundsOverlappingPolygon=(bounds,polygon2)=>polygon2.length<3?!1:polygon2.some(point6=>isPointInsideBounds(point6,bounds))||getBoundsCorners(bounds).some(corner=>isPointInsidePolygon(corner,polygon2))?!0:doesPolygonIntersectBounds(bounds,polygon2),areBoundsCompletelyInsidePolygon=(bounds,polygon2)=>polygon2.length<3||!getBoundsCorners(bounds).every(corner=>isPointInsidePolygon(corner,polygon2))?!1:!doesPolygonIntersectBounds(bounds,polygon2),isRectOverlappingPolygon=(rect,polygon2)=>areBoundsOverlappingPolygon(universalRectToBounds(rect),polygon2),isRectCompletelyInsidePolygon=(rect,polygon2)=>areBoundsCompletelyInsidePolygon(universalRectToBounds(rect),polygon2);function range(start,end,step=1){if(step===0)throw new Error("step cannot be 0");let _start,_end;end===void 0?(_start=0,_end=start):(_start=start,_end=end);let result=[];if(step>0)for(let i3=_start;i3<_end;i3+=step)result.push(i3);else for(let i3=_start;i3>_end;i3+=step)result.push(i3);return result}var boundsAreaOverlap=(bounds1,bounds2)=>{let overlapX=Math.max(0,Math.min(bounds1.maxX,bounds2.maxX)-Math.max(bounds1.minX,bounds2.minX)),overlapY=Math.max(0,Math.min(bounds1.maxY,bounds2.maxY)-Math.max(bounds1.minY,bounds2.minY));return overlapX*overlapY};var boundsDistance=(bounds1,bounds2)=>{let dx2=bounds1.maxX<bounds2.minX?bounds2.minX-bounds1.maxX:bounds2.maxX<bounds1.minX?bounds1.minX-bounds2.maxX:0,dy2=bounds1.maxY<bounds2.minY?bounds2.minY-bounds1.maxY:bounds2.maxY<bounds1.minY?bounds1.minY-bounds2.maxY:0;return Math.sqrt(dx2*dx2+dy2*dy2)};var boundsIntersection=(bounds1,bounds2)=>{let minX=Math.max(bounds1.minX,bounds2.minX),minY=Math.max(bounds1.minY,bounds2.minY),maxX=Math.min(bounds1.maxX,bounds2.maxX),maxY=Math.min(bounds1.maxY,bounds2.maxY);return minX>maxX||minY>maxY?null:{minX,minY,maxX,maxY}};var doBoundsOverlap=(bounds1,bounds2)=>!(bounds1.maxX<bounds2.minX||bounds2.maxX<bounds1.minX||bounds1.maxY<bounds2.minY||bounds2.maxY<bounds1.minY);var getBoundsFromPoints=points=>{if(points.length===0)return null;let minX=points[0].x,minY=points[0].y,maxX=points[0].x,maxY=points[0].y;for(let i3=1;i3<points.length;i3++){let point6=points[i3];point6.x<minX&&(minX=point6.x),point6.y<minY&&(minY=point6.y),point6.x>maxX&&(maxX=point6.x),point6.y>maxY&&(maxY=point6.y)}return{minX,minY,maxX,maxY}};var getUnitVectorFromPointAToB2=(a2,b3)=>{let delta={x:b3.x-a2.x,y:b3.y-a2.y},magnitude=Math.sqrt(delta.x**2+delta.y**2);return{x:delta.x/magnitude,y:delta.y/magnitude}},getUnitVectorFromDirection2=direction2=>{switch(direction2){case"up":return{x:0,y:1};case"down":return{x:0,y:-1};case"left":return{x:-1,y:0};case"right":return{x:1,y:0}}};function grid2({rows,cols,xSpacing,ySpacing,width,height,offsetX=0,offsetY=0,yDirection="cartesian",centered=!0}){let effectiveXSpacing=xSpacing??1,effectiveYSpacing=ySpacing??1,totalWidth=width??cols*effectiveXSpacing,totalHeight=height??rows*effectiveYSpacing,centeringOffsetX=centered?-totalWidth/2:0,centeringOffsetY=centered?-totalHeight/2:0,cellWidth=width?width/cols:effectiveXSpacing,cellHeight=height?height/rows:effectiveYSpacing,cells=[];for(let row=0;row<rows;row++)for(let col=0;col<cols;col++){let index=row*cols+col,centerX=offsetX+centeringOffsetX+col*cellWidth+cellWidth/2,rawCenterY=offsetY+row*cellHeight+cellHeight/2,centerY=yDirection==="cartesian"?offsetY+centeringOffsetY+(rows-1-row)*cellHeight+cellHeight/2:offsetY+centeringOffsetY+row*cellHeight+cellHeight/2;cells.push({index,center:{x:centerX,y:centerY},topLeft:{x:centerX-cellWidth/2,y:centerY+cellHeight/2},bottomRight:{x:centerX+cellWidth/2,y:centerY-cellHeight/2},row,col})}return cells}init_dist();init_dist5();var package_default={name:"@tscircuit/capacity-autorouter",main:"./dist/index.js",version:"0.0.258",type:"module",files:["dist"],scripts:{start:"cosmos",build:"tsup ./lib/index.ts --minify terser --external @tscircuit/core --external circuit-to-svg --format esm --dts --sourcemap",bench:"bun test tests/spatial-index-bench.test.ts",format:"biome format --write .","format:check":"biome format .","vercel-build":"cosmos-export","repomix:lib":"repomix --ignore 'testing/**,**/TwoRouteHighDensitySolver/**,**/RouteStitchingSolver/**,solvers/CapacitySegmentPointOptimizer/CapacitySegmentPointOptimizer.ts' lib","bug-report":"bun run scripts/download-bug-report.ts","bug-report-with-test":"bun run scripts/create-bug-report-test.ts"},devDependencies:{"@biomejs/biome":"^1.9.4","@radix-ui/react-icons":"^1.3.2","@radix-ui/react-menubar":"^1.1.14","@react-hook/resize-observer":"^2.0.2","@resvg/resvg-js":"^2.6.2","@tscircuit/checks":"^0.0.75","@tscircuit/circuit-json-util":"^0.0.46","@tscircuit/core":"^0.0.337","@tscircuit/curvy-trace-solver":"^0.0.10","@tscircuit/hypergraph":"^0.0.15","@tscircuit/math-utils":"^0.0.27","@tscircuit/rectdiff":"0.0.22","@tscircuit/solver-utils":"^0.0.9","@types/bun":"^1.2.23","@types/fast-json-stable-stringify":"^2.1.2","@types/object-hash":"^3.0.6","@types/rbush":"^4.0.0","@types/react":"^19.0.8","@types/react-dom":"^19.0.3","@vercel/node":"^5.1.7","@vitejs/plugin-react":"^4.3.4","circuit-json-to-connectivity-map":"^0.0.19","circuit-to-svg":"^0.0.220",clsx:"^2.1.1",flatbush:"^4.4.0","graphics-debug":"^0.0.77",kleur:"^4.1.5","looks-same":"9",rbush:"^4.0.1",react:"18","react-cosmos":"^6.2.3","react-cosmos-plugin-vite":"^6.2.0","react-dom":"18","react-konva":"18",recharts:"^2.15.1","tailwind-merge":"^3.2.0",terser:"^5.43.1",tsup:"^8.3.6",typescript:"^5.9.3","use-mouse-matrix-transform":"^1.3.0",vite:"^6.0.11","vite-tsconfig-paths":"^5.1.4"},dependencies:{"bun-match-svg":"^0.0.14","fast-json-stable-stringify":"^2.1.0","object-hash":"^3.0.0"}};init_dist();init_dist4();init_dist6();var import_react3=__toESM(require_react(),1);init_dist();var import_debug9=__toESM(require_browser(),1);var import_object_hash=__toESM(require_object_hash(),1),import_object_hash2=__toESM(require_object_hash(),1),import_object_hash3=__toESM(require_object_hash(),1);var t=Object.create,e3=Object.defineProperty,n=Object.getOwnPropertyDescriptor,s2=Object.getOwnPropertyNames,o=Object.getPrototypeOf,i=Object.prototype.hasOwnProperty,r3=(t5,e4)=>function(){return e4||(0,t5[s2(t5)[0]])((e4={exports:{}}).exports,e4),e4.exports},a=(r4,a2,c3)=>(c3=r4!=null?t(o(r4)):{},((t5,o4,r6,a3)=>{if(o4&&typeof o4=="object"||typeof o4=="function")for(let c4 of s2(o4))i.call(t5,c4)||c4===r6||e3(t5,c4,{get:()=>o4[c4],enumerable:!(a3=n(o4,c4))||a3.enumerable});return t5})(!a2&&r4&&r4.__esModule?c3:e3(c3,"default",{value:r4,enumerable:!0}),r4)),c=r3({"node_modules/is-buffer/index.js"(t5,e4){function n3(t7){return!!t7.constructor&&typeof t7.constructor.isBuffer=="function"&&t7.constructor.isBuffer(t7)}e4.exports=function(t7){return t7!=null&&(n3(t7)||(function(t8){return typeof t8.readFloatLE=="function"&&typeof t8.slice=="function"&&n3(t8.slice(0,0))})(t7)||!!t7._isBuffer)}}}),h=r3({"node_modules/kind-of/index.js"(t5,e4){var n3=c(),s3=Object.prototype.toString;e4.exports=function(t7){if(t7===void 0)return"undefined";if(t7===null)return"null";if(t7===!0||t7===!1||t7 instanceof Boolean)return"boolean";if(typeof t7=="string"||t7 instanceof String)return"string";if(typeof t7=="number"||t7 instanceof Number)return"number";if(typeof t7=="function"||t7 instanceof Function)return"function";if(Array.isArray!==void 0&&Array.isArray(t7))return"array";if(t7 instanceof RegExp)return"regexp";if(t7 instanceof Date)return"date";var e5=s3.call(t7);return e5==="[object RegExp]"?"regexp":e5==="[object Date]"?"date":e5==="[object Arguments]"?"arguments":e5==="[object Error]"?"error":n3(t7)?"buffer":e5==="[object Set]"?"set":e5==="[object WeakSet]"?"weakset":e5==="[object Map]"?"map":e5==="[object WeakMap]"?"weakmap":e5==="[object Symbol]"?"symbol":e5==="[object Int8Array]"?"int8array":e5==="[object Uint8Array]"?"uint8array":e5==="[object Uint8ClampedArray]"?"uint8clampedarray":e5==="[object Int16Array]"?"int16array":e5==="[object Uint16Array]"?"uint16array":e5==="[object Int32Array]"?"int32array":e5==="[object Uint32Array]"?"uint32array":e5==="[object Float32Array]"?"float32array":e5==="[object Float64Array]"?"float64array":"object"}}}),d=r3({"node_modules/rename-keys/index.js"(t5,e4){(function(){function t7(t8,e5){if(typeof e5!="function")return t8;var n3={};for(var s3 in t8)Object.prototype.hasOwnProperty.call(t8,s3)&&(n3[e5(s3,t8[s3])||s3]=t8[s3]);return n3}e4!==void 0&&e4.exports?e4.exports=t7:typeof define=="function"&&define.amd?define([],function(){return t7}):window.rename=t7})()}}),l=r3({"node_modules/deep-rename-keys/index.js"(t5,e4){var n3=h(),s3=d();e4.exports=function t7(e5,o4){var i3=n3(e5);if(i3!=="object"&&i3!=="array")throw new Error("expected an object");var r4=[];for(var a2 in i3==="object"&&(e5=s3(e5,o4),r4={}),e5)if(e5.hasOwnProperty(a2)){var c3=e5[a2];n3(c3)==="object"||n3(c3)==="array"?r4[a2]=t7(c3,o4):r4[a2]=c3}return r4}}}),u3=r3({"node_modules/xml-reader/node_modules/eventemitter3/index.js"(t5,e4){var n3=Object.prototype.hasOwnProperty,s3="~";function o4(){}function i3(t7,e5,n4){this.fn=t7,this.context=e5,this.once=n4||!1}function r4(){this._events=new o4,this._eventsCount=0}Object.create&&(o4.prototype=Object.create(null),new o4().__proto__||(s3=!1)),r4.prototype.eventNames=function(){var t7,e5,o5=[];if(this._eventsCount===0)return o5;for(e5 in t7=this._events)n3.call(t7,e5)&&o5.push(s3?e5.slice(1):e5);return Object.getOwnPropertySymbols?o5.concat(Object.getOwnPropertySymbols(t7)):o5},r4.prototype.listeners=function(t7,e5){var n4=s3?s3+t7:t7,o5=this._events[n4];if(e5)return!!o5;if(!o5)return[];if(o5.fn)return[o5.fn];for(var i4=0,r6=o5.length,a2=new Array(r6);i4<r6;i4++)a2[i4]=o5[i4].fn;return a2},r4.prototype.emit=function(t7,e5,n4,o5,i4,r6){var a2=s3?s3+t7:t7;if(!this._events[a2])return!1;var c3,h2,d3=this._events[a2],l2=arguments.length;if(d3.fn){switch(d3.once&&this.removeListener(t7,d3.fn,void 0,!0),l2){case 1:return d3.fn.call(d3.context),!0;case 2:return d3.fn.call(d3.context,e5),!0;case 3:return d3.fn.call(d3.context,e5,n4),!0;case 4:return d3.fn.call(d3.context,e5,n4,o5),!0;case 5:return d3.fn.call(d3.context,e5,n4,o5,i4),!0;case 6:return d3.fn.call(d3.context,e5,n4,o5,i4,r6),!0}for(h2=1,c3=new Array(l2-1);h2<l2;h2++)c3[h2-1]=arguments[h2];d3.fn.apply(d3.context,c3)}else{var u4,p2=d3.length;for(h2=0;h2<p2;h2++)switch(d3[h2].once&&this.removeListener(t7,d3[h2].fn,void 0,!0),l2){case 1:d3[h2].fn.call(d3[h2].context);break;case 2:d3[h2].fn.call(d3[h2].context,e5);break;case 3:d3[h2].fn.call(d3[h2].context,e5,n4);break;case 4:d3[h2].fn.call(d3[h2].context,e5,n4,o5);break;default:if(!c3)for(u4=1,c3=new Array(l2-1);u4<l2;u4++)c3[u4-1]=arguments[u4];d3[h2].fn.apply(d3[h2].context,c3)}}return!0},r4.prototype.on=function(t7,e5,n4){var o5=new i3(e5,n4||this),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.once=function(t7,e5,n4){var o5=new i3(e5,n4||this,!0),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.removeListener=function(t7,e5,n4,i4){var r6=s3?s3+t7:t7;if(!this._events[r6])return this;if(!e5)return--this._eventsCount===0?this._events=new o4:delete this._events[r6],this;var a2=this._events[r6];if(a2.fn)a2.fn!==e5||i4&&!a2.once||n4&&a2.context!==n4||(--this._eventsCount===0?this._events=new o4:delete this._events[r6]);else{for(var c3=0,h2=[],d3=a2.length;c3<d3;c3++)(a2[c3].fn!==e5||i4&&!a2[c3].once||n4&&a2[c3].context!==n4)&&h2.push(a2[c3]);h2.length?this._events[r6]=h2.length===1?h2[0]:h2:--this._eventsCount===0?this._events=new o4:delete this._events[r6]}return this},r4.prototype.removeAllListeners=function(t7){var e5;return t7?(e5=s3?s3+t7:t7,this._events[e5]&&(--this._eventsCount===0?this._events=new o4:delete this._events[e5])):(this._events=new o4,this._eventsCount=0),this},r4.prototype.off=r4.prototype.removeListener,r4.prototype.addListener=r4.prototype.on,r4.prototype.setMaxListeners=function(){return this},r4.prefixed=s3,r4.EventEmitter=r4,e4!==void 0&&(e4.exports=r4)}}),p=r3({"node_modules/xml-lexer/node_modules/eventemitter3/index.js"(t5,e4){var n3=Object.prototype.hasOwnProperty,s3="~";function o4(){}function i3(t7,e5,n4){this.fn=t7,this.context=e5,this.once=n4||!1}function r4(){this._events=new o4,this._eventsCount=0}Object.create&&(o4.prototype=Object.create(null),new o4().__proto__||(s3=!1)),r4.prototype.eventNames=function(){var t7,e5,o5=[];if(this._eventsCount===0)return o5;for(e5 in t7=this._events)n3.call(t7,e5)&&o5.push(s3?e5.slice(1):e5);return Object.getOwnPropertySymbols?o5.concat(Object.getOwnPropertySymbols(t7)):o5},r4.prototype.listeners=function(t7,e5){var n4=s3?s3+t7:t7,o5=this._events[n4];if(e5)return!!o5;if(!o5)return[];if(o5.fn)return[o5.fn];for(var i4=0,r6=o5.length,a2=new Array(r6);i4<r6;i4++)a2[i4]=o5[i4].fn;return a2},r4.prototype.emit=function(t7,e5,n4,o5,i4,r6){var a2=s3?s3+t7:t7;if(!this._events[a2])return!1;var c3,h2,d3=this._events[a2],l2=arguments.length;if(d3.fn){switch(d3.once&&this.removeListener(t7,d3.fn,void 0,!0),l2){case 1:return d3.fn.call(d3.context),!0;case 2:return d3.fn.call(d3.context,e5),!0;case 3:return d3.fn.call(d3.context,e5,n4),!0;case 4:return d3.fn.call(d3.context,e5,n4,o5),!0;case 5:return d3.fn.call(d3.context,e5,n4,o5,i4),!0;case 6:return d3.fn.call(d3.context,e5,n4,o5,i4,r6),!0}for(h2=1,c3=new Array(l2-1);h2<l2;h2++)c3[h2-1]=arguments[h2];d3.fn.apply(d3.context,c3)}else{var u4,p2=d3.length;for(h2=0;h2<p2;h2++)switch(d3[h2].once&&this.removeListener(t7,d3[h2].fn,void 0,!0),l2){case 1:d3[h2].fn.call(d3[h2].context);break;case 2:d3[h2].fn.call(d3[h2].context,e5);break;case 3:d3[h2].fn.call(d3[h2].context,e5,n4);break;case 4:d3[h2].fn.call(d3[h2].context,e5,n4,o5);break;default:if(!c3)for(u4=1,c3=new Array(l2-1);u4<l2;u4++)c3[u4-1]=arguments[u4];d3[h2].fn.apply(d3[h2].context,c3)}}return!0},r4.prototype.on=function(t7,e5,n4){var o5=new i3(e5,n4||this),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.once=function(t7,e5,n4){var o5=new i3(e5,n4||this,!0),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.removeListener=function(t7,e5,n4,i4){var r6=s3?s3+t7:t7;if(!this._events[r6])return this;if(!e5)return--this._eventsCount===0?this._events=new o4:delete this._events[r6],this;var a2=this._events[r6];if(a2.fn)a2.fn!==e5||i4&&!a2.once||n4&&a2.context!==n4||(--this._eventsCount===0?this._events=new o4:delete this._events[r6]);else{for(var c3=0,h2=[],d3=a2.length;c3<d3;c3++)(a2[c3].fn!==e5||i4&&!a2[c3].once||n4&&a2[c3].context!==n4)&&h2.push(a2[c3]);h2.length?this._events[r6]=h2.length===1?h2[0]:h2:--this._eventsCount===0?this._events=new o4:delete this._events[r6]}return this},r4.prototype.removeAllListeners=function(t7){var e5;return t7?(e5=s3?s3+t7:t7,this._events[e5]&&(--this._eventsCount===0?this._events=new o4:delete this._events[e5])):(this._events=new o4,this._eventsCount=0),this},r4.prototype.off=r4.prototype.removeListener,r4.prototype.addListener=r4.prototype.on,r4.prototype.setMaxListeners=function(){return this},r4.prefixed=s3,r4.EventEmitter=r4,e4!==void 0&&(e4.exports=r4)}}),m=r3({"node_modules/xml-lexer/dist/lexer.js"(t5,e4){function n3(t7,e5,n4){return e5 in t7?Object.defineProperty(t7,e5,{value:n4,enumerable:!0,configurable:!0,writable:!0}):t7[e5]=n4,t7}var s3=p(),o4=function(){},i3={data:"state-data",cdata:"state-cdata",tagBegin:"state-tag-begin",tagName:"state-tag-name",tagEnd:"state-tag-end",attributeNameStart:"state-attribute-name-start",attributeName:"state-attribute-name",attributeNameEnd:"state-attribute-name-end",attributeValueBegin:"state-attribute-value-begin",attributeValue:"state-attribute-value"},r4={lt:"action-lt",gt:"action-gt",space:"action-space",equal:"action-equal",quote:"action-quote",slash:"action-slash",char:"action-char",error:"action-error"},a2={text:"text",openTag:"open-tag",closeTag:"close-tag",attributeName:"attribute-name",attributeValue:"attribute-value"},c3={" ":r4.space," ":r4.space,"\n":r4.space,"\r":r4.space,"<":r4.lt,">":r4.gt,'"':r4.quote,"'":r4.quote,"=":r4.equal,"/":r4.slash};e4.exports={State:i3,Action:r4,Type:a2,create:function(t7){var e5,h2,d3,l2,u4,p2,m3,f2,g4,y3;t7=Object.assign({debug:!1},t7);var x3=new s3,v4=i3.data,S4="",P4="",b3="",M5="",N4="",I4="",C3=function(e6,n4){if(P4[0]!=="?"&&P4[0]!=="!"){var s4={type:e6,value:n4};t7.debug&&console.log("emit:",s4),x3.emit("data",s4)}};x3.stateMachine=(n3(y3={},i3.data,(n3(e5={},r4.lt,function(){S4.trim()&&C3(a2.text,S4),P4="",N4=!1,v4=i3.tagBegin}),n3(e5,r4.char,function(t8){S4+=t8}),e5)),n3(y3,i3.cdata,n3({},r4.char,function(t8){(S4+=t8).substr(-3)==="]]>"&&(C3(a2.text,S4.slice(0,-3)),S4="",v4=i3.data)})),n3(y3,i3.tagBegin,(n3(h2={},r4.space,o4),n3(h2,r4.char,function(t8){P4=t8,v4=i3.tagName}),n3(h2,r4.slash,function(){P4="",N4=!0}),h2)),n3(y3,i3.tagName,(n3(d3={},r4.space,function(){N4?v4=i3.tagEnd:(v4=i3.attributeNameStart,C3(a2.openTag,P4))}),n3(d3,r4.gt,function(){C3(N4?a2.closeTag:a2.openTag,P4),S4="",v4=i3.data}),n3(d3,r4.slash,function(){v4=i3.tagEnd,C3(a2.openTag,P4)}),n3(d3,r4.char,function(t8){(P4+=t8)==="![CDATA["&&(v4=i3.cdata,S4="",P4="")}),d3)),n3(y3,i3.tagEnd,(n3(l2={},r4.gt,function(){C3(a2.closeTag,P4),S4="",v4=i3.data}),n3(l2,r4.char,o4),l2)),n3(y3,i3.attributeNameStart,(n3(u4={},r4.char,function(t8){b3=t8,v4=i3.attributeName}),n3(u4,r4.gt,function(){S4="",v4=i3.data}),n3(u4,r4.space,o4),n3(u4,r4.slash,function(){N4=!0,v4=i3.tagEnd}),u4)),n3(y3,i3.attributeName,(n3(p2={},r4.space,function(){v4=i3.attributeNameEnd}),n3(p2,r4.equal,function(){C3(a2.attributeName,b3),v4=i3.attributeValueBegin}),n3(p2,r4.gt,function(){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),S4="",v4=i3.data}),n3(p2,r4.slash,function(){N4=!0,M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),v4=i3.tagEnd}),n3(p2,r4.char,function(t8){b3+=t8}),p2)),n3(y3,i3.attributeNameEnd,(n3(m3={},r4.space,o4),n3(m3,r4.equal,function(){C3(a2.attributeName,b3),v4=i3.attributeValueBegin}),n3(m3,r4.gt,function(){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),S4="",v4=i3.data}),n3(m3,r4.char,function(t8){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),b3=t8,v4=i3.attributeName}),m3)),n3(y3,i3.attributeValueBegin,(n3(f2={},r4.space,o4),n3(f2,r4.quote,function(t8){I4=t8,M5="",v4=i3.attributeValue}),n3(f2,r4.gt,function(){C3(a2.attributeValue,M5=""),S4="",v4=i3.data}),n3(f2,r4.char,function(t8){I4="",M5=t8,v4=i3.attributeValue}),f2)),n3(y3,i3.attributeValue,(n3(g4={},r4.space,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),v4=i3.attributeNameStart)}),n3(g4,r4.quote,function(t8){I4===t8?(C3(a2.attributeValue,M5),v4=i3.attributeNameStart):M5+=t8}),n3(g4,r4.gt,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),S4="",v4=i3.data)}),n3(g4,r4.slash,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),N4=!0,v4=i3.tagEnd)}),n3(g4,r4.char,function(t8){M5+=t8}),g4)),y3);var _4=function(e6){t7.debug&&console.log(v4,e6);var n4=x3.stateMachine[v4],s4=n4[(function(t8){return c3[t8]||r4.char})(e6)]||n4[r4.error]||n4[r4.char];s4(e6)};return x3.write=function(t8){for(var e6=t8.length,n4=0;n4<e6;n4++)_4(t8[n4])},x3}}}}),f=r3({"node_modules/xml-reader/dist/reader.js"(t5,e4){var n3=u3(),s3=m(),o4=s3.Type,i3={element:"element",text:"text"},r4=function(t7){return Object.assign({name:"",type:i3.element,value:"",parent:null,attributes:{},children:[]},t7)},a2=function(t7){t7=Object.assign({stream:!1,parentNodes:!0,doneEvent:"done",tagPrefix:"tag:",emitTopLevelOnly:!1,debug:!1},t7);var e5=void 0,a3=void 0,c3=void 0,h2=void 0,d3=new n3,l2=function(n4){switch(n4.type){case o4.openTag:if(c3===null)(c3=a3).name=n4.value;else{var s4=r4({name:n4.value,parent:c3});c3.children.push(s4),c3=s4}break;case o4.closeTag:var l3=c3.parent;if(t7.parentNodes||(c3.parent=null),c3.name!==n4.value)break;t7.stream&&l3===a3&&(a3.children=[],c3.parent=null),t7.emitTopLevelOnly&&l3!==a3||(d3.emit(t7.tagPrefix+c3.name,c3),d3.emit("tag",c3.name,c3)),c3===a3&&(e5.removeAllListeners("data"),d3.emit(t7.doneEvent,c3),a3=null),c3=l3;break;case o4.text:c3&&c3.children.push(r4({type:i3.text,value:n4.value,parent:t7.parentNodes?c3:null}));break;case o4.attributeName:h2=n4.value,c3.attributes[h2]="";break;case o4.attributeValue:c3.attributes[h2]=n4.value}};return d3.reset=function(){(e5=s3.create({debug:t7.debug})).on("data",l2),a3=r4(),c3=null,h2="",d3.parse=e5.write},d3.reset(),d3};e4.exports={parseSync:function(t7,e5){e5=Object.assign({},e5,{stream:!1,tagPrefix:":"});var n4=a2(e5),s4=void 0;return n4.on("done",function(t8){s4=t8}),n4.parse(t7),s4},create:a2,NodeType:i3}}}),g3=(...t5)=>{let e4={points:[],lines:[],circles:[],rects:[]};return t5.forEach((t7,n3)=>{t7&&(t7.lines&&(e4.lines=[...e4.lines||[],...t7.lines.map(t8=>({...t8,step:n3}))]),t7.points&&(e4.points=[...e4.points||[],...t7.points.map(t8=>({...t8,step:n3}))]),t7.circles&&(e4.circles=[...e4.circles||[],...t7.circles.map(t8=>({...t8,step:n3}))]),t7.rects&&(e4.rects=[...e4.rects||[],...t7.rects.map(t8=>({...t8,step:n3}))]))}),e4},y=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,"cacheHit");__publicField(this,"cacheKey");__publicField(this,"cacheToSolveSpaceTransform")}step(){if(!this.solved&&!this.failed){this.iterations++;try{this._step()}catch(t5){throw this.error=`${this.constructor.name} error: ${t5}`,console.error(this.error),this.failed=!0,t5}!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 (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 t5=Date.now();for(;!this.solved&&!this.failed;)this.step();let e4=Date.now();this.timeToSolve=e4-t5}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}preview(){return{lines:[],points:[],rects:[],circles:[]}}};function x(){return x=Object.assign?Object.assign.bind():function(t5){for(var e4=1;e4<arguments.length;e4++){var n3=arguments[e4];for(var s3 in n3)({}).hasOwnProperty.call(n3,s3)&&(t5[s3]=n3[s3])}return t5},x.apply(null,arguments)}function v3(t5,e4){return(v3=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t7,e5){return t7.__proto__=e5,t7})(t5,e4)}function S3(t5){return(S3=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t7){return t7.__proto__||Object.getPrototypeOf(t7)})(t5)}function P3(){try{var t5=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch{}return(P3=function(){return!!t5})()}function b(t5){var e4=typeof Map=="function"?new Map:void 0;return b=function(t7){if(t7===null||!(function(t8){try{return Function.toString.call(t8).indexOf("[native code]")!==-1}catch{return typeof t8=="function"}})(t7))return t7;if(typeof t7!="function")throw new TypeError("Super expression must either be null or a function");if(e4!==void 0){if(e4.has(t7))return e4.get(t7);e4.set(t7,n3)}function n3(){return(function(t8,e5,n4){if(P3())return Reflect.construct.apply(null,arguments);var s3=[null];s3.push.apply(s3,e5);var o4=new(t8.bind.apply(t8,s3));return n4&&v3(o4,n4.prototype),o4})(t7,arguments,S3(this).constructor)}return n3.prototype=Object.create(t7.prototype,{constructor:{value:n3,enumerable:!1,writable:!0,configurable:!0}}),v3(n3,t7)},b(t5)}var M3={1:`Passed invalid arguments to hsl, please pass multiple numbers e.g. hsl(360, 0.75, 0.4) or an object e.g. rgb({ hue: 255, saturation: 0.4, lightness: 0.75 }).
|
|
360
|
+
`),{solved:!1,connectionName:connection.name}}createObstacleList({dominantLayer,connection,obstaclesFromTraces}){return new ObstacleList(this.allObstacles.filter(obstacle=>!obstacle.connectedTo.includes(connection.name)).filter(obstacle=>obstacle.layers.includes(dominantLayer)).concat(obstaclesFromTraces??[]))}postprocessConnectionSolveResult(connection,result){return result}solve(){let solutions=[],obstaclesFromTraces=[];this.debugTraceCount=0;for(let connection of this.input.connections){let dominantLayer=connection.pointsToConnect[0].layer??"top";this.debugTraceCount+=1,this.obstacles=this.createObstacleList({dominantLayer,connection,obstaclesFromTraces});let result=this.solveConnection(connection);result=this.postprocessConnectionSolveResult(connection,result),solutions.push(result),debug2.enabled&&this.drawDebugTraceObstacles(obstaclesFromTraces),result.solved&&obstaclesFromTraces.push(...getObstaclesFromRoute(result.route.map(p2=>({x:p2.x,y:p2.y,layer:p2.layer??dominantLayer})),connection.name))}return solutions}solveAndMapToTraces(){return this.solve().flatMap(solution=>solution.solved?[{type:"pcb_trace",pcb_trace_id:`pcb_trace_for_${solution.connectionName}`,route:addViasWhenLayerChanges(solution.route.map(point6=>({route_type:"wire",x:point6.x,y:point6.y,width:this.input.minTraceWidth,layer:point6.layer})))}]:[])}getDebugGroup(){let dgn=`t${this.debugTraceCount}_iter[${this.iterations-1}]`;return this.iterations<30||this.iterations<100&&this.iterations%10===0||this.iterations<1e3&&this.iterations%100===0||!this.debugSolutions?dgn:null}drawDebugTraceObstacles(obstacles){let{debugTraceCount,debugSolutions}=this;for(let key in debugSolutions)key.startsWith(`t${debugTraceCount}_`)&&debugSolutions[key].push(...obstacles.map((obstacle,i3)=>({type:"pcb_smtpad",pcb_component_id:"",layer:obstacle.layers[0],width:obstacle.width,shape:"rect",x:obstacle.center.x,y:obstacle.center.y,pcb_smtpad_id:`trace_obstacle_${i3}`,height:obstacle.height})))}drawDebugSolution({current:current2,newNeighbors}){let debugGroup=this.getDebugGroup();if(!debugGroup)return;let{openSet,debugTraceCount,debugSolutions}=this;debugSolutions[debugGroup]??(debugSolutions[debugGroup]=[]);let debugSolution=debugSolutions[debugGroup];debugSolution.push({type:"pcb_fabrication_note_text",pcb_fabrication_note_text_id:`debug_note_${current2.x}_${current2.y}`,font:"tscircuit2024",font_size:.25,text:"X"+(current2.l!==void 0?current2.l:""),pcb_component_id:"",layer:"top",anchor_position:{x:current2.x,y:current2.y},anchor_alignment:"center"});for(let i3=0;i3<openSet.length;i3++){let node=openSet[i3];debugSolution.push({type:"pcb_fabrication_note_path",pcb_component_id:"",pcb_fabrication_note_path_id:`note_path_${node.x}_${node.y}`,layer:"top",route:[[0,.05],[.05,0],[0,-.05],[-.05,0],[0,.05]].map(([dx2,dy2])=>({x:node.x+dx2,y:node.y+dy2})),stroke_width:.01}),debugSolution.push({type:"pcb_fabrication_note_text",pcb_fabrication_note_text_id:`debug_note_${node.x}_${node.y}`,font:"tscircuit2024",font_size:.03,text:i3.toString(),pcb_component_id:"",layer:"top",anchor_position:{x:node.x,y:node.y},anchor_alignment:"center"})}if(current2.parent){let path=[],p2=current2;for(;p2;)path.unshift(p2),p2=p2.parent;debugSolution.push({type:"pcb_fabrication_note_path",pcb_component_id:"",pcb_fabrication_note_path_id:`note_path_${current2.x}_${current2.y}`,layer:"top",route:path,stroke_width:.01})}}},debug3=(0,import_debug3.default)("autorouting-dataset:infinite-grid-ijump-astar:get-distance-to-overcome-obstacle");function getDistanceToOvercomeObstacle({node,travelDir,wallDir,obstacle,obstacles,obstaclesInRow=0,OBSTACLE_MARGIN=.15,SHOULD_DETECT_CONJOINED_OBSTACLES=!1,MAX_CONJOINED_OBSTACLES=20}){let distToOvercomeObstacle;if(travelDir.dx===0?travelDir.dy>0?distToOvercomeObstacle=obstacle.center.y+obstacle.height/2-node.y:distToOvercomeObstacle=node.y-(obstacle.center.y-obstacle.height/2):travelDir.dx>0?distToOvercomeObstacle=obstacle.center.x+obstacle.width/2-node.x:distToOvercomeObstacle=node.x-(obstacle.center.x-obstacle.width/2),distToOvercomeObstacle+=OBSTACLE_MARGIN,SHOULD_DETECT_CONJOINED_OBSTACLES&&obstaclesInRow<MAX_CONJOINED_OBSTACLES){let obstacleAtEnd=obstacles.getObstacleAt(node.x+travelDir.dx*distToOvercomeObstacle+wallDir.dx*(wallDir.wallDistance+.001),node.y+travelDir.dy*distToOvercomeObstacle+wallDir.dy*(wallDir.wallDistance+.001));if(obstacleAtEnd===obstacle)return distToOvercomeObstacle;if(obstacleAtEnd&&obstacleAtEnd.type==="rect"){let extendingAlongXAxis=travelDir.dy===0,o1OrthoDim=extendingAlongXAxis?obstacle.height:obstacle.width;if((extendingAlongXAxis?obstacleAtEnd.height:obstacleAtEnd.width)>o1OrthoDim)return debug3("next obstacle on path is bigger, not trying to overcome it"),distToOvercomeObstacle;let endObstacleDistToOvercome=getDistanceToOvercomeObstacle({node:{x:node.x+travelDir.dx*distToOvercomeObstacle,y:node.y+travelDir.dy*distToOvercomeObstacle},travelDir,wallDir,obstacle:obstacleAtEnd,obstacles,obstaclesInRow:obstaclesInRow+1,SHOULD_DETECT_CONJOINED_OBSTACLES,MAX_CONJOINED_OBSTACLES,OBSTACLE_MARGIN});distToOvercomeObstacle+=endObstacleDistToOvercome}}return distToOvercomeObstacle}var IJumpAutorouter=class extends GeneralizedAstarAutorouter{constructor(){super(...arguments);__publicField(this,"MAX_ITERATIONS",200)}getNeighbors(node){let obstacles=this.obstacles,goalPoint=this.goalPoint,forwardDir;node.parent?forwardDir=dirFromAToB(node.parent,node):forwardDir=dirFromAToB(node,goalPoint);let travelDirs1=[{dx:0,dy:1},{dx:1,dy:0},{dx:0,dy:-1},{dx:-1,dy:0}].filter(dir=>dir.dx===forwardDir.dx*-1&&dir.dy===forwardDir.dy*-1?!1:!(dir.dx===forwardDir.dx&&dir.dy===forwardDir.dy&&node.parent?.obstacleHit)).map(dir=>obstacles.getOrthoDirectionCollisionInfo(node,dir,{margin:this.OBSTACLE_MARGIN})).filter(dir=>dir.wallDistance>=this.OBSTACLE_MARGIN),travelDirs2=[];for(let travelDir of travelDirs1){let overcomeDistance=null;node?.obstacleHit&&(overcomeDistance=getDistanceToOvercomeObstacle({node,travelDir,wallDir:{...forwardDir,wallDistance:this.OBSTACLE_MARGIN},obstacle:node.obstacleHit,obstacles,OBSTACLE_MARGIN:this.OBSTACLE_MARGIN,SHOULD_DETECT_CONJOINED_OBSTACLES:!0}));let goalDistAlongTravelDir=distAlongDir(node,goalPoint,travelDir),isGoalInTravelDir=(travelDir.dx===0||Math.sign(goalPoint.x-node.x)===travelDir.dx)&&(travelDir.dy===0||Math.sign(goalPoint.y-node.y)===travelDir.dy);goalDistAlongTravelDir<travelDir.wallDistance&&goalDistAlongTravelDir>0&&isGoalInTravelDir?travelDirs2.push({...travelDir,travelDistance:goalDistAlongTravelDir}):overcomeDistance!==null&&overcomeDistance<travelDir.wallDistance?travelDirs2.push({...travelDir,travelDistance:overcomeDistance}):travelDir.wallDistance!==1/0&&travelDirs2.push({...travelDir,travelDistance:travelDir.wallDistance-this.OBSTACLE_MARGIN})}return travelDirs2.filter(dir=>!obstacles.isObstacleAt(node.x+dir.dx*dir.travelDistance,node.y+dir.dy*dir.travelDistance)).map(dir=>({x:node.x+dir.dx*dir.travelDistance,y:node.y+dir.dy*dir.travelDistance,obstacleHit:dir.obstacle}))}};function generateApproximatingRects(rotatedRect,numRects=4){let{center:center2,width,height,rotation:rotation4}=rotatedRect,rects=[],angleRad=rotation4*Math.PI/180,cosAngle=Math.cos(angleRad),sinAngle=Math.sin(angleRad),normalizedRotation=(rotation4%360+360)%360;if(height<=width?normalizedRotation>=45&&normalizedRotation<135||normalizedRotation>=225&&normalizedRotation<315:normalizedRotation>=135&&normalizedRotation<225||normalizedRotation>=315||normalizedRotation<45){let sliceWidth=width/numRects;for(let i3=0;i3<numRects;i3++){let x3=(i3-numRects/2+.5)*sliceWidth,rotatedX=-x3*cosAngle,rotatedY=-x3*sinAngle,coverageWidth=sliceWidth*1.1,coverageHeight=Math.abs(height*cosAngle)+Math.abs(sliceWidth*sinAngle);rects.push({center:{x:center2.x+rotatedX,y:center2.y+rotatedY},width:coverageWidth,height:coverageHeight})}}else{let sliceHeight=height/numRects;for(let i3=0;i3<numRects;i3++){let y3=(i3-numRects/2+.5)*sliceHeight,rotatedX=-y3*sinAngle,rotatedY=y3*cosAngle,coverageWidth=Math.abs(width*cosAngle)+Math.abs(sliceHeight*sinAngle),coverageHeight=sliceHeight*1.1;rects.push({center:{x:center2.x+rotatedX,y:center2.y+rotatedY},width:coverageWidth,height:coverageHeight})}}return rects}var EVERY_LAYER=["top","inner1","inner2","bottom"],getObstaclesFromCircuitJson=(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},approximatingRects=generateApproximatingRects(rotatedRect);for(let rect of approximatingRects)obstacles.push({type:"rect",layers:[element.layer],center:rect.center,width:rect.width,height:rect.height,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_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==="square"?obstacles.push({type:"rect",layers:EVERY_LAYER,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_LAYER,center:{x:element.x,y:element.y},width:element.hole_diameter,height:element.hole_diameter,connectedTo:[]});else if(element.type==="pcb_plated_hole")element.shape==="circle"?obstacles.push({type:"oval",layers:EVERY_LAYER,center:{x:element.x,y:element.y},width:element.outer_diameter,height:element.outer_diameter,connectedTo:withNetId([element.pcb_plated_hole_id])}):(element.shape==="oval"||element.shape==="pill")&&obstacles.push({type:"oval",layers:EVERY_LAYER,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.type==="pcb_trace"){let traceObstacles=getObstaclesFromRoute(element.route.map(rp2=>({x:rp2.x,y:rp2.y,layer:"layer"in rp2?rp2.layer:rp2.from_layer})),element.source_trace_id);obstacles.push(...traceObstacles)}else element.type==="pcb_via"&&obstacles.push({type:"rect",layers:element.layers,center:{x:element.x,y:element.y},connectedTo:[],width:element.outer_diameter,height:element.outer_diameter});return obstacles};function getAlternativeGoalBoxes(params){let{pcbConnMap,goalElementId}=params;if(!goalElementId.startsWith("pcb_port_"))throw new Error(`Currently alternative goal boxes must have a goal id with prefix "pcb_port_" (got ${goalElementId})`);let goalTraces=pcbConnMap.getAllTracesConnectedToPort(goalElementId);return getObstaclesFromCircuitJson(goalTraces).map(obs=>({...obs,connectedTo:[goalElementId]}))}var getConnectionWithAlternativeGoalBoxes=params=>{let{connection,pcbConnMap}=params;if(connection.pointsToConnect.length!==2)throw new Error(`Connection must have exactly 2 points for alternative goal boxes (got ${connection.pointsToConnect.length})`);let[a2,b3]=connection.pointsToConnect;if(!a2.pcb_port_id||!b3.pcb_port_id)throw new Error(`Connection points must have pcb_port_id for alternative goal box calculation (got ${a2.pcb_port_id} and ${b3.pcb_port_id})`);let goalBoxesA=getAlternativeGoalBoxes({goalElementId:a2.pcb_port_id,pcbConnMap}).concat([{center:a2,width:.01,height:.01,connectedTo:[a2.pcb_port_id],layers:[a2.layer],type:"rect"}]),goalBoxesB=getAlternativeGoalBoxes({goalElementId:b3.pcb_port_id,pcbConnMap}).concat([{center:b3,width:.01,height:.01,connectedTo:[b3.pcb_port_id],layers:[b3.layer],type:"rect"}]);if(goalBoxesA.length<=1&&goalBoxesB.length<=1)return{...connection,startPoint:a2,endPoint:b3,goalBoxes:[]};let nearestPoints=findNearestPointsBetweenBoxSets2(goalBoxesA,goalBoxesB),startPoint,endPoint,goalBoxes;return goalBoxesA.length>=goalBoxesB.length?(startPoint={...b3,...nearestPoints.pointB},endPoint={...a2,...nearestPoints.pointA},goalBoxes=goalBoxesA):(startPoint={...a2,...nearestPoints.pointA},endPoint={...b3,...nearestPoints.pointB},goalBoxes=goalBoxesB),{startPoint,endPoint,goalBoxes,name:connection.name,pointsToConnect:[startPoint,endPoint]}},getSimpleRouteJson=(circuitJson,opts={})=>{let routeJson={minTraceWidth:.1};routeJson.layerCount=opts.layerCount??1,routeJson.obstacles=getObstaclesFromCircuitJson(circuitJson,opts.connMap),routeJson.connections=[];for(let element of circuitJson)if(element.type==="source_trace"){if(circuitJson.some(e4=>e4.type==="pcb_trace"&&e4.source_trace_id===element.source_trace_id))continue;let connection={name:element.source_trace_id,pointsToConnect:element.connected_source_port_ids.map(portId=>{let pcb_port2=su_default(circuitJson).pcb_port.getWhere({source_port_id:portId});if(!pcb_port2)throw new Error(`Could not find pcb_port for source_port_id "${portId}"`);return{x:pcb_port2.x,y:pcb_port2.y,layer:pcb_port2.layers?.[0]??"top",pcb_port_id:pcb_port2.pcb_port_id}})};if(opts.optimizeWithGoalBoxes){let pcbConnMap=new PcbConnectivityMap(circuitJson);connection=getConnectionWithAlternativeGoalBoxes({connection,pcbConnMap})}routeJson.connections.push(connection),markObstaclesAsConnected(routeJson.obstacles,connection.pointsToConnect,connection.name)}let bounds={minX:1/0,maxX:-1/0,minY:1/0,maxY:-1/0};for(let obstacle of routeJson.obstacles)bounds.minX=Math.min(bounds.minX,obstacle.center.x-obstacle.width/2),bounds.maxX=Math.max(bounds.maxX,obstacle.center.x+obstacle.width/2),bounds.minY=Math.min(bounds.minY,obstacle.center.y-obstacle.height/2),bounds.maxY=Math.max(bounds.maxY,obstacle.center.y+obstacle.height/2);for(let connection of routeJson.connections)for(let point6 of connection.pointsToConnect)bounds.minX=Math.min(bounds.minX,point6.x),bounds.maxX=Math.max(bounds.maxX,point6.x),bounds.minY=Math.min(bounds.minY,point6.y),bounds.maxY=Math.max(bounds.maxY,point6.y);return routeJson.bounds=bounds,routeJson},markObstaclesAsConnected=(obstacles,pointsToConnect,connectionName)=>{for(let point6 of pointsToConnect)for(let obstacle of obstacles)isPointInsideObstacle(point6,obstacle)&&obstacle.connectedTo.push(connectionName)};function isPointInsideObstacle(point6,obstacle){let halfWidth=obstacle.width/2,halfHeight=obstacle.height/2;if(obstacle.type==="rect")return point6.x>=obstacle.center.x-halfWidth&&point6.x<=obstacle.center.x+halfWidth&&point6.y>=obstacle.center.y-halfHeight&&point6.y<=obstacle.center.y+halfHeight;if(obstacle.type==="oval"){let normalizedX=(point6.x-obstacle.center.x)/halfWidth,normalizedY=(point6.y-obstacle.center.y)/halfHeight;return normalizedX*normalizedX+normalizedY*normalizedY<=1}return!1}function dirFromAToB2(nodeA,nodeB){let dx2=nodeB.x>nodeA.x?1:nodeB.x<nodeA.x?-1:0,dy2=nodeB.y>nodeA.y?1:nodeB.y<nodeA.y?-1:0,dl2=nodeB.l>nodeA.l?1:nodeB.l<nodeA.l?-1:0;return{dx:dx2,dy:dy2,dl:dl2}}var LAYER_COUNT_INDEX_MAP={1:["top"],2:["top","bottom"],4:["top","inner1","inner2","bottom"]},getLayerNamesForLayerCount=layerCount=>LAYER_COUNT_INDEX_MAP[layerCount];function getLayerIndex(layerCount,layer){let index=LAYER_COUNT_INDEX_MAP[layerCount].indexOf(layer);if(index===-1)throw new Error(`Invalid layer for getLayerIndex (for layerCount === ${layerCount}): "${layer}"`);return index}function indexToLayer(layerCount,index){let layer=LAYER_COUNT_INDEX_MAP[layerCount][index];if(!layer)throw new Error(`Invalid index for indexToLayer (for layerCount === ${layerCount}): "${index}"`);return layer}var ObstacleList3d=class extends ObstacleList{constructor(layerCount,obstacles){super([]);__publicField(this,"obstacles");__publicField(this,"GRID_STEP",.1);__publicField(this,"layerCount");this.layerCount=layerCount;let availableLayers=getLayerNamesForLayerCount(layerCount);this.obstacles=obstacles.flatMap(obstacle=>obstacle.layers.filter(layer=>availableLayers.includes(layer)).map(layer=>({...obstacle,left:obstacle.center.x-obstacle.width/2,right:obstacle.center.x+obstacle.width/2,top:obstacle.center.y+obstacle.height/2,bottom:obstacle.center.y-obstacle.height/2,l:getLayerIndex(layerCount,layer)})))}getObstacleAt(x3,y3,l2,m3){m3??(m3=this.GRID_STEP);for(let obstacle of this.obstacles){if(obstacle.l!==l2)continue;let halfWidth=obstacle.width/2+m3,halfHeight=obstacle.height/2+m3;if(x3>=obstacle.center.x-halfWidth&&x3<=obstacle.center.x+halfWidth&&y3>=obstacle.center.y-halfHeight&&y3<=obstacle.center.y+halfHeight)return obstacle}return null}isObstacleAt(x3,y3,l2,m3){return this.getObstacleAt(x3,y3,l2,m3)!==null}getDirectionDistancesToNearestObstacle3d(x3,y3,l2){let{GRID_STEP}=this,result={left:1/0,top:1/0,bottom:1/0,right:1/0};for(let obstacle of this.obstacles)if(obstacle.l===l2&&obstacle.type==="rect"){let left=obstacle.center.x-obstacle.width/2-GRID_STEP,right=obstacle.center.x+obstacle.width/2+GRID_STEP,top=obstacle.center.y+obstacle.height/2+GRID_STEP,bottom=obstacle.center.y-obstacle.height/2-GRID_STEP;y3>=bottom&&y3<=top&&x3>left&&(result.left=Math.min(result.left,x3-right)),y3>=bottom&&y3<=top&&x3<right&&(result.right=Math.min(result.right,left-x3)),x3>=left&&x3<=right&&y3<top&&(result.top=Math.min(result.top,bottom-y3)),x3>=left&&x3<=right&&y3>bottom&&(result.bottom=Math.min(result.bottom,y3-top))}return result}getOrthoDirectionCollisionInfo(point6,dir,{margin=0}={}){let{x:x3,y:y3,l:l2}=point6,{dx:dx2,dy:dy2,dl:dl2}=dir,minDistance=1/0,collisionObstacle=null;if(dl2!==0){let newLayer=l2+dl2;return this.isObstacleAt(x3,y3,newLayer,margin)?(minDistance=1,collisionObstacle=this.getObstacleAt(x3,y3,newLayer,margin)):minDistance=1,{dx:dx2,dy:dy2,dl:dl2,wallDistance:minDistance,obstacle:collisionObstacle}}else{for(let obstacle of this.obstacles){if(obstacle.l!==l2)continue;let leftMargin=obstacle.left-margin,rightMargin=obstacle.right+margin,topMargin=obstacle.top+margin,bottomMargin=obstacle.bottom-margin,distance8=null;dx2===1&&dy2===0?y3>bottomMargin&&y3<topMargin&&x3<obstacle.left&&(distance8=obstacle.left-x3):dx2===-1&&dy2===0?y3>bottomMargin&&y3<topMargin&&x3>obstacle.right&&(distance8=x3-obstacle.right):dx2===0&&dy2===1?x3>leftMargin&&x3<rightMargin&&y3<obstacle.bottom&&(distance8=obstacle.bottom-y3):dx2===0&&dy2===-1&&x3>leftMargin&&x3<rightMargin&&y3>obstacle.top&&(distance8=y3-obstacle.top),distance8!==null&&distance8<minDistance&&(minDistance=distance8,collisionObstacle=obstacle)}return{dx:dx2,dy:dy2,dl:0,wallDistance:minDistance,obstacle:collisionObstacle}}}getObstaclesOverlappingRegion(region){let obstacles=[];for(let obstacle of this.obstacles){if(obstacle.l!==region.l)continue;let{left,right,top,bottom}=obstacle;left<=region.maxX&&right>=region.minX&&top>=region.minY&&bottom<=region.maxY&&obstacles.push(obstacle)}return obstacles}},MultilayerIjump=class extends GeneralizedAstarAutorouter{constructor(opts){super(opts);__publicField(this,"MAX_ITERATIONS",500);__publicField(this,"VIA_COST",4);__publicField(this,"VIA_DIAMETER",.5);__publicField(this,"allowLayerChange",!0);__publicField(this,"layerCount");__publicField(this,"obstacles");__publicField(this,"optimizeWithGoalBoxes");__publicField(this,"connMap");__publicField(this,"pcbConnMap");__publicField(this,"GOAL_RUSH_FACTOR",1.1);__publicField(this,"defaultGoalViaMargin",.5);__publicField(this,"marginsWithCosts");this.layerCount=opts.input.layerCount??2,this.MAX_ITERATIONS=opts.MAX_ITERATIONS??this.MAX_ITERATIONS,this.VIA_COST=opts.VIA_COST??this.VIA_COST,this.connMap=opts.connMap,this.pcbConnMap=opts.pcbConnMap??new PcbConnectivityMap,this.optimizeWithGoalBoxes=opts.optimizeWithGoalBoxes??!1,this.obstacles=null,this.marginsWithCosts=opts.marginsWithCosts??[{margin:1,enterCost:0,travelCostFactor:1},{margin:this.OBSTACLE_MARGIN,enterCost:10,travelCostFactor:2}]}get largestMargin(){return this.marginsWithCosts[0].margin}preprocessConnectionBeforeSolving(connection){return this.optimizeWithGoalBoxes?getConnectionWithAlternativeGoalBoxes({connection,pcbConnMap:this.pcbConnMap}):connection}postprocessConnectionSolveResult(connection,result){if(!result.solved)return result;if(this.optimizeWithGoalBoxes){let traceRoute=result.route.map(rp2=>({x:rp2.x,y:rp2.y,route_type:"wire",layer:rp2.layer,width:this.input.minTraceWidth}));traceRoute[0].start_pcb_port_id=connection.pointsToConnect[0].pcb_port_id,traceRoute[traceRoute.length-1].end_pcb_port_id=connection.pointsToConnect[1].pcb_port_id,this.pcbConnMap.addTrace({type:"pcb_trace",pcb_trace_id:`postprocess_trace_${nanoid(8)}`,route:traceRoute})}return result}createObstacleList({dominantLayer,connection,obstaclesFromTraces}){let bestConnectionId=this.connMap?this.connMap.getNetConnectedToId(connection.name):connection.name;if(!bestConnectionId)throw new Error(`The connection.name "${connection.name}" wasn't present in the full connectivity map`);return new ObstacleList3d(this.layerCount,this.allObstacles.filter(obstacle=>!obstacle.connectedTo.includes(bestConnectionId)).concat(obstaclesFromTraces??[]))}computeG(current2,neighbor){let cost=current2.g+manDist(current2,neighbor)*(current2.travelMarginCostFactor??1)+(neighbor.enterMarginCost??0);return(neighbor.l??current2.l!==-1??-1)&&(cost+=this.VIA_COST),cost}computeH(node){let dx2=Math.abs(node.x-this.goalPoint.x),dy2=Math.abs(node.y-this.goalPoint.y),dl2=Math.abs(node.l-this.goalPoint.l);return(dx2+dy2)**this.GOAL_RUSH_FACTOR+dl2*this.VIA_COST}getStartNode(connection){return{...super.getStartNode(connection),l:this.layerToIndex(connection.pointsToConnect[0].layer)}}layerToIndex(layer){return getLayerIndex(this.layerCount,layer)}indexToLayer(index){return indexToLayer(this.layerCount,index)}getNodeName(node){return`${nodeName(node,this.GRID_STEP)}-${node.l??0}`}hasSpaceForVia(layers,point6){return layers.every(l2=>this.obstacles.getObstaclesOverlappingRegion({minX:point6.x-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,minY:point6.y-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,maxX:point6.x+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,maxY:point6.y+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,l:l2}).length===0)}getNeighborsSurroundingGoal(node){let obstacles=this.obstacles,goalPoint=this.goalPoint,neighbors=[],travelDirs=[{dx:1,dy:0,dl:0},{dx:-1,dy:0,dl:0},{dx:0,dy:1,dl:0},{dx:0,dy:-1,dl:0}],travelDistance=this.VIA_DIAMETER+this.OBSTACLE_MARGIN+this.defaultGoalViaMargin;for(let dir of travelDirs){let candidateNeighbor={x:node.x+dir.dx*travelDistance,y:node.y+dir.dy*travelDistance,l:node.l+dir.dl,obstacleHit:null};this.hasSpaceForVia([node.l,goalPoint.l],candidateNeighbor)&&neighbors.push(candidateNeighbor)}return neighbors}getNeighbors(node){let obstacles=this.obstacles,goalPoint=this.goalPoint,goalDistIgnoringLayer=manDist(node,goalPoint);if(goalDistIgnoringLayer<=this.OBSTACLE_MARGIN)return this.getNeighborsSurroundingGoal(node);let forwardDir;node.parent?forwardDir=dirFromAToB2(node.parent,node):forwardDir=dirFromAToB2(node,goalPoint);let travelDirs1=[{dx:0,dy:1,dl:0},{dx:1,dy:0,dl:0},{dx:0,dy:-1,dl:0},{dx:-1,dy:0,dl:0}],isFarEnoughFromGoalToChangeLayer=goalDistIgnoringLayer>this.VIA_DIAMETER+this.OBSTACLE_MARGIN,isFarEnoughFromStartToChangeLayer=manDist(node,this.startNode)>this.VIA_DIAMETER+this.OBSTACLE_MARGIN;this.allowLayerChange&&isFarEnoughFromGoalToChangeLayer&&isFarEnoughFromStartToChangeLayer&&(node.l<this.layerCount-1&&travelDirs1.push({dx:0,dy:0,dl:1}),node.l>0&&travelDirs1.push({dx:0,dy:0,dl:-1}));let travelDirs2=travelDirs1.filter(dir=>dir.dx===forwardDir.dx*-1&&dir.dy===forwardDir.dy*-1&&dir.dl===forwardDir.dl*-1?!1:!(dir.dx===forwardDir.dx&&dir.dy===forwardDir.dy&&dir.dl===forwardDir.dl&&node.parent?.obstacleHit)).map(dir=>obstacles.getOrthoDirectionCollisionInfo(node,dir,{margin:this.OBSTACLE_MARGIN})).filter(dir=>!(dir.wallDistance<this.OBSTACLE_MARGIN)),travelDirs3=[];for(let travelDir of travelDirs2){let isDownVia=travelDir.dx===0&&travelDir.dy===0&&travelDir.dl===1,isUpVia=travelDir.dx===0&&travelDir.dy===0&&travelDir.dl===-1;if((isDownVia||isUpVia)&&![node.l,node.l+travelDir.dl].every(l2=>obstacles.getObstaclesOverlappingRegion({minX:node.x-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,minY:node.y-this.VIA_DIAMETER/2-this.OBSTACLE_MARGIN,maxX:node.x+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,maxY:node.y+this.VIA_DIAMETER/2+this.OBSTACLE_MARGIN,l:l2}).length===0))continue;if(isDownVia){node.l<this.layerCount-1&&travelDirs3.push({...travelDir,travelDistance:0,enterMarginCost:0,travelMarginCostFactor:1});continue}if(isUpVia){node.l>0&&travelDirs3.push({...travelDir,travelDistance:0,enterMarginCost:0,travelMarginCostFactor:1});continue}let overcomeDistance=null;node?.obstacleHit&&(overcomeDistance=getDistanceToOvercomeObstacle({node,travelDir,wallDir:{...forwardDir,wallDistance:this.OBSTACLE_MARGIN},obstacle:node.obstacleHit,obstacles,OBSTACLE_MARGIN:this.OBSTACLE_MARGIN,SHOULD_DETECT_CONJOINED_OBSTACLES:!0}));let goalDistAlongTravelDir=distAlongDir(node,goalPoint,travelDir),isGoalInTravelDir=(travelDir.dx===0||Math.sign(goalPoint.x-node.x)===travelDir.dx)&&(travelDir.dy===0||Math.sign(goalPoint.y-node.y)===travelDir.dy);if(goalDistAlongTravelDir<travelDir.wallDistance&&goalDistAlongTravelDir>0&&isGoalInTravelDir){let isGoalOnSameLayer=node.l===goalPoint.l,stopShortDistance=0;!isGoalOnSameLayer&&Math.abs(goalDistAlongTravelDir-goalDistIgnoringLayer)<this.GRID_STEP&&(stopShortDistance=this.VIA_DIAMETER+this.OBSTACLE_MARGIN+this.defaultGoalViaMargin),travelDirs3.push({...travelDir,travelDistance:goalDistAlongTravelDir-stopShortDistance,enterMarginCost:0,travelMarginCostFactor:1})}else if(overcomeDistance!==null&&overcomeDistance<travelDir.wallDistance){for(let{margin,enterCost,travelCostFactor}of this.marginsWithCosts)overcomeDistance-this.OBSTACLE_MARGIN+margin*2<travelDir.wallDistance&&travelDirs3.push({...travelDir,travelDistance:overcomeDistance-this.OBSTACLE_MARGIN+margin,enterMarginCost:enterCost,travelMarginCostFactor:travelCostFactor});if(travelDir.wallDistance===1/0)travelDirs3.push({...travelDir,travelDistance:goalDistAlongTravelDir,enterMarginCost:0,travelMarginCostFactor:1});else if(travelDir.wallDistance>this.largestMargin)for(let{margin,enterCost,travelCostFactor}of this.marginsWithCosts)travelDir.wallDistance>this.largestMargin+margin&&travelDirs3.push({...travelDir,travelDistance:travelDir.wallDistance-margin,enterMarginCost:enterCost,travelMarginCostFactor:travelCostFactor})}else if(travelDir.wallDistance!==1/0)for(let{margin,enterCost,travelCostFactor}of this.marginsWithCosts)travelDir.wallDistance>margin&&travelDirs3.push({...travelDir,travelDistance:travelDir.wallDistance-margin,enterMarginCost:enterCost,travelMarginCostFactor:travelCostFactor})}return travelDirs3.map(dir=>({x:node.x+dir.dx*dir.travelDistance,y:node.y+dir.dy*dir.travelDistance,l:node.l+dir.dl,obstacleHit:dir.obstacle,travelMarginCostFactor:dir.travelMarginCostFactor,enterMarginCost:dir.enterMarginCost}))}};function autoroute2(soup){let input2=getSimpleRouteJson(soup),autorouter=new IJumpAutorouter({input:input2});return{solution:autorouter.solveAndMapToTraces(),debugSolutions:autorouter.debugSolutions,debugMessage:autorouter.debugMessage}}init_zod();init_zod();init_dist();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_dist();init_zod();init_zod();init_dist();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_dist();init_zod();init_zod();var expectTypesMatch2=shouldBe=>{};expectTypesMatch2("extra props b");expectTypesMatch2("missing props b");expectTypesMatch2(!0);expectTypesMatch2("property a has mismatched types");var direction=external_exports.enum(["up","down","left","right"]),directionAlongEdge=external_exports.enum(["top-to-bottom","left-to-right","bottom-to-top","right-to-left"]);expectTypesMatch2(!0);expectTypesMatch2(!0);var portHints=external_exports.array(external_exports.string().or(external_exports.number()));expectTypesMatch2(!0);var calcString=external_exports.string().regex(/^calc\(.*\)$/),distance3=distance,pcbCoordinate=calcString.or(distance),point32=external_exports.object({x:distance,y:distance,z:distance}),rotationPoint3=external_exports.object({x:external_exports.union([external_exports.number(),external_exports.string()]),y:external_exports.union([external_exports.number(),external_exports.string()]),z:external_exports.union([external_exports.number(),external_exports.string()])}),cadModelBase=external_exports.object({rotationOffset:external_exports.number().or(rotationPoint3).optional(),positionOffset:point32.optional(),size:point32.optional(),modelUnitToMmScale:distance3.optional(),zOffsetFromSurface:distance3.optional()});expectTypesMatch2(!0);var cadModelStl=cadModelBase.extend({stlUrl:external_exports.string()}),cadModelObj=cadModelBase.extend({objUrl:external_exports.string(),mtlUrl:external_exports.string().optional()}),cadModelGltf=cadModelBase.extend({gltfUrl:external_exports.string()}),cadModelGlb=cadModelBase.extend({glbUrl:external_exports.string()}),cadModelStep=cadModelBase.extend({stepUrl:external_exports.string()}),cadModelWrl=cadModelBase.extend({wrlUrl:external_exports.string()}),cadModelJscad=cadModelBase.extend({jscad:external_exports.record(external_exports.any())}),cadModelProp=external_exports.union([external_exports.null(),external_exports.string(),external_exports.custom(v4=>v4&&typeof v4=="object"&&"type"in v4&&"props"in v4),cadModelStl,cadModelObj,cadModelGltf,cadModelGlb,cadModelStep,cadModelWrl,cadModelJscad]);expectTypesMatch2(!0);var footprintProp=external_exports.custom(v4=>!0),pcbStyle=external_exports.object({silkscreenFontSize:distance.optional(),viaPadDiameter:distance.optional(),viaHoleDiameter:distance.optional(),silkscreenTextPosition:external_exports.union([external_exports.enum(["centered","outside","none"]),external_exports.object({offsetX:external_exports.number(),offsetY:external_exports.number()})]).optional(),silkscreenTextVisibility:external_exports.enum(["hidden","visible","inherit"]).optional()});expectTypesMatch2(!0);var schStyle=external_exports.object({defaultPassiveSize:external_exports.union([external_exports.enum(["xs","sm","md"]),distance]).optional(),defaultCapacitorOrientation:external_exports.enum(["vertical","none"]).optional()});expectTypesMatch2(!0);var symbolProp=external_exports.custom(v4=>!0),pcbLayoutProps=external_exports.object({pcbX:pcbCoordinate.optional(),pcbY:pcbCoordinate.optional(),pcbLeftEdgeX:pcbCoordinate.optional(),pcbRightEdgeX:pcbCoordinate.optional(),pcbTopEdgeY:pcbCoordinate.optional(),pcbBottomEdgeY:pcbCoordinate.optional(),pcbOffsetX:distance.optional(),pcbOffsetY:distance.optional(),pcbRotation:rotation.optional(),pcbPositionAnchor:external_exports.string().optional(),pcbPositionMode:external_exports.enum(["relative_to_group_anchor","auto","relative_to_board_anchor","relative_to_component_anchor"]).optional(),layer:layer_ref.optional(),pcbMarginTop:distance.optional(),pcbMarginRight:distance.optional(),pcbMarginBottom:distance.optional(),pcbMarginLeft:distance.optional(),pcbMarginX:distance.optional(),pcbMarginY:distance.optional(),pcbStyle:pcbStyle.optional(),pcbRelative:external_exports.boolean().optional(),relative:external_exports.boolean().optional()});expectTypesMatch2(!0);var commonLayoutProps=external_exports.object({pcbX:pcbCoordinate.optional(),pcbY:pcbCoordinate.optional(),pcbLeftEdgeX:pcbCoordinate.optional(),pcbRightEdgeX:pcbCoordinate.optional(),pcbTopEdgeY:pcbCoordinate.optional(),pcbBottomEdgeY:pcbCoordinate.optional(),pcbOffsetX:distance.optional(),pcbOffsetY:distance.optional(),pcbRotation:rotation.optional(),pcbPositionAnchor:external_exports.string().optional(),pcbPositionMode:external_exports.enum(["relative_to_group_anchor","auto","relative_to_board_anchor","relative_to_component_anchor"]).optional(),pcbMarginTop:distance.optional(),pcbMarginRight:distance.optional(),pcbMarginBottom:distance.optional(),pcbMarginLeft:distance.optional(),pcbMarginX:distance.optional(),pcbMarginY:distance.optional(),pcbStyle:pcbStyle.optional(),schMarginTop:distance.optional(),schMarginRight:distance.optional(),schMarginBottom:distance.optional(),schMarginLeft:distance.optional(),schMarginX:distance.optional(),schMarginY:distance.optional(),schX:distance.optional(),schY:distance.optional(),schRotation:rotation.optional(),layer:layer_ref.optional(),footprint:footprintProp.optional(),symbol:symbolProp.optional(),schStyle:schStyle.optional(),relative:external_exports.boolean().optional(),schRelative:external_exports.boolean().optional(),pcbRelative:external_exports.boolean().optional()});expectTypesMatch2(!0);var supplierProps=external_exports.object({supplierPartNumbers:external_exports.record(supplier_name,external_exports.array(external_exports.string())).optional()});expectTypesMatch2(!0);var pinAttributeMap=external_exports.object({providesPower:external_exports.boolean().optional(),requiresPower:external_exports.boolean().optional(),providesGround:external_exports.boolean().optional(),requiresGround:external_exports.boolean().optional(),providesVoltage:external_exports.union([external_exports.string(),external_exports.number()]).optional(),requiresVoltage:external_exports.union([external_exports.string(),external_exports.number()]).optional(),doNotConnect:external_exports.boolean().optional(),includeInBoardPinout:external_exports.boolean().optional(),highlightColor:external_exports.string().optional(),mustBeConnected:external_exports.boolean().optional()});expectTypesMatch2(!0);var commonComponentProps=commonLayoutProps.merge(supplierProps).extend({key:external_exports.any().optional(),name:external_exports.string(),cadModel:cadModelProp.optional(),children:external_exports.any().optional(),symbolName:external_exports.string().optional(),doNotPlace:external_exports.boolean().optional(),obstructsWithinBounds:external_exports.boolean().optional().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"),showAsTranslucentModel:external_exports.boolean().optional().describe("Whether to show this component's CAD model as translucent in the 3D viewer."),pinAttributes:external_exports.record(external_exports.string(),pinAttributeMap).optional()});expectTypesMatch2(!0);var lrPins=["pin1","left","pin2","right"],lrPolarPins=["pin1","left","anode","pos","pin2","right","cathode","neg"],distanceOrMultiplier=distance.or(external_exports.enum(["2x","3x","4x"]));var schematicOrientation=external_exports.enum(["vertical","horizontal","pos_top","pos_bottom","pos_left","pos_right","neg_top","neg_bottom","neg_left","neg_right"]).describe("horizontal means pins go 1->2 rightward and vertical means pins go 1->2 downward (generally, positive on top)");expectTypesMatch2(!0);var explicitPinSideDefinition=external_exports.object({pins:external_exports.array(external_exports.union([external_exports.number(),external_exports.string()])),direction:external_exports.union([external_exports.literal("top-to-bottom"),external_exports.literal("left-to-right"),external_exports.literal("bottom-to-top"),external_exports.literal("right-to-left")])}),schematicPortArrangement=external_exports.object({leftSize:external_exports.number().optional().describe("@deprecated, use leftPinCount"),topSize:external_exports.number().optional().describe("@deprecated, use topPinCount"),rightSize:external_exports.number().optional().describe("@deprecated, use rightPinCount"),bottomSize:external_exports.number().optional().describe("@deprecated, use bottomPinCount"),leftPinCount:external_exports.number().optional(),rightPinCount:external_exports.number().optional(),topPinCount:external_exports.number().optional(),bottomPinCount:external_exports.number().optional(),leftSide:explicitPinSideDefinition.optional(),rightSide:explicitPinSideDefinition.optional(),topSide:explicitPinSideDefinition.optional(),bottomSide:explicitPinSideDefinition.optional()}),schematicPinArrangement=schematicPortArrangement;expectTypesMatch2(!0);var schematicPinStyle=external_exports.record(external_exports.object({marginLeft:distance.optional(),marginRight:distance.optional(),marginTop:distance.optional(),marginBottom:distance.optional(),leftMargin:distance.optional(),rightMargin:distance.optional(),topMargin:distance.optional(),bottomMargin:distance.optional()}));expectTypesMatch2(!0);var schematicPinLabel=external_exports.string().regex(/^[A-Za-z0-9_]+$/),schematicSymbolSize=distance.or(external_exports.enum(["xs","sm","default","md"])).describe("distance between pin1 and pin2 of the schematic symbol"),ninePointAnchor2=external_exports.enum(["top_left","top_center","top_right","center_left","center","center_right","bottom_left","bottom_center","bottom_right"]),point2=external_exports.object({x:distance,y:distance}),base_manual_edit_event=external_exports.object({edit_event_id:external_exports.string(),in_progress:external_exports.boolean().optional(),created_at:external_exports.number()});expectTypesMatch2(!0);var edit_pcb_component_location_event=base_manual_edit_event.extend({pcb_edit_event_type:external_exports.literal("edit_component_location").describe("deprecated"),edit_event_type:external_exports.literal("edit_pcb_component_location"),pcb_component_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var edit_trace_hint_event=base_manual_edit_event.extend({pcb_edit_event_type:external_exports.literal("edit_trace_hint").describe("deprecated"),edit_event_type:external_exports.literal("edit_pcb_trace_hint").optional(),pcb_port_id:external_exports.string(),pcb_trace_hint_id:external_exports.string().optional(),route:external_exports.array(external_exports.object({x:external_exports.number(),y:external_exports.number(),via:external_exports.boolean().optional()}))});expectTypesMatch2(!0);var edit_schematic_component_location_event=base_manual_edit_event.extend({edit_event_type:external_exports.literal("edit_schematic_component_location"),schematic_component_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var edit_pcb_group_location_event=base_manual_edit_event.extend({edit_event_type:external_exports.literal("edit_pcb_group_location"),pcb_group_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var edit_schematic_group_location_event=base_manual_edit_event.extend({edit_event_type:external_exports.literal("edit_schematic_group_location"),schematic_group_id:external_exports.string(),original_center:external_exports.object({x:external_exports.number(),y:external_exports.number()}),new_center:external_exports.object({x:external_exports.number(),y:external_exports.number()})});expectTypesMatch2(!0);var manual_edit_event=external_exports.union([edit_pcb_component_location_event,edit_trace_hint_event,edit_schematic_component_location_event]);expectTypesMatch2(!0);var manual_pcb_placement=external_exports.object({selector:external_exports.string(),relative_to:external_exports.string().optional().default("group_center").describe("Can be a selector or 'group_center'"),center:point});expectTypesMatch2(!0);var manual_trace_hint=external_exports.object({pcb_port_selector:external_exports.string(),offsets:external_exports.array(route_hint_point)});expectTypesMatch2(!0);var manual_schematic_placement=external_exports.object({selector:external_exports.string(),relative_to:external_exports.string().optional().default("group_center").describe("Can be a selector or 'group_center'"),center:point});expectTypesMatch2(!0);var manual_edits_file=external_exports.object({pcb_placements:external_exports.array(manual_pcb_placement).optional(),manual_trace_hints:external_exports.array(manual_trace_hint).optional(),schematic_placements:external_exports.array(manual_schematic_placement).optional()});expectTypesMatch2(!0);var connectionTarget=external_exports.string().or(external_exports.array(external_exports.string()).readonly()).or(external_exports.array(external_exports.string())),createConnectionsProp=labels=>external_exports.record(external_exports.enum(labels),connectionTarget),layoutConfig=external_exports.object({layoutMode:external_exports.enum(["grid","flex","match-adapt","relative","none"]).optional(),position:external_exports.enum(["absolute","relative"]).optional(),grid:external_exports.boolean().optional(),gridCols:external_exports.number().or(external_exports.string()).optional(),gridRows:external_exports.number().or(external_exports.string()).optional(),gridTemplateRows:external_exports.string().optional(),gridTemplateColumns:external_exports.string().optional(),gridTemplate:external_exports.string().optional(),gridGap:external_exports.number().or(external_exports.string()).optional(),gridRowGap:external_exports.number().or(external_exports.string()).optional(),gridColumnGap:external_exports.number().or(external_exports.string()).optional(),flex:external_exports.boolean().or(external_exports.string()).optional(),flexDirection:external_exports.enum(["row","column"]).optional(),alignItems:external_exports.enum(["start","center","end","stretch"]).optional(),justifyContent:external_exports.enum(["start","center","end","stretch","space-between","space-around","space-evenly"]).optional(),flexRow:external_exports.boolean().optional(),flexColumn:external_exports.boolean().optional(),gap:external_exports.number().or(external_exports.string()).optional(),pack:external_exports.boolean().optional().describe("Pack the contents of this group using a packing strategy"),packOrderStrategy:external_exports.enum(["largest_to_smallest","first_to_last","highest_to_lowest_pin_count"]).optional(),packPlacementStrategy:external_exports.enum(["shortest_connection_along_outline"]).optional(),padding:length.optional(),paddingLeft:length.optional(),paddingRight:length.optional(),paddingTop:length.optional(),paddingBottom:length.optional(),paddingX:length.optional(),paddingY:length.optional(),width:length.optional(),height:length.optional(),matchAdapt:external_exports.boolean().optional(),matchAdaptTemplate:external_exports.any().optional()});expectTypesMatch2(!0);var border=external_exports.object({strokeWidth:length.optional(),dashed:external_exports.boolean().optional(),solid:external_exports.boolean().optional()}),pcbAnchorAlignmentAutocomplete=external_exports.custom(value=>typeof value=="string"),autorouterConfig=external_exports.object({serverUrl:external_exports.string().optional(),inputFormat:external_exports.enum(["simplified","circuit-json"]).optional(),serverMode:external_exports.enum(["job","solve-endpoint"]).optional(),serverCacheEnabled:external_exports.boolean().optional(),cache:external_exports.custom(v4=>!0).optional(),traceClearance:length.optional(),groupMode:external_exports.enum(["sequential_trace","subcircuit","sequential-trace"]).optional(),algorithmFn:external_exports.custom(v4=>typeof v4=="function"||v4===void 0).optional(),preset:external_exports.enum(["sequential_trace","subcircuit","auto","auto_local","auto_cloud","auto_jumper","tscircuit_beta","freerouting","laser_prefab","auto-jumper","sequential-trace","auto-local","auto-cloud"]).optional(),local:external_exports.boolean().optional()}),autorouterPreset=external_exports.union([external_exports.literal("sequential_trace"),external_exports.literal("subcircuit"),external_exports.literal("auto"),external_exports.literal("auto_local"),external_exports.literal("auto_cloud"),external_exports.literal("auto_jumper"),external_exports.literal("tscircuit_beta"),external_exports.literal("freerouting"),external_exports.literal("laser_prefab"),external_exports.literal("auto-jumper"),external_exports.literal("sequential-trace"),external_exports.literal("auto-local"),external_exports.literal("auto-cloud")]),autorouterString=external_exports.string(),autorouterProp=external_exports.union([autorouterConfig,autorouterPreset,autorouterString]),autorouterEffortLevel=external_exports.enum(["1x","2x","5x","10x","100x"]),baseGroupProps=commonLayoutProps.extend({name:external_exports.string().optional(),children:external_exports.any().optional(),schTitle:external_exports.string().optional(),key:external_exports.any().optional(),showAsSchematicBox:external_exports.boolean().optional(),connections:external_exports.record(external_exports.string(),connectionTarget.optional()).optional(),schPinArrangement:schematicPinArrangement.optional(),schPinSpacing:length.optional(),schPinStyle:schematicPinStyle.optional(),...layoutConfig.shape,grid:layoutConfig.shape.grid.describe("@deprecated use pcbGrid"),flex:layoutConfig.shape.flex.describe("@deprecated use pcbFlex"),pcbGrid:external_exports.boolean().optional(),pcbGridCols:external_exports.number().or(external_exports.string()).optional(),pcbGridRows:external_exports.number().or(external_exports.string()).optional(),pcbGridTemplateRows:external_exports.string().optional(),pcbGridTemplateColumns:external_exports.string().optional(),pcbGridTemplate:external_exports.string().optional(),pcbGridGap:external_exports.number().or(external_exports.string()).optional(),pcbGridRowGap:external_exports.number().or(external_exports.string()).optional(),pcbGridColumnGap:external_exports.number().or(external_exports.string()).optional(),pcbFlex:external_exports.boolean().or(external_exports.string()).optional(),pcbFlexGap:external_exports.number().or(external_exports.string()).optional(),pcbFlexDirection:external_exports.enum(["row","column"]).optional(),pcbAlignItems:external_exports.enum(["start","center","end","stretch"]).optional(),pcbJustifyContent:external_exports.enum(["start","center","end","stretch","space-between","space-around","space-evenly"]).optional(),pcbFlexRow:external_exports.boolean().optional(),pcbFlexColumn:external_exports.boolean().optional(),pcbGap:external_exports.number().or(external_exports.string()).optional(),pcbPack:external_exports.boolean().optional(),pcbPackGap:external_exports.number().or(external_exports.string()).optional(),schGrid:external_exports.boolean().optional(),schGridCols:external_exports.number().or(external_exports.string()).optional(),schGridRows:external_exports.number().or(external_exports.string()).optional(),schGridTemplateRows:external_exports.string().optional(),schGridTemplateColumns:external_exports.string().optional(),schGridTemplate:external_exports.string().optional(),schGridGap:external_exports.number().or(external_exports.string()).optional(),schGridRowGap:external_exports.number().or(external_exports.string()).optional(),schGridColumnGap:external_exports.number().or(external_exports.string()).optional(),schFlex:external_exports.boolean().or(external_exports.string()).optional(),schFlexGap:external_exports.number().or(external_exports.string()).optional(),schFlexDirection:external_exports.enum(["row","column"]).optional(),schAlignItems:external_exports.enum(["start","center","end","stretch"]).optional(),schJustifyContent:external_exports.enum(["start","center","end","stretch","space-between","space-around","space-evenly"]).optional(),schFlexRow:external_exports.boolean().optional(),schFlexColumn:external_exports.boolean().optional(),schGap:external_exports.number().or(external_exports.string()).optional(),schPack:external_exports.boolean().optional(),schMatchAdapt:external_exports.boolean().optional(),pcbWidth:length.optional(),pcbHeight:length.optional(),minTraceWidth:length.optional(),nominalTraceWidth:length.optional(),schWidth:length.optional(),schHeight:length.optional(),pcbLayout:layoutConfig.optional(),schLayout:layoutConfig.optional(),cellBorder:border.nullable().optional(),border:border.nullable().optional(),schPadding:length.optional(),schPaddingLeft:length.optional(),schPaddingRight:length.optional(),schPaddingTop:length.optional(),schPaddingBottom:length.optional(),pcbPadding:length.optional(),pcbPaddingLeft:length.optional(),pcbPaddingRight:length.optional(),pcbPaddingTop:length.optional(),pcbPaddingBottom:length.optional(),pcbAnchorAlignment:pcbAnchorAlignmentAutocomplete.optional()}),partsEngine=external_exports.custom(v4=>"findPart"in v4),subcircuitGroupProps=baseGroupProps.extend({manualEdits:manual_edits_file.optional(),schAutoLayoutEnabled:external_exports.boolean().optional(),schTraceAutoLabelEnabled:external_exports.boolean().optional(),schMaxTraceDistance:distance.optional(),routingDisabled:external_exports.boolean().optional(),bomDisabled:external_exports.boolean().optional(),defaultTraceWidth:length.optional(),minTraceWidth:length.optional(),nominalTraceWidth:length.optional(),partsEngine:partsEngine.optional(),pcbRouteCache:external_exports.custom(v4=>!0).optional(),autorouter:autorouterProp.optional(),autorouterEffortLevel:autorouterEffortLevel.optional(),autorouterVersion:external_exports.enum(["v1","v2","latest"]).optional(),square:external_exports.boolean().optional(),emptyArea:external_exports.string().optional(),filledArea:external_exports.string().optional(),width:distance.optional(),height:distance.optional(),outline:external_exports.array(point2).optional(),outlineOffsetX:distance.optional(),outlineOffsetY:distance.optional(),circuitJson:external_exports.array(external_exports.any()).optional()}),subcircuitGroupPropsWithBool=subcircuitGroupProps.extend({subcircuit:external_exports.literal(!0)}),groupProps=external_exports.discriminatedUnion("subcircuit",[baseGroupProps.extend({subcircuit:external_exports.literal(!1).optional()}),subcircuitGroupPropsWithBool]);expectTypesMatch2(!0);expectTypesMatch2(!0);expectTypesMatch2(!0);expectTypesMatch2(!0);var boardColor=external_exports.custom(value=>typeof value=="string"),boardProps=subcircuitGroupProps.omit({connections:!0}).extend({material:external_exports.enum(["fr4","fr1"]).default("fr4"),layers:external_exports.union([external_exports.literal(1),external_exports.literal(2),external_exports.literal(4),external_exports.literal(6),external_exports.literal(8)]).default(2),borderRadius:distance3.optional(),thickness:distance3.optional(),boardAnchorPosition:point2.optional(),anchorAlignment:ninePointAnchor2.optional(),boardAnchorAlignment:ninePointAnchor2.optional().describe("Prefer using anchorAlignment when possible"),title:external_exports.string().optional(),solderMaskColor:boardColor.optional(),topSolderMaskColor:boardColor.optional(),bottomSolderMaskColor:boardColor.optional(),silkscreenColor:boardColor.optional(),topSilkscreenColor:boardColor.optional(),bottomSilkscreenColor:boardColor.optional(),doubleSidedAssembly:external_exports.boolean().optional().default(!1),schematicDisabled:external_exports.boolean().optional()});expectTypesMatch2(!0);var panelProps=baseGroupProps.omit({width:!0,height:!0,layoutMode:!0,children:!0}).extend({width:distance3.optional(),height:distance3.optional(),children:external_exports.any().optional(),anchorAlignment:ninePointAnchor2.optional(),noSolderMask:external_exports.boolean().optional(),panelizationMethod:external_exports.enum(["tab-routing","none"]).optional(),boardGap:distance3.optional(),layoutMode:external_exports.enum(["grid","pack","none"]).optional(),row:external_exports.number().optional(),col:external_exports.number().optional(),cellWidth:distance3.optional(),cellHeight:distance3.optional(),tabWidth:distance3.optional(),tabLength:distance3.optional(),mouseBites:external_exports.boolean().optional(),edgePadding:distance3.optional(),edgePaddingLeft:distance3.optional(),edgePaddingRight:distance3.optional(),edgePaddingTop:distance3.optional(),edgePaddingBottom:distance3.optional()});expectTypesMatch2(!0);expectTypesMatch2(!0);var breakoutProps=subcircuitGroupProps.extend({padding:distance.optional(),paddingLeft:distance.optional(),paddingRight:distance.optional(),paddingTop:distance.optional(),paddingBottom:distance.optional()});expectTypesMatch2(!0);var connectionTarget2=external_exports.string().or(external_exports.array(external_exports.string()).readonly()).or(external_exports.array(external_exports.string())),connectionsProp=external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget2)),pinLabelsProp=external_exports.record(schematicPinLabel,schematicPinLabel.or(external_exports.array(schematicPinLabel).readonly()).or(external_exports.array(schematicPinLabel)));expectTypesMatch2(!0);var pinCompatibleVariant=external_exports.object({manufacturerPartNumber:external_exports.string().optional(),supplierPartNumber:external_exports.record(supplier_name,external_exports.array(external_exports.string())).optional()}),chipProps=commonComponentProps.extend({manufacturerPartNumber:external_exports.string().optional(),pinLabels:pinLabelsProp.optional(),showPinAliases:external_exports.boolean().optional(),pcbPinLabels:external_exports.record(external_exports.string(),external_exports.string()).optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional(),externallyConnectedPins:external_exports.array(external_exports.array(external_exports.string())).optional(),schPinArrangement:schematicPortArrangement.optional(),schPortArrangement:schematicPortArrangement.optional(),pinCompatibleVariants:external_exports.array(pinCompatibleVariant).optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional(),noSchematicRepresentation:external_exports.boolean().optional(),connections:connectionsProp.optional()});expectTypesMatch2(!0);var pinoutProps=chipProps;expectTypesMatch2(!0);var jumperProps=commonComponentProps.extend({manufacturerPartNumber:external_exports.string().optional(),pinLabels:external_exports.record(external_exports.number().or(schematicPinLabel),schematicPinLabel.or(external_exports.array(schematicPinLabel))).optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional(),schDirection:external_exports.enum(["left","right"]).optional(),schPinArrangement:schematicPinArrangement.optional(),schPortArrangement:schematicPortArrangement.optional(),pcbPinLabels:external_exports.record(external_exports.string(),external_exports.string()).optional(),pinCount:external_exports.union([external_exports.literal(2),external_exports.literal(3)]).optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional(),connections:external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget)).optional()});expectTypesMatch2(!0);var solderjumperProps=jumperProps.extend({bridgedPins:external_exports.array(external_exports.array(external_exports.string())).optional(),bridged:external_exports.boolean().optional()});expectTypesMatch2(!0);var connectorProps=commonComponentProps.extend({manufacturerPartNumber:external_exports.string().optional(),pinLabels:external_exports.record(external_exports.number().or(schematicPinLabel),schematicPinLabel.or(external_exports.array(schematicPinLabel))).optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional(),schDirection:external_exports.enum(["left","right"]).optional(),schPortArrangement:schematicPortArrangement.optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional(),standard:external_exports.enum(["usb_c","m2"]).optional()});expectTypesMatch2(!0);var interconnectProps=commonComponentProps.extend({standard:external_exports.enum(["TSC0001_36P_XALT_2025_11","0805","0603","1206"]).optional(),pinLabels:external_exports.record(external_exports.number().or(schematicPinLabel),schematicPinLabel.or(external_exports.array(schematicPinLabel))).optional(),internallyConnectedPins:external_exports.array(external_exports.array(external_exports.union([external_exports.string(),external_exports.number()]))).optional()});expectTypesMatch2(!0);var fuseProps=commonComponentProps.extend({currentRating:external_exports.union([external_exports.number(),external_exports.string()]),voltageRating:external_exports.union([external_exports.number(),external_exports.string()]).optional(),schShowRatings:external_exports.boolean().optional(),schOrientation:schematicOrientation.optional(),connections:external_exports.record(external_exports.string(),external_exports.union([external_exports.string(),external_exports.array(external_exports.string()).readonly(),external_exports.array(external_exports.string())])).optional()}),distanceHiddenUndefined=external_exports.custom().transform(a2=>{if(a2!==void 0)return distance.parse(a2)}),platedHoleProps=external_exports.discriminatedUnion("shape",[pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("circle"),holeDiameter:distance,outerDiameter:distance,padDiameter:distance.optional().describe("Diameter of the copper pad"),portHints:portHints.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("oval"),outerWidth:distance,outerHeight:distance,holeWidth:distanceHiddenUndefined,holeHeight:distanceHiddenUndefined,innerWidth:distance.optional().describe("DEPRECATED use holeWidth"),innerHeight:distance.optional().describe("DEPRECATED use holeHeight"),portHints:portHints.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("pill"),rectPad:external_exports.boolean().optional(),outerWidth:distance,outerHeight:distance,holeWidth:distanceHiddenUndefined,holeHeight:distanceHiddenUndefined,innerWidth:distance.optional().describe("DEPRECATED use holeWidth"),innerHeight:distance.optional().describe("DEPRECATED use holeHeight"),portHints:portHints.optional(),holeOffsetX:distance.optional(),holeOffsetY:distance.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("circular_hole_with_rect_pad"),holeDiameter:distance,rectPadWidth:distance,rectPadHeight:distance,rectBorderRadius:distance.optional(),holeShape:external_exports.literal("circle").optional(),padShape:external_exports.literal("rect").optional(),portHints:portHints.optional(),holeOffsetX:distance.optional(),holeOffsetY:distance.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("pill_hole_with_rect_pad"),holeShape:external_exports.literal("pill").optional(),padShape:external_exports.literal("rect").optional(),holeWidth:distance,holeHeight:distance,rectPadWidth:distance,rectPadHeight:distance,portHints:portHints.optional(),holeOffsetX:distance.optional(),holeOffsetY:distance.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),shape:external_exports.literal("hole_with_polygon_pad"),holeShape:external_exports.enum(["circle","oval","pill","rotated_pill"]),holeDiameter:distance.optional(),holeWidth:distance.optional(),holeHeight:distance.optional(),padOutline:external_exports.array(point2),holeOffsetX:distance,holeOffsetY:distance,portHints:portHints.optional(),solderMaskMargin:distance.optional(),coveredWithSolderMask:external_exports.boolean().optional()})]).refine(a2=>("innerWidth"in a2&&a2.innerWidth!==void 0&&(a2.holeWidth??(a2.holeWidth=a2.innerWidth)),"innerHeight"in a2&&a2.innerHeight!==void 0&&(a2.holeHeight??(a2.holeHeight=a2.innerHeight)),a2));expectTypesMatch2(!0);var resistorPinLabels=["pin1","pin2","pos","neg"],resistorProps=commonComponentProps.extend({resistance,pullupFor:external_exports.string().optional(),pullupTo:external_exports.string().optional(),pulldownFor:external_exports.string().optional(),pulldownTo:external_exports.string().optional(),schOrientation:schematicOrientation.optional(),schSize:schematicSymbolSize.optional(),connections:createConnectionsProp(resistorPinLabels).optional()}),resistorPins=lrPins;expectTypesMatch2(!0);var potentiometerProps=commonComponentProps.extend({maxResistance:resistance,pinVariant:external_exports.enum(["two_pin","three_pin"]).optional()});expectTypesMatch2(!0);var crystalPins=lrPins,crystalProps=commonComponentProps.extend({frequency,loadCapacitance:capacitance,manufacturerPartNumber:external_exports.string().optional(),mpn:external_exports.string().optional(),pinVariant:external_exports.enum(["two_pin","four_pin"]).optional(),schOrientation:schematicOrientation.optional(),connections:createConnectionsProp(crystalPins).optional()});expectTypesMatch2(!0);var resonatorProps=commonComponentProps.extend({frequency,loadCapacitance:capacitance,pinVariant:external_exports.enum(["no_ground","ground_pin","two_ground_pins"]).optional()});expectTypesMatch2(!0);var stampboardProps=boardProps.extend({leftPinCount:external_exports.number().optional(),rightPinCount:external_exports.number().optional(),topPinCount:external_exports.number().optional(),bottomPinCount:external_exports.number().optional(),leftPins:external_exports.array(external_exports.string()).optional(),rightPins:external_exports.array(external_exports.string()).optional(),topPins:external_exports.array(external_exports.string()).optional(),bottomPins:external_exports.array(external_exports.string()).optional(),pinPitch:distance.optional(),innerHoles:external_exports.boolean().optional()});expectTypesMatch2(!0);var capacitorPinLabels=["pin1","pin2","pos","neg","anode","cathode"],capacitorProps=commonComponentProps.extend({capacitance,maxVoltageRating:voltage.optional(),schShowRatings:external_exports.boolean().optional().default(!1),polarized:external_exports.boolean().optional().default(!1),decouplingFor:external_exports.string().optional(),decouplingTo:external_exports.string().optional(),bypassFor:external_exports.string().optional(),bypassTo:external_exports.string().optional(),maxDecouplingTraceLength:external_exports.number().optional(),schOrientation:schematicOrientation.optional(),schSize:schematicSymbolSize.optional(),connections:createConnectionsProp(capacitorPinLabels).optional()}),capacitorPins=lrPolarPins;expectTypesMatch2(!0);var netProps=external_exports.object({name:external_exports.string(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),highlightColor:external_exports.string().optional(),isPowerNet:external_exports.boolean().optional(),isGroundNet:external_exports.boolean().optional()});expectTypesMatch2(!0);var fiducialProps=commonComponentProps.extend({soldermaskPullback:distance3.optional(),padDiameter:distance3.optional()});expectTypesMatch2(!0);var constrainedLayoutProps=external_exports.object({name:external_exports.string().optional(),pcbOnly:external_exports.boolean().optional(),schOnly:external_exports.boolean().optional()});expectTypesMatch2(!0);var pcbXDistConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),xDist:distance3,left:external_exports.string(),right:external_exports.string(),edgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var pcbYDistConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),yDist:distance3,top:external_exports.string(),bottom:external_exports.string(),edgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var pcbSameYConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),sameY:external_exports.literal(!0).optional(),for:external_exports.array(external_exports.string())});expectTypesMatch2(!0);var pcbSameXConstraintProps=external_exports.object({pcb:external_exports.literal(!0).optional(),sameX:external_exports.literal(!0).optional(),for:external_exports.array(external_exports.string())});expectTypesMatch2(!0);var constraintProps=external_exports.union([pcbXDistConstraintProps,pcbYDistConstraintProps,pcbSameYConstraintProps,pcbSameXConstraintProps]);expectTypesMatch2(!0);var rectCutoutProps=pcbLayoutProps.omit({layer:!0,pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("rect"),width:distance3,height:distance3});expectTypesMatch2(!0);var circleCutoutProps=pcbLayoutProps.omit({layer:!0,pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("circle"),radius:distance3});expectTypesMatch2(!0);var polygonCutoutProps=pcbLayoutProps.omit({layer:!0,pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("polygon"),points:external_exports.array(point2)});expectTypesMatch2(!0);var cutoutProps=external_exports.discriminatedUnion("shape",[rectCutoutProps,circleCutoutProps,polygonCutoutProps]),rectSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("rect"),width:distance3,height:distance3,rectBorderRadius:distance3.optional(),cornerRadius:distance3.optional(),portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var rotatedRectSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("rotated_rect"),width:distance3,height:distance3,ccwRotation:external_exports.number(),cornerRadius:distance3.optional(),portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var circleSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("circle"),radius:distance3,portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var pillSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("pill"),width:distance3,height:distance3,radius:distance3,portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var polygonSmtPadProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({name:external_exports.string().optional(),shape:external_exports.literal("polygon"),points:external_exports.array(point2),portHints:portHints.optional(),coveredWithSolderMask:external_exports.boolean().optional(),solderMaskMargin:distance3.optional()});expectTypesMatch2(!0);var smtPadProps=external_exports.discriminatedUnion("shape",[circleSmtPadProps,rectSmtPadProps,rotatedRectSmtPadProps,pillSmtPadProps,polygonSmtPadProps]);expectTypesMatch2(!0);var rectSolderPasteProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({shape:external_exports.literal("rect"),width:distance3,height:distance3});expectTypesMatch2(!0);var circleSolderPasteProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({shape:external_exports.literal("circle"),radius:distance3});expectTypesMatch2(!0);var solderPasteProps=external_exports.union([circleSolderPasteProps,rectSolderPasteProps]);expectTypesMatch2(!0);var circleHoleProps=pcbLayoutProps.extend({name:external_exports.string().optional(),shape:external_exports.literal("circle").optional(),diameter:distance3.optional(),radius:distance3.optional(),solderMaskMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional()}).transform(d3=>({...d3,diameter:d3.diameter??2*d3.radius,radius:d3.radius??d3.diameter/2})),pillHoleProps=pcbLayoutProps.extend({name:external_exports.string().optional(),shape:external_exports.literal("pill"),width:distance3,height:distance3,solderMaskMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),rectHoleProps=pcbLayoutProps.extend({name:external_exports.string().optional(),shape:external_exports.literal("rect"),width:distance3,height:distance3,solderMaskMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional()}),holeProps=external_exports.union([circleHoleProps,pillHoleProps,rectHoleProps]);expectTypesMatch2(!0);var portRef=external_exports.union([external_exports.string(),external_exports.custom(v4=>!!v4.getPortSelector)]),pcbPath=external_exports.array(external_exports.union([point2,external_exports.string()])),baseTraceProps=external_exports.object({key:external_exports.string().optional(),thickness:distance.optional(),width:distance.optional().describe("Alias for trace thickness"),schematicRouteHints:external_exports.array(point2).optional(),pcbRouteHints:external_exports.array(route_hint_point).optional(),pcbPathRelativeTo:external_exports.string().optional(),pcbPath:pcbPath.optional(),pcbPaths:external_exports.array(pcbPath).optional(),pcbStraightLine:external_exports.boolean().optional().describe("Draw a straight pcb trace between the connected points"),schDisplayLabel:external_exports.string().optional(),schStroke:external_exports.string().optional(),highlightColor:external_exports.string().optional(),maxLength:distance.optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional()}),traceProps=external_exports.union([baseTraceProps.extend({path:external_exports.array(portRef)}),baseTraceProps.extend({from:portRef,to:portRef})]),footprintProps=external_exports.object({children:external_exports.any().optional(),originalLayer:layer_ref.default("top").optional(),circuitJson:external_exports.array(external_exports.any()).optional()});expectTypesMatch2(!0);var symbolProps=external_exports.object({originalFacingDirection:external_exports.enum(["up","down","left","right"]).default("right").optional()});expectTypesMatch2(!0);var capacity=external_exports.number().or(external_exports.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"),batteryProps=commonComponentProps.extend({capacity:capacity.optional(),voltage:voltage.optional(),standard:external_exports.enum(["AA","AAA","9V","CR2032","18650","C"]).optional(),schOrientation:schematicOrientation.optional()});expectTypesMatch2(!0);var pcbOrientation=external_exports.enum(["vertical","horizontal"]).describe("vertical means pins go 1->2 downward and horizontal means pins go 1->2 rightward");expectTypesMatch2(!0);var pinHeaderProps=commonComponentProps.extend({pinCount:external_exports.number(),pitch:distance.optional(),schFacingDirection:external_exports.enum(["up","down","left","right"]).optional(),gender:external_exports.enum(["male","female","unpopulated"]).optional().default("male"),showSilkscreenPinLabels:external_exports.boolean().optional(),pcbPinLabels:external_exports.record(external_exports.string(),external_exports.string()).optional(),doubleRow:external_exports.boolean().optional(),rightAngle:external_exports.boolean().optional(),pcbOrientation:pcbOrientation.optional(),holeDiameter:distance.optional(),platedDiameter:distance.optional(),pinLabels:external_exports.record(external_exports.string(),schematicPinLabel).or(external_exports.array(schematicPinLabel)).optional(),connections:external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget)).optional(),facingDirection:external_exports.enum(["left","right"]).optional(),schPinArrangement:schematicPinArrangement.optional(),schPinStyle:schematicPinStyle.optional(),schPinSpacing:distance.optional(),schWidth:distance.optional(),schHeight:distance.optional()});expectTypesMatch2(!0);var netAliasProps=external_exports.object({net:external_exports.string().optional(),connection:external_exports.string().optional(),schX:distance3.optional(),schY:distance3.optional(),schRotation:rotation.optional(),anchorSide:external_exports.enum(["left","top","right","bottom"]).optional()});expectTypesMatch2(!0);var netLabelProps=external_exports.object({net:external_exports.string().optional(),connection:external_exports.string().optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),schX:distance3.optional(),schY:distance3.optional(),schRotation:rotation.optional(),anchorSide:external_exports.enum(["left","top","right","bottom"]).optional()});expectTypesMatch2(!0);var pushButtonProps=chipProps.extend({});expectTypesMatch2(!0);expectTypesMatch2(!0);var spiceEngine=external_exports.custom(value=>typeof value=="string"),analogSimulationProps=external_exports.object({simulationType:external_exports.literal("spice_transient_analysis").default("spice_transient_analysis"),duration:ms.optional(),timePerStep:ms.optional(),spiceEngine:spiceEngine.optional()});expectTypesMatch2(!0);var transistorPinsLabels=["pin1","pin2","pin3","emitter","collector","base","gate","source","drain"],transistorProps=commonComponentProps.extend({type:external_exports.enum(["npn","pnp","bjt","jfet","mosfet","igbt"]),connections:createConnectionsProp(transistorPinsLabels).optional()});expectTypesMatch2(!0);var mosfetProps=commonComponentProps.extend({channelType:external_exports.enum(["n","p"]),mosfetMode:external_exports.enum(["enhancement","depletion"])});expectTypesMatch2(!0);var opampPinLabels=["inverting_input","non_inverting_input","output","positive_supply","negative_supply"],opampProps=commonComponentProps.extend({connections:createConnectionsProp(opampPinLabels).optional()});expectTypesMatch2(!0);var inductorPins=lrPins,inductorProps=commonComponentProps.extend({inductance,maxCurrentRating:external_exports.union([external_exports.string(),external_exports.number()]).optional(),schOrientation:schematicOrientation.optional(),connections:createConnectionsProp(inductorPins).optional()});expectTypesMatch2(!0);var diodeConnectionKeys=external_exports.enum(["anode","cathode","pin1","pin2","pos","neg"]),connectionTarget3=external_exports.string().or(external_exports.array(external_exports.string()).readonly()).or(external_exports.array(external_exports.string())),connectionsProp2=external_exports.record(diodeConnectionKeys,connectionTarget3),diodeVariant=external_exports.enum(["standard","schottky","zener","avalanche","photo","tvs"]),diodeProps=commonComponentProps.extend({connections:connectionsProp2.optional(),variant:diodeVariant.optional().default("standard"),standard:external_exports.boolean().optional(),schottky:external_exports.boolean().optional(),zener:external_exports.boolean().optional(),avalanche:external_exports.boolean().optional(),photo:external_exports.boolean().optional(),tvs:external_exports.boolean().optional(),schOrientation:schematicOrientation.optional()}).superRefine((data,ctx)=>{if([data.standard,data.schottky,data.zener,data.avalanche,data.photo,data.tvs].filter(Boolean).length>1)return ctx.addIssue({code:external_exports.ZodIssueCode.custom,message:"Exactly one diode variant must be enabled",path:[]}),external_exports.INVALID}).transform(data=>{let result={...data,standard:!1,schottky:!1,zener:!1,avalanche:!1,photo:!1,tvs:!1};if(data.standard)result.standard=!0;else if(data.schottky)result.schottky=!0;else if(data.zener)result.zener=!0;else if(data.photo)result.photo=!0;else if(data.tvs)result.tvs=!0;else switch(data.variant){case"standard":result.standard=!0;break;case"schottky":result.schottky=!0;break;case"zener":result.zener=!0;break;case"avalanche":result.avalanche=!0;break;case"photo":result.photo=!0;break;case"tvs":result.tvs=!0;break;default:result.standard=!0}return result}),diodePins=lrPolarPins;expectTypesMatch2(!0);var ledProps=commonComponentProps.extend({color:external_exports.string().optional(),wavelength:external_exports.string().optional(),schDisplayValue:external_exports.string().optional(),schOrientation:schematicOrientation.optional(),connections:createConnectionsProp(lrPolarPins).optional(),laser:external_exports.boolean().optional()}),ledPins=lrPolarPins,switchProps=commonComponentProps.extend({type:external_exports.enum(["spst","spdt","dpst","dpdt"]).optional(),isNormallyClosed:external_exports.boolean().optional().default(!1),spst:external_exports.boolean().optional(),spdt:external_exports.boolean().optional(),dpst:external_exports.boolean().optional(),dpdt:external_exports.boolean().optional(),simSwitchFrequency:frequency.optional(),simCloseAt:ms.optional(),simOpenAt:ms.optional(),simStartClosed:external_exports.boolean().optional(),simStartOpen:external_exports.boolean().optional(),connections:external_exports.custom().pipe(external_exports.record(external_exports.string(),connectionTarget)).optional()}).transform(props=>{let updatedProps={...props};switch(updatedProps.dpdt?updatedProps.type="dpdt":updatedProps.spst?updatedProps.type="spst":updatedProps.spdt?updatedProps.type="spdt":updatedProps.dpst&&(updatedProps.type="dpst"),updatedProps.type){case"spdt":updatedProps.spdt=!0;break;case"spst":updatedProps.spst=!0;break;case"dpst":updatedProps.dpst=!0;break;case"dpdt":updatedProps.dpdt=!0;break}return updatedProps});expectTypesMatch2(!0);var fabricationNoteTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:external_exports.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var fabricationNoteRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({width:distance,height:distance,strokeWidth:distance.optional(),isFilled:external_exports.boolean().optional(),hasStroke:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional(),cornerRadius:distance.optional()}),fabricationNotePathProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({route:external_exports.array(route_hint_point),strokeWidth:length.optional(),color:external_exports.string().optional()}),dimensionTarget=external_exports.union([external_exports.string(),point2]),fabricationNoteDimensionProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({from:dimensionTarget,to:dimensionTarget,text:external_exports.string().optional(),offset:distance.optional(),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional(),arrowSize:distance.optional(),units:external_exports.enum(["in","mm"]).optional(),outerEdgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional(),innerEdgeToEdge:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var pcbTraceProps=external_exports.object({layer:external_exports.string().optional(),thickness:distance.optional(),route:external_exports.array(route_hint_point)}),viaProps=commonLayoutProps.extend({name:external_exports.string().optional(),fromLayer:layer_ref,toLayer:layer_ref,holeDiameter:distance.optional(),outerDiameter:distance.optional(),connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional(),netIsAssignable:external_exports.boolean().optional()});expectTypesMatch2(!0);var testpointConnectionsProp=external_exports.object({pin1:connectionTarget}).strict(),testpointProps=commonComponentProps.extend({connections:testpointConnectionsProp.optional(),footprintVariant:external_exports.enum(["pad","through_hole"]).optional(),padShape:external_exports.enum(["rect","circle"]).optional().default("circle"),padDiameter:distance.optional(),holeDiameter:distance.optional(),width:distance.optional(),height:distance.optional()}).refine(props=>props.footprintVariant!=="through_hole"||props.holeDiameter!==void 0,{message:"holeDiameter is required for through_hole testpoints"});expectTypesMatch2(!0);var breakoutPointProps=pcbLayoutProps.omit({pcbRotation:!0,layer:!0}).extend({connection:external_exports.string()});expectTypesMatch2(!0);var pcbKeepoutProps=external_exports.union([pcbLayoutProps.omit({pcbRotation:!0}).extend({shape:external_exports.literal("circle"),radius:distance}),pcbLayoutProps.extend({shape:external_exports.literal("rect"),width:distance,height:distance})]),courtyardRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({width:distance,height:distance,strokeWidth:distance.optional(),isFilled:external_exports.boolean().optional(),hasStroke:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional()}),courtyardOutlineProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({outline:external_exports.array(point2),strokeWidth:length.optional(),isClosed:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional()}),copperPourProps=external_exports.object({name:external_exports.string().optional(),layer:layer_ref,connectsTo:external_exports.string(),padMargin:distance3.optional(),traceMargin:distance3.optional(),clearance:distance3.optional(),boardEdgeMargin:distance3.optional(),cutoutMargin:distance3.optional(),coveredWithSolderMask:external_exports.boolean().optional().default(!0)});expectTypesMatch2(!0);var cadassemblyProps=external_exports.object({originalLayer:layer_ref.default("top").optional(),children:external_exports.any().optional()});expectTypesMatch2(!0);var pcbPosition=external_exports.object({pcbX:pcbCoordinate.optional(),pcbY:pcbCoordinate.optional(),pcbLeftEdgeX:pcbCoordinate.optional(),pcbRightEdgeX:pcbCoordinate.optional(),pcbTopEdgeY:pcbCoordinate.optional(),pcbBottomEdgeY:pcbCoordinate.optional(),pcbOffsetX:distance3.optional(),pcbOffsetY:distance3.optional(),pcbZ:distance3.optional()}),cadModelBaseWithUrl=cadModelBase.extend({modelUrl:external_exports.string(),stepUrl:external_exports.string().optional()}),cadModelObject=cadModelBaseWithUrl.merge(pcbPosition);expectTypesMatch2(!0);var cadmodelProps=external_exports.union([external_exports.null(),external_exports.string(),cadModelObject]),powerSourceProps=commonComponentProps.extend({voltage}),voltageSourcePinLabels=["pin1","pin2","pos","neg"],percentage3=external_exports.union([external_exports.string(),external_exports.number()]).transform(val=>typeof val=="string"?val.endsWith("%")?parseFloat(val.slice(0,-1))/100:parseFloat(val):val).pipe(external_exports.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),voltageSourceProps=commonComponentProps.extend({voltage:voltage.optional(),frequency:frequency.optional(),peakToPeakVoltage:voltage.optional(),waveShape:external_exports.enum(["sinewave","square","triangle","sawtooth"]).optional(),phase:rotation.optional(),dutyCycle:percentage3.optional(),connections:createConnectionsProp(voltageSourcePinLabels).optional()});expectTypesMatch2(!0);var currentSourcePinLabels=["pin1","pin2","pos","neg"],percentage22=external_exports.union([external_exports.string(),external_exports.number()]).transform(val=>typeof val=="string"?val.endsWith("%")?parseFloat(val.slice(0,-1))/100:parseFloat(val):val).pipe(external_exports.number().min(0,"Duty cycle must be non-negative").max(1,"Duty cycle cannot be greater than 100%")),currentSourceProps=commonComponentProps.extend({current:current.optional(),frequency:frequency.optional(),peakToPeakCurrent:current.optional(),waveShape:external_exports.enum(["sinewave","square","triangle","sawtooth"]).optional(),phase:rotation.optional(),dutyCycle:percentage22.optional(),connections:createConnectionsProp(currentSourcePinLabels).optional()});expectTypesMatch2(!0);var voltageProbeProps=commonComponentProps.omit({name:!0}).extend({name:external_exports.string().optional(),connectsTo:external_exports.string(),referenceTo:external_exports.string().optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var schematicArcProps=external_exports.object({center:point,radius:distance,startAngleDegrees:rotation,endAngleDegrees:rotation,direction:external_exports.enum(["clockwise","counterclockwise"]).default("counterclockwise"),strokeWidth:distance.optional(),color:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1)});expectTypesMatch2(!0);var toolingrailProps=external_exports.object({children:external_exports.any().optional()});expectTypesMatch2(!0);var schematicBoxProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),width:distance.optional(),height:distance.optional(),overlay:external_exports.array(external_exports.string()).optional(),padding:distance.optional(),paddingLeft:distance.optional(),paddingRight:distance.optional(),paddingTop:distance.optional(),paddingBottom:distance.optional(),title:external_exports.string().optional(),titleAlignment:ninePointAnchor2.default("top_left"),titleColor:external_exports.string().optional(),titleFontSize:distance.optional(),titleInside:external_exports.boolean().default(!1),strokeStyle:external_exports.enum(["solid","dashed"]).default("solid")}).refine(elm=>elm.width!==void 0&&elm.height!==void 0||Array.isArray(elm.overlay)&&elm.overlay.length>0,{message:"Must provide either both `width` and `height`, or a non-empty `overlay` array."}).refine(elm=>!(elm.width!==void 0&&elm.height!==void 0&&Array.isArray(elm.overlay)&&elm.overlay.length>0),{message:"Cannot provide both `width`/`height` and `overlay` at the same time."});expectTypesMatch2(!0);var schematicCircleProps=external_exports.object({center:point,radius:distance,strokeWidth:distance.optional(),color:external_exports.string().optional(),isFilled:external_exports.boolean().optional().default(!1),fillColor:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1)});expectTypesMatch2(!0);var schematicRectProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),width:distance,height:distance,rotation:rotation.default(0),strokeWidth:distance.optional(),color:external_exports.string().optional(),isFilled:external_exports.boolean().optional().default(!1),fillColor:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1),cornerRadius:distance.optional()});expectTypesMatch2(!0);var schematicLineProps=external_exports.object({x1:distance,y1:distance,x2:distance,y2:distance,strokeWidth:distance.optional(),color:external_exports.string().optional(),isDashed:external_exports.boolean().optional().default(!1)});expectTypesMatch2(!0);var fivePointAnchor2=external_exports.enum(["center","left","right","top","bottom"]),schematicTextProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),text:external_exports.string(),fontSize:external_exports.number().default(1),anchor:external_exports.union([fivePointAnchor2.describe("legacy"),ninePointAnchor2]).default("center"),color:external_exports.string().default("#000000"),schRotation:rotation.default(0)});expectTypesMatch2(!0);var schematicPathProps=external_exports.object({points:external_exports.array(point),isFilled:external_exports.boolean().optional().default(!1),fillColor:external_exports.enum(["red","blue"]).optional()});expectTypesMatch2(!0);var schematicTableProps=external_exports.object({schX:distance.optional(),schY:distance.optional(),children:external_exports.any().optional(),cellPadding:distance.optional(),borderWidth:distance.optional(),anchor:ninePointAnchor2.optional(),fontSize:distance.optional()});expectTypesMatch2(!0);var schematicRowProps=external_exports.object({children:external_exports.any().optional(),height:distance.optional()});expectTypesMatch2(!0);var schematicCellProps=external_exports.object({children:external_exports.string().optional(),horizontalAlign:external_exports.enum(["left","center","right"]).optional(),verticalAlign:external_exports.enum(["top","middle","bottom"]).optional(),fontSize:distance.optional(),rowSpan:external_exports.number().optional(),colSpan:external_exports.number().optional(),width:distance.optional(),text:external_exports.string().optional()});expectTypesMatch2(!0);var copperTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:ninePointAnchor2.default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),layers:external_exports.array(layer_ref).optional(),knockout:external_exports.boolean().optional(),mirrored:external_exports.boolean().optional()}),silkscreenTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:ninePointAnchor2.default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),isKnockout:external_exports.boolean().optional(),knockoutPadding:length.optional(),knockoutPaddingLeft:length.optional(),knockoutPaddingRight:length.optional(),knockoutPaddingTop:length.optional(),knockoutPaddingBottom:length.optional(),layers:external_exports.array(layer_ref).optional()}),silkscreenPathProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({route:external_exports.array(route_hint_point),strokeWidth:length.optional()}),silkscreenLineProps=pcbLayoutProps.omit({pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({strokeWidth:distance,x1:distance,y1:distance,x2:distance,y2:distance}),silkscreenRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({filled:external_exports.boolean().default(!0).optional(),stroke:external_exports.enum(["dashed","solid","none"]).optional(),strokeWidth:distance.optional(),width:distance,height:distance,cornerRadius:distance.optional()}),silkscreenCircleProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({isFilled:external_exports.boolean().optional(),isOutline:external_exports.boolean().optional(),strokeWidth:distance.optional(),radius:distance}),routeHintPointProps=external_exports.object({x:distance,y:distance,via:external_exports.boolean().optional(),toLayer:layer_ref.optional()}),traceHintProps=external_exports.object({for:external_exports.string().optional().describe("Selector for the port you're targeting, not required if you're inside a trace"),order:external_exports.number().optional(),offset:route_hint_point.or(routeHintPointProps).optional(),offsets:external_exports.array(route_hint_point).or(external_exports.array(routeHintPointProps)).optional(),traceWidth:external_exports.number().optional()}),portProps=commonLayoutProps.extend({name:external_exports.string(),pinNumber:external_exports.number().optional(),aliases:external_exports.array(external_exports.string()).optional(),direction,connectsTo:external_exports.string().or(external_exports.array(external_exports.string())).optional()}),pcbNoteTextProps=pcbLayoutProps.extend({text:external_exports.string(),anchorAlignment:external_exports.enum(["center","top_left","top_right","bottom_left","bottom_right"]).default("center"),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var pcbNoteRectProps=pcbLayoutProps.omit({pcbRotation:!0}).extend({width:distance,height:distance,strokeWidth:distance.optional(),isFilled:external_exports.boolean().optional(),hasStroke:external_exports.boolean().optional(),isStrokeDashed:external_exports.boolean().optional(),color:external_exports.string().optional(),cornerRadius:distance.optional()});expectTypesMatch2(!0);var pcbNotePathProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({route:external_exports.array(route_hint_point),strokeWidth:length.optional(),color:external_exports.string().optional()});expectTypesMatch2(!0);var pcbNoteLineProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({x1:distance,y1:distance,x2:distance,y2:distance,strokeWidth:distance.optional(),color:external_exports.string().optional(),isDashed:external_exports.boolean().optional()});expectTypesMatch2(!0);var dimensionTarget2=external_exports.union([external_exports.string(),point2]),pcbNoteDimensionProps=pcbLayoutProps.omit({pcbLeftEdgeX:!0,pcbRightEdgeX:!0,pcbTopEdgeY:!0,pcbBottomEdgeY:!0,pcbX:!0,pcbY:!0,pcbOffsetX:!0,pcbOffsetY:!0,pcbRotation:!0}).extend({from:dimensionTarget2,to:dimensionTarget2,text:external_exports.string().optional(),offset:distance.optional(),font:external_exports.enum(["tscircuit2024"]).optional(),fontSize:length.optional(),color:external_exports.string().optional(),arrowSize:distance.optional(),units:external_exports.enum(["in","mm"]).optional(),outerEdgeToEdge:external_exports.literal(!0).optional(),centerToCenter:external_exports.literal(!0).optional(),innerEdgeToEdge:external_exports.literal(!0).optional()});expectTypesMatch2(!0);var unvalidatedCircuitJson=external_exports.array(external_exports.any()).describe("Circuit JSON"),footprintLibraryResult=external_exports.object({footprintCircuitJson:external_exports.array(external_exports.any()),cadModel:cadModelProp.optional()}),pathToCircuitJsonFn=external_exports.function().args(external_exports.string()).returns(external_exports.promise(footprintLibraryResult)).or(external_exports.function().args(external_exports.string(),external_exports.object({resolvedPcbStyle:pcbStyle.optional()}).optional()).returns(external_exports.promise(footprintLibraryResult))).describe("A function that takes a path and returns Circuit JSON"),footprintFileParserEntry=external_exports.object({loadFromUrl:external_exports.function().args(external_exports.string()).returns(external_exports.promise(footprintLibraryResult)).describe("A function that takes a footprint file URL and returns Circuit JSON")}),spiceEngineSimulationResult=external_exports.object({engineVersionString:external_exports.string().optional(),simulationResultCircuitJson:unvalidatedCircuitJson}),spiceEngineZod=external_exports.object({simulate:external_exports.function().args(external_exports.string()).returns(external_exports.promise(spiceEngineSimulationResult)).describe("A function that takes a SPICE string and returns a simulation result")}),defaultSpiceEngine=external_exports.custom(value=>typeof value=="string"),autorouterInstance=external_exports.object({run:external_exports.function().args().returns(external_exports.promise(external_exports.unknown())).describe("Run the autorouter"),getOutputSimpleRouteJson:external_exports.function().args().returns(external_exports.promise(external_exports.any())).describe("Get the resulting SimpleRouteJson")}),autorouterDefinition=external_exports.object({createAutorouter:external_exports.function().args(external_exports.any(),external_exports.any().optional()).returns(external_exports.union([autorouterInstance,external_exports.promise(autorouterInstance)])).describe("Create an autorouter instance")}),platformConfig=external_exports.object({partsEngine:partsEngine.optional(),autorouter:autorouterProp.optional(),autorouterMap:external_exports.record(external_exports.string(),autorouterDefinition).optional(),registryApiUrl:external_exports.string().optional(),cloudAutorouterUrl:external_exports.string().optional(),projectName:external_exports.string().optional(),projectBaseUrl:external_exports.string().optional(),version:external_exports.string().optional(),url:external_exports.string().optional(),printBoardInformationToSilkscreen:external_exports.boolean().optional(),includeBoardFiles:external_exports.array(external_exports.string()).describe('The board files to automatically build with "tsci build", defaults to ["**/*.circuit.tsx"]. Can be an array of files or globs').optional(),snapshotsDir:external_exports.string().describe('The directory where snapshots are stored for "tsci snapshot", defaults to "tests/__snapshots__"').optional(),defaultSpiceEngine:defaultSpiceEngine.optional(),localCacheEngine:external_exports.any().optional(),pcbDisabled:external_exports.boolean().optional(),schematicDisabled:external_exports.boolean().optional(),partsEngineDisabled:external_exports.boolean().optional(),spiceEngineMap:external_exports.record(external_exports.string(),spiceEngineZod).optional(),footprintLibraryMap:external_exports.record(external_exports.string(),external_exports.union([pathToCircuitJsonFn,external_exports.record(external_exports.string(),external_exports.union([unvalidatedCircuitJson,pathToCircuitJsonFn]))])).optional(),footprintFileParserMap:external_exports.record(external_exports.string(),footprintFileParserEntry).optional(),resolveProjectStaticFileImportUrl:external_exports.function().args(external_exports.string()).returns(external_exports.promise(external_exports.string())).describe("A function that returns a string URL for static files for the project").optional()});expectTypesMatch2(!0);var platformConfigObject=platformConfig,projectConfig=platformConfigObject.pick({projectName:!0,projectBaseUrl:!0,version:!0,url:!0,printBoardInformationToSilkscreen:!0,includeBoardFiles:!0,snapshotsDir:!0,defaultSpiceEngine:!0});expectTypesMatch2(!0);init_dist();init_zod();init_dist();init_dist();init_dist();init_dist2();init_zod();var import_react2=__toESM(require_react(),1);init_dist2();init_zod();function createMap(){return new IndexedMap}var IndexedMap=class _IndexedMap{constructor(){__publicField(this,"index",{});__publicField(this,"array",[])}size(){return this.array.length}empty(){return this.array.length===0}itemAt(index){return this.array[index]}contains(key){return this.index[key.id()]!==void 0}find(key){let i3=this.index[key.id()];return i3===void 0?void 0:this.array[i3]}setDefault(key,factory){let i3=this.index[key.id()];if(i3===void 0){let pair=new Pair(key,factory());return this.index[key.id()]=this.array.length,this.array.push(pair),pair}else return this.array[i3]}insert(key,value){let pair=new Pair(key,value),i3=this.index[key.id()];return i3===void 0?(this.index[key.id()]=this.array.length,this.array.push(pair)):this.array[i3]=pair,pair}erase(key){let i3=this.index[key.id()];if(i3===void 0)return;this.index[key.id()]=void 0;let pair=this.array[i3],last=this.array.pop();return pair!==last&&(this.array[i3]=last,this.index[last.first.id()]=i3),pair}copy(){let copy=new _IndexedMap;for(let i3=0;i3<this.array.length;i3++){let pair=this.array[i3].copy();copy.array[i3]=pair,copy.index[pair.first.id()]=i3}return copy}},Pair=class _Pair{constructor(first,second){__publicField(this,"first");__publicField(this,"second");this.first=first,this.second=second}copy(){return new _Pair(this.first,this.second)}};var Variable=class{constructor(name=""){__publicField(this,"_name");__publicField(this,"_value",0);__publicField(this,"_context",null);__publicField(this,"_id",VarId++);this._name=name}id(){return this._id}name(){return this._name}setName(name){this._name=name}context(){return this._context}setContext(context){this._context=context}value(){return this._value}setValue(value){this._value=value}plus(value){return new Expression(this,value)}minus(value){return new Expression(this,typeof value=="number"?-value:[-1,value])}multiply(coefficient){return new Expression([coefficient,this])}divide(coefficient){return new Expression([1/coefficient,this])}toJSON(){return{name:this._name,value:this._value}}toString(){return this._context+"["+this._name+":"+this._value+"]"}},VarId=0;var Expression=class _Expression{constructor(){__publicField(this,"_terms");__publicField(this,"_constant");let parsed=parseArgs(arguments);this._terms=parsed.terms,this._constant=parsed.constant}terms(){return this._terms}constant(){return this._constant}value(){let result=this._constant;for(let i3=0,n3=this._terms.size();i3<n3;i3++){let pair=this._terms.itemAt(i3);result+=pair.first.value()*pair.second}return result}plus(value){return new _Expression(this,value)}minus(value){return new _Expression(this,typeof value=="number"?-value:[-1,value])}multiply(coefficient){return new _Expression([coefficient,this])}divide(coefficient){return new _Expression([1/coefficient,this])}isConstant(){return this._terms.size()==0}toString(){let result=this._terms.array.map(function(pair){return pair.second+"*"+pair.first.toString()}).join(" + ");return!this.isConstant()&&this._constant!==0&&(result+=" + "),result+=this._constant,result}};function parseArgs(args){let constant=0,factory=()=>0,terms=createMap();for(let i3=0,n3=args.length;i3<n3;++i3){let item=args[i3];if(typeof item=="number")constant+=item;else if(item instanceof Variable)terms.setDefault(item,factory).second+=1;else if(item instanceof Expression){constant+=item.constant();let terms2=item.terms();for(let j3=0,k4=terms2.size();j3<k4;j3++){let termPair=terms2.itemAt(j3);terms.setDefault(termPair.first,factory).second+=termPair.second}}else if(item instanceof Array){if(item.length!==2)throw new Error("array must have length 2");let value=item[0],value2=item[1];if(typeof value!="number")throw new Error("array item 0 must be a number");if(value2 instanceof Variable)terms.setDefault(value2,factory).second+=value;else if(value2 instanceof Expression){constant+=value2.constant()*value;let terms2=value2.terms();for(let j3=0,k4=terms2.size();j3<k4;j3++){let termPair=terms2.itemAt(j3);terms.setDefault(termPair.first,factory).second+=termPair.second*value}}else throw new Error("array item 1 must be a variable or expression")}else throw new Error("invalid Expression argument: "+item)}return{terms,constant}}var _Strength=class _Strength{static create(a2,b3,c3,w4=1){let result=0;return result+=Math.max(0,Math.min(1e3,a2*w4))*1e6,result+=Math.max(0,Math.min(1e3,b3*w4))*1e3,result+=Math.max(0,Math.min(1e3,c3*w4)),result}static clip(value){return Math.max(0,Math.min(_Strength.required,value))}};__publicField(_Strength,"required",_Strength.create(1e3,1e3,1e3)),__publicField(_Strength,"strong",_Strength.create(1,0,0)),__publicField(_Strength,"medium",_Strength.create(0,1,0)),__publicField(_Strength,"weak",_Strength.create(0,0,1));var Strength=_Strength;var Operator;(function(Operator2){Operator2[Operator2.Le=0]="Le",Operator2[Operator2.Ge=1]="Ge",Operator2[Operator2.Eq=2]="Eq"})(Operator||(Operator={}));var Constraint=class{constructor(expression,operator,rhs,strength=Strength.required){__publicField(this,"_expression");__publicField(this,"_operator");__publicField(this,"_strength");__publicField(this,"_id",CnId++);this._operator=operator,this._strength=Strength.clip(strength),rhs===void 0&&expression instanceof Expression?this._expression=expression:this._expression=expression.minus(rhs)}id(){return this._id}expression(){return this._expression}op(){return this._operator}strength(){return this._strength}toString(){return this._expression.toString()+" "+["<=",">=","="][this._operator]+" 0 ("+this._strength.toString()+")"}},CnId=0;var Solver=class{constructor(){__publicField(this,"maxIterations",1e3);__publicField(this,"_cnMap",createCnMap());__publicField(this,"_rowMap",createRowMap());__publicField(this,"_varMap",createVarMap());__publicField(this,"_editMap",createEditMap());__publicField(this,"_infeasibleRows",[]);__publicField(this,"_objective",new Row);__publicField(this,"_artificial",null);__publicField(this,"_idTick",0)}createConstraint(lhs,operator,rhs,strength=Strength.required){let cn3=new Constraint(lhs,operator,rhs,strength);return this.addConstraint(cn3),cn3}addConstraint(constraint){if(this._cnMap.find(constraint)!==void 0)throw new Error("duplicate constraint");let data=this._createRow(constraint),row=data.row,tag=data.tag,subject=this._chooseSubject(row,tag);if(subject.type()===SymbolType.Invalid&&row.allDummies())if(nearZero(row.constant()))subject=tag.marker;else throw new Error("unsatisfiable constraint");if(subject.type()===SymbolType.Invalid){if(!this._addWithArtificialVariable(row))throw new Error("unsatisfiable constraint")}else row.solveFor(subject),this._substitute(subject,row),this._rowMap.insert(subject,row);this._cnMap.insert(constraint,tag),this._optimize(this._objective)}removeConstraint(constraint){let cnPair=this._cnMap.erase(constraint);if(cnPair===void 0)throw new Error("unknown constraint");this._removeConstraintEffects(constraint,cnPair.second);let marker=cnPair.second.marker,rowPair=this._rowMap.erase(marker);if(rowPair===void 0){let leaving=this._getMarkerLeavingSymbol(marker);if(leaving.type()===SymbolType.Invalid)throw new Error("failed to find leaving row");rowPair=this._rowMap.erase(leaving),rowPair.second.solveForEx(leaving,marker),this._substitute(marker,rowPair.second)}this._optimize(this._objective)}hasConstraint(constraint){return this._cnMap.contains(constraint)}getConstraints(){return this._cnMap.array.map(({first})=>first)}addEditVariable(variable,strength){if(this._editMap.find(variable)!==void 0)throw new Error("duplicate edit variable");if(strength=Strength.clip(strength),strength===Strength.required)throw new Error("bad required strength");let expr=new Expression(variable),cn3=new Constraint(expr,Operator.Eq,void 0,strength);this.addConstraint(cn3);let info={tag:this._cnMap.find(cn3).second,constraint:cn3,constant:0};this._editMap.insert(variable,info)}removeEditVariable(variable){let editPair=this._editMap.erase(variable);if(editPair===void 0)throw new Error("unknown edit variable");this.removeConstraint(editPair.second.constraint)}hasEditVariable(variable){return this._editMap.contains(variable)}suggestValue(variable,value){let editPair=this._editMap.find(variable);if(editPair===void 0)throw new Error("unknown edit variable");let rows=this._rowMap,info=editPair.second,delta=value-info.constant;info.constant=value;let marker=info.tag.marker,rowPair=rows.find(marker);if(rowPair!==void 0){rowPair.second.add(-delta)<0&&this._infeasibleRows.push(marker),this._dualOptimize();return}let other=info.tag.other;if(rowPair=rows.find(other),rowPair!==void 0){rowPair.second.add(delta)<0&&this._infeasibleRows.push(other),this._dualOptimize();return}for(let i3=0,n3=rows.size();i3<n3;++i3){let rowPair2=rows.itemAt(i3),row=rowPair2.second,coeff=row.coefficientFor(marker);coeff!==0&&row.add(delta*coeff)<0&&rowPair2.first.type()!==SymbolType.External&&this._infeasibleRows.push(rowPair2.first)}this._dualOptimize()}updateVariables(){let vars=this._varMap,rows=this._rowMap;for(let i3=0,n3=vars.size();i3<n3;++i3){let pair=vars.itemAt(i3),rowPair=rows.find(pair.second);rowPair!==void 0?pair.first.setValue(rowPair.second.constant()):pair.first.setValue(0)}}_getVarSymbol(variable){let factory=()=>this._makeSymbol(SymbolType.External);return this._varMap.setDefault(variable,factory).second}_createRow(constraint){let expr=constraint.expression(),row=new Row(expr.constant()),terms=expr.terms();for(let i3=0,n3=terms.size();i3<n3;++i3){let termPair=terms.itemAt(i3);if(!nearZero(termPair.second)){let symbol=this._getVarSymbol(termPair.first),basicPair=this._rowMap.find(symbol);basicPair!==void 0?row.insertRow(basicPair.second,termPair.second):row.insertSymbol(symbol,termPair.second)}}let objective=this._objective,strength=constraint.strength(),tag={marker:INVALID_SYMBOL,other:INVALID_SYMBOL};switch(constraint.op()){case Operator.Le:case Operator.Ge:{let coeff=constraint.op()===Operator.Le?1:-1,slack=this._makeSymbol(SymbolType.Slack);if(tag.marker=slack,row.insertSymbol(slack,coeff),strength<Strength.required){let error=this._makeSymbol(SymbolType.Error);tag.other=error,row.insertSymbol(error,-coeff),objective.insertSymbol(error,strength)}break}case Operator.Eq:{if(strength<Strength.required){let errplus=this._makeSymbol(SymbolType.Error),errminus=this._makeSymbol(SymbolType.Error);tag.marker=errplus,tag.other=errminus,row.insertSymbol(errplus,-1),row.insertSymbol(errminus,1),objective.insertSymbol(errplus,strength),objective.insertSymbol(errminus,strength)}else{let dummy=this._makeSymbol(SymbolType.Dummy);tag.marker=dummy,row.insertSymbol(dummy)}break}}return row.constant()<0&&row.reverseSign(),{row,tag}}_chooseSubject(row,tag){let cells=row.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3);if(pair.first.type()===SymbolType.External)return pair.first}let type=tag.marker.type();return(type===SymbolType.Slack||type===SymbolType.Error)&&row.coefficientFor(tag.marker)<0?tag.marker:(type=tag.other.type(),(type===SymbolType.Slack||type===SymbolType.Error)&&row.coefficientFor(tag.other)<0?tag.other:INVALID_SYMBOL)}_addWithArtificialVariable(row){let art=this._makeSymbol(SymbolType.Slack);this._rowMap.insert(art,row.copy()),this._artificial=row.copy(),this._optimize(this._artificial);let success=nearZero(this._artificial.constant());this._artificial=null;let pair=this._rowMap.erase(art);if(pair!==void 0){let basicRow=pair.second;if(basicRow.isConstant())return success;let entering=this._anyPivotableSymbol(basicRow);if(entering.type()===SymbolType.Invalid)return!1;basicRow.solveForEx(art,entering),this._substitute(entering,basicRow),this._rowMap.insert(entering,basicRow)}let rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3)rows.itemAt(i3).second.removeSymbol(art);return this._objective.removeSymbol(art),success}_substitute(symbol,row){let rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3){let pair=rows.itemAt(i3);pair.second.substitute(symbol,row),pair.second.constant()<0&&pair.first.type()!==SymbolType.External&&this._infeasibleRows.push(pair.first)}this._objective.substitute(symbol,row),this._artificial&&this._artificial.substitute(symbol,row)}_optimize(objective){let iterations=0;for(;iterations<this.maxIterations;){let entering=this._getEnteringSymbol(objective);if(entering.type()===SymbolType.Invalid)return;let leaving=this._getLeavingSymbol(entering);if(leaving.type()===SymbolType.Invalid)throw new Error("the objective is unbounded");let row=this._rowMap.erase(leaving).second;row.solveForEx(leaving,entering),this._substitute(entering,row),this._rowMap.insert(entering,row),iterations++}throw new Error("solver iterations exceeded")}_dualOptimize(){let rows=this._rowMap,infeasible=this._infeasibleRows;for(;infeasible.length!==0;){let leaving=infeasible.pop(),pair=rows.find(leaving);if(pair!==void 0&&pair.second.constant()<0){let entering=this._getDualEnteringSymbol(pair.second);if(entering.type()===SymbolType.Invalid)throw new Error("dual optimize failed");let row=pair.second;rows.erase(leaving),row.solveForEx(leaving,entering),this._substitute(entering,row),rows.insert(entering,row)}}}_getEnteringSymbol(objective){let cells=objective.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3),symbol=pair.first;if(pair.second<0&&symbol.type()!==SymbolType.Dummy)return symbol}return INVALID_SYMBOL}_getDualEnteringSymbol(row){let ratio=Number.MAX_VALUE,entering=INVALID_SYMBOL,cells=row.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3),symbol=pair.first,c3=pair.second;if(c3>0&&symbol.type()!==SymbolType.Dummy){let r4=this._objective.coefficientFor(symbol)/c3;r4<ratio&&(ratio=r4,entering=symbol)}}return entering}_getLeavingSymbol(entering){let ratio=Number.MAX_VALUE,found=INVALID_SYMBOL,rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3){let pair=rows.itemAt(i3),symbol=pair.first;if(symbol.type()!==SymbolType.External){let row=pair.second,temp=row.coefficientFor(entering);if(temp<0){let temp_ratio=-row.constant()/temp;temp_ratio<ratio&&(ratio=temp_ratio,found=symbol)}}}return found}_getMarkerLeavingSymbol(marker){let dmax=Number.MAX_VALUE,r12=dmax,r22=dmax,invalid=INVALID_SYMBOL,first=invalid,second=invalid,third=invalid,rows=this._rowMap;for(let i3=0,n3=rows.size();i3<n3;++i3){let pair=rows.itemAt(i3),row=pair.second,c3=row.coefficientFor(marker);if(c3===0)continue;let symbol=pair.first;if(symbol.type()===SymbolType.External)third=symbol;else if(c3<0){let r4=-row.constant()/c3;r4<r12&&(r12=r4,first=symbol)}else{let r4=row.constant()/c3;r4<r22&&(r22=r4,second=symbol)}}return first!==invalid?first:second!==invalid?second:third}_removeConstraintEffects(cn3,tag){tag.marker.type()===SymbolType.Error&&this._removeMarkerEffects(tag.marker,cn3.strength()),tag.other.type()===SymbolType.Error&&this._removeMarkerEffects(tag.other,cn3.strength())}_removeMarkerEffects(marker,strength){let pair=this._rowMap.find(marker);pair!==void 0?this._objective.insertRow(pair.second,-strength):this._objective.insertSymbol(marker,-strength)}_anyPivotableSymbol(row){let cells=row.cells();for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3),type=pair.first.type();if(type===SymbolType.Slack||type===SymbolType.Error)return pair.first}return INVALID_SYMBOL}_makeSymbol(type){return new Symbol2(type,this._idTick++)}};function nearZero(value){let eps=1e-8;return value<0?-value<eps:value<eps}function createCnMap(){return createMap()}function createRowMap(){return createMap()}function createVarMap(){return createMap()}function createEditMap(){return createMap()}var SymbolType;(function(SymbolType2){SymbolType2[SymbolType2.Invalid=0]="Invalid",SymbolType2[SymbolType2.External=1]="External",SymbolType2[SymbolType2.Slack=2]="Slack",SymbolType2[SymbolType2.Error=3]="Error",SymbolType2[SymbolType2.Dummy=4]="Dummy"})(SymbolType||(SymbolType={}));var Symbol2=class{constructor(type,id2){__publicField(this,"_id");__publicField(this,"_type");this._id=id2,this._type=type}id(){return this._id}type(){return this._type}},INVALID_SYMBOL=new Symbol2(SymbolType.Invalid,-1),Row=class _Row{constructor(constant=0){__publicField(this,"_cellMap",createMap());__publicField(this,"_constant");this._constant=constant}cells(){return this._cellMap}constant(){return this._constant}isConstant(){return this._cellMap.empty()}allDummies(){let cells=this._cellMap;for(let i3=0,n3=cells.size();i3<n3;++i3)if(cells.itemAt(i3).first.type()!==SymbolType.Dummy)return!1;return!0}copy(){let theCopy=new _Row(this._constant);return theCopy._cellMap=this._cellMap.copy(),theCopy}add(value){return this._constant+=value}insertSymbol(symbol,coefficient=1){let pair=this._cellMap.setDefault(symbol,()=>0);nearZero(pair.second+=coefficient)&&this._cellMap.erase(symbol)}insertRow(other,coefficient=1){this._constant+=other._constant*coefficient;let cells=other._cellMap;for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3);this.insertSymbol(pair.first,pair.second*coefficient)}}removeSymbol(symbol){this._cellMap.erase(symbol)}reverseSign(){this._constant=-this._constant;let cells=this._cellMap;for(let i3=0,n3=cells.size();i3<n3;++i3){let pair=cells.itemAt(i3);pair.second=-pair.second}}solveFor(symbol){let cells=this._cellMap,coeff=-1/cells.erase(symbol).second;this._constant*=coeff;for(let i3=0,n3=cells.size();i3<n3;++i3)cells.itemAt(i3).second*=coeff}solveForEx(lhs,rhs){this.insertSymbol(lhs,-1),this.solveFor(rhs)}coefficientFor(symbol){let pair=this._cellMap.find(symbol);return pair!==void 0?pair.second:0}substitute(symbol,row){let pair=this._cellMap.erase(symbol);pair!==void 0&&this.insertRow(row,pair.second)}};var import_debug8=__toESM(require_browser(),1);init_zod();init_dist();init_dist();init_dist4();var dist_exports2={};__export(dist_exports2,{areBoundsCompletelyInsidePolygon:()=>areBoundsCompletelyInsidePolygon,areBoundsOverlappingPolygon:()=>areBoundsOverlappingPolygon,boundsAreaOverlap:()=>boundsAreaOverlap,boundsDistance:()=>boundsDistance,boundsIntersection:()=>boundsIntersection,clamp:()=>clamp2,computeDistanceBetweenBoxes:()=>computeDistanceBetweenBoxes2,computeGapBetweenBoxes:()=>computeGapBetweenBoxes,computeManhattanDistanceBetweenBoxes:()=>computeManhattanDistanceBetweenBoxes,distSq:()=>distSq,distance:()=>distance4,doBoundsOverlap:()=>doBoundsOverlap,doSegmentsIntersect:()=>doSegmentsIntersect2,doesLineIntersectLine:()=>doesLineIntersectLine2,doesSegmentIntersectRect:()=>doesSegmentIntersectRect,findNearestPointsBetweenBoxSets:()=>findNearestPointsBetweenBoxSets2,getBoundingBox:()=>getBoundingBox2,getBoundsFromPoints:()=>getBoundsFromPoints,getSegmentIntersection:()=>getSegmentIntersection,getUnitVectorFromDirection:()=>getUnitVectorFromDirection2,getUnitVectorFromPointAToB:()=>getUnitVectorFromPointAToB2,grid:()=>grid2,isPointInsidePolygon:()=>isPointInsidePolygon,isRectCompletelyInsidePolygon:()=>isRectCompletelyInsidePolygon,isRectOverlappingPolygon:()=>isRectOverlappingPolygon,midpoint:()=>midpoint,normalizeDegrees:()=>normalizeDegrees,onSegment:()=>onSegment2,orientation:()=>orientation2,pointToBoundsDistance:()=>pointToBoundsDistance,pointToBoxDistance:()=>pointToBoxDistance,pointToSegmentClosestPoint:()=>pointToSegmentClosestPoint,pointToSegmentDistance:()=>pointToSegmentDistance2,range:()=>range,segmentToBoundsMinDistance:()=>segmentToBoundsMinDistance,segmentToBoxMinDistance:()=>segmentToBoxMinDistance,segmentToCircleMinDistance:()=>segmentToCircleMinDistance,segmentToSegmentMinDistance:()=>segmentToSegmentMinDistance});function doesLineIntersectLine2([a12,a2],[b12,b22],{lineThickness=0}={}){return lineThickness===0?doSegmentsIntersect2(a12,a2,b12,b22):segmentsDistance2(a12,a2,b12,b22)<=lineThickness}function doSegmentsIntersect2(p12,q12,p2,q22){let o12=orientation2(p12,q12,p2),o22=orientation2(p12,q12,q22),o32=orientation2(p2,q22,p12),o4=orientation2(p2,q22,q12);return!!(o12!==o22&&o32!==o4||o12===0&&onSegment2(p12,p2,q12)||o22===0&&onSegment2(p12,q22,q12)||o32===0&&onSegment2(p2,p12,q22)||o4===0&&onSegment2(p2,q12,q22))}function orientation2(p2,q4,r4){let val=(q4.y-p2.y)*(r4.x-q4.x)-(q4.x-p2.x)*(r4.y-q4.y);return val===0?0:val>0?1:2}function onSegment2(p2,q4,r4){return q4.x<=Math.max(p2.x,r4.x)&&q4.x>=Math.min(p2.x,r4.x)&&q4.y<=Math.max(p2.y,r4.y)&&q4.y>=Math.min(p2.y,r4.y)}function segmentsDistance2(a12,a2,b12,b22){if(a12.x===a2.x&&a12.y===a2.y)return pointToSegmentDistance2(a12,b12,b22);if(b12.x===b22.x&&b12.y===b22.y)return pointToSegmentDistance2(b12,a12,a2);if(doSegmentsIntersect2(a12,a2,b12,b22))return 0;let distances=[pointToSegmentDistance2(a12,b12,b22),pointToSegmentDistance2(a2,b12,b22),pointToSegmentDistance2(b12,a12,a2),pointToSegmentDistance2(b22,a12,a2)];return Math.min(...distances)}function pointToSegmentDistance2(p2,v4,w4){let l2=(w4.x-v4.x)**2+(w4.y-v4.y)**2;if(l2===0)return distance4(p2,v4);let t5=((p2.x-v4.x)*(w4.x-v4.x)+(p2.y-v4.y)*(w4.y-v4.y))/l2;t5=Math.max(0,Math.min(1,t5));let projection={x:v4.x+t5*(w4.x-v4.x),y:v4.y+t5*(w4.y-v4.y)};return distance4(p2,projection)}function distance4(p12,p2){let dx2=p12.x-p2.x,dy2=p12.y-p2.y;return Math.sqrt(dx2*dx2+dy2*dy2)}function getSegmentIntersection(a2,b3,u4,v4){let dx1=b3.x-a2.x,dy1=b3.y-a2.y,dx2=v4.x-u4.x,dy2=v4.y-u4.y,dx3=a2.x-u4.x,dy3=a2.y-u4.y,denominator=dx1*dy2-dy1*dx2;if(Math.abs(denominator)<1e-10)return null;let t5=(dy3*dx2-dx3*dy2)/denominator,s3=(dx1*dy3-dy1*dx3)/denominator,epsilon=1e-9;if(t5>=-epsilon&&t5<=1+epsilon&&s3>=-epsilon&&s3<=1+epsilon){let intersectionX=a2.x+t5*dx1,intersectionY=a2.y+t5*dy1;return{x:intersectionX,y:intersectionY}}return null}function doesSegmentIntersectRect(a2,b3,rect){let pointInside=p2=>p2.x>=rect.minX&&p2.x<=rect.maxX&&p2.y>=rect.minY&&p2.y<=rect.maxY;if(pointInside(a2)||pointInside(b3))return!0;let topLeft={x:rect.minX,y:rect.minY},topRight={x:rect.maxX,y:rect.minY},bottomLeft={x:rect.minX,y:rect.maxY},bottomRight={x:rect.maxX,y:rect.maxY};return doSegmentsIntersect2(a2,b3,topLeft,topRight)||doSegmentsIntersect2(a2,b3,topRight,bottomRight)||doSegmentsIntersect2(a2,b3,bottomRight,bottomLeft)||doSegmentsIntersect2(a2,b3,bottomLeft,topLeft)}function segmentToSegmentMinDistance(a2,b3,u4,v4){if(a2.x===b3.x&&a2.y===b3.y)return pointToSegmentDistance2(a2,u4,v4);if(u4.x===v4.x&&u4.y===v4.y)return pointToSegmentDistance2(u4,a2,b3);if(doSegmentsIntersect2(a2,b3,u4,v4))return 0;let distances=[pointToSegmentDistance2(a2,u4,v4),pointToSegmentDistance2(b3,u4,v4),pointToSegmentDistance2(u4,a2,b3),pointToSegmentDistance2(v4,a2,b3)];return Math.min(...distances)}function segmentToBoundsMinDistance(a2,b3,bounds){let topLeft={x:bounds.minX,y:bounds.minY},topRight={x:bounds.maxX,y:bounds.minY},bottomLeft={x:bounds.minX,y:bounds.maxY},bottomRight={x:bounds.maxX,y:bounds.maxY};if(doSegmentsIntersect2(a2,b3,topLeft,topRight)||doSegmentsIntersect2(a2,b3,topRight,bottomRight)||doSegmentsIntersect2(a2,b3,bottomRight,bottomLeft)||doSegmentsIntersect2(a2,b3,bottomLeft,topLeft)||a2.x>=bounds.minX&&a2.x<=bounds.maxX&&a2.y>=bounds.minY&&a2.y<=bounds.maxY&&b3.x>=bounds.minX&&b3.x<=bounds.maxX&&b3.y>=bounds.minY&&b3.y<=bounds.maxY)return 0;let distances=[pointToSegmentDistance2(topLeft,a2,b3),pointToSegmentDistance2(topRight,a2,b3),pointToSegmentDistance2(bottomLeft,a2,b3),pointToSegmentDistance2(bottomRight,a2,b3)];if(a2.x>=bounds.minX&&a2.x<=bounds.maxX&&a2.y>=bounds.minY&&a2.y<=bounds.maxY||b3.x>=bounds.minX&&b3.x<=bounds.maxX&&b3.y>=bounds.minY&&b3.y<=bounds.maxY)return 0;if(a2.x<bounds.minX||a2.x>bounds.maxX||a2.y<bounds.minY||a2.y>bounds.maxY){let closestX=clamp2(a2.x,bounds.minX,bounds.maxX),closestY=clamp2(a2.y,bounds.minY,bounds.maxY);distances.push(distance4(a2,{x:closestX,y:closestY}))}if(b3.x<bounds.minX||b3.x>bounds.maxX||b3.y<bounds.minY||b3.y>bounds.maxY){let closestX=clamp2(b3.x,bounds.minX,bounds.maxX),closestY=clamp2(b3.y,bounds.minY,bounds.maxY);distances.push(distance4(b3,{x:closestX,y:closestY}))}return Math.min(...distances)}function segmentToBoxMinDistance(a2,b3,box2){let halfWidth=box2.width/2,halfHeight=box2.height/2,bounds={minX:box2.center.x-halfWidth,maxX:box2.center.x+halfWidth,minY:box2.center.y-halfHeight,maxY:box2.center.y+halfHeight};return segmentToBoundsMinDistance(a2,b3,bounds)}function segmentToCircleMinDistance(a2,b3,circle2){let circleCenter={x:circle2.x,y:circle2.y};if(a2.x===b3.x&&a2.y===b3.y)return Math.max(0,distance4(a2,circleCenter)-circle2.radius);let ab2={x:b3.x-a2.x,y:b3.y-a2.y},ac2={x:circleCenter.x-a2.x,y:circleCenter.y-a2.y},abLengthSq=ab2.x*ab2.x+ab2.y*ab2.y,t5=Math.max(0,Math.min(1,(ab2.x*ac2.x+ab2.y*ac2.y)/abLengthSq)),closestPoint={x:a2.x+t5*ab2.x,y:a2.y+t5*ab2.y},distToCenter=distance4(closestPoint,circleCenter);return Math.max(0,distToCenter-circle2.radius)}function pointToSegmentClosestPoint(p2,a2,b3){let dx_ab=b3.x-a2.x,dy_ab=b3.y-a2.y,l2=dx_ab*dx_ab+dy_ab*dy_ab;if(l2===0)return{x:a2.x,y:a2.y};let t5=((p2.x-a2.x)*dx_ab+(p2.y-a2.y)*dy_ab)/l2;return t5=Math.max(0,Math.min(1,t5)),{x:a2.x+t5*dx_ab,y:a2.y+t5*dy_ab}}function normalizeDegrees(angle){return(angle%360+360)%360}function pointToBoxDistance(p2,box2){let halfWidth=box2.width/2,halfHeight=box2.height/2,minX=box2.center.x-halfWidth,maxX=box2.center.x+halfWidth,minY=box2.center.y-halfHeight,maxY=box2.center.y+halfHeight;if(p2.x>=minX&&p2.x<=maxX&&p2.y>=minY&&p2.y<=maxY)return 0;let closestX=clamp2(p2.x,minX,maxX),closestY=clamp2(p2.y,minY,maxY);return distance4(p2,{x:closestX,y:closestY})}function pointToBoundsDistance(p2,bounds){if(p2.x>=bounds.minX&&p2.x<=bounds.maxX&&p2.y>=bounds.minY&&p2.y<=bounds.maxY)return 0;let closestX=clamp2(p2.x,bounds.minX,bounds.maxX),closestY=clamp2(p2.y,bounds.minY,bounds.maxY);return distance4(p2,{x:closestX,y:closestY})}function midpoint(p12,p2){return{x:(p12.x+p2.x)/2,y:(p12.y+p2.y)/2}}function distSq(p12,p2){let dx2=p12.x-p2.x,dy2=p12.y-p2.y;return dx2*dx2+dy2*dy2}var universalRectToBounds=rect=>{if("minX"in rect)return rect;let halfWidth=rect.width/2,halfHeight=rect.height/2;return{minX:rect.center.x-halfWidth,minY:rect.center.y-halfHeight,maxX:rect.center.x+halfWidth,maxY:rect.center.y+halfHeight}},getBoundsCorners=bounds=>[{x:bounds.minX,y:bounds.minY},{x:bounds.maxX,y:bounds.minY},{x:bounds.maxX,y:bounds.maxY},{x:bounds.minX,y:bounds.maxY}],getPolygonEdges=polygon2=>{let edges=[];for(let i3=0;i3<polygon2.length;i3++){let start=polygon2[i3],end=polygon2[(i3+1)%polygon2.length];edges.push([start,end])}return edges},isPointOnSegment=(point6,start,end)=>{let cross3=(point6.y-start.y)*(end.x-start.x)-(point6.x-start.x)*(end.y-start.y);if(Math.abs(cross3)>1e-9)return!1;let dot=(point6.x-start.x)*(end.x-start.x)+(point6.y-start.y)*(end.y-start.y);if(dot<0)return!1;let squaredLength=(end.x-start.x)**2+(end.y-start.y)**2;return!(dot>squaredLength)},isPointInsideBounds=(point6,bounds)=>point6.x>=bounds.minX&&point6.x<=bounds.maxX&&point6.y>=bounds.minY&&point6.y<=bounds.maxY,isPointInsidePolygon=(point6,polygon2)=>{if(polygon2.length<3)return!1;let edges=getPolygonEdges(polygon2);for(let[start,end]of edges)if(isPointOnSegment(point6,start,end))return!0;let inside2=!1;for(let i3=0,j3=polygon2.length-1;i3<polygon2.length;j3=i3++){let xi3=polygon2[i3].x,yi3=polygon2[i3].y,xj=polygon2[j3].x,yj=polygon2[j3].y;yi3>point6.y!=yj>point6.y&&point6.x<(xj-xi3)*(point6.y-yi3)/(yj-yi3)+xi3&&(inside2=!inside2)}return inside2},doesPolygonIntersectBounds=(bounds,polygon2)=>{let boundsCorners=getBoundsCorners(bounds),boundsEdges=[[boundsCorners[0],boundsCorners[1]],[boundsCorners[1],boundsCorners[2]],[boundsCorners[2],boundsCorners[3]],[boundsCorners[3],boundsCorners[0]]],polygonEdges=getPolygonEdges(polygon2);for(let[start,end]of polygonEdges)for(let[rectStart,rectEnd]of boundsEdges)if(doSegmentsIntersect2(start,end,rectStart,rectEnd))return!0;return!1},areBoundsOverlappingPolygon=(bounds,polygon2)=>polygon2.length<3?!1:polygon2.some(point6=>isPointInsideBounds(point6,bounds))||getBoundsCorners(bounds).some(corner=>isPointInsidePolygon(corner,polygon2))?!0:doesPolygonIntersectBounds(bounds,polygon2),areBoundsCompletelyInsidePolygon=(bounds,polygon2)=>polygon2.length<3||!getBoundsCorners(bounds).every(corner=>isPointInsidePolygon(corner,polygon2))?!1:!doesPolygonIntersectBounds(bounds,polygon2),isRectOverlappingPolygon=(rect,polygon2)=>areBoundsOverlappingPolygon(universalRectToBounds(rect),polygon2),isRectCompletelyInsidePolygon=(rect,polygon2)=>areBoundsCompletelyInsidePolygon(universalRectToBounds(rect),polygon2);function range(start,end,step=1){if(step===0)throw new Error("step cannot be 0");let _start,_end;end===void 0?(_start=0,_end=start):(_start=start,_end=end);let result=[];if(step>0)for(let i3=_start;i3<_end;i3+=step)result.push(i3);else for(let i3=_start;i3>_end;i3+=step)result.push(i3);return result}var boundsAreaOverlap=(bounds1,bounds2)=>{let overlapX=Math.max(0,Math.min(bounds1.maxX,bounds2.maxX)-Math.max(bounds1.minX,bounds2.minX)),overlapY=Math.max(0,Math.min(bounds1.maxY,bounds2.maxY)-Math.max(bounds1.minY,bounds2.minY));return overlapX*overlapY};var boundsDistance=(bounds1,bounds2)=>{let dx2=bounds1.maxX<bounds2.minX?bounds2.minX-bounds1.maxX:bounds2.maxX<bounds1.minX?bounds1.minX-bounds2.maxX:0,dy2=bounds1.maxY<bounds2.minY?bounds2.minY-bounds1.maxY:bounds2.maxY<bounds1.minY?bounds1.minY-bounds2.maxY:0;return Math.sqrt(dx2*dx2+dy2*dy2)};var boundsIntersection=(bounds1,bounds2)=>{let minX=Math.max(bounds1.minX,bounds2.minX),minY=Math.max(bounds1.minY,bounds2.minY),maxX=Math.min(bounds1.maxX,bounds2.maxX),maxY=Math.min(bounds1.maxY,bounds2.maxY);return minX>maxX||minY>maxY?null:{minX,minY,maxX,maxY}};var doBoundsOverlap=(bounds1,bounds2)=>!(bounds1.maxX<bounds2.minX||bounds2.maxX<bounds1.minX||bounds1.maxY<bounds2.minY||bounds2.maxY<bounds1.minY);var getBoundsFromPoints=points=>{if(points.length===0)return null;let minX=points[0].x,minY=points[0].y,maxX=points[0].x,maxY=points[0].y;for(let i3=1;i3<points.length;i3++){let point6=points[i3];point6.x<minX&&(minX=point6.x),point6.y<minY&&(minY=point6.y),point6.x>maxX&&(maxX=point6.x),point6.y>maxY&&(maxY=point6.y)}return{minX,minY,maxX,maxY}};var getUnitVectorFromPointAToB2=(a2,b3)=>{let delta={x:b3.x-a2.x,y:b3.y-a2.y},magnitude=Math.sqrt(delta.x**2+delta.y**2);return{x:delta.x/magnitude,y:delta.y/magnitude}},getUnitVectorFromDirection2=direction2=>{switch(direction2){case"up":return{x:0,y:1};case"down":return{x:0,y:-1};case"left":return{x:-1,y:0};case"right":return{x:1,y:0}}};function grid2({rows,cols,xSpacing,ySpacing,width,height,offsetX=0,offsetY=0,yDirection="cartesian",centered=!0}){let effectiveXSpacing=xSpacing??1,effectiveYSpacing=ySpacing??1,totalWidth=width??cols*effectiveXSpacing,totalHeight=height??rows*effectiveYSpacing,centeringOffsetX=centered?-totalWidth/2:0,centeringOffsetY=centered?-totalHeight/2:0,cellWidth=width?width/cols:effectiveXSpacing,cellHeight=height?height/rows:effectiveYSpacing,cells=[];for(let row=0;row<rows;row++)for(let col=0;col<cols;col++){let index=row*cols+col,centerX=offsetX+centeringOffsetX+col*cellWidth+cellWidth/2,rawCenterY=offsetY+row*cellHeight+cellHeight/2,centerY=yDirection==="cartesian"?offsetY+centeringOffsetY+(rows-1-row)*cellHeight+cellHeight/2:offsetY+centeringOffsetY+row*cellHeight+cellHeight/2;cells.push({index,center:{x:centerX,y:centerY},topLeft:{x:centerX-cellWidth/2,y:centerY+cellHeight/2},bottomRight:{x:centerX+cellWidth/2,y:centerY-cellHeight/2},row,col})}return cells}init_dist();init_dist5();var package_default={name:"@tscircuit/capacity-autorouter",main:"./dist/index.js",version:"0.0.259",type:"module",files:["dist"],scripts:{start:"cosmos",build:"tsup ./lib/index.ts --minify terser --external @tscircuit/core --external circuit-to-svg --format esm --dts --sourcemap",bench:"bun test tests/spatial-index-bench.test.ts",format:"biome format --write .","format:check":"biome format .","vercel-build":"cosmos-export","repomix:lib":"repomix --ignore 'testing/**,**/TwoRouteHighDensitySolver/**,**/RouteStitchingSolver/**,solvers/CapacitySegmentPointOptimizer/CapacitySegmentPointOptimizer.ts' lib","bug-report":"bun run scripts/download-bug-report.ts","bug-report-with-test":"bun run scripts/create-bug-report-test.ts"},devDependencies:{"@biomejs/biome":"^1.9.4","@radix-ui/react-icons":"^1.3.2","@radix-ui/react-menubar":"^1.1.14","@react-hook/resize-observer":"^2.0.2","@resvg/resvg-js":"^2.6.2","@tscircuit/checks":"^0.0.75","@tscircuit/circuit-json-util":"^0.0.46","@tscircuit/core":"^0.0.337","@tscircuit/curvy-trace-solver":"^0.0.10","@tscircuit/hypergraph":"^0.0.15","@tscircuit/math-utils":"^0.0.27","@tscircuit/rectdiff":"0.0.22","@tscircuit/solver-utils":"^0.0.9","@types/bun":"^1.2.23","@types/fast-json-stable-stringify":"^2.1.2","@types/object-hash":"^3.0.6","@types/rbush":"^4.0.0","@types/react":"^19.0.8","@types/react-dom":"^19.0.3","@vercel/node":"^5.1.7","@vitejs/plugin-react":"^4.3.4","circuit-json-to-connectivity-map":"^0.0.19","circuit-to-svg":"^0.0.220",clsx:"^2.1.1",flatbush:"^4.4.0","graphics-debug":"^0.0.77",kleur:"^4.1.5","looks-same":"9",rbush:"^4.0.1",react:"18","react-cosmos":"^6.2.3","react-cosmos-plugin-vite":"^6.2.0","react-dom":"18","react-konva":"18",recharts:"^2.15.1","tailwind-merge":"^3.2.0",terser:"^5.43.1",tsup:"^8.3.6",typescript:"^5.9.3","use-mouse-matrix-transform":"^1.3.0",vite:"^6.0.11","vite-tsconfig-paths":"^5.1.4"},dependencies:{"bun-match-svg":"^0.0.14","fast-json-stable-stringify":"^2.1.0","object-hash":"^3.0.0"}};init_dist();init_dist4();init_dist6();var import_react3=__toESM(require_react(),1);init_dist();var import_debug9=__toESM(require_browser(),1);var import_object_hash=__toESM(require_object_hash(),1),import_object_hash2=__toESM(require_object_hash(),1),import_object_hash3=__toESM(require_object_hash(),1);var t=Object.create,e3=Object.defineProperty,n=Object.getOwnPropertyDescriptor,s2=Object.getOwnPropertyNames,o=Object.getPrototypeOf,i=Object.prototype.hasOwnProperty,r3=(t5,e4)=>function(){return e4||(0,t5[s2(t5)[0]])((e4={exports:{}}).exports,e4),e4.exports},a=(r4,a2,c3)=>(c3=r4!=null?t(o(r4)):{},((t5,o4,r6,a3)=>{if(o4&&typeof o4=="object"||typeof o4=="function")for(let c4 of s2(o4))i.call(t5,c4)||c4===r6||e3(t5,c4,{get:()=>o4[c4],enumerable:!(a3=n(o4,c4))||a3.enumerable});return t5})(!a2&&r4&&r4.__esModule?c3:e3(c3,"default",{value:r4,enumerable:!0}),r4)),c=r3({"node_modules/is-buffer/index.js"(t5,e4){function n3(t7){return!!t7.constructor&&typeof t7.constructor.isBuffer=="function"&&t7.constructor.isBuffer(t7)}e4.exports=function(t7){return t7!=null&&(n3(t7)||(function(t8){return typeof t8.readFloatLE=="function"&&typeof t8.slice=="function"&&n3(t8.slice(0,0))})(t7)||!!t7._isBuffer)}}}),h=r3({"node_modules/kind-of/index.js"(t5,e4){var n3=c(),s3=Object.prototype.toString;e4.exports=function(t7){if(t7===void 0)return"undefined";if(t7===null)return"null";if(t7===!0||t7===!1||t7 instanceof Boolean)return"boolean";if(typeof t7=="string"||t7 instanceof String)return"string";if(typeof t7=="number"||t7 instanceof Number)return"number";if(typeof t7=="function"||t7 instanceof Function)return"function";if(Array.isArray!==void 0&&Array.isArray(t7))return"array";if(t7 instanceof RegExp)return"regexp";if(t7 instanceof Date)return"date";var e5=s3.call(t7);return e5==="[object RegExp]"?"regexp":e5==="[object Date]"?"date":e5==="[object Arguments]"?"arguments":e5==="[object Error]"?"error":n3(t7)?"buffer":e5==="[object Set]"?"set":e5==="[object WeakSet]"?"weakset":e5==="[object Map]"?"map":e5==="[object WeakMap]"?"weakmap":e5==="[object Symbol]"?"symbol":e5==="[object Int8Array]"?"int8array":e5==="[object Uint8Array]"?"uint8array":e5==="[object Uint8ClampedArray]"?"uint8clampedarray":e5==="[object Int16Array]"?"int16array":e5==="[object Uint16Array]"?"uint16array":e5==="[object Int32Array]"?"int32array":e5==="[object Uint32Array]"?"uint32array":e5==="[object Float32Array]"?"float32array":e5==="[object Float64Array]"?"float64array":"object"}}}),d=r3({"node_modules/rename-keys/index.js"(t5,e4){(function(){function t7(t8,e5){if(typeof e5!="function")return t8;var n3={};for(var s3 in t8)Object.prototype.hasOwnProperty.call(t8,s3)&&(n3[e5(s3,t8[s3])||s3]=t8[s3]);return n3}e4!==void 0&&e4.exports?e4.exports=t7:typeof define=="function"&&define.amd?define([],function(){return t7}):window.rename=t7})()}}),l=r3({"node_modules/deep-rename-keys/index.js"(t5,e4){var n3=h(),s3=d();e4.exports=function t7(e5,o4){var i3=n3(e5);if(i3!=="object"&&i3!=="array")throw new Error("expected an object");var r4=[];for(var a2 in i3==="object"&&(e5=s3(e5,o4),r4={}),e5)if(e5.hasOwnProperty(a2)){var c3=e5[a2];n3(c3)==="object"||n3(c3)==="array"?r4[a2]=t7(c3,o4):r4[a2]=c3}return r4}}}),u3=r3({"node_modules/xml-reader/node_modules/eventemitter3/index.js"(t5,e4){var n3=Object.prototype.hasOwnProperty,s3="~";function o4(){}function i3(t7,e5,n4){this.fn=t7,this.context=e5,this.once=n4||!1}function r4(){this._events=new o4,this._eventsCount=0}Object.create&&(o4.prototype=Object.create(null),new o4().__proto__||(s3=!1)),r4.prototype.eventNames=function(){var t7,e5,o5=[];if(this._eventsCount===0)return o5;for(e5 in t7=this._events)n3.call(t7,e5)&&o5.push(s3?e5.slice(1):e5);return Object.getOwnPropertySymbols?o5.concat(Object.getOwnPropertySymbols(t7)):o5},r4.prototype.listeners=function(t7,e5){var n4=s3?s3+t7:t7,o5=this._events[n4];if(e5)return!!o5;if(!o5)return[];if(o5.fn)return[o5.fn];for(var i4=0,r6=o5.length,a2=new Array(r6);i4<r6;i4++)a2[i4]=o5[i4].fn;return a2},r4.prototype.emit=function(t7,e5,n4,o5,i4,r6){var a2=s3?s3+t7:t7;if(!this._events[a2])return!1;var c3,h2,d3=this._events[a2],l2=arguments.length;if(d3.fn){switch(d3.once&&this.removeListener(t7,d3.fn,void 0,!0),l2){case 1:return d3.fn.call(d3.context),!0;case 2:return d3.fn.call(d3.context,e5),!0;case 3:return d3.fn.call(d3.context,e5,n4),!0;case 4:return d3.fn.call(d3.context,e5,n4,o5),!0;case 5:return d3.fn.call(d3.context,e5,n4,o5,i4),!0;case 6:return d3.fn.call(d3.context,e5,n4,o5,i4,r6),!0}for(h2=1,c3=new Array(l2-1);h2<l2;h2++)c3[h2-1]=arguments[h2];d3.fn.apply(d3.context,c3)}else{var u4,p2=d3.length;for(h2=0;h2<p2;h2++)switch(d3[h2].once&&this.removeListener(t7,d3[h2].fn,void 0,!0),l2){case 1:d3[h2].fn.call(d3[h2].context);break;case 2:d3[h2].fn.call(d3[h2].context,e5);break;case 3:d3[h2].fn.call(d3[h2].context,e5,n4);break;case 4:d3[h2].fn.call(d3[h2].context,e5,n4,o5);break;default:if(!c3)for(u4=1,c3=new Array(l2-1);u4<l2;u4++)c3[u4-1]=arguments[u4];d3[h2].fn.apply(d3[h2].context,c3)}}return!0},r4.prototype.on=function(t7,e5,n4){var o5=new i3(e5,n4||this),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.once=function(t7,e5,n4){var o5=new i3(e5,n4||this,!0),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.removeListener=function(t7,e5,n4,i4){var r6=s3?s3+t7:t7;if(!this._events[r6])return this;if(!e5)return--this._eventsCount===0?this._events=new o4:delete this._events[r6],this;var a2=this._events[r6];if(a2.fn)a2.fn!==e5||i4&&!a2.once||n4&&a2.context!==n4||(--this._eventsCount===0?this._events=new o4:delete this._events[r6]);else{for(var c3=0,h2=[],d3=a2.length;c3<d3;c3++)(a2[c3].fn!==e5||i4&&!a2[c3].once||n4&&a2[c3].context!==n4)&&h2.push(a2[c3]);h2.length?this._events[r6]=h2.length===1?h2[0]:h2:--this._eventsCount===0?this._events=new o4:delete this._events[r6]}return this},r4.prototype.removeAllListeners=function(t7){var e5;return t7?(e5=s3?s3+t7:t7,this._events[e5]&&(--this._eventsCount===0?this._events=new o4:delete this._events[e5])):(this._events=new o4,this._eventsCount=0),this},r4.prototype.off=r4.prototype.removeListener,r4.prototype.addListener=r4.prototype.on,r4.prototype.setMaxListeners=function(){return this},r4.prefixed=s3,r4.EventEmitter=r4,e4!==void 0&&(e4.exports=r4)}}),p=r3({"node_modules/xml-lexer/node_modules/eventemitter3/index.js"(t5,e4){var n3=Object.prototype.hasOwnProperty,s3="~";function o4(){}function i3(t7,e5,n4){this.fn=t7,this.context=e5,this.once=n4||!1}function r4(){this._events=new o4,this._eventsCount=0}Object.create&&(o4.prototype=Object.create(null),new o4().__proto__||(s3=!1)),r4.prototype.eventNames=function(){var t7,e5,o5=[];if(this._eventsCount===0)return o5;for(e5 in t7=this._events)n3.call(t7,e5)&&o5.push(s3?e5.slice(1):e5);return Object.getOwnPropertySymbols?o5.concat(Object.getOwnPropertySymbols(t7)):o5},r4.prototype.listeners=function(t7,e5){var n4=s3?s3+t7:t7,o5=this._events[n4];if(e5)return!!o5;if(!o5)return[];if(o5.fn)return[o5.fn];for(var i4=0,r6=o5.length,a2=new Array(r6);i4<r6;i4++)a2[i4]=o5[i4].fn;return a2},r4.prototype.emit=function(t7,e5,n4,o5,i4,r6){var a2=s3?s3+t7:t7;if(!this._events[a2])return!1;var c3,h2,d3=this._events[a2],l2=arguments.length;if(d3.fn){switch(d3.once&&this.removeListener(t7,d3.fn,void 0,!0),l2){case 1:return d3.fn.call(d3.context),!0;case 2:return d3.fn.call(d3.context,e5),!0;case 3:return d3.fn.call(d3.context,e5,n4),!0;case 4:return d3.fn.call(d3.context,e5,n4,o5),!0;case 5:return d3.fn.call(d3.context,e5,n4,o5,i4),!0;case 6:return d3.fn.call(d3.context,e5,n4,o5,i4,r6),!0}for(h2=1,c3=new Array(l2-1);h2<l2;h2++)c3[h2-1]=arguments[h2];d3.fn.apply(d3.context,c3)}else{var u4,p2=d3.length;for(h2=0;h2<p2;h2++)switch(d3[h2].once&&this.removeListener(t7,d3[h2].fn,void 0,!0),l2){case 1:d3[h2].fn.call(d3[h2].context);break;case 2:d3[h2].fn.call(d3[h2].context,e5);break;case 3:d3[h2].fn.call(d3[h2].context,e5,n4);break;case 4:d3[h2].fn.call(d3[h2].context,e5,n4,o5);break;default:if(!c3)for(u4=1,c3=new Array(l2-1);u4<l2;u4++)c3[u4-1]=arguments[u4];d3[h2].fn.apply(d3[h2].context,c3)}}return!0},r4.prototype.on=function(t7,e5,n4){var o5=new i3(e5,n4||this),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.once=function(t7,e5,n4){var o5=new i3(e5,n4||this,!0),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.removeListener=function(t7,e5,n4,i4){var r6=s3?s3+t7:t7;if(!this._events[r6])return this;if(!e5)return--this._eventsCount===0?this._events=new o4:delete this._events[r6],this;var a2=this._events[r6];if(a2.fn)a2.fn!==e5||i4&&!a2.once||n4&&a2.context!==n4||(--this._eventsCount===0?this._events=new o4:delete this._events[r6]);else{for(var c3=0,h2=[],d3=a2.length;c3<d3;c3++)(a2[c3].fn!==e5||i4&&!a2[c3].once||n4&&a2[c3].context!==n4)&&h2.push(a2[c3]);h2.length?this._events[r6]=h2.length===1?h2[0]:h2:--this._eventsCount===0?this._events=new o4:delete this._events[r6]}return this},r4.prototype.removeAllListeners=function(t7){var e5;return t7?(e5=s3?s3+t7:t7,this._events[e5]&&(--this._eventsCount===0?this._events=new o4:delete this._events[e5])):(this._events=new o4,this._eventsCount=0),this},r4.prototype.off=r4.prototype.removeListener,r4.prototype.addListener=r4.prototype.on,r4.prototype.setMaxListeners=function(){return this},r4.prefixed=s3,r4.EventEmitter=r4,e4!==void 0&&(e4.exports=r4)}}),m=r3({"node_modules/xml-lexer/dist/lexer.js"(t5,e4){function n3(t7,e5,n4){return e5 in t7?Object.defineProperty(t7,e5,{value:n4,enumerable:!0,configurable:!0,writable:!0}):t7[e5]=n4,t7}var s3=p(),o4=function(){},i3={data:"state-data",cdata:"state-cdata",tagBegin:"state-tag-begin",tagName:"state-tag-name",tagEnd:"state-tag-end",attributeNameStart:"state-attribute-name-start",attributeName:"state-attribute-name",attributeNameEnd:"state-attribute-name-end",attributeValueBegin:"state-attribute-value-begin",attributeValue:"state-attribute-value"},r4={lt:"action-lt",gt:"action-gt",space:"action-space",equal:"action-equal",quote:"action-quote",slash:"action-slash",char:"action-char",error:"action-error"},a2={text:"text",openTag:"open-tag",closeTag:"close-tag",attributeName:"attribute-name",attributeValue:"attribute-value"},c3={" ":r4.space," ":r4.space,"\n":r4.space,"\r":r4.space,"<":r4.lt,">":r4.gt,'"':r4.quote,"'":r4.quote,"=":r4.equal,"/":r4.slash};e4.exports={State:i3,Action:r4,Type:a2,create:function(t7){var e5,h2,d3,l2,u4,p2,m3,f2,g4,y3;t7=Object.assign({debug:!1},t7);var x3=new s3,v4=i3.data,S4="",P4="",b3="",M5="",N4="",I4="",C3=function(e6,n4){if(P4[0]!=="?"&&P4[0]!=="!"){var s4={type:e6,value:n4};t7.debug&&console.log("emit:",s4),x3.emit("data",s4)}};x3.stateMachine=(n3(y3={},i3.data,(n3(e5={},r4.lt,function(){S4.trim()&&C3(a2.text,S4),P4="",N4=!1,v4=i3.tagBegin}),n3(e5,r4.char,function(t8){S4+=t8}),e5)),n3(y3,i3.cdata,n3({},r4.char,function(t8){(S4+=t8).substr(-3)==="]]>"&&(C3(a2.text,S4.slice(0,-3)),S4="",v4=i3.data)})),n3(y3,i3.tagBegin,(n3(h2={},r4.space,o4),n3(h2,r4.char,function(t8){P4=t8,v4=i3.tagName}),n3(h2,r4.slash,function(){P4="",N4=!0}),h2)),n3(y3,i3.tagName,(n3(d3={},r4.space,function(){N4?v4=i3.tagEnd:(v4=i3.attributeNameStart,C3(a2.openTag,P4))}),n3(d3,r4.gt,function(){C3(N4?a2.closeTag:a2.openTag,P4),S4="",v4=i3.data}),n3(d3,r4.slash,function(){v4=i3.tagEnd,C3(a2.openTag,P4)}),n3(d3,r4.char,function(t8){(P4+=t8)==="![CDATA["&&(v4=i3.cdata,S4="",P4="")}),d3)),n3(y3,i3.tagEnd,(n3(l2={},r4.gt,function(){C3(a2.closeTag,P4),S4="",v4=i3.data}),n3(l2,r4.char,o4),l2)),n3(y3,i3.attributeNameStart,(n3(u4={},r4.char,function(t8){b3=t8,v4=i3.attributeName}),n3(u4,r4.gt,function(){S4="",v4=i3.data}),n3(u4,r4.space,o4),n3(u4,r4.slash,function(){N4=!0,v4=i3.tagEnd}),u4)),n3(y3,i3.attributeName,(n3(p2={},r4.space,function(){v4=i3.attributeNameEnd}),n3(p2,r4.equal,function(){C3(a2.attributeName,b3),v4=i3.attributeValueBegin}),n3(p2,r4.gt,function(){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),S4="",v4=i3.data}),n3(p2,r4.slash,function(){N4=!0,M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),v4=i3.tagEnd}),n3(p2,r4.char,function(t8){b3+=t8}),p2)),n3(y3,i3.attributeNameEnd,(n3(m3={},r4.space,o4),n3(m3,r4.equal,function(){C3(a2.attributeName,b3),v4=i3.attributeValueBegin}),n3(m3,r4.gt,function(){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),S4="",v4=i3.data}),n3(m3,r4.char,function(t8){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),b3=t8,v4=i3.attributeName}),m3)),n3(y3,i3.attributeValueBegin,(n3(f2={},r4.space,o4),n3(f2,r4.quote,function(t8){I4=t8,M5="",v4=i3.attributeValue}),n3(f2,r4.gt,function(){C3(a2.attributeValue,M5=""),S4="",v4=i3.data}),n3(f2,r4.char,function(t8){I4="",M5=t8,v4=i3.attributeValue}),f2)),n3(y3,i3.attributeValue,(n3(g4={},r4.space,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),v4=i3.attributeNameStart)}),n3(g4,r4.quote,function(t8){I4===t8?(C3(a2.attributeValue,M5),v4=i3.attributeNameStart):M5+=t8}),n3(g4,r4.gt,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),S4="",v4=i3.data)}),n3(g4,r4.slash,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),N4=!0,v4=i3.tagEnd)}),n3(g4,r4.char,function(t8){M5+=t8}),g4)),y3);var _4=function(e6){t7.debug&&console.log(v4,e6);var n4=x3.stateMachine[v4],s4=n4[(function(t8){return c3[t8]||r4.char})(e6)]||n4[r4.error]||n4[r4.char];s4(e6)};return x3.write=function(t8){for(var e6=t8.length,n4=0;n4<e6;n4++)_4(t8[n4])},x3}}}}),f=r3({"node_modules/xml-reader/dist/reader.js"(t5,e4){var n3=u3(),s3=m(),o4=s3.Type,i3={element:"element",text:"text"},r4=function(t7){return Object.assign({name:"",type:i3.element,value:"",parent:null,attributes:{},children:[]},t7)},a2=function(t7){t7=Object.assign({stream:!1,parentNodes:!0,doneEvent:"done",tagPrefix:"tag:",emitTopLevelOnly:!1,debug:!1},t7);var e5=void 0,a3=void 0,c3=void 0,h2=void 0,d3=new n3,l2=function(n4){switch(n4.type){case o4.openTag:if(c3===null)(c3=a3).name=n4.value;else{var s4=r4({name:n4.value,parent:c3});c3.children.push(s4),c3=s4}break;case o4.closeTag:var l3=c3.parent;if(t7.parentNodes||(c3.parent=null),c3.name!==n4.value)break;t7.stream&&l3===a3&&(a3.children=[],c3.parent=null),t7.emitTopLevelOnly&&l3!==a3||(d3.emit(t7.tagPrefix+c3.name,c3),d3.emit("tag",c3.name,c3)),c3===a3&&(e5.removeAllListeners("data"),d3.emit(t7.doneEvent,c3),a3=null),c3=l3;break;case o4.text:c3&&c3.children.push(r4({type:i3.text,value:n4.value,parent:t7.parentNodes?c3:null}));break;case o4.attributeName:h2=n4.value,c3.attributes[h2]="";break;case o4.attributeValue:c3.attributes[h2]=n4.value}};return d3.reset=function(){(e5=s3.create({debug:t7.debug})).on("data",l2),a3=r4(),c3=null,h2="",d3.parse=e5.write},d3.reset(),d3};e4.exports={parseSync:function(t7,e5){e5=Object.assign({},e5,{stream:!1,tagPrefix:":"});var n4=a2(e5),s4=void 0;return n4.on("done",function(t8){s4=t8}),n4.parse(t7),s4},create:a2,NodeType:i3}}}),g3=(...t5)=>{let e4={points:[],lines:[],circles:[],rects:[]};return t5.forEach((t7,n3)=>{t7&&(t7.lines&&(e4.lines=[...e4.lines||[],...t7.lines.map(t8=>({...t8,step:n3}))]),t7.points&&(e4.points=[...e4.points||[],...t7.points.map(t8=>({...t8,step:n3}))]),t7.circles&&(e4.circles=[...e4.circles||[],...t7.circles.map(t8=>({...t8,step:n3}))]),t7.rects&&(e4.rects=[...e4.rects||[],...t7.rects.map(t8=>({...t8,step:n3}))]))}),e4},y=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,"cacheHit");__publicField(this,"cacheKey");__publicField(this,"cacheToSolveSpaceTransform")}step(){if(!this.solved&&!this.failed){this.iterations++;try{this._step()}catch(t5){throw this.error=`${this.constructor.name} error: ${t5}`,console.error(this.error),this.failed=!0,t5}!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 (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 t5=Date.now();for(;!this.solved&&!this.failed;)this.step();let e4=Date.now();this.timeToSolve=e4-t5}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}preview(){return{lines:[],points:[],rects:[],circles:[]}}};function x(){return x=Object.assign?Object.assign.bind():function(t5){for(var e4=1;e4<arguments.length;e4++){var n3=arguments[e4];for(var s3 in n3)({}).hasOwnProperty.call(n3,s3)&&(t5[s3]=n3[s3])}return t5},x.apply(null,arguments)}function v3(t5,e4){return(v3=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t7,e5){return t7.__proto__=e5,t7})(t5,e4)}function S3(t5){return(S3=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t7){return t7.__proto__||Object.getPrototypeOf(t7)})(t5)}function P3(){try{var t5=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch{}return(P3=function(){return!!t5})()}function b(t5){var e4=typeof Map=="function"?new Map:void 0;return b=function(t7){if(t7===null||!(function(t8){try{return Function.toString.call(t8).indexOf("[native code]")!==-1}catch{return typeof t8=="function"}})(t7))return t7;if(typeof t7!="function")throw new TypeError("Super expression must either be null or a function");if(e4!==void 0){if(e4.has(t7))return e4.get(t7);e4.set(t7,n3)}function n3(){return(function(t8,e5,n4){if(P3())return Reflect.construct.apply(null,arguments);var s3=[null];s3.push.apply(s3,e5);var o4=new(t8.bind.apply(t8,s3));return n4&&v3(o4,n4.prototype),o4})(t7,arguments,S3(this).constructor)}return n3.prototype=Object.create(t7.prototype,{constructor:{value:n3,enumerable:!1,writable:!0,configurable:!0}}),v3(n3,t7)},b(t5)}var M3={1:`Passed invalid arguments to hsl, please pass multiple numbers e.g. hsl(360, 0.75, 0.4) or an object e.g. rgb({ hue: 255, saturation: 0.4, lightness: 0.75 }).
|
|
361
361
|
|
|
362
362
|
`,2:`Passed invalid arguments to hsla, please pass multiple numbers e.g. hsla(360, 0.75, 0.4, 0.7) or an object e.g. rgb({ hue: 255, saturation: 0.4, lightness: 0.75, alpha: 0.7 }).
|
|
363
363
|
|
|
@@ -539,7 +539,7 @@ obs: ${n4._containsObstacle?"yes":"no"}`})}if(Lo2(t5))for(let[n4,s3]of t5.portPo
|
|
|
539
539
|
`)}),e4.points.push({x:o6.x,y:o6.y,color:s3,label:[`End: ${n4.connection.name}`,`${n4.connection.rootConnectionName}`].join(`
|
|
540
540
|
`)}),e4.circles.push({center:o6,radius:.08,stroke:s3,label:`Goal: ${n4.connection.name}`})}}let o4=[...t5.candidates].sort((t7,e5)=>t7.f-e5.f).slice(0,1);for(let i3 of o4){let o5=[],r4=i3;for(;r4;)o5.unshift({x:r4.point.x,y:r4.point.y,z:r4.z,lastMoveWasOffBoard:r4.lastMoveWasOffBoard,nodeId:r4.currentNodeId}),r4=r4.prevCandidate;for(let n5=0;n5<o5.length-1;n5++){let i4=o5[n5],r6=o5[n5+1],a2=i4.z===r6.z,c3=i4.z,h2;h2=r6.lastMoveWasOffBoard?"2 2":a2?c3===0?void 0:"10 5":"3 3 10";let d3=i4.nodeId?t5.nodeMap.get(i4.nodeId):null,l2=.02*i4.z;if(d3&&zo2(i4,r6,d3.center,d3.width,d3.height)){let t7=Do2(i4,r6,d3.center,d3.width,d3.height);e4.lines.push({points:[{x:i4.x+l2,y:i4.y+l2},{x:t7.x+l2,y:t7.y+l2}],strokeColor:it2(s3,.25),strokeDash:h2}),e4.lines.push({points:[{x:t7.x+l2,y:t7.y+l2},{x:r6.x+l2,y:r6.y+l2}],strokeColor:it2(s3,.25),strokeDash:h2})}else e4.lines.push({points:[{x:i4.x+l2,y:i4.y+l2},{x:r6.x+l2,y:r6.y+l2}],strokeColor:it2(s3,.25),strokeDash:h2})}if(o5.length>=1){let r6=o5[o5.length-1],a2=0,c3=0,h2=0,d3=0,l2=0,u4=0,p2=t5.nodeMap.get(i3.prevCandidate?.currentNodeId);if(p2&&i3.prevCandidate&&i3.portPoint&&n4){let e5=n4.connection.name,s4={x:i3.prevCandidate.point.x,y:i3.prevCandidate.point.y,z:i3.prevCandidate.z,connectionName:e5},o6={x:i3.portPoint.x,y:i3.portPoint.y,z:i3.portPoint.z,connectionName:e5},r7=t5.buildNodeWithPortPointsForCrossing(p2,[s4,o6]),m4=de2(r7);h2=m4.numSameLayerCrossings,d3=m4.numTransitionPairCrossings,l2=m4.numEntryExitLayerChanges;let f4=t5.capacityMeshNodeMap.get(p2.capacityMeshNodeId);f4&&(c3=t5.JUMPER_PF_FN_ENABLED&&p2.availableZ.length===1?Ao2(f4,h2):Co2(f4,h2,l2,d3),a2=c3**2*t5.NODE_PF_FACTOR),u4=i3.prevCandidate.g>0?i3.g-i3.prevCandidate.g:i3.g}if(!n4)continue;let[m3,f2]=n4.nodeIds,g4=t5.nodeMap.get(f2),y3=g4?Math.sqrt((r6.x-g4.center.x)**2+(r6.y-g4.center.y)**2):0,x3=t5.avgNodePitch>0?y3/t5.avgNodePitch:0,v4=x3*t5.BASE_CANDIDATE_COST,S4=t5.nodeMemoryPfMap.get(i3.currentNodeId)??0,P4=-Math.log(1-S4)*t5.MEMORY_PF_FACTOR;e4.circles.push({center:r6,radius:.03,fill:it2(s3,.25),layer:`z${i3.z}`,label:[`f: ${i3.f.toFixed(2)}`,`g: ${i3.g.toFixed(2)} (nodeDelta: ${u4.toFixed(2)})`,`h: ${i3.h.toFixed(2)}`,` dist: ${y3.toFixed(2)}`,` estHops: ${x3.toFixed(1)}`,` estStepCost: ${v4.toFixed(2)}`,` memRiskCost: ${P4.toFixed(2)}`,`z: ${i3.z}`,`node: ${i3.currentNodeId}`,`Cost(Pf): ${a2.toFixed(3)}`,`Pf: ${c3.toFixed(3)}`,`xSame: ${h2}, xTrans: ${d3}, xLC: ${l2}`,`routeOffBoard=${t5.currentConnectionShouldRouteOffBoard}`,`offBoardTouched=${i3.hasTouchedOffBoardNode??!1}`,`lastMoveWasOffBoard=${i3.lastMoveWasOffBoard??!1}`].join(`
|
|
541
541
|
`)})}}}return e4}function Xo2(t5,e4){let n3=[],s3=e4.filter(t7=>t7._containsTarget),o4=new Map;for(let i3 of t5.connections){let t7=[];for(let n4 of i3.pointsToConnect){let o5=e4[0],i4=Number.MAX_VALUE;for(let t8 of s3){let e5=Math.sqrt((t8.center.x-n4.x)**2+(t8.center.y-n4.y)**2);e5<i4&&(i4=e5,o5=t8)}t7.push(o5)}if(t7.length<2)throw new Error(`Not enough nodes for connection "${i3.name}", only ${t7.length} found`);o4.set(i3.name,t7.map(t8=>t8.capacityMeshNodeId)),n3.push({connection:i3,nodeIds:[t7[0].capacityMeshNodeId,t7[t7.length-1].capacityMeshNodeId],straightLineDistance:St2(t7[0].center,t7[t7.length-1].center)})}return{unshuffledConnectionsWithResults:n3,connectionNameToGoalNodeIds:o4}}function Yo2(t5,e4){let n3=new Map(e4.map(t7=>[t7.capacityMeshNodeId,t7])),s3=e4.map(t7=>(t7.width+t7.height)/2).filter(t7=>Number.isFinite(t7)&&t7>0),o4=s3.length>0?s3.reduce((t7,e5)=>t7+e5,0)/s3.length:1,i3=e4.filter(t7=>t7._offBoardConnectionId),r4=new Map,a2=new Map,c3=new Map;for(let t7 of e4)a2.set(t7.capacityMeshNodeId,[]),c3.set(t7.capacityMeshNodeId,[]);for(let t7 of e4)for(let e5 of t7.portPoints){r4.set(e5.portPointId,e5);for(let t8 of e5.connectionNodeIds){let n4=a2.get(t8);n4&&!n4.some(t10=>t10.portPointId===e5.portPointId)&&n4.push(e5)}}let{unshuffledConnectionsWithResults:h2,connectionNameToGoalNodeIds:d3}=Xo2(t5,e4);return{nodeMap:n3,avgNodePitch:o4,offBoardNodes:i3,portPointMap:r4,nodePortPointsMap:a2,nodeAssignedPortPoints:c3,unshuffledConnectionsWithResults:h2,connectionNameToGoalNodeIds:d3}}function $o2(t5,e4,n3){let s3=0,o4=n3?.NODE_MAX_PF??.99999;for(let n4 of t5){let t7=e4.get(n4.capacityMeshNodeId);if(!t7||t7._containsTarget)continue;let i3=Ro2(n4),r4=Math.min(Co2(t7,i3.numSameLayerCrossings,i3.numEntryExitLayerChanges,i3.numTransitionPairCrossings),o4);s3+=Math.log(1-r4)}return s3}function ko2(t5,e4){if(e4._containsTarget)return 0;let n3=Ro2(t5);return Co2(e4,n3.numSameLayerCrossings,n3.numEntryExitLayerChanges,n3.numTransitionPairCrossings)}function Bo2(t5,e4,n3,s3,o4){let i3=n3-e4,r4=o4-s3,a2=1e-6;if(Math.abs(t5.y-o4)<a2)return t5.x-e4;if(Math.abs(t5.x-n3)<a2)return i3+(o4-t5.y);if(Math.abs(t5.y-s3)<a2)return i3+r4+(n3-t5.x);if(Math.abs(t5.x-e4)<a2)return 2*i3+r4+(t5.y-s3);let c3=Math.abs(t5.y-o4),h2=Math.abs(t5.x-n3),d3=Math.abs(t5.y-s3),l2=Math.abs(t5.x-e4),u4=Math.min(c3,h2,d3,l2);return u4===c3?Math.max(0,Math.min(i3,t5.x-e4)):u4===h2?i3+Math.max(0,Math.min(r4,o4-t5.y)):u4===d3?i3+r4+Math.max(0,Math.min(i3,n3-t5.x)):2*i3+r4+Math.max(0,Math.min(r4,t5.y-s3))}function jo2(t5,e4,n3){let s3=0,o4=n3?.NODE_MAX_PF??.99999;for(let n4 of t5){let t7=e4.get(n4.capacityMeshNodeId);if(!t7||t7._containsTarget)continue;let i3=Ro2(n4),r4=Math.min(Ao2(t7,i3.numSameLayerCrossings),o4);s3+=Math.log(1-r4)}return s3}function Wo2(t5){let e4=t5;return()=>{e4+=1831565813;let t7=e4;return t7=Math.imul(t7^t7>>>15,1|t7),t7^=t7+Math.imul(t7^t7>>>7,61|t7),((t7^t7>>>14)>>>0)/4294967296}}var Ho2=[{SHUFFLE_SEED:100,NODE_PF_FACTOR:100,NODE_PF_MAX_PENALTY:100,MEMORY_PF_FACTOR:0,EXPANSION_DEGREES:10,FORCE_CENTER_FIRST:!0,FORCE_OFF_BOARD_FREQUENCY:0,CENTER_OFFSET_DIST_PENALTY_FACTOR:0}],Uo2=class extends y{constructor(t5){super();__publicField(this,"simpleRouteJson");__publicField(this,"inputNodes");__publicField(this,"capacityMeshNodes");__publicField(this,"capacityMeshEdges");__publicField(this,"colorMap");__publicField(this,"nodeMap");__publicField(this,"capacityMeshNodeMap");__publicField(this,"connectionResults");__publicField(this,"assignedPortPoints");__publicField(this,"nodeAssignedPortPoints");__publicField(this,"sections",[]);__publicField(this,"activeSubSolver",null);__publicField(this,"currentSection",null);__publicField(this,"sectionScoreBeforeOptimization",0);__publicField(this,"currentSectionCenterNodeId",null);__publicField(this,"currentScheduleIndex",0);__publicField(this,"nodePfMap",new Map);__publicField(this,"attemptsToFixNode",new Map);__publicField(this,"sectionAttempts",0);__publicField(this,"MAX_ATTEMPTS_PER_NODE",100);__publicField(this,"MAX_SECTION_ATTEMPTS",50);__publicField(this,"ACCEPTABLE_PF",.05);__publicField(this,"FRACTION_TO_REPLACE",.2);__publicField(this,"JUMPER_PF_FN_ENABLED",!1);__publicField(this,"SHUFFLE_SEEDS_PER_SECTION",null);__publicField(this,"ALWAYS_RIP_INTERSECTIONS",!0);__publicField(this,"effort",1);__publicField(this,"HYPERPARAMETER_SCHEDULE",Ho2);__publicField(this,"currentSectionCutPathInfo",new Map);__publicField(this,"currentSectionKeptPortPoints",new Map);__publicField(this,"currentSectionFixedRoutes",[]);this.MAX_ITERATIONS=1e6,this.simpleRouteJson=t5.simpleRouteJson,this.inputNodes=t5.inputNodes,this.capacityMeshNodes=t5.capacityMeshNodes,this.capacityMeshEdges=t5.capacityMeshEdges,this.colorMap=t5.colorMap??{},this.effort=t5.effort??1,t5.FRACTION_TO_REPLACE!==void 0&&(this.FRACTION_TO_REPLACE=t5.FRACTION_TO_REPLACE),t5.ALWAYS_RIP_INTERSECTIONS!==void 0&&(this.ALWAYS_RIP_INTERSECTIONS=t5.ALWAYS_RIP_INTERSECTIONS),t5.MAX_ATTEMPTS_PER_NODE!==void 0&&(this.MAX_ATTEMPTS_PER_NODE=t5.MAX_ATTEMPTS_PER_NODE),t5.MAX_SECTION_ATTEMPTS!==void 0&&(this.MAX_SECTION_ATTEMPTS=t5.MAX_SECTION_ATTEMPTS),t5.HYPERPARAMETER_SCHEDULE!==void 0&&(this.HYPERPARAMETER_SCHEDULE=t5.HYPERPARAMETER_SCHEDULE),this.JUMPER_PF_FN_ENABLED=t5.JUMPER_PF_FN_ENABLED??this.JUMPER_PF_FN_ENABLED,this.SHUFFLE_SEEDS_PER_SECTION=t5.SHUFFLE_SEEDS_PER_SECTION,this.MAX_SECTION_ATTEMPTS*=this.effort,this.nodeMap=new Map(t5.inputNodes.map(t7=>[t7.capacityMeshNodeId,t7])),this.capacityMeshNodeMap=new Map(t5.capacityMeshNodes.map(t7=>[t7.capacityMeshNodeId,t7])),this.connectionResults=[...t5.initialConnectionResults],this.assignedPortPoints=new Map(t5.initialAssignedPortPoints),this.nodeAssignedPortPoints=new Map(t5.initialNodeAssignedPortPoints),this.nodePfMap=this.computeInitialPfMap();let e4=this.computeBoardScore();this.stats.successfulOptimizations=0,this.stats.failedOptimizations=0,this.stats.nodesExamined=0,this.stats.sectionAttempts=0,this.stats.sectionScores={},this.stats.initialBoardScore=e4,this.stats.currentBoardScore=e4,this.stats.errors=0}computeInitialPfMap(){let t5=new Map;for(let e4 of this.capacityMeshNodes){let n3=this.nodeAssignedPortPoints.get(e4.capacityMeshNodeId)??[];if(n3.length===0)continue;let s3={capacityMeshNodeId:e4.capacityMeshNodeId,center:e4.center,width:e4.width,height:e4.height,portPoints:n3,availableZ:e4.availableZ},o4=this.JUMPER_PF_FN_ENABLED&&e4.availableZ.length===1?Ao2(e4,Ro2(s3).numSameLayerCrossings):ko2(s3,e4);t5.set(e4.capacityMeshNodeId,o4)}return t5}computeBoardScore(){let t5=this.getNodesWithPortPoints();return this.computeScoreForNodes(t5)}computeScoreForNodes(t5){return this.JUMPER_PF_FN_ENABLED?jo2(t5,this.capacityMeshNodeMap):$o2(t5,this.capacityMeshNodeMap)}recomputePfForNodes(t5){for(let e4 of t5){let t7=this.capacityMeshNodeMap.get(e4);if(!t7)continue;let n3=this.nodeAssignedPortPoints.get(e4)??[];if(n3.length===0){this.nodePfMap.set(e4,0);continue}let s3={capacityMeshNodeId:e4,center:t7.center,width:t7.width,height:t7.height,portPoints:n3,availableZ:t7.availableZ},o4=this.JUMPER_PF_FN_ENABLED&&t7.availableZ.length===1?Ao2(t7,Ro2(s3).numSameLayerCrossings):ko2(s3,t7);this.nodePfMap.set(e4,o4)}}getCreatePortPointSectionInput(){return{inputNodes:this.inputNodes,capacityMeshNodes:this.capacityMeshNodes,capacityMeshEdges:this.capacityMeshEdges,nodeMap:this.nodeMap,connectionResults:this.connectionResults}}createSection(t5){return(function(t7,e4){let{inputNodes:n3,capacityMeshNodes:s3,capacityMeshEdges:o4,connectionResults:i3}=t7,{centerOfSectionCapacityNodeId:r4,expansionDegrees:a2}=e4,c3=new Map;for(let t8 of o4){let[e5,n4]=t8.nodeIds;c3.has(e5)||c3.set(e5,new Set),c3.has(n4)||c3.set(n4,new Set),c3.get(e5).add(n4),c3.get(n4).add(e5)}let h2=new Set,d3=new Set,l2=[];for(l2.push({nodeId:r4,depth:0}),d3.add(r4);l2.length>0;){let{nodeId:t8,depth:e5}=l2.shift();if(h2.add(t8),e5<a2){let n4=c3.get(t8)??new Set;for(let t10 of n4)d3.has(t10)||(d3.add(t10),l2.push({nodeId:t10,depth:e5+1}))}}let u4=n3.filter(t8=>h2.has(t8.capacityMeshNodeId)),p2=s3.filter(t8=>h2.has(t8.capacityMeshNodeId)),m3=[],f2=[];for(let t8 of o4){let[e5,n4]=t8.nodeIds,s4=h2.has(e5),o5=h2.has(n4);s4&&o5?m3.push(t8):(s4||o5)&&f2.push(t8)}let g4=u4.map(t8=>{let e5=t8.portPoints.filter(t10=>{let[e6,n4]=t10.connectionNodeIds,s4=h2.has(e6),o5=h2.has(n4);return s4||o5});return{...t8,portPoints:e5}}),y3=(function(t8,e5){let n4=[];for(let s4 of t8){if(!s4.path||s4.path.length===0)continue;let t10=s4.connection.name,o5=s4.connection.rootConnectionName,i4=[];for(let t11=0;t11<s4.path.length;t11++){let n5=s4.path[t11];e5.has(n5.currentNodeId)&&i4.push(t11)}if(i4.length===0)continue;let r6=i4[0],a3=i4[i4.length-1],c4=r6,h3=a3;if(r6>0){let t11=s4.path[0].currentNodeId;(s4.nodeIds[0]===t11||s4.nodeIds[1]===t11)&&(c4=0)}if(a3<s4.path.length-1){let t11=s4.path.length-1,e6=s4.path[t11].currentNodeId;(s4.nodeIds[0]===e6||s4.nodeIds[1]===e6)&&(h3=t11)}let d4=s4.path.slice(c4,h3+1),l3=c4>0,u5=h3<s4.path.length-1;n4.push({connectionName:t10,rootConnectionName:o5,points:d4.map(t11=>({x:t11.point.x,y:t11.point.y,z:t11.z,nodeId:t11.currentNodeId,portPointId:t11.portPoint?.portPointId})),originalStartIndex:c4,originalEndIndex:h3,hasEntryFromOutside:l3,hasExitToOutside:u5})}return n4})(i3??[],h2);return{centerNodeId:r4,expansionDegrees:a2,nodeIds:h2,inputNodes:g4,capacityMeshNodes:p2,internalEdges:m3,boundaryEdges:f2,sectionPaths:y3}})(this.getCreatePortPointSectionInput(),t5)}getSectionNodesWithPortPoints(t5){let e4=[];for(let n3 of t5.nodeIds){let t7=this.nodeMap.get(n3),s3=this.capacityMeshNodeMap.get(n3);if(!t7||!s3)continue;let o4=this.nodeAssignedPortPoints.get(n3)??[];o4.length>0&&e4.push({capacityMeshNodeId:n3,center:t7.center,width:t7.width,height:t7.height,portPoints:o4,availableZ:t7.availableZ})}return e4}getNodesWithPortPoints(){let t5=[];for(let e4 of this.inputNodes){let n3=this.nodeAssignedPortPoints.get(e4.capacityMeshNodeId)??[];n3.length>0&&t5.push({capacityMeshNodeId:e4.capacityMeshNodeId,center:e4.center,width:e4.width,height:e4.height,portPoints:n3,availableZ:e4.availableZ})}return t5}findHighestPfNode(){let t5=null,e4=0;for(let[n3,s3]of this.nodePfMap.entries())s3*(1-(this.attemptsToFixNode.get(n3)??0)/this.MAX_ATTEMPTS_PER_NODE)**2>e4&&(e4=s3,t5=n3);return!t5||e4<this.ACCEPTABLE_PF?null:t5}determineConnectionsToRip(t5,e4){let n3=31337*this.sectionAttempts,s3=Wo2(n3);if(this.FRACTION_TO_REPLACE>=1)return new Set(e4);let o4=(function(t7,e5){let n4=Wo2(e5),s4=[...t7];for(let t8=s4.length-1;t8>0;t8--){let e6=Math.floor(n4()*(t8+1));[s4[t8],s4[e6]]=[s4[e6],s4[t8]]}return s4})(e4,n3),i3=Math.max(1,Math.ceil(o4.length*this.FRACTION_TO_REPLACE)),r4=new Set(o4.slice(0,i3));if(this.ALWAYS_RIP_INTERSECTIONS){let n4=(function(t7){let{section:e5,nodePfMap:n5,capacityMeshNodeMap:s4,nodeAssignedPortPoints:o5,acceptablePf:i4}=t7,r6=[];for(let t8 of e5.nodeIds){if((n5.get(t8)??0)<=i4)continue;let e6=s4.get(t8);if(!e6)continue;let a2=o5.get(t8)??[];if(a2.length<2)continue;let c3=e6.center.x-e6.width/2,h2=e6.center.x+e6.width/2,d3=e6.center.y-e6.height/2,l2=e6.center.y+e6.height/2,u4=new Map;for(let t10 of a2){let e7=u4.get(t10.connectionName)??[];e7.some(e8=>e8.x===t10.x&&e8.y===t10.y&&e8.z===t10.z)||e7.push({x:t10.x,y:t10.y,z:t10.z}),u4.set(t10.connectionName,e7)}let p2=new Map;for(let[t10,e7]of u4){if(e7.length<2)continue;let n6=e7[0],s5=e7[1];if(n6.z!==s5.z)continue;let o6=Bo2(n6,c3,h2,d3,l2),i5=Bo2(s5,c3,h2,d3,l2),r7=n6.z,a3=p2.get(r7)??[];a3.push({connectionName:t10,t1:o6,t2:i5}),p2.set(r7,a3)}let m3=1e-6;for(let[,t10]of p2){let e7=t10.map(t11=>({connectionName:t11.connectionName,a:Math.min(t11.t1,t11.t2),b:Math.max(t11.t1,t11.t2)}));for(let t11=0;t11<e7.length;t11++){let{connectionName:n6,a:s5,b:o6}=e7[t11];for(let i5=t11+1;i5<e7.length;i5++){let{connectionName:t12,a:a3,b:c4}=e7[i5];Math.abs(s5-a3)<m3||Math.abs(s5-c4)<m3||Math.abs(o6-a3)<m3||Math.abs(o6-c4)<m3||(s5<a3&&a3<o6&&o6<c4||a3<s5&&s5<c4&&c4<o6)&&r6.push([n6,t12])}}}}return r6})({section:t5,nodePfMap:this.nodePfMap,capacityMeshNodeMap:this.capacityMeshNodeMap,nodeAssignedPortPoints:this.nodeAssignedPortPoints,acceptablePf:this.ACCEPTABLE_PF});for(let[t7,o5]of n4){if(r4.has(t7)||r4.has(o5))continue;let n5=e4.includes(t7),i4=e4.includes(o5);if(n5&&i4){let e5=s3()<.5;r4.add(e5?t7:o5)}else n5?r4.add(t7):i4&&r4.add(o5)}}return this.stats.lastRipCount=r4.size,r4}createSectionSimpleRouteJson(t5){let e4=[];this.currentSectionCutPathInfo.clear(),this.currentSectionKeptPortPoints.clear(),this.currentSectionFixedRoutes=[];let n3=[],s3=[];for(let e5 of this.connectionResults){if(!e5.path||e5.path.length===0)continue;let[o5,i4]=e5.nodeIds,r6=t5.nodeIds.has(o5),a2=t5.nodeIds.has(i4);r6&&a2&&(s3.push(e5),n3.push(e5.connection.name))}let o4=[];for(let e5 of t5.sectionPaths){if(!e5.hasEntryFromOutside&&!e5.hasExitToOutside||e5.points.length<2)continue;let t7=this.connectionResults.find(t8=>t8.connection.name===e5.connectionName);t7&&(o4.push({sectionPath:e5,originalResult:t7}),n3.includes(e5.connectionName)||n3.push(e5.connectionName))}let i3=this.determineConnectionsToRip(t5,n3);for(let t7 of s3)i3.has(t7.connection.name)&&e4.push(t7.connection);for(let{sectionPath:t7,originalResult:n4}of o4){if(!i3.has(t7.connectionName))continue;let s4=`__cut__${t7.connectionName}__${t7.originalStartIndex}`;this.colorMap[s4]=this.colorMap[t7.connectionName];let o5=t7.points[0],r6=t7.points[t7.points.length-1],a2={name:s4,rootConnectionName:t7.rootConnectionName??t7.connectionName,pointsToConnect:[{x:o5.x,y:o5.y,layers:[`layer${o5.z+1}`]},{x:r6.x,y:r6.y,layers:[`layer${r6.z+1}`]}]};e4.push(a2),this.currentSectionCutPathInfo.set(s4,{sectionPath:t7,originalConnectionResult:n4})}let r4=new Set(n3.filter(t7=>!i3.has(t7)));if(r4.size>0){for(let e5 of t5.nodeIds){let t7=(this.nodeAssignedPortPoints.get(e5)??[]).filter(t8=>r4.has(t8.connectionName));t7.length>0&&this.currentSectionKeptPortPoints.set(e5,t7)}for(let t7 of s3)r4.has(t7.connection.name)&&this.currentSectionFixedRoutes.push(t7);for(let{sectionPath:t7,originalResult:e5}of o4)if(r4.has(t7.connectionName)){let n4={connection:{name:t7.connectionName,rootConnectionName:t7.rootConnectionName,pointsToConnect:e5.connection.pointsToConnect},path:t7.points.map(t8=>({prevCandidate:null,portPoint:null,currentNodeId:t8.nodeId,point:{x:t8.x,y:t8.y},z:t8.z,f:0,g:0,h:0,distanceTraveled:0})),portPoints:t7.points.map(e6=>({portPointId:e6.portPointId,x:e6.x,y:e6.y,z:e6.z,connectionName:t7.connectionName,rootConnectionName:t7.rootConnectionName})),nodeIds:e5.nodeIds,straightLineDistance:e5.straightLineDistance};this.currentSectionFixedRoutes.push(n4)}}return{...this.simpleRouteJson,connections:e4}}prepareSectionInputNodesForCutPaths(t5){let e4=new Set;for(let[,t7]of this.currentSectionCutPathInfo.entries()){let{sectionPath:n3}=t7;if(n3.points.length===0)continue;let s3=n3.points[0].nodeId;e4.add(s3);let o4=n3.points[n3.points.length-1].nodeId;e4.add(o4)}return t5.inputNodes.map(t7=>e4.has(t7.capacityMeshNodeId)?{...t7,_containsTarget:!0}:t7)}getHyperParametersForScheduleIndex(t5,e4){let n3=this.HYPERPARAMETER_SCHEDULE[t5];return{...n3,SHUFFLE_SEED:(n3.SHUFFLE_SEED??0)+17*e4}}createSectionSolver(t5){let e4=this.createSectionSimpleRouteJson(t5),n3=this.prepareSectionInputNodesForCutPaths(t5),s3=Yo2(e4,n3);for(let[t7,e5]of this.currentSectionKeptPortPoints){let n4=s3.nodeAssignedPortPoints.get(t7)??[];s3.nodeAssignedPortPoints.set(t7,[...n4,...e5])}return new Zo2({simpleRouteJson:e4,inputNodes:n3,capacityMeshNodes:t5.capacityMeshNodes,colorMap:this.colorMap,nodeMemoryPfMap:this.nodePfMap,numShuffleSeeds:this.SHUFFLE_SEEDS_PER_SECTION??2*e4.connections.length*this.effort,hyperParameters:{...this.getHyperParametersForScheduleIndex(this.currentScheduleIndex,this.sectionAttempts)},precomputedInitialParams:s3,fixedRoutes:this.currentSectionFixedRoutes})}reattachSection(t5,e4,n3,s3){let o4=[],i3=[];for(let t7 of e4)t7.connection.name.startsWith("__cut__")?i3.push(t7):o4.push(t7);let r4=new Set(o4.map(t7=>t7.connection.name));this.connectionResults=this.connectionResults.filter(t7=>!r4.has(t7.connection.name)),this.connectionResults.push(...o4);for(let[e5,n4]of this.nodeAssignedPortPoints.entries()){if(!t5.nodeIds.has(e5))continue;let s4=n4.filter(t7=>!r4.has(t7.connectionName));this.nodeAssignedPortPoints.set(e5,s4)}for(let[t7,e5]of this.assignedPortPoints.entries())r4.has(e5.connectionName)&&this.assignedPortPoints.delete(t7);for(let e5 of i3){let n4=this.currentSectionCutPathInfo.get(e5.connection.name);if(!n4||!e5.path)continue;let{sectionPath:s4,originalConnectionResult:o5}=n4,i4=o5.path;if(!i4)continue;let r6=s4.connectionName;for(let[e6,n5]of this.nodeAssignedPortPoints.entries()){let s5=n5.filter(n6=>n6.connectionName!==r6||!t5.nodeIds.has(e6));this.nodeAssignedPortPoints.set(e6,s5)}let a2=i4.slice(0,s4.originalStartIndex),c3=i4.slice(s4.originalEndIndex+1),h2=[],d3=a2.length>0?a2[a2.length-1]:null;for(let t7 of e5.path){let e6={...t7,prevCandidate:d3};h2.push(e6),d3=e6}if(c3.length>0&&h2.length>0&&(c3[0]={...c3[0],prevCandidate:h2[h2.length-1]}),o5.path=[...a2,...h2,...c3],e5.portPoints)for(let n5 of e5.portPoints){let e6={...n5,connectionName:r6,rootConnectionName:s4.rootConnectionName??r6};for(let s5 of t5.inputNodes)for(let t7 of s5.portPoints)if(Math.abs(t7.x-n5.x)<.001&&Math.abs(t7.y-n5.y)<.001&&t7.z===n5.z){for(let n6 of t7.connectionNodeIds){let t8=this.nodeAssignedPortPoints.get(n6)??[];t8.push(e6),this.nodeAssignedPortPoints.set(n6,t8)}break}}}for(let[t7,e5]of n3.entries())e5.connectionName.startsWith("__cut__")||this.assignedPortPoints.set(t7,e5);for(let[t7,e5]of s3.entries()){let n4=e5.filter(t8=>!t8.connectionName.startsWith("__cut__"));if(n4.length>0){let e6=this.nodeAssignedPortPoints.get(t7)??[];this.nodeAssignedPortPoints.set(t7,[...e6,...n4])}}}_step(){if(this.activeSubSolver){if(this.activeSubSolver.step(),this.activeSubSolver.solved||this.activeSubSolver.failed){if(this.activeSubSolver.failed){if(this.currentScheduleIndex++,this.activeSubSolver.error&&this.stats.errors++,this.currentScheduleIndex<this.HYPERPARAMETER_SCHEDULE.length&&this.currentSectionCenterNodeId){let t8=this.HYPERPARAMETER_SCHEDULE[this.currentScheduleIndex];this.currentSection=this.createSection({centerOfSectionCapacityNodeId:this.currentSectionCenterNodeId,expansionDegrees:t8.EXPANSION_DEGREES}),this.activeSubSolver=this.createSectionSolver(this.currentSection)}else this.stats.failedOptimizations++,this.activeSubSolver=null,this.currentSection=null,this.currentSectionCenterNodeId=null,this.currentScheduleIndex=0;return}let t7=this.activeSubSolver.getNodesWithPortPoints().map(t8=>({...t8,portPoints:t8.portPoints.map(t10=>{if(t10.connectionName.startsWith("__cut__")){let e6=t10.connectionName.slice(7),n5=e6.lastIndexOf("__"),s4=n5>=0?e6.slice(0,n5):e6;return{...t10,connectionName:s4}}return t10})})),e5=new Set;for(let n5 of t7)for(let t8 of n5.portPoints)e5.add(t8.connectionName);let n4=this.getSectionNodesWithPortPoints(this.currentSection).map(t8=>({...t8,portPoints:t8.portPoints.filter(t10=>e5.has(t10.connectionName))})).filter(t8=>t8.portPoints.length>0),s3=this.computeScoreForNodes(n4),o4=this.computeScoreForNodes(t7),i3=`attempt${this.sectionAttempts}`;if(this.stats.lastSectionScore=o4,o4>s3){let t8=this.stats.currentBoardScore;this.stats.lastBoardScore=t8;let e6=[...this.connectionResults],n5=new Map(this.assignedPortPoints),s4=new Map(Array.from(this.nodeAssignedPortPoints.entries()).map(([t10,e7])=>[t10,[...e7]]));this.reattachSection(this.currentSection,this.activeSubSolver.connectionsWithResults,this.activeSubSolver.assignedPortPoints,this.activeSubSolver.nodeAssignedPortPoints),this.recomputePfForNodes(this.currentSection.nodeIds);let o5=this.computeBoardScore();this.stats.sectionScores[i3]=o5,o5>t8?(this.stats.successfulOptimizations++,this.stats.currentBoardScore=o5):(this.connectionResults=e6,this.assignedPortPoints=n5,this.nodeAssignedPortPoints=s4,this.recomputePfForNodes(this.currentSection.nodeIds),this.stats.failedOptimizations++),this.activeSubSolver=null,this.currentSection=null,this.currentSectionCenterNodeId=null,this.currentScheduleIndex=0}else if(this.currentScheduleIndex++,this.currentScheduleIndex<this.HYPERPARAMETER_SCHEDULE.length&&this.currentSectionCenterNodeId){let t8=this.HYPERPARAMETER_SCHEDULE[this.currentScheduleIndex];this.currentSection=this.createSection({centerOfSectionCapacityNodeId:this.currentSectionCenterNodeId,expansionDegrees:t8.EXPANSION_DEGREES}),this.activeSubSolver=this.createSectionSolver(this.currentSection)}else this.stats.failedOptimizations++,this.activeSubSolver=null,this.currentSection=null,this.currentSectionCenterNodeId=null,this.currentScheduleIndex=0}return}if(this.sectionAttempts>=this.MAX_SECTION_ATTEMPTS)return void(this.solved=!0);let t5=this.findHighestPfNode();if(!t5)return void(this.solved=!0);this.sectionAttempts++,this.stats.sectionAttempts=this.sectionAttempts,this.stats.nodesExamined++,this.attemptsToFixNode.set(t5,(this.attemptsToFixNode.get(t5)??0)+1),this.currentSectionCenterNodeId=t5,this.currentScheduleIndex=0;let e4=this.HYPERPARAMETER_SCHEDULE[this.currentScheduleIndex];this.currentSection=this.createSection({centerOfSectionCapacityNodeId:t5,expansionDegrees:e4.EXPANSION_DEGREES});let n3=this.getSectionNodesWithPortPoints(this.currentSection);if(this.sectionScoreBeforeOptimization=this.computeScoreForNodes(n3),this.createSectionSimpleRouteJson(this.currentSection).connections.length===0)return this.currentSection=null,void(this.currentSectionCenterNodeId=null);this.activeSubSolver=this.createSectionSolver(this.currentSection)}computeProgress(){return this.sectionAttempts/this.MAX_SECTION_ATTEMPTS}visualize(){return this.solved?Fo2(this):this.activeSubSolver?this.activeSubSolver.visualize():this.currentSection?(function(t5,e4){let n3={lines:[],points:[],rects:[],circles:[]};for(let e5 of t5.inputNodes){let s3=e5.capacityMeshNodeId===t5.centerNodeId,o4=s3?"rgba(0, 200, 0, 0.3)":"rgba(200, 200, 200, 0.3)";n3.rects.push({center:e5.center,width:.9*e5.width,height:.9*e5.height,layer:`z${e5.availableZ.join(",")}`,fill:o4,label:`${e5.capacityMeshNodeId}${s3?" (CENTER)":""}`})}for(let e5 of t5.inputNodes)for(let t7 of e5.portPoints)n3.circles.push({center:{x:t7.x,y:t7.y},radius:.05,fill:"rgba(150, 150, 150, 0.5)",layer:`z${t7.z}`,label:[t7.portPointId,`cd: ${t7.distToCentermostPortOnZ}`,`connects: ${t7.connectionNodeIds.join(",")}`].filter(Boolean).join(`
|
|
542
|
-
`)});for(let s3 of t5.sectionPaths){let t7=e4?.[s3.connectionName]??"blue";for(let e5=0;e5<s3.points.length-1;e5++){let o4=s3.points[e5],i3=s3.points[e5+1],r4=o4.z===i3.z,a2=o4.z,c3;c3=r4?a2===0?"5 5":"10 5":"3 3 10",n3.lines.push({points:[{x:o4.x,y:o4.y},{x:i3.x,y:i3.y}],strokeColor:t7,strokeDash:c3})}}return n3})(this.currentSection,this.colorMap):Fo2(this)}},Vo2=class extends y{constructor(t5){super();__publicField(this,"hyperParameters");__publicField(this,"simpleRouteJson");__publicField(this,"inputNodes");__publicField(this,"nodeMap");__publicField(this,"nodePortPointsMap");__publicField(this,"portPointMap");__publicField(this,"connectionsWithResults",[]);__publicField(this,"failedConnection",null);__publicField(this,"assignedPortPoints",new Map);__publicField(this,"nodeAssignedPortPoints",new Map);__publicField(this,"PORT_POINT_REUSE_FACTOR",1e3);__publicField(this,"BASE_COST_FOR_NOT_GOING_OFF_BOARD",100);__publicField(this,"colorMap");__publicField(this,"MAX_CANDIDATES_IN_MEMORY",5e3);__publicField(this,"ITERATIONS_PER_MM_FOR_PATH",30);__publicField(this,"BASE_ITERATIONS_PER_PATH",1e4);__publicField(this,"jumpersPerMmSquared",.1);__publicField(this,"testedRipConnections",new Map);__publicField(this,"totalRipCount",0);__publicField(this,"nodeMemoryPfMap");__publicField(this,"unprocessedConnectionQueue",[]);__publicField(this,"processedConnectionQueue",[]);__publicField(this,"currentConnection",null);__publicField(this,"totalConnectionCount",0);__publicField(this,"currentPathIterations",0);__publicField(this,"candidates");__publicField(this,"visitedPortPoints");__publicField(this,"connectionNameToGoalNodeIds");__publicField(this,"capacityMeshNodeMap");__publicField(this,"avgNodePitch");__publicField(this,"currentConnectionShouldRouteOffBoard",!1);__publicField(this,"activeCandidateStraightLineDistance");__publicField(this,"offBoardNodes",[]);__publicField(this,"baseNodeCostCache",new Map);this.input=t5;let{simpleRouteJson:e4,capacityMeshNodes:n3,inputNodes:s3,colorMap:o4,nodeMemoryPfMap:i3,hyperParameters:r4,precomputedInitialParams:a2,fixedRoutes:c3}=t5;if(this.input=structuredClone(t5),this.MAX_ITERATIONS=1e8,this.simpleRouteJson=e4,this.inputNodes=s3,this.colorMap=o4??{},this.capacityMeshNodeMap=new Map(n3.map(t7=>[t7.capacityMeshNodeId,t7])),this.nodeMemoryPfMap=i3??new Map,this.hyperParameters=r4??{},a2){this.nodeMap=a2.nodeMap,this.avgNodePitch=a2.avgNodePitch,this.offBoardNodes=a2.offBoardNodes,this.portPointMap=a2.portPointMap,this.nodePortPointsMap=a2.nodePortPointsMap,this.connectionNameToGoalNodeIds=a2.connectionNameToGoalNodeIds;let{nodeAssignedPortPoints:t7}=(function(t8){let e5=new Map;for(let[n4,s4]of t8.nodeAssignedPortPoints)e5.set(n4,[...s4]);return{nodeAssignedPortPoints:e5}})(a2);this.nodeAssignedPortPoints=t7,this.connectionsWithResults=kt2(structuredClone(a2.unshuffledConnectionsWithResults),this.hyperParameters.SHUFFLE_SEED??0)}else{this.nodeMap=new Map(s3.map(t8=>[t8.capacityMeshNodeId,t8]));let t7=s3.map(t8=>(t8.width+t8.height)/2).filter(t8=>Number.isFinite(t8)&&t8>0);this.avgNodePitch=t7.length>0?t7.reduce((t8,e6)=>t8+e6,0)/t7.length:1,this.offBoardNodes=s3.filter(t8=>t8._offBoardConnectionId),this.portPointMap=new Map,this.nodePortPointsMap=new Map;for(let t8 of s3)this.nodePortPointsMap.set(t8.capacityMeshNodeId,[]),this.nodeAssignedPortPoints.set(t8.capacityMeshNodeId,[]);for(let t8 of s3)for(let e6 of t8.portPoints){this.portPointMap.set(e6.portPointId,e6);for(let t10 of e6.connectionNodeIds){let n5=this.nodePortPointsMap.get(t10);n5&&!n5.some(t11=>t11.portPointId===e6.portPointId)&&n5.push(e6)}}let{connectionsWithResults:e5,connectionNameToGoalNodeIds:n4}=this.getConnectionsWithNodes();this.connectionsWithResults=e5,this.connectionNameToGoalNodeIds=n4}if(c3&&c3.length>0){for(let t7 of c3)if(this.connectionsWithResults.push(t7),t7.portPoints)for(let e5 of t7.portPoints)e5.portPointId&&this.assignedPortPoints.set(e5.portPointId,{connectionName:e5.connectionName,rootConnectionName:e5.rootConnectionName})}for(let t7 of this.connectionsWithResults)t7.path?this.processedConnectionQueue.push(t7):this.unprocessedConnectionQueue.push(t7);this.totalConnectionCount=this.connectionsWithResults.length}get NODE_PF_FACTOR(){return this.hyperParameters.NODE_PF_FACTOR??50}get RANDOM_WALK_DISTANCE(){return this.hyperParameters.RANDOM_WALK_DISTANCE??0}get MEMORY_PF_FACTOR(){return this.hyperParameters.MEMORY_PF_FACTOR??0}get CENTER_OFFSET_FOCUS_SHIFT(){return this.hyperParameters.CENTER_OFFSET_FOCUS_SHIFT??0}get RANDOM_COST_MAGNITUDE(){return this.hyperParameters.RANDOM_COST_MAGNITUDE??0}get BASE_CANDIDATE_COST(){return this.hyperParameters.BASE_CANDIDATE_COST??0}get NODE_PF_MAX_PENALTY(){return this.hyperParameters.NODE_PF_MAX_PENALTY??1e4}get FORCE_CENTER_FIRST(){return this.hyperParameters.FORCE_CENTER_FIRST??!0}get FORCE_OFF_BOARD_FREQUENCY(){return this.offBoardNodes.length===0?0:this.hyperParameters.FORCE_OFF_BOARD_FREQUENCY??0}get FORCE_OFF_BOARD_SEED(){return this.hyperParameters.FORCE_OFF_BOARD_SEED??0}get NODE_MAX_PF(){return Math.min(.99999,1-Math.exp(-this.NODE_PF_MAX_PENALTY))}get CENTER_OFFSET_DIST_PENALTY_FACTOR(){return this.hyperParameters.CENTER_OFFSET_DIST_PENALTY_FACTOR??0}get STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR(){return this.hyperParameters.STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR??0}get GREEDY_MULTIPLIER(){return this.hyperParameters.GREEDY_MULTIPLIER??1.3}get MAX_ITERATIONS_PER_PATH(){return this.hyperParameters.MAX_ITERATIONS_PER_PATH??1e4}get RIPPING_ENABLED(){return this.hyperParameters.RIPPING_ENABLED??!1}get RIPPING_PF_THRESHOLD(){return this.hyperParameters.RIPPING_PF_THRESHOLD??.3}get MAX_RIPS(){return this.hyperParameters.MAX_RIPS??100}get RANDOM_RIP_FRACTION(){return this.hyperParameters.RANDOM_RIP_FRACTION??0}get JUMPER_PF_FN_ENABLED(){return this.hyperParameters.JUMPER_PF_FN_ENABLED??!1}get MIN_ALLOWED_BOARD_SCORE(){return this.hyperParameters.MIN_ALLOWED_BOARD_SCORE??-1e4}getConstructorParams(){return this.input}clearCostCaches(){this.baseNodeCostCache.clear()}clampPf(t5){return Number.isFinite(t5)?Math.min(Math.max(t5,0),.999999):.999999}pfToFailureCost(t5){let e4=this.clampPf(t5);return e4>=this.NODE_MAX_PF?this.NODE_PF_MAX_PENALTY:-Math.log(1-e4)}getBaseNodeFailureCost(t5){let e4=this.baseNodeCostCache.get(t5);if(e4!=null)return e4;let n3=this.nodeMap.get(t5);if(!n3)return 0;let s3=this.computeNodePf(n3),o4=this.pfToFailureCost(s3);return this.baseNodeCostCache.set(t5,o4),o4}computeBoardScore(){let t5=this.getNodesWithPortPoints();return this.JUMPER_PF_FN_ENABLED?jo2(t5,this.capacityMeshNodeMap):$o2(t5,this.capacityMeshNodeMap)}getMaxIterationsForCurrentPath(){let t5=this.activeCandidateStraightLineDistance??0;return Math.min(this.BASE_ITERATIONS_PER_PATH+this.ITERATIONS_PER_MM_FOR_PATH*t5,this.MAX_ITERATIONS_PER_PATH)}getNodeDeltaFailureCostForSegment(t5,e4,n3){let s3=this.nodeMap.get(t5);if(!s3)return 0;let o4=this.getBaseNodeFailureCost(t5),i3=this.computeNodePf(s3,[e4,n3]),r4=this.pfToFailureCost(i3),a2=Math.max(0,r4-o4);return i3>=this.NODE_MAX_PF?this.NODE_PF_MAX_PENALTY:a2*this.NODE_PF_FACTOR}getConnectionsWithNodes(){let{unshuffledConnectionsWithResults:t5,connectionNameToGoalNodeIds:e4}=Xo2(this.simpleRouteJson,this.inputNodes);return{connectionsWithResults:kt2(t5,this.hyperParameters.SHUFFLE_SEED??0),connectionNameToGoalNodeIds:e4}}buildNodeWithPortPointsForCrossing(t5,e4){let n3=this.nodeAssignedPortPoints.get(t5.capacityMeshNodeId)??[],s3=e4?[...n3,...e4]:n3;return{capacityMeshNodeId:t5.capacityMeshNodeId,center:t5.center,width:t5.width,height:t5.height,portPoints:s3,availableZ:t5.availableZ}}computeNodePf(t5,e4){if(t5._containsTarget)return 0;let n3=this.buildNodeWithPortPointsForCrossing(t5,e4),s3=Ro2(n3);return this.JUMPER_PF_FN_ENABLED&&t5.availableZ.length===1?Ao2(this.capacityMeshNodeMap.get(t5.capacityMeshNodeId),s3.numSameLayerCrossings):Co2(this.capacityMeshNodeMap.get(t5.capacityMeshNodeId),s3.numSameLayerCrossings,s3.numEntryExitLayerChanges,s3.numTransitionPairCrossings)}getPortPointReusePenalty(t5,e4){let n3=this.assignedPortPoints.get(t5);return n3?e4===n3.rootConnectionName?0:this.PORT_POINT_REUSE_FACTOR:0}getOtherNodeId(t5,e4){let[n3,s3]=t5.connectionNodeIds;return n3===e4?s3:s3===e4?n3:null}computeG(t5,e4,n3,s3,o4){let i3=t5.currentNodeId,r4=t5.point,a2={x:r4.x,y:r4.y,z:t5.z,connectionName:s3,rootConnectionName:o4},c3={x:e4.x,y:e4.y,z:e4.z,connectionName:s3,rootConnectionName:o4},h2=this.getNodeDeltaFailureCostForSegment(i3,a2,c3);return t5.g+h2}computeGToEndTarget(t5,e4,n3,s3){let o4=t5.currentNodeId,i3={x:t5.point.x,y:t5.point.y,z:t5.z,connectionName:n3,rootConnectionName:s3},r4={x:e4.x,y:e4.y,z:t5.z,connectionName:n3,rootConnectionName:s3},a2=this.getNodeDeltaFailureCostForSegment(o4,i3,r4);return t5.g+a2}computeDistanceToNearestOffBoardNode(t5){if(this.offBoardNodes.length===0)return 1/0;let e4=1/0;for(let n3 of this.offBoardNodes){let s3=St2(t5,n3.center);s3<e4&&(e4=s3)}return e4}computeH(t5,e4,n3,s3,o4,i3){if(this.RANDOM_WALK_DISTANCE>0&&o4<this.RANDOM_WALK_DISTANCE)return 0;if(this.currentConnectionShouldRouteOffBoard&&!i3)return this.BASE_COST_FOR_NOT_GOING_OFF_BOARD+this.computeDistanceToNearestOffBoardNode(t5);let r4=this.nodeMap.get(n3);if(!r4)return 0;let a2=St2(t5,r4.center),c3=this.avgNodePitch>0?a2/this.avgNodePitch:0,h2=this.clampPf(this.nodeMemoryPfMap.get(e4)??0),d3=this.pfToFailureCost(h2)*this.MEMORY_PF_FACTOR,l2=c3*this.BASE_CANDIDATE_COST,u4=this.CENTER_OFFSET_DIST_PENALTY_FACTOR*t5.distToCentermostPortOnZ**2,p2=0;if(this.STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR>0&&this.currentConnection){let e5=vt2(t5,this.currentConnection.connection.pointsToConnect[0],this.currentConnection.connection.pointsToConnect[1]);p2=this.STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR*e5}return a2+l2+d3+u4+p2}getVisitedPortPointKey(t5,e4){return this.currentConnectionShouldRouteOffBoard&&e4?`${t5}:touched_off_board`:t5}getAvailableExitPortPoints(t5,e4){let n3=this.currentConnection?.connection.rootConnectionName,s3=this.nodePortPointsMap.get(t5)??[],o4=[];for(let t7 of s3){let s4=this.getVisitedPortPointKey(t7.portPointId,e4);if(this.visitedPortPoints?.has(s4))continue;let i3=this.assignedPortPoints.get(t7.portPointId);i3&&i3?.rootConnectionName!==n3||o4.push(t7)}return o4}getAvailableExitPortPointsWithOmissions(t5,e4,n3){let s3=this.nodePortPointsMap.get(t5)??[],o4=this.currentConnection?.connection.rootConnectionName,i3=new Map;for(let e5 of s3){let s4=this.getVisitedPortPointKey(e5.portPointId,n3);if(this.visitedPortPoints?.has(s4))continue;let o5=this.getOtherNodeId(e5,t5);if(!o5)continue;this.nodeMap.get(o5);let r6=`${o5}|${e5.z}`,a2=i3.get(r6)??[];a2.push(e5),i3.set(r6,a2)}let r4=[];for(let[,t7]of i3){t7.sort((t8,e6)=>t8.distToCentermostPortOnZ-e6.distToCentermostPortOnZ);let e5=t7[0];if(!e5)continue;let n4=this.assignedPortPoints.get(e5.portPointId),s4=n4&&n4.rootConnectionName===o4;if(!n4||s4){r4.push(e5);continue}let i4=[...t7].sort((t8,e6)=>t8.x!==e6.x?t8.x-e6.x:t8.y-e6.y),a2=[],c3=[];for(let t8 of i4){let e6=this.assignedPortPoints.get(t8.portPointId);!e6||e6.rootConnectionName===o4?c3.push(t8):c3.length>0&&(a2.push(c3),c3=[])}c3.length>0&&a2.push(c3);for(let t8 of a2){let e6=Math.floor(t8.length/2);r4.push(t8[e6])}}return r4}getAvailableExitPortPointsForOffboardConnection(t5,e4){let n3=this.nodeMap.get(t5);if(!n3)return[];let s3=this.currentConnection?.connection.rootConnectionName,o4=[];for(let i3 of n3?._offBoardConnectedCapacityMeshNodeIds??[]){if(i3===t5||!this.nodeMap.get(i3))continue;let n4=this.nodePortPointsMap.get(i3)??[];for(let t7 of n4){let n5=this.getVisitedPortPointKey(t7.portPointId,e4);if(this.visitedPortPoints?.has(n5))continue;let r4=this.assignedPortPoints.get(t7.portPointId);r4&&r4.rootConnectionName!==s3||o4.push({...t7,throughNodeId:i3})}}return o4}canTravelThroughObstacle(t5,e4,n3){return this.connectionNameToGoalNodeIds.get(e4)?.includes(t5.capacityMeshNodeId)||!!t5._offBoardConnectionId}isAtEndGoal(t5,e4){return t5===e4}getBacktrackedPath(t5){let e4=[],n3=t5;for(;n3;){if(n3.lastMoveWasOffBoard&&n3.throughNodeId){let t7=this.nodeMap.get(n3.throughNodeId),s3=n3.prevCandidate?this.nodeMap.get(n3.prevCandidate.currentNodeId):null;e4.push(n3),t7&&e4.push({prevCandidate:null,portPoint:null,currentNodeId:n3.throughNodeId,point:t7.center,z:n3.z,f:0,g:0,h:0,distanceTraveled:0}),s3&&s3._offBoardConnectionId&&e4.push({prevCandidate:null,portPoint:null,currentNodeId:n3.prevCandidate.currentNodeId,point:s3.center,z:n3.z,f:0,g:0,h:0,distanceTraveled:0})}else e4.push(n3);n3=n3.prevCandidate}return e4.reverse()}assignPortPointsForPath(t5,e4,n3){let s3=[];for(let o5=0;o5<t5.length;o5++){let i3=t5[o5];if(!i3.portPoint){let r6=o5===0,a3=o5===t5.length-1;if(!r6&&!a3){let t7={x:i3.point.x,y:i3.point.y,z:i3.z,connectionName:e4,rootConnectionName:n3};s3.push(t7);let o6=this.nodeAssignedPortPoints.get(i3.currentNodeId)??[];o6.push(t7),this.nodeAssignedPortPoints.set(i3.currentNodeId,o6)}continue}let r4=i3.portPoint;this.assignedPortPoints.set(r4.portPointId,{connectionName:e4,rootConnectionName:n3});let a2={portPointId:r4.portPointId,x:r4.x,y:r4.y,z:r4.z,connectionName:e4,rootConnectionName:n3};s3.push(a2);for(let t7 of r4.connectionNodeIds){let e5=this.nodeAssignedPortPoints.get(t7)??[];e5.push(a2),this.nodeAssignedPortPoints.set(t7,e5)}}let o4=Array.from(new Set(t5.map(t7=>t7.currentNodeId)));for(let t7 of o4){let s4=this.nodeMap.get(t7);if(s4&&s4._offBoardConnectionId)for(let t8 of s4?._offBoardConnectedCapacityMeshNodeIds??[]){let s5=this.nodePortPointsMap.get(t8)??[];for(let t10 of s5)this.assignedPortPoints.set(t10.portPointId,{connectionName:e4,rootConnectionName:n3})}}return s3}addTargetPointsToNodes(t5,e4){let n3=t5[0],s3=t5[t5.length-1],o4=e4.pointsToConnect[0],i3=e4.pointsToConnect[e4.pointsToConnect.length-1];if(n3&&o4){let t7=this.nodeAssignedPortPoints.get(n3.currentNodeId)??[];t7.push({x:o4.x,y:o4.y,z:n3.z,connectionName:e4.name,rootConnectionName:e4.rootConnectionName}),this.nodeAssignedPortPoints.set(n3.currentNodeId,t7)}if(s3&&i3){let t7=this.nodeAssignedPortPoints.get(s3.currentNodeId)??[];t7.push({x:i3.x,y:i3.y,z:s3.z,connectionName:e4.name,rootConnectionName:e4.rootConnectionName}),this.nodeAssignedPortPoints.set(s3.currentNodeId,t7)}}isPortPointInPathChain(t5,e4){let n3=t5;for(;n3;){if(n3.portPoint?.portPointId===e4)return!0;n3=n3.prevCandidate}return!1}isNodeInPathChain(t5,e4){let n3=t5;for(;n3;){if(n3.currentNodeId===e4)return!0;n3=n3.prevCandidate}return!1}_step(){if(this.currentConnection||(this.currentConnection=this.unprocessedConnectionQueue.shift()??null),!this.currentConnection){let t7=this.computeBoardScore();return this.stats={boardScore:t7},t7<this.MIN_ALLOWED_BOARD_SCORE?(this.failedConnection=null,this.failed=!0,void(this.error=`Board score ${t7.toFixed(2)} is less than MIN_ALLOWED_BOARD_SCORE ${this.MIN_ALLOWED_BOARD_SCORE.toFixed(2)}`)):void(this.solved=!0)}let t5=this.currentConnection;this.activeCandidateStraightLineDistance=t5.straightLineDistance,this.currentPathIterations++;let e4=this.getMaxIterationsForCurrentPath();if(this.currentPathIterations>e4)return this.failedConnection=t5,this.processedConnectionQueue.push(t5),this.currentConnection=null,this.candidates=null,this.visitedPortPoints=null,this.currentPathIterations=0,this.failed=!0,void(this.error=`Exceeded max iterations for path (${e4}) on connection ${t5.connection.name}`);let[n3,s3]=t5.nodeIds,o4=this.nodeMap.get(n3),i3=this.nodeMap.get(s3);if(!o4||!i3)return this.processedConnectionQueue.push(t5),this.currentConnection=null,void(this.currentPathIterations=0);let r4=t5.connection.name,a2=t5.connection.rootConnectionName,c3=t5.connection.pointsToConnect[0];if(!this.candidates){if(this.clearCostCaches(),this.FORCE_OFF_BOARD_FREQUENCY>0){let t7=Yt2(17*(this.hyperParameters.SHUFFLE_SEED??0)+this.FORCE_OFF_BOARD_SEED+this.processedConnectionQueue.length);this.currentConnectionShouldRouteOffBoard=t7()<this.FORCE_OFF_BOARD_FREQUENCY}else this.currentConnectionShouldRouteOffBoard=!1;this.candidates=[],this.visitedPortPoints=new Set;for(let t7 of o4.availableZ){let e5=c3?{x:c3.x,y:c3.y}:o4.center,i4=this.computeH({...e5,distToCentermostPortOnZ:0},n3,s3,t7,0,!1),r6=0+i4*this.GREEDY_MULTIPLIER;this.candidates.push({prevCandidate:null,portPoint:null,currentNodeId:n3,point:e5,z:t7,f:r6,g:0,h:i4,distanceTraveled:0,hasTouchedOffBoardNode:!1})}}this.candidates.sort((t7,e5)=>t7.f-e5.f);let h2,d3=this.candidates.shift();for(;d3?.portPoint&&this.visitedPortPoints;){let t7=this.getVisitedPortPointKey(d3.portPoint.portPointId,d3.hasTouchedOffBoardNode);if(!this.visitedPortPoints.has(t7))break;d3=this.candidates.shift()}if(this.candidates.length>this.MAX_CANDIDATES_IN_MEMORY&&this.candidates.splice(this.MAX_CANDIDATES_IN_MEMORY,this.candidates.length-this.MAX_CANDIDATES_IN_MEMORY),!d3)return this.error=`Ran out of candidates on connection ${r4}`,this.failedConnection=t5,this.processedConnectionQueue.push(t5),this.currentConnection=null,this.candidates=null,this.visitedPortPoints=null,this.currentPathIterations=0,void(this.failed=!0);if(d3.portPoint&&this.visitedPortPoints){let t7=this.getVisitedPortPointKey(d3.portPoint.portPointId,d3.hasTouchedOffBoardNode);this.visitedPortPoints.add(t7)}if(this.isAtEndGoal(d3.currentNodeId,s3)){let e5=t5.connection.pointsToConnect[t5.connection.pointsToConnect.length-1],n4=e5?{x:e5.x,y:e5.y}:i3.center,o5=this.computeGToEndTarget(d3,n4,r4,a2),c4={prevCandidate:d3,portPoint:null,currentNodeId:s3,point:n4,z:d3.z,g:o5,h:0,f:o5,distanceTraveled:d3.distanceTraveled+St2(d3.point,n4)},h3=this.getBacktrackedPath(c4);return t5.path=h3,t5.portPoints=this.assignPortPointsForPath(h3,r4,a2),this.addTargetPointsToNodes(h3,t5.connection),this.clearCostCaches(),this.RIPPING_ENABLED&&this.processRippingForPath(h3,r4),this.processedConnectionQueue.push(t5),this.currentConnection=null,this.progress=this.processedConnectionQueue.length/this.totalConnectionCount,this.candidates=null,this.visitedPortPoints=null,void(this.currentPathIterations=0)}let l2=this.nodeMap.get(d3.currentNodeId);h2=l2?._offBoardConnectionId?this.getAvailableExitPortPointsForOffboardConnection(d3.currentNodeId,d3.hasTouchedOffBoardNode):this.FORCE_CENTER_FIRST?this.getAvailableExitPortPointsWithOmissions(d3.currentNodeId,s3,d3.hasTouchedOffBoardNode):this.getAvailableExitPortPoints(d3.currentNodeId,d3.hasTouchedOffBoardNode);for(let t7 of h2){if(this.isPortPointInPathChain(d3,t7.portPointId)||this.visitedPortPoints?.has(t7.portPointId))continue;let e5=this.getOtherNodeId(t7,t7.throughNodeId??d3.currentNodeId);if(!e5||this.isNodeInPathChain(d3,e5))continue;let n4="throughNodeId"in t7?t7.throughNodeId:void 0,o5=n4?this.nodeMap.get(n4):null,i4=this.nodeMap.get(e5);if(!i4||i4._containsObstacle&&!this.canTravelThroughObstacle(i4,r4,a2))continue;let c4=this.computeG(d3,t7,e5,r4,a2);if(!this.RIPPING_ENABLED&&c4>-this.MIN_ALLOWED_BOARD_SCORE)continue;let h3=d3.distanceTraveled+St2(d3.point,t7),u4=d3.hasTouchedOffBoardNode||!!i4._offBoardConnectionId,p2=this.computeH(t7,e5,s3,t7.z,h3,u4),m3=c4+p2*this.GREEDY_MULTIPLIER,f2=!!l2?._offBoardConnectionId&&!!o5?._offBoardConnectionId;this.candidates.push({prevCandidate:d3,portPoint:t7,currentNodeId:e5,point:{x:t7.x,y:t7.y},z:t7.z,f:m3,g:c4,h:p2,distanceTraveled:h3,lastMoveWasOffBoard:f2,throughNodeId:f2?n4:void 0,hasTouchedOffBoardNode:u4||!!i4._offBoardConnectionId||!!l2?._offBoardConnectionId})}}getNodesWithPortPoints(){let t5=[];for(let e4 of this.inputNodes){let n3=this.nodeAssignedPortPoints.get(e4.capacityMeshNodeId)??[];n3.length>0&&t5.push({capacityMeshNodeId:e4.capacityMeshNodeId,center:e4.center,width:e4.width,height:e4.height,portPoints:n3,availableZ:e4.availableZ})}return t5}getConnectionsInNode(t5,e4){let n3=[],s3=new Set;for(let o4 of this.connectionsWithResults)if(o4.path&&o4.connection.name!==e4&&!s3.has(o4.connection.name)){for(let e5 of o4.path)if(e5.currentNodeId===t5){n3.push(o4),s3.add(o4.connection.name);break}}return n3}computeNodePfWithoutConnection(t5,e4){if(t5._containsTarget)return{pf:0,totalCrossings:0};let n3=(this.nodeAssignedPortPoints.get(t5.capacityMeshNodeId)??[]).filter(t7=>t7.connectionName!==e4),s3={capacityMeshNodeId:t5.capacityMeshNodeId,center:t5.center,width:t5.width,height:t5.height,portPoints:n3,availableZ:t5.availableZ},o4=Ro2(s3),i3=o4.numSameLayerCrossings+o4.numEntryExitLayerChanges+o4.numTransitionPairCrossings;return{pf:Co2(this.capacityMeshNodeMap.get(t5.capacityMeshNodeId),o4.numSameLayerCrossings,o4.numEntryExitLayerChanges,o4.numTransitionPairCrossings),totalCrossings:i3}}computeNodeCrossings(t5){if(t5._containsTarget)return 0;let e4=this.buildNodeWithPortPointsForCrossing(t5),n3=Ro2(e4);return n3.numSameLayerCrossings+n3.numEntryExitLayerChanges+n3.numTransitionPairCrossings}ripConnection(t5){let e4=t5.connection.name;for(let[t7,n3]of this.assignedPortPoints.entries())n3.connectionName===e4&&this.assignedPortPoints.delete(t7);for(let[t7,n3]of this.nodeAssignedPortPoints.entries()){let s3=n3.filter(t8=>t8.connectionName!==e4);this.nodeAssignedPortPoints.set(t7,s3)}t5.path=void 0,t5.portPoints=void 0}requeueConnection(t5){this.totalRipCount++;let e4=this.processedConnectionQueue.indexOf(t5);if(e4!==-1)return this.processedConnectionQueue.splice(e4,1),this.unprocessedConnectionQueue.push(t5),!0;let n3=this.unprocessedConnectionQueue.indexOf(t5);return n3!==-1&&(this.unprocessedConnectionQueue.splice(n3,1),this.unprocessedConnectionQueue.unshift(t5)),!0}processRippingForPath(t5,e4){let n3=Array.from(new Set(t5.map(t7=>t7.currentNodeId))),s3=!1;for(let t7 of n3){if(this.totalRipCount>this.MAX_RIPS)break;let n4=this.nodeMap.get(t7);if(!n4)continue;let o4=this.computeNodePf(n4);if(o4<=this.RIPPING_PF_THRESHOLD)continue;this.testedRipConnections.has(t7)||this.testedRipConnections.set(t7,new Set);let i3=this.testedRipConnections.get(t7),r4=kt2(this.getConnectionsInNode(t7,e4),(this.hyperParameters.SHUFFLE_SEED??0)+this.processedConnectionQueue.length);for(let t8 of r4){if(o4<=this.RIPPING_PF_THRESHOLD)break;let e5=t8.connection.name;i3.add(e5);let{pf:r6}=this.computeNodePfWithoutConnection(n4,e5);if(this.ripConnection(t8),!this.requeueConnection(t8))return;o4=r6,s3=!0,this.clearCostCaches()}}s3&&this.RANDOM_RIP_FRACTION>0&&this.processRandomRipping(e4)}processRandomRipping(t5){let e4=this.processedConnectionQueue.filter(e5=>e5.path!==void 0&&e5.connection.name!==t5);if(e4.length===0)return;let n3=Math.max(1,Math.floor(this.RANDOM_RIP_FRACTION*e4.length)),s3=kt2(e4,(this.hyperParameters.SHUFFLE_SEED??0)+this.totalRipCount+this.processedConnectionQueue.length);for(let t7=0;t7<n3&&t7<s3.length&&!(this.totalRipCount>this.MAX_RIPS);t7++){let e5=s3[t7];if(this.ripConnection(e5),!this.requeueConnection(e5))return;this.clearCostCaches()}}visualize(){let t5={};if(this.failed){let e5=this.failedConnection?.connection.pointsToConnect[0],n4=this.failedConnection?.connection.pointsToConnect[1];e5&&n4&&(t5={lines:[{points:[e5,n4],label:`Failed Connection ${this.failedConnection?.connection.name}`,strokeWidth:1,strokeColor:"red",strokeDash:[2,2]}]})}return e4=Fo2(this),n3=t5,{...e4,rects:[...e4.rects??[],...n3.rects??[]],points:[...e4.points??[],...n3.points??[]],lines:[...e4.lines??[],...n3.lines??[]],circles:[...e4.circles??[],...n3.circles??[]],arrows:[...e4.arrows??[],...n3.arrows??[]],texts:[...e4.texts??[],...n3.texts??[]]};var e4,n3}},Zo2=class extends Zt2{constructor(t5){super();__publicField(this,"params");__publicField(this,"precomputedInitialParams");this.params=t5,this.MAX_ITERATIONS=1e8,this.GREEDY_MULTIPLIER=1.2,this.MIN_SUBSTEPS=50,this.precomputedInitialParams=t5.precomputedInitialParams??Yo2(t5.simpleRouteJson,t5.inputNodes)}getHyperParameterDefs(){let t5=this.params.numShuffleSeeds??50;return[{name:"SHUFFLE_SEED",possibleValues:Array.from({length:t5},(t7,e4)=>({SHUFFLE_SEED:e4+1700*(this.params.hyperParameters?.SHUFFLE_SEED??0)}))}]}getCombinationDefs(){return[["SHUFFLE_SEED"]]}generateSolver(t5){return new Vo2({simpleRouteJson:this.params.simpleRouteJson,capacityMeshNodes:this.params.capacityMeshNodes,inputNodes:this.params.inputNodes,colorMap:this.params.colorMap,nodeMemoryPfMap:this.params.nodeMemoryPfMap,hyperParameters:{...this.params.hyperParameters,...t5,MIN_ALLOWED_BOARD_SCORE:this.params.minAllowedBoardScore??t5.MIN_ALLOWED_BOARD_SCORE??this.params.hyperParameters?.MIN_ALLOWED_BOARD_SCORE},precomputedInitialParams:this.precomputedInitialParams,fixedRoutes:this.params.fixedRoutes})}computeG(t5){return-t5.computeBoardScore()}computeH(t5){let e4=t5.progress||0;return e4<.1?0:-(t5.computeBoardScore()/e4)*(1-e4)}getNodesWithPortPoints(){if(this.winningSolver)return this.winningSolver.getNodesWithPortPoints();let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.getNodesWithPortPoints():[]}get connectionsWithResults(){if(this.winningSolver)return this.winningSolver.connectionsWithResults;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.connectionsWithResults:[]}get inputNodes(){if(this.winningSolver)return this.winningSolver.inputNodes;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.inputNodes:this.params.inputNodes}get nodeMap(){if(this.winningSolver)return this.winningSolver.nodeMap;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.nodeMap:new Map(this.params.inputNodes.map(t7=>[t7.capacityMeshNodeId,t7]))}get assignedPortPoints(){if(this.winningSolver)return this.winningSolver.assignedPortPoints;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.assignedPortPoints:new Map}get nodeAssignedPortPoints(){if(this.winningSolver)return this.winningSolver.nodeAssignedPortPoints;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.nodeAssignedPortPoints:new Map}computeBoardScore(){if(this.winningSolver)return this.winningSolver.computeBoardScore();let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.computeBoardScore():0}onSolve(t5){this.stats={...t5.solver.stats,winningHyperParameters:this.winningSolver?.hyperParameters}}visualize(){return this.winningSolver?this.winningSolver.visualize():super.visualize()}};function Go2(t5,e4,n3,s3={}){return{solverName:t5,solverClass:e4,getConstructorParams:n3,onSolved:s3.onSolved}}var Jo2=class extends y{constructor(t5,e4={}){super();__publicField(this,"netToPointPairsSolver");__publicField(this,"nodeSolver");__publicField(this,"nodeTargetMerger");__publicField(this,"edgeSolver");__publicField(this,"colorMap");__publicField(this,"highDensityRouteSolver");__publicField(this,"highDensityStitchSolver");__publicField(this,"singleLayerNodeMerger");__publicField(this,"strawSolver");__publicField(this,"deadEndSolver");__publicField(this,"traceSimplificationSolver");__publicField(this,"availableSegmentPointSolver");__publicField(this,"portPointPathingSolver");__publicField(this,"multiSectionPortPointOptimizer");__publicField(this,"viaDiameter");__publicField(this,"minTraceWidth");__publicField(this,"effort");__publicField(this,"startTimeOfPhase");__publicField(this,"endTimeOfPhase");__publicField(this,"timeSpentOnPhase");__publicField(this,"activeSubSolver",null);__publicField(this,"connMap");__publicField(this,"srjWithPointPairs");__publicField(this,"capacityNodes",null);__publicField(this,"capacityEdges",null);__publicField(this,"cacheProvider",null);__publicField(this,"pipelineDef",[Go2("netToPointPairsSolver",gn2,t5=>[t5.srj,t5.colorMap],{onSolved:t5=>{t5.srjWithPointPairs=t5.netToPointPairsSolver?.getNewSimpleRouteJson(),t5.colorMap=ot2(t5.srjWithPointPairs,this.connMap),t5.connMap=$e2(t5.srjWithPointPairs)}}),Go2("nodeSolver",Js2,t5=>[{simpleRouteJson:t5.srjWithPointPairs}],{onSolved:t5=>{t5.capacityNodes=t5.nodeSolver?.getOutput().meshNodes??[]}}),Go2("edgeSolver",cn2,t5=>[t5.capacityNodes],{onSolved:t5=>{t5.capacityEdges=t5.edgeSolver?.edges}}),Go2("availableSegmentPointSolver",Io2,t5=>[{nodes:t5.capacityNodes,edges:t5.capacityEdges||[],traceWidth:t5.minTraceWidth,colorMap:t5.colorMap}]),Go2("portPointPathingSolver",Zo2,t5=>{let e4=t5.capacityNodes.map(t7=>({capacityMeshNodeId:t7.capacityMeshNodeId,center:t7.center,width:t7.width,height:t7.height,portPoints:[],availableZ:t7.availableZ,_containsTarget:t7._containsTarget,_containsObstacle:t7._containsObstacle})),n3=new Map(e4.map(t7=>[t7.capacityMeshNodeId,t7])),s3=t5.availableSegmentPointSolver;for(let t7 of s3.sharedEdgeSegments)for(let e5 of t7.portPoints){let[t8,s4]=e5.nodeIds,o4={portPointId:e5.segmentPortPointId,x:e5.x,y:e5.y,z:e5.availableZ[0]??0,connectionNodeIds:[t8,s4],distToCentermostPortOnZ:e5.distToCentermostPortOnZ},i3=n3.get(t8);i3&&i3.portPoints.push(o4)}return[{simpleRouteJson:t5.srjWithPointPairs,inputNodes:e4,capacityMeshNodes:t5.capacityNodes,colorMap:t5.colorMap,numShuffleSeeds:200,hyperParameters:{NODE_PF_MAX_PENALTY:100,FORCE_OFF_BOARD_FREQUENCY:0,STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR:4}}]}),Go2("multiSectionPortPointOptimizer",Uo2,t5=>{let e4=t5.portPointPathingSolver;return[{simpleRouteJson:t5.srjWithPointPairs,inputNodes:e4.inputNodes,capacityMeshNodes:t5.capacityNodes,capacityMeshEdges:t5.capacityEdges,colorMap:t5.colorMap,initialConnectionResults:e4.connectionsWithResults,initialAssignedPortPoints:e4.assignedPortPoints,initialNodeAssignedPortPoints:e4.nodeAssignedPortPoints,effort:t5.effort}]}),Go2("highDensityRouteSolver",Le2,t5=>[{nodePortPoints:t5.multiSectionPortPointOptimizer?.getNodesWithPortPoints()??t5.portPointPathingSolver?.getNodesWithPortPoints()??[],colorMap:t5.colorMap,connMap:t5.connMap,viaDiameter:t5.viaDiameter,traceWidth:t5.minTraceWidth}]),Go2("highDensityStitchSolver",nn2,t5=>[{connections:t5.srjWithPointPairs.connections,hdRoutes:t5.highDensityRouteSolver.routes,colorMap:t5.colorMap,layerCount:t5.srj.layerCount,defaultViaDiameter:t5.viaDiameter}]),Go2("traceSimplificationSolver",Mo2,t5=>[{hdRoutes:t5.highDensityStitchSolver.mergedHdRoutes,obstacles:t5.srj.obstacles,connMap:t5.connMap,colorMap:t5.colorMap,outline:t5.srj.outline,defaultViaDiameter:t5.viaDiameter,layerCount:t5.srj.layerCount,iterations:2}])]);__publicField(this,"currentPipelineStepIndex",0);if(this.srj=t5,this.opts=e4,this.MAX_ITERATIONS=1e8,this.viaDiameter=t5.minViaDiameter??.6,this.minTraceWidth=t5.minTraceWidth,this.effort=e4.effort??1,e4.capacityDepth===void 0){let n3=t5.bounds.maxX-t5.bounds.minX,s3=t5.bounds.maxY-t5.bounds.minY,o4=Math.max(n3,s3),i3=e4.targetMinCapacity??.5;e4.capacityDepth=Be2(o4,i3)}this.connMap=$e2(t5),this.colorMap=ot2(t5,this.connMap),this.cacheProvider=e4.cacheProvider===void 0?ut2():e4.cacheProvider===null?null:e4.cacheProvider,this.startTimeOfPhase={},this.endTimeOfPhase={},this.timeSpentOnPhase={}}getConstructorParams(){return[this.srj,this.opts]}_step(){let t5=this.pipelineDef[this.currentPipelineStepIndex];if(!t5)return void(this.solved=!0);if(this.activeSubSolver)return this.activeSubSolver.step(),void(this.activeSubSolver.solved?(this.endTimeOfPhase[t5.solverName]=performance.now(),this.timeSpentOnPhase[t5.solverName]=this.endTimeOfPhase[t5.solverName]-this.startTimeOfPhase[t5.solverName],t5.onSolved?.(this),this.activeSubSolver=null,this.currentPipelineStepIndex++):this.activeSubSolver.failed&&(this.error=this.activeSubSolver?.error,this.failed=!0,this.activeSubSolver=null));let e4=t5.getConstructorParams(this);this.activeSubSolver=new t5.solverClass(...e4),this[t5.solverName]=this.activeSubSolver,this.timeSpentOnPhase[t5.solverName]=0,this.startTimeOfPhase[t5.solverName]=performance.now()}solveUntilPhase(t5){for(;this.getCurrentPhase()!==t5;)this.step()}getCurrentPhase(){return this.pipelineDef[this.currentPipelineStepIndex]?.solverName??"none"}visualize(){if(!this.solved&&this.activeSubSolver)return this.activeSubSolver.visualize();let t5=this.netToPointPairsSolver?.visualize(),e4=this.nodeSolver?.visualize(),n3=this.nodeTargetMerger?.visualize(),s3=this.singleLayerNodeMerger?.visualize(),o4=this.strawSolver?.visualize(),i3=this.edgeSolver?.visualize(),r4=this.deadEndSolver?.visualize(),a2=this.availableSegmentPointSolver?.visualize(),c3=this.portPointPathingSolver?.visualize(),h2=this.multiSectionPortPointOptimizer?.visualize(),d3=this.highDensityRouteSolver?.visualize(),l2=this.highDensityStitchSolver?.visualize(),u4=this.traceSimplificationSolver?.visualize(),p2=this.srj.outline,m3=[];if(m3.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)"}),p2&&p2.length>=2){let t7=p2.map(t8=>({x:t8.x,y:t8.y}));t7.push({...t7[0]}),m3.push({points:t7,strokeColor:"rgba(0, 136, 255, 0.95)"})}let f2={points:[...this.srj.connections.flatMap(t7=>t7.pointsToConnect.map(e5=>({...e5,label:`${t7.name} ${e5.pcb_port_id??""}`})))],rects:[...(this.srj.obstacles??[]).map(t7=>({...t7,fill:t7.layers?.includes("top")?"rgba(255,0,0,0.25)":t7.layers?.includes("bottom")?"rgba(0,0,255,0.25)":"rgba(255,0,0,0.25)",label:t7.layers?.join(", ")}))],lines:m3},y3=[f2,t5,e4,n3,s3,o4,i3,r4,a2,c3,h2,d3?g3(f2,d3):null,l2,u4,this.solved?g3(f2,sn2(this.getOutputSimpleRouteJson())):null].filter(Boolean);return g3(...y3)}preview(){if(this.highDensityRouteSolver){let t5=[];for(let e4=this.highDensityRouteSolver.routes.length-1;e4>=0;e4--){let n3=this.highDensityRouteSolver.routes[e4];if(t5.push({points:n3.route.map(t7=>({x:t7.x,y:t7.y})),strokeColor:this.colorMap[n3.connectionName]}),t5.length>200)break}return{lines:t5}}if(this.portPointPathingSolver){let t5=[];for(let e4 of this.portPointPathingSolver.connectionsWithResults)e4.path&&t5.push({points:e4.path.map(t7=>({x:t7.point.x,y:t7.point.y})),strokeColor:this.colorMap[e4.connection.name]});return{lines:t5}}return this.netToPointPairsSolver?this.netToPointPairsSolver?.visualize():{}}_getOutputHdRoutes(){return this.traceSimplificationSolver?.simplifiedHdRoutes??this.highDensityStitchSolver.mergedHdRoutes}getOutputSimplifiedPcbTraces(){if(!this.solved||!this.highDensityRouteSolver)throw new Error("Cannot get output before solving is complete");let t5=[],e4=this._getOutputHdRoutes();for(let n3 of this.netToPointPairsSolver?.newConnections??[]){let s3=n3.netConnectionName??this.srj.connections.find(t7=>t7.name===n3.name)?.netConnectionName,o4=e4.filter(t7=>t7.connectionName===n3.name);for(let e5=0;e5<o4.length;e5++){let i3=o4[e5],r4={type:"pcb_trace",pcb_trace_id:`${n3.name}_${e5}`,connection_name:s3??n3.rootConnectionName??n3.name,route:We2(i3,this.srj.layerCount)};t5.push(r4)}}return t5}getOutputSimpleRouteJson(){return{...this.srj,traces:this.getOutputSimplifiedPcbTraces()}}};var Ko2=class extends y{constructor({nodes:t5,edges:e4,capacityPaths:n3,colorMap:s3}){super();__publicField(this,"nodes");__publicField(this,"edges");__publicField(this,"capacityPaths");__publicField(this,"nodeMap");__publicField(this,"nodeEdgeMap");__publicField(this,"unprocessedNodeIds");__publicField(this,"nodePortSegments");__publicField(this,"colorMap");this.nodes=t5,this.edges=e4,this.nodeMap=new Map(t5.map(t7=>[t7.capacityMeshNodeId,t7])),this.nodeEdgeMap=No2(e4),this.capacityPaths=n3,this.colorMap=s3??{},this.unprocessedNodeIds=[...new Set(n3.flatMap(t7=>t7.nodeIds))],this.nodePortSegments=new Map}step(){let t5=this.unprocessedNodeIds.pop();if(!t5)return void(this.solved=!0);let e4=[];for(let n4 of this.capacityPaths){let s4=n4.nodeIds.indexOf(t5);s4!==-1&&e4.push({path:n4,indexOfNodeInPath:s4})}let n3=this.nodeMap.get(t5),s3=[];for(let{path:o5,indexOfNodeInPath:i3}of e4){let e5=o5.nodeIds[i3-1],r4=o5.nodeIds[i3+1];for(let i4 of[e5,r4]){let e6=this.nodeMap.get(i4);if(!e6)continue;let r6=Qo2(n3,e6),a2=e6.availableZ.filter(t7=>n3.availableZ.includes(t7));if(a2.length===0)continue;let c3={capacityMeshNodeId:t5,start:r6.start,end:r6.end,connectionNames:[o5.connectionName],rootConnectionNames:o5.rootConnectionName?[o5.rootConnectionName]:void 0,availableZ:a2};s3.push(c3)}}let o4=(function(t7){let e5=[],n4=t7.map(t8=>({...t8,connectionNames:[...t8.connectionNames],rootConnectionNames:t8.rootConnectionNames?[...t8.rootConnectionNames]:[],availableZ:[...t8.availableZ].sort((t10,e6)=>t10-e6)}));for(;n4.length>0;){let t8=n4.pop(),s4=!1;for(let n5=0;n5<e5.length;n5++){let o5=e5[n5],i3=ei2(o5.start,t8.start)&&ei2(o5.end,t8.end)||ei2(o5.start,t8.end)&&ei2(o5.end,t8.start),r4=ni2(o5.availableZ,t8.availableZ);if(i3&&r4){let e6=new Set(o5.connectionNames);t8.connectionNames.forEach(t10=>e6.add(t10)),o5.connectionNames=Array.from(e6);let n6=new Set(o5.rootConnectionNames||[]);t8.rootConnectionNames?.forEach(t10=>n6.add(t10)),o5.rootConnectionNames=Array.from(n6),s4=!0;break}}s4||e5.push(t8)}return e5})(s3);this.nodePortSegments.set(t5,o4)}visualize(){let t5={lines:[],points:[],rects:[],circles:[]};return this.nodePortSegments.forEach((e4,n3)=>{this.nodeMap.get(n3),e4.forEach(e5=>{e5.start.x,e5.end.x;for(let s3=0;s3<e5.connectionNames.length;s3++){let o4={x:.05*Math.max(...e5.availableZ),y:.05*Math.max(...e5.availableZ)},i3={x:(e5.start.x+e5.end.x)/2,y:(e5.start.y+e5.end.y)/2},r4={x:i3.x+o4.x,y:i3.y+o4.y};o4.x>0&&t5.lines.push({points:[i3,r4],strokeColor:"rgba(0, 0, 0, 0.25)",strokeDash:"5 5"}),t5.points.push({x:r4.x,y:r4.y,label:`${n3}: ${e5.connectionNames.join(", ")}
|
|
542
|
+
`)});for(let s3 of t5.sectionPaths){let t7=e4?.[s3.connectionName]??"blue";for(let e5=0;e5<s3.points.length-1;e5++){let o4=s3.points[e5],i3=s3.points[e5+1],r4=o4.z===i3.z,a2=o4.z,c3;c3=r4?a2===0?"5 5":"10 5":"3 3 10",n3.lines.push({points:[{x:o4.x,y:o4.y},{x:i3.x,y:i3.y}],strokeColor:t7,strokeDash:c3})}}return n3})(this.currentSection,this.colorMap):Fo2(this)}},Vo2=class extends y{constructor(t5){super();__publicField(this,"hyperParameters");__publicField(this,"simpleRouteJson");__publicField(this,"inputNodes");__publicField(this,"nodeMap");__publicField(this,"nodePortPointsMap");__publicField(this,"portPointMap");__publicField(this,"connectionsWithResults",[]);__publicField(this,"failedConnection",null);__publicField(this,"assignedPortPoints",new Map);__publicField(this,"nodeAssignedPortPoints",new Map);__publicField(this,"PORT_POINT_REUSE_FACTOR",1e3);__publicField(this,"BASE_COST_FOR_NOT_GOING_OFF_BOARD",100);__publicField(this,"colorMap");__publicField(this,"MAX_CANDIDATES_IN_MEMORY",5e3);__publicField(this,"ITERATIONS_PER_MM_FOR_PATH",30);__publicField(this,"BASE_ITERATIONS_PER_PATH",1e4);__publicField(this,"jumpersPerMmSquared",.1);__publicField(this,"testedRipConnections",new Map);__publicField(this,"totalRipCount",0);__publicField(this,"nodeMemoryPfMap");__publicField(this,"unprocessedConnectionQueue",[]);__publicField(this,"processedConnectionQueue",[]);__publicField(this,"currentConnection",null);__publicField(this,"totalConnectionCount",0);__publicField(this,"currentPathIterations",0);__publicField(this,"candidates");__publicField(this,"visitedPortPoints");__publicField(this,"connectionNameToGoalNodeIds");__publicField(this,"capacityMeshNodeMap");__publicField(this,"avgNodePitch");__publicField(this,"currentConnectionShouldRouteOffBoard",!1);__publicField(this,"activeCandidateStraightLineDistance");__publicField(this,"offBoardNodes",[]);__publicField(this,"baseNodeCostCache",new Map);this.input=t5;let{simpleRouteJson:e4,capacityMeshNodes:n3,inputNodes:s3,colorMap:o4,nodeMemoryPfMap:i3,hyperParameters:r4,precomputedInitialParams:a2,fixedRoutes:c3}=t5;if(this.input=structuredClone(t5),this.MAX_ITERATIONS=1e8,this.simpleRouteJson=e4,this.inputNodes=s3,this.colorMap=o4??{},this.capacityMeshNodeMap=new Map(n3.map(t7=>[t7.capacityMeshNodeId,t7])),this.nodeMemoryPfMap=i3??new Map,this.hyperParameters=r4??{},a2){this.nodeMap=a2.nodeMap,this.avgNodePitch=a2.avgNodePitch,this.offBoardNodes=a2.offBoardNodes,this.portPointMap=a2.portPointMap,this.nodePortPointsMap=a2.nodePortPointsMap,this.connectionNameToGoalNodeIds=a2.connectionNameToGoalNodeIds;let{nodeAssignedPortPoints:t7}=(function(t8){let e5=new Map;for(let[n4,s4]of t8.nodeAssignedPortPoints)e5.set(n4,[...s4]);return{nodeAssignedPortPoints:e5}})(a2);this.nodeAssignedPortPoints=t7,this.connectionsWithResults=kt2(structuredClone(a2.unshuffledConnectionsWithResults),this.hyperParameters.SHUFFLE_SEED??0)}else{this.nodeMap=new Map(s3.map(t8=>[t8.capacityMeshNodeId,t8]));let t7=s3.map(t8=>(t8.width+t8.height)/2).filter(t8=>Number.isFinite(t8)&&t8>0);this.avgNodePitch=t7.length>0?t7.reduce((t8,e6)=>t8+e6,0)/t7.length:1,this.offBoardNodes=s3.filter(t8=>t8._offBoardConnectionId),this.portPointMap=new Map,this.nodePortPointsMap=new Map;for(let t8 of s3)this.nodePortPointsMap.set(t8.capacityMeshNodeId,[]),this.nodeAssignedPortPoints.set(t8.capacityMeshNodeId,[]);for(let t8 of s3)for(let e6 of t8.portPoints){this.portPointMap.set(e6.portPointId,e6);for(let t10 of e6.connectionNodeIds){let n5=this.nodePortPointsMap.get(t10);n5&&!n5.some(t11=>t11.portPointId===e6.portPointId)&&n5.push(e6)}}let{connectionsWithResults:e5,connectionNameToGoalNodeIds:n4}=this.getConnectionsWithNodes();this.connectionsWithResults=e5,this.connectionNameToGoalNodeIds=n4}if(c3&&c3.length>0){for(let t7 of c3)if(this.connectionsWithResults.push(t7),t7.portPoints)for(let e5 of t7.portPoints)e5.portPointId&&this.assignedPortPoints.set(e5.portPointId,{connectionName:e5.connectionName,rootConnectionName:e5.rootConnectionName})}for(let t7 of this.connectionsWithResults)t7.path?this.processedConnectionQueue.push(t7):this.unprocessedConnectionQueue.push(t7);this.totalConnectionCount=this.connectionsWithResults.length}get NODE_PF_FACTOR(){return this.hyperParameters.NODE_PF_FACTOR??50}get RANDOM_WALK_DISTANCE(){return this.hyperParameters.RANDOM_WALK_DISTANCE??0}get MEMORY_PF_FACTOR(){return this.hyperParameters.MEMORY_PF_FACTOR??0}get CENTER_OFFSET_FOCUS_SHIFT(){return this.hyperParameters.CENTER_OFFSET_FOCUS_SHIFT??0}get RANDOM_COST_MAGNITUDE(){return this.hyperParameters.RANDOM_COST_MAGNITUDE??0}get BASE_CANDIDATE_COST(){return this.hyperParameters.BASE_CANDIDATE_COST??0}get NODE_PF_MAX_PENALTY(){return this.hyperParameters.NODE_PF_MAX_PENALTY??1e4}get FORCE_CENTER_FIRST(){return this.hyperParameters.FORCE_CENTER_FIRST??!0}get FORCE_OFF_BOARD_FREQUENCY(){return this.offBoardNodes.length===0?0:this.hyperParameters.FORCE_OFF_BOARD_FREQUENCY??0}get FORCE_OFF_BOARD_SEED(){return this.hyperParameters.FORCE_OFF_BOARD_SEED??0}get NODE_MAX_PF(){return Math.min(.99999,1-Math.exp(-this.NODE_PF_MAX_PENALTY))}get CENTER_OFFSET_DIST_PENALTY_FACTOR(){return this.hyperParameters.CENTER_OFFSET_DIST_PENALTY_FACTOR??0}get STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR(){return this.hyperParameters.STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR??0}get GREEDY_MULTIPLIER(){return this.hyperParameters.GREEDY_MULTIPLIER??1.3}get MAX_ITERATIONS_PER_PATH(){return this.hyperParameters.MAX_ITERATIONS_PER_PATH??1e4}get RIPPING_ENABLED(){return this.hyperParameters.RIPPING_ENABLED??!1}get RIPPING_PF_THRESHOLD(){let t5=this.hyperParameters.START_RIPPING_PF_THRESHOLD,e4=this.hyperParameters.END_RIPPING_PF_THRESHOLD;if(t5!==void 0&&e4!==void 0){let n3=this.MAX_RIPS;return t5+(n3>0?this.totalRipCount/n3:0)*(e4-t5)}return this.hyperParameters.RIPPING_PF_THRESHOLD??.3}get MAX_RIPS(){return this.hyperParameters.MAX_RIPS??100}get RANDOM_RIP_FRACTION(){return this.hyperParameters.RANDOM_RIP_FRACTION??0}get JUMPER_PF_FN_ENABLED(){return this.hyperParameters.JUMPER_PF_FN_ENABLED??!1}get MIN_ALLOWED_BOARD_SCORE(){return this.hyperParameters.MIN_ALLOWED_BOARD_SCORE??-1e4}getConstructorParams(){return this.input}clearCostCaches(){this.baseNodeCostCache.clear()}clampPf(t5){return Number.isFinite(t5)?Math.min(Math.max(t5,0),.999999):.999999}pfToFailureCost(t5){let e4=this.clampPf(t5);return e4>=this.NODE_MAX_PF?this.NODE_PF_MAX_PENALTY:-Math.log(1-e4)}getBaseNodeFailureCost(t5){let e4=this.baseNodeCostCache.get(t5);if(e4!=null)return e4;let n3=this.nodeMap.get(t5);if(!n3)return 0;let s3=this.computeNodePf(n3),o4=this.pfToFailureCost(s3);return this.baseNodeCostCache.set(t5,o4),o4}computeBoardScore(){let t5=this.getNodesWithPortPoints();return this.JUMPER_PF_FN_ENABLED?jo2(t5,this.capacityMeshNodeMap):$o2(t5,this.capacityMeshNodeMap)}getMaxIterationsForCurrentPath(){let t5=this.activeCandidateStraightLineDistance??0;return Math.min(this.BASE_ITERATIONS_PER_PATH+this.ITERATIONS_PER_MM_FOR_PATH*t5,this.MAX_ITERATIONS_PER_PATH)}getNodeDeltaFailureCostForSegment(t5,e4,n3){let s3=this.nodeMap.get(t5);if(!s3)return 0;let o4=this.getBaseNodeFailureCost(t5),i3=this.computeNodePf(s3,[e4,n3]),r4=this.pfToFailureCost(i3),a2=Math.max(0,r4-o4);return i3>=this.NODE_MAX_PF?this.NODE_PF_MAX_PENALTY:a2*this.NODE_PF_FACTOR}getConnectionsWithNodes(){let{unshuffledConnectionsWithResults:t5,connectionNameToGoalNodeIds:e4}=Xo2(this.simpleRouteJson,this.inputNodes);return{connectionsWithResults:kt2(t5,this.hyperParameters.SHUFFLE_SEED??0),connectionNameToGoalNodeIds:e4}}buildNodeWithPortPointsForCrossing(t5,e4){let n3=this.nodeAssignedPortPoints.get(t5.capacityMeshNodeId)??[],s3=e4?[...n3,...e4]:n3;return{capacityMeshNodeId:t5.capacityMeshNodeId,center:t5.center,width:t5.width,height:t5.height,portPoints:s3,availableZ:t5.availableZ}}computeNodePf(t5,e4){if(t5._containsTarget)return 0;let n3=this.buildNodeWithPortPointsForCrossing(t5,e4),s3=Ro2(n3);return this.JUMPER_PF_FN_ENABLED&&t5.availableZ.length===1?Ao2(this.capacityMeshNodeMap.get(t5.capacityMeshNodeId),s3.numSameLayerCrossings):Co2(this.capacityMeshNodeMap.get(t5.capacityMeshNodeId),s3.numSameLayerCrossings,s3.numEntryExitLayerChanges,s3.numTransitionPairCrossings)}getPortPointReusePenalty(t5,e4){let n3=this.assignedPortPoints.get(t5);return n3?e4===n3.rootConnectionName?0:this.PORT_POINT_REUSE_FACTOR:0}getOtherNodeId(t5,e4){let[n3,s3]=t5.connectionNodeIds;return n3===e4?s3:s3===e4?n3:null}computeG(t5,e4,n3,s3,o4){let i3=t5.currentNodeId,r4=t5.point,a2={x:r4.x,y:r4.y,z:t5.z,connectionName:s3,rootConnectionName:o4},c3={x:e4.x,y:e4.y,z:e4.z,connectionName:s3,rootConnectionName:o4},h2=this.getNodeDeltaFailureCostForSegment(i3,a2,c3);return t5.g+h2}computeGToEndTarget(t5,e4,n3,s3){let o4=t5.currentNodeId,i3={x:t5.point.x,y:t5.point.y,z:t5.z,connectionName:n3,rootConnectionName:s3},r4={x:e4.x,y:e4.y,z:t5.z,connectionName:n3,rootConnectionName:s3},a2=this.getNodeDeltaFailureCostForSegment(o4,i3,r4);return t5.g+a2}computeDistanceToNearestOffBoardNode(t5){if(this.offBoardNodes.length===0)return 1/0;let e4=1/0;for(let n3 of this.offBoardNodes){let s3=St2(t5,n3.center);s3<e4&&(e4=s3)}return e4}computeH(t5,e4,n3,s3,o4,i3){if(this.RANDOM_WALK_DISTANCE>0&&o4<this.RANDOM_WALK_DISTANCE)return 0;if(this.currentConnectionShouldRouteOffBoard&&!i3)return this.BASE_COST_FOR_NOT_GOING_OFF_BOARD+this.computeDistanceToNearestOffBoardNode(t5);let r4=this.nodeMap.get(n3);if(!r4)return 0;let a2=St2(t5,r4.center),c3=this.avgNodePitch>0?a2/this.avgNodePitch:0,h2=this.clampPf(this.nodeMemoryPfMap.get(e4)??0),d3=this.pfToFailureCost(h2)*this.MEMORY_PF_FACTOR,l2=c3*this.BASE_CANDIDATE_COST,u4=this.CENTER_OFFSET_DIST_PENALTY_FACTOR*t5.distToCentermostPortOnZ**2,p2=0;if(this.STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR>0&&this.currentConnection){let e5=vt2(t5,this.currentConnection.connection.pointsToConnect[0],this.currentConnection.connection.pointsToConnect[1]);p2=this.STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR*e5}return a2+l2+d3+u4+p2}getVisitedPortPointKey(t5,e4){return this.currentConnectionShouldRouteOffBoard&&e4?`${t5}:touched_off_board`:t5}getAvailableExitPortPoints(t5,e4){let n3=this.currentConnection?.connection.rootConnectionName,s3=this.nodePortPointsMap.get(t5)??[],o4=[];for(let t7 of s3){let s4=this.getVisitedPortPointKey(t7.portPointId,e4);if(this.visitedPortPoints?.has(s4))continue;let i3=this.assignedPortPoints.get(t7.portPointId);i3&&i3?.rootConnectionName!==n3||o4.push(t7)}return o4}getAvailableExitPortPointsWithOmissions(t5,e4,n3){let s3=this.nodePortPointsMap.get(t5)??[],o4=this.currentConnection?.connection.rootConnectionName,i3=new Map;for(let e5 of s3){let s4=this.getVisitedPortPointKey(e5.portPointId,n3);if(this.visitedPortPoints?.has(s4))continue;let o5=this.getOtherNodeId(e5,t5);if(!o5)continue;this.nodeMap.get(o5);let r6=`${o5}|${e5.z}`,a2=i3.get(r6)??[];a2.push(e5),i3.set(r6,a2)}let r4=[];for(let[,t7]of i3){t7.sort((t8,e6)=>t8.distToCentermostPortOnZ-e6.distToCentermostPortOnZ);let e5=t7[0];if(!e5)continue;let n4=this.assignedPortPoints.get(e5.portPointId),s4=n4&&n4.rootConnectionName===o4;if(!n4||s4){r4.push(e5);continue}let i4=[...t7].sort((t8,e6)=>t8.x!==e6.x?t8.x-e6.x:t8.y-e6.y),a2=[],c3=[];for(let t8 of i4){let e6=this.assignedPortPoints.get(t8.portPointId);!e6||e6.rootConnectionName===o4?c3.push(t8):c3.length>0&&(a2.push(c3),c3=[])}c3.length>0&&a2.push(c3);for(let t8 of a2){let e6=Math.floor(t8.length/2);r4.push(t8[e6])}}return r4}getAvailableExitPortPointsForOffboardConnection(t5,e4){let n3=this.nodeMap.get(t5);if(!n3)return[];let s3=this.currentConnection?.connection.rootConnectionName,o4=[];for(let i3 of n3?._offBoardConnectedCapacityMeshNodeIds??[]){if(i3===t5||!this.nodeMap.get(i3))continue;let n4=this.nodePortPointsMap.get(i3)??[];for(let t7 of n4){let n5=this.getVisitedPortPointKey(t7.portPointId,e4);if(this.visitedPortPoints?.has(n5))continue;let r4=this.assignedPortPoints.get(t7.portPointId);r4&&r4.rootConnectionName!==s3||o4.push({...t7,throughNodeId:i3})}}return o4}canTravelThroughObstacle(t5,e4,n3){return this.connectionNameToGoalNodeIds.get(e4)?.includes(t5.capacityMeshNodeId)||!!t5._offBoardConnectionId}isAtEndGoal(t5,e4){return t5===e4}getBacktrackedPath(t5){let e4=[],n3=t5;for(;n3;){if(n3.lastMoveWasOffBoard&&n3.throughNodeId){let t7=this.nodeMap.get(n3.throughNodeId),s3=n3.prevCandidate?this.nodeMap.get(n3.prevCandidate.currentNodeId):null;e4.push(n3),t7&&e4.push({prevCandidate:null,portPoint:null,currentNodeId:n3.throughNodeId,point:t7.center,z:n3.z,f:0,g:0,h:0,distanceTraveled:0}),s3&&s3._offBoardConnectionId&&e4.push({prevCandidate:null,portPoint:null,currentNodeId:n3.prevCandidate.currentNodeId,point:s3.center,z:n3.z,f:0,g:0,h:0,distanceTraveled:0})}else e4.push(n3);n3=n3.prevCandidate}return e4.reverse()}assignPortPointsForPath(t5,e4,n3){let s3=[];for(let o5=0;o5<t5.length;o5++){let i3=t5[o5];if(!i3.portPoint){let r6=o5===0,a3=o5===t5.length-1;if(!r6&&!a3){let t7={x:i3.point.x,y:i3.point.y,z:i3.z,connectionName:e4,rootConnectionName:n3};s3.push(t7);let o6=this.nodeAssignedPortPoints.get(i3.currentNodeId)??[];o6.push(t7),this.nodeAssignedPortPoints.set(i3.currentNodeId,o6)}continue}let r4=i3.portPoint;this.assignedPortPoints.set(r4.portPointId,{connectionName:e4,rootConnectionName:n3});let a2={portPointId:r4.portPointId,x:r4.x,y:r4.y,z:r4.z,connectionName:e4,rootConnectionName:n3};s3.push(a2);for(let t7 of r4.connectionNodeIds){let e5=this.nodeAssignedPortPoints.get(t7)??[];e5.push(a2),this.nodeAssignedPortPoints.set(t7,e5)}}let o4=Array.from(new Set(t5.map(t7=>t7.currentNodeId)));for(let t7 of o4){let s4=this.nodeMap.get(t7);if(s4&&s4._offBoardConnectionId)for(let t8 of s4?._offBoardConnectedCapacityMeshNodeIds??[]){let s5=this.nodePortPointsMap.get(t8)??[];for(let t10 of s5)this.assignedPortPoints.set(t10.portPointId,{connectionName:e4,rootConnectionName:n3})}}return s3}addTargetPointsToNodes(t5,e4){let n3=t5[0],s3=t5[t5.length-1],o4=e4.pointsToConnect[0],i3=e4.pointsToConnect[e4.pointsToConnect.length-1];if(n3&&o4){let t7=this.nodeAssignedPortPoints.get(n3.currentNodeId)??[];t7.push({x:o4.x,y:o4.y,z:n3.z,connectionName:e4.name,rootConnectionName:e4.rootConnectionName}),this.nodeAssignedPortPoints.set(n3.currentNodeId,t7)}if(s3&&i3){let t7=this.nodeAssignedPortPoints.get(s3.currentNodeId)??[];t7.push({x:i3.x,y:i3.y,z:s3.z,connectionName:e4.name,rootConnectionName:e4.rootConnectionName}),this.nodeAssignedPortPoints.set(s3.currentNodeId,t7)}}isPortPointInPathChain(t5,e4){let n3=t5;for(;n3;){if(n3.portPoint?.portPointId===e4)return!0;n3=n3.prevCandidate}return!1}isNodeInPathChain(t5,e4){let n3=t5;for(;n3;){if(n3.currentNodeId===e4)return!0;n3=n3.prevCandidate}return!1}_step(){if(this.currentConnection||(this.currentConnection=this.unprocessedConnectionQueue.shift()??null),!this.currentConnection){let t7=this.computeBoardScore();return this.stats={boardScore:t7,totalRipCount:this.totalRipCount},t7<this.MIN_ALLOWED_BOARD_SCORE?(this.failedConnection=null,this.failed=!0,void(this.error=`Board score ${t7.toFixed(2)} is less than MIN_ALLOWED_BOARD_SCORE ${this.MIN_ALLOWED_BOARD_SCORE.toFixed(2)}`)):void(this.solved=!0)}let t5=this.currentConnection;this.activeCandidateStraightLineDistance=t5.straightLineDistance,this.currentPathIterations++;let e4=this.getMaxIterationsForCurrentPath();if(this.currentPathIterations>e4)return this.failedConnection=t5,this.processedConnectionQueue.push(t5),this.currentConnection=null,this.candidates=null,this.visitedPortPoints=null,this.currentPathIterations=0,this.failed=!0,void(this.error=`Exceeded max iterations for path (${e4}) on connection ${t5.connection.name}`);let[n3,s3]=t5.nodeIds,o4=this.nodeMap.get(n3),i3=this.nodeMap.get(s3);if(!o4||!i3)return this.processedConnectionQueue.push(t5),this.currentConnection=null,void(this.currentPathIterations=0);let r4=t5.connection.name,a2=t5.connection.rootConnectionName,c3=t5.connection.pointsToConnect[0];if(!this.candidates){if(this.clearCostCaches(),this.FORCE_OFF_BOARD_FREQUENCY>0){let t7=Yt2(17*(this.hyperParameters.SHUFFLE_SEED??0)+this.FORCE_OFF_BOARD_SEED+this.processedConnectionQueue.length);this.currentConnectionShouldRouteOffBoard=t7()<this.FORCE_OFF_BOARD_FREQUENCY}else this.currentConnectionShouldRouteOffBoard=!1;this.candidates=[],this.visitedPortPoints=new Set;for(let t7 of o4.availableZ){let e5=c3?{x:c3.x,y:c3.y}:o4.center,i4=this.computeH({...e5,distToCentermostPortOnZ:0},n3,s3,t7,0,!1),r6=0+i4*this.GREEDY_MULTIPLIER;this.candidates.push({prevCandidate:null,portPoint:null,currentNodeId:n3,point:e5,z:t7,f:r6,g:0,h:i4,distanceTraveled:0,hasTouchedOffBoardNode:!1})}}this.candidates.sort((t7,e5)=>t7.f-e5.f);let h2,d3=this.candidates.shift();for(;d3?.portPoint&&this.visitedPortPoints;){let t7=this.getVisitedPortPointKey(d3.portPoint.portPointId,d3.hasTouchedOffBoardNode);if(!this.visitedPortPoints.has(t7))break;d3=this.candidates.shift()}if(this.candidates.length>this.MAX_CANDIDATES_IN_MEMORY&&this.candidates.splice(this.MAX_CANDIDATES_IN_MEMORY,this.candidates.length-this.MAX_CANDIDATES_IN_MEMORY),!d3)return this.error=`Ran out of candidates on connection ${r4}`,this.failedConnection=t5,this.processedConnectionQueue.push(t5),this.currentConnection=null,this.candidates=null,this.visitedPortPoints=null,this.currentPathIterations=0,void(this.failed=!0);if(d3.portPoint&&this.visitedPortPoints){let t7=this.getVisitedPortPointKey(d3.portPoint.portPointId,d3.hasTouchedOffBoardNode);this.visitedPortPoints.add(t7)}if(this.isAtEndGoal(d3.currentNodeId,s3)){let e5=t5.connection.pointsToConnect[t5.connection.pointsToConnect.length-1],n4=e5?{x:e5.x,y:e5.y}:i3.center,o5=this.computeGToEndTarget(d3,n4,r4,a2),c4={prevCandidate:d3,portPoint:null,currentNodeId:s3,point:n4,z:d3.z,g:o5,h:0,f:o5,distanceTraveled:d3.distanceTraveled+St2(d3.point,n4)},h3=this.getBacktrackedPath(c4);return t5.path=h3,t5.portPoints=this.assignPortPointsForPath(h3,r4,a2),this.addTargetPointsToNodes(h3,t5.connection),this.clearCostCaches(),this.RIPPING_ENABLED&&this.processRippingForPath(h3,r4),this.processedConnectionQueue.push(t5),this.currentConnection=null,this.progress=this.processedConnectionQueue.length/this.totalConnectionCount,this.candidates=null,this.visitedPortPoints=null,void(this.currentPathIterations=0)}let l2=this.nodeMap.get(d3.currentNodeId);h2=l2?._offBoardConnectionId?this.getAvailableExitPortPointsForOffboardConnection(d3.currentNodeId,d3.hasTouchedOffBoardNode):this.FORCE_CENTER_FIRST?this.getAvailableExitPortPointsWithOmissions(d3.currentNodeId,s3,d3.hasTouchedOffBoardNode):this.getAvailableExitPortPoints(d3.currentNodeId,d3.hasTouchedOffBoardNode);for(let t7 of h2){if(this.isPortPointInPathChain(d3,t7.portPointId)||this.visitedPortPoints?.has(t7.portPointId))continue;let e5=this.getOtherNodeId(t7,t7.throughNodeId??d3.currentNodeId);if(!e5||this.isNodeInPathChain(d3,e5))continue;let n4="throughNodeId"in t7?t7.throughNodeId:void 0,o5=n4?this.nodeMap.get(n4):null,i4=this.nodeMap.get(e5);if(!i4||i4._containsObstacle&&!this.canTravelThroughObstacle(i4,r4,a2))continue;let c4=this.computeG(d3,t7,e5,r4,a2);if(!this.RIPPING_ENABLED&&c4>-this.MIN_ALLOWED_BOARD_SCORE)continue;let h3=d3.distanceTraveled+St2(d3.point,t7),u4=d3.hasTouchedOffBoardNode||!!i4._offBoardConnectionId,p2=this.computeH(t7,e5,s3,t7.z,h3,u4),m3=c4+p2*this.GREEDY_MULTIPLIER,f2=!!l2?._offBoardConnectionId&&!!o5?._offBoardConnectionId;this.candidates.push({prevCandidate:d3,portPoint:t7,currentNodeId:e5,point:{x:t7.x,y:t7.y},z:t7.z,f:m3,g:c4,h:p2,distanceTraveled:h3,lastMoveWasOffBoard:f2,throughNodeId:f2?n4:void 0,hasTouchedOffBoardNode:u4||!!i4._offBoardConnectionId||!!l2?._offBoardConnectionId})}}getNodesWithPortPoints(){let t5=[];for(let e4 of this.inputNodes){let n3=this.nodeAssignedPortPoints.get(e4.capacityMeshNodeId)??[];n3.length>0&&t5.push({capacityMeshNodeId:e4.capacityMeshNodeId,center:e4.center,width:e4.width,height:e4.height,portPoints:n3,availableZ:e4.availableZ})}return t5}getConnectionsInNode(t5,e4){let n3=[],s3=new Set;for(let o4 of this.connectionsWithResults)if(o4.path&&o4.connection.name!==e4&&!s3.has(o4.connection.name)){for(let e5 of o4.path)if(e5.currentNodeId===t5){n3.push(o4),s3.add(o4.connection.name);break}}return n3}computeNodePfWithoutConnection(t5,e4){if(t5._containsTarget)return{pf:0,totalCrossings:0};let n3=(this.nodeAssignedPortPoints.get(t5.capacityMeshNodeId)??[]).filter(t7=>t7.connectionName!==e4),s3={capacityMeshNodeId:t5.capacityMeshNodeId,center:t5.center,width:t5.width,height:t5.height,portPoints:n3,availableZ:t5.availableZ},o4=Ro2(s3),i3=o4.numSameLayerCrossings+o4.numEntryExitLayerChanges+o4.numTransitionPairCrossings;return{pf:Co2(this.capacityMeshNodeMap.get(t5.capacityMeshNodeId),o4.numSameLayerCrossings,o4.numEntryExitLayerChanges,o4.numTransitionPairCrossings),totalCrossings:i3}}computeNodeCrossings(t5){if(t5._containsTarget)return 0;let e4=this.buildNodeWithPortPointsForCrossing(t5),n3=Ro2(e4);return n3.numSameLayerCrossings+n3.numEntryExitLayerChanges+n3.numTransitionPairCrossings}ripConnection(t5){let e4=t5.connection.name;for(let[t7,n3]of this.assignedPortPoints.entries())n3.connectionName===e4&&this.assignedPortPoints.delete(t7);for(let[t7,n3]of this.nodeAssignedPortPoints.entries()){let s3=n3.filter(t8=>t8.connectionName!==e4);this.nodeAssignedPortPoints.set(t7,s3)}t5.path=void 0,t5.portPoints=void 0}requeueConnection(t5){this.totalRipCount++;let e4=this.processedConnectionQueue.indexOf(t5);if(e4!==-1)return this.processedConnectionQueue.splice(e4,1),this.unprocessedConnectionQueue.push(t5),!0;let n3=this.unprocessedConnectionQueue.indexOf(t5);return n3!==-1&&(this.unprocessedConnectionQueue.splice(n3,1),this.unprocessedConnectionQueue.unshift(t5)),!0}processRippingForPath(t5,e4){let n3=Array.from(new Set(t5.map(t7=>t7.currentNodeId))),s3=!1;for(let t7 of n3){if(this.totalRipCount>this.MAX_RIPS)break;let n4=this.nodeMap.get(t7);if(!n4)continue;let o4=this.computeNodePf(n4);if(o4<=this.RIPPING_PF_THRESHOLD)continue;this.testedRipConnections.has(t7)||this.testedRipConnections.set(t7,new Set);let i3=this.testedRipConnections.get(t7),r4=kt2(this.getConnectionsInNode(t7,e4),(this.hyperParameters.SHUFFLE_SEED??0)+this.processedConnectionQueue.length);for(let t8 of r4){if(o4<=this.RIPPING_PF_THRESHOLD)break;let e5=t8.connection.name;i3.add(e5);let{pf:r6}=this.computeNodePfWithoutConnection(n4,e5);if(this.ripConnection(t8),!this.requeueConnection(t8))return;o4=r6,s3=!0,this.clearCostCaches()}}s3&&this.RANDOM_RIP_FRACTION>0&&this.processRandomRipping(e4)}processRandomRipping(t5){let e4=this.processedConnectionQueue.filter(e5=>e5.path!==void 0&&e5.connection.name!==t5);if(e4.length===0)return;let n3=Math.max(1,Math.floor(this.RANDOM_RIP_FRACTION*e4.length)),s3=kt2(e4,(this.hyperParameters.SHUFFLE_SEED??0)+this.totalRipCount+this.processedConnectionQueue.length);for(let t7=0;t7<n3&&t7<s3.length&&!(this.totalRipCount>this.MAX_RIPS);t7++){let e5=s3[t7];if(this.ripConnection(e5),!this.requeueConnection(e5))return;this.clearCostCaches()}}visualize(){let t5={};if(this.failed){let e5=this.failedConnection?.connection.pointsToConnect[0],n4=this.failedConnection?.connection.pointsToConnect[1];e5&&n4&&(t5={lines:[{points:[e5,n4],label:`Failed Connection ${this.failedConnection?.connection.name}`,strokeWidth:1,strokeColor:"red",strokeDash:[2,2]}]})}return e4=Fo2(this),n3=t5,{...e4,rects:[...e4.rects??[],...n3.rects??[]],points:[...e4.points??[],...n3.points??[]],lines:[...e4.lines??[],...n3.lines??[]],circles:[...e4.circles??[],...n3.circles??[]],arrows:[...e4.arrows??[],...n3.arrows??[]],texts:[...e4.texts??[],...n3.texts??[]]};var e4,n3}},Zo2=class extends Zt2{constructor(t5){super();__publicField(this,"params");__publicField(this,"precomputedInitialParams");this.params=t5,this.MAX_ITERATIONS=1e8,this.GREEDY_MULTIPLIER=1.2,this.MIN_SUBSTEPS=50,this.precomputedInitialParams=t5.precomputedInitialParams??Yo2(t5.simpleRouteJson,t5.inputNodes)}getHyperParameterDefs(){let t5=this.params.numShuffleSeeds??50;return[{name:"SHUFFLE_SEED",possibleValues:Array.from({length:t5},(t7,e4)=>({SHUFFLE_SEED:e4+1700*(this.params.hyperParameters?.SHUFFLE_SEED??0)}))}]}getCombinationDefs(){return[["SHUFFLE_SEED"]]}generateSolver(t5){return new Vo2({simpleRouteJson:this.params.simpleRouteJson,capacityMeshNodes:this.params.capacityMeshNodes,inputNodes:this.params.inputNodes,colorMap:this.params.colorMap,nodeMemoryPfMap:this.params.nodeMemoryPfMap,hyperParameters:{...this.params.hyperParameters,...t5,MIN_ALLOWED_BOARD_SCORE:this.params.minAllowedBoardScore??t5.MIN_ALLOWED_BOARD_SCORE??this.params.hyperParameters?.MIN_ALLOWED_BOARD_SCORE},precomputedInitialParams:this.precomputedInitialParams,fixedRoutes:this.params.fixedRoutes})}computeG(t5){return-t5.computeBoardScore()}computeH(t5){let e4=t5.progress||0;return e4<.1?0:-(t5.computeBoardScore()/e4)*(1-e4)}getNodesWithPortPoints(){if(this.winningSolver)return this.winningSolver.getNodesWithPortPoints();let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.getNodesWithPortPoints():[]}get connectionsWithResults(){if(this.winningSolver)return this.winningSolver.connectionsWithResults;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.connectionsWithResults:[]}get inputNodes(){if(this.winningSolver)return this.winningSolver.inputNodes;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.inputNodes:this.params.inputNodes}get nodeMap(){if(this.winningSolver)return this.winningSolver.nodeMap;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.nodeMap:new Map(this.params.inputNodes.map(t7=>[t7.capacityMeshNodeId,t7]))}get assignedPortPoints(){if(this.winningSolver)return this.winningSolver.assignedPortPoints;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.assignedPortPoints:new Map}get nodeAssignedPortPoints(){if(this.winningSolver)return this.winningSolver.nodeAssignedPortPoints;let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.nodeAssignedPortPoints:new Map}computeBoardScore(){if(this.winningSolver)return this.winningSolver.computeBoardScore();let t5=this.getSupervisedSolverWithBestFitness();return t5?t5.solver.computeBoardScore():0}onSolve(t5){this.stats={...t5.solver.stats,winningHyperParameters:this.winningSolver?.hyperParameters}}visualize(){return this.winningSolver?this.winningSolver.visualize():super.visualize()}};function Go2(t5,e4,n3,s3={}){return{solverName:t5,solverClass:e4,getConstructorParams:n3,onSolved:s3.onSolved}}var Jo2=class extends y{constructor(t5,e4={}){super();__publicField(this,"netToPointPairsSolver");__publicField(this,"nodeSolver");__publicField(this,"nodeTargetMerger");__publicField(this,"edgeSolver");__publicField(this,"colorMap");__publicField(this,"highDensityRouteSolver");__publicField(this,"highDensityStitchSolver");__publicField(this,"singleLayerNodeMerger");__publicField(this,"strawSolver");__publicField(this,"deadEndSolver");__publicField(this,"traceSimplificationSolver");__publicField(this,"availableSegmentPointSolver");__publicField(this,"portPointPathingSolver");__publicField(this,"multiSectionPortPointOptimizer");__publicField(this,"viaDiameter");__publicField(this,"minTraceWidth");__publicField(this,"effort");__publicField(this,"startTimeOfPhase");__publicField(this,"endTimeOfPhase");__publicField(this,"timeSpentOnPhase");__publicField(this,"activeSubSolver",null);__publicField(this,"connMap");__publicField(this,"srjWithPointPairs");__publicField(this,"capacityNodes",null);__publicField(this,"capacityEdges",null);__publicField(this,"cacheProvider",null);__publicField(this,"pipelineDef",[Go2("netToPointPairsSolver",gn2,t5=>[t5.srj,t5.colorMap],{onSolved:t5=>{t5.srjWithPointPairs=t5.netToPointPairsSolver?.getNewSimpleRouteJson(),t5.colorMap=ot2(t5.srjWithPointPairs,this.connMap),t5.connMap=$e2(t5.srjWithPointPairs)}}),Go2("nodeSolver",Js2,t5=>[{simpleRouteJson:t5.srjWithPointPairs}],{onSolved:t5=>{t5.capacityNodes=t5.nodeSolver?.getOutput().meshNodes??[]}}),Go2("edgeSolver",cn2,t5=>[t5.capacityNodes],{onSolved:t5=>{t5.capacityEdges=t5.edgeSolver?.edges}}),Go2("availableSegmentPointSolver",Io2,t5=>[{nodes:t5.capacityNodes,edges:t5.capacityEdges||[],traceWidth:t5.minTraceWidth,colorMap:t5.colorMap}]),Go2("portPointPathingSolver",Zo2,t5=>{let e4=t5.capacityNodes.map(t7=>({capacityMeshNodeId:t7.capacityMeshNodeId,center:t7.center,width:t7.width,height:t7.height,portPoints:[],availableZ:t7.availableZ,_containsTarget:t7._containsTarget,_containsObstacle:t7._containsObstacle})),n3=new Map(e4.map(t7=>[t7.capacityMeshNodeId,t7])),s3=t5.availableSegmentPointSolver;for(let t7 of s3.sharedEdgeSegments)for(let e5 of t7.portPoints){let[t8,s4]=e5.nodeIds,o4={portPointId:e5.segmentPortPointId,x:e5.x,y:e5.y,z:e5.availableZ[0]??0,connectionNodeIds:[t8,s4],distToCentermostPortOnZ:e5.distToCentermostPortOnZ},i3=n3.get(t8);i3&&i3.portPoints.push(o4)}return[{simpleRouteJson:t5.srjWithPointPairs,inputNodes:e4,capacityMeshNodes:t5.capacityNodes,colorMap:t5.colorMap,numShuffleSeeds:200,hyperParameters:{NODE_PF_MAX_PENALTY:100,FORCE_OFF_BOARD_FREQUENCY:0,STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR:4}}]}),Go2("multiSectionPortPointOptimizer",Uo2,t5=>{let e4=t5.portPointPathingSolver;return[{simpleRouteJson:t5.srjWithPointPairs,inputNodes:e4.inputNodes,capacityMeshNodes:t5.capacityNodes,capacityMeshEdges:t5.capacityEdges,colorMap:t5.colorMap,initialConnectionResults:e4.connectionsWithResults,initialAssignedPortPoints:e4.assignedPortPoints,initialNodeAssignedPortPoints:e4.nodeAssignedPortPoints,effort:t5.effort}]}),Go2("highDensityRouteSolver",Le2,t5=>[{nodePortPoints:t5.multiSectionPortPointOptimizer?.getNodesWithPortPoints()??t5.portPointPathingSolver?.getNodesWithPortPoints()??[],colorMap:t5.colorMap,connMap:t5.connMap,viaDiameter:t5.viaDiameter,traceWidth:t5.minTraceWidth}]),Go2("highDensityStitchSolver",nn2,t5=>[{connections:t5.srjWithPointPairs.connections,hdRoutes:t5.highDensityRouteSolver.routes,colorMap:t5.colorMap,layerCount:t5.srj.layerCount,defaultViaDiameter:t5.viaDiameter}]),Go2("traceSimplificationSolver",Mo2,t5=>[{hdRoutes:t5.highDensityStitchSolver.mergedHdRoutes,obstacles:t5.srj.obstacles,connMap:t5.connMap,colorMap:t5.colorMap,outline:t5.srj.outline,defaultViaDiameter:t5.viaDiameter,layerCount:t5.srj.layerCount,iterations:2}])]);__publicField(this,"currentPipelineStepIndex",0);if(this.srj=t5,this.opts=e4,this.MAX_ITERATIONS=1e8,this.viaDiameter=t5.minViaDiameter??.6,this.minTraceWidth=t5.minTraceWidth,this.effort=e4.effort??1,e4.capacityDepth===void 0){let n3=t5.bounds.maxX-t5.bounds.minX,s3=t5.bounds.maxY-t5.bounds.minY,o4=Math.max(n3,s3),i3=e4.targetMinCapacity??.5;e4.capacityDepth=Be2(o4,i3)}this.connMap=$e2(t5),this.colorMap=ot2(t5,this.connMap),this.cacheProvider=e4.cacheProvider===void 0?ut2():e4.cacheProvider===null?null:e4.cacheProvider,this.startTimeOfPhase={},this.endTimeOfPhase={},this.timeSpentOnPhase={}}getConstructorParams(){return[this.srj,this.opts]}_step(){let t5=this.pipelineDef[this.currentPipelineStepIndex];if(!t5)return void(this.solved=!0);if(this.activeSubSolver)return this.activeSubSolver.step(),void(this.activeSubSolver.solved?(this.endTimeOfPhase[t5.solverName]=performance.now(),this.timeSpentOnPhase[t5.solverName]=this.endTimeOfPhase[t5.solverName]-this.startTimeOfPhase[t5.solverName],t5.onSolved?.(this),this.activeSubSolver=null,this.currentPipelineStepIndex++):this.activeSubSolver.failed&&(this.error=this.activeSubSolver?.error,this.failed=!0,this.activeSubSolver=null));let e4=t5.getConstructorParams(this);this.activeSubSolver=new t5.solverClass(...e4),this[t5.solverName]=this.activeSubSolver,this.timeSpentOnPhase[t5.solverName]=0,this.startTimeOfPhase[t5.solverName]=performance.now()}solveUntilPhase(t5){for(;this.getCurrentPhase()!==t5;)this.step()}getCurrentPhase(){return this.pipelineDef[this.currentPipelineStepIndex]?.solverName??"none"}visualize(){if(!this.solved&&this.activeSubSolver)return this.activeSubSolver.visualize();let t5=this.netToPointPairsSolver?.visualize(),e4=this.nodeSolver?.visualize(),n3=this.nodeTargetMerger?.visualize(),s3=this.singleLayerNodeMerger?.visualize(),o4=this.strawSolver?.visualize(),i3=this.edgeSolver?.visualize(),r4=this.deadEndSolver?.visualize(),a2=this.availableSegmentPointSolver?.visualize(),c3=this.portPointPathingSolver?.visualize(),h2=this.multiSectionPortPointOptimizer?.visualize(),d3=this.highDensityRouteSolver?.visualize(),l2=this.highDensityStitchSolver?.visualize(),u4=this.traceSimplificationSolver?.visualize(),p2=this.srj.outline,m3=[];if(m3.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)"}),p2&&p2.length>=2){let t7=p2.map(t8=>({x:t8.x,y:t8.y}));t7.push({...t7[0]}),m3.push({points:t7,strokeColor:"rgba(0, 136, 255, 0.95)"})}let f2={points:[...this.srj.connections.flatMap(t7=>t7.pointsToConnect.map(e5=>({...e5,label:`${t7.name} ${e5.pcb_port_id??""}`})))],rects:[...(this.srj.obstacles??[]).map(t7=>({...t7,fill:t7.layers?.includes("top")?"rgba(255,0,0,0.25)":t7.layers?.includes("bottom")?"rgba(0,0,255,0.25)":"rgba(255,0,0,0.25)",label:t7.layers?.join(", ")}))],lines:m3},y3=[f2,t5,e4,n3,s3,o4,i3,r4,a2,c3,h2,d3?g3(f2,d3):null,l2,u4,this.solved?g3(f2,sn2(this.getOutputSimpleRouteJson())):null].filter(Boolean);return g3(...y3)}preview(){if(this.highDensityRouteSolver){let t5=[];for(let e4=this.highDensityRouteSolver.routes.length-1;e4>=0;e4--){let n3=this.highDensityRouteSolver.routes[e4];if(t5.push({points:n3.route.map(t7=>({x:t7.x,y:t7.y})),strokeColor:this.colorMap[n3.connectionName]}),t5.length>200)break}return{lines:t5}}if(this.portPointPathingSolver){let t5=[];for(let e4 of this.portPointPathingSolver.connectionsWithResults)e4.path&&t5.push({points:e4.path.map(t7=>({x:t7.point.x,y:t7.point.y})),strokeColor:this.colorMap[e4.connection.name]});return{lines:t5}}return this.netToPointPairsSolver?this.netToPointPairsSolver?.visualize():{}}_getOutputHdRoutes(){return this.traceSimplificationSolver?.simplifiedHdRoutes??this.highDensityStitchSolver.mergedHdRoutes}getOutputSimplifiedPcbTraces(){if(!this.solved||!this.highDensityRouteSolver)throw new Error("Cannot get output before solving is complete");let t5=[],e4=this._getOutputHdRoutes();for(let n3 of this.netToPointPairsSolver?.newConnections??[]){let s3=n3.netConnectionName??this.srj.connections.find(t7=>t7.name===n3.name)?.netConnectionName,o4=e4.filter(t7=>t7.connectionName===n3.name);for(let e5=0;e5<o4.length;e5++){let i3=o4[e5],r4={type:"pcb_trace",pcb_trace_id:`${n3.name}_${e5}`,connection_name:s3??n3.rootConnectionName??n3.name,route:We2(i3,this.srj.layerCount)};t5.push(r4)}}return t5}getOutputSimpleRouteJson(){return{...this.srj,traces:this.getOutputSimplifiedPcbTraces()}}};var Ko2=class extends y{constructor({nodes:t5,edges:e4,capacityPaths:n3,colorMap:s3}){super();__publicField(this,"nodes");__publicField(this,"edges");__publicField(this,"capacityPaths");__publicField(this,"nodeMap");__publicField(this,"nodeEdgeMap");__publicField(this,"unprocessedNodeIds");__publicField(this,"nodePortSegments");__publicField(this,"colorMap");this.nodes=t5,this.edges=e4,this.nodeMap=new Map(t5.map(t7=>[t7.capacityMeshNodeId,t7])),this.nodeEdgeMap=No2(e4),this.capacityPaths=n3,this.colorMap=s3??{},this.unprocessedNodeIds=[...new Set(n3.flatMap(t7=>t7.nodeIds))],this.nodePortSegments=new Map}step(){let t5=this.unprocessedNodeIds.pop();if(!t5)return void(this.solved=!0);let e4=[];for(let n4 of this.capacityPaths){let s4=n4.nodeIds.indexOf(t5);s4!==-1&&e4.push({path:n4,indexOfNodeInPath:s4})}let n3=this.nodeMap.get(t5),s3=[];for(let{path:o5,indexOfNodeInPath:i3}of e4){let e5=o5.nodeIds[i3-1],r4=o5.nodeIds[i3+1];for(let i4 of[e5,r4]){let e6=this.nodeMap.get(i4);if(!e6)continue;let r6=Qo2(n3,e6),a2=e6.availableZ.filter(t7=>n3.availableZ.includes(t7));if(a2.length===0)continue;let c3={capacityMeshNodeId:t5,start:r6.start,end:r6.end,connectionNames:[o5.connectionName],rootConnectionNames:o5.rootConnectionName?[o5.rootConnectionName]:void 0,availableZ:a2};s3.push(c3)}}let o4=(function(t7){let e5=[],n4=t7.map(t8=>({...t8,connectionNames:[...t8.connectionNames],rootConnectionNames:t8.rootConnectionNames?[...t8.rootConnectionNames]:[],availableZ:[...t8.availableZ].sort((t10,e6)=>t10-e6)}));for(;n4.length>0;){let t8=n4.pop(),s4=!1;for(let n5=0;n5<e5.length;n5++){let o5=e5[n5],i3=ei2(o5.start,t8.start)&&ei2(o5.end,t8.end)||ei2(o5.start,t8.end)&&ei2(o5.end,t8.start),r4=ni2(o5.availableZ,t8.availableZ);if(i3&&r4){let e6=new Set(o5.connectionNames);t8.connectionNames.forEach(t10=>e6.add(t10)),o5.connectionNames=Array.from(e6);let n6=new Set(o5.rootConnectionNames||[]);t8.rootConnectionNames?.forEach(t10=>n6.add(t10)),o5.rootConnectionNames=Array.from(n6),s4=!0;break}}s4||e5.push(t8)}return e5})(s3);this.nodePortSegments.set(t5,o4)}visualize(){let t5={lines:[],points:[],rects:[],circles:[]};return this.nodePortSegments.forEach((e4,n3)=>{this.nodeMap.get(n3),e4.forEach(e5=>{e5.start.x,e5.end.x;for(let s3=0;s3<e5.connectionNames.length;s3++){let o4={x:.05*Math.max(...e5.availableZ),y:.05*Math.max(...e5.availableZ)},i3={x:(e5.start.x+e5.end.x)/2,y:(e5.start.y+e5.end.y)/2},r4={x:i3.x+o4.x,y:i3.y+o4.y};o4.x>0&&t5.lines.push({points:[i3,r4],strokeColor:"rgba(0, 0, 0, 0.25)",strokeDash:"5 5"}),t5.points.push({x:r4.x,y:r4.y,label:`${n3}: ${e5.connectionNames.join(", ")}
|
|
543
543
|
availableZ: ${e5.availableZ.join(",")}
|
|
544
544
|
nodePortSegmentId: ${e5.nodePortSegmentId}`}),t5.lines.push({points:[e5.start,e5.end],strokeColor:it2(this.colorMap[e5.connectionNames[s3]],.6)})}})}),t5}};function Qo2(t5,e4){let n3={start:Math.max(t5.center.x-t5.width/2,e4.center.x-e4.width/2),end:Math.min(t5.center.x+t5.width/2,e4.center.x+e4.width/2)},s3={start:Math.max(t5.center.y-t5.height/2,e4.center.y-e4.height/2),end:Math.min(t5.center.y+t5.height/2,e4.center.y+e4.height/2)};if(n3.end-n3.start<s3.end-s3.start){let t7=(n3.start+n3.end)/2;return{start:{x:t7,y:s3.start},end:{x:t7,y:s3.end}}}{let t7=(s3.start+s3.end)/2;return{start:{x:n3.start,y:t7},end:{x:n3.end,y:t7}}}}var ti2=1e-9;function ei2(t5,e4){return Math.abs(t5.x-e4.x)<ti2&&Math.abs(t5.y-e4.y)<ti2}function ni2(t5,e4){if(t5.length!==e4.length)return!1;for(let n3=0;n3<t5.length;n3++)if(t5[n3]!==e4[n3])return!1;return!0}var si2=class extends y{constructor({segments:t5,colorMap:e4,nodes:n3}){super();__publicField(this,"unsolvedSegments");__publicField(this,"solvedSegments");__publicField(this,"nodeMap");__publicField(this,"colorMap");this.MAX_ITERATIONS=1e5,this.unsolvedSegments=t5,this.solvedSegments=[],this.colorMap=e4??{},this.nodeMap=Object.fromEntries(n3.map(t7=>[t7.capacityMeshNodeId,t7]))}_step(){let t5=!1,e4=[...this.unsolvedSegments];for(let n3 of e4){let e5=n3.connectionNames.length;if((!("assignedPoints"in n3)||n3.assignedPoints?.length!==e5)&&e5===1){let e6={x:(n3.start.x+n3.end.x)/2,y:(n3.start.y+n3.end.y)/2,z:n3.availableZ[0]};n3.assignedPoints=[{connectionName:n3.connectionNames[0],rootConnectionName:n3.rootConnectionNames?.[0],point:e6}],this.unsolvedSegments.splice(this.unsolvedSegments.indexOf(n3),1),this.solvedSegments.push(n3),t5=!0}}if(!t5&&e4.length>0){let n3=e4[0];for(let t7 of e4)t7.connectionNames.length<n3.connectionNames.length&&(n3=t7);let s3=[...n3.connectionNames].sort(),o4=n3.end.x-n3.start.x,i3=n3.end.y-n3.start.y,r4=s3.length,a2=[];for(let t7=1;t7<=r4;t7++){let e5=t7/(r4+1);a2.push({x:n3.start.x+o4*e5,y:n3.start.y+i3*e5,z:n3.availableZ[0]})}n3.assignedPoints=s3.map((t7,e5)=>({connectionName:t7,rootConnectionName:n3.rootConnectionNames?.[n3.connectionNames.indexOf(t7)],point:a2[e5]})),this.unsolvedSegments.splice(this.unsolvedSegments.indexOf(n3),1),this.solvedSegments.push(n3),t5=!0}this.unsolvedSegments.length===0&&(this.solved=!0)}getNodesWithPortPoints(){if(!this.solved)throw new Error("CapacitySegmentToPointSolver not solved, can't give port points yet");let t5=new Map;for(let e4 of this.solvedSegments){let n3=e4.capacityMeshNodeId,s3=this.nodeMap[n3];t5.has(n3)||t5.set(n3,{capacityMeshNodeId:n3,portPoints:[],center:s3.center,width:s3.width,height:s3.height}),t5.get(n3).portPoints.push(...e4.assignedPoints.map(t7=>({...t7.point,connectionName:t7.connectionName})))}return Array.from(t5.values())}visualize(){let t5={points:[],lines:this.solvedSegments.map(t7=>({points:[t7.start,t7.end],step:4})),rects:[],circles:[],coordinateSystem:"cartesian",title:"Capacity Segment to Point Solver"};for(let e5=0;e5<this.solvedSegments.length;e5++){let n4=this.solvedSegments[e5];for(let e6=0;e6<n4.assignedPoints.length;e6++){let s3=n4.assignedPoints[e6],o4={x:s3.point.x,y:s3.point.y},i3={x:s3.point.x+.05*s3.point.z,y:s3.point.y+.05*s3.point.z};s3.point.z!==0&&t5.lines.push({points:[o4,i3],strokeColor:"rgba(0, 0, 0, 0.25)",strokeDash:"5 5",step:4}),t5.points.push({x:i3.x,y:i3.y,label:[`${n4.capacityMeshNodeId}-${s3.connectionName}`,`z: ${n4.availableZ.join(",")}`,`nodePortSegmentId: ${n4.nodePortSegmentId}`].join(`
|
|
545
545
|
`),color:this.colorMap[s3.connectionName],step:4})}}let e4=[],n3={};for(let t7 of this.solvedSegments){let e5=t7.capacityMeshNodeId;n3[e5]||(n3[e5]={});for(let s3 of t7.assignedPoints)n3[e5][s3.connectionName]||(n3[e5][s3.connectionName]=[]),n3[e5][s3.connectionName].push({x:s3.point.x,y:s3.point.y})}for(let t7 in n3)for(let s3 in n3[t7]){let o4=n3[t7][s3];o4.length>1&&e4.push({points:o4,step:4,strokeDash:"5 5",strokeColor:this.colorMap[s3]||"#000"})}return t5.lines.push(...e4),t5}};function oi2(t5){let{nodeId:e4,nodeIdToSegmentIds:n3,segmentIdToNodeIds:s3,hops:o4}=t5;if(o4===0)return[e4];let i3=new Set([e4]),r4=[{nodeId:e4,remainingHops:o4}];for(;r4.length>0;){let{nodeId:t7,remainingHops:e5}=r4.shift();if(e5===0)continue;let o5=n3.get(t7)||[];for(let t8 of o5){let n4=s3.get(t8)||[];for(let t10 of n4)i3.has(t10)||(i3.add(t10),r4.push({nodeId:t10,remainingHops:e5-1}))}}return Array.from(i3)}var ii2=t5=>Array.from(t5.entries()).map(([t7,{x:e4,y:n3,z:s3}])=>`${t7}(${e4?.toFixed(3)??""},${n3?.toFixed(3)??""},${s3??""})`).sort().join("&"),ri2=(t5,e4,n3,s3)=>{let o4=Math.min(t5,e4),i3=Math.max(t5,e4),r4=Math.min(n3,s3);return o4<=Math.max(n3,s3)&&i3>=r4},ai2=(t5,e4,n3,s3)=>{let o4=[],i3=new Map(t5.originalPointMap);for(let[t7,e5]of n3.entries()){let n4=i3.get(t7);i3.set(t7,{x:e5.x??n4.x,y:e5.y??n4.y,z:e5.z??n4.z})}for(let n4 of t5.allNodeIds){if(!e4.get(n4))continue;let r4=t5.segmentPairsInNode.get(n4);for(let t7 of r4){let e5=i3.get(t7[0]),s4=i3.get(t7[1]);e5.z!==s4.z&&o4.push({type:"transition_via",segmentPoints:t7,capacityMeshNodeId:n4,probabilityOfFailure:0})}for(let t7=0;t7<r4.length;t7++)for(let e5=t7+1;e5<r4.length;e5++){if(s3?.areIdsConnected(r4[t7][0],r4[t7][1]))continue;let a2=r4[t7],c3=r4[e5],h2=i3.get(a2[0]),d3=i3.get(a2[1]),l2=i3.get(c3[0]),u4=i3.get(c3[1]);if(!ri2(h2.z,d3.z,l2.z,u4.z))continue;let p2=gt2(h2,d3,l2,u4),m3=h2.z===d3.z&&l2.z===u4.z&&h2.z===l2.z;p2&&(m3?o4.push({type:"same_layer_crossing",segmentPoints:[a2,c3],capacityMeshNodeId:n4,crossingLine1:a2,crossingLine2:c3,probabilityOfFailure:0}):h2.z===d3.z&&l2.z!==u4.z?o4.push({type:"single_transition_crossing",segmentPoints:[a2,c3],capacityMeshNodeId:n4,sameLayerCrossingLine:a2,transitionCrossingLine:c3,probabilityOfFailure:0}):h2.z!==d3.z&&l2.z===u4.z?o4.push({type:"single_transition_crossing",segmentPoints:[a2,c3],capacityMeshNodeId:n4,sameLayerCrossingLine:c3,transitionCrossingLine:a2,probabilityOfFailure:0}):h2.z!==d3.z&&l2.z!==u4.z&&o4.push({type:"double_transition_crossing",segmentPoints:[a2,c3],capacityMeshNodeId:n4,crossingLine1:a2,crossingLine2:c3,probabilityOfFailure:0}))}}return o4},ci2=(t5,e4,n3)=>{if(e4.type==="change_layer")for(let n4 of e4.segmentPointIds){let s3=t5.get(n4)||{};t5.set(n4,{...s3,z:e4.newZ})}else if(e4.type==="swap_position_on_segment"){let[s3,o4]=e4.segmentPointIds,i3=n3(s3),r4=n3(o4),a2=t5.get(s3)||{},c3=t5.get(o4)||{};t5.set(s3,{...a2,x:r4.x,y:r4.y}),t5.set(o4,{...c3,x:i3.x,y:i3.y})}else if(e4.type==="combined")for(let s3 of e4.operations)ci2(t5,s3,n3)},hi2=(t5,e4)=>{let n3=new Map,s3=new Map,o4=new Map,i3=[],r4=0;for(let a2 of t5)for(let t7 of a2.assignedPoints){let c3={segmentPointId:"SP"+r4++,segmentId:a2.nodePortSegmentId,capacityMeshNodeIds:e4.get(a2.nodePortSegmentId),connectionName:t7.connectionName,rootConnectionName:t7.rootConnectionName,x:t7.point.x,y:t7.point.y,z:t7.point.z,directlyConnectedSegmentPointIds:[]};n3.set(c3.segmentPointId,c3);for(let t8 of c3.capacityMeshNodeIds)s3.set(t8,[...s3.get(t8)??[],c3.segmentPointId]);o4.set(a2.nodePortSegmentId,[...o4.get(a2.nodePortSegmentId)??[],c3.segmentPointId]),i3.push(c3)}return{segmentPointMap:n3,nodeToSegmentPointMap:s3,segmentToSegmentPointMap:o4}},di2=class extends y{constructor(t5){super();__publicField(this,"nodeMap");__publicField(this,"dedupedSegments");__publicField(this,"dedupedSegmentMap");__publicField(this,"MUTABLE_HOPS",1);__publicField(this,"unravelSection");__publicField(this,"candidates",[]);__publicField(this,"lastProcessedCandidate",null);__publicField(this,"bestCandidate",null);__publicField(this,"originalCandidate");__publicField(this,"rootNodeId");__publicField(this,"nodeIdToSegmentIds");__publicField(this,"segmentIdToNodeIds");__publicField(this,"colorMap");__publicField(this,"tunedNodeCapacityMap");__publicField(this,"MAX_CANDIDATES",500);__publicField(this,"iterationsSinceImprovement",0);__publicField(this,"hyperParameters");__publicField(this,"selectedCandidateIndex",null);__publicField(this,"queuedOrExploredCandidatePointModificationHashes",new Set);__publicField(this,"constructorParams");if(this.constructorParams=t5,this.MUTABLE_HOPS=t5.MUTABLE_HOPS??this.MUTABLE_HOPS,this.MAX_ITERATIONS=5e4,this.hyperParameters={...t5.hyperParameters,MAX_ITERATIONS_WITHOUT_IMPROVEMENT:200},this.nodeMap=t5.nodeMap,this.dedupedSegments=t5.dedupedSegments,t5.dedupedSegmentMap)this.dedupedSegmentMap=t5.dedupedSegmentMap;else{this.dedupedSegmentMap=new Map;for(let t7 of this.dedupedSegments)this.dedupedSegmentMap.set(t7.nodePortSegmentId,t7)}this.nodeIdToSegmentIds=t5.nodeIdToSegmentIds,this.segmentIdToNodeIds=t5.segmentIdToNodeIds,this.rootNodeId=t5.rootNodeId,this.colorMap=t5.colorMap??{},this.unravelSection=this.createUnravelSection({segmentPointMap:t5.segmentPointMap,nodeToSegmentPointMap:t5.nodeToSegmentPointMap,segmentToSegmentPointMap:t5.segmentToSegmentPointMap}),this.tunedNodeCapacityMap=new Map;for(let t7 of this.unravelSection.allNodeIds)this.tunedNodeCapacityMap.set(t7,ke2(this.nodeMap.get(t7)));this.originalCandidate=this.createInitialCandidate(),this.candidates=[this.originalCandidate]}getConstructorParams(){return{...this.constructorParams,segmentPointMap:this.unravelSection.segmentPointMap,nodeToSegmentPointMap:this.unravelSection.segmentPointsInNode,segmentToSegmentPointMap:this.unravelSection.segmentPointsInSegment}}createUnravelSection(t5){let e4=oi2({nodeId:this.rootNodeId,nodeIdToSegmentIds:this.nodeIdToSegmentIds,segmentIdToNodeIds:this.segmentIdToNodeIds,hops:this.MUTABLE_HOPS}),n3=oi2({nodeId:this.rootNodeId,nodeIdToSegmentIds:this.nodeIdToSegmentIds,segmentIdToNodeIds:this.segmentIdToNodeIds,hops:this.MUTABLE_HOPS+1}),s3=Array.from(new Set(n3).difference(new Set(e4)));t5?.segmentPointMap||(t5=hi2(this.dedupedSegments,this.segmentIdToNodeIds));let o4=new Map;for(let e5 of n3)o4.set(e5,t5.nodeToSegmentPointMap.get(e5));let i3=new Map;for(let e5 of n3)for(let n4 of o4.get(e5)){let e6=t5.segmentPointMap.get(n4);i3.set(n4,e6)}let r4=Array.from(i3.values()),a2=new Map;for(let t7 of r4)a2.set(t7.segmentId,[...a2.get(t7.segmentId)??[],t7.segmentPointId]);for(let[e5,n4]of o4.entries())for(let e6=0;e6<n4.length;e6++){let s4=t5.segmentPointMap.get(n4[e6]);for(let o5=e6+1;o5<n4.length;o5++){let e7=t5.segmentPointMap.get(n4[o5]);e7.segmentPointId!==s4.segmentPointId&&e7.segmentId!==s4.segmentId&&e7.connectionName===s4.connectionName&&(e7.directlyConnectedSegmentPointIds.includes(s4.segmentPointId)||(s4.directlyConnectedSegmentPointIds.push(e7.segmentPointId),e7.directlyConnectedSegmentPointIds.push(s4.segmentPointId)))}}let c3=new Map;for(let t7 of n3)c3.set(t7,[]);for(let e5 of r4)for(let n4 of e5.capacityMeshNodeIds){let s4=c3.get(n4);if(s4)for(let o5 of e5.directlyConnectedSegmentPointIds){let i4=t5.segmentPointMap.get(o5);i4.segmentPointId!==e5.segmentPointId&&i4.capacityMeshNodeIds.some(t7=>t7===n4)&&(s4.some(([t7,n5])=>t7===e5.segmentPointId&&n5===i4.segmentPointId||t7===i4.segmentPointId&&n5===e5.segmentPointId)||s4.push([e5.segmentPointId,i4.segmentPointId]))}}let h2=new Set;for(let t7 of e4)for(let e5 of this.nodeIdToSegmentIds.get(t7))this.segmentIdToNodeIds.get(e5).every(t8=>!this.nodeMap.get(t8)._containsTarget)&&h2.add(e5);let d3=new Set;for(let t7 of r4){let n4=t7.capacityMeshNodeIds.some(t8=>e4.includes(t8)),s4=this.dedupedSegmentMap.get(t7.segmentId),o5=s4&&s4.availableZ.length>1;(n4||o5)&&d3.add(t7.segmentPointId)}let l2=new Set;for(let t7 of r4)if(t7.capacityMeshNodeIds.some(t8=>this.nodeMap.get(t8)?._containsTarget)){let e5=this.dedupedSegmentMap.get(t7.segmentId);e5&&e5.availableZ.length===1&&l2.add(t7.segmentPointId)}return{allNodeIds:n3,mutableNodeIds:e4,immutableNodeIds:s3,mutableSegmentIds:h2,segmentPairsInNode:c3,segmentPointMap:i3,segmentPointsInNode:o4,segmentPointsInSegment:a2,originalPointMap:i3,mutableSegmentPointIds:d3,zLockedSegmentPointIds:l2}}createInitialCandidate(){let t5=new Map,e4=ai2(this.unravelSection,this.nodeMap,t5),n3=this.computeG({issues:e4,originalCandidate:{},operationsPerformed:0,operation:{}});return{pointModifications:t5,g:n3,h:0,f:n3,operationsPerformed:0,candidateHash:ii2(t5),issues:ai2(this.unravelSection,this.nodeMap,t5)}}get nextCandidate(){return this.candidates[0]??null}getPointInCandidate(t5,e4){let n3=this.unravelSection.segmentPointMap.get(e4),s3=t5.pointModifications.get(e4);return{x:s3?.x??n3.x,y:s3?.y??n3.y,z:s3?.z??n3.z,segmentId:n3.segmentId}}getConnectionSegmentPointIds(t5){let e4=[];for(let[n3,s3]of this.unravelSection.segmentPointMap.entries())s3.connectionName===t5&&e4.push(n3);return e4}canConnectionUseLayer(t5,e4){for(let n3 of t5){let t7=this.unravelSection.segmentPointMap.get(n3),s3=this.dedupedSegmentMap.get(t7.segmentId);if(!s3||!s3.availableZ.includes(e4))return!1}return!0}getOperationsForIssue(t5,e4){let n3=[];if(e4.type==="transition_via"){let[s3,o4]=e4.segmentPoints,i3=this.getPointInCandidate(t5,s3),r4=this.getPointInCandidate(t5,o4),a2=this.unravelSection.segmentPointMap.get(s3),c3=(this.unravelSection.segmentPointMap.get(o4),this.dedupedSegmentMap.get(i3.segmentId).availableZ),h2=this.dedupedSegmentMap.get(r4.segmentId).availableZ,d3=this.unravelSection.zLockedSegmentPointIds.has(s3),l2=this.unravelSection.zLockedSegmentPointIds.has(o4),u4=this.getConnectionSegmentPointIds(a2.connectionName);if(this.canConnectionUseLayer(u4,r4.z)){let t7=u4.filter(t8=>this.unravelSection.mutableSegmentPointIds.has(t8)&&!this.unravelSection.zLockedSegmentPointIds.has(t8));t7.length>0&&n3.push({type:"change_layer",newZ:r4.z,segmentPointIds:t7})}if(this.canConnectionUseLayer(u4,i3.z)){let t7=u4.filter(t8=>this.unravelSection.mutableSegmentPointIds.has(t8)&&!this.unravelSection.zLockedSegmentPointIds.has(t8));t7.length>0&&n3.push({type:"change_layer",newZ:i3.z,segmentPointIds:t7})}this.unravelSection.mutableSegmentPointIds.has(s3)&&!d3&&c3.includes(r4.z)&&n3.push({type:"change_layer",newZ:r4.z,segmentPointIds:[s3]}),this.unravelSection.mutableSegmentPointIds.has(o4)&&!l2&&h2.includes(i3.z)&&n3.push({type:"change_layer",newZ:i3.z,segmentPointIds:[o4]})}if(e4.type==="same_layer_crossing"){let[t7,s3]=e4.crossingLine1,[o4,i3]=e4.crossingLine2,r4=[],a2=this.unravelSection.segmentPointMap.get(t7),c3=this.unravelSection.segmentPointMap.get(s3),h2=this.unravelSection.segmentPointMap.get(o4),d3=this.unravelSection.segmentPointMap.get(i3),l2=this.unravelSection.mutableSegmentPointIds.has(t7),u4=this.unravelSection.mutableSegmentPointIds.has(s3),p2=this.unravelSection.mutableSegmentPointIds.has(o4),m3=this.unravelSection.mutableSegmentPointIds.has(i3),f2=this.unravelSection.zLockedSegmentPointIds.has(t7),g4=this.unravelSection.zLockedSegmentPointIds.has(s3),y3=this.unravelSection.zLockedSegmentPointIds.has(o4),x3=this.unravelSection.zLockedSegmentPointIds.has(i3);l2&&p2&&a2.segmentId===h2.segmentId&&r4.push([t7,o4]),l2&&m3&&a2.segmentId===d3.segmentId&&r4.push([t7,i3]),u4&&p2&&c3.segmentId===h2.segmentId&&r4.push([s3,o4]),u4&&m3&&c3.segmentId===d3.segmentId&&r4.push([s3,i3]);for(let[t8,e5]of r4)n3.push({type:"swap_position_on_segment",segmentPointIds:[t8,e5]});let v4=this.getConnectionSegmentPointIds(a2.connectionName),S4=this.getConnectionSegmentPointIds(h2.connectionName),P4=new Set;for(let t8 of this.unravelSection.segmentPointMap.values()){let e5=this.dedupedSegmentMap.get(t8.segmentId);if(e5)for(let t10 of e5.availableZ)P4.add(t10)}for(let t8 of P4)if(t8!==a2.z&&this.canConnectionUseLayer(v4,t8)){let e5=v4.filter(t10=>this.unravelSection.mutableSegmentPointIds.has(t10)&&!this.unravelSection.zLockedSegmentPointIds.has(t10));e5.length>0&&n3.push({type:"change_layer",newZ:t8,segmentPointIds:e5})}for(let t8 of P4)if(t8!==h2.z&&this.canConnectionUseLayer(S4,t8)){let e5=S4.filter(t10=>this.unravelSection.mutableSegmentPointIds.has(t10)&&!this.unravelSection.zLockedSegmentPointIds.has(t10));e5.length>0&&n3.push({type:"change_layer",newZ:t8,segmentPointIds:e5})}let b3=this.dedupedSegmentMap.get(a2.segmentId),M5=this.dedupedSegmentMap.get(c3.segmentId),N4=this.dedupedSegmentMap.get(h2.segmentId),I4=this.dedupedSegmentMap.get(d3.segmentId),C3=(t8,e5)=>t8.every(t10=>t10.availableZ.includes(e5));if(l2&&u4&&!f2&&!g4){let e5=a2.z===0?1:0;C3([b3,M5],e5)&&n3.push({type:"change_layer",newZ:e5,segmentPointIds:[t7,s3]})}if(p2&&m3&&!y3&&!x3){let t8=h2.z===0?1:0;C3([N4,I4],t8)&&n3.push({type:"change_layer",newZ:t8,segmentPointIds:[o4,i3]})}if(l2&&!f2){let e5=a2.z===0?1:0;b3.availableZ.includes(e5)&&n3.push({type:"change_layer",newZ:e5,segmentPointIds:[t7]})}if(u4&&!g4){let t8=c3.z===0?1:0;M5.availableZ.includes(t8)&&n3.push({type:"change_layer",newZ:t8,segmentPointIds:[s3]})}if(p2&&!y3){let t8=h2.z===0?1:0;N4.availableZ.includes(t8)&&n3.push({type:"change_layer",newZ:t8,segmentPointIds:[o4]})}if(m3&&!x3){let t8=d3.z===0?1:0;I4.availableZ.includes(t8)&&n3.push({type:"change_layer",newZ:t8,segmentPointIds:[i3]})}}return n3}computeG(t5){let{issues:e4,originalCandidate:n3,operationsPerformed:s3,operation:o4}=t5,i3=new Map;for(let t7 of e4){i3.has(t7.capacityMeshNodeId)||i3.set(t7.capacityMeshNodeId,{numTransitionCrossings:0,numSameLayerCrossings:0,numEntryExitLayerChanges:0});let e5=i3.get(t7.capacityMeshNodeId);t7.type==="transition_via"?e5.numTransitionCrossings++:t7.type==="same_layer_crossing"?e5.numSameLayerCrossings++:t7.type==="double_transition_crossing"||t7.type==="single_transition_crossing"?e5.numEntryExitLayerChanges++:t7.type}let r4=0;for(let[t7,{numEntryExitLayerChanges:e5,numSameLayerCrossings:n4,numTransitionCrossings:s4}]of i3){let o5=this.nodeMap.get(t7),i4=Math.min(Co2(o5,n4,e5,s4),.999999);r4+=Math.log(1-i4)}var a2;return(a2=r4)<-Math.LN2?Math.log(1-Math.exp(a2)):Math.log(-Math.expm1(a2))}getUnexploredNeighborByApplyingOperation(t5,e4){let n3=new Map(t5.pointModifications);ci2(n3,e4,e5=>this.getPointInCandidate(t5,e5));let s3=ii2(n3);if(this.queuedOrExploredCandidatePointModificationHashes.has(s3))return null;let o4=ai2(this.unravelSection,this.nodeMap,n3),i3=t5.operationsPerformed+1,r4=this.computeG({issues:o4,originalCandidate:t5,operationsPerformed:i3,operation:e4});return{issues:o4,g:r4,h:0,f:r4,pointModifications:n3,candidateHash:s3,operationsPerformed:i3}}getNeighborOperationsForCandidate(t5){return t5.issues.flatMap(e4=>this.getOperationsForIssue(t5,e4))}getNeighbors(t5){let e4=[],n3=this.getNeighborOperationsForCandidate(t5);for(let s3 of n3){let n4=this.getUnexploredNeighborByApplyingOperation(t5,s3);n4&&e4.push(n4)}return e4}_step(){let t5=this.candidates.shift();this.iterationsSinceImprovement++,this.iterationsSinceImprovement>this.hyperParameters.MAX_ITERATIONS_WITHOUT_IMPROVEMENT?this.solved=!0:t5?(this.lastProcessedCandidate=t5,t5.f<(this.bestCandidate?.f??1/0)&&(this.bestCandidate=t5,this.iterationsSinceImprovement=0),this.getNeighbors(t5).forEach(t7=>{this.queuedOrExploredCandidatePointModificationHashes.has(t7.candidateHash)||(this.queuedOrExploredCandidatePointModificationHashes.add(t7.candidateHash),this.candidates.push(t7))}),this.candidates.sort((t7,e4)=>t7.f-e4.f),this.candidates.length=Math.min(this.candidates.length,this.MAX_CANDIDATES)):this.solved=!0}visualize(){let t5={points:[],lines:[],rects:[],circles:[],coordinateSystem:"cartesian",title:"Unravel Section Solver"},e4=null;if(e4=this.selectedCandidateIndex!==null?this.selectedCandidateIndex==="best"?this.bestCandidate:this.selectedCandidateIndex==="original"?this.originalCandidate:this.candidates[this.selectedCandidateIndex]:this.solved?this.bestCandidate:this.lastProcessedCandidate||this.candidates[0],!e4)return t5;let n3=new Map;for(let[t7,s4]of this.unravelSection.segmentPointMap){let o4={...s4},i3=e4.pointModifications.get(t7);i3&&(i3.x!==void 0&&(o4.x=i3.x),i3.y!==void 0&&(o4.y=i3.y),i3.z!==void 0&&(o4.z=i3.z)),n3.set(t7,o4)}for(let[e5,s4]of n3)t5.points.push({x:s4.x,y:s4.y,label:`${e5}
|
|
@@ -574,7 +574,7 @@ ${e4.width}x${e4.height}`});return t5}},zi2=class extends y{constructor({nodes:t
|
|
|
574
574
|
`)}),e4.points.push({x:r4.x-.1,y:r4.y+.1,color:n4,label:[t5.currentConnection.connectionId,"end"].join(`
|
|
575
575
|
`)})}for(let n4 of t5.solvedRoutes){let t7=Rr2(n4.connection.connectionId),s4=[];for(let t8 of n4.path){let e5=t8.port;s4.push({x:e5.d.x,y:e5.d.y})}s4.length>0&&e4.lines.push({points:s4,strokeColor:t7})}let n3=t5.candidateQueue.peekMany(10);for(let t7=0;t7<n3.length;t7++){let s4=n3[t7],o4=s4.port,i3=t7===0;e4.points.push({x:o4.d.x,y:o4.d.y,color:i3?"green":"rgba(128, 128, 128, 0.25)",label:[s4.port.portId,`g: ${s4.g.toFixed(2)}`,`h: ${s4.h.toFixed(2)}`,`f: ${s4.f.toFixed(2)}`].join(`
|
|
576
576
|
`)})}let s3=n3[0];if(!t5.solved&&s3&&t5.currentConnection){let n4=Rr2(t5.currentConnection.connectionId),o4=[],i3=s3;for(;i3;){let t7=i3.port;o4.unshift({x:t7.d.x,y:t7.d.y}),i3=i3.parent}o4.length>1&&e4.lines.push({points:o4,strokeColor:n4})}return e4})(this)}},kr2=Object.create,Br2=Object.defineProperty,jr2=Object.getOwnPropertyDescriptor,Wr2=Object.getOwnPropertyNames,Hr2=Object.getPrototypeOf,Ur2=Object.prototype.hasOwnProperty,Vr2=(t5,e4)=>function(){return e4||(0,t5[Wr2(t5)[0]])((e4={exports:{}}).exports,e4),e4.exports},Zr2=(t5,e4,n3)=>(n3=t5!=null?kr2(Hr2(t5)):{},((t7,e5,n4,s3)=>{if(e5&&typeof e5=="object"||typeof e5=="function")for(let o4 of Wr2(e5))Ur2.call(t7,o4)||o4===n4||Br2(t7,o4,{get:()=>e5[o4],enumerable:!(s3=jr2(e5,o4))||s3.enumerable});return t7})(!e4&&t5&&t5.__esModule?n3:Br2(n3,"default",{value:t5,enumerable:!0}),t5)),Gr2=Vr2({"node_modules/is-buffer/index.js"(t5,e4){function n3(t7){return!!t7.constructor&&typeof t7.constructor.isBuffer=="function"&&t7.constructor.isBuffer(t7)}e4.exports=function(t7){return t7!=null&&(n3(t7)||(function(t8){return typeof t8.readFloatLE=="function"&&typeof t8.slice=="function"&&n3(t8.slice(0,0))})(t7)||!!t7._isBuffer)}}}),Jr2=Vr2({"node_modules/kind-of/index.js"(t5,e4){var n3=Gr2(),s3=Object.prototype.toString;e4.exports=function(t7){if(t7===void 0)return"undefined";if(t7===null)return"null";if(t7===!0||t7===!1||t7 instanceof Boolean)return"boolean";if(typeof t7=="string"||t7 instanceof String)return"string";if(typeof t7=="number"||t7 instanceof Number)return"number";if(typeof t7=="function"||t7 instanceof Function)return"function";if(Array.isArray!==void 0&&Array.isArray(t7))return"array";if(t7 instanceof RegExp)return"regexp";if(t7 instanceof Date)return"date";var e5=s3.call(t7);return e5==="[object RegExp]"?"regexp":e5==="[object Date]"?"date":e5==="[object Arguments]"?"arguments":e5==="[object Error]"?"error":n3(t7)?"buffer":e5==="[object Set]"?"set":e5==="[object WeakSet]"?"weakset":e5==="[object Map]"?"map":e5==="[object WeakMap]"?"weakmap":e5==="[object Symbol]"?"symbol":e5==="[object Int8Array]"?"int8array":e5==="[object Uint8Array]"?"uint8array":e5==="[object Uint8ClampedArray]"?"uint8clampedarray":e5==="[object Int16Array]"?"int16array":e5==="[object Uint16Array]"?"uint16array":e5==="[object Int32Array]"?"int32array":e5==="[object Uint32Array]"?"uint32array":e5==="[object Float32Array]"?"float32array":e5==="[object Float64Array]"?"float64array":"object"}}}),qr2=Vr2({"node_modules/rename-keys/index.js"(t5,e4){(function(){function t7(t8,e5){if(typeof e5!="function")return t8;var n3={};for(var s3 in t8)Object.prototype.hasOwnProperty.call(t8,s3)&&(n3[e5(s3,t8[s3])||s3]=t8[s3]);return n3}e4!==void 0&&e4.exports?e4.exports=t7:typeof define=="function"&&define.amd?define([],function(){return t7}):window.rename=t7})()}}),Kr2=Vr2({"node_modules/deep-rename-keys/index.js"(t5,e4){var n3=Jr2(),s3=qr2();e4.exports=function t7(e5,o4){var i3=n3(e5);if(i3!=="object"&&i3!=="array")throw new Error("expected an object");var r4=[];for(var a2 in i3==="object"&&(e5=s3(e5,o4),r4={}),e5)if(e5.hasOwnProperty(a2)){var c3=e5[a2];n3(c3)==="object"||n3(c3)==="array"?r4[a2]=t7(c3,o4):r4[a2]=c3}return r4}}}),Qr2=Vr2({"node_modules/eventemitter3/index.js"(t5,e4){var n3=Object.prototype.hasOwnProperty,s3="~";function o4(){}function i3(t7,e5,n4){this.fn=t7,this.context=e5,this.once=n4||!1}function r4(){this._events=new o4,this._eventsCount=0}Object.create&&(o4.prototype=Object.create(null),new o4().__proto__||(s3=!1)),r4.prototype.eventNames=function(){var t7,e5,o5=[];if(this._eventsCount===0)return o5;for(e5 in t7=this._events)n3.call(t7,e5)&&o5.push(s3?e5.slice(1):e5);return Object.getOwnPropertySymbols?o5.concat(Object.getOwnPropertySymbols(t7)):o5},r4.prototype.listeners=function(t7,e5){var n4=s3?s3+t7:t7,o5=this._events[n4];if(e5)return!!o5;if(!o5)return[];if(o5.fn)return[o5.fn];for(var i4=0,r6=o5.length,a2=new Array(r6);i4<r6;i4++)a2[i4]=o5[i4].fn;return a2},r4.prototype.emit=function(t7,e5,n4,o5,i4,r6){var a2=s3?s3+t7:t7;if(!this._events[a2])return!1;var c3,h2,d3=this._events[a2],l2=arguments.length;if(d3.fn){switch(d3.once&&this.removeListener(t7,d3.fn,void 0,!0),l2){case 1:return d3.fn.call(d3.context),!0;case 2:return d3.fn.call(d3.context,e5),!0;case 3:return d3.fn.call(d3.context,e5,n4),!0;case 4:return d3.fn.call(d3.context,e5,n4,o5),!0;case 5:return d3.fn.call(d3.context,e5,n4,o5,i4),!0;case 6:return d3.fn.call(d3.context,e5,n4,o5,i4,r6),!0}for(h2=1,c3=new Array(l2-1);h2<l2;h2++)c3[h2-1]=arguments[h2];d3.fn.apply(d3.context,c3)}else{var u4,p2=d3.length;for(h2=0;h2<p2;h2++)switch(d3[h2].once&&this.removeListener(t7,d3[h2].fn,void 0,!0),l2){case 1:d3[h2].fn.call(d3[h2].context);break;case 2:d3[h2].fn.call(d3[h2].context,e5);break;case 3:d3[h2].fn.call(d3[h2].context,e5,n4);break;case 4:d3[h2].fn.call(d3[h2].context,e5,n4,o5);break;default:if(!c3)for(u4=1,c3=new Array(l2-1);u4<l2;u4++)c3[u4-1]=arguments[u4];d3[h2].fn.apply(d3[h2].context,c3)}}return!0},r4.prototype.on=function(t7,e5,n4){var o5=new i3(e5,n4||this),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.once=function(t7,e5,n4){var o5=new i3(e5,n4||this,!0),r6=s3?s3+t7:t7;return this._events[r6]?this._events[r6].fn?this._events[r6]=[this._events[r6],o5]:this._events[r6].push(o5):(this._events[r6]=o5,this._eventsCount++),this},r4.prototype.removeListener=function(t7,e5,n4,i4){var r6=s3?s3+t7:t7;if(!this._events[r6])return this;if(!e5)return--this._eventsCount===0?this._events=new o4:delete this._events[r6],this;var a2=this._events[r6];if(a2.fn)a2.fn!==e5||i4&&!a2.once||n4&&a2.context!==n4||(--this._eventsCount===0?this._events=new o4:delete this._events[r6]);else{for(var c3=0,h2=[],d3=a2.length;c3<d3;c3++)(a2[c3].fn!==e5||i4&&!a2[c3].once||n4&&a2[c3].context!==n4)&&h2.push(a2[c3]);h2.length?this._events[r6]=h2.length===1?h2[0]:h2:--this._eventsCount===0?this._events=new o4:delete this._events[r6]}return this},r4.prototype.removeAllListeners=function(t7){var e5;return t7?(e5=s3?s3+t7:t7,this._events[e5]&&(--this._eventsCount===0?this._events=new o4:delete this._events[e5])):(this._events=new o4,this._eventsCount=0),this},r4.prototype.off=r4.prototype.removeListener,r4.prototype.addListener=r4.prototype.on,r4.prototype.setMaxListeners=function(){return this},r4.prefixed=s3,r4.EventEmitter=r4,e4!==void 0&&(e4.exports=r4)}}),ta2=Vr2({"node_modules/xml-lexer/dist/lexer.js"(t5,e4){function n3(t7,e5,n4){return e5 in t7?Object.defineProperty(t7,e5,{value:n4,enumerable:!0,configurable:!0,writable:!0}):t7[e5]=n4,t7}var s3=Qr2(),o4=function(){},i3={data:"state-data",cdata:"state-cdata",tagBegin:"state-tag-begin",tagName:"state-tag-name",tagEnd:"state-tag-end",attributeNameStart:"state-attribute-name-start",attributeName:"state-attribute-name",attributeNameEnd:"state-attribute-name-end",attributeValueBegin:"state-attribute-value-begin",attributeValue:"state-attribute-value"},r4={lt:"action-lt",gt:"action-gt",space:"action-space",equal:"action-equal",quote:"action-quote",slash:"action-slash",char:"action-char",error:"action-error"},a2={text:"text",openTag:"open-tag",closeTag:"close-tag",attributeName:"attribute-name",attributeValue:"attribute-value"},c3={" ":r4.space," ":r4.space,"\n":r4.space,"\r":r4.space,"<":r4.lt,">":r4.gt,'"':r4.quote,"'":r4.quote,"=":r4.equal,"/":r4.slash};e4.exports={State:i3,Action:r4,Type:a2,create:function(t7){var e5,h2,d3,l2,u4,p2,m3,f2,g4,y3;t7=Object.assign({debug:!1},t7);var x3=new s3,v4=i3.data,S4="",P4="",b3="",M5="",N4="",I4="",C3=function(e6,n4){if(P4[0]!=="?"&&P4[0]!=="!"){var s4={type:e6,value:n4};t7.debug&&console.log("emit:",s4),x3.emit("data",s4)}};x3.stateMachine=(n3(y3={},i3.data,(n3(e5={},r4.lt,function(){S4.trim()&&C3(a2.text,S4),P4="",N4=!1,v4=i3.tagBegin}),n3(e5,r4.char,function(t8){S4+=t8}),e5)),n3(y3,i3.cdata,n3({},r4.char,function(t8){(S4+=t8).substr(-3)==="]]>"&&(C3(a2.text,S4.slice(0,-3)),S4="",v4=i3.data)})),n3(y3,i3.tagBegin,(n3(h2={},r4.space,o4),n3(h2,r4.char,function(t8){P4=t8,v4=i3.tagName}),n3(h2,r4.slash,function(){P4="",N4=!0}),h2)),n3(y3,i3.tagName,(n3(d3={},r4.space,function(){N4?v4=i3.tagEnd:(v4=i3.attributeNameStart,C3(a2.openTag,P4))}),n3(d3,r4.gt,function(){C3(N4?a2.closeTag:a2.openTag,P4),S4="",v4=i3.data}),n3(d3,r4.slash,function(){v4=i3.tagEnd,C3(a2.openTag,P4)}),n3(d3,r4.char,function(t8){(P4+=t8)==="![CDATA["&&(v4=i3.cdata,S4="",P4="")}),d3)),n3(y3,i3.tagEnd,(n3(l2={},r4.gt,function(){C3(a2.closeTag,P4),S4="",v4=i3.data}),n3(l2,r4.char,o4),l2)),n3(y3,i3.attributeNameStart,(n3(u4={},r4.char,function(t8){b3=t8,v4=i3.attributeName}),n3(u4,r4.gt,function(){S4="",v4=i3.data}),n3(u4,r4.space,o4),n3(u4,r4.slash,function(){N4=!0,v4=i3.tagEnd}),u4)),n3(y3,i3.attributeName,(n3(p2={},r4.space,function(){v4=i3.attributeNameEnd}),n3(p2,r4.equal,function(){C3(a2.attributeName,b3),v4=i3.attributeValueBegin}),n3(p2,r4.gt,function(){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),S4="",v4=i3.data}),n3(p2,r4.slash,function(){N4=!0,M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),v4=i3.tagEnd}),n3(p2,r4.char,function(t8){b3+=t8}),p2)),n3(y3,i3.attributeNameEnd,(n3(m3={},r4.space,o4),n3(m3,r4.equal,function(){C3(a2.attributeName,b3),v4=i3.attributeValueBegin}),n3(m3,r4.gt,function(){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),S4="",v4=i3.data}),n3(m3,r4.char,function(t8){M5="",C3(a2.attributeName,b3),C3(a2.attributeValue,M5),b3=t8,v4=i3.attributeName}),m3)),n3(y3,i3.attributeValueBegin,(n3(f2={},r4.space,o4),n3(f2,r4.quote,function(t8){I4=t8,M5="",v4=i3.attributeValue}),n3(f2,r4.gt,function(){C3(a2.attributeValue,M5=""),S4="",v4=i3.data}),n3(f2,r4.char,function(t8){I4="",M5=t8,v4=i3.attributeValue}),f2)),n3(y3,i3.attributeValue,(n3(g4={},r4.space,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),v4=i3.attributeNameStart)}),n3(g4,r4.quote,function(t8){I4===t8?(C3(a2.attributeValue,M5),v4=i3.attributeNameStart):M5+=t8}),n3(g4,r4.gt,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),S4="",v4=i3.data)}),n3(g4,r4.slash,function(t8){I4?M5+=t8:(C3(a2.attributeValue,M5),N4=!0,v4=i3.tagEnd)}),n3(g4,r4.char,function(t8){M5+=t8}),g4)),y3);var _4=function(e6){t7.debug&&console.log(v4,e6);var n4=x3.stateMachine[v4],s4=n4[(function(t8){return c3[t8]||r4.char})(e6)]||n4[r4.error]||n4[r4.char];s4(e6)};return x3.write=function(t8){for(var e6=t8.length,n4=0;n4<e6;n4++)_4(t8[n4])},x3}}}}),ea2=Vr2({"node_modules/xml-reader/dist/reader.js"(t5,e4){var n3=Qr2(),s3=ta2(),o4=s3.Type,i3={element:"element",text:"text"},r4=function(t7){return Object.assign({name:"",type:i3.element,value:"",parent:null,attributes:{},children:[]},t7)},a2=function(t7){t7=Object.assign({stream:!1,parentNodes:!0,doneEvent:"done",tagPrefix:"tag:",emitTopLevelOnly:!1,debug:!1},t7);var e5=void 0,a3=void 0,c3=void 0,h2=void 0,d3=new n3,l2=function(n4){switch(n4.type){case o4.openTag:if(c3===null)(c3=a3).name=n4.value;else{var s4=r4({name:n4.value,parent:c3});c3.children.push(s4),c3=s4}break;case o4.closeTag:var l3=c3.parent;if(t7.parentNodes||(c3.parent=null),c3.name!==n4.value)break;t7.stream&&l3===a3&&(a3.children=[],c3.parent=null),t7.emitTopLevelOnly&&l3!==a3||(d3.emit(t7.tagPrefix+c3.name,c3),d3.emit("tag",c3.name,c3)),c3===a3&&(e5.removeAllListeners("data"),d3.emit(t7.doneEvent,c3),a3=null),c3=l3;break;case o4.text:c3&&c3.children.push(r4({type:i3.text,value:n4.value,parent:t7.parentNodes?c3:null}));break;case o4.attributeName:h2=n4.value,c3.attributes[h2]="";break;case o4.attributeValue:c3.attributes[h2]=n4.value}};return d3.reset=function(){(e5=s3.create({debug:t7.debug})).on("data",l2),a3=r4(),c3=null,h2="",d3.parse=e5.write},d3.reset(),d3};e4.exports={parseSync:function(t7,e5){e5=Object.assign({},e5,{stream:!1,tagPrefix:":"});var n4=a2(e5),s4=void 0;return n4.on("done",function(t8){s4=t8}),n4.parse(t7),s4},create:a2,NodeType:i3}}}),{cos:na2,sin:sa2,PI:oa2}=Math,{tan:ia2}=Math,ra2=(Zr2(Kr2()),Zr2(ea2()),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(t5){throw this.error=`${this.constructor.name} error: ${t5}`,this.failed=!0,t5}!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`,this.failed=!0),"computeProgress"in this&&(this.progress=this.computeProgress())}}_step(){}getConstructorParams(){throw new Error("getConstructorParams not implemented")}getOutput(){return null}solve(){let t5=Date.now();for(;!this.solved&&!this.failed;)this.step();let e4=Date.now();this.timeToSolve=e4-t5}visualize(){return{lines:[],points:[],rects:[],circles:[]}}tryFinalAcceptance(){}preview(){return{lines:[],points:[],rects:[],circles:[]}}}),aa2=t5=>t5?`hsl(${(t7=>{let e4=0;for(let n3=0;n3<t7.length;n3++)e4=779*t7.charCodeAt(n3)+((e4<<5)-e4);return e4})(t5)%360}, 100%, 50%)`:"rgba(0, 0, 0, 0.5)",ca2=t5=>[[{x:t5.minX,y:t5.minY},{x:t5.maxX,y:t5.minY}],[{x:t5.maxX,y:t5.minY},{x:t5.maxX,y:t5.maxY}],[{x:t5.maxX,y:t5.maxY},{x:t5.minX,y:t5.maxY}],[{x:t5.minX,y:t5.maxY},{x:t5.minX,y:t5.minY}]];function ha2(t5,e4){let{minX:n3,maxX:s3,minY:o4,maxY:i3}=e4,r4=s3-n3,a2=i3-o4,c3=1e-6;return Math.abs(t5.y-i3)<c3?t5.x-n3:Math.abs(t5.x-s3)<c3?r4+(i3-t5.y):Math.abs(t5.y-o4)<c3?r4+a2+(s3-t5.x):Math.abs(t5.x-n3)<c3?2*r4+a2+(t5.y-o4):0}function da2(t5,e4){let{minX:n3,maxX:s3,minY:o4,maxY:i3}=e4,r4=1e-6,a2=Math.abs(t5.y-i3)<r4,c3=Math.abs(t5.y-o4)<r4,h2=Math.abs(t5.x-s3)<r4,d3=Math.abs(t5.x-n3)<r4;if(a2&&h2)return{x:-Math.SQRT1_2,y:-Math.SQRT1_2};if(a2&&d3)return{x:Math.SQRT1_2,y:-Math.SQRT1_2};if(c3&&h2)return{x:-Math.SQRT1_2,y:Math.SQRT1_2};if(c3&&d3)return{x:Math.SQRT1_2,y:Math.SQRT1_2};if(a2)return{x:0,y:-1};if(c3)return{x:0,y:1};if(h2)return{x:-1,y:0};if(d3)return{x:1,y:0};let l2=(o4+i3)/2,u4=(n3+s3)/2-t5.x,p2=l2-t5.y,m3=Math.hypot(u4,p2);return m3>0?{x:u4/m3,y:p2/m3}:{x:0,y:-1}}function la2(t5,e4,n3,s3,o4,i3,r4,a2,c3,h2){for(let d3=0;d3<=h2;d3++){let l2=d3/h2,u4=1-l2,p2=u4*u4,m3=p2*u4,f2=l2*l2,g4=f2*l2,y3=2*d3;c3[y3]=m3*t5+3*p2*l2*n3+3*u4*f2*o4+g4*r4,c3[y3+1]=m3*e4+3*p2*l2*s3+3*u4*f2*i3+g4*a2}}function ua2(t5,e4,n3,s3,o4){let i3=[];for(let r4=0;r4<=o4;r4++){let a2=r4/o4,c3=1-a2,h2=c3*c3,d3=h2*c3,l2=a2*a2,u4=l2*a2;i3.push({x:d3*t5.x+3*h2*a2*e4.x+3*c3*l2*n3.x+u4*s3.x,y:d3*t5.y+3*h2*a2*e4.y+3*c3*l2*n3.y+u4*s3.y})}return i3}function pa2(t5,e4,n3,s3,o4,i3){let r4=o4-n3,a2=i3-s3,c3=r4*r4+a2*a2;if(c3===0){let o5=t5-n3,i4=e4-s3;return o5*o5+i4*i4}let h2=Math.max(0,Math.min(1,((t5-n3)*r4+(e4-s3)*a2)/c3)),d3=t5-(n3+h2*r4),l2=e4-(s3+h2*a2);return d3*d3+l2*l2}function ma2(t5,e4,n3,s3,o4,i3,r4,a2){let c3=(r4-o4)*(e4-i3)-(a2-i3)*(t5-o4),h2=(r4-o4)*(s3-i3)-(a2-i3)*(n3-o4),d3=(n3-t5)*(i3-e4)-(s3-e4)*(o4-t5),l2=(n3-t5)*(a2-e4)-(s3-e4)*(r4-t5);return(c3>0&&h2<0||c3<0&&h2>0)&&(d3>0&&l2<0||d3<0&&l2>0)?0:Math.min(pa2(t5,e4,o4,i3,r4,a2),pa2(n3,s3,o4,i3,r4,a2),pa2(o4,i3,t5,e4,n3,s3),pa2(r4,a2,t5,e4,n3,s3))}function fa2(t5,e4,n3,s3,o4,i3,r4,a2){let c3=(r4-o4)*(e4-i3)-(a2-i3)*(t5-o4),h2=(r4-o4)*(s3-i3)-(a2-i3)*(n3-o4),d3=(n3-t5)*(i3-e4)-(s3-e4)*(o4-t5),l2=(n3-t5)*(a2-e4)-(s3-e4)*(r4-t5);return(c3>0&&h2<0||c3<0&&h2>0)&&(d3>0&&l2<0||d3<0&&l2>0)}function ga2(t5,e4,n3,s3,o4){let i3=t7=>(t7%o4+o4)%o4,r4=i3(t5),a2=i3(e4),c3=i3(n3),h2=i3(s3),[d3,l2]=r4<a2?[r4,a2]:[a2,r4];return c3>d3&&c3<l2&&h2>d3&&h2<l2}function ya2(t5,e4){let n3=1/0,s3=-1/0,o4=1/0,i3=-1/0;for(let r4=0;r4<e4;r4++){let e5=t5[2*r4],a2=t5[2*r4+1];e5<n3&&(n3=e5),e5>s3&&(s3=e5),a2<o4&&(o4=a2),a2>i3&&(i3=a2)}return{minX:n3,maxX:s3,minY:o4,maxY:i3}}var xa2=class extends ra2{constructor(t5){super();__publicField(this,"outputTraces",[]);__publicField(this,"traces",[]);__publicField(this,"optimizationStep",0);__publicField(this,"maxOptimizationSteps",100);__publicField(this,"sampledPoints",[]);__publicField(this,"traceBounds",[]);__publicField(this,"obstacleSegments",new Float64Array(0));__publicField(this,"obstacleNetworkIds",[]);__publicField(this,"numObstacleSegments",0);__publicField(this,"collisionPairs",[]);__publicField(this,"lastCost",1/0);__publicField(this,"stagnantSteps",0);__publicField(this,"effectiveTraceToTraceSpacing",0);this.problem=t5;for(let t7 of this.problem.obstacles)t7.outerSegments=ca2(t7);this.precomputeObstacles()}getConstructorParams(){return this.problem}precomputeObstacles(){let{obstacles:t5}=this.problem,e4=0;for(let n4 of t5)n4.outerSegments&&(e4+=n4.outerSegments.length);this.obstacleSegments=new Float64Array(4*e4),this.obstacleNetworkIds=[],this.numObstacleSegments=e4;let n3=0;for(let e5 of t5)if(e5.outerSegments)for(let t7 of e5.outerSegments)this.obstacleSegments[n3++]=t7[0].x,this.obstacleSegments[n3++]=t7[0].y,this.obstacleSegments[n3++]=t7[1].x,this.obstacleSegments[n3++]=t7[1].y,this.obstacleNetworkIds.push(e5.networkId)}initializeTraces(){let{bounds:t5,waypointPairs:e4}=this.problem,{minX:n3,maxX:s3,minY:o4,maxY:i3}=t5,r4=s3-n3,a2=i3-o4,c3=2*r4+2*a2,h2=(function(t7){return{x:(t7.minX+t7.maxX)/2,y:(t7.minY+t7.maxY)/2}})(t5),d3=e4.map((e5,n4)=>({pair:e5,t1:ha2(e5.start,t5),t2:ha2(e5.end,t5),idx:n4})),l2=d3.map(()=>[]),u4=d3.map(()=>[]);for(let t7 of d3)for(let e5 of d3)if(t7.idx!==e5.idx){if(t7.pair.networkId&&e5.pair.networkId&&t7.pair.networkId===e5.pair.networkId)continue;ga2(e5.t1,e5.t2,t7.t1,t7.t2,c3)&&(l2[t7.idx].push(e5.idx),u4[e5.idx].push(t7.idx))}let p2=l2.map(t7=>t7.length),m3=Math.max(...p2,1);this.traces=d3.map(({pair:e5,t1:n4,t2:s4,idx:o5})=>{let i4=da2(e5.start,t5),c4=da2(e5.end,t5),d4=Math.hypot(e5.end.x-e5.start.x,e5.end.y-e5.start.y),f2=p2[o5]/m3,g4=(e5.start.x+e5.end.x)/2,y3=(e5.start.y+e5.end.y)/2,x3=d4*(.25+.15*(1-Math.hypot(g4-h2.x,y3-h2.y)/Math.hypot(r4/2,a2/2)))*(1-.3*f2),v4=.05*Math.min(r4,a2),S4=Math.max(v4,x3),P4=Math.max(v4,x3);return{waypointPair:e5,ctrl1:{x:e5.start.x+S4*i4.x,y:e5.start.y+S4*i4.y},ctrl2:{x:e5.end.x+P4*c4.x,y:e5.end.y+P4*c4.y},networkId:e5.networkId,t1:n4,t2:s4,perpDir1:i4,perpDir2:c4,d1:S4,d2:P4,containedBy:l2[o5],contains:u4[o5]}}),this.sampledPoints=this.traces.map(()=>new Float64Array(12)),this.traceBounds=this.traces.map(()=>({minX:0,maxX:0,minY:0,maxY:0})),this.updateSampledTraces(),this.updateCollisionPairs()}updateSampledTraces(){for(let t5=0;t5<this.traces.length;t5++){let e4=this.traces[t5];la2(e4.waypointPair.start.x,e4.waypointPair.start.y,e4.ctrl1.x,e4.ctrl1.y,e4.ctrl2.x,e4.ctrl2.y,e4.waypointPair.end.x,e4.waypointPair.end.y,this.sampledPoints[t5],5),this.traceBounds[t5]=ya2(this.sampledPoints[t5],6)}}updateSingleTraceSample(t5){let e4=this.traces[t5];la2(e4.waypointPair.start.x,e4.waypointPair.start.y,e4.ctrl1.x,e4.ctrl1.y,e4.ctrl2.x,e4.ctrl2.y,e4.waypointPair.end.x,e4.waypointPair.end.y,this.sampledPoints[t5],5),this.traceBounds[t5]=ya2(this.sampledPoints[t5],6)}updateControlPointsFromDistances(t5){let e4=this.traces[t5],{minX:n3,maxX:s3,minY:o4,maxY:i3}=this.problem.bounds,r4=1e-6,a2=e4.waypointPair.start.x+e4.d1*e4.perpDir1.x,c3=e4.waypointPair.start.y+e4.d1*e4.perpDir1.y,h2=e4.waypointPair.end.x+e4.d2*e4.perpDir2.x,d3=e4.waypointPair.end.y+e4.d2*e4.perpDir2.y,l2=e4.waypointPair.start;Math.abs(l2.x-n3)<r4&&(a2=Math.max(a2,n3)),Math.abs(l2.x-s3)<r4&&(a2=Math.min(a2,s3)),Math.abs(l2.y-o4)<r4&&(c3=Math.max(c3,o4)),Math.abs(l2.y-i3)<r4&&(c3=Math.min(c3,i3));let u4=e4.waypointPair.end;Math.abs(u4.x-n3)<r4&&(h2=Math.max(h2,n3)),Math.abs(u4.x-s3)<r4&&(h2=Math.min(h2,s3)),Math.abs(u4.y-o4)<r4&&(d3=Math.max(d3,o4)),Math.abs(u4.y-i3)<r4&&(d3=Math.min(d3,i3)),a2=Math.max(n3,Math.min(s3,a2)),c3=Math.max(o4,Math.min(i3,c3)),h2=Math.max(n3,Math.min(s3,h2)),d3=Math.max(o4,Math.min(i3,d3)),e4.ctrl1.x=a2,e4.ctrl1.y=c3,e4.ctrl2.x=h2,e4.ctrl2.y=d3}updateCollisionPairs(){let t5=this.effectiveTraceToTraceSpacing;this.collisionPairs=[];for(let e4=0;e4<this.traces.length;e4++)for(let n3=e4+1;n3<this.traces.length;n3++){let s3=this.traces[e4],o4=this.traces[n3];if(s3.networkId&&o4.networkId&&s3.networkId===o4.networkId)continue;let i3=this.traceBounds[e4],r4=this.traceBounds[n3];i3.maxX+t5>=r4.minX&&r4.maxX+t5>=i3.minX&&i3.maxY+t5>=r4.minY&&r4.maxY+t5>=i3.minY&&this.collisionPairs.push([e4,n3])}}computeTotalCost(){let{preferredObstacleToTraceSpacing:t5}=this.problem,e4=this.effectiveTraceToTraceSpacing,n3=e4**2,s3=t5**2,o4=0;for(let[t7,s4]of this.collisionPairs){let i3=this.sampledPoints[t7],r4=this.sampledPoints[s4];for(let t8=0;t8<5;t8++){let s5=i3[2*t8],a2=i3[2*t8+1],c3=i3[2*(t8+1)],h2=i3[2*(t8+1)+1];for(let t10=0;t10<5;t10++){let i4=ma2(s5,a2,c3,h2,r4[2*t10],r4[2*t10+1],r4[2*(t10+1)],r4[2*(t10+1)+1]);i4<n3&&(o4+=(e4-Math.sqrt(i4))**2,i4<1e-18&&(o4+=20*n3))}}}for(let e5=0;e5<this.traces.length;e5++){let n4=this.traces[e5],i3=this.sampledPoints[e5],r4=this.traceBounds[e5];for(let e6=0;e6<this.numObstacleSegments;e6++){if(n4.networkId&&this.obstacleNetworkIds[e6]&&n4.networkId===this.obstacleNetworkIds[e6])continue;let a2=4*e6,c3=this.obstacleSegments[a2],h2=this.obstacleSegments[a2+1],d3=this.obstacleSegments[a2+2],l2=this.obstacleSegments[a2+3],u4=Math.min(c3,d3),p2=Math.max(c3,d3),m3=Math.min(h2,l2),f2=Math.max(h2,l2);if(!(r4.maxX+t5<u4||p2+t5<r4.minX||r4.maxY+t5<m3||f2+t5<r4.minY))for(let e7=0;e7<5;e7++){let n5=ma2(i3[2*e7],i3[2*e7+1],i3[2*(e7+1)],i3[2*(e7+1)+1],c3,h2,d3,l2);n5<s3&&(o4+=(t5-Math.sqrt(n5))**2,n5<1e-18&&(o4+=20*s3))}}}return o4}computeCostForTrace(t5){let{preferredObstacleToTraceSpacing:e4}=this.problem,n3=this.effectiveTraceToTraceSpacing,s3=n3**2,o4=e4**2,i3=this.traces[t5],r4=this.sampledPoints[t5],a2=this.traceBounds[t5],c3=0;for(let e5=0;e5<this.traces.length;e5++){if(e5===t5)continue;let o5=this.traces[e5];if(i3.networkId&&o5.networkId&&i3.networkId===o5.networkId)continue;let h2=this.traceBounds[e5];if(a2.maxX+n3<h2.minX||h2.maxX+n3<a2.minX||a2.maxY+n3<h2.minY||h2.maxY+n3<a2.minY)continue;let d3=this.sampledPoints[e5];for(let t7=0;t7<5;t7++){let e6=r4[2*t7],o6=r4[2*t7+1],i4=r4[2*(t7+1)],a3=r4[2*(t7+1)+1];for(let t8=0;t8<5;t8++){let r6=ma2(e6,o6,i4,a3,d3[2*t8],d3[2*t8+1],d3[2*(t8+1)],d3[2*(t8+1)+1]);r6<s3&&(c3+=(n3-Math.sqrt(r6))**2,r6<1e-18&&(c3+=20*s3))}}}for(let t7=0;t7<this.numObstacleSegments;t7++){if(i3.networkId&&this.obstacleNetworkIds[t7]&&i3.networkId===this.obstacleNetworkIds[t7])continue;let n4=4*t7,s4=this.obstacleSegments[n4],h2=this.obstacleSegments[n4+1],d3=this.obstacleSegments[n4+2],l2=this.obstacleSegments[n4+3],u4=Math.min(s4,d3),p2=Math.max(s4,d3),m3=Math.min(h2,l2),f2=Math.max(h2,l2);if(!(a2.maxX+e4<u4||p2+e4<a2.minX||a2.maxY+e4<m3||f2+e4<a2.minY))for(let t8=0;t8<5;t8++){let n5=ma2(r4[2*t8],r4[2*t8+1],r4[2*(t8+1)],r4[2*(t8+1)+1],s4,h2,d3,l2);n5<o4&&(c3+=(e4-Math.sqrt(n5))**2,n5<1e-18&&(c3+=20*o4))}}return c3}tracesIntersect(t5,e4){let n3=this.traces[t5],s3=this.traces[e4],o4=15,i3=new Float64Array(32),r4=new Float64Array(32);la2(n3.waypointPair.start.x,n3.waypointPair.start.y,n3.ctrl1.x,n3.ctrl1.y,n3.ctrl2.x,n3.ctrl2.y,n3.waypointPair.end.x,n3.waypointPair.end.y,i3,o4),la2(s3.waypointPair.start.x,s3.waypointPair.start.y,s3.ctrl1.x,s3.ctrl1.y,s3.ctrl2.x,s3.ctrl2.y,s3.waypointPair.end.x,s3.waypointPair.end.y,r4,o4);for(let t7=0;t7<o4;t7++){let e5=i3[2*t7],n4=i3[2*t7+1],s4=i3[2*(t7+1)],a2=i3[2*(t7+1)+1];for(let t8=0;t8<o4;t8++)if(fa2(e5,n4,s4,a2,r4[2*t8],r4[2*t8+1],r4[2*(t8+1)],r4[2*(t8+1)+1]))return!0}return!1}findIntersectingPairs(){let t5=[];for(let e4=0;e4<this.traces.length;e4++)for(let n3=e4+1;n3<this.traces.length;n3++){let s3=this.traces[e4],o4=this.traces[n3];if(s3.networkId&&o4.networkId&&s3.networkId===o4.networkId)continue;let i3=this.traceBounds[e4],r4=this.traceBounds[n3];i3.maxX<r4.minX||r4.maxX<i3.minX||i3.maxY<r4.minY||r4.maxY<i3.minY||this.tracesIntersect(e4,n3)&&t5.push([e4,n3])}return t5}resolveIntersections(){let{bounds:t5,preferredTraceToTraceSpacing:e4}=this.problem,{minX:n3,maxX:s3,minY:o4,maxY:i3}=t5,r4=Math.min(s3-n3,i3-o4),a2=.02*r4,c3=1.5*r4,h2=this.findIntersectingPairs();if(h2.length===0)return 0;let d3=0;for(let[t7,n4]of h2){let s4=this.traces[t7],o5=this.traces[n4];if(!this.tracesIntersect(t7,n4))continue;let i4,r6;s4.containedBy.includes(n4)?(i4=n4,r6=t7):o5.containedBy.includes(t7)||(s4.d1+s4.d2)/2<(o5.d1+o5.d2)/2?(i4=t7,r6=n4):(i4=n4,r6=t7);let h3=this.traces[i4],l2=this.traces[r6],u4=h3.d1,p2=h3.d2,m3=l2.d1,f2=l2.d2,g4=2*e4,y3=[{innerMult:1,outerMult:0},{innerMult:0,outerMult:1},{innerMult:.5,outerMult:.5},{innerMult:2,outerMult:0},{innerMult:1,outerMult:1},{innerMult:3,outerMult:0},{innerMult:2,outerMult:1},{innerMult:4,outerMult:0}],x3=this.computeTotalCost(),v4=null;for(let t8 of y3)if(h3.d1=u4,h3.d2=p2,l2.d1=m3,l2.d2=f2,l2.d1=Math.min(c3,m3+g4*t8.innerMult),l2.d2=Math.min(c3,f2+g4*t8.innerMult),h3.d1=Math.max(a2,u4-g4*t8.outerMult),h3.d2=Math.max(a2,p2-g4*t8.outerMult),this.updateControlPointsFromDistances(r6),this.updateControlPointsFromDistances(i4),this.updateSingleTraceSample(r6),this.updateSingleTraceSample(i4),!this.tracesIntersect(i4,r6)){let e5=this.computeTotalCost();(v4===null||e5<x3)&&(x3=e5,v4=t8)}v4?(l2.d1=Math.min(c3,m3+g4*v4.innerMult),l2.d2=Math.min(c3,f2+g4*v4.innerMult),h3.d1=Math.max(a2,u4-g4*v4.outerMult),h3.d2=Math.max(a2,p2-g4*v4.outerMult),this.updateControlPointsFromDistances(r6),this.updateControlPointsFromDistances(i4),this.updateSingleTraceSample(r6),this.updateSingleTraceSample(i4),d3++):(h3.d1=u4,h3.d2=p2,l2.d1=m3,l2.d2=f2,this.updateControlPointsFromDistances(i4),this.updateControlPointsFromDistances(r6),this.updateSingleTraceSample(i4),this.updateSingleTraceSample(r6))}return d3}optimizeStep(){let{bounds:t5}=this.problem,{minX:e4,maxX:n3,minY:s3,maxY:o4}=t5,i3=Math.min(n3-e4,o4-s3),r4=this.effectiveTraceToTraceSpacing,a2=4*(1-this.optimizationStep/this.maxOptimizationSteps)+.5,c3=.02*i3,h2=1.5*i3,d3=[];for(let t7=0;t7<this.traces.length;t7++)d3.push({idx:t7,cost:this.computeCostForTrace(t7)});d3.sort((t7,e5)=>e5.cost-t7.cost);for(let{idx:t7,cost:e5}of d3){if(e5===0)continue;let n4=this.traces[t7],s4=e5>100?2:1,o5=[a2*s4,1.5*a2*s4,.5*a2];for(let s5 of o5){let o6=e5>100?[s5,-s5,2*s5,2*-s5,3*s5,3*-s5,2*r4,2*-r4]:[s5,-s5,2*s5,2*-s5],i4=this.computeCostForTrace(t7),a3=n4.d1,d4=n4.d2,l2=n4.d1,u4=n4.d2;for(let e6 of o6){n4.d1=Math.max(c3,Math.min(h2,l2+e6)),this.updateControlPointsFromDistances(t7),this.updateSingleTraceSample(t7);let s6=this.computeCostForTrace(t7);s6<i4&&(i4=s6,a3=n4.d1,d4=u4),n4.d1=l2,this.updateControlPointsFromDistances(t7),n4.d2=Math.max(c3,Math.min(h2,u4+e6)),this.updateControlPointsFromDistances(t7),this.updateSingleTraceSample(t7);let o7=this.computeCostForTrace(t7);o7<i4&&(i4=o7,a3=l2,d4=n4.d2),n4.d2=u4,this.updateControlPointsFromDistances(t7),n4.d1=Math.max(c3,Math.min(h2,l2+e6)),n4.d2=Math.max(c3,Math.min(h2,u4+e6)),this.updateControlPointsFromDistances(t7),this.updateSingleTraceSample(t7);let r6=this.computeCostForTrace(t7);r6<i4&&(i4=r6,a3=n4.d1,d4=n4.d2),n4.d1=l2,n4.d2=u4,this.updateControlPointsFromDistances(t7),n4.d1=Math.max(c3,Math.min(h2,l2+e6)),n4.d2=Math.max(c3,Math.min(h2,u4-e6)),this.updateControlPointsFromDistances(t7),this.updateSingleTraceSample(t7);let p2=this.computeCostForTrace(t7);p2<i4&&(i4=p2,a3=n4.d1,d4=n4.d2),n4.d1=l2,n4.d2=u4,this.updateControlPointsFromDistances(t7)}if(n4.d1=a3,n4.d2=d4,this.updateControlPointsFromDistances(t7),this.updateSingleTraceSample(t7),i4<.9*e5)break}}this.optimizationStep%10==0&&this.updateCollisionPairs()}buildOutputTraces(){this.outputTraces=this.traces.map(t5=>({waypointPair:t5.waypointPair,points:ua2(t5.waypointPair.start,t5.ctrl1,t5.ctrl2,t5.waypointPair.end,20),networkId:t5.networkId}))}_step(){if(this.traces.length===0&&(this.effectiveTraceToTraceSpacing=3*this.problem.preferredTraceToTraceSpacing,this.initializeTraces(),this.lastCost=this.computeTotalCost(),this.stagnantSteps=0),this.optimizationStep<this.maxOptimizationSteps){let e4=3+-2*(this.optimizationStep/this.maxOptimizationSteps);this.effectiveTraceToTraceSpacing=this.problem.preferredTraceToTraceSpacing*e4,this.optimizeStep(),this.optimizationStep++,this.optimizationStep%10==0&&this.resolveIntersections()>0&&this.updateCollisionPairs();let n3=this.computeTotalCost();n3===0?this.optimizationStep=this.maxOptimizationSteps:n3>=.99*this.lastCost?(this.stagnantSteps++,this.stagnantSteps>10&&(this.resolveIntersections()>0?(this.updateCollisionPairs(),this.stagnantSteps=0):this.stagnantSteps>15&&(this.optimizationStep=this.maxOptimizationSteps))):this.stagnantSteps=0,this.lastCost=n3}this.optimizationStep>=this.maxOptimizationSteps&&(this.resolveIntersections(),this.buildOutputTraces(),this.solved=!0)}visualize(){return this.traces.length>0&&this.buildOutputTraces(),((t5,e4=[])=>{let n3={arrows:[],circles:[],lines:[],rects:[],coordinateSystem:"cartesian",points:[],texts:[],title:"Curvy Trace Problem"};n3.lines.push({points:[{x:t5.bounds.minX,y:t5.bounds.minY},{x:t5.bounds.maxX,y:t5.bounds.minY},{x:t5.bounds.maxX,y:t5.bounds.maxY},{x:t5.bounds.minX,y:t5.bounds.maxY},{x:t5.bounds.minX,y:t5.bounds.minY}],strokeColor:"rgba(0, 0, 0, 0.1)"});for(let e5 of t5.waypointPairs)n3.points.push({...e5.start,label:`start ${e5.networkId??""}`,color:aa2(e5.networkId)}),n3.points.push({...e5.end,label:`end ${e5.networkId??""}`,color:aa2(e5.networkId)});for(let e5 of t5.obstacles)n3.rects.push({center:e5.center,width:e5.maxX-e5.minX,height:e5.maxY-e5.minY,fill:"rgba(128, 128, 128, 0.3)",stroke:"rgba(128, 128, 128, 0.8)",label:`netId: ${e5.networkId}`});for(let t7 of e4)n3.lines.push({points:t7.points,strokeColor:aa2(t7.networkId)});return n3})(this.problem,this.outputTraces)}},va2=class extends y{constructor(t5){super();__publicField(this,"constructorParams");__publicField(this,"nodeWithPortPoints");__publicField(this,"colorMap");__publicField(this,"traceWidth");__publicField(this,"hyperParameters");__publicField(this,"jumperGraphSolver",null);__publicField(this,"xyConnections",[]);__publicField(this,"graphBounds",null);__publicField(this,"jumperLocations",[]);__publicField(this,"solvedRoutes",[]);__publicField(this,"jumpers",[]);__publicField(this,"phase","jumperGraph");__publicField(this,"curvySolvers",[]);__publicField(this,"currentCurvySolverIndex",0);__publicField(this,"routeInfos",[]);__publicField(this,"regionCurvedPaths",new Map);this.constructorParams=t5,this.nodeWithPortPoints=t5.nodeWithPortPoints,this.colorMap=t5.colorMap??{},this.traceWidth=t5.traceWidth??.15,this.hyperParameters=t5.hyperParameters??{},this.MAX_ITERATIONS=1e6,Object.keys(this.colorMap).length===0&&(this.colorMap=this._buildColorMap())}getConstructorParams(){return this.constructorParams}_buildColorMap(){let t5=["#e6194b","#3cb44b","#ffe119","#4363d8","#f58231","#911eb4","#46f0f0","#f032e6","#bcf60c","#fabebe"],e4={},n3=new Set;for(let t7 of this.nodeWithPortPoints.portPoints)n3.add(t7.connectionName);let s3=0;for(let o4 of Array.from(n3))e4[o4]=t5[s3%t5.length],s3++;return e4}_getPatternConfig(){return{cols:this.hyperParameters.COLS??1,rows:this.hyperParameters.ROWS??1}}_initializeGraph(){let t5=this.nodeWithPortPoints,e4=this._getPatternConfig(),n3=this.hyperParameters.ORIENTATION??"vertical",s3={minX:t5.center.x-t5.width/2,maxX:t5.center.x+t5.width/2,minY:t5.center.y-t5.height/2,maxY:t5.center.y+t5.height/2};this.graphBounds=s3;let o4=Nr2({cols:e4.cols,rows:e4.rows,marginX:Math.max(1.2,.3*e4.cols),marginY:Math.max(1.2,.3*e4.rows),outerPaddingX:.4,outerPaddingY:.4,parallelTracesUnderJumperCount:2,innerColChannelPointCount:3,innerRowChannelPointCount:3,outerChannelXPointCount:3,outerChannelYPointCount:3,regionsBetweenPads:!0,orientation:n3,bounds:s3});if(o4.regions.length>0){let t7=1/0,e5=-1/0,n4=1/0,i4=-1/0;for(let s4 of o4.regions){if(!s4.d?.isPad)continue;let o5=s4.d?.bounds;o5&&(t7=Math.min(t7,o5.minX),e5=Math.max(e5,o5.maxX),n4=Math.min(n4,o5.minY),i4=Math.max(i4,o5.maxY))}let r6=1;if(t7-r6<s3.minX||e5+r6>s3.maxX||n4-r6<s3.minY||i4+r6>s3.maxY)return this.error=`baseGraph bounds (${t7.toFixed(2)}, ${n4.toFixed(2)}, ${e5.toFixed(2)}, ${i4.toFixed(2)}) exceed node bounds (${s3.minX.toFixed(2)}, ${s3.minY.toFixed(2)}, ${s3.maxX.toFixed(2)}, ${s3.maxY.toFixed(2)})`,this.failed=!0,!1}this.jumperLocations=o4.jumperLocations?.map(t7=>({center:t7.center,orientation:t7.orientation,padRegions:t7.padRegions}))??[];let i3=new Map;for(let e5 of t5.portPoints){let t7=i3.get(e5.connectionName);t7?t7.points.push(e5):i3.set(e5.connectionName,{points:[e5],rootConnectionName:e5.rootConnectionName})}this.xyConnections=[];for(let[t7,e5]of Array.from(i3.entries()))e5.points.length<2||this.xyConnections.push({start:{x:e5.points[0].x,y:e5.points[0].y},end:{x:e5.points[1].x,y:e5.points[1].y},connectionId:t7});if(this.xyConnections.length===0)return this.solved=!0,!0;let r4=((t7,e5)=>{let n4=[...t7.regions],s4=[...t7.ports],o5=[],i4=fr2(t7.regions);for(let r6 of e5){let{start:e6,end:a2,connectionId:c3}=r6,h2=Cr2(`conn:${c3}:start`,e6.x,e6.y);n4.push(h2);let d3=Cr2(`conn:${c3}:end`,a2.x,a2.y);n4.push(d3);let l2=_r2(e6.x,e6.y,t7.regions,i4);if(l2){let t8=Ir2(`conn:${c3}:start-port`,h2,l2.region,l2.portPosition);s4.push(t8)}let u4=_r2(a2.x,a2.y,t7.regions,i4);if(u4){let t8=Ir2(`conn:${c3}:end-port`,d3,u4.region,u4.portPosition);s4.push(t8)}let p2={connectionId:c3,mutuallyConnectedNetworkId:c3,startRegion:h2,endRegion:d3};o5.push(p2)}return{regions:n4,ports:s4,connections:o5}})(o4,this.xyConnections);return this.jumperGraphSolver=new $r2({inputGraph:{regions:r4.regions,ports:r4.ports},inputConnections:r4.connections}),this.jumperGraphSolver.MAX_ITERATIONS*=3,!0}_step(){switch(this.phase){case"jumperGraph":this._stepJumperGraph();break;case"curvyTrace":this._stepCurvyTrace();break;case"done":this.solved=!0}}_stepJumperGraph(){if(!this.jumperGraphSolver){if(this._initializeGraph(),this.solved)return;if(!this.jumperGraphSolver)return void(this.failed=!0)}this.activeSubSolver=this.jumperGraphSolver,this.jumperGraphSolver.step(),this.jumperGraphSolver.solved?(this._initializeCurvyTraceSolvers(),this.curvySolvers.length>0?this.phase="curvyTrace":(this._finalizeCurvyTraceResults(),this.phase="done",this.solved=!0)):this.jumperGraphSolver.failed&&(this.error=this.jumperGraphSolver.error,this.failed=!0)}_stepCurvyTrace(){if(this.currentCurvySolverIndex>=this.curvySolvers.length)return this._finalizeCurvyTraceResults(),this.phase="done",void(this.solved=!0);let t5=this.curvySolvers[this.currentCurvySolverIndex],e4=t5.solver;if(this.activeSubSolver=e4,e4.step(),e4.solved){let n3=t5.regionId;this.regionCurvedPaths.has(n3)||this.regionCurvedPaths.set(n3,new Map);for(let t7 of e4.outputTraces){let e5=t7.networkId??"",s3=t7.points.map(t8=>({x:t8.x,y:t8.y})),o4={path:s3,start:s3[0]??{x:0,y:0},end:s3[s3.length-1]??{x:0,y:0}};this.regionCurvedPaths.get(n3).has(e5)||this.regionCurvedPaths.get(n3).set(e5,[]),this.regionCurvedPaths.get(n3).get(e5).push(o4)}this.currentCurvySolverIndex++}else e4.failed&&this.currentCurvySolverIndex++}_initializeCurvyTraceSolvers(){if(!this.jumperGraphSolver)return;let t5=new Set,e4=[];for(let t7 of this.jumperLocations)for(let n4 of t7.padRegions){let t8=n4.d.bounds,s3=n4.d.center;e4.push({minX:t8.minX,minY:t8.minY,maxX:t8.maxX,maxY:t8.maxY,center:{x:s3.x,y:s3.y},networkIds:[]})}let n3=new Map;for(let e5=0;e5<this.jumperGraphSolver.solvedRoutes.length;e5++){let s3=this.jumperGraphSolver.solvedRoutes[e5],o4=s3.connection.connectionId,i3=this.nodeWithPortPoints.portPoints.find(t7=>t7.connectionName===o4)?.rootConnectionName,r4=[],a2=[],c3=null,h2=null;for(let d3=0;d3<s3.path.length;d3++){let l2=s3.path[d3],u4=l2.port,p2=l2.lastRegion,m3=u4.region1,f2=u4.region2,g4;if(p2)m3&&m3.regionId!==p2.regionId?g4=m3:f2&&f2.regionId!==p2.regionId&&(g4=f2);else{let t7=s3.path[d3+1],e6=t7?.lastRegion;if(e6&&(m3&&m3.regionId===e6.regionId?g4=m3:f2&&f2.regionId===e6.regionId&&(g4=f2)),!g4){let t8=t10=>t10?.regionId?.startsWith("conn:");g4=!m3||t8(m3)||m3.d?.isPad||m3.d?.isThroughJumper?!f2||t8(f2)||f2.d?.isPad||f2.d?.isThroughJumper?!m3||m3.d?.isPad||m3.d?.isThroughJumper?(!f2||f2.d?.isPad||f2.d?.isThroughJumper)&&m3||f2:m3:f2:m3}}if(g4&&(!c3||g4.regionId!==c3.regionId)){if(c3&&h2){a2.push({regionId:c3.regionId,region:c3,entryPort:h2,exitPort:u4});let t7=c3.regionId;n3.has(t7)||n3.set(t7,[]),n3.get(t7).push({regionId:c3.regionId,region:c3,routeIndex:e5,connectionName:o4,rootConnectionName:i3,entryPort:h2,exitPort:u4})}c3=g4,h2=u4}if(p2?.d?.isThroughJumper&&!t5.has(p2.regionId)){t5.add(p2.regionId);let e6=p2.d.bounds,n4=p2.d.center;e6.maxX-e6.minX>e6.maxY-e6.minY?r4.push({route_type:"jumper",start:{x:e6.minX,y:n4.y},end:{x:e6.maxX,y:n4.y},footprint:"1206x4_pair"}):r4.push({route_type:"jumper",start:{x:n4.x,y:e6.minY},end:{x:n4.x,y:e6.maxY},footprint:"1206x4_pair"})}}if(c3&&h2){let t7=s3.path[s3.path.length-1];a2.push({regionId:c3.regionId,region:c3,entryPort:h2,exitPort:t7?.port||null})}this.routeInfos.push({connectionId:o4,rootConnectionName:i3,jumpers:r4,traversals:a2})}for(let t7=0;t7<this.routeInfos.length;t7++){let n4=this.routeInfos[t7],s3=n4.rootConnectionName??n4.connectionId;for(let t8 of n4.jumpers){let n5=[t8.start,t8.end];for(let t10 of n5)for(let n6 of e4){let e5=Math.abs(n6.center.x-t10.x),o4=Math.abs(n6.center.y-t10.y);e5<.1&&o4<.1&&(n6.networkIds.includes(s3)||n6.networkIds.push(s3))}}}for(let[t7,s3]of n3){if(s3.length===0)continue;let n4=s3[0].region;if(n4.d.isPad||n4.d.isThroughJumper)continue;let o4=n4.d.bounds,i3=[];for(let t8 of s3)i3.push({start:{x:t8.entryPort.d.x,y:t8.entryPort.d.y},end:{x:t8.exitPort.d.x,y:t8.exitPort.d.y},networkId:t8.rootConnectionName??t8.connectionName});let r4=.01,a2=e4.filter(t8=>t8.minX<=o4.maxX+r4&&t8.maxX>=o4.minX-r4&&t8.minY<=o4.maxY+r4&&t8.maxY>=o4.minY-r4).map(t8=>{let e5=s3.map(t10=>t10.rootConnectionName??t10.connectionName),n5=t8.networkIds.find(t10=>e5.includes(t10));return{minX:t8.minX,minY:t8.minY,maxX:t8.maxX,maxY:t8.maxY,center:t8.center,networkId:n5}}),c3={bounds:o4,waypointPairs:i3,obstacles:a2,preferredTraceToTraceSpacing:2*this.traceWidth,preferredObstacleToTraceSpacing:2*this.traceWidth},h2=new xa2(c3);this.curvySolvers.push({solver:h2,regionId:t7,traversals:s3.map(t8=>({routeIndex:t8.routeIndex,connectionName:t8.connectionName,rootConnectionName:t8.rootConnectionName}))})}}_finalizeCurvyTraceResults(){let t5=(t7,e4)=>Math.sqrt((t7.x-e4.x)**2+(t7.y-e4.y)**2);for(let e4=0;e4<this.routeInfos.length;e4++){let n3=this.routeInfos[e4],s3=[];for(let e5 of n3.traversals){let o4=e5.regionId,i3=n3.rootConnectionName??n3.connectionId,r4=this.regionCurvedPaths.get(o4)?.get(i3),a2=null;if(r4&&r4.length>0){let n4={x:e5.entryPort.d.x,y:e5.entryPort.d.y},s4=e5.exitPort?{x:e5.exitPort.d.x,y:e5.exitPort.d.y}:null,o5=null,i4=1/0;for(let e6 of r4){let r6=t5(e6.start,n4)+(s4?t5(e6.end,s4):0);r6<i4&&(i4=r6,o5=e6)}o5&&i4<.5&&(a2=o5.path)}if(a2&&a2.length>0)for(let t7=s3.length>0?1:0;t7<a2.length;t7++)s3.push({x:a2[t7].x,y:a2[t7].y,z:0});else s3.length===0&&s3.push({x:e5.entryPort.d.x,y:e5.entryPort.d.y,z:0}),e5.exitPort&&s3.push({x:e5.exitPort.d.x,y:e5.exitPort.d.y,z:0})}this.solvedRoutes.push({connectionName:n3.connectionId,rootConnectionName:n3.rootConnectionName,traceThickness:this.traceWidth,route:s3,jumpers:n3.jumpers})}}getOutput(){return this.solvedRoutes}getOutputJumpers(){if(this.jumpers.length>0)return this.jumpers;let t5=new Map;for(let e5 of this.solvedRoutes)for(let n3 of e5.jumpers){let s3=[n3.start,n3.end];for(let n4 of s3){let s4=`${n4.x.toFixed(3)},${n4.y.toFixed(3)}`,o4=t5.get(s4)??[];e5.rootConnectionName&&!o4.includes(e5.rootConnectionName)&&o4.push(e5.rootConnectionName),o4.includes(e5.connectionName)||o4.push(e5.connectionName),t5.set(s4,o4)}}let e4=Ze2["1206x4_pair"];for(let n3 of this.jumperLocations){let s3=n3.orientation==="horizontal",o4=n3.padRegions.map(e5=>{let n4=e5.d.bounds,s4=e5.d.center,o5=n4.maxX-n4.minX,i4=n4.maxY-n4.minY,r4=`${s4.x.toFixed(3)},${s4.y.toFixed(3)}`;return{type:"rect",center:s4,width:o5,height:i4,layers:["top"],connectedTo:[...t5.get(r4)??[]]}}),i3={jumper_footprint:"1206x4",center:n3.center,orientation:n3.orientation,width:s3?e4.length:e4.width,height:s3?e4.width:e4.length,pads:o4};this.jumpers.push(i3)}return this.jumpers=this.jumpers.filter(t7=>t7.pads.some(t8=>t8.connectedTo.length>0)),this.jumpers}visualize(){if(this.jumperGraphSolver&&!this.solved)return this.jumperGraphSolver.visualize();let t5={lines:[],points:[],rects:[],circles:[]},e4=this.nodeWithPortPoints,n3={minX:e4.center.x-e4.width/2,maxX:e4.center.x+e4.width/2,minY:e4.center.y-e4.height/2,maxY:e4.center.y+e4.height/2};t5.lines.push({points:[{x:n3.minX,y:n3.minY},{x:n3.maxX,y:n3.minY},{x:n3.maxX,y:n3.maxY},{x:n3.minX,y:n3.maxY},{x:n3.minX,y:n3.minY}],strokeColor:"rgba(255, 0, 0, 0.25)",strokeDash:"4 4",layer:"border"});for(let n4 of e4.portPoints)t5.points.push({x:n4.x,y:n4.y,label:n4.connectionName,color:this.colorMap[n4.connectionName]??"blue"});for(let e5 of this.solvedRoutes){let n4=this.colorMap[e5.connectionName]??"blue";for(let s3=0;s3<e5.route.length-1;s3++){let o4=e5.route[s3],i3=e5.route[s3+1];t5.lines.push({points:[o4,i3],strokeColor:it2(n4,.2),strokeWidth:e5.traceThickness,layer:"route-layer-0"})}for(let s3 of e5.jumpers)this._drawJumperPads(t5,s3,it2(n4,.5))}return t5}_drawJumperPads(t5,e4,n3){let s3=Ze2[e4.footprint],o4=e4.end.x-e4.start.x,i3=e4.end.y-e4.start.y,r4=Math.abs(o4)>Math.abs(i3),a2=r4?s3.padLength:s3.padWidth,c3=r4?s3.padWidth:s3.padLength;t5.rects.push({center:{x:e4.start.x,y:e4.start.y},width:a2,height:c3,fill:n3,stroke:"rgba(0, 0, 0, 0.5)",layer:"jumper"}),t5.rects.push({center:{x:e4.end.x,y:e4.end.y},width:a2,height:c3,fill:n3,stroke:"rgba(0, 0, 0, 0.5)",layer:"jumper"}),t5.lines.push({points:[e4.start,e4.end],strokeColor:"rgba(100, 100, 100, 0.8)",strokeWidth:.3*s3.padWidth,layer:"jumper-body"})}},Sa2=class extends Zt2{constructor(t5){super();__publicField(this,"constructorParams");__publicField(this,"nodeWithPortPoints");__publicField(this,"colorMap");__publicField(this,"traceWidth");__publicField(this,"connMap");__publicField(this,"baseHyperParameters");__publicField(this,"solvedRoutes",[]);__publicField(this,"jumpers",[]);this.constructorParams=t5,this.nodeWithPortPoints=t5.nodeWithPortPoints,this.colorMap=t5.colorMap??{},this.traceWidth=t5.traceWidth??.15,this.connMap=t5.connMap,this.baseHyperParameters=t5.hyperParameters??{},this.MAX_ITERATIONS=1e6,this.GREEDY_MULTIPLIER=1,this.MIN_SUBSTEPS=1e3}getConstructorParams(){return this.constructorParams}getHyperParameterDefs(){return[{name:"cols",possibleValues:[{COLS:1},{COLS:2},{COLS:3},{COLS:4},{COLS:6},{COLS:8},{COLS:10}]},{name:"rows",possibleValues:[{ROWS:1},{ROWS:2},{ROWS:3},{ROWS:4},{ROWS:8}]},{name:"orientation",possibleValues:[{ORIENTATION:"vertical"},{ORIENTATION:"horizontal"}]}]}getCombinationDefs(){return[["cols","rows","orientation"]]}generateSolver(t5){return new va2({nodeWithPortPoints:this.nodeWithPortPoints,colorMap:this.colorMap,traceWidth:this.traceWidth,hyperParameters:{COLS:t5.COLS,ROWS:t5.ROWS,ORIENTATION:t5.ORIENTATION}})}computeG(t5){let e4=t5.hyperParameters.COLS*t5.hyperParameters.ROWS;return t5.iterations/1e4+.25*e4}computeH(t5){return 1-(t5.progress||0)}onSolve(t5){this.solvedRoutes=t5.solver.solvedRoutes,this.jumpers=t5.solver.getOutputJumpers()}getOutput(){return this.solvedRoutes}getOutputJumpers(){return this.jumpers}visualize(){return this.winningSolver?this.winningSolver.visualize():super.visualize()}},Pa2=class extends y{constructor(t5){super();__publicField(this,"nodeWithPortPoints");__publicField(this,"colorMap");__publicField(this,"traceWidth");__publicField(this,"viaDiameter");__publicField(this,"adjacentObstacles");__publicField(this,"routes",[]);__publicField(this,"curvyTraceSolver");__publicField(this,"phase","initializing");this.nodeWithPortPoints=t5.nodeWithPortPoints,this.colorMap=t5.colorMap??{},this.traceWidth=t5.traceWidth??.15,this.viaDiameter=t5.viaDiameter??.6,this.adjacentObstacles=t5.adjacentObstacles??[],this.MAX_ITERATIONS=1e3}_step(){switch(this.phase){case"initializing":this._initializeCurvySolver();break;case"solving":this._stepCurvySolver();break;case"done":this.solved=!0}}_initializeCurvySolver(){let t5=this.nodeWithPortPoints,e4={minX:t5.center.x-t5.width/2,minY:t5.center.y-t5.height/2,maxX:t5.center.x+t5.width/2,maxY:t5.center.y+t5.height/2},n3=new Map;for(let e5 of t5.portPoints)n3.has(e5.connectionName)||n3.set(e5.connectionName,[]),n3.get(e5.connectionName).push(e5);let s3=[];for(let[t7,e5]of n3){if(e5.length<2)continue;let n4=e5[0],o5=e5[e5.length-1];s3.push({start:{x:n4.x,y:n4.y},end:{x:o5.x,y:o5.y},networkId:t7})}if(s3.length===0)return void(this.phase="done");let o4={bounds:e4,waypointPairs:s3,obstacles:this.adjacentObstacles.map(t7=>({minX:t7.minX,minY:t7.minY,maxX:t7.maxX,maxY:t7.maxY,center:{x:(t7.minX+t7.maxX)/2,y:(t7.minY+t7.maxY)/2},networkId:t7.networkId})),preferredTraceToTraceSpacing:2*this.traceWidth,preferredObstacleToTraceSpacing:2*this.traceWidth};this.curvyTraceSolver=new xa2(o4),this.phase="solving"}_stepCurvySolver(){this.curvyTraceSolver?(this.activeSubSolver=this.curvyTraceSolver,this.curvyTraceSolver.step(),this.curvyTraceSolver.solved?(this._convertOutputTraces(),this.phase="done"):this.curvyTraceSolver.failed&&(this.error=this.curvyTraceSolver.error,this.failed=!0)):this.phase="done"}_convertOutputTraces(){if(!this.curvyTraceSolver)return;let t5=this.nodeWithPortPoints,e4=new Map;for(let n3 of t5.portPoints){let t7=n3.connectionName;e4.has(t7)||e4.set(t7,{connectionName:n3.connectionName,rootConnectionName:n3.rootConnectionName,z:n3.z})}for(let t7 of this.curvyTraceSolver.outputTraces){let n3=t7.networkId??"",s3=e4.get(n3);if(!s3)continue;let o4={connectionName:s3.connectionName,rootConnectionName:s3.rootConnectionName,traceThickness:this.traceWidth,viaDiameter:this.viaDiameter,route:t7.points.map(t8=>({x:t8.x,y:t8.y,z:s3.z})),vias:[]};this.routes.push(o4)}}getConstructorParams(){return{nodeWithPortPoints:this.nodeWithPortPoints,colorMap:this.colorMap,traceWidth:this.traceWidth,viaDiameter:this.viaDiameter,adjacentObstacles:this.adjacentObstacles}}visualize(){let t5={lines:[],points:[],rects:[],circles:[]},e4=this.nodeWithPortPoints;t5.rects.push({center:e4.center,width:e4.width,height:e4.height,fill:"rgba(0, 200, 0, 0.1)",stroke:"rgba(0, 200, 0, 0.5)",label:e4.capacityMeshNodeId});for(let e5 of this.adjacentObstacles)t5.rects.push({center:{x:(e5.minX+e5.maxX)/2,y:(e5.minY+e5.maxY)/2},width:e5.maxX-e5.minX,height:e5.maxY-e5.minY,fill:"rgba(255, 0, 0, 0.1)",stroke:"rgba(255, 0, 0, 0.3)",label:`obstacle: ${e5.networkId??""}`});if(this.curvyTraceSolver){let e5=this.curvyTraceSolver.visualize();e5.lines&&t5.lines.push(...e5.lines),e5.points&&t5.points.push(...e5.points),e5.rects&&t5.rects.push(...e5.rects),e5.circles&&t5.circles.push(...e5.circles)}for(let e5 of this.routes){let n3=this.colorMap[e5.connectionName]??"gray";t5.lines.push({points:e5.route.map(t7=>({x:t7.x,y:t7.y})),strokeColor:n3,strokeWidth:this.traceWidth,label:e5.connectionName})}for(let n3 of e4.portPoints){let e5=this.colorMap[n3.connectionName]??"gray";t5.points.push({x:n3.x,y:n3.y,color:e5,label:n3.connectionName})}return t5}};function ba2(t5){return{connectionName:t5.connectionName,rootConnectionName:t5.rootConnectionName,traceThickness:t5.traceThickness,viaDiameter:0,route:t5.route,vias:[],jumpers:t5.jumpers}}var Ma2=class extends y{constructor({nodePortPoints:t5,colorMap:e4,traceWidth:n3=.15,viaDiameter:s3=.6,connMap:o4,hyperParameters:i3,capacityMeshNodes:r4=[],capacityMeshEdges:a2=[]}){super();__publicField(this,"allNodes");__publicField(this,"nodeAnalyses");__publicField(this,"routes");__publicField(this,"colorMap");__publicField(this,"traceWidth");__publicField(this,"viaDiameter");__publicField(this,"connMap");__publicField(this,"hyperParameters");__publicField(this,"capacityMeshNodes");__publicField(this,"capacityMeshEdges");__publicField(this,"capacityMeshNodeMap");__publicField(this,"nodeAdjacencyMap");__publicField(this,"nodesWithoutCrossings");__publicField(this,"nodesWithCrossings");__publicField(this,"curvyIntraNodeSolvers");__publicField(this,"currentCurvySolverIndex");__publicField(this,"jumperSolvers");__publicField(this,"currentJumperSolverIndex");__publicField(this,"phase");__publicField(this,"jumpers",[]);this.allNodes=[...t5],this.colorMap=e4??{},this.routes=[],this.traceWidth=n3,this.viaDiameter=s3,this.connMap=o4,this.hyperParameters=i3,this.capacityMeshNodes=r4,this.capacityMeshEdges=a2,this.capacityMeshNodeMap=new Map(r4.map(t7=>[t7.capacityMeshNodeId,t7])),this.nodeAdjacencyMap=this._buildNodeAdjacencyMap(),this.nodesWithoutCrossings=[],this.nodesWithCrossings=[],this.nodeAnalyses=[],this.curvyIntraNodeSolvers=[],this.currentCurvySolverIndex=0,this.jumperSolvers=[],this.currentJumperSolverIndex=0,this.phase="analyzing",this._analyzeNodes();let c3=1e3*this.nodesWithoutCrossings.length,h2=1e5*this.nodesWithCrossings.length;this.MAX_ITERATIONS=c3+h2+100}_buildNodeAdjacencyMap(){let t5=new Map;for(let e4 of this.capacityMeshEdges){let[n3,s3]=e4.nodeIds;t5.has(n3)||t5.set(n3,new Set),t5.has(s3)||t5.set(s3,new Set),t5.get(n3).add(s3),t5.get(s3).add(n3)}return t5}_analyzeNodes(){for(let t5 of this.allNodes){let e4=Ro2(t5),n3={node:t5,hasCrossings:e4.numSameLayerCrossings>0,numSameLayerCrossings:e4.numSameLayerCrossings};this.nodeAnalyses.push(n3),e4.numSameLayerCrossings>0?this.nodesWithCrossings.push(t5):this.nodesWithoutCrossings.push(t5)}this.nodesWithoutCrossings.length>0?(this.phase="curvy",this._initializeCurvySolvers()):this.nodesWithCrossings.length>0?(this.phase="jumpers",this._initializeJumperSolvers()):this.phase="done"}_step(){switch(this.phase){case"analyzing":this.nodesWithoutCrossings.length>0?(this.phase="curvy",this._initializeCurvySolvers()):this.nodesWithCrossings.length>0?(this.phase="jumpers",this._initializeJumperSolvers()):this.phase="done";break;case"curvy":this._stepCurvySolvers();break;case"jumpers":this._stepJumperSolvers();break;case"done":this.solved=!0}}_getAdjacentObstacles(t5){let e4=[],n3=this.nodeAdjacencyMap.get(t5.capacityMeshNodeId);if(!n3||n3.size===0)return e4;let s3=new Map(this.allNodes.map(t7=>[t7.capacityMeshNodeId,t7]));for(let t7 of n3){let n4=this.capacityMeshNodeMap.get(t7);if(!n4||!n4._containsObstacle&&!n4._containsTarget)continue;let o4=n4.center.x-n4.width/2,i3=n4.center.y-n4.height/2,r4=n4.center.x+n4.width/2,a2=n4.center.y+n4.height/2,c3;if(n4._containsTarget)if(n4._targetConnectionName)c3=n4._targetConnectionName;else{let e5=s3.get(t7);e5&&e5.portPoints.length>0&&(c3=e5.portPoints[0].rootConnectionName??e5.portPoints[0].connectionName)}e4.push({minX:o4,minY:i3,maxX:r4,maxY:a2,networkId:c3})}return e4}_initializeCurvySolvers(){for(let t5 of this.nodesWithoutCrossings){let e4=this._getAdjacentObstacles(t5),n3=new Pa2({nodeWithPortPoints:t5,colorMap:this.colorMap,traceWidth:this.traceWidth,viaDiameter:this.viaDiameter,adjacentObstacles:e4});this.curvyIntraNodeSolvers.push(n3)}}_stepCurvySolvers(){if(this.curvyIntraNodeSolvers.length===0)return this.phase=this.nodesWithCrossings.length>0?"jumpers":"done",void(this.phase==="jumpers"&&this._initializeJumperSolvers());let t5=this.curvyIntraNodeSolvers[this.currentCurvySolverIndex];if(this.activeSubSolver=t5,!t5)return this.phase=this.nodesWithCrossings.length>0?"jumpers":"done",void(this.phase==="jumpers"&&this._initializeJumperSolvers());if(t5.step(),t5.solved){this.routes.push(...t5.routes),this.currentCurvySolverIndex++;for(let t7=this.currentCurvySolverIndex;t7<this.curvyIntraNodeSolvers.length;t7++){this.curvyIntraNodeSolvers[t7];let e4=this.nodesWithoutCrossings[t7],n3=this._getAdjacentObstacles(e4),s3=new Pa2({nodeWithPortPoints:e4,colorMap:this.colorMap,traceWidth:this.traceWidth,viaDiameter:this.viaDiameter,adjacentObstacles:n3});this.curvyIntraNodeSolvers[t7]=s3}this.currentCurvySolverIndex>=this.curvyIntraNodeSolvers.length&&(this.phase=this.nodesWithCrossings.length>0?"jumpers":"done",this.phase==="jumpers"&&this._initializeJumperSolvers())}else t5.failed&&(this.error=`CurvyIntraNodeSolver failed for node: ${t5.nodeWithPortPoints.capacityMeshNodeId}: ${t5.error}`,this.failed=!0)}_initializeJumperSolvers(){for(let t5 of this.nodesWithCrossings){let e4=new Sa2({nodeWithPortPoints:t5,colorMap:this.colorMap,traceWidth:this.traceWidth,connMap:this.connMap});this.jumperSolvers.push(e4)}}_stepJumperSolvers(){if(this.jumperSolvers.length===0)return this.phase="done",void(this.solved=!0);let t5=this.jumperSolvers[this.currentJumperSolverIndex];if(this.activeSubSolver=t5,!t5)return this.phase="done",void(this.solved=!0);if(t5.step(),t5.solved){for(let e4 of t5.solvedRoutes)this.routes.push(ba2(e4));this.jumpers.push(...t5.getOutputJumpers()),this.currentJumperSolverIndex++,this.currentJumperSolverIndex>=this.jumperSolvers.length&&(this.phase="done",this.solved=!0)}else t5.failed&&(this.error=`HyperJumperPrepatternSolver2 failed for node: ${t5.nodeWithPortPoints.capacityMeshNodeId}: ${t5.error}`,this.failed=!0)}computeProgress(){let t5=this.allNodes.length;if(t5===0)return 1;let e4=0;e4+=this.currentCurvySolverIndex;let n3=this.curvyIntraNodeSolvers[this.currentCurvySolverIndex];n3&&(e4+=n3.progress),e4+=this.currentJumperSolverIndex;let s3=this.jumperSolvers[this.currentJumperSolverIndex];return s3&&(e4+=s3.progress),e4/t5}getConstructorParams(){return{nodePortPoints:this.allNodes,colorMap:this.colorMap,traceWidth:this.traceWidth,viaDiameter:this.viaDiameter,connMap:this.connMap,hyperParameters:this.hyperParameters,capacityMeshNodes:this.capacityMeshNodes,capacityMeshEdges:this.capacityMeshEdges}}getOutputJumpers(){return this.jumpers}visualize(){let t5={lines:[],points:[],rects:[],circles:[]};if(this.failed&&this.activeSubSolver)return this.activeSubSolver.visualize();if(this.phase==="curvy"&&this.curvyIntraNodeSolvers[this.currentCurvySolverIndex])return this.curvyIntraNodeSolvers[this.currentCurvySolverIndex].visualize();if(this.phase==="jumpers"&&this.jumperSolvers[this.currentJumperSolverIndex])return this.jumperSolvers[this.currentJumperSolverIndex].visualize();for(let e4 of this.routes){let n3=e4.rootConnectionName??e4.connectionName,s3=De2(e4.route,e4.connectionName,this.colorMap[n3]);for(let n4 of s3)t5.lines.push({points:n4.points,label:n4.connectionName,strokeColor:n4.z===0?n4.color:it2(n4.color??"gray",.75),layer:`z${n4.z}`,strokeWidth:e4.traceThickness,strokeDash:n4.z!==0?"10, 5":void 0});for(let s4 of e4.vias)t5.circles.push({center:s4,radius:e4.viaDiameter/2,fill:it2(this.colorMap[n3]??"gray",.5),layer:"via"});if("jumpers"in e4&&e4.jumpers)for(let s4 of e4.jumpers){let e5=this.colorMap[n3]??"gray",o4=s4.footprint??"1206",i3=Ze2[o4],r4=s4.end.x-s4.start.x,a2=s4.end.y-s4.start.y,c3=Math.abs(r4)>Math.abs(a2),h2=c3?i3.padLength:i3.padWidth,d3=c3?i3.padWidth:i3.padLength;t5.rects.push({center:s4.start,width:h2,height:d3,fill:it2(e5,.5),stroke:"rgba(0, 0, 0, 0.5)",layer:"jumper"}),t5.rects.push({center:s4.end,width:h2,height:d3,fill:it2(e5,.5),stroke:"rgba(0, 0, 0, 0.5)",layer:"jumper"}),t5.lines.push({points:[s4.start,s4.end],strokeColor:"rgba(100, 100, 100, 0.8)",strokeWidth:.3*i3.padWidth,layer:"jumper-body"})}}for(let e4 of this.nodeAnalyses){let n3=e4.node;n3.center.x,n3.width,n3.center.x,n3.width,n3.center.y,n3.height,n3.center.y,n3.height,t5.rects.push({center:n3.center,width:n3.width,height:n3.height,fill:e4.hasCrossings?"rgba(255, 200, 0, 0.1)":"rgba(0, 200, 0, 0.1)",stroke:e4.hasCrossings?"rgba(255, 150, 0, 0.5)":"rgba(0, 150, 0, 0.5)",label:[n3.capacityMeshNodeId,e4.hasCrossings?`crossings: ${e4.numSameLayerCrossings}`:"no crossings"].join(`
|
|
577
|
-
`)})}return t5}},Na2=class extends y{constructor(t5){super();__publicField(this,"unsolvedRoutes");__publicField(this,"mergedHdRoutes",[]);__publicField(this,"colorMap",{});__publicField(this,"defaultTraceThickness");__publicField(this,"defaultViaDiameter");this.colorMap=t5.colorMap??{};let e4=t5.hdRoutes[0];this.defaultTraceThickness=e4?.traceThickness??.15,this.defaultViaDiameter=e4?.viaDiameter??t5.defaultViaDiameter??.6;let n3=new Map;for(let e5 of t5.connectionPathResults)n3.set(e5.connection.name,e5);let s3=new Map;for(let e5 of t5.hdRoutes){let t7=s3.get(e5.connectionName);t7?t7.push(e5):s3.set(e5.connectionName,[e5])}this.unsolvedRoutes=[];for(let[e5,o4]of s3.entries()){let s4=t5.connections.find(t7=>t7.name===e5);if(!s4)continue;let i3=n3.get(e5),r4=[];i3?.path&&(r4=i3.path.map(t7=>t7.currentNodeId));let a2={...s4.pointsToConnect[0],z:Xe2(Ue2(s4.pointsToConnect[0]),t5.layerCount)},c3={...s4.pointsToConnect[1],z:Xe2(Ue2(s4.pointsToConnect[1]),t5.layerCount)};this.unsolvedRoutes.push({connectionName:e5,hdRoutes:o4,nodeOrder:r4,start:a2,end:c3})}this.MAX_ITERATIONS=1e5}_step(){let t5=this.unsolvedRoutes.pop();if(!t5)return void(this.solved=!0);let e4=this.stitchOrderedRoutes(t5);this.mergedHdRoutes.push(e4)}stitchOrderedRoutes(t5){let{connectionName:e4,hdRoutes:n3,nodeOrder:s3,start:o4,end:i3}=t5;if(n3.length===0)return{connectionName:e4,traceThickness:this.defaultTraceThickness,viaDiameter:this.defaultViaDiameter,route:[o4,i3],vias:[],jumpers:[]};let r4;r4=s3.length>0?this.orderRoutesByNodePath(n3,s3,o4,e4):this.orderRoutesByProximity(n3,o4);let a2=[],c3=[],h2=[];a2.push({x:o4.x,y:o4.y,z:o4.z});for(let t7=0;t7<r4.length;t7++){let e5=r4[t7],n4=a2[a2.length-1],s4=e5.route[0],o5=e5.route[e5.route.length-1],i4=St2(n4,s4),d4=St2(n4,o5),l2=Math.min(i4,d4);if(t7>0&&l2>1)continue;let u4;u4=i4<=d4?[...e5.route]:[...e5.route].reverse(),u4.length>0&&St2(n4,u4[0])<.001&&(u4=u4.slice(1)),a2.push(...u4),c3.push(...e5.vias),e5.jumpers&&h2.push(...e5.jumpers)}let d3=St2(a2[a2.length-1],i3);return d3>.001&&d3<5&&a2.push({x:i3.x,y:i3.y,z:i3.z}),{connectionName:e4,rootConnectionName:n3[0]?.rootConnectionName,traceThickness:n3[0]?.traceThickness??this.defaultTraceThickness,viaDiameter:n3[0]?.viaDiameter??this.defaultViaDiameter,route:a2,vias:c3,jumpers:h2}}orderRoutesByNodePath(t5,e4,n3,s3){if(t5.length===0)return[];let o4=new Set(t5),i3=null,r4=1/0;for(let t7 of o4){let e5=t7.route[0],s4=t7.route[t7.route.length-1],o5=Math.min(St2(n3,e5),St2(n3,s4));o5<r4&&(r4=o5,i3=t7)}if(!i3)return[];o4.delete(i3);let a2=i3.route[0],c3=i3.route[i3.route.length-1],h2,d3;St2(n3,a2)<=St2(n3,c3)?(h2=a2,d3=c3):(h2=c3,d3=a2);let l2=(t7,e5)=>{let n4=0;for(let s4 of o4){if(s4===e5)continue;let o5=s4.route[0],i4=s4.route[s4.route.length-1];(St2(t7,o5)<10||St2(t7,i4)<10)&&n4++}return n4},u4=[i3],p2=d3;for(;o4.size>0;){let t7=null,e5=1/0,n4=-1;for(let s4 of o4){let o5=s4.route[0],i4=s4.route[s4.route.length-1],r6=St2(p2,o5),a3=St2(p2,i4),c4=Math.min(r6,a3);if(c4>=10)continue;let h3=l2(r6<=a3?i4:o5,s4),d4=h3===0,u5=n4===0,m4=c4-e5,f4=!1;f4=t7===null||!!(!d4&&u5&&m4<5)||!(d4&&!u5&&m4>-5)&&c4<e5,f4&&(e5=c4,t7=s4,n4=h3)}if(!t7)break;{u4.push(t7),o4.delete(t7);let e6=t7.route[0],n5=t7.route[t7.route.length-1];p2=St2(p2,e6)<=St2(p2,n5)?n5:e6}}let m3=[];for(p2=h2;o4.size>0;){let t7=null,e5=1/0,s4=-1,i4=St2(p2,n3);for(let r6 of o4){let o5=r6.route[0],a3=r6.route[r6.route.length-1],c4=St2(p2,o5),h3=St2(p2,a3),d4=Math.min(c4,h3);if(d4>=10)continue;let u5=c4<=h3?a3:o5;if(St2(u5,n3)>i4+2)continue;let m4=l2(u5,r6),f4=m4===0,g4=s4===0,y3=d4-e5,x3=!1;x3=t7===null||!!(!f4&&g4&&y3<5)||!(f4&&!g4&&y3>-5)&&d4<e5,x3&&(e5=d4,t7=r6,s4=m4)}if(!t7)break;{m3.unshift(t7),o4.delete(t7);let e6=t7.route[0],n4=t7.route[t7.route.length-1];p2=St2(p2,e6)<=St2(p2,n4)?n4:e6}}let f2=[...m3,...u4];if(o4.size>0){let e5=[...o4].map(t7=>{let e6=t7.route[0],n4=t7.route[t7.route.length-1];return`start=(${e6.x.toFixed(2)},${e6.y.toFixed(2)}) end=(${n4.x.toFixed(2)},${n4.y.toFixed(2)})`});console.warn(`[StitchSolver] Skipped ${o4.size} routes for connection ${t5[0]?.connectionName??"?"}, skipped routes: ${e5.join("; ")}`)}return f2}orderRoutesByProximity(t5,e4){let n3=new Set(t5),s3=[],o4=e4;for(;n3.size>0;){let t7=null,e5=1/0,i3=!1;for(let s4 of n3){let n4=s4.route[0],r4=s4.route[s4.route.length-1],a2=St2(o4,n4),c3=St2(o4,r4);a2<e5&&(e5=a2,t7=s4,i3=!1),c3<e5&&(e5=c3,t7=s4,i3=!0)}if(!t7)break;{s3.push(t7),n3.delete(t7);let e6=t7.route[0],r4=t7.route[t7.route.length-1];o4=i3?e6:r4}}return s3}visualize(){let t5={points:[],lines:[],circles:[],rects:[],title:"Multiple High Density Route Stitch Solver 2"};for(let[e4,n3]of this.mergedHdRoutes.entries()){let s3=this.colorMap[n3.connectionName]??`hsl(120, 100%, ${40+10*e4%40}%)`;for(let e5=0;e5<n3.route.length-1;e5++){let o4=n3.route[e5],i3=n3.route[e5+1],r4=o4.z!==0?it2(s3,.5):s3;t5.lines?.push({points:[{x:o4.x,y:o4.y},{x:i3.x,y:i3.y}],strokeColor:r4,strokeWidth:n3.traceThickness})}for(let e5 of n3.route){let n4=e5.z!==0?it2(s3,.5):s3;t5.points?.push({x:e5.x,y:e5.y,color:n4})}for(let e5 of n3.vias)t5.circles?.push({center:{x:e5.x,y:e5.y},radius:n3.viaDiameter/2,fill:s3});if(n3.jumpers&&n3.jumpers.length>0){let e5=Je2(n3.jumpers,{color:s3,label:n3.connectionName});t5.rects.push(...e5.rects??[]),t5.lines.push(...e5.lines??[])}}for(let e4 of this.unsolvedRoutes){let n3=this.colorMap[e4.connectionName]??"gray";t5.points?.push({x:e4.start.x,y:e4.start.y,color:n3,label:`${e4.connectionName} Start`},{x:e4.end.x,y:e4.end.y,color:n3,label:`${e4.connectionName} End`});for(let s3=0;s3<e4.hdRoutes.length;s3++){let o4=e4.hdRoutes[s3];if(o4.route.length>1&&t5.lines?.push({points:o4.route.map(t7=>({x:t7.x,y:t7.y})),strokeColor:it2(n3,.5),strokeDash:"10 5",label:`segment ${s3}`}),o4.jumpers&&o4.jumpers.length>0){let e5=Je2(o4.jumpers,{color:n3,label:o4.connectionName});t5.rects.push(...e5.rects??[]),t5.lines.push(...e5.lines??[])}}}return t5}};function Ia2(t5,e4,n3,s3={}){return{solverName:t5,solverClass:e4,getConstructorParams:n3,onSolved:s3.onSolved}}var Ca2=class extends y{constructor(t5,e4={}){super();__publicField(this,"netToPointPairsSolver");__publicField(this,"traceKeepoutSolver");__publicField(this,"nodeSolver");__publicField(this,"nodeTargetMerger");__publicField(this,"edgeSolver");__publicField(this,"relateNodesToOffBoardConnections");__publicField(this,"colorMap");__publicField(this,"highDensityRouteSolver");__publicField(this,"simpleHighDensityRouteSolver");__publicField(this,"highDensitySolver");__publicField(this,"highDensityStitchSolver");__publicField(this,"singleLayerNodeMerger");__publicField(this,"offboardPathFragmentSolver");__publicField(this,"strawSolver");__publicField(this,"deadEndSolver");__publicField(this,"traceSimplificationSolver");__publicField(this,"traceWidthSolver");__publicField(this,"availableSegmentPointSolver");__publicField(this,"portPointPathingSolver");__publicField(this,"multiSectionPortPointOptimizer");__publicField(this,"viaDiameter");__publicField(this,"minTraceWidth");__publicField(this,"effort");__publicField(this,"startTimeOfPhase");__publicField(this,"endTimeOfPhase");__publicField(this,"timeSpentOnPhase");__publicField(this,"activeSubSolver",null);__publicField(this,"connMap");__publicField(this,"srjWithPointPairs");__publicField(this,"capacityNodes",null);__publicField(this,"capacityEdges",null);__publicField(this,"cacheProvider",null);__publicField(this,"pipelineDef",[Ia2("netToPointPairsSolver",fn2,t5=>[t5.srj,t5.colorMap],{onSolved:t5=>{t5.srjWithPointPairs=t5.netToPointPairsSolver?.getNewSimpleRouteJson(),t5.colorMap=ot2(t5.srjWithPointPairs,this.connMap),t5.connMap=$e2(t5.srjWithPointPairs)}}),Ia2("nodeSolver",Js2,t5=>[{simpleRouteJson:t5.srjWithPointPairs}],{onSolved:t5=>{t5.capacityNodes=t5.nodeSolver?.getOutput().meshNodes??[]}}),Ia2("relateNodesToOffBoardConnections",cr2,t5=>[{capacityMeshNodes:t5.capacityNodes,srj:t5.srj}],{onSolved:t5=>{t5.capacityNodes=t5.relateNodesToOffBoardConnections?.getOutput().capacityNodes}}),Ia2("edgeSolver",cn2,t5=>[t5.capacityNodes],{onSolved:t5=>{t5.capacityEdges=t5.edgeSolver?.edges}}),Ia2("availableSegmentPointSolver",Io2,t5=>[{nodes:t5.capacityNodes,edges:t5.capacityEdges||[],traceWidth:t5.minTraceWidth,colorMap:t5.colorMap}]),Ia2("portPointPathingSolver",Zo2,t5=>{let e4=t5.capacityNodes.map(t7=>({capacityMeshNodeId:t7.capacityMeshNodeId,center:t7.center,width:t7.width,height:t7.height,portPoints:[],availableZ:t7.availableZ,_containsTarget:t7._containsTarget,_containsObstacle:t7._containsObstacle,_offBoardConnectionId:t7._offBoardConnectionId,_offBoardConnectedCapacityMeshNodeIds:t7._offBoardConnectedCapacityMeshNodeIds})),n3=new Map(e4.map(t7=>[t7.capacityMeshNodeId,t7])),s3=t5.availableSegmentPointSolver;for(let t7 of s3.sharedEdgeSegments)for(let e5 of t7.portPoints){let[s4,o4]=e5.nodeIds,i3={portPointId:e5.segmentPortPointId,x:e5.x,y:e5.y,z:e5.availableZ[0]??0,connectionNodeIds:[s4,o4],distToCentermostPortOnZ:e5.distToCentermostPortOnZ,connectsToOffBoardNode:t7.nodeIds.some(t8=>n3.get(t8)?._offBoardConnectionId)},r4=n3.get(s4);r4&&r4.portPoints.push(i3)}return[{simpleRouteJson:t5.srjWithPointPairs,inputNodes:e4,capacityMeshNodes:t5.capacityNodes,colorMap:t5.colorMap,numShuffleSeeds:10*t5.effort,hyperParameters:{JUMPER_PF_FN_ENABLED:!0,NODE_PF_FACTOR:100,MAX_RIPS:100*t5.effort,RIPPING_ENABLED:!0,RIPPING_PF_THRESHOLD:.9-.7*(1-1/t5.effort),RANDOM_RIP_FRACTION:.05,NODE_PF_MAX_PENALTY:1e3,STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR:0,CENTER_OFFSET_DIST_PENALTY_FACTOR:0,FORCE_CENTER_FIRST:!0}}]},{onSolved:t5=>{let e4=t5.portPointPathingSolver;e4&&hr2({connMap:t5.connMap,connectionsWithResults:e4.connectionsWithResults,inputNodes:e4.inputNodes,obstacles:t5.srj.obstacles})}}),Ia2("highDensitySolver",Ma2,t5=>[{nodePortPoints:t5.multiSectionPortPointOptimizer?.getNodesWithPortPoints()??t5.portPointPathingSolver?.getNodesWithPortPoints()??[],colorMap:t5.colorMap,viaDiameter:t5.viaDiameter,traceWidth:t5.minTraceWidth,connMap:t5.connMap,capacityMeshNodes:t5.capacityNodes??[],capacityMeshEdges:t5.capacityEdges??[]}]),Ia2("highDensityStitchSolver",Na2,t5=>[{connections:t5.srjWithPointPairs.connections,hdRoutes:t5.highDensitySolver.routes,connectionPathResults:t5.multiSectionPortPointOptimizer?.connectionResults??t5.portPointPathingSolver?.connectionsWithResults??[],colorMap:t5.colorMap,layerCount:t5.srj.layerCount,defaultViaDiameter:t5.viaDiameter}]),Ia2("traceKeepoutSolver",rr2,t5=>[{hdRoutes:t5.traceSimplificationSolver?.simplifiedHdRoutes??t5.highDensityStitchSolver?.mergedHdRoutes??[],obstacles:t5.srj.obstacles,jumpers:t5.highDensitySolver?.getOutputJumpers()??[],connMap:t5.connMap,colorMap:t5.colorMap,srj:t5.srj}])]);__publicField(this,"currentPipelineStepIndex",0);if(this.srj=t5,this.opts=e4,this.MAX_ITERATIONS=1e8,this.viaDiameter=t5.minViaDiameter??.6,this.minTraceWidth=t5.minTraceWidth,this.effort=e4.effort??1,e4.capacityDepth===void 0){let n3=t5.bounds.maxX-t5.bounds.minX,s3=t5.bounds.maxY-t5.bounds.minY,o4=Math.max(n3,s3),i3=e4.targetMinCapacity??.5;e4.capacityDepth=Be2(o4,i3)}this.connMap=$e2(t5),this.colorMap=ot2(t5,this.connMap),this.cacheProvider=e4.cacheProvider===void 0?ut2():e4.cacheProvider===null?null:e4.cacheProvider,this.startTimeOfPhase={},this.endTimeOfPhase={},this.timeSpentOnPhase={}}getConstructorParams(){return[this.srj,this.opts]}_step(){let t5=this.pipelineDef[this.currentPipelineStepIndex];if(!t5)return void(this.solved=!0);if(this.activeSubSolver)return this.activeSubSolver.step(),void(this.activeSubSolver.solved?(this.endTimeOfPhase[t5.solverName]=performance.now(),this.timeSpentOnPhase[t5.solverName]=this.endTimeOfPhase[t5.solverName]-this.startTimeOfPhase[t5.solverName],t5.onSolved?.(this),this.activeSubSolver=null,this.currentPipelineStepIndex++):this.activeSubSolver.failed&&(this.error=this.activeSubSolver?.error,this.failed=!0,this.activeSubSolver=null));let e4=t5.getConstructorParams(this);this.activeSubSolver=new t5.solverClass(...e4),this[t5.solverName]=this.activeSubSolver,this.timeSpentOnPhase[t5.solverName]=0,this.startTimeOfPhase[t5.solverName]=performance.now()}solveUntilPhase(t5){for(;this.getCurrentPhase()!==t5;)this.step()}getCurrentPhase(){return this.pipelineDef[this.currentPipelineStepIndex]?.solverName??"none"}visualize(){if(!this.solved&&this.activeSubSolver)return this.activeSubSolver.visualize();let t5=this.netToPointPairsSolver?.visualize(),e4=this.nodeSolver?.visualize(),n3=this.nodeTargetMerger?.visualize(),s3=this.singleLayerNodeMerger?.visualize(),o4=this.strawSolver?.visualize(),i3=this.edgeSolver?.visualize(),r4=this.traceKeepoutSolver?.visualize(),a2=this.deadEndSolver?.visualize(),c3=this.availableSegmentPointSolver?.visualize(),h2=this.offboardPathFragmentSolver?.visualize(),d3=this.portPointPathingSolver?.visualize(),l2=this.multiSectionPortPointOptimizer?.visualize(),u4=this.highDensityRouteSolver?.visualize(),p2=this.highDensitySolver?.visualize(),m3=this.simpleHighDensityRouteSolver?.visualize(),f2=this.highDensityStitchSolver?.visualize(),y3=this.traceSimplificationSolver?.visualize(),x3=this.traceWidthSolver?.visualize(),v4=this.srj.outline,S4=[];if(S4.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)"}),v4&&v4.length>=2){let t7=v4.map(t8=>({x:t8.x,y:t8.y}));t7.push({...t7[0]}),S4.push({points:t7,strokeColor:"rgba(0, 136, 255, 0.95)"})}let P4={points:[...this.srj.connections.flatMap(t7=>t7.pointsToConnect.map(e5=>({...e5,label:`${t7.name} ${e5.pcb_port_id??""}`})))],rects:[...(this.srj.obstacles??[]).map(t7=>({...t7,fill:t7.layers?.includes("top")?"rgba(255,0,0,0.25)":t7.layers?.includes("bottom")?"rgba(0,0,255,0.25)":"rgba(255,0,0,0.25)",label:["obstacle",t7.offBoardConnectsTo?`offboardConnections: ${t7.offBoardConnectsTo?.join(", ")}`:"",t7.layers?.join(", ")].filter(Boolean).join(`
|
|
577
|
+
`)})}return t5}},Na2=class extends y{constructor(t5){super();__publicField(this,"unsolvedRoutes");__publicField(this,"mergedHdRoutes",[]);__publicField(this,"colorMap",{});__publicField(this,"defaultTraceThickness");__publicField(this,"defaultViaDiameter");this.colorMap=t5.colorMap??{};let e4=t5.hdRoutes[0];this.defaultTraceThickness=e4?.traceThickness??.15,this.defaultViaDiameter=e4?.viaDiameter??t5.defaultViaDiameter??.6;let n3=new Map;for(let e5 of t5.connectionPathResults)n3.set(e5.connection.name,e5);let s3=new Map;for(let e5 of t5.hdRoutes){let t7=s3.get(e5.connectionName);t7?t7.push(e5):s3.set(e5.connectionName,[e5])}this.unsolvedRoutes=[];for(let[e5,o4]of s3.entries()){let s4=t5.connections.find(t7=>t7.name===e5);if(!s4)continue;let i3=n3.get(e5),r4=[];i3?.path&&(r4=i3.path.map(t7=>t7.currentNodeId));let a2={...s4.pointsToConnect[0],z:Xe2(Ue2(s4.pointsToConnect[0]),t5.layerCount)},c3={...s4.pointsToConnect[1],z:Xe2(Ue2(s4.pointsToConnect[1]),t5.layerCount)};this.unsolvedRoutes.push({connectionName:e5,hdRoutes:o4,nodeOrder:r4,start:a2,end:c3})}this.MAX_ITERATIONS=1e5}_step(){let t5=this.unsolvedRoutes.pop();if(!t5)return void(this.solved=!0);let e4=this.stitchOrderedRoutes(t5);this.mergedHdRoutes.push(e4)}stitchOrderedRoutes(t5){let{connectionName:e4,hdRoutes:n3,nodeOrder:s3,start:o4,end:i3}=t5;if(n3.length===0)return{connectionName:e4,traceThickness:this.defaultTraceThickness,viaDiameter:this.defaultViaDiameter,route:[o4,i3],vias:[],jumpers:[]};let r4;r4=s3.length>0?this.orderRoutesByNodePath(n3,s3,o4,e4):this.orderRoutesByProximity(n3,o4);let a2=[],c3=[],h2=[];a2.push({x:o4.x,y:o4.y,z:o4.z});for(let t7=0;t7<r4.length;t7++){let e5=r4[t7],n4=a2[a2.length-1],s4=e5.route[0],o5=e5.route[e5.route.length-1],i4=St2(n4,s4),d4=St2(n4,o5),l2=Math.min(i4,d4);if(t7>0&&l2>1)continue;let u4;u4=i4<=d4?[...e5.route]:[...e5.route].reverse(),u4.length>0&&St2(n4,u4[0])<.001&&(u4=u4.slice(1)),a2.push(...u4),c3.push(...e5.vias),e5.jumpers&&h2.push(...e5.jumpers)}let d3=St2(a2[a2.length-1],i3);return d3>.001&&d3<5&&a2.push({x:i3.x,y:i3.y,z:i3.z}),{connectionName:e4,rootConnectionName:n3[0]?.rootConnectionName,traceThickness:n3[0]?.traceThickness??this.defaultTraceThickness,viaDiameter:n3[0]?.viaDiameter??this.defaultViaDiameter,route:a2,vias:c3,jumpers:h2}}orderRoutesByNodePath(t5,e4,n3,s3){if(t5.length===0)return[];let o4=new Set(t5),i3=null,r4=1/0;for(let t7 of o4){let e5=t7.route[0],s4=t7.route[t7.route.length-1],o5=Math.min(St2(n3,e5),St2(n3,s4));o5<r4&&(r4=o5,i3=t7)}if(!i3)return[];o4.delete(i3);let a2=i3.route[0],c3=i3.route[i3.route.length-1],h2,d3;St2(n3,a2)<=St2(n3,c3)?(h2=a2,d3=c3):(h2=c3,d3=a2);let l2=(t7,e5)=>{let n4=0;for(let s4 of o4){if(s4===e5)continue;let o5=s4.route[0],i4=s4.route[s4.route.length-1];(St2(t7,o5)<10||St2(t7,i4)<10)&&n4++}return n4},u4=[i3],p2=d3;for(;o4.size>0;){let t7=null,e5=1/0,n4=-1;for(let s4 of o4){let o5=s4.route[0],i4=s4.route[s4.route.length-1],r6=St2(p2,o5),a3=St2(p2,i4),c4=Math.min(r6,a3);if(c4>=10)continue;let h3=l2(r6<=a3?i4:o5,s4),d4=h3===0,u5=n4===0,m4=c4-e5,f4=!1;f4=t7===null||!!(!d4&&u5&&m4<5)||!(d4&&!u5&&m4>-5)&&c4<e5,f4&&(e5=c4,t7=s4,n4=h3)}if(!t7)break;{u4.push(t7),o4.delete(t7);let e6=t7.route[0],n5=t7.route[t7.route.length-1];p2=St2(p2,e6)<=St2(p2,n5)?n5:e6}}let m3=[];for(p2=h2;o4.size>0;){let t7=null,e5=1/0,s4=-1,i4=St2(p2,n3);for(let r6 of o4){let o5=r6.route[0],a3=r6.route[r6.route.length-1],c4=St2(p2,o5),h3=St2(p2,a3),d4=Math.min(c4,h3);if(d4>=10)continue;let u5=c4<=h3?a3:o5;if(St2(u5,n3)>i4+2)continue;let m4=l2(u5,r6),f4=m4===0,g4=s4===0,y3=d4-e5,x3=!1;x3=t7===null||!!(!f4&&g4&&y3<5)||!(f4&&!g4&&y3>-5)&&d4<e5,x3&&(e5=d4,t7=r6,s4=m4)}if(!t7)break;{m3.unshift(t7),o4.delete(t7);let e6=t7.route[0],n4=t7.route[t7.route.length-1];p2=St2(p2,e6)<=St2(p2,n4)?n4:e6}}let f2=[...m3,...u4];if(o4.size>0){let e5=[...o4].map(t7=>{let e6=t7.route[0],n4=t7.route[t7.route.length-1];return`start=(${e6.x.toFixed(2)},${e6.y.toFixed(2)}) end=(${n4.x.toFixed(2)},${n4.y.toFixed(2)})`});console.warn(`[StitchSolver] Skipped ${o4.size} routes for connection ${t5[0]?.connectionName??"?"}, skipped routes: ${e5.join("; ")}`)}return f2}orderRoutesByProximity(t5,e4){let n3=new Set(t5),s3=[],o4=e4;for(;n3.size>0;){let t7=null,e5=1/0,i3=!1;for(let s4 of n3){let n4=s4.route[0],r4=s4.route[s4.route.length-1],a2=St2(o4,n4),c3=St2(o4,r4);a2<e5&&(e5=a2,t7=s4,i3=!1),c3<e5&&(e5=c3,t7=s4,i3=!0)}if(!t7)break;{s3.push(t7),n3.delete(t7);let e6=t7.route[0],r4=t7.route[t7.route.length-1];o4=i3?e6:r4}}return s3}visualize(){let t5={points:[],lines:[],circles:[],rects:[],title:"Multiple High Density Route Stitch Solver 2"};for(let[e4,n3]of this.mergedHdRoutes.entries()){let s3=this.colorMap[n3.connectionName]??`hsl(120, 100%, ${40+10*e4%40}%)`;for(let e5=0;e5<n3.route.length-1;e5++){let o4=n3.route[e5],i3=n3.route[e5+1],r4=o4.z!==0?it2(s3,.5):s3;t5.lines?.push({points:[{x:o4.x,y:o4.y},{x:i3.x,y:i3.y}],strokeColor:r4,strokeWidth:n3.traceThickness})}for(let e5 of n3.route){let n4=e5.z!==0?it2(s3,.5):s3;t5.points?.push({x:e5.x,y:e5.y,color:n4})}for(let e5 of n3.vias)t5.circles?.push({center:{x:e5.x,y:e5.y},radius:n3.viaDiameter/2,fill:s3});if(n3.jumpers&&n3.jumpers.length>0){let e5=Je2(n3.jumpers,{color:s3,label:n3.connectionName});t5.rects.push(...e5.rects??[]),t5.lines.push(...e5.lines??[])}}for(let e4 of this.unsolvedRoutes){let n3=this.colorMap[e4.connectionName]??"gray";t5.points?.push({x:e4.start.x,y:e4.start.y,color:n3,label:`${e4.connectionName} Start`},{x:e4.end.x,y:e4.end.y,color:n3,label:`${e4.connectionName} End`});for(let s3=0;s3<e4.hdRoutes.length;s3++){let o4=e4.hdRoutes[s3];if(o4.route.length>1&&t5.lines?.push({points:o4.route.map(t7=>({x:t7.x,y:t7.y})),strokeColor:it2(n3,.5),strokeDash:"10 5",label:`segment ${s3}`}),o4.jumpers&&o4.jumpers.length>0){let e5=Je2(o4.jumpers,{color:n3,label:o4.connectionName});t5.rects.push(...e5.rects??[]),t5.lines.push(...e5.lines??[])}}}return t5}};function Ia2(t5,e4,n3,s3={}){return{solverName:t5,solverClass:e4,getConstructorParams:n3,onSolved:s3.onSolved}}var Ca2=class extends y{constructor(t5,e4={}){super();__publicField(this,"netToPointPairsSolver");__publicField(this,"traceKeepoutSolver");__publicField(this,"nodeSolver");__publicField(this,"nodeTargetMerger");__publicField(this,"edgeSolver");__publicField(this,"relateNodesToOffBoardConnections");__publicField(this,"colorMap");__publicField(this,"highDensityRouteSolver");__publicField(this,"simpleHighDensityRouteSolver");__publicField(this,"highDensitySolver");__publicField(this,"highDensityStitchSolver");__publicField(this,"singleLayerNodeMerger");__publicField(this,"offboardPathFragmentSolver");__publicField(this,"strawSolver");__publicField(this,"deadEndSolver");__publicField(this,"traceSimplificationSolver");__publicField(this,"traceWidthSolver");__publicField(this,"availableSegmentPointSolver");__publicField(this,"portPointPathingSolver");__publicField(this,"multiSectionPortPointOptimizer");__publicField(this,"viaDiameter");__publicField(this,"minTraceWidth");__publicField(this,"effort");__publicField(this,"startTimeOfPhase");__publicField(this,"endTimeOfPhase");__publicField(this,"timeSpentOnPhase");__publicField(this,"activeSubSolver",null);__publicField(this,"connMap");__publicField(this,"srjWithPointPairs");__publicField(this,"capacityNodes",null);__publicField(this,"capacityEdges",null);__publicField(this,"cacheProvider",null);__publicField(this,"pipelineDef",[Ia2("netToPointPairsSolver",fn2,t5=>[t5.srj,t5.colorMap],{onSolved:t5=>{t5.srjWithPointPairs=t5.netToPointPairsSolver?.getNewSimpleRouteJson(),t5.colorMap=ot2(t5.srjWithPointPairs,this.connMap),t5.connMap=$e2(t5.srjWithPointPairs)}}),Ia2("nodeSolver",Js2,t5=>[{simpleRouteJson:t5.srjWithPointPairs}],{onSolved:t5=>{t5.capacityNodes=t5.nodeSolver?.getOutput().meshNodes??[]}}),Ia2("relateNodesToOffBoardConnections",cr2,t5=>[{capacityMeshNodes:t5.capacityNodes,srj:t5.srj}],{onSolved:t5=>{t5.capacityNodes=t5.relateNodesToOffBoardConnections?.getOutput().capacityNodes}}),Ia2("edgeSolver",cn2,t5=>[t5.capacityNodes],{onSolved:t5=>{t5.capacityEdges=t5.edgeSolver?.edges}}),Ia2("availableSegmentPointSolver",Io2,t5=>[{nodes:t5.capacityNodes,edges:t5.capacityEdges||[],traceWidth:t5.minTraceWidth,colorMap:t5.colorMap}]),Ia2("portPointPathingSolver",Zo2,t5=>{let e4=t5.capacityNodes.map(t7=>({capacityMeshNodeId:t7.capacityMeshNodeId,center:t7.center,width:t7.width,height:t7.height,portPoints:[],availableZ:t7.availableZ,_containsTarget:t7._containsTarget,_containsObstacle:t7._containsObstacle,_offBoardConnectionId:t7._offBoardConnectionId,_offBoardConnectedCapacityMeshNodeIds:t7._offBoardConnectedCapacityMeshNodeIds})),n3=new Map(e4.map(t7=>[t7.capacityMeshNodeId,t7])),s3=t5.availableSegmentPointSolver;for(let t7 of s3.sharedEdgeSegments)for(let e5 of t7.portPoints){let[s4,o4]=e5.nodeIds,i3={portPointId:e5.segmentPortPointId,x:e5.x,y:e5.y,z:e5.availableZ[0]??0,connectionNodeIds:[s4,o4],distToCentermostPortOnZ:e5.distToCentermostPortOnZ,connectsToOffBoardNode:t7.nodeIds.some(t8=>n3.get(t8)?._offBoardConnectionId)},r4=n3.get(s4);r4&&r4.portPoints.push(i3)}return[{simpleRouteJson:t5.srjWithPointPairs,inputNodes:e4,capacityMeshNodes:t5.capacityNodes,colorMap:t5.colorMap,numShuffleSeeds:10*t5.effort,hyperParameters:{JUMPER_PF_FN_ENABLED:!0,NODE_PF_FACTOR:100,MAX_RIPS:100*t5.effort,RIPPING_ENABLED:!0,MAX_RIPPING_PF_THRESHOLD:.9,MIN_RIPPING_PF_THRESHOLD:.1,RANDOM_RIP_FRACTION:.05,NODE_PF_MAX_PENALTY:1e3,STRAIGHT_LINE_DEVIATION_PENALTY_FACTOR:0,CENTER_OFFSET_DIST_PENALTY_FACTOR:0,FORCE_CENTER_FIRST:!0}}]},{onSolved:t5=>{let e4=t5.portPointPathingSolver;e4&&hr2({connMap:t5.connMap,connectionsWithResults:e4.connectionsWithResults,inputNodes:e4.inputNodes,obstacles:t5.srj.obstacles})}}),Ia2("highDensitySolver",Ma2,t5=>[{nodePortPoints:t5.multiSectionPortPointOptimizer?.getNodesWithPortPoints()??t5.portPointPathingSolver?.getNodesWithPortPoints()??[],colorMap:t5.colorMap,viaDiameter:t5.viaDiameter,traceWidth:t5.minTraceWidth,connMap:t5.connMap,capacityMeshNodes:t5.capacityNodes??[],capacityMeshEdges:t5.capacityEdges??[]}]),Ia2("highDensityStitchSolver",Na2,t5=>[{connections:t5.srjWithPointPairs.connections,hdRoutes:t5.highDensitySolver.routes,connectionPathResults:t5.multiSectionPortPointOptimizer?.connectionResults??t5.portPointPathingSolver?.connectionsWithResults??[],colorMap:t5.colorMap,layerCount:t5.srj.layerCount,defaultViaDiameter:t5.viaDiameter}]),Ia2("traceKeepoutSolver",rr2,t5=>[{hdRoutes:t5.traceSimplificationSolver?.simplifiedHdRoutes??t5.highDensityStitchSolver?.mergedHdRoutes??[],obstacles:t5.srj.obstacles,jumpers:t5.highDensitySolver?.getOutputJumpers()??[],connMap:t5.connMap,colorMap:t5.colorMap,srj:t5.srj}])]);__publicField(this,"currentPipelineStepIndex",0);if(this.srj=t5,this.opts=e4,this.MAX_ITERATIONS=1e8,this.viaDiameter=t5.minViaDiameter??.6,this.minTraceWidth=t5.minTraceWidth,this.effort=e4.effort??1,e4.capacityDepth===void 0){let n3=t5.bounds.maxX-t5.bounds.minX,s3=t5.bounds.maxY-t5.bounds.minY,o4=Math.max(n3,s3),i3=e4.targetMinCapacity??.5;e4.capacityDepth=Be2(o4,i3)}this.connMap=$e2(t5),this.colorMap=ot2(t5,this.connMap),this.cacheProvider=e4.cacheProvider===void 0?ut2():e4.cacheProvider===null?null:e4.cacheProvider,this.startTimeOfPhase={},this.endTimeOfPhase={},this.timeSpentOnPhase={}}getConstructorParams(){return[this.srj,this.opts]}_step(){let t5=this.pipelineDef[this.currentPipelineStepIndex];if(!t5)return void(this.solved=!0);if(this.activeSubSolver)return this.activeSubSolver.step(),void(this.activeSubSolver.solved?(this.endTimeOfPhase[t5.solverName]=performance.now(),this.timeSpentOnPhase[t5.solverName]=this.endTimeOfPhase[t5.solverName]-this.startTimeOfPhase[t5.solverName],t5.onSolved?.(this),this.activeSubSolver=null,this.currentPipelineStepIndex++):this.activeSubSolver.failed&&(this.error=this.activeSubSolver?.error,this.failed=!0,this.activeSubSolver=null));let e4=t5.getConstructorParams(this);this.activeSubSolver=new t5.solverClass(...e4),this[t5.solverName]=this.activeSubSolver,this.timeSpentOnPhase[t5.solverName]=0,this.startTimeOfPhase[t5.solverName]=performance.now()}solveUntilPhase(t5){for(;this.getCurrentPhase()!==t5;)this.step()}getCurrentPhase(){return this.pipelineDef[this.currentPipelineStepIndex]?.solverName??"none"}visualize(){if(!this.solved&&this.activeSubSolver)return this.activeSubSolver.visualize();let t5=this.netToPointPairsSolver?.visualize(),e4=this.nodeSolver?.visualize(),n3=this.nodeTargetMerger?.visualize(),s3=this.singleLayerNodeMerger?.visualize(),o4=this.strawSolver?.visualize(),i3=this.edgeSolver?.visualize(),r4=this.traceKeepoutSolver?.visualize(),a2=this.deadEndSolver?.visualize(),c3=this.availableSegmentPointSolver?.visualize(),h2=this.offboardPathFragmentSolver?.visualize(),d3=this.portPointPathingSolver?.visualize(),l2=this.multiSectionPortPointOptimizer?.visualize(),u4=this.highDensityRouteSolver?.visualize(),p2=this.highDensitySolver?.visualize(),m3=this.simpleHighDensityRouteSolver?.visualize(),f2=this.highDensityStitchSolver?.visualize(),y3=this.traceSimplificationSolver?.visualize(),x3=this.traceWidthSolver?.visualize(),v4=this.srj.outline,S4=[];if(S4.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)"}),v4&&v4.length>=2){let t7=v4.map(t8=>({x:t8.x,y:t8.y}));t7.push({...t7[0]}),S4.push({points:t7,strokeColor:"rgba(0, 136, 255, 0.95)"})}let P4={points:[...this.srj.connections.flatMap(t7=>t7.pointsToConnect.map(e5=>({...e5,label:`${t7.name} ${e5.pcb_port_id??""}`})))],rects:[...(this.srj.obstacles??[]).map(t7=>({...t7,fill:t7.layers?.includes("top")?"rgba(255,0,0,0.25)":t7.layers?.includes("bottom")?"rgba(0,0,255,0.25)":"rgba(255,0,0,0.25)",label:["obstacle",t7.offBoardConnectsTo?`offboardConnections: ${t7.offBoardConnectsTo?.join(", ")}`:"",t7.layers?.join(", ")].filter(Boolean).join(`
|
|
578
578
|
`)}))],lines:S4},b3=[P4,t5,e4,n3,s3,o4,i3,a2,c3,h2,d3,l2,u4?g3(P4,u4):null,p2?g3(P4,p2):null,m3?g3(P4,m3):null,f2,y3,r4,x3,this.solved?g3(P4,sn2(this.getOutputSimpleRouteJson())):null].filter(Boolean);return g3(...b3)}preview(){let t5=this.highDensitySolver?.routes??this.simpleHighDensityRouteSolver?.routes??this.highDensityRouteSolver?.routes;if(t5){let e4=[];for(let n3=t5.length-1;n3>=0;n3--){let s3=t5[n3];if(e4.push({points:s3.route.map(t7=>({x:t7.x,y:t7.y})),strokeColor:this.colorMap[s3.connectionName]}),e4.length>200)break}return{lines:e4}}if(this.portPointPathingSolver){let t7=[];for(let e4 of this.portPointPathingSolver.connectionsWithResults)e4.path&&t7.push({points:e4.path.map(t8=>({x:t8.point.x,y:t8.point.y})),strokeColor:this.colorMap[e4.connection.name]});return{lines:t7}}return this.netToPointPairsSolver?this.netToPointPairsSolver?.visualize():{}}_getOutputHdRoutes(){return this.traceWidthSolver?.hdRoutesWithWidths??this.traceKeepoutSolver?.redrawnHdRoutes??this.traceSimplificationSolver?.simplifiedHdRoutes??this.highDensityStitchSolver?.mergedHdRoutes??this.highDensitySolver?.routes??this.simpleHighDensityRouteSolver?.routes??this.highDensityRouteSolver?.routes}getConnectedOffboardObstacles(){let t5={},e4=new Set(this.srj.connections.map(t7=>t7.rootConnectionName??t7.name));for(let[n3,s3]of this.srj.obstacles.entries()){if(!s3.offBoardConnectsTo?.length)continue;let o4=s3.obstacleId??`__obs${n3}`;s3.obstacleId=o4;let i3=this.connMap.getNetConnectedToId(o4);if(!i3)continue;let r4=this.connMap.getIdsConnectedToNet(i3).find(t7=>e4.has(t7));r4&&(t5[o4]=r4)}return t5}getOutputSimplifiedPcbTraces(){if(!this.solved||!this.highDensityRouteSolver&&!this.simpleHighDensityRouteSolver&&!this.highDensitySolver)throw new Error("Cannot get output before solving is complete");let t5=[],e4=this._getOutputHdRoutes();for(let n3 of this.netToPointPairsSolver?.newConnections??[]){let s3=n3.netConnectionName??this.srj.connections.find(t7=>t7.name===n3.name)?.netConnectionName,o4=e4.filter(t7=>t7.connectionName===n3.name);for(let e5=0;e5<o4.length;e5++){let i3=o4[e5],r4={type:"pcb_trace",pcb_trace_id:`${n3.name}_${e5}`,connection_name:s3??n3.rootConnectionName??n3.name,route:We2(i3,this.srj.layerCount)};t5.push(r4)}}return t5}getOutputJumpers(){return this.highDensitySolver?this.highDensitySolver.getOutputJumpers():[]}getOutputSimpleRouteJson(){let t5=this.getOutputJumpers();return{...this.srj,traces:this.getOutputSimplifiedPcbTraces(),jumpers:t5.length>0?t5:void 0}}};var ORIENTATION={CCW:-1,CW:1,NOT_ORIENTABLE:0},PIx2=2*Math.PI,INSIDE$2=1,OUTSIDE$1=0,BOUNDARY$1=2,CONTAINS=3,INTERLACE=4,OVERLAP_SAME$1=1,OVERLAP_OPPOSITE$1=2,NOT_VERTEX$1=0,START_VERTEX$1=1,END_VERTEX$1=2,Constants=Object.freeze({__proto__:null,BOUNDARY:BOUNDARY$1,CCW:!0,CONTAINS,CW:!1,END_VERTEX:END_VERTEX$1,INSIDE:INSIDE$2,INTERLACE,NOT_VERTEX:NOT_VERTEX$1,ORIENTATION,OUTSIDE:OUTSIDE$1,OVERLAP_OPPOSITE:OVERLAP_OPPOSITE$1,OVERLAP_SAME:OVERLAP_SAME$1,PIx2,START_VERTEX:START_VERTEX$1}),DP_TOL=1e-6;function setTolerance(tolerance){DP_TOL=tolerance}function getTolerance(){return DP_TOL}var DECIMALS=3;function EQ_0(x3){return x3<DP_TOL&&x3>-DP_TOL}function EQ(x3,y3){return x3-y3<DP_TOL&&x3-y3>-DP_TOL}function GT2(x3,y3){return x3-y3>DP_TOL}function GE(x3,y3){return x3-y3>-DP_TOL}function LT(x3,y3){return x3-y3<-DP_TOL}function LE(x3,y3){return x3-y3<DP_TOL}var Utils$1=Object.freeze({__proto__:null,DECIMALS,EQ,EQ_0,GE,GT:GT2,LE,LT,getTolerance,setTolerance}),Flatten={Utils:Utils$1,Errors:void 0,Matrix:void 0,Planar_set:void 0,Point:void 0,Vector:void 0,Line:void 0,Circle:void 0,Segment:void 0,Arc:void 0,Box:void 0,Edge:void 0,Face:void 0,Ray:void 0,Ray_shooting:void 0,Multiline:void 0,Polygon:void 0,Distance:void 0,Inversion:void 0};for(let c3 in Constants)Flatten[c3]=Constants[c3];Object.defineProperty(Flatten,"DP_TOL",{get:function(){return getTolerance()},set:function(value){setTolerance(value)}});var Errors=class{static get ILLEGAL_PARAMETERS(){return new ReferenceError("Illegal Parameters")}static get ZERO_DIVISION(){return new Error("Zero division")}static get UNRESOLVED_BOUNDARY_CONFLICT(){return new Error("Unresolved boundary conflict in boolean operation")}static get INFINITE_LOOP(){return new Error("Infinite loop")}static get CANNOT_COMPLETE_BOOLEAN_OPERATION(){return new Error("Cannot complete boolean operation")}static get CANNOT_INVOKE_ABSTRACT_METHOD(){return new Error("Abstract method cannot be invoked")}static get OPERATION_IS_NOT_SUPPORTED(){return new Error("Operation is not supported")}static get UNSUPPORTED_SHAPE_TYPE(){return new Error("Unsupported shape type")}};Flatten.Errors=Errors;var LinkedList=class{constructor(first,last){this.first=first,this.last=last||this.first}[Symbol.iterator](){let value;return{next:()=>(value=value?value.next:this.first,{value,done:value===void 0})}}get size(){let counter=0;for(let edge of this)counter++;return counter}toArray(start=void 0,end=void 0){let elements=[],from=start||this.first,to3=end||this.last,element=from;if(element===void 0)return elements;do elements.push(element),element=element.next;while(element!==to3.next);return elements}append(element){return this.isEmpty()?this.first=element:(element.prev=this.last,this.last.next=element),this.last=element,this.last.next=void 0,this.first.prev=void 0,this}insert(newElement,elementBefore){if(this.isEmpty())this.first=newElement,this.last=newElement;else if(elementBefore==null)newElement.next=this.first,this.first.prev=newElement,this.first=newElement;else{let elementAfter=elementBefore.next;elementBefore.next=newElement,elementAfter&&(elementAfter.prev=newElement),newElement.prev=elementBefore,newElement.next=elementAfter,this.last===elementBefore&&(this.last=newElement)}return this.last.next=void 0,this.first.prev=void 0,this}remove(element){return element===this.first&&element===this.last?(this.first=void 0,this.last=void 0):(element.prev&&(element.prev.next=element.next),element.next&&(element.next.prev=element.prev),element===this.first&&(this.first=element.next),element===this.last&&(this.last=element.prev)),this}isEmpty(){return this.first===void 0}static testInfiniteLoop(first){let edge=first,controlEdge=first;do{if(edge!=first&&edge===controlEdge)throw Errors.INFINITE_LOOP;edge=edge.next,controlEdge=controlEdge.next.next}while(edge!=first)}},defaultAttributes={stroke:"black"},SVGAttributes=class{constructor(args=defaultAttributes){for(let property in args)this[property]=args[property];this.stroke=args.stroke??defaultAttributes.stroke}toAttributesString(){return Object.keys(this).reduce((acc,key)=>acc+(this[key]!==void 0?this.toAttrString(key,this[key]):""),"")}toAttrString(key,value){let SVGKey=key==="className"?"class":this.convertCamelToKebabCase(key);return value===null?`${SVGKey} `:`${SVGKey}="${value.toString()}" `}convertCamelToKebabCase(str){return str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g).join("-").toLowerCase()}};function convertToString(attrs){return new SVGAttributes(attrs).toAttributesString()}function intersectLine2Line(line1,line2){let ip2=[],[A12,B12,C12]=line1.standard,[A22,B22,C22]=line2.standard,det=A12*B22-B12*A22,detX=C12*B22-B12*C22,detY=A12*C22-C12*A22;if(!Flatten.Utils.EQ_0(det)){let x3,y3;B12===0?(x3=C12/A12,y3=detY/det):B22===0?(x3=C22/A22,y3=detY/det):A12===0?(x3=detX/det,y3=C12/B12):A22===0?(x3=detX/det,y3=C22/B22):(x3=detX/det,y3=detY/det),ip2.push(new Flatten.Point(x3,y3))}return ip2}function intersectLine2Circle(line2,circle2){let ip2=[],prj=circle2.pc.projectionOn(line2),dist=circle2.pc.distanceTo(prj)[0];if(Flatten.Utils.EQ(dist,circle2.r))ip2.push(prj);else if(Flatten.Utils.LT(dist,circle2.r)){let delta=Math.sqrt(circle2.r*circle2.r-dist*dist),v_trans,pt3;v_trans=line2.norm.rotate90CCW().multiply(delta),pt3=prj.translate(v_trans),ip2.push(pt3),v_trans=line2.norm.rotate90CW().multiply(delta),pt3=prj.translate(v_trans),ip2.push(pt3)}return ip2}function intersectLine2Box(line2,box2){let ips=[];for(let seg of box2.toSegments()){let ips_tmp=intersectSegment2Line(seg,line2);for(let pt3 of ips_tmp)ptInIntPoints(pt3,ips)||ips.push(pt3)}return ips}function intersectLine2Arc(line2,arc2){let ip2=[];if(intersectLine2Box(line2,arc2.box).length===0)return ip2;let circle2=new Flatten.Circle(arc2.pc,arc2.r),ip_tmp=intersectLine2Circle(line2,circle2);for(let pt3 of ip_tmp)pt3.on(arc2)&&ip2.push(pt3);return ip2}function intersectSegment2Line(seg,line2){let ip2=[];if(seg.ps.on(line2)&&ip2.push(seg.ps),seg.pe.on(line2)&&!seg.isZeroLength()&&ip2.push(seg.pe),ip2.length>0||seg.isZeroLength()||seg.ps.leftTo(line2)&&seg.pe.leftTo(line2)||!seg.ps.leftTo(line2)&&!seg.pe.leftTo(line2))return ip2;let line1=new Flatten.Line(seg.ps,seg.pe);return intersectLine2Line(line1,line2)}function intersectSegment2Segment(seg1,seg2){let ip2=[];if(seg1.isZeroLength())return seg1.ps.on(seg2)&&ip2.push(seg1.ps),ip2;if(seg2.isZeroLength())return seg2.ps.on(seg1)&&ip2.push(seg2.ps),ip2;let line1=new Flatten.Line(seg1.ps,seg1.pe),line2=new Flatten.Line(seg2.ps,seg2.pe);if(line1.incidentTo(line2))seg1.ps.on(seg2)&&ip2.push(seg1.ps),seg1.pe.on(seg2)&&ip2.push(seg1.pe),seg2.ps.on(seg1)&&!seg2.ps.equalTo(seg1.ps)&&!seg2.ps.equalTo(seg1.pe)&&ip2.push(seg2.ps),seg2.pe.on(seg1)&&!seg2.pe.equalTo(seg1.ps)&&!seg2.pe.equalTo(seg1.pe)&&ip2.push(seg2.pe);else{let new_ip=intersectLine2Line(line1,line2);new_ip.length>0&&isPointInSegmentBox(new_ip[0],seg1)&&isPointInSegmentBox(new_ip[0],seg2)&&ip2.push(new_ip[0])}return ip2}function isPointInSegmentBox(point6,segment2){let box2=segment2.box;return Flatten.Utils.LE(point6.x,box2.xmax)&&Flatten.Utils.GE(point6.x,box2.xmin)&&Flatten.Utils.LE(point6.y,box2.ymax)&&Flatten.Utils.GE(point6.y,box2.ymin)}function intersectSegment2Circle(segment2,circle2){let ips=[];if(segment2.isZeroLength()){let[dist,_4]=segment2.ps.distanceTo(circle2.pc);return Flatten.Utils.EQ(dist,circle2.r)&&ips.push(segment2.ps),ips}let line2=new Flatten.Line(segment2.ps,segment2.pe),ips_tmp=intersectLine2Circle(line2,circle2);for(let ip2 of ips_tmp)ip2.on(segment2)&&ips.push(ip2);return ips}function intersectSegment2Arc(segment2,arc2){let ip2=[];if(segment2.isZeroLength())return segment2.ps.on(arc2)&&ip2.push(segment2.ps),ip2;let line2=new Flatten.Line(segment2.ps,segment2.pe),circle2=new Flatten.Circle(arc2.pc,arc2.r),ip_tmp=intersectLine2Circle(line2,circle2);for(let pt3 of ip_tmp)pt3.on(segment2)&&pt3.on(arc2)&&ip2.push(pt3);return ip2}function intersectSegment2Box(segment2,box2){let ips=[];for(let seg of box2.toSegments()){let ips_tmp=intersectSegment2Segment(seg,segment2);for(let ip2 of ips_tmp)ips.push(ip2)}return ips}function intersectCircle2Circle(circle1,circle2){let ip2=[],vec=new Flatten.Vector(circle1.pc,circle2.pc),r12=circle1.r,r22=circle2.r;if(Flatten.Utils.EQ_0(r12)||Flatten.Utils.EQ_0(r22))return ip2;if(Flatten.Utils.EQ_0(vec.x)&&Flatten.Utils.EQ_0(vec.y)&&Flatten.Utils.EQ(r12,r22))return ip2.push(circle1.pc.translate(-r12,0)),ip2;let dist=circle1.pc.distanceTo(circle2.pc)[0];if(Flatten.Utils.GT(dist,r12+r22)||Flatten.Utils.LT(dist,Math.abs(r12-r22)))return ip2;vec.x/=dist,vec.y/=dist;let pt3;if(Flatten.Utils.EQ(dist,r12+r22)||Flatten.Utils.EQ(dist,Math.abs(r12-r22)))return pt3=circle1.pc.translate(r12*vec.x,r12*vec.y),ip2.push(pt3),ip2;let a2=r12*r12/(2*dist)-r22*r22/(2*dist)+dist/2,mid_pt=circle1.pc.translate(a2*vec.x,a2*vec.y),h2=Math.sqrt(r12*r12-a2*a2);return pt3=mid_pt.translate(vec.rotate90CCW().multiply(h2)),ip2.push(pt3),pt3=mid_pt.translate(vec.rotate90CW().multiply(h2)),ip2.push(pt3),ip2}function intersectCircle2Box(circle2,box2){let ips=[];for(let seg of box2.toSegments()){let ips_tmp=intersectSegment2Circle(seg,circle2);for(let ip2 of ips_tmp)ips.push(ip2)}return ips}function intersectArc2Arc(arc1,arc2){let ip2=[];if(arc1.pc.equalTo(arc2.pc)&&Flatten.Utils.EQ(arc1.r,arc2.r)){let pt3;return pt3=arc1.start,pt3.on(arc2)&&ip2.push(pt3),pt3=arc1.end,pt3.on(arc2)&&ip2.push(pt3),pt3=arc2.start,pt3.on(arc1)&&ip2.push(pt3),pt3=arc2.end,pt3.on(arc1)&&ip2.push(pt3),ip2}let circle1=new Flatten.Circle(arc1.pc,arc1.r),circle2=new Flatten.Circle(arc2.pc,arc2.r),ip_tmp=circle1.intersect(circle2);for(let pt3 of ip_tmp)pt3.on(arc1)&&pt3.on(arc2)&&ip2.push(pt3);return ip2}function intersectArc2Circle(arc2,circle2){let ip2=[];if(circle2.pc.equalTo(arc2.pc)&&Flatten.Utils.EQ(circle2.r,arc2.r))return ip2.push(arc2.start),ip2.push(arc2.end),ip2;let circle1=circle2,circle22=new Flatten.Circle(arc2.pc,arc2.r),ip_tmp=intersectCircle2Circle(circle1,circle22);for(let pt3 of ip_tmp)pt3.on(arc2)&&ip2.push(pt3);return ip2}function intersectArc2Box(arc2,box2){let ips=[];for(let seg of box2.toSegments()){let ips_tmp=intersectSegment2Arc(seg,arc2);for(let ip2 of ips_tmp)ips.push(ip2)}return ips}function intersectEdge2Segment(edge,segment2){return edge.isSegment?intersectSegment2Segment(edge.shape,segment2):intersectSegment2Arc(segment2,edge.shape)}function intersectEdge2Arc(edge,arc2){return edge.isSegment?intersectSegment2Arc(edge.shape,arc2):intersectArc2Arc(edge.shape,arc2)}function intersectEdge2Line(edge,line2){return edge.isSegment?intersectSegment2Line(edge.shape,line2):intersectLine2Arc(line2,edge.shape)}function intersectEdge2Ray(edge,ray2){return edge.isSegment?intersectRay2Segment(ray2,edge.shape):intersectRay2Arc(ray2,edge.shape)}function intersectEdge2Circle(edge,circle2){return edge.isSegment?intersectSegment2Circle(edge.shape,circle2):intersectArc2Circle(edge.shape,circle2)}function intersectSegment2Polygon(segment2,polygon2){let ip2=[];for(let edge of polygon2.edges)for(let pt3 of intersectEdge2Segment(edge,segment2))ip2.push(pt3);return ip2}function intersectArc2Polygon(arc2,polygon2){let ip2=[];for(let edge of polygon2.edges)for(let pt3 of intersectEdge2Arc(edge,arc2))ip2.push(pt3);return ip2}function intersectLine2Polygon(line2,polygon2){let ip2=[];if(polygon2.isEmpty())return ip2;for(let edge of polygon2.edges)for(let pt3 of intersectEdge2Line(edge,line2))ptInIntPoints(pt3,ip2)||ip2.push(pt3);return line2.sortPoints(ip2)}function intersectCircle2Polygon(circle2,polygon2){let ip2=[];if(polygon2.isEmpty())return ip2;for(let edge of polygon2.edges)for(let pt3 of intersectEdge2Circle(edge,circle2))ip2.push(pt3);return ip2}function intersectEdge2Edge(edge1,edge2){return edge1.isSegment?intersectEdge2Segment(edge2,edge1.shape):edge1.isArc?intersectEdge2Arc(edge2,edge1.shape):edge1.isLine?intersectEdge2Line(edge2,edge1.shape):edge1.isRay?intersectEdge2Ray(edge2,edge1.shape):[]}function intersectEdge2Polygon(edge,polygon2){let ip2=[];if(polygon2.isEmpty()||edge.shape.box.not_intersect(polygon2.box))return ip2;let resp_edges=polygon2.edges.search(edge.shape.box);for(let resp_edge of resp_edges)ip2=[...ip2,...intersectEdge2Edge(edge,resp_edge)];return ip2}function intersectMultiline2Polygon(multiline2,polygon2){let ip2=[];if(polygon2.isEmpty()||multiline2.size===0)return ip2;for(let edge of multiline2)ip2=[...ip2,...intersectEdge2Polygon(edge,polygon2)];return ip2}function intersectPolygon2Polygon(polygon1,polygon2){let ip2=[];if(polygon1.isEmpty()||polygon2.isEmpty()||polygon1.box.not_intersect(polygon2.box))return ip2;for(let edge1 of polygon1.edges)ip2=[...ip2,...intersectEdge2Polygon(edge1,polygon2)];return ip2}function intersectShape2Polygon(shape,polygon2){return shape instanceof Flatten.Line?intersectLine2Polygon(shape,polygon2):shape instanceof Flatten.Segment?intersectSegment2Polygon(shape,polygon2):shape instanceof Flatten.Arc?intersectArc2Polygon(shape,polygon2):[]}function ptInIntPoints(new_pt,ip2){return ip2.some(pt3=>pt3.equalTo(new_pt))}function createLineFromRay(ray2){return new Flatten.Line(ray2.start,ray2.norm)}function intersectRay2Segment(ray2,segment2){return intersectSegment2Line(segment2,createLineFromRay(ray2)).filter(pt3=>ray2.contains(pt3))}function intersectRay2Arc(ray2,arc2){return intersectLine2Arc(createLineFromRay(ray2),arc2).filter(pt3=>ray2.contains(pt3))}function intersectRay2Circle(ray2,circle2){return intersectLine2Circle(createLineFromRay(ray2),circle2).filter(pt3=>ray2.contains(pt3))}function intersectRay2Box(ray2,box2){return intersectLine2Box(createLineFromRay(ray2),box2).filter(pt3=>ray2.contains(pt3))}function intersectRay2Line(ray2,line2){return intersectLine2Line(createLineFromRay(ray2),line2).filter(pt3=>ray2.contains(pt3))}function intersectRay2Ray(ray1,ray2){return intersectLine2Line(createLineFromRay(ray1),createLineFromRay(ray2)).filter(pt3=>ray1.contains(pt3)).filter(pt3=>ray2.contains(pt3))}function intersectRay2Polygon(ray2,polygon2){return intersectLine2Polygon(createLineFromRay(ray2),polygon2).filter(pt3=>ray2.contains(pt3))}function intersectShape2Shape(shape1,shape2){if(shape1.intersect&&shape1.intersect instanceof Function)return shape1.intersect(shape2);throw Errors.UNSUPPORTED_SHAPE_TYPE}function intersectShape2Multiline(shape,multiline2){let ip2=[];for(let edge of multiline2)ip2=[...ip2,...intersectShape2Shape(shape,edge.shape)];return ip2}function intersectMultiline2Multiline(multiline1,multiline2){let ip2=[];for(let edge1 of multiline1)for(let edge2 of multiline2)ip2=[...ip2,...intersectShape2Shape(edge1.shape,edge2.shape)];return ip2}var Multiline$1=class Multiline extends LinkedList{constructor(...args){if(super(),this.isInfinite=!1,args.length===1&&args[0]instanceof Array&&args[0].length>0){let shapes=args[0],L3=shapes.length,anyShape=s3=>s3 instanceof Flatten.Segment||s3 instanceof Flatten.Arc||s3 instanceof Flatten.Ray||s3 instanceof Flatten.Line,anyShapeExceptLine=s3=>s3 instanceof Flatten.Segment||s3 instanceof Flatten.Arc||s3 instanceof Flatten.Ray,shapeSegmentOrArc=s3=>s3 instanceof Flatten.Segment||s3 instanceof Flatten.Arc;if(L3===1&&anyShape(shapes[0])||L3>1&&anyShapeExceptLine(shapes[0])&&anyShapeExceptLine(shapes[L3-1])&&shapes.slice(1,L3-1).every(shapeSegmentOrArc)){this.isInfinite=shapes.some(shape=>shape instanceof Flatten.Ray||shape instanceof Flatten.Line);for(let shape of shapes){let edge=new Flatten.Edge(shape);this.append(edge)}this.setArcLength()}else throw Flatten.Errors.ILLEGAL_PARAMETERS}}get edges(){return[...this]}get box(){return this.edges.reduce((acc,edge)=>acc.merge(edge.box),new Flatten.Box)}get vertices(){let v4=this.edges.map(edge=>edge.start);return v4.push(this.last.end),v4}get length(){if(this.isEmpty())return 0;if(this.isInfinite)return Number.POSITIVE_INFINITY;let len=0;for(let edge of this)len+=edge.length;return len}clone(){return new Multiline(this.toShapes())}setArcLength(){for(let edge of this)this.setOneEdgeArcLength(edge)}setOneEdgeArcLength(edge){edge===this.first?edge.arc_length=0:edge.arc_length=edge.prev.arc_length+edge.prev.length}pointAtLength(length3){if(length3>this.length||length3<0||this.isInfinite)return null;let point6=null;for(let edge of this)if(length3>=edge.arc_length&&(edge===this.last||length3<edge.next.arc_length)){point6=edge.pointAtLength(length3-edge.arc_length);break}return point6}addVertex(pt3,edge){let shapes=edge.shape.split(pt3);if(shapes[0]===null)return edge.prev;if(shapes[1]===null)return edge;let newEdge=new Flatten.Edge(shapes[0]),edgeBefore=edge.prev;return this.insert(newEdge,edgeBefore),edge.shape=shapes[1],newEdge}getChain(edgeFrom,edgeTo){let edges=[];for(let edge=edgeFrom;edge!==edgeTo.next;edge=edge.next)edges.push(edge);return edges}split(ip2){for(let pt3 of ip2){let edge=this.findEdgeByPoint(pt3);this.addVertex(pt3,edge)}return this}findEdgeByPoint(pt3){let edgeFound;for(let edge of this)if(edge.shape.contains(pt3)){edgeFound=edge;break}return edgeFound}distanceTo(shape){if(shape instanceof Point){let[dist,shortest_segment]=Flatten.Distance.shape2multiline(shape,this);return[dist,shortest_segment.reverse()]}if(shape instanceof Flatten.Line){let[dist,shortest_segment]=Flatten.Distance.shape2multiline(shape,this);return[dist,shortest_segment.reverse()]}if(shape instanceof Flatten.Circle){let[dist,shortest_segment]=Flatten.Distance.shape2multiline(shape,this);return[dist,shortest_segment.reverse()]}if(shape instanceof Flatten.Segment){let[dist,shortest_segment]=Flatten.Distance.shape2multiline(shape,this);return[dist,shortest_segment.reverse()]}if(shape instanceof Flatten.Arc){let[dist,shortest_segment]=Flatten.Distance.shape2multiline(shape,this);return[dist,shortest_segment.reverse()]}if(shape instanceof Flatten.Multiline)return Flatten.Distance.multiline2multiline(this,shape);throw Flatten.Errors.UNSUPPORTED_SHAPE_TYPE}intersect(shape){return shape instanceof Flatten.Multiline?intersectMultiline2Multiline(this,shape):intersectShape2Multiline(shape,this)}contains(shape){if(shape instanceof Flatten.Point)return this.edges.some(edge=>edge.shape.contains(shape));throw Flatten.Errors.UNSUPPORTED_SHAPE_TYPE}translate(vec){return new Multiline(this.edges.map(edge=>edge.shape.translate(vec)))}rotate(angle=0,center2=new Flatten.Point){return new Multiline(this.edges.map(edge=>edge.shape.rotate(angle,center2)))}transform(matrix2=new Flatten.Matrix){return new Multiline(this.edges.map(edge=>edge.shape.transform(matrix2)))}toShapes(){return this.edges.map(edge=>edge.shape.clone())}toJSON(){return this.edges.map(edge=>edge.toJSON())}svgPoints(){return this.vertices.map(p2=>`${p2.x},${p2.y}`).join(" ")}dpath(){let dPathStr=`M${this.first.start.x},${this.first.start.y}`;for(let edge of this)dPathStr+=edge.svg();return dPathStr}svg(attrs={}){let svgStr=`
|
|
579
579
|
<path ${convertToString({fill:"none",...attrs})} d="`;svgStr+=`
|
|
580
580
|
M${this.first.start.x},${this.first.start.y}`;for(let edge of this)svgStr+=edge.svg();return svgStr+=`" >
|
|
@@ -612,7 +612,7 @@ ${error.stack}`),asyncEffect.complete=!0,"root"in this&&this.root&&this.root.emi
|
|
|
612
612
|
`||ch2==="\r"){i3++;continue}if(isDigit(ch2)||ch2==="."&&i3+1<expr.length&&isDigit(expr[i3+1])){let start=i3;for(i3++;i3<expr.length;){let c3=expr[i3];if(isDigit(c3)||c3===".")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(ch2)){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(ch2==="("||ch2===")"){tokens.push({type:"paren",value:ch2}),i3++;continue}if(ch2==="+"||ch2==="-"||ch2==="*"||ch2==="/"){tokens.push({type:"operator",value:ch2}),i3++;continue}throw new Error(`Unexpected character "${ch2}" 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(t5=>"value"in t5?t5.value:"?").join(" ");throw new Error(`Unexpected tokens at end of expression: ${leftover}`)}return result}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,j3)=>i3!==j3&&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:(a2,b3)=>a2._renderId===b3._renderId,isHovered:elem=>!1,isVisited:elem=>!1,isActive:elem=>!1},cssSelectPrimitiveComponentAdapterWithoutSubcircuits={...cssSelectPrimitiveComponentAdapter,getChildren:node=>node.children.filter(c3=>!c3.isSubcircuit)},cssSelectPrimitiveComponentAdapterOnlySubcircuits={...cssSelectPrimitiveComponentAdapter,getChildren:node=>node.children.filter(c3=>c3.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,"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 current2=this;for(;current2;){if(current2._parsedProps&&propertyName in current2._parsedProps)return current2._parsedProps[propertyName];current2=current2.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}}get lowercaseComponentName(){return this.componentName.toLowerCase()}get isSubcircuit(){return!!this.props.subcircuit||this.lowercaseComponentName==="group"&&this?.parent?.isRoot}get isGroup(){return this.lowercaseComponentName==="group"}get name(){return this._parsedProps.name??this.fallbackUnassignedName}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")}}_resolvePcbCoordinate(rawValue,axis,options={}){if(rawValue==null)return 0;if(typeof rawValue=="number")return rawValue;if(typeof rawValue!="string")throw new Error(`Invalid ${axis} value for ${this.componentName}: ${String(rawValue)}`);let allowBoardVariables=options.allowBoardVariables??this._isNormalComponent===!0,includesBoardVariable=rawValue.includes("board."),knownVariables={};if(allowBoardVariables){let board=this._getBoard(),boardVariables=board?._getBoardCalcVariables()??{};if(includesBoardVariable&&!board)throw new Error(`Cannot resolve ${axis} for ${this.componentName}: no board found for board.* variables`);if(includesBoardVariable&&board&&Object.keys(boardVariables).length===0)throw new Error("Cannot do calculations based on board size when the board is auto-sized");Object.assign(knownVariables,boardVariables)}try{return evaluateCalcString(rawValue,{knownVariables})}catch(error){let message=error instanceof Error?error.message:String(error);throw new Error(`Invalid ${axis} value for ${this.componentName}: ${message}`)}}computePcbPropsTransform(){let rotation4=this._getPcbRotationBeforeLayout()??0,{pcbX,pcbY}=this.getResolvedPcbPositionProp();return compose(translate(pcbX,pcbY),rotate(rotation4*Math.PI/180))}_computePcbGlobalTransformBeforeLayout(){let manualPlacement=this.getSubcircuit()._getPcbManualPlacementForComponent(this);if(manualPlacement&&this.props.pcbX===void 0&&this.props.pcbY===void 0){let rotation4=this._getPcbRotationBeforeLayout()??0;return compose(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),compose(translate(manualPlacement.x,manualPlacement.y),rotate(rotation4*Math.PI/180)))}if(this.isPcbPrimitive){let primitiveContainer=this.getPrimitiveContainer();if(primitiveContainer&&primitiveContainer._parsedProps.layer==="bottom")return compose(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),flipY(),this.computePcbPropsTransform())}return compose(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),this.computePcbPropsTransform())}getPrimitiveContainer(){return this.isPrimitiveContainer?this:this.parent?.getPrimitiveContainer?.()??null}getParentNormalComponent(){let current2=this.parent;for(;current2;){if(current2.isPrimitiveContainer&¤t2.doInitialPcbComponentRender)return current2;current2=current2.parent}return null}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(),isFlipped=container?container._parsedProps.layer==="bottom":!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 compose(translate(props.schX??0,props.schY??0))}computeSchematicGlobalTransform(){let manualPlacementTransform=this._getSchematicGlobalManualPlacementTransform(this);return manualPlacementTransform||compose(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 cf&&normalizedRotation===0)return symbol_name_right;if(symbol_name_up in cf&&normalizedRotation===90)return symbol_name_up;if(symbol_name_left in cf&&normalizedRotation===180)return symbol_name_left;if(symbol_name_down in cf&&normalizedRotation===270)return symbol_name_down;if(symbol_name_horz in cf&&(normalizedRotation===0||normalizedRotation===180))return symbol_name_horz;if(symbol_name_vert in cf&&(normalizedRotation===90||normalizedRotation===270))return symbol_name_vert;if(base_symbol_name in cf)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?cf[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 position2 of placementConfigPositions)if(isMatchingSelector(component,position2.selector)||component.props.name===position2.selector)return applyToPoint(this._computePcbGlobalTransformBeforeLayout(),position2.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 position2 of placementConfigPositions)if(isMatchingSelector(component,position2.selector)||component.props.name===position2.selector)return applyToPoint(this.computeSchematicGlobalTransform(),position2.center);return null}_getSchematicGlobalManualPlacementTransform(component){let manualEdits=this.getSubcircuit()?._parsedProps.manualEdits;if(!manualEdits)return null;for(let position2 of manualEdits.schematic_placements??[])if((isMatchingSelector(component,position2.selector)||component.props.name===position2.selector)&&position2.relative_to==="group_center")return compose(this.parent?._computePcbGlobalTransformBeforeLayout()??identity(),translate(position2.center.x,position2.center.y));return null}_getGlobalPcbPositionBeforeLayout(){return applyToPoint(this._computePcbGlobalTransformBeforeLayout(),{x:0,y:0})}_getGlobalSchematicPositionBeforeLayout(){return applyToPoint(this.computeSchematicGlobalTransform(),{x:0,y:0})}_getBoard(){let current2=this;for(;current2;){let maybePrimitive=current2;if(maybePrimitive.componentName==="Board")return maybePrimitive;current2=current2.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(c3=>c3!==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(a2=>aliases2.map(a22=>a22.toString()).includes(a2))}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");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}`];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(n3=>n3.lowercaseComponentName===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}_getPinCount(){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(ph2=>`.${ph2}`).join(", ")}) />`:`<${cname}#${this._renderId} />`}get[Symbol.toStringTag](){return this.getString()}[Symbol.for("nodejs.util.inspect.custom")](){return this.getString()}},ErrorPlaceholderComponent=class extends PrimitiveComponent2{constructor(props,error){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,type:props.type||"unknown",component_name:props.name,error_type:"source_failed_to_create_component_error",message:error instanceof Error?error.message:String(error),pcbX:resolveCoordinate(props.pcbX,"pcbX"),pcbY:resolveCoordinate(props.pcbY,"pcbY"),schX:props.schX,schY:props.schY}}get config(){return{componentName:"ErrorPlaceholder",zodProps:external_exports.object({}).passthrough()}}doInitialSourceRender(){if(this.root?.db){let pcbPosition2=this._getGlobalPcbPositionBeforeLayout(),schematicPosition=this._getGlobalSchematicPositionBeforeLayout();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:`Could not create ${this._parsedProps.componentType??"component"}${this._parsedProps.name?` "${this._parsedProps.name}"`:""}. ${this._parsedProps.error?.formattedError?._errors?.join("; ")||this._parsedProps.message}`,pcb_center:pcbPosition2,schematic_center:schematicPosition})}}};function createErrorPlaceholderComponent(props,error){return new ErrorPlaceholderComponent(props,error)}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(error){return createErrorPlaceholderComponent({...props,componentType:type},error)}},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",error=>{console.log("Error in createContainer"),console.error(error),containerErrors.push(error)},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]},parsePinNumberFromLabelsOrThrow=(pinNumberOrLabel,pinLabels)=>{if(typeof pinNumberOrLabel=="number")return pinNumberOrLabel;if(pinNumberOrLabel.startsWith("pin"))return Number(pinNumberOrLabel.slice(3));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))return Number(pinNumberKey.replace("pin",""));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}}};function pairs2(arr){let result=[];for(let i3=0;i3<arr.length-1;i3++)result.push([arr[i3],arr[i3+1]]);return result}var netProps2=external_exports.object({name:external_exports.string().refine(val=>!/[+-]/.test(val),val=>({message:`Net names cannot contain "+" or "-" (component "Net" received "${val}"). Try using underscores instead, e.g. VCC_P`}))}),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:netProps2}}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()._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,B3]of islandPairs){let Apositions=A4.ports.map(port=>port._getGlobalPcbPositionBeforeLayout()),Bpositions=B3.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 j3=0;j3<Bpositions.length;j3++){let Bpos=Bpositions[j3],dist=Math.sqrt((Apos.x-Bpos.x)**2+(Apos.y-Bpos.y)**2);dist<closestDist&&(closestDist=dist,closestPair=[i3,j3])}}let Aport=A4.ports[closestPair[0]],Bport=B3.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)}}},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 angleRad=(props.ccwRotation??0)*Math.PI/180,cosAngle=Math.cos(angleRad),sinAngle=Math.sin(angleRad),width=Math.abs(props.width*cosAngle)+Math.abs(props.height*sinAngle),height=Math.abs(props.width*sinAngle)+Math.abs(props.height*cosAngle);return{width,height}}if(props.shape==="polygon"){let points=props.points,xs3=points.map(p2=>p2.x),ys3=points.map(p2=>p2.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){for(let port of parentPorts)if(port.isMatchingAnyOf(this.props.portHints)){this.matchedPort=port,port.registerMatch(this);return}}}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(),position2=this._getGlobalPcbPositionBeforeLayout(),globalTransform=this._computePcbGlobalTransformBeforeLayout(),normalizedRotationDegrees=(decomposeTSR(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(ph2=>ph2.toString())??[],pcb_smtpad2=null,pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id;if(props.shape==="circle")pcb_smtpad2=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:position2.x,y:position2.y,subcircuit_id:subcircuit?.subcircuit_id??void 0}),shouldCreateSolderPaste&&db2.pcb_solder_paste.insert({layer:pcb_smtpad2.layer,shape:"circle",radius:pcb_smtpad2.radius*.7,x:pcb_smtpad2.x,y:pcb_smtpad2.y,pcb_component_id:pcb_smtpad2.pcb_component_id,pcb_smtpad_id:pcb_smtpad2.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_smtpad2=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:position2.x,y:position2.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_smtpad2=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:position2.x,y:position2.y,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}),shouldCreateSolderPaste&&(pcb_smtpad2.shape==="rect"?db2.pcb_solder_paste.insert({layer:maybeFlipLayer(props.layer??"top"),shape:"rect",width:pcb_smtpad2.width*.7,height:pcb_smtpad2.height*.7,x:pcb_smtpad2.x,y:pcb_smtpad2.y,pcb_component_id:pcb_smtpad2.pcb_component_id,pcb_smtpad_id:pcb_smtpad2.pcb_smtpad_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:this.getGroup()?.pcb_group_id??void 0}):pcb_smtpad2.shape==="rotated_rect"&&db2.pcb_solder_paste.insert({layer:maybeFlipLayer(props.layer??"top"),shape:"rotated_rect",width:pcb_smtpad2.width*.7,height:pcb_smtpad2.height*.7,x:pcb_smtpad2.x,y:pcb_smtpad2.y,ccw_rotation:pcb_smtpad2.ccw_rotation,pcb_component_id:pcb_smtpad2.pcb_component_id,pcb_smtpad_id:pcb_smtpad2.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_smtpad2=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:position2.x,y:position2.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_smtpad2.width*.7,height:pcb_smtpad2.height*.7,x:position2.x,y:position2.y,ccw_rotation:padRotation,pcb_component_id,pcb_smtpad_id:pcb_smtpad2.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(point23=>{let transformed=applyToPoint(globalTransform,{x:distance.parse(point23.x),y:distance.parse(point23.y)});return{x:transformed.x,y:transformed.y}});pcb_smtpad2=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"&&(pcb_smtpad2=db2.pcb_smtpad.insert({pcb_component_id,pcb_port_id:this.matchedPort?.pcb_port_id,layer:maybeFlipLayer(props.layer??"top"),shape:"pill",x:position2.x,y:position2.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_smtpad2&&(this.pcb_smtpad_id=pcb_smtpad2.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 angleRad=smtpad2.ccw_rotation*Math.PI/180,cosAngle=Math.cos(angleRad),sinAngle=Math.sin(angleRad),w22=smtpad2.width/2,h2=smtpad2.height/2,xExtent=Math.abs(w22*cosAngle)+Math.abs(h2*sinAngle),yExtent=Math.abs(w22*sinAngle)+Math.abs(h2*cosAngle);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:xExtent*2,height:yExtent*2}}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(p2=>p2.x),ys3=points.map(p2=>p2.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}}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")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(p2=>({x:p2.x+deltaX,y:p2.y+deltaY}))});let newCenter={x:this._getPcbCircuitJsonBounds().center.x+deltaX/2,y:this._getPcbCircuitJsonBounds().center.y+deltaY/2};this.matchedPort?._setPositionFromLayout(newCenter)}}},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 transform5=this._computePcbGlobalTransformBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_path2=db2.pcb_silkscreen_path.insert({pcb_component_id,layer,route:props.route.map(p2=>{let transformedPosition=applyToPoint(transform5,{x:p2.x,y:p2.y});return{...p2,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_path2.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 point23 of currentPath.route)currentCenterX+=point23.x,currentCenterY+=point23.y;currentCenterX/=currentPath.route.length,currentCenterY/=currentPath.route.length;let offsetX=newCenter.x-currentCenterX,offsetY=newCenter.y-currentCenterY,newRoute=currentPath.route.map(point23=>({...point23,x:point23.x+offsetX,y:point23.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(p2=>({...p2,x:p2.x+deltaX,y:p2.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 point23 of props.route)minX=Math.min(minX,point23.x),maxX=Math.max(maxX,point23.x),minY=Math.min(minY,point23.y),maxY=Math.max(maxY,point23.y);return{width:maxX-minX,height:maxY-minY}}},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(point23=>{let{x:x3,y:y3,...restOfPoint}=point23,transformedPoint=applyToPoint(parentTransform,{x:x3,y:y3});return point23.route_type==="wire"&&point23.layer?{...transformedPoint,...restOfPoint,layer:maybeFlipLayer(point23.layer)}:{...transformedPoint,...restOfPoint}}),pcb_trace2=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_trace2.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 point23 of props.route)minX=Math.min(minX,point23.x),maxX=Math.max(maxX,point23.x),minY=Math.min(minY,point23.y),maxY=Math.max(maxY,point23.y),point23.route_type==="wire"&&(minX=Math.min(minX,point23.x-point23.width/2),maxX=Math.max(maxX,point23.x+point23.width/2),minY=Math.min(minY,point23.y-point23.width/2),maxY=Math.max(maxY,point23.y+point23.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}}},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(p2=>typeof p2.x=="number"?p2.x:parseFloat(String(p2.x))),ys3=props.padOutline.map(p2=>typeof p2.y=="number"?p2.y:parseFloat(String(p2.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),size2=this.getPcbSize();return{center:{x:platedHole.x,y:platedHole.y},bounds:{left:platedHole.x-size2.width/2,top:platedHole.y+size2.height/2,right:platedHole.x+size2.width/2,bottom:platedHole.y-size2.height/2},width:size2.width,height:size2.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.props.portHints){for(let port of parentPorts)if(port.isMatchingAnyOf(this.props.portHints)){this.matchedPort=port,port.registerMatch(this);return}}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,position2=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;if(this.emitSolderMaskMarginWarning(isCoveredWithSolderMask,soldermaskMargin),props.shape==="circle"){let pcb_plated_hole2=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:position2.x,y:position2.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_hole2.pcb_plated_hole_id,db2.pcb_solder_paste.insert({layer:"top",shape:"circle",radius:props.outerDiameter/2,x:position2.x,y:position2.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:position2.x,y:position2.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_hole2=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:position2.x,y:position2.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:props.pcbRotation??0,rect_ccw_rotation:props.pcbRotation??0,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_hole2.pcb_plated_hole_id}else if(props.shape==="pill"||props.shape==="oval"){let pcb_plated_hole2=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:position2.x,y:position2.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:props.pcbRotation??0});this.pcb_plated_hole_id=pcb_plated_hole2.pcb_plated_hole_id,db2.pcb_solder_paste.insert({layer:"top",shape:props.shape,width:props.outerWidth,height:props.outerHeight,x:position2.x,y:position2.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:position2.x,y:position2.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_hole2=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:position2.x,y:position2.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});this.pcb_plated_hole_id=pcb_plated_hole2.pcb_plated_hole_id}else if(props.shape==="pill_hole_with_rect_pad"){let pcb_plated_hole2=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",port_hints:this.getNameAndAliases(),x:position2.x,y:position2.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_hole2.pcb_plated_hole_id}else if(props.shape==="hole_with_polygon_pad"){let padOutline=(props.padOutline||[]).map(point23=>{let x3=typeof point23.x=="number"?point23.x:parseFloat(String(point23.x)),y3=typeof point23.y=="number"?point23.y:parseFloat(String(point23.y));return{x:x3,y:y3}}),pcb_plated_hole2=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:position2.x,y:position2.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_hole2.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)}}},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,position2=this._getGlobalPcbPositionBeforeLayout(),decomposedMat=decomposeTSR(this._computePcbGlobalTransformBeforeLayout()),isRotated90=Math.abs(decomposedMat.rotation.angle*(180/Math.PI)-90)%180<.01,pcb_keepout2=null;props.shape==="circle"?pcb_keepout2=db2.pcb_keepout.insert({layers:["top"],shape:"circle",radius:props.radius,center:{x:position2.x,y:position2.y},subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0}):props.shape==="rect"&&(pcb_keepout2=db2.pcb_keepout.insert({layers:["top"],shape:"rect",...isRotated90?{width:props.height,height:props.width}:{width:props.width,height:props.height},center:{x:position2.x,y:position2.y},subcircuit_id:subcircuit?.subcircuit_id??void 0,pcb_group_id:subcircuit?.getGroup()?.pcb_group_id??void 0})),pcb_keepout2&&(this.pcb_keepout_id=pcb_keepout2.pcb_keepout_id)}},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(),position2=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:position2.x,y:position2.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:position2.x,y:position2.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:position2.x,y:position2.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:position2.x,y:position2.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),size2=this.getPcbSize();return{center:{x:hole.x,y:hole.y},bounds:{left:hole.x-size2.width/2,top:hole.y-size2.height/2,right:hole.x+size2.width/2,bottom:hole.y+size2.height/2},width:size2.width,height:size2.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})}};function normalizeTextForCircuitJson(text){return text.replace(/\\n/g,`
|
|
613
613
|
`)}var SilkscreenText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"pcb_silkscreen_text_ids",[]);__publicField(this,"isPcbPrimitive",!0)}get config(){return{componentName:"SilkscreenText",zodProps:silkscreenTextProps}}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,container=this.getPrimitiveContainer(),position2=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer,isFlipped}=this._getPcbPrimitiveFlippedHelpers(),subcircuit=this.getSubcircuit(),rotation4=0;if(props.pcbRotation!==void 0&&props.pcbRotation!==0)rotation4=props.pcbRotation;else{let globalTransform=this._computePcbGlobalTransformBeforeLayout();rotation4=decomposeTSR(globalTransform).rotation.angle*180/Math.PI}isFlipped&&(rotation4=(rotation4+180)%360);let uniqueLayers=new Set(props.layers);props.layer&&uniqueLayers.add(props.layer);let targetLayers=uniqueLayers.size>0?Array.from(uniqueLayers):["top"],fontSize=props.fontSize??this.getInheritedProperty("pcbStyle")?.silkscreenFontSize??1;for(let layer of targetLayers){let pcb_silkscreen_text2=db2.pcb_silkscreen_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:position2.x,y:position2.y},font:props.font??"tscircuit2024",font_size:fontSize,layer:maybeFlipLayer(layer),text:normalizeTextForCircuitJson(props.text??""),ccw_rotation:rotation4,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_silkscreen_text_ids.push(pcb_silkscreen_text2.pcb_silkscreen_text_id)}}getPcbSize(){let{_parsedProps:props}=this,fontSize=props.fontSize??this.getInheritedProperty("pcbStyle")?.silkscreenFontSize??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;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}})}}},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 transform5=this._computePcbGlobalTransformBeforeLayout(),polygonData={shape:"polygon",points:props.points.map(p2=>applyToPoint(transform5,p2)),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 point23 of props.points)minX=Math.min(minX,point23.x),maxX=Math.max(maxX,point23.x),minY=Math.min(minY,point23.y),maxY=Math.max(maxY,point23.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 point23 of cutout.points)minX=Math.min(minX,point23.x),maxX=Math.max(maxX,point23.x),minY=Math.min(minY,point23.y),maxY=Math.max(maxY,point23.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,dx2=newCenter.x-oldCenter.x,dy2=newCenter.y-oldCenter.y,newPoints=cutout.points.map(p2=>({x:p2.x+dx2,y:p2.y+dy2}));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(p2=>({x:p2.x+deltaX,y:p2.y+deltaY}))}))}},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));return new SilkscreenText({anchorAlignment:anchorAlignment||"center",text:label??pinNum,layer:layer||"top",fontSize:elm.font_size+.2,pcbX:isNaN(elm.anchor_position.x)?0:elm.anchor_position.x,pcbY:elm.anchor_position.y,pcbRotation:readableRotation??0})},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_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,portHints:elm.port_hints,holeOffsetX:elm.hole_offset_x,holeOffsetY:elm.hole_offset_y})):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);footprinterString?.includes("pinrow")&&elm.text.includes("PIN")?components.push(createPinrowSilkscreenText({elm,pinLabels:pcbPinLabels??pinLabels??{},layer:elm.layer,readableRotation:ccwRotation,anchorAlignment:elm.anchor_alignment})):components.push(new SilkscreenText({anchorAlignment:elm.anchor_alignment||"center",text:componentName||elm.text,fontSize:elm.font_size+.2,pcbX:Number.isNaN(elm.anchor_position.x)?0:elm.anchor_position.x,pcbY:elm.anchor_position.y,pcbRotation:ccwRotation??0}))}else elm.type==="pcb_trace"&&components.push(new PcbTrace({route:elm.route}));return components};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&&!child.componentName.startsWith("Silkscreen")){let{x:x3,y:y3}=child._getGlobalPcbPositionBeforeLayout(),{width:width2,height:height2}=child.getPcbSize();minX=Math.min(minX,x3-width2/2),minY=Math.min(minY,y3-height2/2),maxX=Math.max(maxX,x3+width2/2),maxY=Math.max(maxY,y3+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 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,x3=center2.x+radius*Math.cos(radians),y3=center2.y+radius*Math.sin(radians);minX=Math.min(minX,x3),maxX=Math.max(maxX,x3),minY=Math.min(minY,y3),maxY=Math.max(maxY,y3)}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 cx2,cy2,w4,h2;if(elm.type==="schematic_component")cx2=elm.center?.x,cy2=elm.center?.y,w4=elm.size?.width,h2=elm.size?.height;else if(elm.type==="schematic_box")cx2=elm.x,cy2=elm.y,w4=elm.width,h2=elm.height;else if(elm.type==="schematic_port")cx2=elm.center?.x,cy2=elm.center?.y,w4=.2,h2=.2;else if(elm.type==="schematic_text")cx2=elm.position?.x,cy2=elm.position?.y,w4=(elm.text?.length??0)*.1,h2=.2;else if(elm.type==="schematic_line"){let x12=elm.x1??0,y12=elm.y1??0,x22=elm.x2??0,y22=elm.y2??0;cx2=(x12+x22)/2,cy2=(y12+y22)/2,w4=Math.abs(x22-x12),h2=Math.abs(y22-y12)}else if(elm.type==="schematic_rect")cx2=elm.center?.x,cy2=elm.center?.y,w4=elm.width,h2=elm.height;else if(elm.type==="schematic_circle"){cx2=elm.center?.x,cy2=elm.center?.y;let radius=elm.radius;typeof radius=="number"&&(w4=radius*2,h2=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}typeof cx2=="number"&&typeof cy2=="number"&&typeof w4=="number"&&typeof h2=="number"&&(minX=Math.min(minX,cx2-w4/2),maxX=Math.max(maxX,cx2+w4/2),minY=Math.min(minY,cy2-h2/2),maxY=Math.max(maxY,cy2+h2/2))}return{minX,maxX,minY,maxY}}function getRelativeDirection(pointA,pointB){let dx2=pointB.x-pointA.x,dy2=pointB.y-pointA.y;return Math.abs(dx2)>Math.abs(dy2)?dx2>=0?"right":"left":dy2>=0?"up":"down"}var areAllPcbPrimitivesOverlapping=pcbPrimitives=>{if(pcbPrimitives.length<=1)return!0;let bounds=pcbPrimitives.map(p2=>{let circuitBounds=p2._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 j3=i3+1;j3<bounds.length;j3++){let a2=bounds[i3],b3=bounds[j3];overlaps[i3][j3]=overlaps[j3][i3]=!(a2.right<b3.left||a2.left>b3.right||a2.bottom>b3.top||a2.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},getCenterOfPcbPrimitives=pcbPrimitives=>{if(pcbPrimitives.length===0)throw new Error("Cannot get center of empty PCB primitives array");let positions=pcbPrimitives.map(p2=>p2._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}},portProps2=external_exports.object({name:external_exports.string().optional(),pinNumber: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,"schematicSymbolPortDef",null);__publicField(this,"matchedComponents");__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(c3=>c3.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_port2=db2.pcb_port.get(this.pcb_port_id);return{center:{x:pcb_port2.x,y:pcb_port2.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(p2=>p2.schematicSymbolPortDef));let parentBoxDim=parentNormalComponent?._getSchematicBoxDimensions();return!!(parentBoxDim&&this.props.pinNumber!==void 0&&parentBoxDim.getPortPositionByPinNumber(this.props.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(p2=>p2.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 transform5=compose(parentNormalComponent.computeSchematicGlobalTransform(),translate(-symbol.center.x,-symbol.center.y));return applyToPoint(transform5,schematicSymbolPortDef)}let parentBoxDim=parentNormalComponent?._getSchematicBoxDimensions();if(parentBoxDim&&this.props.pinNumber!==void 0){let localPortPosition=parentBoxDim.getPortPositionByPinNumber(this.props.pinNumber);if(!localPortPosition)throw new Error(`Couldn't find position for schematic_port for port ${this.getString()} inside of the schematic box`);return applyToPoint(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_port2=db2.schematic_port.get(this.schematic_port_id);if(!schematic_port2)throw new Error(`Schematic port not found when trying to get post-layout position: ${this.schematic_port_id}`);return schematic_port2.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 pinAttributes=this.parent?._parsedProps?.pinAttributes;if(!pinAttributes)return[];let matches=[];for(let alias of this.getNameAndAliases()){let attributes2=pinAttributes[alias];attributes2&&matches.push(attributes2)}return 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(c3=>c3.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)attributes2.mustBeConnected!==void 0&&(portAttributesFromParent.must_be_connected=attributes2.mustBeConnected);let source_port2=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_port2.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_port2=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_port2.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(c3=>c3.isPcbPrimitive);if(pcbMatches.length===0)return;let matchCenter=null;if(pcbMatches.length===1&&(matchCenter=pcbMatches[0]._getPcbCircuitJsonBounds().center),pcbMatches.length>1){if(!areAllPcbPrimitivesOverlapping(pcbMatches))throw new Error(`${this.getString()} has multiple non-overlapping pcb matches, unclear how to place pcb_port: ${pcbMatches.map(c3=>c3.getString()).join(", ")}. (Note: tscircuit core does not currently allow you to specify internally connected pcb primitives with the same port hints, try giving them different port hints and specifying they are connected externally- or file an issue)`);matchCenter=getCenterOfPcbPrimitives(pcbMatches)}if(matchCenter){let subcircuit=this.getSubcircuit(),isBoardPinout=this._shouldIncludeInBoardPinout(),pcb_port2=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_port2.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(c3=>c3.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_port2=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_port2.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{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(),schematicPortInsertProps={type:"schematic_port",schematic_component_id:this.getParentNormalComponent()?.schematic_component_id,center:portCenter,source_port_id:this.source_port_id,facing_direction:this.facingDirection,distance_from_component_edge:.4,side_of_component:localPortInfo?.side,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_port2=db2.schematic_port.insert(schematicPortInsertProps);this.schematic_port_id=schematic_port2.schematic_port_id}_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(c3=>c3.isPcbPrimitive)}_getNetLabelText(){return`${this.parent?.props.name}_${this.props.name}`}},getPinNumberFromLabels=labels=>{let pinNumber=labels.find(p2=>/^(pin)?\d+$/.test(p2));return pinNumber?Number.parseInt(pinNumber.replace(/^pin/,"")):null};function getPortFromHints(hints,opts){let pinNumber=getPinNumberFromLabels(hints);if(!pinNumber)return null;let aliases2=[...hints.filter(p2=>p2.toString()!==pinNumber.toString()&&p2!==`pin${pinNumber}`),...opts?.additionalAliases?.[`pin${pinNumber}`]??[]];return new Port({pinNumber,aliases:aliases2})}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:pa3.leftSide?.pins.length??0,rightSize:pa3.rightSide?.pins.length??0,topSize:pa3.topSide?.pins.length??0,bottomSize:pa3.bottomSide?.pins.length??0};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 a2=arrangement;return a2.leftSide!==void 0||a2.rightSide!==void 0||a2.topSide!==void 0||a2.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(p2=>p2.side==="left"||p2.side==="right").some(p2=>params.pinLabels?.[`pin${p2.pinNumber}`]||params.pinLabels?.[p2.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(p2=>{let{distanceFromOrthogonalEdge,side}=p2,edgePos=trueEdgePositions[side],edgeDir=trueEdgeTraversalDirections[side];return{x:edgePos.x+distanceFromOrthogonalEdge*edgeDir.x,y:edgePos.y+distanceFromOrthogonalEdge*edgeDir.y,...p2}});return{getPortPositionByPinNumber(pinNumber){let port=truePortsWithPositions.find(p2=>p2.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}},debug22=(0,import_debug8.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(c3=>c3.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})}}},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}=this.root?._getBoard()??{},bounds=parent._getPcbCircuitJsonBounds(),pcb_component2=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=decomposeTSR(parentTransform).rotation.angle*180/Math.PI,rotationOffset=rotation3.parse({x:0,y:0,z:0});if(typeof props.rotationOffset=="number")rotationOffset.z=Number(props.rotationOffset);else if(typeof props.rotationOffset=="object"){let parsed=rotation3.parse(props.rotationOffset);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,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:parent._parsedProps.showAsTranslucentModel,...urlProps});this.cad_component_id=cad.cad_component_id}_findParentWithPcbComponent(){let p2=this.parent;for(;p2&&!p2.pcb_component_id;)p2=p2.parent;return p2}_addCachebustToModelUrl(url){if(!url)return url;let baseUrl=this.root?.platform?.projectBaseUrl,transformedUrl=constructAssetUrl(url,baseUrl);if(!transformedUrl.includes("modelcdn.tscircuit.com"))return transformedUrl;let origin=this.root?.getClientOrigin()??"";return`${transformedUrl}${transformedUrl.includes("?")?"&":"?"}cachebust_origin=${encodeURIComponent(origin)}`}},CadAssembly=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isPrimitiveContainer",!0)}get config(){return{componentName:"CadAssembly",zodProps:cadassemblyProps}}},getNumericSchPinStyle=(pinStyles,pinLabels)=>{if(!pinStyles)return;let numericPinStyles={};for(let[pinNameOrLabel,pinStyle]of Object.entries(pinStyles)){let pinNumber=parsePinNumberFromLabelsOrThrow(pinNameOrLabel,pinLabels),pinStyleWithSideFirst={leftMargin:pinStyle.marginLeft??pinStyle.leftMargin,rightMargin:pinStyle.marginRight??pinStyle.rightMargin,topMargin:pinStyle.marginTop??pinStyle.topMargin,bottomMargin:pinStyle.marginBottom??pinStyle.bottomMargin};numericPinStyles[`pin${pinNumber}`]={...numericPinStyles[`pin${pinNumber}`],...pinStyleWithSideFirst}}return numericPinStyles},DirectLineRouter=class{constructor({input:input2}){__publicField(this,"input");this.input=input2}solveAndMapToTraces(){let traces=[];for(let connection of this.input.connections){if(connection.pointsToConnect.length!==2)continue;let[start,end]=connection.pointsToConnect,trace={type:"pcb_trace",pcb_trace_id:"",connection_name:connection.name,route:[{route_type:"wire",x:start.x,y:start.y,layer:"top",width:.1},{route_type:"wire",x:end.x,y:end.y,layer:"top",width:.1}]};traces.push(trace)}return traces}},computeObstacleBounds=obstacles=>{let minX=Math.min(...obstacles.map(o4=>o4.center.x)),maxX=Math.max(...obstacles.map(o4=>o4.center.x)),minY=Math.min(...obstacles.map(o4=>o4.center.y)),maxY=Math.max(...obstacles.map(o4=>o4.center.y));return{minX,maxX,minY,maxY}},LAYER_SELECTION_PREFERENCE=["top","bottom","inner1","inner2"],findPossibleTraceLayerCombinations=(hints,layer_path=[])=>{let candidates=[];if(layer_path.length===0){let starting_layers=hints[0].layers;for(let layer of starting_layers)candidates.push(...findPossibleTraceLayerCombinations(hints.slice(1),[layer]));return candidates}if(hints.length===0)return[];let current_hint=hints[0],is_possibly_via=current_hint.via||current_hint.optional_via,last_layer=layer_path[layer_path.length-1];if(hints.length===1){let last_hint=current_hint;return last_hint.layers&&is_possibly_via?last_hint.layers.map(layer=>({layer_path:[...layer_path,layer]})):last_hint.layers?.includes(last_layer)?[{layer_path:[...layer_path,last_layer]}]:[]}if(!is_possibly_via)return current_hint.layers&&!current_hint.layers.includes(last_layer)?[]:findPossibleTraceLayerCombinations(hints.slice(1),layer_path.concat([last_layer]));let candidate_next_layers=(current_hint.optional_via?LAYER_SELECTION_PREFERENCE:LAYER_SELECTION_PREFERENCE.filter(layer=>layer!==last_layer)).filter(layer=>!current_hint.layers||current_hint.layers?.includes(layer));for(let candidate_next_layer of candidate_next_layers)candidates.push(...findPossibleTraceLayerCombinations(hints.slice(1),layer_path.concat(candidate_next_layer)));return candidates};function getDominantDirection(edge){let delta={x:edge.to.x-edge.from.x,y:edge.to.y-edge.from.y},absX=Math.abs(delta.x),absY=Math.abs(delta.y);return absX>absY?delta.x>0?"right":"left":delta.y>0?"down":"up"}function pdist(a2,b3){return Math.hypot(a2.x-b3.x,a2.y-b3.y)}var mergeRoutes=routes=>{if(routes.length===1)return routes[0];if(routes.some(r4=>r4.length===0))throw new Error("Cannot merge routes with zero length");let merged=[],first_route_fp=routes[0][0],first_route_lp=routes[0][routes[0].length-1],second_route_fp=routes[1][0],second_route_lp=routes[1][routes[1].length-1],best_reverse_dist=Math.min(pdist(first_route_fp,second_route_fp),pdist(first_route_fp,second_route_lp)),best_normal_dist=Math.min(pdist(first_route_lp,second_route_fp),pdist(first_route_lp,second_route_lp));best_reverse_dist<best_normal_dist?merged.push(...routes[0].reverse()):merged.push(...routes[0]);for(let i3=1;i3<routes.length;i3++){let last_merged_point=merged[merged.length-1],next_route=routes[i3],next_first_point=next_route[0],next_last_point=next_route[next_route.length-1],distance_to_first=pdist(last_merged_point,next_first_point),distance_to_last=pdist(last_merged_point,next_last_point);distance_to_first<distance_to_last?merged.push(...next_route):merged.push(...next_route.reverse())}for(let i3=1;i3<merged.length-1;i3++){let lastPoint=merged[i3-1],currentPoint=merged[i3];lastPoint.route_type==="wire"&¤tPoint.route_type==="wire"&&lastPoint.layer!==currentPoint.layer&&merged.splice(i3,0,{x:lastPoint.x,y:lastPoint.y,from_layer:lastPoint.layer,to_layer:currentPoint.layer,route_type:"via"})}return merged},getDistance=(a2,b3)=>{let aPos="_getGlobalPcbPositionBeforeLayout"in a2?a2._getGlobalPcbPositionBeforeLayout():a2,bPos="_getGlobalPcbPositionBeforeLayout"in b3?b3._getGlobalPcbPositionBeforeLayout():b3;return Math.sqrt((aPos.x-bPos.x)**2+(aPos.y-bPos.y)**2)};function getClosest(point23,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=getDistance(point23,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(e4=>({from:e4.to,to:e4.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(e4=>distance4(e4.from,e4.to)>.01),edges};function tryNow(fn3){try{return[fn3(),null]}catch(e4){return[null,e4]}}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 isRouteOutsideBoard=(mergedRoute,{db:db2})=>{let pcbBoard=db2.pcb_board.list()[0];if(pcbBoard.outline){let boardOutline=pcbBoard.outline,isInsidePolygon=(point23,polygon2)=>{let inside2=!1;for(let i3=0,j3=polygon2.length-1;i3<polygon2.length;j3=i3++){let xi3=polygon2[i3].x,yi3=polygon2[i3].y,xj=polygon2[j3].x,yj=polygon2[j3].y;yi3>point23.y!=yj>point23.y&&point23.x<(xj-xi3)*(point23.y-yi3)/(yj-yi3)+xi3&&(inside2=!inside2)}return inside2};return mergedRoute.some(point23=>!isInsidePolygon(point23,boardOutline))}let boardWidth=pcbBoard.width,boardHeight=pcbBoard.height,boardCenterX=pcbBoard.center.x,boardCenterY=pcbBoard.center.y;return mergedRoute.some(point23=>point23.x<boardCenterX-boardWidth/2||point23.y<boardCenterY-boardHeight/2||point23.x>boardCenterX+boardWidth/2||point23.y>boardCenterY+boardHeight/2)},isCloseTo2=(a2,b3)=>Math.abs(a2-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 generateApproximatingRects2(rotatedRect,numRects=2){let{center:center2,width,height,rotation:rotation4}=rotatedRect,rects=[],angleRad=rotation4*Math.PI/180,cosAngle=Math.cos(angleRad),sinAngle=Math.sin(angleRad),normalizedRotation=(rotation4%360+360)%360;if(height<=width?normalizedRotation>=45&&normalizedRotation<135||normalizedRotation>=225&&normalizedRotation<315:normalizedRotation>=135&&normalizedRotation<225||normalizedRotation>=315||normalizedRotation<45){let sliceWidth=width/numRects;for(let i3=0;i3<numRects;i3++){let x3=(i3-numRects/2+.5)*sliceWidth,rotatedX=-x3*cosAngle,rotatedY=-x3*sinAngle,coverageWidth=sliceWidth*1.1,coverageHeight=Math.abs(height*cosAngle)+Math.abs(sliceWidth*sinAngle);rects.push({center:{x:center2.x+rotatedX,y:center2.y+rotatedY},width:coverageWidth,height:coverageHeight})}}else{let sliceHeight=height/numRects;for(let i3=0;i3<numRects;i3++){let y3=(i3-numRects/2+.5)*sliceHeight,rotatedX=-y3*sinAngle,rotatedY=y3*cosAngle,coverageWidth=Math.abs(width*cosAngle)+Math.abs(sliceHeight*sinAngle),coverageHeight=sliceHeight*1.1;rects.push({center:{x:center2.x+rotatedX,y:center2.y+rotatedY},width:coverageWidth,height:coverageHeight})}}return rects}function fillPolygonWithRects(polygon2,options={}){if(polygon2.length<3)return[];let{rectHeight=.1}=options,rects=[],yCoords=polygon2.map(p2=>p2.y),minY=Math.min(...yCoords),maxY=Math.max(...yCoords);for(let y3=minY;y3<maxY;y3+=rectHeight){let scanlineY=y3+rectHeight/2,intersections=[];for(let i3=0;i3<polygon2.length;i3++){let p12=polygon2[i3],p2=polygon2[(i3+1)%polygon2.length];if(p12.y<=scanlineY&&p2.y>scanlineY||p2.y<=scanlineY&&p12.y>scanlineY){let x3=(scanlineY-p12.y)*(p2.x-p12.x)/(p2.y-p12.y)+p12.x;intersections.push(x3)}}intersections.sort((a2,b3)=>a2-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 y3=center2.y-radius+(i3+.5)*rectHeight,dy2=y3-center2.y,halfWidth=Math.sqrt(radius*radius-dy2*dy2);halfWidth>0&&rects.push({center:{x:center2.x,y:y3},width:halfWidth*2,height:rectHeight})}return rects}var EVERY_LAYER2=["top","inner1","inner2","bottom"],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},approximatingRects=generateApproximatingRects2(rotatedRect);for(let rect of approximatingRects)obstacles.push({type:"rect",layers:[element.layer],center:rect.center,width:rect.width,height:rect.height,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==="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"||element.shape==="pill")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==="hole_with_polygon_pad"&&"pad_outline"in element&&element.pad_outline&&element.pad_outline.length>0){let xs3=element.pad_outline.map(p2=>element.x+p2.x),ys3=element.pad_outline.map(p2=>element.y+p2.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(rp2=>({x:rp2.x,y:rp2.y,layer:"layer"in rp2?rp2.layer:rp2.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:[],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(doesLineIntersectLine2([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:distance4(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=getUnitVectorFromPointAToB2(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=distance4(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=(point23,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 point23.x>=minX&&point23.x<=maxX&&point23.y>=minY&&point23.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,m3=(diagonalEdge.to.y-diagonalEdge.from.y)/(diagonalEdge.to.x-diagonalEdge.from.x),b3=diagonalEdge.from.y-m3*diagonalEdge.from.x,y22=m3*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 x3=(b22-b12)/(m12-m22),y3=m12*x3+b12,intersection={x:x3,y:y3};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(t5=>t5.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 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(p2=>p2.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?getUnitVectorFromDirection2(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(t5=>t5.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&&doesLineIntersectLine2([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),this.errorData=errorData,this.name="TraceConnectionError"}},Trace_doInitialSchematicTraceRender=trace=>{if(trace.root?._featureMspSchematicTraceRouting||trace._couldNotFindPort||trace.root?.schematicDisabled)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(error){if(error instanceof TraceConnectionError){db2.source_trace_not_connected_error.insert({...error.errorData,error_type:"source_trace_not_connected_error"});return}throw error}let{netsWithSelectors}=trace._findConnectedNets();if(!allPortsFound)return;let portPairKey=connectedPorts.map(p2=>p2.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(nl2=>{let conn=nl2._parsedProps.connection??nl2._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 j3=0;j3<path.length-1;j3++)elbowEdges.push({from:path[j3],to:path[j3+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=p2=>p2.x>=left&&p2.x<=right&&p2.y>=top&&p2.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(r4=>doesLineIntersectLine2([edge.from,edge.to],r4,{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:position2})=>({...position2,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(r4=>r4.route_type==="wire"||r4.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(t5=>t5.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 point23=route[i3];if(point23.route_type==="wire"){let nextPoint=route[i3+1];if(nextPoint){let dx2=nextPoint.x-point23.x,dy2=nextPoint.y-point23.y;totalLength+=Math.sqrt(dx2*dx2+dy2*dy2)}}else point23.route_type==="via"&&(totalLength+=1.6)}return totalLength}var DEFAULT_VIA_HOLE_DIAMETER=.3,DEFAULT_VIA_PAD_DIAMETER=.6,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}},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)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}=trace._findConnectedPorts(),portsConnectedOnPcbViaNet=[];if(!allPortsFound)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(p2=>p2.getString()).join(", ")}`,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:portsWithoutMatchedPcbPrimitive.map(p2=>p2.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(p2=>p2!==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(c3=>c3.componentName==="TraceHint")),pcbRouteHints=(trace._parsedProps.pcbRouteHints??[]).concat(hints.flatMap(h2=>h2.getPcbRouteHints()));if(ports.length>2){trace.renderError(`Trace has more than two ports (${ports.map(p2=>p2.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(p2=>p2.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((t5,idx)=>t5.via?{...t5,via_to_layer:candidateLayerSelections[idx]}:{...t5,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[a2,b3]of pairs2(orderedRoutePoints)){let dominantLayer="via_to_layer"in a2?a2.via_to_layer:null,BOUNDS_MARGIN=2,aLayer="layers"in a2&&a2.layers.length===1?a2.layers[0]:dominantLayer??"top",bLayer="layers"in b3&&b3.layers.length===1?b3.layers[0]:dominantLayer??"top",pcbPortA="pcb_port_id"in a2?a2.pcb_port_id:null,pcbPortB="pcb_port_id"in b3?b3.pcb_port_id:null,minTraceWidth=trace._getExplicitTraceThickness()??trace.getSubcircuit()._parsedProps.minTraceWidth??.16,ijump=new MultilayerIjump({OBSTACLE_MARGIN:minTraceWidth*2,isRemovePathLoopsEnabled:!0,optimizeWithGoalBoxes:!!(pcbPortA&&pcbPortB),connMap,input:{obstacles,minTraceWidth,connections:[{name:trace.source_trace_id,pointsToConnect:[{...a2,layer:aLayer,pcb_port_id:pcbPortA},{...b3,layer:bLayer,pcb_port_id:pcbPortB}]}],layerCount:trace.getSubcircuit()._getSubcircuitLayerCount(),bounds:{minX:Math.min(a2.x,b3.x)-BOUNDS_MARGIN,maxX:Math.max(a2.x,b3.x)+BOUNDS_MARGIN,minY:Math.min(a2.y,b3.y)-BOUNDS_MARGIN,maxY:Math.max(a2.y,b3.y)+BOUNDS_MARGIN}}}),traces=null;try{traces=ijump.solveAndMapToTraces()}catch(e4){trace.renderError({type:"pcb_trace_error",pcb_trace_error_id:trace.source_trace_id,error_type:"pcb_trace_error",message:`error solving route: ${e4.message}`,source_trace_id:trace.pcb_trace_id,center:{x:(a2.x+b3.x)/2,y:(a2.y+b3.y)/2},pcb_port_ids:ports.map(p2=>p2.pcb_port_id),pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:ports.map(p2=>p2.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:(a2.x+b3.x)/2,y:(a2.y+b3.y)/2},pcb_port_ids:ports.map(p2=>p2.pcb_port_id),pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:ports.map(p2=>p2.pcb_component_id)});return}let[autoroutedTrace]=traces;dominantLayer&&(autoroutedTrace.route=autoroutedTrace.route.map(p2=>(p2.route_type==="wire"&&!p2.layer&&(p2.layer=dominantLayer),p2))),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_trace2=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_trace2.pcb_trace_id;for(let point23 of mergedRoute)point23.route_type==="via"&&db2.pcb_via.insert({pcb_trace_id:pcb_trace2.pcb_trace_id,x:point23.x,y:point23.y,hole_diameter:holeDiameter,outer_diameter:padDiameter,layers:[point23.from_layer,point23.to_layer],from_layer:point23.from_layer,to_layer:point23.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,dx2=lineEnd.x-lineStart.x,dy2=lineEnd.y-lineStart.y,intersections=[];if(dx2!==0){let t5=(left-lineStart.x)/dx2;if(t5>=0&&t5<=1){let y3=lineStart.y+t5*dy2;y3>=bottom&&y3<=top&&intersections.push({x:left,y:y3,t:t5})}}if(dx2!==0){let t5=(right-lineStart.x)/dx2;if(t5>=0&&t5<=1){let y3=lineStart.y+t5*dy2;y3>=bottom&&y3<=top&&intersections.push({x:right,y:y3,t:t5})}}if(dy2!==0){let t5=(bottom-lineStart.y)/dy2;if(t5>=0&&t5<=1){let x3=lineStart.x+t5*dx2;x3>=left&&x3<=right&&intersections.push({x:x3,y:bottom,t:t5})}}if(dy2!==0){let t5=(top-lineStart.y)/dy2;if(t5>=0&&t5<=1){let x3=lineStart.x+t5*dx2;x3>=left&&x3<=right&&intersections.push({x:x3,y:top,t:t5})}}return intersections.length===0?null:(intersections.sort((a2,b3)=>a2.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,dx2=x22-x12,dy2=y22-y12,a2=dx2*dx2+dy2*dy2,b3=2*(x12*dx2+y12*dy2),c3=x12*x12+y12*y12-circleRadius*circleRadius,discriminant=b3*b3-4*a2*c3;if(discriminant<0)return null;let sqrtDisc=Math.sqrt(discriminant),t12=(-b3-sqrtDisc)/(2*a2),t22=(-b3+sqrtDisc)/(2*a2),t5=null;return t12>=0&&t12<=1?t5=t12:t22>=0&&t22<=1&&(t5=t22),t5===null?null:{x:lineStart.x+t5*dx2,y:lineStart.y+t5*dy2}}function clipTraceEndAtPad(params){let{traceStart,traceEnd,traceWidth,port}=params,pcbPrimitive=port.matchedComponents.find(c3=>c3.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}=trace._findConnectedPorts();if(!allPortsFound)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(p2=>p2.getString()).join(", ")}`,pcb_trace_id:trace.pcb_trace_id,pcb_component_ids:[],pcb_port_ids:portsWithoutMatchedPcbPrimitive.map(p2=>p2.pcb_port_id).filter(Boolean)});return}let width=trace._getExplicitTraceThickness()??trace.getSubcircuit()._parsedProps.minTraceWidth??.16;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(p2=>p2.selector===props.pcbPathRelativeTo)?.port,anchorPort||(anchorPort=trace.getSubcircuit().selectOne(props.pcbPathRelativeTo))),anchorPort||(anchorPort=ports[0]);let otherPort=ports.find(p2=>p2!==anchorPort)??ports[1],layer=anchorPort.getAvailablePcbLayers()[0]||"top",anchorPos=anchorPort._getGlobalPcbPositionAfterLayout(),otherPos=otherPort._getGlobalPcbPositionAfterLayout(),route=[];route.push({route_type:"wire",x:anchorPos.x,y:anchorPos.y,width,layer,start_pcb_port_id:anchorPort.pcb_port_id});let transform5=anchorPort?._computePcbGlobalTransformBeforeLayout?.()||identity();for(let pt3 of props.pcbPath){let coordinates,isGlobalPosition=!1;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 portPos=resolvedPort._getGlobalPcbPositionAfterLayout();coordinates={x:portPos.x,y:portPos.y},isGlobalPosition=!0}else coordinates={x:pt3.x,y:pt3.y},isGlobalPosition=!1;let finalCoordinates=isGlobalPosition?coordinates:applyToPoint(transform5,coordinates);route.push({route_type:"wire",x:finalCoordinates.x,y:finalCoordinates.y,width,layer})}route.push({route_type:"wire",x:otherPos.x,y:otherPos.y,width,layer,end_pcb_port_id:otherPort.pcb_port_id});let traceLength=getTraceLength(route),pcb_trace2=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});trace._portsRoutedOnPcb=ports,trace.pcb_trace_id=pcb_trace2.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 portsWithSelectors=trace.getTracePortPathSelectors().map(selector=>({selector,port:trace.getSubcircuit().selectOne(selector,{type:"port"})??null}));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(c3=>c3.componentName==="Port"),portLabel=portToken.includes(".")?portToken.split(".").pop()??"":portToken,portNames=ports.flatMap(c3=>c3.getNameAndAliases()),hasCustomLabels=portNames.some(n3=>!/^(pin\d+|\d+)$/.test(n3)),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(p2=>!p2.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(p2=>typeof p2=="string"?p2:p2.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(d3=>d3.componentName==="Net"&&d3._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(n3=>!n3.net);return undefinedNets.length>0&&this.renderError(`Could not find net for selector "${undefinedNets[0].selector}" inside ${this}`),{netsWithSelectors,nets:netsWithSelectors.map(n3=>n3.net)}}_getAllTracesConnectedToSameNet(){let traces=this.getSubcircuit().selectAll("trace"),myNets=this._findConnectedNets().nets,myPorts=this._findConnectedPorts().ports??[];return traces.filter(t5=>{if(t5===this)return!1;let tNets=t5._findConnectedNets().nets,tPorts=t5._findConnectedPorts().ports??[];return tNets.some(n3=>myNets.includes(n3))||tPorts.some(p2=>myPorts.includes(p2))})}_isExplicitlyConnectedToPort(port){let{allPortsFound,portsWithSelectors:portsWithMetadata}=this._findConnectedPorts();return allPortsFound?portsWithMetadata.map(p2=>p2.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((a2,b3)=>(a2.pcb_port_id||"").localeCompare(b3.pcb_port_id||"")).map(p2=>p2.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(error){if(error instanceof TraceConnectionError){db2.source_trace_not_connected_error.insert({...error.errorData,error_type:"source_trace_not_connected_error"}),this._couldNotFindPort=!0;return}throw error}if(!allPortsFound)return;this._traceConnectionHash=this._computeTraceConnectionHash();let existingTrace=db2.source_trace.list().find(t5=>t5.subcircuit_connectivity_map_key===this.subcircuit_connectivity_map_key&&t5.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(p2=>p2.port.source_port_id),connected_source_net_ids:nets.map(n3=>n3.source_net_id),subcircuit_id:this.getSubcircuit()?.subcircuit_id,max_length:getMaxLengthFromConnectedCapacitors(ports.map(p2=>p2.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;isRouteOutsideBoard(mergedRoute,{db:db2})&&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(p2=>p2.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)}},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,position2)=>{let{db:db2}=component.root,allCircuitJson=db2.toArray();if(component.pcb_component_id){repositionPcbComponentTo(allCircuitJson,component.pcb_component_id,position2);return}if(component.source_group_id){repositionPcbGroupTo(allCircuitJson,component.source_group_id,position2);return}throw new Error(`Cannot reposition component ${component.getString()}: no pcb_component_id or source_group_id`)},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(p2=>p2.source_port_id&&connected.has(p2.source_port_id)))for(let p2 of group)p2.source_port_id&&connected.add(p2.source_port_id);for(let port of ports)port.source_port_id&&shouldCheckPortForMissingTrace(component,port)&&(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};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 getBoundingBox2(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=getBoundingBox2(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=getBoundingBox2(flippedTextBox);obstacleBounds.some(obstacle=>doBoundsOverlap(flippedTextBounds,obstacle))||db2.pcb_silkscreen_text.update(silkscreenText.pcb_silkscreen_text_id,{anchor_position:{x:flippedX,y:flippedY}})}}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. Please use a valid pin label.`);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 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("/"),resolveStaticFileImportDebug=(0,import_debug9.default)("tscircuit:core:resolveStaticFileImport");async function resolveStaticFileImport(path,platform){if(!path)return path;let resolver=platform?.resolveProjectStaticFileImportUrl;if(resolver&&path.startsWith("/"))try{let resolved=await resolver(path);if(resolved)return resolved}catch(error){resolveStaticFileImportDebug("failed to resolve static file via platform resolver",error)}return constructAssetUrl(path,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 url=footprint;queueAsyncEffect("load-footprint-url",async()=>{try{let res2=await fetch(url);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:url,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 "${url}": `+(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:url});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;let resolvedPcbStyle=component.getInheritedMergedProperty("pcbStyle");queueAsyncEffect("load-lib-footprint",async()=>{try{let result=await resolverFn(libRef.footprintName,{resolvedPcbStyle}),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);component.addAll(fpComponents),!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 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 debug32=(0,import_debug5.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,"isPrimitiveContainer",!0);__publicField(this,"_isNormalComponent",!0);__publicField(this,"_attributeLowerToCamelNameMap",{_isnormalcomponent:"_isNormalComponent"});__publicField(this,"_asyncSupplierPartNumbers");__publicField(this,"_asyncFootprintCadModel");__publicField(this,"_isCadModelChild");__publicField(this,"pcb_missing_footprint_error_id");__publicField(this,"_hasStartedFootprintUrlLoad",!1);__publicField(this,"_invalidPinLabelMessages",[]);__publicField(this,"_adjustSilkscreenTextAutomatically",!1);this._invalidPinLabelMessages=invalidPinLabelsMessages,this._addChildrenFromStringFootprint(),this.initPorts()}get defaultInternallyConnectedPinNames(){return[]}get internallyConnectedPinNames(){return(this._parsedProps.internallyConnectedPins??this.defaultInternallyConnectedPinNames).map(pinGroup=>pinGroup.map(pin=>typeof pin=="number"?`pin${pin}`:pin))}doInitialSourceNameDuplicateComponentRemoval(){if(!this.name)return;let root=this.root;if(this.getSubcircuit().selectAll(`.${this.name}`).filter(component=>component!==this&&component._isNormalComponent&&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;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 size2=schPortArrangement[`${side}Size`];for(let i3=0;i3<size2;i3++)portsToCreate.push(new Port({pinNumber:pinNum++,aliases:opts.additionalAliases?.[`pin${pinNum}`]??[]},{originDescription:`schPortArrangement:${side}`}))}}let pinLabels=this._parsedProps.pinLabels;if(pinLabels)for(let[pinNumber,label]of Object.entries(pinLabels)){pinNumber=pinNumber.replace("pin","");let existingPort=portsToCreate.find(p2=>p2._parsedProps.pinNumber===Number(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:parseInt(pinNumber),name:primaryLabel,aliases:[...otherLabels,...opts.additionalAliases?.[`pin${parseInt(pinNumber)}`]??[]]},{originDescription:`pinLabels:pin${pinNumber}`}),portsToCreate.push(existingPort))}if(config.schematicSymbolName&&!opts.ignoreSymbolPorts){let sym=cf[this._getSchematicSymbolNameOrThrow()];if(!sym)return;for(let symPort of sym.ports){let pinNumber=getPinNumberFromLabels(symPort.labels);if(!pinNumber)continue;let existingPort=portsToCreate.find(p2=>p2._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 portsFromFootprint=this.getPortsFromFootprint(opts);for(let port of portsFromFootprint)portsToCreate.some(p2=>p2.isMatchingAnyOf(port.getNameAndAliases()))||portsToCreate.push(port)}let requiredPinCount=opts.pinCount??this._getPinCount()??0;for(let pn3=1;pn3<=requiredPinCount;pn3++){if(portsToCreate.find(p2=>p2._parsedProps.pinNumber===pn3))continue;if(!schPortArrangement){portsToCreate.push(new Port({pinNumber:pn3,aliases:opts.additionalAliases?.[`pin${pn3}`]??[]}));continue}let explicitlyListedPinNumbersInSchPortArrangement=[...schPortArrangement.leftSide?.pins??[],...schPortArrangement.rightSide?.pins??[],...schPortArrangement.topSide?.pins??[],...schPortArrangement.bottomSide?.pins??[]].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._getPinCount()},(_4,i3)=>i3+1)),explicitlyListedPinNumbersInSchPortArrangement.includes(pn3)&&portsToCreate.push(new Port({pinNumber:pn3,aliases:opts.additionalAliases?.[`pin${pn3}`]??[]},{originDescription:`notOtherwiseAddedButDeducedFromPinCount:${pn3}`}))}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 fpSoup=fp.string(footprint).soup(),fpComponents=createComponentsFromCircuitJson({componentName:this.name??this.componentName,componentRotation:pcbRotation,footprinterString:footprint,pinLabels,pcbPinLabels},fpSoup);this.addAll(fpComponents)}}get portMap(){return new Proxy({},{get:(target,prop)=>{let port=this.children.find(c3=>c3.componentName==="Port"&&c3.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});this.source_component_id=source_component.source_component_id}doInitialSchematicComponentRender(){if(this.root?.schematicDisabled)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"})}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=cf[symbol_name],center2=this._getGlobalSchematicPositionBeforeLayout();if(symbol){let schematic_component2=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_component2.schematic_component_id}}_doInitialSchematicComponentRenderWithReactSymbol(symbolElement){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,center2=this._getGlobalSchematicPositionBeforeLayout(),schematic_component2=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_component2.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_component2=db2.schematic_component.insert({center:center2,rotation:props.schRotation??0,size:dimensions.getSize(),port_arrangement:underscorifyPortArrangement(schPortArrangement),pin_spacing:props.schPinSpacing??.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_component2.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.name??"",schematic_component_id:schematic_component2.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_component2.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 error=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(error)}let globalTransform=this._computePcbGlobalTransformBeforeLayout(),accumulatedRotation=decomposeTSR(globalTransform).rotation.angle*180/Math.PI,pcb_component2=db2.pcb_component.insert({center:this._getGlobalPcbPositionBeforeLayout(),width:0,height:0,layer:componentLayer==="top"||componentLayer==="bottom"?componentLayer:"top",rotation:props.pcbRotation??accumulatedRotation,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});if(!(props.footprint??this._getImpliedFootprintString())&&!this.isGroup){let footprint_error=db2.pcb_missing_footprint_error.insert({message:`No footprint found 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_component2.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,{_parsedProps:props}=this,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)}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()}doInitialReactSubtreesRender(){let fpElm=this.props.footprint;(0,import_react2.isValidElement)(fpElm)&&(this.children.some(c3=>c3.componentName==="Footprint")||this.add(fpElm));let symElm=this.props.symbol;(0,import_react2.isValidElement)(symElm)&&(this.children.some(c3=>c3.componentName==="Symbol")||this.add(symElm));let cmElm=this.props.cadModel;if((0,import_react2.isValidElement)(cmElm)){this._isCadModelChild=!0;let hasCadAssemblyChild=this.children.some(c3=>c3.componentName==="CadAssembly"),hasCadModelChild=this.children.some(c3=>c3.componentName==="CadModel");!hasCadAssemblyChild&&!hasCadModelChild&&this.add(cmElm)}}doInitialPcbFootprintStringRender(){NormalComponent_doInitialPcbFootprintStringRender(this,(name,effect)=>this._queueAsyncEffect(name,effect))}_hasExistingPortExactly(port1){return this.children.filter(c3=>c3.componentName==="Port").some(port2=>{let aliases1=port1.getNameAndAliases(),aliases2=port2.getNameAndAliases();return aliases1.length===aliases2.length&&aliases1.every(alias=>aliases2.includes(alias))})}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;let conflictingPort=this.children.filter(c3=>c3.componentName==="Port").find(p2=>p2.isMatchingAnyOf(component.getNameAndAliases()));conflictingPort&&debug32(`Similar ports added. Port 1: ${conflictingPort}, Port 2: ${component}`)}super.add(component)}getPortsFromFootprint(opts){let{footprint}=this.props;if((!footprint||(0,import_react2.isValidElement)(footprint))&&(footprint=this.children.find(c3=>c3.componentName==="Footprint")),typeof footprint=="string"){if(isHttpUrl(footprint))return[];if(isStaticAssetPath(footprint))return[];if(parseLibraryFootprintRef(footprint))return[];let fpSoup=fp.string(footprint).soup(),newPorts2=[];for(let elm of fpSoup)if("port_hints"in elm&&elm.port_hints){let newPort=getPortFromHints(elm.port_hints,opts);if(!newPort)continue;newPort.originDescription=`footprint:string:${footprint}:port_hints[0]:${elm.port_hints[0]}`,newPorts2.push(newPort)}return newPorts2}if(!(0,import_react2.isValidElement)(footprint)&&footprint&&footprint.componentName==="Footprint"){let fp22=footprint,pinNumber=1,newPorts2=[];for(let fpChild of fp22.children){if(!fpChild.props.portHints)continue;let portHintsList=fpChild.props.portHints;portHintsList.some(hint=>hint.startsWith("pin"))||(portHintsList=[...portHintsList,`pin${pinNumber}`]),pinNumber++;let newPort=getPortFromHints(portHintsList);newPort&&(newPort.originDescription=`footprint:${footprint}`,newPorts2.push(newPort))}return newPorts2}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}getPortsFromSchematicSymbol(){if(this.root?.schematicDisabled)return[];let{config}=this;if(!config.schematicSymbolName)return[];let symbol=cf[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_component2=db2.pcb_component.get(this.pcb_component_id);return{center:{x:pcb_component2.center.x,y:pcb_component2.center.y},bounds:{left:pcb_component2.center.x-pcb_component2.width/2,top:pcb_component2.center.y-pcb_component2.height/2,right:pcb_component2.center.x+pcb_component2.width/2,bottom:pcb_component2.center.y+pcb_component2.height/2},width:pcb_component2.width,height:pcb_component2.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??[])}_getPinCount(){if(this._getSchematicPortArrangement())return this._getPinCountFromSchematicPortArrangement();let portsFromFootprint=this.getPortsFromFootprint();if(portsFromFootprint.length>0)return portsFromFootprint.length;let{pinLabels}=this._parsedProps;if(pinLabels){if(Array.isArray(pinLabels))return pinLabels.length;let pinNumbers=Object.keys(pinLabels).map(k4=>k4.startsWith("pin")?parseInt(k4.slice(3)):parseInt(k4)).filter(n3=>!Number.isNaN(n3));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)return null;let{_parsedProps:props}=this,pinCount=this._getPinCount(),pinSpacing=props.schPinSpacing??.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.root?._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 rotationOffset=rotation32.parse({x:0,y:0,z:typeof cadModel?.rotationOffset=="number"?cadModel.rotationOffset:0,...typeof cadModel?.rotationOffset=="object"?cadModel.rotationOffset??{}:{}}),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",globalTransform=this._computePcbGlobalTransformBeforeLayout(),totalRotation=decomposeTSR(globalTransform).rotation.angle*180/Math.PI,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,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(url){if(!url||!url.includes("modelcdn.tscircuit.com"))return url;let origin=this.root?.getClientOrigin()??"";return`${url}${url.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"))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(error=>{this._asyncSupplierPartNumbers={};let errorObj=unknown_error_finding_part.parse({type:"unknown_error_finding_part",message:`Failed to fetch supplier part numbers for ${this.getString()}: ${error.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"))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}}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)}doInitialPcbLayout(){if(this.root?.pcbDisabled||!this.pcb_component_id)return;let{db:db2}=this.root,props=this._parsedProps;if(!(props.pcbX!==void 0||props.pcbY!==void 0))return;let sourceComponent=db2.source_component.get(this.source_component_id),positionedRelativeToGroupId=sourceComponent?.source_group_id?db2.pcb_group.getWhere({source_group_id:sourceComponent.source_group_id})?.pcb_group_id:void 0,positionedRelativeToBoardId=positionedRelativeToGroupId?void 0:this._getBoard()?.pcb_board_id??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:props.pcbX,display_offset_y:props.pcbY})}_getMinimumFlexContainerSize(){return NormalComponent__getMinimumFlexContainerSize(this)}_repositionOnPcb(position2){return NormalComponent__repositionOnPcb(this,position2)}doInitialSilkscreenOverlapAdjustment(){return NormalComponent_doInitialSilkscreenOverlapAdjustment(this)}isRelativelyPositioned(){return this._parsedProps.pcbX!==void 0||this._parsedProps.pcbY!==void 0}},getBoardCenterFromAnchor=({boardAnchorPosition,boardAnchorAlignment,width,height})=>{let{x:ax2,y:ay2}=boardAnchorPosition,cx2=ax2,cy2=ay2;switch(boardAnchorAlignment){case"top_left":cx2=ax2+width/2,cy2=ay2-height/2;break;case"top_right":cx2=ax2-width/2,cy2=ay2-height/2;break;case"bottom_left":cx2=ax2+width/2,cy2=ay2+height/2;break;case"bottom_right":cx2=ax2-width/2,cy2=ay2+height/2;break;case"top":cx2=ax2,cy2=ay2-height/2;break;case"bottom":cx2=ax2,cy2=ay2+height/2;break;case"left":cx2=ax2+width/2,cy2=ay2;break;case"right":cx2=ax2-width/2,cy2=ay2;break;default:break}return{x:cx2,y:cy2}},SOLVERS={PackSolver2,AutoroutingPipelineSolver:Jo2,AssignableAutoroutingPipeline2:lr2,AssignableAutoroutingPipeline3:Ca2,AutoroutingPipeline1_OriginalUnravel:Li2,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":useAutoJumperSolver?solverName="AssignableAutoroutingPipeline3":useAssignableSolver?solverName="AssignableAutoroutingPipeline2":solverName="AutoroutingPipelineSolver";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())}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;)this.solver.step();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(error){this.emitEvent({type:"error",error:error instanceof Error?new AutorouterError(error.message):new AutorouterError(String(error))}),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():{}}},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=>({...applyToPoint(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()})}},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_component2=su2(circuitJson).pcb_component.get(pcb_component_id);if(!pcb_component2)continue;let source_component=su2(circuitJson).source_component.get(pcb_component2.source_component_id);if(!source_component)continue;let existingPlacementIndex=updatedManualEditsFile.pcb_placements?.findIndex(p2=>p2.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_component2=su2(circuitJson).schematic_component.get(schematic_component_id);if(!schematic_component2||!schematic_component2.source_component_id)continue;let source_component=su2(circuitJson).source_component.get(schematic_component2.source_component_id);if(!source_component)continue;let existingPlacementIndex=updatedManualEditsFile.schematic_placements?.findIndex(p2=>p2.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(e4=>e4.pcb_trace_hint_id===edit_event.pcb_trace_hint_id?{...e4,route:edit_event.route}:e4);else{let pcbPort=su2(circuitJson).pcb_port.get(edit_event.pcb_port_id);circuitJson=circuitJson.filter(e4=>!(e4.type==="pcb_trace_hint"&&e4.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(e4=>e4.type==="pcb_component"&&e4.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=translate(editEvent.new_center.x-editEvent.original_center.x,editEvent.new_center.y-editEvent.original_center.y);circuitJson=circuitJson.map(e4=>e4.pcb_component_id!==editEvent.pcb_component_id?e4:transformPCBElement(e4,mat))}}else editEvent.edit_event_type==="edit_schematic_component_location"?circuitJson=circuitJson.map(e4=>e4.type==="schematic_component"&&e4.schematic_component_id===editEvent.schematic_component_id?{...e4,center:editEvent.new_center}:e4):editEvent.edit_event_type==="edit_pcb_trace_hint"&&(circuitJson=applyTraceHintEditEvent(circuitJson,editEvent));return circuitJson},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},getSimpleRouteJsonFromCircuitJson=({db:db2,circuitJson,subcircuit_id,minTraceWidth=.1,nominalTraceWidth})=>{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(e4=>!subcircuit_id||"subcircuit_id"in e4&&relevantSubcircuitIds.has(e4.subcircuit_id)),board=null;if(subcircuit_id){let source_group_id=subcircuit_id.replace(/^subcircuit_/,""),source_board2=db2.source_board.getWhere({source_group_id});source_board2&&(board=db2.pcb_board.getWhere({source_board_id:source_board2.source_board_id}))}board||(board=db2.pcb_board.list()[0]),db2=su2(subcircuitElements);let 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(e4=>!subcircuit_id||relevantSubcircuitIds?.has(e4.subcircuit_id)),connMap);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 ic2 of internalConnections)for(let sourcePortId of ic2.source_port_ids)sourcePortIdToInternalConnectionId.set(sourcePortId,ic2.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(p2=>p2.x))-1,maxX:Math.max(...allPoints.map(p2=>p2.x))+1,minY:Math.min(...allPoints.map(p2=>p2.y))-1,maxY:Math.max(...allPoints.map(p2=>p2.y))+1},subcircuit_id){let group=db2.pcb_group.getWhere({subcircuit_id});if(group?.width&&group.height){let groupBounds={minX:group.center.x-group.width/2,maxX:group.center.x+group.width/2,minY:group.center.y-group.height/2,maxY:group.center.y+group.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(t5=>t5.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_port2=db2.source_port.get(id2),pcb_port2=db2.pcb_port.getWhere({source_port_id:id2});return{...source_port2,...pcb_port2}});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,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(c3=>c3!==null),directTraceConnectionsById=new Map(directTraceConnections.map(c3=>[c3.source_trace_id,c3])),source_nets=db2.source_net.list().filter(e4=>!subcircuit_id||relevantSubcircuitIds?.has(e4.subcircuit_id)),connectionsFromNets=[];for(let net of source_nets){let connectedSourceTraces=db2.source_trace.list().filter(st2=>st2.connected_source_net_ids?.includes(net.source_net_id));connectionsFromNets.push({name:net.source_net_id??connMap.getNetConnectedToId(net.source_net_id),pointsToConnect:connectedSourceTraces.flatMap(st2=>db2.pcb_port.list().filter(p2=>st2.connected_source_port_ids.includes(p2.source_port_id)).map(p2=>({x:p2.x,y:p2.y,layer:p2.layers?.[0]??"top",pointId:p2.pcb_port_id,pcb_port_id:p2.pcb_port_id})))})}let breakoutPoints=db2.pcb_breakout_point.list().filter(bp2=>!subcircuit_id||relevantSubcircuitIds?.has(bp2.subcircuit_id)),connectionsFromBreakoutPoints=[],breakoutTraceConnectionsById=new Map;for(let bp2 of breakoutPoints){let pt3={x:bp2.x,y:bp2.y,layer:"top"};if(bp2.source_trace_id){let conn=directTraceConnectionsById.get(bp2.source_trace_id)??breakoutTraceConnectionsById.get(bp2.source_trace_id);if(conn)conn.pointsToConnect.push(pt3);else{let newConn={name:bp2.source_trace_id,source_trace_id:bp2.source_trace_id,pointsToConnect:[pt3]};connectionsFromBreakoutPoints.push(newConn),breakoutTraceConnectionsById.set(bp2.source_trace_id,newConn)}}else if(bp2.source_net_id){let conn=connectionsFromNets.find(c3=>c3.name===bp2.source_net_id);conn?conn.pointsToConnect.push(pt3):connectionsFromBreakoutPoints.push({name:bp2.source_net_id,pointsToConnect:[pt3]})}else if(bp2.source_port_id){let pcb_port2=db2.pcb_port.getWhere({source_port_id:bp2.source_port_id});pcb_port2&&connectionsFromBreakoutPoints.push({name:bp2.source_port_id,source_trace_id:void 0,pointsToConnect:[{x:pcb_port2.x,y:pcb_port2.y,layer:pcb_port2.layers?.[0]??"top",pointId:pcb_port2.pcb_port_id,pcb_port_id:pcb_port2.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(t5=>!subcircuit_id||relevantSubcircuitIds?.has(t5.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,nominalTraceWidth,outline:board?.outline?.map(point23=>({...point23}))},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};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}var debug42=(0,import_debug11.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);debug42.enabled&&global?.debugGraphics&&global.debugGraphics?.push(getGraphicsForBpcGraph(bpcGraphBeforeGeneratedNetLabels,{title:`floatingBpcGraph-${group.name}`}));let floatingGraph=convertCircuitJsonToBpc(subtreeCircuitJson),floatingGraphNoNotConnected={boxes:floatingGraph.boxes,pins:floatingGraph.pins.map(p2=>({...p2,color:p2.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(p2=>p2.boxId===box2.boxId).filter(bp2=>!bp2.color.includes("center")).length<=2).map(b3=>b3.boxId)),corpus:{}});debug42.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_component2=db2.schematic_component.get(box2.boxId);if(schematic_component2){let newCenter={x:box2.center.x+groupOffset.x,y:box2.center.y+groupOffset.y},ports=db2.schematic_port.list({schematic_component_id:schematic_component2.schematic_component_id}),texts=db2.schematic_text.list({schematic_component_id:schematic_component2.schematic_component_id}),positionDelta={x:newCenter.x-schematic_component2.center.x,y:newCenter.y-schematic_component2.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_component2.schematic_component_id,deltaX:positionDelta.x,deltaY:positionDelta.y}),schematic_component2.center=newCenter;continue}let schematic_net_label2=db2.schematic_net_label.get(box2.boxId);if(schematic_net_label2){let pin=laidOutBpcGraph.pins.find(p2=>p2.boxId===box2.boxId&&p2.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_label2.center=finalCenter,schematic_net_label2.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 debug52=(0,import_debug12.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 convertTreeToInputProblem(tree,db2,group){let problem={chipMap:{},chipPinMap:{},netMap:{},pinStrongConnMap:{},netConnMap:{},chipGap:.6,decouplingCapsGap:.4,partitionGap:1.2};debug52(`[${group.name}] Processing ${tree.childNodes.length} child nodes for input problem`),tree.childNodes.forEach((child,index)=>{if(debug52(`[${group.name}] Processing child ${index}: nodeType=${child.nodeType}`),child.nodeType==="component"?debug52(`[${group.name}] - Component: ${child.sourceComponent?.name}`):child.nodeType==="group"&&debug52(`[${group.name}] - Group: ${child.sourceGroup?.name}`),child.nodeType==="component"&&child.sourceComponent){let chipId=child.sourceComponent.name||`chip_${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=child.sourceGroup.name||`group_${index}`;debug52(`[${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(debug52(`[${group.name}] Found schematic_group for ${groupId}:`,schematicGroup),schematicGroup){debug52(`[${group.name}] Treating group ${groupId} as composite chip`);let groupComponents=db2.schematic_component.list({schematic_group_id:schematicGroup.schematic_group_id});debug52(`[${group.name}] Group ${groupId} has ${groupComponents.length} components:`,groupComponents.map(c3=>c3.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;debug52(`[${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}}}debug52(`[${group.name}] Group ${groupId} has ${groupPins.length} pins:`,groupPins),problem.chipMap[groupId]={chipId:groupId,pins:groupPins,size:{x:groupWidth,y:groupHeight}},debug52(`[${group.name}] Added group ${groupId} to chipMap`)}else debug52(`[${group.name}] Warning: No schematic_group found for group ${groupId}`)}}),debug52(`[${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=>child.nodeType==="component"&&child.sourceComponent?child.sourceComponent.name===chipId:child.nodeType==="group"&&child.sourceGroup?`group_${tree.childNodes.indexOf(child)}`===chipId:!1);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),debug52(`[${group.name}] \u2713 Pin ${pinId} has connectivity key: ${connectivityKey}`)}else debug52(`[${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),debug52(`[${group.name}] Pin ${pinId} has connectivity key: ${connectivityKey}`)}}}}debug52(`[${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(debug52(`[${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=>child.nodeType==="component"&&child.sourceComponent?child.sourceComponent.name===chipId:child.nodeType==="group"&&child.sourceGroup?`group_${tree.childNodes.indexOf(child)}`===chipId:!1);treeNode?.nodeType==="component"&&treeNode.sourceComponent&&db2.source_port.list({source_component_id:treeNode.sourceComponent.source_component_id}).some(p2=>p2.source_port_id===portId)&&directlyConnectedPins.push(pinId)}}for(let i3=0;i3<directlyConnectedPins.length;i3++)for(let j3=i3+1;j3<directlyConnectedPins.length;j3++){let pin1=directlyConnectedPins[i3],pin2=directlyConnectedPins[j3];problem.pinStrongConnMap[`${pin1}-${pin2}`]=!0,problem.pinStrongConnMap[`${pin2}-${pin1}`]=!0,debug52(`[${group.name}] Created strong connection: ${pin1} <-> ${pin2}`)}}}if(hasNetConnections){let source_net2=db2.source_net.getWhere({subcircuit_connectivity_map_key:connectivityKey}),isGround=source_net2?.is_ground??!1,isPositiveVoltageSource=source_net2?.is_power??!1;problem.netMap[connectivityKey]={netId:connectivityKey,isGround,isPositiveVoltageSource};for(let pinId of pins)problem.netConnMap[`${pinId}-${connectivityKey}`]=!0;debug52(`[${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(debug52(`[${group.name}] Starting matchpack layout with ${tree.childNodes.length} children`),debug52(`[${group.name}] Tree structure:`,JSON.stringify(tree,null,2)),tree.childNodes.length<=1){debug52(`[${group.name}] Only ${tree.childNodes.length} children, skipping layout`);return}debug52("Converting circuit tree to InputProblem...");let inputProblem=convertTreeToInputProblem(tree,db2,group);debug52.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(debug52("Starting LayoutPipelineSolver..."),debug52.enabled&&global?.debugGraphics){let initialViz=solver.visualize();global.debugGraphics.push({...initialViz,title:`matchpack-initial-${group.name}`})}if(solver.solve(),debug52(`Solver completed in ${solver.iterations} iterations`),debug52(`Solved: ${solver.solved}, Failed: ${solver.failed}`),solver.failed)throw debug52(`Solver failed with error: ${solver.error}`),new Error(`Matchpack layout solver failed: ${solver.error}`);let outputLayout=solver.getOutputLayout();if(debug52("OutputLayout:",JSON.stringify(outputLayout,null,2)),debug52("Solver completed successfully:",!solver.failed),debug52.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){debug52(`Warning: Found ${overlaps.length} overlapping components:`);for(let overlap of overlaps)debug52(` ${overlap.chip1} overlaps ${overlap.chip2} (area: ${overlap.overlapArea})`)}let groupOffset=group._getGlobalSchematicPositionBeforeLayout();debug52(`Group offset: x=${groupOffset.x}, y=${groupOffset.y}`),debug52(`Applying layout results for ${Object.keys(outputLayout.chipPlacements).length} chip placements`);for(let[chipId,placement]of Object.entries(outputLayout.chipPlacements)){debug52(`Processing placement for chip: ${chipId} at (${placement.x}, ${placement.y})`);let treeNode=tree.childNodes.find(child=>{if(child.nodeType==="component"&&child.sourceComponent){let matches=child.sourceComponent.name===chipId;return debug52(` Checking component ${child.sourceComponent.name}: matches=${matches}`),matches}if(child.nodeType==="group"&&child.sourceGroup){let groupName=child.sourceGroup.name,expectedChipId=`group_${tree.childNodes.indexOf(child)}`,matches=expectedChipId===chipId;return debug52(` Checking group ${groupName} (expected chipId: ${expectedChipId}): matches=${matches}`),matches}return!1});if(!treeNode){debug52(`Warning: No tree node found for chip: ${chipId}`),debug52("Available tree nodes:",tree.childNodes.map((child,idx)=>({type:child.nodeType,name:child.nodeType==="component"?child.sourceComponent?.name:child.sourceGroup?.name,expectedChipId:child.nodeType==="group"?`group_${idx}`:child.sourceComponent?.name})));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){debug52(`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){debug52(`Component ${chipId} has rotation: ${placement.ccwRotationDegrees}\xB0`);let angleRad=placement.ccwRotationDegrees*Math.PI/180,cos4=Math.cos(angleRad),sin4=Math.sin(angleRad);for(let port of ports){let dx2=port.center.x-newCenter.x,dy2=port.center.y-newCenter.y,rotatedDx=dx2*cos4-dy2*sin4,rotatedDy=dx2*sin4+dy2*cos4;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 dx2=text.position.x-newCenter.x,dy2=text.position.y-newCenter.y,rotatedDx=dx2*cos4-dy2*sin4,rotatedDy=dx2*sin4+dy2*cos4;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)}`))}}}}else if(treeNode.nodeType==="group"&&treeNode.sourceGroup){let schematicGroup=db2.schematic_group?.getWhere?.({source_group_id:treeNode.sourceGroup.source_group_id});if(schematicGroup){debug52(`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});debug52(`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};debug52(`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,debug52(`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,debug52(`Updated group ${chipId} center to (${newCenter.x}, ${newCenter.y})`)}}}debug52("Matchpack layout completed successfully")}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(t5=>{let source_trace2=db2.source_trace.get(t5.source_trace_id);return source_trace2?[source_trace2.source_trace_id,...source_trace2.connected_source_port_ids,...source_trace2.connected_source_net_ids]:null}).filter(c3=>c3!==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_trace2=db2.source_trace.get(trace.source_trace_id);if(source_trace2)for(let id2 of source_trace2.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_trace2=db2.source_trace.get(trace.source_trace_id);if(source_trace2)for(let source_net_id of source_trace2.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(n3=>n3.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 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 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(size2=>size2!==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 size2=getSizeOfTreeNodeChild(db2,child);flexBox.addChild({metadata:child,width:size2?.width??0,height:size2?.height??0,flexBasis:size2?direction2==="row"?size2.width:size2.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})},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})}}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 applyComponentConstraintClusters=(group,packInput)=>{let constraints=group.children.filter(c3=>c3.componentName==="Constraint"&&c3._parsedProps.pcb),clusterByRoot=new Map,parent={},find2=x3=>(parent[x3]!==x3&&(parent[x3]=find2(parent[x3])),parent[x3]),union2=(a2,b3)=>{let ra3=find2(a2),rb2=find2(b3);ra3!==rb2&&(parent[rb2]=ra3)},makeSet=x3=>{x3 in parent||(parent[x3]=x3)},getIdFromSelector=sel2=>{let name=sel2.startsWith(".")?sel2.slice(1):sel2;return group.children.find(c3=>c3.name===name)?.pcb_component_id??void 0};for(let constraint of constraints){let props=constraint._parsedProps;if("left"in props&&"right"in props){let a2=getIdFromSelector(props.left),b3=getIdFromSelector(props.right);a2&&b3&&(makeSet(a2),makeSet(b3),union2(a2,b3))}else if("top"in props&&"bottom"in props){let a2=getIdFromSelector(props.top),b3=getIdFromSelector(props.bottom);a2&&b3&&(makeSet(a2),makeSet(b3),union2(a2,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(c3=>[c3.componentId,c3]));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 ax2=pos.x+pad2.offset.x,ay2=pos.y+pad2.offset.y;minX=Math.min(minX,ax2-pad2.size.x/2),maxX=Math.max(maxX,ax2+pad2.size.x/2),minY=Math.min(minY,ay2-pad2.size.y/2),maxY=Math.max(maxY,ay2+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(c3=>!info.componentIds.includes(c3.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=compose(group._computePcbGlobalTransformBeforeLayout(),translate(center2.x+rotatedRel.x,center2.y+rotatedRel.y),rotate(angleRad),translate(-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=compose(group._computePcbGlobalTransformBeforeLayout(),translate(center2.x,center2.y),rotate(rotationDegrees2*Math.PI/180),translate(-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(g4=>g4.source_group_id===componentId);if(!pcbGroup)continue;let originalCenter=pcbGroup.center,rotationDegrees=ccwRotationDegrees??ccwRotationOffset??0,transformMatrix=compose(group._computePcbGlobalTransformBeforeLayout(),translate(center2.x,center2.y),rotate(rotationDegrees*Math.PI/180),translate(-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",debug6=(0,import_debug13.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);debug6.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(error){throw group.root?.emit("packing:error",{subcircuit_id:group.subcircuit_id,componentDisplayName:group.getString(),error:{message:error instanceof Error?error.message:String(error)}}),error}if(debug6.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()})},Group_doInitialPcbLayoutFlex=group=>{let{db:db2}=group.root,{_parsedProps:props}=group,pcbChildren=group.children.filter(c3=>c3.pcb_component_id||c3.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(size2=>size2!==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 size2=child._getMinimumFlexContainerSize();flexBox.addChild({metadata:child,width:size2?.width??0,height:size2?.height??0,flexBasis:size2?direction2==="row"?size2.width:size2.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})},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 createSchematicTraceSolverInputProblem(group){let{db:db2}=group.root,sckToSourceNet=new Map,sckToUserNetId=new Map,allScks=new Set,displayLabelTraces=group.selectAll("trace").filter(t5=>t5._parsedProps?.schDisplayLabel),childGroups=group.selectAll("group"),allSchematicGroupIds=[group.schematic_group_id,...childGroups.map(a2=>a2.schematic_group_id)],schematicComponents=db2.schematic_component.list().filter(a2=>allSchematicGroupIds.includes(a2.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 sp2 of ports)allSourceAndSchematicPortIdsInScope.add(sp2.schematic_port_id),sp2.source_port_id&&(schPortIdToSourcePortId.set(sp2.schematic_port_id,sp2.source_port_id),sourcePortIdToSchPortId.set(sp2.source_port_id,sp2.schematic_port_id))}let allowedSubcircuitIds=new Set;group.subcircuit_id&&allowedSubcircuitIds.add(group.subcircuit_id);for(let cg of childGroups)cg.subcircuit_id&&allowedSubcircuitIds.add(cg.subcircuit_id);let externalNetIds=db2.source_trace.list().filter(st2=>{if(st2.subcircuit_id===group.subcircuit_id)return!0;for(let source_port_id of st2.connected_source_port_ids)if(sourcePortIdToSchPortId.has(source_port_id))return!0;return!1}).flatMap(st2=>st2.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 st2 of db2.source_trace.list()){if(st2.subcircuit_id&&!allowedSubcircuitIds.has(st2.subcircuit_id))continue;let connected=(st2.connected_source_port_ids??[]).map(srcId=>sourcePortIdToSchPortId.get(srcId)).filter(sourcePortId=>!!sourcePortId&&allSourceAndSchematicPortIdsInScope.has(sourcePortId));if(connected.length>=2){let[a2,b3]=connected.slice(0,2),pairKey=[a2,b3].sort().join("::");if(!pairKeyToSourceTraceId.has(pairKey)){pairKeyToSourceTraceId.set(pairKey,st2.source_trace_id);let userNetId=st2.display_name??st2.source_trace_id;st2.subcircuit_connectivity_map_key&&(allScks.add(st2.subcircuit_connectivity_map_key),userNetIdToSck.set(userNetId,st2.subcircuit_connectivity_map_key),sckToUserNetId.set(st2.subcircuit_connectivity_map_key,userNetId)),directConnections.push({pinIds:[a2,b3].map(id2=>schematicPortIdToPinId.get(id2)),netId:userNetId})}}}let netConnections=[];for(let net of db2.source_net.list().filter(n3=>!n3.subcircuit_id||allowedSubcircuitIds.has(n3.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 sp2=db2.source_port.get(srcPortId);if(!sp2?.subcircuit_connectivity_map_key)continue;let sck=sp2.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(nc2=>nc2.netId));for(let net of db2.source_net.list().filter(n3=>!n3.subcircuit_id||allowedSubcircuitIds.has(n3.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 dx2=Math.abs(edge.to.x-edge.from.x),dy2=Math.abs(edge.to.y-edge.from.y);return dx2>=dy2}function length6(a2,b3){return Math.hypot(b3.x-a2.x,b3.y-a2.y)}function pointAt(a2,b3,t5){return{x:a2.x+(b3.x-a2.x)*t5,y:a2.y+(b3.y-a2.y)*t5}}function paramAlong(a2,b3,p2){let L3=length6(a2,b3);if(L3<TOL)return 0;let t5=((p2.x-a2.x)*(b3.x-a2.x)+(p2.y-a2.y)*(b3.y-a2.y))/((b3.x-a2.x)*(b3.x-a2.x)+(b3.y-a2.y)*(b3.y-a2.y));return Math.max(0,Math.min(1,t5))*L3}function cross2(ax2,ay2,bx2,by2){return ax2*by2-ay2*bx2}function segmentIntersection(p12,p2,q12,q22){let r4={x:p2.x-p12.x,y:p2.y-p12.y},s3={x:q22.x-q12.x,y:q22.y-q12.y},rxs=cross2(r4.x,r4.y,s3.x,s3.y),q_p={x:q12.x-p12.x,y:q12.y-p12.y},q_pxr=cross2(q_p.x,q_p.y,r4.x,r4.y);if(Math.abs(rxs)<TOL&&Math.abs(q_pxr)<TOL||Math.abs(rxs)<TOL&&Math.abs(q_pxr)>=TOL)return null;let t5=cross2(q_p.x,q_p.y,s3.x,s3.y)/rxs,u4=cross2(q_p.x,q_p.y,r4.x,r4.y)/rxs;return t5<-TOL||t5>1+TOL||u4<-TOL||u4>1+TOL?null:{x:p12.x+t5*r4.x,y:p12.y+t5*r4.y}}function mergeIntervals(intervals,tol=TOL){if(intervals.length===0)return intervals;intervals.sort((a2,b3)=>a2.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(d3=>({start:Math.max(0,d3-half),end:Math.min(L3,d3+half)})).filter(iv=>iv.end-iv.start>TOL),intervals=mergeIntervals(rawIntervals),result=[],cursor=0,dir={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,t12=d12/L3;result.push({from:pointAt(edge.from,edge.to,t02),to:pointAt(edge.from,edge.to,t12),...isCrossing?{is_crossing:!0}:{}})};for(let iv of intervals)iv.start-cursor>TOL&&addSeg(cursor,iv.start,!1),addSeg(iv.start,iv.end,!0),cursor=iv.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 eA=A4.edges[ei3];for(let tj2=ti3;tj2<traces.length;tj2++){let B3=traces[tj2];for(let ej2=tj2===ti3?ei3+1:0;ej2<B3.edges.length;ej2++){let eB=B3.edges[ej2],P4=segmentIntersection(eA.from,eA.to,eB.from,eB.to);if(!P4)continue;let LA=length6(eA.from,eA.to),LB=length6(eB.from,eB.to);if(LA<tol||LB<tol)continue;let dA=paramAlong(eA.from,eA.to,P4),dB=paramAlong(eB.from,eB.to,P4),nearEndpointA=dA<=tol||Math.abs(LA-dA)<=tol||Number.isNaN(dA),nearEndpointB=dB<=tol||Math.abs(LB-dB)<=tol||Number.isNaN(dB);if(!nearEndpointA&&!nearEndpointB){let aIsHorizontal=isHorizontalEdge(eA),bIsHorizontal=isHorizontalEdge(eB),assignToA;if(aIsHorizontal!==bIsHorizontal)assignToA=aIsHorizontal;else{let ax2=Math.abs(eA.to.x-eA.from.x),ay2=Math.abs(eA.to.y-eA.from.y),bx2=Math.abs(eB.to.x-eB.from.x),by2=Math.abs(eB.to.y-eB.from.y),aScore=ax2-ay2,bScore=bx2-by2;assignToA=aScore===bScore?!0:aScore>bScore}let chosenKey=keyOf({traceIdx:assignToA?ti3:tj2,edgeIdx:assignToA?ei3:ej2}),chosenList=crossingsByEdge.get(chosenKey)??[];chosenList.push(assignToA?dA:dB),crossingsByEdge.set(chosenKey,chosenList)}}}}}let out=traces.map(t5=>({source_trace_id:t5.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(d3=>Number(d3.toFixed(6))))).sort((a2,b3)=>a2-b3),split=splitEdgeByCrossings(trace.edges[ei3],uniqueSorted,crossLen);out[ti3].edges.push(...split)}}return out}var TOL2=1e-6;function nearlyEqual(a2,b3,tol=TOL2){return Math.abs(a2-b3)<=tol}function pointEq(a2,b3,tol=TOL2){return nearlyEqual(a2.x,b3.x,tol)&&nearlyEqual(a2.y,b3.y,tol)}function onSegment4(p2,a2,b3,tol=TOL2){let minX=Math.min(a2.x,b3.x)-tol,maxX=Math.max(a2.x,b3.x)+tol,minY=Math.min(a2.y,b3.y)-tol,maxY=Math.max(a2.y,b3.y)+tol;return p2.x<minX||p2.x>maxX||p2.y<minY||p2.y>maxY?!1:Math.abs((b3.x-a2.x)*(p2.y-a2.y)-(b3.y-a2.y)*(p2.x-a2.x))<=tol}function dedupePoints(points,tol=TOL2){let map=new Map;for(let p2 of points){let key=`${p2.x.toFixed(6)},${p2.y.toFixed(6)}`;map.has(key)||map.set(key,p2)}return Array.from(map.values())}function edgeVec(e4){return{x:e4.to.x-e4.from.x,y:e4.to.y-e4.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,p2,tol=TOL2){return trace.edges.filter(e4=>pointEq(e4.from,p2,tol)||pointEq(e4.to,p2,tol))}function nearestEndpointOnTrace(trace,p2,tol=TOL2){for(let e4 of trace.edges){if(pointEq(e4.from,p2,tol))return e4.from;if(pointEq(e4.to,p2,tol))return e4.to}return null}function edgeDirectionFromPoint(e4,p2,tol=TOL2){let other=pointEq(e4.from,p2,tol)||nearlyEqual(e4.from.x,p2.x,tol)&&nearlyEqual(e4.from.y,p2.y,tol)?e4.to:e4.from,dx2=other.x-p2.x,dy2=other.y-p2.y;return Math.abs(dx2)<tol&&Math.abs(dy2)<tol?null:Math.abs(dx2)>=Math.abs(dy2)?dx2>=0?"right":"left":dy2>=0?"up":"down"}function getCornerOrientationAtPoint(trace,p2,tol=TOL2){let incident=incidentEdgesAtPoint(trace,p2,tol);if(incident.length<2)return null;let dirs=incident.map(e4=>edgeDirectionFromPoint(e4,p2,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 t5 of traces)result[t5.source_trace_id]=[];let endpointsByTrace=traces.map(t5=>{let pts=[];for(let e4 of t5.edges)pts.push(e4.from,e4.to);return dedupePoints(pts,tol)});for(let i3=0;i3<traces.length;i3++){let A4=traces[i3],AEnds=endpointsByTrace[i3];for(let j3=i3+1;j3<traces.length;j3++){let B3=traces[j3],BEnds=endpointsByTrace[j3];for(let pa3 of AEnds)for(let pb2 of BEnds)if(pointEq(pa3,pb2,tol)){let aEdgesAtP=incidentEdgesAtPoint(A4,pa3,tol),bEdgesAtP=incidentEdgesAtPoint(B3,pb2,tol),hasCorner=aEdgesAtP.some(eA=>bEdgesAtP.some(eB=>!isParallel(eA,eB,tol))),aCorner=getCornerOrientationAtPoint(A4,pa3,tol),bCorner=getCornerOrientationAtPoint(B3,pb2,tol);hasCorner&&!(aCorner!==null&&bCorner!==null&&aCorner===bCorner)&&(result[A4.source_trace_id].push(pa3),A4.source_trace_id!==B3.source_trace_id&&result[B3.source_trace_id].push(pb2))}for(let pa3 of AEnds)for(let eB of B3.edges)if(onSegment4(pa3,eB.from,eB.to,tol)){let hasCorner=incidentEdgesAtPoint(A4,pa3,tol).some(eA=>!isParallel(eA,eB,tol)),aCorner=getCornerOrientationAtPoint(A4,pa3,tol),bEndpointNearPa=nearestEndpointOnTrace(B3,pa3,tol*1e3),bCorner=bEndpointNearPa?getCornerOrientationAtPoint(B3,bEndpointNearPa,tol):null;hasCorner&&!(aCorner!==null&&bCorner!==null&&aCorner===bCorner)&&(result[A4.source_trace_id].push(pa3),A4.source_trace_id!==B3.source_trace_id&&result[B3.source_trace_id].push(pa3))}for(let pb2 of BEnds)for(let eA of A4.edges)if(onSegment4(pb2,eA.from,eA.to,tol)){let hasCorner=incidentEdgesAtPoint(B3,pb2,tol).some(eB=>!isParallel(eA,eB,tol)),bCorner=getCornerOrientationAtPoint(B3,pb2,tol),aEndpointNearPb=nearestEndpointOnTrace(A4,pb2,tol*1e3),aCorner=aEndpointNearPb?getCornerOrientationAtPoint(A4,aEndpointNearPb,tol):null;hasCorner&&!(aCorner!==null&&bCorner!==null&&aCorner===bCorner)&&(result[B3.source_trace_id].push(pb2),A4.source_trace_id!==B3.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_debug15.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 pA=pinIdToSchematicPortId.get(solvedTracePath.pins[0]?.pinId),pB=pinIdToSchematicPortId.get(solvedTracePath.pins[1]?.pinId);if(pA&&pB){for(let schPid of[pA,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(t5=>({source_trace_id:t5.source_trace_id,edges:t5.edges}))),junctionsById=computeJunctions(withCrossings);for(let t5 of withCrossings)db2.schematic_trace.insert({source_trace_id:t5.source_trace_id,edges:t5.edges,junctions:junctionsById[t5.source_trace_id]??[],subcircuit_connectivity_map_key:pendingTraces.find(p2=>p2.source_trace_id===t5.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(p2=>p2._getNetLabelText()).join("/"),wasAssignedDisplayLabel:!1}},debug8=(0,import_debug16.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(p2=>p2._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(nl2=>Math.abs(nl2.anchor_position.x-schPort.center.x)<.1&&Math.abs(nl2.anchor_position.y-schPort.center.y)<.1?sourceNet.source_net_id&&nl2.source_net_id?nl2.source_net_id===sourceNet.source_net_id:nl2.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_debug14.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),schematicPortIdsWithPreExistingNetLabels=getSchematicPortIdsWithAssignedNetLabels(group);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(132, 0, 0)","rgb(194, 194, 0)","rgb(194, 0, 194)","rgb(194, 0, 0)","rgb(0, 132, 132)","rgb(0, 132, 0)","rgb(0, 0, 132)","rgb(132, 132, 132)","rgb(132, 0, 132)","rgb(194, 194, 194)","rgb(132, 0, 132)","rgb(132, 0, 0)","rgb(132, 132, 0)","rgb(194, 194, 194)","rgb(0, 0, 132)","rgb(0, 132, 0)"],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}var debug10=(0,import_debug17.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:
|
|
614
614
|
${spiceString}`)}catch(error){debug10(`Failed to convert circuit JSON to SPICE: ${error}`);return}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=voltageProbes.find(p2=>p2.finalProbeName===element.name);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(error){debug10(`Simulation failed for engine ${engineName}: ${error}`);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:error instanceof Error?error.message:String(error)})}})}}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})}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 ax2=anchorPosition.x,ay2=anchorPosition.y;switch(alignment){case"top_left":return{x:ax2+width/2,y:ay2-height/2};case"top_center":return{x:ax2,y:ay2-height/2};case"top_right":return{x:ax2-width/2,y:ay2-height/2};case"center_left":return{x:ax2+width/2,y:ay2};case"center_right":return{x:ax2-width/2,y:ay2};case"bottom_left":return{x:ax2+width/2,y:ay2+height/2};case"bottom_center":return{x:ax2,y:ay2+height/2};case"bottom_right":return{x:ax2-width/2,y:ay2+height/2};default:return anchorPosition}}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(g4=>g4.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:{}}),rotation4=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:rotation4,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(p2=>Math.abs(p2.pad.center.x-groupPad.center.x)<.01&&Math.abs(p2.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(p2=>p2.route_type==="jumper"),wireAndViaRoutes=route.filter(p2=>p2.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 p2=wireAndViaRoutes[i3];if(p2.route_type!=="wire")continue;let distToStart=Math.hypot(p2.x-jumperStart.x,p2.y-jumperStart.y),distToEnd=Math.hypot(p2.x-jumperEnd.x,p2.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((a2,b3)=>a2.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 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,x3,y3,tolerance=.01){for(let pad2 of padInfos)if(Math.abs(pad2.x-x3)<tolerance&&Math.abs(pad2.y-y3)<tolerance)return pad2.pcb_port_id}function findJumperPortContainingPoint(padInfos,x3,y3){for(let pad2 of padInfos)if(x3>=pad2.minX&&x3<=pad2.maxX&&y3>=pad2.minY&&y3<=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 point23=route[i3];if(currentSegment.push(point23),point23.route_type==="wire"&&i3>0&&i3<route.length-1){let padInfo=findJumperPortContainingPoint(padInfos,point23.x,point23.y);if(padInfo){point23.end_pcb_port_id||(point23.end_pcb_port_id=padInfo.pcb_port_id),segments.push(currentSegment);let newStartPoint={...point23};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}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,"_asyncAutoroutingResult",null);__publicField(this,"unnamedElementCounter",{})}get config(){return{zodProps:groupProps,componentName:"Group"}}doInitialSourceGroupRender(){let{db:db2}=this.root,hasExplicitName=typeof this._parsedProps.name=="string"&&this._parsedProps.name.length>0,source_group2=db2.source_group.insert({name:this.name,is_subcircuit:this.isSubcircuit,was_automatically_named:!hasExplicitName});this.source_group_id=source_group2.source_group_id,this.isSubcircuit&&(this.subcircuit_id=`subcircuit_${source_group2.source_group_id}`,db2.source_group.update(source_group2.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(point23=>({x:distance.parse(point23.x),y:distance.parse(point23.y)})):void 0,ctx=this.props,anchorPosition=this._getGlobalPcbPositionBeforeLayout(),center2=computeCenterFromAnchorPosition(anchorPosition,ctx),pcb_group2=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_group2.pcb_group_id;for(let child of this.children)db2.pcb_component.update(child.pcb_component_id,{pcb_group_id:pcb_group2.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(point23=>({x:distance.parse(point23.x),y:distance.parse(point23.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 _a359,_b2;return(_a359=this.unnamedElementCounter)[_b2=elm.lowercaseComponentName]??(_a359[_b2]=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(g4=>g4.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)}_hasTracesToRoute(){let debug112=(0,import_debug10.default)("tscircuit:core:_hasTracesToRoute"),traces=this.selectAll("trace");return debug112(`[${this.getString()}] has ${traces.length} traces to route`),traces.length>0}async _runEffectMakeHttpAutoroutingRequest(){let{db:db2}=this.root,debug112=(0,import_debug10.default)("tscircuit:core:_runEffectMakeHttpAutoroutingRequest"),props=this._parsedProps,autorouterConfig2=this._getAutorouterConfig(),serverUrl=autorouterConfig2.serverUrl,serverMode=autorouterConfig2.serverMode,fetchWithDebug=(url,options)=>(debug112("fetching",url),options.headers&&(options.headers["Tscircuit-Core-Version"]=this.root?.getCoreVersion()),fetch(url,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:this.props.autorouter?.minTraceWidth??.15,nominalTraceWidth:this.props.nominalTraceWidth,subcircuit_id:this.subcircuit_id}).simpleRouteJson,subcircuit_id:this.subcircuit_id}),headers:{"Content-Type":"application/json"}}).then(r4=>r4.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(r4=>r4.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(r4=>r4.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(r4=>r4.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(r4=>r4.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_debug10.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}=getSimpleRouteJsonFromCircuitJson({db:db2,minTraceWidth:this.props.autorouter?.minTraceWidth??.15,nominalTraceWidth:this.props.nominalTraceWidth,subcircuit_id:this.subcircuit_id});if(isAutoJumperPreset&&(simpleRouteJson.allowJumpers=!0),debug112.enabled&&global.debugOutputArray?.push({name:`simpleroutejson-${this.props.name}.json`,obj:simpleRouteJson}),debug112.enabled){let graphicsObject=sn2(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 outputJumpers=[],solver=autorouter.solver;solver?.getOutputJumpers&&(outputJumpers=solver.getOutputJumpers()||[]),this._asyncAutoroutingResult={output_pcb_traces:traces,output_jumpers:outputJumpers},this._markDirty("PcbTraceRender")}catch(error){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:error instanceof Error?error.message:String(error)}),this.root?.emit("autorouting:error",{subcircuit_id:this.subcircuit_id,componentDisplayName:this.getString(),error:{message:error instanceof Error?error.message:String(error)},simpleRouteJson}),error}finally{autorouter.stop()}}_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_debug10.default)("tscircuit:core:doInitialPcbTraceRender");if(this.isSubcircuit&&!this.root?.pcbDisabled&&!this.getInheritedProperty("routingDisabled")&&!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(){Group_doInitialSchematicTraceRender(this)}updatePcbTraceRender(){let debug112=(0,import_debug10.default)("tscircuit:core:updatePcbTraceRender");if(debug112(`[${this.getString()}] updating...`),!this.isSubcircuit)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_trace2=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);output_jumpers&&output_jumpers.length>0&&insertAutoplacedJumpers({db:db2,output_jumpers,subcircuit_id:this.subcircuit_id});for(let pcb_trace2 of output_pcb_traces){if(pcb_trace2.type!=="pcb_trace")continue;if(pcb_trace2.subcircuit_id=this.subcircuit_id,pcb_trace2.connection_name){let sourceTraceId=pcb_trace2.connection_name;pcb_trace2.source_trace_id=sourceTraceId}let segments=splitPcbTracesOnJumperSegments(pcb_trace2.route);segments===null&&(segments=[pcb_trace2.route]);let processedSegments=addPortIdsToTracesAtJumperPads(segments,db2);for(let segment2 of processedSegments)segment2.length>0&&db2.pcb_trace.insert({...pcb_trace2,route:segment2})}for(let pcb_trace2 of output_pcb_traces)if(pcb_trace2.type!=="pcb_via"&&pcb_trace2.type==="pcb_trace")for(let point23 of pcb_trace2.route)point23.route_type==="via"&&db2.pcb_via.insert({pcb_trace_id:pcb_trace2.pcb_trace_id,x:point23.x,y:point23.y,hole_diameter:holeDiameter,outer_diameter:padDiameter,layers:[point23.from_layer,point23.to_layer],from_layer:point23.from_layer,to_layer:point23.to_layer})}doInitialSchematicComponentRender(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,schematic_group2=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});this.schematic_group_id=schematic_group2.schematic_group_id;for(let child of this.children)child.schematic_component_id&&db2.schematic_component.update(child.schematic_component_id,{schematic_group_id:schematic_group2.schematic_group_id})}_getSchematicLayoutMode(){let props=this._parsedProps;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 anyChildHasSchCoords=this.children.some(child=>{let cProps=child._parsedProps;return cProps?.schX!==void 0||cProps?.schY!==void 0}),hasManualEdits=(props.manualEdits?.schematic_placements?.length??0)>0;return!anyChildHasSchCoords&&!hasManualEdits?"match-adapt":"relative"}doInitialSchematicLayout(){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;if(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,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,hasCoords=childProps?.pcbX!==void 0||childProps?.pcbY!==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 dx2=port.center.x-component.center.x,dy2=port.center.y-component.center.y;return Math.abs(dx2)>Math.abs(dy2)?dx2>0?"right":"left":dy2>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.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(c3=>c3.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 nl2 of subtree.schematic_net_label.list()){let net=subtree.source_net.get(nl2.source_net_id),text=nl2.text||net?.name||"";if(nl2.anchor_side==="top"&&/^gnd/i.test(text)){subtree.schematic_net_label.update(nl2.schematic_net_label_id,{symbol_name:"rail_down"});continue}nl2.anchor_side==="bottom"&&/^v/i.test(text)&&subtree.schematic_net_label.update(nl2.schematic_net_label_id,{symbol_name:"rail_up"})}}doInitialSimulationSpiceEngineRender(){Group_doInitialSimulationSpiceEngineRender(this)}doInitialPcbComponentAnchorAlignment(){Group_doInitialPcbComponentAnchorAlignment(this)}updatePcbComponentAnchorAlignment(){this.doInitialPcbComponentAnchorAlignment()}_getMinimumFlexContainerSize(){return super._getMinimumFlexContainerSize()}_repositionOnPcb(position2){return super._repositionOnPcb(position2)}};function inflatePcbBoard(pcbBoard,inflatorContext){let{subcircuit}=inflatorContext;if(subcircuit.lowercaseComponentName==="board"||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 stringProxy=new Proxy({},{get:(target,prop)=>prop}),FTYPE=stringProxy,SCHEMATIC_COMPONENT_OUTLINE_COLOR="rgba(132, 0, 0)",SCHEMATIC_COMPONENT_OUTLINE_STROKE_WIDTH=.12,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});this.source_component_id=source_component.source_component_id}},inflatePcbComponent=(pcbElm,inflatorContext)=>{let{injectionDb,normalComponent}=inflatorContext;if(!normalComponent)return;let componentCenter=pcbElm.center||{x:0,y:0},componentRotation=pcbElm.rotation||0,absoluteToComponentRelativeTransform=inverse(compose(translate(componentCenter.x,componentCenter.y),rotate(componentRotation*Math.PI/180))),relativeElements=injectionDb.toArray().filter(elm=>"pcb_component_id"in elm&&elm.pcb_component_id===pcbElm.pcb_component_id),clonedRelativeElements=structuredClone(relativeElements);transformPCBElements(clonedRelativeElements,absoluteToComponentRelativeTransform);let components=createComponentsFromCircuitJson({componentName:normalComponent.name,componentRotation:"0deg"},clonedRelativeElements);normalComponent.addAll(components)};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}),capacitor=new Capacitor({name:sourceElm.name,capacitance:sourceElm.capacitance,layer:pcbElm?.layer,pcbX:pcbElm?.center?.x,pcbY:pcbElm?.center?.y,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});pcbElm&&inflatePcbComponent(pcbElm,{...inflatorContext,normalComponent:capacitor}),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,{pcbX,pcbY}=this.getResolvedPcbPositionProp();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,{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});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(),componentLayer=props.layer??"top";if(componentLayer!=="top"&&componentLayer!=="bottom"){let subcircuit=this.getSubcircuit(),error=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(error)}let pcb_component2=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:componentLayer==="top"||componentLayer==="bottom"?componentLayer:"top",rotation:props.pcbRotation??0,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});this.pcb_component_id=pcb_component2.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,voltage2,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,voltage2=attributes2.providesVoltage),attributes2.providesGround&&(groundPort=port)}if(!powerPort||!groundPort||voltage2===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:voltage2})}},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),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:pcbElm?.center?.x,pcbY:pcbElm?.center?.y,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds,internallyConnectedPins}),footprint=cadElm?.footprinter_string??null;footprint&&(Object.assign(chip.props,{footprint}),Object.assign(chip._parsedProps,{footprint}),cadElm||chip._addChildrenFromStringFootprint?.()),pcbElm&&inflatePcbComponent(pcbElm,{...inflatorContext,normalComponent:chip}),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});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}),diode2=new Diode({name:sourceElm.name,layer:pcbElm?.layer,pcbX:pcbElm?.center?.x,pcbY:pcbElm?.center?.y,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});pcbElm&&inflatePcbComponent(pcbElm,{...inflatorContext,normalComponent:diode2}),sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(diode2):subcircuit.add(diode2)}function inflateSourceGroup(sourceGroup,inflatorContext){let{subcircuit,groupsMap}=inflatorContext,group=new Group6({name:sourceGroup.name??`inflated_group_${sourceGroup.source_group_id}`});return 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});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}),inductor=new Inductor({name:sourceElm.name,inductance:sourceElm.inductance,layer:pcbElm?.layer,pcbX:pcbElm?.center?.x,pcbY:pcbElm?.center?.y,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});pcbElm&&inflatePcbComponent(pcbElm,{...inflatorContext,normalComponent:inductor}),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_port2=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_port2.pcb_port_id}}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});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}),resistor=new Resistor({name:sourceElm.name,resistance:sourceElm.resistance,layer:pcbElm?.layer,pcbX:pcbElm?.center?.x,pcbY:pcbElm?.center?.y,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});pcbElm&&inflatePcbComponent(pcbElm,{...inflatorContext,normalComponent:resistor}),sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(resistor):subcircuit.add(resistor)}var getSelectorPath=(component,inflatorContext)=>{let{injectionDb,subcircuit,groupsMap}=inflatorContext,path_parts=[],currentGroupId=component.source_group_id;for(;currentGroupId&¤tGroupId!==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 trace=new Trace3({path:connectedSelectors});trace.source_trace_id=sourceTrace.source_trace_id,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});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}),transistor=new Transistor({name:sourceElm.name,type:sourceElm.transistor_type,layer:pcbElm?.layer,pcbX:pcbElm?.center?.x,pcbY:pcbElm?.center?.y,pcbRotation:pcbElm?.rotation,doNotPlace:pcbElm?.do_not_place,obstructsWithinBounds:pcbElm?.obstructs_within_bounds});pcbElm&&inflatePcbComponent(pcbElm,{...inflatorContext,normalComponent:transistor}),sourceElm.source_group_id&&groupsMap?.has(sourceElm.source_group_id)?groupsMap.get(sourceElm.source_group_id).add(transistor):subcircuit.add(transistor)}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();for(let sourceGroup of sourceGroups)inflateSourceGroup(sourceGroup,inflationCtx);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;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)},MIN_EFFECTIVE_BORDER_RADIUS_MM=.01,getRoundedRectOutline=(width,height,radius)=>{let w22=width/2,h2=height/2,r4=Math.min(radius,w22,h2);if(r4<MIN_EFFECTIVE_BORDER_RADIUS_MM)return[{x:-w22,y:-h2},{x:w22,y:-h2},{x:w22,y:h2},{x:-w22,y:h2}];let segments=Math.max(1,Math.ceil(Math.PI/2*r4/.1)),step=Math.PI/2/segments,outline=[];outline.push({x:-w22+r4,y:-h2}),outline.push({x:w22-r4,y:-h2});for(let i3=1;i3<=segments;i3++){let theta=-Math.PI/2+i3*step;outline.push({x:w22-r4+r4*Math.cos(theta),y:-h2+r4+r4*Math.sin(theta)})}outline.push({x:w22,y:h2-r4});for(let i3=1;i3<=segments;i3++){let theta=0+i3*step;outline.push({x:w22-r4+r4*Math.cos(theta),y:h2-r4+r4*Math.sin(theta)})}outline.push({x:-w22+r4,y:h2});for(let i3=1;i3<=segments;i3++){let theta=Math.PI/2+i3*step;outline.push({x:-w22+r4+r4*Math.cos(theta),y:h2-r4+r4*Math.sin(theta)})}outline.push({x:-w22,y:-h2+r4});for(let i3=1;i3<=segments;i3++){let theta=Math.PI+i3*step;outline.push({x:-w22+r4+r4*Math.cos(theta),y:-h2+r4+r4*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,"_connectedSchematicPortPairs",new Set)}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}_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(c3=>c3.subcircuit_id&&allowedSubcircuitIds.has(c3.subcircuit_id)),allPcbGroups=db2.pcb_group.list().filter(g4=>g4.subcircuit_id&&allowedSubcircuitIds.has(g4.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:x3,y:y3}=props.boardAnchorPosition;minX=Math.min(minX,x3),minY=Math.min(minY,y3),maxX=Math.max(maxX,x3),maxY=Math.max(maxY,y3)}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(point23=>({x:point23.x+(props.outlineOffsetX??0),y:point23.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(`
|
|
615
|
-
`),position2={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:position2})}doInitialSourceRender(){let nestedBoard=this.getDescendants().find(d3=>d3.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_board2=db2.source_board.insert({source_group_id:this.source_group_id,title:this.props.title||this.props.name});this.source_board_id=source_board2.source_board_id}doInitialInflateSubcircuitCircuitJson(){let{circuitJson,children}=this._parsedProps;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(point23=>point23.x),yValues=props.outline.map(point23=>point23.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 pcb_board2=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(point23=>({x:point23.x+(props.outlineOffsetX??0),y:point23.y+(props.outlineOffsetY??0)})),material:props.material});this.pcb_board_id=pcb_board2.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||this.getInheritedProperty("routingDisabled")||super.doInitialPcbDesignRuleChecks()}updatePcbDesignRuleChecks(){if(this.root?.pcbDisabled||this.getInheritedProperty("routingDisabled"))return;let{db:db2}=this.root;if(!this._areChildSubcircuitsRouted()||this._drcChecksComplete)return;this._drcChecksComplete=!0;let errors=checkEachPcbTraceNonOverlapping(db2.toArray());for(let error of errors)db2.pcb_trace_error.insert(error);let pcbPortNotConnectedErrors=checkEachPcbPortConnectedToPcbTraces(db2.toArray());for(let error of pcbPortNotConnectedErrors)db2.pcb_port_not_connected_error.insert(error);let pcbComponentOutsideErrors=checkPcbComponentsOutOfBoard(db2.toArray());for(let error of pcbComponentOutsideErrors)db2.pcb_component_outside_board_error.insert(error);let pcbTracesOutOfBoardErrors=checkPcbTracesOutOfBoard(db2.toArray());for(let error of pcbTracesOutOfBoardErrors)db2.pcb_trace_error.insert(error);let differentNetViaErrors=checkDifferentNetViaSpacing(db2.toArray());for(let error of differentNetViaErrors)db2.pcb_via_clearance_error.insert(error);let sameNetViaErrors=checkSameNetViaSpacing(db2.toArray());for(let error of sameNetViaErrors)db2.pcb_via_clearance_error.insert(error);let pcbComponentOverlapErrors=checkPcbComponentOverlap(db2.toArray());for(let error of pcbComponentOverlapErrors)db2.pcb_footprint_overlap_error.insert(error);let sourcePinMustBeConnectedErrors=checkPinMustBeConnected(db2.toArray());for(let error of sourcePinMustBeConnectedErrors)db2.source_pin_must_be_connected_error.insert(error)}_emitRenderLifecycleEvent(phase,startOrEnd){super._emitRenderLifecycleEvent(phase,startOrEnd),startOrEnd==="start"&&this.root?.emit("board:renderPhaseStarted",{renderId:this._renderId,phase})}_repositionOnPcb(position2){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:position2});return}let deltaX=position2.x-oldPos.x,deltaY=position2.y-oldPos.y;if(!(Math.abs(deltaX)<1e-6&&Math.abs(deltaY)<1e-6)){for(let child of this.children)if(child instanceof NormalComponent3){let childOldCenter;if(child.pcb_component_id){let comp=db2.pcb_component.get(child.pcb_component_id);comp&&(childOldCenter=comp.center)}else if(child instanceof Group6&&child.pcb_group_id){let group=db2.pcb_group.get(child.pcb_group_id);group&&(childOldCenter=group.center)}childOldCenter&&child._repositionOnPcb({x:childOldCenter.x+deltaX,y:childOldCenter.y+deltaY})}else child.isPcbPrimitive&&"_moveCircuitJsonElements"in child&&typeof child._moveCircuitJsonElements=="function"&&child._moveCircuitJsonElements({deltaX,deltaY});if(this.pcb_board_id&&(db2.pcb_board.update(this.pcb_board_id,{center:position2}),pcbBoard?.outline)){let outlineBounds=getBoundsFromPoints(pcbBoard.outline);if(outlineBounds){let oldOutlineCenter={x:(outlineBounds.minX+outlineBounds.maxX)/2,y:(outlineBounds.minY+outlineBounds.maxY)/2},outlineDeltaX=position2.x-oldOutlineCenter.x,outlineDeltaY=position2.y-oldOutlineCenter.y,newOutline=pcbBoard.outline.map(p2=>({x:p2.x+outlineDeltaX,y:p2.y+outlineDeltaY}));db2.pcb_board.update(this.pcb_board_id,{outline:newOutline})}}}}},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(p2=>point4(p2.x,p2.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),p2=point4(p2_.x,p2_.y),segment2=segment(p12,p2),segmentLength=segment2.length;if(segmentLength<1e-6)continue;let segmentVec=vector$1(p12,p2),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(p2,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,processedBoards=boards.map(board=>{if((!board.outline||board.outline.length===0)&&board.width&&board.height){let w22=board.width/2,h2=board.height/2;return{...board,outline:[{x:board.center.x-w22,y:board.center.y-h2},{x:board.center.x+w22,y:board.center.y-h2},{x:board.center.x+w22,y:board.center.y+h2},{x:board.center.x-w22,y:board.center.y+h2}]}}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 packBoardsIntoGrid=({boards,db:db2,row,col,cellWidth,cellHeight,boardGap})=>{let boardsWithDims=boards.map(board=>{let pcbBoard=db2.pcb_board.get(board.pcb_board_id);return!pcbBoard||pcbBoard.width===void 0||pcbBoard.height===void 0?null:{board,width:pcbBoard.width,height:pcbBoard.height}}).filter(b3=>b3!==null);if(boardsWithDims.length===0)return{positions:[],gridWidth:0,gridHeight:0};let explicitRow=row,cols=col??Math.ceil(explicitRow?boardsWithDims.length/explicitRow:Math.sqrt(boardsWithDims.length)),rows=explicitRow??Math.ceil(boardsWithDims.length/cols),colWidths=Array(cols).fill(0),rowHeights=Array(rows).fill(0);boardsWithDims.forEach((b3,i3)=>{let col2=i3%cols,row2=Math.floor(i3/cols);row2<rowHeights.length&&b3.height>rowHeights[row2]&&(rowHeights[row2]=b3.height),col2<colWidths.length&&b3.width>colWidths[col2]&&(colWidths[col2]=b3.width)});let minCellWidth=cellWidth?distance.parse(cellWidth):0,minCellHeight=cellHeight?distance.parse(cellHeight):0;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 totalGridWidth=colWidths.reduce((a2,b3)=>a2+b3,0)+(cols>1?(cols-1)*boardGap:0),totalGridHeight=rowHeights.reduce((a2,b3)=>a2+b3,0)+(rows>1?(rows-1)*boardGap:0),startX=-totalGridWidth/2,rowYOffsets=[-totalGridHeight/2];for(let i3=1;i3<rows;i3++)rowYOffsets.push(rowYOffsets[i3-1]+rowHeights[i3-1]+boardGap);let colXOffsets=[startX];for(let i3=1;i3<cols;i3++)colXOffsets.push(colXOffsets[i3-1]+colWidths[i3-1]+boardGap);let positions=[];return boardsWithDims.forEach((b3,i3)=>{let col2=i3%cols,row2=Math.floor(i3/cols);if(row2>=rowYOffsets.length||col2>=colXOffsets.length)return;let cellX=colXOffsets[col2],cellY=rowYOffsets[row2],cellWidth2=colWidths[col2],cellHeight2=rowHeights[row2],boardX=cellX+cellWidth2/2,boardY=cellY+cellHeight2/2;positions.push({board:b3.board,pos:{x:boardX,y:boardY}})}),{positions,gridWidth:totalGridWidth,gridHeight:totalGridHeight}},Panel=class extends Group6{constructor(){super(...arguments);__publicField(this,"pcb_panel_id",null);__publicField(this,"_tabsAndMouseBitesGenerated",!1)}get config(){return{componentName:"Panel",zodProps:panelProps}}get isGroup(){return!0}get isSubcircuit(){return!0}add(component){if(component.lowercaseComponentName!=="board")throw new Error("<panel> can only contain <board> elements");super.add(component)}doInitialPanelLayout(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,childBoardInstances=this.children.filter(c3=>c3 instanceof Board),hasAnyPositionedBoards=childBoardInstances.some(b3=>b3.props.pcbX!==void 0||b3.props.pcbY!==void 0),unpositionedBoards=childBoardInstances.filter(b3=>b3.props.pcbX===void 0&&b3.props.pcbY===void 0);if(unpositionedBoards.length>0&&!hasAnyPositionedBoards){let tabWidth=this._parsedProps.tabWidth??DEFAULT_TAB_WIDTH,boardGap=this._parsedProps.boardGap??tabWidth,{positions,gridWidth,gridHeight}=packBoardsIntoGrid({boards:unpositionedBoards,db:db2,row:this._parsedProps.row,col:this._parsedProps.col,cellWidth:this._parsedProps.cellWidth,cellHeight:this._parsedProps.cellHeight,boardGap}),panelGlobalPos=this._getGlobalPcbPositionBeforeLayout();for(let{board,pos}of positions){let absoluteX=panelGlobalPos.x+pos.x,absoluteY=panelGlobalPos.y+pos.y;board._repositionOnPcb({x:absoluteX,y:absoluteY}),db2.pcb_board.update(board.pcb_board_id,{center:{x:absoluteX,y:absoluteY},position_mode:"relative_to_panel_anchor",display_offset_x:`${pos.x}mm`,display_offset_y:`${pos.y}mm`})}let hasExplicitWidth=this._parsedProps.width!==void 0,hasExplicitHeight=this._parsedProps.height!==void 0;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})}}else{let panelGlobalPos=this._getGlobalPcbPositionBeforeLayout();for(let board of childBoardInstances){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`})}}if(this._tabsAndMouseBitesGenerated)return;let props=this._parsedProps;if((props.panelizationMethod??"none")!=="none"){let childBoardIds=childBoardInstances.map(c3=>c3.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}runRenderCycle(){if(!this.children.some(child=>child.componentName==="Board"))throw new Error("<panel> must contain at least one <board>");super.runRenderCycle()}doInitialPcbComponentRender(){if(super.doInitialPcbComponentRender(),this.root?.pcbDisabled)return;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,center:this._getGlobalPcbPositionBeforeLayout(),covered_with_solder_mask:!(props.noSolderMask??!1)});this.pcb_panel_id=inserted.pcb_panel_id}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});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,current2=typeof rawCurrent=="string"?parseFloat(rawCurrent):rawCurrent,voltage2=typeof rawVoltage=="string"?parseFloat(rawVoltage):rawVoltage;return`${formatSiUnit(current2)}A / ${formatSiUnit(voltage2)}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`});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});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(),pcb_component2=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:props.layer??"top",rotation:props.pcbRotation??0,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});this.pcb_component_id=pcb_component2.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(h2=>/^(pin)?\d+$/.test(h2));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});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(c3=>c3.componentName==="Port").map(p2=>p2.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(n3=>n3!==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(n3=>n3!==null))).sort((a2,b3)=>a2-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});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(),pcb_component2=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:props.layer??"top",rotation:props.pcbRotation??0,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});this.pcb_component_id=pcb_component2.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(h2=>/^(pin)?\d+$/.test(h2));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});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});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(){}initPorts(){super.initPorts({additionalAliases:{pin1:["terminal1"],pin2:["terminal2"]}})}_getSchematicSymbolDisplayValue(){let{voltage:voltage2,frequency:frequency2}=this._parsedProps,parts=[];return voltage2!==void 0&&parts.push(`${formatSiUnit(voltage2)}V`),frequency2!==void 0&&parts.push(`${formatSiUnit(frequency2)}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});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(){}initPorts(){super.initPorts({additionalAliases:{pin1:["pos"],pin2:["neg"]}})}_getSchematicSymbolDisplayValue(){let{current:current2,frequency:frequency2,peakToPeakCurrent}=this._parsedProps,parts=[];return current2!==void 0&&parts.push(`${formatSiUnit(current2)}A`),peakToPeakCurrent!==void 0&&parts.push(`${formatSiUnit(peakToPeakCurrent)}A p-p`),frequency2!==void 0&&parts.push(`${formatSiUnit(frequency2)}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});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}}},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,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),{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:pcbX,y:pcbY},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}})}},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 transform5=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(p2=>{let transformedPosition=applyToPoint(transform5,{x:p2.x,y:p2.y});return{...p2,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(point23=>typeof point23.x=="string"?parseFloat(point23.x):point23.x),ys3=props.route.map(point23=>typeof point23.y=="string"?parseFloat(point23.y):point23.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(p2=>({...p2,x:p2.x+deltaX,y:p2.y+deltaY}))})}},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,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),container=this.getPrimitiveContainer(),subcircuit=this.getSubcircuit(),pcb_fabrication_note_text2=db2.pcb_fabrication_note_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:pcbX,y:pcbY},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_text2.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}})}}},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,transform5){if(typeof input2=="string"){let target=this.getSubcircuit().selectOne(input2);return target?target._getGlobalPcbPositionBeforeLayout():(this.renderError(`FabricationNoteDimension could not find selector "${input2}"`),applyToPoint(transform5,{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 applyToPoint(transform5,{x:numericX,y:numericY})}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(props.from,transform5),to3=this._resolvePoint(props.to,transform5),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 transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(this._parsedProps.from,transform5),to3=this._resolvePoint(this._parsedProps.to,transform5);return{width:Math.abs(to3.x-from.x),height:Math.abs(to3.y-from.y)}}_formatDistanceText({from,to:to3,units}){let dx2=to3.x-from.x,dy2=to3.y-from.y,distanceInMillimeters=Math.sqrt(dx2*dx2+dy2*dy2),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}`}},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(),transform5=this._computePcbGlobalTransformBeforeLayout(),start=applyToPoint(transform5,{x:props.x1,y:props.y1}),end=applyToPoint(transform5,{x:props.x2,y:props.y2}),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id??void 0,pcb_note_line2=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,stroke_width:props.strokeWidth??.1,color:props.color,is_dashed:props.isDashed});this.pcb_note_line_id=pcb_note_line2.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})}},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,transform5=this._computePcbGlobalTransformBeforeLayout(),center2=applyToPoint(transform5,{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_rect2=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,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_rect2.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,transform5=this._computePcbGlobalTransformBeforeLayout(),anchorPosition=applyToPoint(transform5,{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_text2=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",color:props.color});this.pcb_note_text_id=pcb_note_text2.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}})}},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,transform5=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(point23=>{let{x:x3,y:y3,...rest}=point23,numericX=typeof x3=="string"?parseFloat(x3):x3,numericY=typeof y3=="string"?parseFloat(y3):y3,transformed=applyToPoint(transform5,{x:numericX,y:numericY});return{...rest,x:transformed.x,y:transformed.y}}),pcb_note_path2=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,stroke_width:props.strokeWidth??.1,color:props.color});this.pcb_note_path_id=pcb_note_path2.pcb_note_path_id}getPcbSize(){let{_parsedProps:props}=this;if(props.route.length===0)return{width:0,height:0};let xs3=props.route.map(point23=>typeof point23.x=="string"?parseFloat(point23.x):point23.x),ys3=props.route.map(point23=>typeof point23.y=="string"?parseFloat(point23.y):point23.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(p2=>({...p2,x:p2.x+deltaX,y:p2.y+deltaY}))})}},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,transform5){if(typeof input2=="string"){let target=this.getSubcircuit().selectOne(`.${input2}`);return target?target._getGlobalPcbPositionBeforeLayout():(this.renderError(`PcbNoteDimension could not find selector "${input2}"`),applyToPoint(transform5,{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 applyToPoint(transform5,{x:numericX,y:numericY})}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(props.from,transform5),to3=this._resolvePoint(props.to,transform5),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_dimension2=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,color:props.color,arrow_size:props.arrowSize??1});this.pcb_note_dimension_id=pcb_note_dimension2.pcb_note_dimension_id}getPcbSize(){let transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(this._parsedProps.from,transform5),to3=this._resolvePoint(this._parsedProps.to,transform5);return{width:Math.abs(to3.x-from.x),height:Math.abs(to3.y-from.y)}}_formatDistanceText({from,to:to3,units}){let dx2=to3.x-from.x,dy2=to3.y-from.y,distanceInMillimeters=Math.sqrt(dx2*dx2+dy2*dy2),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}})}},Subcircuit=class extends Group6{constructor(props){super({...props,subcircuit:!0})}doInitialInflateSubcircuitCircuitJson(){let{circuitJson,children}=this._parsedProps;inflateCircuitJson(this,circuitJson,children)}},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_group2=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_group2.width??0)+padLeft+padRight,height:(pcb_group2.height??0)+padTop+padBottom,center:{x:pcb_group2.center.x+(padRight-padLeft)/2,y:pcb_group2.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(st2=>st2.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(st2=>st2.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{pcbX,pcbY}=this.getResolvedPcbPositionProp(),group=this.parent?.getGroup(),subcircuit=this.getSubcircuit();if(!group||!group.pcb_group_id)return;let pcb_breakout_point2=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:pcbX,y:pcbY});this.pcb_breakout_point_id=pcb_breakout_point2.pcb_breakout_point_id}_getPcbCircuitJsonBounds(){let{pcbX,pcbY}=this.getResolvedPcbPositionProp();return{center:{x:pcbX,y:pcbY},bounds:{left:pcbX,top:pcbY,right:pcbX,bottom:pcbY},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 point23=db2.pcb_breakout_point.get(this.pcb_breakout_point_id);point23&&db2.pcb_breakout_point.update(this.pcb_breakout_point_id,{x:point23.x+deltaX,y:point23.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(),dx2=connectedPortPosition.x-anchorPos.x,dy2=connectedPortPosition.y-anchorPos.y;if(Math.abs(dx2)>Math.abs(dy2)){if(dx2>0)return"right";if(dx2<0)return"left"}else{if(dy2>0)return"top";if(dy2<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=applyToPoint(this.parent?.computeSchematicGlobalTransform?.()??identity(),{x:0,y:0});return translate(portPos.x-parentCenter.x,portPos.y-parentCenter.y)}}return super.computeSchematicPropsTransform()}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled)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)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(st2=>st2.connected_source_net_ids?.includes(net.source_net_id)&&st2.connected_source_port_ids?.includes(port.source_port_id??""));if(candidateSourceTrace&&(existingTraceForThisConnection=db2.schematic_trace.list().some(t5=>t5.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 st2=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=st2?.source_trace_id,subcircuit_connectivity_map_key=st2?.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})}}},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,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),{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 transform5=this._computePcbGlobalTransformBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_circle2=db2.pcb_silkscreen_circle.insert({pcb_component_id,layer,center:{x:pcbX,y:pcbY},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_circle2.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}})}},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=(decomposeTSR(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(),position2=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_rect2=db2.pcb_silkscreen_rect.insert({pcb_component_id,layer,center:{x:position2.x,y:position2.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_rect2.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}})}},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(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_line2=db2.pcb_silkscreen_line.insert({pcb_component_id,layer,x1:props.x1,y1:props.y1,x2:props.x2,y2:props.y2,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_line2.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})}},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,position2=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_smtpad2=db2.pcb_smtpad.insert({pcb_component_id,layer:maybeFlipLayer(props.layer||"top"),shape:"circle",x:position2.x,y:position2.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_smtpad2.pcb_smtpad_id}getPcbSize(){let{_parsedProps:props}=this,d3=distance.parse(props.padDiameter);return{width:d3,height:d3}}_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(p2=>({x:p2.x+deltaX,y:p2.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),size2=this.getPcbSize();return{center:{x:via.x,y:via.y},bounds:{left:via.x-size2.width/2,top:via.y-size2.height/2,right:via.x+size2.width/2,bottom:via.y+size2.height/2},width:size2.width,height:size2.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),position2=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component2=db2.pcb_component.insert({center:position2,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_component2.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),position2=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_via2=db2.pcb_via.insert({x:position2.x,y:position2.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_via2.pcb_via_id}},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(),sourceNet=db2.toArray().filter(elm=>elm.type==="source_net"&&elm.name===net.name)[0]||"",clearance=props.clearance??.2,inputProblem=convertCircuitJsonToInputProblem(db2.toArray(),{layer:props.layer,pour_connectivity_key:sourceNet.subcircuit_connectivity_map_key||"",pad_margin:props.padMargin??clearance,trace_margin:props.traceMargin??clearance,board_edge_margin:props.boardEdgeMargin??clearance,cutout_margin:props.cutoutMargin??clearance}),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_shape2 of brep_shapes)db2.pcb_copper_pour.insert({shape:"brep",layer:props.layer,brep_shape:brep_shape2,source_net_id:net.source_net_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,covered_with_solder_mask:coveredWithSolderMask})})}},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(),position2=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_copper_text2=db2.pcb_copper_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:position2.x,y:position2.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_text2.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});this.source_component_id=source_component.source_component_id}},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});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"});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"});this.source_component_id=source_component.source_component_id}},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=cf[this._getSchematicSymbolNameOrThrow()],symPort1=symbol.ports.find(p2=>p2.labels.includes("1")),symPort2=symbol.ports.find(p2=>p2.labels.includes("2")),ports=this.selectAll("port"),pin1Port=ports.find(p2=>p2.props.pinNumber===1),pin2Port=ports.find(p2=>p2.props.pinNumber===2),pin3Port=ports.find(p2=>p2.props.pinNumber===3),pin4Port=ports.find(p2=>p2.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});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"});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});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});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"});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});this.source_component_id=source_component.source_component_id}},SchematicText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0)}get config(){return{componentName:"SchematicText",zodProps:schematicTextProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout();db2.schematic_text.insert({anchor:props.anchor??"center",text:normalizeTextForCircuitJson(props.text),font_size:props.fontSize,color:props.color||"#000000",position:{x:globalPos.x,y:globalPos.y},rotation:props.schRotation??0})}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_line2=db2.schematic_line.insert({schematic_component_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_line2.schematic_line_id}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_rect2=db2.schematic_rect.insert({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_rect2.schematic_rect_id}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_arc2=db2.schematic_arc.insert({schematic_component_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_arc2.schematic_arc_id}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_circle2=db2.schematic_circle.insert({schematic_component_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_circle2.schematic_circle_id}};function getTitleAnchorAndPosition({anchor,x:x3,y:y3,width,height,isInside}){switch(anchor){case"top_left":return{x:x3,y:y3+height,textAnchor:isInside?"top_left":"bottom_left"};case"top_center":return{x:x3+width/2,y:y3+height,textAnchor:isInside?"top_center":"bottom_center"};case"top_right":return{x:x3+width,y:y3+height,textAnchor:isInside?"top_right":"bottom_right"};case"center_left":return{x:x3,y:y3+height/2,textAnchor:isInside?"center_left":"center_right"};case"center":return{x:x3+width/2,y:y3+height/2,textAnchor:"center"};case"center_right":return{x:x3+width,y:y3+height/2,textAnchor:isInside?"center_right":"center_left"};case"bottom_left":return{x:x3,y:y3,textAnchor:isInside?"bottom_left":"top_left"};case"bottom_center":return{x:x3+width/2,y:y3,textAnchor:isInside?"bottom_center":"top_center"};case"bottom_right":return{x:x3+width,y:y3,textAnchor:isInside?"bottom_right":"top_right"};default:return{x:x3+width/2,y:y3+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)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,x3,y3,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(p2=>p2.position.x),ys3=portsWithPosition.map(p2=>p2.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,x3=left+(props.schX??0),y3=top+(props.schY??0),centerX=x3+width/2,centerY=y3+height/2}else if(hasFixedSize){width=props.width,height=props.height;let center2=this._getGlobalSchematicPositionBeforeLayout();centerX=center2.x,centerY=center2.y,x3=centerX-width/2,y3=centerY-height/2}else return;if(db2.schematic_box.insert({height,width,x:x3,y:y3,is_dashed:props.strokeStyle==="dashed"}),props.title){let isInside=props.titleInside,TITLE_PADDING=.1,anchor=props.titleAlignment,anchorPos=getTitleAnchorAndPosition({anchor,x:x3,y:y3,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)return;let{db:db2}=this.root,{_parsedProps:props}=this,rows=this.children.filter(c3=>c3.componentName==="SchematicRow");if(rows.length===0)return;let grid4=[],maxCols=0;for(let row of rows){let cells=row.children.filter(c3=>c3.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(c3=>c3.componentName==="SchematicCell"),k4=0;for(let j3=0;j3<cells.length;j3++){for(;grid4[i3][k4];)k4++;let cell=cells[j3],colSpan=cell._parsedProps.colSpan??1,rowSpan=cell._parsedProps.rowSpan??1;for(let r4=0;r4<rowSpan;r4++)for(let c3=0;c3<colSpan;c3++)grid4[i3+r4]||(grid4[i3+r4]=[]),grid4[i3+r4][k4+c3]=cell;k4+=colSpan}}maxCols=Math.max(0,...grid4.map(r4=>r4.length));let rowHeights=rows.map((row,i3)=>row._parsedProps.height??1),colWidths=Array.from({length:maxCols},(_4,j3)=>{let maxWidth=0;for(let i3=0;i3<rows.length;i3++){let cell=grid4[i3]?.[j3];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 j3=0;j3<maxCols;j3++){let cell=grid4[i3]?.[j3];if(cell&&!processedCells.has(cell)){processedCells.add(cell);let cellProps=cell._parsedProps,rowSpan=cellProps.rowSpan??1,colSpan=cellProps.colSpan??1,cellWidth=0;for(let c3=0;c3<colSpan;c3++)cellWidth+=colWidths[j3+c3];let cellHeight=0;for(let r4=0;r4<rowSpan;r4++)cellHeight+=rowHeights[i3+r4];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:j3,end_column_index:j3+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[j3]&&(xOffset+=colWidths[j3])}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)}get config(){return{componentName:"Symbol",zodProps:symbolProps}}},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 cx2,cy2,w4,h2;if(elm.type==="schematic_component")cx2=elm.center?.x,cy2=elm.center?.y,w4=elm.size?.width,h2=elm.size?.height;else if(elm.type==="schematic_text")cx2=elm.position?.x,cy2=elm.position?.y,w4=(elm.text?.length??0)*.1,h2=.2;else return null;return typeof cx2=="number"&&typeof cy2=="number"&&typeof w4=="number"&&typeof h2=="number"?{minX:cx2-w4/2,maxX:cx2+w4/2,minY:cy2-h2/2,maxY:cy2+h2/2}:null}function getOverlapArea(a2,b3){if(!doBoundsOverlap(a2,b3))return 0;let overlapWidth=Math.min(a2.maxX,b3.maxX)-Math.max(a2.minX,b3.minX),overlapHeight=Math.min(a2.maxY,b3.maxY)-Math.max(a2.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(a2=>a2!==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 position2=port._getGlobalSchematicPositionAfterLayout(),targetTraceId=null;for(let trace of db2.schematic_trace.list()){for(let edge of trace.edges)if(Math.abs(edge.from.x-position2.x)<1e-6&&Math.abs(edge.from.y-position2.y)<1e-6||Math.abs(edge.to.x-position2.x)<1e-6&&Math.abs(edge.to.y-position2.y)<1e-6){targetTraceId=trace.schematic_trace_id;break}if(targetTraceId)break}if(!targetTraceId)return;let probeName=this.finalProbeName,labelAlignment=selectBestLabelAlignment({probePosition:position2,labelText:probeName,schematicElements:[...db2.schematic_component.list(),...db2.schematic_text.list()],defaultAlignment:"top_right"}),schematic_voltage_probe2=db2.schematic_voltage_probe.insert({name:probeName,position:position2,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_probe2.schematic_voltage_probe_id}},package_default3={name:"@tscircuit/core",type:"module",version:"0.0.968",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 index.ts --format esm --dts",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/capacity-autorouter":"^0.0.258","@tscircuit/checks":"^0.0.87","@tscircuit/circuit-json-util":"^0.0.75","@tscircuit/common":"^0.0.20","@tscircuit/copper-pour-solver":"^0.0.14","@tscircuit/footprinter":"^0.0.288","@tscircuit/infgrid-ijump-astar":"^0.0.35","@tscircuit/log-soup":"^1.0.2","@tscircuit/matchpack":"^0.0.16","@tscircuit/math-utils":"^0.0.29","@tscircuit/miniflex":"^0.0.4","@tscircuit/ngspice-spice-engine":"^0.0.8","@tscircuit/props":"^0.0.442","@tscircuit/schematic-match-adapt":"^0.0.16","@tscircuit/schematic-trace-solver":"^v0.0.45","@tscircuit/solver-utils":"^0.0.3","@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.350","circuit-json-to-bpc":"^0.0.13","circuit-json-to-connectivity-map":"^0.0.23","circuit-json-to-gltf":"^0.0.31","circuit-json-to-simple-3d":"^0.0.9","circuit-json-to-spice":"^0.0.33","circuit-to-svg":"^0.0.313",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.60",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.206",spicey:"^0.0.14","ts-expect":"^1.3.0",tsup:"^8.2.4","@tscircuit/soup-util":"^0.0.41"},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.68","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","transformation-matrix":"^2.16.1",zod:"^3.25.67"}},RootCircuit=class{constructor({platform,projectUrl}={}){__publicField(this,"firstChild",null);__publicField(this,"children");__publicField(this,"db");__publicField(this,"root",null);__publicField(this,"isRoot",!0);__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,"_eventListeners",{});this.children=[],this.db=su2([]),this.root=this,this.platform=platform,this.projectUrl=projectUrl,this.pcbDisabled=platform?.pcbDisabled??!1}get schematicDisabled(){return this._schematicDisabledOverride!==void 0?this._schematicDisabledOverride: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}}_getBoard(){let directBoard=this.children.find(c3=>c3.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: RootCircuit 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("RootCircuit 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.children.some(child=>child._hasIncompleteAsyncEffects())}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(e4=>{throw new Error(`To use circuit.getSvg, you must install the "circuit-to-svg" package.
|
|
615
|
+
`),position2={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:position2})}doInitialSourceRender(){let nestedBoard=this.getDescendants().find(d3=>d3.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_board2=db2.source_board.insert({source_group_id:this.source_group_id,title:this.props.title||this.props.name});this.source_board_id=source_board2.source_board_id}doInitialInflateSubcircuitCircuitJson(){let{circuitJson,children}=this._parsedProps;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(point23=>point23.x),yValues=props.outline.map(point23=>point23.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 pcb_board2=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(point23=>({x:point23.x+(props.outlineOffsetX??0),y:point23.y+(props.outlineOffsetY??0)})),material:props.material});this.pcb_board_id=pcb_board2.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||this.getInheritedProperty("routingDisabled")||super.doInitialPcbDesignRuleChecks()}updatePcbDesignRuleChecks(){if(this.root?.pcbDisabled||this.getInheritedProperty("routingDisabled"))return;let{db:db2}=this.root;if(!this._areChildSubcircuitsRouted()||this._drcChecksComplete)return;this._drcChecksComplete=!0;let errors=checkEachPcbTraceNonOverlapping(db2.toArray());for(let error of errors)db2.pcb_trace_error.insert(error);let pcbPortNotConnectedErrors=checkEachPcbPortConnectedToPcbTraces(db2.toArray());for(let error of pcbPortNotConnectedErrors)db2.pcb_port_not_connected_error.insert(error);let pcbComponentOutsideErrors=checkPcbComponentsOutOfBoard(db2.toArray());for(let error of pcbComponentOutsideErrors)db2.pcb_component_outside_board_error.insert(error);let pcbTracesOutOfBoardErrors=checkPcbTracesOutOfBoard(db2.toArray());for(let error of pcbTracesOutOfBoardErrors)db2.pcb_trace_error.insert(error);let differentNetViaErrors=checkDifferentNetViaSpacing(db2.toArray());for(let error of differentNetViaErrors)db2.pcb_via_clearance_error.insert(error);let sameNetViaErrors=checkSameNetViaSpacing(db2.toArray());for(let error of sameNetViaErrors)db2.pcb_via_clearance_error.insert(error);let pcbComponentOverlapErrors=checkPcbComponentOverlap(db2.toArray());for(let error of pcbComponentOverlapErrors)db2.pcb_footprint_overlap_error.insert(error);let sourcePinMustBeConnectedErrors=checkPinMustBeConnected(db2.toArray());for(let error of sourcePinMustBeConnectedErrors)db2.source_pin_must_be_connected_error.insert(error)}_emitRenderLifecycleEvent(phase,startOrEnd){super._emitRenderLifecycleEvent(phase,startOrEnd),startOrEnd==="start"&&this.root?.emit("board:renderPhaseStarted",{renderId:this._renderId,phase})}_repositionOnPcb(position2){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:position2});return}let deltaX=position2.x-oldPos.x,deltaY=position2.y-oldPos.y;if(!(Math.abs(deltaX)<1e-6&&Math.abs(deltaY)<1e-6)){for(let child of this.children)if(child instanceof NormalComponent3){let childOldCenter;if(child.pcb_component_id){let comp=db2.pcb_component.get(child.pcb_component_id);comp&&(childOldCenter=comp.center)}else if(child instanceof Group6&&child.pcb_group_id){let group=db2.pcb_group.get(child.pcb_group_id);group&&(childOldCenter=group.center)}childOldCenter&&child._repositionOnPcb({x:childOldCenter.x+deltaX,y:childOldCenter.y+deltaY})}else child.isPcbPrimitive&&"_moveCircuitJsonElements"in child&&typeof child._moveCircuitJsonElements=="function"&&child._moveCircuitJsonElements({deltaX,deltaY});if(this.pcb_board_id&&(db2.pcb_board.update(this.pcb_board_id,{center:position2}),pcbBoard?.outline)){let outlineBounds=getBoundsFromPoints(pcbBoard.outline);if(outlineBounds){let oldOutlineCenter={x:(outlineBounds.minX+outlineBounds.maxX)/2,y:(outlineBounds.minY+outlineBounds.maxY)/2},outlineDeltaX=position2.x-oldOutlineCenter.x,outlineDeltaY=position2.y-oldOutlineCenter.y,newOutline=pcbBoard.outline.map(p2=>({x:p2.x+outlineDeltaX,y:p2.y+outlineDeltaY}));db2.pcb_board.update(this.pcb_board_id,{outline:newOutline})}}}}},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(p2=>point4(p2.x,p2.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),p2=point4(p2_.x,p2_.y),segment2=segment(p12,p2),segmentLength=segment2.length;if(segmentLength<1e-6)continue;let segmentVec=vector$1(p12,p2),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(p2,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,processedBoards=boards.map(board=>{if((!board.outline||board.outline.length===0)&&board.width&&board.height){let w22=board.width/2,h2=board.height/2;return{...board,outline:[{x:board.center.x-w22,y:board.center.y-h2},{x:board.center.x+w22,y:board.center.y-h2},{x:board.center.x+w22,y:board.center.y+h2},{x:board.center.x-w22,y:board.center.y+h2}]}}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 packBoardsIntoGrid=({boards,db:db2,row,col,cellWidth,cellHeight,boardGap})=>{let boardsWithDims=boards.map(board=>{let pcbBoard=db2.pcb_board.get(board.pcb_board_id);return!pcbBoard||pcbBoard.width===void 0||pcbBoard.height===void 0?null:{board,width:pcbBoard.width,height:pcbBoard.height}}).filter(b3=>b3!==null);if(boardsWithDims.length===0)return{positions:[],gridWidth:0,gridHeight:0};let explicitRow=row,cols=col??Math.ceil(explicitRow?boardsWithDims.length/explicitRow:Math.sqrt(boardsWithDims.length)),rows=explicitRow??Math.ceil(boardsWithDims.length/cols),colWidths=Array(cols).fill(0),rowHeights=Array(rows).fill(0);boardsWithDims.forEach((b3,i3)=>{let col2=i3%cols,row2=Math.floor(i3/cols);row2<rowHeights.length&&b3.height>rowHeights[row2]&&(rowHeights[row2]=b3.height),col2<colWidths.length&&b3.width>colWidths[col2]&&(colWidths[col2]=b3.width)});let minCellWidth=cellWidth?distance.parse(cellWidth):0,minCellHeight=cellHeight?distance.parse(cellHeight):0;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 totalGridWidth=colWidths.reduce((a2,b3)=>a2+b3,0)+(cols>1?(cols-1)*boardGap:0),totalGridHeight=rowHeights.reduce((a2,b3)=>a2+b3,0)+(rows>1?(rows-1)*boardGap:0),startX=-totalGridWidth/2,rowYOffsets=[-totalGridHeight/2];for(let i3=1;i3<rows;i3++)rowYOffsets.push(rowYOffsets[i3-1]+rowHeights[i3-1]+boardGap);let colXOffsets=[startX];for(let i3=1;i3<cols;i3++)colXOffsets.push(colXOffsets[i3-1]+colWidths[i3-1]+boardGap);let positions=[];return boardsWithDims.forEach((b3,i3)=>{let col2=i3%cols,row2=Math.floor(i3/cols);if(row2>=rowYOffsets.length||col2>=colXOffsets.length)return;let cellX=colXOffsets[col2],cellY=rowYOffsets[row2],cellWidth2=colWidths[col2],cellHeight2=rowHeights[row2],boardX=cellX+cellWidth2/2,boardY=cellY+cellHeight2/2;positions.push({board:b3.board,pos:{x:boardX,y:boardY}})}),{positions,gridWidth:totalGridWidth,gridHeight:totalGridHeight}},Panel=class extends Group6{constructor(){super(...arguments);__publicField(this,"pcb_panel_id",null);__publicField(this,"_tabsAndMouseBitesGenerated",!1)}get config(){return{componentName:"Panel",zodProps:panelProps}}get isGroup(){return!0}get isSubcircuit(){return!0}add(component){if(component.lowercaseComponentName!=="board")throw new Error("<panel> can only contain <board> elements");super.add(component)}doInitialPanelLayout(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,childBoardInstances=this.children.filter(c3=>c3 instanceof Board),hasAnyPositionedBoards=childBoardInstances.some(b3=>b3.props.pcbX!==void 0||b3.props.pcbY!==void 0),unpositionedBoards=childBoardInstances.filter(b3=>b3.props.pcbX===void 0&&b3.props.pcbY===void 0);if(unpositionedBoards.length>0&&!hasAnyPositionedBoards){let tabWidth=this._parsedProps.tabWidth??DEFAULT_TAB_WIDTH,boardGap=this._parsedProps.boardGap??tabWidth,{positions,gridWidth,gridHeight}=packBoardsIntoGrid({boards:unpositionedBoards,db:db2,row:this._parsedProps.row,col:this._parsedProps.col,cellWidth:this._parsedProps.cellWidth,cellHeight:this._parsedProps.cellHeight,boardGap}),panelGlobalPos=this._getGlobalPcbPositionBeforeLayout();for(let{board,pos}of positions){let absoluteX=panelGlobalPos.x+pos.x,absoluteY=panelGlobalPos.y+pos.y;board._repositionOnPcb({x:absoluteX,y:absoluteY}),db2.pcb_board.update(board.pcb_board_id,{center:{x:absoluteX,y:absoluteY},position_mode:"relative_to_panel_anchor",display_offset_x:`${pos.x}mm`,display_offset_y:`${pos.y}mm`})}let hasExplicitWidth=this._parsedProps.width!==void 0,hasExplicitHeight=this._parsedProps.height!==void 0;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})}}else{let panelGlobalPos=this._getGlobalPcbPositionBeforeLayout();for(let board of childBoardInstances){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`})}}if(this._tabsAndMouseBitesGenerated)return;let props=this._parsedProps;if((props.panelizationMethod??"none")!=="none"){let childBoardIds=childBoardInstances.map(c3=>c3.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}runRenderCycle(){if(!this.children.some(child=>child.componentName==="Board"))throw new Error("<panel> must contain at least one <board>");super.runRenderCycle()}doInitialPcbComponentRender(){if(super.doInitialPcbComponentRender(),this.root?.pcbDisabled)return;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,center:this._getGlobalPcbPositionBeforeLayout(),covered_with_solder_mask:!(props.noSolderMask??!1)});this.pcb_panel_id=inserted.pcb_panel_id}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});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,current2=typeof rawCurrent=="string"?parseFloat(rawCurrent):rawCurrent,voltage2=typeof rawVoltage=="string"?parseFloat(rawVoltage):rawVoltage;return`${formatSiUnit(current2)}A / ${formatSiUnit(voltage2)}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`});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});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(),pcb_component2=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:props.layer??"top",rotation:props.pcbRotation??0,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});this.pcb_component_id=pcb_component2.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(h2=>/^(pin)?\d+$/.test(h2));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});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(c3=>c3.componentName==="Port").map(p2=>p2.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(n3=>n3!==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(n3=>n3!==null))).sort((a2,b3)=>a2-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});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(),pcb_component2=db2.pcb_component.insert({center:{x:pcbX,y:pcbY},width:2,height:3,layer:props.layer??"top",rotation:props.pcbRotation??0,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});this.pcb_component_id=pcb_component2.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(h2=>/^(pin)?\d+$/.test(h2));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});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});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(){}initPorts(){super.initPorts({additionalAliases:{pin1:["terminal1"],pin2:["terminal2"]}})}_getSchematicSymbolDisplayValue(){let{voltage:voltage2,frequency:frequency2}=this._parsedProps,parts=[];return voltage2!==void 0&&parts.push(`${formatSiUnit(voltage2)}V`),frequency2!==void 0&&parts.push(`${formatSiUnit(frequency2)}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});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(){}initPorts(){super.initPorts({additionalAliases:{pin1:["pos"],pin2:["neg"]}})}_getSchematicSymbolDisplayValue(){let{current:current2,frequency:frequency2,peakToPeakCurrent}=this._parsedProps,parts=[];return current2!==void 0&&parts.push(`${formatSiUnit(current2)}A`),peakToPeakCurrent!==void 0&&parts.push(`${formatSiUnit(peakToPeakCurrent)}A p-p`),frequency2!==void 0&&parts.push(`${formatSiUnit(frequency2)}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});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}}},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,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),{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:pcbX,y:pcbY},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}})}},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 transform5=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(p2=>{let transformedPosition=applyToPoint(transform5,{x:p2.x,y:p2.y});return{...p2,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(point23=>typeof point23.x=="string"?parseFloat(point23.x):point23.x),ys3=props.route.map(point23=>typeof point23.y=="string"?parseFloat(point23.y):point23.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(p2=>({...p2,x:p2.x+deltaX,y:p2.y+deltaY}))})}},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,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),container=this.getPrimitiveContainer(),subcircuit=this.getSubcircuit(),pcb_fabrication_note_text2=db2.pcb_fabrication_note_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:pcbX,y:pcbY},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_text2.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}})}}},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,transform5){if(typeof input2=="string"){let target=this.getSubcircuit().selectOne(input2);return target?target._getGlobalPcbPositionBeforeLayout():(this.renderError(`FabricationNoteDimension could not find selector "${input2}"`),applyToPoint(transform5,{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 applyToPoint(transform5,{x:numericX,y:numericY})}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(props.from,transform5),to3=this._resolvePoint(props.to,transform5),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 transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(this._parsedProps.from,transform5),to3=this._resolvePoint(this._parsedProps.to,transform5);return{width:Math.abs(to3.x-from.x),height:Math.abs(to3.y-from.y)}}_formatDistanceText({from,to:to3,units}){let dx2=to3.x-from.x,dy2=to3.y-from.y,distanceInMillimeters=Math.sqrt(dx2*dx2+dy2*dy2),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}`}},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(),transform5=this._computePcbGlobalTransformBeforeLayout(),start=applyToPoint(transform5,{x:props.x1,y:props.y1}),end=applyToPoint(transform5,{x:props.x2,y:props.y2}),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id??void 0,pcb_note_line2=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,stroke_width:props.strokeWidth??.1,color:props.color,is_dashed:props.isDashed});this.pcb_note_line_id=pcb_note_line2.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})}},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,transform5=this._computePcbGlobalTransformBeforeLayout(),center2=applyToPoint(transform5,{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_rect2=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,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_rect2.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,transform5=this._computePcbGlobalTransformBeforeLayout(),anchorPosition=applyToPoint(transform5,{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_text2=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",color:props.color});this.pcb_note_text_id=pcb_note_text2.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}})}},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,transform5=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(point23=>{let{x:x3,y:y3,...rest}=point23,numericX=typeof x3=="string"?parseFloat(x3):x3,numericY=typeof y3=="string"?parseFloat(y3):y3,transformed=applyToPoint(transform5,{x:numericX,y:numericY});return{...rest,x:transformed.x,y:transformed.y}}),pcb_note_path2=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,stroke_width:props.strokeWidth??.1,color:props.color});this.pcb_note_path_id=pcb_note_path2.pcb_note_path_id}getPcbSize(){let{_parsedProps:props}=this;if(props.route.length===0)return{width:0,height:0};let xs3=props.route.map(point23=>typeof point23.x=="string"?parseFloat(point23.x):point23.x),ys3=props.route.map(point23=>typeof point23.y=="string"?parseFloat(point23.y):point23.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(p2=>({...p2,x:p2.x+deltaX,y:p2.y+deltaY}))})}},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,transform5){if(typeof input2=="string"){let target=this.getSubcircuit().selectOne(`.${input2}`);return target?target._getGlobalPcbPositionBeforeLayout():(this.renderError(`PcbNoteDimension could not find selector "${input2}"`),applyToPoint(transform5,{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 applyToPoint(transform5,{x:numericX,y:numericY})}doInitialPcbPrimitiveRender(){if(this.root?.pcbDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(props.from,transform5),to3=this._resolvePoint(props.to,transform5),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_dimension2=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,color:props.color,arrow_size:props.arrowSize??1});this.pcb_note_dimension_id=pcb_note_dimension2.pcb_note_dimension_id}getPcbSize(){let transform5=this._computePcbGlobalTransformBeforeLayout(),from=this._resolvePoint(this._parsedProps.from,transform5),to3=this._resolvePoint(this._parsedProps.to,transform5);return{width:Math.abs(to3.x-from.x),height:Math.abs(to3.y-from.y)}}_formatDistanceText({from,to:to3,units}){let dx2=to3.x-from.x,dy2=to3.y-from.y,distanceInMillimeters=Math.sqrt(dx2*dx2+dy2*dy2),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}})}},Subcircuit=class extends Group6{constructor(props){super({...props,subcircuit:!0})}doInitialInflateSubcircuitCircuitJson(){let{circuitJson,children}=this._parsedProps;inflateCircuitJson(this,circuitJson,children)}},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_group2=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_group2.width??0)+padLeft+padRight,height:(pcb_group2.height??0)+padTop+padBottom,center:{x:pcb_group2.center.x+(padRight-padLeft)/2,y:pcb_group2.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(st2=>st2.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(st2=>st2.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{pcbX,pcbY}=this.getResolvedPcbPositionProp(),group=this.parent?.getGroup(),subcircuit=this.getSubcircuit();if(!group||!group.pcb_group_id)return;let pcb_breakout_point2=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:pcbX,y:pcbY});this.pcb_breakout_point_id=pcb_breakout_point2.pcb_breakout_point_id}_getPcbCircuitJsonBounds(){let{pcbX,pcbY}=this.getResolvedPcbPositionProp();return{center:{x:pcbX,y:pcbY},bounds:{left:pcbX,top:pcbY,right:pcbX,bottom:pcbY},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 point23=db2.pcb_breakout_point.get(this.pcb_breakout_point_id);point23&&db2.pcb_breakout_point.update(this.pcb_breakout_point_id,{x:point23.x+deltaX,y:point23.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(),dx2=connectedPortPosition.x-anchorPos.x,dy2=connectedPortPosition.y-anchorPos.y;if(Math.abs(dx2)>Math.abs(dy2)){if(dx2>0)return"right";if(dx2<0)return"left"}else{if(dy2>0)return"top";if(dy2<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=applyToPoint(this.parent?.computeSchematicGlobalTransform?.()??identity(),{x:0,y:0});return translate(portPos.x-parentCenter.x,portPos.y-parentCenter.y)}}return super.computeSchematicPropsTransform()}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled)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)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(st2=>st2.connected_source_net_ids?.includes(net.source_net_id)&&st2.connected_source_port_ids?.includes(port.source_port_id??""));if(candidateSourceTrace&&(existingTraceForThisConnection=db2.schematic_trace.list().some(t5=>t5.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 st2=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=st2?.source_trace_id,subcircuit_connectivity_map_key=st2?.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})}}},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,{pcbX,pcbY}=this.getResolvedPcbPositionProp(),{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 transform5=this._computePcbGlobalTransformBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_circle2=db2.pcb_silkscreen_circle.insert({pcb_component_id,layer,center:{x:pcbX,y:pcbY},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_circle2.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}})}},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=(decomposeTSR(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(),position2=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_rect2=db2.pcb_silkscreen_rect.insert({pcb_component_id,layer,center:{x:position2.x,y:position2.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_rect2.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}})}},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(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_silkscreen_line2=db2.pcb_silkscreen_line.insert({pcb_component_id,layer,x1:props.x1,y1:props.y1,x2:props.x2,y2:props.y2,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_line2.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})}},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,position2=this._getGlobalPcbPositionBeforeLayout(),{maybeFlipLayer}=this._getPcbPrimitiveFlippedHelpers(),pcb_component_id=this.parent?.pcb_component_id??this.getPrimitiveContainer()?.pcb_component_id,pcb_smtpad2=db2.pcb_smtpad.insert({pcb_component_id,layer:maybeFlipLayer(props.layer||"top"),shape:"circle",x:position2.x,y:position2.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_smtpad2.pcb_smtpad_id}getPcbSize(){let{_parsedProps:props}=this,d3=distance.parse(props.padDiameter);return{width:d3,height:d3}}_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(p2=>({x:p2.x+deltaX,y:p2.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),size2=this.getPcbSize();return{center:{x:via.x,y:via.y},bounds:{left:via.x-size2.width/2,top:via.y-size2.height/2,right:via.x+size2.width/2,bottom:via.y+size2.height/2},width:size2.width,height:size2.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),position2=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_component2=db2.pcb_component.insert({center:position2,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_component2.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),position2=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_via2=db2.pcb_via.insert({x:position2.x,y:position2.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_via2.pcb_via_id}},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(),sourceNet=db2.toArray().filter(elm=>elm.type==="source_net"&&elm.name===net.name)[0]||"",clearance=props.clearance??.2,inputProblem=convertCircuitJsonToInputProblem(db2.toArray(),{layer:props.layer,pour_connectivity_key:sourceNet.subcircuit_connectivity_map_key||"",pad_margin:props.padMargin??clearance,trace_margin:props.traceMargin??clearance,board_edge_margin:props.boardEdgeMargin??clearance,cutout_margin:props.cutoutMargin??clearance}),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_shape2 of brep_shapes)db2.pcb_copper_pour.insert({shape:"brep",layer:props.layer,brep_shape:brep_shape2,source_net_id:net.source_net_id,subcircuit_id:subcircuit?.subcircuit_id??void 0,covered_with_solder_mask:coveredWithSolderMask})})}},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(),position2=this._getGlobalPcbPositionBeforeLayout(),subcircuit=this.getSubcircuit(),pcb_copper_text2=db2.pcb_copper_text.insert({anchor_alignment:props.anchorAlignment,anchor_position:{x:position2.x,y:position2.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_text2.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});this.source_component_id=source_component.source_component_id}},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});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"});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"});this.source_component_id=source_component.source_component_id}},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=cf[this._getSchematicSymbolNameOrThrow()],symPort1=symbol.ports.find(p2=>p2.labels.includes("1")),symPort2=symbol.ports.find(p2=>p2.labels.includes("2")),ports=this.selectAll("port"),pin1Port=ports.find(p2=>p2.props.pinNumber===1),pin2Port=ports.find(p2=>p2.props.pinNumber===2),pin3Port=ports.find(p2=>p2.props.pinNumber===3),pin4Port=ports.find(p2=>p2.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});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"});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});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});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"});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});this.source_component_id=source_component.source_component_id}},SchematicText=class extends PrimitiveComponent2{constructor(){super(...arguments);__publicField(this,"isSchematicPrimitive",!0)}get config(){return{componentName:"SchematicText",zodProps:schematicTextProps}}doInitialSchematicPrimitiveRender(){if(this.root?.schematicDisabled)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout();db2.schematic_text.insert({anchor:props.anchor??"center",text:normalizeTextForCircuitJson(props.text),font_size:props.fontSize,color:props.color||"#000000",position:{x:globalPos.x,y:globalPos.y},rotation:props.schRotation??0})}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_line2=db2.schematic_line.insert({schematic_component_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_line2.schematic_line_id}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_rect2=db2.schematic_rect.insert({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_rect2.schematic_rect_id}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_arc2=db2.schematic_arc.insert({schematic_component_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_arc2.schematic_arc_id}},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)return;let{db:db2}=this.root,{_parsedProps:props}=this,globalPos=this._getGlobalSchematicPositionBeforeLayout(),schematic_component_id=this.getPrimitiveContainer()?.parent?.schematic_component_id,schematic_circle2=db2.schematic_circle.insert({schematic_component_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_circle2.schematic_circle_id}};function getTitleAnchorAndPosition({anchor,x:x3,y:y3,width,height,isInside}){switch(anchor){case"top_left":return{x:x3,y:y3+height,textAnchor:isInside?"top_left":"bottom_left"};case"top_center":return{x:x3+width/2,y:y3+height,textAnchor:isInside?"top_center":"bottom_center"};case"top_right":return{x:x3+width,y:y3+height,textAnchor:isInside?"top_right":"bottom_right"};case"center_left":return{x:x3,y:y3+height/2,textAnchor:isInside?"center_left":"center_right"};case"center":return{x:x3+width/2,y:y3+height/2,textAnchor:"center"};case"center_right":return{x:x3+width,y:y3+height/2,textAnchor:isInside?"center_right":"center_left"};case"bottom_left":return{x:x3,y:y3,textAnchor:isInside?"bottom_left":"top_left"};case"bottom_center":return{x:x3+width/2,y:y3,textAnchor:isInside?"bottom_center":"top_center"};case"bottom_right":return{x:x3+width,y:y3,textAnchor:isInside?"bottom_right":"top_right"};default:return{x:x3+width/2,y:y3+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)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,x3,y3,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(p2=>p2.position.x),ys3=portsWithPosition.map(p2=>p2.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,x3=left+(props.schX??0),y3=top+(props.schY??0),centerX=x3+width/2,centerY=y3+height/2}else if(hasFixedSize){width=props.width,height=props.height;let center2=this._getGlobalSchematicPositionBeforeLayout();centerX=center2.x,centerY=center2.y,x3=centerX-width/2,y3=centerY-height/2}else return;if(db2.schematic_box.insert({height,width,x:x3,y:y3,is_dashed:props.strokeStyle==="dashed"}),props.title){let isInside=props.titleInside,TITLE_PADDING=.1,anchor=props.titleAlignment,anchorPos=getTitleAnchorAndPosition({anchor,x:x3,y:y3,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)return;let{db:db2}=this.root,{_parsedProps:props}=this,rows=this.children.filter(c3=>c3.componentName==="SchematicRow");if(rows.length===0)return;let grid4=[],maxCols=0;for(let row of rows){let cells=row.children.filter(c3=>c3.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(c3=>c3.componentName==="SchematicCell"),k4=0;for(let j3=0;j3<cells.length;j3++){for(;grid4[i3][k4];)k4++;let cell=cells[j3],colSpan=cell._parsedProps.colSpan??1,rowSpan=cell._parsedProps.rowSpan??1;for(let r4=0;r4<rowSpan;r4++)for(let c3=0;c3<colSpan;c3++)grid4[i3+r4]||(grid4[i3+r4]=[]),grid4[i3+r4][k4+c3]=cell;k4+=colSpan}}maxCols=Math.max(0,...grid4.map(r4=>r4.length));let rowHeights=rows.map((row,i3)=>row._parsedProps.height??1),colWidths=Array.from({length:maxCols},(_4,j3)=>{let maxWidth=0;for(let i3=0;i3<rows.length;i3++){let cell=grid4[i3]?.[j3];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 j3=0;j3<maxCols;j3++){let cell=grid4[i3]?.[j3];if(cell&&!processedCells.has(cell)){processedCells.add(cell);let cellProps=cell._parsedProps,rowSpan=cellProps.rowSpan??1,colSpan=cellProps.colSpan??1,cellWidth=0;for(let c3=0;c3<colSpan;c3++)cellWidth+=colWidths[j3+c3];let cellHeight=0;for(let r4=0;r4<rowSpan;r4++)cellHeight+=rowHeights[i3+r4];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:j3,end_column_index:j3+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[j3]&&(xOffset+=colWidths[j3])}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)}get config(){return{componentName:"Symbol",zodProps:symbolProps}}},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 cx2,cy2,w4,h2;if(elm.type==="schematic_component")cx2=elm.center?.x,cy2=elm.center?.y,w4=elm.size?.width,h2=elm.size?.height;else if(elm.type==="schematic_text")cx2=elm.position?.x,cy2=elm.position?.y,w4=(elm.text?.length??0)*.1,h2=.2;else return null;return typeof cx2=="number"&&typeof cy2=="number"&&typeof w4=="number"&&typeof h2=="number"?{minX:cx2-w4/2,maxX:cx2+w4/2,minY:cy2-h2/2,maxY:cy2+h2/2}:null}function getOverlapArea(a2,b3){if(!doBoundsOverlap(a2,b3))return 0;let overlapWidth=Math.min(a2.maxX,b3.maxX)-Math.max(a2.minX,b3.minX),overlapHeight=Math.min(a2.maxY,b3.maxY)-Math.max(a2.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(a2=>a2!==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 position2=port._getGlobalSchematicPositionAfterLayout(),targetTraceId=null;for(let trace of db2.schematic_trace.list()){for(let edge of trace.edges)if(Math.abs(edge.from.x-position2.x)<1e-6&&Math.abs(edge.from.y-position2.y)<1e-6||Math.abs(edge.to.x-position2.x)<1e-6&&Math.abs(edge.to.y-position2.y)<1e-6){targetTraceId=trace.schematic_trace_id;break}if(targetTraceId)break}if(!targetTraceId)return;let probeName=this.finalProbeName,labelAlignment=selectBestLabelAlignment({probePosition:position2,labelText:probeName,schematicElements:[...db2.schematic_component.list(),...db2.schematic_text.list()],defaultAlignment:"top_right"}),schematic_voltage_probe2=db2.schematic_voltage_probe.insert({name:probeName,position:position2,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_probe2.schematic_voltage_probe_id}},package_default3={name:"@tscircuit/core",type:"module",version:"0.0.969",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 index.ts --format esm --dts",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/capacity-autorouter":"^0.0.259","@tscircuit/checks":"^0.0.87","@tscircuit/circuit-json-util":"^0.0.75","@tscircuit/common":"^0.0.20","@tscircuit/copper-pour-solver":"^0.0.14","@tscircuit/footprinter":"^0.0.288","@tscircuit/infgrid-ijump-astar":"^0.0.35","@tscircuit/log-soup":"^1.0.2","@tscircuit/matchpack":"^0.0.16","@tscircuit/math-utils":"^0.0.29","@tscircuit/miniflex":"^0.0.4","@tscircuit/ngspice-spice-engine":"^0.0.8","@tscircuit/props":"^0.0.442","@tscircuit/schematic-match-adapt":"^0.0.16","@tscircuit/schematic-trace-solver":"^v0.0.45","@tscircuit/solver-utils":"^0.0.3","@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.350","circuit-json-to-bpc":"^0.0.13","circuit-json-to-connectivity-map":"^0.0.23","circuit-json-to-gltf":"^0.0.31","circuit-json-to-simple-3d":"^0.0.9","circuit-json-to-spice":"^0.0.33","circuit-to-svg":"^0.0.313",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.60",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.206",spicey:"^0.0.14","ts-expect":"^1.3.0",tsup:"^8.2.4","@tscircuit/soup-util":"^0.0.41"},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.68","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","transformation-matrix":"^2.16.1",zod:"^3.25.67"}},RootCircuit=class{constructor({platform,projectUrl}={}){__publicField(this,"firstChild",null);__publicField(this,"children");__publicField(this,"db");__publicField(this,"root",null);__publicField(this,"isRoot",!0);__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,"_eventListeners",{});this.children=[],this.db=su2([]),this.root=this,this.platform=platform,this.projectUrl=projectUrl,this.pcbDisabled=platform?.pcbDisabled??!1}get schematicDisabled(){return this._schematicDisabledOverride!==void 0?this._schematicDisabledOverride: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}}_getBoard(){let directBoard=this.children.find(c3=>c3.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: RootCircuit 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("RootCircuit 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.children.some(child=>child._hasIncompleteAsyncEffects())}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(e4=>{throw new Error(`To use circuit.getSvg, you must install the "circuit-to-svg" package.
|
|
616
616
|
|
|
617
617
|
"${e4.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(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(l2=>l2!==listener))}enableDebug(debug112){typeof debug112=="string"?import_debug18.default.enable(debug112):(debug112===null||debug112===!1)&&import_debug18.default.disable()}getClientOrigin(){return typeof window<"u"&&window.location?window.location.origin:typeof self<"u"&&self.location?self.location.origin:""}},Project=RootCircuit,Circuit=RootCircuit,useRenderedCircuit=reactElements=>{let[isLoading,setIsLoading]=import_react5.default.useState(!0),[error,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(error2){setError(error2)}setIsLoading(!1)},1)},[reactElements]),{isLoading,error,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 R4=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)R4[port]=`.${name} > .${port}`;return R4},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(p2=>prop1.startsWith(p2))?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 getFootprinterStringFromKicad=kicadFootprint=>{let match2=kicadFootprint.match(/:[RC]_(\d{4})_/);if(match2||(match2=kicadFootprint.match(/:(SOIC-\d+|SOT-\d+|SOD-\d+|SSOP-\d+|TSSOP-\d+|QFP-\d+|QFN-\d+)/),match2))return match2[1]};var getJlcPackageFromFootprinterString=footprinterString=>footprinterString.includes("cap")?footprinterString.replace(/cap/g,""):footprinterString;var getJlcpcbPackageName=footprint=>{if(footprint){if(footprint.startsWith("kicad:")){let footprinterString=getFootprinterStringFromKicad(footprint);return footprinterString?getJlcPackageFromFootprinterString(footprinterString):footprint}return getJlcPackageFromFootprinterString(footprint)}};var cache=new Map,getJlcPartsCached=async(name,params)=>{let paramString=new URLSearchParams({...params,json:"true"}).toString();if(cache.has(paramString))return cache.get(paramString);let responseJson=await(await fetch(`https://jlcsearch.tscircuit.com/${name}/list?${paramString}`)).json();return cache.set(paramString,responseJson),responseJson},withBasicPartPreference=parts=>parts?[...parts].sort((a2,b3)=>Number(b3.is_basic??!1)-Number(a2.is_basic??!1)):[],jlcPartsEngine={findPart:async({sourceComponent,footprinterString})=>{let jlcpcbPackage=getJlcpcbPackageName(footprinterString);if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_resistor"){let{resistors}=await getJlcPartsCached("resistors",{resistance:sourceComponent.resistance,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(resistors).map(r4=>`C${r4.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_capacitor"){let{capacitors}=await getJlcPartsCached("capacitors",{capacitance:sourceComponent.capacitance,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(capacitors).map(c3=>`C${c3.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_pin_header"){let pitch;footprinterString?.includes("_p")&&(pitch=Number(footprinterString.split("_p")[1]));let{headers}=await getJlcPartsCached("headers",pitch?{pitch,num_pins:sourceComponent.pin_count,gender:sourceComponent.gender}:{num_pins:sourceComponent.pin_count,gender:sourceComponent.gender});return{jlcpcb:withBasicPartPreference(headers).map(h2=>`C${h2.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_potentiometer"){let{potentiometers}=await getJlcPartsCached("potentiometers",{resistance:sourceComponent.max_resistance,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(potentiometers).map(p2=>`C${p2.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_diode"){let{diodes}=await getJlcPartsCached("diodes",{package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(diodes).map(d3=>`C${d3.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_chip"){let{chips}=await getJlcPartsCached("chips",{package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(chips).map(c3=>`C${c3.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_transistor"){let{transistors}=await getJlcPartsCached("transistors",{package:jlcpcbPackage,transistor_type:sourceComponent.transistor_type});return{jlcpcb:withBasicPartPreference(transistors).map(t5=>`C${t5.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_power_source"){let{power_sources}=await getJlcPartsCached("power_sources",{voltage:sourceComponent.voltage,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(power_sources).map(p2=>`C${p2.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_inductor"){let{inductors}=await getJlcPartsCached("inductors",{inductance:sourceComponent.inductance,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(inductors).map(i3=>`C${i3.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_crystal"){let{crystals}=await getJlcPartsCached("crystals",{frequency:sourceComponent.frequency,load_capacitance:sourceComponent.load_capacitance,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(crystals).map(c3=>`C${c3.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_mosfet"){let{mosfets}=await getJlcPartsCached("mosfets",{package:jlcpcbPackage,mosfet_mode:sourceComponent.mosfet_mode,channel_type:sourceComponent.channel_type});return{jlcpcb:withBasicPartPreference(mosfets).map(m3=>`C${m3.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_resonator"){let{resonators}=await getJlcPartsCached("resonators",{frequency:sourceComponent.frequency,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(resonators).map(r4=>`C${r4.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_switch"){let{switches}=await getJlcPartsCached("switches",{switch_type:sourceComponent.type,package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(switches).map(s3=>`C${s3.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_led"){let{leds}=await getJlcPartsCached("leds",{package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(leds).map(l2=>`C${l2.lcsc}`).slice(0,3)}}else if(sourceComponent.type==="source_component"&&sourceComponent.ftype==="simple_fuse"){let{fuses}=await getJlcPartsCached("fuses",{package:jlcpcbPackage});return{jlcpcb:withBasicPartPreference(fuses).map(l2=>`C${l2.lcsc}`).slice(0,3)}}return{}}};var import_s_expression=__toESM(require_s_expression(),1);init_zod();var import_debug19=__toESM(require_browser(),1),import_debug20=__toESM(require_browser(),1),point22=external_exports.tuple([external_exports.coerce.number(),external_exports.coerce.number()]),point33=external_exports.tuple([external_exports.number(),external_exports.number(),external_exports.number()]),point5=external_exports.union([point22,point33]),fp_poly_arc_segment_def=external_exports.object({kind:external_exports.literal("arc"),start:point22,mid:point22,end:point22}),fp_poly_point_def=external_exports.union([point22,fp_poly_arc_segment_def]),attributes_def=external_exports.object({at:point5,size:point22,layer:external_exports.string(),layers:external_exports.array(external_exports.string()),roundrect_rratio:external_exports.number(),uuid:external_exports.string()}).partial(),property_def=external_exports.object({key:external_exports.string(),val:external_exports.string(),attributes:attributes_def}),drill_def=external_exports.object({oval:external_exports.boolean().default(!1),width:external_exports.number().optional(),height:external_exports.number().optional(),offset:point22.optional()}),hole_def=external_exports.object({name:external_exports.string(),pad_type:external_exports.enum(["thru_hole","smd","np_thru_hole","connect"]),pad_shape:external_exports.enum(["roundrect","circle","rect","oval","trapezoid","custom"]),at:point5,drill:external_exports.union([external_exports.number(),external_exports.array(external_exports.any()),drill_def]).transform(a2=>typeof a2=="number"?{oval:!1,width:a2,height:a2}:"oval"in a2?a2:a2.length===2?{oval:!1,width:Number.parseFloat(a2[0]),height:Number.parseFloat(a2[0]),offset:point22.parse(a2[1].slice(1))}:a2.length===3||a2.length===4?{oval:a2[0]==="oval",width:Number.parseFloat(a2[1]),height:Number.parseFloat(a2[2]),offset:a2[3]?point22.parse(a2[3].slice(1)):void 0}:a2).pipe(drill_def),size:external_exports.union([external_exports.array(external_exports.number()).length(2).transform(([w4,h2])=>({width:w4,height:h2})),external_exports.object({width:external_exports.number(),height:external_exports.number()})]),layers:external_exports.array(external_exports.string()).optional(),roundrect_rratio:external_exports.number().optional(),uuid:external_exports.string().optional()}),pad_def2=external_exports.object({name:external_exports.string(),pad_type:external_exports.enum(["thru_hole","smd","np_thru_hole","connect"]),pad_shape:external_exports.enum(["roundrect","circle","rect","oval","trapezoid","custom"]),at:point5,size:point22,drill:external_exports.union([external_exports.number(),external_exports.array(external_exports.any()),drill_def]).transform(a2=>typeof a2=="number"?{oval:!1,width:a2,height:a2}:"oval"in a2?a2:a2.length===2?{oval:!1,width:Number.parseFloat(a2[0]),height:Number.parseFloat(a2[0]),offset:point22.parse(a2[1].slice(1))}:a2.length===3||a2.length===4?{oval:a2[0]==="oval",width:Number.parseFloat(a2[1]),height:Number.parseFloat(a2[2]),offset:a2[3]?point22.parse(a2[3].slice(1)):void 0}:a2).pipe(drill_def).optional(),layers:external_exports.array(external_exports.string()).optional(),roundrect_rratio:external_exports.number().optional(),chamfer_ratio:external_exports.number().optional(),solder_paste_margin:external_exports.number().optional(),solder_paste_margin_ratio:external_exports.number().optional(),clearance:external_exports.number().optional(),zone_connection:external_exports.union([external_exports.literal(0).describe("Pad is not connect to zone"),external_exports.literal(1).describe("Pad is connected to zone using thermal relief"),external_exports.literal(2).describe("Pad is connected to zone using solid fill")]).optional(),thermal_width:external_exports.number().optional(),thermal_gap:external_exports.number().optional(),uuid:external_exports.string().optional()}),effects_def=external_exports.object({font:external_exports.object({size:point22,thickness:external_exports.number().optional()})}).partial(),fp_text_def=external_exports.object({fp_text_type:external_exports.literal("user"),text:external_exports.string(),at:point5,layer:external_exports.string(),uuid:external_exports.string().optional(),effects:effects_def.partial()}),fp_arc_def=external_exports.object({start:point22,mid:point22,end:point22,stroke:external_exports.object({width:external_exports.number(),type:external_exports.string()}),layer:external_exports.string(),uuid:external_exports.string().optional()}),fp_circle_def=external_exports.object({center:point22,end:point22,stroke:external_exports.object({width:external_exports.number(),type:external_exports.string()}),fill:external_exports.string().optional(),layer:external_exports.string(),uuid:external_exports.string().optional()}),fp_poly_def=external_exports.object({pts:external_exports.array(fp_poly_point_def),stroke:external_exports.object({width:external_exports.number(),type:external_exports.string()}).optional(),width:external_exports.number().optional(),layer:external_exports.string(),uuid:external_exports.string().optional(),fill:external_exports.string().optional()}).transform(data=>({...data,width:void 0,stroke:data.stroke??{width:data.width}})),fp_line=external_exports.object({start:point22,end:point22,stroke:external_exports.object({width:external_exports.number(),type:external_exports.string()}).optional(),width:external_exports.number().optional(),layer:external_exports.string(),uuid:external_exports.string().optional()}).transform(data=>({...data,width:void 0,stroke:data.stroke??{width:data.width}})),kicad_mod_json_def=external_exports.object({footprint_name:external_exports.string(),version:external_exports.string().optional(),generator:external_exports.string().optional(),generator_version:external_exports.string().optional(),layer:external_exports.string(),descr:external_exports.string().default(""),tags:external_exports.array(external_exports.string()).optional(),properties:external_exports.array(property_def),fp_lines:external_exports.array(fp_line),fp_texts:external_exports.array(fp_text_def),fp_arcs:external_exports.array(fp_arc_def),fp_circles:external_exports.array(fp_circle_def).optional(),fp_polys:external_exports.array(fp_poly_def).optional(),pads:external_exports.array(pad_def2),holes:external_exports.array(hole_def).optional()}),formatAttr=(val,attrKey)=>{if(attrKey==="effects"&&Array.isArray(val)){let effectsObj={};for(let elm of val)if(elm[0]==="font"){let fontObj={};for(let fontElm of elm.slice(1))fontElm.length===2?fontObj[fontElm[0].valueOf()]=Number.parseFloat(fontElm[1].valueOf()):fontObj[fontElm[0].valueOf()]=fontElm.slice(1).map(n3=>Number.parseFloat(n3.valueOf()));effectsObj.font=fontObj}return effects_def.parse(effectsObj)}if(attrKey==="pts")return val.map(segment2=>{let segmentType=segment2[0]?.valueOf?.()??segment2[0];if(segmentType==="xy")return segment2.slice(1).map(n3=>Number.parseFloat(n3.valueOf()));if(segmentType==="arc"){let arcObj={kind:"arc"};for(let arcAttr of segment2.slice(1)){let key=arcAttr[0].valueOf();arcObj[key]=arcAttr.slice(1).map(n3=>Number.parseFloat(n3.valueOf()))}return arcObj}return segment2});if(attrKey==="stroke"){let strokeObj={};for(let strokeElm of val){let strokePropKey=strokeElm[0].valueOf();strokeObj[strokePropKey]=formatAttr(strokeElm.slice(1),strokePropKey)}return strokeObj}return attrKey==="at"||attrKey==="size"||attrKey==="start"||attrKey==="mid"||attrKey==="end"?(Array.isArray(val)?val:[val]).map(n3=>n3?.valueOf?.()??n3).filter(v4=>typeof v4=="number"||typeof v4=="string"&&/^[-+]?\d*\.?\d+(e[-+]?\d+)?$/i.test(v4)).map(v4=>typeof v4=="number"?v4:Number.parseFloat(v4)):attrKey==="tags"?val.map(n3=>n3.valueOf()):attrKey==="generator_version"||attrKey==="version"?val[0].valueOf():val.length===2?val.valueOf():attrKey==="uuid"?Array.isArray(val)?val[0].valueOf():val.valueOf():/^[\d\.]+$/.test(val)&&!Number.isNaN(Number.parseFloat(val))?Number.parseFloat(val):Array.isArray(val)&&val.length===1?val[0].valueOf():Array.isArray(val)?val.map(s3=>s3.valueOf()):val},getAttr=(s3,key)=>{for(let elm of s3)if(Array.isArray(elm)&&elm[0]===key)return formatAttr(elm.slice(1),key)},debug11=(0,import_debug19.default)("kicad-mod-converter"),parseKicadModToKicadJson=fileContent=>{let kicadSExpr=(0,import_s_expression.default)(fileContent),footprintName=kicadSExpr[1].valueOf(),topLevelAttributes={},simpleTopLevelAttributes=Object.entries(kicad_mod_json_def.shape).filter(([attributeKey,def])=>def._def.typeName==="ZodString"||attributeKey==="tags").map(([attributeKey])=>attributeKey);for(let kicadSExprRow of kicadSExpr.slice(2)){if(!simpleTopLevelAttributes.includes(kicadSExprRow[0]))continue;let key=kicadSExprRow[0].valueOf(),val=formatAttr(kicadSExprRow.slice(1),key);topLevelAttributes[key]=val}let properties=kicadSExpr.slice(2).filter(row=>row[0]==="property").map(row=>{let key=row[1].valueOf(),val=row[2].valueOf(),attributes2=attributes_def.parse(row.slice(3).reduce((acc,attrAr)=>{let attrKey=attrAr[0].valueOf();return acc[attrKey]=formatAttr(attrAr.slice(1),attrKey),acc},{}));return{key,val,attributes:attributes2}}),padRows=kicadSExpr.slice(2).filter(row=>row[0]==="pad"),pads=[];for(let row of padRows){let at3=getAttr(row,"at"),size2=getAttr(row,"size"),drill=getAttr(row,"drill"),layers=getAttr(row,"layers");if(Array.isArray(layers)?layers=layers.map(layer=>layer.valueOf()):typeof layers=="string"?layers=[layers]:layers||(layers=[]),!layers.includes("F.Cu")){debug11(`Skipping pad without F.Cu layer: layers=${layers.join(", ")}`);continue}let roundrect_rratio=getAttr(row,"roundrect_rratio"),uuid=getAttr(row,"uuid"),padRaw={name:row[1].valueOf(),pad_type:row[2].valueOf(),pad_shape:row[3].valueOf(),at:at3,drill,size:size2,layers,roundrect_rratio,uuid};debug11(`attempting to parse pad: ${JSON.stringify(padRaw,null," ")}`),pads.push(pad_def2.parse(padRaw))}let fp_texts_rows=kicadSExpr.slice(2).filter(row=>row[0]==="fp_text"),fp_texts=[];for(let fp_text_row of fp_texts_rows){let text=fp_text_row[2].valueOf(),at3=getAttr(fp_text_row,"at"),layer=getAttr(fp_text_row,"layer"),uuid=getAttr(fp_text_row,"uuid"),effects=getAttr(fp_text_row,"effects");fp_texts.push({fp_text_type:"user",text,at:at3,layer,uuid,effects})}let fp_lines=[],fp_lines_rows=kicadSExpr.slice(2).filter(row=>row[0]==="fp_line");for(let fp_line_row of fp_lines_rows){let start=getAttr(fp_line_row,"start"),end=getAttr(fp_line_row,"end"),stroke=getAttr(fp_line_row,"stroke"),layer=getAttr(fp_line_row,"layer"),uuid=getAttr(fp_line_row,"uuid");fp_lines.push({start,end,stroke,layer,uuid})}let fp_arcs=[],fp_arcs_rows=kicadSExpr.slice(2).filter(row=>row[0]==="fp_arc");for(let fp_arc_row of fp_arcs_rows){let start=getAttr(fp_arc_row,"start"),mid=getAttr(fp_arc_row,"mid"),end=getAttr(fp_arc_row,"end"),stroke=getAttr(fp_arc_row,"stroke"),layer=getAttr(fp_arc_row,"layer"),uuid=getAttr(fp_arc_row,"uuid");!start||!end||!mid||!stroke||!layer||fp_arcs.push({start,mid,end,stroke,layer,uuid})}let fp_circles=[],fp_circles_rows=kicadSExpr.slice(2).filter(row=>row[0]==="fp_circle");for(let fp_circle_row of fp_circles_rows){let center2=getAttr(fp_circle_row,"center"),end=getAttr(fp_circle_row,"end"),stroke=getAttr(fp_circle_row,"stroke"),fill=getAttr(fp_circle_row,"fill"),layer=getAttr(fp_circle_row,"layer"),uuid=getAttr(fp_circle_row,"uuid");!center2||!end||!stroke||!layer||fp_circles.push({center:center2,end,stroke,fill,layer,uuid})}let fp_polys=[],fp_polys_rows=kicadSExpr.slice(2).filter(row=>row[0]==="fp_poly");for(let fp_poly_row of fp_polys_rows){let pts=getAttr(fp_poly_row,"pts"),stroke=getAttr(fp_poly_row,"stroke"),width=getAttr(fp_poly_row,"width"),layer=getAttr(fp_poly_row,"layer"),uuid=getAttr(fp_poly_row,"uuid"),fill=getAttr(fp_poly_row,"fill"),normalizedStroke=stroke;!normalizedStroke&&typeof width=="number"?normalizedStroke={width,type:"solid"}:normalizedStroke&&typeof normalizedStroke=="object"&&typeof width=="number"&&normalizedStroke.width===void 0&&(normalizedStroke={...normalizedStroke,width}),fp_polys.push({pts,stroke:normalizedStroke,layer,uuid,fill})}let holes=[];for(let row of kicadSExpr.slice(2)){if(row[0]!=="pad"||row[2]?.valueOf?.()!=="thru_hole")continue;let name=row[1]?.valueOf?.(),pad_type=row[2]?.valueOf?.(),pad_shape=row[3]?.valueOf?.(),at3=getAttr(row,"at"),drill=getAttr(row,"drill"),size2=getAttr(row,"size");Array.isArray(size2)&&(size2[0]==="size"&&(size2=size2.slice(1)),size2={width:Number(size2[0]),height:Number(size2[1])});let uuid=getAttr(row,"uuid"),roundrect_rratio=getAttr(row,"roundrect_rratio"),layers=getAttr(row,"layers");Array.isArray(layers)?layers=layers.map(layer=>layer.valueOf()):typeof layers=="string"?layers=[layers]:layers||(layers=[]);let holeRaw={name,pad_type,pad_shape,at:at3,drill,size:size2,layers,roundrect_rratio,uuid};debug11(`attempting to parse holes: ${JSON.stringify(holeRaw,null,2)}`),holes.push(hole_def.parse(holeRaw))}return kicad_mod_json_def.parse({footprint_name:footprintName,...topLevelAttributes,properties,fp_lines,fp_texts,fp_arcs,fp_circles,pads,holes,fp_polys})},TWO_PI=Math.PI*2,normalizeAngle2=angle=>{let result=angle%TWO_PI;return result<0&&(result+=TWO_PI),result},directedAngleCCW=(start,target)=>{let startNorm=normalizeAngle2(start),delta=normalizeAngle2(target)-startNorm;return delta<0&&(delta+=TWO_PI),delta};function calculateCenter(start,mid,end){let mid1={x:(start.x+mid.x)/2,y:(start.y+mid.y)/2},mid2={x:(mid.x+end.x)/2,y:(mid.y+end.y)/2},slope1=-(start.x-mid.x)/(start.y-mid.y),slope2=-(mid.x-end.x)/(mid.y-end.y),centerX=(mid1.y-mid2.y+slope2*mid2.x-slope1*mid1.x)/(slope2-slope1),centerY=mid1.y+slope1*(centerX-mid1.x);return{x:centerX,y:centerY}}function calculateRadius(center2,point42){return Math.sqrt((center2.x-point42.x)**2+(center2.y-point42.y)**2)}function calculateAngle(center2,point42){return Math.atan2(point42.y-center2.y,point42.x-center2.x)}var getArcLength=(start,mid,end)=>{let center2=calculateCenter(start,mid,end),radius=calculateRadius(center2,start),angleStart=calculateAngle(center2,start),angleMid=calculateAngle(center2,mid),angleEnd=calculateAngle(center2,end),ccwToMid=directedAngleCCW(angleStart,angleMid),ccwToEnd=directedAngleCCW(angleStart,angleEnd),angleDelta=ccwToEnd;return ccwToMid>ccwToEnd&&(angleDelta=ccwToEnd-TWO_PI),Math.abs(radius*angleDelta)};function generateArcPath(start,mid,end,numPoints){let center2=calculateCenter(start,mid,end),radius=calculateRadius(center2,start),angleStart=calculateAngle(center2,start),angleMid=calculateAngle(center2,mid),angleEnd=calculateAngle(center2,end),ccwToMid=directedAngleCCW(angleStart,angleMid),ccwToEnd=directedAngleCCW(angleStart,angleEnd),angleDelta=ccwToEnd;ccwToMid>ccwToEnd&&(angleDelta=ccwToEnd-TWO_PI);let path=[];for(let i3=0;i3<=numPoints;i3++){let angle=angleStart+i3/numPoints*angleDelta,x3=center2.x+radius*Math.cos(angle),y3=center2.y+radius*Math.sin(angle);path.push({x:x3,y:y3})}return path}var makePoint=p2=>Array.isArray(p2)?{x:p2[0],y:p2[1]}:p2,pointsEqual=(p12,p2,tolerance=1e-4)=>Math.abs(p12.x-p2.x)<tolerance&&Math.abs(p12.y-p2.y)<tolerance,findClosedPolygons=segments=>{let polygons=[],used=new Set;for(let i3=0;i3<segments.length;i3++){if(used.has(i3))continue;let polygon2=[segments[i3]];used.add(i3);let currentEnd=segments[i3].end,foundNext=!0;for(;foundNext;){if(foundNext=!1,polygon2.length>1&&pointsEqual(currentEnd,polygon2[0].start)){polygons.push(polygon2);break}for(let j3=0;j3<segments.length;j3++)if(!used.has(j3)){if(pointsEqual(currentEnd,segments[j3].start)){polygon2.push(segments[j3]),used.add(j3),currentEnd=segments[j3].end,foundNext=!0;break}else if(pointsEqual(currentEnd,segments[j3].end)){segments[j3].type==="arc"?polygon2.push({...segments[j3],reversed:!0}):polygon2.push({...segments[j3],start:segments[j3].end,end:segments[j3].start}),used.add(j3),currentEnd=segments[j3].start,foundNext=!0;break}}if(!foundNext){for(let k4=polygon2.length-1;k4>=0;k4--){let idx=segments.indexOf(polygon2[k4]);idx!==-1&&used.delete(idx)}break}}}return polygons},polygonToPoints=polygon2=>{let points=[];for(let segment2 of polygon2)if(segment2.type==="line")points.push(segment2.start);else if(segment2.type==="arc"&&segment2.mid){let arcLength=getArcLength(segment2.start,segment2.mid,segment2.end),numPoints=Math.max(3,Math.ceil(arcLength)),arcPoints=generateArcPath(segment2.start,segment2.mid,segment2.end,numPoints);segment2.reversed&&(arcPoints=arcPoints.reverse()),points.push(...arcPoints.slice(0,-1))}return points};function getSilkscreenFontSizeFromFpTexts(fp_texts){if(!Array.isArray(fp_texts))return null;let refText=fp_texts.find(t5=>t5.layer?.toLowerCase()==="f.silks"&&(t5.text?.includes("${REFERENCE}")||t5.fp_text_type?.toLowerCase()==="reference"||t5.text?.match(/^R\d+|C\d+|U\d+/))),fallbackText=refText||fp_texts.find(t5=>t5.layer?.toLowerCase()==="f.fab"&&(t5.text?.includes("${REFERENCE}")||t5.fp_text_type?.toLowerCase()==="reference")),target=refText||fallbackText;if(!target?.effects?.font?.size)return null;let[width,height]=target.effects.font.size;return height??width??1}var degToRad=deg=>deg*Math.PI/180,rotatePoint3=(x3,y3,deg)=>{let r4=degToRad(deg),cos4=Math.cos(r4),sin4=Math.sin(r4);return{x:x3*cos4-y3*sin4,y:x3*sin4+y3*cos4}},getAxisAlignedRectFromPoints=points=>{let uniquePoints=[...new Map(points.map(p2=>[`${p2.x},${p2.y}`,p2])).values()];if(uniquePoints.length!==4)return null;let xs3=uniquePoints.map(p2=>p2.x),ys3=uniquePoints.map(p2=>p2.y),uniqueXs=[...new Set(xs3)],uniqueYs=[...new Set(ys3)];if(uniqueXs.length!==2||uniqueYs.length!==2)return null;let[minX,maxX]=uniqueXs.sort((a2,b3)=>a2-b3),[minY,maxY]=uniqueYs.sort((a2,b3)=>a2-b3);return minX===void 0||maxX===void 0||minY===void 0||maxY===void 0?null:{x:(minX+maxX)/2,y:(minY+maxY)/2,width:maxX-minX,height:maxY-minY}},fpPolyHasFill=fill=>{if(!fill)return!1;let normalized=fill.toLowerCase();return normalized!=="no"&&normalized!=="none"&&normalized!=="outline"},getRotationDeg=at3=>at3&&Array.isArray(at3)&&at3.length>=3&&typeof at3[2]=="number"?at3[2]:0,isNinetyLike=deg=>{let n3=(deg%360+360)%360;return n3===90||n3===270},normalizePortName=name=>{if(name!=null)return`${name}`},getPinNumber=name=>{let normalized=normalizePortName(name),parsed=normalized!==void 0?Number(normalized):NaN;return Number.isFinite(parsed)?parsed:void 0},debug23=(0,import_debug20.default)("kicad-mod-converter"),convertKicadLayerToTscircuitLayer=kicadLayer=>{switch(kicadLayer.toLowerCase()){case"f.cu":case"f.fab":case"f.silks":case"edge.cuts":return"top";case"b.cu":case"b.fab":case"b.silks":return"bottom"}},convertKicadJsonToTsCircuitSoup=async kicadJson=>{let{fp_lines,fp_texts,fp_arcs,fp_circles,pads,properties,holes,fp_polys}=kicadJson,circuitJson=[];circuitJson.push({type:"source_component",source_component_id:"source_component_0",supplier_part_numbers:{}}),circuitJson.push({type:"schematic_component",schematic_component_id:"schematic_component_0",source_component_id:"source_component_0",center:{x:0,y:0},rotation:0,size:{width:0,height:0}});let portNames=new Set,portNameToPinNumber=new Map;for(let pad2 of pads){let portName=normalizePortName(pad2.name);if(portName){portNames.add(portName);let pinNumber=getPinNumber(pad2.name);pinNumber!==void 0&&portNameToPinNumber.set(portName,pinNumber)}}if(holes)for(let hole of holes){let portName=normalizePortName(hole.name);if(portName){portNames.add(portName);let pinNumber=getPinNumber(hole.name);pinNumber!==void 0&&portNameToPinNumber.set(portName,pinNumber)}}let sourcePortId=0,portNameToSourcePortId=new Map;for(let portName of portNames){let source_port_id=`source_port_${sourcePortId++}`;portNameToSourcePortId.set(portName,source_port_id);let pinNumber=portNameToPinNumber.get(portName);circuitJson.push({type:"source_port",source_port_id,source_component_id:"source_component_0",name:portName,port_hints:[portName],pin_number:pinNumber,pin_label:pinNumber!==void 0?`pin${pinNumber}`:void 0}),circuitJson.push({type:"schematic_port",schematic_port_id:`schematic_port_${sourcePortId++}`,source_port_id,schematic_component_id:"schematic_component_0",center:{x:0,y:0}})}let minX=Number.POSITIVE_INFINITY,maxX=Number.NEGATIVE_INFINITY,minY=Number.POSITIVE_INFINITY,maxY=Number.NEGATIVE_INFINITY;for(let pad2 of pads){let x3=pad2.at[0],y3=-pad2.at[1],w4=pad2.size[0],h2=pad2.size[1];minX=Math.min(minX,x3-w4/2),maxX=Math.max(maxX,x3+w4/2),minY=Math.min(minY,y3-h2/2),maxY=Math.max(maxY,y3+h2/2)}let pcb_component_id="pcb_component_0";circuitJson.push({type:"pcb_component",source_component_id:"source_component_0",pcb_component_id,layer:"top",center:{x:0,y:0},rotation:0,width:Number.isFinite(minX)?maxX-minX:0,height:Number.isFinite(minY)?maxY-minY:0});let pcbPortId=0,portNameToPcbPortId=new Map;for(let portName of portNames){let pcb_port_id=`pcb_port_${pcbPortId++}`,source_port_id=portNameToSourcePortId.get(portName);portNameToPcbPortId.set(portName,pcb_port_id);let x3=0,y3=0,layers=["top","bottom"],pad2=pads.find(p2=>normalizePortName(p2.name)===portName);if(pad2)x3=pad2.at[0],y3=-pad2.at[1],layers=pad2.layers?pad2.layers.map(l2=>convertKicadLayerToTscircuitLayer(l2)).filter(Boolean):["top","bottom"];else if(holes){let hole=holes.find(h2=>normalizePortName(h2.name)===portName);hole&&(x3=hole.at[0],y3=-hole.at[1],layers=hole.layers?hole.layers.map(l2=>convertKicadLayerToTscircuitLayer(l2)).filter(Boolean):["top","bottom"])}circuitJson.push({type:"pcb_port",pcb_port_id,source_port_id,pcb_component_id,x:x3,y:y3,layers})}let smtpadId=0,platedHoleId=0,holeId=0;for(let pad2 of pads){let portName=normalizePortName(pad2.name),pinNumber=portName?portNameToPinNumber.get(portName):void 0;if(pad2.pad_type==="smd"){let rotation4=getRotationDeg(pad2.at),width=isNinetyLike(rotation4)?pad2.size[1]:pad2.size[0],height=isNinetyLike(rotation4)?pad2.size[0]:pad2.size[1],pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0,pinLabel=pinNumber!==void 0?`pin${pinNumber}`:void 0;circuitJson.push({type:"pcb_smtpad",pcb_smtpad_id:`pcb_smtpad_${smtpadId++}`,shape:"rect",x:pad2.at[0],y:-pad2.at[1],width,height,layer:convertKicadLayerToTscircuitLayer(pad2.layers?.[0]??"F.Cu"),pcb_component_id,port_hints:pinLabel?[pinLabel]:portName?[portName]:[],pcb_port_id,pin_number:pinNumber,pin_label:pinLabel})}else if(pad2.pad_type==="thru_hole"){if(pad2.pad_shape==="rect"){let rotation4=getRotationDeg(pad2.at),width=isNinetyLike(rotation4)?pad2.size[1]:pad2.size[0],height=isNinetyLike(rotation4)?pad2.size[0]:pad2.size[1],offX=pad2.drill?.offset?.[0]??0,offY=pad2.drill?.offset?.[1]??0,rotOff=rotatePoint3(offX,offY,rotation4),pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0,pinLabel=pinNumber!==void 0?`pin${pinNumber}`:void 0;circuitJson.push({type:"pcb_plated_hole",pcb_plated_hole_id:`pcb_plated_hole_${platedHoleId++}`,shape:"circular_hole_with_rect_pad",hole_shape:"circle",pad_shape:"rect",x:pad2.at[0],y:-pad2.at[1],hole_offset_x:-rotOff.x,hole_offset_y:-rotOff.y,hole_diameter:pad2.drill?.width,rect_pad_width:width,rect_pad_height:height,layers:["top","bottom"],pcb_component_id,port_hints:pinLabel?[pinLabel]:portName?[portName]:[],pcb_port_id,pin_number:pinNumber,pin_label:pinLabel})}else if(pad2.pad_shape==="circle"){let pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0,pinLabel=pinNumber!==void 0?`pin${pinNumber}`:void 0;circuitJson.push({type:"pcb_plated_hole",pcb_plated_hole_id:`pcb_plated_hole_${platedHoleId++}`,shape:"circle",x:pad2.at[0],y:-pad2.at[1],outer_diameter:pad2.size[0],hole_diameter:pad2.drill?.width,layers:["top","bottom"],pcb_component_id,port_hints:pinLabel?[pinLabel]:portName?[portName]:[],pcb_port_id,pin_number:pinNumber,pin_label:pinLabel})}else if(pad2.pad_shape==="oval"){let pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0,pinLabel=pinNumber!==void 0?`pin${pinNumber}`:void 0;circuitJson.push({type:"pcb_plated_hole",pcb_plated_hole_id:`pcb_plated_hole_${platedHoleId++}`,shape:"pill",x:pad2.at[0],y:-pad2.at[1],outer_width:pad2.size[0],outer_height:pad2.size[1],hole_width:pad2.drill?.width,hole_height:pad2.drill?.height,layers:["top","bottom"],pcb_component_id,port_hints:pinLabel?[pinLabel]:portName?[portName]:[],pcb_port_id,pin_number:pinNumber,pin_label:pinLabel})}}else pad2.pad_type==="np_thru_hole"&&circuitJson.push({type:"pcb_hole",pcb_hole_id:`pcb_hole_${holeId++}`,x:pad2.at[0],y:-pad2.at[1],hole_diameter:pad2.drill?.width,pcb_component_id})}if(holes)for(let hole of holes){let portName=normalizePortName(hole.name),pinNumber=portName?portNameToPinNumber.get(portName):void 0,hasCuLayer=hole.layers?.some(l2=>l2.endsWith(".Cu")||l2==="*.Cu"),rotation4=getRotationDeg(hole.at),offX=hole.drill?.offset?.[0]??0,offY=hole.drill?.offset?.[1]??0,rotOff=rotatePoint3(offX,offY,rotation4),x3=hole.at[0]+rotOff.x,y3=-(hole.at[1]+rotOff.y),holeDiameter=hole.drill?.width??0,outerDiameter=hole.size?.width??holeDiameter,rr3=hole.roundrect_rratio??0,rectBorderRadius=rr3>0?Math.min(isNinetyLike(rotation4)?hole.size?.height??outerDiameter:hole.size?.width??outerDiameter,isNinetyLike(rotation4)?hole.size?.width??outerDiameter:hole.size?.height??outerDiameter)/2*rr3:0;if(hasCuLayer)if(hole.pad_shape==="rect"){let pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0;circuitJson.push({type:"pcb_plated_hole",pcb_plated_hole_id:`pcb_plated_hole_${platedHoleId++}`,shape:"circular_hole_with_rect_pad",hole_shape:"circle",pad_shape:"rect",x:hole.at[0],y:-hole.at[1],hole_offset_x:-rotOff.x,hole_offset_y:-rotOff.y,hole_diameter:holeDiameter,rect_pad_width:isNinetyLike(rotation4)?hole.size?.height??outerDiameter:hole.size?.width??outerDiameter,rect_pad_height:isNinetyLike(rotation4)?hole.size?.width??outerDiameter:hole.size?.height??outerDiameter,rect_border_radius:rectBorderRadius,port_hints:pinNumber!==void 0?[`pin${pinNumber}`]:portName?[portName]:[],layers:["top","bottom"],pcb_component_id,pcb_port_id,pin_number:pinNumber,pin_label:pinNumber!==void 0?`pin${pinNumber}`:void 0})}else if(hole.pad_shape==="oval"){let pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0;circuitJson.push({type:"pcb_plated_hole",pcb_plated_hole_id:`pcb_plated_hole_${platedHoleId++}`,shape:"pill",x:x3,y:y3,outer_width:isNinetyLike(rotation4)?hole.size?.height??outerDiameter:hole.size?.width??outerDiameter,outer_height:isNinetyLike(rotation4)?hole.size?.width??outerDiameter:hole.size?.height??outerDiameter,hole_width:isNinetyLike(rotation4)?hole.drill?.height??holeDiameter:hole.drill?.width??holeDiameter,hole_height:isNinetyLike(rotation4)?hole.drill?.width??holeDiameter:hole.drill?.height??holeDiameter,port_hints:pinNumber!==void 0?[`pin${pinNumber}`]:portName?[portName]:[],layers:["top","bottom"],pcb_component_id,pcb_port_id,pin_number:pinNumber,pin_label:pinNumber!==void 0?`pin${pinNumber}`:void 0})}else if(hole.pad_shape==="roundrect"){let pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0,offX2=hole.drill?.offset?.[0]??0,offY2=hole.drill?.offset?.[1]??0,rotOff2=rotatePoint3(offX2,offY2,rotation4),width=isNinetyLike(rotation4)?hole.size?.height??outerDiameter:hole.size?.width??outerDiameter,height=isNinetyLike(rotation4)?hole.size?.width??outerDiameter:hole.size?.height??outerDiameter;circuitJson.push({type:"pcb_plated_hole",pcb_plated_hole_id:`pcb_plated_hole_${platedHoleId++}`,shape:"circular_hole_with_rect_pad",hole_shape:"circle",pad_shape:"rect",x:x3,y:y3,hole_offset_x:-rotOff2.x,hole_offset_y:rotOff2.y,hole_diameter:holeDiameter,rect_pad_width:width,rect_pad_height:height,rect_border_radius:rectBorderRadius,port_hints:pinNumber!==void 0?[`pin${pinNumber}`]:portName?[portName]:[],layers:["top","bottom"],pcb_component_id,pcb_port_id,pin_number:pinNumber,pin_label:pinNumber!==void 0?`pin${pinNumber}`:void 0})}else{let pcb_port_id=portName?portNameToPcbPortId.get(portName):void 0;circuitJson.push({type:"pcb_plated_hole",pcb_plated_hole_id:`pcb_plated_hole_${platedHoleId++}`,shape:"circle",x:x3,y:y3,outer_diameter:outerDiameter,hole_diameter:holeDiameter,port_hints:pinNumber!==void 0?[`pin${pinNumber}`]:portName?[portName]:[],layers:["top","bottom"],pcb_component_id,pcb_port_id,pin_number:pinNumber,pin_label:pinNumber!==void 0?`pin${pinNumber}`:void 0})}else circuitJson.push({type:"pcb_hole",pcb_hole_id:`pcb_hole_${holeId++}`,x:x3,y:y3,hole_diameter:outerDiameter,hole_shape:"circle",pcb_component_id})}let edgeCutSegments=[];for(let fp_line2 of fp_lines)fp_line2.layer.toLowerCase()==="edge.cuts"&&edgeCutSegments.push({type:"line",start:{x:fp_line2.start[0],y:fp_line2.start[1]},end:{x:fp_line2.end[0],y:fp_line2.end[1]},strokeWidth:fp_line2.stroke.width});for(let fp_arc of fp_arcs)fp_arc.layer.toLowerCase()==="edge.cuts"&&edgeCutSegments.push({type:"arc",start:{x:fp_arc.start[0],y:fp_arc.start[1]},mid:{x:fp_arc.mid[0],y:fp_arc.mid[1]},end:{x:fp_arc.end[0],y:fp_arc.end[1]},strokeWidth:fp_arc.stroke.width});let closedPolygons=findClosedPolygons(edgeCutSegments),cutoutId=0;for(let polygon2 of closedPolygons){let points=polygonToPoints(polygon2);points.length>=3&&circuitJson.push({type:"pcb_cutout",pcb_cutout_id:`pcb_cutout_${cutoutId++}`,shape:"polygon",points:points.map(p2=>({x:p2.x,y:-p2.y})),pcb_component_id})}let traceId=0,silkPathId=0,fabPathId=0,noteLineId=0;for(let fp_line2 of fp_lines){let route=[{x:fp_line2.start[0],y:-fp_line2.start[1]},{x:fp_line2.end[0],y:-fp_line2.end[1]}],lowerLayer=fp_line2.layer.toLowerCase();lowerLayer==="f.cu"?circuitJson.push({type:"pcb_trace",pcb_trace_id:`pcb_trace_${traceId++}`,pcb_component_id,layer:convertKicadLayerToTscircuitLayer(fp_line2.layer),route,thickness:fp_line2.stroke.width}):lowerLayer==="f.silks"?circuitJson.push({type:"pcb_silkscreen_path",pcb_silkscreen_path_id:`pcb_silkscreen_path_${silkPathId++}`,pcb_component_id,layer:"top",route,stroke_width:fp_line2.stroke.width}):lowerLayer==="edge.cuts"?debug23("Skipping Edge.Cuts fp_line (converted to pcb_cutout)",fp_line2.layer):lowerLayer==="f.fab"?circuitJson.push({type:"pcb_fabrication_note_path",fabrication_note_path_id:`fabrication_note_path_${fabPathId++}`,pcb_component_id,layer:"top",route,stroke_width:fp_line2.stroke.width,port_hints:[]}):lowerLayer.startsWith("user.")?circuitJson.push({type:"pcb_note_line",pcb_note_line_id:`pcb_note_line_${noteLineId++}`,pcb_component_id,x1:fp_line2.start[0],y1:-fp_line2.start[1],x2:fp_line2.end[0],y2:-fp_line2.end[1],stroke_width:fp_line2.stroke.width}):debug23("Unhandled layer for fp_line",fp_line2.layer)}if(fp_polys)for(let fp_poly of fp_polys){let route=[],pushRoutePoint=point42=>{!Number.isFinite(point42.x)||!Number.isFinite(point42.y)||route.push(point42)};for(let segment2 of fp_poly.pts){if(Array.isArray(segment2)){pushRoutePoint({x:segment2[0],y:-segment2[1]});continue}if(segment2&&typeof segment2=="object"&&"kind"in segment2){if(segment2.kind==="arc"){let start=makePoint(segment2.start),mid=makePoint(segment2.mid),end=makePoint(segment2.end),arcLength=getArcLength(start,mid,end),numPoints=Math.max(8,Math.ceil(arcLength)),adjustedNumPoints=Math.max(2,Math.ceil(arcLength/.1)),arcPoints=generateArcPath(start,mid,end,adjustedNumPoints).map(p2=>({x:p2.x,y:-p2.y}));for(let point42 of arcPoints)pushRoutePoint(point42)}continue}}let routePoints=route,polygonPoints=routePoints.length>2&&routePoints[0].x===routePoints[routePoints.length-1].x&&routePoints[0].y===routePoints[routePoints.length-1].y?routePoints.slice(0,-1):routePoints;if(routePoints.length===0)continue;let strokeWidth=fp_poly.stroke?.width??0;if(fp_poly.layer.endsWith(".Cu")){let rect=getAxisAlignedRectFromPoints(polygonPoints);rect?circuitJson.push({type:"pcb_smtpad",pcb_smtpad_id:`pcb_smtpad_${smtpadId++}`,shape:"rect",x:rect.x,y:rect.y,width:rect.width,height:rect.height,layer:convertKicadLayerToTscircuitLayer(fp_poly.layer),pcb_component_id}):fpPolyHasFill(fp_poly.fill)?polygonPoints.length>=3?circuitJson.push({type:"pcb_smtpad",pcb_smtpad_id:`pcb_smtpad_${smtpadId++}`,shape:"polygon",points:polygonPoints,layer:convertKicadLayerToTscircuitLayer(fp_poly.layer),pcb_component_id}):polygonPoints.length>=2&&circuitJson.push({type:"pcb_trace",pcb_trace_id:`pcb_trace_${traceId++}`,pcb_component_id,layer:convertKicadLayerToTscircuitLayer(fp_poly.layer),route:polygonPoints,thickness:strokeWidth}):polygonPoints.length>=2&&circuitJson.push({type:"pcb_trace",pcb_trace_id:`pcb_trace_${traceId++}`,pcb_component_id,layer:convertKicadLayerToTscircuitLayer(fp_poly.layer),route:polygonPoints,thickness:strokeWidth})}else fp_poly.layer.endsWith(".SilkS")?circuitJson.push({type:"pcb_silkscreen_path",pcb_silkscreen_path_id:`pcb_silkscreen_path_${silkPathId++}`,pcb_component_id,layer:convertKicadLayerToTscircuitLayer(fp_poly.layer),route:routePoints,stroke_width:strokeWidth}):fp_poly.layer.endsWith(".Fab")?circuitJson.push({type:"pcb_fabrication_note_path",fabrication_note_path_id:`fabrication_note_path_${fabPathId++}`,pcb_component_id,layer:convertKicadLayerToTscircuitLayer(fp_poly.layer),route:polygonPoints,stroke_width:strokeWidth,port_hints:[]}):debug23("Unhandled layer for fp_poly",fp_poly.layer)}let notePathId=0;for(let fp_arc of fp_arcs){let lowerLayer=fp_arc.layer.toLowerCase();if(lowerLayer==="edge.cuts"){debug23("Skipping Edge.Cuts fp_arc (converted to pcb_cutout)",fp_arc.layer);continue}let start=makePoint(fp_arc.start),mid=makePoint(fp_arc.mid),end=makePoint(fp_arc.end),arcLength=getArcLength(start,mid,end),arcPoints=generateArcPath(start,mid,end,Math.ceil(arcLength));if(lowerLayer.startsWith("user.")){circuitJson.push({type:"pcb_note_path",pcb_note_path_id:`pcb_note_path_${notePathId++}`,pcb_component_id,route:arcPoints.map(p2=>({x:p2.x,y:-p2.y})),stroke_width:fp_arc.stroke.width});continue}let tscircuitLayer=convertKicadLayerToTscircuitLayer(fp_arc.layer);if(!tscircuitLayer){debug23("Unable to convert layer for fp_arc",fp_arc.layer);continue}circuitJson.push({type:"pcb_silkscreen_path",pcb_silkscreen_path_id:`pcb_silkscreen_path_${silkPathId++}`,layer:tscircuitLayer,pcb_component_id,route:arcPoints.map(p2=>({x:p2.x,y:-p2.y})),stroke_width:fp_arc.stroke.width})}if(fp_circles)for(let fp_circle of fp_circles){let lowerLayer=fp_circle.layer.toLowerCase(),center2=makePoint(fp_circle.center),endPoint=makePoint(fp_circle.end),radius=Math.sqrt((endPoint.x-center2.x)**2+(endPoint.y-center2.y)**2),numPoints=Math.max(16,Math.ceil(2*Math.PI*radius)),circlePoints=[];for(let i3=0;i3<=numPoints;i3++){let angle=i3/numPoints*2*Math.PI;circlePoints.push({x:center2.x+radius*Math.cos(angle),y:center2.y+radius*Math.sin(angle)})}lowerLayer.startsWith("user.")&&circuitJson.push({type:"pcb_note_path",pcb_note_path_id:`pcb_note_path_${notePathId++}`,pcb_component_id,route:circlePoints.map(p2=>({x:p2.x,y:-p2.y})),stroke_width:fp_circle.stroke.width})}for(let fp_text of fp_texts){let layerRef=convertKicadLayerToTscircuitLayer(fp_text.layer);fp_text.layer.endsWith(".SilkS")?circuitJson.push({type:"pcb_silkscreen_text",layer:layerRef,font:"tscircuit2024",font_size:fp_text.effects?.font?.size[0]??1,pcb_component_id,anchor_position:{x:fp_text.at[0],y:-fp_text.at[1]},anchor_alignment:"center",text:fp_text.text}):fp_text.layer.endsWith(".Fab")?circuitJson.push({type:"pcb_fabrication_note_text",layer:layerRef,font:"tscircuit2024",font_size:fp_text.effects?.font?.size[0]??1,pcb_component_id,anchor_position:{x:fp_text.at[0],y:-fp_text.at[1]},anchor_alignment:"center",text:fp_text.text}):debug23("Unhandled layer for fp_text",fp_text.layer)}let refProp=properties.find(prop=>prop.key==="Reference"),valProp=properties.find(prop=>prop.key==="Value"),propFabTexts=[refProp,valProp].filter(p2=>p2&&!!p2.val);for(let propFab of propFabTexts){let at3=propFab.attributes.at;if(!at3)continue;let isFabLayer=propFab.attributes.layer?.toLowerCase()?.endsWith(".fab"),font_size=getSilkscreenFontSizeFromFpTexts(fp_texts);circuitJson.push({type:isFabLayer?"pcb_fabrication_note_text":"pcb_silkscreen_text",layer:"top",font:"tscircuit2024",font_size,pcb_component_id,anchor_position:{x:at3[0],y:-at3[1]},anchor_alignment:"center",text:propFab.val})}return circuitJson},parseKicadModToCircuitJson=async kicadMod=>{let kicadJson=parseKicadModToKicadJson(kicadMod);return await convertKicadJsonToTsCircuitSoup(kicadJson)};var dynamicallyLoadDependencyWithCdnBackup=async packageName=>{try{return(await import(packageName)).default}catch{console.log(`Failed to load ${packageName} locally, trying CDN fallback...`);try{let res2=await fetch(`https://cdn.jsdelivr.net/npm/${packageName}/+esm`);if(!res2.ok)throw new Error(`Failed to fetch ${packageName} from CDN: ${res2.statusText}`);let code=await res2.text(),blob=new Blob([code],{type:"application/javascript"}),url=URL.createObjectURL(blob);try{let{default:loadedModule}=await import(url);return loadedModule}finally{URL.revokeObjectURL(url)}}catch(cdnError){throw console.error(`CDN fallback for ${packageName} also failed:`,cdnError),cdnError}}};var KICAD_FOOTPRINT_CACHE_URL="https://kicad-mod-cache.tscircuit.com",ngspiceEngineCache=null,getPlatformConfig=()=>({partsEngine:jlcPartsEngine,spiceEngineMap:{ngspice:{simulate:async spice=>{if(!ngspiceEngineCache){let createNgspiceSpiceEngine=await dynamicallyLoadDependencyWithCdnBackup("@tscircuit/ngspice-spice-engine").catch(error=>{throw new Error("Could not load ngspice engine from local node_modules or CDN fallback.",{cause:error})});createNgspiceSpiceEngine&&(ngspiceEngineCache=await createNgspiceSpiceEngine())}if(!ngspiceEngineCache)throw new Error("Could not load ngspice engine from local node_modules or CDN fallback.");return ngspiceEngineCache.simulate(spice)}}},footprintLibraryMap:{kicad:async footprintName=>{let baseUrl=`${KICAD_FOOTPRINT_CACHE_URL}/${footprintName}`,circuitJsonUrl=`${baseUrl}.circuit.json`,raw=await(await fetch(circuitJsonUrl)).json(),filtered=Array.isArray(raw)?raw.filter(el2=>el2?.type==="pcb_silkscreen_text"?el2?.text==="REF**":!0):raw,wrlUrl=`${baseUrl}.wrl`;return{footprintCircuitJson:filtered,cadModel:{wrlUrl,modelUnitToMmScale:2.54}}}},footprintFileParserMap:{kicad_mod:{loadFromUrl:async url=>{let kicadContent=await fetch(url).then(res2=>res2.text()),kicadJson=await parseKicadModToCircuitJson(kicadContent);return{footprintCircuitJson:Array.isArray(kicadJson)?kicadJson:[kicadJson]}}}}});var tslib_es6_exports={};__export(tslib_es6_exports,{__addDisposableResource:()=>__addDisposableResource,__assign:()=>__assign,__asyncDelegator:()=>__asyncDelegator,__asyncGenerator:()=>__asyncGenerator,__asyncValues:()=>__asyncValues,__await:()=>__await,__awaiter:()=>__awaiter,__classPrivateFieldGet:()=>__classPrivateFieldGet,__classPrivateFieldIn:()=>__classPrivateFieldIn,__classPrivateFieldSet:()=>__classPrivateFieldSet,__createBinding:()=>__createBinding,__decorate:()=>__decorate,__disposeResources:()=>__disposeResources,__esDecorate:()=>__esDecorate,__exportStar:()=>__exportStar,__extends:()=>__extends,__generator:()=>__generator,__importDefault:()=>__importDefault,__importStar:()=>__importStar,__makeTemplateObject:()=>__makeTemplateObject,__metadata:()=>__metadata,__param:()=>__param,__propKey:()=>__propKey,__read:()=>__read,__rest:()=>__rest,__rewriteRelativeImportExtension:()=>__rewriteRelativeImportExtension,__runInitializers:()=>__runInitializers,__setFunctionName:()=>__setFunctionName,__spread:()=>__spread,__spreadArray:()=>__spreadArray,__spreadArrays:()=>__spreadArrays,__values:()=>__values,default:()=>tslib_es6_default});var extendStatics=function(d3,b3){return extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(d4,b4){d4.__proto__=b4}||function(d4,b4){for(var p2 in b4)Object.prototype.hasOwnProperty.call(b4,p2)&&(d4[p2]=b4[p2])},extendStatics(d3,b3)};function __extends(d3,b3){if(typeof b3!="function"&&b3!==null)throw new TypeError("Class extends value "+String(b3)+" is not a constructor or null");extendStatics(d3,b3);function __(){this.constructor=d3}d3.prototype=b3===null?Object.create(b3):(__.prototype=b3.prototype,new __)}var __assign=function(){return __assign=Object.assign||function(t5){for(var s3,i3=1,n3=arguments.length;i3<n3;i3++){s3=arguments[i3];for(var p2 in s3)Object.prototype.hasOwnProperty.call(s3,p2)&&(t5[p2]=s3[p2])}return t5},__assign.apply(this,arguments)};function __rest(s3,e4){var t5={};for(var p2 in s3)Object.prototype.hasOwnProperty.call(s3,p2)&&e4.indexOf(p2)<0&&(t5[p2]=s3[p2]);if(s3!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i3=0,p2=Object.getOwnPropertySymbols(s3);i3<p2.length;i3++)e4.indexOf(p2[i3])<0&&Object.prototype.propertyIsEnumerable.call(s3,p2[i3])&&(t5[p2[i3]]=s3[p2[i3]]);return t5}function __decorate(decorators,target,key,desc){var c3=arguments.length,r4=c3<3?target:desc===null?desc=Object.getOwnPropertyDescriptor(target,key):desc,d3;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r4=Reflect.decorate(decorators,target,key,desc);else for(var i3=decorators.length-1;i3>=0;i3--)(d3=decorators[i3])&&(r4=(c3<3?d3(r4):c3>3?d3(target,key,r4):d3(target,key))||r4);return c3>3&&r4&&Object.defineProperty(target,key,r4),r4}function __param(paramIndex,decorator){return function(target,key){decorator(target,key,paramIndex)}}function __esDecorate(ctor,descriptorIn,decorators,contextIn,initializers,extraInitializers){function accept(f2){if(f2!==void 0&&typeof f2!="function")throw new TypeError("Function expected");return f2}for(var kind=contextIn.kind,key=kind==="getter"?"get":kind==="setter"?"set":"value",target=!descriptorIn&&ctor?contextIn.static?ctor:ctor.prototype:null,descriptor=descriptorIn||(target?Object.getOwnPropertyDescriptor(target,contextIn.name):{}),_4,done=!1,i3=decorators.length-1;i3>=0;i3--){var context={};for(var p2 in contextIn)context[p2]=p2==="access"?{}:contextIn[p2];for(var p2 in contextIn.access)context.access[p2]=contextIn.access[p2];context.addInitializer=function(f2){if(done)throw new TypeError("Cannot add initializers after decoration has completed");extraInitializers.push(accept(f2||null))};var result=(0,decorators[i3])(kind==="accessor"?{get:descriptor.get,set:descriptor.set}:descriptor[key],context);if(kind==="accessor"){if(result===void 0)continue;if(result===null||typeof result!="object")throw new TypeError("Object expected");(_4=accept(result.get))&&(descriptor.get=_4),(_4=accept(result.set))&&(descriptor.set=_4),(_4=accept(result.init))&&initializers.unshift(_4)}else(_4=accept(result))&&(kind==="field"?initializers.unshift(_4):descriptor[key]=_4)}target&&Object.defineProperty(target,contextIn.name,descriptor),done=!0}function __runInitializers(thisArg,initializers,value){for(var useValue=arguments.length>2,i3=0;i3<initializers.length;i3++)value=useValue?initializers[i3].call(thisArg,value):initializers[i3].call(thisArg);return useValue?value:void 0}function __propKey(x3){return typeof x3=="symbol"?x3:"".concat(x3)}function __setFunctionName(f2,name,prefix){return typeof name=="symbol"&&(name=name.description?"[".concat(name.description,"]"):""),Object.defineProperty(f2,"name",{configurable:!0,value:prefix?"".concat(prefix," ",name):name})}function __metadata(metadataKey,metadataValue){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(metadataKey,metadataValue)}function __awaiter(thisArg,_arguments,P4,generator){function adopt(value){return value instanceof P4?value:new P4(function(resolve){resolve(value)})}return new(P4||(P4=Promise))(function(resolve,reject){function fulfilled(value){try{step(generator.next(value))}catch(e4){reject(e4)}}function rejected(value){try{step(generator.throw(value))}catch(e4){reject(e4)}}function step(result){result.done?resolve(result.value):adopt(result.value).then(fulfilled,rejected)}step((generator=generator.apply(thisArg,_arguments||[])).next())})}function __generator(thisArg,body){var _4={label:0,sent:function(){if(t5[0]&1)throw t5[1];return t5[1]},trys:[],ops:[]},f2,y3,t5,g4=Object.create((typeof Iterator=="function"?Iterator:Object).prototype);return g4.next=verb(0),g4.throw=verb(1),g4.return=verb(2),typeof Symbol=="function"&&(g4[Symbol.iterator]=function(){return this}),g4;function verb(n3){return function(v4){return step([n3,v4])}}function step(op2){if(f2)throw new TypeError("Generator is already executing.");for(;g4&&(g4=0,op2[0]&&(_4=0)),_4;)try{if(f2=1,y3&&(t5=op2[0]&2?y3.return:op2[0]?y3.throw||((t5=y3.return)&&t5.call(y3),0):y3.next)&&!(t5=t5.call(y3,op2[1])).done)return t5;switch(y3=0,t5&&(op2=[op2[0]&2,t5.value]),op2[0]){case 0:case 1:t5=op2;break;case 4:return _4.label++,{value:op2[1],done:!1};case 5:_4.label++,y3=op2[1],op2=[0];continue;case 7:op2=_4.ops.pop(),_4.trys.pop();continue;default:if(t5=_4.trys,!(t5=t5.length>0&&t5[t5.length-1])&&(op2[0]===6||op2[0]===2)){_4=0;continue}if(op2[0]===3&&(!t5||op2[1]>t5[0]&&op2[1]<t5[3])){_4.label=op2[1];break}if(op2[0]===6&&_4.label<t5[1]){_4.label=t5[1],t5=op2;break}if(t5&&_4.label<t5[2]){_4.label=t5[2],_4.ops.push(op2);break}t5[2]&&_4.ops.pop(),_4.trys.pop();continue}op2=body.call(thisArg,_4)}catch(e4){op2=[6,e4],y3=0}finally{f2=t5=0}if(op2[0]&5)throw op2[1];return{value:op2[0]?op2[1]:void 0,done:!0}}}var __createBinding=Object.create?(function(o4,m3,k4,k22){k22===void 0&&(k22=k4);var desc=Object.getOwnPropertyDescriptor(m3,k4);(!desc||("get"in desc?!m3.__esModule:desc.writable||desc.configurable))&&(desc={enumerable:!0,get:function(){return m3[k4]}}),Object.defineProperty(o4,k22,desc)}):(function(o4,m3,k4,k22){k22===void 0&&(k22=k4),o4[k22]=m3[k4]});function __exportStar(m3,o4){for(var p2 in m3)p2!=="default"&&!Object.prototype.hasOwnProperty.call(o4,p2)&&__createBinding(o4,m3,p2)}function __values(o4){var s3=typeof Symbol=="function"&&Symbol.iterator,m3=s3&&o4[s3],i3=0;if(m3)return m3.call(o4);if(o4&&typeof o4.length=="number")return{next:function(){return o4&&i3>=o4.length&&(o4=void 0),{value:o4&&o4[i3++],done:!o4}}};throw new TypeError(s3?"Object is not iterable.":"Symbol.iterator is not defined.")}function __read(o4,n3){var m3=typeof Symbol=="function"&&o4[Symbol.iterator];if(!m3)return o4;var i3=m3.call(o4),r4,ar3=[],e4;try{for(;(n3===void 0||n3-- >0)&&!(r4=i3.next()).done;)ar3.push(r4.value)}catch(error){e4={error}}finally{try{r4&&!r4.done&&(m3=i3.return)&&m3.call(i3)}finally{if(e4)throw e4.error}}return ar3}function __spread(){for(var ar3=[],i3=0;i3<arguments.length;i3++)ar3=ar3.concat(__read(arguments[i3]));return ar3}function __spreadArrays(){for(var s3=0,i3=0,il2=arguments.length;i3<il2;i3++)s3+=arguments[i3].length;for(var r4=Array(s3),k4=0,i3=0;i3<il2;i3++)for(var a2=arguments[i3],j3=0,jl2=a2.length;j3<jl2;j3++,k4++)r4[k4]=a2[j3];return r4}function __spreadArray(to3,from,pack2){if(pack2||arguments.length===2)for(var i3=0,l2=from.length,ar3;i3<l2;i3++)(ar3||!(i3 in from))&&(ar3||(ar3=Array.prototype.slice.call(from,0,i3)),ar3[i3]=from[i3]);return to3.concat(ar3||Array.prototype.slice.call(from))}function __await(v4){return this instanceof __await?(this.v=v4,this):new __await(v4)}function __asyncGenerator(thisArg,_arguments,generator){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var g4=generator.apply(thisArg,_arguments||[]),i3,q4=[];return i3=Object.create((typeof AsyncIterator=="function"?AsyncIterator:Object).prototype),verb("next"),verb("throw"),verb("return",awaitReturn),i3[Symbol.asyncIterator]=function(){return this},i3;function awaitReturn(f2){return function(v4){return Promise.resolve(v4).then(f2,reject)}}function verb(n3,f2){g4[n3]&&(i3[n3]=function(v4){return new Promise(function(a2,b3){q4.push([n3,v4,a2,b3])>1||resume(n3,v4)})},f2&&(i3[n3]=f2(i3[n3])))}function resume(n3,v4){try{step(g4[n3](v4))}catch(e4){settle(q4[0][3],e4)}}function step(r4){r4.value instanceof __await?Promise.resolve(r4.value.v).then(fulfill,reject):settle(q4[0][2],r4)}function fulfill(value){resume("next",value)}function reject(value){resume("throw",value)}function settle(f2,v4){f2(v4),q4.shift(),q4.length&&resume(q4[0][0],q4[0][1])}}function __asyncDelegator(o4){var i3,p2;return i3={},verb("next"),verb("throw",function(e4){throw e4}),verb("return"),i3[Symbol.iterator]=function(){return this},i3;function verb(n3,f2){i3[n3]=o4[n3]?function(v4){return(p2=!p2)?{value:__await(o4[n3](v4)),done:!1}:f2?f2(v4):v4}:f2}}function __asyncValues(o4){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var m3=o4[Symbol.asyncIterator],i3;return m3?m3.call(o4):(o4=typeof __values=="function"?__values(o4):o4[Symbol.iterator](),i3={},verb("next"),verb("throw"),verb("return"),i3[Symbol.asyncIterator]=function(){return this},i3);function verb(n3){i3[n3]=o4[n3]&&function(v4){return new Promise(function(resolve,reject){v4=o4[n3](v4),settle(resolve,reject,v4.done,v4.value)})}}function settle(resolve,reject,d3,v4){Promise.resolve(v4).then(function(v6){resolve({value:v6,done:d3})},reject)}}function __makeTemplateObject(cooked,raw){return Object.defineProperty?Object.defineProperty(cooked,"raw",{value:raw}):cooked.raw=raw,cooked}var __setModuleDefault=Object.create?(function(o4,v4){Object.defineProperty(o4,"default",{enumerable:!0,value:v4})}):function(o4,v4){o4.default=v4},ownKeys=function(o4){return ownKeys=Object.getOwnPropertyNames||function(o5){var ar3=[];for(var k4 in o5)Object.prototype.hasOwnProperty.call(o5,k4)&&(ar3[ar3.length]=k4);return ar3},ownKeys(o4)};function __importStar(mod){if(mod&&mod.__esModule)return mod;var result={};if(mod!=null)for(var k4=ownKeys(mod),i3=0;i3<k4.length;i3++)k4[i3]!=="default"&&__createBinding(result,mod,k4[i3]);return __setModuleDefault(result,mod),result}function __importDefault(mod){return mod&&mod.__esModule?mod:{default:mod}}function __classPrivateFieldGet(receiver,state2,kind,f2){if(kind==="a"&&!f2)throw new TypeError("Private accessor was defined without a getter");if(typeof state2=="function"?receiver!==state2||!f2:!state2.has(receiver))throw new TypeError("Cannot read private member from an object whose class did not declare it");return kind==="m"?f2:kind==="a"?f2.call(receiver):f2?f2.value:state2.get(receiver)}function __classPrivateFieldSet(receiver,state2,value,kind,f2){if(kind==="m")throw new TypeError("Private method is not writable");if(kind==="a"&&!f2)throw new TypeError("Private accessor was defined without a setter");if(typeof state2=="function"?receiver!==state2||!f2:!state2.has(receiver))throw new TypeError("Cannot write private member to an object whose class did not declare it");return kind==="a"?f2.call(receiver,value):f2?f2.value=value:state2.set(receiver,value),value}function __classPrivateFieldIn(state2,receiver){if(receiver===null||typeof receiver!="object"&&typeof receiver!="function")throw new TypeError("Cannot use 'in' operator on non-object");return typeof state2=="function"?receiver===state2:state2.has(receiver)}function __addDisposableResource(env,value,async){if(value!=null){if(typeof value!="object"&&typeof value!="function")throw new TypeError("Object expected.");var dispose,inner;if(async){if(!Symbol.asyncDispose)throw new TypeError("Symbol.asyncDispose is not defined.");dispose=value[Symbol.asyncDispose]}if(dispose===void 0){if(!Symbol.dispose)throw new TypeError("Symbol.dispose is not defined.");dispose=value[Symbol.dispose],async&&(inner=dispose)}if(typeof dispose!="function")throw new TypeError("Object not disposable.");inner&&(dispose=function(){try{inner.call(this)}catch(e4){return Promise.reject(e4)}}),env.stack.push({value,dispose,async})}else async&&env.stack.push({async:!0});return value}var _SuppressedError=typeof SuppressedError=="function"?SuppressedError:function(error,suppressed,message){var e4=new Error(message);return e4.name="SuppressedError",e4.error=error,e4.suppressed=suppressed,e4};function __disposeResources(env){function fail(e4){env.error=env.hasError?new _SuppressedError(e4,env.error,"An error was suppressed during disposal."):e4,env.hasError=!0}var r4,s3=0;function next2(){for(;r4=env.stack.pop();)try{if(!r4.async&&s3===1)return s3=0,env.stack.push(r4),Promise.resolve().then(next2);if(r4.dispose){var result=r4.dispose.call(r4.value);if(r4.async)return s3|=2,Promise.resolve(result).then(next2,function(e4){return fail(e4),next2()})}else s3|=1}catch(e4){fail(e4)}if(s3===1)return env.hasError?Promise.reject(env.error):Promise.resolve();if(env.hasError)throw env.error}return next2()}function __rewriteRelativeImportExtension(path,preserveJsx){return typeof path=="string"&&/^\.\.?\//.test(path)?path.replace(/\.(tsx)$|((?:\.d)?)((?:\.[^./]+?)?)\.([cm]?)ts$/i,function(m3,tsx,d3,ext,cm2){return tsx?preserveJsx?".jsx":".js":d3&&(!ext||!cm2)?m3:d3+ext+"."+cm2.toLowerCase()+"js"}):path}var tslib_es6_default={__extends,__assign,__rest,__decorate,__param,__esDecorate,__runInitializers,__propKey,__setFunctionName,__metadata,__awaiter,__generator,__createBinding,__exportStar,__values,__read,__spread,__spreadArrays,__spreadArray,__await,__asyncGenerator,__asyncDelegator,__asyncValues,__makeTemplateObject,__importStar,__importDefault,__classPrivateFieldGet,__classPrivateFieldSet,__classPrivateFieldIn,__addDisposableResource,__disposeResources,__rewriteRelativeImportExtension};var import_debug21=__toESM(require_browser(),1),debug12=(0,import_debug21.default)("tsci:eval:execution-context");function createExecutionContext(webWorkerConfiguration,opts={}){globalThis.React=React;let basePlatform=opts.platform||getPlatformConfig(),platform=opts.projectConfig?{...basePlatform,...opts.projectConfig}:basePlatform;platform.partsEngineDisabled&&(platform.partsEngine=void 0);let circuit=new RootCircuit({platform});opts.name&&(circuit.name=opts.name),opts.debugNamespace&&circuit.enableDebug(opts.debugNamespace);let logs=[];return{fsMap:{},entrypoint:"",logger:{info:message=>{logs.push({msg:message})},getLogs:()=>logs,stringifyLogs:()=>logs.map(log=>log.msg).join(`
|
|
618
618
|
`)},preSuppliedImports:{"@tscircuit/core":dist_exports4,tscircuit:dist_exports4,"@tscircuit/math-utils":dist_exports2,react:React,"react/jsx-runtime":ReactJsxRuntime,debug:import_debug21.default,tslib:tslib_es6_exports,"@tscircuit/props":{}},circuit,tsConfig:null,importStack:[],currentlyImporting:new Set,...webWorkerConfiguration}}function normalizeFilePath(filePath){let normFilePath=filePath;return normFilePath=normFilePath.replace(/\\/g,"/"),normFilePath=normFilePath.trim(),normFilePath.startsWith("./")&&(normFilePath=normFilePath.slice(2)),normFilePath.startsWith("/")&&(normFilePath=normFilePath.slice(1)),normFilePath}function normalizeFsMap(fsMap){let normalizedFsMap={};for(let[fsPath,fileContent]of Object.entries(fsMap))normalizedFsMap[normalizeFilePath(fsPath)]=fileContent;return normalizedFsMap}function dirname(path){if(!path)return".";let cleanPath=path.replace(/\\/g,"/").replace(/\/+$/,"");return cleanPath.indexOf("/")===-1?".":cleanPath.substring(0,cleanPath.lastIndexOf("/"))||"/"}function resolveRelativePath(importPath,cwd){if(importPath.startsWith("../")){let parentDir=dirname(cwd);return resolveRelativePath(importPath.slice(3),parentDir)}return importPath.startsWith("./")?resolveRelativePath(importPath.slice(2),cwd):importPath.startsWith("/")?importPath.slice(1):`${cwd}/${importPath}`}function getTsConfig(fsMapOrAllFilePaths){if(Array.isArray(fsMapOrAllFilePaths))return null;let tsconfigContent=fsMapOrAllFilePaths["tsconfig.json"];if(!tsconfigContent)return null;try{let sanitizedContent=tsconfigContent.replace(/\/\*[\s\S]*?\*\/|\/\/.*/g,"");return JSON.parse(sanitizedContent)}catch(e4){throw new Error(`Failed to parse tsconfig.json: ${e4.message}`)}}function resolveWithTsconfigPaths(opts){let{importPath,normalizedFilePathMap,extensions,tsConfig,tsconfigDir}=opts,paths=tsConfig?.compilerOptions?.paths;if(!paths)return null;let baseUrl=tsConfig?.compilerOptions?.baseUrl||".",tryResolveCandidate=candidate=>{let normalizedCandidate=normalizeFilePath(candidate);if(normalizedFilePathMap.has(normalizedCandidate))return normalizedFilePathMap.get(normalizedCandidate);for(let ext of extensions){let withExt=`${normalizedCandidate}.${ext}`;if(normalizedFilePathMap.has(withExt))return normalizedFilePathMap.get(withExt)}return null};for(let[alias,targets]of Object.entries(paths))if(alias.includes("*")){let[prefix,suffix]=alias.split("*");if(!importPath.startsWith(prefix)||!importPath.endsWith(suffix||""))continue;let starMatch=importPath.slice(prefix.length,importPath.length-(suffix?suffix.length:0));for(let target of targets){let replaced=target.replace("*",starMatch),candidate=baseUrl&&!replaced.startsWith("./")&&!replaced.startsWith("/")?`${baseUrl}/${replaced}`:replaced,resolved=tryResolveCandidate(candidate);if(resolved)return resolved}}else{if(importPath!==alias)continue;for(let target of targets){let candidate=baseUrl&&!target.startsWith("./")&&!target.startsWith("/")?`${baseUrl}/${target}`:target,resolved=tryResolveCandidate(candidate);if(resolved)return resolved}}let resolvedPathFromBaseUrl=resolveWithBaseUrl({importPath,normalizedFilePathMap,extensions,tsConfig,tsconfigDir});return resolvedPathFromBaseUrl||null}function resolveWithBaseUrl(opts){let{importPath,normalizedFilePathMap,extensions,tsConfig,tsconfigDir}=opts,baseUrl=tsConfig?.compilerOptions?.baseUrl;if(!baseUrl)return null;let filePathToResolve=`${tsconfigDir||"."}/${baseUrl}/${importPath}`;filePathToResolve=filePathToResolve.replace(/\/+/g,"/"),filePathToResolve=filePathToResolve.replace(/\/\.\//g,"/");let normalizedFilePath=normalizeFilePath(filePathToResolve);if(normalizedFilePathMap.has(normalizedFilePath))return normalizedFilePathMap.get(normalizedFilePath);for(let ext of extensions){let withExt=`${normalizedFilePath}.${ext}`;if(normalizedFilePathMap.has(withExt))return normalizedFilePathMap.get(withExt)}return null}function matchesTsconfigPathPattern(importPath,tsConfig){let paths=tsConfig?.compilerOptions?.paths;if(!paths)return!1;for(let[alias]of Object.entries(paths))if(alias.includes("*")){let[prefix,suffix]=alias.split("*");if(importPath.startsWith(prefix)&&importPath.endsWith(suffix||""))return!0}else if(importPath===alias)return!0;return!1}var FILE_EXTENSIONS=["tsx","ts","json","js","jsx","obj","gltf","glb","stl","step","stp"],resolveFilePath=(unknownFilePath,fsMapOrAllFilePaths,cwd,opts={})=>{let tsConfig=opts.tsConfig??null,isRelativeImport=unknownFilePath.startsWith("./")||unknownFilePath.startsWith("../"),hasBaseUrl=!!tsConfig?.compilerOptions?.baseUrl,resolvedPath=cwd&&(isRelativeImport||!hasBaseUrl)?resolveRelativePath(unknownFilePath,cwd):unknownFilePath,filePaths=new Set(Array.isArray(fsMapOrAllFilePaths)?fsMapOrAllFilePaths:Object.keys(fsMapOrAllFilePaths));if(filePaths.has(resolvedPath))return resolvedPath;let normalizedFilePathMap=new Map;for(let filePath of filePaths)normalizedFilePathMap.set(normalizeFilePath(filePath),filePath);let normalizedResolvedPath=normalizeFilePath(resolvedPath);if(isRelativeImport||!hasBaseUrl){if(normalizedFilePathMap.has(normalizedResolvedPath))return normalizedFilePathMap.get(normalizedResolvedPath);for(let ext of FILE_EXTENSIONS){let possibleFilePath=`${normalizedResolvedPath}.${ext}`;if(normalizedFilePathMap.has(possibleFilePath))return normalizedFilePathMap.get(possibleFilePath)}}if(!isRelativeImport){let resolvedPathFromPaths=resolveWithTsconfigPaths({importPath:unknownFilePath,normalizedFilePathMap,extensions:FILE_EXTENSIONS,tsConfig,tsconfigDir:opts.tsconfigDir});if(resolvedPathFromPaths)return resolvedPathFromPaths;let resolvedPathFromBaseUrl=resolveWithBaseUrl({importPath:unknownFilePath,normalizedFilePathMap,extensions:FILE_EXTENSIONS,tsConfig,tsconfigDir:opts.tsconfigDir});if(resolvedPathFromBaseUrl)return resolvedPathFromBaseUrl}if(!isRelativeImport&&!hasBaseUrl){let normalizedUnknownFilePath=normalizeFilePath(unknownFilePath);if(normalizedFilePathMap.has(normalizedUnknownFilePath))return normalizedFilePathMap.get(normalizedUnknownFilePath);for(let ext of FILE_EXTENSIONS){let possibleFilePath=`${normalizedUnknownFilePath}.${ext}`;if(normalizedFilePathMap.has(possibleFilePath))return normalizedFilePathMap.get(possibleFilePath)}}return null},resolveFilePathOrThrow=(unknownFilePath,fsMapOrAllFilePaths,cwd,opts={})=>{let resolvedFilePath=resolveFilePath(unknownFilePath,fsMapOrAllFilePaths,cwd,opts);if(!resolvedFilePath)throw new Error(`File not found "${unknownFilePath}", available paths:
|