fomantic-ui-react
Version:
Fomantic-UI React -- A React Component Library.
106 lines (89 loc) • 4.05 kB
JavaScript
/**
* fomantic-ui-react v0.0.1-alpha.10
* (c) 2022 FireLoong <fireloong@foxmail.com>
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var defineProperty = require('../_chunks/dep-6ab59a61.js');
var slicedToArray = require('../_chunks/dep-640599ea.js');
var objectWithoutProperties = require('../_chunks/dep-03754121.js');
var classNames = require('classnames');
var _ = require('lodash');
var React = require('react');
var icon_index = require('../icon/index.js');
require('../icon/Icon.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var classNames__default = /*#__PURE__*/_interopDefaultLegacy(classNames);
var ___default = /*#__PURE__*/_interopDefaultLegacy(_);
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
var _excluded = ["as", "className", "icon", "max", "rating", "color", "disabled", "size"];
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { defineProperty._defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
var Rating = function Rating(_ref) {
var _ref$as = _ref.as,
as = _ref$as === void 0 ? "div" : _ref$as,
className = _ref.className,
_ref$icon = _ref.icon,
icon = _ref$icon === void 0 ? "star" : _ref$icon,
_ref$max = _ref.max,
max = _ref$max === void 0 ? 1 : _ref$max,
_ref$rating = _ref.rating,
rating = _ref$rating === void 0 ? 0 : _ref$rating,
_ref$color = _ref.color,
color = _ref$color === void 0 ? "black" : _ref$color,
disabled = _ref.disabled,
size = _ref.size,
props = objectWithoutProperties._objectWithoutProperties(_ref, _excluded);
var _useState = React.useState(false),
_useState2 = slicedToArray._slicedToArray(_useState, 2),
selected = _useState2[0],
setSelected = _useState2[1];
var _useState3 = React.useState(-1),
_useState4 = slicedToArray._slicedToArray(_useState3, 2),
selectedIndex = _useState4[0],
setSelectedIndex = _useState4[1];
var _useState5 = React.useState(rating),
_useState6 = slicedToArray._slicedToArray(_useState5, 2),
ratingVal = _useState6[0],
setRatingVal = _useState6[1];
if (!as) {
as = "div";
}
return /*#__PURE__*/React.createElement(as, _objectSpread({
className: classNames__default["default"]("ui", size, color, {
disabled: disabled
}, "rating", {
selected: selected
}, className),
onMouseLeave: function onMouseLeave() {
if (!disabled) {
setSelectedIndex(-1);
setSelected(false);
}
}
}, props), ___default["default"].times(max, function (i) {
return /* @__PURE__ */React__default["default"].createElement(icon_index.Icon, {
key: i,
name: icon,
className: classNames__default["default"]({
active: ratingVal > i,
selected: selected && selectedIndex >= i
}),
onClick: function onClick() {
if (!disabled) {
setRatingVal(i + 1);
}
},
onMouseEnter: function onMouseEnter() {
if (!disabled) {
setSelectedIndex(i);
setSelected(true);
}
}
});
}));
};
Rating.displayName = "Rating";
exports["default"] = Rating;
//# sourceMappingURL=Rating.js.map