fluffychat/lib/pages/send_file_dialog.dart

106 lines
3.0 KiB
Dart
Raw Normal View History

import 'package:matrix/matrix.dart';
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/l10n.dart';
2020-09-04 12:56:25 +02:00
2020-12-25 09:58:34 +01:00
import 'package:future_loading_dialog/future_loading_dialog.dart';
import '../utils/matrix_sdk_extensions.dart/matrix_file_extension.dart';
2021-04-24 09:15:59 +02:00
import '../utils/room_send_file_extension.dart';
import '../utils/resize_image.dart';
2020-09-04 12:56:25 +02:00
class SendFileDialog extends StatefulWidget {
final Room room;
final MatrixFile file;
2021-01-18 10:43:00 +01:00
const SendFileDialog({
this.room,
this.file,
Key key,
}) : super(key: key);
2020-09-04 12:56:25 +02:00
@override
_SendFileDialogState createState() => _SendFileDialogState();
}
class _SendFileDialogState extends State<SendFileDialog> {
bool origImage = false;
bool _isSending = false;
2021-10-26 18:47:05 +02:00
static const maxWidth = 1600;
2020-09-04 12:56:25 +02:00
Future<void> _send() async {
var file = widget.file;
if (file is MatrixImageFile && !origImage) {
try {
2021-10-26 18:47:05 +02:00
file = await resizeImage(file, max: maxWidth);
2020-09-04 12:56:25 +02:00
} catch (e) {
// couldn't resize
}
}
await widget.room.sendFileEventWithThumbnail(file);
}
@override
Widget build(BuildContext context) {
2021-02-24 12:17:23 +01:00
var sendStr = L10n.of(context).sendFile;
2020-09-04 12:56:25 +02:00
if (widget.file is MatrixImageFile) {
2021-02-24 12:17:23 +01:00
sendStr = L10n.of(context).sendImage;
2020-09-04 12:56:25 +02:00
} else if (widget.file is MatrixAudioFile) {
2021-02-24 12:17:23 +01:00
sendStr = L10n.of(context).sendAudio;
2020-09-04 12:56:25 +02:00
} else if (widget.file is MatrixVideoFile) {
2021-02-24 12:17:23 +01:00
sendStr = L10n.of(context).sendVideo;
2020-09-04 12:56:25 +02:00
}
Widget contentWidget;
if (widget.file is MatrixImageFile) {
contentWidget = Column(mainAxisSize: MainAxisSize.min, children: <Widget>[
Flexible(
child: Image.memory(
widget.file.bytes,
fit: BoxFit.contain,
),
),
Text(widget.file.name),
Row(
children: <Widget>[
Checkbox(
value: origImage,
onChanged: (v) => setState(() => origImage = v),
),
InkWell(
onTap: () => setState(() => origImage = !origImage),
2021-02-24 12:17:23 +01:00
child: Text(L10n.of(context).sendOriginal +
' (${widget.file.sizeString})'),
2020-09-04 12:56:25 +02:00
),
],
)
]);
} else {
contentWidget = Text('${widget.file.name} (${widget.file.sizeString})');
}
return AlertDialog(
title: Text(sendStr),
content: contentWidget,
actions: <Widget>[
2021-02-27 07:53:34 +01:00
TextButton(
2020-09-04 12:56:25 +02:00
onPressed: () {
// just close the dialog
2021-02-24 12:17:23 +01:00
Navigator.of(context, rootNavigator: false).pop();
2020-09-04 12:56:25 +02:00
},
2021-03-04 12:28:06 +01:00
child: Text(L10n.of(context).cancel),
2020-09-04 12:56:25 +02:00
),
2021-02-27 07:53:34 +01:00
TextButton(
onPressed: _isSending
? null
: () async {
setState(() {
_isSending = true;
});
2020-12-25 09:58:34 +01:00
await showFutureLoadingDialog(
context: context, future: () => _send());
2021-03-04 12:28:06 +01:00
Navigator.of(context, rootNavigator: false).pop();
},
2021-03-04 12:28:06 +01:00
child: Text(L10n.of(context).send),
2020-09-04 12:56:25 +02:00
),
],
);
}
}