mon-entreprise/source/components/Controls.js

72 lines
1.9 KiB
JavaScript
Raw Normal View History

import React from 'react'
import './Controls.css'
import emoji from 'react-easy-emoji'
import { connect } from 'react-redux'
2018-10-02 16:14:01 +00:00
import { startConversation, hideControl } from 'Actions/actions'
2018-09-12 13:07:46 +00:00
import { makeJsx } from 'Engine/evaluation'
2018-09-12 15:49:50 +00:00
import { createMarkdownDiv } from 'Engine/marked'
2018-10-02 14:52:27 +00:00
import withColours from './utils/withColours'
import withLanguage from 'Components/utils/withLanguage'
function Controls({
controls,
startConversation,
2018-10-02 16:14:01 +00:00
hideControl,
2018-10-02 14:52:27 +00:00
foldedSteps,
2018-10-02 16:14:01 +00:00
colours,
hiddenControls
}) {
if (!controls?.length) return null
return (
2018-09-11 15:33:11 +00:00
<div id="controlsBlock">
<ul>
{controls.map(({ level, test, message, solution, evaluated }) =>
hiddenControls.includes(test) ? null : (
<li
key={test}
className="control"
style={{ background: colours.lightenColour(45) }}>
{emoji(level == 'avertissement' ? '⚠️' : '')}
<div className="controlText">
{message && createMarkdownDiv(message)}
{!message && (
<span id="controlExplanation">{makeJsx(evaluated)}</span>
)}
{solution && !foldedSteps.includes(solution.cible) && (
<div id="solution">
{/*emoji('💡')*/}
2018-10-02 16:28:56 +00:00
<button
key={solution.cible}
className="ui__ link-button"
onClick={() => startConversation(solution.cible)}>
{solution.texte}
2018-10-02 16:28:56 +00:00
</button>
</div>
)}
</div>
<button
className="hide"
aria-label="close"
onClick={() => hideControl(test)}>
×
</button>
</li>
)
)}
</ul>
</div>
)
}
export default connect(
(state, props) => ({
foldedSteps: state.conversationSteps.foldedSteps,
2018-10-02 16:14:01 +00:00
key: props.language,
hiddenControls: state.hiddenControls
}),
2018-10-02 16:14:01 +00:00
dispatch => ({
startConversation: cible => dispatch(startConversation(cible)),
hideControl: id => dispatch(hideControl(id))
})
)(withColours(withLanguage(Controls)))