Автоматическое изменение размера перетаскиваемого компонента в React - PullRequest
0 голосов
/ 17 марта 2020

Я работаю в React. Я работаю над перетаскиванием подразделения, скажем Q, и переносом его в другое подразделение, скажем A. Контейнер A имеет свойство увеличения и уменьшения, которое реализовано с помощью функции масштабирования. Когда Q сбрасывается на A, Q становится частью A, а при отбрасывании на A, масштаб Q относительно A. Теперь при перетаскивании Q из A, Q возвращается к своему первоначальному размеру, а не с курсором. Как сделать размер компонента при перетаскивании из A относительно шкалы A. Ниже приведен код, который будет полезен для справки

zoomState(e) {
switch (e.deltaY > 0) {
  case true:
  if(out==0)
  {
    if(this.state.scale>2.5)
    {
    this.zoomOut(e);
    }
    }

  else{
  }
  break;
  default:

    this.zoomIn(e);

    }
  }
zoomIn = (e) => {
  this.setState({ scale: this.state.scale * 2});
    console.log("zoomin" + ""+ this.state.scale)
    e.target.style.transform = `scale(${this.state.scale})`
    out=0  
  }
zoomOut = (e) => {
  this.setState({ scale: this.state.scale / 2});
   e.target.style.transform = `scale(${this.state.scale})`
   console.log("zoomout" + ""+ this.state.scale)
   if(this.state.scale==1)
   {
     e.target.style.transform=null
   }
  }

  dragStart(event) {
    event.dataTransfer.setData("Text", event.target.id);
    var dragtarget1=document.getElementById("dragtarget1")
    var dragtarget2=document.getElementById("dragtarget2")

    if(event.target.id=="dragtarget1")
    {

     setTimeout(function(){
      dragtarget1.classList.add('hide');
    });


  }
  if(event.target.id=="dragtarget2")
  {
   setTimeout(function(){
    dragtarget2.classList.add('hide');
  });
}




    }
    allowDrop(event) {
      event.preventDefault();

    }
    drop=(event)=> {
      event.preventDefault();
      var data = document.getElementById(event.dataTransfer.getData("Text"));
      event.target.appendChild(data);
      data.style.position = "fixed";

      if(this.state.scale>1){
        data.style.left = (event.nativeEvent.offsetX - data.clientWidth / 2)  + "px";
        data.style.top = (event.nativeEvent.offsetY - data.clientHeight / 2) + "px";

      }
      else{
        data.style.left = (event.clientX - data.clientWidth / 2)  + "px";
        data.style.top = (event.clientY - data.clientHeight / 2)  + "px";
        }
      var dragtarget1=document.getElementById("dragtarget1")
      setTimeout(function(){
      dragtarget1.classList.remove('hide');
      });
      var dragtarget2=document.getElementById("dragtarget2")
      setTimeout(function(){
      dragtarget2.classList.remove('hide');
      });


    }
    cood(){
     var bg=document.getElementById("bg")
     bg.style.transform=null
    }
    onMouseMove(e)
    {
      xcood=e.nativeEvent.offsetX
      ycood= e.nativeEvent.offsetY 
      console.log(xcood,ycood)
    }
    render() {
    return (
      <div id="base" >   
      <div className="first" id="first">

      </div>
      <div className="second">
      <div className="container">
           <div  id="bg" ref="bg"
           onWheel={(e)=>this.zoomState(e)}
           className="bg-image-wrapper"
           style={{ 'transform': `scale(${this.state.scale})`}}
           onDrop={(e)=>this.drop(e)} onDragOver={(e)=>this.allowDrop(e)} 
           onDoubleClick={
            e => {

                this.handleDoubleClick (e);
            }}
           >



          </div> 


      </div>
      <div className="comp">

      <div className="droptarget1">
      <div 
      style={{
         height:25,
         width:25,
         backgroundColor:"red",
         position:"fixed", 
         //transform:`scale(${this.state.scale})`
         transform:`scale(${this.state.scale2})`

       }}
       onDragStart={(e)=>this.dragStart(e)} draggable="true" id="dragtarget1">
      </div>
      </div>
      <div className="droptarget2"> 
      <div
      style={{
        height:25,
        width:25,
        backgroundColor:"blue",
        position:"fixed",




      }}
      onDragStart={(e)=>this.dragStart(e)} draggable="true" id="dragtarget2">
      </div>
      </div>

    </div>
    </div>
    <div className="third">



    </div>

    </div>   
      );
    }
...