mirror of
https://github.com/ascribe/onion.git
synced 2024-12-31 09:07:48 +01:00
Merge pull request #205 from ascribe/use-js-utility-belt
Use js-utility-belt
This commit is contained in:
commit
fe2ab10441
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"extends": "ascribe",
|
"extends": "ascribe-react",
|
||||||
"rules": {
|
"rules": {
|
||||||
"no-console": [1, { "allow": ["error", "logGlobal"] }]
|
"no-console": [1, { "allow": ["error", "logGlobal"] }]
|
||||||
}
|
}
|
||||||
|
23
js/app.js
23
js/app.js
@ -12,10 +12,10 @@ import history from './history';
|
|||||||
|
|
||||||
import AppConstants from './constants/application_constants';
|
import AppConstants from './constants/application_constants';
|
||||||
|
|
||||||
import { getDefaultSubdomainSettings, getSubdomainSettings } from './utils/constants_utils';
|
import { getDefaultSubdomainSettings, getSubdomainSettings } from './utils/constants';
|
||||||
import { initLogging } from './utils/error_utils';
|
import { initLogging } from './utils/error';
|
||||||
import { getSubdomain } from './utils/general_utils';
|
import { getCurrentSubdomain } from './utils/url';
|
||||||
import requests from './utils/requests';
|
import UrlResolver from './utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
// FIXME: rename these event actions
|
// FIXME: rename these event actions
|
||||||
@ -38,7 +38,7 @@ const AppGateway = {
|
|||||||
let subdomainSettings;
|
let subdomainSettings;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
subdomainSettings = getSubdomainSettings(getSubdomain());
|
subdomainSettings = getSubdomainSettings(getCurrentSubdomain());
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
// if there are no matching subdomains, we''ll route to the default frontend
|
// if there are no matching subdomains, we''ll route to the default frontend
|
||||||
console.logGlobal(err);
|
console.logGlobal(err);
|
||||||
@ -74,17 +74,8 @@ const AppGateway = {
|
|||||||
AppResolver
|
AppResolver
|
||||||
.resolve(settings)
|
.resolve(settings)
|
||||||
.then(({ apiUrls, redirectRoute, routes }) => {
|
.then(({ apiUrls, redirectRoute, routes }) => {
|
||||||
// Initialize api urls and defaults for outgoing requests
|
// Set url mapping for outgoing api requests
|
||||||
requests.defaults({
|
UrlResolver.setUrlMapping(apiUrls);
|
||||||
urlMap: apiUrls,
|
|
||||||
http: {
|
|
||||||
headers: {
|
|
||||||
'Accept': 'application/json',
|
|
||||||
'Content-Type': 'application/json'
|
|
||||||
},
|
|
||||||
credentials: 'include'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
ReactDOM.render((
|
ReactDOM.render((
|
||||||
<Router history={history}>
|
<Router history={history}>
|
||||||
|
@ -9,7 +9,7 @@ import WhitelabelStore from '../stores/whitelabel_store';
|
|||||||
import GlobalNotification from './global_notification';
|
import GlobalNotification from './global_notification';
|
||||||
import { currentUserShape, locationShape, whitelabelShape } from './prop_types';
|
import { currentUserShape, locationShape, whitelabelShape } from './prop_types';
|
||||||
|
|
||||||
import { mergeOptions } from '../utils/general_utils';
|
import { safeMerge } from '../utils/general';
|
||||||
|
|
||||||
|
|
||||||
export default function AppBase(App) {
|
export default function AppBase(App) {
|
||||||
@ -29,7 +29,7 @@ export default function AppBase(App) {
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
UserStore.getState(),
|
UserStore.getState(),
|
||||||
WhitelabelStore.getState()
|
WhitelabelStore.getState()
|
||||||
);
|
);
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Link from 'react-router/es6/Link';
|
import Link from 'react-router/es6/Link';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let AccordionList = React.createClass({
|
let AccordionList = React.createClass({
|
||||||
|
@ -8,13 +8,11 @@ import EditionListStore from '../../stores/edition_list_store';
|
|||||||
|
|
||||||
import PieceListStore from '../../stores/piece_list_store';
|
import PieceListStore from '../../stores/piece_list_store';
|
||||||
|
|
||||||
import Button from 'react-bootstrap/lib/Button';
|
|
||||||
|
|
||||||
import CreateEditionsButton from '../ascribe_buttons/create_editions_button';
|
import CreateEditionsButton from '../ascribe_buttons/create_editions_button';
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
import { safeMerge } from '../../utils/general';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let AccordionListItemEditionWidget = React.createClass({
|
let AccordionListItemEditionWidget = React.createClass({
|
||||||
@ -27,7 +25,7 @@ let AccordionListItemEditionWidget = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
EditionListStore.getState(),
|
EditionListStore.getState(),
|
||||||
PieceListStore.getState()
|
PieceListStore.getState()
|
||||||
);
|
);
|
||||||
|
@ -5,7 +5,7 @@ import React from 'react';
|
|||||||
import AccordionListItem from './accordion_list_item';
|
import AccordionListItem from './accordion_list_item';
|
||||||
import AccordionListItemThumbnailPlacholder from './accordion_list_item_thumbnail_placeholder';
|
import AccordionListItemThumbnailPlacholder from './accordion_list_item_thumbnail_placeholder';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let AccordionListItemPiece = React.createClass({
|
let AccordionListItemPiece = React.createClass({
|
||||||
|
@ -16,8 +16,8 @@ import TableItemCheckbox from '../ascribe_table/table_item_checkbox';
|
|||||||
import TableItemAclFiltered from '../ascribe_table/table_item_acl_filtered';
|
import TableItemAclFiltered from '../ascribe_table/table_item_acl_filtered';
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
import { safeMerge } from '../../utils/general';
|
||||||
|
|
||||||
|
|
||||||
let AccordionListItemTableEditions = React.createClass({
|
let AccordionListItemTableEditions = React.createClass({
|
||||||
@ -28,7 +28,7 @@ let AccordionListItemTableEditions = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
EditionListStore.getState(),
|
EditionListStore.getState(),
|
||||||
{
|
{
|
||||||
showMoreLoading: false
|
showMoreLoading: false
|
||||||
|
@ -23,8 +23,8 @@ import AclProxy from '../acl_proxy';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { whitelabelShape } from '../prop_types';
|
import { whitelabelShape } from '../prop_types';
|
||||||
|
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
import { safeMerge } from '../../utils/general';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let AccordionListItemWallet = React.createClass({
|
let AccordionListItemWallet = React.createClass({
|
||||||
@ -43,7 +43,7 @@ let AccordionListItemWallet = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
PieceListStore.getState(),
|
PieceListStore.getState(),
|
||||||
{
|
{
|
||||||
showCreateEditionsDialog: false
|
showCreateEditionsDialog: false
|
||||||
|
@ -5,11 +5,10 @@ import React from 'react';
|
|||||||
import ConsignButton from './acls/consign_button';
|
import ConsignButton from './acls/consign_button';
|
||||||
import EmailButton from './acls/email_button';
|
import EmailButton from './acls/email_button';
|
||||||
import LoanButton from './acls/loan_button';
|
import LoanButton from './acls/loan_button';
|
||||||
import LoanRequestButton from './acls/loan_request_button';
|
|
||||||
import TransferButton from './acls/transfer_button';
|
import TransferButton from './acls/transfer_button';
|
||||||
import UnconsignButton from './acls/unconsign_button';
|
import UnconsignButton from './acls/unconsign_button';
|
||||||
|
|
||||||
import { selectFromObject } from '../../utils/general_utils';
|
import { selectFromObject } from '../../utils/general';
|
||||||
|
|
||||||
let AclButtonList = React.createClass({
|
let AclButtonList = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -4,8 +4,8 @@ import React from 'react';
|
|||||||
import classnames from 'classnames';
|
import classnames from 'classnames';
|
||||||
|
|
||||||
import { AclInformationText } from '../../constants/acl_information_text';
|
import { AclInformationText } from '../../constants/acl_information_text';
|
||||||
import { replaceSubstringAtIndex, sanitize, intersectLists } from '../../utils/general_utils';
|
import { intersectLists, sanitize } from '../../utils/general';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let AclInformation = React.createClass({
|
let AclInformation = React.createClass({
|
||||||
@ -45,7 +45,7 @@ let AclInformation = React.createClass({
|
|||||||
return (
|
return (
|
||||||
<p key={title}>
|
<p key={title}>
|
||||||
<span className="info">
|
<span className="info">
|
||||||
{replaceSubstringAtIndex(info.slice(2), 's ', ' ')}
|
{info.slice(2).replace('s', '')}
|
||||||
</span>
|
</span>
|
||||||
<span className="example">
|
<span className="example">
|
||||||
{' ' + example}
|
{' ' + example}
|
||||||
@ -90,7 +90,7 @@ let AclInformation = React.createClass({
|
|||||||
verbsToDisplay = verbsToDisplay.concat(verbs);
|
verbsToDisplay = verbsToDisplay.concat(verbs);
|
||||||
} else if(aim === 'button' && this.props.aclObject) {
|
} else if(aim === 'button' && this.props.aclObject) {
|
||||||
const { aclObject } = this.props;
|
const { aclObject } = this.props;
|
||||||
const sanitizedAclObject = sanitize(aclObject, (val) => !val);
|
const sanitizedAclObject = sanitize(aclObject);
|
||||||
verbsToDisplay = verbsToDisplay.concat(intersectLists(verbs, Object.keys(sanitizedAclObject)));
|
verbsToDisplay = verbsToDisplay.concat(intersectLists(verbs, Object.keys(sanitizedAclObject)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
import AclButton from './acl_button';
|
import AclButton from './acl_button';
|
||||||
|
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
export default AclButton({
|
export default AclButton({
|
||||||
action: 'acl_consign',
|
action: 'acl_consign',
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
import AclButton from './acl_button';
|
import AclButton from './acl_button';
|
||||||
|
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
export default AclButton({
|
export default AclButton({
|
||||||
action: 'acl_share',
|
action: 'acl_share',
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
import AclButton from './acl_button';
|
import AclButton from './acl_button';
|
||||||
|
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
export default AclButton({
|
export default AclButton({
|
||||||
action: 'acl_loan',
|
action: 'acl_loan',
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
import AclButton from './acl_button';
|
import AclButton from './acl_button';
|
||||||
|
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
export default AclButton({
|
export default AclButton({
|
||||||
action: 'acl_loan_request',
|
action: 'acl_loan_request',
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
import AclButton from './acl_button';
|
import AclButton from './acl_button';
|
||||||
|
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
export default AclButton({
|
export default AclButton({
|
||||||
action: 'acl_transfer',
|
action: 'acl_transfer',
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
import AclButton from './acl_button';
|
import AclButton from './acl_button';
|
||||||
|
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
export default AclButton({
|
export default AclButton({
|
||||||
action: 'acl_unconsign',
|
action: 'acl_unconsign',
|
||||||
|
@ -1,15 +1,15 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
import classNames from 'classnames';
|
||||||
|
|
||||||
import EditionListActions from '../../actions/edition_list_actions';
|
import EditionListActions from '../../actions/edition_list_actions';
|
||||||
import EditionListStore from '../../stores/edition_list_store';
|
import EditionListStore from '../../stores/edition_list_store';
|
||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
import classNames from 'classnames';
|
|
||||||
|
|
||||||
let CreateEditionsButton = React.createClass({
|
let CreateEditionsButton = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -46,9 +46,9 @@ let CreateEditionsButton = React.createClass({
|
|||||||
startPolling() {
|
startPolling() {
|
||||||
// start polling until editions are defined
|
// start polling until editions are defined
|
||||||
let pollingIntervalIndex = setInterval(() => {
|
let pollingIntervalIndex = setInterval(() => {
|
||||||
|
// TODO: re-evaluate whether this is necessary:
|
||||||
// requests, will try to merge the filterBy parameter with other parameters (mergeOptions).
|
// requests, will try to merge the filterBy parameter with other parameters (safeMerge).
|
||||||
// Therefore it can't but null but instead has to be an empty object
|
// Therefore it can't be null but instead has to be an empty object
|
||||||
EditionListActions
|
EditionListActions
|
||||||
.fetchEditionList({
|
.fetchEditionList({
|
||||||
pieceId: this.props.piece.id,
|
pieceId: this.props.piece.id,
|
||||||
|
@ -12,8 +12,8 @@ import PieceRemoveFromCollectionForm from '../ascribe_forms/form_remove_piece_fr
|
|||||||
|
|
||||||
import ModalWrapper from '../ascribe_modal/modal_wrapper';
|
import ModalWrapper from '../ascribe_modal/modal_wrapper';
|
||||||
|
|
||||||
import { getAvailableAcls } from '../../utils/acl_utils';
|
import { getAvailableAcls } from '../../utils/acl';
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
|
|
||||||
let DeleteButton = React.createClass({
|
let DeleteButton = React.createClass({
|
||||||
|
@ -2,14 +2,14 @@
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import S3Fetcher from '../../fetchers/s3_fetcher';
|
|
||||||
|
|
||||||
import Glyphicon from 'react-bootstrap/lib/Glyphicon';
|
import Glyphicon from 'react-bootstrap/lib/Glyphicon';
|
||||||
|
|
||||||
|
import S3Fetcher from '../../fetchers/s3_fetcher';
|
||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import { queryParamsToArgs } from '../../utils/url_utils';
|
import { parseQueryParamStr } from '../../utils/url';
|
||||||
|
|
||||||
|
|
||||||
const { string } = React.PropTypes;
|
const { string } = React.PropTypes;
|
||||||
@ -52,7 +52,7 @@ const S3DownloadButton = React.createClass({
|
|||||||
|
|
||||||
// The signed url, however can expire, which is why we need to set up a timer to
|
// The signed url, however can expire, which is why we need to set up a timer to
|
||||||
// renew it when it expires.
|
// renew it when it expires.
|
||||||
const expires = parseInt(queryParamsToArgs(downloadUrl.split('?')[1]).expires, 10);
|
const expires = parseInt(parseQueryParamStr(downloadUrl).expires, 10);
|
||||||
const now = new Date().getTime() / 1000;
|
const now = new Date().getTime() / 1000;
|
||||||
|
|
||||||
// Amazon uses seconds as their signature unix timestamp while `setTimeout` uses
|
// Amazon uses seconds as their signature unix timestamp while `setTimeout` uses
|
||||||
|
@ -10,8 +10,8 @@ import UnConsignRequestForm from '../ascribe_forms/form_unconsign_request';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { currentUserShape } from '../prop_types';
|
import { currentUserShape } from '../prop_types';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
const UnConsignRequestButton = React.createClass({
|
const UnConsignRequestButton = React.createClass({
|
||||||
@ -36,7 +36,7 @@ const UnConsignRequestButton = React.createClass({
|
|||||||
handleSuccess={handleSuccess}
|
handleSuccess={handleSuccess}
|
||||||
title={getLangText('Request to Un-Consign')}>
|
title={getLangText('Request to Un-Consign')}>
|
||||||
<UnConsignRequestForm
|
<UnConsignRequestForm
|
||||||
url={ApiUrls.ownership_unconsigns_request}
|
url={resolveUrl('ownership_unconsigns_request')}
|
||||||
id={{'bitcoin_id': edition.bitcoin_id}}
|
id={{'bitcoin_id': edition.bitcoin_id}}
|
||||||
message={`${getLangText('Hi')},
|
message={`${getLangText('Hi')},
|
||||||
|
|
||||||
|
@ -24,10 +24,10 @@ import Property from '../ascribe_forms/property';
|
|||||||
import AclProxy from '../acl_proxy';
|
import AclProxy from '../acl_proxy';
|
||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -120,7 +120,7 @@ const Edition = React.createClass({
|
|||||||
placeholder={getLangText('Enter your comments ...')}
|
placeholder={getLangText('Enter your comments ...')}
|
||||||
editable={true}
|
editable={true}
|
||||||
successMessage={getLangText('Private note saved')}
|
successMessage={getLangText('Private note saved')}
|
||||||
url={ApiUrls.note_private_edition} />
|
url={resolveUrl('note_private_edition')} />
|
||||||
<Note
|
<Note
|
||||||
id={() => {return {'bitcoin_id': edition.bitcoin_id}; }}
|
id={() => {return {'bitcoin_id': edition.bitcoin_id}; }}
|
||||||
label={getLangText('Personal note (public)')}
|
label={getLangText('Personal note (public)')}
|
||||||
@ -129,7 +129,7 @@ const Edition = React.createClass({
|
|||||||
editable={!!edition.acl.acl_edit}
|
editable={!!edition.acl.acl_edit}
|
||||||
show={!!(edition.public_note || edition.acl.acl_edit)}
|
show={!!(edition.public_note || edition.acl.acl_edit)}
|
||||||
successMessage={getLangText('Public edition note saved')}
|
successMessage={getLangText('Public edition note saved')}
|
||||||
url={ApiUrls.note_public_edition} />
|
url={resolveUrl('note_public_edition')} />
|
||||||
</CollapsibleParagraph>
|
</CollapsibleParagraph>
|
||||||
<CollapsibleParagraph
|
<CollapsibleParagraph
|
||||||
title={getLangText('Further Details')}
|
title={getLangText('Further Details')}
|
||||||
|
@ -26,9 +26,8 @@ import AclProxy from '../acl_proxy';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { routerShape } from '../prop_types';
|
import { routerShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
A component that handles all the actions inside of the edition detail
|
A component that handles all the actions inside of the edition detail
|
||||||
@ -121,7 +120,7 @@ const EditionActionPanel = React.createClass({
|
|||||||
aclObject={edition.acl}
|
aclObject={edition.acl}
|
||||||
aclName="acl_withdraw_transfer">
|
aclName="acl_withdraw_transfer">
|
||||||
<Form
|
<Form
|
||||||
url={ApiUrls.ownership_transfers_withdraw}
|
url={resolveUrl('ownership_transfers_withdraw')}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
className='inline'
|
className='inline'
|
||||||
isInline={true}>
|
isInline={true}>
|
||||||
@ -142,7 +141,7 @@ const EditionActionPanel = React.createClass({
|
|||||||
aclObject={edition.acl}
|
aclObject={edition.acl}
|
||||||
aclName="acl_withdraw_consign">
|
aclName="acl_withdraw_consign">
|
||||||
<Form
|
<Form
|
||||||
url={ApiUrls.ownership_consigns_withdraw}
|
url={resolveUrl('ownership_consigns_withdraw')}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
className='inline'
|
className='inline'
|
||||||
isInline={true}>
|
isInline={true}>
|
||||||
|
@ -12,8 +12,8 @@ import Edition from './edition';
|
|||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import { setDocumentTitle } from '../../utils/dom_utils';
|
import { setDocumentTitle } from '../../utils/dom';
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -15,7 +15,7 @@ import PieceExtraDataForm from './../ascribe_forms/form_piece_extradata';
|
|||||||
|
|
||||||
import { formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
import { formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let FurtherDetails = React.createClass({
|
let FurtherDetails = React.createClass({
|
||||||
|
@ -6,12 +6,12 @@ import Property from './../ascribe_forms/property';
|
|||||||
|
|
||||||
import ReactS3FineUploader from './../ascribe_uploader/react_s3_fine_uploader';
|
import ReactS3FineUploader from './../ascribe_uploader/react_s3_fine_uploader';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
import { validationTypes } from '../../constants/uploader_constants';
|
import { validationTypes } from '../../constants/uploader_constants';
|
||||||
|
|
||||||
import { getCookie } from '../../utils/fetch_api_utils';
|
import { makeCsrfHeader } from '../../utils/csrf';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
const { func, bool, number, object, string, arrayOf } = React.PropTypes;
|
const { func, bool, number, object, string, arrayOf } = React.PropTypes;
|
||||||
@ -75,16 +75,14 @@ let FurtherDetailsFileuploader = React.createClass({
|
|||||||
areAssetsDownloadable
|
areAssetsDownloadable
|
||||||
areAssetsEditable={editable}
|
areAssetsEditable={editable}
|
||||||
createBlobRoutine={{
|
createBlobRoutine={{
|
||||||
url: ApiUrls.blob_otherdatas,
|
url: resolveUrl('blob_otherdatas'),
|
||||||
pieceId: pieceId
|
pieceId: pieceId
|
||||||
}}
|
}}
|
||||||
deleteFile={{
|
deleteFile={{
|
||||||
enabled: true,
|
enabled: true,
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
endpoint: `${AppConstants.serverUrl}/s3/delete`,
|
endpoint: `${AppConstants.serverUrl}/s3/delete`,
|
||||||
customHeaders: {
|
customHeaders: makeCsrfHeader()
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
|
||||||
}
|
|
||||||
}}
|
}}
|
||||||
isReadyForFormSubmission={isReadyForFormSubmission}
|
isReadyForFormSubmission={isReadyForFormSubmission}
|
||||||
keyRoutine={{
|
keyRoutine={{
|
||||||
@ -97,9 +95,7 @@ let FurtherDetailsFileuploader = React.createClass({
|
|||||||
setIsUploadReady={setIsUploadReady}
|
setIsUploadReady={setIsUploadReady}
|
||||||
session={{
|
session={{
|
||||||
endpoint: `${AppConstants.serverUrl}/api/blob/otherdatas/fineuploader_session/`,
|
endpoint: `${AppConstants.serverUrl}/api/blob/otherdatas/fineuploader_session/`,
|
||||||
customHeaders: {
|
customHeaders: makeCsrfHeader(),
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
|
||||||
},
|
|
||||||
params: {
|
params: {
|
||||||
'pk': otherDataIds
|
'pk': otherDataIds
|
||||||
},
|
},
|
||||||
@ -110,9 +106,7 @@ let FurtherDetailsFileuploader = React.createClass({
|
|||||||
}}
|
}}
|
||||||
signature={{
|
signature={{
|
||||||
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
|
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
|
||||||
customHeaders: {
|
customHeaders: makeCsrfHeader()
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
|
||||||
}
|
|
||||||
}}
|
}}
|
||||||
submitFile={submitFile}
|
submitFile={submitFile}
|
||||||
showErrorPrompt={showErrorPrompt}
|
showErrorPrompt={showErrorPrompt}
|
||||||
|
@ -5,8 +5,6 @@ import React from 'react';
|
|||||||
import Form from '../ascribe_forms/form';
|
import Form from '../ascribe_forms/form';
|
||||||
import Property from '../ascribe_forms/property';
|
import Property from '../ascribe_forms/property';
|
||||||
|
|
||||||
import { replaceSubstringAtIndex } from '../../utils/general_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let HistoryIterator = React.createClass({
|
let HistoryIterator = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -18,7 +16,7 @@ let HistoryIterator = React.createClass({
|
|||||||
// We want to get the capturing group without the quotes,
|
// We want to get the capturing group without the quotes,
|
||||||
// which is why we access the match list at index 1 and not 0
|
// which is why we access the match list at index 1 and not 0
|
||||||
const contractName = historicalEvent[1].match(/\"(.*)\"/)[1];
|
const contractName = historicalEvent[1].match(/\"(.*)\"/)[1];
|
||||||
const historicalEventDescription = replaceSubstringAtIndex(historicalEvent[1], `"${contractName}"`, '');
|
const historicalEventDescription = historicalEvent[1].replace(`"${contractName}"`, '');
|
||||||
return (
|
return (
|
||||||
<span>
|
<span>
|
||||||
{historicalEventDescription}
|
{historicalEventDescription}
|
||||||
|
@ -22,8 +22,8 @@ import { currentUserShape } from '../prop_types';
|
|||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
|
|
||||||
import { extractFileExtensionFromUrl } from '../../utils/file_utils';
|
import { extractFileExtensionFromUrl } from '../../utils/file';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const EMBED_IFRAME_HEIGHT = {
|
const EMBED_IFRAME_HEIGHT = {
|
||||||
|
@ -11,7 +11,7 @@ import InputTextAreaToggable from '../ascribe_forms/input_textarea_toggable';
|
|||||||
|
|
||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
let Note = React.createClass({
|
let Note = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -39,11 +39,10 @@ import AscribeSpinner from '../ascribe_spinner';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { routerShape } from '../prop_types';
|
import { routerShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import { setDocumentTitle } from '../../utils/dom';
|
||||||
|
import { safeMerge } from '../../utils/general';
|
||||||
import { setDocumentTitle } from '../../utils/dom_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is the component that implements resource/data specific functionality
|
* This is the component that implements resource/data specific functionality
|
||||||
@ -69,7 +68,7 @@ const PieceContainer = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
PieceListStore.getState(),
|
PieceListStore.getState(),
|
||||||
PieceStore.getInitialState(),
|
PieceStore.getInitialState(),
|
||||||
{
|
{
|
||||||
@ -121,7 +120,7 @@ const PieceContainer = React.createClass({
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
if (state && state.piece && state.piece.acl && typeof state.piece.acl.acl_loan !== 'undefined') {
|
if (state && state.piece && state.piece.acl && typeof state.piece.acl.acl_loan !== 'undefined') {
|
||||||
let pieceState = mergeOptions({}, state.piece);
|
const pieceState = Object.assign({}, state.piece);
|
||||||
pieceState.acl.acl_loan = false;
|
pieceState.acl.acl_loan = false;
|
||||||
this.setState({
|
this.setState({
|
||||||
piece: pieceState
|
piece: pieceState
|
||||||
@ -302,7 +301,7 @@ const PieceContainer = React.createClass({
|
|||||||
placeholder={getLangText('Enter your comments ...')}
|
placeholder={getLangText('Enter your comments ...')}
|
||||||
editable={true}
|
editable={true}
|
||||||
successMessage={getLangText('Private note saved')}
|
successMessage={getLangText('Private note saved')}
|
||||||
url={ApiUrls.note_private_piece} />
|
url={resolveUrl('note_private_piece')} />
|
||||||
<Note
|
<Note
|
||||||
id={this.getId}
|
id={this.getId}
|
||||||
label={getLangText('Personal note (public)')}
|
label={getLangText('Personal note (public)')}
|
||||||
@ -311,7 +310,7 @@ const PieceContainer = React.createClass({
|
|||||||
editable={!!piece.acl.acl_edit}
|
editable={!!piece.acl.acl_edit}
|
||||||
show={!!(piece.public_note || piece.acl.acl_edit)}
|
show={!!(piece.public_note || piece.acl.acl_edit)}
|
||||||
successMessage={getLangText('Public note saved')}
|
successMessage={getLangText('Public note saved')}
|
||||||
url={ApiUrls.note_public_piece} />
|
url={resolveUrl('note_public_piece')} />
|
||||||
</CollapsibleParagraph>
|
</CollapsibleParagraph>
|
||||||
<CollapsibleParagraph
|
<CollapsibleParagraph
|
||||||
title={getLangText('Further Details')}
|
title={getLangText('Further Details')}
|
||||||
|
@ -16,9 +16,9 @@ import withContext from '../context/with_context';
|
|||||||
import { currentUserShape } from '../prop_types';
|
import { currentUserShape } from '../prop_types';
|
||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
|
|
||||||
import { getAclFormMessage, getAclFormDataId } from '../../utils/form_utils';
|
import { getAclFormMessage, getAclFormDataId } from '../../utils/form';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
let AclFormFactory = React.createClass({
|
let AclFormFactory = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -86,7 +86,7 @@ let AclFormFactory = React.createClass({
|
|||||||
message={formMessage}
|
message={formMessage}
|
||||||
labels={labels}
|
labels={labels}
|
||||||
id={this.getFormDataId()}
|
id={this.getFormDataId()}
|
||||||
url={ApiUrls.ownership_consigns}
|
url={resolveUrl('ownership_consigns')}
|
||||||
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
||||||
);
|
);
|
||||||
} else if (action === 'acl_unconsign') {
|
} else if (action === 'acl_unconsign') {
|
||||||
@ -94,7 +94,7 @@ let AclFormFactory = React.createClass({
|
|||||||
<UnConsignForm
|
<UnConsignForm
|
||||||
message={formMessage}
|
message={formMessage}
|
||||||
id={this.getFormDataId()}
|
id={this.getFormDataId()}
|
||||||
url={ApiUrls.ownership_unconsigns}
|
url={resolveUrl('ownership_unconsigns')}
|
||||||
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
||||||
);
|
);
|
||||||
} else if (action === 'acl_transfer') {
|
} else if (action === 'acl_transfer') {
|
||||||
@ -102,7 +102,7 @@ let AclFormFactory = React.createClass({
|
|||||||
<TransferForm
|
<TransferForm
|
||||||
message={formMessage}
|
message={formMessage}
|
||||||
id={this.getFormDataId()}
|
id={this.getFormDataId()}
|
||||||
url={ApiUrls.ownership_transfers}
|
url={resolveUrl('ownership_transfers')}
|
||||||
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
||||||
);
|
);
|
||||||
} else if (action === 'acl_loan') {
|
} else if (action === 'acl_loan') {
|
||||||
@ -111,8 +111,8 @@ let AclFormFactory = React.createClass({
|
|||||||
email={email}
|
email={email}
|
||||||
message={formMessage}
|
message={formMessage}
|
||||||
id={this.getFormDataId()}
|
id={this.getFormDataId()}
|
||||||
url={this.isPiece() ? ApiUrls.ownership_loans_pieces
|
url={resolveUrl(this.isPiece() ? 'ownership_loans_pieces'
|
||||||
: ApiUrls.ownership_loans_editions}
|
: 'ownership_loans_editions')}
|
||||||
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
||||||
);
|
);
|
||||||
} else if (action === 'acl_loan_request') {
|
} else if (action === 'acl_loan_request') {
|
||||||
@ -120,7 +120,7 @@ let AclFormFactory = React.createClass({
|
|||||||
<LoanRequestAnswerForm
|
<LoanRequestAnswerForm
|
||||||
message={formMessage}
|
message={formMessage}
|
||||||
id={this.getFormDataId()}
|
id={this.getFormDataId()}
|
||||||
url={ApiUrls.ownership_loans_pieces_request_confirm}
|
url={resolveUrl('ownership_loans_pieces_request_confirm')}
|
||||||
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
||||||
);
|
);
|
||||||
} else if (action === 'acl_share') {
|
} else if (action === 'acl_share') {
|
||||||
@ -128,8 +128,8 @@ let AclFormFactory = React.createClass({
|
|||||||
<ShareForm
|
<ShareForm
|
||||||
message={formMessage}
|
message={formMessage}
|
||||||
id={this.getFormDataId()}
|
id={this.getFormDataId()}
|
||||||
url={this.isPiece() ? ApiUrls.ownership_shares_pieces
|
url={resolveUrl(this.isPiece() ? 'ownership_shares_pieces'
|
||||||
: ApiUrls.ownership_shares_editions}
|
: 'ownership_shares_editions')}
|
||||||
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
handleSuccess={showNotification ? this.showSuccessNotification : handleSuccess} />
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
@ -9,9 +9,9 @@ import GlobalNotificationModel from '../../models/global_notification_model';
|
|||||||
import GlobalNotificationActions from '../../actions/global_notification_actions';
|
import GlobalNotificationActions from '../../actions/global_notification_actions';
|
||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
let CreateEditionsForm = React.createClass({
|
let CreateEditionsForm = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -40,7 +40,7 @@ let CreateEditionsForm = React.createClass({
|
|||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.editions}
|
url={resolveUrl('editions')}
|
||||||
getFormData={this.getFormData}
|
getFormData={this.getFormData}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -11,10 +11,10 @@ import AlertDismissable from './alert';
|
|||||||
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 requests from '../../utils/requests';
|
import { sanitize } from '../../utils/general';
|
||||||
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import request from '../../utils/request';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
|
||||||
import { sanitize } from '../../utils/general_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let Form = React.createClass({
|
let Form = React.createClass({
|
||||||
@ -95,32 +95,29 @@ let Form = React.createClass({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
post() {
|
request(method) {
|
||||||
requests
|
request(this.props.url, {
|
||||||
.post(this.props.url, { body: this.getFormData() })
|
method,
|
||||||
|
jsonBody: this.getFormData()
|
||||||
|
})
|
||||||
.then(this.handleSuccess)
|
.then(this.handleSuccess)
|
||||||
.catch(this.handleError);
|
.catch(this.handleError);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
post() {
|
||||||
|
this.request('POST');
|
||||||
|
},
|
||||||
|
|
||||||
put() {
|
put() {
|
||||||
requests
|
this.request('PUT');
|
||||||
.put(this.props.url, { body: this.getFormData() })
|
|
||||||
.then(this.handleSuccess)
|
|
||||||
.catch(this.handleError);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
patch() {
|
patch() {
|
||||||
requests
|
this.request('PATCH');
|
||||||
.patch(this.props.url, { body: this.getFormData() })
|
|
||||||
.then(this.handleSuccess)
|
|
||||||
.catch(this.handleError);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
delete() {
|
delete() {
|
||||||
requests
|
this.request('DELETE');
|
||||||
.delete(this.props.url, this.getFormData())
|
|
||||||
.then(this.handleSuccess)
|
|
||||||
.catch(this.handleError);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
getFormData() {
|
getFormData() {
|
||||||
@ -370,7 +367,7 @@ let Form = React.createClass({
|
|||||||
const validatedRef = this._hasRefErrors(refToValidate);
|
const validatedRef = this._hasRefErrors(refToValidate);
|
||||||
validatedFormInputs[refName] = validatedRef;
|
validatedFormInputs[refName] = validatedRef;
|
||||||
});
|
});
|
||||||
const errorMessagesForRefs = sanitize(validatedFormInputs, (val) => !val);
|
const errorMessagesForRefs = sanitize(validatedFormInputs);
|
||||||
this.handleError({ json: { errors: errorMessagesForRefs } });
|
this.handleError({ json: { errors: errorMessagesForRefs } });
|
||||||
return !Object.keys(errorMessagesForRefs).length;
|
return !Object.keys(errorMessagesForRefs).length;
|
||||||
},
|
},
|
||||||
|
@ -15,7 +15,7 @@ import AscribeSpinner from '../ascribe_spinner';
|
|||||||
|
|
||||||
import AclInformation from '../ascribe_buttons/acl_information';
|
import AclInformation from '../ascribe_buttons/acl_information';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
let ConsignForm = React.createClass({
|
let ConsignForm = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -11,10 +11,10 @@ import Property from './property';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { currentUserShape } from '../prop_types';
|
import { currentUserShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
const { bool } = React.PropTypes;
|
const { bool } = React.PropTypes;
|
||||||
@ -50,7 +50,7 @@ const CopyrightAssociationForm = React.createClass({
|
|||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.users_profile}
|
url={resolveUrl('users_profile')}
|
||||||
getFormData={this.getProfileFormData}
|
getFormData={this.getProfileFormData}
|
||||||
handleSuccess={this.handleSubmitSuccess}>
|
handleSuccess={this.handleSubmitSuccess}>
|
||||||
<Property
|
<Property
|
||||||
|
@ -12,12 +12,12 @@ import InputFineUploader from './input_fineuploader';
|
|||||||
import Form from '../ascribe_forms/form';
|
import Form from '../ascribe_forms/form';
|
||||||
import Property from '../ascribe_forms/property';
|
import Property from '../ascribe_forms/property';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
import { validationTypes } from '../../constants/uploader_constants';
|
import { validationTypes } from '../../constants/uploader_constants';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import { formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
import { formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let CreateContractForm = React.createClass({
|
let CreateContractForm = React.createClass({
|
||||||
@ -64,7 +64,7 @@ let CreateContractForm = React.createClass({
|
|||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.ownership_contract_list}
|
url={resolveUrl('ownership_contract_list')}
|
||||||
handleSuccess={this.handleCreateSuccess}>
|
handleSuccess={this.handleCreateSuccess}>
|
||||||
<Property
|
<Property
|
||||||
name="blob"
|
name="blob"
|
||||||
@ -76,7 +76,7 @@ let CreateContractForm = React.createClass({
|
|||||||
fileClass: 'contract'
|
fileClass: 'contract'
|
||||||
}}
|
}}
|
||||||
createBlobRoutine={{
|
createBlobRoutine={{
|
||||||
url: ApiUrls.blob_contracts
|
url: resolveUrl('blob_contracts')
|
||||||
}}
|
}}
|
||||||
validation={{
|
validation={{
|
||||||
itemLimit: validationTypes.additionalData.itemLimit,
|
itemLimit: validationTypes.additionalData.itemLimit,
|
||||||
|
@ -4,11 +4,14 @@ import React from 'react';
|
|||||||
|
|
||||||
import Form from './form';
|
import Form from './form';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import AclInformation from '../ascribe_buttons/acl_information';
|
||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import AclInformation from '../ascribe_buttons/acl_information';
|
import { formatText } from '../../utils/text';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let EditionDeleteForm = React.createClass({
|
let EditionDeleteForm = React.createClass({
|
||||||
|
|
||||||
@ -20,25 +23,22 @@ let EditionDeleteForm = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getBitcoinIds() {
|
getBitcoinIds() {
|
||||||
return this.props.editions.map(function(edition){
|
return this.props.editions.map((edition) => edition.bitcoin_id);
|
||||||
return edition.bitcoin_id;
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// Since this form can be used for either deleting a single edition or multiple
|
getUrl() {
|
||||||
// we need to call getBitcoinIds to get the value of edition_id
|
return formatText(resolveUrl('edition_delete'), {
|
||||||
getFormData() {
|
// Since this form can be used for either deleting a single edition or multiple we need
|
||||||
return {
|
// to call getBitcoinIds to get the value of edition_id
|
||||||
edition_id: this.getBitcoinIds().join(',')
|
editionId: this.getBitcoinIds().join(',')
|
||||||
};
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.edition_delete}
|
url={this.getUrl()}
|
||||||
getFormData={this.getFormData}
|
|
||||||
method="delete"
|
method="delete"
|
||||||
handleSuccess={this.props.handleSuccess}
|
handleSuccess={this.props.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -6,10 +6,11 @@ import Form from '../ascribe_forms/form';
|
|||||||
|
|
||||||
import AclInformation from '../ascribe_buttons/acl_information';
|
import AclInformation from '../ascribe_buttons/acl_information';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { formatText } from '../../utils/text';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let PieceDeleteForm = React.createClass({
|
let PieceDeleteForm = React.createClass({
|
||||||
@ -20,18 +21,17 @@ let PieceDeleteForm = React.createClass({
|
|||||||
handleSuccess: React.PropTypes.func
|
handleSuccess: React.PropTypes.func
|
||||||
},
|
},
|
||||||
|
|
||||||
getFormData() {
|
getUrl() {
|
||||||
return {
|
return formatText(resolveUrl('piece'), {
|
||||||
piece_id: this.props.pieceId
|
pieceId: this.props.pieceId
|
||||||
};
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.piece}
|
url={this.getUrl()}
|
||||||
getFormData={this.getFormData}
|
|
||||||
method="delete"
|
method="delete"
|
||||||
handleSuccess={this.props.handleSuccess}
|
handleSuccess={this.props.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -5,21 +5,17 @@ import classnames from 'classnames';
|
|||||||
|
|
||||||
import Button from 'react-bootstrap/lib/Button';
|
import Button from 'react-bootstrap/lib/Button';
|
||||||
|
|
||||||
import ContractAgreementListStore from '../../stores/contract_agreement_list_store';
|
|
||||||
|
|
||||||
import Form from './form';
|
import Form from './form';
|
||||||
import Property from './property';
|
import Property from './property';
|
||||||
|
|
||||||
import InputDate from './input_date';
|
import InputDate from './input_date';
|
||||||
import InputTextAreaToggable from './input_textarea_toggable';
|
import InputTextAreaToggable from './input_textarea_toggable';
|
||||||
import InputContractAgreementCheckbox from './input_contract_agreement_checkbox';
|
import InputContractAgreementCheckbox from './input_contract_agreement_checkbox';
|
||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
|
||||||
|
|
||||||
import AclInformation from '../ascribe_buttons/acl_information';
|
import AclInformation from '../ascribe_buttons/acl_information';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
|
||||||
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let LoanForm = React.createClass({
|
let LoanForm = React.createClass({
|
||||||
|
@ -3,14 +3,10 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Moment from 'moment';
|
import Moment from 'moment';
|
||||||
|
|
||||||
import LoanForm from './form_loan';
|
|
||||||
|
|
||||||
import OwnershipActions from '../../actions/ownership_actions';
|
import OwnershipActions from '../../actions/ownership_actions';
|
||||||
import OwnershipStore from '../../stores/ownership_store';
|
import OwnershipStore from '../../stores/ownership_store';
|
||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import LoanForm from './form_loan';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let LoanRequestAnswerForm = React.createClass({
|
let LoanRequestAnswerForm = React.createClass({
|
||||||
|
@ -14,9 +14,8 @@ import AscribeSpinner from '../ascribe_spinner';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { locationShape } from '../prop_types';
|
import { locationShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let LoginForm = React.createClass({
|
let LoginForm = React.createClass({
|
||||||
@ -55,7 +54,7 @@ let LoginForm = React.createClass({
|
|||||||
<Form
|
<Form
|
||||||
className="ascribe-form-bordered"
|
className="ascribe-form-bordered"
|
||||||
ref="loginForm"
|
ref="loginForm"
|
||||||
url={ApiUrls.users_login}
|
url={resolveUrl('users_login')}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
autoComplete="on"
|
autoComplete="on"
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -2,15 +2,15 @@
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import requests from '../../utils/requests';
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
|
|
||||||
import Form from './form';
|
import Form from './form';
|
||||||
import Property from './property';
|
import Property from './property';
|
||||||
import InputTextAreaToggable from './input_textarea_toggable';
|
import InputTextAreaToggable from './input_textarea_toggable';
|
||||||
|
|
||||||
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
import { formatText } from '../../utils/text';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let PieceExtraDataForm = React.createClass({
|
let PieceExtraDataForm = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
name: React.PropTypes.string.isRequired,
|
name: React.PropTypes.string.isRequired,
|
||||||
@ -24,16 +24,24 @@ let PieceExtraDataForm = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getFormData() {
|
getFormData() {
|
||||||
|
const { name, pieceId } = this.props;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
extradata: {
|
extradata: {
|
||||||
[this.props.name]: this.refs.form.refs[this.props.name].state.value
|
[name]: this.refs.form.refs[name].state.value
|
||||||
},
|
},
|
||||||
piece_id: this.props.pieceId
|
piece_id: pieceId
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getUrl() {
|
||||||
|
return formatText(resolveUrl('piece_extradata'), {
|
||||||
|
pieceId: this.props.pieceId
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { convertLinks, editable, extraData, handleSuccess, name, pieceId, title } = this.props;
|
const { convertLinks, editable, extraData, handleSuccess, name, title } = this.props;
|
||||||
const defaultValue = (extraData && extraData[name]) || null;
|
const defaultValue = (extraData && extraData[name]) || null;
|
||||||
|
|
||||||
if (!defaultValue && !editable) {
|
if (!defaultValue && !editable) {
|
||||||
@ -46,7 +54,7 @@ let PieceExtraDataForm = React.createClass({
|
|||||||
disabled={!editable}
|
disabled={!editable}
|
||||||
getFormData={this.getFormData}
|
getFormData={this.getFormData}
|
||||||
handleSuccess={handleSuccess}
|
handleSuccess={handleSuccess}
|
||||||
url={requests.prepareUrl(ApiUrls.piece_extradata, { piece_id: pieceId })}>
|
url={this.getUrl()}>
|
||||||
<Property
|
<Property
|
||||||
name={name}
|
name={name}
|
||||||
label={title}>
|
label={title}>
|
||||||
|
@ -14,12 +14,12 @@ import AscribeSpinner from '../ascribe_spinner';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { currentUserShape, locationShape } from '../prop_types';
|
import { currentUserShape, locationShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
import { validationParts, validationTypes } from '../../constants/uploader_constants';
|
import { validationParts, validationTypes } from '../../constants/uploader_constants';
|
||||||
|
|
||||||
import { FileStatus, formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
import { FileStatus, formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let RegisterPieceForm = React.createClass({
|
let RegisterPieceForm = React.createClass({
|
||||||
@ -138,7 +138,7 @@ let RegisterPieceForm = React.createClass({
|
|||||||
disabled={disabled}
|
disabled={disabled}
|
||||||
className="ascribe-form-bordered"
|
className="ascribe-form-bordered"
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.pieces_list}
|
url={resolveUrl('pieces_list')}
|
||||||
handleSuccess={handleSuccess}
|
handleSuccess={handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
<FormSubmitButton
|
<FormSubmitButton
|
||||||
@ -168,7 +168,7 @@ let RegisterPieceForm = React.createClass({
|
|||||||
fileClass: 'digitalwork'
|
fileClass: 'digitalwork'
|
||||||
}}
|
}}
|
||||||
createBlobRoutine={{
|
createBlobRoutine={{
|
||||||
url: ApiUrls.blob_digitalworks
|
url: resolveUrl('blob_digitalworks')
|
||||||
}}
|
}}
|
||||||
validation={validationTypes.registerWork}
|
validation={validationTypes.registerWork}
|
||||||
setIsUploadReady={this.setIsUploadReady('digitalWorkKeyReady')}
|
setIsUploadReady={this.setIsUploadReady('digitalWorkKeyReady')}
|
||||||
@ -187,7 +187,7 @@ let RegisterPieceForm = React.createClass({
|
|||||||
ref={ref => this.refs.thumbnailFineUploader = ref}
|
ref={ref => this.refs.thumbnailFineUploader = ref}
|
||||||
fileInputElement={UploadButton({ className: 'btn btn-secondary btn-sm' })}
|
fileInputElement={UploadButton({ className: 'btn btn-secondary btn-sm' })}
|
||||||
createBlobRoutine={{
|
createBlobRoutine={{
|
||||||
url: ApiUrls.blob_thumbnails
|
url: resolveUrl('blob_thumbnails')
|
||||||
}}
|
}}
|
||||||
handleChangedFile={this.handleChangedThumbnail}
|
handleChangedFile={this.handleChangedThumbnail}
|
||||||
onValidationFailed={this.handleThumbnailValidationFailed}
|
onValidationFailed={this.handleThumbnailValidationFailed}
|
||||||
|
@ -4,10 +4,11 @@ import React from 'react';
|
|||||||
|
|
||||||
import Form from './form';
|
import Form from './form';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { formatText } from '../../utils/text';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
let EditionRemoveFromCollectionForm = React.createClass({
|
let EditionRemoveFromCollectionForm = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -18,25 +19,22 @@ let EditionRemoveFromCollectionForm = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getBitcoinIds() {
|
getBitcoinIds() {
|
||||||
return this.props.editions.map(function(edition){
|
return this.props.editions.map((edition) => edition.bitcoin_id);
|
||||||
return edition.bitcoin_id;
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// Since this form can be used for either removing a single edition or multiple
|
getUrl() {
|
||||||
// we need to call getBitcoinIds to get the value of edition_id
|
return formatText(resolveUrl('edition_remove_from_collection'), {
|
||||||
getFormData() {
|
// Since this form can be used for either deleting a single edition or multiple we need
|
||||||
return {
|
// to call getBitcoinIds to get the value of edition_id
|
||||||
edition_id: this.getBitcoinIds().join(',')
|
editionId: this.getBitcoinIds().join(',')
|
||||||
};
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.edition_remove_from_collection}
|
url={this.getUrl()}
|
||||||
getFormData={this.getFormData}
|
|
||||||
method="delete"
|
method="delete"
|
||||||
handleSuccess={this.props.handleSuccess}
|
handleSuccess={this.props.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -4,10 +4,10 @@ import React from 'react';
|
|||||||
|
|
||||||
import Form from './form';
|
import Form from './form';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let PieceRemoveFromCollectionForm = React.createClass({
|
let PieceRemoveFromCollectionForm = React.createClass({
|
||||||
@ -18,18 +18,17 @@ let PieceRemoveFromCollectionForm = React.createClass({
|
|||||||
handleSuccess: React.PropTypes.func
|
handleSuccess: React.PropTypes.func
|
||||||
},
|
},
|
||||||
|
|
||||||
getFormData() {
|
getUrl() {
|
||||||
return {
|
return formatText(resolveUrl('piece_remove_from_collection'), {
|
||||||
piece_id: this.props.pieceId
|
pieceId: this.props.pieceId
|
||||||
};
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
render () {
|
render () {
|
||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.piece_remove_from_collection}
|
url={this.getUrl()}
|
||||||
getFormData={this.getFormData}
|
|
||||||
method="delete"
|
method="delete"
|
||||||
handleSuccess={this.props.handleSuccess}
|
handleSuccess={this.props.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -14,10 +14,9 @@ import NotificationActions from '../../actions/notification_actions';
|
|||||||
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 ApiUrls from '../../constants/api_urls';
|
import { getAclFormDataId } from '../../utils/form';
|
||||||
|
import { getLangText } from '../../utils/lang.js';
|
||||||
import { getAclFormDataId } from '../../utils/form_utils';
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
|
||||||
|
|
||||||
let RequestActionForm = React.createClass({
|
let RequestActionForm = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -35,25 +34,30 @@ let RequestActionForm = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getUrls() {
|
getUrls() {
|
||||||
let urls = {};
|
const urls = {};
|
||||||
|
|
||||||
if (this.props.notifications.action === 'consign') {
|
if (this.props.notifications.action === 'consign') {
|
||||||
urls.accept = ApiUrls.ownership_consigns_confirm;
|
urls.accept = 'ownership_consigns_confirm';
|
||||||
urls.deny = ApiUrls.ownership_consigns_deny;
|
urls.deny = 'ownership_consigns_deny';
|
||||||
} else if (this.props.notifications.action === 'unconsign') {
|
} else if (this.props.notifications.action === 'unconsign') {
|
||||||
urls.accept = ApiUrls.ownership_unconsigns;
|
urls.accept = 'ownership_unconsigns';
|
||||||
urls.deny = ApiUrls.ownership_unconsigns_deny;
|
urls.deny = 'ownership_unconsigns_deny';
|
||||||
} else if (this.props.notifications.action === 'loan' && !this.isPiece()) {
|
} else if (this.props.notifications.action === 'loan' && !this.isPiece()) {
|
||||||
urls.accept = ApiUrls.ownership_loans_confirm;
|
urls.accept = 'ownership_loans_confirm';
|
||||||
urls.deny = ApiUrls.ownership_loans_deny;
|
urls.deny = 'ownership_loans_deny';
|
||||||
} else if (this.props.notifications.action === 'loan' && this.isPiece()) {
|
} else if (this.props.notifications.action === 'loan' && this.isPiece()) {
|
||||||
urls.accept = ApiUrls.ownership_loans_pieces_confirm;
|
urls.accept = 'ownership_loans_pieces_confirm';
|
||||||
urls.deny = ApiUrls.ownership_loans_pieces_deny;
|
urls.deny = 'ownership_loans_pieces_deny';
|
||||||
} else if (this.props.notifications.action === 'loan_request' && this.isPiece()) {
|
} else if (this.props.notifications.action === 'loan_request' && this.isPiece()) {
|
||||||
urls.accept = ApiUrls.ownership_loans_pieces_request_confirm;
|
urls.accept = 'ownership_loans_pieces_request_confirm';
|
||||||
urls.deny = ApiUrls.ownership_loans_pieces_request_deny;
|
urls.deny = 'ownership_loans_pieces_request_deny';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Resolve the urls
|
||||||
|
Object.entries(urls).forEach(([key, val]) => {
|
||||||
|
urls[key] = resolveUrl(val);
|
||||||
|
});
|
||||||
|
|
||||||
return urls;
|
return urls;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -16,10 +16,9 @@ import AscribeSpinner from '../ascribe_spinner';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { routerShape } from '../prop_types';
|
import { routerShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import { safeMerge } from '../../utils/general';
|
||||||
|
import { getLangText } from '../../utils/lang';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
|
||||||
|
|
||||||
|
|
||||||
const SendContractAgreementForm = React.createClass({
|
const SendContractAgreementForm = React.createClass({
|
||||||
@ -31,7 +30,7 @@ const SendContractAgreementForm = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
ContractListStore.getState(),
|
ContractListStore.getState(),
|
||||||
{
|
{
|
||||||
selectedContract: 0
|
selectedContract: 0
|
||||||
@ -103,7 +102,7 @@ const SendContractAgreementForm = React.createClass({
|
|||||||
<Form
|
<Form
|
||||||
className="ascribe-form-bordered ascribe-form-wrapper"
|
className="ascribe-form-bordered ascribe-form-wrapper"
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.ownership_contract_agreements}
|
url={resolveUrl('ownership_contract_agreements')}
|
||||||
getFormData={this.getFormData}
|
getFormData={this.getFormData}
|
||||||
handleSuccess={this.handleSubmitSuccess}
|
handleSuccess={this.handleSubmitSuccess}
|
||||||
buttons={<button
|
buttons={<button
|
||||||
|
@ -2,17 +2,17 @@
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
|
import Button from 'react-bootstrap/lib/Button';
|
||||||
|
|
||||||
import Form from './form';
|
import Form from './form';
|
||||||
import Property from './property';
|
import Property from './property';
|
||||||
import InputTextAreaToggable from './input_textarea_toggable';
|
import InputTextAreaToggable from './input_textarea_toggable';
|
||||||
|
|
||||||
import Button from 'react-bootstrap/lib/Button';
|
|
||||||
|
|
||||||
import AclInformation from '../ascribe_buttons/acl_information';
|
import AclInformation from '../ascribe_buttons/acl_information';
|
||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
|
|
||||||
let ShareForm = React.createClass({
|
let ShareForm = React.createClass({
|
||||||
|
@ -15,9 +15,8 @@ import AscribeSpinner from '../ascribe_spinner';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { locationShape } from '../prop_types';
|
import { locationShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let SignupForm = React.createClass({
|
let SignupForm = React.createClass({
|
||||||
@ -71,7 +70,7 @@ let SignupForm = React.createClass({
|
|||||||
<Form
|
<Form
|
||||||
className="ascribe-form-bordered"
|
className="ascribe-form-bordered"
|
||||||
ref='form'
|
ref='form'
|
||||||
url={ApiUrls.users_signup}
|
url={resolveUrl('users_signup')}
|
||||||
getFormData={this.getFormData}
|
getFormData={this.getFormData}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -13,7 +13,7 @@ import AclInformation from '../ascribe_buttons/acl_information';
|
|||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
|
|
||||||
let TransferForm = React.createClass({
|
let TransferForm = React.createClass({
|
||||||
|
@ -9,7 +9,8 @@ import Property from './property';
|
|||||||
import InputTextAreaToggable from './input_textarea_toggable';
|
import InputTextAreaToggable from './input_textarea_toggable';
|
||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
|
||||||
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
|
|
||||||
let UnConsignForm = React.createClass({
|
let UnConsignForm = React.createClass({
|
||||||
|
@ -9,7 +9,8 @@ import Property from './property';
|
|||||||
import InputTextAreaToggable from './input_textarea_toggable';
|
import InputTextAreaToggable from './input_textarea_toggable';
|
||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
|
||||||
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
|
|
||||||
let UnConsignRequestForm = React.createClass({
|
let UnConsignRequestForm = React.createClass({
|
||||||
|
@ -8,9 +8,9 @@ import InputCheckbox from './input_checkbox';
|
|||||||
import ContractAgreementListStore from '../../stores/contract_agreement_list_store';
|
import ContractAgreementListStore from '../../stores/contract_agreement_list_store';
|
||||||
import ContractAgreementListActions from '../../actions/contract_agreement_list_actions';
|
import ContractAgreementListActions from '../../actions/contract_agreement_list_actions';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { safeMerge } from '../../utils/general';
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import { isEmail } from '../../utils/regex_utils';
|
import { isEmail } from '../../utils/regex';
|
||||||
|
|
||||||
|
|
||||||
const InputContractAgreementCheckbox = React.createClass({
|
const InputContractAgreementCheckbox = React.createClass({
|
||||||
@ -37,7 +37,7 @@ const InputContractAgreementCheckbox = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
ContractAgreementListStore.getState(),
|
ContractAgreementListStore.getState(),
|
||||||
{
|
{
|
||||||
value: {
|
value: {
|
||||||
@ -73,7 +73,7 @@ const InputContractAgreementCheckbox = React.createClass({
|
|||||||
// If there is no contract available, hide this `Property` from the user
|
// If there is no contract available, hide this `Property` from the user
|
||||||
this.props.setExpanded(!!contractAgreement);
|
this.props.setExpanded(!!contractAgreement);
|
||||||
|
|
||||||
state = mergeOptions(state, {
|
this.setState({
|
||||||
value: {
|
value: {
|
||||||
// If `email` is defined in this component, `getContractAgreementsOrCreatePublic`
|
// If `email` is defined in this component, `getContractAgreementsOrCreatePublic`
|
||||||
// is either:
|
// is either:
|
||||||
@ -93,8 +93,6 @@ const InputContractAgreementCheckbox = React.createClass({
|
|||||||
terms: !contractAgreement || !!contractAgreement.datetime_accepted
|
terms: !contractAgreement || !!contractAgreement.datetime_accepted
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
this.setState(state);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
onChange(event) {
|
onChange(event) {
|
||||||
|
@ -7,10 +7,10 @@ import FileDragAndDrop from '../ascribe_uploader/ascribe_file_drag_and_drop/file
|
|||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
|
|
||||||
import { getCookie } from '../../utils/fetch_api_utils';
|
import { makeCsrfHeader } from '../../utils/csrf';
|
||||||
|
|
||||||
|
|
||||||
const { func, bool, shape, string, number, element, oneOf, oneOfType, arrayOf } = React.PropTypes;
|
const { func, bool, oneOf } = React.PropTypes;
|
||||||
|
|
||||||
const InputFineUploader = React.createClass({
|
const InputFineUploader = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -122,17 +122,13 @@ const InputFineUploader = React.createClass({
|
|||||||
showErrorPrompt={showErrorPrompt}
|
showErrorPrompt={showErrorPrompt}
|
||||||
signature={{
|
signature={{
|
||||||
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
|
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
|
||||||
customHeaders: {
|
customHeaders: makeCsrfHeader()
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
|
||||||
}
|
|
||||||
}}
|
}}
|
||||||
deleteFile={{
|
deleteFile={{
|
||||||
enabled: true,
|
enabled: true,
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
endpoint: `${AppConstants.serverUrl}/s3/delete`,
|
endpoint: `${AppConstants.serverUrl}/s3/delete`,
|
||||||
customHeaders: {
|
customHeaders: makeCsrfHeader()
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
|
||||||
}
|
|
||||||
}}
|
}}
|
||||||
enableLocalHashing={enableLocalHashing}
|
enableLocalHashing={enableLocalHashing}
|
||||||
uploadMethod={uploadMethod}
|
uploadMethod={uploadMethod}
|
||||||
|
@ -4,7 +4,7 @@ import React from 'react';
|
|||||||
|
|
||||||
import TextareaAutosize from 'react-textarea-autosize';
|
import TextareaAutosize from 'react-textarea-autosize';
|
||||||
|
|
||||||
import { anchorize } from '../../utils/dom_utils';
|
import { anchorize } from '../../utils/dom';
|
||||||
|
|
||||||
|
|
||||||
let InputTextAreaToggable = React.createClass({
|
let InputTextAreaToggable = React.createClass({
|
||||||
|
@ -1,19 +1,15 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Q from 'q';
|
|
||||||
|
|
||||||
import Panel from 'react-bootstrap/lib/Panel';
|
import Panel from 'react-bootstrap/lib/Panel';
|
||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
|
||||||
|
|
||||||
import audiojs from '../../third_party/imports/audiojs';
|
import audiojs from '../../third_party/imports/audiojs';
|
||||||
import shmui from '../../third_party/imports/shmui';
|
import shmui from '../../third_party/imports/shmui';
|
||||||
import videojs from '../../third_party/imports/videojs';
|
import videojs from '../../third_party/imports/videojs';
|
||||||
|
|
||||||
import { escapeHTML } from '../../utils/general_utils';
|
import { escapeHTML } from '../../utils/dom';
|
||||||
import { extractFileExtensionFromUrl } from '../../utils/file_utils';
|
import { extractFileExtensionFromUrl } from '../../utils/file';
|
||||||
import { InjectInHeadUtils } from '../../utils/inject_utils';
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,34 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
import ModalWrapper from './modal_wrapper';
|
|
||||||
import PasswordResetRequestForm from '../ascribe_forms/form_password_reset_request';
|
|
||||||
|
|
||||||
import GlobalNotificationModel from '../../models/global_notification_model';
|
|
||||||
import GlobalNotificationActions from '../../actions/global_notification_actions';
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
|
||||||
|
|
||||||
let PasswordResetRequestModal = React.createClass({
|
|
||||||
propTypes: {
|
|
||||||
button: React.PropTypes.element
|
|
||||||
},
|
|
||||||
|
|
||||||
handleResetSuccess(){
|
|
||||||
let notificationText = getLangText('Request successfully sent, check your email');
|
|
||||||
let notification = new GlobalNotificationModel(notificationText, 'success', 50000);
|
|
||||||
GlobalNotificationActions.appendGlobalNotification(notification);
|
|
||||||
},
|
|
||||||
render() {
|
|
||||||
return (
|
|
||||||
<ModalWrapper
|
|
||||||
trigger={this.props.button}
|
|
||||||
title={getLangText('Reset your password')}
|
|
||||||
handleSuccess={this.handleResetSuccess}>
|
|
||||||
<PasswordResetRequestForm />
|
|
||||||
</ModalWrapper>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export default PasswordResetRequestModal;
|
|
@ -4,7 +4,7 @@ import React from 'react';
|
|||||||
import Link from 'react-router/es6/Link';
|
import Link from 'react-router/es6/Link';
|
||||||
|
|
||||||
import Glyphicon from 'react-bootstrap/lib/Glyphicon';
|
import Glyphicon from 'react-bootstrap/lib/Glyphicon';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let PaginationButton = React.createClass({
|
let PaginationButton = React.createClass({
|
||||||
|
@ -2,13 +2,12 @@
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import { mergeOptions } from '../../utils/general_utils';
|
|
||||||
|
|
||||||
import EditionListActions from '../../actions/edition_list_actions';
|
import EditionListActions from '../../actions/edition_list_actions';
|
||||||
|
|
||||||
import PieceListBulkModalSelectedEditionsWidget from './piece_list_bulk_modal_selected_editions_widget';
|
import PieceListBulkModalSelectedEditionsWidget from './piece_list_bulk_modal_selected_editions_widget';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
|
|
||||||
let PieceListBulkModal = React.createClass({
|
let PieceListBulkModal = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
|
||||||
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
let PieceListBulkModalSelectedEditionsWidget = React.createClass({
|
let PieceListBulkModalSelectedEditionsWidget = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -4,7 +4,7 @@ import React from 'react';
|
|||||||
|
|
||||||
import DropdownButton from 'react-bootstrap/lib/DropdownButton';
|
import DropdownButton from 'react-bootstrap/lib/DropdownButton';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
|
|
||||||
let PieceListToolbarFilterWidget = React.createClass({
|
let PieceListToolbarFilterWidget = React.createClass({
|
||||||
|
@ -4,7 +4,7 @@ import React from 'react';
|
|||||||
|
|
||||||
import DropdownButton from 'react-bootstrap/lib/DropdownButton';
|
import DropdownButton from 'react-bootstrap/lib/DropdownButton';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils.js';
|
import { getLangText } from '../../utils/lang.js';
|
||||||
|
|
||||||
let PieceListToolbarOrderWidget = React.createClass({
|
let PieceListToolbarOrderWidget = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import UserStore from '../../stores/user_store';
|
import UserStore from '../../stores/user_store';
|
||||||
@ -10,7 +8,7 @@ import { currentUserShape, locationShape, routerShape, whitelabelShape } from '.
|
|||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
|
|
||||||
|
|
||||||
const { bool, object } = React.PropTypes;
|
const { bool } = React.PropTypes;
|
||||||
const WHEN_ENUM = ['loggedIn', 'loggedOut'];
|
const WHEN_ENUM = ['loggedIn', 'loggedOut'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -50,17 +48,17 @@ export function AuthRedirect({ to, when }) {
|
|||||||
return true;
|
return true;
|
||||||
|
|
||||||
} else if (!exprToValidate && when === 'loggedOut' && redirectAuthenticated) {
|
} else if (!exprToValidate && when === 'loggedOut' && redirectAuthenticated) {
|
||||||
/*
|
/**
|
||||||
* redirectAuthenticated contains an arbitrary path
|
* redirectAuthenticated contains an arbitrary path
|
||||||
* eg pieces/<id>, editions/<bitcoin_id>, collection, settings, ...
|
* eg pieces/<id>, editions/<bitcoin_id>, collection, settings, ...
|
||||||
* hence transitionTo cannot be used directly.
|
* hence transitionTo cannot be used directly.
|
||||||
*
|
*
|
||||||
* While we're getting rid of `query.redirect` explicitly in the
|
* While we're getting rid of `query.redirect` explicitly in the
|
||||||
* above `else if` statement, here it's sufficient to just set the
|
* above `else if` statement, here it's sufficient to just set the
|
||||||
* location to `${baseUrl}/${redirectAuthenticated}`, as this will
|
* location to `${appBasePath}/${redirectAuthenticated}`, as this will
|
||||||
* get rid of queries as well.
|
* get rid of queries as well.
|
||||||
*/
|
*/
|
||||||
window.location = `${AppConstants.baseUrl}/${redirectAuthenticated}`;
|
window.location = `${AppConstants.appBasePath}/${redirectAuthenticated}`;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,9 +17,8 @@ import AscribeSpinner from '../ascribe_spinner';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { currentUserShape, whitelabelShape } from '../prop_types';
|
import { currentUserShape, whitelabelShape } from '../prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
|
||||||
|
|
||||||
let AccountSettings = React.createClass({
|
let AccountSettings = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -49,7 +48,7 @@ let AccountSettings = React.createClass({
|
|||||||
if (currentUser.username) {
|
if (currentUser.username) {
|
||||||
content = (
|
content = (
|
||||||
<Form
|
<Form
|
||||||
url={ApiUrls.users_username}
|
url={resolveUrl('users_username')}
|
||||||
handleSuccess={this.handleSuccess}>
|
handleSuccess={this.handleSuccess}>
|
||||||
<Property
|
<Property
|
||||||
name='username'
|
name='username'
|
||||||
@ -79,7 +78,7 @@ let AccountSettings = React.createClass({
|
|||||||
aclObject={whitelabel}
|
aclObject={whitelabel}
|
||||||
aclName="acl_view_settings_account_hash">
|
aclName="acl_view_settings_account_hash">
|
||||||
<Form
|
<Form
|
||||||
url={ApiUrls.users_profile}
|
url={resolveUrl('users_profile')}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
getFormData={this.getFormDataProfile}>
|
getFormData={this.getFormDataProfile}>
|
||||||
<Property
|
<Property
|
||||||
|
@ -14,10 +14,10 @@ import Property from '../ascribe_forms/property';
|
|||||||
import ActionPanel from '../ascribe_panel/action_panel';
|
import ActionPanel from '../ascribe_panel/action_panel';
|
||||||
import CollapsibleParagraph from '../ascribe_collapsible/collapsible_paragraph';
|
import CollapsibleParagraph from '../ascribe_collapsible/collapsible_paragraph';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let APISettings = React.createClass({
|
let APISettings = React.createClass({
|
||||||
@ -99,7 +99,7 @@ let APISettings = React.createClass({
|
|||||||
title={getLangText('API Integration')}
|
title={getLangText('API Integration')}
|
||||||
defaultExpanded={this.props.defaultExpanded}>
|
defaultExpanded={this.props.defaultExpanded}>
|
||||||
<Form
|
<Form
|
||||||
url={ApiUrls.applications}
|
url={resolveUrl('applications')}
|
||||||
handleSuccess={this.handleCreateSuccess}>
|
handleSuccess={this.handleCreateSuccess}>
|
||||||
<Property
|
<Property
|
||||||
name='name'
|
name='name'
|
||||||
|
@ -12,7 +12,7 @@ import CollapsibleParagraph from '../ascribe_collapsible/collapsible_paragraph';
|
|||||||
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let BitcoinWalletSettings = React.createClass({
|
let BitcoinWalletSettings = React.createClass({
|
||||||
|
@ -19,9 +19,9 @@ import AclProxy from '../acl_proxy';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { currentUserShape, whitelabelShape } from '../prop_types';
|
import { currentUserShape, whitelabelShape } from '../prop_types';
|
||||||
|
|
||||||
import { setDocumentTitle } from '../../utils/dom_utils';
|
import { setDocumentTitle } from '../../utils/dom';
|
||||||
import { truncateTextAtCharIndex } from '../../utils/general_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { truncateText } from '../../utils/text';
|
||||||
|
|
||||||
|
|
||||||
let ContractSettings = React.createClass({
|
let ContractSettings = React.createClass({
|
||||||
@ -105,7 +105,7 @@ let ContractSettings = React.createClass({
|
|||||||
<ActionPanel
|
<ActionPanel
|
||||||
key={contract.id}
|
key={contract.id}
|
||||||
title={contract.name}
|
title={contract.name}
|
||||||
content={truncateTextAtCharIndex(contract.name, 120, '(...).pdf')}
|
content={truncateText(contract.name, 120, '(...).pdf')}
|
||||||
buttons={
|
buttons={
|
||||||
<div className="pull-right">
|
<div className="pull-right">
|
||||||
<AclProxy
|
<AclProxy
|
||||||
@ -147,7 +147,7 @@ let ContractSettings = React.createClass({
|
|||||||
<ActionPanel
|
<ActionPanel
|
||||||
key={contract.id}
|
key={contract.id}
|
||||||
title={contract.name}
|
title={contract.name}
|
||||||
content={truncateTextAtCharIndex(contract.name, 120, '(...).pdf')}
|
content={truncateText(contract.name, 120, '(...).pdf')}
|
||||||
buttons={
|
buttons={
|
||||||
<div className="pull-right">
|
<div className="pull-right">
|
||||||
<AclProxy
|
<AclProxy
|
||||||
|
@ -10,13 +10,13 @@ import GlobalNotificationActions from '../../actions/global_notification_actions
|
|||||||
import ReactS3FineUploader from '../ascribe_uploader/react_s3_fine_uploader';
|
import ReactS3FineUploader from '../ascribe_uploader/react_s3_fine_uploader';
|
||||||
import UploadButton from '../ascribe_uploader/ascribe_upload_button/upload_button';
|
import UploadButton from '../ascribe_uploader/ascribe_upload_button/upload_button';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
import { validationTypes } from '../../constants/uploader_constants';
|
import { validationTypes } from '../../constants/uploader_constants';
|
||||||
|
|
||||||
import { formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
import { formSubmissionValidation } from '../ascribe_uploader/react_s3_fine_uploader_utils';
|
||||||
import { getCookie } from '../../utils/fetch_api_utils';
|
import { makeCsrfHeader } from '../../utils/csrf';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let ContractSettingsUpdateButton = React.createClass({
|
let ContractSettingsUpdateButton = React.createClass({
|
||||||
@ -66,7 +66,7 @@ let ContractSettingsUpdateButton = React.createClass({
|
|||||||
fileClass: 'contract'
|
fileClass: 'contract'
|
||||||
}}
|
}}
|
||||||
createBlobRoutine={{
|
createBlobRoutine={{
|
||||||
url: ApiUrls.blob_contracts
|
url: resolveUrl('blob_contracts')
|
||||||
}}
|
}}
|
||||||
validation={{
|
validation={{
|
||||||
itemLimit: validationTypes.registerWork.itemLimit,
|
itemLimit: validationTypes.registerWork.itemLimit,
|
||||||
@ -76,17 +76,13 @@ let ContractSettingsUpdateButton = React.createClass({
|
|||||||
setIsUploadReady={() =>{/* So that ReactS3FineUploader is not complaining */}}
|
setIsUploadReady={() =>{/* So that ReactS3FineUploader is not complaining */}}
|
||||||
signature={{
|
signature={{
|
||||||
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
|
endpoint: `${AppConstants.serverUrl}/s3/signature/`,
|
||||||
customHeaders: {
|
customHeaders: makeCsrfHeader()
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
|
||||||
}
|
|
||||||
}}
|
}}
|
||||||
deleteFile={{
|
deleteFile={{
|
||||||
enabled: true,
|
enabled: true,
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
endpoint: `${AppConstants.serverUrl}/s3/delete`,
|
endpoint: `${AppConstants.serverUrl}/s3/delete`,
|
||||||
customHeaders: {
|
customHeaders: makeCsrfHeader()
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
|
||||||
}
|
|
||||||
}}
|
}}
|
||||||
fileClassToUpload={{
|
fileClassToUpload={{
|
||||||
singular: getLangText('UPDATE'),
|
singular: getLangText('UPDATE'),
|
||||||
|
@ -13,8 +13,8 @@ import AclProxy from '../acl_proxy';
|
|||||||
import withContext from '../context/with_context';
|
import withContext from '../context/with_context';
|
||||||
import { whitelabelShape } from '../prop_types';
|
import { whitelabelShape } from '../prop_types';
|
||||||
|
|
||||||
import { setDocumentTitle } from '../../utils/dom_utils';
|
import { setDocumentTitle } from '../../utils/dom';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let SettingsContainer = React.createClass({
|
let SettingsContainer = React.createClass({
|
||||||
|
@ -16,10 +16,10 @@ import AclProxy from '../acl_proxy';
|
|||||||
import ActionPanel from '../ascribe_panel/action_panel';
|
import ActionPanel from '../ascribe_panel/action_panel';
|
||||||
import CollapsibleParagraph from '../ascribe_collapsible/collapsible_paragraph';
|
import CollapsibleParagraph from '../ascribe_collapsible/collapsible_paragraph';
|
||||||
|
|
||||||
import ApiUrls from '../../constants/api_urls';
|
|
||||||
import AscribeSpinner from '../ascribe_spinner';
|
import AscribeSpinner from '../ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../utils/url_resolver';
|
||||||
|
|
||||||
|
|
||||||
let WebhookSettings = React.createClass({
|
let WebhookSettings = React.createClass({
|
||||||
@ -143,7 +143,7 @@ let WebhookSettings = React.createClass({
|
|||||||
<AclProxy show={this.state.webhookEvents && this.state.webhookEvents.length > 0}>
|
<AclProxy show={this.state.webhookEvents && this.state.webhookEvents.length > 0}>
|
||||||
<Form
|
<Form
|
||||||
ref="webhookCreateForm"
|
ref="webhookCreateForm"
|
||||||
url={ApiUrls.webhooks}
|
url={resolveUrl('webhooks')}
|
||||||
handleSuccess={this.handleCreateSuccess}>
|
handleSuccess={this.handleCreateSuccess}>
|
||||||
{this.getEvents()}
|
{this.getEvents()}
|
||||||
<Property
|
<Property
|
||||||
|
@ -6,7 +6,7 @@ import FacebookHandler from '../../third_party/facebook_handler';
|
|||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
|
|
||||||
import { InjectInHeadUtils } from '../../utils/inject_utils';
|
import { InjectInHeadUtils } from '../../utils/inject';
|
||||||
|
|
||||||
let FacebookShareButton = React.createClass({
|
let FacebookShareButton = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -4,7 +4,7 @@ import React from 'react';
|
|||||||
|
|
||||||
import AppConstants from '../../constants/application_constants';
|
import AppConstants from '../../constants/application_constants';
|
||||||
|
|
||||||
import { InjectInHeadUtils } from '../../utils/inject_utils';
|
import { InjectInHeadUtils } from '../../utils/inject';
|
||||||
|
|
||||||
let TwitterShareButton = React.createClass({
|
let TwitterShareButton = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -9,7 +9,7 @@ import FileDragAndDropErrorDialog from './file_drag_and_drop_error_dialog';
|
|||||||
import FileDragAndDropPreviewIterator from './file_drag_and_drop_preview_iterator';
|
import FileDragAndDropPreviewIterator from './file_drag_and_drop_preview_iterator';
|
||||||
|
|
||||||
import { FileStatus } from '../react_s3_fine_uploader_utils';
|
import { FileStatus } from '../react_s3_fine_uploader_utils';
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
// Taken from: https://github.com/fedosejev/react-file-drag-and-drop
|
// Taken from: https://github.com/fedosejev/react-file-drag-and-drop
|
||||||
|
@ -3,9 +3,10 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Link } from 'react-router';
|
import { Link } from 'react-router';
|
||||||
|
|
||||||
import { dragAndDropAvailable } from '../../../utils/feature_detection_utils';
|
import { dragAndDropAvailable } from 'js-utility-belt/es6/feature_detection';
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
|
||||||
import { getCurrentQueryParams } from '../../../utils/url_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
import { getCurrentQueryParams } from '../../../utils/url';
|
||||||
|
|
||||||
let FileDragAndDropDialog = React.createClass({
|
let FileDragAndDropDialog = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -5,7 +5,7 @@ import classNames from 'classnames';
|
|||||||
|
|
||||||
import { ErrorClasses } from '../../../constants/error_constants';
|
import { ErrorClasses } from '../../../constants/error_constants';
|
||||||
|
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
let FileDragAndDropErrorDialog = React.createClass({
|
let FileDragAndDropErrorDialog = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
@ -6,9 +6,9 @@ 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 { FileStatus } from '../react_s3_fine_uploader_utils';
|
import { FileStatus } from '../react_s3_fine_uploader_utils';
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { extractFileExtensionFromString } from '../../../utils/file';
|
||||||
import { truncateTextAtCharIndex } from '../../../utils/general_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
import { extractFileExtensionFromString } from '../../../utils/file_utils';
|
import { truncateText } from '../../../utils/text';
|
||||||
|
|
||||||
|
|
||||||
const { shape, string, number, func, bool } = React.PropTypes;
|
const { shape, string, number, func, bool } = React.PropTypes;
|
||||||
@ -76,7 +76,7 @@ const FileDragAndDropPreview = React.createClass({
|
|||||||
if (numberOfDisplayedFiles === 1) {
|
if (numberOfDisplayedFiles === 1) {
|
||||||
return (
|
return (
|
||||||
<span className="file-name">
|
<span className="file-name">
|
||||||
{truncateTextAtCharIndex(file.name, 30, '(...).' + extractFileExtensionFromString(file.name))}
|
{truncateText(file.name, 30, `(...).${extractFileExtensionFromString(file.name)}`)}
|
||||||
</span>
|
</span>
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
@ -5,7 +5,7 @@ import ProgressBar from 'react-bootstrap/lib/ProgressBar';
|
|||||||
|
|
||||||
import AclProxy from '../../acl_proxy';
|
import AclProxy from '../../acl_proxy';
|
||||||
import AscribeSpinner from '../../ascribe_spinner';
|
import AscribeSpinner from '../../ascribe_spinner';
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const { number, string, func, bool } = React.PropTypes;
|
const { number, string, func, bool } = React.PropTypes;
|
||||||
|
@ -3,9 +3,8 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import ProgressBar from 'react-bootstrap/lib/ProgressBar';
|
import ProgressBar from 'react-bootstrap/lib/ProgressBar';
|
||||||
|
|
||||||
import AclProxy from '../../acl_proxy';
|
|
||||||
import AscribeSpinner from '../../ascribe_spinner';
|
import AscribeSpinner from '../../ascribe_spinner';
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const { string, number, bool, func } = React.PropTypes;
|
const { string, number, bool, func } = React.PropTypes;
|
||||||
|
@ -4,8 +4,8 @@ import React from 'react';
|
|||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
|
|
||||||
import { displayValidProgressFilesFilter, FileStatus } from '../react_s3_fine_uploader_utils';
|
import { displayValidProgressFilesFilter, FileStatus } from '../react_s3_fine_uploader_utils';
|
||||||
import { getLangText } from '../../../utils/lang_utils';
|
import { getLangText } from '../../../utils/lang';
|
||||||
import { truncateTextAtCharIndex } from '../../../utils/general_utils';
|
import { truncateText } from '../../../utils/text';
|
||||||
|
|
||||||
const { func, array, bool, shape, string } = React.PropTypes;
|
const { func, array, bool, shape, string } = React.PropTypes;
|
||||||
|
|
||||||
@ -127,7 +127,7 @@ export default function UploadButton({ className = 'btn btn-default btn-sm', sho
|
|||||||
if (uploadingFiles.length) {
|
if (uploadingFiles.length) {
|
||||||
return (
|
return (
|
||||||
<span>
|
<span>
|
||||||
{' ' + truncateTextAtCharIndex(uploadingFiles[0].name, 40) + ' '}
|
{` ${truncateText(uploadingFiles[0].name, 40)} `}
|
||||||
[<a onClick={this.onClickRemove}>{getLangText('cancel upload')}</a>]
|
[<a onClick={this.onClickRemove}>{getLangText('cancel upload')}</a>]
|
||||||
</span>
|
</span>
|
||||||
);
|
);
|
||||||
@ -135,7 +135,7 @@ export default function UploadButton({ className = 'btn btn-default btn-sm', sho
|
|||||||
return (
|
return (
|
||||||
<span>
|
<span>
|
||||||
<span className='ascribe-icon icon-ascribe-ok'/>
|
<span className='ascribe-icon icon-ascribe-ok'/>
|
||||||
{' ' + truncateTextAtCharIndex(uploadedFile.name, 40) + ' '}
|
{` ${truncateText(uploadedFile.name, 40)} `}
|
||||||
[<a onClick={this.onClickRemove}>{getLangText('remove')}</a>]
|
[<a onClick={this.onClickRemove}>{getLangText('remove')}</a>]
|
||||||
</span>
|
</span>
|
||||||
);
|
);
|
||||||
|
@ -15,14 +15,13 @@ import ErrorQueueStore from '../../stores/error_queue_store';
|
|||||||
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 AppConstants from '../../constants/application_constants';
|
|
||||||
import { ErrorClasses, testErrorAgainstAll } from '../../constants/error_constants';
|
import { ErrorClasses, testErrorAgainstAll } from '../../constants/error_constants';
|
||||||
import { RETRY_ATTEMPT_TO_SHOW_CONTACT_US, ENDPOINTS } from '../../constants/uploader_constants';
|
import { RETRY_ATTEMPT_TO_SHOW_CONTACT_US, ENDPOINTS } from '../../constants/uploader_constants';
|
||||||
|
|
||||||
import { displayValidFilesFilter, FileStatus, transformAllowedExtensionsToInputAcceptProp } from './react_s3_fine_uploader_utils';
|
import { displayValidFilesFilter, FileStatus, transformAllowedExtensionsToInputAcceptProp } from './react_s3_fine_uploader_utils';
|
||||||
import { getCookie } from '../../utils/fetch_api_utils';
|
import { getCsrfToken, makeCsrfHeader } from '../../utils/csrf';
|
||||||
import { computeHashOfFile, extractFileExtensionFromString } from '../../utils/file_utils';
|
import { computeHashOfFile, extractFileExtensionFromString } from '../../utils/file';
|
||||||
import { getLangText } from '../../utils/lang_utils';
|
import { getLangText } from '../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const { shape,
|
const { shape,
|
||||||
@ -215,7 +214,7 @@ const ReactS3FineUploader = React.createClass({
|
|||||||
return {
|
return {
|
||||||
filesToUpload: [],
|
filesToUpload: [],
|
||||||
uploader: this.createNewFineUploader(),
|
uploader: this.createNewFineUploader(),
|
||||||
csrfToken: getCookie(AppConstants.csrftoken),
|
csrfToken: getCsrfToken(),
|
||||||
errorState: {
|
errorState: {
|
||||||
manualRetryAttempt: 0,
|
manualRetryAttempt: 0,
|
||||||
errorClass: null
|
errorClass: null
|
||||||
@ -235,7 +234,7 @@ const ReactS3FineUploader = React.createClass({
|
|||||||
// since the csrf header is defined in this component's props,
|
// since the csrf header is defined in this component's props,
|
||||||
// everytime the csrf cookie is changed we'll need to reinitalize
|
// everytime the csrf cookie is changed we'll need to reinitalize
|
||||||
// fineuploader and update the actual csrf token
|
// fineuploader and update the actual csrf token
|
||||||
let potentiallyNewCSRFToken = getCookie(AppConstants.csrftoken);
|
let potentiallyNewCSRFToken = getCsrfToken();
|
||||||
if(this.state.csrfToken !== potentiallyNewCSRFToken) {
|
if(this.state.csrfToken !== potentiallyNewCSRFToken) {
|
||||||
this.setState({
|
this.setState({
|
||||||
uploader: this.createNewFineUploader(),
|
uploader: this.createNewFineUploader(),
|
||||||
@ -318,7 +317,7 @@ const ReactS3FineUploader = React.createClass({
|
|||||||
headers: {
|
headers: {
|
||||||
'Accept': 'application/json',
|
'Accept': 'application/json',
|
||||||
'Content-Type': 'application/json',
|
'Content-Type': 'application/json',
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
...makeCsrfHeader()
|
||||||
},
|
},
|
||||||
credentials: 'include',
|
credentials: 'include',
|
||||||
body: JSON.stringify({
|
body: JSON.stringify({
|
||||||
@ -361,7 +360,7 @@ const ReactS3FineUploader = React.createClass({
|
|||||||
headers: {
|
headers: {
|
||||||
'Accept': 'application/json',
|
'Accept': 'application/json',
|
||||||
'Content-Type': 'application/json',
|
'Content-Type': 'application/json',
|
||||||
'X-CSRFToken': getCookie(AppConstants.csrftoken)
|
...makeCsrfHeader()
|
||||||
},
|
},
|
||||||
credentials: 'include',
|
credentials: 'include',
|
||||||
body: JSON.stringify({
|
body: JSON.stringify({
|
||||||
|
@ -13,10 +13,9 @@ import AscribeSpinner from './ascribe_spinner';
|
|||||||
import withContext from './context/with_context';
|
import withContext from './context/with_context';
|
||||||
import { locationShape } from './prop_types';
|
import { locationShape } from './prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../constants/api_urls';
|
import { setDocumentTitle } from '../utils/dom';
|
||||||
|
import { getLangText } from '../utils/lang';
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { resolveUrl } from '../utils/url_resolver';
|
||||||
import { setDocumentTitle } from '../utils/dom_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let CoaVerifyContainer = React.createClass({
|
let CoaVerifyContainer = React.createClass({
|
||||||
@ -75,7 +74,7 @@ let CoaVerifyForm = React.createClass({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<Form
|
<Form
|
||||||
url={ApiUrls.coa_verify}
|
url={resolveUrl('coa_verify')}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
<button
|
<button
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { currentUserShape, locationShape, routerShape, whitelabelShape } from '../prop_types';
|
import { currentUserShape, locationShape, routerShape, whitelabelShape } from '../prop_types';
|
||||||
|
|
||||||
import { selectFromObject } from '../../utils/general_utils';
|
import { selectFromObject } from '../../utils/general';
|
||||||
import { getDisplayName } from '../../utils/react_utils';
|
import { getDisplayName } from '../../utils/react';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ContextPropDefinitions
|
* ContextPropDefinitions
|
||||||
|
@ -2,7 +2,7 @@ import React from 'react';
|
|||||||
|
|
||||||
import history from '../history';
|
import history from '../history';
|
||||||
|
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const ErrorNotFoundPage = React.createClass({
|
const ErrorNotFoundPage = React.createClass({
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const Footer = React.createClass({
|
const Footer = React.createClass({
|
||||||
|
@ -3,13 +3,12 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
|
|
||||||
import GlobalNotificationActions from '../actions/global_notification_actions';
|
|
||||||
import GlobalNotificationStore from '../stores/global_notification_store';
|
|
||||||
|
|
||||||
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 { mergeOptions } from '../utils/general_utils';
|
import GlobalNotificationStore from '../stores/global_notification_store';
|
||||||
|
|
||||||
|
import { safeMerge } from '../utils/general';
|
||||||
|
|
||||||
const MAX_NOTIFICATION_BUBBLE_CONTAINER_WIDTH = 768;
|
const MAX_NOTIFICATION_BUBBLE_CONTAINER_WIDTH = 768;
|
||||||
|
|
||||||
@ -18,7 +17,7 @@ let GlobalNotification = React.createClass({
|
|||||||
getInitialState() {
|
getInitialState() {
|
||||||
const notificationStore = GlobalNotificationStore.getState();
|
const notificationStore = GlobalNotificationStore.getState();
|
||||||
|
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
{
|
{
|
||||||
containerWidth: 0
|
containerWidth: 0
|
||||||
},
|
},
|
||||||
@ -60,7 +59,7 @@ let GlobalNotification = React.createClass({
|
|||||||
|
|
||||||
const notificationClasses = [];
|
const notificationClasses = [];
|
||||||
|
|
||||||
if (this.state.containerWidth > 768) {
|
if (this.state.containerWidth > MAX_NOTIFICATION_BUBBLE_CONTAINER_WIDTH) {
|
||||||
notificationClasses.push('ascribe-global-notification-bubble');
|
notificationClasses.push('ascribe-global-notification-bubble');
|
||||||
notificationClasses.push(notificationStatus === 'show' ? 'ascribe-global-notification-bubble-on'
|
notificationClasses.push(notificationStatus === 'show' ? 'ascribe-global-notification-bubble-on'
|
||||||
: 'ascribe-global-notification-bubble-off');
|
: 'ascribe-global-notification-bubble-off');
|
||||||
|
@ -20,8 +20,8 @@ import HeaderNotificationDebug from './header_notification_debug';
|
|||||||
import NavRoutesLinks from './nav_routes_links';
|
import NavRoutesLinks from './nav_routes_links';
|
||||||
import { currentUserShape, whitelabelShape } from './prop_types';
|
import { currentUserShape, whitelabelShape } from './prop_types';
|
||||||
|
|
||||||
import { constructHead } from '../utils/dom_utils';
|
import { constructHead } from '../utils/dom';
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let Header = React.createClass({
|
let Header = React.createClass({
|
||||||
|
@ -13,7 +13,7 @@ import NotificationStore from '../stores/notification_store';
|
|||||||
import withContext from './context/with_context';
|
import withContext from './context/with_context';
|
||||||
import { currentUserShape } from './prop_types';
|
import { currentUserShape } from './prop_types';
|
||||||
|
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let HeaderNotifications = React.createClass({
|
let HeaderNotifications = React.createClass({
|
||||||
|
@ -8,8 +8,8 @@ import LoginForm from './ascribe_forms/form_login';
|
|||||||
import withContext from './context/with_context';
|
import withContext from './context/with_context';
|
||||||
import { whitelabelShape } from './prop_types';
|
import { whitelabelShape } from './prop_types';
|
||||||
|
|
||||||
import { setDocumentTitle } from '../utils/dom_utils';
|
import { setDocumentTitle } from '../utils/dom';
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let LoginContainer = React.createClass({
|
let LoginContainer = React.createClass({
|
||||||
|
@ -2,12 +2,12 @@
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import AscribeSpinner from './ascribe_spinner';
|
|
||||||
|
|
||||||
import UserActions from '../actions/user_actions';
|
import UserActions from '../actions/user_actions';
|
||||||
|
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import AscribeSpinner from './ascribe_spinner';
|
||||||
import { setDocumentTitle } from '../utils/dom_utils';
|
|
||||||
|
import { setDocumentTitle } from '../utils/dom';
|
||||||
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let LogoutContainer = React.createClass({
|
let LogoutContainer = React.createClass({
|
||||||
|
@ -4,11 +4,10 @@ import React from 'react';
|
|||||||
|
|
||||||
import Nav from 'react-bootstrap/lib/Nav';
|
import Nav from 'react-bootstrap/lib/Nav';
|
||||||
|
|
||||||
|
import AclProxy from './acl_proxy';
|
||||||
import NavRoutesLinksLink from './nav_routes_links_link';
|
import NavRoutesLinksLink from './nav_routes_links_link';
|
||||||
|
|
||||||
import AclProxy from './acl_proxy';
|
import { sanitizeList } from '../utils/general';
|
||||||
|
|
||||||
import { sanitizeList } from '../utils/general_utils';
|
|
||||||
|
|
||||||
|
|
||||||
const DISABLE_ENUM = ['hasPieces', 'noPieces'];
|
const DISABLE_ENUM = ['hasPieces', 'noPieces'];
|
||||||
|
@ -12,10 +12,9 @@ import AscribeSpinner from './ascribe_spinner';
|
|||||||
import withContext from './context/with_context';
|
import withContext from './context/with_context';
|
||||||
import { locationShape, routerShape } from './prop_types';
|
import { locationShape, routerShape } from './prop_types';
|
||||||
|
|
||||||
import ApiUrls from '../constants/api_urls';
|
import { setDocumentTitle } from '../utils/dom';
|
||||||
|
import { getLangText } from '../utils/lang';
|
||||||
import { setDocumentTitle } from '../utils/dom_utils';
|
import { resolveUrl } from '../utils/url_resolver';
|
||||||
import { getLangText } from '../utils/lang_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let PasswordResetContainer = React.createClass({
|
let PasswordResetContainer = React.createClass({
|
||||||
@ -76,7 +75,7 @@ let PasswordRequestResetForm = React.createClass({
|
|||||||
<Form
|
<Form
|
||||||
ref="form"
|
ref="form"
|
||||||
className='ascribe-form-wrapper'
|
className='ascribe-form-wrapper'
|
||||||
url={ApiUrls.users_password_reset_request}
|
url={resolveUrl('users_password_reset_request')}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
buttons={
|
buttons={
|
||||||
<button
|
<button
|
||||||
@ -136,7 +135,7 @@ let PasswordResetForm = withContext(React.createClass({
|
|||||||
<Form
|
<Form
|
||||||
ref="form"
|
ref="form"
|
||||||
className='ascribe-form-wrapper'
|
className='ascribe-form-wrapper'
|
||||||
url={ApiUrls.users_password_reset}
|
url={resolveUrl('users_password_reset')}
|
||||||
handleSuccess={this.handleSuccess}
|
handleSuccess={this.handleSuccess}
|
||||||
getFormData={this.getFormData}
|
getFormData={this.getFormData}
|
||||||
buttons={
|
buttons={
|
||||||
|
@ -24,10 +24,10 @@ import AscribeSpinner from './ascribe_spinner';
|
|||||||
import withContext from './context/with_context';
|
import withContext from './context/with_context';
|
||||||
import { locationShape, routerShape } from './prop_types';
|
import { locationShape, routerShape } from './prop_types';
|
||||||
|
|
||||||
import { getAvailableAcls } from '../utils/acl_utils';
|
import { getAvailableAcls } from '../utils/acl';
|
||||||
import { setDocumentTitle } from '../utils/dom_utils';
|
import { setDocumentTitle } from '../utils/dom';
|
||||||
import { mergeOptions, isShallowEqual } from '../utils/general_utils';
|
import { safeMerge, isShallowEqual } from '../utils/general';
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const PieceList = React.createClass({
|
const PieceList = React.createClass({
|
||||||
@ -75,7 +75,7 @@ const PieceList = React.createClass({
|
|||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
const pieceListStore = PieceListStore.getState();
|
const pieceListStore = PieceListStore.getState();
|
||||||
const stores = mergeOptions(
|
const stores = safeMerge(
|
||||||
pieceListStore,
|
pieceListStore,
|
||||||
EditionListStore.getState(),
|
EditionListStore.getState(),
|
||||||
{
|
{
|
||||||
|
@ -15,8 +15,8 @@ import RegisterPieceForm from './ascribe_forms/form_register_piece';
|
|||||||
import withContext from './context/with_context';
|
import withContext from './context/with_context';
|
||||||
import { routerShape, whitelabelShape } from './prop_types';
|
import { routerShape, whitelabelShape } from './prop_types';
|
||||||
|
|
||||||
import { setDocumentTitle } from '../utils/dom_utils';
|
import { setDocumentTitle } from '../utils/dom';
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const RegisterPiece = React.createClass( {
|
const RegisterPiece = React.createClass( {
|
||||||
|
@ -4,11 +4,10 @@ import React from 'react';
|
|||||||
|
|
||||||
// FIXME: Input is deprecated
|
// FIXME: Input is deprecated
|
||||||
import Input from 'react-bootstrap/lib/Input';
|
import Input from 'react-bootstrap/lib/Input';
|
||||||
import Glyphicon from 'react-bootstrap/lib/Glyphicon';
|
|
||||||
|
|
||||||
import AscribeSpinner from './ascribe_spinner';
|
import AscribeSpinner from './ascribe_spinner';
|
||||||
|
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
const { func, string, number } = React.PropTypes;
|
const { func, string, number } = React.PropTypes;
|
||||||
|
@ -6,8 +6,8 @@ import SignupForm from './ascribe_forms/form_signup';
|
|||||||
import withContext from './context/with_context';
|
import withContext from './context/with_context';
|
||||||
import { whitelabelShape } from './prop_types';
|
import { whitelabelShape } from './prop_types';
|
||||||
|
|
||||||
import { setDocumentTitle } from '../utils/dom_utils';
|
import { setDocumentTitle } from '../utils/dom';
|
||||||
import { getLangText } from '../utils/lang_utils';
|
import { getLangText } from '../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let SignupContainer = React.createClass({
|
let SignupContainer = React.createClass({
|
||||||
|
@ -8,8 +8,8 @@ import LinkContainer from 'react-router-bootstrap/lib/LinkContainer';
|
|||||||
import withContext from '../../../../context/with_context';
|
import withContext from '../../../../context/with_context';
|
||||||
import { whitelabelShape } from '../../../../prop_types';
|
import { whitelabelShape } from '../../../../prop_types';
|
||||||
|
|
||||||
import { setDocumentTitle } from '../../../../../utils/dom_utils';
|
import { setDocumentTitle } from '../../../../../utils/dom';
|
||||||
import { getLangText } from '../../../../../utils/lang_utils';
|
import { getLangText } from '../../../../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let Vivi23Landing = React.createClass({
|
let Vivi23Landing = React.createClass({
|
||||||
|
@ -8,8 +8,8 @@ import LinkContainer from 'react-router-bootstrap/lib/LinkContainer';
|
|||||||
import withContext from '../../../../context/with_context';
|
import withContext from '../../../../context/with_context';
|
||||||
import { whitelabelShape } from '../../../../prop_types';
|
import { whitelabelShape } from '../../../../prop_types';
|
||||||
|
|
||||||
import { getLangText } from '../../../../../utils/lang_utils';
|
import { getLangText } from '../../../../../utils/lang';
|
||||||
import { setDocumentTitle } from '../../../../../utils/dom_utils';
|
import { setDocumentTitle } from '../../../../../utils/dom';
|
||||||
|
|
||||||
|
|
||||||
let ArtcityLanding = React.createClass({
|
let ArtcityLanding = React.createClass({
|
||||||
|
@ -10,8 +10,6 @@ import AclProxy from '../../../../acl_proxy';
|
|||||||
import withContext from '../../../../context/with_context';
|
import withContext from '../../../../context/with_context';
|
||||||
import { currentUserShape } from '../../../../prop_types';
|
import { currentUserShape } from '../../../../prop_types';
|
||||||
|
|
||||||
import { mergeOptions } from '../../../../../utils/general_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let WalletActionPanel = React.createClass({
|
let WalletActionPanel = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
@ -40,7 +38,7 @@ let WalletActionPanel = React.createClass({
|
|||||||
|
|
||||||
if (piece && piece.acl && typeof piece.acl.acl_loan !== 'undefined') {
|
if (piece && piece.acl && typeof piece.acl.acl_loan !== 'undefined') {
|
||||||
// make a copy to not have side effects
|
// make a copy to not have side effects
|
||||||
availableAcls = mergeOptions({}, piece.acl);
|
availableAcls = Object.assign({}, piece.acl);
|
||||||
availableAcls.acl_loan = false;
|
availableAcls.acl_loan = false;
|
||||||
}
|
}
|
||||||
let SubmitButtonType = submitButtonType;
|
let SubmitButtonType = submitButtonType;
|
||||||
|
@ -15,9 +15,8 @@ import Piece from '../../../../../components/ascribe_detail/piece';
|
|||||||
import AscribeSpinner from '../../../../ascribe_spinner';
|
import AscribeSpinner from '../../../../ascribe_spinner';
|
||||||
import withContext from '../../../../context/with_context';
|
import withContext from '../../../../context/with_context';
|
||||||
|
|
||||||
import ApiUrls from '../../../../../constants/api_urls';
|
import { getLangText } from '../../../../../utils/lang';
|
||||||
|
import { resolveUrl } from '../../../../../utils/url_resolver';
|
||||||
import { getLangText } from '../../../../../utils/lang_utils';
|
|
||||||
|
|
||||||
|
|
||||||
let WalletPieceContainer = React.createClass({
|
let WalletPieceContainer = React.createClass({
|
||||||
@ -85,7 +84,7 @@ let WalletPieceContainer = React.createClass({
|
|||||||
placeholder={getLangText('Enter your comments ...')}
|
placeholder={getLangText('Enter your comments ...')}
|
||||||
editable={true}
|
editable={true}
|
||||||
successMessage={getLangText('Private note saved')}
|
successMessage={getLangText('Private note saved')}
|
||||||
url={ApiUrls.note_private_piece} />
|
url={resolveUrl('note_private_piece')} />
|
||||||
</CollapsibleParagraph>
|
</CollapsibleParagraph>
|
||||||
{children}
|
{children}
|
||||||
</Piece>
|
</Piece>
|
||||||
|
@ -7,13 +7,13 @@ import Property from '../../../../ascribe_forms/property';
|
|||||||
import LicenseActions from '../../../../../actions/license_actions';
|
import LicenseActions from '../../../../../actions/license_actions';
|
||||||
import LicenseStore from '../../../../../stores/license_store';
|
import LicenseStore from '../../../../../stores/license_store';
|
||||||
|
|
||||||
import { getLangText } from '../../../../../utils/lang_utils';
|
import { setDocumentTitle } from '../../../../../utils/dom';
|
||||||
import { setDocumentTitle } from '../../../../../utils/dom_utils';
|
import { safeMerge } from '../../../../../utils/general';
|
||||||
import { mergeOptions } from '../../../../../utils/general_utils';
|
import { getLangText } from '../../../../../utils/lang';
|
||||||
|
|
||||||
let CCRegisterPiece = React.createClass({
|
let CCRegisterPiece = React.createClass({
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return mergeOptions(
|
return safeMerge(
|
||||||
LicenseStore.getState(),
|
LicenseStore.getState(),
|
||||||
{
|
{
|
||||||
selectedLicense: 0
|
selectedLicense: 0
|
||||||
|
@ -15,7 +15,7 @@ import AccordionListItemPiece from '../../../../../ascribe_accordion_list/accord
|
|||||||
|
|
||||||
import AclProxy from '../../../../../acl_proxy';
|
import AclProxy from '../../../../../acl_proxy';
|
||||||
|
|
||||||
import { getLangText } from '../../../../../../utils/lang_utils';
|
import { getLangText } from '../../../../../../utils/lang';
|
||||||
|
|
||||||
|
|
||||||
let CylandAccordionListItem = React.createClass({
|
let CylandAccordionListItem = React.createClass({
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user