2024-01-24 15:03:54 +00:00
|
|
|
import { FC } from "react";
|
|
|
|
import { Inbox } from "lucide-react";
|
2024-01-25 08:11:02 +00:00
|
|
|
import { observer } from "mobx-react";
|
|
|
|
// hooks
|
|
|
|
import { useInboxIssues } from "hooks/store";
|
|
|
|
// ui
|
|
|
|
import { Loader } from "@plane/ui";
|
2024-01-24 15:03:54 +00:00
|
|
|
// components
|
|
|
|
import { InboxIssueList, InboxIssueFilterSelection, InboxIssueAppliedFilter } from "../";
|
|
|
|
|
|
|
|
type TInboxSidebarRoot = {
|
|
|
|
workspaceSlug: string;
|
|
|
|
projectId: string;
|
|
|
|
inboxId: string;
|
|
|
|
};
|
|
|
|
|
2024-01-25 08:11:02 +00:00
|
|
|
export const InboxSidebarRoot: FC<TInboxSidebarRoot> = observer((props) => {
|
2024-01-24 15:03:54 +00:00
|
|
|
const { workspaceSlug, projectId, inboxId } = props;
|
2024-01-25 08:11:02 +00:00
|
|
|
// store hooks
|
|
|
|
const {
|
|
|
|
issues: { loader },
|
|
|
|
} = useInboxIssues();
|
2024-01-24 15:03:54 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="relative flex flex-col w-full h-full">
|
2024-01-25 08:11:02 +00:00
|
|
|
<div className="flex-shrink-0 w-full h-[50px] relative flex justify-between items-center gap-2 p-2 px-3 border-b border-custom-border-300">
|
2024-01-24 15:03:54 +00:00
|
|
|
<div className="relative flex items-center gap-1">
|
|
|
|
<div className="relative w-6 h-6 flex justify-center items-center rounded bg-custom-background-80">
|
|
|
|
<Inbox className="w-4 h-4" />
|
|
|
|
</div>
|
|
|
|
<div className="font-medium">Inbox</div>
|
|
|
|
</div>
|
2024-01-25 08:11:02 +00:00
|
|
|
<div className="z-20">
|
2024-01-24 15:03:54 +00:00
|
|
|
<InboxIssueFilterSelection workspaceSlug={workspaceSlug} projectId={projectId} inboxId={inboxId} />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className="w-full h-auto">
|
|
|
|
<InboxIssueAppliedFilter workspaceSlug={workspaceSlug} projectId={projectId} inboxId={inboxId} />
|
|
|
|
</div>
|
|
|
|
|
2024-01-25 08:11:02 +00:00
|
|
|
{loader && ["init-loader", "mutation"].includes(loader) ? (
|
|
|
|
<Loader className="flex flex-col h-full gap-5 p-5">
|
|
|
|
<Loader.Item height="30px" />
|
|
|
|
<Loader.Item height="30px" />
|
|
|
|
<Loader.Item height="30px" />
|
|
|
|
<Loader.Item height="30px" />
|
|
|
|
</Loader>
|
|
|
|
) : (
|
|
|
|
<div className="w-full h-full overflow-hidden">
|
|
|
|
<InboxIssueList workspaceSlug={workspaceSlug} projectId={projectId} inboxId={inboxId} />
|
|
|
|
</div>
|
|
|
|
)}
|
2024-01-24 15:03:54 +00:00
|
|
|
</div>
|
|
|
|
);
|
2024-01-25 08:11:02 +00:00
|
|
|
});
|