You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
HMG_Patient_App_New/lib/widgets/buttons/custom_button.dart

102 lines
3.4 KiB
Dart

2 months ago
import 'package:flutter/material.dart';
import 'package:hmg_patient_app_new/core/app_export.dart';
2 months ago
import 'package:hmg_patient_app_new/core/utils/utils.dart';
import 'package:hmg_patient_app_new/extensions/string_extensions.dart';
import 'package:hmg_patient_app_new/extensions/widget_extensions.dart';
class CustomButton extends StatelessWidget {
final String text;
String? icon;
final VoidCallback onPressed;
final Color backgroundColor;
final Color borderColor;
final Color textColor;
final double borderRadius;
final double borderWidth;
final EdgeInsetsGeometry padding;
final double fontSize;
final String? fontFamily;
final FontWeight fontWeight;
final bool isDisabled;
2 months ago
final Color? iconColor;
final double height;
final double? width;
final double iconSize;
final TextOverflow? textOverflow;
2 months ago
CustomButton({
Key? key,
required this.text,
required this.onPressed,
this.backgroundColor = const Color(0xFFED1C2B),
this.borderColor = const Color(0xFFED1C2B),
this.textColor = Colors.white,
this.borderRadius = 12,
this.borderWidth = 2,
this.padding = const EdgeInsets.fromLTRB(8, 10, 8, 10),
this.fontSize = 16,
this.fontFamily,
this.fontWeight = FontWeight.w500,
this.isDisabled = false,
this.icon,
this.iconColor = Colors.white,
this.height = 56,
this.width,
this.iconSize = 24,
this.textOverflow,
2 months ago
}) : super(key: key);
@override
Widget build(BuildContext context) {
return GestureDetector(
onTap: isDisabled ? null : onPressed,
child: Container(
height: height,
width: width,
padding: padding,
2 months ago
decoration: RoundedRectangleBorder().toSmoothCornerDecoration(
color: isDisabled ? Colors.transparent : backgroundColor,
borderRadius: borderRadius,
side: BorderSide(
width: borderWidth.h,
2 months ago
color: isDisabled ? borderColor.withOpacity(0.5) : borderColor,
)),
child: Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
if (icon != null)
Padding(
padding: const EdgeInsets.only(right: 8.0, left: 8.0),
child: Utils.buildSvgWithAssets(icon: icon!, iconColor: iconColor, isDisabled: isDisabled, width: iconSize, height: iconSize),
2 months ago
),
Padding(
padding: EdgeInsets.only(top: 0),
child: Text(
text,
overflow: textOverflow,
style: context.dynamicTextStyle(
fontSize: fontSize.fSize,
color: isDisabled ? textColor.withOpacity(0.5) : textColor,
letterSpacing: 0,
fontWeight: fontWeight,
),
),
),
],
2 months ago
),
)
// .toSmoothContainer(
// smoothness: 1,
// side: BorderSide(width: borderWidth, color: backgroundColor),
// borderRadius: BorderRadius.circular(borderRadius * 1.2),
// foregroundDecoration: BoxDecoration(
// color: isDisabled ? backgroundColor.withOpacity(0.5) : Colors.transparent,
// borderRadius: BorderRadius.circular(borderRadius),
// ),
// ),
);
}
}