maui icon indicating copy to clipboard operation
maui copied to clipboard

CollectionView with EmptyView and EmptyViewTemplate for Data template selector throws an exception

Open Vignesh-SF3580 opened this issue 1 year ago • 10 comments

Root Cause

The exception occurred because the RealizeView method in the ItemsViewController file was attempting to create and render a view when both EmptyView and EmptyViewTemplate were defined in the CollectionView, with a DataTemplateSelector for the EmptyViewTemplate. The original code did not account for the scenario where the viewTemplate was a DataTemplateSelector. In this case, the RealizeView method expected a DataTemplate to be directly provided, leading to a null reference issue when trying to use the viewTemplate. This caused an exception when it encountered a DataTemplateSelector, which should dynamically choose the correct template based on the input data.

Description of Change

The fix introduced an additional condition to handle cases where the viewTemplate is a DataTemplateSelector. This ensures that when the view is null and the viewTemplate is either null or a DataTemplateSelector, the logic correctly bypasses attempting to realize a non-existent view. This fix code prevents the exception by ensuring that the method can handle DataTemplateSelector cases, avoiding invalid template realization, and allowing the CollectionView to display the appropriate empty view template without errors.

Tested the behaviour in the following platforms

  • [x] Android
  • [x] Windows
  • [x] iOS
  • [x] Mac

Issues Fixed

Fixes https://github.com/dotnet/maui/issues/25224

Screenshots

iOS:

Before Issue Fix After Issue Fix
)

Mac:

Before Issue Fix After Issue Fix

Vignesh-SF3580 avatar Oct 21 '24 12:10 Vignesh-SF3580

/azp run

jsuarezruiz avatar Oct 21 '24 14:10 jsuarezruiz

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Oct 21 '24 14:10 azure-pipelines[bot]

/azp run

jsuarezruiz avatar Oct 22 '24 13:10 jsuarezruiz

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Oct 22 '24 13:10 azure-pipelines[bot]

/rebase

jsuarezruiz avatar Oct 23 '24 07:10 jsuarezruiz

/azp run

jsuarezruiz avatar Oct 23 '24 07:10 jsuarezruiz

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Oct 23 '24 07:10 azure-pipelines[bot]

/rebase

PureWeen avatar Oct 24 '24 16:10 PureWeen

/azp run

PureWeen avatar Oct 24 '24 16:10 PureWeen

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Oct 24 '24 16:10 azure-pipelines[bot]

/azp run

jsuarezruiz avatar Nov 04 '24 15:11 jsuarezruiz

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Nov 04 '24 15:11 azure-pipelines[bot]

/rebase

praveenkumarkarunanithi avatar Nov 06 '24 05:11 praveenkumarkarunanithi

/azp run

jsuarezruiz avatar Nov 06 '24 10:11 jsuarezruiz

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Nov 06 '24 10:11 azure-pipelines[bot]

/rebase

rmarinho avatar Nov 07 '24 14:11 rmarinho

/azp run

PureWeen avatar Nov 11 '24 04:11 PureWeen

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Nov 11 '24 04:11 azure-pipelines[bot]

/rebase

PureWeen avatar Nov 11 '24 15:11 PureWeen

/azp run

PureWeen avatar Nov 11 '24 17:11 PureWeen

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Nov 11 '24 17:11 azure-pipelines[bot]

/azp run

jsuarezruiz avatar Nov 12 '24 15:11 jsuarezruiz

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Nov 12 '24 15:11 azure-pipelines[bot]

/azp run

rmarinho avatar Nov 16 '24 02:11 rmarinho

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Nov 16 '24 02:11 azure-pipelines[bot]

/rebase

rmarinho avatar Nov 18 '24 00:11 rmarinho

/azp run

PureWeen avatar Nov 18 '24 19:11 PureWeen

Azure Pipelines successfully started running 3 pipeline(s).

azure-pipelines[bot] avatar Nov 18 '24 19:11 azure-pipelines[bot]