import { Component } from 'react'; import PropTypes from 'prop-types'; import { observer } from 'mobx-react'; import { defineMessages, injectIntl } from 'react-intl'; import ReactTooltip from 'react-tooltip'; import injectSheet from 'react-jss'; import classnames from 'classnames'; import Loader from '../../ui/Loader'; import Button from '../../ui/button'; import Infobox from '../../ui/Infobox'; import { H1 } from '../../ui/headline'; import { LIVE_FRANZ_API } from '../../../config'; const messages = defineMessages({ headline: { id: 'settings.team.headline', defaultMessage: 'Team', }, contentHeadline: { id: 'settings.team.contentHeadline', defaultMessage: 'Franz Team Management', }, intro: { id: 'settings.team.intro', defaultMessage: 'You are currently using Franz Servers, which is why you have access to Team Management.', }, copy: { id: 'settings.team.copy', defaultMessage: "Franz's Team Management allows you to manage Franz Subscriptions for multiple users. Please keep in mind that having a Franz Premium subscription will give you no advantages in using Ferdium: The only reason you still have access to Team Management is so you can manage your legacy Franz Teams and so that you don't loose any functionality in managing your account.", }, manageButton: { id: 'settings.team.manageAction', defaultMessage: 'Manage your Team on meetfranz.com', }, teamsUnavailable: { id: 'settings.team.teamsUnavailable', defaultMessage: 'Teams are unavailable', }, teamsUnavailableInfo: { id: 'settings.team.teamsUnavailableInfo', defaultMessage: 'Teams are currently only available when using the Franz Server and after paying for Franz Professional. Please change your server to https://api.franzinfra.com to use teams.', }, tryReloadUserInfoRequest: { id: 'settings.team.tryReloadUserInfoRequest', defaultMessage: 'Try reloading', }, userInfoRequestFailed: { id: 'settings.team.userInfoRequestFailed', defaultMessage: 'User Info request failed', }, }); const styles = { cta: { margin: [40, 'auto'], height: 'auto', }, container: { display: 'flex', flexDirection: 'column', height: 'auto', '@media(min-width: 800px)': { flexDirection: 'row', }, }, content: { height: 'auto', order: 1, '@media(min-width: 800px)': { order: 0, }, }, image: { display: 'block', height: 150, order: 0, margin: [0, 'auto', 40, 'auto'], '@media(min-width: 800px)': { marginLeft: 40, order: 1, }, }, headline: { marginBottom: 0, }, headlineWithSpacing: { marginBottom: 'inherit', }, buttonContainer: { display: 'flex', height: 'auto', }, }; class TeamDashboard extends Component { static propTypes = { isLoading: PropTypes.bool.isRequired, userInfoRequestFailed: PropTypes.bool.isRequired, retryUserInfoRequest: PropTypes.func.isRequired, openTeamManagement: PropTypes.func.isRequired, classes: PropTypes.object.isRequired, server: PropTypes.string.isRequired, }; render() { const { isLoading, userInfoRequestFailed, retryUserInfoRequest, openTeamManagement, classes, server, } = this.props; const { intl } = this.props; if (server === LIVE_FRANZ_API) { return (
{intl.formatMessage(messages.headline)}
{isLoading && } {!isLoading && userInfoRequestFailed && ( {intl.formatMessage(messages.userInfoRequestFailed)} )} {!userInfoRequestFailed && !isLoading && ( <>

{intl.formatMessage(messages.contentHeadline)}

{intl.formatMessage(messages.intro)}

{intl.formatMessage(messages.copy)}

Ferdium for Teams
)}
); } return (
{intl.formatMessage(messages.headline)}

{intl.formatMessage(messages.teamsUnavailable)}

{intl.formatMessage(messages.teamsUnavailableInfo)}

); } } export default injectIntl( injectSheet(styles, { injectTheme: true })(observer(TeamDashboard)), );