Add bookscreen

This commit is contained in:
2025-12-05 18:52:09 +07:00
parent b81bc48de5
commit 262573b71e
4 changed files with 191 additions and 5 deletions

View File

@@ -15,6 +15,7 @@ import ru.myitschool.work.ui.nav.AuthScreenDestination
import ru.myitschool.work.ui.nav.BookScreenDestination import ru.myitschool.work.ui.nav.BookScreenDestination
import ru.myitschool.work.ui.nav.MainScreenDestination import ru.myitschool.work.ui.nav.MainScreenDestination
import ru.myitschool.work.ui.screen.auth.AuthScreen import ru.myitschool.work.ui.screen.auth.AuthScreen
import ru.myitschool.work.ui.screen.book.BookScreen
@Composable @Composable
fun AppNavHost( fun AppNavHost(
@@ -39,11 +40,17 @@ fun AppNavHost(
} }
} }
composable<BookScreenDestination> { composable<BookScreenDestination> {
Box( BookScreen(
contentAlignment = Alignment.Center selectedDateIndex = 0,
) { onDateClick = {},
Text(text = "Hello") //selectedPlaceIndex = null,
} //onPlaceSelect = {},
error = null,
isEmpty = false,
onRefresh = {},
onBack = { navController.popBackStack() },
onBook = {}
)
} }
} }
} }

View File

@@ -0,0 +1,172 @@
package ru.myitschool.work.ui.screen.book
import android.R
import androidx.annotation.ColorRes
import androidx.compose.foundation.background
import androidx.compose.foundation.border
import androidx.compose.foundation.clickable
import androidx.compose.foundation.horizontalScroll
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.width
import androidx.compose.foundation.rememberScrollState
import androidx.compose.foundation.selection.selectable
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material3.Button
import androidx.compose.material3.ButtonDefaults
import androidx.compose.material3.CheckboxDefaults.colors
import androidx.compose.material3.RadioButton
import androidx.compose.material3.RadioButtonDefaults
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.collectAsState
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.platform.testTag
import androidx.compose.ui.text.style.TextAlign
import androidx.compose.ui.unit.dp
import androidx.lifecycle.viewmodel.compose.viewModel
import androidx.navigation.NavController
import ru.myitschool.work.core.TestIds
import ru.myitschool.work.ui.nav.MainScreenDestination
import ru.myitschool.work.ui.screen.auth.AuthState
import ru.myitschool.work.ui.screen.auth.AuthViewModel
@Composable
fun BookScreen(
dates: List<String> = listOf("19.04", "20.04", "21.04", "22.04"),
selectedDateIndex: Int,
onDateClick: (Int) -> Unit,
places: List<String> = listOf(
"Рабочее место у окна",
"Переговорная комната №1",
"Коворкинг A"
),
myColor: Color = Color(0xFF0090FF),
error: String?,
isEmpty: Boolean,
onRefresh: () -> Unit,
onBack: () -> Unit,
onBook: () -> Unit
) {
// Локальное состояние выбранного места
var selectedPlaceIndex by remember { mutableStateOf<Int?>(null) }
Column(
modifier = Modifier
.fillMaxSize()
.padding(16.dp)
) {
Button(
modifier = Modifier.testTag(TestIds.Book.BACK_BUTTON),
onClick = onBack,
colors = ButtonDefaults.buttonColors( containerColor = myColor ),
)
{Text("Назад")}
// Горизонтальные даты
Row(
modifier = Modifier
.horizontalScroll(rememberScrollState())
.padding(top = 16.dp)
) {
dates.forEachIndexed { index, date ->
Box(
modifier = Modifier
.width(60.dp)
.height(40.dp)
.border(
width = 2.dp,
color = if (index == selectedDateIndex) myColor else Color.LightGray,
shape = RoundedCornerShape(6.dp)
)
.background(Color.White, RoundedCornerShape(6.dp))
.clickable { onDateClick(index) }
.padding(8.dp)
) {
Text(
text = date,
modifier = Modifier.align(Alignment.Center),
textAlign = TextAlign.Center
)
}
Spacer(modifier = Modifier.width(8.dp))
}
}
Spacer(Modifier.height(20.dp))
// Места
Column {
places.forEachIndexed { index, place ->
Row(
verticalAlignment = Alignment.CenterVertically,
horizontalArrangement = Arrangement.SpaceBetween,
modifier = Modifier
.fillMaxWidth()
.padding(12.dp)
) {
Text(place)
RadioButton(
selected = selectedPlaceIndex == index,
onClick = { selectedPlaceIndex = index },
colors = RadioButtonDefaults.colors(
selectedColor = myColor,
unselectedColor = Color.Gray
)
)
}
}
}
if (error != null) {
Text(
text = error,
color = Color.Red,
modifier = Modifier.padding(top = 8.dp).testTag(TestIds.Book.ERROR)
)
}
if (isEmpty) {
Text(
text = "Всё забронировано",
modifier = Modifier.padding(top = 12.dp).testTag(TestIds.Book.EMPTY)
)
Button(
onClick = onRefresh,
modifier = Modifier.padding(top = 12.dp).testTag(TestIds.Book.REFRESH_BUTTON),
colors = ButtonDefaults.buttonColors( containerColor = myColor )
) {
Text("Обновить")
}
}
Button(
onClick = onBook,
modifier = Modifier
.fillMaxWidth()
.padding(top = 20.dp),
colors = ButtonDefaults.buttonColors( containerColor = myColor )
) {
Text("Забронировать")
}
}
}

View File

@@ -0,0 +1,6 @@
package ru.myitschool.work.ui.screen.book;
import android.app.Application;
class BookViewModel {
}

View File

@@ -7,4 +7,5 @@
<color name="teal_700">#FF018786</color> <color name="teal_700">#FF018786</color>
<color name="black">#FF000000</color> <color name="black">#FF000000</color>
<color name="white">#FFFFFFFF</color> <color name="white">#FFFFFFFF</color>
<color name="primary_blue">#517DFF</color>
</resources> </resources>