ente/lib/ui/components/toggle_switch_widget.dart

39 lines
1.1 KiB
Dart
Raw Normal View History

2022-09-28 11:07:12 +00:00
import 'package:flutter/material.dart';
import 'package:photos/ente_theme_data.dart';
2022-10-05 15:57:41 +00:00
typedef OnChangedCallBack = void Function(bool);
class ToggleSwitchWidget extends StatefulWidget {
2022-09-28 11:07:12 +00:00
final bool value;
2022-10-05 15:57:41 +00:00
final OnChangedCallBack onChanged;
const ToggleSwitchWidget(
{required this.value, required this.onChanged, Key? key})
2022-09-28 11:07:12 +00:00
: super(key: key);
@override
2022-10-05 15:57:41 +00:00
State<ToggleSwitchWidget> createState() => _ToggleSwitchWidgetState();
2022-09-28 11:07:12 +00:00
}
2022-10-05 15:57:41 +00:00
class _ToggleSwitchWidgetState extends State<ToggleSwitchWidget> {
2022-09-28 11:07:12 +00:00
@override
Widget build(BuildContext context) {
2022-10-05 15:57:41 +00:00
final enteColorScheme = Theme.of(context).colorScheme.enteTheme.colorScheme;
return Padding(
padding: const EdgeInsets.symmetric(vertical: 4),
child: SizedBox(
height: 30,
child: FittedBox(
fit: BoxFit.contain,
child: Switch.adaptive(
activeColor: enteColorScheme.primary400,
inactiveTrackColor: enteColorScheme.fillMuted,
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
value: widget.value,
onChanged: widget.onChanged,
),
2022-09-28 11:07:12 +00:00
),
2022-10-05 15:57:41 +00:00
),
2022-09-28 11:07:12 +00:00
);
}
}