mirror of
https://github.com/freeCodeCamp/freeCodeCamp.git
synced 2026-05-26 04:01:17 -04:00
85 lines
2.3 KiB
JavaScript
85 lines
2.3 KiB
JavaScript
import React, { Component } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { bindActionCreators } from 'redux';
|
|
import { connect } from 'react-redux';
|
|
import { Button, Modal } from '@freecodecamp/react-bootstrap';
|
|
|
|
import ga from '../../../analytics';
|
|
import { createQuestion, closeModal, isHelpModalOpenSelector } from '../redux';
|
|
|
|
import './help-modal.css';
|
|
|
|
const mapStateToProps = state => ({ isOpen: isHelpModalOpenSelector(state) });
|
|
const mapDispatchToProps = dispatch =>
|
|
bindActionCreators(
|
|
{ createQuestion, closeHelpModal: () => closeModal('help') },
|
|
dispatch
|
|
);
|
|
|
|
const propTypes = {
|
|
closeHelpModal: PropTypes.func.isRequired,
|
|
createQuestion: PropTypes.func.isRequired,
|
|
isOpen: PropTypes.bool
|
|
};
|
|
|
|
const RSA =
|
|
'https://forum.freecodecamp.org/t/the-read-search-ask-methodology-for-' +
|
|
'getting-unstuck/137307';
|
|
|
|
export class HelpModal extends Component {
|
|
render() {
|
|
const { isOpen, closeHelpModal, createQuestion } = this.props;
|
|
if (isOpen) {
|
|
ga.modalview('/help-modal');
|
|
}
|
|
return (
|
|
<Modal dialogClassName='help-modal' onHide={closeHelpModal} show={isOpen}>
|
|
<Modal.Header
|
|
className='help-modal-header fcc-modal'
|
|
closeButton={true}
|
|
>
|
|
<Modal.Title className='text-center'>Ask for help?</Modal.Title>
|
|
</Modal.Header>
|
|
<Modal.Body className='help-modal-body text-center'>
|
|
<h3>
|
|
If you've already tried the
|
|
<a
|
|
href={RSA}
|
|
rel='noopener noreferrer'
|
|
target='_blank'
|
|
title='Read, search, ask'
|
|
>
|
|
Read-Search-Ask
|
|
</a>
|
|
method, then you can ask for help on the freeCodeCamp forum.
|
|
</h3>
|
|
<Button
|
|
block={true}
|
|
bsSize='lg'
|
|
bsStyle='primary'
|
|
onClick={createQuestion}
|
|
>
|
|
Create a help post on the forum
|
|
</Button>
|
|
<Button
|
|
block={true}
|
|
bsSize='lg'
|
|
bsStyle='primary'
|
|
onClick={closeHelpModal}
|
|
>
|
|
Cancel
|
|
</Button>
|
|
</Modal.Body>
|
|
</Modal>
|
|
);
|
|
}
|
|
}
|
|
|
|
HelpModal.displayName = 'HelpModal';
|
|
HelpModal.propTypes = propTypes;
|
|
|
|
export default connect(
|
|
mapStateToProps,
|
|
mapDispatchToProps
|
|
)(HelpModal);
|