From b00693a516264f25532fb02cffb2ad1b642d93d4 Mon Sep 17 00:00:00 2001
From: Gyan Ponnappa <129504209+Darkeye14@users.noreply.github.com>
Date: Sat, 30 Nov 2024 00:05:36 +0530
Subject: [PATCH] Applying spotless and detekt on search module (JIRA 288)
(#2246)
---
feature/search/build.gradle.kts | 9 +++
.../feature/search/ExampleInstrumentedTest.kt | 17 ++++--
feature/search/src/main/AndroidManifest.xml | 9 +++
.../com/mifos/feature/search/SearchScreen.kt | 47 +++++++++-------
.../com/mifos/feature/search/SearchUiState.kt | 13 ++++-
.../mifos/feature/search/SearchViewModel.kt | 45 +++++++++------
.../feature/search/components/FilterDialog.kt | 37 +++++++-----
.../feature/search/components/SearchBox.kt | 56 ++++++++++---------
.../search/components/SearchScreenResult.kt | 49 +++++++++-------
.../search/navigation/SearchNavigation.kt | 22 +++++---
.../search/navigation/SearchScreens.kt | 11 +++-
.../res/values/feature_search_strings.xml | 9 +++
.../feature/search/SearchViewModelTest.kt | 14 ++++-
13 files changed, 224 insertions(+), 114 deletions(-)
diff --git a/feature/search/build.gradle.kts b/feature/search/build.gradle.kts
index caa71924d21..a6465380725 100644
--- a/feature/search/build.gradle.kts
+++ b/feature/search/build.gradle.kts
@@ -1,3 +1,12 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
plugins {
alias(libs.plugins.mifos.android.feature)
alias(libs.plugins.mifos.android.library.compose)
diff --git a/feature/search/src/androidTest/java/com/mifos/feature/search/ExampleInstrumentedTest.kt b/feature/search/src/androidTest/java/com/mifos/feature/search/ExampleInstrumentedTest.kt
index d672723c875..95ff57e3be3 100644
--- a/feature/search/src/androidTest/java/com/mifos/feature/search/ExampleInstrumentedTest.kt
+++ b/feature/search/src/androidTest/java/com/mifos/feature/search/ExampleInstrumentedTest.kt
@@ -1,13 +1,20 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search
-import androidx.test.platform.app.InstrumentationRegistry
import androidx.test.ext.junit.runners.AndroidJUnit4
-
+import androidx.test.platform.app.InstrumentationRegistry
+import org.junit.Assert.assertEquals
import org.junit.Test
import org.junit.runner.RunWith
-import org.junit.Assert.*
-
/**
* Instrumented test, which will execute on an Android device.
*
@@ -21,4 +28,4 @@ class ExampleInstrumentedTest {
val appContext = InstrumentationRegistry.getInstrumentation().targetContext
assertEquals("com.mifos.feature.search.test", appContext.packageName)
}
-}
\ No newline at end of file
+}
diff --git a/feature/search/src/main/AndroidManifest.xml b/feature/search/src/main/AndroidManifest.xml
index a5918e68abc..1dc76da0f7e 100644
--- a/feature/search/src/main/AndroidManifest.xml
+++ b/feature/search/src/main/AndroidManifest.xml
@@ -1,4 +1,13 @@
+
\ No newline at end of file
diff --git a/feature/search/src/main/java/com/mifos/feature/search/SearchScreen.kt b/feature/search/src/main/java/com/mifos/feature/search/SearchScreen.kt
index 5125f5b9cf8..560edecc227 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/SearchScreen.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/SearchScreen.kt
@@ -1,3 +1,12 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search
import androidx.annotation.VisibleForTesting
@@ -29,9 +38,9 @@ import com.mifos.feature.search.components.SearchScreenResult
@Composable
fun SearchScreenRoute(
- modifier: Modifier = Modifier,
onFabClick: (FabType) -> Unit,
onSearchOptionClick: (SearchedEntity) -> Unit,
+ modifier: Modifier = Modifier,
viewModel: SearchViewModel = hiltViewModel(),
) {
val state by viewModel.state
@@ -50,12 +59,12 @@ fun SearchScreenRoute(
@VisibleForTesting
@Composable
internal fun SearchScreenContent(
- modifier: Modifier = Modifier,
state: SearchScreenState,
searchResultState: SearchResultState,
onEvent: (SearchScreenEvent) -> Unit,
onFabClick: (FabType) -> Unit,
- onResultItemClick: (SearchedEntity) -> Unit
+ onResultItemClick: (SearchedEntity) -> Unit,
+ modifier: Modifier = Modifier,
) {
val snackbarHostState = remember { SnackbarHostState() }
var fabButtonState by remember { mutableStateOf(FabButtonState.Collapsed) }
@@ -67,25 +76,25 @@ internal fun SearchScreenContent(
fabButtons = listOf(
FabButton(
fabType = FabType.CLIENT,
- iconRes = com.mifos.core.ui.R.drawable.core_ui_ic_person_black_24dp
+ iconRes = com.mifos.core.ui.R.drawable.core_ui_ic_person_black_24dp,
),
FabButton(
fabType = FabType.CENTER,
- iconRes = com.mifos.core.ui.R.drawable.core_ui_ic_centers_24dp
+ iconRes = com.mifos.core.ui.R.drawable.core_ui_ic_centers_24dp,
),
FabButton(
fabType = FabType.GROUP,
- iconRes = com.mifos.core.ui.R.drawable.core_ui_ic_group_black_24dp
- )
+ iconRes = com.mifos.core.ui.R.drawable.core_ui_ic_group_black_24dp,
+ ),
),
fabButtonState = fabButtonState,
onFabButtonStateChange = {
fabButtonState = it
},
- onFabClick = onFabClick
+ onFabClick = onFabClick,
)
},
- snackbarHostState = snackbarHostState
+ snackbarHostState = snackbarHostState,
) {
Column(
modifier = Modifier
@@ -97,13 +106,13 @@ internal fun SearchScreenContent(
modifier = Modifier
.padding(horizontal = 16.dp),
state = state,
- onEvent = onEvent
+ onEvent = onEvent,
)
SearchScreenResult(
modifier = Modifier.weight(2f),
searchResultState = searchResultState,
- onResultItemClick = onResultItemClick
+ onResultItemClick = onResultItemClick,
)
}
}
@@ -119,7 +128,7 @@ private fun SearchScreenContentEmptyStateAndLoadingPreview() {
searchResultState = SearchResultState.Loading,
onEvent = {},
onFabClick = {},
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -132,7 +141,7 @@ private fun SearchScreenContentInitialEmptyStatePreview() {
searchResultState = SearchResultState.Empty(),
onEvent = {},
onFabClick = {},
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -143,12 +152,12 @@ private fun SearchScreenContentEmptyResultPreview() {
modifier = Modifier,
state = SearchScreenState(
searchText = "yyy",
- selectedFilter = FilterOption.Groups
+ selectedFilter = FilterOption.Groups,
),
searchResultState = SearchResultState.Empty(false),
onEvent = {},
onFabClick = {},
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -161,7 +170,7 @@ private fun SearchScreenContentErrorPreview() {
searchResultState = SearchResultState.Error("Something went wrong!"),
onEvent = {},
onFabClick = {},
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -169,7 +178,7 @@ private fun SearchScreenContentErrorPreview() {
@Composable
private fun SearchScreenContentSuccessPreview(
@PreviewParameter(SearchResultPreviewParameter::class)
- results: List
+ results: List,
) {
SearchScreenContent(
modifier = Modifier,
@@ -179,6 +188,6 @@ private fun SearchScreenContentSuccessPreview(
searchResultState = SearchResultState.Success(results),
onEvent = {},
onFabClick = {},
- onResultItemClick = {}
+ onResultItemClick = {},
)
-}
\ No newline at end of file
+}
diff --git a/feature/search/src/main/java/com/mifos/feature/search/SearchUiState.kt b/feature/search/src/main/java/com/mifos/feature/search/SearchUiState.kt
index 7a33f1e5564..2b5cb89c1df 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/SearchUiState.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/SearchUiState.kt
@@ -1,3 +1,12 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search
import com.mifos.core.objects.SearchedEntity
@@ -5,5 +14,5 @@ import com.mifos.core.objects.SearchedEntity
data class SearchUiState(
val isLoading: Boolean = false,
val error: String? = null,
- val searchedEntities: List = emptyList()
-)
\ No newline at end of file
+ val searchedEntities: List = emptyList(),
+)
diff --git a/feature/search/src/main/java/com/mifos/feature/search/SearchViewModel.kt b/feature/search/src/main/java/com/mifos/feature/search/SearchViewModel.kt
index d444583a06e..4c9037eef35 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/SearchViewModel.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/SearchViewModel.kt
@@ -1,3 +1,12 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search
import androidx.compose.runtime.mutableStateOf
@@ -25,8 +34,8 @@ class SearchViewModel @Inject constructor(
var state = mutableStateOf(SearchScreenState())
private set
- private val _searchResultState = MutableStateFlow(SearchResultState.Empty())
- val searchResult = _searchResultState.asStateFlow()
+ private val searchResultState = MutableStateFlow(SearchResultState.Empty())
+ val searchResult = searchResultState.asStateFlow()
private var searchJob: Job? = null
@@ -35,7 +44,7 @@ class SearchViewModel @Inject constructor(
is SearchScreenEvent.UpdateSearchText -> {
viewModelScope.launch {
state.value = state.value.copy(
- searchText = event.searchText
+ searchText = event.searchText,
)
}
}
@@ -43,17 +52,17 @@ class SearchViewModel @Inject constructor(
is SearchScreenEvent.ClearSearchText -> {
viewModelScope.launch {
state.value = state.value.copy(
- searchText = ""
+ searchText = "",
)
- _searchResultState.update { SearchResultState.Empty() }
+ searchResultState.update { SearchResultState.Empty() }
}
}
is SearchScreenEvent.UpdateSelectedFilter -> {
viewModelScope.launch {
state.value = state.value.copy(
- selectedFilter = event.filter
+ selectedFilter = event.filter,
)
getSearchResult()
@@ -63,8 +72,11 @@ class SearchViewModel @Inject constructor(
is SearchScreenEvent.UpdateExactMatch -> {
viewModelScope.launch {
state.value = state.value.copy(
- exactMatch = if (state.value.exactMatch == null) true
- else !state.value.exactMatch!!
+ exactMatch = if (state.value.exactMatch == null) {
+ true
+ } else {
+ !state.value.exactMatch!!
+ },
)
getSearchResult()
@@ -76,7 +88,6 @@ class SearchViewModel @Inject constructor(
getSearchResult()
}
}
-
}
}
@@ -87,16 +98,16 @@ class SearchViewModel @Inject constructor(
searchJob = searchRepository.searchResources(
query = state.value.searchText,
resources = state.value.selectedFilter?.value,
- exactMatch = state.value.exactMatch
+ exactMatch = state.value.exactMatch,
).onStart {
- _searchResultState.update { SearchResultState.Loading }
+ searchResultState.update { SearchResultState.Loading }
}.catch { throwable ->
- _searchResultState.update { SearchResultState.Error(throwable.message.toString()) }
+ searchResultState.update { SearchResultState.Error(throwable.message.toString()) }
}.onEach { results ->
if (results.isEmpty()) {
- _searchResultState.update { SearchResultState.Empty(false) }
+ searchResultState.update { SearchResultState.Empty(false) }
} else {
- _searchResultState.update { SearchResultState.Success(results) }
+ searchResultState.update { SearchResultState.Success(results) }
}
}.launchIn(viewModelScope)
}
@@ -113,7 +124,7 @@ sealed interface SearchResultState {
data class SearchScreenState(
val searchText: String = "",
val selectedFilter: FilterOption? = null,
- val exactMatch: Boolean? = null
+ val exactMatch: Boolean? = null,
)
sealed interface SearchScreenEvent {
@@ -121,7 +132,7 @@ sealed interface SearchScreenEvent {
data class UpdateSelectedFilter(val filter: FilterOption? = null) : SearchScreenEvent
- data object ClearSearchText: SearchScreenEvent
+ data object ClearSearchText : SearchScreenEvent
data object UpdateExactMatch : SearchScreenEvent
@@ -142,4 +153,4 @@ sealed class FilterOption(val label: String, val value: String) {
companion object {
val values = listOf(Clients, Groups, LoanAccounts, SavingsAccounts)
}
-}
\ No newline at end of file
+}
diff --git a/feature/search/src/main/java/com/mifos/feature/search/components/FilterDialog.kt b/feature/search/src/main/java/com/mifos/feature/search/components/FilterDialog.kt
index c7d9bfc7cb1..a621d10f465 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/components/FilterDialog.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/components/FilterDialog.kt
@@ -1,3 +1,12 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search.components
import androidx.compose.foundation.clickable
@@ -27,10 +36,10 @@ import com.mifos.feature.search.SearchScreenEvent
@Composable
internal fun FilterDialog(
- modifier: Modifier = Modifier,
selected: FilterOption?,
onEvent: (SearchScreenEvent.UpdateSelectedFilter) -> Unit,
onDismiss: () -> Unit,
+ modifier: Modifier = Modifier,
) {
val configuration = LocalConfiguration.current
@@ -45,7 +54,7 @@ internal fun FilterDialog(
HorizontalDivider()
Column(
modifier = Modifier
- .verticalScroll(rememberScrollState())
+ .verticalScroll(rememberScrollState()),
) {
FilterOption(
text = "All",
@@ -53,7 +62,7 @@ internal fun FilterDialog(
onSelected = {
onEvent(SearchScreenEvent.UpdateSelectedFilter(null))
onDismiss()
- }
+ },
)
HorizontalDivider()
@@ -65,7 +74,7 @@ internal fun FilterDialog(
onSelected = {
onEvent(SearchScreenEvent.UpdateSelectedFilter(option))
onDismiss()
- }
+ },
)
if (index != FilterOption.values.size - 1) {
@@ -74,16 +83,16 @@ internal fun FilterDialog(
}
}
},
- confirmButton = {}
+ confirmButton = {},
)
}
@Composable
internal fun FilterOption(
- modifier: Modifier = Modifier,
text: String,
selected: Boolean,
- onSelected: () -> Unit
+ onSelected: () -> Unit,
+ modifier: Modifier = Modifier,
) {
Row(
modifier = modifier
@@ -97,11 +106,11 @@ internal fun FilterOption(
selected = selected,
onClick = {
onSelected()
- }
+ },
)
Text(
text = text,
- fontSize = 16.sp
+ fontSize = 16.sp,
)
}
}
@@ -109,27 +118,27 @@ internal fun FilterOption(
@DevicePreviews
@Composable
private fun FilterDialogPreview(
- modifier: Modifier = Modifier
+ modifier: Modifier = Modifier,
) {
FilterDialog(
modifier = modifier,
selected = null,
onEvent = {},
- onDismiss = {}
+ onDismiss = {},
)
}
@DevicePreviews
@Composable
private fun FilterOptionPreview(
- modifier: Modifier = Modifier
+ modifier: Modifier = Modifier,
) {
MaterialTheme {
FilterOption(
modifier = modifier,
text = "Search Option",
selected = true,
- onSelected = {}
+ onSelected = {},
)
}
-}
\ No newline at end of file
+}
diff --git a/feature/search/src/main/java/com/mifos/feature/search/components/SearchBox.kt b/feature/search/src/main/java/com/mifos/feature/search/components/SearchBox.kt
index e472f3d0934..4e199d65729 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/components/SearchBox.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/components/SearchBox.kt
@@ -1,6 +1,14 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search.components
-
import androidx.compose.animation.AnimatedVisibility
import androidx.compose.foundation.background
import androidx.compose.foundation.clickable
@@ -45,29 +53,29 @@ import com.mifos.feature.search.SearchScreenState
@Composable
internal fun SearchBox(
- modifier: Modifier = Modifier,
state: SearchScreenState,
onEvent: (SearchScreenEvent) -> Unit,
+ modifier: Modifier = Modifier,
) {
val interactionSource = remember { MutableInteractionSource() }
var showDialog by remember { mutableStateOf(false) }
Box(
- modifier = modifier.fillMaxWidth()
+ modifier = modifier.fillMaxWidth(),
) {
Column(
modifier = Modifier.fillMaxWidth(),
- verticalArrangement = Arrangement.spacedBy(8.dp)
+ verticalArrangement = Arrangement.spacedBy(8.dp),
) {
// Title And Filter Icon
Row(
modifier = Modifier.fillMaxWidth(),
horizontalArrangement = Arrangement.SpaceBetween,
- verticalAlignment = Alignment.CenterVertically
+ verticalAlignment = Alignment.CenterVertically,
) {
Text(
text = stringResource(id = R.string.feature_search_title),
- fontSize = 24.sp
+ fontSize = 24.sp,
)
AssistChip(
@@ -77,24 +85,24 @@ internal fun SearchBox(
label = {
Text(
text = state.selectedFilter?.label ?: "All",
- fontSize = 16.sp
+ fontSize = 16.sp,
)
},
leadingIcon = {
Icon(
imageVector = Icons.Default.FilterList,
- contentDescription = "filterIcon"
+ contentDescription = "filterIcon",
)
},
trailingIcon = {
Icon(
imageVector = Icons.Default.KeyboardArrowDown,
- contentDescription = "changeFilter"
+ contentDescription = "changeFilter",
)
},
colors = AssistChipDefaults.assistChipColors().copy(
- leadingIconContentColor = MaterialTheme.colorScheme.tertiary
- )
+ leadingIconContentColor = MaterialTheme.colorScheme.tertiary,
+ ),
)
}
@@ -124,12 +132,12 @@ internal fun SearchBox(
) {
Icon(
imageVector = Icons.Outlined.Search,
- contentDescription = "searchIcon"
+ contentDescription = "searchIcon",
)
Text(
text = stringResource(id = R.string.feature_search_title),
- fontSize = 16.sp
+ fontSize = 16.sp,
)
}
@@ -138,13 +146,13 @@ internal fun SearchBox(
modifier = Modifier
.clickable(
interactionSource = interactionSource,
- indication = null
+ indication = null,
) {
onEvent(SearchScreenEvent.UpdateExactMatch)
}
.padding(vertical = 12.dp),
verticalAlignment = Alignment.CenterVertically,
- horizontalArrangement = Arrangement.spacedBy(8.dp, Alignment.Start)
+ horizontalArrangement = Arrangement.spacedBy(8.dp, Alignment.Start),
) {
Checkbox(
checked = state.exactMatch ?: false,
@@ -152,42 +160,40 @@ internal fun SearchBox(
onEvent(SearchScreenEvent.UpdateExactMatch)
},
modifier = Modifier
- .size(20.dp)
+ .size(20.dp),
)
Text(
text = stringResource(id = R.string.feature_search_exact_match),
- fontSize = 16.sp
+ fontSize = 16.sp,
)
}
}
}
AnimatedVisibility(
- visible = showDialog
+ visible = showDialog,
) {
FilterDialog(
selected = state.selectedFilter,
onEvent = onEvent,
onDismiss = {
showDialog = false
- }
+ },
)
}
}
-
@DevicePreviews
@Composable
private fun SearchBoxPreview() {
SearchBox(
modifier = Modifier.background(Color.White),
state = SearchScreenState(),
- onEvent = {}
+ onEvent = {},
)
}
-
@DevicePreviews
@Composable
private fun SearchBoxWithValuesPreview() {
@@ -196,8 +202,8 @@ private fun SearchBoxWithValuesPreview() {
state = SearchScreenState(
searchText = "search text",
selectedFilter = FilterOption.Groups,
- exactMatch = true
+ exactMatch = true,
),
- onEvent = {}
+ onEvent = {},
)
-}
\ No newline at end of file
+}
diff --git a/feature/search/src/main/java/com/mifos/feature/search/components/SearchScreenResult.kt b/feature/search/src/main/java/com/mifos/feature/search/components/SearchScreenResult.kt
index 524ea002d5b..9a455ec9b69 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/components/SearchScreenResult.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/components/SearchScreenResult.kt
@@ -1,6 +1,14 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search.components
-
import androidx.compose.animation.Crossfade
import androidx.compose.foundation.Image
import androidx.compose.foundation.clickable
@@ -36,9 +44,9 @@ import com.mifos.feature.search.SearchResultState
@Composable
internal fun SearchScreenResult(
- modifier: Modifier = Modifier,
searchResultState: SearchResultState,
onResultItemClick: (SearchedEntity) -> Unit,
+ modifier: Modifier = Modifier,
) {
Box(
modifier = modifier
@@ -46,7 +54,7 @@ internal fun SearchScreenResult(
) {
Crossfade(
targetState = searchResultState,
- label = "SearchResult"
+ label = "SearchResult",
) { state ->
when (state) {
is SearchResultState.Loading -> {
@@ -56,7 +64,7 @@ internal fun SearchScreenResult(
is SearchResultState.Empty -> {
if (!state.initial) {
MifosEmptyUi(
- text = stringResource(R.string.feature_search_no_search_result_found)
+ text = stringResource(R.string.feature_search_no_search_result_found),
)
}
}
@@ -64,7 +72,7 @@ internal fun SearchScreenResult(
is SearchResultState.Error -> {
MifosEmptyUi(
text = state.message,
- modifier = Modifier.align(Alignment.Center)
+ modifier = Modifier.align(Alignment.Center),
)
}
@@ -73,17 +81,17 @@ internal fun SearchScreenResult(
modifier = Modifier
.fillMaxSize(),
contentPadding = PaddingValues(vertical = 8.dp),
- verticalArrangement = Arrangement.spacedBy(8.dp)
+ verticalArrangement = Arrangement.spacedBy(8.dp),
) {
items(
items = state.results,
key = {
"${it.entityType}-${it.entityId}-${it.parentId}"
- }
+ },
) { searchedEntity ->
SearchResult(
searchedEntity = searchedEntity,
- onSearchOptionClick = onResultItemClick
+ onSearchOptionClick = onResultItemClick,
)
}
}
@@ -95,9 +103,9 @@ internal fun SearchScreenResult(
@Composable
internal fun SearchResult(
- modifier: Modifier = Modifier,
searchedEntity: SearchedEntity,
- onSearchOptionClick: (SearchedEntity) -> Unit
+ onSearchOptionClick: (SearchedEntity) -> Unit,
+ modifier: Modifier = Modifier,
) {
val color = ColorGenerator.MATERIAL.getColor(searchedEntity.entityType)
val drawable =
@@ -117,7 +125,7 @@ internal fun SearchResult(
)
},
colors = ListItemDefaults.colors(
- containerColor = MaterialTheme.colorScheme.surfaceContainerLowest
+ containerColor = MaterialTheme.colorScheme.surfaceContainerLowest,
),
modifier = modifier
.fillMaxWidth()
@@ -127,13 +135,12 @@ internal fun SearchResult(
)
}
-
@DevicePreviews
@Composable
private fun SearchScreenResultLoadingPreview() {
SearchScreenResult(
searchResultState = SearchResultState.Loading,
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -142,7 +149,7 @@ private fun SearchScreenResultLoadingPreview() {
private fun SearchScreenResultInitialEmptyPreview() {
SearchScreenResult(
searchResultState = SearchResultState.Empty(),
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -151,7 +158,7 @@ private fun SearchScreenResultInitialEmptyPreview() {
private fun SearchScreenResultEmptyPreview() {
SearchScreenResult(
searchResultState = SearchResultState.Empty(true),
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -160,7 +167,7 @@ private fun SearchScreenResultEmptyPreview() {
private fun SearchScreenResultErrorPreview() {
SearchScreenResult(
searchResultState = SearchResultState.Error("Unable to fetch data from server"),
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -168,11 +175,11 @@ private fun SearchScreenResultErrorPreview() {
@Composable
private fun SearchScreenResultSuccessPreview(
@PreviewParameter(SearchResultPreviewParameter::class)
- results: List
+ results: List,
) {
SearchScreenResult(
searchResultState = SearchResultState.Success(results),
- onResultItemClick = {}
+ onResultItemClick = {},
)
}
@@ -187,8 +194,8 @@ private fun SearchResultPreview() {
entityType = "center",
parentId = 3296,
parentName = "center",
- entityStatus = null
+ entityStatus = null,
),
- onSearchOptionClick = {}
+ onSearchOptionClick = {},
)
-}
\ No newline at end of file
+}
diff --git a/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchNavigation.kt b/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchNavigation.kt
index e5270c920a5..c36b008dcdb 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchNavigation.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchNavigation.kt
@@ -1,9 +1,17 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search.navigation
import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.padding
import androidx.compose.ui.Modifier
-import androidx.navigation.NavController
import androidx.navigation.NavGraphBuilder
import androidx.navigation.compose.composable
import androidx.navigation.navigation
@@ -21,11 +29,11 @@ fun NavGraphBuilder.searchNavGraph(
onCenter: (Int) -> Unit,
onGroup: (Int) -> Unit,
onSavings: (Int) -> Unit,
- onLoan: (Int) -> Unit
+ onLoan: (Int) -> Unit,
) {
navigation(
startDestination = SearchScreens.SearchScreen.route,
- route = SearchScreens.SearchScreenRoute.route
+ route = SearchScreens.SearchScreenRoute.route,
) {
searchRoute(
modifier = Modifier.padding(paddingValues),
@@ -66,7 +74,7 @@ fun NavGraphBuilder.searchNavGraph(
onCenter(searchedEntity.entityId)
}
}
- }
+ },
)
}
}
@@ -74,15 +82,15 @@ fun NavGraphBuilder.searchNavGraph(
fun NavGraphBuilder.searchRoute(
modifier: Modifier,
onFabClick: (FabType) -> Unit,
- onSearchOptionClick: (SearchedEntity) -> Unit
+ onSearchOptionClick: (SearchedEntity) -> Unit,
) {
composable(
- route = SearchScreens.SearchScreen.route
+ route = SearchScreens.SearchScreen.route,
) {
SearchScreenRoute(
modifier = modifier,
onFabClick = onFabClick,
- onSearchOptionClick = onSearchOptionClick
+ onSearchOptionClick = onSearchOptionClick,
)
}
}
diff --git a/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchScreens.kt b/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchScreens.kt
index 27ff0d1b021..c73aa4950c0 100644
--- a/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchScreens.kt
+++ b/feature/search/src/main/java/com/mifos/feature/search/navigation/SearchScreens.kt
@@ -1,7 +1,16 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search.navigation
sealed class SearchScreens(val route: String) {
data object SearchScreenRoute : SearchScreens("search_screen_route")
data object SearchScreen : SearchScreens("search_screen")
-}
\ No newline at end of file
+}
diff --git a/feature/search/src/main/res/values/feature_search_strings.xml b/feature/search/src/main/res/values/feature_search_strings.xml
index fb93139eb8d..a545ab7a61b 100644
--- a/feature/search/src/main/res/values/feature_search_strings.xml
+++ b/feature/search/src/main/res/values/feature_search_strings.xml
@@ -1,4 +1,13 @@
+
Search
Filter Search
diff --git a/feature/search/src/test/java/com/mifos/feature/search/SearchViewModelTest.kt b/feature/search/src/test/java/com/mifos/feature/search/SearchViewModelTest.kt
index 772d6bf6b58..9c16f9dc2b1 100644
--- a/feature/search/src/test/java/com/mifos/feature/search/SearchViewModelTest.kt
+++ b/feature/search/src/test/java/com/mifos/feature/search/SearchViewModelTest.kt
@@ -1,3 +1,12 @@
+/*
+ * Copyright 2024 Mifos Initiative
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ *
+ * See https://github.com/openMF/android-client/blob/master/LICENSE.md
+ */
package com.mifos.feature.search
import com.mifos.core.testing.repository.TestSearchRepository
@@ -11,7 +20,6 @@ import kotlin.test.assertEquals
import kotlin.test.assertIs
import kotlin.test.assertIsNot
-
class SearchViewModelTest {
@get:Rule
@@ -31,7 +39,7 @@ class SearchViewModelTest {
}
@Test
- fun performSearchAndReturnEmptyResult() = runTest{
+ fun performSearchAndReturnEmptyResult() = runTest {
repository.addSampleResults(SearchResultPreviewData.searchResults)
viewModel.onEvent(SearchScreenEvent.UpdateSearchText("kkk"))
@@ -123,4 +131,4 @@ class SearchViewModelTest {
assertIsNot(viewModel.searchResult.value)
assertIs(viewModel.searchResult.value)
}
-}
\ No newline at end of file
+}