mirror of
https://github.com/khairul169/garage-webui.git
synced 2025-04-28 14:59:31 +07:00
59 lines
1.4 KiB
TypeScript
59 lines
1.4 KiB
TypeScript
import { useParams } from "react-router-dom";
|
|
import { useBucket } from "./hooks";
|
|
import Page from "@/context/page-context";
|
|
import TabView, { Tab } from "@/components/containers/tab-view";
|
|
import { ChartLine, FolderSearch, LockKeyhole } from "lucide-react";
|
|
import OverviewTab from "./overview/overview-tab";
|
|
import PermissionsTab from "./permissions/permissions-tab";
|
|
import MenuButton from "./components/menu-button";
|
|
import BrowseTab from "./browse/browse-tab";
|
|
import { BucketContext } from "./context";
|
|
|
|
const tabs: Tab[] = [
|
|
{
|
|
name: "overview",
|
|
title: "Overview",
|
|
icon: ChartLine,
|
|
Component: OverviewTab,
|
|
},
|
|
{
|
|
name: "permissions",
|
|
title: "Permissions",
|
|
icon: LockKeyhole,
|
|
Component: PermissionsTab,
|
|
},
|
|
{
|
|
name: "browse",
|
|
title: "Browse",
|
|
icon: FolderSearch,
|
|
Component: BrowseTab,
|
|
},
|
|
];
|
|
|
|
const ManageBucketPage = () => {
|
|
const { id } = useParams();
|
|
const { data, refetch } = useBucket(id);
|
|
|
|
const name = data?.globalAliases[0];
|
|
|
|
return (
|
|
<div className="container">
|
|
<Page
|
|
title={name || "Manage Bucket"}
|
|
prev="/buckets"
|
|
actions={data ? <MenuButton /> : undefined}
|
|
/>
|
|
|
|
{data && (
|
|
<BucketContext.Provider
|
|
value={{ bucket: data, refetch, bucketName: name || "" }}
|
|
>
|
|
<TabView tabs={tabs} className="bg-base-100 h-14 px-1.5" />
|
|
</BucketContext.Provider>
|
|
)}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default ManageBucketPage;
|