2018-08-23 16:25:18 +00:00
|
|
|
import withLanguage from 'Components/utils/withLanguage'
|
|
|
|
import withTracker from 'Components/utils/withTracker'
|
2018-05-02 15:55:25 +00:00
|
|
|
import React, { Component } from 'react'
|
2018-05-03 16:55:22 +00:00
|
|
|
import { Trans, translate } from 'react-i18next'
|
2018-06-18 08:49:02 +00:00
|
|
|
import { connect } from 'react-redux'
|
2018-06-13 15:34:33 +00:00
|
|
|
import {
|
2018-06-18 08:49:02 +00:00
|
|
|
nextStepsSelector,
|
|
|
|
noUserInputSelector
|
2018-06-13 15:34:33 +00:00
|
|
|
} from 'Selectors/analyseSelectors'
|
2018-06-18 08:49:02 +00:00
|
|
|
import Smiley from './SatisfactionSmiley'
|
2018-05-02 15:55:25 +00:00
|
|
|
|
|
|
|
@connect(state => ({
|
2018-06-13 15:34:33 +00:00
|
|
|
conversationStarted: state.conversationStarted,
|
|
|
|
noUserInput: noUserInputSelector(state),
|
|
|
|
nextSteps: nextStepsSelector(state)
|
2018-05-02 15:55:25 +00:00
|
|
|
}))
|
2018-05-03 16:55:22 +00:00
|
|
|
@translate()
|
2018-04-27 13:51:31 +00:00
|
|
|
@withLanguage
|
2018-08-23 16:25:18 +00:00
|
|
|
@withTracker
|
2018-05-03 16:55:22 +00:00
|
|
|
export default class Sondage extends Component {
|
|
|
|
state = {
|
2018-08-23 16:25:18 +00:00
|
|
|
visible: true,
|
2018-05-03 16:55:22 +00:00
|
|
|
showForm: false,
|
|
|
|
askFeedbackTime: 'AFTER_FIRST_ESTIMATE'
|
|
|
|
}
|
2018-05-03 13:24:19 +00:00
|
|
|
|
2018-05-03 16:55:22 +00:00
|
|
|
handleClose = () => {
|
|
|
|
this.setState({ visible: false })
|
|
|
|
}
|
|
|
|
onSmileyClick = satisfaction => {
|
2018-08-23 16:25:18 +00:00
|
|
|
this.props.tracker.push(['trackEvent', 'feedback', 'smiley', satisfaction])
|
2018-05-03 16:55:22 +00:00
|
|
|
this.setState({ showForm: true, satisfaction, visible: false })
|
|
|
|
}
|
2018-05-02 15:55:25 +00:00
|
|
|
render() {
|
2018-08-23 16:25:18 +00:00
|
|
|
let { satisfaction, showForm, visible } = this.state
|
2018-05-02 15:55:25 +00:00
|
|
|
return (
|
2018-08-23 16:25:18 +00:00
|
|
|
<div className="sondage__container">
|
|
|
|
{showForm &&
|
|
|
|
(satisfaction === ':|' ? (
|
|
|
|
<p className="ui__ notice">
|
|
|
|
<strong>
|
|
|
|
<Trans i18nKey="feedback.bad.headline">
|
|
|
|
Nous sommes désolé de ne pas vous avoir apporté entière
|
|
|
|
satisfaction.
|
|
|
|
</Trans>
|
|
|
|
</strong>{' '}
|
|
|
|
<Trans i18nKey="feedback.bad.support">
|
|
|
|
Si vous le souhaitez, vous pouvez nous envoyer un mail à{' '}
|
|
|
|
<a href="mailto:contact@embauche.beta.gouv.fr">
|
|
|
|
contact@embauche.beta.gouv.fr
|
|
|
|
</a>
|
|
|
|
Nous vous garantissons de vous répondre au plus vite, et de
|
|
|
|
faire tout notre possible pour vous venir en aide
|
|
|
|
</Trans>
|
|
|
|
</p>
|
|
|
|
) : (
|
|
|
|
<p className="ui__ notice">
|
|
|
|
<strong>
|
|
|
|
<Trans i18nKey="feedback.good.headline">
|
|
|
|
Merci pour votre retour !
|
|
|
|
</Trans>
|
|
|
|
</strong>{' '}
|
|
|
|
<Trans i18nKey="feedback.good.support">
|
|
|
|
Si vous avez une remarque, ou une idée d'amélioration, n'hésitez
|
|
|
|
pas à nous contacter directement par mail à
|
|
|
|
<a href="mailto:contact@embauche.beta.gouv.fr">
|
|
|
|
contact@embauche.beta.gouv.fr
|
|
|
|
</a>
|
|
|
|
</Trans>
|
|
|
|
</p>
|
|
|
|
))}
|
|
|
|
{visible && (
|
|
|
|
<p className="ui__ notice">
|
|
|
|
<span className="sondage__text">
|
|
|
|
<Trans>Votre avis nous intéresse !</Trans>
|
|
|
|
</span>
|
|
|
|
<br />
|
|
|
|
<Smiley
|
|
|
|
text=":)"
|
|
|
|
hoverColor="#16a085"
|
|
|
|
onClick={this.onSmileyClick}
|
|
|
|
/>
|
|
|
|
<Smiley
|
|
|
|
text=":|"
|
|
|
|
hoverColor="#f39c12"
|
|
|
|
onClick={this.onSmileyClick}
|
|
|
|
/>
|
|
|
|
</p>
|
2018-05-03 13:24:19 +00:00
|
|
|
)}
|
2018-08-23 16:25:18 +00:00
|
|
|
</div>
|
2018-05-02 15:55:25 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|