Orchestra is a composable shell built on top of Catel.
Orchestra consists of a main shell including an SDK with services that allows developers to communicate with the shell. Developers can write their own modules which implement the actual functionality of their application.
These modules can communicate with the shell, but also with each other through the services that are offered out of the box.
Orchestra provides support for a lot of different shells.
Please check LogViewer, for an example on how to build an application with Orchestra.
Some of the features which will come out of the box:
- MahApps integration
- Module management (Nearly there with Orc.NuGetExplorer)
- License management => Orc.LicenseManager
- Command management
- Shortcut manager (which will allow end users to remap shortcut keys)
- Splash screen customization
- About box window
- Automatic updates => Orc.Squirrel
Features already included in Catel:
- Application wide logging
- FluentValidation
- Memento (undo/redo)
Other Projects that might be of interest (And integrate easily with Orchestra):
- Orc.ProjectManagement
- Orc.WorkspaceManagement
- Orc.LicenseManager
- Orc.Squirrel (Automatic Updates)
- Orc.FilterBuilder
- Orc.Controls
- Orc.Search
- Orc.Feedback
- Orc.SystemInfo
- Orc.CrashReporting
- Orc.Notifications
- Orc.NuGetExplorer
MIT License
- Framework developed with best practices in mind which will allow you to deploy robust applications
- Allows you to focus on the business logic so your application will be completed a lot sooner
- Built on Catel and all that goes with it giving you a head start on your project
- Nuget packages released regularly:
- Visual Studio templates to get started quickly
Orchestra uses a plugin architecture with some already well know open source libraries already implemented:
- Catel (MVVM framework plus a lot more)
- Fluent Ribbon
- Prism
- Nancy (Lightweight Web Framework for .NET)
- OxyPlot (Cross platform plotting library - Work in progress)
It is easy to add extra modules by following the examples.
- Automatic plugin update infrastructure
Please create an issue.
Everyone is encouraged to contribute, either by:
- Submitting pull requests
- Documentation
- Blogs and tutorials