Skip to content

Commit

Permalink
fix(datagrid): set expandable rows overflow hidden only during animat…
Browse files Browse the repository at this point in the history
…ion (backport to 16.x) (#1290)

Backport 66395d0 from #1288. 
## PR Checklist

Please check if your PR fulfills the following requirements:

- [ ] Tests for the changes have been added (for bug fixes / features)
- [ ] Docs have been added / updated (for bug fixes / features)
- [ ] If applicable, have a visual design approval

## PR Type

What kind of change does this PR introduce?

<!-- Please check the one that applies to this PR using "x". -->

- [x] Bugfix
- [ ] Feature
- [ ] Code style update (formatting, local variables)
- [ ] Refactoring (no functional changes, no api changes)
- [ ] Build related changes
- [ ] CI related changes
- [ ] Documentation content changes
- [ ] Other... Please describe:

## What is the current behavior?
In expandable row in datagrid overflow is set to hidden in occupancies.

<!-- Please describe the current behavior that you are modifying, or
link to a relevant issue. -->

Issue Number: CDE-1692

## What is the new behavior?
In expandable row in datagrid overflow is set to hidden only during
animation.

## Does this PR introduce a breaking change?

- [ ] Yes
- [x] No

<!-- If this PR contains a breaking change, please describe the impact
and migration path for existing applications below. -->

## Other information

Co-authored-by: Valentin Mladenov <[email protected]>
  • Loading branch information
github-actions[bot] and valentin-mladenov authored Feb 27, 2024
1 parent 66b1c43 commit a4b4b80
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 5 deletions.
21 changes: 20 additions & 1 deletion .storybook/stories/datagrid/datagrid-expandable-row.stories.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,26 @@ const defaultStory: Story = args => ({
(clrDgExpandedChange)="index === 0 && clrDgExpandedChange($event)"
(clrDgSelectedChange)="index === 0 && clrDgSelectedChange($event)"
>
<clr-dg-cell>{{element.name}}</clr-dg-cell>
<clr-dg-cell>
<a
href="javascript:void(0)"
role="tooltip"
aria-haspopup="true"
class="tooltip tooltip-lg tooltip-bottom-right"
>
<cds-icon
shape="exclamation-circle"
solid
></cds-icon>
<span class="tooltip-content"
>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Proin in
neque in ante placerat mattis id sed quam. Proin rhoncus lacus et
tempor dignissim. Vivamus sem quam, pellentesque aliquet suscipit
eget, pellentesque sed arcu. Vivamus in dui lectus.</span
>
</a>
{{ element.name }}
</clr-dg-cell>
<clr-dg-cell>{{element.symbol}}</clr-dg-cell>
<clr-dg-cell>{{element.number}}</clr-dg-cell>
<clr-dg-cell>
Expand Down
4 changes: 3 additions & 1 deletion projects/angular/clarity.api.md
Original file line number Diff line number Diff line change
Expand Up @@ -2204,10 +2204,12 @@ export class ClrEmphasisModule {
// @public (undocumented)
export class ClrExpandableAnimation {
// Warning: (ae-forgotten-export) The symbol "DomAdapter" needs to be exported by the entry point index.d.ts
constructor(element: ElementRef, domAdapter: DomAdapter);
constructor(element: ElementRef, domAdapter: DomAdapter, renderer: Renderer2);
// (undocumented)
animationDone(): void;
// (undocumented)
animationStart(): void;
// (undocumented)
clrExpandTrigger: any;
// (undocumented)
get expandAnimation(): {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
*/

import { animate, style, transition, trigger } from '@angular/animations';
import { Component, ElementRef, HostBinding, HostListener, Input } from '@angular/core';
import { Component, ElementRef, HostBinding, HostListener, Input, Renderer2 } from '@angular/core';

import { DomAdapter } from '../../dom-adapter/dom-adapter';

Expand All @@ -16,7 +16,6 @@ import { DomAdapter } from '../../dom-adapter/dom-adapter';
`
:host {
display: block;
overflow: hidden;
}
`,
],
Expand All @@ -35,15 +34,21 @@ export class ClrExpandableAnimation {

startHeight = 0;

constructor(private element: ElementRef, private domAdapter: DomAdapter) {}
constructor(private element: ElementRef, private domAdapter: DomAdapter, private renderer: Renderer2) {}

@HostBinding('@expandAnimation')
get expandAnimation() {
return { value: this.clrExpandTrigger, params: { startHeight: this.startHeight } };
}

@HostListener('@expandAnimation.start')
animationStart() {
this.renderer.setStyle(this.element.nativeElement, 'overflow', 'hidden');
}
@HostListener('@expandAnimation.done')
animationDone() {
this.renderer.removeStyle(this.element.nativeElement, 'overflow');

// A "safe" auto-update of the height ensuring basic OOTB user experience .
// Prone to small jumps in initial animation height if data was changed in the meantime, window was resized, etc.
// For optimal behavior call manually updateStartHeight() from the parent component before initiating the update.
Expand Down

0 comments on commit a4b4b80

Please sign in to comment.