|
|
|
@ -2,18 +2,15 @@ package com.example.mathseduc.ui
|
|
|
|
|
|
|
|
|
|
import android.app.Activity
|
|
|
|
|
import android.content.res.Configuration
|
|
|
|
|
import android.widget.Toast
|
|
|
|
|
import androidx.compose.foundation.background
|
|
|
|
|
import androidx.compose.foundation.layout.Arrangement
|
|
|
|
|
import androidx.compose.foundation.layout.Column
|
|
|
|
|
import androidx.compose.foundation.layout.Row
|
|
|
|
|
import androidx.compose.foundation.layout.Spacer
|
|
|
|
|
import androidx.compose.foundation.layout.fillMaxSize
|
|
|
|
|
import androidx.compose.foundation.layout.fillMaxWidth
|
|
|
|
|
import androidx.compose.foundation.layout.height
|
|
|
|
|
import androidx.compose.foundation.layout.padding
|
|
|
|
|
import androidx.compose.foundation.layout.size
|
|
|
|
|
import androidx.compose.foundation.layout.width
|
|
|
|
|
import androidx.compose.foundation.shape.RoundedCornerShape
|
|
|
|
|
import androidx.compose.foundation.text.KeyboardOptions
|
|
|
|
|
import androidx.compose.material.icons.Icons
|
|
|
|
@ -39,7 +36,6 @@ import androidx.compose.ui.Alignment
|
|
|
|
|
import androidx.compose.ui.Modifier
|
|
|
|
|
import androidx.compose.ui.graphics.Color
|
|
|
|
|
import androidx.compose.ui.platform.LocalConfiguration
|
|
|
|
|
import androidx.compose.ui.platform.LocalContext
|
|
|
|
|
import androidx.compose.ui.platform.LocalView
|
|
|
|
|
import androidx.compose.ui.text.font.FontWeight
|
|
|
|
|
import androidx.compose.ui.text.input.KeyboardType
|
|
|
|
@ -51,9 +47,10 @@ import androidx.core.view.WindowInsetsCompat
|
|
|
|
|
import androidx.core.view.WindowInsetsControllerCompat
|
|
|
|
|
import androidx.navigation.NavController
|
|
|
|
|
import com.example.mathseduc.MainActivity
|
|
|
|
|
import com.example.mathseduc.RegisterDialog
|
|
|
|
|
import com.example.mathseduc.controllers.ControllerPlayer
|
|
|
|
|
import com.example.mathseduc.ui.theme.Colors
|
|
|
|
|
import okhttp3.MultipartBody
|
|
|
|
|
import org.mindrot.jbcrypt.BCrypt
|
|
|
|
|
|
|
|
|
|
@OptIn(ExperimentalMaterial3Api::class)
|
|
|
|
|
@Composable
|
|
|
|
@ -62,6 +59,7 @@ fun ProfilePlayerPage(navController: NavController) {
|
|
|
|
|
val player = ControllerPlayer.getPlayerInfoById(MainActivity.idPlayerConnected.toString())
|
|
|
|
|
|
|
|
|
|
var showDialog by rememberSaveable { mutableStateOf(false) }
|
|
|
|
|
var confirmDialog by rememberSaveable { mutableStateOf(false) }
|
|
|
|
|
|
|
|
|
|
val isPortrait = LocalConfiguration.current.orientation == Configuration.ORIENTATION_PORTRAIT
|
|
|
|
|
|
|
|
|
@ -153,7 +151,23 @@ fun ProfilePlayerPage(navController: NavController) {
|
|
|
|
|
|
|
|
|
|
Spacer(modifier = Modifier.height(10.dp))
|
|
|
|
|
Button(
|
|
|
|
|
onClick = { },
|
|
|
|
|
onClick = { MainActivity.idPlayerConnected = -1
|
|
|
|
|
navController.navigate("home") },
|
|
|
|
|
shape = RoundedCornerShape(15),
|
|
|
|
|
colors = ButtonDefaults.buttonColors(Colors.Blue),
|
|
|
|
|
modifier = Modifier
|
|
|
|
|
.height(48.dp)
|
|
|
|
|
.padding(horizontal = 6.dp)
|
|
|
|
|
) {
|
|
|
|
|
Text(
|
|
|
|
|
text = "disconnection",
|
|
|
|
|
color = Color.White
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Spacer(modifier = Modifier.height(10.dp))
|
|
|
|
|
Button(
|
|
|
|
|
onClick = { confirmDialog = true },
|
|
|
|
|
shape = RoundedCornerShape(15),
|
|
|
|
|
colors = ButtonDefaults.buttonColors(Colors.Red),
|
|
|
|
|
modifier = Modifier
|
|
|
|
@ -167,7 +181,15 @@ fun ProfilePlayerPage(navController: NavController) {
|
|
|
|
|
}
|
|
|
|
|
if (showDialog) {
|
|
|
|
|
if (player != null) {
|
|
|
|
|
ChangeDialog(player.id.toString(),onDismiss = { showDialog = false })
|
|
|
|
|
ChangeDialog(player.id.toString(),player.nickname,onDismiss = { showDialog = false })
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (confirmDialog) {
|
|
|
|
|
if (player != null) {
|
|
|
|
|
DeleteConfirmDialog(onConfirmDelete = { ControllerPlayer.deletePlayer(player.id.toString())
|
|
|
|
|
MainActivity.idPlayerConnected = -1
|
|
|
|
|
navController.navigate("home")
|
|
|
|
|
confirmDialog = false},onDismiss = { confirmDialog = false })
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
@ -175,12 +197,14 @@ fun ProfilePlayerPage(navController: NavController) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Composable
|
|
|
|
|
fun ChangeDialog(playerId: String,onDismiss: () -> Unit) {
|
|
|
|
|
val context = LocalContext.current
|
|
|
|
|
fun ChangeDialog(playerId: String, currentNickname: String, onDismiss: () -> Unit) {
|
|
|
|
|
|
|
|
|
|
var nickname by rememberSaveable { mutableStateOf("") }
|
|
|
|
|
var nickname by rememberSaveable { mutableStateOf(currentNickname) }
|
|
|
|
|
var password by rememberSaveable { mutableStateOf("") }
|
|
|
|
|
|
|
|
|
|
var nicknameError by remember { mutableStateOf(false) }
|
|
|
|
|
var passwordError by remember { mutableStateOf(false) }
|
|
|
|
|
|
|
|
|
|
AlertDialog(
|
|
|
|
|
onDismissRequest = {
|
|
|
|
|
onDismiss()
|
|
|
|
@ -191,10 +215,15 @@ fun ChangeDialog(playerId: String,onDismiss: () -> Unit) {
|
|
|
|
|
colors = ButtonDefaults.buttonColors(Colors.Cyan),
|
|
|
|
|
onClick = {
|
|
|
|
|
if (nickname.isNotBlank() && password.isNotBlank()) {
|
|
|
|
|
/*ControllerPlayer.updatePlayer(playerId,nickname,password)*/
|
|
|
|
|
val hashedPassword = BCrypt.hashpw(password, BCrypt.gensalt())
|
|
|
|
|
val formDataBuilder = MultipartBody.Builder().setType(MultipartBody.FORM)
|
|
|
|
|
formDataBuilder.addFormDataPart("nickname", nickname)
|
|
|
|
|
formDataBuilder.addFormDataPart("password", hashedPassword)
|
|
|
|
|
ControllerPlayer.updatePlayer(playerId, formDataBuilder)
|
|
|
|
|
onDismiss()
|
|
|
|
|
} else {
|
|
|
|
|
Toast.makeText(context, "Please fill in all fields", Toast.LENGTH_SHORT).show()
|
|
|
|
|
if (nickname.isBlank()) nicknameError = true
|
|
|
|
|
if (password.isBlank()) passwordError = true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
) {
|
|
|
|
@ -219,15 +248,22 @@ fun ChangeDialog(playerId: String,onDismiss: () -> Unit) {
|
|
|
|
|
) {
|
|
|
|
|
OutlinedTextField(
|
|
|
|
|
value = nickname,
|
|
|
|
|
onValueChange = { nickname = it },
|
|
|
|
|
onValueChange = {
|
|
|
|
|
nickname = it
|
|
|
|
|
nicknameError = false
|
|
|
|
|
},
|
|
|
|
|
label = { Text("Nickname") },
|
|
|
|
|
modifier = Modifier
|
|
|
|
|
.fillMaxWidth()
|
|
|
|
|
.padding(8.dp)
|
|
|
|
|
.padding(8.dp),
|
|
|
|
|
isError = nicknameError
|
|
|
|
|
)
|
|
|
|
|
OutlinedTextField(
|
|
|
|
|
value = password,
|
|
|
|
|
onValueChange = { password = it },
|
|
|
|
|
onValueChange = {
|
|
|
|
|
password = it
|
|
|
|
|
passwordError = false
|
|
|
|
|
},
|
|
|
|
|
label = { Text("Password") },
|
|
|
|
|
visualTransformation = PasswordVisualTransformation(),
|
|
|
|
|
keyboardOptions = KeyboardOptions.Default.copy(
|
|
|
|
@ -235,9 +271,50 @@ fun ChangeDialog(playerId: String,onDismiss: () -> Unit) {
|
|
|
|
|
),
|
|
|
|
|
modifier = Modifier
|
|
|
|
|
.fillMaxWidth()
|
|
|
|
|
.padding(8.dp)
|
|
|
|
|
.padding(8.dp),
|
|
|
|
|
isError = passwordError
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
if (nicknameError || passwordError) {
|
|
|
|
|
Text(
|
|
|
|
|
text = "Please fill in all fields",
|
|
|
|
|
color = Color.Red,
|
|
|
|
|
modifier = Modifier.padding(start = 8.dp)
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Composable
|
|
|
|
|
fun DeleteConfirmDialog(onConfirmDelete: () -> Unit, onDismiss: () -> Unit) {
|
|
|
|
|
AlertDialog(
|
|
|
|
|
onDismissRequest = onDismiss,
|
|
|
|
|
title = { Text("Confirm deleting account") },
|
|
|
|
|
confirmButton = {
|
|
|
|
|
Button(
|
|
|
|
|
onClick = {
|
|
|
|
|
onConfirmDelete()
|
|
|
|
|
},
|
|
|
|
|
colors = ButtonDefaults.buttonColors(Colors.Red)
|
|
|
|
|
) {
|
|
|
|
|
Text("Delete",color = Color.White)
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
dismissButton = {
|
|
|
|
|
Button(
|
|
|
|
|
onClick = {
|
|
|
|
|
onDismiss()
|
|
|
|
|
},
|
|
|
|
|
colors = ButtonDefaults.buttonColors(Color.LightGray)
|
|
|
|
|
) {
|
|
|
|
|
Text("Cancel",color = Color.White)
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
text = {
|
|
|
|
|
Text("Are you sure you want to delete your account?")
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
}
|