2015-08-12 13:34:41 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import Property from './../ascribe_forms/property';
|
|
|
|
|
|
|
|
import ReactS3FineUploader from './../ascribe_uploader/react_s3_fine_uploader';
|
|
|
|
|
|
|
|
import AppConstants from '../../constants/application_constants';
|
2016-01-21 12:24:15 +01:00
|
|
|
import { validationTypes } from '../../constants/uploader_constants';
|
2015-08-12 13:34:41 +02:00
|
|
|
|
2016-06-14 13:37:33 +02:00
|
|
|
import { makeCsrfHeader } from '../../utils/csrf';
|
2016-06-13 14:35:02 +02:00
|
|
|
import { getLangText } from '../../utils/lang';
|
2016-06-14 13:05:57 +02:00
|
|
|
import { resolveUrl } from '../../utils/url_resolver';
|
2015-12-02 12:25:11 +01:00
|
|
|
|
2015-08-12 13:34:41 +02:00
|
|
|
|
2015-12-08 20:57:40 +01:00
|
|
|
const { func, bool, number, object, string, arrayOf } = React.PropTypes;
|
2015-12-08 18:09:24 +01:00
|
|
|
|
2015-08-12 13:34:41 +02:00
|
|
|
let FurtherDetailsFileuploader = React.createClass({
|
|
|
|
propTypes: {
|
2016-02-05 17:06:16 +01:00
|
|
|
pieceId: number.isRequired,
|
|
|
|
|
|
|
|
editable: bool,
|
2015-12-08 20:55:13 +01:00
|
|
|
label: string,
|
2015-12-08 18:09:24 +01:00
|
|
|
otherData: arrayOf(object),
|
|
|
|
|
|
|
|
// Props for ReactS3FineUploader
|
2016-02-05 17:06:16 +01:00
|
|
|
areAssetsDownloadable: bool,
|
|
|
|
isReadyForFormSubmission: func,
|
2015-12-08 18:09:24 +01:00
|
|
|
submitFile: func, // TODO: rename to onSubmitFile
|
2016-02-05 17:06:16 +01:00
|
|
|
onValidationFailed: func,
|
|
|
|
multiple: bool,
|
2015-12-08 18:09:24 +01:00
|
|
|
setIsUploadReady: func, //TODO: rename to setIsUploaderValidated
|
2016-02-05 17:06:16 +01:00
|
|
|
showErrorPrompt: bool,
|
2016-01-21 12:24:15 +01:00
|
|
|
validation: ReactS3FineUploader.propTypes.validation
|
2015-08-12 13:34:41 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
getDefaultProps() {
|
|
|
|
return {
|
2015-12-09 18:29:43 +01:00
|
|
|
areAssetsDownloadable: true,
|
2015-12-02 12:25:11 +01:00
|
|
|
label: getLangText('Additional files'),
|
2016-01-21 12:24:15 +01:00
|
|
|
multiple: false,
|
|
|
|
validation: validationTypes.additionalData
|
2015-08-12 13:34:41 +02:00
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
render() {
|
2016-02-08 14:08:54 +01:00
|
|
|
const { editable,
|
|
|
|
isReadyForFormSubmission,
|
|
|
|
multiple,
|
|
|
|
onValidationFailed,
|
|
|
|
otherData,
|
|
|
|
pieceId,
|
|
|
|
setIsUploadReady,
|
|
|
|
showErrorPrompt,
|
|
|
|
submitFile,
|
|
|
|
validation } = this.props;
|
2015-12-08 18:09:24 +01:00
|
|
|
|
2015-08-12 13:34:41 +02:00
|
|
|
// Essentially there a three cases important to the fileuploader
|
|
|
|
//
|
2015-08-24 11:22:44 +02:00
|
|
|
// 1. there is no other_data => do not show the fileuploader at all (where otherData is now an array)
|
2015-08-12 13:34:41 +02:00
|
|
|
// 2. there is other_data, but user has no edit rights => show fileuploader but without action buttons
|
2015-08-20 11:32:11 +02:00
|
|
|
// 3. both other_data and editable are defined or true => show fileuploader with all action buttons
|
2015-12-08 18:09:24 +01:00
|
|
|
if (!editable && (!otherData || otherData.length === 0)) {
|
2015-08-12 13:34:41 +02:00
|
|
|
return null;
|
|
|
|
}
|
2015-08-21 14:07:10 +02:00
|
|
|
|
2015-12-08 18:09:24 +01:00
|
|
|
let otherDataIds = otherData ? otherData.map((data) => data.id).join() : null;
|
2015-08-17 20:52:36 +02:00
|
|
|
|
2015-08-12 13:34:41 +02:00
|
|
|
return (
|
|
|
|
<Property
|
2015-11-02 10:42:15 +01:00
|
|
|
name="other_data_key"
|
2015-10-27 17:54:35 +01:00
|
|
|
label={this.props.label}>
|
2015-08-12 13:34:41 +02:00
|
|
|
<ReactS3FineUploader
|
2016-02-05 17:06:16 +01:00
|
|
|
areAssetsDownloadable
|
|
|
|
areAssetsEditable={editable}
|
|
|
|
createBlobRoutine={{
|
2016-06-14 13:05:57 +02:00
|
|
|
url: resolveUrl('blob_otherdatas'),
|
2016-02-05 17:06:16 +01:00
|
|
|
pieceId: pieceId
|
|
|
|
}}
|
|
|
|
deleteFile={{
|
|
|
|
enabled: true,
|
|
|
|
method: 'DELETE',
|
2016-06-02 15:31:21 +02:00
|
|
|
endpoint: `${AppConstants.serverUrl}/s3/delete`,
|
2016-06-14 13:37:33 +02:00
|
|
|
customHeaders: makeCsrfHeader()
|
2016-02-05 17:06:16 +01:00
|
|
|
}}
|
|
|
|
isReadyForFormSubmission={isReadyForFormSubmission}
|
2015-08-12 13:34:41 +02:00
|
|
|
keyRoutine={{
|
2016-06-02 15:31:21 +02:00
|
|
|
url: `${AppConstants.serverUrl}/s3/key/`,
|
2015-08-12 13:34:41 +02:00
|
|
|
fileClass: 'otherdata',
|
2015-12-08 18:09:24 +01:00
|
|
|
pieceId: pieceId
|
2015-08-12 13:34:41 +02:00
|
|
|
}}
|
2016-02-05 17:06:16 +01:00
|
|
|
multiple={multiple}
|
|
|
|
onValidationFailed={onValidationFailed}
|
2015-12-08 18:09:24 +01:00
|
|
|
setIsUploadReady={setIsUploadReady}
|
2015-08-12 13:34:41 +02:00
|
|
|
session={{
|
2016-06-02 15:31:21 +02:00
|
|
|
endpoint: `${AppConstants.serverUrl}/api/blob/otherdatas/fineuploader_session/`,
|
2016-06-14 13:37:33 +02:00
|
|
|
customHeaders: makeCsrfHeader(),
|
2015-08-12 13:34:41 +02:00
|
|
|
params: {
|
2015-08-17 20:52:36 +02:00
|
|
|
'pk': otherDataIds
|
2015-08-12 13:34:41 +02:00
|
|
|
},
|
|
|
|
cors: {
|
|
|
|
expected: true,
|
|
|
|
sendCredentials: true
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
signature={{
|
2016-06-02 15:31:21 +02:00
|
|
|
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
|
2016-06-14 13:37:33 +02:00
|
|
|
customHeaders: makeCsrfHeader()
|
2015-08-12 13:34:41 +02:00
|
|
|
}}
|
2016-02-05 17:06:16 +01:00
|
|
|
submitFile={submitFile}
|
|
|
|
showErrorPrompt={showErrorPrompt}
|
|
|
|
validation={validation} />
|
2015-08-12 13:34:41 +02:00
|
|
|
</Property>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2015-10-30 17:43:20 +01:00
|
|
|
export default FurtherDetailsFileuploader;
|