From 0979acc1a4b910323ff8b8729879336e7c0de551 Mon Sep 17 00:00:00 2001 From: Dakshesh Jain <65905942+dakshesh14@users.noreply.github.com> Date: Wed, 16 Aug 2023 13:09:56 +0530 Subject: [PATCH 1/4] fix: notification card not redirecting to archive issue detail for archived issue (#1861) --- apps/app/components/notifications/notification-card.tsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/apps/app/components/notifications/notification-card.tsx b/apps/app/components/notifications/notification-card.tsx index 9733a0f5b..1987c7155 100644 --- a/apps/app/components/notifications/notification-card.tsx +++ b/apps/app/components/notifications/notification-card.tsx @@ -53,7 +53,9 @@ export const NotificationCard: React.FC = (props) => { onClick={() => { markNotificationReadStatus(notification.id); router.push( - `/${workspaceSlug}/projects/${notification.project}/issues/${notification.data.issue.id}` + `/${workspaceSlug}/projects/${notification.project}/${ + notification.data.issue_activity.field === "archived_at" ? "archived-issues" : "issues" + }/${notification.data.issue.id}` ); }} className={`group w-full flex items-center gap-4 p-3 pl-6 relative cursor-pointer ${ From 2c43a155150335652716675c5ba0fd3df69b2b97 Mon Sep 17 00:00:00 2001 From: Bavisetti Narayan <72156168+NarayanBavisetti@users.noreply.github.com> Date: Wed, 16 Aug 2023 03:40:03 -0400 Subject: [PATCH 2/4] chore: added new filed in serializer (#1874) Co-authored-by: NarayanBavisetti --- apiserver/plane/api/serializers/project.py | 1 + 1 file changed, 1 insertion(+) diff --git a/apiserver/plane/api/serializers/project.py b/apiserver/plane/api/serializers/project.py index 18983c7be..1f7a973c1 100644 --- a/apiserver/plane/api/serializers/project.py +++ b/apiserver/plane/api/serializers/project.py @@ -88,6 +88,7 @@ class ProjectLiteSerializer(BaseSerializer): "cover_image", "icon_prop", "emoji", + "description", ] read_only_fields = fields From 1ded8f486facb0fae4f229e71a42f63050705d8a Mon Sep 17 00:00:00 2001 From: guru_sainath Date: Wed, 16 Aug 2023 13:15:57 +0530 Subject: [PATCH 3/4] chore: updated meta tags for project issues (#1875) * dev: updated meta tags for project issues * dev: updated project description in meta tags in plane deploy. --- .../[project_slug]/layout.tsx | 27 +++++++++++++++++-- apps/space/app/page.tsx | 2 +- apps/space/components/issues/navbar/index.tsx | 20 +++++++++++++- apps/space/package.json | 2 +- apps/space/store/types/project.ts | 1 + 5 files changed, 47 insertions(+), 5 deletions(-) diff --git a/apps/space/app/[workspace_slug]/[project_slug]/layout.tsx b/apps/space/app/[workspace_slug]/[project_slug]/layout.tsx index 8cc3ee8c8..fde4f5d99 100644 --- a/apps/space/app/[workspace_slug]/[project_slug]/layout.tsx +++ b/apps/space/app/[workspace_slug]/[project_slug]/layout.tsx @@ -1,11 +1,34 @@ -"use client"; - // next imports import Link from "next/link"; import Image from "next/image"; +import { Metadata, ResolvingMetadata } from "next"; // components import IssueNavbar from "components/issues/navbar"; import IssueFilter from "components/issues/filters-render"; +// service +import ProjectService from "services/project.service"; + +type LayoutProps = { + params: { workspace_slug: string; project_slug: string }; +}; + +export async function generateMetadata({ params }: LayoutProps): Promise { + // read route params + const { workspace_slug, project_slug } = params; + const projectServiceInstance = new ProjectService(); + + const project = await projectServiceInstance?.getProjectSettingsAsync(workspace_slug, project_slug); + + return { + title: `${project?.project_details?.name} | ${workspace_slug}`, + description: `${project?.project_details?.description || `${project?.project_details?.name} | ${workspace_slug}`}`, + icons: `data:image/svg+xml,${ + typeof project?.project_details?.emoji != "object" + ? String.fromCodePoint(parseInt(project?.project_details?.emoji)) + : "✈️" + }`, + }; +} const RootLayout = ({ children }: { children: React.ReactNode }) => (
diff --git a/apps/space/app/page.tsx b/apps/space/app/page.tsx index c1b2926b3..6a18b7283 100644 --- a/apps/space/app/page.tsx +++ b/apps/space/app/page.tsx @@ -3,7 +3,7 @@ import React from "react"; const HomePage = () => ( -
Plane Space
+
Plane Deploy
); export default HomePage; diff --git a/apps/space/components/issues/navbar/index.tsx b/apps/space/components/issues/navbar/index.tsx index 0207aaee2..71a2fabcc 100644 --- a/apps/space/components/issues/navbar/index.tsx +++ b/apps/space/components/issues/navbar/index.tsx @@ -1,5 +1,7 @@ "use client"; +// next imports +import Image from "next/image"; // components import { NavbarSearch } from "./search"; import { NavbarIssueBoardView } from "./issue-board-view"; @@ -12,6 +14,18 @@ import { observer } from "mobx-react-lite"; import { useMobxStore } from "lib/mobx/store-provider"; import { RootStore } from "store/root"; +const renderEmoji = (emoji: string | { name: string; color: string }) => { + if (!emoji) return; + + if (typeof emoji === "object") + return ( + + {emoji.name} + + ); + else return isNaN(parseInt(emoji)) ? emoji : String.fromCodePoint(parseInt(emoji)); +}; + const IssueNavbar = observer(() => { const store: RootStore = useMobxStore(); @@ -20,7 +34,11 @@ const IssueNavbar = observer(() => { {/* project detail */}
- {store?.project?.project && store?.project?.project?.icon ? store?.project?.project?.icon : "😊"} + {store?.project?.project && store?.project?.project?.emoji ? ( + renderEmoji(store?.project?.project?.emoji) + ) : ( + plane logo + )}
{store?.project?.project?.name || `...`} diff --git a/apps/space/package.json b/apps/space/package.json index 4af31d312..c2eaa8af1 100644 --- a/apps/space/package.json +++ b/apps/space/package.json @@ -1,5 +1,5 @@ { - "name": "plane-space", + "name": "plane-deploy", "version": "0.0.1", "private": true, "scripts": { diff --git a/apps/space/store/types/project.ts b/apps/space/store/types/project.ts index a55f30be0..41f4c2f44 100644 --- a/apps/space/store/types/project.ts +++ b/apps/space/store/types/project.ts @@ -8,6 +8,7 @@ export interface IProject { id: string; identifier: string; name: string; + description: string; icon: string; cover_image: string | null; icon_prop: string | null; From f44d142f2ccc56f634d0a95699c4f53d3070db02 Mon Sep 17 00:00:00 2001 From: guru_sainath Date: Wed, 16 Aug 2023 13:16:20 +0530 Subject: [PATCH 4/4] chore: tip-tap editor update in workspace user activity (#1877) --- .../[workspaceSlug]/me/profile/activity.tsx | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/apps/app/pages/[workspaceSlug]/me/profile/activity.tsx b/apps/app/pages/[workspaceSlug]/me/profile/activity.tsx index fcf30aca0..67f3a77ee 100644 --- a/apps/app/pages/[workspaceSlug]/me/profile/activity.tsx +++ b/apps/app/pages/[workspaceSlug]/me/profile/activity.tsx @@ -10,6 +10,7 @@ import { WorkspaceAuthorizationLayout } from "layouts/auth-layout"; import SettingsNavbar from "layouts/settings-navbar"; // components import { ActivityIcon, ActivityMessage } from "components/core"; +import Tiptap, { ITiptapRichTextEditor } from "components/tiptap"; // icons import { ArrowTopRightOnSquareIcon, ChatBubbleLeftEllipsisIcon } from "@heroicons/react/24/outline"; // ui @@ -104,14 +105,16 @@ const ProfileActivity = () => {

- {/* // TODO: Check these styles */} -