fluffychat/lib/pages/chat/events/state_message.dart

69 lines
2.3 KiB
Dart
Raw Normal View History

2020-01-01 19:10:13 +01:00
import 'package:flutter/material.dart';
2021-10-26 18:50:34 +02:00
import 'package:flutter_gen/gen_l10n/l10n.dart';
2021-10-26 18:50:34 +02:00
import 'package:matrix/matrix.dart';
2020-01-01 19:10:13 +01:00
2021-10-26 18:50:34 +02:00
import 'package:fluffychat/utils/matrix_sdk_extensions.dart/matrix_locals.dart';
2021-11-09 21:32:16 +01:00
import '../../../config/app_config.dart';
2021-02-07 08:59:58 +01:00
2020-01-01 19:10:13 +01:00
class StateMessage extends StatelessWidget {
final Event event;
final void Function(String) unfold;
2021-10-14 18:09:30 +02:00
const StateMessage(this.event, {@required this.unfold, Key key})
: super(key: key);
2020-01-01 19:10:13 +01:00
@override
Widget build(BuildContext context) {
if (event.unsigned['im.fluffychat.collapsed_state_event'] == true) {
return Container();
}
final int counter =
event.unsigned['im.fluffychat.collapsed_state_event_count'] ?? 0;
return Padding(
padding: const EdgeInsets.symmetric(
horizontal: 8.0,
vertical: 4.0,
),
child: Center(
child: InkWell(
onTap: counter != 0 ? () => unfold(event.eventId) : null,
borderRadius: BorderRadius.circular(AppConfig.borderRadius),
child: Container(
padding: const EdgeInsets.all(8),
decoration: BoxDecoration(
2021-04-25 15:09:47 +02:00
border: Border.all(
color: Theme.of(context).dividerColor,
2021-04-25 15:09:47 +02:00
),
color: Theme.of(context).scaffoldBackgroundColor,
2021-04-25 15:09:47 +02:00
borderRadius: BorderRadius.circular(AppConfig.borderRadius),
),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
Text(
event.getLocalizedBody(MatrixLocals(L10n.of(context))),
textAlign: TextAlign.center,
style: TextStyle(
fontSize: Theme.of(context).textTheme.bodyText1.fontSize *
AppConfig.fontSizeFactor,
color: Theme.of(context).textTheme.bodyText2.color,
decoration:
event.redacted ? TextDecoration.lineThrough : null,
),
),
if (counter != 0)
Text(
2021-08-14 11:30:18 +02:00
L10n.of(context).moreEvents(counter),
2021-10-14 18:09:30 +02:00
style: const TextStyle(
fontWeight: FontWeight.bold,
),
),
],
2020-09-21 19:21:24 +02:00
),
2020-01-19 15:07:42 +01:00
),
2020-01-03 11:57:00 +01:00
),
2020-01-01 19:10:13 +01:00
),
);
}
}