mirror of
https://gitlab.com/nkming2/nc-photos.git
synced 2025-01-22 16:56:19 +01:00
Trigger a Photos tab refresh after image processor is done
This commit is contained in:
parent
abdded09ca
commit
a4a4d952f7
6 changed files with 75 additions and 11 deletions
|
@ -121,6 +121,7 @@ class ScanAccountDirBloc
|
|||
_accountPrefUpdatedEventListener.begin();
|
||||
|
||||
_nativeFileExifUpdatedListener?.begin();
|
||||
_imageProcessorUploadSuccessListener?.begin();
|
||||
|
||||
on<ScanAccountDirBlocEvent>(_onEvent, transformer: ((events, mapper) {
|
||||
return events.asyncExpand(mapper).distinct((a, b) {
|
||||
|
@ -164,6 +165,7 @@ class ScanAccountDirBloc
|
|||
_accountPrefUpdatedEventListener.end();
|
||||
|
||||
_nativeFileExifUpdatedListener?.end();
|
||||
_imageProcessorUploadSuccessListener?.end();
|
||||
|
||||
_refreshThrottler.clear();
|
||||
return super.close();
|
||||
|
@ -333,6 +335,14 @@ class ScanAccountDirBloc
|
|||
);
|
||||
}
|
||||
|
||||
void _onImageProcessorUploadSuccessEvent(
|
||||
ImageProcessorUploadSuccessEvent ev) {
|
||||
_refreshThrottler.trigger(
|
||||
maxResponceTime: const Duration(seconds: 3),
|
||||
maxPendingCount: 10,
|
||||
);
|
||||
}
|
||||
|
||||
/// Query a small amount of files to give an illusion of quick startup
|
||||
Future<List<File>> _queryOfflineMini(ScanAccountDirBlocQueryBase ev) async {
|
||||
return await ScanDirOfflineMini(_c)(
|
||||
|
@ -540,6 +550,10 @@ class ScanAccountDirBloc
|
|||
late final _nativeFileExifUpdatedListener = platform_k.isWeb
|
||||
? null
|
||||
: NativeEventListener<FileExifUpdatedEvent>(_onNativeFileExifUpdated);
|
||||
late final _imageProcessorUploadSuccessListener = platform_k.isWeb
|
||||
? null
|
||||
: NativeEventListener<ImageProcessorUploadSuccessEvent>(
|
||||
_onImageProcessorUploadSuccessEvent);
|
||||
|
||||
late final _refreshThrottler = Throttler(
|
||||
onTriggered: (_) {
|
||||
|
|
|
@ -31,6 +31,9 @@ class NativeEventListener<T> {
|
|||
case FileExifUpdatedEvent._id:
|
||||
return FileExifUpdatedEvent.fromEvent(ev);
|
||||
|
||||
case ImageProcessorUploadSuccessEvent._id:
|
||||
return ImageProcessorUploadSuccessEvent.fromEvent(ev);
|
||||
|
||||
default:
|
||||
throw ArgumentError("Invalid event: ${ev.event}");
|
||||
}
|
||||
|
@ -63,3 +66,15 @@ class FileExifUpdatedEvent {
|
|||
|
||||
final List<int> fileIds;
|
||||
}
|
||||
|
||||
class ImageProcessorUploadSuccessEvent {
|
||||
const ImageProcessorUploadSuccessEvent();
|
||||
|
||||
factory ImageProcessorUploadSuccessEvent.fromEvent(NativeEventObject ev) {
|
||||
assert(ev.event == _id);
|
||||
assert(ev.data == null);
|
||||
return const ImageProcessorUploadSuccessEvent();
|
||||
}
|
||||
|
||||
static const _id = "ImageProcessorUploadSuccessEvent";
|
||||
}
|
||||
|
|
|
@ -611,12 +611,12 @@ class _MyAppState extends State<MyApp>
|
|||
} else if (settings.name?.startsWith("${ResultViewer.routeName}?") ==
|
||||
true) {
|
||||
final queries = Uri.parse(settings.name!).queryParameters;
|
||||
final fileUrl = Uri.decodeQueryComponent(queries["url"]!);
|
||||
final args = ResultViewerArguments(fileUrl);
|
||||
final args = ResultViewerArguments(queries["url"]!);
|
||||
return ResultViewer.buildRoute(args);
|
||||
}
|
||||
} catch (e) {
|
||||
_log.severe("[_handleResultViewerRoute] Failed while handling route", e);
|
||||
} catch (e, stackTrace) {
|
||||
_log.severe("[_handleResultViewerRoute] Failed while handling route", e,
|
||||
stackTrace);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
|
|
@ -372,6 +372,7 @@ class ImageProcessorService : Service() {
|
|||
|
||||
private fun notifyResult(event: MessageEvent) {
|
||||
if (event is ImageProcessorCompletedEvent) {
|
||||
NativeEventChannelHandler.fire(ImageProcessorUploadSuccessEvent())
|
||||
notificationManager.notify(
|
||||
RESULT_NOTIFICATION_ID, buildResultNotification(event.result)
|
||||
)
|
||||
|
|
|
@ -0,0 +1,14 @@
|
|||
package com.nkming.nc_photos.plugin
|
||||
|
||||
interface NativeEvent {
|
||||
fun getId(): String
|
||||
fun getData(): String? = null
|
||||
}
|
||||
|
||||
class ImageProcessorUploadSuccessEvent : NativeEvent {
|
||||
companion object {
|
||||
const val id = "ImageProcessorUploadSuccessEvent"
|
||||
}
|
||||
|
||||
override fun getId() = id
|
||||
}
|
|
@ -10,6 +10,20 @@ class NativeEventChannelHandler : MethodChannel.MethodCallHandler,
|
|||
const val EVENT_CHANNEL = "${K.LIB_ID}/native_event"
|
||||
const val METHOD_CHANNEL = "${K.LIB_ID}/native_event_method"
|
||||
|
||||
/**
|
||||
* Fire native events on the native side
|
||||
*/
|
||||
fun fire(eventObj: NativeEvent) {
|
||||
synchronized(eventSinks) {
|
||||
for (s in eventSinks.values) {
|
||||
s.success(buildMap {
|
||||
put("event", eventObj.getId())
|
||||
eventObj.getData()?.also { put("data", it) }
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private val eventSinks = mutableMapOf<Int, EventChannel.EventSink>()
|
||||
private var nextId = 0
|
||||
}
|
||||
|
@ -29,22 +43,28 @@ class NativeEventChannelHandler : MethodChannel.MethodCallHandler,
|
|||
}
|
||||
|
||||
override fun onListen(arguments: Any?, events: EventChannel.EventSink) {
|
||||
synchronized(eventSinks) {
|
||||
eventSinks[id] = events
|
||||
}
|
||||
}
|
||||
|
||||
override fun onCancel(arguments: Any?) {
|
||||
synchronized(eventSinks) {
|
||||
eventSinks.remove(id)
|
||||
}
|
||||
}
|
||||
|
||||
private fun fire(
|
||||
event: String, data: String?, result: MethodChannel.Result
|
||||
) {
|
||||
synchronized(eventSinks) {
|
||||
for (s in eventSinks.values) {
|
||||
s.success(buildMap {
|
||||
put("event", event)
|
||||
if (data != null) put("data", data)
|
||||
})
|
||||
}
|
||||
}
|
||||
result.success(null)
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue