-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathnews_feed_page.dart
75 lines (67 loc) · 2.54 KB
/
news_feed_page.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'package:provider/provider.dart';
import '../../../generated/l10n.dart';
import '../../../widgets/error_page.dart';
import '../../../widgets/scaffold.dart';
import '../model/news_feed_item.dart';
import '../service/news_provider.dart';
import 'news_item_details_page.dart';
class NewsFeedPage extends StatefulWidget {
const NewsFeedPage({final Key key}) : super(key: key);
@override
_NewsFeedPageState createState() => _NewsFeedPageState();
}
class _NewsFeedPageState extends State<NewsFeedPage> {
String _formatDate(final String date) {
final DateTime dateTime = DateTime.parse(date);
return DateFormat('yyyy-MM-dd').format(dateTime);
}
@override
Widget build(final BuildContext context) {
final newsFeedProvider = Provider.of<NewsProvider>(context);
return FutureBuilder(
future: newsFeedProvider.fetchNewsFeedItems(),
builder: (final _, final snapshot) {
if (snapshot.connectionState != ConnectionState.done) {
return const Center(child: CircularProgressIndicator());
}
final List<NewsFeedItem> newsFeedItems = snapshot.data;
if (newsFeedItems == null) {
return ErrorPage(
errorMessage: S.current.warningUnableToReachNewsFeed,
info: [TextSpan(text: S.current.warningInternetConnection)],
actionText: S.current.actionRefresh,
actionOnTap: () => setState(() {}),
);
} else if (newsFeedItems.isEmpty) {
return ErrorPage(
imgPath: 'assets/illustrations/undraw_empty.png',
errorMessage: S.current.warningNoNews,
);
}
return ListView(
children: ListTile.divideTiles(
context: context,
tiles: newsFeedItems
.map(
(final item) => ListTile(
title: Text(item.title),
subtitle: Text(_formatDate(item.createdAt)),
trailing: const Icon(Icons.arrow_forward_ios_outlined),
onTap: () => Navigator.push(
context,
MaterialPageRoute<Map<dynamic, dynamic>>(
builder: (final context) =>
NewsItemDetailsPage(newsItemGuid: item.itemGuid),
),
),
dense: true,
),
)
.toList(),
).toList());
},
);
}
}