Site Web React
Ce générateur crée un nouveau site React configuré avec CloudScape, ainsi que l’infrastructure AWS CDK ou Terraform pour déployer votre site web dans le cloud en tant que site statique hébergé dans S3, servi par CloudFront et protégé par WAF.
L’application générée utilise Vite comme outil de build et bundler. Elle utilise TanStack Router pour le routage type-safe.
Utilisation
Section intitulée « Utilisation »Générer un site React
Section intitulée « Générer un site React »Vous pouvez générer un nouveau site React de deux manières :
- Installez le Nx Console VSCode Plugin si ce n'est pas déjà fait
- Ouvrez la console Nx dans VSCode
- Cliquez sur
Generate (UI)
dans la section "Common Nx Commands" - Recherchez
@aws/nx-plugin - ts#react-website
- Remplissez les paramètres requis
- Cliquez sur
Generate
pnpm nx g @aws/nx-plugin:ts#react-website
yarn nx g @aws/nx-plugin:ts#react-website
npx nx g @aws/nx-plugin:ts#react-website
bunx nx g @aws/nx-plugin:ts#react-website
Vous pouvez également effectuer une simulation pour voir quels fichiers seraient modifiés
pnpm nx g @aws/nx-plugin:ts#react-website --dry-run
yarn nx g @aws/nx-plugin:ts#react-website --dry-run
npx nx g @aws/nx-plugin:ts#react-website --dry-run
bunx nx g @aws/nx-plugin:ts#react-website --dry-run
Paramètre | Type | Par défaut | Description |
---|---|---|---|
name Requis | string | - | The name of the application. |
directory | string | packages | The directory of the new application. |
enableTailwind | boolean | true | Enable TailwindCSS for utility-first styling. |
enableTanstackRouter | boolean | true | Enable Tanstack router for type-safe routing. |
iacProvider | string | Inherit | The preferred IaC provider. By default this is inherited from your initial selection. |
Sortie du générateur
Section intitulée « Sortie du générateur »Le générateur créera la structure de projet suivante dans le répertoire <directory>/<name>
:
- index.html Point d’entrée HTML
- public Assets statiques
Répertoiresrc
- main.tsx Point d’entrée de l’application avec la configuration React
- config.ts Configuration de l’application (ex: logo)
Répertoirecomponents
- AppLayout Composants pour le layout CloudScape et la barre de navigation
Répertoirehooks
- useAppLayout.tsx Hook pour ajuster l’AppLayout depuis des composants imbriqués
Répertoireroutes
Répertoirewelcome
- index.tsx Exemple de route (ou page) pour @tanstack/react-router
- styles.css Styles globaux
- vite.config.ts Configuration Vite et Vitest
- tsconfig.json Configuration TypeScript de base pour le code et les tests
- tsconfig.app.json Configuration TypeScript pour le code source
- tsconfig.spec.json Configuration TypeScript pour les tests
Infrastructure
Section intitulée « Infrastructure »Ce générateur fournit de l’infrastructure as code basée sur votre iacProvider
choisi. Il créera un projet dans packages/common
qui inclut les constructions CDK ou modules Terraform pertinents.
Le projet commun d’infrastructure as code est structuré comme suit :
Répertoirepackages/common/constructs
Répertoiresrc
Répertoireapp/ Constructions pour l’infrastructure spécifique à un projet/générateur
- …
Répertoirecore/ Constructions génériques réutilisées par celles dans
app
- …
- index.ts Point d’entrée exportant les constructions depuis
app
- project.json Cibles de build et configuration du projet
Répertoirepackages/common/terraform
Répertoiresrc
Répertoireapp/ Modules Terraform pour l’infrastructure spécifique à un projet/générateur
- …
Répertoirecore/ Modules génériques réutilisés par ceux dans
app
- …
- project.json Cibles de build et configuration du projet
Le générateur crée une infrastructure as code pour déployer votre site web en fonction du iacProvider
sélectionné :
Répertoirepackages/common/constructs/src
Répertoireapp
Répertoirestatic-websites
- <name>.ts Infrastructure spécifique à votre site
Répertoirecore
- static-website.ts Construct générique StaticWebsite
Répertoirepackages/common/terraform/src
Répertoireapp
Répertoirestatic-websites
Répertoire<name>
- <name>.tf Module spécifique à votre site
Répertoirecore
Répertoirestatic-website
- static-website.tf Module générique de site statique
Implémentation de votre site React
Section intitulée « Implémentation de votre site React »La documentation React est un bon point de départ pour apprendre les bases du développement avec React. Vous pouvez consulter la documentation CloudScape pour les détails sur les composants disponibles et leur utilisation.
Création d’une route/page
Section intitulée « Création d’une route/page »Votre site CloudScape est configuré avec TanStack Router par défaut. Cela facilite l’ajout de nouvelles routes :
- Lancer le serveur de développement local
- Créer un nouveau fichier
<page-name>.tsx
danssrc/routes
, où la position dans l’arborescence représente le chemin - Une
Route
et unRouteComponent
sont générés automatiquement. Vous pouvez commencer à développer votre page ici !
Navigation entre pages
Section intitulée « Navigation entre pages »Vous pouvez utiliser le composant Link
ou le hook useNavigate
pour naviguer entre les pages :
import { Link, useNavigate } from '@tanstack/react-router';
export const MyComponent = () => { const navigate = useNavigate();
const submit = async () => { const id = await ... // Utiliser `navigate` pour rediriger après une action asynchrone navigate({ to: '/products/$id', { params: { id }} }); };
return ( <> <Link to="/products">Annuler</Link> <Button onClick={submit}>Valider</Button> </> )};
Pour plus de détails, consultez la documentation TanStack Router.
Configuration runtime
Section intitulée « Configuration runtime »La configuration de votre infrastructure est fournie à votre site via la Configuration Runtime. Cela permet à votre site d’accéder à des détails comme les URLs d’API qui ne sont connus qu’au moment du déploiement.
Infrastructure
Section intitulée « Infrastructure »Le construct CDK RuntimeConfig
peut être utilisé pour ajouter et récupérer la configuration dans votre infrastructure CDK. Les constructs CDK générés par les générateurs @aws/nx-plugin
(comme ts#trpc-api
et py#fast-api
) ajoutent automatiquement les valeurs appropriées au RuntimeConfig
.
Votre construct CDK de site web déploie la configuration runtime dans un fichier runtime-config.json
à la racine de votre bucket S3.
import { Stack } from 'aws-cdk-lib';import { Construct } from 'constructs';import { MyWebsite } from ':my-scope/common-constructs';
export class ApplicationStack extends Stack { constructor(scope: Construct, id: string) { super(scope, id);
// Ajoute automatiquement des valeurs au RuntimeConfig new MyApi(this, 'MyApi', { integrations: MyApi.defaultIntegrations(this).build(), });
// Déploie automatiquement la config runtime dans runtime-config.json new MyWebsite(this, 'MyWebsite'); }}
Avec Terraform, la configuration runtime est gérée via les modules runtime-config. Les modules Terraform générés par les générateurs @aws/nx-plugin
(comme ts#trpc-api
et py#fast-api
) ajoutent automatiquement les valeurs appropriées à la configuration runtime.
Votre module Terraform de site web déploie la configuration runtime dans un fichier runtime-config.json
à la racine de votre bucket S3.
# Ajoute automatiquement des valeurs à la config runtimemodule "my_api" { source = "../../common/terraform/src/app/apis/my-api"}
# Déploie automatiquement la config runtime dans runtime-config.jsonmodule "my_website" { source = "../../common/terraform/src/app/static-websites/my-website"
providers = { aws.us_east_1 = aws.us_east_1 }
# S'assure que l'API est déployée en premier pour ajouter à la config runtime depends_on = [module.my_api]}
Code du site
Section intitulée « Code du site »Dans votre site, vous pouvez utiliser le hook useRuntimeConfig
pour récupérer les valeurs de la configuration runtime :
import { useRuntimeConfig } from '../hooks/useRuntimeConfig';
const MyComponent = () => { const runtimeConfig = useRuntimeConfig();
// Accéder aux valeurs de la config runtime ici const apiUrl = runtimeConfig.apis.MyApi;};
Configuration runtime locale
Section intitulée « Configuration runtime locale »Lors de l’exécution du serveur de développement local, vous aurez besoin d’un fichier runtime-config.json
dans votre répertoire public
pour que votre site local connaisse les URLs des backends, la configuration d’identité, etc.
Votre projet de site est configuré avec une cible load:runtime-config
que vous pouvez utiliser pour récupérer le fichier runtime-config.json
d’une application déployée :
pnpm nx run <my-website>:"load:runtime-config"
yarn nx run <my-website>:"load:runtime-config"
npx nx run <my-website>:"load:runtime-config"
bunx nx run <my-website>:"load:runtime-config"
Serveur de développement local
Section intitulée « Serveur de développement local »Vous pouvez lancer un serveur de développement local en utilisant les cibles serve
ou serve-local
.
Cible Serve
Section intitulée « Cible Serve »La cible serve
démarre un serveur de développement local pour votre site. Cette cible nécessite que vous ayez déployé toute infrastructure de support avec laquelle le site interagit, et que vous ayez chargé la configuration runtime locale.
Vous pouvez exécuter cette cible avec la commande :
pnpm nx run <my-website>:serve
yarn nx run <my-website>:serve
npx nx run <my-website>:serve
bunx nx run <my-website>:serve
Cette cible est utile pour travailler sur des modifications du site tout en pointant vers des APIs “réelles” déployées.
Cible Serve Local
Section intitulée « Cible Serve Local »La cible serve-local
démarre un serveur de développement local pour votre site (avec le MODE Vite défini sur serve-local
), ainsi que des serveurs locaux pour les APIs connectées via le générateur de connexion API.
Lorsque le serveur local est lancé via cette cible, le runtime-config.json
est automatiquement remplacé pour pointer vers les URLs des APIs locales.
Vous pouvez exécuter cette cible avec la commande :
pnpm nx run <my-website>:serve-local
yarn nx run <my-website>:serve-local
npx nx run <my-website>:serve-local
bunx nx run <my-website>:serve-local
Cette cible est utile lorsque vous travaillez à la fois sur votre site et vos APIs et souhaitez itérer rapidement sans déployer l’infrastructure.
Dans ce mode, si aucun runtime-config.json
n’est présent et que vous avez configuré l’authentification Cognito (via le générateur d’authentification pour site CloudScape), la connexion sera ignorée et les requêtes vers vos serveurs locaux n’incluront pas d’en-têtes d’authentification.
Pour activer la connexion et l’authentification en mode serve-local
, déployez votre infrastructure et chargez la configuration runtime.
Vous pouvez builder votre site avec la cible build
. Cela utilise Vite pour créer un bundle de production dans le répertoire dist/packages/<my-website>/bundle
, ainsi que la vérification de types, la compilation et le linting.
pnpm nx run <my-website>:build
yarn nx run <my-website>:build
npx nx run <my-website>:build
bunx nx run <my-website>:build
Tester votre site fonctionne comme pour un projet TypeScript standard. Consultez le guide de projet TypeScript pour plus de détails.
Pour les tests spécifiques à React, React Testing Library est déjà installé et disponible. Consultez la documentation React Testing Library pour son utilisation.
Vous pouvez exécuter les tests avec la cible test
:
pnpm nx run <my-website>:test
yarn nx run <my-website>:test
npx nx run <my-website>:test
bunx nx run <my-website>:test
Déploiement du site
Section intitulée « Déploiement du site »Le générateur de site React crée une infrastructure CDK ou Terraform en fonction du iacProvider
sélectionné. Vous pouvez l’utiliser pour déployer votre site.
Pour déployer votre site, nous recommandons d’utiliser le générateur ts#infra
pour créer une application CDK.
Vous pouvez utiliser le construct CDK généré dans packages/common/constructs
pour déployer votre site.
import { Stack } from 'aws-cdk-lib';import { Construct } from 'constructs';import { MyWebsite } from ':my-scope/common-constructs';
export class ApplicationStack extends Stack { constructor(scope: Construct, id: string) { super(scope, id);
new MyWebsite(this, 'MyWebsite'); }}
Ceci configure :
- Un bucket S3 pour héberger les fichiers statiques
- Une distribution CloudFront pour la diffusion globale
- Un Web ACL WAF pour la sécurité
- Une Origin Access Control pour l’accès sécurisé à S3
- Déploiement automatique des fichiers et configuration runtime
Pour déployer votre site, nous recommandons d’utiliser le générateur terraform#project
pour créer un projet Terraform.
Vous pouvez utiliser le module Terraform généré dans packages/common/terraform
pour déployer votre site.
# Déployer le sitemodule "my_website" { source = "../../common/terraform/src/app/static-websites/my-website"
providers = { aws.us_east_1 = aws.us_east_1 }}
Ceci configure :
- Un bucket S3 pour héberger les fichiers statiques
- Une distribution CloudFront pour la diffusion globale
- Un Web ACL WAF pour la sécurité (déployé en us-east-1)
- Une Origin Access Control pour l’accès sécurisé à S3
- Déploiement automatique des fichiers et configuration runtime