Merge pull request #1334 from guardicore/ransomware_mode_at_sidebar

Island UI: add island scenario/mode to side navigation
This commit is contained in:
VakarisZ 2021-07-21 08:54:09 +03:00 committed by GitHub
commit 64787faf77
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 40 additions and 7 deletions

View File

@ -29,6 +29,8 @@ import {CompletedSteps} from "./side-menu/CompletedSteps";
import Timeout = NodeJS.Timeout; import Timeout = NodeJS.Timeout;
import IslandHttpClient from "./IslandHttpClient"; import IslandHttpClient from "./IslandHttpClient";
import _ from "lodash"; import _ from "lodash";
import {FontAwesomeIcon} from "@fortawesome/react-fontawesome";
import {faFileCode, faLightbulb} from "@fortawesome/free-solid-svg-icons";
let notificationIcon = require('../images/notification-logo-512x512.png'); let notificationIcon = require('../images/notification-logo-512x512.png');
@ -180,18 +182,35 @@ class AppComponent extends AuthComponent {
getDefaultReport() { getDefaultReport() {
if(this.state.islandMode === 'ransomware'){ if(this.state.islandMode === 'ransomware'){
return Routes.RansomwareReport return Routes.RansomwareReport;
} else { } else {
return Routes.SecurityReport return Routes.SecurityReport;
} }
} }
getIslandModeTitle(){
if(this.state.islandMode === 'ransomware'){
return this.formIslandModeTitle("Ransomware", faFileCode);
} else {
return this.formIslandModeTitle("Custom", faLightbulb);
}
}
formIslandModeTitle(title, icon){
return (<>
<h5 className={'text-muted'}>
<FontAwesomeIcon icon={icon} /> {title}
</h5>
</>)
}
render() { render() {
let defaultSideNavProps = {completedSteps: this.state.completedSteps, let defaultSideNavProps = {completedSteps: this.state.completedSteps,
onStatusChange: this.updateStatus, onStatusChange: this.updateStatus,
islandMode: this.state.islandMode, islandMode: this.state.islandMode,
defaultReport: this.getDefaultReport()} defaultReport: this.getDefaultReport(),
sideNavHeader: this.getIslandModeTitle()}
return ( return (
<Router> <Router>

View File

@ -1,4 +1,4 @@
import React from 'react'; import React, {ReactFragment} from 'react';
import {NavLink} from 'react-router-dom'; import {NavLink} from 'react-router-dom';
import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; import {FontAwesomeIcon} from '@fortawesome/react-fontawesome';
import {faCheck} from '@fortawesome/free-solid-svg-icons/faCheck'; import {faCheck} from '@fortawesome/free-solid-svg-icons/faCheck';
@ -18,11 +18,15 @@ const infectionMonkeyImage = require('../images/infection-monkey.svg');
type Props = { type Props = {
disabled?: boolean, disabled?: boolean,
completedSteps: CompletedSteps, completedSteps: CompletedSteps,
defaultReport: string defaultReport: string,
header?: ReactFragment
} }
const SideNavComponent = ({disabled, completedSteps, defaultReport}: Props) => { const SideNavComponent = ({disabled,
completedSteps,
defaultReport,
header=null}: Props) => {
return ( return (
<> <>
@ -34,6 +38,14 @@ const SideNavComponent = ({disabled, completedSteps, defaultReport}: Props) => {
</NavLink> </NavLink>
<ul className='navigation'> <ul className='navigation'>
{(header !== null) &&
<>
<li>
{header}
</li>
<hr/>
</>}
<li> <li>
<NavLink to={Routes.RunMonkeyPage} className={getNavLinkClass()}> <NavLink to={Routes.RunMonkeyPage} className={getNavLinkClass()}>
<span className='number'>1.</span> <span className='number'>1.</span>

View File

@ -7,6 +7,7 @@ const SidebarLayoutComponent = ({component: Component,
sideNavDisabled = false, sideNavDisabled = false,
completedSteps = null, completedSteps = null,
defaultReport = '', defaultReport = '',
sideNavHeader = (<></>),
...other ...other
}) => ( }) => (
<Route {...other} render={() => { <Route {...other} render={() => {
@ -15,7 +16,8 @@ const SidebarLayoutComponent = ({component: Component,
<Col sm={3} md={3} lg={3} xl={2} className='sidebar'> <Col sm={3} md={3} lg={3} xl={2} className='sidebar'>
<SideNavComponent disabled={sideNavDisabled} <SideNavComponent disabled={sideNavDisabled}
completedSteps={completedSteps} completedSteps={completedSteps}
defaultReport={defaultReport}/> defaultReport={defaultReport}
header={sideNavHeader}/>
</Col> </Col>
<Component {...other} /> <Component {...other} />
</Row>) </Row>)