1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-03 18:35:09 +01:00

translated english text to french

This commit is contained in:
Sylvain Bellemare 2015-07-03 19:08:56 +02:00
parent 22629ac09d
commit f066008ce9
44 changed files with 669 additions and 205 deletions

View File

@ -1,6 +1,8 @@
'use strict'; 'use strict';
import React from 'react'; import React from 'react';
import { getLangText } from '../../utils/lang_utils';
let AccordionList = React.createClass({ let AccordionList = React.createClass({
propTypes: { propTypes: {
@ -20,8 +22,8 @@ let AccordionList = React.createClass({
} else if(this.props.count === 0) { } else if(this.props.count === 0) {
return ( return (
<div> <div>
<p className="text-center">We could not find any works related to you...</p> <p className="text-center">{getLangText('We could not find any works related to you%s', '...')}</p>
<p className="text-center">To register one, click <a href="register_piece">here</a>!</p> <p className="text-center">{getLangText('To register one, click')} <a href="register_piece">{getLangText('here')}</a>!</p>
</div> </div>
); );
} else { } else {

View File

@ -29,7 +29,7 @@ let AccordionListItem = React.createClass({
if (this.props.content.requestAction){ if (this.props.content.requestAction){
return ( return (
<OverlayTrigger delay={500} placement="left" <OverlayTrigger delay={500} placement="left"
overlay={<Tooltip>You have actions pending in one of your editions</Tooltip>}> overlay={<Tooltip>{getLangText('You have actions pending in one of your editions')}</Tooltip>}>
<Glyphicon glyph='bell' /> <Glyphicon glyph='bell' />
</OverlayTrigger>); </OverlayTrigger>);
} }

View File

@ -146,10 +146,10 @@ let AccordionListItemTableEditions = React.createClass({
new ColumnModel( new ColumnModel(
(item) => { (item) => {
return { return {
'content': item.edition_number + ' of ' + item.num_editions 'content': item.edition_number + ' ' + getLangText('of') + ' ' + item.num_editions
}; }, }; },
'edition_number', 'edition_number',
'Edition', getLangText('Edition'),
TableItemText, TableItemText,
1, 1,
false, false,
@ -172,6 +172,7 @@ let AccordionListItemTableEditions = React.createClass({
(item) => { (item) => {
let content = item.acl; let content = item.acl;
if (item.request_action){ if (item.request_action){
// TODO should request be translated?
content = [item.request_action + ' request']; content = [item.request_action + ' request'];
} }
return { return {
@ -193,7 +194,7 @@ let AccordionListItemTableEditions = React.createClass({
<AccordionListItemTableToggle <AccordionListItemTableToggle
className="ascribe-accordion-list-table-toggle" className="ascribe-accordion-list-table-toggle"
onClick={this.toggleTable} onClick={this.toggleTable}
message={show && typeof editionsForPiece !== 'undefined' ? <span><span className="glyphicon glyphicon-menu-up" aria-hidden="true" style={{top: 2}}></span> Hide editions</span> : <span><span className="glyphicon glyphicon-menu-down" aria-hidden="true" style={{top: 2}}></span> Show editions {show && typeof editionsForPiece === 'undefined' ? loadingSpinner : null}</span>} /> message={show && typeof editionsForPiece !== 'undefined' ? <span><span className="glyphicon glyphicon-menu-up" aria-hidden="true" style={{top: 2}}></span> {getLangText('Hide editions')}</span> : <span><span className="glyphicon glyphicon-menu-down" aria-hidden="true" style={{top: 2}}></span> {getLangText('Show editions')} {show && typeof editionsForPiece === 'undefined' ? loadingSpinner : null}</span>} />
<AccordionListItemTable <AccordionListItemTable
parentId={this.props.parentId} parentId={this.props.parentId}
itemList={editionsForPiece} itemList={editionsForPiece}

View File

@ -1,6 +1,8 @@
'use strict'; 'use strict';
import React from 'react'; import React from 'react';
import { getLangText } from '../../utils/lang_utils.js';
let AccordionListItemTableToggle = React.createClass({ let AccordionListItemTableToggle = React.createClass({
propTypes: { propTypes: {

View File

@ -13,6 +13,9 @@ import AppConstants from '../../constants/application_constants';
import GlobalNotificationModel from '../../models/global_notification_model'; import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions'; import GlobalNotificationActions from '../../actions/global_notification_actions';
import { getLangText } from '../../utils/lang_utils.js'
let AclButton = React.createClass({ let AclButton = React.createClass({
propTypes: { propTypes: {
action: React.PropTypes.oneOf(AppConstants.aclList).isRequired, action: React.PropTypes.oneOf(AppConstants.aclList).isRequired,
@ -26,39 +29,39 @@ let AclButton = React.createClass({
actionProperties(){ actionProperties(){
if (this.props.action === 'consign'){ if (this.props.action === 'consign'){
return { return {
title: 'Consign artwork', title: getLangText('Consign artwork'),
tooltip: 'Have someone else sell the artwork', tooltip: getLangText('Have someone else sell the artwork'),
form: <ConsignForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>, form: <ConsignForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>,
handleSuccess: this.showNotification handleSuccess: this.showNotification
}; };
} }
if (this.props.action === 'unconsign'){ if (this.props.action === 'unconsign'){
return { return {
title: 'Unconsign artwork', title: getLangText('Unconsign artwork'),
tooltip: 'Have the owner manage his sales again', tooltip: getLangText('Have the owner manage his sales again'),
form: <UnConsignForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>, form: <UnConsignForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>,
handleSuccess: this.showNotification handleSuccess: this.showNotification
}; };
}else if (this.props.action === 'transfer') { }else if (this.props.action === 'transfer') {
return { return {
title: 'Transfer artwork', title: getLangText('Transfer artwork'),
tooltip: 'Transfer the ownership of the artwork', tooltip: getLangText('Transfer the ownership of the artwork'),
form: <TransferForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>, form: <TransferForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>,
handleSuccess: this.showNotification handleSuccess: this.showNotification
}; };
} }
else if (this.props.action === 'loan'){ else if (this.props.action === 'loan'){
return { return {
title: 'Loan artwork', title: getLangText('Loan artwork'),
tooltip: 'Loan your artwork for a limited period of time', tooltip: getLangText('Loan your artwork for a limited period of time'),
form: <LoanForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>, form: <LoanForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>,
handleSuccess: this.showNotification handleSuccess: this.showNotification
}; };
} }
else if (this.props.action === 'share'){ else if (this.props.action === 'share'){
return { return {
title: 'Share artwork', title: getLangText('Share artwork'),
tooltip: 'Share the artwork', tooltip: getLangText('Share the artwork'),
form: <ShareForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>, form: <ShareForm currentUser={ this.props.currentUser } editions={ this.props.editions }/>,
handleSuccess: this.showNotification handleSuccess: this.showNotification
}; };
@ -75,6 +78,7 @@ let AclButton = React.createClass({
return ( return (
<ModalWrapper <ModalWrapper
button={ button={
// TODO translate hidden?
<button className={shouldDisplay ? 'btn btn-default btn-sm ' : 'hidden'}> <button className={shouldDisplay ? 'btn btn-default btn-sm ' : 'hidden'}>
{this.props.action.toUpperCase()} {this.props.action.toUpperCase()}
</button> </button>

View File

@ -3,6 +3,7 @@
import React from 'react'; import React from 'react';
import AppConstants from '../../constants/application_constants'; import AppConstants from '../../constants/application_constants';
import { getLangText } from '../../utils/lang_utils.js'
let ButtonSubmitOrClose = React.createClass({ let ButtonSubmitOrClose = React.createClass({
propTypes: { propTypes: {
@ -22,7 +23,7 @@ let ButtonSubmitOrClose = React.createClass({
return ( return (
<div className="modal-footer"> <div className="modal-footer">
<button type="submit" className="btn btn-ascribe-inv">{this.props.text}</button> <button type="submit" className="btn btn-ascribe-inv">{this.props.text}</button>
<button className="btn btn-ascribe-inv" onClick={this.props.onClose}>CLOSE</button> <button className="btn btn-ascribe-inv" onClick={this.props.onClose}>{getLangText('CLOSE')}</button>
</div> </div>
); );
} }

View File

@ -13,6 +13,7 @@ import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions'; import GlobalNotificationActions from '../../actions/global_notification_actions';
import { getAvailableAcls } from '../../utils/acl_utils'; import { getAvailableAcls } from '../../utils/acl_utils';
import { getLangText } from '../../utils/lang_utils.js'
import EditionListActions from '../../actions/edition_list_actions'; import EditionListActions from '../../actions/edition_list_actions';
@ -42,11 +43,11 @@ let DeleteButton = React.createClass({
if (availableAcls.indexOf('delete') > -1) { if (availableAcls.indexOf('delete') > -1) {
content = <EditionDeleteForm editions={ this.props.editions }/>; content = <EditionDeleteForm editions={ this.props.editions }/>;
btnDelete = <Button bsStyle="danger" className="btn-delete" bsSize="small">DELETE</Button>; btnDelete = <Button bsStyle="danger" className="btn-delete" bsSize="small">{getLangText('DELETE')}</Button>;
} }
else if (availableAcls.indexOf('del_from_collection') > -1){ else if (availableAcls.indexOf('del_from_collection') > -1){
content = <EditionRemoveFromCollectionForm editions={ this.props.editions }/>; content = <EditionRemoveFromCollectionForm editions={ this.props.editions }/>;
btnDelete = <Button bsStyle="danger" className="btn-delete" bsSize="small">REMOVE FROM COLLECTION</Button>; btnDelete = <Button bsStyle="danger" className="btn-delete" bsSize="small">{getLangText('REMOVE FROM COLLECTION')}</Button>;
} }
else{ else{
return null; return null;
@ -55,8 +56,8 @@ let DeleteButton = React.createClass({
<ModalWrapper <ModalWrapper
button={ btnDelete } button={ btnDelete }
handleSuccess={ this.showNotification } handleSuccess={ this.showNotification }
title='Remove Edition' title={getLangText('Remove Edition')}
tooltip='Click to remove edition'> tooltip={getLangText('Click to remove edition')}>
{ content } { content }
</ModalWrapper> </ModalWrapper>
); );

View File

@ -6,6 +6,8 @@ import CollapsibleMixin from 'react-bootstrap/lib/CollapsibleMixin';
import classNames from 'classnames'; import classNames from 'classnames';
import { getLangText } from '../../utils/lang_utils.js'
const CollapsibleParagraph = React.createClass({ const CollapsibleParagraph = React.createClass({
@ -41,7 +43,7 @@ const CollapsibleParagraph = React.createClass({
render() { render() {
let styles = this.getCollapsibleClassSet(); let styles = this.getCollapsibleClassSet();
let text = this.isExpanded() ? '[hide]' : '[show]'; let text = this.isExpanded() ? '[' + getLangText('hide') + ']' : '[' + getLangText('show') + ']';
if(this.props.show) { if(this.props.show) {
return ( return (
<div className="ascribe-detail-header"> <div className="ascribe-detail-header">

View File

@ -7,6 +7,7 @@ import FormMixin from '../../mixins/form_mixin';
import InputText from './input_text'; import InputText from './input_text';
import InputTextArea from './input_textarea'; import InputTextArea from './input_textarea';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let ConsignForm = React.createClass({ let ConsignForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -29,12 +30,12 @@ let ConsignForm = React.createClass({
let title = this.getTitlesString().join(''); let title = this.getTitlesString().join('');
let username = this.props.currentUser.username; let username = this.props.currentUser.username;
let message = let message =
`Hi, `${getLangText('Hi')},
I consign : ${getLangText('I consign')} :
${title}to you. ${title}${getLangText('to you')}.
Truly yours, ${getLangText('Truly yours')},
${username}`; ${username}`;
return ( return (
@ -43,7 +44,7 @@ ${username}`;
<input className="invisible" type="password" name="fake_password"/> <input className="invisible" type="password" name="fake_password"/>
<InputText <InputText
ref="consignee" ref="consignee"
placeHolder="Consignee email" placeHolder={getLangText('Consignee email')}
required="required" required="required"
type="email" type="email"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
@ -54,12 +55,12 @@ ${username}`;
/> />
<InputText <InputText
ref="password" ref="password"
placeHolder="Password" placeHolder={getLangText('Password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="CONSIGN" text={getLangText('CONSIGN')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -5,6 +5,7 @@ import React from 'react';
import requests from '../../utils/requests'; import requests from '../../utils/requests';
import ApiUrls from '../../constants/api_urls'; import ApiUrls from '../../constants/api_urls';
import FormMixin from '../../mixins/form_mixin'; import FormMixin from '../../mixins/form_mixin';
import { getLangText } from '../../utils/lang_utils';
let EditionDeleteForm = React.createClass({ let EditionDeleteForm = React.createClass({
@ -20,11 +21,11 @@ let EditionDeleteForm = React.createClass({
renderForm () { renderForm () {
return ( return (
<div className="modal-body"> <div className="modal-body">
<p>Are you sure you would like to permanently delete this edition&#63;</p> <p>{getLangText('Are you sure you would like to permanently delete this edition')}&#63;</p>
<p>This is an irrevocable action.</p> <p>{getLangText('This is an irrevocable action%s', '.')}</p>
<div className="modal-footer"> <div className="modal-footer">
<button type="submit" className="btn btn-ascribe-inv" onClick={this.submit}>YES, DELETE</button> <button type="submit" className="btn btn-ascribe-inv" onClick={this.submit}>{getLangText('YES, DELETE')}</button>
<button className="btn btn-ascribe" onClick={this.props.onRequestHide}>CLOSE</button> <button className="btn btn-ascribe" onClick={this.props.onRequestHide}>{getLangText('CLOSE')}</button>
</div> </div>
</div> </div>
); );

View File

@ -13,6 +13,8 @@ import InputTextArea from './input_textarea';
import OwnershipFetcher from '../../fetchers/ownership_fetcher'; import OwnershipFetcher from '../../fetchers/ownership_fetcher';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let LoanForm = React.createClass({ let LoanForm = React.createClass({
getInitialState() { getInitialState() {
@ -74,20 +76,20 @@ let LoanForm = React.createClass({
let title = this.getTitlesString().join(''); let title = this.getTitlesString().join('');
let username = this.props.currentUser.username; let username = this.props.currentUser.username;
let message = let message =
`Hi, `${getLangText('Hi')},
I loan : ${getLangText('I loan')} :
${title}to you. ${title}${getLangText('to you')}.
Truly yours, ${getLangText('Truly yours')},
${username}`; ${username}`;
let contract = <InputHidden ref="terms" value="True"/>; let contract = <InputHidden ref="terms" value="True"/>;
if (this.state.loaneeHasContract){ if (this.state.loaneeHasContract){
let label = (<div> let label = (<div>
I agree to the&nbsp; {getLangText('I agree to the')}&nbsp;
<a href={this.state.contract_url} target="_blank"> <a href={this.state.contract_url} target="_blank">
terms of {this.refs.loanee.state.value} {getLangText('terms of')} {this.refs.loanee.state.value}
</a> </a>
</div>); </div>);
contract = (<InputCheckbox contract = (<InputCheckbox
@ -103,14 +105,14 @@ ${username}`;
<input className="invisible" type="password" name="fake_password"/> <input className="invisible" type="password" name="fake_password"/>
<InputText <InputText
ref="loanee" ref="loanee"
placeHolder="Loanee email" placeHolder={getLangText('Loanee email')}
required="required" required="required"
type="email" type="email"
submitted={this.state.submitted} submitted={this.state.submitted}
onBlur={this.handleLoanEmailBlur}/> onBlur={this.handleLoanEmailBlur}/>
<InputText <InputText
ref="gallery_name" ref="gallery_name"
placeHolder="Gallery/exhibition (optional)" placeHolder={getLangText('Gallery/exhibition (optional)')}
required="" required=""
type="text" type="text"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
@ -118,12 +120,12 @@ ${username}`;
<div className="col-xs-6"> <div className="col-xs-6">
<InputDate <InputDate
ref="startdate" ref="startdate"
placeholderText="Loan start date" /> placeholderText={getLangText('Loan start date')} />
</div> </div>
<div className="col-xs-6 form-group"> <div className="col-xs-6 form-group">
<InputDate <InputDate
ref="enddate" ref="enddate"
placeholderText="Loan end date" /> placeholderText={getLangText('Loan end date')} />
</div> </div>
</div> </div>
<InputTextArea <InputTextArea
@ -133,13 +135,13 @@ ${username}`;
/> />
<InputText <InputText
ref="password" ref="password"
placeHolder="Password" placeHolder={getLangText('Password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
{contract} {contract}
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="LOAN" text={getLangText('LOAN')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -9,6 +9,7 @@ import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import SignupModal from '../ascribe_modal/modal_signup'; import SignupModal from '../ascribe_modal/modal_signup';
import PasswordResetRequestModal from '../ascribe_modal/modal_password_request_reset'; import PasswordResetRequestModal from '../ascribe_modal/modal_password_request_reset';
import { getLangText } from '../../utils/lang_utils.js'
let LoginForm = React.createClass({ let LoginForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -31,28 +32,28 @@ let LoginForm = React.createClass({
<input className="invisible" type="password" name="fake_password"/> <input className="invisible" type="password" name="fake_password"/>
<InputText <InputText
ref="email" ref="email"
placeHolder="Email" placeHolder={getLangText('Email')}
required="required" required="required"
type="email" type="email"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<InputText <InputText
ref="password" ref="password"
placeHolder="Password" placeHolder={getLangText('Password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<div> <div>
Forgot your password&#63; {getLangText('Forgot your password')}&#63;
<PasswordResetRequestModal <PasswordResetRequestModal
button={<a className="button" href="#"> Reset password</a>}/> button={<a className="button" href="#"> {getLangText('Reset password')}</a>}/>
</div> </div>
<div> <div>
Not a member yet&#63; {getLangText('Not a member yet')}&#63;
<SignupModal <SignupModal
button={<a className="button" href="#"> Sign up</a>}/> button={<a className="button" href="#"> {getLangText('Sign up')}</a>}/>
</div> </div>
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="LOGIN" text={getLangText('LOGIN')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -6,6 +6,7 @@ import apiUrls from '../../constants/api_urls';
import FormMixin from '../../mixins/form_mixin'; import FormMixin from '../../mixins/form_mixin';
import InputText from './input_text'; import InputText from './input_text';
import ButtonSubmit from '../ascribe_buttons/button_submit'; import ButtonSubmit from '../ascribe_buttons/button_submit';
import { getLangText } from '../../utils/lang_utils.js'
let PasswordResetForm = React.createClass({ let PasswordResetForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -29,18 +30,18 @@ let PasswordResetForm = React.createClass({
<div>Reset the password for {this.props.email}:</div> <div>Reset the password for {this.props.email}:</div>
<InputText <InputText
ref="password" ref="password"
placeHolder="Choose a password" placeHolder={getLangText('Choose a password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<InputText <InputText
ref="password_confirm" ref="password_confirm"
placeHolder="Confirm password" placeHolder={getLangText('Confirm password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<ButtonSubmit <ButtonSubmit
text="RESET PASSWORD" text={getLangText('RESET PASSWORD')}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>
); );

View File

@ -6,6 +6,7 @@ import apiUrls from '../../constants/api_urls';
import FormMixin from '../../mixins/form_mixin'; import FormMixin from '../../mixins/form_mixin';
import InputText from './input_text'; import InputText from './input_text';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let PasswordResetRequestForm = React.createClass({ let PasswordResetRequestForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -25,12 +26,12 @@ let PasswordResetRequestForm = React.createClass({
<form id="request_reset_password_modal_content" role="form" onSubmit={this.submit}> <form id="request_reset_password_modal_content" role="form" onSubmit={this.submit}>
<InputText <InputText
ref="email" ref="email"
placeHolder="Email" placeHolder={getLangText('Email')}
required="required" required="required"
type="email" type="email"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="RESET PASSWORD" text={getLangText('RESET PASSWORD')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -3,6 +3,7 @@
import React from 'react'; import React from 'react';
import requests from '../../utils/requests'; import requests from '../../utils/requests';
import { getLangText } from '../../utils/lang_utils.js'
import apiUrls from '../../constants/api_urls'; import apiUrls from '../../constants/api_urls';
@ -46,7 +47,7 @@ let PieceExtraDataForm = React.createClass({
rows={3} rows={3}
editable={this.props.editable} editable={this.props.editable}
defaultValue={defaultValue} defaultValue={defaultValue}
placeholder={'Fill in ' + this.props.title} placeholder={getLangText('Fill in%s', ' ') + this.props.title}
required/> required/>
</Property> </Property>
<Property hidden={true} name='bitcoin_id'> <Property hidden={true} name='bitcoin_id'>

View File

@ -2,6 +2,7 @@
import React from 'react'; import React from 'react';
import { getLangText } from '../../utils/lang_utils.js'
import requests from '../../utils/requests'; import requests from '../../utils/requests';
import apiUrls from '../../constants/api_urls'; import apiUrls from '../../constants/api_urls';
import FormMixin from '../../mixins/form_mixin'; import FormMixin from '../../mixins/form_mixin';
@ -20,11 +21,11 @@ let EditionRemoveFromCollectionForm = React.createClass({
renderForm () { renderForm () {
return ( return (
<div className="modal-body"> <div className="modal-body">
<p>Are you sure you would like to remove these editions from your collection&#63;</p> <p>{getLangText('Are you sure you would like to remove these editions from your collection')}&#63;</p>
<p>This is an irrevocable action.</p> <p>{getLangText('This is an irrevocable action%s', '.')}</p>
<div className="modal-footer"> <div className="modal-footer">
<button type="submit" className="btn btn-ascribe-inv" onClick={this.submit}>YES, REMOVE</button> <button type="submit" className="btn btn-ascribe-inv" onClick={this.submit}>{getLangText('YES, REMOVE')}</button>
<button className="btn btn-ascribe" onClick={this.props.onRequestHide}>CLOSE</button> <button className="btn btn-ascribe" onClick={this.props.onRequestHide}>{getLangText('CLOSE')}</button>
</div> </div>
</div> </div>
); );

View File

@ -8,6 +8,7 @@ import apiUrls from '../../constants/api_urls';
import FormMixin from '../../mixins/form_mixin'; import FormMixin from '../../mixins/form_mixin';
import AppConstants from '../../constants/application_constants'; import AppConstants from '../../constants/application_constants';
import { getLangText } from '../../utils/lang_utils.js'
let RequestActionForm = React.createClass({ let RequestActionForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -54,10 +55,10 @@ let RequestActionForm = React.createClass({
let buttons = ( let buttons = (
<span> <span>
<span> <span>
<div id="request_accept" onClick={this.handleRequest} className='btn btn-default btn-sm ascribe-margin-1px'>ACCEPT</div> <div id="request_accept" onClick={this.handleRequest} className='btn btn-default btn-sm ascribe-margin-1px'>{getLangText('ACCEPT')}</div>
</span> </span>
<span> <span>
<div id="request_deny" onClick={this.handleRequest} className='btn btn-danger btn-delete btn-sm ascribe-margin-1px'>REJECT</div> <div id="request_deny" onClick={this.handleRequest} className='btn btn-danger btn-delete btn-sm ascribe-margin-1px'>{getLangText('REJECT')}</div>
</span> </span>
</span> </span>
); );
@ -71,7 +72,7 @@ let RequestActionForm = React.createClass({
return ( return (
<Alert bsStyle='warning'> <Alert bsStyle='warning'>
<div style={{textAlign: 'center'}}> <div style={{textAlign: 'center'}}>
<div>{ edition.owner } requests you { edition.request_action } this edition.&nbsp;&nbsp;</div> <div>{ edition.owner } {getFormData('requests you')} { edition.request_action } {getLangText('this edition%s', '.')}&nbsp;&nbsp;</div>
{buttons} {buttons}
</div> </div>
</Alert> </Alert>

View File

@ -7,6 +7,8 @@ import FormMixin from '../../mixins/form_mixin';
import InputText from './input_text'; import InputText from './input_text';
import InputTextArea from './input_textarea'; import InputTextArea from './input_textarea';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let ShareForm = React.createClass({ let ShareForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -27,19 +29,19 @@ let ShareForm = React.createClass({
let title = this.getTitlesString().join(''); let title = this.getTitlesString().join('');
let username = this.props.currentUser.username; let username = this.props.currentUser.username;
let message = let message =
`Hi, `${getLangText('Hi')},
I am sharing : ${getLangText('I am sharing')} :
${title}with you. ${title}${getLangText('with you')}.
Truly yours, ${getLangText('Truly yours')},
${username}`; ${username}`;
return ( return (
<form id="share_modal_content" role="form" key="share_modal_content" onSubmit={this.submit}> <form id="share_modal_content" role="form" key="share_modal_content" onSubmit={this.submit}>
<InputText <InputText
ref="share_emails" ref="share_emails"
placeHolder="Comma separated emails" placeHolder={getLangText('Comma separated emails')}
required="required" required="required"
type="text" type="text"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
@ -49,7 +51,7 @@ ${username}`;
required="" required=""
/> />
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="SHARE" text={getLangText('SHARE')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -7,6 +7,7 @@ import FormMixin from '../../mixins/form_mixin';
import InputText from './input_text'; import InputText from './input_text';
import InputCheckbox from './input_checkbox'; import InputCheckbox from './input_checkbox';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let SignupForm = React.createClass({ let SignupForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -32,43 +33,43 @@ let SignupForm = React.createClass({
<input className="invisible" type="password" name="fake_password"/> <input className="invisible" type="password" name="fake_password"/>
<InputText <InputText
ref="email" ref="email"
placeHolder="Email" placeHolder={getLangText('Email')}
required="required" required="required"
type="email" type="email"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<InputText <InputText
ref="password" ref="password"
placeHolder="Choose a password" placeHolder={getLangText('Choose a password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<InputText <InputText
ref="password_confirm" ref="password_confirm"
placeHolder="Confirm password" placeHolder={getLangText('Confirm password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<div> <div>
Your password must be at least 10 characters. {getLangText('Your password must be at least 10 characters')}.
This password is securing your digital property like a bank account. {getLangText('This password is securing your digital property like a bank account')}.
Store it in a safe place! {getLangText('Store it in a safe place')}!
</div> </div>
<InputCheckbox <InputCheckbox
ref="terms" ref="terms"
required="required" required="required"
label={ label={
<div> <div>
I agree to the&nbsp; {getLangText('I agree to the')}&nbsp;
<a href="/terms" target="_blank"> Terms of Service</a> <a href="/terms" target="_blank"> {getLangText('Terms of Service')}</a>
</div>}/> </div>}/>
<InputText <InputText
ref="promo_code" ref="promo_code"
placeHolder="Promocode (Optional)" placeHolder={getLangText('Promocode (Optional)')}
required="" required=""
type="text" type="text"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="JOIN US" text={getLangText('JOIN US')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -7,7 +7,7 @@ import FormMixin from '../../mixins/form_mixin';
import InputText from './input_text'; import InputText from './input_text';
import InputTextArea from './input_textarea'; import InputTextArea from './input_textarea';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let TransferForm = React.createClass({ let TransferForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -29,12 +29,12 @@ let TransferForm = React.createClass({
let title = this.getTitlesString().join(''); let title = this.getTitlesString().join('');
let username = this.props.currentUser.username; let username = this.props.currentUser.username;
let message = let message =
`Hi, `${getLangText('Hi')},
I transfer ownership of : ${getLangText('I transfer ownership of')} :
${title}to you. ${title}${getLangText('to you')}.
Truly yours, ${getLangText('Truly yours')},
${username}`; ${username}`;
return ( return (
@ -43,7 +43,7 @@ ${username}`;
<input className="invisible" type="password" name="fake_password"/> <input className="invisible" type="password" name="fake_password"/>
<InputText <InputText
ref="transferee" ref="transferee"
placeHolder="Transferee email" placeHolder={getLangText('Transferee email')}
required="required" required="required"
type="email" type="email"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
@ -54,7 +54,7 @@ ${username}`;
/> />
<InputText <InputText
ref="password" ref="password"
placeHolder="Password" placeHolder={getLangText('Password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted}/> submitted={this.state.submitted}/>
@ -63,7 +63,7 @@ ${username}`;
They cannot be edited after the transfer. They cannot be edited after the transfer.
</div> </div>
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="TRANSFER" text={getLangText('TRANSFER')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -7,6 +7,7 @@ import FormMixin from '../../mixins/form_mixin';
import InputText from './input_text'; import InputText from './input_text';
import InputTextArea from './input_textarea'; import InputTextArea from './input_textarea';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let UnConsignForm = React.createClass({ let UnConsignForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -27,12 +28,12 @@ let UnConsignForm = React.createClass({
let title = this.getTitlesString().join(''); let title = this.getTitlesString().join('');
let username = this.props.currentUser.username; let username = this.props.currentUser.username;
let message = let message =
`Hi, `${getLangText('Hi')},
I un-consign: ${getLangText('I un-consign')}:
${title}from you. ${title}${getLangText('from you')}.
Truly yours, ${getLangText('Truly yours')},
${username}`; ${username}`;
return ( return (
@ -45,12 +46,12 @@ ${username}`;
required="" /> required="" />
<InputText <InputText
ref="password" ref="password"
placeHolder="Password" placeHolder={getLangText('Password')}
required="required" required="required"
type="password" type="password"
submitted={this.state.submitted} /> submitted={this.state.submitted} />
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="UNCONSIGN" text={getLangText('UNCONSIGN')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -6,6 +6,7 @@ import ApiUrls from '../../constants/api_urls';
import FormMixin from '../../mixins/form_mixin'; import FormMixin from '../../mixins/form_mixin';
import InputTextArea from './input_textarea'; import InputTextArea from './input_textarea';
import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close'; import ButtonSubmitOrClose from '../ascribe_buttons/button_submit_close';
import { getLangText } from '../../utils/lang_utils.js'
let UnConsignRequestForm = React.createClass({ let UnConsignRequestForm = React.createClass({
mixins: [FormMixin], mixins: [FormMixin],
@ -25,11 +26,11 @@ let UnConsignRequestForm = React.createClass({
let title = this.props.edition.title; let title = this.props.edition.title;
let username = this.props.currentUser.username; let username = this.props.currentUser.username;
let message = let message =
`Hi, `${getLangText('Hi')},
I request you to un-consign \" ${title} \". ${getLangText('I request you to un-consign')} \" ${title} \".
Truly yours, ${getLangText('Truly yours')},
${username}`; ${username}`;
return ( return (
@ -39,7 +40,7 @@ ${username}`;
defaultValue={message} defaultValue={message}
required="" /> required="" />
<ButtonSubmitOrClose <ButtonSubmitOrClose
text="UNCONSIGN REQUEST" text={getLangText('UNCONSIGN REQUEST')}
onClose={this.props.onRequestHide} onClose={this.props.onRequestHide}
submitted={this.state.submitted} /> submitted={this.state.submitted} />
</form> </form>

View File

@ -7,11 +7,12 @@ import LoginForm from '../ascribe_forms/form_login';
import GlobalNotificationModel from '../../models/global_notification_model'; import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions'; import GlobalNotificationActions from '../../actions/global_notification_actions';
import { getLangText } from '../../utils/lang_utils.js'
let LoginModal = React.createClass({ let LoginModal = React.createClass({
handleLoginSuccess(){ handleLoginSuccess(){
this.props.handleSuccess(); this.props.handleSuccess();
let notificationText = 'Login successful'; let notificationText = getLangText('Login successful');
let notification = new GlobalNotificationModel(notificationText, 'success'); let notification = new GlobalNotificationModel(notificationText, 'success');
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);
}, },
@ -20,9 +21,9 @@ let LoginModal = React.createClass({
return ( return (
<ModalWrapper <ModalWrapper
button={this.props.button} button={this.props.button}
title='Log in to ascribe' title={getLangText('Log in to ascribe')}
handleSuccess={this.handleLoginSuccess} handleSuccess={this.handleLoginSuccess}
tooltip='Log in to ascribe'> tooltip={getLangText('Log in to ascribe')}>
<LoginForm /> <LoginForm />
</ModalWrapper> </ModalWrapper>
); );

View File

@ -7,10 +7,11 @@ import PasswordResetRequestForm from '../ascribe_forms/form_password_reset_reque
import GlobalNotificationModel from '../../models/global_notification_model'; import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions'; import GlobalNotificationActions from '../../actions/global_notification_actions';
import { getLangText } from '../../utils/lang_utils.js'
let PasswordResetRequestModal = React.createClass({ let PasswordResetRequestModal = React.createClass({
handleResetSuccess(){ handleResetSuccess(){
let notificationText = 'Request succesfully sent, check your email'; let notificationText = getLangText('Request successfully sent, check your email');
let notification = new GlobalNotificationModel(notificationText, 'success', 50000); let notification = new GlobalNotificationModel(notificationText, 'success', 50000);
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);
}, },
@ -18,9 +19,9 @@ let PasswordResetRequestModal = React.createClass({
return ( return (
<ModalWrapper <ModalWrapper
button={this.props.button} button={this.props.button}
title='Reset your password' title={getLangText('Reset your password')}
handleSuccess={this.handleResetSuccess} handleSuccess={this.handleResetSuccess}
tooltip='Reset your password'> tooltip={getLangText('Reset your password')}>
<PasswordResetRequestForm /> <PasswordResetRequestForm />
</ModalWrapper> </ModalWrapper>
); );

View File

@ -7,10 +7,11 @@ import SignupForm from '../ascribe_forms/form_signup';
import GlobalNotificationModel from '../../models/global_notification_model'; import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions'; import GlobalNotificationActions from '../../actions/global_notification_actions';
import { getLangText } from '../../utils/lang_utils.js'
let SignupModal = React.createClass({ let SignupModal = React.createClass({
handleSignupSuccess(response){ handleSignupSuccess(response){
let notificationText = 'We sent an email to your address ' + response.user.email + ', please confirm.'; let notificationText = getLangText('We sent an email to your address') + ' ' + response.user.email + ', ' + getLangText('please confirm') + '.';
let notification = new GlobalNotificationModel(notificationText, 'success', 50000); let notification = new GlobalNotificationModel(notificationText, 'success', 50000);
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);
}, },
@ -19,9 +20,9 @@ let SignupModal = React.createClass({
return ( return (
<ModalWrapper <ModalWrapper
button={this.props.button} button={this.props.button}
title='Create an account' title={getLangText('Create an account')}
handleSuccess={this.handleSignupSuccess} handleSuccess={this.handleSignupSuccess}
tooltip='Sign up to ascribe'> tooltip={getLangText('Sign up to ascribe')}>
<SignupForm /> <SignupForm />
</ModalWrapper> </ModalWrapper>
); );

View File

@ -15,7 +15,7 @@ import AclButtonList from '../ascribe_buttons/acl_button_list';
import { getAvailableAcls } from '../../utils/acl_utils'; import { getAvailableAcls } from '../../utils/acl_utils';
import { getLangText } from '../../utils/lang_utils.js'
let PieceListBulkModal = React.createClass({ let PieceListBulkModal = React.createClass({
propTypes: { propTypes: {
@ -97,7 +97,7 @@ let PieceListBulkModal = React.createClass({
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<span <span
className="piece-list-bulk-modal-clear-all" className="piece-list-bulk-modal-clear-all"
onClick={this.clearAllSelections}>clear all</span> onClick={this.clearAllSelections}>{getLangText('clear all')}</span>
</div> </div>
</div> </div>
<p></p> <p></p>

View File

@ -1,6 +1,7 @@
'use strict'; 'use strict';
import React from 'react'; import React from 'react';
import { getLangText } from '../../utils/lang_utils.js'
let PieceListBulkModalSelectedEditionsWidget = React.createClass({ let PieceListBulkModalSelectedEditionsWidget = React.createClass({
propTypes: { propTypes: {
@ -9,8 +10,8 @@ let PieceListBulkModalSelectedEditionsWidget = React.createClass({
render() { render() {
return ( return (
<span className={this.props.numberOfSelectedEditions < 1 ? 'hidden' : ''}> <span className={this.props.numberOfSelectedEditions < 1 ? getLangText('hidden') : ''}>
{this.props.numberOfSelectedEditions} Editions selected {this.props.numberOfSelectedEditions} {getLangText('Editions selected')}
</span> </span>
); );
} }

View File

@ -7,6 +7,7 @@ import Glyphicon from 'react-bootstrap/lib/Glyphicon';
import ButtonLink from 'react-router-bootstrap/lib/ButtonLink'; import ButtonLink from 'react-router-bootstrap/lib/ButtonLink';
import Row from 'react-bootstrap/lib/Row'; import Row from 'react-bootstrap/lib/Row';
import Col from 'react-bootstrap/lib/Col'; import Col from 'react-bootstrap/lib/Col';
import { getLangText } from '../../utils/lang_utils';
let PieceListToolbar = React.createClass({ let PieceListToolbar = React.createClass({
@ -32,7 +33,7 @@ let PieceListToolbar = React.createClass({
<Input <Input
type='text' type='text'
ref="search" ref="search"
placeholder="Search..." placeholder={getLangText('Search%s', '...')}
onChange={this.searchFor} onChange={this.searchFor}
addonAfter={searchIcon} /> addonAfter={searchIcon} />
</span> </span>

View File

@ -5,6 +5,7 @@ import React from 'react';
import Glyphicon from 'react-bootstrap/lib/Glyphicon'; import Glyphicon from 'react-bootstrap/lib/Glyphicon';
import DropdownButton from 'react-bootstrap/lib/DropdownButton'; import DropdownButton from 'react-bootstrap/lib/DropdownButton';
import MenuItem from 'react-bootstrap/lib/MenuItem'; import MenuItem from 'react-bootstrap/lib/MenuItem';
import { getLangText } from '../../utils/lang_utils.js'
let PieceListToolbarFilterWidgetFilter = React.createClass({ let PieceListToolbarFilterWidgetFilter = React.createClass({
render() { render() {
@ -13,16 +14,16 @@ let PieceListToolbarFilterWidgetFilter = React.createClass({
return ( return (
<DropdownButton title={filterIcon}> <DropdownButton title={filterIcon}>
<li style={{'textAlign': 'center'}}> <li style={{'textAlign': 'center'}}>
<em>Show Pieces that:</em> <em>{getLangText('Show Pieces that')}:</em>
</li> </li>
<MenuItem eventKey='1'> <MenuItem eventKey='1'>
<div className="checkbox"> <div className="checkbox">
I can transfer <input type="checkbox" /> {getLangText('I can transfer')} <input type="checkbox" />
</div> </div>
</MenuItem> </MenuItem>
<MenuItem eventKey='2'> <MenuItem eventKey='2'>
<div className="checkbox"> <div className="checkbox">
I can consign <input type="checkbox" /> {getLangText('I can consign')} <input type="checkbox" />
</div> </div>
</MenuItem> </MenuItem>
</DropdownButton> </DropdownButton>

View File

@ -4,6 +4,7 @@ import React from 'react';
import FileDragAndDropDialog from './file_drag_and_drop_dialog'; import FileDragAndDropDialog from './file_drag_and_drop_dialog';
import FileDragAndDropPreviewIterator from './file_drag_and_drop_preview_iterator'; import FileDragAndDropPreviewIterator from './file_drag_and_drop_preview_iterator';
import { getLangText } from '../../utils/lang_utils.js';
// Taken from: https://github.com/fedosejev/react-file-drag-and-drop // Taken from: https://github.com/fedosejev/react-file-drag-and-drop
@ -152,8 +153,7 @@ let FileDragAndDrop = React.createClass({
<FileDragAndDropDialog <FileDragAndDropDialog
multipleFiles={this.props.multiple} multipleFiles={this.props.multiple}
hasFiles={hasFiles} hasFiles={hasFiles}
onClick={this.handleOnClick} onClick={this.handleOnClick}/>
/>
<FileDragAndDropPreviewIterator <FileDragAndDropPreviewIterator
files={this.props.filesToUpload} files={this.props.filesToUpload}
handleDeleteFile={this.handleDeleteFile} handleDeleteFile={this.handleDeleteFile}

View File

@ -4,7 +4,7 @@ import React from 'react';
import FileDragAndDropPreviewImage from './file_drag_and_drop_preview_image'; import FileDragAndDropPreviewImage from './file_drag_and_drop_preview_image';
import FileDragAndDropPreviewOther from './file_drag_and_drop_preview_other'; import FileDragAndDropPreviewOther from './file_drag_and_drop_preview_other';
import { getLangText } from '../../utils/lang_utils.js'
let FileDragAndDropPreview = React.createClass({ let FileDragAndDropPreview = React.createClass({
@ -75,7 +75,7 @@ let FileDragAndDropPreview = React.createClass({
<span <span
className="glyphicon glyphicon-remove text-center" className="glyphicon glyphicon-remove text-center"
aria-hidden="true" aria-hidden="true"
title="Remove file" title={getLangText('Remove file')}
onClick={this.handleDeleteFile}/> onClick={this.handleDeleteFile}/>
</div>); </div>);
} }

View File

@ -4,6 +4,7 @@ import React from 'react';
import ProgressBar from 'react-progressbar'; import ProgressBar from 'react-progressbar';
import AppConstants from '../../constants/application_constants'; import AppConstants from '../../constants/application_constants';
import { getLangText } from '../../utils/lang_utils.js'
let FileDragAndDropPreviewImage = React.createClass({ let FileDragAndDropPreviewImage = React.createClass({
propTypes: { propTypes: {
@ -40,15 +41,15 @@ let FileDragAndDropPreviewImage = React.createClass({
let actionSymbol; let actionSymbol;
if(this.props.progress > 0 && this.props.progress < 99 && this.state.paused) { if(this.props.progress > 0 && this.props.progress < 99 && this.state.paused) {
actionSymbol = <span className="glyphicon glyphicon-pause action-file" aria-hidden="true" title="Pause upload" onClick={this.toggleUploadProcess}/>; actionSymbol = <span className="glyphicon glyphicon-pause action-file" aria-hidden="true" title={getLangText('Pause upload')} onClick={this.toggleUploadProcess}/>;
} else if(this.props.progress > 0 && this.props.progress < 99 && !this.state.paused) { } else if(this.props.progress > 0 && this.props.progress < 99 && !this.state.paused) {
actionSymbol = <span className="glyphicon glyphicon-play action-file" aria-hidden="true" title="Resume uploading" onClick={this.toggleUploadProcess}/>; actionSymbol = <span className="glyphicon glyphicon-play action-file" aria-hidden="true" title={getLangText('Resume uploading')} onClick={this.toggleUploadProcess}/>;
} else if(this.props.progress === 100) { } else if(this.props.progress === 100) {
// only if assets are actually downloadable, there should be a download icon if the process is already at // only if assets are actually downloadable, there should be a download icon if the process is already at
// 100%. If not, no actionSymbol should be displayed // 100%. If not, no actionSymbol should be displayed
if(this.props.areAssetsDownloadable) { if(this.props.areAssetsDownloadable) {
actionSymbol = <a href={this.props.downloadUrl} target="_blank" className="glyphicon glyphicon-download action-file" aria-hidden="true" title="Download file"/>; actionSymbol = <a href={this.props.downloadUrl} target="_blank" className="glyphicon glyphicon-download action-file" aria-hidden="true" title={getLangText('Download file')}/>;
} }
} else { } else {

View File

@ -4,6 +4,7 @@ import React from 'react';
import ProgressBar from 'react-progressbar'; import ProgressBar from 'react-progressbar';
import AppConstants from '../../constants/application_constants'; import AppConstants from '../../constants/application_constants';
import { getLangText } from '../../utils/lang_utils.js'
let FileDragAndDropPreviewOther = React.createClass({ let FileDragAndDropPreviewOther = React.createClass({
propTypes: { propTypes: {
@ -36,15 +37,15 @@ let FileDragAndDropPreviewOther = React.createClass({
let actionSymbol; let actionSymbol;
if(this.props.progress > 0 && this.props.progress < 99 && this.state.paused) { if(this.props.progress > 0 && this.props.progress < 99 && this.state.paused) {
actionSymbol = <span className="glyphicon glyphicon-pause action-file" aria-hidden="true" title="Pause upload" onClick={this.toggleUploadProcess}/>; actionSymbol = <span className="glyphicon glyphicon-pause action-file" aria-hidden="true" title={getLangText('Pause upload')} onClick={this.toggleUploadProcess}/>;
} else if(this.props.progress > 0 && this.props.progress < 99 && !this.state.paused) { } else if(this.props.progress > 0 && this.props.progress < 99 && !this.state.paused) {
actionSymbol = <span className="glyphicon glyphicon-play action-file" aria-hidden="true" title="Resume uploading" onClick={this.toggleUploadProcess}/>; actionSymbol = <span className="glyphicon glyphicon-play action-file" aria-hidden="true" title={getLangText('Resume uploading')} onClick={this.toggleUploadProcess}/>;
} else if(this.props.progress === 100) { } else if(this.props.progress === 100) {
// only if assets are actually downloadable, there should be a download icon if the process is already at // only if assets are actually downloadable, there should be a download icon if the process is already at
// 100%. If not, no actionSymbol should be displayed // 100%. If not, no actionSymbol should be displayed
if(this.props.areAssetsDownloadable) { if(this.props.areAssetsDownloadable) {
actionSymbol = <a href={this.props.downloadUrl} target="_blank" className="glyphicon glyphicon-download action-file" aria-hidden="true" title="Download file"/>; actionSymbol = <a href={this.props.downloadUrl} target="_blank" className="glyphicon glyphicon-download action-file" aria-hidden="true" title={getLangText('Download file')}/>;
} }
} else { } else {

View File

@ -463,7 +463,7 @@ var ReactS3FineUploader = React.createClass({
// replace filelist with first-element file list // replace filelist with first-element file list
files = tempFilesList; files = tempFilesList;
// TOOD translate?
let notification = new GlobalNotificationModel('Only one file allowed (took first one)', 'danger', 10000); let notification = new GlobalNotificationModel('Only one file allowed (took first one)', 'danger', 10000);
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);
} }

View File

@ -22,13 +22,13 @@ let CoaVerifyContainer = React.createClass({
<div className="ascribe-login-wrapper"> <div className="ascribe-login-wrapper">
<br/> <br/>
<div className="ascribe-login-text ascribe-login-header"> <div className="ascribe-login-text ascribe-login-header">
Verify your Certificate of Authenticity {getLangText('Verify your Certificate of Authenticity')}
</div> </div>
<CoaVerifyForm /> <CoaVerifyForm />
<br /> <br />
<br /> <br />
ascribe is using the following public key for verification: {getLangText('ascribe is using the following public key for verification')}:
<br /> <br />
<pre> <pre>
-----BEGIN PUBLIC KEY----- -----BEGIN PUBLIC KEY-----
@ -50,6 +50,7 @@ let CoaVerifyForm = React.createClass({
handleSuccess(response){ handleSuccess(response){
let notification = null; let notification = null;
if (response.verdict){ if (response.verdict){
// TODO translate?
notification = new GlobalNotificationModel('Certificate of Authenticity successfully verified', 'success'); notification = new GlobalNotificationModel('Certificate of Authenticity successfully verified', 'success');
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);
} }
@ -65,7 +66,7 @@ let CoaVerifyForm = React.createClass({
<button <button
type="submit" type="submit"
className="btn ascribe-btn ascribe-btn-login"> className="btn ascribe-btn ascribe-btn-login">
Verify your Certificate of Authenticity {getLangText('Verify your Certificate of Authenticity')}
</button>} </button>}
spinner={ spinner={
<button className="btn ascribe-btn ascribe-btn-login ascribe-btn-login-spinner"> <button className="btn ascribe-btn ascribe-btn-login ascribe-btn-login-spinner">
@ -74,10 +75,10 @@ let CoaVerifyForm = React.createClass({
}> }>
<Property <Property
name='message' name='message'
label="Message"> label={getLangText('Message')}>
<input <input
type="text" type="text"
placeholder="Copy paste the message on the bottom of your Certificate of Authenticity" placeholder={getLangText('Copy paste the message on the bottom of your Certificate of Authenticity')}
autoComplete="on" autoComplete="on"
name="username" name="username"
required/> required/>
@ -88,7 +89,7 @@ let CoaVerifyForm = React.createClass({
<InputTextAreaToggable <InputTextAreaToggable
rows={3} rows={3}
editable={true} editable={true}
placeholder="Copy paste the signature on the bottom of your Certificate of Authenticity" placeholder={getLangText('Copy paste the signature on the bottom of your Certificate of Authenticity')}
required/> required/>
</Property> </Property>
<hr /> <hr />

View File

@ -38,6 +38,7 @@ import AppConstants from '../constants/application_constants';
import classNames from 'classnames'; import classNames from 'classnames';
import { getCookie } from '../utils/fetch_api_utils'; import { getCookie } from '../utils/fetch_api_utils';
import { getLangText } from '../utils/lang_utils';
let Link = Router.Link; let Link = Router.Link;
/** /**
@ -94,7 +95,7 @@ let Edition = React.createClass({
</CollapsibleParagraph> </CollapsibleParagraph>
<CollapsibleParagraph <CollapsibleParagraph
title="Further Details" title={getLangText('Further Details')}
show={this.props.edition.acl.indexOf('edit') > -1 show={this.props.edition.acl.indexOf('edit') > -1
|| Object.keys(this.props.edition.extra_data).length > 0 || Object.keys(this.props.edition.extra_data).length > 0
|| this.props.edition.other_data !== null}> || this.props.edition.other_data !== null}>
@ -104,35 +105,35 @@ let Edition = React.createClass({
</CollapsibleParagraph> </CollapsibleParagraph>
<CollapsibleParagraph <CollapsibleParagraph
title="Certificate of Authenticity" title={getLangText('Certificate of Authenticity')}
show={this.props.edition.acl.indexOf('coa') > -1}> show={this.props.edition.acl.indexOf('coa') > -1}>
<CoaDetails <CoaDetails
edition={this.props.edition}/> edition={this.props.edition}/>
</CollapsibleParagraph> </CollapsibleParagraph>
<CollapsibleParagraph <CollapsibleParagraph
title="Provenance/Ownership History" title={getLangText('Provenance/Ownership History')}
show={this.props.edition.ownership_history && this.props.edition.ownership_history.length > 0}> show={this.props.edition.ownership_history && this.props.edition.ownership_history.length > 0}>
<EditionDetailHistoryIterator <EditionDetailHistoryIterator
history={this.props.edition.ownership_history} /> history={this.props.edition.ownership_history} />
</CollapsibleParagraph> </CollapsibleParagraph>
<CollapsibleParagraph <CollapsibleParagraph
title="Consignment History" title={getLangText('Consignment History')}
show={this.props.edition.consign_history && this.props.edition.consign_history.length > 0}> show={this.props.edition.consign_history && this.props.edition.consign_history.length > 0}>
<EditionDetailHistoryIterator <EditionDetailHistoryIterator
history={this.props.edition.consign_history} /> history={this.props.edition.consign_history} />
</CollapsibleParagraph> </CollapsibleParagraph>
<CollapsibleParagraph <CollapsibleParagraph
title="Loan History" title={getLangText('Loan History')}
show={this.props.edition.loan_history && this.props.edition.loan_history.length > 0}> show={this.props.edition.loan_history && this.props.edition.loan_history.length > 0}>
<EditionDetailHistoryIterator <EditionDetailHistoryIterator
history={this.props.edition.loan_history} /> history={this.props.edition.loan_history} />
</CollapsibleParagraph> </CollapsibleParagraph>
<CollapsibleParagraph <CollapsibleParagraph
title="SPOOL Details"> title={getLangText('SPOOL Details')}>
<SpoolDetails <SpoolDetails
edition={this.props.edition} /> edition={this.props.edition} />
</CollapsibleParagraph> </CollapsibleParagraph>
@ -182,7 +183,7 @@ let MediaContainer = React.createClass({
extraData={extraData} /> extraData={extraData} />
<p className="text-center"> <p className="text-center">
<Button bsSize="xsmall" className="ascribe-margin-1px" href={this.props.edition.digital_work.url} target="_blank"> <Button bsSize="xsmall" className="ascribe-margin-1px" href={this.props.edition.digital_work.url} target="_blank">
Download <Glyphicon glyph="cloud-download"/> {getLangText('Download')} <Glyphicon glyph="cloud-download"/>
</Button> </Button>
{embed} {embed}
</p> </p>
@ -209,7 +210,7 @@ const CollapsibleButton = React.createClass({
this.setState({expanded: !this.state.expanded}); this.setState({expanded: !this.state.expanded});
}, },
render() { render() {
let isVisible = (this.state.expanded) ? '' : 'invisible'; let isVisible = (this.state.expanded) ? '' : getLangText('invisible');
return ( return (
<span> <span>
<span onClick={this.handleToggle}> <span onClick={this.handleToggle}>
@ -233,9 +234,9 @@ let EditionHeader = React.createClass({
var titleHtml = <div className="ascribe-detail-title">{this.props.edition.title}</div>; var titleHtml = <div className="ascribe-detail-title">{this.props.edition.title}</div>;
return ( return (
<div className="ascribe-detail-header"> <div className="ascribe-detail-header">
<EditionDetailProperty label="TITLE" value={titleHtml} /> <EditionDetailProperty label={getLangText('TITLE')} value={titleHtml} />
<EditionDetailProperty label="BY" value={this.props.edition.artist_name} /> <EditionDetailProperty label={getLangText('BY')} value={this.props.edition.artist_name} />
<EditionDetailProperty label="DATE" value={ this.props.edition.date_created.slice(0, 4) } /> <EditionDetailProperty label={getLangText('DATE')} value={ this.props.edition.date_created.slice(0, 4) } />
<hr/> <hr/>
</div> </div>
); );
@ -263,18 +264,18 @@ let EditionSummary = React.createClass({
let status = null; let status = null;
if (this.props.edition.status.length > 0){ if (this.props.edition.status.length > 0){
let statusStr = this.props.edition.status.join().replace(/_/, ' '); let statusStr = this.props.edition.status.join().replace(/_/, ' ');
status = <EditionDetailProperty label="STATUS" value={ statusStr }/>; status = <EditionDetailProperty label={getLangText('STATUS')} value={ statusStr }/>;
if (this.props.edition.pending_new_owner && this.props.edition.acl.indexOf('withdraw_transfer') > -1){ if (this.props.edition.pending_new_owner && this.props.edition.acl.indexOf('withdraw_transfer') > -1){
status = ( status = (
<Form <Form
url={apiUrls.ownership_transfers_withdraw} url={apiUrls.ownership_transfers_withdraw}
getFormData={this.getTransferWithdrawData} getFormData={this.getTransferWithdrawData}
handleSuccess={this.showNotification}> handleSuccess={this.showNotification}>
<EditionDetailProperty label="STATUS" value={ statusStr }> <EditionDetailProperty label={getLangText('STATUS')} value={ statusStr }>
<button <button
type="submit" type="submit"
className="pull-right btn btn-default btn-sm"> className="pull-right btn btn-default btn-sm">
WITHDRAW {getLangText('WITHDRAW')}
</button> </button>
</EditionDetailProperty> </EditionDetailProperty>
</Form> </Form>
@ -303,10 +304,10 @@ let EditionSummary = React.createClass({
return ( return (
<div className="ascribe-detail-header"> <div className="ascribe-detail-header">
<EditionDetailProperty label="EDITION" <EditionDetailProperty label={getLangText('EDITION')}
value={this.props.edition.edition_number + ' of ' + this.props.edition.num_editions} /> value={this.props.edition.edition_number + ' ' + getLangText('of') + ' ' + this.props.edition.num_editions} />
<EditionDetailProperty label="ID" value={ this.props.edition.bitcoin_id } /> <EditionDetailProperty label={getLangText('ID')} value={ this.props.edition.bitcoin_id } />
<EditionDetailProperty label="OWNER" value={ this.props.edition.owner } /> <EditionDetailProperty label={getLangText('OWNER')} value={ this.props.edition.owner } />
{status} {status}
<br/> <br/>
{actions} {actions}
@ -399,7 +400,7 @@ let EditionPersonalNote = React.createClass({
}, },
showNotification(){ showNotification(){
this.props.handleSuccess(); this.props.handleSuccess();
let notification = new GlobalNotificationModel('Private note saved', 'success'); let notification = new GlobalNotificationModel(getLangText('Private note saved'), 'success');
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);
}, },
@ -411,13 +412,13 @@ let EditionPersonalNote = React.createClass({
handleSuccess={this.showNotification}> handleSuccess={this.showNotification}>
<Property <Property
name='note' name='note'
label='Personal note (private)' label={getLangText('Personal note (private)')}
editable={true}> editable={true}>
<InputTextAreaToggable <InputTextAreaToggable
rows={3} rows={3}
editable={true} editable={true}
defaultValue={this.props.edition.note_from_user} defaultValue={this.props.edition.note_from_user}
placeholder='Enter a personal note...' placeholder={getLangText('Enter a personal note%s', '...')}
required/> required/>
</Property> </Property>
<Property hidden={true} name='bitcoin_id'> <Property hidden={true} name='bitcoin_id'>
@ -437,9 +438,7 @@ let EditionPublicEditionNote = React.createClass({
handleSuccess: React.PropTypes.func handleSuccess: React.PropTypes.func
}, },
showNotification(){ showNotification(){
this.props.handleSuccess(); this.props.handleSuccess();EnterndGlobalNotification(notification);
let notification = new GlobalNotificationModel('Public note saved', 'success');
GlobalNotificationActions.appendGlobalNotification(notification);
}, },
render() { render() {
let isEditable = this.props.edition.acl.indexOf('edit') > -1; let isEditable = this.props.edition.acl.indexOf('edit') > -1;
@ -450,13 +449,13 @@ let EditionPublicEditionNote = React.createClass({
handleSuccess={this.showNotification}> handleSuccess={this.showNotification}>
<Property <Property
name='note' name='note'
label='Edition note (public)' label={getLangText('Edition note (public)')}
editable={isEditable}> editable={isEditable}>
<InputTextAreaToggable <InputTextAreaToggable
rows={3} rows={3}
editable={isEditable} editable={isEditable}
defaultValue={this.props.edition.public_note} defaultValue={this.props.edition.public_note}
placeholder='Enter a public note for this edition...' placeholder={getLangText('Enter a public note for this edition%', '...')}
required/> required/>
</Property> </Property>
<Property hidden={true} name='bitcoin_id'> <Property hidden={true} name='bitcoin_id'>
@ -485,7 +484,7 @@ let EditionFurtherDetails = React.createClass({
showNotification(){ showNotification(){
this.props.handleSuccess(); this.props.handleSuccess();
let notification = new GlobalNotificationModel('Details updated', 'success'); let notification = new GlobalNotificationModel(getLangText('Details updated'), 'success');
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);
}, },
@ -518,19 +517,19 @@ let EditionFurtherDetails = React.createClass({
<Col md={12} className="ascribe-edition-personal-note"> <Col md={12} className="ascribe-edition-personal-note">
<PieceExtraDataForm <PieceExtraDataForm
name='artist_contact_info' name='artist_contact_info'
title='Artist Contact Info' title={getLangText('Artist Contact Info')}
handleSuccess={this.showNotification} handleSuccess={this.showNotification}
editable={editable} editable={editable}
edition={this.props.edition} /> edition={this.props.edition} />
<PieceExtraDataForm <PieceExtraDataForm
name='display_instructions' name='display_instructions'
title='Display Instructions' title={getLangText('Display Instructions')}
handleSuccess={this.showNotification} handleSuccess={this.showNotification}
editable={editable} editable={editable}
edition={this.props.edition} /> edition={this.props.edition} />
<PieceExtraDataForm <PieceExtraDataForm
name='technology_details' name='technology_details'
title='Technology Details' title={getLangText('Technology Details')}
handleSuccess={this.showNotification} handleSuccess={this.showNotification}
editable={editable} editable={editable}
edition={this.props.edition} /> edition={this.props.edition} />
@ -567,7 +566,7 @@ let FileUploader = React.createClass({
return ( return (
<Form> <Form>
<Property <Property
label="Additional files"> label={getLangText('Additional files')}>
<ReactS3FineUploader <ReactS3FineUploader
keyRoutine={{ keyRoutine={{
url: AppConstants.serverUrl + 's3/key/', url: AppConstants.serverUrl + 's3/key/',
@ -656,12 +655,12 @@ let CoaDetails = React.createClass({
<p className="text-center ascribe-button-list"> <p className="text-center ascribe-button-list">
<a href={this.state.coa.url_safe} target="_blank"> <a href={this.state.coa.url_safe} target="_blank">
<button className="btn btn-default btn-xs"> <button className="btn btn-default btn-xs">
Download <Glyphicon glyph="cloud-download"/> {getLangText('Download')} <Glyphicon glyph="cloud-download"/>
</button> </button>
</a> </a>
<Link to="coa_verify"> <Link to="coa_verify">
<button className="btn btn-default btn-xs"> <button className="btn btn-default btn-xs">
Verify <Glyphicon glyph="check"/> {getLangText('Verify')} <Glyphicon glyph="check"/>
</button> </button>
</Link> </Link>
@ -699,19 +698,19 @@ let SpoolDetails = React.createClass({
<Form > <Form >
<Property <Property
name='artwork_id' name='artwork_id'
label="Artwork ID" label={getLangText('Artwork ID')}
editable={false}> editable={false}>
<pre className="ascribe-pre">{bitcoinIdValue}</pre> <pre className="ascribe-pre">{bitcoinIdValue}</pre>
</Property> </Property>
<Property <Property
name='hash_of_artwork' name='hash_of_artwork'
label="Hash of Artwork, title, etc" label={getLangText('Hash of Artwork, title, etc')}
editable={false}> editable={false}>
<pre className="ascribe-pre">{hashOfArtwork}</pre> <pre className="ascribe-pre">{hashOfArtwork}</pre>
</Property> </Property>
<Property <Property
name='owner_address' name='owner_address'
label="Owned by SPOOL address" label={getLangText('Owned by SPOOL address')}
editable={false}> editable={false}>
<pre className="ascribe-pre">{ownerAddress}</pre> <pre className="ascribe-pre">{ownerAddress}</pre>
</Property> </Property>

View File

@ -48,6 +48,7 @@ let EditionContainer = React.createClass({
); );
} else { } else {
return ( return (
// TODO translate?
<p>Loading</p> <p>Loading</p>
); );
} }

View File

@ -13,8 +13,8 @@ let Footer = React.createClass({
<br /> <br />
<a href="https://github.com/ascribe/REST-main/" target="_blank">api</a> | <a href="https://github.com/ascribe/REST-main/" target="_blank">api</a> |
<a href="https://www.ascribe.io/impressum" target="_blank"> impressum</a> | <a href="https://www.ascribe.io/impressum" target="_blank"> impressum</a> |
<a href="https://www.ascribe.io/terms" target="_blank"> terms of service</a> | <a href="https://www.ascribe.io/terms" target="_blank"> {getLangText('terms of service')}</a> |
<a href="https://www.ascribe.io/privacy" target="_blank"> privacy</a> <a href="https://www.ascribe.io/privacy" target="_blank"> {getLangText('privacy')}</a>
</p> </p>
<p className="social-icons-wrapper"> <p className="social-icons-wrapper">
<a href="https://twitter.com/ascribeIO" className="social social-twitter" target="_blank"></a> <a href="https://twitter.com/ascribeIO" className="social social-twitter" target="_blank"></a>

View File

@ -65,7 +65,7 @@ let Header = React.createClass({
return ( return (
<div className="row no-margin ascribe-subheader"> <div className="row no-margin ascribe-subheader">
<a className="pull-right" href="https://www.ascribe.io/" target="_blank"> <a className="pull-right" href="https://www.ascribe.io/" target="_blank">
<span id="powered">powered by </span> <span id="powered">{getLangText('powered by')} </span>
<span>ascribe </span> <span>ascribe </span>
<span className="glyph-ascribe-spool-chunked ascribe-color"></span> <span className="glyph-ascribe-spool-chunked ascribe-color"></span>
</a> </a>
@ -90,8 +90,8 @@ let Header = React.createClass({
<MenuItem eventKey="3" onClick={this.handleLogout}>{getLangText('Log out')}</MenuItem> <MenuItem eventKey="3" onClick={this.handleLogout}>{getLangText('Log out')}</MenuItem>
</DropdownButton> </DropdownButton>
); );
collection = <NavItemLink to="pieces">COLLECTION</NavItemLink>; collection = <NavItemLink to="pieces">{getLangText('COLLECTION')}</NavItemLink>;
addNewWork = <NavItemLink to="register_piece">+ NEW WORK</NavItemLink>; addNewWork = <NavItemLink to="register_piece">+ {getLangText('NEW WORK')}</NavItemLink>;
} }
else { else {
account = <NavItemLink to="login">{getLangText('LOGIN')}</NavItemLink>; account = <NavItemLink to="login">{getLangText('LOGIN')}</NavItemLink>;

View File

@ -5,6 +5,7 @@ import React from 'react';
import Button from 'react-bootstrap/lib/Button'; import Button from 'react-bootstrap/lib/Button';
import Modal from 'react-bootstrap/lib/Modal'; import Modal from 'react-bootstrap/lib/Modal';
import OverlayMixin from 'react-bootstrap/lib/OverlayMixin'; import OverlayMixin from 'react-bootstrap/lib/OverlayMixin';
import { getLangText } from '../utils/lang_utils.js'
let LoginModalHandler = React.createClass({ let LoginModalHandler = React.createClass({
mixins: [OverlayMixin], mixins: [OverlayMixin],
@ -32,7 +33,7 @@ let LoginModalHandler = React.createClass({
This modal is controlled by our custom trigger component. This modal is controlled by our custom trigger component.
</div> </div>
<div className='modal-footer'> <div className='modal-footer'>
<Button onClick={this.handleToggle}>Close</Button> <Button onClick={this.handleToggle}>{getLangText('Close')}</Button>
</div> </div>
</Modal> </Modal>
); );

View File

@ -33,6 +33,7 @@ import ReactS3FineUploader from './ascribe_uploader/react_s3_fine_uploader';
import { mergeOptions } from '../utils/general_utils'; import { mergeOptions } from '../utils/general_utils';
import { getCookie } from '../utils/fetch_api_utils'; import { getCookie } from '../utils/fetch_api_utils';
import { getLangText } from '../utils/lang_utils';
let RegisterPiece = React.createClass( { let RegisterPiece = React.createClass( {
mixins: [Router.Navigation], mixins: [Router.Navigation],
@ -127,11 +128,11 @@ let RegisterPiece = React.createClass( {
return ( return (
<Property <Property
name='license' name='license'
label="Copyright license..." label={getLangText('Copyright license%s', '...')}
onChange={this.onLicenseChange} onChange={this.onLicenseChange}
footer={ footer={
<a className="pull-right" href={this.state.licenses[this.state.selectedLicense].url} target="_blank"> <a className="pull-right" href={this.state.licenses[this.state.selectedLicense].url} target="_blank">
Learn more {getLangText('Learn more')}
</a>}> </a>}>
<select name="license"> <select name="license">
{this.state.licenses.map((license, i) => { {this.state.licenses.map((license, i) => {
@ -166,7 +167,7 @@ let RegisterPiece = React.createClass( {
onFocus={this.changeSlide}> onFocus={this.changeSlide}>
<Row className="no-margin"> <Row className="no-margin">
<Col xs={12} sm={10} md={8} smOffset={1} mdOffset={2}> <Col xs={12} sm={10} md={8} smOffset={1} mdOffset={2}>
<h3 style={{'marginTop': 0, 'marginLeft': '1em'}}>Register your work</h3> <h3 style={{'marginTop': 0, 'marginLeft': '1em'}}>{getLangText('Register your work')}</h3>
<Form <Form
ref='form' ref='form'
url={apiUrls.pieces_list} url={apiUrls.pieces_list}
@ -176,7 +177,7 @@ let RegisterPiece = React.createClass( {
type="submit" type="submit"
className="btn ascribe-btn ascribe-btn-login" className="btn ascribe-btn ascribe-btn-login"
disabled={!this.state.isUploadReady}> disabled={!this.state.isUploadReady}>
Register work {getLangText('Register work')}
</button>} </button>}
spinner={ spinner={
<button className="btn ascribe-btn ascribe-btn-login ascribe-btn-login-spinner"> <button className="btn ascribe-btn ascribe-btn-login ascribe-btn-login-spinner">
@ -192,7 +193,7 @@ let RegisterPiece = React.createClass( {
</Property> </Property>
<Property <Property
name='artist_name' name='artist_name'
label="Artist Name"> label={getLangText('Artist Name')}>
<input <input
type="text" type="text"
placeholder="(e.g. Andy Warhol)" placeholder="(e.g. Andy Warhol)"
@ -200,7 +201,7 @@ let RegisterPiece = React.createClass( {
</Property> </Property>
<Property <Property
name='title' name='title'
label="Title"> label={getLangText('Title')}>
<input <input
type="text" type="text"
placeholder="(e.g. 32 Campbell's Soup Cans)" placeholder="(e.g. 32 Campbell's Soup Cans)"
@ -208,7 +209,7 @@ let RegisterPiece = React.createClass( {
</Property> </Property>
<Property <Property
name='date_created' name='date_created'
label="Year Created"> label={getLangText('Year Created')}>
<input <input
type="number" type="number"
placeholder="(e.g. 1962)" placeholder="(e.g. 1962)"
@ -223,7 +224,7 @@ let RegisterPiece = React.createClass( {
</div> </div>
<div> <div>
<LoginContainer <LoginContainer
message="Please login before ascribing your work..." message={getLangText('Please login before ascribing your work%s', '...')}
redirectOnLoggedIn={false} redirectOnLoggedIn={false}
redirectOnLoginSuccess={false}/> redirectOnLoginSuccess={false}/>
</div> </div>

View File

@ -33,6 +33,7 @@ const languages = {
'I agree to the': 'I agree to the', 'I agree to the': 'I agree to the',
'Confirm Password': 'Confirm Password', 'Confirm Password': 'Confirm Password',
'Promocode': 'Promocode', 'Promocode': 'Promocode',
'Promocode (Optional)': 'Promocode (Optional)',
'Sign up successful': 'Sign up successful', 'Sign up successful': 'Sign up successful',
'We sent an email to your address': 'We sent an email to your address', 'We sent an email to your address': 'We sent an email to your address',
'please confirm': 'please confirm', 'please confirm': 'please confirm',
@ -61,7 +62,147 @@ const languages = {
'API Integration': 'API Integration', 'API Integration': 'API Integration',
'Application Name': 'Application Name', 'Application Name': 'Application Name',
'Enter the name of your app': 'Enter the name of your app', 'Enter the name of your app': 'Enter the name of your app',
'Account': 'Account' 'Account': 'Account',
'Copyright license%s': 'Copyright license%s',
'Files to upload': 'Files to upload',
'Lock down title': 'Lock down title',
'Artist Name': 'Artist Name',
'The name of the creator': 'The name of the creator',
'Number of editions': 'Number of editions',
'Artwork title': 'Artwork title',
'The title of the artwork': 'The title of the artwork',
'Year Created': 'Year Created',
'Year Created (e.g. 2015)': 'Year Created (e.g. 2015)',
'Specify the number of unique editions for this artwork': 'Specify the number of unique editions for this artwork',
'Please login before ascribing your work%s': 'Please login before ascribing your work%s',
'Click or drag to add files': 'Click or drag to add files',
'Click or drag to add a file': 'Click or drag to add a file',
'Register your artwork': 'Register your artwork',
'Register work': 'Register work',
'Learn more': 'Learn more',
'api': 'api',
'impressum': 'impressum',
'terms of service': 'terms of service',
'privacy': 'privacy',
'Search%s': 'Search%s',
'Hide all Editions' : 'Hide all Editions',
'Hide editions' : 'Hide editions',
'Show all Editions': 'Show all Editions',
'Show editions': 'Show editions',
'Edition': 'Edition',
'Work': 'Work',
'You don\'t have any works yet%s': 'You don\'t have any works yet%s',
'To register one, click': 'To register one, click',
'here': 'here',
'Consign artwork': 'Consign artwork',
'Unconsign artwork': 'Unconsign artwork',
'Have the owner manage his sales again': 'Have the owner manage his sales again',
'Transfer artwork': 'Transfer artwork',
'Transfer the ownership of the artwork': 'Transfer the ownership of the artwork',
'Loan artwork': 'Loan artwork',
'Loan your artwork for a limited period of time': 'Loan your artwork for a limited period of time',
'Share artwork': 'Share artwork',
'Share the artwork': 'Share the artwork',
'Remove Edition': 'Remove Edition',
'Click to remove edition': 'Click to remove edition',
'hide': 'hide',
'show': 'show',
'Hi': 'Hi',
'I am sharing': 'I am sharing',
'with you': 'with you',
'Truly yours': 'Truly yours',
'Comma separated emails': 'Comma separated emails',
'SHARE': 'SHARE',
'I consign': 'I consign',
'to you': 'to you',
'Consignee email': 'Consignee email',
'CONSIGN': 'CONSIGN',
'REMOVE FROM COLLECTION': 'REMOVE FROM COLLECTION',
'Further Details': 'Further Details',
'Certificate of Authenticity': 'Certificate of Authenticity',
'Provenance/Ownership History': 'Provenance/Ownership History',
'Consignment History': 'Consignment History',
'SPOOL Details': 'SPOOL Details',
'Download': 'Download',
'invisible': 'invisible',
'TITLE': 'TITLE',
'BY': 'BY',
'DATE': 'DATE',
'STATUS': 'STATUS',
'EDITION': 'EDITION',
'of': 'of',
'OWNER': 'OWNER',
'Private note saved': 'Private note saved',
'Personal note (private)': 'Personal note (private)',
'Enter a personal note%s': 'Enter a personal note%s',
'Public note saved': 'Public note saved',
'Edition note (public)': 'Edition note (public)',
'Enter a public note for this edition%s': 'Enter a public note for this edition%s',
'Details updated': 'Details updated',
'Artist Contact Info': 'Artist Contact Info',
'Display Instructions': 'Display Instructions',
'Technology Details': 'Technology Details',
'Additional files': 'Additional files',
'Verify': 'Verify',
'Artwork ID': 'Artwork ID',
'Hash of Artwork, title, etc': 'Hash of Artwork, title, etc',
'Owned by SPOOL address': 'Owned by SPOOL address',
'Are you sure you would like to permanently delete this edition%s': 'Are you sure you would like to permanently delete this edition%s',
'This is an irrevocable action%s': 'This is an irrevocable action%s',
'DELETE': 'DELETE',
'YES, DELETE': 'YES, DELETE',
'CLOSE': 'CLOSE',
'I loan': 'I loan',
'terms of': 'terms of',
'Loanee email': 'Loanee email',
'Gallery/exhibition (optional)': 'Gallery/exhibition (optional)',
'Loan start date': 'Loan start date',
'Loan end date': 'Loan end date',
'LOAN': 'LOAN',
'I transfer ownership of': 'I transfer ownership of',
'Transferee email': 'Transferee email',
'TRANSFER': 'TRANSFER',
'Forgot your password': 'Forgot your password',
'Reset password': 'Reset password',
'Not a member yet': 'Not a member yet',
'Fill in%s': 'Fill in%s',
'ACCEPT': 'ACCEPT',
'REJECT': 'REJECT',
'this edition%s': 'this edition%s',
'RESET PASSWORD': 'RESET PASSWORD',
'Choose a password': 'Choose a password',
'I un-consign': 'I un-consign',
'from you': 'from you',
'UNCONSIGN': 'UNCONSIGN',
'I request you to un-consign': 'I request you to un-consign',
'UNCONSIGN REQUEST': 'UNCONSIGN REQUEST',
'You have actions pending in one of your editions': 'You have actions pending in one of your editions',
'Login successful': 'Login successful',
'Log in to ascribe': 'Log in to ascribe',
'Create an account': 'Create an account',
'clear all': 'clear all',
'hidden': 'hidden',
'Editions selected': 'Editions selected',
'Show Pieces that': 'Show Pieces that',
'I can transfer': 'I can transfer',
'I can consign': 'I can consign',
'Remove file': 'Remove file',
'Pause upload': 'Pause upload',
'Resume uploading': 'Resume uploading',
'Download file': 'Download file',
'Verify your Certificate of Authenticity': 'Verify your Certificate of Authenticity',
'ascribe is using the following public key for verification': 'ascribe is using the following public key for verification',
'Message': 'Message',
'Copy paste the message on the bottom of your Certificate of Authenticity': 'Copy paste the message on the bottom of your Certificate of Authenticity',
'Copy paste the signature on the bottom of your Certificate of Authenticity': 'Copy paste the signature on the bottom of your Certificate of Authenticity',
'WITHDRAW': 'WITHDRAW',
'powered by': 'powered by',
'COLLECTION': 'COLLECTION',
'edition': 'edition',
'Enter': 'Enter',
'NEW WORK': 'NEW WORK',
'Have someone else sell the artwork': 'Have someone else sell the artwork',
'Loan History': 'Loan History',
}, },
'de': { 'de': {
'ID': 'ID', 'ID': 'ID',
@ -95,6 +236,7 @@ const languages = {
'I agree to the': 'I agree to the', 'I agree to the': 'I agree to the',
'Confirm Password': 'Confirm Password', 'Confirm Password': 'Confirm Password',
'Promocode': 'Promocode', 'Promocode': 'Promocode',
'Promocode (Optional)': 'Promocode (Optional)',
'Sign up successful': 'Sign up successful', 'Sign up successful': 'Sign up successful',
'We sent an email to your address': 'We sent an email to your address', 'We sent an email to your address': 'We sent an email to your address',
'please confirm': 'please confirm', 'please confirm': 'please confirm',
@ -123,7 +265,147 @@ const languages = {
'API Integration': 'API Integration', 'API Integration': 'API Integration',
'Application Name': 'Application Name', 'Application Name': 'Application Name',
'Enter the name of your app': 'Enter the name of your app', 'Enter the name of your app': 'Enter the name of your app',
'Account': 'Account' 'Account': 'Account',
'Copyright license%s': 'Copyright license%s',
'Files to upload': 'Files to upload',
'Lock down title': 'Lock down title',
'Artist Name': 'Artist Name',
'The name of the creator': 'The name of the creator',
'Number of editions': 'Number of editions',
'Artwork title': 'Artwork title',
'The title of the artwork': 'The title of the artwork',
'Year Created': 'Year Created',
'Year Created (e.g. 2015)': 'Year Created (e.g. 2015)',
'Specify the number of unique editions for this artwork': 'Specify the number of unique editions for this artwork',
'Please login before ascribing your work%s': 'Please login before ascribing your work%s',
'Click or drag to add files': 'Click or drag to add files',
'Click or drag to add a file': 'Click or drag to add a file',
'Register your artwork': 'Register your artwork',
'Register work': 'Register work',
'Learn more': 'Learn more',
'api': 'api',
'impressum': 'impressum',
'terms of service': 'terms of service',
'privacy': 'privacy',
'Search%s': 'Search%s',
'Hide all Editions' : 'Hide all Editions',
'Hide editions' : 'Hide editions',
'Show all Editions': 'Show all Editions',
'Show editions': 'Show editions',
'Edition': 'Edition',
'Work': 'Work',
'You don\'t have any works yet%s': 'You don\'t have any works yet%s',
'To register one, click': 'To register one, click',
'here': 'here',
'Consign artwork': 'Consign artwork',
'Unconsign artwork': 'Unconsign artwork',
'Have the owner manage his sales again': 'Have the owner manage his sales again',
'Transfer artwork': 'Transfer artwork',
'Transfer the ownership of the artwork': 'Transfer the ownership of the artwork',
'Loan artwork': 'Loan artwork',
'Loan your artwork for a limited period of time': 'Loan your artwork for a limited period of time',
'Share artwork': 'Share artwork',
'Share the artwork': 'Share the artwork',
'Remove Edition': 'Remove Edition',
'Click to remove edition': 'Click to remove edition',
'hide': 'hide',
'show': 'show',
'Hi': 'Hi',
'I am sharing': 'I am sharing',
'with you': 'with you',
'Truly yours': 'Truly yours',
'Comma separated emails': 'Comma separated emails',
'SHARE': 'SHARE',
'I consign': 'I consign',
'to you': 'to you',
'Consignee email': 'Consignee email',
'CONSIGN': 'CONSIGN',
'REMOVE FROM COLLECTION': 'REMOVE FROM COLLECTION',
'Further Details': 'Further Details',
'Certificate of Authenticity': 'Certificate of Authenticity',
'Provenance/Ownership History': 'Provenance/Ownership History',
'Consignment History': 'Consignment History',
'SPOOL Details': 'SPOOL Details',
'Download': 'Download',
'invisible': 'invisible',
'TITLE': 'TITLE',
'BY': 'BY',
'DATE': 'DATE',
'STATUS': 'STATUS',
'EDITION': 'EDITION',
'of': 'of',
'OWNER': 'OWNER',
'Private note saved': 'Private note saved',
'Personal note (private)': 'Personal note (private)',
'Enter a personal note%s': 'Enter a personal note%s',
'Public note saved': 'Public note saved',
'Edition note (public)': 'Edition note (public)',
'Enter a public note for this edition%s': 'Enter a public note for this edition%s',
'Details updated': 'Details updated',
'Artist Contact Info': 'Artist Contact Info',
'Display Instructions': 'Display Instructions',
'Technology Details': 'Technology Details',
'Additional files': 'Additional files',
'Verify': 'Verify',
'Artwork ID': 'Artwork ID',
'Hash of Artwork, title, etc': 'Hash of Artwork, title, etc',
'Owned by SPOOL address': 'Owned by SPOOL address',
'Are you sure you would like to permanently delete this edition%s': 'Are you sure you would like to permanently delete this edition%s',
'This is an irrevocable action%s': 'This is an irrevocable action%s',
'DELETE': 'DELETE',
'YES, DELETE': 'YES, DELETE',
'CLOSE': 'CLOSE',
'I loan': 'I loan',
'terms of': 'terms of',
'Loanee email': 'Loanee email',
'Gallery/exhibition (optional)': 'Gallery/exhibition (optional)',
'Loan start date': 'Loan start date',
'Loan end date': 'Loan end date',
'LOAN': 'LOAN',
'I transfer ownership of': 'I transfer ownership of',
'Transferee email': 'Transferee email',
'TRANSFER': 'TRANSFER',
'Forgot your password': 'Forgot your password',
'Reset password': 'Reset password',
'Not a member yet': 'Not a member yet',
'Fill in%s': 'Fill in%s',
'ACCEPT': 'ACCEPT',
'REJECT': 'REJECT',
'this edition%s': 'this edition%s',
'RESET PASSWORD': 'RESET PASSWORD',
'Choose a password': 'Choose a password',
'I un-consign': 'I un-consign',
'from you': 'from you',
'UNCONSIGN': 'UNCONSIGN',
'I request you to un-consign': 'I request you to un-consign',
'UNCONSIGN REQUEST': 'UNCONSIGN REQUEST',
'You have actions pending in one of your editions': 'You have actions pending in one of your editions',
'Login successful': 'Login successful',
'Log in to ascribe': 'Log in to ascribe',
'Create an account': 'Create an account',
'clear all': 'clear all',
'hidden': 'hidden',
'Editions selected': 'Editions selected',
'Show Pieces that': 'Show Pieces that',
'I can transfer': 'I can transfer',
'I can consign': 'I can consign',
'Remove file': 'Remove file',
'Pause upload': 'Pause upload',
'Resume uploading': 'Resume uploading',
'Download file': 'Download file',
'Verify your Certificate of Authenticity': 'Verify your Certificate of Authenticity',
'ascribe is using the following public key for verification': 'ascribe is using the following public key for verification',
'Message': 'Message',
'Copy paste the message on the bottom of your Certificate of Authenticity': 'Copy paste the message on the bottom of your Certificate of Authenticity',
'Copy paste the signature on the bottom of your Certificate of Authenticity': 'Copy paste the signature on the bottom of your Certificate of Authenticity',
'WITHDRAW': 'WITHDRAW',
'powered by': 'powered by',
'COLLECTION': 'COLLECTION',
'edition': 'edition',
'Enter': 'Enter',
'NEW WORK': 'NEW WORK',
'Have someone else sell the artwork': 'Have someone else sell the artwork',
'Loan History': 'Loan History',
}, },
'fr': { 'fr': {
'ID': 'ID', 'ID': 'ID',
@ -141,7 +423,7 @@ const languages = {
'%s license': '%s license', '%s license': '%s license',
'Log into': 'Se connecter à', 'Log into': 'Se connecter à',
'Email': 'E-mail', 'Email': 'E-mail',
'Enter your email': 'Entrez votre e-mail', 'Enter your email': 'Entrez votre courriel',
'Password': 'Mot de passe', 'Password': 'Mot de passe',
'Enter your password': 'Entrez votre mot de passe', 'Enter your password': 'Entrez votre mot de passe',
'Not an ascribe user': 'Pas un utilisateur d\'ascribe', 'Not an ascribe user': 'Pas un utilisateur d\'ascribe',
@ -157,18 +439,19 @@ const languages = {
'I agree to the': 'Je suis d\'accrod avec les', 'I agree to the': 'Je suis d\'accrod avec les',
'Confirm Password': 'Confirmez le mot de passe', 'Confirm Password': 'Confirmez le mot de passe',
'Promocode': 'Code promotionnel', 'Promocode': 'Code promotionnel',
'Promocode (Optional)': 'Code promotionnel (Facultatif)',
'Sign up successful': 'Inscription réussie', 'Sign up successful': 'Inscription réussie',
'We sent an email to your address': 'Nous avons envoyé un e-mail à votre adresse', 'We sent an email to your address': 'Nous avons envoyé un courriel à votre adresse',
'please confirm': 'veuillez confirmer', 'please confirm': 'veuillez confirmer',
'Your password must be at least 10 characters': 'Votre mot de passe doit être composé d\'au moins 10 caractères', 'Your password must be at least 10 characters': 'Votre mot de passe doit être composé d\'au moins 10 caractères',
'This password is securing your digital property like a bank account': 'Ce mot de passe sécurise votre propriété numérique tel un compte bancaire', 'This password is securing your digital property like a bank account': 'Ce mot de passe sécurise votre propriété numérique tel un compte bancaire',
'Store it in a safe place': 'Conservez-le dans un endroit sécuritaire', 'Store it in a safe place': 'Conservez-le dans un endroit sécuritaire',
'Reset the password for': 'Réinitialiser le mot de passe pour', 'Reset the password for': 'Réinitialiser le mot de passe pour',
'Reset your ascribe password': 'Réinitialiser votre mot de passe ascribe', 'Reset your ascribe password': 'Réinitialiser votre mot de passe ascribe',
'An email has been sent to': 'Un e-mail a été envoyé à', 'An email has been sent to': 'Un courriel a été envoyé à',
'Request successfully sent, check your email': 'Requête envoyée avec succès, veuillez consultez votre courrier électronique', 'Request successfully sent, check your email': 'Requête envoyée avec succès, veuillez consultez votre courrier électronique',
'Reset your password': 'Réinitialiser votre mot de passe', 'Reset your password': 'Réinitialiser votre mot de passe',
'Enter your email and we\'ll send a link': 'Entrez votre e-mail et nous vous enverrons un lien', 'Enter your email and we\'ll send a link': 'Entrez votre courriel et nous vous enverrons un lien',
'password successfully updated': 'mise à jour du mot de passe réussie', 'password successfully updated': 'mise à jour du mot de passe réussie',
'Enter a new password': 'Entrez un nouveau mot de passe', 'Enter a new password': 'Entrez un nouveau mot de passe',
'Something went wrong, please try again later': 'Quelque chose ne fonctionne pas, veuillez réessayer plus tard', 'Something went wrong, please try again later': 'Quelque chose ne fonctionne pas, veuillez réessayer plus tard',
@ -185,7 +468,147 @@ const languages = {
'API Integration': 'Intégration de l\'API', 'API Integration': 'Intégration de l\'API',
'Application Name': 'Nom de l\'Application', 'Application Name': 'Nom de l\'Application',
'Enter the name of your app': 'Entrez le nom de votre application', 'Enter the name of your app': 'Entrez le nom de votre application',
'Account': 'Compte' 'Account': 'Compte',
'Copyright license%s': 'License de droit d\'auteur%s',
'Files to upload': 'Fichiers à télécharger',
'Lock down title': 'Verrouillez le titre',
'Artist Name': 'Nom de l\'artiste',
'The name of the creator': 'Le nom du créateur',
'Number of editions': 'Nombre d\'éditions',
'Artwork title': 'Titre de l\'oeuvre',
'The title of the artwork': 'Le titre de l\'oeuvre',
'Year Created': 'Année de la création',
'Year Created (e.g. 2015)': 'Année de la création (e.g. 2015)',
'Specify the number of unique editions for this artwork': 'Spécifiez le nombre d\'éditions uniques pour cette oeuvre',
'Please login before ascribing your work%s': 'S\'il vous plaît vous identifier avant d\'attribuer votre oeuvre%s',
'Click or drag to add files': 'Cliquez ou faites glisser pour ajouter des fichiers',
'Click or drag to add a file': 'Cliquez ou faites glisser pour ajouter un fichier',
'Register your artwork': 'Enregistrer votre oeuvre',
'Register work': 'Enregistrer l\'oeuvre',
'Learn more': 'En savoir plus',
'api': 'api',
'impressum': 'impressum',
'terms of service': 'conditions d\'utilisation',
'privacy': 'confidentialité',
'Search%s': 'Rechercher%s',
'Hide all Editions' : 'Cacher toutes les Éditions',
'Hide editions' : 'Cacher les éditions',
'Show all Editions': 'Montrer toutes les Éditions',
'Show editions': 'Montrer les éditions',
'Edition': 'Édition',
'Work': 'Oeuvre',
'You don\'t have any works yet%s': 'Vous n\'avez pas encore d\'oeuvres%s',
'To register one, click': 'Pour en inscrire une, cliquez',
'here': 'ici',
'Consign artwork': 'Consigner l\'oeuvre',
'Unconsign artwork': 'Déconsigner l\'oeuvre',
'Have the owner manage his sales again': 'Demandez au propriétaire de gérer à nouveau ses ventes',
'Transfer artwork': 'Transférez l\'oeuvre',
'Transfer the ownership of the artwork': 'Transférez la propriété de l\'oeuvre',
'Loan artwork': 'Prêtez l\'oeuvre',
'Loan your artwork for a limited period of time': 'Prêtez votre oeuvre pour un temps limité',
'Share artwork': 'Partagez l\'oeuvre',
'Share the artwork': 'Partagez l\'oeuvre',
'Remove Edition': 'Retirer l\'Édition',
'Click to remove edition': 'Cliquez pour retirer l\'édition',
'hide': 'cacher',
'show': 'afficher',
'Hi': 'Bonjour',
'I am sharing': 'Je partage',
'with you': 'avec vous',
'Truly yours': 'Sincèrement',
'Comma separated emails': 'courriel séparés par des virgules',
'SHARE': 'PARTAGER',
'I consign': 'Je consigne',
'to you': 'pour vous',
'Consignee email': 'Courriel du destinataire',
'CONSIGN': 'CONSIGNER',
'REMOVE FROM COLLECTION': 'RETIRER DE LA COLLECTION',
'Further Details': 'Détails Supplémentaires',
'Certificate of Authenticity': 'Certificat d\'Authenticité',
'Provenance/Ownership History': 'Provenance / Historique de Possession', // TODO review
'Consignment History': 'Historique de consignation', // TODO review
'SPOOL Details': 'Détails de spool', // TODO review
'Download': 'Télécharger',
'invisible': 'invisible',
'TITLE': 'TITRE',
'BY': 'PAR', // TODO review
'DATE': 'DATE',
'STATUS': 'STATUT',
'EDITION': 'ÉDITION',
'of': 'de',
'OWNER': 'PROPRIÉTAIRE',
'Private note saved': 'Note privée sauvegardée',
'Personal note (private)': 'Note personnelle (privée)',
'Enter a personal note%s': 'Entrez une note personnelle%s',
'Public note saved': 'Note publique sauvegardée',
'Edition note (public)': 'Note d\'Édition (publique)',
'Enter a public note for this edition%s': 'Entrez une note publique pour cette édition%s',
'Details updated': 'Détails mis à jour',
'Artist Contact Info': 'Coordonnées de l\'artiste',
'Display Instructions': 'Afficher les Instructions',
'Technology Details': 'Détails technologique',
'Additional files': 'fichiers supplémentaires',
'Verify': 'Vérifiez',
'Artwork ID': 'ID de l\'Oeuvre',
'Hash of Artwork, title, etc': 'Valeur de hachage de l\'Oeuvre, titre, etc',
'Owned by SPOOL address': 'Appartient via l\'adresse SPOOL',
'Are you sure you would like to permanently delete this edition': 'Êtes-vous vraiment certaine de vouloir définitivement supprimer cette édition',
'This is an irrevocable action%s': 'Ceci est une action irrévocable%s',
'DELETE': 'SUPPRIMER',
'YES, DELETE': 'OUI, SUPPRIMER',
'CLOSE': 'FERMER',
'I loan': 'Je prête',
'terms of': 'conditions de',
'Loanee email': 'courriel de l\'emprunteur',
'Gallery/exhibition (optional)': 'Galerie/exposition (facultatif)',
'Loan start date': 'Date du commencement du prêt',
'Loan end date': 'Date de la fin de prêt',
'LOAN': 'PRÊT',
'I transfer ownership of': 'Je transfère la propriété de' ,
'Transferee email': 'Courriel du cessionnaire',
'TRANSFER': 'TRANSFÉRER',
'Forgot your password': 'Oubliez votre mot de passe',
'Reset password': 'Réinitialiser le mot de passe',
'Not a member yet': 'Pas encore membre',
'Fill in%s': 'Remplir%s',
'ACCEPT': 'ACCEPTER',
'REJECT': 'REJETER',
'this edition%s': 'cette édition%s',
'RESET PASSWORD': 'RÉINITIALISER LE MOT DE PASSE',
'Choose a password': 'Choisir un mot de passe',
'I un-consign': 'Je déconsigne',
'from you': 'de vous',
'UNCONSIGN': 'DÉCONSIGNER',
'I request you to un-consign': 'Je vous demande de déconsigner',
'UNCONSIGN REQUEST': 'DEMANDE DE DÉCONSIGNATION',
'You have actions pending in one of your editions': 'Vous avez des actions en cours dans l\'une de vos éditions',
'Login successful': 'Connexion réussie',
'Log in to ascribe': 'Connectez-vous à ascribe',
'Create an account': 'Créer un compte',
'clear all': 'tout effacer',
'hidden': 'hidden',
'Editions selected': 'Éditions sélectionnées',
'Show Pieces that': 'Afficher les oeuvres qui',
'I can transfer': 'Je peux transférerr',
'I can consign': 'Je peux consigner',
'Remove file': 'Retirer le fichier',
'Pause upload': 'Mettre en pause le téléchargement',
'Resume uploading': 'Reprendre le téléchargement',
'Download file': 'Télécharger le fichier',
'Verify your Certificate of Authenticity': 'Vérifiez votre certificat d\'authenticité',
'ascribe is using the following public key for verification': 'ascribe utilise la clé publique suivante pour à des fins de vérification',
'Message': 'Message',
'Copy paste the message on the bottom of your Certificate of Authenticity': 'Copier coller le message qui se trouve sur le bas de votre certificat d\'authenticité',
'Copy paste the signature on the bottom of your Certificate of Authenticity': 'Copier coller la signature qui se trouve sur le bas de votre certificat d\'authenticité',
'WITHDRAW': 'RETIRER',
'powered by': 'alimenté par', // TODO review
'COLLECTION': 'COLLECTION',
'edition': 'édition',
'Enter': 'Entrez',
'NEW WORK': 'NOUVEL OEUVRE',
'Have someone else sell the artwork': 'Demandez à quelqu\'un de vendre l\'oeuvre',
'Loan History': 'Historique de Prêts',
} }
}; };

View File

@ -4,6 +4,7 @@ import requests from '../utils/requests';
import React from 'react'; import React from 'react';
import AlertDismissable from '../components/ascribe_forms/alert'; import AlertDismissable from '../components/ascribe_forms/alert';
import { getLangText } from '../utils/lang_utils.js'
export const FormMixin = { export const FormMixin = {
propTypes: { propTypes: {
@ -68,6 +69,7 @@ export const FormMixin = {
} }
} }
else { else {
// TODO translate?
this.setState({errors: ['Something went wrong, please try again later']}); this.setState({errors: ['Something went wrong, please try again later']});
} }
this.setState({submitted: false}); this.setState({submitted: false});
@ -81,7 +83,7 @@ export const FormMixin = {
getTitlesString(){ getTitlesString(){
return this.props.editions.map(function(edition){ return this.props.editions.map(function(edition){
return '- \"' + edition.title + ', edition ' + edition.edition_number + '\"\n'; return '- \"' + edition.title + ', ' + getLangText('edition') + ' ' + edition.edition_number + '\"\n';
}); });
}, },

View File

@ -13,7 +13,7 @@ import { formatText } from './general_utils';
export function getLangText(s, ...args) { export function getLangText(s, ...args) {
let lang = navigator.language || navigator.userLanguage; let lang = navigator.language || navigator.userLanguage;
// this is just for testing, as changing the navigator.language wasn't possible // this is just for testing, as changing the navigator.language wasn't possible
//lang = 'de'; //ang = 'de';
try { try {
if(lang in languages) { if(lang in languages) {
return formatText(languages[lang][s], args); return formatText(languages[lang][s], args);