はじめに
はじめまして、とほほと申します!
プログラミングスクール「RUNTEQ」を卒業し、集大成としてポートフォリオを制作したため、リリースしたサービスについて本記事で紹介させていただきます🙇
なお、最後に開発にあたって参考にさせていただいた記事も一覧で掲載しておりますので、今後個人開発をされる方の参考になれば幸いです😊
サービス URL🔗
Github リポジトリ🔗
1. サービス概要
MuseUP(みゅーじあっぷ)とは、近くのミュージアム(博物館・美術館等)を検索したり、おススメしたいミュージアムを投稿したりして、もっとミュージアムを知る・楽しむことができるサービスです!
ユーザーは、他のユーザーが投稿したミュージアムの詳細を閲覧したり、地域やカテゴリ、現在地から条件に該当するミュージアムを探すことができます。そして、ミュージアム好きなユーザーは、自分がおススメしたいミュージアムを投稿したり、ミュージアムのレビューを投稿することが出来ます。加えて、ミュージアムをリストに登録して管理したり、ミュージアムに対してプライベートなメモを記録することができます。
開発の背景💁
私は昔から博物館・美術館巡りが趣味で、大学でも博物館の学芸員資格を取得しました。
そんな私にとってミュージアムは身近なものでしたが、「もっと多くの人にミュージアムを身近に感じてほしい!」「ミュージアム好きな人が使って楽しめるサービスがほしい!」と思い、このサービスを作りました✨
2. サービスの機能
ログインが不要な機能
❶ミュージアムを検索する🔍
トップページの「ミュージアムを探す」ボタンやメニューバーの「検索」ボタンからミュージアムの一覧ページに飛ぶことができます。
一覧ページの「詳しく検索する」ボタンで、ミュージアム名・都道府県、カテゴリから AND 検索ができます。また、ユーザーの現在の位置情報から最も近いミュージアムも検索できます。
❷ミュージアムの詳細を閲覧する📓
一覧ページでミュージアムのピンをクリックすると、詳細ページを閲覧できます。詳細情報、レビュー、リスト、メモのタブの切り替えができます。
ログインが必要な機能
❶ユーザー登録・ログインをする👤
メールアドレスとパスワードを設定して、ユーザー登録ができます。
また、ログインのハードルを下げるため、Google アカウントや X のアカウントでもログインが可能になっています。
❷ミュージアムを投稿する🗺️
おすすめのミュージアムがあれば、ぜひ投稿してみてください!
投稿ページでは、ミュージアム名を途中まで入力すると、オートコンプリート機能で候補がサジェストされます。候補から選択すると住所が自動的に入力されます。
❸ミュージアムのレビューを投稿する💬
既に訪れたミュージアムがあれば、そのミュージアムの詳細ページからレビューを投稿できます。レビューのコメントと 5 段階の評価を記録できます。
❹ミュージアムをリストに登録する🗂️
投稿されているミュージアムを、自分用のリストに登録することもできます。
デフォルトでは「行きたい」と「行った」リストが用意されていますので、行きたいミュージアムや既に行ったミュージアムをリストで管理してみてください!
それに加えて、任意のリストも新規作成できるので、あなたの好きなようにミュージアムを管理できます。
❺ミュージアムのメモを記録する
ミュージアムに対するプライベートなメモを記録することができます。
既に訪れたミュージアムなどで、何か自分用に書き記しておきたいことがあれば、詳細ページからメモを作成してください。
3. 技術構成
技術スタック🔧
カテゴリ | 技術 |
---|---|
フロントエンド | HTML / CSS (Tailwind CSS + daisyUI) / Javascript |
サーバーサイド | Ruby 3.3.6 / Ruby on Rails 7.2.2.1 |
データベース | PostgreSQL |
インフラ | Render.com / Amazon S3 |
Web API | Maps Javascript API / Geocoding API / Places API |
その他 gem | devise / carrierwave / mini_magick / ransack / kaminari / rails_admin / omniauth |
ER 図💻
画面遷移図📚
4. 参考にした記事
devise でのログイン機能
Google Maps API と連携した投稿機能
ファビコン設定
ページネーション(Tailwind CSS + kaminari)
Render でのスリープ対策
おわりに
画面遷移図・ER図を作成してから 2 ヶ月の期間で、無事主要機能の実装にまでたどりつくことができました!
ご協力いただいた皆様、本当にありがとうございました🙇
これからも技術のキャッチアップに努め、研鑽を重ねていこうと思います💪
ここまでお読みいただきありがとうございました!