lbry-desktop/ui/js/component/fileTile/index.js

37 lines
1.2 KiB
JavaScript
Raw Normal View History

2017-06-06 17:19:12 -04:00
import React from "react";
import { connect } from "react-redux";
import { doNavigate } from "actions/app";
import { doResolveUri } from "actions/content";
2017-04-23 21:01:00 +07:00
import {
makeSelectClaimForUri,
2017-05-08 18:22:27 -04:00
makeSelectMetadataForUri,
2017-06-06 17:19:12 -04:00
} from "selectors/claims";
import { makeSelectFileInfoForUri } from "selectors/file_info";
2017-06-28 14:12:01 +07:00
import { selectShowNsfw } from "selectors/settings";
2017-06-06 17:19:12 -04:00
import { makeSelectIsResolvingForUri } from "selectors/content";
import FileTile from "./view";
2017-04-23 16:56:50 +07:00
const makeSelect = () => {
2017-06-06 17:19:12 -04:00
const selectClaimForUri = makeSelectClaimForUri();
const selectFileInfoForUri = makeSelectFileInfoForUri();
const selectMetadataForUri = makeSelectMetadataForUri();
const selectResolvingUri = makeSelectIsResolvingForUri();
2017-05-08 18:22:27 -04:00
const select = (state, props) => ({
claim: selectClaimForUri(state, props),
fileInfo: selectFileInfoForUri(state, props),
2017-06-28 14:12:01 +07:00
obscureNsfw: !selectShowNsfw(state),
2017-05-08 18:22:27 -04:00
metadata: selectMetadataForUri(state, props),
isResolvingUri: selectResolvingUri(state, props),
2017-06-06 17:19:12 -04:00
});
2017-06-06 17:19:12 -04:00
return select;
2017-06-05 21:21:55 -07:00
};
2017-04-23 16:56:50 +07:00
2017-06-05 21:21:55 -07:00
const perform = dispatch => ({
2017-05-11 19:28:43 -04:00
navigate: (path, params) => dispatch(doNavigate(path, params)),
2017-06-06 17:19:12 -04:00
resolveUri: uri => dispatch(doResolveUri(uri)),
2017-06-05 21:21:55 -07:00
});
2017-04-23 16:56:50 +07:00
2017-06-05 21:21:55 -07:00
export default connect(makeSelect, perform)(FileTile);