brep-io-kernel 1.0.202 → 1.0.203

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.
Files changed (35) hide show
  1. package/dist/help/api-examples.html +1 -1
  2. package/dist/help/developer-index.html +1 -1
  3. package/dist/help/developer__architecture__index.html +1 -1
  4. package/dist/help/developer__embedding__index.html +1 -1
  5. package/dist/help/developer__kernel__index.html +1 -1
  6. package/dist/help/developer__subsystems__index.html +1 -1
  7. package/dist/help/features__datium.html +1 -1
  8. package/dist/help/features__datum.html +1 -1
  9. package/dist/help/features__index.html +1 -1
  10. package/dist/help/getting-started.html +1 -1
  11. package/dist/help/modes__modeling.html +1 -1
  12. package/dist/help/modes__sketch.html +1 -1
  13. package/dist/help/plugins.html +1 -1
  14. package/dist/help/search-index.json +31 -31
  15. package/dist/help/workbenches__all.html +1 -1
  16. package/dist/help/workbenches__modeling.html +1 -1
  17. package/dist/help/workbenches__wire-harness.html +1 -1
  18. package/dist-kernel/help/api-examples.html +1 -1
  19. package/dist-kernel/help/developer-index.html +1 -1
  20. package/dist-kernel/help/developer__architecture__index.html +1 -1
  21. package/dist-kernel/help/developer__embedding__index.html +1 -1
  22. package/dist-kernel/help/developer__kernel__index.html +1 -1
  23. package/dist-kernel/help/developer__subsystems__index.html +1 -1
  24. package/dist-kernel/help/features__datium.html +1 -1
  25. package/dist-kernel/help/features__datum.html +1 -1
  26. package/dist-kernel/help/features__index.html +1 -1
  27. package/dist-kernel/help/getting-started.html +1 -1
  28. package/dist-kernel/help/modes__modeling.html +1 -1
  29. package/dist-kernel/help/modes__sketch.html +1 -1
  30. package/dist-kernel/help/plugins.html +1 -1
  31. package/dist-kernel/help/search-index.json +31 -31
  32. package/dist-kernel/help/workbenches__all.html +1 -1
  33. package/dist-kernel/help/workbenches__modeling.html +1 -1
  34. package/dist-kernel/help/workbenches__wire-harness.html +1 -1
  35. package/package.json +1 -1
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>API Examples</h1><p>Standalone browser demos for the BREP kernel and Sketcher2D APIs. This page links every live <code>.html</code> demo under <code>/apiExamples/</code>, including the examples index page.</p><h2>Example Hub</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/index.html">https://BREP.io/apiExamples/index.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/index.html">apiExamples/index.html</a></li></ul><h2>BREP Booleans</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Booleans.html">https://BREP.io/apiExamples/BREP_Booleans.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Booleans.html">apiExamples/BREP_Booleans.html</a></li></ul><h2>BREP Primitives</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Primitives.html">https://BREP.io/apiExamples/BREP_Primitives.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Primitives.html">apiExamples/BREP_Primitives.html</a></li></ul><h2>BREP Transforms</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Transforms.html">https://BREP.io/apiExamples/BREP_Transforms.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Transforms.html">apiExamples/BREP_Transforms.html</a></li></ul><h2>BREP Export</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Export.html">https://BREP.io/apiExamples/BREP_Export.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Export.html">apiExamples/BREP_Export.html</a></li></ul><h2>Embeded 2D Sketcher</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_2D_Sketcher.html">https://BREP.io/apiExamples/Embeded_2D_Sketcher.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_2D_Sketcher.html">apiExamples/Embeded_2D_Sketcher.html</a></li><li>Includes host-side exports for SVG, DXF, and sampled per-curve 3D polylines.</li></ul><h2>Embeded CAD</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_CAD.html">https://BREP.io/apiExamples/Embeded_CAD.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_CAD.html">apiExamples/Embeded_CAD.html</a></li><li>Mounts the full CAD app with the iframe-based <code>CadEmbed</code> API and shows host-side history/model controls.</li></ul><h2>Embeded CAD (CDN)</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_CAD_CDN.html">https://BREP.io/apiExamples/Embeded_CAD_CDN.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_CAD_CDN.html">apiExamples/Embeded_CAD_CDN.html</a></li><li>Uses direct jsDelivr import:</li></ul><p><code>import { BREP, CadEmbed } from &quot;<a href="https://cdn.jsdelivr.net/npm/brep-io-kernel@latest/dist-kernel/brep-kernel.js&quot;;" target="_blank" rel="noopener noreferrer">https://cdn.jsdelivr.net/npm/brep-io-kernel@latest/dist-kernel/brep-kernel.js&quot;;</a></code></p><h2>Embeded CAD Integration Test</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html">https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_CAD_Integration_Test.html">apiExamples/Embeded_CAD_Integration_Test.html</a></li><li>Runs in-browser assertions across the <code>CadEmbed</code> lifecycle and runtime methods.</li></ul>
191
+ <h1>API Examples</h1><p>Standalone browser demos for the BREP kernel and Sketcher2D APIs. This page links the live <code>.html</code> demos under <code>/apiExamples/</code>.</p><h2>Example Hub</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/index.html">https://BREP.io/apiExamples/index.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/index.html">apiExamples/index.html</a></li></ul><h2>BREP Booleans</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Booleans.html">https://BREP.io/apiExamples/BREP_Booleans.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Booleans.html">apiExamples/BREP_Booleans.html</a></li></ul><h2>BREP Primitives</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Primitives.html">https://BREP.io/apiExamples/BREP_Primitives.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Primitives.html">apiExamples/BREP_Primitives.html</a></li></ul><h2>BREP Transforms</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Transforms.html">https://BREP.io/apiExamples/BREP_Transforms.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Transforms.html">apiExamples/BREP_Transforms.html</a></li></ul><h2>BREP Export</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/BREP_Export.html">https://BREP.io/apiExamples/BREP_Export.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/BREP_Export.html">apiExamples/BREP_Export.html</a></li></ul><h2>Embedded 2D Sketcher</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_2D_Sketcher.html">https://BREP.io/apiExamples/Embeded_2D_Sketcher.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_2D_Sketcher.html">apiExamples/Embeded_2D_Sketcher.html</a></li><li>Includes host-side exports for SVG, DXF, and sampled per-curve 3D polylines.</li></ul><h2>Embedded CAD</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_CAD.html">https://BREP.io/apiExamples/Embeded_CAD.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_CAD.html">apiExamples/Embeded_CAD.html</a></li><li>Mounts the full CAD app with the iframe-based <code>CadEmbed</code> API and shows host-side history/model controls.</li></ul><h2>Embedded CAD (CDN)</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_CAD_CDN.html">https://BREP.io/apiExamples/Embeded_CAD_CDN.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_CAD_CDN.html">apiExamples/Embeded_CAD_CDN.html</a></li><li>Uses direct jsDelivr import:</li></ul><p><code>import { BREP, CadEmbed } from &quot;<a href="https://cdn.jsdelivr.net/npm/brep-io-kernel@latest/dist-kernel/brep-kernel.js&quot;;" target="_blank" rel="noopener noreferrer">https://cdn.jsdelivr.net/npm/brep-io-kernel@latest/dist-kernel/brep-kernel.js&quot;;</a></code></p><h2>Embedded CAD Integration Test</h2><ul><li>Demo: <a href="https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html">https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html</a></li><li>Source: <a href="https://github.com/mmiscool/BREP/blob/master/apiExamples/Embeded_CAD_Integration_Test.html">apiExamples/Embeded_CAD_Integration_Test.html</a></li><li>Runs in-browser assertions across the <code>CadEmbed</code> lifecycle and runtime methods.</li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Developer Docs</h1><p>This is the top-level hub for developer-facing documentation.</p><p>Pick the area you are working in:</p><h2>Start Here</h2><ul><li><a href="getting-started.html">Getting Started</a> - local setup, dev server, and tests.</li><li><a href="api-examples.html">API Examples</a> - runnable examples and demo entry points.</li><li><a href="bug-reporting.html">Bug Reporting and Repro Test Cases</a> - how to capture actionable reports.</li><li><a href="https://discord.gg/R5KNAKrQ">Developer Discord</a></li></ul><h2>Developer Doc Sections</h2><ul><li><a href="developer__kernel__index.html">Kernel and Geometry Docs</a> - BREP kernel architecture, class APIs, topology, metadata, booleans, and geometry internals.</li><li><a href="developer__embedding__index.html">Embedding and Integration Docs</a> - <code>CadEmbed</code>, <code>Sketcher2DEmbed</code>, package usage, and integration demos.</li><li><a href="developer__architecture__index.html">Application Architecture Docs</a> - <code>PartHistory</code>, history execution, expressions, UI structure, and implementation notes.</li><li><a href="developer__subsystems__index.html">Application Subsystems Docs</a> - assembly constraints, inspector, PMI annotations, plugins, and related subsystems.</li></ul><h2>Most Used Pages</h2><ul><li><a href="api__index.html">BREP Class API Reference</a></li><li><a href="api__solid__index.html">Solid API Index</a></li><li><a href="brep-kernel.html">BREP Kernel Reference</a></li><li><a href="brep-api.html">BREP.js Export Map and Usage</a></li><li><a href="part-history.html">PartHistory Reference</a></li><li><a href="cad-embed.html">CadEmbed API</a></li><li><a href="sketcher2d-embed.html">Sketcher2DEmbed API</a></li></ul>
191
+ <h1>Developer Docs</h1><p>Top-level hub for developer-facing documentation.</p><h2>Start Here</h2><ul><li><a href="getting-started.html">Getting Started</a> - local setup, dev server, and tests</li><li><a href="api-examples.html">API Examples</a> - runnable examples and demo entry points</li><li><a href="bug-reporting.html">Bug Reporting and Repro Test Cases</a> - how to capture actionable reports</li><li><a href="https://discord.gg/R5KNAKrQ">Developer Discord</a></li></ul><h2>Sections</h2><ul><li><a href="developer__kernel__index.html">Kernel and Geometry Docs</a> - kernel architecture, class APIs, topology, metadata, and geometry internals</li><li><a href="developer__embedding__index.html">Embedding and Integration Docs</a> - <code>CadEmbed</code>, <code>Sketcher2DEmbed</code>, package usage, and demos</li><li><a href="developer__architecture__index.html">Application Architecture Docs</a> - <code>PartHistory</code>, history execution, expressions, UI structure, and implementation notes</li><li><a href="developer__subsystems__index.html">Application Subsystems Docs</a> - assembly constraints, inspector, PMI annotations, plugins, and related subsystems</li></ul><h2>Most Used Pages</h2><ul><li><a href="api__index.html">BREP Class API Reference</a></li><li><a href="api__solid__index.html">Solid API Index</a></li><li><a href="brep-kernel.html">BREP Kernel Reference</a></li><li><a href="brep-api.html">BREP.js Export Map and Usage</a></li><li><a href="part-history.html">PartHistory Reference</a></li><li><a href="cad-embed.html">CadEmbed API</a></li><li><a href="sketcher2d-embed.html">Sketcher2DEmbed API</a></li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Application Architecture Docs</h1><p>Use this section when you are changing how the application is structured, how history is replayed, how expressions work, or how the UI and feature system are wired together.</p><h2>Core Architecture</h2><ul><li><a href="how-it-works.html">How It Works</a></li><li><a href="part-history.html">PartHistory Reference</a></li><li><a href="history-systems.html">History Systems</a></li><li><a href="input-params-schema.html">Input Params Schema</a></li></ul><h2>UI and Authoring Systems</h2><ul><li><a href="expressions.html">Expressions and Configurator</a></li><li><a href="ui-overview.html">UI Overview</a></li><li><a href="feature-dimension-gizmos.html">Feature Dimension Gizmos</a></li><li><a href="workbench-implementation-plan.html">Workbench Implementation Plan</a></li></ul><h2>Related References</h2><ul><li><a href="features__index.html">Features Index</a></li><li><a href="modes__modeling.html">Modeling Mode</a></li><li><a href="modes__sketch.html">Sketch Mode</a></li><li><a href="modes__pmi.html">PMI Mode</a></li><li><a href="modes__sheets.html">2D Sheets Mode</a></li></ul>
191
+ <h1>Application Architecture Docs</h1><p>Use this section for application structure, history replay, expressions, and UI wiring.</p><h2>Core Architecture</h2><ul><li><a href="how-it-works.html">How It Works</a></li><li><a href="part-history.html">PartHistory Reference</a></li><li><a href="history-systems.html">History Systems</a></li><li><a href="input-params-schema.html">Input Params Schema</a></li></ul><h2>UI and Authoring Systems</h2><ul><li><a href="expressions.html">Expressions and Configurator</a></li><li><a href="ui-overview.html">UI Overview</a></li><li><a href="feature-dimension-gizmos.html">Feature Dimension Gizmos</a></li><li><a href="workbench-implementation-plan.html">Workbench Implementation Plan</a></li></ul><h2>Related References</h2><ul><li><a href="features__index.html">Features Index</a></li><li><a href="modes__modeling.html">Modeling Mode</a></li><li><a href="modes__sketch.html">Sketch Mode</a></li><li><a href="modes__pmi.html">PMI Mode</a></li><li><a href="modes__sheets.html">2D Sheets Mode</a></li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Embedding and Integration Docs</h1><p>Use this section when you are embedding the kernel, the full CAD app, or the 2D sketcher into another application.</p><h2>Start Here</h2><ul><li><a href="getting-started.html">Getting Started</a></li><li><a href="api-examples.html">API Examples</a></li></ul><h2>Embedding APIs</h2><ul><li><a href="cad-embed.html">Embeddable CAD App (<code>CadEmbed</code>)</a></li><li><a href="sketcher2d-embed.html">Embeddable 2D Sketcher (<code>Sketcher2DEmbed</code>)</a></li><li><a href="brep-api.html">BREP.js Export Map and Usage</a></li></ul><h2>Integration Demo Pages</h2><ul><li><a href="https://BREP.io/apiExamples/index.html">Examples Index</a></li><li><a href="https://BREP.io/apiExamples/Embeded_CAD.html">Embedded CAD Demo</a></li><li><a href="https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html">Embedded CAD Integration Test</a></li><li><a href="https://BREP.io/apiExamples/Embeded_2D_Sketcher.html">Embedded 2D Sketcher Demo</a></li></ul><h2>Related Topics</h2><ul><li><a href="file-formats.html">File Formats: Import and Export</a></li><li><a href="github-repo-storage.html">GitHub Repo Storage</a></li><li><a href="plugins.html">Plugins and Examples</a></li></ul>
191
+ <h1>Embedding and Integration Docs</h1><p>Use this section when embedding the kernel, the full CAD app, or the 2D sketcher into another application.</p><h2>Start Here</h2><ul><li><a href="getting-started.html">Getting Started</a></li><li><a href="api-examples.html">API Examples</a></li></ul><h2>Embedding APIs</h2><ul><li><a href="cad-embed.html">Embeddable CAD App (<code>CadEmbed</code>)</a></li><li><a href="sketcher2d-embed.html">Embeddable 2D Sketcher (<code>Sketcher2DEmbed</code>)</a></li><li><a href="brep-api.html">BREP.js Export Map and Usage</a></li></ul><h2>Integration Demo Pages</h2><ul><li><a href="https://BREP.io/apiExamples/index.html">Examples Index</a></li><li><a href="https://BREP.io/apiExamples/Embeded_CAD.html">Embedded CAD Demo</a></li><li><a href="https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html">Embedded CAD Integration Test</a></li><li><a href="https://BREP.io/apiExamples/Embeded_2D_Sketcher.html">Embedded 2D Sketcher Demo</a></li></ul><h2>Related Topics</h2><ul><li><a href="file-formats.html">File Formats: Import and Export</a></li><li><a href="github-repo-storage.html">GitHub Repo Storage</a></li><li><a href="plugins.html">Plugins and Examples</a></li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Kernel and Geometry Docs</h1><p>Use this section when you are working on the BREP kernel, geometry data model, class APIs, topology tracking, or export behavior.</p><h2>Start Here</h2><ul><li><a href="brep-kernel.html">BREP Kernel Reference</a> - source-level overview of <code>src/BREP</code> responsibilities.</li><li><a href="brep-model.html">BREP Model and Classes</a> - compact conceptual summary of the geometry model.</li><li><a href="brep-api.html">BREP.js Export Map and Usage</a> - what is publicly exported from <code>BREP.js</code>.</li></ul><h2>Core Classes</h2><ul><li><a href="solid-methods.html">Solid Developer Guide</a> - workflow-oriented overview for <code>Solid</code>.</li><li><a href="api__solid__index.html">Solid API Index</a> - canonical per-method reference for <code>Solid</code>.</li><li><a href="api__face__index.html">Face API Index</a> - canonical per-method reference for <code>Face</code>.</li><li><a href="api__edge__index.html">Edge API Index</a> - canonical per-method reference for <code>Edge</code>.</li><li><a href="api__index.html">BREP Class API Reference</a> - hub for all kernel class method docs.</li></ul><h2>Kernel Topics</h2><ul><li><a href="topological-face-tracking.html">Topological Face Naming and Triangle Ownership</a></li><li><a href="extruded-sketch-radius-embedding.html">Radius Metadata for Extruded Sketches</a></li><li><a href="cylindrical-face-radius-embedding.html">Cylindrical Face Radius Embedding</a></li><li><a href="simplified-radial-dimensions.html">Simplified Radial Dimensions</a></li><li><a href="fillet-process.html">Fillet Process</a></li><li><a href="file-formats.html">File Formats: Import and Export</a></li><li><a href="cpp-solid-porting.html">C++ Solid Porting Notes</a></li></ul><h2>Example Pages</h2><ul><li><a href="https://BREP.io/apiExamples/BREP_Booleans.html">BREP Booleans Demo</a></li><li><a href="https://BREP.io/apiExamples/BREP_Primitives.html">BREP Primitives Demo</a></li><li><a href="https://BREP.io/apiExamples/BREP_Transforms.html">BREP Transforms Demo</a></li><li><a href="https://BREP.io/apiExamples/BREP_Export.html">BREP Export Demo</a></li></ul><h2>Suggested Reading Order</h2><ol><li>Read <a href="brep-kernel.html">BREP Kernel Reference</a> for structure.</li><li>Open <a href="api__index.html">BREP Class API Reference</a> for exact class behavior.</li><li>Use the topic pages above for deeper geometry-specific behavior.</li></ol>
191
+ <h1>Kernel and Geometry Docs</h1><p>Use this section for the BREP kernel, geometry data model, class APIs, topology tracking, and export behavior.</p><h2>Start Here</h2><ul><li><a href="brep-kernel.html">BREP Kernel Reference</a> - source-level overview of <code>src/BREP</code> responsibilities.</li><li><a href="brep-model.html">BREP Model and Classes</a> - compact conceptual summary of the geometry model.</li><li><a href="brep-api.html">BREP.js Export Map and Usage</a> - what is publicly exported from <code>BREP.js</code>.</li></ul><h2>Core Classes</h2><ul><li><a href="solid-methods.html">Solid Developer Guide</a> - workflow-oriented overview for <code>Solid</code>.</li><li><a href="api__solid__index.html">Solid API Index</a> - canonical per-method reference for <code>Solid</code>.</li><li><a href="api__face__index.html">Face API Index</a> - canonical per-method reference for <code>Face</code>.</li><li><a href="api__edge__index.html">Edge API Index</a> - canonical per-method reference for <code>Edge</code>.</li><li><a href="api__index.html">BREP Class API Reference</a> - hub for all kernel class method docs.</li></ul><h2>Kernel Topics</h2><ul><li><a href="topological-face-tracking.html">Topological Face Naming and Triangle Ownership</a></li><li><a href="extruded-sketch-radius-embedding.html">Radius Metadata for Extruded Sketches</a></li><li><a href="cylindrical-face-radius-embedding.html">Cylindrical Face Radius Embedding</a></li><li><a href="simplified-radial-dimensions.html">Simplified Radial Dimensions</a></li><li><a href="fillet-process.html">Fillet Process</a></li><li><a href="file-formats.html">File Formats: Import and Export</a></li><li><a href="cpp-solid-porting.html">C++ Solid Porting Notes</a></li></ul><h2>Example Pages</h2><ul><li><a href="https://BREP.io/apiExamples/BREP_Booleans.html">BREP Booleans Demo</a></li><li><a href="https://BREP.io/apiExamples/BREP_Primitives.html">BREP Primitives Demo</a></li><li><a href="https://BREP.io/apiExamples/BREP_Transforms.html">BREP Transforms Demo</a></li><li><a href="https://BREP.io/apiExamples/BREP_Export.html">BREP Export Demo</a></li></ul><h2>Suggested Reading Order</h2><ol><li>Read <a href="brep-kernel.html">BREP Kernel Reference</a> for structure</li><li>Open <a href="api__index.html">BREP Class API Reference</a> for exact class behavior</li><li>Use the topic pages above for deeper geometry-specific behavior</li></ol>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Application Subsystems Docs</h1><p>Use this section when you are working on a specific subsystem rather than the core kernel or embed APIs.</p><h2>Assembly Constraints</h2><ul><li><a href="assembly-constraints__solver.html">Constraint Solver</a></li><li><a href="assembly-constraints__angle-constraint.html">Angle Constraint</a></li><li><a href="assembly-constraints__coincident-constraint.html">Coincident Constraint</a></li><li><a href="assembly-constraints__distance-constraint.html">Distance Constraint</a></li><li><a href="assembly-constraints__fixed-constraint.html">Fixed Constraint</a></li><li><a href="assembly-constraints__parallel-constraint.html">Parallel Constraint</a></li><li><a href="assembly-constraints__touch-align-constraint.html">Touch Align Constraint</a></li></ul><h2>Inspector and Debugging</h2><ul><li><a href="inspector.html">Inspector</a></li><li><a href="inspector-improvements.html">Inspector Improvements</a></li><li><a href="dialog-screenshots.html">Dialog Screenshots</a></li></ul><h2>PMI and Annotation Systems</h2><ul><li><a href="pmi-annotations__index.html">PMI Annotations Index</a></li><li><a href="pmi-annotations__angle-dimension.html">Angle Dimension</a></li><li><a href="pmi-annotations__explode-body.html">Explode Body</a></li><li><a href="pmi-annotations__hole-callout.html">Hole Callout</a></li><li><a href="pmi-annotations__leader.html">Leader</a></li><li><a href="pmi-annotations__linear-dimension.html">Linear Dimension</a></li><li><a href="pmi-annotations__note.html">Note</a></li><li><a href="pmi-annotations__radial-dimension.html">Radial Dimension</a></li></ul><h2>Extension and Platform Topics</h2><ul><li><a href="plugins.html">Plugins and Examples</a></li><li><a href="fonts-licenses.html">Font Licenses</a></li></ul>
191
+ <h1>Application Subsystems Docs</h1><p>Use this section for application subsystems outside the core kernel and embed APIs.</p><h2>Assembly Constraints</h2><ul><li><a href="assembly-constraints__solver.html">Constraint Solver</a></li><li><a href="assembly-constraints__angle-constraint.html">Angle Constraint</a></li><li><a href="assembly-constraints__coincident-constraint.html">Coincident Constraint</a></li><li><a href="assembly-constraints__distance-constraint.html">Distance Constraint</a></li><li><a href="assembly-constraints__fixed-constraint.html">Fixed Constraint</a></li><li><a href="assembly-constraints__parallel-constraint.html">Parallel Constraint</a></li><li><a href="assembly-constraints__touch-align-constraint.html">Touch Align Constraint</a></li></ul><h2>Inspector and Debugging</h2><ul><li><a href="inspector.html">Inspector</a></li><li><a href="inspector-improvements.html">Inspector Improvements</a></li><li><a href="dialog-screenshots.html">Dialog Screenshots</a></li></ul><h2>PMI and Annotation Systems</h2><ul><li><a href="pmi-annotations__index.html">PMI Annotations Index</a></li><li><a href="pmi-annotations__angle-dimension.html">Angle Dimension</a></li><li><a href="pmi-annotations__explode-body.html">Explode Body</a></li><li><a href="pmi-annotations__hole-callout.html">Hole Callout</a></li><li><a href="pmi-annotations__leader.html">Leader</a></li><li><a href="pmi-annotations__linear-dimension.html">Linear Dimension</a></li><li><a href="pmi-annotations__note.html">Note</a></li><li><a href="pmi-annotations__radial-dimension.html">Radial Dimension</a></li></ul><h2>Extension and Platform Topics</h2><ul><li><a href="plugins.html">Plugins and Examples</a></li><li><a href="fonts-licenses.html">Font Licenses</a></li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Datium</h1><p>Status: Implemented</p><p><img src="features__Datium_dialog.png" alt="Datum feature dialog" width="280" loading="lazy" /></p><p>Datium creates an orthogonal datum triad (XY/XZ/YZ planes) for sketching and feature references.</p><h2>Inputs</h2><ul><li><code>transform</code> Position, rotation, and scale applied to the datum group.</li></ul><h2>Behaviour</h2><ul><li>Emits a <code>THREE.Group</code> named after the feature ID containing three selectable planes tagged as <code>PLANE</code>.</li><li>Planes are oriented like the Plane feature and respond to the supplied transform, making it easy to anchor sketches or construction geometry away from the origin.</li></ul>
191
+ <h1>Datium</h1><p>Status: Implemented</p><p><img src="features__Datium_dialog.png" alt="Datum feature dialog" width="280" loading="lazy" /></p><p>Datium creates a reference triad of orthogonal <code>XY</code>, <code>XZ</code>, and <code>YZ</code> planes for sketching and other feature inputs.</p><h2>Inputs</h2><ul><li><code>transform</code> - position, rotation, and scale applied to the datum group.</li></ul><h2>Behaviour</h2><ul><li>Emits a <code>THREE.Group</code> named after the feature ID with three selectable plane meshes: <code>XY</code>, <code>XZ</code>, and <code>YZ</code>.</li><li>The planes use the <code>PLANE</code> selection filter, so sketches and other downstream features can target them directly.</li><li>The triad starts at the world origin, then applies the supplied transform.</li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Datum</h1><p>Status: Implemented</p><p><img src="features__Datium_dialog.png" alt="Datum feature dialog" width="280" loading="lazy" /></p><p>Datum creates a lightweight reference group that exposes orthogonal XY/XZ/YZ planes for downstream selections.</p><h2>Inputs</h2><ul><li><code>transform</code> position, rotation, and scale applied to the three reference planes.</li></ul><h2>Behaviour</h2><ul><li>The feature emits a <code>THREE.Group</code> named after the feature ID with three plane meshes (<code>XY</code>, <code>XZ</code>, <code>YZ</code>).</li><li>No references are inherited from other geometry yet; the datum always starts at the world origin before the supplied transform is applied.</li><li>Each plane is selectable through the <code>PLANE</code> selection filter so other features (e.g. sketches) can lock to the datum.</li></ul>
191
+ <h1>Datum</h1><p><code>Datum</code> is the legacy name for <a href="features__datium.html"><code>Datium</code></a>.</p><p>Use the Datium page for the current feature behavior, inputs, and screenshots.</p>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Features</h1><p>Reference docs for the built-in modeling features.</p><ul><li><a href="features__assembly-component.html">Assembly Component</a></li><li><a href="features__boolean.html">Boolean</a></li><li><a href="features__chamfer.html">Chamfer</a></li><li><a href="features__collapse-edge.html">Collapse Edge</a></li><li><a href="features__datium.html">Datium</a></li><li><a href="features__edge-smooth.html">Edge Smooth</a></li><li><a href="features__extrude.html">Extrude</a></li><li><a href="features__fillet.html">Fillet</a></li><li><a href="features__helix.html">Helix</a></li><li><a href="features__hole.html">Hole</a></li><li><a href="features__image-editor.html">Image Editor (Shared)</a></li><li><a href="features__image-to-face.html">Image to Face</a></li><li><a href="features__image-heightmap-solid.html">Image Heightmap Solid</a></li><li><a href="features__import-3d-model.html">Import 3D Model</a></li><li><a href="features__loft.html">Loft</a></li><li><a href="features__mirror.html">Mirror</a></li><li><a href="features__nurbs-face-solid.html">NURBS Face Solid</a></li><li><a href="features__offset-face.html">Offset Face</a></li><li><a href="features__offset-shell.html">Offset Shell</a></li><li><a href="features__overlap-cleanup.html">Overlap Cleanup</a></li><li><a href="features__pattern.html">Pattern (Legacy)</a></li><li><a href="features__pattern-linear.html">Pattern Linear</a></li><li><a href="features__pattern-radial.html">Pattern Radial</a></li><li><a href="features__plane.html">Plane</a></li><li><a href="features__polygon-solid.html">Polygon Solid</a></li><li><a href="features__primitive-cone.html">Primitive Cone</a></li><li><a href="features__primitive-cube.html">Primitive Cube</a></li><li><a href="features__primitive-cylinder.html">Primitive Cylinder</a></li><li><a href="features__primitive-pyramid.html">Primitive Pyramid</a></li><li><a href="features__primitive-sphere.html">Primitive Sphere</a></li><li><a href="features__primitive-torus.html">Primitive Torus</a></li><li><a href="features__push-face.html">Push Face</a></li><li><a href="features__remesh.html">Remesh</a></li><li><a href="features__revolve.html">Revolve</a></li><li><a href="features__sheet-metal-contour-flange.html">Sheet Metal Contour Flange</a></li><li><a href="features__sheet-metal-cutout.html">Sheet Metal Cutout</a></li><li><a href="features__sheet-metal-flange.html">Sheet Metal Flange</a></li><li><a href="features__sheet-metal-hem.html">Sheet Metal Hem</a></li><li><a href="features__sheet-metal-tab.html">Sheet Metal Tab</a></li><li><a href="features__sketch.html">Sketch</a></li><li><a href="features__smooth-with-subdivision.html">Smooth With Subdivision</a></li><li><a href="features__spline.html">Spline</a></li><li><a href="features__sweep.html">Sweep</a></li><li><a href="features__text-to-face.html">Text to Face</a></li><li><a href="features__thicken.html">Thicken</a></li><li><a href="features__transform.html">Transform</a></li><li><a href="features__tube.html">Tube</a></li></ul><p><code>Datum</code> is kept as a legacy alias page; use <code>Datium</code> for the current feature name.</p>
191
+ <h1>Features</h1><p>Reference docs for the built-in modeling features.</p><ul><li><a href="features__assembly-component.html">Assembly Component</a></li><li><a href="features__boolean.html">Boolean</a></li><li><a href="features__chamfer.html">Chamfer</a></li><li><a href="features__collapse-edge.html">Collapse Edge</a></li><li><a href="features__datium.html">Datium</a></li><li><a href="features__edge-smooth.html">Edge Smooth</a></li><li><a href="features__extrude.html">Extrude</a></li><li><a href="features__fillet.html">Fillet</a></li><li><a href="features__helix.html">Helix</a></li><li><a href="features__hole.html">Hole</a></li><li><a href="features__image-editor.html">Image Editor (Shared)</a></li><li><a href="features__image-to-face.html">Image to Face</a></li><li><a href="features__image-heightmap-solid.html">Image Heightmap Solid</a></li><li><a href="features__import-3d-model.html">Import 3D Model</a></li><li><a href="features__loft.html">Loft</a></li><li><a href="features__mirror.html">Mirror</a></li><li><a href="features__nurbs-face-solid.html">NURBS Face Solid</a></li><li><a href="features__offset-face.html">Offset Face</a></li><li><a href="features__offset-shell.html">Offset Shell</a></li><li><a href="features__overlap-cleanup.html">Overlap Cleanup</a></li><li><a href="features__pattern.html">Pattern (Legacy)</a></li><li><a href="features__pattern-linear.html">Pattern Linear</a></li><li><a href="features__pattern-radial.html">Pattern Radial</a></li><li><a href="features__plane.html">Plane</a></li><li><a href="features__polygon-solid.html">Polygon Solid</a></li><li><a href="features__primitive-cone.html">Primitive Cone</a></li><li><a href="features__primitive-cube.html">Primitive Cube</a></li><li><a href="features__primitive-cylinder.html">Primitive Cylinder</a></li><li><a href="features__primitive-pyramid.html">Primitive Pyramid</a></li><li><a href="features__primitive-sphere.html">Primitive Sphere</a></li><li><a href="features__primitive-torus.html">Primitive Torus</a></li><li><a href="features__push-face.html">Push Face</a></li><li><a href="features__remesh.html">Remesh</a></li><li><a href="features__revolve.html">Revolve</a></li><li><a href="features__sheet-metal-contour-flange.html">Sheet Metal Contour Flange</a></li><li><a href="features__sheet-metal-cutout.html">Sheet Metal Cutout</a></li><li><a href="features__sheet-metal-flange.html">Sheet Metal Flange</a></li><li><a href="features__sheet-metal-hem.html">Sheet Metal Hem</a></li><li><a href="features__sheet-metal-tab.html">Sheet Metal Tab</a></li><li><a href="features__sketch.html">Sketch</a></li><li><a href="features__smooth-with-subdivision.html">Smooth With Subdivision</a></li><li><a href="features__spline.html">Spline</a></li><li><a href="features__sweep.html">Sweep</a></li><li><a href="features__text-to-face.html">Text to Face</a></li><li><a href="features__thicken.html">Thicken</a></li><li><a href="features__transform.html">Transform</a></li><li><a href="features__tube.html">Tube</a></li></ul><p><code>Datum</code> remains as a legacy alias page; <code>Datium</code> is the canonical feature doc.</p>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Getting Started</h1><p>Prerequisites: Node.js 18 or newer and <code>pnpm</code> installed.</p><ul><li>Install dependencies: <code>pnpm install</code></li><li>Run the Vite dev server: <code>pnpm dev</code></li><p>- Open the printed URL (usually <a href="http://localhost:5173" target="_blank" rel="noopener noreferrer">http://localhost:5173</a>). Use <code>index.html</code> for sandbox scenes.</p><li>Run tests: <code>pnpm test</code></li><li>Live testing while editing (Node): <code>pnpm liveTesting</code></li></ul><h2>API Demos</h2><ul><li>Demo hub: <a href="https://BREP.io/apiExamples/index.html">https://BREP.io/apiExamples/index.html</a></li><li>Full demo list + source links: <a href="api-examples.html">API Examples</a></li></ul>
191
+ <h1>Getting Started</h1><p>Prerequisites: Node.js 18 or newer and <code>pnpm</code> installed.</p><ul><li>Install dependencies: <code>pnpm install</code></li><li>Run the Vite dev server: <code>pnpm dev</code></li><p>- Open the printed URL, usually <code><a href="http://localhost:5173" target="_blank" rel="noopener noreferrer">http://localhost:5173</a></code></p><li>Run tests: <code>pnpm test</code></li><li>Live testing while editing (Node): <code>pnpm liveTesting</code></li></ul><h2>API Demos</h2><ul><li>Demo hub: <a href="https://BREP.io/apiExamples/index.html">https://BREP.io/apiExamples/index.html</a></li><li>Full demo list + source links: <a href="api-examples.html">API Examples</a></li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <p><img src="MODELING.png" alt="Modeling Mode" loading="lazy" /></p><h1>Modeling Mode</h1><p>Modeling Mode is the default workspace for solid construction. The scene shows the active history tree, 3D viewport, and main toolbar controls. Add primitives, booleans, and editing features to the timeline, then drag or edit them to re-run the part. Selection filters and gizmos in this mode operate directly on bodies, faces, and edges to drive feature inputs.</p><p>Key tools:</p><ul><li>Main toolbar (Save, Zoom to Fit, Wireframe, Import/Export, About)</li><li>Feature history panel for creating primitives, sketches, and operations</li><li>Expressions panel for global variables and configurator widgets</li><li>Inspector for per-face metrics like area and owning feature</li></ul><p>The Expressions panel supports two related workflows:</p><ul><li><code>expressions</code>: a shared JavaScript-style scratchpad for variables such as <code>width = 20;</code></li><li><code>configurator</code>: a UI-driven set of widgets (<code>slider</code>, <code>number</code>, <code>select</code>, <code>string</code>) whose values are injected into expressions as <code>configurator.fieldName</code></li></ul><p>If configurator widgets exist, the generated configurator form appears above the expression editor. Those values are stored in part history, survive save/load, and can be referenced by feature dialogs through normal expression entry.</p><p>Use Modeling Mode to position solids, apply patterns, and manage global transforms before switching to specialized modes.</p>
191
+ <p><img src="MODELING.png" alt="Modeling Mode" loading="lazy" /></p><h1>Modeling Mode</h1><p>Modeling Mode is the default solid-modeling workspace. It combines the history tree, 3D viewport, and the standard modeling toolbars for building and editing parts.</p><h2>Main Panels</h2><ul><li>Main toolbar for save, view, import/export, and app-level actions</li><li>History panel for creating and reordering features</li><li>Expressions panel for shared variables and configurator widgets</li><li>Inspector for per-face metrics such as area and owning feature</li></ul><h2>Expressions Panel</h2><ul><li><code>expressions</code>: a shared JavaScript-style scratchpad for variables such as <code>width = 20;</code></li><li><code>configurator</code>: a UI-driven set of widgets (<code>slider</code>, <code>number</code>, <code>select</code>, <code>string</code>) whose values are injected into expressions as <code>configurator.fieldName</code></li></ul><p>If configurator widgets exist, their generated form appears above the editor. Those values are stored in part history, survive save/load, and can be referenced from feature dialogs.</p><p>For the feature menu that backs this mode, see <a href="workbenches__modeling.html">Modeling Workbench</a>.</p>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Sketch Mode</h1><p>For complete documentation on Sketch functionality, workflow, and technical details, see:</p><p><strong><a href="features__sketch.html">→ Sketch Feature Documentation</a></strong></p><p>This page covers the complete Sketch feature including:</p><ul><li>Overview and workflow</li><li>Input parameters and behavior</li><li>2D sketching tools and constraints</li><li>Integration with other features (Extrude, Revolve, Loft, Sweep)</li><li>Tool icon legend (Unicode toolbar buttons)</li></ul><h2>Recent Sketcher Additions</h2><ul><li><strong>Trim tool</strong> for line/arc/circle/Bezier editing with local intersection-based trimming</li><li><strong>Bezier editing</strong> improvements (insert points and construction guides)</li><li><strong>Hand draw tool</strong> that auto-converts freehand strokes into sketch geometry with endpoint snapping</li><li><strong>Line to point distance</strong> constraint and dimension (<code>↥</code>) for perpendicular point-to-line measurements</li><li><strong>Under‑constrained point highlight</strong> and quick <strong>Fix/Unfix</strong> toggle in the context toolbar</li><li><strong>Orphan point cleanup</strong> button and auto‑cleanup option in Solver Settings</li></ul>
191
+ <h1>Sketch Mode</h1><p>Sketch Mode is the dedicated editing environment for the <a href="features__sketch.html">Sketch feature</a>. The feature page is the canonical reference for tools, constraints, parameters, and downstream usage.</p><h2>Recent Sketcher Additions</h2><ul><li><strong>Trim tool</strong> for line/arc/circle/Bezier editing with local intersection-based trimming</li><li><strong>Bezier editing</strong> improvements (insert points and construction guides)</li><li><strong>Hand draw tool</strong> that auto-converts freehand strokes into sketch geometry with endpoint snapping</li><li><strong>Line to point distance</strong> constraint and dimension (<code>↥</code>) for perpendicular point-to-line measurements</li><li><strong>Under‑constrained point highlight</strong> and quick <strong>Fix/Unfix</strong> toggle in the context toolbar</li><li><strong>Orphan point cleanup</strong> button and auto‑cleanup option in Solver Settings</li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Plugins and Examples</h1><ul><li>Example plugin repository: <a href="https://github.com/mmiscool/BREPpluginExample" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample</a></li><li>Example plugin README: <a href="https://github.com/mmiscool/BREPpluginExample/blob/master/README.md" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample/blob/master/README.md</a></li><li>Entrypoint: <a href="https://github.com/mmiscool/BREPpluginExample/blob/master/plugin.js" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample/blob/master/plugin.js</a></li><li>Feature example: <a href="https://github.com/mmiscool/BREPpluginExample/blob/master/exampleFeature.js" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample/blob/master/exampleFeature.js</a></li></ul><p>Use the plugin system to extend BREP with custom features, toolbar buttons, or automation pipelines sourced from GitHub.</p><p>When adding dialogs for your feature, follow the shared <code>inputParamsSchema</code> format described in <a href="input-params-schema.html">Input Params Schema</a> to pick field types, defaults, and reference-selection rules.</p>
191
+ <h1>Plugins and Examples</h1><p>Use the plugin system to extend BREP with custom features, toolbar buttons, or automation pipelines sourced from GitHub.</p><h2>Example Plugin</h2><ul><li>Repository: <a href="https://github.com/mmiscool/BREPpluginExample" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample</a></li><li>README: <a href="https://github.com/mmiscool/BREPpluginExample/blob/master/README.md" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample/blob/master/README.md</a></li><li>Entrypoint: <a href="https://github.com/mmiscool/BREPpluginExample/blob/master/plugin.js" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample/blob/master/plugin.js</a></li><li>Feature example: <a href="https://github.com/mmiscool/BREPpluginExample/blob/master/exampleFeature.js" target="_blank" rel="noopener noreferrer">https://github.com/mmiscool/BREPpluginExample/blob/master/exampleFeature.js</a></li></ul><p>When adding dialogs for a plugin feature, follow the shared <a href="input-params-schema.html">Input Params Schema</a> for field types, defaults, and reference-selection rules.</p>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -506,8 +506,8 @@
506
506
  {
507
507
  "title": "API Examples",
508
508
  "href": "api-examples.html",
509
- "summary": "API Examples Standalone browser demos for the BREP kernel and Sketcher2D APIs. This page links every live .html demo under /apiExamples/ , including the examples index page. Example Hub Demo: https://BREP.io/apiExamples/index.html Source: a...",
510
- "content": "API Examples Standalone browser demos for the BREP kernel and Sketcher2D APIs. This page links every live .html demo under /apiExamples/ , including the examples index page. Example Hub Demo: https://BREP.io/apiExamples/index.html Source: apiExamples/index.html BREP Booleans Demo: https://BREP.io/apiExamples/BREP_Booleans.html Source: apiExamples/BREP_Booleans.html BREP Primitives Demo: https://BREP.io/apiExamples/BREP_Primitives.html Source: apiExamples/BREP_Primitives.html BREP Transforms Demo: https://BREP.io/apiExamples/BREP_Transforms.html Source: apiExamples/BREP_Transforms.html BREP Export Demo: https://BREP.io/apiExamples/BREP_Export.html Source: apiExamples/BREP_Export.html Embeded 2D Sketcher Demo: https://BREP.io/apiExamples/Embeded_2D_Sketcher.html Source: apiExamples/Embeded_2D_Sketcher.html Includes host-side exports for SVG, DXF, and sampled per-curve 3D polylines. Embeded CAD Demo: https://BREP.io/apiExamples/Embeded_CAD.html Source: apiExamples/Embeded_CAD.html Mounts the full CAD app with the iframe-based CadEmbed API and shows host-side history/model controls. Embeded CAD (CDN) Demo: https://BREP.io/apiExamples/Embeded_CAD_CDN.html Source: apiExamples/Embeded_CAD_CDN.html Uses direct jsDelivr import: import { BREP, CadEmbed } from \" https://cdn.jsdelivr.net/npm/brep-io-kernel@latest/dist-kernel/brep-kernel.js\"; Embeded CAD Integration Test Demo: https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html Source: apiExamples/Embeded_CAD_Integration_Test.html Runs in-browser assertions across the CadEmbed lifecycle and runtime methods."
509
+ "summary": "API Examples Standalone browser demos for the BREP kernel and Sketcher2D APIs. This page links the live .html demos under /apiExamples/ . Example Hub Demo: https://BREP.io/apiExamples/index.html Source: apiExamples/index.html BREP Booleans....",
510
+ "content": "API Examples Standalone browser demos for the BREP kernel and Sketcher2D APIs. This page links the live .html demos under /apiExamples/ . Example Hub Demo: https://BREP.io/apiExamples/index.html Source: apiExamples/index.html BREP Booleans Demo: https://BREP.io/apiExamples/BREP_Booleans.html Source: apiExamples/BREP_Booleans.html BREP Primitives Demo: https://BREP.io/apiExamples/BREP_Primitives.html Source: apiExamples/BREP_Primitives.html BREP Transforms Demo: https://BREP.io/apiExamples/BREP_Transforms.html Source: apiExamples/BREP_Transforms.html BREP Export Demo: https://BREP.io/apiExamples/BREP_Export.html Source: apiExamples/BREP_Export.html Embedded 2D Sketcher Demo: https://BREP.io/apiExamples/Embeded_2D_Sketcher.html Source: apiExamples/Embeded_2D_Sketcher.html Includes host-side exports for SVG, DXF, and sampled per-curve 3D polylines. Embedded CAD Demo: https://BREP.io/apiExamples/Embeded_CAD.html Source: apiExamples/Embeded_CAD.html Mounts the full CAD app with the iframe-based CadEmbed API and shows host-side history/model controls. Embedded CAD (CDN) Demo: https://BREP.io/apiExamples/Embeded_CAD_CDN.html Source: apiExamples/Embeded_CAD_CDN.html Uses direct jsDelivr import: import { BREP, CadEmbed } from \" https://cdn.jsdelivr.net/npm/brep-io-kernel@latest/dist-kernel/brep-kernel.js\"; Embedded CAD Integration Test Demo: https://BREP.io/apiExamples/Embeded_CAD_Integration_Test.html Source: apiExamples/Embeded_CAD_Integration_Test.html Runs in-browser assertions across the CadEmbed lifecycle and runtime methods."
511
511
  },
512
512
  {
513
513
  "title": "Angle Constraint",
@@ -602,32 +602,32 @@
602
602
  {
603
603
  "title": "Application Architecture Docs",
604
604
  "href": "developer__architecture__index.html",
605
- "summary": "Application Architecture Docs Use this section when you are changing how the application is structured, how history is replayed, how expressions work, or how the UI and feature system are wired together. Core Architecture How It Works PartH...",
606
- "content": "Application Architecture Docs Use this section when you are changing how the application is structured, how history is replayed, how expressions work, or how the UI and feature system are wired together. Core Architecture How It Works PartHistory Reference History Systems Input Params Schema UI and Authoring Systems Expressions and Configurator UI Overview Feature Dimension Gizmos Workbench Implementation Plan Related References Features Index Modeling Mode Sketch Mode PMI Mode 2D Sheets Mode"
605
+ "summary": "Application Architecture Docs Use this section for application structure, history replay, expressions, and UI wiring. Core Architecture How It Works PartHistory Reference History Systems Input Params Schema UI and Authoring Systems Expressi...",
606
+ "content": "Application Architecture Docs Use this section for application structure, history replay, expressions, and UI wiring. Core Architecture How It Works PartHistory Reference History Systems Input Params Schema UI and Authoring Systems Expressions and Configurator UI Overview Feature Dimension Gizmos Workbench Implementation Plan Related References Features Index Modeling Mode Sketch Mode PMI Mode 2D Sheets Mode"
607
607
  },
608
608
  {
609
609
  "title": "Embedding and Integration Docs",
610
610
  "href": "developer__embedding__index.html",
611
- "summary": "Embedding and Integration Docs Use this section when you are embedding the kernel, the full CAD app, or the 2D sketcher into another application. Start Here Getting Started API Examples Embedding APIs Embeddable CAD App ( CadEmbed ) Embedda...",
612
- "content": "Embedding and Integration Docs Use this section when you are embedding the kernel, the full CAD app, or the 2D sketcher into another application. Start Here Getting Started API Examples Embedding APIs Embeddable CAD App ( CadEmbed ) Embeddable 2D Sketcher ( Sketcher2DEmbed ) BREP.js Export Map and Usage Integration Demo Pages Examples Index Embedded CAD Demo Embedded CAD Integration Test Embedded 2D Sketcher Demo Related Topics File Formats: Import and Export GitHub Repo Storage Plugins and Examples"
611
+ "summary": "Embedding and Integration Docs Use this section when embedding the kernel, the full CAD app, or the 2D sketcher into another application. Start Here Getting Started API Examples Embedding APIs Embeddable CAD App ( CadEmbed ) Embeddable 2D S...",
612
+ "content": "Embedding and Integration Docs Use this section when embedding the kernel, the full CAD app, or the 2D sketcher into another application. Start Here Getting Started API Examples Embedding APIs Embeddable CAD App ( CadEmbed ) Embeddable 2D Sketcher ( Sketcher2DEmbed ) BREP.js Export Map and Usage Integration Demo Pages Examples Index Embedded CAD Demo Embedded CAD Integration Test Embedded 2D Sketcher Demo Related Topics File Formats: Import and Export GitHub Repo Storage Plugins and Examples"
613
613
  },
614
614
  {
615
615
  "title": "Kernel and Geometry Docs",
616
616
  "href": "developer__kernel__index.html",
617
- "summary": "Kernel and Geometry Docs Use this section when you are working on the BREP kernel, geometry data model, class APIs, topology tracking, or export behavior. Start Here BREP Kernel Reference - source-level overview of src/BREP responsibilities...",
618
- "content": "Kernel and Geometry Docs Use this section when you are working on the BREP kernel, geometry data model, class APIs, topology tracking, or export behavior. Start Here BREP Kernel Reference - source-level overview of src/BREP responsibilities. BREP Model and Classes - compact conceptual summary of the geometry model. BREP.js Export Map and Usage - what is publicly exported from BREP.js . Core Classes Solid Developer Guide - workflow-oriented overview for Solid . Solid API Index - canonical per-method reference for Solid . Face API Index - canonical per-method reference for Face . Edge API Index - canonical per-method reference for Edge . BREP Class API Reference - hub for all kernel class method docs. Kernel Topics Topological Face Naming and Triangle Ownership Radius Metadata for Extruded Sketches Cylindrical Face Radius Embedding Simplified Radial Dimensions Fillet Process File Formats: Import and Export C++ Solid Porting Notes Example Pages BREP Booleans Demo BREP Primitives Demo BREP Transforms Demo BREP Export Demo Suggested Reading Order Read BREP Kernel Reference for structure. Open BREP Class API Reference for exact class behavior. Use the topic pages above for deeper geometry-specific behavior."
617
+ "summary": "Kernel and Geometry Docs Use this section for the BREP kernel, geometry data model, class APIs, topology tracking, and export behavior. Start Here BREP Kernel Reference - source-level overview of src/BREP responsibilities. BREP Model and Cl...",
618
+ "content": "Kernel and Geometry Docs Use this section for the BREP kernel, geometry data model, class APIs, topology tracking, and export behavior. Start Here BREP Kernel Reference - source-level overview of src/BREP responsibilities. BREP Model and Classes - compact conceptual summary of the geometry model. BREP.js Export Map and Usage - what is publicly exported from BREP.js . Core Classes Solid Developer Guide - workflow-oriented overview for Solid . Solid API Index - canonical per-method reference for Solid . Face API Index - canonical per-method reference for Face . Edge API Index - canonical per-method reference for Edge . BREP Class API Reference - hub for all kernel class method docs. Kernel Topics Topological Face Naming and Triangle Ownership Radius Metadata for Extruded Sketches Cylindrical Face Radius Embedding Simplified Radial Dimensions Fillet Process File Formats: Import and Export C++ Solid Porting Notes Example Pages BREP Booleans Demo BREP Primitives Demo BREP Transforms Demo BREP Export Demo Suggested Reading Order Read BREP Kernel Reference for structure Open BREP Class API Reference for exact class behavior Use the topic pages above for deeper geometry-specific behavior"
619
619
  },
620
620
  {
621
621
  "title": "Application Subsystems Docs",
622
622
  "href": "developer__subsystems__index.html",
623
- "summary": "Application Subsystems Docs Use this section when you are working on a specific subsystem rather than the core kernel or embed APIs. Assembly Constraints Constraint Solver Angle Constraint Coincident Constraint Distance Constraint Fixed Con...",
624
- "content": "Application Subsystems Docs Use this section when you are working on a specific subsystem rather than the core kernel or embed APIs. Assembly Constraints Constraint Solver Angle Constraint Coincident Constraint Distance Constraint Fixed Constraint Parallel Constraint Touch Align Constraint Inspector and Debugging Inspector Inspector Improvements Dialog Screenshots PMI and Annotation Systems PMI Annotations Index Angle Dimension Explode Body Hole Callout Leader Linear Dimension Note Radial Dimension Extension and Platform Topics Plugins and Examples Font Licenses"
623
+ "summary": "Application Subsystems Docs Use this section for application subsystems outside the core kernel and embed APIs. Assembly Constraints Constraint Solver Angle Constraint Coincident Constraint Distance Constraint Fixed Constraint Parallel Cons...",
624
+ "content": "Application Subsystems Docs Use this section for application subsystems outside the core kernel and embed APIs. Assembly Constraints Constraint Solver Angle Constraint Coincident Constraint Distance Constraint Fixed Constraint Parallel Constraint Touch Align Constraint Inspector and Debugging Inspector Inspector Improvements Dialog Screenshots PMI and Annotation Systems PMI Annotations Index Angle Dimension Explode Body Hole Callout Leader Linear Dimension Note Radial Dimension Extension and Platform Topics Plugins and Examples Font Licenses"
625
625
  },
626
626
  {
627
627
  "title": "Developer Docs",
628
628
  "href": "developer-index.html",
629
- "summary": "Developer Docs This is the top-level hub for developer-facing documentation. Pick the area you are working in: Start Here Getting Started - local setup, dev server, and tests. API Examples - runnable examples and demo entry points. Bug Repo...",
630
- "content": "Developer Docs This is the top-level hub for developer-facing documentation. Pick the area you are working in: Start Here Getting Started - local setup, dev server, and tests. API Examples - runnable examples and demo entry points. Bug Reporting and Repro Test Cases - how to capture actionable reports. Developer Discord Developer Doc Sections Kernel and Geometry Docs - BREP kernel architecture, class APIs, topology, metadata, booleans, and geometry internals. Embedding and Integration Docs - CadEmbed , Sketcher2DEmbed , package usage, and integration demos. Application Architecture Docs - PartHistory , history execution, expressions, UI structure, and implementation notes. Application Subsystems Docs - assembly constraints, inspector, PMI annotations, plugins, and related subsystems. Most Used Pages BREP Class API Reference Solid API Index BREP Kernel Reference BREP.js Export Map and Usage PartHistory Reference CadEmbed API Sketcher2DEmbed API"
629
+ "summary": "Developer Docs Top-level hub for developer-facing documentation. Start Here Getting Started - local setup, dev server, and tests API Examples - runnable examples and demo entry points Bug Reporting and Repro Test Cases - how to capture acti...",
630
+ "content": "Developer Docs Top-level hub for developer-facing documentation. Start Here Getting Started - local setup, dev server, and tests API Examples - runnable examples and demo entry points Bug Reporting and Repro Test Cases - how to capture actionable reports Developer Discord Sections Kernel and Geometry Docs - kernel architecture, class APIs, topology, metadata, and geometry internals Embedding and Integration Docs - CadEmbed , Sketcher2DEmbed , package usage, and demos Application Architecture Docs - PartHistory , history execution, expressions, UI structure, and implementation notes Application Subsystems Docs - assembly constraints, inspector, PMI annotations, plugins, and related subsystems Most Used Pages BREP Class API Reference Solid API Index BREP Kernel Reference BREP.js Export Map and Usage PartHistory Reference CadEmbed API Sketcher2DEmbed API"
631
631
  },
632
632
  {
633
633
  "title": "Documentation Screenshots",
@@ -680,14 +680,14 @@
680
680
  {
681
681
  "title": "Datium",
682
682
  "href": "features__datium.html",
683
- "summary": "Datium Status: Implemented Datium creates an orthogonal datum triad (XY/XZ/YZ planes) for sketching and feature references. Inputs transform Position, rotation, and scale applied to the datum group. Behaviour Emits a THREE.Group named aft...",
684
- "content": "Datium Status: Implemented Datium creates an orthogonal datum triad (XY/XZ/YZ planes) for sketching and feature references. Inputs transform Position, rotation, and scale applied to the datum group. Behaviour Emits a THREE.Group named after the feature ID containing three selectable planes tagged as PLANE . Planes are oriented like the Plane feature and respond to the supplied transform, making it easy to anchor sketches or construction geometry away from the origin."
683
+ "summary": "Datium Status: Implemented Datium creates a reference triad of orthogonal XY , XZ , and YZ planes for sketching and other feature inputs. Inputs transform - position, rotation, and scale applied to the datum group. Behaviour Emits a THREE.G...",
684
+ "content": "Datium Status: Implemented Datium creates a reference triad of orthogonal XY , XZ , and YZ planes for sketching and other feature inputs. Inputs transform - position, rotation, and scale applied to the datum group. Behaviour Emits a THREE.Group named after the feature ID with three selectable plane meshes: XY , XZ , and YZ . The planes use the PLANE selection filter, so sketches and other downstream features can target them directly. The triad starts at the world origin, then applies the supplied transform."
685
685
  },
686
686
  {
687
687
  "title": "Datum",
688
688
  "href": "features__datum.html",
689
- "summary": "Datum Status: Implemented Datum creates a lightweight reference group that exposes orthogonal XY/XZ/YZ planes for downstream selections. Inputs transform – position, rotation, and scale applied to the three reference planes. Behaviour The f...",
690
- "content": "Datum Status: Implemented Datum creates a lightweight reference group that exposes orthogonal XY/XZ/YZ planes for downstream selections. Inputs transform position, rotation, and scale applied to the three reference planes. Behaviour The feature emits a THREE.Group named after the feature ID with three plane meshes ( XY , XZ , YZ ). No references are inherited from other geometry yet; the datum always starts at the world origin before the supplied transform is applied. Each plane is selectable through the PLANE selection filter so other features (e.g. sketches) can lock to the datum."
689
+ "summary": "Datum Datum is the legacy name for Datium . Use the Datium page for the current feature behavior, inputs, and screenshots.",
690
+ "content": "Datum Datum is the legacy name for Datium . Use the Datium page for the current feature behavior, inputs, and screenshots."
691
691
  },
692
692
  {
693
693
  "title": "Edge Smooth",
@@ -747,7 +747,7 @@
747
747
  "title": "Features",
748
748
  "href": "features__index.html",
749
749
  "summary": "Features Reference docs for the built-in modeling features. Assembly Component Boolean Chamfer Collapse Edge Datium Edge Smooth Extrude Fillet Helix Hole Image Editor (Shared) Image to Face Image Heightmap Solid Import 3D Model Loft Mirror....",
750
- "content": "Features Reference docs for the built-in modeling features. Assembly Component Boolean Chamfer Collapse Edge Datium Edge Smooth Extrude Fillet Helix Hole Image Editor (Shared) Image to Face Image Heightmap Solid Import 3D Model Loft Mirror NURBS Face Solid Offset Face Offset Shell Overlap Cleanup Pattern (Legacy) Pattern Linear Pattern Radial Plane Polygon Solid Primitive Cone Primitive Cube Primitive Cylinder Primitive Pyramid Primitive Sphere Primitive Torus Push Face Remesh Revolve Sheet Metal Contour Flange Sheet Metal Cutout Sheet Metal Flange Sheet Metal Hem Sheet Metal Tab Sketch Smooth With Subdivision Spline Sweep Text to Face Thicken Transform Tube Datum is kept as a legacy alias page; use Datium for the current feature name."
750
+ "content": "Features Reference docs for the built-in modeling features. Assembly Component Boolean Chamfer Collapse Edge Datium Edge Smooth Extrude Fillet Helix Hole Image Editor (Shared) Image to Face Image Heightmap Solid Import 3D Model Loft Mirror NURBS Face Solid Offset Face Offset Shell Overlap Cleanup Pattern (Legacy) Pattern Linear Pattern Radial Plane Polygon Solid Primitive Cone Primitive Cube Primitive Cylinder Primitive Pyramid Primitive Sphere Primitive Torus Push Face Remesh Revolve Sheet Metal Contour Flange Sheet Metal Cutout Sheet Metal Flange Sheet Metal Hem Sheet Metal Tab Sketch Smooth With Subdivision Spline Sweep Text to Face Thicken Transform Tube Datum remains as a legacy alias page; Datium is the canonical feature doc."
751
751
  },
752
752
  {
753
753
  "title": "Loft",
@@ -968,8 +968,8 @@
968
968
  {
969
969
  "title": "Getting Started",
970
970
  "href": "getting-started.html",
971
- "summary": "Getting Started Prerequisites: Node.js 18 or newer and pnpm installed. Install dependencies: pnpm install Run the Vite dev server: pnpm dev - Open the printed URL (usually http://localhost:5173 ). Use index.html for sandbox scenes. Run test...",
972
- "content": "Getting Started Prerequisites: Node.js 18 or newer and pnpm installed. Install dependencies: pnpm install Run the Vite dev server: pnpm dev - Open the printed URL (usually http://localhost:5173 ). Use index.html for sandbox scenes. Run tests: pnpm test Live testing while editing (Node): pnpm liveTesting API Demos Demo hub: https://BREP.io/apiExamples/index.html Full demo list + source links: API Examples"
971
+ "summary": "Getting Started Prerequisites: Node.js 18 or newer and pnpm installed. Install dependencies: pnpm install Run the Vite dev server: pnpm dev - Open the printed URL, usually http://localhost:5173 Run tests: pnpm test Live testing while editin...",
972
+ "content": "Getting Started Prerequisites: Node.js 18 or newer and pnpm installed. Install dependencies: pnpm install Run the Vite dev server: pnpm dev - Open the printed URL, usually http://localhost:5173 Run tests: pnpm test Live testing while editing (Node): pnpm liveTesting API Demos Demo hub: https://BREP.io/apiExamples/index.html Full demo list + source links: API Examples"
973
973
  },
974
974
  {
975
975
  "title": "GitHub Repo Storage",
@@ -1028,8 +1028,8 @@
1028
1028
  {
1029
1029
  "title": "Modeling Mode",
1030
1030
  "href": "modes__modeling.html",
1031
- "summary": "Modeling Mode Modeling Mode is the default workspace for solid construction. The scene shows the active history tree, 3D viewport, and main toolbar controls. Add primitives, booleans, and editing features to the timeline, then drag or edit....",
1032
- "content": "Modeling Mode Modeling Mode is the default workspace for solid construction. The scene shows the active history tree, 3D viewport, and main toolbar controls. Add primitives, booleans, and editing features to the timeline, then drag or edit them to re-run the part. Selection filters and gizmos in this mode operate directly on bodies, faces, and edges to drive feature inputs. Key tools: Main toolbar (Save, Zoom to Fit, Wireframe, Import/Export, About) Feature history panel for creating primitives, sketches, and operations Expressions panel for global variables and configurator widgets Inspector for per-face metrics like area and owning feature The Expressions panel supports two related workflows: expressions : a shared JavaScript-style scratchpad for variables such as width = 20; configurator : a UI-driven set of widgets ( slider , number , select , string ) whose values are injected into expressions as configurator.fieldName If configurator widgets exist, the generated configurator form appears above the expression editor. Those values are stored in part history, survive save/load, and can be referenced by feature dialogs through normal expression entry. Use Modeling Mode to position solids, apply patterns, and manage global transforms before switching to specialized modes."
1031
+ "summary": "Modeling Mode Modeling Mode is the default solid-modeling workspace. It combines the history tree, 3D viewport, and the standard modeling toolbars for building and editing parts. Main Panels Main toolbar for save, view, import/export, and a...",
1032
+ "content": "Modeling Mode Modeling Mode is the default solid-modeling workspace. It combines the history tree, 3D viewport, and the standard modeling toolbars for building and editing parts. Main Panels Main toolbar for save, view, import/export, and app-level actions History panel for creating and reordering features Expressions panel for shared variables and configurator widgets Inspector for per-face metrics such as area and owning feature Expressions Panel expressions : a shared JavaScript-style scratchpad for variables such as width = 20; configurator : a UI-driven set of widgets ( slider , number , select , string ) whose values are injected into expressions as configurator.fieldName If configurator widgets exist, their generated form appears above the editor. Those values are stored in part history, survive save/load, and can be referenced from feature dialogs. For the feature menu that backs this mode, see Modeling Workbench ."
1033
1033
  },
1034
1034
  {
1035
1035
  "title": "PMI Mode",
@@ -1046,8 +1046,8 @@
1046
1046
  {
1047
1047
  "title": "Sketch Mode",
1048
1048
  "href": "modes__sketch.html",
1049
- "summary": "Sketch Mode For complete documentation on Sketch functionality, workflow, and technical details, see: Sketch Feature Documentation This page covers the complete Sketch feature including: Overview and workflow Input parameters and behavior...",
1050
- "content": "Sketch Mode For complete documentation on Sketch functionality, workflow, and technical details, see: Sketch Feature Documentation This page covers the complete Sketch feature including: Overview and workflow Input parameters and behavior 2D sketching tools and constraints Integration with other features (Extrude, Revolve, Loft, Sweep) Tool icon legend (Unicode toolbar buttons) Recent Sketcher Additions Trim tool for line/arc/circle/Bezier editing with local intersection-based trimming Bezier editing improvements (insert points and construction guides) Hand draw tool that auto-converts freehand strokes into sketch geometry with endpoint snapping Line to point distance constraint and dimension ( ↥ ) for perpendicular point-to-line measurements Under‑constrained point highlight and quick Fix/Unfix toggle in the context toolbar Orphan point cleanup button and auto‑cleanup option in Solver Settings"
1049
+ "summary": "Sketch Mode Sketch Mode is the dedicated editing environment for the Sketch feature . The feature page is the canonical reference for tools, constraints, parameters, and downstream usage. Recent Sketcher Additions Trim tool for line/arc/cir...",
1050
+ "content": "Sketch Mode Sketch Mode is the dedicated editing environment for the Sketch feature . The feature page is the canonical reference for tools, constraints, parameters, and downstream usage. Recent Sketcher Additions Trim tool for line/arc/circle/Bezier editing with local intersection-based trimming Bezier editing improvements (insert points and construction guides) Hand draw tool that auto-converts freehand strokes into sketch geometry with endpoint snapping Line to point distance constraint and dimension ( ↥ ) for perpendicular point-to-line measurements Under‑constrained point highlight and quick Fix/Unfix toggle in the context toolbar Orphan point cleanup button and auto‑cleanup option in Solver Settings"
1051
1051
  },
1052
1052
  {
1053
1053
  "title": "PartHistory Reference",
@@ -1058,8 +1058,8 @@
1058
1058
  {
1059
1059
  "title": "Plugins and Examples",
1060
1060
  "href": "plugins.html",
1061
- "summary": "Plugins and Examples Example plugin repository: https://github.com/mmiscool/BREPpluginExample Example plugin README: https://github.com/mmiscool/BREPpluginExample/blob/master/README.md Entrypoint: https://github.com/mmiscool/BREPpluginExamp...",
1062
- "content": "Plugins and Examples Example plugin repository: https://github.com/mmiscool/BREPpluginExample Example plugin README: https://github.com/mmiscool/BREPpluginExample/blob/master/README.md Entrypoint: https://github.com/mmiscool/BREPpluginExample/blob/master/plugin.js Feature example: https://github.com/mmiscool/BREPpluginExample/blob/master/exampleFeature.js Use the plugin system to extend BREP with custom features, toolbar buttons, or automation pipelines sourced from GitHub. When adding dialogs for your feature, follow the shared inputParamsSchema format described in Input Params Schema to pick field types, defaults, and reference-selection rules."
1061
+ "summary": "Plugins and Examples Use the plugin system to extend BREP with custom features, toolbar buttons, or automation pipelines sourced from GitHub. Example Plugin Repository: https://github.com/mmiscool/BREPpluginExample README: https://github.co...",
1062
+ "content": "Plugins and Examples Use the plugin system to extend BREP with custom features, toolbar buttons, or automation pipelines sourced from GitHub. Example Plugin Repository: https://github.com/mmiscool/BREPpluginExample README: https://github.com/mmiscool/BREPpluginExample/blob/master/README.md Entrypoint: https://github.com/mmiscool/BREPpluginExample/blob/master/plugin.js Feature example: https://github.com/mmiscool/BREPpluginExample/blob/master/exampleFeature.js When adding dialogs for a plugin feature, follow the shared Input Params Schema for field types, defaults, and reference-selection rules."
1063
1063
  },
1064
1064
  {
1065
1065
  "title": "Angle Dimension",
@@ -1166,8 +1166,8 @@
1166
1166
  {
1167
1167
  "title": "All Workbench",
1168
1168
  "href": "workbenches__all.html",
1169
- "summary": "All Workbench The All workbench is the unfiltered view. It exposes every built-in feature that is otherwise grouped into the specialized workbenches. Features Datium Plane Primitive Cube Primitive Cylinder Primitive Cone Primitive Sphere Pr...",
1170
- "content": "All Workbench The All workbench is the unfiltered view. It exposes every built-in feature that is otherwise grouped into the specialized workbenches. Features Datium Plane Primitive Cube Primitive Cylinder Primitive Cone Primitive Sphere Primitive Torus Primitive Pyramid Sketch Extrude Revolve Sweep Tube Boolean Fillet Chamfer Hole Push Face Pattern Linear Pattern Radial Pattern Transform Mirror Text to Face Helix Spline Import 3D Model Image to Face Image Heightmap Solid Loft Offset Face NURBS Face Solid Polygon Solid Smooth With Subdivision Remesh Collapse Edge Edge Smooth Overlap Cleanup Offset Shell Sheet Metal Tab Sheet Metal Contour Flange Sheet Metal Flange Sheet Metal Hem Sheet Metal Cutout Assembly Component Related Features Index"
1169
+ "summary": "All Workbench The All workbench is the unfiltered feature menu. It exposes the full built-in feature set without the category limits used by the specialized workbenches. Includes Core construction and solids from the Modeling Workbench Surf...",
1170
+ "content": "All Workbench The All workbench is the unfiltered feature menu. It exposes the full built-in feature set without the category limits used by the specialized workbenches. Includes Core construction and solids from the Modeling Workbench Surface-oriented tools from the Surfacing Workbench Imported and image-driven flows from the Import Workbench Sheet workflows from the Sheet Metal Workbench Assembly setup from the Assemblies Workbench Use this workbench when you do not want the + menu filtered by task. For the canonical per-feature list, use the Features Index . Related Features Index"
1171
1171
  },
1172
1172
  {
1173
1173
  "title": "Assemblies Workbench",
@@ -1184,8 +1184,8 @@
1184
1184
  {
1185
1185
  "title": "Modeling Workbench",
1186
1186
  "href": "workbenches__modeling.html",
1187
- "summary": "Modeling Workbench The Modeling workbench is the default workbench for new parts. It focuses on core solid modeling and general-purpose construction tools. Features Datium Plane Primitive Cube Primitive Cylinder Primitive Cone Primitive Sph...",
1188
- "content": "Modeling Workbench The Modeling workbench is the default workbench for new parts. It focuses on core solid modeling and general-purpose construction tools. Features Datium Plane Primitive Cube Primitive Cylinder Primitive Cone Primitive Sphere Primitive Torus Primitive Pyramid Sketch Extrude Revolve Sweep Tube Boolean Fillet Chamfer Hole Push Face Pattern Linear Pattern Radial Pattern Transform Mirror Text to Face Helix Spline"
1187
+ "summary": "Modeling Workbench The Modeling workbench is the default workbench for new parts. It keeps the + menu focused on general-purpose solid modeling instead of surfacing, sheet metal, or assembly-only tools. Feature Groups Reference geometry: Da...",
1188
+ "content": "Modeling Workbench The Modeling workbench is the default workbench for new parts. It keeps the + menu focused on general-purpose solid modeling instead of surfacing, sheet metal, or assembly-only tools. Feature Groups Reference geometry: Datium , Plane Primitives: Cube , Cylinder , Cone , Sphere , Torus , Pyramid Sketch-driven creation: Sketch , Extrude , Revolve , Sweep , Tube Editing and booleans: Boolean , Fillet , Chamfer , Hole , Push Face Repetition and transforms: Pattern Linear , Pattern Radial , Pattern (Legacy) , Transform , Mirror Utility geometry: Text to Face , Helix , Spline If you need the unrestricted menu, switch to All Workbench ."
1189
1189
  },
1190
1190
  {
1191
1191
  "title": "PMI Workbench",
@@ -1208,7 +1208,7 @@
1208
1208
  {
1209
1209
  "title": "Wire Harness Workbench",
1210
1210
  "href": "workbenches__wire-harness.html",
1211
- "summary": "Wire Harness Workbench The Wire Harness workbench is for building routed wire runs across assembly ports and spline-guided harness paths. It narrows the creation tools to the geometry and assembly setup needed for harness authoring, while e...",
1212
- "content": "Wire Harness Workbench The Wire Harness workbench is for building routed wire runs across assembly ports and spline-guided harness paths. It narrows the creation tools to the geometry and assembly setup needed for harness authoring, while exposing the harness connection list in the sidebar. Features Datium Plane Assembly Component Spline Port Side Panels Harness Connections : create wires, set From and To endpoints, assign wire diameters, route the harness, inspect route status and length, hover rows to highlight the routed path, and insert the current connection list into a 2D sheet as an editable table. Assembly Constraints : stays available for positioning the components that own the ports. PMI Views : remains available in the same way it is in other modeling-oriented workbenches. Typical Workflow Add the assembly components that contain the ports you want to connect. Add ports and create spline features that define the allowed harness path through the model. Attach spline points to ports and confirm the correct side selection ( A or B ) for each attachment. Use the Harness Connections panel to add wires, set endpoint labels, and enter the wire diameter for each connection. Click Route to rebuild the harness. The list reports route length and status for each wire. Hover a row in the connection list to highlight the related ports and the routed tube geometry in the viewport. Click To Sheet to insert the current connection list into a 2D sheet if you want the harness schedule on a drawing page. Routing Notes Routing operates on the spline network built from the current harness splines and attached ports. The router respects attached port side selection. If no valid sided path exists, the wire remains unrouted and the status column shows the failure. Shared spline segments render as a bundle. Segment diameter increases as more wires use that segment. The Route action also shows the exact JSON payload being passed into the routing logic, which is useful when debugging a harness setup. Related Docs Assemblies Workbench 2D Sheets Mode Spline"
1211
+ "summary": "Wire Harness Workbench The Wire Harness workbench is for routed wire runs across assembly ports and spline-guided harness paths. It narrows creation tools to the geometry needed for harness authoring and exposes the harness connection list....",
1212
+ "content": "Wire Harness Workbench The Wire Harness workbench is for routed wire runs across assembly ports and spline-guided harness paths. It narrows creation tools to the geometry needed for harness authoring and exposes the harness connection list in the sidebar. Features Datium Plane Assembly Component Spline Port Side Panels Harness Connections : create wires, set From and To , assign diameters, route the harness, inspect status and length, and insert the current connection list into a 2D sheet table. Assembly Constraints : position the components that own the ports. PMI Views : remains available like it does in other modeling-oriented workbenches. Typical Workflow Add the assembly components that contain the ports you want to connect. Add ports and create spline features that define the allowed harness path through the model. Attach spline points to ports and confirm the correct side selection ( A or B ) for each attachment. Use the Harness Connections panel to add wires, set endpoint labels, and enter the wire diameter for each connection. Click Route to rebuild the harness. The list reports route length and status for each wire. Hover a row to highlight the related ports and routed tube geometry. Click To Sheet to place the current connection list on a 2D sheet. Routing Notes Routing operates on the spline network built from the current harness splines and attached ports. The router respects attached port side selection. If no valid sided path exists, the wire remains unrouted and the status column shows the failure. Shared spline segments render as a bundle. Segment diameter increases as more wires use that segment. The Route action also shows the JSON payload passed into the routing logic, which is useful when debugging a harness setup. Related Docs Assemblies Workbench 2D Sheets Mode Spline"
1213
1213
  }
1214
1214
  ]
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>All Workbench</h1><p>The All workbench is the unfiltered view. It exposes every built-in feature that is otherwise grouped into the specialized workbenches.</p><h2>Features</h2><ul><li><a href="features__datium.html">Datium</a></li><li><a href="features__plane.html">Plane</a></li><li><a href="features__primitive-cube.html">Primitive Cube</a></li><li><a href="features__primitive-cylinder.html">Primitive Cylinder</a></li><li><a href="features__primitive-cone.html">Primitive Cone</a></li><li><a href="features__primitive-sphere.html">Primitive Sphere</a></li><li><a href="features__primitive-torus.html">Primitive Torus</a></li><li><a href="features__primitive-pyramid.html">Primitive Pyramid</a></li><li><a href="features__sketch.html">Sketch</a></li><li><a href="features__extrude.html">Extrude</a></li><li><a href="features__revolve.html">Revolve</a></li><li><a href="features__sweep.html">Sweep</a></li><li><a href="features__tube.html">Tube</a></li><li><a href="features__boolean.html">Boolean</a></li><li><a href="features__fillet.html">Fillet</a></li><li><a href="features__chamfer.html">Chamfer</a></li><li><a href="features__hole.html">Hole</a></li><li><a href="features__push-face.html">Push Face</a></li><li><a href="features__pattern-linear.html">Pattern Linear</a></li><li><a href="features__pattern-radial.html">Pattern Radial</a></li><li><a href="features__pattern.html">Pattern</a></li><li><a href="features__transform.html">Transform</a></li><li><a href="features__mirror.html">Mirror</a></li><li><a href="features__text-to-face.html">Text to Face</a></li><li><a href="features__helix.html">Helix</a></li><li><a href="features__spline.html">Spline</a></li><li><a href="features__import-3d-model.html">Import 3D Model</a></li><li><a href="features__image-to-face.html">Image to Face</a></li><li><a href="features__image-heightmap-solid.html">Image Heightmap Solid</a></li><li><a href="features__loft.html">Loft</a></li><li><a href="features__offset-face.html">Offset Face</a></li><li><a href="features__nurbs-face-solid.html">NURBS Face Solid</a></li><li><a href="features__polygon-solid.html">Polygon Solid</a></li><li><a href="features__smooth-with-subdivision.html">Smooth With Subdivision</a></li><li><a href="features__remesh.html">Remesh</a></li><li><a href="features__collapse-edge.html">Collapse Edge</a></li><li><a href="features__edge-smooth.html">Edge Smooth</a></li><li><a href="features__overlap-cleanup.html">Overlap Cleanup</a></li><li><a href="features__offset-shell.html">Offset Shell</a></li><li><a href="features__sheet-metal-tab.html">Sheet Metal Tab</a></li><li><a href="features__sheet-metal-contour-flange.html">Sheet Metal Contour Flange</a></li><li><a href="features__sheet-metal-flange.html">Sheet Metal Flange</a></li><li><a href="features__sheet-metal-hem.html">Sheet Metal Hem</a></li><li><a href="features__sheet-metal-cutout.html">Sheet Metal Cutout</a></li><li><a href="features__assembly-component.html">Assembly Component</a></li></ul><h2>Related</h2><ul><li><a href="features__index.html">Features Index</a></li></ul>
191
+ <h1>All Workbench</h1><p>The All workbench is the unfiltered feature menu. It exposes the full built-in feature set without the category limits used by the specialized workbenches.</p><h2>Includes</h2><ul><li>Core construction and solids from the <a href="workbenches__modeling.html">Modeling Workbench</a></li><li>Surface-oriented tools from the <a href="workbenches__surfacing.html">Surfacing Workbench</a></li><li>Imported and image-driven flows from the <a href="workbenches__import.html">Import Workbench</a></li><li>Sheet workflows from the <a href="workbenches__sheet-metal.html">Sheet Metal Workbench</a></li><li>Assembly setup from the <a href="workbenches__assemblies.html">Assemblies Workbench</a></li></ul><p>Use this workbench when you do not want the <code>+</code> menu filtered by task. For the canonical per-feature list, use the <a href="features__index.html">Features Index</a>.</p><h2>Related</h2><ul><li><a href="features__index.html">Features Index</a></li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Modeling Workbench</h1><p>The Modeling workbench is the default workbench for new parts. It focuses on core solid modeling and general-purpose construction tools.</p><h2>Features</h2><ul><li><a href="features__datium.html">Datium</a></li><li><a href="features__plane.html">Plane</a></li><li><a href="features__primitive-cube.html">Primitive Cube</a></li><li><a href="features__primitive-cylinder.html">Primitive Cylinder</a></li><li><a href="features__primitive-cone.html">Primitive Cone</a></li><li><a href="features__primitive-sphere.html">Primitive Sphere</a></li><li><a href="features__primitive-torus.html">Primitive Torus</a></li><li><a href="features__primitive-pyramid.html">Primitive Pyramid</a></li><li><a href="features__sketch.html">Sketch</a></li><li><a href="features__extrude.html">Extrude</a></li><li><a href="features__revolve.html">Revolve</a></li><li><a href="features__sweep.html">Sweep</a></li><li><a href="features__tube.html">Tube</a></li><li><a href="features__boolean.html">Boolean</a></li><li><a href="features__fillet.html">Fillet</a></li><li><a href="features__chamfer.html">Chamfer</a></li><li><a href="features__hole.html">Hole</a></li><li><a href="features__push-face.html">Push Face</a></li><li><a href="features__pattern-linear.html">Pattern Linear</a></li><li><a href="features__pattern-radial.html">Pattern Radial</a></li><li><a href="features__pattern.html">Pattern</a></li><li><a href="features__transform.html">Transform</a></li><li><a href="features__mirror.html">Mirror</a></li><li><a href="features__text-to-face.html">Text to Face</a></li><li><a href="features__helix.html">Helix</a></li><li><a href="features__spline.html">Spline</a></li></ul>
191
+ <h1>Modeling Workbench</h1><p>The Modeling workbench is the default workbench for new parts. It keeps the <code>+</code> menu focused on general-purpose solid modeling instead of surfacing, sheet metal, or assembly-only tools.</p><h2>Feature Groups</h2><ul><li>Reference geometry: <a href="features__datium.html">Datium</a>, <a href="features__plane.html">Plane</a></li><li>Primitives: <a href="features__primitive-cube.html">Cube</a>, <a href="features__primitive-cylinder.html">Cylinder</a>, <a href="features__primitive-cone.html">Cone</a>, <a href="features__primitive-sphere.html">Sphere</a>, <a href="features__primitive-torus.html">Torus</a>, <a href="features__primitive-pyramid.html">Pyramid</a></li><li>Sketch-driven creation: <a href="features__sketch.html">Sketch</a>, <a href="features__extrude.html">Extrude</a>, <a href="features__revolve.html">Revolve</a>, <a href="features__sweep.html">Sweep</a>, <a href="features__tube.html">Tube</a></li><li>Editing and booleans: <a href="features__boolean.html">Boolean</a>, <a href="features__fillet.html">Fillet</a>, <a href="features__chamfer.html">Chamfer</a>, <a href="features__hole.html">Hole</a>, <a href="features__push-face.html">Push Face</a></li><li>Repetition and transforms: <a href="features__pattern-linear.html">Pattern Linear</a>, <a href="features__pattern-radial.html">Pattern Radial</a>, <a href="features__pattern.html">Pattern (Legacy)</a>, <a href="features__transform.html">Transform</a>, <a href="features__mirror.html">Mirror</a></li><li>Utility geometry: <a href="features__text-to-face.html">Text to Face</a>, <a href="features__helix.html">Helix</a>, <a href="features__spline.html">Spline</a></li></ul><p>If you need the unrestricted menu, switch to <a href="workbenches__all.html">All Workbench</a>.</p>
192
192
  </div>
193
193
  </section>
194
194
  </div>
@@ -188,7 +188,7 @@ a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
188
188
  <section class="card doc-card doc-page-card">
189
189
 
190
190
  <div class="prose">
191
- <h1>Wire Harness Workbench</h1><p>The Wire Harness workbench is for building routed wire runs across assembly ports and spline-guided harness paths. It narrows the creation tools to the geometry and assembly setup needed for harness authoring, while exposing the harness connection list in the sidebar.</p><h2>Features</h2><ul><li><a href="features__datium.html">Datium</a></li><li><a href="features__plane.html">Plane</a></li><li><a href="features__assembly-component.html">Assembly Component</a></li><li><a href="features__spline.html">Spline</a></li><li>Port</li></ul><h2>Side Panels</h2><ul><li><code>Harness Connections</code>: create wires, set <code>From</code> and <code>To</code> endpoints, assign wire diameters, route the harness, inspect route status and length, hover rows to highlight the routed path, and insert the current connection list into a 2D sheet as an editable table.</li><li><code>Assembly Constraints</code>: stays available for positioning the components that own the ports.</li><li><code>PMI Views</code>: remains available in the same way it is in other modeling-oriented workbenches.</li></ul><h2>Typical Workflow</h2><ol><li>Add the assembly components that contain the ports you want to connect.</li><li>Add ports and create spline features that define the allowed harness path through the model.</li><li>Attach spline points to ports and confirm the correct side selection (<code>A</code> or <code>B</code>) for each attachment.</li><li>Use the <code>Harness Connections</code> panel to add wires, set endpoint labels, and enter the wire diameter for each connection.</li><li>Click <code>Route</code> to rebuild the harness. The list reports route length and status for each wire.</li><li>Hover a row in the connection list to highlight the related ports and the routed tube geometry in the viewport.</li><li>Click <code>To Sheet</code> to insert the current connection list into a 2D sheet if you want the harness schedule on a drawing page.</li></ol><h2>Routing Notes</h2><ul><li>Routing operates on the spline network built from the current harness splines and attached ports.</li><li>The router respects attached port side selection. If no valid sided path exists, the wire remains unrouted and the status column shows the failure.</li><li>Shared spline segments render as a bundle. Segment diameter increases as more wires use that segment.</li><li>The <code>Route</code> action also shows the exact JSON payload being passed into the routing logic, which is useful when debugging a harness setup.</li></ul><h2>Related Docs</h2><ul><li><a href="workbenches__assemblies.html">Assemblies Workbench</a></li><li><a href="modes__sheets.html">2D Sheets Mode</a></li><li><a href="features__spline.html">Spline</a></li></ul>
191
+ <h1>Wire Harness Workbench</h1><p>The Wire Harness workbench is for routed wire runs across assembly ports and spline-guided harness paths. It narrows creation tools to the geometry needed for harness authoring and exposes the harness connection list in the sidebar.</p><h2>Features</h2><ul><li><a href="features__datium.html">Datium</a></li><li><a href="features__plane.html">Plane</a></li><li><a href="features__assembly-component.html">Assembly Component</a></li><li><a href="features__spline.html">Spline</a></li><li>Port</li></ul><h2>Side Panels</h2><ul><li><code>Harness Connections</code>: create wires, set <code>From</code> and <code>To</code>, assign diameters, route the harness, inspect status and length, and insert the current connection list into a 2D sheet table.</li><li><code>Assembly Constraints</code>: position the components that own the ports.</li><li><code>PMI Views</code>: remains available like it does in other modeling-oriented workbenches.</li></ul><h2>Typical Workflow</h2><ol><li>Add the assembly components that contain the ports you want to connect.</li><li>Add ports and create spline features that define the allowed harness path through the model.</li><li>Attach spline points to ports and confirm the correct side selection (<code>A</code> or <code>B</code>) for each attachment.</li><li>Use the <code>Harness Connections</code> panel to add wires, set endpoint labels, and enter the wire diameter for each connection.</li><li>Click <code>Route</code> to rebuild the harness. The list reports route length and status for each wire.</li><li>Hover a row to highlight the related ports and routed tube geometry.</li><li>Click <code>To Sheet</code> to place the current connection list on a 2D sheet.</li></ol><h2>Routing Notes</h2><ul><li>Routing operates on the spline network built from the current harness splines and attached ports.</li><li>The router respects attached port side selection. If no valid sided path exists, the wire remains unrouted and the status column shows the failure.</li><li>Shared spline segments render as a bundle. Segment diameter increases as more wires use that segment.</li><li>The <code>Route</code> action also shows the JSON payload passed into the routing logic, which is useful when debugging a harness setup.</li></ul><h2>Related Docs</h2><ul><li><a href="workbenches__assemblies.html">Assemblies Workbench</a></li><li><a href="modes__sheets.html">2D Sheets Mode</a></li><li><a href="features__spline.html">Spline</a></li></ul>
192
192
  </div>
193
193
  </section>
194
194
  </div>