2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2017-12-21 18:08:54 -03:00
|
|
|
import React from 'react';
|
2018-03-26 14:32:43 -07:00
|
|
|
import CreditAmount from 'component/common/credit-amount';
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
showFullPrice: boolean,
|
|
|
|
costInfo: ?{ includesData: boolean, cost: number },
|
|
|
|
fetchCostInfo: string => void,
|
|
|
|
uri: string,
|
|
|
|
fetching: boolean,
|
|
|
|
claim: ?{},
|
2018-07-25 00:23:58 -04:00
|
|
|
// below props are just passed to <CreditAmount />
|
2018-10-19 16:38:07 -04:00
|
|
|
badge?: boolean,
|
2018-07-25 00:23:58 -04:00
|
|
|
inheritStyle?: boolean,
|
|
|
|
showLBC?: boolean,
|
2018-08-06 13:58:33 -04:00
|
|
|
hideFree?: boolean, // hide the file price if it's free
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
class FilePrice extends React.PureComponent<Props> {
|
|
|
|
static defaultProps = {
|
|
|
|
showFullPrice: false,
|
|
|
|
};
|
2017-04-30 00:02:25 +07:00
|
|
|
|
2019-08-21 14:22:51 -04:00
|
|
|
componentDidMount() {
|
2018-05-03 01:20:31 -04:00
|
|
|
this.fetchCost(this.props);
|
|
|
|
}
|
|
|
|
|
2019-08-21 14:22:51 -04:00
|
|
|
componentDidUpdate() {
|
|
|
|
this.fetchCost(this.props);
|
2018-05-03 01:20:31 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
fetchCost = (props: Props) => {
|
|
|
|
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
|
|
|
}
|
2018-05-03 01:20:31 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
render() {
|
2018-10-19 16:38:07 -04:00
|
|
|
const { costInfo, showFullPrice, badge, inheritStyle, showLBC, hideFree } = this.props;
|
2018-08-06 13:58:33 -04:00
|
|
|
|
|
|
|
if (costInfo && !costInfo.cost && hideFree) {
|
|
|
|
return null;
|
|
|
|
}
|
2017-05-12 13:14:06 -04:00
|
|
|
|
2018-05-25 12:16:17 -04:00
|
|
|
return costInfo ? (
|
2017-06-06 17:19:12 -04:00
|
|
|
<CreditAmount
|
2018-07-24 20:50:04 -04:00
|
|
|
showFree
|
2018-10-19 16:38:07 -04:00
|
|
|
badge={badge}
|
2018-07-25 00:23:58 -04:00
|
|
|
inheritStyle={inheritStyle}
|
|
|
|
showLBC={showLBC}
|
2017-06-06 17:19:12 -04:00
|
|
|
amount={costInfo.cost}
|
2018-05-25 12:16:17 -04:00
|
|
|
isEstimate={!costInfo.includesData}
|
2017-08-22 18:59:36 -06:00
|
|
|
showFullPrice={showFullPrice}
|
2017-06-06 17:19:12 -04:00
|
|
|
/>
|
2018-05-25 12:16:17 -04:00
|
|
|
) : null;
|
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;
|