-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMainActivity.kt
170 lines (152 loc) · 5.98 KB
/
MainActivity.kt
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
package dev.fredag.cheerwithme
import android.content.Context
import android.os.Bundle
import android.util.Log
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.foundation.layout.*
import androidx.compose.material.*
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.livedata.observeAsState
import androidx.compose.ui.Modifier
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.unit.dp
import androidx.hilt.navigation.compose.hiltViewModel
import androidx.navigation.NavHostController
import androidx.navigation.compose.NavHost
import androidx.navigation.compose.composable
import androidx.navigation.compose.currentBackStackEntryAsState
import androidx.navigation.compose.rememberNavController
import dagger.hilt.android.AndroidEntryPoint
import dev.fredag.cheerwithme.data.UserState
import dev.fredag.cheerwithme.data.backend.BackendModule
import dev.fredag.cheerwithme.data.backend.HappeningId
import dev.fredag.cheerwithme.friends.FindFriendView
import dev.fredag.cheerwithme.friends.FriendsScreen
import dev.fredag.cheerwithme.happening.Happenings
import dev.fredag.cheerwithme.ui.CheerWithMeTheme
import kotlinx.coroutines.FlowPreview
@AndroidEntryPoint
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
val navController = rememberNavController()
CheerWithMeTheme {
// A surface container using the 'background' color from the theme
Surface(color = MaterialTheme.colors.background) {
Router(navController)
}
}
}
// Comment this out if you don't want to auto-login with stored access key. To test login
UserState.loggedIn.postValue(BackendModule.hasAccessKey(applicationContext))
}
}
sealed class AuthenticatedScreen(val route: String, val path: String = route) {
object Friends : AuthenticatedScreen("authenticated/friends")
object Happenings : AuthenticatedScreen("authenticated/happenings")
object NewHappening : AuthenticatedScreen("authenticated/happenings/new")
class Happening(happeningsId: HappeningId) : AuthenticatedScreen(
route,
"authenticated/happenings/$happeningsId"
) {
companion object {
const val route = "authenticated/happenings/{happeningsId}"
}
}
object Profile : AuthenticatedScreen("authenticated/profile")
object Checkin : AuthenticatedScreen("authenticated/checkin")
object Map : AuthenticatedScreen("authenticated/map")
object Login : AuthenticatedScreen("authenticated/login")
object FindFriend : AuthenticatedScreen("authenticated/findfriend")
}
@Composable
public fun currentRoute(navController: NavHostController): String? {
val navBackStackEntry by navController.currentBackStackEntryAsState()
return navBackStackEntry?.destination?.route
}
@OptIn(FlowPreview::class)
@Composable
fun Router(navController: NavHostController) {
val loggedIn = UserState.loggedIn.observeAsState()
Scaffold(
topBar = {
if (currentRoute(navController) != AuthenticatedScreen.Login.route) {
NavBar(navController)
}
}) {
Box(modifier = Modifier.padding(0.dp, 0.dp, 0.dp, 58.dp)) {
NavHost(
navController = navController,
startDestination = if (loggedIn.value == true) AuthenticatedScreen.Happenings.route else AuthenticatedScreen.Login.route
) {
composable(AuthenticatedScreen.Friends.route) {
FriendsScreen(hiltViewModel()) {
navController.navigate(
AuthenticatedScreen.FindFriend.route
) {
launchSingleTop = true
}
}
}
composable(AuthenticatedScreen.Map.route) { Map() }
composable(AuthenticatedScreen.FindFriend.route) {
FindFriendView(
navController,
hiltViewModel()
)
}
composable(AuthenticatedScreen.Checkin.route) { Happening() }
composable(AuthenticatedScreen.Happening.route) {
}
composable(AuthenticatedScreen.NewHappening.route) {
NewHappeningScreen(hiltViewModel())
}
composable(AuthenticatedScreen.Happenings.route) {
Happenings(
hiltViewModel(),
openAddHappeningScreen = {
navController.navigate(AuthenticatedScreen.NewHappening.path)
},
openHappningScreen = {
navController.navigate(AuthenticatedScreen.Happening(it.happeningId).path)
})
}
composable(AuthenticatedScreen.Profile.route) { Profile(navController) }
composable(AuthenticatedScreen.Login.route) {
Login(hiltViewModel(), {
navController.navigate(AuthenticatedScreen.Checkin.route)
}, {
Log.d("Login", "login failed")
})
}
}
}
}
}
@Composable
fun Happening() {
Text("Checkin")
}
@Composable
fun Map() {
Text("map")
}
@Composable
fun Profile(navController: NavHostController) {
val context = LocalContext.current
Column() {
Text("profile")
Button(onClick = {
clearAccessToken(context)
navController.navigate(AuthenticatedScreen.Login.route)
}) {
Text(text = "Logout")
}
}
}
fun clearAccessToken(context: Context) {
BackendModule.clearAccessKey(context)
}