added upload with multiple files #61

Merged
MineTec merged 7 commits from develop-uploadMultipleFiles into develop 2024-04-09 08:21:55 +00:00
4 changed files with 13 additions and 23 deletions
Showing only changes of commit cf4dea566e - Show all commits

View File

@@ -219,8 +219,8 @@ class _FilesState extends State<Files> {
leading: const Icon(Icons.add_a_photo_outlined),
title: const Text('Aus Gallerie hochladen'),
onTap: () {
FilePick.galleryPick().then((value) {
if(value != null) mediaUpload([value.path]);
FilePick.multipleGalleryPick().then((value) {
if(value != null) mediaUpload(value.map((e) => e.path).toList());
});
Navigator.of(context).pop();
},

View File

@@ -170,7 +170,6 @@ class _FilesUploadDialogState extends State<FilesUploadDialog> {
);
if(uploadTask.statusCode < 200 || uploadTask.statusCode > 299) {
// error code
setState(() {
Pupsi marked this conversation as resolved
Review

kommentar raus

kommentar raus
_isUploading = false;
_overallProgressValue = 0.0;
@@ -241,7 +240,7 @@ class _FilesUploadDialogState extends State<FilesUploadDialog> {
value: currentFile._uploadProgress,
borderRadius: const BorderRadius.all(Radius.circular(2)),
) : null,
leading: Container(
trailing: Container(
width: 24,
height: 24,
padding: EdgeInsets.zero,
@@ -256,23 +255,6 @@ class _FilesUploadDialogState extends State<FilesUploadDialog> {
});
}
},
icon: const Icon(Icons.close_outlined),
),
),
trailing: Container(
width: 24,
height: 24,
padding: EdgeInsets.zero,
child: IconButton(
tooltip: 'Namen löschen',
padding: EdgeInsets.zero,
onPressed: () {
if(!_isUploading) {
setState(() {
currentFile.fileName = '';
});
}
},
icon: const Icon(Icons.delete_outlined),
),
),

View File

@@ -111,8 +111,8 @@ class _ChatTextfieldState extends State<ChatTextfield> {
leading: const Icon(Icons.image),
title: const Text('Aus Gallerie auswählen'),
onTap: () {
FilePick.galleryPick().then((value) {
if(value != null) mediaUpload([value.path]);
FilePick.multipleGalleryPick().then((value) {
if(value != null) mediaUpload(value.map((e) => e.path).toList());
});
Navigator.of(context).pop();
},

View File

@@ -13,6 +13,14 @@ class FilePick {
return null;
}
static Future<List<XFile>?> multipleGalleryPick() async {
final pickedImages = await _picker.pickMultiImage();
if(pickedImages.isNotEmpty) {
return pickedImages;
}
return null;
}
static Future<List<String>?> documentPick() async {
var result = await FilePicker.platform.pickFiles(allowMultiple: true);
var paths = result?.files.nonNulls.map((e) => e.path).toList();