A Blog App for all Coders, Programmers, and other.
A Bloogo app made using react js as frontend and FastAPI as backend, and Storing data in a MongoDB ulimately also known as FARM Stack APP.
-
Markdown Blogging:
- Description: Users can create and publish blog posts using Markdown syntax for rich and structured content.
-
Tagging System:
- Description: Bloggers can categorize their posts by adding tags, facilitating content organization.
-
Thumbnail Upload:
- Description: Users can upload custom thumbnails for their blog posts, enhancing visual appeal.
-
Advanced Login/Register System:
- Description: Robust user authentication system ensures secure login and registration processes.
-
Cloudinary Integration:
- Description: Images are stored and managed using Cloudinary, a cloud-based media management solution.
-
User Profile Image:
- Description: Users can upload and personalize their profile images.
-
Search Features:
- Description: Users can search for blogs based on various criteria, including content, author, and tags.
-
FastAPI for Automatic Error Handling:
- Description: Utilizing FastAPI library for automatic error handling, ensuring smooth and efficient error resolution.
-
JWT Verification:
- Description: JSON Web Token (JWT) verification is implemented for secure authentication and authorization.
-
Account Verification through Email:
- Description: Users undergo account verification through email, enhancing security and confirming valid user accounts.
Bloogo APP Frontend
Bloogo API Backend
- SMTPlib for sending the email for account verification purpose.
- logo.com for Creating the Bloogo logo.
- write.as Reference for creating the blog. Using The above website design.
- Footer Design Footer Design has been taken from the above website.
- Day.js Used for Formatting the Date recieved From backend.
- React Markdown Viewer For Viewing the blog post.
- Animate.css for Animating some components.
- Formik used for handling client side validation of form data.
- yup used for creating the form schema that can be used with formik.
- Material UI Great UI Components for react, creating the readymade and coding free components.
- React Icons Icons for using in various pages to make user Interaction more attractive.
- React Toastify For adding the Notification to alert the user about any changes made by him.
- React Loader Spinner Using this Library we added the loading components where the loading of data takes place.
- Loading.io Using these website created the Loading.gif for showing with the react loader spinner.
- React Markdown Editor Writing the blog post using these markdown components.
- React Select, Select component with create in it.
- Reading Time Estimator Used for Read the whole blog and estimate the time to read it.
- Error Page Reference From the above website the error page design has been made.
- moment.js JS library for date utility for giving from how many hours or minutes have been over by uploading this blog.
- animista.net For providing the CSS Animations for the Hamburger menu component.
- medium.com Search Page & Blog according to Tag Reference has been taken from Medium.com Website.
-
Day 1 - 17 July 2023
- Project Intialize. ποΈ
-
Day 2 - 18 July 2023
- Gathering Information on how to integrate google login and selecting the correct database. π
- Started working on Backend installed various library. π»
-
Day 3 - 19 July 2023
- Started creating the api
- Created the Folder and Managing various file π
-
Day 4 - 20 July 2023
- Implemented Database and Models π
- Login,Register and Authorization Code β
- Email Verification Code π§
-
Day 5 - 21 July 2023
- Completed Backend for Blog endpoint π»
- Completed Backend for Tags endpoint π»
- Completed Backend for Profile Endpoint π»
-
Day 6 - 22 July 2023
- Implemented full backend only google login is remaining in it. β¨οΈ
- Documented the api backend. π
- Frontend Initialized. π
-
Day 7 - 23 July 2023
-
Day 8 - 24 July 2023
- Created the logo, Favicon for our website.
-
Day 9 - 27 July 2023
- Implemented Header and Home Page or Landing Page.
- Implemented Footer.
-
Day 10 - 28 July 2023
- Implemented About and Developer Page and modified some CSS constraints in Header and Footer.
- Applied the CORS Middleware to the Backend for successful communication with the frontend.
- Implemented Full Page Blog.
-
Day 11 - 29 July 2023
- Implemented the Login and signup page and integrated backend.
- Improved some Authentication in Frontend.
-
Day 12 - 30 July 2023
- Implemented Logout,Profile and Email Verification Pages.
- Implemented Protected Routes.
- Created Account on Cloudinary for image uploading and image resizing.
- Implemented Error Page 404 Not Found Page.
-
Day 13 - 31 July 2023
- Modified Update Endpoint of Backend.
- Added verify token without needing the token in Backend.
- Get Author profile with author related Blogs added in Backend.
-
Day 14 - 1 August 2023
- Modified Profile Avatar in Header.
- Integrated the backend with profile Page.
-
Day 15 - 2 August 2023
- Implemented the Profile Popover.
- Implemented Profile Page
- Forgot Password and change Password Page added.
- Blog Page Added.
- Working on Write Blog Page.
-
Day 16 - 3 August 2023
- Implemented Write Blog Page.
- Implemented API call for Write Blog Page.
-
Day 17 - 4 August 2023
- Optimized the Code for Frequently appearing Dialog Boxes.
- Fixed the Blog Thumbnail Not uploading.
- Reading Time Estimator and Uploaded the blogs in min,hours,day ago in Blog View Page.
- Fixed Jodit Editor for Various Toolbar.
-
Day 18 - 5 August 2023
- Fixed some bugs in Backend related to Date in blog.
- Implemented Dashboard page for login User.
- Delete and Edit button Added for each blog for the user who has created the blog.
- Public Profile page Implemented using which User's can view Bloogo Blog Author Profile.
- Fixed Some Issue related to Profile Picture in Profile Component
- Added the Share button to share the blog with various Social Media.
- Fixed Upload Button Issue in Upload Thumbnail in Create New Blog Page.
-
Day 19 - 6 August 2023
- Added Estimated Reading Time for each Blogcard
- Implemented Edit Page will full Performance Support
- Reduced the Words per minute for Estimate Reading Time
- Added SearchBar in the Header and Implemented Search Home Page.
- Implemented Recent Searches in the Search Home Page
-
Day 20 - 7 August 2023
- Implemented Search Page for Blog.
- Modification in Search page.
- Modification in Dashboard Page.
- Created the Place Holder for Blog Page.
-
Day 21 - 8 August 2023
- Implemented Blog Author Search Page.
- Implemented Profile cards to shown in Author Search Page.
- Simple Modification in Search Page.
- Updated Placeholder for Author Page.
-
Day 22 - 9 August 2023
- Improved Searching for Profiles in backend.
- Implemented Search Tag page.
- Implemented Tag Page.
- Implemented Full Frontend Now Ready to Host.
- Future Work or updates will be worked after availability of app.
-
Day 23 - 10 August 2023
- Implemented Full Page and optimized some images.
- Blog View has been modified.
- Project Completed.
- Deployed the Project.
============= NEW UPDATE LOGS ==============
-
Day 24 - 06 February 2024
- Researching for new Email Sender SMTP.
- Researching of New Editor for blog writing.
-
Day 25 - 07 February 2024
- Implemented the Email Sender SMTP with
smtplib
library of python. - Loading component implemented in various Pages to minimize the pressure on backend.
- Improved functionality when the blog is deleted the whole page is being reloaded so removed the reloaded code.
- Implemented the New Markdown Editor for writing the blogs.
- Now the Images or thumbnails can be directly uploaded to Backend Fastapi integrated the cloudinary in the backend.
- Switched from client side image uploading to server side image uploading.
- Improved the experience with the tag and solved the issue related to selecting the tag.
- Implemented the Email Sender SMTP with
-
Day 26 - 08 February 2024
- Improved the taglist edit blog experience.
- Improved the Profile Image uploading to the backend and frontend.
- Updated and user deleted blog Images deletion service Implemented for optimize the performance of the cloudinary service.
- Added the new Meta Tags to the frontend.
- Change of version from v1.0 to v1.5.0.
- Optimization of Code in the frontend Part.
- New Updates Implemented and completed the Project.
- Deployed The Project.
- Improved performance with optimized frontend and rendering for a smoother user experience.
- Enhanced security by moving image uploading from client-side to server-side.
- Implemented a "Please Wait" component during API calls for login, signup, forgot password, and change password functionalities.
- Users can now delete images from Cloudinary server to minimize storage.
- Eliminated the use of
setTimeout
function from various pages for improved code efficiency.
- Utilized
smtplib
for sending emails, removing dependency on the brevo SMTP server.
- Google Login
- Dark Mode Feature
Guide For running the project locally in your system.
- Clone the Repository
git clone https://github.com/PrathameshDhande22/Bloogo-App.git
- Make Sure You have
python
installed in your system withversion => 3.10.3
Goto backend Folder.
cd backend
-
Simple command it will automatically create the virtual environment and install the packages.
Note : The Poetry package should be installed in our System before triggering the below commands.
poetry install
if any error comes google the error it will Solved.
- Create
.env
file
MONGODB_URI=Your Mongodb URI
SECRET=Jwt secret
EMAIL= Your Email addresss
PASSWORD= Your email address password
LINK=http://localhost:5173 of the frontend.
CLOUD_NAME=cloudinary cloud name
API_KEY=Cloudinary api key
API_SECRET=Cloudinary api secret
UPLOAD_PRESET=Cloudinary Upload preset
- Run
python run.py
ππ Backend is Running Successfully in your System.
- Navigate to Frontend Folder.
cd frontend
- Create .env File in it which contains various Values.
VITE_BASE_API=backend running url
VITE_CLOUD_NAME=cloudinary cloud name
- Install the dependencies.
npm install
- Run the project.
npm run dev
ππ The project setup is complete.