Files
swagger-ui/src/core/components/parameter-include-empty.jsx

54 lines
1.3 KiB
JavaScript

import React, { Component } from "react"
import cx from "classnames"
import PropTypes from "prop-types"
const noop = () => { }
const ParameterIncludeEmptyPropTypes = {
isIncluded: PropTypes.bool.isRequired,
isDisabled: PropTypes.bool.isRequired,
isIncludedOptions: PropTypes.object,
onChange: PropTypes.func.isRequired,
}
const ParameterIncludeEmptyDefaultProps = {
onChange: noop,
isIncludedOptions: {},
}
export default class ParameterIncludeEmpty extends Component {
static propTypes = ParameterIncludeEmptyPropTypes
static defaultProps = ParameterIncludeEmptyDefaultProps
componentDidMount() {
const { isIncludedOptions, onChange } = this.props
const { shouldDispatchInit, defaultValue } = isIncludedOptions
if (shouldDispatchInit) {
onChange(defaultValue)
}
}
onCheckboxChange = e => {
const { onChange } = this.props
onChange(e.target.checked)
}
render() {
let { isIncluded, isDisabled } = this.props
return (
<div>
<label className={cx("parameter__empty_value_toggle", {
"disabled": isDisabled
})}>
<input type="checkbox"
disabled={isDisabled}
checked={!isDisabled && isIncluded}
onChange={this.onCheckboxChange} />
Send empty value
</label>
</div>
)
}
}