A modern blog platform with Markdown support
Get straight to the business? Visit Writistry
Writistry is a MERN full stack personal blog. This site was built in a day With React, Redux, CSS libraries, and supports markdown. Visitors can view my blog posts in descending chronological order, and as the owner, I can create new posts through a custom built admin UI. Additionally, visitors who sign up for an account get access to quick-launch share-to-Twitter links to pass their favorite posts along to friends and followes. More member features, suchas likes and commenting are in development.
AS A developer with a story to tell and new knowledge to share,
I WANT to log in to my personal blog and spin up a new post on the fly,
SO THAT I can quickly share it with the world!
To start your own instance, clone this repository and run npm install
from the
root directory. Then cd client
and run another install to complete the
dependencies.
I built this app to store data using MongoDB Atlas cloud hosting. Please
see their docs for information regarding
setting up a cluster for this app. You will need to create a .env
file and
save your MONGO_URI to the file. Authorizing users relies on tokens from node
package jsonwebtoken. When setting
up tokens, remember to drop your JWT_SECRET into the .env
. Lastly, I utilized
react-markdown to add simple
markdown support. GitHub-flavored markdown and syntax highlighting for code
blocks are in the works for future deployments.
To develop and run the app:
- Local Instance: To test and develop locally, open a Node enabled
terminal window, navigate to the root directory and run
npm run dev
to start the servers listening and connect to MongoDB. Unless altered, all data will hit your cloud database by default. This script tells npm Concurrently to start both servers listening at ports 3000 and 5000 respectively. Launch your browser, navigate tolocalhost:3000
and begin using Writistry! - Web Instance: Connect your MongoDB cloud cluster to you preferred cloud platform for website hosting. I used Render to deploy this app, go here to checkout 👉 Writistry in action.
Users start their experience at the landing page, where they can catch a quick view of the app. A link to the Feed with all blog posts is prominent on the home page. On the Feed, each post appears as a short teaser card that can be clicked to view the full post. Sign in & Sign up pages are linked in the navigation and at the bottom of blog posts for users that are not logged in. The blog posts will always be available for anyone to read without signing up. Future fun interactions are planned for members!
Admins can publish and update blogs, with delete coming soon. Admins will remain a private affair for now, but the basic architecture for building this into a site where users can become authors themselves is in place. Super stretch goals? 🤔
- Delete Posts
!important
Admin priviledge coming very soon. - Likes, Comments & Bookmarks For signed up users.
- GitHub-flavored Markdown & Syntax Highlighting Because code should be pretty.
- Search For your favorite post by keyword.
- UI Improvements It looks nice now, but could be more eye catching.
MIT • (If you fork and recreate this, please be kind and rebrand your version!)
- React, React-Redux and React-Bootstrap
- MongoDB, Express and Node
- react-markdown
- bcryptjs and jsonwebtoken for authentication
- David Metcalf
- GitHub: gloriousLoaf
- hello@metcalf.dev