Доступ к позиции пройденного контейнера - PullRequest
0 голосов
/ 06 февраля 2020

Событие Onmousedown, я хочу изменить позицию контейнера. Но когда я прохожу контейнер, я не могу получить доступ к позиции контейнера. Ниже приведен следующий код. Я вызываю функцию catchItem для события mousedown по порядку. изменить позицию контейнера. Но он выдает ошибку как: TypeError: Невозможно установить свойство 'left' из неопределенного


import React, { useState, useEffect, useCallback } from "react";
import ReactDom from "react-dom";
import {AnchorButton, Intent, ProgressBar} from "@blueprintjs/core";
import "./style.scss";

import _ from "lodash";
import { Icon } from "react-icons-kit";
import {remove} from 'react-icons-kit/fa/remove';

import "./style.scss";
var mousePosition;
var offset = [0,0];
var div;
var isDown = false;

export class Core  extends React.Component{
    constructor(props){
        super(props)
        //Setting the state
        this.state = {
            loadedFiles:[],
        };

    };





    onFileLoad(e) {
        const file = e.currentTarget.files[0];
        let fileReader = new FileReader();
        fileReader.onload = () => {
            //console.log("Image Loaded: ", fileReader.result);
            const file = {


                data: fileReader.result,
                isUploading:false
            }

            this.addLoadedFile(file);
        }

        fileReader.onabort = () => {
            alert("Reading Aborted");
        }
        fileReader.onerror = () => {
            alert("Error in Reading")
        }

        fileReader.readAsDataURL(file);



        //file.onmousedown=this.catchItem(e);



    }
    addLoadedFile(file){
        this.setState((prevState) => ({ loadedFiles: [...prevState.loadedFiles, file]}));
    }
    removeLoadedFile(file){
        this.setState((prevState) => {
            let loadedFiles = prevState.loadedFiles;
            let newLoadedFiles = _.filter(loadedFiles, (ldFile) => {
                return ldFile!=file;
            });
            return { loadedFiles : newLoadedFiles }
        });
    }
    removeAllLoadedFile(){
        this.setState({loadedFiles : []});
    }
    catchItem(e) {
        this.style.left = e.pageX - this.clientWidth / 2 + "px";
        this.style.top = e.pageY - this.clientHeight / 2 + "px";
        this.onmousemove = function(e) {
        this.style.left = e.pageX - this.clientWidth / 2 + "px";
        this.style.top = e.pageY - this.clientHeight / 2 + "px";
        }
        this.onmouseup = function() {
        this.onmousemove = null; // onmouseup event [ redirect mousemove event signal to null instead of the drag-able element]
        }
    }



    render(){

        const { loadedFiles } = this.state;
        return(

        <div>
                <div className="header">

                </div>
                <div className="function">
                    <div className="tools">

                        <button className="button"

                            onClick={()=>this.fileInput.click()}

                        >
                            Components
                        </button>




                    </div>
                    <div className="grid">
                    <input 
                    type="file"
                    className="file"
                    id="file-browser-input"
                    name="file-browser-input"
                    ref ={input=>this.fileInput=input}
                    onDragOver={(e)=>{
                        e.preventDefault();
                        e.stopPropagation();
                    }


                    }
                    onDrop={this.onFileLoad.bind(this)}
                    onChange={this.onFileLoad.bind(this)}
                    onMouseDown={this.catchItem.bind(this)}
                    //onMouseMove={this.mousemove.bind(this)}
                    //onMouseUp={this.mouseup.bind(this)}

                    />
                    <div style={{left:"5px",top:"5px"}}
                    className="files-preview-container" 

                    onMouseDown={this.catchItem.bind(this)}>
                        {loadedFiles.map((file,idx) => {
                            return <div
                                className="file"
                                key={idx}
                                >
                                <img src = {file.data}/>


                            </div>
                        })}
                    </div>





                    </div>
                    <div className="ui">

                    </div>

                </div>
                <div className="footer">

                </div>
        </div>
        )
    }
}

export default Core

1 Ответ

0 голосов
/ 06 февраля 2020

Вы можете получить доступ к положению контейнера через SyntheticEvent

catchItem(e) {
    console.log(e.target.style.left);
    console.log(e.target.getBoundingClientRect());
}
...