From 8e08ac588cfe37ec8cb8e77ed9ddcf4617150e5c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E3=83=9D=E3=83=BC=E3=83=AB=20=E3=82=A6=E3=82=A7=E3=83=83?= =?UTF-8?q?=E3=83=96?= Date: Thu, 25 Oct 2018 12:13:25 -0500 Subject: [PATCH 1/9] Fixes --- src/renderer/scss/component/_form-field.scss | 2 +- src/renderer/scss/themes/_dark.scss | 15 +++++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/src/renderer/scss/component/_form-field.scss b/src/renderer/scss/component/_form-field.scss index 1fc15ac1f..58588df62 100644 --- a/src/renderer/scss/component/_form-field.scss +++ b/src/renderer/scss/component/_form-field.scss @@ -92,7 +92,7 @@ } .form-field__error { - color: $lbry-red-5; + color: $lbry-red-3 !important; } .form-field__help { diff --git a/src/renderer/scss/themes/_dark.scss b/src/renderer/scss/themes/_dark.scss index 45b1ba2e5..4eb043ec1 100644 --- a/src/renderer/scss/themes/_dark.scss +++ b/src/renderer/scss/themes/_dark.scss @@ -115,4 +115,19 @@ html[data-theme='dark'] { .item-list__item:not(:last-of-type) { border-bottom: 1px solid rgba($lbry-gray-1, 0.1); } + + .modal-overlay, + .error-modal-overlay { + background-color: rgba($lbry-black, 0.7); + } + + .btn { + color: $lbry-gray-3; + } + + .modal { + background-color: rgba($lbry-black, 0.9); + border: 1px solid rgba($lbry-gray-1, 0.1); + color: $lbry-gray-3; + } } -- 2.45.3 From c41bf79e4b67318e31d68f4fcfe3a6229e0837a4 Mon Sep 17 00:00:00 2001 From: Anna Melzer Date: Thu, 25 Oct 2018 23:41:51 +0200 Subject: [PATCH 2/9] Improve type checking for card verify --- src/renderer/component/cardVerify/view.jsx | 71 +++++++++++++++------- 1 file changed, 50 insertions(+), 21 deletions(-) diff --git a/src/renderer/component/cardVerify/view.jsx b/src/renderer/component/cardVerify/view.jsx index 0f3ff4fe0..5d3f3e007 100644 --- a/src/renderer/component/cardVerify/view.jsx +++ b/src/renderer/component/cardVerify/view.jsx @@ -7,6 +7,20 @@ 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, @@ -27,14 +41,20 @@ 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, }; -class CardVerify extends React.Component { - constructor(props) { +type State = { + open: boolean, +}; + +class CardVerifyComponent extends React.Component { + constructor(props: Props) { super(props); this.state = { open: false, }; + this.onClick = this.onClick.bind(this); } componentDidMount() { @@ -65,12 +85,14 @@ class CardVerify extends React.Component { scriptDidError = true; scriptLoading = false; reject(event); - this.onScriptError(event); + this.onScriptError(); }; }); const wrappedPromise = new Promise((accept, cancel) => { - promise.then(() => (canceled ? cancel({ isCanceled: true }) : accept())); - promise.catch(error => (canceled ? cancel({ isCanceled: true }) : cancel(error))); + promise.then(() => (canceled ? cancel(new Error({ isCanceled: true })) : accept())); + promise.catch( + error => (canceled ? cancel(new Error({ isCanceled: true })) : cancel(error)) + ); }); return { @@ -83,7 +105,9 @@ class CardVerify extends React.Component { this.loadPromise.promise.then(this.onScriptLoaded).catch(this.onScriptError); - document.body.appendChild(script); + if (document.body) { + document.body.appendChild(script); + } } componentDidUpdate() { @@ -112,7 +136,7 @@ class CardVerify extends React.Component { } }; - onScriptError = (...args) => { + onScriptError = () => { throw new Error('Unable to load credit validation script.'); }; @@ -120,6 +144,23 @@ class CardVerify extends React.Component { 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, + cancel: Function, + }; + + hasPendingClick: boolean; + updateStripeHandler() { if (!CardVerify.stripeHandler) { CardVerify.stripeHandler = StripeCheckout.configure({ @@ -142,18 +183,6 @@ class CardVerify extends React.Component { }); } - 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 (