2019-12-30 10:47:29 +02:00
import React from 'react' ;
2020-06-04 19:41:27 +03:00
import { defineMessages , FormattedMessage as Message } from 'react-intl' ;
2019-12-30 09:29:39 +02:00
import { Helmet } from 'react-helmet-async' ;
2020-05-24 02:08:24 +03:00
import { Input , Button , Checkbox , Form , FormModel } from 'app/components/ui/form' ;
2019-12-07 21:02:00 +02:00
2019-12-30 10:47:29 +02:00
import { BackButton } from '../ProfileForm' ;
import styles from '../profileForm.scss' ;
2020-06-04 19:41:27 +03:00
const labels = defineMessages ( {
newPasswordLabel : 'New password:' ,
repeatNewPasswordLabel : 'Repeat the password:' ,
logoutOnAllDevices : 'Logout on all devices' ,
} ) ;
2016-04-17 12:35:04 +03:00
2019-12-30 10:47:29 +02:00
interface Props {
2020-05-24 02:08:24 +03:00
form : FormModel ;
onSubmit : ( form : FormModel ) = > Promise < void > ;
2019-12-30 10:47:29 +02:00
}
2016-05-01 20:50:55 +03:00
2019-12-30 10:47:29 +02:00
export default class ChangePassword extends React . Component < Props > {
2020-05-24 02:08:24 +03:00
static get defaultProps ( ) : Partial < Props > {
return {
form : new FormModel ( ) ,
} ;
}
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
render() {
const { form } = this . props ;
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
return (
< Form onSubmit = { this . onFormSubmit } form = { form } >
< div className = { styles . contentWithBackButton } >
< BackButton / >
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
< div className = { styles . form } >
< div className = { styles . formBody } >
2020-06-04 19:41:27 +03:00
< Message key = "changePasswordTitle" defaultMessage = "Change password" >
2020-05-24 02:08:24 +03:00
{ ( pageTitle ) = > (
< h3 className = { styles . title } >
< Helmet title = { pageTitle as string } / >
{ pageTitle }
< / h3 >
) }
< / Message >
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
< div className = { styles . formRow } >
< p className = { styles . description } >
2020-06-04 19:41:27 +03:00
< Message
key = "changePasswordDescription"
defaultMessage = "Please take a password, that will be different from your passwords on the other sites and will not be the same you are using to enter Minecraft game servers you are playing."
/ >
2020-05-24 02:08:24 +03:00
< br / >
< b >
2020-06-04 19:41:27 +03:00
< Message
key = "achievementLossWarning"
defaultMessage = "Are you cherish your game achievements, right?"
/ >
2020-05-24 02:08:24 +03:00
< / b >
< / p >
< / div >
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
< div className = { styles . formRow } >
< Input
{ . . . form . bindField ( 'newPassword' ) }
type = "password"
required
skin = "light"
2020-06-04 19:41:27 +03:00
label = { labels . newPasswordLabel }
2020-05-24 02:08:24 +03:00
/ >
< / div >
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
< div className = { styles . formRow } >
< p className = { styles . description } >
2020-06-04 19:41:27 +03:00
< Message
key = "passwordRequirements"
defaultMessage = "Password must contain at least 8 characters. It can be any symbols — do not limit yourself, create an unpredictable password!"
/ >
2020-05-24 02:08:24 +03:00
< / p >
< / div >
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
< div className = { styles . formRow } >
< Input
{ . . . form . bindField ( 'newRePassword' ) }
type = "password"
required
skin = "light"
2020-06-04 19:41:27 +03:00
label = { labels . repeatNewPasswordLabel }
2020-05-24 02:08:24 +03:00
/ >
< / div >
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
< div className = { styles . formRow } >
< Checkbox
{ . . . form . bindField ( 'logoutAll' ) }
defaultChecked
skin = "light"
2020-06-04 19:41:27 +03:00
label = { labels . logoutOnAllDevices }
2020-05-24 02:08:24 +03:00
/ >
< / div >
< / div >
2019-11-27 11:03:32 +02:00
2020-07-22 14:20:10 +03:00
< Button color = "green" block type = "submit" >
< Message key = "changePasswordButton" defaultMessage = "Change password" / >
< / Button >
2020-05-24 02:08:24 +03:00
< / div >
< / div >
< / Form >
) ;
}
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
onFormSubmit = ( ) = > {
const { form } = this . props ;
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
this . props . onSubmit ( form ) . catch ( ( resp ) = > {
if ( resp . errors ) {
form . setErrors ( resp . errors ) ;
} else {
return Promise . reject ( resp ) ;
}
} ) ;
} ;
2016-04-17 12:35:04 +03:00
}