Fetching but Type Conversion Err
This commit is contained in:
53
lib/album_fetch.dart
Normal file
53
lib/album_fetch.dart
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
|
||||||
|
import 'dart:convert';
|
||||||
|
import 'dart:async';
|
||||||
|
|
||||||
|
import 'package:http/http.dart' as http;
|
||||||
|
|
||||||
|
Future<FetchAlbum> fetchArrivals() async {
|
||||||
|
final response = await http
|
||||||
|
.get(Uri.parse(DB_URL));
|
||||||
|
|
||||||
|
if (response.statusCode == 200) {
|
||||||
|
// If the server did return a 200 OK response,
|
||||||
|
// then parse the JSON.
|
||||||
|
return FetchAlbum.fromJson(jsonDecode(response.body) as Map<String, dynamic>);
|
||||||
|
} else {
|
||||||
|
// If the server did not return a 200 OK response,
|
||||||
|
// then throw an exception.
|
||||||
|
throw Exception('Failed to load album');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class FetchAlbum {
|
||||||
|
final String timeOfDay;
|
||||||
|
final int weekDay;
|
||||||
|
final String tramLine;
|
||||||
|
final bool direction;
|
||||||
|
|
||||||
|
const FetchAlbum({
|
||||||
|
required this.timeOfDay,
|
||||||
|
required this.weekDay,
|
||||||
|
required this.tramLine,
|
||||||
|
required this.direction,
|
||||||
|
});
|
||||||
|
|
||||||
|
factory FetchAlbum.fromJson(Map<String, dynamic> json) {
|
||||||
|
return switch (json) {
|
||||||
|
{
|
||||||
|
'time_of_day': String jsonTime,
|
||||||
|
'week_day': int jsonDay,
|
||||||
|
'tram_line': String jsonTramLine,
|
||||||
|
'direction': bool jsonDirec,
|
||||||
|
} =>
|
||||||
|
FetchAlbum(
|
||||||
|
// Class : json declaration
|
||||||
|
timeOfDay: jsonTime,
|
||||||
|
weekDay: jsonDay,
|
||||||
|
tramLine: jsonTramLine,
|
||||||
|
direction: jsonDirec,
|
||||||
|
),
|
||||||
|
_ => throw const FormatException('Failed to load album.'),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,8 +1,22 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:witl/album_fetch.dart';
|
||||||
|
|
||||||
class FetchAPI extends StatelessWidget {
|
class FetchAPI extends StatefulWidget {
|
||||||
const FetchAPI({super.key});
|
const FetchAPI({super.key});
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<FetchAPI> createState() => _FetchAPIState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _FetchAPIState extends State<FetchAPI> {
|
||||||
|
late Future<FetchAlbum> fetchedAlbum;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
fetchedAlbum = fetchArrivals();
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
@@ -11,6 +25,18 @@ class FetchAPI extends StatelessWidget {
|
|||||||
),
|
),
|
||||||
body: ListView(
|
body: ListView(
|
||||||
children: [
|
children: [
|
||||||
|
FutureBuilder<FetchAlbum> (
|
||||||
|
future: fetchedAlbum,
|
||||||
|
builder: (context, snapshot) {
|
||||||
|
if (snapshot.hasData) {
|
||||||
|
return Text(snapshot.data!.timeOfDay);
|
||||||
|
} else if (snapshot.hasError) {
|
||||||
|
return Text('${snapshot.error}');
|
||||||
|
}
|
||||||
|
|
||||||
|
return const CircularProgressIndicator();
|
||||||
|
},
|
||||||
|
),
|
||||||
InkWell(
|
InkWell(
|
||||||
onTap: () {
|
onTap: () {
|
||||||
Navigator.pushNamedAndRemoveUntil(
|
Navigator.pushNamedAndRemoveUntil(
|
||||||
|
|||||||
Reference in New Issue
Block a user