This is just a technology testing project based on Create React App and TailwindCSS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

60 lines
3.5KB

  1. import React, { useState } from 'react'
  2. import ButtonPrimary from './components/controls/ButtonPrimary'
  3. import Popup from './components/Popup';
  4. import { FormLogin } from './components/forms/FormLogin'
  5. import { FormRegistration } from './components/forms/FormRegistration';
  6. import { FormFeedback } from './components/forms/FormFeedback';
  7. const App = () => {
  8. const [popupTitle, setPopupTitle] = useState('')
  9. const [popupContent, setPopupContent] = useState(<></>)
  10. const [popupOpened, setPopupOpened] = useState(false)
  11. const close = () => {
  12. setPopupOpened(false)
  13. }
  14. const doOpenLoginPopup = () => {
  15. setPopupContent(<FormLogin setPopupTitle={setPopupTitle} setPopupContent={setPopupContent} setPopupOpened={setPopupOpened} close={close} />)
  16. setPopupOpened(true)
  17. }
  18. const doOpenRegistrationPopup = () => {
  19. setPopupContent(<FormRegistration setPopupTitle={setPopupTitle} setPopupContent={setPopupContent} setPopupOpened={setPopupOpened} close={close} />)
  20. setPopupOpened(true)
  21. }
  22. const doOpenFeedbackPopup = () => {
  23. setPopupContent(<FormFeedback setPopupTitle={setPopupTitle} setPopupContent={setPopupContent} setPopupOpened={setPopupOpened} close={close} />)
  24. setPopupOpened(true)
  25. }
  26. return (
  27. <>
  28. <div className="w-full h-full min-h-screen bg-white text-gray-900 text-lg flex items-center font-gilroy">
  29. <div className="page-content max-w-lg w-full mx-auto py-8">
  30. <div className="my-4">
  31. <ButtonPrimary text="Sign In" action={doOpenLoginPopup} />
  32. </div>
  33. <div className="my-4">
  34. <ButtonPrimary text="Registration" action={doOpenRegistrationPopup} />
  35. </div>
  36. <div className="my-4">
  37. <ButtonPrimary text="Feedback" action={doOpenFeedbackPopup} />
  38. </div>
  39. <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. </p>
  40. <p>Delectus sequi, iste error dignissimos necessitatibus aliquam perspiciatis pariatur reprehenderit dolor maiores sed officiis modi, praesentium atque? Delectus amet optio tempora ipsam, molestiae unde quibusdam minus placeat dolorem exercitationem enim alias?</p>
  41. <p>Porro tempore natus minus ex voluptas, hic culpa iure vero quod laudantium quas enim pariatur ullam commodi! Totam deleniti nesciunt earum, nam modi aspernatur rem harum pariatur, voluptatibus, adipisci accusamus sequi perferendis corrupti explicabo excepturi commodi soluta necessitatibus! Officiis similique nemo architecto odit debitis cupiditate reprehenderit ex vel atque beatae blanditiis dolores sequi unde quisquam molestias, eum sit aut. Soluta hic provident autem eius a aliquid neque in, distinctio eveniet ullam sequi pariatur deleniti perferendis magni debitis minus quod!</p>
  42. <p>Facere ex error molestiae maxime ullam dolor blanditiis dolores fuga ipsam vero distinctio, ipsum delectus harum optio quo repudiandae unde beatae rerum laborum cumque, quisquam quia quod?</p>
  43. <p>Numquam praesentium ex recusandae quia tenetur, quod, illum officiis magni est alias consequatur maiores accusamus ipsam provident sequi dolores excepturi exercitationem vitae aspernatur perferendis porro sit accusantium aut? Tempora nesciunt, autem dignissimos sit ratione dolores odit amet laborum nihil corporis id nobis tempore! Quam rerum repudiandae expedita voluptate error dolorum a. Obcaecati fugiat magnam earum?</p>
  44. </div>
  45. </div>
  46. <Popup opened={popupOpened} title={popupTitle} close={close}>{popupContent}</Popup>
  47. </>
  48. )
  49. }
  50. export default App;