Skip to content

Pot Overflow is a question and answer website for professional chefs and cooking enthusiasts to troubleshoot, improve, and share dishes and recipes with each other.

Notifications You must be signed in to change notification settings

zanehamadi/Pot-Overflow

Repository files navigation

Pot Overflow

By Sean Cotter, Zane Hamadi, Jacky Hao

Visit Pot Overflow

Summary

Pot Overflow is a web application, inspired by Stack Overflow, that allows users to:

  • log in/log out/demo app

  • ask questions

  • answer questions

  • search for questions

  • upvote/downvote questions

Technologies Used:

Backend: Pot Overflow was built utilizing the Express framework for Node.js and the PostgreSQL RDBMS. The API was created following RESTful conventions and data is sent from and received by the API as JSON payloads.

Frontend: Pot Overflow was built entirely in Vanilla JS and utilizes Pug.js as the HTML templating engine for rendering frontend views.

Languages: HTML, CSS, JavaScript

Database Structure

dbdiagram.pngdbdiagram

Pot Overflow in Action

Home Pagehomepage

Home Page When Logged Inloggedhomepage

Questions Pagequestions

Specific Question Page question

Log In Page login

Register Page register

Key word search search

Implementation Details

  • An important feature of Pot Overflow is the ability for users to search for questions related to their own to look for existing answers, rather than ask a previously asked question again. Upon a form submission, the Pot Overflow API destructures the search request and checks each word in the request against existing questions in the database, rendering and returning matching questions through a Pug template. Sequelize, a promise-based Node.js ORM (object-relational mapping) allows for interaction with the Postgres database using Javascript rather than SQL.
router.post('/', asyncHandler(async (req, res, next) => {
    const { searchBar } = req.body
    let words = searchBar.split(" ")
    let qArray = []
    let idArray = []

    for (let i = 0; i < words.length; i++) {
        const questions = await Question.findAll({
            where: {
                question: {
                    [Op.substring]: words[i]
                }
            },
            include: [User, Upvote, Downvote]
        })

        if (questions[0] && !idArray.includes(questions[0].id)) {
            idArray.push(questions[0].id)
            qArray.push(...questions)
        }
    }
    
    res.render('search', { qArray })
}))
  • Another important detail lies in dynamically rewriting the current web page with new data from the server when a user upvotes a question or answer, downvotes a question or answer, and answers a question. These features rely on awaiting a fetch request to the API and updating the view, based on data returned from the server, using DOM manipulation.
const post = await fetch(`/questions/${questionId}/answers`, {
                method: "POST",
                headers: {
                    "Content-Type": "application/json"
                },
                body: JSON.stringify({
                    answer,
                    _csrf
                })
            })

const newAnswer = await post.json();
const tr = document.createElement('tr');

tr.innerHTML = `
   <td><div class="buttons">
   <button id= upvote-${newAnswer.newAnswer.id} class="answerUpvoteButtons"><i class="far fa-thumbs-up fa-lg"></i> ${newAnswer.newAnswer.Upvotes.length}</button>
   <button id= downvote-${newAnswer.newAnswer.id} class="answerDownvoteButtons"><i class="far fa-thumbs-down fa-lg"></i> ${newAnswer.newAnswer.Downvotes.length}    </button>
   </div>
   </td>
   <td>${newAnswer.newAnswer.answer}</td>
   <td>${newAnswer.newAnswer.User.username}</td>
   <td>${new Date(newAnswer.newAnswer.createdAt).toDateString()}</td>
`;

tableContainer.appendChild(tr)

Final Thoughts

  • This project presented it's fair share of challenges!
  • The major highlights would be:
    • implimenting our first search bar,
    • adding answers to our page with DOM manipulation,
    • authentication including a demo user,
    • dynamic voting on both questions and answers
  • We were very fortunate to have an excellent team to tackle this project! Communication was always first priority and allowed us to be very efficient. We had completed, except for a few bugs, our entire feature list in less than 24 hours. Any member of this team is worth their weight in GOLD, I can't wait to see what we can accomplish in the future.

About

Pot Overflow is a question and answer website for professional chefs and cooking enthusiasts to troubleshoot, improve, and share dishes and recipes with each other.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •