mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 06:52:46 +08:00
FIX: intercept escape in lightbox and prevent default (#22923)
The escape key is used as a shortcut to escape the Discourse Lightbox. However, some browsers also use the escape key to exit fullscreen mode. This change is to allow escaping the lightbox when browser is in fullscreen mode, while preventing any behavior associated with the Escape key (such as exiting fullscreen). This has to be done on the keydown event, as this means we can handle our logic and then preventDefault before the browser tries to exit fullscreen.
This commit is contained in:
parent
773b22e8d0
commit
db7581ce49
|
@ -15,6 +15,7 @@
|
||||||
class="d-lightbox__content"
|
class="d-lightbox__content"
|
||||||
style={{this.CSSVars}}
|
style={{this.CSSVars}}
|
||||||
aria-labelledby={{this.titleElementId}}
|
aria-labelledby={{this.titleElementId}}
|
||||||
|
{{on "keydown" this.onKeydown passive=false capture=true}}
|
||||||
{{on "keyup" this.onKeyup passive=true capture=true}}
|
{{on "keyup" this.onKeyup passive=true capture=true}}
|
||||||
>
|
>
|
||||||
<div class="d-lightbox__focus-trap" tabindex="0"></div>
|
<div class="d-lightbox__focus-trap" tabindex="0"></div>
|
||||||
|
|
|
@ -357,6 +357,14 @@ export default class DLightbox extends Component {
|
||||||
this.hasExpandedTitle = !this.hasExpandedTitle;
|
this.hasExpandedTitle = !this.hasExpandedTitle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@bind
|
||||||
|
onKeydown(event) {
|
||||||
|
if (event.key === KEYBOARD_SHORTCUTS.CLOSE) {
|
||||||
|
event.preventDefault();
|
||||||
|
return this.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@bind
|
@bind
|
||||||
onKeyup({ key }) {
|
onKeyup({ key }) {
|
||||||
if (KEYBOARD_SHORTCUTS.PREVIOUS.includes(key)) {
|
if (KEYBOARD_SHORTCUTS.PREVIOUS.includes(key)) {
|
||||||
|
@ -367,10 +375,6 @@ export default class DLightbox extends Component {
|
||||||
return this.showNextItem();
|
return this.showNextItem();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key === KEYBOARD_SHORTCUTS.CLOSE) {
|
|
||||||
return this.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (key === KEYBOARD_SHORTCUTS.ZOOM) {
|
if (key === KEYBOARD_SHORTCUTS.ZOOM) {
|
||||||
return this.toggleZoom();
|
return this.toggleZoom();
|
||||||
}
|
}
|
||||||
|
|
|
@ -626,7 +626,7 @@ acceptance("Experimental Lightbox - interaction", function (needs) {
|
||||||
requestFullscreenStub.restore();
|
requestFullscreenStub.restore();
|
||||||
exitFullscreenStub.restore();
|
exitFullscreenStub.restore();
|
||||||
|
|
||||||
await triggerKeyEvent(SELECTORS.LIGHTBOX_CONTENT, "keyup", "Escape");
|
await triggerKeyEvent(SELECTORS.LIGHTBOX_CONTENT, "keydown", "Escape");
|
||||||
|
|
||||||
assert.dom(SELECTORS.LIGHTBOX_CONTENT).doesNotExist();
|
assert.dom(SELECTORS.LIGHTBOX_CONTENT).doesNotExist();
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user