ReduxSimple.DevTools 3.7.0-preview001

This is a prerelease version of ReduxSimple.DevTools.
Install-Package ReduxSimple.DevTools -Version 3.7.0-preview001
dotnet add package ReduxSimple.DevTools --version 3.7.0-preview001
<PackageReference Include="ReduxSimple.DevTools" Version="3.7.0-preview001" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ReduxSimple.DevTools --version 3.7.0-preview001
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: ReduxSimple.DevTools, 3.7.0-preview001"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install ReduxSimple.DevTools as a Cake Addin
#addin nuget:?package=ReduxSimple.DevTools&version=3.7.0-preview001&prerelease

// Install ReduxSimple.DevTools as a Cake Tool
#tool nuget:?package=ReduxSimple.DevTools&version=3.7.0-preview001&prerelease
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

Redux Simple

Simple Stupid Redux Store using Reactive Extensions

Redux Simple is a .NET library based on Redux principle. Redux Simple is written with Rx.NET and built with the minimum of code you need to scale your whatever .NET application you want to design.

Example app

There is a sample UWP application to show how ReduxSimple library can be used and the steps required to make a C#/XAML application using the Redux pattern.

You can follow this link: https://www.microsoft.com/store/apps/9PDBXGFZCVMS

Getting started

Like the original Redux library, you will have to initialize a new State when creating a Store + you will create Reducer functions each linked to an Action which will possibly update this State.

In your app, you can:

  • Dispatch new Action to change the State
  • and listen to events/changes using the Subscribe method

You will need to follow the following steps to create your own Redux Store:

  1. Create State definition
public record RootState
{
    public string CurrentPage { get; set; } = string.Empty;
    public ImmutableArray<string> Pages { get; set; } = ImmutableArray<string>.Empty;
}

Each State should be immutable. That's why we prefer to use immutable types for each property of the State.

  1. Create Action definitions
public class NavigateAction
{
    public string PageName { get; set; }
}

public class GoBackAction { }

public class ResetAction { }
  1. Create Reducer functions
public static class Reducers
{
    public static IEnumerable<On<RootState>> CreateReducers()
    {
        return new List<On<RootState>>
        {
            On<NavigateAction, RootState>(
                (state, action) => state with { Pages = state.Pages.Add(action.PageName) }
            ),
            On<GoBackAction, RootState>(
                state =>
                {
                    var newPages = state.Pages.RemoveAt(state.Pages.Length - 1);

                    return state with {
                        CurrentPage = newPages.LastOrDefault(),
                        Pages = newPages
                    };
                }
            ),
            On<ResetAction, RootState>(
                state => state with {
                    CurrentPage = string.Empty,
                    Pages = ImmutableArray<string>.Empty
                }
            )
        };
    }
}
  1. Create a new instance of your Store
sealed partial class App
{
    public static readonly ReduxStore<RootState> Store;

    static App()
    {
        Store = new ReduxStore<RootState>(CreateReducers());
    }
}
  1. And be ready to use your store inside your entire application...

NuGet packages (1)

Showing the top 1 NuGet packages that depend on ReduxSimple.DevTools:

Package Downloads
ReduxSimple.Uwp.DevTools

Simple Stupid Redux Store using Reactive Extensions - DevTools for UWP applications

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.7.0-preview001 31 12/20/2021
3.6.1-preview001 95 4/19/2021
3.6.0-preview001 53 2/15/2021
3.5.2-preview001 78 1/13/2021
3.5.1-preview001 127 10/16/2020
3.5.0-preview001 200 10/10/2020
3.4.0-preview001 170 4/24/2020
3.3.0-preview001 168 4/16/2020
3.2.0-preview001 198 4/16/2020
3.1.0-preview001 180 2/26/2020
3.0.1-preview001 324 1/25/2020
3.0.0-preview001 204 11/11/2019