0f68bad3eb
## Why Frequently used; top in perf profile ## Changes Most of the time, you already have the claim object in the current context. `selectClaimIsMineForUri` will retrieve the claim again, which is wasteful, even if it is memoized (looking up the cache still takes time). Break apart the logic and added the alternative `selectClaimIsMine` for faster lookup.
59 lines
2.2 KiB
JavaScript
59 lines
2.2 KiB
JavaScript
import { connect } from 'react-redux';
|
|
|
|
import { withRouter } from 'react-router-dom';
|
|
import CollectionPage from './view';
|
|
import {
|
|
makeSelectTitleForUri,
|
|
makeSelectThumbnailForUri,
|
|
selectClaimIsMine,
|
|
makeSelectClaimIsPending,
|
|
makeSelectClaimForClaimId,
|
|
makeSelectChannelForClaimUri,
|
|
} from 'redux/selectors/claims';
|
|
|
|
import {
|
|
makeSelectCollectionForId,
|
|
makeSelectUrlsForCollectionId,
|
|
makeSelectIsResolvingCollectionForId,
|
|
makeSelectCollectionIsMine,
|
|
makeSelectCountForCollectionId,
|
|
makeSelectEditedCollectionForId,
|
|
} from 'redux/selectors/collections';
|
|
|
|
import { doFetchItemsInCollection, doCollectionDelete, doCollectionEdit } from 'redux/actions/collections';
|
|
import { selectUser } from 'redux/selectors/user';
|
|
|
|
const select = (state, props) => {
|
|
const { match } = props;
|
|
const { params } = match;
|
|
const { collectionId } = params;
|
|
|
|
const claim = collectionId && makeSelectClaimForClaimId(collectionId)(state);
|
|
const uri = (claim && (claim.canonical_url || claim.permanent_url)) || null;
|
|
|
|
return {
|
|
collectionId,
|
|
claim,
|
|
collection: makeSelectCollectionForId(collectionId)(state),
|
|
collectionUrls: makeSelectUrlsForCollectionId(collectionId)(state),
|
|
collectionCount: makeSelectCountForCollectionId(collectionId)(state),
|
|
isResolvingCollection: makeSelectIsResolvingCollectionForId(collectionId)(state),
|
|
title: makeSelectTitleForUri(uri)(state),
|
|
thumbnail: makeSelectThumbnailForUri(uri)(state),
|
|
isMyClaim: selectClaimIsMine(state, claim), // or collection is mine?
|
|
isMyCollection: makeSelectCollectionIsMine(collectionId)(state),
|
|
claimIsPending: makeSelectClaimIsPending(uri)(state),
|
|
collectionHasEdits: Boolean(makeSelectEditedCollectionForId(collectionId)(state)),
|
|
uri,
|
|
user: selectUser(state),
|
|
channel: uri && makeSelectChannelForClaimUri(uri)(state),
|
|
};
|
|
};
|
|
|
|
const perform = (dispatch) => ({
|
|
fetchCollectionItems: (claimId, cb) => dispatch(doFetchItemsInCollection({ collectionId: claimId }, cb)), // if this collection is not resolved, resolve it
|
|
deleteCollection: (id, colKey) => dispatch(doCollectionDelete(id, colKey)),
|
|
editCollection: (id, params) => dispatch(doCollectionEdit(id, params)),
|
|
});
|
|
|
|
export default withRouter(connect(select, perform)(CollectionPage));
|