59 lines
1.4 KiB
TypeScript
Raw Normal View History

2024-08-16 01:23:55 +07:00
import { useParams } from "react-router-dom";
import { useBucket } from "./hooks";
import Page from "@/context/page-context";
import TabView, { Tab } from "@/components/containers/tab-view";
2024-08-18 22:57:08 +07:00
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";
2024-08-18 22:57:08 +07:00
import BrowseTab from "./browse/browse-tab";
2024-08-19 02:28:25 +07:00
import { BucketContext } from "./context";
2024-08-16 01:23:55 +07:00
const tabs: Tab[] = [
{
name: "overview",
title: "Overview",
icon: ChartLine,
Component: OverviewTab,
},
{
name: "permissions",
title: "Permissions",
icon: LockKeyhole,
Component: PermissionsTab,
},
2024-08-18 22:57:08 +07:00
{
name: "browse",
title: "Browse",
icon: FolderSearch,
Component: BrowseTab,
},
2024-08-16 01:23:55 +07:00
];
const ManageBucketPage = () => {
const { id } = useParams();
2024-08-19 02:28:25 +07:00
const { data, refetch } = useBucket(id);
2024-08-16 01:23:55 +07:00
const name = data?.globalAliases[0];
return (
<div className="container">
<Page
title={name || "Manage Bucket"}
prev="/buckets"
2024-08-19 02:28:25 +07:00
actions={data ? <MenuButton /> : undefined}
/>
2024-08-19 02:28:25 +07:00
{data && (
<BucketContext.Provider
value={{ bucket: data, refetch, bucketName: name || "" }}
>
<TabView tabs={tabs} className="bg-base-100 h-14 px-1.5" />
</BucketContext.Provider>
)}
2024-08-16 01:23:55 +07:00
</div>
);
};
export default ManageBucketPage;