Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/gbreen12/reactiveforms

This is a set of ReactiveUI and Xamarin Forms extensions for performing common functions such as: Page Navigation & Showing Alerts. Supports Xamarin.iOS, Xamarin.Android, Xamarin.Mac, Xamarin Forms, WPF, Windows Forms, Windows Phone 8.1.
https://github.com/gbreen12/reactiveforms

reactiveui xamarin xamarin-forms

Last synced: 6 days ago
JSON representation

This is a set of ReactiveUI and Xamarin Forms extensions for performing common functions such as: Page Navigation & Showing Alerts. Supports Xamarin.iOS, Xamarin.Android, Xamarin.Mac, Xamarin Forms, WPF, Windows Forms, Windows Phone 8.1.

Awesome Lists containing this project

README

        

# ReactiveForms

Reactive Forms is a set of extensions built on Xamarin Forms and ReactiveUI. There is also a dependency on Splat (1.6.2) for page navigation.

## Setup

1. Make a new Xamarin Forms PCL project
2. Make sure only project types that are supported are targeted (You may need to uninstall the Xamarin Forms nuget package to change the targets and then reinstall it)
3. Add ReactiveForms nuget package to all projects (PCL, Android, iOS, etc.)

## NOTE

Previous version had `BaseNavigationPage`. This has been removed. Instead just use the `BasePage` inside of a normal `NavigationPage` and it will all work the same.

### BasePage

Reactive Forms comes with a `BasePage` that abstracts some common code for setting up a page. The base page takes two arguments: The current page and the page model interface that the page uses. The interface must inherit from `IBasePageModel` and the page model must extend `BasePageModel`.

Example:

FirstPage.xaml
```

```

FirstPageModel.cs
```
public interface IFirstPageModel : IBasePageModel
{
}

public class FirstPageModel : BasePageModel, IFirstPageModel
{
public FirstPageModel()
: base()
{
}
}
```

### Show Alert

Any page that extends the bast page can easily show an alert. A simple alert can be shown by using the following code in the view model:

```
_alerts.OnNext(new AlertMessage("Title", "Message to show"));
```

This will show a default alert with "OK" as the only option. This can be changed by changing the `Cancel` attribute, or by passing in a different string for cancel in the constructor. You can also customize functionality by setting the `AcceptCommand` and/or `CancelCommand`.

The following example shows how to use the `AcceptCommand` and `CancelCommand`:

```
public interface IFirstPageModel : IBasePageModel
{
ReactiveCommand ShowAlertCommand { get; }
}

public class FirstPageModel : BasePageModel, IFirstPageModel
{
public FirstPageModel()
: base()
{
ShowAlertCommand = ReactiveCommand.CreateFromObservable(() => {
var response = new AsyncSubject();

_alerts.OnNext(new AlertMessage("Title", "Message to show", "Cancel", "Accept"){
AcceptCommand = ReactiveCommand.CreateFromObservable(() => {
// Do work
response.OnNext(Unit.Default);
response.OnCompleted();
}),
CancelCommand = ReactiveCommand.CreateFromObservable(() => {
// Do work
response.OnNext(Unit.Default);
response.OnCompleted();
})
});

return response;
});
}

public ReactiveCommand ShowAlertCommand { get; private set; }
}

```

### Page Navigation

Reactive Forms allows for simple page navigation. If a page extends the `BasePage` and the page model and page model interface extend `BasePageModel` and `IBasePageModel` respectively, two observables are exposed: `_navigateToPage` and `_navigateBack`. To use page navigation, do the following:

FirstPage.xaml
```

```

FirstPageModel.cs
```
public interface IFirstPageModel : IBasePageModel
{
ReactiveCommand NavigateToNextPageCommand { get; }
ReactiveCommand NavigateBackCommand { get; }
}

public class FirstPageModel : BasePageModel, IFirstPageModel
{
public FirstPageModel()
: base()
{
NavigateToNextPageCommand = ReactiveCommand.CreateFromObservable(() => {
var response = new AsyncSubject();

var pageModel = new SecondPageModel();
_navigateToPage.OnNext(new NavigationModel(pageModel, response));

return response;
});

NavigateBackCommand = ReactiveCommand.CreateFromObservable(() => {
var response = new AsyncSubject();

_navigateBack.OnNext(new NavigationBackModel(response));

return response;
});
}

public ReactiveCommand NavigateToNextPageCommand { get; private set; }
public ReactiveCommand NavigateBackCommand { get; private set; }
}
```

Three other pieces of setup must happen before you can use the navigation.

1. The page model of the page you are navigating to must inherit from `IPageModelNavigateTo`
2. You must setup the `Splat` connection like: `Locator.CurrentMutable.Register(() => new SecondPage(), typeof(SecondPageModel));`
3. The first page you want to use in the navigation stack must be the base page in a `NavigationPage`: `MainPage = new NavigationPage(new FirstPage());`

### NavigationModel

The navigation model allows the user to setup some fields:

1. `Model`: The page model you want to navigate to. Must inherit from `IPageModelNavigateTo`
2. `ToBoCompleted`: If navigating within a command, this is the subject to be completed from the command
3. `Animated`: Whether the page navigation should be animated
4. `IsModel`: Whether the page should be used as a modal

### NavigationBackModel

The navigation back model also has some optional setup fields

1. `ToBeCompleted`: If navigating within a command, this is the subject to be completed from the command
2. `Animated`: Whether the page navigation should be animated
3. `IsModal`: Whether the page should be used as a modal
4. `CountToGoBack`: If you want to go back multiple pages at the same time, you can use this field