UNPKG

@blueprintjs/core

Version:
106 lines (104 loc) 12.7 kB
/* * 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 */ "use strict"; 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/"}