Fix Android Export Image Preview
continuous-integration/drone/pr Build is running Details

This commit is contained in:
Sarah Jamie Lewis 2023-03-20 14:16:25 -07:00
parent 1a70937898
commit d5d9bd8530
1 changed files with 42 additions and 29 deletions

View File

@ -9,6 +9,7 @@ import 'package:cwtch/models/message.dart';
import 'package:cwtch/models/profile.dart'; import 'package:cwtch/models/profile.dart';
import 'package:cwtch/widgets/malformedbubble.dart'; import 'package:cwtch/widgets/malformedbubble.dart';
import 'package:file_picker_desktop/file_picker_desktop.dart'; import 'package:file_picker_desktop/file_picker_desktop.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import '../main.dart'; import '../main.dart';
@ -172,7 +173,7 @@ class FileBubbleState extends State<FileBubble> {
child: GestureDetector( child: GestureDetector(
child: Padding(padding: EdgeInsets.all(1.0), child: getPreview(context)), child: Padding(padding: EdgeInsets.all(1.0), child: getPreview(context)),
onTap: () { onTap: () {
pop(bcontext, myFile!, wdgMessage); pop(bcontext, myFile!, widget.nameSuggestion);
}, },
))); )));
} else { } else {
@ -406,37 +407,49 @@ class FileBubbleState extends State<FileBubble> {
); );
} }
void pop(context, File myFile, Widget meta) async { void pop(context, File myFile, String meta) async {
await showDialog( await showDialog(
context: context, context: context,
builder: (bcontext) => Dialog( builder: (bcontext) => Dialog(
alignment: Alignment.center, alignment: Alignment.topCenter,
child: Container( child: SingleChildScrollView(
padding: EdgeInsets.all(10), controller: ScrollController(),
child: Column(children: [ child: Container(
ListTile( padding: EdgeInsets.all(10),
title: meta, child: Column(mainAxisAlignment: MainAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.center, children: [
trailing: IconButton( ListTile(
icon: Icon(Icons.close), leading: Icon(CwtchIcons.attached_file_2),
color: Provider.of<Settings>(bcontext, listen: false).theme.toolbarIconColor, title: Text(meta),
iconSize: 32, trailing: IconButton(
onPressed: () { icon: Icon(Icons.close),
Navigator.pop(bcontext, true); color: Provider.of<Settings>(bcontext, listen: false).theme.toolbarIconColor,
})), iconSize: 32,
Image.file( onPressed: () {
myFile, Navigator.pop(bcontext, true);
cacheWidth: (MediaQuery.of(bcontext).size.width * 0.6).floor(), })),
width: (MediaQuery.of(bcontext).size.width * 0.6), Padding(
height: (MediaQuery.of(bcontext).size.height * 0.6), padding: EdgeInsets.all(10),
fit: BoxFit.scaleDown, child: Image.file(
), myFile,
SizedBox( cacheWidth: (MediaQuery.of(bcontext).size.width * 0.6).floor(),
height: 20, width: (MediaQuery.of(bcontext).size.width * 0.6),
), height: (MediaQuery.of(bcontext).size.height * 0.6),
Visibility(visible: !Platform.isAndroid, child: Text(myFile.path, textAlign: TextAlign.center)), fit: BoxFit.scaleDown,
Visibility(visible: Platform.isAndroid, child: IconButton(icon: Icon(Icons.arrow_downward), onPressed: androidExport)), )),
]), Visibility(visible: !Platform.isAndroid, maintainSize: false, child: Text(myFile.path, textAlign: TextAlign.center)),
))); Visibility(
visible: Platform.isAndroid,
maintainSize: false,
child: Padding(
padding: EdgeInsets.all(10),
child: ElevatedButton.icon(
icon: Icon(Icons.arrow_downward),
onPressed: androidExport,
label: Text(
AppLocalizations.of(context)!.saveBtn,
)))),
]),
))));
} }
void androidExport() async { void androidExport() async {