Report section set to full width, icons added

This commit is contained in:
VakarisZ 2019-12-03 12:58:57 +02:00
parent 6185dbfeab
commit 064a0b17e6
5 changed files with 27 additions and 11 deletions

View File

@ -146,7 +146,7 @@ class ReportPageComponent extends AuthComponent {
content = <MustRunMonkeyWarning/>; content = <MustRunMonkeyWarning/>;
} }
return ( return (
<Col xs={12} lg={10}> <Col xs={12} lg={12}>
<h1 className='page-title no-print'>4. Security Reports</h1> <h1 className='page-title no-print'>4. Security Reports</h1>
{this.renderNav()} {this.renderNav()}
<MonkeysStillAliveWarning allMonkeysAreDead={this.state.allMonkeysAreDead}/> <MonkeysStillAliveWarning allMonkeysAreDead={this.state.allMonkeysAreDead}/>

View File

@ -3,7 +3,7 @@ import {Col, Button} from 'react-bootstrap';
import '../../styles/Collapse.scss'; import '../../styles/Collapse.scss';
import '../../styles/report/AttackReport.scss'; import '../../styles/report/AttackReport.scss';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faCircle } from '@fortawesome/free-solid-svg-icons'; import {faCircle, faEye, faEyeSlash, faRadiation} from '@fortawesome/free-solid-svg-icons';
import ReportHeader, {ReportTypes} from './common/ReportHeader'; import ReportHeader, {ReportTypes} from './common/ReportHeader';
import {ScanStatus} from '../attack/techniques/Helpers'; import {ScanStatus} from '../attack/techniques/Helpers';
@ -65,6 +65,17 @@ class AttackReport extends React.Component {
} }
} }
static getStatusIcon(tech_id, techniques){
switch (techniques[tech_id].status){
case ScanStatus.SCANNED:
return <FontAwesomeIcon icon={faEye} className={"technique-status-icon"}/>;
case ScanStatus.USED:
return <FontAwesomeIcon icon={faRadiation} className={"technique-status-icon"}/>;
default:
return <FontAwesomeIcon icon={faEyeSlash} className={"technique-status-icon"}/>;
}
}
renderLegend() { renderLegend() {
return (<div id='header' className='row justify-content-between attack-legend'> return (<div id='header' className='row justify-content-between attack-legend'>
<Col xs={4}> <Col xs={4}>

View File

@ -32,7 +32,10 @@ class SelectedTechnique extends React.Component {
<button className={classNames('btn-collapse', <button className={classNames('btn-collapse',
'selected-technique', 'selected-technique',
AttackReport.getComponentClass(tech_id, this.state.techniques))}> AttackReport.getComponentClass(tech_id, this.state.techniques))}>
<span>{this.state.techniques[tech_id].title}</span> <span>
{AttackReport.getStatusIcon(tech_id, this.state.techniques)}
{this.state.techniques[tech_id].title}
</span>
<span> <span>
<a href={this.state.techniques[tech_id].link} target='_blank' className={'link-to-technique'}> <a href={this.state.techniques[tech_id].link} target='_blank' className={'link-to-technique'}>
<FontAwesomeIcon icon={faQuestionCircle}/> <FontAwesomeIcon icon={faQuestionCircle}/>

View File

@ -34,7 +34,10 @@ class TechniqueDropdowns extends React.Component{
<div key={tech_id} className={classNames('collapse-item', {'item--active': this.state.collapseOpen === tech_id})}> <div key={tech_id} className={classNames('collapse-item', {'item--active': this.state.collapseOpen === tech_id})}>
<button className={classNames('btn-collapse', AttackReport.getComponentClass(tech_id, this.state.techniques))} <button className={classNames('btn-collapse', AttackReport.getComponentClass(tech_id, this.state.techniques))}
onClick={() => this.onToggle(tech_id)}> onClick={() => this.onToggle(tech_id)}>
<span>{this.state.techniques[tech_id].title}</span> <span>
{AttackReport.getStatusIcon(tech_id, this.state.techniques)}
{this.state.techniques[tech_id].title}
</span>
<span> <span>
<a href={this.state.techniques[tech_id].link} target='_blank' className={'link-to-technique'}> <a href={this.state.techniques[tech_id].link} target='_blank' className={'link-to-technique'}>
<FontAwesomeIcon icon={faQuestionCircle}/> <FontAwesomeIcon icon={faQuestionCircle}/>

View File

@ -26,12 +26,6 @@
cursor: default; cursor: default;
} }
.attack-report {
padding: 0 !important;
-webkit-box-shadow: none !important;
box-shadow: none !important;
}
.attack-report .padded{ .attack-report .padded{
padding: 2em 2em 0 2em; padding: 2em 2em 0 2em;
} }
@ -53,7 +47,7 @@
.attack-report .toggle-btn { .attack-report .toggle-btn {
padding: 0; padding: 0;
margin-bottom: 33px; margin-bottom: 30px;
margin-left: 6px; margin-left: 6px;
outline: none !important; outline: none !important;
font-size: 15px; font-size: 15px;
@ -81,3 +75,8 @@
transform: scaleX(-1); transform: scaleX(-1);
color: gray; color: gray;
} }
.technique-status-icon {
padding-right:5px;
margin-bottom: 1px;
}