fluffychat/lib/pages/chat/event_info_dialog.dart

115 lines
3.8 KiB
Dart
Raw Normal View History

2021-11-13 12:06:36 +00:00
import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/l10n.dart';
import 'package:matrix/matrix.dart';
2021-11-22 18:27:40 +00:00
import 'package:fluffychat/config/app_config.dart';
2023-01-07 09:29:34 +00:00
import 'package:fluffychat/utils/adaptive_bottom_sheet.dart';
2021-11-13 12:06:36 +00:00
import 'package:fluffychat/utils/date_time_extension.dart';
import 'package:fluffychat/widgets/avatar.dart';
extension EventInfoDialogExtension on Event {
2023-01-07 09:29:34 +00:00
void showInfoDialog(BuildContext context) => showAdaptiveBottomSheet(
2021-11-13 12:06:36 +00:00
context: context,
builder: (context) =>
2022-01-29 11:35:03 +00:00
EventInfoDialog(l10n: L10n.of(context)!, event: this),
2021-11-13 12:06:36 +00:00
);
}
class EventInfoDialog extends StatelessWidget {
final Event event;
final L10n l10n;
const EventInfoDialog({
2022-01-29 11:35:03 +00:00
required this.event,
required this.l10n,
super.key,
});
2021-11-13 12:06:36 +00:00
2024-09-27 15:43:02 +00:00
String prettyJson(MatrixEvent event) {
2024-07-04 13:42:00 +00:00
const decoder = JsonDecoder();
const encoder = JsonEncoder.withIndent(' ');
2021-11-13 12:06:36 +00:00
final object = decoder.convert(jsonEncode(event.toJson()));
return encoder.convert(object);
}
@override
Widget build(BuildContext context) {
final theme = Theme.of(context);
2024-09-27 15:43:02 +00:00
final originalSource = event.originalSource;
2021-11-13 12:06:36 +00:00
return Scaffold(
appBar: AppBar(
2022-01-29 11:35:03 +00:00
title: Text(L10n.of(context)!.messageInfo),
2021-11-13 12:06:36 +00:00
leading: IconButton(
icon: const Icon(Icons.arrow_downward_outlined),
onPressed: Navigator.of(context, rootNavigator: false).pop,
2022-01-29 11:35:03 +00:00
tooltip: L10n.of(context)!.close,
2021-11-13 12:06:36 +00:00
),
),
body: ListView(
children: [
ListTile(
2021-11-20 09:42:23 +00:00
leading: Avatar(
mxContent: event.senderFromMemoryOrFallback.avatarUrl,
name: event.senderFromMemoryOrFallback.calcDisplayname(),
2023-11-19 08:44:58 +00:00
client: event.room.client,
2023-11-11 16:56:23 +00:00
presenceUserId: event.senderId,
2021-11-20 09:42:23 +00:00
),
2022-01-29 11:35:03 +00:00
title: Text(L10n.of(context)!.sender),
subtitle: Text(
'${event.senderFromMemoryOrFallback.calcDisplayname()} [${event.senderId}]',
),
2021-11-13 12:06:36 +00:00
),
ListTile(
2024-09-27 15:43:02 +00:00
title: Text('${L10n.of(context)!.time}:'),
2021-11-13 12:06:36 +00:00
subtitle: Text(event.originServerTs.localizedTime(context)),
),
ListTile(
2024-09-27 15:43:02 +00:00
title: Text('${L10n.of(context)!.status}:'),
subtitle: Text(event.status.name),
2021-11-13 12:06:36 +00:00
),
2022-01-29 11:35:03 +00:00
ListTile(title: Text('${L10n.of(context)!.sourceCode}:')),
2021-11-13 12:06:36 +00:00
Padding(
padding: const EdgeInsets.all(12.0),
2021-11-22 18:27:40 +00:00
child: Material(
borderRadius: BorderRadius.circular(AppConfig.borderRadius),
2024-09-27 15:43:02 +00:00
color: theme.colorScheme.surfaceContainer,
2021-11-22 18:27:40 +00:00
child: SingleChildScrollView(
2024-09-27 15:43:02 +00:00
padding: const EdgeInsets.all(16),
2021-11-22 18:27:40 +00:00
scrollDirection: Axis.horizontal,
2024-04-18 09:12:55 +00:00
child: SelectableText(
2024-09-27 15:43:02 +00:00
prettyJson(MatrixEvent.fromJson(event.toJson())),
2024-04-18 09:12:55 +00:00
style: TextStyle(
2024-09-27 15:43:02 +00:00
color: theme.colorScheme.onSurface,
2024-04-18 09:12:55 +00:00
),
),
2021-11-22 18:27:40 +00:00
),
2021-11-13 12:06:36 +00:00
),
),
2024-09-27 15:43:02 +00:00
if (originalSource != null) ...[
ListTile(title: Text('${L10n.of(context)!.encrypted}:')),
Padding(
padding: const EdgeInsets.all(12.0),
child: Material(
borderRadius: BorderRadius.circular(AppConfig.borderRadius),
color: theme.colorScheme.surfaceContainer,
child: SingleChildScrollView(
padding: const EdgeInsets.all(16),
scrollDirection: Axis.horizontal,
child: SelectableText(
prettyJson(originalSource),
style: TextStyle(
color: theme.colorScheme.onSurface,
),
),
),
),
),
],
2021-11-13 12:06:36 +00:00
],
),
);
}
}