fluffychat/lib/components/message_content.dart

136 lines
4.8 KiB
Dart
Raw Normal View History

2020-01-01 19:10:13 +01:00
import 'package:famedlysdk/famedlysdk.dart';
2020-03-15 11:27:51 +01:00
import 'package:fluffychat/components/audio_player.dart';
2020-04-02 14:05:32 +02:00
import 'package:fluffychat/components/image_bubble.dart';
2020-01-20 13:46:39 +01:00
import 'package:fluffychat/i18n/i18n.dart';
2020-01-19 15:07:42 +01:00
import 'package:fluffychat/utils/event_extension.dart';
2020-01-03 09:09:14 +01:00
import 'package:flutter/foundation.dart';
2020-01-01 19:10:13 +01:00
import 'package:flutter/material.dart';
2020-01-06 20:36:11 +01:00
import 'package:link_text/link_text.dart';
2020-01-01 19:10:13 +01:00
import 'package:url_launcher/url_launcher.dart';
2020-03-29 20:13:25 +02:00
import 'package:fluffychat/utils/matrix_file_extension.dart';
2020-01-01 19:10:13 +01:00
import 'matrix.dart';
class MessageContent extends StatelessWidget {
final Event event;
final Color textColor;
2020-01-19 15:07:42 +01:00
const MessageContent(this.event, {this.textColor});
2020-01-01 19:10:13 +01:00
@override
Widget build(BuildContext context) {
switch (event.type) {
case EventTypes.Message:
2020-02-21 09:45:37 +01:00
case EventTypes.Encrypted:
case EventTypes.Sticker:
2020-03-29 20:13:25 +02:00
switch (event.messageType) {
case MessageTypes.Image:
case MessageTypes.Sticker:
2020-04-02 14:05:32 +02:00
return ImageBubble(event);
case MessageTypes.Audio:
2020-03-15 11:27:51 +01:00
return AudioPlayer(
2020-03-29 20:13:25 +02:00
event,
2020-03-15 11:27:51 +01:00
color: textColor,
);
2020-03-13 21:58:48 +01:00
case MessageTypes.Video:
case MessageTypes.File:
return Container(
2020-03-13 21:58:48 +01:00
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: <Widget>[
RaisedButton(
2020-03-29 12:06:25 +02:00
color: Colors.blueGrey,
child: Text(
I18n.of(context).downloadFile,
overflow: TextOverflow.fade,
softWrap: false,
maxLines: 1,
style: TextStyle(color: Colors.white),
),
onPressed: () async {
if (kIsWeb) {
if (event.room.encrypted) {
Scaffold.of(context).showSnackBar(
SnackBar(
content:
Text(I18n.of(context).notSupportedInWeb),
),
);
}
await launch(
MxContent(event.content["url"])
.getDownloadLink(event.room.client),
);
return;
}
2020-03-29 20:13:25 +02:00
final MatrixFile matrixFile = await Matrix.of(context)
2020-03-29 12:06:25 +02:00
.tryRequestWithLoadingDialog(
event.downloadAndDecryptAttachment(),
);
2020-03-29 20:13:25 +02:00
matrixFile.open();
2020-03-29 12:06:25 +02:00
}),
2020-03-13 22:04:32 +01:00
Text(
"- " +
(event.content.containsKey("filename")
? event.content["filename"]
: event.body),
style: TextStyle(
color: textColor,
fontWeight: FontWeight.bold,
),
),
2020-03-13 21:58:48 +01:00
if (event.sizeString != null)
Text(
2020-03-13 22:04:32 +01:00
"- " + event.sizeString,
2020-03-13 21:58:48 +01:00
style: TextStyle(
color: textColor,
2020-03-13 22:04:32 +01:00
fontWeight: FontWeight.bold,
2020-03-13 21:58:48 +01:00
),
),
2020-03-13 21:58:48 +01:00
],
),
);
2020-02-18 08:13:20 +01:00
case MessageTypes.BadEncrypted:
case MessageTypes.Text:
case MessageTypes.Reply:
case MessageTypes.Location:
case MessageTypes.None:
case MessageTypes.Notice:
case MessageTypes.Emote:
2020-02-21 09:45:37 +01:00
default:
2020-04-08 17:43:07 +02:00
if (event.content['msgtype'] == Matrix.callNamespace) {
return RaisedButton(
color: Theme.of(context).backgroundColor,
child: Row(
mainAxisSize: MainAxisSize.min,
children: <Widget>[
Icon(Icons.phone),
Text(I18n.of(context).videoCall),
],
),
onPressed: () => launch(event.body),
);
}
2020-01-06 20:36:11 +01:00
return LinkText(
2020-02-20 20:45:38 +01:00
text: event.getLocalizedBody(context, hideReply: true),
2020-01-06 20:36:11 +01:00
textStyle: TextStyle(
color: textColor,
decoration: event.redacted ? TextDecoration.lineThrough : null,
),
);
2020-01-04 09:37:09 +01:00
}
2020-02-21 09:45:37 +01:00
break;
2020-01-19 15:07:42 +01:00
default:
2020-01-02 23:38:46 +01:00
return Text(
2020-01-20 13:46:39 +01:00
I18n.of(context).userSentUnknownEvent(
event.sender.calcDisplayname(), event.typeKey),
2020-01-02 23:38:46 +01:00
style: TextStyle(
color: textColor,
2020-01-19 15:07:42 +01:00
decoration: event.redacted ? TextDecoration.lineThrough : null,
2020-01-02 23:38:46 +01:00
),
);
2020-01-01 19:10:13 +01:00
}
}
}