Skip to content

Commit 54f2a5f

Browse files
Committed Columns sample
1 parent 9efdeeb commit 54f2a5f

38 files changed

+1156
-0
lines changed

DataGrid_Columns/App.xaml

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:DataGrid_Columns"
5+
x:Class="DataGrid_Columns.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>

DataGrid_Columns/App.xaml.cs

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
namespace DataGrid_Columns;
2+
3+
public partial class App : Application
4+
{
5+
public App()
6+
{
7+
InitializeComponent();
8+
9+
MainPage = new AppShell();
10+
}
11+
}

DataGrid_Columns/AppShell.xaml

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+
<Shell
3+
x:Class="DataGrid_Columns.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:DataGrid_Columns"
7+
Shell.FlyoutBehavior="Disabled">
8+
9+
<ShellContent
10+
Title="Home"
11+
ContentTemplate="{DataTemplate local:MainPage}"
12+
Route="MainPage" />
13+
14+
</Shell>

DataGrid_Columns/AppShell.xaml.cs

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
namespace DataGrid_Columns;
2+
3+
public partial class AppShell : Shell
4+
{
5+
public AppShell()
6+
{
7+
InitializeComponent();
8+
}
9+
}
Lines changed: 55 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
<Project Sdk="Microsoft.NET.Sdk">
2+
3+
<PropertyGroup>
4+
<TargetFrameworks>net6.0-android;net6.0-ios;net6.0-maccatalyst</TargetFrameworks>
5+
<TargetFrameworks Condition="$([MSBuild]::IsOSPlatform('windows'))">$(TargetFrameworks);net6.0-windows10.0.19041.0</TargetFrameworks>
6+
<!-- Uncomment to also build the tizen app. You will need to install tizen by following this: https://github.com/Samsung/Tizen.NET -->
7+
<!-- <TargetFrameworks>$(TargetFrameworks);net6.0-tizen</TargetFrameworks> -->
8+
<OutputType>Exe</OutputType>
9+
<RootNamespace>DataGrid_Columns</RootNamespace>
10+
<UseMaui>true</UseMaui>
11+
<SingleProject>true</SingleProject>
12+
<ImplicitUsings>enable</ImplicitUsings>
13+
14+
<!-- Display name -->
15+
<ApplicationTitle>DataGrid_Columns</ApplicationTitle>
16+
17+
<!-- App Identifier -->
18+
<ApplicationId>com.companyname.datagrid_columns</ApplicationId>
19+
<ApplicationIdGuid>187b91d4-37d2-400d-8dd5-51097bead5ba</ApplicationIdGuid>
20+
21+
<!-- Versions -->
22+
<ApplicationDisplayVersion>1.0</ApplicationDisplayVersion>
23+
<ApplicationVersion>1</ApplicationVersion>
24+
25+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'ios'">14.2</SupportedOSPlatformVersion>
26+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'maccatalyst'">14.0</SupportedOSPlatformVersion>
27+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'android'">21.0</SupportedOSPlatformVersion>
28+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'windows'">10.0.17763.0</SupportedOSPlatformVersion>
29+
<TargetPlatformMinVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'windows'">10.0.17763.0</TargetPlatformMinVersion>
30+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'tizen'">6.5</SupportedOSPlatformVersion>
31+
</PropertyGroup>
32+
33+
<ItemGroup>
34+
<!-- App Icon -->
35+
<MauiIcon Include="Resources\AppIcon\appicon.svg" ForegroundFile="Resources\AppIcon\appiconfg.svg" Color="#512BD4" />
36+
37+
<!-- Splash Screen -->
38+
<MauiSplashScreen Include="Resources\Splash\splash.svg" Color="#512BD4" BaseSize="128,128" />
39+
40+
<!-- Images -->
41+
<MauiImage Include="Resources\Images\*" />
42+
<MauiImage Update="Resources\Images\dotnet_bot.svg" BaseSize="168,208" />
43+
44+
<!-- Custom Fonts -->
45+
<MauiFont Include="Resources\Fonts\*" />
46+
47+
<!-- Raw Assets (also remove the "Resources\Raw" prefix) -->
48+
<MauiAsset Include="Resources\Raw\**" LogicalName="%(RecursiveDir)%(Filename)%(Extension)" />
49+
</ItemGroup>
50+
51+
<ItemGroup>
52+
<PackageReference Include="Syncfusion.Maui.DataGrid" Version="20.4.38" />
53+
</ItemGroup>
54+
55+
</Project>
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
3+
<PropertyGroup>
4+
<IsFirstTimeProjectOpen>False</IsFirstTimeProjectOpen>
5+
<ActiveDebugFramework>net6.0-android</ActiveDebugFramework>
6+
<ActiveDebugProfile>Pixel 5 - API 32 (Android 12.1 - API 32)</ActiveDebugProfile>
7+
<SelectedPlatformGroup>Emulator</SelectedPlatformGroup>
8+
<DefaultDevice>pixel_5_-_api_32</DefaultDevice>
9+
</PropertyGroup>
10+
</Project>
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
2+
Microsoft Visual Studio Solution File, Format Version 12.00
3+
# Visual Studio Version 17
4+
VisualStudioVersion = 17.0.31611.283
5+
MinimumVisualStudioVersion = 10.0.40219.1
6+
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "DataGrid_Columns", "DataGrid_Columns.csproj", "{B1815B0E-BAA1-44FC-AF56-77D2E0E914C8}"
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+
{B1815B0E-BAA1-44FC-AF56-77D2E0E914C8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15+
{B1815B0E-BAA1-44FC-AF56-77D2E0E914C8}.Debug|Any CPU.Build.0 = Debug|Any CPU
16+
{B1815B0E-BAA1-44FC-AF56-77D2E0E914C8}.Debug|Any CPU.Deploy.0 = Debug|Any CPU
17+
{B1815B0E-BAA1-44FC-AF56-77D2E0E914C8}.Release|Any CPU.ActiveCfg = Release|Any CPU
18+
{B1815B0E-BAA1-44FC-AF56-77D2E0E914C8}.Release|Any CPU.Build.0 = Release|Any CPU
19+
{B1815B0E-BAA1-44FC-AF56-77D2E0E914C8}.Release|Any CPU.Deploy.0 = Release|Any CPU
20+
EndGlobalSection
21+
GlobalSection(SolutionProperties) = preSolution
22+
HideSolutionNode = FALSE
23+
EndGlobalSection
24+
GlobalSection(ExtensibilityGlobals) = postSolution
25+
SolutionGuid = {61F7FB11-1E47-470C-91E2-47F8143E1572}
26+
EndGlobalSection
27+
EndGlobal

DataGrid_Columns/MainPage.xaml

Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
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:DataGrid_Columns"
6+
x:Class="DataGrid_Columns.MainPage">
7+
8+
<ContentPage.BindingContext>
9+
<local:OrderInfoRepo />
10+
</ContentPage.BindingContext>
11+
12+
<StackLayout>
13+
14+
<StackLayout Orientation="Horizontal">
15+
<Button Text="Add" Clicked="Button_Clicked_1" Margin="3" />
16+
<Button Text="Edit" Clicked="Button_Clicked_2" Margin="3" />
17+
<Button Text="Remove" Clicked="Button_Clicked_3" Margin="3" />
18+
<Button Text="Clear" Clicked="Button_Clicked_4" Margin="3" />
19+
</StackLayout>
20+
21+
<syncfusion:SfDataGrid x:Name="dataGrid" ItemsSource="{Binding Orders}"
22+
ColumnWidthMode="FitByHeader"
23+
AutoGenerateColumnsMode="None" >
24+
<syncfusion:SfDataGrid.Columns>
25+
<syncfusion:DataGridNumericColumn MappingName="OrderID" HeaderText="Order ID"/>
26+
<syncfusion:DataGridTextColumn MappingName="Customer" HeaderText="Customer"/>
27+
<syncfusion:DataGridCheckBoxColumn MappingName="IsShipped" HeaderText="Is Shipped"/>
28+
<syncfusion:DataGridDateColumn MappingName="ShipTime" HeaderText="Ship Time"/>
29+
</syncfusion:SfDataGrid.Columns>
30+
</syncfusion:SfDataGrid>
31+
32+
</StackLayout>
33+
34+
</ContentPage>

DataGrid_Columns/MainPage.xaml.cs

Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
using Syncfusion.Maui.DataGrid;
2+
3+
namespace DataGrid_Columns;
4+
5+
public partial class MainPage : ContentPage
6+
{
7+
public MainPage()
8+
{
9+
InitializeComponent();
10+
}
11+
12+
private void Button_Clicked_1(object sender, EventArgs e)
13+
{
14+
var shipCountry = new DataGridTextColumn() { MappingName = "ShipCountry", HeaderText="Ship Country" };
15+
this.dataGrid.Columns.Add(shipCountry);
16+
17+
//this.dataGrid.Columns.Insert(1, shipCountry);
18+
}
19+
20+
private void Button_Clicked_2(object sender, EventArgs e)
21+
{
22+
var column = this.dataGrid.Columns[0];
23+
column.HeaderText = "Client";
24+
}
25+
26+
private void Button_Clicked_3(object sender, EventArgs e)
27+
{
28+
if (this.dataGrid.Columns.Count > 0)
29+
this.dataGrid.Columns.RemoveAt(0);
30+
}
31+
32+
private void Button_Clicked_4(object sender, EventArgs e)
33+
{
34+
this.dataGrid.Columns.Clear();
35+
}
36+
37+
private void dataGrid_AutoGeneratingColumn(object sender, DataGridAutoGeneratingColumnEventArgs e)
38+
{
39+
if(e.Column.MappingName == "ShipTime")
40+
{
41+
e.Column.Format = "MMM yy";
42+
}
43+
44+
if (e.Column.MappingName == "OrderID")
45+
e.Column.HeaderText = "Order ID";
46+
else if (e.Column.MappingName == "IsShipped")
47+
e.Column.HeaderText = "Is Shipped";
48+
else if (e.Column.MappingName == "CustomerID")
49+
e.Column.HeaderText = "Customer ID";
50+
else if (e.Column.MappingName == "ShipTime")
51+
e.Column.HeaderText = "Ship Time";
52+
else if (e.Column.MappingName == "ShipCountry")
53+
e.Column.HeaderText = "ShipCountry";
54+
}
55+
}
56+

DataGrid_Columns/MauiProgram.cs

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
using Syncfusion.Maui.Core.Hosting;
2+
3+
namespace DataGrid_Columns;
4+
5+
public static class MauiProgram
6+
{
7+
public static MauiApp CreateMauiApp()
8+
{
9+
var builder = MauiApp.CreateBuilder();
10+
builder
11+
.UseMauiApp<App>()
12+
.ConfigureSyncfusionCore()
13+
.ConfigureFonts(fonts =>
14+
{
15+
fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular");
16+
fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold");
17+
});
18+
19+
return builder.Build();
20+
}
21+
}

0 commit comments

Comments
 (0)