Go to file
Antony Male c6224952ec Merge branch 'release/1.3.2' into develop 2020-04-23 18:03:42 +01:00
Bootstrappers Fix disposal in NoIoCContainerBootstrapper 2018-09-30 18:57:32 +01:00
NuGet Tweak nuspcs and README 2019-09-25 12:36:16 +01:00
Samples Update NuGet packages to fix Fody breakage in newer VS versions 2019-01-10 12:33:05 +00:00
Stylet Throw a better exception than an NRE if they forget to call builder.Bind(..).To(..) 2020-04-23 17:58:28 +01:00
StyletIntegrationTests Turns out it is possible to have a single csproj targetting both core and framework 2019-09-22 17:12:54 +01:00
StyletTemplates Fix default namespace in .NET Core project template 2020-03-12 21:25:22 +00:00
StyletUnitTests Throw a better exception than an NRE if they forget to call builder.Bind(..).To(..) 2020-04-23 17:58:28 +01:00
.gitattributes Use powershell, and powershell only, for Stylet.Start 2016-04-04 14:48:16 +01:00
.gitignore Add support for CommandBinding in Actions 2018-09-30 17:56:51 +01:00
CHANGELOG.txt Update changelog 2020-04-23 18:03:28 +01:00
LICENSE.txt Actually fill in the blanks in the license 2014-05-23 13:08:19 +01:00
README.md Fix typo in README 2019-09-26 12:28:41 +01:00
Rakefile Add a .NET Core template 2019-09-24 14:51:33 +01:00
Stylet.sln Add a .NET Core template 2019-09-24 14:51:33 +01:00
Stylet.sln.DotSettings Align style with ReSharper 2015-01-14 15:08:43 +00:00
StyletIcon.png First attempt at an icon 2014-04-19 00:17:08 +01:00
StyletIcon.svg First attempt at an icon 2014-04-19 00:17:08 +01:00
global.json Add a .NET Core template 2019-09-24 14:51:33 +01:00

README.md

Project Icon Stylet

NuGet Build status

Introduction

Stylet is a small but powerful ViewModel-first MVVM framework for WPF (.NET 4.5+ and .NET Core 3.0+), which allows you to write maintainable and extensible code in a way which is easy to test. Stylet's aims are to:

  • Solve the blockers, niggles, and annoyances which hamper MVVM development without a framework, using simple but powerful concepts.
  • Be obvious to people picking up your project for the first time: there's very little magic
  • Be easy to verify/validate. The LOC count is low, and it comes with a very comprehensive test suite. The code is well-written and well-documented.
  • Be flexible while providing sensible defaults. Almost any part of the framework can be overridden if you wish, but you probably won't want to.

It is inspired by Caliburn.Micro, and shares many of its concepts, but removes most of the magic (replacing it with more powerful alternatives), and simplifies parts considerably by targeting only MVVM, WPF and .NET 4.5.

Getting Started

.NET Framework

For .NET Framework projects, the quickest way to get started is to create a new "WPF Application" project, then install the NuGet package Stylet.Start. This will install Stylet, and set up a simple skeleton project.

See Quick Start for more details.

If you want to set up your project manually, install the Stylet package, then follow the instructions in the Quick Start.

Stylet requires .NET 4.5 (Visual Studio 2012 or higher).

.NET Core

For .NET Core projects, the quickest way to get started is by using dotnet new with Stylet's template.

Open a command window where you want to create your new project, and install the Stylet templates using:

dotnet new -i Stylet.Templates

Then create a new project with:

dotnet new stylet -o MyStyletProject

(changing MyStyletProject as appropriate).

If you want to set up your project manually, install the Stylet package, then follow the instructions in the Quick Start.

Stylet requires .NET Core 3.0.

Documentation

The Wiki is the documentation source. There's loads of information there - go and have a look, or start with the Quick Start.

Symbols

The source is also available when you are debugging, using Source Link. Go to Debug -> Options and Settings -> General, and make the following changes:

  • Turn off "Enable Just My Code"
  • Turn on "Enable Source Link support"
  • Turn off "Enable .NET Framework source stepping". Yes, it is misleading, but if you don't, then Visual Studio will ignore your custom server order and only use its own servers.

Contributing

Contributions are always welcome. If you've got a problem or a question, raise an issue. If you've got code you want to contribute, please read the Contributing guidelines first of all. Create a feature branch off the develop branch, add your changes there, and submit it as a pull request.