aves/lib/widgets/settings/common/quick_actions/action_panel.dart
2023-08-11 23:04:30 +02:00

39 lines
1.1 KiB
Dart

import 'package:aves/theme/durations.dart';
import 'package:flutter/material.dart';
class ActionPanel extends StatelessWidget {
final bool highlight;
final Widget child;
const ActionPanel({
super.key,
this.highlight = false,
required this.child,
});
@override
Widget build(BuildContext context) {
final theme = Theme.of(context);
final color = highlight
? theme.colorScheme.secondary
: theme.brightness == Brightness.dark
? Colors.blueGrey
: Colors.blueGrey.shade100;
return AnimatedContainer(
foregroundDecoration: BoxDecoration(
color: color.withOpacity(.2),
border: Border.fromBorderSide(BorderSide(
color: color,
width: highlight ? 2 : 1,
)),
borderRadius: const BorderRadius.all(Radius.circular(8)),
),
margin: const EdgeInsets.all(16),
duration: ADurations.quickActionHighlightAnimation,
child: ClipRRect(
borderRadius: const BorderRadius.all(Radius.circular(8)),
child: child,
),
);
}
}