-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample.ts
115 lines (103 loc) · 2.97 KB
/
example.ts
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/*
Purpose: Demonstrate how to use @mishguru/status-finder with
a somewhat realistic example.
*/
// 1. Import the function and generic type
import { statusFinder, StatusTree } from './'
// 2. Define the possible statuses that our state can represent
enum session {
REQUIRES_CORRECT_PASSWORD,
REQUIRES_CORRECT_USERNAME,
REQUIRES_VERIFICATION,
IS_ACTIVE_SESSION,
AWAITING_VERIFICATION_TOKEN,
ATTEMPTING_VERIFICATION,
ERROR_STATE
}
// 3. Define the shape of the state we will be testing against
interface SessionState {
isInvalid: boolean
hasBadPassword: boolean
hasBadUsername: boolean
verification?: {
isComplete: boolean
attempt?: {
token?: string
}
}
}
/* 4. Use the generic StatusTree to specify what the shape the statusTree will be
`StatusTree<SessionState, session>`
In our example:
- the state being passed each test function will be SessionState
- the possible outcomes will be one of the session enums
*/
type SessionTree = StatusTree<SessionState, session>
/* 5. Define the hierarchy of different statuses
Once we have a succesful match, this will be returned.
*/
const statusTree: SessionTree = [
{
status: session.REQUIRES_CORRECT_PASSWORD,
test: (state) => state.hasBadPassword === true,
subStates: []
},
{
status: session.REQUIRES_CORRECT_USERNAME,
test: (state) => state.hasBadUsername === true,
subStates: []
},
{
status: session.IS_ACTIVE_SESSION,
test: (state) => state.isInvalid === false,
subStates: [
{
status: session.REQUIRES_VERIFICATION,
test: ({ verification }) =>
verification != null && verification.isComplete === false,
subStates: [
{
status: session.AWAITING_VERIFICATION_TOKEN,
test: ({ verification }) =>
verification != null
&& verification.attempt != null
&& verification.attempt.token == null,
subStates: []
},
{
status: session.ATTEMPTING_VERIFICATION,
test: ({ verification }) =>
verification != null
&& verification.attempt != null
&& verification.attempt.token != null,
subStates: []
}
]
}
]
}
]
/*
6. Retrieve the application state.
In this example I have made up a value that's
similar to what you can expect from querying
a database with three SQL joins.
I encourage you to experiment with changing the
value of different properties to see how
statusFinder produces different results.
*/
const state: SessionState = {
isInvalid: false,
hasBadPassword: false,
hasBadUsername: false,
verification: {
isComplete: false,
attempt: {
token: undefined
}
}
}
// Use the statusFinder to determine what status we currently have
const result = statusFinder(state, statusTree, session.ERROR_STATE)
// Print out the result so we can see what the current status is
console.log(session[result])