Initial commit.
This commit is contained in:
		
							parent
							
								
									f7ad8786d6
								
							
						
					
					
						commit
						813f44a428
					
				
					 6 changed files with 213 additions and 21 deletions
				
			
		
							
								
								
									
										93
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										93
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							|  | @ -5615,6 +5615,11 @@ | |||
|       "resolved": "https://registry.npmjs.org/growly/-/growly-1.3.0.tgz", | ||||
|       "integrity": "sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE=" | ||||
|     }, | ||||
|     "gud": { | ||||
|       "version": "1.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/gud/-/gud-1.0.0.tgz", | ||||
|       "integrity": "sha512-zGEOVKFM5sVPPrYs7J5/hYEw2Pof8KCyOwyhG8sAF26mCAeUFAcYPu1mwB7hhpIP29zOIBaDqwuHdLp0jvZXjw==" | ||||
|     }, | ||||
|     "gzip-size": { | ||||
|       "version": "5.1.1", | ||||
|       "resolved": "https://registry.npmjs.org/gzip-size/-/gzip-size-5.1.1.tgz", | ||||
|  | @ -5745,6 +5750,19 @@ | |||
|       "resolved": "https://registry.npmjs.org/hex-color-regex/-/hex-color-regex-1.1.0.tgz", | ||||
|       "integrity": "sha512-l9sfDFsuqtOqKDsQdqrMRk0U85RZc0RtOR9yPI7mRVOa4FsR/BVnZ0shmQRM96Ji99kYZP/7hn1cedc1+ApsTQ==" | ||||
|     }, | ||||
|     "history": { | ||||
|       "version": "4.10.1", | ||||
|       "resolved": "https://registry.npmjs.org/history/-/history-4.10.1.tgz", | ||||
|       "integrity": "sha512-36nwAD620w12kuzPAsyINPWJqlNbij+hpK1k9XRloDtym8mxzGYl2c17LnV6IAGB2Dmg4tEa7G7DlawS0+qjew==", | ||||
|       "requires": { | ||||
|         "@babel/runtime": "^7.1.2", | ||||
|         "loose-envify": "^1.2.0", | ||||
|         "resolve-pathname": "^3.0.0", | ||||
|         "tiny-invariant": "^1.0.2", | ||||
|         "tiny-warning": "^1.0.0", | ||||
|         "value-equal": "^1.0.1" | ||||
|       } | ||||
|     }, | ||||
|     "hmac-drbg": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", | ||||
|  | @ -5755,6 +5773,14 @@ | |||
|         "minimalistic-crypto-utils": "^1.0.1" | ||||
|       } | ||||
|     }, | ||||
|     "hoist-non-react-statics": { | ||||
|       "version": "3.3.2", | ||||
|       "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz", | ||||
|       "integrity": "sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==", | ||||
|       "requires": { | ||||
|         "react-is": "^16.7.0" | ||||
|       } | ||||
|     }, | ||||
|     "hosted-git-info": { | ||||
|       "version": "2.8.5", | ||||
|       "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.5.tgz", | ||||
|  | @ -8063,6 +8089,16 @@ | |||
|       "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.0.tgz", | ||||
|       "integrity": "sha1-z8RcN+nsDY8KDsPdTvf3w6vjklY=" | ||||
|     }, | ||||
|     "mini-create-react-context": { | ||||
|       "version": "0.3.2", | ||||
|       "resolved": "https://registry.npmjs.org/mini-create-react-context/-/mini-create-react-context-0.3.2.tgz", | ||||
|       "integrity": "sha512-2v+OeetEyliMt5VHMXsBhABoJ0/M4RCe7fatd/fBy6SMiKazUSEt3gxxypfnk2SHMkdBYvorHRoQxuGoiwbzAw==", | ||||
|       "requires": { | ||||
|         "@babel/runtime": "^7.4.0", | ||||
|         "gud": "^1.0.0", | ||||
|         "tiny-warning": "^1.0.2" | ||||
|       } | ||||
|     }, | ||||
|     "mini-css-extract-plugin": { | ||||
|       "version": "0.9.0", | ||||
|       "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.9.0.tgz", | ||||
|  | @ -10147,6 +10183,11 @@ | |||
|       "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", | ||||
|       "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" | ||||
|     }, | ||||
|     "purecss": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/purecss/-/purecss-1.0.1.tgz", | ||||
|       "integrity": "sha512-mTUc5ZzpzafswEhCmTDfSRMMyRFdLYdd+KywMwnBC/MuA/Th7jug2z0Xso4WkxvtxoU/BS9aRb7WnBNyuA7YJQ==" | ||||
|     }, | ||||
|     "q": { | ||||
|       "version": "1.5.1", | ||||
|       "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", | ||||
|  | @ -10439,6 +10480,38 @@ | |||
|       "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.12.0.tgz", | ||||
|       "integrity": "sha512-rPCkf/mWBtKc97aLL9/txD8DZdemK0vkA3JMLShjlJB3Pj3s+lpf1KaBzMfQrAmhMQB0n1cU/SUGgKKBCe837Q==" | ||||
|     }, | ||||
|     "react-router": { | ||||
|       "version": "5.1.2", | ||||
|       "resolved": "https://registry.npmjs.org/react-router/-/react-router-5.1.2.tgz", | ||||
|       "integrity": "sha512-yjEuMFy1ONK246B+rsa0cUam5OeAQ8pyclRDgpxuSCrAlJ1qN9uZ5IgyKC7gQg0w8OM50NXHEegPh/ks9YuR2A==", | ||||
|       "requires": { | ||||
|         "@babel/runtime": "^7.1.2", | ||||
|         "history": "^4.9.0", | ||||
|         "hoist-non-react-statics": "^3.1.0", | ||||
|         "loose-envify": "^1.3.1", | ||||
|         "mini-create-react-context": "^0.3.0", | ||||
|         "path-to-regexp": "^1.7.0", | ||||
|         "prop-types": "^15.6.2", | ||||
|         "react-is": "^16.6.0", | ||||
|         "tiny-invariant": "^1.0.2", | ||||
|         "tiny-warning": "^1.0.0" | ||||
|       }, | ||||
|       "dependencies": { | ||||
|         "isarray": { | ||||
|           "version": "0.0.1", | ||||
|           "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", | ||||
|           "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" | ||||
|         }, | ||||
|         "path-to-regexp": { | ||||
|           "version": "1.8.0", | ||||
|           "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-1.8.0.tgz", | ||||
|           "integrity": "sha512-n43JRhlUKUAlibEJhPeir1ncUID16QnEjNpwzNdO3Lm4ywrBpBZ5oLD0I6br9evr1Y9JTqwRtAh7JLoOzAQdVA==", | ||||
|           "requires": { | ||||
|             "isarray": "0.0.1" | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "react-scripts": { | ||||
|       "version": "3.3.1", | ||||
|       "resolved": "https://registry.npmjs.org/react-scripts/-/react-scripts-3.3.1.tgz", | ||||
|  | @ -10801,6 +10874,11 @@ | |||
|       "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", | ||||
|       "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=" | ||||
|     }, | ||||
|     "resolve-pathname": { | ||||
|       "version": "3.0.0", | ||||
|       "resolved": "https://registry.npmjs.org/resolve-pathname/-/resolve-pathname-3.0.0.tgz", | ||||
|       "integrity": "sha512-C7rARubxI8bXFNB/hqcp/4iUeIXJhJZvFPFPiSPRnhU5UPxzMFIl+2E6yY6c4k9giDJAhtV+enfA+G89N6Csng==" | ||||
|     }, | ||||
|     "resolve-url": { | ||||
|       "version": "0.2.1", | ||||
|       "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", | ||||
|  | @ -12173,6 +12251,16 @@ | |||
|       "resolved": "https://registry.npmjs.org/timsort/-/timsort-0.3.0.tgz", | ||||
|       "integrity": "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=" | ||||
|     }, | ||||
|     "tiny-invariant": { | ||||
|       "version": "1.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/tiny-invariant/-/tiny-invariant-1.1.0.tgz", | ||||
|       "integrity": "sha512-ytxQvrb1cPc9WBEI/HSeYYoGD0kWnGEOR8RY6KomWLBVhqz0RgTwVO9dLrGz7dC+nN9llyI7OKAgRq8Vq4ZBSw==" | ||||
|     }, | ||||
|     "tiny-warning": { | ||||
|       "version": "1.0.3", | ||||
|       "resolved": "https://registry.npmjs.org/tiny-warning/-/tiny-warning-1.0.3.tgz", | ||||
|       "integrity": "sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA==" | ||||
|     }, | ||||
|     "tmp": { | ||||
|       "version": "0.0.33", | ||||
|       "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", | ||||
|  | @ -12549,6 +12637,11 @@ | |||
|         "spdx-expression-parse": "^3.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "value-equal": { | ||||
|       "version": "1.0.1", | ||||
|       "resolved": "https://registry.npmjs.org/value-equal/-/value-equal-1.0.1.tgz", | ||||
|       "integrity": "sha512-NOJ6JZCAWr0zlxZt+xqCHNTEKOsrks2HQd4MqhP1qy4z1SkbEP467eNx6TgDKXMvUOb+OENfJCZwM+16n7fRfw==" | ||||
|     }, | ||||
|     "vary": { | ||||
|       "version": "1.1.2", | ||||
|       "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", | ||||
|  |  | |||
|  | @ -6,8 +6,10 @@ | |||
|     "@testing-library/jest-dom": "^4.2.4", | ||||
|     "@testing-library/react": "^9.4.0", | ||||
|     "@testing-library/user-event": "^7.2.1", | ||||
|     "purecss": "^1.0.1", | ||||
|     "react": "^16.12.0", | ||||
|     "react-dom": "^16.12.0", | ||||
|     "react-router": "^5.1.2", | ||||
|     "react-scripts": "3.3.1" | ||||
|   }, | ||||
|   "scripts": { | ||||
|  |  | |||
|  | @ -24,6 +24,7 @@ | |||
|       work correctly both with client-side routing and a non-root public URL. | ||||
|       Learn how to configure a non-root public URL by running `npm run build`. | ||||
|     --> | ||||
|     <link rel="stylesheet" href="https://unpkg.com/purecss@1.0.1/build/pure-min.css" integrity="sha384-oAOxQR6DkCoMliIh8yFnu25d7Eq/PHS21PClpwjOTeU2jRSq11vu66rf90/cZr47" crossorigin="anonymous" /> | ||||
|     <title>React App</title> | ||||
|   </head> | ||||
|   <body> | ||||
|  |  | |||
							
								
								
									
										44
									
								
								src/App.css
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								src/App.css
									
									
									
									
									
								
							|  | @ -1,5 +1,6 @@ | |||
| .App { | ||||
|   text-align: center; | ||||
|   animation: fadein 2s; | ||||
| } | ||||
| 
 | ||||
| .App-logo { | ||||
|  | @ -9,30 +10,55 @@ | |||
| 
 | ||||
| @media (prefers-reduced-motion: no-preference) { | ||||
|   .App-logo { | ||||
|     animation: App-logo-spin infinite 20s linear; | ||||
|     animation: App-logo-grow-shrink infinite 2s cubic-bezier(1, 0, 0, 1); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .App-header { | ||||
|   background-color: #282c34; | ||||
|   background-color: rgb(255, 149, 172); | ||||
|   min-height: 100vh; | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   align-items: center; | ||||
|   justify-content: center; | ||||
|   font-size: calc(10px + 2vmin); | ||||
|   color: #242424; | ||||
| } | ||||
| 
 | ||||
| .App-statement { | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| .App-link { | ||||
|   color: #61dafb; | ||||
| .App-button { | ||||
|   background-color: rgb(3, 102, 216); | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| @keyframes App-logo-spin { | ||||
|   from { | ||||
|     transform: rotate(0deg); | ||||
| .Poem-statement { | ||||
|   color: white; | ||||
|   animation: fadein 2s; | ||||
| } | ||||
| 
 | ||||
| @keyframes App-logo-grow-shrink { | ||||
|   0% { | ||||
|     transform: scale(0.5); | ||||
|   } | ||||
|   to { | ||||
|     transform: rotate(360deg); | ||||
|   40% { | ||||
|     transform: scale(1.2); | ||||
|   } | ||||
|   60% { | ||||
|     transform: scale(1.2); | ||||
|   } | ||||
|   100% { | ||||
|     transform: scale(0.5); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| @keyframes fadein { | ||||
|   from { | ||||
|     opacity: 0; | ||||
|   } | ||||
|   to { | ||||
|     opacity: 1; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										94
									
								
								src/App.js
									
									
									
									
									
								
							
							
						
						
									
										94
									
								
								src/App.js
									
									
									
									
									
								
							|  | @ -1,23 +1,93 @@ | |||
| import React from 'react'; | ||||
| import logo from './logo.svg'; | ||||
| import './App.css'; | ||||
| import React, { useState } from "react"; | ||||
| import logo from "./heart-icon.png"; | ||||
| import "./App.css"; | ||||
| 
 | ||||
| function MakePoem() { | ||||
|   return ( | ||||
|     <div className="App Poem-statement"> | ||||
|       <div className="pure-g"> | ||||
|         <div className="pure-u-1-5" /> | ||||
|         <p className="pure-u-3-5"> | ||||
|           <code> | ||||
|             You are important. I wrote a small poem I hope will help you today.<br></br> | ||||
|             It's not very long, but I'm doing my best, and so are you. | ||||
|           </code> | ||||
|         </p> | ||||
|       </div> | ||||
|       <div className="pure-g"> | ||||
|         <div className="pure-u-1-5" /> | ||||
|         <p className="pure-u-3-5"> | ||||
|           <code> | ||||
|             You are the moon, you are the stars<br></br> | ||||
|             I'm glad you're here, whomever you are. | ||||
|           </code> | ||||
|         </p> | ||||
|       </div> | ||||
|       <div className="pure-g"> | ||||
|         <div className="pure-u-1-5" /> | ||||
|         <p className="pure-u-3-5"> | ||||
|           <code> | ||||
|             We've been through much; in this life it's true,<br></br> | ||||
|             But in the end, you will come through. | ||||
|           </code> | ||||
|         </p> | ||||
|         <div className="pure-u-1-5" /> | ||||
|       </div> | ||||
|       <div className="pure-g"> | ||||
|         <div className="pure-u-1-5" /> | ||||
|         <p className="pure-u-3-5"> | ||||
|           <code> | ||||
|             Much like life, this poem is short<br></br> | ||||
|             It doesn't always rhyme, or have a nice beat;<br></br> | ||||
|             It might seem wrong, or incomplete;<br></br> | ||||
|             It might go on, or so it seems;<br></br> | ||||
|             It might feel like you're in a dream. | ||||
|           </code> | ||||
|         </p> | ||||
|         <div className="pure-u-1-5" /> | ||||
|       </div> | ||||
|       <div className="pure-g"> | ||||
|         <div className="pure-u-1-5" /> | ||||
|         <p className="pure-u-3-5"> | ||||
|           <code> | ||||
|             That's not the point, I know in my heart<br></br> | ||||
|             I'm glad you're here, whomever you are. | ||||
|           </code> | ||||
|         </p> | ||||
|         <div className="pure-u-1-5" /> | ||||
|       </div> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| function App() { | ||||
|   let [isPoemShown, showPoem] = useState(false); | ||||
|   let [buttonTextString, changeButtonText] = useState("Tell me more"); | ||||
|   const activatePoem = () => { | ||||
|     showPoem(!isPoemShown); | ||||
|     if (isPoemShown) { | ||||
|       changeButtonText("Tell me more"); | ||||
|     } else { | ||||
|       changeButtonText("Tell me less"); | ||||
|     } | ||||
|   }; | ||||
| 
 | ||||
|   return ( | ||||
|     <div className="App"> | ||||
|       <header className="App-header"> | ||||
|         <img src={logo} className="App-logo" alt="logo" /> | ||||
|         <img src={logo} className="App-logo pure-img" alt="logo" /> | ||||
|         <p> | ||||
|           Edit <code>src/App.js</code> and save to reload. | ||||
|           <code className="App-statement">You are important and loved</code> | ||||
|         </p> | ||||
|         <a | ||||
|           className="App-link" | ||||
|           href="https://reactjs.org" | ||||
|           target="_blank" | ||||
|           rel="noopener noreferrer" | ||||
|         <button | ||||
|           className="App-button pure-button" | ||||
|           autoFocus | ||||
|           name="Tell me more" | ||||
|           onClick={() => activatePoem()} | ||||
|         > | ||||
|           Learn React | ||||
|         </a> | ||||
|           {buttonTextString} | ||||
|         </button> | ||||
|         {isPoemShown && <MakePoem />} | ||||
|       </header> | ||||
|     </div> | ||||
|   ); | ||||
|  |  | |||
							
								
								
									
										
											BIN
										
									
								
								src/heart-icon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/heart-icon.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 24 KiB | 
		Reference in a new issue
	
	 Alexis Werefox
						Alexis Werefox