-
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
[data:image/s3,"s3://crabby-images/b4281/b4281492f34fbd5445ccbe211ae3ed6c04a72307" alt="Nuget"](https://www.nuget.org/packages/Xam.Plugin.Once) data:image/s3,"s3://crabby-images/1e603/1e603c27ad908aa1f052917924ee426088f51166" alt="Nuget"
data:image/s3,"s3://crabby-images/dd112/dd11238024a6e01b66517f66e96e595b3fc2a64f" alt="Icon"
# 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!)
[data:image/s3,"s3://crabby-images/db3fd/db3fdb2632effe253b24b7c0da3a220448d0827c" alt="PayPal donate button"](https://www.paypal.me/markheinis)