2022-12-08 16:39:13 +01:00
|
|
|
import 'package:flutter/foundation.dart';
|
2023-05-23 18:47:32 +02:00
|
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
2021-08-01 22:46:16 +02:00
|
|
|
import 'package:kiwi/kiwi.dart';
|
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
import 'package:nc_photos/account.dart';
|
2022-01-27 11:02:45 +01:00
|
|
|
import 'package:nc_photos/bloc/bloc_util.dart' as bloc_util;
|
2022-07-05 22:20:24 +02:00
|
|
|
import 'package:nc_photos/di_container.dart';
|
2021-08-01 22:46:16 +02:00
|
|
|
import 'package:nc_photos/entity/file.dart';
|
|
|
|
import 'package:nc_photos/entity/file_util.dart' as file_util;
|
|
|
|
import 'package:nc_photos/event/event.dart';
|
|
|
|
import 'package:nc_photos/throttler.dart';
|
|
|
|
import 'package:nc_photos/use_case/ls_trashbin.dart';
|
2022-12-16 16:01:04 +01:00
|
|
|
import 'package:np_codegen/np_codegen.dart';
|
2022-12-08 16:39:13 +01:00
|
|
|
import 'package:to_string/to_string.dart';
|
|
|
|
|
|
|
|
part 'ls_trashbin.g.dart';
|
2021-08-01 22:46:16 +02:00
|
|
|
|
|
|
|
abstract class LsTrashbinBlocEvent {
|
|
|
|
const LsTrashbinBlocEvent();
|
|
|
|
}
|
|
|
|
|
2022-12-08 16:39:13 +01:00
|
|
|
@toString
|
2021-08-01 22:46:16 +02:00
|
|
|
class LsTrashbinBlocQuery extends LsTrashbinBlocEvent {
|
|
|
|
const LsTrashbinBlocQuery(this.account);
|
|
|
|
|
|
|
|
@override
|
2022-12-08 16:39:13 +01:00
|
|
|
String toString() => _$toString();
|
2021-08-01 22:46:16 +02:00
|
|
|
|
|
|
|
final Account account;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// An external event has happened and may affect the state of this bloc
|
2022-12-08 16:39:13 +01:00
|
|
|
@toString
|
2021-08-01 22:46:16 +02:00
|
|
|
class _LsTrashbinBlocExternalEvent extends LsTrashbinBlocEvent {
|
|
|
|
const _LsTrashbinBlocExternalEvent();
|
|
|
|
|
|
|
|
@override
|
2022-12-08 16:39:13 +01:00
|
|
|
String toString() => _$toString();
|
2021-08-01 22:46:16 +02:00
|
|
|
}
|
|
|
|
|
2022-12-08 16:39:13 +01:00
|
|
|
@toString
|
2021-08-01 22:46:16 +02:00
|
|
|
abstract class LsTrashbinBlocState {
|
|
|
|
const LsTrashbinBlocState(this.account, this.items);
|
|
|
|
|
|
|
|
@override
|
2022-12-08 16:39:13 +01:00
|
|
|
String toString() => _$toString();
|
2021-08-01 22:46:16 +02:00
|
|
|
|
|
|
|
final Account? account;
|
|
|
|
final List<File> items;
|
|
|
|
}
|
|
|
|
|
|
|
|
class LsTrashbinBlocInit extends LsTrashbinBlocState {
|
|
|
|
LsTrashbinBlocInit() : super(null, const []);
|
|
|
|
}
|
|
|
|
|
|
|
|
class LsTrashbinBlocLoading extends LsTrashbinBlocState {
|
|
|
|
const LsTrashbinBlocLoading(Account? account, List<File> items)
|
|
|
|
: super(account, items);
|
|
|
|
}
|
|
|
|
|
|
|
|
class LsTrashbinBlocSuccess extends LsTrashbinBlocState {
|
|
|
|
const LsTrashbinBlocSuccess(Account? account, List<File> items)
|
|
|
|
: super(account, items);
|
|
|
|
}
|
|
|
|
|
2022-12-08 16:39:13 +01:00
|
|
|
@toString
|
2021-08-01 22:46:16 +02:00
|
|
|
class LsTrashbinBlocFailure extends LsTrashbinBlocState {
|
|
|
|
const LsTrashbinBlocFailure(
|
|
|
|
Account? account, List<File> items, this.exception)
|
|
|
|
: super(account, items);
|
|
|
|
|
|
|
|
@override
|
2022-12-08 16:39:13 +01:00
|
|
|
String toString() => _$toString();
|
2021-08-01 22:46:16 +02:00
|
|
|
|
|
|
|
final dynamic exception;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// The state of this bloc is inconsistent. This typically means that the data
|
|
|
|
/// may have been changed externally
|
|
|
|
class LsTrashbinBlocInconsistent extends LsTrashbinBlocState {
|
|
|
|
const LsTrashbinBlocInconsistent(Account? account, List<File> items)
|
|
|
|
: super(account, items);
|
|
|
|
}
|
|
|
|
|
2022-12-16 16:01:04 +01:00
|
|
|
@npLog
|
2021-08-01 22:46:16 +02:00
|
|
|
class LsTrashbinBloc extends Bloc<LsTrashbinBlocEvent, LsTrashbinBlocState> {
|
|
|
|
LsTrashbinBloc() : super(LsTrashbinBlocInit()) {
|
|
|
|
_fileRemovedEventListener =
|
|
|
|
AppEventListener<FileRemovedEvent>(_onFileRemovedEvent);
|
|
|
|
_fileTrashbinRestoredEventListener =
|
|
|
|
AppEventListener<FileTrashbinRestoredEvent>(
|
|
|
|
_onFileTrashbinRestoredEvent);
|
|
|
|
_fileRemovedEventListener.begin();
|
|
|
|
_fileTrashbinRestoredEventListener.begin();
|
|
|
|
|
|
|
|
_refreshThrottler = Throttler(
|
|
|
|
onTriggered: (_) {
|
2021-09-15 08:58:06 +02:00
|
|
|
add(const _LsTrashbinBlocExternalEvent());
|
2021-08-01 22:46:16 +02:00
|
|
|
},
|
|
|
|
logTag: "LsTrashbinBloc.refresh",
|
|
|
|
);
|
2022-07-09 07:59:09 +02:00
|
|
|
|
|
|
|
on<LsTrashbinBlocEvent>(_onEvent);
|
2021-08-01 22:46:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static LsTrashbinBloc of(Account account) {
|
2022-01-27 11:02:45 +01:00
|
|
|
final name = bloc_util.getInstNameForAccount("LsTrashbinBloc", account);
|
2021-08-01 22:46:16 +02:00
|
|
|
try {
|
2022-01-27 11:02:45 +01:00
|
|
|
_log.fine("[of] Resolving bloc for '$name'");
|
|
|
|
return KiwiContainer().resolve<LsTrashbinBloc>(name);
|
2021-08-01 22:46:16 +02:00
|
|
|
} catch (_) {
|
|
|
|
// no created instance for this account, make a new one
|
|
|
|
_log.info("[of] New bloc instance for account: $account");
|
|
|
|
final bloc = LsTrashbinBloc();
|
2022-01-27 11:02:45 +01:00
|
|
|
KiwiContainer().registerInstance<LsTrashbinBloc>(bloc, name: name);
|
2021-08-01 22:46:16 +02:00
|
|
|
return bloc;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-09 07:59:09 +02:00
|
|
|
Future<void> _onEvent(
|
|
|
|
LsTrashbinBlocEvent event, Emitter<LsTrashbinBlocState> emit) async {
|
|
|
|
_log.info("[_onEvent] $event");
|
2021-08-01 22:46:16 +02:00
|
|
|
if (event is LsTrashbinBlocQuery) {
|
2022-07-09 07:59:09 +02:00
|
|
|
await _onEventQuery(event, emit);
|
2021-08-01 22:46:16 +02:00
|
|
|
} else if (event is _LsTrashbinBlocExternalEvent) {
|
2022-07-09 07:59:09 +02:00
|
|
|
await _onExternalEvent(event, emit);
|
2021-08-01 22:46:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-09 07:59:09 +02:00
|
|
|
Future<void> _onEventQuery(
|
|
|
|
LsTrashbinBlocQuery ev, Emitter<LsTrashbinBlocState> emit) async {
|
2021-08-01 22:46:16 +02:00
|
|
|
try {
|
2022-07-09 07:59:09 +02:00
|
|
|
emit(LsTrashbinBlocLoading(ev.account, state.items));
|
|
|
|
emit(LsTrashbinBlocSuccess(ev.account, await _query(ev)));
|
2021-08-01 22:46:16 +02:00
|
|
|
} catch (e) {
|
|
|
|
_log.severe("[_onEventQuery] Exception while request", e);
|
2022-07-09 07:59:09 +02:00
|
|
|
emit(LsTrashbinBlocFailure(ev.account, state.items, e));
|
2021-08-01 22:46:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-09 07:59:09 +02:00
|
|
|
Future<void> _onExternalEvent(_LsTrashbinBlocExternalEvent ev,
|
|
|
|
Emitter<LsTrashbinBlocState> emit) async {
|
|
|
|
emit(LsTrashbinBlocInconsistent(state.account, state.items));
|
2021-08-01 22:46:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void _onFileRemovedEvent(FileRemovedEvent ev) {
|
|
|
|
if (state is LsTrashbinBlocInit) {
|
|
|
|
// no data in this bloc, ignore
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (file_util.isTrash(ev.account, ev.file)) {
|
|
|
|
_refreshThrottler.trigger(
|
|
|
|
maxResponceTime: const Duration(seconds: 3),
|
|
|
|
maxPendingCount: 10,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void _onFileTrashbinRestoredEvent(FileTrashbinRestoredEvent ev) {
|
|
|
|
if (state is LsTrashbinBlocInit) {
|
|
|
|
// no data in this bloc, ignore
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
_refreshThrottler.trigger(
|
|
|
|
maxResponceTime: const Duration(seconds: 3),
|
|
|
|
maxPendingCount: 10,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-12-19 19:09:38 +01:00
|
|
|
Future<List<File>> _query(LsTrashbinBlocQuery ev) async {
|
2022-07-05 22:20:24 +02:00
|
|
|
final c = KiwiContainer().resolve<DiContainer>();
|
2021-08-01 22:46:16 +02:00
|
|
|
// caching contents in trashbin doesn't sounds useful
|
2022-07-05 22:20:24 +02:00
|
|
|
final files = await LsTrashbin(c.fileRepoRemote)(ev.account);
|
2021-12-19 19:09:38 +01:00
|
|
|
return files.where((f) => file_util.isSupportedFormat(f)).toList();
|
2021-08-01 22:46:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
late final AppEventListener<FileRemovedEvent> _fileRemovedEventListener;
|
|
|
|
late final AppEventListener<FileTrashbinRestoredEvent>
|
|
|
|
_fileTrashbinRestoredEventListener;
|
|
|
|
|
|
|
|
late Throttler _refreshThrottler;
|
|
|
|
|
2022-12-20 17:49:14 +01:00
|
|
|
static final _log = _$LsTrashbinBlocNpLog.log;
|
2021-08-01 22:46:16 +02:00
|
|
|
}
|