KEMBAR78
Fix Customised CollectionView inherited from does not ScrollTo and display selection correctly by SuthiYuvaraj · Pull Request #31549 · dotnet/maui · GitHub
Skip to content

Conversation

@SuthiYuvaraj
Copy link
Contributor

@SuthiYuvaraj SuthiYuvaraj commented Sep 10, 2025

Note

Are you waiting for the changes in this PR to be merged?
It would be very helpful if you could test the resulting artifacts from this PR and let us know in a comment if this change resolves your issue. Thank you!

Issue Description

When creating a custom class that inherits from CollectionView, calling ScrollTo works as expected on Android and iOS, but it does nothing on WinUI.

Description of Change

On Windows, the method FindBoundItem is used to locate the target item before scrolling. However, this method checks the item by reference, which causes the issue: even though the items are logically the same, the reference check fails, preventing scrolling.

To fix this, I updated the condition to match the behavior on Android and iOS, ensuring that the item can be correctly identified and scrolled to.

Issues Fixed

Fixes #31351

Tested the existing UI and DeviceTest in the following platforms

  • Android
  • Windows
  • iOS
  • Mac

Output Screenshot:

Before Issue Fix After Issue Fix
BeforeScroll.mp4
AfterScroll.mp4

@dotnet-policy-service dotnet-policy-service bot added the community ✨ Community Contribution label Sep 10, 2025
@dotnet-policy-service
Copy link
Contributor

Hey there @@SuthiYuvaraj! Thank you so much for your PR! Someone from the team will get assigned to your PR shortly and we'll get it reviewed.

@dotnet-policy-service dotnet-policy-service bot added the partner/syncfusion Issues / PR's with Syncfusion collaboration label Sep 10, 2025
@SuthiYuvaraj SuthiYuvaraj changed the title Fix 31351 Fix Customised CollectionView inherited from does not ScrollTo and display selection correctly Sep 10, 2025
@jsuarezruiz
Copy link
Contributor

/azp run MAUI-UITests-public

@azure-pipelines
Copy link

Azure Pipelines successfully started running 1 pipeline(s).

@SuthiYuvaraj SuthiYuvaraj marked this pull request as ready for review September 11, 2025 04:33
@SuthiYuvaraj SuthiYuvaraj requested a review from a team as a code owner September 11, 2025 04:33
@Copilot Copilot AI review requested due to automatic review settings September 11, 2025 04:33
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull Request Overview

This PR fixes a Windows-specific issue where custom CollectionView classes that inherit from CollectionView fail to scroll to items correctly. The problem occurs because the Windows implementation uses reference equality checks instead of value equality when finding target items for scrolling.

  • Updates the item comparison logic in Windows ItemsViewHandler to use Equals() instead of reference equality
  • Adds comprehensive UI test cases to verify scroll functionality works correctly in custom CollectionView implementations

Reviewed Changes

Copilot reviewed 3 out of 3 changed files in this pull request and generated 3 comments.

File Description
src/Controls/src/Core/Handlers/Items/ItemsViewHandler.Windows.cs Changes item comparison from reference equality (==) to value equality (Equals()) in FindBoundItem method
src/Controls/tests/TestCases.HostApp/Issues/Issue31351.cs Adds test page with custom CollectionView implementation and scroll test functionality
src/Controls/tests/TestCases.Shared.Tests/Tests/Issues/Issue31351.cs Adds automated UI tests to verify scroll behavior works correctly

Comment on lines +236 to +238
label.SetBinding(Label.TextProperty, nameof(Issue31351CollectionViewItem.Title));
label.Padding = new Thickness(10);
label.BackgroundColor = Colors.White;
Copy link

Copilot AI Sep 11, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The Label element lacks an AutomationId which is required for UI test automation. According to the guidelines, AutomationIds should be UNIQUE and are necessary for WaitForElement to find the correct element in tests.

Copilot uses AI. Check for mistakes.

App.WaitForElement("Issue31351CollectionView");
App.WaitForElement("Issue31351ScrollButton");
App.Tap("Issue31351ScrollButton");
var MidItemRect = App.WaitForElement("Item 50").GetRect();
Copy link

Copilot AI Sep 11, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This test relies on finding elements by text content ('Item 50') rather than AutomationId. This approach is brittle because it depends on the specific text generation logic. The corresponding UI elements in the HostApp should have unique AutomationIds for more reliable test automation.

Copilot uses AI. Check for mistakes.

Assert.That(MidItemRect.X, Is.GreaterThanOrEqualTo(0));
App.WaitForElement("Issue31351TopScrollButton");
App.Tap("Issue31351TopScrollButton");
var TopItemRect = App.WaitForElement("Item 1").GetRect();
Copy link

Copilot AI Sep 11, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Similar to the previous issue, this test relies on text content ('Item 1') to locate elements instead of using AutomationIds. This makes the test fragile and dependent on the exact text formatting.

Copilot uses AI. Check for mistakes.

@PureWeen PureWeen changed the base branch from main to inflight/current September 11, 2025 17:40
@PureWeen PureWeen merged commit 4fc5f76 into dotnet:inflight/current Sep 11, 2025
78 checks passed
PureWeen pushed a commit that referenced this pull request Sep 18, 2025
…splay selection correctly (#31549)

* Update ItemsViewHandler.Windows.cs

* Testcases added

* commit for testcases

* Update Issue31351.cs

* Update Issue31351.cs

* Update Issue31351.cs
PureWeen pushed a commit that referenced this pull request Sep 18, 2025
…splay selection correctly (#31549)

* Update ItemsViewHandler.Windows.cs

* Testcases added

* commit for testcases

* Update Issue31351.cs

* Update Issue31351.cs

* Update Issue31351.cs
github-actions bot pushed a commit that referenced this pull request Sep 18, 2025
…splay selection correctly (#31549)

* Update ItemsViewHandler.Windows.cs

* Testcases added

* commit for testcases

* Update Issue31351.cs

* Update Issue31351.cs

* Update Issue31351.cs
github-actions bot pushed a commit that referenced this pull request Sep 23, 2025
…splay selection correctly (#31549)

* Update ItemsViewHandler.Windows.cs

* Testcases added

* commit for testcases

* Update Issue31351.cs

* Update Issue31351.cs

* Update Issue31351.cs
github-actions bot pushed a commit that referenced this pull request Sep 23, 2025
…splay selection correctly (#31549)

* Update ItemsViewHandler.Windows.cs

* Testcases added

* commit for testcases

* Update Issue31351.cs

* Update Issue31351.cs

* Update Issue31351.cs
@github-actions github-actions bot locked and limited conversation to collaborators Oct 12, 2025
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

community ✨ Community Contribution partner/syncfusion Issues / PR's with Syncfusion collaboration platform/windows

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[Windows] - Customised CollectionView (inherited from) does not [ScrollTo] and display selection correctly

3 participants