Sketched out export config modal infrastructure

This commit is contained in:
VakarisZ 2021-05-27 13:36:39 +03:00
parent 243642c1af
commit 3240e1138e
2 changed files with 68 additions and 2 deletions

View File

@ -0,0 +1,53 @@
import {Button, Modal, Form} from 'react-bootstrap';
import React from 'react';
type Props = {
show: boolean,
onClick: () => void
}
const PasswordInput = (props) => {
return (
<div className={'config-export-password-input'}>
<p>Encrypt with a password:</p>
<Form.Control type='password' placeholder='Password' />
</div>
)
}
const ConfigExportModal = (props: Props) => {
return (
<Modal show={props.show}
onHide={props.onClick}
size={'lg'}>
<Modal.Header closeButton>
<Modal.Title>Configuration export</Modal.Title>
</Modal.Header>
<Modal.Body>
<div key={'config-export-option'} className='mb-3'>
<Form.Check
type={'radio'}
id={'password'}
label={<PasswordInput/>}
/>
<Form.Check
type={'radio'}
label={'Skip encryption (export as plaintext)'}
/>
</div>
</Modal.Body>
<Modal.Footer>
<Button variant='secondary' onClick={props.onClick}>
Close
</Button>
<Button variant='primary' onClick={props.onClick}>
Save Changes
</Button>
</Modal.Footer>
</Modal>)
}
export default ConfigExportModal;

View File

@ -14,6 +14,7 @@ import InternalConfig from '../configuration-components/InternalConfig';
import UnsafeOptionsConfirmationModal from '../configuration-components/UnsafeOptionsConfirmationModal.js'; import UnsafeOptionsConfirmationModal from '../configuration-components/UnsafeOptionsConfirmationModal.js';
import UnsafeOptionsWarningModal from '../configuration-components/UnsafeOptionsWarningModal.js'; import UnsafeOptionsWarningModal from '../configuration-components/UnsafeOptionsWarningModal.js';
import isUnsafeOptionSelected from '../utils/SafeOptionValidator.js'; import isUnsafeOptionSelected from '../utils/SafeOptionValidator.js';
import ConfigExportModal from '../configuration-components/ExportConfigModal';
const ATTACK_URL = '/api/attack'; const ATTACK_URL = '/api/attack';
const CONFIG_URL = '/api/configuration/island'; const CONFIG_URL = '/api/configuration/island';
@ -40,7 +41,8 @@ class ConfigurePageComponent extends AuthComponent {
selectedSection: 'attack', selectedSection: 'attack',
showAttackAlert: false, showAttackAlert: false,
showUnsafeOptionsConfirmation: false, showUnsafeOptionsConfirmation: false,
showUnsafeAttackOptionsWarning: false showUnsafeAttackOptionsWarning: false,
showConfigExportModal: false
}; };
} }
@ -220,6 +222,14 @@ class ConfigurePageComponent extends AuthComponent {
this.setState({configuration: newConfig, lastAction: 'none'}); this.setState({configuration: newConfig, lastAction: 'none'});
}; };
renderConfigExportModal = () => {
return (<ConfigExportModal show={this.state.showConfigExportModal}
onClick={this.onExport} />)}
onExport = () => {
this.setState({showConfigExportModal: false})
}
renderAttackAlertModal = () => { renderAttackAlertModal = () => {
return (<Modal show={this.state.showAttackAlert} onHide={() => { return (<Modal show={this.state.showAttackAlert} onHide={() => {
this.setState({showAttackAlert: false}) this.setState({showAttackAlert: false})
@ -488,6 +498,7 @@ class ConfigurePageComponent extends AuthComponent {
<Col sm={{offset: 3, span: 9}} md={{offset: 3, span: 9}} <Col sm={{offset: 3, span: 9}} md={{offset: 3, span: 9}}
lg={{offset: 3, span: 8}} xl={{offset: 2, span: 8}} lg={{offset: 3, span: 8}} xl={{offset: 2, span: 8}}
className={'main'}> className={'main'}>
{this.renderConfigExportModal()}
{this.renderAttackAlertModal()} {this.renderAttackAlertModal()}
{this.renderUnsafeOptionsConfirmationModal()} {this.renderUnsafeOptionsConfirmationModal()}
{this.renderUnsafeAttackOptionsWarningModal()} {this.renderUnsafeAttackOptionsWarningModal()}
@ -509,7 +520,9 @@ class ConfigurePageComponent extends AuthComponent {
</button> </button>
<input id='uploadInputInternal' type='file' accept='.conf' onChange={this.importConfig} <input id='uploadInputInternal' type='file' accept='.conf' onChange={this.importConfig}
style={{display: 'none'}}/> style={{display: 'none'}}/>
<button type='button' onClick={this.exportConfig} className='btn btn-info btn-lg' style={{margin: '5px'}}> <button type='button'
onClick={() => {this.setState({showConfigExportModal: true})}}
className='btn btn-info btn-lg' style={{margin: '5px'}}>
Export config Export config
</button> </button>
</div> </div>