2015-06-05 11:06:36 +02:00
|
|
|
'use strict';
|
2015-05-29 15:16:42 +02:00
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
|
2015-07-14 14:16:51 +02:00
|
|
|
import Button from 'react-bootstrap/lib/Button';
|
2015-05-29 15:16:42 +02:00
|
|
|
|
2015-07-14 14:16:51 +02:00
|
|
|
import Form from './form';
|
|
|
|
import Property from './property';
|
|
|
|
import InputTextAreaToggable from './input_textarea_toggable';
|
2015-05-29 15:16:42 +02:00
|
|
|
|
2015-10-12 15:25:21 +02:00
|
|
|
import AscribeSpinner from '../ascribe_spinner';
|
2015-11-03 10:39:01 +01:00
|
|
|
import AclInformation from '../ascribe_buttons/acl_information';
|
|
|
|
|
2015-07-14 14:16:51 +02:00
|
|
|
import { getLangText } from '../../utils/lang_utils.js';
|
2015-06-02 11:38:18 +02:00
|
|
|
|
2015-07-14 14:16:51 +02:00
|
|
|
let ConsignForm = React.createClass({
|
|
|
|
propTypes: {
|
|
|
|
url: React.PropTypes.string,
|
|
|
|
id: React.PropTypes.object,
|
2015-11-10 18:24:46 +01:00
|
|
|
autoFocusProperty: React.PropTypes.string,
|
2015-10-26 19:17:06 +01:00
|
|
|
email: React.PropTypes.string,
|
2015-07-14 14:16:51 +02:00
|
|
|
message: React.PropTypes.string,
|
2015-11-10 18:24:46 +01:00
|
|
|
labels: React.PropTypes.object,
|
2015-07-14 14:16:51 +02:00
|
|
|
handleSuccess: React.PropTypes.func
|
|
|
|
},
|
|
|
|
|
|
|
|
getFormData(){
|
|
|
|
return this.props.id;
|
|
|
|
},
|
2015-05-29 15:16:42 +02:00
|
|
|
|
2015-07-14 14:16:51 +02:00
|
|
|
render() {
|
2015-11-10 18:24:46 +01:00
|
|
|
const { autoFocusProperty, email, id, handleSuccess, message, labels, url } = this.props;
|
|
|
|
|
2015-05-29 15:16:42 +02:00
|
|
|
return (
|
2015-07-14 14:16:51 +02:00
|
|
|
<Form
|
|
|
|
ref='form'
|
2015-11-10 18:24:46 +01:00
|
|
|
url={url}
|
2015-07-14 14:16:51 +02:00
|
|
|
getFormData={this.getFormData}
|
|
|
|
handleSuccess={this.props.handleSuccess}
|
|
|
|
buttons={
|
|
|
|
<div className="modal-footer">
|
|
|
|
<p className="pull-right">
|
|
|
|
<Button
|
|
|
|
className="btn btn-default btn-sm ascribe-margin-1px"
|
2015-08-05 18:00:44 +02:00
|
|
|
type="submit">
|
|
|
|
{getLangText('CONSIGN')}
|
|
|
|
</Button>
|
2015-07-14 14:16:51 +02:00
|
|
|
</p>
|
|
|
|
</div>}
|
|
|
|
spinner={
|
|
|
|
<div className="modal-footer">
|
2015-10-12 15:25:21 +02:00
|
|
|
<p className="pull-right">
|
|
|
|
<AscribeSpinner color='dark-blue' size='md'/>
|
|
|
|
</p>
|
2015-07-14 14:16:51 +02:00
|
|
|
</div>}>
|
2015-11-03 10:39:01 +01:00
|
|
|
<AclInformation aim={'form'} verbs={['acl_consign']}/>
|
2015-07-14 14:16:51 +02:00
|
|
|
<Property
|
2015-11-10 18:24:46 +01:00
|
|
|
autoFocus={autoFocusProperty === 'email'}
|
2015-07-14 14:16:51 +02:00
|
|
|
name='consignee'
|
2015-11-10 18:24:46 +01:00
|
|
|
label={labels.email || getLangText('Email')}
|
|
|
|
editable={!email}
|
|
|
|
overrideForm={!!email}>
|
2015-07-14 14:16:51 +02:00
|
|
|
<input
|
|
|
|
type="email"
|
|
|
|
placeholder={getLangText('Email of the consignee')}
|
2015-11-10 18:24:46 +01:00
|
|
|
defaultValue={email}
|
2015-07-14 14:16:51 +02:00
|
|
|
required/>
|
|
|
|
</Property>
|
|
|
|
<Property
|
2015-11-10 18:24:46 +01:00
|
|
|
autoFocus={autoFocusProperty === 'message'}
|
2015-07-14 14:16:51 +02:00
|
|
|
name='consign_message'
|
2015-11-10 18:24:46 +01:00
|
|
|
label={labels.message || getLangText('Personal Message')}
|
|
|
|
editable
|
|
|
|
overrideForm>
|
2015-07-14 14:16:51 +02:00
|
|
|
<InputTextAreaToggable
|
|
|
|
rows={1}
|
2015-11-10 18:24:46 +01:00
|
|
|
defaultValue={message}
|
2015-07-14 14:16:51 +02:00
|
|
|
placeholder={getLangText('Enter a message...')}
|
2015-10-28 19:19:14 +01:00
|
|
|
required />
|
2015-07-14 14:16:51 +02:00
|
|
|
</Property>
|
|
|
|
<Property
|
|
|
|
name='password'
|
|
|
|
label={getLangText('Password')}>
|
|
|
|
<input
|
|
|
|
type="password"
|
|
|
|
placeholder={getLangText('Enter your password')}
|
|
|
|
required/>
|
|
|
|
</Property>
|
|
|
|
<hr />
|
|
|
|
</Form>
|
2015-05-29 15:16:42 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2015-10-23 14:19:44 +02:00
|
|
|
export default ConsignForm;
|