mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
fix: auth screens (#2054)
This commit is contained in:
parent
441e83eba6
commit
54d781ef91
@ -1,12 +1,17 @@
|
|||||||
import { useEffect } from "react";
|
import { useEffect } from "react";
|
||||||
|
|
||||||
|
import Link from "next/link";
|
||||||
import Image from "next/image";
|
import Image from "next/image";
|
||||||
import { observer } from "mobx-react-lite";
|
|
||||||
import { useRouter } from "next/router";
|
import { useRouter } from "next/router";
|
||||||
|
|
||||||
|
// mobx
|
||||||
|
import { observer } from "mobx-react-lite";
|
||||||
// components
|
// components
|
||||||
import { NavbarSearch } from "./search";
|
import { NavbarSearch } from "./search";
|
||||||
import { NavbarIssueBoardView } from "./issue-board-view";
|
import { NavbarIssueBoardView } from "./issue-board-view";
|
||||||
import { NavbarIssueFilter } from "./issue-filter";
|
|
||||||
import { NavbarTheme } from "./theme";
|
import { NavbarTheme } from "./theme";
|
||||||
|
// ui
|
||||||
|
import { PrimaryButton } from "components/ui";
|
||||||
// lib
|
// lib
|
||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
// store
|
// store
|
||||||
@ -25,11 +30,13 @@ const renderEmoji = (emoji: string | { name: string; color: string }) => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const IssueNavbar = observer(() => {
|
const IssueNavbar = observer(() => {
|
||||||
const { project: projectStore }: RootStore = useMobxStore();
|
const { project: projectStore, user: userStore }: RootStore = useMobxStore();
|
||||||
// router
|
// router
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const { workspace_slug, project_slug, board } = router.query;
|
const { workspace_slug, project_slug, board } = router.query;
|
||||||
|
|
||||||
|
const user = userStore?.currentUser;
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (workspace_slug && project_slug) {
|
if (workspace_slug && project_slug) {
|
||||||
projectStore.fetchProjectSettings(workspace_slug.toString(), project_slug.toString());
|
projectStore.fetchProjectSettings(workspace_slug.toString(), project_slug.toString());
|
||||||
@ -77,6 +84,32 @@ const IssueNavbar = observer(() => {
|
|||||||
<div className="flex-shrink-0 relative">
|
<div className="flex-shrink-0 relative">
|
||||||
<NavbarTheme />
|
<NavbarTheme />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{user ? (
|
||||||
|
<div className="border border-custom-border-200 rounded flex items-center gap-2 p-2">
|
||||||
|
{user.avatar && user.avatar !== "" ? (
|
||||||
|
<div className="h-5 w-5 rounded-full">
|
||||||
|
{/* eslint-disable-next-line @next/next/no-img-element */}
|
||||||
|
<img src={user.avatar} alt={user.display_name ?? ""} className="rounded-full" />
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<div className="bg-custom-background-80 h-5 w-5 rounded-full grid place-items-center text-[10px] capitalize">
|
||||||
|
{(user.display_name ?? "A")[0]}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
<h6 className="text-xs font-medium">{user.display_name}</h6>
|
||||||
|
</div>
|
||||||
|
) : (
|
||||||
|
<div className="flex-shrink-0">
|
||||||
|
<Link href={`/?next_path=${router.asPath}`}>
|
||||||
|
<a>
|
||||||
|
<PrimaryButton className="flex-shrink-0" outline>
|
||||||
|
Sign in
|
||||||
|
</PrimaryButton>
|
||||||
|
</a>
|
||||||
|
</Link>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@ -1,10 +1,16 @@
|
|||||||
import React, { useEffect } from "react";
|
import React from "react";
|
||||||
|
|
||||||
|
import Link from "next/link";
|
||||||
import { useRouter } from "next/router";
|
import { useRouter } from "next/router";
|
||||||
|
|
||||||
|
// mobx
|
||||||
import { observer } from "mobx-react-lite";
|
import { observer } from "mobx-react-lite";
|
||||||
// lib
|
// lib
|
||||||
import { useMobxStore } from "lib/mobx/store-provider";
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||||||
// components
|
// components
|
||||||
import { CommentCard, AddComment } from "components/issues/peek-overview";
|
import { CommentCard, AddComment } from "components/issues/peek-overview";
|
||||||
|
// ui
|
||||||
|
import { Icon, PrimaryButton } from "components/ui";
|
||||||
// types
|
// types
|
||||||
import { IIssue } from "types/issue";
|
import { IIssue } from "types/issue";
|
||||||
|
|
||||||
@ -20,10 +26,10 @@ export const PeekOverviewIssueActivity: React.FC<Props> = observer((props) => {
|
|||||||
|
|
||||||
const comments = issueDetailStore.details[issueDetailStore.peekId || ""]?.comments || [];
|
const comments = issueDetailStore.details[issueDetailStore.peekId || ""]?.comments || [];
|
||||||
|
|
||||||
console.log("issueDetailStore", issueDetailStore);
|
const user = userStore?.currentUser;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div>
|
<div className="pb-10">
|
||||||
<h4 className="font-medium">Activity</h4>
|
<h4 className="font-medium">Activity</h4>
|
||||||
{workspace_slug && (
|
{workspace_slug && (
|
||||||
<div className="mt-4">
|
<div className="mt-4">
|
||||||
@ -32,9 +38,25 @@ export const PeekOverviewIssueActivity: React.FC<Props> = observer((props) => {
|
|||||||
<CommentCard key={comment.id} comment={comment} workspaceSlug={workspace_slug?.toString()} />
|
<CommentCard key={comment.id} comment={comment} workspaceSlug={workspace_slug?.toString()} />
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
{projectStore.deploySettings?.comments && (
|
{user ? (
|
||||||
<div className="mt-4">
|
<>
|
||||||
<AddComment disabled={!userStore.currentUser} />
|
{projectStore.deploySettings?.comments && (
|
||||||
|
<div className="mt-4">
|
||||||
|
<AddComment disabled={!userStore.currentUser} />
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
) : (
|
||||||
|
<div className="bg-custom-background-80 px-2 py-2.5 flex items-center justify-between gap-2 border border-custom-border-300 rounded">
|
||||||
|
<p className="flex gap-2 text-sm text-custom-text-200 break-words overflow-hidden">
|
||||||
|
<Icon iconName="lock" className="!text-sm" />
|
||||||
|
Sign in to add your comment
|
||||||
|
</p>
|
||||||
|
<Link href={`/?next_path=${router.asPath}`}>
|
||||||
|
<a>
|
||||||
|
<PrimaryButton className="flex-shrink-0 !px-7">Sign in</PrimaryButton>
|
||||||
|
</a>
|
||||||
|
</Link>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
|
@ -17,7 +17,7 @@ const HomePage = () => {
|
|||||||
const { user: userStore } = useMobxStore();
|
const { user: userStore } = useMobxStore();
|
||||||
|
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const { next_path = "/" } = router.query;
|
const { next_path } = router.query;
|
||||||
|
|
||||||
const { setToastAlert } = useToast();
|
const { setToastAlert } = useToast();
|
||||||
|
|
||||||
@ -38,7 +38,7 @@ const HomePage = () => {
|
|||||||
router.push(`/onboarding?next_path=${next_path}`);
|
router.push(`/onboarding?next_path=${next_path}`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
router.push(next_path.toString());
|
router.push((next_path ?? "/").toString());
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleGoogleSignIn = async ({ clientId, credential }: any) => {
|
const handleGoogleSignIn = async ({ clientId, credential }: any) => {
|
||||||
|
@ -28,8 +28,9 @@ class UserStore implements IUserStore {
|
|||||||
}
|
}
|
||||||
|
|
||||||
setCurrentUser = (user: any) => {
|
setCurrentUser = (user: any) => {
|
||||||
// TODO: destructure user object
|
runInAction(() => {
|
||||||
this.currentUser = user;
|
this.currentUser = { ...user };
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user