import React, { Component } from 'react' import './Sondage.css' import { connect } from 'react-redux' import ReactCSSTransitionGroup from 'react-addons-css-transition-group' import Smiley from './SatisfactionSmiley' import TypeFormEmbed from './TypeFormEmbed' import PropTypes from 'prop-types' import { Trans, translate } from 'react-i18next' @connect(state => ({ targets: state.analysis ? state.analysis.targets : [], activeInput: state.activeTargetInput, currentQuestion: state.currentQuestion, conversationStarted: state.conversationStarted })) @translate() export default class Sondage extends Component { state = { visible: false, showForm: false, askFeedbackTime: 'AFTER_FIRST_ESTIMATE' } static contextTypes = { i18n: PropTypes.object.isRequired } static getDerivedStateFromProps(nextProps, currentState) { let feedbackAlreadyAsked = !!document.cookie.includes('feedback_asked=true') let conditions = { AFTER_FIRST_ESTIMATE: nextProps.activeInput && nextProps.targets.length, AFTER_SIMULATION_COMPLETED: !nextProps.currentQuestion && nextProps.conversationStarted } return { visible: conditions[currentState.askFeedbackTime] && !feedbackAlreadyAsked } } componentDidMount() { this.setState({ askFeedbackTime: Math.random() > 0.5 ? 'AFTER_SIMULATION_COMPLETED' : 'AFTER_FIRST_ESTIMATE' }) } handleClose = () => { this.setState({ visible: false }) this.setCookie() } setCookie = () => { document.cookie = 'feedback_asked=true;' } onSmileyClick = satisfaction => { this.setState({ showForm: true, satisfaction, visible: false }) this.setCookie() } render() { let { satisfaction, showForm, visible, askFeedbackTime } = this.state return ( <> {showForm && ( )} {visible && ( Votre avis nous intéresse ! X )} > ) } }