1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-09 05:06:59 +01:00
onion/js/components/ascribe_forms/form_contract_agreement.js

151 lines
5.3 KiB
JavaScript
Raw Normal View History

2015-08-18 16:24:36 +02:00
'use strict';
import React from 'react';
import { History } from 'react-router';
2015-08-18 16:24:36 +02:00
2015-08-28 16:18:10 +02:00
import ContractListActions from '../../actions/contract_list_actions';
import ContractListStore from '../../stores/contract_list_store';
2015-08-18 16:24:36 +02:00
import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions';
2015-08-18 16:24:36 +02:00
import Form from './form';
import Property from './property';
import InputTextAreaToggable from './input_textarea_toggable';
2015-08-18 16:24:36 +02:00
import ApiUrls from '../../constants/api_urls';
2015-10-12 17:55:02 +02:00
import AscribeSpinner from '../ascribe_spinner';
2015-08-18 16:24:36 +02:00
import { getLangText } from '../../utils/lang_utils';
import { mergeOptions } from '../../utils/general_utils';
2015-08-18 16:24:36 +02:00
2015-09-02 14:39:32 +02:00
let ContractAgreementForm = React.createClass({
propTypes: {
2015-08-24 11:22:44 +02:00
handleSuccess: React.PropTypes.func
},
mixins: [History],
2015-08-24 11:22:44 +02:00
getInitialState() {
2015-08-18 16:24:36 +02:00
return mergeOptions(
2015-08-28 16:18:10 +02:00
ContractListStore.getState(),
2015-08-18 16:24:36 +02:00
{
selectedContract: 0
}
);
},
componentDidMount() {
2015-08-28 16:18:10 +02:00
ContractListStore.listen(this.onChange);
ContractListActions.fetchContractList(true, false);
2015-08-18 16:24:36 +02:00
},
componentWillUnmount() {
2015-08-28 16:18:10 +02:00
ContractListStore.unlisten(this.onChange);
2015-08-18 16:24:36 +02:00
},
onChange(state) {
this.setState(state);
},
onContractChange(event){
this.setState({selectedContract: event.target.selectedIndex});
},
handleSubmitSuccess() {
let notification = 'Contract agreement send';
notification = new GlobalNotificationModel(notification, 'success', 10000);
2015-08-18 16:24:36 +02:00
GlobalNotificationActions.appendGlobalNotification(notification);
this.history.pushState(null, '/collection');
2015-08-18 16:24:36 +02:00
},
2015-09-02 14:39:32 +02:00
getFormData(){
2015-09-09 11:11:16 +02:00
return {'appendix': {'default': this.refs.form.refs.appendix.state.value}};
2015-09-02 14:39:32 +02:00
},
2015-08-18 16:24:36 +02:00
getContracts() {
2015-09-04 11:49:55 +02:00
if (this.state.contractList && this.state.contractList.length > 0) {
let contractList = this.state.contractList;
2015-08-18 16:24:36 +02:00
return (
<Property
name='contract'
label={getLangText('Contract Type')}
2015-09-22 13:20:55 +02:00
onChange={this.onContractChange}>
2015-08-18 16:24:36 +02:00
<select name="contract">
2015-09-02 14:39:32 +02:00
{contractList.map((contract, i) => {
2015-08-18 16:24:36 +02:00
return (
<option
name={i}
key={i}
2015-09-04 11:49:55 +02:00
value={ contract.id }>
2015-08-18 16:24:36 +02:00
{ contract.name }
</option>
);
})}
</select>
</Property>);
}
return null;
},
render() {
if (this.state.contractList && this.state.contractList.length > 0) {
return (
<Form
className="ascribe-form-bordered ascribe-form-wrapper"
ref='form'
url={ApiUrls.ownership_contract_agreements}
getFormData={this.getFormData}
handleSuccess={this.handleSubmitSuccess}
buttons={<button
type="submit"
2015-10-12 17:55:02 +02:00
className="btn btn-default btn-wide">
{getLangText('Send contract')}
</button>}
spinner={
2015-10-12 17:55:02 +02:00
<span className="btn btn-default btn-wide btn-spinner">
<AscribeSpinner color="dark-blue" size="md" />
</span>
}>
<div className="ascribe-form-header">
<h3>{getLangText('Contract form')}</h3>
</div>
<Property
name='signee'
label={getLangText('Artist Email')}>
<input
type="email"
placeholder={getLangText('(e.g. andy@warhol.co.uk)')}
required/>
</Property>
{this.getContracts()}
<Property
name='appendix'
checkboxLabel={getLangText('Add appendix to the contract')}
expanded={false}>
<span>{getLangText('Appendix')}</span>
{/* We're using disabled on a form here as PropertyCollapsible currently
does not support the disabled + overrideForm functionality */}
<InputTextAreaToggable
rows={1}
disabled={false}
placeholder={getLangText('This will be appended to the contract selected above')}/>
</Property>
</Form>
);
}
2015-08-18 16:24:36 +02:00
return (
<div>
<p className="text-center">
2015-09-22 14:13:04 +02:00
{getLangText('No contracts uploaded yet, please go to the ')}
2015-10-01 15:57:46 +02:00
<a href="contract_settings">{getLangText('contract settings page')}</a>
{getLangText(' and create them.')}
</p>
</div>
2015-08-18 16:24:36 +02:00
);
}
});
2015-09-02 14:39:32 +02:00
export default ContractAgreementForm;