updated publish tool and dropzone components

This commit is contained in:
bill bittner 2018-06-01 14:53:12 -07:00
parent 857ae03b32
commit f1ae2e5bc7
27 changed files with 432 additions and 348 deletions

View file

@ -0,0 +1,21 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var DropzoneDropItDisplay = function DropzoneDropItDisplay() {
return _react.default.createElement("div", {
className: "dropzone-dropit-display"
}, _react.default.createElement("p", {
className: "blue"
}, "Drop it."));
};
var _default = DropzoneDropItDisplay;
exports.default = _default;

View file

@ -0,0 +1,27 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var DropzoneInstructionsDisplay = function DropzoneInstructionsDisplay(_ref) {
var fileError = _ref.fileError;
return _react.default.createElement("div", {
className: "dropzone-instructions-display"
}, _react.default.createElement("p", {
className: "info-message-placeholder info-message--failure",
id: "input-error-file-selection"
}, fileError), _react.default.createElement("p", null, "Drag & drop image or video here to publish"), _react.default.createElement("p", {
className: "fine-print"
}, "OR"), _react.default.createElement("p", {
className: "blue--underlined"
}, "CHOOSE FILE"));
};
var _default = DropzoneInstructionsDisplay;
exports.default = _default;

View file

@ -0,0 +1,123 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } _setPrototypeOf(subClass.prototype, superClass && superClass.prototype); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _getPrototypeOf(o) { _getPrototypeOf = Object.getPrototypeOf || function _getPrototypeOf(o) { return o.__proto__; }; return _getPrototypeOf(o); }
var PublishPreview =
/*#__PURE__*/
function (_React$Component) {
function PublishPreview(props) {
var _this;
_classCallCheck(this, PublishPreview);
_this = _possibleConstructorReturn(this, _getPrototypeOf(PublishPreview).call(this, props));
_this.state = {
imgSource: '',
defaultThumbnail: '/assets/img/video_thumb_default.png'
};
return _this;
}
_createClass(PublishPreview, [{
key: "componentDidMount",
value: function componentDidMount() {
this.setPreviewImageSource(this.props.file);
}
}, {
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(newProps) {
if (newProps.file !== this.props.file) {
this.setPreviewImageSource(newProps.file);
}
if (newProps.thumbnail !== this.props.thumbnail) {
if (newProps.thumbnail) {
this.setPreviewImageSourceFromFile(newProps.thumbnail);
} else {
this.setState({
imgSource: this.state.defaultThumbnail
});
}
}
}
}, {
key: "setPreviewImageSourceFromFile",
value: function setPreviewImageSourceFromFile(file) {
var _this2 = this;
var previewReader = new FileReader();
previewReader.readAsDataURL(file);
previewReader.onloadend = function () {
_this2.setState({
imgSource: previewReader.result
});
};
}
}, {
key: "setPreviewImageSource",
value: function setPreviewImageSource(file) {
if (file.type !== 'video/mp4') {
this.setPreviewImageSourceFromFile(file);
} else {
if (this.props.thumbnail) {
this.setPreviewImageSourceFromFile(this.props.thumbnail);
}
this.setState({
imgSource: this.state.defaultThumbnail
});
}
}
}, {
key: "render",
value: function render() {
return _react.default.createElement("img", {
id: "dropzone-preview",
src: this.state.imgSource,
className: this.props.dimPreview ? 'publish-preview-dim' : '',
alt: "publish preview"
});
}
}]);
_inherits(PublishPreview, _React$Component);
return PublishPreview;
}(_react.default.Component);
;
PublishPreview.propTypes = {
dimPreview: _propTypes.default.bool.isRequired,
file: _propTypes.default.object.isRequired,
thumbnail: _propTypes.default.object
};
var _default = PublishPreview;
exports.default = _default;

View file

@ -7,8 +7,6 @@ exports.default = void 0;
var _react = _interopRequireDefault(require("react")); var _react = _interopRequireDefault(require("react"));
var _styleCss = _interopRequireDefault(require("./style.css.js"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
@ -47,11 +45,11 @@ function (_React$Component) {
key: "render", key: "render",
value: function render() { value: function render() {
return _react.default.createElement("div", { return _react.default.createElement("div", {
style: _styleCss.default.wrapper className: 'horizontal-split'
}, _react.default.createElement("div", { }, _react.default.createElement("div", {
style: _styleCss.default.column className: 'column'
}, this.props.leftSide), _react.default.createElement("div", { }, this.props.leftSide), _react.default.createElement("div", {
style: _styleCss.default.column className: 'column'
}, this.props.rightSide)); }, this.props.rightSide));
} }
}]); }]);

View file

@ -1,20 +0,0 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var wrapper = {
display: 'flex',
flexDirection: 'row',
justifyContent: 'space-between',
alignItems: 'flex-start'
};
var column = {
width: '45%'
};
var _default = {
wrapper: wrapper,
column: column
};
exports.default = _default;

View file

@ -7,8 +7,6 @@ exports.default = void 0;
var _react = _interopRequireDefault(require("react")); var _react = _interopRequireDefault(require("react"));
var _styleCss = _interopRequireDefault(require("./style.css.js"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
@ -47,8 +45,7 @@ function (_React$Component) {
key: "render", key: "render",
value: function render() { value: function render() {
return _react.default.createElement("div", { return _react.default.createElement("div", {
style: _styleCss.default, className: 'page-content'
className: 'row--tall flex-container--column'
}, this.props.children); }, this.props.children);
} }
}]); }]);

View file

@ -5,8 +5,8 @@ Object.defineProperty(exports, "__esModule", {
}); });
exports.default = void 0; exports.default = void 0;
var style = { var style = {
margin: '2em', margin: '2em' // backgroundColor: 'red',
backgroundColor: 'red'
}; };
var _default = style; var _default = style;
exports.default = _default; exports.default = _default;

View file

@ -7,7 +7,13 @@ exports.default = void 0;
var _react = _interopRequireDefault(require("react")); var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types")); var _HorizontalSplit = _interopRequireDefault(require("@components/HorizontalSplit"));
var _Dropzone = _interopRequireDefault(require("@containers/Dropzone"));
var _PublishDetails = _interopRequireDefault(require("@containers/PublishDetails"));
var _PublishTitleInput = _interopRequireDefault(require("@containers/PublishTitleInput"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@ -32,79 +38,19 @@ function _getPrototypeOf(o) { _getPrototypeOf = Object.getPrototypeOf || functio
var PublishPreview = var PublishPreview =
/*#__PURE__*/ /*#__PURE__*/
function (_React$Component) { function (_React$Component) {
function PublishPreview(props) { function PublishPreview() {
var _this;
_classCallCheck(this, PublishPreview); _classCallCheck(this, PublishPreview);
_this = _possibleConstructorReturn(this, _getPrototypeOf(PublishPreview).call(this, props)); return _possibleConstructorReturn(this, _getPrototypeOf(PublishPreview).apply(this, arguments));
_this.state = {
imgSource: '',
defaultThumbnail: '/assets/img/video_thumb_default.png'
};
return _this;
} }
_createClass(PublishPreview, [{ _createClass(PublishPreview, [{
key: "componentDidMount",
value: function componentDidMount() {
this.setPreviewImageSource(this.props.file);
}
}, {
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(newProps) {
if (newProps.file !== this.props.file) {
this.setPreviewImageSource(newProps.file);
}
if (newProps.thumbnail !== this.props.thumbnail) {
if (newProps.thumbnail) {
this.setPreviewImageSourceFromFile(newProps.thumbnail);
} else {
this.setState({
imgSource: this.state.defaultThumbnail
});
}
}
}
}, {
key: "setPreviewImageSourceFromFile",
value: function setPreviewImageSourceFromFile(file) {
var _this2 = this;
var previewReader = new FileReader();
previewReader.readAsDataURL(file);
previewReader.onloadend = function () {
_this2.setState({
imgSource: previewReader.result
});
};
}
}, {
key: "setPreviewImageSource",
value: function setPreviewImageSource(file) {
if (file.type !== 'video/mp4') {
this.setPreviewImageSourceFromFile(file);
} else {
if (this.props.thumbnail) {
this.setPreviewImageSourceFromFile(this.props.thumbnail);
}
this.setState({
imgSource: this.state.defaultThumbnail
});
}
}
}, {
key: "render", key: "render",
value: function render() { value: function render() {
return _react.default.createElement("img", { return _react.default.createElement("div", null, _react.default.createElement(_PublishTitleInput.default, null), _react.default.createElement(_HorizontalSplit.default, {
id: "dropzone-preview", leftSide: _react.default.createElement(_Dropzone.default, null),
src: this.state.imgSource, rightSide: _react.default.createElement(_PublishDetails.default, null)
className: this.props.dimPreview ? 'publish-preview-dim' : '', }));
alt: "publish preview"
});
} }
}]); }]);
@ -114,10 +60,5 @@ function (_React$Component) {
}(_react.default.Component); }(_react.default.Component);
; ;
PublishPreview.propTypes = {
dimPreview: _propTypes.default.bool.isRequired,
file: _propTypes.default.object.isRequired,
thumbnail: _propTypes.default.object
};
var _default = PublishPreview; var _default = PublishPreview;
exports.default = _default; exports.default = _default;

View file

@ -9,7 +9,11 @@ var _react = _interopRequireDefault(require("react"));
var _file = require("../../utils/file"); var _file = require("../../utils/file");
var _PublishPreview = _interopRequireDefault(require("@components/PublishPreview")); var _DropzonePreview = _interopRequireDefault(require("@components/DropzonePreview"));
var _DropzoneDropItDisplay = _interopRequireDefault(require("@components/DropzoneDropItDisplay"));
var _DropzoneInstructionsDisplay = _interopRequireDefault(require("@components/DropzoneInstructionsDisplay"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@ -156,7 +160,7 @@ function (_React$Component) {
key: "render", key: "render",
value: function render() { value: function render() {
return _react.default.createElement("div", { return _react.default.createElement("div", {
className: "row row--tall flex-container--column" className: "dropzone-wrapper"
}, _react.default.createElement("form", null, _react.default.createElement("input", { }, _react.default.createElement("form", null, _react.default.createElement("input", {
className: "input-file", className: "input-file",
type: "file", type: "file",
@ -166,8 +170,7 @@ function (_React$Component) {
onChange: this.handleFileInput, onChange: this.handleFileInput,
encType: "multipart/form-data" encType: "multipart/form-data"
})), _react.default.createElement("div", { })), _react.default.createElement("div", {
id: "preview-dropzone", className: 'dropzone' + (this.state.dragOver ? ' dropzone--drag-over' : ''),
className: 'row row--padded row--tall dropzone' + (this.state.dragOver ? ' dropzone--drag-over' : ''),
onDrop: this.handleDrop, onDrop: this.handleDrop,
onDragOver: this.handleDragOver, onDragOver: this.handleDragOver,
onDragEnd: this.handleDragEnd, onDragEnd: this.handleDragEnd,
@ -176,43 +179,15 @@ function (_React$Component) {
onMouseEnter: this.handleMouseEnter, onMouseEnter: this.handleMouseEnter,
onMouseLeave: this.handleMouseLeave, onMouseLeave: this.handleMouseLeave,
onClick: this.handleClick onClick: this.handleClick
}, this.props.file ? _react.default.createElement("div", null, _react.default.createElement(_PublishPreview.default, { }, this.props.file ? _react.default.createElement("div", null, _react.default.createElement(_DropzonePreview.default, {
dimPreview: this.state.dimPreview, dimPreview: this.state.dimPreview,
file: this.props.file, file: this.props.file,
thumbnail: this.props.thumbnail thumbnail: this.props.thumbnail
}), _react.default.createElement("div", { }), this.state.dragOver ? _react.default.createElement(_DropzoneDropItDisplay.default, null) : null, this.state.mouseOver ? _react.default.createElement(_DropzoneInstructionsDisplay.default, {
id: "dropzone-text-holder", fileError: this.props.fileError
className: 'flex-container--column flex-container--center-center' }) : null) : this.state.dragOver ? _react.default.createElement(_DropzoneDropItDisplay.default, null) : _react.default.createElement(_DropzoneInstructionsDisplay.default, {
}, this.state.dragOver ? _react.default.createElement("div", { fileError: this.props.fileError
id: "dropzone-dragover" })));
}, _react.default.createElement("p", {
className: "blue"
}, "Drop it.")) : null, this.state.mouseOver ? _react.default.createElement("div", {
id: "dropzone-instructions"
}, _react.default.createElement("p", {
className: "info-message-placeholder info-message--failure",
id: "input-error-file-selection"
}, this.props.fileError), _react.default.createElement("p", null, "Drag & drop image or video here to publish"), _react.default.createElement("p", {
className: "fine-print"
}, "OR"), _react.default.createElement("p", {
className: "blue--underlined"
}, "CHOOSE FILE")) : null)) : _react.default.createElement("div", {
id: "dropzone-text-holder",
className: 'flex-container--column flex-container--center-center'
}, this.state.dragOver ? _react.default.createElement("div", {
id: "dropzone-dragover"
}, _react.default.createElement("p", {
className: "blue"
}, "Drop it.")) : _react.default.createElement("div", {
id: "dropzone-instructions"
}, _react.default.createElement("p", {
className: "info-message-placeholder info-message--failure",
id: "input-error-file-selection"
}, this.props.fileError), _react.default.createElement("p", null, "Drag & drop image or video here to publish"), _react.default.createElement("p", {
className: "fine-print"
}, "OR"), _react.default.createElement("p", {
className: "blue--underlined"
}, "CHOOSE FILE")))));
} }
}]); }]);

View file

@ -9,8 +9,6 @@ var _react = _interopRequireDefault(require("react"));
var _reactRouterDom = require("react-router-dom"); var _reactRouterDom = require("react-router-dom");
var _Dropzone = _interopRequireDefault(require("@containers/Dropzone"));
var _PublishTitleInput = _interopRequireDefault(require("@containers/PublishTitleInput")); var _PublishTitleInput = _interopRequireDefault(require("@containers/PublishTitleInput"));
var _PublishUrlInput = _interopRequireDefault(require("@containers/PublishUrlInput")); var _PublishUrlInput = _interopRequireDefault(require("@containers/PublishUrlInput"));
@ -63,16 +61,6 @@ function (_React$Component) {
key: "render", key: "render",
value: function render() { value: function render() {
return _react.default.createElement("div", { return _react.default.createElement("div", {
className: "row row--no-bottom"
}, _react.default.createElement("div", {
className: "column column--10"
}, _react.default.createElement(_PublishTitleInput.default, null)), _react.default.createElement("div", {
className: "column column--5 column--sml-10"
}, _react.default.createElement("div", {
className: "row row--padded"
}, _react.default.createElement(_Dropzone.default, null))), _react.default.createElement("div", {
className: "column column--5 column--sml-10 align-content-top"
}, _react.default.createElement("div", {
id: "publish-active-area", id: "publish-active-area",
className: "row row--padded" className: "row row--padded"
}, _react.default.createElement("div", { }, _react.default.createElement("div", {
@ -102,7 +90,7 @@ function (_React$Component) {
className: "link--primary", className: "link--primary",
target: "_blank", target: "_blank",
href: "https://lbry.io/learn" href: "https://lbry.io/learn"
}, "Read more.")))))); }, "Read more."))));
} }
}]); }]);

View file

@ -9,7 +9,7 @@ var _react = _interopRequireDefault(require("react"));
var _Dropzone = _interopRequireDefault(require("@containers/Dropzone")); var _Dropzone = _interopRequireDefault(require("@containers/Dropzone"));
var _PublishDetails = _interopRequireDefault(require("@containers/PublishDetails")); var _PublishPreview = _interopRequireDefault(require("@components/PublishPreview"));
var _PublishStatus = _interopRequireDefault(require("@containers/PublishStatus")); var _PublishStatus = _interopRequireDefault(require("@containers/PublishStatus"));
@ -54,7 +54,7 @@ function (_React$Component) {
if (this.props.status) { if (this.props.status) {
return _react.default.createElement(_PublishStatus.default, null); return _react.default.createElement(_PublishStatus.default, null);
} else { } else {
return _react.default.createElement(_PublishDetails.default, null); return _react.default.createElement(_PublishPreview.default, null);
} }
} }

View file

@ -1,28 +0,0 @@
.dropzone, .dropzone--disabled {
border: 2px dashed #9b9b9b;
text-align: center;
position: relative;
}
.dropzone:hover, .dropzone--drag-over {
border: 2px dashed #4156C5;
cursor: pointer;
}
#dropzone-text-holder {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
}
#dropzone-dragover, #dropzone-instructions {
padding: 1em;
}
#dropzone-preview {
display: block;
width: 100%;
}

View file

@ -7,18 +7,20 @@
@import '_tooltip'; @import '_tooltip';
@import '_link'; @import '_link';
@import '_row'; @import '_row';
@import '_column'; //@import '_column';
@import '_info-message'; @import '_info-message';
@import '_input'; @import '_input';
@import '_button'; @import '_button';
@import '_span'; @import '_span';
@import '_video'; @import '_video';
@import 'asset'; @import '_asset';
@import 'asset-preview'; @import '_asset-preview';
@import 'dropzone'; @import 'containers/_dropzone';
@import 'nav-bar'; @import '_nav-bar';
@import 'progress-bar'; @import '_progress-bar';
@import 'publish-preview'; @import '_publish-preview';
@import 'media-queries'; @import 'components/_horizontal-split';
@import 'components/_page-content';
@import '_media-queries';

View file

@ -0,0 +1,9 @@
.horizontal-split {
display : flex;
flex-direction : row;
justify-content: space-between;
align-items : flex-start;
.column {
width: calc(50% - 1em);
}
};

View file

@ -0,0 +1,10 @@
.page-content {
margin: 2em;
background-color: blue;
// fill the parent flex container
flex: 1 0 auto;
// be a flex container for children
display: flex;
-webkit-flex-direction: column;
flex-direction: column;
};

View file

@ -0,0 +1,38 @@
.dropzone-wrapper {
background-color: yellow;
// fill the parent flex container
flex: 1 0 auto;
// be a flex container for children
display: flex;
flex-direction: column;
}
.dropzone {
border: 2px dashed #9b9b9b;
background-color: red;
// fill the parent flex container
flex: 1 0 auto;
// be a flex container for children
display: flex;
-webkit-flex-direction: column;
flex-direction: column;
justify-content: center;
align-items: center;
}
.dropzone:hover, .dropzone--active {
border: 2px dashed #4156C5;
cursor: pointer;
}
.dropzone-dropit-display, .dropzone-instructions-display {
padding: 1em;
text-align: center;
}
#dropzone-preview {
display: block;
padding: 1em;
width: calc(100% - 2em);
}

View file

@ -0,0 +1,11 @@
import React from 'react';
const DropzoneDropItDisplay = () => {
return (
<div className='dropzone-dropit-display'>
<p className='blue'>Drop it.</p>
</div>
);
}
export default DropzoneDropItDisplay;

View file

@ -0,0 +1,14 @@
import React from 'react';
const DropzoneInstructionsDisplay = ({fileError}) => {
return (
<div className='dropzone-instructions-display'>
<p className='info-message-placeholder info-message--failure' id='input-error-file-selection'>{fileError}</p>
<p>Drag & drop image or video here to publish</p>
<p className='fine-print'>OR</p>
<p className='blue--underlined'>CHOOSE FILE</p>
</div>
);
};
export default DropzoneInstructionsDisplay;

View file

@ -0,0 +1,62 @@
import React from 'react';
import PropTypes from 'prop-types';
class PublishPreview extends React.Component {
constructor (props) {
super(props);
this.state = {
imgSource : '',
defaultThumbnail: '/assets/img/video_thumb_default.png',
};
}
componentDidMount () {
this.setPreviewImageSource(this.props.file);
}
componentWillReceiveProps (newProps) {
if (newProps.file !== this.props.file) {
this.setPreviewImageSource(newProps.file);
}
if (newProps.thumbnail !== this.props.thumbnail) {
if (newProps.thumbnail) {
this.setPreviewImageSourceFromFile(newProps.thumbnail);
} else {
this.setState({imgSource: this.state.defaultThumbnail});
}
}
}
setPreviewImageSourceFromFile (file) {
const previewReader = new FileReader();
previewReader.readAsDataURL(file);
previewReader.onloadend = () => {
this.setState({imgSource: previewReader.result});
};
}
setPreviewImageSource (file) {
if (file.type !== 'video/mp4') {
this.setPreviewImageSourceFromFile(file);
} else {
if (this.props.thumbnail) {
this.setPreviewImageSourceFromFile(this.props.thumbnail);
}
this.setState({imgSource: this.state.defaultThumbnail});
}
}
render () {
return (
<img
id='dropzone-preview'
src={this.state.imgSource}
className={this.props.dimPreview ? 'publish-preview-dim' : ''}
alt='publish preview'
/>
);
}
};
PublishPreview.propTypes = {
dimPreview: PropTypes.bool.isRequired,
file : PropTypes.object.isRequired,
thumbnail : PropTypes.object,
};
export default PublishPreview;

View file

@ -1,18 +1,16 @@
import React from 'react'; import React from 'react';
import style from './style.css.js';
class HorizontalSplit extends React.Component { class HorizontalSplit extends React.Component {
shouldComponentUpdate () { shouldComponentUpdate () {
return false; return false;
} }
render () { render () {
return ( return (
<div style={style.wrapper}> <div className={'horizontal-split'}>
<div style={style.column}> <div className={'column'}>
{this.props.leftSide} {this.props.leftSide}
</div> </div>
<div style={style.column}> <div className={'column'}>
{this.props.rightSide} {this.props.rightSide}
</div> </div>
</div> </div>

View file

@ -1,15 +0,0 @@
const wrapper = {
display : 'flex',
flexDirection : 'row',
justifyContent: 'space-between',
alignItems : 'flex-start',
};
const column = {
width: '45%',
};
export default {
wrapper,
column,
};

View file

@ -1,14 +1,12 @@
import React from 'react'; import React from 'react';
import style from './style.css.js';
class PageContent extends React.Component { class PageContent extends React.Component {
shouldComponentUpdate () { shouldComponentUpdate () {
return false; return false;
} }
render () { render () {
return ( return (
<div style={style} className={'row--tall flex-container--column'}> <div className={'page-content'}>
{this.props.children} {this.props.children}
</div> </div>
); );

View file

@ -1,6 +0,0 @@
const style = {
margin : '2em',
backgroundColor: 'red',
};
export default style;

View file

@ -1,62 +1,21 @@
import React from 'react'; import React from 'react';
import PropTypes from 'prop-types'; import HorizontalSplit from '@components/HorizontalSplit';
import Dropzone from '@containers/Dropzone';
import PublishDetails from '@containers/PublishDetails';
import PublishTitleInput from '@containers/PublishTitleInput';
class PublishPreview extends React.Component { class PublishPreview extends React.Component {
constructor (props) {
super(props);
this.state = {
imgSource : '',
defaultThumbnail: '/assets/img/video_thumb_default.png',
};
}
componentDidMount () {
this.setPreviewImageSource(this.props.file);
}
componentWillReceiveProps (newProps) {
if (newProps.file !== this.props.file) {
this.setPreviewImageSource(newProps.file);
}
if (newProps.thumbnail !== this.props.thumbnail) {
if (newProps.thumbnail) {
this.setPreviewImageSourceFromFile(newProps.thumbnail);
} else {
this.setState({imgSource: this.state.defaultThumbnail});
}
}
}
setPreviewImageSourceFromFile (file) {
const previewReader = new FileReader();
previewReader.readAsDataURL(file);
previewReader.onloadend = () => {
this.setState({imgSource: previewReader.result});
};
}
setPreviewImageSource (file) {
if (file.type !== 'video/mp4') {
this.setPreviewImageSourceFromFile(file);
} else {
if (this.props.thumbnail) {
this.setPreviewImageSourceFromFile(this.props.thumbnail);
}
this.setState({imgSource: this.state.defaultThumbnail});
}
}
render () { render () {
return ( return (
<img <div>
id='dropzone-preview' <PublishTitleInput />
src={this.state.imgSource} <HorizontalSplit
className={this.props.dimPreview ? 'publish-preview-dim' : ''} leftSide={<Dropzone />}
alt='publish preview' rightSide={<PublishDetails />}
/> />
</div>
); );
} }
}; };
PublishPreview.propTypes = {
dimPreview: PropTypes.bool.isRequired,
file : PropTypes.object.isRequired,
thumbnail : PropTypes.object,
};
export default PublishPreview; export default PublishPreview;

View file

@ -1,6 +1,8 @@
import React from 'react'; import React from 'react';
import { validateFile } from '../../utils/file'; import { validateFile } from '../../utils/file';
import PublishPreview from '@components/PublishPreview'; import DropzonePreview from '@components/DropzonePreview';
import DropzoneDropItDisplay from '@components/DropzoneDropItDisplay';
import DropzoneInstructionsDisplay from '@components/DropzoneInstructionsDisplay';
class Dropzone extends React.Component { class Dropzone extends React.Component {
constructor (props) { constructor (props) {
@ -80,53 +82,48 @@ class Dropzone extends React.Component {
} }
render () { render () {
return ( return (
<div className='row row--tall flex-container--column'> <div className='dropzone-wrapper'>
<form> <form>
<input className='input-file' type='file' id='file_input' name='file_input' accept='video/*,image/*' onChange={this.handleFileInput} encType='multipart/form-data' /> <input
className='input-file'
type='file'
id='file_input'
name='file_input'
accept='video/*,image/*'
onChange={this.handleFileInput}
encType='multipart/form-data'
/>
</form> </form>
<div id='preview-dropzone' className={'row row--padded row--tall dropzone' + (this.state.dragOver ? ' dropzone--drag-over' : '')} onDrop={this.handleDrop} onDragOver={this.handleDragOver} onDragEnd={this.handleDragEnd} onDragEnter={this.handleDragEnter} onDragLeave={this.handleDragLeave} onMouseEnter={this.handleMouseEnter} onMouseLeave={this.handleMouseLeave} onClick={this.handleClick}> <div
className={'dropzone' + (this.state.dragOver ? ' dropzone--drag-over' : '')}
onDrop={this.handleDrop}
onDragOver={this.handleDragOver}
onDragEnd={this.handleDragEnd}
onDragEnter={this.handleDragEnter}
onDragLeave={this.handleDragLeave}
onMouseEnter={this.handleMouseEnter}
onMouseLeave={this.handleMouseLeave}
onClick={this.handleClick}>
{this.props.file ? ( {this.props.file ? (
<div> <div>
<PublishPreview <DropzonePreview
dimPreview={this.state.dimPreview} dimPreview={this.state.dimPreview}
file={this.props.file} file={this.props.file}
thumbnail={this.props.thumbnail} thumbnail={this.props.thumbnail}
/> />
<div id='dropzone-text-holder' className={'flex-container--column flex-container--center-center'}> { this.state.dragOver ? <DropzoneDropItDisplay /> : null }
{ this.state.dragOver ? (
<div id='dropzone-dragover'>
<p className='blue'>Drop it.</p>
</div>
) : (
null
)}
{ this.state.mouseOver ? ( { this.state.mouseOver ? (
<div id='dropzone-instructions'> <DropzoneInstructionsDisplay
<p className='info-message-placeholder info-message--failure' id='input-error-file-selection'>{this.props.fileError}</p> fileError={this.props.fileError}
<p>Drag & drop image or video here to publish</p> />
<p className='fine-print'>OR</p> ) : null }
<p className='blue--underlined'>CHOOSE FILE</p>
</div> </div>
) : ( ) : (
null this.state.dragOver ? <DropzoneDropItDisplay /> : (
)} <DropzoneInstructionsDisplay
</div> fileError={this.props.fileError}
</div> />
) : ( )
<div id='dropzone-text-holder' className={'flex-container--column flex-container--center-center'}>
{ this.state.dragOver ? (
<div id='dropzone-dragover'>
<p className='blue'>Drop it.</p>
</div>
) : (
<div id='dropzone-instructions'>
<p className='info-message-placeholder info-message--failure' id='input-error-file-selection'>{this.props.fileError}</p>
<p>Drag & drop image or video here to publish</p>
<p className='fine-print'>OR</p>
<p className='blue--underlined'>CHOOSE FILE</p>
</div>
)}
</div>
)} )}
</div> </div>
</div> </div>

View file

@ -1,6 +1,5 @@
import React from 'react'; import React from 'react';
import { withRouter } from 'react-router-dom'; import { withRouter } from 'react-router-dom';
import Dropzone from '@containers/Dropzone';
import PublishTitleInput from '@containers/PublishTitleInput'; import PublishTitleInput from '@containers/PublishTitleInput';
import PublishUrlInput from '@containers/PublishUrlInput'; import PublishUrlInput from '@containers/PublishUrlInput';
import PublishThumbnailInput from '@containers/PublishThumbnailInput'; import PublishThumbnailInput from '@containers/PublishThumbnailInput';
@ -17,18 +16,6 @@ class PublishDetails extends React.Component {
} }
render () { render () {
return ( return (
<div className='row row--no-bottom'>
<div className='column column--10'>
<PublishTitleInput />
</div>
{/* left column */}
<div className='column column--5 column--sml-10' >
<div className='row row--padded'>
<Dropzone />
</div>
</div>
{/* right column */}
<div className='column column--5 column--sml-10 align-content-top'>
<div id='publish-active-area' className='row row--padded'> <div id='publish-active-area' className='row row--padded'>
<div className='row row--padded row--no-top row--wide'> <div className='row row--padded row--no-top row--wide'>
<PublishUrlInput /> <PublishUrlInput />
@ -54,8 +41,6 @@ class PublishDetails extends React.Component {
<p className='fine-print'>By clicking 'Publish', you affirm that you have the rights to publish this content to the LBRY network, and that you understand the properties of publishing it to a decentralized, user-controlled network. <a className='link--primary' target='_blank' href='https://lbry.io/learn'>Read more.</a></p> <p className='fine-print'>By clicking 'Publish', you affirm that you have the rights to publish this content to the LBRY network, and that you understand the properties of publishing it to a decentralized, user-controlled network. <a className='link--primary' target='_blank' href='https://lbry.io/learn'>Read more.</a></p>
</div> </div>
</div> </div>
</div>
</div>
); );
} }
}; };

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import Dropzone from '@containers/Dropzone'; import Dropzone from '@containers/Dropzone';
import PublishDetails from '@containers/PublishDetails'; import PublishPreview from '@components/PublishPreview';
import PublishStatus from '@containers/PublishStatus'; import PublishStatus from '@containers/PublishStatus';
import PublishDisabledMessage from '@containers/PublishDisabledMessage'; import PublishDisabledMessage from '@containers/PublishDisabledMessage';
@ -17,7 +17,7 @@ class PublishTool extends React.Component {
<PublishStatus /> <PublishStatus />
); );
} else { } else {
return <PublishDetails />; return <PublishPreview />;
} }
} }
return <Dropzone />; return <Dropzone />;