Skip to content

Pantry makes use of Nuxt.js & Spoonacular API to offer a user-friendly platform for exploring various dishes. It empowers users to store their favorite recipes; granting prompt access to revisit the exciting world of culinary delights anytime.

Notifications You must be signed in to change notification settings

ciarantr/pantry

Repository files navigation

Pantry

mockup

Pantry connects our users directly with Spoonacular API. View an amazing range of recipes as well as nutritional information. Save your recipes to view later in greater detail, everything from the paleo diet to your favorite chocolate desserts.


UX 🎨

User stories

As a user, customer I would like to the following:

✅ successfully implemented
❌ not yet implemented

  • ✅ View recipes & nutritional information.
  • ✅ Save favorite recipes.
  • ✅ View social media links.
  • ✅ View about section to find out more about Pantry.
  • ❌ Add persistent storage for user saved recipes (Database for users saved recipes)
  • ❌ Add caching layer for improved performance (Memcached or Redis)
  • ❌ Improve SEO on site.

Typography

  • I chose to use default browser fonts & not to use a custom font.

Features

1. View saved recipe

FEATURE 1 SCREENSHOT

  • Users can view their saves recipe

2. View recipe nutritional information

FEATURE 1 SCREENSHOT

  • Users can view recipes in greater detail

3. Users can navigate with mobile menu

FEATURE 1 SCREENSHOT

  • Users can view recipes in greater detail

Future features 🔮 May 2023

  • ❌ Add persistent storage for users favorite recipes
  • ❌ Improve SEO (Add open graph meta information).
  • ❌ Add account page for users:
    • User can view account information
    • User can view, create & edit own recipes
  • ❌ Improve security:
    • Add Content Security Policy (further research needed).
  • ❌ Add unit testing & CI workflow (further research needed)

🔝 Back to Top


Technologies ⚙️

Web development

Design

Front-End Technologies

  • HTML5

    • Markup language used within VueJS templates.
  • CSS3

    • Used to style elements within pages & add transition effects.
  • JavaScript

    • Used to add reactivity.
    • From validation (client side)
    • Return data based on query parameters

Ui Library / CSS framework

  • Tailwind css
    • Tailwindcss 🔗 (Used to enhance workflow & improve maintainability of CSS).

JavaScript Library

  • VueJs
    • Vue.js 🔗 (The Progressive JavaScript Framework)
    • Reactivity.
    • Reusable components.

JavaScript Framework

  • NuxtJS 🔗 (The Intuitive Vue Framework)
    • Used for server side rendering.
    • Enhanced SEO.
    • Image optimization.
    • Code optimization (minified CSS & JavaScript).
    • State management.

Additional modules to extend NuxtJs 🔌

  1. NuxtJS Modules 🔗 (Extends NuxtJS functionality)

    • Nuxt Icon 🔗 Used to generate Icons for project.
    • Nuxt image 🔗 Used to optimize images for variable screen sizes & convert to webp image format.
  2. VueJS devtools 🔗 Used to inspect debug VueJS (performance issues & reactivity issues)

🔝 Back to Top


Testing 🧪

1. Page speed metrics & SEO analytics CSS (ADD SCREENSHOTS)

Google page speed insight (Used for testing performance & SEO) 🔗

Desktop

Home page speed test

Home page speed test


2. Browser Testing

Google Chrome Dev (v.108.0.5343.2)

Used to check for console & API errors, also checked responsiveness for screen widths 300px - 1250px on all pages

✏️ Note

knowledge of unit testing is limited, application will need unit testing at later date.

ℹ️ INFORMATION

NuxtJS & Vite provide excellent development experience & detailed errors in development.

  • Check for JavaScript errors
    1. All known errors resolved in development.

External Validation Testing HTML | CSS | JavaScript

🔥 Important

HTML & CSS validation returns 48 CSS parsing errors. This issue is discussed by the maintainer of Tailwindcss & has provided a solution however, I cannot use the recommended fix as I use scoped styles within VueJS. This will break styles used within the application. Remove --tw- variables from universal selector #7317 🔗

1. HTML

W3C Markup Validation 🔗 (Validate HTML)

Home page html validation

html validation

2. CSS

W3C CSS Validation 🔗 (Validate CSS)

Home page CSS validation

Home page CSS validation

3. JavaScript

JS Hint 🔗 (Validate JavaScript)

I added the following rule to ignore missing semicolons and test for ECMAScript 9 support.

/* jslint asi: true, esversion: 11 */
All pages & components

All pages & components

Development Automated Testing | Linting

🔥 Important

NuxtJS auto imports VusJS components, Eslint will display no-undefined warnings, I have yet to find a fix for this.
Nuxt Auto imports 🔗

VueJS & JavaScript

I added Eslint & Eslint-plugin-vue to validate & check for errors during development as well as follow VueJS best practices based on VusJs style guide. Linting errors are shown in visual studio code terminal.

  1. Eslint Plugin Vue

🔝 Back to Top


Deployment 🚀

✏️ Note

This project is currently deployed on Heroku. A planned migration too Cloudflare will take place in January 2023. Cold starts on Free Heroku dynos can take a moment to load.

The project is live now @ https://pantry-ci.herokuapp.com 🔗

Local Deployment 🛠️

🔥 Important

You will need the following installed on your system 🖥️ You will also need to sign up to Spoonacular to obtain a api key. After that simply add a .env file and add the following key SPOONACULAR_API_KEY= along with your api key

Note: There is a limit on the free tier which can be met very easily. Consider caching responses so you don't surpass the daily limit.

✏️ Note

if you would like to use npm you will need to delete yarn.lock file after cloning the repository

  1. Clone repository in desired directory

    • HTTPS
    git clone https://github.com/ciaran-io/pantry.git
    • SSH
     git clone [email protected]:ciaran-io/pantry.git
    • GitHub CLI
     gh repo clone ciaran-io/pantry
    • Download Zip - Click Download Zip option from dropdown from the CODE menu
  2. Install project dependencies:

✏️ Note

This will create a node_modules folder with all the project dependencies

For yarn installation

yarn install

For npm installation

npm install
  1. Start development server

✏️ Note This should open the application on localhost:3000 if port 3000 is free. (Check terminal if in doubt)

For yarn installation

yarn dev

For npm install

npm run dev

💁 Tip

If you use Visual Studio Code I recommend installing the following plugins.

  • Tailwind CSS IntelliSense 🔗

    ℹ️ Information

  • Tailwind CSS IntelliSense enhances the Tailwind development experience by providing Visual Studio Code users with advanced features such as autocomplete, syntax highlighting, and linting.

  • Vue Language Features (Volar)

    ℹ️ Information Fast Vue Language Support Extension

  • Vue VSCode Snippets

    ℹ️ Information These snippets were built to supercharge a workflow in the most seamless manner possible.


Remote Deployment 🏗

View NuxtJS documentation to view all available supported hosting providers find out more

Deploying using Heroku

  1. Create a Heroku account or log in.

  2. Create a new app & select a region closets to you or your audience.

  3. Deployment

  • From Cli

    1. Create a new Heroku app.
    heroku create myapp
    1. Configure Heroku to use the nodejs buildpack.
    heroku buildpacks:set heroku/nodejs
    1. Configure your app.
     heroku config:set NITRO_PRESET=heroku
    1. Ensure you have start and build commands in your package.json file.
    "scripts": {
      "build": "nuxt build",
      "start": "node .output/server/index.mjs"
    }
  • In Heroku dashboard

    1. In settings tab in Heroku add the following inside the Config Vars
    Config Vars
    NITRO_PRESET heroku
    SPOONACULAR_API_KEY YOUR_API_KEY
    1. Next go to Buildpacks and select Add buildpack then select nodejs.
    2. Finally go to the deploy tab on Heroku & click the GitHub as deployment method. The app will no be automatically deploy when you push to GitHub. You can also use the manual deploy option if Heroku did not create a build.

💁 Tip**

You can preview the app in a production ready environment.

  1. Build the application
yarn build
  1. Preview the application in production ( command sets process.env.NODE_ENV to production )
yarn preview

Congratulations you are now ready to successfully deploy the application. 🥳

🔝 Back to Top


Credits 💌

Content 📰

Media 📽️

About us banner image.

Home page banner image.

Home page recipe dish image.

User saved recipe page banner image.

Acknowledgements 🙏

  • @ Tim
    • My Code Institute mentor.
      • Practical advice ✅
      • kept me on track ✅
      • Can't thank him enough ✅
      • Clear guidance & mentorship ✅

🔝 Back to Top

About

Pantry makes use of Nuxt.js & Spoonacular API to offer a user-friendly platform for exploring various dishes. It empowers users to store their favorite recipes; granting prompt access to revisit the exciting world of culinary delights anytime.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published