Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: DataGrid issue with Virtualize=true #3102

Closed
AdyGeo opened this issue Dec 26, 2024 · 13 comments · Fixed by #3117
Closed

fix: DataGrid issue with Virtualize=true #3102

AdyGeo opened this issue Dec 26, 2024 · 13 comments · Fixed by #3117
Labels
closed:done Work is finished

Comments

@AdyGeo
Copy link

AdyGeo commented Dec 26, 2024

DataGridOnHomePage.zip

🐛 Bug Report

DataGrid issue with large number of columns (36 columns) when Virtualize="true"

🤔 Expected Behavior

to scroll and see data :-)))

😯 Current Behavior

When you are positioned to the left of the table (first columns visible) and you scroll vertically data loads and everything is fine.
When you scroll horizontally to the right (last columns visible) and then you scroll vertically data does not load or it loads ony in the beginning and the it stops loading...

@microsoft-github-policy-service microsoft-github-policy-service bot added the triage New issue. Needs to be looked at label Dec 26, 2024
@vnbaaij
Copy link
Collaborator

vnbaaij commented Dec 26, 2024

No title, no details, no reproduction code... No help.

Please try again with a real issue report. If not, we will close this one in 3 days.

@vnbaaij vnbaaij added the needs: repro code or repository The provided description or code is insufficient to repro the issue label Dec 26, 2024
@AdyGeo AdyGeo changed the title fix: [what is the issue?] in [where is the issue?] DataGrid issue with Virtualize=true Dec 26, 2024
@AdyGeo AdyGeo changed the title DataGrid issue with Virtualize=true fix: DataGrid issue with Virtualize=true Dec 26, 2024
@AdyGeo
Copy link
Author

AdyGeo commented Dec 26, 2024

Just try you datagrid in with 30+ columns with Virtualize=true.
Scroll vertically when last columns are in view... (I get data only when I'm positioned on the first columns)

@vnbaaij
Copy link
Collaborator

vnbaaij commented Dec 26, 2024

No, that is not how we run this open source project...

You do not ask us to go create/craft/come up with code so we can try to get the same thing you are seeing.
You give us reproduction code that is ready to run and shows us the issue. You need to help us to help you.

@AdyGeo
Copy link
Author

AdyGeo commented Dec 26, 2024

@page "/datafromcsvfluent"
@rendermode InteractiveServer
@using BlazorPetProfileApp.Models
@using System.Reflection
@using CsvHelper.Configuration
@using Microsoft.EntityFrameworkCore;
@using CsvHelper;
@using System.Globalization;
@using System.Linq.Expressions
@using System.Net.Http.Json
@using Microsoft.FluentUI.AspNetCore.Components
@inject ILogger<DataFromCSVFluent> Logger


<PageTitle>DataGrid</PageTitle>

<h1>TEST Data From CSV</h1>
<div style="width: 1000px; overflow-x:auto;">
<FluentDataGrid @ref="grid" Items=@records Virtualize="true" ItemSize="54" AutoFit="true" GenerateHeader="@GenerateHeaderOption.Sticky" style="height:600px;">
    <ChildContent>
        <PropertyColumn Property="@(c => c.ReportDate)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Id)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Description)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Category)" Sortable="true" />
        <PropertyColumn Property="@(c => c.ProductType)" Sortable="true" />
        <PropertyColumn Property="@(c => c.CostRON)" Sortable="true" />
        <PropertyColumn Property="@(c => c.SalesPrice)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Currency)" Sortable="true" />
        <PropertyColumn Property="@(c => c.DateIn)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Supplier)" Sortable="true" />
        <PropertyColumn Property="@(c => c.CodFu)" Sortable="true" />
        <PropertyColumn Property="@(c => c.WebsiteCode)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Weight)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Metal)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Color)" Sortable="true" />
        <PropertyColumn Property="@(c => c.RingSize)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Length)" Sortable="true" />
        <PropertyColumn Property="@(c => c.image)" Sortable="true" />
        <PropertyColumn Property="@(c => c.style)" Sortable="true" />
        <PropertyColumn Property="@(c => c.stone_category)" Sortable="true" />
        <PropertyColumn Property="@(c => c.TEILORCODE)" Sortable="true" />
        <PropertyColumn Property="@(c => c.maturity)" Sortable="true" />
        <PropertyColumn Property="@(c => c.marcaANPC)" Sortable="true" />
        <PropertyColumn Property="@(c => c.marcaTeilor)" Sortable="true" />
        <PropertyColumn Property="@(c => c.audientaTinta)" Sortable="true" />
        <PropertyColumn Property="@(c => c.consignment)" Sortable="true" />
        <PropertyColumn Property="@(c => c.SplitDiamondsDetails)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Tennis_bracelet_setting)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Nivel_design)" Sortable="true" />
        <PropertyColumn Property="@(c => c.PROMODISC)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Width)" Sortable="true" />
        <PropertyColumn Property="@(c => c.WeightNET)" Sortable="true" />
        <PropertyColumn Property="@(c => c.FormaPandant)" Sortable="true" />
        <PropertyColumn Property="@(c => c.Solitaire)" Sortable="true" />
        <PropertyColumn Property="@(c => c.TEILOR2DAAR)" Sortable="true" />
    </ChildContent>
    <LoadingContent>
        <FluentStack Orientation="Orientation.Vertical" HorizontalAlignment="HorizontalAlignment.Center">
            Loading...<br />
            <FluentProgress Width="240px" />
        </FluentStack>
    </LoadingContent>
</FluentDataGrid>
</div>




@code {

    FluentDataGrid<Product>? grid;
    IQueryable<Product>? records = Enumerable.Empty<Product>().AsQueryable();
    PropertyInfo[] props = typeof(Product).GetProperties();



    protected override Task OnInitializedAsync()
    {
        grid?.SetLoadingState(true);
        GetGridData();
        grid?.SetLoadingState(false);
        return base.OnInitializedAsync();
    }

    private void GetGridData()
    {

        var config = new CsvConfiguration(CultureInfo.InvariantCulture)
            {
                HasHeaderRecord = true,
            };

        using var reader = new StreamReader("temp products.csv");
        using var csv = new CsvReader(reader, config);

        {

            csv.Context.RegisterClassMap<ProductMap>();
            var data = csv.GetRecords<Product>().ToList<Product>();
            data = data[0..10_000];
            records = data.AsQueryable<Product>();
            Logger.LogInformation(records.Count().ToString());

        }
    }

}

@vnbaaij
Copy link
Collaborator

vnbaaij commented Dec 26, 2024

This is not ready to run code, is it?

@AdyGeo
Copy link
Author

AdyGeo commented Dec 26, 2024

Look :-))) You misunderstood me.
I am bored, I usually work with a lot of data and I decided to try a lot of datagrids that can handle a lot of data (React, Angular and some Blazor datagrids).
Out of blazor ones MudBlazor handled virtualized well....
FluentUi looks waay better but I found this issue.
If you think it's worthwhile to look into it then look into it... otherwise close the ticket.

@vnbaaij
Copy link
Collaborator

vnbaaij commented Dec 26, 2024

We look into every issue that gets reported as long as our template is followed and ready to run reproduction code in the form of something we can copy and paste, has a zipped project or a link to a repo we can clone is provided.

We appreciate you look into using the library (and think it looks good) but we simply do not have capacity to act on half working code that we need to investigate and examine, need to install dependencies for, etc. I don't think that that is to much to ask for if you want us to help you.

@AdyGeo
Copy link
Author

AdyGeo commented Dec 26, 2024

You are right:
DataGridOnHomePage.zip

It's the example from the FluentUI page (virtualized section). I just added more columns.
Scroll horizontally to the right and then scroll vertically: Data stops coming or the UI stops updating...

@vnbaaij vnbaaij added status:needs-investigation Needs additional investigation area:blazor A blazor-specific issue status:blocked Any issue blocked by another community:noteworthy An issue or PR of particular interest to the community or planned for an announcement. community:contribution Issue will/can be addressed by community contribution and removed needs: repro code or repository The provided description or code is insufficient to repro the issue triage New issue. Needs to be looked at status:needs-investigation Needs additional investigation area:blazor A blazor-specific issue labels Dec 26, 2024
@vnbaaij
Copy link
Collaborator

vnbaaij commented Dec 27, 2024

Ok, I spent a considerate amount of time looking at this but was not able to solve the issue. I even added a standard QuickGrid to test the same code, but the issue does not present itself there.

It has to do with the way we create the HTML for the DataGrid that leads to the JS part of Virtualize not being called if the grid is horizontally scrolled for a certain part.

We need the wisdom of the crowd to solve this!

If you want to help, please checkout the dev branch, run the Fluent.Demo.Server project and navigate
to the /issue-tester page to see the example for the issue.

Scrolling vertically while the horizontal scroll is at the left margin works as it should. Scrolling vertically while the horizontal scroll is at the right margin leads to a blank grid. If the horizontal scrollbar is moved to the left sufficiently, the data re-appears. Scrolling vertically is erratic as well...

@MarvinKlein1508
Copy link
Contributor

@vnbaaij did you consider using tr for virtualized content as well? If I remember correctly Virtualize will create a div by default. The Blazor team has added a way to change that behaviour I think in .NET 8. As the div can lead to some errors when being used within a table.

@vnbaaij
Copy link
Collaborator

vnbaaij commented Dec 28, 2024

Yes, saw that too. Tested with that locally but did not help 😕.

But will use that for next version anyway.

@AdyGeo
Copy link
Author

AdyGeo commented Dec 28, 2024

I don't know if this is related or if it helps: but the scroll bar jumps all over the place on vertical scrolling (vigorously) . It does not seem to indicate the corect position related to the virtualized data collection.
...when scrolling positioned on the left margin of the table.

@vnbaaij
Copy link
Collaborator

vnbaaij commented Jan 2, 2025

Ok, i have a fix for this but it comes with a caveat...

The issue is there because we use a specific way of rendering the table (with display: grid), thead, tbody and tr (with display: contents). This is done to have compatibility with the previous way of rendering and allows for specifying column widths with fr units. It is also necessary to have this for resizing the columns. Obviously, we do not want to (and will not) remove that option.

The issue is fixed when using 'pure' HTML table rendering:

Image

But it comes with the 'cost' of not being able to use fr units for sizing and does not work with a resizable grid. I think the resizing can be fixed but need some help with the JS.

We decided to implement both ways of rendering by adding a new parameter Rendermode of type DataGridRendermode with options Grid (default) and 'Table. With Gridnothing changes from how DataGrids are being rendered right now. WithTable` the described specifics will not be used and everything will just be rendered as pure HTML table elements.

You as the developer have the choice of specifying what Rendermode to use, taking into account the limitations of each mode.

@vnbaaij vnbaaij removed community:noteworthy An issue or PR of particular interest to the community or planned for an announcement. status:blocked Any issue blocked by another labels Jan 2, 2025
@vnbaaij vnbaaij added closed:done Work is finished and removed community:contribution Issue will/can be addressed by community contribution labels Jan 2, 2025
@vnbaaij vnbaaij closed this as completed Jan 2, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
closed:done Work is finished
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants