Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
19 commits
Select commit Hold shift + click to select a range
aef8dd8
fix(grid-pinning): remove hide call in scrollToRow
IMinchev64 Jan 21, 2026
7a40bcf
fix(grid-pinning): hide action strip menu after scrolling to row
IMinchev64 Feb 2, 2026
d9c7b5c
fix(grid): improve action strip visibility logic during scrolling
IMinchev64 Feb 16, 2026
1927f71
Merge branch '20.1.x' into iminchev/fix-16943-20.1.x
dkamburov Mar 10, 2026
ad4ee5a
test(grid): enhance action strip visibility tests for pinned rows
IMinchev64 Mar 10, 2026
b57fcd0
fix(grid): adjust debounce time in pinning actions test
IMinchev64 Mar 10, 2026
88d839c
fix(grid): update action strip visibility logic for pinned rows
IMinchev64 Mar 11, 2026
000e5f2
fix(grid): correct action strip visibility logic for pinned rows
IMinchev64 Mar 11, 2026
f556e4e
fix(grid): update action strip logic to check for menu items presence
IMinchev64 Mar 12, 2026
de60460
Merge branch '20.1.x' into iminchev/fix-16943-20.1.x
ChronosSF Mar 27, 2026
10cd985
fix(IgxGrid): add method to check for menu pinning actions in action …
IMinchev64 Apr 1, 2026
150680c
Merge branch '20.1.x' into iminchev/fix-16943-20.1.x
IMinchev64 Apr 1, 2026
e132c52
fix(grid): Remove unnecessary type assertion hasMenuPinningActions
IMinchev64 Apr 2, 2026
f48f0ce
Merge branch 'iminchev/fix-16943-20.1.x' of https://github.com/Ignite…
IMinchev64 Apr 2, 2026
35ed9ea
chore(grid): remove unused import of IgxActionStripComponent
IMinchev64 Apr 2, 2026
c456bba
Merge branch '20.1.x' into iminchev/fix-16943-20.1.x
IMinchev64 Apr 2, 2026
005c8d1
fix(grid): Simplify hasMenuPinningActions method for better readability
IMinchev64 Apr 2, 2026
51729aa
fix(grid): resolve circular dependency by using relative import for I…
Copilot Apr 6, 2026
360a343
chore(element): update elements config
dkamburov Apr 6, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,12 @@ import { IgxColumnLayoutComponent } from "../../../igniteui-angular/src/lib/grid
import { IgxGridToolbarExporterComponent } from "../../../igniteui-angular/src/lib/grids/toolbar/grid-toolbar-exporter.component";
import { IgxGridToolbarHidingComponent } from "../../../igniteui-angular/src/lib/grids/toolbar/grid-toolbar-hiding.component";
import { IgxGridToolbarPinningComponent } from "../../../igniteui-angular/src/lib/grids/toolbar/grid-toolbar-pinning.component";
import { IgxRowIslandComponent } from "../../../igniteui-angular/src/lib/grids/hierarchical-grid/row-island.component";
import { IgxActionStripComponent } from "../../../igniteui-angular/src/lib/action-strip/action-strip.component";
import { IgxActionStripToken } from "../../../igniteui-angular/src/lib/action-strip/token";
import { IgxGridEditingActionsComponent } from "../../../igniteui-angular/src/lib/action-strip/grid-actions/grid-editing-actions.component";
import { IgxGridActionsBaseDirective } from "../../../igniteui-angular/src/lib/action-strip/grid-actions/grid-actions-base.directive";
import { IgxGridPinningActionsComponent } from "../../../igniteui-angular/src/lib/action-strip/grid-actions/grid-pinning-actions.component";
import { IgxGridActionsBaseDirective } from "../../../igniteui-angular/src/lib/action-strip/grid-actions/grid-actions-base.directive";
import { IgxRowIslandComponent } from "../../../igniteui-angular/src/lib/grids/hierarchical-grid/row-island.component";
import { IgxGridEditingActionsComponent } from "../../../igniteui-angular/src/lib/action-strip/grid-actions/grid-editing-actions.component";
import { IgxGridStateComponent } from "../lib/state.component";

export const registerComponents = [
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,26 @@ describe('igxGridPinningActions #grid ', () => {
const secondToLastVisible = grid.rowList.toArray()[grid.rowList.length - 2];
expect(secondToLastVisible.key).toEqual('FAMIA');
});

it('should not hide action strip in base mode when scrollToRow is invoked', () => {
grid.pinRow('FAMIA');
fixture.detectChanges();

const pinnedRow = grid.pinnedRows[0];
actionStrip.show(pinnedRow);
fixture.detectChanges();

const pinningActions = fixture.debugElement.query(By.directive(IgxGridPinningActionsComponent))
.componentInstance as IgxGridPinningActionsComponent;
spyOn<any>(grid, 'scrollTo');

pinningActions.scrollToRow(null);
fixture.detectChanges();

expect((grid as any).scrollTo).toHaveBeenCalledWith(pinnedRow.data, 0);
expect(actionStrip.hidden).toBeFalse();
expect(actionStrip.context).toBe(pinnedRow);
});
});

describe('Menu ', () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -125,7 +125,10 @@ export class IgxGridPinningActionsComponent extends IgxGridActionsBaseDirective
const context = this.strip.context;
const grid = context.grid;
grid.scrollTo(context.data, 0);
this.strip.hide();

if (this.asMenuItems) {
this.strip.hide();
}
}

private registerSVGIcons(): void {
Expand Down
3 changes: 3 additions & 0 deletions projects/igniteui-angular/src/lib/action-strip/token.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
import { QueryList } from '@angular/core';
import { OverlaySettings } from '../services/public_api';
import { IgxGridActionsBaseDirective } from './grid-actions/grid-actions-base.directive';

/* csSuppress */
/** @hidden @internal */
export abstract class IgxActionStripToken {
public abstract context: any;
public abstract menuOverlaySettings: OverlaySettings;
public abstract actionButtons: QueryList<IgxGridActionsBaseDirective>;
public abstract get hideOnRowLeave(): boolean;

public abstract show(context?: any): void;
Expand Down
33 changes: 30 additions & 3 deletions projects/igniteui-angular/src/lib/grids/grid-base.directive.ts
Original file line number Diff line number Diff line change
Expand Up @@ -186,6 +186,7 @@ import { getCurrentResourceStrings } from '../core/i18n/resources';
import { isTree, recreateTree, recreateTreeFromFields } from '../data-operations/expressions-tree-util';
import { getUUID } from './common/random';
import { DefaultMergeStrategy, IGridMergeStrategy } from '../data-operations/merge-strategy';
import { IgxGridPinningActionsComponent } from '../action-strip/grid-actions/grid-pinning-actions.component';

interface IMatchInfoCache {
row: any;
Expand Down Expand Up @@ -7831,9 +7832,18 @@ export abstract class IgxGridBaseDirective implements GridType,
this.disableTransitions = false;

this.hideOverlays();
this.actionStrip?.hide();
if (this.actionStrip) {
this.actionStrip.context = null;
const context = this.actionStrip?.context;
const contextEl = context?.element?.nativeElement as HTMLElement;
const keepActionStrip =
!!context?.pinned &&
!!contextEl?.isConnected &&
!this.hasMenuPinningActions();

if (!keepActionStrip) {
if (this.actionStrip) {
this.actionStrip.hide();
this.actionStrip.context = null;
}
}
const args: IGridScrollEventArgs = {
direction: 'vertical',
Expand All @@ -7843,6 +7853,23 @@ export abstract class IgxGridBaseDirective implements GridType,
this.gridScroll.emit(args);
}

protected hasMenuPinningActions(): boolean {
const strip = this.actionStrip;
const actionButtons = strip?.actionButtons;

if (!actionButtons?.length) {
return false;
}

return actionButtons
.toArray()
.some(
(button) =>
button instanceof IgxGridPinningActionsComponent &&
button.asMenuItems
);
}

protected horizontalScrollHandler(event) {
const scrollLeft = event.target.scrollLeft;
this.headerContainer.onHScroll(scrollLeft);
Expand Down
Loading