1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

feat: personal dashboard route (#8173)

This commit is contained in:
Mateusz Kwasniewski 2024-09-19 09:59:07 +02:00 committed by GitHub
parent d5076f0772
commit 8e037a335f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 42 additions and 1 deletions

View File

@ -15,6 +15,7 @@ import useUiConfig from 'hooks/api/getters/useUiConfig/useUiConfig';
import SearchIcon from '@mui/icons-material/Search';
import PlaygroundIcon from '@mui/icons-material/AutoFixNormal';
import InsightsIcon from '@mui/icons-material/Insights';
import PersonalDashboardIcon from '@mui/icons-material/DashboardOutlined';
import Accordion from '@mui/material/Accordion';
import AccordionDetails from '@mui/material/AccordionDetails';
import AccordionSummary from '@mui/material/AccordionSummary';
@ -23,6 +24,7 @@ import FlagIcon from '@mui/icons-material/OutlinedFlag';
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
import useProjectOverview from 'hooks/api/getters/useProjectOverview/useProjectOverview';
import { ProjectIcon } from 'component/common/ProjectIcon/ProjectIcon';
import { useUiFlag } from 'hooks/useUiFlag';
const StyledBadgeContainer = styled('div')(({ theme }) => ({
paddingLeft: theme.spacing(2),
@ -155,10 +157,22 @@ export const PrimaryNavigationList: FC<{
activeItem?: string;
}> = ({ mode, onClick, activeItem }) => {
const DynamicListItem = mode === 'mini' ? MiniListItem : FullListItem;
const personalDashboardUIEnabled = useUiFlag('personalDashboardUI');
const { isOss } = useUiConfig();
return (
<List>
{personalDashboardUIEnabled ? (
<DynamicListItem
href='/personal'
text='Personal Dahsboard'
onClick={() => onClick('/personal')}
selected={activeItem === '/personal'}
>
<PersonalDashboardIcon />
</DynamicListItem>
) : null}
<DynamicListItem
href='/projects'
text='Projects'

View File

@ -10,6 +10,15 @@ exports[`returns all baseRoutes 1`] = `
"title": "Unleash",
"type": "protected",
},
{
"component": [Function],
"menu": {
"mobile": true,
},
"path": "/personal",
"title": "Personal Dashboard",
"type": "protected",
},
{
"component": {
"$$typeof": Symbol(react.lazy),

View File

@ -47,6 +47,7 @@ import { FeedbackList } from '../feedbackNew/FeedbackList';
import { Application } from 'component/application/Application';
import { Signals } from 'component/signals/Signals';
import { LazyCreateProject } from '../project/Project/CreateProject/LazyCreateProject';
import { PersonalDashboard } from '../personalDashboard/PersonalDashboard';
export const routes: IRoute[] = [
// Splash
@ -58,6 +59,14 @@ export const routes: IRoute[] = [
menu: {},
isStandalone: true,
},
// Personal Dashboard
{
path: '/personal',
title: 'Personal Dashboard',
component: PersonalDashboard,
type: 'protected',
menu: { mobile: true },
},
// Project
{

View File

@ -0,0 +1,3 @@
export const PersonalDashboard = () => {
return <>Personal Dashboard</>;
};

View File

@ -91,6 +91,7 @@ export type UiFlags = {
projectListImprovements?: boolean;
onboardingUI?: boolean;
eventTimeline?: boolean;
personalDashboardUI?: boolean;
};
export interface IVersionInfo {

View File

@ -64,7 +64,8 @@ export type IFlagKey =
| 'onboardingMetrics'
| 'onboardingUI'
| 'projectRoleAssignment'
| 'eventTimeline';
| 'eventTimeline'
| 'personalDashboardUI';
export type IFlags = Partial<{ [key in IFlagKey]: boolean | Variant }>;
@ -317,6 +318,10 @@ const flags: IFlags = {
process.env.UNLEASH_EXPERIMENTAL_EVENT_TIMELINE,
false,
),
personalDashboardUI: parseEnvVarBoolean(
process.env.UNLEASH_EXPERIMENTAL_PERSONAL_DASHBOARD_UI,
false,
),
};
export const defaultExperimentalOptions: IExperimentalOptions = {