Ce repo a pour but de fournir une interface visuelle pour interagir avec l'API d'Albert (le projet de chatbot LLM du gouvernement français).
DSFR est déjà installé, voici quelques ressources utiles :
- Basics : marges, taille de police, design, picto etc.
- Composants
- Accessibilité : Critères RGAA
Redux 👉 pour la gestion globale de l'état du client
React-Query 👉 pour les requêtes API, la mise en cache et la gestion asynchrone du state.
Nous utilisons Valibot pour valider les entrées des utilisateurs, c'est une alternative légère aux bibliothèques populaires comme Zod.
Implémentation d'un combineReducers pour gérer les différents états de l'application, disponible dans /utils/reducer/reducer.jsx. Pour l'utiliser, un Store enveloppe le composant Root
.
Les scripts sont disponibles dans package.json
Installer les dépendances :
npm i
Créer un fichier tailwind :
npx tailwind -i src/style/style.css -o style.css
Lancer le mode dev :
npm run dev
Consulter les Vite docs
Nous utilisons ViteJS pour construire le projet donc chaque nom de variable d'environnement est préfixé par VITE_
.
VITE_API_URL -- url pour les requêtes de l'api.
VITE_MATOMO_URL -- l'url de l'instance de matomo pour l'analyse (optionnel)
VITE_ENVIRONMENT_NAME -- une variable optionnelle utilisée pour afficher des fonctionnalités spécifiques pour les usagers de France Services.
VITE_MODEL_NAME -- le modèle à utiliser pour les requêtes, vous pouvez trouver une liste ici ici
VITE_MODEL_MODE -- chaque modèle possède plusieurs modes lui permettant de répondre différemment: rag, rag-gt-operators-llama
VITE_MODEL_TEMPERATURE -- la température utilisée par le modèle pour générer la réponse. Entre 1 et 100
Voici tous les points d'accès utilisés par Albert
Note : La documentation des endpoints n'est pas encore complète.
Albert front utilise tanstack-query (react-query) pour interagir avec le backend.
Les fonctions sont situées dans le dossier src/api
et peuvent être importées via @api.
Tous les points d'entrée de l'api sont référencés dans src/api/routes.ts
-
stream
: Gère la réponse du bot en cours, il est aussi utilisé pour vérifier si le bot est en streaming ou non. -
user
: Tous les messages utilisateur/agent de la conversation, ainsi que les sources du message actuel.
English version
This repo aims to provide a visual interface to interact with Albert's (the French governement's LLM chatbot project) API
DSFR is already installed, here are some useful resources:
- Basics: margins, font size, design, picto etc.
- Components
- Accessibility: RGAA criterias
Redux 👉 for global client state management
React-Query 👉 for querying, caching and async state management
We use Valibot to validate users input, this is a lightweight alternative to popular libraries like Zod.
Implementation of a combineReducers to manage the application's various states, available in /utils/reducer/reducer.jsx. To use it, a Store wraps the Root
component.
Scripts are available in package.json
Install dependencies:
npm i
Create tailwind file:
npx tailwind -i src/style/style.css -o style.css
Launch dev mode:
npm run dev
Check out the Vite docs
We are using ViteJS to build the project so every env variable name is prefixed with VITE_
.
VITE_API_URL -- url for api queries.
VITE_MATOMO_URL -- the url to the matomo instance for analytics (optionnal)
VITE_ENVIRONMENT_NAME -- and extra variable currently used to display different features in the UI for FranceServices.
VITE_MODEL_NAME -- the model to use for queries, you can find a list in here
VITE_MODEL_MODE -- model mode for instance 'rag'
VITE_MODEL_TEMPERATURE -- the temperature used by the model to generate the response. between 1 and 100
Here are all the endpoints used by Albert. Note: The endpoints documentation is not complete yet
Albert front uses tanstack-query (react-query) to interact with the backend.
Functions are located in the src/api
folder and can be importe via @api.
All the api's endpoints are referenced in src/api/routes.ts
-
stream
: Handles the current bot's response, it is also used to check if the bot is streaming or not. -
user
: current chat and stream ids, message history