1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
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 <Loader />
let verifiedLookup = verifications[dataset.key] || {}
// console.log(verifications)
return (
<div className='citations'>
<h2>{title}</h2>
<ul>
{(sortedCitations || []).map((citation, i) => {
let cite = { ...citation }
cite.id = {
_raw: true,
value: <Link to={'/paper/' + dataset.key + '/verify/' + citation.id}>{citation.id}</Link>
}
cite.pdf = {
_raw: true,
value: (cite.pdf && cite.pdf.length)
? cite.pdf.map((pdf, i) => <a key={'pdf_' + i} href={pdf} rel='noopener noreferrer' target="_blank">[pdf]</a>)
: "no pdf"
}
cite.s2 = {
_raw: true,
value: <a
href={'https://www.semanticscholar.org/paper/' + citation.id}
target="_blank"
rel="noopener noreferrer"
className={'pdfLink'}
>{'[semantic scholar]'}</a>
}
cite.addresses = {
_raw: true,
value: (cite.addresses || []).map((address, j) => (
<div key={j}>{address.name}{', '}<span className='type'>{address.type}</span></div>
))
}
if (citation.id in verifiedLookup) {
const verification = verifiedLookup[citation.id]
cite.verified = {
_raw: true,
value: verification.uses_dataset === USES_DATASET.YES
? <span className='verified'>uses dataset</span>
: verification.uses_dataset === USES_DATASET.NO
? <span className='unverified'>{"doesn't use dataset"}</span>
: <span className='not_enough_info'>{"not enough information"}</span>
}
}
else {
cite.verified = {
_raw: true,
value: <span className='unknown'>unknown</span>
}
}
return (
<li key={i}>
<TableObject
summary
object={cite}
tag={cite.title}
order={['id', 'pdf', 's2', 'year', 'addresses', 'verified']}
/>
</li>
)
})}
</ul>
</div>
)
}
}
const mapStateToProps = state => ({
api: state.api,
})
const mapDispatchToProps = dispatch => ({
actions: bindActionCreators({ ...actions }, dispatch),
})
export default connect(mapStateToProps, mapDispatchToProps)(CitationList)
|