You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123 lines
2.9 KiB

4 years ago
import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
4 years ago
3 years ago
class IconText extends StatelessWidget {
final String? leftImage;
final String? rightImage;
final IconData? leftIcon;
final IconData? rightIcon;
4 years ago
final String text;
final TextStyle? textStyle;
4 years ago
final double iconSize;
4 years ago
final double space;
4 years ago
final Color iconColor;
4 years ago
final TextOverflow overFlow;
4 years ago
final CrossAxisAlignment textAxisAlignment;
4 years ago
final bool isMax;
IconText(this.text,
{this.leftIcon,
this.rightIcon,
this.leftImage,
this.rightImage,
this.isMax = false,
this.iconSize = 16,
4 years ago
this.space = 1,
4 years ago
this.overFlow = TextOverflow.fade,
4 years ago
this.textAxisAlignment = CrossAxisAlignment.center,
this.iconColor = Colors.black,
this.textStyle});
4 years ago
@override
Widget build(BuildContext context) {
var widgets = <Widget>[];
if (leftIcon != null || (leftImage?.isNotEmpty ?? false)) {
if (leftIcon != null) {
widgets.add(
Padding(
padding: EdgeInsets.only(left: 2.w),
child: Icon(
leftIcon,
size: iconSize,
color: iconColor,
),
),
);
} else {
widgets.add(
Padding(
padding: EdgeInsets.only(left: 2.w),
child: Image.asset(
leftImage!,
width: iconSize,
height: iconSize,
),
),
);
}
}
4 years ago
3 years ago
widgets.add(SizedBox(
width: space,
));
4 years ago
3 years ago
widgets.add(isMax
? Expanded(
child: Text(
text,
overflow: overFlow,
// maxLines: 2,
3 years ago
textAlign: TextAlign.start,
style: textStyle,
),
flex: 1,
)
: Text(
text,
overflow: overFlow,
textAlign: TextAlign.center,
style: textStyle,
));
widgets.add(SizedBox(
width: space,
));
4 years ago
if (rightIcon != null || (rightImage?.isNotEmpty ?? false)) {
if (rightIcon != null) {
widgets.add(
Padding(
padding: EdgeInsets.only(left: 2.w),
child: Icon(
rightIcon,
size: iconSize,
color: iconColor,
),
),
);
} else {
widgets.add(
Padding(
padding: EdgeInsets.only(left: 2.w),
child: Image.asset(
rightImage!,
width: iconSize,
height: iconSize,
),
),
);
}
}
4 years ago
return Container(
child: Row(
mainAxisAlignment: isMax ? MainAxisAlignment.center : MainAxisAlignment.start,
4 years ago
crossAxisAlignment: textAxisAlignment,
mainAxisSize: MainAxisSize.min,
4 years ago
children: widgets,
),
);
}
}