adguard-home-manager/lib/widgets/option_box.dart
2023-10-08 00:26:48 +02:00

53 lines
No EOL
1.6 KiB
Dart

import 'package:flutter/material.dart';
class OptionBox extends StatelessWidget {
final dynamic optionsValue;
final dynamic itemValue;
final void Function(dynamic) onTap;
final String label;
const OptionBox({
Key? key,
required this.optionsValue,
required this.itemValue,
required this.onTap,
required this.label,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return Material(
color: Colors.transparent,
borderRadius: BorderRadius.circular(50),
child: InkWell(
borderRadius: BorderRadius.circular(50),
onTap: () => onTap(itemValue),
child: AnimatedContainer(
duration: const Duration(milliseconds: 250),
curve: Curves.easeInOut,
padding: const EdgeInsets.symmetric(vertical: 16),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(50),
color: optionsValue == itemValue
? Theme.of(context).colorScheme.primary
: Theme.of(context).colorScheme.primaryContainer,
),
child: AnimatedDefaultTextStyle(
duration: const Duration(milliseconds: 250),
style: TextStyle(
fontWeight: FontWeight.w500,
fontSize: 14,
color: optionsValue == itemValue
? Theme.of(context).colorScheme.onInverseSurface
: Theme.of(context).colorScheme.onSurface
),
child: Text(
label,
textAlign: TextAlign.center,
),
),
),
),
);
}
}