Password UI
This commit is contained in:
@@ -4,13 +4,18 @@ import CheckBox from '../../../components/UI/CheckBox/CheckBox';
|
||||
import {connect} from 'react-redux';
|
||||
import {faInfoCircle} from '@fortawesome/free-solid-svg-icons';
|
||||
import {FontAwesomeIcon} from '@fortawesome/react-fontawesome';
|
||||
import {notifyInfo} from '../../../redux/actions/error_actions';
|
||||
import {
|
||||
notifyError,
|
||||
notifyInfo
|
||||
} from '../../../redux/actions/error_actions';
|
||||
import settings from '../../../assets/settings';
|
||||
import DropDown from '../../../components/UI/DropDown/DropDown';
|
||||
import Password from '../../../containers/UI/Password/Password';
|
||||
|
||||
const mapDispatchToProps = dispatch => {
|
||||
return {
|
||||
notifyInfo: (title, msg) => dispatch(notifyInfo(title, msg))
|
||||
notifyError: msg => dispatch(notifyError(msg)),
|
||||
notifyInfo: (title, msg) => dispatch(notifyInfo(title, msg)),
|
||||
}
|
||||
};
|
||||
|
||||
@@ -68,12 +73,29 @@ export default connect(null, mapDispatchToProps)(props => {
|
||||
break;
|
||||
|
||||
case 'string':
|
||||
data = <input onChange={e=>handleChanged(e)}
|
||||
if (props.template.subtype === 'password') {
|
||||
data = (
|
||||
<Password autoFocus={props.autoFocus}
|
||||
changed={s => handleChanged({
|
||||
target: {
|
||||
type: 'password',
|
||||
value: s,
|
||||
},
|
||||
})}
|
||||
disabled={props.readOnly}
|
||||
mismatchHandler={() => props.notifyError('Passwords do not match')}
|
||||
value={props.value} />
|
||||
);
|
||||
} else {
|
||||
data = (
|
||||
<input onChange={e => handleChanged(e)}
|
||||
autoFocus={props.autoFocus}
|
||||
className={'ConfigurationItemInput'}
|
||||
disabled={props.readOnly}
|
||||
type={'text'}
|
||||
value={props.value}/>;
|
||||
value={props.value}/>
|
||||
);
|
||||
}
|
||||
break;
|
||||
|
||||
case 'uint8':
|
||||
@@ -132,6 +154,21 @@ export default connect(null, mapDispatchToProps)(props => {
|
||||
);
|
||||
break;
|
||||
|
||||
case 'password':
|
||||
data = (
|
||||
<Password autoFocus={props.autoFocus}
|
||||
changed={s => handleChanged({
|
||||
target: {
|
||||
type: 'password',
|
||||
value: s,
|
||||
},
|
||||
})}
|
||||
disabled={props.readOnly}
|
||||
mismatchHandler={() => props.notifyError('Passwords do not match')}
|
||||
value={props.value} />
|
||||
);
|
||||
break;
|
||||
|
||||
default:
|
||||
data = <div>{props.value}</div>;
|
||||
}
|
||||
|
||||
33
src/containers/UI/Password/Password.css
Normal file
33
src/containers/UI/Password/Password.css
Normal file
@@ -0,0 +1,33 @@
|
||||
.PasswordOwner {
|
||||
padding: 0;
|
||||
width: auto;
|
||||
height: auto;
|
||||
display: flex;
|
||||
justify-content: left;
|
||||
align-content: center;
|
||||
flex-direction: row;
|
||||
}
|
||||
|
||||
input.PasswordInput {
|
||||
display: block;
|
||||
margin-right: var(--default_spacing);
|
||||
padding: 2px;
|
||||
border-radius: var(--border_radius);
|
||||
background: rgba(160, 160, 160, 0.1);
|
||||
border: none;
|
||||
box-shadow: none;
|
||||
outline: none;
|
||||
color: var(--text_color);
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
.PasswordShowHide {
|
||||
padding-top: 2px;
|
||||
cursor: pointer;
|
||||
min-width: 20px;
|
||||
}
|
||||
|
||||
.PasswordLink {
|
||||
margin-right: var(--default_spacing);
|
||||
cursor: pointer;
|
||||
}
|
||||
133
src/containers/UI/Password/Password.js
Normal file
133
src/containers/UI/Password/Password.js
Normal file
@@ -0,0 +1,133 @@
|
||||
import React, {Component} from 'react';
|
||||
import './Password.css';
|
||||
import {faEye, faEyeSlash} from '@fortawesome/free-solid-svg-icons';
|
||||
import {FontAwesomeIcon} from '@fortawesome/react-fontawesome';
|
||||
|
||||
export default class extends Component {
|
||||
state = {
|
||||
button_text: 'clear',
|
||||
password: '',
|
||||
password2: '',
|
||||
show_password: false,
|
||||
};
|
||||
|
||||
componentDidMount() {
|
||||
if (!this.props.value || (this.props.value.length === 0)) {
|
||||
this.setState({
|
||||
...this.state,
|
||||
button_text: 'set',
|
||||
password: '',
|
||||
password2: '',
|
||||
show_password: false,
|
||||
})
|
||||
} else {
|
||||
this.setState({
|
||||
...this.state,
|
||||
button_text: 'clear',
|
||||
password: this.props.value,
|
||||
password2: '',
|
||||
show_password: false,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
handleActionClick = () => {
|
||||
if (!this.props.disabled) {
|
||||
switch (this.state.button_text) {
|
||||
case 'clear':
|
||||
this.setState({
|
||||
...this.state,
|
||||
button_text: 'set',
|
||||
password: '',
|
||||
password2: '',
|
||||
});
|
||||
break;
|
||||
|
||||
case 'confirm':
|
||||
if (this.state.password === this.state.password2) {
|
||||
this.props.changed(this.state.password);
|
||||
this.setState({
|
||||
...this.state,
|
||||
button_text: 'clear',
|
||||
password2: '',
|
||||
});
|
||||
} else {
|
||||
this.setState({
|
||||
...this.state,
|
||||
button_text: 'set',
|
||||
password: '',
|
||||
password2: '',
|
||||
}, () => {
|
||||
if (this.props.mismatchHandler) {
|
||||
this.props.mismatchHandler();
|
||||
}
|
||||
});
|
||||
}
|
||||
break;
|
||||
|
||||
case 'set':
|
||||
this.setState({
|
||||
...this.state,
|
||||
button_text: 'confirm',
|
||||
password2: '',
|
||||
});
|
||||
break;
|
||||
|
||||
default:
|
||||
return;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
handlePasswordChanged = e => {
|
||||
if (this.state.button_text === 'set') {
|
||||
this.setState({
|
||||
...this.state,
|
||||
password: e.target.value,
|
||||
});
|
||||
} else if (this.state.button_text === 'confirm') {
|
||||
this.setState({
|
||||
...this.state,
|
||||
password2: e.target.value,
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
handlePasswordKeyUp = e => {
|
||||
if ((e.keyCode === 13) && ((this.state.button_text === 'confirm') || (this.state.button_text === 'set'))) {
|
||||
this.handleActionClick();
|
||||
}
|
||||
};
|
||||
|
||||
handleShowHideClick = () => {
|
||||
this.setState({
|
||||
...this.state,
|
||||
show_password: !this.state.show_password,
|
||||
});
|
||||
};
|
||||
|
||||
render() {
|
||||
return (
|
||||
<div className={'PasswordOwner'}>
|
||||
<a href={'#'}
|
||||
className={'PasswordLink'}
|
||||
onClick={this.handleActionClick}>
|
||||
<u>{this.state.button_text}</u>
|
||||
</a>
|
||||
<input
|
||||
onChange={this.handlePasswordChanged}
|
||||
onKeyUp={this.handlePasswordKeyUp}
|
||||
autoFocus={this.props.autoFocus}
|
||||
className={'PasswordInput'}
|
||||
disabled={this.props.readOnly || (this.state.button_text === 'clear')}
|
||||
type={this.state.show_password ? 'text' : 'password'}
|
||||
value={(this.state.button_text === 'confirm') ? this.state.password2 : this.state.password} />
|
||||
<a href={'#'}
|
||||
className={'PasswordShowHide'}
|
||||
onClick={this.handleShowHideClick}>
|
||||
<FontAwesomeIcon icon={this.state.show_password ? faEye : faEyeSlash} />
|
||||
</a>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
};
|
||||
@@ -79,7 +79,6 @@ export const getIPCRenderer = () => {
|
||||
|
||||
export const getNewReleases = (existingLocations, newLocations, selectedVersion) => {
|
||||
const ret = [];
|
||||
console.log(selectedVersion);
|
||||
if (existingLocations && newLocations) {
|
||||
Constants.RELEASE_TYPES.forEach(release => {
|
||||
newLocations[release]
|
||||
|
||||
Reference in New Issue
Block a user