mirror of
https://github.com/immich-app/immich.git
synced 2025-01-22 19:52:46 +01:00
48 lines
994 B
Dart
48 lines
994 B
Dart
import 'package:async/async.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
|
|
RestartableTimer useTimer(
|
|
Duration duration,
|
|
void Function() callback,
|
|
) {
|
|
return use(
|
|
_TimerHook(
|
|
duration: duration,
|
|
callback: callback,
|
|
),
|
|
);
|
|
}
|
|
|
|
class _TimerHook extends Hook<RestartableTimer> {
|
|
final Duration duration;
|
|
final void Function() callback;
|
|
|
|
const _TimerHook({
|
|
required this.duration,
|
|
required this.callback,
|
|
});
|
|
@override
|
|
HookState<RestartableTimer, Hook<RestartableTimer>> createState() =>
|
|
_TimerHookState();
|
|
}
|
|
|
|
class _TimerHookState extends HookState<RestartableTimer, _TimerHook> {
|
|
late RestartableTimer timer;
|
|
@override
|
|
void initHook() {
|
|
super.initHook();
|
|
timer = RestartableTimer(hook.duration, hook.callback);
|
|
}
|
|
|
|
@override
|
|
RestartableTimer build(BuildContext context) {
|
|
return timer;
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
timer.cancel();
|
|
super.dispose();
|
|
}
|
|
}
|