Перетащите изображения в React - PullRequest
0 голосов
/ 17 июня 2019

Я пытаюсь реализовать поведение перетаскивания с использованием React JS и библиотеки act-dropzone с отображением миниатюр.

Код выглядит следующим образом:

import React from "react";
import ReactDOM from "react-dom";
import Dropzone from "react-dropzone";

import "./styles.css";

class App extends React.Component {
  constructor(props) {
    super(props);

    this.state = {
      dropzone1: [],
      dropzone2: []
    };
  }

  addFilesToDropzone(files, dropzone) {
    let files_with_preview = [];
    files.map(file => {
      file["preview"] = URL.createObjectURL(file);
      files_with_preview.push(file);
    });

    const new_files = [...this.state[dropzone], ...files_with_preview];
    this.setState({ [dropzone]: new_files });
  }

  render() {

    return (
      <div className="App">
        <Dropzone
          onDrop={files => {
            this.addFilesToDropzone(files, "dropzone1");
          }}
        >
          {({ getRootProps, getInputProps }) => (
            <div {...getRootProps()} className="">
              <input {...getInputProps()} />
              <div style={{ height: 100, backgroundColor: "yellow" }}>
                Drop some files here
                {dropzone1.map(file => (
                  <img
                    src={file.preview}
                    alt={file.path}
                    style={{ width: 40, height: 40 }}
                  />
                ))}
              </div>
            </div>
          )}
        </Dropzone>

        <div style={{ display: "flex", flexDirection: "row", marginTop: 25 }}>
          <div style={{ width: "100%" }}>
            DROPZONE 2
            <Dropzone
              onDrop={files => {
                this.addFilesToDropzone(files, "dropzone2");
              }}
            >
              {({ getRootProps, getInputProps }) => (
                <div {...getRootProps()} className="">
                  <input {...getInputProps()} />
                  <div style={{ height: 100, backgroundColor: "yellow" }}>
                    Drop some files here
                    {this.state.dropzone2.map(file => (
                      <img
                        src={file.preview}
                        alt="dsds"
                        style={{ width: 40, height: 40 }}
                      />
                    ))}
                  </div>
                </div>
              )}
            </Dropzone>
          </div>
        </div>
      </div>
    );
  }
}

const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);

Вот пример для codesandbox.

Все отлично работает, когда я перетаскиваю файлы из папки на моем компьютере, но я хочу иметь возможность перетаскивать миниатюры, созданные с помощью dropzone 1 вdropzone 2. Но это не работает.

Есть идеи, как это сделать?

Ответы [ 2 ]

1 голос
/ 17 июня 2019

Да, это не работает, потому что это не то, для чего предназначена реагирующая дропзона.Цитата с сайта:

Простая ловушка React для создания HTML5-совместимой зоны перетаскивания для файлов.

Используйте Reaction-dnd или реагировать-Beautiful-вместо этого.

0 голосов
/ 17 июня 2019

Вы можете использовать другой пакет: Reaction-file-drop

...