Skip to content

Commit a389e84

Browse files
Merge pull request #1 from SyncfusionExamples/hideColumn
How to hide a column on button click using MVVM pattern in SfDataGrid?
2 parents 5b7ceab + e8c8c16 commit a389e84

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

+9611
-2
lines changed

README.md

Lines changed: 82 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,82 @@
1-
# How-to-hide-a-column-on-button-click-using-MVVM-pattern-in-SfDataGrid
2-
This demo shows how can I hide a column on button click using MVVM pattern in SfDataGrid?
1+
# How to hide a column on button click using MVVM pattern in SfDataGrid
2+
In this article, we will show you how to hide a column on button click using MVVM pattern in [.Net Maui DataGrid](https://www.syncfusion.com/maui-controls/maui-datagrid).
3+
4+
## xaml
5+
```
6+
<ContentPage.BindingContext>
7+
<local:EmployeeViewModel x:Name="viewModel" />
8+
</ContentPage.BindingContext>
9+
10+
<StackLayout>
11+
<Button Text="Hide Employee Name Column"
12+
WidthRequest="230" Command="{Binding HideColumnCommand}" CommandParameter="{x:Reference dataGrid}"
13+
HeightRequest="55" />
14+
<syncfusion:SfDataGrid x:Name="dataGrid"
15+
Margin="10"
16+
GridLinesVisibility="Both"
17+
HeaderGridLinesVisibility="Both"
18+
HorizontalOptions="FillAndExpand"
19+
VerticalOptions="FillAndExpand"
20+
ColumnWidthMode="Auto"
21+
AutoGenerateColumnsMode="None"
22+
ItemsSource="{Binding Employees}">
23+
24+
<syncfusion:SfDataGrid.Columns>
25+
<syncfusion:DataGridNumericColumn MappingName="EmployeeID"
26+
Format="#"
27+
HeaderText="Employee ID" />
28+
<syncfusion:DataGridTextColumn MappingName="Name"
29+
HeaderText="Employee Name" />
30+
<syncfusion:DataGridTextColumn MappingName="Title"
31+
HeaderText="Designation" />
32+
<syncfusion:DataGridDateColumn MappingName="HireDate"
33+
HeaderText="Hire Date" />
34+
35+
</syncfusion:SfDataGrid.Columns>
36+
37+
</syncfusion:SfDataGrid>
38+
</StackLayout>
39+
```
40+
41+
## C#
42+
The code below demonstrates how to hide a column on button click using MVVM pattern in DataGrid.
43+
**EmployeeViewModel.cs**
44+
```
45+
public ICommand HideColumnCommand { get; }
46+
47+
public EmployeeViewModel()
48+
{
49+
PopulateData();
50+
this.CustomerNames = Customers.ToObservableCollection();
51+
HideColumnCommand = new Command<object>(ExecuteHideColumn);
52+
employees = this.GetEmployeeDetails(50);
53+
}
54+
55+
private void ExecuteHideColumn(object parameter)
56+
{
57+
var dataGrid = parameter as SfDataGrid;
58+
if (dataGrid != null)
59+
{
60+
var columnName = dataGrid.Columns.FirstOrDefault(c => c.MappingName == "Name");
61+
if (columnName != null)
62+
{
63+
columnName.Visible = false;
64+
}
65+
}
66+
}
67+
```
68+
69+
![hideColumn.gif](https://support.syncfusion.com/kb/agent/attachment/inline?token=eyJhbGciOiJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGRzaWctbW9yZSNobWFjLXNoYTI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IjMzNTc0Iiwib3JnaWQiOiIzIiwiaXNzIjoic3VwcG9ydC5zeW5jZnVzaW9uLmNvbSJ9.aPP2e9Zhg0gyyoREazyqsY9ds_nqY0Jbf56Nqqi4aS8)
70+
71+
[View sample in GitHub](https://github.com/SyncfusionExamples/How-to-hide-a-column-on-button-click-using-MVVM-pattern-in-SfDataGrid)
72+
73+
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).
74+
75+
##### Conclusion
76+
77+
I hope you enjoyed learning about how to hide a column on button click using MVVM pattern in .NET MAUI DataGrid (SfDataGrid).
78+
79+
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.
80+
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.
81+
82+
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: 43 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
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+
13+
<StackLayout>
14+
<Button Text="Hide Employee Name Column"
15+
WidthRequest="230" Command="{Binding HideColumnCommand}" CommandParameter="{x:Reference dataGrid}"
16+
HeightRequest="55" />
17+
<syncfusion:SfDataGrid x:Name="dataGrid"
18+
Margin="10"
19+
GridLinesVisibility="Both"
20+
HeaderGridLinesVisibility="Both"
21+
HorizontalOptions="FillAndExpand"
22+
VerticalOptions="FillAndExpand"
23+
ColumnWidthMode="Auto"
24+
AutoGenerateColumnsMode="None"
25+
ItemsSource="{Binding Employees}">
26+
27+
<syncfusion:SfDataGrid.Columns>
28+
<syncfusion:DataGridNumericColumn MappingName="EmployeeID"
29+
Format="#"
30+
HeaderText="Employee ID" />
31+
<syncfusion:DataGridTextColumn MappingName="Name"
32+
HeaderText="Employee Name" />
33+
<syncfusion:DataGridTextColumn MappingName="Title"
34+
HeaderText="Designation" />
35+
<syncfusion:DataGridDateColumn MappingName="HireDate"
36+
HeaderText="Hire Date" />
37+
38+
</syncfusion:SfDataGrid.Columns>
39+
40+
</syncfusion:SfDataGrid>
41+
</StackLayout>
42+
43+
</ContentPage>
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
namespace SfDataGridSample
2+
{
3+
public partial class MainPage : ContentPage
4+
{
5+
public MainPage()
6+
{
7+
InitializeComponent();
8+
}
9+
10+
}
11+
}
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+
}

0 commit comments

Comments
 (0)