gallery_picker/lib/gallery_picker.dart

136 lines
4.4 KiB
Dart
Raw Normal View History

2022-12-25 12:30:20 +03:00
library gallery_picker;
export 'models/config.dart';
2022-12-29 08:45:28 +03:00
export 'models/media_file.dart';
export 'models/mode.dart';
export 'models/medium.dart';
export 'models/gallery_media.dart';
export 'models/gallery_album.dart';
export 'package:page_transition/src/enum.dart';
2022-12-29 08:45:28 +03:00
export 'user_widgets/thumbnail_media.dart';
export 'user_widgets/album_categories_view.dart';
export 'user_widgets/album_media_view.dart';
2022-12-29 08:45:28 +03:00
export 'user_widgets/date_category_view.dart';
2022-12-29 12:12:06 +03:00
export 'user_widgets/thumbnail_album.dart';
export 'user_widgets/gallery_picker_builder.dart';
2022-12-29 08:45:28 +03:00
export 'user_widgets/photo_provider.dart';
export 'user_widgets/video_provider.dart';
export 'user_widgets/media_provider.dart';
2023-01-20 09:58:21 +03:00
export 'views/picker_scaffold.dart';
2023-01-21 11:08:55 +03:00
export 'package:bottom_sheet_scaffold/models/sheet_status.dart';
export 'package:bottom_sheet_scaffold/views/bottom_sheet_builder.dart';
2022-12-29 08:45:28 +03:00
export 'views/gallery_picker_view/gallery_picker_view.dart';
2023-01-20 09:58:21 +03:00
import 'package:bottom_sheet_scaffold/bottom_sheet_scaffold.dart';
2022-12-25 12:30:20 +03:00
import 'package:flutter/material.dart';
2022-12-29 08:45:28 +03:00
import 'package:gallery_picker/models/gallery_media.dart';
2022-12-25 12:30:20 +03:00
import 'package:get/get.dart';
import 'package:page_transition/page_transition.dart';
2022-12-25 12:30:20 +03:00
import '../../controller/gallery_controller.dart';
2022-12-29 08:45:28 +03:00
import 'controller/picker_listener.dart';
2022-12-25 12:30:20 +03:00
import 'models/config.dart';
import 'models/media_file.dart';
2022-12-29 08:45:28 +03:00
import 'views/gallery_picker_view/gallery_picker_view.dart';
2022-12-25 12:30:20 +03:00
2022-12-29 08:45:28 +03:00
class GalleryPicker {
static Stream<List<MediaFile>> get listenSelectedFiles {
var controller = Get.put(PickerListener());
return controller.stream;
}
2022-12-25 12:30:20 +03:00
2022-12-29 08:45:28 +03:00
static void disposeSelectedFilesListener() {
if (GetInstance().isRegistered<PickerListener>()) {
Get.find<PickerListener>().dispose();
}
}
2022-12-25 12:30:20 +03:00
2022-12-29 08:45:28 +03:00
static void dispose() {
2022-12-25 12:30:20 +03:00
if (GetInstance().isRegistered<PhoneGalleryController>()) {
2022-12-29 08:45:28 +03:00
Get.find<PhoneGalleryController>().disposeController();
2022-12-25 12:30:20 +03:00
}
}
static Future<List<MediaFile>?> pickMedia(
2022-12-29 08:45:28 +03:00
{Config? config,
bool startWithRecent = false,
bool singleMedia = false,
PageTransitionType pageTransitionType = PageTransitionType.rightToLeft,
List<MediaFile>? initSelectedMedia,
List<MediaFile>? extraRecentMedia,
2022-12-29 08:45:28 +03:00
required BuildContext context}) async {
List<MediaFile>? media;
2022-12-29 08:45:28 +03:00
await Navigator.push(
context,
PageTransition(
type: pageTransitionType,
child: GalleryPickerView(
onSelect: (mediaTmp) {
media = mediaTmp;
},
config: config,
singleMedia: singleMedia,
initSelectedMedia: initSelectedMedia,
extraRecentMedia: extraRecentMedia,
startWithRecent: startWithRecent,
)));
return media;
2022-12-25 12:30:20 +03:00
}
static Future<void> pickMediaWithBuilder(
2022-12-29 08:45:28 +03:00
{Config? config,
required Widget Function(List<MediaFile> media, BuildContext context)?
multipleMediaBuilder,
2022-12-29 08:45:28 +03:00
Widget Function(String tag, MediaFile media, BuildContext context)?
heroBuilder,
bool singleMedia = false,
PageTransitionType pageTransitionType = PageTransitionType.rightToLeft,
List<MediaFile>? initSelectedMedia,
List<MediaFile>? extraRecentMedia,
2022-12-29 08:45:28 +03:00
bool startWithRecent = false,
required BuildContext context}) async {
await Navigator.push(
context,
PageTransition(
type: pageTransitionType,
child: GalleryPickerView(
onSelect: (media) {},
multipleMediaBuilder: multipleMediaBuilder,
heroBuilder: heroBuilder,
singleMedia: singleMedia,
config: config,
initSelectedMedia: initSelectedMedia,
extraRecentMedia: extraRecentMedia,
startWithRecent: startWithRecent,
)));
2022-12-25 12:30:20 +03:00
}
2022-12-29 08:45:28 +03:00
static Future<void> openSheet() async {
2023-01-20 09:58:21 +03:00
BottomSheetPanel.open();
2022-12-25 12:30:20 +03:00
}
2022-12-29 08:45:28 +03:00
static Future<void> closeSheet() async {
2023-01-20 09:58:21 +03:00
BottomSheetPanel.close();
2022-12-25 12:30:20 +03:00
}
2022-12-29 08:45:28 +03:00
static bool get isSheetOpened {
2023-01-20 09:58:21 +03:00
return BottomSheetPanel.isOpen;
}
static bool get isSheetExpanded {
return BottomSheetPanel.isExpanded;
}
static bool get isSheetCollapsed {
return BottomSheetPanel.isCollapsed;
2022-12-25 12:30:20 +03:00
}
2022-12-29 08:45:28 +03:00
static Future<GalleryMedia?> get collectGallery async {
return await PhoneGalleryController.collectGallery;
}
2023-01-20 09:58:21 +03:00
static Future<GalleryMedia?> get initializeGallery async {
final controller = Get.put(PhoneGalleryController());
await controller.initializeAlbums();
return controller.media;
}
2022-12-25 12:30:20 +03:00
}