|
@@ -1,5 +1,6 @@
|
|
package com.fastest.pass.home.presentation.ui.components
|
|
package com.fastest.pass.home.presentation.ui.components
|
|
|
|
|
|
|
|
+import android.util.Log
|
|
import androidx.compose.foundation.background
|
|
import androidx.compose.foundation.background
|
|
import androidx.compose.foundation.border
|
|
import androidx.compose.foundation.border
|
|
import androidx.compose.foundation.clickable
|
|
import androidx.compose.foundation.clickable
|
|
@@ -50,12 +51,26 @@ import androidx.compose.ui.text.style.TextAlign
|
|
import androidx.compose.ui.unit.dp
|
|
import androidx.compose.ui.unit.dp
|
|
import androidx.compose.ui.unit.sp
|
|
import androidx.compose.ui.unit.sp
|
|
import com.fastest.pass.R
|
|
import com.fastest.pass.R
|
|
|
|
+import com.fastest.pass.helpers.BasePreferenceHelper
|
|
|
|
+import com.fastest.pass.home.data.model.NewItemFormField
|
|
|
|
|
|
@Composable
|
|
@Composable
|
|
-fun AddPaymentCardFormScreen() {
|
|
+fun AddPaymentCardFormScreen(
|
|
|
|
+ basePreferenceHelper: BasePreferenceHelper,
|
|
|
|
+ onPaymentCardFormList: (ArrayList<NewItemFormField>, Boolean) -> Unit
|
|
|
|
+) {
|
|
val keyboardController = LocalSoftwareKeyboardController.current
|
|
val keyboardController = LocalSoftwareKeyboardController.current
|
|
val focusManager = LocalFocusManager.current
|
|
val focusManager = LocalFocusManager.current
|
|
|
|
|
|
|
|
+ var payment_cards_title by remember { mutableStateOf("") }
|
|
|
|
+ var payment_cards_name_on_card by remember { mutableStateOf("") }
|
|
|
|
+ var payment_cards_type by remember { mutableStateOf("") }
|
|
|
|
+ var payment_cards_number by remember { mutableStateOf("") }
|
|
|
|
+ var payment_cards_security_code by remember { mutableStateOf("") }
|
|
|
|
+ var payment_cards_start_date by remember { mutableStateOf("") }
|
|
|
|
+ var payment_cards_expiration_date by remember { mutableStateOf("") }
|
|
|
|
+ var payment_cards_notes by remember { mutableStateOf("") }
|
|
|
|
+
|
|
Box(
|
|
Box(
|
|
modifier = Modifier
|
|
modifier = Modifier
|
|
.fillMaxSize()
|
|
.fillMaxSize()
|
|
@@ -64,7 +79,35 @@ fun AddPaymentCardFormScreen() {
|
|
.background(Color.Transparent)
|
|
.background(Color.Transparent)
|
|
.imePadding(),
|
|
.imePadding(),
|
|
) {
|
|
) {
|
|
- SaveButtonAPCFS(buttonText = R.string.save)
|
|
+ SaveButtonAPCFS(
|
|
|
|
+ buttonText = R.string.save,
|
|
|
|
+ onSaveButtonClick = {
|
|
|
|
+ val paymentCardFormList = ArrayList<NewItemFormField>()
|
|
|
|
+ val saltKey = basePreferenceHelper.getCustomSaltKey()
|
|
|
|
+ val secretKey = basePreferenceHelper.getCustomSecretKey()
|
|
|
|
+ val isTitleEmpty = payment_cards_title.isEmpty()
|
|
|
|
+
|
|
|
|
+ payment_cards_title = encryptIfNotEmpty(payment_cards_title, secretKey, saltKey)
|
|
|
|
+ payment_cards_name_on_card = encryptIfNotEmpty(payment_cards_name_on_card, secretKey, saltKey)
|
|
|
|
+ payment_cards_type = encryptIfNotEmpty(payment_cards_type, secretKey, saltKey)
|
|
|
|
+ payment_cards_number = encryptIfNotEmpty(payment_cards_number, secretKey, saltKey)
|
|
|
|
+ payment_cards_security_code = encryptIfNotEmpty(payment_cards_security_code, secretKey, saltKey)
|
|
|
|
+ payment_cards_start_date = encryptIfNotEmpty(payment_cards_start_date, secretKey, saltKey)
|
|
|
|
+ payment_cards_expiration_date = encryptIfNotEmpty(payment_cards_expiration_date, secretKey, saltKey)
|
|
|
|
+ payment_cards_notes = encryptIfNotEmpty(payment_cards_notes, secretKey, saltKey)
|
|
|
|
+
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_title", payment_cards_title))
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_name_on_card", payment_cards_name_on_card))
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_type", payment_cards_type))
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_number", payment_cards_number))
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_security_code", payment_cards_security_code))
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_start_date", payment_cards_start_date))
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_expiration_date", payment_cards_expiration_date))
|
|
|
|
+ paymentCardFormList.add(NewItemFormField("payment-cards_notes", payment_cards_notes))
|
|
|
|
+
|
|
|
|
+ onPaymentCardFormList.invoke(paymentCardFormList, isTitleEmpty)
|
|
|
|
+ }
|
|
|
|
+ )
|
|
|
|
|
|
Column(
|
|
Column(
|
|
modifier = Modifier
|
|
modifier = Modifier
|
|
@@ -78,52 +121,61 @@ fun AddPaymentCardFormScreen() {
|
|
NameTextFieldAPCFS(
|
|
NameTextFieldAPCFS(
|
|
keyboardController = keyboardController,
|
|
keyboardController = keyboardController,
|
|
focusManager = focusManager,
|
|
focusManager = focusManager,
|
|
- labelText = R.string.title
|
|
+ labelText = R.string.title,
|
|
|
|
+ onText = { payment_cards_title = it }
|
|
)
|
|
)
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
NameTextFieldAPCFS(
|
|
NameTextFieldAPCFS(
|
|
keyboardController = keyboardController,
|
|
keyboardController = keyboardController,
|
|
focusManager = focusManager,
|
|
focusManager = focusManager,
|
|
- labelText = R.string.name_on_card
|
|
+ labelText = R.string.name_on_card,
|
|
|
|
+ onText = { payment_cards_name_on_card = it }
|
|
)
|
|
)
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
NameTextFieldAPCFS(
|
|
NameTextFieldAPCFS(
|
|
keyboardController = keyboardController,
|
|
keyboardController = keyboardController,
|
|
focusManager = focusManager,
|
|
focusManager = focusManager,
|
|
- labelText = R.string.type
|
|
+ labelText = R.string.type,
|
|
|
|
+ onText = { payment_cards_type = it }
|
|
)
|
|
)
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
NumberTextFieldAPCFS(
|
|
NumberTextFieldAPCFS(
|
|
keyboardController = keyboardController,
|
|
keyboardController = keyboardController,
|
|
focusManager = focusManager,
|
|
focusManager = focusManager,
|
|
labelText = R.string.number,
|
|
labelText = R.string.number,
|
|
- placeholder = "1234 1234 1234 1234"
|
|
+ placeholder = "1234 1234 1234 1234",
|
|
|
|
+ onText = { payment_cards_number = it }
|
|
)
|
|
)
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
NumberTextFieldAPCFS(
|
|
NumberTextFieldAPCFS(
|
|
keyboardController = keyboardController,
|
|
keyboardController = keyboardController,
|
|
focusManager = focusManager,
|
|
focusManager = focusManager,
|
|
labelText = R.string.security_code,
|
|
labelText = R.string.security_code,
|
|
- placeholder = "CVV"
|
|
+ placeholder = "CVV",
|
|
|
|
+ onText = { payment_cards_security_code = it }
|
|
)
|
|
)
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
NumberDateFieldAPCFS(
|
|
NumberDateFieldAPCFS(
|
|
keyboardController = keyboardController,
|
|
keyboardController = keyboardController,
|
|
focusManager = focusManager,
|
|
focusManager = focusManager,
|
|
labelText = R.string.start_date,
|
|
labelText = R.string.start_date,
|
|
- placeholder = "MM/YY"
|
|
+ placeholder = "MM/YY",
|
|
|
|
+ onText = { payment_cards_start_date = it }
|
|
)
|
|
)
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
NumberDateFieldAPCFS(
|
|
NumberDateFieldAPCFS(
|
|
keyboardController = keyboardController,
|
|
keyboardController = keyboardController,
|
|
focusManager = focusManager,
|
|
focusManager = focusManager,
|
|
labelText = R.string.expiration_date,
|
|
labelText = R.string.expiration_date,
|
|
- placeholder = "MM/YY"
|
|
+ placeholder = "MM/YY",
|
|
|
|
+ onText = { payment_cards_expiration_date = it }
|
|
)
|
|
)
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
Spacer(modifier = Modifier.height(20.dp))
|
|
- NotesTextFieldAPCFS(keyboardController, focusManager)
|
|
+ NotesTextFieldAPCFS(
|
|
-// Spacer(modifier = Modifier.height(25.dp))
|
|
+ keyboardController,
|
|
-// SaveButtonAPCFS(buttonText = R.string.save)
|
|
+ focusManager,
|
|
|
|
+ onText = { payment_cards_notes = it }
|
|
|
|
+ )
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -133,7 +185,8 @@ fun AddPaymentCardFormScreen() {
|
|
fun ColumnScope.NameTextFieldAPCFS(
|
|
fun ColumnScope.NameTextFieldAPCFS(
|
|
keyboardController: SoftwareKeyboardController?,
|
|
keyboardController: SoftwareKeyboardController?,
|
|
focusManager: FocusManager,
|
|
focusManager: FocusManager,
|
|
- labelText: Int
|
|
+ labelText: Int,
|
|
|
|
+ onText: (String) -> Unit
|
|
) {
|
|
) {
|
|
var text by remember { mutableStateOf("") }
|
|
var text by remember { mutableStateOf("") }
|
|
|
|
|
|
@@ -141,6 +194,7 @@ fun ColumnScope.NameTextFieldAPCFS(
|
|
value = text,
|
|
value = text,
|
|
onValueChange = {
|
|
onValueChange = {
|
|
text = it
|
|
text = it
|
|
|
|
+ onText.invoke(text)
|
|
},
|
|
},
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
modifier = Modifier
|
|
modifier = Modifier
|
|
@@ -204,7 +258,8 @@ fun ColumnScope.NumberTextFieldAPCFS(
|
|
keyboardController: SoftwareKeyboardController?,
|
|
keyboardController: SoftwareKeyboardController?,
|
|
focusManager: FocusManager,
|
|
focusManager: FocusManager,
|
|
labelText: Int,
|
|
labelText: Int,
|
|
- placeholder: String
|
|
+ placeholder: String,
|
|
|
|
+ onText: (String) -> Unit
|
|
) {
|
|
) {
|
|
var text by remember { mutableStateOf("") }
|
|
var text by remember { mutableStateOf("") }
|
|
|
|
|
|
@@ -212,6 +267,7 @@ fun ColumnScope.NumberTextFieldAPCFS(
|
|
value = text,
|
|
value = text,
|
|
onValueChange = {
|
|
onValueChange = {
|
|
text = it
|
|
text = it
|
|
|
|
+ onText.invoke(text)
|
|
},
|
|
},
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
modifier = Modifier
|
|
modifier = Modifier
|
|
@@ -276,7 +332,8 @@ fun ColumnScope.NumberDateFieldAPCFS(
|
|
keyboardController: SoftwareKeyboardController?,
|
|
keyboardController: SoftwareKeyboardController?,
|
|
focusManager: FocusManager,
|
|
focusManager: FocusManager,
|
|
labelText: Int,
|
|
labelText: Int,
|
|
- placeholder: String
|
|
+ placeholder: String,
|
|
|
|
+ onText: (String) -> Unit
|
|
) {
|
|
) {
|
|
var text by remember { mutableStateOf("") }
|
|
var text by remember { mutableStateOf("") }
|
|
val maxLength = 4
|
|
val maxLength = 4
|
|
@@ -286,6 +343,7 @@ fun ColumnScope.NumberDateFieldAPCFS(
|
|
onValueChange = { input ->
|
|
onValueChange = { input ->
|
|
if (input.length <= maxLength) {
|
|
if (input.length <= maxLength) {
|
|
text = input.filter { it.isDigit() }
|
|
text = input.filter { it.isDigit() }
|
|
|
|
+ onText.invoke(text)
|
|
}
|
|
}
|
|
},
|
|
},
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
@@ -382,7 +440,8 @@ fun dateFilter(text: AnnotatedString): TransformedText {
|
|
@Composable
|
|
@Composable
|
|
fun ColumnScope.NotesTextFieldAPCFS(
|
|
fun ColumnScope.NotesTextFieldAPCFS(
|
|
keyboardController: SoftwareKeyboardController?,
|
|
keyboardController: SoftwareKeyboardController?,
|
|
- focusManager: FocusManager
|
|
+ focusManager: FocusManager,
|
|
|
|
+ onText: (String) -> Unit
|
|
) {
|
|
) {
|
|
var notesText by remember { mutableStateOf("") }
|
|
var notesText by remember { mutableStateOf("") }
|
|
|
|
|
|
@@ -390,6 +449,7 @@ fun ColumnScope.NotesTextFieldAPCFS(
|
|
value = notesText,
|
|
value = notesText,
|
|
onValueChange = {
|
|
onValueChange = {
|
|
notesText = it
|
|
notesText = it
|
|
|
|
+ onText.invoke(notesText)
|
|
},
|
|
},
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
textStyle = MaterialTheme.typography.displayMedium,
|
|
modifier = Modifier
|
|
modifier = Modifier
|
|
@@ -450,7 +510,10 @@ fun ColumnScope.NotesTextFieldAPCFS(
|
|
}
|
|
}
|
|
|
|
|
|
@Composable
|
|
@Composable
|
|
-fun BoxScope.SaveButtonAPCFS(buttonText: Int) {
|
|
+fun BoxScope.SaveButtonAPCFS(
|
|
|
|
+ buttonText: Int,
|
|
|
|
+ onSaveButtonClick: () -> Unit
|
|
|
|
+ ) {
|
|
Button(
|
|
Button(
|
|
modifier = Modifier
|
|
modifier = Modifier
|
|
.background(colorResource(id = R.color.transparent))
|
|
.background(colorResource(id = R.color.transparent))
|
|
@@ -458,7 +521,9 @@ fun BoxScope.SaveButtonAPCFS(buttonText: Int) {
|
|
.height(60.dp)
|
|
.height(60.dp)
|
|
.align(Alignment.BottomCenter)
|
|
.align(Alignment.BottomCenter)
|
|
.clickable() { },
|
|
.clickable() { },
|
|
- onClick = {},
|
|
+ onClick = {
|
|
|
|
+ onSaveButtonClick.invoke()
|
|
|
|
+ },
|
|
shape = RoundedCornerShape(15.dp),
|
|
shape = RoundedCornerShape(15.dp),
|
|
// border = BorderStroke(25.dp, colorResource(id = R.color.black)),
|
|
// border = BorderStroke(25.dp, colorResource(id = R.color.black)),
|
|
colors = ButtonDefaults.buttonColors(
|
|
colors = ButtonDefaults.buttonColors(
|