feat(settings): persist soundEnabled flag (additive, default true)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -42,6 +42,9 @@ class SaveRepository {
|
|||||||
_adsRemoved =
|
_adsRemoved =
|
||||||
(json['flags'] as Map<String, dynamic>?)?['adsRemoved'] as bool? ??
|
(json['flags'] as Map<String, dynamic>?)?['adsRemoved'] as bool? ??
|
||||||
false;
|
false;
|
||||||
|
_soundEnabled =
|
||||||
|
(json['flags'] as Map<String, dynamic>?)?['soundEnabled'] as bool? ??
|
||||||
|
true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -56,11 +59,13 @@ class SaveRepository {
|
|||||||
bool _tutorialDone = false;
|
bool _tutorialDone = false;
|
||||||
int _endlessBest = 0;
|
int _endlessBest = 0;
|
||||||
bool _adsRemoved = false;
|
bool _adsRemoved = false;
|
||||||
|
bool _soundEnabled = true;
|
||||||
|
|
||||||
StreakState get streak => _streak;
|
StreakState get streak => _streak;
|
||||||
bool get tutorialDone => _tutorialDone;
|
bool get tutorialDone => _tutorialDone;
|
||||||
int get endlessBest => _endlessBest;
|
int get endlessBest => _endlessBest;
|
||||||
bool get adsRemoved => _adsRemoved;
|
bool get adsRemoved => _adsRemoved;
|
||||||
|
bool get soundEnabled => _soundEnabled;
|
||||||
|
|
||||||
Future<void> markTutorialDone() {
|
Future<void> markTutorialDone() {
|
||||||
_tutorialDone = true;
|
_tutorialDone = true;
|
||||||
@@ -72,6 +77,11 @@ class SaveRepository {
|
|||||||
return _flush();
|
return _flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<void> setSoundEnabled(bool value) {
|
||||||
|
_soundEnabled = value;
|
||||||
|
return _flush();
|
||||||
|
}
|
||||||
|
|
||||||
Future<void> recordEndlessScore(int score) {
|
Future<void> recordEndlessScore(int score) {
|
||||||
if (score > _endlessBest) _endlessBest = score;
|
if (score > _endlessBest) _endlessBest = score;
|
||||||
return _flush();
|
return _flush();
|
||||||
@@ -140,7 +150,11 @@ class SaveRepository {
|
|||||||
'best': _streak.best,
|
'best': _streak.best,
|
||||||
'lastYmd': _streak.lastYmd,
|
'lastYmd': _streak.lastYmd,
|
||||||
},
|
},
|
||||||
'flags': {'tutorialDone': _tutorialDone, 'adsRemoved': _adsRemoved},
|
'flags': {
|
||||||
|
'tutorialDone': _tutorialDone,
|
||||||
|
'adsRemoved': _adsRemoved,
|
||||||
|
'soundEnabled': _soundEnabled,
|
||||||
|
},
|
||||||
'endless': {'best': _endlessBest},
|
'endless': {'best': _endlessBest},
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -0,0 +1,24 @@
|
|||||||
|
import 'package:block_seasons/data/save_repository.dart';
|
||||||
|
import 'package:flutter_test/flutter_test.dart';
|
||||||
|
import 'package:shared_preferences/shared_preferences.dart';
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
setUp(() => SharedPreferences.setMockInitialValues({}));
|
||||||
|
|
||||||
|
test('soundEnabled defaults true and persists across reopen', () async {
|
||||||
|
final repo = await SaveRepository.open();
|
||||||
|
expect(repo.soundEnabled, isTrue);
|
||||||
|
await repo.setSoundEnabled(false);
|
||||||
|
expect(repo.soundEnabled, isFalse);
|
||||||
|
final reopened = await SaveRepository.open();
|
||||||
|
expect(reopened.soundEnabled, isFalse);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('legacy save without the sound flag reads as true', () async {
|
||||||
|
SharedPreferences.setMockInitialValues({
|
||||||
|
'save_v1': '{"saveVersion":1,"progress":{},"flags":{"tutorialDone":true}}',
|
||||||
|
});
|
||||||
|
final repo = await SaveRepository.open();
|
||||||
|
expect(repo.soundEnabled, isTrue);
|
||||||
|
});
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user