gallery_picker/lib/views/album_view/selected_medias_view.dart

100 lines
3.8 KiB
Dart
Raw Normal View History

2022-12-25 12:30:20 +03:00
import 'package:flutter/material.dart';
import 'package:get/get.dart';
2022-12-29 08:45:28 +03:00
import '../../controller/bottom_sheet_controller.dart';
2022-12-25 12:30:20 +03:00
import '../../controller/gallery_controller.dart';
import '../../models/config.dart';
2022-12-29 08:45:28 +03:00
class SelectedMediasView extends StatelessWidget {
2022-12-30 05:18:18 +03:00
final PhoneGalleryController controller;
final Config config;
SelectedMediasView({super.key, required this.controller})
: config = controller.config;
2022-12-25 12:30:20 +03:00
@override
Widget build(BuildContext context) {
double width = MediaQuery.of(context).size.width;
return Container(
color: config.bottomSheetColor,
width: width,
height: 65,
child: Padding(
padding: const EdgeInsets.only(left: 8.0),
child: Row(
children: [
SizedBox(
width: width * 0.8,
height: 55,
child: ListView(
scrollDirection: Axis.horizontal,
children: [
2022-12-29 08:45:28 +03:00
for (var selectedMedia in controller.selectedFiles)
2022-12-25 12:30:20 +03:00
Padding(
padding: const EdgeInsets.only(
top: 3.0, bottom: 3.0, right: 2),
2023-01-01 18:15:47 +03:00
child: !selectedMedia.thumbnailFailed
? Container(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(5),
image: DecorationImage(
fit: BoxFit.fill,
image: Image.memory(
selectedMedia.thumbnail!,
fit: BoxFit.fill,
).image),
),
child: const SizedBox(
width: 47,
height: 47,
),
)
: Container(
width: 47,
height: 47,
alignment: Alignment.center,
child: Icon(
selectedMedia.isImage
? Icons.image_not_supported
: Icons.videocam_off_rounded,
color: Colors.grey,
),
),
2022-12-25 12:30:20 +03:00
),
],
),
),
TextButton(
onPressed: () {
2022-12-29 08:45:28 +03:00
if (controller.selectedFiles.length == 1 &&
controller.heroBuilder != null) {
2022-12-25 12:30:20 +03:00
Navigator.of(context).push(
MaterialPageRoute<void>(builder: (BuildContext context) {
2022-12-29 08:45:28 +03:00
return controller.heroBuilder!(
controller.selectedFiles[0].medium.id,
controller.selectedFiles[0],
context);
2022-12-25 12:30:20 +03:00
}));
2022-12-29 08:45:28 +03:00
} else if (controller.multipleMediasBuilder != null) {
2022-12-25 12:30:20 +03:00
Navigator.of(context).push(
MaterialPageRoute<void>(builder: (BuildContext context) {
2022-12-29 08:45:28 +03:00
return controller.multipleMediasBuilder!(
controller.selectedFiles, context);
2022-12-25 12:30:20 +03:00
}));
} else {
2022-12-29 08:45:28 +03:00
controller.onSelect(controller.selectedFiles);
if (GetInstance().isRegistered<BottomSheetController>()) {
Get.find<BottomSheetController>().close();
} else {
2022-12-25 12:30:20 +03:00
Navigator.pop(context);
2022-12-29 08:45:28 +03:00
controller.disposeController();
2022-12-25 12:30:20 +03:00
}
}
},
child: config.selectIcon,
)
],
),
),
);
}
}