Reputation: 303
I am having trouble making a Link onClick disabled if a condition is not met.
1ST ATTEMPT
class Order extends React.Component<OrderProps> {
state = { referenceIsValid: true }
handleClick = (e: any) => {
if (!this.state.referenceIsValid) {
e.preventDefault()
} else {
this.props.postProspect()
}
}
render() {
const {
configuration: { referenceType, reference }
}
if (referenceType && referenceType === "required") {
referenceIsValid = reference && reference.length > 0
}
return (
{(referenceType === "required" || referenceType === "optional") && (
<Field
component={TextField}
name="configuration.reference"
label="References
placeholder="People you have worked with."
getErrors={(value: any) => {
if (
referenceType === "required" &&
(value === undefined || value.length < 1)
) {
return ["Add a reference"]
}
return []
}}
/>
)}
<Link
to={`/${slug}/client/finish`}
onClick={e => this.handleClick(e)}
> Order
</Link>
)
}
const connectedReview = connect(
mapStateToProps,
{
postProspect,
}
)(Review)
export default reduxForm({
form: "orderForm",
destroyOnUnmount: false,
})(connectedReview)
2ND ATTEMPT
let referenceIsValid = true
onClick={
!referenceIsValid ? undefined : this.props.postProspect
}
I expect the button to be disabled unless at least one character has been enterred into the input field.
Upvotes: 3
Views: 6329
Reputation: 549
You need to prevent the default functionality. try something along the lines of this
let referenceIsValid = true
onClick={ e => !referenceIsValid ? e.preventDefault() : this.props.postProspect()
}
https://github.com/ReactTraining/react-router/issues/1082
Upvotes: 8