0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-20 22:52:46 -05:00

refactor: fixed lint erros - destructuring-assignment

This commit is contained in:
Priscila Oliveira 2019-01-05 23:15:52 +01:00
parent 0529b8e7a9
commit b3ea81e596
5 changed files with 22 additions and 14 deletions

View file

@ -47,7 +47,7 @@
"prettier/prettier": ["error", null, "@prettier"],
"react/no-deprecated": 1,
"react/jsx-no-target-blank": 1,
"react/destructuring-assignment": ["warn", "always"],
"react/destructuring-assignment": ["error", "always"],
"react/forbid-component-props": ["warn", { "forbid": ["style"] }],
"react/no-this-in-sfc": ["warn"],
"react/no-unsafe": ["warn"],

View file

@ -36,7 +36,8 @@ export default class App extends Component {
// eslint-disable-next-line no-unused-vars
componentDidUpdate(_, prevState) {
if (prevState.isUserLoggedIn !== this.state.isUserLoggedIn) {
const { isUserLoggedIn } = this.state;
if (prevState.isUserLoggedIn !== isUserLoggedIn) {
this.loadPackages();
}
}

View file

@ -91,17 +91,19 @@ class Header extends Component<IProps, IState> {
* close/open popover menu for logged in users.
*/
handleToggleLogin = () => {
const { onToggleLoginModal } = this.props;
this.setState(
{
anchorEl: null,
},
this.props.onToggleLoginModal
onToggleLoginModal
);
};
handleToggleMNav = () => {
const { showMobileNavBar } = this.state;
this.setState({
showMobileNavBar: !this.state.showMobileNavBar,
showMobileNavBar: !showMobileNavBar,
});
};

View file

@ -55,11 +55,12 @@ export default class LoginModal extends Component {
* Required to login
*/
setCredentials = (name, e) => {
const { form } = this.state;
this.setState({
form: {
...this.state.form,
...form,
[name]: {
...this.state.form[name],
...form[name],
value: e.target.value,
pristine: false,
},
@ -76,30 +77,32 @@ export default class LoginModal extends Component {
}
validateCredentials = (event) => {
const { form } = this.state;
// prevents default submit behavior
event.preventDefault();
this.setState({
form: Object.keys(this.state.form).reduce((acc, key) => ({
form: Object.keys(form).reduce((acc, key) => ({
...acc,
...{ [key]: {...this.state.form[key], pristine: false } },
...{ [key]: {...form[key], pristine: false } },
}), {}),
}, () => {
if (!Object.keys(this.state.form).some(id => !this.state.form[id])) {
if (!Object.keys(form).some(id => !form[id])) {
this.submitCredentials();
}
});
}
submitCredentials = async () => {
const { form: { username, password } } = this.state;
await this.props.onSubmit(username.value, password.value);
const { form } = this.state;
const { onSubmit } = this.props;
await onSubmit(form.username.value, form.password.value);
// let's wait for API response and then set
// username and password filed to empty state
this.setState({
form: Object.keys(this.state.form).reduce((acc, key) => ({
form: Object.keys(form).reduce((acc, key) => ({
...acc,
...{ [key]: {...this.state.form[key], value: "", pristine: true } },
...{ [key]: {...form[key], value: "", pristine: true } },
}), {}),
});
}

View file

@ -6,13 +6,15 @@ export function asyncComponent(getComponent) {
state = {Component: AsyncComponent.Component};
componentDidMount() {
if (!this.state.Component) {
const { Component } = this.state;
if (!Component) {
getComponent().then(({default: Component}) => {
AsyncComponent.Component = Component;
this.setState({Component});
});
}
}
render() {
const {Component} = this.state;
if (Component) {