import { linearGradientDef } from "@nivo/core"; // assets import UpcomingAssignedIssuesDark from "public/empty-state/dashboard/dark/upcoming-assigned-issues.svg"; import UpcomingAssignedIssuesLight from "public/empty-state/dashboard/light/upcoming-assigned-issues.svg"; import OverdueAssignedIssuesDark from "public/empty-state/dashboard/dark/overdue-assigned-issues.svg"; import OverdueAssignedIssuesLight from "public/empty-state/dashboard/light/overdue-assigned-issues.svg"; import CompletedAssignedIssuesDark from "public/empty-state/dashboard/dark/completed-assigned-issues.svg"; import CompletedAssignedIssuesLight from "public/empty-state/dashboard/light/completed-assigned-issues.svg"; import UpcomingCreatedIssuesDark from "public/empty-state/dashboard/dark/upcoming-created-issues.svg"; import UpcomingCreatedIssuesLight from "public/empty-state/dashboard/light/upcoming-created-issues.svg"; import OverdueCreatedIssuesDark from "public/empty-state/dashboard/dark/overdue-created-issues.svg"; import OverdueCreatedIssuesLight from "public/empty-state/dashboard/light/overdue-created-issues.svg"; import CompletedCreatedIssuesDark from "public/empty-state/dashboard/dark/completed-created-issues.svg"; import CompletedCreatedIssuesLight from "public/empty-state/dashboard/light/completed-created-issues.svg"; // types import { TDurationFilterOptions, TIssuesListTypes, TStateGroups } from "@plane/types"; import { Props } from "components/icons/types"; // constants import { EUserWorkspaceRoles } from "./workspace"; // icons import { BarChart2, Briefcase, CheckCircle, LayoutGrid, SendToBack } from "lucide-react"; // gradients for issues by priority widget graph bars export const PRIORITY_GRAPH_GRADIENTS = [ linearGradientDef( "gradientUrgent", [ { offset: 0, color: "#A90408" }, { offset: 100, color: "#DF4D51" }, ], { x1: 1, y1: 0, x2: 0, y2: 0, } ), linearGradientDef( "gradientHigh", [ { offset: 0, color: "#FE6B00" }, { offset: 100, color: "#FFAC88" }, ], { x1: 1, y1: 0, x2: 0, y2: 0, } ), linearGradientDef( "gradientMedium", [ { offset: 0, color: "#F5AC00" }, { offset: 100, color: "#FFD675" }, ], { x1: 1, y1: 0, x2: 0, y2: 0, } ), linearGradientDef( "gradientLow", [ { offset: 0, color: "#1B46DE" }, { offset: 100, color: "#4F9BF4" }, ], { x1: 1, y1: 0, x2: 0, y2: 0, } ), linearGradientDef( "gradientNone", [ { offset: 0, color: "#A0A1A9" }, { offset: 100, color: "#B9BBC6" }, ], { x1: 1, y1: 0, x2: 0, y2: 0, } ), ]; // colors for issues by state group widget graph arcs export const STATE_GROUP_GRAPH_GRADIENTS = [ linearGradientDef("gradientBacklog", [ { offset: 0, color: "#DEDEDE" }, { offset: 100, color: "#BABABE" }, ]), linearGradientDef("gradientUnstarted", [ { offset: 0, color: "#D4D4D4" }, { offset: 100, color: "#878796" }, ]), linearGradientDef("gradientStarted", [ { offset: 0, color: "#FFD300" }, { offset: 100, color: "#FAE270" }, ]), linearGradientDef("gradientCompleted", [ { offset: 0, color: "#0E8B1B" }, { offset: 100, color: "#37CB46" }, ]), linearGradientDef("gradientCanceled", [ { offset: 0, color: "#C90004" }, { offset: 100, color: "#FF7679" }, ]), ]; export const STATE_GROUP_GRAPH_COLORS: Record = { backlog: "#CDCED6", unstarted: "#80838D", started: "#FFC53D", completed: "#3E9B4F", cancelled: "#E5484D", }; // filter duration options export const DURATION_FILTER_OPTIONS: { key: TDurationFilterOptions; label: string; }[] = [ { key: "today", label: "Today", }, { key: "this_week", label: "This week", }, { key: "this_month", label: "This month", }, { key: "this_year", label: "This year", }, ]; // random background colors for project cards export const PROJECT_BACKGROUND_COLORS = [ "bg-gray-500/20", "bg-green-500/20", "bg-red-500/20", "bg-orange-500/20", "bg-blue-500/20", "bg-yellow-500/20", "bg-pink-500/20", "bg-purple-500/20", ]; // assigned and created issues widgets tabs list export const ISSUES_TABS_LIST: { key: TIssuesListTypes; label: string; }[] = [ { key: "upcoming", label: "Upcoming", }, { key: "overdue", label: "Overdue", }, { key: "completed", label: "Completed", }, ]; // empty state constants const ASSIGNED_ISSUES_DURATION_TITLES: { [type in TIssuesListTypes]: { [duration in TDurationFilterOptions]: string; }; } = { upcoming: { today: "today", this_week: "yet in this week", this_month: "yet in this month", this_year: "yet in this year", }, overdue: { today: "today", this_week: "in this week", this_month: "in this month", this_year: "in this year", }, completed: { today: "today", this_week: "this week", this_month: "this month", this_year: "this year", }, }; const CREATED_ISSUES_DURATION_TITLES: { [duration in TDurationFilterOptions]: string; } = { today: "today", this_week: "in this week", this_month: "in this month", this_year: "in this year", }; export const ASSIGNED_ISSUES_EMPTY_STATES = { upcoming: { title: (duration: TDurationFilterOptions) => `No issues assigned to you ${ASSIGNED_ISSUES_DURATION_TITLES.upcoming[duration]}.`, darkImage: UpcomingAssignedIssuesDark, lightImage: UpcomingAssignedIssuesLight, }, overdue: { title: (duration: TDurationFilterOptions) => `No issues with due dates ${ASSIGNED_ISSUES_DURATION_TITLES.overdue[duration]} are open.`, darkImage: OverdueAssignedIssuesDark, lightImage: OverdueAssignedIssuesLight, }, completed: { title: (duration: TDurationFilterOptions) => `No issues completed by you ${ASSIGNED_ISSUES_DURATION_TITLES.completed[duration]}.`, darkImage: CompletedAssignedIssuesDark, lightImage: CompletedAssignedIssuesLight, }, }; export const CREATED_ISSUES_EMPTY_STATES = { upcoming: { title: (duration: TDurationFilterOptions) => `No created issues have deadlines coming up ${CREATED_ISSUES_DURATION_TITLES[duration]}.`, darkImage: UpcomingCreatedIssuesDark, lightImage: UpcomingCreatedIssuesLight, }, overdue: { title: (duration: TDurationFilterOptions) => `No created issues with due dates ${CREATED_ISSUES_DURATION_TITLES[duration]} are open.`, darkImage: OverdueCreatedIssuesDark, lightImage: OverdueCreatedIssuesLight, }, completed: { title: (duration: TDurationFilterOptions) => `No created issues are completed ${CREATED_ISSUES_DURATION_TITLES[duration]}.`, darkImage: CompletedCreatedIssuesDark, lightImage: CompletedCreatedIssuesLight, }, }; export const SIDEBAR_MENU_ITEMS: { key: string; label: string; href: string; access: EUserWorkspaceRoles; highlight: (pathname: string, baseUrl: string) => boolean; Icon: React.FC; }[] = [ { key: "dashboard", label: "Dashboard", href: ``, access: EUserWorkspaceRoles.GUEST, highlight: (pathname: string, baseUrl: string) => pathname === `${baseUrl}`, Icon: LayoutGrid, }, { key: "analytics", label: "Analytics", href: `/analytics`, access: EUserWorkspaceRoles.MEMBER, highlight: (pathname: string, baseUrl: string) => pathname === `${baseUrl}/analytics`, Icon: BarChart2, }, { key: "projects", label: "Projects", href: `/projects`, access: EUserWorkspaceRoles.GUEST, highlight: (pathname: string, baseUrl: string) => pathname === `${baseUrl}/projects`, Icon: Briefcase, }, { key: "all-issues", label: "All Issues", href: `/workspace-views/all-issues`, access: EUserWorkspaceRoles.GUEST, highlight: (pathname: string, baseUrl: string) => pathname === `${baseUrl}/workspace-views/all-issues`, Icon: CheckCircle, }, { key: "active-cycles", label: "Active cycles", href: `/active-cycles`, access: EUserWorkspaceRoles.GUEST, highlight: (pathname: string, baseUrl: string) => pathname === `${baseUrl}/active-cycles`, Icon: SendToBack, }, ];