mirror of
https://github.com/msfjarvis/compose-lobsters
synced 2025-08-17 20:17:02 +05:30
common/app: migrate all string usages to common Strings API
Signed-off-by: Harsh Shandilya <me@msfjarvis.dev>
This commit is contained in:
parent
cad53dcce5
commit
1abbd8baba
8 changed files with 17 additions and 23 deletions
|
@ -12,7 +12,6 @@ import androidx.compose.runtime.getValue
|
|||
import androidx.compose.runtime.rememberCoroutineScope
|
||||
import androidx.compose.ui.Modifier
|
||||
import androidx.compose.ui.platform.testTag
|
||||
import androidx.compose.ui.res.stringResource
|
||||
import androidx.lifecycle.viewmodel.compose.viewModel
|
||||
import androidx.navigation.compose.KEY_ROUTE
|
||||
import androidx.navigation.compose.NavHost
|
||||
|
@ -27,6 +26,7 @@ import dev.msfjarvis.lobsters.ui.posts.HottestPosts
|
|||
import dev.msfjarvis.lobsters.ui.posts.SavedPosts
|
||||
import dev.msfjarvis.lobsters.ui.viewmodel.LobstersViewModel
|
||||
import dev.msfjarvis.lobsters.util.IconResource
|
||||
import dev.msfjarvis.lobsters.utils.get
|
||||
import kotlinx.coroutines.launch
|
||||
|
||||
@Composable
|
||||
|
@ -104,10 +104,10 @@ fun LobstersBottomNav(
|
|||
icon = {
|
||||
IconResource(
|
||||
resourceId = screen.badgeRes,
|
||||
contentDescription = stringResource(screen.labelRes),
|
||||
contentDescription = screen.labelRes.get(),
|
||||
)
|
||||
},
|
||||
label = { Text(stringResource(id = screen.labelRes)) },
|
||||
label = { Text(screen.labelRes.get()) },
|
||||
selected = currentDestination == screen,
|
||||
modifier = Modifier.testTag(screen.name),
|
||||
alwaysShowLabel = false,
|
||||
|
|
|
@ -13,6 +13,8 @@ import androidx.compose.ui.unit.dp
|
|||
import dev.msfjarvis.lobsters.R
|
||||
import dev.msfjarvis.lobsters.ui.navigation.Destination
|
||||
import dev.msfjarvis.lobsters.util.IconResource
|
||||
import dev.msfjarvis.lobsters.utils.Strings
|
||||
import dev.msfjarvis.lobsters.utils.get
|
||||
import kotlinx.coroutines.launch
|
||||
|
||||
@OptIn(ExperimentalAnimationApi::class)
|
||||
|
@ -33,7 +35,7 @@ fun LobstersTopAppBar(
|
|||
if (currentDestination == Destination.Saved) {
|
||||
IconResource(
|
||||
resourceId = R.drawable.ic_sort_24px,
|
||||
contentDescription = stringResource(id = R.string.change_sorting_order),
|
||||
contentDescription = Strings.ChangeSortingOrder.get(),
|
||||
modifier = Modifier
|
||||
.padding(horizontal = 8.dp, vertical = 8.dp)
|
||||
.clickable { scope.launch { toggleSortingOrder() } },
|
||||
|
|
|
@ -1,19 +1,19 @@
|
|||
package dev.msfjarvis.lobsters.ui.navigation
|
||||
|
||||
import androidx.annotation.DrawableRes
|
||||
import androidx.annotation.StringRes
|
||||
import dev.msfjarvis.lobsters.R
|
||||
import dev.msfjarvis.lobsters.utils.Strings
|
||||
|
||||
/**
|
||||
* Destinations for navigation within the app.
|
||||
*/
|
||||
enum class Destination(
|
||||
val route: String,
|
||||
@StringRes val labelRes: Int,
|
||||
val labelRes: Strings,
|
||||
@DrawableRes val badgeRes: Int,
|
||||
) {
|
||||
Hottest("hottest", R.string.hottest_posts, R.drawable.ic_whatshot_24px),
|
||||
Saved("saved", R.string.saved_posts, R.drawable.ic_favorite_24px),
|
||||
Hottest("hottest", Strings.HottestPosts, R.drawable.ic_whatshot_24px),
|
||||
Saved("saved", Strings.SavedPosts, R.drawable.ic_favorite_24px),
|
||||
;
|
||||
|
||||
companion object {
|
||||
|
|
|
@ -1,14 +1,3 @@
|
|||
<resources>
|
||||
<string name="app_name">Claw</string>
|
||||
<string name="loading">Loading posts…</string>
|
||||
<string name="no_saved_posts">You don\'t have any saved posts</string>
|
||||
<string name="hottest_posts">Hottest</string>
|
||||
<string name="saved_posts">Saved</string>
|
||||
<string name="submitted_by">submitted by %1$s</string>
|
||||
<string name="avatar_content_description">%1$s\'s avatar</string>
|
||||
<string name="add_to_saved_posts">Add to saved posts</string>
|
||||
<string name="remove_from_saved_posts">Remove from saved posts</string>
|
||||
<string name="refresh_posts_content_description">Refresh posts</string>
|
||||
<string name="open_comments">Open comments</string>
|
||||
<string name="change_sorting_order">Change sort order</string>
|
||||
</resources>
|
||||
|
|
|
@ -9,12 +9,13 @@ private fun stringEnumMapper(stringEnum: Strings): Int {
|
|||
Strings.AddToSavedPosts -> R.string.add_to_saved_posts
|
||||
Strings.AppName -> R.string.app_name
|
||||
Strings.AvatarContentDescription -> R.string.avatar_content_description
|
||||
Strings.ChangeSortingOrder -> R.string.change_sorting_order
|
||||
Strings.HottestPosts -> R.string.hottest_posts
|
||||
Strings.Loading -> R.string.loading
|
||||
Strings.NoSavedPost -> R.string.no_saved_posts
|
||||
Strings.OpenComments -> R.string.open_comments
|
||||
Strings.RefreshPostsContentDescription -> R.string.refresh_posts_content_description
|
||||
Strings.RemoveFromSavedPosts -> R.string.remove_from_saved_posts
|
||||
Strings.SavedPosts -> R.string.saved_posts
|
||||
Strings.SubmittedBy -> R.string.submitted_by
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,6 +1,5 @@
|
|||
<resources>
|
||||
<string name="app_name">Claw</string>
|
||||
<string name="loading">Loading posts…</string>
|
||||
<string name="no_saved_posts">You don\'t have any saved posts</string>
|
||||
<string name="hottest_posts">Hottest</string>
|
||||
<string name="saved_posts">Saved</string>
|
||||
|
@ -10,4 +9,5 @@
|
|||
<string name="remove_from_saved_posts">Remove from saved posts</string>
|
||||
<string name="refresh_posts_content_description">Refresh posts</string>
|
||||
<string name="open_comments">Open comments</string>
|
||||
<string name="change_sorting_order">Change sort order</string>
|
||||
</resources>
|
||||
|
|
|
@ -4,12 +4,13 @@ enum class Strings {
|
|||
AddToSavedPosts,
|
||||
AppName,
|
||||
AvatarContentDescription,
|
||||
ChangeSortingOrder,
|
||||
HottestPosts,
|
||||
Loading,
|
||||
NoSavedPost,
|
||||
OpenComments,
|
||||
RefreshPostsContentDescription,
|
||||
RemoveFromSavedPosts,
|
||||
SavedPosts,
|
||||
SubmittedBy,
|
||||
;
|
||||
}
|
||||
|
|
|
@ -7,12 +7,13 @@ private fun stringEnumMapper(stringEnum: Strings): String {
|
|||
Strings.AddToSavedPosts -> "Add to saved posts"
|
||||
Strings.AppName -> "Claw"
|
||||
Strings.AvatarContentDescription -> "%1s's avatar"
|
||||
Strings.ChangeSortingOrder -> "Change sorting order"
|
||||
Strings.HottestPosts -> "Hottest"
|
||||
Strings.Loading -> "Loading posts…"
|
||||
Strings.NoSavedPost -> "You don't have any saved posts"
|
||||
Strings.OpenComments -> "Open comments"
|
||||
Strings.RefreshPostsContentDescription -> "Refresh posts"
|
||||
Strings.RemoveFromSavedPosts -> "Remove from saved posts"
|
||||
Strings.SavedPosts -> "Saved"
|
||||
Strings.SubmittedBy -> "submitted by %1s"
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue