/* eslint react/no-multi-comp:off */
import React, { Component, PureComponent } from 'react';
import PropTypes from 'prop-types';
import { Link } from 'react-router';
import {
Grid,
Cell,
Card,
CardTitle,
CardText,
CardMenu,
List,
ListItem,
ListItemContent,
Textfield,
Icon,
ProgressBar,
Tabs,
Tab,
Switch,
} from 'react-mdl';
import { IconLink, shorten, styles as commonStyles } from '../common';
import { formatFullDateTime } from '../common/util';
class StatefulTextfield extends Component {
static propTypes = {
value: PropTypes.string,
label: PropTypes.string,
rows: PropTypes.number,
onBlur: PropTypes.func.isRequired,
};
constructor(props) {
super(props);
this.state = { value: props.value };
this.setValue = function setValue(e) {
this.setState({ value: e.target.value });
}.bind(this);
}
render() {
return (
);
}
}
class ClientApplications extends PureComponent {
static propTypes = {
fetchApplication: PropTypes.func.isRequired,
appName: PropTypes.string,
application: PropTypes.object,
storeApplicationMetaData: PropTypes.func.isRequired,
};
constructor(props) {
super(props);
this.state = { activeTab: 0 };
}
componentDidMount() {
this.props.fetchApplication(this.props.appName);
}
render() {
if (!this.props.application) {
return ;
}
const { application, storeApplicationMetaData } = this.props;
const { appName, instances, strategies, seenToggles, url, description, icon = 'apps', color } = application;
const content =
this.state.activeTab === 0 ? (
Toggles
{seenToggles.map(
({ name, description, enabled, notFound }, i) =>
notFound ? (
{name}
) : (
}
subtitle={shorten(description, 60)}
>
{shorten(name, 50)}
)
)}
|
Implemented strategies
{strategies.map(
({ name, description, notFound }, i) =>
notFound ? (
{name}
) : (
{shorten(name, 50)}
)
)}
|
{instances.length} Instances registered
{instances.map(({ instanceId, clientIp, lastSeen, sdkVersion }, i) => (
{clientIp} last seen at {formatFullDateTime(lastSeen)}
}
>
{instanceId} {sdkVersion ? `(${sdkVersion})` : ''}
))}
|
) : (
Edit app meta data
|
storeApplicationMetaData(appName, 'url', e.target.value)}
/>
storeApplicationMetaData(appName, 'description', e.target.value)}
/>
|
storeApplicationMetaData(appName, 'icon', e.target.value)}
/>
storeApplicationMetaData(appName, 'color', e.target.value)}
/>
|
);
return (
{appName}
{description && {description}}
{url && (
)}
this.setState({ activeTab: tabId })}
ripple
tabBarProps={{ style: { width: '100%' } }}
className="mdl-color--grey-100"
>
Details
Edit
{content}
);
}
}
export default ClientApplications;