/reason-react-shopping-cart

A shopping cart based on Shopify Polaris styleguide, built on top of ReasonML

Primary LanguageJavaScript

react-shopping-cart


Ce projet a été démarré avec Create React App.

Mises à jour

  1. Permettre l'ajout d'un produit au panier ✅
  2. Permettre la suppression d'un produit présent dans le panier ✅
  3. Calculer automatiquement le montant total du panier ainsi que les différentes TVA ✅

Je ne suis pas sûr d'avoir bien cerné le fonctionnement au niveau de la TVA, la relation entre les taxes dans l'objet panier et la taxe au niveau du produit lui même. Je pense m'informer rapidement dessus, mais je crois que cela peut rapidement se régler avec de plus amples explications de votre part.

  1. Ajouter un système de recherche dans les produits du catalogue ✅
  2. Gérer un système de devises ✅
  3. Créer un système de cache pour que les paniers ne soient pas perdus même après rafraichissement de la page ✅
  4. Transformer le code en ReasonML pour avoir une codebase plus secure 🔜

Je suis entrain de suivre les vidéos de formation pour m'imprégner de ReasonML et ReasonReact, une d'entre elles est cette vidéo de 6 heures 😊

  1. Relier l'application à une API externe qui retourne des produits au format JSON 🔜

J'ai pas trouvé une Fake Data API qui puisse me fournir une liste de produits. Du coup j'ai commencé par refléchir à cela en l'implémentant d'abord au niveau des devises, la récupération des données des devises via une API online. L'ébauche est sur la branche thunk

  1. Refactorer le code pour utiliser les hooks 🔜

Démarrage

Pour initialiser l'application et la lancer dans un mode de développement :

$ yarn
$ yarn start

Ouvrir la page http://localhost:3000 pour voir l'application dans votre navigateur.

La page se mettra à jour si vous faites une modification du code. Vous verrez également toutes les erreurs Eslint et Typescript dans la console.

Prérequis

(choisir l'un des deux 😊)

Pour Javascript:

  1. ReactJS with Hooks
  2. Ramda (optionnel)
  3. TypeScript

Pour ReasonML:

  1. ReasonReact with Hooks
  2. BuckleScript Belt

Explication

React Shopping Cart

L'objectif de ce test est de recréer un système de panier comme l'on trouve sur de nombreux sites e-commerce. Vous trouverez en ouvrant le fichier src/App.tsx l'ossature de l'application avec un set de données présent et quelques balises html pour structurer la page.

Rien n'a encore été dynamisé dans l'interface, vous aurez donc l'objectif de :

Documentation

Quelques points à prendre en compte

  • L'équipe technique suit une logique de développement cross-platform. En effet, Wino propose à ses clients des outils pour différentes plateformes : iOS, Mac, Windows ... De ce fait, le développement technique de chaque fonctionnalité doit être réfléchi pour pouvoir être un maximum partageable entre chaque codebase.

  • La gestion comptable est un élément clé des produits Wino. Ainsi, le développement des services de calcul de données comptables nécessite d'adopter une attitude de rigueur extrême. Aucune erreur n'est permise. Pour parvenir à cela, l'équipe Wino a mis en place un ensemble de procédures et défini un ensemble de bonnes pratiques.

  • Afin de faciliter le développement technique de nos produits, nous nous basons sur la librairie Polaris de Shopify pour la création d'interfaces utilisateur web. Toute la documentation est accessible à l'adresse suivante : polaris.shopify.com.

  • L'application a été initialisée avec Typescript. Cela permet de typer le code Javascript écrit pour ainsi le rendre plus sûr.

Quelques astuces

  • Le calcul des TVA répond à l'application de formules mathémathiques simples. Vous trouverez des exemples en accédant au site suivant calculertva.com/. Les quelques formules à connaître :
[Montant HT] x (1 + ([Taux TVA] / 100))=[Montant TTC]
[Montant HT] x ([Taux TVA] / 100)=[Montant TVA]
[Montant TTC] / (1 + ([Taux TVA] / 100))=[Montant HT]
$ 0.1+0.2
> 0.30000000000000004  🙃

Les plus

Une fois avoir répondu avec soin aux objectifs de base de l'exercice, vous pourrez effectuer quelques améliorations supplémentaires, quelques idées :

  • Gérer un système de devises (€, $ ...) 💰
  • Transformer le code en ReasonML pour avoir une codebase plus secure
  • Ajouter un système de remise 💳
  • Créer un système de cache pour que les paniers ne soient pas perdus même après rafraichissement de la page 💾
  • Relier l'application à une API externe qui retourne des produits au format JSON 🌍
  • Ajouter un système de paiement 💸
  • ...