phanpy/src/components/columns.jsx

79 lines
2.2 KiB
React
Raw Normal View History

import { useHotkeys } from 'react-hotkeys-hook';
import { useSnapshot } from 'valtio';
import Bookmarks from '../pages/bookmarks';
import Favourites from '../pages/favourites';
import Following from '../pages/following';
import Hashtag from '../pages/hashtag';
import List from '../pages/list';
2023-04-09 04:36:55 +03:00
import Mentions from '../pages/mentions';
import Notifications from '../pages/notifications';
import Public from '../pages/public';
2023-12-22 13:01:41 +03:00
import Search from '../pages/search';
2023-04-14 05:54:22 +03:00
import Trending from '../pages/trending';
import states from '../utils/states';
2023-02-18 17:13:32 +03:00
import useTitle from '../utils/useTitle';
function Columns() {
2023-02-18 17:13:32 +03:00
useTitle('Home', '/');
const snapStates = useSnapshot(states);
const { shortcuts } = snapStates;
console.debug('RENDER Columns', shortcuts);
const components = shortcuts.map((shortcut) => {
2023-04-08 17:16:13 +03:00
if (!shortcut) return null;
const { type, ...params } = shortcut;
const Component = {
following: Following,
notifications: Notifications,
list: List,
public: Public,
bookmarks: Bookmarks,
favourites: Favourites,
hashtag: Hashtag,
2023-04-09 04:36:55 +03:00
mentions: Mentions,
2023-04-14 05:54:22 +03:00
trending: Trending,
2023-12-22 13:01:41 +03:00
search: Search,
}[type];
if (!Component) return null;
2023-12-22 13:01:41 +03:00
// Don't show Search column with no query, for now
if (type === 'search' && !params.query) return null;
// Don't show List column with no list, for now
if (type === 'list' && !params.id) return null;
return (
<Component key={type + JSON.stringify(params)} {...params} columnMode />
);
});
useHotkeys(['1', '2', '3', '4', '5', '6', '7', '8', '9'], (e, handler) => {
try {
const index = parseInt(handler.keys[0], 10) - 1;
document.querySelectorAll('#columns > *')[index].focus();
} catch (e) {
console.error(e);
}
});
return (
<div
id="columns"
onContextMenu={(e) => {
// If right-click on header, but not links or buttons
if (
e.target.closest('.deck > header') &&
!e.target.closest('a') &&
!e.target.closest('button')
) {
e.preventDefault();
states.showShortcutsSettings = true;
}
}}
>
{components}
</div>
);
}
export default Columns;