This is just a technology testing project based on Create React App and TailwindCSS
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

57 行
4.8KB

  1. import React, { useState } from 'react'
  2. import ButtonPrimary from './components/controls/ButtonPrimary'
  3. import Popup from './Popup';
  4. import { FormLogin } from './components/forms/FormLogin'
  5. import { FormRegistration } from './components/forms/FormRegistration';
  6. const App = () => {
  7. const [popupTitle, setPopupTitle] = useState('')
  8. const [popupContent, setPopupContent] = useState(<></>)
  9. const [popupBack, setPopupBack] = useState(null)
  10. const [popupOpened, setPopupOpened] = useState(false)
  11. const close = () => {
  12. if (popupBack) {
  13. setPopupOpened(false)
  14. setTimeout(() => {
  15. setPopupContent(popupBack)
  16. setPopupOpened(true)
  17. }, 200)
  18. } else {
  19. setPopupOpened(false)
  20. }
  21. }
  22. const doOpenLoginPopup = () => {
  23. setPopupContent(<FormLogin setPopupTitle={setPopupTitle} setPopupContent={setPopupContent} setPopupOpened={setPopupOpened} setPopupBack={setPopupBack} close={close} />)
  24. setPopupOpened(true)
  25. }
  26. const doOpenRegistrationPopup = () => {
  27. setPopupContent(<FormRegistration setPopupTitle={setPopupTitle} setPopupContent={setPopupContent} setPopupOpened={setPopupOpened} setPopupBack={setPopupBack} close={close} />)
  28. setPopupOpened(true)
  29. }
  30. return (
  31. <>
  32. <div className="w-full h-full min-h-screen bg-white text-gray-900 text-lg flex items-center">
  33. <div className="max-w-lg w-full mx-auto py-8">
  34. <div className="my-4">
  35. <ButtonPrimary text="Login" action={doOpenLoginPopup} />
  36. </div>
  37. <div className="my-4">
  38. <ButtonPrimary text="Registration" action={doOpenRegistrationPopup} />
  39. </div>
  40. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Blanditiis voluptates necessitatibus impedit laudantium, ea quam voluptatibus unde nulla voluptas neque suscipit temporibus ipsam ducimus eum inventore libero, ullam soluta minima adipisci omnis! Deleniti alias perspiciatis et? Accusamus aliquam eveniet voluptas vitae tenetur quas quae maxime necessitatibus mollitia molestias, commodi sunt quibusdam, cum, vero qui exercitationem iste beatae eaque dicta odit deleniti dolorem! Eius itaque quasi quibusdam tempora fugit laboriosam magni quod vel voluptas, officiis culpa numquam, molestias tempore. Sapiente exercitationem doloremque velit dolores excepturi asperiores, cumque minus earum enim voluptatibus quod veritatis non tempora nemo quo officiis expedita eveniet ratione atque! Illo ab accusamus vero, quas quisquam soluta. Voluptatum repudiandae asperiores laboriosam blanditiis dolorum quo, minus porro consequuntur eius nihil illum quaerat quod, laudantium omnis temporibus inventore voluptate, explicabo libero numquam beatae saepe? Repudiandae perferendis nostrum sit nam ad eaque expedita doloribus? Deserunt perspiciatis quo nulla dolor voluptatum temporibus, beatae iusto veritatis laboriosam reiciendis cupiditate ab quisquam. Distinctio neque, voluptate enim, aliquam dignissimos inventore perspiciatis tempore, quae officia quis minima necessitatibus at repellendus. Animi corrupti at modi quas et ipsam asperiores a ducimus consequuntur necessitatibus! Tempore, quisquam? Magnam harum ducimus cupiditate aspernatur, sit veritatis ipsa ratione maxime similique fuga corporis consequuntur obcaecati quas provident ut! Dignissimos labore qui amet in, accusantium minus suscipit numquam saepe nulla hic vero molestias mollitia autem, magni rem illo fugit doloremque est consectetur? Iure laborum nesciunt possimus quod animi temporibus perspiciatis modi aspernatur alias, maxime, sint dolores. Ab quaerat beatae dolorem itaque ex, similique dolore consectetur voluptatibus tenetur maiores eaque tempore quos ullam facilis illo nisi ipsum veniam maxime pariatur sint iste? Modi voluptas molestias inventore omnis repellendus? Veniam alias rerum voluptatum aut possimus labore, iste neque recusandae eveniet aspernatur dolor mollitia accusantium repudiandae molestias magni odit illum dolorem iure nesciunt cumque commodi voluptatibus sed nobis! Labore sint optio voluptatum, harum minima ad cum dolorem inventore sed qui eligendi asperiores nihil, quisquam veniam unde quaerat eveniet ipsam reprehenderit. Molestias sequi sapiente, aperiam iusto nostrum obcaecati accusamus tenetur eum excepturi cupiditate voluptatem dolor consequuntur, modi nesciunt quibusdam nam quae, illo sed animi debitis praesentium deserunt! Obcaecati, repellendus odit. Commodi, omnis cupiditate qui atque debitis repellendus eius ipsam deserunt cum pariatur, ut illum nisi aspernatur exercitationem odit consectetur aliquam nam dignissimos minus non. Nam possimus totam doloremque ipsam architecto enim corrupti officia iste debitis ab nemo, exercitationem facere laborum optio magni earum, temporibus, impedit ipsa perferendis! Ex!</p>
  41. </div>
  42. </div>
  43. <Popup opened={popupOpened} title={popupTitle} close={close}>{popupContent}</Popup>
  44. </>
  45. )
  46. }
  47. export default App;