Skip to content

Commit

Permalink
Merge branch 'bananenwilly-master'
Browse files Browse the repository at this point in the history
  • Loading branch information
peerchemist committed May 29, 2019
2 parents 4685336 + 8fbd52a commit 6ae75fb
Show file tree
Hide file tree
Showing 4 changed files with 148 additions and 54 deletions.
1 change: 1 addition & 0 deletions public/img/eye-regular.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions public/img/eye-slash-regular.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
17 changes: 15 additions & 2 deletions src/components/RegisterPopup/RegisterPopup.css
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,6 @@
font-weight: bold;
text-align: center;
color: var(--color-red);

}

.RegisterPopupComp .register-popup .file {
Expand Down Expand Up @@ -145,4 +144,18 @@
display: block;
position: absolute;
}
}
}

.eye-slash {
content: url(/img/eye-slash-regular.svg);
width: 16px;
margin-left: 1rem;
cursor: pointer;
}

.eye-regular {
content: url(/img/eye-regular.svg);
width: 16px;
margin-left: 1rem;
cursor: pointer;
}
183 changes: 131 additions & 52 deletions src/components/RegisterPopup/RegisterPopup.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import * as React from 'react';
import Loader from 'src/components/Loader/Loader';
import SuccessPopup from 'src/components/SuccessPopup/SuccessPopup';
import ObservableHelper from 'src/helpers/Observable';
import PerperaService from 'src/services/Perpera';
import './RegisterPopup.css';
import * as React from "react";
import Loader from "src/components/Loader/Loader";
import SuccessPopup from "src/components/SuccessPopup/SuccessPopup";
import ObservableHelper from "src/helpers/Observable";
import PerperaService from "src/services/Perpera";
import "./RegisterPopup.css";

interface IState {
errorMsg: string;
Expand All @@ -16,6 +16,7 @@ interface IState {
isSuccess: boolean;
fee?: any;
txid: string;
showPassword: boolean;
}

class RegisterPopup extends React.Component<{}, IState> {
Expand All @@ -25,32 +26,33 @@ class RegisterPopup extends React.Component<{}, IState> {
super(props);

this.state = {
errorMsg: '',
fileName: '',
hash: '',
errorMsg: "",
fileName: "",
hash: "",
isLoading: false,
isOpen: false,
isSuccess: false,
txid: '',
wif: '',
}
showPassword: false,
txid: "",
wif: ""
};

this.handleForm = this.handleForm.bind(this);
this.handleFee = this.handleFee.bind(this);
this.close = this.close.bind(this);
this.handleWIF = this.handleWIF.bind(this);
}

public componentWillMount() {
ObservableHelper.on('onNewFileHash', (payload: any) => {
public componentDidMount() {
ObservableHelper.on("onNewFileHash", (payload: any) => {
this.setState({
fileName: payload.fileName,
hash: payload.hash,
isOpen: true,
originalHash: ''
originalHash: ""
});
});
ObservableHelper.on('onUpdateFileHash', (payload: any) => {
ObservableHelper.on("onUpdateFileHash", (payload: any) => {
this.setState({
fileName: payload.fileName,
hash: payload.hash,
Expand All @@ -68,22 +70,29 @@ class RegisterPopup extends React.Component<{}, IState> {

try {
if (this.state.originalHash) {
const result = await perperaService.updateDocument(this.state.originalHash, this.state.hash, this.state.wif);
const result = await perperaService.updateDocument(
this.state.originalHash,
this.state.hash,
this.state.wif
);
console.log(result);
} else {
const result = await this.reference.commit();
console.log(result);
}
this.setState({ isSuccess: true, isLoading: false });
} catch(e) {
if (e.toString().includes('Insufficient funds')) {
this.setState({ errorMsg: 'Your wallet has no funds.', isLoading: false });
} catch (e) {
if (e.toString().includes("Insufficient funds")) {
this.setState({
errorMsg: "Your wallet has no funds.",
isLoading: false
});
return;
}

console.log(e);

this.setState({ errorMsg: 'WIF invalid.', isLoading: false });
this.setState({ errorMsg: "WIF invalid.", isLoading: false });
}
}

Expand All @@ -94,70 +103,140 @@ class RegisterPopup extends React.Component<{}, IState> {
const perperaService = new PerperaService();

try {
const result = await perperaService.getFee(this.state.hash, this.state.wif);

const result = await perperaService.getFee(
this.state.hash,
this.state.wif
);

this.reference = result.reference;

this.setState({
fee: result.fee,
isLoading: false
});
} catch(e) {
if (e.toString().includes('Insufficient funds')) {
this.setState({ errorMsg: 'Your wallet has no funds.', isLoading: false });
} catch (e) {
if (e.toString().includes("Insufficient funds")) {
this.setState({
errorMsg: "Your wallet has no funds.",
isLoading: false
});
return;
}

console.log(e);

this.setState({ errorMsg: 'WIF invalid.', isLoading: false });
this.setState({ errorMsg: "WIF invalid.", isLoading: false });
}
}

public handleWIF(e: any) {
this.setState({errorMsg: '', wif: e.target.value});
this.setState({ errorMsg: "", wif: e.target.value });
}

public close() {
this.setState({ isOpen: false, isLoading: false });
}

public renderEye = () => {
return this.state.showPassword ? (
<i className="eye-slash" onClick={this.toggleShowPassword} />
) : (
<i className="eye-regular" onClick={this.toggleShowPassword} />
);
};

public toggleShowPassword = () => {
this.setState({ showPassword: !this.state.showPassword });
};

public render() {
const { wif, showPassword } = this.state;
return (
<div className={this.state.isOpen ? 'RegisterPopupComp open' : 'RegisterPopupComp'}>
<div
className={
this.state.isOpen ? "RegisterPopupComp open" : "RegisterPopupComp"
}
>
{this.state.isLoading && <Loader />}
{this.state.isSuccess && <SuccessPopup txid={this.state.txid} text="Your file got registered in the blockchain. Wait at least 10 minutes and use the file hash to check it's registry." />}
{this.state.isSuccess && (
<SuccessPopup
txid={this.state.txid}
text="Your file got registered in the blockchain. Wait at least 10 minutes and use the file hash to check it's registry."
/>
)}
{this.state.isOpen && (
<div className="register-popup">
<button className="close" onClick={this.close}><img src="img/icon-close.svg" alt="Close Popup"/></button>
<button className="close" onClick={this.close}>
<img src="img/icon-close.svg" alt="Close Popup" />
</button>
<div className="file">
<img src="img/icon-file.svg" alt="File" className="file-icon"/>
<img src="img/icon-file.svg" alt="File" className="file-icon" />
<span>{this.state.fileName}</span>
</div>

<div className="hash">
<div className="label">sha256</div>
<div className="hash-string">{this.state.hash}</div>
</div>

{!this.state.fee && <p>Fee to be calculated.</p>}
{this.state.fee && <p>Saving this hash on blockchain will cost you a transaction fee of <b className="bold-green">{this.state.fee} PPC</b>.</p>}

{!this.state.fee && <form className="form" onSubmit={this.handleFee}>
<label>Insert your WIF:</label>
<textarea className="form-field" autoCorrect="false" placeholder="Type WIF here..." value={this.state.wif.trim()} onChange={this.handleWIF} />
{this.state.errorMsg && <div className="error-msg">{this.state.errorMsg}</div>}
<button className="form-submit" disabled={this.state.isLoading || this.state.isSuccess}>Calculate Fee</button>
</form>}

{this.state.fee && <form className="form" onSubmit={this.handleForm}>
<label>Insert your WIF:</label>
<textarea className="form-field" autoCorrect="false" placeholder="Type WIF here..." value={this.state.wif.trim()} onChange={this.handleWIF} />
{this.state.errorMsg && <div className="error-msg">{this.state.errorMsg}</div>}
<button className="form-submit" disabled={this.state.isLoading || this.state.isSuccess}>{this.state.originalHash ? 'Update' : 'Register'} Document</button>
</form>}

<p>After registering, you will have to wait for at least one new block to be sure your entry is registered with the blockchain.</p>
{this.state.fee && (
<p>
Saving this hash on blockchain will cost you a transaction fee
of <b className="bold-green">{this.state.fee} PPC</b>.
</p>
)}

{!this.state.fee && (
<form className="form" onSubmit={this.handleFee}>
<label>Insert your WIF:{this.renderEye()}</label>
<input
className="form-field"
autoCorrect="false"
placeholder="Type WIF here..."
value={wif.trim()}
onChange={this.handleWIF}
type={showPassword ? "text" : "password"}
/>
{this.state.errorMsg && (
<div className="error-msg">{this.state.errorMsg}</div>
)}
<button
className="form-submit"
disabled={this.state.isLoading || this.state.isSuccess}
>
Calculate Fee
</button>
</form>
)}

{this.state.fee && (
<form className="form" onSubmit={this.handleForm}>
<label>Insert your WIF:{this.renderEye()}</label>
<input
className="form-field"
autoCorrect="false"
placeholder="Type WIF here..."
value={wif.trim()}
onChange={this.handleWIF}
type={showPassword ? "text" : "password"}
/>
{this.state.errorMsg && (
<div className="error-msg">{this.state.errorMsg}</div>
)}
<button
className="form-submit"
disabled={this.state.isLoading || this.state.isSuccess}
>
{this.state.originalHash ? "Update" : "Register"} Document
</button>
</form>
)}

<p>
After registering, you will have to wait for at least one new
block to be sure your entry is registered with the blockchain.
</p>
</div>
)}
</div>
Expand Down

0 comments on commit 6ae75fb

Please sign in to comment.