2017-03-14 10:42:44 +00:00
|
|
|
import React from 'react'
|
|
|
|
import R from 'ramda'
|
2017-03-15 17:13:46 +00:00
|
|
|
import classNames from 'classnames'
|
2017-03-14 10:42:44 +00:00
|
|
|
|
2017-03-27 16:37:11 +00:00
|
|
|
let treatValue = data =>
|
2017-03-28 16:52:01 +00:00
|
|
|
data == null
|
|
|
|
? '?'
|
|
|
|
: R.is(Number)(data) ? Math.round(data) : data ? 'oui' : 'non'
|
2017-03-15 17:13:46 +00:00
|
|
|
|
2017-03-27 16:37:11 +00:00
|
|
|
let NodeValue = ({data}) => (
|
2017-03-28 16:52:01 +00:00
|
|
|
<span className={'situationValue ' + treatValue(data)}>
|
|
|
|
←
|
|
|
|
{treatValue(data)}
|
|
|
|
</span>
|
2017-03-27 16:37:11 +00:00
|
|
|
)
|
2017-03-15 17:13:46 +00:00
|
|
|
|
|
|
|
// Un élément du graphe de calcul qui a une valeur interprétée (à afficher)
|
2017-03-27 16:37:11 +00:00
|
|
|
export class Node extends React.Component {
|
|
|
|
render() {
|
2017-03-28 16:52:01 +00:00
|
|
|
let
|
|
|
|
{classes, name, value, child} = this.props,
|
|
|
|
termDefinition = R.contains('mecanism', classes) && name
|
2017-03-15 17:13:46 +00:00
|
|
|
|
2017-03-27 16:37:11 +00:00
|
|
|
return (
|
2017-03-28 16:52:01 +00:00
|
|
|
<div className={classNames(classes, 'node')}>
|
|
|
|
{name &&
|
|
|
|
<span className="nodeHead">
|
|
|
|
<span className="name" data-term-definition={termDefinition} >{name}</span>
|
|
|
|
<NodeValue data={value} />
|
|
|
|
</span>}
|
|
|
|
{child}
|
|
|
|
{!name && <NodeValue data={value} />}
|
|
|
|
</div>
|
2017-03-27 16:37:11 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
2017-03-15 17:13:46 +00:00
|
|
|
|
|
|
|
// Un élément du graphe de calcul qui a une valeur interprétée (à afficher)
|
2017-03-27 16:37:11 +00:00
|
|
|
export let Leaf = ({classes, name, value}) => (
|
2017-03-28 16:52:01 +00:00
|
|
|
<span className={classNames(classes, 'leaf')}>
|
|
|
|
{name &&
|
|
|
|
<span className="nodeHead">
|
|
|
|
<span className="name">{name}<NodeValue data={value} /></span>
|
|
|
|
</span>}
|
|
|
|
</span>
|
2017-03-27 16:37:11 +00:00
|
|
|
)
|