Skip to content

Latest commit

 

History

History
126 lines (74 loc) · 6.64 KB

README.md

File metadata and controls

126 lines (74 loc) · 6.64 KB

Post Thoughts

This is a content and comment web app built with react and redux. Users can post content to predefined categories, comment on their posts and other users' posts, and vote on posts and comments. Users are also able to edit and delete posts and comments.

This app is deployed with Netlify and can be accessed here: post-thoughts.ramizrahman.com

Netlify Status

View a demo of the app on youtube:

Demo of 'Post Thoughts' by Ramiz Rahman

Purpose

This content and comment structure is common across a large number of websites and applications, from news sites to blogs to aggregators like Hacker News and Reddit. My purpose with building this app was to gain an understanding and demonstrate how React and Redux can function in a standard type of application.

I've also structured my React components in a modular way so that they can used as a starter kit for building similar kinds of applications in the future.

Installation

The app is already deployed so you can play around with the final product using this link.

If you wish to run this app locally, clone this repo and install the dependencies.

$ git clone https://github.com/ramiz-rahman/post-thoughts-frontend.git
$ cd post-thoughts-frontend
$ npm install

The backend server is a modified fork of udacity's readable demo server that is deployed using heroku.

As the heroku server is running on a free dyno, for best performance I would strongly recommend installing the server locally and then replace the line 9 in the src/utils/PostsApi.js file:

const api = 'https://ramiz-post-thoughts-api-server.herokuapp.com';

with the following:

const api = 'http://localhost:3001';

The server's endpoints are used to manage storing, reading, updating, and deleting data for the application.

Learn More

This project was bootstrapped with Create React App.

You can learn more in the Create React App documentation.

To learn React, check out the React documentation.

App Conventions

The app is grouped into components and containers. The key difference between the two are that containers connect directly to the Redux store whereas components do not. They are separated into two different folders: src/components and src/containers. However, both of these groups follow these common conventions:

  1. Each component or container is contained in its own folder.

  2. The folder is named in PascalCase.

  3. The folder contains a minimum of two files - a <ComponentName>.js file and a <ComponentName>.module.css file.

  4. The <ComponentName> is the same as the folder name and is written in PascalCase.

  5. The <ComponentName>.js file imports React and a styles object from the <ComponentName>.module.css file.

  6. The <ComponentName>.module.css file imports the src/styles/colors.css file that contains css variables. This is used to ensure that app colors are consistent across all components and can be updated from one place only, thus making the code more reusable and dry. The idea can be extended for layouts and typography as well but I felt it was not needed for this app.

  7. The <ComponentName>.module.css file only contains rules for classes which are written using an alternate style naming scheme of BEM that is described as follows:

    • Blocks are written in PascalCase and must match the name of the corresponding component.
    • Elements are also written in PascalCase and separated from the block using double underscores (__). eg. ComponentName__ElementName.
    • An element is always part of a block, not another element.
    • Modifiers are written in lowercase.
    • The modifier name is separated from the block or element name by a single underscore (_). eg. ComponentName_modifername_modifiervalue

The index.css file uses a modified version of Bootsrap's reboot.css file. This is used to ensure that the styling remains consistent across different browsers.

App Functionality

The app has three primary views as defined below:

Category view

This is the default (Root) view of the app with all being the default category. It contains an action bar and a list of all posts.

all categories

The action bar itself contains a list of all available categories, which when clicked, takes you to the category view for that category.

selected category

The action bar also contains a control for sorting the list of posts. The controls are defined as follows:

  • Top Rated: Sorts by the votescore in descending order
  • Controversial: Sorts by the votescore in ascending order
  • Latest: Sorts by timestamp in descending order
  • Oldest: Sorts by timestamp in ascending order

sort in action

The action bar also contains a button that navigates you to the Create Post View.

Create/Edit Post View

The Create or Edit Post view changes based on how it was reached. If it was reached using the create button, then the form displayed is empty and you have to fill everything up.

create post

If you had navigated this to this view by clicking on the edit button of a post, then the details of the post would have already been filled up.

edit post

Post Details View

Click on the body of a post from the category view to navigate to the post details view. Here you can see the post along with a form for adding a comment and a list of comments for that post.

To add a comment, type into the comment box and click the comment button

add comment

Once the comment is saved, it will appear in the list of comments.

comment list

Like posts, comments can be upvoted or downvoted, edited and deleted.

License

My Reads is released under the MIT License