fluffychat/lib/views/archive.dart

54 lines
1.6 KiB
Dart
Raw Permalink Normal View History

2020-01-05 12:27:03 +01:00
import 'package:famedlysdk/famedlysdk.dart';
import 'package:fluffychat/components/adaptive_page_layout.dart';
import 'package:fluffychat/components/list_items/chat_list_item.dart';
import 'package:fluffychat/components/matrix.dart';
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/l10n.dart';
2020-01-05 12:27:03 +01:00
class Archive extends StatefulWidget {
@override
_ArchiveState createState() => _ArchiveState();
}
class _ArchiveState extends State<Archive> {
List<Room> archive;
Future<List<Room>> getArchive(BuildContext context) async {
if (archive != null) return archive;
return await Matrix.of(context).client.archive;
}
@override
Widget build(BuildContext context) {
return AdaptivePageLayout(
firstScaffold: Scaffold(
appBar: AppBar(
2020-05-07 07:52:40 +02:00
title: Text(L10n.of(context).archive),
2020-01-05 12:27:03 +01:00
),
body: FutureBuilder<List<Room>>(
future: getArchive(context),
builder: (BuildContext context, snapshot) {
if (!snapshot.hasData) {
return Center(child: CircularProgressIndicator());
} else {
archive = snapshot.data;
return ListView.builder(
itemCount: archive.length,
itemBuilder: (BuildContext context, int i) => ChatListItem(
archive[i],
2020-02-16 09:22:56 +01:00
onForget: () => setState(() => archive.removeAt(i))),
2020-01-05 12:27:03 +01:00
);
}
},
),
),
secondScaffold: Scaffold(
body: Center(
2020-05-13 15:58:59 +02:00
child: Image.asset('assets/logo.png', width: 100, height: 100),
2020-01-05 12:27:03 +01:00
),
),
primaryPage: FocusPage.FIRST,
);
}
}