diff --git a/web/components/headers/project-settings.tsx b/web/components/headers/project-settings.tsx index 3dfb9da07..bf2dc374d 100644 --- a/web/components/headers/project-settings.tsx +++ b/web/components/headers/project-settings.tsx @@ -8,6 +8,8 @@ import { renderEmoji } from "helpers/emoji.helper"; // hooks import { useMobxStore } from "lib/mobx/store-provider"; import { observer } from "mobx-react-lite"; +// constants +import { EUserWorkspaceRoles } from "constants/workspace"; export interface IProjectSettingHeader { title: string; @@ -18,9 +20,14 @@ export const ProjectSettingHeader: FC = observer((props) const router = useRouter(); const { workspaceSlug } = router.query; // store - const { project: projectStore } = useMobxStore(); + const { + project: projectStore, + user: { currentProjectRole }, + } = useMobxStore(); const { currentProjectDetails } = projectStore; + if (currentProjectRole && currentProjectRole <= EUserWorkspaceRoles.VIEWER) return null; + return (
diff --git a/web/components/issues/sidebar-select/label.tsx b/web/components/issues/sidebar-select/label.tsx index 43dfeefd9..4d9459a31 100644 --- a/web/components/issues/sidebar-select/label.tsx +++ b/web/components/issues/sidebar-select/label.tsx @@ -89,7 +89,7 @@ export const SidebarLabelSelect: React.FC = observer((props) => { if (label) return ( - { @@ -98,6 +98,7 @@ export const SidebarLabelSelect: React.FC = observer((props) => { labels: updatedLabels, }); }} + disabled={uneditable} > = observer((props) => { /> {label.name} - + ); })} = observer((props) => { type="button" className="grid place-items-center rounded bg-red-500 p-2.5" onClick={() => setCreateLabelForm(false)} + disabled={uneditable} > diff --git a/web/components/modules/sidebar.tsx b/web/components/modules/sidebar.tsx index a257f5e1e..b2685ca2c 100644 --- a/web/components/modules/sidebar.tsx +++ b/web/components/modules/sidebar.tsx @@ -226,7 +226,6 @@ export const ModuleDetailsSidebar: React.FC = observer((props) => { : null; const handleEditLink = (link: ILinkDetails) => { - console.log("link", link); setSelectedLinkToUpdate(link); setModuleLinkModal(true); }; diff --git a/web/components/ui/datepicker.tsx b/web/components/ui/datepicker.tsx index d8ebc143a..3e3c08296 100644 --- a/web/components/ui/datepicker.tsx +++ b/web/components/ui/datepicker.tsx @@ -61,7 +61,7 @@ export const CustomDatePicker: React.FC = ({ noBorder ? "" : "border border-custom-border-200" } w-full rounded-md caret-transparent outline-none ${className}`} dateFormat="MMM dd, yyyy" - isClearable={isClearable} + isClearable={Boolean(isClearable && !disabled)} disabled={disabled} maxDate={maxDate} minDate={minDate} diff --git a/web/layouts/settings-layout/project/layout.tsx b/web/layouts/settings-layout/project/layout.tsx index d823cbe70..7762469a7 100644 --- a/web/layouts/settings-layout/project/layout.tsx +++ b/web/layouts/settings-layout/project/layout.tsx @@ -1,10 +1,12 @@ import { FC, ReactNode } from "react"; +import { useRouter } from "next/router"; // components import { ProjectSettingsSidebar } from "./sidebar"; import { useMobxStore } from "lib/mobx/store-provider"; import { EUserWorkspaceRoles } from "constants/workspace"; import { NotAuthorizedView } from "components/auth-screens"; import { observer } from "mobx-react-lite"; +import { Button, LayersIcon } from "@plane/ui"; export interface IProjectSettingLayout { children: ReactNode; @@ -13,6 +15,9 @@ export interface IProjectSettingLayout { export const ProjectSettingLayout: FC = observer((props) => { const { children } = props; + const router = useRouter(); + const { workspaceSlug, projectId } = router.query; + const { user: { currentProjectRole }, } = useMobxStore(); @@ -20,7 +25,19 @@ export const ProjectSettingLayout: FC = observer((props) const restrictViewSettings = currentProjectRole && currentProjectRole <= EUserWorkspaceRoles.VIEWER; return restrictViewSettings ? ( - + } + onClick={() => router.push(`/${workspaceSlug}/projects/${projectId}/issues`)} + > + Go to issues + + } + /> ) : (