2020-07-21 15:30:18 +03:00
import React , { ComponentType , useCallback , useRef } from 'react' ;
2019-11-11 10:40:05 +02:00
import { FormattedMessage as Message } from 'react-intl' ;
2017-05-25 22:11:57 +03:00
import { Link } from 'react-router-dom' ;
2019-12-30 09:29:39 +02:00
import { Helmet } from 'react-helmet-async' ;
2020-07-22 18:15:58 +03:00
2019-12-07 21:02:00 +02:00
import { ChangeLanguageLink } from 'app/components/languageSwitcher' ;
import { RelativeTime } from 'app/components/ui' ;
2020-07-22 18:15:58 +03:00
import { Button } from 'app/components/ui/form' ;
2019-12-07 21:02:00 +02:00
import { User } from 'app/components/user' ;
import RulesPage from 'app/pages/rules/RulesPage' ;
2019-11-11 10:40:05 +02:00
2016-03-17 08:01:11 +02:00
import ProfileField from './ProfileField' ;
import styles from './profile.scss' ;
2016-04-17 12:35:04 +03:00
import profileForm from './profileForm.scss' ;
2019-06-30 16:32:50 +03:00
type Props = {
2020-05-24 02:08:24 +03:00
user : User ;
2020-07-21 15:30:18 +03:00
activeLocale : string ;
2019-06-30 16:32:50 +03:00
} ;
2020-07-21 15:30:18 +03:00
const Profile : ComponentType < Props > = ( { user , activeLocale } ) = > {
const uuidRef = useRef < HTMLSpanElement > ( ) ;
const onUuidMouseOver = useCallback ( ( ) = > {
if ( ! uuidRef . current ) {
2020-05-24 02:08:24 +03:00
return ;
}
try {
const selection = window . getSelection ( ) ;
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
if ( ! selection ) {
return ;
}
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
const range = document . createRange ( ) ;
2020-07-21 15:30:18 +03:00
range . selectNodeContents ( uuidRef . current ) ;
2020-05-24 02:08:24 +03:00
selection . removeAllRanges ( ) ;
selection . addRange ( range ) ;
} catch ( err ) {
// the browser does not support an API
}
2020-07-21 15:30:18 +03:00
} , [ ] ) ;
return (
< div data-testid = "profile-index" >
< Message key = "accountPreferencesTitle" defaultMessage = "Ely.by account preferences" >
{ ( pageTitle : string ) = > (
< h2 className = { styles . indexTitle } >
< Helmet title = { pageTitle } / >
{ pageTitle }
< / h2 >
) }
< / Message >
< div className = { styles . indexContent } >
< div className = { styles . descriptionColumn } >
< div className = { styles . indexDescription } >
< Message
key = "accountDescription"
defaultMessage = "Ely.by account allows you to get access to many Minecraft resources. Please, take care of your account safety. Use secure password and change it regularly."
/ >
< / div >
< / div >
< div className = { styles . formColumn } >
2020-07-22 18:15:58 +03:00
< div className = { styles . profilePanel } >
2020-07-21 15:30:18 +03:00
< div className = { styles . item } >
< h3 className = { profileForm . title } >
< Message key = "personalData" defaultMessage = "Personal data" / >
< / h3 >
< p className = { profileForm . description } >
< Message
key = "preferencesDescription"
defaultMessage = "Here you can change the key preferences of your account. Please note that all actions must be confirmed by entering a password."
/ >
< / p >
< / div >
2019-11-27 11:03:32 +02:00
2020-07-21 15:30:18 +03:00
< ProfileField
link = "/profile/change-username"
label = { < Message key = "nickname" defaultMessage = "Nickname:" / > }
value = { user . username }
warningMessage = {
user . hasMojangUsernameCollision ? (
< Message
key = "mojangPriorityWarning"
defaultMessage = "A Mojang account with the same nickname was found. According to {rules}, account owner has the right to demand the restoration of control over nickname."
values = { {
rules : (
< Link
to = { {
pathname : '/rules' ,
hash : ` # ${ RulesPage . getRuleHash ( 1 , 4 ) } ` ,
} }
>
< Message key = "projectRules" defaultMessage = "project rules" / >
< / Link >
) ,
} }
/ >
) : (
''
)
}
/ >
< ProfileField
link = "/profile/change-email"
label = { < Message key = "email" defaultMessage = "E‑ mail:" / > }
value = { user . email }
/ >
< ProfileField
label = { < Message key = "siteLanguage" defaultMessage = "Site language:" / > }
value = { < ChangeLanguageLink / > }
warningMessage = {
user . lang === activeLocale ? (
''
) : (
< Message
key = "languageIsUnavailableWarning"
defaultMessage = {
'The locale "{locale}" you\'ve used earlier isn\'t currently translated enough. If you want to continue using the selected language, please {participateInTheTranslation} of the project.'
}
values = { {
locale : user.lang ,
participateInTheTranslation : (
2024-12-03 16:07:41 +05:00
< a href = "https://crowdin.com/project/elyby" target = "_blank" >
2020-07-21 15:30:18 +03:00
< Message
key = "participateInTheTranslation"
defaultMessage = "participate in the translation"
/ >
< / a >
) ,
} }
/ >
)
}
/ >
2020-07-22 18:15:58 +03:00
< ProfileField
label = { < Message key = "uuid" defaultMessage = "UUID:" / > }
value = {
< span
className = { styles . uuid }
ref = { ( ref ) = > ( uuidRef . current = ref ! ) }
onMouseOver = { onUuidMouseOver }
>
{ user . uuid }
< / span >
}
/ >
< / div >
< div className = { styles . profilePanel } >
< div className = { styles . item } >
< h3 className = { profileForm . title } >
< Message key = "accountManagement" defaultMessage = "Account management" / >
< / h3 >
< p className = { profileForm . description } >
< Message
key = "accountManagementDescription"
defaultMessage = "In this area you can manage the security settings of your account. Some operations may cause logout on other devices."
/ >
< / p >
< / div >
< ProfileField
link = "/profile/change-password"
label = { < Message key = "password" defaultMessage = "Password:" / > }
value = {
< Message
key = "changedAt"
defaultMessage = "Changed {at}"
values = { {
at : < RelativeTime timestamp = { user . passwordChangedAt * 1000 } / > ,
} }
/ >
}
/ >
2020-07-21 15:30:18 +03:00
< ProfileField
link = "/profile/mfa"
label = { < Message key = "twoFactorAuth" defaultMessage = "Two‑ factor auth:" / > }
value = {
user . isOtpEnabled ? (
< Message key = "enabled" defaultMessage = "Enabled" / >
) : (
< Message key = "disabled" defaultMessage = "Disabled" / >
)
}
/ >
< ProfileField
value = {
2020-07-28 23:00:51 +03:00
< Button
component = { Link }
// @ts-ignore
to = "/profile/delete"
small
color = "black"
data - testid = "profile-action"
>
2020-07-22 18:15:58 +03:00
< Message key = "accountDeletion" defaultMessage = "Account deletion" / >
< / Button >
2020-07-21 15:30:18 +03:00
}
/ >
< / div >
< / div >
< / div >
< / div >
) ;
} ;
2017-05-25 22:11:57 +03:00
2020-07-21 15:30:18 +03:00
export default Profile ;