123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- "use strict";
- "use client";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var React = _interopRequireWildcard(require("react"));
- var _classnames = _interopRequireDefault(require("classnames"));
- var _rcMotion = _interopRequireDefault(require("rc-motion"));
- var _raf = _interopRequireDefault(require("rc-util/lib/raf"));
- var _ref = require("rc-util/lib/ref");
- var _UnstableContext = require("../../config-provider/UnstableContext");
- var _interface = require("./interface");
- var _util = require("./util");
- function validateNum(value) {
- return Number.isNaN(value) ? 0 : value;
- }
- const WaveEffect = props => {
- const {
- className,
- target,
- component,
- registerUnmount
- } = props;
- const divRef = React.useRef(null);
- // ====================== Refs ======================
- const unmountRef = React.useRef(null);
- React.useEffect(() => {
- unmountRef.current = registerUnmount();
- }, []);
- // ===================== Effect =====================
- const [color, setWaveColor] = React.useState(null);
- const [borderRadius, setBorderRadius] = React.useState([]);
- const [left, setLeft] = React.useState(0);
- const [top, setTop] = React.useState(0);
- const [width, setWidth] = React.useState(0);
- const [height, setHeight] = React.useState(0);
- const [enabled, setEnabled] = React.useState(false);
- const waveStyle = {
- left,
- top,
- width,
- height,
- borderRadius: borderRadius.map(radius => `${radius}px`).join(' ')
- };
- if (color) {
- waveStyle['--wave-color'] = color;
- }
- function syncPos() {
- const nodeStyle = getComputedStyle(target);
- // Get wave color from target
- setWaveColor((0, _util.getTargetWaveColor)(target));
- const isStatic = nodeStyle.position === 'static';
- // Rect
- const {
- borderLeftWidth,
- borderTopWidth
- } = nodeStyle;
- setLeft(isStatic ? target.offsetLeft : validateNum(-parseFloat(borderLeftWidth)));
- setTop(isStatic ? target.offsetTop : validateNum(-parseFloat(borderTopWidth)));
- setWidth(target.offsetWidth);
- setHeight(target.offsetHeight);
- // Get border radius
- const {
- borderTopLeftRadius,
- borderTopRightRadius,
- borderBottomLeftRadius,
- borderBottomRightRadius
- } = nodeStyle;
- setBorderRadius([borderTopLeftRadius, borderTopRightRadius, borderBottomRightRadius, borderBottomLeftRadius].map(radius => validateNum(parseFloat(radius))));
- }
- React.useEffect(() => {
- if (target) {
- // We need delay to check position here
- // since UI may change after click
- const id = (0, _raf.default)(() => {
- syncPos();
- setEnabled(true);
- });
- // Add resize observer to follow size
- let resizeObserver;
- if (typeof ResizeObserver !== 'undefined') {
- resizeObserver = new ResizeObserver(syncPos);
- resizeObserver.observe(target);
- }
- return () => {
- _raf.default.cancel(id);
- resizeObserver === null || resizeObserver === void 0 ? void 0 : resizeObserver.disconnect();
- };
- }
- }, []);
- if (!enabled) {
- return null;
- }
- const isSmallComponent = (component === 'Checkbox' || component === 'Radio') && (target === null || target === void 0 ? void 0 : target.classList.contains(_interface.TARGET_CLS));
- return /*#__PURE__*/React.createElement(_rcMotion.default, {
- visible: true,
- motionAppear: true,
- motionName: "wave-motion",
- motionDeadline: 5000,
- onAppearEnd: (_, event) => {
- var _a, _b;
- if (event.deadline || event.propertyName === 'opacity') {
- const holder = (_a = divRef.current) === null || _a === void 0 ? void 0 : _a.parentElement;
- (_b = unmountRef.current) === null || _b === void 0 ? void 0 : _b.call(unmountRef).then(() => {
- holder === null || holder === void 0 ? void 0 : holder.remove();
- });
- }
- return false;
- }
- }, ({
- className: motionClassName
- }, ref) => (/*#__PURE__*/React.createElement("div", {
- ref: (0, _ref.composeRef)(divRef, ref),
- className: (0, _classnames.default)(className, motionClassName, {
- 'wave-quick': isSmallComponent
- }),
- style: waveStyle
- })));
- };
- const showWaveEffect = (target, info) => {
- var _a;
- const {
- component
- } = info;
- // Skip for unchecked checkbox
- if (component === 'Checkbox' && !((_a = target.querySelector('input')) === null || _a === void 0 ? void 0 : _a.checked)) {
- return;
- }
- // Create holder
- const holder = document.createElement('div');
- holder.style.position = 'absolute';
- holder.style.left = '0px';
- holder.style.top = '0px';
- target === null || target === void 0 ? void 0 : target.insertBefore(holder, target === null || target === void 0 ? void 0 : target.firstChild);
- const reactRender = (0, _UnstableContext.unstableSetRender)();
- let unmountCallback = null;
- function registerUnmount() {
- return unmountCallback;
- }
- unmountCallback = reactRender(/*#__PURE__*/React.createElement(WaveEffect, Object.assign({}, info, {
- target: target,
- registerUnmount: registerUnmount
- })), holder);
- };
- var _default = exports.default = showWaveEffect;
|