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:fluffychat/l10n/l10n.dart';
import 'package:flutter/material.dart';

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(
          title: Text(L10n.of(context).archive),
        ),
        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],
                    onForget: () => setState(() => archive.removeAt(i))),
              );
            }
          },
        ),
      ),
      secondScaffold: Scaffold(
        body: Center(
          child: Image.asset('assets/logo.png', width: 100, height: 100),
        ),
      ),
      primaryPage: FocusPage.FIRST,
    );
  }
}