import React, { useState } from 'react'; import { FormattedMessage, defineMessages, useIntl } from 'react-intl'; import { useDispatch } from 'react-redux'; import { changeSettingImmediate } from 'soapbox/actions/settings'; import snackbar from 'soapbox/actions/snackbar'; import { Column, Button, Form, FormActions, FormGroup, Input, Text } from 'soapbox/components/ui'; const messages = defineMessages({ heading: { id: 'column.developers', defaultMessage: 'Developers' }, answerLabel: { id: 'developers.challenge.answer_label', defaultMessage: 'Answer' }, answerPlaceholder: { id: 'developers.challenge.answer_placeholder', defaultMessage: 'Your answer' }, success: { id: 'developers.challenge.success', defaultMessage: 'You are now a developer' }, fail: { id: 'developers.challenge.fail', defaultMessage: 'Wrong answer' }, }); const DevelopersChallenge = () => { const dispatch = useDispatch(); const intl = useIntl(); const [answer, setAnswer] = useState(''); const handleChangeAnswer = (e: React.ChangeEvent) => { setAnswer(e.target.value); }; const handleSubmit = () => { if (answer === 'boxsoap') { dispatch(changeSettingImmediate(['isDeveloper'], true)); dispatch(snackbar.success(intl.formatMessage(messages.success))); } else { dispatch(snackbar.error(intl.formatMessage(messages.fail))); } }; const challenge = `function soapbox() { return 'soap|box'.split('|').reverse().join(''); }`; return (
soapbox() }} /> {challenge}
); }; export default DevelopersChallenge;