Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/samuelematias/shopping-cart

🛍️ Menu items that you can add it to your Shopping cart.
https://github.com/samuelematias/shopping-cart

expo javascript jest react-native react-native-testing-library react-native-toast-message react-navigation

Last synced: 19 days ago
JSON representation

🛍️ Menu items that you can add it to your Shopping cart.

Awesome Lists containing this project

README

        

# Shopping Cart

## Demo

https://github.com/user-attachments/assets/fda5b193-2278-46e7-9703-33ddb101edcc

## Tech Stack

- [React Native](https://reactnative.dev/)
- [JavaScript](https://developer.mozilla.org/pt-BR/docs/Web/JavaScript)
- [Expo](https://expo.dev/client)
- [React Navigation](https://reactnavigation.org/)
- [React Native Toast Message](https://github.com/calintamas/react-native-toast-message/tree/main)
- [React Native Testing Library](https://callstack.github.io/react-native-testing-library/)
- [Jest](https://jestjs.io/)
- and more!

## About

In this app, You can see your Menu items and add them to your Shopping cart.

> 💡 This project has a simple CI pipeline, to analyze the code and run the unit and ui tests.
For more information, check the [ci.yaml](https://github.com/samuelematias/shopping-cart/blob/main/.github/workflows/ci.yml) file, which has the whole process explained in detail, step by step.

## Project

- This project revolves around building a simple menu and shopping cart.
- The user can add items from the menu to the shopping cart:

https://github.com/user-attachments/assets/e31e1993-c418-493e-ab80-be70ff2b6dba

- The user can change screens to the shopping cart:

https://github.com/user-attachments/assets/40d75da1-8b89-48db-abfc-bc5d4b425cba

- The shopping cart will have all the items that were added from the menu screen and an 'amount' display object showing the number of times that item was added to the shopping cart:

https://github.com/user-attachments/assets/8f895435-9fdc-41f4-a7f9-ad8aa3277217

- Users should have some feedback that an item was added to the cart:

https://github.com/user-attachments/assets/2b11c809-cea4-4dfe-a7ee-72b6f4d56a06

- There should be a (+) button to add 1 to the amount for an item and a (-) button to subtract 1 from the amount:

https://github.com/user-attachments/assets/5b499c7c-aea9-4895-b151-0a8c0a81fd51

- The shopping cart should also include the base price of the item, and the total price (base x amount):

https://github.com/user-attachments/assets/9532c1c3-db16-4159-a5fe-e5b64c54928a

- When an item in the shopping cart reaches 0 amount, it should be removed from the shopping cart:

https://github.com/user-attachments/assets/eb9dcc84-6d71-4204-9ac8-de9637033700

- There should be a total cost that is a sum of all the items (x the amount) in the shopping cart displayed at the bottom:

https://github.com/user-attachments/assets/4c8e41eb-3172-43eb-8ddb-f16d0f824539

## Next Steps (Future changes)

- Improve State Management
What: Maybe, introduce a global state management solution, like Redux, to handle more complex state across multiple components and screens, depending on the scale of the app;
How: Refactor the current context or state management logic into a more scalable structure.

- User Authentication
What: Add user authentication (e.g., login, signup) to allow personalized shopping experiences;
How: Integrate OAuth or JWT authentication using Firebase, Auth0, or another authentication service.

- Persistent Storage (Offline Mode)
What: Enable offline mode with persistent storage so that users can add items to their cart even without an internet connection;
How: Use libraries like AsyncStorage or SQLite to locally save the cart and other user data. Synchronize data with the server when the user goes back online.

- Internationalization (i18n)
What: Support multiple languages to increase accessibility and appeal to users from different regions;
How: Implement react-i18next to handle translations and locale-based formatting. Create a structure that allows switching between languages dynamically, and ensure that text is externalized for easy translation.

- Optimize Performance for Large Data Sets
What: Improve app performance when dealing with large amounts of data, such as an extensive list of products or cart items;
How: Implement lazy loading, virtualized lists, and pagination to handle large data sets efficiently. Optimize rendering performance by profiling components and minimizing re-renders.

- Dark Mode and Theme Customization
What: Add support for dark mode and allow users to customize the theme of the app;
How: Use React Native's Appearance API to detect the user's system theme and automatically switch between dark and light themes. Implement a theme provider to handle different color schemes.

## Running Locally

```
First of all, correctly configure the React Native development environment on your machine, see https://reactnative.dev/docs/environment-setup, and the Expo development environment on your machine, see https://docs.expo.dev/tutorial/create-your-first-app/.

- Enter in the main directory:
$ cd shopping-cart

- For install server dependencies:
$ npm install

- Run the simulador/emulator:
$ npx expo start
```

## How to Contribute

```
- Fork the project

- Create a new branch with your changes:
$ git checkout -b feat/my-feature

- Save your changes and create a commit message telling you what you did:
$ git commit -m "feat: implement my-feature"

- Submit your changes:
$ git push origin feat/my-feature
```

## Cloning / Forking

Please review the [license](https://github.com/samuelematias/shopping-cart/blob/main/LICENSE.txt) and remove all of my personal information (docs, images, etc.).

## Author


Samuel Matias
Samuel Matias

💻 🎨