mirror of
https://github.com/status-im/embark-area-51.git
synced 2025-01-24 06:08:48 +00:00
Show functions
This commit is contained in:
parent
3f2f06f295
commit
82cd43d32e
48
embark-ui/src/components/ContractFunctions.js
Normal file
48
embark-ui/src/components/ContractFunctions.js
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
import PropTypes from "prop-types";
|
||||||
|
import React from 'react';
|
||||||
|
import {
|
||||||
|
Page,
|
||||||
|
Grid,
|
||||||
|
Form,
|
||||||
|
Button,
|
||||||
|
Card
|
||||||
|
} from "tabler-react";
|
||||||
|
|
||||||
|
const ContractFunction = ({method}) => (
|
||||||
|
<Grid.Row>
|
||||||
|
<Grid.Col>
|
||||||
|
<Card>
|
||||||
|
<Card.Header>
|
||||||
|
<Card.Title>{method.name}</Card.Title>
|
||||||
|
</Card.Header>
|
||||||
|
{method.inputs.length > 0 &&
|
||||||
|
<Card.Body>
|
||||||
|
{method.inputs.map(input => (
|
||||||
|
<Form.Group label={input.name}>
|
||||||
|
<Form.Input placeholder={input.type}/>
|
||||||
|
</Form.Group>
|
||||||
|
))}
|
||||||
|
</Card.Body>
|
||||||
|
}
|
||||||
|
<Card.Footer>
|
||||||
|
<Button color="primary">Call</Button>
|
||||||
|
</Card.Footer>
|
||||||
|
</Card>
|
||||||
|
</Grid.Col>
|
||||||
|
</Grid.Row>
|
||||||
|
);
|
||||||
|
|
||||||
|
const ContractFunctions = ({contractProfile}) => (
|
||||||
|
<Page.Content title={contractProfile.name + ' Functions'}>
|
||||||
|
{contractProfile.methods
|
||||||
|
.filter(method => method.name !== 'constructor')
|
||||||
|
.map(method => <ContractFunction method={method} />)}
|
||||||
|
</Page.Content>
|
||||||
|
);
|
||||||
|
|
||||||
|
ContractFunctions.propTypes = {
|
||||||
|
contractProfile: PropTypes.object
|
||||||
|
};
|
||||||
|
|
||||||
|
export default ContractFunctions;
|
||||||
|
|
@ -9,6 +9,7 @@ import {
|
|||||||
|
|
||||||
import ContractContainer from '../containers/ContractContainer';
|
import ContractContainer from '../containers/ContractContainer';
|
||||||
import ContractLoggerContainer from '../containers/ContractLoggerContainer';
|
import ContractLoggerContainer from '../containers/ContractLoggerContainer';
|
||||||
|
import ContractFunctionsContainer from '../containers/ContractFunctionsContainer';
|
||||||
import ContractProfileContainer from '../containers/ContractProfileContainer';
|
import ContractProfileContainer from '../containers/ContractProfileContainer';
|
||||||
import ContractSourceContainer from '../containers/ContractSourceContainer';
|
import ContractSourceContainer from '../containers/ContractSourceContainer';
|
||||||
|
|
||||||
@ -72,6 +73,7 @@ const ContractLayout = ({match}) => (
|
|||||||
<Grid.Col md={9}>
|
<Grid.Col md={9}>
|
||||||
<Switch>
|
<Switch>
|
||||||
<Route exact path="/embark/contracts/:contractName/overview" component={ContractContainer} />
|
<Route exact path="/embark/contracts/:contractName/overview" component={ContractContainer} />
|
||||||
|
<Route exact path="/embark/contracts/:contractName/functions" component={ContractFunctionsContainer} />
|
||||||
<Route exact path="/embark/contracts/:contractName/source" component={ContractSourceContainer} />
|
<Route exact path="/embark/contracts/:contractName/source" component={ContractSourceContainer} />
|
||||||
<Route exact path="/embark/contracts/:contractName/profiler" component={ContractProfileContainer} />
|
<Route exact path="/embark/contracts/:contractName/profiler" component={ContractProfileContainer} />
|
||||||
<Route exact path="/embark/contracts/:contractName/logger" component={ContractLoggerContainer} />
|
<Route exact path="/embark/contracts/:contractName/logger" component={ContractLoggerContainer} />
|
||||||
|
@ -3,7 +3,6 @@ import {connect} from 'react-redux';
|
|||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import {withRouter} from 'react-router-dom';
|
import {withRouter} from 'react-router-dom';
|
||||||
|
|
||||||
import {contract as contractAction} from '../actions';
|
|
||||||
import Contract from '../components/Contract';
|
import Contract from '../components/Contract';
|
||||||
import DataWrapper from "../components/DataWrapper";
|
import DataWrapper from "../components/DataWrapper";
|
||||||
import {getContract} from "../reducers/selectors";
|
import {getContract} from "../reducers/selectors";
|
||||||
@ -27,14 +26,10 @@ function mapStateToProps(state, props) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ContractContainer.propTypes = {
|
ContractContainer.propTypes = {
|
||||||
match: PropTypes.object,
|
|
||||||
contract: PropTypes.object,
|
contract: PropTypes.object,
|
||||||
error: PropTypes.string
|
error: PropTypes.string
|
||||||
};
|
};
|
||||||
|
|
||||||
export default withRouter(connect(
|
export default withRouter(connect(
|
||||||
mapStateToProps,
|
mapStateToProps
|
||||||
{
|
|
||||||
fetchContract: contractAction.request
|
|
||||||
}
|
|
||||||
)(ContractContainer));
|
)(ContractContainer));
|
||||||
|
45
embark-ui/src/containers/ContractFunctionsContainer.js
Normal file
45
embark-ui/src/containers/ContractFunctionsContainer.js
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
import React, {Component} from 'react';
|
||||||
|
import {connect} from 'react-redux';
|
||||||
|
import PropTypes from 'prop-types';
|
||||||
|
import {withRouter} from 'react-router-dom';
|
||||||
|
|
||||||
|
import {contractProfile as contractProfileAction} from '../actions';
|
||||||
|
import ContractFunctions from '../components/ContractFunctions';
|
||||||
|
import DataWrapper from "../components/DataWrapper";
|
||||||
|
import {getContractProfile} from "../reducers/selectors";
|
||||||
|
|
||||||
|
class ContractFunctionsContainer extends Component {
|
||||||
|
componentDidMount() {
|
||||||
|
this.props.fetchContractProfile(this.props.match.params.contractName);
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<DataWrapper shouldRender={this.props.contractProfile !== undefined } {...this.props} render={({contractProfile}) => (
|
||||||
|
<ContractFunctions contractProfile={contractProfile} />
|
||||||
|
)} />
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function mapStateToProps(state, props) {
|
||||||
|
return {
|
||||||
|
contractProfile: getContractProfile(state, props.match.params.contractName),
|
||||||
|
error: state.errorMessage,
|
||||||
|
loading: state.loading
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
ContractFunctionsContainer.propTypes = {
|
||||||
|
match: PropTypes.object,
|
||||||
|
contractProfile: PropTypes.object,
|
||||||
|
fetchContractProfile: PropTypes.func,
|
||||||
|
error: PropTypes.string
|
||||||
|
};
|
||||||
|
|
||||||
|
export default withRouter(connect(
|
||||||
|
mapStateToProps,
|
||||||
|
{
|
||||||
|
fetchContractProfile: contractProfileAction.request
|
||||||
|
}
|
||||||
|
)(ContractFunctionsContainer));
|
Loading…
x
Reference in New Issue
Block a user