import 'package:nc_photos/account.dart'; import 'package:nc_photos/di_container.dart'; import 'package:nc_photos/entity/collection.dart'; import 'package:nc_photos/entity/collection/adapter.dart'; import 'package:nc_photos/entity/collection/adapter/adapter_mixin.dart'; import 'package:nc_photos/entity/collection/content_provider/ad_hoc.dart'; import 'package:nc_photos/entity/collection_item.dart'; import 'package:nc_photos/entity/collection_item/basic_item.dart'; import 'package:nc_photos/entity/file_util.dart' as file_util; import 'package:nc_photos/use_case/find_file_descriptor.dart'; class CollectionAdHocAdapter with CollectionAdapterReadOnlyTag, CollectionAdapterUnremovableTag, CollectionAdapterUnshareableTag implements CollectionAdapter { CollectionAdHocAdapter(this._c, this.account, this.collection) : _provider = collection.contentProvider as CollectionAdHocProvider; @override Stream> listItem() async* { final files = await FindFileDescriptor(_c)( account, _provider.fileIds, onFileNotFound: (_) { // ignore not found }, ); yield files .where((f) => file_util.isSupportedFormat(f)) .map((f) => BasicCollectionFileItem(f)) .toList(); } @override Future adaptToNewItem(CollectionItem original) async { if (original is CollectionFileItem) { return BasicCollectionFileItem(original.file); } else { throw UnsupportedError("Unsupported type: ${original.runtimeType}"); } } @override bool isItemDeletable(CollectionItem item) => true; @override bool isPermitted(CollectionCapability capability) => _provider.capabilities.contains(capability); final DiContainer _c; final Account account; final Collection collection; final CollectionAdHocProvider _provider; }