📢 Je vous présente le livre Angular

  • 1) Il offre un contenu clair et concis, tout en couvrant une multitude de concepts d'Angular.
  • 2) Le livre est structuré en trois niveaux : débutant, intermédiaire et avancé
  • 3) traite des pratiques les plus récentes d'Angular, comme les signaux, les vues différées, la gestion des flux, entre autres
  • 4) De plus, vous y trouverez plusieurs liens vers des exemples de code source pour approfondir vos connaissances en pratique.

Skip to content

Comment créer des actions sur NgRx ?

Les actions dans NGRX sont des objets qui décrivent des événements déclenchés dans votre application. Elles permettent de signaler que quelque chose s'est produit et qu'une modification de l'état est nécessaire. Voici comment créer les actions pour gérer la liste des utilisateurs dans votre application Angular.

définition des actions

Pour gérer l'état des utilisateurs, nous allons créer trois actions principales :

  1. Charger les utilisateurs.
  2. Indiquer le succès du chargement des utilisateurs.
  3. Indiquer une erreur lors du chargement des utilisateurs.

Ces actions sont définies dans un fichier nommé users.actions.ts dans le répertoire src/app/store/users/.

1. Charger les utilisateurs

Cette action est déclenchée pour commencer le processus de chargement des utilisateurs. Elle n'a pas de charge utile (payload), car elle sert uniquement à signaler le début du chargement.

typescript
import { createAction, props } from '@ngrx/store';
import { User } from './user';

// Action pour commencer le chargement des utilisateurs
export const loadUsers = createAction('[Users] Load Users');
ts
export interface User {
    id: number;
    name: string;
    username?: string;
    email: string;
    address?: {
        street: string;
        suite: string;
        city: string;
        zipcode: string;
        geo: {
            lat: string;
            lng: string;
        }
    };
    phone?: string;
    website?: string;
    company?: {
        name: string;
        catchPhrase: string;
        bs: string;
    };
}

2. Indiquer le succès du chargement des utilisateurs

Cette action est déclenchée lorsque les utilisateurs ont été chargés avec succès. Elle transporte les données des utilisateurs sous forme de charge utile.

typescript
// Action pour indiquer le succès du chargement des utilisateurs
export const loadUsersSuccess = createAction(
  '[Users] Load Users Success',
  props<{ users: User[] }>() 
);

qu'est-ce que props dans les actions ngrx?

La fonction props dans NGRX est utilisée pour ajouter des propriétés (ou charges utiles) à une action. Lorsqu'une action nécessite de transporter des données (par exemple, une liste d'utilisateurs ou des détails d'une erreur), props permet de définir la forme de ces données.

  • Type sûr : En utilisant props, TypeScript peut vérifier les types des données transportées par vos actions, réduisant ainsi les erreurs.
  • Clarté : props rend explicite les données associées à chaque action, ce qui améliore la lisibilité et la maintenance du code.
  • Interopérabilité : Les actions avec props peuvent être facilement utilisées avec d'autres parties de NGRX, comme les reducers et les effets, qui peuvent accéder directement aux propriétés définies.

3. Indiquer une erreur lors du chargement des utilisateurs

Cette action est déclenchée en cas d'échec du chargement des utilisateurs. Elle peut transporter des informations supplémentaires sur l'erreur, mais dans cet exemple, nous n'ajoutons pas de charge utile.

typescript
// Action pour indiquer une erreur lors du chargement des utilisateurs
export const loadUsersFailure = createAction('[Users] Load Users Failure');

Organisation des actions

Pour une organisation claire et une maintenance facile, placez toutes les actions dans un fichier séparé comme users.actions.ts. Voici à quoi devrait ressembler le fichier complet :

typescript
import { createAction, props } from '@ngrx/store';
import { User } from '../../core/interfaces/user.interface';

// Action pour commencer le chargement des utilisateurs
export const loadUsers = createAction('[Users] Load Users');

// Action pour indiquer le succès du chargement des utilisateurs
export const loadUsersSuccess = createAction(
  '[Users] Load Users Success',
  props<{ users: User[] }>()
);

// Action pour indiquer une erreur lors du chargement des utilisateurs
export const loadUsersFailure = createAction('[Users] Load Users Failure');

Regroupement des actions avec createActionGroup

NGRX propose une fonctionnalité pratique appelée createActionGroup, qui permet de regrouper plusieurs actions sous une même source. Cela simplifie la gestion et l'organisation des actions dans votre application. Voici comment utiliser createActionGroup pour gérer les actions liées à la liste des utilisateurs.

1. créer le groupe d'actions

Nous utilisons createActionGroup pour définir un groupe d'actions sous la source 'Users'. Chaque événement (ou action) est défini avec les propriétés (ou charge utile) qu'il transporte.

typescript
import { createActionGroup, emptyProps, props } from '@ngrx/store';
import { User } from './user';

export const usersActions = createActionGroup({
  source: 'Users',
  events: {
    'Get All':  emptyProps(), 
    'Get All Success': props<{ users: User[] }>(),
    'Get All Failure': props<{ error: any }>() 
  },
});

ça va créé un objet usersActions qui contient les actions suivantes : getAll, getAllSuccess, getAllFailure. Autrement dit, les clés de l'objet ont été changées en camelCase. Donc, par exemple, pour déclencher l'action Get All, on utilisera usersActions.getAll().

Bonnes pratiques

  • Utilisez createActionGroup pour regrouper les actions liées par fonctionnalité.
  • Nommez les actions de manière descriptive pour clarifier leur rôle.
  • Centralisez la définition des actions dans des fichiers séparés pour une meilleure organisation.
  • Utilisez les actions groupées dans les reducers et les effets pour une gestion cohérente de l'état.

Chaque mois, recevez en avant-première notre newsletter avec les dernières actualités, tutoriels, astuces et ressources Angular directement par email !