// Copyright 2015-2017 Parity Technologies (UK) Ltd. // This file is part of Parity. // Parity is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // Parity is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with Parity. If not, see . import React, { Component, PropTypes } from 'react'; import { nodeOrStringProptype } from '~/util/proptypes'; import styles from './title.css'; export default class Title extends Component { static propTypes = { actions: PropTypes.array, byline: nodeOrStringProptype(), className: PropTypes.string, description: nodeOrStringProptype(), title: nodeOrStringProptype() }; static defaultProps = { actions: [] }; render () { const { className, title } = this.props; return (

{ title }

{ this.renderByline() } { this.renderDescription() }
{ this.renderActions() }
); } renderActions () { const { actions } = this.props; if (actions.length === 0) { return null; } return (
{ actions }
); } renderByline () { const { byline } = this.props; if (!byline) { return null; } return (
{ typeof byline === 'string' ? ( { byline } ) : byline }
); } renderDescription () { const { description } = this.props; if (!description) { return null; } return (
{ typeof description === 'string' ? ( { description } ) : description }
); } }