mirror of
https://github.com/JeremyLikness/vanillajs-deck
synced 2024-12-04 19:27:37 +00:00
Add key press handler
This commit is contained in:
parent
88f7b5cbc2
commit
3a59e39fb0
@ -65,7 +65,6 @@ img {
|
|||||||
slide-deck div {
|
slide-deck div {
|
||||||
height: 80vh;
|
height: 80vh;
|
||||||
padding: 1em;
|
padding: 1em;
|
||||||
border: solid 2px lightgray;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@media only screen and (max-width: 960px) {
|
@media only screen and (max-width: 960px) {
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
<h1>DevNexus | Vanilla.js: Modern 1st Party JavaScript</h1>
|
<h1>DevNexus | Vanilla.js: Modern 1st Party JavaScript</h1>
|
||||||
<h2>Setting things up ...</h2>
|
<h2>Setting things up ...</h2>
|
||||||
</slide-deck>
|
</slide-deck>
|
||||||
|
<key-handler deck="main"></key-handler>
|
||||||
<div class="footer left">
|
<div class="footer left">
|
||||||
<img src="./images/devnexus.png" alt="DevNexus logo" title="DevNexus logo" />
|
<img src="./images/devnexus.png" alt="DevNexus logo" title="DevNexus logo" />
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
import { registerDeck } from "./navigator.js"
|
import { registerDeck } from "./navigator.js"
|
||||||
import { registerControls } from "./controls.js"
|
import { registerControls } from "./controls.js"
|
||||||
|
import { registerKeyHandler } from "./keyhandler.js"
|
||||||
|
|
||||||
const app = async () => {
|
const app = async () => {
|
||||||
|
|
||||||
registerDeck();
|
registerDeck();
|
||||||
registerControls();
|
registerControls();
|
||||||
|
registerKeyHandler();
|
||||||
};
|
};
|
||||||
|
|
||||||
document.addEventListener("DOMContentLoaded", app);
|
document.addEventListener("DOMContentLoaded", app);
|
||||||
|
29
js/keyhandler.js
Normal file
29
js/keyhandler.js
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
class KeyHandler extends HTMLElement {
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
super();
|
||||||
|
this._deck = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
static get observedAttributes() {
|
||||||
|
return ["deck"];
|
||||||
|
}
|
||||||
|
|
||||||
|
async attributeChangedCallback(attrName, oldVal, newVal) {
|
||||||
|
if (attrName === "deck") {
|
||||||
|
if (oldVal !== newVal) {
|
||||||
|
this._deck = document.getElementById(newVal);
|
||||||
|
this._deck.parentElement.addEventListener("keydown", key => {
|
||||||
|
if (key.keyCode == 39 || key.keyCode == 32) {
|
||||||
|
this._deck.next();
|
||||||
|
}
|
||||||
|
else if (key.keyCode == 37) {
|
||||||
|
this._deck.previous();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const registerKeyHandler = () => customElements.define('key-handler', KeyHandler);
|
Loading…
Reference in New Issue
Block a user