Skip to content

Commit ef117d9

Browse files
Merge pull request #1 from SyncfusionExamples/tailTruncation
How to display a tail-truncated text in .NET MAUI DataGrid (SfDataGrid)?
2 parents b3d5f26 + 2a9ebb1 commit ef117d9

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

42 files changed

+9497
-2
lines changed

README.md

Lines changed: 47 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,47 @@
1-
# How-to-display-a-tail-truncated-text-in-a-DataGridCell-in-.NET-MAUI-DataGrid-SfDataGrid
2-
This demo shows how to display a tail truncated text in a DataGridCell in .NET MAUI DataGrid (SfDataGrid) ?
1+
# How to display a tail-truncated text in .NET MAUI DataGrid (SfDataGrid)?
2+
In this article, we will show you how to display a tail-truncated text in [.NET MAUI DataGrid](https://www.syncfusion.com/maui-controls/maui-datagrid).
3+
4+
## Xaml
5+
The code below demonstrates how to display a tail-truncated text in SfDataGrid. The text wrapping and truncation of a column’s cell values can be customized by setting the [DataGridColumn.LineBreakMode](https://help.syncfusion.com/cr/maui/Syncfusion.Maui.DataGrid.DataGridColumn.html#Syncfusion_Maui_DataGrid_DataGridColumn_LineBreakMode) property.
6+
```
7+
<ContentPage.BindingContext>
8+
<local:EmployeeViewModel x:Name="viewModel" />
9+
</ContentPage.BindingContext>
10+
11+
<syncfusion:SfDataGrid x:Name="sfGrid"
12+
GridLinesVisibility="Both"
13+
HeaderGridLinesVisibility="Both"
14+
AutoGenerateColumnsMode="None"
15+
ItemsSource="{Binding Employees}">
16+
17+
<syncfusion:SfDataGrid.Columns>
18+
<syncfusion:DataGridNumericColumn MappingName="EmployeeID"
19+
Format="#"
20+
HeaderText="Employee ID" />
21+
<syncfusion:DataGridTextColumn MappingName="Name"
22+
HeaderText="Employee Name"
23+
LineBreakMode="TailTruncation" />
24+
<syncfusion:DataGridTextColumn MappingName="Title"
25+
HeaderText="Designation"
26+
ColumnWidthMode="Auto" />
27+
<syncfusion:DataGridDateColumn MappingName="HireDate"
28+
HeaderText="Hire Date" />
29+
</syncfusion:SfDataGrid.Columns>
30+
31+
</syncfusion:SfDataGrid>
32+
```
33+
34+
<img src="https://support.syncfusion.com/kb/agent/attachment/inline?token=eyJhbGciOiJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNobWFjLXNoYTI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IjM3MjI5Iiwib3JnaWQiOiIzIiwiaXNzIjoic3VwcG9ydC5zeW5jZnVzaW9uLmNvbSJ9.fZ0xCYvjZ8tPpb4hsozfYr7ZZzIeilK6SvP0Ogfc9ck" width=800/>
35+
36+
[View sample in GitHub](https://github.com/SyncfusionExamples/How-to-display-a-tail-truncated-text-in-a-DataGridCell-in-.NET-MAUI-DataGrid-SfDataGrid)
37+
38+
Take a moment to explore this [documentation](https://help.syncfusion.com/maui/datagrid/overview), where you can find more information about Syncfusion .NET MAUI DataGrid (SfDataGrid) with code examples. Please refer to this [link](https://www.syncfusion.com/maui-controls/maui-datagrid) to learn about the essential features of Syncfusion .NET MAUI DataGrid (SfDataGrid).
39+
40+
##### Conclusion
41+
42+
I hope you enjoyed learning about how to display a tail-truncated text in SfDataGrid.
43+
44+
You can refer to our [.NET MAUI DataGrid’s feature tour](https://www.syncfusion.com/maui-controls/maui-datagrid) page to learn about its other groundbreaking feature representations. You can also explore our [.NET MAUI DataGrid Documentation](https://help.syncfusion.com/maui/datagrid/getting-started) to understand how to present and manipulate data.
45+
For current customers, you can check out our .NET MAUI components on the [License and Downloads](https://www.syncfusion.com/sales/teamlicense) page. If you are new to Syncfusion, you can try our 30-day [free trial](https://www.syncfusion.com/downloads/maui) to explore our .NET MAUI DataGrid and other .NET MAUI components.
46+
47+
If you have any queries or require clarifications, please let us know in the comments below. You can also contact us through our [support forums](https://www.syncfusion.com/forums), [Direct-Trac](https://support.syncfusion.com/create) or [feedback portal](https://www.syncfusion.com/feedback/maui?control=sfdatagrid), or the feedback portal. We are always happy to assist you!
Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
2+
Microsoft Visual Studio Solution File, Format Version 12.00
3+
# Visual Studio Version 17
4+
VisualStudioVersion = 17.12.35506.116 d17.12
5+
MinimumVisualStudioVersion = 10.0.40219.1
6+
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SfDataGridSample", "SfDataGridSample\SfDataGridSample.csproj", "{EEB0310E-49AF-4663-87C2-E585EEFE9E5E}"
7+
EndProject
8+
Global
9+
GlobalSection(SolutionConfigurationPlatforms) = preSolution
10+
Debug|Any CPU = Debug|Any CPU
11+
Release|Any CPU = Release|Any CPU
12+
EndGlobalSection
13+
GlobalSection(ProjectConfigurationPlatforms) = postSolution
14+
{EEB0310E-49AF-4663-87C2-E585EEFE9E5E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15+
{EEB0310E-49AF-4663-87C2-E585EEFE9E5E}.Debug|Any CPU.Build.0 = Debug|Any CPU
16+
{EEB0310E-49AF-4663-87C2-E585EEFE9E5E}.Release|Any CPU.ActiveCfg = Release|Any CPU
17+
{EEB0310E-49AF-4663-87C2-E585EEFE9E5E}.Release|Any CPU.Build.0 = Release|Any CPU
18+
EndGlobalSection
19+
GlobalSection(SolutionProperties) = preSolution
20+
HideSolutionNode = FALSE
21+
EndGlobalSection
22+
EndGlobal
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
<?xml version = "1.0" encoding = "UTF-8" ?>
2+
<Application xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
3+
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
4+
xmlns:local="clr-namespace:SfDataGridSample"
5+
x:Class="SfDataGridSample.App">
6+
<Application.Resources>
7+
<ResourceDictionary>
8+
<ResourceDictionary.MergedDictionaries>
9+
<ResourceDictionary Source="Resources/Styles/Colors.xaml" />
10+
<ResourceDictionary Source="Resources/Styles/Styles.xaml" />
11+
</ResourceDictionary.MergedDictionaries>
12+
</ResourceDictionary>
13+
</Application.Resources>
14+
</Application>
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
namespace SfDataGridSample
2+
{
3+
public partial class App : Application
4+
{
5+
public App()
6+
{
7+
InitializeComponent();
8+
}
9+
10+
protected override Window CreateWindow(IActivationState? activationState)
11+
{
12+
return new Window(new AppShell());
13+
}
14+
}
15+
}
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
<?xml version="1.0" encoding="UTF-8" ?>
2+
<Shell
3+
x:Class="SfDataGridSample.AppShell"
4+
xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
5+
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
6+
xmlns:local="clr-namespace:SfDataGridSample"
7+
Shell.FlyoutBehavior="Flyout"
8+
Title="SfDataGridSample">
9+
10+
<ShellContent
11+
Title="Home"
12+
ContentTemplate="{DataTemplate local:MainPage}"
13+
Route="MainPage" />
14+
15+
</Shell>
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
namespace SfDataGridSample
2+
{
3+
public partial class AppShell : Shell
4+
{
5+
public AppShell()
6+
{
7+
InitializeComponent();
8+
}
9+
}
10+
}
Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
<?xml version="1.0" encoding="utf-8" ?>
2+
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
3+
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
4+
xmlns:syncfusion="clr-namespace:Syncfusion.Maui.DataGrid;assembly=Syncfusion.Maui.DataGrid"
5+
xmlns:local="clr-namespace:SfDataGridSample"
6+
x:Class="SfDataGridSample.MainPage">
7+
8+
<ContentPage.BindingContext>
9+
<local:EmployeeViewModel x:Name="viewModel" />
10+
</ContentPage.BindingContext>
11+
12+
<syncfusion:SfDataGrid x:Name="sfGrid"
13+
GridLinesVisibility="Both"
14+
HeaderGridLinesVisibility="Both"
15+
AutoGenerateColumnsMode="None"
16+
ItemsSource="{Binding Employees}">
17+
18+
<syncfusion:SfDataGrid.Columns>
19+
<syncfusion:DataGridNumericColumn MappingName="EmployeeID"
20+
Format="#"
21+
HeaderText="Employee ID" />
22+
<syncfusion:DataGridTextColumn MappingName="Name"
23+
HeaderText="Employee Name"
24+
LineBreakMode="TailTruncation" />
25+
<syncfusion:DataGridTextColumn MappingName="Title"
26+
HeaderText="Designation"
27+
ColumnWidthMode="Auto" />
28+
<syncfusion:DataGridDateColumn MappingName="HireDate"
29+
HeaderText="Hire Date" />
30+
</syncfusion:SfDataGrid.Columns>
31+
32+
</syncfusion:SfDataGrid>
33+
</ContentPage>
Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
using Syncfusion.Maui.DataGrid;
2+
3+
namespace SfDataGridSample
4+
{
5+
public partial class MainPage : ContentPage
6+
{
7+
public MainPage()
8+
{
9+
InitializeComponent();
10+
}
11+
}
12+
}
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
using Microsoft.Extensions.Logging;
2+
using Syncfusion.Maui.Core.Hosting;
3+
4+
namespace SfDataGridSample
5+
{
6+
public static class MauiProgram
7+
{
8+
public static MauiApp CreateMauiApp()
9+
{
10+
var builder = MauiApp.CreateBuilder();
11+
builder
12+
.UseMauiApp<App>()
13+
.ConfigureSyncfusionCore()
14+
.ConfigureFonts(fonts =>
15+
{
16+
fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular");
17+
fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold");
18+
});
19+
20+
#if DEBUG
21+
builder.Logging.AddDebug();
22+
#endif
23+
24+
return builder.Build();
25+
}
26+
}
27+
}
Lines changed: 113 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,113 @@
1+
using System.ComponentModel;
2+
3+
namespace SfDataGridSample
4+
{
5+
public class Employee : INotifyPropertyChanged
6+
{
7+
private int? _employeeID;
8+
private string? _name;
9+
private long _iDNumber;
10+
private int _contactID;
11+
private string? _loginID;
12+
private int _managerID;
13+
private string? _title;
14+
private DateTime _birthDate;
15+
private string? _maritalStatus;
16+
private string? _gender;
17+
private DateTime _hireDate;
18+
private int _sickLeaveHours;
19+
private double _salary;
20+
private bool _employeeStatus;
21+
private int _rating;
22+
private bool _isButtonVisible;
23+
24+
public int? EmployeeID
25+
{
26+
get { return _employeeID; }
27+
set { _employeeID = value; OnPropertyChanged(nameof(EmployeeID)); }
28+
}
29+
public string? Name
30+
{
31+
get { return _name; }
32+
set { _name = value; OnPropertyChanged(nameof(Name)); }
33+
}
34+
public long IDNumber
35+
{
36+
get { return _iDNumber; }
37+
set { _iDNumber = value; OnPropertyChanged(nameof(IDNumber)); }
38+
}
39+
public string? Title
40+
{
41+
get { return _title; }
42+
set { _title = value; OnPropertyChanged(nameof(Title)); }
43+
}
44+
public int ContactID
45+
{
46+
get { return _contactID; }
47+
set { _contactID = value; OnPropertyChanged(nameof(ContactID)); }
48+
}
49+
public DateTime BirthDate
50+
{
51+
get { return _birthDate; }
52+
set { _birthDate = value; OnPropertyChanged(nameof(BirthDate)); }
53+
}
54+
public string? MaritalStatus
55+
{
56+
get { return _maritalStatus; }
57+
set { _maritalStatus = value; OnPropertyChanged(nameof(MaritalStatus)); }
58+
}
59+
public string? Gender
60+
{
61+
get { return _gender; }
62+
set { _gender = value; OnPropertyChanged(nameof(Gender)); }
63+
}
64+
public DateTime HireDate
65+
{
66+
get { return _hireDate; }
67+
set { _hireDate = value; OnPropertyChanged(nameof(HireDate)); }
68+
}
69+
public int SickLeaveHours
70+
{
71+
get { return _sickLeaveHours; }
72+
set { _sickLeaveHours = value; OnPropertyChanged(nameof(SickLeaveHours)); }
73+
}
74+
public double Salary
75+
{
76+
get { return _salary; }
77+
set { _salary = value; OnPropertyChanged(nameof(Salary)); }
78+
}
79+
public string? LoginID
80+
{
81+
get { return _loginID; }
82+
set { _loginID = value; OnPropertyChanged(nameof(LoginID)); }
83+
}
84+
public int ManagerID
85+
{
86+
get { return _managerID; }
87+
set { _managerID = value; OnPropertyChanged(nameof(ManagerID)); }
88+
}
89+
public bool EmployeeStatus
90+
{
91+
get { return _employeeStatus; }
92+
set { _employeeStatus = value; OnPropertyChanged(nameof(EmployeeStatus)); }
93+
}
94+
public int Rating
95+
{
96+
get { return _rating; }
97+
set { _rating = value; OnPropertyChanged(nameof(Rating)); }
98+
}
99+
100+
public bool IsButtonVisible
101+
{
102+
get { return _isButtonVisible; }
103+
set { _isButtonVisible = value; OnPropertyChanged(nameof(IsButtonVisible)); }
104+
}
105+
106+
public event PropertyChangedEventHandler? PropertyChanged;
107+
108+
protected void OnPropertyChanged(string propertyName)
109+
{
110+
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
111+
}
112+
}
113+
}

0 commit comments

Comments
 (0)