Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
AmplifyとReact/ReactNativeでマルチプラットフォームアプリを1ヶ月...
Search
Yu Miyachika
November 27, 2020
Technology
0
3.8k
AmplifyとReact/ReactNativeでマルチプラットフォームアプリを1ヶ月で作る
Yu Miyachika
November 27, 2020
Tweet
Share
Other Decks in Technology
See All in Technology
株式会社EventHub・エンジニア採用資料
eventhub
0
4.2k
事業継続を支える自動テストの考え方
tsuemura
0
300
飲食店予約台帳を支えるインタラクティブ UI 設計と実装
siropaca
6
1.4k
自動テストの世界に、この5年間で起きたこと
autifyhq
10
7.1k
地方拠点で エンジニアリングマネージャーってできるの? 〜地方という制約を楽しむオーナーシップとコミュニティ作り〜
1coin
1
130
『AWS Distinguished Engineerに学ぶ リトライの技術』 #ARC403/Marc Brooker on Try again: The tools and techniques behind resilient systems
quiver
0
130
SCSAから学ぶセキュリティ管理
masakamayama
0
140
テストアーキテクチャ設計で実現する高品質で高スピードな開発の実践 / Test Architecture Design in Practice
ropqa
3
710
マルチモーダル理解と生成の統合 DeepSeek Janus, etc... / Multimodal Understanding and Generation Integration
hiroga
0
360
『衛星データ利用の方々にとって近いようで触れる機会のなさそうな小話 ~ 衛星搭載ソフトウェアと衛星運用ソフトウェア (実物) を動かしながらわいわいする編 ~』 @日本衛星データコミニティ勉強会
meltingrabbit
0
120
滅・サービスクラス🔥 / Destruction Service Class
sinsoku
6
1.5k
Larkご案内資料
customercloud
PRO
0
600
Featured
See All Featured
Keith and Marios Guide to Fast Websites
keithpitt
411
22k
Facilitating Awesome Meetings
lara
51
6.2k
The Straight Up "How To Draw Better" Workshop
denniskardys
232
140k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
175
51k
A Modern Web Designer's Workflow
chriscoyier
693
190k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
10
1.3k
How to Ace a Technical Interview
jacobian
276
23k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
232
17k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
6
540
Rebuilding a faster, lazier Slack
samanthasiow
79
8.8k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
356
29k
Become a Pro
speakerdeck
PRO
26
5.1k
Transcript
AmplifyとReact/ReactNative でマルチプラットフォームアプリ を1ヶ月で作る Amplify meetup #02 宮近 雄宇 / Yu
Miyachika 2020/11/27
宮近 雄宇 / Yu Miyachika • フロントエンドエンジニア • SIer4年 ->
フリーランス11年目 • iOSは4のころから • Reactはここ2年 • 好きなAWS Amplify, CodeBuild
お仕事について • お客様のDXのお手伝い • 3-4週でPoCをスクラム開発 • スプリント期間は1日
すなわち・・・
アジリティ 特化型 エンジニア
だから・・・
と相性が よかった
特にReactとの組み合わせが最高 ここ1年半、たくさんPoC開発やってきました
Amplifyの端的なメリット • 開幕15分でHTTPSのURLが払い出せる • 次の30分でAppSyncが立つ • 提供する価値に注力できる アジリティ重視のPoCにピッタリ!!
Amplifyの端的なデメリット • Cloud Formationの知識がないとツライ • カスタマイズしたいときはちょっと大変 • 更新頻度高すぎて「いつの間に…」事案
そろそろ本題。
少し前までのモバイル開発のつらみ • フロントエンド/バックエンド • 記述量に対して得られるアウトカムが低い • OSS無しでは非同期処理がつらい • UIのステート管理がつらい ⇨
とにかくDX(Developer Experience)が悪い
ソフトウェア開発は10年で大きく進化 • BaaS • クロスプラットフォーム • async / await •
宣言的UI
従来のモバイル開発環境もがんばってきた • Swift UI / Combine framework • Kotlin /
Coroutines ⇨ FacebookがReact NativeでWeb開発者をつれてきてし まった ⇨ GoogleがAndroid開発をFlutterで再定義してしまった (ついでにiOSも)
モバイル開発は クロスプラットフォーム+BaaSが台頭 React Native + AWS Amplify Flutter + Firebase
日本でも じわじわ人口増加中 日本ではあまり… 海外では結構多い?
引越し先をさがそう… 可否 / 興味 AWS Amplify Google Firebase React Native
◦ / ◎ ◦ / ◦ Flutter ✗(→△) / ✗ ◦ / △ React NativeならReactだしAmplifyあるし簡単っしょ 決定
コロナで完全リモート開始から数ヶ月たったある日… プロダクトオーナー S氏 社内でポッドキャスト始めたんだけど、 ちょっと視聴ストリーミングアプリ つくってほしいな〜? わたし 過去にSwiftでやっちゃってるから React Native+Amplifyの素振りしながらでも
いっすか? えー?いいよ
開発開始。
実はストリーミングアプリ、 得意分野だったのです • 無料音楽レーベルの公式アプリを 2010年に個人リリース • 2016年にSwiftで書き直して リニューアル ストリーミングアプリ =技術的お砂場の位置付け
開発開始から2日目… リスナーは ポッドキャストの 各回を選択して 視聴することができる AppSync DynamoDB S3 React Native
アプリ Amplify API Amplify Storage
開発開始から2日目… ちょっとデザイナーにも参加してもらって 真面目にプロダクトバックログ書くわ わたし 昔2週間、下手すると1ヶ月ぐらい かけてたことが2日…2日… デザイナー H氏 ウィッスー プロダクトオーナー
S氏
開発開始から2週間後… システムは、 ユーザーを認証・認 可できる (ログイン機能) 管理者は、エピソード を投稿・編集・削除で きる(管理画面) リスナーは、 もっとかっこいいア
プリをさわりたい (デザイン適用)
開発開始から2週間後… AppSync DynamoDB S3 React Native アプリ Amplify API Amplify
Storage React 管理画面 S3 CloudFront WAF Amplify Hosting Cognito Amplify Auth システムは、ユーザーを 認証・認可できる (ログイン機能) 管理者は、エピソードを投 稿・編集・削除できる(管理 画面) リスナーは、 もっとかっこいいアプリをさ わりたい (デザイン適用)
TIPS: マルチフロントエンドの魔法の言葉 $ amplify pull
開発開始から2週間後… よっしゃ運用周りもうちょい充実させたら 内部向けリリースするぞ わたし React Native、 レイアウトとルーティングが違うだけで あとReactと全部同じやん デザイナー H氏
ウィッスー プロダクトオーナー S氏
開発開始から1ヶ月後… リスナーはSlackの Botで新着エピソード の配信を知ることが できる リスナーはプッシュ通 知で新着エピソード の配信を知ることが できる あと色々
細かいところ…
開発開始から1ヶ月後… AppSync DynamoDB S3 React Native アプリ Amplify API Amplify
Storage React 管理画面 S3 CloudFront WAF Amplify Hosting Cognito Amplify Auth Lambda (Slack) Lambda (PUSH通知) CloudWatchEvent (定期実行) Amplify Function Slack FCM リスナーはSlackのBotで新着エピ ソードの配信を知ることができる リスナーはプッシュ通知で新着エ ピソードの配信を知ることができる ?
Amplify Push Notificationsにしたかった • Amplify Push Notificationsの実体はAWS Pinpoint • Firebase
Analytics + Firebase Cloud Messaging的存在 • AWS SNSと比べて、マーケティング寄り • 導通の確立に関するドキュメントが手薄い • トライして撃沈しました(当時は)
TIPS: APIとFunctionをつなぐ方法 クエリの定義 ディレクティブ Function名 LambdaResolverがこれだけで仕上がる DataSource,Resolver, Role, VTL…さよなら… 戻り値の型
なにはともあれ1ヶ月で完成。
React Native + Amplify、どうだったか • Reactで作ったhooksや通信部分を流用できる • Amplifyの文脈は全く一緒 • コード記述量の投資対効果抜群
• レイアウトとルーティングは違う • 各ネイティブの知識は必要なときもある
React / React Native + Amplifyで マルチフロントエンド開発やっていきましょう!
ご清聴ありがとうございました