There are many forms of blogs and communications online from Facebook to Instragram to Reddit. However, it is difficult to share an indepth view of any passion an user has. Hobbyist is a web app that acts as a blog for users with a focus on any hobbies they want to share in their many different mediums. User can register and login. Once they are logged in, they can create a blog post with optional field description. The user can view all other users' blogs, all of their own posts, or search for specific content. Users can also like and comment on posts in order for the community to thrive with the ability to delete their own posts.
The application will store Users, Posts, and Comments.
- users can have multiple posts (via references)
- each post can have multiple comments (via references)
- each comment can have only one post and one user who owns the comment (via references)
A User with references to Posts and other Users:
{
name: String,
hash: {type: String, required: true},
posts: [{type: mongoose.Schema.Types.ObjectId, ref: 'Post'}]
}
A Post with references to Comments items and User:
{
user: {type: mongoose.Schema.Types.ObjectId, ref: 'User'},
content: String,
title: String,
category: String,
comments: [{type: mongoose.Schema.Types.ObjectId, ref: 'Comment'}],
createdAt: Date,
likes: [{type: mongoose.Schema.Types.ObjectId, ref: 'User'}]
}
A Comment with reference to User who owns the Comment and the Post the Comment is under:
{
user: {type: mongoose.Schema.Types.ObjectId, ref: 'User'},
content: String,
post: {type: mongoose.Schema.Types.ObjectId, ref: 'Post'}
}
/login - page to login to an exist account
/register - page to create an account
/feed - page which 50 of the most recent posts or posts by users the user follows
/post - page to display a specific post with comments along with like and comment form functionality
/create - page with a form to create a post with an optional image insert field
/profile - page displaying all posts made by the user
- As non-registered user, I can register a new account with the site.
- As a user, I can log in to the site.
- As a user, I want to share my hobbies through posts.
- As a user, I want to see other user's hobbies and activities.
- As a user, I want to like and comment on other user's posts.
- As a user, I want to see all of my posts.
- As a user, I want to delete my posts.
- As a user, I want to search for a specific category of posts.
- (2 points) Bootstrap
- use Bootstrap CSS framework to create a theme
- (6 points) React
- use React as the front-end framework
- (3 points) dotenv
- use dotenv as a configuration management to connect to MongoDB Atlas
- store MongoDB username, password, and url
- configure API endpoints for React from local host to my AWS hosting url api endpoint
11 points total out of 10 required points
Because there is a frontend ReactJS server and a backend ExpressJS server, there are two servers running at the same time. I run both servers at the same time in order for communciations to happen using concurrently and the command npm run dev
in the root directory of the project.
(TODO: list any tutorials/references/etc. that you've based your code off of)
- Concurrently package - used to run both ExpressJS and ReactJS servers at the same time with the React client commuicating with the Express backend server.
- ReactJS frontend with ExpressJS backend - what I used to research how to setup my ReactJS frontend and have it communicate with the ExpressJS backend through API endpoints.
- ReactJS Navbar Reference - used to start my React NavBar and routing implementation.
- ReactJS NavBar Reference - used this as well to learn about React NavBars
- Bootstrap Documentation - reference this to style my applications through buttons, cards, navbar, and more.
- dotenv in React - learned about using dotenv in React