Metadata-Version: 2.4
Name: marimo-cad
Version: 0.1.0
Summary: Reactive Parametric CAD for marimo notebooks
Project-URL: Homepage, https://github.com/cemrehancavdar/marimo-cad
Project-URL: Repository, https://github.com/cemrehancavdar/marimo-cad
Project-URL: Issues, https://github.com/cemrehancavdar/marimo-cad/issues
Author-email: Cemrehan Cavdar <cemrehancavdar@hotmail.com>
License: MIT
License-File: LICENSE
Keywords: 3d,anywidget,build123d,cad,marimo,parametric
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Scientific/Engineering :: Visualization
Requires-Python: >=3.10
Requires-Dist: anywidget>=0.9.0
Requires-Dist: build123d>=0.10.0
Requires-Dist: marimo>=0.9.0
Requires-Dist: ocp-tessellate>=3.0.0
Provides-Extra: dev
Requires-Dist: pytest; extra == 'dev'
Requires-Dist: ruff; extra == 'dev'
Provides-Extra: gears
Requires-Dist: bd-warehouse>=0.1.0; extra == 'gears'
Description-Content-Type: text/markdown

# marimo-cad

**Reactive Parametric CAD** for [marimo](https://marimo.io) notebooks.

Build interactive 3D CAD models with sliders that update in real-time without losing your camera position.

![Parametric Bookshelf Demo](assets/demo.gif)

## Why marimo-cad?

| Use Case | Native build123d | marimo-cad |
|----------|------------------|------------|
| Quick visualization | Just return the object | Overkill |
| **Parametric design with sliders** | Camera resets on every change | Camera preserved |
| Named multi-part assemblies | No | Yes, with tree view |
| Export (STL/STEP/GLTF) | Manual | Built-in |

## Installation

```bash
uv add marimo-cad
```

## Quick Start

```python
import marimo as mo
from build123d import Box
import marimo_cad as cad

size = mo.ui.slider(10, 50, value=20, label="Size")
viewer = cad.Viewer()

box = Box(size.value, size.value, size.value)
viewer.render(box)

mo.vstack([size, viewer])
```

## Examples

See [notebooks/](notebooks/) for complete examples:
- `bookshelf.py` - Parametric bookshelf
- `vase.py` - Parametric vase with STL export

## Viewer Features

- **Mouse**: Rotate (drag), pan (right-drag), zoom (scroll)
- **Tree view**: Toggle part visibility
- **Clipping planes**: Slice along X/Y/Z
- **Measurement**: Distance and angles

## Limitations

- Large models (>100k triangles) may be slow to tessellate
- Selection events not yet exposed to Python

## Development

```bash
uv sync && cd js && npm install && npm run build && cd ..
uv run pytest tests/           # 34 tests
uv run ruff check src/ --fix   # Lint
```

---

## API Reference

### Viewer

```python
viewer = cad.Viewer(width="100%", height=600)
viewer.render(shapes)
```

| Parameter | Type | Default | Description |
|-----------|------|---------|-------------|
| `width` | `str \| int` | `"100%"` | CSS width or pixels |
| `height` | `int` | `600` | Height in pixels |

**render(shapes)** - Render shapes, preserving camera position.

```python
# Single shape
viewer.render(box)

# Multiple shapes
viewer.render([box, cylinder])

# Named parts with colors
viewer.render([
    {"shape": base, "name": "Base", "color": "blue"},
    {"shape": top, "name": "Top", "color": "red", "alpha": 0.8},
])
```

### PartSpec

Dict for specifying parts with metadata:

| Key | Type | Required | Description |
|-----|------|----------|-------------|
| `shape` | `Shape` | Yes | build123d object |
| `name` | `str` | No | Display name |
| `color` | `str` | No | Color name or hex |
| `alpha` | `float` | No | Opacity 0.0-1.0 |

### COLORS

Available named colors: `blue`, `red`, `green`, `yellow`, `orange`, `purple`, `cyan`, `pink`, `gray`, `white`, `black`

```python
{"shape": box, "color": "blue"}      # Named
{"shape": box, "color": "#ff6600"}   # Hex
```

### Export Functions

```python
from marimo_cad import export_stl, export_step, export_gltf

export_stl(obj, "part.stl")                    # 3D printing
export_stl(obj, "fine.stl", tolerance=0.0001)  # Higher resolution
export_step(obj, "part.step")                  # CAD interchange (lossless)
export_gltf(obj, "part.glb")                   # Web viewers
```

| Function | Parameters | Description |
|----------|------------|-------------|
| `export_stl` | `obj, filename, tolerance=0.001, angular_tolerance=0.1` | Tessellated mesh |
| `export_step` | `obj, filename` | Exact geometry |
| `export_gltf` | `obj, filename` | Web-ready format |

All return `Path` to exported file.

### How It Works

1. **Tessellate**: build123d → triangle meshes (ocp-tessellate)
2. **Transport**: Mesh data → JavaScript (anywidget)
3. **Render**: Three.js via three-cad-viewer
4. **Update**: `render()` updates geometry, camera preserved

## License

MIT
