Script Symphony is a coding blog site where users can write, manage, and publish blog articles. It fetches data from a backend server, allowing users to perform various actions such as creating, updating, and deleting articles. Articles are written in Markdown format and can include metadata such as title, author name, description, tags, cover image, and content.
Note: This rebo has a backend, you can access it from Here
- Folder Structure
- Features
- Technologies Used
- Setup
- Environment Variables
- Available Scripts
- Usage
- Notes
- Contact
├───.vscode
├───dist
│ └───assets
├───public
└───src
├───assets
├───components
│ ├───aboutComponents
│ ├───articleComponents
│ ├───ArticleFormComponents
│ ├───footer
│ ├───header
│ ├───homeComponents
│ │ ├───allPosts
│ │ ├───pagination
│ │ └───recentPosts
│ ├───navBar
│ └───userFormComponents
├───context
├───features
│ ├───article
│ ├───articles
│ └───user
├───hooks
├───pages
├───scss
│ └───variables
├───utilities
└───validation
-
Article Management:
- Create, edit, and delete blog articles.
- Write articles using Markdown format.
- Manage article metadata such as title, author, description, tags, and cover image.
-
Dashboard:
- View all articles with pagination.
- Track the total number of articles and views.
- Navigate between pages and sort articles by date or views.
-
Authentication:
- User authentication system to secure access to the dashboard.
- Login/logout functionality with form validation.
-
Theme Switcher:
- Option to toggle between light and dark themes.
- Enhances readability and user experience based on user preference.
-
Additional Features:
- API integration for fetching article data from the backend.
- Markdown preview for real-time article editing.
- Responsive design for optimal viewing across devices.
- React
- Material-UI for UI components
- Redux Toolkit for state management
- React Router DOM for routing
- react-markdown for rendering Markdown content
- react-icons for icons
- react-toastify for notifications
- Axios for making HTTP requests
- vite for build.
-
Clone the repository.
git clone https://github.com/ibrahim11elian/My-Blog.git
-
Navigate into the project directory.
cd My-Blog
-
Install dependencies using npm.
Using npm:
npm i
-
Start the development server.
npm start
The application will be accessible at http://localhost:5000
.
To run this project, you will need to add the following environment variables to your .env file. Make sure to replace the values with your own configuration:
VITE_API_URL={Your API URL}
This variable specifies the API URL used for fetching data from the backend server. You need to replace {Your API URL}
with your API URL
Note: The Backend repository is currently Available at Github.
- start: Starts the development server.
- build: Builds the project for production.
- lint: Lints the code using ESLint.
- preview: Previews the production build locally.
- Login to access the dashboard(Admin only).
- Create, update, or delete articles as needed.
- Write articles using Markdown syntax.
- Add metadata such as title, author name, description, tags, and cover image.
- View article statistics on the dashboard.
- Ensure proper authentication and authorization mechanisms are implemented to secure user data and prevent unauthorized access.
- Handle errors and edge cases gracefully to provide a smooth user experience.
- Follow best practices for writing clean, maintainable code and optimizing performance.
- Regularly update dependencies to leverage new features and security patches.