Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@uiw/react-overlay

Package Overview
Dependencies
Maintainers
1
Versions
172
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@uiw/react-overlay - npm Package Compare versions

Comparing version 4.7.8 to 4.7.9

4

lib/cjs/index.js

@@ -284,3 +284,3 @@ "use strict";

};
module.exports = exports.default;
//# sourceMappingURL=index.js.map
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["noop","undefined","Overlay","props","container","visible","handleDocumentClick","e","maskClosable","onClose","isOpen","state","domNode","ReactDOM","findDOMNode","nextSibling","target","nextElementSibling","setState","isMount","handleBackdropMouseDown","backdropProps","hasBackdrop","usePortal","bind","onMouseDown","onClosed","node","overlayWillClose","overlayWillOpen","document","removeEventListener","prefixCls","body","classList","remove","add","addEventListener","prevProps","className","style","children","unmountOnExit","timeout","transitionName","portalProps","dialogProps","otherProps","onOpening","onOpened","onClosing","decoratedChild","filter","Boolean","join","trim","tabIndex","TransitionGroupComp","status","React","Component","defaultProps","onEnter"],"mappings":"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","sourcesContent":["/**\n * Overlay 组件\n * ---------------\n * 动画库 react-transition-group 文档\n * 老的文档\n * https://facebook.github.io/react/docs/animation.html\n * 新的文档\n * https://reactcommunity.org/react-transition-group/\n * 动画效果\n * https://daneden.github.io/animate.css/\n */\n\nimport React, { cloneElement } from 'react';\nimport ReactDOM from 'react-dom';\nimport { CSSTransition } from 'react-transition-group';\nimport { TransitionProps } from 'react-transition-group/Transition';\nimport Portal, { PortalProps } from '@uiw/react-portal';\nimport { IProps } from '@uiw/utils';\n\nimport './style/index.less';\n\nconst noop = () => undefined;\n\nexport interface OverlayProps extends IProps, Omit<TransitionProps, 'timeout'> {\n  timeout?: TransitionProps['timeout'];\n  isOpen?: boolean;\n  usePortal?: boolean;\n  maskClosable?: boolean;\n  dialogProps?: React.HTMLProps<HTMLElement>;\n  backdropProps?: React.HTMLProps<HTMLDivElement>;\n  portalProps?: PortalProps;\n  hasBackdrop?: boolean;\n  unmountOnExit?: boolean;\n  transitionName?: string;\n  onEnter?: (node: HTMLElement, isAppearing: boolean) => void;\n  onOpening?: (node: HTMLElement, isAppearing: boolean) => void;\n  onOpened?: (node: HTMLElement, isAppearing: boolean) => void;\n  onClosing?: (node: HTMLElement) => void;\n  onClosed?: (\n    node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>,\n  ) => void;\n  onClose?: (evn: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n  children?: any;\n}\n\nexport interface OverlayState {\n  isMount: boolean;\n  isOpen: boolean;\n}\n\nexport default class Overlay extends React.Component<\n  OverlayProps,\n  OverlayState\n> {\n  public static defaultProps: OverlayProps = {\n    isOpen: false,\n    prefixCls: 'w-overlay',\n    usePortal: true,\n    maskClosable: true,\n    backdropProps: {},\n    portalProps: {},\n    hasBackdrop: true,\n    unmountOnExit: true, // 设置 true 销毁根节点\n    timeout: 300,\n    transitionName: 'w-overlay',\n    onEnter: noop,\n    onOpening: noop,\n    onOpened: noop,\n    onClosing: noop,\n    onClosed: noop,\n    onClose: noop,\n  };\n  public container!: HTMLDivElement | null;\n  private visible?: boolean;\n  constructor(props: OverlayProps) {\n    super(props);\n    this.state = {\n      isMount: false,\n      isOpen: false,\n    };\n  }\n  componentDidMount() {\n    if (this.props.isOpen) {\n      this.overlayWillOpen();\n    }\n  }\n  componentWillUnmount() {\n    document.removeEventListener('mousedown', this.handleDocumentClick, false);\n  }\n  overlayWillClose() {\n    const { prefixCls } = this.props;\n    document.removeEventListener('mousedown', this.handleDocumentClick, false);\n    document.body.classList.remove(`${prefixCls}-open`);\n    this.setState({ isOpen: false });\n  }\n  handleDocumentClick = (\n    e: MouseEvent | React.MouseEvent<HTMLButtonElement, MouseEvent>,\n  ) => {\n    const { maskClosable, onClose } = this.props;\n    const { isOpen } = this.state;\n    const domNode = ReactDOM.findDOMNode(this);\n    if (\n      isOpen &&\n      maskClosable &&\n      domNode &&\n      (domNode.nextSibling === e.target ||\n        domNode.nextElementSibling === e.target)\n    ) {\n      this.setState({ isMount: false }, () => {\n        onClose &&\n          onClose(e as React.MouseEvent<HTMLButtonElement, MouseEvent>);\n      });\n    }\n  };\n  overlayWillOpen() {\n    const { prefixCls, maskClosable, hasBackdrop, usePortal } = this.props;\n    this.setState({ isMount: true, isOpen: true });\n    if (this.props.hasBackdrop && usePortal) {\n      // add a class to the body to prevent scrolling of content below the overlay\n      document.body.classList.add(`${prefixCls}-open`);\n    }\n    if (maskClosable && !hasBackdrop) {\n      document.addEventListener('mousedown', this.handleDocumentClick, false);\n    }\n  }\n  componentDidUpdate(prevProps: OverlayProps) {\n    if (\n      this.props.isOpen !== this.state.isOpen &&\n      prevProps.isOpen !== this.props.isOpen\n    ) {\n      this.props.isOpen ? this.overlayWillOpen() : this.overlayWillClose();\n    }\n  }\n  handleBackdropMouseDown = (\n    e: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => {\n    const {\n      backdropProps,\n      maskClosable,\n      hasBackdrop,\n      usePortal,\n      onClose,\n    } = this.props;\n    if (e.target !== this.container && usePortal) {\n      return;\n    }\n    if (maskClosable && hasBackdrop) {\n      this.setState({ isOpen: false }, onClose!.bind(this, e));\n    }\n    backdropProps && backdropProps.onMouseDown && backdropProps.onMouseDown(e);\n  };\n  public onClosed = (\n    node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>,\n  ) => {\n    const { onClosed } = this.props;\n    if (this.state.isMount) {\n      this.setState({ isMount: false }, () => {\n        onClosed && onClosed(node);\n      });\n    } else {\n      onClosed && onClosed(node);\n    }\n    this.overlayWillClose();\n  };\n  public render() {\n    const {\n      prefixCls,\n      className,\n      style,\n      isOpen,\n      maskClosable,\n      usePortal,\n      children,\n      unmountOnExit,\n      timeout,\n      transitionName,\n      hasBackdrop,\n      portalProps = {},\n      backdropProps = {},\n      dialogProps = {},\n      onClose,\n      ...otherProps\n    } = this.props;\n    const { onOpening, onOpened, onClosing } = this.props;\n    const decoratedChild =\n      typeof children === 'object' ? (\n        cloneElement(children, {\n          ...dialogProps,\n          style: { ...children.props.style, ...dialogProps.style },\n          className: [children.props.className, `${prefixCls}-content`]\n            .filter(Boolean)\n            .join(' ')\n            .trim(),\n          tabIndex: 0,\n        })\n      ) : (\n        <span {...dialogProps} className={`${prefixCls}-content`}>\n          {children}\n        </span>\n      );\n\n    const TransitionGroupComp = (\n      <CSSTransition\n        in={this.state.isOpen}\n        unmountOnExit={unmountOnExit}\n        onEntering={onOpening}\n        onEntered={onOpened}\n        onExiting={onClosing}\n        onExited={this.onClosed}\n        timeout={timeout!}\n        {...otherProps}\n        classNames={transitionName}\n      >\n        {(status) => (\n          <div\n            style={style}\n            className={[\n              prefixCls,\n              className,\n              !usePortal ? `${prefixCls}-inline` : null,\n              this.state.isOpen ? `${prefixCls}-enter-done` : null,\n            ]\n              .filter(Boolean)\n              .join(' ')\n              .trim()}\n          >\n            {hasBackdrop &&\n              cloneElement(<div />, {\n                ...backdropProps,\n                onMouseDown: this.handleBackdropMouseDown.bind(this),\n                className: [`${prefixCls}-backdrop`, backdropProps.className]\n                  .filter(Boolean)\n                  .join(' ')\n                  .trim(),\n                tabIndex: this.props.maskClosable ? 0 : null,\n              })}\n            {usePortal ? (\n              <div\n                ref={(node) => (this.container = node)}\n                onMouseDown={this.handleBackdropMouseDown.bind(this)}\n                className={`${prefixCls}-container`}\n              >\n                {cloneElement(decoratedChild, { 'data-status': status })}\n              </div>\n            ) : (\n              cloneElement(decoratedChild, { 'data-status': status })\n            )}\n          </div>\n        )}\n      </CSSTransition>\n    );\n    if (usePortal) {\n      if (!this.visible) {\n        this.visible = this.props.isOpen;\n      } else if (\n        this.visible === true &&\n        this.state.isOpen === false &&\n        this.state.isMount === false\n      ) {\n        this.visible = false;\n      }\n      return (\n        <Portal {...{ ...portalProps, ...{ visible: this.visible } }}>\n          {' '}\n          {TransitionGroupComp}{' '}\n        </Portal>\n      );\n    } else {\n      return TransitionGroupComp;\n    }\n  }\n}\n"]}

@@ -263,3 +263,3 @@ import _extends from "@babel/runtime/helpers/esm/extends";

};
export { Overlay as default };
//# sourceMappingURL=index.js.map
export { Overlay as default };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","cloneElement","ReactDOM","CSSTransition","Portal","noop","undefined","Overlay","props","container","visible","handleDocumentClick","e","maskClosable","onClose","isOpen","state","domNode","findDOMNode","nextSibling","target","nextElementSibling","setState","isMount","handleBackdropMouseDown","backdropProps","hasBackdrop","usePortal","bind","onMouseDown","onClosed","node","overlayWillClose","overlayWillOpen","document","removeEventListener","prefixCls","body","classList","remove","add","addEventListener","prevProps","className","style","children","unmountOnExit","timeout","transitionName","portalProps","dialogProps","otherProps","onOpening","onOpened","onClosing","decoratedChild","filter","Boolean","join","trim","tabIndex","TransitionGroupComp","status","Component","defaultProps","onEnter"],"mappings":"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","sourcesContent":["/**\n * Overlay 组件\n * ---------------\n * 动画库 react-transition-group 文档\n * 老的文档\n * https://facebook.github.io/react/docs/animation.html\n * 新的文档\n * https://reactcommunity.org/react-transition-group/\n * 动画效果\n * https://daneden.github.io/animate.css/\n */\n\nimport React, { cloneElement } from 'react';\nimport ReactDOM from 'react-dom';\nimport { CSSTransition } from 'react-transition-group';\nimport { TransitionProps } from 'react-transition-group/Transition';\nimport Portal, { PortalProps } from '@uiw/react-portal';\nimport { IProps } from '@uiw/utils';\n\nimport './style/index.less';\n\nconst noop = () => undefined;\n\nexport interface OverlayProps extends IProps, Omit<TransitionProps, 'timeout'> {\n  timeout?: TransitionProps['timeout'];\n  isOpen?: boolean;\n  usePortal?: boolean;\n  maskClosable?: boolean;\n  dialogProps?: React.HTMLProps<HTMLElement>;\n  backdropProps?: React.HTMLProps<HTMLDivElement>;\n  portalProps?: PortalProps;\n  hasBackdrop?: boolean;\n  unmountOnExit?: boolean;\n  transitionName?: string;\n  onEnter?: (node: HTMLElement, isAppearing: boolean) => void;\n  onOpening?: (node: HTMLElement, isAppearing: boolean) => void;\n  onOpened?: (node: HTMLElement, isAppearing: boolean) => void;\n  onClosing?: (node: HTMLElement) => void;\n  onClosed?: (\n    node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>,\n  ) => void;\n  onClose?: (evn: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n  children?: any;\n}\n\nexport interface OverlayState {\n  isMount: boolean;\n  isOpen: boolean;\n}\n\nexport default class Overlay extends React.Component<\n  OverlayProps,\n  OverlayState\n> {\n  public static defaultProps: OverlayProps = {\n    isOpen: false,\n    prefixCls: 'w-overlay',\n    usePortal: true,\n    maskClosable: true,\n    backdropProps: {},\n    portalProps: {},\n    hasBackdrop: true,\n    unmountOnExit: true, // 设置 true 销毁根节点\n    timeout: 300,\n    transitionName: 'w-overlay',\n    onEnter: noop,\n    onOpening: noop,\n    onOpened: noop,\n    onClosing: noop,\n    onClosed: noop,\n    onClose: noop,\n  };\n  public container!: HTMLDivElement | null;\n  private visible?: boolean;\n  constructor(props: OverlayProps) {\n    super(props);\n    this.state = {\n      isMount: false,\n      isOpen: false,\n    };\n  }\n  componentDidMount() {\n    if (this.props.isOpen) {\n      this.overlayWillOpen();\n    }\n  }\n  componentWillUnmount() {\n    document.removeEventListener('mousedown', this.handleDocumentClick, false);\n  }\n  overlayWillClose() {\n    const { prefixCls } = this.props;\n    document.removeEventListener('mousedown', this.handleDocumentClick, false);\n    document.body.classList.remove(`${prefixCls}-open`);\n    this.setState({ isOpen: false });\n  }\n  handleDocumentClick = (\n    e: MouseEvent | React.MouseEvent<HTMLButtonElement, MouseEvent>,\n  ) => {\n    const { maskClosable, onClose } = this.props;\n    const { isOpen } = this.state;\n    const domNode = ReactDOM.findDOMNode(this);\n    if (\n      isOpen &&\n      maskClosable &&\n      domNode &&\n      (domNode.nextSibling === e.target ||\n        domNode.nextElementSibling === e.target)\n    ) {\n      this.setState({ isMount: false }, () => {\n        onClose &&\n          onClose(e as React.MouseEvent<HTMLButtonElement, MouseEvent>);\n      });\n    }\n  };\n  overlayWillOpen() {\n    const { prefixCls, maskClosable, hasBackdrop, usePortal } = this.props;\n    this.setState({ isMount: true, isOpen: true });\n    if (this.props.hasBackdrop && usePortal) {\n      // add a class to the body to prevent scrolling of content below the overlay\n      document.body.classList.add(`${prefixCls}-open`);\n    }\n    if (maskClosable && !hasBackdrop) {\n      document.addEventListener('mousedown', this.handleDocumentClick, false);\n    }\n  }\n  componentDidUpdate(prevProps: OverlayProps) {\n    if (\n      this.props.isOpen !== this.state.isOpen &&\n      prevProps.isOpen !== this.props.isOpen\n    ) {\n      this.props.isOpen ? this.overlayWillOpen() : this.overlayWillClose();\n    }\n  }\n  handleBackdropMouseDown = (\n    e: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => {\n    const {\n      backdropProps,\n      maskClosable,\n      hasBackdrop,\n      usePortal,\n      onClose,\n    } = this.props;\n    if (e.target !== this.container && usePortal) {\n      return;\n    }\n    if (maskClosable && hasBackdrop) {\n      this.setState({ isOpen: false }, onClose!.bind(this, e));\n    }\n    backdropProps && backdropProps.onMouseDown && backdropProps.onMouseDown(e);\n  };\n  public onClosed = (\n    node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>,\n  ) => {\n    const { onClosed } = this.props;\n    if (this.state.isMount) {\n      this.setState({ isMount: false }, () => {\n        onClosed && onClosed(node);\n      });\n    } else {\n      onClosed && onClosed(node);\n    }\n    this.overlayWillClose();\n  };\n  public render() {\n    const {\n      prefixCls,\n      className,\n      style,\n      isOpen,\n      maskClosable,\n      usePortal,\n      children,\n      unmountOnExit,\n      timeout,\n      transitionName,\n      hasBackdrop,\n      portalProps = {},\n      backdropProps = {},\n      dialogProps = {},\n      onClose,\n      ...otherProps\n    } = this.props;\n    const { onOpening, onOpened, onClosing } = this.props;\n    const decoratedChild =\n      typeof children === 'object' ? (\n        cloneElement(children, {\n          ...dialogProps,\n          style: { ...children.props.style, ...dialogProps.style },\n          className: [children.props.className, `${prefixCls}-content`]\n            .filter(Boolean)\n            .join(' ')\n            .trim(),\n          tabIndex: 0,\n        })\n      ) : (\n        <span {...dialogProps} className={`${prefixCls}-content`}>\n          {children}\n        </span>\n      );\n\n    const TransitionGroupComp = (\n      <CSSTransition\n        in={this.state.isOpen}\n        unmountOnExit={unmountOnExit}\n        onEntering={onOpening}\n        onEntered={onOpened}\n        onExiting={onClosing}\n        onExited={this.onClosed}\n        timeout={timeout!}\n        {...otherProps}\n        classNames={transitionName}\n      >\n        {(status) => (\n          <div\n            style={style}\n            className={[\n              prefixCls,\n              className,\n              !usePortal ? `${prefixCls}-inline` : null,\n              this.state.isOpen ? `${prefixCls}-enter-done` : null,\n            ]\n              .filter(Boolean)\n              .join(' ')\n              .trim()}\n          >\n            {hasBackdrop &&\n              cloneElement(<div />, {\n                ...backdropProps,\n                onMouseDown: this.handleBackdropMouseDown.bind(this),\n                className: [`${prefixCls}-backdrop`, backdropProps.className]\n                  .filter(Boolean)\n                  .join(' ')\n                  .trim(),\n                tabIndex: this.props.maskClosable ? 0 : null,\n              })}\n            {usePortal ? (\n              <div\n                ref={(node) => (this.container = node)}\n                onMouseDown={this.handleBackdropMouseDown.bind(this)}\n                className={`${prefixCls}-container`}\n              >\n                {cloneElement(decoratedChild, { 'data-status': status })}\n              </div>\n            ) : (\n              cloneElement(decoratedChild, { 'data-status': status })\n            )}\n          </div>\n        )}\n      </CSSTransition>\n    );\n    if (usePortal) {\n      if (!this.visible) {\n        this.visible = this.props.isOpen;\n      } else if (\n        this.visible === true &&\n        this.state.isOpen === false &&\n        this.state.isMount === false\n      ) {\n        this.visible = false;\n      }\n      return (\n        <Portal {...{ ...portalProps, ...{ visible: this.visible } }}>\n          {' '}\n          {TransitionGroupComp}{' '}\n        </Portal>\n      );\n    } else {\n      return TransitionGroupComp;\n    }\n  }\n}\n"]}
{
"name": "@uiw/react-overlay",
"version": "4.7.8",
"version": "4.7.9",
"description": "Overlay component",

@@ -45,4 +45,4 @@ "author": "Kenny Wong <wowohoo@qq.com>",

"dependencies": {
"@uiw/react-portal": "^4.7.8",
"@uiw/utils": "^4.7.8",
"@uiw/react-portal": "^4.7.9",
"@uiw/utils": "^4.7.9",
"react-transition-group": "^4.3.0"

@@ -59,3 +59,3 @@ },

},
"gitHead": "88859311dcf55770272516a0b46a8203ebc9eaf2"
"gitHead": "31bc1ada6fb6bd8603ede2df5a86aa8810eac17d"
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc