From 9c764071e597ef8fd01a3c86f83f44e042555538 Mon Sep 17 00:00:00 2001 From: cesarLima1 Date: Mon, 18 Nov 2024 23:55:58 -0400 Subject: [PATCH] [TM-1492] make dashboard endpoints publicly accessible --- .../extensive/BlurContainer/BlurContainer.tsx | 21 ++++++++++++++++--- .../extensive/PageElements/Card/PageCard.tsx | 4 +++- src/middleware.page.ts | 7 ++++++- src/pages/dashboard/index.page.tsx | 4 +++- 4 files changed, 30 insertions(+), 6 deletions(-) diff --git a/src/components/extensive/BlurContainer/BlurContainer.tsx b/src/components/extensive/BlurContainer/BlurContainer.tsx index 84bacd87d..a99c82929 100644 --- a/src/components/extensive/BlurContainer/BlurContainer.tsx +++ b/src/components/extensive/BlurContainer/BlurContainer.tsx @@ -6,7 +6,7 @@ import Text from "@/components/elements/Text/Text"; export interface BlurContainerProps { isBlur: boolean; - textInformation?: string; + textInformation?: string | React.ReactNode; children: React.ReactNode; className?: string; } @@ -16,6 +16,21 @@ const BlurContainer = ({ isBlur, textInformation, children, className, ...props return <>{children}; } + const LoginText = () => ( + <> + + Login to view. + {" "} + If you are a funder or representing a government agency, please{" "} + + click here to request an account. + + + ); + return (
- + - {textInformation} + {typeof textInformation === "string" ? textInformation : }
diff --git a/src/components/extensive/PageElements/Card/PageCard.tsx b/src/components/extensive/PageElements/Card/PageCard.tsx index 3bd4faf1e..4336ad5ac 100644 --- a/src/components/extensive/PageElements/Card/PageCard.tsx +++ b/src/components/extensive/PageElements/Card/PageCard.tsx @@ -8,6 +8,7 @@ import EmptyField, { EmptyFieldProps } from "@/components/elements/Field/EmptyFi import Paper from "@/components/elements/Paper/Paper"; import Text from "@/components/elements/Text/Text"; import ToolTip from "@/components/elements/Tooltip/Tooltip"; +import { useMyUser } from "@/connections/User"; import { NO_DATA_INFORMATION } from "@/constants/dashboardConsts"; import { withFrameworkShow } from "@/context/framework.provider"; import { TextVariants } from "@/types/common"; @@ -55,6 +56,7 @@ const PageCard = ({ const [collapseSubtile, setCollapseSubtile] = useState(true); const [subtitleText, setSubtitleText] = useState(subtitle); const t = useT(); + const [, { user }] = useMyUser(); const maxLength = 278; @@ -68,7 +70,7 @@ const PageCard = ({ return ( - + }>
diff --git a/src/middleware.page.ts b/src/middleware.page.ts index 08af842f4..d20e8eb43 100644 --- a/src/middleware.page.ts +++ b/src/middleware.page.ts @@ -14,6 +14,10 @@ export async function middleware(request: NextRequest) { const accessToken = request.cookies.get("accessToken")?.value; const middlewareCache = request.cookies.get(MiddlewareCacheKey)?.value; + if (request.nextUrl.pathname.startsWith("/dashboard")) { + return NextResponse.next(); + } + if (!!accessToken && !!middlewareCache) { // Skip middleware for dashboard routes to prevent redirect loop if (request.nextUrl.pathname.startsWith("/dashboard")) { @@ -37,7 +41,8 @@ export async function middleware(request: NextRequest) { matcher.startWith("/auth")?.next(); matcher.exact("/")?.next(); - matcher.redirect("/auth/login"); + // Commented for now as any unauthenticated user can access to the dashboard + // matcher.redirect("/auth/login"); }, async () => { // The redux store isn't available yet at this point, so we do a quick manual users/me fetch diff --git a/src/pages/dashboard/index.page.tsx b/src/pages/dashboard/index.page.tsx index 975577eca..2f1f91679 100644 --- a/src/pages/dashboard/index.page.tsx +++ b/src/pages/dashboard/index.page.tsx @@ -8,6 +8,7 @@ import BlurContainer from "@/components/extensive/BlurContainer/BlurContainer"; import Icon, { IconNames } from "@/components/extensive/Icon/Icon"; import PageCard from "@/components/extensive/PageElements/Card/PageCard"; import PageRow from "@/components/extensive/PageElements/Row/PageRow"; +import { useMyUser } from "@/connections/User"; import { CHART_TYPES, JOBS_CREATED_CHART_TYPE, @@ -57,6 +58,7 @@ export interface GraphicLegendProps { const Dashboard = () => { const t = useT(); + const [, { user }] = useMyUser(); const { filters, setFilters, frameworks } = useDashboardContext(); const { dashboardHeader, @@ -283,7 +285,7 @@ const Dashboard = () => { } >
{dashboardHeader.map((item, index) => (