2023-09-11 19:01:47 +02:00
|
|
|
part of '../sharing_browser.dart';
|
|
|
|
|
|
|
|
/// List shares to be shown in [SharingBrowser]
|
|
|
|
@npLog
|
2024-06-17 18:04:53 +02:00
|
|
|
class _Bloc extends Bloc<_Event, _State> with BlocForEachMixin<_Event, _State> {
|
2023-09-11 19:01:47 +02:00
|
|
|
_Bloc({
|
|
|
|
required this.account,
|
|
|
|
required this.accountPrefController,
|
|
|
|
required this.sharingsController,
|
|
|
|
}) : super(_State.init()) {
|
|
|
|
on<_Init>(_onInit);
|
|
|
|
on<_TransformItems>(_onTransformItems);
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> _onInit(_Init ev, Emitter<_State> emit) async {
|
|
|
|
_log.info(ev);
|
|
|
|
try {
|
|
|
|
await _importPotentialSharedAlbum();
|
|
|
|
} catch (e, stackTrace) {
|
|
|
|
_log.severe(
|
|
|
|
"[_onInit] Failed while _importPotentialSharedAlbum", e, stackTrace);
|
|
|
|
}
|
|
|
|
unawaited(sharingsController.reload());
|
2024-06-17 18:04:53 +02:00
|
|
|
return forEach(
|
|
|
|
emit,
|
2023-09-11 19:01:47 +02:00
|
|
|
sharingsController.stream,
|
|
|
|
onData: (data) => state.copyWith(
|
|
|
|
items: data.data,
|
|
|
|
isLoading: data.hasNext,
|
|
|
|
),
|
|
|
|
onError: (e, stackTrace) {
|
|
|
|
_log.severe("[_onInit] Uncaught exception", e, stackTrace);
|
|
|
|
return state.copyWith(
|
|
|
|
isLoading: false,
|
|
|
|
error: ExceptionEvent(e, stackTrace),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> _onTransformItems(
|
|
|
|
_TransformItems ev, Emitter<_State> emit) async {
|
|
|
|
_log.info(ev);
|
|
|
|
// group shares of the same file
|
|
|
|
final map = <String, List<SharingStreamShareData>>{};
|
|
|
|
for (final i in ev.items) {
|
|
|
|
if (i is SharingStreamShareData) {
|
|
|
|
final isSharedByMe = (i.share.uidOwner == account.userId);
|
|
|
|
final groupKey = "${i.share.path}?$isSharedByMe";
|
|
|
|
map[groupKey] ??= <SharingStreamShareData>[];
|
|
|
|
map[groupKey]!.add(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
final results = <_Item>[];
|
|
|
|
// sort and convert the sub-lists
|
|
|
|
for (final list in map.values) {
|
|
|
|
results.add(_Item.fromSharingStreamData(
|
|
|
|
account, list.sortedBy((e) => e.share.stime).reversed.toList()));
|
|
|
|
}
|
|
|
|
// then sort the list itself
|
|
|
|
emit(state.copyWith(
|
|
|
|
transformedItems: results.sortedBy((e) => e.sortTime).reversed.toList(),
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<List<Album>> _importPotentialSharedAlbum() async {
|
|
|
|
final c = KiwiContainer().resolve<DiContainer>().copyWith(
|
|
|
|
// don't want the potential albums to be cached at this moment
|
|
|
|
fileRepo: const OrNull(FileRepo(FileWebdavDataSource())),
|
|
|
|
albumRepo: OrNull(AlbumRepo(AlbumRemoteDataSource())),
|
|
|
|
);
|
|
|
|
try {
|
|
|
|
return await ImportPotentialSharedAlbum(c)(
|
2024-02-25 05:09:57 +01:00
|
|
|
account, accountPrefController.shareFolderValue);
|
2023-09-11 19:01:47 +02:00
|
|
|
} catch (e, stackTrace) {
|
|
|
|
_log.shout(
|
|
|
|
"[_importPotentialSharedAlbum] Failed while ImportPotentialSharedAlbum",
|
|
|
|
e,
|
|
|
|
stackTrace);
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
final Account account;
|
|
|
|
final AccountPrefController accountPrefController;
|
|
|
|
final SharingsController sharingsController;
|
|
|
|
}
|