fluffychat/lib/components/message_content.dart

163 lines
5.6 KiB
Dart
Raw Normal View History

2020-01-03 09:09:14 +01:00
import 'package:bubble/bubble.dart';
import 'package:cached_network_image/cached_network_image.dart';
2020-01-01 19:10:13 +01:00
import 'package:famedlysdk/famedlysdk.dart';
2020-01-20 13:46:39 +01:00
import 'package:fluffychat/i18n/i18n.dart';
import 'package:fluffychat/utils/app_route.dart';
2020-01-19 15:07:42 +01:00
import 'package:fluffychat/utils/event_extension.dart';
import 'package:fluffychat/views/content_web_view.dart';
2020-02-16 12:35:04 +01:00
import 'package:fluffychat/views/image_viewer.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';
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:
case EventTypes.Sticker:
switch (event.messageType) {
case MessageTypes.Image:
case MessageTypes.Sticker:
final int size = 400;
2020-02-16 12:35:04 +01:00
final MxContent content = MxContent(event.content["url"]);
final String src = content.getThumbnail(
Matrix.of(context).client,
width: size * MediaQuery.of(context).devicePixelRatio,
height: size * MediaQuery.of(context).devicePixelRatio,
method: ThumbnailMethod.scale,
);
return Bubble(
padding: BubbleEdges.all(0),
radius: Radius.circular(10),
elevation: 0,
child: InkWell(
2020-02-16 12:35:04 +01:00
onTap: () => ImageViewer.show(context, content),
child: Container(
height: size.toDouble(),
width: size.toDouble(),
child: kIsWeb
? Image.network(
src,
fit: BoxFit.cover,
)
: CachedNetworkImage(
imageUrl: src,
fit: BoxFit.cover,
placeholder: (c, s) => Center(
child: CircularProgressIndicator(),
),
),
),
),
);
case MessageTypes.Audio:
return Container(
width: 200,
child: RaisedButton(
color: Colors.blueGrey,
child: Row(
children: <Widget>[
Icon(Icons.play_arrow, color: Colors.white),
Text(
2020-01-20 13:46:39 +01:00
I18n.of(context).play(event.body),
overflow: TextOverflow.fade,
softWrap: false,
maxLines: 1,
style: TextStyle(color: Colors.white),
),
],
),
onPressed: () => Navigator.of(context).push(
AppRoute.defaultRoute(
context,
ContentWebView(MxContent(event.content["url"])),
),
),
),
);
case MessageTypes.Video:
return Container(
width: 200,
child: RaisedButton(
color: Colors.blueGrey,
child: Row(
children: <Widget>[
Icon(Icons.play_arrow, color: Colors.white),
Text(
2020-01-20 13:46:39 +01:00
I18n.of(context).play(event.body),
overflow: TextOverflow.fade,
softWrap: false,
maxLines: 1,
style: TextStyle(color: Colors.white),
),
],
),
onPressed: () => Navigator.of(context).push(
AppRoute.defaultRoute(
context,
ContentWebView(MxContent(event.content["url"])),
),
),
),
);
case MessageTypes.File:
return Container(
width: 200,
child: RaisedButton(
color: Colors.blueGrey,
child: Text(
2020-01-20 13:46:39 +01:00
I18n.of(context).download(event.body),
overflow: TextOverflow.fade,
softWrap: false,
maxLines: 1,
style: TextStyle(color: Colors.white),
),
onPressed: () => launch(
MxContent(event.content["url"])
.getDownloadLink(Matrix.of(context).client),
),
),
);
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-01-06 20:36:11 +01:00
return LinkText(
2020-02-11 12:49:39 +01:00
text: event.getLocalizedBody(context, hideQuotes: 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-01-02 23:38:46 +01:00
return Text(
2020-01-19 15:07:42 +01:00
event.getLocalizedBody(context),
2020-01-02 23:38:46 +01:00
style: TextStyle(
color: textColor,
),
);
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
}
}
}