2.2 KiB
| id | ticket | title | created | tags | ||||
|---|---|---|---|---|---|---|---|---|
| LSN-0005 | studio-docs-import | Studio events and components legacy lesson | 2026-03-26 |
|
Context
Legacy import from docs/studio/learn/mental-model-studio-events-and-components.md.
This lesson preserves the Studio-wide mental model for typed events and the prometeu-studio-components control layer.
Key Decisions
Studio should grow through typed events and a Studio-owned control layer
What: The Studio should use a typed event model with both workspace buses and a global bus, automatically republishing workspace events upward, while visible controls should come through prometeu-studio-components rather than raw JavaFX usage scattered across the app.
Why: Direct references between shell, workspaces, and services create coupling that becomes hard to unwind as the application gains global activity, background operations, multiple workspaces, and cross-cutting actions. Raw JavaFX use also causes naming, styling, and behavior drift.
Trade-offs: This approach adds explicit control layers and event publication paths, but it keeps the UI dialect smaller, more opinionated, and easier to evolve consistently.
Patterns and Algorithms
- Give each workspace its own bus and republish workspace events to the global Studio bus.
- Keep event publication explicit and typed.
- Use
prometeu-studio-componentsas the Studio-facing control API rather than reimplementing JavaFX wholesale. - When adding UI code, ask whether the behavior is an event and whether the control is part of the Studio-visible dialect.
Pitfalls
- Letting shell, workspaces, and services call each other directly by convenience.
- Spreading raw JavaFX controls directly across the app.
- Recreating local wrappers and styling hooks inconsistently.
- Treating the component layer as a full JavaFX replacement instead of a focused Studio API.
Takeaways
- Typed events and a Studio-owned control layer solve different problems, but together they prevent architectural drift as the UI grows.
- Workspace-local segregation and global shell visibility both matter; one bus alone is not enough.
- Legacy source attribution:
docs/studio/learn/mental-model-studio-events-and-components.md.