@blueprintjs/core
Version:
Core styles & components
82 lines (80 loc) • 11.7 kB
JavaScript
/*
* Copyright 2016 Palantir Technologies, Inc. All rights reserved.
* Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy
* of the license at https://github.com/palantir/blueprint/blob/master/LICENSE
* and https://github.com/palantir/blueprint/blob/master/PATENTS
*/
;
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var __assign = (this && this.__assign) || Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
var React = require("react");
var abstractComponent_1 = require("../../common/abstractComponent");
var Classes = require("../../common/classes");
var Errors = require("../../common/errors");
var controls_1 = require("./controls");
var counter = 0;
function nextName() { return RadioGroup.displayName + "-" + counter++; }
var RadioGroup = (function (_super) {
__extends(RadioGroup, _super);
function RadioGroup() {
_super.apply(this, arguments);
// a unique name for this group, which can be overridden by `name` prop.
this.autoGroupName = nextName();
}
RadioGroup.prototype.render = function () {
var label = this.props.label;
return (React.createElement("div", {className: this.props.className},
label == null ? null : React.createElement("label", {className: Classes.LABEL}, label),
Array.isArray(this.props.options) ? this.renderOptions() : this.renderChildren()));
};
RadioGroup.prototype.validateProps = function () {
if (this.props.children != null) {
if (this.props.options != null) {
throw new Error(Errors.RADIOGROUP_CHILDREN_OPTIONS_MUTEX);
}
React.Children.forEach(this.props.children, function (child) {
var radio = child;
if (radio.type !== controls_1.Radio) {
throw new Error(Errors.RADIOGROUP_RADIO_CHILDREN);
}
});
}
};
RadioGroup.prototype.renderChildren = function () {
var _this = this;
return React.Children.map(this.props.children, function (child) {
var radio = child;
return React.cloneElement(radio, _this.getRadioProps(radio.props));
});
};
RadioGroup.prototype.renderOptions = function () {
var _this = this;
return this.props.options.map(function (option) { return (React.createElement(controls_1.Radio, __assign({}, option, _this.getRadioProps(option), {key: option.value}))); });
};
RadioGroup.prototype.getRadioProps = function (optionProps) {
var name = this.props.name;
var value = optionProps.value, disabled = optionProps.disabled;
return {
checked: value === this.props.selectedValue,
disabled: disabled || this.props.disabled,
name: name == null ? this.autoGroupName : name,
onChange: this.props.onChange,
};
};
RadioGroup.displayName = "Blueprint.RadioGroup";
return RadioGroup;
}(abstractComponent_1.AbstractComponent));
exports.RadioGroup = RadioGroup;
;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/forms/radioGroup.tsx"],"names":[],"mappings":"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","file":"components/forms/radioGroup.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport * as React from \"react\";\n\nimport { AbstractComponent } from \"../../common/abstractComponent\";\nimport * as Classes from \"../../common/classes\";\nimport * as Errors from \"../../common/errors\";\nimport { IOptionProps, IProps } from \"../../common/props\";\nimport { Radio } from \"./controls\";\n\nexport interface IRadioGroupProps extends IProps {\n    /**\n     * Whether the group and _all_ its radios are disabled.\n     * Individual radios can be disabled using their `disabled` prop.\n     */\n    disabled?: boolean;\n\n    /** Optional label text to display above the radio buttons. */\n    label?: string;\n\n    /**\n     * Name of the group, used to link radio buttons together in HTML.\n     * If omitted, a unique name will be generated internally.\n     */\n    name?: string;\n\n    /**\n     * Callback invoked when the currently selected radio changes.\n     * This prop is required because this component currently supports only controlled usage.\n     */\n    onChange: (event: React.FormEvent<HTMLElement>) => void;\n\n    /**\n     * Array of options to render in the group.\n     * This prop is mutually exclusive with `children`: either provide an array of `IOptionProps`\n     * objects or provide `<Radio>` children elements.\n     */\n    options?: IOptionProps[];\n\n    /** Value of the selected radio. The child with this value will be `:checked`. */\n    selectedValue?: string;\n}\n\nlet counter = 0;\nfunction nextName() { return `${RadioGroup.displayName}-${counter++}`; }\n\nexport class RadioGroup extends AbstractComponent<IRadioGroupProps, {}> {\n    public static displayName = \"Blueprint.RadioGroup\";\n\n    // a unique name for this group, which can be overridden by `name` prop.\n    private autoGroupName = nextName();\n\n    public render() {\n        const { label } = this.props;\n        return (\n            <div className={this.props.className}>\n                {label == null ? null : <label className={Classes.LABEL}>{label}</label>}\n                {Array.isArray(this.props.options) ? this.renderOptions() : this.renderChildren()}\n            </div>\n        );\n    }\n\n    protected validateProps() {\n        if (this.props.children != null) {\n            if (this.props.options != null) {\n                throw new Error(Errors.RADIOGROUP_CHILDREN_OPTIONS_MUTEX);\n            }\n            React.Children.forEach(this.props.children, (child) => {\n                const radio = child as JSX.Element;\n                if (radio.type !== Radio) {\n                    throw new Error(Errors.RADIOGROUP_RADIO_CHILDREN);\n                }\n            });\n        }\n    }\n\n    private renderChildren() {\n        return React.Children.map(this.props.children, (child) => {\n            const radio = child as JSX.Element;\n            return React.cloneElement(radio, this.getRadioProps(radio.props));\n        });\n    }\n\n    private renderOptions() {\n        return this.props.options.map((option) => (\n            <Radio {...option} {...this.getRadioProps(option)} key={option.value} />\n        ));\n    }\n\n    private getRadioProps(optionProps: IOptionProps) {\n        const { name } = this.props;\n        const { value, disabled } = optionProps;\n        return {\n            checked: value === this.props.selectedValue,\n            disabled: disabled || this.props.disabled,\n            name: name == null ? this.autoGroupName : name,\n            onChange: this.props.onChange,\n        };\n    }\n};\n"],"sourceRoot":"/source/"}