Skip to content

kiyomasa05/cooklog2

Repository files navigation

ポートフォリオ紹介

制作したアプリケーションはこちら
https://cooklog-frontend.herokuapp.com/

(herokuなので初回起動は遅めです。開かなければ少し時間をおいてください)

github
https://github.com/kiyomasa05/cooklog2

(フロントとバックエンドの親フォルダ)

Qiita記事
https://qiita.com/kiyomasa05/items/bfb08e9694ef4fbae5d2

Cooklogというアプリで、自分の作ったレシピや、他人の作ったレシピを確認、お気に入り登録できます。 お気に入りにしておくとマイページで簡単に確認できる:クックパッドのクローンです

なぜこのアプリを作ったかというと  妻を喜ばすためです。 妻に「どんなアプリがあったらいいと思う?」と聞くと、 「(毎日料理を作るので)クックパッドもいいんだけど、お気に入りのレシピが並べて見れるアプリがいい」 とのことなので、UIにこだわり、自作のレシピとお気に入りのレシピが横並びで見れるアプリを作成しました。

レスポンシブ対応もしています

レスポンシブ

ポートフォリオに使用した技術

フロントエンド

  • Docker
  • docker-compose
  • React
  • React-Hook-Form
  • chakra-ui

バックエンド

  • Ruby on Rails (apiモード)
  • MySQL

テスト

  • Jest
  • testing-library
  • Rspec

インフラ

  • heroku
  • AWS S3

コード整形

  • ESlint
  • pretter

CI/CD

  • CircleCi

本番環境ではクライアント側とapi側 別々にデプロイしていますが、ローカル環境ではその親フォルダからDocker-composeで1コマンドで起動できるようにしています。

システム構成図

herokuを利用

名称未設定ファイル.jpg

ER図


Untitled Diagram-Page-1.drawio.png

フロントエンド

名称 説明
React(Create React App) Javascriptフレームワーク
React-Hook-Form フォームバリデーションライブラリ
chakra-ui UIコンポーネント
  • ATOMICデザインを意識したディレクトリ構成になっています。
  • api通信はHooksを使用し、axiosで叩いています。
  • 認証はcookieを利用 
  • React-Hook-Formは正直めちゃくちゃ使いやすかったです。

大変だったのは、

  • rails activestorageを利用した画像の送信
  • cookieを利用した認証
  • providerへのデータ格納とコンパイル調整対応

この辺はエラーを直すのに1,2週間かかってます、、、 (完全独学なので、ググることはもちろん、関連することをUdemyで勉強したり、教材を購入したり大変でした。 メンターも検討しましたが、利用しませんでした。テラテイルが神)

バックエンド

名称 説明
Ruby on Rails(APIモード) apiサーバーとして利用
MySQL データベースマネジメントシステム
  • APIサーバーとしてフロントからのリクエストに対し、JSONデータを返す役割
  • 画像データはActiveStorage経由でS3バケットに保存してます
  • 認証はsessionメソッドを利用(cookie) - ローカル環境での認証は、Firefoxを使用するようにしてください(Chromeではcookieのsecure属性がtrueにならない。 - 本番環境はhttps通信でsecure属性がtrueになるためChromeでも問題ないです

インフラ 

名称 説明
heroku (フロントエンドもバックエンド )PaaS インフラ周りを任せています
  • Dockerを利用した開発しているため、herokuでもDockerコンテナで稼働しています。
  • heroku.ymlという便利なherokuの設定を利用しデプロイしています

CI/CD

名称 説明
CircleCI (フロントエンドもバックエンド )PaaS インフラ周りを任せています
  • github連携しmasterブランチにpushした際にテスト&デプロイするように設定しています。

機能紹介

機能一覧

機能名 説明
ユーザー機能 新規登録、登録内容変更、アバター登録、ログイン、ログアウト
レシピ投稿機能 投稿、編集
レシピ一覧確認機能 タイムライン表示、タイトル検索
お気に入り機能 投稿されたレシピをお気に入り登録、解除

機能詳細

トップページ

ログイン&新規登録への遷移のみ ヘッダーのボタンはログインしているか、していないかで変わるようにしています

スクリーンショット 2022-06-26 9 23 26

スクリーンショット 2022-06-26 10 09 51

新規登録 ログインページ

クライアント側のエラーメッセージはyupとreact-hook-formを使用 アバター写真も設定可能にしています。

新規登録
signup.gif

ログイン

ログイン.gif

ユーザー編集

パスワードは任意で変更できるように設定

useredit.gif

お気に入り登録

投稿レシピ一覧から好きなレシピをクリックするとモーダルにて詳細確認可能 自分が投稿したレシピは編集ボタンが表示され、他人が投稿したレシピにはお気に入り登録ボタンを設置 お気に入りにするとマイページで確認可能になります。

favo.gif

レシピ投稿

写真と材料、手順、時間などを入力 時間のUIはスライダーとカウンターを採用

レシピ投稿.gif

レシピ編集

(初期値の設定に苦労しました、、)
編集.gif

レシピ検索

タイトル検索です。

検索.gif

local での起動方法

作業ディレクトリ(cooklog)で

docker-compose build を実行し docker-compose up -dでコンテナを起動 必要に応じて、docker-compose logsでエラーを確認

イメージを作り直した時は、 docker-compose run api rake rails db:create db:migate でデータベースも作成する必要がある

コンテナが起動したら localhost:3000 で rails のトップページ localhost:3001 で react のアプリに接続できます

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published