что. :)
Как бы по вашему мнению бы следовало решать навигацию между экранами?
Нынешняя архитектура - мввм со стэйтами, навигация на основании состояния запускается через вью модели.
У коллеги возникла идея передвинуть переходы (через интерфейс, разумеется) на бизнес уровень, прям в юз кейс. Аргументирует это тем, что переходы между экранами/окнами на всех платформах, мол, одинаковые, это часть бизнес логики, куда после чего идти, а вьюмодел только стэйт пусть помогает отображать.
А бизнес логике разве важно на каком экране что отображается?
В том-то и дело, что все привыкли считать, что нет. Я тоже так считаю, спорим вот. С другой стороны, вью модели в идеале не должны ничего знать о других экранах. Вот и спрашиваю, интересно, как другие это решают. :)
роутинг является бизнес логикой, и как раз таки роутеры могут быть вынесены.
Это понятно, вопрос на каком уровне их объединить. Я бы сделала отдельно роутер и отдельно юз кейс для данных, мерджнула их во вью модели. Он же, получается, роутер в юз кейс засунул, грубо говоря.
На мой взгляд юз кейс не должен знать про роутинг, сам роутинг может быть следствием юз кейс, но не в жёсткой с ним связке. Имхо, поместить роутер и юзкейс/интерактор во вью модель это окей
Спасибо. :) Теперь, надеюсь, будем спорить, как именно их объединять, но это уже совсем другая история.
А роутер в виде activity уже не модно нынче применять? Через колбэк с фрагмента отправлять код события и пусть activity решает что делать дальше
Роутинг лучше всего выполнять на Presentation слое (не на domain). Потому что навигация относится больше к инфраструктуре, чем к бизнес правилам. И лучше его делать через делегирующий объект
Наверное это очень просто гуглится, если знать как гуглить, но. Не могли бы поделиться ссылкой на код, где навигация сделана посредством делегирующего объекта, пожалуйста?
Это было бы удобно, если бы приложение было с одной активити. Сейчас же оно поделено на фичур модули, у каждого своя активити. Я бы даже не колбэк посылала, а ивент бас какой, и в активити бы на него подписалась. Только не очень представляю, как это делать с большим количеством активити, я привыкла к архитектуре с одной мэйн (ну, и логин там какой или регистрация отдельно со своей навигацией).
Вообще, именно это является основной причиной спора. Мне тоже кажется, что навигация - это просто инфраструктура. Оппонент же утверждает, что с точки зрения бизнеса *важно*, куда пользователь перейдет после того или иного действия, более того, на всех платформах переходы в принципе будут одинаковые, потому что так этого хочет бизнес. И, мол, если когда-нибудь бы перейдем на KMM (даже речи быть не может, как по мне, это решение надо было принимать год назад), то у нас уже всё будет готово, в том числе общая навигация.
А потом придут дезигнеры и нарисуют новую красивую навигацию. И можно будет переделывать бизнес-логику 😁
если у Вас бизнесу важно как происходит навигация - значит у Вас некорректно выделены слои. Так как домен может быть переиспользован между несколькими приложениями
Обсуждают сегодня