1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/components/autoFocuser.js

102 lines
2.8 KiB
JavaScript
Raw Normal View History

2019-11-14 18:33:31 +03:00
define(["focusManager", "layoutManager"], function (focusManager, layoutManager) {
2019-11-02 20:38:58 +03:00
"use strict";
/**
* Previously selected element.
*/
var activeElement;
2019-11-14 18:33:31 +03:00
/**
* Returns true if AutoFocuser is enabled.
*/
function isEnabled() {
return layoutManager.tv;
};
2019-11-02 20:38:58 +03:00
/**
* Start AutoFocuser
*/
function enable() {
2019-11-14 18:33:31 +03:00
if (!isEnabled()) {
return;
}
2019-11-02 20:38:58 +03:00
window.addEventListener("focusin", function (e) {
activeElement = e.target;
});
console.log("AutoFocuser enabled");
}
/**
* Create an array from some source.
*/
var arrayFrom = Array.prototype.from || function (src) {
return Array.prototype.slice.call(src);
}
2019-11-02 20:38:58 +03:00
/**
* Set focus on a suitable element, taking into account the previously selected.
*/
function autoFocus(container) {
2019-11-14 18:33:31 +03:00
if (!isEnabled()) {
return;
}
2019-11-02 20:38:58 +03:00
container = container || document.body;
var candidates = [];
if (activeElement) {
// These elements are recreated
if (activeElement.classList.contains("btnPreviousPage")) {
candidates.push(container.querySelector(".btnPreviousPage"));
candidates.push(container.querySelector(".btnNextPage"));
} else if (activeElement.classList.contains("btnNextPage")) {
candidates.push(container.querySelector(".btnNextPage"));
candidates.push(container.querySelector(".btnPreviousPage"));
} else if (activeElement.classList.contains("btnSelectView")) {
candidates.push(container.querySelector(".btnSelectView"));
}
candidates.push(activeElement);
}
candidates = candidates.concat(arrayFrom(container.querySelectorAll(".btnResume")));
candidates = candidates.concat(arrayFrom(container.querySelectorAll(".btnPlay")));
2019-11-02 20:38:58 +03:00
2019-11-27 16:23:27 +03:00
var focusedElement;
candidates.every(function (element) {
2019-11-02 20:38:58 +03:00
if (focusManager.isCurrentlyFocusable(element)) {
focusManager.focus(element);
2019-11-27 16:23:27 +03:00
focusedElement = element;
2019-11-02 20:38:58 +03:00
return false;
}
return true;
});
2019-11-27 16:23:27 +03:00
if (!focusedElement) {
2019-11-14 16:41:50 +03:00
// FIXME: Multiple itemsContainers
var itemsContainer = container.querySelector(".itemsContainer");
if (itemsContainer) {
2019-11-27 16:23:27 +03:00
focusedElement = focusManager.autoFocus(itemsContainer);
2019-11-14 16:41:50 +03:00
}
}
2019-11-27 16:23:27 +03:00
if (!focusedElement) {
focusedElement = focusManager.autoFocus(container);
2019-11-02 20:38:58 +03:00
}
2019-11-27 16:23:27 +03:00
return focusedElement;
2019-11-02 20:38:58 +03:00
}
return {
2019-11-14 18:33:31 +03:00
isEnabled: isEnabled,
2019-11-02 20:38:58 +03:00
enable: enable,
autoFocus: autoFocus
};
});