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

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

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

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

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


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

19209Как беспрецедентный бунт чернокожих женщин в суде Бостона разрушил планы рабовладельцев? 19208Как новые поколения троянов удаленного доступа захватывают системы ради кибершпионажа и... 19207Почему мировые киберпреступники захватили рекламные сети, и как Meta вместе с властями... 19206Как фальшивый пакет StripeApi.Net в NuGet Gallery незаметно похищал финансовые API-токены... 19205Зачем неизвестная группировка UAT-10027 внедряет бэкдор Dohdoor в системы образования и... 19204Ритуальный предсвадебный плач как форма протеста в традиционном Китае 19203Невидимая угроза в оперативной памяти: масштабная атака северокорейских хакеров на... 19202Как уязвимость нулевого дня в Cisco SD-WAN позволяет хакерам незаметно захватывать... 19201Как Google разрушил глобальную шпионскую сеть UNC2814, охватившую правительства 70 стран... 19200Как простое открытие репозитория в Claude Code позволяет хакерам получить полный контроль... 19199Зачем киберсиндикат SLH платит женщинам до 1000 долларов за один телефонный звонок в... 19198Устранение слепых зон SOC: переход к доказательной сортировке угроз для защиты бизнеса 19197Скрытые бэкдоры в цепочках поставок по: атаки через вредоносные пакеты NuGet и npm
Ссылка