Use cards in contract deployment

This commit is contained in:
Anthony Laibe 2018-10-18 15:22:44 +01:00 committed by Pascal Precht
parent 8740c8c0c9
commit 627fec5b49
No known key found for this signature in database
GPG Key ID: 0EE28D8D6FD85D7D

View File

@ -11,13 +11,15 @@ import {
Button, Button,
Card, Card,
CardHeader, CardHeader,
CardTitle,
CardBody CardBody
} from 'reactstrap'; } from 'reactstrap';
import classNames from 'classnames'; import classNames from 'classnames';
import {DEPLOYMENT_PIPELINES} from '../constants'; import {DEPLOYMENT_PIPELINES} from '../constants';
import Description from './Description';
const orderClassName = (address) => { const orderClassName = (address) => {
return classNames({ return classNames('mr-4', {
badge: true, badge: true,
'badge-success': address, 'badge-success': address,
'badge-secondary': !address 'badge-secondary': !address
@ -35,15 +37,20 @@ const NoWeb3 = () => (
</Row> </Row>
) )
const LayoutContract = ({contract, children}) => ( const LayoutContract = ({contract, children, cardTitle}) => (
<Row className="border-bottom border-primary pb-3 mt-4"> <Card>
<Col xs={1} className="text-center"> <CardHeader>
<h4><span className={orderClassName(contract.address)}>{contract.index + 1}</span></h4> <CardTitle>
</Col> <h4>
<Col xs={11}> <span className={orderClassName(contract.address)}>{contract.index + 1}</span>
{cardTitle}
</h4>
</CardTitle>
</CardHeader>
<CardBody>
{children} {children}
</Col> </CardBody>
</Row> </Card>
) )
const DeploymentResult = ({deployment}) => { const DeploymentResult = ({deployment}) => {
@ -59,14 +66,9 @@ const DeploymentResult = ({deployment}) => {
<React.Fragment> <React.Fragment>
<p className="text-success">Deployment succeed:</p> <p className="text-success">Deployment succeed:</p>
<dl class="row"> <dl class="row">
<dt class="col-sm-3">Transaction</dt> <Description label="Transaction" value={deployment.transactionHash} />
<dd class="col-sm-9">{deployment.transactionHash}</dd> <Description label="Gas used" value={deployment.gasUsed} />
<Description label="Address" value={deployment.contractAddress} />
<dt class="col-sm-3">Gas used</dt>
<dd class="col-sm-9">{deployment.gasUsed}</dd>
<dt class="col-sm-3">Address</dt>
<dd class="col-sm-9">{deployment.contractAddress}</dd>
</dl> </dl>
</React.Fragment> </React.Fragment>
) )
@ -111,25 +113,24 @@ class Web3Contract extends React.Component {
const isInterface = !abiConstructor; const isInterface = !abiConstructor;
const argumentsRequired = abiConstructor && abiConstructor.inputs.length > 0; const argumentsRequired = abiConstructor && abiConstructor.inputs.length > 0;
return ( return (
<LayoutContract contract={this.props.contract}> <LayoutContract contract={this.props.contract} cardTitle={
<React.Fragment>
{isInterface && `${this.props.contract.className} is an interface`}
{!isInterface && this.props.contract.className}
</React.Fragment>
}>
<Row> <Row>
<Col md={6}> <Col md={6}>
{isInterface && <h5>{this.props.contract.className} is an interface</h5>}
{!isInterface && <h5>{this.props.contract.className}</h5>}
{argumentsRequired && {argumentsRequired &&
<Card> <React.Fragment>
<CardHeader> <h5>Arguments:</h5>
<strong>Arguments:</strong> {abiConstructor.inputs.map(input => (
</CardHeader>
<CardBody>
{abiConstructor.inputs.map(input => (
<FormGroup key={input.name}> <FormGroup key={input.name}>
<Label htmlFor={input.name}>{input.name}</Label> <Label htmlFor={input.name}>{input.name}</Label>
<Input id={input.name} placeholder={input.name} onChange={e => this.handleOnChange(e, input.name)} /> <Input id={input.name} placeholder={input.name} onChange={e => this.handleOnChange(e, input.name)} />
</FormGroup> </FormGroup>
))} ))}
</CardBody> </React.Fragment>
</Card>
} }
{!this.props.web3 && <NoWeb3 />} {!this.props.web3 && <NoWeb3 />}
@ -158,16 +159,13 @@ class Web3Contract extends React.Component {
} }
const EmbarkContract = ({contract}) => ( const EmbarkContract = ({contract}) => (
<LayoutContract contract={contract}> <LayoutContract contract={contract} cardTitle={
{contract.address && <React.Fragment>
<React.Fragment> {contract.address && `${contract.className} deployed at ${contract.address}`}
<h5>{contract.className} deployed at {contract.address}</h5> {!contract.address && `${contract.className} not deployed`}
<p><strong>Arguments:</strong> {JSON.stringify(contract.args)}</p> </React.Fragment>
</React.Fragment> }>
} {contract.address && <p><strong>Arguments:</strong> {JSON.stringify(contract.args)}</p>}
{!contract.address &&
<h5>{contract.className} not deployed</h5>
}
{contract.transactionHash && {contract.transactionHash &&
<React.Fragment> <React.Fragment>
<p><strong>Transaction Hash:</strong> {contract.transactionHash}</p> <p><strong>Transaction Hash:</strong> {contract.transactionHash}</p>
@ -182,45 +180,37 @@ const EmbarkContract = ({contract}) => (
const ContractsHeader = ({deploymentPipeline, updateDeploymentPipeline}) => ( const ContractsHeader = ({deploymentPipeline, updateDeploymentPipeline}) => (
<Row className="mt-3"> <Row className="mt-3">
<Col xs={1} className="text-center"> <div className="ml-auto mr-5">
<strong>Order</strong> <FormGroup row>
</Col> <span className="mr-2">Deploy using</span>
<Col xs={11}> <FormGroup check inline>
<Row> <Label className="form-check-label" check>
<strong>Contract</strong> <Input className="form-check-input"
<div className="ml-auto mr-5"> type="radio"
<FormGroup row> onChange={() => updateDeploymentPipeline(DEPLOYMENT_PIPELINES.embark)}
<span className="mr-2">Deploy using</span> checked={deploymentPipeline === DEPLOYMENT_PIPELINES.embark} />
<FormGroup check inline> Embark
<Label className="form-check-label" check> <FontAwesomeIcon className="ml-1" name="question" id="embark-tooltip" />
<Input className="form-check-input" <UncontrolledTooltip placement="bottom" target="embark-tooltip">
type="radio" Embark will deploy the contracts automatically for you each time there is a change in one of them.
onChange={() => updateDeploymentPipeline(DEPLOYMENT_PIPELINES.embark)} </UncontrolledTooltip>
checked={deploymentPipeline === DEPLOYMENT_PIPELINES.embark} /> </Label>
Embark </FormGroup>
<FontAwesomeIcon className="ml-1" name="question" id="embark-tooltip" /> <FormGroup check inline>
<UncontrolledTooltip placement="bottom" target="embark-tooltip"> <Label className="form-check-label" check>
Embark will deploy the contracts automatically for you each time there is a change in one of them. <Input className="form-check-input"
</UncontrolledTooltip> type="radio"
</Label> onChange={() => updateDeploymentPipeline(DEPLOYMENT_PIPELINES.injectedWeb3)}
</FormGroup> checked={deploymentPipeline === DEPLOYMENT_PIPELINES.injectedWeb3} />
<FormGroup check inline> Injected Web3
<Label className="form-check-label" check> <FontAwesomeIcon className="ml-1" name="question" id="web3-tooltip" />
<Input className="form-check-input" <UncontrolledTooltip placement="bottom" target="web3-tooltip">
type="radio" You will have full control on your deployment
onChange={() => updateDeploymentPipeline(DEPLOYMENT_PIPELINES.injectedWeb3)} </UncontrolledTooltip>
checked={deploymentPipeline === DEPLOYMENT_PIPELINES.injectedWeb3} /> </Label>
Injected Web3 </FormGroup>
<FontAwesomeIcon className="ml-1" name="question" id="web3-tooltip" /> </FormGroup>
<UncontrolledTooltip placement="bottom" target="web3-tooltip"> </div>
You will have full control on your deployment
</UncontrolledTooltip>
</Label>
</FormGroup>
</FormGroup>
</div>
</Row>
</Col>
</Row> </Row>
) )