yqcloud-ui
Version:
An enterprise-class UI design language and React-based implementation
112 lines (87 loc) • 3.72 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
var Star = function (_React$Component) {
(0, _inherits3['default'])(Star, _React$Component);
function Star() {
var _temp, _this, _ret;
(0, _classCallCheck3['default'])(this, Star);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3['default'])(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _this.onHover = function (e) {
var _this$props = _this.props,
onHover = _this$props.onHover,
index = _this$props.index;
onHover(e, index);
}, _this.onClick = function (e) {
var _this$props2 = _this.props,
onClick = _this$props2.onClick,
index = _this$props2.index;
onClick(e, index);
}, _temp), (0, _possibleConstructorReturn3['default'])(_this, _ret);
}
Star.prototype.getClassName = function getClassName() {
var _props = this.props,
prefixCls = _props.prefixCls,
index = _props.index,
value = _props.value,
allowHalf = _props.allowHalf,
focused = _props.focused;
var starValue = index + 1;
var className = prefixCls;
if (value === 0 && index === 0 && focused) {
className += ' ' + prefixCls + '-focused';
} else if (allowHalf && value + 0.5 === starValue) {
className += ' ' + prefixCls + '-half ' + prefixCls + '-active';
if (focused) {
className += ' ' + prefixCls + '-focused';
}
} else {
className += starValue <= value ? ' ' + prefixCls + '-full' : ' ' + prefixCls + '-zero';
if (starValue === value && focused) {
className += ' ' + prefixCls + '-focused';
}
}
return className;
};
Star.prototype.render = function render() {
var onHover = this.onHover,
onClick = this.onClick;
var _props2 = this.props,
disabled = _props2.disabled,
prefixCls = _props2.prefixCls,
character = _props2.character;
return _react2['default'].createElement('li', {
className: this.getClassName(),
onClick: disabled ? null : onClick,
onMouseMove: disabled ? null : onHover
}, _react2['default'].createElement('div', { className: prefixCls + '-first' }, character), _react2['default'].createElement('div', { className: prefixCls + '-second' }, character));
};
return Star;
}(_react2['default'].Component);
Star.propTypes = {
value: _propTypes2['default'].number,
index: _propTypes2['default'].number,
prefixCls: _propTypes2['default'].string,
allowHalf: _propTypes2['default'].bool,
disabled: _propTypes2['default'].bool,
onHover: _propTypes2['default'].func,
onClick: _propTypes2['default'].func,
character: _propTypes2['default'].node,
focused: _propTypes2['default'].bool
};
exports['default'] = Star;
module.exports = exports['default'];