import React, { Component } from 'react' import { bindActionCreators } from 'redux' import { connect } from 'react-redux' import { Link } from 'react-router-dom' import * as actions from '../actions' import { TableObject, Loader } from '../common' import { USES_DATASET } from '../types' class CitationList extends Component { componentDidMount() { const { citations, api } = this.props const { paperInfo, unknownCitations, verifications } = api const { dataset } = paperInfo if (!dataset || !citations || !verifications[dataset.key]) { this.props.actions.setSortedCitations([]) return } let verifiedLookup = verifications[dataset.key] || {} const sortedCitations = citations.map(citation => [ citation.title, verifiedLookup[citation.id] ? verifiedLookup[citation.id].uses_dataset : USES_DATASET.NO_DATA, citation.pdf.length, citation ]) .sort((a,b) => (b[1] - a[1] || b[2] - a[2] || (a[0].localeCompare(b[0])))) .map(tup => tup[3]) this.props.actions.setSortedCitations(sortedCitations) } render() { const { citations, title, api } = this.props const { paperInfo, unknownCitations, verifications, sortedCitations } = api const { dataset } = paperInfo if (!dataset || !citations || !verifications[dataset.key]) return let verifiedLookup = verifications[dataset.key] || {} // console.log(verifications) return (

{title}

) } } const mapStateToProps = state => ({ api: state.api, }) const mapDispatchToProps = dispatch => ({ actions: bindActionCreators({ ...actions }, dispatch), }) export default connect(mapStateToProps, mapDispatchToProps)(CitationList)