Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Digital Twins page preview - trigger pipeline from client #891

Closed
Changes from 1 commit
Commits
Show all changes
76 commits
Select commit Hold shift + click to select a range
5c78206
configuration changes
VanessaScherma May 2, 2024
2d2b717
pre-commit-configuration
VanessaScherma May 2, 2024
3d6fb92
Merge branch 'INTO-CPS-Association:feature/distributed-demo' into fea…
VanessaScherma Jun 11, 2024
a3ff550
Merge branch 'INTO-CPS-Association:feature/distributed-demo' into fea…
VanessaScherma Jun 20, 2024
4a9740b
class DigitalTwin added
Jun 20, 2024
e7f2964
configuration changes
Jun 20, 2024
6beacfa
Merge branch 'INTO-CPS-Association:feature/distributed-demo' into fea…
VanessaScherma Jul 30, 2024
663cc3d
Update gitlab.ts and gitlab.test.ts
VanessaScherma Jul 30, 2024
c35450d
Eslint fixes
VanessaScherma Jul 30, 2024
4f8e74a
gitlab class updated
VanessaScherma Aug 1, 2024
f0f1160
Add DigitalTwinSubfolders
VanessaScherma Aug 1, 2024
8536453
Fix
VanessaScherma Aug 1, 2024
a86a47b
Add GitlabDriver and divide GitlabInstance and GitlabDigitalTwin
VanessaScherma Aug 2, 2024
56b412e
Change imports
VanessaScherma Aug 7, 2024
c8dc464
Adds config for managing gitlab code of client
prasadtalasila Aug 16, 2024
8d20c28
Adds instructions for running gitlab code of client
prasadtalasila Aug 16, 2024
f61ea59
Merge branch 'INTO-CPS-Association:feature/distributed-demo' into fea…
VanessaScherma Aug 16, 2024
3f35520
Merge branch 'pr-830' of https://github.com/VanessaScherma/DTaaS into…
VanessaScherma Aug 16, 2024
7806eef
Comments resolved
VanessaScherma Aug 17, 2024
ea3fd03
Refactor
VanessaScherma Aug 18, 2024
41cd332
Refactor
VanessaScherma Aug 18, 2024
cb8c5e8
Temporary update
VanessaScherma Aug 18, 2024
3a70879
Merge branch 'feature/distributed-demo' of https://github.com/Vanessa…
VanessaScherma Aug 18, 2024
d54bbb8
Change GitlabInstance constructor parameters
VanessaScherma Aug 23, 2024
19b893f
Digital Twins page preview completed
VanessaScherma Aug 26, 2024
6bc73f9
Merge branch 'feature/distributed-demo' of https://github.com/Vanessa…
VanessaScherma Aug 30, 2024
a3a3b68
Code review fixes
VanessaScherma Aug 30, 2024
751a2e2
Convert DTContent into class
VanessaScherma Sep 1, 2024
d4d5b14
Add class for DigitalTwinsPreview
VanessaScherma Sep 1, 2024
809cdc8
Add documentation to DEVELOPER.md
VanessaScherma Sep 2, 2024
52a5f21
Use Asset components (graphical adaptation)
VanessaScherma Sep 3, 2024
b6b1f01
Add GITLAB-RUNNER.md
VanessaScherma Sep 4, 2024
da096ac
Remove unused import
VanessaScherma Sep 4, 2024
5095cc1
Update gitlab-runner instructions
VanessaScherma Sep 4, 2024
af9009b
Use asset components
VanessaScherma Sep 5, 2024
2effdf1
Use asset components
VanessaScherma Sep 5, 2024
ed9ecee
Little fix
VanessaScherma Sep 5, 2024
7a07d77
Update gitlab-runner instructions
VanessaScherma Sep 5, 2024
579f7db
Fix codeclimate issues
VanessaScherma Sep 5, 2024
51bfd6d
Fix codeclimate issues
VanessaScherma Sep 5, 2024
b75d586
Temporary update
VanessaScherma Aug 18, 2024
ede2311
Digital Twins page preview completed
VanessaScherma Aug 26, 2024
c0561f5
Code review fixes
VanessaScherma Aug 30, 2024
b755928
Convert DTContent into class
VanessaScherma Sep 1, 2024
bcf6030
Add class for DigitalTwinsPreview
VanessaScherma Sep 1, 2024
6fe33c2
Add documentation to DEVELOPER.md
VanessaScherma Sep 2, 2024
c2e3d60
Use Asset components (graphical adaptation)
VanessaScherma Sep 3, 2024
41bf25f
Add GITLAB-RUNNER.md
VanessaScherma Sep 4, 2024
5f38a79
Update gitlab-runner instructions
VanessaScherma Sep 4, 2024
22ce9ae
Use asset components
VanessaScherma Sep 5, 2024
3b9fc76
Little fix
VanessaScherma Sep 5, 2024
46c4c6a
Update gitlab-runner instructions
VanessaScherma Sep 5, 2024
f952324
Fix codeclimate issues
VanessaScherma Sep 5, 2024
4fc5a05
Fix codeclimate issues
VanessaScherma Sep 5, 2024
aa2f607
Update
VanessaScherma Sep 5, 2024
98037b0
Merge branch 'gitlab' of https://github.com/VanessaScherma/DTaaS into…
VanessaScherma Sep 5, 2024
58cca12
Temporary update
VanessaScherma Aug 18, 2024
15bdaf6
Digital Twins page preview completed
VanessaScherma Aug 26, 2024
0809a1c
Code review fixes
VanessaScherma Aug 30, 2024
60cd817
Convert DTContent into class
VanessaScherma Sep 1, 2024
84f8901
Add class for DigitalTwinsPreview
VanessaScherma Sep 1, 2024
7535eb4
Add documentation to DEVELOPER.md
VanessaScherma Sep 2, 2024
fe2563b
Use Asset components (graphical adaptation)
VanessaScherma Sep 3, 2024
06176f6
Use asset components
VanessaScherma Sep 5, 2024
2f7ce42
Merge branch 'gitlab' of https://github.com/VanessaScherma/DTaaS into…
VanessaScherma Sep 5, 2024
2f65511
Temporary update
VanessaScherma Aug 18, 2024
d1f1b87
Digital Twins page preview completed
VanessaScherma Aug 26, 2024
5168797
Code review fixes
VanessaScherma Aug 30, 2024
488ca46
Convert DTContent into class
VanessaScherma Sep 1, 2024
f044b6c
Add class for DigitalTwinsPreview
VanessaScherma Sep 1, 2024
a518099
Add documentation to DEVELOPER.md
VanessaScherma Sep 2, 2024
99b4ff3
Use Asset components (graphical adaptation)
VanessaScherma Sep 3, 2024
e80192c
Use asset components
VanessaScherma Sep 5, 2024
33c9351
Merge branch 'gitlab' of https://github.com/VanessaScherma/DTaaS into…
VanessaScherma Sep 5, 2024
5a1eae8
use redux to store digital twin
VanessaScherma Sep 5, 2024
94614ec
Fix codeclimate issues
VanessaScherma Sep 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add class for DigitalTwinsPreview
  • Loading branch information
VanessaScherma committed Sep 5, 2024
commit bcf603047c8073e02df69539253923555b66869c
69 changes: 25 additions & 44 deletions client/src/route/digitaltwins/DigitalTwinsPreview.tsx
prasadtalasila marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -1,57 +1,38 @@
import React, { Component } from 'react';
import React, { useState, useEffect } from 'react';
import { Typography } from '@mui/material';
import Layout from 'page/Layout';
import TabComponent from 'components/tab/TabComponent';
import { TabData } from 'components/tab/subcomponents/TabRender';
import { GitlabInstance, FolderEntry } from 'util/gitlab';
import { getAuthority } from 'util/envUtil';
import { FolderEntry } from 'util/gitlab';
import tabs from './DigitalTwinTabData';
import ExecuteTab from './ExecuteTab';
import GitlabService from './GitlabService';

class DTContent extends Component<Record<string, never>, { subfolders: FolderEntry[], gitlabInstance: GitlabInstance | null }> {
constructor(props: Record<string, never>
) {
super(props);
this.state = {
subfolders: [],
gitlabInstance: null,
};
}
function DTContent() {
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Function DTContent has 38 lines of code (exceeds 25 allowed). Consider refactoring.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Function DTContent has 30 lines of code (exceeds 25 allowed). Consider refactoring.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Function DTContent has 36 lines of code (exceeds 25 allowed). Consider refactoring.

const [subfolders, setSubfolders] = useState<FolderEntry[]>([]);
const gitlabService = new GitlabService();

async fetchSubfolders() {
const instance = new GitlabInstance(sessionStorage.getItem('username') || '', getAuthority(), sessionStorage.getItem('access_token') || '');
this.setState({ gitlabInstance: instance });
const projectId = await instance.getProjectId();
if (projectId) {
const subfoldersData = await instance.getDTSubfolders(projectId);
this.setState({ subfolders: subfoldersData });
}
}
useEffect(() => {
gitlabService.getSubfolders().then((subfoldersData) => {setSubfolders(subfoldersData)}); ;
}, []);

componentDidMount() {
this.fetchSubfolders();
}
const DTTab: TabData[] = tabs
.filter((tab) => tab.label === 'Execute')
.map((tab) => ({
label: tab.label,
body: (
<>
<Typography variant="body1">{tab.body}</Typography>
{gitlabService.getInstance() && <ExecuteTab subfolders={subfolders} gitlabInstance={gitlabService.getInstance()} />}
</>
),
}));

render() {
const { subfolders, gitlabInstance } = this.state;
const DTTab: TabData[] = tabs
.filter((tab) => tab.label === 'Execute')
.map((tab) => ({
label: tab.label,
body: (
<>
<Typography variant="body1">{tab.body}</Typography>
{gitlabInstance && <ExecuteTab subfolders={subfolders} gitlabInstance={gitlabInstance} />}
</>
),
}));

return (
<Layout>
<TabComponent assetType={DTTab} scope={[]} />
</Layout>
);
}
return (
<Layout>
<TabComponent assetType={DTTab} scope={[]} />
</Layout>
);
}

export default DTContent;
31 changes: 31 additions & 0 deletions client/src/route/digitaltwins/GitlabService.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import { GitlabInstance, FolderEntry } from 'util/gitlab';
import { getAuthority } from 'util/envUtil';

class GitlabService {
private gitlabInstance: GitlabInstance;

constructor() {
this.gitlabInstance = new GitlabInstance(
sessionStorage.getItem('username') || '',
getAuthority(),
sessionStorage.getItem('access_token') || ''
);
}

async getSubfolders(): Promise<FolderEntry[]> {
if (!this.gitlabInstance) {
throw new Error('GitlabInstance is not initialized');
}
const projectId = await this.gitlabInstance.getProjectId();
if (projectId) {
return this.gitlabInstance.getDTSubfolders(projectId);
}
return [];
}

getInstance(): GitlabInstance {
return this.gitlabInstance;
}
}

export default GitlabService;
104 changes: 104 additions & 0 deletions client/src/store/digitalTwin.slice.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
// digitalTwinSlice.ts
import { AlertColor } from '@mui/material';
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
import { GitlabInstance } from 'util/gitlab';
import DigitalTwin from 'util/gitlabDigitalTwin';

interface DigitalTwinState {
gitlab: GitlabInstance | null;
digitalTwin: DigitalTwin | null;
description: string;
executionStatus: string | null;
snackbarOpen: boolean;
snackbarMessage: string;
snackbarSeverity: AlertColor;
jobLogs: { jobName: string; log: string }[];
showLog: boolean;
pipelineCompleted: boolean;
pipelineLoading: boolean;
buttonText: string;
executionCount: number;
}

const initialState: DigitalTwinState = {
gitlab: null,
digitalTwin: null,
description: '',
executionStatus: null,
snackbarOpen: false,
snackbarMessage: '',
snackbarSeverity: 'success',
jobLogs: [],
showLog: false,
pipelineCompleted: false,
pipelineLoading: false,
buttonText: 'Start',
executionCount: 0,
};

const digitalTwinSlice = createSlice({
name: 'digitalTwin',
initialState,
reducers: {
setGitlab: (state, action: PayloadAction<GitlabInstance | null>) => {
state.gitlab = action.payload;
},
setDigitalTwin: (state, action: PayloadAction<DigitalTwin | null>) => {
state.digitalTwin = action.payload;
},
setDescription: (state, action: PayloadAction<string>) => {
state.description = action.payload;
},
setExecutionStatus: (state, action: PayloadAction<string | null>) => {
state.executionStatus = action.payload;
},
setSnackbarOpen: (state, action: PayloadAction<boolean>) => {
state.snackbarOpen = action.payload;
},
setSnackbarMessage: (state, action: PayloadAction<string>) => {
state.snackbarMessage = action.payload;
},
setSnackbarSeverity: (state, action: PayloadAction<AlertColor>) => {
state.snackbarSeverity = action.payload;
},
setJobLogs: (state, action: PayloadAction<{ jobName: string; log: string }[]>) => {
state.jobLogs = action.payload;
},
setShowLog: (state, action: PayloadAction<boolean>) => {
state.showLog = action.payload;
},
setPipelineCompleted: (state, action: PayloadAction<boolean>) => {
state.pipelineCompleted = action.payload;
},
setPipelineLoading: (state, action: PayloadAction<boolean>) => {
state.pipelineLoading = action.payload;
},
setButtonText: (state, action: PayloadAction<string>) => {
state.buttonText = action.payload;
},
setExecutionCount: (state, action: PayloadAction<number>) => {
state.executionCount = action.payload;
},
},
});

export const {
setGitlab,
setDigitalTwin,
setDescription,
setExecutionStatus,
setSnackbarOpen,
setSnackbarMessage,
setSnackbarSeverity,
setJobLogs,
setShowLog,
setPipelineCompleted,
setPipelineLoading,
setButtonText,
setExecutionCount,
} = digitalTwinSlice.actions;

export const selectGitlab = (state: { digitalTwin: DigitalTwinState }) => state.digitalTwin.gitlab;
export const selectDigitalTwin = (state: { digitalTwin: DigitalTwinState }) => state.digitalTwin;

export default digitalTwinSlice.reducer;
2 changes: 2 additions & 0 deletions client/src/store/store.ts
Original file line number Diff line number Diff line change
@@ -2,10 +2,12 @@ import { combineReducers } from 'redux';
import { configureStore } from '@reduxjs/toolkit';
import menuSlice from './menu.slice';
import authSlice from './auth.slice';
import digitalTwinSlice from './digitalTwin.slice';

const rootReducer = combineReducers({
menu: menuSlice,
auth: authSlice,
digitalTwin: digitalTwinSlice,
});

const store = configureStore({