2018-07-23 14:26:11 +00:00
|
|
|
/* @flow */
|
2019-01-31 16:33:14 +00:00
|
|
|
import { startConversation } from 'Actions/actions';
|
|
|
|
import withLanguage from 'Components/utils/withLanguage';
|
|
|
|
import { compose, toPairs } from 'ramda';
|
|
|
|
import React from 'react';
|
|
|
|
import { Trans } from 'react-i18next';
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { withRouter } from 'react-router';
|
|
|
|
import { animated, Spring } from 'react-spring';
|
|
|
|
import { validInputEnteredSelector } 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 = {
|
|
|
|
quickLinks: {[string]: string},
|
|
|
|
}
|
|
|
|
type Props = OwnProps & {
|
2018-10-04 13:20:57 +00:00
|
|
|
startConversation: (?string) => void,
|
|
|
|
location: Location,
|
2019-01-31 16:33:14 +00:00
|
|
|
validInputEntered: boolean,
|
|
|
|
conversationStarted: boolean
|
2018-07-23 14:26:11 +00:00
|
|
|
}
|
2018-09-10 12:28:25 +00:00
|
|
|
|
2019-01-17 14:34:44 +00:00
|
|
|
const QuickLinks = ({
|
2018-10-04 13:20:57 +00:00
|
|
|
startConversation,
|
2019-01-17 14:34:44 +00:00
|
|
|
validInputEntered,
|
|
|
|
quickLinks,
|
|
|
|
conversationStarted
|
2018-10-04 13:20:57 +00:00
|
|
|
}: Props) => {
|
2019-01-17 14:34:44 +00:00
|
|
|
const show = validInputEntered && !conversationStarted
|
2018-10-04 13:20:57 +00:00
|
|
|
return (
|
|
|
|
<Spring
|
|
|
|
to={{
|
|
|
|
height: show ? 'auto' : 0,
|
|
|
|
opacity: show ? 1 : 0
|
|
|
|
}}
|
2019-01-31 16:33:14 +00:00
|
|
|
config={{ delay: show ? 2000 : 0 }}
|
2018-10-04 13:20:57 +00:00
|
|
|
native>
|
|
|
|
{styles => (
|
|
|
|
<animated.div
|
2019-01-24 10:28:00 +00:00
|
|
|
className="ui__ answer-group"
|
2018-10-04 13:20:57 +00:00
|
|
|
style={{
|
|
|
|
...styles,
|
|
|
|
display: 'flex',
|
|
|
|
overflow: 'hidden',
|
|
|
|
flexWrap: 'wrap-reverse',
|
|
|
|
fontSize: '110%',
|
|
|
|
justifyContent: 'space-evenly',
|
|
|
|
marginBottom: '0.6rem'
|
|
|
|
}}>
|
|
|
|
{toPairs(quickLinks).map(([label, dottedName]) => (
|
|
|
|
<button
|
|
|
|
key={label}
|
|
|
|
className="ui__ link-button"
|
|
|
|
onClick={() => startConversation(dottedName)}>
|
|
|
|
<Trans>{label}</Trans>
|
|
|
|
</button>
|
|
|
|
))}
|
|
|
|
</animated.div>
|
|
|
|
)}
|
|
|
|
</Spring>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
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-01-17 14:34:44 +00:00
|
|
|
validInputEntered: validInputEnteredSelector(state),
|
|
|
|
conversationStarted: state.conversationStarted,
|
|
|
|
quickLinks: state.simulation?.config["questions à l'affiche"]
|
2018-10-04 13:20:57 +00:00
|
|
|
}),
|
2018-07-31 13:32:41 +00:00
|
|
|
{
|
|
|
|
startConversation
|
|
|
|
}
|
|
|
|
)
|
2019-02-03 17:05:55 +00:00
|
|
|
)(QuickLinks): React$ComponentType<OwnProps>)
|