forked from AvaloniaUI/Avalonia.Controls.TreeDataGrid
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
6 changed files
with
137 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,98 @@ | ||
# Creating a Flat TreeDataGrid | ||
|
||
There are two parts to any `TreeDataGrid`: | ||
|
||
- The "Source" which is defined in code and describes how your data model will map to the rows and columns of the `TreeDataGrid` | ||
- The control which can be instantiated from XAML or from code and describes how the `TreeDataGrid` will appear | ||
|
||
The source is usually defined at the view model layer if you're using the MVVM pattern but can also be defined in code-behind. This introduction will assume that you're using the MVVM pattern. | ||
|
||
This article assumes that you are using C# 10 and have [nullable reference types](https://docs.microsoft.com/en-us/dotnet/csharp/nullable-references) enabled. | ||
|
||
## Installation | ||
|
||
First follow the [installation](installation.md) instructions, ensuring that you add the theme to your `App.axaml` file. | ||
|
||
## The Data Model | ||
|
||
The data model is your "source" data that will be displayed in the `TreeDataGrid` and will be specific to your application. For this introduction we will be using a very simple `Person` class: | ||
|
||
```csharp | ||
public class Person | ||
{ | ||
public string? FirstName { get; set; } | ||
public string? LastName { get; set; } | ||
public int Age { get; set; } | ||
} | ||
``` | ||
|
||
First we create a `MainWindowViewModel` containing our simple dataset: | ||
|
||
```csharp | ||
using System.Collections.ObjectModel; | ||
using Avalonia.Controls; | ||
using Avalonia.Controls.Models.TreeDataGrid; | ||
|
||
public class MainWindowViewModel | ||
{ | ||
private ObservableCollection<Person> _people = new() | ||
{ | ||
new Person { FirstName = "Eleanor", LastName = "Pope", Age = 32 }, | ||
new Person { FirstName = "Jeremy", LastName = "Navarro", Age = 74 }, | ||
new Person { FirstName = "Lailah ", LastName = "Velazquez", Age = 16 }, | ||
new Person { FirstName = "Jazmine", LastName = "Schroeder", Age = 52 }, | ||
}; | ||
} | ||
``` | ||
|
||
We store the data in an [`ObservableCollection<T>`](https://docs.microsoft.com/en-us/dotnet/api/system.collections.objectmodel.observablecollection-1?view=net-6.0) which will allow the `TreeDataGrid` to listen for changes in the data and automatically update the UI. | ||
|
||
## The `TreeDataGrid` source | ||
|
||
The source defines how to map the data model to rows and columns. Because we're displaying non-hierarchical data, we'll use a `FlatTreeDataGridSource<Person>`. `FlatTreeDataGridSource` is a generic class where the type parameter represents the data model type, in this case `Person`. | ||
|
||
The constructor to `FlatTreeDataGridSource` accepts a collection of type `IEnumerable<T>` to which we'll pass our data set. | ||
|
||
We'll create the source in the `MainWindowViewModel` constructor, add three columns, and expose the source in a property: | ||
|
||
```csharp | ||
public class MainWindowViewModel | ||
{ | ||
private ObservableCollection<Person> _people = /* defined earlier */ | ||
|
||
public MainWindowViewModel() | ||
{ | ||
Source = new FlatTreeDataGridSource<Person>(_people) | ||
{ | ||
Columns = | ||
{ | ||
new TextColumn<Person, string>("First Name", x => x.FirstName), | ||
new TextColumn<Person, string>("Last Name", x => x.FirstName), | ||
new TextColumn<Person, int>("Age", x => x.Age), | ||
}, | ||
}; | ||
} | ||
|
||
public FlatTreeDataGridSource<Person> Source { get; } | ||
} | ||
``` | ||
|
||
The columns above are defined as `TextColumn`s - again, `TextColumn` is a generic class that accepts the data model type and a value type. The first parameter is the header to display in the column and the second parameter is a lambda expression which selects the value to display from the data model. | ||
|
||
## The `TreeDataGrid` control | ||
|
||
It's now time to add the `TreeDataGrid` control to a window and bind it to the source. | ||
|
||
```xml | ||
<Window xmlns="https://github.com/avaloniaui" | ||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" | ||
x:Class="AvaloniaApplication.MainWindow"> | ||
<TreeDataGrid Source="{Binding Source}"/> | ||
</Window> | ||
``` | ||
|
||
## Run the Application | ||
|
||
Run the application and you should see the data appear: | ||
|
||
data:image/s3,"s3://crabby-images/0b42f/0b42f1d5b270c02083ace573f1a4b2ee613d9995" alt="Simple TreeDataGrid" |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# Avalonia `TreeDataGrid` | ||
|
||
## Introduction | ||
|
||
`TreeDataGrid` is a control which displays hierarchical and tabular data together in a single view. It is a combination of a `TreeView` and `DataGrid` control. | ||
|
||
The control has two modes of operation: | ||
|
||
- Hierarchical: data is displayed in a tree with optional columns | ||
- Flat: data is displayed in a 2D table, similar to other `DataGrid` controls | ||
|
||
An example of `TreeDataGrid` displaying hierarchical data: | ||
|
||
data:image/s3,"s3://crabby-images/332c1/332c14aa02bc610323849ae7e809bcdfd893430e" alt="TreeDataGrid in hierarchical mode" | ||
|
||
An example of `TreeDataGrid` displaying flat data: | ||
|
||
data:image/s3,"s3://crabby-images/911de/911de7118257ece05a8cc87047bb2c4b99296397" alt="TreeDataGrid in hierarchical mode" | ||
|
||
## Getting Started | ||
|
||
- [Installation](installation.md) | ||
- [Creating a flat `TreeDataGrid`](get-started-flat.md) | ||
- [Creating a hierarchical `TreeDataGrid`](get-started-hierarchical.md) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
# `TreeDataGrid` Installation | ||
|
||
- Add the `Avalonia.Controls.TreeDataGrid` NuGet package to your project | ||
- Add the `TreeDataGrid` theme to your `App.xaml` file (the `StyleInclude` in the following markup): | ||
|
||
```xml | ||
<Application xmlns="https://github.com/avaloniaui" | ||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" | ||
x:Class="AvaloniaApplication.App"> | ||
<Application.Styles> | ||
<FluentTheme/> | ||
<StyleInclude Source="avares://Avalonia.Controls.TreeDataGrid/Themes/Fluent.axaml"/> | ||
</Application.Styles> | ||
</Application> | ||
``` |