Add basic datatypes and first form implementation
This commit is contained in:
		
							parent
							
								
									6be3f2e94c
								
							
						
					
					
						commit
						a3710d4b9b
					
				| @ -4,13 +4,17 @@ | ||||
|   "private": true, | ||||
|   "dependencies": { | ||||
|     "@material-ui/core": "^4.10.1", | ||||
|     "@material-ui/lab": "^4.0.0-alpha.55", | ||||
|     "@testing-library/jest-dom": "^4.2.4", | ||||
|     "@testing-library/react": "^9.3.2", | ||||
|     "@testing-library/user-event": "^7.1.2", | ||||
|     "@types/jest": "^24.0.0", | ||||
|     "@types/moment": "^2.13.0", | ||||
|     "@types/node": "^12.0.0", | ||||
|     "@types/react": "^16.9.0", | ||||
|     "@types/react-dom": "^16.9.0", | ||||
|     "formik": "^2.1.4", | ||||
|     "moment": "^2.26.0", | ||||
|     "react": "^16.13.1", | ||||
|     "react-dom": "^16.13.1", | ||||
|     "react-scripts": "3.4.1", | ||||
|  | ||||
							
								
								
									
										38
									
								
								src/App.css
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								src/App.css
									
									
									
									
									
								
							| @ -1,38 +0,0 @@ | ||||
| .App { | ||||
|   text-align: center; | ||||
| } | ||||
| 
 | ||||
| .App-logo { | ||||
|   height: 40vmin; | ||||
|   pointer-events: none; | ||||
| } | ||||
| 
 | ||||
| @media (prefers-reduced-motion: no-preference) { | ||||
|   .App-logo { | ||||
|     animation: App-logo-spin infinite 20s linear; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .App-header { | ||||
|   background-color: #282c34; | ||||
|   min-height: 100vh; | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   align-items: center; | ||||
|   justify-content: center; | ||||
|   font-size: calc(10px + 2vmin); | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| .App-link { | ||||
|   color: #61dafb; | ||||
| } | ||||
| 
 | ||||
| @keyframes App-logo-spin { | ||||
|   from { | ||||
|     transform: rotate(0deg); | ||||
|   } | ||||
|   to { | ||||
|     transform: rotate(360deg); | ||||
|   } | ||||
| } | ||||
| @ -1,9 +0,0 @@ | ||||
| import React from 'react'; | ||||
| import { render } from '@testing-library/react'; | ||||
| import App from './App'; | ||||
| 
 | ||||
| test('renders learn react link', () => { | ||||
|   const { getByText } = render(<App />); | ||||
|   const linkElement = getByText(/learn react/i); | ||||
|   expect(linkElement).toBeInTheDocument(); | ||||
| }); | ||||
							
								
								
									
										23
									
								
								src/App.tsx
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								src/App.tsx
									
									
									
									
									
								
							| @ -1,24 +1,13 @@ | ||||
| import React from 'react'; | ||||
| import logo from './logo.svg'; | ||||
| import './App.css'; | ||||
| import { Container } from "@material-ui/core"; | ||||
| import { CompanyForm } from "./forms/company"; | ||||
| 
 | ||||
| function App() { | ||||
|   return ( | ||||
|     <div className="App"> | ||||
|       <header className="App-header"> | ||||
|         <img src={logo} className="App-logo" alt="logo" /> | ||||
|         <p> | ||||
|           Edit <code>src/App.tsx</code> and save to reload. | ||||
|         </p> | ||||
|         <a | ||||
|           className="App-link" | ||||
|           href="https://reactjs.org" | ||||
|           target="_blank" | ||||
|           rel="noopener noreferrer" | ||||
|         > | ||||
|           Learn React - System Praktyk | ||||
|         </a> | ||||
|       </header> | ||||
|     <div className="app"> | ||||
|         <Container> | ||||
|             <CompanyForm /> | ||||
|         </Container> | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
|  | ||||
							
								
								
									
										27
									
								
								src/data/company.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								src/data/company.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | ||||
| export interface Address { | ||||
|     street: string; | ||||
|     building: string; | ||||
|     city: string; | ||||
|     postalCode: string; | ||||
|     country: string; | ||||
| } | ||||
| 
 | ||||
| export interface Company { | ||||
|     name: string; | ||||
|     url?: string; | ||||
|     nip: string; | ||||
|     offices: BranchOffice[]; | ||||
| } | ||||
| 
 | ||||
| export interface BranchOffice { | ||||
|     address: Address; | ||||
| } | ||||
| 
 | ||||
| export const emptyCompany: Company = { | ||||
|     offices: [], | ||||
|     url: "", | ||||
|     name: "", | ||||
|     nip: "", | ||||
| } | ||||
| 
 | ||||
| export const formatAddress = ({ postalCode, building, street, city, country }: Address): string => `${street} ${building}, ${postalCode} ${city}, ${country}` | ||||
							
								
								
									
										23
									
								
								src/data/internship.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								src/data/internship.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| import { Moment } from "moment"; | ||||
| import { Nullable } from "../helpers"; | ||||
| 
 | ||||
| export enum InternshipType { } | ||||
| export enum InternshipProgram { } | ||||
| 
 | ||||
| export interface Internship { | ||||
|     type: InternshipType; | ||||
|     program: InternshipProgram; | ||||
|     startDate: Moment; | ||||
|     endDate: Moment; | ||||
|     isAccepted: boolean; | ||||
|     lengthInWeeks: number; | ||||
| } | ||||
| 
 | ||||
| export const emptyInternship: Nullable<Internship> = { | ||||
|     endDate: null, | ||||
|     startDate: null, | ||||
|     type: null, | ||||
|     program: null, | ||||
|     isAccepted: false, | ||||
|     lengthInWeeks: 0, | ||||
| } | ||||
							
								
								
									
										22
									
								
								src/forms/Internship.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/forms/Internship.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| import React from "react"; | ||||
| import { useFormik } from "formik"; | ||||
| import { emptyInternship, Internship } from "../data/internship"; | ||||
| import { Nullable } from "../helpers"; | ||||
| import { TextField } from "@material-ui/core"; | ||||
| 
 | ||||
| export type InternshipFormProps = { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| export const InternshipForm: React.FunctionComponent<InternshipFormProps> = props => { | ||||
|     const formik = useFormik<Nullable<Internship>>({ onSubmit: values => console.log(values), initialValues: emptyInternship }); | ||||
| 
 | ||||
|     const formikProps = (prop: keyof Internship) => ({ onChange: formik.handleChange, value: formik.values[prop], name: prop }) | ||||
| 
 | ||||
|     return ( | ||||
|         <div className="internship-form"> | ||||
|             <TextField {...formikProps("startDate")} /> | ||||
|         </div> | ||||
|     ) | ||||
| } | ||||
| 
 | ||||
							
								
								
									
										69
									
								
								src/forms/company.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/forms/company.tsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,69 @@ | ||||
| import React, { HTMLProps, useState } from "react"; | ||||
| import { useFormik } from "formik"; | ||||
| import { Nullable } from "../helpers"; | ||||
| import { formatAddress, Company, emptyCompany, BranchOffice } from "../data/company"; | ||||
| import { sampleCompanies } from "../provider/company"; | ||||
| import { Autocomplete } from "@material-ui/lab"; | ||||
| import { Box, Grid, TextField, Typography } from "@material-ui/core"; | ||||
| 
 | ||||
| export type CompanyFormProps = { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| export const CompanyItem = ({ company, ...props }: { company: Company } & HTMLProps<any>) => ( | ||||
|     <div className="company-item" {...props}> | ||||
|         <div>{ company.name }</div> | ||||
|         <Typography variant="caption">NIP: <strong>{ company.nip }</strong></Typography> | ||||
|     </div> | ||||
| ) | ||||
| 
 | ||||
| export const OfficeItem = ({ office, ...props }: { office: BranchOffice } & HTMLProps<any>) => ( | ||||
|     <div className="office-item" {...props}> | ||||
|         <div>{ office.address.city }, { office.address.street }</div> | ||||
|         <Typography variant="caption">{ formatAddress(office.address) }</Typography> | ||||
|     </div> | ||||
| ) | ||||
| 
 | ||||
| export const CompanyForm: React.FunctionComponent<CompanyFormProps> = props => { | ||||
|     const formik = useFormik<Nullable<Company>>({ onSubmit: values => console.log(values), initialValues: emptyCompany }); | ||||
| 
 | ||||
|     const formikProps = (prop: keyof Company) => ({ onChange: formik.handleChange, value: formik.values[prop], name: prop }) | ||||
| 
 | ||||
|     const [company, setCompany] = useState<Company | null>(null); | ||||
| 
 | ||||
|     return ( | ||||
|         <Grid container spacing={3}> | ||||
|             <Grid item xs={12}> | ||||
|                 <Autocomplete options={ sampleCompanies } | ||||
|                               getOptionLabel={ option => option.name } | ||||
|                               renderOption={ company => <CompanyItem company={company} /> } | ||||
|                               renderInput={ props => <TextField {...props} label={"Nazwa firmy"} fullWidth />} | ||||
|                               onChange={ (ev, value: Company | null) => { | ||||
|                                   setCompany(value) | ||||
| 
 | ||||
|                                   formik.setFieldValue("name", value?.name || "") | ||||
|                                   formik.setFieldValue("url", value?.url || ""); | ||||
|                                   formik.setFieldValue("nip", value?.nip || ""); | ||||
|                               } } | ||||
|                 /> | ||||
|             </Grid> | ||||
|             <Grid container item spacing={2} xs={12}> | ||||
|                 <Grid item xs={4}> | ||||
|                     <TextField label={"NIP"} fullWidth {...formikProps("nip")} disabled={ company != null}/> | ||||
|                 </Grid> | ||||
|                 <Grid item xs={8}> | ||||
|                     <TextField label={"Url"} fullWidth {...formikProps("url")} disabled={ company != null }/> | ||||
|                 </Grid> | ||||
|             </Grid> | ||||
|             <Grid item xs={12}> | ||||
|                 <Autocomplete options={ company?.offices || [] } | ||||
|                               disabled={ company == null} | ||||
|                               getOptionLabel={ office => office.address.city } | ||||
|                               renderOption={ office => <OfficeItem office={ office } /> } | ||||
|                               renderInput={ props => <TextField {...props} label={"Oddział"} fullWidth />} | ||||
|                 /> | ||||
|             </Grid> | ||||
|         </Grid> | ||||
|     ) | ||||
| } | ||||
| 
 | ||||
							
								
								
									
										1
									
								
								src/helpers.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								src/helpers.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| export type Nullable<T> = { [P in keyof T]: T[P] | null } | ||||
| @ -1,13 +0,0 @@ | ||||
| body { | ||||
|   margin: 0; | ||||
|   font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', | ||||
|     'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', | ||||
|     sans-serif; | ||||
|   -webkit-font-smoothing: antialiased; | ||||
|   -moz-osx-font-smoothing: grayscale; | ||||
| } | ||||
| 
 | ||||
| code { | ||||
|   font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New', | ||||
|     monospace; | ||||
| } | ||||
| @ -1,6 +1,5 @@ | ||||
| import React from 'react'; | ||||
| import ReactDOM from 'react-dom'; | ||||
| import './index.css'; | ||||
| import App from './App'; | ||||
| import * as serviceWorker from './serviceWorker'; | ||||
| 
 | ||||
|  | ||||
| @ -1,7 +0,0 @@ | ||||
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 841.9 595.3"> | ||||
|     <g fill="#61DAFB"> | ||||
|         <path d="M666.3 296.5c0-32.5-40.7-63.3-103.1-82.4 14.4-63.6 8-114.2-20.2-130.4-6.5-3.8-14.1-5.6-22.4-5.6v22.3c4.6 0 8.3.9 11.4 2.6 13.6 7.8 19.5 37.5 14.9 75.7-1.1 9.4-2.9 19.3-5.1 29.4-19.6-4.8-41-8.5-63.5-10.9-13.5-18.5-27.5-35.3-41.6-50 32.6-30.3 63.2-46.9 84-46.9V78c-27.5 0-63.5 19.6-99.9 53.6-36.4-33.8-72.4-53.2-99.9-53.2v22.3c20.7 0 51.4 16.5 84 46.6-14 14.7-28 31.4-41.3 49.9-22.6 2.4-44 6.1-63.6 11-2.3-10-4-19.7-5.2-29-4.7-38.2 1.1-67.9 14.6-75.8 3-1.8 6.9-2.6 11.5-2.6V78.5c-8.4 0-16 1.8-22.6 5.6-28.1 16.2-34.4 66.7-19.9 130.1-62.2 19.2-102.7 49.9-102.7 82.3 0 32.5 40.7 63.3 103.1 82.4-14.4 63.6-8 114.2 20.2 130.4 6.5 3.8 14.1 5.6 22.5 5.6 27.5 0 63.5-19.6 99.9-53.6 36.4 33.8 72.4 53.2 99.9 53.2 8.4 0 16-1.8 22.6-5.6 28.1-16.2 34.4-66.7 19.9-130.1 62-19.1 102.5-49.9 102.5-82.3zm-130.2-66.7c-3.7 12.9-8.3 26.2-13.5 39.5-4.1-8-8.4-16-13.1-24-4.6-8-9.5-15.8-14.4-23.4 14.2 2.1 27.9 4.7 41 7.9zm-45.8 106.5c-7.8 13.5-15.8 26.3-24.1 38.2-14.9 1.3-30 2-45.2 2-15.1 0-30.2-.7-45-1.9-8.3-11.9-16.4-24.6-24.2-38-7.6-13.1-14.5-26.4-20.8-39.8 6.2-13.4 13.2-26.8 20.7-39.9 7.8-13.5 15.8-26.3 24.1-38.2 14.9-1.3 30-2 45.2-2 15.1 0 30.2.7 45 1.9 8.3 11.9 16.4 24.6 24.2 38 7.6 13.1 14.5 26.4 20.8 39.8-6.3 13.4-13.2 26.8-20.7 39.9zm32.3-13c5.4 13.4 10 26.8 13.8 39.8-13.1 3.2-26.9 5.9-41.2 8 4.9-7.7 9.8-15.6 14.4-23.7 4.6-8 8.9-16.1 13-24.1zM421.2 430c-9.3-9.6-18.6-20.3-27.8-32 9 .4 18.2.7 27.5.7 9.4 0 18.7-.2 27.8-.7-9 11.7-18.3 22.4-27.5 32zm-74.4-58.9c-14.2-2.1-27.9-4.7-41-7.9 3.7-12.9 8.3-26.2 13.5-39.5 4.1 8 8.4 16 13.1 24 4.7 8 9.5 15.8 14.4 23.4zM420.7 163c9.3 9.6 18.6 20.3 27.8 32-9-.4-18.2-.7-27.5-.7-9.4 0-18.7.2-27.8.7 9-11.7 18.3-22.4 27.5-32zm-74 58.9c-4.9 7.7-9.8 15.6-14.4 23.7-4.6 8-8.9 16-13 24-5.4-13.4-10-26.8-13.8-39.8 13.1-3.1 26.9-5.8 41.2-7.9zm-90.5 125.2c-35.4-15.1-58.3-34.9-58.3-50.6 0-15.7 22.9-35.6 58.3-50.6 8.6-3.7 18-7 27.7-10.1 5.7 19.6 13.2 40 22.5 60.9-9.2 20.8-16.6 41.1-22.2 60.6-9.9-3.1-19.3-6.5-28-10.2zM310 490c-13.6-7.8-19.5-37.5-14.9-75.7 1.1-9.4 2.9-19.3 5.1-29.4 19.6 4.8 41 8.5 63.5 10.9 13.5 18.5 27.5 35.3 41.6 50-32.6 30.3-63.2 46.9-84 46.9-4.5-.1-8.3-1-11.3-2.7zm237.2-76.2c4.7 38.2-1.1 67.9-14.6 75.8-3 1.8-6.9 2.6-11.5 2.6-20.7 0-51.4-16.5-84-46.6 14-14.7 28-31.4 41.3-49.9 22.6-2.4 44-6.1 63.6-11 2.3 10.1 4.1 19.8 5.2 29.1zm38.5-66.7c-8.6 3.7-18 7-27.7 10.1-5.7-19.6-13.2-40-22.5-60.9 9.2-20.8 16.6-41.1 22.2-60.6 9.9 3.1 19.3 6.5 28.1 10.2 35.4 15.1 58.3 34.9 58.3 50.6-.1 15.7-23 35.6-58.4 50.6zM320.8 78.4z"/> | ||||
|         <circle cx="420.9" cy="296.5" r="45.7"/> | ||||
|         <path d="M520.5 78.1z"/> | ||||
|     </g> | ||||
| </svg> | ||||
| Before Width: | Height: | Size: 2.6 KiB | 
							
								
								
									
										62
									
								
								src/provider/company.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								src/provider/company.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,62 @@ | ||||
| import { Company } from "../data/company"; | ||||
| 
 | ||||
| export const sampleCompanies: Company[] = [ | ||||
|     { | ||||
|         name: "Intel", | ||||
|         url: "https://www.intel.com/content/www/us/en/jobs/locations/poland.html", | ||||
|         nip: "9570752316", | ||||
|         offices: [{ | ||||
|             address: { | ||||
|                 city: "Gdańsk", | ||||
|                 street: "ul. Słowackiego", | ||||
|                 building: "173", | ||||
|                 postalCode: "80-298", | ||||
|                 country: "Poland" | ||||
|             } | ||||
|         }] | ||||
|     }, | ||||
|     { | ||||
|         name: "IHS Markit", | ||||
|         url: "http://ihsgdansk.com/", | ||||
|         nip: "5842068320", | ||||
|         offices: [{ | ||||
|             address: { | ||||
|                 city: "Gdańsk", | ||||
|                 street: "ul. Marynarki Polskiej", | ||||
|                 building: "163", | ||||
|                 postalCode: "80-868", | ||||
|                 country: "Poland" | ||||
|             } | ||||
|         }] | ||||
|     }, | ||||
|     { | ||||
|         name: "Asseco Poland", | ||||
|         url: "http://pl.asseco.com/", | ||||
|         nip: "5842068320", | ||||
|         offices: [{ | ||||
|             address: { | ||||
|                 city: "Gdynia", | ||||
|                 street: "ul. Podolska", | ||||
|                 building: "21", | ||||
|                 postalCode: "81-321", | ||||
|                 country: "Poland" | ||||
|             } | ||||
|         }, { | ||||
|             address: { | ||||
|                 city: "Łódź", | ||||
|                 street: "al. Marszałka Józefa Piłsudskiego", | ||||
|                 building: "85", | ||||
|                 postalCode: "90-332", | ||||
|                 country: "Poland" | ||||
|             } | ||||
|         }, { | ||||
|             address: { | ||||
|                 city: "Wrocław", | ||||
|                 street: "Traugutta", | ||||
|                 building: "1/7", | ||||
|                 postalCode: "50-449", | ||||
|                 country: "Poland" | ||||
|             } | ||||
|         }] | ||||
|     } | ||||
| ] | ||||
| @ -1,5 +0,0 @@ | ||||
| // jest-dom adds custom jest matchers for asserting on DOM nodes.
 | ||||
| // allows you to do things like:
 | ||||
| // expect(element).toHaveTextContent(/react/i)
 | ||||
| // learn more: https://github.com/testing-library/jest-dom
 | ||||
| import '@testing-library/jest-dom/extend-expect'; | ||||
							
								
								
									
										62
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								yarn.lock
									
									
									
									
									
								
							| @ -1309,6 +1309,17 @@ | ||||
|     react-is "^16.8.0" | ||||
|     react-transition-group "^4.4.0" | ||||
| 
 | ||||
| "@material-ui/lab@^4.0.0-alpha.55": | ||||
|   version "4.0.0-alpha.55" | ||||
|   resolved "https://registry.yarnpkg.com/@material-ui/lab/-/lab-4.0.0-alpha.55.tgz#82a850dc59654e04ee3a31be1b34eb3bf64d5585" | ||||
|   integrity sha512-mPHiS52Z1AT6NlWNp07xxTkoKGU3DZhoGdVtLKGy2+uMH5t4/UPtiZLRab7hR3hvuHvguxgV4tkBC9ww3xqUzA== | ||||
|   dependencies: | ||||
|     "@babel/runtime" "^7.4.4" | ||||
|     "@material-ui/utils" "^4.9.6" | ||||
|     clsx "^1.0.4" | ||||
|     prop-types "^15.7.2" | ||||
|     react-is "^16.8.0" | ||||
| 
 | ||||
| "@material-ui/styles@^4.10.0": | ||||
|   version "4.10.0" | ||||
|   resolved "https://registry.yarnpkg.com/@material-ui/styles/-/styles-4.10.0.tgz#2406dc23aa358217aa8cc772e6237bd7f0544071" | ||||
| @ -1612,6 +1623,13 @@ | ||||
|   resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.3.tgz#3dca0e3f33b200fc7d1139c0cd96c1268cadfd9d" | ||||
|   integrity sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA== | ||||
| 
 | ||||
| "@types/moment@^2.13.0": | ||||
|   version "2.13.0" | ||||
|   resolved "https://registry.yarnpkg.com/@types/moment/-/moment-2.13.0.tgz#604ebd189bc3bc34a1548689404e61a2a4aac896" | ||||
|   integrity sha1-YE69GJvDvDShVIaJQE5hoqSqyJY= | ||||
|   dependencies: | ||||
|     moment "*" | ||||
| 
 | ||||
| "@types/node@*": | ||||
|   version "13.9.2" | ||||
|   resolved "https://registry.yarnpkg.com/@types/node/-/node-13.9.2.tgz#ace1880c03594cc3e80206d96847157d8e7fa349" | ||||
| @ -3654,6 +3672,11 @@ deep-is@~0.1.3: | ||||
|   resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" | ||||
|   integrity sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ= | ||||
| 
 | ||||
| deepmerge@^2.1.1: | ||||
|   version "2.2.1" | ||||
|   resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-2.2.1.tgz#5d3ff22a01c00f645405a2fbc17d0778a1801170" | ||||
|   integrity sha512-R9hc1Xa/NOBi9WRVUWg19rl1UB7Tt4kuPd+thNJgFZoxXsTz7ncaPaeIm+40oSGuP33DfMb4sZt1QIGiJzC4EA== | ||||
| 
 | ||||
| default-gateway@^4.2.0: | ||||
|   version "4.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/default-gateway/-/default-gateway-4.2.0.tgz#167104c7500c2115f6dd69b0a536bb8ed720552b" | ||||
| @ -4728,6 +4751,20 @@ form-data@~2.3.2: | ||||
|     combined-stream "^1.0.6" | ||||
|     mime-types "^2.1.12" | ||||
| 
 | ||||
| formik@^2.1.4: | ||||
|   version "2.1.4" | ||||
|   resolved "https://registry.yarnpkg.com/formik/-/formik-2.1.4.tgz#8deef07ec845ea98f75e03da4aad7aab4ac46570" | ||||
|   integrity sha512-oKz8S+yQBzuQVSEoxkqqJrKQS5XJASWGVn6mrs+oTWrBoHgByVwwI1qHiVc9GKDpZBU9vAxXYAKz2BvujlwunA== | ||||
|   dependencies: | ||||
|     deepmerge "^2.1.1" | ||||
|     hoist-non-react-statics "^3.3.0" | ||||
|     lodash "^4.17.14" | ||||
|     lodash-es "^4.17.14" | ||||
|     react-fast-compare "^2.0.1" | ||||
|     scheduler "^0.18.0" | ||||
|     tiny-warning "^1.0.2" | ||||
|     tslib "^1.10.0" | ||||
| 
 | ||||
| forwarded@~0.1.2: | ||||
|   version "0.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.1.2.tgz#98c23dab1175657b8c0573e8ceccd91b0ff18c84" | ||||
| @ -5084,7 +5121,7 @@ hmac-drbg@^1.0.0: | ||||
|     minimalistic-assert "^1.0.0" | ||||
|     minimalistic-crypto-utils "^1.0.1" | ||||
| 
 | ||||
| hoist-non-react-statics@^3.3.2: | ||||
| hoist-non-react-statics@^3.3.0, hoist-non-react-statics@^3.3.2: | ||||
|   version "3.3.2" | ||||
|   resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" | ||||
|   integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw== | ||||
| @ -6657,6 +6694,11 @@ locate-path@^5.0.0: | ||||
|   dependencies: | ||||
|     p-locate "^4.1.0" | ||||
| 
 | ||||
| lodash-es@^4.17.14: | ||||
|   version "4.17.15" | ||||
|   resolved "https://registry.yarnpkg.com/lodash-es/-/lodash-es-4.17.15.tgz#21bd96839354412f23d7a10340e5eac6ee455d78" | ||||
|   integrity sha512-rlrc3yU3+JNOpZ9zj5pQtxnx2THmvRykwL4Xlxoa8I9lHBlVbbyPhgyPMioxVZ4NqyxaVVtaJnzsyOidQIhyyQ== | ||||
| 
 | ||||
| lodash._reinterpolate@^3.0.0: | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz#0ccf2d89166af03b3663c796538b75ac6e114d9d" | ||||
| @ -7017,6 +7059,11 @@ mkdirp@^0.5.1, mkdirp@^0.5.3, mkdirp@~0.5.1: | ||||
|   dependencies: | ||||
|     minimist "^1.2.5" | ||||
| 
 | ||||
| moment@*, moment@^2.26.0: | ||||
|   version "2.26.0" | ||||
|   resolved "https://registry.yarnpkg.com/moment/-/moment-2.26.0.tgz#5e1f82c6bafca6e83e808b30c8705eed0dcbd39a" | ||||
|   integrity sha512-oIixUO+OamkUkwjhAVE18rAMfRJNsNe/Stid/gwHSOfHrOtw9EhAY2AHvdKZ/k/MggcYELFCJz/Sn2pL8b8JMw== | ||||
| 
 | ||||
| move-concurrently@^1.0.1: | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/move-concurrently/-/move-concurrently-1.0.1.tgz#be2c005fda32e0b29af1f05d7c4b33214c701f92" | ||||
| @ -8785,6 +8832,11 @@ react-error-overlay@^6.0.7: | ||||
|   resolved "https://registry.yarnpkg.com/react-error-overlay/-/react-error-overlay-6.0.7.tgz#1dcfb459ab671d53f660a991513cb2f0a0553108" | ||||
|   integrity sha512-TAv1KJFh3RhqxNvhzxj6LeT5NWklP6rDr2a0jaTfsZ5wSZWHOGeqQyejUp3xxLfPt2UpyJEcVQB/zyPcmonNFA== | ||||
| 
 | ||||
| react-fast-compare@^2.0.1: | ||||
|   version "2.0.4" | ||||
|   resolved "https://registry.yarnpkg.com/react-fast-compare/-/react-fast-compare-2.0.4.tgz#e84b4d455b0fec113e0402c329352715196f81f9" | ||||
|   integrity sha512-suNP+J1VU1MWFKcyt7RtjiSWUjvidmQSlqu+eHslq+342xCbGTYmC0mEhPCOHxlW0CywylOC1u2DFAT+bv4dBw== | ||||
| 
 | ||||
| react-is@^16.12.0, react-is@^16.7.0, react-is@^16.8.0, react-is@^16.8.1, react-is@^16.8.4: | ||||
|   version "16.13.1" | ||||
|   resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" | ||||
| @ -9352,6 +9404,14 @@ saxes@^3.1.9: | ||||
|   dependencies: | ||||
|     xmlchars "^2.1.1" | ||||
| 
 | ||||
| scheduler@^0.18.0: | ||||
|   version "0.18.0" | ||||
|   resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.18.0.tgz#5901ad6659bc1d8f3fdaf36eb7a67b0d6746b1c4" | ||||
|   integrity sha512-agTSHR1Nbfi6ulI0kYNK0203joW2Y5W4po4l+v03tOoiJKpTBbxpNhWDvqc/4IcOw+KLmSiQLTasZ4cab2/UWQ== | ||||
|   dependencies: | ||||
|     loose-envify "^1.1.0" | ||||
|     object-assign "^4.1.1" | ||||
| 
 | ||||
| scheduler@^0.19.1: | ||||
|   version "0.19.1" | ||||
|   resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.19.1.tgz#4f3e2ed2c1a7d65681f4c854fa8c5a1ccb40f196" | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user