Fix ChildChanged event not being triggered for BusinessListBase objects in Blazor ViewModel#4747
Merged
Merged
Conversation
Co-authored-by: rockfordlhotka <[email protected]>
Copilot
AI
changed the title
[WIP] Fix ChildChanged event not triggered in Blazor ViewModel
Fix ChildChanged event not being triggered for BusinessListBase objects in Blazor ViewModel
Oct 20, 2025
rockfordlhotka
approved these changes
Oct 20, 2025
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Problem
The ChildChanged event on the Blazor ViewModel was not being triggered when the Model object is of type
BusinessListBase. The event hooks only worked forIBusinessBaseobjects, excluding collection types likeBusinessListBase.Root Cause
The
HookChangedEventsandUnhookChangedEventsmethods inCsla.Blazor.ViewModel<T>were checking for theIBusinessBaseinterface:While
BusinessBaseimplementsIBusinessBase(which extendsINotifyChildChanged),BusinessListBasedoes not implementIBusinessBase. Instead, it inherits fromObservableBindingList<T>which directly implementsINotifyChildChanged.Solution
Changed both methods to check for
INotifyChildChangedinstead ofIBusinessBase:This works because:
IBusinessBaseextendsINotifyChildChanged→BusinessBaseobjects continue to workObservableBindingList<T>implementsINotifyChildChanged→BusinessListBaseobjects now workChanges
Modified:
Source/Csla.Blazor/ViewModel.cs(2 lines)HookChangedEventsto check forINotifyChildChangedUnhookChangedEventsto check forINotifyChildChangedAdded:
Source/tests/Csla.Blazor.Test/ViewModelChildChangedEventTests.csBenefits
✅ Backwards Compatible: All existing
BusinessBaseobjects continue to work✅ Fixes the Issue:
BusinessListBaseobjects now properly hook ChildChanged events✅ Aligned with Existing Code: Matches the pattern in
Csla.Xaml.Shared/ViewModelBase.cs✅ Minimal Change: Only 2 lines of production code modified
✅ Well Tested: Comprehensive unit tests added to prevent regression
Fixes #[issue_number]
Original prompt
Fixes #4723
💡 You can make Copilot smarter by setting up custom instructions, customizing its development environment and configuring Model Context Protocol (MCP) servers. Learn more Copilot coding agent tips in the docs.