FM.Application.MAUI.DataGrid 1.0.1

dotnet add package FM.Application.MAUI.DataGrid --version 1.0.1                
NuGet\Install-Package FM.Application.MAUI.DataGrid -Version 1.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FM.Application.MAUI.DataGrid" Version="1.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add FM.Application.MAUI.DataGrid --version 1.0.1                
#r "nuget: FM.Application.MAUI.DataGrid, 1.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install FM.Application.MAUI.DataGrid as a Cake Addin
#addin nuget:?package=FM.Application.MAUI.DataGrid&version=1.0.1

// Install FM.Application.MAUI.DataGrid as a Cake Tool
#tool nuget:?package=FM.Application.MAUI.DataGrid&version=1.0.1                

FM MAUI DataGrid

The features offered in the Maui.DataGrid (https://github.com/akgulebubekir/Maui.DataGrid) repository did not fully meet my needs, so I cloned the repository and made the necessary modifications. I appreciate and thank you for the contributions from the original developers.

Features added:

  • Added support for “load more” or pagination when scrolling to the bottom of the grid.
  • Loading Added When Loading Data Indicator Will Be Shown.

Features to be added:

  • Horizontal scrolling wasn’t working.

Pagination and Loading Indicators

This implementation supports pagination, allowing you to load more items as you scroll to the bottom. Below are the key properties and commands you can use:

Commands

  • ScrollToLoadMoreCommand: Set this command to trigger the loading of more items when you scroll to the bottom of the list.

Properties

  • IsLoadingMore: Set this property to true to show a loading indicator while more items are being loaded.
  • LoadingMoreColor: Customize the color of the loading indicator by setting this property.
  • ScrollAfterIndex: Specify the index after which the loading command will be triggered.

Initial Loading

If you're loading or adding items for the first time, or if you want to display a loading indication, use the following properties:

  • IsLoading: Set this property to true to show an initial loading indicator.
  • LoadingColor: Customize the color of the initial loading indicator by setting this property.

Horizontal Scrolling with DataGrid

To enable horizontal scrolling for the DataGrid, you can wrap the DataGrid in a Grid with ColumnDefinitions set to Auto, and then wrap that Grid in a ScrollView. This allows the DataGrid to scroll horizontally. Note that this functionality is not implemented in the package by default.

Example Implementation

<ScrollView Grid.Row="0" Orientation="Horizontal" CompressedLayout.IsHeadless="True">
    <Grid CompressedLayout.IsHeadless="True" Margin="0,0,0,100" ColumnDefinitions="Auto">
        <dg:DataGrid Grid.Row="0" Grid.Column="0" 
                     IsLoading="{Binding DataLoading}" 
                     IsLoadingMore="{Binding DataLoadingMore}" 
                     ScrollToLoadMoreCommand="{Binding LoadMoreDataCommand}" 
                     ItemsSource="{Binding AdData}"
                     BorderColor="Transparent" 
                     HeaderBackground="#2A2A2A" 
                     RowHeight="30">
            <dg:DataGrid.NoDataView>
                <Label Text="No Results Found" IsVisible="{Binding IsNotBusy}" Style="{StaticResource NoData}"/>
            </dg:DataGrid.NoDataView>
            <dg:DataGrid.Columns>
                <dg:DataGridColumn Title="Date Aired" Width="100" 
                                   HeaderLabelStyle="{StaticResource LeftColumnTitle}"
                                   PropertyName="DateAired" 
                                   SortingEnabled="True">
                    <dg:DataGridColumn.CellTemplate>
                        <DataTemplate>
                            <Label Text="{Binding}" Style="{StaticResource LeftColumnValue}" />
                        </DataTemplate>
                    </dg:DataGridColumn.CellTemplate>
                </dg:DataGridColumn>
            </dg:DataGrid.Columns>
            <dg:DataGrid.RowsBackgroundColorPalette>
                <dg:PaletteCollection>
                    <Color>#393939</Color>
                    <Color>#2A2A2A</Color>
                </dg:PaletteCollection>
            </dg:DataGrid.RowsBackgroundColorPalette>
        </dg:DataGrid>
    </Grid>
</ScrollView>
Product Compatible and additional computed target framework versions.
.NET net8.0-android34.0 is compatible.  net8.0-ios17.5 is compatible.  net8.0-maccatalyst17.5 is compatible.  net8.0-windows10.0.19041 is compatible.  net9.0-android was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.1 123 10/6/2024
1.0.0 104 10/5/2024