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