lbry-desktop/ui/component/filePrice/view.jsx

78 lines
2 KiB
React
Raw Normal View History

2018-03-26 14:32:43 -07:00
// @flow
2020-05-21 11:38:28 -04:00
import * as ICONS from 'constants/icons';
import React from 'react';
2020-05-21 11:38:28 -04:00
import classnames from 'classnames';
2018-03-26 14:32:43 -07:00
import CreditAmount from 'component/common/credit-amount';
2020-05-21 11:38:28 -04:00
import Icon from 'component/common/icon';
2018-03-26 14:32:43 -07:00
type Props = {
showFullPrice: boolean,
costInfo: ?{ includesData: boolean, cost: number },
fetchCostInfo: string => void,
uri: string,
fetching: boolean,
claim: ?{},
2020-05-21 11:38:28 -04:00
claimWasPurchased: boolean,
claimIsMine: boolean,
type?: string,
2018-07-25 00:23:58 -04:00
// below props are just passed to <CreditAmount />
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,
};
2019-08-21 14:22:51 -04:00
componentDidMount() {
this.fetchCost(this.props);
}
2019-08-21 14:22:51 -04:00
componentDidUpdate() {
this.fetchCost(this.props);
}
fetchCost = (props: Props) => {
const { costInfo, fetchCostInfo, uri, fetching, claim } = props;
if (costInfo === undefined && !fetching && claim) {
2017-06-06 17:19:12 -04:00
fetchCostInfo(uri);
2017-05-12 13:14:06 -04:00
}
};
render() {
2020-05-21 11:38:28 -04:00
const { costInfo, showFullPrice, showLBC, hideFree, claimWasPurchased, type, claimIsMine } = this.props;
if (claimIsMine || !costInfo || !costInfo.cost || (!costInfo.cost && hideFree)) {
2018-08-06 13:58:33 -04:00
return null;
}
2017-05-12 13:14:06 -04:00
2020-05-21 11:38:28 -04:00
return claimWasPurchased ? (
<span
className={classnames('file-price__key', {
'file-price__key--filepage': type === 'filepage',
'file-price__key--modal': type === 'modal',
})}
>
<Icon icon={ICONS.PURCHASED} size={type === 'filepage' ? 22 : undefined} />
</span>
) : (
2017-06-06 17:19:12 -04:00
<CreditAmount
2020-05-21 11:38:28 -04:00
className={classnames('file-price', {
'file-price--filepage': type === 'filepage',
'file-price--modal': type === 'modal',
})}
showFree
2018-07-25 00:23:58 -04:00
showLBC={showLBC}
2017-06-06 17:19:12 -04:00
amount={costInfo.cost}
isEstimate={!costInfo.includesData}
showFullPrice={showFullPrice}
2017-06-06 17:19:12 -04:00
/>
2020-05-21 11:38:28 -04:00
);
2017-05-12 13:14:06 -04:00
}
}
2017-06-05 21:21:55 -07:00
export default FilePrice;