Styles in .NET MAUI Chat (SfChat)

12 Dec 202424 minutes to read

You can style the elements of the SfChat control by creating resource dictionaries and assigning values to the in-built keys assigned for each individual element.

Chat background

You can set any solid color as background for SfChat by setting any color to the SfChat.Background property. However, if you want the solid color to be applied to the message input view area, also, set the background color of the message input view as transparent, as shown in the below code sample.

<?xml version="1.0" encoding="utf-8" ?>
    <ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
                xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                xmlns:sfChat="clr-namespace:Syncfusion.Maui.Chat;assembly=Syncfusion.Maui.Chat"
                xmlns:syncTheme="clr-namespace:Syncfusion.Maui.Themes;assembly=Syncfusion.Maui.Core"
                xmlns:local="clr-namespace:MauiChat"             
                x:Class="MauiChat.MainPage">

        <ContentPage.BindingContext>
            <local:ViewModel x:Name="viewModel"/>
        </ContentPage.BindingContext>
        
        <ContentPage.Resources>
            <syncTheme:SyncfusionThemeDictionary>
                <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                    <ResourceDictionary>
                        <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                        <Color x:Key="SfChatMessageInputViewBackground">Transparent</Color>
                    </ResourceDictionary>
                </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
            </syncTheme:SyncfusionThemeDictionary>
        </ContentPage.Resources>

        <ContentPage.Content>
            <sfChat:SfChat x:Name="sfChat"
                            Messages="{Binding Messages}"
                            CurrentUser="{Binding CurrentUser}"
                            Background="#94b6ec"/>
        </ContentPage.Content>
    </ContentPage>
public partial class MainPage : ContentPage
    {
        SfChat sfChat;
        ViewModel viewModel;      
        public MainPage()
        {
            InitializeComponent();
            this.sfChat = new SfChat();
            this.viewModel = new ViewModel();
            this.sfChat.Messages = viewModel.Messages;
            this.sfChat.CurrentUser = viewModel.CurrentUser;
            sfChat.Background = Color.FromHex("#94b6ec");
            this.Content = sfChat;
        }
    }

Background color in .NET MAUI Chat

Set background image

You can set any image as the background for the SfChat by setting the SfChat.Background as Colors.Transparent and adding an image below the SfChat control. However, if you want the image to be applied to the message input view area as well, set the background color of the message input view as transparent, as shown in the code sample below.

<?xml version="1.0" encoding="utf-8" ?>
    <ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
                xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                xmlns:sfChat="clr-namespace:Syncfusion.Maui.Chat;assembly=Syncfusion.Maui.Chat"
                xmlns:syncTheme="clr-namespace:Syncfusion.Maui.Themes;assembly=Syncfusion.Maui.Core"
                xmlns:local="clr-namespace:MauiChat"             
                x:Class="MauiApp1.MainPage">

        <ContentPage.BindingContext>
            <local:ViewModel x:Name="viewModel"/>
        </ContentPage.BindingContext>

        <ContentPage.Resources>
            <syncTheme:SyncfusionThemeDictionary>
                <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                    <ResourceDictionary>
                        <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                        <Color x:Key="SfChatMessageInputViewBackground">Transparent</Color>
                    </ResourceDictionary>
                </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
            </syncTheme:SyncfusionThemeDictionary>
        </ContentPage.Resources>

        <ContentPage.Content>
            <Grid>
                <Image Source="backgroundimage.jpg" Aspect="AspectFill" />
                <sfChat:SfChat x:Name="sfChat"
                                Messages="{Binding Messages}"
                                CurrentUser="{Binding CurrentUser}"
                                Background="Transparent" /> 
            </Grid>
        </ContentPage.Content>
    </ContentPage>
public partial class MainPage : ContentPage
    {
        Grid grid = new Grid();
        SfChat sfChat;
        Image image = new Image();
        ViewModel viewModel;
        public MainPage()
        {
            this.InitializeComponent();
            image.Source = "backgroundimage.jpg";
            image.Aspect = Aspect.AspectFill;
            grid.Children.Add(image);
            this.sfChat = new SfChat();
            this.sfChat.Background = Colors.Transparent;
            this.viewModel = new ViewModel();
            this.sfChat.Messages = viewModel.Messages;
            this.sfChat.CurrentUser = viewModel.CurrentUser;
            grid.Children.Add(sfChat);
            this.Content = grid;
        }
    }

Background image in .NET MAUI Chat

Set gradient background

You can set the gradient view as a background for a chat by setting the SfChat.Background property to the gradient colors. However, if you want the gradient view to be applied to the message input view area, also, set the background color of the message input view as transparent as shown in the below code sample.

<?xml version="1.0" encoding="utf-8" ?>
    <ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
                xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                xmlns:sfChat="clr-namespace:Syncfusion.Maui.Chat;assembly=Syncfusion.Maui.Chat"
                xmlns:syncTheme="clr-namespace:Syncfusion.Maui.Themes;assembly=Syncfusion.Maui.Core"
                xmlns:local="clr-namespace:MauiApp1"             
                x:Class="MauiApp1.MainPage">

        <ContentPage.BindingContext>
            <local:ViewModel x:Name="viewModel"/>
        </ContentPage.BindingContext>
        
        <ContentPage.Resources>
            <syncTheme:SyncfusionThemeDictionary>
                <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                    <ResourceDictionary>
                        <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                        <Color x:Key="SfChatMessageInputViewBackground">Transparent</Color>
                    </ResourceDictionary>
                </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
            </syncTheme:SyncfusionThemeDictionary>
        </ContentPage.Resources>

        <ContentPage.Content>
            <sfChat:SfChat x:Name="sfChat"
                                Messages="{Binding Messages}"
                                CurrentUser="{Binding CurrentUser}" >
                                    
                <sfChat:SfChat.Background>
                    <LinearGradientBrush>
                        <GradientStop Color="SkyBlue" Offset="0.0" />
                        <GradientStop Color="LightCyan" Offset="0.25" />
                        <GradientStop Color="SteelBlue" Offset="0.5" />
                        <GradientStop Color="LightSkyBlue" Offset="0.75" />
                        <GradientStop Color="LightGray" Offset="1.0" />
                    </LinearGradientBrush>
                </sfChat:SfChat.Background>
            </sfChat:SfChat>
        </ContentPage.Content>
    </ContentPage>
public partial class MainPage : ContentPage
    {
        SfChat sfChat;
        ViewModel viewModel;
        public MainPage()
        {
            InitializeComponent();
            this.sfChat = new SfChat();
            this.viewModel = new ViewModel();
            this.sfChat.Messages = viewModel.Messages;
            this.sfChat.CurrentUser = viewModel.CurrentUser;
            LinearGradientBrush linearGradientBrush = new LinearGradientBrush();     
            linearGradientBrush.GradientStops.Add(new GradientStop(Colors.SkyBlue, 0.0f));
            linearGradientBrush.GradientStops.Add(new GradientStop(Colors.LightCyan, 0.25f));
            linearGradientBrush.GradientStops.Add(new GradientStop(Colors.SteelBlue, 0.5f));
            linearGradientBrush.GradientStops.Add(new GradientStop(Colors.LightSkyBlue, 0.75f));
            linearGradientBrush.GradientStops.Add(new GradientStop(Colors.LightGray, 1.0f));
            this.sfChat.Background = linearGradientBrush;
            this.Content = sfChat;
        }
    }

Gradient background in .NET MAUI Chat

Incoming message styling

You can style the elements of an incoming message by setting values to the in-built keys of an incoming message in the resource dictionary.

Key Description
SfChatIncomingMessageTextColor Text color of the incoming message.
SfChatIncomingMessageAuthorTextColor Text color of the author’s name in an incoming message.
SfChatIncomingMessageTimestampTextColor Text color of the timestamp in an incoming message.
SfChatIncomingMessageBackground Background color of the incoming message.
SfChatIncomingMessageFontFamily Font family of the incoming message.
SfChatIncomingMessageFontAttributes Font attributes of the incoming message.
SfChatIncomingMessageFontSize Font size of the incoming message.
SfChatIncomingMessageAuthorFontFamily Font family of the author’s name in an incoming message.
SfChatIncomingMessageAuthorFontAttributes Font attributes of the author’s name in an incoming message.
SfChatIncomingMessageAuthorFontSize Font size of the author’s name in an incoming message.
SfChatIncomingMessageTimestampFontFamily Font family of the timestamp in an incoming message.
SfChatIncomingMessageTimestampFontAttributes Font attributes of the timestamp in an incoming message.
SfChatIncomingMessageTimestampFontSize Font size of the timestamp in an incoming message.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatIncomingMessageTextColor">Gray</Color>
                    <Color x:Key="SfChatIncomingMessageTimestampTextColor">Gray</Color>
                    <Color x:Key="SfChatIncomingMessageAuthorTextColor">Gray</Color>
                    <Color x:Key="SfChatIncomingMessageBackground">#eee479</Color>
                    <x:String x:Key="SfChatIncomingMessageFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatIncomingMessageFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatIncomingMessageFontSize">16</x:Double>
                    <x:String x:Key="SfChatIncomingMessageAuthorFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatIncomingMessageAuthorFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatIncomingMessageAuthorFontSize">16</x:Double>
                    <x:String x:Key="SfChatIncomingMessageTimestampFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatIncomingMessageTimestampFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatIncomingMessageTimestampFontSize">16</x:Double>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatIncomingMessageTextColor", Colors.Gray);
        dictionary.Add("SfChatIncomingMessageTimestampTextColor", Colors.Gray);
        dictionary.Add("SfChatIncomingMessageAuthorTextColor", Colors.Gray);
        dictionary.Add("SfChatIncomingMessageBackground", Color.FromHex("#eee479"));
        dictionary.Add("SfChatIncomingMessageFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatIncomingMessageFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatIncomingMessageFontSize", 16);
        dictionary.Add("SfChatIncomingMessageAuthorFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatIncomingMessageAuthorFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatIncomingMessageAuthorFontSize", 16);
        dictionary.Add("SfChatIncomingMessageTimestampFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatIncomingMessageTimestampFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatIncomingMessageTimestampFontSize", 16);
        this.Resources.Add(dictionary);
    }

Incoming message style in .NET MAUI Chat

Outgoing message styling

You can style the elements of an outgoing message by setting values to the in-built keys of an outgoing message in the resource dictionary.

</tr>
Key Description
SfChatOutgoingMessageTextColor Text color of outgoing message.
sfChatOutgoingMessageAuthorTextColor Text color of the author’s name in an outgoing message.
sfChatOutgoingMessageTimestampTextColor Text color of the timestamp in an outgoing message.
SfChatOutgoingMessageBackground Background color of the outgoing message.
sfChatOutgoingMessageFontFamily Font family of the outgoing message.
sfChatOutgoingMessageFontAttributes Font attributes of the outgoing message.
sfChatOutgoingMessageFontSize Font size of the outgoing message.
sfChatOutgoingMessageAuthorFontFamily Font family of the author’s name in an outgoing message.
sfChatOutgoingMessageAuthorFontAttributes Font attributes of the author’s name in an outgoing message.
sfChatOutgoingMessageAuthorFontSize Font size of the author’s name in an outgoing message.
sfChatOutgoingMessageTimestampFontFamily Font family of the timestamp in an outgoing message.
sfChatOutgoingMessageTimestampFontAttributes Font attributes of the timestamp in an outgoing message.
SfChatOutgoingMessageTimestampFontSize Font size of the timestamp in an outgoing message.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatOutgoingMessageTextColor">Gray</Color>
                    <Color x:Key="SfChatOutgoingMessageBackground">#eee479</Color>
                    <Color x:Key="SfChatOutgoingMessageTimestampTextColor">Gray</Color>
                    <Color x:Key="SfChatOutgoingMessageAuthorTextColor">Gray</Color>
                    <x:String x:Key="SfChatOutgoingMessageFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatOutgoingMessageFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatOutgoingMessageFontSize">16</x:Double>
                    <x:String x:Key="SfChatOutgoingingMessageAuthorFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatOutgoingMessageAuthorFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatOutgoingMessageAuthorFontSize">16</x:Double>
                    <x:String x:Key="SfChatOutgoingMessageTimestampFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatOutgoingMessageTimestampFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatOutgoingMessageTimestampFontSize">16</x:Double>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatOutgoingMessageTextColor", Colors.Gray);
        dictionary.Add("SfChatOutgoingMessageTimestampTextColor", Colors.Gray);
        dictionary.Add("SfChatOutgoingMessageAuthorTextColor", Colors.Gray);
        dictionary.Add("SfChatOutgoingMessageBackground", Color.FromHex("#eee479"));
        dictionary.Add("SfChatOutgoingMessageFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatOutgoingMessageFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatOutgoingMessageFontSize", 16);
        dictionary.Add("SfChatOutgoingMessageAuthorFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatOutgoingMessageAuthorFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatOutgoingMessageAuthorFontSize", 16);
        dictionary.Add("SfChatOutgoingMessageTimestampFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatOutgoingMessageTimestampFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatOutgoingMessageTimestampFontSize", 16);
        this.Resources.Add(dictionary);
    }

Outgoing message style in .NET MAUI Chat

Calendar message styling

You can style the elements of a calendar message by setting values to the in-built keys of a calendar message in the resource dictionary.

Key Description
SfChatCalendarBackground Background color of the calendar message.
SfChatCalendarStroke Border color of the calendar message.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatCalendarBackground">White</Color>
                    <Color x:Key="SfChatCalendarStroke">Black</Color>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatCalendarBackground", Colors.White);
        dictionary.Add("SfChatCalendarStroke", Colors.Black);
        this.Resources.Add(dictionary);
        ....
    }

NOTE

In addition to this, you can write the target style to the SfCalendar control to style the inner elements of the calendar, like the selection of background color, foreground color, etc.

You can style the elements of a hyperlink message by setting values to the in-built keys of a hyperlink message in the resource dictionary.

Key Description
SfChatIncomingHyperlinkColor Text color of the URL in a hyperlink message.
SfChatOutgoingHyperlinkColor Text color of the URL in an outgoing hyperlink message.
SfChatHyperlinkDescriptionTextColor Text color of the URL's meta description in a hyperlink message.
sfChatHyperlinkDescriptionBackground Background color of the URL description area in a hyperlink message.
SfChatHyperlinkMetaTitleTextColor Text color of the URL's meta title in a hyperlink message.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatIncomingHyperlinkColor">#94b6ec</Color>
                    <Color x:Key="SfChatHyperlinkMetaTitleTextColor">#f29d0a</Color>
                    <Color x:Key="SfChatHyperlinkDescriptionTextColor">Black</Color>
                    <Color x:Key="SfChatHyperlinkDescriptionBackground">#dde9cc</Color>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatIncomingHyperlinkColor", Color.FromHex("#94b6ec"));
        dictionary.Add("SfChatHyperlinkMetaTitleTextColor", Color.FromHex("#f29d0a"));
        dictionary.Add("SfChatHyperlinkDescriptionTextColor", Colors.Black);
        dictionary.Add("SfChatHyperlinkDescriptionBackground", Color.FromHex("#dde9cc"));
        this.Resources.Add(dictionary);
        ....
    }

Hyperlink message style in .NET MAUI Chat

Image message styling

You can style the elements of a image message by setting values to the in-built keys of a image message in the resource dictionary.

Key Description
SfChatIncomingImageStroke Border color of an image in an incoming image message.
SfChatOutgoingImageStroke Border color of an image in an outgoing image message.

Date picker message styling

You can style the elements of a date picker message by setting values to the in-built keys of a date picker message in the resource dictionary.

Key Description
SfChatDatePickerIconColor Color of date picker icon.
SfChatDatePickerTextColor Color of the text in date picker.
SfChatDatePickerBackground Background color of the date picker.
SfChatDatePickerStroke Border color of the date picker.
SfChatDateTimeInputMessageIconColor Icon color for datetime input messsge.
SfChatDateTimeInputMessageIconBackground Icon background color for datetime input messsge.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatDatePickerIconColor">Blue</Color>
                    <Color x:Key="SfChatDatePickerTextColor">White</Color>
                    <Color x:Key="SfChatDatePickerBackground">SkyBlue</Color>
                    <Color x:Key="SfChatDatePickerStroke">Black</Color>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatDatePickerBackground", Colors.SkyBlue);
        dictionary.Add("SfChatDatePickerTextColor", Colors.White);
        dictionary.Add("SfChatDatePickerIconColor", Colors.Blue);
        dictionary.Add("SfChatDatePickerStroke", Colors.Blue);
        this.Resources.Add(dictionary);
        ....
    }

Date picker message style in .NET MAUI Chat

Time picker message styling

You can style the elements of a time picker message by setting values to the in-built keys of a time picker message in the resource dictionary.

Key Description
SfChatTimePickerIconColor Color of time picker icon.
SfChatTimePickerTextColor Color of the text in time picker.
SfChatTimePickerBackground Background color of time picker.
SfChatTimePickerStroke Border color of time picker.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatTimePickerIconColor">Blue</Color>
                    <Color x:Key="SfChatTimePickerTextColor">White</Color>
                    <Color x:Key="SfChatTimePickerBackground">SkyBlue</Color>
                    <Color x:Key="SfChatTimePickerStroke">Black</Color>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatTimePickerBackground", Colors.SkyBlue);
        dictionary.Add("SfChatTimePickerTextColor", Colors.White);
        dictionary.Add("SfChatTimePickerIconColor", Colors.Blue);
        dictionary.Add("SfChatTimePickerStroke", Colors.Black);
        this.Resources.Add(dictionary);
        ....
    }

Time picker message style in .NET MAUI Chat

Message input view styling

You can style the elements of the message input view by setting values to the in-built keys of the message input view in the resource dictionary.

Key Description
SfChatMessageInputViewBackground Message input view background color.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatMessageInputViewBackground">#94b6ec</Color>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatMessageInputViewBackground", Colors.SkyBlue);
        this.Resources.Add(dictionary);
        ....
    }

Message input view style in .NET MAUI Chat

Editor styling

You can style the elements of the editor view by setting values to the in-built keys of the editor view in the resource dictionary.

Key Description
SfChatEditorTextColor Color of the text in the editor.
SfChatEditorPlaceholderTextColor Color of the placeholder text in the editor.
SfChatEditorStroke Color of the border in the editor.
SfChatEditorBackground Background color of the editor.
SfChatEditorFontFamily Font family of the text in the editor.
SfChatEditorFontAttributes Font attributes of the text in the editor.
SfChatEditorFontSize Font size of the text in the editor.
SfChatFocusedEditorStroke Focused border color of editor.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatEditorPlaceholderTextColor">Blue</Color>
                    <Color x:Key="SfChatEditorTextColor">Black</Color>
                    <Color x:Key="SfChatEditorBackground">LightGreen</Color>
                    <Color x:Key="SfChatEditorStroke">Black</Color>
                    <x:String x:Key="SfChatEditorFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatEditorFontAttributes">Bold</FontAttributes>
                    <x:Double x:Key="SfChatEditorFontSize">16</x:Double>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatEditorPlaceholderTextColor", Colors.Blue);
        dictionary.Add("SfChatEditorBackground", Colors.LightGreen);
        dictionary.Add("SfChatEditorTextColor", Colors.Black);
        dictionary.Add("SfChatEditorStroke", Colors.Black);
        dictionary.Add("SfChatEditorFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatEditorFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatEditorFontSize", 16);
        this.Resources.Add(dictionary);
        ....
    }

Editor style in .NET MAUI Chat

Typing indicator styling

You can style the elements of the typing indicator view by setting values to the in-built keys of the typing indicator view in the resource dictionary.

Key Description
SfChatTypingIndicatorTextColor Text color in the typing indicator.
SfChatTypingIndicatorBackground Background color of the typing indicator.
SfChatTypingIndicatorFontFamily Font family of the text in the typing indicator.
SfChatTypingIndicatorFontAttributes Font attributes of the text in the typing indicator.
SfChatTypingIndicatorFontSize Font size of the text in the typing indicator.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatTypingIndicatorTextColor">Blue</Color>
                    <Color x:Key="SfChatTypingIndicatorBackground">#eee479</Color>
                    <x:String x:Key="SfChatTypingIndicatorFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatTypingIndicatorFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatTypingIndicatorFontSize">16</x:Double>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatTypingIndicatorBackground", Color.FromHex("#eee479"));
        dictionary.Add("SfChatTypingIndicatorTextColor", Colors.Blue);
        dictionary.Add("SfChatTypingIndicatorFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatTypingIndicatorFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatTypingIndicatorFontSize", 16);
        this.Resources.Add(dictionary);
        ....
    }

Typing indicator style in .NET MAUI Chat

Time break view styling

You can style the elements of the time break view by setting values to the in-built keys of the time break view in the resource dictionary.

Key Description
SfChatTimeBreakViewTextColor Text color of the text in the time break view.
SfChatTimeBreakViewBackground Background color of the time break view.
SfChatTimeBreakViewFontFamily Font family of the text in the time break view.
SfChatTimeBreakViewFontAttributes Font attributes of the text in the time break view.
SfChatTimeBreakViewFontSize Font size of the text in the time break view.
SfChatTimeBreakViewStroke Border color of the time break view.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatTimeBreakViewTextColor">Blue</Color>
                    <Color x:Key="SfChatTimeBreakViewBackground">#e2f9cd</Color>
                    <Color x:Key="SfChatTimeBreakViewStroke">LimeGreen</Color>
                    <x:String x:Key="SfChatTimeBreakViewFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatTimeBreakViewFontAttributes">Italic</FontAttributes>
                    <x:Double x:Key="SfChatTimeBreakViewFontSize">16</x:Double>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatTimeBreakViewTextColor", Colors.Blue);
        dictionary.Add("SfChatTimeBreakViewStroke", Colors.LimeGreen);
        dictionary.Add("SfChatTimeBreakViewBackground", Color.FromHex("#e2f9cd"));
        dictionary.Add("SfChatTimeBreakViewFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatTimeBreakViewFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatTimeBreakViewFontSize", 16);
        this.Resources.Add(dictionary);
        ....
    }

Time break view style in .NET MAUI Chat

Suggestions styling

You can style the elements of the suggestion view by setting values to the in-built keys of the suggestion view in the resource dictionary.

Key Description
SfChatSuggestionListItemTextColor Text color of an item in the list of suggestions.
SfChatSuggestionListItemBackground Background color of an item in the list of suggestions.
SfChatSuggestionListBackground Background color of the suggestions list view.
SfChatSuggestionListItemFontFamily Font family of an item in the list of suggestions.
SfChatSuggestionListItemFontAttributes Font attributes of an item in the list of suggestions.
SfChatSuggestionListItemFontSize Font size of an item in the list of suggestions.
SfChatSuggestionListItemStroke Border color of an item in the list of suggestions.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatSuggestionListItemTextColor">Blue</Color>
                    <Color x:Key="SfChatSuggestionListItemBackground">#d9d9d9</Color>
                    <Color x:Key="SfChatSuggestionListBackground">Violet</Color>
                    <x:String x:Key="SfChatSuggestionListItemFontFamily">Roboto-Medium</x:String>
                    <FontAttributes x:Key="SfChatSuggestionListItemFontAttributes">Bold</FontAttributes>
                    <x:Double x:Key="SfChatSuggestionListItemFontSize">16</x:Double>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatSuggestionListItemTextColor", Colors.Blue);
        dictionary.Add("SfChatSuggestionListBackground", Colors.Violet);
        dictionary.Add("SfChatSuggestionListItemBackground", Color.FromHex("#d9d9d9"));
        dictionary.Add("SfChatSuggestionListItemFontFamily", "Roboto-Medium");
        dictionary.Add("SfChatSuggestionListItemFontAttributes", FontAttributes.Italic);
        dictionary.Add("SfChatSuggestionListItemFontSize", 16);
        this.Resources.Add(dictionary);
        ....
    }

Suggestions style in .NET MAUI Chat

Send button styling

You can style the send message button based on its state by setting values to the in-built keys of the send message button in the resource dictionary.

Key Description
SfChatSendButtonColor Color of the send button.
SfChatSendButtonDisabledColor Color of the send button when it is in 'Disabled' state.
SfChatSendButtonBackground Background color of the send button.
SfChatDisabledSendButtonBackground Disabled background color of the send button.
SfChatHoveredSendButtonBackground Hovered background color of the send button.
SfChatPressedSendButtonBackground Pressed background color of the send button.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatSendButtonDisabledColor">Purple</Color>
                    <Color x:Key="SfChatSendButtonColor">DeepPink</Color>
                    <Color x:Key="SfChatSendButtonBackground">SkyBlue</Color>
                    <Color x:Key="SfChatDisabledSendButtonBackground">LightGreen</Color>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatSendButtonDisabledColor", Colors.Purple);
        dictionary.Add("SfChatSendButtonColor", Colors.DeepPink);
        dictionary.Add("SfChatSendButtonBackground", Colors.SkyBlue);
        dictionary.Add("SfChatDisabledSendButtonBackground", Colors.LightGreen);
        this.Resources.Add(dictionary);
        ....
    }

Send button disable and enable style in .NET MAUI Chat

Attachment button styling

You can style the attachment button by setting values to the in-built keys of the attachment button in the resource dictionary.

Key Description
SfChatAttachmentButtonColor Color of the attachment button.
SfChatAttachmentBackground Background color of the attachment button.
SfChatHoveredAttachmentBackground Hovered background color of the attachment button.
SfChatPressedAttachmentBackground Pressed background color of the attachment button.
SfChatHoveredAttachmentButtonColor Hovered color of the attachment button.
<ContentPage.Resources>
        <syncTheme:SyncfusionThemeDictionary>
            <syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
                <ResourceDictionary>
                    <x:String x:Key="SfChatTheme">CustomTheme</x:String>
                    <Color x:Key="SfChatAttachmentButtonColor">Orange</Color>
                </ResourceDictionary>
            </syncTheme:SyncfusionThemeDictionary.MergedDictionaries>
        </syncTheme:SyncfusionThemeDictionary>
    </ContentPage.Resources>
public MainPage()
    {
        ....
        InitializeComponent();
        ResourceDictionary dictionary = new ResourceDictionary();
        dictionary.Add("SfChatTheme", "CustomTheme");
        dictionary.Add("SfChatAttachmentButtonColor", Colors.Orange);
        this.Resources.Add(dictionary);
        ....
    }

Attachment button style in .NET MAUI Chat

Load More styling

You can style the load more button by setting values to the in-built keys of the load more button in the resource dictionary.

Key Description
SfChatLoadMoreBackground Background color of the load more button.
SfChatLoadMoreTextColor Text color of the load more button.
SfChatLoadMoreStroke Stroke color of the load more button.
SfChatLoadMoreIndicatorColor Indicator color of the load more button.