@blueprintjs/core
Version:
Core styles & components
106 lines (104 loc) • 12.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;
};
// HACKHACK: these components should go in separate files
// tslint:disable max-classes-per-file
var classNames = require("classnames");
var React = require("react");
var props_1 = require("../../common/props");
var utils_1 = require("../../common/utils");
/** Base Component class for all Controls */
var Control = (function (_super) {
__extends(Control, _super);
function Control() {
_super.apply(this, arguments);
}
// generates control markup for given input type.
// optional inputRef in case the component needs reference for itself (don't forget to invoke the prop!).
Control.prototype.renderControl = function (type, typeClassName, inputRef) {
if (inputRef === void 0) { inputRef = this.props.inputRef; }
return (React.createElement("label", {className: classNames("pt-control", typeClassName, this.props.className), style: this.props.style},
React.createElement("input", __assign({}, props_1.removeNonHTMLProps(this.props, ["children"], true), {ref: inputRef, type: type})),
React.createElement("span", {className: "pt-control-indicator"}),
this.props.label,
this.props.children));
};
return Control;
}(React.Component));
exports.Control = Control;
var Checkbox = (function (_super) {
__extends(Checkbox, _super);
function Checkbox() {
var _this = this;
_super.apply(this, arguments);
this.handleInputRef = function (ref) {
_this.input = ref;
utils_1.safeInvoke(_this.props.inputRef, ref);
};
}
Checkbox.prototype.render = function () {
return this.renderControl("checkbox", "pt-checkbox", this.handleInputRef);
};
Checkbox.prototype.componentDidMount = function () {
if (this.props.defaultIndeterminate != null) {
this.input.indeterminate = this.props.defaultIndeterminate;
}
this.updateIndeterminate();
};
Checkbox.prototype.componentDidUpdate = function () {
this.updateIndeterminate();
};
Checkbox.prototype.updateIndeterminate = function () {
if (this.props.indeterminate != null) {
this.input.indeterminate = this.props.indeterminate;
}
};
Checkbox.displayName = "Blueprint.Checkbox";
return Checkbox;
}(Control));
exports.Checkbox = Checkbox;
var Switch = (function (_super) {
__extends(Switch, _super);
function Switch() {
_super.apply(this, arguments);
}
Switch.prototype.render = function () {
return this.renderControl("checkbox", "pt-switch");
};
Switch.displayName = "Blueprint.Switch";
return Switch;
}(Control));
exports.Switch = Switch;
var Radio = (function (_super) {
__extends(Radio, _super);
function Radio() {
_super.apply(this, arguments);
}
Radio.prototype.render = function () {
return this.renderControl("radio", "pt-radio");
};
Radio.displayName = "Blueprint.Radio";
return Radio;
}(Control));
exports.Radio = Radio;
exports.CheckboxFactory = React.createFactory(Checkbox);
exports.SwitchFactory = React.createFactory(Switch);
exports.RadioFactory = React.createFactory(Radio);
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/forms/controls.tsx"],"names":[],"mappings":"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","file":"components/forms/controls.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\n// HACKHACK: these components should go in separate files\n// tslint:disable max-classes-per-file\n\nimport * as classNames from \"classnames\";\nimport * as React from \"react\";\n\nimport { IProps, removeNonHTMLProps } from \"../../common/props\";\nimport { safeInvoke } from \"../../common/utils\";\n\nexport interface IControlProps extends IProps {\n    /** Whether the control is checked. */\n    checked?: boolean;\n\n    /** Whether the control is initially checked (uncontrolled) */\n    defaultChecked?: boolean;\n\n    /** Ref handler that receives HTML `<input>` element backing this component. */\n    inputRef?: (ref: HTMLInputElement) => any;\n\n    /** Text label for control. */\n    label?: string;\n\n    /** Event handler invoked when input value is changed */\n    onChange?: React.FormEventHandler<HTMLInputElement>;\n}\n\n/** Base Component class for all Controls */\nexport class Control<P extends IControlProps> extends React.Component<React.HTMLProps<HTMLInputElement> & P, {}> {\n    // generates control markup for given input type.\n    // optional inputRef in case the component needs reference for itself (don't forget to invoke the prop!).\n    protected renderControl(type: \"checkbox\" | \"radio\", typeClassName: string, inputRef = this.props.inputRef) {\n        return (\n            <label className={classNames(\"pt-control\", typeClassName, this.props.className)} style={this.props.style}>\n                <input {...removeNonHTMLProps(this.props, [\"children\"], true)} ref={inputRef} type={type} />\n                <span className=\"pt-control-indicator\" />\n                {this.props.label}\n                {this.props.children}\n            </label>\n        );\n    }\n}\n\nexport interface ICheckboxProps extends IControlProps {\n    /** Whether this checkbox is initially indeterminate (uncontrolled) */\n    defaultIndeterminate?: boolean;\n\n    /** Whether this checkbox is indeterminate */\n    indeterminate?: boolean;\n}\n\nexport class Checkbox extends Control<ICheckboxProps> {\n    public static displayName = \"Blueprint.Checkbox\";\n\n    // must maintain internal reference for `indeterminate` support\n    private input: HTMLInputElement;\n\n    public render() {\n        return this.renderControl(\"checkbox\", \"pt-checkbox\", this.handleInputRef);\n    }\n\n    public componentDidMount() {\n        if (this.props.defaultIndeterminate != null) {\n            this.input.indeterminate = this.props.defaultIndeterminate;\n        }\n        this.updateIndeterminate();\n    }\n\n    public componentDidUpdate() {\n        this.updateIndeterminate();\n    }\n\n    private updateIndeterminate() {\n        if (this.props.indeterminate != null) {\n            this.input.indeterminate = this.props.indeterminate;\n        }\n    }\n\n    private handleInputRef = (ref: HTMLInputElement) => {\n        this.input = ref;\n        safeInvoke(this.props.inputRef, ref);\n    }\n}\n\nexport interface ISwitchProps extends IControlProps {}\n\nexport class Switch extends Control<ISwitchProps> {\n    public static displayName = \"Blueprint.Switch\";\n\n    public render() {\n        return this.renderControl(\"checkbox\", \"pt-switch\");\n    }\n}\n\nexport interface IRadioProps extends IControlProps {}\n\nexport class Radio extends Control<IRadioProps> {\n    public static displayName = \"Blueprint.Radio\";\n\n    public render() {\n        return this.renderControl(\"radio\", \"pt-radio\");\n    }\n}\n\nexport const CheckboxFactory = React.createFactory(Checkbox);\nexport const SwitchFactory = React.createFactory(Switch);\nexport const RadioFactory = React.createFactory(Radio);\n"],"sourceRoot":"/source/"}