UNPKG

@crossed/ui

Version:

A universal & performant styling library for React Native, Next.js & React

77 lines (76 loc) 2.82 kB
var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var Trigger_exports = {}; __export(Trigger_exports, { FloatingTrigger: () => FloatingTrigger }); module.exports = __toCommonJS(Trigger_exports); var import_jsx_runtime = require("react/jsx-runtime"); var import_react_native = require("react-native"); var import_Slot = require("../../Slot"); var import_context = require("./context"); var import_react = require("react"); var import_core = require("@crossed/core"); var import_styled = require("@crossed/styled"); const FloatingTrigger = (0, import_react.memo)( (0, import_react.forwardRef)(({ style, ...props }, ref) => { const { triggerStrategy, enabled } = (0, import_context.useFloatingConfig)(); const { open, onClose, onOpen } = (0, import_context.useFloatingContext)(); const toggle = (0, import_react.useCallback)(() => { if (open) onClose(); else onOpen(); }, [open, onClose, onOpen]); const propsExtended = (0, import_react.useMemo)(() => { const eventStrategiy = !enabled ? {} : triggerStrategy === "onPress" ? { onPress: (0, import_core.composeEventHandlers)(toggle, props.onPress) } : { onPointerEnter: (0, import_core.composeEventHandlers)( onOpen, props.onPointerEnter ), onPointerLeave: (0, import_core.composeEventHandlers)( onClose, props.onPointerLeave ) }; return { ...props, ...style == null ? void 0 : style.rnw(), ...eventStrategiy }; }, [props, toggle, enabled, onClose, onOpen]); return /* @__PURE__ */ (0, import_jsx_runtime.jsx)( import_Slot.Slot, { ref, Comp: import_react_native.Pressable, role: "button", ...propsExtended, ...(0, import_styled.composeStyles)(propsExtended.style).style() } ); }) ); FloatingTrigger.displayName = "Floating.Trigger"; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { FloatingTrigger }); //# sourceMappingURL=Trigger.js.map