/primitive-notion

A CMS-style blog site similar to a Wordpress site, where developers can publish their blog posts and comment on other developers’ posts as well. This app follows the MVC paradigm in its architectural structure, using Handlebars.js as the templating language, Sequelize as the ORM, and the express-session npm package for authentication.

Primary LanguageJavaScriptMIT LicenseMIT

Model View Controller - Tech Blog

License: MIT

A CMS-style blog site similar to a Wordpress site, where developers can publish their blog posts and comment on other developers’ posts as well. This app follows the MVC paradigm in its architectural structure, using Handlebars.js as the templating language, Sequelize as the ORM, and the express-session npm package for authentication.

Blog site Launch application click here

Table of Contents

User Story

AS A developer who writes about tech
I WANT a CMS-style blog site
SO THAT I can publish articles, blog posts, and my thoughts and opinions

Acceptance Criteria

  • GIVEN a CMS-style blog site
  • WHEN I visit the site for the first time
  • THEN I am presented with the homepage, which includes existing blog posts if any have been posted; navigation links for the homepage and the dashboard; and the option to log in
  • WHEN I click on the homepage option
  • THEN I am taken to the homepage
  • WHEN I click on any other links in the navigation
  • THEN I am prompted to either sign up or sign in
  • WHEN I choose to sign up
  • THEN I am prompted to create a username and password
  • WHEN I click on the sign-up button
  • THEN my user credentials are saved and I am logged into the site
  • WHEN I revisit the site at a later time and choose to sign in
  • THEN I am prompted to enter my username and password
  • WHEN I am signed in to the site
  • THEN I see navigation links for the homepage, the dashboard, and the option to log out
  • WHEN I click on the homepage option in the navigation
  • THEN I am taken to the homepage and presented with existing blog posts that include the post title and the date created
  • WHEN I click on an existing blog post
  • THEN I am presented with the post title, contents, post creator’s username, and date created for that post and have the option to leave a comment
  • WHEN I enter a comment and click on the submit button while signed in
  • THEN the comment is saved and the post is updated to display the comment, the comment creator’s username, and the date created
  • WHEN I click on the dashboard option in the navigation
  • THEN I am taken to the dashboard and presented with any blog posts I have already created and the option to add a new blog post
  • WHEN I click on the button to add a new blog post
  • THEN I am prompted to enter both a title and contents for my blog post
  • WHEN I click on the button to create a new blog post
  • THEN the title and contents of my post are saved and I am taken back to an updated dashboard with my new blog post
  • WHEN I click on one of my existing posts in the dashboard
  • THEN I am able to delete or update my post and taken back to an updated dashboard
  • WHEN I click on the logout option in the navigation
  • THEN I am signed out of the site
  • WHEN I am idle on the page for more than a set time
  • THEN I am automatically signed out of the site

Description

A full stack application for a blog site site allowing users to create an account and make blog posts to the application. A user, once signed in is routed to their dashboard where they can add new posts and view all of their existing posts, and make updates or remove posts

login page

Users can also add comments to other users posts once signed in. Each post is appended with a user name, which in the database is appended to an ID that's assigned on creation of an account.

Dashboard

home page

This application is configured with an Express.js API, and uses Sequelize to interact with a MySQL database. It also uses handlebars.js for front-end views and layouts, as well as javascript for interactions

Launch application click here

Installation

Clone the repo to your local development environment.

git clone https://github.com/FAC-73/primitive-notion.git

Navigate to the primitive-notion folder directory using the command prompt.

Run npm install to install all dependencies. in terminal or bash

Run node seeds/index.js to seed the data

Run npm start to run the application in terminal or bash

Use http://localhost:3001 [or whatever terminal port you have specified] in your browser

Licence

License: MIT

Contributing

Kay Davis

Built with

Questions?

GitHub Username:

FAC-73

✉️ Email me:

kaydavis21@googlemail.com

📁 GitHub project repo:

https://github.com/FAC-73/primitive-notion