Revert "Improve type checking for card verify" #2074

Merged
neb-b merged 1 commit from revert-2057-types/cardverify into master 2018-10-30 18:35:48 +01:00

View file

@ -7,20 +7,6 @@ let scriptLoading = false;
let scriptLoaded = false;
let scriptDidError = false;
declare class CardVerify {
static stripeHandler: {
open: Function,
close: Function,
};
}
declare class StripeCheckout {
static configure({}): {
open: Function,
close: Function,
};
}
type Props = {
disabled: boolean,
label: ?string,
@ -41,20 +27,14 @@ type Props = {
// token.id can be used to create a charge or customer.
// token.email contains the email address entered by the user.
token: string,
email: string,
};
type State = {
open: boolean,
};
class CardVerifyComponent extends React.Component<Props, State> {
constructor(props: Props) {
class CardVerify extends React.Component {
constructor(props) {
super(props);
this.state = {
open: false,
};
this.onClick = this.onClick.bind(this);
}
componentDidMount() {
@ -85,14 +65,12 @@ class CardVerifyComponent extends React.Component<Props, State> {
scriptDidError = true;
scriptLoading = false;
reject(event);
this.onScriptError();
this.onScriptError(event);
};
});
const wrappedPromise = new Promise((accept, cancel) => {
promise.then(() => (canceled ? cancel(new Error({ isCanceled: true })) : accept()));
promise.catch(
error => (canceled ? cancel(new Error({ isCanceled: true })) : cancel(error))
);
promise.then(() => (canceled ? cancel({ isCanceled: true }) : accept()));
promise.catch(error => (canceled ? cancel({ isCanceled: true }) : cancel(error)));
});
return {
@ -105,9 +83,7 @@ class CardVerifyComponent extends React.Component<Props, State> {
this.loadPromise.promise.then(this.onScriptLoaded).catch(this.onScriptError);
if (document.body) {
document.body.appendChild(script);
}
document.body.appendChild(script);
}
componentDidUpdate() {
@ -136,7 +112,7 @@ class CardVerifyComponent extends React.Component<Props, State> {
}
};
onScriptError = () => {
onScriptError = (...args) => {
throw new Error('Unable to load credit validation script.');
};
@ -144,23 +120,6 @@ class CardVerifyComponent extends React.Component<Props, State> {
this.setState({ open: false });
};
onClick = () => {
if (scriptDidError) {
throw new Error('Tried to call onClick, but StripeCheckout failed to load');
} else if (CardVerify.stripeHandler) {
this.showStripeDialog();
} else {
this.hasPendingClick = true;
}
};
loadPromise: {
promise: Promise<any>,
cancel: Function,
};
hasPendingClick: boolean;
updateStripeHandler() {
if (!CardVerify.stripeHandler) {
CardVerify.stripeHandler = StripeCheckout.configure({
@ -183,6 +142,18 @@ class CardVerifyComponent extends React.Component<Props, State> {
});
}
onClick = () => {
if (scriptDidError) {
try {
throw new Error('Tried to call onClick, but StripeCheckout failed to load');
} catch (x) {}
} else if (CardVerify.stripeHandler) {
this.showStripeDialog();
} else {
this.hasPendingClick = true;
}
};
render() {
return (
<Button
@ -190,10 +161,10 @@ class CardVerifyComponent extends React.Component<Props, State> {
label={this.props.label}
icon={icons.LOCK}
disabled={this.props.disabled || this.state.open || this.hasPendingClick}
onClick={this.onClick}
onClick={this.onClick.bind(this)}
/>
);
}
}
export default CardVerifyComponent;
export default CardVerify;