Confetti: building a Kotlin Multiplatform conference app in 40min 🎊
Martin Bonnin 🇫🇷
John O’Reilly 🇮🇪
AndroidMakers, April 2023
@martinbonnin 🎊 @joreilly
@martinbonnin 🎊 @joreilly
Agenda
- Brief overview of Kotlin Multiplatform, Declarative UI and GraphQL
- Live coding session where we build out backend and iOS/Android
versions of the Confetti conference app that use these technologies
@martinbonnin 🎊 @joreilly
Kotlin Multiplatform
- Ability to run Kotlin code natively on a range of platforms
- Di
ff
ers from other approaches in that it supports optional code
sharing that allows incremental adoption
- Focussed primarily on sharing of non-UI code
- Allows full access to platform capabilities
- KMM currently in beta with plan to go stable this year.
@martinbonnin 🎊 @joreilly
@martinbonnin 🎊 @joreilly
Declarative UI (Compose/SwiftUI)
- Describe UI in terms of what it should be like in a particular state. Any change in
state will be re
fl
ected automatically in UI.
- Encourages use of MVVM/Unidirectional Data Flow
- Jetpack Compose
- announced at Google I/O in 2019
- stable release 2021
- SwiftUI
- announced at WWDC in 2019
- allows building of user interfaces across all Apple platforms (SwiftUI Multiplatform!)
@martinbonnin 🎊 @joreilly
GraphQL
- “Open source query language to describe and run your APIs”
- Type safe: your compiler/runtime ensure your
fi
elds are present at
runtime.
- No overfetching: you get the data you asked for and only this.
- Self documenting: introspection and tools means you always have
docs up to date.
@martinbonnin 🎊 @joreilly
@martinbonnin 🎊 @joreilly
GraphQL ❤ Kotlin
GraphQL Kotlin (server)
- Takes your Kotlin code and turns it into GraphQL types and schema
- Spring Boot and Ktor support
Apollo Kotlin (client)
- Takes your GraphQL queries and generate type safe Kotlin models
- In-memory and persistent caches
- Multiplaform
@martinbonnin 🎊 @joreilly
@martinbonnin 🎊 @joreilly
@martinbonnin 🎊 @joreilly
Compose
Repository
Kotlin Multiplatform Shared Code
Kotlin
Swift
SwiftUI
GraphQL Server
(Apollo)
ViewModel
@martinbonnin 🎊 @joreilly
Coding!
@martinbonnin 🎊 @joreilly
@martinbonnin 🎊 @joreilly
Wrap up!
@martinbonnin 🎊 @joreilly
Compose
Repository
Kotlin Multiplatform Shared Code
Kotlin
Swift
SwiftUI
GraphQL Server
(Apollo)
ViewModel
@martinbonnin 🎊 @joreilly
Sessions
Session Details
Speaker Details
Share
Search
Bookmarks
Dark Mode
Material 3
iOS
Wear OS
Compose Desktop
…
Confetti is on the App/Play store
Android Auto 🏎
Auto Persisted Queries
Google Cloud CDN
Settings sync
O
ffl
ine mode
Background refresh
Screenshot tests
a11y
…
@martinbonnin 🎊 @joreilly
One more thing platform?
+
@martinbonnin 🎊 @joreilly
Thanks! 🎊
@joreilly
@oreillyj@mastodon.social
@martinbonnin@mastodon.social
@martinbonnin
github.com/joreilly/Confetti
@martinbonnin 🎊 @joreilly
Resources
- KMM - https://kotlinlang.org/lp/mobile/
- Jetpack Compose - https://developer.android.com/jetpack/compose
- SwiftUI - https://developer.apple.com/xcode/swiftui/
- Confetti repo - https://github.com/joreilly/Confetti
- Apollo Kotlin Multiplatform - https://www.apollographql.com/docs/
kotlin/tutorial/00-introduction/
- GraphQL Kotlin - https://opensource.expediagroup.com/graphql-
kotlin/docs/
- Compose Web - https://compose-web.ui.pages.jetbrains.team/
- Kotlin wasm - https://kotl.in/wasm
@martinbonnin 🎊 @joreilly
Compose
Repository
Kotlin Multiplatform Shared Code
Kotlin
Swift
SwiftUI
GraphQL Server
Apollo
ViewModel
- schema.graphqls
- queries.graphql

More Related Content

PDF
MVVM-C vs MVP
PDF
SAML / OpenID Connect / OAuth / SCIM 技術解説 - ID&IT 2014 #idit2014
PPTX
20210113「アウトプットしないのは知的な便秘」の影響力 -2020年版- ~How To Output Intellectual Constipa...
PDF
[AWSマイスターシリーズ] Amazon VPC VPN & Direct Connect
PDF
プロトコルから見るID連携
PDF
20231109_OpenID_TechNight_OpenID_Federation.pdf
PPTX
Uwpアプリケーション開発入門
PPTX
OpenID Connect Flowの種類と使い道
MVVM-C vs MVP
SAML / OpenID Connect / OAuth / SCIM 技術解説 - ID&IT 2014 #idit2014
20210113「アウトプットしないのは知的な便秘」の影響力 -2020年版- ~How To Output Intellectual Constipa...
[AWSマイスターシリーズ] Amazon VPC VPN & Direct Connect
プロトコルから見るID連携
20231109_OpenID_TechNight_OpenID_Federation.pdf
Uwpアプリケーション開発入門
OpenID Connect Flowの種類と使い道

What's hot (20)

PDF
AWS Black Belt Techシリーズ Amazon SNS モバイルプッシュ
PDF
20180914 security iotlt#1_ほんとうにあった怖い話_aws_iot編
PDF
今更聞けない電子認証入門 - OAuth 2.0/OIDCからFIDOまで -
PDF
WSO2 Identity Server
PPTX
Chatbot with RASA | Valuebound
PDF
AWS IoTにおけるデバイスへの認証情報のプロビジョニング
PDF
02B_AWS IoT Core for LoRaWANのご紹介
PDF
open-banking-on-aws.pdf
PPTX
M5Stack互換機を作った話
PDF
IDaaSにSign in with Appleをつないでみた
PPTX
Azure Api Management 俺的マニュアル 2020年3月版
PPTX
Power Automate for desktopとGoogle Apps Scriptの連携について
PDF
ブロックチェーンを用いた自己主権型デジタルID管理
PDF
エンタープライズITでのOpenID Connect利用ガイドライン
PDF
SSI DIDs VCs 入門資料
PDF
Go 製リアルタイムサーバーの Kubernetes での運用について
PDF
誰でもできるスマートシティ向けOSS : FIWAREのはじめかた
PDF
【de:code 2020】 SaaS で迅速に IoT を実現 - Azure IoT Central 最新アップデートと活用術
PPTX
SNMPセキュリティ超入門
PDF
한글과컴퓨터의 클라우드 마이그레이션, 거버넌스 그리고 모더나이제이션-박인재, AWS ISV SA Manager / 박상형, 한글과컴퓨터 I...
AWS Black Belt Techシリーズ Amazon SNS モバイルプッシュ
20180914 security iotlt#1_ほんとうにあった怖い話_aws_iot編
今更聞けない電子認証入門 - OAuth 2.0/OIDCからFIDOまで -
WSO2 Identity Server
Chatbot with RASA | Valuebound
AWS IoTにおけるデバイスへの認証情報のプロビジョニング
02B_AWS IoT Core for LoRaWANのご紹介
open-banking-on-aws.pdf
M5Stack互換機を作った話
IDaaSにSign in with Appleをつないでみた
Azure Api Management 俺的マニュアル 2020年3月版
Power Automate for desktopとGoogle Apps Scriptの連携について
ブロックチェーンを用いた自己主権型デジタルID管理
エンタープライズITでのOpenID Connect利用ガイドライン
SSI DIDs VCs 入門資料
Go 製リアルタイムサーバーの Kubernetes での運用について
誰でもできるスマートシティ向けOSS : FIWAREのはじめかた
【de:code 2020】 SaaS で迅速に IoT を実現 - Azure IoT Central 最新アップデートと活用術
SNMPセキュリティ超入門
한글과컴퓨터의 클라우드 마이그레이션, 거버넌스 그리고 모더나이제이션-박인재, AWS ISV SA Manager / 박상형, 한글과컴퓨터 I...
Ad

Similar to AndroidMakers2023.pdf (20)

PDF
kotlinconf2023.pdf
PPTX
Kotlin REST & GraphQL API
PPTX
What is Kotlin Multiplaform? Why & How?
PPTX
android group material Presentation1.pptx
PDF
QCon São Paulo 2018
PPTX
Introduction to Android- A session by Sagar Das
PDF
Droidcon Online 2020 quick summary
PPTX
Android Developer Toolbox 2017
PDF
Android dev toolbox - Shem Magnezi, WeWork
PPTX
Google I/O 2019 - what's new in Android Q and Jetpack
PPTX
Android dev toolbox
PDF
What’s new in Kotlin 12-08-2023 Google IO Cairo 23
PDF
Cross-platform UI Engines Rendering Performance
PDF
Be More Productive with Kotlin
PDF
Kotlin native for iOS and Android
PDF
DroidCon Berlin 2018 summary
PDF
Building android apps with kotlin
PDF
GraphQL: Enabling a new generation of API developer tools
PDF
Green flag Wrap up Google Solution Challenge.pdf
PPTX
Why Choose Kotlin For Android Application Development.pptx
kotlinconf2023.pdf
Kotlin REST & GraphQL API
What is Kotlin Multiplaform? Why & How?
android group material Presentation1.pptx
QCon São Paulo 2018
Introduction to Android- A session by Sagar Das
Droidcon Online 2020 quick summary
Android Developer Toolbox 2017
Android dev toolbox - Shem Magnezi, WeWork
Google I/O 2019 - what's new in Android Q and Jetpack
Android dev toolbox
What’s new in Kotlin 12-08-2023 Google IO Cairo 23
Cross-platform UI Engines Rendering Performance
Be More Productive with Kotlin
Kotlin native for iOS and Android
DroidCon Berlin 2018 summary
Building android apps with kotlin
GraphQL: Enabling a new generation of API developer tools
Green flag Wrap up Google Solution Challenge.pdf
Why Choose Kotlin For Android Application Development.pptx
Ad

Recently uploaded (20)

PDF
Transform Your ITIL® 4 & ITSM Strategy with AI in 2025.pdf
PPTX
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
PDF
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
PPTX
Final SEM Unit 1 for mit wpu at pune .pptx
PDF
A comparative study of natural language inference in Swahili using monolingua...
PDF
sustainability-14-14877-v2.pddhzftheheeeee
PDF
WOOl fibre morphology and structure.pdf for textiles
PDF
Assigned Numbers - 2025 - Bluetooth® Document
PPTX
observCloud-Native Containerability and monitoring.pptx
PDF
A review of recent deep learning applications in wood surface defect identifi...
PDF
Zenith AI: Advanced Artificial Intelligence
PDF
Getting started with AI Agents and Multi-Agent Systems
PDF
August Patch Tuesday
PDF
Five Habits of High-Impact Board Members
PDF
DP Operators-handbook-extract for the Mautical Institute
PDF
From MVP to Full-Scale Product A Startup’s Software Journey.pdf
PDF
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
PDF
Getting Started with Data Integration: FME Form 101
PDF
Univ-Connecticut-ChatGPT-Presentaion.pdf
PPTX
Modernising the Digital Integration Hub
Transform Your ITIL® 4 & ITSM Strategy with AI in 2025.pdf
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
Final SEM Unit 1 for mit wpu at pune .pptx
A comparative study of natural language inference in Swahili using monolingua...
sustainability-14-14877-v2.pddhzftheheeeee
WOOl fibre morphology and structure.pdf for textiles
Assigned Numbers - 2025 - Bluetooth® Document
observCloud-Native Containerability and monitoring.pptx
A review of recent deep learning applications in wood surface defect identifi...
Zenith AI: Advanced Artificial Intelligence
Getting started with AI Agents and Multi-Agent Systems
August Patch Tuesday
Five Habits of High-Impact Board Members
DP Operators-handbook-extract for the Mautical Institute
From MVP to Full-Scale Product A Startup’s Software Journey.pdf
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
Getting Started with Data Integration: FME Form 101
Univ-Connecticut-ChatGPT-Presentaion.pdf
Modernising the Digital Integration Hub

AndroidMakers2023.pdf