Skip to content

Commit

Permalink
Fix: Delay button update until after focus (fixes #261) (#266)
Browse files Browse the repository at this point in the history
  • Loading branch information
oliverfoster authored May 26, 2023
1 parent 2b7605b commit 949ee68
Showing 1 changed file with 12 additions and 4 deletions.
16 changes: 12 additions & 4 deletions js/NarrativeView.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,10 @@ class NarrativeView extends ComponentView {
$animatedElement.one('transitionend', () => this.focusOnNarrativeElement(itemIndex));
return;
}
this.focusOnNarrativeElement(itemIndex);
// Allow dom to settle before moving focus
requestAnimationFrame(() => {
this.focusOnNarrativeElement(itemIndex);
});
}

focusOnNarrativeElement(itemIndex) {
Expand All @@ -56,6 +59,9 @@ class NarrativeView extends ComponentView {
this.$(`.narrative__content-item${dataIndexAttr}`) :
this.$(`.narrative__strapline-btn${dataIndexAttr}`);
a11y.focusFirst($elementToFocus);
// Set button labels after focus to stop the change reading on a focused button
this.setupBackNextLabels();
this.manageBackNextStates();
}

onItemsActiveChange(item, _isActive) {
Expand All @@ -68,10 +74,13 @@ class NarrativeView extends ComponentView {
const index = item.get('_index');
this.model.set('_activeItemIndex', index);

this.manageBackNextStates(index);
this.setStage(item);

if (this.model.get('_isInitial')) return;
if (this.model.get('_isInitial')) {
this.setupBackNextLabels();
this.manageBackNextStates();
return;
}
this.setFocus(index);
}

Expand Down Expand Up @@ -219,7 +228,6 @@ class NarrativeView extends ComponentView {
item.toggleVisited(true);
}

this.setupBackNextLabels();
this.evaluateCompletion();
this.shouldShowInstructionError();
this.moveSliderToIndex(index);
Expand Down

0 comments on commit 949ee68

Please sign in to comment.