chore: Merge upstream changes --------- Signed-off-by: Krille <c.kussowski@famedly.com> Co-authored-by: krille-chan <christian-kussowski@posteo.de> Co-authored-by: Krille <c.kussowski@famedly.com> Co-authored-by: Linerly <linerly@proton.me> Co-authored-by: Priit Jõerüüt <hwlate@joeruut.com> Co-authored-by: 大王叫我来巡山 <hamburger2048@users.noreply.hosted.weblate.org> Co-authored-by: fadelkon <fadelkon@posteo.net> Co-authored-by: Aindriú Mac Giolla Eoin <aindriu80@gmail.com> Co-authored-by: Edgars Andersons <Edgars+Weblate@gaitenis.id.lv> Co-authored-by: josé m <correoxm@disroot.org> Co-authored-by: Bezruchenko Simon <worcposj44@gmail.com> Co-authored-by: Christian <christian-pauly@posteo.de> Co-authored-by: - <hitekex@yandex.ru> Co-authored-by: Angelo Schirinzi <Odi-3@users.noreply.hosted.weblate.org> Co-authored-by: xabirequejo <xabi.rn@gmail.com> Co-authored-by: Piotr Orzechowski <piotr@orzechowski.tech> Co-authored-by: Rex_sa <rex.sa@pm.me> Co-authored-by: Tewuzij <tenajeza@outlook.com> Co-authored-by: goknarbahceli <goknarbahceli@proton.me> Co-authored-by: தமிழ்நேரம் <anishprabu.t@gmail.com> Co-authored-by: Erin <erin@erindesu.cz> Co-authored-by: EpicKiwi <me@epickiwi.fr> Co-authored-by: Christian Tietze <me@christiantietze.de> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
75 lines
2.2 KiB
Dart
75 lines
2.2 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_gen/gen_l10n/l10n.dart';
|
|
import 'package:matrix/matrix.dart';
|
|
|
|
import 'package:fluffychat/pages/archive/archive_view.dart';
|
|
import 'package:fluffychat/pangea/extensions/pangea_room_extension.dart';
|
|
import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart';
|
|
import 'package:fluffychat/widgets/future_loading_dialog.dart';
|
|
import 'package:fluffychat/widgets/matrix.dart';
|
|
|
|
class Archive extends StatefulWidget {
|
|
const Archive({super.key});
|
|
|
|
@override
|
|
ArchiveController createState() => ArchiveController();
|
|
}
|
|
|
|
class ArchiveController extends State<Archive> {
|
|
List<Room> archive = [];
|
|
|
|
Future<List<Room>> getArchive(BuildContext context) async {
|
|
if (archive.isNotEmpty) return archive;
|
|
// #Pangea
|
|
//return archive = await Matrix.of(context).client.loadArchive();
|
|
return archive = (await Matrix.of(context).client.loadArchive())
|
|
.where((e) => (!e.isSpace && !e.isAnalyticsRoom))
|
|
.toList();
|
|
// Pangea#
|
|
}
|
|
|
|
void forgetRoomAction(int i) async {
|
|
await showFutureLoadingDialog(
|
|
context: context,
|
|
future: () async {
|
|
Logs().v('Forget room ${archive.last.getLocalizedDisplayname()}');
|
|
await archive[i].forget();
|
|
archive.removeAt(i);
|
|
},
|
|
);
|
|
setState(() {});
|
|
}
|
|
|
|
void forgetAllAction() async {
|
|
final archive = this.archive;
|
|
final client = Matrix.of(context).client;
|
|
if (archive.isEmpty) return;
|
|
if (await showOkCancelAlertDialog(
|
|
useRootNavigator: false,
|
|
context: context,
|
|
title: L10n.of(context).areYouSure,
|
|
okLabel: L10n.of(context).yes,
|
|
cancelLabel: L10n.of(context).cancel,
|
|
message: L10n.of(context).clearArchive,
|
|
) !=
|
|
OkCancelResult.ok) {
|
|
return;
|
|
}
|
|
await showFutureLoadingDialog(
|
|
context: context,
|
|
future: () async {
|
|
while (archive.isNotEmpty) {
|
|
Logs().v('Forget room ${archive.last.getLocalizedDisplayname()}');
|
|
await archive.last.forget();
|
|
archive.removeLast();
|
|
}
|
|
},
|
|
);
|
|
client.clearArchivesFromCache();
|
|
setState(() {});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) => ArchiveView(this);
|
|
}
|