import 'package:flutter/material.dart'; import 'package:photos/core/event_bus.dart'; import 'package:photos/db/files_db.dart'; import 'package:photos/events/collection_updated_event.dart'; import 'package:photos/events/files_updated_event.dart'; import 'package:photos/models/collection_items.dart'; import 'package:photos/models/galleryType.dart'; import 'package:photos/models/selected_files.dart'; import 'package:photos/ui/gallery.dart'; import 'package:photos/ui/gallery_app_bar_widget.dart'; import 'package:photos/ui/gallery_overlay_widget.dart'; class CollectionPage extends StatelessWidget { final CollectionWithThumbnail c; final String tagPrefix; final GalleryType appBarType; final GalleryType overlayType; final _selectedFiles = SelectedFiles(); CollectionPage( this.c, { this.tagPrefix = "collection", this.appBarType = GalleryType.owned_collection, this.overlayType = GalleryType.owned_collection, Key key, }) : super(key: key); @override Widget build(Object context) { final initialFiles = c.thumbnail != null ? [c.thumbnail] : null; final gallery = Gallery( asyncLoader: (creationStartTime, creationEndTime, {limit, asc}) { return FilesDB.instance.getFilesInCollection( c.collection.id, creationStartTime, creationEndTime, limit: limit, asc: asc, ); }, reloadEvent: Bus.instance .on() .where((event) => event.collectionID == c.collection.id), removalEventTypes: const { EventType.deletedFromRemote, EventType.deletedFromEverywhere, }, tagPrefix: tagPrefix, selectedFiles: _selectedFiles, initialFiles: initialFiles, smallerTodayFont: true, albumName: c.collection.name, footer: const SizedBox(height: 32), ); return Scaffold( appBar: PreferredSize( preferredSize: Size.fromHeight(50.0), child: GalleryAppBarWidget( appBarType, c.collection.name, _selectedFiles, collection: c.collection, ), ), body: Stack( alignment: Alignment.bottomCenter, children: [ gallery, GalleryOverlayWidget( overlayType, _selectedFiles, collection: c.collection, ), ], ), ); } }