57 lines
1.6 KiB
Dart
57 lines
1.6 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
class FButton extends StatelessWidget {
|
|
final String labelText;
|
|
final double padding;
|
|
final double insidePadding;
|
|
final double fontSize;
|
|
final Function()? onPressed;
|
|
|
|
const FButton(
|
|
{super.key,
|
|
required this.labelText,
|
|
this.padding = 8,
|
|
this.insidePadding = 24,
|
|
this.fontSize = 20,
|
|
this.onPressed});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
var theme = Theme.of(context);
|
|
var colorScheme = theme.colorScheme;
|
|
|
|
return GestureDetector(
|
|
onTap: onPressed,
|
|
child: Padding(
|
|
padding: EdgeInsets.symmetric(vertical: padding, horizontal: padding),
|
|
child: Container(
|
|
padding: EdgeInsets.symmetric(vertical: insidePadding),
|
|
decoration: BoxDecoration(
|
|
gradient: LinearGradient(
|
|
colors: [
|
|
colorScheme.primary.withOpacity(0.5),
|
|
colorScheme.secondary.withOpacity(0.5),
|
|
],
|
|
),
|
|
borderRadius: BorderRadius.circular(4),
|
|
boxShadow: [
|
|
BoxShadow(
|
|
color: colorScheme.primary.withOpacity(0.3),
|
|
blurRadius: 5,
|
|
offset: const Offset(0, 5),
|
|
)
|
|
],
|
|
),
|
|
child: Center(
|
|
child: Text(
|
|
labelText,
|
|
style: theme.textTheme.labelLarge!.copyWith(
|
|
fontWeight: FontWeight.bold,
|
|
fontSize: fontSize,
|
|
),
|
|
),
|
|
),
|
|
),
|
|
));
|
|
}
|
|
}
|