ente/lib/ui/home/home_gallery_widget.dart

96 lines
3.3 KiB
Dart
Raw Normal View History

2022-10-20 09:21:23 +00:00
import 'package:flutter/material.dart';
import 'package:photos/core/configuration.dart';
import 'package:photos/core/event_bus.dart';
import 'package:photos/db/files_db.dart';
import 'package:photos/events/backup_folders_updated_event.dart';
import 'package:photos/events/files_updated_event.dart';
import 'package:photos/events/force_reload_home_gallery_event.dart';
import 'package:photos/events/local_photos_updated_event.dart';
import 'package:photos/models/file_load_result.dart';
import 'package:photos/models/gallery_type.dart';
2022-10-20 09:21:23 +00:00
import 'package:photos/models/selected_files.dart';
import 'package:photos/services/collections_service.dart';
import 'package:photos/services/ignored_files_service.dart';
import 'package:photos/ui/viewer/actions/file_selection_overlay_bar.dart';
2022-10-20 09:21:23 +00:00
import 'package:photos/ui/viewer/gallery/gallery.dart';
class HomeGalleryWidget extends StatelessWidget {
final Widget? header;
final Widget? footer;
final SelectedFiles selectedFiles;
2022-10-20 09:21:23 +00:00
const HomeGalleryWidget({
Key? key,
2022-10-20 09:21:23 +00:00
this.header,
this.footer,
required this.selectedFiles,
2022-10-20 09:21:23 +00:00
}) : super(key: key);
@override
Widget build(BuildContext context) {
2022-11-06 08:34:06 +00:00
final double bottomSafeArea = MediaQuery.of(context).padding.bottom;
2022-10-20 09:21:23 +00:00
final gallery = Gallery(
asyncLoader: (creationStartTime, creationEndTime, {limit, asc}) async {
final ownerID = Configuration.instance.getUserID();
final hasSelectedAllForBackup =
Configuration.instance.hasSelectedAllFoldersForBackup();
2022-10-27 06:07:20 +00:00
final collectionsToHide =
CollectionsService.instance.collectionsHiddenFromTimeline();
2022-10-20 09:21:23 +00:00
FileLoadResult result;
if (hasSelectedAllForBackup) {
result = await FilesDB.instance.getAllLocalAndUploadedFiles(
creationStartTime,
creationEndTime,
ownerID!,
2022-10-20 09:21:23 +00:00
limit: limit,
asc: asc,
2022-10-27 06:07:20 +00:00
ignoredCollectionIDs: collectionsToHide,
2022-10-20 09:21:23 +00:00
);
} else {
result = await FilesDB.instance.getAllPendingOrUploadedFiles(
creationStartTime,
creationEndTime,
ownerID!,
2022-10-20 09:21:23 +00:00
limit: limit,
asc: asc,
2022-10-27 06:07:20 +00:00
ignoredCollectionIDs: collectionsToHide,
2022-10-20 09:21:23 +00:00
);
}
// hide ignored files from home page UI
final ignoredIDs = await IgnoredFilesService.instance.ignoredIDs;
result.files.removeWhere(
(f) =>
f.uploadedFileID == null &&
IgnoredFilesService.instance.shouldSkipUpload(ignoredIDs, f),
);
return result;
},
reloadEvent: Bus.instance.on<LocalPhotosUpdatedEvent>(),
removalEventTypes: const {
EventType.deletedFromRemote,
EventType.deletedFromEverywhere,
EventType.archived,
2022-10-27 07:23:45 +00:00
EventType.hide,
2022-10-20 09:21:23 +00:00
},
forceReloadEvents: [
Bus.instance.on<BackupFoldersUpdatedEvent>(),
Bus.instance.on<ForceReloadHomeGalleryEvent>(),
],
tagPrefix: "home_gallery",
selectedFiles: selectedFiles,
header: header,
footer: footer,
// scrollSafe area -> SafeArea + Preserver more + Nav Bar buttons
scrollBottomSafeArea: bottomSafeArea + 180,
2022-10-20 09:21:23 +00:00
);
return Stack(
children: [
gallery,
FileSelectionOverlayBar(GalleryType.homepage, selectedFiles)
],
);
// return gallery;
2022-10-20 09:21:23 +00:00
}
}