feat: Refactor login screen - fix compilation error

This commit is contained in:
2025-10-02 13:11:49 +03:00
parent 8816377361
commit eccc7ee970
21 changed files with 494 additions and 174 deletions

View File

@@ -1,98 +1,51 @@
<![CDATA[
<?xml version="1.0" encoding="UTF-8"?>
<WORK_ORDER>
<META>
<VERSION>1.0</VERSION>
<CREATED_AT>{timestamp}</CREATED_AT>
<TITLE>[ARCHITECT -> DEV] Refactor Item Edit Screen</TITLE>
<DESCRIPTION>
This work order instructs the developer agent to refactor the Item Edit screen to include all available API fields and implement a user-friendly, grouped layout.
</DESCRIPTION>
<ASSIGNED_TO>agent-developer</ASSIGNED_TO>
<LABELS>type::refactoring,feature::item-edit,status::pending</LABELS>
<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>
<SPECIFICATION>
<GOAL>
The primary goal is to refactor the `ItemEditScreen` to include all available fields from the Homebox API for creating and updating items, and to present them in a user-friendly manner.
</GOAL>
<CONTEXT>
<FILE_LIST>
<FILE path="domain/src/main/java/com/homebox/lens/domain/model/Item.kt" />
<FILE path="data/src/main/java/com/homebox/lens/data/db/entity/ItemEntity.kt" />
<FILE path="data/src/main/java/com/homebox/lens/data/api/dto/ItemCreateDto.kt" />
<FILE path="data/src/main/java/com/homebox/lens/data/api/dto/ItemUpdateDto.kt" />
<FILE path="data/src/main/java/com/homebox/lens/data/api/dto/ItemOutDto.kt" />
<FILE path="data/src/main/java/com/homebox/lens/data/db/entity/Mapper.kt" />
<FILE path="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditViewModel.kt" />
<FILE path="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditScreen.kt" />
</FILE_LIST>
</CONTEXT>
</SPECIFICATION>
<EXECUTION_PLAN>
<STEP id="1" name="Update Domain Model">
<ACTION>Modify `domain/src/main/java/com/homebox/lens/domain/model/Item.kt`.</ACTION>
<TASK_BREAKDOWN>
<STEP n="1" file="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditViewModel.kt">
<ACTION>Загрузка списков локаций и меток.</ACTION>
<DETAILS>
- Add the following fields to the `Item` data class:
- `archived: Boolean`
- `assetId: String?`
- `fields: List<CustomField>`
- `insured: Boolean`
- `lifetimeWarranty: Boolean`
- `manufacturer: String?`
- `modelNumber: String?`
- `notes: String?`
- `parentId: String?`
- `purchaseFrom: String?`
- `purchaseTime: String?`
- `serialNumber: String?`
- `soldNotes: String?`
- `soldPrice: Double?`
- `soldTime: String?`
- `soldTo: String?`
- `syncChildItemsLocations: Boolean`
- `warrantyDetails: String?`
- `warrantyExpires: String?`
- Rename the existing `value: BigDecimal?` field to `purchasePrice: Double?`.
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 id="2" name="Update Data Layer">
<ACTION>Update database entity, DTOs, and mappers.</ACTION>
<STEP n="2" file="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditScreen.kt">
<ACTION>Реализация UI для выбора локации.</ACTION>
<DETAILS>
- Modify `data/src/main/java/com/homebox/lens/data/db/entity/ItemEntity.kt` to reflect the new `Item` model.
- Ensure `ItemCreateDto`, `ItemUpdateDto`, and `ItemOutDto` contain all necessary fields according to the API spec.
- Update the mapping functions in `data/src/main/java/com/homebox/lens/data/db/entity/Mapper.kt` to handle all new fields correctly across all layers.
1. Замените `OutlinedTextField` для локации на `ExposedDropdownMenuBox`.
2. В качестве `dropdownMenu` используйте `DropdownMenuItem` для каждого элемента из `uiState.allLocations`.
3. При выборе элемента из списка вызывайте `viewModel.updateLocation(selectedLocation)`.
4. В `ExposedDropdownMenuBox` должно отображаться `item.location?.name`.
</DETAILS>
</STEP>
<STEP id="3" name="Update ViewModel">
<ACTION>Modify `app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditViewModel.kt`.</ACTION>
<STEP n="3" file="app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditScreen.kt">
<ACTION>Реализация UI для выбора меток (множественный выбор).</ACTION>
<DETAILS>
- Update `loadItem` and `saveItem` to handle the state for all new fields.
- Add public functions to update the state for each new field (e.g., `updateManufacturer(String)`, `toggleInsured(Boolean)`).
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>
<STEP id="4" name="Implement UI">
<ACTION>Refactor `app/src/main/java/com/homebox/lens/ui/screen/itemedit/ItemEditScreen.kt`.</ACTION>
<DETAILS>
- Implement a user-friendly layout using tabs or expandable cards for the following groups: General, Purchase, Warranty, Identification, Status & Notes.
- Use appropriate controls for each field type (e.g., `Switch` for booleans, Date Picker for dates).
- Connect all UI controls to the ViewModel.
- Implement basic input validation.
</DETAILS>
</STEP>
</EXECUTION_PLAN>
<ACCEPTANCE_CRITERIA>
<CRITERION>При нажатии на поле "Location" открывается выпадающий список со всеми локациями.</CRITERION>
<CRITERION>Выбранная локация отображается в поле и сохраняется вместе с элементом.</CRITERION>
<CRITERION>При нажатии на поле "Labels" открывается диалоговое окно со списком всех меток и чекбоксами.</CRITERION>
<CRITERION>Выбранные метки отображаются в поле и сохраняются вместе с элементом.</CRITERION>
</ACCEPTANCE_CRITERIA>
<VERIFICATION>
<CHECK>The application compiles successfully.</CHECK>
<CHECK>The Item Edit screen displays all new fields, grouped logically.</CHECK>
<CHECK>Creating a new item with all fields populated works correctly.</CHECK>
<CHECK>Editing an existing item and modifying the new fields works correctly.</CHECK>
<CHECK>Data is persisted correctly and is visible in the Item Details screen after saving.</CHECK>
</VERIFICATION>
</WORK_ORDER>
]]>
</WORK_ORDER>