Skip to content

Commit

Permalink
Revert "Use Android desugaring to use more modern Java constructs (#97)"
Browse files Browse the repository at this point in the history
This reverts commit c79f063.
  • Loading branch information
chvp committed Jun 28, 2024
1 parent cececb4 commit 4fa98cb
Show file tree
Hide file tree
Showing 5 changed files with 37 additions and 30 deletions.
2 changes: 0 additions & 2 deletions app/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@ android {
}
}
compileOptions {
isCoreLibraryDesugaringEnabled = true
sourceCompatibility = JavaVersion.VERSION_17
targetCompatibility = JavaVersion.VERSION_17
}
Expand Down Expand Up @@ -84,7 +83,6 @@ configure<org.jlleitschuh.gradle.ktlint.KtlintExtension> {
}

dependencies {
coreLibraryDesugaring(libs.android.desugar)
implementation(libs.activity.compose)
implementation(libs.activity.ktx)
implementation(platform(libs.compose.bom))
Expand Down
16 changes: 14 additions & 2 deletions app/src/main/java/be/chvp/nanoledger/data/LedgerRepository.kt
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,13 @@ class LedgerRepository
fileUri
.let { context.contentResolver.openInputStream(it) }
?.let { BufferedReader(InputStreamReader(it)) }
?.use { it.lines().forEach { result.add(it) } }
?.use { reader ->
var line = reader.readLine()
while (line != null) {
result.add(line)
line = reader.readLine()
}
}

if (!result.equals(fileContents.value)) {
onMismatch()
Expand Down Expand Up @@ -110,7 +116,13 @@ class LedgerRepository
fileUri
.let { context.contentResolver.openInputStream(it) }
?.let { BufferedReader(InputStreamReader(it)) }
?.use { it.lines().forEach { result.add(it) } }
?.use { reader ->
var line = reader.readLine()
while (line != null) {
result.add(line)
line = reader.readLine()
}
}
val extracted = extractTransactions(result)
_fileContents.postValue(result)
_transactions.postValue(extracted)
Expand Down
4 changes: 2 additions & 2 deletions app/src/main/java/be/chvp/nanoledger/ui/add/AddActivity.kt
Original file line number Diff line number Diff line change
Expand Up @@ -280,8 +280,8 @@ fun DateSelector(
addViewModel: AddViewModel = viewModel(),
) {
val focusManager = LocalFocusManager.current
val date by addViewModel.date.observeAsState()
val formattedDate by addViewModel.formattedDate.observeAsState()
val dateMillis by addViewModel.dateMillis.observeAsState()
var dateDialogOpen by rememberSaveable { mutableStateOf(false) }
OutlinedTextField(
value = formattedDate ?: "",
Expand All @@ -302,7 +302,7 @@ fun DateSelector(
},
)
if (dateDialogOpen) {
val datePickerState = rememberDatePickerState(initialSelectedDateMillis = dateMillis)
val datePickerState = rememberDatePickerState(initialSelectedDateMillis = date?.getTime())
DatePickerDialog(
onDismissRequest = { dateDialogOpen = false },
confirmButton = {
Expand Down
43 changes: 21 additions & 22 deletions app/src/main/java/be/chvp/nanoledger/ui/add/AddViewModel.kt
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,8 @@ import kotlinx.coroutines.Dispatchers.IO
import kotlinx.coroutines.launch
import java.io.IOException
import java.math.BigDecimal
import java.time.Instant
import java.time.LocalDate
import java.time.ZoneId
import java.time.ZoneOffset
import java.time.format.DateTimeFormatter
import java.text.SimpleDateFormat
import java.util.Date
import javax.inject.Inject

@HiltViewModel
Expand All @@ -33,10 +30,9 @@ class AddViewModel
private val _saving = MutableLiveData<Boolean>(false)
val saving: LiveData<Boolean> = _saving

private val _date = MutableLiveData<LocalDate>(LocalDate.now())
val date: LiveData<LocalDate> = _date
val formattedDate: LiveData<String> = _date.map { it.format(DateTimeFormatter.ISO_DATE) }
val dateMillis: LiveData<Long> = _date.map { it.atStartOfDay().toInstant(ZoneOffset.UTC).toEpochMilli() }
private val _date = MutableLiveData<Date>(Date())
val date: LiveData<Date> = _date
val formattedDate: LiveData<String> = _date.map { SimpleDateFormat("yyyy-MM-dd").format(it) }

private val _status = MutableLiveData<String>(preferencesDataSource.getDefaultStatus())
val status: LiveData<String> = _status
Expand Down Expand Up @@ -117,7 +113,7 @@ class AddViewModel
_saving.value = true
viewModelScope.launch(IO) {
val transaction = StringBuilder()
transaction.append(_date.value!!.format(DateTimeFormatter.ISO_DATE))
transaction.append(SimpleDateFormat("yyyy-MM-dd").format(date.value!!))
if (status.value!! != " ") {
transaction.append(" ${status.value}")
}
Expand Down Expand Up @@ -169,7 +165,7 @@ class AddViewModel
}

fun setDate(dateMillis: Long) {
_date.value = Instant.ofEpochMilli(dateMillis).atZone(ZoneId.of("UTC")).toLocalDate()
_date.value = Date(dateMillis)
}

fun setStatus(newStatus: String) {
Expand All @@ -190,7 +186,14 @@ class AddViewModel
) {
val result = ArrayList(postings.value!!)
result[index] = Triple(newAccount, result[index].second, result[index].third)
_postings.value = removeEmpty(result)
val filteredResult = ArrayList<Triple<String, String, String>>()
for (triple in result) {
if (triple.first != "" || triple.third != "") {
filteredResult.add(triple)
}
}
filteredResult.add(emptyPosting())
_postings.value = filteredResult
}

fun setCurrency(
Expand All @@ -208,18 +211,14 @@ class AddViewModel
) {
val result = ArrayList(postings.value!!)
result[index] = Triple(result[index].first, result[index].second, newAmount)
_postings.value = removeEmpty(result)
}

fun removeEmpty(postings: List<Triple<String, String, String>>): List<Triple<String, String, String>> {
val result = ArrayList<Triple<String, String, String>>()
for (p in postings) {
if (p.first != "" || p.third != "") {
result.add(p)
val filteredResult = ArrayList<Triple<String, String, String>>()
for (triple in result) {
if (triple.first != "" || triple.third != "") {
filteredResult.add(triple)
}
}
result.add(emptyPosting())
return result
filteredResult.add(emptyPosting())
_postings.value = filteredResult
}

fun emptyPosting(): Triple<String, String, String> {
Expand Down
2 changes: 0 additions & 2 deletions gradle/libs.versions.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
[versions]
agp = "8.5.0"
desugar = "2.0.4"
kotlin = "1.9.24"
ksp = "1.9.24-1.0.20"
hilt = "2.51.1"
Expand All @@ -17,7 +16,6 @@ material = "1.12.0"
[libraries]
activity-compose = { group = "androidx.activity", name = "activity-compose", version.ref = "activity" }
activity-ktx = { group = "androidx.activity", name = "activity-ktx", version.ref = "activity" }
android-desugar = { group = "com.android.tools", name = "desugar_jdk_libs", version.ref = "desugar" }
androidx-test-ext-junit = { group = "androidx.test.ext", name = "junit", version.ref = "androidx-test-ext-junit" }
compose-bom = { group = "androidx.compose", name = "compose-bom", version.ref = "compose-bom" }
compose-material-icons-extended = { group = "androidx.compose.material", name = "material-icons-extended" }
Expand Down

0 comments on commit 4fa98cb

Please sign in to comment.