Welcome to the Restaurant App project! This application serves as a dynamic learning platform aimed at helping developers master modern web technologies such as React, Sass, TypeScript, and more.
The primary goal of this project is educational. It provides a practical sandbox where developers can experiment with real-world technologies and methodologies. Whether you’re new to web development or looking to sharpen your skills, this project is an excellent place to start.
This app incorporates cutting-edge development practices and design systems, including:
- 🏗️ Atomic Design: Create components that scale.
- 🎨 Sass: Write maintainable and flexible stylesheets.
- 🔒 TypeScript: Static typing for robust code.
- ⚡ Next.js: Server-side rendering for optimized web apps.
- ✅ Conventional Commits & Commitizen: Maintain clean and standard commit messages.
- 📖 Storybook: Visual development and testing of UI components.
- 🛠️ BEM Methodology: Organize your CSS for scalability.
- 🎯 CSS Modules: Isolate CSS to avoid clashes.
- 🧪 Jest: Efficient unit testing for JavaScript code.
- 🔍 Cypress: End-to-end testing made simple.
- 🏎️ User-Centric Performance Metrics: Improve your app’s user experience.
Check out the interactive Figma design for a visual preview of what we’re building!
Follow these steps to set up the project locally and start exploring:
-
Clone the repository:
git clone https://github.com/bruno-keiko/Restaurant-app.git
-
Navigate to the project directory:
cd restaurant-app
-
Install the dependencies:
npm install
-
Start the storybook for component exploration:
npm run storybook
-
Run the development server:
npm run dev
This project is your playground! Experiment with the codebase, modify components, and try out new features. The app is intended to help you practice and refine your web development skills, so feel free to explore and extend the functionalities.
Here are a few suggestions to get started:
- Modify Components: Customize existing components or add new ones to better understand how component architecture works.
- Experiment with Styling: Use Sass or CSS Modules to experiment with different styles and see the impact on the app’s design.
- Add New Features: Implement new features such as a shopping cart, user authentication, or a menu page to challenge yourself.
- Testing: Write unit tests using Jest and end-to-end tests with Cypress to ensure your code is reliable and bug-free.
Don't hesitate to break things and learn from the process—that’s the essence of this project!
We welcome contributions from developers of all skill levels! Whether you're fixing a bug, adding new features, or improving documentation, your help is appreciated.
To contribute:
- Fork the repository.
- Create a new branch for your feature or fix:
git checkout -b feature-or-fix-name
- Make your changes and commit them using Conventional Commits:
git commit -m "feat: describe your changes"
- Push your branch:
git push origin feature-or-fix-name
- Open a pull request and describe the changes you made.
Please refer to the CONTRIBUTING.md file for more details on how to get started.
This project exists thanks to all the amazing people who have contributed! Check out the Contributors Graph to see everyone who has helped out.
This project is licensed under the MIT License, meaning you’re free to use, modify, and distribute this software as long as the original license is included. For more information, please see the LICENSE file.