mon-entreprise/source/components/QuickLinks.js

77 lines
1.8 KiB
JavaScript
Raw Normal View History

/* @flow */
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';
import type { Location } from 'react-router'
type Props = {
startConversation: (?string) => void,
location: Location,
validInputEntered: boolean,
quickLinks: {[string]: string},
conversationStarted: boolean
}
2018-09-10 12:28:25 +00:00
2019-01-17 14:34:44 +00:00
const QuickLinks = ({
startConversation,
2019-01-17 14:34:44 +00:00
validInputEntered,
quickLinks,
conversationStarted
}: Props) => {
2019-01-17 14:34:44 +00:00
const show = validInputEntered && !conversationStarted
return (
<Spring
to={{
height: show ? 'auto' : 0,
opacity: show ? 1 : 0
}}
config={{ delay: show ? 2000 : 0 }}
native>
{styles => (
<animated.div
className="ui__ answer-group"
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>
)
}
export default compose(
withLanguage,
withRouter,
connect(
(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"]
}),
{
startConversation
}
)
2019-01-17 14:34:44 +00:00
)(QuickLinks)