Added transactions now to UiState to be able to watch them
This commit is contained in:
parent
75f73164aa
commit
3c4a2232e8
|
@ -26,8 +26,6 @@ private val typography = Typography(
|
||||||
body1 = TextStyle(fontSize = 14.sp, color = Colors.Zinc700)
|
body1 = TextStyle(fontSize = 14.sp, color = Colors.Zinc700)
|
||||||
)
|
)
|
||||||
|
|
||||||
private val bankService = DI.bankingService
|
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
@Preview
|
@Preview
|
||||||
fun App() {
|
fun App() {
|
||||||
|
@ -36,10 +34,9 @@ fun App() {
|
||||||
var showAddAccountDialog by remember { mutableStateOf(false) }
|
var showAddAccountDialog by remember { mutableStateOf(false) }
|
||||||
|
|
||||||
val coroutineScope = rememberCoroutineScope()
|
val coroutineScope = rememberCoroutineScope()
|
||||||
val (transactions, setTransaction) = remember { mutableStateOf<List<AccountTransaction>>(emptyList()) }
|
|
||||||
|
|
||||||
coroutineScope.launch {
|
coroutineScope.launch {
|
||||||
setTransaction(bankService.getTransactions())
|
DI.init()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -49,7 +46,7 @@ fun App() {
|
||||||
Modifier.fillMaxWidth().fillMaxHeight().background(color = Colors.Zinc100),
|
Modifier.fillMaxWidth().fillMaxHeight().background(color = Colors.Zinc100),
|
||||||
horizontalAlignment = Alignment.CenterHorizontally
|
horizontalAlignment = Alignment.CenterHorizontally
|
||||||
) {
|
) {
|
||||||
TransactionsList(transactions)
|
TransactionsList(DI.uiState)
|
||||||
}
|
}
|
||||||
|
|
||||||
Row(Modifier.align(Alignment.BottomEnd)) {
|
Row(Modifier.align(Alignment.BottomEnd)) {
|
||||||
|
|
|
@ -7,10 +7,7 @@ import androidx.compose.foundation.lazy.items
|
||||||
import androidx.compose.material.Divider
|
import androidx.compose.material.Divider
|
||||||
import androidx.compose.material.MaterialTheme
|
import androidx.compose.material.MaterialTheme
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.*
|
||||||
import androidx.compose.runtime.derivedStateOf
|
|
||||||
import androidx.compose.runtime.getValue
|
|
||||||
import androidx.compose.runtime.remember
|
|
||||||
import androidx.compose.ui.Alignment
|
import androidx.compose.ui.Alignment
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.graphics.Color
|
import androidx.compose.ui.graphics.Color
|
||||||
|
@ -24,12 +21,15 @@ import net.codinux.banking.ui.extensions.toBigDecimal
|
||||||
import net.codinux.banking.ui.forms.RoundedCornersCard
|
import net.codinux.banking.ui.forms.RoundedCornersCard
|
||||||
import net.codinux.banking.ui.config.Colors
|
import net.codinux.banking.ui.config.Colors
|
||||||
import net.codinux.banking.ui.config.DI
|
import net.codinux.banking.ui.config.DI
|
||||||
|
import net.codinux.banking.ui.state.UiState
|
||||||
import org.jetbrains.compose.ui.tooling.preview.Preview
|
import org.jetbrains.compose.ui.tooling.preview.Preview
|
||||||
|
|
||||||
private val formatUtil = DI.formatUtil
|
private val formatUtil = DI.formatUtil
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun TransactionsList(transactions: List<AccountTransaction>) {
|
fun TransactionsList(uiState: UiState) {
|
||||||
|
val transactions by uiState.transactions.collectAsState()
|
||||||
|
|
||||||
val groupedByMonth by remember(transactions) {
|
val groupedByMonth by remember(transactions) {
|
||||||
derivedStateOf { transactions.groupBy { LocalDate(it.valueDate.year, it.valueDate.monthNumber, 1) } }
|
derivedStateOf { transactions.groupBy { LocalDate(it.valueDate.year, it.valueDate.monthNumber, 1) } }
|
||||||
}
|
}
|
||||||
|
@ -86,6 +86,6 @@ fun TransactionsList(transactions: List<AccountTransaction>) {
|
||||||
@Composable
|
@Composable
|
||||||
fun TransactionsListPreview() {
|
fun TransactionsListPreview() {
|
||||||
MaterialTheme {
|
MaterialTheme {
|
||||||
TransactionsList(emptyList())
|
TransactionsList(UiState())
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -19,4 +19,9 @@ object DI {
|
||||||
|
|
||||||
val formatUtil = FormatUtil()
|
val formatUtil = FormatUtil()
|
||||||
|
|
||||||
|
|
||||||
|
suspend fun init() {
|
||||||
|
bankingService.init()
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -27,25 +27,18 @@ class BankingService(
|
||||||
private val bankFinder: BankFinder
|
private val bankFinder: BankFinder
|
||||||
) {
|
) {
|
||||||
|
|
||||||
private var cachedTransactions: List<AccountTransaction>? = null
|
|
||||||
|
|
||||||
private val log by logger()
|
private val log by logger()
|
||||||
|
|
||||||
|
|
||||||
|
suspend fun init() {
|
||||||
|
val transactions = readTransactionsFromCsv()
|
||||||
|
|
||||||
|
uiState.transactions.value = transactions
|
||||||
|
}
|
||||||
|
|
||||||
suspend fun findBanks(query: String): List<BankInfo> =
|
suspend fun findBanks(query: String): List<BankInfo> =
|
||||||
bankFinder.findBankByNameBankCodeOrCity(query, 25)
|
bankFinder.findBankByNameBankCodeOrCity(query, 25)
|
||||||
|
|
||||||
suspend fun getTransactions(): List<AccountTransaction> {
|
|
||||||
cachedTransactions?.let {
|
|
||||||
return it
|
|
||||||
}
|
|
||||||
|
|
||||||
val transactions = readTransactionsFromCsv()
|
|
||||||
cachedTransactions = transactions
|
|
||||||
|
|
||||||
return transactions
|
|
||||||
}
|
|
||||||
|
|
||||||
suspend fun addAccount(bank: BankInfo, loginName: String, password: String): Boolean {
|
suspend fun addAccount(bank: BankInfo, loginName: String, password: String): Boolean {
|
||||||
try {
|
try {
|
||||||
val config = FinTsClientConfiguration(FinTsClientOptions(true))
|
val config = FinTsClientConfiguration(FinTsClientOptions(true))
|
||||||
|
@ -73,11 +66,11 @@ class BankingService(
|
||||||
|
|
||||||
private fun handleSuccessfulGetAccountDataResponse(response: GetAccountDataResponse) {
|
private fun handleSuccessfulGetAccountDataResponse(response: GetAccountDataResponse) {
|
||||||
// TODO: save customer
|
// TODO: save customer
|
||||||
if (cachedTransactions == null) {
|
|
||||||
cachedTransactions = response.bookedTransactions
|
val transactions = uiState.transactions.value.toMutableList()
|
||||||
} else {
|
transactions.addAll(response.bookedTransactions)
|
||||||
cachedTransactions = (cachedTransactions!! + response.bookedTransactions).sortedByDescending { it.valueDate }
|
|
||||||
}
|
uiState.transactions.value = transactions.sortedByDescending { it.valueDate }
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun handleUnsuccessfulBankingClientResponse(action: BankingClientAction, response: Response<*>) {
|
private fun handleUnsuccessfulBankingClientResponse(action: BankingClientAction, response: Response<*>) {
|
||||||
|
|
Loading…
Reference in New Issue