Compare commits
10 Commits
ac433bc492
...
feature/ne
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
59c869d539 | ||
|
|
082c4f7973 | ||
|
|
c2efbd1f75 | ||
|
|
0482f03e09 | ||
|
|
aff43c61a0 | ||
|
|
2987289581 | ||
|
|
aaed01bd12 | ||
|
|
39ff86c8a0 | ||
|
|
993ab0a0b1 | ||
|
|
1f6e7b8ac0 |
@@ -14,7 +14,7 @@ private const val BASE_TIMEOUT = 30L
|
||||
@InstallIn(SingletonComponent::class)
|
||||
object AppConfigModule {
|
||||
|
||||
private const val BASE_URL_PROD = "https://tulsu.ru/schedule/queries/"
|
||||
private const val BASE_URL_PROD = "https://tulsu.ru/"
|
||||
private const val BASE_URL_DEVELOP = "https://scherbatykh.ru/app/tsudesk/"
|
||||
|
||||
@Provides
|
||||
@@ -1,37 +1,32 @@
|
||||
package ru.fincode.tsudesk.app.presentation.main
|
||||
package ru.fincode.tsudesk.presentation.main
|
||||
|
||||
import androidx.navigation.NavBackStackEntry
|
||||
import androidx.navigation.NavDestination
|
||||
import androidx.navigation.NavDestination.Companion.hasRoute
|
||||
import ru.fincode.tsudesk.core.navigation.AppRoute
|
||||
import ru.fincode.tsudesk.core.navigation.TopLevelDestination
|
||||
import ru.fincode.tsudesk.core.navigation.route
|
||||
|
||||
fun selectedTopLevel(entry: NavBackStackEntry?): TopLevelDestination {
|
||||
if (entry == null) return TopLevelDestination.SCHEDULE
|
||||
val dest: NavDestination = entry?.destination ?: return TopLevelDestination.SCHEDULE
|
||||
|
||||
return runCatching {
|
||||
when (entry.route<AppRoute>()) {
|
||||
AppRoute.Schedule,
|
||||
is AppRoute.ScheduleDetails -> TopLevelDestination.SCHEDULE
|
||||
return when {
|
||||
dest.hasRoute<AppRoute.Schedule>() || dest.hasRoute<AppRoute.ScheduleDetails>() ->
|
||||
TopLevelDestination.SCHEDULE
|
||||
|
||||
AppRoute.News,
|
||||
is AppRoute.NewsDetails -> TopLevelDestination.NEWS
|
||||
dest.hasRoute<AppRoute.News>() || dest.hasRoute<AppRoute.NewsDetails>() ->
|
||||
TopLevelDestination.NEWS
|
||||
|
||||
AppRoute.Progress -> TopLevelDestination.PROGRESS
|
||||
dest.hasRoute<AppRoute.Progress>() ->
|
||||
TopLevelDestination.PROGRESS
|
||||
|
||||
AppRoute.Settings -> TopLevelDestination.SETTINGS
|
||||
dest.hasRoute<AppRoute.Settings>() ->
|
||||
TopLevelDestination.SETTINGS
|
||||
|
||||
else -> TopLevelDestination.SCHEDULE
|
||||
}
|
||||
}.getOrDefault(TopLevelDestination.SCHEDULE)
|
||||
}
|
||||
|
||||
fun shouldShowBottomBar(entry: NavBackStackEntry?): Boolean {
|
||||
if (entry == null) return false
|
||||
|
||||
return runCatching {
|
||||
when (entry.route<AppRoute>()) {
|
||||
AppRoute.Splash -> false
|
||||
else -> true
|
||||
}
|
||||
}.getOrDefault(true)
|
||||
val dest: NavDestination = entry?.destination ?: return false
|
||||
return !dest.hasRoute<AppRoute.Splash>()
|
||||
}
|
||||
@@ -5,15 +5,13 @@ import androidx.compose.material3.Scaffold
|
||||
import androidx.compose.runtime.Composable
|
||||
import androidx.compose.runtime.getValue
|
||||
import androidx.compose.ui.Modifier
|
||||
import androidx.compose.ui.res.painterResource
|
||||
import androidx.compose.ui.res.stringResource
|
||||
import androidx.compose.ui.res.vectorResource
|
||||
import androidx.navigation.NavHostController
|
||||
import androidx.navigation.compose.currentBackStackEntryAsState
|
||||
import ru.fincode.core.ui.components.BottomBarItem
|
||||
import ru.fincode.core.ui.components.TsudeskBottomBar
|
||||
import ru.fincode.tsudesk.R
|
||||
import ru.fincode.tsudesk.app.presentation.main.selectedTopLevel
|
||||
import ru.fincode.tsudesk.app.presentation.main.shouldShowBottomBar
|
||||
import ru.fincode.tsudesk.core.navigation.TopLevelDestination
|
||||
import ru.fincode.tsudesk.core.navigation.navigateToTopLevel
|
||||
|
||||
@@ -22,32 +20,20 @@ fun MainScaffold(
|
||||
navController: NavHostController,
|
||||
content: @Composable (Modifier) -> Unit,
|
||||
) {
|
||||
val scheduleIcon = painterResource(R.drawable.ic_progress)
|
||||
val newsIcon = painterResource(R.drawable.ic_news)
|
||||
val progressIcon = painterResource(R.drawable.ic_progress)
|
||||
val settingsIcon = painterResource(R.drawable.ic_progress)
|
||||
val scheduleIcon =
|
||||
androidx.compose.ui.graphics.vector.ImageVector.vectorResource(R.drawable.ic_progress)
|
||||
val newsIcon =
|
||||
androidx.compose.ui.graphics.vector.ImageVector.vectorResource(R.drawable.ic_progress)
|
||||
val progressIcon =
|
||||
androidx.compose.ui.graphics.vector.ImageVector.vectorResource(R.drawable.ic_progress)
|
||||
val settingsIcon =
|
||||
androidx.compose.ui.graphics.vector.ImageVector.vectorResource(R.drawable.ic_progress)
|
||||
|
||||
val items = listOf(
|
||||
TopLevelItem(
|
||||
destination = TopLevelDestination.SCHEDULE,
|
||||
labelRes = R.string.tab_schedule,
|
||||
icon = scheduleIcon
|
||||
),
|
||||
TopLevelItem(
|
||||
destination = TopLevelDestination.NEWS,
|
||||
labelRes = R.string.tab_news,
|
||||
icon = newsIcon
|
||||
),
|
||||
TopLevelItem(
|
||||
destination = TopLevelDestination.PROGRESS,
|
||||
labelRes = R.string.tab_progress,
|
||||
icon = progressIcon
|
||||
),
|
||||
TopLevelItem(
|
||||
destination = TopLevelDestination.SETTINGS,
|
||||
labelRes = R.string.tab_settings,
|
||||
icon = settingsIcon
|
||||
),
|
||||
TopLevelItem(TopLevelDestination.SCHEDULE, R.string.tab_schedule, scheduleIcon),
|
||||
TopLevelItem(TopLevelDestination.NEWS, R.string.tab_news, newsIcon),
|
||||
TopLevelItem(TopLevelDestination.PROGRESS, R.string.tab_progress, progressIcon),
|
||||
TopLevelItem(TopLevelDestination.SETTINGS, R.string.tab_settings, settingsIcon),
|
||||
)
|
||||
|
||||
val backStackEntry by navController.currentBackStackEntryAsState()
|
||||
|
||||
@@ -1,12 +1,11 @@
|
||||
package ru.fincode.tsudesk.presentation.main
|
||||
|
||||
import androidx.annotation.StringRes
|
||||
import androidx.compose.ui.graphics.painter.Painter
|
||||
import androidx.compose.ui.graphics.vector.ImageVector
|
||||
import ru.fincode.tsudesk.core.navigation.TopLevelDestination
|
||||
|
||||
data class TopLevelItem(
|
||||
val destination: TopLevelDestination,
|
||||
@StringRes val labelRes: Int,
|
||||
val icon: Painter,
|
||||
val icon: ImageVector
|
||||
)
|
||||
@@ -1,19 +1,20 @@
|
||||
package ru.fincode.tsudesk.presentation.navigation
|
||||
|
||||
import androidx.compose.foundation.layout.fillMaxSize
|
||||
import androidx.compose.runtime.Composable
|
||||
import androidx.compose.ui.Modifier
|
||||
import androidx.navigation.NavHostController
|
||||
import androidx.navigation.compose.NavHost
|
||||
import androidx.navigation.compose.composable
|
||||
import androidx.navigation.compose.navigation
|
||||
import ru.fincode.tsudesk.presentation.main.MainScaffold
|
||||
import androidx.navigation.compose.rememberNavController
|
||||
import ru.fincode.tsudesk.core.navigation.AppRoute
|
||||
import ru.fincode.tsudesk.core.navigation.navigateRoute
|
||||
import ru.fincode.tsudesk.feature.news.presentation.screen.NewsRoute
|
||||
//import ru.fincode.tsudesk.feature.news.presentation.screen.NewsRoute
|
||||
import ru.fincode.tsudesk.presentation.main.MainScaffold
|
||||
import ru.fincode.tsudesk.feature.schedule.presentation.screen.ScheduleRoute
|
||||
|
||||
import ru.fincode.tsudesk.feature.splash.presentation.screen.SplashRoute
|
||||
|
||||
|
||||
@Composable
|
||||
fun AppNavHost(
|
||||
navController: NavHostController,
|
||||
@@ -33,51 +34,45 @@ fun AppNavHost(
|
||||
)
|
||||
}
|
||||
|
||||
navigation<AppRoute.Main>(startDestination = AppRoute.Schedule) {
|
||||
composable<AppRoute.Main> {
|
||||
val tabsNavController = rememberNavController()
|
||||
|
||||
composable<AppRoute.Schedule> {
|
||||
MainScaffold(navController) { innerModifier ->
|
||||
ScheduleRoute(
|
||||
modifier = innerModifier,
|
||||
// onOpenDetails = { lessonId ->
|
||||
// navController.navigateRoute(AppRoute.ScheduleDetails(lessonId))
|
||||
// }
|
||||
MainScaffold(
|
||||
navController = tabsNavController
|
||||
) { innerModifier ->
|
||||
MainTabsNavHost(
|
||||
navController = tabsNavController,
|
||||
modifier = innerModifier
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
private fun MainTabsNavHost(
|
||||
navController: NavHostController,
|
||||
modifier: Modifier = Modifier,
|
||||
) {
|
||||
NavHost(
|
||||
navController = navController,
|
||||
startDestination = AppRoute.Schedule,
|
||||
modifier = modifier
|
||||
) {
|
||||
composable<AppRoute.Schedule> {
|
||||
ScheduleRoute(modifier = Modifier.fillMaxSize())
|
||||
}
|
||||
|
||||
composable<AppRoute.News> {
|
||||
MainScaffold(navController) { innerModifier: Modifier ->
|
||||
// NewsScreen(
|
||||
// modifier = innerModifier,
|
||||
// onOpenDetails = { id ->
|
||||
// navController.navigateRoute(AppRoute.NewsDetails(id))
|
||||
// }
|
||||
// )
|
||||
}
|
||||
NewsRoute(modifier = Modifier.fillMaxSize())
|
||||
}
|
||||
|
||||
composable<AppRoute.Progress> {
|
||||
MainScaffold(navController) { innerModifier: Modifier ->
|
||||
// ProgressScreen(modifier = innerModifier)
|
||||
}
|
||||
// ProgressRoute(modifier = Modifier)
|
||||
}
|
||||
|
||||
composable<AppRoute.Settings> {
|
||||
MainScaffold(navController) { innerModifier ->
|
||||
// SettingsRoute(modifier = innerModifier)
|
||||
}
|
||||
}
|
||||
//
|
||||
// composable<AppRoute.ScheduleDetails> { entry ->
|
||||
// val args = entry.route<AppRoute.ScheduleDetails>()
|
||||
// ScheduleDetailsScreen(lessonId = args.lessonId)
|
||||
// }
|
||||
//
|
||||
// composable<AppRoute.NewsDetails> { entry ->
|
||||
// val args = entry.route<AppRoute.NewsDetails>()
|
||||
// NewsDetailsScreen(id = args.id)
|
||||
// }
|
||||
// SettingsRoute(modifier = Modifier)
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -3,10 +3,12 @@
|
||||
android:height="24dp"
|
||||
android:viewportWidth="24"
|
||||
android:viewportHeight="24">
|
||||
|
||||
<path
|
||||
android:pathData="M12,3L1,9l11,6 9,-4.91V17h2V9L12,3z"
|
||||
android:fillColor="?attr/colorControlNormal"/>
|
||||
android:fillColor="#FF000000"/>
|
||||
|
||||
<path
|
||||
android:pathData="M5,12.18V17c0,2.21 3.58,4 7,4s7,-1.79 7,-4v-4.82l-7,3.82 -7,-3.82z"
|
||||
android:fillColor="?attr/colorControlNormal"/>
|
||||
android:fillColor="#FF000000"/>
|
||||
</vector>
|
||||
@@ -13,7 +13,6 @@ import ru.fincode.tsudesk.core.database.api.schedule.ScheduleDao
|
||||
LessonCacheEntity::class
|
||||
],
|
||||
version = 2,
|
||||
exportSchema = true
|
||||
)
|
||||
@TypeConverters(StringListConverter::class)
|
||||
abstract class AppDatabase : RoomDatabase() {
|
||||
|
||||
@@ -0,0 +1,9 @@
|
||||
package ru.fincode.core.ui.components
|
||||
|
||||
import androidx.compose.ui.graphics.vector.ImageVector
|
||||
|
||||
data class BottomBarItem(
|
||||
val key: String,
|
||||
val label: String,
|
||||
val icon: ImageVector,
|
||||
)
|
||||
@@ -1,17 +1,11 @@
|
||||
package ru.fincode.core.ui.components
|
||||
|
||||
import androidx.compose.material3.Icon
|
||||
import androidx.compose.material3.MaterialTheme
|
||||
import androidx.compose.material3.NavigationBar
|
||||
import androidx.compose.material3.NavigationBarItem
|
||||
import androidx.compose.material3.Text
|
||||
import androidx.compose.runtime.Composable
|
||||
import androidx.compose.ui.graphics.painter.Painter
|
||||
|
||||
data class BottomBarItem(
|
||||
val key: String,
|
||||
val label: String,
|
||||
val icon: Painter,
|
||||
)
|
||||
|
||||
@Composable
|
||||
fun TsudeskBottomBar(
|
||||
@@ -21,19 +15,22 @@ fun TsudeskBottomBar(
|
||||
) {
|
||||
NavigationBar {
|
||||
items.forEach { item ->
|
||||
val selected = item.key == selectedKey
|
||||
|
||||
NavigationBarItem(
|
||||
selected = item.key == selectedKey,
|
||||
selected = selected,
|
||||
onClick = { onItemClick(item) },
|
||||
icon = {
|
||||
Icon(
|
||||
painter = item.icon,
|
||||
contentDescription = item.label
|
||||
imageVector = item.icon,
|
||||
contentDescription = item.label,
|
||||
tint = if (selected)
|
||||
MaterialTheme.colorScheme.primary
|
||||
else
|
||||
MaterialTheme.colorScheme.onSurfaceVariant
|
||||
)
|
||||
},
|
||||
label = {
|
||||
Text(text = item.label)
|
||||
},
|
||||
alwaysShowLabel = true
|
||||
label = { Text(item.label) }
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -9,7 +9,7 @@ import java.util.Locale
|
||||
class NewsHtmlParser {
|
||||
|
||||
private val dateFormatter =
|
||||
DateTimeFormatter.ofPattern("dd.MM.yyyy", Locale("ru"))
|
||||
DateTimeFormatter.ofPattern("dd.MM.yyyy", Locale.forLanguageTag("ru"))
|
||||
|
||||
fun parseArchivePage(html: String): List<NewsItem> {
|
||||
val itemRegex = Regex(
|
||||
|
||||
@@ -3,7 +3,7 @@ package ru.fincode.tsudesk.feature.schedule.data.remote
|
||||
object ScheduleApiContract {
|
||||
|
||||
object Path {
|
||||
const val GET_SCHEDULE_METHOD = "GetSchedule.php"
|
||||
const val GET_SCHEDULE_METHOD = "schedule/queries/GetSchedule.php"
|
||||
}
|
||||
|
||||
object Query {
|
||||
|
||||
@@ -1,18 +1,25 @@
|
||||
package ru.fincode.tsudesk.feature.schedule.presentation.navigation
|
||||
|
||||
import androidx.compose.ui.Modifier
|
||||
import androidx.navigation.NavGraphBuilder
|
||||
import androidx.navigation.compose.composable
|
||||
import ru.fincode.tsudesk.core.navigation.AppRoute
|
||||
import ru.fincode.tsudesk.feature.schedule.presentation.screen.ScheduleRoute
|
||||
|
||||
fun NavGraphBuilder.scheduleGraph(
|
||||
modifier: Modifier = Modifier,
|
||||
// на будущее:
|
||||
// onOpenDetails: (lessonId: Long) -> Unit,
|
||||
) {
|
||||
composable<AppRoute.Schedule> {
|
||||
ScheduleRoute()
|
||||
ScheduleRoute(
|
||||
modifier = modifier,
|
||||
// onOpenDetails = onOpenDetails
|
||||
)
|
||||
}
|
||||
|
||||
// composable<AppRoute.ScheduleDetails> { backStackEntry ->
|
||||
// val args = backStackEntry.toRoute<AppRoute.ScheduleDetails>()
|
||||
// composable<AppRoute.ScheduleDetails> { entry ->
|
||||
// val args = entry.toRoute<AppRoute.ScheduleDetails>()
|
||||
// ScheduleDetailsRoute(lessonId = args.lessonId)
|
||||
// }
|
||||
}
|
||||
@@ -1,4 +1,4 @@
|
||||
package ru.fincode.tsudesk.feature.schedule.presentation
|
||||
package ru.fincode.tsudesk.feature.schedule.presentation.screen
|
||||
|
||||
sealed interface ScheduleAction {
|
||||
|
||||
Reference in New Issue
Block a user