2018-07-23 14:26:11 +00:00
|
|
|
/* @flow */
|
2019-06-05 14:57:08 +00:00
|
|
|
import { goToQuestion } from 'Actions/actions'
|
2019-06-12 10:04:15 +00:00
|
|
|
import { T } from 'Components'
|
2019-02-27 13:36:50 +00:00
|
|
|
import withLanguage from 'Components/utils/withLanguage'
|
2019-09-08 10:17:30 +00:00
|
|
|
import { compose, contains, filter, reject, toPairs } from 'ramda'
|
2019-07-02 14:28:23 +00:00
|
|
|
import React, { Fragment } from 'react'
|
2019-02-27 13:36:50 +00:00
|
|
|
import { connect } from 'react-redux'
|
|
|
|
import { withRouter } from 'react-router'
|
2019-09-08 10:17:30 +00:00
|
|
|
import {
|
|
|
|
currentQuestionSelector,
|
|
|
|
nextStepsSelector
|
|
|
|
} from 'Selectors/analyseSelectors'
|
2018-10-04 13:20:57 +00:00
|
|
|
import type { Location } from 'react-router'
|
|
|
|
|
2019-02-03 17:05:55 +00:00
|
|
|
type OwnProps = {
|
2019-02-27 13:36:50 +00:00
|
|
|
quickLinks: { [string]: string }
|
2019-02-03 17:05:55 +00:00
|
|
|
}
|
|
|
|
type Props = OwnProps & {
|
2019-06-05 14:57:08 +00:00
|
|
|
goToQuestion: string => void,
|
2018-10-04 13:20:57 +00:00
|
|
|
location: Location,
|
2019-09-08 10:17:30 +00:00
|
|
|
nextSteps: Array<string>,
|
2019-06-05 16:11:29 +00:00
|
|
|
quickLinksToHide: Array<string>,
|
2019-04-19 17:05:01 +00:00
|
|
|
show: boolean
|
2018-07-23 14:26:11 +00:00
|
|
|
}
|
2018-09-10 12:28:25 +00:00
|
|
|
|
2019-09-08 10:17:30 +00:00
|
|
|
const QuickLinks = ({
|
|
|
|
goToQuestion,
|
|
|
|
nextSteps,
|
|
|
|
quickLinks,
|
|
|
|
quickLinksToHide
|
|
|
|
}: Props) => {
|
2019-06-05 16:11:29 +00:00
|
|
|
if (!quickLinks) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
const links = compose(
|
|
|
|
toPairs,
|
2019-09-08 10:17:30 +00:00
|
|
|
filter(dottedName => contains(dottedName, nextSteps)),
|
2019-06-05 16:11:29 +00:00
|
|
|
reject(dottedName => contains(dottedName, quickLinksToHide))
|
|
|
|
)(quickLinks)
|
2019-06-20 15:57:13 +00:00
|
|
|
|
2018-10-04 13:20:57 +00:00
|
|
|
return (
|
2019-06-20 15:57:13 +00:00
|
|
|
!!links.length && (
|
|
|
|
<span>
|
|
|
|
<small>
|
|
|
|
<T k="quicklinks.autres">Autres questions :</T>
|
2019-09-05 15:21:58 +00:00
|
|
|
</small>
|
2019-06-20 15:57:13 +00:00
|
|
|
{links.map(([label, dottedName]) => (
|
2019-07-02 14:28:23 +00:00
|
|
|
<Fragment key={dottedName}>
|
2019-06-20 15:57:13 +00:00
|
|
|
<button
|
|
|
|
className="ui__ link-button"
|
2019-09-05 15:21:58 +00:00
|
|
|
css="margin: 0 0.4rem !important"
|
2019-06-20 15:57:13 +00:00
|
|
|
onClick={() => goToQuestion(dottedName)}>
|
|
|
|
<T k={'quicklinks.' + label}>{label}</T>
|
2019-09-05 15:21:58 +00:00
|
|
|
</button>
|
2019-07-02 14:28:23 +00:00
|
|
|
</Fragment>
|
2019-06-20 15:57:13 +00:00
|
|
|
))}{' '}
|
|
|
|
{/* <button className="ui__ link-button">Voir la liste</button> */}
|
|
|
|
</span>
|
|
|
|
)
|
2018-10-04 13:20:57 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2019-02-03 17:05:55 +00:00
|
|
|
export default (compose(
|
2018-07-31 13:32:41 +00:00
|
|
|
withLanguage,
|
2018-10-04 13:20:57 +00:00
|
|
|
withRouter,
|
2018-07-31 13:32:41 +00:00
|
|
|
connect(
|
2018-10-04 13:20:57 +00:00
|
|
|
(state, props) => ({
|
|
|
|
key: props.language,
|
2019-09-08 10:17:30 +00:00
|
|
|
nextSteps: nextStepsSelector(state),
|
2019-06-20 15:57:13 +00:00
|
|
|
quickLinks: state.simulation?.config.questions?.["à l'affiche"],
|
2019-06-05 16:11:29 +00:00
|
|
|
quickLinksToHide: [
|
|
|
|
...state.conversationSteps.foldedSteps,
|
2019-06-12 10:04:15 +00:00
|
|
|
currentQuestionSelector(state)
|
2019-06-05 16:11:29 +00:00
|
|
|
]
|
2018-10-04 13:20:57 +00:00
|
|
|
}),
|
2018-07-31 13:32:41 +00:00
|
|
|
{
|
2019-06-05 14:57:08 +00:00
|
|
|
goToQuestion
|
2018-07-31 13:32:41 +00:00
|
|
|
}
|
|
|
|
)
|
2019-02-03 17:05:55 +00:00
|
|
|
)(QuickLinks): React$ComponentType<OwnProps>)
|