はじめに
はじめまして。
2024年3月よりプログラミングスクールRUNTEQに通っている、わーちゃん(@wa-chan222)と申します。
未経験からのWebエンジニア転職を目指して、Ruby on Railsを中心にプログラミングの学習を続けております。
今回スクールの卒業制作として「Trainspotter」という鉄道写真を共有できるWEBサービスを開発しました。
▶サービスURL:Trainspotter
▶Github:リポジトリ
🚆 サービス概要
Trainspotter.は、「鉄道車両の写真をみんなで楽しむ」をコンセプトとした、鉄道車両に少しでも興味がある人、好きな人を対象にしたアプリです。普段利用している🚆路線や旅行で利用した路線の車両を投稿することができます。まだ知らない鉄道車両を観察しに行きませんか?
🚆 このサービスへの思い・作りたい理由
1:甥っ子が鉄道好きで、今後様々な鉄道車両を利用する機会があった時に記録に残しておきたい。
2:私だからこそ知っているベストショットの時間やポジションを知りたい。
3:家にいてもアプリ一つで日本中の鉄道車両の写真を楽しみたい。
🚆 ユーザー層について
- 撮り鉄の人
- 鉄道に少しでも興味のある人
🚆 サービスの利用イメージ
- スマホやPCでの利用。
- 自分や他者と共有することで、もっと鉄道を好きになってもらう。鉄道仲間を増やす
- (鉄道関係者の場合、鉄道車両を撮影してもらうことで、魅力を知ってもらうきっかけとなる。さらには鉄道の利用にもつながる。)
🚆 ユーザーの獲得について
SNS、個人のネットワーク、そして RUNTEQ のようなコミュニティを活用して、アプリの存在を広める予定です。
🚆 サービスの差別化ポイント・推しポイント
- スタンプラリー形式のものや、訪れた駅を地図上で塗りつぶすようなアプリは存在するが、いずれも個人完結型であった。Trainspotter.のような共有型である点。
- 投稿数に応じてバッジ機能を実装した点。
- いいねアイコンを鉄道モチーフにすることでかわいらしさ?を加えた点。
🚆 機能一覧
- ユーザー登録機能/ログイン機能/Googleログイン機能
- パスワードリセット機能
- マイページ
- ユーザー情報編集
- アカウント削除
- 投稿機能
- 駅名、路線名、都道府県、コメント、撮影場所、画像
- 投稿一覧
- 詳細(編集、削除)
- お気に入り追加ボタン(電車アイコン)
- 検索機能(都道府県、路線名、駅名、フリーワード)
- ユーザー自身の投稿一覧
- お気に入り投稿一覧
- バッジページ
- SNSシェア機能(X:旧Twitter)
機能紹介
新規登録 |
---|
名前、メールアドレス、パスワード、パスワード確認から新規登録が可能。 |
新規投稿 |
---|
駅名と路線名はID番号から簡単に一致させることができます。全て必須項目です。 |
投稿一覧 |
---|
投稿一覧からお気に入り登録や投稿詳細を見ることが可能。上部には様々な方法で検索できるようにしています。(お気に入り一覧。ユーザー自身の投稿一覧も同様) |
投稿詳細 |
---|
投稿詳細から編集、削除が可能。 |
マイバッジ |
---|
投稿数に応じたバッジ機能。何枚でバッジが現れるかはお楽しみ。 |
🚆 機能の実装方針予定
カテゴリ | 使用技術 |
---|---|
開発環境 | Docker |
バックエンド | Ruby 3.2.2 / Rails 7.1.3 |
フロントエンド | TurboとStimulus |
データベース | PostgreSQL |
インフラ | Render |
認証 | Sorcery ・ Google OAuth |
🚆 画面遷移
🚆 ER図
🚆 このアプリ開発中作成した記事
★マークは特に時間がかかった内容や苦労した内容になります
データーベースを確認したい
★【Error】ログアウトボタンが反応しない
★【Error】migrateがうまくいかずusersテーブルにnameだけ登録できない問題
★【豆知識】マイグレーションファイル生成時userはinteger?references?&名称変更注意点など
★【豆知識とError】Google認証周り。APIキーを含む秘匿情報について
【豆知識】リセットパスワードの流れを改めて整理してみる
★【豆知識】 Google のクライアント ID やシークレットにアクセスする方法について
【豆知識+Error】コードがあっていても少し位置が違うだけでエラーになってしまうrenderのお話
★【豆知識】Google認証APIキーを含む秘匿情報ENVコードで管理。+credentialとの違い
★【豆知識】.gitignoreとconfigとの関係性について
★【Error】rails db:migrate
コマンドを実行した際に発生したエラー。タイムスタンプについて知る
【豆知識】has_manyの設定について少し理解
【豆知識】Tailwind背景色が何かおかしかった
★【豆知識とError】belongs_toとvalidatesのちょっとした誤解
【豆知識】CSVファイルインポートを少し学ぶ
【Error】古いCSSやjavascriptがのこっていてうまくいかない
【Error】シングルクォートとダブルクォート。Rubocopの自動修正機能
【豆知識】条件分岐。if とunless と演算子
【Error】ラベルのエラーについて
【豆知識】Render無料枠終了後のその先
【学習】AWSのS3設定 画像関係①
★【Error】AWS画像関係~原因が全く違った?件
【学習】MVP後、わからなかった部分
【学習】Githubプロジェクト紐づけ
【学習】静的OGPの設定。
【Error・学習】RailsプロジェクトにGitHub Actions(Rspec)
🚆最後に
今回のアプリ作成にあたり、お力添え頂いた全ての方々に心よりお礼申し上げます🙇♂️
プログラミング学習を通じ、もっとプログラミングについて知りたくなる気持ちが強まりました。市場を見ているとAI、ローコード、IOWN、永続性メモリー、Huskyだったり。言語はもちろんですが、学習してみたいものが沢山あります
最後までご覧頂きありがとうございました!
※ X(旧Twitter)もやっているので、よろしければフォローして頂けると嬉しいです。
https://x.com/wa_2sk