quel-est-ce-pokemon/lib/api/pokemon_api.dart

43 lines
1.8 KiB
Dart

import '../models/pokemon.dart';
import '../utils/pokemon_type.dart';
import 'dart:convert';
import 'package:http/http.dart' as http;
// Classe qui permet de récupérer les données des pokémons depuis l'API Tyradex
// On utilise la librairie http pour effectuer les requêtes
// On utilise la librairie dart:convert pour convertir les données JSON en objet Dart
class PokemonApi {
static const String baseUrl = 'tyradex.vercel.app';
static const String pokemonUrl = 'api/v1/pokemon';
static Future<Pokemon> getPokemon(int id) async {
// On utilise la méthode get de la classe http pour effectuer une requête GET
// On utilise Uri.https pour construire l'URL de la requête
var response = await http.get(Uri.https(baseUrl, "$pokemonUrl/$id"));
if (response.statusCode != 200) {
// Si le code de retour de la requête n'est pas 200, on lève une exception
throw Exception('Erreur lors de la récupération du pokémon $id, code de retour ${response.statusCode}');
}
// On utilise la méthode jsonDecode de la librairie dart:convert pour convertir le corps de la réponse en fichier JSON
var json = jsonDecode(response.body);
// Récupération du nom en français
String name = json['name']['fr'] ?? json['name']['en'] ?? 'unknown';
// Récupération des types (en français dans l'API Tyradex)
List types = json['types'] ?? [];
PokemonType type1 = types.isNotEmpty
? frenchTypeToEnum(types[0]['name'])
: PokemonType.unknown;
PokemonType? type2 = types.length > 1
? frenchTypeToEnum(types[1]['name'])
: null;
// On crée un objet Pokemon à partir du fichier JSON
return Pokemon(
name: name,
id: id,
type1: type1,
type2: type2,
);
}
}