fluffychat/lib/pages/settings_ignore_list/settings_ignore_list_view.dart

110 lines
4.1 KiB
Dart
Raw Normal View History

2020-09-19 13:29:12 +00:00
import 'package:flutter/material.dart';
2021-10-26 16:50:34 +00:00
import 'package:flutter_gen/gen_l10n/l10n.dart';
2021-10-26 16:50:34 +00:00
import 'package:future_loading_dialog/future_loading_dialog.dart';
import 'package:matrix/matrix.dart';
2021-10-26 16:50:34 +00:00
import 'package:fluffychat/widgets/avatar.dart';
import 'package:fluffychat/widgets/layouts/max_width_body.dart';
2021-05-22 06:53:52 +00:00
import '../../widgets/matrix.dart';
2021-11-09 20:32:16 +00:00
import 'settings_ignore_list.dart';
2020-09-19 13:29:12 +00:00
2021-05-22 07:13:47 +00:00
class SettingsIgnoreListView extends StatelessWidget {
2021-04-24 05:43:47 +00:00
final SettingsIgnoreListController controller;
2021-02-02 08:00:06 +00:00
const SettingsIgnoreListView(this.controller, {super.key});
2020-09-19 13:29:12 +00:00
@override
Widget build(BuildContext context) {
final client = Matrix.of(context).client;
return Scaffold(
2021-01-16 13:24:52 +00:00
appBar: AppBar(
leading: const Center(child: BackButton()),
2023-12-01 16:58:04 +00:00
title: Text(L10n.of(context)!.blockedUsers),
2021-01-16 13:24:52 +00:00
),
2021-04-09 16:26:44 +00:00
body: MaxWidthBody(
2023-12-01 16:58:04 +00:00
withScrolling: false,
2021-04-09 16:26:44 +00:00
child: Column(
2023-12-01 16:58:04 +00:00
mainAxisSize: MainAxisSize.min,
2021-04-09 16:26:44 +00:00
children: [
Padding(
padding: const EdgeInsets.all(16.0),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
TextField(
2021-04-24 05:43:47 +00:00
controller: controller.controller,
2021-04-09 16:26:44 +00:00
autocorrect: false,
textInputAction: TextInputAction.done,
2021-04-24 05:43:47 +00:00
onSubmitted: (_) => controller.ignoreUser(context),
2021-04-09 16:26:44 +00:00
decoration: InputDecoration(
2024-04-14 11:06:30 +00:00
errorText: controller.errorText,
hintText: '@bad_guy:domain.abc',
floatingLabelBehavior: FloatingLabelBehavior.always,
2023-12-01 16:58:04 +00:00
labelText: L10n.of(context)!.blockUsername,
2021-04-09 16:26:44 +00:00
suffixIcon: IconButton(
2023-12-01 16:58:04 +00:00
tooltip: L10n.of(context)!.block,
2024-04-14 11:06:30 +00:00
icon: const Icon(Icons.send_outlined),
2021-04-24 05:43:47 +00:00
onPressed: () => controller.ignoreUser(context),
2021-04-09 16:26:44 +00:00
),
2020-09-19 13:29:12 +00:00
),
),
2021-10-14 16:09:30 +00:00
const SizedBox(height: 16),
2021-04-09 16:26:44 +00:00
Text(
2023-12-01 16:58:04 +00:00
L10n.of(context)!.blockListDescription,
2021-10-14 16:09:30 +00:00
style: const TextStyle(color: Colors.orange),
2021-04-09 16:26:44 +00:00
),
],
),
2020-09-19 13:29:12 +00:00
),
2024-04-14 11:06:30 +00:00
Divider(
color: Theme.of(context).dividerColor,
),
2021-04-09 16:26:44 +00:00
Expanded(
child: StreamBuilder<Object>(
stream: client.onSync.stream.where(
(syncUpdate) =>
syncUpdate.accountData?.any(
(accountData) =>
accountData.type == 'm.ignored_user_list',
) ??
false,
),
builder: (context, snapshot) {
return ListView.builder(
itemCount: client.ignoredUsers.length,
itemBuilder: (c, i) => FutureBuilder<Profile>(
future:
client.getProfileFromUserId(client.ignoredUsers[i]),
builder: (c, s) => ListTile(
leading: Avatar(
mxContent: s.data?.avatarUrl ?? Uri.parse(''),
name: s.data?.displayName ?? client.ignoredUsers[i],
),
title: Text(
s.data?.displayName ?? client.ignoredUsers[i],
),
2024-04-14 11:06:30 +00:00
subtitle:
Text(s.data?.userId ?? client.ignoredUsers[i]),
trailing: IconButton(
tooltip: L10n.of(context)!.delete,
2024-04-14 11:06:30 +00:00
icon: const Icon(Icons.delete_outlined),
onPressed: () => showFutureLoadingDialog(
context: context,
future: () =>
client.unignoreUser(client.ignoredUsers[i]),
2020-09-19 13:29:12 +00:00
),
),
),
),
);
},
),
2021-04-09 16:26:44 +00:00
),
],
),
2020-09-19 13:29:12 +00:00
),
);
}
}