mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-01-11 13:14:32 +00:00
Lock toggling lelantus scanning behind a mutex
This commit is contained in:
parent
0f98c0be2c
commit
d37d86759d
2 changed files with 35 additions and 19 deletions
|
@ -47,7 +47,8 @@ class _LelantusSettingsViewState extends ConsumerState<LelantusSettingsView> {
|
||||||
|
|
||||||
bool _isInitialized = false;
|
bool _isInitialized = false;
|
||||||
Wallet<CryptoCurrency>? wallet;
|
Wallet<CryptoCurrency>? wallet;
|
||||||
bool? enableLelantusScanning = false;
|
bool _enableLelantusScanning = false;
|
||||||
|
bool _isUpdatingLelantusScanning = false;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void didChangeDependencies() {
|
void didChangeDependencies() {
|
||||||
|
@ -63,7 +64,7 @@ class _LelantusSettingsViewState extends ConsumerState<LelantusSettingsView> {
|
||||||
// Parse otherDataJsonString to get the enableLelantusScanning value.
|
// Parse otherDataJsonString to get the enableLelantusScanning value.
|
||||||
if (wallet?.info.otherDataJsonString != null) {
|
if (wallet?.info.otherDataJsonString != null) {
|
||||||
final otherDataJson = json.decode(wallet!.info.otherDataJsonString!);
|
final otherDataJson = json.decode(wallet!.info.otherDataJsonString!);
|
||||||
enableLelantusScanning =
|
_enableLelantusScanning =
|
||||||
otherDataJson[WalletInfoKeys.enableLelantusScanning] as bool? ??
|
otherDataJson[WalletInfoKeys.enableLelantusScanning] as bool? ??
|
||||||
false;
|
false;
|
||||||
}
|
}
|
||||||
|
@ -106,16 +107,23 @@ class _LelantusSettingsViewState extends ConsumerState<LelantusSettingsView> {
|
||||||
height: 20,
|
height: 20,
|
||||||
width: 40,
|
width: 40,
|
||||||
child: DraggableSwitchButton(
|
child: DraggableSwitchButton(
|
||||||
isOn: enableLelantusScanning ?? false,
|
isOn: _enableLelantusScanning,
|
||||||
onValueChanged: (newValue) {
|
onValueChanged: (newValue) async {
|
||||||
|
if (_isUpdatingLelantusScanning) return;
|
||||||
|
_isUpdatingLelantusScanning = true; // Lock mutex.
|
||||||
|
|
||||||
// Toggle enableLelantusScanning in wallet info.
|
// Toggle enableLelantusScanning in wallet info.
|
||||||
wallet?.info.updateOtherData(newEntries: {
|
await wallet?.info.updateOtherData(
|
||||||
WalletInfoKeys.enableLelantusScanning:
|
newEntries: {
|
||||||
!(enableLelantusScanning ?? false)
|
WalletInfoKeys.enableLelantusScanning:
|
||||||
}, isar: ref.read(mainDBProvider).isar).then((value) {
|
!_enableLelantusScanning,
|
||||||
// Should setState be used here?
|
},
|
||||||
enableLelantusScanning =
|
isar: ref.read(mainDBProvider).isar,
|
||||||
!(enableLelantusScanning ?? false);
|
);
|
||||||
|
|
||||||
|
setState(() {
|
||||||
|
_enableLelantusScanning = !_enableLelantusScanning;
|
||||||
|
_isUpdatingLelantusScanning = false; // Free mutex.
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
|
|
@ -60,6 +60,7 @@ class MoreFeaturesDialog extends ConsumerStatefulWidget {
|
||||||
|
|
||||||
class _MoreFeaturesDialogState extends ConsumerState<MoreFeaturesDialog> {
|
class _MoreFeaturesDialogState extends ConsumerState<MoreFeaturesDialog> {
|
||||||
bool _enableLelantusScanning = false;
|
bool _enableLelantusScanning = false;
|
||||||
|
bool _isUpdatingLelantusScanning = false; // Mutex.
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
@ -171,15 +172,22 @@ class _MoreFeaturesDialogState extends ConsumerState<MoreFeaturesDialog> {
|
||||||
width: 40,
|
width: 40,
|
||||||
child: DraggableSwitchButton(
|
child: DraggableSwitchButton(
|
||||||
isOn: _enableLelantusScanning,
|
isOn: _enableLelantusScanning,
|
||||||
onValueChanged: (newValue) {
|
onValueChanged: (newValue) async {
|
||||||
|
if (_isUpdatingLelantusScanning) return;
|
||||||
|
_isUpdatingLelantusScanning = true; // Lock mutex.
|
||||||
|
|
||||||
// Toggle enableLelantusScanning in wallet info.
|
// Toggle enableLelantusScanning in wallet info.
|
||||||
wallet.info.updateOtherData(newEntries: {
|
await wallet.info.updateOtherData(
|
||||||
WalletInfoKeys.enableLelantusScanning:
|
newEntries: {
|
||||||
!(_enableLelantusScanning)
|
WalletInfoKeys.enableLelantusScanning:
|
||||||
}, isar: ref.read(mainDBProvider).isar).then((value) {
|
!_enableLelantusScanning,
|
||||||
// Should setState be used here?
|
},
|
||||||
_enableLelantusScanning =
|
isar: ref.read(mainDBProvider).isar,
|
||||||
!(_enableLelantusScanning);
|
);
|
||||||
|
|
||||||
|
setState(() {
|
||||||
|
_enableLelantusScanning = !_enableLelantusScanning;
|
||||||
|
_isUpdatingLelantusScanning = false; // Free mutex.
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
|
Loading…
Reference in a new issue