2022-10-04 13:12:54 +03:00
|
|
|
/*
|
2023-02-08 19:12:49 +03:00
|
|
|
* Copyright (C) 2022-2023 Yubico.
|
2022-10-04 13:12:54 +03:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2022-05-11 15:53:41 +03:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
|
|
|
import 'package:logging/logging.dart';
|
2023-02-08 19:12:49 +03:00
|
|
|
import 'package:yubico_authenticator/android/state.dart';
|
2022-05-11 15:53:41 +03:00
|
|
|
import 'package:yubico_authenticator/app/logging.dart';
|
|
|
|
|
|
|
|
import '../app/models.dart';
|
2023-02-08 19:12:49 +03:00
|
|
|
import 'app_methods.dart';
|
2022-05-11 15:53:41 +03:00
|
|
|
|
|
|
|
final _log = Logger('android.window_state_provider');
|
|
|
|
|
|
|
|
final _windowStateProvider =
|
|
|
|
StateNotifierProvider<_WindowStateNotifier, WindowState>(
|
2023-02-08 19:12:49 +03:00
|
|
|
(ref) => _WindowStateNotifier(ref));
|
2022-05-11 15:53:41 +03:00
|
|
|
|
|
|
|
final androidWindowStateProvider = Provider<WindowState>(
|
|
|
|
(ref) => ref.watch(_windowStateProvider),
|
|
|
|
);
|
|
|
|
|
|
|
|
class _WindowStateNotifier extends StateNotifier<WindowState>
|
|
|
|
with WidgetsBindingObserver {
|
2023-02-08 19:12:49 +03:00
|
|
|
final StateNotifierProviderRef<_WindowStateNotifier, WindowState> _ref;
|
|
|
|
_WindowStateNotifier(this._ref)
|
2022-05-11 15:53:41 +03:00
|
|
|
: super(WindowState(focused: true, visible: true, active: true)) {
|
|
|
|
_init();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void didChangeAppLifecycleState(AppLifecycleState lifeCycleState) {
|
|
|
|
_log.debug(
|
|
|
|
'appLifecycleStateChange triggered with: ${lifeCycleState.name}');
|
|
|
|
|
|
|
|
var requestedState = lifeCycleState == AppLifecycleState.resumed;
|
|
|
|
var currentState = state.focused;
|
|
|
|
|
|
|
|
if (requestedState != currentState) {
|
|
|
|
state = WindowState(
|
|
|
|
focused: requestedState,
|
|
|
|
visible: requestedState,
|
|
|
|
active: requestedState);
|
|
|
|
_log.debug('Updated windowState to $state');
|
2023-02-08 19:12:49 +03:00
|
|
|
if (lifeCycleState == AppLifecycleState.resumed) {
|
|
|
|
_log.debug('Reading nfc enabled value');
|
|
|
|
isNfcEnabled().then((value) =>
|
|
|
|
_ref.read(androidNfcStateProvider.notifier).setNfcEnabled(value));
|
|
|
|
}
|
2022-05-11 15:53:41 +03:00
|
|
|
} else {
|
|
|
|
_log.debug('Ignoring appLifecycleStateChange');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void _init() {
|
|
|
|
WidgetsBinding.instance.addObserver(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void dispose() {
|
|
|
|
WidgetsBinding.instance.removeObserver(this);
|
|
|
|
super.dispose();
|
|
|
|
}
|
|
|
|
}
|