TokenResponse rework
This commit is contained in:
@@ -1,17 +0,0 @@
|
||||
<![CDATA[
|
||||
<WORK_ORDER>
|
||||
<METADATA>
|
||||
<ID>enrichment-task-001</ID>
|
||||
<TITLE>Perform initial semantic enrichment</TITLE>
|
||||
<ROLE_TARGET>agent-enrichment</ROLE_TARGET>
|
||||
<TYPE>type::enrichment</TYPE>
|
||||
<STATUS>status::pending</STATUS>
|
||||
</METADATA>
|
||||
<TASK_BODY>
|
||||
<ENRICHMENT_TASK>
|
||||
<SCOPE>full_project</SCOPE>
|
||||
<TARGET></TARGET>
|
||||
</ENRICHMENT_TASK>
|
||||
</TASK_BODY>
|
||||
</WORK_ORDER>
|
||||
]]>
|
||||
@@ -1,6 +0,0 @@
|
||||
<![CDATA[
|
||||
<ENRICHMENT_TASK>
|
||||
<SCOPE>directory</SCOPE>
|
||||
<TARGET>app/src/main/java/com/homebox/lens/ui</TARGET>
|
||||
</ENRICHMENT_TASK>
|
||||
]]>
|
||||
@@ -1,51 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<WORK_ORDER>
|
||||
<META>
|
||||
<ID>WO-ITEMEDIT-FIX</ID>
|
||||
<TITLE>[ARCHITECT -> DEV] Исправление выбора локации и меток на экране ItemEdit</TITLE>
|
||||
<DESCRIPTION>В текущей реализации на экране редактирования/создания элемента (ItemEditScreen) поля "Location" и "Labels" неактивны. Необходимо реализовать функционал выбора значения для этих полей из списка доступных.</DESCRIPTION>
|
||||
<CREATED_BY>architect-agent</CREATED_BY>
|
||||
<ASSIGNED_TO>developer-agent</ASSIGNED_TO>
|
||||
<STATUS>pending</STATUS>
|
||||
</META>
|
||||
|
||||
<TASK_BREAKDOWN>
|
||||
<STEP n="1" file="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditViewModel.kt">
|
||||
<ACTION>Загрузка списков локаций и меток.</ACTION>
|
||||
<DETAILS>
|
||||
1. Внедрите `GetAllLocationsUseCase` и `GetAllLabelsUseCase` в `ItemEditViewModel`.
|
||||
2. Обновите `ItemEditUiState`, добавив два новых поля: `val allLocations: List<Location> = emptyList()` и `val allLabels: List<Label> = emptyList()`.
|
||||
3. В функции `loadItem`, после загрузки основной информации о товаре, вызовите `getAllLocationsUseCase` и `getAllLabelsUseCase` и обновите `uiState` полученными списками.
|
||||
4. Добавьте публичные методы `updateLocation(location: Location)` и `updateLabels(labels: List<Label>)` для обновления `item` в `uiState`.
|
||||
</DETAILS>
|
||||
</STEP>
|
||||
|
||||
<STEP n="2" file="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditScreen.kt">
|
||||
<ACTION>Реализация UI для выбора локации.</ACTION>
|
||||
<DETAILS>
|
||||
1. Замените `OutlinedTextField` для локации на `ExposedDropdownMenuBox`.
|
||||
2. В качестве `dropdownMenu` используйте `DropdownMenuItem` для каждого элемента из `uiState.allLocations`.
|
||||
3. При выборе элемента из списка вызывайте `viewModel.updateLocation(selectedLocation)`.
|
||||
4. В `ExposedDropdownMenuBox` должно отображаться `item.location?.name`.
|
||||
</DETAILS>
|
||||
</STEP>
|
||||
|
||||
<STEP n="3" file="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditScreen.kt">
|
||||
<ACTION>Реализация UI для выбора меток (множественный выбор).</ACTION>
|
||||
<DETAILS>
|
||||
1. Поле для меток `Labels` должно оставаться `OutlinedTextField` (read-only), но `onClick` по нему должен открывать диалоговое окно (`AlertDialog`).
|
||||
2. В `AlertDialog` отобразите список всех меток (`uiState.allLabels`) с `Checkbox`'ами.
|
||||
3. Состояние `Checkbox`'ов должно соответствовать списку `item.labels`.
|
||||
4. При нажатии на "OK" в диалоге, вызывайте `viewModel.updateLabels(selectedLabels)`.
|
||||
</DETAILS>
|
||||
</STEP>
|
||||
</TASK_BREAKDOWN>
|
||||
|
||||
<ACCEPTANCE_CRITERIA>
|
||||
<CRITERION>При нажатии на поле "Location" открывается выпадающий список со всеми локациями.</CRITERION>
|
||||
<CRITERION>Выбранная локация отображается в поле и сохраняется вместе с элементом.</CRITERION>
|
||||
<CRITERION>При нажатии на поле "Labels" открывается диалоговое окно со списком всех меток и чекбоксами.</CRITERION>
|
||||
<CRITERION>Выбранные метки отображаются в поле и сохраняются вместе с элементом.</CRITERION>
|
||||
</ACCEPTANCE_CRITERIA>
|
||||
|
||||
</WORK_ORDER>
|
||||
@@ -1,59 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<WORK_ORDER>
|
||||
<META>
|
||||
<ID>WO-LOGIN-REFACTOR</ID>
|
||||
<TITLE>[ARCHITECT -> DEV] Рефакторинг экрана входа и логики первого запуска</TITLE>
|
||||
<DESCRIPTION>Цель этой задачи - изменить логику запуска приложения. Экран входа (SetupScreen) должен появляться только при первом запуске, когда учетные данные еще не сохранены. В последующие запуски пользователь должен сразу попадать на главный экран (Dashboard). Также необходимо улучшить визуальное оформление экрана входа.</DESCRIPTION>
|
||||
<CREATED_BY>architect-agent</CREATED_BY>
|
||||
<ASSIGNED_TO>developer-agent</ASSIGNED_TO>
|
||||
<STATUS>pending</STATUS>
|
||||
</META>
|
||||
|
||||
<TASK_BREAKDOWN>
|
||||
<STEP n="1" file="app/src/main/java/com/homebox/lens/ui/screen/setup/SetupViewModel.kt">
|
||||
<ACTION>Добавить public-метод для синхронной проверки наличия учетных данных.</ACTION>
|
||||
<DETAILS>
|
||||
Добавьте в класс `SetupViewModel` новый метод `fun areCredentialsSaved(): Boolean`.
|
||||
Этот метод должен синхронно проверять, сохранены ли учетные данные в `CredentialsRepository`.
|
||||
Текущая реализация `getCredentials()` асинхронна, что не подходит для быстрой проверки в `NavGraph`.
|
||||
Вам может потребоваться изменить `CredentialsRepository` для поддержки синхронной проверки (например, используя `SharedPreferences` напрямую).
|
||||
</DETAILS>
|
||||
</STEP>
|
||||
|
||||
<STEP n="2" file="app/src/main/java/com/homebox/lens/ui/screen/splash/SplashScreen.kt">
|
||||
<ACTION>Создать новый `SplashScreen`.</ACTION>
|
||||
<DETAILS>
|
||||
Создайте новый Composable-экран `SplashScreen.kt`.
|
||||
Этот экран будет новой точкой входа в `NavGraph`.
|
||||
Он будет использовать `SetupViewModel` для вызова `areCredentialsSaved()` и, в зависимости от результата, немедленно навигироваться либо на `Screen.Setup`, либо на `Screen.Dashboard`.
|
||||
Пока идет проверка, на экране должен отображаться `CircularProgressIndicator`.
|
||||
</DETAILS>
|
||||
</STEP>
|
||||
|
||||
<STEP n="3" file="app/src/main/java/com/homebox/lens/navigation/NavGraph.kt">
|
||||
<ACTION>Обновить `NavGraph` для использования `SplashScreen`.</ACTION>
|
||||
<DETAILS>
|
||||
Измените `startDestination` в `NavHost` на `Screen.Splash.route`.
|
||||
Добавьте `composable` для `SplashScreen`.
|
||||
В `SplashScreen` вызовите `navController.navigate` с очисткой бэкстека (`popUpTo(Screen.Splash.route) { inclusive = true }`), чтобы пользователь не мог вернуться на сплэш-экран.
|
||||
</DETAILS>
|
||||
</STEP>
|
||||
|
||||
<STEP n="4" file="app/src/main/java/com/homebox/lens/ui/screen/setup/SetupScreen.kt">
|
||||
<ACTION>Улучшить UI экрана `SetupScreen`.</ACTION>
|
||||
<DETAILS>
|
||||
Текущий UI слишком прост. Добавьте заголовок, иконку приложения, и более приятное расположение элементов.
|
||||
Используйте `Card` для группировки полей ввода. Добавьте `Spacer` для лучшего отступа.
|
||||
Кнопку "Connect" сделайте более заметной.
|
||||
</DETAILS>
|
||||
</STEP>
|
||||
|
||||
</TASK_BREAKDOWN>
|
||||
|
||||
<ACCEPTANCE_CRITERIA>
|
||||
<CRITERION>При первом запуске приложения открывается `SetupScreen`.</CRITERION>
|
||||
<CRITERION>После успешного ввода данных и входа, при последующих перезапусках приложения открывается `DashboardScreen`, минуя `SetupScreen`.</CRITERION>
|
||||
<CRITERION>`SetupScreen` имеет улучшенный и более привлекательный дизайн.</CRITERION>
|
||||
</ACCEPTANCE_CRITERIA>
|
||||
|
||||
</WORK_ORDER>
|
||||
Reference in New Issue
Block a user