-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.mdtest
74 lines (42 loc) · 2.23 KB
/
README.mdtest
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
[![Nuget](https://img.shields.io/nuget/v/Xam.Plugin.Once)](https://www.nuget.org/packages/Xam.Plugin.Once) ![Nuget](https://img.shields.io/nuget/dt/Xam.Plugin.Once)
![Icon](https://raw.githubusercontent.com/galadril/Xam.Plugin.Once/master/Samples/Xam.Plugin.Once.Samples/Xam.Plugin.Once.Samples.Android/Resources/mipmap-xxhdpi/ic_launcher.png)
# Xam.Plugin.Once
Just a nice and library that allows you to do something once for your Xamarin Forms project.
!!This was inspired by the Once library for Android made by jonfinerty!!
https://github.com/jonfinerty/Once
----
Some things should happen **once**.
* Users should only get the guided tour _once_.
* Release notes should only pop up _once every app upgrade_.
* Your app should only phone home to update content _once every hour_.
`Once` provides a simple API to track whether or not your app has already performed an action within a given scope.
# Setup
* Available on Nuget:
https://www.nuget.org/packages/Xam.Plugin.Once
!!Install into your .net standard Forms project. !!
# Usage
Here are some examples on how to use Once for Xamarin Forms:
- Only run the app intro once
```
Once.Instance.RunWhen(SHOW_APP_INTRO, new Command(() => UserDialogs.Instance.Toast("Show app intro")));
```
- Only show a survey every 30 days for the first time, then after 90 days
```
if(Once.Instance.LastRunAt(SHOW_SURVEY) == null)
Once.Instance.RunWhen(SHOW_SURVEY, new Command(() => UserDialogs.Instance.Toast("Show app survey")), false, new After() {RunAfter = 30, Type = After.AfterType.Days });
else
Once.Instance.RunWhen(SHOW_SURVEY, new Command(() => UserDialogs.Instance.Toast("Show app survey")), false, new After() {RunAfter = 90, Type = After.AfterType.Days });
```
- Just to check if we need to show the app intro
```
_ = Once.Instance.NeedsToRun(SHOW_APP_INTRO);
```
- Mark a task to done
```
Once.Instance.MarkRunAsDone(SHOW_APP_CHANGELOG);
```
(see sample project for more info)
# Donation
If you like to say thanks, you could always buy me a cup of coffee (/beer)!
(Thanks!)
[![PayPal donate button](https://img.shields.io/badge/paypal-donate-yellow.svg)](https://www.paypal.me/markheinis)