mirror of
https://github.com/Iconica-Development/flutter_chat.git
synced 2025-05-18 18:33:49 +02:00
feat: add borderRadius option for the MessageTheme
This commit is contained in:
parent
70eeb816e2
commit
7a0fd49070
2 changed files with 15 additions and 1 deletions
|
@ -108,6 +108,7 @@ class MessageTheme {
|
||||||
this.borderColor,
|
this.borderColor,
|
||||||
this.textColor,
|
this.textColor,
|
||||||
this.timeTextColor,
|
this.timeTextColor,
|
||||||
|
this.borderRadius,
|
||||||
this.messageAlignment,
|
this.messageAlignment,
|
||||||
this.messageSidePadding,
|
this.messageSidePadding,
|
||||||
this.textAlignment,
|
this.textAlignment,
|
||||||
|
@ -122,6 +123,7 @@ class MessageTheme {
|
||||||
borderColor: theme.colorScheme.primary,
|
borderColor: theme.colorScheme.primary,
|
||||||
textColor: theme.colorScheme.onPrimary,
|
textColor: theme.colorScheme.onPrimary,
|
||||||
timeTextColor: theme.colorScheme.onPrimary,
|
timeTextColor: theme.colorScheme.onPrimary,
|
||||||
|
borderRadius: BorderRadius.circular(12),
|
||||||
textAlignment: TextAlign.start,
|
textAlignment: TextAlign.start,
|
||||||
messageSidePadding: 144.0,
|
messageSidePadding: 144.0,
|
||||||
messageAlignment: null,
|
messageAlignment: null,
|
||||||
|
@ -158,6 +160,10 @@ class MessageTheme {
|
||||||
/// Defaults to [ThemeData.colorScheme.primaryColor]
|
/// Defaults to [ThemeData.colorScheme.primaryColor]
|
||||||
final Color? borderColor;
|
final Color? borderColor;
|
||||||
|
|
||||||
|
/// The border radius of the message container
|
||||||
|
/// Defaults to [BorderRadius.circular(12)]
|
||||||
|
final BorderRadius? borderRadius;
|
||||||
|
|
||||||
/// The padding on the side of the message
|
/// The padding on the side of the message
|
||||||
/// If not set, the padding is 144.0
|
/// If not set, the padding is 144.0
|
||||||
final double? messageSidePadding;
|
final double? messageSidePadding;
|
||||||
|
@ -177,6 +183,7 @@ class MessageTheme {
|
||||||
Color? borderColor,
|
Color? borderColor,
|
||||||
Color? textColor,
|
Color? textColor,
|
||||||
Color? timeTextColor,
|
Color? timeTextColor,
|
||||||
|
BorderRadius? borderRadius,
|
||||||
double? messageSidePadding,
|
double? messageSidePadding,
|
||||||
TextAlign? messageAlignment,
|
TextAlign? messageAlignment,
|
||||||
TextAlign? textAlignment,
|
TextAlign? textAlignment,
|
||||||
|
@ -189,6 +196,7 @@ class MessageTheme {
|
||||||
borderColor: borderColor ?? this.borderColor,
|
borderColor: borderColor ?? this.borderColor,
|
||||||
textColor: textColor ?? this.textColor,
|
textColor: textColor ?? this.textColor,
|
||||||
timeTextColor: timeTextColor ?? this.timeTextColor,
|
timeTextColor: timeTextColor ?? this.timeTextColor,
|
||||||
|
borderRadius: borderRadius ?? this.borderRadius,
|
||||||
messageSidePadding: messageSidePadding ?? this.messageSidePadding,
|
messageSidePadding: messageSidePadding ?? this.messageSidePadding,
|
||||||
messageAlignment: messageAlignment ?? this.messageAlignment,
|
messageAlignment: messageAlignment ?? this.messageAlignment,
|
||||||
textAlignment: textAlignment ?? this.textAlignment,
|
textAlignment: textAlignment ?? this.textAlignment,
|
||||||
|
@ -204,6 +212,7 @@ class MessageTheme {
|
||||||
borderColor: borderColor ?? other.borderColor,
|
borderColor: borderColor ?? other.borderColor,
|
||||||
textColor: textColor ?? other.textColor,
|
textColor: textColor ?? other.textColor,
|
||||||
timeTextColor: timeTextColor ?? other.timeTextColor,
|
timeTextColor: timeTextColor ?? other.timeTextColor,
|
||||||
|
borderRadius: borderRadius ?? other.borderRadius,
|
||||||
messageSidePadding: messageSidePadding ?? other.messageSidePadding,
|
messageSidePadding: messageSidePadding ?? other.messageSidePadding,
|
||||||
messageAlignment: messageAlignment ?? other.messageAlignment,
|
messageAlignment: messageAlignment ?? other.messageAlignment,
|
||||||
textAlignment: textAlignment ?? other.textAlignment,
|
textAlignment: textAlignment ?? other.textAlignment,
|
||||||
|
|
|
@ -173,6 +173,7 @@ class _ChatMessageBubble extends StatelessWidget {
|
||||||
DefaultChatMessageContainer(
|
DefaultChatMessageContainer(
|
||||||
backgroundColor: messageTheme.backgroundColor!,
|
backgroundColor: messageTheme.backgroundColor!,
|
||||||
borderColor: messageTheme.borderColor!,
|
borderColor: messageTheme.borderColor!,
|
||||||
|
borderRadius: messageTheme.borderRadius!,
|
||||||
child: Column(
|
child: Column(
|
||||||
crossAxisAlignment: CrossAxisAlignment.stretch,
|
crossAxisAlignment: CrossAxisAlignment.stretch,
|
||||||
children: [
|
children: [
|
||||||
|
@ -258,6 +259,7 @@ class DefaultChatMessageContainer extends StatelessWidget {
|
||||||
const DefaultChatMessageContainer({
|
const DefaultChatMessageContainer({
|
||||||
required this.backgroundColor,
|
required this.backgroundColor,
|
||||||
required this.borderColor,
|
required this.borderColor,
|
||||||
|
required this.borderRadius,
|
||||||
required this.child,
|
required this.child,
|
||||||
super.key,
|
super.key,
|
||||||
});
|
});
|
||||||
|
@ -268,6 +270,9 @@ class DefaultChatMessageContainer extends StatelessWidget {
|
||||||
/// The color of the border around the message
|
/// The color of the border around the message
|
||||||
final Color borderColor;
|
final Color borderColor;
|
||||||
|
|
||||||
|
/// The border radius of the message container
|
||||||
|
final BorderRadius borderRadius;
|
||||||
|
|
||||||
/// The content of the message
|
/// The content of the message
|
||||||
final Widget child;
|
final Widget child;
|
||||||
|
|
||||||
|
@ -275,7 +280,7 @@ class DefaultChatMessageContainer extends StatelessWidget {
|
||||||
Widget build(BuildContext context) => DecoratedBox(
|
Widget build(BuildContext context) => DecoratedBox(
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: backgroundColor,
|
color: backgroundColor,
|
||||||
borderRadius: BorderRadius.circular(12),
|
borderRadius: borderRadius,
|
||||||
border: Border.all(
|
border: Border.all(
|
||||||
width: 1,
|
width: 1,
|
||||||
color: borderColor,
|
color: borderColor,
|
||||||
|
|
Loading…
Reference in a new issue