UNPKG

@trail-ui/react

Version:
134 lines (130 loc) 4.74 kB
"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; 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 __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/overlay-arrow/overlay-arrow.tsx var overlay_arrow_exports = {}; __export(overlay_arrow_exports, { OverlayArrow: () => _OverlayArrow, OverlayArrowContext: () => OverlayArrowContext }); module.exports = __toCommonJS(overlay_arrow_exports); var import_react2 = require("react"); var import_react_aria_components = require("react-aria-components"); // src/_utils/utils.tsx var import_utils = require("@react-aria/utils"); var import_react = __toESM(require("react")); var import_react_aria = require("react-aria"); var import_react_dom = __toESM(require("react-dom")); var import_jsx_runtime = require("react/jsx-runtime"); function useRenderProps(props) { let { className, style, children, defaultClassName, defaultChildren, values } = props; return (0, import_react.useMemo)(() => { let computedClassName; let computedStyle; let computedChildren; if (typeof className === "function") { computedClassName = className(values); } else { computedClassName = className; } if (typeof style === "function") { computedStyle = style(values); } else { computedStyle = style; } if (typeof children === "function") { computedChildren = children(values); } else if (children == null) { computedChildren = defaultChildren; } else { computedChildren = children; } return { className: computedClassName != null ? computedClassName : defaultClassName, style: computedStyle, children: computedChildren, "data-rac": "" }; }, [className, style, children, defaultClassName, defaultChildren, values]); } if (typeof HTMLTemplateElement !== "undefined") { const getFirstChild = Object.getOwnPropertyDescriptor(Node.prototype, "firstChild").get; Object.defineProperty(HTMLTemplateElement.prototype, "firstChild", { configurable: true, enumerable: true, get: function() { if (this.dataset.reactAriaHidden) { return this.content.firstChild; } else { return getFirstChild.call(this); } } }); } var HiddenContext = (0, import_react.createContext)(false); var hiddenFragment = typeof DocumentFragment !== "undefined" ? new DocumentFragment() : null; // src/overlay-arrow/overlay-arrow.tsx var import_jsx_runtime2 = require("react/jsx-runtime"); var OverlayArrowContext = (0, import_react2.createContext)({ placement: "bottom" }); function OverlayArrow(props, ref) { [props, ref] = (0, import_react_aria_components.useContextProps)(props, ref, OverlayArrowContext); let placement = props.placement; let style = { position: "absolute", [placement]: "100%", transform: placement === "top" || placement === "bottom" ? "translateX(-50%)" : "translateY(-50%)" }; let renderProps = useRenderProps({ ...props, defaultClassName: "react-aria-OverlayArrow", values: { placement } }); return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( "div", { ...props, ...renderProps, style: { ...renderProps.style, ...style }, ref, "data-placement": placement } ); } var _OverlayArrow = /* @__PURE__ */ (0, import_react2.forwardRef)(OverlayArrow); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { OverlayArrow, OverlayArrowContext });