Skip to content

Commit

Permalink
fix(accordion): remove animation
Browse files Browse the repository at this point in the history
fixes #2597
  • Loading branch information
bennypowers committed Sep 27, 2023
1 parent 45a1a27 commit 557c64e
Show file tree
Hide file tree
Showing 5 changed files with 11 additions and 84 deletions.
4 changes: 4 additions & 0 deletions .changeset/accordion-no-animate.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
---
"@patternfly/elements": patch
---
`<pf-accordion>`: remove animations which are not present in PatternFly specs
3 changes: 2 additions & 1 deletion docs/main.css
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,8 @@ main.blog {
opacity: 0;
}

:defined {
/* exclude demos */
[class^="layout-"] :defined {
transition: opacity 0.2s ease;
}

Expand Down
5 changes: 0 additions & 5 deletions elements/pf-accordion/BaseAccordion.css

This file was deleted.

78 changes: 5 additions & 73 deletions elements/pf-accordion/BaseAccordion.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,6 @@ import { BaseAccordionPanel } from './BaseAccordionPanel.js';

import { RovingTabindexController } from '@patternfly/pfe-core/controllers/roving-tabindex-controller.js';

import style from './BaseAccordion.css';

const CSS_TIMING_UNITS_RE = /^[0-9.]+(?<unit>[a-zA-Z]+)/g;

export class AccordionExpandEvent extends ComposedEvent {
constructor(
public toggle: BaseAccordionHeader,
Expand All @@ -34,7 +30,7 @@ export class AccordionCollapseEvent extends ComposedEvent {
}

export abstract class BaseAccordion extends LitElement {
static readonly styles = [style];
static readonly styles = [];

static isAccordion(target: EventTarget | null): target is BaseAccordion {
return target instanceof BaseAccordion;
Expand Down Expand Up @@ -104,10 +100,6 @@ export abstract class BaseAccordion extends LitElement {

#logger = new Logger(this);

#styles = getComputedStyle(this);

#transitionDuration = this.#getAnimationDuration();

// actually is read in #init, by the `||=` operator
#initialized = false;

Expand Down Expand Up @@ -158,11 +150,11 @@ export abstract class BaseAccordion extends LitElement {
this.#initialized ||= !!await this.updateComplete;
this.#headerIndex.initItems(this.headers);
// Event listener to the accordion header after the accordion has been initialized to add the roving tabindex
this.addEventListener('focusin', this.#updateActiveHeader as EventListener);
this.addEventListener('focusin', this.#updateActiveHeader);
this.updateAccessibility();
}

#updateActiveHeader(event: FocusEvent) {
#updateActiveHeader() {
if (this.#activeHeader) {
this.#headerIndex.updateActiveItem(this.#activeHeader);
}
Expand All @@ -184,15 +176,9 @@ export abstract class BaseAccordion extends LitElement {
header.expanded = true;
}

async #expandPanel(panel: BaseAccordionPanel) {
#expandPanel(panel: BaseAccordionPanel) {
panel.expanded = true;
panel.hidden = false;

await panel.updateComplete;

const rect = panel.getBoundingClientRect();

this.#animate(panel, 0, rect.height);
}

async #collapseHeader(header: BaseAccordionHeader, index = this.#getIndex(header)) {
Expand All @@ -210,66 +196,12 @@ export abstract class BaseAccordion extends LitElement {
return;
}

const rect = panel.getBoundingClientRect();

panel.expanded = false;
panel.hidden = true;

this.#animate(panel, rect.height, 0);
await panel.updateComplete;
}

#getAnimationDuration(): number {
if ('computedStyleMap' in this) {
// @ts-expect-error: https://caniuse.com/?search=computedStyleMap
return this.computedStyleMap().get('transition-duration')?.to('ms').value;
} else {
const { transitionDuration } = this.#styles;

const groups = CSS_TIMING_UNITS_RE.exec(transitionDuration)?.groups;

if (!groups) {
return 0;
}

const parsed = parseFloat(transitionDuration);

if (groups.unit === 's') {
return parsed * 1000;
} else {
return parsed;
}
}
}

async #animate(panel: BaseAccordionPanel, start: number, end: number) {
if (panel) {
const header = panel.previousElementSibling;

const transitionDuration = this.#getAnimationDuration();
if (transitionDuration) {
this.#transitionDuration = transitionDuration;
}

const duration = this.#transitionDuration ?? 0;

header?.classList.add('animating');
panel.classList.add('animating');

const animation = panel.animate({ height: [`${start}px`, `${end}px`] }, { duration });
animation.play();
await animation.finished;

header?.classList.remove('animating');
panel.classList.remove('animating');

panel.style.removeProperty('height');
panel.hidden = !panel.expanded;
}
}

#onChange(event: AccordionHeaderChangeEvent) {
if (BaseAccordion.#isAccordionChangeEvent(event) && !this.classList.contains('animating')) {
if (BaseAccordion.#isAccordionChangeEvent(event)) {
const index = this.#getIndex(event.target);
if (event.expanded) {
this.expand(index, event.accordion);
Expand Down
5 changes: 0 additions & 5 deletions elements/pf-accordion/BaseAccordionPanel.css
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,6 @@
position: relative;
}

:host(.animating) {
display: block;
transition: height 0.3s ease-in-out;
}

:host([fixed]) {
overflow-y: auto;
}
Expand Down

0 comments on commit 557c64e

Please sign in to comment.