import { ModalProps, ModalTypeMap } from "../Modal"; import { PaperProps } from "../Paper"; import { Theme } from "../styles"; import { TransitionProps } from "../transitions/transition"; import { PopoverClasses } from "./popoverClasses"; import { SxProps } from "@suid/system"; import * as ST from "@suid/types"; import { JSXElement, Component } from "solid-js"; export interface PopoverOrigin { vertical: "top" | "center" | "bottom" | number; horizontal: "left" | "center" | "right" | number; } export interface PopoverPosition { top: number; left: number; } export type PopoverReference = "anchorEl" | "anchorPosition" | "none"; export interface PopoverActions { updatePosition(): void; } export type PopoverTypeMap

= { name: "MuiPopover"; defaultPropNames: "anchorOrigin" | "anchorReference" | "elevation" | "marginThreshold" | "PaperProps" | "transformOrigin" | "TransitionComponent" | "transitionDuration" | "TransitionProps"; selfProps: { /** * A ref for imperative actions. * It currently only supports updatePosition() action. */ action?: ST.Ref; /** * An HTML element, or a function that returns one. * It's used to set the position of the popover. */ anchorEl?: null | Element | ((element: Element) => Element); /** * This is the point on the anchor where the popover's * `anchorEl` will attach to. This is not used when the * anchorReference is 'anchorPosition'. * * Options: * vertical: [top, center, bottom]; * horizontal: [left, center, right]. * @default { * vertical: 'top', * horizontal: 'left', * } */ anchorOrigin?: PopoverOrigin; /** * This is the position that may be used to set the position of the popover. * The coordinates are relative to the application's client area. */ anchorPosition?: PopoverPosition; /** * This determines which anchor prop to refer to when setting * the position of the popover. * @default 'anchorEl' */ anchorReference?: PopoverReference; /** * The content of the component. */ children?: JSXElement; /** * Override or extend the styles applied to the component. */ classes?: Partial; /** * An HTML element, component instance, or function that returns either. * The `container` will passed to the Modal component. * * By default, it uses the body of the anchorEl's top-level document object, * so it's simply `document.body` most of the time. */ container?: ModalProps["container"]; /** * The elevation of the popover. * @default 8 */ elevation?: number; /** * Specifies how close to the edge of the window the popover can appear. * @default 16 */ marginThreshold?: number; onClose?: ModalProps["onClose"]; /** * If `true`, the component is shown. */ open: boolean; /** * Props applied to the [`Paper`](/api/paper/) element. * @default {} */ PaperProps?: Partial; /** * The system prop that allows defining system overrides as well as additional CSS styles. */ sx?: SxProps; /** * This is the point on the popover which * will attach to the anchor's origin. * * Options: * vertical: [top, center, bottom, x(px)]; * horizontal: [left, center, right, x(px)]. * @default { * vertical: 'top', * horizontal: 'left', * } */ transformOrigin?: PopoverOrigin; /** * The component used for the transition. * [Follow this guide](/components/transitions/#transitioncomponent-prop) to learn more about the requirements for this component. * @default Grow */ TransitionComponent?: Component; /** * Set to 'auto' to automatically calculate transition time based on height. * @default 'auto' */ transitionDuration?: TransitionProps["timeout"] | "auto"; /** * Props applied to the transition element. * By default, the element is based on this [`Transition`](http://reactcommunity.org/react-transition-group/transition/) component. * @default {} */ TransitionProps?: TransitionProps; }; props: P & PopoverTypeMap["selfProps"] & Omit; defaultComponent: D; }; export type PopoverProps = ST.OverrideProps, D>; export default PopoverProps; //# sourceMappingURL=PopoverProps.d.ts.map