39 lines
1000 B
Dart
39 lines
1000 B
Dart
import 'package:flutter/material.dart';
|
|
import 'package:get/get.dart';
|
|
|
|
import 'package:get_storage/get_storage.dart';
|
|
|
|
void main() async {
|
|
await GetStorage.init();
|
|
runApp(App());
|
|
}
|
|
|
|
class Controller extends GetxController {
|
|
final box = GetStorage();
|
|
bool get isDark => box.read('darkmode') ?? false;
|
|
ThemeData get theme => isDark ? ThemeData.dark() : ThemeData.light();
|
|
void changeTheme(bool val) => box.write('darkmode', val);
|
|
}
|
|
|
|
class App extends StatelessWidget {
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final controller = Get.put(Controller());
|
|
return Obx(() {
|
|
return MaterialApp(
|
|
theme: controller.theme,
|
|
home: Scaffold(
|
|
appBar: AppBar(title: Text("Get Storage")),
|
|
body: Center(
|
|
child: SwitchListTile(
|
|
value: controller.isDark,
|
|
title: Text("Touch to change ThemeMode"),
|
|
onChanged: controller.changeTheme,
|
|
),
|
|
),
|
|
),
|
|
);
|
|
});
|
|
}
|
|
}
|