- C#-Plugin "DOSSIER" mit 23 nativen Commands (dWall, dDoor, ..., dSection)
- Native Command-Namen + Autocomplete + saubere History
- Idle-Defer + RhinoCode-API → kein _-RunPythonScript-Echo
- Yak-Paket via build.sh, Install in ~/Library/.../packages/8.0/
- Launcher (Tauri):
- dossier_init Tauri-Command + Setup-Tab in Settings
- Yak-Install + StartupCommands-XML + Window-Layout in einem Schritt
- clean-rhino.sh fuer reproduzierbare Resets
- check_dossier_initialized triggert Auto-Open-Setup beim ersten Start
- Wand-Architektur:
- Chain-Logik DEAKTIVIERT → jede Wand baut eigenes Volume (individuell
anwaehlbar, einzeln loeschbar)
- Polyline-Wand: jedes Segment = eigene Wand
- Smart-Split fuer wand_axis/decke/dach/raum/aussparung/traeger
- Auto-Group axis+volume → kein ChooseOne-Dialog, Delete loescht beides
- Stale-Mitre-Fix: Joint-Cache wird vor jedem Wand-Regen invalidiert
- T-Junction-Tolerance auf 1mm (war 1cm, lieferte falsche T-Mitres)
- Wand-Stile:
- Schema in dossier_project_settings.wand_styles (Material + Prio +
Default-Dicke + Referenz, oder Layered mit Schichten)
- dWall-Command Stil-Picker
- ProjectSettingsDialog: Sidebar-Layout (Pill-Selection) +
Wandstile-Tab mit Liste/Editor
- _wand_chain_compat benutzt style_id
- Prio-Dominanz: hoehere Prio gewinnt Eckverbindung, niedrigere wird
T-mitered (siehe _resolve_corner_miter)
- Cmd+G fuer Group (Geschoss-Up auf Alias 'gu')
- Welcome + Cheatsheet borderless mit X/Back-Buttons
- BeginCommand-Hook fuer Gestaltung-Panel-Auto-Open
- panel_base: Python.NET-Enum-Fix fuer Material-Render
Dossier Launcher
Standalone macOS-App, die als Projekt-Hub für Dossier-Projekte in Rhino 8 dient.
Wählt eine .3dm aus, konfiguriert pro Projekt welche Module aktiv sind, startet
Rhino mit der Datei. Das Python-Plugin in rhino/ liest beim Start die
dossier.project.json (neben der .3dm) und lädt nur die aktivierten Module.
Setup (einmalig)
1. Dependencies installieren
cd launcher
npm install
Beim ersten npm run tauri dev zieht Cargo zusätzlich die Rust-Dependencies
(dauert ein paar Minuten).
2. Rhino Auto-Run einrichten
Damit die Module bei jedem Rhino-Start automatisch laden:
- Rhino 8 starten
Rhinoceros 8→Preferences→General→ Startup commands- Folgende Zeile eintragen:
_-RunPythonScript "/Users/karim/STUDIO/DOSSIER/rhino/startup.py" - OK → Rhino neu starten
Ab jetzt lädt startup.py bei jedem Rhino-Start:
- mit
dossier.project.jsonneben der.3dm→ nur konfigurierte Module - ohne Config → alle Module (Backwards-Compat zum bisherigen Verhalten)
Entwicklung
npm run tauri dev
Startet Vite (Port 5174) und öffnet die Tauri-Window. Hot-Reload für React, Rust-Änderungen brauchen einen Rebuild.
Build (.app + .dmg)
npm run tauri build
Output: src-tauri/target/release/bundle/macos/Dossier.app und
src-tauri/target/release/bundle/dmg/Dossier_0.1.0_*.dmg
Vor dem ersten Build: Icons hinterlegen. Aktuell ist bundle.icon in
src-tauri/tauri.conf.json leer. Mit
npm run tauri icon path/zur/icon.png
generiert Tauri das vollständige Icon-Set (1024×1024 PNG als Quelle reicht).
Architektur
launcher/
├── modules.json # Modul-Manifest (statisch, in Binary einkompiliert)
├── src/ # React-Frontend
│ ├── App.jsx # Project Hub + Modul-Dialog
│ └── styles.css
└── src-tauri/ # Rust-Backend
├── src/lib.rs # Tauri-Commands
└── tauri.conf.json
Datenfluss:
- Launcher liest
~/Library/Application Support/Dossier/recent.json - User klickt „Öffnen" → Launcher schreibt
dossier.project.jsonneben die.3dmund ruftopen -a "Rhinoceros 8" file.3dm - Rhino startet,
startup.pyläuft, liest die Config, lädt nur die aktivierten Module - Jedes Modul registriert sein eigenes Panel via
panel_base.register_and_open
Module-Manifest erweitern
Wenn ein neues Modul dazukommt, drei Stellen synchron halten:
launcher/modules.json— Eintrag mitid,name,description,pythonModule,dependsOnrhino/startup.py—_MODULE_TO_PYMap ergänzenrhino/<pythonModule>.py— die Python-Implementierung
Launcher rebuilden (npm run tauri build), neue .app ersetzt die alte.