Ssylka

Decompose: создание гибкой навигации по вкладкам

В статье рассматривается реализация навигации по вкладкам с использованием Compose, Kotlin Multiplatform, Decompose и Model-View-Intent. Ключевым моментом является разделение логики навигации от UI, что достигается за счёт Decompose. Это позволяет создавать переиспользуемые компоненты, гибко настраивать внешний вид вкладок и их контента, а также поддерживать произвольную компоновку.
Decompose: создание гибкой навигации по вкладкам
Изображение носит иллюстративный характер

Предлагаемая реализация навигации включает возможность выбора активной вкладки, перемещения вкладок с анимацией, закрытия вкладок с освобождением ресурсов и поддержку произвольных конфигураций для компонентов. При этом обеспечивается полная независимость от типов слотов, позволяя отображать как простые элементы, так и сложные редакторы файлов или просмотрщики изображений. Центральным элементом архитектуры является контейнер, который управляет жизненным циклом вкладок и их состоянием.

Для управления состояниями используется библиотека Decompose, позволяющая отслеживать изменения вкладок и обеспечивать их правильную реакцию на действия пользователя. Состояние вкладок, включая их порядок, выбранный индекс и сами компоненты, хранится в классе NavigationState. Этот класс также содержит информацию о жизненном цикле дочерних компонентов, позволяя при активации конкретной вкладки запускать соответствующий компонент, а при переключении в другую – ставить предыдущий на паузу. Кроме того, имеется механизм сохранения состояния и возможность отката по кнопке «назад».

Для настройки UI используются @Composable-функции, которые принимают на вход лямбды для рендеринга содержимого вкладок и контейнера. Таким образом, достигается возможность кастомизировать внешний вид элементов. Для вкладок можно задать свой дизайн кнопок, заголовков и т. д. Содержимое выбранного слота также может быть настроено независимо. Общий подход заключается в разделении логики от UI, чтобы сделать приложение более гибким и расширяемым.


Новое на сайте

19159Академическое фиаско Дороти Паркер в Лос-Анджелесе 19158Китайский шпионский фреймворк DKnife захватывает роутеры с 2019 года 19157Каким образом корейские детские хоры 1950-х годов превратили геополитику в музыку и... 19156Научная революция цвета в женской моде викторианской эпохи 19155Как новый сканер Microsoft обнаруживает «спящих агентов» в открытых моделях ИИ? 19154Как новая кампания DEADVAX использует файлы VHD для скрытой доставки трояна AsyncRAT? 19153Как новые китайские киберкампании взламывают госструктуры Юго-Восточной Азии? 19152Культ священного манго и закат эпохи хунвейбинов в маоистском Китае 19151Готовы ли вы к эре коэффициента адаптивности, когда IQ и EQ больше не гарантируют успех? 19150Иранская группировка RedKitten применяет сгенерированный нейросетями код для кибершпионажа 19149Как новая волна голосового фишинга в стиле ShinyHunters обходит многофакторную... 19148Почему баски стали главными пастухами Америки: врожденный дар или расовый миф? 19147Бывший инженер Google осужден за экономический шпионаж и передачу секретов искусственного... 19146Насколько критичны новые уязвимости SmarterMail и почему их немедленное исправление... 19145Истинный контроль и природа человеческого мастерства: от учения эпиктета до современной...