/* eslint react/no-multi-comp:off */ import React, { PureComponent } from 'react'; import PropTypes from 'prop-types'; import { Button, Card, CardActions, CardTitle, CardText, CardMenu, Icon, ProgressBar, Tabs, Tab } from 'react-mdl'; import { IconLink, styles as commonStyles } from '../common'; import { formatFullDateTimeWithLocale, formatDateWithLocale } from '../common/util'; import { UPDATE_APPLICATION } from '../../permissions'; import ApplicationView from './application-view'; import ApplicationUpdate from './application-update'; class ClientApplications extends PureComponent { static propTypes = { fetchApplication: PropTypes.func.isRequired, appName: PropTypes.string, application: PropTypes.object, location: PropTypes.object, storeApplicationMetaData: PropTypes.func.isRequired, deleteApplication: PropTypes.func.isRequired, hasPermission: PropTypes.func.isRequired, history: PropTypes.object.isRequired, }; constructor(props) { super(); this.state = { activeTab: 0, loading: !props.application }; } componentDidMount() { this.props.fetchApplication(this.props.appName).finally(() => this.setState({ loading: false })); } formatFullDateTime = v => formatFullDateTimeWithLocale(v, this.props.location.locale); formatDate = v => formatDateWithLocale(v, this.props.location.locale); deleteApplication = async evt => { evt.preventDefault(); const { deleteApplication, appName } = this.props; await deleteApplication(appName); this.props.history.push('/applications'); }; render() { if (this.state.loading) { return (

Loading...

); } else if (!this.props.application) { return

Application ({this.props.appName}) not found

; } const { application, storeApplicationMetaData, hasPermission } = this.props; const { appName, instances, strategies, seenToggles, url, description, icon = 'apps', createdAt } = application; const content = this.state.activeTab === 0 ? ( ) : ( ); return (  {appName}

{description || ''}

Created: {this.formatDate(createdAt)}

{url && ( )} {hasPermission(UPDATE_APPLICATION) ? (

this.setState({ activeTab: tabId })} ripple tabBarProps={{ style: { width: '100%' } }} className="mdl-color--grey-100" > Details Edit
) : ( '' )} {content}
); } } export default ClientApplications;