import 'dart:async'; import 'dart:collection'; import 'package:drift/drift.dart' show Value; import 'package:flutter/material.dart'; import 'package:twonly/globals.dart'; import 'package:twonly/src/database/twonly.db.dart'; import 'package:twonly/src/views/components/avatar_icon.component.dart'; import 'package:twonly/src/views/components/flame.dart'; class ReduceFlamesView extends StatefulWidget { const ReduceFlamesView({super.key}); @override State createState() => _ReduceFlamesViewState(); } class _ReduceFlamesViewState extends State { List allGroups = []; List backupFlames = []; HashSet changedGroupIds = HashSet(); late StreamSubscription> groupSub; @override void initState() { super.initState(); final stream = twonlyDB.groupsDao.watchGroupsForChatList(); groupSub = stream.listen((update) async { if (backupFlames.isEmpty) { backupFlames = update; } update.sort( (a, b) => a.flameCounter.compareTo(b.flameCounter), ); setState(() { allGroups = update.where((g) => g.flameCounter > 1).toList(); }); }); } @override void dispose() { unawaited(groupSub.cancel()); super.dispose(); } @override Widget build(BuildContext context) { return GestureDetector( onTap: () => FocusScope.of(context).unfocus(), child: Scaffold( appBar: AppBar( title: const Text('Reduce Flames'), ), body: SafeArea( child: Padding( padding: const EdgeInsets.only( bottom: 40, left: 10, top: 20, right: 10, ), child: Column( children: [ const Text( 'There was a bug that caused the flames in direct messages to be replaced by group flames. Here, you can reduce the flames again. If you reduce the flames, the other person MUST do the same; otherwise, they will be resynchronized to the higher value.', textAlign: TextAlign.center, ), const SizedBox(height: 10), OutlinedButton( onPressed: () async { for (final backupGroup in backupFlames) { if (changedGroupIds.contains(backupGroup.groupId)) { await twonlyDB.groupsDao.updateGroup( backupGroup.groupId, GroupsCompanion( flameCounter: Value(backupGroup.flameCounter), ), ); } } }, child: const Text('Undo changes'), ), const SizedBox(height: 10), Expanded( child: ListView.builder( restorationId: 'new_message_users_list', itemCount: allGroups.length, itemBuilder: (context, i) { final group = allGroups[i]; return ListTile( title: Row( children: [ Text(group.groupName), FlameCounterWidget( groupId: group.groupId, prefix: true, ), ], ), leading: AvatarIcon( group: group, fontSize: 13, ), trailing: OutlinedButton( onPressed: () { changedGroupIds.add(group.groupId); twonlyDB.groupsDao.updateGroup( group.groupId, GroupsCompanion( flameCounter: Value(group.flameCounter - 1), ), ); }, child: const Text('-1'), ), ); }, ), ), ], ), ), ), ), ); } }