54 lines
1.2 KiB
JavaScript
54 lines
1.2 KiB
JavaScript
// @flow
|
|
import React from 'react';
|
|
import FilePrice from 'component/filePrice';
|
|
import { Modal } from 'modal/modal';
|
|
|
|
type Props = {
|
|
closeModal: () => void,
|
|
loadVideo: string => void,
|
|
uri: string,
|
|
cancelPurchase: () => void,
|
|
metadata: StreamMetadata,
|
|
};
|
|
|
|
class ModalAffirmPurchase extends React.PureComponent<Props> {
|
|
constructor() {
|
|
super();
|
|
|
|
(this: any).onAffirmPurchase = this.onAffirmPurchase.bind(this);
|
|
}
|
|
|
|
onAffirmPurchase() {
|
|
this.props.closeModal();
|
|
this.props.loadVideo(this.props.uri);
|
|
}
|
|
|
|
render() {
|
|
const {
|
|
cancelPurchase,
|
|
metadata: { title },
|
|
uri,
|
|
} = this.props;
|
|
|
|
return (
|
|
<Modal
|
|
type="confirm"
|
|
isOpen
|
|
title={__('Confirm Purchase')}
|
|
contentLabel={__('Confirm Purchase')}
|
|
onConfirmed={this.onAffirmPurchase}
|
|
onAborted={cancelPurchase}
|
|
>
|
|
<p className="card__subtitle">
|
|
{__('This will purchase')} <strong>{title ? `"${title}"` : uri}</strong> {__('for')}{' '}
|
|
<strong>
|
|
<FilePrice uri={uri} showFullPrice inheritStyle showLBC={false} />
|
|
</strong>{' '}
|
|
{__('credits')}.
|
|
</p>
|
|
</Modal>
|
|
);
|
|
}
|
|
}
|
|
|
|
export default ModalAffirmPurchase;
|