mirror of
https://github.com/BrenBroZAYT/gameyfin.git
synced 2026-06-16 16:20:04 +00:00
Keep navigation state in LibraryManagementView
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
import {useNavigate, useParams} from "react-router";
|
import {useLocation, useNavigate, useParams} from "react-router";
|
||||||
import React, {useEffect} from "react";
|
import React, {useEffect} from "react";
|
||||||
import LibraryHeader from "Frontend/components/general/covers/LibraryHeader";
|
import LibraryHeader from "Frontend/components/general/covers/LibraryHeader";
|
||||||
import {Button, Tab, Tabs} from "@heroui/react";
|
import {Button, Tab, Tabs} from "@heroui/react";
|
||||||
@@ -12,6 +12,7 @@ import LibraryManagementUnmatchedPaths from "Frontend/components/general/library
|
|||||||
|
|
||||||
export default function LibraryManagementView() {
|
export default function LibraryManagementView() {
|
||||||
const {libraryId} = useParams();
|
const {libraryId} = useParams();
|
||||||
|
const {hash} = useLocation();
|
||||||
const navigate = useNavigate();
|
const navigate = useNavigate();
|
||||||
const state = useSnapshot(libraryState);
|
const state = useSnapshot(libraryState);
|
||||||
|
|
||||||
@@ -32,16 +33,19 @@ export default function LibraryManagementView() {
|
|||||||
</div>
|
</div>
|
||||||
{/* @ts-ignore */}
|
{/* @ts-ignore */}
|
||||||
<LibraryHeader library={state.state[libraryId]} className="h-32"/>
|
<LibraryHeader library={state.state[libraryId]} className="h-32"/>
|
||||||
<Tabs color="primary" fullWidth>
|
{/* @ts-ignore */}
|
||||||
<Tab title="Details">
|
<Tabs color="primary" fullWidth
|
||||||
|
selectedKey={hash.length > 0 ? hash : "#details"}
|
||||||
|
onSelectionChange={(newKey) => navigate(newKey.toString(), {replace: true})}>
|
||||||
|
<Tab key="#details" title="Details">
|
||||||
{/* @ts-ignore */}
|
{/* @ts-ignore */}
|
||||||
<LibraryManagementDetails library={state.state[libraryId]}/>
|
<LibraryManagementDetails library={state.state[libraryId]}/>
|
||||||
</Tab>
|
</Tab>
|
||||||
<Tab title="Games">
|
<Tab key="#games" title="Games">
|
||||||
{/* @ts-ignore */}
|
{/* @ts-ignore */}
|
||||||
<LibraryManagementGames library={state.state[libraryId]}/>
|
<LibraryManagementGames library={state.state[libraryId]}/>
|
||||||
</Tab>
|
</Tab>
|
||||||
<Tab title="Unmatched paths">
|
<Tab key="#unmatched-paths" title="Unmatched paths">
|
||||||
{/* @ts-ignore */}
|
{/* @ts-ignore */}
|
||||||
<LibraryManagementUnmatchedPaths library={state.state[libraryId]}/>
|
<LibraryManagementUnmatchedPaths library={state.state[libraryId]}/>
|
||||||
</Tab>
|
</Tab>
|
||||||
|
|||||||
Reference in New Issue
Block a user