ElmとFirebaseでチャットアプリを写経してみる(1)実行してみる
前回、elmでlocalStorage利用のTODOアプリを2つのソースコードのコピペで作ることができたので、次は、elmでfirebase利用のチャットアプリを作成したいと思いました。
大変ありがたいことに、以下にソースコードを公開してくださっていたので、実行してみたいと思います。
https://qiita.com/qnoyxu/items/ee479b2b96831907e024
data:image/s3,"s3://crabby-images/5e05e/5e05ea93b389c293f6fdabc3874bad4bccfadc11" alt=""
ソースコード: https://github.com/qnoyxu/chat-room
ElmとFirebaseでチャットアプリ目次
開発環境
Windows 10 Pro
Chrome
VisualStudioCode 1.32.3
git version 2.20.1.windows.1
nvm 1.1.7
node 10.2.0
npm 6.4.1
elm 0.19.0-bugfix6
elm-format 0.8.1
VisualStudioCodeの拡張機能でelmをインストールして、settings.jsonに以下のようにelmを設定。
(『Alt + Shift + F』と『Ctrl + S』を使用。)
"[elm]": {
"editor.formatOnSave": true
},
Firebaseで新規プロジェクトを作成
Googleアカウントがなければ作成し、
https://console.firebase.google.com/
へログインして、新規プロジェクトを作成します。
data:image/s3,"s3://crabby-images/bae8c/bae8c58aee516de96837a7f74ef006cac91b1ee7" alt=""
Project Overview
+アプリを追加
Firebase database の 画面に従って入力していくと、
var firebaseConfig = {
の画面が出てくるので、
databaseURL: “https://<YOUR-APPLICATION>.firebaseio.com",
のところのアドレスをコピーしておきます。
注:"https://<YOUR-APPLICATION>.firebaseio.com" のところは、それぞれの人によって変わります。
data:image/s3,"s3://crabby-images/19ae9/19ae96b39d830f08d022b8e8303867d6125751c4" alt=""
Firebaseの認証のルールをread, writeともにtrueにする
セキュリティ的には危険ですが、FirebaseのDatabaseのルールの設定を以下のようにします。
{
"rules": {
".read": true,
".write": true
}
}
data:image/s3,"s3://crabby-images/5afe2/5afe2650c4e48f09e42626a9d322b4e611215c45" alt=""
ソースコードのZIPファイルをダウンロードして解凍
ソースコード: https://github.com/qnoyxu/chat-room
のページから、DOWNLOAD ZIPをクリックしてダウンロードして解凍します。
今回は、D:/elm/ フォルダに解凍しました。
data:image/s3,"s3://crabby-images/eedd3/eedd3e65ca1b1d1557cbf9a685c08ca9b3d3ab41" alt=""
“npm i"
フォルダをVisualStudioCodeで開いて、Ctrl+@でターミナル画面を開き、以下を入力します。
npm i
data:image/s3,"s3://crabby-images/30134/301347600a3f8a8763c31b8e9c64ae7f6f36c2e8" alt=""
src/index.jsの編集
src/index.jsの33行目の
const config = {databaseURL: “Your App Name"};
のdatabaseURL: の次のところを、上記でコピーしておいたアドレスで置き換えます。
data:image/s3,"s3://crabby-images/c5914/c5914b979a8a70c374cf06dc2f6b09b9ed167a3c" alt=""
npm startでlocalhostで確認
npm startで確認できます。localhostで2人の操作を行いたい場合は、ChromeとFirefox(3人なら、さらにEdgeで)で確認できました。
data:image/s3,"s3://crabby-images/15fd1/15fd112a42dab8fee71737320e82dd3eb5285f63" alt=""
data:image/s3,"s3://crabby-images/7ff78/7ff78b0acef3deefdf708fdb9b804778c8aec4a6" alt=""
2人分
data:image/s3,"s3://crabby-images/489fe/489fe5bd5dd6d0cd00a2229f52bf794f2e9791f2" alt=""
3人分
data:image/s3,"s3://crabby-images/9e5e2/9e5e297cce2d9f2ba8940a6b0b865815debd81e3" alt=""
なお、私の環境下では、Internet Explorer11では画面が真っ白で動きませんでした。理由は不明です。
Netlifyにデプロイ
Bitbucket経由でNetlifyにデプロイしました。debugの表示が残ってしまっているのですが、後で消し方を、、、
https://hardcore-fermi-5d12db.netlify.com/
debugの表示を消す(webpack.config.jsを編集)
こちらのコードは、Webpackというシステムを用いているらしく、設定ファイルがwebpack.config.js
のようです。debugの表示を消すためには、以下のように変更するようです。(本当はdevelopment modeとproduction modeで分けて、production modeでoptimiseを使いたいですが、また今度、、、)
参考:https://qiita.com/hibohiboo/items/311b65987fbe64ce29fe
(変更前)
test: /\.elm$/,
loader: 'elm-loader',
options: {
debug: true
}
(変更後)
test: /\.elm$/,
loader: 'elm-loader',
options: {
debug: false
}
ディスカッション
コメント一覧
まだ、コメントがありません