mirror of
https://github.com/vodemn/m3_lightmeter.git
synced 2024-11-25 17:00:39 +00:00
5c27f726c5
* wip * added start/stop button * animated timeline * fixed timer stop state * added reset button (wip) * added `onExposurePairTap` callback * integrated `TimerScreen` to navigation * separated `TimerTimeline` * fixed timeline flickering * added milliseconds to timer * synchronized timeline with actual timer * reused `BottomControlsBar` * fixed default scaffold background color * moved center button size to the bar itself * display selected exposure pair on timer screen * separated reusable `AnimatedCircluarButton` * release camera when timer is opened * added `TimerInteractor` * added `TimerBloc` test * fixed hours parsing * added scenarios for timer golden test * adjusted timer timeline colors * show iso & nd values on timer screen * automatically close timer screen after timeout * added timer autostart * reverted theme changes * updated goldens * typo * removed timer screen auto-dismiss * increased timer vibration duration * replaced outlined locks * increased 1/3 values font size
24 lines
772 B
Dart
24 lines
772 B
Dart
import 'package:lightmeter/data/haptics_service.dart';
|
|
import 'package:lightmeter/data/shared_prefs_service.dart';
|
|
|
|
class TimerInteractor {
|
|
final UserPreferencesService _userPreferencesService;
|
|
final HapticsService _hapticsService;
|
|
|
|
TimerInteractor(
|
|
this._userPreferencesService,
|
|
this._hapticsService,
|
|
);
|
|
|
|
/// Executes vibration if haptics are enabled in settings
|
|
Future<void> startVibration() async {
|
|
if (_userPreferencesService.haptics) await _hapticsService.quickVibration();
|
|
}
|
|
|
|
/// Executes vibration if haptics are enabled in settings
|
|
Future<void> endVibration() async {
|
|
if (_userPreferencesService.haptics) await _hapticsService.errorVibration();
|
|
}
|
|
|
|
bool get isAutostartTimerEnabled => _userPreferencesService.autostartTimer;
|
|
}
|