Skip to content

Commit

Permalink
[3557] Add ProjectSettings tab extension point
Browse files Browse the repository at this point in the history
Bug: eclipse-sirius#3557
Signed-off-by: William Piers <[email protected]>
  • Loading branch information
wpiers authored and sbegaudeau committed Jun 9, 2024
1 parent 389819a commit 2053707
Show file tree
Hide file tree
Showing 6 changed files with 107 additions and 7 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@
- https://github.com/eclipse-sirius/sirius-web/issues/3447[#3447] [view] Add support for For construct in the operations DSL
- https://github.com/eclipse-sirius/sirius-web/issues/3526[#3526] [diagram] Add support for text alignment on node labels
- https://github.com/eclipse-sirius/sirius-web/issues/3550[#3550] [core] Add ExtensionRegistry merge strategy
- https://github.com/eclipse-sirius/sirius-web/issues/3557[#3550] [app] Add ProjectSettings tab extension point

=== Improvements

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,9 @@ import { OnboardArea } from '../onboarding/OnboardArea';
import { RepresentationContextProvider } from '../representations/RepresentationContextProvider';
import { Router } from '../router/Router';
import { siriusWebTheme as defaultTheme } from '../theme/siriusWebTheme';
import { ProjectSettingTabContribution } from '../views/project-settings/ProjectSettingsView.types';
import { projectSettingsTabExtensionPoint } from '../views/project-settings/ProjectSettingsViewExtensionPoints';
import { ProjectImagesSettings } from '../views/project-settings/images/ProjectImagesSettings';
import { SiriusWebApplicationProps } from './SiriusWebApplication.types';

const style = {
Expand Down Expand Up @@ -118,6 +121,13 @@ export const SiriusWebApplication = ({
},
];

const projectSettingsTabContributions: ProjectSettingTabContribution[] = [
{
title: 'Images',
component: ProjectImagesSettings,
},
];

const internalExtensionRegistry = new ExtensionRegistry();
internalExtensionRegistry.addComponent(workbenchMainAreaExtensionPoint, {
identifier: 'siriusweb_workbench#mainArea',
Expand All @@ -127,6 +137,11 @@ export const SiriusWebApplication = ({
identifier: 'siriusweb_workbench#viewContribution',
data: workbenchViewContributions,
});
internalExtensionRegistry.putData(projectSettingsTabExtensionPoint, {
identifier: 'sw_projectSettingsTab',
data: projectSettingsTabContributions,
});

if (extensionRegistry) {
internalExtensionRegistry.addAll(
extensionRegistry,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,3 +36,5 @@ export { routerExtensionPoint } from './router/RouterExtensionPoints';
export { projectActionButtonMenuItemExtensionPoint } from './views/project-browser/list-projects-area/ProjectActionButtonExtensionPoints';
export { type ProjectRowProps } from './views/project-browser/list-projects-area/ProjectRow.types';
export { projectsTableRowExtensionPoint } from './views/project-browser/list-projects-area/ProjectsTableExtensionPoints';
export { type ProjectSettingTabContribution } from './views/project-settings/ProjectSettingsView.types';
export * from './views/project-settings/ProjectSettingsViewExtensionPoints';
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,20 @@
* Contributors:
* Obeo - initial API and implementation
*******************************************************************************/
import { useData } from '@eclipse-sirius/sirius-components-core';
import AppBar from '@material-ui/core/AppBar';
import Container from '@material-ui/core/Container';
import Grid from '@material-ui/core/Grid';
import Tab from '@material-ui/core/Tab';
import Tabs from '@material-ui/core/Tabs';
import Typography from '@material-ui/core/Typography';
import { makeStyles } from '@material-ui/core/styles';
import { useState } from 'react';
import { Link, useParams } from 'react-router-dom';
import { Footer } from '../../footer/Footer';

import { NavigationBar } from '../../navigationBar/NavigationBar';
import { ProjectImagesSettings } from './images/ProjectImagesSettings';
import { ProjectSettingsParams } from './ProjectSettingsView.types';
import { projectSettingsTabExtensionPoint } from './ProjectSettingsViewExtensionPoints';

const useProjectSettingsViewStyles = makeStyles((theme) => ({
projectSettingsView: {
Expand All @@ -28,21 +36,55 @@ const useProjectSettingsViewStyles = makeStyles((theme) => ({
paddingTop: theme.spacing(3),
paddingBottom: theme.spacing(3),
},
header: {
display: 'grid',
gridTemplateColumns: '1fr max-content',
alignItems: 'center',
padding: theme.spacing(3),
},
tabs: {
display: 'grid',
gridTemplateRows: 'min-content 1fr',
},
tabPanels: {
padding: theme.spacing(3),
},
}));

export const ProjectSettingsView = () => {
const classes = useProjectSettingsViewStyles();
const { data: projectSettingsTabContributions } = useData(projectSettingsTabExtensionPoint);
const { projectId } = useParams<ProjectSettingsParams>();
const [value, setValue] = useState(0);
const handleChange = (_, newValue) => {
setValue(newValue);
};

return (
<div className={classes.projectSettingsView}>
<NavigationBar />
<main className={classes.main}>
<Container maxWidth="xl">
<Grid container justifyContent="center">
<Grid item xs={8}>
<ProjectImagesSettings />
</Grid>
</Grid>
<div className={classes.header}>
<Typography variant="h4">Project Settings</Typography>
<Link to={'/projects/' + projectId + '/edit'}>Back to project</Link>
</div>
<div className={classes.tabs}>
<AppBar position="static">
<Tabs value={value} onChange={handleChange}>
{projectSettingsTabContributions.map(({ title }, index) => (
<Tab label={title} key={index} />
))}
</Tabs>
</AppBar>
<div className={classes.tabPanels}>
{projectSettingsTabContributions.map(({ component: ProjectSettingsTabComponent }, index) => (
<div hidden={value !== index} key={index}>
{value === index && <ProjectSettingsTabComponent />}
</div>
))}
</div>
</div>
</Container>
</main>
<Footer />
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
/*******************************************************************************
* Copyright (c) 2024 Obeo.
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Obeo - initial API and implementation
*******************************************************************************/

export interface ProjectSettingsParams {
projectId: string;
}
export interface ProjectSettingTabContribution {
title: string;
component: () => JSX.Element | null;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
/*******************************************************************************
* Copyright (c) 2021, 2024 Obeo.
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Obeo - initial API and implementation
*******************************************************************************/

import { DataExtensionPoint } from '@eclipse-sirius/sirius-components-core';
import { ProjectSettingTabContribution } from './ProjectSettingsView.types';

export const projectSettingsTabExtensionPoint: DataExtensionPoint<Array<ProjectSettingTabContribution>> = {
identifier: 'projectSettings#tabContribution',
fallback: [],
};

0 comments on commit 2053707

Please sign in to comment.