Forwarded from Kotlin Multiplatform Broadcast (Кирилл Розов)
Статья (EN, 4 мин) про разные сценарии использования sealed class и sealed interface с примерами. Иногда спрашивал такое на собесах и часть людей не отвечала
Forwarded from Android Good Reads (Egor Tolstoy)
План Coil по поддержке Kotlin Multiplatform
Я уже упоминал, что недавно библиотека Coil получила грант от Kotlin Foundation направленный на поддержку KMP.
Вышел блогпост, где автор раскрывает больше деталей про миграцию. Основная задача переезда – полностью отвязать Coil от Android. Самым большим изменением API будет замена
План – завершить миграцию в течение нескольких месяцев.
Я уже упоминал, что недавно библиотека Coil получила грант от Kotlin Foundation направленный на поддержку KMP.
Вышел блогпост, где автор раскрывает больше деталей про миграцию. Основная задача переезда – полностью отвязать Coil от Android. Самым большим изменением API будет замена
Drawable на Image, который абстрагирует детали платформенной реализации изображений.План – завершить миграцию в течение нескольких месяцев.
Cash App Code Blog
Multiplatform image loading: Coil 3.0
Building towards Coil 3.0 with a focus on Compose Multiplatform.
👍4🔥2🤔1
Forwarded from Mobile Native ️️
Learn Kotlin Flow by real examples for Android
Проект с примерами для изучения Kotlin Flow.
• How to use Kotlin Flow in Android Project?
• Doing simple task in background using Kotlin Flow.
• Doing tasks in series using Kotlin Flow.
• Doing tasks in parallel using Kotlin Flow. Blog
• Making two network calls in parallel using Kotlin Flow.
• Using operators like filter, map, reduce, flatMapConcat, zip, and etc.
• Exception handling in Kotlin Flow
• How to use onCompletion in Flow?
• Retry Task using retry operator in Flow.
• Retry Task with Exponential Backoff in Flow.
• Using Kotlin Flow with Retrofit. Blog
• Using Kotlin Flow with Room Database. Blog
• Using Kotlin Flow with various 3rd party libraries.
• Making two network calls in parallel using Kotlin Flow.
• Doing task in series using Kotlin Flow.
• Writing Unit-Test for ViewModel which uses Kotlin Flow
• Flow and StateFlow
GitHub → Learn-Kotlin-Flow
Проект с примерами для изучения Kotlin Flow.
• How to use Kotlin Flow in Android Project?
• Doing simple task in background using Kotlin Flow.
• Doing tasks in series using Kotlin Flow.
• Doing tasks in parallel using Kotlin Flow. Blog
• Making two network calls in parallel using Kotlin Flow.
• Using operators like filter, map, reduce, flatMapConcat, zip, and etc.
• Exception handling in Kotlin Flow
• How to use onCompletion in Flow?
• Retry Task using retry operator in Flow.
• Retry Task with Exponential Backoff in Flow.
• Using Kotlin Flow with Retrofit. Blog
• Using Kotlin Flow with Room Database. Blog
• Using Kotlin Flow with various 3rd party libraries.
• Making two network calls in parallel using Kotlin Flow.
• Doing task in series using Kotlin Flow.
• Writing Unit-Test for ViewModel which uses Kotlin Flow
• Flow and StateFlow
GitHub → Learn-Kotlin-Flow
🔥3👍2🤓1
Forwarded from Стой под стрелой (Nikita Prokopov)
Когда Реддит прибил сторонние клиенты, и в том числе Аполло, СЕО Реддита объяснил это так: не, ну а чо они на нашем АПИ сидят, гребут деньги лопатой, а нам не отдают? У нас 50 программистов, их тоже чем-то кормить надо.
На что вроде бы очевидный ответ: так сделайте тоже нормального клиента и гребите эти деньги себе? В чем проблема?
А проблема в том, что того, что хватает одному программисту, не хватит, чтобы прокормить 50. Вот и получается, что у одного есть возможность делать удобно и хорошо для пользователей, а у пятидесяти такой возможности нет.
Поэтому я всегда стараюсь работать в маленьких командах. Большие это что-то про то, как кого-нибудь наебать, развести или еще каким-то способом отжать деньги, причем желательно сразу много. А маленькие могут себе позволить на самом деле уменьшать энтропию и вообще работать на пользователя.
Хотя казалось бы, 50 программистов, звучит так, что это должно быть лучше, чем один. Но нет. Парадокс.
На что вроде бы очевидный ответ: так сделайте тоже нормального клиента и гребите эти деньги себе? В чем проблема?
А проблема в том, что того, что хватает одному программисту, не хватит, чтобы прокормить 50. Вот и получается, что у одного есть возможность делать удобно и хорошо для пользователей, а у пятидесяти такой возможности нет.
Поэтому я всегда стараюсь работать в маленьких командах. Большие это что-то про то, как кого-нибудь наебать, развести или еще каким-то способом отжать деньги, причем желательно сразу много. А маленькие могут себе позволить на самом деле уменьшать энтропию и вообще работать на пользователя.
Хотя казалось бы, 50 программистов, звучит так, что это должно быть лучше, чем один. Но нет. Парадокс.
🤔3👍2
Forwarded from Локалхост (Никита Куликов)
Вчера прозоишло одно из важнейших событий для Flipper Zero и для меня - релиз Apps Catalog.
Теперь больше сотни приложений для Flipper Zero собрано в одном месте. Про существование многих из них я даже не подозревал. В процессе тестирования каталога ни раз качал какую-то игру на пробу и залипал там на час с лишним. Мой личный топ:
1) 2048 - очень качественно сделанная адаптация 2048, идеально ложится на формфактор флиппера
2) Doom - это не порт, а скорее клон, но отличный - со здоровьем, в 3д, с патронами и перезарядкой
3) WAV Player - флиппер может играть черный бумер, ну не чудо ли?
В каталоге еще полно приложений для энтузиастов - для детекта SWD, для чтения/записи UART, для подключенного счетчика гейгера, для модуля GPS, для прошивки ESP32 и так далее. Прямо сейчас оно мне не нужно, но я уверен что рано или поздно какое-то из этих приложений мне понадобится (например, сбросить какой-нибудь очередной грузинский роутер).
Вы сами можете посмотреть приложения в каталоге - флиппер для этого не требуется. Загрузите приложение из AppStore/Google Play, пропустите соединение и перейдите на вкладку "Hub"
Особенно важно это событие лично для меня, так как во флиппере я занимаюсь мобильным приложением, а Apps выпустились как раз там.
Можете потыкать, рассказать как оно вам:
Google Play: https://play.google.com/store/apps/details?id=com.flipperdevices.app
App Store: https://apps.apple.com/app/flipper-mobile-app/id1534655259
Теперь больше сотни приложений для Flipper Zero собрано в одном месте. Про существование многих из них я даже не подозревал. В процессе тестирования каталога ни раз качал какую-то игру на пробу и залипал там на час с лишним. Мой личный топ:
1) 2048 - очень качественно сделанная адаптация 2048, идеально ложится на формфактор флиппера
2) Doom - это не порт, а скорее клон, но отличный - со здоровьем, в 3д, с патронами и перезарядкой
3) WAV Player - флиппер может играть черный бумер, ну не чудо ли?
В каталоге еще полно приложений для энтузиастов - для детекта SWD, для чтения/записи UART, для подключенного счетчика гейгера, для модуля GPS, для прошивки ESP32 и так далее. Прямо сейчас оно мне не нужно, но я уверен что рано или поздно какое-то из этих приложений мне понадобится (например, сбросить какой-нибудь очередной грузинский роутер).
Вы сами можете посмотреть приложения в каталоге - флиппер для этого не требуется. Загрузите приложение из AppStore/Google Play, пропустите соединение и перейдите на вкладку "Hub"
Особенно важно это событие лично для меня, так как во флиппере я занимаюсь мобильным приложением, а Apps выпустились как раз там.
Можете потыкать, рассказать как оно вам:
Google Play: https://play.google.com/store/apps/details?id=com.flipperdevices.app
App Store: https://apps.apple.com/app/flipper-mobile-app/id1534655259
🔥3😱2👍1
Forwarded from Android Good Reads (Egor Tolstoy)
Почему рендеринг текста – это сложно
Отличная статья, про то, из каких элементов вообще состоит текст, почему все браузеры и другие графические движки чаще всего рендерят его неправильно, и с какими эзотерическими проблемами можно столкнуться.
Отличная статья, про то, из каких элементов вообще состоит текст, почему все браузеры и другие графические движки чаще всего рендерят его неправильно, и с какими эзотерическими проблемами можно столкнуться.
Faultlore
Text Rendering Hates You - Faultlore
🔥2
Forwarded from Compose Broadcast (Кирилл Розов)
This media is not supported in your browser
VIEW IN TELEGRAM
В новой версии Android Studio Giraffe появился полноценный Live Edit для Compose - превью UI будет обновляться по мере изменения Compose без необходимости компиляции и запуске на устройстве.
Не стоит путать Live Edit с Compose Preview и Apply Changes, так как Live Edit предназначено для работы с Compose и показа UI с реального устройства или эмулятора.
В статье найдете подробное описание как устроен Live Edit
#androidstudio #tooling
Не стоит путать Live Edit с Compose Preview и Apply Changes, так как Live Edit предназначено для работы с Compose и показа UI с реального устройства или эмулятора.
В статье найдете подробное описание как устроен Live Edit
#androidstudio #tooling
🔥9👨💻2
Forwarded from Mobile Developer (Алексей Гладков)
Gradle Caching [EN]
https://proandroiddev.com/gradle-cache-your-builds-best-friend-4970ad32420e
Статья от известного в Андроид коммьюнити Алексея Быкова
Что внутри:
👉 Как работает градл
👉 Какие варианты кэшей бывают
👉 Практические примеры
👉 и кое-что еще
Приятного чтения
https://proandroiddev.com/gradle-cache-your-builds-best-friend-4970ad32420e
Статья от известного в Андроид коммьюнити Алексея Быкова
Что внутри:
👉 Как работает градл
👉 Какие варианты кэшей бывают
👉 Практические примеры
👉 и кое-что еще
Приятного чтения
Medium
Gradle Cache: Your build’s best friend
Throughout most of my career, I have tried to avoid everything about Gradle as much as possible. For me, it was always just a tool that I…
🔥6👍2🤔2
Forwarded from Compose Broadcast (Кирилл Розов)
This media is not supported in your browser
VIEW IN TELEGRAM
Compose Multiplatform видеоплеер с поддержкой Android (ExoPlayer), iOS (AVPlayer) и Desktop (VLC)
#android #ios #desktop #media
#android #ios #desktop #media
🔥5👍2
Forwarded from Мобильное Чтиво
Сейчас работаю над учебным курсом по Архитектуре Андроид приложений. Решил, что максимально ёмкое и понятное определение слова Архитектура дал старина Мартин.
Пожалуй, сделаю презентацию из этого одного слайда. Лучше уже не будет.
Вообще он весельчак. Наверное большинство его знает как автора толстенных и скучных книг. Но кто смотрел его выступления знает, что он довольно живенький и интересно рассказывает.
Вот например его одно из выступлений.
Пожалуй, сделаю презентацию из этого одного слайда. Лучше уже не будет.
Вообще он весельчак. Наверное большинство его знает как автора толстенных и скучных книг. Но кто смотрел его выступления знает, что он довольно живенький и интересно рассказывает.
Вот например его одно из выступлений.
😁5👍2💩1👨💻1
Forwarded from iOS Makes Me Hate (Lev Bondarenko)
Собесы сеньора. 25 компаний, 54 этапа, 2 оффера
Интересная история. Если вы думали, что всем сеньорам легче джунов, то вы не правы. Быть конкурентным сеньором на рынке сложнее, чем сейчас тамаде стать джуном. Герой статьи показывает частую проблему сеньоров, когда актуальность их знаний в одной компании может не так оценена в другой.
Я сам думал, что став один раз сеньором/тимлидом/техлидом в одной компании, то автоматически ты становишься таким на рынке. Но это не так, чаще даже в одной компании, но в разных командах тебя могут оценить по-другому. Не говоря уже о динамично развивающемся рынке.
Здесь нет виноватых. Кто-то посочувствует автору, кто-то поругет. Но так работает рынок. Чем выше грейд, тем выше ожидания и сильнее реагируют на детали.
Этих деталей очень много: в одних компаниях сеньор должен знать кишки и теорию, но забывает об архитектурах. В других теорию опускают, а спрашивают практические алгоритмы. В других наоборот синтетические, а знание глубин работы с памятью необязательно, ибо нет практического применения. В этом многообразии важно одно — совместимость.
Вывод один. Нужно следить за рынком
https://habr.com/ru/articles/751284/
Интересная история. Если вы думали, что всем сеньорам легче джунов, то вы не правы. Быть конкурентным сеньором на рынке сложнее, чем сейчас тамаде стать джуном. Герой статьи показывает частую проблему сеньоров, когда актуальность их знаний в одной компании может не так оценена в другой.
Я сам думал, что став один раз сеньором/тимлидом/техлидом в одной компании, то автоматически ты становишься таким на рынке. Но это не так, чаще даже в одной компании, но в разных командах тебя могут оценить по-другому. Не говоря уже о динамично развивающемся рынке.
Здесь нет виноватых. Кто-то посочувствует автору, кто-то поругет. Но так работает рынок. Чем выше грейд, тем выше ожидания и сильнее реагируют на детали.
Этих деталей очень много: в одних компаниях сеньор должен знать кишки и теорию, но забывает об архитектурах. В других теорию опускают, а спрашивают практические алгоритмы. В других наоборот синтетические, а знание глубин работы с памятью необязательно, ибо нет практического применения. В этом многообразии важно одно — совместимость.
Вывод один. Нужно следить за рынком
https://habr.com/ru/articles/751284/
Хабр
Что порой кроется за «успехом»
Всем добрый день. Сегодня утром, полистывая статьи на Хабре, я наткнулся на истории карьерных неуспехов и подумал: почему бы мне не рассказать историю своих мытарств в 2022-2023? Честно признаюсь,...
🤔3🫡3😁1🥱1
Forwarded from AppFiles - Mobile Development
Stable Diffusion AI - это простое в использовании приложение, позволяющее быстро генерировать изображения из текста или других изображений с помощью всего нескольких щелчков мыши. С помощью этого приложения можно взаимодействовать с собственным сервером (можно использовать две серверные среды, Txt2Img и Img2Img модели) и генерировать высококачественные изображения за считанные секунды.
Stable Diffusion AI на GitHub: https://github.com/ShiftHackZ/Stable-Diffusion-Android
Платформа: Android
⭐️: 153
Stable Diffusion AI на GitHub: https://github.com/ShiftHackZ/Stable-Diffusion-Android
Платформа: Android
⭐️: 153
🤔2
Forwarded from Mobile Compose (Jetpack Compose Bot)
#Article #Medium #Compose
Jetpack Compose — The order of modifiers does matter
Статья посвящена такой важной теме при знакомстве с Jetpack Compose, как порядок модификаторов.
Jetpack Compose — The order of modifiers does matter
Статья посвящена такой важной теме при знакомстве с Jetpack Compose, как порядок модификаторов.
👍2🔥2👨💻1
Forwarded from Dev Easy Notes (Nikita)
У меня есть друг с которым мы в былые времена, когда были начинающими мидлами горели тем, чтобы сделать какой-нибудь крутой pet или open source проект. Как и подобает мидлам мы страдали страшным перфекционизмом касательно автоматизаций. Сейчас вспоминать это смешно, но тогда это казалось невероятно важным.
Для примера, перед разработкой проекта мы тратили дичайше много времени, чтобы настроить плагин, который автоматически будет отгружать релизную сборку в maven central, далее настроили линтер, но почему-то сложным путем через создание собственного плагина, эээх молодеж... Затем настроили CI для сборки и прогона тестов, затем сделали даже автоматическую проверку на то, действительно ли либа корректно отправилась в maven. Очухались только когда кореш предложил и таски в трелло автоматически двигать после мержа...
Весь прикол заключается в том, что обычно на этом этапе проект и заканчивался. Мы могли побаловаться этими автоматизациями, сделать какой-то минимальный функционал и на этом все.
Автоматизации, хорошо настроенный CI, линтер, тесты, код ревью это очень хорошо и круто, но только на рабочих проектах, где тебе платят зарплату. На проектах, где это действительно нужно, ведь там куча людей, коммуникаций и цена ошибки выше.
Когда вас пара человек или ты вообще один(одна) то вообще не нужно запариваться на этот счет. По одной просто причине, топливо для pet проекта дичайше ограничено и его нужно растратить очень грамотно. Если не успел потратить грамотно выгоришь и проиграешь, суровая правда жизни. В самом начале проекта все что нужно это доехать до первой заправке аналогом которой будут реальные пользователи, деньги или присоединение других разрабов. Только после первой заправки можно думать про автоматизации.
Как я делаю сейчас при подобной разрабоке, которой к слову очень мало сейчас у меня. Я кладу болт на всю автоматизацию, делаю самый минимум насколько это возможно: CI – только сборка на МР, все остальное лесом, автоматическая отправка в Maven – либо руками, либо с готовым плагином без кастомной разрабоки, тесты – смотри мой пост про тесты выше, код ревью – только самый минимум по архитектуре. Даже несмотря на это далеко не всегда хватает энергии, чего уж говорить про автоматизации выше.
Для примера, перед разработкой проекта мы тратили дичайше много времени, чтобы настроить плагин, который автоматически будет отгружать релизную сборку в maven central, далее настроили линтер, но почему-то сложным путем через создание собственного плагина, эээх молодеж... Затем настроили CI для сборки и прогона тестов, затем сделали даже автоматическую проверку на то, действительно ли либа корректно отправилась в maven. Очухались только когда кореш предложил и таски в трелло автоматически двигать после мержа...
Весь прикол заключается в том, что обычно на этом этапе проект и заканчивался. Мы могли побаловаться этими автоматизациями, сделать какой-то минимальный функционал и на этом все.
Автоматизации, хорошо настроенный CI, линтер, тесты, код ревью это очень хорошо и круто, но только на рабочих проектах, где тебе платят зарплату. На проектах, где это действительно нужно, ведь там куча людей, коммуникаций и цена ошибки выше.
Когда вас пара человек или ты вообще один(одна) то вообще не нужно запариваться на этот счет. По одной просто причине, топливо для pet проекта дичайше ограничено и его нужно растратить очень грамотно. Если не успел потратить грамотно выгоришь и проиграешь, суровая правда жизни. В самом начале проекта все что нужно это доехать до первой заправке аналогом которой будут реальные пользователи, деньги или присоединение других разрабов. Только после первой заправки можно думать про автоматизации.
Как я делаю сейчас при подобной разрабоке, которой к слову очень мало сейчас у меня. Я кладу болт на всю автоматизацию, делаю самый минимум насколько это возможно: CI – только сборка на МР, все остальное лесом, автоматическая отправка в Maven – либо руками, либо с готовым плагином без кастомной разрабоки, тесты – смотри мой пост про тесты выше, код ревью – только самый минимум по архитектуре. Даже несмотря на это далеко не всегда хватает энергии, чего уж говорить про автоматизации выше.
🔥5👍2😁1
Forwarded from Android Security & Malware
How to attack (and secure) an Android app: An introduction
Presentation: https://www.droidcon.com/2023/07/31/how-to-attack-and-secure-an-android-app-an-introduction/
CTF apk: https://github.com/badolphi/droidcon-berlin
Slides: https://github.com/badolphi/droidcon-berlin/blob/main/Presentation.pdf
Presentation: https://www.droidcon.com/2023/07/31/how-to-attack-and-secure-an-android-app-an-introduction/
CTF apk: https://github.com/badolphi/droidcon-berlin
Slides: https://github.com/badolphi/droidcon-berlin/blob/main/Presentation.pdf
droidcon
How to attack (and secure) an Android app: an introduction
Android applications can be attacked in a multitude of ways. This workshop will give an introduction to some of the most popular attacks. It will explain how the attacks work in theory, demonstrate how they can be done in practice, with which tools, and discuss…
🔥4👍2
Forwarded from Android Guards
SQL инъекции в Android приложениях можно встретить не часто. Причин тому много. Разработчики поумнели, Google со своим Room-ом подтянулся. Так недолго и забыть как инъекции вообще эксплуатируются. Вот пара типичных пейлоадов для ContentProvider-ов:
💉
💉
А по ссылке можно найти чуть более экзотические варианты, которые подойдут для более сложных случаев.
#aht
💉
* from sqlite_master where type='table'-- (для projection)💉
1=1) union select name,2,3,4,5,6,7 from sqlite_master where type='table'-- (для selection/where)А по ссылке можно найти чуть более экзотические варианты, которые подойдут для более сложных случаев.
#aht
👍2🔥2👨💻2
Forwarded from Mobile Native ️️
Оптимизация анимации на Compose: крутим лоадеры, ищем неочевидные функции
Статья с разбором анимаций в Compose. Особенности анимаций, рекомпозиция, Canvas, в чём разница между группами анимаций Composable и Suspend, ну и всё это с примерами.
Читать (Ru)
Статья с разбором анимаций в Compose. Особенности анимаций, рекомпозиция, Canvas, в чём разница между группами анимаций Composable и Suspend, ну и всё это с примерами.
Читать (Ru)
🫡2🤪2😁1😱1
Forwarded from Mobile Compose
#News #Compose #Compiler
🆕🔥 Новости с полей: начиная с версии 1.5.0 Compose Compiler обеспечивает экспериментальную поддержку компилятора K2.
При этом, пока не весь функционал Compose поддерживается новой версией компилятора, часть будет добавлена позже в будущих версиях.
Надеюсь, скоро руки всё-таки дойдут до дайджеста, и там получится разобрать больше изменений последних релизов.
🆕🔥 Новости с полей: начиная с версии 1.5.0 Compose Compiler обеспечивает экспериментальную поддержку компилятора K2.
При этом, пока не весь функционал Compose поддерживается новой версией компилятора, часть будет добавлена позже в будущих версиях.
Надеюсь, скоро руки всё-таки дойдут до дайджеста, и там получится разобрать больше изменений последних релизов.
👍2🔥2
Forwarded from Мобильное Чтиво
Compose 1.5 быстрее на 80%
Ну не то чтобы обещает быть быстрее в целом, а обещает что производительность модифайеров повысилась на 80%. Так и написали Modifiers see large performance improvements, up to 80% improvement to composition time, in this release.
Это точно очень крутое заявление и очень актуальное для нас сейчас.
Мы в Drinkit делаем один большой и сложный экран на Compose, который имеет проблему медленного открытия (особенно на холодную). Помимо загрузки рантайма (про это я писал отдельно), сам экран тоже влияет на время работы.
Т.к. модифайеры — это ключевой элемент компоуз виджетов и всё ими обмазано, то повышение их производительности это очень классный момент.
Мы скоро проверим это и я поделюсь результатами, помогло ли оно нам.
#compose
Ну не то чтобы обещает быть быстрее в целом, а обещает что производительность модифайеров повысилась на 80%. Так и написали Modifiers see large performance improvements, up to 80% improvement to composition time, in this release.
Это точно очень крутое заявление и очень актуальное для нас сейчас.
Мы в Drinkit делаем один большой и сложный экран на Compose, который имеет проблему медленного открытия (особенно на холодную). Помимо загрузки рантайма (про это я писал отдельно), сам экран тоже влияет на время работы.
Т.к. модифайеры — это ключевой элемент компоуз виджетов и всё ими обмазано, то повышение их производительности это очень классный момент.
Мы скоро проверим это и я поделюсь результатами, помогло ли оно нам.
#compose
👍6🔥3🤔3
Forwarded from Mobile Compose (Jetpack Compose Bot)
#Article #Medium #Compose
A Developer’s Approach to Identifying Jetpack Compose Usage in Apps
🗣 Отвлечемся от всех этих релизов...
Тут человек обнаружил способ определять какой UI фреймворк использует приложение без изучения его кода. Для этого нужен всего-лишь старый советский ... тоггл "Show layout bounds" из раздела Developer Options устройства.
Если вкратце:
▫️Android Views, React Native, и даже Compose внутри ComposeView — отмечаются синим цветов по углам
▫️Jetpack Compose — никаких синих углов, но обводка всё еще сохраняется
▫️Flutter — вообще никаких обводок ui компонентов
Зеркало статьи 👉 тут
A Developer’s Approach to Identifying Jetpack Compose Usage in Apps
🗣 Отвлечемся от всех этих релизов...
Тут человек обнаружил способ определять какой UI фреймворк использует приложение без изучения его кода. Для этого нужен всего-лишь старый советский ... тоггл "Show layout bounds" из раздела Developer Options устройства.
Если вкратце:
▫️Android Views, React Native, и даже Compose внутри ComposeView — отмечаются синим цветов по углам
▫️Jetpack Compose — никаких синих углов, но обводка всё еще сохраняется
▫️Flutter — вообще никаких обводок ui компонентов
Зеркало статьи 👉 тут
👍2🔥2👏2🤔1