2018-01-17 10:49:57 -08:00
|
|
|
import {connect} from 'react-redux';
|
2018-01-18 09:33:26 -08:00
|
|
|
import {clearFile, selectFile, updateError, updatePublishStatus} from 'actions/publish';
|
|
|
|
import {updateLoggedInChannel} from 'actions/channel';
|
2018-01-17 15:00:03 -08:00
|
|
|
import View from './view';
|
2018-01-17 10:49:57 -08:00
|
|
|
|
2018-01-18 09:33:26 -08:00
|
|
|
const mapStateToProps = ({ channel, publish }) => {
|
2018-01-17 10:49:57 -08:00
|
|
|
return {
|
2018-01-18 09:33:26 -08:00
|
|
|
loggedInChannel : channel.loggedInChannel,
|
|
|
|
file : publish.file,
|
|
|
|
claim : publish.claim,
|
|
|
|
title : publish.metadata.title,
|
|
|
|
thumbnail : publish.metadata.thumbnail,
|
|
|
|
description : publish.metadata.description,
|
|
|
|
license : publish.metadata.license,
|
|
|
|
nsfw : publish.metadata.nsfw,
|
|
|
|
publishInChannel : publish.publishInChannel,
|
|
|
|
fileError : publish.error.file,
|
|
|
|
urlError : publish.error.url,
|
|
|
|
publishSubmitError: publish.error.publishSubmit,
|
2018-01-17 10:49:57 -08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const mapDispatchToProps = dispatch => {
|
|
|
|
return {
|
|
|
|
onFileSelect: (file) => {
|
|
|
|
dispatch(selectFile(file));
|
|
|
|
},
|
|
|
|
onFileClear: () => {
|
|
|
|
dispatch(clearFile());
|
|
|
|
},
|
|
|
|
onChannelLogin: (name, shortId, longId) => {
|
|
|
|
dispatch(updateLoggedInChannel(name, shortId, longId));
|
|
|
|
},
|
|
|
|
onPublishStatusChange: (status, message) => {
|
|
|
|
dispatch(updatePublishStatus(status, message));
|
|
|
|
},
|
|
|
|
onPublishSubmitError: (value) => {
|
|
|
|
dispatch(updateError('publishSubmit', value));
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(View);
|