2016-08-08 06:47:48 +02:00
|
|
|
var formatItemImgStyle = {
|
2016-07-16 04:58:24 +02:00
|
|
|
maxWidth: '100%',
|
|
|
|
maxHeight: '100%',
|
|
|
|
display: 'block',
|
|
|
|
marginLeft: 'auto',
|
|
|
|
marginRight: 'auto',
|
|
|
|
marginTop: '5px',
|
|
|
|
};
|
|
|
|
|
|
|
|
var FormatItem = React.createClass({
|
|
|
|
propTypes: {
|
2016-07-30 09:47:31 +02:00
|
|
|
claimInfo: React.PropTypes.object,
|
|
|
|
amount: React.PropTypes.number,
|
|
|
|
name: React.PropTypes.string,
|
2016-08-27 00:11:28 +02:00
|
|
|
available: React.PropTypes.bool,
|
2016-07-16 04:58:24 +02:00
|
|
|
},
|
|
|
|
render: function() {
|
2016-07-30 09:47:31 +02:00
|
|
|
|
|
|
|
var claimInfo = this.props.claimInfo;
|
|
|
|
var thumbnail = claimInfo.thumbnail;
|
|
|
|
var title = claimInfo.title;
|
|
|
|
var description = claimInfo.description;
|
|
|
|
var author = claimInfo.author;
|
|
|
|
var language = claimInfo.language;
|
|
|
|
var license = claimInfo.license;
|
2016-08-27 08:37:35 +02:00
|
|
|
var fileContentType = (claimInfo.content_type || claimInfo['content-type']);
|
2016-08-23 07:22:29 +02:00
|
|
|
var available = this.props.available;
|
2016-07-30 09:47:31 +02:00
|
|
|
var amount = this.props.amount || 0.0;
|
2016-07-16 19:14:06 +02:00
|
|
|
|
2016-07-16 04:58:24 +02:00
|
|
|
return (
|
2016-08-08 06:47:48 +02:00
|
|
|
<div className="row-fluid">
|
2016-07-16 04:58:24 +02:00
|
|
|
<div className="span4">
|
2016-08-26 14:03:08 +02:00
|
|
|
<img src={thumbnail || '/img/default-thumb.svg'} alt={'Photo for ' + title} style={formatItemImgStyle} />
|
2016-07-16 04:58:24 +02:00
|
|
|
</div>
|
|
|
|
<div className="span8">
|
2016-08-08 06:47:48 +02:00
|
|
|
<p>{description}</p>
|
2016-08-27 00:06:22 +02:00
|
|
|
<section>
|
|
|
|
<table className="table-standard">
|
|
|
|
<tbody>
|
|
|
|
<tr>
|
|
|
|
<td>Content-Type</td><td>{fileContentType}</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
2016-08-27 00:11:28 +02:00
|
|
|
<td>Cost</td><td><CreditAmount amount={amount} isEstimate={!available}/></td>
|
2016-08-27 00:06:22 +02:00
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>Author</td><td>{author}</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>Language</td><td>{language}</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>License</td><td>{license}</td>
|
|
|
|
</tr>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</section>
|
|
|
|
<section>
|
|
|
|
<WatchLink streamName={this.props.name} button="primary" />
|
|
|
|
<DownloadLink streamName={this.props.name} button="alt" />
|
|
|
|
</section>
|
2016-07-16 04:58:24 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
var FormatsSection = React.createClass({
|
|
|
|
propTypes: {
|
2016-07-30 09:47:31 +02:00
|
|
|
claimInfo: React.PropTypes.object,
|
|
|
|
amount: React.PropTypes.number,
|
2016-07-16 04:58:24 +02:00
|
|
|
name: React.PropTypes.string,
|
2016-08-27 00:11:28 +02:00
|
|
|
available: React.PropTypes.bool,
|
2016-07-16 04:58:24 +02:00
|
|
|
},
|
|
|
|
render: function() {
|
2016-07-16 19:14:06 +02:00
|
|
|
var name = this.props.name;
|
2016-07-30 09:47:31 +02:00
|
|
|
var format = this.props.claimInfo;
|
2016-07-16 19:14:06 +02:00
|
|
|
var title = format.title;
|
2016-07-16 04:58:24 +02:00
|
|
|
|
2016-07-16 19:14:06 +02:00
|
|
|
if(format == null)
|
|
|
|
{
|
|
|
|
return (
|
|
|
|
<div>
|
2016-08-08 06:47:48 +02:00
|
|
|
<h2>Sorry, no results found for "{name}".</h2>
|
2016-07-16 19:14:06 +02:00
|
|
|
</div>);
|
|
|
|
}
|
2016-07-16 04:58:24 +02:00
|
|
|
|
|
|
|
return (
|
2016-07-16 07:19:40 +02:00
|
|
|
<div>
|
2016-08-08 06:47:48 +02:00
|
|
|
<div className="meta">lbry://{name}</div>
|
|
|
|
<h2>{title}</h2>
|
2016-07-16 07:19:40 +02:00
|
|
|
{/* In future, anticipate multiple formats, just a guess at what it could look like
|
2016-07-30 09:47:31 +02:00
|
|
|
// var formats = this.props.claimInfo.formats
|
2016-07-16 07:19:40 +02:00
|
|
|
// return (<tbody>{formats.map(function(format,i){ */}
|
2016-08-23 07:22:29 +02:00
|
|
|
<FormatItem claimInfo={format} amount={this.props.amount} name={this.props.name} available={this.props.available} />
|
2016-07-16 07:19:40 +02:00
|
|
|
{/* })}</tbody>); */}
|
|
|
|
</div>);
|
2016-07-16 04:58:24 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
var DetailPage = React.createClass({
|
|
|
|
propTypes: {
|
|
|
|
name: React.PropTypes.string,
|
|
|
|
},
|
2016-07-16 19:14:06 +02:00
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
2016-07-30 09:47:31 +02:00
|
|
|
claimInfo: null,
|
|
|
|
amount: null,
|
2016-07-16 19:14:06 +02:00
|
|
|
searching: true,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
componentWillMount: function() {
|
2016-08-08 06:47:48 +02:00
|
|
|
document.title = 'lbry://' + this.props.name;
|
|
|
|
|
2016-08-18 09:34:20 +02:00
|
|
|
lbry.search(this.props.name, (results) => {
|
|
|
|
var result = results[0];
|
2016-07-16 19:14:06 +02:00
|
|
|
this.setState({
|
2016-08-23 07:22:29 +02:00
|
|
|
amount: result.cost,
|
|
|
|
available: result.available,
|
2016-08-18 09:34:20 +02:00
|
|
|
claimInfo: result.value,
|
2016-07-16 19:14:06 +02:00
|
|
|
searching: false,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
2016-07-16 04:58:24 +02:00
|
|
|
render: function() {
|
2016-07-30 09:47:31 +02:00
|
|
|
if (this.state.claimInfo == null && this.state.searching) {
|
2016-07-16 19:14:06 +02:00
|
|
|
// Still waiting for metadata
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
var name = this.props.name;
|
2016-08-23 07:22:29 +02:00
|
|
|
var available = this.state.available;
|
2016-07-30 09:47:31 +02:00
|
|
|
var claimInfo = this.state.claimInfo;
|
|
|
|
var amount = this.state.amount;
|
2016-07-16 19:14:06 +02:00
|
|
|
|
2016-07-16 04:58:24 +02:00
|
|
|
return (
|
2016-08-08 06:47:48 +02:00
|
|
|
<main>
|
|
|
|
<section className="card">
|
2016-08-23 07:22:29 +02:00
|
|
|
<FormatsSection name={name} claimInfo={claimInfo} amount={amount} available={available} />
|
2016-08-08 06:47:48 +02:00
|
|
|
</section>
|
2016-07-16 04:58:24 +02:00
|
|
|
</main>);
|
|
|
|
}
|
|
|
|
});
|