index.js 1.38 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
import React, { useState } from 'react'
import { Modal } from 'antd'

const Drag = (props) => {

  const [style, setStyle] = useState({ left: 0, top: 100 })

  const inWindow = (left, top, startPosX, startPosY) => {
    const H = document.body.clientHeight;
    const W = document.body.clientWidth;
    if (
      (left < 20 && startPosX > left) ||
      (left > W - 20 && startPosX < left) ||
      (top < 20 && startPosY > top) ||
      (top > H - 20 && startPosY < top)
    ) {
      document.body.onmousemove = null;
      document.body.onmouseup = null;
      return false;
    }
    return true;
  }

  const onMouseDown = (e) => {
    const startPosX = e.clientX;
    const startPosY = e.clientY;
    document.body.onmousemove = (e) => {
      const left = e.clientX - startPosX + style.left;
      const top = e.clientY - startPosY + style.top;
      if (inWindow(e.clientX, e.clientY, startPosX, startPosY)) {
        setStyle({ left, top })
      }
    }; // 鼠标放开时去掉移动事件
    document.body.onmouseup = function () {
      document.body.onmousemove = null;
    }
  }

  return (
    <Modal
      getContainer={false}
      {...props}
      style={style}
      title={
        <div style={{ width: '100%', cursor: 'move' }} onMouseDown={onMouseDown}>
          {props.title}
        </div>
      }
    >
      {
        props.children
      }
    </Modal>
  )

}

export default Drag