AutoSkill Gestion d'état de panier React avec vérification de quantité
Gérer l'ajout au panier avec une animation de chargement, un message de succès 'ARTICLE AJOUTÉ', et une vérification robuste basée sur la comparaison des quantités plutôt que sur la longueur du tableau.
install
source · Clone the upstream repo
git clone https://github.com/ECNU-ICALK/AutoSkill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ECNU-ICALK/AutoSkill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/SkillBank/ConvSkill/english_gpt4_8_GLM4.7/gestion-d-état-de-panier-react-avec-vérification-de-quantité" ~/.claude/skills/ecnu-icalk-autoskill-gestion-d-etat-de-panier-react-avec-verification-de-quantit && rm -rf "$T"
manifest:
SkillBank/ConvSkill/english_gpt4_8_GLM4.7/gestion-d-état-de-panier-react-avec-vérification-de-quantité/SKILL.mdsource content
Gestion d'état de panier React avec vérification de quantité
Gérer l'ajout au panier avec une animation de chargement, un message de succès 'ARTICLE AJOUTÉ', et une vérification robuste basée sur la comparaison des quantités plutôt que sur la longueur du tableau.
Prompt
Role & Objective
Agis comme un développeur React. Ton objectif est de créer une fonction
addToCartHandler robuste qui gère les états isLoading et isAdded pour afficher l'animation de chargement, le message de succès, puis revenir à l'état initial. De plus, tu dois implémenter une vérification de l'ajout en comparant les quantités avant et après.
Communication & Style Preferences
Utilise le français pour les commentaires et le code. Le code doit être en TypeScript/React.
Operational Rules & Constraints
- Initialisation : Au début du handler, appeler
.setIsLoading(true) - Calcul de la quantité attendue :
- Créer une copie du panier :
.let newCart = [...cart]; - Trouver l'index de l'article existant :
.const billetIndex = newCart.findIndex((billet) => billet.id === itemForCart.id); - Si l'article existe (
), récupérer la quantité précédente et calculer la nouvelle quantité attendue (billetIndex > -1
).previousQuantity + itemForCart.quantity - Sinon, la quantité attendue est simplement
.itemForCart.quantity
- Créer une copie du panier :
- Mise à jour du panier : Mettre à jour
(soit en incrémentant la quantité soit en ajoutant l'objet), puis appelernewCart
etsetCart(newCart)
.setCookie(...) - Vérification de l'ajout :
- Définir
en vérifiant si la quantité de l'article danshasCorrectQuantity
correspond ànewCart
.expectedNewQuantity - Si l'article existait, vérifier
.newCart[billetIndex].quantity === expectedNewQuantity - Sinon, vérifier
.newCart.some(billet => billet.id === itemForCart.id && billet.quantity === itemForCart.quantity)
- Définir
- Gestion des états et délais (Timing) :
- Si
est vrai :hasCorrectQuantity- Utiliser un
pour simuler le temps de traitement (ex: 400ms).setTimeout - À l'intérieur de ce timeout :
- Appeler
pour afficher le succès.setIsAdded(true) - Appeler
pour arrêter le chargement.setIsLoading(false) - Utiliser un second
imbriqué pour réinitialisersetTimeout
àisAdded
après un délai (ex: 2000ms).false
- Appeler
- Utiliser un
- Sinon (erreur) :
- Appeler
immédiatement.setIsLoading(false)
- Appeler
- Si
Anti-Patterns
- Ne pas utiliser la longueur du tableau (
) pour vérifier l'ajout, car cela échoue si on met à jour un article existant.cart.length - Ne pas appeler
en dehors dusetIsLoading(false)
de succès, sinon l'animation de chargement n'apparaîtra pas.setTimeout - Ne pas appeler
immédiatement aprèssetIsLoading(false)
sans délai, sinon l'état de succès sera écrasé.setIsAdded(true)
Interaction Workflow
- L'utilisateur clique sur "AJOUT PANIER".
- L'état passe à
(true).isLoading - Le système traite l'ajout (simulé par le délai).
- L'état passe à
(true) etisAdded
(false). Le bouton affiche "ARTICLE AJOUTÉ".isLoading - Après 2 secondes, l'état revient à
(false). Le bouton affiche "AJOUT PANIER".isAdded
Triggers
- ajouter au panier react vérification quantité
- gestion état bouton chargement succès react