choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
141 lines (120 loc) • 3.9 kB
JavaScript
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
import _extends from "@babel/runtime/helpers/extends";
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
import _createClass from "@babel/runtime/helpers/createClass";
import _inherits from "@babel/runtime/helpers/inherits";
import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn";
import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
function _createSuper(Derived) {
function isNativeReflectConstruct() {
if (typeof Reflect === "undefined" || !Reflect.construct) return false;
if (Reflect.construct.sham) return false;
if (typeof Proxy === "function") return true;
try {
Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));
return true;
} catch (e) {
return false;
}
}
return function () {
var Super = _getPrototypeOf(Derived),
result;
if (isNativeReflectConstruct()) {
var NewTarget = _getPrototypeOf(this).constructor;
result = Reflect.construct(Super, arguments, NewTarget);
} else {
result = Super.apply(this, arguments);
}
return _possibleConstructorReturn(this, result);
};
}
import { __decorate } from "tslib";
import React from 'react';
import PropTypes from 'prop-types';
import { observer } from 'mobx-react';
import noop from 'lodash/noop';
import Slider from '../../../es/slider';
import { NumberField } from '../number-field/NumberField';
var Range =
/*#__PURE__*/
function (_NumberField) {
_inherits(Range, _NumberField);
var _super = _createSuper(Range);
function Range() {
_classCallCheck(this, Range);
return _super.apply(this, arguments);
}
_createClass(Range, [{
key: "renderWrapper",
value: function renderWrapper() {
return React.createElement("label", _extends({
key: "wrapper"
}, this.getWrapperProps()), this.renderTrack());
}
}, {
key: "renderTrack",
value: function renderTrack() {
var _this = this;
var _this$props = this.props,
dataSet = _this$props.dataSet,
_this$props$onChange = _this$props.onChange,
_onChange = _this$props$onChange === void 0 ? noop : _this$props$onChange,
otherProps = _objectWithoutProperties(_this$props, ["dataSet", "onChange"]),
prefixCls = this.prefixCls;
if (dataSet) {
var _dataSet$props$fields = dataSet.props.fields,
fields = _dataSet$props$fields === void 0 ? [] : _dataSet$props$fields;
var props = {};
if (otherProps.name) {
var fieldProps = fields.find(function (x) {
return x.name === otherProps.name;
});
props = fieldProps;
}
return React.createElement(Slider, _extends({
prefixCls: prefixCls
}, otherProps, props, {
onChange: function onChange(value) {
_this.setValue(value);
_onChange(value);
}
}));
}
return React.createElement(Slider, _extends({
prefixCls: prefixCls
}, otherProps, {
onChange: _onChange
}));
}
}]);
return Range;
}(NumberField);
Range.displayName = 'Range';
Range.propTypes = _objectSpread({
/**
* 是否垂直方向
* @default
* false
*/
vertical: PropTypes.bool,
dots: PropTypes.bool,
marks: PropTypes.object,
included: PropTypes.bool
}, NumberField.propTypes);
Range.defaultProps = _objectSpread({}, NumberField.defaultProps, {
suffixCls: 'range',
min: 0,
step: 1,
max: 100,
vertical: false,
dots: false,
marks: {},
included: true,
range: false,
tipFormatter: null
});
Range = __decorate([observer], Range);
export default Range;
//# sourceMappingURL=Range.js.map