* chore: removed viewer role * chore: indentation * chore: remove viewer role * chore: handled user permissions in store * chore: updated the migration file * chore: updated user permissions store * chore: removed the owner key * chore: code refactor * chore: code refactor * chore: code refactor * chore: code refactor * chore: code refactor * fix: build error * chore: updated user permissions store and handled the permissions fetch in workspace and project wrappers * chore: package user enum updated * chore: user permission updated * chore: user permission updated * chore: resolved build errors * chore: resolved build error * chore: resolved build errors * chore: computedFn deep map issue resolved * chore: added back migration * chore: added new field in project table * chore: removed member store in users * chore: private project for admins * chore: workspace notification access validation updated * fix: workspace member edit option * fix: project intake permission validation updated * chore: workspace export settings permission updated * chore: guest_view_all_issues added * chore: guest_view_all_issues added * chore: key changed for guest access * chore: added validation for individual issues * chore: changed the dashboard issues count * chore: added new yarn file * chore: modified yarn file * chore: project page permission updated * chore: project page permission updated * chore: member setting ux updated * chore: build error * fix: yarn lock * fix: build error --------- Co-authored-by: gurusainath <gurusainath007@gmail.com> Co-authored-by: Anmol Singh Bhatia <anmolsinghbhatia@plane.so>
48 lines
1.7 KiB
TypeScript
48 lines
1.7 KiB
TypeScript
"use client";
|
|
|
|
import React from "react";
|
|
import { observer } from "mobx-react";
|
|
import Link from "next/link";
|
|
import { useParams, usePathname } from "next/navigation";
|
|
// components
|
|
import { SidebarNavItem } from "@/components/sidebar";
|
|
// hooks
|
|
import { useUserPermissions } from "@/hooks/store";
|
|
// plane web constants
|
|
import { EUserPermissionsLevel } from "@/plane-web/constants/user-permissions";
|
|
import { WORKSPACE_SETTINGS_LINKS } from "@/plane-web/constants/workspace";
|
|
// plane web helpers
|
|
import { shouldRenderSettingLink } from "@/plane-web/helpers/workspace.helper";
|
|
|
|
export const WorkspaceSettingsSidebar = observer(() => {
|
|
// router
|
|
const { workspaceSlug } = useParams();
|
|
const pathname = usePathname();
|
|
// mobx store
|
|
const { allowPermissions } = useUserPermissions();
|
|
|
|
return (
|
|
<div className="flex w-[280px] flex-col gap-6">
|
|
<div className="flex flex-col gap-2">
|
|
<span className="text-xs font-semibold text-custom-sidebar-text-400">SETTINGS</span>
|
|
<div className="flex w-full flex-col gap-1">
|
|
{WORKSPACE_SETTINGS_LINKS.map(
|
|
(link) =>
|
|
shouldRenderSettingLink(link.key) &&
|
|
allowPermissions(link.access, EUserPermissionsLevel.WORKSPACE, workspaceSlug.toString()) && (
|
|
<Link key={link.key} href={`/${workspaceSlug}${link.href}`}>
|
|
<SidebarNavItem
|
|
key={link.key}
|
|
isActive={link.highlight(pathname, `/${workspaceSlug}`)}
|
|
className="text-sm font-medium px-4 py-2"
|
|
>
|
|
{link.label}
|
|
</SidebarNavItem>
|
|
</Link>
|
|
)
|
|
)}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
});
|