-
+
diff --git a/web/components/headers/modules.tsx b/web/components/headers/modules.tsx
index ef9fc670a31..2bd83f73a36 100644
--- a/web/components/headers/modules.tsx
+++ b/web/components/headers/modules.tsx
@@ -1,10 +1,10 @@
import { Dispatch, FC, SetStateAction } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import { ArrowLeft, Plus } from "lucide-react";
// components
-import { Breadcrumbs, BreadcrumbItem } from "components/breadcrumbs";
// ui
-import { Button, Tooltip } from "@plane/ui";
+import { Breadcrumbs, BreadcrumbItem, Button, Tooltip } from "@plane/ui";
import { Icon } from "components/ui";
// helper
import { replaceUnderscoreIfSnakeCase, truncateText } from "helpers/string.helper";
@@ -34,9 +34,9 @@ export const ModulesHeader: FC
= (props) => {
return (
-
+
@@ -62,7 +70,7 @@ export const ModulesHeader: FC
= (props) => {
>
-
+ router.back()}>
diff --git a/web/components/headers/project-issues.tsx b/web/components/headers/project-issues.tsx
index 2cf5ad93fc9..910e18a523d 100644
--- a/web/components/headers/project-issues.tsx
+++ b/web/components/headers/project-issues.tsx
@@ -9,8 +9,7 @@ import { useMobxStore } from "lib/mobx/store-provider";
import { DisplayFiltersSelection, FiltersDropdown, FilterSelection, LayoutSelection } from "components/issues";
import { ProjectAnalyticsModal } from "components/analytics";
// ui
-import { Button } from "@plane/ui";
-import { Breadcrumbs, BreadcrumbItem } from "components/breadcrumbs";
+import { Breadcrumbs, BreadcrumbItem, Button } from "@plane/ui";
// types
import { IIssueDisplayFilterOptions, IIssueDisplayProperties, IIssueFilterOptions, TIssueLayouts } from "types";
// constants
@@ -115,8 +114,16 @@ export const ProjectIssuesHeader: FC = observer(() => {
diff --git a/web/components/headers/project-views.tsx b/web/components/headers/project-views.tsx
index dc6f53d7088..003de9f9f3c 100644
--- a/web/components/headers/project-views.tsx
+++ b/web/components/headers/project-views.tsx
@@ -1,11 +1,11 @@
import { FC, useState } from "react";
import { useRouter } from "next/router";
// icons
-import { ArrowLeft, Plus } from "lucide-react";
+import { ArrowLeft, Link, Plus } from "lucide-react";
// components
import { CreateUpdateProjectViewModal } from "components/views";
// components
-import { Breadcrumbs, BreadcrumbItem } from "components/breadcrumbs";
+import { Breadcrumbs, BreadcrumbItem } from "@plane/ui";
// ui
import { PrimaryButton } from "components/ui";
// helpers
@@ -40,8 +40,16 @@ export const ProjectViewsHeader: FC = (props) => {
diff --git a/web/components/headers/projects.tsx b/web/components/headers/projects.tsx
index b8f1f9636d2..616352e18a0 100644
--- a/web/components/headers/projects.tsx
+++ b/web/components/headers/projects.tsx
@@ -1,8 +1,7 @@
import { useRouter } from "next/router";
import { ArrowLeft, Search, Plus } from "lucide-react";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
-import { Button } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Button } from "@plane/ui";
// helper
import { truncateText } from "helpers/string.helper";
// hooks
@@ -30,7 +29,7 @@ export const ProjectsHeader = observer(() => {
-
+ router.back()}>
{
const router = useRouter();
@@ -22,7 +22,7 @@ export const WorkspaceAnalyticsHeader = () => {
-
+ router.back()}>
diff --git a/web/layouts/profile-layout.tsx b/web/layouts/profile-layout.tsx
index b0be984958c..e7ee873a578 100644
--- a/web/layouts/profile-layout.tsx
+++ b/web/layouts/profile-layout.tsx
@@ -1,3 +1,4 @@
+import { useRouter } from "next/router";
// hooks
import { useWorkspaceMyMembership } from "contexts/workspace-member.context";
// layouts
@@ -5,24 +6,27 @@ import { WorkspaceAuthorizationLayout } from "layouts/auth-layout-legacy";
// components
import { ProfileNavbar, ProfileSidebar } from "components/profile";
// ui
-import { Breadcrumbs, BreadcrumbItem } from "components/breadcrumbs";
+import { Breadcrumbs, BreadcrumbItem } from "@plane/ui";
type Props = {
children: React.ReactNode;
className?: string;
};
-export const ProfileAuthWrapper = (props: Props) => (
-
-
-
- }
- >
-
-
-);
+export const ProfileAuthWrapper = (props: Props) => {
+ const router = useRouter();
+ return (
+
router.back()}>
+
+
+ }
+ >
+
+
+ );
+};
const ProfileLayout: React.FC
= ({ children, className }) => {
const { memberRole } = useWorkspaceMyMembership();
diff --git a/web/pages/[workspaceSlug]/me/my-issues.tsx b/web/pages/[workspaceSlug]/me/my-issues.tsx
index afd2cd654e9..09036471f5c 100644
--- a/web/pages/[workspaceSlug]/me/my-issues.tsx
+++ b/web/pages/[workspaceSlug]/me/my-issues.tsx
@@ -11,8 +11,7 @@ import useMyIssuesFilters from "hooks/my-issues/use-my-issues-filter";
// components
import { MyIssuesView, MyIssuesViewOptions } from "components/issues";
// ui
-import { Button } from "@plane/ui";
-import { Breadcrumbs, BreadcrumbItem } from "components/breadcrumbs";
+import { Breadcrumbs, BreadcrumbItem, Button } from "@plane/ui";
// types
import type { NextPage } from "next";
import useUser from "hooks/use-user";
@@ -78,7 +77,7 @@ const MyIssuesPage: NextPage = () => {
return (
+ router.back()}>
}
diff --git a/web/pages/[workspaceSlug]/me/profile/activity.tsx b/web/pages/[workspaceSlug]/me/profile/activity.tsx
index 3b70b30b71d..9d58e7bc9c0 100644
--- a/web/pages/[workspaceSlug]/me/profile/activity.tsx
+++ b/web/pages/[workspaceSlug]/me/profile/activity.tsx
@@ -11,8 +11,7 @@ import { RichReadOnlyEditor } from "@plane/rich-text-editor";
// icons
import { History, MessageSquare } from "lucide-react";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
-import { ExternalLinkIcon, Loader } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, ExternalLinkIcon, Loader } from "@plane/ui";
// fetch-keys
import { USER_ACTIVITY } from "constants/fetch-keys";
// helper
@@ -33,7 +32,7 @@ const ProfileActivity = () => {
return (
+ router.back()}>
}
diff --git a/web/pages/[workspaceSlug]/me/profile/index.tsx b/web/pages/[workspaceSlug]/me/profile/index.tsx
index c9456900cff..d4dbc4c538b 100644
--- a/web/pages/[workspaceSlug]/me/profile/index.tsx
+++ b/web/pages/[workspaceSlug]/me/profile/index.tsx
@@ -14,9 +14,8 @@ import { WorkspaceAuthorizationLayout } from "layouts/auth-layout-legacy";
import { ImagePickerPopover, ImageUploadModal } from "components/core";
import { SettingsSidebar } from "components/project";
// ui
-import { Button, Input, Spinner } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Button, Input, Spinner } from "@plane/ui";
import { CustomSearchSelect, CustomSelect } from "components/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
// icons
import { User2, UserCircle2 } from "lucide-react";
// types
@@ -147,7 +146,7 @@ const Profile: NextPage = () => {
return (
+ router.back()}>
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/archived-issues/[archivedIssueId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/archived-issues/[archivedIssueId].tsx
index 33792f8ba59..a0cca15b1a2 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/archived-issues/[archivedIssueId].tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/archived-issues/[archivedIssueId].tsx
@@ -1,6 +1,7 @@
import React, { useCallback, useEffect, useState } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR, { mutate } from "swr";
@@ -16,8 +17,7 @@ import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy";
// components
import { IssueDetailsSidebar, IssueMainContent } from "components/issues";
// ui
-import { Breadcrumbs } from "components/breadcrumbs";
-import { ArchiveIcon, Loader } from "@plane/ui";
+import { ArchiveIcon, Breadcrumbs, Loader } from "@plane/ui";
// icons
import { History } from "lucide-react";
// types
@@ -145,11 +145,18 @@ const ArchivedIssueDetailsPage: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(
+ issueDetails?.project_detail.name ?? "Project",
+ 32
+ )} Issues`}
+
+
+ }
/>
{
-
+ router.back()}>
+
+
+ Projects
+
+
+ }
+ />
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx
index a66b13d0b09..b1879d25501 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx
@@ -1,8 +1,8 @@
import React, { useState } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
// icons
-import { ContrastIcon } from "@plane/ui";
import { ArrowLeft } from "lucide-react";
// layouts
import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy";
@@ -19,9 +19,9 @@ import { CycleService } from "services/cycle.service";
import useToast from "hooks/use-toast";
import useUserAuth from "hooks/use-user-auth";
// ui
+import { BreadcrumbItem, Breadcrumbs, ContrastIcon } from "@plane/ui";
import { CustomMenu } from "components/ui";
import { EmptyState } from "components/common";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
// images
import emptyCycle from "public/empty-state/cycle.svg";
// helpers
@@ -97,11 +97,18 @@ const SingleCycle: React.FC = () => {
/>
- router.back()}>
+
+
+ {`${truncateText(
+ cycleDetails?.project_detail.name ?? "Project",
+ 32
+ )} Cycles`}
+
+
+ }
/>
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/draft-issues/index.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/draft-issues/index.tsx
index d2b073a329c..2645cf66671 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/draft-issues/index.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/draft-issues/index.tsx
@@ -1,4 +1,5 @@
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -13,7 +14,7 @@ import { truncateText } from "helpers/string.helper";
// components
import { IssuesFilterView, IssuesView } from "components/core";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs } from "@plane/ui";
// icons
import { X, PenSquare } from "lucide-react";
// types
@@ -37,8 +38,16 @@ const ProjectDraftIssues: NextPage = () => {
-
+ router.back()}>
+
+
+ Projects
+
+
+ }
+ />
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/inbox/[inboxId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/inbox/[inboxId].tsx
index 96652b159e5..f08837e8c29 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/inbox/[inboxId].tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/inbox/[inboxId].tsx
@@ -1,4 +1,6 @@
import { useRouter } from "next/router";
+import Link from "next/link";
+
import { NextPage } from "next";
import useSWR from "swr";
// hooks
@@ -11,7 +13,7 @@ import { ProjectInboxHeader } from "components/headers";
// helper
import { truncateText } from "helpers/string.helper";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs } from "@plane/ui";
const ProjectInbox: NextPage = () => {
const router = useRouter();
@@ -37,8 +39,16 @@ const ProjectInbox: NextPage = () => {
return (
-
+ router.back()}>
+
+
+ Projects
+
+
+ }
+ />
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx
index 158201aa890..f7d9d9ed8af 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx
@@ -1,6 +1,7 @@
import React, { useCallback, useEffect } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR, { mutate } from "swr";
@@ -16,8 +17,7 @@ import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy";
import { IssueDetailsSidebar, IssueMainContent } from "components/issues";
// ui
import { EmptyState } from "components/common";
-import { Breadcrumbs } from "components/breadcrumbs";
-import { Loader } from "@plane/ui";
+import { Breadcrumbs, Loader } from "@plane/ui";
// images
import emptyIssue from "public/empty-state/issue.svg";
// types
@@ -120,11 +120,18 @@ const IssueDetailsPage: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(
+ issueDetails?.project_detail.name ?? "Project",
+ 32
+ )} Issues`}
+
+
+ }
/>
{
/>
+ router.back()}>
+
+ {`${truncateText(
+ moduleDetails?.project_detail.name ?? "Project",
+ 32
+ )} Modules`}
+
+
+ }
/>
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/pages/[pageId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/pages/[pageId].tsx
index 2a1f4422f12..2e8402d844c 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/pages/[pageId].tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/pages/[pageId].tsx
@@ -1,4 +1,5 @@
import React, { useEffect, useRef, useState } from "react";
+import Link from "next/link";
import { useRouter } from "next/router";
@@ -27,10 +28,9 @@ import { CreateUpdateBlockInline, SinglePageBlock } from "components/pages";
import { CreateLabelModal } from "components/labels";
import { CreateBlock } from "components/pages/create-block";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
import { CustomSearchSelect } from "components/ui";
import { EmptyState } from "components/common";
-import { TextArea, Loader, ToggleSwitch, Tooltip } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, TextArea, Loader, ToggleSwitch, Tooltip } from "@plane/ui";
// images
import emptyPage from "public/empty-state/page.svg";
// icons
@@ -306,8 +306,16 @@ const SinglePage: NextPage = () => {
return (
-
+ router.back()}>
+
+
+ Projects
+
+
+ }
+ />
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/pages/index.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/pages/index.tsx
index cd627a44214..c62042493fe 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/pages/index.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/pages/index.tsx
@@ -1,4 +1,5 @@
import { useState, Fragment } from "react";
+import Link from "next/link";
import { useRouter } from "next/router";
import dynamic from "next/dynamic";
@@ -19,8 +20,7 @@ import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy";
// components
import { RecentPagesList, CreateUpdatePageModal, TPagesListProps } from "components/pages";
// ui
-import { Button } from "@plane/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs, Button } from "@plane/ui";
// types
import { TPageViewProps } from "types";
import type { NextPage } from "next";
@@ -94,8 +94,16 @@ const ProjectPages: NextPage = () => {
/>
-
+ router.back()}>
+
+
+ Projects
+
+
+ }
+ />
}
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/automations.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/automations.tsx
index afa2c088e50..74df52f6a27 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/automations.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/automations.tsx
@@ -1,6 +1,7 @@
import React from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR, { mutate } from "swr";
@@ -16,7 +17,7 @@ import useToast from "hooks/use-toast";
import { AutoArchiveAutomation, AutoCloseAutomation } from "components/automation";
import { SettingsSidebar } from "components/project";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs } from "@plane/ui";
// types
import type { NextPage } from "next";
import { IProject } from "types";
@@ -76,11 +77,15 @@ const AutomationsSettings: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/estimates.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/estimates.tsx
index 255d5a139d9..997cbf719f7 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/estimates.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/estimates.tsx
@@ -1,5 +1,6 @@
import React, { useState } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR, { mutate } from "swr";
// services
import { ProjectService, ProjectEstimateService } from "services/project";
@@ -14,9 +15,8 @@ import { SettingsSidebar } from "components/project";
import useToast from "hooks/use-toast";
import useUserAuth from "hooks/use-user-auth";
// ui
-import { Button, Loader } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Button, Loader } from "@plane/ui";
import { EmptyState } from "components/common";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
// icons
import { Plus } from "lucide-react";
// images
@@ -112,11 +112,15 @@ const EstimatesSettings: NextPage = () => {
/>
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/features.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/features.tsx
index fba5dd3abc1..1dc80ac852b 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/features.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/features.tsx
@@ -1,5 +1,7 @@
import React from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
+
import useSWR, { mutate } from "swr";
// services
import { ProjectService } from "services/project";
@@ -12,8 +14,7 @@ import useUserAuth from "hooks/use-user-auth";
// components
import { SettingsSidebar } from "components/project";
// ui
-import { ContrastIcon, DiceIcon, ToggleSwitch } from "@plane/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs, ContrastIcon, DiceIcon, ToggleSwitch } from "@plane/ui";
// icons
import { FileText, Inbox, Layers } from "lucide-react";
// types
@@ -140,11 +141,15 @@ const FeaturesSettings: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/index.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/index.tsx
index 178f5bceafe..e85a66c8536 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/index.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/index.tsx
@@ -1,5 +1,7 @@
import { useState } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
+
import useSWR from "swr";
import { Disclosure, Transition } from "@headlessui/react";
// layouts
@@ -8,8 +10,7 @@ import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy";
import { ProjectService } from "services/project";
// components
import { DeleteProjectModal, ProjectDetailsForm, ProjectDetailsFormLoader, SettingsSidebar } from "components/project";
-import { Button, Loader } from "@plane/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs, Button, Loader } from "@plane/ui";
import { ChevronDown, ChevronUp } from "lucide-react";
// helpers
import { truncateText } from "helpers/string.helper";
@@ -58,11 +59,15 @@ const GeneralSettings: NextPage = observer(() => {
return (
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/integrations.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/integrations.tsx
index f124a88c4af..e989dcbfacd 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/integrations.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/integrations.tsx
@@ -1,6 +1,7 @@
import React from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -13,8 +14,7 @@ import { ProjectService } from "services/project";
import { SettingsSidebar, SingleIntegration } from "components/project";
// ui
import { EmptyState } from "components/common";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
-import { Loader } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Loader } from "@plane/ui";
// images
import emptyIntegration from "public/empty-state/integration.svg";
// types
@@ -55,11 +55,15 @@ const ProjectIntegrations: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/labels.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/labels.tsx
index a9627e7034e..68ac28503c6 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/labels.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/labels.tsx
@@ -1,6 +1,7 @@
import React, { useState, useRef } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -21,9 +22,8 @@ import {
} from "components/labels";
import { SettingsSidebar } from "components/project";
// ui
-import { Button, Loader } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Button, Loader } from "@plane/ui";
import { EmptyState } from "components/common";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
// images
import emptyLabel from "public/empty-state/label.svg";
// types
@@ -104,11 +104,15 @@ const LabelsSettings: NextPage = () => {
/>
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/members.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/members.tsx
index 589ef3151c2..d91e6084da6 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/members.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/members.tsx
@@ -18,9 +18,8 @@ import ConfirmProjectMemberRemove from "components/project/confirm-project-membe
import SendProjectInvitationModal from "components/project/send-project-invitation-modal";
import { MemberSelect, SettingsSidebar } from "components/project";
// ui
-import { Button, Loader } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Button, Loader } from "@plane/ui";
import { CustomMenu, CustomSelect } from "components/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
// icons
import { ChevronDown, X } from "lucide-react";
// types
@@ -201,11 +200,15 @@ const MembersSettings: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/settings/states.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/settings/states.tsx
index 9bb1a195fd3..5e27d97553b 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/settings/states.tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/settings/states.tsx
@@ -1,6 +1,7 @@
import React, { useState } from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -15,8 +16,7 @@ import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy";
import { CreateUpdateStateInline, DeleteStateModal, SingleState, StateGroup } from "components/states";
import { SettingsSidebar } from "components/project";
// ui
-import { Loader } from "@plane/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs, Loader } from "@plane/ui";
// icons
import { Plus } from "lucide-react";
// helpers
@@ -61,11 +61,15 @@ const StatesSettings: NextPage = () => {
/>
+ router.back()}>
+
+ {`${truncateText(projectDetails?.name ?? "Project", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx
index d42281fbbb9..263c953dd4e 100644
--- a/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx
+++ b/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx
@@ -1,4 +1,5 @@
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -10,11 +11,10 @@ import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy";
// components
import { ProjectViewLayoutRoot } from "components/issues";
// ui
+import { BreadcrumbItem, Breadcrumbs, PhotoFilterIcon } from "@plane/ui";
import { CustomMenu } from "components/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
import { EmptyState } from "components/common";
// icons
-import { PhotoFilterIcon } from "@plane/ui";
// images
import emptyView from "public/empty-state/view.svg";
// helpers
@@ -51,10 +51,15 @@ const SingleView: React.FC = () => {
return (
+ router.back()}>
+
+ {`${activeProject?.name ?? "Project"} Views`}
+
+
+ }
/>
}
diff --git a/web/pages/[workspaceSlug]/settings/billing.tsx b/web/pages/[workspaceSlug]/settings/billing.tsx
index 5469b6b4fd7..9d5d241c4f3 100644
--- a/web/pages/[workspaceSlug]/settings/billing.tsx
+++ b/web/pages/[workspaceSlug]/settings/billing.tsx
@@ -1,6 +1,7 @@
import React from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -11,8 +12,7 @@ import { WorkspaceAuthorizationLayout } from "layouts/auth-layout-legacy";
// component
import { SettingsSidebar } from "components/project";
// ui
-import { Button } from "@plane/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs, Button } from "@plane/ui";
// types
import type { NextPage } from "next";
// fetch-keys
@@ -24,9 +24,8 @@ import { truncateText } from "helpers/string.helper";
const workspaceService = new WorkspaceService();
const BillingSettings: NextPage = () => {
- const {
- query: { workspaceSlug },
- } = useRouter();
+ const router = useRouter();
+ const { workspaceSlug } = router.query;
const { data: activeWorkspace } = useSWR(workspaceSlug ? WORKSPACE_DETAILS(workspaceSlug as string) : null, () =>
workspaceSlug ? workspaceService.getWorkspace(workspaceSlug as string) : null
@@ -35,11 +34,15 @@ const BillingSettings: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(activeWorkspace?.name ?? "Workspace", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/settings/exports.tsx b/web/pages/[workspaceSlug]/settings/exports.tsx
index b0345d49896..ec391dc837e 100644
--- a/web/pages/[workspaceSlug]/settings/exports.tsx
+++ b/web/pages/[workspaceSlug]/settings/exports.tsx
@@ -1,4 +1,5 @@
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -10,7 +11,7 @@ import { WorkspaceAuthorizationLayout } from "layouts/auth-layout-legacy";
import ExportGuide from "components/exporter/guide";
import { SettingsSidebar } from "components/project";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs } from "@plane/ui";
// types
import type { NextPage } from "next";
// fetch-keys
@@ -32,11 +33,15 @@ const ImportExport: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(activeWorkspace?.name ?? "Workspace", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/settings/imports.tsx b/web/pages/[workspaceSlug]/settings/imports.tsx
index c0b500637b0..27b700caccd 100644
--- a/web/pages/[workspaceSlug]/settings/imports.tsx
+++ b/web/pages/[workspaceSlug]/settings/imports.tsx
@@ -1,4 +1,5 @@
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -10,7 +11,7 @@ import { WorkspaceAuthorizationLayout } from "layouts/auth-layout-legacy";
import IntegrationGuide from "components/integration/guide";
import { SettingsSidebar } from "components/project";
// ui
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs } from "@plane/ui";
// types
import type { NextPage } from "next";
// fetch-keys
@@ -32,11 +33,15 @@ const ImportExport: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(activeWorkspace?.name ?? "Workspace", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/settings/index.tsx b/web/pages/[workspaceSlug]/settings/index.tsx
index 3d4a7352fba..1edb6cd52b0 100644
--- a/web/pages/[workspaceSlug]/settings/index.tsx
+++ b/web/pages/[workspaceSlug]/settings/index.tsx
@@ -21,8 +21,7 @@ import { SettingsSidebar } from "components/project";
// ui
import { Disclosure, Transition } from "@headlessui/react";
import { CustomSelect } from "components/ui";
-import { Button, Input, Spinner } from "@plane/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
+import { BreadcrumbItem, Breadcrumbs, Button, Input, Spinner } from "@plane/ui";
// icons
import { ChevronDown, ChevronUp, Pencil } from "lucide-react";
// helpers
@@ -159,7 +158,7 @@ const WorkspaceSettings: NextPage = () => {
return (
+ router.back()}>
}
diff --git a/web/pages/[workspaceSlug]/settings/integrations.tsx b/web/pages/[workspaceSlug]/settings/integrations.tsx
index 7d6869ed289..783a1c933ea 100644
--- a/web/pages/[workspaceSlug]/settings/integrations.tsx
+++ b/web/pages/[workspaceSlug]/settings/integrations.tsx
@@ -1,6 +1,7 @@
import React from "react";
import { useRouter } from "next/router";
+import Link from "next/link";
import useSWR from "swr";
@@ -14,8 +15,7 @@ import { SingleIntegrationCard } from "components/integration";
import { SettingsSidebar } from "components/project";
// ui
import { IntegrationAndImportExportBanner } from "components/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
-import { Loader } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Loader } from "@plane/ui";
// types
import type { NextPage } from "next";
// fetch-keys
@@ -42,11 +42,15 @@ const WorkspaceIntegrations: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(activeWorkspace?.name ?? "Workspace", 32)}`}
+
+
+ }
/>
diff --git a/web/pages/[workspaceSlug]/settings/members.tsx b/web/pages/[workspaceSlug]/settings/members.tsx
index 80548b686fc..f1bc895888d 100644
--- a/web/pages/[workspaceSlug]/settings/members.tsx
+++ b/web/pages/[workspaceSlug]/settings/members.tsx
@@ -18,9 +18,8 @@ import ConfirmWorkspaceMemberRemove from "components/workspace/confirm-workspace
import SendWorkspaceInvitationModal from "components/workspace/send-workspace-invitation-modal";
import { SettingsSidebar } from "components/project";
// ui
-import { Button, Loader } from "@plane/ui";
+import { BreadcrumbItem, Breadcrumbs, Button, Loader } from "@plane/ui";
import { CustomMenu, CustomSelect } from "components/ui";
-import { BreadcrumbItem, Breadcrumbs } from "components/breadcrumbs";
// icons
import { ChevronDown, X } from "lucide-react";
// types
@@ -101,11 +100,15 @@ const MembersSettings: NextPage = () => {
return (
+ router.back()}>
+
+ {`${truncateText(activeWorkspace?.name ?? "Workspace", 32)}`}
+
+
+ }
/>