2017-06-06 17:19:12 -04:00
|
|
|
import React from "react";
|
|
|
|
import { CreditAmount } from "component/common";
|
2017-04-30 00:02:25 +07:00
|
|
|
|
2017-06-07 21:42:19 -07:00
|
|
|
class FilePrice extends React.PureComponent {
|
2017-05-18 13:58:28 -04:00
|
|
|
componentWillMount() {
|
2017-06-06 17:19:12 -04:00
|
|
|
this.fetchCost(this.props);
|
2017-05-12 13:14:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
componentWillReceiveProps(nextProps) {
|
2017-06-06 17:19:12 -04:00
|
|
|
this.fetchCost(nextProps);
|
2017-05-12 13:14:06 -04:00
|
|
|
}
|
2017-04-30 00:02:25 +07:00
|
|
|
|
2017-05-12 13:14:06 -04:00
|
|
|
fetchCost(props) {
|
2017-06-07 21:42:19 -07:00
|
|
|
const { costInfo, fetchCostInfo, uri, fetching, claim } = props;
|
2017-06-05 15:37:37 +07:00
|
|
|
|
|
|
|
if (costInfo === undefined && !fetching && claim) {
|
2017-06-06 17:19:12 -04:00
|
|
|
fetchCostInfo(uri);
|
2017-05-12 13:14:06 -04:00
|
|
|
}
|
2017-04-30 00:02:25 +07:00
|
|
|
}
|
|
|
|
|
2017-05-12 13:14:06 -04:00
|
|
|
render() {
|
2017-06-06 17:19:12 -04:00
|
|
|
const { costInfo, look = "indicator" } = this.props;
|
2017-05-12 13:14:06 -04:00
|
|
|
|
2017-06-06 17:19:12 -04:00
|
|
|
const isEstimate = costInfo ? !costInfo.includesData : null;
|
2017-05-12 13:14:06 -04:00
|
|
|
|
|
|
|
if (!costInfo) {
|
2017-06-06 17:19:12 -04:00
|
|
|
return (
|
|
|
|
<span className={`credit-amount credit-amount--${look}`}>???</span>
|
|
|
|
);
|
2017-05-12 13:14:06 -04:00
|
|
|
}
|
|
|
|
|
2017-06-06 17:19:12 -04:00
|
|
|
return (
|
|
|
|
<CreditAmount
|
|
|
|
label={false}
|
|
|
|
amount={costInfo.cost}
|
|
|
|
isEstimate={isEstimate}
|
|
|
|
showFree={true}
|
|
|
|
/>
|
|
|
|
);
|
2017-05-12 13:14:06 -04:00
|
|
|
}
|
2017-04-30 00:02:25 +07:00
|
|
|
}
|
|
|
|
|
2017-06-05 21:21:55 -07:00
|
|
|
export default FilePrice;
|