office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
76 lines • 3.32 kB
JavaScript
import * as tslib_1 from "tslib";
import * as React from 'react';
import { BaseComponent, autobind, css } from '../../Utilities';
import * as stylesImport from './ColorPicker.scss';
var styles = stylesImport;
var ColorSlider = /** @class */ (function (_super) {
tslib_1.__extends(ColorSlider, _super);
function ColorSlider(props) {
var _this = _super.call(this, props) || this;
var value = _this.props.value;
_this.state = {
isAdjusting: false,
origin: undefined,
currentValue: value
};
return _this;
}
ColorSlider.prototype.componentWillReceiveProps = function (newProps) {
if (newProps && newProps.value) {
this.setState({ currentValue: newProps.value });
}
};
ColorSlider.prototype.render = function () {
var _a = this.props, className = _a.className, minValue = _a.minValue, maxValue = _a.maxValue, overlayStyle = _a.overlayStyle;
var _b = this.state, currentValue = _b.currentValue, isAdjusting = _b.isAdjusting;
var currentPercentage = 100 * (currentValue - minValue) / (maxValue - minValue);
return (React.createElement("div", { ref: this._resolveRef('_root'), className: css('ms-ColorPicker-slider', styles.slider, className, isAdjusting && 'is-adjusting'), onMouseDown: this._onMouseDown },
React.createElement("div", { className: css('ms-ColorPicker-sliderOverlay', styles.sliderOverlay), style: overlayStyle }),
React.createElement("div", { className: css('ms-ColorPicker-thumb is-slider', styles.thumb, styles.thumbIsSlider), style: { left: currentPercentage + '%' } })));
};
ColorSlider.prototype._onMouseDown = function (ev) {
this._events.on(window, 'mousemove', this._onMouseMove, true);
this._events.on(window, 'mouseup', this._onMouseUp, true);
this._onMouseMove(ev);
};
ColorSlider.prototype._onMouseMove = function (ev) {
var _a = this.props, onChanged = _a.onChanged, minValue = _a.minValue, maxValue = _a.maxValue;
var rectSize = this._root.getBoundingClientRect();
var currentPercentage = (ev.clientX - rectSize.left) / rectSize.width;
var newValue = Math.min(maxValue, Math.max(minValue, currentPercentage * maxValue));
this.setState({
isAdjusting: true,
currentValue: newValue
});
if (onChanged) {
onChanged(newValue);
}
ev.preventDefault();
ev.stopPropagation();
};
ColorSlider.prototype._onMouseUp = function (ev) {
this._events.off();
this.setState({
isAdjusting: false,
origin: undefined
});
};
ColorSlider.defaultProps = {
minValue: 0,
maxValue: 100,
thumbColor: 'inherit',
value: 0
};
tslib_1.__decorate([
autobind
], ColorSlider.prototype, "_onMouseDown", null);
tslib_1.__decorate([
autobind
], ColorSlider.prototype, "_onMouseMove", null);
tslib_1.__decorate([
autobind
], ColorSlider.prototype, "_onMouseUp", null);
return ColorSlider;
}(BaseComponent));
export { ColorSlider };
//# sourceMappingURL=ColorSlider.js.map