UNPKG

@yamada-ui/react

Version:

React UI components of the Yamada, by the Yamada, for the Yamada built with React and Emotion

69 lines (65 loc) 2.42 kB
"use client"; const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs'); const require_create_component = require('../../core/components/create-component.cjs'); const require_factory = require('../motion/factory.cjs'); const require_transition = require('../motion/transition.cjs'); const require_fade_style = require('./fade.style.cjs'); let react = require("react"); react = require_rolldown_runtime.__toESM(react); let react_jsx_runtime = require("react/jsx-runtime"); react_jsx_runtime = require_rolldown_runtime.__toESM(react_jsx_runtime); let motion_react = require("motion/react"); motion_react = require_rolldown_runtime.__toESM(motion_react); //#region src/components/fade/fade.tsx const fadeVariants = { enter: ({ delay, duration, enter, transition, transitionEnd } = {}) => ({ opacity: 1, transition: require_transition.createTransition.enter(transition?.enter)(delay, duration), transitionEnd: transitionEnd?.enter, ...enter }), exit: ({ delay, duration, exit, transition, transitionEnd } = {}) => ({ opacity: 0, transition: require_transition.createTransition.exit(transition?.exit)(delay, duration), transitionEnd: transitionEnd?.exit, ...exit }) }; const { PropsContext: FadePropsContext, usePropsContext: useFadePropsContext, withContext } = require_create_component.createComponent("fade", require_fade_style.fadeStyle); /** * `Fade` is a component that gradually shows or hides an element. * * @see https://yamada-ui.com/docs/components/fade */ const Fade = withContext(({ delay, duration, open: openProp, transition, transitionEnd, unmountOnExit,...rest }) => { const animate = openProp || unmountOnExit ? "enter" : "exit"; const open = unmountOnExit ? openProp && unmountOnExit : true; const custom = (0, react.useMemo)(() => ({ delay, duration, transition, transitionEnd }), [ delay, duration, transition, transitionEnd ]); return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(motion_react.AnimatePresence, { custom, children: open ? /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_factory.motion.div, { animate, custom, exit: "exit", initial: "exit", variants: fadeVariants, ...rest }) : null }); })(); //#endregion exports.Fade = Fade; exports.FadePropsContext = FadePropsContext; exports.fadeVariants = fadeVariants; exports.useFadePropsContext = useFadePropsContext; //# sourceMappingURL=fade.cjs.map