67 lines
2.8 KiB
TypeScript
Raw Normal View History

2016-05-14 14:26:17 +03:00
import React from 'react';
import { defineMessages, FormattedMessage as Message } from 'react-intl';
import icons from 'app/components/ui/icons.scss';
import { PanelBodyHeader } from 'app/components/ui/Panel';
import BaseAuthBody from 'app/components/auth/BaseAuthBody';
2016-05-14 14:26:17 +03:00
import styles from './permissions.scss';
const scopesMessages = defineMessages({
scope_minecraft_server_session: 'Authorization data for minecraft server',
scope_offline_access: 'Access to your profile data, when you offline',
scope_account_info: 'Access to your profile data (except Email)',
scope_account_email: 'Access to your Email address',
});
2016-05-14 14:26:17 +03:00
export default class PermissionsBody extends BaseAuthBody {
2020-05-24 02:08:24 +03:00
static displayName = 'PermissionsBody';
static panelId = 'permissions';
2020-05-24 02:08:24 +03:00
render() {
const { user } = this.context;
const { scopes } = this.context.auth;
2020-05-24 02:08:24 +03:00
return (
<div>
{this.renderErrors()}
2020-05-24 02:08:24 +03:00
<PanelBodyHeader>
<div className={styles.authInfo}>
<div className={styles.authInfoAvatar}>
{user.avatar ? <img src={user.avatar} /> : <span className={icons.user} />}
</div>
<div className={styles.authInfoTitle}>
<Message key="youAuthorizedAs" defaultMessage="You authorized as:" />
2020-05-24 02:08:24 +03:00
</div>
<div className={styles.authInfoEmail}>{user.username}</div>
</div>
</PanelBodyHeader>
<div className={styles.permissionsContainer}>
<div className={styles.permissionsTitle}>
<Message key="theAppNeedsAccess1" defaultMessage="This application needs access" />
2020-05-24 02:08:24 +03:00
<br />
<Message key="theAppNeedsAccess2" defaultMessage="to your data" />
2020-05-24 02:08:24 +03:00
</div>
<ul className={styles.permissionsList}>
{scopes.map((scope) => {
const key = `scope_${scope}`;
// @ts-ignore
const message = scopesMessages[key];
2020-05-24 02:08:24 +03:00
return (
<li key={key}>
{message ? (
<Message {...message} />
) : (
scope.replace(/^\w|_/g, (match) => match.replace('_', ' ').toUpperCase())
)}
</li>
);
})}
</ul>
</div>
</div>
);
}
2016-05-14 14:26:17 +03:00
}