first commit
This commit is contained in:
9
frontend/node_modules/rc-rate/LICENSE.md
generated
vendored
Normal file
9
frontend/node_modules/rc-rate/LICENSE.md
generated
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) 2014-present yiminghe
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
121
frontend/node_modules/rc-rate/README.md
generated
vendored
Normal file
121
frontend/node_modules/rc-rate/README.md
generated
vendored
Normal file
@@ -0,0 +1,121 @@
|
||||
# rc-rate
|
||||
|
||||
React Rate Component
|
||||
|
||||
[![NPM version][npm-image]][npm-url]
|
||||
[![npm download][download-image]][download-url]
|
||||
[![build status][github-actions-image]][github-actions-url]
|
||||
[![Codecov][codecov-image]][codecov-url]
|
||||
[![bundle size][bundlephobia-image]][bundlephobia-url]
|
||||
[![dumi][dumi-image]][dumi-url]
|
||||
|
||||
[npm-image]: http://img.shields.io/npm/v/rc-rate.svg?style=flat-square
|
||||
[npm-url]: http://npmjs.org/package/rc-rate
|
||||
[github-actions-image]: https://github.com/react-component/rate/workflows/CI/badge.svg
|
||||
[github-actions-url]: https://github.com/react-component/rate/actions
|
||||
[codecov-image]: https://img.shields.io/codecov/c/github/react-component/rate/master.svg?style=flat-square
|
||||
[codecov-url]: https://codecov.io/gh/react-component/rate/branch/master
|
||||
[david-url]: https://david-dm.org/react-component/rate
|
||||
[david-image]: https://david-dm.org/react-component/rate/status.svg?style=flat-square
|
||||
[david-dev-url]: https://david-dm.org/react-component/rate?type=dev
|
||||
[david-dev-image]: https://david-dm.org/react-component/rate/dev-status.svg?style=flat-square
|
||||
[download-image]: https://img.shields.io/npm/dm/rc-rate.svg?style=flat-square
|
||||
[download-url]: https://npmjs.org/package/rc-rate
|
||||
[bundlephobia-url]: https://bundlephobia.com/result?p=rc-rate
|
||||
[bundlephobia-image]: https://badgen.net/bundlephobia/minzip/rc-rate
|
||||
[dumi-url]: https://github.com/umijs/dumi
|
||||
[dumi-image]: https://img.shields.io/badge/docs%20by-dumi-blue?style=flat-square
|
||||
|
||||
## Screenshots
|
||||
|
||||
<img src="https://img.alicdn.com/tps/TB1ijlpLVXXXXb8XpXXXXXXXXXX-466-172.png" width="288"/>
|
||||
|
||||
## Changelog
|
||||
|
||||
- [CHANGELOG](./CHANGELOG.md)
|
||||
|
||||
## Development
|
||||
|
||||
```
|
||||
npm install
|
||||
npm start
|
||||
```
|
||||
|
||||
## Example
|
||||
|
||||
- Local: http://localhost:9001/
|
||||
|
||||
- Online: http://react-component.github.io/rate/
|
||||
|
||||
## install
|
||||
|
||||
[](https://npmjs.org/package/rc-rate)
|
||||
|
||||
## Usage
|
||||
|
||||
```js
|
||||
import React from 'react';
|
||||
import ReactDOM from 'react-dom';
|
||||
import Rate from 'rc-rate';
|
||||
|
||||
ReactDOM.render(
|
||||
<Rate />,
|
||||
document.getElementById('root')
|
||||
)
|
||||
```
|
||||
|
||||
### with [styled-components](https://github.com/styled-components/styled-components)
|
||||
```js
|
||||
import React from 'react';
|
||||
import ReactDOM from 'react-dom';
|
||||
import Rate from 'rc-rate';
|
||||
import styled from 'styled-components';
|
||||
|
||||
const StyledRate = styled(Rate)`
|
||||
&.rc-rate {
|
||||
font-size: ${({ size }) => size}px;
|
||||
}
|
||||
`
|
||||
|
||||
ReactDOM.render(
|
||||
<StyledRate size="24" />,
|
||||
document.getElementById('root')
|
||||
)
|
||||
```
|
||||
|
||||
## API
|
||||
|
||||
### props
|
||||
|
||||
| name | type | default | description |
|
||||
| ------------- | --------------------------------- | ------------- | ----------------------------------------------------- |
|
||||
| count | number | 5 | Star numbers |
|
||||
| value | number | - | Controlled value |
|
||||
| defaultValue | number | 0 | Initial value |
|
||||
| allowHalf | boolean | false | Support half star |
|
||||
| allowClear | boolean | true | Reset when click again |
|
||||
| style | object | {} | |
|
||||
| onChange | function | (value) => {} | `onChange` will be triggered when click |
|
||||
| onHoverChange | function | (value) => {} | `onHoverChange` will be triggered when hover on stars |
|
||||
| character | ReactNode \| (props) => ReactNode | ★ | The each character of rate |
|
||||
| disabled | boolean | false | |
|
||||
| direction | string | `ltr` | The direction of rate |
|
||||
|
||||
## Test Case
|
||||
|
||||
```
|
||||
npm test
|
||||
npm run chrome-test
|
||||
```
|
||||
|
||||
## Coverage
|
||||
|
||||
```
|
||||
npm run coverage
|
||||
```
|
||||
|
||||
open coverage/ dir
|
||||
|
||||
## License
|
||||
|
||||
rc-rate is released under the MIT license.
|
||||
97
frontend/node_modules/rc-rate/assets/index.css
generated
vendored
Normal file
97
frontend/node_modules/rc-rate/assets/index.css
generated
vendored
Normal file
@@ -0,0 +1,97 @@
|
||||
.rc-rate {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
list-style: none;
|
||||
font-size: 18px;
|
||||
display: inline-block;
|
||||
vertical-align: middle;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
outline: none;
|
||||
}
|
||||
.rc-rate-rtl {
|
||||
direction: rtl;
|
||||
}
|
||||
.rc-rate-disabled .rc-rate-star {
|
||||
cursor: default;
|
||||
}
|
||||
.rc-rate-disabled .rc-rate-star:before,
|
||||
.rc-rate-disabled .rc-rate-star-content:before {
|
||||
cursor: default;
|
||||
}
|
||||
.rc-rate-disabled .rc-rate-star:hover {
|
||||
transform: scale(1);
|
||||
}
|
||||
.rc-rate-star {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
display: inline-block;
|
||||
margin-right: 8px;
|
||||
position: relative;
|
||||
transition: all 0.3s;
|
||||
color: #e9e9e9;
|
||||
cursor: pointer;
|
||||
line-height: 1.5;
|
||||
}
|
||||
.rc-rate-rtl .rc-rate-star {
|
||||
margin-right: 0;
|
||||
margin-left: 8px;
|
||||
float: right;
|
||||
}
|
||||
.rc-rate-star-first,
|
||||
.rc-rate-star-second {
|
||||
transition: all 0.3s;
|
||||
}
|
||||
.rc-rate-star-focused,
|
||||
.rc-rate-star:hover {
|
||||
transform: scale(1.1);
|
||||
}
|
||||
.rc-rate-star-first {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
width: 50%;
|
||||
height: 100%;
|
||||
overflow: hidden;
|
||||
opacity: 0;
|
||||
}
|
||||
.rc-rate-rtl .rc-rate-star-first {
|
||||
right: 0;
|
||||
left: auto;
|
||||
}
|
||||
.rc-rate-star-half .rc-rate-star-first,
|
||||
.rc-rate-star-half .rc-rate-star-second {
|
||||
opacity: 1;
|
||||
}
|
||||
.rc-rate-star-half .rc-rate-star-first,
|
||||
.rc-rate-star-full .rc-rate-star-second {
|
||||
color: #f5a623;
|
||||
}
|
||||
.rc-rate-star-half:hover .rc-rate-star-first,
|
||||
.rc-rate-star-full:hover .rc-rate-star-second {
|
||||
color: #f8c165;
|
||||
}
|
||||
@font-face {
|
||||
font-family: 'anticon';
|
||||
src: url('//at.alicdn.com/t/font_r5u29ls31bgldi.eot');
|
||||
/* IE9*/
|
||||
src: url('//at.alicdn.com/t/font_r5u29ls31bgldi.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('//at.alicdn.com/t/font_r5u29ls31bgldi.woff') format('woff'), /* chrome、firefox */ url('//at.alicdn.com/t/font_r5u29ls31bgldi.ttf') format('truetype'), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/ url('//at.alicdn.com/t/font_r5u29ls31bgldi.svg#iconfont') format('svg');
|
||||
/* iOS 4.1- */
|
||||
}
|
||||
.anticon {
|
||||
font-style: normal;
|
||||
vertical-align: baseline;
|
||||
text-align: center;
|
||||
text-transform: none;
|
||||
line-height: 1;
|
||||
text-rendering: optimizeLegibility;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
}
|
||||
.anticon:before {
|
||||
display: block;
|
||||
font-family: "anticon" !important;
|
||||
}
|
||||
.anticon-star:before {
|
||||
content: "\e660";
|
||||
}
|
||||
32
frontend/node_modules/rc-rate/es/Rate.d.ts
generated
vendored
Normal file
32
frontend/node_modules/rc-rate/es/Rate.d.ts
generated
vendored
Normal file
@@ -0,0 +1,32 @@
|
||||
import React from 'react';
|
||||
import type { StarProps } from './Star';
|
||||
export interface RateProps extends Pick<StarProps, 'count' | 'character' | 'characterRender' | 'allowHalf' | 'disabled'> {
|
||||
value?: number;
|
||||
defaultValue?: number;
|
||||
allowClear?: boolean;
|
||||
style?: React.CSSProperties;
|
||||
prefixCls?: string;
|
||||
onChange?: (value: number) => void;
|
||||
onHoverChange?: (value: number) => void;
|
||||
className?: string;
|
||||
tabIndex?: number;
|
||||
onFocus?: () => void;
|
||||
onBlur?: () => void;
|
||||
onKeyDown?: React.KeyboardEventHandler<HTMLUListElement>;
|
||||
onMouseEnter?: React.MouseEventHandler<HTMLUListElement>;
|
||||
onMouseLeave?: React.MouseEventHandler<HTMLUListElement>;
|
||||
id?: string;
|
||||
autoFocus?: boolean;
|
||||
direction?: string;
|
||||
/**
|
||||
* Is keyboard control enabled.
|
||||
* @default true
|
||||
*/
|
||||
keyboard?: boolean;
|
||||
}
|
||||
export interface RateRef {
|
||||
focus: VoidFunction;
|
||||
blur: VoidFunction;
|
||||
}
|
||||
declare const _default: React.ForwardRefExoticComponent<RateProps & React.RefAttributes<RateRef>>;
|
||||
export default _default;
|
||||
217
frontend/node_modules/rc-rate/es/Rate.js
generated
vendored
Normal file
217
frontend/node_modules/rc-rate/es/Rate.js
generated
vendored
Normal file
@@ -0,0 +1,217 @@
|
||||
import _extends from "@babel/runtime/helpers/esm/extends";
|
||||
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
||||
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
||||
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
||||
var _excluded = ["prefixCls", "className", "defaultValue", "value", "count", "allowHalf", "allowClear", "keyboard", "character", "characterRender", "disabled", "direction", "tabIndex", "autoFocus", "onHoverChange", "onChange", "onFocus", "onBlur", "onKeyDown", "onMouseLeave"];
|
||||
import classNames from 'classnames';
|
||||
import useMergedState from "rc-util/es/hooks/useMergedState";
|
||||
import KeyCode from "rc-util/es/KeyCode";
|
||||
import pickAttrs from "rc-util/es/pickAttrs";
|
||||
import React from 'react';
|
||||
import Star from "./Star";
|
||||
import useRefs from "./useRefs";
|
||||
import { getOffsetLeft } from "./util";
|
||||
function Rate(props, ref) {
|
||||
var _props$prefixCls = props.prefixCls,
|
||||
prefixCls = _props$prefixCls === void 0 ? 'rc-rate' : _props$prefixCls,
|
||||
className = props.className,
|
||||
defaultValue = props.defaultValue,
|
||||
propValue = props.value,
|
||||
_props$count = props.count,
|
||||
count = _props$count === void 0 ? 5 : _props$count,
|
||||
_props$allowHalf = props.allowHalf,
|
||||
allowHalf = _props$allowHalf === void 0 ? false : _props$allowHalf,
|
||||
_props$allowClear = props.allowClear,
|
||||
allowClear = _props$allowClear === void 0 ? true : _props$allowClear,
|
||||
_props$keyboard = props.keyboard,
|
||||
keyboard = _props$keyboard === void 0 ? true : _props$keyboard,
|
||||
_props$character = props.character,
|
||||
character = _props$character === void 0 ? '★' : _props$character,
|
||||
characterRender = props.characterRender,
|
||||
disabled = props.disabled,
|
||||
_props$direction = props.direction,
|
||||
direction = _props$direction === void 0 ? 'ltr' : _props$direction,
|
||||
_props$tabIndex = props.tabIndex,
|
||||
tabIndex = _props$tabIndex === void 0 ? 0 : _props$tabIndex,
|
||||
autoFocus = props.autoFocus,
|
||||
onHoverChange = props.onHoverChange,
|
||||
onChange = props.onChange,
|
||||
onFocus = props.onFocus,
|
||||
onBlur = props.onBlur,
|
||||
onKeyDown = props.onKeyDown,
|
||||
onMouseLeave = props.onMouseLeave,
|
||||
restProps = _objectWithoutProperties(props, _excluded);
|
||||
var _useRefs = useRefs(),
|
||||
_useRefs2 = _slicedToArray(_useRefs, 2),
|
||||
getStarRef = _useRefs2[0],
|
||||
setStarRef = _useRefs2[1];
|
||||
var rateRef = React.useRef(null);
|
||||
|
||||
// ============================ Ref =============================
|
||||
var triggerFocus = function triggerFocus() {
|
||||
if (!disabled) {
|
||||
var _rateRef$current;
|
||||
(_rateRef$current = rateRef.current) === null || _rateRef$current === void 0 || _rateRef$current.focus();
|
||||
}
|
||||
};
|
||||
React.useImperativeHandle(ref, function () {
|
||||
return {
|
||||
focus: triggerFocus,
|
||||
blur: function blur() {
|
||||
if (!disabled) {
|
||||
var _rateRef$current2;
|
||||
(_rateRef$current2 = rateRef.current) === null || _rateRef$current2 === void 0 || _rateRef$current2.blur();
|
||||
}
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
// =========================== Value ============================
|
||||
var _useMergedState = useMergedState(defaultValue || 0, {
|
||||
value: propValue
|
||||
}),
|
||||
_useMergedState2 = _slicedToArray(_useMergedState, 2),
|
||||
value = _useMergedState2[0],
|
||||
setValue = _useMergedState2[1];
|
||||
var _useMergedState3 = useMergedState(null),
|
||||
_useMergedState4 = _slicedToArray(_useMergedState3, 2),
|
||||
cleanedValue = _useMergedState4[0],
|
||||
setCleanedValue = _useMergedState4[1];
|
||||
var getStarValue = function getStarValue(index, x) {
|
||||
var reverse = direction === 'rtl';
|
||||
var starValue = index + 1;
|
||||
if (allowHalf) {
|
||||
var starEle = getStarRef(index);
|
||||
var leftDis = getOffsetLeft(starEle);
|
||||
var width = starEle.clientWidth;
|
||||
if (reverse && x - leftDis > width / 2) {
|
||||
starValue -= 0.5;
|
||||
} else if (!reverse && x - leftDis < width / 2) {
|
||||
starValue -= 0.5;
|
||||
}
|
||||
}
|
||||
return starValue;
|
||||
};
|
||||
|
||||
// >>>>> Change
|
||||
var changeValue = function changeValue(nextValue) {
|
||||
setValue(nextValue);
|
||||
onChange === null || onChange === void 0 || onChange(nextValue);
|
||||
};
|
||||
|
||||
// =========================== Focus ============================
|
||||
var _React$useState = React.useState(false),
|
||||
_React$useState2 = _slicedToArray(_React$useState, 2),
|
||||
focused = _React$useState2[0],
|
||||
setFocused = _React$useState2[1];
|
||||
var onInternalFocus = function onInternalFocus() {
|
||||
setFocused(true);
|
||||
onFocus === null || onFocus === void 0 || onFocus();
|
||||
};
|
||||
var onInternalBlur = function onInternalBlur() {
|
||||
setFocused(false);
|
||||
onBlur === null || onBlur === void 0 || onBlur();
|
||||
};
|
||||
|
||||
// =========================== Hover ============================
|
||||
var _React$useState3 = React.useState(null),
|
||||
_React$useState4 = _slicedToArray(_React$useState3, 2),
|
||||
hoverValue = _React$useState4[0],
|
||||
setHoverValue = _React$useState4[1];
|
||||
var onHover = function onHover(event, index) {
|
||||
var nextHoverValue = getStarValue(index, event.pageX);
|
||||
if (nextHoverValue !== cleanedValue) {
|
||||
setHoverValue(nextHoverValue);
|
||||
setCleanedValue(null);
|
||||
}
|
||||
onHoverChange === null || onHoverChange === void 0 || onHoverChange(nextHoverValue);
|
||||
};
|
||||
var onMouseLeaveCallback = function onMouseLeaveCallback(event) {
|
||||
if (!disabled) {
|
||||
setHoverValue(null);
|
||||
setCleanedValue(null);
|
||||
onHoverChange === null || onHoverChange === void 0 || onHoverChange(undefined);
|
||||
}
|
||||
if (event) {
|
||||
onMouseLeave === null || onMouseLeave === void 0 || onMouseLeave(event);
|
||||
}
|
||||
};
|
||||
|
||||
// =========================== Click ============================
|
||||
var onClick = function onClick(event, index) {
|
||||
var newValue = getStarValue(index, event.pageX);
|
||||
var isReset = false;
|
||||
if (allowClear) {
|
||||
isReset = newValue === value;
|
||||
}
|
||||
onMouseLeaveCallback();
|
||||
changeValue(isReset ? 0 : newValue);
|
||||
setCleanedValue(isReset ? newValue : null);
|
||||
};
|
||||
var onInternalKeyDown = function onInternalKeyDown(event) {
|
||||
var keyCode = event.keyCode;
|
||||
var reverse = direction === 'rtl';
|
||||
var step = allowHalf ? 0.5 : 1;
|
||||
if (keyboard) {
|
||||
if (keyCode === KeyCode.RIGHT && value < count && !reverse) {
|
||||
changeValue(value + step);
|
||||
event.preventDefault();
|
||||
} else if (keyCode === KeyCode.LEFT && value > 0 && !reverse) {
|
||||
changeValue(value - step);
|
||||
event.preventDefault();
|
||||
} else if (keyCode === KeyCode.RIGHT && value > 0 && reverse) {
|
||||
changeValue(value - step);
|
||||
event.preventDefault();
|
||||
} else if (keyCode === KeyCode.LEFT && value < count && reverse) {
|
||||
changeValue(value + step);
|
||||
event.preventDefault();
|
||||
}
|
||||
}
|
||||
onKeyDown === null || onKeyDown === void 0 || onKeyDown(event);
|
||||
};
|
||||
|
||||
// =========================== Effect ===========================
|
||||
|
||||
React.useEffect(function () {
|
||||
if (autoFocus && !disabled) {
|
||||
triggerFocus();
|
||||
}
|
||||
}, []);
|
||||
|
||||
// =========================== Render ===========================
|
||||
// >>> Star
|
||||
var starNodes = new Array(count).fill(0).map(function (item, index) {
|
||||
return /*#__PURE__*/React.createElement(Star, {
|
||||
ref: setStarRef(index),
|
||||
index: index,
|
||||
count: count,
|
||||
disabled: disabled,
|
||||
prefixCls: "".concat(prefixCls, "-star"),
|
||||
allowHalf: allowHalf,
|
||||
value: hoverValue === null ? value : hoverValue,
|
||||
onClick: onClick,
|
||||
onHover: onHover,
|
||||
key: item || index,
|
||||
character: character,
|
||||
characterRender: characterRender,
|
||||
focused: focused
|
||||
});
|
||||
});
|
||||
var classString = classNames(prefixCls, className, _defineProperty(_defineProperty({}, "".concat(prefixCls, "-disabled"), disabled), "".concat(prefixCls, "-rtl"), direction === 'rtl'));
|
||||
|
||||
// >>> Node
|
||||
return /*#__PURE__*/React.createElement("ul", _extends({
|
||||
className: classString,
|
||||
onMouseLeave: onMouseLeaveCallback,
|
||||
tabIndex: disabled ? -1 : tabIndex,
|
||||
onFocus: disabled ? null : onInternalFocus,
|
||||
onBlur: disabled ? null : onInternalBlur,
|
||||
onKeyDown: disabled ? null : onInternalKeyDown,
|
||||
ref: rateRef
|
||||
}, pickAttrs(restProps, {
|
||||
aria: true,
|
||||
data: true,
|
||||
attr: true
|
||||
})), starNodes);
|
||||
}
|
||||
export default /*#__PURE__*/React.forwardRef(Rate);
|
||||
16
frontend/node_modules/rc-rate/es/Star.d.ts
generated
vendored
Normal file
16
frontend/node_modules/rc-rate/es/Star.d.ts
generated
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
import React from 'react';
|
||||
export interface StarProps {
|
||||
value?: number;
|
||||
index?: number;
|
||||
prefixCls?: string;
|
||||
allowHalf?: boolean;
|
||||
disabled?: boolean;
|
||||
onHover?: (e: React.MouseEvent<HTMLDivElement>, index: number) => void;
|
||||
onClick?: (e: React.MouseEvent<HTMLDivElement> | React.KeyboardEvent<HTMLDivElement>, index: number) => void;
|
||||
character?: React.ReactNode | ((props: StarProps) => React.ReactNode);
|
||||
characterRender?: (origin: React.ReactElement, props: StarProps) => React.ReactNode;
|
||||
focused?: boolean;
|
||||
count?: number;
|
||||
}
|
||||
declare const _default: React.ForwardRefExoticComponent<StarProps & React.RefAttributes<HTMLLIElement>>;
|
||||
export default _default;
|
||||
79
frontend/node_modules/rc-rate/es/Star.js
generated
vendored
Normal file
79
frontend/node_modules/rc-rate/es/Star.js
generated
vendored
Normal file
@@ -0,0 +1,79 @@
|
||||
import React from 'react';
|
||||
import KeyCode from "rc-util/es/KeyCode";
|
||||
import classNames from 'classnames';
|
||||
function Star(props, ref) {
|
||||
var disabled = props.disabled,
|
||||
prefixCls = props.prefixCls,
|
||||
character = props.character,
|
||||
characterRender = props.characterRender,
|
||||
index = props.index,
|
||||
count = props.count,
|
||||
value = props.value,
|
||||
allowHalf = props.allowHalf,
|
||||
focused = props.focused,
|
||||
onHover = props.onHover,
|
||||
onClick = props.onClick;
|
||||
|
||||
// =========================== Events ===========================
|
||||
var onInternalHover = function onInternalHover(e) {
|
||||
onHover(e, index);
|
||||
};
|
||||
var onInternalClick = function onInternalClick(e) {
|
||||
onClick(e, index);
|
||||
};
|
||||
var onInternalKeyDown = function onInternalKeyDown(e) {
|
||||
if (e.keyCode === KeyCode.ENTER) {
|
||||
onClick(e, index);
|
||||
}
|
||||
};
|
||||
|
||||
// =========================== Render ===========================
|
||||
// >>>>> ClassName
|
||||
var starValue = index + 1;
|
||||
var classNameList = new Set([prefixCls]);
|
||||
|
||||
// TODO: Current we just refactor from CC to FC. This logic seems can be optimized.
|
||||
if (value === 0 && index === 0 && focused) {
|
||||
classNameList.add("".concat(prefixCls, "-focused"));
|
||||
} else if (allowHalf && value + 0.5 >= starValue && value < starValue) {
|
||||
classNameList.add("".concat(prefixCls, "-half"));
|
||||
classNameList.add("".concat(prefixCls, "-active"));
|
||||
if (focused) {
|
||||
classNameList.add("".concat(prefixCls, "-focused"));
|
||||
}
|
||||
} else {
|
||||
if (starValue <= value) {
|
||||
classNameList.add("".concat(prefixCls, "-full"));
|
||||
} else {
|
||||
classNameList.add("".concat(prefixCls, "-zero"));
|
||||
}
|
||||
if (starValue === value && focused) {
|
||||
classNameList.add("".concat(prefixCls, "-focused"));
|
||||
}
|
||||
}
|
||||
|
||||
// >>>>> Node
|
||||
var characterNode = typeof character === 'function' ? character(props) : character;
|
||||
var start = /*#__PURE__*/React.createElement("li", {
|
||||
className: classNames(Array.from(classNameList)),
|
||||
ref: ref
|
||||
}, /*#__PURE__*/React.createElement("div", {
|
||||
onClick: disabled ? null : onInternalClick,
|
||||
onKeyDown: disabled ? null : onInternalKeyDown,
|
||||
onMouseMove: disabled ? null : onInternalHover,
|
||||
role: "radio",
|
||||
"aria-checked": value > index ? 'true' : 'false',
|
||||
"aria-posinset": index + 1,
|
||||
"aria-setsize": count,
|
||||
tabIndex: disabled ? -1 : 0
|
||||
}, /*#__PURE__*/React.createElement("div", {
|
||||
className: "".concat(prefixCls, "-first")
|
||||
}, characterNode), /*#__PURE__*/React.createElement("div", {
|
||||
className: "".concat(prefixCls, "-second")
|
||||
}, characterNode)));
|
||||
if (characterRender) {
|
||||
start = characterRender(start, props);
|
||||
}
|
||||
return start;
|
||||
}
|
||||
export default /*#__PURE__*/React.forwardRef(Star);
|
||||
2
frontend/node_modules/rc-rate/es/index.d.ts
generated
vendored
Normal file
2
frontend/node_modules/rc-rate/es/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import Rate from './Rate';
|
||||
export default Rate;
|
||||
2
frontend/node_modules/rc-rate/es/index.js
generated
vendored
Normal file
2
frontend/node_modules/rc-rate/es/index.js
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import Rate from "./Rate";
|
||||
export default Rate;
|
||||
4
frontend/node_modules/rc-rate/es/useRefs.d.ts
generated
vendored
Normal file
4
frontend/node_modules/rc-rate/es/useRefs.d.ts
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
export default function useRefs<T>(): [
|
||||
getRef: (index: number) => T,
|
||||
setRef: (index: number) => (instance: T) => void
|
||||
];
|
||||
13
frontend/node_modules/rc-rate/es/useRefs.js
generated
vendored
Normal file
13
frontend/node_modules/rc-rate/es/useRefs.js
generated
vendored
Normal file
@@ -0,0 +1,13 @@
|
||||
import * as React from 'react';
|
||||
export default function useRefs() {
|
||||
var nodeRef = React.useRef({});
|
||||
function getRef(index) {
|
||||
return nodeRef.current[index];
|
||||
}
|
||||
function setRef(index) {
|
||||
return function (node) {
|
||||
nodeRef.current[index] = node;
|
||||
};
|
||||
}
|
||||
return [getRef, setRef];
|
||||
}
|
||||
1
frontend/node_modules/rc-rate/es/util.d.ts
generated
vendored
Normal file
1
frontend/node_modules/rc-rate/es/util.d.ts
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
export declare function getOffsetLeft(el: HTMLElement): number;
|
||||
38
frontend/node_modules/rc-rate/es/util.js
generated
vendored
Normal file
38
frontend/node_modules/rc-rate/es/util.js
generated
vendored
Normal file
@@ -0,0 +1,38 @@
|
||||
function getScroll(w) {
|
||||
var ret = w.pageXOffset;
|
||||
var method = 'scrollLeft';
|
||||
if (typeof ret !== 'number') {
|
||||
var d = w.document;
|
||||
// ie6,7,8 standard mode
|
||||
ret = d.documentElement[method];
|
||||
if (typeof ret !== 'number') {
|
||||
// quirks mode
|
||||
ret = d.body[method];
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
function getClientPosition(elem) {
|
||||
var x;
|
||||
var y;
|
||||
var doc = elem.ownerDocument;
|
||||
var body = doc.body;
|
||||
var docElem = doc && doc.documentElement;
|
||||
var box = elem.getBoundingClientRect();
|
||||
x = box.left;
|
||||
y = box.top;
|
||||
x -= docElem.clientLeft || body.clientLeft || 0;
|
||||
y -= docElem.clientTop || body.clientTop || 0;
|
||||
return {
|
||||
left: x,
|
||||
top: y
|
||||
};
|
||||
}
|
||||
export function getOffsetLeft(el) {
|
||||
var pos = getClientPosition(el);
|
||||
var doc = el.ownerDocument;
|
||||
// Only IE use `parentWindow`
|
||||
var w = doc.defaultView || doc.parentWindow;
|
||||
pos.left += getScroll(w);
|
||||
return pos.left;
|
||||
}
|
||||
32
frontend/node_modules/rc-rate/lib/Rate.d.ts
generated
vendored
Normal file
32
frontend/node_modules/rc-rate/lib/Rate.d.ts
generated
vendored
Normal file
@@ -0,0 +1,32 @@
|
||||
import React from 'react';
|
||||
import type { StarProps } from './Star';
|
||||
export interface RateProps extends Pick<StarProps, 'count' | 'character' | 'characterRender' | 'allowHalf' | 'disabled'> {
|
||||
value?: number;
|
||||
defaultValue?: number;
|
||||
allowClear?: boolean;
|
||||
style?: React.CSSProperties;
|
||||
prefixCls?: string;
|
||||
onChange?: (value: number) => void;
|
||||
onHoverChange?: (value: number) => void;
|
||||
className?: string;
|
||||
tabIndex?: number;
|
||||
onFocus?: () => void;
|
||||
onBlur?: () => void;
|
||||
onKeyDown?: React.KeyboardEventHandler<HTMLUListElement>;
|
||||
onMouseEnter?: React.MouseEventHandler<HTMLUListElement>;
|
||||
onMouseLeave?: React.MouseEventHandler<HTMLUListElement>;
|
||||
id?: string;
|
||||
autoFocus?: boolean;
|
||||
direction?: string;
|
||||
/**
|
||||
* Is keyboard control enabled.
|
||||
* @default true
|
||||
*/
|
||||
keyboard?: boolean;
|
||||
}
|
||||
export interface RateRef {
|
||||
focus: VoidFunction;
|
||||
blur: VoidFunction;
|
||||
}
|
||||
declare const _default: React.ForwardRefExoticComponent<RateProps & React.RefAttributes<RateRef>>;
|
||||
export default _default;
|
||||
224
frontend/node_modules/rc-rate/lib/Rate.js
generated
vendored
Normal file
224
frontend/node_modules/rc-rate/lib/Rate.js
generated
vendored
Normal file
@@ -0,0 +1,224 @@
|
||||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
||||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
||||
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
||||
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
||||
var _classnames = _interopRequireDefault(require("classnames"));
|
||||
var _useMergedState5 = _interopRequireDefault(require("rc-util/lib/hooks/useMergedState"));
|
||||
var _KeyCode = _interopRequireDefault(require("rc-util/lib/KeyCode"));
|
||||
var _pickAttrs = _interopRequireDefault(require("rc-util/lib/pickAttrs"));
|
||||
var _react = _interopRequireDefault(require("react"));
|
||||
var _Star = _interopRequireDefault(require("./Star"));
|
||||
var _useRefs3 = _interopRequireDefault(require("./useRefs"));
|
||||
var _util = require("./util");
|
||||
var _excluded = ["prefixCls", "className", "defaultValue", "value", "count", "allowHalf", "allowClear", "keyboard", "character", "characterRender", "disabled", "direction", "tabIndex", "autoFocus", "onHoverChange", "onChange", "onFocus", "onBlur", "onKeyDown", "onMouseLeave"];
|
||||
function Rate(props, ref) {
|
||||
var _props$prefixCls = props.prefixCls,
|
||||
prefixCls = _props$prefixCls === void 0 ? 'rc-rate' : _props$prefixCls,
|
||||
className = props.className,
|
||||
defaultValue = props.defaultValue,
|
||||
propValue = props.value,
|
||||
_props$count = props.count,
|
||||
count = _props$count === void 0 ? 5 : _props$count,
|
||||
_props$allowHalf = props.allowHalf,
|
||||
allowHalf = _props$allowHalf === void 0 ? false : _props$allowHalf,
|
||||
_props$allowClear = props.allowClear,
|
||||
allowClear = _props$allowClear === void 0 ? true : _props$allowClear,
|
||||
_props$keyboard = props.keyboard,
|
||||
keyboard = _props$keyboard === void 0 ? true : _props$keyboard,
|
||||
_props$character = props.character,
|
||||
character = _props$character === void 0 ? '★' : _props$character,
|
||||
characterRender = props.characterRender,
|
||||
disabled = props.disabled,
|
||||
_props$direction = props.direction,
|
||||
direction = _props$direction === void 0 ? 'ltr' : _props$direction,
|
||||
_props$tabIndex = props.tabIndex,
|
||||
tabIndex = _props$tabIndex === void 0 ? 0 : _props$tabIndex,
|
||||
autoFocus = props.autoFocus,
|
||||
onHoverChange = props.onHoverChange,
|
||||
onChange = props.onChange,
|
||||
onFocus = props.onFocus,
|
||||
onBlur = props.onBlur,
|
||||
onKeyDown = props.onKeyDown,
|
||||
onMouseLeave = props.onMouseLeave,
|
||||
restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
|
||||
var _useRefs = (0, _useRefs3.default)(),
|
||||
_useRefs2 = (0, _slicedToArray2.default)(_useRefs, 2),
|
||||
getStarRef = _useRefs2[0],
|
||||
setStarRef = _useRefs2[1];
|
||||
var rateRef = _react.default.useRef(null);
|
||||
|
||||
// ============================ Ref =============================
|
||||
var triggerFocus = function triggerFocus() {
|
||||
if (!disabled) {
|
||||
var _rateRef$current;
|
||||
(_rateRef$current = rateRef.current) === null || _rateRef$current === void 0 || _rateRef$current.focus();
|
||||
}
|
||||
};
|
||||
_react.default.useImperativeHandle(ref, function () {
|
||||
return {
|
||||
focus: triggerFocus,
|
||||
blur: function blur() {
|
||||
if (!disabled) {
|
||||
var _rateRef$current2;
|
||||
(_rateRef$current2 = rateRef.current) === null || _rateRef$current2 === void 0 || _rateRef$current2.blur();
|
||||
}
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
// =========================== Value ============================
|
||||
var _useMergedState = (0, _useMergedState5.default)(defaultValue || 0, {
|
||||
value: propValue
|
||||
}),
|
||||
_useMergedState2 = (0, _slicedToArray2.default)(_useMergedState, 2),
|
||||
value = _useMergedState2[0],
|
||||
setValue = _useMergedState2[1];
|
||||
var _useMergedState3 = (0, _useMergedState5.default)(null),
|
||||
_useMergedState4 = (0, _slicedToArray2.default)(_useMergedState3, 2),
|
||||
cleanedValue = _useMergedState4[0],
|
||||
setCleanedValue = _useMergedState4[1];
|
||||
var getStarValue = function getStarValue(index, x) {
|
||||
var reverse = direction === 'rtl';
|
||||
var starValue = index + 1;
|
||||
if (allowHalf) {
|
||||
var starEle = getStarRef(index);
|
||||
var leftDis = (0, _util.getOffsetLeft)(starEle);
|
||||
var width = starEle.clientWidth;
|
||||
if (reverse && x - leftDis > width / 2) {
|
||||
starValue -= 0.5;
|
||||
} else if (!reverse && x - leftDis < width / 2) {
|
||||
starValue -= 0.5;
|
||||
}
|
||||
}
|
||||
return starValue;
|
||||
};
|
||||
|
||||
// >>>>> Change
|
||||
var changeValue = function changeValue(nextValue) {
|
||||
setValue(nextValue);
|
||||
onChange === null || onChange === void 0 || onChange(nextValue);
|
||||
};
|
||||
|
||||
// =========================== Focus ============================
|
||||
var _React$useState = _react.default.useState(false),
|
||||
_React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
|
||||
focused = _React$useState2[0],
|
||||
setFocused = _React$useState2[1];
|
||||
var onInternalFocus = function onInternalFocus() {
|
||||
setFocused(true);
|
||||
onFocus === null || onFocus === void 0 || onFocus();
|
||||
};
|
||||
var onInternalBlur = function onInternalBlur() {
|
||||
setFocused(false);
|
||||
onBlur === null || onBlur === void 0 || onBlur();
|
||||
};
|
||||
|
||||
// =========================== Hover ============================
|
||||
var _React$useState3 = _react.default.useState(null),
|
||||
_React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
|
||||
hoverValue = _React$useState4[0],
|
||||
setHoverValue = _React$useState4[1];
|
||||
var onHover = function onHover(event, index) {
|
||||
var nextHoverValue = getStarValue(index, event.pageX);
|
||||
if (nextHoverValue !== cleanedValue) {
|
||||
setHoverValue(nextHoverValue);
|
||||
setCleanedValue(null);
|
||||
}
|
||||
onHoverChange === null || onHoverChange === void 0 || onHoverChange(nextHoverValue);
|
||||
};
|
||||
var onMouseLeaveCallback = function onMouseLeaveCallback(event) {
|
||||
if (!disabled) {
|
||||
setHoverValue(null);
|
||||
setCleanedValue(null);
|
||||
onHoverChange === null || onHoverChange === void 0 || onHoverChange(undefined);
|
||||
}
|
||||
if (event) {
|
||||
onMouseLeave === null || onMouseLeave === void 0 || onMouseLeave(event);
|
||||
}
|
||||
};
|
||||
|
||||
// =========================== Click ============================
|
||||
var onClick = function onClick(event, index) {
|
||||
var newValue = getStarValue(index, event.pageX);
|
||||
var isReset = false;
|
||||
if (allowClear) {
|
||||
isReset = newValue === value;
|
||||
}
|
||||
onMouseLeaveCallback();
|
||||
changeValue(isReset ? 0 : newValue);
|
||||
setCleanedValue(isReset ? newValue : null);
|
||||
};
|
||||
var onInternalKeyDown = function onInternalKeyDown(event) {
|
||||
var keyCode = event.keyCode;
|
||||
var reverse = direction === 'rtl';
|
||||
var step = allowHalf ? 0.5 : 1;
|
||||
if (keyboard) {
|
||||
if (keyCode === _KeyCode.default.RIGHT && value < count && !reverse) {
|
||||
changeValue(value + step);
|
||||
event.preventDefault();
|
||||
} else if (keyCode === _KeyCode.default.LEFT && value > 0 && !reverse) {
|
||||
changeValue(value - step);
|
||||
event.preventDefault();
|
||||
} else if (keyCode === _KeyCode.default.RIGHT && value > 0 && reverse) {
|
||||
changeValue(value - step);
|
||||
event.preventDefault();
|
||||
} else if (keyCode === _KeyCode.default.LEFT && value < count && reverse) {
|
||||
changeValue(value + step);
|
||||
event.preventDefault();
|
||||
}
|
||||
}
|
||||
onKeyDown === null || onKeyDown === void 0 || onKeyDown(event);
|
||||
};
|
||||
|
||||
// =========================== Effect ===========================
|
||||
|
||||
_react.default.useEffect(function () {
|
||||
if (autoFocus && !disabled) {
|
||||
triggerFocus();
|
||||
}
|
||||
}, []);
|
||||
|
||||
// =========================== Render ===========================
|
||||
// >>> Star
|
||||
var starNodes = new Array(count).fill(0).map(function (item, index) {
|
||||
return /*#__PURE__*/_react.default.createElement(_Star.default, {
|
||||
ref: setStarRef(index),
|
||||
index: index,
|
||||
count: count,
|
||||
disabled: disabled,
|
||||
prefixCls: "".concat(prefixCls, "-star"),
|
||||
allowHalf: allowHalf,
|
||||
value: hoverValue === null ? value : hoverValue,
|
||||
onClick: onClick,
|
||||
onHover: onHover,
|
||||
key: item || index,
|
||||
character: character,
|
||||
characterRender: characterRender,
|
||||
focused: focused
|
||||
});
|
||||
});
|
||||
var classString = (0, _classnames.default)(prefixCls, className, (0, _defineProperty2.default)((0, _defineProperty2.default)({}, "".concat(prefixCls, "-disabled"), disabled), "".concat(prefixCls, "-rtl"), direction === 'rtl'));
|
||||
|
||||
// >>> Node
|
||||
return /*#__PURE__*/_react.default.createElement("ul", (0, _extends2.default)({
|
||||
className: classString,
|
||||
onMouseLeave: onMouseLeaveCallback,
|
||||
tabIndex: disabled ? -1 : tabIndex,
|
||||
onFocus: disabled ? null : onInternalFocus,
|
||||
onBlur: disabled ? null : onInternalBlur,
|
||||
onKeyDown: disabled ? null : onInternalKeyDown,
|
||||
ref: rateRef
|
||||
}, (0, _pickAttrs.default)(restProps, {
|
||||
aria: true,
|
||||
data: true,
|
||||
attr: true
|
||||
})), starNodes);
|
||||
}
|
||||
var _default = exports.default = /*#__PURE__*/_react.default.forwardRef(Rate);
|
||||
16
frontend/node_modules/rc-rate/lib/Star.d.ts
generated
vendored
Normal file
16
frontend/node_modules/rc-rate/lib/Star.d.ts
generated
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
import React from 'react';
|
||||
export interface StarProps {
|
||||
value?: number;
|
||||
index?: number;
|
||||
prefixCls?: string;
|
||||
allowHalf?: boolean;
|
||||
disabled?: boolean;
|
||||
onHover?: (e: React.MouseEvent<HTMLDivElement>, index: number) => void;
|
||||
onClick?: (e: React.MouseEvent<HTMLDivElement> | React.KeyboardEvent<HTMLDivElement>, index: number) => void;
|
||||
character?: React.ReactNode | ((props: StarProps) => React.ReactNode);
|
||||
characterRender?: (origin: React.ReactElement, props: StarProps) => React.ReactNode;
|
||||
focused?: boolean;
|
||||
count?: number;
|
||||
}
|
||||
declare const _default: React.ForwardRefExoticComponent<StarProps & React.RefAttributes<HTMLLIElement>>;
|
||||
export default _default;
|
||||
86
frontend/node_modules/rc-rate/lib/Star.js
generated
vendored
Normal file
86
frontend/node_modules/rc-rate/lib/Star.js
generated
vendored
Normal file
@@ -0,0 +1,86 @@
|
||||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var _react = _interopRequireDefault(require("react"));
|
||||
var _KeyCode = _interopRequireDefault(require("rc-util/lib/KeyCode"));
|
||||
var _classnames = _interopRequireDefault(require("classnames"));
|
||||
function Star(props, ref) {
|
||||
var disabled = props.disabled,
|
||||
prefixCls = props.prefixCls,
|
||||
character = props.character,
|
||||
characterRender = props.characterRender,
|
||||
index = props.index,
|
||||
count = props.count,
|
||||
value = props.value,
|
||||
allowHalf = props.allowHalf,
|
||||
focused = props.focused,
|
||||
onHover = props.onHover,
|
||||
onClick = props.onClick;
|
||||
|
||||
// =========================== Events ===========================
|
||||
var onInternalHover = function onInternalHover(e) {
|
||||
onHover(e, index);
|
||||
};
|
||||
var onInternalClick = function onInternalClick(e) {
|
||||
onClick(e, index);
|
||||
};
|
||||
var onInternalKeyDown = function onInternalKeyDown(e) {
|
||||
if (e.keyCode === _KeyCode.default.ENTER) {
|
||||
onClick(e, index);
|
||||
}
|
||||
};
|
||||
|
||||
// =========================== Render ===========================
|
||||
// >>>>> ClassName
|
||||
var starValue = index + 1;
|
||||
var classNameList = new Set([prefixCls]);
|
||||
|
||||
// TODO: Current we just refactor from CC to FC. This logic seems can be optimized.
|
||||
if (value === 0 && index === 0 && focused) {
|
||||
classNameList.add("".concat(prefixCls, "-focused"));
|
||||
} else if (allowHalf && value + 0.5 >= starValue && value < starValue) {
|
||||
classNameList.add("".concat(prefixCls, "-half"));
|
||||
classNameList.add("".concat(prefixCls, "-active"));
|
||||
if (focused) {
|
||||
classNameList.add("".concat(prefixCls, "-focused"));
|
||||
}
|
||||
} else {
|
||||
if (starValue <= value) {
|
||||
classNameList.add("".concat(prefixCls, "-full"));
|
||||
} else {
|
||||
classNameList.add("".concat(prefixCls, "-zero"));
|
||||
}
|
||||
if (starValue === value && focused) {
|
||||
classNameList.add("".concat(prefixCls, "-focused"));
|
||||
}
|
||||
}
|
||||
|
||||
// >>>>> Node
|
||||
var characterNode = typeof character === 'function' ? character(props) : character;
|
||||
var start = /*#__PURE__*/_react.default.createElement("li", {
|
||||
className: (0, _classnames.default)(Array.from(classNameList)),
|
||||
ref: ref
|
||||
}, /*#__PURE__*/_react.default.createElement("div", {
|
||||
onClick: disabled ? null : onInternalClick,
|
||||
onKeyDown: disabled ? null : onInternalKeyDown,
|
||||
onMouseMove: disabled ? null : onInternalHover,
|
||||
role: "radio",
|
||||
"aria-checked": value > index ? 'true' : 'false',
|
||||
"aria-posinset": index + 1,
|
||||
"aria-setsize": count,
|
||||
tabIndex: disabled ? -1 : 0
|
||||
}, /*#__PURE__*/_react.default.createElement("div", {
|
||||
className: "".concat(prefixCls, "-first")
|
||||
}, characterNode), /*#__PURE__*/_react.default.createElement("div", {
|
||||
className: "".concat(prefixCls, "-second")
|
||||
}, characterNode)));
|
||||
if (characterRender) {
|
||||
start = characterRender(start, props);
|
||||
}
|
||||
return start;
|
||||
}
|
||||
var _default = exports.default = /*#__PURE__*/_react.default.forwardRef(Star);
|
||||
2
frontend/node_modules/rc-rate/lib/index.d.ts
generated
vendored
Normal file
2
frontend/node_modules/rc-rate/lib/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import Rate from './Rate';
|
||||
export default Rate;
|
||||
9
frontend/node_modules/rc-rate/lib/index.js
generated
vendored
Normal file
9
frontend/node_modules/rc-rate/lib/index.js
generated
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var _Rate = _interopRequireDefault(require("./Rate"));
|
||||
var _default = exports.default = _Rate.default;
|
||||
4
frontend/node_modules/rc-rate/lib/useRefs.d.ts
generated
vendored
Normal file
4
frontend/node_modules/rc-rate/lib/useRefs.d.ts
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
export default function useRefs<T>(): [
|
||||
getRef: (index: number) => T,
|
||||
setRef: (index: number) => (instance: T) => void
|
||||
];
|
||||
22
frontend/node_modules/rc-rate/lib/useRefs.js
generated
vendored
Normal file
22
frontend/node_modules/rc-rate/lib/useRefs.js
generated
vendored
Normal file
@@ -0,0 +1,22 @@
|
||||
"use strict";
|
||||
|
||||
var _typeof = require("@babel/runtime/helpers/typeof");
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = useRefs;
|
||||
var React = _interopRequireWildcard(require("react"));
|
||||
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
||||
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
||||
function useRefs() {
|
||||
var nodeRef = React.useRef({});
|
||||
function getRef(index) {
|
||||
return nodeRef.current[index];
|
||||
}
|
||||
function setRef(index) {
|
||||
return function (node) {
|
||||
nodeRef.current[index] = node;
|
||||
};
|
||||
}
|
||||
return [getRef, setRef];
|
||||
}
|
||||
1
frontend/node_modules/rc-rate/lib/util.d.ts
generated
vendored
Normal file
1
frontend/node_modules/rc-rate/lib/util.d.ts
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
export declare function getOffsetLeft(el: HTMLElement): number;
|
||||
44
frontend/node_modules/rc-rate/lib/util.js
generated
vendored
Normal file
44
frontend/node_modules/rc-rate/lib/util.js
generated
vendored
Normal file
@@ -0,0 +1,44 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.getOffsetLeft = getOffsetLeft;
|
||||
function getScroll(w) {
|
||||
var ret = w.pageXOffset;
|
||||
var method = 'scrollLeft';
|
||||
if (typeof ret !== 'number') {
|
||||
var d = w.document;
|
||||
// ie6,7,8 standard mode
|
||||
ret = d.documentElement[method];
|
||||
if (typeof ret !== 'number') {
|
||||
// quirks mode
|
||||
ret = d.body[method];
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
function getClientPosition(elem) {
|
||||
var x;
|
||||
var y;
|
||||
var doc = elem.ownerDocument;
|
||||
var body = doc.body;
|
||||
var docElem = doc && doc.documentElement;
|
||||
var box = elem.getBoundingClientRect();
|
||||
x = box.left;
|
||||
y = box.top;
|
||||
x -= docElem.clientLeft || body.clientLeft || 0;
|
||||
y -= docElem.clientTop || body.clientTop || 0;
|
||||
return {
|
||||
left: x,
|
||||
top: y
|
||||
};
|
||||
}
|
||||
function getOffsetLeft(el) {
|
||||
var pos = getClientPosition(el);
|
||||
var doc = el.ownerDocument;
|
||||
// Only IE use `parentWindow`
|
||||
var w = doc.defaultView || doc.parentWindow;
|
||||
pos.left += getScroll(w);
|
||||
return pos.left;
|
||||
}
|
||||
77
frontend/node_modules/rc-rate/package.json
generated
vendored
Normal file
77
frontend/node_modules/rc-rate/package.json
generated
vendored
Normal file
@@ -0,0 +1,77 @@
|
||||
{
|
||||
"name": "rc-rate",
|
||||
"version": "2.13.1",
|
||||
"description": "React Star Rate Component",
|
||||
"engines": {
|
||||
"node": ">=8.x"
|
||||
},
|
||||
"keywords": [
|
||||
"react",
|
||||
"react-component",
|
||||
"react-rate",
|
||||
"rate"
|
||||
],
|
||||
"homepage": "https://github.com/react-component/rate",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/react-component/rate.git"
|
||||
},
|
||||
"bugs": {
|
||||
"url": "https://github.com/react-component/rate/issues"
|
||||
},
|
||||
"files": [
|
||||
"lib",
|
||||
"es",
|
||||
"assets/*.css"
|
||||
],
|
||||
"license": "MIT",
|
||||
"main": "./lib/index",
|
||||
"module": "./es/index",
|
||||
"scripts": {
|
||||
"start": "dumi dev",
|
||||
"docs:build": "dumi build",
|
||||
"docs:deploy": "gh-pages -d .doc",
|
||||
"compile": "father build && lessc assets/index.less assets/index.css",
|
||||
"prepare": "dumi setup",
|
||||
"prepublishOnly": "npm run compile && np --yolo --no-publish",
|
||||
"postpublish": "npm run docs:build && npm run docs:deploy",
|
||||
"lint": "eslint src/ --ext .ts,.tsx,.jsx,.js,.md",
|
||||
"prettier": "prettier --write \"**/*.{ts,tsx,js,jsx,json,md}\"",
|
||||
"test": "rc-test",
|
||||
"coverage": "rc-test --coverage",
|
||||
"now-build": "npm run docs:build"
|
||||
},
|
||||
"dependencies": {
|
||||
"@babel/runtime": "^7.10.1",
|
||||
"classnames": "^2.2.5",
|
||||
"rc-util": "^5.0.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@rc-component/father-plugin": "^1.0.0",
|
||||
"@types/classnames": "^2.2.9",
|
||||
"@types/jest": "^29.5.1",
|
||||
"@types/react": "^17.0.15",
|
||||
"@types/react-dom": "^17.0.9",
|
||||
"@umijs/fabric": "^3.0.0",
|
||||
"cheerio": "1.0.0-rc.12",
|
||||
"cross-env": "^7.0.0",
|
||||
"dumi": "^2.1.2",
|
||||
"enzyme": "^3.1.1",
|
||||
"enzyme-adapter-react-16": "^1.15.6",
|
||||
"enzyme-to-json": "^3.1.2",
|
||||
"eslint": "^7.1.0",
|
||||
"father": "^4.0.0",
|
||||
"gh-pages": "^3.1.0",
|
||||
"less": "^3.0.0",
|
||||
"np": "^7.0.0",
|
||||
"rc-test": "^7.0.15",
|
||||
"rc-tooltip": "^5.0.1",
|
||||
"react": "^16.0.0",
|
||||
"react-dom": "^16.0.0",
|
||||
"typescript": "^5.0.4"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"react": ">=16.9.0",
|
||||
"react-dom": ">=16.9.0"
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user