// Copyright 2018 Red Hat, Inc // // Licensed under the Apache License, Version 2.0 (the "License"); you may // not use this file except in compliance with the License. You may obtain // a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the // License for the specific language governing permissions and limitations // under the License. import * as React from 'react' import PropTypes from 'prop-types' import { connect } from 'react-redux' import { Table } from 'patternfly-react' import * as moment from 'moment' import { PageSection, PageSectionVariants } from '@patternfly/react-core' import { fetchNodesIfNeeded } from '../actions/nodes' import { Fetchable } from '../containers/Fetching' class NodesPage extends React.Component { static propTypes = { tenant: PropTypes.object, remoteData: PropTypes.object, dispatch: PropTypes.func } updateData = (force) => { this.props.dispatch(fetchNodesIfNeeded(this.props.tenant, force)) } componentDidMount () { document.title = 'Zuul Nodes' if (this.props.tenant.name) { this.updateData() } } componentDidUpdate (prevProps) { if (this.props.tenant.name !== prevProps.tenant.name) { this.updateData() } } render () { const { remoteData } = this.props const nodes = remoteData.nodes const headerFormat = value => {value} const cellFormat = value => {value} const cellLabelsFormat = value => {value.join(',')} const cellPreFormat = value => ( {value} ) const cellAgeFormat = value => ( {moment.unix(value).fromNow()} ) const columns = [] const myColumns = [ 'id', 'labels', 'connection', 'server', 'provider', 'state', 'age', 'comment' ] myColumns.forEach(column => { let formatter = cellFormat let prop = column if (column === 'labels') { prop = 'type' formatter = cellLabelsFormat } else if (column === 'connection') { prop = 'connection_type' } else if (column === 'server') { prop = 'external_id' formatter = cellPreFormat } else if (column === 'age') { prop = 'state_time' formatter = cellAgeFormat } columns.push({ header: {label: column, formatters: [headerFormat]}, property: prop, cell: {formatters: [formatter]} }) }) return ( ) } } export default connect(state => ({ tenant: state.tenant, remoteData: state.nodes, }))(NodesPage)