Scoped keyboard shortcuts
This commit is contained in:
parent
4520822f1f
commit
db428c04d1
1 changed files with 103 additions and 111 deletions
|
@ -21,7 +21,6 @@ function Home({ hidden }) {
|
||||||
useTitle('Home', '/');
|
useTitle('Home', '/');
|
||||||
const { masto, instance } = api();
|
const { masto, instance } = api();
|
||||||
const snapStates = useSnapshot(states);
|
const snapStates = useSnapshot(states);
|
||||||
const isHomeLocation = snapStates.currentLocation === '/';
|
|
||||||
const [uiState, setUIState] = useState('default');
|
const [uiState, setUIState] = useState('default');
|
||||||
const [showMore, setShowMore] = useState(false);
|
const [showMore, setShowMore] = useState(false);
|
||||||
|
|
||||||
|
@ -149,9 +148,7 @@ function Home({ hidden }) {
|
||||||
|
|
||||||
const scrollableRef = useRef();
|
const scrollableRef = useRef();
|
||||||
|
|
||||||
useHotkeys(
|
const jRef = useHotkeys('j, shift+j', (_, handler) => {
|
||||||
'j, shift+j',
|
|
||||||
(_, handler) => {
|
|
||||||
// focus on next status after active status
|
// focus on next status after active status
|
||||||
// Traverses .timeline li .status-link, focus on .status-link
|
// Traverses .timeline li .status-link, focus on .status-link
|
||||||
const activeStatus = document.activeElement.closest(
|
const activeStatus = document.activeElement.closest(
|
||||||
|
@ -193,15 +190,9 @@ function Home({ hidden }) {
|
||||||
topmostStatusLink.scrollIntoViewIfNeeded?.();
|
topmostStatusLink.scrollIntoViewIfNeeded?.();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
});
|
||||||
{
|
|
||||||
enabled: isHomeLocation,
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
useHotkeys(
|
const kRef = useHotkeys('k, shift+k', (_, handler) => {
|
||||||
'k, shift+k',
|
|
||||||
(_, handler) => {
|
|
||||||
// focus on previous status after active status
|
// focus on previous status after active status
|
||||||
// Traverses .timeline li .status-link, focus on .status-link
|
// Traverses .timeline li .status-link, focus on .status-link
|
||||||
const activeStatus = document.activeElement.closest(
|
const activeStatus = document.activeElement.closest(
|
||||||
|
@ -243,15 +234,9 @@ function Home({ hidden }) {
|
||||||
topmostStatusLink.scrollIntoViewIfNeeded?.();
|
topmostStatusLink.scrollIntoViewIfNeeded?.();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
});
|
||||||
{
|
|
||||||
enabled: isHomeLocation,
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
useHotkeys(
|
const oRef = useHotkeys(['enter', 'o'], () => {
|
||||||
['enter', 'o'],
|
|
||||||
() => {
|
|
||||||
// open active status
|
// open active status
|
||||||
const activeStatus = document.activeElement.closest(
|
const activeStatus = document.activeElement.closest(
|
||||||
'.status-link, .status-boost-link',
|
'.status-link, .status-boost-link',
|
||||||
|
@ -259,11 +244,7 @@ function Home({ hidden }) {
|
||||||
if (activeStatus) {
|
if (activeStatus) {
|
||||||
activeStatus.click();
|
activeStatus.click();
|
||||||
}
|
}
|
||||||
},
|
});
|
||||||
{
|
|
||||||
enabled: isHomeLocation,
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
const {
|
const {
|
||||||
scrollDirection,
|
scrollDirection,
|
||||||
|
@ -306,6 +287,12 @@ function Home({ hidden }) {
|
||||||
const [showUpdatesButton, setShowUpdatesButton] = useState(false);
|
const [showUpdatesButton, setShowUpdatesButton] = useState(false);
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const isNewAndTop = snapStates.homeNew.length > 0 && reachStart;
|
const isNewAndTop = snapStates.homeNew.length > 0 && reachStart;
|
||||||
|
console.log(
|
||||||
|
'isNewAndTop',
|
||||||
|
isNewAndTop,
|
||||||
|
snapStates.homeNew.length,
|
||||||
|
reachStart,
|
||||||
|
);
|
||||||
setShowUpdatesButton(isNewAndTop);
|
setShowUpdatesButton(isNewAndTop);
|
||||||
}, [snapStates.homeNew.length]);
|
}, [snapStates.homeNew.length]);
|
||||||
|
|
||||||
|
@ -315,7 +302,12 @@ function Home({ hidden }) {
|
||||||
id="home-page"
|
id="home-page"
|
||||||
class="deck-container"
|
class="deck-container"
|
||||||
hidden={hidden}
|
hidden={hidden}
|
||||||
ref={scrollableRef}
|
ref={(node) => {
|
||||||
|
scrollableRef.current = node;
|
||||||
|
jRef.current = node;
|
||||||
|
kRef.current = node;
|
||||||
|
oRef.current = node;
|
||||||
|
}}
|
||||||
tabIndex="-1"
|
tabIndex="-1"
|
||||||
>
|
>
|
||||||
<div class="timeline-deck deck">
|
<div class="timeline-deck deck">
|
||||||
|
|
Loading…
Add table
Reference in a new issue