aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/ui/ImageUpload.js
blob: d07c3649c433a225143d9fcbd90a7a1917a5154e (plain) (blame)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import React, { Component } from 'react';
import PropTypes from 'prop-types';
import { observer } from 'mobx-react';
import { Field } from 'mobx-react-form';
// import Loader from 'react-loader';
import classnames from 'classnames';
import Dropzone from 'react-dropzone';

@observer
export default class ImageUpload extends Component {
  static propTypes = {
    field: PropTypes.instanceOf(Field).isRequired,
    className: PropTypes.string,
    multiple: PropTypes.bool,
    // disabled: PropTypes.bool,
    // onClick: PropTypes.func,
    // type: PropTypes.string,
    // buttonType: PropTypes.string,
    // loaded: PropTypes.bool,
    // htmlForm: PropTypes.string,
  };

  static defaultProps = {
    className: null,
    multiple: false,
    // disabled: false,
    // onClick: () => {},
    // type: 'button',
    // buttonType: '',
    // loaded: true,
    // htmlForm: '',
  };

  dropzoneRef = null;

  state = {
    path: null,
  }

  onDrop(acceptedFiles) {
    // const req = request.post('/upload');
    acceptedFiles.forEach((file) => {
      console.log(file);
      this.setState({
        path: file.path,
      });
      // req.attach(file.name, file);
    });
    // req.end(callback);
  }

  render() {
    const {
      field,
      className,
      multiple,
      // disabled,
      // onClick,
      // type,
      // buttonType,
      // loaded,
      // htmlForm,
    } = this.props;

    const cssClasses = classnames({
      'franz-form__button': true,
      // [`franz-form__button--${buttonType}`]: buttonType,
      [`${className}`]: className,
    });

    return (
      <div>
        {field.label}
        {this.state.path ? (
          <div
            className="image-upload"
          >
            <div
              className="image-upload__preview"
              style={({
                backgroundImage: `url(${this.state.path})`,
              })}
            />
            <div className="image-upload__action">
              <button
                type="button"
                onClick={() => {
                  this.setState({
                    path: null,
                  });
                }}
              >
                remove icon

              </button>
              <div className="image-upload__action-background" />
            </div>
          </div>
        ) : (
          <Dropzone
            ref={(node) => { this.dropzoneRef = node; }}
            onDrop={this.onDrop.bind(this)}
            className={cssClasses}
            multiple={multiple}
            accept="image/jpeg, image/png"
          >
            <p>Try dropping some files here, or click to select files to upload.</p>
          </Dropzone>
        )}
      </div>
    );
  }
}