1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-07 04:04:20 +01:00
onion/js/components/ascribe_settings/contract_settings_update_button.js

99 lines
4.0 KiB
JavaScript
Raw Normal View History

'use strict';
import React from 'react';
import { atLeastOneCreatedBlobFile } from 'react-utility-belt/es6/uploader/utils/file_validation_utils';
2015-09-16 09:47:22 +02:00
import ContractListActions from '../../actions/contract_list_actions';
import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions';
import ReactS3FineUploader from '../ascribe_uploader/react_s3_fine_uploader';
import UploadButton from '../ascribe_uploader/ascribe_upload_button/upload_button';
import AppConstants from '../../constants/application_constants';
import { ValidationTypes } from '../../constants/uploader_constants';
2016-06-14 13:37:33 +02:00
import { makeCsrfHeader } from '../../utils/csrf';
import { getLangText } from '../../utils/lang';
import { resolveUrl } from '../../utils/url_resolver';
let ContractSettingsUpdateButton = React.createClass({
2015-09-16 09:47:22 +02:00
propTypes: {
contract: React.PropTypes.object
},
submitFile(file) {
2015-09-16 09:47:22 +02:00
// override the blob with the key's value
const contract = Object.assign(this.props.contract, { blob: file.key });
2015-09-16 09:47:22 +02:00
// send it to the server
ContractListActions
.changeContract(contract)
.then((res) => {
2015-09-16 14:07:55 +02:00
// Display feedback to the user
const notification = new GlobalNotificationModel(getLangText('Contract %s successfully updated', contract.name), 'success', 5000);
2015-09-16 09:47:22 +02:00
GlobalNotificationActions.appendGlobalNotification(notification);
2015-09-16 14:07:55 +02:00
// and refresh the contract list to get the updated contracs
return ContractListActions
.fetchContractList(true)
// Also, reset the fineuploader component if fetch is successful so that the user can again 'update' his contract
.then(this.refs.fineuploader.reset)
.catch((err) => {
const notification = new GlobalNotificationModel(getLangText('Latest contract failed to load'), 'danger', 5000);
GlobalNotificationActions.appendGlobalNotification(notification);
return Promise.reject(err);
});
}, (err) => {
const notification = new GlobalNotificationModel(getLangText('Contract could not be updated'), 'danger', 5000);
2015-09-16 09:47:22 +02:00
GlobalNotificationActions.appendGlobalNotification(notification);
return Promise.reject(err);
})
.catch(console.logGlobal);
},
render() {
return (
<ReactS3FineUploader
ref='fineuploader'
fileInputElement={UploadButton({ showFileLabel: false })}
keyRoutine={{
url: `${AppConstants.serverUrl}/s3/key/`,
fileClass: 'contract'
}}
createBlobRoutine={{
url: resolveUrl('blob_contracts')
}}
validation={{
itemLimit: ValidationTypes.registerWork.itemLimit,
sizeLimit: ValidationTypes.additionalData.sizeLimit,
allowedExtensions: ['pdf']
}}
setIsUploadReady={() =>{/* So that ReactS3FineUploader is not complaining */}}
signature={{
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
2016-06-14 13:37:33 +02:00
customHeaders: makeCsrfHeader()
}}
deleteFile={{
enabled: true,
method: 'DELETE',
endpoint: `${AppConstants.serverUrl}/s3/delete`,
2016-06-14 13:37:33 +02:00
customHeaders: makeCsrfHeader()
}}
fileClassToUpload={{
singular: getLangText('UPDATE'),
plural: getLangText('UPDATE')
}}
isReadyForFormSubmission={atLeastOneCreatedBlobFile}
submitFile={this.submitFile} />
);
}
});
export default ContractSettingsUpdateButton;