Skip to content

fix(elements): Ensure ForOF out of bound row gets deleted before moving to opposite side#17238

Open
skrustev wants to merge 2 commits into21.1.xfrom
skrastev/fix-for-of-elements-21.1.x
Open

fix(elements): Ensure ForOF out of bound row gets deleted before moving to opposite side#17238
skrustev wants to merge 2 commits into21.1.xfrom
skrastev/fix-for-of-elements-21.1.x

Conversation

@skrustev
Copy link
Copy Markdown
Member

Closes #17179

Type of Change (check all that apply):

  • Bug fix
  • New functionality
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • Refactoring (no functional changes)
  • Documentation
  • Demos
  • CI/CD
  • Tests
  • Changelog
  • Skills/Agents

Component(s) / Area(s) Affected:

Grids, ForOf

How Has This Been Tested?

  • Unit tests
  • Manual testing
  • Automated e2e tests

Test Configuration:

  • Angular version:
  • Browser(s):
  • OS:

Checklist:

  • All relevant tags have been applied to this PR
  • This PR includes unit tests covering all the new code (test guidelines)
  • This PR includes API docs for newly added methods/properties (api docs guidelines)
  • This PR includes feature/README.MD updates for the feature docs
  • This PR includes general feature table updates in the root README.MD
  • This PR includes CHANGELOG.MD updates for newly added functionality
  • This PR contains breaking changes
  • This PR includes ng update migrations for the breaking changes (migrations guidelines)
  • This PR includes behavioral changes and the feature specification has been updated with them
  • Accessibility (ARIA, keyboard navigation, focus management) has been verified

Copilot AI review requested due to automatic review settings April 24, 2026 14:57
@skrustev skrustev changed the title Skrastev/fix for of elements 21.1.x fix(elements): Ensure ForOF out of bound row gets deleted before moving to opposite side Apr 24, 2026
Copy link
Copy Markdown
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

Fixes a virtualization/state update issue affecting IgxForOfDirective (notably reproducible in Elements + Hierarchical Grid scenarios) that could lead to incorrect sizing/scroll behavior after view reuse.

Changes:

  • Adjusts IgxForOfDirective scroll-swap logic to be more defensive and forces a view refresh (detectChanges) when reusing cached embedded views.
  • Updates an existing grid grouping spec to better reproduce/cover the virtualization scenario (scroll + cached row reuse).

Reviewed changes

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

File Description
projects/igniteui-angular/grids/grid/src/grid.groupby.spec.ts Updates an async virtualization-related test sequence to stabilize/trigger the expected state restoration after scrolling.
projects/igniteui-angular/directives/src/directives/for-of/for_of.directive.ts Tweaks view-reuse logic during scroll swaps, adds extra change detection, and guards against missing embedded views.

Comment thread projects/igniteui-angular/grids/grid/src/grid.groupby.spec.ts
Comment thread projects/igniteui-angular/grids/grid/src/grid.groupby.spec.ts
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants