Modal.jsx 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import { ModalWrapper, ModalPara, ModalButton } from './style.js';
  4. const ModalWindow = ({ isActive, handleClickClose }) => {
  5. if (isActive) {
  6. return (
  7. <ModalWrapper>
  8. <ModalButton onClick={handleClickClose}>X</ModalButton>
  9. <ModalPara>
  10. Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
  11. eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
  12. minim veniam, quis nostrud exercitation ullamco laboris nisi ut
  13. aliquip ex ea commodo consequat. Duis aute irure dolor in
  14. reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla
  15. pariatur. Excepteur sint occaecat cupidatat non proident, sunt in
  16. culpa qui officia deserunt mollit anim id est laborum.
  17. </ModalPara>
  18. </ModalWrapper>
  19. );
  20. }
  21. return null;
  22. };
  23. ModalWindow.displayName = 'ModalWindow';
  24. ModalWindow.PropTypes = {
  25. isActive: PropTypes.bool.isRequired,
  26. handleClickClose: PropTypes.func.isRequired
  27. };
  28. export { ModalWindow };
  29. export default class Modal extends React.Component {
  30. state = { isActive: false };
  31. handleClick = () => {
  32. this.setState({ isActive: true });
  33. };
  34. handleCloseModal = () => {
  35. this.setState({ isActive: false });
  36. };
  37. render() {
  38. return (
  39. <div>
  40. <button className="show" onClick={this.handleClick}>Show Modal</button>
  41. <ModalWindow
  42. isActive={this.state.isActive}
  43. handleClickClose={this.handleCloseModal}
  44. />
  45. </div>
  46. );
  47. }
  48. }