UNPKG

@blueprintjs/core

Version:
110 lines (108 loc) 16.1 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 __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var classNames = require("classnames"); var PureRender = require("pure-render-decorator"); var React = require("react"); var abstractComponent_1 = require("../../common/abstractComponent"); var Classes = require("../../common/classes"); var utils_1 = require("../../common/utils"); var CoreSlider = (function (_super) { __extends(CoreSlider, _super); function CoreSlider() { var _this = this; _super.apply(this, arguments); this.state = { tickSize: 0, }; this.className = Classes.SLIDER; this.refHandlers = { track: function (el) { return _this.trackElement = el; }, }; this.maybeHandleTrackClick = function (event) { var target = event.target; // ensure event does not come from inside the handle if (!_this.props.disabled && target.closest("." + Classes.SLIDER_HANDLE) == null) { _this.handleTrackClick(event.nativeEvent); } }; } CoreSlider.prototype.render = function () { var disabled = this.props.disabled; var classes = classNames(this.className, (_a = {}, _a[Classes.DISABLED] = disabled, _a[Classes.SLIDER + "-unlabeled"] = this.props.renderLabel === false, _a ), this.props.className); return (React.createElement("div", {className: classes, onMouseDown: this.maybeHandleTrackClick}, React.createElement("div", {className: Classes.SLIDER + "-track", ref: this.refHandlers.track}), this.maybeRenderFill(), this.maybeRenderAxis(), this.renderHandles())); var _a; }; CoreSlider.prototype.componentDidMount = function () { this.updateTickSize(); }; CoreSlider.prototype.componentDidUpdate = function () { this.updateTickSize(); }; CoreSlider.prototype.formatLabel = function (value) { var renderLabel = this.props.renderLabel; if (renderLabel === false) { return undefined; } else if (utils_1.isFunction(renderLabel)) { return renderLabel(value); } else { return value; } }; CoreSlider.prototype.maybeRenderAxis = function () { var _a = this.props, max = _a.max, min = _a.min, labelStepSize = _a.labelStepSize; if (this.props.renderLabel === false) { return undefined; } var stepSize = Math.round(this.state.tickSize * labelStepSize); var labels = []; // tslint:disable-next-line:one-variable-per-declaration for (var i = min, left = 0; i < max || utils_1.approxEqual(i, max); i += labelStepSize, left += stepSize) { labels.push(React.createElement("div", {className: Classes.SLIDER + "-label", key: i, style: { left: left }}, this.formatLabel(i))); } return React.createElement("div", {className: Classes.SLIDER + "-axis"}, labels); }; CoreSlider.prototype.maybeRenderFill = function () { if (this.props.showTrackFill && this.trackElement != null) { return this.renderFill(); } return undefined; }; CoreSlider.prototype.updateTickSize = function () { if (this.trackElement != null) { var tickSize = this.trackElement.clientWidth / (this.props.max - this.props.min); this.setState({ tickSize: tickSize }); } }; CoreSlider = __decorate([ PureRender ], CoreSlider); return CoreSlider; }(abstractComponent_1.AbstractComponent)); exports.CoreSlider = CoreSlider; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/slider/coreSlider.tsx"],"names":[],"mappings":"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","file":"components/slider/coreSlider.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 classNames from \"classnames\";\nimport * as PureRender from \"pure-render-decorator\";\nimport * as React from \"react\";\n\nimport { AbstractComponent } from \"../../common/abstractComponent\";\nimport * as Classes from \"../../common/classes\";\nimport { IProps } from \"../../common/props\";\nimport { approxEqual, isFunction } from \"../../common/utils\";\n\nexport interface ICoreSliderProps extends IProps {\n    /**\n     * Whether the slider is non-interactive.\n     * @default false\n     */\n    disabled?: boolean;\n\n    /**\n     * Increment between successive labels.\n     * @default 1\n     */\n    labelStepSize?: number;\n\n    /**\n     * Maximum value of the slider.\n     * @default 10\n     */\n    max?: number;\n\n    /**\n     * Minimum value of the slider.\n     * @default 0\n     */\n    min?: number;\n\n    /**\n     * Whether a solid bar should be rendered on the track between current and initial values,\n     * or between handles for `RangeSlider`.\n     * @default true\n     */\n    showTrackFill?: boolean;\n\n    /**\n     * Increment between successive values; amount by which the handle moves.\n     * @default 1\n     */\n    stepSize?: number;\n\n    /**\n     * Callback to render a single label. Useful for formatting numbers as currency or percentages.\n     * If `true`, labels will use number value. If `false`, labels will not be shown.\n     * @default true\n     */\n    renderLabel?: ((value: number) => string | JSX.Element) | boolean;\n}\n\nexport interface ISliderState {\n    /** the client size, in pixels, of one tick */\n    tickSize?: number;\n}\n\n@PureRender\nexport abstract class CoreSlider<P extends ICoreSliderProps> extends AbstractComponent<P, ISliderState> {\n    public state: ISliderState = {\n        tickSize: 0,\n    };\n\n    public className = Classes.SLIDER;\n\n    private trackElement: HTMLElement;\n    private refHandlers = {\n        track: (el: HTMLDivElement) => this.trackElement = el,\n    };\n\n    public render() {\n        const { disabled } = this.props;\n        const classes = classNames(this.className, {\n            [Classes.DISABLED]: disabled,\n            [`${Classes.SLIDER}-unlabeled`]: this.props.renderLabel === false,\n        }, this.props.className);\n        return (\n            <div className={classes} onMouseDown={this.maybeHandleTrackClick}>\n                <div className={`${Classes.SLIDER}-track`} ref={this.refHandlers.track} />\n                {this.maybeRenderFill()}\n                {this.maybeRenderAxis()}\n                {this.renderHandles()}\n            </div>\n        );\n    }\n\n    public componentDidMount() {\n        this.updateTickSize();\n    }\n\n    public componentDidUpdate() {\n        this.updateTickSize();\n    }\n\n    protected abstract renderHandles(): JSX.Element | JSX.Element[];\n    protected abstract renderFill(): JSX.Element;\n    /** An event listener invoked when the user clicks on the track outside a handle */\n    protected abstract handleTrackClick(event: MouseEvent | React.MouseEvent<HTMLElement>): void;\n\n    protected formatLabel(value: number): React.ReactChild {\n        const { renderLabel } = this.props;\n        if (renderLabel === false) {\n            return undefined;\n        } else if (isFunction(renderLabel)) {\n            return renderLabel(value);\n        } else {\n            return value;\n        }\n    }\n\n    private maybeRenderAxis() {\n        const { max, min, labelStepSize } = this.props;\n        if (this.props.renderLabel === false) { return undefined; }\n\n        const stepSize = Math.round(this.state.tickSize * labelStepSize);\n        const labels: JSX.Element[] = [];\n        // tslint:disable-next-line:one-variable-per-declaration\n        for (let i = min, left = 0; i < max || approxEqual(i, max); i += labelStepSize, left += stepSize) {\n            labels.push(<div className={`${Classes.SLIDER}-label`} key={i} style={{left}}>{this.formatLabel(i)}</div>);\n        }\n        return <div className={`${Classes.SLIDER}-axis`}>{labels}</div>;\n    }\n\n    private maybeRenderFill() {\n        if (this.props.showTrackFill && this.trackElement != null) {\n            return this.renderFill();\n        }\n        return undefined;\n    }\n\n    private maybeHandleTrackClick = (event: React.MouseEvent<HTMLDivElement>) => {\n        const target = event.target as HTMLElement;\n        // ensure event does not come from inside the handle\n        if (!this.props.disabled && target.closest(`.${Classes.SLIDER_HANDLE}`) == null) {\n            this.handleTrackClick(event.nativeEvent as MouseEvent);\n        }\n    }\n\n    private updateTickSize() {\n        if (this.trackElement != null) {\n            const tickSize = this.trackElement.clientWidth / (this.props.max - this.props.min);\n            this.setState({ tickSize });\n        }\n    }\n}\n"],"sourceRoot":"/source/"}