https://github.com/chandan8018/brainwave_matrix_intern
This Blog Web Application allows admins to manage blog posts and user comments, while users can read, comment on blogs, and manage their profiles. The application supports Google Authentication and traditional credential-based authentication.
https://github.com/chandan8018/brainwave_matrix_intern
express-js flowbite mangodb moment mui-material nodejs react-hooks react-router reactjs redux-persist redux-toolkit tailwind-css
Last synced: 8 days ago
JSON representation
This Blog Web Application allows admins to manage blog posts and user comments, while users can read, comment on blogs, and manage their profiles. The application supports Google Authentication and traditional credential-based authentication.
- Host: GitHub
- URL: https://github.com/chandan8018/brainwave_matrix_intern
- Owner: Chandan8018
- Created: 2024-08-17T18:31:42.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-10-05T01:27:54.000Z (5 months ago)
- Last Synced: 2025-02-09T14:38:28.344Z (12 days ago)
- Topics: express-js, flowbite, mangodb, moment, mui-material, nodejs, react-hooks, react-router, reactjs, redux-persist, redux-toolkit, tailwind-css
- Language: JavaScript
- Homepage: https://chandanblog.onrender.com/
- Size: 2.17 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# ThinkBig's Blog Web Application
This Blog Web Application allows admins to manage blog posts and user comments, while users can read, comment on blogs, and manage their profiles. The application supports Google Authentication and traditional credential-based authentication.
## Features
### Admin Features:
- **Add, Update, and Delete Blogs:** Admins can create new blog posts, update existing ones, and delete blogs.
- **Manage Comments:** Admins can edit and delete any comments left by users on blog posts.
- **User Management:** Admins have the ability to delete user accounts.### User Features:
- **Read Blogs:** Users can browse and read published blog posts.
- **Comment on Blogs:** After authenticating, users can leave comments on blog posts.
- **Edit and Delete Own Comments:** Users can edit or delete their comments on blog posts.
- **Profile Management:** Users can update their profile picture, name, user ID, and password.
- **Search:** Users can search with titel of blog post.## Authentication
- **Google Authentication:** Users can log in using their Google account.
- **Traditional Credentials:** Users can also create an account using their email and password.## Tech Stack
- **Frontend:** React.js, Tailwind CSS / Material-UI
- **Backend:** Express.js, Node.js
- **Database:** MongoDB / MySQL (based on preference)
- **Authentication:** Passport.js for Google OAuth and traditional login
- **ORM:** Prisma ORM (for MySQL setup) or Mongoose (for MongoDB setup)
- **State Management:** Redux (for managing global state)## Installation
1. Clone the repository:
```bash
git clone https://github.com/Chandan8018/ChandanBlog.git
cd blog-web-app
```2. Install dependencies:
```bash
npm install
```3. Set up environment variables:
- Create a `.env` file in the root directory.
- Add the following variables:
```env
PORT=3000
DB_URL=mongodb://localhost:27017/blogwebapp
SESSION_SECRET=your-session-secret
```4. Run the application:
```bash
npm run dev
```5. Visit `http://localhost:3000` in your browser to access the application.
## Usage
### Admin Panel
- Accessible to users with admin privileges.
- Manage blogs and user comments directly from the admin dashboard.### User Dashboard
- Users can view and update their profile.
- Users can manage their comments on blog posts.### Blog Viewing
- Any authenticated user can view blogs and leave comments.## API Endpoints
### Authentication
- `api/auth/google`: Google OAuth authentication.
- `api/auth/login`: Traditional email and password login.
- `api/auth/signup`: User registration.### Blog Management (Admin)
- `POST /api/post/create`: Create a new blog.
- `GET /api/post/getposts`: Get all blogs post.
- `PUT /api/post/updatepost/:postId/:userId`: Update an existing blog.
- `DELETE /api/post/deletepost/:postId/:userId`: Delete a blog.### Comment Management
- `POST /api/comment/create`: Add a comment to a blog.
- `GET /api/comment/getPostComments/:postId`: Get all post comment on array.
- `PUT /api/comment/editComment/:commentId`: Edit a comment.
- `PUT /api/comment/likeComment/:commentId`: Likes comment.
- `DELETE /api/comment/deleteComment/:commentId`: Delete a comment.### User Management
- `GET /api/user`: Fetch user details.
- `PUT /api/user/update/:userId`: Update user profile.
- `DELETE /api/user/delete/:userId`: Delete user.
- `POST /api/user/signout`: SignOut User.## Demo
- Home Page
data:image/s3,"s3://crabby-images/8d584/8d58443626b10215c85819e8dab2cc2bc55b15d6" alt="Home Page"
---
- Sign-Up Page
data:image/s3,"s3://crabby-images/9182f/9182f15942f8277a4cd73e158660aa5222baf45f" alt="Sign Up"
---
- Sign-In Page
data:image/s3,"s3://crabby-images/b023d/b023d4abe8f66c519473a265af4e2d16a869f1c1" alt="Sign In"
---
- Admin Dashboard Page
data:image/s3,"s3://crabby-images/1ee1a/1ee1a610c95e5306d69c217699ba5f50773c1aac" alt="Admin Dashboard"
---
- User Profile Page
data:image/s3,"s3://crabby-images/2713a/2713a54d8518de960381c92f12518128435c8473" alt="User Profile"
---
- Blogs Page
data:image/s3,"s3://crabby-images/5719c/5719ca9083527c9a02333944f4de3f2939f9680c" alt="Blogs"
---
- Create Blog Page
data:image/s3,"s3://crabby-images/9a6cf/9a6cff1dc81d4b329b03067fabf9fe8413b460e6" alt="Create Blog"
---
- Users Page
data:image/s3,"s3://crabby-images/afb20/afb201fdda706b6c11a2e067d65b9a6156b854ed" alt="Users"
---
- Comments Page
data:image/s3,"s3://crabby-images/e7f19/e7f19d5e9d282c6e7ed2c4c20642b14ed99588b9" alt="Comments"
---
## Contributing1. Fork the repository.
2. Create a new branch (`git checkout -b feature/your-feature-name`).
3. Commit your changes (`git commit -m 'Add some feature'`).
4. Push to the branch (`git push origin feature/your-feature-name`).
5. Open a Pull Request.## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
## Contact
For further inquiries, feel free to reach out to me at [[email protected]](mailto:[email protected]).