From 8c2a6a12e7056e1f21b04266f1756ce55231a096 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Thu, 16 Jan 2020 11:41:41 -0300 Subject: [PATCH 01/72] initial commit --- README.md | 68 + package-lock.json | 14531 ++++++++++++++++++++++++++++ package.json | 37 + public/favicon.ico | Bin 0 -> 3870 bytes public/index.html | 43 + public/logo192.png | Bin 0 -> 5347 bytes public/logo512.png | Bin 0 -> 9664 bytes public/manifest.json | 25 + public/robots.txt | 2 + src/App.css | 38 + src/App.js | 104 + src/App.test.js | 9 + src/components/FormFieldSelect.js | 67 + src/components/FormFieldText.js | 49 + src/index.css | 13 + src/index.js | 12 + src/logo.svg | 7 + src/serviceWorker.js | 137 + src/setupTests.js | 5 + 19 files changed, 15147 insertions(+) create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 public/favicon.ico create mode 100644 public/index.html create mode 100644 public/logo192.png create mode 100644 public/logo512.png create mode 100644 public/manifest.json create mode 100644 public/robots.txt create mode 100644 src/App.css create mode 100644 src/App.js create mode 100644 src/App.test.js create mode 100644 src/components/FormFieldSelect.js create mode 100644 src/components/FormFieldText.js create mode 100644 src/index.css create mode 100644 src/index.js create mode 100644 src/logo.svg create mode 100644 src/serviceWorker.js create mode 100644 src/setupTests.js diff --git a/README.md b/README.md index e69de29..859d27a 100644 --- a/README.md +++ b/README.md @@ -0,0 +1,68 @@ +This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). + +## Available Scripts + +In the project directory, you can run: + +### `npm start` + +Runs the app in the development mode.<br /> +Open [http://localhost:3000](http://localhost:3000) to view it in the browser. + +The page will reload if you make edits.<br /> +You will also see any lint errors in the console. + +### `npm test` + +Launches the test runner in the interactive watch mode.<br /> +See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information. + +### `npm run build` + +Builds the app for production to the `build` folder.<br /> +It correctly bundles React in production mode and optimizes the build for the best performance. + +The build is minified and the filenames include the hashes.<br /> +Your app is ready to be deployed! + +See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information. + +### `npm run eject` + +**Note: this is a one-way operation. Once you `eject`, you can’t go back!** + +If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project. + +Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own. + +You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it. + +## Learn More + +You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started). + +To learn React, check out the [React documentation](https://reactjs.org/). + +### Code Splitting + +This section has moved here: https://facebook.github.io/create-react-app/docs/code-splitting + +### Analyzing the Bundle Size + +This section has moved here: https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size + +### Making a Progressive Web App + +This section has moved here: https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app + +### Advanced Configuration + +This section has moved here: https://facebook.github.io/create-react-app/docs/advanced-configuration + +### Deployment + +This section has moved here: https://facebook.github.io/create-react-app/docs/deployment + +### `npm run build` fails to minify + +This section has moved here: https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..c964a0d --- /dev/null +++ b/package-lock.json @@ -0,0 +1,14531 @@ +{ + "name": "my-app", + "version": "0.1.0", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@babel/code-frame": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.0.tgz", + "integrity": "sha512-AN2IR/wCUYsM+PdErq6Bp3RFTXl8W0p9Nmymm7zkpsCmh+r/YYcckaCGpU8Q/mEKmST19kkGRaG42A/jxOWwBA==", + "requires": { + "@babel/highlight": "^7.8.0" + } + }, + "@babel/compat-data": { + "version": "7.8.1", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.8.1.tgz", + "integrity": "sha512-Z+6ZOXvyOWYxJ50BwxzdhRnRsGST8Y3jaZgxYig575lTjVSs3KtJnmESwZegg6e2Dn0td1eDhoWlp1wI4BTCPw==", + "requires": { + "browserslist": "^4.8.2", + "invariant": "^2.2.4", + "semver": "^5.5.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "@babel/core": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.7.4.tgz", + "integrity": "sha512-+bYbx56j4nYBmpsWtnPUsKW3NdnYxbqyfrP2w9wILBuHzdfIKz9prieZK0DFPyIzkjYVUe4QkusGL07r5pXznQ==", + "requires": { + "@babel/code-frame": "^7.5.5", + "@babel/generator": "^7.7.4", + "@babel/helpers": "^7.7.4", + "@babel/parser": "^7.7.4", + "@babel/template": "^7.7.4", + "@babel/traverse": "^7.7.4", + "@babel/types": "^7.7.4", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "json5": "^2.1.0", + "lodash": "^4.17.13", + "resolve": "^1.3.2", + "semver": "^5.4.1", + "source-map": "^0.5.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "@babel/generator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.8.0.tgz", + "integrity": "sha512-2Lp2e02CV2C7j/H4n4D9YvsvdhPVVg9GDIamr6Tu4tU35mL3mzOrzl1lZ8ZJtysfZXh+y+AGORc2rPS7yHxBUg==", + "requires": { + "@babel/types": "^7.8.0", + "jsesc": "^2.5.1", + "lodash": "^4.17.13", + "source-map": "^0.5.0" + } + }, + "@babel/helper-annotate-as-pure": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.8.0.tgz", + "integrity": "sha512-WWj+1amBdowU2g18p3/KUc1Y5kWnaNm1paohq2tT4/RreeMNssYkv6ul9wkE2iIqjwLBwNMZGH4pTGlMSUqMMg==", + "requires": { + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.8.0.tgz", + "integrity": "sha512-KbBloNiBHM3ZyHg1ViDRs4QcnAunwMJ+rLpAEA8l3cWb3Z1xof7ag1iHvX16EwhUfaTG3+YSvTRPv4xHIrseUQ==", + "requires": { + "@babel/helper-explode-assignable-expression": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-builder-react-jsx": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-react-jsx/-/helper-builder-react-jsx-7.8.0.tgz", + "integrity": "sha512-Zg7VLtZzcAHoQ13S0pEIGKo8OAG3s5kjsk/4keGmUeNuc810T9fVp6izIaL8ZVeAErRFWJdvqFItY3QMTHMsSg==", + "requires": { + "@babel/types": "^7.8.0", + "esutils": "^2.0.0" + } + }, + "@babel/helper-call-delegate": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-call-delegate/-/helper-call-delegate-7.8.0.tgz", + "integrity": "sha512-Vi8K1LScr8ZgLicfuCNSE7JWUPG/H/9Bw9zn+3vQyy4vA54FEGTCuUTOXCFwmBM93OD6jHfjrQ6ZnivM5U+bHg==", + "requires": { + "@babel/helper-hoist-variables": "^7.8.0", + "@babel/traverse": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-compilation-targets": { + "version": "7.8.1", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.8.1.tgz", + "integrity": "sha512-Fsrljg8DHSdnKSzC0YFopX7lseRpVfWMYuC1Dnvf7tw972E2KDjZ4XEaqjO9aJL0sLcG4KNRXxowDxHYIcZ+Cw==", + "requires": { + "@babel/compat-data": "^7.8.1", + "browserslist": "^4.8.2", + "invariant": "^2.2.4", + "levenary": "^1.1.0", + "semver": "^5.5.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "@babel/helper-create-class-features-plugin": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.8.0.tgz", + "integrity": "sha512-ctCvqYBTlwEl2uF4hCxE0cd/sSw71Zfag0jKa39y4HDLh0BQ4PVBX1384Ye8GqrEZ69xgLp9fwPbv3GgIDDF2Q==", + "requires": { + "@babel/helper-function-name": "^7.8.0", + "@babel/helper-member-expression-to-functions": "^7.8.0", + "@babel/helper-optimise-call-expression": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/helper-replace-supers": "^7.8.0", + "@babel/helper-split-export-declaration": "^7.8.0" + } + }, + "@babel/helper-create-regexp-features-plugin": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.8.0.tgz", + "integrity": "sha512-vJj2hPbxxLUWJEV86iZiac5curAnC3ZVc+rFmFeWZigUOcuCPpbF+KxoEmxrkmuCGylHFF9t4lkpcDUcxnhQ5g==", + "requires": { + "@babel/helper-regex": "^7.8.0", + "regexpu-core": "^4.6.0" + } + }, + "@babel/helper-define-map": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-define-map/-/helper-define-map-7.8.0.tgz", + "integrity": "sha512-Go06lUlZ4YImNEmdyAH5iO38yh5mbpOPSwA2PtV1vyczFhTZfX0OtzkiIL2pACo6AOYf89pLh42nhhDrqgzC3A==", + "requires": { + "@babel/helper-function-name": "^7.8.0", + "@babel/types": "^7.8.0", + "lodash": "^4.17.13" + } + }, + "@babel/helper-explode-assignable-expression": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.8.0.tgz", + "integrity": "sha512-w4mRQqKAh4M7BSLwvDMm8jYFroEzpqMCtXDhFHP+kNjMIQWpbC6b0Q/RUQsJNSf54rIx6XMdci1Stf60DWw+og==", + "requires": { + "@babel/traverse": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-function-name": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.8.0.tgz", + "integrity": "sha512-x9psucuU0Xalw+0Vpr2FYJMLB7/KnPSLZhlkUyOGbYAWRDfmtZBrguYpJYiaNCRV7vGkYjO/gF6/J6yMvdWTDw==", + "requires": { + "@babel/helper-get-function-arity": "^7.8.0", + "@babel/template": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.8.0.tgz", + "integrity": "sha512-eUP5grliToMapQiTaYS2AAO/WwaCG7cuJztR1v/a1aPzUzUeGt+AaI9OvLATc/AfFkF8SLJ10d5ugGt/AQ9d6w==", + "requires": { + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-hoist-variables": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.8.0.tgz", + "integrity": "sha512-jDl66KvuklTXUADcoXDMur1jDtAZUZZkzLIaQ54+z38ih8C0V0hC56hMaoVoyoxN60MwQmmrHctBwcLqP0c/Lw==", + "requires": { + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-member-expression-to-functions": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.8.0.tgz", + "integrity": "sha512-0m1QabGrdXuoxX/g+KOAGndoHwskC70WweqHRQyCsaO67KOEELYh4ECcGw6ZGKjDKa5Y7SW4Qbhw6ly4Fah/jQ==", + "requires": { + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-module-imports": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.8.0.tgz", + "integrity": "sha512-ylY9J6ZxEcjmJaJ4P6aVs/fZdrZVctCGnxxfYXwCnSMapqd544zT8lWK2qI/vBPjE5gS0o2jILnH+AkpsPauEQ==", + "requires": { + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-module-transforms": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.8.0.tgz", + "integrity": "sha512-fvGhX4FY7YwRdWW/zfddNaKpYl8TaA8hvwONIYhv1/a1ZbgxbTrjsmH6IGWUgUNki7QzbpZ27OEh88sZdft3YA==", + "requires": { + "@babel/helper-module-imports": "^7.8.0", + "@babel/helper-simple-access": "^7.8.0", + "@babel/helper-split-export-declaration": "^7.8.0", + "@babel/template": "^7.8.0", + "@babel/types": "^7.8.0", + "lodash": "^4.17.13" + } + }, + "@babel/helper-optimise-call-expression": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.8.0.tgz", + "integrity": "sha512-aiJt1m+K57y0n10fTw+QXcCXzmpkG+o+NoQmAZqlZPstkTE0PZT+Z27QSd/6Gf00nuXJQO4NiJ0/YagSW5kC2A==", + "requires": { + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-plugin-utils": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.8.0.tgz", + "integrity": "sha512-+hAlRGdf8fHQAyNnDBqTHQhwdLURLdrCROoWaEQYiQhk2sV9Rhs+GoFZZfMJExTq9HG8o2NX3uN2G90bFtmFdA==" + }, + "@babel/helper-regex": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-regex/-/helper-regex-7.8.0.tgz", + "integrity": "sha512-haD8fRsPtyFZkbtxBIaGBBHRtbn0YsyecdYrxNgO0Bl6SlGokJPQX9M2tDuVbeQBYHZVLUPMSwGQn4obHevsMQ==", + "requires": { + "lodash": "^4.17.13" + } + }, + "@babel/helper-remap-async-to-generator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.8.0.tgz", + "integrity": "sha512-+aKyBd4oHAaIZgOLq/uLjkUz7ExZ0ppdNBc8Qr72BmtKNAy3A6EJa/ifjj0//CIzQtUDPs3E6HjKM2cV6bnXsQ==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.0", + "@babel/helper-wrap-function": "^7.8.0", + "@babel/template": "^7.8.0", + "@babel/traverse": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-replace-supers": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.8.0.tgz", + "integrity": "sha512-R2CyorW4tcO3YzdkClLpt6MS84G+tPkOi0MmiCn1bvYVnmDpdl9R15XOi3NQW2mhOAEeBnuQ4g1Bh7pT2sX8fg==", + "requires": { + "@babel/helper-member-expression-to-functions": "^7.8.0", + "@babel/helper-optimise-call-expression": "^7.8.0", + "@babel/traverse": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-simple-access": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.8.0.tgz", + "integrity": "sha512-I+7yKZJnxp7VIC2UFzXfVjLiJuU16rYFF59x27c+boINkO/pLETgZcoesCryg9jmU4jxEa0foFueW+2wjc9Gsw==", + "requires": { + "@babel/template": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.8.0.tgz", + "integrity": "sha512-YhYFhH4T6DlbT6CPtVgLfC1Jp2gbCawU/ml7WJvUpBg01bCrXSzTYMZZXbbIGjq/kHmK8YUATxTppcRGzj31pA==", + "requires": { + "@babel/types": "^7.8.0" + } + }, + "@babel/helper-wrap-function": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.8.0.tgz", + "integrity": "sha512-2j6idN2jt8Y+8nJ4UPN/6AZa53DAkcETMVmroJQh50qZc59PuQKVjgOIIqmrLoQf6Ia9bs90MHRcID1OW5tfag==", + "requires": { + "@babel/helper-function-name": "^7.8.0", + "@babel/template": "^7.8.0", + "@babel/traverse": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/helpers": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.8.0.tgz", + "integrity": "sha512-srWKpjAFbiut5JoCReZJ098hLqoZ9HufOnKZPggc7j74XaPuQ+9b3RYPV1M/HfjL63lCNd8uI1O487qIWxAFNA==", + "requires": { + "@babel/template": "^7.8.0", + "@babel/traverse": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/highlight": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.8.0.tgz", + "integrity": "sha512-OsdTJbHlPtIk2mmtwXItYrdmalJ8T0zpVzNAbKSkHshuywj7zb29Y09McV/jQsQunc/nEyHiPV2oy9llYMLqxw==", + "requires": { + "chalk": "^2.0.0", + "esutils": "^2.0.2", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.8.0.tgz", + "integrity": "sha512-VVtsnUYbd1+2A2vOVhm4P2qNXQE8L/W859GpUHfUcdhX8d3pEKThZuIr6fztocWx9HbK+00/CR0tXnhAggJ4CA==" + }, + "@babel/plugin-proposal-async-generator-functions": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.8.0.tgz", + "integrity": "sha512-8vIQf8JYced7gCeKDsGETNGKE+zdD/JmP1LBlRn+w3UXc1aSpZv2Y330bB/fnOEbUgPbuFv+IEi+gopg+Fu0kQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/helper-remap-async-to-generator": "^7.8.0", + "@babel/plugin-syntax-async-generators": "^7.8.0" + } + }, + "@babel/plugin-proposal-class-properties": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.7.4.tgz", + "integrity": "sha512-EcuXeV4Hv1X3+Q1TsuOmyyxeTRiSqurGJ26+I/FW1WbymmRRapVORm6x1Zl3iDIHyRxEs+VXWp6qnlcfcJSbbw==", + "requires": { + "@babel/helper-create-class-features-plugin": "^7.7.4", + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/plugin-proposal-decorators": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-decorators/-/plugin-proposal-decorators-7.7.4.tgz", + "integrity": "sha512-GftcVDcLCwVdzKmwOBDjATd548+IE+mBo7ttgatqNDR7VG7GqIuZPtRWlMLHbhTXhcnFZiGER8iIYl1n/imtsg==", + "requires": { + "@babel/helper-create-class-features-plugin": "^7.7.4", + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-decorators": "^7.7.4" + } + }, + "@babel/plugin-proposal-dynamic-import": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.8.0.tgz", + "integrity": "sha512-YzMq0AqeTR4Mh2pz3GrCWqhcEV38HgUMMR/56/YR5GPc4Y2p1KJ4Le6j92vMnW8TJqVj+qJz/KDNglpMeww9Yg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-dynamic-import": "^7.8.0" + } + }, + "@babel/plugin-proposal-json-strings": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.8.0.tgz", + "integrity": "sha512-pSpuhwn926vtNeUH2FHx1OzIXaUMgklG0MzlFZJVEg37fB904gOxN572NgBae+KDwFyZDpkLMyEkVA011lBJrQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-json-strings": "^7.8.0" + } + }, + "@babel/plugin-proposal-nullish-coalescing-operator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.8.0.tgz", + "integrity": "sha512-cQMI+RQdcK2IyMm13NKKFCYfOSBUtFxEeRBOdFCi2Pubv/CpkrCubc/ikdeKMT6Lu+uQ+lNSDEJvDCOQZkUy0g==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.0" + } + }, + "@babel/plugin-proposal-numeric-separator": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.7.4.tgz", + "integrity": "sha512-CG605v7lLpVgVldSY6kxsN9ui1DxFOyepBfuX2AzU2TNriMAYApoU55mrGw9Jr4TlrTzPCG10CL8YXyi+E/iPw==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-numeric-separator": "^7.7.4" + } + }, + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.8.0.tgz", + "integrity": "sha512-SjJ2ZXCylpWC+5DTES0/pbpNmw/FnjU/3dF068xF0DU9aN+oOKah+3MCSFcb4pnZ9IwmxfOy4KnbGJSQR+hAZA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-object-rest-spread": "^7.8.0" + } + }, + "@babel/plugin-proposal-optional-catch-binding": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.8.0.tgz", + "integrity": "sha512-tHP3eez6TrpPJYttBZ/6uItRbIuXUIDpQ9xwvzKwR+RboWGMJ7WzFC5dDJ3vjLuCx0/DG1tM0MVkmgcBybth9w==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.0" + } + }, + "@babel/plugin-proposal-optional-chaining": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.8.0.tgz", + "integrity": "sha512-PNBHxPHE91m+LLOdGwlvyGicWfrMgiVwng5WdB3CMjd61+vn3vPw0GbgECIAUCZnyi7Jqs5htUIZRztGuV8/5g==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-optional-chaining": "^7.8.0" + } + }, + "@babel/plugin-proposal-unicode-property-regex": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.8.0.tgz", + "integrity": "sha512-3oK0Qt5w4arb+es3rWBribDbtc0TYJP7dFZ1dXcYul3cXderqfIOoSx9YUC1oD208nJwJO/++fvrgLmkYSbe8A==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-async-generators": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.0.tgz", + "integrity": "sha512-a8w8k7pK8nYhem07rXdAq03T+DlTX8LFojUptrh9JEx80AgLqGiuoFIyQOGTWif39kFnDOQqbzl1s6KQqrfV+A==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-decorators": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-decorators/-/plugin-syntax-decorators-7.8.0.tgz", + "integrity": "sha512-Qz68qh9jJqQePGWqbNW9PA7vkE2gvnWkYtx32jgPOszpE7u+xObPkRGm3B80oXAjQlBdTa4ktqjkOIRiKRuapw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-dynamic-import": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.0.tgz", + "integrity": "sha512-Mx2RzpCHJaBfmFdA2abXDKRHVJdzJ6R0Wqwb6TxCgM7NRR5wcC4cyiAsRL7Ga+lwG8GG1cKvb+4ENjic8y15jA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-flow": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.8.0.tgz", + "integrity": "sha512-MDK9WdjDccrxzz+4sthpSDnqdf5McJwTtfBYGitOweC/j0Zg6e8wHmP4RGLTeyGYe/IySoRgKC5hvSm6ddrNRw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-json-strings": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.0.tgz", + "integrity": "sha512-LPykaAbH86L5NnDfCRSpNxtEHZk+6GaFzXfWEFU/6R4v69EXQr6GOp7hwH+Uw0QlYVN++s6TukTJ3flFcspahA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-jsx": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.8.0.tgz", + "integrity": "sha512-zLDUckAuKeOtxJhfNE0TlR7iEApb2u7EYRlh5cxKzq6A5VzUbYEdyJGJlug41jDbjRbHTtsLKZUnUcy/8V3xZw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.0.tgz", + "integrity": "sha512-Rv2hnBToN6rbA9hO2a4vtwXZLzNa+TWkoSIMMvUezFz5+D9NPeX7SFrArwtFzzbwndmWiqboTr5rNpzAz0MPpA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-numeric-separator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.8.0.tgz", + "integrity": "sha512-GEYjlQAr/zXMVuce0Nq/boG4wNjJxdIOc4RKcgBEo/r/J3LrghZz8+ZYo8k+OuLJKvvV22k84tBuw1YunnLgCQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.0.tgz", + "integrity": "sha512-dt89fDlkfkTrQcy5KavMQPyF2A6tR0kYp8HAnIoQv5hO34iAUffHghP/hMGd7Gf/+uYTmLQO0ar7peX1SUWyIA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.0.tgz", + "integrity": "sha512-EIgJVy+u1RvR2gJfX4ReLwAupO/twllUue1wPrRxhu18+eC3bGTEcOSXLQdaE9ya9NG1rE0eQs0GSiloUGFEwg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-chaining": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.0.tgz", + "integrity": "sha512-LV1c+TTAO8Vawe3t+WXBHYWbS7endP8MSlqKPKEZOyWPEJX2akl3jfvFG828/OE7RpyoC3JXfLJDFj/jN7A8hg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-top-level-await": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.8.0.tgz", + "integrity": "sha512-iXR/Cw32fMfWlD1sK2zD/nXtuLStkalRv+xee6VrX84CFrn2LKwb/EOs/4UaDNUpUsws8YZYKeQjPagacFquug==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-typescript": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.8.0.tgz", + "integrity": "sha512-LrvVrabb993Ve5fzXsyEkfYCuhpXBwsUFjlvgD8UmXXg3r/8/ceooSdRvjdmtPXXz+lHaqZHZooV1jMWer2qkA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-arrow-functions": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.8.0.tgz", + "integrity": "sha512-9KfteDp9d8cF388dxFMOh3Dum41qpOVUPVjQhXGd1kPyQBE05FJgYndiAriML2yhMIbZ2bjgweh2nnvBXDH2MQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-async-to-generator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.8.0.tgz", + "integrity": "sha512-9dvBvJnEdsDWYMrykoMyLNVRPGoub6SFlARtsYgSQ1riTjnyBjhctihSME4XsSku86F59PDeFpC9PCU+9I154w==", + "requires": { + "@babel/helper-module-imports": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/helper-remap-async-to-generator": "^7.8.0" + } + }, + "@babel/plugin-transform-block-scoped-functions": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.8.0.tgz", + "integrity": "sha512-bim6gUfHq2kPN+aQst33ZEMeglpaUXAo6PWTZvOA8BOnWpNKgZcUzBvpZhh2ofL6YhZgzGoRwVVfzwynDEf47g==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-block-scoping": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.8.0.tgz", + "integrity": "sha512-FKTK4hzg7W950Yu9iqMl12WBixCmusMc5HBt3/ErvpFLnvr3/6mu/EBTZoCEJ0mw/lQUDfU01vTcZY9oEahlMg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "lodash": "^4.17.13" + } + }, + "@babel/plugin-transform-classes": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.8.0.tgz", + "integrity": "sha512-18RLDwKtGXCLLbf5V03GojebPH7dKYCmIBqQGhgfZDoYsyEzR9kMZ6IxlJP72K5ROC9ADa4KPI6ywuh7NfQOgQ==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.0", + "@babel/helper-define-map": "^7.8.0", + "@babel/helper-function-name": "^7.8.0", + "@babel/helper-optimise-call-expression": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/helper-replace-supers": "^7.8.0", + "@babel/helper-split-export-declaration": "^7.8.0", + "globals": "^11.1.0" + } + }, + "@babel/plugin-transform-computed-properties": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.8.0.tgz", + "integrity": "sha512-FaODHuQRdnWFVwxLPlTN85Lk/aitfvQBHTXahf58FnatCynfhkeNUO8ID+AqAxY4IJsZjeH6OnKDzcGfgKJcVw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-destructuring": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.8.0.tgz", + "integrity": "sha512-D+69HT//cE86aBTLULzSBFLC5A7HcPQzJPiny6P4SLHkDF750MylRKO3iWvdgvb+OSp5dOrOxwXajvaxk1ZfYA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-dotall-regex": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.8.0.tgz", + "integrity": "sha512-pq/XLkDB4MPvTe9ktHJInfWksalXogrIGRZJUG7RiDXhEfdNrlducoMPbACZQuCFtelVgVpD0VyreiY0l38G7g==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-duplicate-keys": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.8.0.tgz", + "integrity": "sha512-REtYWvpP4TDw4oVeP01vQJcAeewjgk8/i7tPFP11vUjvarUGGyxJLeq79WEnIdnKPQJirZaoDRT4kEWEdSWkDw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-exponentiation-operator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.8.0.tgz", + "integrity": "sha512-vaDgF3gPLzVcoe3UZqnra6FA7O797sZc+UCHPd9eQTI34cPtpCA270LzopIXS3Fhc3UmFrijLmre9mHTmUKVgg==", + "requires": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-flow-strip-types": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.7.4.tgz", + "integrity": "sha512-w9dRNlHY5ElNimyMYy0oQowvQpwt/PRHI0QS98ZJCTZU2bvSnKXo5zEiD5u76FBPigTm8TkqzmnUTg16T7qbkA==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-flow": "^7.7.4" + } + }, + "@babel/plugin-transform-for-of": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.8.0.tgz", + "integrity": "sha512-9j9g0qViCAo8E5qCBSaQdghymn7A9bRXSfS9jU7oLpYccYFZg9A+1KO8X+HV7fhJYH6mZ+e7MRg4p3sLo+RG6Q==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-function-name": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.8.0.tgz", + "integrity": "sha512-YL8Ol54UKeIyY1uUGfry+B9ppXAB3aVBB1gG9gxqhg/OBCPpV2QUNswmjvfmyXEdaWv8qODssBgX7on792h44w==", + "requires": { + "@babel/helper-function-name": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-literals": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.8.0.tgz", + "integrity": "sha512-7UDPKG+uVltsZt98Hw+rMbLg772r8fQC6YJ2fNDckcpAXgIWqQbMCmCpfYo0hBNhdhqocM73auk4P/zziQshQw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-member-expression-literals": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.8.0.tgz", + "integrity": "sha512-lJSdaWR56wmrosCiyqKFRVnLrFYoVAk2mtZAyegt7akeJky/gguv0Rukx9GV3XwHGuM1ZPE06cZMjNlcLp8LrQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-modules-amd": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.8.0.tgz", + "integrity": "sha512-mFr1O3TaDL4XozM3AzNPz9AsxzzjTxwn4aOShYP5TlO+4rufvjagV2KKDTPMZTQm1ZA/C/PxJDsDekEnnUGz5A==", + "requires": { + "@babel/helper-module-transforms": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "babel-plugin-dynamic-import-node": "^2.3.0" + } + }, + "@babel/plugin-transform-modules-commonjs": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.8.0.tgz", + "integrity": "sha512-w2g8tmL7NgBYt6alc8YawMcmPiYqnVvvI0kLB++VOUOssqdJMAkfQOMGV+2M8H5uhJYDaAghAVMUYps3s+jMrw==", + "requires": { + "@babel/helper-module-transforms": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/helper-simple-access": "^7.8.0", + "babel-plugin-dynamic-import-node": "^2.3.0" + } + }, + "@babel/plugin-transform-modules-systemjs": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.8.0.tgz", + "integrity": "sha512-tKF9KLiIsiKyWTVU0yo+NcNAylGn7euggYwXw63/tMxGtDTPsB9Y7Ecqv4EoXEwtoJOJ0Lewf17oaWQtindxIA==", + "requires": { + "@babel/helper-hoist-variables": "^7.8.0", + "@babel/helper-module-transforms": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "babel-plugin-dynamic-import-node": "^2.3.0" + } + }, + "@babel/plugin-transform-modules-umd": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.8.0.tgz", + "integrity": "sha512-lAwNfXwmfTy7fl2XOyoVpMXnLkJANgH0vdSYNFcS4RuJPBtHfunGA+Y0L7wsHmfPzyVYt8sUglLjaWtdZMNJNg==", + "requires": { + "@babel/helper-module-transforms": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.8.0.tgz", + "integrity": "sha512-kq1rxQ1HviCP13SMGZ4WjBBpdogTGK7yn/g/+p+g1AQledgHOWKVeMY1DwKYGlGJ/grDGTOqpJLF1v3Sb7ghKA==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.0" + } + }, + "@babel/plugin-transform-new-target": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.8.0.tgz", + "integrity": "sha512-hH1Afz9Xy/wkcxhoI0vYw48kTBJqYUhMmhp3SLI1p817iByM6ItH4LS8tZatDAIKmAQAXj8d3Ups1BgVJECDrA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-object-super": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.8.0.tgz", + "integrity": "sha512-2DYqQ811nRlFVlni6iqfxBVVGqkBgfvEv/lcvmdNu2CaG+EA7zSP1hqYUsqamR+uCdDbsrV7uY6/0rkXbJo5YQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/helper-replace-supers": "^7.8.0" + } + }, + "@babel/plugin-transform-parameters": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.8.0.tgz", + "integrity": "sha512-9R2yykk7H92rntETO0fq52vJ4OFaTcDA49K9s8bQPyoD4o3/SkWEklukArCsQC6fowEuraPkH/umopr9uO539g==", + "requires": { + "@babel/helper-call-delegate": "^7.8.0", + "@babel/helper-get-function-arity": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-property-literals": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.8.0.tgz", + "integrity": "sha512-vjZaQlojnZIahu5ofEW+hPJfDI5A6r2Sbi5C0RuCaAOFj7viDIR5kOR7ul3Fz5US8V1sVk5Zd2yuPaz7iBeysg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-react-constant-elements": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-constant-elements/-/plugin-transform-react-constant-elements-7.8.0.tgz", + "integrity": "sha512-Rv1xUzuQK1tC66/4FxaG750bDr/Nv5AiSBmIwAK4bhksGUsl8XHPznASFchvsM7JMjI50gZvXMKmDJiKbyAfLw==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-react-display-name": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.8.0.tgz", + "integrity": "sha512-oozdOhU2hZ6Tb9LS9BceGqDSmiUrlZX8lmRqnxQuiGzqWlhflIRQ1oFBHdV+hv+Zi9e5BhRkfSYtMLRLEkuOVA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-react-jsx": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.8.0.tgz", + "integrity": "sha512-r5DgP2ZblaGmW/azRS9rlaf3oY4r/ByXRDA5Lcr3iHUkx3cCfL9RM10gU7AQmzwKymoq8LZ55sHyq9VeQFHwyQ==", + "requires": { + "@babel/helper-builder-react-jsx": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-jsx": "^7.8.0" + } + }, + "@babel/plugin-transform-react-jsx-self": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.8.0.tgz", + "integrity": "sha512-hJXfJdLDDlJoxW/rAjkuIpGUUTizQ6fN9tIciW1M8KIqFsmpEf9psBPNTXYRCOLYLEsra+/WgVq+sc+1z05nQw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-jsx": "^7.8.0" + } + }, + "@babel/plugin-transform-react-jsx-source": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.8.0.tgz", + "integrity": "sha512-W+0VXOhMRdUTL7brjKXND+BiXbsxczfMdZongQ/Jtti0JVMtcTxWo66NMxNNtbPYvbc4aUXmgjl3eMms41sYtg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-jsx": "^7.8.0" + } + }, + "@babel/plugin-transform-regenerator": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.8.0.tgz", + "integrity": "sha512-n88GT8PZuOHWxqxCJORW3g1QaYzQhHu5sEslxYeQkHVoewfnfuWN37t7YGaRLaNUdaZUlRPXhDcLGT7zBa/u0g==", + "requires": { + "regenerator-transform": "^0.14.0" + } + }, + "@babel/plugin-transform-reserved-words": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.8.0.tgz", + "integrity": "sha512-DnshRyDTXZhmAgO2c1QKZI4CfZjoP2t3fSwRsnbCP9P/FSBpf9I7ovnAELswklw5OeY+/D/JIiaGLoUt2II3LA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-runtime": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.7.4.tgz", + "integrity": "sha512-O8kSkS5fP74Ad/8pfsCMGa8sBRdLxYoSReaARRNSz3FbFQj3z/QUvoUmJ28gn9BO93YfnXc3j+Xyaqe8cKDNBQ==", + "requires": { + "@babel/helper-module-imports": "^7.7.4", + "@babel/helper-plugin-utils": "^7.0.0", + "resolve": "^1.8.1", + "semver": "^5.5.1" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "@babel/plugin-transform-shorthand-properties": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.8.0.tgz", + "integrity": "sha512-sExhzq63Gl2PMbl7ETpN7Z1A38rLD6GeCT6EEEIIKjTVt9u6dRqJ6nHhaquL7QgR3egj/8fcvq23UvzfPqGAYA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-spread": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.8.0.tgz", + "integrity": "sha512-6Zjl0pv6x10YmFVRI0VhwJ/rE++geVHNJ9xwd+UIt3ON2VMRO7qI2lPsyLnzidR5HYNd/JXj47kdU9Rrn4YcnQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-sticky-regex": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.8.0.tgz", + "integrity": "sha512-uksok0Bqox8YeIRFhr6RRtlBXeGpN1ogiEVjEd7A7rVLPZBXKGbL7kODpE7MQ+avjDLv5EEKtDCeYuWZK7FF7g==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/helper-regex": "^7.8.0" + } + }, + "@babel/plugin-transform-template-literals": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.8.0.tgz", + "integrity": "sha512-EF7Q7LEgeMpogHcvmHMNXBWdLWG1tpA1ErXH3i8zTu3+UEKo6aBn+FldPAJ16UbbbOwSCUCiDP6oZxvVRPhwnQ==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-typeof-symbol": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.8.0.tgz", + "integrity": "sha512-rEUBEFzsA9mCS2r7EtXFlM/6GqtzgLdC4WVYM9fIgJX+HcSJ8oMmj8LinfKhbo0ipRauvUM2teE2iNDNqDwO1g==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-transform-typescript": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.8.0.tgz", + "integrity": "sha512-RhMZnNWcyvX+rM6mk888MaeoVl5pGfmYP3as709n4+0d15SRedz4r+LPRg2a9s4z+t+DM+gy8uz/rmM3Cb8JBw==", + "requires": { + "@babel/helper-create-class-features-plugin": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-syntax-typescript": "^7.8.0" + } + }, + "@babel/plugin-transform-unicode-regex": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.8.0.tgz", + "integrity": "sha512-qDg8wsnE47B/Sj8ZtOndPHrGBxJMssZJ71SzXrItum9n++iVFN7kYuJO+OHhjom7+/or0zzYqvJNzCkUjyNKqg==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/preset-env": { + "version": "7.8.2", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.8.2.tgz", + "integrity": "sha512-AF2YUl2bGsLWTtFL68upTTB7nDo05aEcKjHmXJE+aXRvsx5K+9yRsHQP3MjnTrLOWe/eFyUr93dfILROsKC4eg==", + "requires": { + "@babel/compat-data": "^7.8.0", + "@babel/helper-compilation-targets": "^7.8.0", + "@babel/helper-module-imports": "^7.8.0", + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-proposal-async-generator-functions": "^7.8.0", + "@babel/plugin-proposal-dynamic-import": "^7.8.0", + "@babel/plugin-proposal-json-strings": "^7.8.0", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.8.0", + "@babel/plugin-proposal-object-rest-spread": "^7.8.0", + "@babel/plugin-proposal-optional-catch-binding": "^7.8.0", + "@babel/plugin-proposal-optional-chaining": "^7.8.0", + "@babel/plugin-proposal-unicode-property-regex": "^7.8.0", + "@babel/plugin-syntax-async-generators": "^7.8.0", + "@babel/plugin-syntax-dynamic-import": "^7.8.0", + "@babel/plugin-syntax-json-strings": "^7.8.0", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.0", + "@babel/plugin-syntax-object-rest-spread": "^7.8.0", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.0", + "@babel/plugin-syntax-optional-chaining": "^7.8.0", + "@babel/plugin-syntax-top-level-await": "^7.8.0", + "@babel/plugin-transform-arrow-functions": "^7.8.0", + "@babel/plugin-transform-async-to-generator": "^7.8.0", + "@babel/plugin-transform-block-scoped-functions": "^7.8.0", + "@babel/plugin-transform-block-scoping": "^7.8.0", + "@babel/plugin-transform-classes": "^7.8.0", + "@babel/plugin-transform-computed-properties": "^7.8.0", + "@babel/plugin-transform-destructuring": "^7.8.0", + "@babel/plugin-transform-dotall-regex": "^7.8.0", + "@babel/plugin-transform-duplicate-keys": "^7.8.0", + "@babel/plugin-transform-exponentiation-operator": "^7.8.0", + "@babel/plugin-transform-for-of": "^7.8.0", + "@babel/plugin-transform-function-name": "^7.8.0", + "@babel/plugin-transform-literals": "^7.8.0", + "@babel/plugin-transform-member-expression-literals": "^7.8.0", + "@babel/plugin-transform-modules-amd": "^7.8.0", + "@babel/plugin-transform-modules-commonjs": "^7.8.0", + "@babel/plugin-transform-modules-systemjs": "^7.8.0", + "@babel/plugin-transform-modules-umd": "^7.8.0", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.8.0", + "@babel/plugin-transform-new-target": "^7.8.0", + "@babel/plugin-transform-object-super": "^7.8.0", + "@babel/plugin-transform-parameters": "^7.8.0", + "@babel/plugin-transform-property-literals": "^7.8.0", + "@babel/plugin-transform-regenerator": "^7.8.0", + "@babel/plugin-transform-reserved-words": "^7.8.0", + "@babel/plugin-transform-shorthand-properties": "^7.8.0", + "@babel/plugin-transform-spread": "^7.8.0", + "@babel/plugin-transform-sticky-regex": "^7.8.0", + "@babel/plugin-transform-template-literals": "^7.8.0", + "@babel/plugin-transform-typeof-symbol": "^7.8.0", + "@babel/plugin-transform-unicode-regex": "^7.8.0", + "@babel/types": "^7.8.0", + "browserslist": "^4.8.2", + "core-js-compat": "^3.6.2", + "invariant": "^2.2.2", + "levenary": "^1.1.0", + "semver": "^5.5.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "@babel/preset-react": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/preset-react/-/preset-react-7.8.0.tgz", + "integrity": "sha512-GP9t18RjtH67ea3DA2k71VqtMnTOupYJx34Z+KUEBRoRxvdETaucmtMWH5uoGHWzAD4qxbuV5ckxpewm39NXkA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0", + "@babel/plugin-transform-react-display-name": "^7.8.0", + "@babel/plugin-transform-react-jsx": "^7.8.0", + "@babel/plugin-transform-react-jsx-self": "^7.8.0", + "@babel/plugin-transform-react-jsx-source": "^7.8.0" + } + }, + "@babel/preset-typescript": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.7.4.tgz", + "integrity": "sha512-rqrjxfdiHPsnuPur0jKrIIGQCIgoTWMTjlbWE69G4QJ6TIOVnnRnIJhUxNTL/VwDmEAVX08Tq3B1nirer5341w==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-transform-typescript": "^7.7.4" + } + }, + "@babel/runtime": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.7.4.tgz", + "integrity": "sha512-r24eVUUr0QqNZa+qrImUk8fn5SPhHq+IfYvIoIMg0do3GdK9sMdiLKP3GYVVaxpPKORgm8KRKaNTEhAjgIpLMw==", + "requires": { + "regenerator-runtime": "^0.13.2" + } + }, + "@babel/runtime-corejs3": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/runtime-corejs3/-/runtime-corejs3-7.8.0.tgz", + "integrity": "sha512-5XaME/D4hTkUclw4BW+FeDyfUcxN5/Fox/+9UiWUqdyU33zsLxDAE74IexAmLccuHSQyFbIzF5+Yb4E6obVOSg==", + "requires": { + "core-js-pure": "^3.0.0", + "regenerator-runtime": "^0.13.2" + } + }, + "@babel/template": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.8.0.tgz", + "integrity": "sha512-0NNMDsY2t3ltAVVK1WHNiaePo3tXPUeJpCX4I3xSKFoEl852wJHG8mrgHVADf8Lz1y+8al9cF7cSSfzSnFSYiw==", + "requires": { + "@babel/code-frame": "^7.8.0", + "@babel/parser": "^7.8.0", + "@babel/types": "^7.8.0" + } + }, + "@babel/traverse": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.8.0.tgz", + "integrity": "sha512-d/6sPXFLGlJHZO/zWDtgFaKyalCOHLedzxpVJn6el1cw+f2TZa7xZEszeXdOw6EUemqRFBAn106BWBvtSck9Qw==", + "requires": { + "@babel/code-frame": "^7.8.0", + "@babel/generator": "^7.8.0", + "@babel/helper-function-name": "^7.8.0", + "@babel/helper-split-export-declaration": "^7.8.0", + "@babel/parser": "^7.8.0", + "@babel/types": "^7.8.0", + "debug": "^4.1.0", + "globals": "^11.1.0", + "lodash": "^4.17.13" + } + }, + "@babel/types": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.8.0.tgz", + "integrity": "sha512-1RF84ehyx9HH09dMMwGWl3UTWlVoCPtqqJPjGuC4JzMe1ZIVDJ2DT8mv3cPv/A7veLD6sgR7vi95lJqm+ZayIg==", + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.13", + "to-fast-properties": "^2.0.0" + } + }, + "@cnakazawa/watch": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/@cnakazawa/watch/-/watch-1.0.3.tgz", + "integrity": "sha512-r5160ogAvGyHsal38Kux7YYtodEKOj89RGb28ht1jh3SJb08VwRwAKKJL0bGb04Zd/3r9FL3BFIc3bBidYffCA==", + "requires": { + "exec-sh": "^0.3.2", + "minimist": "^1.2.0" + } + }, + "@csstools/convert-colors": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@csstools/convert-colors/-/convert-colors-1.4.0.tgz", + "integrity": "sha512-5a6wqoJV/xEdbRNKVo6I4hO3VjyDq//8q2f9I6PBAvMesJHFauXDorcNCsr9RzvsZnaWi5NYCcfyqP1QeFHFbw==" + }, + "@csstools/normalize.css": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/@csstools/normalize.css/-/normalize.css-10.1.0.tgz", + "integrity": "sha512-ij4wRiunFfaJxjB0BdrYHIH8FxBJpOwNPhhAcunlmPdXudL1WQV1qoP9un6JsEBAgQH+7UXyyjh0g7jTxXK6tg==" + }, + "@emotion/hash": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.7.4.tgz", + "integrity": "sha512-fxfMSBMX3tlIbKUdtGKxqB1fyrH6gVrX39Gsv3y8lRYKUqlgDt3UMqQyGnR1bQMa2B8aGnhLZokZgg8vT0Le+A==" + }, + "@hapi/address": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@hapi/address/-/address-2.1.4.tgz", + "integrity": "sha512-QD1PhQk+s31P1ixsX0H0Suoupp3VMXzIVMSwobR3F3MSUO2YCV0B7xqLcUw/Bh8yuvd3LhpyqLQWTNcRmp6IdQ==" + }, + "@hapi/bourne": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/@hapi/bourne/-/bourne-1.3.2.tgz", + "integrity": "sha512-1dVNHT76Uu5N3eJNTYcvxee+jzX4Z9lfciqRRHCU27ihbUcYi+iSc2iml5Ke1LXe1SyJCLA0+14Jh4tXJgOppA==" + }, + "@hapi/hoek": { + "version": "8.5.0", + "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-8.5.0.tgz", + "integrity": "sha512-7XYT10CZfPsH7j9F1Jmg1+d0ezOux2oM2GfArAzLwWe4mE2Dr3hVjsAL6+TFY49RRJlCdJDMw3nJsLFroTc8Kw==" + }, + "@hapi/joi": { + "version": "15.1.1", + "resolved": "https://registry.npmjs.org/@hapi/joi/-/joi-15.1.1.tgz", + "integrity": "sha512-entf8ZMOK8sc+8YfeOlM8pCfg3b5+WZIKBfUaaJT8UsjAAPjartzxIYm3TIbjvA4u+u++KbcXD38k682nVHDAQ==", + "requires": { + "@hapi/address": "2.x.x", + "@hapi/bourne": "1.x.x", + "@hapi/hoek": "8.x.x", + "@hapi/topo": "3.x.x" + } + }, + "@hapi/topo": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-3.1.6.tgz", + "integrity": "sha512-tAag0jEcjwH+P2quUfipd7liWCNX2F8NvYjQp2wtInsZxnMlypdw0FtAOLxtvvkO+GSRRbmNi8m/5y42PQJYCQ==", + "requires": { + "@hapi/hoek": "^8.3.0" + } + }, + "@jest/console": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/console/-/console-24.9.0.tgz", + "integrity": "sha512-Zuj6b8TnKXi3q4ymac8EQfc3ea/uhLeCGThFqXeC8H9/raaH8ARPUTdId+XyGd03Z4In0/VjD2OYFcBF09fNLQ==", + "requires": { + "@jest/source-map": "^24.9.0", + "chalk": "^2.0.1", + "slash": "^2.0.0" + } + }, + "@jest/core": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/core/-/core-24.9.0.tgz", + "integrity": "sha512-Fogg3s4wlAr1VX7q+rhV9RVnUv5tD7VuWfYy1+whMiWUrvl7U3QJSJyWcDio9Lq2prqYsZaeTv2Rz24pWGkJ2A==", + "requires": { + "@jest/console": "^24.7.1", + "@jest/reporters": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "ansi-escapes": "^3.0.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "graceful-fs": "^4.1.15", + "jest-changed-files": "^24.9.0", + "jest-config": "^24.9.0", + "jest-haste-map": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-resolve": "^24.9.0", + "jest-resolve-dependencies": "^24.9.0", + "jest-runner": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-snapshot": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "jest-watcher": "^24.9.0", + "micromatch": "^3.1.10", + "p-each-series": "^1.0.0", + "realpath-native": "^1.1.0", + "rimraf": "^2.5.4", + "slash": "^2.0.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "ansi-escapes": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", + "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==" + } + } + }, + "@jest/environment": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-24.9.0.tgz", + "integrity": "sha512-5A1QluTPhvdIPFYnO3sZC3smkNeXPVELz7ikPbhUj0bQjB07EoE9qtLrem14ZUYWdVayYbsjVwIiL4WBIMV4aQ==", + "requires": { + "@jest/fake-timers": "^24.9.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "jest-mock": "^24.9.0" + } + }, + "@jest/fake-timers": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-24.9.0.tgz", + "integrity": "sha512-eWQcNa2YSwzXWIMC5KufBh3oWRIijrQFROsIqt6v/NS9Io/gknw1jsAC9c+ih/RQX4A3O7SeWAhQeN0goKhT9A==", + "requires": { + "@jest/types": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-mock": "^24.9.0" + } + }, + "@jest/reporters": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-24.9.0.tgz", + "integrity": "sha512-mu4X0yjaHrffOsWmVLzitKmmmWSQ3GGuefgNscUSWNiUNcEOSEQk9k3pERKEQVBb0Cnn88+UESIsZEMH3o88Gw==", + "requires": { + "@jest/environment": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "glob": "^7.1.2", + "istanbul-lib-coverage": "^2.0.2", + "istanbul-lib-instrument": "^3.0.1", + "istanbul-lib-report": "^2.0.4", + "istanbul-lib-source-maps": "^3.0.1", + "istanbul-reports": "^2.2.6", + "jest-haste-map": "^24.9.0", + "jest-resolve": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-util": "^24.9.0", + "jest-worker": "^24.6.0", + "node-notifier": "^5.4.2", + "slash": "^2.0.0", + "source-map": "^0.6.0", + "string-length": "^2.0.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "@jest/source-map": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-24.9.0.tgz", + "integrity": "sha512-/Xw7xGlsZb4MJzNDgB7PW5crou5JqWiBQaz6xyPd3ArOg2nfn/PunV8+olXbbEZzNl591o5rWKE9BRDaFAuIBg==", + "requires": { + "callsites": "^3.0.0", + "graceful-fs": "^4.1.15", + "source-map": "^0.6.0" + }, + "dependencies": { + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "@jest/test-result": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-24.9.0.tgz", + "integrity": "sha512-XEFrHbBonBJ8dGp2JmF8kP/nQI/ImPpygKHwQ/SY+es59Z3L5PI4Qb9TQQMAEeYsThG1xF0k6tmG0tIKATNiiA==", + "requires": { + "@jest/console": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/istanbul-lib-coverage": "^2.0.0" + } + }, + "@jest/test-sequencer": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-24.9.0.tgz", + "integrity": "sha512-6qqsU4o0kW1dvA95qfNog8v8gkRN9ph6Lz7r96IvZpHdNipP2cBcb07J1Z45mz/VIS01OHJ3pY8T5fUY38tg4A==", + "requires": { + "@jest/test-result": "^24.9.0", + "jest-haste-map": "^24.9.0", + "jest-runner": "^24.9.0", + "jest-runtime": "^24.9.0" + } + }, + "@jest/transform": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-24.9.0.tgz", + "integrity": "sha512-TcQUmyNRxV94S0QpMOnZl0++6RMiqpbH/ZMccFB/amku6Uwvyb1cjYX7xkp5nGNkbX4QPH/FcB6q1HBTHynLmQ==", + "requires": { + "@babel/core": "^7.1.0", + "@jest/types": "^24.9.0", + "babel-plugin-istanbul": "^5.1.0", + "chalk": "^2.0.1", + "convert-source-map": "^1.4.0", + "fast-json-stable-stringify": "^2.0.0", + "graceful-fs": "^4.1.15", + "jest-haste-map": "^24.9.0", + "jest-regex-util": "^24.9.0", + "jest-util": "^24.9.0", + "micromatch": "^3.1.10", + "pirates": "^4.0.1", + "realpath-native": "^1.1.0", + "slash": "^2.0.0", + "source-map": "^0.6.1", + "write-file-atomic": "2.4.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "@jest/types": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-24.9.0.tgz", + "integrity": "sha512-XKK7ze1apu5JWQ5eZjHITP66AX+QsLlbaJRBGYr8pNzwcAE2JVkwnf0yqjHTsDRcjR0mujy/NmZMXw5kl+kGBw==", + "requires": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^1.1.1", + "@types/yargs": "^13.0.0" + } + }, + "@material-ui/core": { + "version": "4.8.3", + "resolved": "https://registry.npmjs.org/@material-ui/core/-/core-4.8.3.tgz", + "integrity": "sha512-ZJbfJQmkuZCSQTf0nzpfZwizmDdCq8ruZxnPNFnhoKDqgJpMvV8TJRi8vdI9ls1tMuTqxlhyhw8556fxOpWpFQ==", + "requires": { + "@babel/runtime": "^7.4.4", + "@material-ui/styles": "^4.8.2", + "@material-ui/system": "^4.7.1", + "@material-ui/types": "^4.1.1", + "@material-ui/utils": "^4.7.1", + "@types/react-transition-group": "^4.2.0", + "clsx": "^1.0.2", + "convert-css-length": "^2.0.1", + "hoist-non-react-statics": "^3.2.1", + "normalize-scroll-left": "^0.2.0", + "popper.js": "^1.14.1", + "prop-types": "^15.7.2", + "react-is": "^16.8.0", + "react-transition-group": "^4.3.0" + }, + "dependencies": { + "dom-helpers": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-5.1.3.tgz", + "integrity": "sha512-nZD1OtwfWGRBWlpANxacBEZrEuLa16o1nh7YopFWeoF68Zt8GGEmzHu6Xv4F3XaFIC+YXtTLrzgqKxFgLEe4jw==", + "requires": { + "@babel/runtime": "^7.6.3", + "csstype": "^2.6.7" + } + }, + "hoist-non-react-statics": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.1.tgz", + "integrity": "sha512-wbg3bpgA/ZqWrZuMOeJi8+SKMhr7X9TesL/rXMjTzh0p0JUBo3II8DHboYbuIXWRlttrUFxwcu/5kygrCw8fJw==", + "requires": { + "react-is": "^16.7.0" + } + }, + "react-transition-group": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.3.0.tgz", + "integrity": "sha512-1qRV1ZuVSdxPlPf4O8t7inxUGpdyO5zG9IoNfJxSO0ImU2A1YWkEQvFPuIPZmMLkg5hYs7vv5mMOyfgSkvAwvw==", + "requires": { + "@babel/runtime": "^7.5.5", + "dom-helpers": "^5.0.1", + "loose-envify": "^1.4.0", + "prop-types": "^15.6.2" + } + } + } + }, + "@material-ui/icons": { + "version": "4.5.1", + "resolved": "https://registry.npmjs.org/@material-ui/icons/-/icons-4.5.1.tgz", + "integrity": "sha512-YZ/BgJbXX4a0gOuKWb30mBaHaoXRqPanlePam83JQPZ/y4kl+3aW0Wv9tlR70hB5EGAkEJGW5m4ktJwMgxQAeA==", + "requires": { + "@babel/runtime": "^7.4.4" + } + }, + "@material-ui/styles": { + "version": "4.8.2", + "resolved": "https://registry.npmjs.org/@material-ui/styles/-/styles-4.8.2.tgz", + "integrity": "sha512-r5U+93pkpwQOmHTmwyn2sqTio6PHd873xvSHiKP6fdybAXXX6CZgVvh3W8saZNbYr/QXsS8OHmFv7sYJLt5Yfg==", + "requires": { + "@babel/runtime": "^7.4.4", + "@emotion/hash": "^0.7.4", + "@material-ui/types": "^4.1.1", + "@material-ui/utils": "^4.7.1", + "clsx": "^1.0.2", + "csstype": "^2.5.2", + "hoist-non-react-statics": "^3.2.1", + "jss": "^10.0.0", + "jss-plugin-camel-case": "^10.0.0", + "jss-plugin-default-unit": "^10.0.0", + "jss-plugin-global": "^10.0.0", + "jss-plugin-nested": "^10.0.0", + "jss-plugin-props-sort": "^10.0.0", + "jss-plugin-rule-value-function": "^10.0.0", + "jss-plugin-vendor-prefixer": "^10.0.0", + "prop-types": "^15.7.2" + }, + "dependencies": { + "hoist-non-react-statics": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.1.tgz", + "integrity": "sha512-wbg3bpgA/ZqWrZuMOeJi8+SKMhr7X9TesL/rXMjTzh0p0JUBo3II8DHboYbuIXWRlttrUFxwcu/5kygrCw8fJw==", + "requires": { + "react-is": "^16.7.0" + } + } + } + }, + "@material-ui/system": { + "version": "4.7.1", + "resolved": "https://registry.npmjs.org/@material-ui/system/-/system-4.7.1.tgz", + "integrity": "sha512-zH02p+FOimXLSKOW/OT2laYkl9bB3dD1AvnZqsHYoseUaq0aVrpbl2BGjQi+vJ5lg8w73uYlt9zOWzb3+1UdMQ==", + "requires": { + "@babel/runtime": "^7.4.4", + "@material-ui/utils": "^4.7.1", + "prop-types": "^15.7.2" + } + }, + "@material-ui/types": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/@material-ui/types/-/types-4.1.1.tgz", + "integrity": "sha512-AN+GZNXytX9yxGi0JOfxHrRTbhFybjUJ05rnsBVjcB+16e466Z0Xe5IxawuOayVZgTBNDxmPKo5j4V6OnMtaSQ==", + "requires": { + "@types/react": "*" + } + }, + "@material-ui/utils": { + "version": "4.7.1", + "resolved": "https://registry.npmjs.org/@material-ui/utils/-/utils-4.7.1.tgz", + "integrity": "sha512-+ux0SlLdlehvzCk2zdQ3KiS3/ylWvuo/JwAGhvb8dFVvwR21K28z0PU9OQW2PGogrMEdvX3miEI5tGxTwwWiwQ==", + "requires": { + "@babel/runtime": "^7.4.4", + "prop-types": "^15.7.2", + "react-is": "^16.8.0" + } + }, + "@mrmlnc/readdir-enhanced": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz", + "integrity": "sha512-bPHp6Ji8b41szTOcaP63VlnbbO5Ny6dwAATtY6JTjh5N2OLrb5Qk/Th5cRkRQhkWCt+EJsYrNB0MiL+Gpn6e3g==", + "requires": { + "call-me-maybe": "^1.0.1", + "glob-to-regexp": "^0.3.0" + } + }, + "@nodelib/fs.stat": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz", + "integrity": "sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw==" + }, + "@sheerun/mutationobserver-shim": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@sheerun/mutationobserver-shim/-/mutationobserver-shim-0.3.2.tgz", + "integrity": "sha512-vTCdPp/T/Q3oSqwHmZ5Kpa9oI7iLtGl3RQaA/NyLHikvcrPxACkkKVr/XzkSPJWXHRhKGzVvb0urJsbMlRxi1Q==" + }, + "@svgr/babel-plugin-add-jsx-attribute": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-4.2.0.tgz", + "integrity": "sha512-j7KnilGyZzYr/jhcrSYS3FGWMZVaqyCG0vzMCwzvei0coIkczuYMcniK07nI0aHJINciujjH11T72ICW5eL5Ig==" + }, + "@svgr/babel-plugin-remove-jsx-attribute": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-attribute/-/babel-plugin-remove-jsx-attribute-4.2.0.tgz", + "integrity": "sha512-3XHLtJ+HbRCH4n28S7y/yZoEQnRpl0tvTZQsHqvaeNXPra+6vE5tbRliH3ox1yZYPCxrlqaJT/Mg+75GpDKlvQ==" + }, + "@svgr/babel-plugin-remove-jsx-empty-expression": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-empty-expression/-/babel-plugin-remove-jsx-empty-expression-4.2.0.tgz", + "integrity": "sha512-yTr2iLdf6oEuUE9MsRdvt0NmdpMBAkgK8Bjhl6epb+eQWk6abBaX3d65UZ3E3FWaOwePyUgNyNCMVG61gGCQ7w==" + }, + "@svgr/babel-plugin-replace-jsx-attribute-value": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-replace-jsx-attribute-value/-/babel-plugin-replace-jsx-attribute-value-4.2.0.tgz", + "integrity": "sha512-U9m870Kqm0ko8beHawRXLGLvSi/ZMrl89gJ5BNcT452fAjtF2p4uRzXkdzvGJJJYBgx7BmqlDjBN/eCp5AAX2w==" + }, + "@svgr/babel-plugin-svg-dynamic-title": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-dynamic-title/-/babel-plugin-svg-dynamic-title-4.3.3.tgz", + "integrity": "sha512-w3Be6xUNdwgParsvxkkeZb545VhXEwjGMwExMVBIdPQJeyMQHqm9Msnb2a1teHBqUYL66qtwfhNkbj1iarCG7w==" + }, + "@svgr/babel-plugin-svg-em-dimensions": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-em-dimensions/-/babel-plugin-svg-em-dimensions-4.2.0.tgz", + "integrity": "sha512-C0Uy+BHolCHGOZ8Dnr1zXy/KgpBOkEUYY9kI/HseHVPeMbluaX3CijJr7D4C5uR8zrc1T64nnq/k63ydQuGt4w==" + }, + "@svgr/babel-plugin-transform-react-native-svg": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-react-native-svg/-/babel-plugin-transform-react-native-svg-4.2.0.tgz", + "integrity": "sha512-7YvynOpZDpCOUoIVlaaOUU87J4Z6RdD6spYN4eUb5tfPoKGSF9OG2NuhgYnq4jSkAxcpMaXWPf1cePkzmqTPNw==" + }, + "@svgr/babel-plugin-transform-svg-component": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-svg-component/-/babel-plugin-transform-svg-component-4.2.0.tgz", + "integrity": "sha512-hYfYuZhQPCBVotABsXKSCfel2slf/yvJY8heTVX1PCTaq/IgASq1IyxPPKJ0chWREEKewIU/JMSsIGBtK1KKxw==" + }, + "@svgr/babel-preset": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/babel-preset/-/babel-preset-4.3.3.tgz", + "integrity": "sha512-6PG80tdz4eAlYUN3g5GZiUjg2FMcp+Wn6rtnz5WJG9ITGEF1pmFdzq02597Hn0OmnQuCVaBYQE1OVFAnwOl+0A==", + "requires": { + "@svgr/babel-plugin-add-jsx-attribute": "^4.2.0", + "@svgr/babel-plugin-remove-jsx-attribute": "^4.2.0", + "@svgr/babel-plugin-remove-jsx-empty-expression": "^4.2.0", + "@svgr/babel-plugin-replace-jsx-attribute-value": "^4.2.0", + "@svgr/babel-plugin-svg-dynamic-title": "^4.3.3", + "@svgr/babel-plugin-svg-em-dimensions": "^4.2.0", + "@svgr/babel-plugin-transform-react-native-svg": "^4.2.0", + "@svgr/babel-plugin-transform-svg-component": "^4.2.0" + } + }, + "@svgr/core": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/core/-/core-4.3.3.tgz", + "integrity": "sha512-qNuGF1QON1626UCaZamWt5yedpgOytvLj5BQZe2j1k1B8DUG4OyugZyfEwBeXozCUwhLEpsrgPrE+eCu4fY17w==", + "requires": { + "@svgr/plugin-jsx": "^4.3.3", + "camelcase": "^5.3.1", + "cosmiconfig": "^5.2.1" + } + }, + "@svgr/hast-util-to-babel-ast": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/@svgr/hast-util-to-babel-ast/-/hast-util-to-babel-ast-4.3.2.tgz", + "integrity": "sha512-JioXclZGhFIDL3ddn4Kiq8qEqYM2PyDKV0aYno8+IXTLuYt6TOgHUbUAAFvqtb0Xn37NwP0BTHglejFoYr8RZg==", + "requires": { + "@babel/types": "^7.4.4" + } + }, + "@svgr/plugin-jsx": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/plugin-jsx/-/plugin-jsx-4.3.3.tgz", + "integrity": "sha512-cLOCSpNWQnDB1/v+SUENHH7a0XY09bfuMKdq9+gYvtuwzC2rU4I0wKGFEp1i24holdQdwodCtDQdFtJiTCWc+w==", + "requires": { + "@babel/core": "^7.4.5", + "@svgr/babel-preset": "^4.3.3", + "@svgr/hast-util-to-babel-ast": "^4.3.2", + "svg-parser": "^2.0.0" + } + }, + "@svgr/plugin-svgo": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/@svgr/plugin-svgo/-/plugin-svgo-4.3.1.tgz", + "integrity": "sha512-PrMtEDUWjX3Ea65JsVCwTIXuSqa3CG9px+DluF1/eo9mlDrgrtFE7NE/DjdhjJgSM9wenlVBzkzneSIUgfUI/w==", + "requires": { + "cosmiconfig": "^5.2.1", + "merge-deep": "^3.0.2", + "svgo": "^1.2.2" + } + }, + "@svgr/webpack": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/webpack/-/webpack-4.3.3.tgz", + "integrity": "sha512-bjnWolZ6KVsHhgyCoYRFmbd26p8XVbulCzSG53BDQqAr+JOAderYK7CuYrB3bDjHJuF6LJ7Wrr42+goLRV9qIg==", + "requires": { + "@babel/core": "^7.4.5", + "@babel/plugin-transform-react-constant-elements": "^7.0.0", + "@babel/preset-env": "^7.4.5", + "@babel/preset-react": "^7.0.0", + "@svgr/core": "^4.3.3", + "@svgr/plugin-jsx": "^4.3.3", + "@svgr/plugin-svgo": "^4.3.1", + "loader-utils": "^1.2.3" + } + }, + "@testing-library/dom": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@testing-library/dom/-/dom-6.11.0.tgz", + "integrity": "sha512-Pkx9LMIGshyNbfmecjt18rrAp/ayMqGH674jYER0SXj0iG9xZc+zWRjk2Pg9JgPBDvwI//xGrI/oOQkAi4YEew==", + "requires": { + "@babel/runtime": "^7.6.2", + "@sheerun/mutationobserver-shim": "^0.3.2", + "@types/testing-library__dom": "^6.0.0", + "aria-query": "3.0.0", + "pretty-format": "^24.9.0", + "wait-for-expect": "^3.0.0" + } + }, + "@testing-library/jest-dom": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-4.2.4.tgz", + "integrity": "sha512-j31Bn0rQo12fhCWOUWy9fl7wtqkp7In/YP2p5ZFyRuiiB9Qs3g+hS4gAmDWONbAHcRmVooNJ5eOHQDCOmUFXHg==", + "requires": { + "@babel/runtime": "^7.5.1", + "chalk": "^2.4.1", + "css": "^2.2.3", + "css.escape": "^1.5.1", + "jest-diff": "^24.0.0", + "jest-matcher-utils": "^24.0.0", + "lodash": "^4.17.11", + "pretty-format": "^24.0.0", + "redent": "^3.0.0" + } + }, + "@testing-library/react": { + "version": "9.4.0", + "resolved": "https://registry.npmjs.org/@testing-library/react/-/react-9.4.0.tgz", + "integrity": "sha512-XdhDWkI4GktUPsz0AYyeQ8M9qS/JFie06kcSnUVcpgOwFjAu9vhwR83qBl+lw9yZWkbECjL8Hd+n5hH6C0oWqg==", + "requires": { + "@babel/runtime": "^7.7.6", + "@testing-library/dom": "^6.11.0", + "@types/testing-library__react": "^9.1.2" + }, + "dependencies": { + "@babel/runtime": { + "version": "7.8.0", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.8.0.tgz", + "integrity": "sha512-Z7ti+HB0puCcLmFE3x90kzaVgbx6TRrYIReaygW6EkBEnJh1ajS4/inhF7CypzWeDV3NFl1AfWj0eMtdihojxw==", + "requires": { + "regenerator-runtime": "^0.13.2" + } + } + } + }, + "@testing-library/user-event": { + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/@testing-library/user-event/-/user-event-7.2.1.tgz", + "integrity": "sha512-oZ0Ib5I4Z2pUEcoo95cT1cr6slco9WY7yiPpG+RGNkj8YcYgJnM7pXmYmorNOReh8MIGcKSqXyeGjxnr8YiZbA==" + }, + "@types/babel__core": { + "version": "7.1.3", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.3.tgz", + "integrity": "sha512-8fBo0UR2CcwWxeX7WIIgJ7lXjasFxoYgRnFHUj+hRvKkpiBJbxhdAPTCY6/ZKM0uxANFVzt4yObSLuTiTnazDA==", + "requires": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0", + "@types/babel__generator": "*", + "@types/babel__template": "*", + "@types/babel__traverse": "*" + } + }, + "@types/babel__generator": { + "version": "7.6.1", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.1.tgz", + "integrity": "sha512-bBKm+2VPJcMRVwNhxKu8W+5/zT7pwNEqeokFOmbvVSqGzFneNxYcEBro9Ac7/N9tlsaPYnZLK8J1LWKkMsLAew==", + "requires": { + "@babel/types": "^7.0.0" + } + }, + "@types/babel__template": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.0.2.tgz", + "integrity": "sha512-/K6zCpeW7Imzgab2bLkLEbz0+1JlFSrUMdw7KoIIu+IUdu51GWaBZpd3y1VXGVXzynvGa4DaIaxNZHiON3GXUg==", + "requires": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0" + } + }, + "@types/babel__traverse": { + "version": "7.0.8", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.0.8.tgz", + "integrity": "sha512-yGeB2dHEdvxjP0y4UbRtQaSkXJ9649fYCmIdRoul5kfAoGCwxuCbMhag0k3RPfnuh9kPGm8x89btcfDEXdVWGw==", + "requires": { + "@babel/types": "^7.3.0" + } + }, + "@types/eslint-visitor-keys": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", + "integrity": "sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag==" + }, + "@types/events": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.0.tgz", + "integrity": "sha512-EaObqwIvayI5a8dCzhFrjKzVwKLxjoG9T6Ppd5CEo07LRKfQ8Yokw54r5+Wq7FaBQ+yXRvQAYPrHwya1/UFt9g==" + }, + "@types/glob": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.1.tgz", + "integrity": "sha512-1Bh06cbWJUHMC97acuD6UMG29nMt0Aqz1vF3guLfG+kHHJhy3AyohZFFxYk2f7Q1SQIrNwvncxAE0N/9s70F2w==", + "requires": { + "@types/events": "*", + "@types/minimatch": "*", + "@types/node": "*" + } + }, + "@types/istanbul-lib-coverage": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.1.tgz", + "integrity": "sha512-hRJD2ahnnpLgsj6KWMYSrmXkM3rm2Dl1qkx6IOFD5FnuNPXJIG5L0dhgKXCYTRMGzU4n0wImQ/xfmRc4POUFlg==" + }, + "@types/istanbul-lib-report": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-1.1.1.tgz", + "integrity": "sha512-3BUTyMzbZa2DtDI2BkERNC6jJw2Mr2Y0oGI7mRxYNBPxppbtEK1F66u3bKwU2g+wxwWI7PAoRpJnOY1grJqzHg==", + "requires": { + "@types/istanbul-lib-coverage": "*" + } + }, + "@types/istanbul-reports": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-1.1.1.tgz", + "integrity": "sha512-UpYjBi8xefVChsCoBpKShdxTllC9pwISirfoZsUa2AAdQg/Jd2KQGtSbw+ya7GPo7x/wAPlH6JBhKhAsXUEZNA==", + "requires": { + "@types/istanbul-lib-coverage": "*", + "@types/istanbul-lib-report": "*" + } + }, + "@types/json-schema": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.4.tgz", + "integrity": "sha512-8+KAKzEvSUdeo+kmqnKrqgeE+LcA0tjYWFY7RPProVYwnqDjukzO+3b6dLD56rYX5TdWejnEOLJYOIeh4CXKuA==" + }, + "@types/minimatch": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", + "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==" + }, + "@types/node": { + "version": "13.1.6", + "resolved": "https://registry.npmjs.org/@types/node/-/node-13.1.6.tgz", + "integrity": "sha512-Jg1F+bmxcpENHP23sVKkNuU3uaxPnsBMW0cLjleiikFKomJQbsn0Cqk2yDvQArqzZN6ABfBkZ0To7pQ8sLdWDg==" + }, + "@types/parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==" + }, + "@types/prop-types": { + "version": "15.7.3", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.3.tgz", + "integrity": "sha512-KfRL3PuHmqQLOG+2tGpRO26Ctg+Cq1E01D2DMriKEATHgWLfeNDmq9e29Q9WIky0dQ3NPkd1mzYH8Lm936Z9qw==" + }, + "@types/q": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.5.2.tgz", + "integrity": "sha512-ce5d3q03Ex0sy4R14722Rmt6MT07Ua+k4FwDfdcToYJcMKNtRVQvJ6JCAPdAmAnbRb6CsX6aYb9m96NGod9uTw==" + }, + "@types/react": { + "version": "16.9.17", + "resolved": "https://registry.npmjs.org/@types/react/-/react-16.9.17.tgz", + "integrity": "sha512-UP27In4fp4sWF5JgyV6pwVPAQM83Fj76JOcg02X5BZcpSu5Wx+fP9RMqc2v0ssBoQIFvD5JdKY41gjJJKmw6Bg==", + "requires": { + "@types/prop-types": "*", + "csstype": "^2.2.0" + } + }, + "@types/react-dom": { + "version": "16.9.4", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-16.9.4.tgz", + "integrity": "sha512-fya9xteU/n90tda0s+FtN5Ym4tbgxpq/hb/Af24dvs6uYnYn+fspaxw5USlw0R8apDNwxsqumdRoCoKitckQqw==", + "requires": { + "@types/react": "*" + } + }, + "@types/react-transition-group": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.2.3.tgz", + "integrity": "sha512-Hk8jiuT7iLOHrcjKP/ZVSyCNXK73wJAUz60xm0mVhiRujrdiI++j4duLiL282VGxwAgxetHQFfqA29LgEeSkFA==", + "requires": { + "@types/react": "*" + } + }, + "@types/stack-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-1.0.1.tgz", + "integrity": "sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw==" + }, + "@types/testing-library__dom": { + "version": "6.11.1", + "resolved": "https://registry.npmjs.org/@types/testing-library__dom/-/testing-library__dom-6.11.1.tgz", + "integrity": "sha512-ImChHtQqmjwraRLqBC2sgSQFtczeFvBmBcfhTYZn/3KwXbyD07LQykEQ0xJo7QHc1GbVvf7pRyGaIe6PkCdxEw==", + "requires": { + "pretty-format": "^24.3.0" + } + }, + "@types/testing-library__react": { + "version": "9.1.2", + "resolved": "https://registry.npmjs.org/@types/testing-library__react/-/testing-library__react-9.1.2.tgz", + "integrity": "sha512-CYaMqrswQ+cJACy268jsLAw355DZtPZGt3Jwmmotlcu8O/tkoXBI6AeZ84oZBJsIsesozPKzWzmv/0TIU+1E9Q==", + "requires": { + "@types/react-dom": "*", + "@types/testing-library__dom": "*" + } + }, + "@types/yargs": { + "version": "13.0.5", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-13.0.5.tgz", + "integrity": "sha512-CF/+sxTO7FOwbIRL4wMv0ZYLCRfMid2HQpzDRyViH7kSpfoAFiMdGqKIxb1PxWfjtQXQhnQuD33lvRHNwr809Q==", + "requires": { + "@types/yargs-parser": "*" + } + }, + "@types/yargs-parser": { + "version": "13.1.0", + "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-13.1.0.tgz", + "integrity": "sha512-gCubfBUZ6KxzoibJ+SCUc/57Ms1jz5NjHe4+dI2krNmU5zCPAphyLJYyTOg06ueIyfj+SaCUqmzun7ImlxDcKg==" + }, + "@typescript-eslint/eslint-plugin": { + "version": "2.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.15.0.tgz", + "integrity": "sha512-XRJFznI5v4K1WvIrWmjFjBAdQWaUTz4xJEdqR7+wAFsv6Q9dP3mOlE6BMNT3pdlp9eF1+bC5m5LZTmLMqffCVw==", + "requires": { + "@typescript-eslint/experimental-utils": "2.15.0", + "eslint-utils": "^1.4.3", + "functional-red-black-tree": "^1.0.1", + "regexpp": "^3.0.0", + "tsutils": "^3.17.1" + } + }, + "@typescript-eslint/experimental-utils": { + "version": "2.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-2.15.0.tgz", + "integrity": "sha512-Qkxu5zndY5hqlcQkmA88gfLvqQulMpX/TN91XC7OuXsRf4XG5xLGie0sbpX97o/oeccjeZYRMipIsjKk/tjDHA==", + "requires": { + "@types/json-schema": "^7.0.3", + "@typescript-eslint/typescript-estree": "2.15.0", + "eslint-scope": "^5.0.0" + } + }, + "@typescript-eslint/parser": { + "version": "2.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-2.15.0.tgz", + "integrity": "sha512-6iSgQsqAYTaHw59t0tdjzZJluRAjswdGltzKEdLtcJOxR2UVTPHYvZRqkAVGCkaMVb6Fpa60NnuozNCvsSpA9g==", + "requires": { + "@types/eslint-visitor-keys": "^1.0.0", + "@typescript-eslint/experimental-utils": "2.15.0", + "@typescript-eslint/typescript-estree": "2.15.0", + "eslint-visitor-keys": "^1.1.0" + } + }, + "@typescript-eslint/typescript-estree": { + "version": "2.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-2.15.0.tgz", + "integrity": "sha512-L6Pog+w3VZzXkAdyqA0VlwybF8WcwZX+mufso86CMxSdWmcizJ38lgBdpqTbc9bo92iyi0rOvmATKiwl+amjxg==", + "requires": { + "debug": "^4.1.1", + "eslint-visitor-keys": "^1.1.0", + "glob": "^7.1.6", + "is-glob": "^4.0.1", + "lodash.unescape": "4.0.1", + "semver": "^6.3.0", + "tsutils": "^3.17.1" + } + }, + "@webassemblyjs/ast": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.8.5.tgz", + "integrity": "sha512-aJMfngIZ65+t71C3y2nBBg5FFG0Okt9m0XEgWZ7Ywgn1oMAT8cNwx00Uv1cQyHtidq0Xn94R4TAywO+LCQ+ZAQ==", + "requires": { + "@webassemblyjs/helper-module-context": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/wast-parser": "1.8.5" + } + }, + "@webassemblyjs/floating-point-hex-parser": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.8.5.tgz", + "integrity": "sha512-9p+79WHru1oqBh9ewP9zW95E3XAo+90oth7S5Re3eQnECGq59ly1Ri5tsIipKGpiStHsUYmY3zMLqtk3gTcOtQ==" + }, + "@webassemblyjs/helper-api-error": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.8.5.tgz", + "integrity": "sha512-Za/tnzsvnqdaSPOUXHyKJ2XI7PDX64kWtURyGiJJZKVEdFOsdKUCPTNEVFZq3zJ2R0G5wc2PZ5gvdTRFgm81zA==" + }, + "@webassemblyjs/helper-buffer": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.8.5.tgz", + "integrity": "sha512-Ri2R8nOS0U6G49Q86goFIPNgjyl6+oE1abW1pS84BuhP1Qcr5JqMwRFT3Ah3ADDDYGEgGs1iyb1DGX+kAi/c/Q==" + }, + "@webassemblyjs/helper-code-frame": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.8.5.tgz", + "integrity": "sha512-VQAadSubZIhNpH46IR3yWO4kZZjMxN1opDrzePLdVKAZ+DFjkGD/rf4v1jap744uPVU6yjL/smZbRIIJTOUnKQ==", + "requires": { + "@webassemblyjs/wast-printer": "1.8.5" + } + }, + "@webassemblyjs/helper-fsm": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.8.5.tgz", + "integrity": "sha512-kRuX/saORcg8se/ft6Q2UbRpZwP4y7YrWsLXPbbmtepKr22i8Z4O3V5QE9DbZK908dh5Xya4Un57SDIKwB9eow==" + }, + "@webassemblyjs/helper-module-context": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-module-context/-/helper-module-context-1.8.5.tgz", + "integrity": "sha512-/O1B236mN7UNEU4t9X7Pj38i4VoU8CcMHyy3l2cV/kIF4U5KoHXDVqcDuOs1ltkac90IM4vZdHc52t1x8Yfs3g==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "mamacro": "^0.0.3" + } + }, + "@webassemblyjs/helper-wasm-bytecode": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.8.5.tgz", + "integrity": "sha512-Cu4YMYG3Ddl72CbmpjU/wbP6SACcOPVbHN1dI4VJNJVgFwaKf1ppeFJrwydOG3NDHxVGuCfPlLZNyEdIYlQ6QQ==" + }, + "@webassemblyjs/helper-wasm-section": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.8.5.tgz", + "integrity": "sha512-VV083zwR+VTrIWWtgIUpqfvVdK4ff38loRmrdDBgBT8ADXYsEZ5mPQ4Nde90N3UYatHdYoDIFb7oHzMncI02tA==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5" + } + }, + "@webassemblyjs/ieee754": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.8.5.tgz", + "integrity": "sha512-aaCvQYrvKbY/n6wKHb/ylAJr27GglahUO89CcGXMItrOBqRarUMxWLJgxm9PJNuKULwN5n1csT9bYoMeZOGF3g==", + "requires": { + "@xtuc/ieee754": "^1.2.0" + } + }, + "@webassemblyjs/leb128": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.8.5.tgz", + "integrity": "sha512-plYUuUwleLIziknvlP8VpTgO4kqNaH57Y3JnNa6DLpu/sGcP6hbVdfdX5aHAV716pQBKrfuU26BJK29qY37J7A==", + "requires": { + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/utf8": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.8.5.tgz", + "integrity": "sha512-U7zgftmQriw37tfD934UNInokz6yTmn29inT2cAetAsaU9YeVCveWEwhKL1Mg4yS7q//NGdzy79nlXh3bT8Kjw==" + }, + "@webassemblyjs/wasm-edit": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.8.5.tgz", + "integrity": "sha512-A41EMy8MWw5yvqj7MQzkDjU29K7UJq1VrX2vWLzfpRHt3ISftOXqrtojn7nlPsZ9Ijhp5NwuODuycSvfAO/26Q==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/helper-wasm-section": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5", + "@webassemblyjs/wasm-opt": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5", + "@webassemblyjs/wast-printer": "1.8.5" + } + }, + "@webassemblyjs/wasm-gen": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.8.5.tgz", + "integrity": "sha512-BCZBT0LURC0CXDzj5FXSc2FPTsxwp3nWcqXQdOZE4U7h7i8FqtFK5Egia6f9raQLpEKT1VL7zr4r3+QX6zArWg==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/ieee754": "1.8.5", + "@webassemblyjs/leb128": "1.8.5", + "@webassemblyjs/utf8": "1.8.5" + } + }, + "@webassemblyjs/wasm-opt": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.8.5.tgz", + "integrity": "sha512-HKo2mO/Uh9A6ojzu7cjslGaHaUU14LdLbGEKqTR7PBKwT6LdPtLLh9fPY33rmr5wcOMrsWDbbdCHq4hQUdd37Q==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5" + } + }, + "@webassemblyjs/wasm-parser": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.8.5.tgz", + "integrity": "sha512-pi0SYE9T6tfcMkthwcgCpL0cM9nRYr6/6fjgDtL6q/ZqKHdMWvxitRi5JcZ7RI4SNJJYnYNaWy5UUrHQy998lw==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-api-error": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/ieee754": "1.8.5", + "@webassemblyjs/leb128": "1.8.5", + "@webassemblyjs/utf8": "1.8.5" + } + }, + "@webassemblyjs/wast-parser": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.8.5.tgz", + "integrity": "sha512-daXC1FyKWHF1i11obK086QRlsMsY4+tIOKgBqI1lxAnkp9xe9YMcgOxm9kLe+ttjs5aWV2KKE1TWJCN57/Btsg==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/floating-point-hex-parser": "1.8.5", + "@webassemblyjs/helper-api-error": "1.8.5", + "@webassemblyjs/helper-code-frame": "1.8.5", + "@webassemblyjs/helper-fsm": "1.8.5", + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/wast-printer": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.8.5.tgz", + "integrity": "sha512-w0U0pD4EhlnvRyeJzBqaVSJAo9w/ce7/WPogeXLzGkO6hzhr4GnQIZ4W4uUt5b9ooAaXPtnXlj0gzsXEOUNYMg==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/wast-parser": "1.8.5", + "@xtuc/long": "4.2.2" + } + }, + "@xtuc/ieee754": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", + "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==" + }, + "@xtuc/long": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==" + }, + "abab": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.3.tgz", + "integrity": "sha512-tsFzPpcttalNjFBCFMqsKYQcWxxen1pgJR56by//QwvJc4/OUS3kPOOttx2tSIfjsylB0pYu7f5D3K1RCxUnUg==" + }, + "accepts": { + "version": "1.3.7", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", + "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", + "requires": { + "mime-types": "~2.1.24", + "negotiator": "0.6.2" + } + }, + "acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" + }, + "acorn-globals": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-4.3.4.tgz", + "integrity": "sha512-clfQEh21R+D0leSbUdWf3OcfqyaCSAQ8Ryq00bofSekfr9W8u1jyYZo6ir0xu9Gtcf7BjcHJpnbZH7JOCpP60A==", + "requires": { + "acorn": "^6.0.1", + "acorn-walk": "^6.0.1" + }, + "dependencies": { + "acorn": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.0.tgz", + "integrity": "sha512-gac8OEcQ2Li1dxIEWGZzsp2BitJxwkwcOm0zHAJLcPJaVvm58FRnk6RkuLRpU1EujipU2ZFODv2P9DLMfnV8mw==" + } + } + }, + "acorn-jsx": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.1.0.tgz", + "integrity": "sha512-tMUqwBWfLFbJbizRmEcWSLw6HnFzfdJs2sOJEOwwtVPMoH/0Ay+E703oZz78VSXZiiDcZrQ5XKjPIUQixhmgVw==" + }, + "acorn-walk": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-6.2.0.tgz", + "integrity": "sha512-7evsyfH1cLOCdAzZAd43Cic04yKydNx0cF+7tiA19p1XnLLPU4dpCQOqpjqwokFe//vS0QqfqqjCS2JkiIs0cA==" + }, + "address": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/address/-/address-1.1.2.tgz", + "integrity": "sha512-aT6camzM4xEA54YVJYSqxz1kv4IHnQZRtThJJHhUMRExaU5spC7jX5ugSwTaTgJliIgs4VhZOk7htClvQ/LmRA==" + }, + "adjust-sourcemap-loader": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/adjust-sourcemap-loader/-/adjust-sourcemap-loader-2.0.0.tgz", + "integrity": "sha512-4hFsTsn58+YjrU9qKzML2JSSDqKvN8mUGQ0nNIrfPi8hmIONT4L3uUaT6MKdMsZ9AjsU6D2xDkZxCkbQPxChrA==", + "requires": { + "assert": "1.4.1", + "camelcase": "5.0.0", + "loader-utils": "1.2.3", + "object-path": "0.11.4", + "regex-parser": "2.2.10" + }, + "dependencies": { + "camelcase": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.0.0.tgz", + "integrity": "sha512-faqwZqnWxbxn+F1d399ygeamQNy3lPp/H9H6rNrqYh4FSVCtcY+3cub1MxA8o9mDd55mM8Aghuu/kuyYA6VTsA==" + } + } + }, + "aggregate-error": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.0.1.tgz", + "integrity": "sha512-quoaXsZ9/BLNae5yiNoUz+Nhkwz83GhWwtYFglcjEQB2NDHCIpApbqXxIFnm4Pq/Nvhrsq5sYJFyohrrxnTGAA==", + "requires": { + "clean-stack": "^2.0.0", + "indent-string": "^4.0.0" + } + }, + "ajv": { + "version": "6.10.2", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", + "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", + "requires": { + "fast-deep-equal": "^2.0.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ajv-errors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/ajv-errors/-/ajv-errors-1.0.1.tgz", + "integrity": "sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ==" + }, + "ajv-keywords": { + "version": "3.4.1", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.4.1.tgz", + "integrity": "sha512-RO1ibKvd27e6FEShVFfPALuHI3WjSVNeK5FIsmme/LYRNxjKuNj+Dt7bucLa6NdSv3JcVTyMlm9kGR84z1XpaQ==" + }, + "alphanum-sort": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/alphanum-sort/-/alphanum-sort-1.0.2.tgz", + "integrity": "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=" + }, + "ansi-colors": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.4.tgz", + "integrity": "sha512-hHUXGagefjN2iRrID63xckIvotOXOojhQKWIPUZ4mNUZ9nLZW+7FMNoE1lOkEhNWYsx/7ysGIuJYCiMAA9FnrA==" + }, + "ansi-escapes": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.0.tgz", + "integrity": "sha512-EiYhwo0v255HUL6eDyuLrXEkTi7WwVCLAw+SeOQ7M7qdun1z1pum4DEm/nuqIVbPvi9RPPc9k9LbyBv6H0DwVg==", + "requires": { + "type-fest": "^0.8.1" + } + }, + "ansi-html": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/ansi-html/-/ansi-html-0.0.7.tgz", + "integrity": "sha1-gTWEAhliqenm/QOflA0S9WynhZ4=" + }, + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", + "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "requires": { + "color-convert": "^1.9.0" + } + }, + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "requires": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + } + }, + "aproba": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", + "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "aria-query": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-3.0.0.tgz", + "integrity": "sha1-ZbP8wcoRVajJrmTW7uKX8V1RM8w=", + "requires": { + "ast-types-flow": "0.0.7", + "commander": "^2.11.0" + } + }, + "arity-n": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/arity-n/-/arity-n-1.0.4.tgz", + "integrity": "sha1-2edrEXM+CFacCEeuezmyhgswt0U=" + }, + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=" + }, + "arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" + }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=" + }, + "array-equal": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.0.tgz", + "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=" + }, + "array-flatten": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.2.tgz", + "integrity": "sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==" + }, + "array-includes": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.1.tgz", + "integrity": "sha512-c2VXaCHl7zPsvpkFsw4nxvFie4fh1ur9bpcgsVkIjqn0H/Xwdg+7fv3n2r/isyS8EBj5b06M9kHyZuIr4El6WQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0", + "is-string": "^1.0.5" + } + }, + "array-union": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", + "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", + "requires": { + "array-uniq": "^1.0.1" + } + }, + "array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", + "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=" + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=" + }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=" + }, + "asap": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", + "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=" + }, + "asn1": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", + "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", + "requires": { + "safer-buffer": "~2.1.0" + } + }, + "asn1.js": { + "version": "4.10.1", + "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-4.10.1.tgz", + "integrity": "sha512-p32cOF5q0Zqs9uBiONKYLm6BClCoBCM5O9JfeUSlnQLBTxYdTK+pW+nXflm8UkKd2UYlEbYz5qEi0JuZR9ckSw==", + "requires": { + "bn.js": "^4.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "assert": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.4.1.tgz", + "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", + "requires": { + "util": "0.10.3" + } + }, + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=" + }, + "ast-types-flow": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.7.tgz", + "integrity": "sha1-9wtzXGvKGlycItmCw+Oef+ujva0=" + }, + "astral-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", + "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==" + }, + "async": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.3.tgz", + "integrity": "sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg==", + "requires": { + "lodash": "^4.17.14" + } + }, + "async-each": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz", + "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==" + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" + }, + "atob": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", + "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==" + }, + "autoprefixer": { + "version": "9.7.3", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-9.7.3.tgz", + "integrity": "sha512-8T5Y1C5Iyj6PgkPSFd0ODvK9DIleuPKUPYniNxybS47g2k2wFgLZ46lGQHlBuGKIAEV8fbCDfKCCRS1tvOgc3Q==", + "requires": { + "browserslist": "^4.8.0", + "caniuse-lite": "^1.0.30001012", + "chalk": "^2.4.2", + "normalize-range": "^0.1.2", + "num2fraction": "^1.2.2", + "postcss": "^7.0.23", + "postcss-value-parser": "^4.0.2" + } + }, + "aws-sign2": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", + "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" + }, + "aws4": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.0.tgz", + "integrity": "sha512-Uvq6hVe90D0B2WEnUqtdgY1bATGz3mw33nH9Y+dmA+w5DHvUmBgkr5rM/KCHpCsiFNRUfokW/szpPPgMK2hm4A==" + }, + "axobject-query": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-2.1.1.tgz", + "integrity": "sha512-lF98xa/yvy6j3fBHAgQXIYl+J4eZadOSqsPojemUqClzNbBV38wWGpUbQbVEyf4eUF5yF7eHmGgGA2JiHyjeqw==", + "requires": { + "@babel/runtime": "^7.7.4", + "@babel/runtime-corejs3": "^7.7.4" + } + }, + "babel-code-frame": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", + "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", + "requires": { + "chalk": "^1.1.3", + "esutils": "^2.0.2", + "js-tokens": "^3.0.2" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + }, + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=" + }, + "chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "requires": { + "ansi-styles": "^2.2.1", + "escape-string-regexp": "^1.0.2", + "has-ansi": "^2.0.0", + "strip-ansi": "^3.0.0", + "supports-color": "^2.0.0" + } + }, + "js-tokens": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", + "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=" + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=" + } + } + }, + "babel-eslint": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.0.3.tgz", + "integrity": "sha512-z3U7eMY6r/3f3/JB9mTsLjyxrv0Yb1zb8PCWCLpguxfCzBIZUwy23R1t/XKewP+8mEN2Ck8Dtr4q20z6ce6SoA==", + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.0.0", + "@babel/traverse": "^7.0.0", + "@babel/types": "^7.0.0", + "eslint-visitor-keys": "^1.0.0", + "resolve": "^1.12.0" + } + }, + "babel-extract-comments": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/babel-extract-comments/-/babel-extract-comments-1.0.0.tgz", + "integrity": "sha512-qWWzi4TlddohA91bFwgt6zO/J0X+io7Qp184Fw0m2JYRSTZnJbFR8+07KmzudHCZgOiKRCrjhylwv9Xd8gfhVQ==", + "requires": { + "babylon": "^6.18.0" + } + }, + "babel-jest": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-24.9.0.tgz", + "integrity": "sha512-ntuddfyiN+EhMw58PTNL1ph4C9rECiQXjI4nMMBKBaNjXvqLdkXpPRcMSr4iyBrJg/+wz9brFUD6RhOAT6r4Iw==", + "requires": { + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/babel__core": "^7.1.0", + "babel-plugin-istanbul": "^5.1.0", + "babel-preset-jest": "^24.9.0", + "chalk": "^2.4.2", + "slash": "^2.0.0" + } + }, + "babel-loader": { + "version": "8.0.6", + "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-8.0.6.tgz", + "integrity": "sha512-4BmWKtBOBm13uoUwd08UwjZlaw3O9GWf456R9j+5YykFZ6LUIjIKLc0zEZf+hauxPOJs96C8k6FvYD09vWzhYw==", + "requires": { + "find-cache-dir": "^2.0.0", + "loader-utils": "^1.0.2", + "mkdirp": "^0.5.1", + "pify": "^4.0.1" + }, + "dependencies": { + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==" + } + } + }, + "babel-plugin-dynamic-import-node": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.0.tgz", + "integrity": "sha512-o6qFkpeQEBxcqt0XYlWzAVxNCSCZdUgcR8IRlhD/8DylxjjO4foPcvTW0GGKa/cVt3rvxZ7o5ippJ+/0nvLhlQ==", + "requires": { + "object.assign": "^4.1.0" + } + }, + "babel-plugin-istanbul": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-5.2.0.tgz", + "integrity": "sha512-5LphC0USA8t4i1zCtjbbNb6jJj/9+X6P37Qfirc/70EQ34xKlMW+a1RHGwxGI+SwWpNwZ27HqvzAobeqaXwiZw==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "find-up": "^3.0.0", + "istanbul-lib-instrument": "^3.3.0", + "test-exclude": "^5.2.3" + } + }, + "babel-plugin-jest-hoist": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-24.9.0.tgz", + "integrity": "sha512-2EMA2P8Vp7lG0RAzr4HXqtYwacfMErOuv1U3wrvxHX6rD1sV6xS3WXG3r8TRQ2r6w8OhvSdWt+z41hQNwNm3Xw==", + "requires": { + "@types/babel__traverse": "^7.0.6" + } + }, + "babel-plugin-macros": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-2.7.1.tgz", + "integrity": "sha512-HNM284amlKSQ6FddI4jLXD+XTqF0cTYOe5uemOIZxHJHnamC+OhFQ57rMF9sgnYhkJQptVl9U1SKVZsV9/GLQQ==", + "requires": { + "@babel/runtime": "^7.7.2", + "cosmiconfig": "^6.0.0", + "resolve": "^1.12.0" + }, + "dependencies": { + "cosmiconfig": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-6.0.0.tgz", + "integrity": "sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg==", + "requires": { + "@types/parse-json": "^4.0.0", + "import-fresh": "^3.1.0", + "parse-json": "^5.0.0", + "path-type": "^4.0.0", + "yaml": "^1.7.2" + } + }, + "import-fresh": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", + "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "parse-json": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.0.0.tgz", + "integrity": "sha512-OOY5b7PAEFV0E2Fir1KOkxchnZNCdowAJgQ5NuxjpBKTRP3pQhwkrkxqQjeoKJ+fO7bCpmIZaogI4eZGDMEGOw==", + "requires": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1", + "lines-and-columns": "^1.1.6" + } + }, + "path-type": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==" + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" + } + } + }, + "babel-plugin-named-asset-import": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/babel-plugin-named-asset-import/-/babel-plugin-named-asset-import-0.3.5.tgz", + "integrity": "sha512-sGhfINU+AuMw9oFAdIn/nD5sem3pn/WgxAfDZ//Q3CnF+5uaho7C7shh2rKLk6sKE/XkfmyibghocwKdVjLIKg==" + }, + "babel-plugin-syntax-object-rest-spread": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", + "integrity": "sha1-/WU28rzhODb/o6VFjEkDpZe7O/U=" + }, + "babel-plugin-transform-object-rest-spread": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.26.0.tgz", + "integrity": "sha1-DzZpLVD+9rfi1LOsFHgTepY7ewY=", + "requires": { + "babel-plugin-syntax-object-rest-spread": "^6.8.0", + "babel-runtime": "^6.26.0" + } + }, + "babel-plugin-transform-react-remove-prop-types": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-remove-prop-types/-/babel-plugin-transform-react-remove-prop-types-0.4.24.tgz", + "integrity": "sha512-eqj0hVcJUR57/Ug2zE1Yswsw4LhuqqHhD+8v120T1cl3kjg76QwtyBrdIk4WVwK+lAhBJVYCd/v+4nc4y+8JsA==" + }, + "babel-preset-jest": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-24.9.0.tgz", + "integrity": "sha512-izTUuhE4TMfTRPF92fFwD2QfdXaZW08qvWTFCI51V8rW5x00UuPgc3ajRoWofXOuxjfcOM5zzSYsQS3H8KGCAg==", + "requires": { + "@babel/plugin-syntax-object-rest-spread": "^7.0.0", + "babel-plugin-jest-hoist": "^24.9.0" + } + }, + "babel-preset-react-app": { + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/babel-preset-react-app/-/babel-preset-react-app-9.1.0.tgz", + "integrity": "sha512-0qMOv/pCcCQWxX1eNyKD9GlzZTdzZIK/Pq3O6TGe65tZSJTSplw1pFlaPujm0GjBj4g3GeCQbP08vvzlH7OGHg==", + "requires": { + "@babel/core": "7.7.4", + "@babel/plugin-proposal-class-properties": "7.7.4", + "@babel/plugin-proposal-decorators": "7.7.4", + "@babel/plugin-proposal-nullish-coalescing-operator": "7.7.4", + "@babel/plugin-proposal-numeric-separator": "7.7.4", + "@babel/plugin-proposal-object-rest-spread": "7.7.4", + "@babel/plugin-proposal-optional-chaining": "7.7.4", + "@babel/plugin-syntax-dynamic-import": "7.7.4", + "@babel/plugin-transform-destructuring": "7.7.4", + "@babel/plugin-transform-flow-strip-types": "7.7.4", + "@babel/plugin-transform-react-display-name": "7.7.4", + "@babel/plugin-transform-runtime": "7.7.4", + "@babel/preset-env": "7.7.4", + "@babel/preset-react": "7.7.4", + "@babel/preset-typescript": "7.7.4", + "@babel/runtime": "7.7.4", + "babel-plugin-dynamic-import-node": "2.3.0", + "babel-plugin-macros": "2.7.1", + "babel-plugin-transform-react-remove-prop-types": "0.4.24" + }, + "dependencies": { + "@babel/plugin-proposal-nullish-coalescing-operator": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.7.4.tgz", + "integrity": "sha512-TbYHmr1Gl1UC7Vo2HVuj/Naci5BEGNZ0AJhzqD2Vpr6QPFWpUmBRLrIDjedzx7/CShq0bRDS2gI4FIs77VHLVQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.7.4" + } + }, + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.7.4.tgz", + "integrity": "sha512-rnpnZR3/iWKmiQyJ3LKJpSwLDcX/nSXhdLk4Aq/tXOApIvyu7qoabrige0ylsAJffaUC51WiBu209Q0U+86OWQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-object-rest-spread": "^7.7.4" + } + }, + "@babel/plugin-proposal-optional-chaining": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.7.4.tgz", + "integrity": "sha512-JmgaS+ygAWDR/STPe3/7y0lNlHgS+19qZ9aC06nYLwQ/XB7c0q5Xs+ksFU3EDnp9EiEsO0dnRAOKeyLHTZuW3A==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-optional-chaining": "^7.7.4" + } + }, + "@babel/plugin-syntax-dynamic-import": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.7.4.tgz", + "integrity": "sha512-jHQW0vbRGvwQNgyVxwDh4yuXu4bH1f5/EICJLAhl1SblLs2CDhrsmCk+v5XLdE9wxtAFRyxx+P//Iw+a5L/tTg==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/plugin-transform-destructuring": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.7.4.tgz", + "integrity": "sha512-4jFMXI1Cu2aXbcXXl8Lr6YubCn6Oc7k9lLsu8v61TZh+1jny2BWmdtvY9zSUlLdGUvcy9DMAWyZEOqjsbeg/wA==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/plugin-transform-react-display-name": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.7.4.tgz", + "integrity": "sha512-sBbIvqYkthai0X0vkD2xsAwluBp+LtNHH+/V4a5ydifmTtb8KOVOlrMIk/MYmIc4uTYDnjZUHQildYNo36SRJw==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/preset-env": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.7.4.tgz", + "integrity": "sha512-Dg+ciGJjwvC1NIe/DGblMbcGq1HOtKbw8RLl4nIjlfcILKEOkWT/vRqPpumswABEBVudii6dnVwrBtzD7ibm4g==", + "requires": { + "@babel/helper-module-imports": "^7.7.4", + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-proposal-async-generator-functions": "^7.7.4", + "@babel/plugin-proposal-dynamic-import": "^7.7.4", + "@babel/plugin-proposal-json-strings": "^7.7.4", + "@babel/plugin-proposal-object-rest-spread": "^7.7.4", + "@babel/plugin-proposal-optional-catch-binding": "^7.7.4", + "@babel/plugin-proposal-unicode-property-regex": "^7.7.4", + "@babel/plugin-syntax-async-generators": "^7.7.4", + "@babel/plugin-syntax-dynamic-import": "^7.7.4", + "@babel/plugin-syntax-json-strings": "^7.7.4", + "@babel/plugin-syntax-object-rest-spread": "^7.7.4", + "@babel/plugin-syntax-optional-catch-binding": "^7.7.4", + "@babel/plugin-syntax-top-level-await": "^7.7.4", + "@babel/plugin-transform-arrow-functions": "^7.7.4", + "@babel/plugin-transform-async-to-generator": "^7.7.4", + "@babel/plugin-transform-block-scoped-functions": "^7.7.4", + "@babel/plugin-transform-block-scoping": "^7.7.4", + "@babel/plugin-transform-classes": "^7.7.4", + "@babel/plugin-transform-computed-properties": "^7.7.4", + "@babel/plugin-transform-destructuring": "^7.7.4", + "@babel/plugin-transform-dotall-regex": "^7.7.4", + "@babel/plugin-transform-duplicate-keys": "^7.7.4", + "@babel/plugin-transform-exponentiation-operator": "^7.7.4", + "@babel/plugin-transform-for-of": "^7.7.4", + "@babel/plugin-transform-function-name": "^7.7.4", + "@babel/plugin-transform-literals": "^7.7.4", + "@babel/plugin-transform-member-expression-literals": "^7.7.4", + "@babel/plugin-transform-modules-amd": "^7.7.4", + "@babel/plugin-transform-modules-commonjs": "^7.7.4", + "@babel/plugin-transform-modules-systemjs": "^7.7.4", + "@babel/plugin-transform-modules-umd": "^7.7.4", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.7.4", + "@babel/plugin-transform-new-target": "^7.7.4", + "@babel/plugin-transform-object-super": "^7.7.4", + "@babel/plugin-transform-parameters": "^7.7.4", + "@babel/plugin-transform-property-literals": "^7.7.4", + "@babel/plugin-transform-regenerator": "^7.7.4", + "@babel/plugin-transform-reserved-words": "^7.7.4", + "@babel/plugin-transform-shorthand-properties": "^7.7.4", + "@babel/plugin-transform-spread": "^7.7.4", + "@babel/plugin-transform-sticky-regex": "^7.7.4", + "@babel/plugin-transform-template-literals": "^7.7.4", + "@babel/plugin-transform-typeof-symbol": "^7.7.4", + "@babel/plugin-transform-unicode-regex": "^7.7.4", + "@babel/types": "^7.7.4", + "browserslist": "^4.6.0", + "core-js-compat": "^3.1.1", + "invariant": "^2.2.2", + "js-levenshtein": "^1.1.3", + "semver": "^5.5.0" + } + }, + "@babel/preset-react": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/preset-react/-/preset-react-7.7.4.tgz", + "integrity": "sha512-j+vZtg0/8pQr1H8wKoaJyGL2IEk3rG/GIvua7Sec7meXVIvGycihlGMx5xcU00kqCJbwzHs18xTu3YfREOqQ+g==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-transform-react-display-name": "^7.7.4", + "@babel/plugin-transform-react-jsx": "^7.7.4", + "@babel/plugin-transform-react-jsx-self": "^7.7.4", + "@babel/plugin-transform-react-jsx-source": "^7.7.4" + } + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "babel-runtime": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", + "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", + "requires": { + "core-js": "^2.4.0", + "regenerator-runtime": "^0.11.0" + }, + "dependencies": { + "core-js": { + "version": "2.6.11", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.11.tgz", + "integrity": "sha512-5wjnpaT/3dV+XB4borEsnAYQchn00XSgTAWKDkEqv+K8KevjbzmofK6hfJ9TZIlpj2N0xQpazy7PiRQiWHqzWg==" + }, + "regenerator-runtime": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", + "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==" + } + } + }, + "babylon": { + "version": "6.18.0", + "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", + "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==" + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" + }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "requires": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, + "base64-js": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", + "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==" + }, + "batch": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz", + "integrity": "sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY=" + }, + "bcrypt-pbkdf": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", + "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", + "requires": { + "tweetnacl": "^0.14.3" + } + }, + "big.js": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", + "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==" + }, + "binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", + "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==" + }, + "bindings": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", + "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", + "optional": true, + "requires": { + "file-uri-to-path": "1.0.0" + } + }, + "bluebird": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", + "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" + }, + "bn.js": { + "version": "4.11.8", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.8.tgz", + "integrity": "sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA==" + }, + "body-parser": { + "version": "1.19.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", + "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", + "requires": { + "bytes": "3.1.0", + "content-type": "~1.0.4", + "debug": "2.6.9", + "depd": "~1.1.2", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "on-finished": "~2.3.0", + "qs": "6.7.0", + "raw-body": "2.4.0", + "type-is": "~1.6.17" + }, + "dependencies": { + "bytes": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", + "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", + "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" + } + } + }, + "bonjour": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/bonjour/-/bonjour-3.5.0.tgz", + "integrity": "sha1-jokKGD2O6aI5OzhExpGkK897yfU=", + "requires": { + "array-flatten": "^2.1.0", + "deep-equal": "^1.0.1", + "dns-equal": "^1.0.0", + "dns-txt": "^2.0.2", + "multicast-dns": "^6.0.1", + "multicast-dns-service-types": "^1.1.0" + } + }, + "boolbase": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", + "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=" + }, + "bowser": { + "version": "1.9.4", + "resolved": "https://registry.npmjs.org/bowser/-/bowser-1.9.4.tgz", + "integrity": "sha512-9IdMmj2KjigRq6oWhmwv1W36pDuA4STQZ8q6YO9um+x07xgYNCD3Oou+WP/3L1HNz7iqythGet3/p4wvc8AAwQ==" + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "requires": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "brorand": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", + "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=" + }, + "browser-process-hrtime": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-0.1.3.tgz", + "integrity": "sha512-bRFnI4NnjO6cnyLmOV/7PVoDEMJChlcfN0z4s1YMBY989/SvlfMI1lgCnkFUs53e9gQF+w7qu7XdllSTiSl8Aw==" + }, + "browser-resolve": { + "version": "1.11.3", + "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.3.tgz", + "integrity": "sha512-exDi1BYWB/6raKHmDTCicQfTkqwN5fioMFV4j8BsfMU4R2DK/QfZfK7kOVkmWCNANf0snkBzqGqAJBao9gZMdQ==", + "requires": { + "resolve": "1.1.7" + }, + "dependencies": { + "resolve": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", + "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=" + } + } + }, + "browserify-aes": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", + "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", + "requires": { + "buffer-xor": "^1.0.3", + "cipher-base": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.3", + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "browserify-cipher": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.1.tgz", + "integrity": "sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w==", + "requires": { + "browserify-aes": "^1.0.4", + "browserify-des": "^1.0.0", + "evp_bytestokey": "^1.0.0" + } + }, + "browserify-des": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.2.tgz", + "integrity": "sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A==", + "requires": { + "cipher-base": "^1.0.1", + "des.js": "^1.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "browserify-rsa": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz", + "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=", + "requires": { + "bn.js": "^4.1.0", + "randombytes": "^2.0.1" + } + }, + "browserify-sign": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.0.4.tgz", + "integrity": "sha1-qk62jl17ZYuqa/alfmMMvXqT0pg=", + "requires": { + "bn.js": "^4.1.1", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.2", + "elliptic": "^6.0.0", + "inherits": "^2.0.1", + "parse-asn1": "^5.0.0" + } + }, + "browserify-zlib": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz", + "integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==", + "requires": { + "pako": "~1.0.5" + } + }, + "browserslist": { + "version": "4.8.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.8.3.tgz", + "integrity": "sha512-iU43cMMknxG1ClEZ2MDKeonKE1CCrFVkQK2AqO2YWFmvIrx4JWrvQ4w4hQez6EpVI8rHTtqh/ruHHDHSOKxvUg==", + "requires": { + "caniuse-lite": "^1.0.30001017", + "electron-to-chromium": "^1.3.322", + "node-releases": "^1.1.44" + } + }, + "bser": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", + "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", + "requires": { + "node-int64": "^0.4.0" + } + }, + "buffer": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", + "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", + "requires": { + "base64-js": "^1.0.2", + "ieee754": "^1.1.4", + "isarray": "^1.0.0" + } + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==" + }, + "buffer-indexof": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-indexof/-/buffer-indexof-1.1.1.tgz", + "integrity": "sha512-4/rOEg86jivtPTeOUUT61jJO1Ya1TrR/OkqCSZDyq84WJh3LuuiphBYJN+fm5xufIk4XAFcEwte/8WzC8If/1g==" + }, + "buffer-xor": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", + "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=" + }, + "builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", + "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=" + }, + "bytes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", + "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" + }, + "cacache": { + "version": "13.0.1", + "resolved": "https://registry.npmjs.org/cacache/-/cacache-13.0.1.tgz", + "integrity": "sha512-5ZvAxd05HDDU+y9BVvcqYu2LLXmPnQ0hW62h32g4xBTgL/MppR4/04NHfj/ycM2y6lmTnbw6HVi+1eN0Psba6w==", + "requires": { + "chownr": "^1.1.2", + "figgy-pudding": "^3.5.1", + "fs-minipass": "^2.0.0", + "glob": "^7.1.4", + "graceful-fs": "^4.2.2", + "infer-owner": "^1.0.4", + "lru-cache": "^5.1.1", + "minipass": "^3.0.0", + "minipass-collect": "^1.0.2", + "minipass-flush": "^1.0.5", + "minipass-pipeline": "^1.2.2", + "mkdirp": "^0.5.1", + "move-concurrently": "^1.0.1", + "p-map": "^3.0.0", + "promise-inflight": "^1.0.1", + "rimraf": "^2.7.1", + "ssri": "^7.0.0", + "unique-filename": "^1.1.1" + }, + "dependencies": { + "rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "requires": { + "glob": "^7.1.3" + } + } + } + }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "requires": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + } + }, + "call-me-maybe": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.1.tgz", + "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=" + }, + "caller-callsite": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", + "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", + "requires": { + "callsites": "^2.0.0" + } + }, + "caller-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", + "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", + "requires": { + "caller-callsite": "^2.0.0" + } + }, + "callsites": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", + "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=" + }, + "camel-case": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-3.0.0.tgz", + "integrity": "sha1-yjw2iKTpzzpM2nd9xNy8cTJJz3M=", + "requires": { + "no-case": "^2.2.0", + "upper-case": "^1.1.1" + } + }, + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" + }, + "caniuse-api": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz", + "integrity": "sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==", + "requires": { + "browserslist": "^4.0.0", + "caniuse-lite": "^1.0.0", + "lodash.memoize": "^4.1.2", + "lodash.uniq": "^4.5.0" + } + }, + "caniuse-lite": { + "version": "1.0.30001020", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001020.tgz", + "integrity": "sha512-yWIvwA68wRHKanAVS1GjN8vajAv7MBFshullKCeq/eKpK7pJBVDgFFEqvgWTkcP2+wIDeQGYFRXECjKZnLkUjA==" + }, + "capture-exit": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/capture-exit/-/capture-exit-2.0.0.tgz", + "integrity": "sha512-PiT/hQmTonHhl/HFGN+Lx3JJUznrVYJ3+AQsnthneZbvW7x+f08Tk7yLJTLEOUvBTbduLeeBkxEaYXUOUrRq6g==", + "requires": { + "rsvp": "^4.8.4" + } + }, + "case-sensitive-paths-webpack-plugin": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.2.0.tgz", + "integrity": "sha512-u5ElzokS8A1pm9vM3/iDgTcI3xqHxuCao94Oz8etI3cf0Tio0p8izkDYbTIn09uP3yUUr6+veaE6IkjnTYS46g==" + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" + }, + "chain-function": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/chain-function/-/chain-function-1.0.1.tgz", + "integrity": "sha512-SxltgMwL9uCko5/ZCLiyG2B7R9fY4pDZUw7hJ4MhirdjBLosoDqkWABi3XMucddHdLiFJMb7PD2MZifZriuMTg==" + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "change-emitter": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/change-emitter/-/change-emitter-0.1.6.tgz", + "integrity": "sha1-6LL+PX8at9aaMhma/5HqaTFAlRU=" + }, + "chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==" + }, + "chokidar": { + "version": "2.1.8", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", + "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + }, + "dependencies": { + "fsevents": { + "version": "1.2.11", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.11.tgz", + "integrity": "sha512-+ux3lx6peh0BpvY0JebGyZoiR4D+oYzdPZMKJwkZ+sFkNJzpL7tXc/wehS49gUAxg3tmMHPHZkA8JU2rhhgDHw==", + "optional": true, + "requires": { + "bindings": "^1.5.0", + "nan": "^2.12.1", + "node-pre-gyp": "*" + }, + "dependencies": { + "abbrev": { + "version": "1.1.1", + "bundled": true, + "optional": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "optional": true + }, + "aproba": { + "version": "1.2.0", + "bundled": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.5", + "bundled": true, + "optional": true, + "requires": { + "delegates": "^1.0.0", + "readable-stream": "^2.0.6" + } + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "brace-expansion": { + "version": "1.1.11", + "bundled": true, + "optional": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "chownr": { + "version": "1.1.3", + "bundled": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "optional": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "optional": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true, + "optional": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "debug": { + "version": "3.2.6", + "bundled": true, + "optional": true, + "requires": { + "ms": "^2.1.1" + } + }, + "deep-extend": { + "version": "0.6.0", + "bundled": true, + "optional": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "detect-libc": { + "version": "1.0.3", + "bundled": true, + "optional": true + }, + "fs-minipass": { + "version": "1.2.7", + "bundled": true, + "optional": true, + "requires": { + "minipass": "^2.6.0" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "optional": true, + "requires": { + "aproba": "^1.0.3", + "console-control-strings": "^1.0.0", + "has-unicode": "^2.0.0", + "object-assign": "^4.1.0", + "signal-exit": "^3.0.0", + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wide-align": "^1.1.0" + } + }, + "glob": { + "version": "7.1.6", + "bundled": true, + "optional": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "iconv-lite": { + "version": "0.4.24", + "bundled": true, + "optional": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "ignore-walk": { + "version": "3.0.3", + "bundled": true, + "optional": true, + "requires": { + "minimatch": "^3.0.4" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "optional": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "bundled": true, + "optional": true + }, + "ini": { + "version": "1.3.5", + "bundled": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "optional": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "optional": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true, + "optional": true + }, + "minipass": { + "version": "2.9.0", + "bundled": true, + "optional": true, + "requires": { + "safe-buffer": "^5.1.2", + "yallist": "^3.0.0" + } + }, + "minizlib": { + "version": "1.3.3", + "bundled": true, + "optional": true, + "requires": { + "minipass": "^2.9.0" + } + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "optional": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.1.2", + "bundled": true, + "optional": true + }, + "needle": { + "version": "2.4.0", + "bundled": true, + "optional": true, + "requires": { + "debug": "^3.2.6", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + } + }, + "node-pre-gyp": { + "version": "0.14.0", + "bundled": true, + "optional": true, + "requires": { + "detect-libc": "^1.0.2", + "mkdirp": "^0.5.1", + "needle": "^2.2.1", + "nopt": "^4.0.1", + "npm-packlist": "^1.1.6", + "npmlog": "^4.0.2", + "rc": "^1.2.7", + "rimraf": "^2.6.1", + "semver": "^5.3.0", + "tar": "^4.4.2" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "optional": true, + "requires": { + "abbrev": "1", + "osenv": "^0.1.4" + } + }, + "npm-bundled": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "npm-normalize-package-bin": "^1.0.1" + } + }, + "npm-normalize-package-bin": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "npm-packlist": { + "version": "1.4.7", + "bundled": true, + "optional": true, + "requires": { + "ignore-walk": "^3.0.1", + "npm-bundled": "^1.0.1" + } + }, + "npmlog": { + "version": "4.1.2", + "bundled": true, + "optional": true, + "requires": { + "are-we-there-yet": "~1.1.2", + "console-control-strings": "~1.1.0", + "gauge": "~2.7.3", + "set-blocking": "~2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "optional": true, + "requires": { + "wrappy": "1" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "osenv": { + "version": "0.1.5", + "bundled": true, + "optional": true, + "requires": { + "os-homedir": "^1.0.0", + "os-tmpdir": "^1.0.0" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "process-nextick-args": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "rc": { + "version": "1.2.8", + "bundled": true, + "optional": true, + "requires": { + "deep-extend": "^0.6.0", + "ini": "~1.3.0", + "minimist": "^1.2.0", + "strip-json-comments": "~2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.3.6", + "bundled": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "rimraf": { + "version": "2.7.1", + "bundled": true, + "optional": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-buffer": { + "version": "5.1.2", + "bundled": true, + "optional": true + }, + "safer-buffer": { + "version": "2.1.2", + "bundled": true, + "optional": true + }, + "sax": { + "version": "1.2.4", + "bundled": true, + "optional": true + }, + "semver": { + "version": "5.7.1", + "bundled": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "optional": true + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "optional": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "string_decoder": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "optional": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "tar": { + "version": "4.4.13", + "bundled": true, + "optional": true, + "requires": { + "chownr": "^1.1.1", + "fs-minipass": "^1.2.5", + "minipass": "^2.8.6", + "minizlib": "^1.2.1", + "mkdirp": "^0.5.0", + "safe-buffer": "^5.1.2", + "yallist": "^3.0.3" + } + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "wide-align": { + "version": "1.1.3", + "bundled": true, + "optional": true, + "requires": { + "string-width": "^1.0.2 || 2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "yallist": { + "version": "3.1.1", + "bundled": true, + "optional": true + } + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" + } + } + }, + "chownr": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.3.tgz", + "integrity": "sha512-i70fVHhmV3DtTl6nqvZOnIjbY0Pe4kAUjwHj8z0zAdgBtYrJyYwLKCCuRBQ5ppkyL0AkN7HKRnETdmdp1zqNXw==" + }, + "chrome-trace-event": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.2.tgz", + "integrity": "sha512-9e/zx1jw7B4CO+c/RXoCsfg/x1AfUBioy4owYH0bJprEYAx5hRFLRhWBqHAG57D0ZM4H7vxbP7bPe0VwhQRYDQ==", + "requires": { + "tslib": "^1.9.0" + } + }, + "ci-info": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", + "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" + }, + "cipher-base": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", + "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "requires": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "clean-css": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.2.1.tgz", + "integrity": "sha512-4ZxI6dy4lrY6FHzfiy1aEOXgu4LIsW2MhwG0VBKdcoGoH/XLFgaHSdLTGr4O8Be6A8r3MOphEiI8Gc1n0ecf3g==", + "requires": { + "source-map": "~0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "clean-stack": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", + "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==" + }, + "cli-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", + "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", + "requires": { + "restore-cursor": "^3.1.0" + } + }, + "cli-width": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", + "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=" + }, + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", + "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "clone-deep": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-0.2.4.tgz", + "integrity": "sha1-TnPdCen7lxzDhnDF3O2cGJZIHMY=", + "requires": { + "for-own": "^0.1.3", + "is-plain-object": "^2.0.1", + "kind-of": "^3.0.2", + "lazy-cache": "^1.0.3", + "shallow-clone": "^0.1.2" + } + }, + "clsx": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/clsx/-/clsx-1.0.4.tgz", + "integrity": "sha512-1mQ557MIZTrL/140j+JVdRM6e31/OA4vTYxXgqIIZlndyfjHpyawKZia1Im05Vp9BWmImkcNrNtFYQMyFcgJDg==" + }, + "co": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" + }, + "coa": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/coa/-/coa-2.0.2.tgz", + "integrity": "sha512-q5/jG+YQnSy4nRTV4F7lPepBJZ8qBNJJDBuJdoejDyLXgmL7IEo+Le2JDZudFTFt7mrCqIRaSjws4ygRCTCAXA==", + "requires": { + "@types/q": "^1.5.1", + "chalk": "^2.4.1", + "q": "^1.1.2" + } + }, + "code-point-at": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" + }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "requires": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + } + }, + "color": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/color/-/color-3.1.2.tgz", + "integrity": "sha512-vXTJhHebByxZn3lDvDJYw4lR5+uB3vuoHsuYA5AKuxRVn5wzzIfQKGLBmgdVRHKTJYeK5rvJcHnrd0Li49CFpg==", + "requires": { + "color-convert": "^1.9.1", + "color-string": "^1.5.2" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" + }, + "color-string": { + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.5.3.tgz", + "integrity": "sha512-dC2C5qeWoYkxki5UAXapdjqO672AM4vZuPGRQfO8b5HKuKGBbKWpITyDYN7TOFKvRW7kOgAn3746clDBMDJyQw==", + "requires": { + "color-name": "^1.0.0", + "simple-swizzle": "^0.2.2" + } + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" + }, + "common-tags": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/common-tags/-/common-tags-1.8.0.tgz", + "integrity": "sha512-6P6g0uetGpW/sdyUy/iQQCbFF0kWVMSIVSyYz7Zgjcgh8mgw8PQzDNZeyZ5DQ2gM7LBoZPHmnjz8rUthkBG5tw==" + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=" + }, + "component-emitter": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", + "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" + }, + "compose-function": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/compose-function/-/compose-function-3.0.3.tgz", + "integrity": "sha1-ntZ18TzFRQHTCVCkhv9qe6OrGF8=", + "requires": { + "arity-n": "^1.0.4" + } + }, + "compressible": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", + "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", + "requires": { + "mime-db": ">= 1.43.0 < 2" + } + }, + "compression": { + "version": "1.7.4", + "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", + "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", + "requires": { + "accepts": "~1.3.5", + "bytes": "3.0.0", + "compressible": "~2.0.16", + "debug": "2.6.9", + "on-headers": "~1.0.2", + "safe-buffer": "5.1.2", + "vary": "~1.1.2" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "confusing-browser-globals": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.9.tgz", + "integrity": "sha512-KbS1Y0jMtyPgIxjO7ZzMAuUpAKMt1SzCL9fsrKsX6b0zJPTaT0SiSPmewwVZg9UAO83HVIlEhZF84LIjZ0lmAw==" + }, + "connect-history-api-fallback": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-1.6.0.tgz", + "integrity": "sha512-e54B99q/OUoH64zYYRf3HBP5z24G38h5D3qXu23JGRoigpX5Ss4r9ZnDk3g0Z8uQC2x2lPaJ+UlWBc1ZWBWdLg==" + }, + "console-browserify": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.2.0.tgz", + "integrity": "sha512-ZMkYO/LkF17QvCPqM0gxw8yUzigAOZOSWSHg91FH6orS7vcEj5dVZTidN2fQ14yBSdg97RqhSNwLUXInd52OTA==" + }, + "constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", + "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=" + }, + "contains-path": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", + "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=" + }, + "content-disposition": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", + "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", + "requires": { + "safe-buffer": "5.1.2" + } + }, + "content-type": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", + "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" + }, + "convert-css-length": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/convert-css-length/-/convert-css-length-2.0.1.tgz", + "integrity": "sha512-iGpbcvhLPRKUbBc0Quxx7w/bV14AC3ItuBEGMahA5WTYqB8lq9jH0kTXFheCBASsYnqeMFZhiTruNxr1N59Axg==" + }, + "convert-source-map": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", + "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", + "requires": { + "safe-buffer": "~5.1.1" + } + }, + "cookie": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", + "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" + }, + "cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" + }, + "copy-concurrently": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/copy-concurrently/-/copy-concurrently-1.0.5.tgz", + "integrity": "sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A==", + "requires": { + "aproba": "^1.1.1", + "fs-write-stream-atomic": "^1.0.8", + "iferr": "^0.1.5", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.0" + } + }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=" + }, + "core-js": { + "version": "3.6.3", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.6.3.tgz", + "integrity": "sha512-DOO9b18YHR+Wk5kJ/c5YFbXuUETreD4TrvXb6edzqZE3aAEd0eJIAWghZ9HttMuiON8SVCnU3fqA4rPxRDD1HQ==" + }, + "core-js-compat": { + "version": "3.6.3", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.6.3.tgz", + "integrity": "sha512-Y3YNGU3bU1yrnzVodop23ghArbKv4IqkZg9MMOWv/h7KT6NRk1/SzHhWDDlubg2+tlcUzAqgj1/GyeJ9fUKMeg==", + "requires": { + "browserslist": "^4.8.3", + "semver": "7.0.0" + }, + "dependencies": { + "semver": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", + "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==" + } + } + }, + "core-js-pure": { + "version": "3.6.3", + "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.6.3.tgz", + "integrity": "sha512-4LhJ4fw0sC4/8X5krM9hI5oQ3cgYHYojWwwWnQKjC6k6vf/qIVS9d0r3+Bdn+FUADgRpD0xzPFQ9P7cOeuIwlA==" + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" + }, + "cosmiconfig": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.2.1.tgz", + "integrity": "sha512-H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA==", + "requires": { + "import-fresh": "^2.0.0", + "is-directory": "^0.3.1", + "js-yaml": "^3.13.1", + "parse-json": "^4.0.0" + } + }, + "create-ecdh": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.3.tgz", + "integrity": "sha512-GbEHQPMOswGpKXM9kCWVrremUcBmjteUaQ01T9rkKCPDXfUHX0IoP9LpHYo2NPFampa4e+/pFDc3jQdxrxQLaw==", + "requires": { + "bn.js": "^4.1.0", + "elliptic": "^6.0.0" + } + }, + "create-hash": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", + "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", + "requires": { + "cipher-base": "^1.0.1", + "inherits": "^2.0.1", + "md5.js": "^1.3.4", + "ripemd160": "^2.0.1", + "sha.js": "^2.4.0" + } + }, + "create-hmac": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", + "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", + "requires": { + "cipher-base": "^1.0.3", + "create-hash": "^1.1.0", + "inherits": "^2.0.1", + "ripemd160": "^2.0.0", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "crypto-browserify": { + "version": "3.12.0", + "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", + "integrity": "sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg==", + "requires": { + "browserify-cipher": "^1.0.0", + "browserify-sign": "^4.0.0", + "create-ecdh": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.0", + "diffie-hellman": "^5.0.0", + "inherits": "^2.0.1", + "pbkdf2": "^3.0.3", + "public-encrypt": "^4.0.0", + "randombytes": "^2.0.0", + "randomfill": "^1.0.3" + } + }, + "css": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/css/-/css-2.2.4.tgz", + "integrity": "sha512-oUnjmWpy0niI3x/mPL8dVEI1l7MnG3+HHyRPHf+YFSbK+svOhXpmSOcDURUh2aOCgl2grzrOPt1nHLuCVFULLw==", + "requires": { + "inherits": "^2.0.3", + "source-map": "^0.6.1", + "source-map-resolve": "^0.5.2", + "urix": "^0.1.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "css-blank-pseudo": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/css-blank-pseudo/-/css-blank-pseudo-0.1.4.tgz", + "integrity": "sha512-LHz35Hr83dnFeipc7oqFDmsjHdljj3TQtxGGiNWSOsTLIAubSm4TEz8qCaKFpk7idaQ1GfWscF4E6mgpBysA1w==", + "requires": { + "postcss": "^7.0.5" + } + }, + "css-color-names": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", + "integrity": "sha1-gIrcLnnPhHOAabZGyyDsJ762KeA=" + }, + "css-declaration-sorter": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-4.0.1.tgz", + "integrity": "sha512-BcxQSKTSEEQUftYpBVnsH4SF05NTuBokb19/sBt6asXGKZ/6VP7PLG1CBCkFDYOnhXhPh0jMhO6xZ71oYHXHBA==", + "requires": { + "postcss": "^7.0.1", + "timsort": "^0.3.0" + } + }, + "css-has-pseudo": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/css-has-pseudo/-/css-has-pseudo-0.10.0.tgz", + "integrity": "sha512-Z8hnfsZu4o/kt+AuFzeGpLVhFOGO9mluyHBaA2bA8aCGTwah5sT3WV/fTHH8UNZUytOIImuGPrl/prlb4oX4qQ==", + "requires": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^5.0.0-rc.4" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "css-in-js-utils": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/css-in-js-utils/-/css-in-js-utils-2.0.1.tgz", + "integrity": "sha512-PJF0SpJT+WdbVVt0AOYp9C8GnuruRlL/UFW7932nLWmFLQTaWEzTBQEx7/hn4BuV+WON75iAViSUJLiU3PKbpA==", + "requires": { + "hyphenate-style-name": "^1.0.2", + "isobject": "^3.0.1" + } + }, + "css-loader": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-3.2.0.tgz", + "integrity": "sha512-QTF3Ud5H7DaZotgdcJjGMvyDj5F3Pn1j/sC6VBEOVp94cbwqyIBdcs/quzj4MC1BKQSrTpQznegH/5giYbhnCQ==", + "requires": { + "camelcase": "^5.3.1", + "cssesc": "^3.0.0", + "icss-utils": "^4.1.1", + "loader-utils": "^1.2.3", + "normalize-path": "^3.0.0", + "postcss": "^7.0.17", + "postcss-modules-extract-imports": "^2.0.0", + "postcss-modules-local-by-default": "^3.0.2", + "postcss-modules-scope": "^2.1.0", + "postcss-modules-values": "^3.0.0", + "postcss-value-parser": "^4.0.0", + "schema-utils": "^2.0.0" + }, + "dependencies": { + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" + } + } + }, + "css-prefers-color-scheme": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/css-prefers-color-scheme/-/css-prefers-color-scheme-3.1.1.tgz", + "integrity": "sha512-MTu6+tMs9S3EUqzmqLXEcgNRbNkkD/TGFvowpeoWJn5Vfq7FMgsmRQs9X5NXAURiOBmOxm/lLjsDNXDE6k9bhg==", + "requires": { + "postcss": "^7.0.5" + } + }, + "css-select": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-2.1.0.tgz", + "integrity": "sha512-Dqk7LQKpwLoH3VovzZnkzegqNSuAziQyNZUcrdDM401iY+R5NkGBXGmtO05/yaXQziALuPogeG0b7UAgjnTJTQ==", + "requires": { + "boolbase": "^1.0.0", + "css-what": "^3.2.1", + "domutils": "^1.7.0", + "nth-check": "^1.0.2" + } + }, + "css-select-base-adapter": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/css-select-base-adapter/-/css-select-base-adapter-0.1.1.tgz", + "integrity": "sha512-jQVeeRG70QI08vSTwf1jHxp74JoZsr2XSgETae8/xC8ovSnL2WF87GTLO86Sbwdt2lK4Umg4HnnwMO4YF3Ce7w==" + }, + "css-tree": { + "version": "1.0.0-alpha.37", + "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.0.0-alpha.37.tgz", + "integrity": "sha512-DMxWJg0rnz7UgxKT0Q1HU/L9BeJI0M6ksor0OgqOnF+aRCDWg/N2641HmVyU9KVIu0OVVWOb2IpC9A+BJRnejg==", + "requires": { + "mdn-data": "2.0.4", + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "css-unit-converter": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/css-unit-converter/-/css-unit-converter-1.1.1.tgz", + "integrity": "sha1-2bkoGtz9jO2TW9urqDeGiX9k6ZY=" + }, + "css-vendor": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/css-vendor/-/css-vendor-2.0.7.tgz", + "integrity": "sha512-VS9Rjt79+p7M0WkPqcAza4Yq1ZHrsHrwf7hPL/bjQB+c1lwmAI+1FXxYTYt818D/50fFVflw0XKleiBN5RITkg==", + "requires": { + "@babel/runtime": "^7.6.2", + "is-in-browser": "^1.0.2" + } + }, + "css-what": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-3.2.1.tgz", + "integrity": "sha512-WwOrosiQTvyms+Ti5ZC5vGEK0Vod3FTt1ca+payZqvKuGJF+dq7bG63DstxtN0dpm6FxY27a/zS3Wten+gEtGw==" + }, + "css.escape": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/css.escape/-/css.escape-1.5.1.tgz", + "integrity": "sha1-QuJ9T6BK4y+TGktNQZH6nN3ul8s=" + }, + "cssdb": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/cssdb/-/cssdb-4.4.0.tgz", + "integrity": "sha512-LsTAR1JPEM9TpGhl/0p3nQecC2LJ0kD8X5YARu1hk/9I1gril5vDtMZyNxcEpxxDj34YNck/ucjuoUd66K03oQ==" + }, + "cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==" + }, + "cssnano": { + "version": "4.1.10", + "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-4.1.10.tgz", + "integrity": "sha512-5wny+F6H4/8RgNlaqab4ktc3e0/blKutmq8yNlBFXA//nSFFAqAngjNVRzUvCgYROULmZZUoosL/KSoZo5aUaQ==", + "requires": { + "cosmiconfig": "^5.0.0", + "cssnano-preset-default": "^4.0.7", + "is-resolvable": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "cssnano-preset-default": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/cssnano-preset-default/-/cssnano-preset-default-4.0.7.tgz", + "integrity": "sha512-x0YHHx2h6p0fCl1zY9L9roD7rnlltugGu7zXSKQx6k2rYw0Hi3IqxcoAGF7u9Q5w1nt7vK0ulxV8Lo+EvllGsA==", + "requires": { + "css-declaration-sorter": "^4.0.1", + "cssnano-util-raw-cache": "^4.0.1", + "postcss": "^7.0.0", + "postcss-calc": "^7.0.1", + "postcss-colormin": "^4.0.3", + "postcss-convert-values": "^4.0.1", + "postcss-discard-comments": "^4.0.2", + "postcss-discard-duplicates": "^4.0.2", + "postcss-discard-empty": "^4.0.1", + "postcss-discard-overridden": "^4.0.1", + "postcss-merge-longhand": "^4.0.11", + "postcss-merge-rules": "^4.0.3", + "postcss-minify-font-values": "^4.0.2", + "postcss-minify-gradients": "^4.0.2", + "postcss-minify-params": "^4.0.2", + "postcss-minify-selectors": "^4.0.2", + "postcss-normalize-charset": "^4.0.1", + "postcss-normalize-display-values": "^4.0.2", + "postcss-normalize-positions": "^4.0.2", + "postcss-normalize-repeat-style": "^4.0.2", + "postcss-normalize-string": "^4.0.2", + "postcss-normalize-timing-functions": "^4.0.2", + "postcss-normalize-unicode": "^4.0.1", + "postcss-normalize-url": "^4.0.1", + "postcss-normalize-whitespace": "^4.0.2", + "postcss-ordered-values": "^4.1.2", + "postcss-reduce-initial": "^4.0.3", + "postcss-reduce-transforms": "^4.0.2", + "postcss-svgo": "^4.0.2", + "postcss-unique-selectors": "^4.0.1" + } + }, + "cssnano-util-get-arguments": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-arguments/-/cssnano-util-get-arguments-4.0.0.tgz", + "integrity": "sha1-7ToIKZ8h11dBsg87gfGU7UnMFQ8=" + }, + "cssnano-util-get-match": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-match/-/cssnano-util-get-match-4.0.0.tgz", + "integrity": "sha1-wOTKB/U4a7F+xeUiULT1lhNlFW0=" + }, + "cssnano-util-raw-cache": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-raw-cache/-/cssnano-util-raw-cache-4.0.1.tgz", + "integrity": "sha512-qLuYtWK2b2Dy55I8ZX3ky1Z16WYsx544Q0UWViebptpwn/xDBmog2TLg4f+DBMg1rJ6JDWtn96WHbOKDWt1WQA==", + "requires": { + "postcss": "^7.0.0" + } + }, + "cssnano-util-same-parent": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-same-parent/-/cssnano-util-same-parent-4.0.1.tgz", + "integrity": "sha512-WcKx5OY+KoSIAxBW6UBBRay1U6vkYheCdjyVNDm85zt5K9mHoGOfsOsqIszfAqrQQFIIKgjh2+FDgIj/zsl21Q==" + }, + "csso": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/csso/-/csso-4.0.2.tgz", + "integrity": "sha512-kS7/oeNVXkHWxby5tHVxlhjizRCSv8QdU7hB2FpdAibDU8FjTAolhNjKNTiLzXtUrKT6HwClE81yXwEk1309wg==", + "requires": { + "css-tree": "1.0.0-alpha.37" + } + }, + "cssom": { + "version": "0.3.8", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==" + }, + "cssstyle": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-1.4.0.tgz", + "integrity": "sha512-GBrLZYZ4X4x6/QEoBnIrqb8B/f5l4+8me2dkom/j1Gtbxy0kBv6OGzKuAsGM75bkGwGAFkt56Iwg28S3XTZgSA==", + "requires": { + "cssom": "0.3.x" + } + }, + "csstype": { + "version": "2.6.8", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-2.6.8.tgz", + "integrity": "sha512-msVS9qTuMT5zwAGCVm4mxfrZ18BNc6Csd0oJAtiFMZ1FAx1CCvy2+5MDmYoix63LM/6NDbNtodCiGYGmFgO0dA==" + }, + "cyclist": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cyclist/-/cyclist-1.0.1.tgz", + "integrity": "sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk=" + }, + "d": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", + "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", + "requires": { + "es5-ext": "^0.10.50", + "type": "^1.0.1" + } + }, + "damerau-levenshtein": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.5.tgz", + "integrity": "sha512-CBCRqFnpu715iPmw1KrdOrzRqbdFwQTwAWyyyYS42+iAgHCuXZ+/TdMgQkUENPomxEz9z1BEzuQU2Xw0kUuAgA==" + }, + "dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "requires": { + "assert-plus": "^1.0.0" + } + }, + "data-urls": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-1.1.0.tgz", + "integrity": "sha512-YTWYI9se1P55u58gL5GkQHW4P6VJBJ5iBT+B5a7i2Tjadhv52paJG0qHX4A0OR6/t52odI64KP2YvFpkDOi3eQ==", + "requires": { + "abab": "^2.0.0", + "whatwg-mimetype": "^2.2.0", + "whatwg-url": "^7.0.0" + }, + "dependencies": { + "whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", + "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + } + } + }, + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" + }, + "decode-uri-component": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", + "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=" + }, + "deep-equal": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.1.1.tgz", + "integrity": "sha512-yd9c5AdiqVcR+JjcwUQb9DkhJc8ngNr0MahEBGvDiJw8puWab2yZlh+nkasOnZP+EGTAP6rRp2JzJhJZzvNF8g==", + "requires": { + "is-arguments": "^1.0.4", + "is-date-object": "^1.0.1", + "is-regex": "^1.0.4", + "object-is": "^1.0.1", + "object-keys": "^1.1.1", + "regexp.prototype.flags": "^1.2.0" + } + }, + "deep-is": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", + "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" + }, + "default-gateway": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-4.2.0.tgz", + "integrity": "sha512-h6sMrVB1VMWVrW13mSc6ia/DwYYw5MN6+exNu1OaJeFac5aSAvwM7lZ0NVfTABuSkQelr4h5oebg3KB1XPdjgA==", + "requires": { + "execa": "^1.0.0", + "ip-regex": "^2.1.0" + } + }, + "define-properties": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", + "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", + "requires": { + "object-keys": "^1.0.12" + } + }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "requires": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "dependencies": { + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, + "del": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/del/-/del-4.1.1.tgz", + "integrity": "sha512-QwGuEUouP2kVwQenAsOof5Fv8K9t3D8Ca8NxcXKrIpEHjTXK5J2nXLdP+ALI1cgv8wj7KuwBhTwBkOZSJKM5XQ==", + "requires": { + "@types/glob": "^7.1.1", + "globby": "^6.1.0", + "is-path-cwd": "^2.0.0", + "is-path-in-cwd": "^2.0.0", + "p-map": "^2.0.0", + "pify": "^4.0.1", + "rimraf": "^2.6.3" + }, + "dependencies": { + "globby": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", + "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", + "requires": { + "array-union": "^1.0.1", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + }, + "dependencies": { + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" + } + } + }, + "p-map": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-2.1.0.tgz", + "integrity": "sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw==" + }, + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==" + } + } + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" + }, + "depd": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", + "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" + }, + "des.js": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.0.1.tgz", + "integrity": "sha512-Q0I4pfFrv2VPd34/vfLrFOoRmlYj3OV50i7fskps1jZWK1kApMWWT9G6RRUeYedLcBDIhnSDaUvJMb3AhUlaEA==", + "requires": { + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "destroy": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", + "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" + }, + "detect-newline": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-2.1.0.tgz", + "integrity": "sha1-9B8cEL5LAOh7XxPaaAdZ8sW/0+I=" + }, + "detect-node": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.0.4.tgz", + "integrity": "sha512-ZIzRpLJrOj7jjP2miAtgqIfmzbxa4ZOr5jJc601zklsfEx9oTzmmj2nVpIPRpNlRTIh8lc1kyViIY7BWSGNmKw==" + }, + "detect-port-alt": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/detect-port-alt/-/detect-port-alt-1.1.6.tgz", + "integrity": "sha512-5tQykt+LqfJFBEYaDITx7S7cR7mJ/zQmLXZ2qt5w04ainYZw6tBf9dBunMjVeVOdYVRUzUOE4HkY5J7+uttb5Q==", + "requires": { + "address": "^1.0.1", + "debug": "^2.6.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, + "diff-sequences": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-24.9.0.tgz", + "integrity": "sha512-Dj6Wk3tWyTE+Fo1rW8v0Xhwk80um6yFYKbuAxc9c3EZxIHFDYwbi34Uk42u1CdnIiVorvt4RmlSDjIPyzGC2ew==" + }, + "diffie-hellman": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.3.tgz", + "integrity": "sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg==", + "requires": { + "bn.js": "^4.1.0", + "miller-rabin": "^4.0.0", + "randombytes": "^2.0.0" + } + }, + "dir-glob": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-2.0.0.tgz", + "integrity": "sha512-37qirFDz8cA5fimp9feo43fSuRo2gHwaIn6dXL8Ber1dGwUosDrGZeCCXq57WnIqE4aQ+u3eQZzsk1yOzhdwag==", + "requires": { + "arrify": "^1.0.1", + "path-type": "^3.0.0" + } + }, + "dns-equal": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz", + "integrity": "sha1-s55/HabrCnW6nBcySzR1PEfgZU0=" + }, + "dns-packet": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-1.3.1.tgz", + "integrity": "sha512-0UxfQkMhYAUaZI+xrNZOz/as5KgDU0M/fQ9b6SpkyLbk3GEswDi6PADJVaYJradtRVsRIlF1zLyOodbcTCDzUg==", + "requires": { + "ip": "^1.1.0", + "safe-buffer": "^5.0.1" + } + }, + "dns-txt": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/dns-txt/-/dns-txt-2.0.2.tgz", + "integrity": "sha1-uR2Ab10nGI5Ks+fRB9iBocxGQrY=", + "requires": { + "buffer-indexof": "^1.0.0" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "requires": { + "esutils": "^2.0.2" + } + }, + "dom-converter": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/dom-converter/-/dom-converter-0.2.0.tgz", + "integrity": "sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA==", + "requires": { + "utila": "~0.4" + } + }, + "dom-helpers": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-3.4.0.tgz", + "integrity": "sha512-LnuPJ+dwqKDIyotW1VzmOZ5TONUN7CwkCR5hrgawTUbkBGYdeoNLZo6nNfGkCrjtE1nXXaj7iMMpDa8/d9WoIA==", + "requires": { + "@babel/runtime": "^7.1.2" + } + }, + "dom-serializer": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", + "integrity": "sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==", + "requires": { + "domelementtype": "^2.0.1", + "entities": "^2.0.0" + }, + "dependencies": { + "domelementtype": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.0.1.tgz", + "integrity": "sha512-5HOHUDsYZWV8FGWN0Njbr/Rn7f/eWSQi1v7+HsUVwXgn8nWWlL64zKDkS0n8ZmQ3mlWOMuXOnR+7Nx/5tMO5AQ==" + } + } + }, + "domain-browser": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz", + "integrity": "sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA==" + }, + "domelementtype": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", + "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==" + }, + "domexception": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/domexception/-/domexception-1.0.1.tgz", + "integrity": "sha512-raigMkn7CJNNo6Ihro1fzG7wr3fHuYVytzquZKX5n0yizGsTcYgzdIUwj1X9pK0VvjeihV+XiclP+DjwbsSKug==", + "requires": { + "webidl-conversions": "^4.0.2" + } + }, + "domhandler": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.2.tgz", + "integrity": "sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==", + "requires": { + "domelementtype": "1" + } + }, + "domutils": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz", + "integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==", + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "dot-prop": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", + "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", + "requires": { + "is-obj": "^1.0.0" + } + }, + "dotenv": { + "version": "8.2.0", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", + "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" + }, + "dotenv-expand": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/dotenv-expand/-/dotenv-expand-5.1.0.tgz", + "integrity": "sha512-YXQl1DSa4/PQyRfgrv6aoNjhasp/p4qs9FjJ4q4cQk+8m4r6k4ZSiEyytKG8f8W9gi8WsQtIObNmKd+tMzNTmA==" + }, + "duplexer": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", + "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=" + }, + "duplexify": { + "version": "3.7.1", + "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", + "integrity": "sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==", + "requires": { + "end-of-stream": "^1.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.0.0", + "stream-shift": "^1.0.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "ecc-jsbn": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", + "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", + "requires": { + "jsbn": "~0.1.0", + "safer-buffer": "^2.1.0" + } + }, + "ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" + }, + "electron-to-chromium": { + "version": "1.3.332", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.332.tgz", + "integrity": "sha512-AP2HkLhfSOIxP7gDjlyZ4ywGWIcxRMZoU9+JriuVkQe2pSLDdWBsE6+eI6BQOqun1dohLrUTOPHsQLLhhFA7Eg==" + }, + "elliptic": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.2.tgz", + "integrity": "sha512-f4x70okzZbIQl/NSRLkI/+tteV/9WqL98zx+SQ69KbXxmVrmjwsNUPn/gYJJ0sHvEak24cZgHIPegRePAtA/xw==", + "requires": { + "bn.js": "^4.4.0", + "brorand": "^1.0.1", + "hash.js": "^1.0.0", + "hmac-drbg": "^1.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.0" + } + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" + }, + "emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz", + "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=" + }, + "encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", + "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" + }, + "encoding": { + "version": "0.1.12", + "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.12.tgz", + "integrity": "sha1-U4tm8+5izRq1HsMjgp0flIDHS+s=", + "requires": { + "iconv-lite": "~0.4.13" + } + }, + "end-of-stream": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", + "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", + "requires": { + "once": "^1.4.0" + } + }, + "enhanced-resolve": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-4.1.1.tgz", + "integrity": "sha512-98p2zE+rL7/g/DzMHMTF4zZlCgeVdJ7yr6xzEpJRYwFYrGi9ANdn5DnJURg6RpBkyk60XYDnWIv51VfIhfNGuA==", + "requires": { + "graceful-fs": "^4.1.2", + "memory-fs": "^0.5.0", + "tapable": "^1.0.0" + }, + "dependencies": { + "memory-fs": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.5.0.tgz", + "integrity": "sha512-jA0rdU5KoQMC0e6ppoNRtpp6vjFq6+NY7r8hywnC7V+1Xj/MtHwGIbB1QaK/dunyjWteJzmkpd7ooeWg10T7GA==", + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + } + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "entities": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.0.0.tgz", + "integrity": "sha512-D9f7V0JSRwIxlRI2mjMqufDrRDnx8p+eEOz7aUM9SuvF8gsBzra0/6tbjl1m8eQHrZlYj6PxqE00hZ1SAIKPLw==" + }, + "errno": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz", + "integrity": "sha512-MfrRBDWzIWifgq6tJj60gkAwtLNb6sQPlcFrSOflcP1aFmmruKQ2wRnze/8V6kgyz7H3FF8Npzv78mZ7XLLflg==", + "requires": { + "prr": "~1.0.1" + } + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es-abstract": { + "version": "1.17.0", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.0.tgz", + "integrity": "sha512-yYkE07YF+6SIBmg1MsJ9dlub5L48Ek7X0qz+c/CPCHS9EBXfESorzng4cJQjJW5/pB6vDF41u7F8vUhLVDqIug==", + "requires": { + "es-to-primitive": "^1.2.1", + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1", + "is-callable": "^1.1.5", + "is-regex": "^1.0.5", + "object-inspect": "^1.7.0", + "object-keys": "^1.1.1", + "object.assign": "^4.1.0", + "string.prototype.trimleft": "^2.1.1", + "string.prototype.trimright": "^2.1.1" + } + }, + "es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "es5-ext": { + "version": "0.10.53", + "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.53.tgz", + "integrity": "sha512-Xs2Stw6NiNHWypzRTY1MtaG/uJlwCk8kH81920ma8mvN8Xq1gsfhZvpkImLQArw8AHnv8MT2I45J3c0R8slE+Q==", + "requires": { + "es6-iterator": "~2.0.3", + "es6-symbol": "~3.1.3", + "next-tick": "~1.0.0" + } + }, + "es6-iterator": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", + "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", + "requires": { + "d": "1", + "es5-ext": "^0.10.35", + "es6-symbol": "^3.1.1" + } + }, + "es6-symbol": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", + "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", + "requires": { + "d": "^1.0.1", + "ext": "^1.1.2" + } + }, + "escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" + }, + "escodegen": { + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.12.1.tgz", + "integrity": "sha512-Q8t2YZ+0e0pc7NRVj3B4tSQ9rim1oi4Fh46k2xhJ2qOiEwhQfdjyEQddWdj7ZFaKmU+5104vn1qrcjEPWq+bgQ==", + "requires": { + "esprima": "^3.1.3", + "estraverse": "^4.2.0", + "esutils": "^2.0.2", + "optionator": "^0.8.1", + "source-map": "~0.6.1" + }, + "dependencies": { + "esprima": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", + "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=" + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "optional": true + } + } + }, + "eslint": { + "version": "6.8.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", + "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", + "requires": { + "@babel/code-frame": "^7.0.0", + "ajv": "^6.10.0", + "chalk": "^2.1.0", + "cross-spawn": "^6.0.5", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "eslint-scope": "^5.0.0", + "eslint-utils": "^1.4.3", + "eslint-visitor-keys": "^1.1.0", + "espree": "^6.1.2", + "esquery": "^1.0.1", + "esutils": "^2.0.2", + "file-entry-cache": "^5.0.1", + "functional-red-black-tree": "^1.0.1", + "glob-parent": "^5.0.0", + "globals": "^12.1.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "inquirer": "^7.0.0", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.3.0", + "lodash": "^4.17.14", + "minimatch": "^3.0.4", + "mkdirp": "^0.5.1", + "natural-compare": "^1.4.0", + "optionator": "^0.8.3", + "progress": "^2.0.0", + "regexpp": "^2.0.1", + "semver": "^6.1.2", + "strip-ansi": "^5.2.0", + "strip-json-comments": "^3.0.1", + "table": "^5.2.3", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" + }, + "dependencies": { + "globals": { + "version": "12.3.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-12.3.0.tgz", + "integrity": "sha512-wAfjdLgFsPZsklLJvOBUBmzYE8/CwhEqSBEMRXA3qxIiNtyqvjYurAtIfDh6chlEPUfmTY3MnZh5Hfh4q0UlIw==", + "requires": { + "type-fest": "^0.8.1" + } + }, + "import-fresh": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", + "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "regexpp": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", + "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==" + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" + } + } + }, + "eslint-config-react-app": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-react-app/-/eslint-config-react-app-5.1.0.tgz", + "integrity": "sha512-hBaxisHC6HXRVvxX+/t1n8mOdmCVIKgkXsf2WoUkJi7upHJTwYTsdCmx01QPOjKNT34QMQQ9sL0tVBlbiMFjxA==", + "requires": { + "confusing-browser-globals": "^1.0.9" + } + }, + "eslint-import-resolver-node": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.3.tgz", + "integrity": "sha512-b8crLDo0M5RSe5YG8Pu2DYBj71tSB6OvXkfzwbJU2w7y8P4/yo0MyF8jU26IEuEuHF2K5/gcAJE3LhQGqBBbVg==", + "requires": { + "debug": "^2.6.9", + "resolve": "^1.13.1" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + }, + "resolve": { + "version": "1.14.2", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.14.2.tgz", + "integrity": "sha512-EjlOBLBO1kxsUxsKjLt7TAECyKW6fOh1VRkykQkKGzcBbjjPIxBqGh0jf7GJ3k/f5mxMqW3htMD3WdTUVtW8HQ==", + "requires": { + "path-parse": "^1.0.6" + } + } + } + }, + "eslint-loader": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/eslint-loader/-/eslint-loader-3.0.2.tgz", + "integrity": "sha512-S5VnD+UpVY1PyYRqeBd/4pgsmkvSokbHqTXAQMpvCyRr3XN2tvSLo9spm2nEpqQqh9dezw3os/0zWihLeOg2Rw==", + "requires": { + "fs-extra": "^8.1.0", + "loader-fs-cache": "^1.0.2", + "loader-utils": "^1.2.3", + "object-hash": "^1.3.1", + "schema-utils": "^2.2.0" + } + }, + "eslint-module-utils": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.5.2.tgz", + "integrity": "sha512-LGScZ/JSlqGKiT8OC+cYRxseMjyqt6QO54nl281CK93unD89ijSeRV6An8Ci/2nvWVKe8K/Tqdm75RQoIOCr+Q==", + "requires": { + "debug": "^2.6.9", + "pkg-dir": "^2.0.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "requires": { + "locate-path": "^2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=" + }, + "pkg-dir": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", + "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", + "requires": { + "find-up": "^2.1.0" + } + } + } + }, + "eslint-plugin-flowtype": { + "version": "3.13.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-flowtype/-/eslint-plugin-flowtype-3.13.0.tgz", + "integrity": "sha512-bhewp36P+t7cEV0b6OdmoRWJCBYRiHFlqPZAG1oS3SF+Y0LQkeDvFSM4oxoxvczD1OdONCXMlJfQFiWLcV9urw==", + "requires": { + "lodash": "^4.17.15" + } + }, + "eslint-plugin-import": { + "version": "2.18.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.18.2.tgz", + "integrity": "sha512-5ohpsHAiUBRNaBWAF08izwUGlbrJoJJ+W9/TBwsGoR1MnlgfwMIKrFeSjWbt6moabiXW9xNvtFz+97KHRfI4HQ==", + "requires": { + "array-includes": "^3.0.3", + "contains-path": "^0.1.0", + "debug": "^2.6.9", + "doctrine": "1.5.0", + "eslint-import-resolver-node": "^0.3.2", + "eslint-module-utils": "^2.4.0", + "has": "^1.0.3", + "minimatch": "^3.0.4", + "object.values": "^1.1.0", + "read-pkg-up": "^2.0.0", + "resolve": "^1.11.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "doctrine": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", + "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", + "requires": { + "esutils": "^2.0.2", + "isarray": "^1.0.0" + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "requires": { + "locate-path": "^2.0.0" + } + }, + "load-json-file": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", + "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^2.2.0", + "pify": "^2.0.0", + "strip-bom": "^3.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=" + }, + "parse-json": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", + "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", + "requires": { + "error-ex": "^1.2.0" + } + }, + "path-type": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", + "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", + "requires": { + "pify": "^2.0.0" + } + }, + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" + }, + "read-pkg": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", + "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", + "requires": { + "load-json-file": "^2.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^2.0.0" + } + }, + "read-pkg-up": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", + "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", + "requires": { + "find-up": "^2.0.0", + "read-pkg": "^2.0.0" + } + } + } + }, + "eslint-plugin-jsx-a11y": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.2.3.tgz", + "integrity": "sha512-CawzfGt9w83tyuVekn0GDPU9ytYtxyxyFZ3aSWROmnRRFQFT2BiPJd7jvRdzNDi6oLWaS2asMeYSNMjWTV4eNg==", + "requires": { + "@babel/runtime": "^7.4.5", + "aria-query": "^3.0.0", + "array-includes": "^3.0.3", + "ast-types-flow": "^0.0.7", + "axobject-query": "^2.0.2", + "damerau-levenshtein": "^1.0.4", + "emoji-regex": "^7.0.2", + "has": "^1.0.3", + "jsx-ast-utils": "^2.2.1" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + } + } + }, + "eslint-plugin-react": { + "version": "7.16.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.16.0.tgz", + "integrity": "sha512-GacBAATewhhptbK3/vTP09CbFrgUJmBSaaRcWdbQLFvUZy9yVcQxigBNHGPU/KE2AyHpzj3AWXpxoMTsIDiHug==", + "requires": { + "array-includes": "^3.0.3", + "doctrine": "^2.1.0", + "has": "^1.0.3", + "jsx-ast-utils": "^2.2.1", + "object.entries": "^1.1.0", + "object.fromentries": "^2.0.0", + "object.values": "^1.1.0", + "prop-types": "^15.7.2", + "resolve": "^1.12.0" + }, + "dependencies": { + "doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "requires": { + "esutils": "^2.0.2" + } + } + } + }, + "eslint-plugin-react-hooks": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-1.7.0.tgz", + "integrity": "sha512-iXTCFcOmlWvw4+TOE8CLWj6yX1GwzT0Y6cUfHHZqWnSk144VmVIRcVGtUAzrLES7C798lmvnt02C7rxaOX1HNA==" + }, + "eslint-scope": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", + "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "eslint-utils": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", + "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", + "requires": { + "eslint-visitor-keys": "^1.1.0" + } + }, + "eslint-visitor-keys": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", + "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==" + }, + "espree": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/espree/-/espree-6.1.2.tgz", + "integrity": "sha512-2iUPuuPP+yW1PZaMSDM9eyVf8D5P0Hi8h83YtZ5bPc/zHYjII5khoixIUTMO794NOY8F/ThF1Bo8ncZILarUTA==", + "requires": { + "acorn": "^7.1.0", + "acorn-jsx": "^5.1.0", + "eslint-visitor-keys": "^1.1.0" + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" + }, + "esquery": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", + "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", + "requires": { + "estraverse": "^4.0.0" + } + }, + "esrecurse": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", + "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", + "requires": { + "estraverse": "^4.1.0" + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==" + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==" + }, + "etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" + }, + "eventemitter3": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.0.tgz", + "integrity": "sha512-qerSRB0p+UDEssxTtm6EDKcE7W4OaoisfIMl4CngyEhjpYglocpNg6UEqCvemdGhosAsg4sO2dXJOdyBifPGCg==" + }, + "events": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.1.0.tgz", + "integrity": "sha512-Rv+u8MLHNOdMjTAFeT3nCjHn2aGlx435FP/sDHNaRhDEMwyI/aB22Kj2qIN8R0cw3z28psEQLYwxVKLsKrMgWg==" + }, + "eventsource": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/eventsource/-/eventsource-1.0.7.tgz", + "integrity": "sha512-4Ln17+vVT0k8aWq+t/bF5arcS3EpT9gYtW66EPacdj/mAFevznsnyoHLPy2BA8gbIQeIHoPsvwmfBftfcG//BQ==", + "requires": { + "original": "^1.0.0" + } + }, + "evp_bytestokey": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", + "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", + "requires": { + "md5.js": "^1.3.4", + "safe-buffer": "^5.1.1" + } + }, + "exec-sh": { + "version": "0.3.4", + "resolved": "https://registry.npmjs.org/exec-sh/-/exec-sh-0.3.4.tgz", + "integrity": "sha512-sEFIkc61v75sWeOe72qyrqg2Qg0OuLESziUDk/O/z2qgS15y2gWVFrI6f2Qn/qw/0/NCfCEsmNA4zOjkwEZT1A==" + }, + "execa": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", + "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "requires": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "exit": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", + "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=" + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "requires": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, + "expect": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/expect/-/expect-24.9.0.tgz", + "integrity": "sha512-wvVAx8XIol3Z5m9zvZXiyZOQ+sRJqNTIm6sGjdWlaZIeupQGO3WbYI+15D/AmEwZywL6wtJkbAbJtzkOfBuR0Q==", + "requires": { + "@jest/types": "^24.9.0", + "ansi-styles": "^3.2.0", + "jest-get-type": "^24.9.0", + "jest-matcher-utils": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-regex-util": "^24.9.0" + } + }, + "express": { + "version": "4.17.1", + "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", + "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", + "requires": { + "accepts": "~1.3.7", + "array-flatten": "1.1.1", + "body-parser": "1.19.0", + "content-disposition": "0.5.3", + "content-type": "~1.0.4", + "cookie": "0.4.0", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "~1.1.2", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "~1.1.2", + "fresh": "0.5.2", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.7", + "proxy-addr": "~2.0.5", + "qs": "6.7.0", + "range-parser": "~1.2.1", + "safe-buffer": "5.1.2", + "send": "0.17.1", + "serve-static": "1.14.1", + "setprototypeof": "1.1.1", + "statuses": "~1.5.0", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "dependencies": { + "array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", + "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" + } + } + }, + "ext": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/ext/-/ext-1.4.0.tgz", + "integrity": "sha512-Key5NIsUxdqKg3vIsdw9dSuXpPCQ297y6wBjL30edxwPgt2E44WcWBZey/ZvUc6sERLTxKdyCu4gZFmUbk1Q7A==", + "requires": { + "type": "^2.0.0" + }, + "dependencies": { + "type": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/type/-/type-2.0.0.tgz", + "integrity": "sha512-KBt58xCHry4Cejnc2ISQAF7QY+ORngsWfxezO68+12hKV6lQY8P/psIkcbjeHWn7MqcgciWJyCCevFMJdIXpow==" + } + } + }, + "extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" + }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "requires": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "external-editor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", + "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", + "requires": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "requires": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, + "extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" + }, + "fast-deep-equal": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", + "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=" + }, + "fast-glob": { + "version": "2.2.7", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-2.2.7.tgz", + "integrity": "sha512-g1KuQwHOZAmOZMuBtHdxDtju+T2RT8jgCC9aANsbpdiDDTSnjgfuVsIBNKbUeJI3oKMRExcfNDtJl4OhbffMsw==", + "requires": { + "@mrmlnc/readdir-enhanced": "^2.2.1", + "@nodelib/fs.stat": "^1.1.2", + "glob-parent": "^3.1.0", + "is-glob": "^4.0.0", + "merge2": "^1.2.3", + "micromatch": "^3.1.10" + }, + "dependencies": { + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "requires": { + "is-extglob": "^2.1.0" + } + } + } + } + } + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" + }, + "faye-websocket": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", + "integrity": "sha1-TkkvjQTftviQA1B/btvy1QHnxvQ=", + "requires": { + "websocket-driver": ">=0.5.1" + } + }, + "fb-watchman": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz", + "integrity": "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==", + "requires": { + "bser": "2.1.1" + } + }, + "fbjs": { + "version": "0.8.17", + "resolved": "https://registry.npmjs.org/fbjs/-/fbjs-0.8.17.tgz", + "integrity": "sha1-xNWY6taUkRJlPWWIsBpc3Nn5D90=", + "requires": { + "core-js": "^1.0.0", + "isomorphic-fetch": "^2.1.1", + "loose-envify": "^1.0.0", + "object-assign": "^4.1.0", + "promise": "^7.1.1", + "setimmediate": "^1.0.5", + "ua-parser-js": "^0.7.18" + }, + "dependencies": { + "core-js": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-1.2.7.tgz", + "integrity": "sha1-ZSKUwUZR2yj6k70tX/KYOk8IxjY=" + }, + "promise": { + "version": "7.3.1", + "resolved": "https://registry.npmjs.org/promise/-/promise-7.3.1.tgz", + "integrity": "sha512-nolQXZ/4L+bP/UGlkfaIujX9BKxGwmQ9OT4mOt5yvy8iK1h3wqTEJCijzGANTCCl9nWjY41juyAn2K3Q1hLLTg==", + "requires": { + "asap": "~2.0.3" + } + } + } + }, + "figgy-pudding": { + "version": "3.5.1", + "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.1.tgz", + "integrity": "sha512-vNKxJHTEKNThjfrdJwHc7brvM6eVevuO5nTj6ez8ZQ1qbXTvGthucRF7S4vf2cr71QVnT70V34v0S1DyQsti0w==" + }, + "figures": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-3.1.0.tgz", + "integrity": "sha512-ravh8VRXqHuMvZt/d8GblBeqDMkdJMBdv/2KntFH+ra5MXkO7nxNKpzQ3n6QD/2da1kH0aWmNISdvhM7gl2gVg==", + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "file-entry-cache": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", + "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", + "requires": { + "flat-cache": "^2.0.1" + } + }, + "file-loader": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/file-loader/-/file-loader-4.3.0.tgz", + "integrity": "sha512-aKrYPYjF1yG3oX0kWRrqrSMfgftm7oJW5M+m4owoldH5C51C0RkIwB++JbRvEW3IU6/ZG5n8UvEcdgwOt2UOWA==", + "requires": { + "loader-utils": "^1.2.3", + "schema-utils": "^2.5.0" + } + }, + "file-uri-to-path": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", + "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", + "optional": true + }, + "filesize": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/filesize/-/filesize-3.6.1.tgz", + "integrity": "sha512-7KjR1vv6qnicaPMi1iiTcI85CyYwRO/PSFCu6SvqL8jN2Wjt/NIYQTFtFs7fSDCYOstUkEWIQGFUg5YZQfjlcg==" + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "requires": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "finalhandler": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", + "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", + "requires": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "statuses": "~1.5.0", + "unpipe": "~1.0.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "requires": { + "locate-path": "^3.0.0" + } + }, + "flat-cache": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", + "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", + "requires": { + "flatted": "^2.0.0", + "rimraf": "2.6.3", + "write": "1.0.3" + } + }, + "flatted": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", + "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==" + }, + "flatten": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/flatten/-/flatten-1.0.3.tgz", + "integrity": "sha512-dVsPA/UwQ8+2uoFe5GHtiBMu48dWLTdsuEd7CKGlZlD78r1TTWBvDuFaFGKCo/ZfEr95Uk56vZoX86OsHkUeIg==" + }, + "flush-write-stream": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", + "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", + "requires": { + "inherits": "^2.0.3", + "readable-stream": "^2.3.6" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "follow-redirects": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.9.0.tgz", + "integrity": "sha512-CRcPzsSIbXyVDl0QI01muNDu69S8trU4jArW9LpOt2WtC6LyUJetcIrmfHsRBx7/Jb6GHJUiuqyYxPooFfNt6A==", + "requires": { + "debug": "^3.0.0" + }, + "dependencies": { + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" + }, + "for-own": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", + "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", + "requires": { + "for-in": "^1.0.1" + } + }, + "forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" + }, + "fork-ts-checker-webpack-plugin": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-3.1.0.tgz", + "integrity": "sha512-6OkRfjuNMNqb14f01xokcWcKV5Ekknc2FvziNpcTYru+kxIYFA2MtuuBI19MHThZnjSBhoi35Dcq+I0oUkFjmQ==", + "requires": { + "babel-code-frame": "^6.22.0", + "chalk": "^2.4.1", + "chokidar": "^2.0.4", + "micromatch": "^3.1.10", + "minimatch": "^3.0.4", + "semver": "^5.6.0", + "tapable": "^1.0.0", + "worker-rpc": "^0.1.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "form-data": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", + "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "forwarded": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", + "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" + }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "requires": { + "map-cache": "^0.2.2" + } + }, + "fresh": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", + "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" + }, + "from2": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/from2/-/from2-2.3.0.tgz", + "integrity": "sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8=", + "requires": { + "inherits": "^2.0.1", + "readable-stream": "^2.0.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "fs-extra": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", + "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", + "requires": { + "graceful-fs": "^4.2.0", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs-minipass": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.0.0.tgz", + "integrity": "sha512-40Qz+LFXmd9tzYVnnBmZvFfvAADfUA14TXPK1s7IfElJTIZ97rA8w4Kin7Wt5JBrC3ShnnFJO/5vPjPEeJIq9A==", + "requires": { + "minipass": "^3.0.0" + } + }, + "fs-write-stream-atomic": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz", + "integrity": "sha1-tH31NJPvkR33VzHnCp3tAYnbQMk=", + "requires": { + "graceful-fs": "^4.1.2", + "iferr": "^0.1.5", + "imurmurhash": "^0.1.4", + "readable-stream": "1 || 2" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" + }, + "fsevents": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.2.tgz", + "integrity": "sha512-R4wDiBwZ0KzpgOWetKDug1FZcYhqYnUYKtfZYt4mD5SBz76q0KR4Q9o7GIPamsVPGmW3EYPPJ0dOOjvx32ldZA==", + "optional": true + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=" + }, + "get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" + }, + "get-own-enumerable-property-symbols": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz", + "integrity": "sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==" + }, + "get-stream": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", + "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", + "requires": { + "pump": "^3.0.0" + } + }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=" + }, + "getpass": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "requires": { + "assert-plus": "^1.0.0" + } + }, + "glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.0.tgz", + "integrity": "sha512-qjtRgnIVmOfnKUE3NJAQEdk+lKrxfw8t5ke7SXtfMTHcjsBfOfWXCQfdb30zfDoZQ2IRSIiidmjtbHZPZ++Ihw==", + "requires": { + "is-glob": "^4.0.1" + } + }, + "glob-to-regexp": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.3.0.tgz", + "integrity": "sha1-jFoUlNIGbFcMw7/kSWF1rMTVAqs=" + }, + "global-modules": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-2.0.0.tgz", + "integrity": "sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A==", + "requires": { + "global-prefix": "^3.0.0" + } + }, + "global-prefix": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-3.0.0.tgz", + "integrity": "sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==", + "requires": { + "ini": "^1.3.5", + "kind-of": "^6.0.2", + "which": "^1.3.1" + }, + "dependencies": { + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, + "globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==" + }, + "globby": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/globby/-/globby-8.0.2.tgz", + "integrity": "sha512-yTzMmKygLp8RUpG1Ymu2VXPSJQZjNAZPD4ywgYEaG7e4tBJeUQBO8OpXrf1RCNcEs5alsoJYPAMiIHP0cmeC7w==", + "requires": { + "array-union": "^1.0.1", + "dir-glob": "2.0.0", + "fast-glob": "^2.0.2", + "glob": "^7.1.2", + "ignore": "^3.3.5", + "pify": "^3.0.0", + "slash": "^1.0.0" + }, + "dependencies": { + "ignore": { + "version": "3.3.10", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", + "integrity": "sha512-Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug==" + }, + "slash": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", + "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=" + } + } + }, + "graceful-fs": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", + "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==" + }, + "growly": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/growly/-/growly-1.3.0.tgz", + "integrity": "sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE=" + }, + "gzip-size": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/gzip-size/-/gzip-size-5.1.1.tgz", + "integrity": "sha512-FNHi6mmoHvs1mxZAds4PpdCS6QG8B4C1krxJsMutgxl5t3+GlRTzzI3NEkifXx2pVsOvJdOGSmIgDhQ55FwdPA==", + "requires": { + "duplexer": "^0.1.1", + "pify": "^4.0.1" + }, + "dependencies": { + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==" + } + } + }, + "handle-thing": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.0.tgz", + "integrity": "sha512-d4sze1JNC454Wdo2fkuyzCr6aHcbL6PGGuFAz0Li/NcOm1tCHGnWDRmJP85dh9IhQErTc2svWFEX5xHIOo//kQ==" + }, + "har-schema": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", + "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" + }, + "har-validator": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", + "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", + "requires": { + "ajv": "^6.5.5", + "har-schema": "^2.0.0" + } + }, + "harmony-reflect": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/harmony-reflect/-/harmony-reflect-1.6.1.tgz", + "integrity": "sha512-WJTeyp0JzGtHcuMsi7rw2VwtkvLa+JyfEKJCFyfcS0+CDkjQ5lHPu7zEhFZP+PDSRrEgXa5Ah0l1MbgbE41XjA==" + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "requires": { + "function-bind": "^1.1.1" + } + }, + "has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", + "requires": { + "ansi-regex": "^2.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + } + } + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" + }, + "has-symbols": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", + "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==" + }, + "has-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", + "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "requires": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "has-values": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", + "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "requires": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "dependencies": { + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "hash-base": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.0.4.tgz", + "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "hash.js": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", + "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", + "requires": { + "inherits": "^2.0.3", + "minimalistic-assert": "^1.0.1" + } + }, + "he": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", + "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==" + }, + "hex-color-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/hex-color-regex/-/hex-color-regex-1.1.0.tgz", + "integrity": "sha512-l9sfDFsuqtOqKDsQdqrMRk0U85RZc0RtOR9yPI7mRVOa4FsR/BVnZ0shmQRM96Ji99kYZP/7hn1cedc1+ApsTQ==" + }, + "hmac-drbg": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", + "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", + "requires": { + "hash.js": "^1.0.3", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "hoist-non-react-statics": { + "version": "2.5.5", + "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-2.5.5.tgz", + "integrity": "sha512-rqcy4pJo55FTTLWt+bU8ukscqHeE/e9KWvsOW2b/a3afxQZhwkQdT1rPPCJ0rYXdj4vNcasY8zHTH+jF/qStxw==" + }, + "hosted-git-info": { + "version": "2.8.5", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.5.tgz", + "integrity": "sha512-kssjab8CvdXfcXMXVcvsXum4Hwdq9XGtRD3TteMEvEbq0LXyiNQr6AprqKqfeaDXze7SxWvRxdpwE6ku7ikLkg==" + }, + "hpack.js": { + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz", + "integrity": "sha1-h3dMCUnlE/QuhFdbPEVoH63ioLI=", + "requires": { + "inherits": "^2.0.1", + "obuf": "^1.0.0", + "readable-stream": "^2.0.1", + "wbuf": "^1.1.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "hsl-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsl-regex/-/hsl-regex-1.0.0.tgz", + "integrity": "sha1-1JMwx4ntgZ4nakwNJy3/owsY/m4=" + }, + "hsla-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsla-regex/-/hsla-regex-1.0.0.tgz", + "integrity": "sha1-wc56MWjIxmFAM6S194d/OyJfnDg=" + }, + "html-comment-regex": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/html-comment-regex/-/html-comment-regex-1.1.2.tgz", + "integrity": "sha512-P+M65QY2JQ5Y0G9KKdlDpo0zK+/OHptU5AaBwUfAIDJZk1MYf32Frm84EcOytfJE0t5JvkAnKlmjsXDnWzCJmQ==" + }, + "html-encoding-sniffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-1.0.2.tgz", + "integrity": "sha512-71lZziiDnsuabfdYiUeWdCVyKuqwWi23L8YeIgV9jSSZHCtb6wB1BKWooH7L3tn4/FuZJMVWyNaIDr4RGmaSYw==", + "requires": { + "whatwg-encoding": "^1.0.1" + } + }, + "html-entities": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-1.2.1.tgz", + "integrity": "sha1-DfKTUfByEWNRXfueVUPl9u7VFi8=" + }, + "html-escaper": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.0.tgz", + "integrity": "sha512-a4u9BeERWGu/S8JiWEAQcdrg9v4QArtP9keViQjGMdff20fBdd8waotXaNmODqBe6uZ3Nafi7K/ho4gCQHV3Ig==" + }, + "html-minifier": { + "version": "3.5.21", + "resolved": "https://registry.npmjs.org/html-minifier/-/html-minifier-3.5.21.tgz", + "integrity": "sha512-LKUKwuJDhxNa3uf/LPR/KVjm/l3rBqtYeCOAekvG8F1vItxMUpueGd94i/asDDr8/1u7InxzFA5EeGjhhG5mMA==", + "requires": { + "camel-case": "3.0.x", + "clean-css": "4.2.x", + "commander": "2.17.x", + "he": "1.2.x", + "param-case": "2.1.x", + "relateurl": "0.2.x", + "uglify-js": "3.4.x" + }, + "dependencies": { + "commander": { + "version": "2.17.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", + "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==" + } + } + }, + "html-webpack-plugin": { + "version": "4.0.0-beta.5", + "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-4.0.0-beta.5.tgz", + "integrity": "sha512-y5l4lGxOW3pz3xBTFdfB9rnnrWRPVxlAhX6nrBYIcW+2k2zC3mSp/3DxlWVCMBfnO6UAnoF8OcFn0IMy6kaKAQ==", + "requires": { + "html-minifier": "^3.5.20", + "loader-utils": "^1.1.0", + "lodash": "^4.17.11", + "pretty-error": "^2.1.1", + "tapable": "^1.1.0", + "util.promisify": "1.0.0" + } + }, + "htmlparser2": { + "version": "3.10.1", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.10.1.tgz", + "integrity": "sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==", + "requires": { + "domelementtype": "^1.3.1", + "domhandler": "^2.3.0", + "domutils": "^1.5.1", + "entities": "^1.1.1", + "inherits": "^2.0.1", + "readable-stream": "^3.1.1" + }, + "dependencies": { + "entities": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", + "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==" + } + } + }, + "http-deceiver": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz", + "integrity": "sha1-+nFolEq5pRnTN8sL7HKE3D5yPYc=" + }, + "http-errors": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", + "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.1", + "statuses": ">= 1.5.0 < 2", + "toidentifier": "1.0.0" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + } + } + }, + "http-parser-js": { + "version": "0.4.10", + "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.4.10.tgz", + "integrity": "sha1-ksnBN0w1CF912zWexWzCV8u5P6Q=" + }, + "http-proxy": { + "version": "1.18.0", + "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.0.tgz", + "integrity": "sha512-84I2iJM/n1d4Hdgc6y2+qY5mDaz2PUVjlg9znE9byl+q0uC3DeByqBGReQu5tpLK0TAqTIXScRUV+dg7+bUPpQ==", + "requires": { + "eventemitter3": "^4.0.0", + "follow-redirects": "^1.0.0", + "requires-port": "^1.0.0" + } + }, + "http-proxy-middleware": { + "version": "0.19.1", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz", + "integrity": "sha512-yHYTgWMQO8VvwNS22eLLloAkvungsKdKTLO8AJlftYIKNfJr3GK3zK0ZCfzDDGUBttdGc8xFy1mCitvNKQtC3Q==", + "requires": { + "http-proxy": "^1.17.0", + "is-glob": "^4.0.0", + "lodash": "^4.17.11", + "micromatch": "^3.1.10" + } + }, + "http-signature": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", + "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", + "requires": { + "assert-plus": "^1.0.0", + "jsprim": "^1.2.2", + "sshpk": "^1.7.0" + } + }, + "https-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-1.0.0.tgz", + "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=" + }, + "hyphenate-style-name": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/hyphenate-style-name/-/hyphenate-style-name-1.0.3.tgz", + "integrity": "sha512-EcuixamT82oplpoJ2XU4pDtKGWQ7b00CD9f1ug9IaQ3p1bkHMiKCZ9ut9QDI6qsa6cpUuB+A/I+zLtdNK4n2DQ==" + }, + "iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "icss-utils": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-4.1.1.tgz", + "integrity": "sha512-4aFq7wvWyMHKgxsH8QQtGpvbASCf+eM3wPRLI6R+MgAnTCZ6STYsRvttLvRWK0Nfif5piF394St3HeJDaljGPA==", + "requires": { + "postcss": "^7.0.14" + } + }, + "identity-obj-proxy": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/identity-obj-proxy/-/identity-obj-proxy-3.0.0.tgz", + "integrity": "sha1-lNK9qWCERT7zb7xarsN+D3nx/BQ=", + "requires": { + "harmony-reflect": "^1.4.6" + } + }, + "ieee754": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", + "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==" + }, + "iferr": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/iferr/-/iferr-0.1.5.tgz", + "integrity": "sha1-xg7taebY/bazEEofy8ocGS3FtQE=" + }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==" + }, + "immer": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/immer/-/immer-1.10.0.tgz", + "integrity": "sha512-O3sR1/opvCDGLEVcvrGTMtLac8GJ5IwZC4puPrLuRj3l7ICKvkmA0vGuU9OW8mV9WIBRnaxp5GJh9IEAaNOoYg==" + }, + "import-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-cwd/-/import-cwd-2.1.0.tgz", + "integrity": "sha1-qmzzbnInYShcs3HsZRn1PiQ1sKk=", + "requires": { + "import-from": "^2.1.0" + } + }, + "import-fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", + "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", + "requires": { + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + } + }, + "import-from": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-from/-/import-from-2.1.0.tgz", + "integrity": "sha1-M1238qev/VOqpHHUuAId7ja387E=", + "requires": { + "resolve-from": "^3.0.0" + } + }, + "import-local": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-2.0.0.tgz", + "integrity": "sha512-b6s04m3O+s3CGSbqDIyP4R6aAwAeYlVq9+WUWep6iHa8ETRf9yei1U48C5MmfJmV9AiLYYBKPMq/W+/WRpQmCQ==", + "requires": { + "pkg-dir": "^3.0.0", + "resolve-cwd": "^2.0.0" + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" + }, + "indent-string": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", + "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==" + }, + "indexes-of": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/indexes-of/-/indexes-of-1.0.1.tgz", + "integrity": "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=" + }, + "infer-owner": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/infer-owner/-/infer-owner-1.0.4.tgz", + "integrity": "sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==" + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "ini": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", + "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" + }, + "inline-style-prefixer": { + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/inline-style-prefixer/-/inline-style-prefixer-3.0.8.tgz", + "integrity": "sha1-hVG45bTVcyROZqNLBPfTIHaitTQ=", + "requires": { + "bowser": "^1.7.3", + "css-in-js-utils": "^2.0.0" + } + }, + "inquirer": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.0.3.tgz", + "integrity": "sha512-+OiOVeVydu4hnCGLCSX+wedovR/Yzskv9BFqUNNKq9uU2qg7LCcCo3R86S2E7WLo0y/x2pnEZfZe1CoYnORUAw==", + "requires": { + "ansi-escapes": "^4.2.1", + "chalk": "^2.4.2", + "cli-cursor": "^3.1.0", + "cli-width": "^2.0.0", + "external-editor": "^3.0.3", + "figures": "^3.0.0", + "lodash": "^4.17.15", + "mute-stream": "0.0.8", + "run-async": "^2.2.0", + "rxjs": "^6.5.3", + "string-width": "^4.1.0", + "strip-ansi": "^5.1.0", + "through": "^2.3.6" + } + }, + "internal-ip": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/internal-ip/-/internal-ip-4.3.0.tgz", + "integrity": "sha512-S1zBo1D6zcsyuC6PMmY5+55YMILQ9av8lotMx447Bq6SAgo/sDK6y6uUKmuYhW7eacnIhFfsPmCNYdDzsnnDCg==", + "requires": { + "default-gateway": "^4.2.0", + "ipaddr.js": "^1.9.0" + } + }, + "invariant": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", + "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", + "requires": { + "loose-envify": "^1.0.0" + } + }, + "invert-kv": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", + "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==" + }, + "ip": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", + "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" + }, + "ip-regex": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/ip-regex/-/ip-regex-2.1.0.tgz", + "integrity": "sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=" + }, + "ipaddr.js": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz", + "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA==" + }, + "is-absolute-url": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-2.1.0.tgz", + "integrity": "sha1-UFMN+4T8yap9vnhS6Do3uTufKqY=" + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-arguments": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.0.4.tgz", + "integrity": "sha512-xPh0Rmt8NE65sNzvyUmWgI1tz3mKq74lGA0mL8LYZcoIzKOzDh6HmrYm3d18k60nHerC8A9Km8kYu87zfSFnLA==" + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" + }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "requires": { + "binary-extensions": "^1.0.0" + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" + }, + "is-callable": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.5.tgz", + "integrity": "sha512-ESKv5sMCJB2jnHTWZ3O5itG+O128Hsus4K4Qh1h2/cgn2vbgnLSVqfV46AeJA9D5EeeLa9w81KUXMtn34zhX+Q==" + }, + "is-ci": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", + "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", + "requires": { + "ci-info": "^2.0.0" + } + }, + "is-color-stop": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-color-stop/-/is-color-stop-1.1.0.tgz", + "integrity": "sha1-z/9HGu5N1cnhWFmPvhKWe1za00U=", + "requires": { + "css-color-names": "^0.0.4", + "hex-color-regex": "^1.1.0", + "hsl-regex": "^1.0.0", + "hsla-regex": "^1.0.0", + "rgb-regex": "^1.0.1", + "rgba-regex": "^1.0.0" + } + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-date-object": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", + "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==" + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==" + } + } + }, + "is-directory": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", + "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=" + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" + }, + "is-generator-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", + "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==" + }, + "is-glob": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", + "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-in-browser": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/is-in-browser/-/is-in-browser-1.1.3.tgz", + "integrity": "sha1-Vv9NtoOgeMYILrldrX3GLh0E+DU=" + }, + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-obj": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", + "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=" + }, + "is-path-cwd": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-2.2.0.tgz", + "integrity": "sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==" + }, + "is-path-in-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz", + "integrity": "sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ==", + "requires": { + "is-path-inside": "^2.1.0" + } + }, + "is-path-inside": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-2.1.0.tgz", + "integrity": "sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg==", + "requires": { + "path-is-inside": "^1.0.2" + } + }, + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=" + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "requires": { + "isobject": "^3.0.1" + } + }, + "is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", + "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" + }, + "is-regex": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.5.tgz", + "integrity": "sha512-vlKW17SNq44owv5AQR3Cq0bQPEb8+kF3UKZ2fiZNOWtztYE5i0CzCZxFDwO58qAOWtxdBRVO/V5Qin1wjCqFYQ==", + "requires": { + "has": "^1.0.3" + } + }, + "is-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz", + "integrity": "sha1-/S2INUXEa6xaYz57mgnof6LLUGk=" + }, + "is-resolvable": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", + "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==" + }, + "is-root": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-root/-/is-root-2.1.0.tgz", + "integrity": "sha512-AGOriNp96vNBd3HtU+RzFEc75FfR5ymiYv8E553I71SCeXBiMsVDUtdio1OEFvrPyLIQ9tVR5RxXIFe5PUFjMg==" + }, + "is-stream": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", + "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" + }, + "is-string": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", + "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==" + }, + "is-svg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-svg/-/is-svg-3.0.0.tgz", + "integrity": "sha512-gi4iHK53LR2ujhLVVj+37Ykh9GLqYHX6JOVXbLAucaG/Cqw9xwdFOjDM2qeifLs1sF1npXXFvDu0r5HNgCMrzQ==", + "requires": { + "html-comment-regex": "^1.1.0" + } + }, + "is-symbol": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", + "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", + "requires": { + "has-symbols": "^1.0.1" + } + }, + "is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" + }, + "is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==" + }, + "is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-1.1.0.tgz", + "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=" + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + }, + "isomorphic-fetch": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz", + "integrity": "sha1-YRrhrPFPXoH3KVB0coGf6XM1WKk=", + "requires": { + "node-fetch": "^1.0.1", + "whatwg-fetch": ">=0.10.0" + } + }, + "isstream": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" + }, + "istanbul-lib-coverage": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.5.tgz", + "integrity": "sha512-8aXznuEPCJvGnMSRft4udDRDtb1V3pkQkMMI5LI+6HuQz5oQ4J2UFn1H82raA3qJtyOLkkwVqICBQkjnGtn5mA==" + }, + "istanbul-lib-instrument": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-3.3.0.tgz", + "integrity": "sha512-5nnIN4vo5xQZHdXno/YDXJ0G+I3dAm4XgzfSVTPLQpj/zAV2dV6Juy0yaf10/zrJOJeHoN3fraFe+XRq2bFVZA==", + "requires": { + "@babel/generator": "^7.4.0", + "@babel/parser": "^7.4.3", + "@babel/template": "^7.4.0", + "@babel/traverse": "^7.4.3", + "@babel/types": "^7.4.0", + "istanbul-lib-coverage": "^2.0.5", + "semver": "^6.0.0" + } + }, + "istanbul-lib-report": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-2.0.8.tgz", + "integrity": "sha512-fHBeG573EIihhAblwgxrSenp0Dby6tJMFR/HvlerBsrCTD5bkUuoNtn3gVh29ZCS824cGGBPn7Sg7cNk+2xUsQ==", + "requires": { + "istanbul-lib-coverage": "^2.0.5", + "make-dir": "^2.1.0", + "supports-color": "^6.1.0" + }, + "dependencies": { + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "istanbul-lib-source-maps": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-3.0.6.tgz", + "integrity": "sha512-R47KzMtDJH6X4/YW9XTx+jrLnZnscW4VpNN+1PViSYTejLVPWv7oov+Duf8YQSPyVRUvueQqz1TcsC6mooZTXw==", + "requires": { + "debug": "^4.1.1", + "istanbul-lib-coverage": "^2.0.5", + "make-dir": "^2.1.0", + "rimraf": "^2.6.3", + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "istanbul-reports": { + "version": "2.2.7", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-2.2.7.tgz", + "integrity": "sha512-uu1F/L1o5Y6LzPVSVZXNOoD/KXpJue9aeLRd0sM9uMXfZvzomB0WxVamWb5ue8kA2vVWEmW7EG+A5n3f1kqHKg==", + "requires": { + "html-escaper": "^2.0.0" + } + }, + "jest": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest/-/jest-24.9.0.tgz", + "integrity": "sha512-YvkBL1Zm7d2B1+h5fHEOdyjCG+sGMz4f8D86/0HiqJ6MB4MnDc8FgP5vdWsGnemOQro7lnYo8UakZ3+5A0jxGw==", + "requires": { + "import-local": "^2.0.0", + "jest-cli": "^24.9.0" + }, + "dependencies": { + "jest-cli": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-24.9.0.tgz", + "integrity": "sha512-+VLRKyitT3BWoMeSUIHRxV/2g8y9gw91Jh5z2UmXZzkZKpbC08CSehVxgHUwTpy+HwGcns/tqafQDJW7imYvGg==", + "requires": { + "@jest/core": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "import-local": "^2.0.0", + "is-ci": "^2.0.0", + "jest-config": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "prompts": "^2.0.1", + "realpath-native": "^1.1.0", + "yargs": "^13.3.0" + } + } + } + }, + "jest-changed-files": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-24.9.0.tgz", + "integrity": "sha512-6aTWpe2mHF0DhL28WjdkO8LyGjs3zItPET4bMSeXU6T3ub4FPMw+mcOcbdGXQOAfmLcxofD23/5Bl9Z4AkFwqg==", + "requires": { + "@jest/types": "^24.9.0", + "execa": "^1.0.0", + "throat": "^4.0.0" + } + }, + "jest-config": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-24.9.0.tgz", + "integrity": "sha512-RATtQJtVYQrp7fvWg6f5y3pEFj9I+H8sWw4aKxnDZ96mob5i5SD6ZEGWgMLXQ4LE8UurrjbdlLWdUeo+28QpfQ==", + "requires": { + "@babel/core": "^7.1.0", + "@jest/test-sequencer": "^24.9.0", + "@jest/types": "^24.9.0", + "babel-jest": "^24.9.0", + "chalk": "^2.0.1", + "glob": "^7.1.1", + "jest-environment-jsdom": "^24.9.0", + "jest-environment-node": "^24.9.0", + "jest-get-type": "^24.9.0", + "jest-jasmine2": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-resolve": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "micromatch": "^3.1.10", + "pretty-format": "^24.9.0", + "realpath-native": "^1.1.0" + } + }, + "jest-diff": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-24.9.0.tgz", + "integrity": "sha512-qMfrTs8AdJE2iqrTp0hzh7kTd2PQWrsFyj9tORoKmu32xjPjeE4NyjVRDz8ybYwqS2ik8N4hsIpiVTyFeo2lBQ==", + "requires": { + "chalk": "^2.0.1", + "diff-sequences": "^24.9.0", + "jest-get-type": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-docblock": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-24.9.0.tgz", + "integrity": "sha512-F1DjdpDMJMA1cN6He0FNYNZlo3yYmOtRUnktrT9Q37njYzC5WEaDdmbynIgy0L/IvXvvgsG8OsqhLPXTpfmZAA==", + "requires": { + "detect-newline": "^2.1.0" + } + }, + "jest-each": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-24.9.0.tgz", + "integrity": "sha512-ONi0R4BvW45cw8s2Lrx8YgbeXL1oCQ/wIDwmsM3CqM/nlblNCPmnC3IPQlMbRFZu3wKdQ2U8BqM6lh3LJ5Bsog==", + "requires": { + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "jest-get-type": "^24.9.0", + "jest-util": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-environment-jsdom": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-24.9.0.tgz", + "integrity": "sha512-Zv9FV9NBRzLuALXjvRijO2351DRQeLYXtpD4xNvfoVFw21IOKNhZAEUKcbiEtjTkm2GsJ3boMVgkaR7rN8qetA==", + "requires": { + "@jest/environment": "^24.9.0", + "@jest/fake-timers": "^24.9.0", + "@jest/types": "^24.9.0", + "jest-mock": "^24.9.0", + "jest-util": "^24.9.0", + "jsdom": "^11.5.1" + } + }, + "jest-environment-jsdom-fourteen": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom-fourteen/-/jest-environment-jsdom-fourteen-0.1.0.tgz", + "integrity": "sha512-4vtoRMg7jAstitRzL4nbw83VmGH8Rs13wrND3Ud2o1fczDhMUF32iIrNKwYGgeOPUdfvZU4oy8Bbv+ni1fgVCA==", + "requires": { + "jest-mock": "^24.5.0", + "jest-util": "^24.5.0", + "jsdom": "^14.0.0" + }, + "dependencies": { + "acorn": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.0.tgz", + "integrity": "sha512-gac8OEcQ2Li1dxIEWGZzsp2BitJxwkwcOm0zHAJLcPJaVvm58FRnk6RkuLRpU1EujipU2ZFODv2P9DLMfnV8mw==" + }, + "jsdom": { + "version": "14.1.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-14.1.0.tgz", + "integrity": "sha512-O901mfJSuTdwU2w3Sn+74T+RnDVP+FuV5fH8tcPWyqrseRAb0s5xOtPgCFiPOtLcyK7CLIJwPyD83ZqQWvA5ng==", + "requires": { + "abab": "^2.0.0", + "acorn": "^6.0.4", + "acorn-globals": "^4.3.0", + "array-equal": "^1.0.0", + "cssom": "^0.3.4", + "cssstyle": "^1.1.1", + "data-urls": "^1.1.0", + "domexception": "^1.0.1", + "escodegen": "^1.11.0", + "html-encoding-sniffer": "^1.0.2", + "nwsapi": "^2.1.3", + "parse5": "5.1.0", + "pn": "^1.1.0", + "request": "^2.88.0", + "request-promise-native": "^1.0.5", + "saxes": "^3.1.9", + "symbol-tree": "^3.2.2", + "tough-cookie": "^2.5.0", + "w3c-hr-time": "^1.0.1", + "w3c-xmlserializer": "^1.1.2", + "webidl-conversions": "^4.0.2", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^7.0.0", + "ws": "^6.1.2", + "xml-name-validator": "^3.0.0" + } + }, + "parse5": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.0.tgz", + "integrity": "sha512-fxNG2sQjHvlVAYmzBZS9YlDp6PTSSDwa98vkD4QgVDDCAo84z5X1t5XyJQ62ImdLXx5NdIIfihey6xpum9/gRQ==" + }, + "whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", + "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "ws": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.1.tgz", + "integrity": "sha512-GIyAXC2cB7LjvpgMt9EKS2ldqr0MTrORaleiOno6TweZ6r3TKtoFQWay/2PceJ3RuBasOHzXNn5Lrw1X0bEjqA==", + "requires": { + "async-limiter": "~1.0.0" + } + } + } + }, + "jest-environment-node": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-24.9.0.tgz", + "integrity": "sha512-6d4V2f4nxzIzwendo27Tr0aFm+IXWa0XEUnaH6nU0FMaozxovt+sfRvh4J47wL1OvF83I3SSTu0XK+i4Bqe7uA==", + "requires": { + "@jest/environment": "^24.9.0", + "@jest/fake-timers": "^24.9.0", + "@jest/types": "^24.9.0", + "jest-mock": "^24.9.0", + "jest-util": "^24.9.0" + } + }, + "jest-get-type": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-24.9.0.tgz", + "integrity": "sha512-lUseMzAley4LhIcpSP9Jf+fTrQ4a1yHQwLNeeVa2cEmbCGeoZAtYPOIv8JaxLD/sUpKxetKGP+gsHl8f8TSj8Q==" + }, + "jest-haste-map": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-24.9.0.tgz", + "integrity": "sha512-kfVFmsuWui2Sj1Rp1AJ4D9HqJwE4uwTlS/vO+eRUaMmd54BFpli2XhMQnPC2k4cHFVbB2Q2C+jtI1AGLgEnCjQ==", + "requires": { + "@jest/types": "^24.9.0", + "anymatch": "^2.0.0", + "fb-watchman": "^2.0.0", + "fsevents": "^1.2.7", + "graceful-fs": "^4.1.15", + "invariant": "^2.2.4", + "jest-serializer": "^24.9.0", + "jest-util": "^24.9.0", + "jest-worker": "^24.9.0", + "micromatch": "^3.1.10", + "sane": "^4.0.3", + "walker": "^1.0.7" + }, + "dependencies": { + "fsevents": { + "version": "1.2.11", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.11.tgz", + "integrity": "sha512-+ux3lx6peh0BpvY0JebGyZoiR4D+oYzdPZMKJwkZ+sFkNJzpL7tXc/wehS49gUAxg3tmMHPHZkA8JU2rhhgDHw==", + "optional": true, + "requires": { + "bindings": "^1.5.0", + "nan": "^2.12.1", + "node-pre-gyp": "*" + }, + "dependencies": { + "abbrev": { + "version": "1.1.1", + "bundled": true, + "optional": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true + }, + "aproba": { + "version": "1.2.0", + "bundled": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.5", + "bundled": true, + "optional": true, + "requires": { + "delegates": "^1.0.0", + "readable-stream": "^2.0.6" + } + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "brace-expansion": { + "version": "1.1.11", + "bundled": true, + "optional": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "chownr": { + "version": "1.1.3", + "bundled": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "optional": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "debug": { + "version": "3.2.6", + "bundled": true, + "optional": true, + "requires": { + "ms": "^2.1.1" + } + }, + "deep-extend": { + "version": "0.6.0", + "bundled": true, + "optional": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "detect-libc": { + "version": "1.0.3", + "bundled": true, + "optional": true + }, + "fs-minipass": { + "version": "1.2.7", + "bundled": true, + "optional": true, + "requires": { + "minipass": "^2.6.0" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "optional": true, + "requires": { + "aproba": "^1.0.3", + "console-control-strings": "^1.0.0", + "has-unicode": "^2.0.0", + "object-assign": "^4.1.0", + "signal-exit": "^3.0.0", + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wide-align": "^1.1.0" + } + }, + "glob": { + "version": "7.1.6", + "bundled": true, + "optional": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "iconv-lite": { + "version": "0.4.24", + "bundled": true, + "optional": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "ignore-walk": { + "version": "3.0.3", + "bundled": true, + "optional": true, + "requires": { + "minimatch": "^3.0.4" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "optional": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "bundled": true + }, + "ini": { + "version": "1.3.5", + "bundled": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "optional": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true + }, + "minipass": { + "version": "2.9.0", + "bundled": true, + "requires": { + "safe-buffer": "^5.1.2", + "yallist": "^3.0.0" + } + }, + "minizlib": { + "version": "1.3.3", + "bundled": true, + "optional": true, + "requires": { + "minipass": "^2.9.0" + } + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.1.2", + "bundled": true, + "optional": true + }, + "needle": { + "version": "2.4.0", + "bundled": true, + "optional": true, + "requires": { + "debug": "^3.2.6", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + } + }, + "node-pre-gyp": { + "version": "0.14.0", + "bundled": true, + "optional": true, + "requires": { + "detect-libc": "^1.0.2", + "mkdirp": "^0.5.1", + "needle": "^2.2.1", + "nopt": "^4.0.1", + "npm-packlist": "^1.1.6", + "npmlog": "^4.0.2", + "rc": "^1.2.7", + "rimraf": "^2.6.1", + "semver": "^5.3.0", + "tar": "^4.4.2" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "optional": true, + "requires": { + "abbrev": "1", + "osenv": "^0.1.4" + } + }, + "npm-bundled": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "npm-normalize-package-bin": "^1.0.1" + } + }, + "npm-normalize-package-bin": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "npm-packlist": { + "version": "1.4.7", + "bundled": true, + "optional": true, + "requires": { + "ignore-walk": "^3.0.1", + "npm-bundled": "^1.0.1" + } + }, + "npmlog": { + "version": "4.1.2", + "bundled": true, + "optional": true, + "requires": { + "are-we-there-yet": "~1.1.2", + "console-control-strings": "~1.1.0", + "gauge": "~2.7.3", + "set-blocking": "~2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "requires": { + "wrappy": "1" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "osenv": { + "version": "0.1.5", + "bundled": true, + "optional": true, + "requires": { + "os-homedir": "^1.0.0", + "os-tmpdir": "^1.0.0" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "process-nextick-args": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "rc": { + "version": "1.2.8", + "bundled": true, + "optional": true, + "requires": { + "deep-extend": "^0.6.0", + "ini": "~1.3.0", + "minimist": "^1.2.0", + "strip-json-comments": "~2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.3.6", + "bundled": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "rimraf": { + "version": "2.7.1", + "bundled": true, + "optional": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-buffer": { + "version": "5.1.2", + "bundled": true + }, + "safer-buffer": { + "version": "2.1.2", + "bundled": true, + "optional": true + }, + "sax": { + "version": "1.2.4", + "bundled": true, + "optional": true + }, + "semver": { + "version": "5.7.1", + "bundled": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "optional": true + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "string_decoder": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "tar": { + "version": "4.4.13", + "bundled": true, + "optional": true, + "requires": { + "chownr": "^1.1.1", + "fs-minipass": "^1.2.5", + "minipass": "^2.8.6", + "minizlib": "^1.2.1", + "mkdirp": "^0.5.0", + "safe-buffer": "^5.1.2", + "yallist": "^3.0.3" + } + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "wide-align": { + "version": "1.1.3", + "bundled": true, + "optional": true, + "requires": { + "string-width": "^1.0.2 || 2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true + }, + "yallist": { + "version": "3.1.1", + "bundled": true + } + } + } + } + }, + "jest-jasmine2": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-24.9.0.tgz", + "integrity": "sha512-Cq7vkAgaYKp+PsX+2/JbTarrk0DmNhsEtqBXNwUHkdlbrTBLtMJINADf2mf5FkowNsq8evbPc07/qFO0AdKTzw==", + "requires": { + "@babel/traverse": "^7.1.0", + "@jest/environment": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "co": "^4.6.0", + "expect": "^24.9.0", + "is-generator-fn": "^2.0.0", + "jest-each": "^24.9.0", + "jest-matcher-utils": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-snapshot": "^24.9.0", + "jest-util": "^24.9.0", + "pretty-format": "^24.9.0", + "throat": "^4.0.0" + } + }, + "jest-leak-detector": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-24.9.0.tgz", + "integrity": "sha512-tYkFIDsiKTGwb2FG1w8hX9V0aUb2ot8zY/2nFg087dUageonw1zrLMP4W6zsRO59dPkTSKie+D4rhMuP9nRmrA==", + "requires": { + "jest-get-type": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-matcher-utils": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-24.9.0.tgz", + "integrity": "sha512-OZz2IXsu6eaiMAwe67c1T+5tUAtQyQx27/EMEkbFAGiw52tB9em+uGbzpcgYVpA8wl0hlxKPZxrly4CXU/GjHA==", + "requires": { + "chalk": "^2.0.1", + "jest-diff": "^24.9.0", + "jest-get-type": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-message-util": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-24.9.0.tgz", + "integrity": "sha512-oCj8FiZ3U0hTP4aSui87P4L4jC37BtQwUMqk+zk/b11FR19BJDeZsZAvIHutWnmtw7r85UmR3CEWZ0HWU2mAlw==", + "requires": { + "@babel/code-frame": "^7.0.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/stack-utils": "^1.0.1", + "chalk": "^2.0.1", + "micromatch": "^3.1.10", + "slash": "^2.0.0", + "stack-utils": "^1.0.1" + } + }, + "jest-mock": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-24.9.0.tgz", + "integrity": "sha512-3BEYN5WbSq9wd+SyLDES7AHnjH9A/ROBwmz7l2y+ol+NtSFO8DYiEBzoO1CeFc9a8DYy10EO4dDFVv/wN3zl1w==", + "requires": { + "@jest/types": "^24.9.0" + } + }, + "jest-pnp-resolver": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.1.tgz", + "integrity": "sha512-pgFw2tm54fzgYvc/OHrnysABEObZCUNFnhjoRjaVOCN8NYc032/gVjPaHD4Aq6ApkSieWtfKAFQtmDKAmhupnQ==" + }, + "jest-regex-util": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-24.9.0.tgz", + "integrity": "sha512-05Cmb6CuxaA+Ys6fjr3PhvV3bGQmO+2p2La4hFbU+W5uOc479f7FdLXUWXw4pYMAhhSZIuKHwSXSu6CsSBAXQA==" + }, + "jest-resolve": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-24.9.0.tgz", + "integrity": "sha512-TaLeLVL1l08YFZAt3zaPtjiVvyy4oSA6CRe+0AFPPVX3Q/VI0giIWWoAvoS5L96vj9Dqxj4fB5p2qrHCmTU/MQ==", + "requires": { + "@jest/types": "^24.9.0", + "browser-resolve": "^1.11.3", + "chalk": "^2.0.1", + "jest-pnp-resolver": "^1.2.1", + "realpath-native": "^1.1.0" + } + }, + "jest-resolve-dependencies": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-24.9.0.tgz", + "integrity": "sha512-Fm7b6AlWnYhT0BXy4hXpactHIqER7erNgIsIozDXWl5dVm+k8XdGVe1oTg1JyaFnOxarMEbax3wyRJqGP2Pq+g==", + "requires": { + "@jest/types": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-snapshot": "^24.9.0" + } + }, + "jest-runner": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-24.9.0.tgz", + "integrity": "sha512-KksJQyI3/0mhcfspnxxEOBueGrd5E4vV7ADQLT9ESaCzz02WnbdbKWIf5Mkaucoaj7obQckYPVX6JJhgUcoWWg==", + "requires": { + "@jest/console": "^24.7.1", + "@jest/environment": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.4.2", + "exit": "^0.1.2", + "graceful-fs": "^4.1.15", + "jest-config": "^24.9.0", + "jest-docblock": "^24.3.0", + "jest-haste-map": "^24.9.0", + "jest-jasmine2": "^24.9.0", + "jest-leak-detector": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-resolve": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-util": "^24.9.0", + "jest-worker": "^24.6.0", + "source-map-support": "^0.5.6", + "throat": "^4.0.0" + } + }, + "jest-runtime": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-24.9.0.tgz", + "integrity": "sha512-8oNqgnmF3v2J6PVRM2Jfuj8oX3syKmaynlDMMKQ4iyzbQzIG6th5ub/lM2bCMTmoTKM3ykcUYI2Pw9xwNtjMnw==", + "requires": { + "@jest/console": "^24.7.1", + "@jest/environment": "^24.9.0", + "@jest/source-map": "^24.3.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/yargs": "^13.0.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "glob": "^7.1.3", + "graceful-fs": "^4.1.15", + "jest-config": "^24.9.0", + "jest-haste-map": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-mock": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-resolve": "^24.9.0", + "jest-snapshot": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "realpath-native": "^1.1.0", + "slash": "^2.0.0", + "strip-bom": "^3.0.0", + "yargs": "^13.3.0" + } + }, + "jest-serializer": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-24.9.0.tgz", + "integrity": "sha512-DxYipDr8OvfrKH3Kel6NdED3OXxjvxXZ1uIY2I9OFbGg+vUkkg7AGvi65qbhbWNPvDckXmzMPbK3u3HaDO49bQ==" + }, + "jest-snapshot": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-24.9.0.tgz", + "integrity": "sha512-uI/rszGSs73xCM0l+up7O7a40o90cnrk429LOiK3aeTvfC0HHmldbd81/B7Ix81KSFe1lwkbl7GnBGG4UfuDew==", + "requires": { + "@babel/types": "^7.0.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "expect": "^24.9.0", + "jest-diff": "^24.9.0", + "jest-get-type": "^24.9.0", + "jest-matcher-utils": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-resolve": "^24.9.0", + "mkdirp": "^0.5.1", + "natural-compare": "^1.4.0", + "pretty-format": "^24.9.0", + "semver": "^6.2.0" + } + }, + "jest-util": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-24.9.0.tgz", + "integrity": "sha512-x+cZU8VRmOJxbA1K5oDBdxQmdq0OIdADarLxk0Mq+3XS4jgvhG/oKGWcIDCtPG0HgjxOYvF+ilPJQsAyXfbNOg==", + "requires": { + "@jest/console": "^24.9.0", + "@jest/fake-timers": "^24.9.0", + "@jest/source-map": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "callsites": "^3.0.0", + "chalk": "^2.0.1", + "graceful-fs": "^4.1.15", + "is-ci": "^2.0.0", + "mkdirp": "^0.5.1", + "slash": "^2.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "jest-validate": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-24.9.0.tgz", + "integrity": "sha512-HPIt6C5ACwiqSiwi+OfSSHbK8sG7akG8eATl+IPKaeIjtPOeBUd/g3J7DghugzxrGjI93qS/+RPKe1H6PqvhRQ==", + "requires": { + "@jest/types": "^24.9.0", + "camelcase": "^5.3.1", + "chalk": "^2.0.1", + "jest-get-type": "^24.9.0", + "leven": "^3.1.0", + "pretty-format": "^24.9.0" + } + }, + "jest-watch-typeahead": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/jest-watch-typeahead/-/jest-watch-typeahead-0.4.2.tgz", + "integrity": "sha512-f7VpLebTdaXs81rg/oj4Vg/ObZy2QtGzAmGLNsqUS5G5KtSN68tFcIsbvNODfNyQxU78g7D8x77o3bgfBTR+2Q==", + "requires": { + "ansi-escapes": "^4.2.1", + "chalk": "^2.4.1", + "jest-regex-util": "^24.9.0", + "jest-watcher": "^24.3.0", + "slash": "^3.0.0", + "string-length": "^3.1.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==" + }, + "string-length": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-length/-/string-length-3.1.0.tgz", + "integrity": "sha512-Ttp5YvkGm5v9Ijagtaz1BnN+k9ObpvS0eIBblPMp2YWL8FBmi9qblQ9fexc2k/CXFgrTIteU3jAw3payCnwSTA==", + "requires": { + "astral-regex": "^1.0.0", + "strip-ansi": "^5.2.0" + } + } + } + }, + "jest-watcher": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-24.9.0.tgz", + "integrity": "sha512-+/fLOfKPXXYJDYlks62/4R4GoT+GU1tYZed99JSCOsmzkkF7727RqKrjNAxtfO4YpGv11wybgRvCjR73lK2GZw==", + "requires": { + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/yargs": "^13.0.0", + "ansi-escapes": "^3.0.0", + "chalk": "^2.0.1", + "jest-util": "^24.9.0", + "string-length": "^2.0.0" + }, + "dependencies": { + "ansi-escapes": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", + "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==" + } + } + }, + "jest-worker": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-24.9.0.tgz", + "integrity": "sha512-51PE4haMSXcHohnSMdM42anbvZANYTqMrr52tVKPqqsPJMzoP6FYYDVqahX/HrAoKEKz3uUPzSvKs9A3qR4iVw==", + "requires": { + "merge-stream": "^2.0.0", + "supports-color": "^6.1.0" + }, + "dependencies": { + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "js-levenshtein": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/js-levenshtein/-/js-levenshtein-1.1.6.tgz", + "integrity": "sha512-X2BB11YZtrRqY4EnQcLX5Rh373zbK4alC1FW7D7MBhL2gtcC17cTnr6DmfHZeS0s2rTHjUTMMHfG7gO8SSdw+g==" + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" + }, + "js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" + }, + "jsdom": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-11.12.0.tgz", + "integrity": "sha512-y8Px43oyiBM13Zc1z780FrfNLJCXTL40EWlty/LXUtcjykRBNgLlCjWXpfSPBl2iv+N7koQN+dvqszHZgT/Fjw==", + "requires": { + "abab": "^2.0.0", + "acorn": "^5.5.3", + "acorn-globals": "^4.1.0", + "array-equal": "^1.0.0", + "cssom": ">= 0.3.2 < 0.4.0", + "cssstyle": "^1.0.0", + "data-urls": "^1.0.0", + "domexception": "^1.0.1", + "escodegen": "^1.9.1", + "html-encoding-sniffer": "^1.0.2", + "left-pad": "^1.3.0", + "nwsapi": "^2.0.7", + "parse5": "4.0.0", + "pn": "^1.1.0", + "request": "^2.87.0", + "request-promise-native": "^1.0.5", + "sax": "^1.2.4", + "symbol-tree": "^3.2.2", + "tough-cookie": "^2.3.4", + "w3c-hr-time": "^1.0.1", + "webidl-conversions": "^4.0.2", + "whatwg-encoding": "^1.0.3", + "whatwg-mimetype": "^2.1.0", + "whatwg-url": "^6.4.1", + "ws": "^5.2.0", + "xml-name-validator": "^3.0.0" + }, + "dependencies": { + "acorn": { + "version": "5.7.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.7.3.tgz", + "integrity": "sha512-T/zvzYRfbVojPWahDsE5evJdHb3oJoQfFbsrKM7w5Zcs++Tr257tia3BmMP8XYVjp1S9RZXQMh7gao96BlqZOw==" + } + } + }, + "jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==" + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==" + }, + "json-schema": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" + }, + "json-stable-stringify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", + "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", + "requires": { + "jsonify": "~0.0.0" + } + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=" + }, + "json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" + }, + "json3": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/json3/-/json3-3.3.3.tgz", + "integrity": "sha512-c7/8mbUsKigAbLkD5B010BK4D9LZm7A1pNItkEwiUZRpIN66exu/e7YQWysGun+TRKaJp8MhemM+VkfWv42aCA==" + }, + "json5": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.1.tgz", + "integrity": "sha512-l+3HXD0GEI3huGq1njuqtzYK8OYJyXMkOLtQ53pjWh89tvWS2h6l+1zMkYWqlb57+SiQodKZyvMEFb2X+KrFhQ==", + "requires": { + "minimist": "^1.2.0" + } + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "jsonify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", + "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=" + }, + "jsprim": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", + "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.3.0", + "json-schema": "0.2.3", + "verror": "1.10.0" + } + }, + "jss": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss/-/jss-10.0.3.tgz", + "integrity": "sha512-AcDvFdOk16If9qvC9KN3oFXsrkHWM9+TaPMpVB9orm3z+nq1Xw3ofHyflRe/mkSucRZnaQtlhZs1hdP3DR9uRw==", + "requires": { + "@babel/runtime": "^7.3.1", + "csstype": "^2.6.5", + "is-in-browser": "^1.1.3", + "tiny-warning": "^1.0.2" + } + }, + "jss-plugin-camel-case": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss-plugin-camel-case/-/jss-plugin-camel-case-10.0.3.tgz", + "integrity": "sha512-rild/oFKFkmRP7AoiX9D6bdDAUfmJv8c7sEBvFoi+JP31dn2W8nw4txMKGnV1LJKlFkYprdZt1X99Uvztl1hug==", + "requires": { + "@babel/runtime": "^7.3.1", + "hyphenate-style-name": "^1.0.3", + "jss": "^10.0.3" + } + }, + "jss-plugin-default-unit": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss-plugin-default-unit/-/jss-plugin-default-unit-10.0.3.tgz", + "integrity": "sha512-n+XfVLPF9Qh7IOTdQ8M4oRpjpg6egjr/r0NNytubbCafMgCILJYIVrMTGgOTydH+uvak8onQY3f/F9hasPUx6g==", + "requires": { + "@babel/runtime": "^7.3.1", + "jss": "^10.0.3" + } + }, + "jss-plugin-global": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss-plugin-global/-/jss-plugin-global-10.0.3.tgz", + "integrity": "sha512-kNotkAciJIXpIGYnmueaIifBne9rdq31O8Xq1nF7KMfKlskNRANTcEX5rVnsGKl2yubTMYfjKBFCeDgcQn6+gA==", + "requires": { + "@babel/runtime": "^7.3.1", + "jss": "^10.0.3" + } + }, + "jss-plugin-nested": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss-plugin-nested/-/jss-plugin-nested-10.0.3.tgz", + "integrity": "sha512-OMucRs9YLvWlZ3Ew+VhdgNVMwSS2zZy/2vy+s/etvopnPUzDHgCnJwdY2Wx/SlhLGERJeKKufyih2seH+ui0iw==", + "requires": { + "@babel/runtime": "^7.3.1", + "jss": "^10.0.3", + "tiny-warning": "^1.0.2" + } + }, + "jss-plugin-props-sort": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss-plugin-props-sort/-/jss-plugin-props-sort-10.0.3.tgz", + "integrity": "sha512-ufhvdCMnRcDa0tNHoZ12OcVNQQyE10yLMohxo/UIMarLV245rM6n9D19A12epjldRgyiS13SoSyLFCJEobprYg==", + "requires": { + "@babel/runtime": "^7.3.1", + "jss": "^10.0.3" + } + }, + "jss-plugin-rule-value-function": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss-plugin-rule-value-function/-/jss-plugin-rule-value-function-10.0.3.tgz", + "integrity": "sha512-RWwIT2UBAIwf3f6DQtt5gyjxHMRJoeO9TQku+ueR8dBMakqSSe8vFwQNfjXEoe0W+Tez5HZCTkZKNMulv3Z+9A==", + "requires": { + "@babel/runtime": "^7.3.1", + "jss": "^10.0.3" + } + }, + "jss-plugin-vendor-prefixer": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/jss-plugin-vendor-prefixer/-/jss-plugin-vendor-prefixer-10.0.3.tgz", + "integrity": "sha512-zVs6e5z4tFRK/fJ5kuTLzXlTFQbLeFTVwk7lTZiYNufmZwKT0kSmnOJDUukcSe7JLGSRztjWhnHB/6voP174gw==", + "requires": { + "@babel/runtime": "^7.3.1", + "css-vendor": "^2.0.7", + "jss": "^10.0.3" + } + }, + "jsx-ast-utils": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.2.3.tgz", + "integrity": "sha512-EdIHFMm+1BPynpKOpdPqiOsvnIrInRGJD7bzPZdPkjitQEqpdpUuFpq4T0npZFKTiB3RhWFdGN+oqOJIdhDhQA==", + "requires": { + "array-includes": "^3.0.3", + "object.assign": "^4.1.0" + } + }, + "keycode": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/keycode/-/keycode-2.2.0.tgz", + "integrity": "sha1-PQr1bce4uOXLqNCpfxByBO7CKwQ=" + }, + "killable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/killable/-/killable-1.0.1.tgz", + "integrity": "sha512-LzqtLKlUwirEUyl/nicirVmNiPvYs7l5n8wOPP7fyJVpUPkvCnW/vuiXGpylGUlnPDnB7311rARzAt3Mhswpjg==" + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "^1.1.5" + } + }, + "kleur": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", + "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==" + }, + "last-call-webpack-plugin": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/last-call-webpack-plugin/-/last-call-webpack-plugin-3.0.0.tgz", + "integrity": "sha512-7KI2l2GIZa9p2spzPIVZBYyNKkN+e/SQPpnjlTiPhdbDW3F86tdKKELxKpzJ5sgU19wQWsACULZmpTPYHeWO5w==", + "requires": { + "lodash": "^4.17.5", + "webpack-sources": "^1.1.0" + } + }, + "lazy-cache": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", + "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=" + }, + "lcid": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz", + "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==", + "requires": { + "invert-kv": "^2.0.0" + } + }, + "left-pad": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/left-pad/-/left-pad-1.3.0.tgz", + "integrity": "sha512-XI5MPzVNApjAyhQzphX8BkmKsKUxD4LdyK24iZeQGinBN9yTQT3bFlCBy/aVx2HrNcqQGsdot8ghrjyrvMCoEA==" + }, + "leven": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", + "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==" + }, + "levenary": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/levenary/-/levenary-1.1.0.tgz", + "integrity": "sha512-VHcwhO0UTpUW7rLPN2/OiWJdgA1e9BqEDALhrgCe/F+uUJnep6CoUsTzMeP8Rh0NGr9uKquXxqe7lwLZo509nQ==", + "requires": { + "leven": "^3.1.0" + } + }, + "levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "requires": { + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" + } + }, + "lines-and-columns": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", + "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=" + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + } + }, + "loader-fs-cache": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/loader-fs-cache/-/loader-fs-cache-1.0.2.tgz", + "integrity": "sha512-70IzT/0/L+M20jUlEqZhZyArTU6VKLRTYRDAYN26g4jfzpJqjipLL3/hgYpySqI9PwsVRHHFja0LfEmsx9X2Cw==", + "requires": { + "find-cache-dir": "^0.1.1", + "mkdirp": "0.5.1" + }, + "dependencies": { + "find-cache-dir": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-0.1.1.tgz", + "integrity": "sha1-yN765XyKUqinhPnjHFfHQumToLk=", + "requires": { + "commondir": "^1.0.1", + "mkdirp": "^0.5.1", + "pkg-dir": "^1.0.0" + } + }, + "find-up": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", + "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "requires": { + "path-exists": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "path-exists": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", + "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", + "requires": { + "pinkie-promise": "^2.0.0" + } + }, + "pkg-dir": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", + "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", + "requires": { + "find-up": "^1.0.0" + } + } + } + }, + "loader-runner": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-2.4.0.tgz", + "integrity": "sha512-Jsmr89RcXGIwivFY21FcRrisYZfvLMTWx5kOLc+JTxtpBOG6xML0vzbc6SEQG2FO9/4Fc3wW4LVcB5DmGflaRw==" + }, + "loader-utils": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.2.3.tgz", + "integrity": "sha512-fkpz8ejdnEMG3s37wGL07iSBDg99O9D5yflE9RGNH3hRdx9SOwYfnGYdZOUIZitN8E+E2vkq3MUMYMvPYl5ZZA==", + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^2.0.0", + "json5": "^1.0.1" + }, + "dependencies": { + "json5": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", + "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", + "requires": { + "minimist": "^1.2.0" + } + } + } + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "lodash": { + "version": "4.17.15", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", + "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" + }, + "lodash._reinterpolate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", + "integrity": "sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0=" + }, + "lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=" + }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==" + }, + "lodash.sortby": { + "version": "4.7.0", + "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", + "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=" + }, + "lodash.template": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.template/-/lodash.template-4.5.0.tgz", + "integrity": "sha512-84vYFxIkmidUiFxidA/KjjH9pAycqW+h980j7Fuz5qxRtO9pgB7MDFTdys1N7A5mcucRiDyEq4fusljItR1T/A==", + "requires": { + "lodash._reinterpolate": "^3.0.0", + "lodash.templatesettings": "^4.0.0" + } + }, + "lodash.templatesettings": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/lodash.templatesettings/-/lodash.templatesettings-4.2.0.tgz", + "integrity": "sha512-stgLz+i3Aa9mZgnjr/O+v9ruKZsPsndy7qPZOchbqk2cnTU1ZaldKK+v7m54WoKIyxiuMZTKT2H81F8BeAc3ZQ==", + "requires": { + "lodash._reinterpolate": "^3.0.0" + } + }, + "lodash.throttle": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.throttle/-/lodash.throttle-4.1.1.tgz", + "integrity": "sha1-wj6RtxAkKscMN/HhzaknTMOb8vQ=" + }, + "lodash.unescape": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/lodash.unescape/-/lodash.unescape-4.0.1.tgz", + "integrity": "sha1-vyJJiGzlFM2hEvrpIYzcBlIR/Jw=" + }, + "lodash.uniq": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz", + "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=" + }, + "loglevel": { + "version": "1.6.6", + "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.6.6.tgz", + "integrity": "sha512-Sgr5lbboAUBo3eXCSPL4/KoVz3ROKquOjcctxmHIt+vol2DrqTQe3SwkKKuYhEiWB5kYa13YyopJ69deJ1irzQ==" + }, + "loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "requires": { + "js-tokens": "^3.0.0 || ^4.0.0" + } + }, + "lower-case": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-1.1.4.tgz", + "integrity": "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=" + }, + "lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "requires": { + "yallist": "^3.0.2" + }, + "dependencies": { + "yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" + } + } + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "dependencies": { + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==" + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "makeerror": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.11.tgz", + "integrity": "sha1-4BpckQnyr3lmDk6LlYd5AYT1qWw=", + "requires": { + "tmpl": "1.0.x" + } + }, + "mamacro": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/mamacro/-/mamacro-0.0.3.tgz", + "integrity": "sha512-qMEwh+UujcQ+kbz3T6V+wAmO2U8veoq2w+3wY8MquqwVA3jChfwY+Tk52GZKDfACEPjuZ7r2oJLejwpt8jtwTA==" + }, + "map-age-cleaner": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", + "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", + "requires": { + "p-defer": "^1.0.0" + } + }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=" + }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "requires": { + "object-visit": "^1.0.0" + } + }, + "material-ui": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/material-ui/-/material-ui-0.20.2.tgz", + "integrity": "sha512-VeqgQkdvtK193w+FFvXDEwlVxI4rWk83eWbpYLeOIHDPWr3rbB9B075JRnJt/8IsI2X8q5Aia5W3+7m4KkleDg==", + "requires": { + "babel-runtime": "^6.23.0", + "inline-style-prefixer": "^3.0.8", + "keycode": "^2.1.8", + "lodash.merge": "^4.6.0", + "lodash.throttle": "^4.1.1", + "prop-types": "^15.5.7", + "react-event-listener": "^0.6.2", + "react-transition-group": "^1.2.1", + "recompose": "^0.26.0", + "simple-assign": "^0.1.0", + "warning": "^3.0.0" + } + }, + "md5.js": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", + "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "mdn-data": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.4.tgz", + "integrity": "sha512-iV3XNKw06j5Q7mi6h+9vbx23Tv7JkjEVgKHW4pimwyDGWm0OIQntJJ+u1C6mg6mK1EaTv42XQ7w76yuzH7M2cA==" + }, + "media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" + }, + "mem": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz", + "integrity": "sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w==", + "requires": { + "map-age-cleaner": "^0.1.1", + "mimic-fn": "^2.0.0", + "p-is-promise": "^2.0.0" + } + }, + "memory-fs": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", + "integrity": "sha1-OpoguEYlI+RHz7x+i7gO1me/xVI=", + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "merge-deep": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/merge-deep/-/merge-deep-3.0.2.tgz", + "integrity": "sha512-T7qC8kg4Zoti1cFd8Cr0M+qaZfOwjlPDEdZIIPPB2JZctjaPM4fX+i7HOId69tAti2fvO6X5ldfYUONDODsrkA==", + "requires": { + "arr-union": "^3.1.0", + "clone-deep": "^0.2.4", + "kind-of": "^3.0.2" + } + }, + "merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" + }, + "merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==" + }, + "merge2": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.3.0.tgz", + "integrity": "sha512-2j4DAdlBOkiSZIsaXk4mTE3sRS02yBHAtfy127xRV3bQUFqXkjHCHLW6Scv7DwNRbIWNHH8zpnz9zMaKXIdvYw==" + }, + "methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" + }, + "microevent.ts": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/microevent.ts/-/microevent.ts-0.1.1.tgz", + "integrity": "sha512-jo1OfR4TaEwd5HOrt5+tAZ9mqT4jmpNAusXtyfNzqVm9uiSYFZlKM1wYL4oU7azZW/PxQW53wM0S6OR1JHNa2g==" + }, + "micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, + "miller-rabin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", + "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", + "requires": { + "bn.js": "^4.0.0", + "brorand": "^1.0.1" + } + }, + "mime": { + "version": "2.4.4", + "resolved": "https://registry.npmjs.org/mime/-/mime-2.4.4.tgz", + "integrity": "sha512-LRxmNwziLPT828z+4YkNzloCFC2YM4wrB99k+AV5ZbEyfGNWfG8SO1FUXLmLDBSo89NrJZ4DIWeLjy1CHGhMGA==" + }, + "mime-db": { + "version": "1.43.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.43.0.tgz", + "integrity": "sha512-+5dsGEEovYbT8UY9yD7eE4XTc4UwJ1jBYlgaQQF38ENsKR3wj/8q8RFZrF9WIZpB2V1ArTVFUva8sAul1NzRzQ==" + }, + "mime-types": { + "version": "2.1.26", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.26.tgz", + "integrity": "sha512-01paPWYgLrkqAyrlDorC1uDwl2p3qZT7yl806vW7DvDoxwXi46jsjFbg+WdwotBIk6/MbEhO/dh5aZ5sNj/dWQ==", + "requires": { + "mime-db": "1.43.0" + } + }, + "mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==" + }, + "min-indent": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.0.tgz", + "integrity": "sha1-z8RcN+nsDY8KDsPdTvf3w6vjklY=" + }, + "mini-css-extract-plugin": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.8.0.tgz", + "integrity": "sha512-MNpRGbNA52q6U92i0qbVpQNsgk7LExy41MdAlG84FeytfDOtRIf/mCHdEgG8rpTKOaNKiqUnZdlptF469hxqOw==", + "requires": { + "loader-utils": "^1.1.0", + "normalize-url": "1.9.1", + "schema-utils": "^1.0.0", + "webpack-sources": "^1.1.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "minimalistic-assert": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", + "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==" + }, + "minimalistic-crypto-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", + "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=" + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" + }, + "minipass": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.1.tgz", + "integrity": "sha512-UFqVihv6PQgwj8/yTGvl9kPz7xIAY+R5z6XYjRInD3Gk3qx6QGSD6zEcpeG4Dy/lQnv1J6zv8ejV90hyYIKf3w==", + "requires": { + "yallist": "^4.0.0" + } + }, + "minipass-collect": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/minipass-collect/-/minipass-collect-1.0.2.tgz", + "integrity": "sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA==", + "requires": { + "minipass": "^3.0.0" + } + }, + "minipass-flush": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz", + "integrity": "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==", + "requires": { + "minipass": "^3.0.0" + } + }, + "minipass-pipeline": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.2.tgz", + "integrity": "sha512-3JS5A2DKhD2g0Gg8x3yamO0pj7YeKGwVlDS90pF++kxptwx/F+B//roxf9SqYil5tQo65bijy+dAuAFZmYOouA==", + "requires": { + "minipass": "^3.0.0" + } + }, + "mississippi": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/mississippi/-/mississippi-3.0.0.tgz", + "integrity": "sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA==", + "requires": { + "concat-stream": "^1.5.0", + "duplexify": "^3.4.2", + "end-of-stream": "^1.1.0", + "flush-write-stream": "^1.0.0", + "from2": "^2.1.0", + "parallel-transform": "^1.1.0", + "pump": "^3.0.0", + "pumpify": "^1.3.3", + "stream-each": "^1.1.0", + "through2": "^2.0.0" + } + }, + "mixin-deep": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz", + "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==", + "requires": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "mixin-object": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mixin-object/-/mixin-object-2.0.1.tgz", + "integrity": "sha1-T7lJRB2rGCVA8f4DW6YOGUel5X4=", + "requires": { + "for-in": "^0.1.3", + "is-extendable": "^0.1.1" + }, + "dependencies": { + "for-in": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-0.1.8.tgz", + "integrity": "sha1-2Hc5COMSVhCZUrH9ubP6hn0ndeE=" + } + } + }, + "mkdirp": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "requires": { + "minimist": "0.0.8" + }, + "dependencies": { + "minimist": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" + } + } + }, + "move-concurrently": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz", + "integrity": "sha1-viwAX9oy4LKa8fBdfEszIUxwH5I=", + "requires": { + "aproba": "^1.1.1", + "copy-concurrently": "^1.0.0", + "fs-write-stream-atomic": "^1.0.8", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.3" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + }, + "multicast-dns": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-6.2.3.tgz", + "integrity": "sha512-ji6J5enbMyGRHIAkAOu3WdV8nggqviKCEKtXcOqfphZZtQrmHKycfynJ2V7eVPUA4NhJ6V7Wf4TmGbTwKE9B6g==", + "requires": { + "dns-packet": "^1.3.1", + "thunky": "^1.0.2" + } + }, + "multicast-dns-service-types": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/multicast-dns-service-types/-/multicast-dns-service-types-1.1.0.tgz", + "integrity": "sha1-iZ8R2WhuXgXLkbNdXw5jt3PPyQE=" + }, + "mute-stream": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", + "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" + }, + "nan": { + "version": "2.14.0", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz", + "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==", + "optional": true + }, + "nanomatch": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", + "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=" + }, + "negotiator": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", + "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" + }, + "neo-async": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.1.tgz", + "integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==" + }, + "next-tick": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.0.0.tgz", + "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=" + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" + }, + "no-case": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-2.3.2.tgz", + "integrity": "sha512-rmTZ9kz+f3rCvK2TD1Ue/oZlns7OGoIWP4fc3llxxRXlOkHKoWPPWJOfFYpITabSow43QJbRIoHQXtt10VldyQ==", + "requires": { + "lower-case": "^1.1.1" + } + }, + "node-fetch": { + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-1.7.3.tgz", + "integrity": "sha512-NhZ4CsKx7cYm2vSrBAr2PvFOe6sWDf0UYLRqA6svUYg7+/TSfVAu49jYC4BvQ4Sms9SZgdqGBgroqfDhJdTyKQ==", + "requires": { + "encoding": "^0.1.11", + "is-stream": "^1.0.1" + } + }, + "node-forge": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.9.0.tgz", + "integrity": "sha512-7ASaDa3pD+lJ3WvXFsxekJQelBKRpne+GOVbLbtHYdd7pFspyeuJHnWfLplGf3SwKGbfs/aYl5V/JCIaHVUKKQ==" + }, + "node-int64": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", + "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=" + }, + "node-libs-browser": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.2.1.tgz", + "integrity": "sha512-h/zcD8H9kaDZ9ALUWwlBUDo6TKF8a7qBSCSEGfjTVIYeqsioSKaAX+BN7NgiMGp6iSIXZ3PxgCu8KS3b71YK5Q==", + "requires": { + "assert": "^1.1.1", + "browserify-zlib": "^0.2.0", + "buffer": "^4.3.0", + "console-browserify": "^1.1.0", + "constants-browserify": "^1.0.0", + "crypto-browserify": "^3.11.0", + "domain-browser": "^1.1.1", + "events": "^3.0.0", + "https-browserify": "^1.0.0", + "os-browserify": "^0.3.0", + "path-browserify": "0.0.1", + "process": "^0.11.10", + "punycode": "^1.2.4", + "querystring-es3": "^0.2.0", + "readable-stream": "^2.3.3", + "stream-browserify": "^2.0.1", + "stream-http": "^2.7.2", + "string_decoder": "^1.0.0", + "timers-browserify": "^2.0.4", + "tty-browserify": "0.0.0", + "url": "^0.11.0", + "util": "^0.11.0", + "vm-browserify": "^1.0.1" + }, + "dependencies": { + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + }, + "dependencies": { + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "util": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/util/-/util-0.11.1.tgz", + "integrity": "sha512-HShAsny+zS2TZfaXxD9tYj4HQGlBezXZMZuM/S5PKLLoZkShZiGk9o5CzukI1LVHZvjdvZ2Sj1aW/Ndn2NB/HQ==", + "requires": { + "inherits": "2.0.3" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + } + } + } + } + }, + "node-modules-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/node-modules-regexp/-/node-modules-regexp-1.0.0.tgz", + "integrity": "sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA=" + }, + "node-notifier": { + "version": "5.4.3", + "resolved": "https://registry.npmjs.org/node-notifier/-/node-notifier-5.4.3.tgz", + "integrity": "sha512-M4UBGcs4jeOK9CjTsYwkvH6/MzuUmGCyTW+kCY7uO+1ZVr0+FHGdPdIf5CCLqAaxnRrWidyoQlNkMIIVwbKB8Q==", + "requires": { + "growly": "^1.3.0", + "is-wsl": "^1.1.0", + "semver": "^5.5.0", + "shellwords": "^0.1.1", + "which": "^1.3.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "node-releases": { + "version": "1.1.45", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.45.tgz", + "integrity": "sha512-cXvGSfhITKI8qsV116u2FTzH5EWZJfgG7d4cpqwF8I8+1tWpD6AsvvGRKq2onR0DNj1jfqsjkXZsm14JMS7Cyg==", + "requires": { + "semver": "^6.3.0" + } + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + } + } + }, + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "requires": { + "remove-trailing-separator": "^1.0.1" + } + }, + "normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", + "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=" + }, + "normalize-scroll-left": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/normalize-scroll-left/-/normalize-scroll-left-0.2.0.tgz", + "integrity": "sha512-t5oCENZJl8TGusJKoCJm7+asaSsPuNmK6+iEjrZ5TyBj2f02brCRsd4c83hwtu+e5d4LCSBZ0uoDlMjBo+A8yA==" + }, + "normalize-url": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-1.9.1.tgz", + "integrity": "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=", + "requires": { + "object-assign": "^4.0.1", + "prepend-http": "^1.0.0", + "query-string": "^4.1.0", + "sort-keys": "^1.0.0" + } + }, + "npm-run-path": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", + "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", + "requires": { + "path-key": "^2.0.0" + } + }, + "nth-check": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.2.tgz", + "integrity": "sha512-WeBOdju8SnzPN5vTUJYxYUxLeXpCaVP5i5e0LF8fg7WORF2Wd7wFX/pk0tYZk7s8T+J7VLy0Da6J1+wCT0AtHg==", + "requires": { + "boolbase": "~1.0.0" + } + }, + "num2fraction": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/num2fraction/-/num2fraction-1.2.2.tgz", + "integrity": "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=" + }, + "number-is-nan": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", + "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" + }, + "nwsapi": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.0.tgz", + "integrity": "sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==" + }, + "oauth-sign": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", + "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==" + }, + "object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" + }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "requires": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "object-hash": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-1.3.1.tgz", + "integrity": "sha512-OSuu/pU4ENM9kmREg0BdNrUDIl1heYa4mBZacJc+vVWz4GtAwu7jO8s4AIt2aGRUTqxykpWzI3Oqnsm13tTMDA==" + }, + "object-inspect": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.7.0.tgz", + "integrity": "sha512-a7pEHdh1xKIAgTySUGgLMx/xwDZskN1Ud6egYYN3EdRW4ZMPNEDUTF+hwy2LUC+Bl+SyLXANnwz/jyh/qutKUw==" + }, + "object-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/object-is/-/object-is-1.0.2.tgz", + "integrity": "sha512-Epah+btZd5wrrfjkJZq1AOB9O6OxUQto45hzFd7lXGrpHPGE0W1k+426yrZV+k6NJOzLNNW/nVsmZdIWsAqoOQ==" + }, + "object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==" + }, + "object-path": { + "version": "0.11.4", + "resolved": "https://registry.npmjs.org/object-path/-/object-path-0.11.4.tgz", + "integrity": "sha1-NwrnUvvzfePqcKhhwju6iRVpGUk=" + }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "requires": { + "isobject": "^3.0.0" + } + }, + "object.assign": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", + "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", + "requires": { + "define-properties": "^1.1.2", + "function-bind": "^1.1.1", + "has-symbols": "^1.0.0", + "object-keys": "^1.0.11" + } + }, + "object.entries": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.1.tgz", + "integrity": "sha512-ilqR7BgdyZetJutmDPfXCDffGa0/Yzl2ivVNpbx/g4UeWrCdRnFDUBrKJGLhGieRHDATnyZXWBeCb29k9CJysQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, + "object.fromentries": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.2.tgz", + "integrity": "sha512-r3ZiBH7MQppDJVLx6fhD618GKNG40CZYH9wgwdhKxBDDbQgjeWGGd4AtkZad84d291YxvWe7bJGuE65Anh0dxQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, + "object.getownpropertydescriptors": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", + "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1" + } + }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "requires": { + "isobject": "^3.0.1" + } + }, + "object.values": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.1.tgz", + "integrity": "sha512-WTa54g2K8iu0kmS/us18jEmdv1a4Wi//BZ/DTVYEcH0XhLM5NYdpDHja3gt57VrZLcNAO2WGA+KpWsDBaHt6eA==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, + "obuf": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz", + "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==" + }, + "on-finished": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", + "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", + "requires": { + "ee-first": "1.1.1" + } + }, + "on-headers": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", + "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "requires": { + "wrappy": "1" + } + }, + "onetime": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", + "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", + "requires": { + "mimic-fn": "^2.1.0" + } + }, + "open": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/open/-/open-7.0.0.tgz", + "integrity": "sha512-K6EKzYqnwQzk+/dzJAQSBORub3xlBTxMz+ntpZpH/LyCa1o6KjXhuN+2npAaI9jaSmU3R1Q8NWf4KUWcyytGsQ==", + "requires": { + "is-wsl": "^2.1.0" + }, + "dependencies": { + "is-wsl": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.1.1.tgz", + "integrity": "sha512-umZHcSrwlDHo2TGMXv0DZ8dIUGunZ2Iv68YZnrmCiBPkZ4aaOhtv7pXJKeki9k3qJ3RJr0cDyitcl5wEH3AYog==" + } + } + }, + "opn": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/opn/-/opn-5.5.0.tgz", + "integrity": "sha512-PqHpggC9bLV0VeWcdKhkpxY+3JTzetLSqTCWL/z/tFIbI6G8JCjondXklT1JinczLz2Xib62sSp0T/gKT4KksA==", + "requires": { + "is-wsl": "^1.1.0" + } + }, + "optimize-css-assets-webpack-plugin": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/optimize-css-assets-webpack-plugin/-/optimize-css-assets-webpack-plugin-5.0.3.tgz", + "integrity": "sha512-q9fbvCRS6EYtUKKSwI87qm2IxlyJK5b4dygW1rKUBT6mMDhdG5e5bZT63v6tnJR9F9FB/H5a0HTmtw+laUBxKA==", + "requires": { + "cssnano": "^4.1.10", + "last-call-webpack-plugin": "^3.0.0" + } + }, + "optionator": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", + "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", + "requires": { + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.6", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "word-wrap": "~1.2.3" + } + }, + "original": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/original/-/original-1.0.2.tgz", + "integrity": "sha512-hyBVl6iqqUOJ8FqRe+l/gS8H+kKYjrEndd5Pm1MfBtsEKA038HkkdbAl/72EAXGyonD/PFsvmVG+EvcIpliMBg==", + "requires": { + "url-parse": "^1.4.3" + } + }, + "os-browserify": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.3.0.tgz", + "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=" + }, + "os-locale": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz", + "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==", + "requires": { + "execa": "^1.0.0", + "lcid": "^2.0.0", + "mem": "^4.0.0" + } + }, + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" + }, + "p-defer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", + "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=" + }, + "p-each-series": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-each-series/-/p-each-series-1.0.0.tgz", + "integrity": "sha1-kw89Et0fUOdDRFeiLNbwSsatf3E=", + "requires": { + "p-reduce": "^1.0.0" + } + }, + "p-finally": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", + "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" + }, + "p-is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz", + "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==" + }, + "p-limit": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.2.tgz", + "integrity": "sha512-WGR+xHecKTr7EbUEhyLSh5Dube9JtdiG78ufaeLxTgpudf/20KqyMioIUZJAezlTIi6evxuoUs9YXc11cU+yzQ==", + "requires": { + "p-try": "^2.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "requires": { + "p-limit": "^2.0.0" + } + }, + "p-map": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", + "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", + "requires": { + "aggregate-error": "^3.0.0" + } + }, + "p-reduce": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-reduce/-/p-reduce-1.0.0.tgz", + "integrity": "sha1-GMKw3ZNqRpClKfgjH1ig/bakffo=" + }, + "p-retry": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-3.0.1.tgz", + "integrity": "sha512-XE6G4+YTTkT2a0UWb2kjZe8xNwf8bIbnqpc/IS/idOBVhyves0mK5OJgeocjx7q5pvX/6m23xuzVPYT1uGM73w==", + "requires": { + "retry": "^0.12.0" + } + }, + "p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" + }, + "pako": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.10.tgz", + "integrity": "sha512-0DTvPVU3ed8+HNXOu5Bs+o//Mbdj9VNQMUOe9oKCwh8l0GNwpTDMKCWbRjgtD291AWnkAgkqA/LOnQS8AmS1tw==" + }, + "parallel-transform": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/parallel-transform/-/parallel-transform-1.2.0.tgz", + "integrity": "sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg==", + "requires": { + "cyclist": "^1.0.1", + "inherits": "^2.0.3", + "readable-stream": "^2.1.5" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "param-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-2.1.1.tgz", + "integrity": "sha1-35T9jPZTHs915r75oIWPvHK+Ikc=", + "requires": { + "no-case": "^2.2.0" + } + }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "requires": { + "callsites": "^3.0.0" + }, + "dependencies": { + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" + } + } + }, + "parse-asn1": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.5.tgz", + "integrity": "sha512-jkMYn1dcJqF6d5CpU689bq7w/b5ALS9ROVSpQDPrZsqqesUJii9qutvoT5ltGedNXMO2e16YUWIghG9KxaViTQ==", + "requires": { + "asn1.js": "^4.0.0", + "browserify-aes": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.0", + "pbkdf2": "^3.0.3", + "safe-buffer": "^5.1.1" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "parse5": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-4.0.0.tgz", + "integrity": "sha512-VrZ7eOd3T1Fk4XWNXMgiGBK/z0MG48BWG2uQNU4I72fkQuKUTZpl+u9k+CxEG0twMVzSmXEEz12z5Fnw1jIQFA==" + }, + "parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" + }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=" + }, + "path-browserify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.1.tgz", + "integrity": "sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ==" + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=" + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" + }, + "path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", + "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=" + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + }, + "path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", + "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "requires": { + "pify": "^3.0.0" + } + }, + "pbkdf2": { + "version": "3.0.17", + "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.0.17.tgz", + "integrity": "sha512-U/il5MsrZp7mGg3mSQfn742na2T+1/vHDCG5/iTI3X9MKUuYUZVLQhyRsg06mCgDBTd57TxzgZt7P+fYfjRLtA==", + "requires": { + "create-hash": "^1.1.2", + "create-hmac": "^1.1.4", + "ripemd160": "^2.0.1", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "performance-now": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", + "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + }, + "pinkie": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=" + }, + "pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", + "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "requires": { + "pinkie": "^2.0.0" + } + }, + "pirates": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.1.tgz", + "integrity": "sha512-WuNqLTbMI3tmfef2TKxlQmAiLHKtFhlsCZnPIpuv2Ow0RDVO8lfy1Opf4NUzlMXLjPl+Men7AuVdX6TA+s+uGA==", + "requires": { + "node-modules-regexp": "^1.0.0" + } + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "requires": { + "find-up": "^3.0.0" + } + }, + "pkg-up": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/pkg-up/-/pkg-up-2.0.0.tgz", + "integrity": "sha1-yBmscoBZpGHKscOImivjxJoATX8=", + "requires": { + "find-up": "^2.1.0" + }, + "dependencies": { + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "requires": { + "locate-path": "^2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=" + } + } + }, + "pn": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/pn/-/pn-1.1.0.tgz", + "integrity": "sha512-2qHaIQr2VLRFoxe2nASzsV6ef4yOOH+Fi9FBOVH6cqeSgUnoyySPZkxzLuzd+RYOQTRpROA0ztTMqxROKSb/nA==" + }, + "pnp-webpack-plugin": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/pnp-webpack-plugin/-/pnp-webpack-plugin-1.5.0.tgz", + "integrity": "sha512-jd9olUr9D7do+RN8Wspzhpxhgp1n6Vd0NtQ4SFkmIACZoEL1nkyAdW9Ygrinjec0vgDcWjscFQQ1gDW8rsfKTg==", + "requires": { + "ts-pnp": "^1.1.2" + } + }, + "popper.js": { + "version": "1.16.0", + "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.0.tgz", + "integrity": "sha512-+G+EkOPoE5S/zChTpmBSSDYmhXJ5PsW8eMhH8cP/CQHMFPBG/kC9Y5IIw6qNYgdJ+/COf0ddY2li28iHaZRSjw==" + }, + "portfinder": { + "version": "1.0.25", + "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.25.tgz", + "integrity": "sha512-6ElJnHBbxVA1XSLgBp7G1FiCkQdlqGzuF7DswL5tcea+E8UpuvPU7beVAjjRwCioTS9ZluNbu+ZyRvgTsmqEBg==", + "requires": { + "async": "^2.6.2", + "debug": "^3.1.1", + "mkdirp": "^0.5.1" + }, + "dependencies": { + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=" + }, + "postcss": { + "version": "7.0.26", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.26.tgz", + "integrity": "sha512-IY4oRjpXWYshuTDFxMVkJDtWIk2LhsTlu8bZnbEJA4+bYT16Lvpo8Qv6EvDumhYRgzjZl489pmsY3qVgJQ08nA==", + "requires": { + "chalk": "^2.4.2", + "source-map": "^0.6.1", + "supports-color": "^6.1.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "postcss-attribute-case-insensitive": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-attribute-case-insensitive/-/postcss-attribute-case-insensitive-4.0.1.tgz", + "integrity": "sha512-L2YKB3vF4PetdTIthQVeT+7YiSzMoNMLLYxPXXppOOP7NoazEAy45sh2LvJ8leCQjfBcfkYQs8TtCcQjeZTp8A==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^5.0.0" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-browser-comments": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-browser-comments/-/postcss-browser-comments-3.0.0.tgz", + "integrity": "sha512-qfVjLfq7HFd2e0HW4s1dvU8X080OZdG46fFbIBFjW7US7YPDcWfRvdElvwMJr2LI6hMmD+7LnH2HcmXTs+uOig==", + "requires": { + "postcss": "^7" + } + }, + "postcss-calc": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-7.0.1.tgz", + "integrity": "sha512-oXqx0m6tb4N3JGdmeMSc/i91KppbYsFZKdH0xMOqK8V1rJlzrKlTdokz8ozUXLVejydRN6u2IddxpcijRj2FqQ==", + "requires": { + "css-unit-converter": "^1.1.1", + "postcss": "^7.0.5", + "postcss-selector-parser": "^5.0.0-rc.4", + "postcss-value-parser": "^3.3.1" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + }, + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-color-functional-notation": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/postcss-color-functional-notation/-/postcss-color-functional-notation-2.0.1.tgz", + "integrity": "sha512-ZBARCypjEDofW4P6IdPVTLhDNXPRn8T2s1zHbZidW6rPaaZvcnCS2soYFIQJrMZSxiePJ2XIYTlcb2ztr/eT2g==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-color-gray": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-color-gray/-/postcss-color-gray-5.0.0.tgz", + "integrity": "sha512-q6BuRnAGKM/ZRpfDascZlIZPjvwsRye7UDNalqVz3s7GDxMtqPY6+Q871liNxsonUw8oC61OG+PSaysYpl1bnw==", + "requires": { + "@csstools/convert-colors": "^1.4.0", + "postcss": "^7.0.5", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-color-hex-alpha": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/postcss-color-hex-alpha/-/postcss-color-hex-alpha-5.0.3.tgz", + "integrity": "sha512-PF4GDel8q3kkreVXKLAGNpHKilXsZ6xuu+mOQMHWHLPNyjiUBOr75sp5ZKJfmv1MCus5/DWUGcK9hm6qHEnXYw==", + "requires": { + "postcss": "^7.0.14", + "postcss-values-parser": "^2.0.1" + } + }, + "postcss-color-mod-function": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/postcss-color-mod-function/-/postcss-color-mod-function-3.0.3.tgz", + "integrity": "sha512-YP4VG+xufxaVtzV6ZmhEtc+/aTXH3d0JLpnYfxqTvwZPbJhWqp8bSY3nfNzNRFLgB4XSaBA82OE4VjOOKpCdVQ==", + "requires": { + "@csstools/convert-colors": "^1.4.0", + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-color-rebeccapurple": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-color-rebeccapurple/-/postcss-color-rebeccapurple-4.0.1.tgz", + "integrity": "sha512-aAe3OhkS6qJXBbqzvZth2Au4V3KieR5sRQ4ptb2b2O8wgvB3SJBsdG+jsn2BZbbwekDG8nTfcCNKcSfe/lEy8g==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-colormin": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-4.0.3.tgz", + "integrity": "sha512-WyQFAdDZpExQh32j0U0feWisZ0dmOtPl44qYmJKkq9xFWY3p+4qnRzCHeNrkeRhwPHz9bQ3mo0/yVkaply0MNw==", + "requires": { + "browserslist": "^4.0.0", + "color": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-convert-values": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-4.0.1.tgz", + "integrity": "sha512-Kisdo1y77KUC0Jmn0OXU/COOJbzM8cImvw1ZFsBgBgMgb1iL23Zs/LXRe3r+EZqM3vGYKdQ2YJVQ5VkJI+zEJQ==", + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-custom-media": { + "version": "7.0.8", + "resolved": "https://registry.npmjs.org/postcss-custom-media/-/postcss-custom-media-7.0.8.tgz", + "integrity": "sha512-c9s5iX0Ge15o00HKbuRuTqNndsJUbaXdiNsksnVH8H4gdc+zbLzr/UasOwNG6CTDpLFekVY4672eWdiiWu2GUg==", + "requires": { + "postcss": "^7.0.14" + } + }, + "postcss-custom-properties": { + "version": "8.0.11", + "resolved": "https://registry.npmjs.org/postcss-custom-properties/-/postcss-custom-properties-8.0.11.tgz", + "integrity": "sha512-nm+o0eLdYqdnJ5abAJeXp4CEU1c1k+eB2yMCvhgzsds/e0umabFrN6HoTy/8Q4K5ilxERdl/JD1LO5ANoYBeMA==", + "requires": { + "postcss": "^7.0.17", + "postcss-values-parser": "^2.0.1" + } + }, + "postcss-custom-selectors": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/postcss-custom-selectors/-/postcss-custom-selectors-5.1.2.tgz", + "integrity": "sha512-DSGDhqinCqXqlS4R7KGxL1OSycd1lydugJ1ky4iRXPHdBRiozyMHrdu0H3o7qNOCiZwySZTUI5MV0T8QhCLu+w==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^5.0.0-rc.3" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-dir-pseudo-class": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-dir-pseudo-class/-/postcss-dir-pseudo-class-5.0.0.tgz", + "integrity": "sha512-3pm4oq8HYWMZePJY+5ANriPs3P07q+LW6FAdTlkFH2XqDdP4HeeJYMOzn0HYLhRSjBO3fhiqSwwU9xEULSrPgw==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^5.0.0-rc.3" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-discard-comments": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-4.0.2.tgz", + "integrity": "sha512-RJutN259iuRf3IW7GZyLM5Sw4GLTOH8FmsXBnv8Ab/Tc2k4SR4qbV4DNbyyY4+Sjo362SyDmW2DQ7lBSChrpkg==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-duplicates": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-4.0.2.tgz", + "integrity": "sha512-ZNQfR1gPNAiXZhgENFfEglF93pciw0WxMkJeVmw8eF+JZBbMD7jp6C67GqJAXVZP2BWbOztKfbsdmMp/k8c6oQ==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-empty": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-4.0.1.tgz", + "integrity": "sha512-B9miTzbznhDjTfjvipfHoqbWKwd0Mj+/fL5s1QOz06wufguil+Xheo4XpOnc4NqKYBCNqqEzgPv2aPBIJLox0w==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-overridden": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-4.0.1.tgz", + "integrity": "sha512-IYY2bEDD7g1XM1IDEsUT4//iEYCxAmP5oDSFMVU/JVvT7gh+l4fmjciLqGgwjdWpQIdb0Che2VX00QObS5+cTg==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-double-position-gradients": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/postcss-double-position-gradients/-/postcss-double-position-gradients-1.0.0.tgz", + "integrity": "sha512-G+nV8EnQq25fOI8CH/B6krEohGWnF5+3A6H/+JEpOncu5dCnkS1QQ6+ct3Jkaepw1NGVqqOZH6lqrm244mCftA==", + "requires": { + "postcss": "^7.0.5", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-env-function": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/postcss-env-function/-/postcss-env-function-2.0.2.tgz", + "integrity": "sha512-rwac4BuZlITeUbiBq60h/xbLzXY43qOsIErngWa4l7Mt+RaSkT7QBjXVGTcBHupykkblHMDrBFh30zchYPaOUw==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-flexbugs-fixes": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/postcss-flexbugs-fixes/-/postcss-flexbugs-fixes-4.1.0.tgz", + "integrity": "sha512-jr1LHxQvStNNAHlgco6PzY308zvLklh7SJVYuWUwyUQncofaAlD2l+P/gxKHOdqWKe7xJSkVLFF/2Tp+JqMSZA==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-focus-visible": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-focus-visible/-/postcss-focus-visible-4.0.0.tgz", + "integrity": "sha512-Z5CkWBw0+idJHSV6+Bgf2peDOFf/x4o+vX/pwcNYrWpXFrSfTkQ3JQ1ojrq9yS+upnAlNRHeg8uEwFTgorjI8g==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-focus-within": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-focus-within/-/postcss-focus-within-3.0.0.tgz", + "integrity": "sha512-W0APui8jQeBKbCGZudW37EeMCjDeVxKgiYfIIEo8Bdh5SpB9sxds/Iq8SEuzS0Q4YFOlG7EPFulbbxujpkrV2w==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-font-variant": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-font-variant/-/postcss-font-variant-4.0.0.tgz", + "integrity": "sha512-M8BFYKOvCrI2aITzDad7kWuXXTm0YhGdP9Q8HanmN4EF1Hmcgs1KK5rSHylt/lUJe8yLxiSwWAHdScoEiIxztg==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-gap-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-gap-properties/-/postcss-gap-properties-2.0.0.tgz", + "integrity": "sha512-QZSqDaMgXCHuHTEzMsS2KfVDOq7ZFiknSpkrPJY6jmxbugUPTuSzs/vuE5I3zv0WAS+3vhrlqhijiprnuQfzmg==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-image-set-function": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/postcss-image-set-function/-/postcss-image-set-function-3.0.1.tgz", + "integrity": "sha512-oPTcFFip5LZy8Y/whto91L9xdRHCWEMs3e1MdJxhgt4jy2WYXfhkng59fH5qLXSCPN8k4n94p1Czrfe5IOkKUw==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-initial": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/postcss-initial/-/postcss-initial-3.0.2.tgz", + "integrity": "sha512-ugA2wKonC0xeNHgirR4D3VWHs2JcU08WAi1KFLVcnb7IN89phID6Qtg2RIctWbnvp1TM2BOmDtX8GGLCKdR8YA==", + "requires": { + "lodash.template": "^4.5.0", + "postcss": "^7.0.2" + } + }, + "postcss-lab-function": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/postcss-lab-function/-/postcss-lab-function-2.0.1.tgz", + "integrity": "sha512-whLy1IeZKY+3fYdqQFuDBf8Auw+qFuVnChWjmxm/UhHWqNHZx+B99EwxTvGYmUBqe3Fjxs4L1BoZTJmPu6usVg==", + "requires": { + "@csstools/convert-colors": "^1.4.0", + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-load-config": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-2.1.0.tgz", + "integrity": "sha512-4pV3JJVPLd5+RueiVVB+gFOAa7GWc25XQcMp86Zexzke69mKf6Nx9LRcQywdz7yZI9n1udOxmLuAwTBypypF8Q==", + "requires": { + "cosmiconfig": "^5.0.0", + "import-cwd": "^2.0.0" + } + }, + "postcss-loader": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-3.0.0.tgz", + "integrity": "sha512-cLWoDEY5OwHcAjDnkyRQzAXfs2jrKjXpO/HQFcc5b5u/r7aa471wdmChmwfnv7x2u840iat/wi0lQ5nbRgSkUA==", + "requires": { + "loader-utils": "^1.1.0", + "postcss": "^7.0.0", + "postcss-load-config": "^2.0.0", + "schema-utils": "^1.0.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "postcss-logical": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-logical/-/postcss-logical-3.0.0.tgz", + "integrity": "sha512-1SUKdJc2vuMOmeItqGuNaC+N8MzBWFWEkAnRnLpFYj1tGGa7NqyVBujfRtgNa2gXR+6RkGUiB2O5Vmh7E2RmiA==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-media-minmax": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-media-minmax/-/postcss-media-minmax-4.0.0.tgz", + "integrity": "sha512-fo9moya6qyxsjbFAYl97qKO9gyre3qvbMnkOZeZwlsW6XYFsvs2DMGDlchVLfAd8LHPZDxivu/+qW2SMQeTHBw==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-merge-longhand": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-4.0.11.tgz", + "integrity": "sha512-alx/zmoeXvJjp7L4mxEMjh8lxVlDFX1gqWHzaaQewwMZiVhLo42TEClKaeHbRf6J7j82ZOdTJ808RtN0ZOZwvw==", + "requires": { + "css-color-names": "0.0.4", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "stylehacks": "^4.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-merge-rules": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-4.0.3.tgz", + "integrity": "sha512-U7e3r1SbvYzO0Jr3UT/zKBVgYYyhAz0aitvGIYOYK5CPmkNih+WDSsS5tvPrJ8YMQYlEMvsZIiqmn7HdFUaeEQ==", + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "cssnano-util-same-parent": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0", + "vendors": "^1.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.1.tgz", + "integrity": "sha1-T4dfSvsMllc9XPTXQBGu4lCn6GU=", + "requires": { + "dot-prop": "^4.1.1", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-minify-font-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-4.0.2.tgz", + "integrity": "sha512-j85oO6OnRU9zPf04+PZv1LYIYOprWm6IA6zkXkrJXyRveDEuQggG6tvoy8ir8ZwjLxLuGfNkCZEQG7zan+Hbtg==", + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-minify-gradients": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-4.0.2.tgz", + "integrity": "sha512-qKPfwlONdcf/AndP1U8SJ/uzIJtowHlMaSioKzebAXSG4iJthlWC9iSWznQcX4f66gIWX44RSA841HTHj3wK+Q==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "is-color-stop": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-minify-params": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-4.0.2.tgz", + "integrity": "sha512-G7eWyzEx0xL4/wiBBJxJOz48zAKV2WG3iZOqVhPet/9geefm/Px5uo1fzlHu+DOjT+m0Mmiz3jkQzVHe6wxAWg==", + "requires": { + "alphanum-sort": "^1.0.0", + "browserslist": "^4.0.0", + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "uniqs": "^2.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-minify-selectors": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-4.0.2.tgz", + "integrity": "sha512-D5S1iViljXBj9kflQo4YutWnJmwm8VvIsU1GeXJGiG9j8CIg9zs4voPMdQDUmIxetUOh60VilsNzCiAFTOqu3g==", + "requires": { + "alphanum-sort": "^1.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.1.tgz", + "integrity": "sha1-T4dfSvsMllc9XPTXQBGu4lCn6GU=", + "requires": { + "dot-prop": "^4.1.1", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-modules-extract-imports": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-2.0.0.tgz", + "integrity": "sha512-LaYLDNS4SG8Q5WAWqIJgdHPJrDDr/Lv775rMBFUbgjTz6j34lUznACHcdRWroPvXANP2Vj7yNK57vp9eFqzLWQ==", + "requires": { + "postcss": "^7.0.5" + } + }, + "postcss-modules-local-by-default": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-3.0.2.tgz", + "integrity": "sha512-jM/V8eqM4oJ/22j0gx4jrp63GSvDH6v86OqyTHHUvk4/k1vceipZsaymiZ5PvocqZOl5SFHiFJqjs3la0wnfIQ==", + "requires": { + "icss-utils": "^4.1.1", + "postcss": "^7.0.16", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.0.0" + } + }, + "postcss-modules-scope": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-2.1.1.tgz", + "integrity": "sha512-OXRUPecnHCg8b9xWvldG/jUpRIGPNRka0r4D4j0ESUU2/5IOnpsjfPPmDprM3Ih8CgZ8FXjWqaniK5v4rWt3oQ==", + "requires": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0" + } + }, + "postcss-modules-values": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-3.0.0.tgz", + "integrity": "sha512-1//E5jCBrZ9DmRX+zCtmQtRSV6PV42Ix7Bzj9GbwJceduuf7IqP8MgeTXuRDHOWj2m0VzZD5+roFWDuU8RQjcg==", + "requires": { + "icss-utils": "^4.0.0", + "postcss": "^7.0.6" + } + }, + "postcss-nesting": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/postcss-nesting/-/postcss-nesting-7.0.1.tgz", + "integrity": "sha512-FrorPb0H3nuVq0Sff7W2rnc3SmIcruVC6YwpcS+k687VxyxO33iE1amna7wHuRVzM8vfiYofXSBHNAZ3QhLvYg==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-normalize": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize/-/postcss-normalize-8.0.1.tgz", + "integrity": "sha512-rt9JMS/m9FHIRroDDBGSMsyW1c0fkvOJPy62ggxSHUldJO7B195TqFMqIf+lY5ezpDcYOV4j86aUp3/XbxzCCQ==", + "requires": { + "@csstools/normalize.css": "^10.1.0", + "browserslist": "^4.6.2", + "postcss": "^7.0.17", + "postcss-browser-comments": "^3.0.0", + "sanitize.css": "^10.0.0" + } + }, + "postcss-normalize-charset": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-4.0.1.tgz", + "integrity": "sha512-gMXCrrlWh6G27U0hF3vNvR3w8I1s2wOBILvA87iNXaPvSNo5uZAMYsZG7XjCUf1eVxuPfyL4TJ7++SGZLc9A3g==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-normalize-display-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-display-values/-/postcss-normalize-display-values-4.0.2.tgz", + "integrity": "sha512-3F2jcsaMW7+VtRMAqf/3m4cPFhPD3EFRgNs18u+k3lTJJlVe7d0YPO+bnwqo2xg8YiRpDXJI2u8A0wqJxMsQuQ==", + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-positions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-positions/-/postcss-normalize-positions-4.0.2.tgz", + "integrity": "sha512-Dlf3/9AxpxE+NF1fJxYDeggi5WwV35MXGFnnoccP/9qDtFrTArZ0D0R+iKcg5WsUd8nUYMIl8yXDCtcrT8JrdA==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-repeat-style": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-4.0.2.tgz", + "integrity": "sha512-qvigdYYMpSuoFs3Is/f5nHdRLJN/ITA7huIoCyqqENJe9PvPmLhNLMu7QTjPdtnVf6OcYYO5SHonx4+fbJE1+Q==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-string": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-string/-/postcss-normalize-string-4.0.2.tgz", + "integrity": "sha512-RrERod97Dnwqq49WNz8qo66ps0swYZDSb6rM57kN2J+aoyEAJfZ6bMx0sx/F9TIEX0xthPGCmeyiam/jXif0eA==", + "requires": { + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-timing-functions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-4.0.2.tgz", + "integrity": "sha512-acwJY95edP762e++00Ehq9L4sZCEcOPyaHwoaFOhIwWCDfik6YvqsYNxckee65JHLKzuNSSmAdxwD2Cud1Z54A==", + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-unicode": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-unicode/-/postcss-normalize-unicode-4.0.1.tgz", + "integrity": "sha512-od18Uq2wCYn+vZ/qCOeutvHjB5jm57ToxRaMeNuf0nWVHaP9Hua56QyMF6fs/4FSUnVIw0CBPsU0K4LnBPwYwg==", + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-url": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-4.0.1.tgz", + "integrity": "sha512-p5oVaF4+IHwu7VpMan/SSpmpYxcJMtkGppYf0VbdH5B6hN8YNmVyJLuY9FmLQTzY3fag5ESUUHDqM+heid0UVA==", + "requires": { + "is-absolute-url": "^2.0.0", + "normalize-url": "^3.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "normalize-url": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-3.3.0.tgz", + "integrity": "sha512-U+JJi7duF1o+u2pynbp2zXDW2/PADgC30f0GsHZtRh+HOcXHnw137TrNlyxxRvWW5fjKd3bcLHPxofWuCjaeZg==" + }, + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-whitespace": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-whitespace/-/postcss-normalize-whitespace-4.0.2.tgz", + "integrity": "sha512-tO8QIgrsI3p95r8fyqKV+ufKlSHh9hMJqACqbv2XknufqEDhDvbguXGBBqxw9nsQoXWf0qOqppziKJKHMD4GtA==", + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-ordered-values": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-4.1.2.tgz", + "integrity": "sha512-2fCObh5UanxvSxeXrtLtlwVThBvHn6MQcu4ksNT2tsaV2Fg76R2CV98W7wNSlX+5/pFwEyaDwKLLoEV7uRybAw==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-overflow-shorthand": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-overflow-shorthand/-/postcss-overflow-shorthand-2.0.0.tgz", + "integrity": "sha512-aK0fHc9CBNx8jbzMYhshZcEv8LtYnBIRYQD5i7w/K/wS9c2+0NSR6B3OVMu5y0hBHYLcMGjfU+dmWYNKH0I85g==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-page-break": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-page-break/-/postcss-page-break-2.0.0.tgz", + "integrity": "sha512-tkpTSrLpfLfD9HvgOlJuigLuk39wVTbbd8RKcy8/ugV2bNBUW3xU+AIqyxhDrQr1VUj1RmyJrBn1YWrqUm9zAQ==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-place": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-place/-/postcss-place-4.0.1.tgz", + "integrity": "sha512-Zb6byCSLkgRKLODj/5mQugyuj9bvAAw9LqJJjgwz5cYryGeXfFZfSXoP1UfveccFmeq0b/2xxwcTEVScnqGxBg==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-preset-env": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/postcss-preset-env/-/postcss-preset-env-6.7.0.tgz", + "integrity": "sha512-eU4/K5xzSFwUFJ8hTdTQzo2RBLbDVt83QZrAvI07TULOkmyQlnYlpwep+2yIK+K+0KlZO4BvFcleOCCcUtwchg==", + "requires": { + "autoprefixer": "^9.6.1", + "browserslist": "^4.6.4", + "caniuse-lite": "^1.0.30000981", + "css-blank-pseudo": "^0.1.4", + "css-has-pseudo": "^0.10.0", + "css-prefers-color-scheme": "^3.1.1", + "cssdb": "^4.4.0", + "postcss": "^7.0.17", + "postcss-attribute-case-insensitive": "^4.0.1", + "postcss-color-functional-notation": "^2.0.1", + "postcss-color-gray": "^5.0.0", + "postcss-color-hex-alpha": "^5.0.3", + "postcss-color-mod-function": "^3.0.3", + "postcss-color-rebeccapurple": "^4.0.1", + "postcss-custom-media": "^7.0.8", + "postcss-custom-properties": "^8.0.11", + "postcss-custom-selectors": "^5.1.2", + "postcss-dir-pseudo-class": "^5.0.0", + "postcss-double-position-gradients": "^1.0.0", + "postcss-env-function": "^2.0.2", + "postcss-focus-visible": "^4.0.0", + "postcss-focus-within": "^3.0.0", + "postcss-font-variant": "^4.0.0", + "postcss-gap-properties": "^2.0.0", + "postcss-image-set-function": "^3.0.1", + "postcss-initial": "^3.0.0", + "postcss-lab-function": "^2.0.1", + "postcss-logical": "^3.0.0", + "postcss-media-minmax": "^4.0.0", + "postcss-nesting": "^7.0.0", + "postcss-overflow-shorthand": "^2.0.0", + "postcss-page-break": "^2.0.0", + "postcss-place": "^4.0.1", + "postcss-pseudo-class-any-link": "^6.0.0", + "postcss-replace-overflow-wrap": "^3.0.0", + "postcss-selector-matches": "^4.0.0", + "postcss-selector-not": "^4.0.0" + } + }, + "postcss-pseudo-class-any-link": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/postcss-pseudo-class-any-link/-/postcss-pseudo-class-any-link-6.0.0.tgz", + "integrity": "sha512-lgXW9sYJdLqtmw23otOzrtbDXofUdfYzNm4PIpNE322/swES3VU9XlXHeJS46zT2onFO7V1QFdD4Q9LiZj8mew==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^5.0.0-rc.3" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-reduce-initial": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-4.0.3.tgz", + "integrity": "sha512-gKWmR5aUulSjbzOfD9AlJiHCGH6AEVLaM0AV+aSioxUDd16qXP1PCh8d1/BGVvpdWn8k/HiK7n6TjeoXN1F7DA==", + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "postcss-reduce-transforms": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-4.0.2.tgz", + "integrity": "sha512-EEVig1Q2QJ4ELpJXMZR8Vt5DQx8/mo+dGWSR7vWXqcob2gQLyQGsionYcGKATXvQzMPn6DSN1vTN7yFximdIAg==", + "requires": { + "cssnano-util-get-match": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-replace-overflow-wrap": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-replace-overflow-wrap/-/postcss-replace-overflow-wrap-3.0.0.tgz", + "integrity": "sha512-2T5hcEHArDT6X9+9dVSPQdo7QHzG4XKclFT8rU5TzJPDN7RIRTbO9c4drUISOVemLj03aezStHCR2AIcr8XLpw==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-safe-parser": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-safe-parser/-/postcss-safe-parser-4.0.1.tgz", + "integrity": "sha512-xZsFA3uX8MO3yAda03QrG3/Eg1LN3EPfjjf07vke/46HERLZyHrTsQ9E1r1w1W//fWEhtYNndo2hQplN2cVpCQ==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-selector-matches": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-matches/-/postcss-selector-matches-4.0.0.tgz", + "integrity": "sha512-LgsHwQR/EsRYSqlwdGzeaPKVT0Ml7LAT6E75T8W8xLJY62CE4S/l03BWIt3jT8Taq22kXP08s2SfTSzaraoPww==", + "requires": { + "balanced-match": "^1.0.0", + "postcss": "^7.0.2" + } + }, + "postcss-selector-not": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-not/-/postcss-selector-not-4.0.0.tgz", + "integrity": "sha512-W+bkBZRhqJaYN8XAnbbZPLWMvZD1wKTu0UxtFKdhtGjWYmxhkUneoeOhRJKdAE5V7ZTlnbHfCR+6bNwK9e1dTQ==", + "requires": { + "balanced-match": "^1.0.0", + "postcss": "^7.0.2" + } + }, + "postcss-selector-parser": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.2.tgz", + "integrity": "sha512-36P2QR59jDTOAiIkqEprfJDsoNrvwFei3eCqKd1Y0tUsBimsq39BLp7RD+JWny3WgB1zGhJX8XVePwm9k4wdBg==", + "requires": { + "cssesc": "^3.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + }, + "postcss-svgo": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-4.0.2.tgz", + "integrity": "sha512-C6wyjo3VwFm0QgBy+Fu7gCYOkCmgmClghO+pjcxvrcBKtiKt0uCF+hvbMO1fyv5BMImRK90SMb+dwUnfbGd+jw==", + "requires": { + "is-svg": "^3.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "svgo": "^1.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-unique-selectors": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-4.0.1.tgz", + "integrity": "sha512-+JanVaryLo9QwZjKrmJgkI4Fn8SBgRO6WXQBJi7KiAVPlmxikB5Jzc4EvXMT2H0/m0RjrVVm9rGNhZddm/8Spg==", + "requires": { + "alphanum-sort": "^1.0.0", + "postcss": "^7.0.0", + "uniqs": "^2.0.0" + } + }, + "postcss-value-parser": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.0.2.tgz", + "integrity": "sha512-LmeoohTpp/K4UiyQCwuGWlONxXamGzCMtFxLq4W1nZVGIQLYvMCJx3yAF9qyyuFpflABI9yVdtJAqbihOsCsJQ==" + }, + "postcss-values-parser": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/postcss-values-parser/-/postcss-values-parser-2.0.1.tgz", + "integrity": "sha512-2tLuBsA6P4rYTNKCXYG/71C7j1pU6pK503suYOmn4xYrQIzW+opD+7FAFNuGSdZC/3Qfy334QbeMu7MEb8gOxg==", + "requires": { + "flatten": "^1.0.2", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + }, + "prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" + }, + "prepend-http": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", + "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=" + }, + "pretty-bytes": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-5.3.0.tgz", + "integrity": "sha512-hjGrh+P926p4R4WbaB6OckyRtO0F0/lQBiT+0gnxjV+5kjPBrfVBFCsCLbMqVQeydvIoouYTCmmEURiH3R1Bdg==" + }, + "pretty-error": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/pretty-error/-/pretty-error-2.1.1.tgz", + "integrity": "sha1-X0+HyPkeWuPzuoerTPXgOxoX8aM=", + "requires": { + "renderkid": "^2.0.1", + "utila": "~0.4" + } + }, + "pretty-format": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-24.9.0.tgz", + "integrity": "sha512-00ZMZUiHaJrNfk33guavqgvfJS30sLYf0f8+Srklv0AMPodGGHcoHgksZ3OThYnIvOd+8yMCn0YiEOogjlgsnA==", + "requires": { + "@jest/types": "^24.9.0", + "ansi-regex": "^4.0.0", + "ansi-styles": "^3.2.0", + "react-is": "^16.8.4" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" + } + } + }, + "private": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", + "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==" + }, + "process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=" + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==" + }, + "promise": { + "version": "8.0.3", + "resolved": "https://registry.npmjs.org/promise/-/promise-8.0.3.tgz", + "integrity": "sha512-HeRDUL1RJiLhyA0/grn+PTShlBAcLuh/1BJGtrvjwbvRDCTLLMEz9rOGCV+R3vHY4MixIuoMEd9Yq/XvsTPcjw==", + "requires": { + "asap": "~2.0.6" + } + }, + "promise-inflight": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", + "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=" + }, + "prompts": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.3.0.tgz", + "integrity": "sha512-NfbbPPg/74fT7wk2XYQ7hAIp9zJyZp5Fu19iRbORqqy1BhtrkZ0fPafBU+7bmn8ie69DpT0R6QpJIN2oisYjJg==", + "requires": { + "kleur": "^3.0.3", + "sisteransi": "^1.0.3" + } + }, + "prop-types": { + "version": "15.7.2", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", + "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", + "requires": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.8.1" + } + }, + "proxy-addr": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", + "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==", + "requires": { + "forwarded": "~0.1.2", + "ipaddr.js": "1.9.0" + } + }, + "prr": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", + "integrity": "sha1-0/wRS6BplaRexok/SEzrHXj19HY=" + }, + "psl": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.7.0.tgz", + "integrity": "sha512-5NsSEDv8zY70ScRnOTn7bK7eanl2MvFrOrS/R6x+dBt5g1ghnj9Zv90kO8GwT8gxcu2ANyFprnFYB85IogIJOQ==" + }, + "public-encrypt": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.3.tgz", + "integrity": "sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q==", + "requires": { + "bn.js": "^4.1.0", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "parse-asn1": "^5.0.0", + "randombytes": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "pump": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", + "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "pumpify": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", + "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", + "requires": { + "duplexify": "^3.6.0", + "inherits": "^2.0.3", + "pump": "^2.0.0" + }, + "dependencies": { + "pump": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", + "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + } + } + }, + "punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=" + }, + "qs": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", + "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" + }, + "query-string": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/query-string/-/query-string-4.3.4.tgz", + "integrity": "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=", + "requires": { + "object-assign": "^4.1.0", + "strict-uri-encode": "^1.0.0" + } + }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" + }, + "querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", + "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=" + }, + "querystringify": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.1.1.tgz", + "integrity": "sha512-w7fLxIRCRT7U8Qu53jQnJyPkYZIaR4n5151KMfcJlO/A9397Wxb1amJvROTK6TOnp7PfoAmg/qXiNHI+08jRfA==" + }, + "raf": { + "version": "3.4.1", + "resolved": "https://registry.npmjs.org/raf/-/raf-3.4.1.tgz", + "integrity": "sha512-Sq4CW4QhwOHE8ucn6J34MqtZCeWFP2aQSmrlroYgqAV1PjStIhJXxYuTgUIfkEk7zTLjmIjLmU5q+fbD1NnOJA==", + "requires": { + "performance-now": "^2.1.0" + } + }, + "randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", + "requires": { + "safe-buffer": "^5.1.0" + } + }, + "randomfill": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.4.tgz", + "integrity": "sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw==", + "requires": { + "randombytes": "^2.0.5", + "safe-buffer": "^5.1.0" + } + }, + "range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" + }, + "raw-body": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", + "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", + "requires": { + "bytes": "3.1.0", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + }, + "dependencies": { + "bytes": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", + "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" + } + } + }, + "react": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react/-/react-16.12.0.tgz", + "integrity": "sha512-fglqy3k5E+81pA8s+7K0/T3DBCF0ZDOher1elBFzF7O6arXJgzyu/FW+COxFvAWXJoJN9KIZbT2LXlukwphYTA==", + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1", + "prop-types": "^15.6.2" + } + }, + "react-app-polyfill": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/react-app-polyfill/-/react-app-polyfill-1.0.5.tgz", + "integrity": "sha512-RcbV6+msbvZJZUIK/LX3UafPtoaDSJgUWu4sqBxHKTVmBsnlU2QWCKJRBRmgjxu+ivW/GPINbPWRM4Ppa6Lbgw==", + "requires": { + "core-js": "^3.4.1", + "object-assign": "^4.1.1", + "promise": "^8.0.3", + "raf": "^3.4.1", + "regenerator-runtime": "^0.13.3", + "whatwg-fetch": "^3.0.0" + } + }, + "react-dev-utils": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/react-dev-utils/-/react-dev-utils-10.0.0.tgz", + "integrity": "sha512-8OKSJvl8ccXJDNf0YGw377L9v1OnT16skD/EuZWm0M/yr255etP4x4kuUCT1EfFfJ7Rhc4ZTpPTfPrvgiXa50Q==", + "requires": { + "@babel/code-frame": "7.5.5", + "address": "1.1.2", + "browserslist": "4.7.3", + "chalk": "2.4.2", + "cross-spawn": "6.0.5", + "detect-port-alt": "1.1.6", + "escape-string-regexp": "1.0.5", + "filesize": "3.6.1", + "find-up": "3.0.0", + "fork-ts-checker-webpack-plugin": "3.1.0", + "global-modules": "2.0.0", + "globby": "8.0.2", + "gzip-size": "5.1.1", + "immer": "1.10.0", + "inquirer": "6.5.0", + "is-root": "2.1.0", + "loader-utils": "1.2.3", + "open": "^7.0.0", + "pkg-up": "2.0.0", + "react-error-overlay": "^6.0.4", + "recursive-readdir": "2.2.2", + "shell-quote": "1.7.2", + "strip-ansi": "5.2.0", + "text-table": "0.2.0" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.5.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", + "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", + "requires": { + "@babel/highlight": "^7.0.0" + } + }, + "ansi-escapes": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", + "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==" + }, + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + }, + "browserslist": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.7.3.tgz", + "integrity": "sha512-jWvmhqYpx+9EZm/FxcZSbUZyDEvDTLDi3nSAKbzEkyWvtI0mNSmUosey+5awDW1RUlrgXbQb5A6qY1xQH9U6MQ==", + "requires": { + "caniuse-lite": "^1.0.30001010", + "electron-to-chromium": "^1.3.306", + "node-releases": "^1.1.40" + } + }, + "cli-cursor": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", + "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", + "requires": { + "restore-cursor": "^2.0.0" + } + }, + "figures": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", + "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "inquirer": { + "version": "6.5.0", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.5.0.tgz", + "integrity": "sha512-scfHejeG/lVZSpvCXpsB4j/wQNPM5JC8kiElOI0OUTwmc1RTpXr4H32/HOlQHcZiYl2z2VElwuCVDRG8vFmbnA==", + "requires": { + "ansi-escapes": "^3.2.0", + "chalk": "^2.4.2", + "cli-cursor": "^2.1.0", + "cli-width": "^2.0.0", + "external-editor": "^3.0.3", + "figures": "^2.0.0", + "lodash": "^4.17.12", + "mute-stream": "0.0.7", + "run-async": "^2.2.0", + "rxjs": "^6.4.0", + "string-width": "^2.1.0", + "strip-ansi": "^5.1.0", + "through": "^2.3.6" + } + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "mimic-fn": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", + "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==" + }, + "mute-stream": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", + "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=" + }, + "onetime": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", + "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "restore-cursor": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", + "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", + "requires": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + } + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + } + } + }, + "react-dom": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.12.0.tgz", + "integrity": "sha512-LMxFfAGrcS3kETtQaCkTKjMiifahaMySFDn71fZUNpPHZQEzmk/GiAeIT8JSOrHB23fnuCOMruL2a8NYlw+8Gw==", + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1", + "prop-types": "^15.6.2", + "scheduler": "^0.18.0" + } + }, + "react-error-overlay": { + "version": "6.0.4", + "resolved": "https://registry.npmjs.org/react-error-overlay/-/react-error-overlay-6.0.4.tgz", + "integrity": "sha512-ueZzLmHltszTshDMwyfELDq8zOA803wQ1ZuzCccXa1m57k1PxSHfflPD5W9YIiTXLs0JTLzoj6o1LuM5N6zzNA==" + }, + "react-event-listener": { + "version": "0.6.6", + "resolved": "https://registry.npmjs.org/react-event-listener/-/react-event-listener-0.6.6.tgz", + "integrity": "sha512-+hCNqfy7o9wvO6UgjqFmBzARJS7qrNoda0VqzvOuioEpoEXKutiKuv92dSz6kP7rYLmyHPyYNLesi5t/aH1gfw==", + "requires": { + "@babel/runtime": "^7.2.0", + "prop-types": "^15.6.0", + "warning": "^4.0.1" + }, + "dependencies": { + "warning": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/warning/-/warning-4.0.3.tgz", + "integrity": "sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w==", + "requires": { + "loose-envify": "^1.0.0" + } + } + } + }, + "react-is": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.12.0.tgz", + "integrity": "sha512-rPCkf/mWBtKc97aLL9/txD8DZdemK0vkA3JMLShjlJB3Pj3s+lpf1KaBzMfQrAmhMQB0n1cU/SUGgKKBCe837Q==" + }, + "react-scripts": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/react-scripts/-/react-scripts-3.3.0.tgz", + "integrity": "sha512-hzPc6bxCc9GnsspWqk494c2Gpd0dRbk/C8q76BNQIENi9GMwoxFljOEcZoZcpFpJgQ45alxFR6QaLt+51qie7g==", + "requires": { + "@babel/core": "7.7.4", + "@svgr/webpack": "4.3.3", + "@typescript-eslint/eslint-plugin": "^2.8.0", + "@typescript-eslint/parser": "^2.8.0", + "babel-eslint": "10.0.3", + "babel-jest": "^24.9.0", + "babel-loader": "8.0.6", + "babel-plugin-named-asset-import": "^0.3.5", + "babel-preset-react-app": "^9.1.0", + "camelcase": "^5.3.1", + "case-sensitive-paths-webpack-plugin": "2.2.0", + "css-loader": "3.2.0", + "dotenv": "8.2.0", + "dotenv-expand": "5.1.0", + "eslint": "^6.6.0", + "eslint-config-react-app": "^5.1.0", + "eslint-loader": "3.0.2", + "eslint-plugin-flowtype": "3.13.0", + "eslint-plugin-import": "2.18.2", + "eslint-plugin-jsx-a11y": "6.2.3", + "eslint-plugin-react": "7.16.0", + "eslint-plugin-react-hooks": "^1.6.1", + "file-loader": "4.3.0", + "fs-extra": "^8.1.0", + "fsevents": "2.1.2", + "html-webpack-plugin": "4.0.0-beta.5", + "identity-obj-proxy": "3.0.0", + "jest": "24.9.0", + "jest-environment-jsdom-fourteen": "0.1.0", + "jest-resolve": "24.9.0", + "jest-watch-typeahead": "0.4.2", + "mini-css-extract-plugin": "0.8.0", + "optimize-css-assets-webpack-plugin": "5.0.3", + "pnp-webpack-plugin": "1.5.0", + "postcss-flexbugs-fixes": "4.1.0", + "postcss-loader": "3.0.0", + "postcss-normalize": "8.0.1", + "postcss-preset-env": "6.7.0", + "postcss-safe-parser": "4.0.1", + "react-app-polyfill": "^1.0.5", + "react-dev-utils": "^10.0.0", + "resolve": "1.12.2", + "resolve-url-loader": "3.1.1", + "sass-loader": "8.0.0", + "semver": "6.3.0", + "style-loader": "1.0.0", + "terser-webpack-plugin": "2.2.1", + "ts-pnp": "1.1.5", + "url-loader": "2.3.0", + "webpack": "4.41.2", + "webpack-dev-server": "3.9.0", + "webpack-manifest-plugin": "2.2.0", + "workbox-webpack-plugin": "4.3.1" + } + }, + "react-transition-group": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-1.2.1.tgz", + "integrity": "sha512-CWaL3laCmgAFdxdKbhhps+c0HRGF4c+hdM4H23+FI1QBNUyx/AMeIJGWorehPNSaKnQNOAxL7PQmqMu78CDj3Q==", + "requires": { + "chain-function": "^1.0.0", + "dom-helpers": "^3.2.0", + "loose-envify": "^1.3.1", + "prop-types": "^15.5.6", + "warning": "^3.0.0" + } + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-4.0.0.tgz", + "integrity": "sha512-6etQSH7nJGsK0RbG/2TeDzZFa8shjQ1um+SwQQ5cwKy0dhSXdOncEhb1CPpvQG4h7FyOV6EB6YlV0yJvZQNAkA==", + "requires": { + "find-up": "^3.0.0", + "read-pkg": "^3.0.0" + } + }, + "readable-stream": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.4.0.tgz", + "integrity": "sha512-jItXPLmrSR8jmTRmRWJXCnGJsfy85mB3Wd/uINMXA65yrnFo0cPClFIUWzo2najVNSl+mx7/4W8ttlLWJe99pQ==", + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + }, + "readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", + "requires": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "realpath-native": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/realpath-native/-/realpath-native-1.1.0.tgz", + "integrity": "sha512-wlgPA6cCIIg9gKz0fgAPjnzh4yR/LnXovwuo9hvyGvx3h8nX4+/iLZplfUWasXpqD8BdnGnP5njOFjkUwPzvjA==", + "requires": { + "util.promisify": "^1.0.0" + } + }, + "recompose": { + "version": "0.26.0", + "resolved": "https://registry.npmjs.org/recompose/-/recompose-0.26.0.tgz", + "integrity": "sha512-KwOu6ztO0mN5vy3+zDcc45lgnaUoaQse/a5yLVqtzTK13czSWnFGmXbQVmnoMgDkI5POd1EwIKSbjU1V7xdZog==", + "requires": { + "change-emitter": "^0.1.2", + "fbjs": "^0.8.1", + "hoist-non-react-statics": "^2.3.1", + "symbol-observable": "^1.0.4" + } + }, + "recursive-readdir": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/recursive-readdir/-/recursive-readdir-2.2.2.tgz", + "integrity": "sha512-nRCcW9Sj7NuZwa2XvH9co8NPeXUBhZP7CRKJtU+cS6PW9FpCIFoI5ib0NT1ZrbNuPoRy0ylyCaUL8Gih4LSyFg==", + "requires": { + "minimatch": "3.0.4" + } + }, + "redent": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-3.0.0.tgz", + "integrity": "sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg==", + "requires": { + "indent-string": "^4.0.0", + "strip-indent": "^3.0.0" + } + }, + "regenerate": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.0.tgz", + "integrity": "sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg==" + }, + "regenerate-unicode-properties": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-8.1.0.tgz", + "integrity": "sha512-LGZzkgtLY79GeXLm8Dp0BVLdQlWICzBnJz/ipWUgo59qBaZ+BHtq51P2q1uVZlppMuUAT37SDk39qUbjTWB7bA==", + "requires": { + "regenerate": "^1.4.0" + } + }, + "regenerator-runtime": { + "version": "0.13.3", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.3.tgz", + "integrity": "sha512-naKIZz2GQ8JWh///G7L3X6LaQUAMp2lvb1rvwwsURe/VXwD6VMfr+/1NuNw3ag8v2kY1aQ/go5SNn79O9JU7yw==" + }, + "regenerator-transform": { + "version": "0.14.1", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.14.1.tgz", + "integrity": "sha512-flVuee02C3FKRISbxhXl9mGzdbWUVHubl1SMaknjxkFB1/iqpJhArQUvRxOOPEc/9tAiX0BaQ28FJH10E4isSQ==", + "requires": { + "private": "^0.1.6" + } + }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "requires": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + } + }, + "regex-parser": { + "version": "2.2.10", + "resolved": "https://registry.npmjs.org/regex-parser/-/regex-parser-2.2.10.tgz", + "integrity": "sha512-8t6074A68gHfU8Neftl0Le6KTDwfGAj7IyjPIMSfikI2wJUTHDMaIq42bUsfVnj8mhx0R+45rdUXHGpN164avA==" + }, + "regexp.prototype.flags": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.3.0.tgz", + "integrity": "sha512-2+Q0C5g951OlYlJz6yu5/M33IcsESLlLfsyIaLJaG4FA2r4yP8MvVMJUUP/fVBkSpbbbZlS5gynbEWLipiiXiQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1" + } + }, + "regexpp": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.0.0.tgz", + "integrity": "sha512-Z+hNr7RAVWxznLPuA7DIh8UNX1j9CDrUQxskw9IrBE1Dxue2lyXT+shqEIeLUjrokxIP8CMy1WkjgG3rTsd5/g==" + }, + "regexpu-core": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-4.6.0.tgz", + "integrity": "sha512-YlVaefl8P5BnFYOITTNzDvan1ulLOiXJzCNZxduTIosN17b87h3bvG9yHMoHaRuo88H4mQ06Aodj5VtYGGGiTg==", + "requires": { + "regenerate": "^1.4.0", + "regenerate-unicode-properties": "^8.1.0", + "regjsgen": "^0.5.0", + "regjsparser": "^0.6.0", + "unicode-match-property-ecmascript": "^1.0.4", + "unicode-match-property-value-ecmascript": "^1.1.0" + } + }, + "regjsgen": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.5.1.tgz", + "integrity": "sha512-5qxzGZjDs9w4tzT3TPhCJqWdCc3RLYwy9J2NB0nm5Lz+S273lvWcpjaTGHsT1dc6Hhfq41uSEOw8wBmxrKOuyg==" + }, + "regjsparser": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.2.tgz", + "integrity": "sha512-E9ghzUtoLwDekPT0DYCp+c4h+bvuUpe6rRHCTYn6eGoqj1LgKXxT6I0Il4WbjhQkOghzi/V+y03bPKvbllL93Q==", + "requires": { + "jsesc": "~0.5.0" + }, + "dependencies": { + "jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=" + } + } + }, + "relateurl": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/relateurl/-/relateurl-0.2.7.tgz", + "integrity": "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=" + }, + "remove-trailing-separator": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", + "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=" + }, + "renderkid": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/renderkid/-/renderkid-2.0.3.tgz", + "integrity": "sha512-z8CLQp7EZBPCwCnncgf9C4XAi3WR0dv+uWu/PjIyhhAb5d6IJ/QZqlHFprHeKT+59//V6BNUsLbvN8+2LarxGA==", + "requires": { + "css-select": "^1.1.0", + "dom-converter": "^0.2", + "htmlparser2": "^3.3.0", + "strip-ansi": "^3.0.0", + "utila": "^0.4.0" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + }, + "css-select": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-1.2.0.tgz", + "integrity": "sha1-KzoRBTnFNV8c2NMUYj6HCxIeyFg=", + "requires": { + "boolbase": "~1.0.0", + "css-what": "2.1", + "domutils": "1.5.1", + "nth-check": "~1.0.1" + } + }, + "css-what": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-2.1.3.tgz", + "integrity": "sha512-a+EPoD+uZiNfh+5fxw2nO9QwFa6nJe2Or35fGY6Ipw1R3R4AGz1d1TEZrCegvw2YTmZ0jXirGYlzxxpYSHwpEg==" + }, + "domutils": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", + "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + }, + "repeat-element": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", + "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==" + }, + "repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" + }, + "request": { + "version": "2.88.0", + "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", + "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", + "requires": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.0", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.4.3", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + }, + "dependencies": { + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" + }, + "tough-cookie": { + "version": "2.4.3", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", + "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", + "requires": { + "psl": "^1.1.24", + "punycode": "^1.4.1" + } + } + } + }, + "request-promise-core": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.3.tgz", + "integrity": "sha512-QIs2+ArIGQVp5ZYbWD5ZLCY29D5CfWizP8eWnm8FoGD1TX61veauETVQbrV60662V0oFBkrDOuaBI8XgtuyYAQ==", + "requires": { + "lodash": "^4.17.15" + } + }, + "request-promise-native": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/request-promise-native/-/request-promise-native-1.0.8.tgz", + "integrity": "sha512-dapwLGqkHtwL5AEbfenuzjTYg35Jd6KPytsC2/TLkVMz8rm+tNt72MGUWT1RP/aYawMpN6HqbNGBQaRcBtjQMQ==", + "requires": { + "request-promise-core": "1.1.3", + "stealthy-require": "^1.1.1", + "tough-cookie": "^2.3.3" + } + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" + }, + "require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", + "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==" + }, + "requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", + "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=" + }, + "resolve": { + "version": "1.12.2", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.2.tgz", + "integrity": "sha512-cAVTI2VLHWYsGOirfeYVVQ7ZDejtQ9fp4YhYckWDEkFfqbVjaT11iM8k6xSAfGFMM+gDpZjMnFssPu8we+mqFw==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "resolve-cwd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-2.0.0.tgz", + "integrity": "sha1-AKn3OHVW4nA46uIyyqNypqWbZlo=", + "requires": { + "resolve-from": "^3.0.0" + } + }, + "resolve-from": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", + "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=" + }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=" + }, + "resolve-url-loader": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/resolve-url-loader/-/resolve-url-loader-3.1.1.tgz", + "integrity": "sha512-K1N5xUjj7v0l2j/3Sgs5b8CjrrgtC70SmdCuZiJ8tSyb5J+uk3FoeZ4b7yTnH6j7ngI+Bc5bldHJIa8hYdu2gQ==", + "requires": { + "adjust-sourcemap-loader": "2.0.0", + "camelcase": "5.3.1", + "compose-function": "3.0.3", + "convert-source-map": "1.7.0", + "es6-iterator": "2.0.3", + "loader-utils": "1.2.3", + "postcss": "7.0.21", + "rework": "1.0.1", + "rework-visit": "1.0.0", + "source-map": "0.6.1" + }, + "dependencies": { + "postcss": { + "version": "7.0.21", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.21.tgz", + "integrity": "sha512-uIFtJElxJo29QC753JzhidoAhvp/e/Exezkdhfmt8AymWT6/5B7W1WmponYWkHk2eg6sONyTch0A3nkMPun3SQ==", + "requires": { + "chalk": "^2.4.2", + "source-map": "^0.6.1", + "supports-color": "^6.1.0" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "restore-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", + "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", + "requires": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + } + }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==" + }, + "retry": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", + "integrity": "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=" + }, + "rework": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/rework/-/rework-1.0.1.tgz", + "integrity": "sha1-MIBqhBNCtUUQqkEQhQzUhTQUSqc=", + "requires": { + "convert-source-map": "^0.3.3", + "css": "^2.0.0" + }, + "dependencies": { + "convert-source-map": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-0.3.5.tgz", + "integrity": "sha1-8dgClQr33SYxof6+BZZVDIarMZA=" + } + } + }, + "rework-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/rework-visit/-/rework-visit-1.0.0.tgz", + "integrity": "sha1-mUWygD8hni96ygCtuLyfZA+ELJo=" + }, + "rgb-regex": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/rgb-regex/-/rgb-regex-1.0.1.tgz", + "integrity": "sha1-wODWiC3w4jviVKR16O3UGRX+rrE=" + }, + "rgba-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/rgba-regex/-/rgba-regex-1.0.0.tgz", + "integrity": "sha1-QzdOLiyglosO8VI0YLfXMP8i7rM=" + }, + "rimraf": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", + "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", + "requires": { + "glob": "^7.1.3" + } + }, + "ripemd160": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", + "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "rsvp": { + "version": "4.8.5", + "resolved": "https://registry.npmjs.org/rsvp/-/rsvp-4.8.5.tgz", + "integrity": "sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==" + }, + "run-async": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", + "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", + "requires": { + "is-promise": "^2.1.0" + } + }, + "run-queue": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/run-queue/-/run-queue-1.0.3.tgz", + "integrity": "sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec=", + "requires": { + "aproba": "^1.1.1" + } + }, + "rxjs": { + "version": "6.5.4", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.4.tgz", + "integrity": "sha512-naMQXcgEo3csAEGvw/NydRA0fuS2nDZJiw1YUWFKU7aPPAPGZEsD4Iimit96qwCieH6y614MCLYwdkrWx7z/7Q==", + "requires": { + "tslib": "^1.9.0" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "requires": { + "ret": "~0.1.10" + } + }, + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" + }, + "sane": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/sane/-/sane-4.1.0.tgz", + "integrity": "sha512-hhbzAgTIX8O7SHfp2c8/kREfEn4qO/9q8C9beyY6+tvZ87EpoZ3i1RIEvp27YBswnNbY9mWd6paKVmKbAgLfZA==", + "requires": { + "@cnakazawa/watch": "^1.0.3", + "anymatch": "^2.0.0", + "capture-exit": "^2.0.0", + "exec-sh": "^0.3.2", + "execa": "^1.0.0", + "fb-watchman": "^2.0.0", + "micromatch": "^3.1.4", + "minimist": "^1.1.1", + "walker": "~1.0.5" + } + }, + "sanitize.css": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/sanitize.css/-/sanitize.css-10.0.0.tgz", + "integrity": "sha512-vTxrZz4dX5W86M6oVWVdOVe72ZiPs41Oi7Z6Km4W5Turyz28mrXSJhhEBZoRtzJWIv3833WKVwLSDWWkEfupMg==" + }, + "sass-loader": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-8.0.0.tgz", + "integrity": "sha512-+qeMu563PN7rPdit2+n5uuYVR0SSVwm0JsOUsaJXzgYcClWSlmX0iHDnmeOobPkf5kUglVot3QS6SyLyaQoJ4w==", + "requires": { + "clone-deep": "^4.0.1", + "loader-utils": "^1.2.3", + "neo-async": "^2.6.1", + "schema-utils": "^2.1.0", + "semver": "^6.3.0" + }, + "dependencies": { + "clone-deep": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", + "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", + "requires": { + "is-plain-object": "^2.0.4", + "kind-of": "^6.0.2", + "shallow-clone": "^3.0.0" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + }, + "shallow-clone": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", + "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", + "requires": { + "kind-of": "^6.0.2" + } + } + } + }, + "sax": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", + "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" + }, + "saxes": { + "version": "3.1.11", + "resolved": "https://registry.npmjs.org/saxes/-/saxes-3.1.11.tgz", + "integrity": "sha512-Ydydq3zC+WYDJK1+gRxRapLIED9PWeSuuS41wqyoRmzvhhh9nc+QQrVMKJYzJFULazeGhzSV0QleN2wD3boh2g==", + "requires": { + "xmlchars": "^2.1.1" + } + }, + "scheduler": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.18.0.tgz", + "integrity": "sha512-agTSHR1Nbfi6ulI0kYNK0203joW2Y5W4po4l+v03tOoiJKpTBbxpNhWDvqc/4IcOw+KLmSiQLTasZ4cab2/UWQ==", + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1" + } + }, + "schema-utils": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-2.6.1.tgz", + "integrity": "sha512-0WXHDs1VDJyo+Zqs9TKLKyD/h7yDpHUhEFsM2CzkICFdoX1av+GBq/J2xRTFfsQO5kBfhZzANf2VcIm84jqDbg==", + "requires": { + "ajv": "^6.10.2", + "ajv-keywords": "^3.4.1" + } + }, + "select-hose": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", + "integrity": "sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo=" + }, + "selfsigned": { + "version": "1.10.7", + "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-1.10.7.tgz", + "integrity": "sha512-8M3wBCzeWIJnQfl43IKwOmC4H/RAp50S8DF60znzjW5GVqTcSe2vWclt7hmYVPkKPlHWOu5EaWOMZ2Y6W8ZXTA==", + "requires": { + "node-forge": "0.9.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + }, + "send": { + "version": "0.17.1", + "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", + "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", + "requires": { + "debug": "2.6.9", + "depd": "~1.1.2", + "destroy": "~1.0.4", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "~1.7.2", + "mime": "1.6.0", + "ms": "2.1.1", + "on-finished": "~2.3.0", + "range-parser": "~1.2.1", + "statuses": "~1.5.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + }, + "dependencies": { + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, + "mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" + }, + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", + "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" + } + } + }, + "serialize-javascript": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-2.1.2.tgz", + "integrity": "sha512-rs9OggEUF0V4jUSecXazOYsLfu7OGK2qIn3c7IPBiffz32XniEp/TX9Xmc9LQfK2nQ2QKHvZ2oygKUGU0lG4jQ==" + }, + "serve-index": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz", + "integrity": "sha1-03aNabHn2C5c4FD/9bRTvqEqkjk=", + "requires": { + "accepts": "~1.3.4", + "batch": "0.6.1", + "debug": "2.6.9", + "escape-html": "~1.0.3", + "http-errors": "~1.6.2", + "mime-types": "~2.1.17", + "parseurl": "~1.3.2" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", + "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + } + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + }, + "setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" + } + } + }, + "serve-static": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", + "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", + "requires": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.17.1" + } + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" + }, + "set-value": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", + "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "setimmediate": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", + "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=" + }, + "setprototypeof": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", + "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" + }, + "sha.js": { + "version": "2.4.11", + "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", + "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "shallow-clone": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-0.1.2.tgz", + "integrity": "sha1-WQnodLp3EG1zrEFM/sH/yofZcGA=", + "requires": { + "is-extendable": "^0.1.1", + "kind-of": "^2.0.1", + "lazy-cache": "^0.2.3", + "mixin-object": "^2.0.1" + }, + "dependencies": { + "kind-of": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-2.0.1.tgz", + "integrity": "sha1-AY7HpM5+OobLkUG+UZ0kyPqpgbU=", + "requires": { + "is-buffer": "^1.0.2" + } + }, + "lazy-cache": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-0.2.7.tgz", + "integrity": "sha1-f+3fLctu23fRHvHRF6tf/fCrG2U=" + } + } + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" + }, + "shell-quote": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.2.tgz", + "integrity": "sha512-mRz/m/JVscCrkMyPqHc/bczi3OQHkLTqXHEFu0zDhK/qfv3UcOA4SVmRCLmos4bhjr9ekVQubj/R7waKapmiQg==" + }, + "shellwords": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/shellwords/-/shellwords-0.1.1.tgz", + "integrity": "sha512-vFwSUfQvqybiICwZY5+DAWIPLKsWO31Q91JSKl3UYv+K5c2QRPzn0qzec6QPu1Qc9eHYItiP3NdJqNVqetYAww==" + }, + "signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" + }, + "simple-assign": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/simple-assign/-/simple-assign-0.1.0.tgz", + "integrity": "sha1-F/0wZqXz13OPUDIbsPFMooHMS6o=" + }, + "simple-swizzle": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", + "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", + "requires": { + "is-arrayish": "^0.3.1" + }, + "dependencies": { + "is-arrayish": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", + "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==" + } + } + }, + "sisteransi": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.4.tgz", + "integrity": "sha512-/ekMoM4NJ59ivGSfKapeG+FWtrmWvA1p6FBZwXrqojw90vJu8lBmrTxCMuBCydKtkaUe2zt4PlxeTKpjwMbyig==" + }, + "slash": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz", + "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==" + }, + "slice-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", + "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", + "requires": { + "ansi-styles": "^3.2.0", + "astral-regex": "^1.0.0", + "is-fullwidth-code-point": "^2.0.0" + }, + "dependencies": { + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + } + } + }, + "snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", + "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "requires": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, + "snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "requires": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "requires": { + "kind-of": "^3.2.0" + } + }, + "sockjs": { + "version": "0.3.19", + "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.19.tgz", + "integrity": "sha512-V48klKZl8T6MzatbLlzzRNhMepEys9Y4oGFpypBFFn1gLI/QQ9HtLLyWJNbPlwGLelOVOEijUbTTJeLLI59jLw==", + "requires": { + "faye-websocket": "^0.10.0", + "uuid": "^3.0.1" + } + }, + "sockjs-client": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/sockjs-client/-/sockjs-client-1.4.0.tgz", + "integrity": "sha512-5zaLyO8/nri5cua0VtOrFXBPK1jbL4+1cebT/mmKA1E1ZXOvJrII75bPu0l0k843G/+iAbhEqzyKr0w/eCCj7g==", + "requires": { + "debug": "^3.2.5", + "eventsource": "^1.0.7", + "faye-websocket": "~0.11.1", + "inherits": "^2.0.3", + "json3": "^3.3.2", + "url-parse": "^1.4.3" + }, + "dependencies": { + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "requires": { + "ms": "^2.1.1" + } + }, + "faye-websocket": { + "version": "0.11.3", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.3.tgz", + "integrity": "sha512-D2y4bovYpzziGgbHYtGCMjlJM36vAl/y+xUyn1C+FVx8szd1E+86KwVw6XvYSzOP8iMpm1X0I4xJD+QtUb36OA==", + "requires": { + "websocket-driver": ">=0.5.1" + } + } + } + }, + "sort-keys": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-1.1.2.tgz", + "integrity": "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=", + "requires": { + "is-plain-obj": "^1.0.0" + } + }, + "source-list-map": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/source-list-map/-/source-list-map-2.0.1.tgz", + "integrity": "sha512-qnQ7gVMxGNxsiL4lEuJwe/To8UnK7fAnmbGEEH8RpLouuKbeEm0lhbQVFIrNSuB+G7tVrAlVsZgETT5nljf+Iw==" + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" + }, + "source-map-resolve": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.3.tgz", + "integrity": "sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw==", + "requires": { + "atob": "^2.1.2", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "source-map-support": { + "version": "0.5.16", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.16.tgz", + "integrity": "sha512-efyLRJDr68D9hBBNIPWFjhpFzURh+KJykQwvMyW5UiZzYwoF6l4YMMDIJJEyFWxWCqfyxLzz6tSfUFR+kXXsVQ==", + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "source-map-url": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", + "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=" + }, + "spdx-correct": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", + "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", + "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==" + }, + "spdx-expression-parse": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", + "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", + "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==" + }, + "spdy": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.1.tgz", + "integrity": "sha512-HeZS3PBdMA+sZSu0qwpCxl3DeALD5ASx8pAX0jZdKXSpPWbQ6SYGnlg3BBmYLx5LtiZrmkAZfErCm2oECBcioA==", + "requires": { + "debug": "^4.1.0", + "handle-thing": "^2.0.0", + "http-deceiver": "^1.2.7", + "select-hose": "^2.0.0", + "spdy-transport": "^3.0.0" + } + }, + "spdy-transport": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz", + "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==", + "requires": { + "debug": "^4.1.0", + "detect-node": "^2.0.4", + "hpack.js": "^2.1.6", + "obuf": "^1.1.2", + "readable-stream": "^3.0.6", + "wbuf": "^1.7.3" + } + }, + "split-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "requires": { + "extend-shallow": "^3.0.0" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" + }, + "sshpk": { + "version": "1.16.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", + "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", + "requires": { + "asn1": "~0.2.3", + "assert-plus": "^1.0.0", + "bcrypt-pbkdf": "^1.0.0", + "dashdash": "^1.12.0", + "ecc-jsbn": "~0.1.1", + "getpass": "^0.1.1", + "jsbn": "~0.1.0", + "safer-buffer": "^2.0.2", + "tweetnacl": "~0.14.0" + } + }, + "ssri": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-7.1.0.tgz", + "integrity": "sha512-77/WrDZUWocK0mvA5NTRQyveUf+wsrIc6vyrxpS8tVvYBcX215QbafrJR3KtkpskIzoFLqqNuuYQvxaMjXJ/0g==", + "requires": { + "figgy-pudding": "^3.5.1", + "minipass": "^3.1.1" + } + }, + "stable": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz", + "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==" + }, + "stack-utils": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.2.tgz", + "integrity": "sha512-MTX+MeG5U994cazkjd/9KNAapsHnibjMLnfXodlkXw76JEea0UiNzrqidzo1emMwk7w5Qhc9jd4Bn9TBb1MFwA==" + }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "requires": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "statuses": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", + "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" + }, + "stealthy-require": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz", + "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=" + }, + "stream-browserify": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.2.tgz", + "integrity": "sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg==", + "requires": { + "inherits": "~2.0.1", + "readable-stream": "^2.0.2" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "stream-each": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/stream-each/-/stream-each-1.2.3.tgz", + "integrity": "sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw==", + "requires": { + "end-of-stream": "^1.1.0", + "stream-shift": "^1.0.0" + } + }, + "stream-http": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.8.3.tgz", + "integrity": "sha512-+TSkfINHDo4J+ZobQLWiMouQYB+UVYFttRA94FpEzzJ7ZdqcL4uUUQ7WkdkI4DSozGmgBUE/a47L+38PenXhUw==", + "requires": { + "builtin-status-codes": "^3.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.3.6", + "to-arraybuffer": "^1.0.0", + "xtend": "^4.0.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "stream-shift": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", + "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==" + }, + "strict-uri-encode": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", + "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=" + }, + "string-length": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/string-length/-/string-length-2.0.0.tgz", + "integrity": "sha1-1A27aGo6zpYMHP/KVivyxF+DY+0=", + "requires": { + "astral-regex": "^1.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "string-width": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", + "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", + "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", + "requires": { + "ansi-regex": "^5.0.0" + } + } + } + }, + "string.prototype.trimleft": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.1.tgz", + "integrity": "sha512-iu2AGd3PuP5Rp7x2kEZCrB2Nf41ehzh+goo8TV7z8/XDBbsvc6HQIlUl9RjkZ4oyrW1XM5UwlGl1oVEaDjg6Ag==", + "requires": { + "define-properties": "^1.1.3", + "function-bind": "^1.1.1" + } + }, + "string.prototype.trimright": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.1.tgz", + "integrity": "sha512-qFvWL3/+QIgZXVmJBfpHmxLB7xsUXz6HsUmP8+5dRaC3Q7oKUv9Vo6aMCRZC1smrtyECFsIT30PqBJ1gTjAs+g==", + "requires": { + "define-properties": "^1.1.3", + "function-bind": "^1.1.1" + } + }, + "string_decoder": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "requires": { + "safe-buffer": "~5.2.0" + }, + "dependencies": { + "safe-buffer": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", + "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==" + } + } + }, + "stringify-object": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz", + "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==", + "requires": { + "get-own-enumerable-property-symbols": "^3.0.0", + "is-obj": "^1.0.1", + "is-regexp": "^1.0.0" + } + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "requires": { + "ansi-regex": "^4.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" + } + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=" + }, + "strip-comments": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/strip-comments/-/strip-comments-1.0.2.tgz", + "integrity": "sha512-kL97alc47hoyIQSV165tTt9rG5dn4w1dNnBhOQ3bOU1Nc1hel09jnXANaHJ7vzHLd4Ju8kseDGzlev96pghLFw==", + "requires": { + "babel-extract-comments": "^1.0.0", + "babel-plugin-transform-object-rest-spread": "^6.26.0" + } + }, + "strip-eof": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", + "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" + }, + "strip-indent": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz", + "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==", + "requires": { + "min-indent": "^1.0.0" + } + }, + "strip-json-comments": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", + "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==" + }, + "style-loader": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-1.0.0.tgz", + "integrity": "sha512-B0dOCFwv7/eY31a5PCieNwMgMhVGFe9w+rh7s/Bx8kfFkrth9zfTZquoYvdw8URgiqxObQKcpW51Ugz1HjfdZw==", + "requires": { + "loader-utils": "^1.2.3", + "schema-utils": "^2.0.1" + } + }, + "stylehacks": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-4.0.3.tgz", + "integrity": "sha512-7GlLk9JwlElY4Y6a/rmbH2MhVlTyVmiJd1PfTCqFaIBEGMYNsrO/v3SeGTdhBThLg4Z+NbOk/qFMwCa+J+3p/g==", + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.1.tgz", + "integrity": "sha1-T4dfSvsMllc9XPTXQBGu4lCn6GU=", + "requires": { + "dot-prop": "^4.1.1", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "requires": { + "has-flag": "^3.0.0" + } + }, + "svg-parser": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/svg-parser/-/svg-parser-2.0.2.tgz", + "integrity": "sha512-1gtApepKFweigFZj3sGO8KT8LvVZK8io146EzXrpVuWCDAbISz/yMucco3hWTkpZNoPabM+dnMOpy6Swue68Zg==" + }, + "svgo": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/svgo/-/svgo-1.3.2.tgz", + "integrity": "sha512-yhy/sQYxR5BkC98CY7o31VGsg014AKLEPxdfhora76l36hD9Rdy5NZA/Ocn6yayNPgSamYdtX2rFJdcv07AYVw==", + "requires": { + "chalk": "^2.4.1", + "coa": "^2.0.2", + "css-select": "^2.0.0", + "css-select-base-adapter": "^0.1.1", + "css-tree": "1.0.0-alpha.37", + "csso": "^4.0.2", + "js-yaml": "^3.13.1", + "mkdirp": "~0.5.1", + "object.values": "^1.1.0", + "sax": "~1.2.4", + "stable": "^0.1.8", + "unquote": "~1.1.1", + "util.promisify": "~1.0.0" + } + }, + "symbol-observable": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.2.0.tgz", + "integrity": "sha512-e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ==" + }, + "symbol-tree": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", + "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==" + }, + "table": { + "version": "5.4.6", + "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", + "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", + "requires": { + "ajv": "^6.10.2", + "lodash": "^4.17.14", + "slice-ansi": "^2.1.0", + "string-width": "^3.0.0" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "tapable": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.3.tgz", + "integrity": "sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA==" + }, + "terser": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/terser/-/terser-4.6.2.tgz", + "integrity": "sha512-6FUjJdY2i3WZAtYBtnV06OOcOfzl+4hSKYE9wgac8rkLRBToPDDrBB2AcHwQD/OKDxbnvhVy2YgOPWO2SsKWqg==", + "requires": { + "commander": "^2.20.0", + "source-map": "~0.6.1", + "source-map-support": "~0.5.12" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "terser-webpack-plugin": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-2.2.1.tgz", + "integrity": "sha512-jwdauV5Al7zopR6OAYvIIRcxXCSvLjZjr7uZE8l2tIWb/ryrGN48sJftqGf5k9z09tWhajx53ldp0XPI080YnA==", + "requires": { + "cacache": "^13.0.1", + "find-cache-dir": "^3.0.0", + "jest-worker": "^24.9.0", + "schema-utils": "^2.5.0", + "serialize-javascript": "^2.1.0", + "source-map": "^0.6.1", + "terser": "^4.3.9", + "webpack-sources": "^1.4.3" + }, + "dependencies": { + "find-cache-dir": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.2.0.tgz", + "integrity": "sha512-1JKclkYYsf1q9WIJKLZa9S9muC+08RIjzAlLrK4QcYLJMS6mk9yombQ9qf+zJ7H9LS800k0s44L4sDq9VYzqyg==", + "requires": { + "commondir": "^1.0.1", + "make-dir": "^3.0.0", + "pkg-dir": "^4.1.0" + } + }, + "find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "requires": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + } + }, + "locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "requires": { + "p-locate": "^4.1.0" + } + }, + "make-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.0.0.tgz", + "integrity": "sha512-grNJDhb8b1Jm1qeqW5R/O63wUo4UXo2v2HMic6YT9i/HBlF93S8jkMgH7yugvY9ABDShH4VZMn8I+U8+fCNegw==", + "requires": { + "semver": "^6.0.0" + } + }, + "p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "requires": { + "p-limit": "^2.2.0" + } + }, + "path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" + }, + "pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", + "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "requires": { + "find-up": "^4.0.0" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "test-exclude": { + "version": "5.2.3", + "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-5.2.3.tgz", + "integrity": "sha512-M+oxtseCFO3EDtAaGH7iiej3CBkzXqFMbzqYAACdzKui4eZA+pq3tZEwChvOdNfa7xxy8BfbmgJSIr43cC/+2g==", + "requires": { + "glob": "^7.1.3", + "minimatch": "^3.0.4", + "read-pkg-up": "^4.0.0", + "require-main-filename": "^2.0.0" + } + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=" + }, + "throat": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/throat/-/throat-4.1.0.tgz", + "integrity": "sha1-iQN8vJLFarGJJua6TLsgDhVnKmo=" + }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" + }, + "through2": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", + "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", + "requires": { + "readable-stream": "~2.3.6", + "xtend": "~4.0.1" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "thunky": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", + "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==" + }, + "timers-browserify": { + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-2.0.11.tgz", + "integrity": "sha512-60aV6sgJ5YEbzUdn9c8kYGIqOubPoUdqQCul3SBAsRCZ40s6Y5cMcrW4dt3/k/EsbLVJNl9n6Vz3fTc+k2GeKQ==", + "requires": { + "setimmediate": "^1.0.4" + } + }, + "timsort": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/timsort/-/timsort-0.3.0.tgz", + "integrity": "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=" + }, + "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", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "requires": { + "os-tmpdir": "~1.0.2" + } + }, + "tmpl": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.4.tgz", + "integrity": "sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE=" + }, + "to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", + "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=" + }, + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=" + }, + "to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", + "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "requires": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + } + }, + "to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", + "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "requires": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + } + }, + "toidentifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", + "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" + }, + "tough-cookie": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", + "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", + "requires": { + "psl": "^1.1.28", + "punycode": "^2.1.1" + } + }, + "tr46": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-1.0.1.tgz", + "integrity": "sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk=", + "requires": { + "punycode": "^2.1.0" + } + }, + "ts-pnp": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/ts-pnp/-/ts-pnp-1.1.5.tgz", + "integrity": "sha512-ti7OGMOUOzo66wLF3liskw6YQIaSsBgc4GOAlWRnIEj8htCxJUxskanMUoJOD6MDCRAXo36goXJZch+nOS0VMA==" + }, + "tslib": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", + "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" + }, + "tsutils": { + "version": "3.17.1", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", + "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", + "requires": { + "tslib": "^1.8.1" + } + }, + "tty-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", + "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=" + }, + "tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" + }, + "type": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", + "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==" + }, + "type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "requires": { + "prelude-ls": "~1.1.2" + } + }, + "type-fest": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", + "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==" + }, + "type-is": { + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", + "requires": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" + }, + "ua-parser-js": { + "version": "0.7.21", + "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.21.tgz", + "integrity": "sha512-+O8/qh/Qj8CgC6eYBVBykMrNtp5Gebn4dlGD/kKXVkJNDwyrAwSIqwz8CDf+tsAIWVycKcku6gIXJ0qwx/ZXaQ==" + }, + "uglify-js": { + "version": "3.4.10", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.4.10.tgz", + "integrity": "sha512-Y2VsbPVs0FIshJztycsO2SfPk7/KAF/T72qzv9u5EpQ4kB2hQoHlhNQTsNyy6ul7lQtqJN/AoWeS23OzEiEFxw==", + "requires": { + "commander": "~2.19.0", + "source-map": "~0.6.1" + }, + "dependencies": { + "commander": { + "version": "2.19.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.19.0.tgz", + "integrity": "sha512-6tvAOO+D6OENvRAh524Dh9jcfKTYDQAqvqezbCW82xj5X0pSrcpxtvRKHLG0yBY6SD7PSDrJaj+0AiOcKVd1Xg==" + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "unicode-canonical-property-names-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", + "integrity": "sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==" + }, + "unicode-match-property-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz", + "integrity": "sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg==", + "requires": { + "unicode-canonical-property-names-ecmascript": "^1.0.4", + "unicode-property-aliases-ecmascript": "^1.0.4" + } + }, + "unicode-match-property-value-ecmascript": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.1.0.tgz", + "integrity": "sha512-hDTHvaBk3RmFzvSl0UVrUmC3PuW9wKVnpoUDYH0JDkSIovzw+J5viQmeYHxVSBptubnr7PbH2e0fnpDRQnQl5g==" + }, + "unicode-property-aliases-ecmascript": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.0.5.tgz", + "integrity": "sha512-L5RAqCfXqAwR3RriF8pM0lU0w4Ryf/GgzONwi6KnL1taJQa7x1TCxdJnILX59WIGOwR57IVxn7Nej0fz1Ny6fw==" + }, + "union-value": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", + "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", + "requires": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^2.0.1" + } + }, + "uniq": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", + "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=" + }, + "uniqs": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/uniqs/-/uniqs-2.0.0.tgz", + "integrity": "sha1-/+3ks2slKQaW5uFl1KWe25mOawI=" + }, + "unique-filename": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", + "integrity": "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==", + "requires": { + "unique-slug": "^2.0.0" + } + }, + "unique-slug": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz", + "integrity": "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==", + "requires": { + "imurmurhash": "^0.1.4" + } + }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==" + }, + "unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" + }, + "unquote": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unquote/-/unquote-1.1.1.tgz", + "integrity": "sha1-j97XMk7G6IoP+LkF58CYzcCG1UQ=" + }, + "unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", + "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "requires": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "requires": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "requires": { + "isarray": "1.0.0" + } + } + } + }, + "has-values": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=" + } + } + }, + "upath": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz", + "integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==" + }, + "upper-case": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-1.1.3.tgz", + "integrity": "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=" + }, + "uri-js": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", + "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", + "requires": { + "punycode": "^2.1.0" + } + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=" + }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "requires": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" + } + } + }, + "url-loader": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/url-loader/-/url-loader-2.3.0.tgz", + "integrity": "sha512-goSdg8VY+7nPZKUEChZSEtW5gjbS66USIGCeSJ1OVOJ7Yfuh/36YxCwMi5HVEJh6mqUYOoy3NJ0vlOMrWsSHog==", + "requires": { + "loader-utils": "^1.2.3", + "mime": "^2.4.4", + "schema-utils": "^2.5.0" + } + }, + "url-parse": { + "version": "1.4.7", + "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.4.7.tgz", + "integrity": "sha512-d3uaVyzDB9tQoSXFvuSUNFibTd9zxd2bkVrDRvF5TmvWWQwqE4lgYJ5m+x1DbecWkw+LK4RNl2CU1hHuOKPVlg==", + "requires": { + "querystringify": "^2.1.1", + "requires-port": "^1.0.0" + } + }, + "use": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", + "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==" + }, + "util": { + "version": "0.10.3", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", + "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", + "requires": { + "inherits": "2.0.1" + }, + "dependencies": { + "inherits": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=" + } + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" + }, + "util.promisify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz", + "integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==", + "requires": { + "define-properties": "^1.1.2", + "object.getownpropertydescriptors": "^2.0.3" + } + }, + "utila": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/utila/-/utila-0.4.0.tgz", + "integrity": "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw=" + }, + "utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", + "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" + }, + "uuid": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.3.tgz", + "integrity": "sha512-pW0No1RGHgzlpHJO1nsVrHKpOEIxkGg1xB+v0ZmdNH5OAeAwzAVrCnI2/6Mtx+Uys6iaylxa+D3g4j63IKKjSQ==" + }, + "v8-compile-cache": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", + "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==" + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" + }, + "vendors": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/vendors/-/vendors-1.0.3.tgz", + "integrity": "sha512-fOi47nsJP5Wqefa43kyWSg80qF+Q3XA6MUkgi7Hp1HQaKDQW4cQrK2D0P7mmbFtsV1N89am55Yru/nyEwRubcw==" + }, + "verror": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", + "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", + "requires": { + "assert-plus": "^1.0.0", + "core-util-is": "1.0.2", + "extsprintf": "^1.2.0" + } + }, + "vm-browserify": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-1.1.2.tgz", + "integrity": "sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ==" + }, + "w3c-hr-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.1.tgz", + "integrity": "sha1-gqwr/2PZUOqeMYmlimViX+3xkEU=", + "requires": { + "browser-process-hrtime": "^0.1.2" + } + }, + "w3c-xmlserializer": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-1.1.2.tgz", + "integrity": "sha512-p10l/ayESzrBMYWRID6xbuCKh2Fp77+sA0doRuGn4tTIMrrZVeqfpKjXHY+oDh3K4nLdPgNwMTVP6Vp4pvqbNg==", + "requires": { + "domexception": "^1.0.1", + "webidl-conversions": "^4.0.2", + "xml-name-validator": "^3.0.0" + } + }, + "wait-for-expect": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/wait-for-expect/-/wait-for-expect-3.0.1.tgz", + "integrity": "sha512-3Ha7lu+zshEG/CeHdcpmQsZnnZpPj/UsG3DuKO8FskjuDbkx3jE3845H+CuwZjA2YWYDfKMU2KhnCaXMLd3wVw==" + }, + "walker": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.7.tgz", + "integrity": "sha1-L3+bj9ENZ3JisYqITijRlhjgKPs=", + "requires": { + "makeerror": "1.0.x" + } + }, + "warning": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/warning/-/warning-3.0.0.tgz", + "integrity": "sha1-MuU3fLVy3kqwR1O9+IIcAe1gW3w=", + "requires": { + "loose-envify": "^1.0.0" + } + }, + "watchpack": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-1.6.0.tgz", + "integrity": "sha512-i6dHe3EyLjMmDlU1/bGQpEw25XSjkJULPuAVKCbNRefQVq48yXKUpwg538F7AZTf9kyr57zj++pQFltUa5H7yA==", + "requires": { + "chokidar": "^2.0.2", + "graceful-fs": "^4.1.2", + "neo-async": "^2.5.0" + } + }, + "wbuf": { + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz", + "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==", + "requires": { + "minimalistic-assert": "^1.0.0" + } + }, + "webidl-conversions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.2.tgz", + "integrity": "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg==" + }, + "webpack": { + "version": "4.41.2", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.41.2.tgz", + "integrity": "sha512-Zhw69edTGfbz9/8JJoyRQ/pq8FYUoY0diOXqW0T6yhgdhCv6wr0hra5DwwWexNRns2Z2+gsnrNcbe9hbGBgk/A==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-module-context": "1.8.5", + "@webassemblyjs/wasm-edit": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5", + "acorn": "^6.2.1", + "ajv": "^6.10.2", + "ajv-keywords": "^3.4.1", + "chrome-trace-event": "^1.0.2", + "enhanced-resolve": "^4.1.0", + "eslint-scope": "^4.0.3", + "json-parse-better-errors": "^1.0.2", + "loader-runner": "^2.4.0", + "loader-utils": "^1.2.3", + "memory-fs": "^0.4.1", + "micromatch": "^3.1.10", + "mkdirp": "^0.5.1", + "neo-async": "^2.6.1", + "node-libs-browser": "^2.2.1", + "schema-utils": "^1.0.0", + "tapable": "^1.1.3", + "terser-webpack-plugin": "^1.4.1", + "watchpack": "^1.6.0", + "webpack-sources": "^1.4.1" + }, + "dependencies": { + "acorn": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.0.tgz", + "integrity": "sha512-gac8OEcQ2Li1dxIEWGZzsp2BitJxwkwcOm0zHAJLcPJaVvm58FRnk6RkuLRpU1EujipU2ZFODv2P9DLMfnV8mw==" + }, + "cacache": { + "version": "12.0.3", + "resolved": "https://registry.npmjs.org/cacache/-/cacache-12.0.3.tgz", + "integrity": "sha512-kqdmfXEGFepesTuROHMs3MpFLWrPkSSpRqOw80RCflZXy/khxaArvFrQ7uJxSUduzAufc6G0g1VUCOZXxWavPw==", + "requires": { + "bluebird": "^3.5.5", + "chownr": "^1.1.1", + "figgy-pudding": "^3.5.1", + "glob": "^7.1.4", + "graceful-fs": "^4.1.15", + "infer-owner": "^1.0.3", + "lru-cache": "^5.1.1", + "mississippi": "^3.0.0", + "mkdirp": "^0.5.1", + "move-concurrently": "^1.0.1", + "promise-inflight": "^1.0.1", + "rimraf": "^2.6.3", + "ssri": "^6.0.1", + "unique-filename": "^1.1.1", + "y18n": "^4.0.0" + } + }, + "eslint-scope": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", + "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + }, + "ssri": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.1.tgz", + "integrity": "sha512-3Wge10hNcT1Kur4PDFwEieXSCMCJs/7WvSACcrMYrNp+b8kDL1/0wJch5Ni2WrtwEa2IO8OsVfeKIciKCDx/QA==", + "requires": { + "figgy-pudding": "^3.5.1" + } + }, + "terser-webpack-plugin": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.4.3.tgz", + "integrity": "sha512-QMxecFz/gHQwteWwSo5nTc6UaICqN1bMedC5sMtUc7y3Ha3Q8y6ZO0iCR8pq4RJC8Hjf0FEPEHZqcMB/+DFCrA==", + "requires": { + "cacache": "^12.0.2", + "find-cache-dir": "^2.1.0", + "is-wsl": "^1.1.0", + "schema-utils": "^1.0.0", + "serialize-javascript": "^2.1.2", + "source-map": "^0.6.1", + "terser": "^4.1.2", + "webpack-sources": "^1.4.0", + "worker-farm": "^1.7.0" + } + } + } + }, + "webpack-dev-middleware": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-3.7.2.tgz", + "integrity": "sha512-1xC42LxbYoqLNAhV6YzTYacicgMZQTqRd27Sim9wn5hJrX3I5nxYy1SxSd4+gjUFsz1dQFj+yEe6zEVmSkeJjw==", + "requires": { + "memory-fs": "^0.4.1", + "mime": "^2.4.4", + "mkdirp": "^0.5.1", + "range-parser": "^1.2.1", + "webpack-log": "^2.0.0" + } + }, + "webpack-dev-server": { + "version": "3.9.0", + "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-3.9.0.tgz", + "integrity": "sha512-E6uQ4kRrTX9URN9s/lIbqTAztwEPdvzVrcmHE8EQ9YnuT9J8Es5Wrd8n9BKg1a0oZ5EgEke/EQFgUsp18dSTBw==", + "requires": { + "ansi-html": "0.0.7", + "bonjour": "^3.5.0", + "chokidar": "^2.1.8", + "compression": "^1.7.4", + "connect-history-api-fallback": "^1.6.0", + "debug": "^4.1.1", + "del": "^4.1.1", + "express": "^4.17.1", + "html-entities": "^1.2.1", + "http-proxy-middleware": "0.19.1", + "import-local": "^2.0.0", + "internal-ip": "^4.3.0", + "ip": "^1.1.5", + "is-absolute-url": "^3.0.3", + "killable": "^1.0.1", + "loglevel": "^1.6.4", + "opn": "^5.5.0", + "p-retry": "^3.0.1", + "portfinder": "^1.0.25", + "schema-utils": "^1.0.0", + "selfsigned": "^1.10.7", + "semver": "^6.3.0", + "serve-index": "^1.9.1", + "sockjs": "0.3.19", + "sockjs-client": "1.4.0", + "spdy": "^4.0.1", + "strip-ansi": "^3.0.1", + "supports-color": "^6.1.0", + "url": "^0.11.0", + "webpack-dev-middleware": "^3.7.2", + "webpack-log": "^2.0.0", + "ws": "^6.2.1", + "yargs": "12.0.5" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + }, + "cliui": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", + "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", + "requires": { + "string-width": "^2.1.1", + "strip-ansi": "^4.0.0", + "wrap-ansi": "^2.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "get-caller-file": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", + "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==" + }, + "is-absolute-url": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-3.0.3.tgz", + "integrity": "sha512-opmNIX7uFnS96NtPmhWQgQx6/NYFgsUXYMllcfzwWKUMwfo8kku1TvE6hkNcH+Q1ts5cMVrsY7j0bxXQDciu9Q==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "require-main-filename": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", + "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=" + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "requires": { + "has-flag": "^3.0.0" + } + }, + "wrap-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", + "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", + "requires": { + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + } + } + }, + "ws": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.1.tgz", + "integrity": "sha512-GIyAXC2cB7LjvpgMt9EKS2ldqr0MTrORaleiOno6TweZ6r3TKtoFQWay/2PceJ3RuBasOHzXNn5Lrw1X0bEjqA==", + "requires": { + "async-limiter": "~1.0.0" + } + }, + "yargs": { + "version": "12.0.5", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.5.tgz", + "integrity": "sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw==", + "requires": { + "cliui": "^4.0.0", + "decamelize": "^1.2.0", + "find-up": "^3.0.0", + "get-caller-file": "^1.0.1", + "os-locale": "^3.0.0", + "require-directory": "^2.1.1", + "require-main-filename": "^1.0.1", + "set-blocking": "^2.0.0", + "string-width": "^2.0.0", + "which-module": "^2.0.0", + "y18n": "^3.2.1 || ^4.0.0", + "yargs-parser": "^11.1.1" + } + }, + "yargs-parser": { + "version": "11.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-11.1.1.tgz", + "integrity": "sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ==", + "requires": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + } + } + } + }, + "webpack-log": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/webpack-log/-/webpack-log-2.0.0.tgz", + "integrity": "sha512-cX8G2vR/85UYG59FgkoMamwHUIkSSlV3bBMRsbxVXVUk2j6NleCKjQ/WE9eYg9WY4w25O9w8wKP4rzNZFmUcUg==", + "requires": { + "ansi-colors": "^3.0.0", + "uuid": "^3.3.2" + } + }, + "webpack-manifest-plugin": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/webpack-manifest-plugin/-/webpack-manifest-plugin-2.2.0.tgz", + "integrity": "sha512-9S6YyKKKh/Oz/eryM1RyLVDVmy3NSPV0JXMRhZ18fJsq+AwGxUY34X54VNwkzYcEmEkDwNxuEOboCZEebJXBAQ==", + "requires": { + "fs-extra": "^7.0.0", + "lodash": ">=3.5 <5", + "object.entries": "^1.1.0", + "tapable": "^1.0.0" + }, + "dependencies": { + "fs-extra": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", + "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + } + } + }, + "webpack-sources": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.4.3.tgz", + "integrity": "sha512-lgTS3Xhv1lCOKo7SA5TjKXMjpSM4sBjNV5+q2bqesbSPs5FjGmU6jjtBSkX9b4qW87vDIsCIlUPOEhbZrMdjeQ==", + "requires": { + "source-list-map": "^2.0.0", + "source-map": "~0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + } + } + }, + "websocket-driver": { + "version": "0.7.3", + "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.3.tgz", + "integrity": "sha512-bpxWlvbbB459Mlipc5GBzzZwhoZgGEZLuqPaR0INBGnPAY1vdBX6hPnoFXiw+3yWxDuHyQjO2oXTMyS8A5haFg==", + "requires": { + "http-parser-js": ">=0.4.0 <0.4.11", + "safe-buffer": ">=5.1.0", + "websocket-extensions": ">=0.1.1" + } + }, + "websocket-extensions": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.3.tgz", + "integrity": "sha512-nqHUnMXmBzT0w570r2JpJxfiSD1IzoI+HGVdd3aZ0yNi3ngvQ4jv1dtHt5VGxfI2yj5yqImPhOK4vmIh2xMbGg==" + }, + "whatwg-encoding": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", + "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", + "requires": { + "iconv-lite": "0.4.24" + } + }, + "whatwg-fetch": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-3.0.0.tgz", + "integrity": "sha512-9GSJUgz1D4MfyKU7KRqwOjXCXTqWdFNvEr7eUBYchQiVc744mqK/MzXPNR2WsPkmkOa4ywfg8C2n8h+13Bey1Q==" + }, + "whatwg-mimetype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", + "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==" + }, + "whatwg-url": { + "version": "6.5.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-6.5.0.tgz", + "integrity": "sha512-rhRZRqx/TLJQWUpQ6bmrt2UV4f0HCQ463yQuONJqC6fO2VoEb1pTYddbe59SkYq87aoM5A3bdhMZiUiVws+fzQ==", + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "requires": { + "isexe": "^2.0.0" + } + }, + "which-module": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", + "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" + }, + "word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==" + }, + "workbox-background-sync": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-background-sync/-/workbox-background-sync-4.3.1.tgz", + "integrity": "sha512-1uFkvU8JXi7L7fCHVBEEnc3asPpiAL33kO495UMcD5+arew9IbKW2rV5lpzhoWcm/qhGB89YfO4PmB/0hQwPRg==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-broadcast-update": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-broadcast-update/-/workbox-broadcast-update-4.3.1.tgz", + "integrity": "sha512-MTSfgzIljpKLTBPROo4IpKjESD86pPFlZwlvVG32Kb70hW+aob4Jxpblud8EhNb1/L5m43DUM4q7C+W6eQMMbA==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-build": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-build/-/workbox-build-4.3.1.tgz", + "integrity": "sha512-UHdwrN3FrDvicM3AqJS/J07X0KXj67R8Cg0waq1MKEOqzo89ap6zh6LmaLnRAjpB+bDIz+7OlPye9iii9KBnxw==", + "requires": { + "@babel/runtime": "^7.3.4", + "@hapi/joi": "^15.0.0", + "common-tags": "^1.8.0", + "fs-extra": "^4.0.2", + "glob": "^7.1.3", + "lodash.template": "^4.4.0", + "pretty-bytes": "^5.1.0", + "stringify-object": "^3.3.0", + "strip-comments": "^1.0.2", + "workbox-background-sync": "^4.3.1", + "workbox-broadcast-update": "^4.3.1", + "workbox-cacheable-response": "^4.3.1", + "workbox-core": "^4.3.1", + "workbox-expiration": "^4.3.1", + "workbox-google-analytics": "^4.3.1", + "workbox-navigation-preload": "^4.3.1", + "workbox-precaching": "^4.3.1", + "workbox-range-requests": "^4.3.1", + "workbox-routing": "^4.3.1", + "workbox-strategies": "^4.3.1", + "workbox-streams": "^4.3.1", + "workbox-sw": "^4.3.1", + "workbox-window": "^4.3.1" + }, + "dependencies": { + "fs-extra": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-4.0.3.tgz", + "integrity": "sha512-q6rbdDd1o2mAnQreO7YADIxf/Whx4AHBiRf6d+/cVT8h44ss+lHgxf1FemcqDnQt9X3ct4McHr+JMGlYSsK7Cg==", + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + } + } + }, + "workbox-cacheable-response": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-cacheable-response/-/workbox-cacheable-response-4.3.1.tgz", + "integrity": "sha512-Rp5qlzm6z8IOvnQNkCdO9qrDgDpoPNguovs0H8C+wswLuPgSzSp9p2afb5maUt9R1uTIwOXrVQMmPfPypv+npw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-core": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-core/-/workbox-core-4.3.1.tgz", + "integrity": "sha512-I3C9jlLmMKPxAC1t0ExCq+QoAMd0vAAHULEgRZ7kieCdUd919n53WC0AfvokHNwqRhGn+tIIj7vcb5duCjs2Kg==" + }, + "workbox-expiration": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-expiration/-/workbox-expiration-4.3.1.tgz", + "integrity": "sha512-vsJLhgQsQouv9m0rpbXubT5jw0jMQdjpkum0uT+d9tTwhXcEZks7qLfQ9dGSaufTD2eimxbUOJfWLbNQpIDMPw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-google-analytics": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-google-analytics/-/workbox-google-analytics-4.3.1.tgz", + "integrity": "sha512-xzCjAoKuOb55CBSwQrbyWBKqp35yg1vw9ohIlU2wTy06ZrYfJ8rKochb1MSGlnoBfXGWss3UPzxR5QL5guIFdg==", + "requires": { + "workbox-background-sync": "^4.3.1", + "workbox-core": "^4.3.1", + "workbox-routing": "^4.3.1", + "workbox-strategies": "^4.3.1" + } + }, + "workbox-navigation-preload": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-navigation-preload/-/workbox-navigation-preload-4.3.1.tgz", + "integrity": "sha512-K076n3oFHYp16/C+F8CwrRqD25GitA6Rkd6+qAmLmMv1QHPI2jfDwYqrytOfKfYq42bYtW8Pr21ejZX7GvALOw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-precaching": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-precaching/-/workbox-precaching-4.3.1.tgz", + "integrity": "sha512-piSg/2csPoIi/vPpp48t1q5JLYjMkmg5gsXBQkh/QYapCdVwwmKlU9mHdmy52KsDGIjVaqEUMFvEzn2LRaigqQ==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-range-requests": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-range-requests/-/workbox-range-requests-4.3.1.tgz", + "integrity": "sha512-S+HhL9+iTFypJZ/yQSl/x2Bf5pWnbXdd3j57xnb0V60FW1LVn9LRZkPtneODklzYuFZv7qK6riZ5BNyc0R0jZA==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-routing": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-routing/-/workbox-routing-4.3.1.tgz", + "integrity": "sha512-FkbtrODA4Imsi0p7TW9u9MXuQ5P4pVs1sWHK4dJMMChVROsbEltuE79fBoIk/BCztvOJ7yUpErMKa4z3uQLX+g==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-strategies": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-strategies/-/workbox-strategies-4.3.1.tgz", + "integrity": "sha512-F/+E57BmVG8dX6dCCopBlkDvvhg/zj6VDs0PigYwSN23L8hseSRwljrceU2WzTvk/+BSYICsWmRq5qHS2UYzhw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-streams": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-streams/-/workbox-streams-4.3.1.tgz", + "integrity": "sha512-4Kisis1f/y0ihf4l3u/+ndMkJkIT4/6UOacU3A4BwZSAC9pQ9vSvJpIi/WFGQRH/uPXvuVjF5c2RfIPQFSS2uA==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-sw": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-sw/-/workbox-sw-4.3.1.tgz", + "integrity": "sha512-0jXdusCL2uC5gM3yYFT6QMBzKfBr2XTk0g5TPAV4y8IZDyVNDyj1a8uSXy3/XrvkVTmQvLN4O5k3JawGReXr9w==" + }, + "workbox-webpack-plugin": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-webpack-plugin/-/workbox-webpack-plugin-4.3.1.tgz", + "integrity": "sha512-gJ9jd8Mb8wHLbRz9ZvGN57IAmknOipD3W4XNE/Lk/4lqs5Htw4WOQgakQy/o/4CoXQlMCYldaqUg+EJ35l9MEQ==", + "requires": { + "@babel/runtime": "^7.0.0", + "json-stable-stringify": "^1.0.1", + "workbox-build": "^4.3.1" + } + }, + "workbox-window": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-window/-/workbox-window-4.3.1.tgz", + "integrity": "sha512-C5gWKh6I58w3GeSc0wp2Ne+rqVw8qwcmZnQGpjiek8A2wpbxSJb1FdCoQVO+jDJs35bFgo/WETgl1fqgsxN0Hg==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "worker-farm": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/worker-farm/-/worker-farm-1.7.0.tgz", + "integrity": "sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw==", + "requires": { + "errno": "~0.1.7" + } + }, + "worker-rpc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/worker-rpc/-/worker-rpc-0.1.1.tgz", + "integrity": "sha512-P1WjMrUB3qgJNI9jfmpZ/htmBEjFh//6l/5y8SD9hg1Ef5zTTVVoRjTrTEzPrNBQvmhMxkoTsjOXN10GWU7aCg==", + "requires": { + "microevent.ts": "~0.1.1" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", + "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" + }, + "write": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", + "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", + "requires": { + "mkdirp": "^0.5.1" + } + }, + "write-file-atomic": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.1.tgz", + "integrity": "sha512-TGHFeZEZMnv+gBFRfjAcxL5bPHrsGKtnb4qsFAws7/vlh+QfwAaySIw4AXP9ZskTTh5GWu3FLuJhsWVdiJPGvg==", + "requires": { + "graceful-fs": "^4.1.11", + "imurmurhash": "^0.1.4", + "signal-exit": "^3.0.2" + } + }, + "ws": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/ws/-/ws-5.2.2.tgz", + "integrity": "sha512-jaHFD6PFv6UgoIVda6qZllptQsMlDEJkTQcybzzXDYM1XO9Y8em691FGMPmM46WGyLU4z9KMgQN+qrux/nhlHA==", + "requires": { + "async-limiter": "~1.0.0" + } + }, + "xml-name-validator": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", + "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==" + }, + "xmlchars": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", + "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==" + }, + "xtend": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", + "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" + }, + "y18n": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", + "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==" + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" + }, + "yaml": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.7.2.tgz", + "integrity": "sha512-qXROVp90sb83XtAoqE8bP9RwAkTTZbugRUTm5YeFCBfNRPEp2YzTeqWiz7m5OORHzEvrA/qcGS8hp/E+MMROYw==", + "requires": { + "@babel/runtime": "^7.6.3" + } + }, + "yargs": { + "version": "13.3.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.0.tgz", + "integrity": "sha512-2eehun/8ALW8TLoIl7MVaRUrg+yCnenu8B4kBlRxj3GJGDKU1Og7sMXPNm1BYyM1DOJmTZ4YeN/Nwxv+8XJsUA==", + "requires": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.1" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "yargs-parser": { + "version": "13.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.1.tgz", + "integrity": "sha512-oVAVsHz6uFrg3XQheFII8ESO2ssAf9luWuAd6Wexsu4F3OtIW0o8IribPXYrD4WC24LWtPrJlGy87y5udK+dxQ==", + "requires": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + } + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..b9d1dac --- /dev/null +++ b/package.json @@ -0,0 +1,37 @@ +{ + "name": "my-app", + "version": "0.1.0", + "private": true, + "dependencies": { + "@material-ui/core": "^4.8.3", + "@material-ui/icons": "^4.5.1", + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.4.0", + "@testing-library/user-event": "^7.2.1", + "material-ui": "^0.20.2", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-scripts": "3.3.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/public/favicon.ico b/public/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..a11777cc471a4344702741ab1c8a588998b1311a GIT binary patch literal 3870 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 baj7?x%VD!5Cxk2YbYLNVeiXvvpMCWYo=by@ literal 0 HcmV?d00001 diff --git a/public/index.html b/public/index.html new file mode 100644 index 0000000..aa069f2 --- /dev/null +++ b/public/index.html @@ -0,0 +1,43 @@ +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8" /> + <link rel="icon" href="%PUBLIC_URL%/favicon.ico" /> + <meta name="viewport" content="width=device-width, initial-scale=1" /> + <meta name="theme-color" content="#000000" /> + <meta + name="description" + content="Web site created using create-react-app" + /> + <link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" /> + <!-- + manifest.json provides metadata used when your web app is installed on a + user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/ + --> + <link rel="manifest" href="%PUBLIC_URL%/manifest.json" /> + <!-- + Notice the use of %PUBLIC_URL% in the tags above. + It will be replaced with the URL of the `public` folder during the build. + Only files inside the `public` folder can be referenced from the HTML. + + Unlike "/favicon.ico" or "favicon.ico", "%PUBLIC_URL%/favicon.ico" will + 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`. + --> + <title>React App</title> + </head> + <body> + <noscript>You need to enable JavaScript to run this app.</noscript> + <div id="root"></div> + <!-- + This HTML file is a template. + If you open it directly in the browser, you will see an empty page. + + You can add webfonts, meta tags, or analytics to this file. + The build step will place the bundled scripts into the <body> tag. + + To begin the development, run `npm start` or `yarn start`. + To create a production bundle, use `npm run build` or `yarn build`. + --> + </body> +</html> diff --git a/public/logo192.png b/public/logo192.png new file mode 100644 index 0000000000000000000000000000000000000000..fc44b0a3796c0e0a64c3d858ca038bd4570465d9 GIT binary patch literal 5347 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 X@eDJUQo;Ye2mwlRs<JiGX2Jghdw)}T literal 0 HcmV?d00001 diff --git a/public/logo512.png b/public/logo512.png new file mode 100644 index 0000000000000000000000000000000000000000..a4e47a6545bc15971f8f63fba70e4013df88a664 GIT binary patch literal 9664 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 b{|{}U^kRn2wo}j7|0ATu<;8xA7zX}7|B6mN literal 0 HcmV?d00001 diff --git a/public/manifest.json b/public/manifest.json new file mode 100644 index 0000000..080d6c7 --- /dev/null +++ b/public/manifest.json @@ -0,0 +1,25 @@ +{ + "short_name": "React App", + "name": "Create React App Sample", + "icons": [ + { + "src": "favicon.ico", + "sizes": "64x64 32x32 24x24 16x16", + "type": "image/x-icon" + }, + { + "src": "logo192.png", + "type": "image/png", + "sizes": "192x192" + }, + { + "src": "logo512.png", + "type": "image/png", + "sizes": "512x512" + } + ], + "start_url": ".", + "display": "standalone", + "theme_color": "#000000", + "background_color": "#ffffff" +} diff --git a/public/robots.txt b/public/robots.txt new file mode 100644 index 0000000..01b0f9a --- /dev/null +++ b/public/robots.txt @@ -0,0 +1,2 @@ +# https://www.robotstxt.org/robotstxt.html +User-agent: * diff --git a/src/App.css b/src/App.css new file mode 100644 index 0000000..74b5e05 --- /dev/null +++ b/src/App.css @@ -0,0 +1,38 @@ +.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); + } +} diff --git a/src/App.js b/src/App.js new file mode 100644 index 0000000..db00a15 --- /dev/null +++ b/src/App.js @@ -0,0 +1,104 @@ +import React, { useState } from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import AddIcon from '@material-ui/icons/Add'; +import IconButton from '@material-ui/core/IconButton'; +import ReorderIcon from '@material-ui/icons/Reorder'; + + +import FormFieldText from './components/FormFieldText' +import FormFieldSelect from './components/FormFieldSelect' + + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + height: theme.spacing(15), + position: 'fixed', + top: theme.spacing(10), + left: '90%', + padding: theme.spacing(1) + }, +})); + +function App() { + const classes = useStyles(); + + const [form, setForm] = useState([]); + + function addToFormQuestion() { + setForm([...form, {type: "question", question: ""}]); + console.log(form); + } + + function addToFormSelect() { + setForm([...form, {type: "select", question: "", options: []}]); + console.log(form); + } + + function deleteFromForm(index) { + console.log(index); + form.splice(index, 1) + console.log(form); + setForm([...form]); + } + + function setTextField(value, index) { + form[index].question = value; + setForm([...form]); + console.log(form); + } + + function setSelectField(value, index) { + console.log(form); + } + + + + return ( + <div> + <Grid + container + direction="column" + alignItems="center" + justify="center" + > + + { + form.map((x, index) => { + if(x.type === "question") + return <FormFieldText question={x.question} idq={index} deleteFromForm={deleteFromForm} setTextField={setTextField}/> + else if(x.type === "select") + return <FormFieldSelect question={x.question} idq={index} deleteFromForm={deleteFromForm} setTextField={setSelectField}/> + }) + } + + + </Grid> + + <Paper className={classes.menu}> + <Grid + container + spacing={0} + direction="column" + alignItems="center" + justify="center" + > + <Grid item xs={0}> + <IconButton aria-label="add question" onClick={addToFormQuestion}> + <AddIcon /> + </IconButton> + <IconButton aria-label="add select" onClick={addToFormSelect}> + <ReorderIcon /> + </IconButton> + </Grid> + </Grid> + </Paper> + + </div> + ); +} + +export default App; diff --git a/src/App.test.js b/src/App.test.js new file mode 100644 index 0000000..4db7ebc --- /dev/null +++ b/src/App.test.js @@ -0,0 +1,9 @@ +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(); +}); diff --git a/src/components/FormFieldSelect.js b/src/components/FormFieldSelect.js new file mode 100644 index 0000000..ec68243 --- /dev/null +++ b/src/components/FormFieldSelect.js @@ -0,0 +1,67 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + +function FormFieldSelect(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" onChange={e => props.setTextField(e.target.value, props.idq)}/> + </Grid> + <Grid item xs={11} className={classes.questionsGrid}> + <Select + labelId="demo-simple-select-label" + id="demo-simple-select" + // value={age} + // onChange={handleChange} + > + <MenuItem value={10}>Ten</MenuItem> + <MenuItem value={20}>Twenty</MenuItem> + <MenuItem value={30}>Thirty</MenuItem> + </Select> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> + <DeleteOutlinedIcon /> + </IconButton> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldSelect; + +{/* <InputLabel id="demo-simple-select-label">Age</InputLabel> +<Select + labelId="demo-simple-select-label" + id="demo-simple-select" + value={age} + onChange={handleChange} +> + <MenuItem value={10}>Ten</MenuItem> + <MenuItem value={20}>Twenty</MenuItem> + <MenuItem value={30}>Thirty</MenuItem> +</Select> */} \ No newline at end of file diff --git a/src/components/FormFieldText.js b/src/components/FormFieldText.js new file mode 100644 index 0000000..b9dd034 --- /dev/null +++ b/src/components/FormFieldText.js @@ -0,0 +1,49 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" onChange={e => props.setTextField(e.target.value, props.idq)}/> + </Grid> + <Grid item xs={11} className={classes.questionsGrid}> + <TextField + disabled + id="outlined-disabled" + label="" + defaultValue="Resposta curta" + /> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> + <DeleteOutlinedIcon /> + </IconButton> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldText; \ No newline at end of file diff --git a/src/index.css b/src/index.css new file mode 100644 index 0000000..ec2585e --- /dev/null +++ b/src/index.css @@ -0,0 +1,13 @@ +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; +} diff --git a/src/index.js b/src/index.js new file mode 100644 index 0000000..87d1be5 --- /dev/null +++ b/src/index.js @@ -0,0 +1,12 @@ +import React from 'react'; +import ReactDOM from 'react-dom'; +import './index.css'; +import App from './App'; +import * as serviceWorker from './serviceWorker'; + +ReactDOM.render(<App />, document.getElementById('root')); + +// If you want your app to work offline and load faster, you can change +// unregister() to register() below. Note this comes with some pitfalls. +// Learn more about service workers: https://bit.ly/CRA-PWA +serviceWorker.unregister(); diff --git a/src/logo.svg b/src/logo.svg new file mode 100644 index 0000000..6b60c10 --- /dev/null +++ b/src/logo.svg @@ -0,0 +1,7 @@ +<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> diff --git a/src/serviceWorker.js b/src/serviceWorker.js new file mode 100644 index 0000000..8703ddb --- /dev/null +++ b/src/serviceWorker.js @@ -0,0 +1,137 @@ +// This optional code is used to register a service worker. +// register() is not called by default. + +// This lets the app load faster on subsequent visits in production, and gives +// it offline capabilities. However, it also means that developers (and users) +// will only see deployed updates on subsequent visits to a page, after all the +// existing tabs open on the page have been closed, since previously cached +// resources are updated in the background. + +// To learn more about the benefits of this model and instructions on how to +// opt-in, read https://bit.ly/CRA-PWA + +const isLocalhost = Boolean( + window.location.hostname === 'localhost' || + // [::1] is the IPv6 localhost address. + window.location.hostname === '[::1]' || + // 127.0.0.0/8 are considered localhost for IPv4. + window.location.hostname.match( + /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/ + ) +); + +export function register(config) { + if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) { + // The URL constructor is available in all browsers that support SW. + const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href); + if (publicUrl.origin !== window.location.origin) { + // Our service worker won't work if PUBLIC_URL is on a different origin + // from what our page is served on. This might happen if a CDN is used to + // serve assets; see https://github.com/facebook/create-react-app/issues/2374 + return; + } + + window.addEventListener('load', () => { + const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`; + + if (isLocalhost) { + // This is running on localhost. Let's check if a service worker still exists or not. + checkValidServiceWorker(swUrl, config); + + // Add some additional logging to localhost, pointing developers to the + // service worker/PWA documentation. + navigator.serviceWorker.ready.then(() => { + console.log( + 'This web app is being served cache-first by a service ' + + 'worker. To learn more, visit https://bit.ly/CRA-PWA' + ); + }); + } else { + // Is not localhost. Just register service worker + registerValidSW(swUrl, config); + } + }); + } +} + +function registerValidSW(swUrl, config) { + navigator.serviceWorker + .register(swUrl) + .then(registration => { + registration.onupdatefound = () => { + const installingWorker = registration.installing; + if (installingWorker == null) { + return; + } + installingWorker.onstatechange = () => { + if (installingWorker.state === 'installed') { + if (navigator.serviceWorker.controller) { + // At this point, the updated precached content has been fetched, + // but the previous service worker will still serve the older + // content until all client tabs are closed. + console.log( + 'New content is available and will be used when all ' + + 'tabs for this page are closed. See https://bit.ly/CRA-PWA.' + ); + + // Execute callback + if (config && config.onUpdate) { + config.onUpdate(registration); + } + } else { + // At this point, everything has been precached. + // It's the perfect time to display a + // "Content is cached for offline use." message. + console.log('Content is cached for offline use.'); + + // Execute callback + if (config && config.onSuccess) { + config.onSuccess(registration); + } + } + } + }; + }; + }) + .catch(error => { + console.error('Error during service worker registration:', error); + }); +} + +function checkValidServiceWorker(swUrl, config) { + // Check if the service worker can be found. If it can't reload the page. + fetch(swUrl, { + headers: { 'Service-Worker': 'script' } + }) + .then(response => { + // Ensure service worker exists, and that we really are getting a JS file. + const contentType = response.headers.get('content-type'); + if ( + response.status === 404 || + (contentType != null && contentType.indexOf('javascript') === -1) + ) { + // No service worker found. Probably a different app. Reload the page. + navigator.serviceWorker.ready.then(registration => { + registration.unregister().then(() => { + window.location.reload(); + }); + }); + } else { + // Service worker found. Proceed as normal. + registerValidSW(swUrl, config); + } + }) + .catch(() => { + console.log( + 'No internet connection found. App is running in offline mode.' + ); + }); +} + +export function unregister() { + if ('serviceWorker' in navigator) { + navigator.serviceWorker.ready.then(registration => { + registration.unregister(); + }); + } +} diff --git a/src/setupTests.js b/src/setupTests.js new file mode 100644 index 0000000..74b1a27 --- /dev/null +++ b/src/setupTests.js @@ -0,0 +1,5 @@ +// 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'; -- GitLab From 37e71300bfc7567efbb0ce073998733857848e46 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:08:27 -0300 Subject: [PATCH 02/72] add FieldFooter component --- src/components/FieldFooterOptions.js | 39 ++++++++++++++++++++++++++++ src/components/FormFieldText.js | 19 +++++++++----- 2 files changed, 52 insertions(+), 6 deletions(-) create mode 100644 src/components/FieldFooterOptions.js diff --git a/src/components/FieldFooterOptions.js b/src/components/FieldFooterOptions.js new file mode 100644 index 0000000..0ef5eca --- /dev/null +++ b/src/components/FieldFooterOptions.js @@ -0,0 +1,39 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; + +function FieldFooterOptions(props) { + + return ( + <> + <FormControlLabel + control={ + <Switch + onChange={e => props.setRequiredField(props.idq) } + value="required" + color="primary" + /> + } + label="Obrigatória" + /> + <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> + <DeleteOutlinedIcon /> + </IconButton> + </> + ); + + +} + + +export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/FormFieldText.js b/src/components/FormFieldText.js index b9dd034..31cca40 100644 --- a/src/components/FormFieldText.js +++ b/src/components/FormFieldText.js @@ -6,6 +6,8 @@ import TextField from '@material-ui/core/TextField'; import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; import IconButton from '@material-ui/core/IconButton'; +import FieldFooterOptions from './FieldFooterOptions'; + const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), @@ -25,9 +27,10 @@ function FormFieldText(props) { <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" onChange={e => props.setTextField(e.target.value, props.idq)}/> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setTextField(e.target.value, props.idq)}/> </Grid> - <Grid item xs={11} className={classes.questionsGrid}> + <Grid item xs={9} className={classes.questionsGrid}> <TextField disabled id="outlined-disabled" @@ -35,10 +38,14 @@ function FormFieldText(props) { defaultValue="Resposta curta" /> </Grid> - <Grid item xs={1}> - <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> - <DeleteOutlinedIcon /> - </IconButton> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField}/> </Grid> </Grid> </Paper> -- GitLab From 9cc590ded26e5ee81e30de45a9d245477a79f4cc Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:09:33 -0300 Subject: [PATCH 03/72] create select field component --- src/components/FormFieldSelect.js | 78 ++++++++++++++++++++----------- 1 file changed, 50 insertions(+), 28 deletions(-) diff --git a/src/components/FormFieldSelect.js b/src/components/FormFieldSelect.js index ec68243..7125a80 100644 --- a/src/components/FormFieldSelect.js +++ b/src/components/FormFieldSelect.js @@ -7,12 +7,19 @@ import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; import IconButton from '@material-ui/core/IconButton'; import Select from '@material-ui/core/Select'; import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; + +import FieldFooterOptions from './FieldFooterOptions'; + const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - height: theme.spacing(16), + minheight: theme.spacing(16), margin: theme.spacing(2) }, questionsGrid: { @@ -20,6 +27,8 @@ const useStyles = makeStyles(theme => ({ }, })); + + function FormFieldSelect(props) { const classes = useStyles(); @@ -27,41 +36,54 @@ function FormFieldSelect(props) { <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" onChange={e => props.setTextField(e.target.value, props.idq)}/> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setTextField(e.target.value, props.idq)}/> </Grid> - <Grid item xs={11} className={classes.questionsGrid}> - <Select - labelId="demo-simple-select-label" - id="demo-simple-select" - // value={age} - // onChange={handleChange} + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} > - <MenuItem value={10}>Ten</MenuItem> - <MenuItem value={20}>Twenty</MenuItem> - <MenuItem value={30}>Thirty</MenuItem> - </Select> + { + props.options.map((x, index) => { + return <Grid container> + <Grid item xs={11}> + <TextField label={"opção "+index} value={x} fullWidth + onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="remove option" + onClick={() => { props.removeSelectOption(props.idq, index) } }> + <CloseIcon /> + </IconButton> + </Grid> + </Grid> + }) + } </Grid> - <Grid item xs={1}> - <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> - <DeleteOutlinedIcon /> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={4} + > + <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> + <AddCircleIcon /> </IconButton> </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField}/> + </Grid> </Grid> </Paper> ); } -export default FormFieldSelect; - -{/* <InputLabel id="demo-simple-select-label">Age</InputLabel> -<Select - labelId="demo-simple-select-label" - id="demo-simple-select" - value={age} - onChange={handleChange} -> - <MenuItem value={10}>Ten</MenuItem> - <MenuItem value={20}>Twenty</MenuItem> - <MenuItem value={30}>Thirty</MenuItem> -</Select> */} \ No newline at end of file +export default FormFieldSelect; \ No newline at end of file -- GitLab From 45b18fa561eaf388445f2e546048c1c99fcbc228 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:10:09 -0300 Subject: [PATCH 04/72] ignore node_modules --- .gitignore | 1 + 1 file changed, 1 insertion(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..c2658d7 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +node_modules/ -- GitLab From 166e54d2d61939aaa6c811250e4c7de5f0651ff5 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:11:13 -0300 Subject: [PATCH 05/72] add select field option --- src/App.js | 47 +++++++++++++++++++++++++++++++++++++++-------- 1 file changed, 39 insertions(+), 8 deletions(-) diff --git a/src/App.js b/src/App.js index db00a15..0430743 100644 --- a/src/App.js +++ b/src/App.js @@ -6,6 +6,7 @@ import TextField from '@material-ui/core/TextField'; import AddIcon from '@material-ui/icons/Add'; import IconButton from '@material-ui/core/IconButton'; import ReorderIcon from '@material-ui/icons/Reorder'; +import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; import FormFieldText from './components/FormFieldText' @@ -15,7 +16,7 @@ import FormFieldSelect from './components/FormFieldSelect' const useStyles = makeStyles(theme => ({ menu: { width: theme.spacing(6), - height: theme.spacing(15), + minheight: theme.spacing(15), position: 'fixed', top: theme.spacing(10), left: '90%', @@ -29,12 +30,22 @@ function App() { const [form, setForm] = useState([]); function addToFormQuestion() { - setForm([...form, {type: "question", question: ""}]); + setForm([...form, {type: "question", required: false, question: ""}]); console.log(form); } function addToFormSelect() { - setForm([...form, {type: "select", question: "", options: []}]); + setForm([...form, {type: "select", question: "", required: false, options: [""]}]); + console.log(form); + } + + function addToFormRadio() { + + } + + function addSelectOption(index) { + form[index].options.push(""); + setForm([...form]); console.log(form); } @@ -45,18 +56,30 @@ function App() { setForm([...form]); } + function removeSelectOption(index, idopt) { + form[index].options.splice(idopt, 1); + setForm([...form]); + console.log(form); + } + function setTextField(value, index) { form[index].question = value; setForm([...form]); console.log(form); } - - function setSelectField(value, index) { + + function setSelectOption(value, index, idopt) { + form[index].options[idopt] = value; + setForm([...form]); console.log(form); } + function setRequiredField(index) { + form[index].required = !form[index].required; + setForm([...form]); + console.log(form); + } - return ( <div> <Grid @@ -69,9 +92,14 @@ function App() { { form.map((x, index) => { if(x.type === "question") - return <FormFieldText question={x.question} idq={index} deleteFromForm={deleteFromForm} setTextField={setTextField}/> + return <FormFieldText question={x.question} idq={index} + deleteFromForm={deleteFromForm} setTextField={setTextField} + setRequiredField={setRequiredField}/> else if(x.type === "select") - return <FormFieldSelect question={x.question} idq={index} deleteFromForm={deleteFromForm} setTextField={setSelectField}/> + return <FormFieldSelect question={x.question} options={x.options} idq={index} + deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} + setTextField={setTextField} setRequiredField={setRequiredField} /> }) } @@ -93,6 +121,9 @@ function App() { <IconButton aria-label="add select" onClick={addToFormSelect}> <ReorderIcon /> </IconButton> + <IconButton aria-label="add radio" onClick={addToFormRadio}> + <RadioButtonCheckedIcon /> + </IconButton> </Grid> </Grid> </Paper> -- GitLab From 48552d4bd00651e83d443a85002ee6ab0d5de244 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:39:17 -0300 Subject: [PATCH 06/72] create radio field component --- src/components/FormFieldRadio.js | 97 ++++++++++++++++++++++++++++++++ 1 file changed, 97 insertions(+) create mode 100644 src/components/FormFieldRadio.js diff --git a/src/components/FormFieldRadio.js b/src/components/FormFieldRadio.js new file mode 100644 index 0000000..70d74d4 --- /dev/null +++ b/src/components/FormFieldRadio.js @@ -0,0 +1,97 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import RadioButtonUncheckedIcon from '@material-ui/icons/RadioButtonUnchecked'; + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldRadio(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setTextField(e.target.value, props.idq)}/> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + { + props.options.map((x, index) => { + return <Grid container> + <Grid item container + justify="center" + alignItems="center" + xs={1} + > + <RadioButtonUncheckedIcon/> + </Grid> + <Grid item xs={10}> + <TextField label={"opção "+index} value={x} fullWidth + onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="remove option" + onClick={() => { props.removeSelectOption(props.idq, index) } }> + <CloseIcon /> + </IconButton> + </Grid> + </Grid> + }) + } + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={4} + > + <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> + <AddCircleIcon /> + </IconButton> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField}/> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldRadio; \ No newline at end of file -- GitLab From fd893283fcc0453aaa820c1412168315fa8e0a94 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:40:32 -0300 Subject: [PATCH 07/72] add radio field option --- src/App.js | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/App.js b/src/App.js index 0430743..54f41e4 100644 --- a/src/App.js +++ b/src/App.js @@ -9,9 +9,9 @@ import ReorderIcon from '@material-ui/icons/Reorder'; import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; -import FormFieldText from './components/FormFieldText' -import FormFieldSelect from './components/FormFieldSelect' - +import FormFieldText from './components/FormFieldText'; +import FormFieldSelect from './components/FormFieldSelect'; +import FormFieldRadio from './components/FormFieldRadio'; const useStyles = makeStyles(theme => ({ menu: { @@ -40,7 +40,8 @@ function App() { } function addToFormRadio() { - + setForm([...form, {type: "radio", question: "", required: false, options: [""]}]); + console.log(form); } function addSelectOption(index) { @@ -100,7 +101,12 @@ function App() { deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} setTextField={setTextField} setRequiredField={setRequiredField} /> - }) + else if(x.type === "radio") + return <FormFieldRadio question={x.question} options={x.options} idq={index} + deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} + setTextField={setTextField} setRequiredField={setRequiredField} /> +}) } -- GitLab From 8f295ea6b94d89bc099d62c2b41210098c7fd444 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:49:23 -0300 Subject: [PATCH 08/72] create component field checkbox --- src/components/FormFieldCheckbox.js | 98 +++++++++++++++++++++++++++++ 1 file changed, 98 insertions(+) create mode 100644 src/components/FormFieldCheckbox.js diff --git a/src/components/FormFieldCheckbox.js b/src/components/FormFieldCheckbox.js new file mode 100644 index 0000000..cb49d70 --- /dev/null +++ b/src/components/FormFieldCheckbox.js @@ -0,0 +1,98 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; + + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldCheckbox(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setTextField(e.target.value, props.idq)}/> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + { + props.options.map((x, index) => { + return <Grid container> + <Grid item container + justify="center" + alignItems="center" + xs={1} + > + <CheckBoxOutlineBlankIcon/> + </Grid> + <Grid item xs={10}> + <TextField label={"opção "+index} value={x} fullWidth + onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="remove option" + onClick={() => { props.removeSelectOption(props.idq, index) } }> + <CloseIcon /> + </IconButton> + </Grid> + </Grid> + }) + } + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={4} + > + <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> + <AddCircleIcon /> + </IconButton> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField}/> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldCheckbox; \ No newline at end of file -- GitLab From c87cca85cab8717444024d35aad60b7ac8caf627 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 17 Jan 2020 11:49:53 -0300 Subject: [PATCH 09/72] add checkbox field option --- src/App.js | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/src/App.js b/src/App.js index 54f41e4..46e9d3c 100644 --- a/src/App.js +++ b/src/App.js @@ -7,11 +7,12 @@ import AddIcon from '@material-ui/icons/Add'; import IconButton from '@material-ui/core/IconButton'; import ReorderIcon from '@material-ui/icons/Reorder'; import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; - +import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; import FormFieldText from './components/FormFieldText'; import FormFieldSelect from './components/FormFieldSelect'; import FormFieldRadio from './components/FormFieldRadio'; +import FormFieldCheckbox from './components/FormFieldCheckbox'; const useStyles = makeStyles(theme => ({ menu: { @@ -44,6 +45,11 @@ function App() { console.log(form); } + function addToFormCheckbox() { + setForm([...form, {type: "checkbox", question: "", required: false, options: [""]}]); + console.log(form); + } + function addSelectOption(index) { form[index].options.push(""); setForm([...form]); @@ -106,6 +112,11 @@ function App() { deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} setTextField={setTextField} setRequiredField={setRequiredField} /> + else if(x.type === "checkbox") + return <FormFieldCheckbox question={x.question} options={x.options} idq={index} + deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} + setTextField={setTextField} setRequiredField={setRequiredField} /> }) } @@ -130,6 +141,9 @@ function App() { <IconButton aria-label="add radio" onClick={addToFormRadio}> <RadioButtonCheckedIcon /> </IconButton> + <IconButton aria-label="add checkbox" onClick={addToFormCheckbox}> + <CheckBoxOutlineBlankIcon /> + </IconButton> </Grid> </Grid> </Paper> -- GitLab From 819ddb9c21e133f185ed18a9bc2eda657da72f73 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Tue, 21 Jan 2020 11:12:13 -0300 Subject: [PATCH 10/72] organize files and fix required bug --- .../fieldsCreateForm/FieldFooterOptions.js | 40 ++++++++ .../fieldsCreateForm/FormFieldCheckbox.js | 98 +++++++++++++++++++ .../fieldsCreateForm/FormFieldRadio.js | 97 ++++++++++++++++++ .../fieldsCreateForm/FormFieldSelect.js | 89 +++++++++++++++++ .../fieldsCreateForm/FormFieldText.js | 56 +++++++++++ .../fieldsCreateForm/FormFieldTitle.js | 66 +++++++++++++ 6 files changed, 446 insertions(+) create mode 100644 src/components/fieldsCreateForm/FieldFooterOptions.js create mode 100644 src/components/fieldsCreateForm/FormFieldCheckbox.js create mode 100644 src/components/fieldsCreateForm/FormFieldRadio.js create mode 100644 src/components/fieldsCreateForm/FormFieldSelect.js create mode 100644 src/components/fieldsCreateForm/FormFieldText.js create mode 100644 src/components/fieldsCreateForm/FormFieldTitle.js diff --git a/src/components/fieldsCreateForm/FieldFooterOptions.js b/src/components/fieldsCreateForm/FieldFooterOptions.js new file mode 100644 index 0000000..f6446f0 --- /dev/null +++ b/src/components/fieldsCreateForm/FieldFooterOptions.js @@ -0,0 +1,40 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; + +function FieldFooterOptions(props) { + + return ( + <> + <FormControlLabel + control={ + <Switch + onChange={e => props.setRequiredField(props.idq) } + value="required" + color="primary" + checked={props.required} + /> + } + label="Obrigatória" + /> + <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> + <DeleteOutlinedIcon /> + </IconButton> + </> + ); + + +} + + +export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/fieldsCreateForm/FormFieldCheckbox.js b/src/components/fieldsCreateForm/FormFieldCheckbox.js new file mode 100644 index 0000000..c4f88cd --- /dev/null +++ b/src/components/fieldsCreateForm/FormFieldCheckbox.js @@ -0,0 +1,98 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; + + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldCheckbox(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setQuestionField(e.target.value, props.idq)}/> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + { + props.options.map((x, index) => { + return <Grid container> + <Grid item container + justify="center" + alignItems="center" + xs={1} + > + <CheckBoxOutlineBlankIcon/> + </Grid> + <Grid item xs={10}> + <TextField label={"opção "+index} value={x} fullWidth + onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="remove option" + onClick={() => { props.removeSelectOption(props.idq, index) } }> + <CloseIcon /> + </IconButton> + </Grid> + </Grid> + }) + } + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={4} + > + <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> + <AddCircleIcon /> + </IconButton> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField} required={props.required}/> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldCheckbox; \ No newline at end of file diff --git a/src/components/fieldsCreateForm/FormFieldRadio.js b/src/components/fieldsCreateForm/FormFieldRadio.js new file mode 100644 index 0000000..ce10709 --- /dev/null +++ b/src/components/fieldsCreateForm/FormFieldRadio.js @@ -0,0 +1,97 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import RadioButtonUncheckedIcon from '@material-ui/icons/RadioButtonUnchecked'; + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldRadio(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setQuestionField(e.target.value, props.idq)}/> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + { + props.options.map((x, index) => { + return <Grid container> + <Grid item container + justify="center" + alignItems="center" + xs={1} + > + <RadioButtonUncheckedIcon/> + </Grid> + <Grid item xs={10}> + <TextField label={"opção "+index} value={x} fullWidth + onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="remove option" + onClick={() => { props.removeSelectOption(props.idq, index) } }> + <CloseIcon /> + </IconButton> + </Grid> + </Grid> + }) + } + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={4} + > + <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> + <AddCircleIcon /> + </IconButton> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField} required={props.required} /> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldRadio; \ No newline at end of file diff --git a/src/components/fieldsCreateForm/FormFieldSelect.js b/src/components/fieldsCreateForm/FormFieldSelect.js new file mode 100644 index 0000000..3158b46 --- /dev/null +++ b/src/components/fieldsCreateForm/FormFieldSelect.js @@ -0,0 +1,89 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldSelect(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setQuestionField(e.target.value, props.idq)}/> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + { + props.options.map((x, index) => { + return <Grid container> + <Grid item xs={11}> + <TextField label={"opção "+index} value={x} fullWidth + onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + </Grid> + <Grid item xs={1}> + <IconButton aria-label="remove option" + onClick={() => { props.removeSelectOption(props.idq, index) } }> + <CloseIcon /> + </IconButton> + </Grid> + </Grid> + }) + } + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={4} + > + <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> + <AddCircleIcon /> + </IconButton> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField} required={props.required} /> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldSelect; \ No newline at end of file diff --git a/src/components/fieldsCreateForm/FormFieldText.js b/src/components/fieldsCreateForm/FormFieldText.js new file mode 100644 index 0000000..7b032df --- /dev/null +++ b/src/components/fieldsCreateForm/FormFieldText.js @@ -0,0 +1,56 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; + +import FieldFooterOptions from './FieldFooterOptions'; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="sua pergunta" + onChange={e => props.setQuestionField(e.target.value, props.idq)}/> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <TextField + disabled + id="outlined-disabled" + label="" + defaultValue="Resposta curta" + /> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} + setRequiredField={props.setRequiredField} required={props.required} /> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldText; \ No newline at end of file diff --git a/src/components/fieldsCreateForm/FormFieldTitle.js b/src/components/fieldsCreateForm/FormFieldTitle.js new file mode 100644 index 0000000..0197652 --- /dev/null +++ b/src/components/fieldsCreateForm/FormFieldTitle.js @@ -0,0 +1,66 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; + +import FieldFooterOptions from './FieldFooterOptions'; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, + title: { + fontSize: 'xx-large' + }, + description: { + fontSize: 'x-large' + }, +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <TextField value={props.question} label="Formulário sem tÃtulo" fullWidth + onChange={e => props.setTitleField(e.target.value, props.idq)} + InputProps={{ + classes: { + input: classes.title, + }, + }}/> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <TextField value={props.question} label="Descrição do formulário" + onChange={e => props.setDescriptionField(e.target.value, props.idq)} + InputProps={{ + classes: { + input: classes.description, + }, + }}/> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldText; \ No newline at end of file -- GitLab From 6a7642b8f03774dd2122ebe9bfa9e1564087d150 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Tue, 21 Jan 2020 11:12:49 -0300 Subject: [PATCH 11/72] Add title field --- src/App.js | 48 +++++++++++++++++++++++++++++++++--------------- 1 file changed, 33 insertions(+), 15 deletions(-) diff --git a/src/App.js b/src/App.js index 46e9d3c..0db10c2 100644 --- a/src/App.js +++ b/src/App.js @@ -9,10 +9,12 @@ import ReorderIcon from '@material-ui/icons/Reorder'; import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; -import FormFieldText from './components/FormFieldText'; -import FormFieldSelect from './components/FormFieldSelect'; -import FormFieldRadio from './components/FormFieldRadio'; -import FormFieldCheckbox from './components/FormFieldCheckbox'; +import FormFieldText from './components/fieldsCreateForm/FormFieldText'; +import FormFieldSelect from './components/fieldsCreateForm/FormFieldSelect'; +import FormFieldRadio from './components/fieldsCreateForm/FormFieldRadio'; +import FormFieldCheckbox from './components/fieldsCreateForm/FormFieldCheckbox'; +import FormFieldTitle from './components/fieldsCreateForm/FormFieldTitle'; + const useStyles = makeStyles(theme => ({ menu: { @@ -28,7 +30,7 @@ const useStyles = makeStyles(theme => ({ function App() { const classes = useStyles(); - const [form, setForm] = useState([]); + const [form, setForm] = useState([{type: "title", title: "", description: ""}]); function addToFormQuestion() { setForm([...form, {type: "question", required: false, question: ""}]); @@ -69,7 +71,7 @@ function App() { console.log(form); } - function setTextField(value, index) { + function setQuestionField(value, index) { form[index].question = value; setForm([...form]); console.log(form); @@ -87,6 +89,18 @@ function App() { console.log(form); } + function setTitleField(value, index) { + form[index].title = value; + setForm([...form]); + console.log(form); + } + + function setDescriptionField(value, index) { + form[index].description = value; + setForm([...form]); + console.log(form); + } + return ( <div> <Grid @@ -95,32 +109,36 @@ function App() { alignItems="center" justify="center" > - { form.map((x, index) => { if(x.type === "question") return <FormFieldText question={x.question} idq={index} - deleteFromForm={deleteFromForm} setTextField={setTextField} - setRequiredField={setRequiredField}/> + deleteFromForm={deleteFromForm} setQuestionField={setQuestionField} + setRequiredField={setRequiredField} required={x.required}/> else if(x.type === "select") return <FormFieldSelect question={x.question} options={x.options} idq={index} deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setTextField={setTextField} setRequiredField={setRequiredField} /> + setQuestionField={setQuestionField} setRequiredField={setRequiredField} + required={x.required} /> else if(x.type === "radio") return <FormFieldRadio question={x.question} options={x.options} idq={index} deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setTextField={setTextField} setRequiredField={setRequiredField} /> + setQuestionField={setQuestionField} setRequiredField={setRequiredField} + required={x.required} /> else if(x.type === "checkbox") - return <FormFieldCheckbox question={x.question} options={x.options} idq={index} + return <FormFieldCheckbox question={x.question} options={x.options} idq={index} deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setTextField={setTextField} setRequiredField={setRequiredField} /> + setQuestionField={setQuestionField} setRequiredField={setRequiredField} + required={x.required} /> + else if(x.type === "title") + return <FormFieldTitle question={x.question} idq={index} + deleteFromForm={deleteFromForm} setTitleField={setTitleField} + setDescriptionField={setDescriptionField}/> }) } - - </Grid> <Paper className={classes.menu}> -- GitLab From 77f12684d10f965d9f2a56c2ff31b437b0865752 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Tue, 21 Jan 2020 11:13:42 -0300 Subject: [PATCH 12/72] delete files --- src/components/FieldFooterOptions.js | 39 ----------- src/components/FormFieldCheckbox.js | 98 ---------------------------- src/components/FormFieldRadio.js | 97 --------------------------- src/components/FormFieldSelect.js | 89 ------------------------- src/components/FormFieldText.js | 56 ---------------- 5 files changed, 379 deletions(-) delete mode 100644 src/components/FieldFooterOptions.js delete mode 100644 src/components/FormFieldCheckbox.js delete mode 100644 src/components/FormFieldRadio.js delete mode 100644 src/components/FormFieldSelect.js delete mode 100644 src/components/FormFieldText.js diff --git a/src/components/FieldFooterOptions.js b/src/components/FieldFooterOptions.js deleted file mode 100644 index 0ef5eca..0000000 --- a/src/components/FieldFooterOptions.js +++ /dev/null @@ -1,39 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; - -function FieldFooterOptions(props) { - - return ( - <> - <FormControlLabel - control={ - <Switch - onChange={e => props.setRequiredField(props.idq) } - value="required" - color="primary" - /> - } - label="Obrigatória" - /> - <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> - <DeleteOutlinedIcon /> - </IconButton> - </> - ); - - -} - - -export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/FormFieldCheckbox.js b/src/components/FormFieldCheckbox.js deleted file mode 100644 index cb49d70..0000000 --- a/src/components/FormFieldCheckbox.js +++ /dev/null @@ -1,98 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; - - -import FieldFooterOptions from './FieldFooterOptions'; - - -const useStyles = makeStyles(theme => ({ - paper: { - padding: theme.spacing(3), - width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) - }, - questionsGrid: { - marginBottom: '20px' - }, -})); - - - -function FormFieldCheckbox(props) { - const classes = useStyles(); - - return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setTextField(e.target.value, props.idq)}/> - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} - > - { - props.options.map((x, index) => { - return <Grid container> - <Grid item container - justify="center" - alignItems="center" - xs={1} - > - <CheckBoxOutlineBlankIcon/> - </Grid> - <Grid item xs={10}> - <TextField label={"opção "+index} value={x} fullWidth - onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> - </Grid> - <Grid item xs={1}> - <IconButton aria-label="remove option" - onClick={() => { props.removeSelectOption(props.idq, index) } }> - <CloseIcon /> - </IconButton> - </Grid> - </Grid> - }) - } - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" - xs={4} - > - <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> - <AddCircleIcon /> - </IconButton> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField}/> - </Grid> - </Grid> - </Paper> - ); - -} - -export default FormFieldCheckbox; \ No newline at end of file diff --git a/src/components/FormFieldRadio.js b/src/components/FormFieldRadio.js deleted file mode 100644 index 70d74d4..0000000 --- a/src/components/FormFieldRadio.js +++ /dev/null @@ -1,97 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import RadioButtonUncheckedIcon from '@material-ui/icons/RadioButtonUnchecked'; - -import FieldFooterOptions from './FieldFooterOptions'; - - -const useStyles = makeStyles(theme => ({ - paper: { - padding: theme.spacing(3), - width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) - }, - questionsGrid: { - marginBottom: '20px' - }, -})); - - - -function FormFieldRadio(props) { - const classes = useStyles(); - - return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setTextField(e.target.value, props.idq)}/> - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} - > - { - props.options.map((x, index) => { - return <Grid container> - <Grid item container - justify="center" - alignItems="center" - xs={1} - > - <RadioButtonUncheckedIcon/> - </Grid> - <Grid item xs={10}> - <TextField label={"opção "+index} value={x} fullWidth - onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> - </Grid> - <Grid item xs={1}> - <IconButton aria-label="remove option" - onClick={() => { props.removeSelectOption(props.idq, index) } }> - <CloseIcon /> - </IconButton> - </Grid> - </Grid> - }) - } - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" - xs={4} - > - <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> - <AddCircleIcon /> - </IconButton> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField}/> - </Grid> - </Grid> - </Paper> - ); - -} - -export default FormFieldRadio; \ No newline at end of file diff --git a/src/components/FormFieldSelect.js b/src/components/FormFieldSelect.js deleted file mode 100644 index 7125a80..0000000 --- a/src/components/FormFieldSelect.js +++ /dev/null @@ -1,89 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; - -import FieldFooterOptions from './FieldFooterOptions'; - - -const useStyles = makeStyles(theme => ({ - paper: { - padding: theme.spacing(3), - width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) - }, - questionsGrid: { - marginBottom: '20px' - }, -})); - - - -function FormFieldSelect(props) { - const classes = useStyles(); - - return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setTextField(e.target.value, props.idq)}/> - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} - > - { - props.options.map((x, index) => { - return <Grid container> - <Grid item xs={11}> - <TextField label={"opção "+index} value={x} fullWidth - onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> - </Grid> - <Grid item xs={1}> - <IconButton aria-label="remove option" - onClick={() => { props.removeSelectOption(props.idq, index) } }> - <CloseIcon /> - </IconButton> - </Grid> - </Grid> - }) - } - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" - xs={4} - > - <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> - <AddCircleIcon /> - </IconButton> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField}/> - </Grid> - </Grid> - </Paper> - ); - -} - -export default FormFieldSelect; \ No newline at end of file diff --git a/src/components/FormFieldText.js b/src/components/FormFieldText.js deleted file mode 100644 index 31cca40..0000000 --- a/src/components/FormFieldText.js +++ /dev/null @@ -1,56 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; - -import FieldFooterOptions from './FieldFooterOptions'; - -const useStyles = makeStyles(theme => ({ - paper: { - padding: theme.spacing(3), - width: theme.spacing(100), - height: theme.spacing(16), - margin: theme.spacing(2) - }, - questionsGrid: { - marginBottom: '20px' - }, -})); - -function FormFieldText(props) { - const classes = useStyles(); - - return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setTextField(e.target.value, props.idq)}/> - </Grid> - <Grid item xs={9} className={classes.questionsGrid}> - <TextField - disabled - id="outlined-disabled" - label="" - defaultValue="Resposta curta" - /> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField}/> - </Grid> - </Grid> - </Paper> - ); - -} - -export default FormFieldText; \ No newline at end of file -- GitLab From 7ff5d97e1c95a1252e7017e0c5bada0a9da6f85d Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Tue, 28 Jan 2020 10:35:52 -0300 Subject: [PATCH 13/72] configs for envs --- src/config.js | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 src/config.js diff --git a/src/config.js b/src/config.js new file mode 100644 index 0000000..f2737c1 --- /dev/null +++ b/src/config.js @@ -0,0 +1,22 @@ +const development = { + genformsapi: { + url: "http://200.236.31.188/api/" + } +}; + +const production = { + genformsapi: { + url: "" + } +}; + + +let conf; +if(process.env.REACT_APP_STAGE === "production") { + conf = production; +} else { + conf = development; +} + +const config = conf; +export default config; -- GitLab From e2a47f5d88f0280198c71e414b79756d2e56197f Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Tue, 28 Jan 2020 10:36:18 -0300 Subject: [PATCH 14/72] submit form only questions --- src/App.js | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/src/App.js b/src/App.js index 0db10c2..119012d 100644 --- a/src/App.js +++ b/src/App.js @@ -8,6 +8,8 @@ import IconButton from '@material-ui/core/IconButton'; import ReorderIcon from '@material-ui/icons/Reorder'; import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; +import Button from '@material-ui/core/Button'; +import axios from 'axios'; import FormFieldText from './components/fieldsCreateForm/FormFieldText'; import FormFieldSelect from './components/fieldsCreateForm/FormFieldSelect'; @@ -15,6 +17,8 @@ import FormFieldRadio from './components/fieldsCreateForm/FormFieldRadio'; import FormFieldCheckbox from './components/fieldsCreateForm/FormFieldCheckbox'; import FormFieldTitle from './components/fieldsCreateForm/FormFieldTitle'; +import config from './config'; + const useStyles = makeStyles(theme => ({ menu: { @@ -101,6 +105,35 @@ function App() { console.log(form); } + function createForm() { + let json = { + title: form[0].title, + description: form[0].description, + inputs: [] + } + + form.forEach(function(x, index){ + if(x.type === "question") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": x.required, + "type": 0, // question type = 0 + "validation": [] + }); + } + }); + + + console.log(json); + axios.post(`${config.genformsapi.url}/form`, json ) + .then(res => { + console.log(res); + console.log(res.data); + }); + } + return ( <div> <Grid @@ -139,6 +172,9 @@ function App() { setDescriptionField={setDescriptionField}/> }) } + <Button variant="contained" color="primary" onClick={createForm}> + Criar + </Button> </Grid> <Paper className={classes.menu}> -- GitLab From aeef9d9d348be1a1c17a998d9b92d92d25e89bc3 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Tue, 28 Jan 2020 11:41:58 -0300 Subject: [PATCH 15/72] add fields select, radio and checkbox --- src/App.js | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/App.js b/src/App.js index 119012d..ffe8a70 100644 --- a/src/App.js +++ b/src/App.js @@ -122,6 +122,36 @@ function App() { "type": 0, // question type = 0 "validation": [] }); + } else if(x.type === "select") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": x.required, + "type": 3, // select type = 3 + "validation": [], + "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) + }); + } else if(x.type === "checkbox") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": x.required, + "type": 1, // checkbox type = 1 + "validation": [], + "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) + }); + } else if(x.type === "radio") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": x.required, + "type": 2, // radio type = 2 + "validation": [], + "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) + }); } }); -- GitLab From e92130e19c67f52a4fcc4db8bd75122039f4c4c3 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Wed, 29 Jan 2020 09:47:29 -0300 Subject: [PATCH 16/72] reload page after submit --- src/App.js | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/src/App.js b/src/App.js index ffe8a70..191fcf6 100644 --- a/src/App.js +++ b/src/App.js @@ -118,18 +118,18 @@ function App() { "placement": index-1, "description": "Adicionar esse campo no front", "question": x.question, - "enabled": x.required, + "enabled": true, "type": 0, // question type = 0 - "validation": [] + "validation": x.required ? [{"type": 2, "arguments": ""}] : [] }); } else if(x.type === "select") { json.inputs.push({ "placement": index-1, "description": "Adicionar esse campo no front", "question": x.question, - "enabled": x.required, + "enabled": true, "type": 3, // select type = 3 - "validation": [], + "validation": x.required ? [{"type": 2, "arguments": ""}] : [], "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) }); } else if(x.type === "checkbox") { @@ -137,9 +137,9 @@ function App() { "placement": index-1, "description": "Adicionar esse campo no front", "question": x.question, - "enabled": x.required, + "enabled": true, "type": 1, // checkbox type = 1 - "validation": [], + "validation": x.required ? [{"type": 2, "arguments": ""}] : [], "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) }); } else if(x.type === "radio") { @@ -147,9 +147,9 @@ function App() { "placement": index-1, "description": "Adicionar esse campo no front", "question": x.question, - "enabled": x.required, + "enabled": true, "type": 2, // radio type = 2 - "validation": [], + "validation": x.required ? [{"type": 2, "arguments": ""}] : [], "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) }); } @@ -161,7 +161,10 @@ function App() { .then(res => { console.log(res); console.log(res.data); + + window.location.reload(); }); + } return ( -- GitLab From a0224f4a83fa9f45b55e61efe113588c764abb0a Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Thu, 30 Jan 2020 10:58:20 -0300 Subject: [PATCH 17/72] create routes --- src/App.js | 248 +++-------------------------------------------------- 1 file changed, 11 insertions(+), 237 deletions(-) diff --git a/src/App.js b/src/App.js index 191fcf6..695974d 100644 --- a/src/App.js +++ b/src/App.js @@ -1,242 +1,16 @@ -import React, { useState } from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import AddIcon from '@material-ui/icons/Add'; -import IconButton from '@material-ui/core/IconButton'; -import ReorderIcon from '@material-ui/icons/Reorder'; -import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; -import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; -import Button from '@material-ui/core/Button'; -import axios from 'axios'; +import React from 'react'; +import { HashRouter, Route } from 'react-router-dom'; -import FormFieldText from './components/fieldsCreateForm/FormFieldText'; -import FormFieldSelect from './components/fieldsCreateForm/FormFieldSelect'; -import FormFieldRadio from './components/fieldsCreateForm/FormFieldRadio'; -import FormFieldCheckbox from './components/fieldsCreateForm/FormFieldCheckbox'; -import FormFieldTitle from './components/fieldsCreateForm/FormFieldTitle'; - -import config from './config'; - - -const useStyles = makeStyles(theme => ({ - menu: { - width: theme.spacing(6), - minheight: theme.spacing(15), - position: 'fixed', - top: theme.spacing(10), - left: '90%', - padding: theme.spacing(1) - }, -})); +import CreateForm from './pages/CreateForm'; +import AnswerForm from './pages/AnswerForm'; function App() { - const classes = useStyles(); - - const [form, setForm] = useState([{type: "title", title: "", description: ""}]); - - function addToFormQuestion() { - setForm([...form, {type: "question", required: false, question: ""}]); - console.log(form); - } - - function addToFormSelect() { - setForm([...form, {type: "select", question: "", required: false, options: [""]}]); - console.log(form); - } - - function addToFormRadio() { - setForm([...form, {type: "radio", question: "", required: false, options: [""]}]); - console.log(form); - } - - function addToFormCheckbox() { - setForm([...form, {type: "checkbox", question: "", required: false, options: [""]}]); - console.log(form); - } - - function addSelectOption(index) { - form[index].options.push(""); - setForm([...form]); - console.log(form); - } - - function deleteFromForm(index) { - console.log(index); - form.splice(index, 1) - console.log(form); - setForm([...form]); - } - - function removeSelectOption(index, idopt) { - form[index].options.splice(idopt, 1); - setForm([...form]); - console.log(form); - } - - function setQuestionField(value, index) { - form[index].question = value; - setForm([...form]); - console.log(form); - } - - function setSelectOption(value, index, idopt) { - form[index].options[idopt] = value; - setForm([...form]); - console.log(form); - } - - function setRequiredField(index) { - form[index].required = !form[index].required; - setForm([...form]); - console.log(form); - } - - function setTitleField(value, index) { - form[index].title = value; - setForm([...form]); - console.log(form); - } - - function setDescriptionField(value, index) { - form[index].description = value; - setForm([...form]); - console.log(form); - } - - function createForm() { - let json = { - title: form[0].title, - description: form[0].description, - inputs: [] - } - - form.forEach(function(x, index){ - if(x.type === "question") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 0, // question type = 0 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [] - }); - } else if(x.type === "select") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 3, // select type = 3 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [], - "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) - }); - } else if(x.type === "checkbox") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 1, // checkbox type = 1 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [], - "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) - }); - } else if(x.type === "radio") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 2, // radio type = 2 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [], - "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) - }); - } - }); - - - console.log(json); - axios.post(`${config.genformsapi.url}/form`, json ) - .then(res => { - console.log(res); - console.log(res.data); - - window.location.reload(); - }); - - } - - return ( - <div> - <Grid - container - direction="column" - alignItems="center" - justify="center" - > - { - form.map((x, index) => { - if(x.type === "question") - return <FormFieldText question={x.question} idq={index} - deleteFromForm={deleteFromForm} setQuestionField={setQuestionField} - setRequiredField={setRequiredField} required={x.required}/> - else if(x.type === "select") - return <FormFieldSelect question={x.question} options={x.options} idq={index} - deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setQuestionField={setQuestionField} setRequiredField={setRequiredField} - required={x.required} /> - else if(x.type === "radio") - return <FormFieldRadio question={x.question} options={x.options} idq={index} - deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setQuestionField={setQuestionField} setRequiredField={setRequiredField} - required={x.required} /> - else if(x.type === "checkbox") - return <FormFieldCheckbox question={x.question} options={x.options} idq={index} - deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setQuestionField={setQuestionField} setRequiredField={setRequiredField} - required={x.required} /> - else if(x.type === "title") - return <FormFieldTitle question={x.question} idq={index} - deleteFromForm={deleteFromForm} setTitleField={setTitleField} - setDescriptionField={setDescriptionField}/> -}) - } - <Button variant="contained" color="primary" onClick={createForm}> - Criar - </Button> - </Grid> - - <Paper className={classes.menu}> - <Grid - container - spacing={0} - direction="column" - alignItems="center" - justify="center" - > - <Grid item xs={0}> - <IconButton aria-label="add question" onClick={addToFormQuestion}> - <AddIcon /> - </IconButton> - <IconButton aria-label="add select" onClick={addToFormSelect}> - <ReorderIcon /> - </IconButton> - <IconButton aria-label="add radio" onClick={addToFormRadio}> - <RadioButtonCheckedIcon /> - </IconButton> - <IconButton aria-label="add checkbox" onClick={addToFormCheckbox}> - <CheckBoxOutlineBlankIcon /> - </IconButton> - </Grid> - </Grid> - </Paper> - - </div> - ); + return ( + <HashRouter> + <Route path="/create" component={CreateForm} /> + <Route path="/answer/:id" component={AnswerForm} /> + </HashRouter> + ); } -export default App; +export default App; \ No newline at end of file -- GitLab From a38b51746ad5c23415a26f94a46de58ee05b0d96 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Thu, 30 Jan 2020 10:58:34 -0300 Subject: [PATCH 18/72] organize in pages --- src/pages/AnswerForm.js | 98 ++++++++++++++++ src/pages/CreateForm.js | 242 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 340 insertions(+) create mode 100644 src/pages/AnswerForm.js create mode 100644 src/pages/CreateForm.js diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js new file mode 100644 index 0000000..edcb312 --- /dev/null +++ b/src/pages/AnswerForm.js @@ -0,0 +1,98 @@ +import React, { useState, useEffect } from 'react'; +import { useParams } from "react-router-dom"; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import AddIcon from '@material-ui/icons/Add'; +import IconButton from '@material-ui/core/IconButton'; +import ReorderIcon from '@material-ui/icons/Reorder'; +import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; +import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; +import Button from '@material-ui/core/Button'; +import axios from 'axios'; + +import FormFieldText from '../components/fieldsAnswerForm/FormFieldText'; +import FormFieldSelect from '../components/fieldsAnswerForm/FormFieldSelect'; +import FormFieldRadio from '../components/fieldsAnswerForm/FormFieldRadio'; +import FormFieldCheckbox from '../components/fieldsAnswerForm/FormFieldCheckbox'; +import FormFieldTitle from '../components/fieldsAnswerForm/FormFieldTitle'; + +import config from '../config'; + + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: 'fixed', + top: theme.spacing(10), + left: '90%', + padding: theme.spacing(1) + }, +})); + +function AnwserForm() { + const classes = useStyles(); + + const { id } = useParams(); + + const [formData, setFormData] = useState(0); + + function getForm(id) { + axios.get(`${config.genformsapi.url}/form/${id}`) + .then(res => { + console.log(res); + console.log(res.data); + setFormData(res.data); + }); + } + + function answerForm() { + axios.post(`${config.genformsapi.url}/form`) + .then(res => { + console.log(res); + console.log(res.data); + }); + } + + useEffect(() => { + getForm(id); + }, []); + + return ( + <div> + <Grid + container + direction="column" + alignItems="center" + justify="center" + > + + { + formData ? + <div> + <FormFieldTitle title={formData.title} description={formData.description}/> + { + formData.inputs.map((x, index) => { + if(x.type === 0) + return <FormFieldText question={x.question}/> + else if(x.type === 4) + return <FormFieldSelect question={x.question} options={x.sugestions}/> + else if(x.type === 2) + return <FormFieldRadio question={x.question} options={x.sugestions}/> + else if(x.type === 1) + return <FormFieldCheckbox question={x.question} options={x.sugestions}/> + }) + } + </div> : <p>Loading...</p> + } + <Button variant="contained" color="primary" onClick={answerForm}> + Responder + </Button> + </Grid> + </div> + ); +} + +export default AnwserForm; diff --git a/src/pages/CreateForm.js b/src/pages/CreateForm.js new file mode 100644 index 0000000..677e396 --- /dev/null +++ b/src/pages/CreateForm.js @@ -0,0 +1,242 @@ +import React, { useState } from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import AddIcon from '@material-ui/icons/Add'; +import IconButton from '@material-ui/core/IconButton'; +import ReorderIcon from '@material-ui/icons/Reorder'; +import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; +import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; +import Button from '@material-ui/core/Button'; +import axios from 'axios'; + +import FormFieldText from '../components/fieldsCreateForm/FormFieldText'; +import FormFieldSelect from '../components/fieldsCreateForm/FormFieldSelect'; +import FormFieldRadio from '../components/fieldsCreateForm/FormFieldRadio'; +import FormFieldCheckbox from '../components/fieldsCreateForm/FormFieldCheckbox'; +import FormFieldTitle from '../components/fieldsCreateForm/FormFieldTitle'; + +import config from '../config'; + + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: 'fixed', + top: theme.spacing(10), + left: '90%', + padding: theme.spacing(1) + }, +})); + +function CreateForm() { + const classes = useStyles(); + + const [form, setForm] = useState([{type: "title", title: "", description: ""}]); + + function addToFormQuestion() { + setForm([...form, {type: "question", required: false, question: ""}]); + console.log(form); + } + + function addToFormSelect() { + setForm([...form, {type: "select", question: "", required: false, options: [""]}]); + console.log(form); + } + + function addToFormRadio() { + setForm([...form, {type: "radio", question: "", required: false, options: [""]}]); + console.log(form); + } + + function addToFormCheckbox() { + setForm([...form, {type: "checkbox", question: "", required: false, options: [""]}]); + console.log(form); + } + + function addSelectOption(index) { + form[index].options.push(""); + setForm([...form]); + console.log(form); + } + + function deleteFromForm(index) { + console.log(index); + form.splice(index, 1) + console.log(form); + setForm([...form]); + } + + function removeSelectOption(index, idopt) { + form[index].options.splice(idopt, 1); + setForm([...form]); + console.log(form); + } + + function setQuestionField(value, index) { + form[index].question = value; + setForm([...form]); + console.log(form); + } + + function setSelectOption(value, index, idopt) { + form[index].options[idopt] = value; + setForm([...form]); + console.log(form); + } + + function setRequiredField(index) { + form[index].required = !form[index].required; + setForm([...form]); + console.log(form); + } + + function setTitleField(value, index) { + form[index].title = value; + setForm([...form]); + console.log(form); + } + + function setDescriptionField(value, index) { + form[index].description = value; + setForm([...form]); + console.log(form); + } + + function createForm() { + let json = { + title: form[0].title, + description: form[0].description, + inputs: [] + } + + form.forEach(function(x, index){ + if(x.type === "question") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": true, + "type": 0, // question type = 0 + "validation": x.required ? [{"type": 2, "arguments": ""}] : [] + }); + } else if(x.type === "select") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": true, + "type": 3, // select type = 3 + "validation": x.required ? [{"type": 2, "arguments": ""}] : [], + "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) + }); + } else if(x.type === "checkbox") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": true, + "type": 1, // checkbox type = 1 + "validation": x.required ? [{"type": 2, "arguments": ""}] : [], + "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) + }); + } else if(x.type === "radio") { + json.inputs.push({ + "placement": index-1, + "description": "Adicionar esse campo no front", + "question": x.question, + "enabled": true, + "type": 2, // radio type = 2 + "validation": x.required ? [{"type": 2, "arguments": ""}] : [], + "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) + }); + } + }); + + + console.log(json); + axios.post(`${config.genformsapi.url}/form`, json ) + .then(res => { + console.log(res); + console.log(res.data); + + window.location.reload(); + }); + + } + + return ( + <div> + <Grid + container + direction="column" + alignItems="center" + justify="center" + > + { + form.map((x, index) => { + if(x.type === "question") + return <FormFieldText question={x.question} idq={index} + deleteFromForm={deleteFromForm} setQuestionField={setQuestionField} + setRequiredField={setRequiredField} required={x.required}/> + else if(x.type === "select") + return <FormFieldSelect question={x.question} options={x.options} idq={index} + deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} + setQuestionField={setQuestionField} setRequiredField={setRequiredField} + required={x.required} /> + else if(x.type === "radio") + return <FormFieldRadio question={x.question} options={x.options} idq={index} + deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} + setQuestionField={setQuestionField} setRequiredField={setRequiredField} + required={x.required} /> + else if(x.type === "checkbox") + return <FormFieldCheckbox question={x.question} options={x.options} idq={index} + deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} + setQuestionField={setQuestionField} setRequiredField={setRequiredField} + required={x.required} /> + else if(x.type === "title") + return <FormFieldTitle question={x.question} idq={index} + deleteFromForm={deleteFromForm} setTitleField={setTitleField} + setDescriptionField={setDescriptionField}/> + }) + } + <Button variant="contained" color="primary" onClick={createForm}> + Criar + </Button> + </Grid> + + <Paper className={classes.menu}> + <Grid + container + spacing={0} + direction="column" + alignItems="center" + justify="center" + > + <Grid item xs={0}> + <IconButton aria-label="add question" onClick={addToFormQuestion}> + <AddIcon /> + </IconButton> + <IconButton aria-label="add select" onClick={addToFormSelect}> + <ReorderIcon /> + </IconButton> + <IconButton aria-label="add radio" onClick={addToFormRadio}> + <RadioButtonCheckedIcon /> + </IconButton> + <IconButton aria-label="add checkbox" onClick={addToFormCheckbox}> + <CheckBoxOutlineBlankIcon /> + </IconButton> + </Grid> + </Grid> + </Paper> + + </div> + ); +} + +export default CreateForm; -- GitLab From b304cd6e1b52c85269719fc29f72a30a72cf70b1 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Thu, 30 Jan 2020 10:58:54 -0300 Subject: [PATCH 19/72] answer components --- .../fieldsAnswerForm/FieldFooterOptions.js | 40 +++++++++++ .../fieldsAnswerForm/FormFieldCheckbox.js | 62 +++++++++++++++++ .../fieldsAnswerForm/FormFieldRadio.js | 65 ++++++++++++++++++ .../fieldsAnswerForm/FormFieldSelect.js | 67 +++++++++++++++++++ .../fieldsAnswerForm/FormFieldText.js | 56 ++++++++++++++++ .../fieldsAnswerForm/FormFieldTitle.js | 59 ++++++++++++++++ 6 files changed, 349 insertions(+) create mode 100644 src/components/fieldsAnswerForm/FieldFooterOptions.js create mode 100644 src/components/fieldsAnswerForm/FormFieldCheckbox.js create mode 100644 src/components/fieldsAnswerForm/FormFieldRadio.js create mode 100644 src/components/fieldsAnswerForm/FormFieldSelect.js create mode 100644 src/components/fieldsAnswerForm/FormFieldText.js create mode 100644 src/components/fieldsAnswerForm/FormFieldTitle.js diff --git a/src/components/fieldsAnswerForm/FieldFooterOptions.js b/src/components/fieldsAnswerForm/FieldFooterOptions.js new file mode 100644 index 0000000..f6446f0 --- /dev/null +++ b/src/components/fieldsAnswerForm/FieldFooterOptions.js @@ -0,0 +1,40 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; + +function FieldFooterOptions(props) { + + return ( + <> + <FormControlLabel + control={ + <Switch + onChange={e => props.setRequiredField(props.idq) } + value="required" + color="primary" + checked={props.required} + /> + } + label="Obrigatória" + /> + <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> + <DeleteOutlinedIcon /> + </IconButton> + </> + ); + + +} + + +export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/fieldsAnswerForm/FormFieldCheckbox.js b/src/components/fieldsAnswerForm/FormFieldCheckbox.js new file mode 100644 index 0000000..7b4adf5 --- /dev/null +++ b/src/components/fieldsAnswerForm/FormFieldCheckbox.js @@ -0,0 +1,62 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import Typography from '@material-ui/core/Typography'; +import Checkbox from '@material-ui/core/Checkbox'; + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldCheckbox(props) { + const classes = useStyles(); + + const options = props.options.map(function(x) { + return <span>{x.value} <Checkbox /></span>; + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography variant="h6" gutterBottom> + {props.question} + </Typography> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + {options} + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldCheckbox; \ No newline at end of file diff --git a/src/components/fieldsAnswerForm/FormFieldRadio.js b/src/components/fieldsAnswerForm/FormFieldRadio.js new file mode 100644 index 0000000..4f79cfe --- /dev/null +++ b/src/components/fieldsAnswerForm/FormFieldRadio.js @@ -0,0 +1,65 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import Typography from '@material-ui/core/Typography'; +import Radio from '@material-ui/core/Radio'; +import RadioGroup from '@material-ui/core/RadioGroup'; + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldRadio(props) { + const classes = useStyles(); + + const options = props.options.map(function(x) { + return <span>{x.value} <Radio /></span>; + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography variant="h6" gutterBottom> + {props.question} + </Typography> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + <RadioGroup> + {options} + </RadioGroup> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldRadio; \ No newline at end of file diff --git a/src/components/fieldsAnswerForm/FormFieldSelect.js b/src/components/fieldsAnswerForm/FormFieldSelect.js new file mode 100644 index 0000000..46ee77b --- /dev/null +++ b/src/components/fieldsAnswerForm/FormFieldSelect.js @@ -0,0 +1,67 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import Typography from '@material-ui/core/Typography'; + +import FieldFooterOptions from './FieldFooterOptions'; + + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + + + +function FormFieldSelect(props) { + const classes = useStyles(); + + const options = props.options.map(function(x) { + return <MenuItem value={x.value}>{x.value}</MenuItem>; + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography variant="h6" gutterBottom> + {props.question} + </Typography> + </Grid> + <Grid item container + direction="column" + justify="flex-start" + alignItems="flex-start" xs={5} className={classes.questionsGrid} + > + <Select + labelId="demo-simple-select-label" + id="demo-simple-select" + // onChange={handleChange} + > + {options} + </Select> + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldSelect; \ No newline at end of file diff --git a/src/components/fieldsAnswerForm/FormFieldText.js b/src/components/fieldsAnswerForm/FormFieldText.js new file mode 100644 index 0000000..c42f755 --- /dev/null +++ b/src/components/fieldsAnswerForm/FormFieldText.js @@ -0,0 +1,56 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Typography from '@material-ui/core/Typography'; + +import FieldFooterOptions from './FieldFooterOptions'; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography variant="h6" gutterBottom> + {props.question} + </Typography> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <TextField + disabled + id="outlined-disabled" + label="" + defaultValue="Resposta curta" + /> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldText; \ No newline at end of file diff --git a/src/components/fieldsAnswerForm/FormFieldTitle.js b/src/components/fieldsAnswerForm/FormFieldTitle.js new file mode 100644 index 0000000..52c907b --- /dev/null +++ b/src/components/fieldsAnswerForm/FormFieldTitle.js @@ -0,0 +1,59 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Typography from '@material-ui/core/Typography'; + +import FieldFooterOptions from './FieldFooterOptions'; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(16), + margin: theme.spacing(2) + }, + questionsGrid: { + marginBottom: '20px' + }, + title: { + fontSize: 'xx-large' + }, + description: { + fontSize: 'x-large' + }, +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography variant="h3" gutterBottom> + {props.title} + </Typography> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <Typography variant="h4" gutterBottom> + {props.description} + </Typography> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + </Grid> + </Grid> + </Paper> + ); + +} + +export default FormFieldText; \ No newline at end of file -- GitLab From 1c7b26a1b13aa176c36cc48095ed886743d93228 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 31 Jan 2020 09:36:35 -0300 Subject: [PATCH 20/72] add answer field radio --- src/components/fieldsAnswerForm/FormFieldRadio.js | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/src/components/fieldsAnswerForm/FormFieldRadio.js b/src/components/fieldsAnswerForm/FormFieldRadio.js index 4f79cfe..3f18ffb 100644 --- a/src/components/fieldsAnswerForm/FormFieldRadio.js +++ b/src/components/fieldsAnswerForm/FormFieldRadio.js @@ -35,8 +35,20 @@ const useStyles = makeStyles(theme => ({ function FormFieldRadio(props) { const classes = useStyles(); + const [selectedValue, setSelectedValue] = React.useState(); + + const handleChange = event => { + setSelectedValue(event.target.value); + }; + const options = props.options.map(function(x) { - return <span>{x.value} <Radio /></span>; + return <span> + {x.value} + <Radio checked={selectedValue === x.value} + onChange={handleChange} + value={x.value} + /> + </span>; }); return ( -- GitLab From 2520fff6c9f1bee7703caf9ab4e1fe695ac045a1 Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 31 Jan 2020 09:37:00 -0300 Subject: [PATCH 21/72] fix bug --- src/components/fieldsAnswerForm/FormFieldText.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/components/fieldsAnswerForm/FormFieldText.js b/src/components/fieldsAnswerForm/FormFieldText.js index c42f755..a675f3a 100644 --- a/src/components/fieldsAnswerForm/FormFieldText.js +++ b/src/components/fieldsAnswerForm/FormFieldText.js @@ -34,10 +34,9 @@ function FormFieldText(props) { </Grid> <Grid item xs={9} className={classes.questionsGrid}> <TextField - disabled id="outlined-disabled" label="" - defaultValue="Resposta curta" + placeholder="Resposta curta" /> </Grid> <Grid item container -- GitLab From 0ff6e9db531a6609d8704fc59453dad2bc21788c Mon Sep 17 00:00:00 2001 From: pdg16 <pdg16@inf.ufpr.br> Date: Fri, 31 Jan 2020 09:46:57 -0300 Subject: [PATCH 22/72] update README --- README.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/README.md b/README.md index 859d27a..9b5899d 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,14 @@ +## BUILD + +# Development + +```npm run build``` + +# Produção + +```REACT_APP_STAGE="production" npm run build``` + + This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). ## Available Scripts -- GitLab From cc6274e4f87ccdad72920c950e1c7352d90bdb99 Mon Sep 17 00:00:00 2001 From: Gabriel_S <gash18@inf.ufpr.br> Date: Fri, 7 Feb 2020 11:31:10 -0300 Subject: [PATCH 23/72] Issue #5: Atualizar README.md Signed-off-by: Gabriel_S <gash18@inf.ufpr.br> --- README.md | 13 ++++++++++--- src/App.js | 2 +- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 9b5899d..bb30307 100644 --- a/README.md +++ b/README.md @@ -1,13 +1,20 @@ ## BUILD +# Preqrequisite packages + +`npm install` + +`npm install react-router-dom` + +`npm install axios` + # Development -```npm run build``` +`npm run build` # Produção -```REACT_APP_STAGE="production" npm run build``` - +`REACT_APP_STAGE="production" npm run build` This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). diff --git a/src/App.js b/src/App.js index 695974d..c12655e 100644 --- a/src/App.js +++ b/src/App.js @@ -11,6 +11,6 @@ function App() { <Route path="/answer/:id" component={AnswerForm} /> </HashRouter> ); -} + } export default App; \ No newline at end of file -- GitLab From 2a2a6d51489b26ba01b02ee154d56d9b2345f95c Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 20 Feb 2020 10:48:32 -0300 Subject: [PATCH 24/72] Issue #10: Cleaning Develop --- src/App.js | 24 +++--- .../fieldsAnswerForm/FormFieldRadio.js | 73 ++++++++++--------- .../fieldsAnswerForm/FormFieldText.js | 32 ++++---- 3 files changed, 65 insertions(+), 64 deletions(-) diff --git a/src/App.js b/src/App.js index c12655e..6990081 100644 --- a/src/App.js +++ b/src/App.js @@ -1,16 +1,16 @@ -import React from 'react'; -import { HashRouter, Route } from 'react-router-dom'; +import React from "react"; +import { HashRouter, Route } from "react-router-dom"; -import CreateForm from './pages/CreateForm'; -import AnswerForm from './pages/AnswerForm'; +import CreateForm from "./pages/CreateForm"; +import AnswerForm from "./pages/AnswerForm"; function App() { - return ( - <HashRouter> - <Route path="/create" component={CreateForm} /> - <Route path="/answer/:id" component={AnswerForm} /> - </HashRouter> - ); - } + return ( + <HashRouter> + <Route path="/create" component={CreateForm} /> + <Route path="/answer/:id" component={AnswerForm} /> + </HashRouter> + ); +} -export default App; \ No newline at end of file +export default App; diff --git a/src/components/fieldsAnswerForm/FormFieldRadio.js b/src/components/fieldsAnswerForm/FormFieldRadio.js index 3f18ffb..68a79e4 100644 --- a/src/components/fieldsAnswerForm/FormFieldRadio.js +++ b/src/components/fieldsAnswerForm/FormFieldRadio.js @@ -1,22 +1,21 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import Typography from '@material-ui/core/Typography'; -import Radio from '@material-ui/core/Radio'; -import RadioGroup from '@material-ui/core/RadioGroup'; - -import FieldFooterOptions from './FieldFooterOptions'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import AddCircleIcon from "@material-ui/icons/AddCircle"; +import CloseIcon from "@material-ui/icons/Close"; +import Switch from "@material-ui/core/Switch"; +import FormControlLabel from "@material-ui/core/FormControlLabel"; +import Typography from "@material-ui/core/Typography"; +import Radio from "@material-ui/core/Radio"; +import RadioGroup from "@material-ui/core/RadioGroup"; +import FieldFooterOptions from "./FieldFooterOptions"; const useStyles = makeStyles(theme => ({ paper: { @@ -26,12 +25,10 @@ const useStyles = makeStyles(theme => ({ margin: theme.spacing(2) }, questionsGrid: { - marginBottom: '20px' - }, + marginBottom: "20px" + } })); - - function FormFieldRadio(props) { const classes = useStyles(); @@ -42,13 +39,16 @@ function FormFieldRadio(props) { }; const options = props.options.map(function(x) { - return <span> - {x.value} - <Radio checked={selectedValue === x.value} - onChange={handleChange} - value={x.value} - /> - </span>; + return ( + <span> + {x.value} + <Radio + checked={selectedValue === x.value} + onChange={handleChange} + value={x.value} + /> + </span> + ); }); return ( @@ -59,19 +59,20 @@ function FormFieldRadio(props) { {props.question} </Typography> </Grid> - <Grid item container + <Grid + item + container direction="column" justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} > - <RadioGroup> - {options} - </RadioGroup> + <RadioGroup>{options}</RadioGroup> </Grid> </Grid> </Paper> ); - } -export default FormFieldRadio; \ No newline at end of file +export default FormFieldRadio; diff --git a/src/components/fieldsAnswerForm/FormFieldText.js b/src/components/fieldsAnswerForm/FormFieldText.js index a675f3a..91e2f59 100644 --- a/src/components/fieldsAnswerForm/FormFieldText.js +++ b/src/components/fieldsAnswerForm/FormFieldText.js @@ -1,13 +1,13 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Typography from '@material-ui/core/Typography'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from './FieldFooterOptions'; +import FieldFooterOptions from "./FieldFooterOptions"; const useStyles = makeStyles(theme => ({ paper: { @@ -17,8 +17,8 @@ const useStyles = makeStyles(theme => ({ margin: theme.spacing(2) }, questionsGrid: { - marginBottom: '20px' - }, + marginBottom: "20px" + } })); function FormFieldText(props) { @@ -39,17 +39,17 @@ function FormFieldText(props) { placeholder="Resposta curta" /> </Grid> - <Grid item container + <Grid + item + container direction="row" justify="flex-end" alignItems="flex-end" xs={3} - > - </Grid> + ></Grid> </Grid> </Paper> ); - } -export default FormFieldText; \ No newline at end of file +export default FormFieldText; -- GitLab From 1245a4c5ddec3e2f628406ad3c545ca32abe56cd Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 20 Feb 2020 10:48:32 -0300 Subject: [PATCH 25/72] Issue #10: Cleaning Develop --- src/App.js | 24 +++--- .../fieldsAnswerForm/FormFieldRadio.js | 73 ++++++++++--------- .../fieldsAnswerForm/FormFieldText.js | 32 ++++---- 3 files changed, 65 insertions(+), 64 deletions(-) diff --git a/src/App.js b/src/App.js index c12655e..6990081 100644 --- a/src/App.js +++ b/src/App.js @@ -1,16 +1,16 @@ -import React from 'react'; -import { HashRouter, Route } from 'react-router-dom'; +import React from "react"; +import { HashRouter, Route } from "react-router-dom"; -import CreateForm from './pages/CreateForm'; -import AnswerForm from './pages/AnswerForm'; +import CreateForm from "./pages/CreateForm"; +import AnswerForm from "./pages/AnswerForm"; function App() { - return ( - <HashRouter> - <Route path="/create" component={CreateForm} /> - <Route path="/answer/:id" component={AnswerForm} /> - </HashRouter> - ); - } + return ( + <HashRouter> + <Route path="/create" component={CreateForm} /> + <Route path="/answer/:id" component={AnswerForm} /> + </HashRouter> + ); +} -export default App; \ No newline at end of file +export default App; diff --git a/src/components/fieldsAnswerForm/FormFieldRadio.js b/src/components/fieldsAnswerForm/FormFieldRadio.js index 3f18ffb..68a79e4 100644 --- a/src/components/fieldsAnswerForm/FormFieldRadio.js +++ b/src/components/fieldsAnswerForm/FormFieldRadio.js @@ -1,22 +1,21 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import Typography from '@material-ui/core/Typography'; -import Radio from '@material-ui/core/Radio'; -import RadioGroup from '@material-ui/core/RadioGroup'; - -import FieldFooterOptions from './FieldFooterOptions'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import AddCircleIcon from "@material-ui/icons/AddCircle"; +import CloseIcon from "@material-ui/icons/Close"; +import Switch from "@material-ui/core/Switch"; +import FormControlLabel from "@material-ui/core/FormControlLabel"; +import Typography from "@material-ui/core/Typography"; +import Radio from "@material-ui/core/Radio"; +import RadioGroup from "@material-ui/core/RadioGroup"; +import FieldFooterOptions from "./FieldFooterOptions"; const useStyles = makeStyles(theme => ({ paper: { @@ -26,12 +25,10 @@ const useStyles = makeStyles(theme => ({ margin: theme.spacing(2) }, questionsGrid: { - marginBottom: '20px' - }, + marginBottom: "20px" + } })); - - function FormFieldRadio(props) { const classes = useStyles(); @@ -42,13 +39,16 @@ function FormFieldRadio(props) { }; const options = props.options.map(function(x) { - return <span> - {x.value} - <Radio checked={selectedValue === x.value} - onChange={handleChange} - value={x.value} - /> - </span>; + return ( + <span> + {x.value} + <Radio + checked={selectedValue === x.value} + onChange={handleChange} + value={x.value} + /> + </span> + ); }); return ( @@ -59,19 +59,20 @@ function FormFieldRadio(props) { {props.question} </Typography> </Grid> - <Grid item container + <Grid + item + container direction="column" justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} > - <RadioGroup> - {options} - </RadioGroup> + <RadioGroup>{options}</RadioGroup> </Grid> </Grid> </Paper> ); - } -export default FormFieldRadio; \ No newline at end of file +export default FormFieldRadio; diff --git a/src/components/fieldsAnswerForm/FormFieldText.js b/src/components/fieldsAnswerForm/FormFieldText.js index a675f3a..91e2f59 100644 --- a/src/components/fieldsAnswerForm/FormFieldText.js +++ b/src/components/fieldsAnswerForm/FormFieldText.js @@ -1,13 +1,13 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Typography from '@material-ui/core/Typography'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from './FieldFooterOptions'; +import FieldFooterOptions from "./FieldFooterOptions"; const useStyles = makeStyles(theme => ({ paper: { @@ -17,8 +17,8 @@ const useStyles = makeStyles(theme => ({ margin: theme.spacing(2) }, questionsGrid: { - marginBottom: '20px' - }, + marginBottom: "20px" + } })); function FormFieldText(props) { @@ -39,17 +39,17 @@ function FormFieldText(props) { placeholder="Resposta curta" /> </Grid> - <Grid item container + <Grid + item + container direction="row" justify="flex-end" alignItems="flex-end" xs={3} - > - </Grid> + ></Grid> </Grid> </Paper> ); - } -export default FormFieldText; \ No newline at end of file +export default FormFieldText; -- GitLab From 333dc268d8835361febb1c4fada8c597623926ea Mon Sep 17 00:00:00 2001 From: Mariana Moreira <mms18@inf.ufpr.br> Date: Fri, 21 Feb 2020 11:16:45 -0300 Subject: [PATCH 26/72] Issue #12: Add footer --- src/App.js | 4 +- src/components/footer/c3sl.png | Bin 0 -> 6006 bytes src/components/footer/footer.js | 89 ++++++++++++++++++++++++++++++++ src/components/global.css | 26 ++++++++++ src/global.css | 26 ++++++++++ 5 files changed, 144 insertions(+), 1 deletion(-) create mode 100644 src/components/footer/c3sl.png create mode 100644 src/components/footer/footer.js create mode 100644 src/components/global.css create mode 100644 src/global.css diff --git a/src/App.js b/src/App.js index 6990081..2163158 100644 --- a/src/App.js +++ b/src/App.js @@ -1,14 +1,16 @@ import React from "react"; import { HashRouter, Route } from "react-router-dom"; - +import Footer from "./components/footer/footer"; import CreateForm from "./pages/CreateForm"; import AnswerForm from "./pages/AnswerForm"; +//import "./global.css"; function App() { return ( <HashRouter> <Route path="/create" component={CreateForm} /> <Route path="/answer/:id" component={AnswerForm} /> + <Footer /> </HashRouter> ); } diff --git a/src/components/footer/c3sl.png b/src/components/footer/c3sl.png new file mode 100644 index 0000000000000000000000000000000000000000..0dbfec40fed228e95ce665951d031154401e3605 GIT binary patch literal 6006 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 literal 0 HcmV?d00001 diff --git a/src/components/footer/footer.js b/src/components/footer/footer.js new file mode 100644 index 0000000..524635c --- /dev/null +++ b/src/components/footer/footer.js @@ -0,0 +1,89 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Typography from "@material-ui/core/Typography"; +import Logo from "./c3sl.png"; + +const useStyles = makeStyles(theme => ({ + footer: { + background: "#66a6c2", + position: "fixed", + left: 0, + bottom: 0, + right: 0, + width: "100%", + height: "auto" + }, + + img: { + width: "50px", + marginTop: "5px", + marginBottom: "5px", + marginLeft: "15px", + ["@media (max-width:525px)"]: { + width: "50px", + ["@media (max-width:338px)"]: { + marginTop: "3%" + } + }, + ["@media (max-height:681px)"]: { + width: "65px" + } + }, + + item: { + marginTop: "5px", + marginBottom: "5px", + display: "flex", + justifyContent: "space-evenly", + flexDirection: "column" + }, + + text: { + color: "#46525d", + fontSize: "15px", + textAlign: "center" + }, + + adress: { + color: "#46525d", + fontSize: "12px", + textAlign: "right", + marginRight: "15px" + } +})); + +function Footer() { + const classes = useStyles(); + return ( + <Grid container className={classes.footer}> + <Grid item xs={2} className={classes.item}> + <img src={Logo} className={classes.img}></img> + </Grid> + + <Grid item xs={8} className={classes.item}> + <Typography className={classes.text}> + Ministério da + <b> + <br /> + Ciência, Tecnologia, + <br /> + Inovações e Comunicações + </b> + </Typography> + </Grid> + + <Grid item xs={2} className={classes.item}> + <Typography className={classes.adress}> + Esplanada dos Ministérios, Bloco R + <br /> + CEP: 70044-900 – BrasÃlia-DF + <br /> + Telefone: 61 2027-6000 + </Typography> + </Grid> + </Grid> + ); +} + +export default Footer; diff --git a/src/components/global.css b/src/components/global.css new file mode 100644 index 0000000..deeb81c --- /dev/null +++ b/src/components/global.css @@ -0,0 +1,26 @@ +@import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap"); + +* { + margin: 0; + padding: 0; + outline: 0; + box-sizing: border-box; + background: "#05a5dd"; +} + +html, +body, +#root { + height: 100%; +} + +body { + background: #eceff3; + -webkit-font-smoothing: antialiased; +} + +body, +input, +button { + font-family: Roboto, sans-serif; +} diff --git a/src/global.css b/src/global.css new file mode 100644 index 0000000..879e608 --- /dev/null +++ b/src/global.css @@ -0,0 +1,26 @@ +@import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap"); + +* { + margin: 0; + padding: 0; + outline: 0; + box-sizing: border-box; + color: #667079; +} + +html, +body, +#root { + height: 100%; +} + +body { + background: #eceff3; + -webkit-font-smoothing: antialiased; +} + +body, +input, +button { + font-family: Roboto, sans-serif; +} -- GitLab From 49362a8e3befa504f4945b298302939cf03d1a94 Mon Sep 17 00:00:00 2001 From: Gabriel_S <gash18@inf.ufpr.br> Date: Tue, 3 Mar 2020 10:13:18 -0300 Subject: [PATCH 27/72] Issue #11: Criar header Signed-off-by: Gabriel_S <gash18@inf.ufpr.br> --- src/App.js | 6 +- src/components/header/header.jsx | 161 ++++++++++++++++++ .../header/header_components/MenuList.jsx | 130 ++++++++++++++ .../header/header_imgs/imgsimmc-01.png | Bin 0 -> 217087 bytes src/components/header/header_imgs/user.png | Bin 0 -> 7094 bytes 5 files changed, 295 insertions(+), 2 deletions(-) create mode 100644 src/components/header/header.jsx create mode 100644 src/components/header/header_components/MenuList.jsx create mode 100644 src/components/header/header_imgs/imgsimmc-01.png create mode 100644 src/components/header/header_imgs/user.png diff --git a/src/App.js b/src/App.js index 04d5982..c84cf5e 100644 --- a/src/App.js +++ b/src/App.js @@ -1,13 +1,15 @@ import React from "react"; import { HashRouter, Route } from "react-router-dom"; -import Footer from "./components/footer/footer"; +import "./global.css"; import CreateForm from "./pages/CreateForm"; import AnswerForm from "./pages/AnswerForm"; -//import "./global.css"; +import Header from "./components/header/header"; +import Footer from "./components/footer/footer"; function App() { return ( <HashRouter> + <Header /> <Route path="/create" component={CreateForm} /> <Route path="/answer/:id" component={AnswerForm} /> </HashRouter> diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx new file mode 100644 index 0000000..1ffafe7 --- /dev/null +++ b/src/components/header/header.jsx @@ -0,0 +1,161 @@ +import React from "react"; +import Grid from "@material-ui/core/Grid"; +import logo from "./header_imgs/imgsimmc-01.png"; +import { makeStyles } from "@material-ui/core"; +import MenuListComposition from "./header_components/MenuList"; +import { Avatar } from "@material-ui/core"; + +import MenuItem from "@material-ui/core/MenuItem"; +import MenuList from "@material-ui/core/MenuList"; +import Button from "@material-ui/core/Button"; +import Popper from "@material-ui/core/Popper"; +import Grow from "@material-ui/core/Grow"; +import Paper from "@material-ui/core/Paper"; +import ClickAwayListener from "@material-ui/core/ClickAwayListener"; + +const useStyles = makeStyles(theme => ({ + barraBrasil: { + background: "#7F7F7F", + height: "20px", + padding: "0 0 0 10px", + display: "block" + }, + menuBarraTemp: { + listStyle: "none" + }, + menuBarraTempInterno: { + display: "inline", + float: "left", + paddingRight: "10px", + marginRight: "10px", + borderRight: "1px solid #EDEDED" + }, + header: { + background: "#05a5dd", + width: "auto", + display: "flex", + flexDirection: "column", + justifyContent: "center", + height: "13%" + }, + simmc: { + marginTop: "5%", + fontSize: "15px", + color: "#ffffff", + marginLeft: "2%", + ["@media (max-width:1040px)"]: { + display: "none" + }, + ["@media (max-height:681px)"]: { + display: "none" + } + }, + form_creator: { + color: "#ffffff", + marginTop: "10%", + ["@media (max-width:599px)"]: { + fontSize: "21px", + ["@media (max-width:525px)"]: { + marginTop: "5%", + marginLeft: "10%" + }, + ["@media (max-width:337px)"]: { + fontSize: "19px" + } + }, + ["@media (max-height:681px)"]: { + marginTop: "5%" + } + }, + link: { + textDecoration: "none" + }, + logo: { + marginLeft: "2.5%", + marginTop: "4%", + width: "85px", + ["@media (max-width:525px)"]: { + width: "65px", + ["@media (max-width:338px)"]: { + marginTop: "3%" + } + }, + ["@media (max-height:681px)"]: { + width: "65px" + } + }, + userImgContainer: { + display: "flex", + flexDirection: "column" + } +})); + +export default function Header() { + const classes = useStyles(); + + return ( + <Grid> + <header className={classes.header} alignItems="center "> + <Grid container item> + <Grid container item xs={3} sm={3} md={4}> + <a + href="https://simmc.c3sl.ufpr.br/" + title="Ir para a página inicial do SIMMC" + > + <img + src={logo} + alt="logo" + href="localhost3000/#/signup" + className={classes.logo} + maxWidth="100px" + /> + </a> + <Grid + container + item + xs={5} + sm={6} + md={7} + alignContent="flexstart" + alignItems="start" + > + <a + href="https://simmc.c3sl.ufpr.br/" + title="Ir para a página inicial do SIMMC" + className={classes.link} + > + <h2 className={classes.simmc}> + Sistema Integrado de Monitoramento do Ministério da Ciência, + Tecnologia, Inovações e Comunicações + </h2> + </a> + </Grid> + </Grid> + <Grid container item xs={6} sm={6} md={4} justify="center"> + <a + href="https://google.com.br" + title="Ir para a página inicial do Gerenciador de Formulários" + className={classes.link} + > + <h2 className={classes.form_creator}> + Gerenciador de Formulários + </h2> + </a> + </Grid> + <Grid + container + item + xs={3} + sm={3} + md={4} + className={classes.userImgContainer} + justify="center" + alignContent="flex-end" + > + <MenuListComposition /> + </Grid> + </Grid> + </header> + </Grid> + ); +} diff --git a/src/components/header/header_components/MenuList.jsx b/src/components/header/header_components/MenuList.jsx new file mode 100644 index 0000000..7c8613e --- /dev/null +++ b/src/components/header/header_components/MenuList.jsx @@ -0,0 +1,130 @@ +import React from "react"; +import Button from "@material-ui/core/Button"; +import ClickAwayListener from "@material-ui/core/ClickAwayListener"; +import Grow from "@material-ui/core/Grow"; +import Paper from "@material-ui/core/Paper"; +import Popper from "@material-ui/core/Popper"; +import MenuItem from "@material-ui/core/MenuItem"; +import MenuList from "@material-ui/core/MenuList"; +import { makeStyles } from "@material-ui/core/styles"; +import UserImg from "./../header_imgs/user.png"; + +import { Avatar } from "@material-ui/core"; + +const useStyles = makeStyles(theme => ({ + menuPopUp: { + alignContent: "start", + ["@media (max-width:346px)"]: { + width: "23%" + } + }, + menuPopUpText: { + ["@media (max-width:525px)"]: { + fontSize: "13px" + } + }, + popUpPaper: { + marginRight: "14%", + ["@media (max-width:525px)"]: { + marginRight: "0" + } + }, + menuList: { + alignItems: "flex-start" + } +})); + +/** + * Para fazer com que o componente não apareça em telas em que o usuário não está logado, basta fazer uma função de verificação para tal e retornar o componente, + * caso logado, ou NULL, caso não-logado. + */ + +function MenuListComposition(props) { + const [open, setOpen] = React.useState(false); + + const prevOpen = React.useRef(open); + + const anchorRef = React.useRef(null); + const handleToggle = () => { + setOpen(prevOpen => !prevOpen); + }; + const handleClose = event => { + if (anchorRef.current && anchorRef.current.contains(event.target)) { + return; + } + setOpen(false); + }; + function handleListKeyDown(event) { + if (event.key === "Tab") { + event.preventDefault(); + setOpen(false); + } + } + React.useEffect(() => { + if (prevOpen.current === true && open === false) { + anchorRef.current.focus(); + } + + prevOpen.current = open; + }, [open]); + + const classes = useStyles(); + + return ( + <div> + <Button + ref={anchorRef} + aria-controls={open ? "menu-list-grow" : undefined} + aria-haspopup="true" + onClick={handleToggle} + > + <Avatar alt="user_avatar" src={UserImg} className={classes.userImg} />{" "} + </Button> + <Popper + open={open} + anchorEl={anchorRef.current} + role={undefined} + transition + disablePortal + className={classes.menuPopUp} + > + {({ TransitionProps, placement }) => ( + <Grow + {...TransitionProps} + style={{ + transformOrigin: + placement === "bottom" ? "center top" : "center bottom" + }} + > + <Paper className={classes.popUpPaper}> + <ClickAwayListener onClickAway={handleClose}> + <MenuList + className={classes.menuList} + autoFocusItem={open} + id="menu-list-grow" + onKeyDown={handleListKeyDown} + alignContent="flex-start" + > + <MenuItem + onClick={handleClose} + className={classes.menuPopUpText} + > + Perfil + </MenuItem> + <MenuItem + onClick={handleClose} + className={classes.menuPopUpText} + > + Logout + </MenuItem> + </MenuList> + </ClickAwayListener> + </Paper> + </Grow> + )} + </Popper> + </div> + ); +} + +export default MenuListComposition; diff --git a/src/components/header/header_imgs/imgsimmc-01.png b/src/components/header/header_imgs/imgsimmc-01.png new file mode 100644 index 0000000000000000000000000000000000000000..c549ed8b629749b0ca98d74230f7b1edf7928a15 GIT binary patch literal 217087 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%0AwY$M!oHzSaLp3+2vjnC7jI*#PIzE8YsVZ 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�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Ⓢ+!p`{Dva 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 V3ydWK@dW{2>dHDw^$IqT{}18$!(0FW literal 0 HcmV?d00001 diff --git a/src/components/header/header_imgs/user.png b/src/components/header/header_imgs/user.png new file mode 100644 index 0000000000000000000000000000000000000000..35fcbb89031acbae1c31fec417d35580fab07218 GIT binary patch literal 7094 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 U+3V^&pb=oCZ>CqF<8uFh0Ld|^00000 literal 0 HcmV?d00001 -- GitLab From 7fad321db7e6115165d383effabb9428f62de7e7 Mon Sep 17 00:00:00 2001 From: Gabriel_S <gash18@inf.ufpr.br> Date: Fri, 7 Feb 2020 09:07:17 -0300 Subject: [PATCH 28/72] Issue #3: Create SignUp Screen Signed-off-by: Gabriel_S <gash18@inf.ufpr.br> --- .gitignore | 2 +- build/asset-manifest.json | 22 ++ build/favicon.ico | Bin 0 -> 3870 bytes build/index.html | 1 + build/logo192.png | Bin 0 -> 5347 bytes build/logo512.png | Bin 0 -> 9664 bytes build/manifest.json | 25 ++ ...nifest.4e6796295cf8cef3d8c75de5ce61be3e.js | 26 ++ build/robots.txt | 2 + build/service-worker.js | 39 +++ build/static/css/main.5ecd60fb.chunk.css | 2 + build/static/css/main.5ecd60fb.chunk.css.map | 1 + build/static/js/2.6a72c269.chunk.js | 3 + build/static/js/2.6a72c269.chunk.js.LICENSE | 49 ++++ build/static/js/2.6a72c269.chunk.js.map | 1 + build/static/js/main.928fa077.chunk.js | 2 + build/static/js/main.928fa077.chunk.js.map | 1 + build/static/js/runtime-main.889ad4b6.js | 2 + build/static/js/runtime-main.889ad4b6.js.map | 1 + package-lock.json | 161 +++++++++++- package.json | 2 + src/App.js | 2 + src/api.jsx | 8 + src/components/fieldsSignUp/FormInput.jsx | 28 ++ src/components/header/header.jsx | 27 +- .../header/header_components/MenuList.jsx | 4 +- src/components/header/logo/imgsimmc-01.png | Bin 0 -> 217087 bytes src/global.css | 5 +- src/index.js | 14 +- src/pages/SignUp.js | 240 ++++++++++++++++++ src/pages/teste.css | 0 31 files changed, 625 insertions(+), 45 deletions(-) create mode 100644 build/asset-manifest.json create mode 100644 build/favicon.ico create mode 100644 build/index.html create mode 100644 build/logo192.png create mode 100644 build/logo512.png create mode 100644 build/manifest.json create mode 100644 build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js create mode 100644 build/robots.txt create mode 100644 build/service-worker.js create mode 100644 build/static/css/main.5ecd60fb.chunk.css create mode 100644 build/static/css/main.5ecd60fb.chunk.css.map create mode 100644 build/static/js/2.6a72c269.chunk.js create mode 100644 build/static/js/2.6a72c269.chunk.js.LICENSE create mode 100644 build/static/js/2.6a72c269.chunk.js.map create mode 100644 build/static/js/main.928fa077.chunk.js create mode 100644 build/static/js/main.928fa077.chunk.js.map create mode 100644 build/static/js/runtime-main.889ad4b6.js create mode 100644 build/static/js/runtime-main.889ad4b6.js.map create mode 100644 src/api.jsx create mode 100644 src/components/fieldsSignUp/FormInput.jsx create mode 100644 src/components/header/logo/imgsimmc-01.png create mode 100644 src/pages/SignUp.js create mode 100644 src/pages/teste.css diff --git a/.gitignore b/.gitignore index c2658d7..40b878d 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1 @@ -node_modules/ +node_modules/ \ No newline at end of file diff --git a/build/asset-manifest.json b/build/asset-manifest.json new file mode 100644 index 0000000..c588fd2 --- /dev/null +++ b/build/asset-manifest.json @@ -0,0 +1,22 @@ +{ + "files": { + "main.css": "/static/css/main.5ecd60fb.chunk.css", + "main.js": "/static/js/main.928fa077.chunk.js", + "main.js.map": "/static/js/main.928fa077.chunk.js.map", + "runtime-main.js": "/static/js/runtime-main.889ad4b6.js", + "runtime-main.js.map": "/static/js/runtime-main.889ad4b6.js.map", + "static/js/2.6a72c269.chunk.js": "/static/js/2.6a72c269.chunk.js", + "static/js/2.6a72c269.chunk.js.map": "/static/js/2.6a72c269.chunk.js.map", + "index.html": "/index.html", + "precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js": "/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js", + "service-worker.js": "/service-worker.js", + "static/css/main.5ecd60fb.chunk.css.map": "/static/css/main.5ecd60fb.chunk.css.map", + "static/js/2.6a72c269.chunk.js.LICENSE": "/static/js/2.6a72c269.chunk.js.LICENSE" + }, + "entrypoints": [ + "static/js/runtime-main.889ad4b6.js", + "static/js/2.6a72c269.chunk.js", + "static/css/main.5ecd60fb.chunk.css", + "static/js/main.928fa077.chunk.js" + ] +} \ No newline at end of file diff --git a/build/favicon.ico b/build/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..a11777cc471a4344702741ab1c8a588998b1311a GIT binary patch literal 3870 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 baj7?x%VD!5Cxk2YbYLNVeiXvvpMCWYo=by@ literal 0 HcmV?d00001 diff --git a/build/index.html b/build/index.html new file mode 100644 index 0000000..54fd1fa --- /dev/null +++ b/build/index.html @@ -0,0 +1 @@ +<!doctype html><html lang="en"><head><meta charset="utf-8"/><link rel="icon" href="/favicon.ico"/><meta name="viewport" content="width=device-width,initial-scale=1"/><meta name="theme-color" content="#000000"/><meta name="description" content="Web site created using create-react-app"/><link rel="apple-touch-icon" href="/logo192.png"/><link rel="manifest" href="/manifest.json"/><title>React App</title><link href="/static/css/main.5ecd60fb.chunk.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div><script>!function(a){function e(e){for(var r,t,n=e[0],o=e[1],u=e[2],p=0,l=[];p<n.length;p++)t=n[p],Object.prototype.hasOwnProperty.call(i,t)&&i[t]&&l.push(i[t][0]),i[t]=0;for(r in o)Object.prototype.hasOwnProperty.call(o,r)&&(a[r]=o[r]);for(s&&s(e);l.length;)l.shift()();return c.push.apply(c,u||[]),f()}function f(){for(var e,r=0;r<c.length;r++){for(var t=c[r],n=!0,o=1;o<t.length;o++){var u=t[o];0!==i[u]&&(n=!1)}n&&(c.splice(r--,1),e=p(p.s=t[0]))}return e}var t={},i={1:0},c=[];function p(e){if(t[e])return t[e].exports;var r=t[e]={i:e,l:!1,exports:{}};return a[e].call(r.exports,r,r.exports,p),r.l=!0,r.exports}p.m=a,p.c=t,p.d=function(e,r,t){p.o(e,r)||Object.defineProperty(e,r,{enumerable:!0,get:t})},p.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},p.t=function(r,e){if(1&e&&(r=p(r)),8&e)return r;if(4&e&&"object"==typeof r&&r&&r.__esModule)return r;var t=Object.create(null);if(p.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:r}),2&e&&"string"!=typeof r)for(var n in r)p.d(t,n,function(e){return r[e]}.bind(null,n));return t},p.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return p.d(r,"a",r),r},p.o=function(e,r){return Object.prototype.hasOwnProperty.call(e,r)},p.p="/";var r=this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[],n=r.push.bind(r);r.push=e,r=r.slice();for(var o=0;o<r.length;o++)e(r[o]);var s=n;f()}([])</script><script src="/static/js/2.6a72c269.chunk.js"></script><script src="/static/js/main.928fa077.chunk.js"></script></body></html> \ No newline at end of file diff --git a/build/logo192.png b/build/logo192.png new file mode 100644 index 0000000000000000000000000000000000000000..fc44b0a3796c0e0a64c3d858ca038bd4570465d9 GIT binary patch literal 5347 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 X@eDJUQo;Ye2mwlRs<JiGX2Jghdw)}T literal 0 HcmV?d00001 diff --git a/build/logo512.png b/build/logo512.png new file mode 100644 index 0000000000000000000000000000000000000000..a4e47a6545bc15971f8f63fba70e4013df88a664 GIT binary patch literal 9664 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 b{|{}U^kRn2wo}j7|0ATu<;8xA7zX}7|B6mN literal 0 HcmV?d00001 diff --git a/build/manifest.json b/build/manifest.json new file mode 100644 index 0000000..080d6c7 --- /dev/null +++ b/build/manifest.json @@ -0,0 +1,25 @@ +{ + "short_name": "React App", + "name": "Create React App Sample", + "icons": [ + { + "src": "favicon.ico", + "sizes": "64x64 32x32 24x24 16x16", + "type": "image/x-icon" + }, + { + "src": "logo192.png", + "type": "image/png", + "sizes": "192x192" + }, + { + "src": "logo512.png", + "type": "image/png", + "sizes": "512x512" + } + ], + "start_url": ".", + "display": "standalone", + "theme_color": "#000000", + "background_color": "#ffffff" +} diff --git a/build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js b/build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js new file mode 100644 index 0000000..e1c039a --- /dev/null +++ b/build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js @@ -0,0 +1,26 @@ +self.__precacheManifest = (self.__precacheManifest || []).concat([ + { + "revision": "f40581dfdfeab5d31ffe77d8b69c70dd", + "url": "/index.html" + }, + { + "revision": "f1eb2669e963bc86acde", + "url": "/static/css/main.5ecd60fb.chunk.css" + }, + { + "revision": "cb64c341987a0716d9ea", + "url": "/static/js/2.6a72c269.chunk.js" + }, + { + "revision": "b51e62edbcf7a9c4f4ad13f506021d3e", + "url": "/static/js/2.6a72c269.chunk.js.LICENSE" + }, + { + "revision": "f1eb2669e963bc86acde", + "url": "/static/js/main.928fa077.chunk.js" + }, + { + "revision": "696942293a92ac3a2bb6", + "url": "/static/js/runtime-main.889ad4b6.js" + } +]); \ No newline at end of file diff --git a/build/robots.txt b/build/robots.txt new file mode 100644 index 0000000..01b0f9a --- /dev/null +++ b/build/robots.txt @@ -0,0 +1,2 @@ +# https://www.robotstxt.org/robotstxt.html +User-agent: * diff --git a/build/service-worker.js b/build/service-worker.js new file mode 100644 index 0000000..ef97193 --- /dev/null +++ b/build/service-worker.js @@ -0,0 +1,39 @@ +/** + * Welcome to your Workbox-powered service worker! + * + * You'll need to register this file in your web app and you should + * disable HTTP caching for this file too. + * See https://goo.gl/nhQhGp + * + * The rest of the code is auto-generated. Please don't update this file + * directly; instead, make changes to your Workbox build configuration + * and re-run your build process. + * See https://goo.gl/2aRDsh + */ + +importScripts("https://storage.googleapis.com/workbox-cdn/releases/4.3.1/workbox-sw.js"); + +importScripts( + "/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js" +); + +self.addEventListener('message', (event) => { + if (event.data && event.data.type === 'SKIP_WAITING') { + self.skipWaiting(); + } +}); + +workbox.core.clientsClaim(); + +/** + * The workboxSW.precacheAndRoute() method efficiently caches and responds to + * requests for URLs in the manifest. + * See https://goo.gl/S9QRab + */ +self.__precacheManifest = [].concat(self.__precacheManifest || []); +workbox.precaching.precacheAndRoute(self.__precacheManifest, {}); + +workbox.routing.registerNavigationRoute(workbox.precaching.getCacheKeyForURL("/index.html"), { + + blacklist: [/^\/_/,/\/[^/?]+\.[^/]+$/], +}); diff --git a/build/static/css/main.5ecd60fb.chunk.css b/build/static/css/main.5ecd60fb.chunk.css new file mode 100644 index 0000000..5418557 --- /dev/null +++ b/build/static/css/main.5ecd60fb.chunk.css @@ -0,0 +1,2 @@ +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} +/*# sourceMappingURL=main.5ecd60fb.chunk.css.map */ \ No newline at end of file diff --git a/build/static/css/main.5ecd60fb.chunk.css.map b/build/static/css/main.5ecd60fb.chunk.css.map new file mode 100644 index 0000000..ab2a007 --- /dev/null +++ b/build/static/css/main.5ecd60fb.chunk.css.map @@ -0,0 +1 @@ +{"version":3,"sources":["index.css"],"names":[],"mappings":"AAAA,KACE,QAAS,CACT,mIAEY,CACZ,kCAAmC,CACnC,iCACF,CAEA,KACE,uEAEF","file":"main.5ecd60fb.chunk.css","sourcesContent":["body {\n margin: 0;\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen',\n 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',\n sans-serif;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\ncode {\n font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',\n monospace;\n}\n"]} \ No newline at end of file diff --git a/build/static/js/2.6a72c269.chunk.js b/build/static/js/2.6a72c269.chunk.js new file mode 100644 index 0000000..6224c5e --- /dev/null +++ b/build/static/js/2.6a72c269.chunk.js @@ -0,0 +1,3 @@ +/*! For license information please see 2.6a72c269.chunk.js.LICENSE */ +(this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[]).push([[2],[function(e,t,n){"use strict";e.exports=n(102)},function(e,t,n){"use strict";function r(){return(r=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e}).apply(this,arguments)}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";n.d(t,"a",(function(){return o}));var r=n(15);function o(e,t){if(null==e)return{};var n,o,a=Object(r.a)(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(o=0;o<i.length;o++)n=i[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}},function(e,t,n){"use strict";function r(e){var t,n,o="";if(e)if("object"===typeof e)if(e.push)for(t=0;t<e.length;t++)e[t]&&(n=r(e[t]))&&(o&&(o+=" "),o+=n);else for(t in e)e[t]&&(n=r(t))&&(o&&(o+=" "),o+=n);else"boolean"===typeof e||e.call||(o&&(o+=" "),o+=e);return o}t.a=function(){for(var e,t=0,n="";t<arguments.length;)(e=r(arguments[t++]))&&(n&&(n+=" "),n+=e);return n}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(86)),u=n.n(l),c=n(133),s=n(163),d=n(93),f=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return function(n){var a=t.defaultTheme,l=t.withTheme,f=void 0!==l&&l,p=t.name,h=Object(o.a)(t,["defaultTheme","withTheme","name"]);var m=p,v=Object(c.a)(e,Object(r.a)({defaultTheme:a,Component:n,name:p||n.displayName,classNamePrefix:m},h)),b=i.a.forwardRef((function(e,t){e.classes;var l,u=e.innerRef,c=Object(o.a)(e,["classes","innerRef"]),h=v(e),m=c;return("string"===typeof p||f)&&(l=Object(d.a)()||a,p&&(m=Object(s.a)({theme:l,name:p,props:c})),f&&!m.theme&&(m.theme=l)),i.a.createElement(n,Object(r.a)({ref:u||t,classes:h},m))}));return b.defaultProps=n.defaultProps,u()(b,n),b}},p=n(45);t.a=function(e,t){return f(e,Object(r.a)({defaultTheme:p.a},t))}},function(e,t,n){e.exports=n(124)()},function(e,t,n){"use strict";function r(e){return e.charAt(0).toUpperCase()+e.slice(1)}n.d(t,"a",(function(){return r}))},,function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a=n(35);function i(e,t){return o.a.useMemo((function(){return null==e&&null==t?null:function(n){Object(a.a)(e,n),Object(a.a)(t,n)}}),[e,t])}},function(e,t,n){"use strict";!function e(){if("undefined"!==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__&&"function"===typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE){0;try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(e)}catch(t){console.error(t)}}}(),e.exports=n(103)},function(e,t,n){"use strict";function r(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;return Math.min(Math.max(t,e),n)}function o(e){if(e.type)return e;if("#"===e.charAt(0))return o(function(e){e=e.substr(1);var t=new RegExp(".{1,".concat(e.length/3,"}"),"g"),n=e.match(t);return n&&1===n[0].length&&(n=n.map((function(e){return e+e}))),n?"rgb(".concat(n.map((function(e){return parseInt(e,16)})).join(", "),")"):""}(e));var t=e.indexOf("("),n=e.substring(0,t);if(-1===["rgb","rgba","hsl","hsla"].indexOf(n))throw new Error(["Material-UI: unsupported `".concat(e,"` color."),"We support the following formats: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()."].join("\n"));var r=e.substring(t+1,e.length-1).split(",");return{type:n,values:r=r.map((function(e){return parseFloat(e)}))}}function a(e){var t=e.type,n=e.values;return-1!==t.indexOf("rgb")?n=n.map((function(e,t){return t<3?parseInt(e,10):e})):-1!==t.indexOf("hsl")&&(n[1]="".concat(n[1],"%"),n[2]="".concat(n[2],"%")),"".concat(t,"(").concat(n.join(", "),")")}function i(e,t){var n=l(e),r=l(t);return(Math.max(n,r)+.05)/(Math.min(n,r)+.05)}function l(e){var t="hsl"===(e=o(e)).type?o(function(e){var t=(e=o(e)).values,n=t[0],r=t[1]/100,i=t[2]/100,l=r*Math.min(i,1-i),u=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:(e+n/30)%12;return i-l*Math.max(Math.min(t-3,9-t,1),-1)},c="rgb",s=[Math.round(255*u(0)),Math.round(255*u(8)),Math.round(255*u(4))];return"hsla"===e.type&&(c+="a",s.push(t[3])),a({type:c,values:s})}(e)).values:e.values;return t=t.map((function(e){return(e/=255)<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4)})),Number((.2126*t[0]+.7152*t[1]+.0722*t[2]).toFixed(3))}function u(e,t){return e=o(e),t=r(t),"rgb"!==e.type&&"hsl"!==e.type||(e.type+="a"),e.values[3]=t,a(e)}function c(e,t){if(e=o(e),t=r(t),-1!==e.type.indexOf("hsl"))e.values[2]*=1-t;else if(-1!==e.type.indexOf("rgb"))for(var n=0;n<3;n+=1)e.values[n]*=1-t;return a(e)}function s(e,t){if(e=o(e),t=r(t),-1!==e.type.indexOf("hsl"))e.values[2]+=(100-e.values[2])*t;else if(-1!==e.type.indexOf("rgb"))for(var n=0;n<3;n+=1)e.values[n]+=(255-e.values[n])*t;return a(e)}n.d(t,"c",(function(){return i})),n.d(t,"b",(function(){return u})),n.d(t,"a",(function(){return c})),n.d(t,"d",(function(){return s}))},function(e,t,n){"use strict";var r=n(83);function o(e){return function(e){if(Array.isArray(e)){for(var t=0,n=new Array(e.length);t<e.length;t++)n[t]=e[t];return n}}(e)||Object(r.a)(e)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance")}()}n.d(t,"a",(function(){return o}))},function(e,t,n){"use strict";function r(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}n.d(t,"a",(function(){return r}))},,,function(e,t,n){"use strict";function r(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r<a.length;r++)n=a[r],t.indexOf(n)>=0||(o[n]=e[n]);return o}n.d(t,"a",(function(){return r}))},,,,function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M16 9v10H8V9h8m-1.5-6h-5l-1 1H5v2h14V4h-3.5l-1-1zM18 7H6v12c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7z"}),"DeleteOutlined");t.default=a},function(e,t,n){"use strict";function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(74),o=Object.prototype.toString;function a(e){return"[object Array]"===o.call(e)}function i(e){return"undefined"===typeof e}function l(e){return null!==e&&"object"===typeof e}function u(e){return"[object Function]"===o.call(e)}function c(e,t){if(null!==e&&"undefined"!==typeof e)if("object"!==typeof e&&(e=[e]),a(e))for(var n=0,r=e.length;n<r;n++)t.call(null,e[n],n,e);else for(var o in e)Object.prototype.hasOwnProperty.call(e,o)&&t.call(null,e[o],o,e)}e.exports={isArray:a,isArrayBuffer:function(e){return"[object ArrayBuffer]"===o.call(e)},isBuffer:function(e){return null!==e&&!i(e)&&null!==e.constructor&&!i(e.constructor)&&"function"===typeof e.constructor.isBuffer&&e.constructor.isBuffer(e)},isFormData:function(e){return"undefined"!==typeof FormData&&e instanceof FormData},isArrayBufferView:function(e){return"undefined"!==typeof ArrayBuffer&&ArrayBuffer.isView?ArrayBuffer.isView(e):e&&e.buffer&&e.buffer instanceof ArrayBuffer},isString:function(e){return"string"===typeof e},isNumber:function(e){return"number"===typeof e},isObject:l,isUndefined:i,isDate:function(e){return"[object Date]"===o.call(e)},isFile:function(e){return"[object File]"===o.call(e)},isBlob:function(e){return"[object Blob]"===o.call(e)},isFunction:u,isStream:function(e){return l(e)&&u(e.pipe)},isURLSearchParams:function(e){return"undefined"!==typeof URLSearchParams&&e instanceof URLSearchParams},isStandardBrowserEnv:function(){return("undefined"===typeof navigator||"ReactNative"!==navigator.product&&"NativeScript"!==navigator.product&&"NS"!==navigator.product)&&("undefined"!==typeof window&&"undefined"!==typeof document)},forEach:c,merge:function e(){var t={};function n(n,r){"object"===typeof t[r]&&"object"===typeof n?t[r]=e(t[r],n):t[r]=n}for(var r=0,o=arguments.length;r<o;r++)c(arguments[r],n);return t},deepMerge:function e(){var t={};function n(n,r){"object"===typeof t[r]&&"object"===typeof n?t[r]=e(t[r],n):t[r]="object"===typeof n?e({},n):n}for(var r=0,o=arguments.length;r<o;r++)c(arguments[r],n);return t},extend:function(e,t,n){return c(t,(function(t,o){e[o]=n&&"function"===typeof t?r(t,n):t})),e},trim:function(e){return e.replace(/^\s*/,"").replace(/\s*$/,"")}}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a=n(40);function i(){return o.a.useContext(a.a)}},function(e,t,n){"use strict";t.a=function(e,t){if(!e)throw new Error("Invariant failed")}},function(e,t,n){"use strict";function r(e){var t=e.props,n=e.states,r=e.muiFormControl;return n.reduce((function(e,n){return e[n]=t[n],r&&"undefined"===typeof t[n]&&(e[n]=r[n]),e}),{})}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";n.d(t,"a",(function(){return l}));var r=n(1),o=n(0),a=n.n(o),i=n(60);function l(e,t){var n=a.a.memo(a.a.forwardRef((function(t,n){return a.a.createElement(i.a,Object(r.a)({},t,{ref:n}),e)})));return n.muiName=i.a.muiName,n}},function(e,t,n){"use strict";var r=n(1);function o(e){return"/"===e.charAt(0)}function a(e,t){for(var n=t,r=n+1,o=e.length;r<o;n+=1,r+=1)e[n]=e[r];e.pop()}var i=function(e,t){void 0===t&&(t="");var n,r=e&&e.split("/")||[],i=t&&t.split("/")||[],l=e&&o(e),u=t&&o(t),c=l||u;if(e&&o(e)?i=r:r.length&&(i.pop(),i=i.concat(r)),!i.length)return"/";if(i.length){var s=i[i.length-1];n="."===s||".."===s||""===s}else n=!1;for(var d=0,f=i.length;f>=0;f--){var p=i[f];"."===p?a(i,f):".."===p?(a(i,f),d++):d&&(a(i,f),d--)}if(!c)for(;d--;d)i.unshift("..");!c||""===i[0]||i[0]&&o(i[0])||i.unshift("");var h=i.join("/");return n&&"/"!==h.substr(-1)&&(h+="/"),h};function l(e){return e.valueOf?e.valueOf():Object.prototype.valueOf.call(e)}var u=function e(t,n){if(t===n)return!0;if(null==t||null==n)return!1;if(Array.isArray(t))return Array.isArray(n)&&t.length===n.length&&t.every((function(t,r){return e(t,n[r])}));if("object"===typeof t||"object"===typeof n){var r=l(t),o=l(n);return r!==t||o!==n?e(r,o):Object.keys(Object.assign({},t,n)).every((function(r){return e(t[r],n[r])}))}return!1},c=n(23);function s(e){return"/"===e.charAt(0)?e:"/"+e}function d(e){return"/"===e.charAt(0)?e.substr(1):e}function f(e,t){return function(e,t){return 0===e.toLowerCase().indexOf(t.toLowerCase())&&-1!=="/?#".indexOf(e.charAt(t.length))}(e,t)?e.substr(t.length):e}function p(e){return"/"===e.charAt(e.length-1)?e.slice(0,-1):e}function h(e){var t=e.pathname,n=e.search,r=e.hash,o=t||"/";return n&&"?"!==n&&(o+="?"===n.charAt(0)?n:"?"+n),r&&"#"!==r&&(o+="#"===r.charAt(0)?r:"#"+r),o}function m(e,t,n,o){var a;"string"===typeof e?(a=function(e){var t=e||"/",n="",r="",o=t.indexOf("#");-1!==o&&(r=t.substr(o),t=t.substr(0,o));var a=t.indexOf("?");return-1!==a&&(n=t.substr(a),t=t.substr(0,a)),{pathname:t,search:"?"===n?"":n,hash:"#"===r?"":r}}(e)).state=t:(void 0===(a=Object(r.a)({},e)).pathname&&(a.pathname=""),a.search?"?"!==a.search.charAt(0)&&(a.search="?"+a.search):a.search="",a.hash?"#"!==a.hash.charAt(0)&&(a.hash="#"+a.hash):a.hash="",void 0!==t&&void 0===a.state&&(a.state=t));try{a.pathname=decodeURI(a.pathname)}catch(l){throw l instanceof URIError?new URIError('Pathname "'+a.pathname+'" could not be decoded. This is likely caused by an invalid percent-encoding.'):l}return n&&(a.key=n),o?a.pathname?"/"!==a.pathname.charAt(0)&&(a.pathname=i(a.pathname,o.pathname)):a.pathname=o.pathname:a.pathname||(a.pathname="/"),a}function v(e,t){return e.pathname===t.pathname&&e.search===t.search&&e.hash===t.hash&&e.key===t.key&&u(e.state,t.state)}function b(){var e=null;var t=[];return{setPrompt:function(t){return e=t,function(){e===t&&(e=null)}},confirmTransitionTo:function(t,n,r,o){if(null!=e){var a="function"===typeof e?e(t,n):e;"string"===typeof a?"function"===typeof r?r(a,o):o(!0):o(!1!==a)}else o(!0)},appendListener:function(e){var n=!0;function r(){n&&e.apply(void 0,arguments)}return t.push(r),function(){n=!1,t=t.filter((function(e){return e!==r}))}},notifyListeners:function(){for(var e=arguments.length,n=new Array(e),r=0;r<e;r++)n[r]=arguments[r];t.forEach((function(e){return e.apply(void 0,n)}))}}}n.d(t,"a",(function(){return w})),n.d(t,"b",(function(){return C})),n.d(t,"d",(function(){return j})),n.d(t,"c",(function(){return m})),n.d(t,"f",(function(){return v})),n.d(t,"e",(function(){return h}));var y=!("undefined"===typeof window||!window.document||!window.document.createElement);function g(e,t){t(window.confirm(e))}function x(){try{return window.history.state||{}}catch(e){return{}}}function w(e){void 0===e&&(e={}),y||Object(c.a)(!1);var t=window.history,n=function(){var e=window.navigator.userAgent;return(-1===e.indexOf("Android 2.")&&-1===e.indexOf("Android 4.0")||-1===e.indexOf("Mobile Safari")||-1!==e.indexOf("Chrome")||-1!==e.indexOf("Windows Phone"))&&(window.history&&"pushState"in window.history)}(),o=!(-1===window.navigator.userAgent.indexOf("Trident")),a=e,i=a.forceRefresh,l=void 0!==i&&i,u=a.getUserConfirmation,d=void 0===u?g:u,v=a.keyLength,w=void 0===v?6:v,k=e.basename?p(s(e.basename)):"";function E(e){var t=e||{},n=t.key,r=t.state,o=window.location,a=o.pathname+o.search+o.hash;return k&&(a=f(a,k)),m(a,r,n)}function O(){return Math.random().toString(36).substr(2,w)}var S=b();function C(e){Object(r.a)(D,e),D.length=t.length,S.notifyListeners(D.location,D.action)}function T(e){(function(e){return void 0===e.state&&-1===navigator.userAgent.indexOf("CriOS")})(e)||R(E(e.state))}function j(){R(E(x()))}var P=!1;function R(e){if(P)P=!1,C();else{S.confirmTransitionTo(e,"POP",d,(function(t){t?C({action:"POP",location:e}):function(e){var t=D.location,n=M.indexOf(t.key);-1===n&&(n=0);var r=M.indexOf(e.key);-1===r&&(r=0);var o=n-r;o&&(P=!0,A(o))}(e)}))}}var N=E(x()),M=[N.key];function _(e){return k+h(e)}function A(e){t.go(e)}var z=0;function I(e){1===(z+=e)&&1===e?(window.addEventListener("popstate",T),o&&window.addEventListener("hashchange",j)):0===z&&(window.removeEventListener("popstate",T),o&&window.removeEventListener("hashchange",j))}var L=!1;var D={length:t.length,action:"POP",location:N,createHref:_,push:function(e,r){var o=m(e,r,O(),D.location);S.confirmTransitionTo(o,"PUSH",d,(function(e){if(e){var r=_(o),a=o.key,i=o.state;if(n)if(t.pushState({key:a,state:i},null,r),l)window.location.href=r;else{var u=M.indexOf(D.location.key),c=M.slice(0,u+1);c.push(o.key),M=c,C({action:"PUSH",location:o})}else window.location.href=r}}))},replace:function(e,r){var o=m(e,r,O(),D.location);S.confirmTransitionTo(o,"REPLACE",d,(function(e){if(e){var r=_(o),a=o.key,i=o.state;if(n)if(t.replaceState({key:a,state:i},null,r),l)window.location.replace(r);else{var u=M.indexOf(D.location.key);-1!==u&&(M[u]=o.key),C({action:"REPLACE",location:o})}else window.location.replace(r)}}))},go:A,goBack:function(){A(-1)},goForward:function(){A(1)},block:function(e){void 0===e&&(e=!1);var t=S.setPrompt(e);return L||(I(1),L=!0),function(){return L&&(L=!1,I(-1)),t()}},listen:function(e){var t=S.appendListener(e);return I(1),function(){I(-1),t()}}};return D}var k={hashbang:{encodePath:function(e){return"!"===e.charAt(0)?e:"!/"+d(e)},decodePath:function(e){return"!"===e.charAt(0)?e.substr(1):e}},noslash:{encodePath:d,decodePath:s},slash:{encodePath:s,decodePath:s}};function E(e){var t=e.indexOf("#");return-1===t?e:e.slice(0,t)}function O(){var e=window.location.href,t=e.indexOf("#");return-1===t?"":e.substring(t+1)}function S(e){window.location.replace(E(window.location.href)+"#"+e)}function C(e){void 0===e&&(e={}),y||Object(c.a)(!1);var t=window.history,n=(window.navigator.userAgent.indexOf("Firefox"),e),o=n.getUserConfirmation,a=void 0===o?g:o,i=n.hashType,l=void 0===i?"slash":i,u=e.basename?p(s(e.basename)):"",d=k[l],v=d.encodePath,x=d.decodePath;function w(){var e=x(O());return u&&(e=f(e,u)),m(e)}var C=b();function T(e){Object(r.a)(F,e),F.length=t.length,C.notifyListeners(F.location,F.action)}var j=!1,P=null;function R(){var e,t,n=O(),r=v(n);if(n!==r)S(r);else{var o=w(),i=F.location;if(!j&&(t=o,(e=i).pathname===t.pathname&&e.search===t.search&&e.hash===t.hash))return;if(P===h(o))return;P=null,function(e){if(j)j=!1,T();else{C.confirmTransitionTo(e,"POP",a,(function(t){t?T({action:"POP",location:e}):function(e){var t=F.location,n=A.lastIndexOf(h(t));-1===n&&(n=0);var r=A.lastIndexOf(h(e));-1===r&&(r=0);var o=n-r;o&&(j=!0,z(o))}(e)}))}}(o)}}var N=O(),M=v(N);N!==M&&S(M);var _=w(),A=[h(_)];function z(e){t.go(e)}var I=0;function L(e){1===(I+=e)&&1===e?window.addEventListener("hashchange",R):0===I&&window.removeEventListener("hashchange",R)}var D=!1;var F={length:t.length,action:"POP",location:_,createHref:function(e){var t=document.querySelector("base"),n="";return t&&t.getAttribute("href")&&(n=E(window.location.href)),n+"#"+v(u+h(e))},push:function(e,t){var n=m(e,void 0,void 0,F.location);C.confirmTransitionTo(n,"PUSH",a,(function(e){if(e){var t=h(n),r=v(u+t);if(O()!==r){P=t,function(e){window.location.hash=e}(r);var o=A.lastIndexOf(h(F.location)),a=A.slice(0,o+1);a.push(t),A=a,T({action:"PUSH",location:n})}else T()}}))},replace:function(e,t){var n=m(e,void 0,void 0,F.location);C.confirmTransitionTo(n,"REPLACE",a,(function(e){if(e){var t=h(n),r=v(u+t);O()!==r&&(P=t,S(r));var o=A.indexOf(h(F.location));-1!==o&&(A[o]=t),T({action:"REPLACE",location:n})}}))},go:z,goBack:function(){z(-1)},goForward:function(){z(1)},block:function(e){void 0===e&&(e=!1);var t=C.setPrompt(e);return D||(L(1),D=!0),function(){return D&&(D=!1,L(-1)),t()}},listen:function(e){var t=C.appendListener(e);return L(1),function(){L(-1),t()}}};return F}function T(e,t,n){return Math.min(Math.max(e,t),n)}function j(e){void 0===e&&(e={});var t=e,n=t.getUserConfirmation,o=t.initialEntries,a=void 0===o?["/"]:o,i=t.initialIndex,l=void 0===i?0:i,u=t.keyLength,c=void 0===u?6:u,s=b();function d(e){Object(r.a)(x,e),x.length=x.entries.length,s.notifyListeners(x.location,x.action)}function f(){return Math.random().toString(36).substr(2,c)}var p=T(l,0,a.length-1),v=a.map((function(e){return m(e,void 0,"string"===typeof e?f():e.key||f())})),y=h;function g(e){var t=T(x.index+e,0,x.entries.length-1),r=x.entries[t];s.confirmTransitionTo(r,"POP",n,(function(e){e?d({action:"POP",location:r,index:t}):d()}))}var x={length:v.length,action:"POP",location:v[p],index:p,entries:v,createHref:y,push:function(e,t){var r=m(e,t,f(),x.location);s.confirmTransitionTo(r,"PUSH",n,(function(e){if(e){var t=x.index+1,n=x.entries.slice(0);n.length>t?n.splice(t,n.length-t,r):n.push(r),d({action:"PUSH",location:r,index:t,entries:n})}}))},replace:function(e,t){var r=m(e,t,f(),x.location);s.confirmTransitionTo(r,"REPLACE",n,(function(e){e&&(x.entries[x.index]=r,d({action:"REPLACE",location:r}))}))},go:g,goBack:function(){g(-1)},goForward:function(){g(1)},canGo:function(e){var t=x.index+e;return t>=0&&t<x.entries.length},block:function(e){return void 0===e&&(e=!1),s.setPrompt(e)},listen:function(e){return s.appendListener(e)}};return x}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close");t.default=a},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11h-4v4h-2v-4H7v-2h4V7h2v4h4v2z"}),"AddCircle");t.default=a},function(e,t){e.exports=function(e){return e&&e.__esModule?e:{default:e}}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a="undefined"!==typeof window?o.a.useLayoutEffect:o.a.useEffect;function i(e){var t=o.a.useRef(e);return a((function(){t.current=e})),o.a.useCallback((function(){return t.current.apply(void 0,arguments)}),[])}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){var n=a.default.memo(a.default.forwardRef((function(t,n){return a.default.createElement(i.default,(0,o.default)({ref:n},t),e)})));0;return n.muiName=i.default.muiName,n};var o=r(n(127)),a=r(n(0)),i=r(n(82))},,function(e,t,n){"use strict";t.a=function(e,t){}},function(e,t,n){"use strict";var r=n(84);var o=n(85);function a(e,t){return Object(r.a)(e)||function(e,t){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e)){var n=[],r=!0,o=!1,a=void 0;try{for(var i,l=e[Symbol.iterator]();!(r=(i=l.next()).done)&&(n.push(i.value),!t||n.length!==t);r=!0);}catch(u){o=!0,a=u}finally{try{r||null==l.return||l.return()}finally{if(o)throw a}}return n}}(e,t)||Object(o.a)()}n.d(t,"a",(function(){return a}))},function(e,t,n){"use strict";function r(e,t){"function"===typeof e?e(t):e&&(e.current=t)}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(12),o=n(0),a=n.n(o),i=n(5),l=n.n(i),u=n(26),c=n(67),s=n.n(c),d=n(88),f=n.n(d);function p(e){var t=[];return{on:function(e){t.push(e)},off:function(e){t=t.filter((function(t){return t!==e}))},get:function(){return e},set:function(n,r){e=n,t.forEach((function(t){return t(e,r)}))}}}var h=a.a.createContext||function(e,t){var n,r,a="__create-react-context-"+f()()+"__",i=function(e){function n(){var t;return(t=e.apply(this,arguments)||this).emitter=p(t.props.value),t}s()(n,e);var r=n.prototype;return r.getChildContext=function(){var e;return(e={})[a]=this.emitter,e},r.componentWillReceiveProps=function(e){if(this.props.value!==e.value){var n,r=this.props.value,o=e.value;((a=r)===(i=o)?0!==a||1/a===1/i:a!==a&&i!==i)?n=0:(n="function"===typeof t?t(r,o):1073741823,0!==(n|=0)&&this.emitter.set(e.value,n))}var a,i},r.render=function(){return this.props.children},n}(o.Component);i.childContextTypes=((n={})[a]=l.a.object.isRequired,n);var u=function(t){function n(){var e;return(e=t.apply(this,arguments)||this).state={value:e.getValue()},e.onUpdate=function(t,n){0!==((0|e.observedBits)&n)&&e.setState({value:e.getValue()})},e}s()(n,t);var r=n.prototype;return r.componentWillReceiveProps=function(e){var t=e.observedBits;this.observedBits=void 0===t||null===t?1073741823:t},r.componentDidMount=function(){this.context[a]&&this.context[a].on(this.onUpdate);var e=this.props.observedBits;this.observedBits=void 0===e||null===e?1073741823:e},r.componentWillUnmount=function(){this.context[a]&&this.context[a].off(this.onUpdate)},r.getValue=function(){return this.context[a]?this.context[a].get():e},r.render=function(){return(e=this.props.children,Array.isArray(e)?e[0]:e)(this.state.value);var e},n}(o.Component);return u.contextTypes=((r={})[a]=l.a.object,r),{Provider:i,Consumer:u}},m=n(23),v=n(1),b=n(68),y=n.n(b),g=(n(44),n(15));n(89);n.d(t,"a",(function(){return S})),n.d(t,"b",(function(){return w})),n.d(t,"c",(function(){return x})),n.d(t,"d",(function(){return O})),n.d(t,"e",(function(){return M}));var x=function(e){var t=h();return t.displayName=e,t}("Router"),w=function(e){function t(t){var n;return(n=e.call(this,t)||this).state={location:t.history.location},n._isMounted=!1,n._pendingLocation=null,t.staticContext||(n.unlisten=t.history.listen((function(e){n._isMounted?n.setState({location:e}):n._pendingLocation=e}))),n}Object(r.a)(t,e),t.computeRootMatch=function(e){return{path:"/",url:"/",params:{},isExact:"/"===e}};var n=t.prototype;return n.componentDidMount=function(){this._isMounted=!0,this._pendingLocation&&this.setState({location:this._pendingLocation})},n.componentWillUnmount=function(){this.unlisten&&this.unlisten()},n.render=function(){return a.a.createElement(x.Provider,{children:this.props.children||null,value:{history:this.props.history,location:this.state.location,match:t.computeRootMatch(this.state.location.pathname),staticContext:this.props.staticContext}})},t}(a.a.Component);a.a.Component;a.a.Component;var k={},E=0;function O(e,t){void 0===t&&(t={}),("string"===typeof t||Array.isArray(t))&&(t={path:t});var n=t,r=n.path,o=n.exact,a=void 0!==o&&o,i=n.strict,l=void 0!==i&&i,u=n.sensitive,c=void 0!==u&&u;return[].concat(r).reduce((function(t,n){if(!n&&""!==n)return null;if(t)return t;var r=function(e,t){var n=""+t.end+t.strict+t.sensitive,r=k[n]||(k[n]={});if(r[e])return r[e];var o=[],a={regexp:y()(e,o,t),keys:o};return E<1e4&&(r[e]=a,E++),a}(n,{end:a,strict:l,sensitive:c}),o=r.regexp,i=r.keys,u=o.exec(e);if(!u)return null;var s=u[0],d=u.slice(1),f=e===s;return a&&!f?null:{path:n,url:"/"===n&&""===s?"/":s,isExact:f,params:i.reduce((function(e,t,n){return e[t.name]=d[n],e}),{})}}),null)}var S=function(e){function t(){return e.apply(this,arguments)||this}return Object(r.a)(t,e),t.prototype.render=function(){var e=this;return a.a.createElement(x.Consumer,null,(function(t){t||Object(m.a)(!1);var n=e.props.location||t.location,r=e.props.computedMatch?e.props.computedMatch:e.props.path?O(n.pathname,e.props):t.match,o=Object(v.a)({},t,{location:n,match:r}),i=e.props,l=i.children,u=i.component,c=i.render;return Array.isArray(l)&&0===l.length&&(l=null),a.a.createElement(x.Provider,{value:o},o.match?l?"function"===typeof l?l(o):l:u?a.a.createElement(u,o):c?c(o):null:"function"===typeof l?l(o):null)}))},t}(a.a.Component);function C(e){return"/"===e.charAt(0)?e:"/"+e}function T(e,t){if(!e)return t;var n=C(e);return 0!==t.pathname.indexOf(n)?t:Object(v.a)({},t,{pathname:t.pathname.substr(n.length)})}function j(e){return"string"===typeof e?e:Object(u.e)(e)}function P(e){return function(){Object(m.a)(!1)}}function R(){}a.a.Component;a.a.Component;var N=a.a.useContext;function M(){var e=N(x).match;return e?e.params:{}}},,,,function(e,t,n){"use strict";n.d(t,"b",(function(){return i}));var r=n(0),o=n.n(r),a=o.a.createContext();function i(){return o.a.useContext(a)}t.a=a},function(e,t,n){"use strict";function r(e){return null!=e&&!(Array.isArray(e)&&0===e.length)}function o(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return e&&(r(e.value)&&""!==e.value||t&&r(e.defaultValue)&&""!==e.defaultValue)}function a(e){return e.startAdornment}n.d(t,"b",(function(){return o})),n.d(t,"a",(function(){return a}))},function(e,t,n){"use strict";function r(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];return t.reduce((function(e,t){return null==t?e:function(){for(var n=arguments.length,r=new Array(n),o=0;o<n;o++)r[o]=arguments[o];e.apply(this,r),t.apply(this,r)}}),(function(){}))}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(0),o=n.n(r);t.a=o.a.createContext(null)},function(e,t,n){"use strict";e.exports=n(126)},function(e,t,n){"use strict";var r=n(92),o=Object(r.a)();t.a=o},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(22),c=n(4),s=n(132),d=i.a.forwardRef((function(e,t){var n=e.autoFocus,a=e.checked,c=e.checkedIcon,d=e.classes,f=e.className,p=e.defaultChecked,h=e.disabled,m=e.icon,v=e.id,b=e.inputProps,y=e.inputRef,g=e.name,x=e.onBlur,w=e.onChange,k=e.onFocus,E=e.readOnly,O=e.required,S=e.tabIndex,C=e.type,T=e.value,j=Object(o.a)(e,["autoFocus","checked","checkedIcon","classes","className","defaultChecked","disabled","icon","id","inputProps","inputRef","name","onBlur","onChange","onFocus","readOnly","required","tabIndex","type","value"]),P=i.a.useRef(null!=a).current,R=i.a.useState(Boolean(p)),N=R[0],M=R[1],_=P?a:N,A=Object(u.a)(),z=h;A&&"undefined"===typeof z&&(z=A.disabled);var I="checkbox"===C||"radio"===C;return i.a.createElement(s.a,Object(r.a)({component:"span",className:Object(l.a)(d.root,f,_&&d.checked,z&&d.disabled),disabled:z,tabIndex:null,role:void 0,onFocus:function(e){k&&k(e),A&&A.onFocus&&A.onFocus(e)},onBlur:function(e){x&&x(e),A&&A.onBlur&&A.onBlur(e)},ref:t},j),i.a.createElement("input",Object(r.a)({autoFocus:n,checked:a,defaultChecked:p,className:d.input,disabled:z,id:I&&v,name:g,onChange:function(e){var t=e.target.checked;P||M(t),w&&w(e,t)},readOnly:E,ref:y,required:O,tabIndex:S,type:C,value:T},b)),_?c:m)}));t.a=Object(c.a)({root:{padding:9},checked:{},disabled:{},input:{cursor:"inherit",position:"absolute",opacity:0,width:"100%",height:"100%",top:0,left:0,margin:0,padding:0,zIndex:1}},{name:"PrivateSwitchBase"})(d)},function(e,t,n){"use strict";n.d(t,"a",(function(){return a}));var r=n(93),o=n(45);function a(){return Object(r.a)()||o.a}},function(e,t,n){"use strict";function r(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}function o(e,t,n){return t&&r(e.prototype,t),n&&r(e,n),e}n.d(t,"a",(function(){return o}))},function(e,t,n){"use strict";function r(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";n.d(t,"a",(function(){return a}));var r=n(0),o=n.n(r);function a(e,t){return o.a.isValidElement(e)&&-1!==t.indexOf(e.type.muiName)}},function(e,t,n){"use strict";var r=n(0),o=n.n(r).a.createContext({});t.a=o},,function(e,t,n){"use strict";function r(e){return(r="function"===typeof Symbol&&"symbol"===typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"===typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function o(e){return(o="function"===typeof Symbol&&"symbol"===r(Symbol.iterator)?function(e){return r(e)}:function(e){return e&&"function"===typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":r(e)})(e)}n.d(t,"a",(function(){return o}))},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z"}),"CheckBoxOutlineBlank");t.default=a},function(e,t,n){e.exports=n(107)},,function(e,t,n){"use strict";var r=n(0),o=n.n(r).a.createContext(null);t.a=o},function(e,t,n){"use strict";var r="function"===typeof Symbol&&Symbol.for;t.a=r?Symbol.for("mui.nested"):"__THEME_NESTED__"},function(e,t,n){"use strict";t.a={mobileStepper:1e3,speedDial:1050,appBar:1100,drawer:1200,modal:1300,snackbar:1400,tooltip:1500}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(6),s=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,u=e.className,s=e.color,d=void 0===s?"inherit":s,f=e.component,p=void 0===f?"svg":f,h=e.fontSize,m=void 0===h?"default":h,v=e.htmlColor,b=e.titleAccess,y=e.viewBox,g=void 0===y?"0 0 24 24":y,x=Object(o.a)(e,["children","classes","className","color","component","fontSize","htmlColor","titleAccess","viewBox"]);return i.a.createElement(p,Object(r.a)({className:Object(l.a)(a.root,u,"inherit"!==d&&a["color".concat(Object(c.a)(d))],"default"!==m&&a["fontSize".concat(Object(c.a)(m))]),focusable:"false",viewBox:g,color:v,"aria-hidden":b?null:"true",role:b?"img":"presentation",ref:t},x),n,b?i.a.createElement("title",null,b):null)}));s.muiName="SvgIcon",t.a=Object(u.a)((function(e){return{root:{userSelect:"none",width:"1em",height:"1em",display:"inline-block",fill:"currentColor",flexShrink:0,fontSize:e.typography.pxToRem(24),transition:e.transitions.create("fill",{duration:e.transitions.duration.shorter})},colorPrimary:{color:e.palette.primary.main},colorSecondary:{color:e.palette.secondary.main},colorAction:{color:e.palette.action.active},colorError:{color:e.palette.error.main},colorDisabled:{color:e.palette.action.disabled},fontSizeInherit:{fontSize:"inherit"},fontSizeSmall:{fontSize:e.typography.pxToRem(20)},fontSizeLarge:{fontSize:e.typography.pxToRem(35)}}}),{name:"MuiSvgIcon"})(s)},function(e,t,n){"use strict";function r(e){var t,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:166;function r(){for(var r=arguments.length,o=new Array(r),a=0;a<r;a++)o[a]=arguments[a];var i=this,l=function(){e.apply(i,o)};clearTimeout(t),t=setTimeout(l,n)}return r.clear=function(){clearTimeout(t)},r}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(0),o=n.n(r).a.createContext();t.a=o},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"}),"Add");t.default=a},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M3 15h18v-2H3v2zm0 4h18v-2H3v2zm0-8h18V9H3v2zm0-6v2h18V5H3z"}),"Reorder");t.default=a},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"}),"RadioButtonChecked");t.default=a},function(e,t,n){"use strict";n.d(t,"a",(function(){return d}));var r=n(36),o=n(12),a=n(0),i=n.n(a),l=n(26),u=(n(5),n(1)),c=n(15),s=n(23);i.a.Component;var d=function(e){function t(){for(var t,n=arguments.length,r=new Array(n),o=0;o<n;o++)r[o]=arguments[o];return(t=e.call.apply(e,[this].concat(r))||this).history=Object(l.b)(t.props),t}return Object(o.a)(t,e),t.prototype.render=function(){return i.a.createElement(r.b,{history:this.history,children:this.props.children})},t}(i.a.Component);var f=function(e,t){return"function"===typeof e?e(t):e},p=function(e,t){return"string"===typeof e?Object(l.c)(e,null,null,t):e},h=function(e){return e},m=i.a.forwardRef;"undefined"===typeof m&&(m=h);var v=m((function(e,t){var n=e.innerRef,r=e.navigate,o=e.onClick,a=Object(c.a)(e,["innerRef","navigate","onClick"]),l=a.target,s=Object(u.a)({},a,{onClick:function(e){try{o&&o(e)}catch(t){throw e.preventDefault(),t}e.defaultPrevented||0!==e.button||l&&"_self"!==l||function(e){return!!(e.metaKey||e.altKey||e.ctrlKey||e.shiftKey)}(e)||(e.preventDefault(),r())}});return s.ref=h!==m&&t||n,i.a.createElement("a",s)}));var b=m((function(e,t){var n=e.component,o=void 0===n?v:n,a=e.replace,l=e.to,d=e.innerRef,b=Object(c.a)(e,["component","replace","to","innerRef"]);return i.a.createElement(r.c.Consumer,null,(function(e){e||Object(s.a)(!1);var n=e.history,r=p(f(l,e.location),e.location),c=r?n.createHref(r):"",v=Object(u.a)({},b,{href:c,navigate:function(){var t=f(l,e.location);(a?n.replace:n.push)(t)}});return h!==m?v.ref=t||d:v.innerRef=d,i.a.createElement(o,v)}))})),y=function(e){return e},g=i.a.forwardRef;"undefined"===typeof g&&(g=y);g((function(e,t){var n=e["aria-current"],o=void 0===n?"page":n,a=e.activeClassName,l=void 0===a?"active":a,d=e.activeStyle,h=e.className,m=e.exact,v=e.isActive,x=e.location,w=e.strict,k=e.style,E=e.to,O=e.innerRef,S=Object(c.a)(e,["aria-current","activeClassName","activeStyle","className","exact","isActive","location","strict","style","to","innerRef"]);return i.a.createElement(r.c.Consumer,null,(function(e){e||Object(s.a)(!1);var n=x||e.location,a=p(f(E,n),n),c=a.pathname,C=c&&c.replace(/([.+*?=^!:${}()[\]|/\\])/g,"\\$1"),T=C?Object(r.d)(n.pathname,{path:C,exact:m,strict:w}):null,j=!!(v?v(T,n):T),P=j?function(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];return t.filter((function(e){return e})).join(" ")}(h,l):h,R=j?Object(u.a)({},k,{},d):k,N=Object(u.a)({"aria-current":j&&o||null,className:P,style:R,to:a},S);return y!==g?N.ref=t||O:N.innerRef=O,i.a.createElement(b,N)}))}))},function(e,t){e.exports=function(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}},function(e,t,n){var r=n(129);e.exports=p,e.exports.parse=a,e.exports.compile=function(e,t){return l(a(e,t),t)},e.exports.tokensToFunction=l,e.exports.tokensToRegExp=f;var o=new RegExp(["(\\\\.)","([\\/.])?(?:(?:\\:(\\w+)(?:\\(((?:\\\\.|[^\\\\()])+)\\))?|\\(((?:\\\\.|[^\\\\()])+)\\))([+*?])?|(\\*))"].join("|"),"g");function a(e,t){for(var n,r=[],a=0,i=0,l="",s=t&&t.delimiter||"/";null!=(n=o.exec(e));){var d=n[0],f=n[1],p=n.index;if(l+=e.slice(i,p),i=p+d.length,f)l+=f[1];else{var h=e[i],m=n[2],v=n[3],b=n[4],y=n[5],g=n[6],x=n[7];l&&(r.push(l),l="");var w=null!=m&&null!=h&&h!==m,k="+"===g||"*"===g,E="?"===g||"*"===g,O=n[2]||s,S=b||y;r.push({name:v||a++,prefix:m||"",delimiter:O,optional:E,repeat:k,partial:w,asterisk:!!x,pattern:S?c(S):x?".*":"[^"+u(O)+"]+?"})}}return i<e.length&&(l+=e.substr(i)),l&&r.push(l),r}function i(e){return encodeURI(e).replace(/[\/?#]/g,(function(e){return"%"+e.charCodeAt(0).toString(16).toUpperCase()}))}function l(e,t){for(var n=new Array(e.length),o=0;o<e.length;o++)"object"===typeof e[o]&&(n[o]=new RegExp("^(?:"+e[o].pattern+")$",d(t)));return function(t,o){for(var a="",l=t||{},u=(o||{}).pretty?i:encodeURIComponent,c=0;c<e.length;c++){var s=e[c];if("string"!==typeof s){var d,f=l[s.name];if(null==f){if(s.optional){s.partial&&(a+=s.prefix);continue}throw new TypeError('Expected "'+s.name+'" to be defined')}if(r(f)){if(!s.repeat)throw new TypeError('Expected "'+s.name+'" to not repeat, but received `'+JSON.stringify(f)+"`");if(0===f.length){if(s.optional)continue;throw new TypeError('Expected "'+s.name+'" to not be empty')}for(var p=0;p<f.length;p++){if(d=u(f[p]),!n[c].test(d))throw new TypeError('Expected all "'+s.name+'" to match "'+s.pattern+'", but received `'+JSON.stringify(d)+"`");a+=(0===p?s.prefix:s.delimiter)+d}}else{if(d=s.asterisk?encodeURI(f).replace(/[?#]/g,(function(e){return"%"+e.charCodeAt(0).toString(16).toUpperCase()})):u(f),!n[c].test(d))throw new TypeError('Expected "'+s.name+'" to match "'+s.pattern+'", but received "'+d+'"');a+=s.prefix+d}}else a+=s}return a}}function u(e){return e.replace(/([.+*?=^!:${}()[\]|\/\\])/g,"\\$1")}function c(e){return e.replace(/([=!:$\/()])/g,"\\$1")}function s(e,t){return e.keys=t,e}function d(e){return e&&e.sensitive?"":"i"}function f(e,t,n){r(t)||(n=t||n,t=[]);for(var o=(n=n||{}).strict,a=!1!==n.end,i="",l=0;l<e.length;l++){var c=e[l];if("string"===typeof c)i+=u(c);else{var f=u(c.prefix),p="(?:"+c.pattern+")";t.push(c),c.repeat&&(p+="(?:"+f+p+")*"),i+=p=c.optional?c.partial?f+"("+p+")?":"(?:"+f+"("+p+"))?":f+"("+p+")"}}var h=u(n.delimiter||"/"),m=i.slice(-h.length)===h;return o||(i=(m?i.slice(0,-h.length):i)+"(?:"+h+"(?=$))?"),i+=a?"$":o&&m?"":"(?="+h+"|$)",s(new RegExp("^"+i,d(n)),t)}function p(e,t,n){return r(t)||(n=t||n,t=[]),n=n||{},e instanceof RegExp?function(e,t){var n=e.source.match(/\((?!\?)/g);if(n)for(var r=0;r<n.length;r++)t.push({name:r,prefix:null,delimiter:null,optional:!1,repeat:!1,partial:!1,asterisk:!1,pattern:null});return s(e,t)}(e,t):r(e)?function(e,t,n){for(var r=[],o=0;o<e.length;o++)r.push(p(e[o],t,n).source);return s(new RegExp("(?:"+r.join("|")+")",d(n)),t)}(e,t,n):function(e,t,n){return f(a(e,n),t,n)}(e,t,n)}},,,,,function(e,t,n){"use strict";var r=Object.getOwnPropertySymbols,o=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;function i(e){if(null===e||void 0===e)throw new TypeError("Object.assign cannot be called with null or undefined");return Object(e)}e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map((function(e){return t[e]})).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach((function(e){r[e]=e})),"abcdefghijklmnopqrst"===Object.keys(Object.assign({},r)).join("")}catch(o){return!1}}()?Object.assign:function(e,t){for(var n,l,u=i(e),c=1;c<arguments.length;c++){for(var s in n=Object(arguments[c]))o.call(n,s)&&(u[s]=n[s]);if(r){l=r(n);for(var d=0;d<l.length;d++)a.call(n,l[d])&&(u[l[d]]=n[l[d]])}}return u}},function(e,t,n){"use strict";e.exports=function(e,t){return function(){for(var n=new Array(arguments.length),r=0;r<n.length;r++)n[r]=arguments[r];return e.apply(t,n)}}},function(e,t,n){"use strict";var r=n(21);function o(e){return encodeURIComponent(e).replace(/%40/gi,"@").replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}e.exports=function(e,t,n){if(!t)return e;var a;if(n)a=n(t);else if(r.isURLSearchParams(t))a=t.toString();else{var i=[];r.forEach(t,(function(e,t){null!==e&&"undefined"!==typeof e&&(r.isArray(e)?t+="[]":e=[e],r.forEach(e,(function(e){r.isDate(e)?e=e.toISOString():r.isObject(e)&&(e=JSON.stringify(e)),i.push(o(t)+"="+o(e))})))})),a=i.join("&")}if(a){var l=e.indexOf("#");-1!==l&&(e=e.slice(0,l)),e+=(-1===e.indexOf("?")?"?":"&")+a}return e}},function(e,t,n){"use strict";e.exports=function(e){return!(!e||!e.__CANCEL__)}},function(e,t,n){"use strict";(function(t){var r=n(21),o=n(113),a={"Content-Type":"application/x-www-form-urlencoded"};function i(e,t){!r.isUndefined(e)&&r.isUndefined(e["Content-Type"])&&(e["Content-Type"]=t)}var l={adapter:function(){var e;return"undefined"!==typeof XMLHttpRequest?e=n(78):"undefined"!==typeof t&&"[object process]"===Object.prototype.toString.call(t)&&(e=n(78)),e}(),transformRequest:[function(e,t){return o(t,"Accept"),o(t,"Content-Type"),r.isFormData(e)||r.isArrayBuffer(e)||r.isBuffer(e)||r.isStream(e)||r.isFile(e)||r.isBlob(e)?e:r.isArrayBufferView(e)?e.buffer:r.isURLSearchParams(e)?(i(t,"application/x-www-form-urlencoded;charset=utf-8"),e.toString()):r.isObject(e)?(i(t,"application/json;charset=utf-8"),JSON.stringify(e)):e}],transformResponse:[function(e){if("string"===typeof e)try{e=JSON.parse(e)}catch(t){}return e}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,validateStatus:function(e){return e>=200&&e<300},headers:{common:{Accept:"application/json, text/plain, */*"}}};r.forEach(["delete","get","head"],(function(e){l.headers[e]={}})),r.forEach(["post","put","patch"],(function(e){l.headers[e]=r.merge(a)})),e.exports=l}).call(this,n(112))},function(e,t,n){"use strict";var r=n(21),o=n(114),a=n(75),i=n(116),l=n(119),u=n(120),c=n(79);e.exports=function(e){return new Promise((function(t,s){var d=e.data,f=e.headers;r.isFormData(d)&&delete f["Content-Type"];var p=new XMLHttpRequest;if(e.auth){var h=e.auth.username||"",m=e.auth.password||"";f.Authorization="Basic "+btoa(h+":"+m)}var v=i(e.baseURL,e.url);if(p.open(e.method.toUpperCase(),a(v,e.params,e.paramsSerializer),!0),p.timeout=e.timeout,p.onreadystatechange=function(){if(p&&4===p.readyState&&(0!==p.status||p.responseURL&&0===p.responseURL.indexOf("file:"))){var n="getAllResponseHeaders"in p?l(p.getAllResponseHeaders()):null,r={data:e.responseType&&"text"!==e.responseType?p.response:p.responseText,status:p.status,statusText:p.statusText,headers:n,config:e,request:p};o(t,s,r),p=null}},p.onabort=function(){p&&(s(c("Request aborted",e,"ECONNABORTED",p)),p=null)},p.onerror=function(){s(c("Network Error",e,null,p)),p=null},p.ontimeout=function(){var t="timeout of "+e.timeout+"ms exceeded";e.timeoutErrorMessage&&(t=e.timeoutErrorMessage),s(c(t,e,"ECONNABORTED",p)),p=null},r.isStandardBrowserEnv()){var b=n(121),y=(e.withCredentials||u(v))&&e.xsrfCookieName?b.read(e.xsrfCookieName):void 0;y&&(f[e.xsrfHeaderName]=y)}if("setRequestHeader"in p&&r.forEach(f,(function(e,t){"undefined"===typeof d&&"content-type"===t.toLowerCase()?delete f[t]:p.setRequestHeader(t,e)})),r.isUndefined(e.withCredentials)||(p.withCredentials=!!e.withCredentials),e.responseType)try{p.responseType=e.responseType}catch(g){if("json"!==e.responseType)throw g}"function"===typeof e.onDownloadProgress&&p.addEventListener("progress",e.onDownloadProgress),"function"===typeof e.onUploadProgress&&p.upload&&p.upload.addEventListener("progress",e.onUploadProgress),e.cancelToken&&e.cancelToken.promise.then((function(e){p&&(p.abort(),s(e),p=null)})),void 0===d&&(d=null),p.send(d)}))}},function(e,t,n){"use strict";var r=n(115);e.exports=function(e,t,n,o,a){var i=new Error(e);return r(i,t,n,o,a)}},function(e,t,n){"use strict";var r=n(21);e.exports=function(e,t){t=t||{};var n={},o=["url","method","params","data"],a=["headers","auth","proxy"],i=["baseURL","url","transformRequest","transformResponse","paramsSerializer","timeout","withCredentials","adapter","responseType","xsrfCookieName","xsrfHeaderName","onUploadProgress","onDownloadProgress","maxContentLength","validateStatus","maxRedirects","httpAgent","httpsAgent","cancelToken","socketPath"];r.forEach(o,(function(e){"undefined"!==typeof t[e]&&(n[e]=t[e])})),r.forEach(a,(function(o){r.isObject(t[o])?n[o]=r.deepMerge(e[o],t[o]):"undefined"!==typeof t[o]?n[o]=t[o]:r.isObject(e[o])?n[o]=r.deepMerge(e[o]):"undefined"!==typeof e[o]&&(n[o]=e[o])})),r.forEach(i,(function(r){"undefined"!==typeof t[r]?n[r]=t[r]:"undefined"!==typeof e[r]&&(n[r]=e[r])}));var l=o.concat(a).concat(i),u=Object.keys(t).filter((function(e){return-1===l.indexOf(e)}));return r.forEach(u,(function(r){"undefined"!==typeof t[r]?n[r]=t[r]:"undefined"!==typeof e[r]&&(n[r]=e[r])})),n}},function(e,t,n){"use strict";function r(e){this.message=e}r.prototype.toString=function(){return"Cancel"+(this.message?": "+this.message:"")},r.prototype.__CANCEL__=!0,e.exports=r},function(e,t,n){"use strict";n.r(t);var r=n(60);n.d(t,"default",(function(){return r.a}))},function(e,t,n){"use strict";function r(e){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e))return Array.from(e)}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";function r(e){if(Array.isArray(e))return e}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";function r(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(44),o={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},a={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},i={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},l={};function u(e){return r.isMemo(e)?i:l[e.$$typeof]||o}l[r.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0};var c=Object.defineProperty,s=Object.getOwnPropertyNames,d=Object.getOwnPropertySymbols,f=Object.getOwnPropertyDescriptor,p=Object.getPrototypeOf,h=Object.prototype;e.exports=function e(t,n,r){if("string"!==typeof n){if(h){var o=p(n);o&&o!==h&&e(t,o,r)}var i=s(n);d&&(i=i.concat(d(n)));for(var l=u(t),m=u(n),v=0;v<i.length;++v){var b=i[v];if(!a[b]&&(!r||!r[b])&&(!m||!m[b])&&(!l||!l[b])){var y=f(n,b);try{c(t,b,y)}catch(g){}}}}return t}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"}),"RadioButtonUnchecked");t.default=a},function(e,t,n){"use strict";(function(t){var n="__global_unique_id__";e.exports=function(){return t[n]=(t[n]||0)+1}}).call(this,n(128))},function(e,t,n){"use strict";var r=n(44),o={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},a={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},i={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},l={};function u(e){return r.isMemo(e)?i:l[e.$$typeof]||o}l[r.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},l[r.Memo]=i;var c=Object.defineProperty,s=Object.getOwnPropertyNames,d=Object.getOwnPropertySymbols,f=Object.getOwnPropertyDescriptor,p=Object.getPrototypeOf,h=Object.prototype;e.exports=function e(t,n,r){if("string"!==typeof n){if(h){var o=p(n);o&&o!==h&&e(t,o,r)}var i=s(n);d&&(i=i.concat(d(n)));for(var l=u(t),m=u(n),v=0;v<i.length;++v){var b=i[v];if(!a[b]&&(!r||!r[b])&&(!m||!m[b])&&(!l||!l[b])){var y=f(n,b);try{c(t,b,y)}catch(g){}}}}return t}},function(e,t,n){"use strict";n.d(t,"a",(function(){return a}));var r=n(20);function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function a(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?o(Object(n),!0).forEach((function(t){Object(r.a)(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):o(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z"}),"KeyboardArrowRight");t.default=a},function(e,t,n){"use strict";var r=n(20),o=n(2),a=n(162),i=n(1),l=["xs","sm","md","lg","xl"];function u(e){var t=e.values,n=void 0===t?{xs:0,sm:600,md:960,lg:1280,xl:1920}:t,r=e.unit,a=void 0===r?"px":r,u=e.step,c=void 0===u?5:u,s=Object(o.a)(e,["values","unit","step"]);function d(e){var t="number"===typeof n[e]?n[e]:e;return"@media (min-width:".concat(t).concat(a,")")}function f(e,t){var r=l.indexOf(t);return r===l.length-1?d(e):"@media (min-width:".concat("number"===typeof n[e]?n[e]:e).concat(a,") and ")+"(max-width:".concat((-1!==r&&"number"===typeof n[l[r+1]]?n[l[r+1]]:t)-c/100).concat(a,")")}return Object(i.a)({keys:l,values:n,up:d,down:function(e){var t=l.indexOf(e)+1,r=n[l[t]];return t===l.length?d("xs"):"@media (max-width:".concat(("number"===typeof r&&t>0?r:e)-c/100).concat(a,")")},between:f,only:function(e){return f(e,e)},width:function(e){return n[e]}},s)}function c(e,t,n){var o;return Object(i.a)({gutters:function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return Object(i.a)({paddingLeft:t(2),paddingRight:t(2)},n,Object(r.a)({},e.up("sm"),Object(i.a)({paddingLeft:t(3),paddingRight:t(3)},n[e.up("sm")])))},toolbar:(o={minHeight:56},Object(r.a)(o,"".concat(e.up("xs")," and (orientation: landscape)"),{minHeight:48}),Object(r.a)(o,e.up("sm"),{minHeight:64}),o)},n)}var s={black:"#000",white:"#fff"},d={50:"#fafafa",100:"#f5f5f5",200:"#eeeeee",300:"#e0e0e0",400:"#bdbdbd",500:"#9e9e9e",600:"#757575",700:"#616161",800:"#424242",900:"#212121",A100:"#d5d5d5",A200:"#aaaaaa",A400:"#303030",A700:"#616161"},f={50:"#e8eaf6",100:"#c5cae9",200:"#9fa8da",300:"#7986cb",400:"#5c6bc0",500:"#3f51b5",600:"#3949ab",700:"#303f9f",800:"#283593",900:"#1a237e",A100:"#8c9eff",A200:"#536dfe",A400:"#3d5afe",A700:"#304ffe"},p={50:"#fce4ec",100:"#f8bbd0",200:"#f48fb1",300:"#f06292",400:"#ec407a",500:"#e91e63",600:"#d81b60",700:"#c2185b",800:"#ad1457",900:"#880e4f",A100:"#ff80ab",A200:"#ff4081",A400:"#f50057",A700:"#c51162"},h={50:"#ffebee",100:"#ffcdd2",200:"#ef9a9a",300:"#e57373",400:"#ef5350",500:"#f44336",600:"#e53935",700:"#d32f2f",800:"#c62828",900:"#b71c1c",A100:"#ff8a80",A200:"#ff5252",A400:"#ff1744",A700:"#d50000"},m={50:"#fff3e0",100:"#ffe0b2",200:"#ffcc80",300:"#ffb74d",400:"#ffa726",500:"#ff9800",600:"#fb8c00",700:"#f57c00",800:"#ef6c00",900:"#e65100",A100:"#ffd180",A200:"#ffab40",A400:"#ff9100",A700:"#ff6d00"},v={50:"#e3f2fd",100:"#bbdefb",200:"#90caf9",300:"#64b5f6",400:"#42a5f5",500:"#2196f3",600:"#1e88e5",700:"#1976d2",800:"#1565c0",900:"#0d47a1",A100:"#82b1ff",A200:"#448aff",A400:"#2979ff",A700:"#2962ff"},b={50:"#e8f5e9",100:"#c8e6c9",200:"#a5d6a7",300:"#81c784",400:"#66bb6a",500:"#4caf50",600:"#43a047",700:"#388e3c",800:"#2e7d32",900:"#1b5e20",A100:"#b9f6ca",A200:"#69f0ae",A400:"#00e676",A700:"#00c853"},y=n(10),g={text:{primary:"rgba(0, 0, 0, 0.87)",secondary:"rgba(0, 0, 0, 0.54)",disabled:"rgba(0, 0, 0, 0.38)",hint:"rgba(0, 0, 0, 0.38)"},divider:"rgba(0, 0, 0, 0.12)",background:{paper:s.white,default:d[50]},action:{active:"rgba(0, 0, 0, 0.54)",hover:"rgba(0, 0, 0, 0.08)",hoverOpacity:.08,selected:"rgba(0, 0, 0, 0.14)",disabled:"rgba(0, 0, 0, 0.26)",disabledBackground:"rgba(0, 0, 0, 0.12)"}},x={text:{primary:s.white,secondary:"rgba(255, 255, 255, 0.7)",disabled:"rgba(255, 255, 255, 0.5)",hint:"rgba(255, 255, 255, 0.5)",icon:"rgba(255, 255, 255, 0.5)"},divider:"rgba(255, 255, 255, 0.12)",background:{paper:d[800],default:"#303030"},action:{active:s.white,hover:"rgba(255, 255, 255, 0.1)",hoverOpacity:.1,selected:"rgba(255, 255, 255, 0.2)",disabled:"rgba(255, 255, 255, 0.3)",disabledBackground:"rgba(255, 255, 255, 0.12)"}};function w(e,t,n,r){e[t]||(e.hasOwnProperty(n)?e[t]=e[n]:"light"===t?e.light=Object(y.d)(e.main,r):"dark"===t&&(e.dark=Object(y.a)(e.main,1.5*r)))}function k(e){var t=e.primary,n=void 0===t?{light:f[300],main:f[500],dark:f[700]}:t,r=e.secondary,l=void 0===r?{light:p.A200,main:p.A400,dark:p.A700}:r,u=e.error,c=void 0===u?{light:h[300],main:h[500],dark:h[700]}:u,k=e.warning,E=void 0===k?{light:m[300],main:m[500],dark:m[700]}:k,O=e.info,S=void 0===O?{light:v[300],main:v[500],dark:v[700]}:O,C=e.success,T=void 0===C?{light:b[300],main:b[500],dark:b[700]}:C,j=e.type,P=void 0===j?"light":j,R=e.contrastThreshold,N=void 0===R?3:R,M=e.tonalOffset,_=void 0===M?.2:M,A=Object(o.a)(e,["primary","secondary","error","warning","info","success","type","contrastThreshold","tonalOffset"]);function z(e){if(!e)throw new TypeError("Material-UI: missing background argument in getContrastText(".concat(e,")."));return Object(y.c)(e,x.text.primary)>=N?x.text.primary:g.text.primary}function I(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:500,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:300,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:700;return!(e=Object(i.a)({},e)).main&&e[t]&&(e.main=e[t]),w(e,"light",n,_),w(e,"dark",r,_),e.contrastText||(e.contrastText=z(e.main)),e}var L={dark:x,light:g};return Object(a.a)(Object(i.a)({common:s,type:P,primary:I(n),secondary:I(l,"A400","A200","A700"),error:I(c),warning:I(E),info:I(S),success:I(T),grey:d,contrastThreshold:N,getContrastText:z,augmentColor:I,tonalOffset:_},L[P]),A)}function E(e){return Math.round(1e5*e)/1e5}var O={textTransform:"uppercase"};function S(e,t){var n="function"===typeof t?t(e):t,r=n.fontFamily,l=void 0===r?'"Roboto", "Helvetica", "Arial", sans-serif':r,u=n.fontSize,c=void 0===u?14:u,s=n.fontWeightLight,d=void 0===s?300:s,f=n.fontWeightRegular,p=void 0===f?400:f,h=n.fontWeightMedium,m=void 0===h?500:h,v=n.fontWeightBold,b=void 0===v?700:v,y=n.htmlFontSize,g=void 0===y?16:y,x=n.allVariants,w=n.pxToRem,k=Object(o.a)(n,["fontFamily","fontSize","fontWeightLight","fontWeightRegular","fontWeightMedium","fontWeightBold","htmlFontSize","allVariants","pxToRem"]);var S=c/14,C=w||function(e){return"".concat(e/g*S,"rem")},T=function(e,t,n,r,o){return Object(i.a)({fontFamily:l,fontWeight:e,fontSize:C(t),lineHeight:n},'"Roboto", "Helvetica", "Arial", sans-serif'===l?{letterSpacing:"".concat(E(r/t),"em")}:{},{},o,{},x)},j={h1:T(d,96,1.167,-1.5),h2:T(d,60,1.2,-.5),h3:T(p,48,1.167,0),h4:T(p,34,1.235,.25),h5:T(p,24,1.334,0),h6:T(m,20,1.6,.15),subtitle1:T(p,16,1.75,.15),subtitle2:T(m,14,1.57,.1),body1:T(p,16,1.5,.15),body2:T(p,14,1.43,.15),button:T(m,14,1.75,.4,O),caption:T(p,12,1.66,.4),overline:T(p,12,2.66,1,O)};return Object(a.a)(Object(i.a)({htmlFontSize:g,pxToRem:C,round:E,fontFamily:l,fontSize:c,fontWeightLight:d,fontWeightRegular:p,fontWeightMedium:m,fontWeightBold:b},j),k,{clone:!1})}function C(){return["".concat(arguments.length<=0?void 0:arguments[0],"px ").concat(arguments.length<=1?void 0:arguments[1],"px ").concat(arguments.length<=2?void 0:arguments[2],"px ").concat(arguments.length<=3?void 0:arguments[3],"px rgba(0,0,0,").concat(.2,")"),"".concat(arguments.length<=4?void 0:arguments[4],"px ").concat(arguments.length<=5?void 0:arguments[5],"px ").concat(arguments.length<=6?void 0:arguments[6],"px ").concat(arguments.length<=7?void 0:arguments[7],"px rgba(0,0,0,").concat(.14,")"),"".concat(arguments.length<=8?void 0:arguments[8],"px ").concat(arguments.length<=9?void 0:arguments[9],"px ").concat(arguments.length<=10?void 0:arguments[10],"px ").concat(arguments.length<=11?void 0:arguments[11],"px rgba(0,0,0,").concat(.12,")")].join(",")}var T=["none",C(0,2,1,-1,0,1,1,0,0,1,3,0),C(0,3,1,-2,0,2,2,0,0,1,5,0),C(0,3,3,-2,0,3,4,0,0,1,8,0),C(0,2,4,-1,0,4,5,0,0,1,10,0),C(0,3,5,-1,0,5,8,0,0,1,14,0),C(0,3,5,-1,0,6,10,0,0,1,18,0),C(0,4,5,-2,0,7,10,1,0,2,16,1),C(0,5,5,-3,0,8,10,1,0,3,14,2),C(0,5,6,-3,0,9,12,1,0,3,16,2),C(0,6,6,-3,0,10,14,1,0,4,18,3),C(0,6,7,-4,0,11,15,1,0,4,20,3),C(0,7,8,-4,0,12,17,2,0,5,22,4),C(0,7,8,-4,0,13,19,2,0,5,24,4),C(0,7,9,-4,0,14,21,2,0,5,26,4),C(0,8,9,-5,0,15,22,2,0,6,28,5),C(0,8,10,-5,0,16,24,2,0,6,30,5),C(0,8,11,-5,0,17,26,2,0,6,32,5),C(0,9,11,-5,0,18,28,2,0,7,34,6),C(0,9,12,-6,0,19,29,2,0,7,36,6),C(0,10,13,-6,0,20,31,3,0,8,38,7),C(0,10,13,-6,0,21,33,3,0,8,40,7),C(0,10,14,-6,0,22,35,3,0,8,42,7),C(0,11,14,-7,0,23,36,3,0,9,44,8),C(0,11,15,-7,0,24,38,3,0,9,46,8)],j={borderRadius:4};function P(){var e,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:8;if(t.mui)return t;e="function"===typeof t?t:function(e){return t*e};var n=function(){for(var t=arguments.length,n=new Array(t),r=0;r<t;r++)n[r]=arguments[r];return 0===n.length?e(1):1===n.length?e(n[0]):n.map((function(t){var n=e(t);return"number"===typeof n?"".concat(n,"px"):n})).join(" ")};return Object.defineProperty(n,"unit",{get:function(){return t}}),n.mui=!0,n}var R={easeInOut:"cubic-bezier(0.4, 0, 0.2, 1)",easeOut:"cubic-bezier(0.0, 0, 0.2, 1)",easeIn:"cubic-bezier(0.4, 0, 1, 1)",sharp:"cubic-bezier(0.4, 0, 0.6, 1)"},N={shortest:150,shorter:200,short:250,standard:300,complex:375,enteringScreen:225,leavingScreen:195},M=function(e){return"".concat(Math.round(e),"ms")},_={easing:R,duration:N,create:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:["all"],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.duration,r=void 0===n?N.standard:n,a=t.easing,i=void 0===a?R.easeInOut:a,l=t.delay,u=void 0===l?0:l;Object(o.a)(t,["duration","easing","delay"]);return(Array.isArray(e)?e:[e]).map((function(e){return"".concat(e," ").concat("string"===typeof r?r:M(r)," ").concat(i," ").concat("string"===typeof u?u:M(u))})).join(",")},getAutoHeightDuration:function(e){if(!e)return 0;var t=e/36;return Math.round(10*(4+15*Math.pow(t,.25)+t/5))}},A=n(59);t.a=function(){for(var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.breakpoints,n=void 0===t?{}:t,r=e.mixins,i=void 0===r?{}:r,l=e.palette,s=void 0===l?{}:l,d=e.spacing,f=e.typography,p=void 0===f?{}:f,h=Object(o.a)(e,["breakpoints","mixins","palette","spacing","typography"]),m=k(s),v=u(n),b=P(d),y=Object(a.a)({breakpoints:v,direction:"ltr",mixins:c(v,b,i),overrides:{},palette:m,props:{},shadows:T,typography:S(m,p),spacing:b,shape:j,transitions:_,zIndex:A.a},h),g=arguments.length,x=new Array(g>1?g-1:0),w=1;w<g;w++)x[w-1]=arguments[w];return y=x.reduce((function(e,t){return Object(a.a)(e,t)}),y)}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a=n(57);function i(){return o.a.useContext(a.a)}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(9)),u=n.n(l),c=n(3),s=n(8),d=n(30),f=n(4),p="undefined"!==typeof window?i.a.useLayoutEffect:i.a.useEffect;var h=function(e){var t=e.children,n=e.defer,r=void 0!==n&&n,o=e.fallback,a=void 0===o?null:o,l=i.a.useState(!1),u=l[0],c=l[1];return p((function(){r||c(!0)}),[r]),i.a.useEffect((function(){r&&c(!0)}),[r]),i.a.createElement(i.a.Fragment,null,u?t:a)},m=!0,v=!1,b=null,y={text:!0,search:!0,url:!0,tel:!0,email:!0,password:!0,number:!0,date:!0,month:!0,week:!0,time:!0,datetime:!0,"datetime-local":!0};function g(e){e.metaKey||e.altKey||e.ctrlKey||(m=!0)}function x(){m=!1}function w(){"hidden"===this.visibilityState&&v&&(m=!0)}function k(e){var t=e.target;try{return t.matches(":focus-visible")}catch(n){}return m||function(e){var t=e.type,n=e.tagName;return!("INPUT"!==n||!y[t]||e.readOnly)||("TEXTAREA"===n&&!e.readOnly||!!e.isContentEditable)}(t)}function E(){v=!0,window.clearTimeout(b),b=window.setTimeout((function(){v=!1}),100)}function O(){return{isFocusVisible:k,onBlurVisible:E,ref:i.a.useCallback((function(e){var t,n=u.a.findDOMNode(e);null!=n&&((t=n.ownerDocument).addEventListener("keydown",g,!0),t.addEventListener("mousedown",x,!0),t.addEventListener("pointerdown",x,!0),t.addEventListener("touchstart",x,!0),t.addEventListener("visibilitychange",w,!0))}),[])}}var S=n(11),C=n(15),T=n(12),j=n(49),P=n(43);function R(e,t){var n=Object.create(null);return e&&a.Children.map(e,(function(e){return e})).forEach((function(e){n[e.key]=function(e){return t&&Object(a.isValidElement)(e)?t(e):e}(e)})),n}function N(e,t,n){return null!=n[t]?n[t]:e.props[t]}function M(e,t,n){var r=R(e.children),o=function(e,t){function n(n){return n in t?t[n]:e[n]}e=e||{},t=t||{};var r,o=Object.create(null),a=[];for(var i in e)i in t?a.length&&(o[i]=a,a=[]):a.push(i);var l={};for(var u in t){if(o[u])for(r=0;r<o[u].length;r++){var c=o[u][r];l[o[u][r]]=n(c)}l[u]=n(u)}for(r=0;r<a.length;r++)l[a[r]]=n(a[r]);return l}(t,r);return Object.keys(o).forEach((function(i){var l=o[i];if(Object(a.isValidElement)(l)){var u=i in t,c=i in r,s=t[i],d=Object(a.isValidElement)(s)&&!s.props.in;!c||u&&!d?c||!u||d?c&&u&&Object(a.isValidElement)(s)&&(o[i]=Object(a.cloneElement)(l,{onExited:n.bind(null,l),in:s.props.in,exit:N(l,"exit",e),enter:N(l,"enter",e)})):o[i]=Object(a.cloneElement)(l,{in:!1}):o[i]=Object(a.cloneElement)(l,{onExited:n.bind(null,l),in:!0,exit:N(l,"exit",e),enter:N(l,"enter",e)})}})),o}var _=Object.values||function(e){return Object.keys(e).map((function(t){return e[t]}))},A=function(e){function t(t,n){var r,o=(r=e.call(this,t,n)||this).handleExited.bind(Object(j.a)(Object(j.a)(r)));return r.state={contextValue:{isMounting:!0},handleExited:o,firstRender:!0},r}Object(T.a)(t,e);var n=t.prototype;return n.componentDidMount=function(){this.mounted=!0,this.setState({contextValue:{isMounting:!1}})},n.componentWillUnmount=function(){this.mounted=!1},t.getDerivedStateFromProps=function(e,t){var n,r,o=t.children,i=t.handleExited;return{children:t.firstRender?(n=e,r=i,R(n.children,(function(e){return Object(a.cloneElement)(e,{onExited:r.bind(null,e),in:!0,appear:N(e,"appear",n),enter:N(e,"enter",n),exit:N(e,"exit",n)})}))):M(e,o,i),firstRender:!1}},n.handleExited=function(e,t){var n=R(this.props.children);e.key in n||(e.props.onExited&&e.props.onExited(t),this.mounted&&this.setState((function(t){var n=Object(r.a)({},t.children);return delete n[e.key],{children:n}})))},n.render=function(){var e=this.props,t=e.component,n=e.childFactory,r=Object(C.a)(e,["component","childFactory"]),o=this.state.contextValue,a=_(this.state.children).map(n);return delete r.appear,delete r.enter,delete r.exit,null===t?i.a.createElement(P.a.Provider,{value:o},a):i.a.createElement(P.a.Provider,{value:o},i.a.createElement(t,r,a))},t}(i.a.Component);A.propTypes={},A.defaultProps={component:"div",childFactory:function(e){return e}};var z=A,I="undefined"===typeof window?i.a.useEffect:i.a.useLayoutEffect;var L=function(e){var t=e.classes,n=e.pulsate,r=void 0!==n&&n,o=e.rippleX,a=e.rippleY,l=e.rippleSize,u=e.in,s=e.onExited,f=void 0===s?function(){}:s,p=e.timeout,h=i.a.useState(!1),m=h[0],v=h[1],b=Object(c.a)(t.ripple,t.rippleVisible,r&&t.ripplePulsate),y={width:l,height:l,top:-l/2+a,left:-l/2+o},g=Object(c.a)(t.child,m&&t.childLeaving,r&&t.childPulsate),x=Object(d.a)(f);return I((function(){if(!u){v(!0);var e=setTimeout(x,p);return function(){clearTimeout(e)}}}),[x,u,p]),i.a.createElement("span",{className:b,style:y},i.a.createElement("span",{className:g}))},D=i.a.forwardRef((function(e,t){var n=e.center,a=void 0!==n&&n,l=e.classes,u=e.className,s=Object(o.a)(e,["center","classes","className"]),d=i.a.useState([]),f=d[0],p=d[1],h=i.a.useRef(0),m=i.a.useRef(null);i.a.useEffect((function(){m.current&&(m.current(),m.current=null)}),[f]);var v=i.a.useRef(!1),b=i.a.useRef(null),y=i.a.useRef(null),g=i.a.useRef(null);i.a.useEffect((function(){return function(){clearTimeout(b.current)}}),[]);var x=i.a.useCallback((function(e){var t=e.pulsate,n=e.rippleX,r=e.rippleY,o=e.rippleSize,a=e.cb;p((function(e){return[].concat(Object(S.a)(e),[i.a.createElement(L,{key:h.current,classes:l,timeout:550,pulsate:t,rippleX:n,rippleY:r,rippleSize:o})])})),h.current+=1,m.current=a}),[l]),w=i.a.useCallback((function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=arguments.length>2?arguments[2]:void 0,r=t.pulsate,o=void 0!==r&&r,i=t.center,l=void 0===i?a||t.pulsate:i,u=t.fakeElement,c=void 0!==u&&u;if("mousedown"===e.type&&v.current)v.current=!1;else{"touchstart"===e.type&&(v.current=!0);var s,d,f,p=c?null:g.current,h=p?p.getBoundingClientRect():{width:0,height:0,left:0,top:0};if(l||0===e.clientX&&0===e.clientY||!e.clientX&&!e.touches)s=Math.round(h.width/2),d=Math.round(h.height/2);else{var m=e.clientX?e.clientX:e.touches[0].clientX,w=e.clientY?e.clientY:e.touches[0].clientY;s=Math.round(m-h.left),d=Math.round(w-h.top)}if(l)(f=Math.sqrt((2*Math.pow(h.width,2)+Math.pow(h.height,2))/3))%2===0&&(f+=1);else{var k=2*Math.max(Math.abs((p?p.clientWidth:0)-s),s)+2,E=2*Math.max(Math.abs((p?p.clientHeight:0)-d),d)+2;f=Math.sqrt(Math.pow(k,2)+Math.pow(E,2))}e.touches?(y.current=function(){x({pulsate:o,rippleX:s,rippleY:d,rippleSize:f,cb:n})},b.current=setTimeout((function(){y.current&&(y.current(),y.current=null)}),80)):x({pulsate:o,rippleX:s,rippleY:d,rippleSize:f,cb:n})}}),[a,x]),k=i.a.useCallback((function(){w({},{pulsate:!0})}),[w]),E=i.a.useCallback((function(e,t){if(clearTimeout(b.current),"touchend"===e.type&&y.current)return e.persist(),y.current(),y.current=null,void(b.current=setTimeout((function(){E(e,t)})));y.current=null,p((function(e){return e.length>0?e.slice(1):e})),m.current=t}),[]);return i.a.useImperativeHandle(t,(function(){return{pulsate:k,start:w,stop:E}}),[k,w,E]),i.a.createElement("span",Object(r.a)({className:Object(c.a)(l.root,u),ref:g},s),i.a.createElement(z,{component:null,exit:!0},f))}));var F,U=Object(f.a)((function(e){return{root:{overflow:"hidden",pointerEvents:"none",position:"absolute",zIndex:0,top:0,right:0,bottom:0,left:0,borderRadius:"inherit"},ripple:{opacity:0,position:"absolute"},rippleVisible:{opacity:.3,transform:"scale(1)",animation:"$enter ".concat(550,"ms ").concat(e.transitions.easing.easeInOut)},ripplePulsate:{animationDuration:"".concat(e.transitions.duration.shorter,"ms")},child:{opacity:1,display:"block",width:"100%",height:"100%",borderRadius:"50%",backgroundColor:"currentColor"},childLeaving:{opacity:0,animation:"$exit ".concat(550,"ms ").concat(e.transitions.easing.easeInOut)},childPulsate:{position:"absolute",left:0,top:0,animation:"$pulsate 2500ms ".concat(e.transitions.easing.easeInOut," 200ms infinite")},"@keyframes enter":{"0%":{transform:"scale(0)",opacity:.1},"100%":{transform:"scale(1)",opacity:.3}},"@keyframes exit":{"0%":{opacity:1},"100%":{opacity:0}},"@keyframes pulsate":{"0%":{transform:"scale(1)"},"50%":{transform:"scale(0.92)"},"100%":{transform:"scale(1)"}}}}),{flip:!1,name:"MuiTouchRipple"})(((F=i.a.memo(D)).muiName="MuiTouchRipple",F)),$=i.a.forwardRef((function(e,t){var n=e.action,a=e.buttonRef,l=e.centerRipple,f=void 0!==l&&l,p=e.children,m=e.classes,v=e.className,b=e.component,y=void 0===b?"button":b,g=e.disabled,x=void 0!==g&&g,w=e.disableRipple,k=void 0!==w&&w,E=e.disableTouchRipple,S=void 0!==E&&E,C=e.focusRipple,T=void 0!==C&&C,j=e.focusVisibleClassName,P=e.onBlur,R=e.onClick,N=e.onFocus,M=e.onFocusVisible,_=e.onKeyDown,A=e.onKeyUp,z=e.onMouseDown,I=e.onMouseLeave,L=e.onMouseUp,D=e.onTouchEnd,F=e.onTouchMove,$=e.onTouchStart,B=e.onDragLeave,W=e.tabIndex,V=void 0===W?0:W,H=e.TouchRippleProps,q=e.type,K=void 0===q?"button":q,Q=Object(o.a)(e,["action","buttonRef","centerRipple","children","classes","className","component","disabled","disableRipple","disableTouchRipple","focusRipple","focusVisibleClassName","onBlur","onClick","onFocus","onFocusVisible","onKeyDown","onKeyUp","onMouseDown","onMouseLeave","onMouseUp","onTouchEnd","onTouchMove","onTouchStart","onDragLeave","tabIndex","TouchRippleProps","type"]),X=i.a.useRef(null);var G=i.a.useRef(null),Y=i.a.useState(!1),J=Y[0],Z=Y[1];x&&J&&Z(!1);var ee=O(),te=ee.isFocusVisible,ne=ee.onBlurVisible,re=ee.ref;function oe(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:S;return Object(d.a)((function(r){return t&&t(r),!n&&G.current&&G.current[e](r),!0}))}i.a.useImperativeHandle(n,(function(){return{focusVisible:function(){Z(!0),X.current.focus()}}}),[]),i.a.useEffect((function(){J&&T&&!k&&G.current.pulsate()}),[k,T,J]);var ae=oe("start",z),ie=oe("stop",B),le=oe("stop",L),ue=oe("stop",(function(e){J&&e.preventDefault(),I&&I(e)})),ce=oe("start",$),se=oe("stop",D),de=oe("stop",F),fe=oe("stop",(function(e){J&&(ne(e),Z(!1)),P&&P(e)}),!1),pe=Object(d.a)((function(e){x||(X.current||(X.current=e.currentTarget),te(e)&&(Z(!0),M&&M(e)),N&&N(e))})),he=function(){var e=u.a.findDOMNode(X.current);return y&&"button"!==y&&!("A"===e.tagName&&e.href)},me=i.a.useRef(!1),ve=Object(d.a)((function(e){T&&!me.current&&J&&G.current&&" "===e.key&&(me.current=!0,e.persist(),G.current.stop(e,(function(){G.current.start(e)}))),_&&_(e),e.target===e.currentTarget&&he()&&"Enter"===e.key&&(e.preventDefault(),R&&R(e))})),be=Object(d.a)((function(e){T&&" "===e.key&&G.current&&J&&!e.defaultPrevented&&(me.current=!1,e.persist(),G.current.stop(e,(function(){G.current.pulsate(e)}))),A&&A(e),e.target===e.currentTarget&&he()&&" "===e.key&&!e.defaultPrevented&&(e.preventDefault(),R&&R(e))})),ye=y;"button"===ye&&Q.href&&(ye="a");var ge={};"button"===ye?(ge.type=K,ge.disabled=x):("a"===ye&&Q.href||(ge.role="button"),ge["aria-disabled"]=x);var xe=Object(s.a)(a,t),we=Object(s.a)(re,X),ke=Object(s.a)(xe,we);return i.a.createElement(ye,Object(r.a)({className:Object(c.a)(m.root,v,J&&[m.focusVisible,j],x&&m.disabled),onBlur:fe,onClick:R,onFocus:pe,onKeyDown:ve,onKeyUp:be,onMouseDown:ae,onMouseLeave:ue,onMouseUp:le,onDragLeave:ie,onTouchEnd:se,onTouchMove:de,onTouchStart:ce,ref:ke,tabIndex:x?-1:V},ge,Q),p,k||x?null:i.a.createElement(h,null,i.a.createElement(U,Object(r.a)({ref:G,center:f},H))))}));t.a=Object(f.a)({root:{display:"inline-flex",alignItems:"center",justifyContent:"center",position:"relative",WebkitTapHighlightColor:"transparent",backgroundColor:"transparent",outline:0,border:0,margin:0,borderRadius:0,padding:0,cursor:"pointer",userSelect:"none",verticalAlign:"middle","-moz-appearance":"none","-webkit-appearance":"none",textDecoration:"none",color:"inherit","&::-moz-focus-inner":{borderStyle:"none"},"&$disabled":{pointerEvents:"none",cursor:"default"}},disabled:{},focusVisible:{}},{name:"MuiButtonBase"})($)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(24),c=n(40),s=n(4),d=n(6),f=n(8),p=n(61);function h(e,t){return parseInt(e[t],10)||0}var m="undefined"!==typeof window?i.a.useLayoutEffect:i.a.useEffect,v={visibility:"hidden",position:"absolute",overflow:"hidden",height:0,top:0,left:0,transform:"translateZ(0)"},b=i.a.forwardRef((function(e,t){var n=e.onChange,a=e.rows,l=e.rowsMax,u=e.rowsMin,c=void 0===u?1:u,s=e.style,d=e.value,b=Object(o.a)(e,["onChange","rows","rowsMax","rowsMin","style","value"]),y=a||c,g=i.a.useRef(null!=d).current,x=i.a.useRef(null),w=Object(f.a)(t,x),k=i.a.useRef(null),E=i.a.useState({}),O=E[0],S=E[1],C=i.a.useCallback((function(){var t=x.current,n=window.getComputedStyle(t),r=k.current;r.style.width=n.width,r.value=t.value||e.placeholder||"x";var o=n["box-sizing"],a=h(n,"padding-bottom")+h(n,"padding-top"),i=h(n,"border-bottom-width")+h(n,"border-top-width"),u=r.scrollHeight-a;r.value="x";var c=r.scrollHeight-a,s=u;y&&(s=Math.max(Number(y)*c,s)),l&&(s=Math.min(Number(l)*c,s));var d=(s=Math.max(s,c))+("border-box"===o?a+i:0),f=Math.abs(s-u)<=1;S((function(e){return d>0&&Math.abs((e.outerHeightStyle||0)-d)>1||e.overflow!==f?{overflow:f,outerHeightStyle:d}:e}))}),[l,y,e.placeholder]);i.a.useEffect((function(){var e=Object(p.a)((function(){C()}));return window.addEventListener("resize",e),function(){e.clear(),window.removeEventListener("resize",e)}}),[C]),m((function(){C()}));return i.a.createElement(i.a.Fragment,null,i.a.createElement("textarea",Object(r.a)({value:d,onChange:function(e){g||C(),n&&n(e)},ref:w,rows:y,style:Object(r.a)({height:O.outerHeightStyle,overflow:O.overflow?"hidden":null},s)},b)),i.a.createElement("textarea",{"aria-hidden":!0,className:e.className,readOnly:!0,ref:k,tabIndex:-1,style:Object(r.a)({},v,{},s)}))})),y=n(41),g="undefined"===typeof window?i.a.useEffect:i.a.useLayoutEffect,x=i.a.forwardRef((function(e,t){var n=e["aria-describedby"],a=e.autoComplete,s=e.autoFocus,p=e.classes,h=e.className,m=(e.color,e.defaultValue),v=e.disabled,x=e.endAdornment,w=(e.error,e.fullWidth),k=void 0!==w&&w,E=e.id,O=e.inputComponent,S=void 0===O?"input":O,C=e.inputProps,T=void 0===C?{}:C,j=e.inputRef,P=(e.margin,e.multiline),R=void 0!==P&&P,N=e.name,M=e.onBlur,_=e.onChange,A=e.onClick,z=e.onFocus,I=e.onKeyDown,L=e.onKeyUp,D=e.placeholder,F=e.readOnly,U=e.renderSuffix,$=e.rows,B=e.rowsMax,W=e.rowsMin,V=e.startAdornment,H=e.type,q=void 0===H?"text":H,K=e.value,Q=Object(o.a)(e,["aria-describedby","autoComplete","autoFocus","classes","className","color","defaultValue","disabled","endAdornment","error","fullWidth","id","inputComponent","inputProps","inputRef","margin","multiline","name","onBlur","onChange","onClick","onFocus","onKeyDown","onKeyUp","placeholder","readOnly","renderSuffix","rows","rowsMax","rowsMin","startAdornment","type","value"]),X=null!=T.value?T.value:K,G=i.a.useRef(null!=X).current,Y=i.a.useRef(),J=i.a.useCallback((function(e){0}),[]),Z=Object(f.a)(T.ref,J),ee=Object(f.a)(j,Z),te=Object(f.a)(Y,ee),ne=i.a.useState(!1),re=ne[0],oe=ne[1],ae=Object(c.b)();var ie=Object(u.a)({props:e,muiFormControl:ae,states:["color","disabled","error","hiddenLabel","margin","required","filled"]});ie.focused=ae?ae.focused:re,i.a.useEffect((function(){!ae&&v&&re&&(oe(!1),M&&M())}),[ae,v,re,M]);var le=ae&&ae.onFilled,ue=ae&&ae.onEmpty,ce=i.a.useCallback((function(e){Object(y.b)(e)?le&&le():ue&&ue()}),[le,ue]);g((function(){G&&ce({value:X})}),[X,ce,G]);i.a.useEffect((function(){ce(Y.current)}),[]);var se=S,de=Object(r.a)({},T,{ref:te});"string"!==typeof se?de=Object(r.a)({inputRef:te,type:q},de,{ref:null}):R?!$||B||W?(de=Object(r.a)({rows:$,rowsMax:B},de),se=b):se="textarea":de=Object(r.a)({type:q},de);return i.a.useEffect((function(){ae&&ae.setAdornedStart(Boolean(V))}),[ae,V]),i.a.createElement("div",Object(r.a)({className:Object(l.a)(p.root,p["color".concat(Object(d.a)(ie.color||"primary"))],h,ie.disabled&&p.disabled,ie.error&&p.error,k&&p.fullWidth,ie.focused&&p.focused,ae&&p.formControl,R&&p.multiline,V&&p.adornedStart,x&&p.adornedEnd,{dense:p.marginDense}[ie.margin]),onClick:function(e){Y.current&&e.currentTarget===e.target&&Y.current.focus(),A&&A(e)},ref:t},Q),V,i.a.createElement(c.a.Provider,{value:null},i.a.createElement(se,Object(r.a)({"aria-invalid":ie.error,"aria-describedby":n,autoComplete:a,autoFocus:s,defaultValue:m,disabled:ie.disabled,id:E,onAnimationStart:function(e){ce(-1!==e.animationName.indexOf("auto-fill-cancel")?Y.current:{value:"x"})},name:N,placeholder:D,readOnly:F,required:ie.required,rows:$,value:X,onKeyDown:I,onKeyUp:L},de,{className:Object(l.a)(p.input,T.className,ie.disabled&&p.disabled,R&&p.inputMultiline,ie.hiddenLabel&&p.inputHiddenLabel,V&&p.inputAdornedStart,x&&p.inputAdornedEnd,{search:p.inputTypeSearch}[q],{dense:p.inputMarginDense}[ie.margin]),onBlur:function(e){M&&M(e),T.onBlur&&T.onBlur(e),ae&&ae.onBlur?ae.onBlur(e):oe(!1)},onChange:function(e){if(!G){var t=e.target||Y.current;if(null==t)throw new TypeError("Material-UI: Expected valid input target. Did you use a custom `inputComponent` and forget to forward refs? See https://material-ui.com/r/input-component-ref-interface for more info.");ce({value:t.value})}for(var n=arguments.length,r=new Array(n>1?n-1:0),o=1;o<n;o++)r[o-1]=arguments[o];T.onChange&&T.onChange.apply(T,[e].concat(r)),_&&_.apply(void 0,[e].concat(r))},onFocus:function(e){ie.disabled?e.stopPropagation():(z&&z(e),T.onFocus&&T.onFocus(e),ae&&ae.onFocus?ae.onFocus(e):oe(!0))}}))),x,U?U(Object(r.a)({},ie,{startAdornment:V})):null)}));t.a=Object(s.a)((function(e){var t="light"===e.palette.type,n={color:"currentColor",opacity:t?.42:.5,transition:e.transitions.create("opacity",{duration:e.transitions.duration.shorter})},r={opacity:"0 !important"},o={opacity:t?.42:.5};return{root:{fontFamily:e.typography.fontFamily,color:e.palette.text.primary,fontSize:e.typography.pxToRem(16),lineHeight:"1.1875em",boxSizing:"border-box",position:"relative",cursor:"text",display:"inline-flex",alignItems:"center","&$disabled":{color:e.palette.text.disabled,cursor:"default"}},formControl:{},focused:{},disabled:{},adornedStart:{},adornedEnd:{},error:{},marginDense:{},multiline:{padding:"".concat(6,"px 0 ").concat(7,"px"),"&$marginDense":{paddingTop:3}},colorSecondary:{},fullWidth:{width:"100%"},input:{font:"inherit",color:"currentColor",padding:"".concat(6,"px 0 ").concat(7,"px"),border:0,boxSizing:"content-box",background:"none",height:"1.1875em",margin:0,WebkitTapHighlightColor:"transparent",display:"block",minWidth:0,width:"100%",animationName:"$auto-fill-cancel","&::-webkit-input-placeholder":n,"&::-moz-placeholder":n,"&:-ms-input-placeholder":n,"&::-ms-input-placeholder":n,"&:focus":{outline:0},"&:invalid":{boxShadow:"none"},"&::-webkit-search-decoration":{"-webkit-appearance":"none"},"label[data-shrink=false] + $formControl &":{"&::-webkit-input-placeholder":r,"&::-moz-placeholder":r,"&:-ms-input-placeholder":r,"&::-ms-input-placeholder":r,"&:focus::-webkit-input-placeholder":o,"&:focus::-moz-placeholder":o,"&:focus:-ms-input-placeholder":o,"&:focus::-ms-input-placeholder":o},"&$disabled":{opacity:1},"&:-webkit-autofill":{animationDuration:"5000s",animationName:"$auto-fill"}},"@keyframes auto-fill":{from:{}},"@keyframes auto-fill-cancel":{from:{}},inputMarginDense:{paddingTop:3},inputMultiline:{height:"auto",resize:"none",padding:0},inputTypeSearch:{"-moz-appearance":"textfield","-webkit-appearance":"textfield"},inputAdornedStart:{},inputAdornedEnd:{},inputHiddenLabel:{}}}),{name:"MuiInputBase"})(x)},,,,,,,function(e,t,n){"use strict";var r=n(73),o="function"===typeof Symbol&&Symbol.for,a=o?Symbol.for("react.element"):60103,i=o?Symbol.for("react.portal"):60106,l=o?Symbol.for("react.fragment"):60107,u=o?Symbol.for("react.strict_mode"):60108,c=o?Symbol.for("react.profiler"):60114,s=o?Symbol.for("react.provider"):60109,d=o?Symbol.for("react.context"):60110,f=o?Symbol.for("react.forward_ref"):60112,p=o?Symbol.for("react.suspense"):60113;o&&Symbol.for("react.suspense_list");var h=o?Symbol.for("react.memo"):60115,m=o?Symbol.for("react.lazy"):60116;o&&Symbol.for("react.fundamental"),o&&Symbol.for("react.responder"),o&&Symbol.for("react.scope");var v="function"===typeof Symbol&&Symbol.iterator;function b(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n<arguments.length;n++)t+="&args[]="+encodeURIComponent(arguments[n]);return"Minified React error #"+e+"; visit "+t+" for the full message or use the non-minified dev environment for full errors and additional helpful warnings."}var y={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},g={};function x(e,t,n){this.props=e,this.context=t,this.refs=g,this.updater=n||y}function w(){}function k(e,t,n){this.props=e,this.context=t,this.refs=g,this.updater=n||y}x.prototype.isReactComponent={},x.prototype.setState=function(e,t){if("object"!==typeof e&&"function"!==typeof e&&null!=e)throw Error(b(85));this.updater.enqueueSetState(this,e,t,"setState")},x.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},w.prototype=x.prototype;var E=k.prototype=new w;E.constructor=k,r(E,x.prototype),E.isPureReactComponent=!0;var O={current:null},S={current:null},C=Object.prototype.hasOwnProperty,T={key:!0,ref:!0,__self:!0,__source:!0};function j(e,t,n){var r,o={},i=null,l=null;if(null!=t)for(r in void 0!==t.ref&&(l=t.ref),void 0!==t.key&&(i=""+t.key),t)C.call(t,r)&&!T.hasOwnProperty(r)&&(o[r]=t[r]);var u=arguments.length-2;if(1===u)o.children=n;else if(1<u){for(var c=Array(u),s=0;s<u;s++)c[s]=arguments[s+2];o.children=c}if(e&&e.defaultProps)for(r in u=e.defaultProps)void 0===o[r]&&(o[r]=u[r]);return{$$typeof:a,type:e,key:i,ref:l,props:o,_owner:S.current}}function P(e){return"object"===typeof e&&null!==e&&e.$$typeof===a}var R=/\/+/g,N=[];function M(e,t,n,r){if(N.length){var o=N.pop();return o.result=e,o.keyPrefix=t,o.func=n,o.context=r,o.count=0,o}return{result:e,keyPrefix:t,func:n,context:r,count:0}}function _(e){e.result=null,e.keyPrefix=null,e.func=null,e.context=null,e.count=0,10>N.length&&N.push(e)}function A(e,t,n){return null==e?0:function e(t,n,r,o){var l=typeof t;"undefined"!==l&&"boolean"!==l||(t=null);var u=!1;if(null===t)u=!0;else switch(l){case"string":case"number":u=!0;break;case"object":switch(t.$$typeof){case a:case i:u=!0}}if(u)return r(o,t,""===n?"."+z(t,0):n),1;if(u=0,n=""===n?".":n+":",Array.isArray(t))for(var c=0;c<t.length;c++){var s=n+z(l=t[c],c);u+=e(l,s,r,o)}else if(null===t||"object"!==typeof t?s=null:s="function"===typeof(s=v&&t[v]||t["@@iterator"])?s:null,"function"===typeof s)for(t=s.call(t),c=0;!(l=t.next()).done;)u+=e(l=l.value,s=n+z(l,c++),r,o);else if("object"===l)throw r=""+t,Error(b(31,"[object Object]"===r?"object with keys {"+Object.keys(t).join(", ")+"}":r,""));return u}(e,"",t,n)}function z(e,t){return"object"===typeof e&&null!==e&&null!=e.key?function(e){var t={"=":"=0",":":"=2"};return"$"+(""+e).replace(/[=:]/g,(function(e){return t[e]}))}(e.key):t.toString(36)}function I(e,t){e.func.call(e.context,t,e.count++)}function L(e,t,n){var r=e.result,o=e.keyPrefix;e=e.func.call(e.context,t,e.count++),Array.isArray(e)?D(e,r,n,(function(e){return e})):null!=e&&(P(e)&&(e=function(e,t){return{$$typeof:a,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(e,o+(!e.key||t&&t.key===e.key?"":(""+e.key).replace(R,"$&/")+"/")+n)),r.push(e))}function D(e,t,n,r,o){var a="";null!=n&&(a=(""+n).replace(R,"$&/")+"/"),A(e,L,t=M(t,a,r,o)),_(t)}function F(){var e=O.current;if(null===e)throw Error(b(321));return e}var U={Children:{map:function(e,t,n){if(null==e)return e;var r=[];return D(e,r,null,t,n),r},forEach:function(e,t,n){if(null==e)return e;A(e,I,t=M(null,null,t,n)),_(t)},count:function(e){return A(e,(function(){return null}),null)},toArray:function(e){var t=[];return D(e,t,null,(function(e){return e})),t},only:function(e){if(!P(e))throw Error(b(143));return e}},createRef:function(){return{current:null}},Component:x,PureComponent:k,createContext:function(e,t){return void 0===t&&(t=null),(e={$$typeof:d,_calculateChangedBits:t,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null}).Provider={$$typeof:s,_context:e},e.Consumer=e},forwardRef:function(e){return{$$typeof:f,render:e}},lazy:function(e){return{$$typeof:m,_ctor:e,_status:-1,_result:null}},memo:function(e,t){return{$$typeof:h,type:e,compare:void 0===t?null:t}},useCallback:function(e,t){return F().useCallback(e,t)},useContext:function(e,t){return F().useContext(e,t)},useEffect:function(e,t){return F().useEffect(e,t)},useImperativeHandle:function(e,t,n){return F().useImperativeHandle(e,t,n)},useDebugValue:function(){},useLayoutEffect:function(e,t){return F().useLayoutEffect(e,t)},useMemo:function(e,t){return F().useMemo(e,t)},useReducer:function(e,t,n){return F().useReducer(e,t,n)},useRef:function(e){return F().useRef(e)},useState:function(e){return F().useState(e)},Fragment:l,Profiler:c,StrictMode:u,Suspense:p,createElement:j,cloneElement:function(e,t,n){if(null===e||void 0===e)throw Error(b(267,e));var o=r({},e.props),i=e.key,l=e.ref,u=e._owner;if(null!=t){if(void 0!==t.ref&&(l=t.ref,u=S.current),void 0!==t.key&&(i=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(s in t)C.call(t,s)&&!T.hasOwnProperty(s)&&(o[s]=void 0===t[s]&&void 0!==c?c[s]:t[s])}var s=arguments.length-2;if(1===s)o.children=n;else if(1<s){c=Array(s);for(var d=0;d<s;d++)c[d]=arguments[d+2];o.children=c}return{$$typeof:a,type:e.type,key:i,ref:l,props:o,_owner:u}},createFactory:function(e){var t=j.bind(null,e);return t.type=e,t},isValidElement:P,version:"16.12.0",__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{ReactCurrentDispatcher:O,ReactCurrentBatchConfig:{suspense:null},ReactCurrentOwner:S,IsSomeRendererActing:{current:!1},assign:r}},$={default:U},B=$&&U||$;e.exports=B.default||B},function(e,t,n){"use strict";var r=n(0),o=n(73),a=n(104);function i(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n<arguments.length;n++)t+="&args[]="+encodeURIComponent(arguments[n]);return"Minified React error #"+e+"; visit "+t+" for the full message or use the non-minified dev environment for full errors and additional helpful warnings."}if(!r)throw Error(i(227));var l=null,u={};function c(){if(l)for(var e in u){var t=u[e],n=l.indexOf(e);if(!(-1<n))throw Error(i(96,e));if(!d[n]){if(!t.extractEvents)throw Error(i(97,e));for(var r in d[n]=t,n=t.eventTypes){var o=void 0,a=n[r],c=t,p=r;if(f.hasOwnProperty(p))throw Error(i(99,p));f[p]=a;var h=a.phasedRegistrationNames;if(h){for(o in h)h.hasOwnProperty(o)&&s(h[o],c,p);o=!0}else a.registrationName?(s(a.registrationName,c,p),o=!0):o=!1;if(!o)throw Error(i(98,r,e))}}}}function s(e,t,n){if(p[e])throw Error(i(100,e));p[e]=t,h[e]=t.eventTypes[n].dependencies}var d=[],f={},p={},h={};function m(e,t,n,r,o,a,i,l,u){var c=Array.prototype.slice.call(arguments,3);try{t.apply(n,c)}catch(s){this.onError(s)}}var v=!1,b=null,y=!1,g=null,x={onError:function(e){v=!0,b=e}};function w(e,t,n,r,o,a,i,l,u){v=!1,b=null,m.apply(x,arguments)}var k=null,E=null,O=null;function S(e,t,n){var r=e.type||"unknown-event";e.currentTarget=O(n),function(e,t,n,r,o,a,l,u,c){if(w.apply(this,arguments),v){if(!v)throw Error(i(198));var s=b;v=!1,b=null,y||(y=!0,g=s)}}(r,t,void 0,e),e.currentTarget=null}function C(e,t){if(null==t)throw Error(i(30));return null==e?t:Array.isArray(e)?Array.isArray(t)?(e.push.apply(e,t),e):(e.push(t),e):Array.isArray(t)?[e].concat(t):[e,t]}function T(e,t,n){Array.isArray(e)?e.forEach(t,n):e&&t.call(n,e)}var j=null;function P(e){if(e){var t=e._dispatchListeners,n=e._dispatchInstances;if(Array.isArray(t))for(var r=0;r<t.length&&!e.isPropagationStopped();r++)S(e,t[r],n[r]);else t&&S(e,t,n);e._dispatchListeners=null,e._dispatchInstances=null,e.isPersistent()||e.constructor.release(e)}}function R(e){if(null!==e&&(j=C(j,e)),e=j,j=null,e){if(T(e,P),j)throw Error(i(95));if(y)throw e=g,y=!1,g=null,e}}var N={injectEventPluginOrder:function(e){if(l)throw Error(i(101));l=Array.prototype.slice.call(e),c()},injectEventPluginsByName:function(e){var t,n=!1;for(t in e)if(e.hasOwnProperty(t)){var r=e[t];if(!u.hasOwnProperty(t)||u[t]!==r){if(u[t])throw Error(i(102,t));u[t]=r,n=!0}}n&&c()}};function M(e,t){var n=e.stateNode;if(!n)return null;var r=k(n);if(!r)return null;n=r[t];e:switch(t){case"onClick":case"onClickCapture":case"onDoubleClick":case"onDoubleClickCapture":case"onMouseDown":case"onMouseDownCapture":case"onMouseMove":case"onMouseMoveCapture":case"onMouseUp":case"onMouseUpCapture":(r=!r.disabled)||(r=!("button"===(e=e.type)||"input"===e||"select"===e||"textarea"===e)),e=!r;break e;default:e=!1}if(e)return null;if(n&&"function"!==typeof n)throw Error(i(231,t,typeof n));return n}var _=r.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;_.hasOwnProperty("ReactCurrentDispatcher")||(_.ReactCurrentDispatcher={current:null}),_.hasOwnProperty("ReactCurrentBatchConfig")||(_.ReactCurrentBatchConfig={suspense:null});var A=/^(.*)[\\\/]/,z="function"===typeof Symbol&&Symbol.for,I=z?Symbol.for("react.element"):60103,L=z?Symbol.for("react.portal"):60106,D=z?Symbol.for("react.fragment"):60107,F=z?Symbol.for("react.strict_mode"):60108,U=z?Symbol.for("react.profiler"):60114,$=z?Symbol.for("react.provider"):60109,B=z?Symbol.for("react.context"):60110,W=z?Symbol.for("react.concurrent_mode"):60111,V=z?Symbol.for("react.forward_ref"):60112,H=z?Symbol.for("react.suspense"):60113,q=z?Symbol.for("react.suspense_list"):60120,K=z?Symbol.for("react.memo"):60115,Q=z?Symbol.for("react.lazy"):60116;z&&Symbol.for("react.fundamental"),z&&Symbol.for("react.responder"),z&&Symbol.for("react.scope");var X="function"===typeof Symbol&&Symbol.iterator;function G(e){return null===e||"object"!==typeof e?null:"function"===typeof(e=X&&e[X]||e["@@iterator"])?e:null}function Y(e){if(null==e)return null;if("function"===typeof e)return e.displayName||e.name||null;if("string"===typeof e)return e;switch(e){case D:return"Fragment";case L:return"Portal";case U:return"Profiler";case F:return"StrictMode";case H:return"Suspense";case q:return"SuspenseList"}if("object"===typeof e)switch(e.$$typeof){case B:return"Context.Consumer";case $:return"Context.Provider";case V:var t=e.render;return t=t.displayName||t.name||"",e.displayName||(""!==t?"ForwardRef("+t+")":"ForwardRef");case K:return Y(e.type);case Q:if(e=1===e._status?e._result:null)return Y(e)}return null}function J(e){var t="";do{e:switch(e.tag){case 3:case 4:case 6:case 7:case 10:case 9:var n="";break e;default:var r=e._debugOwner,o=e._debugSource,a=Y(e.type);n=null,r&&(n=Y(r.type)),r=a,a="",o?a=" (at "+o.fileName.replace(A,"")+":"+o.lineNumber+")":n&&(a=" (created by "+n+")"),n="\n in "+(r||"Unknown")+a}t+=n,e=e.return}while(e);return t}var Z=!("undefined"===typeof window||"undefined"===typeof window.document||"undefined"===typeof window.document.createElement),ee=null,te=null,ne=null;function re(e){if(e=E(e)){if("function"!==typeof ee)throw Error(i(280));var t=k(e.stateNode);ee(e.stateNode,e.type,t)}}function oe(e){te?ne?ne.push(e):ne=[e]:te=e}function ae(){if(te){var e=te,t=ne;if(ne=te=null,re(e),t)for(e=0;e<t.length;e++)re(t[e])}}function ie(e,t){return e(t)}function le(e,t,n,r){return e(t,n,r)}function ue(){}var ce=ie,se=!1,de=!1;function fe(){null===te&&null===ne||(ue(),ae())}new Map;var pe=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,he=Object.prototype.hasOwnProperty,me={},ve={};function be(e,t,n,r,o,a){this.acceptsBooleans=2===t||3===t||4===t,this.attributeName=r,this.attributeNamespace=o,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=a}var ye={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach((function(e){ye[e]=new be(e,0,!1,e,null,!1)})),[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach((function(e){var t=e[0];ye[t]=new be(t,1,!1,e[1],null,!1)})),["contentEditable","draggable","spellCheck","value"].forEach((function(e){ye[e]=new be(e,2,!1,e.toLowerCase(),null,!1)})),["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach((function(e){ye[e]=new be(e,2,!1,e,null,!1)})),"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach((function(e){ye[e]=new be(e,3,!1,e.toLowerCase(),null,!1)})),["checked","multiple","muted","selected"].forEach((function(e){ye[e]=new be(e,3,!0,e,null,!1)})),["capture","download"].forEach((function(e){ye[e]=new be(e,4,!1,e,null,!1)})),["cols","rows","size","span"].forEach((function(e){ye[e]=new be(e,6,!1,e,null,!1)})),["rowSpan","start"].forEach((function(e){ye[e]=new be(e,5,!1,e.toLowerCase(),null,!1)}));var ge=/[\-:]([a-z])/g;function xe(e){return e[1].toUpperCase()}function we(e){switch(typeof e){case"boolean":case"number":case"object":case"string":case"undefined":return e;default:return""}}function ke(e,t,n,r){var o=ye.hasOwnProperty(t)?ye[t]:null;(null!==o?0===o.type:!r&&(2<t.length&&("o"===t[0]||"O"===t[0])&&("n"===t[1]||"N"===t[1])))||(function(e,t,n,r){if(null===t||"undefined"===typeof t||function(e,t,n,r){if(null!==n&&0===n.type)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return!r&&(null!==n?!n.acceptsBooleans:"data-"!==(e=e.toLowerCase().slice(0,5))&&"aria-"!==e);default:return!1}}(e,t,n,r))return!0;if(r)return!1;if(null!==n)switch(n.type){case 3:return!t;case 4:return!1===t;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}(t,n,o,r)&&(n=null),r||null===o?function(e){return!!he.call(ve,e)||!he.call(me,e)&&(pe.test(e)?ve[e]=!0:(me[e]=!0,!1))}(t)&&(null===n?e.removeAttribute(t):e.setAttribute(t,""+n)):o.mustUseProperty?e[o.propertyName]=null===n?3!==o.type&&"":n:(t=o.attributeName,r=o.attributeNamespace,null===n?e.removeAttribute(t):(n=3===(o=o.type)||4===o&&!0===n?"":""+n,r?e.setAttributeNS(r,t,n):e.setAttribute(t,n))))}function Ee(e){var t=e.type;return(e=e.nodeName)&&"input"===e.toLowerCase()&&("checkbox"===t||"radio"===t)}function Oe(e){e._valueTracker||(e._valueTracker=function(e){var t=Ee(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&"undefined"!==typeof n&&"function"===typeof n.get&&"function"===typeof n.set){var o=n.get,a=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return o.call(this)},set:function(e){r=""+e,a.call(this,e)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(e){r=""+e},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}(e))}function Se(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=Ee(e)?e.checked?"true":"false":e.value),(e=r)!==n&&(t.setValue(e),!0)}function Ce(e,t){var n=t.checked;return o({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=n?n:e._wrapperState.initialChecked})}function Te(e,t){var n=null==t.defaultValue?"":t.defaultValue,r=null!=t.checked?t.checked:t.defaultChecked;n=we(null!=t.value?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:"checkbox"===t.type||"radio"===t.type?null!=t.checked:null!=t.value}}function je(e,t){null!=(t=t.checked)&&ke(e,"checked",t,!1)}function Pe(e,t){je(e,t);var n=we(t.value),r=t.type;if(null!=n)"number"===r?(0===n&&""===e.value||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if("submit"===r||"reset"===r)return void e.removeAttribute("value");t.hasOwnProperty("value")?Ne(e,t.type,n):t.hasOwnProperty("defaultValue")&&Ne(e,t.type,we(t.defaultValue)),null==t.checked&&null!=t.defaultChecked&&(e.defaultChecked=!!t.defaultChecked)}function Re(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!("submit"!==r&&"reset"!==r||void 0!==t.value&&null!==t.value))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}""!==(n=e.name)&&(e.name=""),e.defaultChecked=!e.defaultChecked,e.defaultChecked=!!e._wrapperState.initialChecked,""!==n&&(e.name=n)}function Ne(e,t,n){"number"===t&&e.ownerDocument.activeElement===e||(null==n?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}function Me(e,t){return e=o({children:void 0},t),(t=function(e){var t="";return r.Children.forEach(e,(function(e){null!=e&&(t+=e)})),t}(t.children))&&(e.children=t),e}function _e(e,t,n,r){if(e=e.options,t){t={};for(var o=0;o<n.length;o++)t["$"+n[o]]=!0;for(n=0;n<e.length;n++)o=t.hasOwnProperty("$"+e[n].value),e[n].selected!==o&&(e[n].selected=o),o&&r&&(e[n].defaultSelected=!0)}else{for(n=""+we(n),t=null,o=0;o<e.length;o++){if(e[o].value===n)return e[o].selected=!0,void(r&&(e[o].defaultSelected=!0));null!==t||e[o].disabled||(t=e[o])}null!==t&&(t.selected=!0)}}function Ae(e,t){if(null!=t.dangerouslySetInnerHTML)throw Error(i(91));return o({},t,{value:void 0,defaultValue:void 0,children:""+e._wrapperState.initialValue})}function ze(e,t){var n=t.value;if(null==n){if(n=t.defaultValue,null!=(t=t.children)){if(null!=n)throw Error(i(92));if(Array.isArray(t)){if(!(1>=t.length))throw Error(i(93));t=t[0]}n=t}null==n&&(n="")}e._wrapperState={initialValue:we(n)}}function Ie(e,t){var n=we(t.value),r=we(t.defaultValue);null!=n&&((n=""+n)!==e.value&&(e.value=n),null==t.defaultValue&&e.defaultValue!==n&&(e.defaultValue=n)),null!=r&&(e.defaultValue=""+r)}function Le(e){var t=e.textContent;t===e._wrapperState.initialValue&&""!==t&&null!==t&&(e.value=t)}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach((function(e){var t=e.replace(ge,xe);ye[t]=new be(t,1,!1,e,null,!1)})),"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach((function(e){var t=e.replace(ge,xe);ye[t]=new be(t,1,!1,e,"http://www.w3.org/1999/xlink",!1)})),["xml:base","xml:lang","xml:space"].forEach((function(e){var t=e.replace(ge,xe);ye[t]=new be(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1)})),["tabIndex","crossOrigin"].forEach((function(e){ye[e]=new be(e,1,!1,e.toLowerCase(),null,!1)})),ye.xlinkHref=new be("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0),["src","href","action","formAction"].forEach((function(e){ye[e]=new be(e,1,!1,e.toLowerCase(),null,!0)}));var De="http://www.w3.org/1999/xhtml",Fe="http://www.w3.org/2000/svg";function Ue(e){switch(e){case"svg":return"http://www.w3.org/2000/svg";case"math":return"http://www.w3.org/1998/Math/MathML";default:return"http://www.w3.org/1999/xhtml"}}function $e(e,t){return null==e||"http://www.w3.org/1999/xhtml"===e?Ue(t):"http://www.w3.org/2000/svg"===e&&"foreignObject"===t?"http://www.w3.org/1999/xhtml":e}var Be,We=function(e){return"undefined"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(t,n,r,o){MSApp.execUnsafeLocalFunction((function(){return e(t,n)}))}:e}((function(e,t){if(e.namespaceURI!==Fe||"innerHTML"in e)e.innerHTML=t;else{for((Be=Be||document.createElement("div")).innerHTML="<svg>"+t.valueOf().toString()+"</svg>",t=Be.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}}));function Ve(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&3===n.nodeType)return void(n.nodeValue=t)}e.textContent=t}function He(e,t){var n={};return n[e.toLowerCase()]=t.toLowerCase(),n["Webkit"+e]="webkit"+t,n["Moz"+e]="moz"+t,n}var qe={animationend:He("Animation","AnimationEnd"),animationiteration:He("Animation","AnimationIteration"),animationstart:He("Animation","AnimationStart"),transitionend:He("Transition","TransitionEnd")},Ke={},Qe={};function Xe(e){if(Ke[e])return Ke[e];if(!qe[e])return e;var t,n=qe[e];for(t in n)if(n.hasOwnProperty(t)&&t in Qe)return Ke[e]=n[t];return e}Z&&(Qe=document.createElement("div").style,"AnimationEvent"in window||(delete qe.animationend.animation,delete qe.animationiteration.animation,delete qe.animationstart.animation),"TransitionEvent"in window||delete qe.transitionend.transition);var Ge=Xe("animationend"),Ye=Xe("animationiteration"),Je=Xe("animationstart"),Ze=Xe("transitionend"),et="abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange seeked seeking stalled suspend timeupdate volumechange waiting".split(" ");function tt(e){var t=e,n=e;if(e.alternate)for(;t.return;)t=t.return;else{e=t;do{0!==(1026&(t=e).effectTag)&&(n=t.return),e=t.return}while(e)}return 3===t.tag?n:null}function nt(e){if(13===e.tag){var t=e.memoizedState;if(null===t&&(null!==(e=e.alternate)&&(t=e.memoizedState)),null!==t)return t.dehydrated}return null}function rt(e){if(tt(e)!==e)throw Error(i(188))}function ot(e){if(!(e=function(e){var t=e.alternate;if(!t){if(null===(t=tt(e)))throw Error(i(188));return t!==e?null:e}for(var n=e,r=t;;){var o=n.return;if(null===o)break;var a=o.alternate;if(null===a){if(null!==(r=o.return)){n=r;continue}break}if(o.child===a.child){for(a=o.child;a;){if(a===n)return rt(o),e;if(a===r)return rt(o),t;a=a.sibling}throw Error(i(188))}if(n.return!==r.return)n=o,r=a;else{for(var l=!1,u=o.child;u;){if(u===n){l=!0,n=o,r=a;break}if(u===r){l=!0,r=o,n=a;break}u=u.sibling}if(!l){for(u=a.child;u;){if(u===n){l=!0,n=a,r=o;break}if(u===r){l=!0,r=a,n=o;break}u=u.sibling}if(!l)throw Error(i(189))}}if(n.alternate!==r)throw Error(i(190))}if(3!==n.tag)throw Error(i(188));return n.stateNode.current===n?e:t}(e)))return null;for(var t=e;;){if(5===t.tag||6===t.tag)return t;if(t.child)t.child.return=t,t=t.child;else{if(t===e)break;for(;!t.sibling;){if(!t.return||t.return===e)return null;t=t.return}t.sibling.return=t.return,t=t.sibling}}return null}var at,it,lt,ut=!1,ct=[],st=null,dt=null,ft=null,pt=new Map,ht=new Map,mt=[],vt="mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput close cancel copy cut paste click change contextmenu reset submit".split(" "),bt="focus blur dragenter dragleave mouseover mouseout pointerover pointerout gotpointercapture lostpointercapture".split(" ");function yt(e,t,n,r){return{blockedOn:e,topLevelType:t,eventSystemFlags:32|n,nativeEvent:r}}function gt(e,t){switch(e){case"focus":case"blur":st=null;break;case"dragenter":case"dragleave":dt=null;break;case"mouseover":case"mouseout":ft=null;break;case"pointerover":case"pointerout":pt.delete(t.pointerId);break;case"gotpointercapture":case"lostpointercapture":ht.delete(t.pointerId)}}function xt(e,t,n,r,o){return null===e||e.nativeEvent!==o?(e=yt(t,n,r,o),null!==t&&(null!==(t=cr(t))&&it(t)),e):(e.eventSystemFlags|=r,e)}function wt(e){var t=ur(e.target);if(null!==t){var n=tt(t);if(null!==n)if(13===(t=n.tag)){if(null!==(t=nt(n)))return e.blockedOn=t,void a.unstable_runWithPriority(e.priority,(function(){lt(n)}))}else if(3===t&&n.stateNode.hydrate)return void(e.blockedOn=3===n.tag?n.stateNode.containerInfo:null)}e.blockedOn=null}function kt(e){if(null!==e.blockedOn)return!1;var t=Nn(e.topLevelType,e.eventSystemFlags,e.nativeEvent);if(null!==t){var n=cr(t);return null!==n&&it(n),e.blockedOn=t,!1}return!0}function Et(e,t,n){kt(e)&&n.delete(t)}function Ot(){for(ut=!1;0<ct.length;){var e=ct[0];if(null!==e.blockedOn){null!==(e=cr(e.blockedOn))&&at(e);break}var t=Nn(e.topLevelType,e.eventSystemFlags,e.nativeEvent);null!==t?e.blockedOn=t:ct.shift()}null!==st&&kt(st)&&(st=null),null!==dt&&kt(dt)&&(dt=null),null!==ft&&kt(ft)&&(ft=null),pt.forEach(Et),ht.forEach(Et)}function St(e,t){e.blockedOn===t&&(e.blockedOn=null,ut||(ut=!0,a.unstable_scheduleCallback(a.unstable_NormalPriority,Ot)))}function Ct(e){function t(t){return St(t,e)}if(0<ct.length){St(ct[0],e);for(var n=1;n<ct.length;n++){var r=ct[n];r.blockedOn===e&&(r.blockedOn=null)}}for(null!==st&&St(st,e),null!==dt&&St(dt,e),null!==ft&&St(ft,e),pt.forEach(t),ht.forEach(t),n=0;n<mt.length;n++)(r=mt[n]).blockedOn===e&&(r.blockedOn=null);for(;0<mt.length&&null===(n=mt[0]).blockedOn;)wt(n),null===n.blockedOn&&mt.shift()}function Tt(e){return(e=e.target||e.srcElement||window).correspondingUseElement&&(e=e.correspondingUseElement),3===e.nodeType?e.parentNode:e}function jt(e){do{e=e.return}while(e&&5!==e.tag);return e||null}function Pt(e,t,n){(t=M(e,n.dispatchConfig.phasedRegistrationNames[t]))&&(n._dispatchListeners=C(n._dispatchListeners,t),n._dispatchInstances=C(n._dispatchInstances,e))}function Rt(e){if(e&&e.dispatchConfig.phasedRegistrationNames){for(var t=e._targetInst,n=[];t;)n.push(t),t=jt(t);for(t=n.length;0<t--;)Pt(n[t],"captured",e);for(t=0;t<n.length;t++)Pt(n[t],"bubbled",e)}}function Nt(e,t,n){e&&n&&n.dispatchConfig.registrationName&&(t=M(e,n.dispatchConfig.registrationName))&&(n._dispatchListeners=C(n._dispatchListeners,t),n._dispatchInstances=C(n._dispatchInstances,e))}function Mt(e){e&&e.dispatchConfig.registrationName&&Nt(e._targetInst,null,e)}function _t(e){T(e,Rt)}function At(){return!0}function zt(){return!1}function It(e,t,n,r){for(var o in this.dispatchConfig=e,this._targetInst=t,this.nativeEvent=n,e=this.constructor.Interface)e.hasOwnProperty(o)&&((t=e[o])?this[o]=t(n):"target"===o?this.target=r:this[o]=n[o]);return this.isDefaultPrevented=(null!=n.defaultPrevented?n.defaultPrevented:!1===n.returnValue)?At:zt,this.isPropagationStopped=zt,this}function Lt(e,t,n,r){if(this.eventPool.length){var o=this.eventPool.pop();return this.call(o,e,t,n,r),o}return new this(e,t,n,r)}function Dt(e){if(!(e instanceof this))throw Error(i(279));e.destructor(),10>this.eventPool.length&&this.eventPool.push(e)}function Ft(e){e.eventPool=[],e.getPooled=Lt,e.release=Dt}o(It.prototype,{preventDefault:function(){this.defaultPrevented=!0;var e=this.nativeEvent;e&&(e.preventDefault?e.preventDefault():"unknown"!==typeof e.returnValue&&(e.returnValue=!1),this.isDefaultPrevented=At)},stopPropagation:function(){var e=this.nativeEvent;e&&(e.stopPropagation?e.stopPropagation():"unknown"!==typeof e.cancelBubble&&(e.cancelBubble=!0),this.isPropagationStopped=At)},persist:function(){this.isPersistent=At},isPersistent:zt,destructor:function(){var e,t=this.constructor.Interface;for(e in t)this[e]=null;this.nativeEvent=this._targetInst=this.dispatchConfig=null,this.isPropagationStopped=this.isDefaultPrevented=zt,this._dispatchInstances=this._dispatchListeners=null}}),It.Interface={type:null,target:null,currentTarget:function(){return null},eventPhase:null,bubbles:null,cancelable:null,timeStamp:function(e){return e.timeStamp||Date.now()},defaultPrevented:null,isTrusted:null},It.extend=function(e){function t(){}function n(){return r.apply(this,arguments)}var r=this;t.prototype=r.prototype;var a=new t;return o(a,n.prototype),n.prototype=a,n.prototype.constructor=n,n.Interface=o({},r.Interface,e),n.extend=r.extend,Ft(n),n},Ft(It);var Ut=It.extend({animationName:null,elapsedTime:null,pseudoElement:null}),$t=It.extend({clipboardData:function(e){return"clipboardData"in e?e.clipboardData:window.clipboardData}}),Bt=It.extend({view:null,detail:null}),Wt=Bt.extend({relatedTarget:null});function Vt(e){var t=e.keyCode;return"charCode"in e?0===(e=e.charCode)&&13===t&&(e=13):e=t,10===e&&(e=13),32<=e||13===e?e:0}var Ht={Esc:"Escape",Spacebar:" ",Left:"ArrowLeft",Up:"ArrowUp",Right:"ArrowRight",Down:"ArrowDown",Del:"Delete",Win:"OS",Menu:"ContextMenu",Apps:"ContextMenu",Scroll:"ScrollLock",MozPrintableKey:"Unidentified"},qt={8:"Backspace",9:"Tab",12:"Clear",13:"Enter",16:"Shift",17:"Control",18:"Alt",19:"Pause",20:"CapsLock",27:"Escape",32:" ",33:"PageUp",34:"PageDown",35:"End",36:"Home",37:"ArrowLeft",38:"ArrowUp",39:"ArrowRight",40:"ArrowDown",45:"Insert",46:"Delete",112:"F1",113:"F2",114:"F3",115:"F4",116:"F5",117:"F6",118:"F7",119:"F8",120:"F9",121:"F10",122:"F11",123:"F12",144:"NumLock",145:"ScrollLock",224:"Meta"},Kt={Alt:"altKey",Control:"ctrlKey",Meta:"metaKey",Shift:"shiftKey"};function Qt(e){var t=this.nativeEvent;return t.getModifierState?t.getModifierState(e):!!(e=Kt[e])&&!!t[e]}function Xt(){return Qt}for(var Gt=Bt.extend({key:function(e){if(e.key){var t=Ht[e.key]||e.key;if("Unidentified"!==t)return t}return"keypress"===e.type?13===(e=Vt(e))?"Enter":String.fromCharCode(e):"keydown"===e.type||"keyup"===e.type?qt[e.keyCode]||"Unidentified":""},location:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,repeat:null,locale:null,getModifierState:Xt,charCode:function(e){return"keypress"===e.type?Vt(e):0},keyCode:function(e){return"keydown"===e.type||"keyup"===e.type?e.keyCode:0},which:function(e){return"keypress"===e.type?Vt(e):"keydown"===e.type||"keyup"===e.type?e.keyCode:0}}),Yt=0,Jt=0,Zt=!1,en=!1,tn=Bt.extend({screenX:null,screenY:null,clientX:null,clientY:null,pageX:null,pageY:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,getModifierState:Xt,button:null,buttons:null,relatedTarget:function(e){return e.relatedTarget||(e.fromElement===e.srcElement?e.toElement:e.fromElement)},movementX:function(e){if("movementX"in e)return e.movementX;var t=Yt;return Yt=e.screenX,Zt?"mousemove"===e.type?e.screenX-t:0:(Zt=!0,0)},movementY:function(e){if("movementY"in e)return e.movementY;var t=Jt;return Jt=e.screenY,en?"mousemove"===e.type?e.screenY-t:0:(en=!0,0)}}),nn=tn.extend({pointerId:null,width:null,height:null,pressure:null,tangentialPressure:null,tiltX:null,tiltY:null,twist:null,pointerType:null,isPrimary:null}),rn=tn.extend({dataTransfer:null}),on=Bt.extend({touches:null,targetTouches:null,changedTouches:null,altKey:null,metaKey:null,ctrlKey:null,shiftKey:null,getModifierState:Xt}),an=It.extend({propertyName:null,elapsedTime:null,pseudoElement:null}),ln=tn.extend({deltaX:function(e){return"deltaX"in e?e.deltaX:"wheelDeltaX"in e?-e.wheelDeltaX:0},deltaY:function(e){return"deltaY"in e?e.deltaY:"wheelDeltaY"in e?-e.wheelDeltaY:"wheelDelta"in e?-e.wheelDelta:0},deltaZ:null,deltaMode:null}),un=[["blur","blur",0],["cancel","cancel",0],["click","click",0],["close","close",0],["contextmenu","contextMenu",0],["copy","copy",0],["cut","cut",0],["auxclick","auxClick",0],["dblclick","doubleClick",0],["dragend","dragEnd",0],["dragstart","dragStart",0],["drop","drop",0],["focus","focus",0],["input","input",0],["invalid","invalid",0],["keydown","keyDown",0],["keypress","keyPress",0],["keyup","keyUp",0],["mousedown","mouseDown",0],["mouseup","mouseUp",0],["paste","paste",0],["pause","pause",0],["play","play",0],["pointercancel","pointerCancel",0],["pointerdown","pointerDown",0],["pointerup","pointerUp",0],["ratechange","rateChange",0],["reset","reset",0],["seeked","seeked",0],["submit","submit",0],["touchcancel","touchCancel",0],["touchend","touchEnd",0],["touchstart","touchStart",0],["volumechange","volumeChange",0],["drag","drag",1],["dragenter","dragEnter",1],["dragexit","dragExit",1],["dragleave","dragLeave",1],["dragover","dragOver",1],["mousemove","mouseMove",1],["mouseout","mouseOut",1],["mouseover","mouseOver",1],["pointermove","pointerMove",1],["pointerout","pointerOut",1],["pointerover","pointerOver",1],["scroll","scroll",1],["toggle","toggle",1],["touchmove","touchMove",1],["wheel","wheel",1],["abort","abort",2],[Ge,"animationEnd",2],[Ye,"animationIteration",2],[Je,"animationStart",2],["canplay","canPlay",2],["canplaythrough","canPlayThrough",2],["durationchange","durationChange",2],["emptied","emptied",2],["encrypted","encrypted",2],["ended","ended",2],["error","error",2],["gotpointercapture","gotPointerCapture",2],["load","load",2],["loadeddata","loadedData",2],["loadedmetadata","loadedMetadata",2],["loadstart","loadStart",2],["lostpointercapture","lostPointerCapture",2],["playing","playing",2],["progress","progress",2],["seeking","seeking",2],["stalled","stalled",2],["suspend","suspend",2],["timeupdate","timeUpdate",2],[Ze,"transitionEnd",2],["waiting","waiting",2]],cn={},sn={},dn=0;dn<un.length;dn++){var fn=un[dn],pn=fn[0],hn=fn[1],mn=fn[2],vn="on"+(hn[0].toUpperCase()+hn.slice(1)),bn={phasedRegistrationNames:{bubbled:vn,captured:vn+"Capture"},dependencies:[pn],eventPriority:mn};cn[hn]=bn,sn[pn]=bn}var yn={eventTypes:cn,getEventPriority:function(e){return void 0!==(e=sn[e])?e.eventPriority:2},extractEvents:function(e,t,n,r){var o=sn[e];if(!o)return null;switch(e){case"keypress":if(0===Vt(n))return null;case"keydown":case"keyup":e=Gt;break;case"blur":case"focus":e=Wt;break;case"click":if(2===n.button)return null;case"auxclick":case"dblclick":case"mousedown":case"mousemove":case"mouseup":case"mouseout":case"mouseover":case"contextmenu":e=tn;break;case"drag":case"dragend":case"dragenter":case"dragexit":case"dragleave":case"dragover":case"dragstart":case"drop":e=rn;break;case"touchcancel":case"touchend":case"touchmove":case"touchstart":e=on;break;case Ge:case Ye:case Je:e=Ut;break;case Ze:e=an;break;case"scroll":e=Bt;break;case"wheel":e=ln;break;case"copy":case"cut":case"paste":e=$t;break;case"gotpointercapture":case"lostpointercapture":case"pointercancel":case"pointerdown":case"pointermove":case"pointerout":case"pointerover":case"pointerup":e=nn;break;default:e=It}return _t(t=e.getPooled(o,t,n,r)),t}},gn=a.unstable_UserBlockingPriority,xn=a.unstable_runWithPriority,wn=yn.getEventPriority,kn=[];function En(e){var t=e.targetInst,n=t;do{if(!n){e.ancestors.push(n);break}var r=n;if(3===r.tag)r=r.stateNode.containerInfo;else{for(;r.return;)r=r.return;r=3!==r.tag?null:r.stateNode.containerInfo}if(!r)break;5!==(t=n.tag)&&6!==t||e.ancestors.push(n),n=ur(r)}while(n);for(n=0;n<e.ancestors.length;n++){t=e.ancestors[n];var o=Tt(e.nativeEvent);r=e.topLevelType;for(var a=e.nativeEvent,i=e.eventSystemFlags,l=null,u=0;u<d.length;u++){var c=d[u];c&&(c=c.extractEvents(r,t,a,o,i))&&(l=C(l,c))}R(l)}}var On=!0;function Sn(e,t){Cn(t,e,!1)}function Cn(e,t,n){switch(wn(t)){case 0:var r=Tn.bind(null,t,1);break;case 1:r=jn.bind(null,t,1);break;default:r=Rn.bind(null,t,1)}n?e.addEventListener(t,r,!0):e.addEventListener(t,r,!1)}function Tn(e,t,n){se||ue();var r=Rn,o=se;se=!0;try{le(r,e,t,n)}finally{(se=o)||fe()}}function jn(e,t,n){xn(gn,Rn.bind(null,e,t,n))}function Pn(e,t,n,r){if(kn.length){var o=kn.pop();o.topLevelType=e,o.eventSystemFlags=t,o.nativeEvent=n,o.targetInst=r,e=o}else e={topLevelType:e,eventSystemFlags:t,nativeEvent:n,targetInst:r,ancestors:[]};try{if(t=En,n=e,de)t(n,void 0);else{de=!0;try{ce(t,n,void 0)}finally{de=!1,fe()}}}finally{e.topLevelType=null,e.nativeEvent=null,e.targetInst=null,e.ancestors.length=0,kn.length<10&&kn.push(e)}}function Rn(e,t,n){if(On)if(0<ct.length&&-1<vt.indexOf(e))e=yt(null,e,t,n),ct.push(e);else{var r=Nn(e,t,n);null===r?gt(e,n):-1<vt.indexOf(e)?(e=yt(r,e,t,n),ct.push(e)):function(e,t,n,r){switch(t){case"focus":return st=xt(st,e,t,n,r),!0;case"dragenter":return dt=xt(dt,e,t,n,r),!0;case"mouseover":return ft=xt(ft,e,t,n,r),!0;case"pointerover":var o=r.pointerId;return pt.set(o,xt(pt.get(o)||null,e,t,n,r)),!0;case"gotpointercapture":return o=r.pointerId,ht.set(o,xt(ht.get(o)||null,e,t,n,r)),!0}return!1}(r,e,t,n)||(gt(e,n),Pn(e,t,n,null))}}function Nn(e,t,n){var r=Tt(n);if(null!==(r=ur(r))){var o=tt(r);if(null===o)r=null;else{var a=o.tag;if(13===a){if(null!==(r=nt(o)))return r;r=null}else if(3===a){if(o.stateNode.hydrate)return 3===o.tag?o.stateNode.containerInfo:null;r=null}else o!==r&&(r=null)}}return Pn(e,t,n,r),null}function Mn(e){if(!Z)return!1;var t=(e="on"+e)in document;return t||((t=document.createElement("div")).setAttribute(e,"return;"),t="function"===typeof t[e]),t}var _n=new("function"===typeof WeakMap?WeakMap:Map);function An(e){var t=_n.get(e);return void 0===t&&(t=new Set,_n.set(e,t)),t}function zn(e,t,n){if(!n.has(e)){switch(e){case"scroll":Cn(t,"scroll",!0);break;case"focus":case"blur":Cn(t,"focus",!0),Cn(t,"blur",!0),n.add("blur"),n.add("focus");break;case"cancel":case"close":Mn(e)&&Cn(t,e,!0);break;case"invalid":case"submit":case"reset":break;default:-1===et.indexOf(e)&&Sn(e,t)}n.add(e)}}var In={animationIterationCount:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},Ln=["Webkit","ms","Moz","O"];function Dn(e,t,n){return null==t||"boolean"===typeof t||""===t?"":n||"number"!==typeof t||0===t||In.hasOwnProperty(e)&&In[e]?(""+t).trim():t+"px"}function Fn(e,t){for(var n in e=e.style,t)if(t.hasOwnProperty(n)){var r=0===n.indexOf("--"),o=Dn(n,t[n],r);"float"===n&&(n="cssFloat"),r?e.setProperty(n,o):e[n]=o}}Object.keys(In).forEach((function(e){Ln.forEach((function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),In[t]=In[e]}))}));var Un=o({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function $n(e,t){if(t){if(Un[e]&&(null!=t.children||null!=t.dangerouslySetInnerHTML))throw Error(i(137,e,""));if(null!=t.dangerouslySetInnerHTML){if(null!=t.children)throw Error(i(60));if(!("object"===typeof t.dangerouslySetInnerHTML&&"__html"in t.dangerouslySetInnerHTML))throw Error(i(61))}if(null!=t.style&&"object"!==typeof t.style)throw Error(i(62,""))}}function Bn(e,t){if(-1===e.indexOf("-"))return"string"===typeof t.is;switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}function Wn(e,t){var n=An(e=9===e.nodeType||11===e.nodeType?e:e.ownerDocument);t=h[t];for(var r=0;r<t.length;r++)zn(t[r],e,n)}function Vn(){}function Hn(e){if("undefined"===typeof(e=e||("undefined"!==typeof document?document:void 0)))return null;try{return e.activeElement||e.body}catch(t){return e.body}}function qn(e){for(;e&&e.firstChild;)e=e.firstChild;return e}function Kn(e,t){var n,r=qn(e);for(e=0;r;){if(3===r.nodeType){if(n=e+r.textContent.length,e<=t&&n>=t)return{node:r,offset:t-e};e=n}e:{for(;r;){if(r.nextSibling){r=r.nextSibling;break e}r=r.parentNode}r=void 0}r=qn(r)}}function Qn(){for(var e=window,t=Hn();t instanceof e.HTMLIFrameElement;){try{var n="string"===typeof t.contentWindow.location.href}catch(r){n=!1}if(!n)break;t=Hn((e=t.contentWindow).document)}return t}function Xn(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&("input"===t&&("text"===e.type||"search"===e.type||"tel"===e.type||"url"===e.type||"password"===e.type)||"textarea"===t||"true"===e.contentEditable)}var Gn=null,Yn=null;function Jn(e,t){switch(e){case"button":case"input":case"select":case"textarea":return!!t.autoFocus}return!1}function Zn(e,t){return"textarea"===e||"option"===e||"noscript"===e||"string"===typeof t.children||"number"===typeof t.children||"object"===typeof t.dangerouslySetInnerHTML&&null!==t.dangerouslySetInnerHTML&&null!=t.dangerouslySetInnerHTML.__html}var er="function"===typeof setTimeout?setTimeout:void 0,tr="function"===typeof clearTimeout?clearTimeout:void 0;function nr(e){for(;null!=e;e=e.nextSibling){var t=e.nodeType;if(1===t||3===t)break}return e}function rr(e){e=e.previousSibling;for(var t=0;e;){if(8===e.nodeType){var n=e.data;if("$"===n||"$!"===n||"$?"===n){if(0===t)return e;t--}else"/$"===n&&t++}e=e.previousSibling}return null}var or=Math.random().toString(36).slice(2),ar="__reactInternalInstance$"+or,ir="__reactEventHandlers$"+or,lr="__reactContainere$"+or;function ur(e){var t=e[ar];if(t)return t;for(var n=e.parentNode;n;){if(t=n[lr]||n[ar]){if(n=t.alternate,null!==t.child||null!==n&&null!==n.child)for(e=rr(e);null!==e;){if(n=e[ar])return n;e=rr(e)}return t}n=(e=n).parentNode}return null}function cr(e){return!(e=e[ar]||e[lr])||5!==e.tag&&6!==e.tag&&13!==e.tag&&3!==e.tag?null:e}function sr(e){if(5===e.tag||6===e.tag)return e.stateNode;throw Error(i(33))}function dr(e){return e[ir]||null}var fr=null,pr=null,hr=null;function mr(){if(hr)return hr;var e,t,n=pr,r=n.length,o="value"in fr?fr.value:fr.textContent,a=o.length;for(e=0;e<r&&n[e]===o[e];e++);var i=r-e;for(t=1;t<=i&&n[r-t]===o[a-t];t++);return hr=o.slice(e,1<t?1-t:void 0)}var vr=It.extend({data:null}),br=It.extend({data:null}),yr=[9,13,27,32],gr=Z&&"CompositionEvent"in window,xr=null;Z&&"documentMode"in document&&(xr=document.documentMode);var wr=Z&&"TextEvent"in window&&!xr,kr=Z&&(!gr||xr&&8<xr&&11>=xr),Er=String.fromCharCode(32),Or={beforeInput:{phasedRegistrationNames:{bubbled:"onBeforeInput",captured:"onBeforeInputCapture"},dependencies:["compositionend","keypress","textInput","paste"]},compositionEnd:{phasedRegistrationNames:{bubbled:"onCompositionEnd",captured:"onCompositionEndCapture"},dependencies:"blur compositionend keydown keypress keyup mousedown".split(" ")},compositionStart:{phasedRegistrationNames:{bubbled:"onCompositionStart",captured:"onCompositionStartCapture"},dependencies:"blur compositionstart keydown keypress keyup mousedown".split(" ")},compositionUpdate:{phasedRegistrationNames:{bubbled:"onCompositionUpdate",captured:"onCompositionUpdateCapture"},dependencies:"blur compositionupdate keydown keypress keyup mousedown".split(" ")}},Sr=!1;function Cr(e,t){switch(e){case"keyup":return-1!==yr.indexOf(t.keyCode);case"keydown":return 229!==t.keyCode;case"keypress":case"mousedown":case"blur":return!0;default:return!1}}function Tr(e){return"object"===typeof(e=e.detail)&&"data"in e?e.data:null}var jr=!1;var Pr={eventTypes:Or,extractEvents:function(e,t,n,r){var o;if(gr)e:{switch(e){case"compositionstart":var a=Or.compositionStart;break e;case"compositionend":a=Or.compositionEnd;break e;case"compositionupdate":a=Or.compositionUpdate;break e}a=void 0}else jr?Cr(e,n)&&(a=Or.compositionEnd):"keydown"===e&&229===n.keyCode&&(a=Or.compositionStart);return a?(kr&&"ko"!==n.locale&&(jr||a!==Or.compositionStart?a===Or.compositionEnd&&jr&&(o=mr()):(pr="value"in(fr=r)?fr.value:fr.textContent,jr=!0)),a=vr.getPooled(a,t,n,r),o?a.data=o:null!==(o=Tr(n))&&(a.data=o),_t(a),o=a):o=null,(e=wr?function(e,t){switch(e){case"compositionend":return Tr(t);case"keypress":return 32!==t.which?null:(Sr=!0,Er);case"textInput":return(e=t.data)===Er&&Sr?null:e;default:return null}}(e,n):function(e,t){if(jr)return"compositionend"===e||!gr&&Cr(e,t)?(e=mr(),hr=pr=fr=null,jr=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1<t.char.length)return t.char;if(t.which)return String.fromCharCode(t.which)}return null;case"compositionend":return kr&&"ko"!==t.locale?null:t.data;default:return null}}(e,n))?((t=br.getPooled(Or.beforeInput,t,n,r)).data=e,_t(t)):t=null,null===o?t:null===t?o:[o,t]}},Rr={color:!0,date:!0,datetime:!0,"datetime-local":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function Nr(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return"input"===t?!!Rr[e.type]:"textarea"===t}var Mr={change:{phasedRegistrationNames:{bubbled:"onChange",captured:"onChangeCapture"},dependencies:"blur change click focus input keydown keyup selectionchange".split(" ")}};function _r(e,t,n){return(e=It.getPooled(Mr.change,e,t,n)).type="change",oe(n),_t(e),e}var Ar=null,zr=null;function Ir(e){R(e)}function Lr(e){if(Se(sr(e)))return e}function Dr(e,t){if("change"===e)return t}var Fr=!1;function Ur(){Ar&&(Ar.detachEvent("onpropertychange",$r),zr=Ar=null)}function $r(e){if("value"===e.propertyName&&Lr(zr))if(e=_r(zr,e,Tt(e)),se)R(e);else{se=!0;try{ie(Ir,e)}finally{se=!1,fe()}}}function Br(e,t,n){"focus"===e?(Ur(),zr=n,(Ar=t).attachEvent("onpropertychange",$r)):"blur"===e&&Ur()}function Wr(e){if("selectionchange"===e||"keyup"===e||"keydown"===e)return Lr(zr)}function Vr(e,t){if("click"===e)return Lr(t)}function Hr(e,t){if("input"===e||"change"===e)return Lr(t)}Z&&(Fr=Mn("input")&&(!document.documentMode||9<document.documentMode));var qr,Kr={eventTypes:Mr,_isInputEventSupported:Fr,extractEvents:function(e,t,n,r){var o=t?sr(t):window,a=o.nodeName&&o.nodeName.toLowerCase();if("select"===a||"input"===a&&"file"===o.type)var i=Dr;else if(Nr(o))if(Fr)i=Hr;else{i=Wr;var l=Br}else(a=o.nodeName)&&"input"===a.toLowerCase()&&("checkbox"===o.type||"radio"===o.type)&&(i=Vr);if(i&&(i=i(e,t)))return _r(i,n,r);l&&l(e,o,t),"blur"===e&&(e=o._wrapperState)&&e.controlled&&"number"===o.type&&Ne(o,"number",o.value)}},Qr={mouseEnter:{registrationName:"onMouseEnter",dependencies:["mouseout","mouseover"]},mouseLeave:{registrationName:"onMouseLeave",dependencies:["mouseout","mouseover"]},pointerEnter:{registrationName:"onPointerEnter",dependencies:["pointerout","pointerover"]},pointerLeave:{registrationName:"onPointerLeave",dependencies:["pointerout","pointerover"]}},Xr={eventTypes:Qr,extractEvents:function(e,t,n,r,o){var a="mouseover"===e||"pointerover"===e,i="mouseout"===e||"pointerout"===e;if(a&&0===(32&o)&&(n.relatedTarget||n.fromElement)||!i&&!a)return null;if(o=r.window===r?r:(o=r.ownerDocument)?o.defaultView||o.parentWindow:window,i?(i=t,null!==(t=(t=n.relatedTarget||n.toElement)?ur(t):null)&&(t!==(a=tt(t))||5!==t.tag&&6!==t.tag)&&(t=null)):i=null,i===t)return null;if("mouseout"===e||"mouseover"===e)var l=tn,u=Qr.mouseLeave,c=Qr.mouseEnter,s="mouse";else"pointerout"!==e&&"pointerover"!==e||(l=nn,u=Qr.pointerLeave,c=Qr.pointerEnter,s="pointer");if(e=null==i?o:sr(i),o=null==t?o:sr(t),(u=l.getPooled(u,i,n,r)).type=s+"leave",u.target=e,u.relatedTarget=o,(r=l.getPooled(c,t,n,r)).type=s+"enter",r.target=o,r.relatedTarget=e,s=t,(l=i)&&s)e:{for(e=s,i=0,t=c=l;t;t=jt(t))i++;for(t=0,o=e;o;o=jt(o))t++;for(;0<i-t;)c=jt(c),i--;for(;0<t-i;)e=jt(e),t--;for(;i--;){if(c===e||c===e.alternate)break e;c=jt(c),e=jt(e)}c=null}else c=null;for(e=c,c=[];l&&l!==e&&(null===(i=l.alternate)||i!==e);)c.push(l),l=jt(l);for(l=[];s&&s!==e&&(null===(i=s.alternate)||i!==e);)l.push(s),s=jt(s);for(s=0;s<c.length;s++)Nt(c[s],"bubbled",u);for(s=l.length;0<s--;)Nt(l[s],"captured",r);return n===qr?(qr=null,[u]):(qr=n,[u,r])}};var Gr="function"===typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e===1/t)||e!==e&&t!==t},Yr=Object.prototype.hasOwnProperty;function Jr(e,t){if(Gr(e,t))return!0;if("object"!==typeof e||null===e||"object"!==typeof t||null===t)return!1;var n=Object.keys(e),r=Object.keys(t);if(n.length!==r.length)return!1;for(r=0;r<n.length;r++)if(!Yr.call(t,n[r])||!Gr(e[n[r]],t[n[r]]))return!1;return!0}var Zr=Z&&"documentMode"in document&&11>=document.documentMode,eo={select:{phasedRegistrationNames:{bubbled:"onSelect",captured:"onSelectCapture"},dependencies:"blur contextmenu dragend focus keydown keyup mousedown mouseup selectionchange".split(" ")}},to=null,no=null,ro=null,oo=!1;function ao(e,t){var n=t.window===t?t.document:9===t.nodeType?t:t.ownerDocument;return oo||null==to||to!==Hn(n)?null:("selectionStart"in(n=to)&&Xn(n)?n={start:n.selectionStart,end:n.selectionEnd}:n={anchorNode:(n=(n.ownerDocument&&n.ownerDocument.defaultView||window).getSelection()).anchorNode,anchorOffset:n.anchorOffset,focusNode:n.focusNode,focusOffset:n.focusOffset},ro&&Jr(ro,n)?null:(ro=n,(e=It.getPooled(eo.select,no,e,t)).type="select",e.target=to,_t(e),e))}var io={eventTypes:eo,extractEvents:function(e,t,n,r){var o,a=r.window===r?r.document:9===r.nodeType?r:r.ownerDocument;if(!(o=!a)){e:{a=An(a),o=h.onSelect;for(var i=0;i<o.length;i++)if(!a.has(o[i])){a=!1;break e}a=!0}o=!a}if(o)return null;switch(a=t?sr(t):window,e){case"focus":(Nr(a)||"true"===a.contentEditable)&&(to=a,no=t,ro=null);break;case"blur":ro=no=to=null;break;case"mousedown":oo=!0;break;case"contextmenu":case"mouseup":case"dragend":return oo=!1,ao(n,r);case"selectionchange":if(Zr)break;case"keydown":case"keyup":return ao(n,r)}return null}};N.injectEventPluginOrder("ResponderEventPlugin SimpleEventPlugin EnterLeaveEventPlugin ChangeEventPlugin SelectEventPlugin BeforeInputEventPlugin".split(" ")),k=dr,E=cr,O=sr,N.injectEventPluginsByName({SimpleEventPlugin:yn,EnterLeaveEventPlugin:Xr,ChangeEventPlugin:Kr,SelectEventPlugin:io,BeforeInputEventPlugin:Pr}),new Set;var lo=[],uo=-1;function co(e){0>uo||(e.current=lo[uo],lo[uo]=null,uo--)}function so(e,t){uo++,lo[uo]=e.current,e.current=t}var fo={},po={current:fo},ho={current:!1},mo=fo;function vo(e,t){var n=e.type.contextTypes;if(!n)return fo;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var o,a={};for(o in n)a[o]=t[o];return r&&((e=e.stateNode).__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=a),a}function bo(e){return null!==(e=e.childContextTypes)&&void 0!==e}function yo(e){co(ho),co(po)}function go(e){co(ho),co(po)}function xo(e,t,n){if(po.current!==fo)throw Error(i(168));so(po,t),so(ho,n)}function wo(e,t,n){var r=e.stateNode;if(e=t.childContextTypes,"function"!==typeof r.getChildContext)return n;for(var a in r=r.getChildContext())if(!(a in e))throw Error(i(108,Y(t)||"Unknown",a));return o({},n,{},r)}function ko(e){var t=e.stateNode;return t=t&&t.__reactInternalMemoizedMergedChildContext||fo,mo=po.current,so(po,t),so(ho,ho.current),!0}function Eo(e,t,n){var r=e.stateNode;if(!r)throw Error(i(169));n?(t=wo(e,t,mo),r.__reactInternalMemoizedMergedChildContext=t,co(ho),co(po),so(po,t)):co(ho),so(ho,n)}var Oo=a.unstable_runWithPriority,So=a.unstable_scheduleCallback,Co=a.unstable_cancelCallback,To=a.unstable_shouldYield,jo=a.unstable_requestPaint,Po=a.unstable_now,Ro=a.unstable_getCurrentPriorityLevel,No=a.unstable_ImmediatePriority,Mo=a.unstable_UserBlockingPriority,_o=a.unstable_NormalPriority,Ao=a.unstable_LowPriority,zo=a.unstable_IdlePriority,Io={},Lo=void 0!==jo?jo:function(){},Do=null,Fo=null,Uo=!1,$o=Po(),Bo=1e4>$o?Po:function(){return Po()-$o};function Wo(){switch(Ro()){case No:return 99;case Mo:return 98;case _o:return 97;case Ao:return 96;case zo:return 95;default:throw Error(i(332))}}function Vo(e){switch(e){case 99:return No;case 98:return Mo;case 97:return _o;case 96:return Ao;case 95:return zo;default:throw Error(i(332))}}function Ho(e,t){return e=Vo(e),Oo(e,t)}function qo(e,t,n){return e=Vo(e),So(e,t,n)}function Ko(e){return null===Do?(Do=[e],Fo=So(No,Xo)):Do.push(e),Io}function Qo(){if(null!==Fo){var e=Fo;Fo=null,Co(e)}Xo()}function Xo(){if(!Uo&&null!==Do){Uo=!0;var e=0;try{var t=Do;Ho(99,(function(){for(;e<t.length;e++){var n=t[e];do{n=n(!0)}while(null!==n)}})),Do=null}catch(n){throw null!==Do&&(Do=Do.slice(e+1)),So(No,Qo),n}finally{Uo=!1}}}var Go=3;function Yo(e,t,n){return 1073741821-(1+((1073741821-e+t/10)/(n/=10)|0))*n}function Jo(e,t){if(e&&e.defaultProps)for(var n in t=o({},t),e=e.defaultProps)void 0===t[n]&&(t[n]=e[n]);return t}var Zo={current:null},ea=null,ta=null,na=null;function ra(){na=ta=ea=null}function oa(e,t){var n=e.type._context;so(Zo,n._currentValue),n._currentValue=t}function aa(e){var t=Zo.current;co(Zo),e.type._context._currentValue=t}function ia(e,t){for(;null!==e;){var n=e.alternate;if(e.childExpirationTime<t)e.childExpirationTime=t,null!==n&&n.childExpirationTime<t&&(n.childExpirationTime=t);else{if(!(null!==n&&n.childExpirationTime<t))break;n.childExpirationTime=t}e=e.return}}function la(e,t){ea=e,na=ta=null,null!==(e=e.dependencies)&&null!==e.firstContext&&(e.expirationTime>=t&&($i=!0),e.firstContext=null)}function ua(e,t){if(na!==e&&!1!==t&&0!==t)if("number"===typeof t&&1073741823!==t||(na=e,t=1073741823),t={context:e,observedBits:t,next:null},null===ta){if(null===ea)throw Error(i(308));ta=t,ea.dependencies={expirationTime:0,firstContext:t,responders:null}}else ta=ta.next=t;return e._currentValue}var ca=!1;function sa(e){return{baseState:e,firstUpdate:null,lastUpdate:null,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}function da(e){return{baseState:e.baseState,firstUpdate:e.firstUpdate,lastUpdate:e.lastUpdate,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}function fa(e,t){return{expirationTime:e,suspenseConfig:t,tag:0,payload:null,callback:null,next:null,nextEffect:null}}function pa(e,t){null===e.lastUpdate?e.firstUpdate=e.lastUpdate=t:(e.lastUpdate.next=t,e.lastUpdate=t)}function ha(e,t){var n=e.alternate;if(null===n){var r=e.updateQueue,o=null;null===r&&(r=e.updateQueue=sa(e.memoizedState))}else r=e.updateQueue,o=n.updateQueue,null===r?null===o?(r=e.updateQueue=sa(e.memoizedState),o=n.updateQueue=sa(n.memoizedState)):r=e.updateQueue=da(o):null===o&&(o=n.updateQueue=da(r));null===o||r===o?pa(r,t):null===r.lastUpdate||null===o.lastUpdate?(pa(r,t),pa(o,t)):(pa(r,t),o.lastUpdate=t)}function ma(e,t){var n=e.updateQueue;null===(n=null===n?e.updateQueue=sa(e.memoizedState):va(e,n)).lastCapturedUpdate?n.firstCapturedUpdate=n.lastCapturedUpdate=t:(n.lastCapturedUpdate.next=t,n.lastCapturedUpdate=t)}function va(e,t){var n=e.alternate;return null!==n&&t===n.updateQueue&&(t=e.updateQueue=da(t)),t}function ba(e,t,n,r,a,i){switch(n.tag){case 1:return"function"===typeof(e=n.payload)?e.call(i,r,a):e;case 3:e.effectTag=-4097&e.effectTag|64;case 0:if(null===(a="function"===typeof(e=n.payload)?e.call(i,r,a):e)||void 0===a)break;return o({},r,a);case 2:ca=!0}return r}function ya(e,t,n,r,o){ca=!1;for(var a=(t=va(e,t)).baseState,i=null,l=0,u=t.firstUpdate,c=a;null!==u;){var s=u.expirationTime;s<o?(null===i&&(i=u,a=c),l<s&&(l=s)):(du(s,u.suspenseConfig),c=ba(e,0,u,c,n,r),null!==u.callback&&(e.effectTag|=32,u.nextEffect=null,null===t.lastEffect?t.firstEffect=t.lastEffect=u:(t.lastEffect.nextEffect=u,t.lastEffect=u))),u=u.next}for(s=null,u=t.firstCapturedUpdate;null!==u;){var d=u.expirationTime;d<o?(null===s&&(s=u,null===i&&(a=c)),l<d&&(l=d)):(c=ba(e,0,u,c,n,r),null!==u.callback&&(e.effectTag|=32,u.nextEffect=null,null===t.lastCapturedEffect?t.firstCapturedEffect=t.lastCapturedEffect=u:(t.lastCapturedEffect.nextEffect=u,t.lastCapturedEffect=u))),u=u.next}null===i&&(t.lastUpdate=null),null===s?t.lastCapturedUpdate=null:e.effectTag|=32,null===i&&null===s&&(a=c),t.baseState=a,t.firstUpdate=i,t.firstCapturedUpdate=s,fu(l),e.expirationTime=l,e.memoizedState=c}function ga(e,t,n){null!==t.firstCapturedUpdate&&(null!==t.lastUpdate&&(t.lastUpdate.next=t.firstCapturedUpdate,t.lastUpdate=t.lastCapturedUpdate),t.firstCapturedUpdate=t.lastCapturedUpdate=null),xa(t.firstEffect,n),t.firstEffect=t.lastEffect=null,xa(t.firstCapturedEffect,n),t.firstCapturedEffect=t.lastCapturedEffect=null}function xa(e,t){for(;null!==e;){var n=e.callback;if(null!==n){e.callback=null;var r=t;if("function"!==typeof n)throw Error(i(191,n));n.call(r)}e=e.nextEffect}}var wa=_.ReactCurrentBatchConfig,ka=(new r.Component).refs;function Ea(e,t,n,r){n=null===(n=n(r,t=e.memoizedState))||void 0===n?t:o({},t,n),e.memoizedState=n,null!==(r=e.updateQueue)&&0===e.expirationTime&&(r.baseState=n)}var Oa={isMounted:function(e){return!!(e=e._reactInternalFiber)&&tt(e)===e},enqueueSetState:function(e,t,n){e=e._reactInternalFiber;var r=Jl(),o=wa.suspense;(o=fa(r=Zl(r,e,o),o)).payload=t,void 0!==n&&null!==n&&(o.callback=n),ha(e,o),eu(e,r)},enqueueReplaceState:function(e,t,n){e=e._reactInternalFiber;var r=Jl(),o=wa.suspense;(o=fa(r=Zl(r,e,o),o)).tag=1,o.payload=t,void 0!==n&&null!==n&&(o.callback=n),ha(e,o),eu(e,r)},enqueueForceUpdate:function(e,t){e=e._reactInternalFiber;var n=Jl(),r=wa.suspense;(r=fa(n=Zl(n,e,r),r)).tag=2,void 0!==t&&null!==t&&(r.callback=t),ha(e,r),eu(e,n)}};function Sa(e,t,n,r,o,a,i){return"function"===typeof(e=e.stateNode).shouldComponentUpdate?e.shouldComponentUpdate(r,a,i):!t.prototype||!t.prototype.isPureReactComponent||(!Jr(n,r)||!Jr(o,a))}function Ca(e,t,n){var r=!1,o=fo,a=t.contextType;return"object"===typeof a&&null!==a?a=ua(a):(o=bo(t)?mo:po.current,a=(r=null!==(r=t.contextTypes)&&void 0!==r)?vo(e,o):fo),t=new t(n,a),e.memoizedState=null!==t.state&&void 0!==t.state?t.state:null,t.updater=Oa,e.stateNode=t,t._reactInternalFiber=e,r&&((e=e.stateNode).__reactInternalMemoizedUnmaskedChildContext=o,e.__reactInternalMemoizedMaskedChildContext=a),t}function Ta(e,t,n,r){e=t.state,"function"===typeof t.componentWillReceiveProps&&t.componentWillReceiveProps(n,r),"function"===typeof t.UNSAFE_componentWillReceiveProps&&t.UNSAFE_componentWillReceiveProps(n,r),t.state!==e&&Oa.enqueueReplaceState(t,t.state,null)}function ja(e,t,n,r){var o=e.stateNode;o.props=n,o.state=e.memoizedState,o.refs=ka;var a=t.contextType;"object"===typeof a&&null!==a?o.context=ua(a):(a=bo(t)?mo:po.current,o.context=vo(e,a)),null!==(a=e.updateQueue)&&(ya(e,a,n,o,r),o.state=e.memoizedState),"function"===typeof(a=t.getDerivedStateFromProps)&&(Ea(e,t,a,n),o.state=e.memoizedState),"function"===typeof t.getDerivedStateFromProps||"function"===typeof o.getSnapshotBeforeUpdate||"function"!==typeof o.UNSAFE_componentWillMount&&"function"!==typeof o.componentWillMount||(t=o.state,"function"===typeof o.componentWillMount&&o.componentWillMount(),"function"===typeof o.UNSAFE_componentWillMount&&o.UNSAFE_componentWillMount(),t!==o.state&&Oa.enqueueReplaceState(o,o.state,null),null!==(a=e.updateQueue)&&(ya(e,a,n,o,r),o.state=e.memoizedState)),"function"===typeof o.componentDidMount&&(e.effectTag|=4)}var Pa=Array.isArray;function Ra(e,t,n){if(null!==(e=n.ref)&&"function"!==typeof e&&"object"!==typeof e){if(n._owner){if(n=n._owner){if(1!==n.tag)throw Error(i(309));var r=n.stateNode}if(!r)throw Error(i(147,e));var o=""+e;return null!==t&&null!==t.ref&&"function"===typeof t.ref&&t.ref._stringRef===o?t.ref:((t=function(e){var t=r.refs;t===ka&&(t=r.refs={}),null===e?delete t[o]:t[o]=e})._stringRef=o,t)}if("string"!==typeof e)throw Error(i(284));if(!n._owner)throw Error(i(290,e))}return e}function Na(e,t){if("textarea"!==e.type)throw Error(i(31,"[object Object]"===Object.prototype.toString.call(t)?"object with keys {"+Object.keys(t).join(", ")+"}":t,""))}function Ma(e){function t(t,n){if(e){var r=t.lastEffect;null!==r?(r.nextEffect=n,t.lastEffect=n):t.firstEffect=t.lastEffect=n,n.nextEffect=null,n.effectTag=8}}function n(n,r){if(!e)return null;for(;null!==r;)t(n,r),r=r.sibling;return null}function r(e,t){for(e=new Map;null!==t;)null!==t.key?e.set(t.key,t):e.set(t.index,t),t=t.sibling;return e}function o(e,t,n){return(e=Mu(e,t)).index=0,e.sibling=null,e}function a(t,n,r){return t.index=r,e?null!==(r=t.alternate)?(r=r.index)<n?(t.effectTag=2,n):r:(t.effectTag=2,n):n}function l(t){return e&&null===t.alternate&&(t.effectTag=2),t}function u(e,t,n,r){return null===t||6!==t.tag?((t=zu(n,e.mode,r)).return=e,t):((t=o(t,n)).return=e,t)}function c(e,t,n,r){return null!==t&&t.elementType===n.type?((r=o(t,n.props)).ref=Ra(e,t,n),r.return=e,r):((r=_u(n.type,n.key,n.props,null,e.mode,r)).ref=Ra(e,t,n),r.return=e,r)}function s(e,t,n,r){return null===t||4!==t.tag||t.stateNode.containerInfo!==n.containerInfo||t.stateNode.implementation!==n.implementation?((t=Iu(n,e.mode,r)).return=e,t):((t=o(t,n.children||[])).return=e,t)}function d(e,t,n,r,a){return null===t||7!==t.tag?((t=Au(n,e.mode,r,a)).return=e,t):((t=o(t,n)).return=e,t)}function f(e,t,n){if("string"===typeof t||"number"===typeof t)return(t=zu(""+t,e.mode,n)).return=e,t;if("object"===typeof t&&null!==t){switch(t.$$typeof){case I:return(n=_u(t.type,t.key,t.props,null,e.mode,n)).ref=Ra(e,null,t),n.return=e,n;case L:return(t=Iu(t,e.mode,n)).return=e,t}if(Pa(t)||G(t))return(t=Au(t,e.mode,n,null)).return=e,t;Na(e,t)}return null}function p(e,t,n,r){var o=null!==t?t.key:null;if("string"===typeof n||"number"===typeof n)return null!==o?null:u(e,t,""+n,r);if("object"===typeof n&&null!==n){switch(n.$$typeof){case I:return n.key===o?n.type===D?d(e,t,n.props.children,r,o):c(e,t,n,r):null;case L:return n.key===o?s(e,t,n,r):null}if(Pa(n)||G(n))return null!==o?null:d(e,t,n,r,null);Na(e,n)}return null}function h(e,t,n,r,o){if("string"===typeof r||"number"===typeof r)return u(t,e=e.get(n)||null,""+r,o);if("object"===typeof r&&null!==r){switch(r.$$typeof){case I:return e=e.get(null===r.key?n:r.key)||null,r.type===D?d(t,e,r.props.children,o,r.key):c(t,e,r,o);case L:return s(t,e=e.get(null===r.key?n:r.key)||null,r,o)}if(Pa(r)||G(r))return d(t,e=e.get(n)||null,r,o,null);Na(t,r)}return null}function m(o,i,l,u){for(var c=null,s=null,d=i,m=i=0,v=null;null!==d&&m<l.length;m++){d.index>m?(v=d,d=null):v=d.sibling;var b=p(o,d,l[m],u);if(null===b){null===d&&(d=v);break}e&&d&&null===b.alternate&&t(o,d),i=a(b,i,m),null===s?c=b:s.sibling=b,s=b,d=v}if(m===l.length)return n(o,d),c;if(null===d){for(;m<l.length;m++)null!==(d=f(o,l[m],u))&&(i=a(d,i,m),null===s?c=d:s.sibling=d,s=d);return c}for(d=r(o,d);m<l.length;m++)null!==(v=h(d,o,m,l[m],u))&&(e&&null!==v.alternate&&d.delete(null===v.key?m:v.key),i=a(v,i,m),null===s?c=v:s.sibling=v,s=v);return e&&d.forEach((function(e){return t(o,e)})),c}function v(o,l,u,c){var s=G(u);if("function"!==typeof s)throw Error(i(150));if(null==(u=s.call(u)))throw Error(i(151));for(var d=s=null,m=l,v=l=0,b=null,y=u.next();null!==m&&!y.done;v++,y=u.next()){m.index>v?(b=m,m=null):b=m.sibling;var g=p(o,m,y.value,c);if(null===g){null===m&&(m=b);break}e&&m&&null===g.alternate&&t(o,m),l=a(g,l,v),null===d?s=g:d.sibling=g,d=g,m=b}if(y.done)return n(o,m),s;if(null===m){for(;!y.done;v++,y=u.next())null!==(y=f(o,y.value,c))&&(l=a(y,l,v),null===d?s=y:d.sibling=y,d=y);return s}for(m=r(o,m);!y.done;v++,y=u.next())null!==(y=h(m,o,v,y.value,c))&&(e&&null!==y.alternate&&m.delete(null===y.key?v:y.key),l=a(y,l,v),null===d?s=y:d.sibling=y,d=y);return e&&m.forEach((function(e){return t(o,e)})),s}return function(e,r,a,u){var c="object"===typeof a&&null!==a&&a.type===D&&null===a.key;c&&(a=a.props.children);var s="object"===typeof a&&null!==a;if(s)switch(a.$$typeof){case I:e:{for(s=a.key,c=r;null!==c;){if(c.key===s){if(7===c.tag?a.type===D:c.elementType===a.type){n(e,c.sibling),(r=o(c,a.type===D?a.props.children:a.props)).ref=Ra(e,c,a),r.return=e,e=r;break e}n(e,c);break}t(e,c),c=c.sibling}a.type===D?((r=Au(a.props.children,e.mode,u,a.key)).return=e,e=r):((u=_u(a.type,a.key,a.props,null,e.mode,u)).ref=Ra(e,r,a),u.return=e,e=u)}return l(e);case L:e:{for(c=a.key;null!==r;){if(r.key===c){if(4===r.tag&&r.stateNode.containerInfo===a.containerInfo&&r.stateNode.implementation===a.implementation){n(e,r.sibling),(r=o(r,a.children||[])).return=e,e=r;break e}n(e,r);break}t(e,r),r=r.sibling}(r=Iu(a,e.mode,u)).return=e,e=r}return l(e)}if("string"===typeof a||"number"===typeof a)return a=""+a,null!==r&&6===r.tag?(n(e,r.sibling),(r=o(r,a)).return=e,e=r):(n(e,r),(r=zu(a,e.mode,u)).return=e,e=r),l(e);if(Pa(a))return m(e,r,a,u);if(G(a))return v(e,r,a,u);if(s&&Na(e,a),"undefined"===typeof a&&!c)switch(e.tag){case 1:case 0:throw e=e.type,Error(i(152,e.displayName||e.name||"Component"))}return n(e,r)}}var _a=Ma(!0),Aa=Ma(!1),za={},Ia={current:za},La={current:za},Da={current:za};function Fa(e){if(e===za)throw Error(i(174));return e}function Ua(e,t){so(Da,t),so(La,e),so(Ia,za);var n=t.nodeType;switch(n){case 9:case 11:t=(t=t.documentElement)?t.namespaceURI:$e(null,"");break;default:t=$e(t=(n=8===n?t.parentNode:t).namespaceURI||null,n=n.tagName)}co(Ia),so(Ia,t)}function $a(e){co(Ia),co(La),co(Da)}function Ba(e){Fa(Da.current);var t=Fa(Ia.current),n=$e(t,e.type);t!==n&&(so(La,e),so(Ia,n))}function Wa(e){La.current===e&&(co(Ia),co(La))}var Va={current:0};function Ha(e){for(var t=e;null!==t;){if(13===t.tag){var n=t.memoizedState;if(null!==n&&(null===(n=n.dehydrated)||"$?"===n.data||"$!"===n.data))return t}else if(19===t.tag&&void 0!==t.memoizedProps.revealOrder){if(0!==(64&t.effectTag))return t}else if(null!==t.child){t.child.return=t,t=t.child;continue}if(t===e)break;for(;null===t.sibling;){if(null===t.return||t.return===e)return null;t=t.return}t.sibling.return=t.return,t=t.sibling}return null}function qa(e,t){return{responder:e,props:t}}var Ka=_.ReactCurrentDispatcher,Qa=_.ReactCurrentBatchConfig,Xa=0,Ga=null,Ya=null,Ja=null,Za=null,ei=null,ti=null,ni=0,ri=null,oi=0,ai=!1,ii=null,li=0;function ui(){throw Error(i(321))}function ci(e,t){if(null===t)return!1;for(var n=0;n<t.length&&n<e.length;n++)if(!Gr(e[n],t[n]))return!1;return!0}function si(e,t,n,r,o,a){if(Xa=a,Ga=t,Ja=null!==e?e.memoizedState:null,Ka.current=null===Ja?Pi:Ri,t=n(r,o),ai){do{ai=!1,li+=1,Ja=null!==e?e.memoizedState:null,ti=Za,ri=ei=Ya=null,Ka.current=Ri,t=n(r,o)}while(ai);ii=null,li=0}if(Ka.current=ji,(e=Ga).memoizedState=Za,e.expirationTime=ni,e.updateQueue=ri,e.effectTag|=oi,e=null!==Ya&&null!==Ya.next,Xa=0,ti=ei=Za=Ja=Ya=Ga=null,ni=0,ri=null,oi=0,e)throw Error(i(300));return t}function di(){Ka.current=ji,Xa=0,ti=ei=Za=Ja=Ya=Ga=null,ni=0,ri=null,oi=0,ai=!1,ii=null,li=0}function fi(){var e={memoizedState:null,baseState:null,queue:null,baseUpdate:null,next:null};return null===ei?Za=ei=e:ei=ei.next=e,ei}function pi(){if(null!==ti)ti=(ei=ti).next,Ja=null!==(Ya=Ja)?Ya.next:null;else{if(null===Ja)throw Error(i(310));var e={memoizedState:(Ya=Ja).memoizedState,baseState:Ya.baseState,queue:Ya.queue,baseUpdate:Ya.baseUpdate,next:null};ei=null===ei?Za=e:ei.next=e,Ja=Ya.next}return ei}function hi(e,t){return"function"===typeof t?t(e):t}function mi(e){var t=pi(),n=t.queue;if(null===n)throw Error(i(311));if(n.lastRenderedReducer=e,0<li){var r=n.dispatch;if(null!==ii){var o=ii.get(n);if(void 0!==o){ii.delete(n);var a=t.memoizedState;do{a=e(a,o.action),o=o.next}while(null!==o);return Gr(a,t.memoizedState)||($i=!0),t.memoizedState=a,t.baseUpdate===n.last&&(t.baseState=a),n.lastRenderedState=a,[a,r]}}return[t.memoizedState,r]}r=n.last;var l=t.baseUpdate;if(a=t.baseState,null!==l?(null!==r&&(r.next=null),r=l.next):r=null!==r?r.next:null,null!==r){var u=o=null,c=r,s=!1;do{var d=c.expirationTime;d<Xa?(s||(s=!0,u=l,o=a),d>ni&&fu(ni=d)):(du(d,c.suspenseConfig),a=c.eagerReducer===e?c.eagerState:e(a,c.action)),l=c,c=c.next}while(null!==c&&c!==r);s||(u=l,o=a),Gr(a,t.memoizedState)||($i=!0),t.memoizedState=a,t.baseUpdate=u,t.baseState=o,n.lastRenderedState=a}return[t.memoizedState,n.dispatch]}function vi(e){var t=fi();return"function"===typeof e&&(e=e()),t.memoizedState=t.baseState=e,e=(e=t.queue={last:null,dispatch:null,lastRenderedReducer:hi,lastRenderedState:e}).dispatch=Ti.bind(null,Ga,e),[t.memoizedState,e]}function bi(e){return mi(hi)}function yi(e,t,n,r){return e={tag:e,create:t,destroy:n,deps:r,next:null},null===ri?(ri={lastEffect:null}).lastEffect=e.next=e:null===(t=ri.lastEffect)?ri.lastEffect=e.next=e:(n=t.next,t.next=e,e.next=n,ri.lastEffect=e),e}function gi(e,t,n,r){var o=fi();oi|=e,o.memoizedState=yi(t,n,void 0,void 0===r?null:r)}function xi(e,t,n,r){var o=pi();r=void 0===r?null:r;var a=void 0;if(null!==Ya){var i=Ya.memoizedState;if(a=i.destroy,null!==r&&ci(r,i.deps))return void yi(0,n,a,r)}oi|=e,o.memoizedState=yi(t,n,a,r)}function wi(e,t){return gi(516,192,e,t)}function ki(e,t){return xi(516,192,e,t)}function Ei(e,t){return"function"===typeof t?(e=e(),t(e),function(){t(null)}):null!==t&&void 0!==t?(e=e(),t.current=e,function(){t.current=null}):void 0}function Oi(){}function Si(e,t){return fi().memoizedState=[e,void 0===t?null:t],e}function Ci(e,t){var n=pi();t=void 0===t?null:t;var r=n.memoizedState;return null!==r&&null!==t&&ci(t,r[1])?r[0]:(n.memoizedState=[e,t],e)}function Ti(e,t,n){if(!(25>li))throw Error(i(301));var r=e.alternate;if(e===Ga||null!==r&&r===Ga)if(ai=!0,e={expirationTime:Xa,suspenseConfig:null,action:n,eagerReducer:null,eagerState:null,next:null},null===ii&&(ii=new Map),void 0===(n=ii.get(t)))ii.set(t,e);else{for(t=n;null!==t.next;)t=t.next;t.next=e}else{var o=Jl(),a=wa.suspense;a={expirationTime:o=Zl(o,e,a),suspenseConfig:a,action:n,eagerReducer:null,eagerState:null,next:null};var l=t.last;if(null===l)a.next=a;else{var u=l.next;null!==u&&(a.next=u),l.next=a}if(t.last=a,0===e.expirationTime&&(null===r||0===r.expirationTime)&&null!==(r=t.lastRenderedReducer))try{var c=t.lastRenderedState,s=r(c,n);if(a.eagerReducer=r,a.eagerState=s,Gr(s,c))return}catch(d){}eu(e,o)}}var ji={readContext:ua,useCallback:ui,useContext:ui,useEffect:ui,useImperativeHandle:ui,useLayoutEffect:ui,useMemo:ui,useReducer:ui,useRef:ui,useState:ui,useDebugValue:ui,useResponder:ui,useDeferredValue:ui,useTransition:ui},Pi={readContext:ua,useCallback:Si,useContext:ua,useEffect:wi,useImperativeHandle:function(e,t,n){return n=null!==n&&void 0!==n?n.concat([e]):null,gi(4,36,Ei.bind(null,t,e),n)},useLayoutEffect:function(e,t){return gi(4,36,e,t)},useMemo:function(e,t){var n=fi();return t=void 0===t?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=fi();return t=void 0!==n?n(t):t,r.memoizedState=r.baseState=t,e=(e=r.queue={last:null,dispatch:null,lastRenderedReducer:e,lastRenderedState:t}).dispatch=Ti.bind(null,Ga,e),[r.memoizedState,e]},useRef:function(e){return e={current:e},fi().memoizedState=e},useState:vi,useDebugValue:Oi,useResponder:qa,useDeferredValue:function(e,t){var n=vi(e),r=n[0],o=n[1];return wi((function(){a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===t?null:t;try{o(e)}finally{Qa.suspense=n}}))}),[e,t]),r},useTransition:function(e){var t=vi(!1),n=t[0],r=t[1];return[Si((function(t){r(!0),a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===e?null:e;try{r(!1),t()}finally{Qa.suspense=n}}))}),[e,n]),n]}},Ri={readContext:ua,useCallback:Ci,useContext:ua,useEffect:ki,useImperativeHandle:function(e,t,n){return n=null!==n&&void 0!==n?n.concat([e]):null,xi(4,36,Ei.bind(null,t,e),n)},useLayoutEffect:function(e,t){return xi(4,36,e,t)},useMemo:function(e,t){var n=pi();t=void 0===t?null:t;var r=n.memoizedState;return null!==r&&null!==t&&ci(t,r[1])?r[0]:(e=e(),n.memoizedState=[e,t],e)},useReducer:mi,useRef:function(){return pi().memoizedState},useState:bi,useDebugValue:Oi,useResponder:qa,useDeferredValue:function(e,t){var n=bi(),r=n[0],o=n[1];return ki((function(){a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===t?null:t;try{o(e)}finally{Qa.suspense=n}}))}),[e,t]),r},useTransition:function(e){var t=bi(),n=t[0],r=t[1];return[Ci((function(t){r(!0),a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===e?null:e;try{r(!1),t()}finally{Qa.suspense=n}}))}),[e,n]),n]}},Ni=null,Mi=null,_i=!1;function Ai(e,t){var n=Ru(5,null,null,0);n.elementType="DELETED",n.type="DELETED",n.stateNode=t,n.return=e,n.effectTag=8,null!==e.lastEffect?(e.lastEffect.nextEffect=n,e.lastEffect=n):e.firstEffect=e.lastEffect=n}function zi(e,t){switch(e.tag){case 5:var n=e.type;return null!==(t=1!==t.nodeType||n.toLowerCase()!==t.nodeName.toLowerCase()?null:t)&&(e.stateNode=t,!0);case 6:return null!==(t=""===e.pendingProps||3!==t.nodeType?null:t)&&(e.stateNode=t,!0);case 13:default:return!1}}function Ii(e){if(_i){var t=Mi;if(t){var n=t;if(!zi(e,t)){if(!(t=nr(n.nextSibling))||!zi(e,t))return e.effectTag=-1025&e.effectTag|2,_i=!1,void(Ni=e);Ai(Ni,n)}Ni=e,Mi=nr(t.firstChild)}else e.effectTag=-1025&e.effectTag|2,_i=!1,Ni=e}}function Li(e){for(e=e.return;null!==e&&5!==e.tag&&3!==e.tag&&13!==e.tag;)e=e.return;Ni=e}function Di(e){if(e!==Ni)return!1;if(!_i)return Li(e),_i=!0,!1;var t=e.type;if(5!==e.tag||"head"!==t&&"body"!==t&&!Zn(t,e.memoizedProps))for(t=Mi;t;)Ai(e,t),t=nr(t.nextSibling);if(Li(e),13===e.tag){if(!(e=null!==(e=e.memoizedState)?e.dehydrated:null))throw Error(i(317));e:{for(e=e.nextSibling,t=0;e;){if(8===e.nodeType){var n=e.data;if("/$"===n){if(0===t){Mi=nr(e.nextSibling);break e}t--}else"$"!==n&&"$!"!==n&&"$?"!==n||t++}e=e.nextSibling}Mi=null}}else Mi=Ni?nr(e.stateNode.nextSibling):null;return!0}function Fi(){Mi=Ni=null,_i=!1}var Ui=_.ReactCurrentOwner,$i=!1;function Bi(e,t,n,r){t.child=null===e?Aa(t,null,n,r):_a(t,e.child,n,r)}function Wi(e,t,n,r,o){n=n.render;var a=t.ref;return la(t,o),r=si(e,t,n,r,a,o),null===e||$i?(t.effectTag|=1,Bi(e,t,r,o),t.child):(t.updateQueue=e.updateQueue,t.effectTag&=-517,e.expirationTime<=o&&(e.expirationTime=0),al(e,t,o))}function Vi(e,t,n,r,o,a){if(null===e){var i=n.type;return"function"!==typeof i||Nu(i)||void 0!==i.defaultProps||null!==n.compare||void 0!==n.defaultProps?((e=_u(n.type,null,r,null,t.mode,a)).ref=t.ref,e.return=t,t.child=e):(t.tag=15,t.type=i,Hi(e,t,i,r,o,a))}return i=e.child,o<a&&(o=i.memoizedProps,(n=null!==(n=n.compare)?n:Jr)(o,r)&&e.ref===t.ref)?al(e,t,a):(t.effectTag|=1,(e=Mu(i,r)).ref=t.ref,e.return=t,t.child=e)}function Hi(e,t,n,r,o,a){return null!==e&&Jr(e.memoizedProps,r)&&e.ref===t.ref&&($i=!1,o<a)?al(e,t,a):Ki(e,t,n,r,a)}function qi(e,t){var n=t.ref;(null===e&&null!==n||null!==e&&e.ref!==n)&&(t.effectTag|=128)}function Ki(e,t,n,r,o){var a=bo(n)?mo:po.current;return a=vo(t,a),la(t,o),n=si(e,t,n,r,a,o),null===e||$i?(t.effectTag|=1,Bi(e,t,n,o),t.child):(t.updateQueue=e.updateQueue,t.effectTag&=-517,e.expirationTime<=o&&(e.expirationTime=0),al(e,t,o))}function Qi(e,t,n,r,o){if(bo(n)){var a=!0;ko(t)}else a=!1;if(la(t,o),null===t.stateNode)null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),Ca(t,n,r),ja(t,n,r,o),r=!0;else if(null===e){var i=t.stateNode,l=t.memoizedProps;i.props=l;var u=i.context,c=n.contextType;"object"===typeof c&&null!==c?c=ua(c):c=vo(t,c=bo(n)?mo:po.current);var s=n.getDerivedStateFromProps,d="function"===typeof s||"function"===typeof i.getSnapshotBeforeUpdate;d||"function"!==typeof i.UNSAFE_componentWillReceiveProps&&"function"!==typeof i.componentWillReceiveProps||(l!==r||u!==c)&&Ta(t,i,r,c),ca=!1;var f=t.memoizedState;u=i.state=f;var p=t.updateQueue;null!==p&&(ya(t,p,r,i,o),u=t.memoizedState),l!==r||f!==u||ho.current||ca?("function"===typeof s&&(Ea(t,n,s,r),u=t.memoizedState),(l=ca||Sa(t,n,l,r,f,u,c))?(d||"function"!==typeof i.UNSAFE_componentWillMount&&"function"!==typeof i.componentWillMount||("function"===typeof i.componentWillMount&&i.componentWillMount(),"function"===typeof i.UNSAFE_componentWillMount&&i.UNSAFE_componentWillMount()),"function"===typeof i.componentDidMount&&(t.effectTag|=4)):("function"===typeof i.componentDidMount&&(t.effectTag|=4),t.memoizedProps=r,t.memoizedState=u),i.props=r,i.state=u,i.context=c,r=l):("function"===typeof i.componentDidMount&&(t.effectTag|=4),r=!1)}else i=t.stateNode,l=t.memoizedProps,i.props=t.type===t.elementType?l:Jo(t.type,l),u=i.context,"object"===typeof(c=n.contextType)&&null!==c?c=ua(c):c=vo(t,c=bo(n)?mo:po.current),(d="function"===typeof(s=n.getDerivedStateFromProps)||"function"===typeof i.getSnapshotBeforeUpdate)||"function"!==typeof i.UNSAFE_componentWillReceiveProps&&"function"!==typeof i.componentWillReceiveProps||(l!==r||u!==c)&&Ta(t,i,r,c),ca=!1,u=t.memoizedState,f=i.state=u,null!==(p=t.updateQueue)&&(ya(t,p,r,i,o),f=t.memoizedState),l!==r||u!==f||ho.current||ca?("function"===typeof s&&(Ea(t,n,s,r),f=t.memoizedState),(s=ca||Sa(t,n,l,r,u,f,c))?(d||"function"!==typeof i.UNSAFE_componentWillUpdate&&"function"!==typeof i.componentWillUpdate||("function"===typeof i.componentWillUpdate&&i.componentWillUpdate(r,f,c),"function"===typeof i.UNSAFE_componentWillUpdate&&i.UNSAFE_componentWillUpdate(r,f,c)),"function"===typeof i.componentDidUpdate&&(t.effectTag|=4),"function"===typeof i.getSnapshotBeforeUpdate&&(t.effectTag|=256)):("function"!==typeof i.componentDidUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=4),"function"!==typeof i.getSnapshotBeforeUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=256),t.memoizedProps=r,t.memoizedState=f),i.props=r,i.state=f,i.context=c,r=s):("function"!==typeof i.componentDidUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=4),"function"!==typeof i.getSnapshotBeforeUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=256),r=!1);return Xi(e,t,n,r,a,o)}function Xi(e,t,n,r,o,a){qi(e,t);var i=0!==(64&t.effectTag);if(!r&&!i)return o&&Eo(t,n,!1),al(e,t,a);r=t.stateNode,Ui.current=t;var l=i&&"function"!==typeof n.getDerivedStateFromError?null:r.render();return t.effectTag|=1,null!==e&&i?(t.child=_a(t,e.child,null,a),t.child=_a(t,null,l,a)):Bi(e,t,l,a),t.memoizedState=r.state,o&&Eo(t,n,!0),t.child}function Gi(e){var t=e.stateNode;t.pendingContext?xo(0,t.pendingContext,t.pendingContext!==t.context):t.context&&xo(0,t.context,!1),Ua(e,t.containerInfo)}var Yi,Ji,Zi,el={dehydrated:null,retryTime:0};function tl(e,t,n){var r,o=t.mode,a=t.pendingProps,i=Va.current,l=!1;if((r=0!==(64&t.effectTag))||(r=0!==(2&i)&&(null===e||null!==e.memoizedState)),r?(l=!0,t.effectTag&=-65):null!==e&&null===e.memoizedState||void 0===a.fallback||!0===a.unstable_avoidThisFallback||(i|=1),so(Va,1&i),null===e){if(void 0!==a.fallback&&Ii(t),l){if(l=a.fallback,(a=Au(null,o,0,null)).return=t,0===(2&t.mode))for(e=null!==t.memoizedState?t.child.child:t.child,a.child=e;null!==e;)e.return=a,e=e.sibling;return(n=Au(l,o,n,null)).return=t,a.sibling=n,t.memoizedState=el,t.child=a,n}return o=a.children,t.memoizedState=null,t.child=Aa(t,null,o,n)}if(null!==e.memoizedState){if(o=(e=e.child).sibling,l){if(a=a.fallback,(n=Mu(e,e.pendingProps)).return=t,0===(2&t.mode)&&(l=null!==t.memoizedState?t.child.child:t.child)!==e.child)for(n.child=l;null!==l;)l.return=n,l=l.sibling;return(o=Mu(o,a,o.expirationTime)).return=t,n.sibling=o,n.childExpirationTime=0,t.memoizedState=el,t.child=n,o}return n=_a(t,e.child,a.children,n),t.memoizedState=null,t.child=n}if(e=e.child,l){if(l=a.fallback,(a=Au(null,o,0,null)).return=t,a.child=e,null!==e&&(e.return=a),0===(2&t.mode))for(e=null!==t.memoizedState?t.child.child:t.child,a.child=e;null!==e;)e.return=a,e=e.sibling;return(n=Au(l,o,n,null)).return=t,a.sibling=n,n.effectTag|=2,a.childExpirationTime=0,t.memoizedState=el,t.child=a,n}return t.memoizedState=null,t.child=_a(t,e,a.children,n)}function nl(e,t){e.expirationTime<t&&(e.expirationTime=t);var n=e.alternate;null!==n&&n.expirationTime<t&&(n.expirationTime=t),ia(e.return,t)}function rl(e,t,n,r,o,a){var i=e.memoizedState;null===i?e.memoizedState={isBackwards:t,rendering:null,last:r,tail:n,tailExpiration:0,tailMode:o,lastEffect:a}:(i.isBackwards=t,i.rendering=null,i.last=r,i.tail=n,i.tailExpiration=0,i.tailMode=o,i.lastEffect=a)}function ol(e,t,n){var r=t.pendingProps,o=r.revealOrder,a=r.tail;if(Bi(e,t,r.children,n),0!==(2&(r=Va.current)))r=1&r|2,t.effectTag|=64;else{if(null!==e&&0!==(64&e.effectTag))e:for(e=t.child;null!==e;){if(13===e.tag)null!==e.memoizedState&&nl(e,n);else if(19===e.tag)nl(e,n);else if(null!==e.child){e.child.return=e,e=e.child;continue}if(e===t)break e;for(;null===e.sibling;){if(null===e.return||e.return===t)break e;e=e.return}e.sibling.return=e.return,e=e.sibling}r&=1}if(so(Va,r),0===(2&t.mode))t.memoizedState=null;else switch(o){case"forwards":for(n=t.child,o=null;null!==n;)null!==(e=n.alternate)&&null===Ha(e)&&(o=n),n=n.sibling;null===(n=o)?(o=t.child,t.child=null):(o=n.sibling,n.sibling=null),rl(t,!1,o,n,a,t.lastEffect);break;case"backwards":for(n=null,o=t.child,t.child=null;null!==o;){if(null!==(e=o.alternate)&&null===Ha(e)){t.child=o;break}e=o.sibling,o.sibling=n,n=o,o=e}rl(t,!0,n,null,a,t.lastEffect);break;case"together":rl(t,!1,null,null,void 0,t.lastEffect);break;default:t.memoizedState=null}return t.child}function al(e,t,n){null!==e&&(t.dependencies=e.dependencies);var r=t.expirationTime;if(0!==r&&fu(r),t.childExpirationTime<n)return null;if(null!==e&&t.child!==e.child)throw Error(i(153));if(null!==t.child){for(n=Mu(e=t.child,e.pendingProps,e.expirationTime),t.child=n,n.return=t;null!==e.sibling;)e=e.sibling,(n=n.sibling=Mu(e,e.pendingProps,e.expirationTime)).return=t;n.sibling=null}return t.child}function il(e){e.effectTag|=4}function ll(e,t){switch(e.tailMode){case"hidden":t=e.tail;for(var n=null;null!==t;)null!==t.alternate&&(n=t),t=t.sibling;null===n?e.tail=null:n.sibling=null;break;case"collapsed":n=e.tail;for(var r=null;null!==n;)null!==n.alternate&&(r=n),n=n.sibling;null===r?t||null===e.tail?e.tail=null:e.tail.sibling=null:r.sibling=null}}function ul(e){switch(e.tag){case 1:bo(e.type)&&yo();var t=e.effectTag;return 4096&t?(e.effectTag=-4097&t|64,e):null;case 3:if($a(),go(),0!==(64&(t=e.effectTag)))throw Error(i(285));return e.effectTag=-4097&t|64,e;case 5:return Wa(e),null;case 13:return co(Va),4096&(t=e.effectTag)?(e.effectTag=-4097&t|64,e):null;case 19:return co(Va),null;case 4:return $a(),null;case 10:return aa(e),null;default:return null}}function cl(e,t){return{value:e,source:t,stack:J(t)}}Yi=function(e,t){for(var n=t.child;null!==n;){if(5===n.tag||6===n.tag)e.appendChild(n.stateNode);else if(4!==n.tag&&null!==n.child){n.child.return=n,n=n.child;continue}if(n===t)break;for(;null===n.sibling;){if(null===n.return||n.return===t)return;n=n.return}n.sibling.return=n.return,n=n.sibling}},Ji=function(e,t,n,r,a){var i=e.memoizedProps;if(i!==r){var l,u,c=t.stateNode;switch(Fa(Ia.current),e=null,n){case"input":i=Ce(c,i),r=Ce(c,r),e=[];break;case"option":i=Me(c,i),r=Me(c,r),e=[];break;case"select":i=o({},i,{value:void 0}),r=o({},r,{value:void 0}),e=[];break;case"textarea":i=Ae(c,i),r=Ae(c,r),e=[];break;default:"function"!==typeof i.onClick&&"function"===typeof r.onClick&&(c.onclick=Vn)}for(l in $n(n,r),n=null,i)if(!r.hasOwnProperty(l)&&i.hasOwnProperty(l)&&null!=i[l])if("style"===l)for(u in c=i[l])c.hasOwnProperty(u)&&(n||(n={}),n[u]="");else"dangerouslySetInnerHTML"!==l&&"children"!==l&&"suppressContentEditableWarning"!==l&&"suppressHydrationWarning"!==l&&"autoFocus"!==l&&(p.hasOwnProperty(l)?e||(e=[]):(e=e||[]).push(l,null));for(l in r){var s=r[l];if(c=null!=i?i[l]:void 0,r.hasOwnProperty(l)&&s!==c&&(null!=s||null!=c))if("style"===l)if(c){for(u in c)!c.hasOwnProperty(u)||s&&s.hasOwnProperty(u)||(n||(n={}),n[u]="");for(u in s)s.hasOwnProperty(u)&&c[u]!==s[u]&&(n||(n={}),n[u]=s[u])}else n||(e||(e=[]),e.push(l,n)),n=s;else"dangerouslySetInnerHTML"===l?(s=s?s.__html:void 0,c=c?c.__html:void 0,null!=s&&c!==s&&(e=e||[]).push(l,""+s)):"children"===l?c===s||"string"!==typeof s&&"number"!==typeof s||(e=e||[]).push(l,""+s):"suppressContentEditableWarning"!==l&&"suppressHydrationWarning"!==l&&(p.hasOwnProperty(l)?(null!=s&&Wn(a,l),e||c===s||(e=[])):(e=e||[]).push(l,s))}n&&(e=e||[]).push("style",n),a=e,(t.updateQueue=a)&&il(t)}},Zi=function(e,t,n,r){n!==r&&il(t)};var sl="function"===typeof WeakSet?WeakSet:Set;function dl(e,t){var n=t.source,r=t.stack;null===r&&null!==n&&(r=J(n)),null!==n&&Y(n.type),t=t.value,null!==e&&1===e.tag&&Y(e.type);try{console.error(t)}catch(o){setTimeout((function(){throw o}))}}function fl(e){var t=e.ref;if(null!==t)if("function"===typeof t)try{t(null)}catch(n){Ou(e,n)}else t.current=null}function pl(e,t){switch(t.tag){case 0:case 11:case 15:hl(2,0,t);break;case 1:if(256&t.effectTag&&null!==e){var n=e.memoizedProps,r=e.memoizedState;t=(e=t.stateNode).getSnapshotBeforeUpdate(t.elementType===t.type?n:Jo(t.type,n),r),e.__reactInternalSnapshotBeforeUpdate=t}break;case 3:case 5:case 6:case 4:case 17:break;default:throw Error(i(163))}}function hl(e,t,n){if(null!==(n=null!==(n=n.updateQueue)?n.lastEffect:null)){var r=n=n.next;do{if(0!==(r.tag&e)){var o=r.destroy;r.destroy=void 0,void 0!==o&&o()}0!==(r.tag&t)&&(o=r.create,r.destroy=o()),r=r.next}while(r!==n)}}function ml(e,t,n){switch("function"===typeof ju&&ju(t),t.tag){case 0:case 11:case 14:case 15:if(null!==(e=t.updateQueue)&&null!==(e=e.lastEffect)){var r=e.next;Ho(97<n?97:n,(function(){var e=r;do{var n=e.destroy;if(void 0!==n){var o=t;try{n()}catch(a){Ou(o,a)}}e=e.next}while(e!==r)}))}break;case 1:fl(t),"function"===typeof(n=t.stateNode).componentWillUnmount&&function(e,t){try{t.props=e.memoizedProps,t.state=e.memoizedState,t.componentWillUnmount()}catch(n){Ou(e,n)}}(t,n);break;case 5:fl(t);break;case 4:gl(e,t,n)}}function vl(e){var t=e.alternate;e.return=null,e.child=null,e.memoizedState=null,e.updateQueue=null,e.dependencies=null,e.alternate=null,e.firstEffect=null,e.lastEffect=null,e.pendingProps=null,e.memoizedProps=null,null!==t&&vl(t)}function bl(e){return 5===e.tag||3===e.tag||4===e.tag}function yl(e){e:{for(var t=e.return;null!==t;){if(bl(t)){var n=t;break e}t=t.return}throw Error(i(160))}switch(t=n.stateNode,n.tag){case 5:var r=!1;break;case 3:case 4:t=t.containerInfo,r=!0;break;default:throw Error(i(161))}16&n.effectTag&&(Ve(t,""),n.effectTag&=-17);e:t:for(n=e;;){for(;null===n.sibling;){if(null===n.return||bl(n.return)){n=null;break e}n=n.return}for(n.sibling.return=n.return,n=n.sibling;5!==n.tag&&6!==n.tag&&18!==n.tag;){if(2&n.effectTag)continue t;if(null===n.child||4===n.tag)continue t;n.child.return=n,n=n.child}if(!(2&n.effectTag)){n=n.stateNode;break e}}for(var o=e;;){var a=5===o.tag||6===o.tag;if(a){var l=a?o.stateNode:o.stateNode.instance;if(n)if(r){var u=l;l=n,8===(a=t).nodeType?a.parentNode.insertBefore(u,l):a.insertBefore(u,l)}else t.insertBefore(l,n);else r?(8===(u=t).nodeType?(a=u.parentNode).insertBefore(l,u):(a=u).appendChild(l),null!==(u=u._reactRootContainer)&&void 0!==u||null!==a.onclick||(a.onclick=Vn)):t.appendChild(l)}else if(4!==o.tag&&null!==o.child){o.child.return=o,o=o.child;continue}if(o===e)break;for(;null===o.sibling;){if(null===o.return||o.return===e)return;o=o.return}o.sibling.return=o.return,o=o.sibling}}function gl(e,t,n){for(var r,o,a=t,l=!1;;){if(!l){l=a.return;e:for(;;){if(null===l)throw Error(i(160));switch(r=l.stateNode,l.tag){case 5:o=!1;break e;case 3:case 4:r=r.containerInfo,o=!0;break e}l=l.return}l=!0}if(5===a.tag||6===a.tag){e:for(var u=e,c=a,s=n,d=c;;)if(ml(u,d,s),null!==d.child&&4!==d.tag)d.child.return=d,d=d.child;else{if(d===c)break;for(;null===d.sibling;){if(null===d.return||d.return===c)break e;d=d.return}d.sibling.return=d.return,d=d.sibling}o?(u=r,c=a.stateNode,8===u.nodeType?u.parentNode.removeChild(c):u.removeChild(c)):r.removeChild(a.stateNode)}else if(4===a.tag){if(null!==a.child){r=a.stateNode.containerInfo,o=!0,a.child.return=a,a=a.child;continue}}else if(ml(e,a,n),null!==a.child){a.child.return=a,a=a.child;continue}if(a===t)break;for(;null===a.sibling;){if(null===a.return||a.return===t)return;4===(a=a.return).tag&&(l=!1)}a.sibling.return=a.return,a=a.sibling}}function xl(e,t){switch(t.tag){case 0:case 11:case 14:case 15:hl(4,8,t);break;case 1:break;case 5:var n=t.stateNode;if(null!=n){var r=t.memoizedProps,o=null!==e?e.memoizedProps:r;e=t.type;var a=t.updateQueue;if(t.updateQueue=null,null!==a){for(n[ir]=r,"input"===e&&"radio"===r.type&&null!=r.name&&je(n,r),Bn(e,o),t=Bn(e,r),o=0;o<a.length;o+=2){var l=a[o],u=a[o+1];"style"===l?Fn(n,u):"dangerouslySetInnerHTML"===l?We(n,u):"children"===l?Ve(n,u):ke(n,l,u,t)}switch(e){case"input":Pe(n,r);break;case"textarea":Ie(n,r);break;case"select":t=n._wrapperState.wasMultiple,n._wrapperState.wasMultiple=!!r.multiple,null!=(e=r.value)?_e(n,!!r.multiple,e,!1):t!==!!r.multiple&&(null!=r.defaultValue?_e(n,!!r.multiple,r.defaultValue,!0):_e(n,!!r.multiple,r.multiple?[]:"",!1))}}}break;case 6:if(null===t.stateNode)throw Error(i(162));t.stateNode.nodeValue=t.memoizedProps;break;case 3:(t=t.stateNode).hydrate&&(t.hydrate=!1,Ct(t.containerInfo));break;case 12:break;case 13:if(n=t,null===t.memoizedState?r=!1:(r=!0,n=t.child,Ul=Bo()),null!==n)e:for(e=n;;){if(5===e.tag)a=e.stateNode,r?"function"===typeof(a=a.style).setProperty?a.setProperty("display","none","important"):a.display="none":(a=e.stateNode,o=void 0!==(o=e.memoizedProps.style)&&null!==o&&o.hasOwnProperty("display")?o.display:null,a.style.display=Dn("display",o));else if(6===e.tag)e.stateNode.nodeValue=r?"":e.memoizedProps;else{if(13===e.tag&&null!==e.memoizedState&&null===e.memoizedState.dehydrated){(a=e.child.sibling).return=e,e=a;continue}if(null!==e.child){e.child.return=e,e=e.child;continue}}if(e===n)break e;for(;null===e.sibling;){if(null===e.return||e.return===n)break e;e=e.return}e.sibling.return=e.return,e=e.sibling}wl(t);break;case 19:wl(t);break;case 17:case 20:case 21:break;default:throw Error(i(163))}}function wl(e){var t=e.updateQueue;if(null!==t){e.updateQueue=null;var n=e.stateNode;null===n&&(n=e.stateNode=new sl),t.forEach((function(t){var r=Cu.bind(null,e,t);n.has(t)||(n.add(t),t.then(r,r))}))}}var kl="function"===typeof WeakMap?WeakMap:Map;function El(e,t,n){(n=fa(n,null)).tag=3,n.payload={element:null};var r=t.value;return n.callback=function(){Bl||(Bl=!0,Wl=r),dl(e,t)},n}function Ol(e,t,n){(n=fa(n,null)).tag=3;var r=e.type.getDerivedStateFromError;if("function"===typeof r){var o=t.value;n.payload=function(){return dl(e,t),r(o)}}var a=e.stateNode;return null!==a&&"function"===typeof a.componentDidCatch&&(n.callback=function(){"function"!==typeof r&&(null===Vl?Vl=new Set([this]):Vl.add(this),dl(e,t));var n=t.stack;this.componentDidCatch(t.value,{componentStack:null!==n?n:""})}),n}var Sl,Cl=Math.ceil,Tl=_.ReactCurrentDispatcher,jl=_.ReactCurrentOwner,Pl=0,Rl=null,Nl=null,Ml=0,_l=0,Al=null,zl=1073741823,Il=1073741823,Ll=null,Dl=0,Fl=!1,Ul=0,$l=null,Bl=!1,Wl=null,Vl=null,Hl=!1,ql=null,Kl=90,Ql=null,Xl=0,Gl=null,Yl=0;function Jl(){return 0!==(48&Pl)?1073741821-(Bo()/10|0):0!==Yl?Yl:Yl=1073741821-(Bo()/10|0)}function Zl(e,t,n){if(0===(2&(t=t.mode)))return 1073741823;var r=Wo();if(0===(4&t))return 99===r?1073741823:1073741822;if(0!==(16&Pl))return Ml;if(null!==n)e=Yo(e,0|n.timeoutMs||5e3,250);else switch(r){case 99:e=1073741823;break;case 98:e=Yo(e,150,100);break;case 97:case 96:e=Yo(e,5e3,250);break;case 95:e=2;break;default:throw Error(i(326))}return null!==Rl&&e===Ml&&--e,e}function eu(e,t){if(50<Xl)throw Xl=0,Gl=null,Error(i(185));if(null!==(e=tu(e,t))){var n=Wo();1073741823===t?0!==(8&Pl)&&0===(48&Pl)?au(e):(ru(e),0===Pl&&Qo()):ru(e),0===(4&Pl)||98!==n&&99!==n||(null===Ql?Ql=new Map([[e,t]]):(void 0===(n=Ql.get(e))||n>t)&&Ql.set(e,t))}}function tu(e,t){e.expirationTime<t&&(e.expirationTime=t);var n=e.alternate;null!==n&&n.expirationTime<t&&(n.expirationTime=t);var r=e.return,o=null;if(null===r&&3===e.tag)o=e.stateNode;else for(;null!==r;){if(n=r.alternate,r.childExpirationTime<t&&(r.childExpirationTime=t),null!==n&&n.childExpirationTime<t&&(n.childExpirationTime=t),null===r.return&&3===r.tag){o=r.stateNode;break}r=r.return}return null!==o&&(Rl===o&&(fu(t),4===_l&&Fu(o,Ml)),Uu(o,t)),o}function nu(e){var t=e.lastExpiredTime;return 0!==t?t:Du(e,t=e.firstPendingTime)?(t=e.lastPingedTime)>(e=e.nextKnownPendingLevel)?t:e:t}function ru(e){if(0!==e.lastExpiredTime)e.callbackExpirationTime=1073741823,e.callbackPriority=99,e.callbackNode=Ko(au.bind(null,e));else{var t=nu(e),n=e.callbackNode;if(0===t)null!==n&&(e.callbackNode=null,e.callbackExpirationTime=0,e.callbackPriority=90);else{var r=Jl();if(1073741823===t?r=99:1===t||2===t?r=95:r=0>=(r=10*(1073741821-t)-10*(1073741821-r))?99:250>=r?98:5250>=r?97:95,null!==n){var o=e.callbackPriority;if(e.callbackExpirationTime===t&&o>=r)return;n!==Io&&Co(n)}e.callbackExpirationTime=t,e.callbackPriority=r,t=1073741823===t?Ko(au.bind(null,e)):qo(r,ou.bind(null,e),{timeout:10*(1073741821-t)-Bo()}),e.callbackNode=t}}}function ou(e,t){if(Yl=0,t)return $u(e,t=Jl()),ru(e),null;var n=nu(e);if(0!==n){if(t=e.callbackNode,0!==(48&Pl))throw Error(i(327));if(wu(),e===Rl&&n===Ml||uu(e,n),null!==Nl){var r=Pl;Pl|=16;for(var o=su();;)try{hu();break}catch(u){cu(e,u)}if(ra(),Pl=r,Tl.current=o,1===_l)throw t=Al,uu(e,n),Fu(e,n),ru(e),t;if(null===Nl)switch(o=e.finishedWork=e.current.alternate,e.finishedExpirationTime=n,r=_l,Rl=null,r){case 0:case 1:throw Error(i(345));case 2:$u(e,2<n?2:n);break;case 3:if(Fu(e,n),n===(r=e.lastSuspendedTime)&&(e.nextKnownPendingLevel=bu(o)),1073741823===zl&&10<(o=Ul+500-Bo())){if(Fl){var a=e.lastPingedTime;if(0===a||a>=n){e.lastPingedTime=n,uu(e,n);break}}if(0!==(a=nu(e))&&a!==n)break;if(0!==r&&r!==n){e.lastPingedTime=r;break}e.timeoutHandle=er(yu.bind(null,e),o);break}yu(e);break;case 4:if(Fu(e,n),n===(r=e.lastSuspendedTime)&&(e.nextKnownPendingLevel=bu(o)),Fl&&(0===(o=e.lastPingedTime)||o>=n)){e.lastPingedTime=n,uu(e,n);break}if(0!==(o=nu(e))&&o!==n)break;if(0!==r&&r!==n){e.lastPingedTime=r;break}if(1073741823!==Il?r=10*(1073741821-Il)-Bo():1073741823===zl?r=0:(r=10*(1073741821-zl)-5e3,0>(r=(o=Bo())-r)&&(r=0),(n=10*(1073741821-n)-o)<(r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*Cl(r/1960))-r)&&(r=n)),10<r){e.timeoutHandle=er(yu.bind(null,e),r);break}yu(e);break;case 5:if(1073741823!==zl&&null!==Ll){a=zl;var l=Ll;if(0>=(r=0|l.busyMinDurationMs)?r=0:(o=0|l.busyDelayMs,r=(a=Bo()-(10*(1073741821-a)-(0|l.timeoutMs||5e3)))<=o?0:o+r-a),10<r){Fu(e,n),e.timeoutHandle=er(yu.bind(null,e),r);break}}yu(e);break;default:throw Error(i(329))}if(ru(e),e.callbackNode===t)return ou.bind(null,e)}}return null}function au(e){var t=e.lastExpiredTime;if(t=0!==t?t:1073741823,e.finishedExpirationTime===t)yu(e);else{if(0!==(48&Pl))throw Error(i(327));if(wu(),e===Rl&&t===Ml||uu(e,t),null!==Nl){var n=Pl;Pl|=16;for(var r=su();;)try{pu();break}catch(o){cu(e,o)}if(ra(),Pl=n,Tl.current=r,1===_l)throw n=Al,uu(e,t),Fu(e,t),ru(e),n;if(null!==Nl)throw Error(i(261));e.finishedWork=e.current.alternate,e.finishedExpirationTime=t,Rl=null,yu(e),ru(e)}}return null}function iu(e,t){var n=Pl;Pl|=1;try{return e(t)}finally{0===(Pl=n)&&Qo()}}function lu(e,t){var n=Pl;Pl&=-2,Pl|=8;try{return e(t)}finally{0===(Pl=n)&&Qo()}}function uu(e,t){e.finishedWork=null,e.finishedExpirationTime=0;var n=e.timeoutHandle;if(-1!==n&&(e.timeoutHandle=-1,tr(n)),null!==Nl)for(n=Nl.return;null!==n;){var r=n;switch(r.tag){case 1:var o=r.type.childContextTypes;null!==o&&void 0!==o&&yo();break;case 3:$a(),go();break;case 5:Wa(r);break;case 4:$a();break;case 13:case 19:co(Va);break;case 10:aa(r)}n=n.return}Rl=e,Nl=Mu(e.current,null),Ml=t,_l=0,Al=null,Il=zl=1073741823,Ll=null,Dl=0,Fl=!1}function cu(e,t){for(;;){try{if(ra(),di(),null===Nl||null===Nl.return)return _l=1,Al=t,null;e:{var n=e,r=Nl.return,o=Nl,a=t;if(t=Ml,o.effectTag|=2048,o.firstEffect=o.lastEffect=null,null!==a&&"object"===typeof a&&"function"===typeof a.then){var i=a,l=0!==(1&Va.current),u=r;do{var c;if(c=13===u.tag){var s=u.memoizedState;if(null!==s)c=null!==s.dehydrated;else{var d=u.memoizedProps;c=void 0!==d.fallback&&(!0!==d.unstable_avoidThisFallback||!l)}}if(c){var f=u.updateQueue;if(null===f){var p=new Set;p.add(i),u.updateQueue=p}else f.add(i);if(0===(2&u.mode)){if(u.effectTag|=64,o.effectTag&=-2981,1===o.tag)if(null===o.alternate)o.tag=17;else{var h=fa(1073741823,null);h.tag=2,ha(o,h)}o.expirationTime=1073741823;break e}a=void 0,o=t;var m=n.pingCache;if(null===m?(m=n.pingCache=new kl,a=new Set,m.set(i,a)):void 0===(a=m.get(i))&&(a=new Set,m.set(i,a)),!a.has(o)){a.add(o);var v=Su.bind(null,n,i,o);i.then(v,v)}u.effectTag|=4096,u.expirationTime=t;break e}u=u.return}while(null!==u);a=Error((Y(o.type)||"A React component")+" suspended while rendering, but no fallback UI was specified.\n\nAdd a <Suspense fallback=...> component higher in the tree to provide a loading indicator or placeholder to display."+J(o))}5!==_l&&(_l=2),a=cl(a,o),u=r;do{switch(u.tag){case 3:i=a,u.effectTag|=4096,u.expirationTime=t,ma(u,El(u,i,t));break e;case 1:i=a;var b=u.type,y=u.stateNode;if(0===(64&u.effectTag)&&("function"===typeof b.getDerivedStateFromError||null!==y&&"function"===typeof y.componentDidCatch&&(null===Vl||!Vl.has(y)))){u.effectTag|=4096,u.expirationTime=t,ma(u,Ol(u,i,t));break e}}u=u.return}while(null!==u)}Nl=vu(Nl)}catch(g){t=g;continue}break}}function su(){var e=Tl.current;return Tl.current=ji,null===e?ji:e}function du(e,t){e<zl&&2<e&&(zl=e),null!==t&&e<Il&&2<e&&(Il=e,Ll=t)}function fu(e){e>Dl&&(Dl=e)}function pu(){for(;null!==Nl;)Nl=mu(Nl)}function hu(){for(;null!==Nl&&!To();)Nl=mu(Nl)}function mu(e){var t=Sl(e.alternate,e,Ml);return e.memoizedProps=e.pendingProps,null===t&&(t=vu(e)),jl.current=null,t}function vu(e){Nl=e;do{var t=Nl.alternate;if(e=Nl.return,0===(2048&Nl.effectTag)){e:{var n=t,r=Ml,a=(t=Nl).pendingProps;switch(t.tag){case 2:case 16:break;case 15:case 0:break;case 1:bo(t.type)&&yo();break;case 3:$a(),go(),(a=t.stateNode).pendingContext&&(a.context=a.pendingContext,a.pendingContext=null),(null===n||null===n.child)&&Di(t)&&il(t);break;case 5:Wa(t),r=Fa(Da.current);var l=t.type;if(null!==n&&null!=t.stateNode)Ji(n,t,l,a,r),n.ref!==t.ref&&(t.effectTag|=128);else if(a){var u=Fa(Ia.current);if(Di(t)){var c=(a=t).stateNode;n=a.type;var s=a.memoizedProps,d=r;switch(c[ar]=a,c[ir]=s,l=void 0,r=c,n){case"iframe":case"object":case"embed":Sn("load",r);break;case"video":case"audio":for(c=0;c<et.length;c++)Sn(et[c],r);break;case"source":Sn("error",r);break;case"img":case"image":case"link":Sn("error",r),Sn("load",r);break;case"form":Sn("reset",r),Sn("submit",r);break;case"details":Sn("toggle",r);break;case"input":Te(r,s),Sn("invalid",r),Wn(d,"onChange");break;case"select":r._wrapperState={wasMultiple:!!s.multiple},Sn("invalid",r),Wn(d,"onChange");break;case"textarea":ze(r,s),Sn("invalid",r),Wn(d,"onChange")}for(l in $n(n,s),c=null,s)s.hasOwnProperty(l)&&(u=s[l],"children"===l?"string"===typeof u?r.textContent!==u&&(c=["children",u]):"number"===typeof u&&r.textContent!==""+u&&(c=["children",""+u]):p.hasOwnProperty(l)&&null!=u&&Wn(d,l));switch(n){case"input":Oe(r),Re(r,s,!0);break;case"textarea":Oe(r),Le(r);break;case"select":case"option":break;default:"function"===typeof s.onClick&&(r.onclick=Vn)}l=c,a.updateQueue=l,(a=null!==l)&&il(t)}else{n=t,d=l,s=a,c=9===r.nodeType?r:r.ownerDocument,u===De&&(u=Ue(d)),u===De?"script"===d?((s=c.createElement("div")).innerHTML="<script><\/script>",c=s.removeChild(s.firstChild)):"string"===typeof s.is?c=c.createElement(d,{is:s.is}):(c=c.createElement(d),"select"===d&&(d=c,s.multiple?d.multiple=!0:s.size&&(d.size=s.size))):c=c.createElementNS(u,d),(s=c)[ar]=n,s[ir]=a,Yi(s,t),t.stateNode=s;var f=r,h=Bn(d=l,n=a);switch(d){case"iframe":case"object":case"embed":Sn("load",s),r=n;break;case"video":case"audio":for(r=0;r<et.length;r++)Sn(et[r],s);r=n;break;case"source":Sn("error",s),r=n;break;case"img":case"image":case"link":Sn("error",s),Sn("load",s),r=n;break;case"form":Sn("reset",s),Sn("submit",s),r=n;break;case"details":Sn("toggle",s),r=n;break;case"input":Te(s,n),r=Ce(s,n),Sn("invalid",s),Wn(f,"onChange");break;case"option":r=Me(s,n);break;case"select":s._wrapperState={wasMultiple:!!n.multiple},r=o({},n,{value:void 0}),Sn("invalid",s),Wn(f,"onChange");break;case"textarea":ze(s,n),r=Ae(s,n),Sn("invalid",s),Wn(f,"onChange");break;default:r=n}$n(d,r),c=void 0,u=d;var m=s,v=r;for(c in v)if(v.hasOwnProperty(c)){var b=v[c];"style"===c?Fn(m,b):"dangerouslySetInnerHTML"===c?null!=(b=b?b.__html:void 0)&&We(m,b):"children"===c?"string"===typeof b?("textarea"!==u||""!==b)&&Ve(m,b):"number"===typeof b&&Ve(m,""+b):"suppressContentEditableWarning"!==c&&"suppressHydrationWarning"!==c&&"autoFocus"!==c&&(p.hasOwnProperty(c)?null!=b&&Wn(f,c):null!=b&&ke(m,c,b,h))}switch(d){case"input":Oe(s),Re(s,n,!1);break;case"textarea":Oe(s),Le(s);break;case"option":null!=n.value&&s.setAttribute("value",""+we(n.value));break;case"select":(r=s).multiple=!!n.multiple,null!=(s=n.value)?_e(r,!!n.multiple,s,!1):null!=n.defaultValue&&_e(r,!!n.multiple,n.defaultValue,!0);break;default:"function"===typeof r.onClick&&(s.onclick=Vn)}(a=Jn(l,a))&&il(t)}null!==t.ref&&(t.effectTag|=128)}else if(null===t.stateNode)throw Error(i(166));break;case 6:if(n&&null!=t.stateNode)Zi(0,t,n.memoizedProps,a);else{if("string"!==typeof a&&null===t.stateNode)throw Error(i(166));r=Fa(Da.current),Fa(Ia.current),Di(t)?(l=(a=t).stateNode,r=a.memoizedProps,l[ar]=a,(a=l.nodeValue!==r)&&il(t)):(l=t,(a=(9===r.nodeType?r:r.ownerDocument).createTextNode(a))[ar]=l,t.stateNode=a)}break;case 11:break;case 13:if(co(Va),a=t.memoizedState,0!==(64&t.effectTag)){t.expirationTime=r;break e}a=null!==a,l=!1,null===n?void 0!==t.memoizedProps.fallback&&Di(t):(l=null!==(r=n.memoizedState),a||null===r||null!==(r=n.child.sibling)&&(null!==(s=t.firstEffect)?(t.firstEffect=r,r.nextEffect=s):(t.firstEffect=t.lastEffect=r,r.nextEffect=null),r.effectTag=8)),a&&!l&&0!==(2&t.mode)&&(null===n&&!0!==t.memoizedProps.unstable_avoidThisFallback||0!==(1&Va.current)?0===_l&&(_l=3):(0!==_l&&3!==_l||(_l=4),0!==Dl&&null!==Rl&&(Fu(Rl,Ml),Uu(Rl,Dl)))),(a||l)&&(t.effectTag|=4);break;case 7:case 8:case 12:break;case 4:$a();break;case 10:aa(t);break;case 9:case 14:break;case 17:bo(t.type)&&yo();break;case 19:if(co(Va),null===(a=t.memoizedState))break;if(l=0!==(64&t.effectTag),null===(s=a.rendering)){if(l)ll(a,!1);else if(0!==_l||null!==n&&0!==(64&n.effectTag))for(n=t.child;null!==n;){if(null!==(s=Ha(n))){for(t.effectTag|=64,ll(a,!1),null!==(l=s.updateQueue)&&(t.updateQueue=l,t.effectTag|=4),null===a.lastEffect&&(t.firstEffect=null),t.lastEffect=a.lastEffect,a=r,l=t.child;null!==l;)n=a,(r=l).effectTag&=2,r.nextEffect=null,r.firstEffect=null,r.lastEffect=null,null===(s=r.alternate)?(r.childExpirationTime=0,r.expirationTime=n,r.child=null,r.memoizedProps=null,r.memoizedState=null,r.updateQueue=null,r.dependencies=null):(r.childExpirationTime=s.childExpirationTime,r.expirationTime=s.expirationTime,r.child=s.child,r.memoizedProps=s.memoizedProps,r.memoizedState=s.memoizedState,r.updateQueue=s.updateQueue,n=s.dependencies,r.dependencies=null===n?null:{expirationTime:n.expirationTime,firstContext:n.firstContext,responders:n.responders}),l=l.sibling;so(Va,1&Va.current|2),t=t.child;break e}n=n.sibling}}else{if(!l)if(null!==(n=Ha(s))){if(t.effectTag|=64,l=!0,null!==(r=n.updateQueue)&&(t.updateQueue=r,t.effectTag|=4),ll(a,!0),null===a.tail&&"hidden"===a.tailMode&&!s.alternate){null!==(t=t.lastEffect=a.lastEffect)&&(t.nextEffect=null);break}}else Bo()>a.tailExpiration&&1<r&&(t.effectTag|=64,l=!0,ll(a,!1),t.expirationTime=t.childExpirationTime=r-1);a.isBackwards?(s.sibling=t.child,t.child=s):(null!==(r=a.last)?r.sibling=s:t.child=s,a.last=s)}if(null!==a.tail){0===a.tailExpiration&&(a.tailExpiration=Bo()+500),r=a.tail,a.rendering=r,a.tail=r.sibling,a.lastEffect=t.lastEffect,r.sibling=null,a=Va.current,so(Va,a=l?1&a|2:1&a),t=r;break e}break;case 20:case 21:break;default:throw Error(i(156,t.tag))}t=null}if(a=Nl,1===Ml||1!==a.childExpirationTime){for(l=0,r=a.child;null!==r;)(n=r.expirationTime)>l&&(l=n),(s=r.childExpirationTime)>l&&(l=s),r=r.sibling;a.childExpirationTime=l}if(null!==t)return t;null!==e&&0===(2048&e.effectTag)&&(null===e.firstEffect&&(e.firstEffect=Nl.firstEffect),null!==Nl.lastEffect&&(null!==e.lastEffect&&(e.lastEffect.nextEffect=Nl.firstEffect),e.lastEffect=Nl.lastEffect),1<Nl.effectTag&&(null!==e.lastEffect?e.lastEffect.nextEffect=Nl:e.firstEffect=Nl,e.lastEffect=Nl))}else{if(null!==(t=ul(Nl)))return t.effectTag&=2047,t;null!==e&&(e.firstEffect=e.lastEffect=null,e.effectTag|=2048)}if(null!==(t=Nl.sibling))return t;Nl=e}while(null!==Nl);return 0===_l&&(_l=5),null}function bu(e){var t=e.expirationTime;return t>(e=e.childExpirationTime)?t:e}function yu(e){var t=Wo();return Ho(99,gu.bind(null,e,t)),null}function gu(e,t){do{wu()}while(null!==ql);if(0!==(48&Pl))throw Error(i(327));var n=e.finishedWork,r=e.finishedExpirationTime;if(null===n)return null;if(e.finishedWork=null,e.finishedExpirationTime=0,n===e.current)throw Error(i(177));e.callbackNode=null,e.callbackExpirationTime=0,e.callbackPriority=90,e.nextKnownPendingLevel=0;var o=bu(n);if(e.firstPendingTime=o,r<=e.lastSuspendedTime?e.firstSuspendedTime=e.lastSuspendedTime=e.nextKnownPendingLevel=0:r<=e.firstSuspendedTime&&(e.firstSuspendedTime=r-1),r<=e.lastPingedTime&&(e.lastPingedTime=0),r<=e.lastExpiredTime&&(e.lastExpiredTime=0),e===Rl&&(Nl=Rl=null,Ml=0),1<n.effectTag?null!==n.lastEffect?(n.lastEffect.nextEffect=n,o=n.firstEffect):o=n:o=n.firstEffect,null!==o){var a=Pl;Pl|=32,jl.current=null,Gn=On;var l=Qn();if(Xn(l)){if("selectionStart"in l)var u={start:l.selectionStart,end:l.selectionEnd};else e:{var c=(u=(u=l.ownerDocument)&&u.defaultView||window).getSelection&&u.getSelection();if(c&&0!==c.rangeCount){u=c.anchorNode;var s=c.anchorOffset,d=c.focusNode;c=c.focusOffset;try{u.nodeType,d.nodeType}catch(z){u=null;break e}var f=0,p=-1,h=-1,m=0,v=0,b=l,y=null;t:for(;;){for(var g;b!==u||0!==s&&3!==b.nodeType||(p=f+s),b!==d||0!==c&&3!==b.nodeType||(h=f+c),3===b.nodeType&&(f+=b.nodeValue.length),null!==(g=b.firstChild);)y=b,b=g;for(;;){if(b===l)break t;if(y===u&&++m===s&&(p=f),y===d&&++v===c&&(h=f),null!==(g=b.nextSibling))break;y=(b=y).parentNode}b=g}u=-1===p||-1===h?null:{start:p,end:h}}else u=null}u=u||{start:0,end:0}}else u=null;Yn={focusedElem:l,selectionRange:u},On=!1,$l=o;do{try{xu()}catch(z){if(null===$l)throw Error(i(330));Ou($l,z),$l=$l.nextEffect}}while(null!==$l);$l=o;do{try{for(l=e,u=t;null!==$l;){var x=$l.effectTag;if(16&x&&Ve($l.stateNode,""),128&x){var w=$l.alternate;if(null!==w){var k=w.ref;null!==k&&("function"===typeof k?k(null):k.current=null)}}switch(1038&x){case 2:yl($l),$l.effectTag&=-3;break;case 6:yl($l),$l.effectTag&=-3,xl($l.alternate,$l);break;case 1024:$l.effectTag&=-1025;break;case 1028:$l.effectTag&=-1025,xl($l.alternate,$l);break;case 4:xl($l.alternate,$l);break;case 8:gl(l,s=$l,u),vl(s)}$l=$l.nextEffect}}catch(z){if(null===$l)throw Error(i(330));Ou($l,z),$l=$l.nextEffect}}while(null!==$l);if(k=Yn,w=Qn(),x=k.focusedElem,u=k.selectionRange,w!==x&&x&&x.ownerDocument&&function e(t,n){return!(!t||!n)&&(t===n||(!t||3!==t.nodeType)&&(n&&3===n.nodeType?e(t,n.parentNode):"contains"in t?t.contains(n):!!t.compareDocumentPosition&&!!(16&t.compareDocumentPosition(n))))}(x.ownerDocument.documentElement,x)){null!==u&&Xn(x)&&(w=u.start,void 0===(k=u.end)&&(k=w),"selectionStart"in x?(x.selectionStart=w,x.selectionEnd=Math.min(k,x.value.length)):(k=(w=x.ownerDocument||document)&&w.defaultView||window).getSelection&&(k=k.getSelection(),s=x.textContent.length,l=Math.min(u.start,s),u=void 0===u.end?l:Math.min(u.end,s),!k.extend&&l>u&&(s=u,u=l,l=s),s=Kn(x,l),d=Kn(x,u),s&&d&&(1!==k.rangeCount||k.anchorNode!==s.node||k.anchorOffset!==s.offset||k.focusNode!==d.node||k.focusOffset!==d.offset)&&((w=w.createRange()).setStart(s.node,s.offset),k.removeAllRanges(),l>u?(k.addRange(w),k.extend(d.node,d.offset)):(w.setEnd(d.node,d.offset),k.addRange(w))))),w=[];for(k=x;k=k.parentNode;)1===k.nodeType&&w.push({element:k,left:k.scrollLeft,top:k.scrollTop});for("function"===typeof x.focus&&x.focus(),x=0;x<w.length;x++)(k=w[x]).element.scrollLeft=k.left,k.element.scrollTop=k.top}Yn=null,On=!!Gn,Gn=null,e.current=n,$l=o;do{try{for(x=r;null!==$l;){var E=$l.effectTag;if(36&E){var O=$l.alternate;switch(k=x,(w=$l).tag){case 0:case 11:case 15:hl(16,32,w);break;case 1:var S=w.stateNode;if(4&w.effectTag)if(null===O)S.componentDidMount();else{var C=w.elementType===w.type?O.memoizedProps:Jo(w.type,O.memoizedProps);S.componentDidUpdate(C,O.memoizedState,S.__reactInternalSnapshotBeforeUpdate)}var T=w.updateQueue;null!==T&&ga(0,T,S);break;case 3:var j=w.updateQueue;if(null!==j){if(l=null,null!==w.child)switch(w.child.tag){case 5:l=w.child.stateNode;break;case 1:l=w.child.stateNode}ga(0,j,l)}break;case 5:var P=w.stateNode;null===O&&4&w.effectTag&&Jn(w.type,w.memoizedProps)&&P.focus();break;case 6:case 4:case 12:break;case 13:if(null===w.memoizedState){var R=w.alternate;if(null!==R){var N=R.memoizedState;if(null!==N){var M=N.dehydrated;null!==M&&Ct(M)}}}break;case 19:case 17:case 20:case 21:break;default:throw Error(i(163))}}if(128&E){w=void 0;var _=$l.ref;if(null!==_){var A=$l.stateNode;switch($l.tag){case 5:w=A;break;default:w=A}"function"===typeof _?_(w):_.current=w}}$l=$l.nextEffect}}catch(z){if(null===$l)throw Error(i(330));Ou($l,z),$l=$l.nextEffect}}while(null!==$l);$l=null,Lo(),Pl=a}else e.current=n;if(Hl)Hl=!1,ql=e,Kl=t;else for($l=o;null!==$l;)t=$l.nextEffect,$l.nextEffect=null,$l=t;if(0===(t=e.firstPendingTime)&&(Vl=null),1073741823===t?e===Gl?Xl++:(Xl=0,Gl=e):Xl=0,"function"===typeof Tu&&Tu(n.stateNode,r),ru(e),Bl)throw Bl=!1,e=Wl,Wl=null,e;return 0!==(8&Pl)?null:(Qo(),null)}function xu(){for(;null!==$l;){var e=$l.effectTag;0!==(256&e)&&pl($l.alternate,$l),0===(512&e)||Hl||(Hl=!0,qo(97,(function(){return wu(),null}))),$l=$l.nextEffect}}function wu(){if(90!==Kl){var e=97<Kl?97:Kl;return Kl=90,Ho(e,ku)}}function ku(){if(null===ql)return!1;var e=ql;if(ql=null,0!==(48&Pl))throw Error(i(331));var t=Pl;for(Pl|=32,e=e.current.firstEffect;null!==e;){try{var n=e;if(0!==(512&n.effectTag))switch(n.tag){case 0:case 11:case 15:hl(128,0,n),hl(0,64,n)}}catch(r){if(null===e)throw Error(i(330));Ou(e,r)}n=e.nextEffect,e.nextEffect=null,e=n}return Pl=t,Qo(),!0}function Eu(e,t,n){ha(e,t=El(e,t=cl(n,t),1073741823)),null!==(e=tu(e,1073741823))&&ru(e)}function Ou(e,t){if(3===e.tag)Eu(e,e,t);else for(var n=e.return;null!==n;){if(3===n.tag){Eu(n,e,t);break}if(1===n.tag){var r=n.stateNode;if("function"===typeof n.type.getDerivedStateFromError||"function"===typeof r.componentDidCatch&&(null===Vl||!Vl.has(r))){ha(n,e=Ol(n,e=cl(t,e),1073741823)),null!==(n=tu(n,1073741823))&&ru(n);break}}n=n.return}}function Su(e,t,n){var r=e.pingCache;null!==r&&r.delete(t),Rl===e&&Ml===n?4===_l||3===_l&&1073741823===zl&&Bo()-Ul<500?uu(e,Ml):Fl=!0:Du(e,n)&&(0!==(t=e.lastPingedTime)&&t<n||(e.lastPingedTime=n,e.finishedExpirationTime===n&&(e.finishedExpirationTime=0,e.finishedWork=null),ru(e)))}function Cu(e,t){var n=e.stateNode;null!==n&&n.delete(t),0===(t=0)&&(t=Zl(t=Jl(),e,null)),null!==(e=tu(e,t))&&ru(e)}Sl=function(e,t,n){var r=t.expirationTime;if(null!==e){var o=t.pendingProps;if(e.memoizedProps!==o||ho.current)$i=!0;else{if(r<n){switch($i=!1,t.tag){case 3:Gi(t),Fi();break;case 5:if(Ba(t),4&t.mode&&1!==n&&o.hidden)return t.expirationTime=t.childExpirationTime=1,null;break;case 1:bo(t.type)&&ko(t);break;case 4:Ua(t,t.stateNode.containerInfo);break;case 10:oa(t,t.memoizedProps.value);break;case 13:if(null!==t.memoizedState)return 0!==(r=t.child.childExpirationTime)&&r>=n?tl(e,t,n):(so(Va,1&Va.current),null!==(t=al(e,t,n))?t.sibling:null);so(Va,1&Va.current);break;case 19:if(r=t.childExpirationTime>=n,0!==(64&e.effectTag)){if(r)return ol(e,t,n);t.effectTag|=64}if(null!==(o=t.memoizedState)&&(o.rendering=null,o.tail=null),so(Va,Va.current),!r)return null}return al(e,t,n)}$i=!1}}else $i=!1;switch(t.expirationTime=0,t.tag){case 2:if(r=t.type,null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),e=t.pendingProps,o=vo(t,po.current),la(t,n),o=si(null,t,r,e,o,n),t.effectTag|=1,"object"===typeof o&&null!==o&&"function"===typeof o.render&&void 0===o.$$typeof){if(t.tag=1,di(),bo(r)){var a=!0;ko(t)}else a=!1;t.memoizedState=null!==o.state&&void 0!==o.state?o.state:null;var l=r.getDerivedStateFromProps;"function"===typeof l&&Ea(t,r,l,e),o.updater=Oa,t.stateNode=o,o._reactInternalFiber=t,ja(t,r,e,n),t=Xi(null,t,r,!0,a,n)}else t.tag=0,Bi(null,t,o,n),t=t.child;return t;case 16:if(o=t.elementType,null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),e=t.pendingProps,function(e){if(-1===e._status){e._status=0;var t=e._ctor;t=t(),e._result=t,t.then((function(t){0===e._status&&(t=t.default,e._status=1,e._result=t)}),(function(t){0===e._status&&(e._status=2,e._result=t)}))}}(o),1!==o._status)throw o._result;switch(o=o._result,t.type=o,a=t.tag=function(e){if("function"===typeof e)return Nu(e)?1:0;if(void 0!==e&&null!==e){if((e=e.$$typeof)===V)return 11;if(e===K)return 14}return 2}(o),e=Jo(o,e),a){case 0:t=Ki(null,t,o,e,n);break;case 1:t=Qi(null,t,o,e,n);break;case 11:t=Wi(null,t,o,e,n);break;case 14:t=Vi(null,t,o,Jo(o.type,e),r,n);break;default:throw Error(i(306,o,""))}return t;case 0:return r=t.type,o=t.pendingProps,Ki(e,t,r,o=t.elementType===r?o:Jo(r,o),n);case 1:return r=t.type,o=t.pendingProps,Qi(e,t,r,o=t.elementType===r?o:Jo(r,o),n);case 3:if(Gi(t),null===(r=t.updateQueue))throw Error(i(282));if(o=null!==(o=t.memoizedState)?o.element:null,ya(t,r,t.pendingProps,null,n),(r=t.memoizedState.element)===o)Fi(),t=al(e,t,n);else{if((o=t.stateNode.hydrate)&&(Mi=nr(t.stateNode.containerInfo.firstChild),Ni=t,o=_i=!0),o)for(n=Aa(t,null,r,n),t.child=n;n;)n.effectTag=-3&n.effectTag|1024,n=n.sibling;else Bi(e,t,r,n),Fi();t=t.child}return t;case 5:return Ba(t),null===e&&Ii(t),r=t.type,o=t.pendingProps,a=null!==e?e.memoizedProps:null,l=o.children,Zn(r,o)?l=null:null!==a&&Zn(r,a)&&(t.effectTag|=16),qi(e,t),4&t.mode&&1!==n&&o.hidden?(t.expirationTime=t.childExpirationTime=1,t=null):(Bi(e,t,l,n),t=t.child),t;case 6:return null===e&&Ii(t),null;case 13:return tl(e,t,n);case 4:return Ua(t,t.stateNode.containerInfo),r=t.pendingProps,null===e?t.child=_a(t,null,r,n):Bi(e,t,r,n),t.child;case 11:return r=t.type,o=t.pendingProps,Wi(e,t,r,o=t.elementType===r?o:Jo(r,o),n);case 7:return Bi(e,t,t.pendingProps,n),t.child;case 8:case 12:return Bi(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,o=t.pendingProps,l=t.memoizedProps,oa(t,a=o.value),null!==l){var u=l.value;if(0===(a=Gr(u,a)?0:0|("function"===typeof r._calculateChangedBits?r._calculateChangedBits(u,a):1073741823))){if(l.children===o.children&&!ho.current){t=al(e,t,n);break e}}else for(null!==(u=t.child)&&(u.return=t);null!==u;){var c=u.dependencies;if(null!==c){l=u.child;for(var s=c.firstContext;null!==s;){if(s.context===r&&0!==(s.observedBits&a)){1===u.tag&&((s=fa(n,null)).tag=2,ha(u,s)),u.expirationTime<n&&(u.expirationTime=n),null!==(s=u.alternate)&&s.expirationTime<n&&(s.expirationTime=n),ia(u.return,n),c.expirationTime<n&&(c.expirationTime=n);break}s=s.next}}else l=10===u.tag&&u.type===t.type?null:u.child;if(null!==l)l.return=u;else for(l=u;null!==l;){if(l===t){l=null;break}if(null!==(u=l.sibling)){u.return=l.return,l=u;break}l=l.return}u=l}}Bi(e,t,o.children,n),t=t.child}return t;case 9:return o=t.type,r=(a=t.pendingProps).children,la(t,n),r=r(o=ua(o,a.unstable_observedBits)),t.effectTag|=1,Bi(e,t,r,n),t.child;case 14:return a=Jo(o=t.type,t.pendingProps),Vi(e,t,o,a=Jo(o.type,a),r,n);case 15:return Hi(e,t,t.type,t.pendingProps,r,n);case 17:return r=t.type,o=t.pendingProps,o=t.elementType===r?o:Jo(r,o),null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),t.tag=1,bo(r)?(e=!0,ko(t)):e=!1,la(t,n),Ca(t,r,o),ja(t,r,o,n),Xi(null,t,r,!0,e,n);case 19:return ol(e,t,n)}throw Error(i(156,t.tag))};var Tu=null,ju=null;function Pu(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.effectTag=0,this.lastEffect=this.firstEffect=this.nextEffect=null,this.childExpirationTime=this.expirationTime=0,this.alternate=null}function Ru(e,t,n,r){return new Pu(e,t,n,r)}function Nu(e){return!(!(e=e.prototype)||!e.isReactComponent)}function Mu(e,t){var n=e.alternate;return null===n?((n=Ru(e.tag,t,e.key,e.mode)).elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.effectTag=0,n.nextEffect=null,n.firstEffect=null,n.lastEffect=null),n.childExpirationTime=e.childExpirationTime,n.expirationTime=e.expirationTime,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=null===t?null:{expirationTime:t.expirationTime,firstContext:t.firstContext,responders:t.responders},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function _u(e,t,n,r,o,a){var l=2;if(r=e,"function"===typeof e)Nu(e)&&(l=1);else if("string"===typeof e)l=5;else e:switch(e){case D:return Au(n.children,o,a,t);case W:l=8,o|=7;break;case F:l=8,o|=1;break;case U:return(e=Ru(12,n,t,8|o)).elementType=U,e.type=U,e.expirationTime=a,e;case H:return(e=Ru(13,n,t,o)).type=H,e.elementType=H,e.expirationTime=a,e;case q:return(e=Ru(19,n,t,o)).elementType=q,e.expirationTime=a,e;default:if("object"===typeof e&&null!==e)switch(e.$$typeof){case $:l=10;break e;case B:l=9;break e;case V:l=11;break e;case K:l=14;break e;case Q:l=16,r=null;break e}throw Error(i(130,null==e?e:typeof e,""))}return(t=Ru(l,n,t,o)).elementType=e,t.type=r,t.expirationTime=a,t}function Au(e,t,n,r){return(e=Ru(7,e,r,t)).expirationTime=n,e}function zu(e,t,n){return(e=Ru(6,e,null,t)).expirationTime=n,e}function Iu(e,t,n){return(t=Ru(4,null!==e.children?e.children:[],e.key,t)).expirationTime=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function Lu(e,t,n){this.tag=t,this.current=null,this.containerInfo=e,this.pingCache=this.pendingChildren=null,this.finishedExpirationTime=0,this.finishedWork=null,this.timeoutHandle=-1,this.pendingContext=this.context=null,this.hydrate=n,this.callbackNode=null,this.callbackPriority=90,this.lastExpiredTime=this.lastPingedTime=this.nextKnownPendingLevel=this.lastSuspendedTime=this.firstSuspendedTime=this.firstPendingTime=0}function Du(e,t){var n=e.firstSuspendedTime;return e=e.lastSuspendedTime,0!==n&&n>=t&&e<=t}function Fu(e,t){var n=e.firstSuspendedTime,r=e.lastSuspendedTime;n<t&&(e.firstSuspendedTime=t),(r>t||0===n)&&(e.lastSuspendedTime=t),t<=e.lastPingedTime&&(e.lastPingedTime=0),t<=e.lastExpiredTime&&(e.lastExpiredTime=0)}function Uu(e,t){t>e.firstPendingTime&&(e.firstPendingTime=t);var n=e.firstSuspendedTime;0!==n&&(t>=n?e.firstSuspendedTime=e.lastSuspendedTime=e.nextKnownPendingLevel=0:t>=e.lastSuspendedTime&&(e.lastSuspendedTime=t+1),t>e.nextKnownPendingLevel&&(e.nextKnownPendingLevel=t))}function $u(e,t){var n=e.lastExpiredTime;(0===n||n>t)&&(e.lastExpiredTime=t)}function Bu(e,t,n,r){var o=t.current,a=Jl(),l=wa.suspense;a=Zl(a,o,l);e:if(n){t:{if(tt(n=n._reactInternalFiber)!==n||1!==n.tag)throw Error(i(170));var u=n;do{switch(u.tag){case 3:u=u.stateNode.context;break t;case 1:if(bo(u.type)){u=u.stateNode.__reactInternalMemoizedMergedChildContext;break t}}u=u.return}while(null!==u);throw Error(i(171))}if(1===n.tag){var c=n.type;if(bo(c)){n=wo(n,c,u);break e}}n=u}else n=fo;return null===t.context?t.context=n:t.pendingContext=n,(t=fa(a,l)).payload={element:e},null!==(r=void 0===r?null:r)&&(t.callback=r),ha(o,t),eu(o,a),a}function Wu(e){if(!(e=e.current).child)return null;switch(e.child.tag){case 5:default:return e.child.stateNode}}function Vu(e,t){null!==(e=e.memoizedState)&&null!==e.dehydrated&&e.retryTime<t&&(e.retryTime=t)}function Hu(e,t){Vu(e,t),(e=e.alternate)&&Vu(e,t)}function qu(e,t,n){var r=new Lu(e,t,n=null!=n&&!0===n.hydrate),o=Ru(3,null,null,2===t?7:1===t?3:0);r.current=o,o.stateNode=r,e[lr]=r.current,n&&0!==t&&function(e){var t=An(e);vt.forEach((function(n){zn(n,e,t)})),bt.forEach((function(n){zn(n,e,t)}))}(9===e.nodeType?e:e.ownerDocument),this._internalRoot=r}function Ku(e){return!(!e||1!==e.nodeType&&9!==e.nodeType&&11!==e.nodeType&&(8!==e.nodeType||" react-mount-point-unstable "!==e.nodeValue))}function Qu(e,t,n,r,o){var a=n._reactRootContainer;if(a){var i=a._internalRoot;if("function"===typeof o){var l=o;o=function(){var e=Wu(i);l.call(e)}}Bu(t,i,e,o)}else{if(a=n._reactRootContainer=function(e,t){if(t||(t=!(!(t=e?9===e.nodeType?e.documentElement:e.firstChild:null)||1!==t.nodeType||!t.hasAttribute("data-reactroot"))),!t)for(var n;n=e.lastChild;)e.removeChild(n);return new qu(e,0,t?{hydrate:!0}:void 0)}(n,r),i=a._internalRoot,"function"===typeof o){var u=o;o=function(){var e=Wu(i);u.call(e)}}lu((function(){Bu(t,i,e,o)}))}return Wu(i)}function Xu(e,t,n){var r=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:L,key:null==r?null:""+r,children:e,containerInfo:t,implementation:n}}function Gu(e,t){var n=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!Ku(t))throw Error(i(200));return Xu(e,t,null,n)}qu.prototype.render=function(e,t){Bu(e,this._internalRoot,null,void 0===t?null:t)},qu.prototype.unmount=function(e){var t=this._internalRoot,n=void 0===e?null:e,r=t.containerInfo;Bu(null,t,null,(function(){r[lr]=null,null!==n&&n()}))},at=function(e){if(13===e.tag){var t=Yo(Jl(),150,100);eu(e,t),Hu(e,t)}},it=function(e){if(13===e.tag){Jl();var t=Go++;eu(e,t),Hu(e,t)}},lt=function(e){if(13===e.tag){var t=Jl();eu(e,t=Zl(t,e,null)),Hu(e,t)}},ee=function(e,t,n){switch(t){case"input":if(Pe(e,n),t=n.name,"radio"===n.type&&null!=t){for(n=e;n.parentNode;)n=n.parentNode;for(n=n.querySelectorAll("input[name="+JSON.stringify(""+t)+'][type="radio"]'),t=0;t<n.length;t++){var r=n[t];if(r!==e&&r.form===e.form){var o=dr(r);if(!o)throw Error(i(90));Se(r),Pe(r,o)}}}break;case"textarea":Ie(e,n);break;case"select":null!=(t=n.value)&&_e(e,!!n.multiple,t,!1)}},ie=iu,le=function(e,t,n,r){var o=Pl;Pl|=4;try{return Ho(98,e.bind(null,t,n,r))}finally{0===(Pl=o)&&Qo()}},ue=function(){0===(49&Pl)&&(function(){if(null!==Ql){var e=Ql;Ql=null,e.forEach((function(e,t){$u(t,e),ru(t)})),Qo()}}(),wu())},ce=function(e,t){var n=Pl;Pl|=2;try{return e(t)}finally{0===(Pl=n)&&Qo()}};var Yu={createPortal:Gu,findDOMNode:function(e){if(null==e)return null;if(1===e.nodeType)return e;var t=e._reactInternalFiber;if(void 0===t){if("function"===typeof e.render)throw Error(i(188));throw Error(i(268,Object.keys(e)))}return e=null===(e=ot(t))?null:e.stateNode},hydrate:function(e,t,n){if(!Ku(t))throw Error(i(200));return Qu(null,e,t,!0,n)},render:function(e,t,n){if(!Ku(t))throw Error(i(200));return Qu(null,e,t,!1,n)},unstable_renderSubtreeIntoContainer:function(e,t,n,r){if(!Ku(n))throw Error(i(200));if(null==e||void 0===e._reactInternalFiber)throw Error(i(38));return Qu(e,t,n,!1,r)},unmountComponentAtNode:function(e){if(!Ku(e))throw Error(i(40));return!!e._reactRootContainer&&(lu((function(){Qu(null,null,e,!1,(function(){e._reactRootContainer=null,e[lr]=null}))})),!0)},unstable_createPortal:function(){return Gu.apply(void 0,arguments)},unstable_batchedUpdates:iu,flushSync:function(e,t){if(0!==(48&Pl))throw Error(i(187));var n=Pl;Pl|=1;try{return Ho(99,e.bind(null,t))}finally{Pl=n,Qo()}},__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{Events:[cr,sr,dr,N.injectEventPluginsByName,f,_t,function(e){T(e,Mt)},oe,ae,Rn,R,wu,{current:!1}]}};!function(e){var t=e.findFiberByHostInstance;(function(e){if("undefined"===typeof __REACT_DEVTOOLS_GLOBAL_HOOK__)return!1;var t=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(t.isDisabled||!t.supportsFiber)return!0;try{var n=t.inject(e);Tu=function(e){try{t.onCommitFiberRoot(n,e,void 0,64===(64&e.current.effectTag))}catch(r){}},ju=function(e){try{t.onCommitFiberUnmount(n,e)}catch(r){}}}catch(r){}})(o({},e,{overrideHookState:null,overrideProps:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:_.ReactCurrentDispatcher,findHostInstanceByFiber:function(e){return null===(e=ot(e))?null:e.stateNode},findFiberByHostInstance:function(e){return t?t(e):null},findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null}))}({findFiberByHostInstance:ur,bundleType:0,version:"16.12.0",rendererPackageName:"react-dom"});var Ju={default:Yu},Zu=Ju&&Yu||Ju;e.exports=Zu.default||Zu},function(e,t,n){"use strict";e.exports=n(105)},function(e,t,n){"use strict";var r,o,a,i,l;if(Object.defineProperty(t,"__esModule",{value:!0}),"undefined"===typeof window||"function"!==typeof MessageChannel){var u=null,c=null,s=function e(){if(null!==u)try{var n=t.unstable_now();u(!0,n),u=null}catch(r){throw setTimeout(e,0),r}},d=Date.now();t.unstable_now=function(){return Date.now()-d},r=function(e){null!==u?setTimeout(r,0,e):(u=e,setTimeout(s,0))},o=function(e,t){c=setTimeout(e,t)},a=function(){clearTimeout(c)},i=function(){return!1},l=t.unstable_forceFrameRate=function(){}}else{var f=window.performance,p=window.Date,h=window.setTimeout,m=window.clearTimeout;if("undefined"!==typeof console){var v=window.cancelAnimationFrame;"function"!==typeof window.requestAnimationFrame&&console.error("This browser doesn't support requestAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills"),"function"!==typeof v&&console.error("This browser doesn't support cancelAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills")}if("object"===typeof f&&"function"===typeof f.now)t.unstable_now=function(){return f.now()};else{var b=p.now();t.unstable_now=function(){return p.now()-b}}var y=!1,g=null,x=-1,w=5,k=0;i=function(){return t.unstable_now()>=k},l=function(){},t.unstable_forceFrameRate=function(e){0>e||125<e?console.error("forceFrameRate takes a positive int between 0 and 125, forcing framerates higher than 125 fps is not unsupported"):w=0<e?Math.floor(1e3/e):5};var E=new MessageChannel,O=E.port2;E.port1.onmessage=function(){if(null!==g){var e=t.unstable_now();k=e+w;try{g(!0,e)?O.postMessage(null):(y=!1,g=null)}catch(n){throw O.postMessage(null),n}}else y=!1},r=function(e){g=e,y||(y=!0,O.postMessage(null))},o=function(e,n){x=h((function(){e(t.unstable_now())}),n)},a=function(){m(x),x=-1}}function S(e,t){var n=e.length;e.push(t);e:for(;;){var r=Math.floor((n-1)/2),o=e[r];if(!(void 0!==o&&0<j(o,t)))break e;e[r]=t,e[n]=o,n=r}}function C(e){return void 0===(e=e[0])?null:e}function T(e){var t=e[0];if(void 0!==t){var n=e.pop();if(n!==t){e[0]=n;e:for(var r=0,o=e.length;r<o;){var a=2*(r+1)-1,i=e[a],l=a+1,u=e[l];if(void 0!==i&&0>j(i,n))void 0!==u&&0>j(u,i)?(e[r]=u,e[l]=n,r=l):(e[r]=i,e[a]=n,r=a);else{if(!(void 0!==u&&0>j(u,n)))break e;e[r]=u,e[l]=n,r=l}}}return t}return null}function j(e,t){var n=e.sortIndex-t.sortIndex;return 0!==n?n:e.id-t.id}var P=[],R=[],N=1,M=null,_=3,A=!1,z=!1,I=!1;function L(e){for(var t=C(R);null!==t;){if(null===t.callback)T(R);else{if(!(t.startTime<=e))break;T(R),t.sortIndex=t.expirationTime,S(P,t)}t=C(R)}}function D(e){if(I=!1,L(e),!z)if(null!==C(P))z=!0,r(F);else{var t=C(R);null!==t&&o(D,t.startTime-e)}}function F(e,n){z=!1,I&&(I=!1,a()),A=!0;var r=_;try{for(L(n),M=C(P);null!==M&&(!(M.expirationTime>n)||e&&!i());){var l=M.callback;if(null!==l){M.callback=null,_=M.priorityLevel;var u=l(M.expirationTime<=n);n=t.unstable_now(),"function"===typeof u?M.callback=u:M===C(P)&&T(P),L(n)}else T(P);M=C(P)}if(null!==M)var c=!0;else{var s=C(R);null!==s&&o(D,s.startTime-n),c=!1}return c}finally{M=null,_=r,A=!1}}function U(e){switch(e){case 1:return-1;case 2:return 250;case 5:return 1073741823;case 4:return 1e4;default:return 5e3}}var $=l;t.unstable_ImmediatePriority=1,t.unstable_UserBlockingPriority=2,t.unstable_NormalPriority=3,t.unstable_IdlePriority=5,t.unstable_LowPriority=4,t.unstable_runWithPriority=function(e,t){switch(e){case 1:case 2:case 3:case 4:case 5:break;default:e=3}var n=_;_=e;try{return t()}finally{_=n}},t.unstable_next=function(e){switch(_){case 1:case 2:case 3:var t=3;break;default:t=_}var n=_;_=t;try{return e()}finally{_=n}},t.unstable_scheduleCallback=function(e,n,i){var l=t.unstable_now();if("object"===typeof i&&null!==i){var u=i.delay;u="number"===typeof u&&0<u?l+u:l,i="number"===typeof i.timeout?i.timeout:U(e)}else i=U(e),u=l;return e={id:N++,callback:n,priorityLevel:e,startTime:u,expirationTime:i=u+i,sortIndex:-1},u>l?(e.sortIndex=u,S(R,e),null===C(P)&&e===C(R)&&(I?a():I=!0,o(D,u-l))):(e.sortIndex=i,S(P,e),z||A||(z=!0,r(F))),e},t.unstable_cancelCallback=function(e){e.callback=null},t.unstable_wrapCallback=function(e){var t=_;return function(){var n=_;_=t;try{return e.apply(this,arguments)}finally{_=n}}},t.unstable_getCurrentPriorityLevel=function(){return _},t.unstable_shouldYield=function(){var e=t.unstable_now();L(e);var n=C(P);return n!==M&&null!==M&&null!==n&&null!==n.callback&&n.startTime<=e&&n.expirationTime<M.expirationTime||i()},t.unstable_requestPaint=$,t.unstable_continueExecution=function(){z||A||(z=!0,r(F))},t.unstable_pauseExecution=function(){},t.unstable_getFirstCallbackNode=function(){return C(P)},t.unstable_Profiling=null},,function(e,t,n){"use strict";var r=n(21),o=n(74),a=n(108),i=n(80);function l(e){var t=new a(e),n=o(a.prototype.request,t);return r.extend(n,a.prototype,t),r.extend(n,t),n}var u=l(n(77));u.Axios=a,u.create=function(e){return l(i(u.defaults,e))},u.Cancel=n(81),u.CancelToken=n(122),u.isCancel=n(76),u.all=function(e){return Promise.all(e)},u.spread=n(123),e.exports=u,e.exports.default=u},function(e,t,n){"use strict";var r=n(21),o=n(75),a=n(109),i=n(110),l=n(80);function u(e){this.defaults=e,this.interceptors={request:new a,response:new a}}u.prototype.request=function(e){"string"===typeof e?(e=arguments[1]||{}).url=arguments[0]:e=e||{},(e=l(this.defaults,e)).method?e.method=e.method.toLowerCase():this.defaults.method?e.method=this.defaults.method.toLowerCase():e.method="get";var t=[i,void 0],n=Promise.resolve(e);for(this.interceptors.request.forEach((function(e){t.unshift(e.fulfilled,e.rejected)})),this.interceptors.response.forEach((function(e){t.push(e.fulfilled,e.rejected)}));t.length;)n=n.then(t.shift(),t.shift());return n},u.prototype.getUri=function(e){return e=l(this.defaults,e),o(e.url,e.params,e.paramsSerializer).replace(/^\?/,"")},r.forEach(["delete","get","head","options"],(function(e){u.prototype[e]=function(t,n){return this.request(r.merge(n||{},{method:e,url:t}))}})),r.forEach(["post","put","patch"],(function(e){u.prototype[e]=function(t,n,o){return this.request(r.merge(o||{},{method:e,url:t,data:n}))}})),e.exports=u},function(e,t,n){"use strict";var r=n(21);function o(){this.handlers=[]}o.prototype.use=function(e,t){return this.handlers.push({fulfilled:e,rejected:t}),this.handlers.length-1},o.prototype.eject=function(e){this.handlers[e]&&(this.handlers[e]=null)},o.prototype.forEach=function(e){r.forEach(this.handlers,(function(t){null!==t&&e(t)}))},e.exports=o},function(e,t,n){"use strict";var r=n(21),o=n(111),a=n(76),i=n(77);function l(e){e.cancelToken&&e.cancelToken.throwIfRequested()}e.exports=function(e){return l(e),e.headers=e.headers||{},e.data=o(e.data,e.headers,e.transformRequest),e.headers=r.merge(e.headers.common||{},e.headers[e.method]||{},e.headers),r.forEach(["delete","get","head","post","put","patch","common"],(function(t){delete e.headers[t]})),(e.adapter||i.adapter)(e).then((function(t){return l(e),t.data=o(t.data,t.headers,e.transformResponse),t}),(function(t){return a(t)||(l(e),t&&t.response&&(t.response.data=o(t.response.data,t.response.headers,e.transformResponse))),Promise.reject(t)}))}},function(e,t,n){"use strict";var r=n(21);e.exports=function(e,t,n){return r.forEach(n,(function(n){e=n(e,t)})),e}},function(e,t){var n,r,o=e.exports={};function a(){throw new Error("setTimeout has not been defined")}function i(){throw new Error("clearTimeout has not been defined")}function l(e){if(n===setTimeout)return setTimeout(e,0);if((n===a||!n)&&setTimeout)return n=setTimeout,setTimeout(e,0);try{return n(e,0)}catch(t){try{return n.call(null,e,0)}catch(t){return n.call(this,e,0)}}}!function(){try{n="function"===typeof setTimeout?setTimeout:a}catch(e){n=a}try{r="function"===typeof clearTimeout?clearTimeout:i}catch(e){r=i}}();var u,c=[],s=!1,d=-1;function f(){s&&u&&(s=!1,u.length?c=u.concat(c):d=-1,c.length&&p())}function p(){if(!s){var e=l(f);s=!0;for(var t=c.length;t;){for(u=c,c=[];++d<t;)u&&u[d].run();d=-1,t=c.length}u=null,s=!1,function(e){if(r===clearTimeout)return clearTimeout(e);if((r===i||!r)&&clearTimeout)return r=clearTimeout,clearTimeout(e);try{r(e)}catch(t){try{return r.call(null,e)}catch(t){return r.call(this,e)}}}(e)}}function h(e,t){this.fun=e,this.array=t}function m(){}o.nextTick=function(e){var t=new Array(arguments.length-1);if(arguments.length>1)for(var n=1;n<arguments.length;n++)t[n-1]=arguments[n];c.push(new h(e,t)),1!==c.length||s||l(p)},h.prototype.run=function(){this.fun.apply(null,this.array)},o.title="browser",o.browser=!0,o.env={},o.argv=[],o.version="",o.versions={},o.on=m,o.addListener=m,o.once=m,o.off=m,o.removeListener=m,o.removeAllListeners=m,o.emit=m,o.prependListener=m,o.prependOnceListener=m,o.listeners=function(e){return[]},o.binding=function(e){throw new Error("process.binding is not supported")},o.cwd=function(){return"/"},o.chdir=function(e){throw new Error("process.chdir is not supported")},o.umask=function(){return 0}},function(e,t,n){"use strict";var r=n(21);e.exports=function(e,t){r.forEach(e,(function(n,r){r!==t&&r.toUpperCase()===t.toUpperCase()&&(e[t]=n,delete e[r])}))}},function(e,t,n){"use strict";var r=n(79);e.exports=function(e,t,n){var o=n.config.validateStatus;!o||o(n.status)?e(n):t(r("Request failed with status code "+n.status,n.config,null,n.request,n))}},function(e,t,n){"use strict";e.exports=function(e,t,n,r,o){return e.config=t,n&&(e.code=n),e.request=r,e.response=o,e.isAxiosError=!0,e.toJSON=function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:this.config,code:this.code}},e}},function(e,t,n){"use strict";var r=n(117),o=n(118);e.exports=function(e,t){return e&&!r(t)?o(e,t):t}},function(e,t,n){"use strict";e.exports=function(e){return/^([a-z][a-z\d\+\-\.]*:)?\/\//i.test(e)}},function(e,t,n){"use strict";e.exports=function(e,t){return t?e.replace(/\/+$/,"")+"/"+t.replace(/^\/+/,""):e}},function(e,t,n){"use strict";var r=n(21),o=["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"];e.exports=function(e){var t,n,a,i={};return e?(r.forEach(e.split("\n"),(function(e){if(a=e.indexOf(":"),t=r.trim(e.substr(0,a)).toLowerCase(),n=r.trim(e.substr(a+1)),t){if(i[t]&&o.indexOf(t)>=0)return;i[t]="set-cookie"===t?(i[t]?i[t]:[]).concat([n]):i[t]?i[t]+", "+n:n}})),i):i}},function(e,t,n){"use strict";var r=n(21);e.exports=r.isStandardBrowserEnv()?function(){var e,t=/(msie|trident)/i.test(navigator.userAgent),n=document.createElement("a");function o(e){var r=e;return t&&(n.setAttribute("href",r),r=n.href),n.setAttribute("href",r),{href:n.href,protocol:n.protocol?n.protocol.replace(/:$/,""):"",host:n.host,search:n.search?n.search.replace(/^\?/,""):"",hash:n.hash?n.hash.replace(/^#/,""):"",hostname:n.hostname,port:n.port,pathname:"/"===n.pathname.charAt(0)?n.pathname:"/"+n.pathname}}return e=o(window.location.href),function(t){var n=r.isString(t)?o(t):t;return n.protocol===e.protocol&&n.host===e.host}}():function(){return!0}},function(e,t,n){"use strict";var r=n(21);e.exports=r.isStandardBrowserEnv()?{write:function(e,t,n,o,a,i){var l=[];l.push(e+"="+encodeURIComponent(t)),r.isNumber(n)&&l.push("expires="+new Date(n).toGMTString()),r.isString(o)&&l.push("path="+o),r.isString(a)&&l.push("domain="+a),!0===i&&l.push("secure"),document.cookie=l.join("; ")},read:function(e){var t=document.cookie.match(new RegExp("(^|;\\s*)("+e+")=([^;]*)"));return t?decodeURIComponent(t[3]):null},remove:function(e){this.write(e,"",Date.now()-864e5)}}:{write:function(){},read:function(){return null},remove:function(){}}},function(e,t,n){"use strict";var r=n(81);function o(e){if("function"!==typeof e)throw new TypeError("executor must be a function.");var t;this.promise=new Promise((function(e){t=e}));var n=this;e((function(e){n.reason||(n.reason=new r(e),t(n.reason))}))}o.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},o.source=function(){var e;return{token:new o((function(t){e=t})),cancel:e}},e.exports=o},function(e,t,n){"use strict";e.exports=function(e){return function(t){return e.apply(null,t)}}},function(e,t,n){"use strict";var r=n(125);function o(){}function a(){}a.resetWarningCache=o,e.exports=function(){function e(e,t,n,o,a,i){if(i!==r){var l=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw l.name="Invariant Violation",l}}function t(){return e}e.isRequired=e;var n={array:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:a,resetWarningCache:o};return n.PropTypes=n,n}},function(e,t,n){"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r="function"===typeof Symbol&&Symbol.for,o=r?Symbol.for("react.element"):60103,a=r?Symbol.for("react.portal"):60106,i=r?Symbol.for("react.fragment"):60107,l=r?Symbol.for("react.strict_mode"):60108,u=r?Symbol.for("react.profiler"):60114,c=r?Symbol.for("react.provider"):60109,s=r?Symbol.for("react.context"):60110,d=r?Symbol.for("react.async_mode"):60111,f=r?Symbol.for("react.concurrent_mode"):60111,p=r?Symbol.for("react.forward_ref"):60112,h=r?Symbol.for("react.suspense"):60113,m=r?Symbol.for("react.suspense_list"):60120,v=r?Symbol.for("react.memo"):60115,b=r?Symbol.for("react.lazy"):60116,y=r?Symbol.for("react.fundamental"):60117,g=r?Symbol.for("react.responder"):60118,x=r?Symbol.for("react.scope"):60119;function w(e){if("object"===typeof e&&null!==e){var t=e.$$typeof;switch(t){case o:switch(e=e.type){case d:case f:case i:case u:case l:case h:return e;default:switch(e=e&&e.$$typeof){case s:case p:case b:case v:case c:return e;default:return t}}case a:return t}}}function k(e){return w(e)===f}t.typeOf=w,t.AsyncMode=d,t.ConcurrentMode=f,t.ContextConsumer=s,t.ContextProvider=c,t.Element=o,t.ForwardRef=p,t.Fragment=i,t.Lazy=b,t.Memo=v,t.Portal=a,t.Profiler=u,t.StrictMode=l,t.Suspense=h,t.isValidElementType=function(e){return"string"===typeof e||"function"===typeof e||e===i||e===f||e===u||e===l||e===h||e===m||"object"===typeof e&&null!==e&&(e.$$typeof===b||e.$$typeof===v||e.$$typeof===c||e.$$typeof===s||e.$$typeof===p||e.$$typeof===y||e.$$typeof===g||e.$$typeof===x)},t.isAsyncMode=function(e){return k(e)||w(e)===d},t.isConcurrentMode=k,t.isContextConsumer=function(e){return w(e)===s},t.isContextProvider=function(e){return w(e)===c},t.isElement=function(e){return"object"===typeof e&&null!==e&&e.$$typeof===o},t.isForwardRef=function(e){return w(e)===p},t.isFragment=function(e){return w(e)===i},t.isLazy=function(e){return w(e)===b},t.isMemo=function(e){return w(e)===v},t.isPortal=function(e){return w(e)===a},t.isProfiler=function(e){return w(e)===u},t.isStrictMode=function(e){return w(e)===l},t.isSuspense=function(e){return w(e)===h}},function(e,t){function n(){return e.exports=n=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},n.apply(this,arguments)}e.exports=n},function(e,t){var n;n=function(){return this}();try{n=n||new Function("return this")()}catch(r){"object"===typeof window&&(n=window)}e.exports=n},function(e,t){e.exports=Array.isArray||function(e){return"[object Array]"==Object.prototype.toString.call(e)}},,function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(6),s={h1:"h1",h2:"h2",h3:"h3",h4:"h4",h5:"h5",h6:"h6",subtitle1:"h6",subtitle2:"h6",body1:"p",body2:"p"},d=i.a.forwardRef((function(e,t){var n=e.align,a=void 0===n?"inherit":n,u=e.classes,d=e.className,f=e.color,p=void 0===f?"initial":f,h=e.component,m=e.display,v=void 0===m?"initial":m,b=e.gutterBottom,y=void 0!==b&&b,g=e.noWrap,x=void 0!==g&&g,w=e.paragraph,k=void 0!==w&&w,E=e.variant,O=void 0===E?"body1":E,S=e.variantMapping,C=void 0===S?s:S,T=Object(o.a)(e,["align","classes","className","color","component","display","gutterBottom","noWrap","paragraph","variant","variantMapping"]),j=h||(k?"p":C[O]||s[O])||"span";return i.a.createElement(j,Object(r.a)({className:Object(l.a)(u.root,d,"inherit"!==O&&u[O],"initial"!==p&&u["color".concat(Object(c.a)(p))],x&&u.noWrap,y&&u.gutterBottom,k&&u.paragraph,"inherit"!==a&&u["align".concat(Object(c.a)(a))],"initial"!==v&&u["display".concat(Object(c.a)(v))]),ref:t},T))}));t.a=Object(u.a)((function(e){return{root:{margin:0},body2:e.typography.body2,body1:e.typography.body1,caption:e.typography.caption,button:e.typography.button,h1:e.typography.h1,h2:e.typography.h2,h3:e.typography.h3,h4:e.typography.h4,h5:e.typography.h5,h6:e.typography.h6,subtitle1:e.typography.subtitle1,subtitle2:e.typography.subtitle2,overline:e.typography.overline,srOnly:{position:"absolute",height:1,width:1,overflow:"hidden"},alignLeft:{textAlign:"left"},alignCenter:{textAlign:"center"},alignRight:{textAlign:"right"},alignJustify:{textAlign:"justify"},noWrap:{overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},gutterBottom:{marginBottom:"0.35em"},paragraph:{marginBottom:16},colorInherit:{color:"inherit"},colorPrimary:{color:e.palette.primary.main},colorSecondary:{color:e.palette.secondary.main},colorTextPrimary:{color:e.palette.text.primary},colorTextSecondary:{color:e.palette.text.secondary},colorError:{color:e.palette.error.main},displayInline:{display:"inline"},displayBlock:{display:"block"}}}),{name:"MuiTypography"})(d)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(10),s=n(94),d=n(6),f=i.a.forwardRef((function(e,t){var n=e.edge,a=void 0!==n&&n,u=e.children,c=e.classes,f=e.className,p=e.color,h=void 0===p?"default":p,m=e.disabled,v=void 0!==m&&m,b=e.disableFocusRipple,y=void 0!==b&&b,g=e.size,x=void 0===g?"medium":g,w=Object(o.a)(e,["edge","children","classes","className","color","disabled","disableFocusRipple","size"]);return i.a.createElement(s.a,Object(r.a)({className:Object(l.a)(c.root,f,"default"!==h&&c["color".concat(Object(d.a)(h))],v&&c.disabled,{small:c["size".concat(Object(d.a)(x))]}[x],{start:c.edgeStart,end:c.edgeEnd}[a]),centerRipple:!0,focusRipple:!y,disabled:v,ref:t},w),i.a.createElement("span",{className:c.label},u))}));t.a=Object(u.a)((function(e){return{root:{textAlign:"center",flex:"0 0 auto",fontSize:e.typography.pxToRem(24),padding:12,borderRadius:"50%",overflow:"visible",color:e.palette.action.active,transition:e.transitions.create("background-color",{duration:e.transitions.duration.shortest}),"&:hover":{backgroundColor:Object(c.b)(e.palette.action.active,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},"&$disabled":{backgroundColor:"transparent",color:e.palette.action.disabled}},edgeStart:{marginLeft:-12,"$sizeSmall&":{marginLeft:-3}},edgeEnd:{marginRight:-12,"$sizeSmall&":{marginRight:-3}},colorInherit:{color:"inherit"},colorPrimary:{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},colorSecondary:{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},disabled:{},sizeSmall:{padding:3,fontSize:e.typography.pxToRem(18)},label:{width:"100%",display:"flex",alignItems:"inherit",justifyContent:"inherit"}}}),{name:"MuiIconButton"})(f)},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l="function"===typeof Symbol&&"symbol"===typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"===typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},u="object"===("undefined"===typeof window?"undefined":l(window))&&"object"===("undefined"===typeof document?"undefined":l(document))&&9===document.nodeType,c=(n(33),n(48)),s=n(12),d=n(49),f=n(15),p={}.constructor;function h(e){if(null==e||"object"!==typeof e)return e;if(Array.isArray(e))return e.map(h);if(e.constructor!==p)return e;var t={};for(var n in e)t[n]=h(e[n]);return t}function m(e,t,n){void 0===e&&(e="unnamed");var r=n.jss,o=h(t),a=r.plugins.onCreateRule(e,o,n);return a||(e[0],null)}var v=function(e,t){for(var n="",r=0;r<e.length&&"!important"!==e[r];r++)n&&(n+=t),n+=e[r];return n};function b(e,t){if(void 0===t&&(t=!1),!Array.isArray(e))return e;var n="";if(Array.isArray(e[0]))for(var r=0;r<e.length&&"!important"!==e[r];r++)n&&(n+=", "),n+=v(e[r]," ");else n=v(e,", ");return t||"!important"!==e[e.length-1]||(n+=" !important"),n}function y(e,t){for(var n="",r=0;r<t;r++)n+=" ";return n+e}function g(e,t,n){void 0===n&&(n={});var r="";if(!t)return r;var o=n.indent,a=void 0===o?0:o,i=t.fallbacks;if(e&&a++,i)if(Array.isArray(i))for(var l=0;l<i.length;l++){var u=i[l];for(var c in u){var s=u[c];null!=s&&(r&&(r+="\n"),r+=""+y(c+": "+b(s)+";",a))}}else for(var d in i){var f=i[d];null!=f&&(r&&(r+="\n"),r+=""+y(d+": "+b(f)+";",a))}for(var p in t){var h=t[p];null!=h&&"fallbacks"!==p&&(r&&(r+="\n"),r+=""+y(p+": "+b(h)+";",a))}return(r||n.allowEmpty)&&e?(r&&(r="\n"+r+"\n"),y(e+" {"+r,--a)+y("}",a)):r}var x=/([[\].#*$><+~=|^:(),"'`\s])/g,w="undefined"!==typeof CSS&&CSS.escape,k=function(e){return w?w(e):e.replace(x,"\\$1")},E=function(){function e(e,t,n){this.type="style",this.key=void 0,this.isProcessed=!1,this.style=void 0,this.renderer=void 0,this.renderable=void 0,this.options=void 0;var r=n.sheet,o=n.Renderer;this.key=e,this.options=n,this.style=t,r?this.renderer=r.renderer:o&&(this.renderer=new o)}return e.prototype.prop=function(e,t,n){if(void 0===t)return this.style[e];var r=!!n&&n.force;if(!r&&this.style[e]===t)return this;var o=t;n&&!1===n.process||(o=this.options.jss.plugins.onChangeValue(t,e,this));var a=null==o||!1===o,i=e in this.style;if(a&&!i&&!r)return this;var l=a&&i;if(l?delete this.style[e]:this.style[e]=o,this.renderable&&this.renderer)return l?this.renderer.removeProperty(this.renderable,e):this.renderer.setProperty(this.renderable,e,o),this;var u=this.options.sheet;return u&&u.attached,this},e}(),O=function(e){function t(t,n,r){var o;(o=e.call(this,t,n,r)||this).selectorText=void 0,o.id=void 0,o.renderable=void 0;var a=r.selector,i=r.scoped,l=r.sheet,u=r.generateId;return a?o.selectorText=a:!1!==i&&(o.id=u(Object(d.a)(Object(d.a)(o)),l),o.selectorText="."+k(o.id)),o}Object(s.a)(t,e);var n=t.prototype;return n.applyTo=function(e){var t=this.renderer;if(t){var n=this.toJSON();for(var r in n)t.setProperty(e,r,n[r])}return this},n.toJSON=function(){var e={};for(var t in this.style){var n=this.style[t];"object"!==typeof n?e[t]=n:Array.isArray(n)&&(e[t]=b(n))}return e},n.toString=function(e){var t=this.options.sheet,n=!!t&&t.options.link?Object(o.a)({},e,{allowEmpty:!0}):e;return g(this.selectorText,this.style,n)},Object(c.a)(t,[{key:"selector",set:function(e){if(e!==this.selectorText){this.selectorText=e;var t=this.renderer,n=this.renderable;if(n&&t)t.setSelector(n,e)||t.replaceRule(n,this)}},get:function(){return this.selectorText}}]),t}(E),S={onCreateRule:function(e,t,n){return"@"===e[0]||n.parent&&"keyframes"===n.parent.type?null:new O(e,t,n)}},C={indent:1,children:!0},T=/@([\w-]+)/,j=function(){function e(e,t,n){this.type="conditional",this.at=void 0,this.key=void 0,this.query=void 0,this.rules=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.query=n.name;var r=e.match(T);for(var a in this.at=r?r[1]:"unknown",this.options=n,this.rules=new G(Object(o.a)({},n,{parent:this})),t)this.rules.add(a,t[a]);this.rules.process()}var t=e.prototype;return t.getRule=function(e){return this.rules.get(e)},t.indexOf=function(e){return this.rules.indexOf(e)},t.addRule=function(e,t,n){var r=this.rules.add(e,t,n);return r?(this.options.jss.plugins.onProcessRule(r),r):null},t.toString=function(e){if(void 0===e&&(e=C),null==e.indent&&(e.indent=C.indent),null==e.children&&(e.children=C.children),!1===e.children)return this.query+" {}";var t=this.rules.toString(e);return t?this.query+" {\n"+t+"\n}":""},e}(),P=/@media|@supports\s+/,R={onCreateRule:function(e,t,n){return P.test(e)?new j(e,t,n):null}},N={indent:1,children:!0},M=/@keyframes\s+([\w-]+)/,_=function(){function e(e,t,n){this.type="keyframes",this.at="@keyframes",this.key=void 0,this.name=void 0,this.id=void 0,this.rules=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0;var r=e.match(M);r&&r[1]?this.name=r[1]:this.name="noname",this.key=this.type+"-"+this.name,this.options=n;var a=n.scoped,i=n.sheet,l=n.generateId;for(var u in this.id=!1===a?this.name:k(l(this,i)),this.rules=new G(Object(o.a)({},n,{parent:this})),t)this.rules.add(u,t[u],Object(o.a)({},n,{parent:this}));this.rules.process()}return e.prototype.toString=function(e){if(void 0===e&&(e=N),null==e.indent&&(e.indent=N.indent),null==e.children&&(e.children=N.children),!1===e.children)return this.at+" "+this.id+" {}";var t=this.rules.toString(e);return t&&(t="\n"+t+"\n"),this.at+" "+this.id+" {"+t+"}"},e}(),A=/@keyframes\s+/,z=/\$([\w-]+)/g,I=function(e,t){return"string"===typeof e?e.replace(z,(function(e,n){return n in t?t[n]:e})):e},L=function(e,t,n){var r=e[t],o=I(r,n);o!==r&&(e[t]=o)},D={onCreateRule:function(e,t,n){return"string"===typeof e&&A.test(e)?new _(e,t,n):null},onProcessStyle:function(e,t,n){return"style"===t.type&&n?("animation-name"in e&&L(e,"animation-name",n.keyframes),"animation"in e&&L(e,"animation",n.keyframes),e):e},onChangeValue:function(e,t,n){var r=n.options.sheet;if(!r)return e;switch(t){case"animation":case"animation-name":return I(e,r.keyframes);default:return e}}},F=function(e){function t(){for(var t,n=arguments.length,r=new Array(n),o=0;o<n;o++)r[o]=arguments[o];return(t=e.call.apply(e,[this].concat(r))||this).renderable=void 0,t}return Object(s.a)(t,e),t.prototype.toString=function(e){var t=this.options.sheet,n=!!t&&t.options.link?Object(o.a)({},e,{allowEmpty:!0}):e;return g(this.key,this.style,n)},t}(E),U={onCreateRule:function(e,t,n){return n.parent&&"keyframes"===n.parent.type?new F(e,t,n):null}},$=function(){function e(e,t,n){this.type="font-face",this.at="@font-face",this.key=void 0,this.style=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.style=t,this.options=n}return e.prototype.toString=function(e){if(Array.isArray(this.style)){for(var t="",n=0;n<this.style.length;n++)t+=g(this.key,this.style[n]),this.style[n+1]&&(t+="\n");return t}return g(this.key,this.style,e)},e}(),B={onCreateRule:function(e,t,n){return"@font-face"===e?new $(e,t,n):null}},W=function(){function e(e,t,n){this.type="viewport",this.at="@viewport",this.key=void 0,this.style=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.style=t,this.options=n}return e.prototype.toString=function(e){return g(this.key,this.style,e)},e}(),V={onCreateRule:function(e,t,n){return"@viewport"===e||"@-ms-viewport"===e?new W(e,t,n):null}},H=function(){function e(e,t,n){this.type="simple",this.key=void 0,this.value=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.value=t,this.options=n}return e.prototype.toString=function(e){if(Array.isArray(this.value)){for(var t="",n=0;n<this.value.length;n++)t+=this.key+" "+this.value[n]+";",this.value[n+1]&&(t+="\n");return t}return this.key+" "+this.value+";"},e}(),q={"@charset":!0,"@import":!0,"@namespace":!0},K=[S,R,D,U,B,V,{onCreateRule:function(e,t,n){return e in q?new H(e,t,n):null}}],Q={process:!0},X={force:!0,process:!0},G=function(){function e(e){this.map={},this.raw={},this.index=[],this.counter=0,this.options=void 0,this.classes=void 0,this.keyframes=void 0,this.options=e,this.classes=e.classes,this.keyframes=e.keyframes}var t=e.prototype;return t.add=function(e,t,n){var r=this.options,a=r.parent,i=r.sheet,l=r.jss,u=r.Renderer,c=r.generateId,s=r.scoped,d=Object(o.a)({classes:this.classes,parent:a,sheet:i,jss:l,Renderer:u,generateId:c,scoped:s,name:e},n),f=e;e in this.raw&&(f=e+"-d"+this.counter++),this.raw[f]=t,f in this.classes&&(d.selector="."+k(this.classes[f]));var p=m(f,t,d);if(!p)return null;this.register(p);var h=void 0===d.index?this.index.length:d.index;return this.index.splice(h,0,p),p},t.get=function(e){return this.map[e]},t.remove=function(e){this.unregister(e),delete this.raw[e.key],this.index.splice(this.index.indexOf(e),1)},t.indexOf=function(e){return this.index.indexOf(e)},t.process=function(){var e=this.options.jss.plugins;this.index.slice(0).forEach(e.onProcessRule,e)},t.register=function(e){this.map[e.key]=e,e instanceof O?(this.map[e.selector]=e,e.id&&(this.classes[e.key]=e.id)):e instanceof _&&this.keyframes&&(this.keyframes[e.name]=e.id)},t.unregister=function(e){delete this.map[e.key],e instanceof O?(delete this.map[e.selector],delete this.classes[e.key]):e instanceof _&&delete this.keyframes[e.name]},t.update=function(){var e,t,n;if("string"===typeof(arguments.length<=0?void 0:arguments[0])?(e=arguments.length<=0?void 0:arguments[0],t=arguments.length<=1?void 0:arguments[1],n=arguments.length<=2?void 0:arguments[2]):(t=arguments.length<=0?void 0:arguments[0],n=arguments.length<=1?void 0:arguments[1],e=null),e)this.updateOne(this.map[e],t,n);else for(var r=0;r<this.index.length;r++)this.updateOne(this.index[r],t,n)},t.updateOne=function(t,n,r){void 0===r&&(r=Q);var o=this.options,a=o.jss.plugins,i=o.sheet;if(t.rules instanceof e)t.rules.update(n,r);else{var l=t,u=l.style;if(a.onUpdate(n,t,i,r),r.process&&u&&u!==l.style){for(var c in a.onProcessStyle(l.style,l,i),l.style){var s=l.style[c];s!==u[c]&&l.prop(c,s,X)}for(var d in u){var f=l.style[d],p=u[d];null==f&&f!==p&&l.prop(d,null,X)}}}},t.toString=function(e){for(var t="",n=this.options.sheet,r=!!n&&n.options.link,o=0;o<this.index.length;o++){var a=this.index[o].toString(e);(a||r)&&(t&&(t+="\n"),t+=a)}return t},e}(),Y=function(){function e(e,t){for(var n in this.options=void 0,this.deployed=void 0,this.attached=void 0,this.rules=void 0,this.renderer=void 0,this.classes=void 0,this.keyframes=void 0,this.queue=void 0,this.attached=!1,this.deployed=!1,this.classes={},this.keyframes={},this.options=Object(o.a)({},t,{sheet:this,parent:this,classes:this.classes,keyframes:this.keyframes}),t.Renderer&&(this.renderer=new t.Renderer(this)),this.rules=new G(this.options),e)this.rules.add(n,e[n]);this.rules.process()}var t=e.prototype;return t.attach=function(){return this.attached?this:(this.renderer&&this.renderer.attach(),this.attached=!0,this.deployed||this.deploy(),this)},t.detach=function(){return this.attached?(this.renderer&&this.renderer.detach(),this.attached=!1,this):this},t.addRule=function(e,t,n){var r=this.queue;this.attached&&!r&&(this.queue=[]);var o=this.rules.add(e,t,n);return o?(this.options.jss.plugins.onProcessRule(o),this.attached?this.deployed?(r?r.push(o):(this.insertRule(o),this.queue&&(this.queue.forEach(this.insertRule,this),this.queue=void 0)),o):o:(this.deployed=!1,o)):null},t.insertRule=function(e){this.renderer&&this.renderer.insertRule(e)},t.addRules=function(e,t){var n=[];for(var r in e){var o=this.addRule(r,e[r],t);o&&n.push(o)}return n},t.getRule=function(e){return this.rules.get(e)},t.deleteRule=function(e){var t="object"===typeof e?e:this.rules.get(e);return!!t&&(this.rules.remove(t),!(this.attached&&t.renderable&&this.renderer)||this.renderer.deleteRule(t.renderable))},t.indexOf=function(e){return this.rules.indexOf(e)},t.deploy=function(){return this.renderer&&this.renderer.deploy(),this.deployed=!0,this},t.update=function(){var e;return(e=this.rules).update.apply(e,arguments),this},t.updateOne=function(e,t,n){return this.rules.updateOne(e,t,n),this},t.toString=function(e){return this.rules.toString(e)},e}(),J=function(){function e(){this.plugins={internal:[],external:[]},this.registry=void 0}var t=e.prototype;return t.onCreateRule=function(e,t,n){for(var r=0;r<this.registry.onCreateRule.length;r++){var o=this.registry.onCreateRule[r](e,t,n);if(o)return o}return null},t.onProcessRule=function(e){if(!e.isProcessed){for(var t=e.options.sheet,n=0;n<this.registry.onProcessRule.length;n++)this.registry.onProcessRule[n](e,t);e.style&&this.onProcessStyle(e.style,e,t),e.isProcessed=!0}},t.onProcessStyle=function(e,t,n){for(var r=0;r<this.registry.onProcessStyle.length;r++)t.style=this.registry.onProcessStyle[r](t.style,t,n)},t.onProcessSheet=function(e){for(var t=0;t<this.registry.onProcessSheet.length;t++)this.registry.onProcessSheet[t](e)},t.onUpdate=function(e,t,n,r){for(var o=0;o<this.registry.onUpdate.length;o++)this.registry.onUpdate[o](e,t,n,r)},t.onChangeValue=function(e,t,n){for(var r=e,o=0;o<this.registry.onChangeValue.length;o++)r=this.registry.onChangeValue[o](r,t,n);return r},t.use=function(e,t){void 0===t&&(t={queue:"external"});var n=this.plugins[t.queue];-1===n.indexOf(e)&&(n.push(e),this.registry=[].concat(this.plugins.external,this.plugins.internal).reduce((function(e,t){for(var n in t)n in e&&e[n].push(t[n]);return e}),{onCreateRule:[],onProcessRule:[],onProcessStyle:[],onProcessSheet:[],onChangeValue:[],onUpdate:[]}))},e}(),Z=new(function(){function e(){this.registry=[]}var t=e.prototype;return t.add=function(e){var t=this.registry,n=e.options.index;if(-1===t.indexOf(e))if(0===t.length||n>=this.index)t.push(e);else for(var r=0;r<t.length;r++)if(t[r].options.index>n)return void t.splice(r,0,e)},t.reset=function(){this.registry=[]},t.remove=function(e){var t=this.registry.indexOf(e);this.registry.splice(t,1)},t.toString=function(e){for(var t=void 0===e?{}:e,n=t.attached,r=Object(f.a)(t,["attached"]),o="",a=0;a<this.registry.length;a++){var i=this.registry[a];null!=n&&i.attached!==n||(o&&(o+="\n"),o+=i.toString(r))}return o},Object(c.a)(e,[{key:"index",get:function(){return 0===this.registry.length?0:this.registry[this.registry.length-1].options.index}}]),e}()),ee="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")(),te="2f1acc6c3a606b082e5eef5e54414ffb";null==ee[te]&&(ee[te]=0);var ne=ee[te]++,re=function(e){void 0===e&&(e={});var t=0;return function(n,r){t+=1;var o="",a="";return r&&(r.options.classNamePrefix&&(a=r.options.classNamePrefix),null!=r.options.jss.id&&(o=String(r.options.jss.id))),e.minify?""+(a||"c")+ne+o+t:a+n.key+"-"+ne+(o?"-"+o:"")+"-"+t}},oe=function(e){var t;return function(){return t||(t=e()),t}};function ae(e,t){try{return e.attributeStyleMap?e.attributeStyleMap.get(t):e.style.getPropertyValue(t)}catch(n){return""}}function ie(e,t,n){try{var r=n;if(Array.isArray(n)&&(r=b(n,!0),"!important"===n[n.length-1]))return e.style.setProperty(t,r,"important"),!0;e.attributeStyleMap?e.attributeStyleMap.set(t,r):e.style.setProperty(t,r)}catch(o){return!1}return!0}function le(e,t){try{e.attributeStyleMap?e.attributeStyleMap.delete(t):e.style.removeProperty(t)}catch(n){}}function ue(e,t){return e.selectorText=t,e.selectorText===t}var ce=oe((function(){return document.querySelector("head")}));function se(e){var t=Z.registry;if(t.length>0){var n=function(e,t){for(var n=0;n<e.length;n++){var r=e[n];if(r.attached&&r.options.index>t.index&&r.options.insertionPoint===t.insertionPoint)return r}return null}(t,e);if(n&&n.renderer)return{parent:n.renderer.element.parentNode,node:n.renderer.element};if((n=function(e,t){for(var n=e.length-1;n>=0;n--){var r=e[n];if(r.attached&&r.options.insertionPoint===t.insertionPoint)return r}return null}(t,e))&&n.renderer)return{parent:n.renderer.element.parentNode,node:n.renderer.element.nextSibling}}var r=e.insertionPoint;if(r&&"string"===typeof r){var o=function(e){for(var t=ce(),n=0;n<t.childNodes.length;n++){var r=t.childNodes[n];if(8===r.nodeType&&r.nodeValue.trim()===e)return r}return null}(r);if(o)return{parent:o.parentNode,node:o.nextSibling}}return!1}var de=oe((function(){var e=document.querySelector('meta[property="csp-nonce"]');return e?e.getAttribute("content"):null})),fe=function(e,t,n){var r=e.cssRules.length;(void 0===n||n>r)&&(n=r);try{if("insertRule"in e)e.insertRule(t,n);else if("appendRule"in e){e.appendRule(t)}}catch(o){return!1}return e.cssRules[n]},pe=function(){function e(e){this.getPropertyValue=ae,this.setProperty=ie,this.removeProperty=le,this.setSelector=ue,this.element=void 0,this.sheet=void 0,this.hasInsertedRules=!1,e&&Z.add(e),this.sheet=e;var t=this.sheet?this.sheet.options:{},n=t.media,r=t.meta,o=t.element;this.element=o||function(){var e=document.createElement("style");return e.textContent="\n",e}(),this.element.setAttribute("data-jss",""),n&&this.element.setAttribute("media",n),r&&this.element.setAttribute("data-meta",r);var a=de();a&&this.element.setAttribute("nonce",a)}var t=e.prototype;return t.attach=function(){if(!this.element.parentNode&&this.sheet){!function(e,t){var n=t.insertionPoint,r=se(t);if(!1!==r&&r.parent)r.parent.insertBefore(e,r.node);else if(n&&"number"===typeof n.nodeType){var o=n,a=o.parentNode;a&&a.insertBefore(e,o.nextSibling)}else ce().appendChild(e)}(this.element,this.sheet.options);var e=Boolean(this.sheet&&this.sheet.deployed);this.hasInsertedRules&&e&&(this.hasInsertedRules=!1,this.deploy())}},t.detach=function(){var e=this.element.parentNode;e&&e.removeChild(this.element)},t.deploy=function(){var e=this.sheet;e&&(e.options.link?this.insertRules(e.rules):this.element.textContent="\n"+e.toString()+"\n")},t.insertRules=function(e,t){for(var n=0;n<e.index.length;n++)this.insertRule(e.index[n],n,t)},t.insertRule=function(e,t,n){if(void 0===n&&(n=this.element.sheet),e.rules){var r=e,o=n;return("conditional"!==e.type&&"keyframes"!==e.type||!1!==(o=fe(n,r.toString({children:!1}),t)))&&(this.insertRules(r.rules,o),o)}if(e.renderable&&e.renderable.parentStyleSheet===this.element.sheet)return e.renderable;var a=e.toString();if(!a)return!1;var i=fe(n,a,t);return!1!==i&&(this.hasInsertedRules=!0,e.renderable=i,i)},t.deleteRule=function(e){var t=this.element.sheet,n=this.indexOf(e);return-1!==n&&(t.deleteRule(n),!0)},t.indexOf=function(e){for(var t=this.element.sheet.cssRules,n=0;n<t.length;n++)if(e===t[n])return n;return-1},t.replaceRule=function(e,t){var n=this.indexOf(e);return-1!==n&&(this.element.sheet.deleteRule(n),this.insertRule(t,n))},t.getRules=function(){return this.element.sheet.cssRules},e}(),he=0,me=function(){function e(e){this.id=he++,this.version="10.0.3",this.plugins=new J,this.options={id:{minify:!1},createGenerateId:re,Renderer:u?pe:null,plugins:[]},this.generateId=re({minify:!1});for(var t=0;t<K.length;t++)this.plugins.use(K[t],{queue:"internal"});this.setup(e)}var t=e.prototype;return t.setup=function(e){return void 0===e&&(e={}),e.createGenerateId&&(this.options.createGenerateId=e.createGenerateId),e.id&&(this.options.id=Object(o.a)({},this.options.id,e.id)),(e.createGenerateId||e.id)&&(this.generateId=this.options.createGenerateId(this.options.id)),null!=e.insertionPoint&&(this.options.insertionPoint=e.insertionPoint),"Renderer"in e&&(this.options.Renderer=e.Renderer),e.plugins&&this.use.apply(this,e.plugins),this},t.createStyleSheet=function(e,t){void 0===t&&(t={});var n=t.index;"number"!==typeof n&&(n=0===Z.index?0:Z.index+1);var r=new Y(e,Object(o.a)({},t,{jss:this,generateId:t.generateId||this.generateId,insertionPoint:this.options.insertionPoint,Renderer:this.options.Renderer,index:n}));return this.plugins.onProcessSheet(r),r},t.removeStyleSheet=function(e){return e.detach(),Z.remove(e),this},t.createRule=function(e,t,n){if(void 0===t&&(t={}),void 0===n&&(n={}),"object"===typeof e)return this.createRule(void 0,e,t);var r=Object(o.a)({},n,{name:e,jss:this,Renderer:this.options.Renderer});r.generateId||(r.generateId=this.generateId),r.classes||(r.classes={}),r.keyframes||(r.keyframes={});var a=m(e,t,r);return a&&this.plugins.onProcessRule(a),a},t.use=function(){for(var e=this,t=arguments.length,n=new Array(t),r=0;r<t;r++)n[r]=arguments[r];return n.forEach((function(t){e.plugins.use(t)})),this},e}();var ve="undefined"!==typeof CSS&&CSS&&"number"in CSS,be=function(e){return new me(e)},ye=(be(),n(161)),ge={set:function(e,t,n,r){var o=e.get(t);o||(o=new Map,e.set(t,o)),o.set(n,r)},get:function(e,t,n){var r=e.get(t);return r?r.get(n):void 0},delete:function(e,t,n){e.get(t).delete(n)}},xe=n(93),we=(n(5),n(58)),ke=["checked","disabled","error","focused","focusVisible","required","expanded","selected"];var Ee=Date.now(),Oe="fnValues"+Ee,Se="fnStyle"+ ++Ee;var Ce=function(){return{onCreateRule:function(e,t,n){if("function"!==typeof t)return null;var r=m(e,{},n);return r[Se]=t,r},onProcessStyle:function(e,t){if(Oe in t||Se in t)return e;var n={};for(var r in e){var o=e[r];"function"===typeof o&&(delete e[r],n[r]=o)}return t[Oe]=n,e},onUpdate:function(e,t,n,r){var o=t,a=o[Se];a&&(o.style=a(e)||{});var i=o[Oe];if(i)for(var l in i)o.prop(l,i[l](e),r)}}},Te="@global",je=function(){function e(e,t,n){for(var r in this.type="global",this.at=Te,this.rules=void 0,this.options=void 0,this.key=void 0,this.isProcessed=!1,this.key=e,this.options=n,this.rules=new G(Object(o.a)({},n,{parent:this})),t)this.rules.add(r,t[r]);this.rules.process()}var t=e.prototype;return t.getRule=function(e){return this.rules.get(e)},t.addRule=function(e,t,n){var r=this.rules.add(e,t,n);return this.options.jss.plugins.onProcessRule(r),r},t.indexOf=function(e){return this.rules.indexOf(e)},t.toString=function(){return this.rules.toString()},e}(),Pe=function(){function e(e,t,n){this.type="global",this.at=Te,this.options=void 0,this.rule=void 0,this.isProcessed=!1,this.key=void 0,this.key=e,this.options=n;var r=e.substr("@global ".length);this.rule=n.jss.createRule(r,t,Object(o.a)({},n,{parent:this}))}return e.prototype.toString=function(e){return this.rule?this.rule.toString(e):""},e}(),Re=/\s*,\s*/g;function Ne(e,t){for(var n=e.split(Re),r="",o=0;o<n.length;o++)r+=t+" "+n[o].trim(),n[o+1]&&(r+=", ");return r}var Me=function(){return{onCreateRule:function(e,t,n){if(!e)return null;if(e===Te)return new je(e,t,n);if("@"===e[0]&&"@global "===e.substr(0,"@global ".length))return new Pe(e,t,n);var r=n.parent;return r&&("global"===r.type||r.options.parent&&"global"===r.options.parent.type)&&(n.scoped=!1),!1===n.scoped&&(n.selector=e),null},onProcessRule:function(e){"style"===e.type&&(function(e){var t=e.options,n=e.style,r=n?n[Te]:null;if(r){for(var a in r)t.sheet.addRule(a,r[a],Object(o.a)({},t,{selector:Ne(a,e.selector)}));delete n[Te]}}(e),function(e){var t=e.options,n=e.style;for(var r in n)if("@"===r[0]&&r.substr(0,Te.length)===Te){var a=Ne(r.substr(Te.length),e.selector);t.sheet.addRule(a,n[r],Object(o.a)({},t,{selector:a})),delete n[r]}}(e))}}},_e=/\s*,\s*/g,Ae=/&/g,ze=/\$([\w-]+)/g;var Ie=function(){function e(e,t){return function(n,r){var o=e.getRule(r)||t&&t.getRule(r);return o?(o=o).selector:r}}function t(e,t){for(var n=t.split(_e),r=e.split(_e),o="",a=0;a<n.length;a++)for(var i=n[a],l=0;l<r.length;l++){var u=r[l];o&&(o+=", "),o+=-1!==u.indexOf("&")?u.replace(Ae,i):i+" "+u}return o}function n(e,t,n){if(n)return Object(o.a)({},n,{index:n.index+1});var r=e.options.nestingLevel;r=void 0===r?1:r+1;var a=Object(o.a)({},e.options,{nestingLevel:r,index:t.indexOf(e)+1});return delete a.name,a}return{onProcessStyle:function(r,a,i){if("style"!==a.type)return r;var l,u,c=a,s=c.options.parent;for(var d in r){var f=-1!==d.indexOf("&"),p="@"===d[0];if(f||p){if(l=n(c,s,l),f){var h=t(d,c.selector);u||(u=e(s,i)),h=h.replace(ze,u),s.addRule(h,r[d],Object(o.a)({},l,{selector:h}))}else p&&s.addRule(d,{},l).addRule(c.key,r[d],{selector:c.selector});delete r[d]}}return r}}},Le=/[A-Z]/g,De=/^ms-/,Fe={};function Ue(e){return"-"+e.toLowerCase()}var $e=function(e){if(Fe.hasOwnProperty(e))return Fe[e];var t=e.replace(Le,Ue);return Fe[e]=De.test(t)?"-"+t:t};function Be(e){var t={};for(var n in e){t[0===n.indexOf("--")?n:$e(n)]=e[n]}return e.fallbacks&&(Array.isArray(e.fallbacks)?t.fallbacks=e.fallbacks.map(Be):t.fallbacks=Be(e.fallbacks)),t}var We=function(){return{onProcessStyle:function(e){if(Array.isArray(e)){for(var t=0;t<e.length;t++)e[t]=Be(e[t]);return e}return Be(e)},onChangeValue:function(e,t,n){if(0===t.indexOf("--"))return e;var r=$e(t);return t===r?e:(n.prop(r,e),null)}}},Ve=ve&&CSS?CSS.px:"px",He=ve&&CSS?CSS.ms:"ms",qe=ve&&CSS?CSS.percent:"%";function Ke(e){var t=/(-[a-z])/g,n=function(e){return e[1].toUpperCase()},r={};for(var o in e)r[o]=e[o],r[o.replace(t,n)]=e[o];return r}var Qe=Ke({"animation-delay":He,"animation-duration":He,"background-position":Ve,"background-position-x":Ve,"background-position-y":Ve,"background-size":Ve,border:Ve,"border-bottom":Ve,"border-bottom-left-radius":Ve,"border-bottom-right-radius":Ve,"border-bottom-width":Ve,"border-left":Ve,"border-left-width":Ve,"border-radius":Ve,"border-right":Ve,"border-right-width":Ve,"border-top":Ve,"border-top-left-radius":Ve,"border-top-right-radius":Ve,"border-top-width":Ve,"border-width":Ve,margin:Ve,"margin-bottom":Ve,"margin-left":Ve,"margin-right":Ve,"margin-top":Ve,padding:Ve,"padding-bottom":Ve,"padding-left":Ve,"padding-right":Ve,"padding-top":Ve,"mask-position-x":Ve,"mask-position-y":Ve,"mask-size":Ve,height:Ve,width:Ve,"min-height":Ve,"max-height":Ve,"min-width":Ve,"max-width":Ve,bottom:Ve,left:Ve,top:Ve,right:Ve,"box-shadow":Ve,"text-shadow":Ve,"column-gap":Ve,"column-rule":Ve,"column-rule-width":Ve,"column-width":Ve,"font-size":Ve,"font-size-delta":Ve,"letter-spacing":Ve,"text-indent":Ve,"text-stroke":Ve,"text-stroke-width":Ve,"word-spacing":Ve,motion:Ve,"motion-offset":Ve,outline:Ve,"outline-offset":Ve,"outline-width":Ve,perspective:Ve,"perspective-origin-x":qe,"perspective-origin-y":qe,"transform-origin":qe,"transform-origin-x":qe,"transform-origin-y":qe,"transform-origin-z":qe,"transition-delay":He,"transition-duration":He,"vertical-align":Ve,"flex-basis":Ve,"shape-margin":Ve,size:Ve,grid:Ve,"grid-gap":Ve,"grid-row-gap":Ve,"grid-column-gap":Ve,"grid-template-rows":Ve,"grid-template-columns":Ve,"grid-auto-rows":Ve,"grid-auto-columns":Ve,"box-shadow-x":Ve,"box-shadow-y":Ve,"box-shadow-blur":Ve,"box-shadow-spread":Ve,"font-line-height":Ve,"text-shadow-x":Ve,"text-shadow-y":Ve,"text-shadow-blur":Ve});function Xe(e,t,n){if(!t)return t;if(Array.isArray(t))for(var r=0;r<t.length;r++)t[r]=Xe(e,t[r],n);else if("object"===typeof t)if("fallbacks"===e)for(var o in t)t[o]=Xe(o,t[o],n);else for(var a in t)t[a]=Xe(e+"-"+a,t[a],n);else if("number"===typeof t)return n[e]?""+t+n[e]:Qe[e]?"function"===typeof Qe[e]?Qe[e](t).toString():""+t+Qe[e]:t.toString();return t}var Ge=function(e){void 0===e&&(e={});var t=Ke(e);return{onProcessStyle:function(e,n){if("style"!==n.type)return e;for(var r in e)e[r]=Xe(r,e[r],t);return e},onChangeValue:function(e,n){return Xe(n,e,t)}}},Ye=n(11),Je="",Ze="",et="",tt=u&&"ontouchstart"in document.documentElement;if(u){var nt={Moz:"-moz-",ms:"-ms-",O:"-o-",Webkit:"-webkit-"},rt=document.createElement("p").style;for(var ot in nt)if(ot+"Transform"in rt){Je=ot,Ze=nt[ot];break}"Webkit"===Je&&"msHyphens"in rt&&(Je="ms",Ze=nt.ms,"edge"),"Webkit"===Je&&"-apple-trailing-word"in rt&&(et="apple")}var at=Je,it=Ze,lt=et,ut=tt;var ct={noPrefill:["appearance"],supportedProperty:function(e){return"appearance"===e&&("ms"===at?"-webkit-"+e:it+e)}},st={noPrefill:["color-adjust"],supportedProperty:function(e){return"color-adjust"===e&&("Webkit"===at?it+"print-"+e:e)}},dt=/[-\s]+(.)?/g;function ft(e,t){return t?t.toUpperCase():""}function pt(e){return e.replace(dt,ft)}function ht(e){return pt("-"+e)}var mt,vt={noPrefill:["mask"],supportedProperty:function(e,t){if(!/^mask/.test(e))return!1;if("Webkit"===at){if(pt("mask-image")in t)return e;if(at+ht("mask-image")in t)return it+e}return e}},bt={noPrefill:["text-orientation"],supportedProperty:function(e){return"text-orientation"===e&&("apple"!==lt||ut?e:it+e)}},yt={noPrefill:["transform"],supportedProperty:function(e,t,n){return"transform"===e&&(n.transform?e:it+e)}},gt={noPrefill:["transition"],supportedProperty:function(e,t,n){return"transition"===e&&(n.transition?e:it+e)}},xt={noPrefill:["writing-mode"],supportedProperty:function(e){return"writing-mode"===e&&("Webkit"===at||"ms"===at?it+e:e)}},wt={noPrefill:["user-select"],supportedProperty:function(e){return"user-select"===e&&("Moz"===at||"ms"===at||"apple"===lt?it+e:e)}},kt={supportedProperty:function(e,t){return!!/^break-/.test(e)&&("Webkit"===at?"WebkitColumn"+ht(e)in t&&it+"column-"+e:"Moz"===at&&("page"+ht(e)in t&&"page-"+e))}},Et={supportedProperty:function(e,t){if(!/^(border|margin|padding)-inline/.test(e))return!1;if("Moz"===at)return e;var n=e.replace("-inline","");return at+ht(n)in t&&it+n}},Ot={supportedProperty:function(e,t){return pt(e)in t&&e}},St={supportedProperty:function(e,t){var n=ht(e);return"-"===e[0]?e:"-"===e[0]&&"-"===e[1]?e:at+n in t?it+e:"Webkit"!==at&&"Webkit"+n in t&&"-webkit-"+e}},Ct={supportedProperty:function(e){return"scroll-snap"===e.substring(0,11)&&("ms"===at?""+it+e:e)}},Tt={supportedProperty:function(e){return"overscroll-behavior"===e&&("ms"===at?it+"scroll-chaining":e)}},jt={"flex-grow":"flex-positive","flex-shrink":"flex-negative","flex-basis":"flex-preferred-size","justify-content":"flex-pack",order:"flex-order","align-items":"flex-align","align-content":"flex-line-pack"},Pt={supportedProperty:function(e,t){var n=jt[e];return!!n&&(at+ht(n)in t&&it+n)}},Rt={flex:"box-flex","flex-grow":"box-flex","flex-direction":["box-orient","box-direction"],order:"box-ordinal-group","align-items":"box-align","flex-flow":["box-orient","box-direction"],"justify-content":"box-pack"},Nt=Object.keys(Rt),Mt=function(e){return it+e},_t=[ct,st,vt,bt,yt,gt,xt,wt,kt,Et,Ot,St,Ct,Tt,Pt,{supportedProperty:function(e,t,n){var r=n.multiple;if(Nt.indexOf(e)>-1){var o=Rt[e];if(!Array.isArray(o))return at+ht(o)in t&&it+o;if(!r)return!1;for(var a=0;a<o.length;a++)if(!(at+ht(o[0])in t))return!1;return o.map(Mt)}return!1}}],At=_t.filter((function(e){return e.supportedProperty})).map((function(e){return e.supportedProperty})),zt=_t.filter((function(e){return e.noPrefill})).reduce((function(e,t){return e.push.apply(e,Object(Ye.a)(t.noPrefill)),e}),[]),It={};if(u){mt=document.createElement("p");var Lt=window.getComputedStyle(document.documentElement,"");for(var Dt in Lt)isNaN(Dt)||(It[Lt[Dt]]=Lt[Dt]);zt.forEach((function(e){return delete It[e]}))}function Ft(e,t){if(void 0===t&&(t={}),!mt)return e;if(null!=It[e])return It[e];"transition"!==e&&"transform"!==e||(t[e]=e in mt.style);for(var n=0;n<At.length&&(It[e]=At[n](e,mt.style,t),!It[e]);n++);try{mt.style[e]=""}catch(r){return!1}return It[e]}var Ut,$t={},Bt={transition:1,"transition-property":1,"-webkit-transition":1,"-webkit-transition-property":1},Wt=/(^\s*[\w-]+)|, (\s*[\w-]+)(?![^()]*\))/g;function Vt(e,t,n){if("var"===t)return"var";if("all"===t)return"all";if("all"===n)return", all";var r=t?Ft(t):", "+Ft(n);return r||(t||n)}function Ht(e,t){var n=t;if(!Ut||"content"===e)return t;if("string"!==typeof n||!isNaN(parseInt(n,10)))return n;var r=e+n;if(null!=$t[r])return $t[r];try{Ut.style[e]=n}catch(o){return $t[r]=!1,!1}if(Bt[e])n=n.replace(Wt,Vt);else if(""===Ut.style[e]&&("-ms-flex"===(n=it+n)&&(Ut.style[e]="-ms-flexbox"),Ut.style[e]=n,""===Ut.style[e]))return $t[r]=!1,!1;return Ut.style[e]="",$t[r]=n,$t[r]}u&&(Ut=document.createElement("p"));var qt=function(){function e(t){for(var n in t){var r=t[n];if("fallbacks"===n&&Array.isArray(r))t[n]=r.map(e);else{var o=!1,a=Ft(n);a&&a!==n&&(o=!0);var i=!1,l=Ht(a,b(r));l&&l!==r&&(i=!0),(o||i)&&(o&&delete t[n],t[a||n]=l||r)}}return t}return{onProcessRule:function(e){if("keyframes"===e.type){var t=e;t.at="-"===(n=t.at)[1]?n:"ms"===at?n:"@"+it+"keyframes"+n.substr(10)}var n},onProcessStyle:function(t,n){return"style"!==n.type?t:e(t)},onChangeValue:function(e,t){return Ht(t,b(e))||e}}};var Kt=function(){var e=function(e,t){return e.length===t.length?e>t?1:-1:e.length-t.length};return{onProcessStyle:function(t,n){if("style"!==n.type)return t;for(var r={},o=Object.keys(t).sort(e),a=0;a<o.length;a++)r[o[a]]=t[o[a]];return r}}};var Qt=function(){return{plugins:[Ce(),Me(),Ie(),We(),Ge(),"undefined"===typeof window?null:qt(),Kt()]}},Xt=be(Qt()),Gt={disableGeneration:!1,generateClassName:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.disableGlobal,n=void 0!==t&&t,r=e.productionPrefix,o=void 0===r?"jss":r,a=e.seed,i=void 0===a?"":a,l=""===i?"":"".concat(i,"-"),u=0;return function(e,t){u+=1;var r=t.options.name;if(r&&0===r.indexOf("Mui")&&!t.options.link&&!n){if(-1!==ke.indexOf(e.key))return"Mui-".concat(e.key);var a="".concat(l).concat(r,"-").concat(e.key);return t.options.theme[we.a]&&""===i?"".concat(a,"-").concat(u):a}return"".concat(l).concat(o).concat(u)}}(),jss:Xt,sheetsCache:null,sheetsManager:new Map,sheetsRegistry:null},Yt=i.a.createContext(Gt);var Jt=-1e9;function Zt(){return Jt+=1}n(53);var en=n(162);var tn=function(e){var t="function"===typeof e;return{create:function(n,r){var a;try{a=t?e(n):e}catch(u){throw u}if(!r||!n.overrides||!n.overrides[r])return a;var i=n.overrides[r],l=Object(o.a)({},a);return Object.keys(i).forEach((function(e){l[e]=Object(en.a)(l[e],i[e])})),l},options:{}}},nn={};function rn(e,t,n){var r=e.state;if(e.stylesOptions.disableGeneration)return t||{};r.cacheClasses||(r.cacheClasses={value:null,lastProp:null,lastJSS:{}});var o=!1;return r.classes!==r.cacheClasses.lastJSS&&(r.cacheClasses.lastJSS=r.classes,o=!0),t!==r.cacheClasses.lastProp&&(r.cacheClasses.lastProp=t,o=!0),o&&(r.cacheClasses.value=Object(ye.a)({baseClasses:r.cacheClasses.lastJSS,newClasses:t,Component:n})),r.cacheClasses.value}function on(e,t){var n=e.state,r=e.theme,a=e.stylesOptions,i=e.stylesCreator,l=e.name;if(!a.disableGeneration){var u=ge.get(a.sheetsManager,i,r);u||(u={refs:0,staticSheet:null,dynamicStyles:null},ge.set(a.sheetsManager,i,r,u));var c=Object(o.a)({},i.options,{},a,{theme:r,flip:"boolean"===typeof a.flip?a.flip:"rtl"===r.direction});c.generateId=c.serverGenerateClassName||c.generateClassName;var s=a.sheetsRegistry;if(0===u.refs){var d;a.sheetsCache&&(d=ge.get(a.sheetsCache,i,r));var f=i.create(r,l);d||((d=a.jss.createStyleSheet(f,Object(o.a)({link:!1},c))).attach(),a.sheetsCache&&ge.set(a.sheetsCache,i,r,d)),s&&s.add(d),u.staticSheet=d,u.dynamicStyles=function e(t){var n=null;for(var r in t){var o=t[r],a=typeof o;if("function"===a)n||(n={}),n[r]=o;else if("object"===a&&null!==o&&!Array.isArray(o)){var i=e(o);i&&(n||(n={}),n[r]=i)}}return n}(f)}if(u.dynamicStyles){var p=a.jss.createStyleSheet(u.dynamicStyles,Object(o.a)({link:!0},c));p.update(t),p.attach(),n.dynamicSheet=p,n.classes=Object(ye.a)({baseClasses:u.staticSheet.classes,newClasses:p.classes}),s&&s.add(p)}else n.classes=u.staticSheet.classes;u.refs+=1}}function an(e,t){var n=e.state;n.dynamicSheet&&n.dynamicSheet.update(t)}function ln(e){var t=e.state,n=e.theme,r=e.stylesOptions,o=e.stylesCreator;if(!r.disableGeneration){var a=ge.get(r.sheetsManager,o,n);a.refs-=1;var i=r.sheetsRegistry;0===a.refs&&(ge.delete(r.sheetsManager,o,n),r.jss.removeStyleSheet(a.staticSheet),i&&i.remove(a.staticSheet)),t.dynamicSheet&&(r.jss.removeStyleSheet(t.dynamicSheet),i&&i.remove(t.dynamicSheet))}}function un(e,t){var n,r=i.a.useRef([]),o=i.a.useMemo((function(){return{}}),t);r.current!==o&&(r.current=o,n=e()),i.a.useEffect((function(){return function(){n&&n()}}),[o])}t.a=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.name,a=t.classNamePrefix,l=t.Component,u=t.defaultTheme,c=void 0===u?nn:u,s=Object(r.a)(t,["name","classNamePrefix","Component","defaultTheme"]),d=tn(e),f=n||a||"makeStyles";return d.options={index:Zt(),name:n,meta:f,classNamePrefix:f},function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=Object(xe.a)()||c,r=Object(o.a)({},i.a.useContext(Yt),{},s),a=i.a.useRef(),u=i.a.useRef();return un((function(){var o={name:n,state:{},stylesCreator:d,stylesOptions:r,theme:t};return on(o,e),u.current=!1,a.current=o,function(){ln(o)}}),[t,d]),i.a.useEffect((function(){u.current&&an(a.current,e),u.current=!0})),rn(a.current,e.classes,l)}}},,,,,,,,,,,,,,,,,,,,,,,,,,,function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(22),c=n(4),s=n(131),d=n(6),f=i.a.forwardRef((function(e,t){e.checked;var n=e.classes,a=e.className,c=e.control,f=e.disabled,p=(e.inputRef,e.label),h=e.labelPlacement,m=void 0===h?"end":h,v=(e.name,e.onChange,e.value,Object(o.a)(e,["checked","classes","className","control","disabled","inputRef","label","labelPlacement","name","onChange","value"])),b=Object(u.a)(),y=f;"undefined"===typeof y&&"undefined"!==typeof c.props.disabled&&(y=c.props.disabled),"undefined"===typeof y&&b&&(y=b.disabled);var g={disabled:y};return["checked","name","onChange","value","inputRef"].forEach((function(t){"undefined"===typeof c.props[t]&&"undefined"!==typeof e[t]&&(g[t]=e[t])})),i.a.createElement("label",Object(r.a)({className:Object(l.a)(n.root,a,"end"!==m&&n["labelPlacement".concat(Object(d.a)(m))],y&&n.disabled),ref:t},v),i.a.cloneElement(c,g),i.a.createElement(s.a,{component:"span",className:Object(l.a)(n.label,y&&n.disabled)},p))}));t.a=Object(c.a)((function(e){return{root:{display:"inline-flex",alignItems:"center",cursor:"pointer",verticalAlign:"middle",WebkitTapHighlightColor:"transparent",marginLeft:-11,marginRight:16,"&$disabled":{cursor:"default"}},labelPlacementStart:{flexDirection:"row-reverse",marginLeft:16,marginRight:-11},labelPlacementTop:{flexDirection:"column-reverse",marginLeft:16},labelPlacementBottom:{flexDirection:"column",marginLeft:16},disabled:{},label:{"&$disabled":{color:e.palette.text.disabled}}}}),{name:"MuiFormControlLabel"})(f)},function(e,t,n){"use strict";var r=n(1);t.a=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.baseClasses,n=e.newClasses;if(e.Component,!n)return t;var o=Object(r.a)({},t);return Object.keys(n).forEach((function(e){n[e]&&(o[e]="".concat(t[e]," ").concat(n[e]))})),o}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(1),o=n(53);function a(e){return e&&"object"===Object(o.a)(e)&&!Array.isArray(e)}function i(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{clone:!0},o=n.clone?Object(r.a)({},e):e;return a(e)&&a(t)&&Object.keys(t).forEach((function(r){"__proto__"!==r&&(a(t[r])&&r in e?o[r]=i(e[r],t[r],n):o[r]=t[r])})),o}},function(e,t,n){"use strict";t.a=function(e){var t=e.theme,n=e.name,r=e.props;if(!t||!t.props||!t.props[n])return r;var o,a=t.props[n];for(o in a)void 0===r[o]&&(r[o]=a[o]);return r}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(10),s=n(6),d=n(46),f=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,u=e.color,c=void 0===u?"secondary":u,f=e.disabled,p=void 0!==f&&f,h=e.edge,m=void 0!==h&&h,v=e.size,b=void 0===v?"medium":v,y=Object(o.a)(e,["classes","className","color","disabled","edge","size"]),g=i.a.createElement("span",{className:n.thumb});return i.a.createElement("span",{className:Object(l.a)(n.root,a,{start:n.edgeStart,end:n.edgeEnd}[m],{small:n["size".concat(Object(s.a)(b))]}[b])},i.a.createElement(d.a,Object(r.a)({type:"checkbox",icon:g,checkedIcon:g,classes:{root:Object(l.a)(n.switchBase,n["color".concat(Object(s.a)(c))]),input:n.input,checked:n.checked,disabled:n.disabled},ref:t,disabled:p},y)),i.a.createElement("span",{className:n.track}))}));t.a=Object(u.a)((function(e){return{root:{display:"inline-flex",width:58,height:38,overflow:"hidden",padding:12,boxSizing:"border-box",position:"relative",flexShrink:0,zIndex:0,verticalAlign:"middle"},edgeStart:{marginLeft:-8},edgeEnd:{marginRight:-8},switchBase:{position:"absolute",top:0,left:0,zIndex:1,color:"light"===e.palette.type?e.palette.grey[50]:e.palette.grey[400],transition:e.transitions.create(["left","transform"],{duration:e.transitions.duration.shortest}),"&$checked":{transform:"translateX(20px)"},"&$disabled":{color:"light"===e.palette.type?e.palette.grey[400]:e.palette.grey[800]},"&$checked + $track":{opacity:.5},"&$disabled + $track":{opacity:"light"===e.palette.type?.12:.1}},colorPrimary:{"&$checked":{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:"light"===e.palette.type?e.palette.grey[400]:e.palette.grey[800]},"&$checked + $track":{backgroundColor:e.palette.primary.main},"&$disabled + $track":{backgroundColor:"light"===e.palette.type?e.palette.common.black:e.palette.common.white}},colorSecondary:{"&$checked":{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:"light"===e.palette.type?e.palette.grey[400]:e.palette.grey[800]},"&$checked + $track":{backgroundColor:e.palette.secondary.main},"&$disabled + $track":{backgroundColor:"light"===e.palette.type?e.palette.common.black:e.palette.common.white}},sizeSmall:{width:40,height:24,padding:7,"& $thumb":{width:16,height:16},"& $switchBase":{padding:4,"&$checked":{transform:"translateX(16px)"}}},checked:{},disabled:{},input:{left:"-100%",width:"300%"},thumb:{boxShadow:e.shadows[1],backgroundColor:"currentColor",width:20,height:20,borderRadius:"50%"},track:{height:"100%",width:"100%",borderRadius:7,zIndex:-1,transition:e.transitions.create(["opacity","background-color"],{duration:e.transitions.duration.shortest}),backgroundColor:"light"===e.palette.type?e.palette.common.black:e.palette.common.white,opacity:"light"===e.palette.type?.38:.3}}}),{name:"MuiSwitch"})(f)},function(e,t,n){"use strict";var r=n(1),o=n(133),a=n(45);t.a=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return Object(o.a)(e,Object(r.a)({defaultTheme:a.a},t))}},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,u=e.component,c=void 0===u?"div":u,s=e.square,d=void 0!==s&&s,f=e.elevation,p=void 0===f?1:f,h=e.variant,m=void 0===h?"elevation":h,v=Object(r.a)(e,["classes","className","component","square","elevation","variant"]);return i.a.createElement(c,Object(o.a)({className:Object(l.a)(n.root,a,"outlined"===m?n.outlined:n["elevation".concat(p)],!d&&n.rounded),ref:t},v))}));t.a=Object(u.a)((function(e){var t={};return e.shadows.forEach((function(e,n){t["elevation".concat(n)]={boxShadow:e}})),Object(o.a)({root:{backgroundColor:e.palette.background.paper,color:e.palette.text.primary,transition:e.transitions.create("box-shadow")},rounded:{borderRadius:e.shape.borderRadius},outlined:{border:"1px solid ".concat(e.palette.divider)}},t)}),{name:"MuiPaper"})(c)},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=[0,1,2,3,4,5,6,7,8,9,10],s=["auto",!0,1,2,3,4,5,6,7,8,9,10,11,12];function d(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,n=parseFloat(e);return"".concat(n/t).concat(String(e).replace(String(n),"")||"px")}var f=i.a.forwardRef((function(e,t){var n=e.alignContent,a=void 0===n?"stretch":n,u=e.alignItems,c=void 0===u?"stretch":u,s=e.classes,d=e.className,f=e.component,p=void 0===f?"div":f,h=e.container,m=void 0!==h&&h,v=e.direction,b=void 0===v?"row":v,y=e.item,g=void 0!==y&&y,x=e.justify,w=void 0===x?"flex-start":x,k=e.lg,E=void 0!==k&&k,O=e.md,S=void 0!==O&&O,C=e.sm,T=void 0!==C&&C,j=e.spacing,P=void 0===j?0:j,R=e.wrap,N=void 0===R?"wrap":R,M=e.xl,_=void 0!==M&&M,A=e.xs,z=void 0!==A&&A,I=e.zeroMinWidth,L=void 0!==I&&I,D=Object(r.a)(e,["alignContent","alignItems","classes","className","component","container","direction","item","justify","lg","md","sm","spacing","wrap","xl","xs","zeroMinWidth"]),F=Object(l.a)(s.root,d,m&&[s.container,0!==P&&s["spacing-xs-".concat(String(P))]],g&&s.item,L&&s.zeroMinWidth,"row"!==b&&s["direction-xs-".concat(String(b))],"wrap"!==N&&s["wrap-xs-".concat(String(N))],"stretch"!==c&&s["align-items-xs-".concat(String(c))],"stretch"!==a&&s["align-content-xs-".concat(String(a))],"flex-start"!==w&&s["justify-xs-".concat(String(w))],!1!==z&&s["grid-xs-".concat(String(z))],!1!==T&&s["grid-sm-".concat(String(T))],!1!==S&&s["grid-md-".concat(String(S))],!1!==E&&s["grid-lg-".concat(String(E))],!1!==_&&s["grid-xl-".concat(String(_))]);return i.a.createElement(p,Object(o.a)({className:F,ref:t},D))})),p=Object(u.a)((function(e){return Object(o.a)({root:{},container:{boxSizing:"border-box",display:"flex",flexWrap:"wrap",width:"100%"},item:{boxSizing:"border-box",margin:"0"},zeroMinWidth:{minWidth:0},"direction-xs-column":{flexDirection:"column"},"direction-xs-column-reverse":{flexDirection:"column-reverse"},"direction-xs-row-reverse":{flexDirection:"row-reverse"},"wrap-xs-nowrap":{flexWrap:"nowrap"},"wrap-xs-wrap-reverse":{flexWrap:"wrap-reverse"},"align-items-xs-center":{alignItems:"center"},"align-items-xs-flex-start":{alignItems:"flex-start"},"align-items-xs-flex-end":{alignItems:"flex-end"},"align-items-xs-baseline":{alignItems:"baseline"},"align-content-xs-center":{alignContent:"center"},"align-content-xs-flex-start":{alignContent:"flex-start"},"align-content-xs-flex-end":{alignContent:"flex-end"},"align-content-xs-space-between":{alignContent:"space-between"},"align-content-xs-space-around":{alignContent:"space-around"},"justify-xs-center":{justifyContent:"center"},"justify-xs-flex-end":{justifyContent:"flex-end"},"justify-xs-space-between":{justifyContent:"space-between"},"justify-xs-space-around":{justifyContent:"space-around"},"justify-xs-space-evenly":{justifyContent:"space-evenly"}},function(e,t){var n={};return c.forEach((function(r){var o=e.spacing(r);0!==o&&(n["spacing-".concat(t,"-").concat(r)]={margin:"-".concat(d(o,2)),width:"calc(100% + ".concat(d(o),")"),"& > $item":{padding:d(o,2)}})})),n}(e,"xs"),{},e.breakpoints.keys.reduce((function(t,n){return function(e,t,n){var r={};s.forEach((function(e){var t="grid-".concat(n,"-").concat(e);if(!0!==e)if("auto"!==e){var o="".concat(Math.round(e/12*1e8)/1e6,"%");r[t]={flexBasis:o,flexGrow:0,maxWidth:o}}else r[t]={flexBasis:"auto",flexGrow:0,maxWidth:"none"};else r[t]={flexBasis:0,flexGrow:1,maxWidth:"100%"}})),"xs"===n?Object(o.a)(e,r):e[t.breakpoints.up(n)]=r}(t,e,n),t}),{}))}),{name:"MuiGrid"})(f);t.a=p},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(95),c=n(4),s=i.a.forwardRef((function(e,t){var n=e.disableUnderline,a=e.classes,c=e.fullWidth,s=void 0!==c&&c,d=e.inputComponent,f=void 0===d?"input":d,p=e.multiline,h=void 0!==p&&p,m=e.type,v=void 0===m?"text":m,b=Object(o.a)(e,["disableUnderline","classes","fullWidth","inputComponent","multiline","type"]);return i.a.createElement(u.a,Object(r.a)({classes:Object(r.a)({},a,{root:Object(l.a)(a.root,!n&&a.underline),underline:null}),fullWidth:s,inputComponent:f,multiline:h,ref:t,type:v},b))}));s.muiName="Input",t.a=Object(c.a)((function(e){var t="light"===e.palette.type?"rgba(0, 0, 0, 0.42)":"rgba(255, 255, 255, 0.7)";return{root:{position:"relative"},formControl:{"label + &":{marginTop:16}},focused:{},disabled:{},colorSecondary:{"&$underline:after":{borderBottomColor:e.palette.secondary.main}},underline:{"&:after":{borderBottom:"2px solid ".concat(e.palette.primary.main),left:0,bottom:0,content:'""',position:"absolute",right:0,transform:"scaleX(0)",transition:e.transitions.create("transform",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut}),pointerEvents:"none"},"&$focused:after":{transform:"scaleX(1)"},"&$error:after":{borderBottomColor:e.palette.error.main,transform:"scaleX(1)"},"&:before":{borderBottom:"1px solid ".concat(t),left:0,bottom:0,content:'"\\00a0"',position:"absolute",right:0,transition:e.transitions.create("border-bottom-color",{duration:e.transitions.duration.shorter}),pointerEvents:"none"},"&:hover:not($disabled):before":{borderBottom:"2px solid ".concat(e.palette.text.primary),"@media (hover: none)":{borderBottom:"1px solid ".concat(t)}},"&$disabled:before":{borderBottomStyle:"dotted"}},error:{},marginDense:{},multiline:{},fullWidth:{},input:{},inputMarginDense:{},inputMultiline:{},inputTypeSearch:{}}}),{name:"MuiInput"})(s)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(95),c=n(4),s=i.a.forwardRef((function(e,t){var n=e.disableUnderline,a=e.classes,c=e.fullWidth,s=void 0!==c&&c,d=e.inputComponent,f=void 0===d?"input":d,p=e.multiline,h=void 0!==p&&p,m=e.type,v=void 0===m?"text":m,b=Object(o.a)(e,["disableUnderline","classes","fullWidth","inputComponent","multiline","type"]);return i.a.createElement(u.a,Object(r.a)({classes:Object(r.a)({},a,{root:Object(l.a)(a.root,!n&&a.underline),underline:null}),fullWidth:s,inputComponent:f,multiline:h,ref:t,type:v},b))}));s.muiName="Input",t.a=Object(c.a)((function(e){var t="light"===e.palette.type,n=t?"rgba(0, 0, 0, 0.42)":"rgba(255, 255, 255, 0.7)",r=t?"rgba(0, 0, 0, 0.09)":"rgba(255, 255, 255, 0.09)";return{root:{position:"relative",backgroundColor:r,borderTopLeftRadius:e.shape.borderRadius,borderTopRightRadius:e.shape.borderRadius,transition:e.transitions.create("background-color",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut}),"&:hover":{backgroundColor:t?"rgba(0, 0, 0, 0.13)":"rgba(255, 255, 255, 0.13)","@media (hover: none)":{backgroundColor:r}},"&$focused":{backgroundColor:t?"rgba(0, 0, 0, 0.09)":"rgba(255, 255, 255, 0.09)"},"&$disabled":{backgroundColor:t?"rgba(0, 0, 0, 0.12)":"rgba(255, 255, 255, 0.12)"}},colorSecondary:{"&$underline:after":{borderBottomColor:e.palette.secondary.main}},underline:{"&:after":{borderBottom:"2px solid ".concat(e.palette.primary.main),left:0,bottom:0,content:'""',position:"absolute",right:0,transform:"scaleX(0)",transition:e.transitions.create("transform",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut}),pointerEvents:"none"},"&$focused:after":{transform:"scaleX(1)"},"&$error:after":{borderBottomColor:e.palette.error.main,transform:"scaleX(1)"},"&:before":{borderBottom:"1px solid ".concat(n),left:0,bottom:0,content:'"\\00a0"',position:"absolute",right:0,transition:e.transitions.create("border-bottom-color",{duration:e.transitions.duration.shorter}),pointerEvents:"none"},"&:hover:before":{borderBottom:"1px solid ".concat(e.palette.text.primary)},"&$disabled:before":{borderBottomStyle:"dotted"}},focused:{},disabled:{},adornedStart:{paddingLeft:12},adornedEnd:{paddingRight:12},error:{},marginDense:{},multiline:{padding:"27px 12px 10px","&$marginDense":{paddingTop:23,paddingBottom:6}},input:{padding:"27px 12px 10px","&:-webkit-autofill":{WebkitBoxShadow:"dark"===e.palette.type?"0 0 0 100px #266798 inset":null,WebkitTextFillColor:"dark"===e.palette.type?"#fff":null,borderTopLeftRadius:"inherit",borderTopRightRadius:"inherit"}},inputMarginDense:{paddingTop:23,paddingBottom:6},inputHiddenLabel:{paddingTop:18,paddingBottom:19,"&$inputMarginDense":{paddingTop:10,paddingBottom:11}},inputMultiline:{padding:0},inputAdornedStart:{paddingLeft:0},inputAdornedEnd:{paddingRight:0}}}),{name:"MuiFilledInput"})(s)},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(10),s=n(94),d=n(6),f=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,u=e.className,c=e.color,f=void 0===c?"default":c,p=e.component,h=void 0===p?"button":p,m=e.disabled,v=void 0!==m&&m,b=e.disableElevation,y=void 0!==b&&b,g=e.disableFocusRipple,x=void 0!==g&&g,w=e.endIcon,k=e.focusVisibleClassName,E=e.fullWidth,O=void 0!==E&&E,S=e.size,C=void 0===S?"medium":S,T=e.startIcon,j=e.type,P=void 0===j?"button":j,R=e.variant,N=void 0===R?"text":R,M=Object(r.a)(e,["children","classes","className","color","component","disabled","disableElevation","disableFocusRipple","endIcon","focusVisibleClassName","fullWidth","size","startIcon","type","variant"]),_=T&&i.a.createElement("span",{className:Object(l.a)(a.startIcon,a["iconSize".concat(Object(d.a)(C))])},T),A=w&&i.a.createElement("span",{className:Object(l.a)(a.endIcon,a["iconSize".concat(Object(d.a)(C))])},w);return i.a.createElement(s.a,Object(o.a)({className:Object(l.a)(a.root,a[N],u,"inherit"===f?a.colorInherit:"default"!==f&&a["".concat(N).concat(Object(d.a)(f))],"medium"!==C&&[a["".concat(N,"Size").concat(Object(d.a)(C))],a["size".concat(Object(d.a)(C))]],y&&a.disableElevation,v&&a.disabled,O&&a.fullWidth),component:h,disabled:v,focusRipple:!x,focusVisibleClassName:Object(l.a)(a.focusVisible,k),ref:t,type:P},M),i.a.createElement("span",{className:a.label},_,n,A))}));t.a=Object(u.a)((function(e){return{root:Object(o.a)({},e.typography.button,{boxSizing:"border-box",minWidth:64,padding:"6px 16px",borderRadius:e.shape.borderRadius,color:e.palette.text.primary,transition:e.transitions.create(["background-color","box-shadow","border"],{duration:e.transitions.duration.short}),"&:hover":{textDecoration:"none",backgroundColor:Object(c.b)(e.palette.text.primary,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"},"&$disabled":{backgroundColor:"transparent"}},"&$disabled":{color:e.palette.action.disabled}}),label:{width:"100%",display:"inherit",alignItems:"inherit",justifyContent:"inherit"},text:{padding:"6px 8px"},textPrimary:{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},textSecondary:{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},outlined:{padding:"5px 15px",border:"1px solid ".concat("light"===e.palette.type?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)"),"&$disabled":{border:"1px solid ".concat(e.palette.action.disabled)}},outlinedPrimary:{color:e.palette.primary.main,border:"1px solid ".concat(Object(c.b)(e.palette.primary.main,.5)),"&:hover":{border:"1px solid ".concat(e.palette.primary.main),backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},outlinedSecondary:{color:e.palette.secondary.main,border:"1px solid ".concat(Object(c.b)(e.palette.secondary.main,.5)),"&:hover":{border:"1px solid ".concat(e.palette.secondary.main),backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},"&$disabled":{border:"1px solid ".concat(e.palette.action.disabled)}},contained:{color:e.palette.getContrastText(e.palette.grey[300]),backgroundColor:e.palette.grey[300],boxShadow:e.shadows[2],"&:hover":{backgroundColor:e.palette.grey.A100,boxShadow:e.shadows[4],"@media (hover: none)":{boxShadow:e.shadows[2],backgroundColor:e.palette.grey[300]},"&$disabled":{backgroundColor:e.palette.action.disabledBackground}},"&$focusVisible":{boxShadow:e.shadows[6]},"&:active":{boxShadow:e.shadows[8]},"&$disabled":{color:e.palette.action.disabled,boxShadow:e.shadows[0],backgroundColor:e.palette.action.disabledBackground}},containedPrimary:{color:e.palette.primary.contrastText,backgroundColor:e.palette.primary.main,"&:hover":{backgroundColor:e.palette.primary.dark,"@media (hover: none)":{backgroundColor:e.palette.primary.main}}},containedSecondary:{color:e.palette.secondary.contrastText,backgroundColor:e.palette.secondary.main,"&:hover":{backgroundColor:e.palette.secondary.dark,"@media (hover: none)":{backgroundColor:e.palette.secondary.main}}},disableElevation:{boxShadow:"none","&:hover":{boxShadow:"none"},"&$focusVisible":{boxShadow:"none"},"&:active":{boxShadow:"none"},"&$disabled":{boxShadow:"none"}},focusVisible:{},disabled:{},colorInherit:{color:"inherit",borderColor:"currentColor"},textSizeSmall:{padding:"4px 5px",fontSize:e.typography.pxToRem(13)},textSizeLarge:{padding:"8px 11px",fontSize:e.typography.pxToRem(15)},outlinedSizeSmall:{padding:"3px 9px",fontSize:e.typography.pxToRem(13)},outlinedSizeLarge:{padding:"7px 21px",fontSize:e.typography.pxToRem(15)},containedSizeSmall:{padding:"4px 10px",fontSize:e.typography.pxToRem(13)},containedSizeLarge:{padding:"8px 22px",fontSize:e.typography.pxToRem(15)},sizeSmall:{},sizeLarge:{},fullWidth:{width:"100%"},startIcon:{display:"inherit",marginRight:8,marginLeft:-4,"&$iconSizeSmall":{marginLeft:-2}},endIcon:{display:"inherit",marginRight:-4,marginLeft:8,"&$iconSizeSmall":{marginRight:-2}},iconSizeSmall:{"& > *:first-child":{fontSize:18}},iconSizeMedium:{"& > *:first-child":{fontSize:20}},iconSizeLarge:{"& > *:first-child":{fontSize:22}}}}),{name:"MuiButton"})(f)},function(e,t,n){"use strict";var r=n(1),o=n(0),a=n.n(o),i=(n(5),n(57)),l=n(93),u=n(58);t.a=function(e){var t=e.children,n=e.theme,o=Object(l.a)(),c=a.a.useMemo((function(){var e=null===o?n:function(e,t){return"function"===typeof t?t(e):Object(r.a)({},e,{},t)}(o,n);return null!=e&&(e[u.a]=null!==o),e}),[n,o]);return a.a.createElement(i.a.Provider,{value:c},t)}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(161)),u=n(11),c=n(53),s=(n(44),n(3)),d=n(6),f=n(4),p=n(9),h=n.n(p),m=n(61);var v=function(e){return e&&e.ownerDocument||document};var b=function(e){return v(e).defaultView||window},y=n(42),g=n(93),x=n(163),w=n(35),k=n(8);var E="undefined"!==typeof window?i.a.useLayoutEffect:i.a.useEffect;var O=i.a.forwardRef((function(e,t){var n=e.children,r=e.container,o=e.disablePortal,a=void 0!==o&&o,l=e.onRendered,u=i.a.useState(null),c=u[0],s=u[1],d=Object(k.a)(i.a.isValidElement(n)?n.ref:null,t);return E((function(){a||s(function(e){return e="function"===typeof e?e():e,h.a.findDOMNode(e)}(r)||document.body)}),[r,a]),E((function(){if(c&&!a)return Object(w.a)(t,c),function(){Object(w.a)(t,null)}}),[t,c,a]),E((function(){l&&(c||a)&&l()}),[l,c,a]),a?i.a.isValidElement(n)?i.a.cloneElement(n,{ref:d}):n:c?h.a.createPortal(n,c):c})),S=n(30),C=n(59);var T=n(48);var j=function(){var e=document.createElement("div");e.style.width="99px",e.style.height="99px",e.style.position="absolute",e.style.top="-9999px",e.style.overflow="scroll",document.body.appendChild(e);var t=e.offsetWidth-e.clientWidth;return document.body.removeChild(e),t};function P(e,t){t?e.setAttribute("aria-hidden","true"):e.removeAttribute("aria-hidden")}function R(e){return parseInt(window.getComputedStyle(e)["padding-right"],10)||0}function N(e,t,n){var r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],o=arguments.length>4?arguments[4]:void 0,a=[t,n].concat(Object(u.a)(r)),i=["TEMPLATE","SCRIPT","STYLE"];[].forEach.call(e.children,(function(e){1===e.nodeType&&-1===a.indexOf(e)&&-1===i.indexOf(e.tagName)&&P(e,o)}))}function M(e,t){var n=-1;return e.some((function(e,r){return!!t(e)&&(n=r,!0)})),n}function _(e,t){var n,r=[],o=[],a=e.container;if(!t.disableScrollLock){if(function(e){var t=v(e);return t.body===e?b(t).innerWidth>t.documentElement.clientWidth:e.scrollHeight>e.clientHeight}(a)){var i=j();r.push({value:a.style.paddingRight,key:"padding-right",el:a}),a.style["padding-right"]="".concat(R(a)+i,"px"),n=v(a).querySelectorAll(".mui-fixed"),[].forEach.call(n,(function(e){o.push(e.style.paddingRight),e.style.paddingRight="".concat(R(e)+i,"px")}))}var l=a.parentElement,u="HTML"===l.nodeName&&"scroll"===window.getComputedStyle(l)["overflow-y"]?l:a;r.push({value:u.style.overflow,key:"overflow",el:u}),u.style.overflow="hidden"}return function(){n&&[].forEach.call(n,(function(e,t){o[t]?e.style.paddingRight=o[t]:e.style.removeProperty("padding-right")})),r.forEach((function(e){var t=e.value,n=e.el,r=e.key;t?n.style.setProperty(r,t):n.style.removeProperty(r)}))}}var A=function(){function e(){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.modals=[],this.containers=[]}return Object(T.a)(e,[{key:"add",value:function(e,t){var n=this.modals.indexOf(e);if(-1!==n)return n;n=this.modals.length,this.modals.push(e),e.modalRef&&P(e.modalRef,!1);var r=function(e){var t=[];return[].forEach.call(e.children,(function(e){e.getAttribute&&"true"===e.getAttribute("aria-hidden")&&t.push(e)})),t}(t);N(t,e.mountNode,e.modalRef,r,!0);var o=M(this.containers,(function(e){return e.container===t}));return-1!==o?(this.containers[o].modals.push(e),n):(this.containers.push({modals:[e],container:t,restore:null,hiddenSiblingNodes:r}),n)}},{key:"mount",value:function(e,t){var n=M(this.containers,(function(t){return-1!==t.modals.indexOf(e)})),r=this.containers[n];r.restore||(r.restore=_(r,t))}},{key:"remove",value:function(e){var t=this.modals.indexOf(e);if(-1===t)return t;var n=M(this.containers,(function(t){return-1!==t.modals.indexOf(e)})),r=this.containers[n];if(r.modals.splice(r.modals.indexOf(e),1),this.modals.splice(t,1),0===r.modals.length)r.restore&&r.restore(),e.modalRef&&P(e.modalRef,!0),N(r.container,e.mountNode,e.modalRef,r.hiddenSiblingNodes,!1),this.containers.splice(n,1);else{var o=r.modals[r.modals.length-1];o.modalRef&&P(o.modalRef,!1)}return t}},{key:"isTopModal",value:function(e){return this.modals.length>0&&this.modals[this.modals.length-1]===e}}]),e}();var z=function(e){var t=e.children,n=e.disableAutoFocus,r=void 0!==n&&n,o=e.disableEnforceFocus,a=void 0!==o&&o,l=e.disableRestoreFocus,u=void 0!==l&&l,c=e.getDoc,s=e.isEnabled,d=e.open,f=i.a.useRef(),p=i.a.useRef(null),m=i.a.useRef(null),b=i.a.useRef(),y=i.a.useRef(null),g=i.a.useCallback((function(e){y.current=h.a.findDOMNode(e)}),[]),x=Object(k.a)(t.ref,g);return i.a.useMemo((function(){d&&"undefined"!==typeof window&&(b.current=c().activeElement)}),[d]),i.a.useEffect((function(){if(d){var e=v(y.current);r||!y.current||y.current.contains(e.activeElement)||(y.current.hasAttribute("tabIndex")||y.current.setAttribute("tabIndex",-1),y.current.focus());var t=function(){a||!s()||f.current?f.current=!1:y.current&&!y.current.contains(e.activeElement)&&y.current.focus()},n=function(t){!a&&s()&&9===t.keyCode&&e.activeElement===y.current&&(f.current=!0,t.shiftKey?m.current.focus():p.current.focus())};e.addEventListener("focus",t,!0),e.addEventListener("keydown",n,!0);var o=setInterval((function(){t()}),50);return function(){clearInterval(o),e.removeEventListener("focus",t,!0),e.removeEventListener("keydown",n,!0),u||(b.current&&b.current.focus&&b.current.focus(),b.current=null)}}}),[r,a,u,s,d]),i.a.createElement(i.a.Fragment,null,i.a.createElement("div",{tabIndex:0,ref:p,"data-test":"sentinelStart"}),i.a.cloneElement(t,{ref:x}),i.a.createElement("div",{tabIndex:0,ref:m,"data-test":"sentinelEnd"}))},I={root:{zIndex:-1,position:"fixed",right:0,bottom:0,top:0,left:0,backgroundColor:"rgba(0, 0, 0, 0.5)",WebkitTapHighlightColor:"transparent",touchAction:"none"},invisible:{backgroundColor:"transparent"}},L=i.a.forwardRef((function(e,t){var n=e.invisible,a=void 0!==n&&n,l=e.open,u=Object(o.a)(e,["invisible","open"]);return l?i.a.createElement("div",Object(r.a)({"aria-hidden":!0,ref:t},u,{style:Object(r.a)({},I.root,{},a?I.invisible:{},{},u.style)})):null}));var D=new A,F=i.a.forwardRef((function(e,t){var n=Object(g.a)(),a=Object(x.a)({name:"MuiModal",props:Object(r.a)({},e),theme:n}),l=a.BackdropComponent,u=void 0===l?L:l,c=a.BackdropProps,s=a.children,d=a.closeAfterTransition,f=void 0!==d&&d,p=a.container,m=a.disableAutoFocus,b=void 0!==m&&m,w=a.disableBackdropClick,E=void 0!==w&&w,T=a.disableEnforceFocus,j=void 0!==T&&T,R=a.disableEscapeKeyDown,N=void 0!==R&&R,M=a.disablePortal,_=void 0!==M&&M,A=a.disableRestoreFocus,I=void 0!==A&&A,F=a.disableScrollLock,U=void 0!==F&&F,$=a.hideBackdrop,B=void 0!==$&&$,W=a.keepMounted,V=void 0!==W&&W,H=a.manager,q=void 0===H?D:H,K=a.onBackdropClick,Q=a.onClose,X=a.onEscapeKeyDown,G=a.onRendered,Y=a.open,J=Object(o.a)(a,["BackdropComponent","BackdropProps","children","closeAfterTransition","container","disableAutoFocus","disableBackdropClick","disableEnforceFocus","disableEscapeKeyDown","disablePortal","disableRestoreFocus","disableScrollLock","hideBackdrop","keepMounted","manager","onBackdropClick","onClose","onEscapeKeyDown","onRendered","open"]),Z=i.a.useState(!0),ee=Z[0],te=Z[1],ne=i.a.useRef({}),re=i.a.useRef(null),oe=i.a.useRef(null),ae=Object(k.a)(oe,t),ie=function(e){return!!e.children&&e.children.props.hasOwnProperty("in")}(a),le=function(){return v(re.current)},ue=function(){return ne.current.modalRef=oe.current,ne.current.mountNode=re.current,ne.current},ce=function(){q.mount(ue(),{disableScrollLock:U}),oe.current.scrollTop=0},se=Object(S.a)((function(){var e=function(e){return e="function"===typeof e?e():e,h.a.findDOMNode(e)}(p)||le().body;q.add(ue(),e),oe.current&&ce()})),de=i.a.useCallback((function(){return q.isTopModal(ue())}),[q]),fe=Object(S.a)((function(e){re.current=e,e&&(G&&G(),Y&&de()?ce():P(oe.current,!0))})),pe=i.a.useCallback((function(){q.remove(ue())}),[q]);if(i.a.useEffect((function(){return function(){pe()}}),[pe]),i.a.useEffect((function(){Y?se():ie&&f||pe()}),[Y,pe,ie,f,se]),!V&&!Y&&(!ie||ee))return null;var he=function(e){return{root:{position:"fixed",zIndex:e.zIndex.modal,right:0,bottom:0,top:0,left:0},hidden:{visibility:"hidden"}}}(n||{zIndex:C.a}),me={};return void 0===s.props.tabIndex&&(me.tabIndex=s.props.tabIndex||"-1"),ie&&(me.onEnter=Object(y.a)((function(){te(!1)}),s.props.onEnter),me.onExited=Object(y.a)((function(){te(!0),f&&pe()}),s.props.onExited)),i.a.createElement(O,{ref:fe,container:p,disablePortal:_},i.a.createElement("div",Object(r.a)({ref:ae,onKeyDown:function(e){"Escape"===e.key&&de()&&(e.stopPropagation(),X&&X(e),!N&&Q&&Q(e,"escapeKeyDown"))},role:"presentation"},J,{style:Object(r.a)({},he.root,{},!Y&&ee?he.hidden:{},{},J.style)}),B?null:i.a.createElement(u,Object(r.a)({open:Y,onClick:function(e){e.target===e.currentTarget&&(K&&K(e),!E&&Q&&Q(e,"backdropClick"))}},c)),i.a.createElement(z,{disableEnforceFocus:j,disableAutoFocus:b,disableRestoreFocus:I,getDoc:le,isEnabled:de,open:Y},i.a.cloneElement(s,me))))})),U=n(15),$=n(12),B=!1,W=n(43),V=function(e){function t(t,n){var r;r=e.call(this,t,n)||this;var o,a=n&&!n.isMounting?t.enter:t.appear;return r.appearStatus=null,t.in?a?(o="exited",r.appearStatus="entering"):o="entered":o=t.unmountOnExit||t.mountOnEnter?"unmounted":"exited",r.state={status:o},r.nextCallback=null,r}Object($.a)(t,e),t.getDerivedStateFromProps=function(e,t){return e.in&&"unmounted"===t.status?{status:"exited"}:null};var n=t.prototype;return n.componentDidMount=function(){this.updateStatus(!0,this.appearStatus)},n.componentDidUpdate=function(e){var t=null;if(e!==this.props){var n=this.state.status;this.props.in?"entering"!==n&&"entered"!==n&&(t="entering"):"entering"!==n&&"entered"!==n||(t="exiting")}this.updateStatus(!1,t)},n.componentWillUnmount=function(){this.cancelNextCallback()},n.getTimeouts=function(){var e,t,n,r=this.props.timeout;return e=t=n=r,null!=r&&"number"!==typeof r&&(e=r.exit,t=r.enter,n=void 0!==r.appear?r.appear:t),{exit:e,enter:t,appear:n}},n.updateStatus=function(e,t){if(void 0===e&&(e=!1),null!==t){this.cancelNextCallback();var n=h.a.findDOMNode(this);"entering"===t?this.performEnter(n,e):this.performExit(n)}else this.props.unmountOnExit&&"exited"===this.state.status&&this.setState({status:"unmounted"})},n.performEnter=function(e,t){var n=this,r=this.props.enter,o=this.context?this.context.isMounting:t,a=this.getTimeouts(),i=o?a.appear:a.enter;!t&&!r||B?this.safeSetState({status:"entered"},(function(){n.props.onEntered(e)})):(this.props.onEnter(e,o),this.safeSetState({status:"entering"},(function(){n.props.onEntering(e,o),n.onTransitionEnd(e,i,(function(){n.safeSetState({status:"entered"},(function(){n.props.onEntered(e,o)}))}))})))},n.performExit=function(e){var t=this,n=this.props.exit,r=this.getTimeouts();n&&!B?(this.props.onExit(e),this.safeSetState({status:"exiting"},(function(){t.props.onExiting(e),t.onTransitionEnd(e,r.exit,(function(){t.safeSetState({status:"exited"},(function(){t.props.onExited(e)}))}))}))):this.safeSetState({status:"exited"},(function(){t.props.onExited(e)}))},n.cancelNextCallback=function(){null!==this.nextCallback&&(this.nextCallback.cancel(),this.nextCallback=null)},n.safeSetState=function(e,t){t=this.setNextCallback(t),this.setState(e,t)},n.setNextCallback=function(e){var t=this,n=!0;return this.nextCallback=function(r){n&&(n=!1,t.nextCallback=null,e(r))},this.nextCallback.cancel=function(){n=!1},this.nextCallback},n.onTransitionEnd=function(e,t,n){this.setNextCallback(n);var r=null==t&&!this.props.addEndListener;e&&!r?(this.props.addEndListener&&this.props.addEndListener(e,this.nextCallback),null!=t&&setTimeout(this.nextCallback,t)):setTimeout(this.nextCallback,0)},n.render=function(){var e=this.state.status;if("unmounted"===e)return null;var t=this.props,n=t.children,r=Object(U.a)(t,["children"]);if(delete r.in,delete r.mountOnEnter,delete r.unmountOnExit,delete r.appear,delete r.enter,delete r.exit,delete r.timeout,delete r.addEndListener,delete r.onEnter,delete r.onEntering,delete r.onEntered,delete r.onExit,delete r.onExiting,delete r.onExited,"function"===typeof n)return i.a.createElement(W.a.Provider,{value:null},n(e,r));var o=i.a.Children.only(n);return(i.a.createElement(W.a.Provider,{value:null},i.a.cloneElement(o,r)))},t}(i.a.Component);function H(){}V.contextType=W.a,V.propTypes={},V.defaultProps={in:!1,mountOnEnter:!1,unmountOnExit:!1,appear:!1,enter:!0,exit:!0,onEnter:H,onEntering:H,onEntered:H,onExit:H,onExiting:H,onExited:H},V.UNMOUNTED=0,V.EXITED=1,V.ENTERING=2,V.ENTERED=3,V.EXITING=4;var q=V,K=n(47);function Q(e,t){var n=e.timeout,r=e.style,o=void 0===r?{}:r;return{duration:o.transitionDuration||"number"===typeof n?n:n[t.mode]||0,delay:o.transitionDelay}}function X(e){return"scale(".concat(e,", ").concat(Math.pow(e,2),")")}var G={entering:{opacity:1,transform:X(1)},entered:{opacity:1,transform:"none"}},Y=i.a.forwardRef((function(e,t){var n=e.children,a=e.in,l=e.onEnter,u=e.onExit,c=e.style,s=e.timeout,d=void 0===s?"auto":s,f=Object(o.a)(e,["children","in","onEnter","onExit","style","timeout"]),p=i.a.useRef(),h=i.a.useRef(),m=Object(k.a)(n.ref,t),v=Object(K.a)();return i.a.useEffect((function(){return function(){clearTimeout(p.current)}}),[]),i.a.createElement(q,Object(r.a)({appear:!0,in:a,onEnter:function(e,t){!function(e){e.scrollTop}(e);var n,r=Q({style:c,timeout:d},{mode:"enter"}),o=r.duration,a=r.delay;"auto"===d?(n=v.transitions.getAutoHeightDuration(e.clientHeight),h.current=n):n=o,e.style.transition=[v.transitions.create("opacity",{duration:n,delay:a}),v.transitions.create("transform",{duration:.666*n,delay:a})].join(","),l&&l(e,t)},onExit:function(e){var t,n=Q({style:c,timeout:d},{mode:"exit"}),r=n.duration,o=n.delay;"auto"===d?(t=v.transitions.getAutoHeightDuration(e.clientHeight),h.current=t):t=r,e.style.transition=[v.transitions.create("opacity",{duration:t,delay:o}),v.transitions.create("transform",{duration:.666*t,delay:o||.333*t})].join(","),e.style.opacity="0",e.style.transform=X(.75),u&&u(e)},addEndListener:function(e,t){"auto"===d&&(p.current=setTimeout(t,h.current||0))},timeout:"auto"===d?null:d},f),(function(e,t){return i.a.cloneElement(n,Object(r.a)({style:Object(r.a)({opacity:0,transform:X(.75),visibility:"exited"!==e||a?void 0:"hidden"},G[e],{},c,{},n.props.style),ref:m},t))}))}));Y.muiSupportAuto=!0;var J=Y,Z=n(166);function ee(e,t){var n=0;return"number"===typeof t?n=t:"center"===t?n=e.height/2:"bottom"===t&&(n=e.height),n}function te(e,t){var n=0;return"number"===typeof t?n=t:"center"===t?n=e.width/2:"right"===t&&(n=e.width),n}function ne(e){return[e.horizontal,e.vertical].map((function(e){return"number"===typeof e?"".concat(e,"px"):e})).join(" ")}function re(e){return"function"===typeof e?e():e}var oe=i.a.forwardRef((function(e,t){var n=e.action,a=e.anchorEl,l=e.anchorOrigin,u=void 0===l?{vertical:"top",horizontal:"left"}:l,c=e.anchorPosition,d=e.anchorReference,f=void 0===d?"anchorEl":d,p=e.children,g=e.classes,x=e.className,w=e.container,k=e.elevation,E=void 0===k?8:k,O=e.getContentAnchorEl,S=e.marginThreshold,C=void 0===S?16:S,T=e.onEnter,j=e.onEntered,P=e.onEntering,R=e.onExit,N=e.onExited,M=e.onExiting,_=e.open,A=e.PaperProps,z=void 0===A?{}:A,I=e.transformOrigin,L=void 0===I?{vertical:"top",horizontal:"left"}:I,D=e.TransitionComponent,U=void 0===D?J:D,$=e.transitionDuration,B=void 0===$?"auto":$,W=e.TransitionProps,V=void 0===W?{}:W,H=Object(o.a)(e,["action","anchorEl","anchorOrigin","anchorPosition","anchorReference","children","classes","className","container","elevation","getContentAnchorEl","marginThreshold","onEnter","onEntered","onEntering","onExit","onExited","onExiting","open","PaperProps","transformOrigin","TransitionComponent","transitionDuration","TransitionProps"]),q=i.a.useRef(),K=i.a.useCallback((function(e){if("anchorPosition"===f)return c;var t=re(a),n=(t instanceof b(t).Element?t:v(q.current).body).getBoundingClientRect(),r=0===e?u.vertical:"center";return{top:n.top+ee(n,r),left:n.left+te(n,u.horizontal)}}),[a,u.horizontal,u.vertical,c,f]),Q=i.a.useCallback((function(e){var t=0;if(O&&"anchorEl"===f){var n=O(e);if(n&&e.contains(n)){var r=function(e,t){for(var n=t,r=0;n&&n!==e;)r+=(n=n.parentElement).scrollTop;return r}(e,n);t=n.offsetTop+n.clientHeight/2-r||0}0}return t}),[u.vertical,f,O]),X=i.a.useCallback((function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return{vertical:ee(e,L.vertical)+t,horizontal:te(e,L.horizontal)}}),[L.horizontal,L.vertical]),G=i.a.useCallback((function(e){var t=Q(e),n={width:e.offsetWidth,height:e.offsetHeight},r=X(n,t);if("none"===f)return{top:null,left:null,transformOrigin:ne(r)};var o=K(t),i=o.top-r.vertical,l=o.left-r.horizontal,u=i+n.height,c=l+n.width,s=b(re(a)),d=s.innerHeight-C,p=s.innerWidth-C;if(i<C){var h=i-C;i-=h,r.vertical+=h}else if(u>d){var m=u-d;i-=m,r.vertical+=m}if(l<C){var v=l-C;l-=v,r.horizontal+=v}else if(c>p){var y=c-p;l-=y,r.horizontal+=y}return{top:"".concat(Math.round(i),"px"),left:"".concat(Math.round(l),"px"),transformOrigin:ne(r)}}),[a,f,K,Q,X,C]),Y=i.a.useCallback((function(){var e=q.current;if(e){var t=G(e);null!==t.top&&(e.style.top=t.top),null!==t.left&&(e.style.left=t.left),e.style.transformOrigin=t.transformOrigin}}),[G]),oe=i.a.useCallback((function(e){q.current=h.a.findDOMNode(e)}),[]);i.a.useEffect((function(){_&&Y()})),i.a.useImperativeHandle(n,(function(){return _?{updatePosition:function(){Y()}}:null}),[_,Y]),i.a.useEffect((function(){if(_){var e=Object(m.a)((function(){Y()}));return window.addEventListener("resize",e),function(){e.clear(),window.removeEventListener("rezise",e)}}}),[_,Y]);var ae=B;"auto"!==B||U.muiSupportAuto||(ae=void 0);var ie=w||(a?v(re(a)).body:void 0);return i.a.createElement(F,Object(r.a)({container:ie,open:_,ref:t,BackdropProps:{invisible:!0},className:Object(s.a)(g.root,x)},H),i.a.createElement(U,Object(r.a)({appear:!0,in:_,onEnter:T,onEntered:j,onExit:R,onExited:N,onExiting:M,timeout:ae},V,{onEntering:Object(y.a)((function(e,t){P&&P(e,t),Y()}),V.onEntering)}),i.a.createElement(Z.a,Object(r.a)({elevation:E,ref:oe},z,{className:Object(s.a)(g.paper,z.className)}),p)))})),ae=Object(f.a)({root:{},paper:{position:"absolute",overflowY:"auto",overflowX:"hidden",minWidth:16,minHeight:16,maxWidth:"calc(100% - 32px)",maxHeight:"calc(100% - 32px)",outline:0}},{name:"MuiPopover"})(oe),ie=n(51),le=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.className,u=e.component,c=void 0===u?"ul":u,d=e.dense,f=void 0!==d&&d,p=e.disablePadding,h=void 0!==p&&p,m=e.subheader,v=Object(o.a)(e,["children","classes","className","component","dense","disablePadding","subheader"]),b=i.a.useMemo((function(){return{dense:f}}),[f]);return i.a.createElement(ie.a.Provider,{value:b},i.a.createElement(c,Object(r.a)({className:Object(s.a)(a.root,l,f&&a.dense,!h&&a.padding,m&&a.subheader),ref:t},v),m,n))})),ue=Object(f.a)({root:{listStyle:"none",margin:0,padding:0,position:"relative"},padding:{paddingTop:8,paddingBottom:8},dense:{},subheader:{paddingTop:0}},{name:"MuiList"})(le);function ce(e,t,n){return e===t?e.firstChild:t&&t.nextElementSibling?t.nextElementSibling:n?null:e.firstChild}function se(e,t,n){return e===t?n?e.firstChild:e.lastChild:t&&t.previousElementSibling?t.previousElementSibling:n?null:e.lastChild}function de(e,t){if(void 0===t)return!0;var n=e.innerText;return void 0===n&&(n=e.textContent),0!==(n=n.trim().toLowerCase()).length&&(t.repeating?n[0]===t.keys[0]:0===n.indexOf(t.keys.join("")))}function fe(e,t,n,r,o){for(var a=!1,i=r(e,t,!!t&&n);i;){if(i===e.firstChild){if(a)return!1;a=!0}if(i.hasAttribute("tabindex")&&!i.disabled&&"true"!==i.getAttribute("aria-disabled")&&de(i,o))return i.focus(),!0;i=r(e,i,n)}return!1}var pe="undefined"===typeof window?i.a.useEffect:i.a.useLayoutEffect,he=i.a.forwardRef((function(e,t){var n=e.actions,a=e.autoFocus,l=void 0!==a&&a,u=e.autoFocusItem,c=void 0!==u&&u,s=e.children,d=e.className,f=e.onKeyDown,p=e.disableListWrap,m=void 0!==p&&p,b=e.variant,y=void 0===b?"selectedMenu":b,g=Object(o.a)(e,["actions","autoFocus","autoFocusItem","children","className","onKeyDown","disableListWrap","variant"]),x=i.a.useRef(null),w=i.a.useRef({keys:[],repeating:!0,previousKeyMatched:!0,lastTime:null});pe((function(){l&&x.current.focus()}),[l]),i.a.useImperativeHandle(n,(function(){return{adjustStyleForScrollbar:function(e,t){var n=!x.current.style.width;if(e.clientHeight<x.current.clientHeight&&n){var r="".concat(j(!0),"px");x.current.style["rtl"===t.direction?"paddingLeft":"paddingRight"]=r,x.current.style.width="calc(100% + ".concat(r,")")}return x.current}}}),[]);var E=i.a.useCallback((function(e){x.current=h.a.findDOMNode(e)}),[]),O=Object(k.a)(E,t),S=-1;i.a.Children.forEach(s,(function(e,t){i.a.isValidElement(e)&&(e.props.disabled||("selectedMenu"===y&&e.props.selected?S=t:-1===S&&(S=t)))}));var C=i.a.Children.map(s,(function(e,t){if(t===S){var n={};if(c&&(n.autoFocus=!0),void 0===e.props.tabIndex&&"selectedMenu"===y&&(n.tabIndex=0),null!==n)return i.a.cloneElement(e,n)}return e}));return i.a.createElement(ue,Object(r.a)({role:"menu",ref:O,className:d,onKeyDown:function(e){var t=x.current,n=e.key,r=v(t).activeElement;if("ArrowDown"===n)e.preventDefault(),fe(t,r,m,ce);else if("ArrowUp"===n)e.preventDefault(),fe(t,r,m,se);else if("Home"===n)e.preventDefault(),fe(t,null,m,ce);else if("End"===n)e.preventDefault(),fe(t,null,m,se);else if(1===n.length){var o=w.current,a=n.toLowerCase(),i=performance.now();o.keys.length>0&&(i-o.lastTime>500?(o.keys=[],o.repeating=!0,o.previousKeyMatched=!0):o.repeating&&a!==o.keys[0]&&(o.repeating=!1)),o.lastTime=i,o.keys.push(a);var l=r&&!o.repeating&&de(r,o);o.previousKeyMatched&&(l||fe(t,r,!1,ce,o))?e.preventDefault():o.previousKeyMatched=!1}f&&f(e)},tabIndex:l?0:-1},g),C)})),me={vertical:"top",horizontal:"right"},ve={vertical:"top",horizontal:"left"},be=i.a.forwardRef((function(e,t){var n=e.autoFocus,a=void 0===n||n,l=e.children,u=e.classes,c=e.disableAutoFocusItem,d=void 0!==c&&c,f=e.MenuListProps,p=void 0===f?{}:f,m=e.onClose,v=e.onEntering,b=e.open,y=e.PaperProps,g=void 0===y?{}:y,x=e.PopoverClasses,k=e.transitionDuration,E=void 0===k?"auto":k,O=e.variant,S=void 0===O?"selectedMenu":O,C=Object(o.a)(e,["autoFocus","children","classes","disableAutoFocusItem","MenuListProps","onClose","onEntering","open","PaperProps","PopoverClasses","transitionDuration","variant"]),T=Object(K.a)(),j=a&&!d&&b,P=i.a.useRef(null),R=i.a.useRef(null),N=-1;i.a.Children.map(l,(function(e,t){i.a.isValidElement(e)&&(e.props.disabled||("menu"!==S&&e.props.selected?N=t:-1===N&&(N=t)))}));var M=i.a.Children.map(l,(function(e,t){return t===N?i.a.cloneElement(e,{ref:function(t){R.current=h.a.findDOMNode(t),Object(w.a)(e.ref,t)}}):e}));return i.a.createElement(ae,Object(r.a)({getContentAnchorEl:function(){return R.current},classes:x,onClose:m,onEntering:function(e,t){P.current&&P.current.adjustStyleForScrollbar(e,T),v&&v(e,t)},anchorOrigin:"rtl"===T.direction?me:ve,transformOrigin:"rtl"===T.direction?me:ve,PaperProps:Object(r.a)({},g,{classes:Object(r.a)({},g.classes,{root:u.paper})}),open:b,ref:t,transitionDuration:E},C),i.a.createElement(he,Object(r.a)({onKeyDown:function(e){"Tab"===e.key&&(e.preventDefault(),m&&m(e,"tabKeyDown"))},actions:P,autoFocus:a&&(-1===N||d),autoFocusItem:j,variant:S},p,{className:Object(s.a)(u.list,p.className)}),M))})),ye=Object(f.a)({paper:{maxHeight:"calc(100% - 96px)",WebkitOverflowScrolling:"touch"},list:{outline:0}},{name:"MuiMenu"})(be),ge=n(41);function xe(e,t){return"object"===Object(c.a)(t)&&null!==t?e===t:String(e)===String(t)}var we=i.a.forwardRef((function(e,t){var n=e.autoFocus,a=e.autoWidth,l=e.children,c=e.classes,f=e.className,p=e.defaultValue,h=e.disabled,m=e.displayEmpty,v=e.IconComponent,b=e.inputRef,y=e.labelId,g=e.MenuProps,x=void 0===g?{}:g,w=e.multiple,E=e.name,O=e.onBlur,S=e.onChange,C=e.onClose,T=e.onFocus,j=e.onOpen,P=e.open,R=e.readOnly,N=e.renderValue,M=(e.required,e.SelectDisplayProps),_=void 0===M?{}:M,A=e.tabIndex,z=(e.type,e.value),I=e.variant,L=void 0===I?"standard":I,D=Object(o.a)(e,["autoFocus","autoWidth","children","classes","className","defaultValue","disabled","displayEmpty","IconComponent","inputRef","labelId","MenuProps","multiple","name","onBlur","onChange","onClose","onFocus","onOpen","open","readOnly","renderValue","required","SelectDisplayProps","tabIndex","type","value","variant"]),F=i.a.useRef(null!=z).current,U=i.a.useState(p),$=U[0],B=U[1],W=F?z:$;var V=i.a.useRef(null),H=i.a.useState(null),q=H[0],K=H[1],Q=i.a.useRef(null!=P).current,X=i.a.useState(),G=X[0],Y=X[1],J=i.a.useState(!1),Z=J[0],ee=J[1],te=Object(k.a)(t,b);i.a.useImperativeHandle(te,(function(){return{focus:function(){q.focus()},node:V.current,value:W}}),[q,W]),i.a.useEffect((function(){n&&q&&q.focus()}),[n,q]);var ne,re,oe=function(e,t){e?j&&j(t):C&&C(t),Q||(Y(a?null:q.clientWidth),ee(e))},ae=function(e){return function(t){var n;if(w||oe(!1,t),w){n=Array.isArray(W)?Object(u.a)(W):[];var r=W.indexOf(e.props.value);-1===r?n.push(e.props.value):n.splice(r,1)}else n=e.props.value;F||B(n),S&&(t.persist(),Object.defineProperty(t,"target",{writable:!0,value:{value:n,name:E}}),S(t,e))}},ie=null!==q&&(Q?P:Z);delete D["aria-invalid"];var le=[],ue=!1;(Object(ge.b)({value:W})||m)&&(N?ne=N(W):ue=!0);var ce=i.a.Children.map(l,(function(e){if(!i.a.isValidElement(e))return null;var t;if(w){if(!Array.isArray(W))throw new Error("Material-UI: the `value` prop must be an array when using the `Select` component with `multiple`.");(t=W.some((function(t){return xe(t,e.props.value)})))&&ue&&le.push(e.props.children)}else(t=xe(W,e.props.value))&&ue&&(re=e.props.children);return t&&!0,i.a.cloneElement(e,{"aria-selected":t?"true":void 0,onClick:ae(e),onKeyUp:function(t){" "===t.key&&t.preventDefault();var n=e.props.onKeyUp;"function"===typeof n&&n(t)},role:"option",selected:t,value:void 0,"data-value":e.props.value})}));ue&&(ne=w?le.join(", "):re);var se,de=G;!a&&Q&&q&&(de=q.clientWidth),se="undefined"!==typeof A?A:h?null:0;var fe=_.id||(E?"mui-component-select-".concat(E):void 0);return i.a.createElement(i.a.Fragment,null,i.a.createElement("div",Object(r.a)({className:Object(s.a)(c.root,c.select,c.selectMenu,c[L],f,h&&c.disabled),ref:K,tabIndex:se,role:"button","aria-expanded":ie?"true":void 0,"aria-labelledby":"".concat(y||""," ").concat(fe||""),"aria-haspopup":"listbox",onKeyDown:function(e){if(!R){-1!==[" ","ArrowUp","ArrowDown","Enter"].indexOf(e.key)&&(e.preventDefault(),oe(!0,e))}},onMouseDown:h||R?null:function(e){e.preventDefault(),q.focus(),oe(!0,e)},onBlur:function(e){!ie&&O&&(e.persist(),Object.defineProperty(e,"target",{writable:!0,value:{value:W,name:E}}),O(e))},onFocus:T},_,{id:fe}),function(e){return null==e||"string"===typeof e&&!e.trim()}(ne)?i.a.createElement("span",{dangerouslySetInnerHTML:{__html:"​"}}):ne),i.a.createElement("input",Object(r.a)({value:Array.isArray(W)?W.join(","):W,name:E,ref:V,type:"hidden",autoFocus:n},D)),i.a.createElement(v,{className:Object(s.a)(c.icon,c["icon".concat(Object(d.a)(L))],ie&&c.iconOpen)}),i.a.createElement(ye,Object(r.a)({id:"menu-".concat(E||""),anchorEl:q,open:ie,onClose:function(e){oe(!1,e)}},x,{MenuListProps:Object(r.a)({"aria-labelledby":y,role:"listbox",disableListWrap:!0},x.MenuListProps),PaperProps:Object(r.a)({},x.PaperProps,{style:Object(r.a)({minWidth:de},null!=x.PaperProps?x.PaperProps.style:null)})}),ce))})),ke=n(24),Ee=n(22),Oe=n(25),Se=Object(Oe.a)(i.a.createElement("path",{d:"M7 10l5 5 5-5z"}),"ArrowDropDown"),Ce=n(168),Te=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,l=e.disabled,u=e.IconComponent,c=e.inputRef,f=e.variant,p=void 0===f?"standard":f,h=Object(o.a)(e,["classes","className","disabled","IconComponent","inputRef","variant"]);return i.a.createElement(i.a.Fragment,null,i.a.createElement("select",Object(r.a)({className:Object(s.a)(n.root,n.select,n[p],a,l&&n.disabled),disabled:l,ref:c||t},h)),e.multiple?null:i.a.createElement(u,{className:Object(s.a)(n.icon,n["icon".concat(Object(d.a)(p))])}))})),je=function(e){return{root:{},select:{"-moz-appearance":"none","-webkit-appearance":"none",userSelect:"none",borderRadius:0,minWidth:16,cursor:"pointer","&:focus":{backgroundColor:"light"===e.palette.type?"rgba(0, 0, 0, 0.05)":"rgba(255, 255, 255, 0.05)",borderRadius:0},"&::-ms-expand":{display:"none"},"&$disabled":{cursor:"default"},"&[multiple]":{height:"auto"},"&:not([multiple]) option, &:not([multiple]) optgroup":{backgroundColor:e.palette.background.paper},"&&":{paddingRight:24}},filled:{"&&":{paddingRight:32}},outlined:{borderRadius:e.shape.borderRadius,"&&":{paddingRight:32}},selectMenu:{height:"auto",textOverflow:"ellipsis",whiteSpace:"nowrap",overflow:"hidden"},disabled:{},icon:{position:"absolute",right:0,top:"calc(50% - 12px)",color:e.palette.action.active,pointerEvents:"none"},iconOpen:{transform:"rotate(180deg)"},iconFilled:{right:7},iconOutlined:{right:7}}},Pe=i.a.createElement(Ce.a,null),Re=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.IconComponent,u=void 0===l?Se:l,c=e.input,s=void 0===c?Pe:c,d=e.inputProps,f=(e.variant,Object(o.a)(e,["children","classes","IconComponent","input","inputProps","variant"])),p=Object(Ee.a)(),h=Object(ke.a)({props:e,muiFormControl:p,states:["variant"]});return i.a.cloneElement(s,Object(r.a)({inputComponent:Te,inputProps:Object(r.a)({children:n,classes:a,IconComponent:u,variant:h.variant,type:void 0},d,{},s?s.props.inputProps:{}),ref:t},f))}));Re.muiName="Select";Object(f.a)(je,{name:"MuiNativeSelect"})(Re);var Ne=n(169),Me=n(176),_e=je,Ae=i.a.createElement(Ce.a,null),ze=i.a.createElement(Ne.a,null),Ie=i.a.forwardRef((function e(t,n){var a=t.autoWidth,u=void 0!==a&&a,c=t.children,s=t.classes,d=t.displayEmpty,f=void 0!==d&&d,p=t.IconComponent,h=void 0===p?Se:p,m=t.id,v=t.input,b=t.inputProps,y=t.labelId,g=t.labelWidth,x=void 0===g?0:g,w=t.MenuProps,k=t.multiple,E=void 0!==k&&k,O=t.native,S=void 0!==O&&O,C=t.onClose,T=t.onOpen,j=t.open,P=t.renderValue,R=t.SelectDisplayProps,N=t.variant,M=void 0===N?"standard":N,_=Object(o.a)(t,["autoWidth","children","classes","displayEmpty","IconComponent","id","input","inputProps","labelId","labelWidth","MenuProps","multiple","native","onClose","onOpen","open","renderValue","SelectDisplayProps","variant"]),A=S?Te:we,z=Object(Ee.a)(),I=Object(ke.a)({props:t,muiFormControl:z,states:["variant"]}).variant||M,L=v||{standard:Ae,outlined:i.a.createElement(Me.a,{labelWidth:x}),filled:ze}[I];return i.a.cloneElement(L,Object(r.a)({inputComponent:A,inputProps:Object(r.a)({children:c,IconComponent:h,variant:I,type:void 0,multiple:E},S?{id:m}:{autoWidth:u,displayEmpty:f,labelId:y,MenuProps:w,onClose:C,onOpen:T,open:j,renderValue:P,SelectDisplayProps:Object(r.a)({id:m},R)},{},b,{classes:b?Object(l.a)({baseClasses:s,newClasses:b.classes,Component:e}):s},v?v.props.inputProps:{}),ref:n},_))}));Ie.muiName="Select";t.a=Object(f.a)(_e,{name:"MuiSelect"})(Ie)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=n(9),u=n.n(l),c=(n(5),n(3)),s=n(168),d=n(169),f=n(176),p=n(24),h=n(22),m=n(4),v=n(6),b=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.className,u=(e.color,e.component),s=void 0===u?"label":u,d=(e.disabled,e.error,e.filled,e.focused,e.required,Object(o.a)(e,["children","classes","className","color","component","disabled","error","filled","focused","required"])),f=Object(h.a)(),m=Object(p.a)({props:e,muiFormControl:f,states:["color","required","focused","disabled","error","filled"]});return i.a.createElement(s,Object(r.a)({className:Object(c.a)(a.root,a["color".concat(Object(v.a)(m.color||"primary"))],l,m.disabled&&a.disabled,m.error&&a.error,m.filled&&a.filled,m.focused&&a.focused,m.required&&a.required),ref:t},d),n,m.required&&i.a.createElement("span",{className:Object(c.a)(a.asterisk,m.error&&a.error)},"\u2009","*"))})),y=Object(m.a)((function(e){return{root:Object(r.a)({color:e.palette.text.secondary},e.typography.body1,{lineHeight:1,padding:0,"&$focused":{color:e.palette.primary.main},"&$disabled":{color:e.palette.text.disabled},"&$error":{color:e.palette.error.main}}),colorSecondary:{"&$focused":{color:e.palette.secondary.main}},focused:{},disabled:{},error:{},filled:{},required:{},asterisk:{"&$error":{color:e.palette.error.main}}}}),{name:"MuiFormLabel"})(b),g=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,l=e.disableAnimation,u=void 0!==l&&l,s=(e.margin,e.shrink),d=(e.variant,Object(o.a)(e,["classes","className","disableAnimation","margin","shrink","variant"])),f=Object(h.a)(),m=s;"undefined"===typeof m&&f&&(m=f.filled||f.focused||f.adornedStart);var v=Object(p.a)({props:e,muiFormControl:f,states:["margin","variant"]});return i.a.createElement(y,Object(r.a)({"data-shrink":m,className:Object(c.a)(n.root,a,f&&n.formControl,!u&&n.animated,m&&n.shrink,{dense:n.marginDense}[v.margin],{filled:n.filled,outlined:n.outlined}[v.variant]),classes:{focused:n.focused,disabled:n.disabled,error:n.error,required:n.required,asterisk:n.asterisk},ref:t},d))})),x=Object(m.a)((function(e){return{root:{display:"block",transformOrigin:"top left"},focused:{},disabled:{},error:{},required:{},asterisk:{},formControl:{position:"absolute",left:0,top:0,transform:"translate(0, 24px) scale(1)"},marginDense:{transform:"translate(0, 21px) scale(1)"},shrink:{transform:"translate(0, 1.5px) scale(0.75)",transformOrigin:"top left"},animated:{transition:e.transitions.create(["color","transform"],{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut})},filled:{zIndex:1,pointerEvents:"none",transform:"translate(12px, 20px) scale(1)","&$marginDense":{transform:"translate(12px, 17px) scale(1)"},"&$shrink":{transform:"translate(12px, 10px) scale(0.75)","&$marginDense":{transform:"translate(12px, 7px) scale(0.75)"}}},outlined:{zIndex:1,pointerEvents:"none",transform:"translate(14px, 20px) scale(1)","&$marginDense":{transform:"translate(14px, 12px) scale(1)"},"&$shrink":{transform:"translate(14px, -6px) scale(0.75)"}}}}),{name:"MuiInputLabel"})(g),w=n(41),k=n(50),E=n(40),O=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.className,u=e.color,s=void 0===u?"primary":u,d=e.component,f=void 0===d?"div":d,p=e.disabled,h=void 0!==p&&p,m=e.error,b=void 0!==m&&m,y=e.fullWidth,g=void 0!==y&&y,x=e.hiddenLabel,O=void 0!==x&&x,S=e.margin,C=void 0===S?"none":S,T=e.required,j=void 0!==T&&T,P=e.size,R=e.variant,N=void 0===R?"standard":R,M=Object(o.a)(e,["children","classes","className","color","component","disabled","error","fullWidth","hiddenLabel","margin","required","size","variant"]),_=i.a.useState((function(){var e=!1;return n&&i.a.Children.forEach(n,(function(t){if(Object(k.a)(t,["Input","Select"])){var n=Object(k.a)(t,["Select"])?t.props.input:t;n&&Object(w.a)(n.props)&&(e=!0)}})),e})),A=_[0],z=_[1],I=i.a.useState((function(){var e=!1;return n&&i.a.Children.forEach(n,(function(t){Object(k.a)(t,["Input","Select"])&&Object(w.b)(t.props,!0)&&(e=!0)})),e})),L=I[0],D=I[1],F=i.a.useState(!1),U=F[0],$=F[1];h&&U&&$(!1);var B=i.a.useCallback((function(){D(!0)}),[]),W={adornedStart:A,setAdornedStart:z,color:s,disabled:h,error:b,filled:L,focused:U,hiddenLabel:O,margin:("small"===P?"dense":void 0)||C,onBlur:function(){$(!1)},onEmpty:i.a.useCallback((function(){D(!1)}),[]),onFilled:B,onFocus:function(){$(!0)},registerEffect:void 0,required:j,variant:N};return i.a.createElement(E.a.Provider,{value:W},i.a.createElement(f,Object(r.a)({className:Object(c.a)(a.root,l,"none"!==C&&a["margin".concat(Object(v.a)(C))],g&&a.fullWidth),ref:t},M),n))})),S=Object(m.a)({root:{display:"inline-flex",flexDirection:"column",position:"relative",minWidth:0,padding:0,margin:0,border:0,verticalAlign:"top"},marginNormal:{marginTop:16,marginBottom:8},marginDense:{marginTop:8,marginBottom:4},fullWidth:{width:"100%"}},{name:"MuiFormControl"})(O),C=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,l=e.component,u=void 0===l?"p":l,s=(e.disabled,e.error,e.filled,e.focused,e.margin,e.required,e.variant,Object(o.a)(e,["classes","className","component","disabled","error","filled","focused","margin","required","variant"])),d=Object(h.a)(),f=Object(p.a)({props:e,muiFormControl:d,states:["variant","margin","disabled","error","filled","focused","required"]});return i.a.createElement(u,Object(r.a)({className:Object(c.a)(n.root,("filled"===f.variant||"outlined"===f.variant)&&n.contained,a,f.disabled&&n.disabled,f.error&&n.error,f.filled&&n.filled,f.focused&&n.focused,f.required&&n.required,{dense:n.marginDense}[f.margin]),ref:t},s))})),T=Object(m.a)((function(e){return{root:Object(r.a)({color:e.palette.text.secondary},e.typography.caption,{textAlign:"left",marginTop:8,lineHeight:"1em",minHeight:"1em",margin:0,"&$disabled":{color:e.palette.text.disabled},"&$error":{color:e.palette.error.main}}),error:{},disabled:{},marginDense:{marginTop:4},contained:{margin:"8px 14px 0"},focused:{},filled:{},required:{}}}),{name:"MuiFormHelperText"})(C),j=n(172),P={standard:s.a,filled:d.a,outlined:f.a},R=i.a.forwardRef((function(e,t){var n=e.autoComplete,a=e.autoFocus,l=void 0!==a&&a,s=e.children,d=e.classes,f=e.className,p=e.color,h=void 0===p?"primary":p,m=e.defaultValue,v=e.disabled,b=void 0!==v&&v,y=e.error,g=void 0!==y&&y,w=e.FormHelperTextProps,k=e.fullWidth,E=void 0!==k&&k,O=e.helperText,C=e.hiddenLabel,R=e.id,N=e.InputLabelProps,M=e.inputProps,_=e.InputProps,A=e.inputRef,z=e.label,I=e.multiline,L=void 0!==I&&I,D=e.name,F=e.onBlur,U=e.onChange,$=e.onFocus,B=e.placeholder,W=e.required,V=void 0!==W&&W,H=e.rows,q=e.rowsMax,K=e.select,Q=void 0!==K&&K,X=e.SelectProps,G=e.type,Y=e.value,J=e.variant,Z=void 0===J?"standard":J,ee=Object(o.a)(e,["autoComplete","autoFocus","children","classes","className","color","defaultValue","disabled","error","FormHelperTextProps","fullWidth","helperText","hiddenLabel","id","InputLabelProps","inputProps","InputProps","inputRef","label","multiline","name","onBlur","onChange","onFocus","placeholder","required","rows","rowsMax","select","SelectProps","type","value","variant"]),te=i.a.useState(0),ne=te[0],re=te[1],oe=i.a.useRef(null);i.a.useEffect((function(){if("outlined"===Z){var e=u.a.findDOMNode(oe.current);re(null!=e?e.offsetWidth:0)}}),[Z,V,z]);var ae={};"outlined"===Z&&(N&&"undefined"!==typeof N.shrink&&(ae.notched=N.shrink),ae.labelWidth=ne),Q&&(X&&X.native||(ae.id=void 0),ae["aria-describedby"]=void 0);var ie=O&&R?"".concat(R,"-helper-text"):void 0,le=z&&R?"".concat(R,"-label"):void 0,ue=P[Z],ce=i.a.createElement(ue,Object(r.a)({"aria-describedby":ie,autoComplete:n,autoFocus:l,defaultValue:m,fullWidth:E,multiline:L,name:D,rows:H,rowsMax:q,type:G,value:Y,id:R,inputRef:A,onBlur:F,onChange:U,onFocus:$,placeholder:B,inputProps:M},ae,_));return i.a.createElement(S,Object(r.a)({className:Object(c.a)(d.root,f),disabled:b,error:g,fullWidth:E,hiddenLabel:C,ref:t,required:V,color:h,variant:Z},ee),z&&i.a.createElement(x,Object(r.a)({htmlFor:R,ref:oe,id:le},N),z),Q?i.a.createElement(j.a,Object(r.a)({"aria-describedby":ie,id:R,labelId:le,value:Y,input:ce},X),s):ce,O&&i.a.createElement(T,Object(r.a)({id:ie},w),O))}));t.a=Object(m.a)({root:{}},{name:"MuiTextField"})(R)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(46),c=n(25),s=Object(c.a)(i.a.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"}),"RadioButtonUnchecked"),d=Object(c.a)(i.a.createElement("path",{d:"M8.465 8.465C9.37 7.56 10.62 7 12 7C14.76 7 17 9.24 17 12C17 13.38 16.44 14.63 15.535 15.535C14.63 16.44 13.38 17 12 17C9.24 17 7 14.76 7 12C7 10.62 7.56 9.37 8.465 8.465Z"}),"RadioButtonChecked"),f=n(4);var p=Object(f.a)((function(e){return{root:{position:"relative",display:"flex","&$checked $layer":{transform:"scale(1)",transition:e.transitions.create("transform",{easing:e.transitions.easing.easeOut,duration:e.transitions.duration.shortest})}},layer:{left:0,position:"absolute",transform:"scale(0)",transition:e.transitions.create("transform",{easing:e.transitions.easing.easeIn,duration:e.transitions.duration.shortest})},checked:{}}}),{name:"PrivateRadioButtonIcon"})((function(e){var t=e.checked,n=e.classes,r=e.fontSize;return i.a.createElement("div",{className:Object(l.a)(n.root,t&&n.checked)},i.a.createElement(s,{fontSize:r}),i.a.createElement(d,{fontSize:r,className:n.layer}))})),h=n(10),m=n(6),v=n(42),b=n(62);var y=i.a.createElement(p,{checked:!0}),g=i.a.createElement(p,null),x=i.a.forwardRef((function(e,t){var n=e.checked,a=e.classes,c=e.color,s=void 0===c?"secondary":c,d=e.disabled,f=void 0!==d&&d,p=e.name,h=e.onChange,x=e.size,w=void 0===x?"medium":x,k=Object(o.a)(e,["checked","classes","color","disabled","name","onChange","size"]),E=i.a.useContext(b.a),O=n,S=Object(v.a)(h,E&&E.onChange),C=p;return E&&("undefined"===typeof O&&(O=E.value===e.value),"undefined"===typeof C&&(C=E.name)),i.a.createElement(u.a,Object(r.a)({color:s,type:"radio",icon:i.a.cloneElement(g,{fontSize:"small"===w?"small":"default"}),checkedIcon:i.a.cloneElement(y,{fontSize:"small"===w?"small":"default"}),classes:{root:Object(l.a)(a.root,a["color".concat(Object(m.a)(s))]),checked:a.checked,disabled:a.disabled},name:C,checked:O,onChange:S,ref:t,disabled:f},k))}));t.a=Object(f.a)((function(e){return{root:{color:e.palette.text.secondary},checked:{},disabled:{},colorPrimary:{"&$checked":{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(h.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}},colorSecondary:{"&$checked":{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(h.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}}}}),{name:"MuiRadio"})(x)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(46),c=n(25),s=Object(c.a)(i.a.createElement("path",{d:"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z"}),"CheckBoxOutlineBlank"),d=Object(c.a)(i.a.createElement("path",{d:"M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"}),"CheckBox"),f=n(10),p=Object(c.a)(i.a.createElement("path",{d:"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z"}),"IndeterminateCheckBox"),h=n(6),m=n(4),v=i.a.createElement(d,null),b=i.a.createElement(s,null),y=i.a.createElement(p,null),g=i.a.forwardRef((function(e,t){var n=e.checkedIcon,a=void 0===n?v:n,c=e.classes,s=e.color,d=void 0===s?"secondary":s,f=e.disabled,p=void 0!==f&&f,m=e.icon,g=void 0===m?b:m,x=e.indeterminate,w=void 0!==x&&x,k=e.indeterminateIcon,E=void 0===k?y:k,O=e.inputProps,S=e.size,C=void 0===S?"medium":S,T=Object(o.a)(e,["checkedIcon","classes","color","disabled","icon","indeterminate","indeterminateIcon","inputProps","size"]);return i.a.createElement(u.a,Object(r.a)({type:"checkbox",classes:{root:Object(l.a)(c.root,c["color".concat(Object(h.a)(d))],w&&c.indeterminate),checked:c.checked,disabled:c.disabled},color:d,inputProps:Object(r.a)({"data-indeterminate":w},O),icon:i.a.cloneElement(w?E:g,{fontSize:"small"===C?"small":"default"}),checkedIcon:i.a.cloneElement(w?E:a,{fontSize:"small"===C?"small":"default"}),ref:t,disabled:p},T))}));t.a=Object(m.a)((function(e){return{root:{color:e.palette.text.secondary},checked:{},disabled:{},indeterminate:{},colorPrimary:{"&$checked":{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(f.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}},colorSecondary:{"&$checked":{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(f.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}}}}),{name:"MuiCheckbox"})(g)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(95),c=n(20),s=n(4),d=n(47),f=n(6),p=i.a.forwardRef((function(e,t){e.children;var n=e.classes,a=e.className,u=e.labelWidth,s=e.notched,p=e.style,h=Object(o.a)(e,["children","classes","className","labelWidth","notched","style"]),m="rtl"===Object(d.a)().direction?"right":"left",v=u>0?.75*u+8:0;return i.a.createElement("fieldset",Object(r.a)({"aria-hidden":!0,style:Object(r.a)(Object(c.a)({},"padding".concat(Object(f.a)(m)),8+(s?0:v/2)),p),className:Object(l.a)(n.root,a),ref:t},h),i.a.createElement("legend",{className:n.legend,style:{width:s?v:.01}},i.a.createElement("span",{dangerouslySetInnerHTML:{__html:"​"}})))})),h=Object(s.a)((function(e){var t="rtl"===e.direction?"right":"left";return{root:{position:"absolute",bottom:0,right:0,top:-5,left:0,margin:0,padding:0,pointerEvents:"none",borderRadius:"inherit",borderStyle:"solid",borderWidth:1,transition:e.transitions.create(["padding-".concat(t),"border-color","border-width"],{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut})},legend:{textAlign:"left",padding:0,lineHeight:"11px",transition:e.transitions.create("width",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut})}}}),{name:"PrivateNotchedOutline"})(p),m=i.a.forwardRef((function(e,t){var n=e.classes,a=e.fullWidth,c=void 0!==a&&a,s=e.inputComponent,d=void 0===s?"input":s,f=e.labelWidth,p=void 0===f?0:f,m=e.multiline,v=void 0!==m&&m,b=e.notched,y=e.type,g=void 0===y?"text":y,x=Object(o.a)(e,["classes","fullWidth","inputComponent","labelWidth","multiline","notched","type"]);return i.a.createElement(u.a,Object(r.a)({renderSuffix:function(e){return i.a.createElement(h,{className:n.notchedOutline,labelWidth:p,notched:"undefined"!==typeof b?b:Boolean(e.startAdornment||e.filled||e.focused)})},classes:Object(r.a)({},n,{root:Object(l.a)(n.root,n.underline),notchedOutline:null}),fullWidth:c,inputComponent:d,multiline:v,ref:t,type:g},x))}));m.muiName="Input";t.a=Object(s.a)((function(e){var t="light"===e.palette.type?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)";return{root:{position:"relative",borderRadius:e.shape.borderRadius,"&:hover $notchedOutline":{borderColor:e.palette.text.primary},"@media (hover: none)":{"&:hover $notchedOutline":{borderColor:t}},"&$focused $notchedOutline":{borderColor:e.palette.primary.main,borderWidth:2},"&$error $notchedOutline":{borderColor:e.palette.error.main},"&$disabled $notchedOutline":{borderColor:e.palette.action.disabled}},colorSecondary:{"&$focused $notchedOutline":{borderColor:e.palette.secondary.main}},focused:{},disabled:{},adornedStart:{paddingLeft:14},adornedEnd:{paddingRight:14},error:{},marginDense:{},multiline:{padding:"18.5px 14px","&$marginDense":{paddingTop:10.5,paddingBottom:10.5}},notchedOutline:{borderColor:t},input:{padding:"18.5px 14px","&:-webkit-autofill":{WebkitBoxShadow:"dark"===e.palette.type?"0 0 0 100px #266798 inset":null,WebkitTextFillColor:"dark"===e.palette.type?"#fff":null,borderRadius:"inherit"}},inputMarginDense:{paddingTop:10.5,paddingBottom:10.5},inputMultiline:{padding:0},inputAdornedStart:{paddingLeft:0},inputAdornedEnd:{paddingRight:0}}}),{name:"MuiOutlinedInput"})(m)},function(e,t,n){"use strict";var r=n(2),o=n(20),a=n(1),i=n(0),l=n.n(i),u=(n(5),n(3)),c=n(4),s=n(94),d=n(50),f=n(8),p=n(51),h=n(9),m=n.n(h),v="undefined"===typeof window?l.a.useEffect:l.a.useLayoutEffect,b=l.a.forwardRef((function(e,t){var n=e.alignItems,o=void 0===n?"center":n,i=e.autoFocus,c=void 0!==i&&i,h=e.button,b=void 0!==h&&h,y=e.children,g=e.classes,x=e.className,w=e.component,k=e.ContainerComponent,E=void 0===k?"li":k,O=e.ContainerProps,S=(O=void 0===O?{}:O).className,C=Object(r.a)(O,["className"]),T=e.dense,j=void 0!==T&&T,P=e.disabled,R=void 0!==P&&P,N=e.disableGutters,M=void 0!==N&&N,_=e.divider,A=void 0!==_&&_,z=e.focusVisibleClassName,I=e.selected,L=void 0!==I&&I,D=Object(r.a)(e,["alignItems","autoFocus","button","children","classes","className","component","ContainerComponent","ContainerProps","dense","disabled","disableGutters","divider","focusVisibleClassName","selected"]),F=l.a.useContext(p.a),U={dense:j||F.dense||!1,alignItems:o},$=l.a.useRef(null);v((function(){c&&$.current&&$.current.focus()}),[c]);var B=l.a.Children.toArray(y),W=B.length&&Object(d.a)(B[B.length-1],["ListItemSecondaryAction"]),V=l.a.useCallback((function(e){$.current=m.a.findDOMNode(e)}),[]),H=Object(f.a)(V,t),q=Object(a.a)({className:Object(u.a)(g.root,x,U.dense&&g.dense,!M&&g.gutters,A&&g.divider,R&&g.disabled,b&&g.button,"center"!==o&&g.alignItemsFlexStart,W&&g.secondaryAction,L&&g.selected),disabled:R},D),K=w||"li";return b&&(q.component=w||"div",q.focusVisibleClassName=Object(u.a)(g.focusVisible,z),K=s.a),W?(K=q.component||w?K:"div","li"===E&&("li"===K?K="div":"li"===q.component&&(q.component="div")),l.a.createElement(p.a.Provider,{value:U},l.a.createElement(E,Object(a.a)({className:Object(u.a)(g.container,S),ref:H},C),l.a.createElement(K,q,B),B.pop()))):l.a.createElement(p.a.Provider,{value:U},l.a.createElement(K,Object(a.a)({ref:H},q),B))})),y=Object(c.a)((function(e){return{root:{display:"flex",justifyContent:"flex-start",alignItems:"center",position:"relative",textDecoration:"none",width:"100%",boxSizing:"border-box",textAlign:"left",paddingTop:8,paddingBottom:8,"&$focusVisible":{backgroundColor:e.palette.action.selected},"&$selected, &$selected:hover":{backgroundColor:e.palette.action.selected},"&$disabled":{opacity:.5}},container:{position:"relative"},focusVisible:{},dense:{paddingTop:4,paddingBottom:4},alignItemsFlexStart:{alignItems:"flex-start"},disabled:{},divider:{borderBottom:"1px solid ".concat(e.palette.divider),backgroundClip:"padding-box"},gutters:{paddingLeft:16,paddingRight:16},button:{transition:e.transitions.create("background-color",{duration:e.transitions.duration.shortest}),"&:hover":{textDecoration:"none",backgroundColor:e.palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}}},secondaryAction:{paddingRight:48},selected:{}}}),{name:"MuiListItem"})(b),g=l.a.forwardRef((function(e,t){var n,o=e.classes,i=e.className,c=e.component,s=void 0===c?"li":c,d=e.disableGutters,f=void 0!==d&&d,p=e.role,h=void 0===p?"menuitem":p,m=e.selected,v=e.tabIndex,b=Object(r.a)(e,["classes","className","component","disableGutters","role","selected","tabIndex"]);return e.disabled||(n=void 0!==v?v:-1),l.a.createElement(y,Object(a.a)({button:!0,role:h,tabIndex:n,component:s,selected:m,disableGutters:f,classes:{dense:o.dense},className:Object(u.a)(o.root,i,m&&o.selected,!f&&o.gutters),ref:t},b))}));t.a=Object(c.a)((function(e){return{root:Object(a.a)({},e.typography.body1,Object(o.a)({minHeight:48,paddingTop:6,paddingBottom:6,boxSizing:"border-box",width:"auto",overflow:"hidden",whiteSpace:"nowrap"},e.breakpoints.up("sm"),{minHeight:"auto"})),gutters:{},selected:{},dense:Object(a.a)({},e.typography.body2,{minHeight:"auto"})}}),{name:"MuiMenuItem"})(g)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,u=e.row,c=void 0!==u&&u,s=Object(o.a)(e,["classes","className","row"]);return i.a.createElement("div",Object(r.a)({className:Object(l.a)(n.root,a,c&&n.row),ref:t},s))})),s=Object(u.a)({root:{display:"flex",flexDirection:"column",flexWrap:"wrap"},row:{flexDirection:"row"}},{name:"MuiFormGroup"})(c),d=n(8),f=n(62),p=i.a.forwardRef((function(e,t){var n=e.actions,a=e.children,l=e.name,u=e.value,c=e.onChange,p=Object(o.a)(e,["actions","children","name","value","onChange"]),h=i.a.useRef(null),m=i.a.useRef(null!=u).current,v=i.a.useState(e.defaultValue),b=v[0],y=v[1],g=m?u:b;i.a.useImperativeHandle(n,(function(){return{focus:function(){var e=h.current.querySelector("input:not(:disabled):checked");e||(e=h.current.querySelector("input:not(:disabled)")),e&&e.focus()}}}),[]);var x=Object(d.a)(t,h);return i.a.createElement(f.a.Provider,{value:{name:l,onChange:function(e){m||y(e.target.value),c&&c(e,e.target.value)},value:g}},i.a.createElement(s,Object(r.a)({role:"radiogroup",ref:x},p),a))}));t.a=p}]]); +//# sourceMappingURL=2.6a72c269.chunk.js.map \ No newline at end of file diff --git a/build/static/js/2.6a72c269.chunk.js.LICENSE b/build/static/js/2.6a72c269.chunk.js.LICENSE new file mode 100644 index 0000000..bfef83c --- /dev/null +++ b/build/static/js/2.6a72c269.chunk.js.LICENSE @@ -0,0 +1,49 @@ +/* +object-assign +(c) Sindre Sorhus +@license MIT +*/ + +/** @license React v16.12.0 + * react.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** @license React v16.12.0 + * react-dom.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** @license React v0.18.0 + * scheduler.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** @license React v16.12.0 + * react-is.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * A better abstraction over CSS. + * + * @copyright Oleg Isonen (Slobodskoi) / Isonen 2014-present + * @website https://github.com/cssinjs/jss + * @license MIT + */ diff --git a/build/static/js/2.6a72c269.chunk.js.map b/build/static/js/2.6a72c269.chunk.js.map new file mode 100644 index 0000000..a9ed7e6 --- /dev/null +++ b/build/static/js/2.6a72c269.chunk.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["../node_modules/react/index.js","../node_modules/@babel/runtime/helpers/esm/extends.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/clsx/dist/clsx.m.js","../node_modules/@material-ui/styles/esm/withStyles/withStyles.js","../node_modules/@material-ui/core/esm/styles/withStyles.js","../node_modules/prop-types/index.js","../node_modules/@material-ui/core/esm/utils/capitalize.js","../node_modules/@material-ui/core/esm/utils/useForkRef.js","../node_modules/react-dom/index.js","../node_modules/@material-ui/core/esm/styles/colorManipulator.js","../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@material-ui/icons/DeleteOutlined.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/axios/lib/utils.js","../node_modules/@material-ui/core/esm/FormControl/useFormControl.js","../node_modules/tiny-invariant/dist/tiny-invariant.esm.js","../node_modules/@material-ui/core/esm/FormControl/formControlState.js","../node_modules/@material-ui/core/esm/internal/svg-icons/createSvgIcon.js","../node_modules/resolve-pathname/esm/resolve-pathname.js","../node_modules/value-equal/esm/value-equal.js","../node_modules/history/esm/history.js","../node_modules/@material-ui/icons/Close.js","../node_modules/@material-ui/icons/AddCircle.js","../node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/@material-ui/core/esm/utils/useEventCallback.js","../node_modules/@material-ui/icons/utils/createSvgIcon.js","../node_modules/tiny-warning/dist/tiny-warning.esm.js","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/@material-ui/core/esm/utils/setRef.js","../node_modules/mini-create-react-context/dist/esm/index.js","../../modules/RouterContext.js","../../modules/Router.js","../../modules/MemoryRouter.js","../../modules/Lifecycle.js","../../modules/matchPath.js","../../modules/Route.js","../../modules/StaticRouter.js","../../modules/Switch.js","../../modules/hooks.js","../node_modules/@material-ui/core/esm/FormControl/FormControlContext.js","../node_modules/@material-ui/core/esm/InputBase/utils.js","../node_modules/@material-ui/core/esm/utils/createChainedFunction.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/TransitionGroupContext.js","../node_modules/react-is/index.js","../node_modules/@material-ui/core/esm/styles/defaultTheme.js","../node_modules/@material-ui/core/esm/internal/SwitchBase.js","../node_modules/@material-ui/core/esm/styles/useTheme.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@material-ui/core/esm/utils/isMuiElement.js","../node_modules/@material-ui/core/esm/List/ListContext.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@material-ui/icons/CheckBoxOutlineBlank.js","../node_modules/axios/index.js","../node_modules/@material-ui/styles/esm/useTheme/ThemeContext.js","../node_modules/@material-ui/styles/esm/ThemeProvider/nested.js","../node_modules/@material-ui/core/esm/styles/zIndex.js","../node_modules/@material-ui/core/esm/SvgIcon/SvgIcon.js","../node_modules/@material-ui/core/esm/utils/debounce.js","../node_modules/@material-ui/core/esm/RadioGroup/RadioGroupContext.js","../node_modules/@material-ui/icons/Add.js","../node_modules/@material-ui/icons/Reorder.js","../node_modules/@material-ui/icons/RadioButtonChecked.js","../../modules/BrowserRouter.js","../../modules/HashRouter.js","../../modules/utils/locationUtils.js","../../modules/Link.js","../../modules/NavLink.js","../node_modules/@babel/runtime/helpers/inheritsLoose.js","../node_modules/react-router/node_modules/path-to-regexp/index.js","../node_modules/object-assign/index.js","../node_modules/axios/lib/helpers/bind.js","../node_modules/axios/lib/helpers/buildURL.js","../node_modules/axios/lib/cancel/isCancel.js","../node_modules/axios/lib/defaults.js","../node_modules/axios/lib/adapters/xhr.js","../node_modules/axios/lib/core/createError.js","../node_modules/axios/lib/core/mergeConfig.js","../node_modules/axios/lib/cancel/Cancel.js","../node_modules/@material-ui/core/esm/SvgIcon/index.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@material-ui/styles/node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/@material-ui/icons/RadioButtonUnchecked.js","../node_modules/gud/index.js","../node_modules/react-router/node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/@material-ui/icons/KeyboardArrowRight.js","../node_modules/@material-ui/core/esm/styles/createBreakpoints.js","../node_modules/@material-ui/core/esm/styles/createMixins.js","../node_modules/@material-ui/core/esm/colors/common.js","../node_modules/@material-ui/core/esm/colors/grey.js","../node_modules/@material-ui/core/esm/colors/indigo.js","../node_modules/@material-ui/core/esm/colors/pink.js","../node_modules/@material-ui/core/esm/colors/red.js","../node_modules/@material-ui/core/esm/colors/orange.js","../node_modules/@material-ui/core/esm/colors/blue.js","../node_modules/@material-ui/core/esm/colors/green.js","../node_modules/@material-ui/core/esm/styles/createPalette.js","../node_modules/@material-ui/core/esm/styles/createTypography.js","../node_modules/@material-ui/core/esm/styles/shadows.js","../node_modules/@material-ui/core/esm/styles/shape.js","../node_modules/@material-ui/core/esm/styles/createSpacing.js","../node_modules/@material-ui/core/esm/styles/transitions.js","../node_modules/@material-ui/core/esm/styles/createMuiTheme.js","../node_modules/@material-ui/styles/esm/useTheme/useTheme.js","../node_modules/@material-ui/core/esm/NoSsr/NoSsr.js","../node_modules/@material-ui/core/esm/utils/focusVisible.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/utils/ChildMapping.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/TransitionGroup.js","../node_modules/@material-ui/core/esm/ButtonBase/Ripple.js","../node_modules/@material-ui/core/esm/ButtonBase/TouchRipple.js","../node_modules/@material-ui/core/esm/ButtonBase/ButtonBase.js","../node_modules/@material-ui/core/esm/TextareaAutosize/TextareaAutosize.js","../node_modules/@material-ui/core/esm/InputBase/InputBase.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/scheduler/index.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/axios/lib/axios.js","../node_modules/axios/lib/core/Axios.js","../node_modules/axios/lib/core/InterceptorManager.js","../node_modules/axios/lib/core/dispatchRequest.js","../node_modules/axios/lib/core/transformData.js","../node_modules/process/browser.js","../node_modules/axios/lib/helpers/normalizeHeaderName.js","../node_modules/axios/lib/core/settle.js","../node_modules/axios/lib/core/enhanceError.js","../node_modules/axios/lib/core/buildFullPath.js","../node_modules/axios/lib/helpers/isAbsoluteURL.js","../node_modules/axios/lib/helpers/combineURLs.js","../node_modules/axios/lib/helpers/parseHeaders.js","../node_modules/axios/lib/helpers/isURLSameOrigin.js","../node_modules/axios/lib/helpers/cookies.js","../node_modules/axios/lib/cancel/CancelToken.js","../node_modules/axios/lib/helpers/spread.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/@babel/runtime/helpers/extends.js","../node_modules/webpack/buildin/global.js","../node_modules/react-router/node_modules/isarray/index.js","../node_modules/@material-ui/core/esm/Typography/Typography.js","../node_modules/@material-ui/core/esm/IconButton/IconButton.js","../node_modules/is-in-browser/dist/module.js","../node_modules/jss/dist/jss.esm.js","../node_modules/@material-ui/styles/esm/makeStyles/multiKeyStore.js","../node_modules/@material-ui/styles/esm/createGenerateClassName/createGenerateClassName.js","../node_modules/jss-plugin-rule-value-function/dist/jss-plugin-rule-value-function.esm.js","../node_modules/jss-plugin-global/dist/jss-plugin-global.esm.js","../node_modules/jss-plugin-nested/dist/jss-plugin-nested.esm.js","../node_modules/hyphenate-style-name/index.js","../node_modules/jss-plugin-camel-case/dist/jss-plugin-camel-case.esm.js","../node_modules/jss-plugin-default-unit/dist/jss-plugin-default-unit.esm.js","../node_modules/css-vendor/dist/css-vendor.esm.js","../node_modules/jss-plugin-vendor-prefixer/dist/jss-plugin-vendor-prefixer.esm.js","../node_modules/jss-plugin-props-sort/dist/jss-plugin-props-sort.esm.js","../node_modules/@material-ui/styles/esm/jssPreset/jssPreset.js","../node_modules/@material-ui/styles/esm/StylesProvider/StylesProvider.js","../node_modules/@material-ui/styles/esm/makeStyles/indexCounter.js","../node_modules/@material-ui/styles/esm/getStylesCreator/getStylesCreator.js","../node_modules/@material-ui/styles/esm/getStylesCreator/noopTheme.js","../node_modules/@material-ui/styles/esm/makeStyles/makeStyles.js","../node_modules/@material-ui/core/esm/FormControlLabel/FormControlLabel.js","../node_modules/@material-ui/styles/esm/mergeClasses/mergeClasses.js","../node_modules/@material-ui/utils/esm/deepmerge.js","../node_modules/@material-ui/styles/esm/getThemeProps/getThemeProps.js","../node_modules/@material-ui/core/esm/Switch/Switch.js","../node_modules/@material-ui/core/esm/styles/makeStyles.js","../node_modules/@material-ui/core/esm/Paper/Paper.js","../node_modules/@material-ui/core/esm/Grid/Grid.js","../node_modules/@material-ui/core/esm/Input/Input.js","../node_modules/@material-ui/core/esm/FilledInput/FilledInput.js","../node_modules/@material-ui/core/esm/Button/Button.js","../node_modules/@material-ui/styles/esm/ThemeProvider/ThemeProvider.js","../node_modules/@material-ui/core/esm/utils/ownerDocument.js","../node_modules/@material-ui/core/esm/utils/ownerWindow.js","../node_modules/@material-ui/core/esm/Portal/Portal.js","../node_modules/@material-ui/core/esm/utils/getScrollbarSize.js","../node_modules/@material-ui/core/esm/Modal/ModalManager.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@material-ui/core/esm/Modal/TrapFocus.js","../node_modules/@material-ui/core/esm/Modal/SimpleBackdrop.js","../node_modules/@material-ui/core/esm/Modal/Modal.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/config.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/Transition.js","../node_modules/@material-ui/core/esm/transitions/utils.js","../node_modules/@material-ui/core/esm/Grow/Grow.js","../node_modules/@material-ui/core/esm/Popover/Popover.js","../node_modules/@material-ui/core/esm/List/List.js","../node_modules/@material-ui/core/esm/MenuList/MenuList.js","../node_modules/@material-ui/core/esm/Menu/Menu.js","../node_modules/@material-ui/core/esm/Select/SelectInput.js","../node_modules/@material-ui/core/esm/internal/svg-icons/ArrowDropDown.js","../node_modules/@material-ui/core/esm/NativeSelect/NativeSelectInput.js","../node_modules/@material-ui/core/esm/NativeSelect/NativeSelect.js","../node_modules/@material-ui/core/esm/Select/Select.js","../node_modules/@material-ui/core/esm/FormLabel/FormLabel.js","../node_modules/@material-ui/core/esm/InputLabel/InputLabel.js","../node_modules/@material-ui/core/esm/FormControl/FormControl.js","../node_modules/@material-ui/core/esm/FormHelperText/FormHelperText.js","../node_modules/@material-ui/core/esm/TextField/TextField.js","../node_modules/@material-ui/core/esm/internal/svg-icons/RadioButtonUnchecked.js","../node_modules/@material-ui/core/esm/internal/svg-icons/RadioButtonChecked.js","../node_modules/@material-ui/core/esm/Radio/RadioButtonIcon.js","../node_modules/@material-ui/core/esm/Radio/Radio.js","../node_modules/@material-ui/core/esm/RadioGroup/useRadioGroup.js","../node_modules/@material-ui/core/esm/internal/svg-icons/CheckBoxOutlineBlank.js","../node_modules/@material-ui/core/esm/internal/svg-icons/CheckBox.js","../node_modules/@material-ui/core/esm/internal/svg-icons/IndeterminateCheckBox.js","../node_modules/@material-ui/core/esm/Checkbox/Checkbox.js","../node_modules/@material-ui/core/esm/OutlinedInput/NotchedOutline.js","../node_modules/@material-ui/core/esm/OutlinedInput/OutlinedInput.js","../node_modules/@material-ui/core/esm/ListItem/ListItem.js","../node_modules/@material-ui/core/esm/MenuItem/MenuItem.js","../node_modules/@material-ui/core/esm/FormGroup/FormGroup.js","../node_modules/@material-ui/core/esm/RadioGroup/RadioGroup.js"],"names":["module","exports","require","_extends","Object","assign","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","_objectWithoutProperties","excluded","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","toVal","mix","k","y","str","push","x","withStyles","stylesOrCreator","options","undefined","Component","defaultTheme","_options$withTheme","withTheme","name","stylesOptions","classNamePrefix","useStyles","makeStyles","displayName","WithStyles","React","forwardRef","props","ref","classes","theme","innerRef","other","more","useTheme","getThemeProps","createElement","defaultProps","hoistNonReactStatics","withStylesWithoutDefault","capitalize","string","charAt","toUpperCase","slice","useForkRef","refA","refB","useMemo","refValue","setRef","checkDCE","__REACT_DEVTOOLS_GLOBAL_HOOK__","process","err","console","error","clamp","value","min","max","Math","decomposeColor","color","type","substr","re","RegExp","concat","colors","match","map","n","parseInt","join","hexToRgb","marker","substring","Error","values","split","parseFloat","recomposeColor","getContrastRatio","foreground","background","lumA","getLuminance","lumB","rgb","h","s","l","a","f","round","hslToRgb","val","pow","Number","toFixed","fade","darken","coefficient","lighten","_toConsumableArray","arr","Array","isArray","arr2","iterableToArray","TypeError","_inheritsLoose","subClass","superClass","create","constructor","__proto__","_objectWithoutPropertiesLoose","sourceKeys","keys","_interopRequireDefault","defineProperty","default","_react","_default","d","_defineProperty","obj","enumerable","configurable","writable","bind","toString","isUndefined","isObject","isFunction","forEach","fn","isArrayBuffer","isBuffer","isFormData","FormData","isArrayBufferView","ArrayBuffer","isView","buffer","isString","isNumber","isDate","isFile","isBlob","isStream","pipe","isURLSearchParams","URLSearchParams","isStandardBrowserEnv","navigator","product","window","document","merge","result","assignValue","deepMerge","extend","b","thisArg","trim","replace","useFormControl","useContext","FormControlContext","invariant","condition","message","formControlState","_ref","states","muiFormControl","reduce","acc","state","createSvgIcon","path","memo","SvgIcon","muiName","isAbsolute","pathname","spliceOne","list","index","pop","resolvePathname","to","from","hasTrailingSlash","toParts","fromParts","isToAbs","isFromAbs","mustEndAbs","last","up","part","unshift","valueOf","valueEqual","every","item","aValue","bValue","addLeadingSlash","stripLeadingSlash","stripBasename","prefix","toLowerCase","hasBasename","stripTrailingSlash","createPath","location","search","hash","createLocation","currentLocation","hashIndex","searchIndex","parsePath","decodeURI","e","URIError","locationsAreEqual","createTransitionManager","prompt","listeners","setPrompt","nextPrompt","confirmTransitionTo","action","getUserConfirmation","callback","appendListener","isActive","listener","filter","notifyListeners","_len","args","_key","canUseDOM","getConfirmation","confirm","getHistoryState","history","createBrowserHistory","globalHistory","canUseHistory","ua","userAgent","supportsHistory","needsHashChangeListener","_props","_props$forceRefresh","forceRefresh","_props$getUserConfirm","_props$keyLength","keyLength","basename","getDOMLocation","historyState","_window$location","createKey","random","transitionManager","setState","nextState","handlePopState","event","isExtraneousPopstateEvent","handlePop","handleHashChange","forceNextPop","ok","fromLocation","toLocation","toIndex","allKeys","fromIndex","delta","go","revertPop","initialLocation","createHref","listenerCount","checkDOMListeners","addEventListener","removeEventListener","isBlocked","href","pushState","prevIndex","nextKeys","replaceState","goBack","goForward","block","unblock","listen","unlisten","HashPathCoders","hashbang","encodePath","decodePath","noslash","slash","stripHash","url","getHashPath","replaceHashPath","createHashHistory","_props$hashType","hashType","_HashPathCoders$hashT","ignorePath","encodedPath","prevLocation","allPaths","lastIndexOf","baseTag","querySelector","getAttribute","pushHashPath","nextPaths","lowerBound","upperBound","createMemoryHistory","_props$initialEntries","initialEntries","_props$initialIndex","initialIndex","entries","entry","nextIndex","nextEntries","splice","canGo","__esModule","useEnhancedEffect","useLayoutEffect","useEffect","useEventCallback","useRef","current","useCallback","_SvgIcon","_extends2","warning","_slicedToArray","arrayWithHoles","Symbol","iterator","_arr","_n","_d","_e","_s","_i","next","done","nonIterableRest","createEventEmitter","handlers","on","handler","off","get","set","newValue","changedBits","createContext","defaultValue","calculateChangedBits","_Provider$childContex","_Consumer$contextType","contextProp","gud","Provider","_Component","_this","emitter","_proto","getChildContext","componentWillReceiveProps","nextProps","oldValue","render","children","childContextTypes","PropTypes","object","isRequired","Consumer","_Component2","_this2","getValue","onUpdate","observedBits","_proto2","componentDidMount","context","componentWillUnmount","contextTypes","createNamedContext","Router","computeRootMatch","params","isExact","_pendingLocation","RouterContext","staticContext","cache","cacheCount","matchPath","exact","strict","sensitive","matched","cacheKey","pathCache","regexp","pathToRegexp","compilePath","end","Route","component","base","createURL","staticHandler","methodName","noop","useParams","hasValue","isFilled","SSR","isAdornedStart","startAdornment","createChainedFunction","funcs","func","_len2","_key2","createMuiTheme","SwitchBase","autoFocus","checkedProp","checked","checkedIcon","className","defaultChecked","disabledProp","disabled","icon","id","inputProps","inputRef","onBlur","onChange","onFocus","readOnly","required","tabIndex","isControlled","_React$useState","useState","Boolean","checkedState","setCheckedState","hasLabelFor","IconButton","clsx","root","role","input","newChecked","padding","cursor","position","opacity","width","height","top","left","margin","zIndex","useThemeWithoutDefault","_defineProperties","descriptor","_createClass","Constructor","protoProps","staticProps","_assertThisInitialized","self","ReferenceError","isMuiElement","element","muiNames","isValidElement","ListContext","_typeof2","_typeof","ThemeContext","hasSymbol","for","mobileStepper","speedDial","appBar","drawer","modal","snackbar","tooltip","_props$color","_props$component","_props$fontSize","fontSize","htmlColor","titleAccess","_props$viewBox","viewBox","focusable","userSelect","display","fill","flexShrink","typography","pxToRem","transition","transitions","duration","shorter","colorPrimary","palette","primary","main","colorSecondary","secondary","colorAction","active","colorError","colorDisabled","fontSizeInherit","fontSizeSmall","fontSizeLarge","debounce","timeout","wait","debounced","that","later","clearTimeout","setTimeout","clear","RadioGroupContext","HashRouter","createHistory","resolveToLocation","normalizeToLocation","forwardRefShim","C","LinkAnchor","navigate","onClick","rest","ex","isModifiedEvent","forwardedRef","Link","method","ariaCurrent","activeClassName","activeStyle","classNameProp","isActiveProp","locationProp","styleProp","style","escapedPath","classnames","joinClassnames","isarray","parse","compile","tokensToFunction","tokensToRegExp","PATH_REGEXP","res","tokens","defaultDelimiter","delimiter","exec","m","escaped","offset","capture","group","modifier","asterisk","partial","repeat","optional","pattern","escapeGroup","escapeString","encodeURIComponentPretty","encodeURI","c","charCodeAt","matches","flags","opts","data","encode","pretty","encodeURIComponent","token","segment","JSON","stringify","j","test","attachKeys","route","endsWithDelimiter","groups","regexpToRegexp","parts","arrayToRegexp","stringToRegexp","propIsEnumerable","toObject","test1","String","getOwnPropertyNames","test2","fromCharCode","test3","letter","shouldUseNative","symbols","utils","paramsSerializer","serializedParams","v","toISOString","hashmarkIndex","__CANCEL__","normalizeHeaderName","DEFAULT_CONTENT_TYPE","setContentTypeIfUnset","headers","defaults","adapter","XMLHttpRequest","getDefaultAdapter","transformRequest","transformResponse","xsrfCookieName","xsrfHeaderName","maxContentLength","validateStatus","status","common","settle","buildURL","buildFullPath","parseHeaders","isURLSameOrigin","createError","config","Promise","resolve","reject","requestData","requestHeaders","request","auth","username","password","Authorization","btoa","fullPath","baseURL","open","onreadystatechange","readyState","responseURL","responseHeaders","getAllResponseHeaders","response","responseType","responseText","statusText","onabort","onerror","ontimeout","timeoutErrorMessage","cookies","xsrfValue","withCredentials","read","setRequestHeader","onDownloadProgress","onUploadProgress","upload","cancelToken","promise","then","cancel","abort","send","enhanceError","code","config1","config2","valueFromConfig2Keys","mergeDeepPropertiesKeys","defaultToConfig2Keys","prop","axiosKeys","otherKeys","Cancel","_iterableToArray","iter","_arrayWithHoles","_nonIterableRest","reactIs","REACT_STATICS","contextType","getDefaultProps","getDerivedStateFromError","getDerivedStateFromProps","mixins","propTypes","KNOWN_STATICS","caller","callee","arity","MEMO_STATICS","compare","TYPE_STATICS","getStatics","isMemo","ForwardRef","getOwnPropertyDescriptor","getPrototypeOf","objectPrototype","targetComponent","sourceComponent","blacklist","inheritedComponent","targetStatics","sourceStatics","global","Memo","ownKeys","enumerableOnly","sym","_objectSpread2","getOwnPropertyDescriptors","defineProperties","createBreakpoints","breakpoints","_breakpoints$values","xs","sm","md","lg","xl","_breakpoints$unit","unit","_breakpoints$step","step","between","start","endIndex","down","upperbound","only","createMixins","spacing","_toolbar","gutters","styles","paddingLeft","paddingRight","toolbar","minHeight","black","white","grey","50","100","200","300","400","500","600","700","800","900","A100","A200","A400","A700","indigo","pink","red","orange","blue","green","light","text","hint","divider","paper","hover","hoverOpacity","selected","disabledBackground","dark","addLightOrDark","intent","direction","shade","tonalOffset","createPalette","_palette$primary","_palette$secondary","_palette$error","_palette$warning","_palette$info","info","_palette$success","success","_palette$type","_palette$contrastThre","contrastThreshold","_palette$tonalOffset","getContrastText","augmentColor","mainShade","lightShade","darkShade","contrastText","types","deepmerge","caseAllCaps","textTransform","createTypography","_ref$fontFamily","fontFamily","_ref$fontSize","_ref$fontWeightLight","fontWeightLight","_ref$fontWeightRegula","fontWeightRegular","_ref$fontWeightMedium","fontWeightMedium","_ref$fontWeightBold","fontWeightBold","_ref$htmlFontSize","htmlFontSize","allVariants","pxToRem2","coef","size","buildVariant","fontWeight","lineHeight","letterSpacing","casing","variants","h1","h2","h3","h4","h5","h6","subtitle1","subtitle2","body1","body2","button","caption","overline","clone","createShadow","shadows","shape","borderRadius","createSpacing","transform","spacingInput","mui","factor","output","easing","easeInOut","easeOut","easeIn","sharp","shortest","short","standard","complex","enteringScreen","leavingScreen","formatMs","milliseconds","_options$duration","durationOption","_options$easing","easingOption","_options$delay","delay","animatedProp","getAutoHeightDuration","constant","_options$breakpoints","breakpointsInput","_options$mixins","mixinsInput","_options$palette","paletteInput","_options$typography","typographyInput","muiTheme","overrides","argument","NoSsr","_props$defer","defer","_props$fallback","fallback","mountedState","setMountedState","Fragment","hadKeyboardEvent","hadFocusVisibleRecently","hadFocusVisibleRecentlyTimeout","inputTypesWhitelist","tel","email","number","date","month","week","time","datetime","handleKeyDown","metaKey","altKey","ctrlKey","handlePointerDown","handleVisibilityChange","visibilityState","isFocusVisible","node","tagName","isContentEditable","focusTriggersKeyboardModality","handleBlurVisible","useIsFocusVisible","onBlurVisible","instance","doc","ReactDOM","findDOMNode","ownerDocument","getChildMapping","mapFn","Children","child","mapper","getProp","getNextChildMapping","prevChildMapping","onExited","nextChildMapping","prev","getValueForKey","nextKeysPending","pendingKeys","prevKey","childMapping","nextKey","pendingNextKey","mergeChildMappings","hasPrev","hasNext","prevChild","isLeaving","in","cloneElement","exit","enter","TransitionGroup","_React$Component","handleExited","contextValue","isMounting","firstRender","mounted","appear","currentChildMapping","_this$props","childFactory","TransitionGroupContext","Ripple","_props$pulsate","pulsate","rippleX","rippleY","rippleSize","inProp","_props$onExited","leaving","setLeaving","rippleClassName","ripple","rippleVisible","ripplePulsate","rippleStyles","childClassName","childLeaving","childPulsate","timeoutId","TouchRipple","_props$center","center","centerProp","ripples","setRipples","rippleCallback","ignoringMouseDown","startTimer","startTimerCommit","container","startCommit","cb","oldRipples","_options$pulsate","_options$center","_options$fakeElement","fakeElement","rect","getBoundingClientRect","clientX","clientY","touches","sqrt","sizeX","abs","clientWidth","sizeY","clientHeight","stop","persist","useImperativeHandle","overflow","pointerEvents","right","bottom","animation","animationDuration","backgroundColor","flip","ButtonBase","buttonRefProp","buttonRef","_props$centerRipple","centerRipple","_props$disabled","_props$disableRipple","disableRipple","_props$disableTouchRi","disableTouchRipple","_props$focusRipple","focusRipple","focusVisibleClassName","onFocusVisible","onKeyDown","onKeyUp","onMouseDown","onMouseLeave","onMouseUp","onTouchEnd","onTouchMove","onTouchStart","onDragLeave","_props$tabIndex","TouchRippleProps","_props$type","rippleRef","focusVisible","setFocusVisible","_useIsFocusVisible","focusVisibleRef","useRippleHandler","rippleAction","eventCallback","skipRippleAction","focus","handleMouseDown","handleDragLeave","handleMouseUp","handleMouseLeave","preventDefault","handleTouchStart","handleTouchEnd","handleTouchMove","handleBlur","handleFocus","currentTarget","isNonNativeButton","keydownRef","handleKeyUp","defaultPrevented","ComponentProp","buttonProps","handleUserRef","handleOwnRef","handleRef","alignItems","justifyContent","WebkitTapHighlightColor","outline","border","verticalAlign","textDecoration","borderStyle","getStyleValue","computedStyle","property","visibility","TextareaAutosize","rows","rowsMax","_props$rowsMin","rowsMin","rowsMinProp","shadowRef","syncHeight","getComputedStyle","inputShallow","placeholder","boxSizing","innerHeight","scrollHeight","singleRowHeight","outerHeight","outerHeightStyle","prevState","handleResize","InputBase","ariaDescribedby","autoComplete","endAdornment","_props$fullWidth","fullWidth","_props$inputComponent","inputComponent","_props$inputProps","inputPropsProp","inputRefProp","_props$multiline","multiline","renderSuffix","valueProp","handleInputRefWarning","handleInputPropsRefProp","handleInputRefProp","handleInputRef","focused","setFocused","fcs","onFilled","onEmpty","checkDirty","InputComponent","setAdornedStart","formControl","adornedStart","adornedEnd","dense","marginDense","onAnimationStart","animationName","inputMultiline","hiddenLabel","inputHiddenLabel","inputAdornedStart","inputAdornedEnd","inputTypeSearch","inputMarginDense","stopPropagation","placeholderHidden","placeholderVisible","paddingTop","font","minWidth","boxShadow","resize","p","q","r","t","u","w","z","aa","A","B","isMounted","enqueueForceUpdate","enqueueReplaceState","enqueueSetState","D","E","refs","updater","F","G","isReactComponent","forceUpdate","H","isPureReactComponent","I","J","K","L","__self","__source","M","g","$$typeof","_owner","N","O","P","Q","keyPrefix","count","R","U","S","T","escape","ca","da","V","ba","W","X","toArray","createRef","PureComponent","_calculateChangedBits","_currentValue","_currentValue2","_threadCount","_context","lazy","_ctor","_status","_result","useDebugValue","useReducer","Profiler","StrictMode","Suspense","createFactory","version","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","ReactCurrentDispatcher","ReactCurrentBatchConfig","suspense","ReactCurrentOwner","IsSomeRendererActing","Y","Z","ea","extractEvents","eventTypes","fa","phasedRegistrationNames","ha","registrationName","ia","ja","dependencies","ka","onError","la","ma","na","oa","pa","qa","sa","va","wa","ra","xa","ya","za","Aa","_dispatchListeners","_dispatchInstances","isPropagationStopped","isPersistent","release","Ba","Ca","injectEventPluginOrder","injectEventPluginsByName","Da","stateNode","Ea","Fa","Ga","Ha","Ia","Ja","Ka","La","Ma","Na","Oa","Pa","Qa","Ra","Sa","Ta","Ua","Wa","Xa","tag","_debugOwner","_debugSource","fileName","lineNumber","return","Ya","Za","$a","ab","bb","db","eb","fb","gb","hb","ib","jb","kb","Map","lb","mb","nb","ob","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","sb","tb","ub","vb","qb","isNaN","rb","pb","removeAttribute","setAttribute","setAttributeNS","wb","nodeName","yb","_valueTracker","setValue","stopTracking","xb","zb","Ab","_wrapperState","initialChecked","Bb","initialValue","controlled","Cb","Eb","Fb","Gb","activeElement","Ib","Hb","Jb","defaultSelected","Kb","dangerouslySetInnerHTML","Lb","Mb","Nb","textContent","xlinkHref","Ob","Pb","Qb","Rb","Sb","MSApp","execUnsafeLocalFunction","namespaceURI","innerHTML","firstChild","removeChild","appendChild","Tb","lastChild","nodeType","nodeValue","Ub","Vb","animationend","animationiteration","animationstart","transitionend","Wb","Xb","Yb","Zb","$b","ac","bc","cc","ec","alternate","effectTag","fc","memoizedState","dehydrated","gc","ic","sibling","hc","jc","kc","lc","mc","nc","oc","pc","qc","rc","sc","tc","uc","vc","zc","blockedOn","topLevelType","eventSystemFlags","nativeEvent","Ac","delete","pointerId","Bc","Cc","Ec","Fc","unstable_runWithPriority","priority","hydrate","containerInfo","Gc","Hc","Ic","Jc","shift","Kc","unstable_scheduleCallback","unstable_NormalPriority","Lc","Mc","srcElement","correspondingUseElement","parentNode","Nc","Oc","dispatchConfig","Pc","_targetInst","Qc","Rc","Sc","Tc","Uc","Interface","isDefaultPrevented","returnValue","Wc","eventPool","Xc","destructor","Vc","getPooled","cancelBubble","eventPhase","bubbles","cancelable","timeStamp","Date","now","isTrusted","Yc","elapsedTime","pseudoElement","Zc","clipboardData","$c","view","detail","ad","relatedTarget","bd","keyCode","charCode","cd","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","dd","8","9","12","13","16","17","18","19","20","27","32","33","34","35","36","37","38","39","40","45","46","112","113","114","115","116","117","118","119","120","121","122","123","144","145","224","ed","Alt","Control","Meta","Shift","gd","getModifierState","hd","shiftKey","locale","which","jd","kd","ld","nd","screenX","screenY","pageX","pageY","buttons","fromElement","toElement","movementX","movementY","od","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","pd","dataTransfer","qd","targetTouches","changedTouches","rd","sd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","td","ud","vd","wd","yd","zd","Ad","Bd","Cd","Dd","bubbled","captured","eventPriority","Ed","getEventPriority","Fd","unstable_UserBlockingPriority","Gd","Hd","Jd","Kd","targetInst","ancestors","Ld","Md","Nd","Od","Pd","Qd","Dc","Rd","Sd","WeakMap","xc","Set","yc","has","add","Td","animationIterationCount","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexGrow","flexPositive","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","lineClamp","order","orphans","tabSize","widows","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","Ud","Vd","Wd","setProperty","Xd","menuitem","area","br","col","embed","hr","img","keygen","link","meta","param","track","wbr","Yd","Zd","is","$d","ae","be","body","ce","de","nextSibling","fe","HTMLIFrameElement","contentWindow","ge","contentEditable","le","me","ne","oe","__html","pe","qe","se","previousSibling","te","ue","ve","we","xe","ye","ze","Ae","Be","Ce","De","Ee","Fe","Ge","He","documentMode","Ie","Je","Ke","Le","beforeInput","compositionEnd","compositionStart","compositionUpdate","Me","Ne","Oe","Pe","Se","Qe","char","Re","Te","range","Ue","Ve","change","We","Xe","Ye","Ze","$e","af","bf","cf","detachEvent","df","ef","attachEvent","ff","gf","hf","lf","jf","_isInputEventSupported","kf","mouseEnter","mouseLeave","pointerEnter","pointerLeave","mf","defaultView","parentWindow","of","pf","qf","rf","sf","select","tf","uf","vf","wf","xf","selectionStart","selectionEnd","anchorNode","getSelection","anchorOffset","focusNode","focusOffset","yf","onSelect","SimpleEventPlugin","EnterLeaveEventPlugin","ChangeEventPlugin","SelectEventPlugin","BeforeInputEventPlugin","Af","Bf","Cf","Df","Ef","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Ff","Gf","Hf","If","Jf","__reactInternalMemoizedMergedChildContext","Kf","Lf","Mf","Nf","unstable_cancelCallback","Of","unstable_shouldYield","Pf","unstable_requestPaint","Qf","unstable_now","Rf","unstable_getCurrentPriorityLevel","Sf","unstable_ImmediatePriority","Tf","Uf","Vf","unstable_LowPriority","Wf","unstable_IdlePriority","Xf","Yf","Zf","$f","ag","bg","cg","dg","eg","fg","gg","hg","ig","jg","kg","mg","ng","og","pg","qg","rg","sg","tg","ug","childExpirationTime","vg","firstContext","expirationTime","wg","xg","responders","yg","zg","baseState","firstUpdate","lastUpdate","firstCapturedUpdate","lastCapturedUpdate","firstEffect","lastEffect","firstCapturedEffect","lastCapturedEffect","Ag","Bg","suspenseConfig","payload","nextEffect","Cg","Dg","updateQueue","Eg","Fg","Gg","Hg","Ig","Jg","Kg","Lg","Mg","Ng","Og","Sg","_reactInternalFiber","Pg","Qg","Rg","Tg","shouldComponentUpdate","Ug","Vg","UNSAFE_componentWillReceiveProps","Wg","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","Xg","Yg","_stringRef","Zg","$g","ah","bh","mode","elementType","ch","implementation","dh","eh","ta","fh","gh","hh","ih","jh","kh","lh","mh","documentElement","nh","oh","ph","qh","memoizedProps","revealOrder","rh","responder","sh","th","uh","vh","wh","xh","yh","zh","Ah","Bh","Ch","Gh","Hh","Ih","Jh","Kh","Lh","Mh","Nh","queue","baseUpdate","Oh","Ph","Qh","lastRenderedReducer","dispatch","lastRenderedState","eagerReducer","eagerState","Rh","Sh","Th","Uh","destroy","deps","Vh","Wh","Xh","Yh","Zh","$h","ai","bi","readContext","useResponder","useDeferredValue","useTransition","unstable_next","ci","di","ei","fi","gi","hi","pendingProps","ii","ji","ki","li","mi","ni","oi","pi","qi","ri","si","ti","ui","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","vi","wi","pendingContext","Hi","Ji","Ki","xi","retryTime","yi","unstable_avoidThisFallback","zi","Ai","isBackwards","rendering","tail","tailExpiration","tailMode","Bi","Ci","Li","Mi","Ni","stack","onclick","Oi","WeakSet","Pi","Si","Ri","Ti","Ui","__reactInternalSnapshotBeforeUpdate","Vi","Wi","Qi","Xi","Yi","Zi","$i","insertBefore","_reactRootContainer","aj","wasMultiple","multiple","bj","cj","dj","ej","fj","gj","hj","ij","componentDidCatch","jj","componentStack","gk","kj","ceil","lj","mj","wj","xj","yj","zj","Aj","Bj","Dj","Ej","Fj","Gj","Hj","Ij","Jj","timeoutMs","Kj","Lj","Mj","Nj","Oj","lastExpiredTime","Pj","firstPendingTime","lastPingedTime","nextKnownPendingLevel","callbackExpirationTime","callbackPriority","callbackNode","Qj","Rj","Sj","Tj","Uj","Vj","Wj","finishedWork","finishedExpirationTime","lastSuspendedTime","Xj","timeoutHandle","Yj","busyMinDurationMs","busyDelayMs","Zj","bk","ck","pingCache","dk","ek","fk","createElementNS","createTextNode","ik","firstSuspendedTime","rangeCount","Db","focusedElem","selectionRange","jk","ee","contains","compareDocumentPosition","createRange","setStart","removeAllRanges","addRange","setEnd","scrollLeft","scrollTop","Dh","dc","fd","hk","Eh","Fh","xk","Di","Ei","Fi","xd","Gi","kk","lk","mk","hidden","Va","nk","unstable_observedBits","pk","pendingChildren","qk","rk","sk","tk","uk","vk","wc","_internalRoot","wk","zk","hasAttribute","yk","Ak","Bk","unmount","querySelectorAll","form","ak","Ck","createPortal","unstable_renderSubtreeIntoContainer","unmountComponentAtNode","unstable_createPortal","unstable_batchedUpdates","flushSync","Events","findFiberByHostInstance","isDisabled","supportsFiber","inject","onCommitFiberRoot","onCommitFiberUnmount","overrideHookState","overrideProps","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","bundleType","rendererPackageName","Dk","Ek","MessageChannel","unstable_forceFrameRate","performance","cancelAnimationFrame","requestAnimationFrame","floor","port2","port1","onmessage","postMessage","sortIndex","startTime","priorityLevel","unstable_wrapCallback","unstable_continueExecution","unstable_pauseExecution","unstable_getFirstCallbackNode","unstable_Profiling","Axios","mergeConfig","createInstance","defaultConfig","axios","instanceConfig","CancelToken","isCancel","all","promises","spread","InterceptorManager","dispatchRequest","interceptors","chain","interceptor","fulfilled","rejected","getUri","use","eject","transformData","throwIfCancellationRequested","throwIfRequested","reason","fns","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","draining","queueIndex","cleanUpNextTick","drainQueue","len","run","runClearTimeout","Item","array","nextTick","title","browser","env","argv","versions","addListener","once","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","binding","cwd","chdir","dir","umask","normalizedName","isAxiosError","toJSON","description","columnNumber","isAbsoluteURL","combineURLs","requestedURL","relativeURL","ignoreDuplicateOf","parsed","line","originURL","msie","urlParsingNode","resolveURL","protocol","host","hostname","port","requestURL","write","expires","domain","secure","cookie","toGMTString","decodeURIComponent","remove","executor","resolvePromise","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","propName","componentName","propFullName","secret","getShim","ReactPropTypes","bool","symbol","any","arrayOf","instanceOf","objectOf","oneOf","oneOfType","checkPropTypes","typeOf","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","Lazy","Portal","isValidElementType","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isPortal","isProfiler","isStrictMode","isSuspense","Function","defaultVariantMapping","Typography","_props$align","align","_props$display","_props$gutterBottom","gutterBottom","_props$noWrap","noWrap","_props$paragraph","paragraph","_props$variant","variant","_props$variantMapping","variantMapping","srOnly","alignLeft","textAlign","alignCenter","alignRight","alignJustify","textOverflow","whiteSpace","marginBottom","colorInherit","colorTextPrimary","colorTextSecondary","displayInline","displayBlock","_props$edge","edge","_props$disableFocusRi","disableFocusRipple","_props$size","small","edgeStart","edgeEnd","label","marginLeft","marginRight","sizeSmall","isBrowser","plainObjectConstrurctor","cloneStyle","newStyle","createRule","decl","jss","declCopy","rule","plugins","onCreateRule","by","toCssValue","ignoreImportant","cssValue","indentStr","indent","toCss","selector","_options$indent","fallbacks","_prop","_value","_prop2","_value2","allowEmpty","escapeRegex","nativeEscape","CSS","BaseStyleRule","isProcessed","renderer","renderable","sheet","Renderer","force","onChangeValue","isEmpty","isDefined","removeProperty","attached","StyleRule","_BaseStyleRule","selectorText","scoped","generateId","applyTo","json","setSelector","replaceRule","pluginStyleRule","parent","defaultToStringOptions","atRegExp","ConditionalRule","at","query","rules","atMatch","RuleList","getRule","addRule","onProcessRule","keyRegExp","pluginConditionalRule","defaultToStringOptions$1","nameRegExp","KeyframesRule","frames","nameMatch","keyRegExp$1","refRegExp","findReferencedKeyframe","keyframes","replaceRef","refKeyframe","plugin","onProcessStyle","KeyframeRule","pluginKeyframeRule","FontFaceRule","pluginFontFaceRule","ViewportRule","pluginViewportRule","SimpleRule","keysMap","defaultUpdateOptions","forceUpdateOptions","raw","counter","ruleOptions","_this$options","register","unregister","plugins$$1","update","updateOne","_this$options2","styleRule","nextValue","_nextValue","_prevValue","css","StyleSheet","deployed","attach","deploy","detach","insertRule","addRules","added","deleteRule","_this$rules","PluginsRegistry","internal","external","registry","onProcessSheet","processedValue","newPlugin","sheets","SheetsRegistry","reset","_temp","globalThis","ns","moduleId","createGenerateId","ruleCounter","jssId","minify","memoize","getPropertyValue","cssRule","attributeStyleMap","getHead","findPrevNode","insertionPoint","findHigherSheet","findHighestSheet","comment","head","childNodes","findCommentNode","getNonce","_insertRule","maxIndex","cssRules","appendRule","DomRenderer","hasInsertedRules","media","el","createStyle","nonce","nextNode","insertionPointElement","insertStyle","insertRules","nativeParent","latestNativeParent","parentStyleSheet","ruleStr","nativeRule","getRules","instanceCounter","Jss","isInBrowser","setup","createStyleSheet","removeStyleSheet","hasCSSTOMSupport","multiKeyStore","key1","key2","subCache","pseudoClasses","fnValuesNs","fnRuleNs","functionPlugin","fnValues","fnRule","GlobalContainerRule","GlobalPrefixedRule","separatorRegExp","addScope","scope","jssGlobal","handleNestedGlobalContainerRule","handlePrefixedGlobalRule","parentRegExp","jssNested","getReplaceRef","replaceParentRefs","nestedProp","parentProp","parentSelectors","nestedSelectors","nested","getOptions","prevOptions","nestingLevel","isNested","isNestedConditional","uppercasePattern","msPattern","toHyphenLower","hyphenateStyleName","hName","convertCase","converted","hyphenate","camelCase","hyphenatedProp","px","ms","percent","addCamelCasedVersion","regExp","newObj","units","motion","perspective","grid","iterate","innerProp","_innerProp","defaultUnit","camelCasedOptions","js","vendor","isTouch","jsCssMap","Moz","Webkit","appearence","noPrefill","supportedProperty","colorAdjust","toUpper","camelize","pascalize","mask","textOrientation","writingMode","breakPropsOld","inlineLogicalOld","newProp","unprefixed","prefixed","pascalized","scrollSnap","overscrollBehavior","propMap","flex2012","propMap$1","propKeys","prefixCss","propertyDetectors","computed","key$1","el$1","cache$1","transitionProperties","transPropsRegExp","prefixTransitionCallback","p1","p2","prefixedValue","supportedValue","jssVendorPrefixer","prefixStyle","changeProp","supportedProp","changeValue","supportedValue$$1","atRule","jssPropsSort","sort","prop0","prop1","jssPreset","functions","vendorPrefixer","propsSort","defaultOptions","disableGeneration","generateClassName","_options$disableGloba","disableGlobal","_options$productionPr","productionPrefix","_options$seed","seed","seedPrefix","styleSheet","createGenerateClassName","sheetsCache","sheetsManager","sheetsRegistry","StylesContext","StylesProvider","indexCounter","increment","getStylesCreator","themingEnabled","stylesWithOverrides","noopTheme","getClasses","cacheClasses","lastProp","lastJSS","generate","mergeClasses","baseClasses","newClasses","_ref2","stylesCreator","sheetManager","staticSheet","dynamicStyles","serverGenerateClassName","getDynamicStyles","extracted","dynamicSheet","_ref3","_ref4","useSynchronousEffect","currentKey","classNamePrefixOption","_options$defaultTheme","stylesOptions2","shouldUpdate","FormControlLabel","control","_props$labelPlacement","labelPlacement","controlProps","labelPlacementStart","flexDirection","labelPlacementTop","labelPlacementBottom","nextClasses","Switch","thumb","switchBase","makeStylesWithoutDefault","Paper","_props$square","square","_props$elevation","elevation","outlined","rounded","elevations","shadow","SPACINGS","GRID_SIZES","getOffset","div","Grid","_props$alignContent","alignContent","_props$alignItems","_props$container","_props$direction","_props$item","_props$justify","justify","_props$lg","_props$md","_props$sm","_props$spacing","_props$wrap","wrap","_props$xl","_props$xs","_props$zeroMinWidth","zeroMinWidth","StyledGrid","flexWrap","breakpoint","themeSpacing","generateGutter","accumulator","globalStyles","flexBasis","maxWidth","generateGrid","Input","disableUnderline","underline","bottomLineColor","marginTop","borderBottomColor","borderBottom","content","borderBottomStyle","FilledInput","borderTopLeftRadius","borderTopRightRadius","paddingBottom","WebkitBoxShadow","WebkitTextFillColor","Button","_props$disableElevati","disableElevation","endIconProp","endIcon","startIconProp","startIcon","textPrimary","textSecondary","outlinedPrimary","outlinedSecondary","contained","containedPrimary","containedSecondary","borderColor","textSizeSmall","textSizeLarge","outlinedSizeSmall","outlinedSizeLarge","containedSizeSmall","containedSizeLarge","sizeLarge","iconSizeSmall","iconSizeMedium","iconSizeLarge","ThemeProvider","localTheme","outerTheme","mergeOuterLocalTheme","ownerWindow","_props$disablePortal","disablePortal","onRendered","mountNode","setMountNode","getContainer","getScrollbarSize","scrollDiv","scrollbarSize","offsetWidth","ariaHidden","show","getPaddingRight","ariaHiddenSiblings","currentNode","nodesToExclude","blacklistTagNames","findIndexOf","idx","some","handleContainer","fixedNodes","restoreStyle","restorePaddings","disableScrollLock","innerWidth","isOverflowing","parentElement","scrollContainer","ModalManager","_classCallCheck","modals","containers","modalIndex","modalRef","hiddenSiblingNodes","hiddenSiblings","getHiddenSiblings","containerIndex","restore","nextTop","TrapFocus","_props$disableAutoFoc","disableAutoFocus","_props$disableEnforce","disableEnforceFocus","_props$disableRestore","disableRestoreFocus","getDoc","isEnabled","ignoreNextEnforceFocus","sentinelStart","sentinelEnd","nodeToRestore","rootRef","contain","loopFocus","interval","setInterval","clearInterval","touchAction","invisible","SimpleBackdrop","_props$invisible","defaultManager","Modal","inProps","_props$BackdropCompon","BackdropComponent","BackdropProps","_props$closeAfterTran","closeAfterTransition","_props$disableBackdro","disableBackdropClick","_props$disableEscapeK","disableEscapeKeyDown","_props$disableScrollL","_props$hideBackdrop","hideBackdrop","_props$keepMounted","keepMounted","_props$manager","manager","onBackdropClick","onClose","onEscapeKeyDown","exited","setExited","mountNodeRef","hasTransition","getHasTransition","getModal","handleMounted","mount","handleOpen","resolvedContainer","isTopModal","handlePortalRef","handleClose","inlineStyle","childProps","onEnter","Transition","initialStatus","appearStatus","unmountOnExit","mountOnEnter","nextCallback","updateStatus","prevProps","nextStatus","cancelNextCallback","getTimeouts","mounting","performEnter","performExit","appearing","timeouts","enterTimeout","safeSetState","onEntered","onEntering","onTransitionEnd","_this3","onExit","onExiting","setNextCallback","_this4","doesNotHaveTimeoutOrListener","addEndListener","UNMOUNTED","EXITED","ENTERING","ENTERED","EXITING","getTransitionProps","_props$style","transitionDuration","transitionDelay","getScale","entering","entered","Grow","_props$timeout","timer","autoTimeout","isAppearing","reflow","_getTransitionProps","_getTransitionProps2","_","muiSupportAuto","getOffsetTop","vertical","getOffsetLeft","horizontal","getTransformOriginValue","transformOrigin","getAnchorEl","anchorEl","Popover","_props$anchorOrigin","anchorOrigin","anchorPosition","_props$anchorReferenc","anchorReference","containerProp","getContentAnchorEl","_props$marginThreshol","marginThreshold","_props$PaperProps","PaperProps","_props$transformOrigi","_props$TransitionComp","TransitionComponent","_props$transitionDura","transitionDurationProp","_props$TransitionProp","TransitionProps","paperRef","getAnchorOffset","contentAnchorOffset","resolvedAnchorEl","anchorRect","anchorVertical","getContentAnchorOffset","contentAnchorEl","getScrollParent","offsetTop","getTransformOrigin","elemRect","getPositioningStyle","offsetHeight","elemTransformOrigin","containerWindow","heightThreshold","widthThreshold","diff","_diff","_diff2","_diff3","setPositioningStyles","positioning","handlePaperRef","updatePosition","overflowY","overflowX","maxHeight","List","_props$dense","_props$disablePadding","disablePadding","subheader","listStyle","nextItem","disableListWrap","nextElementSibling","previousItem","previousElementSibling","textCriteriaMatches","nextFocus","textCriteria","innerText","repeating","moveFocus","currentFocus","traversalFunction","wrappedOnce","MenuList","actions","_props$autoFocus","_props$autoFocusItem","autoFocusItem","_props$disableListWra","listRef","textCriteriaRef","previousKeyMatched","lastTime","adjustStyleForScrollbar","containerElement","noExplicitWidth","activeItemIndex","items","newChildProps","criteria","lowerKey","currTime","keepFocusOnCurrent","RTL_ORIGIN","LTR_ORIGIN","disableAutoFocusItem","_props$MenuListProps","MenuListProps","PopoverClasses","menuListActionsRef","contentAnchorRef","WebkitOverflowScrolling","areEqualValues","SelectInput","autoWidth","displayEmpty","IconComponent","labelId","_props$MenuProps","MenuProps","onOpen","openProp","renderValue","_props$SelectDisplayP","SelectDisplayProps","tabIndexProp","valueState","setValueState","_React$useState2","displayNode","setDisplayNode","isOpenControlled","_React$useState3","menuMinWidthState","setMenuMinWidthState","_React$useState4","openState","setOpenState","displaySingle","handleItemClick","itemIndex","displayMultiple","computeDisplay","menuMinWidth","buttonId","selectMenu","iconOpen","NativeSelectInput","filled","iconFilled","iconOutlined","defaultInput","NativeSelect","_props$IconComponent","ArrowDropDownIcon","_props$input","nativeSelectStyles","Select","_props$autoWidth","_props$displayEmpty","_props$labelWidth","labelWidth","_props$multiple","_props$native","native","variantProps","OutlinedInput","FormLabel","InputLabel","_props$disableAnimati","disableAnimation","shrinkProp","shrink","animated","FormControl","_props$error","_props$hiddenLabel","_props$margin","_props$required","initialAdornedStart","initialFilled","setFilled","childContext","registerEffect","marginNormal","FormHelperText","variantComponent","TextField","FormHelperTextProps","helperText","InputLabelProps","InputProps","_props$select","SelectProps","setLabelWidth","labelRef","labelNode","InputMore","notched","helperTextId","inputLabelId","InputElement","htmlFor","layer","RadioButtonUncheckedIcon","RadioButtonCheckedIcon","defaultCheckedIcon","RadioButtonIcon","defaultIcon","Radio","nameProp","onChangeProp","radioGroup","CheckBoxIcon","CheckBoxOutlineBlankIcon","defaultIndeterminateIcon","IndeterminateCheckBoxIcon","Checkbox","_props$checkedIcon","_props$icon","_props$indeterminate","indeterminate","_props$indeterminateI","indeterminateIcon","NotchedOutline","labelWidthProp","legend","borderWidth","notchedOutline","ListItem","_props$button","childrenProp","componentProp","_props$ContainerCompo","ContainerComponent","_props$ContainerProps","ContainerProps","ContainerClassName","_props$disableGutters","disableGutters","_props$divider","_props$selected","listItemRef","hasSecondaryAction","componentProps","alignItemsFlexStart","secondaryAction","backgroundClip","MenuItem","_props$role","FormGroup","_props$row","row","RadioGroup"],"mappings":"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AAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,GAAI,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,GAAI,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,GAAI,IAAK,EAAG,EAAG,GAAI,GAA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","file":"static/js/2.6a72c269.chunk.js","sourcesContent":["'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","export default function _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n\n return target;\n}","function toVal(mix) {\n\tvar k, y, str='';\n\tif (mix) {\n\t\tif (typeof mix === 'object') {\n\t\t\tif (!!mix.push) {\n\t\t\t\tfor (k=0; k < mix.length; k++) {\n\t\t\t\t\tif (mix[k] && (y = toVal(mix[k]))) {\n\t\t\t\t\t\tstr && (str += ' ');\n\t\t\t\t\t\tstr += y;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor (k in mix) {\n\t\t\t\t\tif (mix[k] && (y = toVal(k))) {\n\t\t\t\t\t\tstr && (str += ' ');\n\t\t\t\t\t\tstr += y;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (typeof mix !== 'boolean' && !mix.call) {\n\t\t\tstr && (str += ' ');\n\t\t\tstr += mix;\n\t\t}\n\t}\n\treturn str;\n}\n\nexport default function () {\n\tvar i=0, x, str='';\n\twhile (i < arguments.length) {\n\t\tif (x = toVal(arguments[i++])) {\n\t\t\tstr && (str += ' ');\n\t\t\tstr += x\n\t\t}\n\t}\n\treturn str;\n}\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport hoistNonReactStatics from 'hoist-non-react-statics';\nimport { chainPropTypes, getDisplayName } from '@material-ui/utils';\nimport makeStyles from '../makeStyles';\nimport getThemeProps from '../getThemeProps';\nimport useTheme from '../useTheme'; // Link a style sheet with a component.\n// It does not modify the component passed to it;\n// instead, it returns a new component, with a `classes` property.\n\nvar withStyles = function withStyles(stylesOrCreator) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return function (Component) {\n var defaultTheme = options.defaultTheme,\n _options$withTheme = options.withTheme,\n withTheme = _options$withTheme === void 0 ? false : _options$withTheme,\n name = options.name,\n stylesOptions = _objectWithoutProperties(options, [\"defaultTheme\", \"withTheme\", \"name\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (Component === undefined) {\n throw new Error(['You are calling withStyles(styles)(Component) with an undefined component.', 'You may have forgotten to import it.'].join('\\n'));\n }\n }\n\n var classNamePrefix = name;\n\n if (process.env.NODE_ENV !== 'production') {\n if (!name) {\n // Provide a better DX outside production.\n var displayName = getDisplayName(Component);\n\n if (displayName !== undefined) {\n classNamePrefix = displayName;\n }\n }\n }\n\n var useStyles = makeStyles(stylesOrCreator, _extends({\n defaultTheme: defaultTheme,\n Component: Component,\n name: name || Component.displayName,\n classNamePrefix: classNamePrefix\n }, stylesOptions));\n var WithStyles = React.forwardRef(function WithStyles(props, ref) {\n var classesProp = props.classes,\n innerRef = props.innerRef,\n other = _objectWithoutProperties(props, [\"classes\", \"innerRef\"]);\n\n var classes = useStyles(props);\n var theme;\n var more = other;\n\n if (typeof name === 'string' || withTheme) {\n // name and withTheme are invariant in the outer scope\n // eslint-disable-next-line react-hooks/rules-of-hooks\n theme = useTheme() || defaultTheme;\n\n if (name) {\n more = getThemeProps({\n theme: theme,\n name: name,\n props: other\n });\n } // Provide the theme to the wrapped component.\n // So we don't have to use the `withTheme()` Higher-order Component.\n\n\n if (withTheme && !more.theme) {\n more.theme = theme;\n }\n }\n\n return React.createElement(Component, _extends({\n ref: innerRef || ref,\n classes: classes\n }, more));\n });\n process.env.NODE_ENV !== \"production\" ? WithStyles.propTypes = {\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n\n /**\n * Use that prop to pass a ref to the decorated component.\n * @deprecated\n */\n innerRef: chainPropTypes(PropTypes.oneOfType([PropTypes.func, PropTypes.object]), function (props) {\n if (props.innerRef == null) {\n return null;\n }\n\n return null; // return new Error(\n // 'Material-UI: the `innerRef` prop is deprecated and will be removed in v5. ' +\n // 'Refs are now automatically forwarded to the inner component.',\n // );\n })\n } : void 0; // The wrapper receives only user supplied props, which could be a subset of\n // the actual props Component might receive due to merging with defaultProps.\n // So copying it here would give us the same result in the wrapper as well.\n\n WithStyles.defaultProps = Component.defaultProps;\n\n if (process.env.NODE_ENV !== 'production') {\n WithStyles.displayName = \"WithStyles(\".concat(getDisplayName(Component), \")\");\n }\n\n hoistNonReactStatics(WithStyles, Component);\n\n if (process.env.NODE_ENV !== 'production') {\n // Exposed for test purposes.\n WithStyles.Naked = Component;\n WithStyles.options = options;\n WithStyles.useStyles = useStyles;\n }\n\n return WithStyles;\n };\n};\n\nexport default withStyles;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { withStyles as withStylesWithoutDefault } from '@material-ui/styles';\nimport defaultTheme from './defaultTheme';\n\nfunction withStyles(stylesOrCreator, options) {\n return withStylesWithoutDefault(stylesOrCreator, _extends({\n defaultTheme: defaultTheme\n }, options));\n}\n\nexport default withStyles;","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","// It should to be noted that this function isn't equivalent to `text-transform: capitalize`.\n//\n// A strict capitalization should uppercase the first letter of each word a the sentence.\n// We only handle the first word.\nexport default function capitalize(string) {\n if (process.env.NODE_ENV !== 'production') {\n if (typeof string !== 'string') {\n throw new Error('Material-UI: capitalize(string) expects a string argument.');\n }\n }\n\n return string.charAt(0).toUpperCase() + string.slice(1);\n}","import React from 'react';\nimport setRef from './setRef';\nexport default function useForkRef(refA, refB) {\n /**\n * This will create a new function if the ref props change and are defined.\n * This means react will call the old forkRef with `null` and the new forkRef\n * with the ref. Cleanup naturally emerges from this behavior\n */\n return React.useMemo(function () {\n if (refA == null && refB == null) {\n return null;\n }\n\n return function (refValue) {\n setRef(refA, refValue);\n setRef(refB, refValue);\n };\n }, [refA, refB]);\n}","'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n","/* eslint-disable no-use-before-define */\n\n/**\n * Returns a number whose value is limited to the given range.\n *\n * @param {number} value The value to be clamped\n * @param {number} min The lower boundary of the output range\n * @param {number} max The upper boundary of the output range\n * @returns {number} A number in the range [min, max]\n */\nfunction clamp(value) {\n var min = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n var max = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;\n\n if (process.env.NODE_ENV !== 'production') {\n if (value < min || value > max) {\n console.error(\"Material-UI: the value provided \".concat(value, \" is out of range [\").concat(min, \", \").concat(max, \"].\"));\n }\n }\n\n return Math.min(Math.max(min, value), max);\n}\n/**\n * Converts a color from CSS hex format to CSS rgb format.\n *\n * @param {string} color - Hex color, i.e. #nnn or #nnnnnn\n * @returns {string} A CSS rgb color string\n */\n\n\nexport function hexToRgb(color) {\n color = color.substr(1);\n var re = new RegExp(\".{1,\".concat(color.length / 3, \"}\"), 'g');\n var colors = color.match(re);\n\n if (colors && colors[0].length === 1) {\n colors = colors.map(function (n) {\n return n + n;\n });\n }\n\n return colors ? \"rgb(\".concat(colors.map(function (n) {\n return parseInt(n, 16);\n }).join(', '), \")\") : '';\n}\n\nfunction intToHex(int) {\n var hex = int.toString(16);\n return hex.length === 1 ? \"0\".concat(hex) : hex;\n}\n/**\n * Converts a color from CSS rgb format to CSS hex format.\n *\n * @param {string} color - RGB color, i.e. rgb(n, n, n)\n * @returns {string} A CSS rgb color string, i.e. #nnnnnn\n */\n\n\nexport function rgbToHex(color) {\n // Idempotent\n if (color.indexOf('#') === 0) {\n return color;\n }\n\n var _decomposeColor = decomposeColor(color),\n values = _decomposeColor.values;\n\n return \"#\".concat(values.map(function (n) {\n return intToHex(n);\n }).join(''));\n}\n/**\n * Converts a color from hsl format to rgb format.\n *\n * @param {string} color - HSL color values\n * @returns {string} rgb color values\n */\n\nexport function hslToRgb(color) {\n color = decomposeColor(color);\n var _color = color,\n values = _color.values;\n var h = values[0];\n var s = values[1] / 100;\n var l = values[2] / 100;\n var a = s * Math.min(l, 1 - l);\n\n var f = function f(n) {\n var k = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (n + h / 30) % 12;\n return l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n };\n\n var type = 'rgb';\n var rgb = [Math.round(f(0) * 255), Math.round(f(8) * 255), Math.round(f(4) * 255)];\n\n if (color.type === 'hsla') {\n type += 'a';\n rgb.push(values[3]);\n }\n\n return recomposeColor({\n type: type,\n values: rgb\n });\n}\n/**\n * Returns an object with the type and values of a color.\n *\n * Note: Does not support rgb % values.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {object} - A MUI color object: {type: string, values: number[]}\n */\n\nexport function decomposeColor(color) {\n // Idempotent\n if (color.type) {\n return color;\n }\n\n if (color.charAt(0) === '#') {\n return decomposeColor(hexToRgb(color));\n }\n\n var marker = color.indexOf('(');\n var type = color.substring(0, marker);\n\n if (['rgb', 'rgba', 'hsl', 'hsla'].indexOf(type) === -1) {\n throw new Error([\"Material-UI: unsupported `\".concat(color, \"` color.\"), 'We support the following formats: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla().'].join('\\n'));\n }\n\n var values = color.substring(marker + 1, color.length - 1).split(',');\n values = values.map(function (value) {\n return parseFloat(value);\n });\n return {\n type: type,\n values: values\n };\n}\n/**\n * Converts a color object with type and values to a string.\n *\n * @param {object} color - Decomposed color\n * @param {string} color.type - One of: 'rgb', 'rgba', 'hsl', 'hsla'\n * @param {array} color.values - [n,n,n] or [n,n,n,n]\n * @returns {string} A CSS color string\n */\n\nexport function recomposeColor(color) {\n var type = color.type;\n var values = color.values;\n\n if (type.indexOf('rgb') !== -1) {\n // Only convert the first 3 values to int (i.e. not alpha)\n values = values.map(function (n, i) {\n return i < 3 ? parseInt(n, 10) : n;\n });\n } else if (type.indexOf('hsl') !== -1) {\n values[1] = \"\".concat(values[1], \"%\");\n values[2] = \"\".concat(values[2], \"%\");\n }\n\n return \"\".concat(type, \"(\").concat(values.join(', '), \")\");\n}\n/**\n * Calculates the contrast ratio between two colors.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n *\n * @param {string} foreground - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {string} background - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {number} A contrast ratio value in the range 0 - 21.\n */\n\nexport function getContrastRatio(foreground, background) {\n var lumA = getLuminance(foreground);\n var lumB = getLuminance(background);\n return (Math.max(lumA, lumB) + 0.05) / (Math.min(lumA, lumB) + 0.05);\n}\n/**\n * The relative brightness of any point in a color space,\n * normalized to 0 for darkest black and 1 for lightest white.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {number} The relative brightness of the color in the range 0 - 1\n */\n\nexport function getLuminance(color) {\n color = decomposeColor(color);\n var rgb = color.type === 'hsl' ? decomposeColor(hslToRgb(color)).values : color.values;\n rgb = rgb.map(function (val) {\n val /= 255; // normalized\n\n return val <= 0.03928 ? val / 12.92 : Math.pow((val + 0.055) / 1.055, 2.4);\n }); // Truncate at 3 digits\n\n return Number((0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2]).toFixed(3));\n}\n/**\n * Darken or lighten a color, depending on its luminance.\n * Light colors are darkened, dark colors are lightened.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} coefficient=0.15 - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function emphasize(color) {\n var coefficient = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0.15;\n return getLuminance(color) > 0.5 ? darken(color, coefficient) : lighten(color, coefficient);\n}\n/**\n * Set the absolute transparency of a color.\n * Any existing alpha values are overwritten.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} value - value to set the alpha channel to in the range 0 -1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function fade(color, value) {\n color = decomposeColor(color);\n value = clamp(value);\n\n if (color.type === 'rgb' || color.type === 'hsl') {\n color.type += 'a';\n }\n\n color.values[3] = value;\n return recomposeColor(color);\n}\n/**\n * Darkens a color.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function darken(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clamp(coefficient);\n\n if (color.type.indexOf('hsl') !== -1) {\n color.values[2] *= 1 - coefficient;\n } else if (color.type.indexOf('rgb') !== -1) {\n for (var i = 0; i < 3; i += 1) {\n color.values[i] *= 1 - coefficient;\n }\n }\n\n return recomposeColor(color);\n}\n/**\n * Lightens a color.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function lighten(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clamp(coefficient);\n\n if (color.type.indexOf('hsl') !== -1) {\n color.values[2] += (100 - color.values[2]) * coefficient;\n } else if (color.type.indexOf('rgb') !== -1) {\n for (var i = 0; i < 3; i += 1) {\n color.values[i] += (255 - color.values[i]) * coefficient;\n }\n }\n\n return recomposeColor(color);\n}","import arrayWithoutHoles from \"./arrayWithoutHoles\";\nimport iterableToArray from \"./iterableToArray\";\nimport nonIterableSpread from \"./nonIterableSpread\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();\n}","export default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) {\n for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n }\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}","export default function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M16 9v10H8V9h8m-1.5-6h-5l-1 1H5v2h14V4h-3.5l-1-1zM18 7H6v12c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7z\"\n}), 'DeleteOutlined');\n\nexports.default = _default;","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","'use strict';\n\nvar bind = require('./helpers/bind');\n\n/*global toString:true*/\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n return (typeof FormData !== 'undefined') && (val instanceof FormData);\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n var result;\n if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n result = ArrayBuffer.isView(val);\n } else {\n result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n return str.replace(/^\\s*/, '').replace(/\\s*$/, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n * typeof window -> undefined\n * typeof document -> undefined\n *\n * react-native:\n * navigator.product -> 'ReactNative'\n * nativescript\n * navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||\n navigator.product === 'NativeScript' ||\n navigator.product === 'NS')) {\n return false;\n }\n return (\n typeof window !== 'undefined' &&\n typeof document !== 'undefined'\n );\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\n\n // Force an array if not already something iterable\n if (typeof obj !== 'object') {\n /*eslint no-param-reassign:0*/\n obj = [obj];\n }\n\n if (isArray(obj)) {\n // Iterate over array values\n for (var i = 0, l = obj.length; i < l; i++) {\n fn.call(null, obj[i], i, obj);\n }\n } else {\n // Iterate over object keys\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n fn.call(null, obj[key], key, obj);\n }\n }\n }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n var result = {};\n function assignValue(val, key) {\n if (typeof result[key] === 'object' && typeof val === 'object') {\n result[key] = merge(result[key], val);\n } else {\n result[key] = val;\n }\n }\n\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Function equal to merge with the difference being that no reference\n * to original objects is kept.\n *\n * @see merge\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction deepMerge(/* obj1, obj2, obj3, ... */) {\n var result = {};\n function assignValue(val, key) {\n if (typeof result[key] === 'object' && typeof val === 'object') {\n result[key] = deepMerge(result[key], val);\n } else if (typeof val === 'object') {\n result[key] = deepMerge({}, val);\n } else {\n result[key] = val;\n }\n }\n\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n forEach(b, function assignValue(val, key) {\n if (thisArg && typeof val === 'function') {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n });\n return a;\n}\n\nmodule.exports = {\n isArray: isArray,\n isArrayBuffer: isArrayBuffer,\n isBuffer: isBuffer,\n isFormData: isFormData,\n isArrayBufferView: isArrayBufferView,\n isString: isString,\n isNumber: isNumber,\n isObject: isObject,\n isUndefined: isUndefined,\n isDate: isDate,\n isFile: isFile,\n isBlob: isBlob,\n isFunction: isFunction,\n isStream: isStream,\n isURLSearchParams: isURLSearchParams,\n isStandardBrowserEnv: isStandardBrowserEnv,\n forEach: forEach,\n merge: merge,\n deepMerge: deepMerge,\n extend: extend,\n trim: trim\n};\n","import React from 'react';\nimport FormControlContext from './FormControlContext';\nexport default function useFormControl() {\n return React.useContext(FormControlContext);\n}","var isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n throw new Error(prefix + \": \" + (message || ''));\n}\n\nexport default invariant;\n","export default function formControlState(_ref) {\n var props = _ref.props,\n states = _ref.states,\n muiFormControl = _ref.muiFormControl;\n return states.reduce(function (acc, state) {\n acc[state] = props[state];\n\n if (muiFormControl) {\n if (typeof props[state] === 'undefined') {\n acc[state] = muiFormControl[state];\n }\n }\n\n return acc;\n }, {});\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport SvgIcon from '../../SvgIcon';\nexport default function createSvgIcon(path, displayName) {\n var Component = React.memo(React.forwardRef(function (props, ref) {\n return React.createElement(SvgIcon, _extends({}, props, {\n ref: ref\n }), path);\n }));\n\n if (process.env.NODE_ENV !== 'production') {\n Component.displayName = \"\".concat(displayName, \"Icon\");\n }\n\n Component.muiName = SvgIcon.muiName;\n return Component;\n}","function isAbsolute(pathname) {\n return pathname.charAt(0) === '/';\n}\n\n// About 1.5x faster than the two-arg version of Array#splice()\nfunction spliceOne(list, index) {\n for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) {\n list[i] = list[k];\n }\n\n list.pop();\n}\n\n// This implementation is based heavily on node's url.parse\nfunction resolvePathname(to, from) {\n if (from === undefined) from = '';\n\n var toParts = (to && to.split('/')) || [];\n var fromParts = (from && from.split('/')) || [];\n\n var isToAbs = to && isAbsolute(to);\n var isFromAbs = from && isAbsolute(from);\n var mustEndAbs = isToAbs || isFromAbs;\n\n if (to && isAbsolute(to)) {\n // to is absolute\n fromParts = toParts;\n } else if (toParts.length) {\n // to is relative, drop the filename\n fromParts.pop();\n fromParts = fromParts.concat(toParts);\n }\n\n if (!fromParts.length) return '/';\n\n var hasTrailingSlash;\n if (fromParts.length) {\n var last = fromParts[fromParts.length - 1];\n hasTrailingSlash = last === '.' || last === '..' || last === '';\n } else {\n hasTrailingSlash = false;\n }\n\n var up = 0;\n for (var i = fromParts.length; i >= 0; i--) {\n var part = fromParts[i];\n\n if (part === '.') {\n spliceOne(fromParts, i);\n } else if (part === '..') {\n spliceOne(fromParts, i);\n up++;\n } else if (up) {\n spliceOne(fromParts, i);\n up--;\n }\n }\n\n if (!mustEndAbs) for (; up--; up) fromParts.unshift('..');\n\n if (\n mustEndAbs &&\n fromParts[0] !== '' &&\n (!fromParts[0] || !isAbsolute(fromParts[0]))\n )\n fromParts.unshift('');\n\n var result = fromParts.join('/');\n\n if (hasTrailingSlash && result.substr(-1) !== '/') result += '/';\n\n return result;\n}\n\nexport default resolvePathname;\n","function valueOf(obj) {\n return obj.valueOf ? obj.valueOf() : Object.prototype.valueOf.call(obj);\n}\n\nfunction valueEqual(a, b) {\n // Test for strict equality first.\n if (a === b) return true;\n\n // Otherwise, if either of them == null they are not equal.\n if (a == null || b == null) return false;\n\n if (Array.isArray(a)) {\n return (\n Array.isArray(b) &&\n a.length === b.length &&\n a.every(function(item, index) {\n return valueEqual(item, b[index]);\n })\n );\n }\n\n if (typeof a === 'object' || typeof b === 'object') {\n var aValue = valueOf(a);\n var bValue = valueOf(b);\n\n if (aValue !== a || bValue !== b) return valueEqual(aValue, bValue);\n\n return Object.keys(Object.assign({}, a, b)).every(function(key) {\n return valueEqual(a[key], b[key]);\n });\n }\n\n return false;\n}\n\nexport default valueEqual;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport resolvePathname from 'resolve-pathname';\nimport valueEqual from 'value-equal';\nimport warning from 'tiny-warning';\nimport invariant from 'tiny-invariant';\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === '/' ? path : '/' + path;\n}\nfunction stripLeadingSlash(path) {\n return path.charAt(0) === '/' ? path.substr(1) : path;\n}\nfunction hasBasename(path, prefix) {\n return path.toLowerCase().indexOf(prefix.toLowerCase()) === 0 && '/?#'.indexOf(path.charAt(prefix.length)) !== -1;\n}\nfunction stripBasename(path, prefix) {\n return hasBasename(path, prefix) ? path.substr(prefix.length) : path;\n}\nfunction stripTrailingSlash(path) {\n return path.charAt(path.length - 1) === '/' ? path.slice(0, -1) : path;\n}\nfunction parsePath(path) {\n var pathname = path || '/';\n var search = '';\n var hash = '';\n var hashIndex = pathname.indexOf('#');\n\n if (hashIndex !== -1) {\n hash = pathname.substr(hashIndex);\n pathname = pathname.substr(0, hashIndex);\n }\n\n var searchIndex = pathname.indexOf('?');\n\n if (searchIndex !== -1) {\n search = pathname.substr(searchIndex);\n pathname = pathname.substr(0, searchIndex);\n }\n\n return {\n pathname: pathname,\n search: search === '?' ? '' : search,\n hash: hash === '#' ? '' : hash\n };\n}\nfunction createPath(location) {\n var pathname = location.pathname,\n search = location.search,\n hash = location.hash;\n var path = pathname || '/';\n if (search && search !== '?') path += search.charAt(0) === '?' ? search : \"?\" + search;\n if (hash && hash !== '#') path += hash.charAt(0) === '#' ? hash : \"#\" + hash;\n return path;\n}\n\nfunction createLocation(path, state, key, currentLocation) {\n var location;\n\n if (typeof path === 'string') {\n // Two-arg form: push(path, state)\n location = parsePath(path);\n location.state = state;\n } else {\n // One-arg form: push(location)\n location = _extends({}, path);\n if (location.pathname === undefined) location.pathname = '';\n\n if (location.search) {\n if (location.search.charAt(0) !== '?') location.search = '?' + location.search;\n } else {\n location.search = '';\n }\n\n if (location.hash) {\n if (location.hash.charAt(0) !== '#') location.hash = '#' + location.hash;\n } else {\n location.hash = '';\n }\n\n if (state !== undefined && location.state === undefined) location.state = state;\n }\n\n try {\n location.pathname = decodeURI(location.pathname);\n } catch (e) {\n if (e instanceof URIError) {\n throw new URIError('Pathname \"' + location.pathname + '\" could not be decoded. ' + 'This is likely caused by an invalid percent-encoding.');\n } else {\n throw e;\n }\n }\n\n if (key) location.key = key;\n\n if (currentLocation) {\n // Resolve incomplete/relative pathname relative to current location.\n if (!location.pathname) {\n location.pathname = currentLocation.pathname;\n } else if (location.pathname.charAt(0) !== '/') {\n location.pathname = resolvePathname(location.pathname, currentLocation.pathname);\n }\n } else {\n // When there is no prior location and pathname is empty, set it to /\n if (!location.pathname) {\n location.pathname = '/';\n }\n }\n\n return location;\n}\nfunction locationsAreEqual(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash && a.key === b.key && valueEqual(a.state, b.state);\n}\n\nfunction createTransitionManager() {\n var prompt = null;\n\n function setPrompt(nextPrompt) {\n process.env.NODE_ENV !== \"production\" ? warning(prompt == null, 'A history supports only one prompt at a time') : void 0;\n prompt = nextPrompt;\n return function () {\n if (prompt === nextPrompt) prompt = null;\n };\n }\n\n function confirmTransitionTo(location, action, getUserConfirmation, callback) {\n // TODO: If another transition starts while we're still confirming\n // the previous one, we may end up in a weird state. Figure out the\n // best way to handle this.\n if (prompt != null) {\n var result = typeof prompt === 'function' ? prompt(location, action) : prompt;\n\n if (typeof result === 'string') {\n if (typeof getUserConfirmation === 'function') {\n getUserConfirmation(result, callback);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'A history needs a getUserConfirmation function in order to use a prompt message') : void 0;\n callback(true);\n }\n } else {\n // Return false from a transition hook to cancel the transition.\n callback(result !== false);\n }\n } else {\n callback(true);\n }\n }\n\n var listeners = [];\n\n function appendListener(fn) {\n var isActive = true;\n\n function listener() {\n if (isActive) fn.apply(void 0, arguments);\n }\n\n listeners.push(listener);\n return function () {\n isActive = false;\n listeners = listeners.filter(function (item) {\n return item !== listener;\n });\n };\n }\n\n function notifyListeners() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n listeners.forEach(function (listener) {\n return listener.apply(void 0, args);\n });\n }\n\n return {\n setPrompt: setPrompt,\n confirmTransitionTo: confirmTransitionTo,\n appendListener: appendListener,\n notifyListeners: notifyListeners\n };\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction getConfirmation(message, callback) {\n callback(window.confirm(message)); // eslint-disable-line no-alert\n}\n/**\n * Returns true if the HTML5 history API is supported. Taken from Modernizr.\n *\n * https://github.com/Modernizr/Modernizr/blob/master/LICENSE\n * https://github.com/Modernizr/Modernizr/blob/master/feature-detects/history.js\n * changed to avoid false negatives for Windows Phones: https://github.com/reactjs/react-router/issues/586\n */\n\nfunction supportsHistory() {\n var ua = window.navigator.userAgent;\n if ((ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) && ua.indexOf('Mobile Safari') !== -1 && ua.indexOf('Chrome') === -1 && ua.indexOf('Windows Phone') === -1) return false;\n return window.history && 'pushState' in window.history;\n}\n/**\n * Returns true if browser fires popstate on hash change.\n * IE10 and IE11 do not.\n */\n\nfunction supportsPopStateOnHashChange() {\n return window.navigator.userAgent.indexOf('Trident') === -1;\n}\n/**\n * Returns false if using go(n) with hash history causes a full page reload.\n */\n\nfunction supportsGoWithoutReloadUsingHash() {\n return window.navigator.userAgent.indexOf('Firefox') === -1;\n}\n/**\n * Returns true if a given popstate event is an extraneous WebKit event.\n * Accounts for the fact that Chrome on iOS fires real popstate events\n * containing undefined state when pressing the back button.\n */\n\nfunction isExtraneousPopstateEvent(event) {\n return event.state === undefined && navigator.userAgent.indexOf('CriOS') === -1;\n}\n\nvar PopStateEvent = 'popstate';\nvar HashChangeEvent = 'hashchange';\n\nfunction getHistoryState() {\n try {\n return window.history.state || {};\n } catch (e) {\n // IE 11 sometimes throws when accessing window.history.state\n // See https://github.com/ReactTraining/history/pull/289\n return {};\n }\n}\n/**\n * Creates a history object that uses the HTML5 history API including\n * pushState, replaceState, and the popstate event.\n */\n\n\nfunction createBrowserHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Browser history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canUseHistory = supportsHistory();\n var needsHashChangeListener = !supportsPopStateOnHashChange();\n var _props = props,\n _props$forceRefresh = _props.forceRefresh,\n forceRefresh = _props$forceRefresh === void 0 ? false : _props$forceRefresh,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n\n function getDOMLocation(historyState) {\n var _ref = historyState || {},\n key = _ref.key,\n state = _ref.state;\n\n var _window$location = window.location,\n pathname = _window$location.pathname,\n search = _window$location.search,\n hash = _window$location.hash;\n var path = pathname + search + hash;\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path, state, key);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function handlePopState(event) {\n // Ignore extraneous popstate events in WebKit.\n if (isExtraneousPopstateEvent(event)) return;\n handlePop(getDOMLocation(event.state));\n }\n\n function handleHashChange() {\n handlePop(getDOMLocation(getHistoryState()));\n }\n\n var forceNextPop = false;\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of keys we've seen in sessionStorage.\n // Instead, we just default to 0 for keys we don't know.\n\n var toIndex = allKeys.indexOf(toLocation.key);\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allKeys.indexOf(fromLocation.key);\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n }\n\n var initialLocation = getDOMLocation(getHistoryState());\n var allKeys = [initialLocation.key]; // Public interface\n\n function createHref(location) {\n return basename + createPath(location);\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.pushState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.href = href;\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n var nextKeys = allKeys.slice(0, prevIndex + 1);\n nextKeys.push(location.key);\n allKeys = nextKeys;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot push state in browsers that do not support HTML5 history') : void 0;\n window.location.href = href;\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.replaceState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.replace(href);\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n if (prevIndex !== -1) allKeys[prevIndex] = location.key;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot replace state in browsers that do not support HTML5 history') : void 0;\n window.location.replace(href);\n }\n });\n }\n\n function go(n) {\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.addEventListener(HashChangeEvent, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.removeEventListener(HashChangeEvent, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nvar HashChangeEvent$1 = 'hashchange';\nvar HashPathCoders = {\n hashbang: {\n encodePath: function encodePath(path) {\n return path.charAt(0) === '!' ? path : '!/' + stripLeadingSlash(path);\n },\n decodePath: function decodePath(path) {\n return path.charAt(0) === '!' ? path.substr(1) : path;\n }\n },\n noslash: {\n encodePath: stripLeadingSlash,\n decodePath: addLeadingSlash\n },\n slash: {\n encodePath: addLeadingSlash,\n decodePath: addLeadingSlash\n }\n};\n\nfunction stripHash(url) {\n var hashIndex = url.indexOf('#');\n return hashIndex === -1 ? url : url.slice(0, hashIndex);\n}\n\nfunction getHashPath() {\n // We can't use window.location.hash here because it's not\n // consistent across browsers - Firefox will pre-decode it!\n var href = window.location.href;\n var hashIndex = href.indexOf('#');\n return hashIndex === -1 ? '' : href.substring(hashIndex + 1);\n}\n\nfunction pushHashPath(path) {\n window.location.hash = path;\n}\n\nfunction replaceHashPath(path) {\n window.location.replace(stripHash(window.location.href) + '#' + path);\n}\n\nfunction createHashHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Hash history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canGoWithoutReload = supportsGoWithoutReloadUsingHash();\n var _props = props,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$hashType = _props.hashType,\n hashType = _props$hashType === void 0 ? 'slash' : _props$hashType;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n var _HashPathCoders$hashT = HashPathCoders[hashType],\n encodePath = _HashPathCoders$hashT.encodePath,\n decodePath = _HashPathCoders$hashT.decodePath;\n\n function getDOMLocation() {\n var path = decodePath(getHashPath());\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n var forceNextPop = false;\n var ignorePath = null;\n\n function locationsAreEqual$$1(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash;\n }\n\n function handleHashChange() {\n var path = getHashPath();\n var encodedPath = encodePath(path);\n\n if (path !== encodedPath) {\n // Ensure we always have a properly-encoded hash.\n replaceHashPath(encodedPath);\n } else {\n var location = getDOMLocation();\n var prevLocation = history.location;\n if (!forceNextPop && locationsAreEqual$$1(prevLocation, location)) return; // A hashchange doesn't always == location change.\n\n if (ignorePath === createPath(location)) return; // Ignore this change; we already setState in push/replace.\n\n ignorePath = null;\n handlePop(location);\n }\n }\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of paths we've seen in sessionStorage.\n // Instead, we just default to 0 for paths we don't know.\n\n var toIndex = allPaths.lastIndexOf(createPath(toLocation));\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allPaths.lastIndexOf(createPath(fromLocation));\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n } // Ensure the hash is encoded properly before doing anything else.\n\n\n var path = getHashPath();\n var encodedPath = encodePath(path);\n if (path !== encodedPath) replaceHashPath(encodedPath);\n var initialLocation = getDOMLocation();\n var allPaths = [createPath(initialLocation)]; // Public interface\n\n function createHref(location) {\n var baseTag = document.querySelector('base');\n var href = '';\n\n if (baseTag && baseTag.getAttribute('href')) {\n href = stripHash(window.location.href);\n }\n\n return href + '#' + encodePath(basename + createPath(location));\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot push state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a PUSH, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n pushHashPath(encodedPath);\n var prevIndex = allPaths.lastIndexOf(createPath(history.location));\n var nextPaths = allPaths.slice(0, prevIndex + 1);\n nextPaths.push(path);\n allPaths = nextPaths;\n setState({\n action: action,\n location: location\n });\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'Hash history cannot PUSH the same path; a new entry will not be added to the history stack') : void 0;\n setState();\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot replace state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a REPLACE, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n replaceHashPath(encodedPath);\n }\n\n var prevIndex = allPaths.indexOf(createPath(history.location));\n if (prevIndex !== -1) allPaths[prevIndex] = path;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n process.env.NODE_ENV !== \"production\" ? warning(canGoWithoutReload, 'Hash history go(n) causes a full page reload in this browser') : void 0;\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(HashChangeEvent$1, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(HashChangeEvent$1, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nfunction clamp(n, lowerBound, upperBound) {\n return Math.min(Math.max(n, lowerBound), upperBound);\n}\n/**\n * Creates a history object that stores locations in memory.\n */\n\n\nfunction createMemoryHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n var _props = props,\n getUserConfirmation = _props.getUserConfirmation,\n _props$initialEntries = _props.initialEntries,\n initialEntries = _props$initialEntries === void 0 ? ['/'] : _props$initialEntries,\n _props$initialIndex = _props.initialIndex,\n initialIndex = _props$initialIndex === void 0 ? 0 : _props$initialIndex,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = history.entries.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var index = clamp(initialIndex, 0, initialEntries.length - 1);\n var entries = initialEntries.map(function (entry) {\n return typeof entry === 'string' ? createLocation(entry, undefined, createKey()) : createLocation(entry, undefined, entry.key || createKey());\n }); // Public interface\n\n var createHref = createPath;\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var prevIndex = history.index;\n var nextIndex = prevIndex + 1;\n var nextEntries = history.entries.slice(0);\n\n if (nextEntries.length > nextIndex) {\n nextEntries.splice(nextIndex, nextEntries.length - nextIndex, location);\n } else {\n nextEntries.push(location);\n }\n\n setState({\n action: action,\n location: location,\n index: nextIndex,\n entries: nextEntries\n });\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n history.entries[history.index] = location;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n var nextIndex = clamp(history.index + n, 0, history.entries.length - 1);\n var action = 'POP';\n var location = history.entries[nextIndex];\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location,\n index: nextIndex\n });\n } else {\n // Mimic the behavior of DOM histories by\n // causing a render after a cancelled POP.\n setState();\n }\n });\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n function canGo(n) {\n var nextIndex = history.index + n;\n return nextIndex >= 0 && nextIndex < history.entries.length;\n }\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n return transitionManager.setPrompt(prompt);\n }\n\n function listen(listener) {\n return transitionManager.appendListener(listener);\n }\n\n var history = {\n length: entries.length,\n action: 'POP',\n location: entries[index],\n index: index,\n entries: entries,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n canGo: canGo,\n block: block,\n listen: listen\n };\n return history;\n}\n\nexport { createBrowserHistory, createHashHistory, createMemoryHistory, createLocation, locationsAreEqual, parsePath, createPath };\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"\n}), 'Close');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11h-4v4h-2v-4H7v-2h4V7h2v4h4v2z\"\n}), 'AddCircle');\n\nexports.default = _default;","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault;","import React from 'react';\nvar useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\n/**\n * https://github.com/facebook/react/issues/14099#issuecomment-440013892\n *\n * @param {function} fn\n */\n\nexport default function useEventCallback(fn) {\n var ref = React.useRef(fn);\n useEnhancedEffect(function () {\n ref.current = fn;\n });\n return React.useCallback(function () {\n return (0, ref.current).apply(void 0, arguments);\n }, []);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = createSvgIcon;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _SvgIcon = _interopRequireDefault(require(\"@material-ui/core/SvgIcon\"));\n\nfunction createSvgIcon(path, displayName) {\n var Component = _react.default.memo(_react.default.forwardRef(function (props, ref) {\n return _react.default.createElement(_SvgIcon.default, (0, _extends2.default)({\n ref: ref\n }, props), path);\n }));\n\n if (process.env.NODE_ENV !== 'production') {\n Component.displayName = \"\".concat(displayName, \"Icon\");\n }\n\n Component.muiName = _SvgIcon.default.muiName;\n return Component;\n}","var isProduction = process.env.NODE_ENV === 'production';\nfunction warning(condition, message) {\n if (!isProduction) {\n if (condition) {\n return;\n }\n\n var text = \"Warning: \" + message;\n\n if (typeof console !== 'undefined') {\n console.warn(text);\n }\n\n try {\n throw Error(text);\n } catch (x) {}\n }\n}\n\nexport default warning;\n","import arrayWithHoles from \"./arrayWithHoles\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit\";\nimport nonIterableRest from \"./nonIterableRest\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}","export default function _iterableToArrayLimit(arr, i) {\n if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === \"[object Arguments]\")) {\n return;\n }\n\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","// TODO: Make it private only in v5\nexport default function setRef(ref, value) {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref) {\n ref.current = value;\n }\n}","import React, { Component } from 'react';\nimport _inheritsLoose from '@babel/runtime/helpers/inheritsLoose';\nimport PropTypes from 'prop-types';\nimport gud from 'gud';\nimport warning from 'tiny-warning';\n\nvar MAX_SIGNED_31_BIT_INT = 1073741823;\n\nfunction objectIs(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nfunction createEventEmitter(value) {\n var handlers = [];\n return {\n on: function on(handler) {\n handlers.push(handler);\n },\n off: function off(handler) {\n handlers = handlers.filter(function (h) {\n return h !== handler;\n });\n },\n get: function get() {\n return value;\n },\n set: function set(newValue, changedBits) {\n value = newValue;\n handlers.forEach(function (handler) {\n return handler(value, changedBits);\n });\n }\n };\n}\n\nfunction onlyChild(children) {\n return Array.isArray(children) ? children[0] : children;\n}\n\nfunction createReactContext(defaultValue, calculateChangedBits) {\n var _Provider$childContex, _Consumer$contextType;\n\n var contextProp = '__create-react-context-' + gud() + '__';\n\n var Provider =\n /*#__PURE__*/\n function (_Component) {\n _inheritsLoose(Provider, _Component);\n\n function Provider() {\n var _this;\n\n _this = _Component.apply(this, arguments) || this;\n _this.emitter = createEventEmitter(_this.props.value);\n return _this;\n }\n\n var _proto = Provider.prototype;\n\n _proto.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[contextProp] = this.emitter, _ref;\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n if (this.props.value !== nextProps.value) {\n var oldValue = this.props.value;\n var newValue = nextProps.value;\n var changedBits;\n\n if (objectIs(oldValue, newValue)) {\n changedBits = 0;\n } else {\n changedBits = typeof calculateChangedBits === 'function' ? calculateChangedBits(oldValue, newValue) : MAX_SIGNED_31_BIT_INT;\n\n if (process.env.NODE_ENV !== 'production') {\n warning((changedBits & MAX_SIGNED_31_BIT_INT) === changedBits, 'calculateChangedBits: Expected the return value to be a ' + '31-bit integer. Instead received: ' + changedBits);\n }\n\n changedBits |= 0;\n\n if (changedBits !== 0) {\n this.emitter.set(nextProps.value, changedBits);\n }\n }\n }\n };\n\n _proto.render = function render() {\n return this.props.children;\n };\n\n return Provider;\n }(Component);\n\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[contextProp] = PropTypes.object.isRequired, _Provider$childContex);\n\n var Consumer =\n /*#__PURE__*/\n function (_Component2) {\n _inheritsLoose(Consumer, _Component2);\n\n function Consumer() {\n var _this2;\n\n _this2 = _Component2.apply(this, arguments) || this;\n _this2.state = {\n value: _this2.getValue()\n };\n\n _this2.onUpdate = function (newValue, changedBits) {\n var observedBits = _this2.observedBits | 0;\n\n if ((observedBits & changedBits) !== 0) {\n _this2.setState({\n value: _this2.getValue()\n });\n }\n };\n\n return _this2;\n }\n\n var _proto2 = Consumer.prototype;\n\n _proto2.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var observedBits = nextProps.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentDidMount = function componentDidMount() {\n if (this.context[contextProp]) {\n this.context[contextProp].on(this.onUpdate);\n }\n\n var observedBits = this.props.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentWillUnmount = function componentWillUnmount() {\n if (this.context[contextProp]) {\n this.context[contextProp].off(this.onUpdate);\n }\n };\n\n _proto2.getValue = function getValue() {\n if (this.context[contextProp]) {\n return this.context[contextProp].get();\n } else {\n return defaultValue;\n }\n };\n\n _proto2.render = function render() {\n return onlyChild(this.props.children)(this.state.value);\n };\n\n return Consumer;\n }(Component);\n\n Consumer.contextTypes = (_Consumer$contextType = {}, _Consumer$contextType[contextProp] = PropTypes.object, _Consumer$contextType);\n return {\n Provider: Provider,\n Consumer: Consumer\n };\n}\n\nvar index = React.createContext || createReactContext;\n\nexport default index;\n","// TODO: Replace with React.createContext once we can assume React 16+\nimport createContext from \"mini-create-react-context\";\n\nconst createNamedContext = name => {\n const context = createContext();\n context.displayName = name;\n\n return context;\n};\n\nconst context = /*#__PURE__*/ createNamedContext(\"Router\");\nexport default context;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext\";\n\n/**\n * The public API for putting history on context.\n */\nclass Router extends React.Component {\n static computeRootMatch(pathname) {\n return { path: \"/\", url: \"/\", params: {}, isExact: pathname === \"/\" };\n }\n\n constructor(props) {\n super(props);\n\n this.state = {\n location: props.history.location\n };\n\n // This is a bit of a hack. We have to start listening for location\n // changes here in the constructor in case there are any <Redirect>s\n // on the initial render. If there are, they will replace/push when\n // they mount and since cDM fires in children before parents, we may\n // get a new location before the <Router> is mounted.\n this._isMounted = false;\n this._pendingLocation = null;\n\n if (!props.staticContext) {\n this.unlisten = props.history.listen(location => {\n if (this._isMounted) {\n this.setState({ location });\n } else {\n this._pendingLocation = location;\n }\n });\n }\n }\n\n componentDidMount() {\n this._isMounted = true;\n\n if (this._pendingLocation) {\n this.setState({ location: this._pendingLocation });\n }\n }\n\n componentWillUnmount() {\n if (this.unlisten) this.unlisten();\n }\n\n render() {\n return (\n <RouterContext.Provider\n children={this.props.children || null}\n value={{\n history: this.props.history,\n location: this.state.location,\n match: Router.computeRootMatch(this.state.location.pathname),\n staticContext: this.props.staticContext\n }}\n />\n );\n }\n}\n\nif (__DEV__) {\n Router.propTypes = {\n children: PropTypes.node,\n history: PropTypes.object.isRequired,\n staticContext: PropTypes.object\n };\n\n Router.prototype.componentDidUpdate = function(prevProps) {\n warning(\n prevProps.history === this.props.history,\n \"You cannot change <Router history>\"\n );\n };\n}\n\nexport default Router;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createMemoryHistory as createHistory } from \"history\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router\";\n\n/**\n * The public API for a <Router> that stores location in memory.\n */\nclass MemoryRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n MemoryRouter.propTypes = {\n initialEntries: PropTypes.array,\n initialIndex: PropTypes.number,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number,\n children: PropTypes.node\n };\n\n MemoryRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<MemoryRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { MemoryRouter as Router }`.\"\n );\n };\n}\n\nexport default MemoryRouter;\n","import React from \"react\";\n\nclass Lifecycle extends React.Component {\n componentDidMount() {\n if (this.props.onMount) this.props.onMount.call(this, this);\n }\n\n componentDidUpdate(prevProps) {\n if (this.props.onUpdate) this.props.onUpdate.call(this, this, prevProps);\n }\n\n componentWillUnmount() {\n if (this.props.onUnmount) this.props.onUnmount.call(this, this);\n }\n\n render() {\n return null;\n }\n}\n\nexport default Lifecycle;\n","import pathToRegexp from \"path-to-regexp\";\n\nconst cache = {};\nconst cacheLimit = 10000;\nlet cacheCount = 0;\n\nfunction compilePath(path, options) {\n const cacheKey = `${options.end}${options.strict}${options.sensitive}`;\n const pathCache = cache[cacheKey] || (cache[cacheKey] = {});\n\n if (pathCache[path]) return pathCache[path];\n\n const keys = [];\n const regexp = pathToRegexp(path, keys, options);\n const result = { regexp, keys };\n\n if (cacheCount < cacheLimit) {\n pathCache[path] = result;\n cacheCount++;\n }\n\n return result;\n}\n\n/**\n * Public API for matching a URL pathname to a path.\n */\nfunction matchPath(pathname, options = {}) {\n if (typeof options === \"string\" || Array.isArray(options)) {\n options = { path: options };\n }\n\n const { path, exact = false, strict = false, sensitive = false } = options;\n\n const paths = [].concat(path);\n\n return paths.reduce((matched, path) => {\n if (!path && path !== \"\") return null;\n if (matched) return matched;\n\n const { regexp, keys } = compilePath(path, {\n end: exact,\n strict,\n sensitive\n });\n const match = regexp.exec(pathname);\n\n if (!match) return null;\n\n const [url, ...values] = match;\n const isExact = pathname === url;\n\n if (exact && !isExact) return null;\n\n return {\n path, // the path used to match\n url: path === \"/\" && url === \"\" ? \"/\" : url, // the matched portion of the URL\n isExact, // whether or not we matched exactly\n params: keys.reduce((memo, key, index) => {\n memo[key.name] = values[index];\n return memo;\n }, {})\n };\n }, null);\n}\n\nexport default matchPath;\n","import React from \"react\";\nimport { isValidElementType } from \"react-is\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext\";\nimport matchPath from \"./matchPath\";\n\nfunction isEmptyChildren(children) {\n return React.Children.count(children) === 0;\n}\n\nfunction evalChildrenDev(children, props, path) {\n const value = children(props);\n\n warning(\n value !== undefined,\n \"You returned `undefined` from the `children` function of \" +\n `<Route${path ? ` path=\"${path}\"` : \"\"}>, but you ` +\n \"should have returned a React element or `null`\"\n );\n\n return value || null;\n}\n\n/**\n * The public API for matching a single path and rendering.\n */\nclass Route extends React.Component {\n render() {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Route> outside a <Router>\");\n\n const location = this.props.location || context.location;\n const match = this.props.computedMatch\n ? this.props.computedMatch // <Switch> already computed the match for us\n : this.props.path\n ? matchPath(location.pathname, this.props)\n : context.match;\n\n const props = { ...context, location, match };\n\n let { children, component, render } = this.props;\n\n // Preact uses an empty array as children by\n // default, so use null if that's the case.\n if (Array.isArray(children) && children.length === 0) {\n children = null;\n }\n\n return (\n <RouterContext.Provider value={props}>\n {props.match\n ? children\n ? typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : children\n : component\n ? React.createElement(component, props)\n : render\n ? render(props)\n : null\n : typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : null}\n </RouterContext.Provider>\n );\n }}\n </RouterContext.Consumer>\n );\n }\n}\n\nif (__DEV__) {\n Route.propTypes = {\n children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),\n component: (props, propName) => {\n if (props[propName] && !isValidElementType(props[propName])) {\n return new Error(\n `Invalid prop 'component' supplied to 'Route': the prop is not a valid React component`\n );\n }\n },\n exact: PropTypes.bool,\n location: PropTypes.object,\n path: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.arrayOf(PropTypes.string)\n ]),\n render: PropTypes.func,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool\n };\n\n Route.prototype.componentDidMount = function() {\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.component\n ),\n \"You should not use <Route component> and <Route children> in the same route; <Route component> will be ignored\"\n );\n\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.render\n ),\n \"You should not use <Route render> and <Route children> in the same route; <Route render> will be ignored\"\n );\n\n warning(\n !(this.props.component && this.props.render),\n \"You should not use <Route component> and <Route render> in the same route; <Route render> will be ignored\"\n );\n };\n\n Route.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n '<Route> elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n '<Route> elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Route;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createLocation, createPath } from \"history\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router\";\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === \"/\" ? path : \"/\" + path;\n}\n\nfunction addBasename(basename, location) {\n if (!basename) return location;\n\n return {\n ...location,\n pathname: addLeadingSlash(basename) + location.pathname\n };\n}\n\nfunction stripBasename(basename, location) {\n if (!basename) return location;\n\n const base = addLeadingSlash(basename);\n\n if (location.pathname.indexOf(base) !== 0) return location;\n\n return {\n ...location,\n pathname: location.pathname.substr(base.length)\n };\n}\n\nfunction createURL(location) {\n return typeof location === \"string\" ? location : createPath(location);\n}\n\nfunction staticHandler(methodName) {\n return () => {\n invariant(false, \"You cannot %s with <StaticRouter>\", methodName);\n };\n}\n\nfunction noop() {}\n\n/**\n * The public top-level API for a \"static\" <Router>, so-called because it\n * can't actually change the current location. Instead, it just records\n * location changes in a context object. Useful mainly in testing and\n * server-rendering scenarios.\n */\nclass StaticRouter extends React.Component {\n navigateTo(location, action) {\n const { basename = \"\", context = {} } = this.props;\n context.action = action;\n context.location = addBasename(basename, createLocation(location));\n context.url = createURL(context.location);\n }\n\n handlePush = location => this.navigateTo(location, \"PUSH\");\n handleReplace = location => this.navigateTo(location, \"REPLACE\");\n handleListen = () => noop;\n handleBlock = () => noop;\n\n render() {\n const { basename = \"\", context = {}, location = \"/\", ...rest } = this.props;\n\n const history = {\n createHref: path => addLeadingSlash(basename + createURL(path)),\n action: \"POP\",\n location: stripBasename(basename, createLocation(location)),\n push: this.handlePush,\n replace: this.handleReplace,\n go: staticHandler(\"go\"),\n goBack: staticHandler(\"goBack\"),\n goForward: staticHandler(\"goForward\"),\n listen: this.handleListen,\n block: this.handleBlock\n };\n\n return <Router {...rest} history={history} staticContext={context} />;\n }\n}\n\nif (__DEV__) {\n StaticRouter.propTypes = {\n basename: PropTypes.string,\n context: PropTypes.object,\n location: PropTypes.oneOfType([PropTypes.string, PropTypes.object])\n };\n\n StaticRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<StaticRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { StaticRouter as Router }`.\"\n );\n };\n}\n\nexport default StaticRouter;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext\";\nimport matchPath from \"./matchPath\";\n\n/**\n * The public API for rendering the first <Route> that matches.\n */\nclass Switch extends React.Component {\n render() {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Switch> outside a <Router>\");\n\n const location = this.props.location || context.location;\n\n let element, match;\n\n // We use React.Children.forEach instead of React.Children.toArray().find()\n // here because toArray adds keys to all child elements and we do not want\n // to trigger an unmount/remount for two <Route>s that render the same\n // component at different URLs.\n React.Children.forEach(this.props.children, child => {\n if (match == null && React.isValidElement(child)) {\n element = child;\n\n const path = child.props.path || child.props.from;\n\n match = path\n ? matchPath(location.pathname, { ...child.props, path })\n : context.match;\n }\n });\n\n return match\n ? React.cloneElement(element, { location, computedMatch: match })\n : null;\n }}\n </RouterContext.Consumer>\n );\n }\n}\n\nif (__DEV__) {\n Switch.propTypes = {\n children: PropTypes.node,\n location: PropTypes.object\n };\n\n Switch.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n '<Switch> elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n '<Switch> elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Switch;\n","import React from \"react\";\nimport invariant from \"tiny-invariant\";\n\nimport Context from \"./RouterContext.js\";\nimport matchPath from \"./matchPath.js\";\n\nconst useContext = React.useContext;\n\nexport function useHistory() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useHistory()\"\n );\n }\n\n return useContext(Context).history;\n}\n\nexport function useLocation() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useLocation()\"\n );\n }\n\n return useContext(Context).location;\n}\n\nexport function useParams() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useParams()\"\n );\n }\n\n const match = useContext(Context).match;\n return match ? match.params : {};\n}\n\nexport function useRouteMatch(path) {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useRouteMatch()\"\n );\n }\n\n return path\n ? matchPath(useLocation().pathname, path)\n : useContext(Context).match;\n}\n","import React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar FormControlContext = React.createContext();\n\nif (process.env.NODE_ENV !== 'production') {\n FormControlContext.displayName = 'FormControlContext';\n}\n\nexport function useFormControl() {\n return React.useContext(FormControlContext);\n}\nexport default FormControlContext;","// Supports determination of isControlled().\n// Controlled input accepts its current value as a prop.\n//\n// @see https://facebook.github.io/react/docs/forms.html#controlled-components\n// @param value\n// @returns {boolean} true if string (including '') or number (including zero)\nexport function hasValue(value) {\n return value != null && !(Array.isArray(value) && value.length === 0);\n} // Determine if field is empty or filled.\n// Response determines if label is presented above field or as placeholder.\n//\n// @param obj\n// @param SSR\n// @returns {boolean} False when not present or empty string.\n// True when any number or string with length.\n\nexport function isFilled(obj) {\n var SSR = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n return obj && (hasValue(obj.value) && obj.value !== '' || SSR && hasValue(obj.defaultValue) && obj.defaultValue !== '');\n} // Determine if an Input is adorned on start.\n// It's corresponding to the left with LTR.\n//\n// @param obj\n// @returns {boolean} False when no adornments.\n// True when adorned at the start.\n\nexport function isAdornedStart(obj) {\n return obj.startAdornment;\n}","/**\n * Safe chained function\n *\n * Will only create a new function if needed,\n * otherwise will pass back existing functions or null.\n *\n * @param {function} functions to chain\n * @returns {function|null}\n */\nexport default function createChainedFunction() {\n for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) {\n funcs[_key] = arguments[_key];\n }\n\n return funcs.reduce(function (acc, func) {\n if (func == null) {\n return acc;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof func !== 'function') {\n console.error('Material-UI: invalid Argument Type, must only provide functions, undefined, or null.');\n }\n }\n\n return function chainedFunction() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n acc.apply(this, args);\n func.apply(this, args);\n };\n }, function () {});\n}","import React from 'react';\nexport default React.createContext(null);","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","import createMuiTheme from './createMuiTheme';\nvar defaultTheme = createMuiTheme();\nexport default defaultTheme;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nimport IconButton from '../IconButton';\nexport var styles = {\n root: {\n padding: 9\n },\n checked: {},\n disabled: {},\n input: {\n cursor: 'inherit',\n position: 'absolute',\n opacity: 0,\n width: '100%',\n height: '100%',\n top: 0,\n left: 0,\n margin: 0,\n padding: 0,\n zIndex: 1\n }\n};\n/**\n * @ignore - internal component.\n */\n\nvar SwitchBase = React.forwardRef(function SwitchBase(props, ref) {\n var autoFocus = props.autoFocus,\n checkedProp = props.checked,\n checkedIcon = props.checkedIcon,\n classes = props.classes,\n className = props.className,\n defaultChecked = props.defaultChecked,\n disabledProp = props.disabled,\n icon = props.icon,\n id = props.id,\n inputProps = props.inputProps,\n inputRef = props.inputRef,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onFocus = props.onFocus,\n readOnly = props.readOnly,\n required = props.required,\n tabIndex = props.tabIndex,\n type = props.type,\n value = props.value,\n other = _objectWithoutProperties(props, [\"autoFocus\", \"checked\", \"checkedIcon\", \"classes\", \"className\", \"defaultChecked\", \"disabled\", \"icon\", \"id\", \"inputProps\", \"inputRef\", \"name\", \"onBlur\", \"onChange\", \"onFocus\", \"readOnly\", \"required\", \"tabIndex\", \"type\", \"value\"]);\n\n var _React$useRef = React.useRef(checkedProp != null),\n isControlled = _React$useRef.current;\n\n var _React$useState = React.useState(Boolean(defaultChecked)),\n checkedState = _React$useState[0],\n setCheckedState = _React$useState[1];\n\n var checked = isControlled ? checkedProp : checkedState;\n var muiFormControl = useFormControl();\n\n var handleFocus = function handleFocus(event) {\n if (onFocus) {\n onFocus(event);\n }\n\n if (muiFormControl && muiFormControl.onFocus) {\n muiFormControl.onFocus(event);\n }\n };\n\n var handleBlur = function handleBlur(event) {\n if (onBlur) {\n onBlur(event);\n }\n\n if (muiFormControl && muiFormControl.onBlur) {\n muiFormControl.onBlur(event);\n }\n };\n\n var handleInputChange = function handleInputChange(event) {\n var newChecked = event.target.checked;\n\n if (!isControlled) {\n setCheckedState(newChecked);\n }\n\n if (onChange) {\n onChange(event, newChecked);\n }\n };\n\n var disabled = disabledProp;\n\n if (muiFormControl) {\n if (typeof disabled === 'undefined') {\n disabled = muiFormControl.disabled;\n }\n }\n\n var hasLabelFor = type === 'checkbox' || type === 'radio';\n return React.createElement(IconButton, _extends({\n component: \"span\",\n className: clsx(classes.root, className, checked && classes.checked, disabled && classes.disabled),\n disabled: disabled,\n tabIndex: null,\n role: undefined,\n onFocus: handleFocus,\n onBlur: handleBlur,\n ref: ref\n }, other), React.createElement(\"input\", _extends({\n autoFocus: autoFocus,\n checked: checkedProp,\n defaultChecked: defaultChecked,\n className: classes.input,\n disabled: disabled,\n id: hasLabelFor && id,\n name: name,\n onChange: handleInputChange,\n readOnly: readOnly,\n ref: inputRef,\n required: required,\n tabIndex: tabIndex,\n type: type,\n value: value\n }, inputProps)), checked ? checkedIcon : icon);\n}); // NB: If changed, please update Checkbox, Switch and Radio\n// so that the API documentation is updated.\n\nprocess.env.NODE_ENV !== \"production\" ? SwitchBase.propTypes = {\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node.isRequired,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * @ignore\n */\n defaultChecked: PropTypes.bool,\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node.isRequired,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /*\n * @ignore\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string.isRequired,\n\n /**\n * The value of the component.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateSwitchBase'\n})(SwitchBase);","import { useTheme as useThemeWithoutDefault } from '@material-ui/styles';\nimport defaultTheme from './defaultTheme';\nexport default function useTheme() {\n return useThemeWithoutDefault() || defaultTheme;\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}","import React from 'react';\nexport default function isMuiElement(element, muiNames) {\n return React.isValidElement(element) && muiNames.indexOf(element.type.muiName) !== -1;\n}","import React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar ListContext = React.createContext({});\n\nif (process.env.NODE_ENV !== 'production') {\n ListContext.displayName = 'ListContext';\n}\n\nexport default ListContext;","function _typeof2(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof2(obj); }\n\nexport default function _typeof(obj) {\n if (typeof Symbol === \"function\" && _typeof2(Symbol.iterator) === \"symbol\") {\n _typeof = function _typeof(obj) {\n return _typeof2(obj);\n };\n } else {\n _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : _typeof2(obj);\n };\n }\n\n return _typeof(obj);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z\"\n}), 'CheckBoxOutlineBlank');\n\nexports.default = _default;","module.exports = require('./lib/axios');","import React from 'react';\nvar ThemeContext = React.createContext(null);\n\nif (process.env.NODE_ENV !== 'production') {\n ThemeContext.displayName = 'ThemeContext';\n}\n\nexport default ThemeContext;","var hasSymbol = typeof Symbol === 'function' && Symbol.for;\nexport default hasSymbol ? Symbol.for('mui.nested') : '__THEME_NESTED__';","// We need to centralize the zIndex definitions as they work\n// like global values in the browser.\nvar zIndex = {\n mobileStepper: 1000,\n speedDial: 1050,\n appBar: 1100,\n drawer: 1200,\n modal: 1300,\n snackbar: 1400,\n tooltip: 1500\n};\nexport default zIndex;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n userSelect: 'none',\n width: '1em',\n height: '1em',\n display: 'inline-block',\n fill: 'currentColor',\n flexShrink: 0,\n fontSize: theme.typography.pxToRem(24),\n transition: theme.transitions.create('fill', {\n duration: theme.transitions.duration.shorter\n })\n },\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n color: theme.palette.primary.main\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n color: theme.palette.secondary.main\n },\n\n /* Styles applied to the root element if `color=\"action\"`. */\n colorAction: {\n color: theme.palette.action.active\n },\n\n /* Styles applied to the root element if `color=\"error\"`. */\n colorError: {\n color: theme.palette.error.main\n },\n\n /* Styles applied to the root element if `color=\"disabled\"`. */\n colorDisabled: {\n color: theme.palette.action.disabled\n },\n\n /* Styles applied to the root element if `fontSize=\"inherit\"`. */\n fontSizeInherit: {\n fontSize: 'inherit'\n },\n\n /* Styles applied to the root element if `fontSize=\"small\"`. */\n fontSizeSmall: {\n fontSize: theme.typography.pxToRem(20)\n },\n\n /* Styles applied to the root element if `fontSize=\"large\"`. */\n fontSizeLarge: {\n fontSize: theme.typography.pxToRem(35)\n }\n };\n};\nvar SvgIcon = React.forwardRef(function SvgIcon(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'inherit' : _props$color,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'svg' : _props$component,\n _props$fontSize = props.fontSize,\n fontSize = _props$fontSize === void 0 ? 'default' : _props$fontSize,\n htmlColor = props.htmlColor,\n titleAccess = props.titleAccess,\n _props$viewBox = props.viewBox,\n viewBox = _props$viewBox === void 0 ? '0 0 24 24' : _props$viewBox,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"fontSize\", \"htmlColor\", \"titleAccess\", \"viewBox\"]);\n\n return React.createElement(Component, _extends({\n className: clsx(classes.root, className, color !== 'inherit' && classes[\"color\".concat(capitalize(color))], fontSize !== 'default' && classes[\"fontSize\".concat(capitalize(fontSize))]),\n focusable: \"false\",\n viewBox: viewBox,\n color: htmlColor,\n \"aria-hidden\": titleAccess ? null : 'true',\n role: titleAccess ? 'img' : 'presentation',\n ref: ref\n }, other), children, titleAccess ? React.createElement(\"title\", null, titleAccess) : null);\n});\nprocess.env.NODE_ENV !== \"production\" ? SvgIcon.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * Node passed into the SVG element.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n * You can use the `htmlColor` prop to apply a color attribute to the SVG element.\n */\n color: PropTypes.oneOf(['action', 'disabled', 'error', 'inherit', 'primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * The fontSize applied to the icon. Defaults to 24px, but can be configure to inherit font size.\n */\n fontSize: PropTypes.oneOf(['default', 'inherit', 'large', 'small']),\n\n /**\n * Applies a color attribute to the SVG element.\n */\n htmlColor: PropTypes.string,\n\n /**\n * The shape-rendering attribute. The behavior of the different options is described on the\n * [MDN Web Docs](https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/shape-rendering).\n * If you are having issues with blurry icons you should investigate this property.\n */\n shapeRendering: PropTypes.string,\n\n /**\n * Provides a human-readable title for the element that contains it.\n * https://www.w3.org/TR/SVG-access/#Equivalent\n */\n titleAccess: PropTypes.string,\n\n /**\n * Allows you to redefine what the coordinates without units mean inside an SVG element.\n * For example, if the SVG element is 500 (width) by 200 (height),\n * and you pass viewBox=\"0 0 50 20\",\n * this means that the coordinates inside the SVG will go from the top left corner (0,0)\n * to bottom right (50,20) and each unit will be worth 10px.\n */\n viewBox: PropTypes.string\n} : void 0;\nSvgIcon.muiName = 'SvgIcon';\nexport default withStyles(styles, {\n name: 'MuiSvgIcon'\n})(SvgIcon);","// Corresponds to 10 frames at 60 Hz.\n// A few bytes payload overhead when lodash/debounce is ~3 kB and debounce ~300 B.\nexport default function debounce(func) {\n var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 166;\n var timeout;\n\n function debounced() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n // eslint-disable-next-line consistent-this\n var that = this;\n\n var later = function later() {\n func.apply(that, args);\n };\n\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n }\n\n debounced.clear = function () {\n clearTimeout(timeout);\n };\n\n return debounced;\n}","import React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar RadioGroupContext = React.createContext();\n\nif (process.env.NODE_ENV !== 'production') {\n RadioGroupContext.displayName = 'RadioGroupContext';\n}\n\nexport default RadioGroupContext;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z\"\n}), 'Add');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M3 15h18v-2H3v2zm0 4h18v-2H3v2zm0-8h18V9H3v2zm0-6v2h18V5H3z\"\n}), 'Reorder');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"\n}), 'RadioButtonChecked');\n\nexports.default = _default;","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createBrowserHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a <Router> that uses HTML5 history.\n */\nclass BrowserRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n BrowserRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n forceRefresh: PropTypes.bool,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number\n };\n\n BrowserRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<BrowserRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { BrowserRouter as Router }`.\"\n );\n };\n}\n\nexport default BrowserRouter;\n","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createHashHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a <Router> that uses window.location.hash.\n */\nclass HashRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n HashRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n getUserConfirmation: PropTypes.func,\n hashType: PropTypes.oneOf([\"hashbang\", \"noslash\", \"slash\"])\n };\n\n HashRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<HashRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { HashRouter as Router }`.\"\n );\n };\n}\n\nexport default HashRouter;\n","import { createLocation } from \"history\";\n\nexport const resolveToLocation = (to, currentLocation) =>\n typeof to === \"function\" ? to(currentLocation) : to;\n\nexport const normalizeToLocation = (to, currentLocation) => {\n return typeof to === \"string\"\n ? createLocation(to, null, null, currentLocation)\n : to;\n};\n","import React from \"react\";\nimport { __RouterContext as RouterContext } from \"react-router\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport { resolveToLocation, normalizeToLocation } from \"./utils/locationUtils\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction isModifiedEvent(event) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\n\nconst LinkAnchor = forwardRef(\n (\n {\n innerRef, // TODO: deprecate\n navigate,\n onClick,\n ...rest\n },\n forwardedRef\n ) => {\n const { target } = rest;\n\n let props = {\n ...rest,\n onClick: event => {\n try {\n if (onClick) onClick(event);\n } catch (ex) {\n event.preventDefault();\n throw ex;\n }\n\n if (\n !event.defaultPrevented && // onClick prevented default\n event.button === 0 && // ignore everything but left clicks\n (!target || target === \"_self\") && // let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event) // ignore clicks with modifier keys\n ) {\n event.preventDefault();\n navigate();\n }\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.ref = innerRef;\n }\n\n return <a {...props} />;\n }\n);\n\nif (__DEV__) {\n LinkAnchor.displayName = \"LinkAnchor\";\n}\n\n/**\n * The public API for rendering a history-aware <a>.\n */\nconst Link = forwardRef(\n (\n {\n component = LinkAnchor,\n replace,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Link> outside a <Router>\");\n\n const { history } = context;\n\n const location = normalizeToLocation(\n resolveToLocation(to, context.location),\n context.location\n );\n\n const href = location ? history.createHref(location) : \"\";\n const props = {\n ...rest,\n href,\n navigate() {\n const location = resolveToLocation(to, context.location);\n const method = replace ? history.replace : history.push;\n\n method(location);\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return React.createElement(component, props);\n }}\n </RouterContext.Consumer>\n );\n }\n);\n\nif (__DEV__) {\n const toType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n PropTypes.func\n ]);\n const refType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.shape({ current: PropTypes.any })\n ]);\n\n Link.displayName = \"Link\";\n\n Link.propTypes = {\n innerRef: refType,\n onClick: PropTypes.func,\n replace: PropTypes.bool,\n target: PropTypes.string,\n to: toType.isRequired\n };\n}\n\nexport default Link;\n","import React from \"react\";\nimport { __RouterContext as RouterContext, matchPath } from \"react-router\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport Link from \"./Link\";\nimport { resolveToLocation, normalizeToLocation } from \"./utils/locationUtils\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction joinClassnames(...classnames) {\n return classnames.filter(i => i).join(\" \");\n}\n\n/**\n * A <Link> wrapper that knows if it's \"active\" or not.\n */\nconst NavLink = forwardRef(\n (\n {\n \"aria-current\": ariaCurrent = \"page\",\n activeClassName = \"active\",\n activeStyle,\n className: classNameProp,\n exact,\n isActive: isActiveProp,\n location: locationProp,\n strict,\n style: styleProp,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <NavLink> outside a <Router>\");\n\n const currentLocation = locationProp || context.location;\n const toLocation = normalizeToLocation(\n resolveToLocation(to, currentLocation),\n currentLocation\n );\n const { pathname: path } = toLocation;\n // Regex taken from: https://github.com/pillarjs/path-to-regexp/blob/master/index.js#L202\n const escapedPath =\n path && path.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n\n const match = escapedPath\n ? matchPath(currentLocation.pathname, {\n path: escapedPath,\n exact,\n strict\n })\n : null;\n const isActive = !!(isActiveProp\n ? isActiveProp(match, currentLocation)\n : match);\n\n const className = isActive\n ? joinClassnames(classNameProp, activeClassName)\n : classNameProp;\n const style = isActive ? { ...styleProp, ...activeStyle } : styleProp;\n\n const props = {\n \"aria-current\": (isActive && ariaCurrent) || null,\n className,\n style,\n to: toLocation,\n ...rest\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return <Link {...props} />;\n }}\n </RouterContext.Consumer>\n );\n }\n);\n\nif (__DEV__) {\n NavLink.displayName = \"NavLink\";\n\n const ariaCurrentType = PropTypes.oneOf([\n \"page\",\n \"step\",\n \"location\",\n \"date\",\n \"time\",\n \"true\"\n ]);\n\n NavLink.propTypes = {\n ...Link.propTypes,\n \"aria-current\": ariaCurrentType,\n activeClassName: PropTypes.string,\n activeStyle: PropTypes.object,\n className: PropTypes.string,\n exact: PropTypes.bool,\n isActive: PropTypes.func,\n location: PropTypes.object,\n strict: PropTypes.bool,\n style: PropTypes.object\n };\n}\n\nexport default NavLink;\n","function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nmodule.exports = _inheritsLoose;","var isarray = require('isarray')\n\n/**\n * Expose `pathToRegexp`.\n */\nmodule.exports = pathToRegexp\nmodule.exports.parse = parse\nmodule.exports.compile = compile\nmodule.exports.tokensToFunction = tokensToFunction\nmodule.exports.tokensToRegExp = tokensToRegExp\n\n/**\n * The main path matching regexp utility.\n *\n * @type {RegExp}\n */\nvar PATH_REGEXP = new RegExp([\n // Match escaped characters that would otherwise appear in future matches.\n // This allows the user to escape special characters that won't transform.\n '(\\\\\\\\.)',\n // Match Express-style parameters and un-named parameters with a prefix\n // and optional suffixes. Matches appear as:\n //\n // \"/:test(\\\\d+)?\" => [\"/\", \"test\", \"\\d+\", undefined, \"?\", undefined]\n // \"/route(\\\\d+)\" => [undefined, undefined, undefined, \"\\d+\", undefined, undefined]\n // \"/*\" => [\"/\", undefined, undefined, undefined, undefined, \"*\"]\n '([\\\\/.])?(?:(?:\\\\:(\\\\w+)(?:\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))?|\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))([+*?])?|(\\\\*))'\n].join('|'), 'g')\n\n/**\n * Parse a string for the raw tokens.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!Array}\n */\nfunction parse (str, options) {\n var tokens = []\n var key = 0\n var index = 0\n var path = ''\n var defaultDelimiter = options && options.delimiter || '/'\n var res\n\n while ((res = PATH_REGEXP.exec(str)) != null) {\n var m = res[0]\n var escaped = res[1]\n var offset = res.index\n path += str.slice(index, offset)\n index = offset + m.length\n\n // Ignore already escaped sequences.\n if (escaped) {\n path += escaped[1]\n continue\n }\n\n var next = str[index]\n var prefix = res[2]\n var name = res[3]\n var capture = res[4]\n var group = res[5]\n var modifier = res[6]\n var asterisk = res[7]\n\n // Push the current path onto the tokens.\n if (path) {\n tokens.push(path)\n path = ''\n }\n\n var partial = prefix != null && next != null && next !== prefix\n var repeat = modifier === '+' || modifier === '*'\n var optional = modifier === '?' || modifier === '*'\n var delimiter = res[2] || defaultDelimiter\n var pattern = capture || group\n\n tokens.push({\n name: name || key++,\n prefix: prefix || '',\n delimiter: delimiter,\n optional: optional,\n repeat: repeat,\n partial: partial,\n asterisk: !!asterisk,\n pattern: pattern ? escapeGroup(pattern) : (asterisk ? '.*' : '[^' + escapeString(delimiter) + ']+?')\n })\n }\n\n // Match any characters still remaining.\n if (index < str.length) {\n path += str.substr(index)\n }\n\n // If the path exists, push it onto the end.\n if (path) {\n tokens.push(path)\n }\n\n return tokens\n}\n\n/**\n * Compile a string to a template function for the path.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!function(Object=, Object=)}\n */\nfunction compile (str, options) {\n return tokensToFunction(parse(str, options), options)\n}\n\n/**\n * Prettier encoding of URI path segments.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeURIComponentPretty (str) {\n return encodeURI(str).replace(/[\\/?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeAsterisk (str) {\n return encodeURI(str).replace(/[?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Expose a method for transforming tokens into the path function.\n */\nfunction tokensToFunction (tokens, options) {\n // Compile all the tokens into regexps.\n var matches = new Array(tokens.length)\n\n // Compile all the patterns before compilation.\n for (var i = 0; i < tokens.length; i++) {\n if (typeof tokens[i] === 'object') {\n matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$', flags(options))\n }\n }\n\n return function (obj, opts) {\n var path = ''\n var data = obj || {}\n var options = opts || {}\n var encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent\n\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n path += token\n\n continue\n }\n\n var value = data[token.name]\n var segment\n\n if (value == null) {\n if (token.optional) {\n // Prepend partial segment prefixes.\n if (token.partial) {\n path += token.prefix\n }\n\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to be defined')\n }\n }\n\n if (isarray(value)) {\n if (!token.repeat) {\n throw new TypeError('Expected \"' + token.name + '\" to not repeat, but received `' + JSON.stringify(value) + '`')\n }\n\n if (value.length === 0) {\n if (token.optional) {\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to not be empty')\n }\n }\n\n for (var j = 0; j < value.length; j++) {\n segment = encode(value[j])\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected all \"' + token.name + '\" to match \"' + token.pattern + '\", but received `' + JSON.stringify(segment) + '`')\n }\n\n path += (j === 0 ? token.prefix : token.delimiter) + segment\n }\n\n continue\n }\n\n segment = token.asterisk ? encodeAsterisk(value) : encode(value)\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected \"' + token.name + '\" to match \"' + token.pattern + '\", but received \"' + segment + '\"')\n }\n\n path += token.prefix + segment\n }\n\n return path\n }\n}\n\n/**\n * Escape a regular expression string.\n *\n * @param {string} str\n * @return {string}\n */\nfunction escapeString (str) {\n return str.replace(/([.+*?=^!:${}()[\\]|\\/\\\\])/g, '\\\\$1')\n}\n\n/**\n * Escape the capturing group by escaping special characters and meaning.\n *\n * @param {string} group\n * @return {string}\n */\nfunction escapeGroup (group) {\n return group.replace(/([=!:$\\/()])/g, '\\\\$1')\n}\n\n/**\n * Attach the keys as a property of the regexp.\n *\n * @param {!RegExp} re\n * @param {Array} keys\n * @return {!RegExp}\n */\nfunction attachKeys (re, keys) {\n re.keys = keys\n return re\n}\n\n/**\n * Get the flags for a regexp from the options.\n *\n * @param {Object} options\n * @return {string}\n */\nfunction flags (options) {\n return options && options.sensitive ? '' : 'i'\n}\n\n/**\n * Pull out keys from a regexp.\n *\n * @param {!RegExp} path\n * @param {!Array} keys\n * @return {!RegExp}\n */\nfunction regexpToRegexp (path, keys) {\n // Use a negative lookahead to match only capturing groups.\n var groups = path.source.match(/\\((?!\\?)/g)\n\n if (groups) {\n for (var i = 0; i < groups.length; i++) {\n keys.push({\n name: i,\n prefix: null,\n delimiter: null,\n optional: false,\n repeat: false,\n partial: false,\n asterisk: false,\n pattern: null\n })\n }\n }\n\n return attachKeys(path, keys)\n}\n\n/**\n * Transform an array into a regexp.\n *\n * @param {!Array} path\n * @param {Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction arrayToRegexp (path, keys, options) {\n var parts = []\n\n for (var i = 0; i < path.length; i++) {\n parts.push(pathToRegexp(path[i], keys, options).source)\n }\n\n var regexp = new RegExp('(?:' + parts.join('|') + ')', flags(options))\n\n return attachKeys(regexp, keys)\n}\n\n/**\n * Create a path regexp from string input.\n *\n * @param {string} path\n * @param {!Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction stringToRegexp (path, keys, options) {\n return tokensToRegExp(parse(path, options), keys, options)\n}\n\n/**\n * Expose a function for taking tokens and returning a RegExp.\n *\n * @param {!Array} tokens\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction tokensToRegExp (tokens, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n var strict = options.strict\n var end = options.end !== false\n var route = ''\n\n // Iterate over the tokens and create our regexp string.\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n route += escapeString(token)\n } else {\n var prefix = escapeString(token.prefix)\n var capture = '(?:' + token.pattern + ')'\n\n keys.push(token)\n\n if (token.repeat) {\n capture += '(?:' + prefix + capture + ')*'\n }\n\n if (token.optional) {\n if (!token.partial) {\n capture = '(?:' + prefix + '(' + capture + '))?'\n } else {\n capture = prefix + '(' + capture + ')?'\n }\n } else {\n capture = prefix + '(' + capture + ')'\n }\n\n route += capture\n }\n }\n\n var delimiter = escapeString(options.delimiter || '/')\n var endsWithDelimiter = route.slice(-delimiter.length) === delimiter\n\n // In non-strict mode we allow a slash at the end of match. If the path to\n // match already ends with a slash, we remove it for consistency. The slash\n // is valid at the end of a path match, not in the middle. This is important\n // in non-ending mode, where \"/test/\" shouldn't match \"/test//route\".\n if (!strict) {\n route = (endsWithDelimiter ? route.slice(0, -delimiter.length) : route) + '(?:' + delimiter + '(?=$))?'\n }\n\n if (end) {\n route += '$'\n } else {\n // In non-ending mode, we need the capturing groups to match as much as\n // possible by using a positive lookahead to the end or next path segment.\n route += strict && endsWithDelimiter ? '' : '(?=' + delimiter + '|$)'\n }\n\n return attachKeys(new RegExp('^' + route, flags(options)), keys)\n}\n\n/**\n * Normalize the given path string, returning a regular expression.\n *\n * An empty array can be passed in for the keys, which will hold the\n * placeholder key descriptions. For example, using `/user/:id`, `keys` will\n * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.\n *\n * @param {(string|RegExp|Array)} path\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction pathToRegexp (path, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n if (path instanceof RegExp) {\n return regexpToRegexp(path, /** @type {!Array} */ (keys))\n }\n\n if (isarray(path)) {\n return arrayToRegexp(/** @type {!Array} */ (path), /** @type {!Array} */ (keys), options)\n }\n\n return stringToRegexp(/** @type {string} */ (path), /** @type {!Array} */ (keys), options)\n}\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n return function wrap() {\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n return fn.apply(thisArg, args);\n };\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction encode(val) {\n return encodeURIComponent(val).\n replace(/%40/gi, '@').\n replace(/%3A/gi, ':').\n replace(/%24/g, '$').\n replace(/%2C/gi, ',').\n replace(/%20/g, '+').\n replace(/%5B/gi, '[').\n replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n\n var serializedParams;\n if (paramsSerializer) {\n serializedParams = paramsSerializer(params);\n } else if (utils.isURLSearchParams(params)) {\n serializedParams = params.toString();\n } else {\n var parts = [];\n\n utils.forEach(params, function serialize(val, key) {\n if (val === null || typeof val === 'undefined') {\n return;\n }\n\n if (utils.isArray(val)) {\n key = key + '[]';\n } else {\n val = [val];\n }\n\n utils.forEach(val, function parseValue(v) {\n if (utils.isDate(v)) {\n v = v.toISOString();\n } else if (utils.isObject(v)) {\n v = JSON.stringify(v);\n }\n parts.push(encode(key) + '=' + encode(v));\n });\n });\n\n serializedParams = parts.join('&');\n }\n\n if (serializedParams) {\n var hashmarkIndex = url.indexOf('#');\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n\n return url;\n};\n","'use strict';\n\nmodule.exports = function isCancel(value) {\n return !!(value && value.__CANCEL__);\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\n\nvar DEFAULT_CONTENT_TYPE = {\n 'Content-Type': 'application/x-www-form-urlencoded'\n};\n\nfunction setContentTypeIfUnset(headers, value) {\n if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n headers['Content-Type'] = value;\n }\n}\n\nfunction getDefaultAdapter() {\n var adapter;\n if (typeof XMLHttpRequest !== 'undefined') {\n // For browsers use XHR adapter\n adapter = require('./adapters/xhr');\n } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n // For node use HTTP adapter\n adapter = require('./adapters/http');\n }\n return adapter;\n}\n\nvar defaults = {\n adapter: getDefaultAdapter(),\n\n transformRequest: [function transformRequest(data, headers) {\n normalizeHeaderName(headers, 'Accept');\n normalizeHeaderName(headers, 'Content-Type');\n if (utils.isFormData(data) ||\n utils.isArrayBuffer(data) ||\n utils.isBuffer(data) ||\n utils.isStream(data) ||\n utils.isFile(data) ||\n utils.isBlob(data)\n ) {\n return data;\n }\n if (utils.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils.isURLSearchParams(data)) {\n setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n return data.toString();\n }\n if (utils.isObject(data)) {\n setContentTypeIfUnset(headers, 'application/json;charset=utf-8');\n return JSON.stringify(data);\n }\n return data;\n }],\n\n transformResponse: [function transformResponse(data) {\n /*eslint no-param-reassign:0*/\n if (typeof data === 'string') {\n try {\n data = JSON.parse(data);\n } catch (e) { /* Ignore */ }\n }\n return data;\n }],\n\n /**\n * A timeout in milliseconds to abort a request. If set to 0 (default) a\n * timeout is not created.\n */\n timeout: 0,\n\n xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n\n maxContentLength: -1,\n\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n }\n};\n\ndefaults.headers = {\n common: {\n 'Accept': 'application/json, text/plain, */*'\n }\n};\n\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n defaults.headers[method] = {};\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\n\nmodule.exports = defaults;\n","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\n\nmodule.exports = function xhrAdapter(config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n var requestData = config.data;\n var requestHeaders = config.headers;\n\n if (utils.isFormData(requestData)) {\n delete requestHeaders['Content-Type']; // Let the browser set it\n }\n\n var request = new XMLHttpRequest();\n\n // HTTP basic authentication\n if (config.auth) {\n var username = config.auth.username || '';\n var password = config.auth.password || '';\n requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n }\n\n var fullPath = buildFullPath(config.baseURL, config.url);\n request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n // Set the request timeout in MS\n request.timeout = config.timeout;\n\n // Listen for ready state\n request.onreadystatechange = function handleLoad() {\n if (!request || request.readyState !== 4) {\n return;\n }\n\n // The request errored out and we didn't get a response, this will be\n // handled by onerror instead\n // With one exception: request that using file: protocol, most browsers\n // will return status as 0 even though it's a successful request\n if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n return;\n }\n\n // Prepare the response\n var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;\n var response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config: config,\n request: request\n };\n\n settle(resolve, reject, response);\n\n // Clean up request\n request = null;\n };\n\n // Handle browser request cancellation (as opposed to a manual cancellation)\n request.onabort = function handleAbort() {\n if (!request) {\n return;\n }\n\n reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\n };\n\n // Handle low level network errors\n request.onerror = function handleError() {\n // Real errors are hidden from us by the browser\n // onerror should only fire if it's a network error\n reject(createError('Network Error', config, null, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle timeout\n request.ontimeout = function handleTimeout() {\n var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n if (config.timeoutErrorMessage) {\n timeoutErrorMessage = config.timeoutErrorMessage;\n }\n reject(createError(timeoutErrorMessage, config, 'ECONNABORTED',\n request));\n\n // Clean up request\n request = null;\n };\n\n // Add xsrf header\n // This is only done if running in a standard browser environment.\n // Specifically not if we're in a web worker, or react-native.\n if (utils.isStandardBrowserEnv()) {\n var cookies = require('./../helpers/cookies');\n\n // Add xsrf header\n var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?\n cookies.read(config.xsrfCookieName) :\n undefined;\n\n if (xsrfValue) {\n requestHeaders[config.xsrfHeaderName] = xsrfValue;\n }\n }\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n // Remove Content-Type if data is undefined\n delete requestHeaders[key];\n } else {\n // Otherwise add header to the request\n request.setRequestHeader(key, val);\n }\n });\n }\n\n // Add withCredentials to request if needed\n if (!utils.isUndefined(config.withCredentials)) {\n request.withCredentials = !!config.withCredentials;\n }\n\n // Add responseType to request if needed\n if (config.responseType) {\n try {\n request.responseType = config.responseType;\n } catch (e) {\n // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.\n // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.\n if (config.responseType !== 'json') {\n throw e;\n }\n }\n }\n\n // Handle progress if needed\n if (typeof config.onDownloadProgress === 'function') {\n request.addEventListener('progress', config.onDownloadProgress);\n }\n\n // Not all browsers support upload events\n if (typeof config.onUploadProgress === 'function' && request.upload) {\n request.upload.addEventListener('progress', config.onUploadProgress);\n }\n\n if (config.cancelToken) {\n // Handle cancellation\n config.cancelToken.promise.then(function onCanceled(cancel) {\n if (!request) {\n return;\n }\n\n request.abort();\n reject(cancel);\n // Clean up request\n request = null;\n });\n }\n\n if (requestData === undefined) {\n requestData = null;\n }\n\n // Send the request\n request.send(requestData);\n });\n};\n","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n var error = new Error(message);\n return enhanceError(error, config, code, request, response);\n};\n","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n var config = {};\n\n var valueFromConfig2Keys = ['url', 'method', 'params', 'data'];\n var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy'];\n var defaultToConfig2Keys = [\n 'baseURL', 'url', 'transformRequest', 'transformResponse', 'paramsSerializer',\n 'timeout', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',\n 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress',\n 'maxContentLength', 'validateStatus', 'maxRedirects', 'httpAgent',\n 'httpsAgent', 'cancelToken', 'socketPath'\n ];\n\n utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n }\n });\n\n utils.forEach(mergeDeepPropertiesKeys, function mergeDeepProperties(prop) {\n if (utils.isObject(config2[prop])) {\n config[prop] = utils.deepMerge(config1[prop], config2[prop]);\n } else if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (utils.isObject(config1[prop])) {\n config[prop] = utils.deepMerge(config1[prop]);\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n\n utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n\n var axiosKeys = valueFromConfig2Keys\n .concat(mergeDeepPropertiesKeys)\n .concat(defaultToConfig2Keys);\n\n var otherKeys = Object\n .keys(config2)\n .filter(function filterAxiosKeys(key) {\n return axiosKeys.indexOf(key) === -1;\n });\n\n utils.forEach(otherKeys, function otherKeysDefaultToConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n\n return config;\n};\n","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n this.message = message;\n}\n\nCancel.prototype.toString = function toString() {\n return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\n\nCancel.prototype.__CANCEL__ = true;\n\nmodule.exports = Cancel;\n","export { default } from './SvgIcon';","export default function _iterableToArray(iter) {\n if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\n\nfunction getStatics(component) {\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n }\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"\n}), 'RadioButtonUnchecked');\n\nexports.default = _default;","// @flow\n'use strict';\n\nvar key = '__global_unique_id__';\n\nmodule.exports = function() {\n return global[key] = (global[key] || 0) + 1;\n};\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","import defineProperty from \"./defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n if (enumerableOnly) symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n keys.push.apply(keys, symbols);\n }\n\n return keys;\n}\n\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? arguments[i] : {};\n\n if (i % 2) {\n ownKeys(Object(source), true).forEach(function (key) {\n defineProperty(target, key, source[key]);\n });\n } else if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n }\n\n return target;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z\"\n}), 'KeyboardArrowRight');\n\nexports.default = _default;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n// Sorted ASC by size. That's important.\n// It can't be configured as it's used statically for propTypes.\nexport var keys = ['xs', 'sm', 'md', 'lg', 'xl']; // Keep in mind that @media is inclusive by the CSS specification.\n\nexport default function createBreakpoints(breakpoints) {\n var _breakpoints$values = breakpoints.values,\n values = _breakpoints$values === void 0 ? {\n xs: 0,\n sm: 600,\n md: 960,\n lg: 1280,\n xl: 1920\n } : _breakpoints$values,\n _breakpoints$unit = breakpoints.unit,\n unit = _breakpoints$unit === void 0 ? 'px' : _breakpoints$unit,\n _breakpoints$step = breakpoints.step,\n step = _breakpoints$step === void 0 ? 5 : _breakpoints$step,\n other = _objectWithoutProperties(breakpoints, [\"values\", \"unit\", \"step\"]);\n\n function up(key) {\n var value = typeof values[key] === 'number' ? values[key] : key;\n return \"@media (min-width:\".concat(value).concat(unit, \")\");\n }\n\n function down(key) {\n var endIndex = keys.indexOf(key) + 1;\n var upperbound = values[keys[endIndex]];\n\n if (endIndex === keys.length) {\n // xl down applies to all sizes\n return up('xs');\n }\n\n var value = typeof upperbound === 'number' && endIndex > 0 ? upperbound : key;\n return \"@media (max-width:\".concat(value - step / 100).concat(unit, \")\");\n }\n\n function between(start, end) {\n var endIndex = keys.indexOf(end);\n\n if (endIndex === keys.length - 1) {\n return up(start);\n }\n\n return \"@media (min-width:\".concat(typeof values[start] === 'number' ? values[start] : start).concat(unit, \") and \") + \"(max-width:\".concat((endIndex !== -1 && typeof values[keys[endIndex + 1]] === 'number' ? values[keys[endIndex + 1]] : end) - step / 100).concat(unit, \")\");\n }\n\n function only(key) {\n return between(key, key);\n }\n\n function width(key) {\n return values[key];\n }\n\n return _extends({\n keys: keys,\n values: values,\n up: up,\n down: down,\n between: between,\n only: only,\n width: width\n }, other);\n}","import _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nexport default function createMixins(breakpoints, spacing, mixins) {\n var _toolbar;\n\n return _extends({\n gutters: function gutters() {\n var styles = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n // To deprecate in v4.1\n // warning(\n // false,\n // [\n // 'Material-UI: theme.mixins.gutters() is deprecated.',\n // 'You can use the source of the mixin directly:',\n // `\n // paddingLeft: theme.spacing(2),\n // paddingRight: theme.spacing(2),\n // [theme.breakpoints.up('sm')]: {\n // paddingLeft: theme.spacing(3),\n // paddingRight: theme.spacing(3),\n // },\n // `,\n // ].join('\\n'),\n // );\n return _extends({\n paddingLeft: spacing(2),\n paddingRight: spacing(2)\n }, styles, _defineProperty({}, breakpoints.up('sm'), _extends({\n paddingLeft: spacing(3),\n paddingRight: spacing(3)\n }, styles[breakpoints.up('sm')])));\n },\n toolbar: (_toolbar = {\n minHeight: 56\n }, _defineProperty(_toolbar, \"\".concat(breakpoints.up('xs'), \" and (orientation: landscape)\"), {\n minHeight: 48\n }), _defineProperty(_toolbar, breakpoints.up('sm'), {\n minHeight: 64\n }), _toolbar)\n }, mixins);\n}","var common = {\n black: '#000',\n white: '#fff'\n};\nexport default common;","var grey = {\n 50: '#fafafa',\n 100: '#f5f5f5',\n 200: '#eeeeee',\n 300: '#e0e0e0',\n 400: '#bdbdbd',\n 500: '#9e9e9e',\n 600: '#757575',\n 700: '#616161',\n 800: '#424242',\n 900: '#212121',\n A100: '#d5d5d5',\n A200: '#aaaaaa',\n A400: '#303030',\n A700: '#616161'\n};\nexport default grey;","var indigo = {\n 50: '#e8eaf6',\n 100: '#c5cae9',\n 200: '#9fa8da',\n 300: '#7986cb',\n 400: '#5c6bc0',\n 500: '#3f51b5',\n 600: '#3949ab',\n 700: '#303f9f',\n 800: '#283593',\n 900: '#1a237e',\n A100: '#8c9eff',\n A200: '#536dfe',\n A400: '#3d5afe',\n A700: '#304ffe'\n};\nexport default indigo;","var pink = {\n 50: '#fce4ec',\n 100: '#f8bbd0',\n 200: '#f48fb1',\n 300: '#f06292',\n 400: '#ec407a',\n 500: '#e91e63',\n 600: '#d81b60',\n 700: '#c2185b',\n 800: '#ad1457',\n 900: '#880e4f',\n A100: '#ff80ab',\n A200: '#ff4081',\n A400: '#f50057',\n A700: '#c51162'\n};\nexport default pink;","var red = {\n 50: '#ffebee',\n 100: '#ffcdd2',\n 200: '#ef9a9a',\n 300: '#e57373',\n 400: '#ef5350',\n 500: '#f44336',\n 600: '#e53935',\n 700: '#d32f2f',\n 800: '#c62828',\n 900: '#b71c1c',\n A100: '#ff8a80',\n A200: '#ff5252',\n A400: '#ff1744',\n A700: '#d50000'\n};\nexport default red;","var orange = {\n 50: '#fff3e0',\n 100: '#ffe0b2',\n 200: '#ffcc80',\n 300: '#ffb74d',\n 400: '#ffa726',\n 500: '#ff9800',\n 600: '#fb8c00',\n 700: '#f57c00',\n 800: '#ef6c00',\n 900: '#e65100',\n A100: '#ffd180',\n A200: '#ffab40',\n A400: '#ff9100',\n A700: '#ff6d00'\n};\nexport default orange;","var blue = {\n 50: '#e3f2fd',\n 100: '#bbdefb',\n 200: '#90caf9',\n 300: '#64b5f6',\n 400: '#42a5f5',\n 500: '#2196f3',\n 600: '#1e88e5',\n 700: '#1976d2',\n 800: '#1565c0',\n 900: '#0d47a1',\n A100: '#82b1ff',\n A200: '#448aff',\n A400: '#2979ff',\n A700: '#2962ff'\n};\nexport default blue;","var green = {\n 50: '#e8f5e9',\n 100: '#c8e6c9',\n 200: '#a5d6a7',\n 300: '#81c784',\n 400: '#66bb6a',\n 500: '#4caf50',\n 600: '#43a047',\n 700: '#388e3c',\n 800: '#2e7d32',\n 900: '#1b5e20',\n A100: '#b9f6ca',\n A200: '#69f0ae',\n A400: '#00e676',\n A700: '#00c853'\n};\nexport default green;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport { deepmerge } from '@material-ui/utils';\nimport common from '../colors/common';\nimport grey from '../colors/grey';\nimport indigo from '../colors/indigo';\nimport pink from '../colors/pink';\nimport red from '../colors/red';\nimport orange from '../colors/orange';\nimport blue from '../colors/blue';\nimport green from '../colors/green';\nimport { darken, getContrastRatio, lighten } from './colorManipulator';\nexport var light = {\n // The colors used to style the text.\n text: {\n // The most important text.\n primary: 'rgba(0, 0, 0, 0.87)',\n // Secondary text.\n secondary: 'rgba(0, 0, 0, 0.54)',\n // Disabled text have even lower visual prominence.\n disabled: 'rgba(0, 0, 0, 0.38)',\n // Text hints.\n hint: 'rgba(0, 0, 0, 0.38)'\n },\n // The color used to divide different elements.\n divider: 'rgba(0, 0, 0, 0.12)',\n // The background colors used to style the surfaces.\n // Consistency between these values is important.\n background: {\n paper: common.white,\n default: grey[50]\n },\n // The colors used to style the action elements.\n action: {\n // The color of an active action like an icon button.\n active: 'rgba(0, 0, 0, 0.54)',\n // The color of an hovered action.\n hover: 'rgba(0, 0, 0, 0.08)',\n hoverOpacity: 0.08,\n // The color of a selected action.\n selected: 'rgba(0, 0, 0, 0.14)',\n // The color of a disabled action.\n disabled: 'rgba(0, 0, 0, 0.26)',\n // The background color of a disabled action.\n disabledBackground: 'rgba(0, 0, 0, 0.12)'\n }\n};\nexport var dark = {\n text: {\n primary: common.white,\n secondary: 'rgba(255, 255, 255, 0.7)',\n disabled: 'rgba(255, 255, 255, 0.5)',\n hint: 'rgba(255, 255, 255, 0.5)',\n icon: 'rgba(255, 255, 255, 0.5)'\n },\n divider: 'rgba(255, 255, 255, 0.12)',\n background: {\n paper: grey[800],\n default: '#303030'\n },\n action: {\n active: common.white,\n hover: 'rgba(255, 255, 255, 0.1)',\n hoverOpacity: 0.1,\n selected: 'rgba(255, 255, 255, 0.2)',\n disabled: 'rgba(255, 255, 255, 0.3)',\n disabledBackground: 'rgba(255, 255, 255, 0.12)'\n }\n};\n\nfunction addLightOrDark(intent, direction, shade, tonalOffset) {\n if (!intent[direction]) {\n if (intent.hasOwnProperty(shade)) {\n intent[direction] = intent[shade];\n } else if (direction === 'light') {\n intent.light = lighten(intent.main, tonalOffset);\n } else if (direction === 'dark') {\n intent.dark = darken(intent.main, tonalOffset * 1.5);\n }\n }\n}\n\nexport default function createPalette(palette) {\n var _palette$primary = palette.primary,\n primary = _palette$primary === void 0 ? {\n light: indigo[300],\n main: indigo[500],\n dark: indigo[700]\n } : _palette$primary,\n _palette$secondary = palette.secondary,\n secondary = _palette$secondary === void 0 ? {\n light: pink.A200,\n main: pink.A400,\n dark: pink.A700\n } : _palette$secondary,\n _palette$error = palette.error,\n error = _palette$error === void 0 ? {\n light: red[300],\n main: red[500],\n dark: red[700]\n } : _palette$error,\n _palette$warning = palette.warning,\n warning = _palette$warning === void 0 ? {\n light: orange[300],\n main: orange[500],\n dark: orange[700]\n } : _palette$warning,\n _palette$info = palette.info,\n info = _palette$info === void 0 ? {\n light: blue[300],\n main: blue[500],\n dark: blue[700]\n } : _palette$info,\n _palette$success = palette.success,\n success = _palette$success === void 0 ? {\n light: green[300],\n main: green[500],\n dark: green[700]\n } : _palette$success,\n _palette$type = palette.type,\n type = _palette$type === void 0 ? 'light' : _palette$type,\n _palette$contrastThre = palette.contrastThreshold,\n contrastThreshold = _palette$contrastThre === void 0 ? 3 : _palette$contrastThre,\n _palette$tonalOffset = palette.tonalOffset,\n tonalOffset = _palette$tonalOffset === void 0 ? 0.2 : _palette$tonalOffset,\n other = _objectWithoutProperties(palette, [\"primary\", \"secondary\", \"error\", \"warning\", \"info\", \"success\", \"type\", \"contrastThreshold\", \"tonalOffset\"]); // Use the same logic as\n // Bootstrap: https://github.com/twbs/bootstrap/blob/1d6e3710dd447de1a200f29e8fa521f8a0908f70/scss/_functions.scss#L59\n // and material-components-web https://github.com/material-components/material-components-web/blob/ac46b8863c4dab9fc22c4c662dc6bd1b65dd652f/packages/mdc-theme/_functions.scss#L54\n\n\n function getContrastText(background) {\n if (!background) {\n throw new TypeError(\"Material-UI: missing background argument in getContrastText(\".concat(background, \").\"));\n }\n\n var contrastText = getContrastRatio(background, dark.text.primary) >= contrastThreshold ? dark.text.primary : light.text.primary;\n\n if (process.env.NODE_ENV !== 'production') {\n var contrast = getContrastRatio(background, contrastText);\n\n if (contrast < 3) {\n console.error([\"Material-UI: the contrast ratio of \".concat(contrast, \":1 for \").concat(contrastText, \" on \").concat(background), 'falls below the WCAG recommended absolute minimum contrast ratio of 3:1.', 'https://www.w3.org/TR/2008/REC-WCAG20-20081211/#visual-audio-contrast-contrast'].join('\\n'));\n }\n }\n\n return contrastText;\n }\n\n function augmentColor(color) {\n var mainShade = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 500;\n var lightShade = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 300;\n var darkShade = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 700;\n color = _extends({}, color);\n\n if (!color.main && color[mainShade]) {\n color.main = color[mainShade];\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (!color.main) {\n throw new Error(['Material-UI: the color provided to augmentColor(color) is invalid.', \"The color object needs to have a `main` property or a `\".concat(mainShade, \"` property.\")].join('\\n'));\n }\n }\n\n addLightOrDark(color, 'light', lightShade, tonalOffset);\n addLightOrDark(color, 'dark', darkShade, tonalOffset);\n\n if (!color.contrastText) {\n color.contrastText = getContrastText(color.main);\n }\n\n return color;\n }\n\n var types = {\n dark: dark,\n light: light\n };\n\n if (process.env.NODE_ENV !== 'production') {\n if (!types[type]) {\n console.error(\"Material-UI: the palette type `\".concat(type, \"` is not supported.\"));\n }\n }\n\n var paletteOutput = deepmerge(_extends({\n // A collection of common colors.\n common: common,\n // The palette type, can be light or dark.\n type: type,\n // The colors used to represent primary interface elements for a user.\n primary: augmentColor(primary),\n // The colors used to represent secondary interface elements for a user.\n secondary: augmentColor(secondary, 'A400', 'A200', 'A700'),\n // The colors used to represent interface elements that the user should be made aware of.\n error: augmentColor(error),\n // The colors used to represent potentially dangerous actions or important messages.\n warning: augmentColor(warning),\n // The colors used to present information to the user that is neutral and not necessarily important.\n info: augmentColor(info),\n // The colors used to indicate the successful completion of an action that user triggered.\n success: augmentColor(success),\n // The grey colors.\n grey: grey,\n // Used by `getContrastText()` to maximize the contrast between\n // the background and the text.\n contrastThreshold: contrastThreshold,\n // Takes a background color and returns the text color that maximizes the contrast.\n getContrastText: getContrastText,\n // Generate a rich color object.\n augmentColor: augmentColor,\n // Used by the functions below to shift a color's luminance by approximately\n // two indexes within its tonal palette.\n // E.g., shift from Red 500 to Red 300 or Red 700.\n tonalOffset: tonalOffset\n }, types[type]), other);\n return paletteOutput;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport { deepmerge } from '@material-ui/utils';\n\nfunction round(value) {\n return Math.round(value * 1e5) / 1e5;\n}\n\nvar caseAllCaps = {\n textTransform: 'uppercase'\n};\nvar defaultFontFamily = '\"Roboto\", \"Helvetica\", \"Arial\", sans-serif';\n/**\n * @see @link{https://material.io/design/typography/the-type-system.html}\n * @see @link{https://material.io/design/typography/understanding-typography.html}\n */\n\nexport default function createTypography(palette, typography) {\n var _ref = typeof typography === 'function' ? typography(palette) : typography,\n _ref$fontFamily = _ref.fontFamily,\n fontFamily = _ref$fontFamily === void 0 ? defaultFontFamily : _ref$fontFamily,\n _ref$fontSize = _ref.fontSize,\n fontSize = _ref$fontSize === void 0 ? 14 : _ref$fontSize,\n _ref$fontWeightLight = _ref.fontWeightLight,\n fontWeightLight = _ref$fontWeightLight === void 0 ? 300 : _ref$fontWeightLight,\n _ref$fontWeightRegula = _ref.fontWeightRegular,\n fontWeightRegular = _ref$fontWeightRegula === void 0 ? 400 : _ref$fontWeightRegula,\n _ref$fontWeightMedium = _ref.fontWeightMedium,\n fontWeightMedium = _ref$fontWeightMedium === void 0 ? 500 : _ref$fontWeightMedium,\n _ref$fontWeightBold = _ref.fontWeightBold,\n fontWeightBold = _ref$fontWeightBold === void 0 ? 700 : _ref$fontWeightBold,\n _ref$htmlFontSize = _ref.htmlFontSize,\n htmlFontSize = _ref$htmlFontSize === void 0 ? 16 : _ref$htmlFontSize,\n allVariants = _ref.allVariants,\n pxToRem2 = _ref.pxToRem,\n other = _objectWithoutProperties(_ref, [\"fontFamily\", \"fontSize\", \"fontWeightLight\", \"fontWeightRegular\", \"fontWeightMedium\", \"fontWeightBold\", \"htmlFontSize\", \"allVariants\", \"pxToRem\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof fontSize !== 'number') {\n console.error('Material-UI: `fontSize` is required to be a number.');\n }\n\n if (typeof htmlFontSize !== 'number') {\n console.error('Material-UI: `htmlFontSize` is required to be a number.');\n }\n }\n\n var coef = fontSize / 14;\n\n var pxToRem = pxToRem2 || function (size) {\n return \"\".concat(size / htmlFontSize * coef, \"rem\");\n };\n\n var buildVariant = function buildVariant(fontWeight, size, lineHeight, letterSpacing, casing) {\n return _extends({\n fontFamily: fontFamily,\n fontWeight: fontWeight,\n fontSize: pxToRem(size),\n // Unitless following https://meyerweb.com/eric/thoughts/2006/02/08/unitless-line-heights/\n lineHeight: lineHeight\n }, fontFamily === defaultFontFamily ? {\n letterSpacing: \"\".concat(round(letterSpacing / size), \"em\")\n } : {}, {}, casing, {}, allVariants);\n };\n\n var variants = {\n h1: buildVariant(fontWeightLight, 96, 1.167, -1.5),\n h2: buildVariant(fontWeightLight, 60, 1.2, -0.5),\n h3: buildVariant(fontWeightRegular, 48, 1.167, 0),\n h4: buildVariant(fontWeightRegular, 34, 1.235, 0.25),\n h5: buildVariant(fontWeightRegular, 24, 1.334, 0),\n h6: buildVariant(fontWeightMedium, 20, 1.6, 0.15),\n subtitle1: buildVariant(fontWeightRegular, 16, 1.75, 0.15),\n subtitle2: buildVariant(fontWeightMedium, 14, 1.57, 0.1),\n body1: buildVariant(fontWeightRegular, 16, 1.5, 0.15),\n body2: buildVariant(fontWeightRegular, 14, 1.43, 0.15),\n button: buildVariant(fontWeightMedium, 14, 1.75, 0.4, caseAllCaps),\n caption: buildVariant(fontWeightRegular, 12, 1.66, 0.4),\n overline: buildVariant(fontWeightRegular, 12, 2.66, 1, caseAllCaps)\n };\n return deepmerge(_extends({\n htmlFontSize: htmlFontSize,\n pxToRem: pxToRem,\n round: round,\n // TODO To remove in v5?\n fontFamily: fontFamily,\n fontSize: fontSize,\n fontWeightLight: fontWeightLight,\n fontWeightRegular: fontWeightRegular,\n fontWeightMedium: fontWeightMedium,\n fontWeightBold: fontWeightBold\n }, variants), other, {\n clone: false // No need to clone deep\n\n });\n}","var shadowKeyUmbraOpacity = 0.2;\nvar shadowKeyPenumbraOpacity = 0.14;\nvar shadowAmbientShadowOpacity = 0.12;\n\nfunction createShadow() {\n return [\"\".concat(arguments.length <= 0 ? undefined : arguments[0], \"px \").concat(arguments.length <= 1 ? undefined : arguments[1], \"px \").concat(arguments.length <= 2 ? undefined : arguments[2], \"px \").concat(arguments.length <= 3 ? undefined : arguments[3], \"px rgba(0,0,0,\").concat(shadowKeyUmbraOpacity, \")\"), \"\".concat(arguments.length <= 4 ? undefined : arguments[4], \"px \").concat(arguments.length <= 5 ? undefined : arguments[5], \"px \").concat(arguments.length <= 6 ? undefined : arguments[6], \"px \").concat(arguments.length <= 7 ? undefined : arguments[7], \"px rgba(0,0,0,\").concat(shadowKeyPenumbraOpacity, \")\"), \"\".concat(arguments.length <= 8 ? undefined : arguments[8], \"px \").concat(arguments.length <= 9 ? undefined : arguments[9], \"px \").concat(arguments.length <= 10 ? undefined : arguments[10], \"px \").concat(arguments.length <= 11 ? undefined : arguments[11], \"px rgba(0,0,0,\").concat(shadowAmbientShadowOpacity, \")\")].join(',');\n} // Values from https://github.com/material-components/material-components-web/blob/be8747f94574669cb5e7add1a7c54fa41a89cec7/packages/mdc-elevation/_variables.scss\n\n\nvar shadows = ['none', createShadow(0, 2, 1, -1, 0, 1, 1, 0, 0, 1, 3, 0), createShadow(0, 3, 1, -2, 0, 2, 2, 0, 0, 1, 5, 0), createShadow(0, 3, 3, -2, 0, 3, 4, 0, 0, 1, 8, 0), createShadow(0, 2, 4, -1, 0, 4, 5, 0, 0, 1, 10, 0), createShadow(0, 3, 5, -1, 0, 5, 8, 0, 0, 1, 14, 0), createShadow(0, 3, 5, -1, 0, 6, 10, 0, 0, 1, 18, 0), createShadow(0, 4, 5, -2, 0, 7, 10, 1, 0, 2, 16, 1), createShadow(0, 5, 5, -3, 0, 8, 10, 1, 0, 3, 14, 2), createShadow(0, 5, 6, -3, 0, 9, 12, 1, 0, 3, 16, 2), createShadow(0, 6, 6, -3, 0, 10, 14, 1, 0, 4, 18, 3), createShadow(0, 6, 7, -4, 0, 11, 15, 1, 0, 4, 20, 3), createShadow(0, 7, 8, -4, 0, 12, 17, 2, 0, 5, 22, 4), createShadow(0, 7, 8, -4, 0, 13, 19, 2, 0, 5, 24, 4), createShadow(0, 7, 9, -4, 0, 14, 21, 2, 0, 5, 26, 4), createShadow(0, 8, 9, -5, 0, 15, 22, 2, 0, 6, 28, 5), createShadow(0, 8, 10, -5, 0, 16, 24, 2, 0, 6, 30, 5), createShadow(0, 8, 11, -5, 0, 17, 26, 2, 0, 6, 32, 5), createShadow(0, 9, 11, -5, 0, 18, 28, 2, 0, 7, 34, 6), createShadow(0, 9, 12, -6, 0, 19, 29, 2, 0, 7, 36, 6), createShadow(0, 10, 13, -6, 0, 20, 31, 3, 0, 8, 38, 7), createShadow(0, 10, 13, -6, 0, 21, 33, 3, 0, 8, 40, 7), createShadow(0, 10, 14, -6, 0, 22, 35, 3, 0, 8, 42, 7), createShadow(0, 11, 14, -7, 0, 23, 36, 3, 0, 9, 44, 8), createShadow(0, 11, 15, -7, 0, 24, 38, 3, 0, 9, 46, 8)];\nexport default shadows;","var shape = {\n borderRadius: 4\n};\nexport default shape;","var warnOnce;\nexport default function createSpacing() {\n var spacingInput = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 8;\n\n // Already transformed.\n if (spacingInput.mui) {\n return spacingInput;\n } // All components align to an 8dp square baseline grid for mobile, tablet, and desktop.\n // https://material.io/design/layout/understanding-layout.html#pixel-density\n\n\n var transform;\n\n if (typeof spacingInput === 'function') {\n transform = spacingInput;\n } else {\n if (process.env.NODE_ENV !== 'production') {\n if (typeof spacingInput !== 'number') {\n console.error([\"Material-UI: the `theme.spacing` value (\".concat(spacingInput, \") is invalid.\"), 'It should be a number or a function.'].join('\\n'));\n }\n }\n\n transform = function transform(factor) {\n if (process.env.NODE_ENV !== 'production') {\n if (typeof factor !== 'number') {\n console.error(\"Expected spacing argument to be a number, got \".concat(factor));\n }\n }\n\n return spacingInput * factor;\n };\n }\n\n var spacing = function spacing() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (!(args.length <= 4)) {\n console.error(\"Material-UI: Too many arguments provided, expected between 0 and 4, got \".concat(args.length));\n }\n }\n\n if (args.length === 0) {\n return transform(1);\n }\n\n if (args.length === 1) {\n return transform(args[0]);\n }\n\n return args.map(function (factor) {\n var output = transform(factor);\n return typeof output === 'number' ? \"\".concat(output, \"px\") : output;\n }).join(' ');\n }; // Backward compatibility, to remove in v5.\n\n\n Object.defineProperty(spacing, 'unit', {\n get: function get() {\n if (process.env.NODE_ENV !== 'production') {\n if (!warnOnce || process.env.NODE_ENV === 'test') {\n console.error(['Material-UI: theme.spacing.unit usage has been deprecated.', 'It will be removed in v5.', 'You can replace `theme.spacing.unit * y` with `theme.spacing(y)`.', '', 'You can use the `https://github.com/mui-org/material-ui/tree/master/packages/material-ui-codemod/README.md#theme-spacing-api` migration helper to make the process smoother.'].join('\\n'));\n }\n\n warnOnce = true;\n }\n\n return spacingInput;\n }\n });\n spacing.mui = true;\n return spacing;\n}","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n// Follow https://material.google.com/motion/duration-easing.html#duration-easing-natural-easing-curves\n// to learn the context in which each easing should be used.\nexport var easing = {\n // This is the most common easing curve.\n easeInOut: 'cubic-bezier(0.4, 0, 0.2, 1)',\n // Objects enter the screen at full velocity from off-screen and\n // slowly decelerate to a resting point.\n easeOut: 'cubic-bezier(0.0, 0, 0.2, 1)',\n // Objects leave the screen at full velocity. They do not decelerate when off-screen.\n easeIn: 'cubic-bezier(0.4, 0, 1, 1)',\n // The sharp curve is used by objects that may return to the screen at any time.\n sharp: 'cubic-bezier(0.4, 0, 0.6, 1)'\n}; // Follow https://material.io/guidelines/motion/duration-easing.html#duration-easing-common-durations\n// to learn when use what timing\n\nexport var duration = {\n shortest: 150,\n shorter: 200,\n short: 250,\n // most basic recommended timing\n standard: 300,\n // this is to be used in complex animations\n complex: 375,\n // recommended when something is entering screen\n enteringScreen: 225,\n // recommended when something is leaving screen\n leavingScreen: 195\n};\nexport var formatMs = function formatMs(milliseconds) {\n return \"\".concat(Math.round(milliseconds), \"ms\");\n};\nexport var isString = function isString(value) {\n return typeof value === 'string';\n};\nexport var isNumber = function isNumber(value) {\n return !isNaN(parseFloat(value));\n};\n/**\n * @param {string|Array} props\n * @param {object} param\n * @param {string} param.prop\n * @param {number} param.duration\n * @param {string} param.easing\n * @param {number} param.delay\n */\n\nexport default {\n easing: easing,\n duration: duration,\n create: function create() {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ['all'];\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var _options$duration = options.duration,\n durationOption = _options$duration === void 0 ? duration.standard : _options$duration,\n _options$easing = options.easing,\n easingOption = _options$easing === void 0 ? easing.easeInOut : _options$easing,\n _options$delay = options.delay,\n delay = _options$delay === void 0 ? 0 : _options$delay,\n other = _objectWithoutProperties(options, [\"duration\", \"easing\", \"delay\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (!isString(props) && !Array.isArray(props)) {\n console.error('Material-UI: argument \"props\" must be a string or Array.');\n }\n\n if (!isNumber(durationOption) && !isString(durationOption)) {\n console.error(\"Material-UI: argument \\\"duration\\\" must be a number or a string but found \".concat(durationOption, \".\"));\n }\n\n if (!isString(easingOption)) {\n console.error('Material-UI: argument \"easing\" must be a string.');\n }\n\n if (!isNumber(delay) && !isString(delay)) {\n console.error('Material-UI: argument \"delay\" must be a number or a string.');\n }\n\n if (Object.keys(other).length !== 0) {\n console.error(\"Material-UI: unrecognized argument(s) [\".concat(Object.keys(other).join(','), \"]\"));\n }\n }\n\n return (Array.isArray(props) ? props : [props]).map(function (animatedProp) {\n return \"\".concat(animatedProp, \" \").concat(typeof durationOption === 'string' ? durationOption : formatMs(durationOption), \" \").concat(easingOption, \" \").concat(typeof delay === 'string' ? delay : formatMs(delay));\n }).join(',');\n },\n getAutoHeightDuration: function getAutoHeightDuration(height) {\n if (!height) {\n return 0;\n }\n\n var constant = height / 36; // https://www.wolframalpha.com/input/?i=(4+%2B+15+*+(x+%2F+36+)+**+0.25+%2B+(x+%2F+36)+%2F+5)+*+10\n\n return Math.round((4 + 15 * Math.pow(constant, 0.25) + constant / 5) * 10);\n }\n};","import _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport { deepmerge } from '@material-ui/utils';\nimport createBreakpoints from './createBreakpoints';\nimport createMixins from './createMixins';\nimport createPalette from './createPalette';\nimport createTypography from './createTypography';\nimport shadows from './shadows';\nimport shape from './shape';\nimport createSpacing from './createSpacing';\nimport transitions from './transitions';\nimport zIndex from './zIndex';\n\nfunction createMuiTheme() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n var _options$breakpoints = options.breakpoints,\n breakpointsInput = _options$breakpoints === void 0 ? {} : _options$breakpoints,\n _options$mixins = options.mixins,\n mixinsInput = _options$mixins === void 0 ? {} : _options$mixins,\n _options$palette = options.palette,\n paletteInput = _options$palette === void 0 ? {} : _options$palette,\n spacingInput = options.spacing,\n _options$typography = options.typography,\n typographyInput = _options$typography === void 0 ? {} : _options$typography,\n other = _objectWithoutProperties(options, [\"breakpoints\", \"mixins\", \"palette\", \"spacing\", \"typography\"]);\n\n var palette = createPalette(paletteInput);\n var breakpoints = createBreakpoints(breakpointsInput);\n var spacing = createSpacing(spacingInput);\n var muiTheme = deepmerge({\n breakpoints: breakpoints,\n direction: 'ltr',\n mixins: createMixins(breakpoints, spacing, mixinsInput),\n overrides: {},\n // Inject custom styles\n palette: palette,\n props: {},\n // Provide default props\n shadows: shadows,\n typography: createTypography(palette, typographyInput),\n spacing: spacing,\n shape: shape,\n transitions: transitions,\n zIndex: zIndex\n }, other);\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n muiTheme = args.reduce(function (acc, argument) {\n return deepmerge(acc, argument);\n }, muiTheme);\n\n if (process.env.NODE_ENV !== 'production') {\n var pseudoClasses = ['checked', 'disabled', 'error', 'focused', 'focusVisible', 'required', 'expanded', 'selected'];\n\n var traverse = function traverse(node, parentKey) {\n var depth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;\n var key; // eslint-disable-next-line guard-for-in, no-restricted-syntax\n\n for (key in node) {\n var child = node[key];\n\n if (depth === 1) {\n if (key.indexOf('Mui') === 0 && child) {\n traverse(child, key, depth + 1);\n }\n } else if (pseudoClasses.indexOf(key) !== -1 && Object.keys(child).length > 0) {\n if (process.env.NODE_ENV !== 'production') {\n console.error([\"Material-UI: the `\".concat(parentKey, \"` component increases \") + \"the CSS specificity of the `\".concat(key, \"` internal state.\"), 'You can not override it like this: ', JSON.stringify(node, null, 2), '', 'Instead, you need to use the $ruleName syntax:', JSON.stringify({\n root: _defineProperty({}, \"&$\".concat(key), child)\n }, null, 2), '', 'https://material-ui.com/r/pseudo-classes-guide'].join('\\n'));\n } // Remove the style to prevent global conflicts.\n\n\n node[key] = {};\n }\n }\n };\n\n traverse(muiTheme.overrides);\n }\n\n return muiTheme;\n}\n\nexport default createMuiTheme;","import React from 'react';\nimport ThemeContext from './ThemeContext';\nexport default function useTheme() {\n return React.useContext(ThemeContext);\n}","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nvar useEnhancedEffect = typeof window !== 'undefined' && process.env.NODE_ENV !== 'test' ? React.useLayoutEffect : React.useEffect;\n/**\n * NoSsr purposely removes components from the subject of Server Side Rendering (SSR).\n *\n * This component can be useful in a variety of situations:\n * - Escape hatch for broken dependencies not supporting SSR.\n * - Improve the time-to-first paint on the client by only rendering above the fold.\n * - Reduce the rendering time on the server.\n * - Under too heavy server load, you can turn on service degradation.\n */\n\nfunction NoSsr(props) {\n var children = props.children,\n _props$defer = props.defer,\n defer = _props$defer === void 0 ? false : _props$defer,\n _props$fallback = props.fallback,\n fallback = _props$fallback === void 0 ? null : _props$fallback;\n\n var _React$useState = React.useState(false),\n mountedState = _React$useState[0],\n setMountedState = _React$useState[1];\n\n useEnhancedEffect(function () {\n if (!defer) {\n setMountedState(true);\n }\n }, [defer]);\n React.useEffect(function () {\n if (defer) {\n setMountedState(true);\n }\n }, [defer]); // We need the Fragment here to force react-docgen to recognise NoSsr as a component.\n\n return React.createElement(React.Fragment, null, mountedState ? children : fallback);\n}\n\nprocess.env.NODE_ENV !== \"production\" ? NoSsr.propTypes = {\n /**\n * You can wrap a node.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * If `true`, the component will not only prevent server-side rendering.\n * It will also defer the rendering of the children into a different screen frame.\n */\n defer: PropTypes.bool,\n\n /**\n * The fallback content to display.\n */\n fallback: PropTypes.node\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n NoSsr['propTypes' + ''] = exactProp(NoSsr.propTypes);\n}\n\nexport default NoSsr;","// based on https://github.com/WICG/focus-visible/blob/v4.1.5/src/focus-visible.js\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nvar hadKeyboardEvent = true;\nvar hadFocusVisibleRecently = false;\nvar hadFocusVisibleRecentlyTimeout = null;\nvar inputTypesWhitelist = {\n text: true,\n search: true,\n url: true,\n tel: true,\n email: true,\n password: true,\n number: true,\n date: true,\n month: true,\n week: true,\n time: true,\n datetime: true,\n 'datetime-local': true\n};\n/**\n * Computes whether the given element should automatically trigger the\n * `focus-visible` class being added, i.e. whether it should always match\n * `:focus-visible` when focused.\n * @param {Element} node\n * @return {boolean}\n */\n\nfunction focusTriggersKeyboardModality(node) {\n var type = node.type,\n tagName = node.tagName;\n\n if (tagName === 'INPUT' && inputTypesWhitelist[type] && !node.readOnly) {\n return true;\n }\n\n if (tagName === 'TEXTAREA' && !node.readOnly) {\n return true;\n }\n\n if (node.isContentEditable) {\n return true;\n }\n\n return false;\n}\n/**\n * Keep track of our keyboard modality state with `hadKeyboardEvent`.\n * If the most recent user interaction was via the keyboard;\n * and the key press did not include a meta, alt/option, or control key;\n * then the modality is keyboard. Otherwise, the modality is not keyboard.\n * @param {KeyboardEvent} event\n */\n\n\nfunction handleKeyDown(event) {\n if (event.metaKey || event.altKey || event.ctrlKey) {\n return;\n }\n\n hadKeyboardEvent = true;\n}\n/**\n * If at any point a user clicks with a pointing device, ensure that we change\n * the modality away from keyboard.\n * This avoids the situation where a user presses a key on an already focused\n * element, and then clicks on a different element, focusing it with a\n * pointing device, while we still think we're in keyboard modality.\n */\n\n\nfunction handlePointerDown() {\n hadKeyboardEvent = false;\n}\n\nfunction handleVisibilityChange() {\n if (this.visibilityState === 'hidden') {\n // If the tab becomes active again, the browser will handle calling focus\n // on the element (Safari actually calls it twice).\n // If this tab change caused a blur on an element with focus-visible,\n // re-apply the class when the user switches back to the tab.\n if (hadFocusVisibleRecently) {\n hadKeyboardEvent = true;\n }\n }\n}\n\nfunction prepare(doc) {\n doc.addEventListener('keydown', handleKeyDown, true);\n doc.addEventListener('mousedown', handlePointerDown, true);\n doc.addEventListener('pointerdown', handlePointerDown, true);\n doc.addEventListener('touchstart', handlePointerDown, true);\n doc.addEventListener('visibilitychange', handleVisibilityChange, true);\n}\n\nexport function teardown(doc) {\n doc.removeEventListener('keydown', handleKeyDown, true);\n doc.removeEventListener('mousedown', handlePointerDown, true);\n doc.removeEventListener('pointerdown', handlePointerDown, true);\n doc.removeEventListener('touchstart', handlePointerDown, true);\n doc.removeEventListener('visibilitychange', handleVisibilityChange, true);\n}\n\nfunction isFocusVisible(event) {\n var target = event.target;\n\n try {\n return target.matches(':focus-visible');\n } catch (error) {} // browsers not implementing :focus-visible will throw a SyntaxError\n // we use our own heuristic for those browsers\n // rethrow might be better if it's not the expected error but do we really\n // want to crash if focus-visible malfunctioned?\n // no need for validFocusTarget check. the user does that by attaching it to\n // focusable events only\n\n\n return hadKeyboardEvent || focusTriggersKeyboardModality(target);\n}\n/**\n * Should be called if a blur event is fired on a focus-visible element\n */\n\n\nfunction handleBlurVisible() {\n // To detect a tab/window switch, we look for a blur event followed\n // rapidly by a visibility change.\n // If we don't see a visibility change within 100ms, it's probably a\n // regular focus change.\n hadFocusVisibleRecently = true;\n window.clearTimeout(hadFocusVisibleRecentlyTimeout);\n hadFocusVisibleRecentlyTimeout = window.setTimeout(function () {\n hadFocusVisibleRecently = false;\n }, 100);\n}\n\nexport function useIsFocusVisible() {\n var ref = React.useCallback(function (instance) {\n var node = ReactDOM.findDOMNode(instance);\n\n if (node != null) {\n prepare(node.ownerDocument);\n }\n }, []);\n return {\n isFocusVisible: isFocusVisible,\n onBlurVisible: handleBlurVisible,\n ref: ref\n };\n}","import { Children, cloneElement, isValidElement } from 'react';\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\n\nexport function getChildMapping(children, mapFn) {\n var mapper = function mapper(child) {\n return mapFn && isValidElement(child) ? mapFn(child) : child;\n };\n\n var result = Object.create(null);\n if (children) Children.map(children, function (c) {\n return c;\n }).forEach(function (child) {\n // run the map function here instead so that the key is the computed one\n result[child.key] = mapper(child);\n });\n return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\nexport function mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n return key in next ? next[key] : prev[key];\n } // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n\n\n var nextKeysPending = Object.create(null);\n var pendingKeys = [];\n\n for (var prevKey in prev) {\n if (prevKey in next) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i;\n var childMapping = {};\n\n for (var nextKey in next) {\n if (nextKeysPending[nextKey]) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n\n childMapping[nextKey] = getValueForKey(nextKey);\n } // Finally, add the keys which didn't appear before any key in `next`\n\n\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nexport function getInitialChildMapping(props, onExited) {\n return getChildMapping(props.children, function (child) {\n return cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n appear: getProp(child, 'appear', props),\n enter: getProp(child, 'enter', props),\n exit: getProp(child, 'exit', props)\n });\n });\n}\nexport function getNextChildMapping(nextProps, prevChildMapping, onExited) {\n var nextChildMapping = getChildMapping(nextProps.children);\n var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n Object.keys(children).forEach(function (key) {\n var child = children[key];\n if (!isValidElement(child)) return;\n var hasPrev = key in prevChildMapping;\n var hasNext = key in nextChildMapping;\n var prevChild = prevChildMapping[key];\n var isLeaving = isValidElement(prevChild) && !prevChild.props.in; // item is new (entering)\n\n if (hasNext && (!hasPrev || isLeaving)) {\n // console.log('entering', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n } else if (!hasNext && hasPrev && !isLeaving) {\n // item is old (exiting)\n // console.log('leaving', key)\n children[key] = cloneElement(child, {\n in: false\n });\n } else if (hasNext && hasPrev && isValidElement(prevChild)) {\n // item hasn't changed transition states\n // copy over the last transition props;\n // console.log('unchanged', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: prevChild.props.in,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n }\n });\n return children;\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { getChildMapping, getInitialChildMapping, getNextChildMapping } from './utils/ChildMapping';\n\nvar values = Object.values || function (obj) {\n return Object.keys(obj).map(function (k) {\n return obj[k];\n });\n};\n\nvar defaultProps = {\n component: 'div',\n childFactory: function childFactory(child) {\n return child;\n }\n /**\n * The `<TransitionGroup>` component manages a set of transition components\n * (`<Transition>` and `<CSSTransition>`) in a list. Like with the transition\n * components, `<TransitionGroup>` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the `<TransitionGroup>`.\n *\n * Note that `<TransitionGroup>` does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\n};\n\nvar TransitionGroup =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n\n var handleExited = _this.handleExited.bind(_assertThisInitialized(_assertThisInitialized(_this))); // Initial children should all be entering, dependent on appear\n\n\n _this.state = {\n contextValue: {\n isMounting: true\n },\n handleExited: handleExited,\n firstRender: true\n };\n return _this;\n }\n\n var _proto = TransitionGroup.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.mounted = true;\n this.setState({\n contextValue: {\n isMounting: false\n }\n });\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.mounted = false;\n };\n\n TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n var prevChildMapping = _ref.children,\n handleExited = _ref.handleExited,\n firstRender = _ref.firstRender;\n return {\n children: firstRender ? getInitialChildMapping(nextProps, handleExited) : getNextChildMapping(nextProps, prevChildMapping, handleExited),\n firstRender: false\n };\n };\n\n _proto.handleExited = function handleExited(child, node) {\n var currentChildMapping = getChildMapping(this.props.children);\n if (child.key in currentChildMapping) return;\n\n if (child.props.onExited) {\n child.props.onExited(node);\n }\n\n if (this.mounted) {\n this.setState(function (state) {\n var children = _extends({}, state.children);\n\n delete children[child.key];\n return {\n children: children\n };\n });\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n Component = _this$props.component,\n childFactory = _this$props.childFactory,\n props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n var contextValue = this.state.contextValue;\n var children = values(this.state.children).map(childFactory);\n delete props.appear;\n delete props.enter;\n delete props.exit;\n\n if (Component === null) {\n return React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, children);\n }\n\n return React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, React.createElement(Component, props, children));\n };\n\n return TransitionGroup;\n}(React.Component);\n\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * `<TransitionGroup>` renders a `<div>` by default. You can change this\n * behavior by providing a `component` prop.\n * If you use React v16+ and would like to avoid a wrapping `<div>` element\n * you can pass in `component={null}`. This is useful if the wrapping div\n * borks your css styles.\n */\n component: PropTypes.any,\n\n /**\n * A set of `<Transition>` components, that are toggled `in` and out as they\n * leave. the `<TransitionGroup>` will inject specific transition props, so\n * remember to spread them through if you are wrapping the `<Transition>` as\n * with our `<Fade>` example.\n *\n * While this component is meant for multiple `Transition` or `CSSTransition`\n * children, sometimes you may want to have a single transition child with\n * content that you want to be transitioned out and in when you change it\n * (e.g. routes, images etc.) In that case you can change the `key` prop of\n * the transition child as you change its content, this will cause\n * `TransitionGroup` to transition the child out and back in.\n */\n children: PropTypes.node,\n\n /**\n * A convenience prop that enables or disables appear animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n appear: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables enter animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables exit animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * You may need to apply reactive updates to a child as it is exiting.\n * This is generally done by using `cloneElement` however in the case of an exiting\n * child the element has already been removed and not accessible to the consumer.\n *\n * If you do need to update a child as it leaves you can provide a `childFactory`\n * to wrap every child, even the ones that are leaving.\n *\n * @type Function(child: ReactElement) -> ReactElement\n */\n childFactory: PropTypes.func\n} : {};\nTransitionGroup.defaultProps = defaultProps;\nexport default TransitionGroup;","import React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport useEventCallback from '../utils/useEventCallback';\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * @ignore - internal component.\n */\n\nfunction Ripple(props) {\n var classes = props.classes,\n _props$pulsate = props.pulsate,\n pulsate = _props$pulsate === void 0 ? false : _props$pulsate,\n rippleX = props.rippleX,\n rippleY = props.rippleY,\n rippleSize = props.rippleSize,\n inProp = props.in,\n _props$onExited = props.onExited,\n onExited = _props$onExited === void 0 ? function () {} : _props$onExited,\n timeout = props.timeout;\n\n var _React$useState = React.useState(false),\n leaving = _React$useState[0],\n setLeaving = _React$useState[1];\n\n var rippleClassName = clsx(classes.ripple, classes.rippleVisible, pulsate && classes.ripplePulsate);\n var rippleStyles = {\n width: rippleSize,\n height: rippleSize,\n top: -(rippleSize / 2) + rippleY,\n left: -(rippleSize / 2) + rippleX\n };\n var childClassName = clsx(classes.child, leaving && classes.childLeaving, pulsate && classes.childPulsate);\n var handleExited = useEventCallback(onExited); // Ripple is used for user feedback (e.g. click or press) so we want to apply styles with the highest priority\n\n useEnhancedEffect(function () {\n if (!inProp) {\n // react-transition-group#onExit\n setLeaving(true); // react-transition-group#onExited\n\n var timeoutId = setTimeout(handleExited, timeout);\n return function () {\n clearTimeout(timeoutId);\n };\n }\n\n return undefined;\n }, [handleExited, inProp, timeout]);\n return React.createElement(\"span\", {\n className: rippleClassName,\n style: rippleStyles\n }, React.createElement(\"span\", {\n className: childClassName\n }));\n}\n\nprocess.env.NODE_ENV !== \"production\" ? Ripple.propTypes = {\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore - injected from TransitionGroup\n */\n in: PropTypes.bool,\n\n /**\n * @ignore - injected from TransitionGroup\n */\n onExited: PropTypes.func,\n\n /**\n * If `true`, the ripple pulsates, typically indicating the keyboard focus state of an element.\n */\n pulsate: PropTypes.bool,\n\n /**\n * Diameter of the ripple.\n */\n rippleSize: PropTypes.number,\n\n /**\n * Horizontal position of the ripple center.\n */\n rippleX: PropTypes.number,\n\n /**\n * Vertical position of the ripple center.\n */\n rippleY: PropTypes.number,\n\n /**\n * exit delay\n */\n timeout: PropTypes.number.isRequired\n} : void 0;\nexport default Ripple;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _toConsumableArray from \"@babel/runtime/helpers/esm/toConsumableArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { TransitionGroup } from 'react-transition-group';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Ripple from './Ripple';\nvar DURATION = 550;\nexport var DELAY_RIPPLE = 80;\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n overflow: 'hidden',\n pointerEvents: 'none',\n position: 'absolute',\n zIndex: 0,\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n borderRadius: 'inherit'\n },\n\n /* Styles applied to the internal `Ripple` components `ripple` class. */\n ripple: {\n opacity: 0,\n position: 'absolute'\n },\n\n /* Styles applied to the internal `Ripple` components `rippleVisible` class. */\n rippleVisible: {\n opacity: 0.3,\n transform: 'scale(1)',\n animation: \"$enter \".concat(DURATION, \"ms \").concat(theme.transitions.easing.easeInOut)\n },\n\n /* Styles applied to the internal `Ripple` components `ripplePulsate` class. */\n ripplePulsate: {\n animationDuration: \"\".concat(theme.transitions.duration.shorter, \"ms\")\n },\n\n /* Styles applied to the internal `Ripple` components `child` class. */\n child: {\n opacity: 1,\n display: 'block',\n width: '100%',\n height: '100%',\n borderRadius: '50%',\n backgroundColor: 'currentColor'\n },\n\n /* Styles applied to the internal `Ripple` components `childLeaving` class. */\n childLeaving: {\n opacity: 0,\n animation: \"$exit \".concat(DURATION, \"ms \").concat(theme.transitions.easing.easeInOut)\n },\n\n /* Styles applied to the internal `Ripple` components `childPulsate` class. */\n childPulsate: {\n position: 'absolute',\n left: 0,\n top: 0,\n animation: \"$pulsate 2500ms \".concat(theme.transitions.easing.easeInOut, \" 200ms infinite\")\n },\n '@keyframes enter': {\n '0%': {\n transform: 'scale(0)',\n opacity: 0.1\n },\n '100%': {\n transform: 'scale(1)',\n opacity: 0.3\n }\n },\n '@keyframes exit': {\n '0%': {\n opacity: 1\n },\n '100%': {\n opacity: 0\n }\n },\n '@keyframes pulsate': {\n '0%': {\n transform: 'scale(1)'\n },\n '50%': {\n transform: 'scale(0.92)'\n },\n '100%': {\n transform: 'scale(1)'\n }\n }\n };\n};\n/**\n * @ignore - internal component.\n *\n * TODO v5: Make private\n */\n\nvar TouchRipple = React.forwardRef(function TouchRipple(props, ref) {\n var _props$center = props.center,\n centerProp = _props$center === void 0 ? false : _props$center,\n classes = props.classes,\n className = props.className,\n other = _objectWithoutProperties(props, [\"center\", \"classes\", \"className\"]);\n\n var _React$useState = React.useState([]),\n ripples = _React$useState[0],\n setRipples = _React$useState[1];\n\n var nextKey = React.useRef(0);\n var rippleCallback = React.useRef(null);\n React.useEffect(function () {\n if (rippleCallback.current) {\n rippleCallback.current();\n rippleCallback.current = null;\n }\n }, [ripples]); // Used to filter out mouse emulated events on mobile.\n\n var ignoringMouseDown = React.useRef(false); // We use a timer in order to only show the ripples for touch \"click\" like events.\n // We don't want to display the ripple for touch scroll events.\n\n var startTimer = React.useRef(null); // This is the hook called once the previous timeout is ready.\n\n var startTimerCommit = React.useRef(null);\n var container = React.useRef(null);\n React.useEffect(function () {\n return function () {\n clearTimeout(startTimer.current);\n };\n }, []);\n var startCommit = React.useCallback(function (params) {\n var pulsate = params.pulsate,\n rippleX = params.rippleX,\n rippleY = params.rippleY,\n rippleSize = params.rippleSize,\n cb = params.cb;\n setRipples(function (oldRipples) {\n return [].concat(_toConsumableArray(oldRipples), [React.createElement(Ripple, {\n key: nextKey.current,\n classes: classes,\n timeout: DURATION,\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize\n })]);\n });\n nextKey.current += 1;\n rippleCallback.current = cb;\n }, [classes]);\n var start = React.useCallback(function () {\n var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var cb = arguments.length > 2 ? arguments[2] : undefined;\n var _options$pulsate = options.pulsate,\n pulsate = _options$pulsate === void 0 ? false : _options$pulsate,\n _options$center = options.center,\n center = _options$center === void 0 ? centerProp || options.pulsate : _options$center,\n _options$fakeElement = options.fakeElement,\n fakeElement = _options$fakeElement === void 0 ? false : _options$fakeElement;\n\n if (event.type === 'mousedown' && ignoringMouseDown.current) {\n ignoringMouseDown.current = false;\n return;\n }\n\n if (event.type === 'touchstart') {\n ignoringMouseDown.current = true;\n }\n\n var element = fakeElement ? null : container.current;\n var rect = element ? element.getBoundingClientRect() : {\n width: 0,\n height: 0,\n left: 0,\n top: 0\n }; // Get the size of the ripple\n\n var rippleX;\n var rippleY;\n var rippleSize;\n\n if (center || event.clientX === 0 && event.clientY === 0 || !event.clientX && !event.touches) {\n rippleX = Math.round(rect.width / 2);\n rippleY = Math.round(rect.height / 2);\n } else {\n var clientX = event.clientX ? event.clientX : event.touches[0].clientX;\n var clientY = event.clientY ? event.clientY : event.touches[0].clientY;\n rippleX = Math.round(clientX - rect.left);\n rippleY = Math.round(clientY - rect.top);\n }\n\n if (center) {\n rippleSize = Math.sqrt((2 * Math.pow(rect.width, 2) + Math.pow(rect.height, 2)) / 3); // For some reason the animation is broken on Mobile Chrome if the size if even.\n\n if (rippleSize % 2 === 0) {\n rippleSize += 1;\n }\n } else {\n var sizeX = Math.max(Math.abs((element ? element.clientWidth : 0) - rippleX), rippleX) * 2 + 2;\n var sizeY = Math.max(Math.abs((element ? element.clientHeight : 0) - rippleY), rippleY) * 2 + 2;\n rippleSize = Math.sqrt(Math.pow(sizeX, 2) + Math.pow(sizeY, 2));\n } // Touche devices\n\n\n if (event.touches) {\n // Prepare the ripple effect.\n startTimerCommit.current = function () {\n startCommit({\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize,\n cb: cb\n });\n }; // Delay the execution of the ripple effect.\n\n\n startTimer.current = setTimeout(function () {\n if (startTimerCommit.current) {\n startTimerCommit.current();\n startTimerCommit.current = null;\n }\n }, DELAY_RIPPLE); // We have to make a tradeoff with this value.\n } else {\n startCommit({\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize,\n cb: cb\n });\n }\n }, [centerProp, startCommit]);\n var pulsate = React.useCallback(function () {\n start({}, {\n pulsate: true\n });\n }, [start]);\n var stop = React.useCallback(function (event, cb) {\n clearTimeout(startTimer.current); // The touch interaction occurs too quickly.\n // We still want to show ripple effect.\n\n if (event.type === 'touchend' && startTimerCommit.current) {\n event.persist();\n startTimerCommit.current();\n startTimerCommit.current = null;\n startTimer.current = setTimeout(function () {\n stop(event, cb);\n });\n return;\n }\n\n startTimerCommit.current = null;\n setRipples(function (oldRipples) {\n if (oldRipples.length > 0) {\n return oldRipples.slice(1);\n }\n\n return oldRipples;\n });\n rippleCallback.current = cb;\n }, []);\n React.useImperativeHandle(ref, function () {\n return {\n pulsate: pulsate,\n start: start,\n stop: stop\n };\n }, [pulsate, start, stop]);\n return React.createElement(\"span\", _extends({\n className: clsx(classes.root, className),\n ref: container\n }, other), React.createElement(TransitionGroup, {\n component: null,\n exit: true\n }, ripples));\n}); // TODO cleanup after https://github.com/reactjs/react-docgen/pull/378 is released\n\nfunction withMuiName(Component) {\n Component.muiName = 'MuiTouchRipple';\n return Component;\n}\n\nprocess.env.NODE_ENV !== \"production\" ? TouchRipple.propTypes = {\n /**\n * If `true`, the ripple starts at the center of the component\n * rather than at the point of interaction.\n */\n center: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string\n} : void 0;\nexport default withStyles(styles, {\n flip: false,\n name: 'MuiTouchRipple'\n})(withMuiName(React.memo(TouchRipple)));","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport clsx from 'clsx';\nimport { elementTypeAcceptingRef, refType } from '@material-ui/utils';\nimport useForkRef from '../utils/useForkRef';\nimport useEventCallback from '../utils/useEventCallback';\nimport withStyles from '../styles/withStyles';\nimport NoSsr from '../NoSsr';\nimport { useIsFocusVisible } from '../utils/focusVisible';\nimport TouchRipple from './TouchRipple';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n position: 'relative',\n WebkitTapHighlightColor: 'transparent',\n backgroundColor: 'transparent',\n // Reset default value\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0,\n border: 0,\n margin: 0,\n // Remove the margin in Safari\n borderRadius: 0,\n padding: 0,\n // Remove the padding in Firefox\n cursor: 'pointer',\n userSelect: 'none',\n verticalAlign: 'middle',\n '-moz-appearance': 'none',\n // Reset\n '-webkit-appearance': 'none',\n // Reset\n textDecoration: 'none',\n // So we take precedent over the style of a native <a /> element.\n color: 'inherit',\n '&::-moz-focus-inner': {\n borderStyle: 'none' // Remove Firefox dotted outline.\n\n },\n '&$disabled': {\n pointerEvents: 'none',\n // Disable link interactions\n cursor: 'default'\n }\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if keyboard focused. */\n focusVisible: {}\n};\n/**\n * `ButtonBase` contains as few styles as possible.\n * It aims to be a simple building block for creating a button.\n * It contains a load of style reset and some focus/ripple logic.\n */\n\nvar ButtonBase = React.forwardRef(function ButtonBase(props, ref) {\n var action = props.action,\n buttonRefProp = props.buttonRef,\n _props$centerRipple = props.centerRipple,\n centerRipple = _props$centerRipple === void 0 ? false : _props$centerRipple,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n component = _props$component === void 0 ? 'button' : _props$component,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableRipple = props.disableRipple,\n disableRipple = _props$disableRipple === void 0 ? false : _props$disableRipple,\n _props$disableTouchRi = props.disableTouchRipple,\n disableTouchRipple = _props$disableTouchRi === void 0 ? false : _props$disableTouchRi,\n _props$focusRipple = props.focusRipple,\n focusRipple = _props$focusRipple === void 0 ? false : _props$focusRipple,\n focusVisibleClassName = props.focusVisibleClassName,\n onBlur = props.onBlur,\n onClick = props.onClick,\n onFocus = props.onFocus,\n onFocusVisible = props.onFocusVisible,\n onKeyDown = props.onKeyDown,\n onKeyUp = props.onKeyUp,\n onMouseDown = props.onMouseDown,\n onMouseLeave = props.onMouseLeave,\n onMouseUp = props.onMouseUp,\n onTouchEnd = props.onTouchEnd,\n onTouchMove = props.onTouchMove,\n onTouchStart = props.onTouchStart,\n onDragLeave = props.onDragLeave,\n _props$tabIndex = props.tabIndex,\n tabIndex = _props$tabIndex === void 0 ? 0 : _props$tabIndex,\n TouchRippleProps = props.TouchRippleProps,\n _props$type = props.type,\n type = _props$type === void 0 ? 'button' : _props$type,\n other = _objectWithoutProperties(props, [\"action\", \"buttonRef\", \"centerRipple\", \"children\", \"classes\", \"className\", \"component\", \"disabled\", \"disableRipple\", \"disableTouchRipple\", \"focusRipple\", \"focusVisibleClassName\", \"onBlur\", \"onClick\", \"onFocus\", \"onFocusVisible\", \"onKeyDown\", \"onKeyUp\", \"onMouseDown\", \"onMouseLeave\", \"onMouseUp\", \"onTouchEnd\", \"onTouchMove\", \"onTouchStart\", \"onDragLeave\", \"tabIndex\", \"TouchRippleProps\", \"type\"]);\n\n var buttonRef = React.useRef(null);\n\n function getButtonNode() {\n // #StrictMode ready\n return ReactDOM.findDOMNode(buttonRef.current);\n }\n\n var rippleRef = React.useRef(null);\n\n var _React$useState = React.useState(false),\n focusVisible = _React$useState[0],\n setFocusVisible = _React$useState[1];\n\n if (disabled && focusVisible) {\n setFocusVisible(false);\n }\n\n var _useIsFocusVisible = useIsFocusVisible(),\n isFocusVisible = _useIsFocusVisible.isFocusVisible,\n onBlurVisible = _useIsFocusVisible.onBlurVisible,\n focusVisibleRef = _useIsFocusVisible.ref;\n\n React.useImperativeHandle(action, function () {\n return {\n focusVisible: function focusVisible() {\n setFocusVisible(true);\n buttonRef.current.focus();\n }\n };\n }, []);\n React.useEffect(function () {\n if (focusVisible && focusRipple && !disableRipple) {\n rippleRef.current.pulsate();\n }\n }, [disableRipple, focusRipple, focusVisible]);\n\n function useRippleHandler(rippleAction, eventCallback) {\n var skipRippleAction = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : disableTouchRipple;\n return useEventCallback(function (event) {\n if (eventCallback) {\n eventCallback(event);\n }\n\n var ignore = skipRippleAction;\n\n if (!ignore && rippleRef.current) {\n rippleRef.current[rippleAction](event);\n }\n\n return true;\n });\n }\n\n var handleMouseDown = useRippleHandler('start', onMouseDown);\n var handleDragLeave = useRippleHandler('stop', onDragLeave);\n var handleMouseUp = useRippleHandler('stop', onMouseUp);\n var handleMouseLeave = useRippleHandler('stop', function (event) {\n if (focusVisible) {\n event.preventDefault();\n }\n\n if (onMouseLeave) {\n onMouseLeave(event);\n }\n });\n var handleTouchStart = useRippleHandler('start', onTouchStart);\n var handleTouchEnd = useRippleHandler('stop', onTouchEnd);\n var handleTouchMove = useRippleHandler('stop', onTouchMove);\n var handleBlur = useRippleHandler('stop', function (event) {\n if (focusVisible) {\n onBlurVisible(event);\n setFocusVisible(false);\n }\n\n if (onBlur) {\n onBlur(event);\n }\n }, false);\n var handleFocus = useEventCallback(function (event) {\n if (disabled) {\n return;\n } // Fix for https://github.com/facebook/react/issues/7769\n\n\n if (!buttonRef.current) {\n buttonRef.current = event.currentTarget;\n }\n\n if (isFocusVisible(event)) {\n setFocusVisible(true);\n\n if (onFocusVisible) {\n onFocusVisible(event);\n }\n }\n\n if (onFocus) {\n onFocus(event);\n }\n });\n\n var isNonNativeButton = function isNonNativeButton() {\n var button = getButtonNode();\n return component && component !== 'button' && !(button.tagName === 'A' && button.href);\n };\n /**\n * IE 11 shim for https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/repeat\n */\n\n\n var keydownRef = React.useRef(false);\n var handleKeyDown = useEventCallback(function (event) {\n // Check if key is already down to avoid repeats being counted as multiple activations\n if (focusRipple && !keydownRef.current && focusVisible && rippleRef.current && event.key === ' ') {\n keydownRef.current = true;\n event.persist();\n rippleRef.current.stop(event, function () {\n rippleRef.current.start(event);\n });\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n } // Keyboard accessibility for non interactive elements\n\n\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === 'Enter') {\n event.preventDefault();\n\n if (onClick) {\n onClick(event);\n }\n }\n });\n var handleKeyUp = useEventCallback(function (event) {\n // calling preventDefault in keyUp on a <button> will not dispatch a click event if Space is pressed\n // https://codesandbox.io/s/button-keyup-preventdefault-dn7f0\n if (focusRipple && event.key === ' ' && rippleRef.current && focusVisible && !event.defaultPrevented) {\n keydownRef.current = false;\n event.persist();\n rippleRef.current.stop(event, function () {\n rippleRef.current.pulsate(event);\n });\n }\n\n if (onKeyUp) {\n onKeyUp(event);\n } // Keyboard accessibility for non interactive elements\n\n\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === ' ' && !event.defaultPrevented) {\n event.preventDefault();\n\n if (onClick) {\n onClick(event);\n }\n }\n });\n var ComponentProp = component;\n\n if (ComponentProp === 'button' && other.href) {\n ComponentProp = 'a';\n }\n\n var buttonProps = {};\n\n if (ComponentProp === 'button') {\n buttonProps.type = type;\n buttonProps.disabled = disabled;\n } else {\n if (ComponentProp !== 'a' || !other.href) {\n buttonProps.role = 'button';\n }\n\n buttonProps['aria-disabled'] = disabled;\n }\n\n var handleUserRef = useForkRef(buttonRefProp, ref);\n var handleOwnRef = useForkRef(focusVisibleRef, buttonRef);\n var handleRef = useForkRef(handleUserRef, handleOwnRef);\n return React.createElement(ComponentProp, _extends({\n className: clsx(classes.root, className, focusVisible && [classes.focusVisible, focusVisibleClassName], disabled && classes.disabled),\n onBlur: handleBlur,\n onClick: onClick,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n onKeyUp: handleKeyUp,\n onMouseDown: handleMouseDown,\n onMouseLeave: handleMouseLeave,\n onMouseUp: handleMouseUp,\n onDragLeave: handleDragLeave,\n onTouchEnd: handleTouchEnd,\n onTouchMove: handleTouchMove,\n onTouchStart: handleTouchStart,\n ref: handleRef,\n tabIndex: disabled ? -1 : tabIndex\n }, buttonProps, other), children, !disableRipple && !disabled ? React.createElement(NoSsr, null, React.createElement(TouchRipple, _extends({\n ref: rippleRef,\n center: centerRipple\n }, TouchRippleProps))) : null);\n});\nprocess.env.NODE_ENV !== \"production\" ? ButtonBase.propTypes = {\n /**\n * A ref for imperative actions.\n * It currently only supports `focusVisible()` action.\n */\n action: refType,\n\n /**\n * @ignore\n *\n * Use that prop to pass a ref to the native button component.\n * @deprecated Use `ref` instead.\n */\n buttonRef: refType,\n\n /**\n * If `true`, the ripples will be centered.\n * They won't start at the cursor interaction position.\n */\n centerRipple: PropTypes.bool,\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: elementTypeAcceptingRef,\n\n /**\n * If `true`, the base button will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n *\n * âš ï¸ Without a ripple there is no styling for :focus-visible by default. Be sure\n * to highlight the element by applying separate styles with the `focusVisibleClassName`.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * If `true`, the touch ripple effect will be disabled.\n */\n disableTouchRipple: PropTypes.bool,\n\n /**\n * If `true`, the base button will have a keyboard focus ripple.\n * `disableRipple` must also be `false`.\n */\n focusRipple: PropTypes.bool,\n\n /**\n * This prop can help a person know which element has the keyboard focus.\n * The class name will be applied when the element gain the focus through a keyboard interaction.\n * It's a polyfill for the [CSS :focus-visible selector](https://drafts.csswg.org/selectors-4/#the-focus-visible-pseudo).\n * The rationale for using this feature [is explained here](https://github.com/WICG/focus-visible/blob/master/explainer.md).\n * A [polyfill can be used](https://github.com/WICG/focus-visible) to apply a `focus-visible` class to other components\n * if needed.\n */\n focusVisibleClassName: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onDragLeave: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * Callback fired when the component is focused with a keyboard.\n * We trigger a `onFocus` callback too.\n */\n onFocusVisible: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyUp: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseDown: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseLeave: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseUp: PropTypes.func,\n\n /**\n * @ignore\n */\n onTouchEnd: PropTypes.func,\n\n /**\n * @ignore\n */\n onTouchMove: PropTypes.func,\n\n /**\n * @ignore\n */\n onTouchStart: PropTypes.func,\n\n /**\n * @ignore\n */\n role: PropTypes.string,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * Props applied to the `TouchRipple` element.\n */\n TouchRippleProps: PropTypes.object,\n\n /**\n * Used to control the button's purpose.\n * This prop passes the value to the `type` attribute of the native button component.\n */\n type: PropTypes.oneOf(['submit', 'reset', 'button'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiButtonBase'\n})(ButtonBase);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport debounce from '../utils/debounce';\nimport useForkRef from '../utils/useForkRef';\n\nfunction getStyleValue(computedStyle, property) {\n return parseInt(computedStyle[property], 10) || 0;\n}\n\nvar useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\nvar styles = {\n /* Styles applied to the shadow textarea element. */\n shadow: {\n // Visibility needed to hide the extra text area on iPads\n visibility: 'hidden',\n // Remove from the content flow\n position: 'absolute',\n // Ignore the scrollbar width\n overflow: 'hidden',\n height: 0,\n top: 0,\n left: 0,\n // Create a new layer, increase the isolation of the computed values\n transform: 'translateZ(0)'\n }\n};\nvar TextareaAutosize = React.forwardRef(function TextareaAutosize(props, ref) {\n var onChange = props.onChange,\n rows = props.rows,\n rowsMax = props.rowsMax,\n _props$rowsMin = props.rowsMin,\n rowsMinProp = _props$rowsMin === void 0 ? 1 : _props$rowsMin,\n style = props.style,\n value = props.value,\n other = _objectWithoutProperties(props, [\"onChange\", \"rows\", \"rowsMax\", \"rowsMin\", \"style\", \"value\"]);\n\n var rowsMin = rows || rowsMinProp;\n\n var _React$useRef = React.useRef(value != null),\n isControlled = _React$useRef.current;\n\n var inputRef = React.useRef(null);\n var handleRef = useForkRef(ref, inputRef);\n var shadowRef = React.useRef(null);\n\n var _React$useState = React.useState({}),\n state = _React$useState[0],\n setState = _React$useState[1];\n\n var syncHeight = React.useCallback(function () {\n var input = inputRef.current;\n var computedStyle = window.getComputedStyle(input);\n var inputShallow = shadowRef.current;\n inputShallow.style.width = computedStyle.width;\n inputShallow.value = input.value || props.placeholder || 'x';\n var boxSizing = computedStyle['box-sizing'];\n var padding = getStyleValue(computedStyle, 'padding-bottom') + getStyleValue(computedStyle, 'padding-top');\n var border = getStyleValue(computedStyle, 'border-bottom-width') + getStyleValue(computedStyle, 'border-top-width'); // The height of the inner content\n\n var innerHeight = inputShallow.scrollHeight - padding; // Measure height of a textarea with a single row\n\n inputShallow.value = 'x';\n var singleRowHeight = inputShallow.scrollHeight - padding; // The height of the outer content\n\n var outerHeight = innerHeight;\n\n if (rowsMin) {\n outerHeight = Math.max(Number(rowsMin) * singleRowHeight, outerHeight);\n }\n\n if (rowsMax) {\n outerHeight = Math.min(Number(rowsMax) * singleRowHeight, outerHeight);\n }\n\n outerHeight = Math.max(outerHeight, singleRowHeight); // Take the box sizing into account for applying this value as a style.\n\n var outerHeightStyle = outerHeight + (boxSizing === 'border-box' ? padding + border : 0);\n var overflow = Math.abs(outerHeight - innerHeight) <= 1;\n setState(function (prevState) {\n // Need a large enough different to update the height.\n // This prevents infinite rendering loop.\n if (outerHeightStyle > 0 && Math.abs((prevState.outerHeightStyle || 0) - outerHeightStyle) > 1 || prevState.overflow !== overflow) {\n return {\n overflow: overflow,\n outerHeightStyle: outerHeightStyle\n };\n }\n\n return prevState;\n });\n }, [rowsMax, rowsMin, props.placeholder]);\n React.useEffect(function () {\n var handleResize = debounce(function () {\n syncHeight();\n });\n window.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n window.removeEventListener('resize', handleResize);\n };\n }, [syncHeight]);\n useEnhancedEffect(function () {\n syncHeight();\n });\n\n var handleChange = function handleChange(event) {\n if (!isControlled) {\n syncHeight();\n }\n\n if (onChange) {\n onChange(event);\n }\n };\n\n return React.createElement(React.Fragment, null, React.createElement(\"textarea\", _extends({\n value: value,\n onChange: handleChange,\n ref: handleRef // Apply the rows prop to get a \"correct\" first SSR paint\n ,\n rows: rowsMin,\n style: _extends({\n height: state.outerHeightStyle,\n // Need a large enough different to allow scrolling.\n // This prevents infinite rendering loop.\n overflow: state.overflow ? 'hidden' : null\n }, style)\n }, other)), React.createElement(\"textarea\", {\n \"aria-hidden\": true,\n className: props.className,\n readOnly: true,\n ref: shadowRef,\n tabIndex: -1,\n style: _extends({}, styles.shadow, {}, style)\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? TextareaAutosize.propTypes = {\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * @ignore\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n placeholder: PropTypes.string,\n\n /**\n * Use `rowsMin` instead. The prop will be removed in v5.\n *\n * @deprecated\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Minimum number of rows to display.\n */\n rowsMin: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * @ignore\n */\n value: PropTypes.any\n} : void 0;\nexport default TextareaAutosize;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n\n/* eslint-disable jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport formControlState from '../FormControl/formControlState';\nimport FormControlContext, { useFormControl } from '../FormControl/FormControlContext';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport useForkRef from '../utils/useForkRef';\nimport TextareaAutosize from '../TextareaAutosize';\nimport { isFilled } from './utils';\nexport var styles = function styles(theme) {\n var light = theme.palette.type === 'light';\n var placeholder = {\n color: 'currentColor',\n opacity: light ? 0.42 : 0.5,\n transition: theme.transitions.create('opacity', {\n duration: theme.transitions.duration.shorter\n })\n };\n var placeholderHidden = {\n opacity: '0 !important'\n };\n var placeholderVisible = {\n opacity: light ? 0.42 : 0.5\n };\n return {\n /* Styles applied to the root element. */\n root: {\n // Mimics the default input display property used by browsers for an input.\n fontFamily: theme.typography.fontFamily,\n color: theme.palette.text.primary,\n fontSize: theme.typography.pxToRem(16),\n lineHeight: '1.1875em',\n // Reset (19px), match the native input line-height\n boxSizing: 'border-box',\n // Prevent padding issue with fullWidth.\n position: 'relative',\n cursor: 'text',\n display: 'inline-flex',\n alignItems: 'center',\n '&$disabled': {\n color: theme.palette.text.disabled,\n cursor: 'default'\n }\n },\n\n /* Styles applied to the root element if the component is a descendant of `FormControl`. */\n formControl: {},\n\n /* Styles applied to the root element if the component is focused. */\n focused: {},\n\n /* Styles applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `startAdornment` is provided. */\n adornedStart: {},\n\n /* Styles applied to the root element if `endAdornment` is provided. */\n adornedEnd: {},\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {\n padding: \"\".concat(8 - 2, \"px 0 \").concat(8 - 1, \"px\"),\n '&$marginDense': {\n paddingTop: 4 - 1\n }\n },\n\n /* Styles applied to the root element if the color is secondary. */\n colorSecondary: {},\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {\n width: '100%'\n },\n\n /* Styles applied to the `input` element. */\n input: {\n font: 'inherit',\n color: 'currentColor',\n padding: \"\".concat(8 - 2, \"px 0 \").concat(8 - 1, \"px\"),\n border: 0,\n boxSizing: 'content-box',\n background: 'none',\n height: '1.1875em',\n // Reset (19px), match the native input line-height\n margin: 0,\n // Reset for Safari\n WebkitTapHighlightColor: 'transparent',\n display: 'block',\n // Make the flex item shrink with Firefox\n minWidth: 0,\n width: '100%',\n // Fix IE 11 width issue\n animationName: '$auto-fill-cancel',\n '&::-webkit-input-placeholder': placeholder,\n '&::-moz-placeholder': placeholder,\n // Firefox 19+\n '&:-ms-input-placeholder': placeholder,\n // IE 11\n '&::-ms-input-placeholder': placeholder,\n // Edge\n '&:focus': {\n outline: 0\n },\n // Reset Firefox invalid required input style\n '&:invalid': {\n boxShadow: 'none'\n },\n '&::-webkit-search-decoration': {\n // Remove the padding when type=search.\n '-webkit-appearance': 'none'\n },\n // Show and hide the placeholder logic\n 'label[data-shrink=false] + $formControl &': {\n '&::-webkit-input-placeholder': placeholderHidden,\n '&::-moz-placeholder': placeholderHidden,\n // Firefox 19+\n '&:-ms-input-placeholder': placeholderHidden,\n // IE 11\n '&::-ms-input-placeholder': placeholderHidden,\n // Edge\n '&:focus::-webkit-input-placeholder': placeholderVisible,\n '&:focus::-moz-placeholder': placeholderVisible,\n // Firefox 19+\n '&:focus:-ms-input-placeholder': placeholderVisible,\n // IE 11\n '&:focus::-ms-input-placeholder': placeholderVisible // Edge\n\n },\n '&$disabled': {\n opacity: 1 // Reset iOS opacity\n\n },\n '&:-webkit-autofill': {\n animationDuration: '5000s',\n animationName: '$auto-fill'\n }\n },\n '@keyframes auto-fill': {\n from: {}\n },\n '@keyframes auto-fill-cancel': {\n from: {}\n },\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {\n paddingTop: 4 - 1\n },\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {\n height: 'auto',\n resize: 'none',\n padding: 0\n },\n\n /* Styles applied to the `input` element if `type=\"search\"`. */\n inputTypeSearch: {\n // Improve type search style.\n '-moz-appearance': 'textfield',\n '-webkit-appearance': 'textfield'\n },\n\n /* Styles applied to the `input` element if `startAdornment` is provided. */\n inputAdornedStart: {},\n\n /* Styles applied to the `input` element if `endAdornment` is provided. */\n inputAdornedEnd: {},\n\n /* Styles applied to the `input` element if `hiddenLabel={true}`. */\n inputHiddenLabel: {}\n };\n};\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * `InputBase` contains as few styles as possible.\n * It aims to be a simple building block for creating an input.\n * It contains a load of style reset and some state logic.\n */\n\nvar InputBase = React.forwardRef(function InputBase(props, ref) {\n var ariaDescribedby = props['aria-describedby'],\n autoComplete = props.autoComplete,\n autoFocus = props.autoFocus,\n classes = props.classes,\n className = props.className,\n color = props.color,\n defaultValue = props.defaultValue,\n disabled = props.disabled,\n endAdornment = props.endAdornment,\n error = props.error,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n id = props.id,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$inputProps = props.inputProps,\n inputPropsProp = _props$inputProps === void 0 ? {} : _props$inputProps,\n inputRefProp = props.inputRef,\n margin = props.margin,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onClick = props.onClick,\n onFocus = props.onFocus,\n onKeyDown = props.onKeyDown,\n onKeyUp = props.onKeyUp,\n placeholder = props.placeholder,\n readOnly = props.readOnly,\n renderSuffix = props.renderSuffix,\n rows = props.rows,\n rowsMax = props.rowsMax,\n rowsMin = props.rowsMin,\n startAdornment = props.startAdornment,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n valueProp = props.value,\n other = _objectWithoutProperties(props, [\"aria-describedby\", \"autoComplete\", \"autoFocus\", \"classes\", \"className\", \"color\", \"defaultValue\", \"disabled\", \"endAdornment\", \"error\", \"fullWidth\", \"id\", \"inputComponent\", \"inputProps\", \"inputRef\", \"margin\", \"multiline\", \"name\", \"onBlur\", \"onChange\", \"onClick\", \"onFocus\", \"onKeyDown\", \"onKeyUp\", \"placeholder\", \"readOnly\", \"renderSuffix\", \"rows\", \"rowsMax\", \"rowsMin\", \"startAdornment\", \"type\", \"value\"]);\n\n var value = inputPropsProp.value != null ? inputPropsProp.value : valueProp;\n\n var _React$useRef = React.useRef(value != null),\n isControlled = _React$useRef.current;\n\n var inputRef = React.useRef();\n var handleInputRefWarning = React.useCallback(function (instance) {\n if (process.env.NODE_ENV !== 'production') {\n if (instance && !(instance instanceof HTMLInputElement) && !instance.focus) {\n console.error(['Material-UI: you have provided a `inputComponent` to the input component', 'that does not correctly handle the `inputRef` prop.', 'Make sure the `inputRef` prop is called with a HTMLInputElement.'].join('\\n'));\n }\n }\n }, []);\n var handleInputPropsRefProp = useForkRef(inputPropsProp.ref, handleInputRefWarning);\n var handleInputRefProp = useForkRef(inputRefProp, handleInputPropsRefProp);\n var handleInputRef = useForkRef(inputRef, handleInputRefProp);\n\n var _React$useState = React.useState(false),\n focused = _React$useState[0],\n setFocused = _React$useState[1];\n\n var muiFormControl = useFormControl();\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (muiFormControl) {\n return muiFormControl.registerEffect();\n }\n\n return undefined;\n }, [muiFormControl]);\n }\n\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['color', 'disabled', 'error', 'hiddenLabel', 'margin', 'required', 'filled']\n });\n fcs.focused = muiFormControl ? muiFormControl.focused : focused; // The blur won't fire when the disabled state is set on a focused input.\n // We need to book keep the focused state manually.\n\n React.useEffect(function () {\n if (!muiFormControl && disabled && focused) {\n setFocused(false);\n\n if (onBlur) {\n onBlur();\n }\n }\n }, [muiFormControl, disabled, focused, onBlur]);\n var onFilled = muiFormControl && muiFormControl.onFilled;\n var onEmpty = muiFormControl && muiFormControl.onEmpty;\n var checkDirty = React.useCallback(function (obj) {\n if (isFilled(obj)) {\n if (onFilled) {\n onFilled();\n }\n } else if (onEmpty) {\n onEmpty();\n }\n }, [onFilled, onEmpty]);\n useEnhancedEffect(function () {\n if (isControlled) {\n checkDirty({\n value: value\n });\n }\n }, [value, checkDirty, isControlled]);\n\n var handleFocus = function handleFocus(event) {\n // Fix a bug with IE 11 where the focus/blur events are triggered\n // while the input is disabled.\n if (fcs.disabled) {\n event.stopPropagation();\n return;\n }\n\n if (onFocus) {\n onFocus(event);\n }\n\n if (inputPropsProp.onFocus) {\n inputPropsProp.onFocus(event);\n }\n\n if (muiFormControl && muiFormControl.onFocus) {\n muiFormControl.onFocus(event);\n } else {\n setFocused(true);\n }\n };\n\n var handleBlur = function handleBlur(event) {\n if (onBlur) {\n onBlur(event);\n }\n\n if (inputPropsProp.onBlur) {\n inputPropsProp.onBlur(event);\n }\n\n if (muiFormControl && muiFormControl.onBlur) {\n muiFormControl.onBlur(event);\n } else {\n setFocused(false);\n }\n };\n\n var handleChange = function handleChange(event) {\n if (!isControlled) {\n var element = event.target || inputRef.current;\n\n if (element == null) {\n throw new TypeError('Material-UI: Expected valid input target. ' + 'Did you use a custom `inputComponent` and forget to forward refs? ' + 'See https://material-ui.com/r/input-component-ref-interface for more info.');\n }\n\n checkDirty({\n value: element.value\n });\n }\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n if (inputPropsProp.onChange) {\n inputPropsProp.onChange.apply(inputPropsProp, [event].concat(args));\n } // Perform in the willUpdate\n\n\n if (onChange) {\n onChange.apply(void 0, [event].concat(args));\n }\n }; // Check the input state on mount, in case it was filled by the user\n // or auto filled by the browser before the hydration (for SSR).\n\n\n React.useEffect(function () {\n checkDirty(inputRef.current);\n }, []); // eslint-disable-line react-hooks/exhaustive-deps\n\n var handleClick = function handleClick(event) {\n if (inputRef.current && event.currentTarget === event.target) {\n inputRef.current.focus();\n }\n\n if (onClick) {\n onClick(event);\n }\n };\n\n var InputComponent = inputComponent;\n\n var inputProps = _extends({}, inputPropsProp, {\n ref: handleInputRef\n });\n\n if (typeof InputComponent !== 'string') {\n inputProps = _extends({\n // Rename ref to inputRef as we don't know the\n // provided `inputComponent` structure.\n inputRef: handleInputRef,\n type: type\n }, inputProps, {\n ref: null\n });\n } else if (multiline) {\n if (rows && !rowsMax && !rowsMin) {\n InputComponent = 'textarea';\n } else {\n inputProps = _extends({\n rows: rows,\n rowsMax: rowsMax\n }, inputProps);\n InputComponent = TextareaAutosize;\n }\n } else {\n inputProps = _extends({\n type: type\n }, inputProps);\n }\n\n var handleAutoFill = function handleAutoFill(event) {\n // Provide a fake value as Chrome might not let you access it for security reasons.\n checkDirty(event.animationName.indexOf('auto-fill-cancel') !== -1 ? inputRef.current : {\n value: 'x'\n });\n };\n\n React.useEffect(function () {\n if (muiFormControl) {\n muiFormControl.setAdornedStart(Boolean(startAdornment));\n }\n }, [muiFormControl, startAdornment]);\n return React.createElement(\"div\", _extends({\n className: clsx(classes.root, classes[\"color\".concat(capitalize(fcs.color || 'primary'))], className, fcs.disabled && classes.disabled, fcs.error && classes.error, fullWidth && classes.fullWidth, fcs.focused && classes.focused, muiFormControl && classes.formControl, multiline && classes.multiline, startAdornment && classes.adornedStart, endAdornment && classes.adornedEnd, {\n dense: classes.marginDense\n }[fcs.margin]),\n onClick: handleClick,\n ref: ref\n }, other), startAdornment, React.createElement(FormControlContext.Provider, {\n value: null\n }, React.createElement(InputComponent, _extends({\n \"aria-invalid\": fcs.error,\n \"aria-describedby\": ariaDescribedby,\n autoComplete: autoComplete,\n autoFocus: autoFocus,\n defaultValue: defaultValue,\n disabled: fcs.disabled,\n id: id,\n onAnimationStart: handleAutoFill,\n name: name,\n placeholder: placeholder,\n readOnly: readOnly,\n required: fcs.required,\n rows: rows,\n value: value,\n onKeyDown: onKeyDown,\n onKeyUp: onKeyUp\n }, inputProps, {\n className: clsx(classes.input, inputPropsProp.className, fcs.disabled && classes.disabled, multiline && classes.inputMultiline, fcs.hiddenLabel && classes.inputHiddenLabel, startAdornment && classes.inputAdornedStart, endAdornment && classes.inputAdornedEnd, {\n search: classes.inputTypeSearch\n }[type], {\n dense: classes.inputMarginDense\n }[fcs.margin]),\n onBlur: handleBlur,\n onChange: handleChange,\n onFocus: handleFocus\n }))), endAdornment, renderSuffix ? renderSuffix(_extends({}, fcs, {\n startAdornment: startAdornment\n })) : null);\n});\nprocess.env.NODE_ENV !== \"production\" ? InputBase.propTypes = {\n /**\n * @ignore\n */\n 'aria-describedby': PropTypes.string,\n\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the `input` element.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the input is blurred.\n *\n * Notice that the first argument (event) might be undefined.\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyUp: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * @ignore\n */\n renderSuffix: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Minimum number of rows to display when multiline option is set to true.\n */\n rowsMin: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiInputBase'\n})(InputBase);","/** @license React v16.12.0\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var h=require(\"object-assign\"),n=\"function\"===typeof Symbol&&Symbol.for,p=n?Symbol.for(\"react.element\"):60103,q=n?Symbol.for(\"react.portal\"):60106,r=n?Symbol.for(\"react.fragment\"):60107,t=n?Symbol.for(\"react.strict_mode\"):60108,u=n?Symbol.for(\"react.profiler\"):60114,v=n?Symbol.for(\"react.provider\"):60109,w=n?Symbol.for(\"react.context\"):60110,x=n?Symbol.for(\"react.forward_ref\"):60112,y=n?Symbol.for(\"react.suspense\"):60113;n&&Symbol.for(\"react.suspense_list\");\nvar z=n?Symbol.for(\"react.memo\"):60115,aa=n?Symbol.for(\"react.lazy\"):60116;n&&Symbol.for(\"react.fundamental\");n&&Symbol.for(\"react.responder\");n&&Symbol.for(\"react.scope\");var A=\"function\"===typeof Symbol&&Symbol.iterator;\nfunction B(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}var C={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},D={};\nfunction E(a,b,c){this.props=a;this.context=b;this.refs=D;this.updater=c||C}E.prototype.isReactComponent={};E.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(B(85));this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,c){this.props=a;this.context=b;this.refs=D;this.updater=c||C}var H=G.prototype=new F;\nH.constructor=G;h(H,E.prototype);H.isPureReactComponent=!0;var I={current:null},J={current:null},K=Object.prototype.hasOwnProperty,L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,c){var e,d={},g=null,l=null;if(null!=b)for(e in void 0!==b.ref&&(l=b.ref),void 0!==b.key&&(g=\"\"+b.key),b)K.call(b,e)&&!L.hasOwnProperty(e)&&(d[e]=b[e]);var f=arguments.length-2;if(1===f)d.children=c;else if(1<f){for(var k=Array(f),m=0;m<f;m++)k[m]=arguments[m+2];d.children=k}if(a&&a.defaultProps)for(e in f=a.defaultProps,f)void 0===d[e]&&(d[e]=f[e]);return{$$typeof:p,type:a,key:g,ref:l,props:d,_owner:J.current}}\nfunction ba(a,b){return{$$typeof:p,type:a.type,key:b,ref:a.ref,props:a.props,_owner:a._owner}}function N(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===p}function escape(a){var b={\"=\":\"=0\",\":\":\"=2\"};return\"$\"+(\"\"+a).replace(/[=:]/g,function(a){return b[a]})}var O=/\\/+/g,P=[];function Q(a,b,c,e){if(P.length){var d=P.pop();d.result=a;d.keyPrefix=b;d.func=c;d.context=e;d.count=0;return d}return{result:a,keyPrefix:b,func:c,context:e,count:0}}\nfunction R(a){a.result=null;a.keyPrefix=null;a.func=null;a.context=null;a.count=0;10>P.length&&P.push(a)}\nfunction S(a,b,c,e){var d=typeof a;if(\"undefined\"===d||\"boolean\"===d)a=null;var g=!1;if(null===a)g=!0;else switch(d){case \"string\":case \"number\":g=!0;break;case \"object\":switch(a.$$typeof){case p:case q:g=!0}}if(g)return c(e,a,\"\"===b?\".\"+T(a,0):b),1;g=0;b=\"\"===b?\".\":b+\":\";if(Array.isArray(a))for(var l=0;l<a.length;l++){d=a[l];var f=b+T(d,l);g+=S(d,f,c,e)}else if(null===a||\"object\"!==typeof a?f=null:(f=A&&a[A]||a[\"@@iterator\"],f=\"function\"===typeof f?f:null),\"function\"===typeof f)for(a=f.call(a),l=\n0;!(d=a.next()).done;)d=d.value,f=b+T(d,l++),g+=S(d,f,c,e);else if(\"object\"===d)throw c=\"\"+a,Error(B(31,\"[object Object]\"===c?\"object with keys {\"+Object.keys(a).join(\", \")+\"}\":c,\"\"));return g}function U(a,b,c){return null==a?0:S(a,\"\",b,c)}function T(a,b){return\"object\"===typeof a&&null!==a&&null!=a.key?escape(a.key):b.toString(36)}function ca(a,b){a.func.call(a.context,b,a.count++)}\nfunction da(a,b,c){var e=a.result,d=a.keyPrefix;a=a.func.call(a.context,b,a.count++);Array.isArray(a)?V(a,e,c,function(a){return a}):null!=a&&(N(a)&&(a=ba(a,d+(!a.key||b&&b.key===a.key?\"\":(\"\"+a.key).replace(O,\"$&/\")+\"/\")+c)),e.push(a))}function V(a,b,c,e,d){var g=\"\";null!=c&&(g=(\"\"+c).replace(O,\"$&/\")+\"/\");b=Q(b,g,e,d);U(a,da,b);R(b)}function W(){var a=I.current;if(null===a)throw Error(B(321));return a}\nvar X={Children:{map:function(a,b,c){if(null==a)return a;var e=[];V(a,e,null,b,c);return e},forEach:function(a,b,c){if(null==a)return a;b=Q(null,null,b,c);U(a,ca,b);R(b)},count:function(a){return U(a,function(){return null},null)},toArray:function(a){var b=[];V(a,b,null,function(a){return a});return b},only:function(a){if(!N(a))throw Error(B(143));return a}},createRef:function(){return{current:null}},Component:E,PureComponent:G,createContext:function(a,b){void 0===b&&(b=null);a={$$typeof:w,_calculateChangedBits:b,\n_currentValue:a,_currentValue2:a,_threadCount:0,Provider:null,Consumer:null};a.Provider={$$typeof:v,_context:a};return a.Consumer=a},forwardRef:function(a){return{$$typeof:x,render:a}},lazy:function(a){return{$$typeof:aa,_ctor:a,_status:-1,_result:null}},memo:function(a,b){return{$$typeof:z,type:a,compare:void 0===b?null:b}},useCallback:function(a,b){return W().useCallback(a,b)},useContext:function(a,b){return W().useContext(a,b)},useEffect:function(a,b){return W().useEffect(a,b)},useImperativeHandle:function(a,\nb,c){return W().useImperativeHandle(a,b,c)},useDebugValue:function(){},useLayoutEffect:function(a,b){return W().useLayoutEffect(a,b)},useMemo:function(a,b){return W().useMemo(a,b)},useReducer:function(a,b,c){return W().useReducer(a,b,c)},useRef:function(a){return W().useRef(a)},useState:function(a){return W().useState(a)},Fragment:r,Profiler:u,StrictMode:t,Suspense:y,createElement:M,cloneElement:function(a,b,c){if(null===a||void 0===a)throw Error(B(267,a));var e=h({},a.props),d=a.key,g=a.ref,l=a._owner;\nif(null!=b){void 0!==b.ref&&(g=b.ref,l=J.current);void 0!==b.key&&(d=\"\"+b.key);if(a.type&&a.type.defaultProps)var f=a.type.defaultProps;for(k in b)K.call(b,k)&&!L.hasOwnProperty(k)&&(e[k]=void 0===b[k]&&void 0!==f?f[k]:b[k])}var k=arguments.length-2;if(1===k)e.children=c;else if(1<k){f=Array(k);for(var m=0;m<k;m++)f[m]=arguments[m+2];e.children=f}return{$$typeof:p,type:a.type,key:d,ref:g,props:e,_owner:l}},createFactory:function(a){var b=M.bind(null,a);b.type=a;return b},isValidElement:N,version:\"16.12.0\",\n__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{ReactCurrentDispatcher:I,ReactCurrentBatchConfig:{suspense:null},ReactCurrentOwner:J,IsSomeRendererActing:{current:!1},assign:h}},Y={default:X},Z=Y&&X||Y;module.exports=Z.default||Z;\n","/** @license React v16.12.0\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),n=require(\"object-assign\"),q=require(\"scheduler\");function u(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}if(!aa)throw Error(u(227));var ba=null,ca={};\nfunction da(){if(ba)for(var a in ca){var b=ca[a],c=ba.indexOf(a);if(!(-1<c))throw Error(u(96,a));if(!ea[c]){if(!b.extractEvents)throw Error(u(97,a));ea[c]=b;c=b.eventTypes;for(var d in c){var e=void 0;var f=c[d],g=b,h=d;if(fa.hasOwnProperty(h))throw Error(u(99,h));fa[h]=f;var k=f.phasedRegistrationNames;if(k){for(e in k)k.hasOwnProperty(e)&&ha(k[e],g,h);e=!0}else f.registrationName?(ha(f.registrationName,g,h),e=!0):e=!1;if(!e)throw Error(u(98,d,a));}}}}\nfunction ha(a,b,c){if(ia[a])throw Error(u(100,a));ia[a]=b;ja[a]=b.eventTypes[c].dependencies}var ea=[],fa={},ia={},ja={};function ka(a,b,c,d,e,f,g,h,k){var l=Array.prototype.slice.call(arguments,3);try{b.apply(c,l)}catch(m){this.onError(m)}}var la=!1,ma=null,na=!1,oa=null,pa={onError:function(a){la=!0;ma=a}};function qa(a,b,c,d,e,f,g,h,k){la=!1;ma=null;ka.apply(pa,arguments)}\nfunction ra(a,b,c,d,e,f,g,h,k){qa.apply(this,arguments);if(la){if(la){var l=ma;la=!1;ma=null}else throw Error(u(198));na||(na=!0,oa=l)}}var sa=null,ua=null,va=null;function wa(a,b,c){var d=a.type||\"unknown-event\";a.currentTarget=va(c);ra(d,b,void 0,a);a.currentTarget=null}function xa(a,b){if(null==b)throw Error(u(30));if(null==a)return b;if(Array.isArray(a)){if(Array.isArray(b))return a.push.apply(a,b),a;a.push(b);return a}return Array.isArray(b)?[a].concat(b):[a,b]}\nfunction ya(a,b,c){Array.isArray(a)?a.forEach(b,c):a&&b.call(c,a)}var za=null;function Aa(a){if(a){var b=a._dispatchListeners,c=a._dispatchInstances;if(Array.isArray(b))for(var d=0;d<b.length&&!a.isPropagationStopped();d++)wa(a,b[d],c[d]);else b&&wa(a,b,c);a._dispatchListeners=null;a._dispatchInstances=null;a.isPersistent()||a.constructor.release(a)}}function Ba(a){null!==a&&(za=xa(za,a));a=za;za=null;if(a){ya(a,Aa);if(za)throw Error(u(95));if(na)throw a=oa,na=!1,oa=null,a;}}\nvar Ca={injectEventPluginOrder:function(a){if(ba)throw Error(u(101));ba=Array.prototype.slice.call(a);da()},injectEventPluginsByName:function(a){var b=!1,c;for(c in a)if(a.hasOwnProperty(c)){var d=a[c];if(!ca.hasOwnProperty(c)||ca[c]!==d){if(ca[c])throw Error(u(102,c));ca[c]=d;b=!0}}b&&da()}};\nfunction Da(a,b){var c=a.stateNode;if(!c)return null;var d=sa(c);if(!d)return null;c=d[b];a:switch(b){case \"onClick\":case \"onClickCapture\":case \"onDoubleClick\":case \"onDoubleClickCapture\":case \"onMouseDown\":case \"onMouseDownCapture\":case \"onMouseMove\":case \"onMouseMoveCapture\":case \"onMouseUp\":case \"onMouseUpCapture\":(d=!d.disabled)||(a=a.type,d=!(\"button\"===a||\"input\"===a||\"select\"===a||\"textarea\"===a));a=!d;break a;default:a=!1}if(a)return null;if(c&&\"function\"!==typeof c)throw Error(u(231,b,typeof c));\nreturn c}var Ea=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;Ea.hasOwnProperty(\"ReactCurrentDispatcher\")||(Ea.ReactCurrentDispatcher={current:null});Ea.hasOwnProperty(\"ReactCurrentBatchConfig\")||(Ea.ReactCurrentBatchConfig={suspense:null});\nvar Fa=/^(.*)[\\\\\\/]/,w=\"function\"===typeof Symbol&&Symbol.for,Ga=w?Symbol.for(\"react.element\"):60103,Ha=w?Symbol.for(\"react.portal\"):60106,Ia=w?Symbol.for(\"react.fragment\"):60107,Ja=w?Symbol.for(\"react.strict_mode\"):60108,Ka=w?Symbol.for(\"react.profiler\"):60114,La=w?Symbol.for(\"react.provider\"):60109,Ma=w?Symbol.for(\"react.context\"):60110,Na=w?Symbol.for(\"react.concurrent_mode\"):60111,Oa=w?Symbol.for(\"react.forward_ref\"):60112,Pa=w?Symbol.for(\"react.suspense\"):60113,Qa=w?Symbol.for(\"react.suspense_list\"):\n60120,Ra=w?Symbol.for(\"react.memo\"):60115,Sa=w?Symbol.for(\"react.lazy\"):60116;w&&Symbol.for(\"react.fundamental\");w&&Symbol.for(\"react.responder\");w&&Symbol.for(\"react.scope\");var Ta=\"function\"===typeof Symbol&&Symbol.iterator;function Ua(a){if(null===a||\"object\"!==typeof a)return null;a=Ta&&a[Ta]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nfunction Va(a){if(-1===a._status){a._status=0;var b=a._ctor;b=b();a._result=b;b.then(function(b){0===a._status&&(b=b.default,a._status=1,a._result=b)},function(b){0===a._status&&(a._status=2,a._result=b)})}}\nfunction Wa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case Ia:return\"Fragment\";case Ha:return\"Portal\";case Ka:return\"Profiler\";case Ja:return\"StrictMode\";case Pa:return\"Suspense\";case Qa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ma:return\"Context.Consumer\";case La:return\"Context.Provider\";case Oa:var b=a.render;b=b.displayName||b.name||\"\";return a.displayName||(\"\"!==b?\"ForwardRef(\"+b+\")\":\n\"ForwardRef\");case Ra:return Wa(a.type);case Sa:if(a=1===a._status?a._result:null)return Wa(a)}return null}function Xa(a){var b=\"\";do{a:switch(a.tag){case 3:case 4:case 6:case 7:case 10:case 9:var c=\"\";break a;default:var d=a._debugOwner,e=a._debugSource,f=Wa(a.type);c=null;d&&(c=Wa(d.type));d=f;f=\"\";e?f=\" (at \"+e.fileName.replace(Fa,\"\")+\":\"+e.lineNumber+\")\":c&&(f=\" (created by \"+c+\")\");c=\"\\n in \"+(d||\"Unknown\")+f}b+=c;a=a.return}while(a);return b}\nvar Ya=!(\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement),Za=null,$a=null,ab=null;function bb(a){if(a=ua(a)){if(\"function\"!==typeof Za)throw Error(u(280));var b=sa(a.stateNode);Za(a.stateNode,a.type,b)}}function cb(a){$a?ab?ab.push(a):ab=[a]:$a=a}function db(){if($a){var a=$a,b=ab;ab=$a=null;bb(a);if(b)for(a=0;a<b.length;a++)bb(b[a])}}function eb(a,b){return a(b)}function fb(a,b,c,d){return a(b,c,d)}function gb(){}\nvar hb=eb,ib=!1,jb=!1;function kb(){if(null!==$a||null!==ab)gb(),db()}new Map;var lb=/^[:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD][:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD\\-.0-9\\u00B7\\u0300-\\u036F\\u203F-\\u2040]*$/,mb=Object.prototype.hasOwnProperty,nb={},ob={};\nfunction pb(a){if(mb.call(ob,a))return!0;if(mb.call(nb,a))return!1;if(lb.test(a))return ob[a]=!0;nb[a]=!0;return!1}function qb(a,b,c,d){if(null!==c&&0===c.type)return!1;switch(typeof b){case \"function\":case \"symbol\":return!0;case \"boolean\":if(d)return!1;if(null!==c)return!c.acceptsBooleans;a=a.toLowerCase().slice(0,5);return\"data-\"!==a&&\"aria-\"!==a;default:return!1}}\nfunction rb(a,b,c,d){if(null===b||\"undefined\"===typeof b||qb(a,b,c,d))return!0;if(d)return!1;if(null!==c)switch(c.type){case 3:return!b;case 4:return!1===b;case 5:return isNaN(b);case 6:return isNaN(b)||1>b}return!1}function B(a,b,c,d,e,f){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f}var D={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){D[a]=new B(a,0,!1,a,null,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];D[b]=new B(b,1,!1,a[1],null,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){D[a]=new B(a,2,!1,a.toLowerCase(),null,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){D[a]=new B(a,2,!1,a,null,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){D[a]=new B(a,3,!1,a.toLowerCase(),null,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){D[a]=new B(a,3,!0,a,null,!1)});[\"capture\",\"download\"].forEach(function(a){D[a]=new B(a,4,!1,a,null,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){D[a]=new B(a,6,!1,a,null,!1)});[\"rowSpan\",\"start\"].forEach(function(a){D[a]=new B(a,5,!1,a.toLowerCase(),null,!1)});var sb=/[\\-:]([a-z])/g;function tb(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(sb,\ntb);D[b]=new B(b,1,!1,a,null,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(sb,tb);D[b]=new B(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(sb,tb);D[b]=new B(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!1)});\nD.xlinkHref=new B(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!0)});function ub(a){switch(typeof a){case \"boolean\":case \"number\":case \"object\":case \"string\":case \"undefined\":return a;default:return\"\"}}\nfunction vb(a,b,c,d){var e=D.hasOwnProperty(b)?D[b]:null;var f=null!==e?0===e.type:d?!1:!(2<b.length)||\"o\"!==b[0]&&\"O\"!==b[0]||\"n\"!==b[1]&&\"N\"!==b[1]?!1:!0;f||(rb(b,c,e,d)&&(c=null),d||null===e?pb(b)&&(null===c?a.removeAttribute(b):a.setAttribute(b,\"\"+c)):e.mustUseProperty?a[e.propertyName]=null===c?3===e.type?!1:\"\":c:(b=e.attributeName,d=e.attributeNamespace,null===c?a.removeAttribute(b):(e=e.type,c=3===e||4===e&&!0===c?\"\":\"\"+c,d?a.setAttributeNS(d,b,c):a.setAttribute(b,c))))}\nfunction wb(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction xb(a){var b=wb(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function yb(a){a._valueTracker||(a._valueTracker=xb(a))}function zb(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=wb(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Ab(a,b){var c=b.checked;return n({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}\nfunction Bb(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=ub(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function Cb(a,b){b=b.checked;null!=b&&vb(a,\"checked\",b,!1)}\nfunction Eb(a,b){Cb(a,b);var c=ub(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?Fb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&Fb(a,b.type,ub(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction Gb(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!a.defaultChecked;a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction Fb(a,b,c){if(\"number\"!==b||a.ownerDocument.activeElement!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}function Hb(a){var b=\"\";aa.Children.forEach(a,function(a){null!=a&&(b+=a)});return b}function Ib(a,b){a=n({children:void 0},b);if(b=Hb(b.children))a.children=b;return a}\nfunction Jb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e<c.length;e++)b[\"$\"+c[e]]=!0;for(c=0;c<a.length;c++)e=b.hasOwnProperty(\"$\"+a[c].value),a[c].selected!==e&&(a[c].selected=e),e&&d&&(a[c].defaultSelected=!0)}else{c=\"\"+ub(c);b=null;for(e=0;e<a.length;e++){if(a[e].value===c){a[e].selected=!0;d&&(a[e].defaultSelected=!0);return}null!==b||a[e].disabled||(b=a[e])}null!==b&&(b.selected=!0)}}\nfunction Kb(a,b){if(null!=b.dangerouslySetInnerHTML)throw Error(u(91));return n({},b,{value:void 0,defaultValue:void 0,children:\"\"+a._wrapperState.initialValue})}function Lb(a,b){var c=b.value;if(null==c){c=b.defaultValue;b=b.children;if(null!=b){if(null!=c)throw Error(u(92));if(Array.isArray(b)){if(!(1>=b.length))throw Error(u(93));b=b[0]}c=b}null==c&&(c=\"\")}a._wrapperState={initialValue:ub(c)}}\nfunction Mb(a,b){var c=ub(b.value),d=ub(b.defaultValue);null!=c&&(c=\"\"+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=\"\"+d)}function Nb(a){var b=a.textContent;b===a._wrapperState.initialValue&&\"\"!==b&&null!==b&&(a.value=b)}var Ob={html:\"http://www.w3.org/1999/xhtml\",mathml:\"http://www.w3.org/1998/Math/MathML\",svg:\"http://www.w3.org/2000/svg\"};\nfunction Pb(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}function Qb(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?Pb(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}\nvar Rb,Sb=function(a){return\"undefined\"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if(a.namespaceURI!==Ob.svg||\"innerHTML\"in a)a.innerHTML=b;else{Rb=Rb||document.createElement(\"div\");Rb.innerHTML=\"<svg>\"+b.valueOf().toString()+\"</svg>\";for(b=Rb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction Tb(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}function Ub(a,b){var c={};c[a.toLowerCase()]=b.toLowerCase();c[\"Webkit\"+a]=\"webkit\"+b;c[\"Moz\"+a]=\"moz\"+b;return c}var Vb={animationend:Ub(\"Animation\",\"AnimationEnd\"),animationiteration:Ub(\"Animation\",\"AnimationIteration\"),animationstart:Ub(\"Animation\",\"AnimationStart\"),transitionend:Ub(\"Transition\",\"TransitionEnd\")},Wb={},Xb={};\nYa&&(Xb=document.createElement(\"div\").style,\"AnimationEvent\"in window||(delete Vb.animationend.animation,delete Vb.animationiteration.animation,delete Vb.animationstart.animation),\"TransitionEvent\"in window||delete Vb.transitionend.transition);function Yb(a){if(Wb[a])return Wb[a];if(!Vb[a])return a;var b=Vb[a],c;for(c in b)if(b.hasOwnProperty(c)&&c in Xb)return Wb[a]=b[c];return a}var Zb=Yb(\"animationend\"),$b=Yb(\"animationiteration\"),ac=Yb(\"animationstart\"),bc=Yb(\"transitionend\"),cc=\"abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange seeked seeking stalled suspend timeupdate volumechange waiting\".split(\" \");\nfunction ec(a){var b=a,c=a;if(a.alternate)for(;b.return;)b=b.return;else{a=b;do b=a,0!==(b.effectTag&1026)&&(c=b.return),a=b.return;while(a)}return 3===b.tag?c:null}function fc(a){if(13===a.tag){var b=a.memoizedState;null===b&&(a=a.alternate,null!==a&&(b=a.memoizedState));if(null!==b)return b.dehydrated}return null}function gc(a){if(ec(a)!==a)throw Error(u(188));}\nfunction hc(a){var b=a.alternate;if(!b){b=ec(a);if(null===b)throw Error(u(188));return b!==a?null:a}for(var c=a,d=b;;){var e=c.return;if(null===e)break;var f=e.alternate;if(null===f){d=e.return;if(null!==d){c=d;continue}break}if(e.child===f.child){for(f=e.child;f;){if(f===c)return gc(e),a;if(f===d)return gc(e),b;f=f.sibling}throw Error(u(188));}if(c.return!==d.return)c=e,d=f;else{for(var g=!1,h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===\nc){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}if(!g)throw Error(u(189));}}if(c.alternate!==d)throw Error(u(190));}if(3!==c.tag)throw Error(u(188));return c.stateNode.current===c?a:b}function ic(a){a=hc(a);if(!a)return null;for(var b=a;;){if(5===b.tag||6===b.tag)return b;if(b.child)b.child.return=b,b=b.child;else{if(b===a)break;for(;!b.sibling;){if(!b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}}return null}\nvar jc,kc,lc,mc=!1,nc=[],oc=null,pc=null,qc=null,rc=new Map,sc=new Map,tc=[],uc=\"mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput close cancel copy cut paste click change contextmenu reset submit\".split(\" \"),vc=\"focus blur dragenter dragleave mouseover mouseout pointerover pointerout gotpointercapture lostpointercapture\".split(\" \");\nfunction wc(a){var b=xc(a);uc.forEach(function(c){yc(c,a,b)});vc.forEach(function(c){yc(c,a,b)})}function zc(a,b,c,d){return{blockedOn:a,topLevelType:b,eventSystemFlags:c|32,nativeEvent:d}}function Ac(a,b){switch(a){case \"focus\":case \"blur\":oc=null;break;case \"dragenter\":case \"dragleave\":pc=null;break;case \"mouseover\":case \"mouseout\":qc=null;break;case \"pointerover\":case \"pointerout\":rc.delete(b.pointerId);break;case \"gotpointercapture\":case \"lostpointercapture\":sc.delete(b.pointerId)}}\nfunction Bc(a,b,c,d,e){if(null===a||a.nativeEvent!==e)return a=zc(b,c,d,e),null!==b&&(b=Cc(b),null!==b&&kc(b)),a;a.eventSystemFlags|=d;return a}function Dc(a,b,c,d){switch(b){case \"focus\":return oc=Bc(oc,a,b,c,d),!0;case \"dragenter\":return pc=Bc(pc,a,b,c,d),!0;case \"mouseover\":return qc=Bc(qc,a,b,c,d),!0;case \"pointerover\":var e=d.pointerId;rc.set(e,Bc(rc.get(e)||null,a,b,c,d));return!0;case \"gotpointercapture\":return e=d.pointerId,sc.set(e,Bc(sc.get(e)||null,a,b,c,d)),!0}return!1}\nfunction Ec(a){var b=Fc(a.target);if(null!==b){var c=ec(b);if(null!==c)if(b=c.tag,13===b){if(b=fc(c),null!==b){a.blockedOn=b;q.unstable_runWithPriority(a.priority,function(){lc(c)});return}}else if(3===b&&c.stateNode.hydrate){a.blockedOn=3===c.tag?c.stateNode.containerInfo:null;return}}a.blockedOn=null}function Gc(a){if(null!==a.blockedOn)return!1;var b=Hc(a.topLevelType,a.eventSystemFlags,a.nativeEvent);if(null!==b){var c=Cc(b);null!==c&&kc(c);a.blockedOn=b;return!1}return!0}\nfunction Ic(a,b,c){Gc(a)&&c.delete(b)}function Jc(){for(mc=!1;0<nc.length;){var a=nc[0];if(null!==a.blockedOn){a=Cc(a.blockedOn);null!==a&&jc(a);break}var b=Hc(a.topLevelType,a.eventSystemFlags,a.nativeEvent);null!==b?a.blockedOn=b:nc.shift()}null!==oc&&Gc(oc)&&(oc=null);null!==pc&&Gc(pc)&&(pc=null);null!==qc&&Gc(qc)&&(qc=null);rc.forEach(Ic);sc.forEach(Ic)}function Kc(a,b){a.blockedOn===b&&(a.blockedOn=null,mc||(mc=!0,q.unstable_scheduleCallback(q.unstable_NormalPriority,Jc)))}\nfunction Lc(a){function b(b){return Kc(b,a)}if(0<nc.length){Kc(nc[0],a);for(var c=1;c<nc.length;c++){var d=nc[c];d.blockedOn===a&&(d.blockedOn=null)}}null!==oc&&Kc(oc,a);null!==pc&&Kc(pc,a);null!==qc&&Kc(qc,a);rc.forEach(b);sc.forEach(b);for(c=0;c<tc.length;c++)d=tc[c],d.blockedOn===a&&(d.blockedOn=null);for(;0<tc.length&&(c=tc[0],null===c.blockedOn);)Ec(c),null===c.blockedOn&&tc.shift()}\nfunction Mc(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}function Nc(a){do a=a.return;while(a&&5!==a.tag);return a?a:null}function Oc(a,b,c){if(b=Da(a,c.dispatchConfig.phasedRegistrationNames[b]))c._dispatchListeners=xa(c._dispatchListeners,b),c._dispatchInstances=xa(c._dispatchInstances,a)}\nfunction Pc(a){if(a&&a.dispatchConfig.phasedRegistrationNames){for(var b=a._targetInst,c=[];b;)c.push(b),b=Nc(b);for(b=c.length;0<b--;)Oc(c[b],\"captured\",a);for(b=0;b<c.length;b++)Oc(c[b],\"bubbled\",a)}}function Qc(a,b,c){a&&c&&c.dispatchConfig.registrationName&&(b=Da(a,c.dispatchConfig.registrationName))&&(c._dispatchListeners=xa(c._dispatchListeners,b),c._dispatchInstances=xa(c._dispatchInstances,a))}function Rc(a){a&&a.dispatchConfig.registrationName&&Qc(a._targetInst,null,a)}\nfunction Sc(a){ya(a,Pc)}function Tc(){return!0}function Uc(){return!1}function E(a,b,c,d){this.dispatchConfig=a;this._targetInst=b;this.nativeEvent=c;a=this.constructor.Interface;for(var e in a)a.hasOwnProperty(e)&&((b=a[e])?this[e]=b(c):\"target\"===e?this.target=d:this[e]=c[e]);this.isDefaultPrevented=(null!=c.defaultPrevented?c.defaultPrevented:!1===c.returnValue)?Tc:Uc;this.isPropagationStopped=Uc;return this}\nn(E.prototype,{preventDefault:function(){this.defaultPrevented=!0;var a=this.nativeEvent;a&&(a.preventDefault?a.preventDefault():\"unknown\"!==typeof a.returnValue&&(a.returnValue=!1),this.isDefaultPrevented=Tc)},stopPropagation:function(){var a=this.nativeEvent;a&&(a.stopPropagation?a.stopPropagation():\"unknown\"!==typeof a.cancelBubble&&(a.cancelBubble=!0),this.isPropagationStopped=Tc)},persist:function(){this.isPersistent=Tc},isPersistent:Uc,destructor:function(){var a=this.constructor.Interface,\nb;for(b in a)this[b]=null;this.nativeEvent=this._targetInst=this.dispatchConfig=null;this.isPropagationStopped=this.isDefaultPrevented=Uc;this._dispatchInstances=this._dispatchListeners=null}});E.Interface={type:null,target:null,currentTarget:function(){return null},eventPhase:null,bubbles:null,cancelable:null,timeStamp:function(a){return a.timeStamp||Date.now()},defaultPrevented:null,isTrusted:null};\nE.extend=function(a){function b(){}function c(){return d.apply(this,arguments)}var d=this;b.prototype=d.prototype;var e=new b;n(e,c.prototype);c.prototype=e;c.prototype.constructor=c;c.Interface=n({},d.Interface,a);c.extend=d.extend;Vc(c);return c};Vc(E);function Wc(a,b,c,d){if(this.eventPool.length){var e=this.eventPool.pop();this.call(e,a,b,c,d);return e}return new this(a,b,c,d)}\nfunction Xc(a){if(!(a instanceof this))throw Error(u(279));a.destructor();10>this.eventPool.length&&this.eventPool.push(a)}function Vc(a){a.eventPool=[];a.getPooled=Wc;a.release=Xc}var Yc=E.extend({animationName:null,elapsedTime:null,pseudoElement:null}),Zc=E.extend({clipboardData:function(a){return\"clipboardData\"in a?a.clipboardData:window.clipboardData}}),$c=E.extend({view:null,detail:null}),ad=$c.extend({relatedTarget:null});\nfunction bd(a){var b=a.keyCode;\"charCode\"in a?(a=a.charCode,0===a&&13===b&&(a=13)):a=b;10===a&&(a=13);return 32<=a||13===a?a:0}\nvar cd={Esc:\"Escape\",Spacebar:\" \",Left:\"ArrowLeft\",Up:\"ArrowUp\",Right:\"ArrowRight\",Down:\"ArrowDown\",Del:\"Delete\",Win:\"OS\",Menu:\"ContextMenu\",Apps:\"ContextMenu\",Scroll:\"ScrollLock\",MozPrintableKey:\"Unidentified\"},dd={8:\"Backspace\",9:\"Tab\",12:\"Clear\",13:\"Enter\",16:\"Shift\",17:\"Control\",18:\"Alt\",19:\"Pause\",20:\"CapsLock\",27:\"Escape\",32:\" \",33:\"PageUp\",34:\"PageDown\",35:\"End\",36:\"Home\",37:\"ArrowLeft\",38:\"ArrowUp\",39:\"ArrowRight\",40:\"ArrowDown\",45:\"Insert\",46:\"Delete\",112:\"F1\",113:\"F2\",114:\"F3\",115:\"F4\",\n116:\"F5\",117:\"F6\",118:\"F7\",119:\"F8\",120:\"F9\",121:\"F10\",122:\"F11\",123:\"F12\",144:\"NumLock\",145:\"ScrollLock\",224:\"Meta\"},ed={Alt:\"altKey\",Control:\"ctrlKey\",Meta:\"metaKey\",Shift:\"shiftKey\"};function gd(a){var b=this.nativeEvent;return b.getModifierState?b.getModifierState(a):(a=ed[a])?!!b[a]:!1}function hd(){return gd}\nvar id=$c.extend({key:function(a){if(a.key){var b=cd[a.key]||a.key;if(\"Unidentified\"!==b)return b}return\"keypress\"===a.type?(a=bd(a),13===a?\"Enter\":String.fromCharCode(a)):\"keydown\"===a.type||\"keyup\"===a.type?dd[a.keyCode]||\"Unidentified\":\"\"},location:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,repeat:null,locale:null,getModifierState:hd,charCode:function(a){return\"keypress\"===a.type?bd(a):0},keyCode:function(a){return\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0},which:function(a){return\"keypress\"===\na.type?bd(a):\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0}}),jd=0,kd=0,ld=!1,md=!1,nd=$c.extend({screenX:null,screenY:null,clientX:null,clientY:null,pageX:null,pageY:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,getModifierState:hd,button:null,buttons:null,relatedTarget:function(a){return a.relatedTarget||(a.fromElement===a.srcElement?a.toElement:a.fromElement)},movementX:function(a){if(\"movementX\"in a)return a.movementX;var b=jd;jd=a.screenX;return ld?\"mousemove\"===a.type?a.screenX-\nb:0:(ld=!0,0)},movementY:function(a){if(\"movementY\"in a)return a.movementY;var b=kd;kd=a.screenY;return md?\"mousemove\"===a.type?a.screenY-b:0:(md=!0,0)}}),od=nd.extend({pointerId:null,width:null,height:null,pressure:null,tangentialPressure:null,tiltX:null,tiltY:null,twist:null,pointerType:null,isPrimary:null}),pd=nd.extend({dataTransfer:null}),qd=$c.extend({touches:null,targetTouches:null,changedTouches:null,altKey:null,metaKey:null,ctrlKey:null,shiftKey:null,getModifierState:hd}),rd=E.extend({propertyName:null,\nelapsedTime:null,pseudoElement:null}),sd=nd.extend({deltaX:function(a){return\"deltaX\"in a?a.deltaX:\"wheelDeltaX\"in a?-a.wheelDeltaX:0},deltaY:function(a){return\"deltaY\"in a?a.deltaY:\"wheelDeltaY\"in a?-a.wheelDeltaY:\"wheelDelta\"in a?-a.wheelDelta:0},deltaZ:null,deltaMode:null}),td=[[\"blur\",\"blur\",0],[\"cancel\",\"cancel\",0],[\"click\",\"click\",0],[\"close\",\"close\",0],[\"contextmenu\",\"contextMenu\",0],[\"copy\",\"copy\",0],[\"cut\",\"cut\",0],[\"auxclick\",\"auxClick\",0],[\"dblclick\",\"doubleClick\",0],[\"dragend\",\"dragEnd\",\n0],[\"dragstart\",\"dragStart\",0],[\"drop\",\"drop\",0],[\"focus\",\"focus\",0],[\"input\",\"input\",0],[\"invalid\",\"invalid\",0],[\"keydown\",\"keyDown\",0],[\"keypress\",\"keyPress\",0],[\"keyup\",\"keyUp\",0],[\"mousedown\",\"mouseDown\",0],[\"mouseup\",\"mouseUp\",0],[\"paste\",\"paste\",0],[\"pause\",\"pause\",0],[\"play\",\"play\",0],[\"pointercancel\",\"pointerCancel\",0],[\"pointerdown\",\"pointerDown\",0],[\"pointerup\",\"pointerUp\",0],[\"ratechange\",\"rateChange\",0],[\"reset\",\"reset\",0],[\"seeked\",\"seeked\",0],[\"submit\",\"submit\",0],[\"touchcancel\",\"touchCancel\",\n0],[\"touchend\",\"touchEnd\",0],[\"touchstart\",\"touchStart\",0],[\"volumechange\",\"volumeChange\",0],[\"drag\",\"drag\",1],[\"dragenter\",\"dragEnter\",1],[\"dragexit\",\"dragExit\",1],[\"dragleave\",\"dragLeave\",1],[\"dragover\",\"dragOver\",1],[\"mousemove\",\"mouseMove\",1],[\"mouseout\",\"mouseOut\",1],[\"mouseover\",\"mouseOver\",1],[\"pointermove\",\"pointerMove\",1],[\"pointerout\",\"pointerOut\",1],[\"pointerover\",\"pointerOver\",1],[\"scroll\",\"scroll\",1],[\"toggle\",\"toggle\",1],[\"touchmove\",\"touchMove\",1],[\"wheel\",\"wheel\",1],[\"abort\",\"abort\",\n2],[Zb,\"animationEnd\",2],[$b,\"animationIteration\",2],[ac,\"animationStart\",2],[\"canplay\",\"canPlay\",2],[\"canplaythrough\",\"canPlayThrough\",2],[\"durationchange\",\"durationChange\",2],[\"emptied\",\"emptied\",2],[\"encrypted\",\"encrypted\",2],[\"ended\",\"ended\",2],[\"error\",\"error\",2],[\"gotpointercapture\",\"gotPointerCapture\",2],[\"load\",\"load\",2],[\"loadeddata\",\"loadedData\",2],[\"loadedmetadata\",\"loadedMetadata\",2],[\"loadstart\",\"loadStart\",2],[\"lostpointercapture\",\"lostPointerCapture\",2],[\"playing\",\"playing\",2],[\"progress\",\n\"progress\",2],[\"seeking\",\"seeking\",2],[\"stalled\",\"stalled\",2],[\"suspend\",\"suspend\",2],[\"timeupdate\",\"timeUpdate\",2],[bc,\"transitionEnd\",2],[\"waiting\",\"waiting\",2]],ud={},vd={},wd=0;for(;wd<td.length;wd++){var yd=td[wd],zd=yd[0],Ad=yd[1],Bd=yd[2],Cd=\"on\"+(Ad[0].toUpperCase()+Ad.slice(1)),Dd={phasedRegistrationNames:{bubbled:Cd,captured:Cd+\"Capture\"},dependencies:[zd],eventPriority:Bd};ud[Ad]=Dd;vd[zd]=Dd}\nvar Ed={eventTypes:ud,getEventPriority:function(a){a=vd[a];return void 0!==a?a.eventPriority:2},extractEvents:function(a,b,c,d){var e=vd[a];if(!e)return null;switch(a){case \"keypress\":if(0===bd(c))return null;case \"keydown\":case \"keyup\":a=id;break;case \"blur\":case \"focus\":a=ad;break;case \"click\":if(2===c.button)return null;case \"auxclick\":case \"dblclick\":case \"mousedown\":case \"mousemove\":case \"mouseup\":case \"mouseout\":case \"mouseover\":case \"contextmenu\":a=nd;break;case \"drag\":case \"dragend\":case \"dragenter\":case \"dragexit\":case \"dragleave\":case \"dragover\":case \"dragstart\":case \"drop\":a=\npd;break;case \"touchcancel\":case \"touchend\":case \"touchmove\":case \"touchstart\":a=qd;break;case Zb:case $b:case ac:a=Yc;break;case bc:a=rd;break;case \"scroll\":a=$c;break;case \"wheel\":a=sd;break;case \"copy\":case \"cut\":case \"paste\":a=Zc;break;case \"gotpointercapture\":case \"lostpointercapture\":case \"pointercancel\":case \"pointerdown\":case \"pointermove\":case \"pointerout\":case \"pointerover\":case \"pointerup\":a=od;break;default:a=E}b=a.getPooled(e,b,c,d);Sc(b);return b}},Fd=q.unstable_UserBlockingPriority,\nGd=q.unstable_runWithPriority,Hd=Ed.getEventPriority,Id=10,Jd=[];\nfunction Kd(a){var b=a.targetInst,c=b;do{if(!c){a.ancestors.push(c);break}var d=c;if(3===d.tag)d=d.stateNode.containerInfo;else{for(;d.return;)d=d.return;d=3!==d.tag?null:d.stateNode.containerInfo}if(!d)break;b=c.tag;5!==b&&6!==b||a.ancestors.push(c);c=Fc(d)}while(c);for(c=0;c<a.ancestors.length;c++){b=a.ancestors[c];var e=Mc(a.nativeEvent);d=a.topLevelType;for(var f=a.nativeEvent,g=a.eventSystemFlags,h=null,k=0;k<ea.length;k++){var l=ea[k];l&&(l=l.extractEvents(d,b,f,e,g))&&(h=xa(h,l))}Ba(h)}}\nvar Ld=!0;function F(a,b){Md(b,a,!1)}function Md(a,b,c){switch(Hd(b)){case 0:var d=Nd.bind(null,b,1);break;case 1:d=Od.bind(null,b,1);break;default:d=Pd.bind(null,b,1)}c?a.addEventListener(b,d,!0):a.addEventListener(b,d,!1)}function Nd(a,b,c){ib||gb();var d=Pd,e=ib;ib=!0;try{fb(d,a,b,c)}finally{(ib=e)||kb()}}function Od(a,b,c){Gd(Fd,Pd.bind(null,a,b,c))}\nfunction Qd(a,b,c,d){if(Jd.length){var e=Jd.pop();e.topLevelType=a;e.eventSystemFlags=b;e.nativeEvent=c;e.targetInst=d;a=e}else a={topLevelType:a,eventSystemFlags:b,nativeEvent:c,targetInst:d,ancestors:[]};try{if(b=Kd,c=a,jb)b(c,void 0);else{jb=!0;try{hb(b,c,void 0)}finally{jb=!1,kb()}}}finally{a.topLevelType=null,a.nativeEvent=null,a.targetInst=null,a.ancestors.length=0,Jd.length<Id&&Jd.push(a)}}\nfunction Pd(a,b,c){if(Ld)if(0<nc.length&&-1<uc.indexOf(a))a=zc(null,a,b,c),nc.push(a);else{var d=Hc(a,b,c);null===d?Ac(a,c):-1<uc.indexOf(a)?(a=zc(d,a,b,c),nc.push(a)):Dc(d,a,b,c)||(Ac(a,c),Qd(a,b,c,null))}}function Hc(a,b,c){var d=Mc(c);d=Fc(d);if(null!==d){var e=ec(d);if(null===e)d=null;else{var f=e.tag;if(13===f){d=fc(e);if(null!==d)return d;d=null}else if(3===f){if(e.stateNode.hydrate)return 3===e.tag?e.stateNode.containerInfo:null;d=null}else e!==d&&(d=null)}}Qd(a,b,c,d);return null}\nfunction Rd(a){if(!Ya)return!1;a=\"on\"+a;var b=a in document;b||(b=document.createElement(\"div\"),b.setAttribute(a,\"return;\"),b=\"function\"===typeof b[a]);return b}var Sd=new (\"function\"===typeof WeakMap?WeakMap:Map);function xc(a){var b=Sd.get(a);void 0===b&&(b=new Set,Sd.set(a,b));return b}\nfunction yc(a,b,c){if(!c.has(a)){switch(a){case \"scroll\":Md(b,\"scroll\",!0);break;case \"focus\":case \"blur\":Md(b,\"focus\",!0);Md(b,\"blur\",!0);c.add(\"blur\");c.add(\"focus\");break;case \"cancel\":case \"close\":Rd(a)&&Md(b,a,!0);break;case \"invalid\":case \"submit\":case \"reset\":break;default:-1===cc.indexOf(a)&&F(a,b)}c.add(a)}}\nvar Td={animationIterationCount:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,\nfloodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},Ud=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(Td).forEach(function(a){Ud.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);Td[b]=Td[a]})});function Vd(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||Td.hasOwnProperty(a)&&Td[a]?(\"\"+b).trim():b+\"px\"}\nfunction Wd(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=Vd(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var Xd=n({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction Yd(a,b){if(b){if(Xd[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(u(137,a,\"\"));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(u(60));if(!(\"object\"===typeof b.dangerouslySetInnerHTML&&\"__html\"in b.dangerouslySetInnerHTML))throw Error(u(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(u(62,\"\"));}}\nfunction Zd(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}function $d(a,b){a=9===a.nodeType||11===a.nodeType?a:a.ownerDocument;var c=xc(a);b=ja[b];for(var d=0;d<b.length;d++)yc(b[d],a,c)}function ae(){}\nfunction be(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}function ce(a){for(;a&&a.firstChild;)a=a.firstChild;return a}function de(a,b){var c=ce(a);a=0;for(var d;c;){if(3===c.nodeType){d=a+c.textContent.length;if(a<=b&&d>=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=ce(c)}}\nfunction ee(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?ee(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}function fe(){for(var a=window,b=be();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=be(a.document)}return b}\nfunction ge(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}var he=\"$\",ie=\"/$\",je=\"$?\",ke=\"$!\",le=null,me=null;function ne(a,b){switch(a){case \"button\":case \"input\":case \"select\":case \"textarea\":return!!b.autoFocus}return!1}\nfunction oe(a,b){return\"textarea\"===a||\"option\"===a||\"noscript\"===a||\"string\"===typeof b.children||\"number\"===typeof b.children||\"object\"===typeof b.dangerouslySetInnerHTML&&null!==b.dangerouslySetInnerHTML&&null!=b.dangerouslySetInnerHTML.__html}var pe=\"function\"===typeof setTimeout?setTimeout:void 0,qe=\"function\"===typeof clearTimeout?clearTimeout:void 0;function re(a){for(;null!=a;a=a.nextSibling){var b=a.nodeType;if(1===b||3===b)break}return a}\nfunction se(a){a=a.previousSibling;for(var b=0;a;){if(8===a.nodeType){var c=a.data;if(c===he||c===ke||c===je){if(0===b)return a;b--}else c===ie&&b++}a=a.previousSibling}return null}var te=Math.random().toString(36).slice(2),ue=\"__reactInternalInstance$\"+te,ve=\"__reactEventHandlers$\"+te,we=\"__reactContainere$\"+te;\nfunction Fc(a){var b=a[ue];if(b)return b;for(var c=a.parentNode;c;){if(b=c[we]||c[ue]){c=b.alternate;if(null!==b.child||null!==c&&null!==c.child)for(a=se(a);null!==a;){if(c=a[ue])return c;a=se(a)}return b}a=c;c=a.parentNode}return null}function Cc(a){a=a[ue]||a[we];return!a||5!==a.tag&&6!==a.tag&&13!==a.tag&&3!==a.tag?null:a}function xe(a){if(5===a.tag||6===a.tag)return a.stateNode;throw Error(u(33));}function ye(a){return a[ve]||null}var ze=null,Ae=null,Be=null;\nfunction Ce(){if(Be)return Be;var a,b=Ae,c=b.length,d,e=\"value\"in ze?ze.value:ze.textContent,f=e.length;for(a=0;a<c&&b[a]===e[a];a++);var g=c-a;for(d=1;d<=g&&b[c-d]===e[f-d];d++);return Be=e.slice(a,1<d?1-d:void 0)}var De=E.extend({data:null}),Ee=E.extend({data:null}),Fe=[9,13,27,32],Ge=Ya&&\"CompositionEvent\"in window,He=null;Ya&&\"documentMode\"in document&&(He=document.documentMode);\nvar Ie=Ya&&\"TextEvent\"in window&&!He,Je=Ya&&(!Ge||He&&8<He&&11>=He),Ke=String.fromCharCode(32),Le={beforeInput:{phasedRegistrationNames:{bubbled:\"onBeforeInput\",captured:\"onBeforeInputCapture\"},dependencies:[\"compositionend\",\"keypress\",\"textInput\",\"paste\"]},compositionEnd:{phasedRegistrationNames:{bubbled:\"onCompositionEnd\",captured:\"onCompositionEndCapture\"},dependencies:\"blur compositionend keydown keypress keyup mousedown\".split(\" \")},compositionStart:{phasedRegistrationNames:{bubbled:\"onCompositionStart\",\ncaptured:\"onCompositionStartCapture\"},dependencies:\"blur compositionstart keydown keypress keyup mousedown\".split(\" \")},compositionUpdate:{phasedRegistrationNames:{bubbled:\"onCompositionUpdate\",captured:\"onCompositionUpdateCapture\"},dependencies:\"blur compositionupdate keydown keypress keyup mousedown\".split(\" \")}},Me=!1;\nfunction Ne(a,b){switch(a){case \"keyup\":return-1!==Fe.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"blur\":return!0;default:return!1}}function Oe(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var Pe=!1;function Qe(a,b){switch(a){case \"compositionend\":return Oe(b);case \"keypress\":if(32!==b.which)return null;Me=!0;return Ke;case \"textInput\":return a=b.data,a===Ke&&Me?null:a;default:return null}}\nfunction Re(a,b){if(Pe)return\"compositionend\"===a||!Ge&&Ne(a,b)?(a=Ce(),Be=Ae=ze=null,Pe=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1<b.char.length)return b.char;if(b.which)return String.fromCharCode(b.which)}return null;case \"compositionend\":return Je&&\"ko\"!==b.locale?null:b.data;default:return null}}\nvar Se={eventTypes:Le,extractEvents:function(a,b,c,d){var e;if(Ge)b:{switch(a){case \"compositionstart\":var f=Le.compositionStart;break b;case \"compositionend\":f=Le.compositionEnd;break b;case \"compositionupdate\":f=Le.compositionUpdate;break b}f=void 0}else Pe?Ne(a,c)&&(f=Le.compositionEnd):\"keydown\"===a&&229===c.keyCode&&(f=Le.compositionStart);f?(Je&&\"ko\"!==c.locale&&(Pe||f!==Le.compositionStart?f===Le.compositionEnd&&Pe&&(e=Ce()):(ze=d,Ae=\"value\"in ze?ze.value:ze.textContent,Pe=!0)),f=De.getPooled(f,\nb,c,d),e?f.data=e:(e=Oe(c),null!==e&&(f.data=e)),Sc(f),e=f):e=null;(a=Ie?Qe(a,c):Re(a,c))?(b=Ee.getPooled(Le.beforeInput,b,c,d),b.data=a,Sc(b)):b=null;return null===e?b:null===b?e:[e,b]}},Te={color:!0,date:!0,datetime:!0,\"datetime-local\":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function Ue(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return\"input\"===b?!!Te[a.type]:\"textarea\"===b?!0:!1}\nvar Ve={change:{phasedRegistrationNames:{bubbled:\"onChange\",captured:\"onChangeCapture\"},dependencies:\"blur change click focus input keydown keyup selectionchange\".split(\" \")}};function We(a,b,c){a=E.getPooled(Ve.change,a,b,c);a.type=\"change\";cb(c);Sc(a);return a}var Xe=null,Ye=null;function Ze(a){Ba(a)}function $e(a){var b=xe(a);if(zb(b))return a}function af(a,b){if(\"change\"===a)return b}var bf=!1;Ya&&(bf=Rd(\"input\")&&(!document.documentMode||9<document.documentMode));\nfunction cf(){Xe&&(Xe.detachEvent(\"onpropertychange\",df),Ye=Xe=null)}function df(a){if(\"value\"===a.propertyName&&$e(Ye))if(a=We(Ye,a,Mc(a)),ib)Ba(a);else{ib=!0;try{eb(Ze,a)}finally{ib=!1,kb()}}}function ef(a,b,c){\"focus\"===a?(cf(),Xe=b,Ye=c,Xe.attachEvent(\"onpropertychange\",df)):\"blur\"===a&&cf()}function ff(a){if(\"selectionchange\"===a||\"keyup\"===a||\"keydown\"===a)return $e(Ye)}function gf(a,b){if(\"click\"===a)return $e(b)}function hf(a,b){if(\"input\"===a||\"change\"===a)return $e(b)}\nvar jf={eventTypes:Ve,_isInputEventSupported:bf,extractEvents:function(a,b,c,d){var e=b?xe(b):window,f=e.nodeName&&e.nodeName.toLowerCase();if(\"select\"===f||\"input\"===f&&\"file\"===e.type)var g=af;else if(Ue(e))if(bf)g=hf;else{g=ff;var h=ef}else(f=e.nodeName)&&\"input\"===f.toLowerCase()&&(\"checkbox\"===e.type||\"radio\"===e.type)&&(g=gf);if(g&&(g=g(a,b)))return We(g,c,d);h&&h(a,e,b);\"blur\"===a&&(a=e._wrapperState)&&a.controlled&&\"number\"===e.type&&Fb(e,\"number\",e.value)}},kf={mouseEnter:{registrationName:\"onMouseEnter\",\ndependencies:[\"mouseout\",\"mouseover\"]},mouseLeave:{registrationName:\"onMouseLeave\",dependencies:[\"mouseout\",\"mouseover\"]},pointerEnter:{registrationName:\"onPointerEnter\",dependencies:[\"pointerout\",\"pointerover\"]},pointerLeave:{registrationName:\"onPointerLeave\",dependencies:[\"pointerout\",\"pointerover\"]}},lf,mf={eventTypes:kf,extractEvents:function(a,b,c,d,e){var f=\"mouseover\"===a||\"pointerover\"===a,g=\"mouseout\"===a||\"pointerout\"===a;if(f&&0===(e&32)&&(c.relatedTarget||c.fromElement)||!g&&!f)return null;\ne=d.window===d?d:(e=d.ownerDocument)?e.defaultView||e.parentWindow:window;if(g){if(g=b,b=(b=c.relatedTarget||c.toElement)?Fc(b):null,null!==b&&(f=ec(b),b!==f||5!==b.tag&&6!==b.tag))b=null}else g=null;if(g===b)return null;if(\"mouseout\"===a||\"mouseover\"===a){var h=nd;var k=kf.mouseLeave;var l=kf.mouseEnter;var m=\"mouse\"}else if(\"pointerout\"===a||\"pointerover\"===a)h=od,k=kf.pointerLeave,l=kf.pointerEnter,m=\"pointer\";a=null==g?e:xe(g);e=null==b?e:xe(b);k=h.getPooled(k,g,c,d);k.type=m+\"leave\";k.target=\na;k.relatedTarget=e;d=h.getPooled(l,b,c,d);d.type=m+\"enter\";d.target=e;d.relatedTarget=a;h=g;m=b;if(h&&m)a:{l=h;a=m;g=0;for(b=l;b;b=Nc(b))g++;b=0;for(e=a;e;e=Nc(e))b++;for(;0<g-b;)l=Nc(l),g--;for(;0<b-g;)a=Nc(a),b--;for(;g--;){if(l===a||l===a.alternate)break a;l=Nc(l);a=Nc(a)}l=null}else l=null;a=l;for(l=[];h&&h!==a;){g=h.alternate;if(null!==g&&g===a)break;l.push(h);h=Nc(h)}for(h=[];m&&m!==a;){g=m.alternate;if(null!==g&&g===a)break;h.push(m);m=Nc(m)}for(m=0;m<l.length;m++)Qc(l[m],\"bubbled\",k);for(m=\nh.length;0<m--;)Qc(h[m],\"captured\",d);if(c===lf)return lf=null,[k];lf=c;return[k,d]}};function nf(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var of=\"function\"===typeof Object.is?Object.is:nf,pf=Object.prototype.hasOwnProperty;function qf(a,b){if(of(a,b))return!0;if(\"object\"!==typeof a||null===a||\"object\"!==typeof b||null===b)return!1;var c=Object.keys(a),d=Object.keys(b);if(c.length!==d.length)return!1;for(d=0;d<c.length;d++)if(!pf.call(b,c[d])||!of(a[c[d]],b[c[d]]))return!1;return!0}\nvar rf=Ya&&\"documentMode\"in document&&11>=document.documentMode,sf={select:{phasedRegistrationNames:{bubbled:\"onSelect\",captured:\"onSelectCapture\"},dependencies:\"blur contextmenu dragend focus keydown keyup mousedown mouseup selectionchange\".split(\" \")}},tf=null,uf=null,vf=null,wf=!1;\nfunction xf(a,b){var c=b.window===b?b.document:9===b.nodeType?b:b.ownerDocument;if(wf||null==tf||tf!==be(c))return null;c=tf;\"selectionStart\"in c&&ge(c)?c={start:c.selectionStart,end:c.selectionEnd}:(c=(c.ownerDocument&&c.ownerDocument.defaultView||window).getSelection(),c={anchorNode:c.anchorNode,anchorOffset:c.anchorOffset,focusNode:c.focusNode,focusOffset:c.focusOffset});return vf&&qf(vf,c)?null:(vf=c,a=E.getPooled(sf.select,uf,a,b),a.type=\"select\",a.target=tf,Sc(a),a)}\nvar yf={eventTypes:sf,extractEvents:function(a,b,c,d){var e=d.window===d?d.document:9===d.nodeType?d:d.ownerDocument,f;if(!(f=!e)){a:{e=xc(e);f=ja.onSelect;for(var g=0;g<f.length;g++)if(!e.has(f[g])){e=!1;break a}e=!0}f=!e}if(f)return null;e=b?xe(b):window;switch(a){case \"focus\":if(Ue(e)||\"true\"===e.contentEditable)tf=e,uf=b,vf=null;break;case \"blur\":vf=uf=tf=null;break;case \"mousedown\":wf=!0;break;case \"contextmenu\":case \"mouseup\":case \"dragend\":return wf=!1,xf(c,d);case \"selectionchange\":if(rf)break;\ncase \"keydown\":case \"keyup\":return xf(c,d)}return null}};Ca.injectEventPluginOrder(\"ResponderEventPlugin SimpleEventPlugin EnterLeaveEventPlugin ChangeEventPlugin SelectEventPlugin BeforeInputEventPlugin\".split(\" \"));var zf=Cc;sa=ye;ua=zf;va=xe;Ca.injectEventPluginsByName({SimpleEventPlugin:Ed,EnterLeaveEventPlugin:mf,ChangeEventPlugin:jf,SelectEventPlugin:yf,BeforeInputEventPlugin:Se});new Set;var Af=[],Bf=-1;function G(a){0>Bf||(a.current=Af[Bf],Af[Bf]=null,Bf--)}\nfunction I(a,b){Bf++;Af[Bf]=a.current;a.current=b}var Cf={},J={current:Cf},K={current:!1},Df=Cf;function Ef(a,b){var c=a.type.contextTypes;if(!c)return Cf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}function L(a){a=a.childContextTypes;return null!==a&&void 0!==a}\nfunction Ff(a){G(K,a);G(J,a)}function Gf(a){G(K,a);G(J,a)}function Hf(a,b,c){if(J.current!==Cf)throw Error(u(168));I(J,b,a);I(K,c,a)}function If(a,b,c){var d=a.stateNode;a=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in a))throw Error(u(108,Wa(b)||\"Unknown\",e));return n({},c,{},d)}function Jf(a){var b=a.stateNode;b=b&&b.__reactInternalMemoizedMergedChildContext||Cf;Df=J.current;I(J,b,a);I(K,K.current,a);return!0}\nfunction Kf(a,b,c){var d=a.stateNode;if(!d)throw Error(u(169));c?(b=If(a,b,Df),d.__reactInternalMemoizedMergedChildContext=b,G(K,a),G(J,a),I(J,b,a)):G(K,a);I(K,c,a)}\nvar Lf=q.unstable_runWithPriority,Mf=q.unstable_scheduleCallback,Nf=q.unstable_cancelCallback,Of=q.unstable_shouldYield,Pf=q.unstable_requestPaint,Qf=q.unstable_now,Rf=q.unstable_getCurrentPriorityLevel,Sf=q.unstable_ImmediatePriority,Tf=q.unstable_UserBlockingPriority,Uf=q.unstable_NormalPriority,Vf=q.unstable_LowPriority,Wf=q.unstable_IdlePriority,Xf={},Yf=void 0!==Pf?Pf:function(){},Zf=null,$f=null,ag=!1,bg=Qf(),cg=1E4>bg?Qf:function(){return Qf()-bg};\nfunction dg(){switch(Rf()){case Sf:return 99;case Tf:return 98;case Uf:return 97;case Vf:return 96;case Wf:return 95;default:throw Error(u(332));}}function eg(a){switch(a){case 99:return Sf;case 98:return Tf;case 97:return Uf;case 96:return Vf;case 95:return Wf;default:throw Error(u(332));}}function fg(a,b){a=eg(a);return Lf(a,b)}function gg(a,b,c){a=eg(a);return Mf(a,b,c)}function hg(a){null===Zf?(Zf=[a],$f=Mf(Sf,ig)):Zf.push(a);return Xf}function jg(){if(null!==$f){var a=$f;$f=null;Nf(a)}ig()}\nfunction ig(){if(!ag&&null!==Zf){ag=!0;var a=0;try{var b=Zf;fg(99,function(){for(;a<b.length;a++){var c=b[a];do c=c(!0);while(null!==c)}});Zf=null}catch(c){throw null!==Zf&&(Zf=Zf.slice(a+1)),Mf(Sf,jg),c;}finally{ag=!1}}}var kg=3;function lg(a,b,c){c/=10;return 1073741821-(((1073741821-a+b/10)/c|0)+1)*c}function mg(a,b){if(a&&a.defaultProps){b=n({},b);a=a.defaultProps;for(var c in a)void 0===b[c]&&(b[c]=a[c])}return b}var ng={current:null},og=null,pg=null,qg=null;function rg(){qg=pg=og=null}\nfunction sg(a,b){var c=a.type._context;I(ng,c._currentValue,a);c._currentValue=b}function tg(a){var b=ng.current;G(ng,a);a.type._context._currentValue=b}function ug(a,b){for(;null!==a;){var c=a.alternate;if(a.childExpirationTime<b)a.childExpirationTime=b,null!==c&&c.childExpirationTime<b&&(c.childExpirationTime=b);else if(null!==c&&c.childExpirationTime<b)c.childExpirationTime=b;else break;a=a.return}}\nfunction vg(a,b){og=a;qg=pg=null;a=a.dependencies;null!==a&&null!==a.firstContext&&(a.expirationTime>=b&&(wg=!0),a.firstContext=null)}function xg(a,b){if(qg!==a&&!1!==b&&0!==b){if(\"number\"!==typeof b||1073741823===b)qg=a,b=1073741823;b={context:a,observedBits:b,next:null};if(null===pg){if(null===og)throw Error(u(308));pg=b;og.dependencies={expirationTime:0,firstContext:b,responders:null}}else pg=pg.next=b}return a._currentValue}var yg=!1;\nfunction zg(a){return{baseState:a,firstUpdate:null,lastUpdate:null,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}function Ag(a){return{baseState:a.baseState,firstUpdate:a.firstUpdate,lastUpdate:a.lastUpdate,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}\nfunction Bg(a,b){return{expirationTime:a,suspenseConfig:b,tag:0,payload:null,callback:null,next:null,nextEffect:null}}function Cg(a,b){null===a.lastUpdate?a.firstUpdate=a.lastUpdate=b:(a.lastUpdate.next=b,a.lastUpdate=b)}\nfunction Dg(a,b){var c=a.alternate;if(null===c){var d=a.updateQueue;var e=null;null===d&&(d=a.updateQueue=zg(a.memoizedState))}else d=a.updateQueue,e=c.updateQueue,null===d?null===e?(d=a.updateQueue=zg(a.memoizedState),e=c.updateQueue=zg(c.memoizedState)):d=a.updateQueue=Ag(e):null===e&&(e=c.updateQueue=Ag(d));null===e||d===e?Cg(d,b):null===d.lastUpdate||null===e.lastUpdate?(Cg(d,b),Cg(e,b)):(Cg(d,b),e.lastUpdate=b)}\nfunction Eg(a,b){var c=a.updateQueue;c=null===c?a.updateQueue=zg(a.memoizedState):Fg(a,c);null===c.lastCapturedUpdate?c.firstCapturedUpdate=c.lastCapturedUpdate=b:(c.lastCapturedUpdate.next=b,c.lastCapturedUpdate=b)}function Fg(a,b){var c=a.alternate;null!==c&&b===c.updateQueue&&(b=a.updateQueue=Ag(b));return b}\nfunction Gg(a,b,c,d,e,f){switch(c.tag){case 1:return a=c.payload,\"function\"===typeof a?a.call(f,d,e):a;case 3:a.effectTag=a.effectTag&-4097|64;case 0:a=c.payload;e=\"function\"===typeof a?a.call(f,d,e):a;if(null===e||void 0===e)break;return n({},d,e);case 2:yg=!0}return d}\nfunction Hg(a,b,c,d,e){yg=!1;b=Fg(a,b);for(var f=b.baseState,g=null,h=0,k=b.firstUpdate,l=f;null!==k;){var m=k.expirationTime;m<e?(null===g&&(g=k,f=l),h<m&&(h=m)):(Ig(m,k.suspenseConfig),l=Gg(a,b,k,l,c,d),null!==k.callback&&(a.effectTag|=32,k.nextEffect=null,null===b.lastEffect?b.firstEffect=b.lastEffect=k:(b.lastEffect.nextEffect=k,b.lastEffect=k)));k=k.next}m=null;for(k=b.firstCapturedUpdate;null!==k;){var C=k.expirationTime;C<e?(null===m&&(m=k,null===g&&(f=l)),h<C&&(h=C)):(l=Gg(a,b,k,l,c,d),null!==\nk.callback&&(a.effectTag|=32,k.nextEffect=null,null===b.lastCapturedEffect?b.firstCapturedEffect=b.lastCapturedEffect=k:(b.lastCapturedEffect.nextEffect=k,b.lastCapturedEffect=k)));k=k.next}null===g&&(b.lastUpdate=null);null===m?b.lastCapturedUpdate=null:a.effectTag|=32;null===g&&null===m&&(f=l);b.baseState=f;b.firstUpdate=g;b.firstCapturedUpdate=m;Jg(h);a.expirationTime=h;a.memoizedState=l}\nfunction Kg(a,b,c){null!==b.firstCapturedUpdate&&(null!==b.lastUpdate&&(b.lastUpdate.next=b.firstCapturedUpdate,b.lastUpdate=b.lastCapturedUpdate),b.firstCapturedUpdate=b.lastCapturedUpdate=null);Lg(b.firstEffect,c);b.firstEffect=b.lastEffect=null;Lg(b.firstCapturedEffect,c);b.firstCapturedEffect=b.lastCapturedEffect=null}function Lg(a,b){for(;null!==a;){var c=a.callback;if(null!==c){a.callback=null;var d=b;if(\"function\"!==typeof c)throw Error(u(191,c));c.call(d)}a=a.nextEffect}}\nvar Mg=Ea.ReactCurrentBatchConfig,Ng=(new aa.Component).refs;function Og(a,b,c,d){b=a.memoizedState;c=c(d,b);c=null===c||void 0===c?b:n({},b,c);a.memoizedState=c;d=a.updateQueue;null!==d&&0===a.expirationTime&&(d.baseState=c)}\nvar Sg={isMounted:function(a){return(a=a._reactInternalFiber)?ec(a)===a:!1},enqueueSetState:function(a,b,c){a=a._reactInternalFiber;var d=Pg(),e=Mg.suspense;d=Qg(d,a,e);e=Bg(d,e);e.payload=b;void 0!==c&&null!==c&&(e.callback=c);Dg(a,e);Rg(a,d)},enqueueReplaceState:function(a,b,c){a=a._reactInternalFiber;var d=Pg(),e=Mg.suspense;d=Qg(d,a,e);e=Bg(d,e);e.tag=1;e.payload=b;void 0!==c&&null!==c&&(e.callback=c);Dg(a,e);Rg(a,d)},enqueueForceUpdate:function(a,b){a=a._reactInternalFiber;var c=Pg(),d=Mg.suspense;\nc=Qg(c,a,d);d=Bg(c,d);d.tag=2;void 0!==b&&null!==b&&(d.callback=b);Dg(a,d);Rg(a,c)}};function Tg(a,b,c,d,e,f,g){a=a.stateNode;return\"function\"===typeof a.shouldComponentUpdate?a.shouldComponentUpdate(d,f,g):b.prototype&&b.prototype.isPureReactComponent?!qf(c,d)||!qf(e,f):!0}\nfunction Ug(a,b,c){var d=!1,e=Cf;var f=b.contextType;\"object\"===typeof f&&null!==f?f=xg(f):(e=L(b)?Df:J.current,d=b.contextTypes,f=(d=null!==d&&void 0!==d)?Ef(a,e):Cf);b=new b(c,f);a.memoizedState=null!==b.state&&void 0!==b.state?b.state:null;b.updater=Sg;a.stateNode=b;b._reactInternalFiber=a;d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=e,a.__reactInternalMemoizedMaskedChildContext=f);return b}\nfunction Vg(a,b,c,d){a=b.state;\"function\"===typeof b.componentWillReceiveProps&&b.componentWillReceiveProps(c,d);\"function\"===typeof b.UNSAFE_componentWillReceiveProps&&b.UNSAFE_componentWillReceiveProps(c,d);b.state!==a&&Sg.enqueueReplaceState(b,b.state,null)}\nfunction Wg(a,b,c,d){var e=a.stateNode;e.props=c;e.state=a.memoizedState;e.refs=Ng;var f=b.contextType;\"object\"===typeof f&&null!==f?e.context=xg(f):(f=L(b)?Df:J.current,e.context=Ef(a,f));f=a.updateQueue;null!==f&&(Hg(a,f,c,e,d),e.state=a.memoizedState);f=b.getDerivedStateFromProps;\"function\"===typeof f&&(Og(a,b,f,c),e.state=a.memoizedState);\"function\"===typeof b.getDerivedStateFromProps||\"function\"===typeof e.getSnapshotBeforeUpdate||\"function\"!==typeof e.UNSAFE_componentWillMount&&\"function\"!==\ntypeof e.componentWillMount||(b=e.state,\"function\"===typeof e.componentWillMount&&e.componentWillMount(),\"function\"===typeof e.UNSAFE_componentWillMount&&e.UNSAFE_componentWillMount(),b!==e.state&&Sg.enqueueReplaceState(e,e.state,null),f=a.updateQueue,null!==f&&(Hg(a,f,c,e,d),e.state=a.memoizedState));\"function\"===typeof e.componentDidMount&&(a.effectTag|=4)}var Xg=Array.isArray;\nfunction Yg(a,b,c){a=c.ref;if(null!==a&&\"function\"!==typeof a&&\"object\"!==typeof a){if(c._owner){c=c._owner;if(c){if(1!==c.tag)throw Error(u(309));var d=c.stateNode}if(!d)throw Error(u(147,a));var e=\"\"+a;if(null!==b&&null!==b.ref&&\"function\"===typeof b.ref&&b.ref._stringRef===e)return b.ref;b=function(a){var b=d.refs;b===Ng&&(b=d.refs={});null===a?delete b[e]:b[e]=a};b._stringRef=e;return b}if(\"string\"!==typeof a)throw Error(u(284));if(!c._owner)throw Error(u(290,a));}return a}\nfunction Zg(a,b){if(\"textarea\"!==a.type)throw Error(u(31,\"[object Object]\"===Object.prototype.toString.call(b)?\"object with keys {\"+Object.keys(b).join(\", \")+\"}\":b,\"\"));}\nfunction $g(a){function b(b,c){if(a){var d=b.lastEffect;null!==d?(d.nextEffect=c,b.lastEffect=c):b.firstEffect=b.lastEffect=c;c.nextEffect=null;c.effectTag=8}}function c(c,d){if(!a)return null;for(;null!==d;)b(c,d),d=d.sibling;return null}function d(a,b){for(a=new Map;null!==b;)null!==b.key?a.set(b.key,b):a.set(b.index,b),b=b.sibling;return a}function e(a,b,c){a=ah(a,b,c);a.index=0;a.sibling=null;return a}function f(b,c,d){b.index=d;if(!a)return c;d=b.alternate;if(null!==d)return d=d.index,d<c?(b.effectTag=\n2,c):d;b.effectTag=2;return c}function g(b){a&&null===b.alternate&&(b.effectTag=2);return b}function h(a,b,c,d){if(null===b||6!==b.tag)return b=bh(c,a.mode,d),b.return=a,b;b=e(b,c,d);b.return=a;return b}function k(a,b,c,d){if(null!==b&&b.elementType===c.type)return d=e(b,c.props,d),d.ref=Yg(a,b,c),d.return=a,d;d=ch(c.type,c.key,c.props,null,a.mode,d);d.ref=Yg(a,b,c);d.return=a;return d}function l(a,b,c,d){if(null===b||4!==b.tag||b.stateNode.containerInfo!==c.containerInfo||b.stateNode.implementation!==\nc.implementation)return b=dh(c,a.mode,d),b.return=a,b;b=e(b,c.children||[],d);b.return=a;return b}function m(a,b,c,d,f){if(null===b||7!==b.tag)return b=eh(c,a.mode,d,f),b.return=a,b;b=e(b,c,d);b.return=a;return b}function C(a,b,c){if(\"string\"===typeof b||\"number\"===typeof b)return b=bh(\"\"+b,a.mode,c),b.return=a,b;if(\"object\"===typeof b&&null!==b){switch(b.$$typeof){case Ga:return c=ch(b.type,b.key,b.props,null,a.mode,c),c.ref=Yg(a,null,b),c.return=a,c;case Ha:return b=dh(b,a.mode,c),b.return=a,b}if(Xg(b)||\nUa(b))return b=eh(b,a.mode,c,null),b.return=a,b;Zg(a,b)}return null}function y(a,b,c,d){var e=null!==b?b.key:null;if(\"string\"===typeof c||\"number\"===typeof c)return null!==e?null:h(a,b,\"\"+c,d);if(\"object\"===typeof c&&null!==c){switch(c.$$typeof){case Ga:return c.key===e?c.type===Ia?m(a,b,c.props.children,d,e):k(a,b,c,d):null;case Ha:return c.key===e?l(a,b,c,d):null}if(Xg(c)||Ua(c))return null!==e?null:m(a,b,c,d,null);Zg(a,c)}return null}function H(a,b,c,d,e){if(\"string\"===typeof d||\"number\"===typeof d)return a=\na.get(c)||null,h(b,a,\"\"+d,e);if(\"object\"===typeof d&&null!==d){switch(d.$$typeof){case Ga:return a=a.get(null===d.key?c:d.key)||null,d.type===Ia?m(b,a,d.props.children,e,d.key):k(b,a,d,e);case Ha:return a=a.get(null===d.key?c:d.key)||null,l(b,a,d,e)}if(Xg(d)||Ua(d))return a=a.get(c)||null,m(b,a,d,e,null);Zg(b,d)}return null}function z(e,g,h,k){for(var l=null,m=null,r=g,x=g=0,A=null;null!==r&&x<h.length;x++){r.index>x?(A=r,r=null):A=r.sibling;var p=y(e,r,h[x],k);if(null===p){null===r&&(r=A);break}a&&\nr&&null===p.alternate&&b(e,r);g=f(p,g,x);null===m?l=p:m.sibling=p;m=p;r=A}if(x===h.length)return c(e,r),l;if(null===r){for(;x<h.length;x++)r=C(e,h[x],k),null!==r&&(g=f(r,g,x),null===m?l=r:m.sibling=r,m=r);return l}for(r=d(e,r);x<h.length;x++)A=H(r,e,x,h[x],k),null!==A&&(a&&null!==A.alternate&&r.delete(null===A.key?x:A.key),g=f(A,g,x),null===m?l=A:m.sibling=A,m=A);a&&r.forEach(function(a){return b(e,a)});return l}function ta(e,g,h,k){var l=Ua(h);if(\"function\"!==typeof l)throw Error(u(150));h=l.call(h);\nif(null==h)throw Error(u(151));for(var m=l=null,r=g,x=g=0,A=null,p=h.next();null!==r&&!p.done;x++,p=h.next()){r.index>x?(A=r,r=null):A=r.sibling;var z=y(e,r,p.value,k);if(null===z){null===r&&(r=A);break}a&&r&&null===z.alternate&&b(e,r);g=f(z,g,x);null===m?l=z:m.sibling=z;m=z;r=A}if(p.done)return c(e,r),l;if(null===r){for(;!p.done;x++,p=h.next())p=C(e,p.value,k),null!==p&&(g=f(p,g,x),null===m?l=p:m.sibling=p,m=p);return l}for(r=d(e,r);!p.done;x++,p=h.next())p=H(r,e,x,p.value,k),null!==p&&(a&&null!==\np.alternate&&r.delete(null===p.key?x:p.key),g=f(p,g,x),null===m?l=p:m.sibling=p,m=p);a&&r.forEach(function(a){return b(e,a)});return l}return function(a,d,f,h){var k=\"object\"===typeof f&&null!==f&&f.type===Ia&&null===f.key;k&&(f=f.props.children);var l=\"object\"===typeof f&&null!==f;if(l)switch(f.$$typeof){case Ga:a:{l=f.key;for(k=d;null!==k;){if(k.key===l)if(7===k.tag?f.type===Ia:k.elementType===f.type){c(a,k.sibling);d=e(k,f.type===Ia?f.props.children:f.props,h);d.ref=Yg(a,k,f);d.return=a;a=d;break a}else{c(a,\nk);break}else b(a,k);k=k.sibling}f.type===Ia?(d=eh(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=ch(f.type,f.key,f.props,null,a.mode,h),h.ref=Yg(a,d,f),h.return=a,a=h)}return g(a);case Ha:a:{for(k=f.key;null!==d;){if(d.key===k)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[],h);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=dh(f,a.mode,h);d.return=a;a=d}return g(a)}if(\"string\"===\ntypeof f||\"number\"===typeof f)return f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f,h),d.return=a,a=d):(c(a,d),d=bh(f,a.mode,h),d.return=a,a=d),g(a);if(Xg(f))return z(a,d,f,h);if(Ua(f))return ta(a,d,f,h);l&&Zg(a,f);if(\"undefined\"===typeof f&&!k)switch(a.tag){case 1:case 0:throw a=a.type,Error(u(152,a.displayName||a.name||\"Component\"));}return c(a,d)}}var fh=$g(!0),gh=$g(!1),hh={},ih={current:hh},jh={current:hh},kh={current:hh};function lh(a){if(a===hh)throw Error(u(174));return a}\nfunction mh(a,b){I(kh,b,a);I(jh,a,a);I(ih,hh,a);var c=b.nodeType;switch(c){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:Qb(null,\"\");break;default:c=8===c?b.parentNode:b,b=c.namespaceURI||null,c=c.tagName,b=Qb(b,c)}G(ih,a);I(ih,b,a)}function nh(a){G(ih,a);G(jh,a);G(kh,a)}function oh(a){lh(kh.current);var b=lh(ih.current);var c=Qb(b,a.type);b!==c&&(I(jh,a,a),I(ih,c,a))}function ph(a){jh.current===a&&(G(ih,a),G(jh,a))}var M={current:0};\nfunction qh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||c.data===je||c.data===ke))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.effectTag&64))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}function rh(a,b){return{responder:a,props:b}}\nvar sh=Ea.ReactCurrentDispatcher,N=Ea.ReactCurrentBatchConfig,th=0,uh=null,O=null,vh=null,wh=null,P=null,xh=null,yh=0,zh=null,Ah=0,Bh=!1,Ch=null,Gh=0;function Q(){throw Error(u(321));}function Hh(a,b){if(null===b)return!1;for(var c=0;c<b.length&&c<a.length;c++)if(!of(a[c],b[c]))return!1;return!0}\nfunction Ih(a,b,c,d,e,f){th=f;uh=b;vh=null!==a?a.memoizedState:null;sh.current=null===vh?Jh:Kh;b=c(d,e);if(Bh){do Bh=!1,Gh+=1,vh=null!==a?a.memoizedState:null,xh=wh,zh=P=O=null,sh.current=Kh,b=c(d,e);while(Bh);Ch=null;Gh=0}sh.current=Lh;a=uh;a.memoizedState=wh;a.expirationTime=yh;a.updateQueue=zh;a.effectTag|=Ah;a=null!==O&&null!==O.next;th=0;xh=P=wh=vh=O=uh=null;yh=0;zh=null;Ah=0;if(a)throw Error(u(300));return b}\nfunction Mh(){sh.current=Lh;th=0;xh=P=wh=vh=O=uh=null;yh=0;zh=null;Ah=0;Bh=!1;Ch=null;Gh=0}function Nh(){var a={memoizedState:null,baseState:null,queue:null,baseUpdate:null,next:null};null===P?wh=P=a:P=P.next=a;return P}function Oh(){if(null!==xh)P=xh,xh=P.next,O=vh,vh=null!==O?O.next:null;else{if(null===vh)throw Error(u(310));O=vh;var a={memoizedState:O.memoizedState,baseState:O.baseState,queue:O.queue,baseUpdate:O.baseUpdate,next:null};P=null===P?wh=a:P.next=a;vh=O.next}return P}\nfunction Ph(a,b){return\"function\"===typeof b?b(a):b}\nfunction Qh(a){var b=Oh(),c=b.queue;if(null===c)throw Error(u(311));c.lastRenderedReducer=a;if(0<Gh){var d=c.dispatch;if(null!==Ch){var e=Ch.get(c);if(void 0!==e){Ch.delete(c);var f=b.memoizedState;do f=a(f,e.action),e=e.next;while(null!==e);of(f,b.memoizedState)||(wg=!0);b.memoizedState=f;b.baseUpdate===c.last&&(b.baseState=f);c.lastRenderedState=f;return[f,d]}}return[b.memoizedState,d]}d=c.last;var g=b.baseUpdate;f=b.baseState;null!==g?(null!==d&&(d.next=null),d=g.next):d=null!==d?d.next:null;if(null!==\nd){var h=e=null,k=d,l=!1;do{var m=k.expirationTime;m<th?(l||(l=!0,h=g,e=f),m>yh&&(yh=m,Jg(yh))):(Ig(m,k.suspenseConfig),f=k.eagerReducer===a?k.eagerState:a(f,k.action));g=k;k=k.next}while(null!==k&&k!==d);l||(h=g,e=f);of(f,b.memoizedState)||(wg=!0);b.memoizedState=f;b.baseUpdate=h;b.baseState=e;c.lastRenderedState=f}return[b.memoizedState,c.dispatch]}\nfunction Rh(a){var b=Nh();\"function\"===typeof a&&(a=a());b.memoizedState=b.baseState=a;a=b.queue={last:null,dispatch:null,lastRenderedReducer:Ph,lastRenderedState:a};a=a.dispatch=Sh.bind(null,uh,a);return[b.memoizedState,a]}function Th(a){return Qh(Ph,a)}function Uh(a,b,c,d){a={tag:a,create:b,destroy:c,deps:d,next:null};null===zh?(zh={lastEffect:null},zh.lastEffect=a.next=a):(b=zh.lastEffect,null===b?zh.lastEffect=a.next=a:(c=b.next,b.next=a,a.next=c,zh.lastEffect=a));return a}\nfunction Vh(a,b,c,d){var e=Nh();Ah|=a;e.memoizedState=Uh(b,c,void 0,void 0===d?null:d)}function Wh(a,b,c,d){var e=Oh();d=void 0===d?null:d;var f=void 0;if(null!==O){var g=O.memoizedState;f=g.destroy;if(null!==d&&Hh(d,g.deps)){Uh(0,c,f,d);return}}Ah|=a;e.memoizedState=Uh(b,c,f,d)}function Xh(a,b){return Vh(516,192,a,b)}function Yh(a,b){return Wh(516,192,a,b)}\nfunction Zh(a,b){if(\"function\"===typeof b)return a=a(),b(a),function(){b(null)};if(null!==b&&void 0!==b)return a=a(),b.current=a,function(){b.current=null}}function $h(){}function ai(a,b){Nh().memoizedState=[a,void 0===b?null:b];return a}function bi(a,b){var c=Oh();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Hh(b,d[1]))return d[0];c.memoizedState=[a,b];return a}\nfunction Sh(a,b,c){if(!(25>Gh))throw Error(u(301));var d=a.alternate;if(a===uh||null!==d&&d===uh)if(Bh=!0,a={expirationTime:th,suspenseConfig:null,action:c,eagerReducer:null,eagerState:null,next:null},null===Ch&&(Ch=new Map),c=Ch.get(b),void 0===c)Ch.set(b,a);else{for(b=c;null!==b.next;)b=b.next;b.next=a}else{var e=Pg(),f=Mg.suspense;e=Qg(e,a,f);f={expirationTime:e,suspenseConfig:f,action:c,eagerReducer:null,eagerState:null,next:null};var g=b.last;if(null===g)f.next=f;else{var h=g.next;null!==h&&\n(f.next=h);g.next=f}b.last=f;if(0===a.expirationTime&&(null===d||0===d.expirationTime)&&(d=b.lastRenderedReducer,null!==d))try{var k=b.lastRenderedState,l=d(k,c);f.eagerReducer=d;f.eagerState=l;if(of(l,k))return}catch(m){}finally{}Rg(a,e)}}\nvar Lh={readContext:xg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useResponder:Q,useDeferredValue:Q,useTransition:Q},Jh={readContext:xg,useCallback:ai,useContext:xg,useEffect:Xh,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return Vh(4,36,Zh.bind(null,b,a),c)},useLayoutEffect:function(a,b){return Vh(4,36,a,b)},useMemo:function(a,b){var c=Nh();b=void 0===b?null:b;a=a();c.memoizedState=\n[a,b];return a},useReducer:function(a,b,c){var d=Nh();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a=d.queue={last:null,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};a=a.dispatch=Sh.bind(null,uh,a);return[d.memoizedState,a]},useRef:function(a){var b=Nh();a={current:a};return b.memoizedState=a},useState:Rh,useDebugValue:$h,useResponder:rh,useDeferredValue:function(a,b){var c=Rh(a),d=c[0],e=c[1];Xh(function(){q.unstable_next(function(){var c=N.suspense;N.suspense=void 0===b?null:b;try{e(a)}finally{N.suspense=\nc}})},[a,b]);return d},useTransition:function(a){var b=Rh(!1),c=b[0],d=b[1];return[ai(function(b){d(!0);q.unstable_next(function(){var c=N.suspense;N.suspense=void 0===a?null:a;try{d(!1),b()}finally{N.suspense=c}})},[a,c]),c]}},Kh={readContext:xg,useCallback:bi,useContext:xg,useEffect:Yh,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return Wh(4,36,Zh.bind(null,b,a),c)},useLayoutEffect:function(a,b){return Wh(4,36,a,b)},useMemo:function(a,b){var c=Oh();b=void 0===b?\nnull:b;var d=c.memoizedState;if(null!==d&&null!==b&&Hh(b,d[1]))return d[0];a=a();c.memoizedState=[a,b];return a},useReducer:Qh,useRef:function(){return Oh().memoizedState},useState:Th,useDebugValue:$h,useResponder:rh,useDeferredValue:function(a,b){var c=Th(a),d=c[0],e=c[1];Yh(function(){q.unstable_next(function(){var c=N.suspense;N.suspense=void 0===b?null:b;try{e(a)}finally{N.suspense=c}})},[a,b]);return d},useTransition:function(a){var b=Th(!1),c=b[0],d=b[1];return[bi(function(b){d(!0);q.unstable_next(function(){var c=\nN.suspense;N.suspense=void 0===a?null:a;try{d(!1),b()}finally{N.suspense=c}})},[a,c]),c]}},ci=null,di=null,ei=!1;function fi(a,b){var c=gi(5,null,null,0);c.elementType=\"DELETED\";c.type=\"DELETED\";c.stateNode=b;c.return=a;c.effectTag=8;null!==a.lastEffect?(a.lastEffect.nextEffect=c,a.lastEffect=c):a.firstEffect=a.lastEffect=c}\nfunction hi(a,b){switch(a.tag){case 5:var c=a.type;b=1!==b.nodeType||c.toLowerCase()!==b.nodeName.toLowerCase()?null:b;return null!==b?(a.stateNode=b,!0):!1;case 6:return b=\"\"===a.pendingProps||3!==b.nodeType?null:b,null!==b?(a.stateNode=b,!0):!1;case 13:return!1;default:return!1}}\nfunction ii(a){if(ei){var b=di;if(b){var c=b;if(!hi(a,b)){b=re(c.nextSibling);if(!b||!hi(a,b)){a.effectTag=a.effectTag&-1025|2;ei=!1;ci=a;return}fi(ci,c)}ci=a;di=re(b.firstChild)}else a.effectTag=a.effectTag&-1025|2,ei=!1,ci=a}}function ji(a){for(a=a.return;null!==a&&5!==a.tag&&3!==a.tag&&13!==a.tag;)a=a.return;ci=a}\nfunction ki(a){if(a!==ci)return!1;if(!ei)return ji(a),ei=!0,!1;var b=a.type;if(5!==a.tag||\"head\"!==b&&\"body\"!==b&&!oe(b,a.memoizedProps))for(b=di;b;)fi(a,b),b=re(b.nextSibling);ji(a);if(13===a.tag){a=a.memoizedState;a=null!==a?a.dehydrated:null;if(!a)throw Error(u(317));a:{a=a.nextSibling;for(b=0;a;){if(8===a.nodeType){var c=a.data;if(c===ie){if(0===b){di=re(a.nextSibling);break a}b--}else c!==he&&c!==ke&&c!==je||b++}a=a.nextSibling}di=null}}else di=ci?re(a.stateNode.nextSibling):null;return!0}\nfunction li(){di=ci=null;ei=!1}var mi=Ea.ReactCurrentOwner,wg=!1;function R(a,b,c,d){b.child=null===a?gh(b,null,c,d):fh(b,a.child,c,d)}function ni(a,b,c,d,e){c=c.render;var f=b.ref;vg(b,e);d=Ih(a,b,c,d,f,e);if(null!==a&&!wg)return b.updateQueue=a.updateQueue,b.effectTag&=-517,a.expirationTime<=e&&(a.expirationTime=0),oi(a,b,e);b.effectTag|=1;R(a,b,d,e);return b.child}\nfunction pi(a,b,c,d,e,f){if(null===a){var g=c.type;if(\"function\"===typeof g&&!qi(g)&&void 0===g.defaultProps&&null===c.compare&&void 0===c.defaultProps)return b.tag=15,b.type=g,ri(a,b,g,d,e,f);a=ch(c.type,null,d,null,b.mode,f);a.ref=b.ref;a.return=b;return b.child=a}g=a.child;if(e<f&&(e=g.memoizedProps,c=c.compare,c=null!==c?c:qf,c(e,d)&&a.ref===b.ref))return oi(a,b,f);b.effectTag|=1;a=ah(g,d,f);a.ref=b.ref;a.return=b;return b.child=a}\nfunction ri(a,b,c,d,e,f){return null!==a&&qf(a.memoizedProps,d)&&a.ref===b.ref&&(wg=!1,e<f)?oi(a,b,f):si(a,b,c,d,f)}function ti(a,b){var c=b.ref;if(null===a&&null!==c||null!==a&&a.ref!==c)b.effectTag|=128}function si(a,b,c,d,e){var f=L(c)?Df:J.current;f=Ef(b,f);vg(b,e);c=Ih(a,b,c,d,f,e);if(null!==a&&!wg)return b.updateQueue=a.updateQueue,b.effectTag&=-517,a.expirationTime<=e&&(a.expirationTime=0),oi(a,b,e);b.effectTag|=1;R(a,b,c,e);return b.child}\nfunction ui(a,b,c,d,e){if(L(c)){var f=!0;Jf(b)}else f=!1;vg(b,e);if(null===b.stateNode)null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2),Ug(b,c,d,e),Wg(b,c,d,e),d=!0;else if(null===a){var g=b.stateNode,h=b.memoizedProps;g.props=h;var k=g.context,l=c.contextType;\"object\"===typeof l&&null!==l?l=xg(l):(l=L(c)?Df:J.current,l=Ef(b,l));var m=c.getDerivedStateFromProps,C=\"function\"===typeof m||\"function\"===typeof g.getSnapshotBeforeUpdate;C||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\n\"function\"!==typeof g.componentWillReceiveProps||(h!==d||k!==l)&&Vg(b,g,d,l);yg=!1;var y=b.memoizedState;k=g.state=y;var H=b.updateQueue;null!==H&&(Hg(b,H,d,g,e),k=b.memoizedState);h!==d||y!==k||K.current||yg?(\"function\"===typeof m&&(Og(b,c,m,d),k=b.memoizedState),(h=yg||Tg(b,c,h,d,y,k,l))?(C||\"function\"!==typeof g.UNSAFE_componentWillMount&&\"function\"!==typeof g.componentWillMount||(\"function\"===typeof g.componentWillMount&&g.componentWillMount(),\"function\"===typeof g.UNSAFE_componentWillMount&&\ng.UNSAFE_componentWillMount()),\"function\"===typeof g.componentDidMount&&(b.effectTag|=4)):(\"function\"===typeof g.componentDidMount&&(b.effectTag|=4),b.memoizedProps=d,b.memoizedState=k),g.props=d,g.state=k,g.context=l,d=h):(\"function\"===typeof g.componentDidMount&&(b.effectTag|=4),d=!1)}else g=b.stateNode,h=b.memoizedProps,g.props=b.type===b.elementType?h:mg(b.type,h),k=g.context,l=c.contextType,\"object\"===typeof l&&null!==l?l=xg(l):(l=L(c)?Df:J.current,l=Ef(b,l)),m=c.getDerivedStateFromProps,(C=\n\"function\"===typeof m||\"function\"===typeof g.getSnapshotBeforeUpdate)||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\"function\"!==typeof g.componentWillReceiveProps||(h!==d||k!==l)&&Vg(b,g,d,l),yg=!1,k=b.memoizedState,y=g.state=k,H=b.updateQueue,null!==H&&(Hg(b,H,d,g,e),y=b.memoizedState),h!==d||k!==y||K.current||yg?(\"function\"===typeof m&&(Og(b,c,m,d),y=b.memoizedState),(m=yg||Tg(b,c,h,d,k,y,l))?(C||\"function\"!==typeof g.UNSAFE_componentWillUpdate&&\"function\"!==typeof g.componentWillUpdate||\n(\"function\"===typeof g.componentWillUpdate&&g.componentWillUpdate(d,y,l),\"function\"===typeof g.UNSAFE_componentWillUpdate&&g.UNSAFE_componentWillUpdate(d,y,l)),\"function\"===typeof g.componentDidUpdate&&(b.effectTag|=4),\"function\"===typeof g.getSnapshotBeforeUpdate&&(b.effectTag|=256)):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=256),b.memoizedProps=\nd,b.memoizedState=y),g.props=d,g.state=y,g.context=l,d=m):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=256),d=!1);return vi(a,b,c,d,f,e)}\nfunction vi(a,b,c,d,e,f){ti(a,b);var g=0!==(b.effectTag&64);if(!d&&!g)return e&&Kf(b,c,!1),oi(a,b,f);d=b.stateNode;mi.current=b;var h=g&&\"function\"!==typeof c.getDerivedStateFromError?null:d.render();b.effectTag|=1;null!==a&&g?(b.child=fh(b,a.child,null,f),b.child=fh(b,null,h,f)):R(a,b,h,f);b.memoizedState=d.state;e&&Kf(b,c,!0);return b.child}function wi(a){var b=a.stateNode;b.pendingContext?Hf(a,b.pendingContext,b.pendingContext!==b.context):b.context&&Hf(a,b.context,!1);mh(a,b.containerInfo)}\nvar xi={dehydrated:null,retryTime:0};\nfunction yi(a,b,c){var d=b.mode,e=b.pendingProps,f=M.current,g=!1,h;(h=0!==(b.effectTag&64))||(h=0!==(f&2)&&(null===a||null!==a.memoizedState));h?(g=!0,b.effectTag&=-65):null!==a&&null===a.memoizedState||void 0===e.fallback||!0===e.unstable_avoidThisFallback||(f|=1);I(M,f&1,b);if(null===a){void 0!==e.fallback&&ii(b);if(g){g=e.fallback;e=eh(null,d,0,null);e.return=b;if(0===(b.mode&2))for(a=null!==b.memoizedState?b.child.child:b.child,e.child=a;null!==a;)a.return=e,a=a.sibling;c=eh(g,d,c,null);c.return=\nb;e.sibling=c;b.memoizedState=xi;b.child=e;return c}d=e.children;b.memoizedState=null;return b.child=gh(b,null,d,c)}if(null!==a.memoizedState){a=a.child;d=a.sibling;if(g){e=e.fallback;c=ah(a,a.pendingProps,0);c.return=b;if(0===(b.mode&2)&&(g=null!==b.memoizedState?b.child.child:b.child,g!==a.child))for(c.child=g;null!==g;)g.return=c,g=g.sibling;d=ah(d,e,d.expirationTime);d.return=b;c.sibling=d;c.childExpirationTime=0;b.memoizedState=xi;b.child=c;return d}c=fh(b,a.child,e.children,c);b.memoizedState=\nnull;return b.child=c}a=a.child;if(g){g=e.fallback;e=eh(null,d,0,null);e.return=b;e.child=a;null!==a&&(a.return=e);if(0===(b.mode&2))for(a=null!==b.memoizedState?b.child.child:b.child,e.child=a;null!==a;)a.return=e,a=a.sibling;c=eh(g,d,c,null);c.return=b;e.sibling=c;c.effectTag|=2;e.childExpirationTime=0;b.memoizedState=xi;b.child=e;return c}b.memoizedState=null;return b.child=fh(b,a,e.children,c)}\nfunction zi(a,b){a.expirationTime<b&&(a.expirationTime=b);var c=a.alternate;null!==c&&c.expirationTime<b&&(c.expirationTime=b);ug(a.return,b)}function Ai(a,b,c,d,e,f){var g=a.memoizedState;null===g?a.memoizedState={isBackwards:b,rendering:null,last:d,tail:c,tailExpiration:0,tailMode:e,lastEffect:f}:(g.isBackwards=b,g.rendering=null,g.last=d,g.tail=c,g.tailExpiration=0,g.tailMode=e,g.lastEffect=f)}\nfunction Bi(a,b,c){var d=b.pendingProps,e=d.revealOrder,f=d.tail;R(a,b,d.children,c);d=M.current;if(0!==(d&2))d=d&1|2,b.effectTag|=64;else{if(null!==a&&0!==(a.effectTag&64))a:for(a=b.child;null!==a;){if(13===a.tag)null!==a.memoizedState&&zi(a,c);else if(19===a.tag)zi(a,c);else if(null!==a.child){a.child.return=a;a=a.child;continue}if(a===b)break a;for(;null===a.sibling;){if(null===a.return||a.return===b)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}d&=1}I(M,d,b);if(0===(b.mode&2))b.memoizedState=\nnull;else switch(e){case \"forwards\":c=b.child;for(e=null;null!==c;)a=c.alternate,null!==a&&null===qh(a)&&(e=c),c=c.sibling;c=e;null===c?(e=b.child,b.child=null):(e=c.sibling,c.sibling=null);Ai(b,!1,e,c,f,b.lastEffect);break;case \"backwards\":c=null;e=b.child;for(b.child=null;null!==e;){a=e.alternate;if(null!==a&&null===qh(a)){b.child=e;break}a=e.sibling;e.sibling=c;c=e;e=a}Ai(b,!0,c,null,f,b.lastEffect);break;case \"together\":Ai(b,!1,null,null,void 0,b.lastEffect);break;default:b.memoizedState=null}return b.child}\nfunction oi(a,b,c){null!==a&&(b.dependencies=a.dependencies);var d=b.expirationTime;0!==d&&Jg(d);if(b.childExpirationTime<c)return null;if(null!==a&&b.child!==a.child)throw Error(u(153));if(null!==b.child){a=b.child;c=ah(a,a.pendingProps,a.expirationTime);b.child=c;for(c.return=b;null!==a.sibling;)a=a.sibling,c=c.sibling=ah(a,a.pendingProps,a.expirationTime),c.return=b;c.sibling=null}return b.child}function Ci(a){a.effectTag|=4}var Hi,Ii,Ji,Ki;\nHi=function(a,b){for(var c=b.child;null!==c;){if(5===c.tag||6===c.tag)a.appendChild(c.stateNode);else if(4!==c.tag&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return}c.sibling.return=c.return;c=c.sibling}};Ii=function(){};\nJi=function(a,b,c,d,e){var f=a.memoizedProps;if(f!==d){var g=b.stateNode;lh(ih.current);a=null;switch(c){case \"input\":f=Ab(g,f);d=Ab(g,d);a=[];break;case \"option\":f=Ib(g,f);d=Ib(g,d);a=[];break;case \"select\":f=n({},f,{value:void 0});d=n({},d,{value:void 0});a=[];break;case \"textarea\":f=Kb(g,f);d=Kb(g,d);a=[];break;default:\"function\"!==typeof f.onClick&&\"function\"===typeof d.onClick&&(g.onclick=ae)}Yd(c,d);var h,k;c=null;for(h in f)if(!d.hasOwnProperty(h)&&f.hasOwnProperty(h)&&null!=f[h])if(\"style\"===\nh)for(k in g=f[h],g)g.hasOwnProperty(k)&&(c||(c={}),c[k]=\"\");else\"dangerouslySetInnerHTML\"!==h&&\"children\"!==h&&\"suppressContentEditableWarning\"!==h&&\"suppressHydrationWarning\"!==h&&\"autoFocus\"!==h&&(ia.hasOwnProperty(h)?a||(a=[]):(a=a||[]).push(h,null));for(h in d){var l=d[h];g=null!=f?f[h]:void 0;if(d.hasOwnProperty(h)&&l!==g&&(null!=l||null!=g))if(\"style\"===h)if(g){for(k in g)!g.hasOwnProperty(k)||l&&l.hasOwnProperty(k)||(c||(c={}),c[k]=\"\");for(k in l)l.hasOwnProperty(k)&&g[k]!==l[k]&&(c||(c={}),\nc[k]=l[k])}else c||(a||(a=[]),a.push(h,c)),c=l;else\"dangerouslySetInnerHTML\"===h?(l=l?l.__html:void 0,g=g?g.__html:void 0,null!=l&&g!==l&&(a=a||[]).push(h,\"\"+l)):\"children\"===h?g===l||\"string\"!==typeof l&&\"number\"!==typeof l||(a=a||[]).push(h,\"\"+l):\"suppressContentEditableWarning\"!==h&&\"suppressHydrationWarning\"!==h&&(ia.hasOwnProperty(h)?(null!=l&&$d(e,h),a||g===l||(a=[])):(a=a||[]).push(h,l))}c&&(a=a||[]).push(\"style\",c);e=a;(b.updateQueue=e)&&Ci(b)}};Ki=function(a,b,c,d){c!==d&&Ci(b)};\nfunction Li(a,b){switch(a.tailMode){case \"hidden\":b=a.tail;for(var c=null;null!==b;)null!==b.alternate&&(c=b),b=b.sibling;null===c?a.tail=null:c.sibling=null;break;case \"collapsed\":c=a.tail;for(var d=null;null!==c;)null!==c.alternate&&(d=c),c=c.sibling;null===d?b||null===a.tail?a.tail=null:a.tail.sibling=null:d.sibling=null}}\nfunction Mi(a){switch(a.tag){case 1:L(a.type)&&Ff(a);var b=a.effectTag;return b&4096?(a.effectTag=b&-4097|64,a):null;case 3:nh(a);Gf(a);b=a.effectTag;if(0!==(b&64))throw Error(u(285));a.effectTag=b&-4097|64;return a;case 5:return ph(a),null;case 13:return G(M,a),b=a.effectTag,b&4096?(a.effectTag=b&-4097|64,a):null;case 19:return G(M,a),null;case 4:return nh(a),null;case 10:return tg(a),null;default:return null}}function Ni(a,b){return{value:a,source:b,stack:Xa(b)}}\nvar Oi=\"function\"===typeof WeakSet?WeakSet:Set;function Pi(a,b){var c=b.source,d=b.stack;null===d&&null!==c&&(d=Xa(c));null!==c&&Wa(c.type);b=b.value;null!==a&&1===a.tag&&Wa(a.type);try{console.error(b)}catch(e){setTimeout(function(){throw e;})}}function Qi(a,b){try{b.props=a.memoizedProps,b.state=a.memoizedState,b.componentWillUnmount()}catch(c){Ri(a,c)}}function Si(a){var b=a.ref;if(null!==b)if(\"function\"===typeof b)try{b(null)}catch(c){Ri(a,c)}else b.current=null}\nfunction Ti(a,b){switch(b.tag){case 0:case 11:case 15:Ui(2,0,b);break;case 1:if(b.effectTag&256&&null!==a){var c=a.memoizedProps,d=a.memoizedState;a=b.stateNode;b=a.getSnapshotBeforeUpdate(b.elementType===b.type?c:mg(b.type,c),d);a.__reactInternalSnapshotBeforeUpdate=b}break;case 3:case 5:case 6:case 4:case 17:break;default:throw Error(u(163));}}\nfunction Ui(a,b,c){c=c.updateQueue;c=null!==c?c.lastEffect:null;if(null!==c){var d=c=c.next;do{if(0!==(d.tag&a)){var e=d.destroy;d.destroy=void 0;void 0!==e&&e()}0!==(d.tag&b)&&(e=d.create,d.destroy=e());d=d.next}while(d!==c)}}\nfunction Vi(a,b,c){\"function\"===typeof Wi&&Wi(b);switch(b.tag){case 0:case 11:case 14:case 15:a=b.updateQueue;if(null!==a&&(a=a.lastEffect,null!==a)){var d=a.next;fg(97<c?97:c,function(){var a=d;do{var c=a.destroy;if(void 0!==c){var g=b;try{c()}catch(h){Ri(g,h)}}a=a.next}while(a!==d)})}break;case 1:Si(b);c=b.stateNode;\"function\"===typeof c.componentWillUnmount&&Qi(b,c);break;case 5:Si(b);break;case 4:Xi(a,b,c)}}\nfunction Yi(a){var b=a.alternate;a.return=null;a.child=null;a.memoizedState=null;a.updateQueue=null;a.dependencies=null;a.alternate=null;a.firstEffect=null;a.lastEffect=null;a.pendingProps=null;a.memoizedProps=null;null!==b&&Yi(b)}function Zi(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction $i(a){a:{for(var b=a.return;null!==b;){if(Zi(b)){var c=b;break a}b=b.return}throw Error(u(160));}b=c.stateNode;switch(c.tag){case 5:var d=!1;break;case 3:b=b.containerInfo;d=!0;break;case 4:b=b.containerInfo;d=!0;break;default:throw Error(u(161));}c.effectTag&16&&(Tb(b,\"\"),c.effectTag&=-17);a:b:for(c=a;;){for(;null===c.sibling;){if(null===c.return||Zi(c.return)){c=null;break a}c=c.return}c.sibling.return=c.return;for(c=c.sibling;5!==c.tag&&6!==c.tag&&18!==c.tag;){if(c.effectTag&2)continue b;\nif(null===c.child||4===c.tag)continue b;else c.child.return=c,c=c.child}if(!(c.effectTag&2)){c=c.stateNode;break a}}for(var e=a;;){var f=5===e.tag||6===e.tag;if(f){var g=f?e.stateNode:e.stateNode.instance;if(c)if(d){f=b;var h=g;g=c;8===f.nodeType?f.parentNode.insertBefore(h,g):f.insertBefore(h,g)}else b.insertBefore(g,c);else d?(h=b,8===h.nodeType?(f=h.parentNode,f.insertBefore(g,h)):(f=h,f.appendChild(g)),h=h._reactRootContainer,null!==h&&void 0!==h||null!==f.onclick||(f.onclick=ae)):b.appendChild(g)}else if(4!==\ne.tag&&null!==e.child){e.child.return=e;e=e.child;continue}if(e===a)break;for(;null===e.sibling;){if(null===e.return||e.return===a)return;e=e.return}e.sibling.return=e.return;e=e.sibling}}\nfunction Xi(a,b,c){for(var d=b,e=!1,f,g;;){if(!e){e=d.return;a:for(;;){if(null===e)throw Error(u(160));f=e.stateNode;switch(e.tag){case 5:g=!1;break a;case 3:f=f.containerInfo;g=!0;break a;case 4:f=f.containerInfo;g=!0;break a}e=e.return}e=!0}if(5===d.tag||6===d.tag){a:for(var h=a,k=d,l=c,m=k;;)if(Vi(h,m,l),null!==m.child&&4!==m.tag)m.child.return=m,m=m.child;else{if(m===k)break;for(;null===m.sibling;){if(null===m.return||m.return===k)break a;m=m.return}m.sibling.return=m.return;m=m.sibling}g?(h=\nf,k=d.stateNode,8===h.nodeType?h.parentNode.removeChild(k):h.removeChild(k)):f.removeChild(d.stateNode)}else if(4===d.tag){if(null!==d.child){f=d.stateNode.containerInfo;g=!0;d.child.return=d;d=d.child;continue}}else if(Vi(a,d,c),null!==d.child){d.child.return=d;d=d.child;continue}if(d===b)break;for(;null===d.sibling;){if(null===d.return||d.return===b)return;d=d.return;4===d.tag&&(e=!1)}d.sibling.return=d.return;d=d.sibling}}\nfunction aj(a,b){switch(b.tag){case 0:case 11:case 14:case 15:Ui(4,8,b);break;case 1:break;case 5:var c=b.stateNode;if(null!=c){var d=b.memoizedProps,e=null!==a?a.memoizedProps:d;a=b.type;var f=b.updateQueue;b.updateQueue=null;if(null!==f){c[ve]=d;\"input\"===a&&\"radio\"===d.type&&null!=d.name&&Cb(c,d);Zd(a,e);b=Zd(a,d);for(e=0;e<f.length;e+=2){var g=f[e],h=f[e+1];\"style\"===g?Wd(c,h):\"dangerouslySetInnerHTML\"===g?Sb(c,h):\"children\"===g?Tb(c,h):vb(c,g,h,b)}switch(a){case \"input\":Eb(c,d);break;case \"textarea\":Mb(c,\nd);break;case \"select\":b=c._wrapperState.wasMultiple,c._wrapperState.wasMultiple=!!d.multiple,a=d.value,null!=a?Jb(c,!!d.multiple,a,!1):b!==!!d.multiple&&(null!=d.defaultValue?Jb(c,!!d.multiple,d.defaultValue,!0):Jb(c,!!d.multiple,d.multiple?[]:\"\",!1))}}}break;case 6:if(null===b.stateNode)throw Error(u(162));b.stateNode.nodeValue=b.memoizedProps;break;case 3:b=b.stateNode;b.hydrate&&(b.hydrate=!1,Lc(b.containerInfo));break;case 12:break;case 13:c=b;null===b.memoizedState?d=!1:(d=!0,c=b.child,bj=cg());\nif(null!==c)a:for(a=c;;){if(5===a.tag)f=a.stateNode,d?(f=f.style,\"function\"===typeof f.setProperty?f.setProperty(\"display\",\"none\",\"important\"):f.display=\"none\"):(f=a.stateNode,e=a.memoizedProps.style,e=void 0!==e&&null!==e&&e.hasOwnProperty(\"display\")?e.display:null,f.style.display=Vd(\"display\",e));else if(6===a.tag)a.stateNode.nodeValue=d?\"\":a.memoizedProps;else if(13===a.tag&&null!==a.memoizedState&&null===a.memoizedState.dehydrated){f=a.child.sibling;f.return=a;a=f;continue}else if(null!==a.child){a.child.return=\na;a=a.child;continue}if(a===c)break a;for(;null===a.sibling;){if(null===a.return||a.return===c)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}cj(b);break;case 19:cj(b);break;case 17:break;case 20:break;case 21:break;default:throw Error(u(163));}}function cj(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Oi);b.forEach(function(b){var d=dj.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}var ej=\"function\"===typeof WeakMap?WeakMap:Map;\nfunction fj(a,b,c){c=Bg(c,null);c.tag=3;c.payload={element:null};var d=b.value;c.callback=function(){gj||(gj=!0,hj=d);Pi(a,b)};return c}\nfunction ij(a,b,c){c=Bg(c,null);c.tag=3;var d=a.type.getDerivedStateFromError;if(\"function\"===typeof d){var e=b.value;c.payload=function(){Pi(a,b);return d(e)}}var f=a.stateNode;null!==f&&\"function\"===typeof f.componentDidCatch&&(c.callback=function(){\"function\"!==typeof d&&(null===jj?jj=new Set([this]):jj.add(this),Pi(a,b));var c=b.stack;this.componentDidCatch(b.value,{componentStack:null!==c?c:\"\"})});return c}\nvar kj=Math.ceil,lj=Ea.ReactCurrentDispatcher,mj=Ea.ReactCurrentOwner,S=0,nj=8,oj=16,pj=32,qj=0,rj=1,sj=2,tj=3,uj=4,vj=5,T=S,U=null,V=null,W=0,X=qj,wj=null,xj=1073741823,yj=1073741823,zj=null,Aj=0,Bj=!1,bj=0,Cj=500,Y=null,gj=!1,hj=null,jj=null,Dj=!1,Ej=null,Fj=90,Gj=null,Hj=0,Ij=null,Jj=0;function Pg(){return(T&(oj|pj))!==S?1073741821-(cg()/10|0):0!==Jj?Jj:Jj=1073741821-(cg()/10|0)}\nfunction Qg(a,b,c){b=b.mode;if(0===(b&2))return 1073741823;var d=dg();if(0===(b&4))return 99===d?1073741823:1073741822;if((T&oj)!==S)return W;if(null!==c)a=lg(a,c.timeoutMs|0||5E3,250);else switch(d){case 99:a=1073741823;break;case 98:a=lg(a,150,100);break;case 97:case 96:a=lg(a,5E3,250);break;case 95:a=2;break;default:throw Error(u(326));}null!==U&&a===W&&--a;return a}\nfunction Rg(a,b){if(50<Hj)throw Hj=0,Ij=null,Error(u(185));a=Kj(a,b);if(null!==a){var c=dg();1073741823===b?(T&nj)!==S&&(T&(oj|pj))===S?Lj(a):(Z(a),T===S&&jg()):Z(a);(T&4)===S||98!==c&&99!==c||(null===Gj?Gj=new Map([[a,b]]):(c=Gj.get(a),(void 0===c||c>b)&&Gj.set(a,b)))}}\nfunction Kj(a,b){a.expirationTime<b&&(a.expirationTime=b);var c=a.alternate;null!==c&&c.expirationTime<b&&(c.expirationTime=b);var d=a.return,e=null;if(null===d&&3===a.tag)e=a.stateNode;else for(;null!==d;){c=d.alternate;d.childExpirationTime<b&&(d.childExpirationTime=b);null!==c&&c.childExpirationTime<b&&(c.childExpirationTime=b);if(null===d.return&&3===d.tag){e=d.stateNode;break}d=d.return}null!==e&&(U===e&&(Jg(b),X===uj&&Mj(e,W)),Nj(e,b));return e}\nfunction Oj(a){var b=a.lastExpiredTime;if(0!==b)return b;b=a.firstPendingTime;if(!Pj(a,b))return b;b=a.lastPingedTime;a=a.nextKnownPendingLevel;return b>a?b:a}\nfunction Z(a){if(0!==a.lastExpiredTime)a.callbackExpirationTime=1073741823,a.callbackPriority=99,a.callbackNode=hg(Lj.bind(null,a));else{var b=Oj(a),c=a.callbackNode;if(0===b)null!==c&&(a.callbackNode=null,a.callbackExpirationTime=0,a.callbackPriority=90);else{var d=Pg();1073741823===b?d=99:1===b||2===b?d=95:(d=10*(1073741821-b)-10*(1073741821-d),d=0>=d?99:250>=d?98:5250>=d?97:95);if(null!==c){var e=a.callbackPriority;if(a.callbackExpirationTime===b&&e>=d)return;c!==Xf&&Nf(c)}a.callbackExpirationTime=\nb;a.callbackPriority=d;b=1073741823===b?hg(Lj.bind(null,a)):gg(d,Qj.bind(null,a),{timeout:10*(1073741821-b)-cg()});a.callbackNode=b}}}\nfunction Qj(a,b){Jj=0;if(b)return b=Pg(),Rj(a,b),Z(a),null;var c=Oj(a);if(0!==c){b=a.callbackNode;if((T&(oj|pj))!==S)throw Error(u(327));Sj();a===U&&c===W||Tj(a,c);if(null!==V){var d=T;T|=oj;var e=Uj(a);do try{Vj();break}catch(h){Wj(a,h)}while(1);rg();T=d;lj.current=e;if(X===rj)throw b=wj,Tj(a,c),Mj(a,c),Z(a),b;if(null===V)switch(e=a.finishedWork=a.current.alternate,a.finishedExpirationTime=c,d=X,U=null,d){case qj:case rj:throw Error(u(345));case sj:Rj(a,2<c?2:c);break;case tj:Mj(a,c);d=a.lastSuspendedTime;\nc===d&&(a.nextKnownPendingLevel=Xj(e));if(1073741823===xj&&(e=bj+Cj-cg(),10<e)){if(Bj){var f=a.lastPingedTime;if(0===f||f>=c){a.lastPingedTime=c;Tj(a,c);break}}f=Oj(a);if(0!==f&&f!==c)break;if(0!==d&&d!==c){a.lastPingedTime=d;break}a.timeoutHandle=pe(Yj.bind(null,a),e);break}Yj(a);break;case uj:Mj(a,c);d=a.lastSuspendedTime;c===d&&(a.nextKnownPendingLevel=Xj(e));if(Bj&&(e=a.lastPingedTime,0===e||e>=c)){a.lastPingedTime=c;Tj(a,c);break}e=Oj(a);if(0!==e&&e!==c)break;if(0!==d&&d!==c){a.lastPingedTime=\nd;break}1073741823!==yj?d=10*(1073741821-yj)-cg():1073741823===xj?d=0:(d=10*(1073741821-xj)-5E3,e=cg(),c=10*(1073741821-c)-e,d=e-d,0>d&&(d=0),d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*kj(d/1960))-d,c<d&&(d=c));if(10<d){a.timeoutHandle=pe(Yj.bind(null,a),d);break}Yj(a);break;case vj:if(1073741823!==xj&&null!==zj){f=xj;var g=zj;d=g.busyMinDurationMs|0;0>=d?d=0:(e=g.busyDelayMs|0,f=cg()-(10*(1073741821-f)-(g.timeoutMs|0||5E3)),d=f<=e?0:e+d-f);if(10<d){Mj(a,c);a.timeoutHandle=\npe(Yj.bind(null,a),d);break}}Yj(a);break;default:throw Error(u(329));}Z(a);if(a.callbackNode===b)return Qj.bind(null,a)}}return null}\nfunction Lj(a){var b=a.lastExpiredTime;b=0!==b?b:1073741823;if(a.finishedExpirationTime===b)Yj(a);else{if((T&(oj|pj))!==S)throw Error(u(327));Sj();a===U&&b===W||Tj(a,b);if(null!==V){var c=T;T|=oj;var d=Uj(a);do try{Zj();break}catch(e){Wj(a,e)}while(1);rg();T=c;lj.current=d;if(X===rj)throw c=wj,Tj(a,b),Mj(a,b),Z(a),c;if(null!==V)throw Error(u(261));a.finishedWork=a.current.alternate;a.finishedExpirationTime=b;U=null;Yj(a);Z(a)}}return null}\nfunction ak(){if(null!==Gj){var a=Gj;Gj=null;a.forEach(function(a,c){Rj(c,a);Z(c)});jg()}}function bk(a,b){var c=T;T|=1;try{return a(b)}finally{T=c,T===S&&jg()}}function ck(a,b){var c=T;T&=-2;T|=nj;try{return a(b)}finally{T=c,T===S&&jg()}}\nfunction Tj(a,b){a.finishedWork=null;a.finishedExpirationTime=0;var c=a.timeoutHandle;-1!==c&&(a.timeoutHandle=-1,qe(c));if(null!==V)for(c=V.return;null!==c;){var d=c;switch(d.tag){case 1:var e=d.type.childContextTypes;null!==e&&void 0!==e&&Ff(d);break;case 3:nh(d);Gf(d);break;case 5:ph(d);break;case 4:nh(d);break;case 13:G(M,d);break;case 19:G(M,d);break;case 10:tg(d)}c=c.return}U=a;V=ah(a.current,null,b);W=b;X=qj;wj=null;yj=xj=1073741823;zj=null;Aj=0;Bj=!1}\nfunction Wj(a,b){do{try{rg();Mh();if(null===V||null===V.return)return X=rj,wj=b,null;a:{var c=a,d=V.return,e=V,f=b;b=W;e.effectTag|=2048;e.firstEffect=e.lastEffect=null;if(null!==f&&\"object\"===typeof f&&\"function\"===typeof f.then){var g=f,h=0!==(M.current&1),k=d;do{var l;if(l=13===k.tag){var m=k.memoizedState;if(null!==m)l=null!==m.dehydrated?!0:!1;else{var C=k.memoizedProps;l=void 0===C.fallback?!1:!0!==C.unstable_avoidThisFallback?!0:h?!1:!0}}if(l){var y=k.updateQueue;if(null===y){var H=new Set;\nH.add(g);k.updateQueue=H}else y.add(g);if(0===(k.mode&2)){k.effectTag|=64;e.effectTag&=-2981;if(1===e.tag)if(null===e.alternate)e.tag=17;else{var z=Bg(1073741823,null);z.tag=2;Dg(e,z)}e.expirationTime=1073741823;break a}f=void 0;e=b;var ta=c.pingCache;null===ta?(ta=c.pingCache=new ej,f=new Set,ta.set(g,f)):(f=ta.get(g),void 0===f&&(f=new Set,ta.set(g,f)));if(!f.has(e)){f.add(e);var r=dk.bind(null,c,g,e);g.then(r,r)}k.effectTag|=4096;k.expirationTime=b;break a}k=k.return}while(null!==k);f=Error((Wa(e.type)||\n\"A React component\")+\" suspended while rendering, but no fallback UI was specified.\\n\\nAdd a <Suspense fallback=...> component higher in the tree to provide a loading indicator or placeholder to display.\"+Xa(e))}X!==vj&&(X=sj);f=Ni(f,e);k=d;do{switch(k.tag){case 3:g=f;k.effectTag|=4096;k.expirationTime=b;var x=fj(k,g,b);Eg(k,x);break a;case 1:g=f;var A=k.type,p=k.stateNode;if(0===(k.effectTag&64)&&(\"function\"===typeof A.getDerivedStateFromError||null!==p&&\"function\"===typeof p.componentDidCatch&&\n(null===jj||!jj.has(p)))){k.effectTag|=4096;k.expirationTime=b;var t=ij(k,g,b);Eg(k,t);break a}}k=k.return}while(null!==k)}V=ek(V)}catch(v){b=v;continue}break}while(1)}function Uj(){var a=lj.current;lj.current=Lh;return null===a?Lh:a}function Ig(a,b){a<xj&&2<a&&(xj=a);null!==b&&a<yj&&2<a&&(yj=a,zj=b)}function Jg(a){a>Aj&&(Aj=a)}function Zj(){for(;null!==V;)V=fk(V)}function Vj(){for(;null!==V&&!Of();)V=fk(V)}\nfunction fk(a){var b=gk(a.alternate,a,W);a.memoizedProps=a.pendingProps;null===b&&(b=ek(a));mj.current=null;return b}\nfunction ek(a){V=a;do{var b=V.alternate;a=V.return;if(0===(V.effectTag&2048)){a:{var c=b;b=V;var d=W;var e=b.pendingProps;switch(b.tag){case 2:break;case 16:break;case 15:case 0:break;case 1:L(b.type)&&Ff(b);break;case 3:nh(b);Gf(b);e=b.stateNode;e.pendingContext&&(e.context=e.pendingContext,e.pendingContext=null);(null===c||null===c.child)&&ki(b)&&Ci(b);Ii(b);break;case 5:ph(b);d=lh(kh.current);var f=b.type;if(null!==c&&null!=b.stateNode)Ji(c,b,f,e,d),c.ref!==b.ref&&(b.effectTag|=128);else if(e){var g=\nlh(ih.current);if(ki(b)){e=b;var h=e.stateNode;c=e.type;var k=e.memoizedProps,l=d;h[ue]=e;h[ve]=k;f=void 0;d=h;switch(c){case \"iframe\":case \"object\":case \"embed\":F(\"load\",d);break;case \"video\":case \"audio\":for(h=0;h<cc.length;h++)F(cc[h],d);break;case \"source\":F(\"error\",d);break;case \"img\":case \"image\":case \"link\":F(\"error\",d);F(\"load\",d);break;case \"form\":F(\"reset\",d);F(\"submit\",d);break;case \"details\":F(\"toggle\",d);break;case \"input\":Bb(d,k);F(\"invalid\",d);$d(l,\"onChange\");break;case \"select\":d._wrapperState=\n{wasMultiple:!!k.multiple};F(\"invalid\",d);$d(l,\"onChange\");break;case \"textarea\":Lb(d,k),F(\"invalid\",d),$d(l,\"onChange\")}Yd(c,k);h=null;for(f in k)k.hasOwnProperty(f)&&(g=k[f],\"children\"===f?\"string\"===typeof g?d.textContent!==g&&(h=[\"children\",g]):\"number\"===typeof g&&d.textContent!==\"\"+g&&(h=[\"children\",\"\"+g]):ia.hasOwnProperty(f)&&null!=g&&$d(l,f));switch(c){case \"input\":yb(d);Gb(d,k,!0);break;case \"textarea\":yb(d);Nb(d,k);break;case \"select\":case \"option\":break;default:\"function\"===typeof k.onClick&&\n(d.onclick=ae)}f=h;e.updateQueue=f;e=null!==f?!0:!1;e&&Ci(b)}else{c=b;l=f;k=e;h=9===d.nodeType?d:d.ownerDocument;g===Ob.html&&(g=Pb(l));g===Ob.html?\"script\"===l?(k=h.createElement(\"div\"),k.innerHTML=\"<script>\\x3c/script>\",h=k.removeChild(k.firstChild)):\"string\"===typeof k.is?h=h.createElement(l,{is:k.is}):(h=h.createElement(l),\"select\"===l&&(l=h,k.multiple?l.multiple=!0:k.size&&(l.size=k.size))):h=h.createElementNS(g,l);k=h;k[ue]=c;k[ve]=e;Hi(k,b,!1,!1);b.stateNode=k;l=f;c=e;var m=d,C=Zd(l,c);switch(l){case \"iframe\":case \"object\":case \"embed\":F(\"load\",\nk);d=c;break;case \"video\":case \"audio\":for(d=0;d<cc.length;d++)F(cc[d],k);d=c;break;case \"source\":F(\"error\",k);d=c;break;case \"img\":case \"image\":case \"link\":F(\"error\",k);F(\"load\",k);d=c;break;case \"form\":F(\"reset\",k);F(\"submit\",k);d=c;break;case \"details\":F(\"toggle\",k);d=c;break;case \"input\":Bb(k,c);d=Ab(k,c);F(\"invalid\",k);$d(m,\"onChange\");break;case \"option\":d=Ib(k,c);break;case \"select\":k._wrapperState={wasMultiple:!!c.multiple};d=n({},c,{value:void 0});F(\"invalid\",k);$d(m,\"onChange\");break;case \"textarea\":Lb(k,\nc);d=Kb(k,c);F(\"invalid\",k);$d(m,\"onChange\");break;default:d=c}Yd(l,d);h=void 0;g=l;var y=k,H=d;for(h in H)if(H.hasOwnProperty(h)){var z=H[h];\"style\"===h?Wd(y,z):\"dangerouslySetInnerHTML\"===h?(z=z?z.__html:void 0,null!=z&&Sb(y,z)):\"children\"===h?\"string\"===typeof z?(\"textarea\"!==g||\"\"!==z)&&Tb(y,z):\"number\"===typeof z&&Tb(y,\"\"+z):\"suppressContentEditableWarning\"!==h&&\"suppressHydrationWarning\"!==h&&\"autoFocus\"!==h&&(ia.hasOwnProperty(h)?null!=z&&$d(m,h):null!=z&&vb(y,h,z,C))}switch(l){case \"input\":yb(k);\nGb(k,c,!1);break;case \"textarea\":yb(k);Nb(k,c);break;case \"option\":null!=c.value&&k.setAttribute(\"value\",\"\"+ub(c.value));break;case \"select\":d=k;d.multiple=!!c.multiple;k=c.value;null!=k?Jb(d,!!c.multiple,k,!1):null!=c.defaultValue&&Jb(d,!!c.multiple,c.defaultValue,!0);break;default:\"function\"===typeof d.onClick&&(k.onclick=ae)}(e=ne(f,e))&&Ci(b)}null!==b.ref&&(b.effectTag|=128)}else if(null===b.stateNode)throw Error(u(166));break;case 6:if(c&&null!=b.stateNode)Ki(c,b,c.memoizedProps,e);else{if(\"string\"!==\ntypeof e&&null===b.stateNode)throw Error(u(166));d=lh(kh.current);lh(ih.current);ki(b)?(e=b,f=e.stateNode,d=e.memoizedProps,f[ue]=e,(e=f.nodeValue!==d)&&Ci(b)):(f=b,e=(9===d.nodeType?d:d.ownerDocument).createTextNode(e),e[ue]=f,b.stateNode=e)}break;case 11:break;case 13:G(M,b);e=b.memoizedState;if(0!==(b.effectTag&64)){b.expirationTime=d;break a}e=null!==e;f=!1;null===c?void 0!==b.memoizedProps.fallback&&ki(b):(d=c.memoizedState,f=null!==d,e||null===d||(d=c.child.sibling,null!==d&&(k=b.firstEffect,\nnull!==k?(b.firstEffect=d,d.nextEffect=k):(b.firstEffect=b.lastEffect=d,d.nextEffect=null),d.effectTag=8)));if(e&&!f&&0!==(b.mode&2))if(null===c&&!0!==b.memoizedProps.unstable_avoidThisFallback||0!==(M.current&1))X===qj&&(X=tj);else{if(X===qj||X===tj)X=uj;0!==Aj&&null!==U&&(Mj(U,W),Nj(U,Aj))}if(e||f)b.effectTag|=4;break;case 7:break;case 8:break;case 12:break;case 4:nh(b);Ii(b);break;case 10:tg(b);break;case 9:break;case 14:break;case 17:L(b.type)&&Ff(b);break;case 19:G(M,b);e=b.memoizedState;if(null===\ne)break;f=0!==(b.effectTag&64);k=e.rendering;if(null===k)if(f)Li(e,!1);else{if(X!==qj||null!==c&&0!==(c.effectTag&64))for(c=b.child;null!==c;){k=qh(c);if(null!==k){b.effectTag|=64;Li(e,!1);f=k.updateQueue;null!==f&&(b.updateQueue=f,b.effectTag|=4);null===e.lastEffect&&(b.firstEffect=null);b.lastEffect=e.lastEffect;e=d;for(f=b.child;null!==f;)d=f,c=e,d.effectTag&=2,d.nextEffect=null,d.firstEffect=null,d.lastEffect=null,k=d.alternate,null===k?(d.childExpirationTime=0,d.expirationTime=c,d.child=null,\nd.memoizedProps=null,d.memoizedState=null,d.updateQueue=null,d.dependencies=null):(d.childExpirationTime=k.childExpirationTime,d.expirationTime=k.expirationTime,d.child=k.child,d.memoizedProps=k.memoizedProps,d.memoizedState=k.memoizedState,d.updateQueue=k.updateQueue,c=k.dependencies,d.dependencies=null===c?null:{expirationTime:c.expirationTime,firstContext:c.firstContext,responders:c.responders}),f=f.sibling;I(M,M.current&1|2,b);b=b.child;break a}c=c.sibling}}else{if(!f)if(c=qh(k),null!==c){if(b.effectTag|=\n64,f=!0,d=c.updateQueue,null!==d&&(b.updateQueue=d,b.effectTag|=4),Li(e,!0),null===e.tail&&\"hidden\"===e.tailMode&&!k.alternate){b=b.lastEffect=e.lastEffect;null!==b&&(b.nextEffect=null);break}}else cg()>e.tailExpiration&&1<d&&(b.effectTag|=64,f=!0,Li(e,!1),b.expirationTime=b.childExpirationTime=d-1);e.isBackwards?(k.sibling=b.child,b.child=k):(d=e.last,null!==d?d.sibling=k:b.child=k,e.last=k)}if(null!==e.tail){0===e.tailExpiration&&(e.tailExpiration=cg()+500);d=e.tail;e.rendering=d;e.tail=d.sibling;\ne.lastEffect=b.lastEffect;d.sibling=null;e=M.current;e=f?e&1|2:e&1;I(M,e,b);b=d;break a}break;case 20:break;case 21:break;default:throw Error(u(156,b.tag));}b=null}e=V;if(1===W||1!==e.childExpirationTime){f=0;for(d=e.child;null!==d;)c=d.expirationTime,k=d.childExpirationTime,c>f&&(f=c),k>f&&(f=k),d=d.sibling;e.childExpirationTime=f}if(null!==b)return b;null!==a&&0===(a.effectTag&2048)&&(null===a.firstEffect&&(a.firstEffect=V.firstEffect),null!==V.lastEffect&&(null!==a.lastEffect&&(a.lastEffect.nextEffect=\nV.firstEffect),a.lastEffect=V.lastEffect),1<V.effectTag&&(null!==a.lastEffect?a.lastEffect.nextEffect=V:a.firstEffect=V,a.lastEffect=V))}else{b=Mi(V,W);if(null!==b)return b.effectTag&=2047,b;null!==a&&(a.firstEffect=a.lastEffect=null,a.effectTag|=2048)}b=V.sibling;if(null!==b)return b;V=a}while(null!==V);X===qj&&(X=vj);return null}function Xj(a){var b=a.expirationTime;a=a.childExpirationTime;return b>a?b:a}function Yj(a){var b=dg();fg(99,ik.bind(null,a,b));return null}\nfunction ik(a,b){do Sj();while(null!==Ej);if((T&(oj|pj))!==S)throw Error(u(327));var c=a.finishedWork,d=a.finishedExpirationTime;if(null===c)return null;a.finishedWork=null;a.finishedExpirationTime=0;if(c===a.current)throw Error(u(177));a.callbackNode=null;a.callbackExpirationTime=0;a.callbackPriority=90;a.nextKnownPendingLevel=0;var e=Xj(c);a.firstPendingTime=e;d<=a.lastSuspendedTime?a.firstSuspendedTime=a.lastSuspendedTime=a.nextKnownPendingLevel=0:d<=a.firstSuspendedTime&&(a.firstSuspendedTime=\nd-1);d<=a.lastPingedTime&&(a.lastPingedTime=0);d<=a.lastExpiredTime&&(a.lastExpiredTime=0);a===U&&(V=U=null,W=0);1<c.effectTag?null!==c.lastEffect?(c.lastEffect.nextEffect=c,e=c.firstEffect):e=c:e=c.firstEffect;if(null!==e){var f=T;T|=pj;mj.current=null;le=Ld;var g=fe();if(ge(g)){if(\"selectionStart\"in g)var h={start:g.selectionStart,end:g.selectionEnd};else a:{h=(h=g.ownerDocument)&&h.defaultView||window;var k=h.getSelection&&h.getSelection();if(k&&0!==k.rangeCount){h=k.anchorNode;var l=k.anchorOffset,\nm=k.focusNode;k=k.focusOffset;try{h.nodeType,m.nodeType}catch(Db){h=null;break a}var C=0,y=-1,H=-1,z=0,ta=0,r=g,x=null;b:for(;;){for(var A;;){r!==h||0!==l&&3!==r.nodeType||(y=C+l);r!==m||0!==k&&3!==r.nodeType||(H=C+k);3===r.nodeType&&(C+=r.nodeValue.length);if(null===(A=r.firstChild))break;x=r;r=A}for(;;){if(r===g)break b;x===h&&++z===l&&(y=C);x===m&&++ta===k&&(H=C);if(null!==(A=r.nextSibling))break;r=x;x=r.parentNode}r=A}h=-1===y||-1===H?null:{start:y,end:H}}else h=null}h=h||{start:0,end:0}}else h=\nnull;me={focusedElem:g,selectionRange:h};Ld=!1;Y=e;do try{jk()}catch(Db){if(null===Y)throw Error(u(330));Ri(Y,Db);Y=Y.nextEffect}while(null!==Y);Y=e;do try{for(g=a,h=b;null!==Y;){var p=Y.effectTag;p&16&&Tb(Y.stateNode,\"\");if(p&128){var t=Y.alternate;if(null!==t){var v=t.ref;null!==v&&(\"function\"===typeof v?v(null):v.current=null)}}switch(p&1038){case 2:$i(Y);Y.effectTag&=-3;break;case 6:$i(Y);Y.effectTag&=-3;aj(Y.alternate,Y);break;case 1024:Y.effectTag&=-1025;break;case 1028:Y.effectTag&=-1025;aj(Y.alternate,\nY);break;case 4:aj(Y.alternate,Y);break;case 8:l=Y,Xi(g,l,h),Yi(l)}Y=Y.nextEffect}}catch(Db){if(null===Y)throw Error(u(330));Ri(Y,Db);Y=Y.nextEffect}while(null!==Y);v=me;t=fe();p=v.focusedElem;h=v.selectionRange;if(t!==p&&p&&p.ownerDocument&&ee(p.ownerDocument.documentElement,p)){null!==h&&ge(p)&&(t=h.start,v=h.end,void 0===v&&(v=t),\"selectionStart\"in p?(p.selectionStart=t,p.selectionEnd=Math.min(v,p.value.length)):(v=(t=p.ownerDocument||document)&&t.defaultView||window,v.getSelection&&(v=v.getSelection(),\nl=p.textContent.length,g=Math.min(h.start,l),h=void 0===h.end?g:Math.min(h.end,l),!v.extend&&g>h&&(l=h,h=g,g=l),l=de(p,g),m=de(p,h),l&&m&&(1!==v.rangeCount||v.anchorNode!==l.node||v.anchorOffset!==l.offset||v.focusNode!==m.node||v.focusOffset!==m.offset)&&(t=t.createRange(),t.setStart(l.node,l.offset),v.removeAllRanges(),g>h?(v.addRange(t),v.extend(m.node,m.offset)):(t.setEnd(m.node,m.offset),v.addRange(t))))));t=[];for(v=p;v=v.parentNode;)1===v.nodeType&&t.push({element:v,left:v.scrollLeft,top:v.scrollTop});\n\"function\"===typeof p.focus&&p.focus();for(p=0;p<t.length;p++)v=t[p],v.element.scrollLeft=v.left,v.element.scrollTop=v.top}me=null;Ld=!!le;le=null;a.current=c;Y=e;do try{for(p=d;null!==Y;){var Dh=Y.effectTag;if(Dh&36){var dc=Y.alternate;t=Y;v=p;switch(t.tag){case 0:case 11:case 15:Ui(16,32,t);break;case 1:var fd=t.stateNode;if(t.effectTag&4)if(null===dc)fd.componentDidMount();else{var hk=t.elementType===t.type?dc.memoizedProps:mg(t.type,dc.memoizedProps);fd.componentDidUpdate(hk,dc.memoizedState,\nfd.__reactInternalSnapshotBeforeUpdate)}var Eh=t.updateQueue;null!==Eh&&Kg(t,Eh,fd,v);break;case 3:var Fh=t.updateQueue;if(null!==Fh){g=null;if(null!==t.child)switch(t.child.tag){case 5:g=t.child.stateNode;break;case 1:g=t.child.stateNode}Kg(t,Fh,g,v)}break;case 5:var xk=t.stateNode;null===dc&&t.effectTag&4&&ne(t.type,t.memoizedProps)&&xk.focus();break;case 6:break;case 4:break;case 12:break;case 13:if(null===t.memoizedState){var Di=t.alternate;if(null!==Di){var Ei=Di.memoizedState;if(null!==Ei){var Fi=\nEi.dehydrated;null!==Fi&&Lc(Fi)}}}break;case 19:case 17:case 20:case 21:break;default:throw Error(u(163));}}if(Dh&128){t=void 0;var xd=Y.ref;if(null!==xd){var Gi=Y.stateNode;switch(Y.tag){case 5:t=Gi;break;default:t=Gi}\"function\"===typeof xd?xd(t):xd.current=t}}Y=Y.nextEffect}}catch(Db){if(null===Y)throw Error(u(330));Ri(Y,Db);Y=Y.nextEffect}while(null!==Y);Y=null;Yf();T=f}else a.current=c;if(Dj)Dj=!1,Ej=a,Fj=b;else for(Y=e;null!==Y;)b=Y.nextEffect,Y.nextEffect=null,Y=b;b=a.firstPendingTime;0===b&&\n(jj=null);1073741823===b?a===Ij?Hj++:(Hj=0,Ij=a):Hj=0;\"function\"===typeof kk&&kk(c.stateNode,d);Z(a);if(gj)throw gj=!1,a=hj,hj=null,a;if((T&nj)!==S)return null;jg();return null}function jk(){for(;null!==Y;){var a=Y.effectTag;0!==(a&256)&&Ti(Y.alternate,Y);0===(a&512)||Dj||(Dj=!0,gg(97,function(){Sj();return null}));Y=Y.nextEffect}}function Sj(){if(90!==Fj){var a=97<Fj?97:Fj;Fj=90;return fg(a,lk)}}\nfunction lk(){if(null===Ej)return!1;var a=Ej;Ej=null;if((T&(oj|pj))!==S)throw Error(u(331));var b=T;T|=pj;for(a=a.current.firstEffect;null!==a;){try{var c=a;if(0!==(c.effectTag&512))switch(c.tag){case 0:case 11:case 15:Ui(128,0,c),Ui(0,64,c)}}catch(d){if(null===a)throw Error(u(330));Ri(a,d)}c=a.nextEffect;a.nextEffect=null;a=c}T=b;jg();return!0}function mk(a,b,c){b=Ni(c,b);b=fj(a,b,1073741823);Dg(a,b);a=Kj(a,1073741823);null!==a&&Z(a)}\nfunction Ri(a,b){if(3===a.tag)mk(a,a,b);else for(var c=a.return;null!==c;){if(3===c.tag){mk(c,a,b);break}else if(1===c.tag){var d=c.stateNode;if(\"function\"===typeof c.type.getDerivedStateFromError||\"function\"===typeof d.componentDidCatch&&(null===jj||!jj.has(d))){a=Ni(b,a);a=ij(c,a,1073741823);Dg(c,a);c=Kj(c,1073741823);null!==c&&Z(c);break}}c=c.return}}\nfunction dk(a,b,c){var d=a.pingCache;null!==d&&d.delete(b);U===a&&W===c?X===uj||X===tj&&1073741823===xj&&cg()-bj<Cj?Tj(a,W):Bj=!0:Pj(a,c)&&(b=a.lastPingedTime,0!==b&&b<c||(a.lastPingedTime=c,a.finishedExpirationTime===c&&(a.finishedExpirationTime=0,a.finishedWork=null),Z(a)))}function dj(a,b){var c=a.stateNode;null!==c&&c.delete(b);b=0;0===b&&(b=Pg(),b=Qg(b,a,null));a=Kj(a,b);null!==a&&Z(a)}var gk;\ngk=function(a,b,c){var d=b.expirationTime;if(null!==a){var e=b.pendingProps;if(a.memoizedProps!==e||K.current)wg=!0;else{if(d<c){wg=!1;switch(b.tag){case 3:wi(b);li();break;case 5:oh(b);if(b.mode&4&&1!==c&&e.hidden)return b.expirationTime=b.childExpirationTime=1,null;break;case 1:L(b.type)&&Jf(b);break;case 4:mh(b,b.stateNode.containerInfo);break;case 10:sg(b,b.memoizedProps.value);break;case 13:if(null!==b.memoizedState){d=b.child.childExpirationTime;if(0!==d&&d>=c)return yi(a,b,c);I(M,M.current&\n1,b);b=oi(a,b,c);return null!==b?b.sibling:null}I(M,M.current&1,b);break;case 19:d=b.childExpirationTime>=c;if(0!==(a.effectTag&64)){if(d)return Bi(a,b,c);b.effectTag|=64}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null);I(M,M.current,b);if(!d)return null}return oi(a,b,c)}wg=!1}}else wg=!1;b.expirationTime=0;switch(b.tag){case 2:d=b.type;null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2);a=b.pendingProps;e=Ef(b,J.current);vg(b,c);e=Ih(null,b,d,a,e,c);b.effectTag|=1;if(\"object\"===\ntypeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof){b.tag=1;Mh();if(L(d)){var f=!0;Jf(b)}else f=!1;b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null;var g=d.getDerivedStateFromProps;\"function\"===typeof g&&Og(b,d,g,a);e.updater=Sg;b.stateNode=e;e._reactInternalFiber=b;Wg(b,d,a,c);b=vi(null,b,d,!0,f,c)}else b.tag=0,R(null,b,e,c),b=b.child;return b;case 16:e=b.elementType;null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2);a=b.pendingProps;Va(e);if(1!==e._status)throw e._result;\ne=e._result;b.type=e;f=b.tag=nk(e);a=mg(e,a);switch(f){case 0:b=si(null,b,e,a,c);break;case 1:b=ui(null,b,e,a,c);break;case 11:b=ni(null,b,e,a,c);break;case 14:b=pi(null,b,e,mg(e.type,a),d,c);break;default:throw Error(u(306,e,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),si(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),ui(a,b,d,e,c);case 3:wi(b);d=b.updateQueue;if(null===d)throw Error(u(282));e=b.memoizedState;e=null!==e?e.element:\nnull;Hg(b,d,b.pendingProps,null,c);d=b.memoizedState.element;if(d===e)li(),b=oi(a,b,c);else{if(e=b.stateNode.hydrate)di=re(b.stateNode.containerInfo.firstChild),ci=b,e=ei=!0;if(e)for(c=gh(b,null,d,c),b.child=c;c;)c.effectTag=c.effectTag&-3|1024,c=c.sibling;else R(a,b,d,c),li();b=b.child}return b;case 5:return oh(b),null===a&&ii(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,oe(d,e)?g=null:null!==f&&oe(d,f)&&(b.effectTag|=16),ti(a,b),b.mode&4&&1!==c&&e.hidden?(b.expirationTime=\nb.childExpirationTime=1,b=null):(R(a,b,g,c),b=b.child),b;case 6:return null===a&&ii(b),null;case 13:return yi(a,b,c);case 4:return mh(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=fh(b,null,d,c):R(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),ni(a,b,d,e,c);case 7:return R(a,b,b.pendingProps,c),b.child;case 8:return R(a,b,b.pendingProps.children,c),b.child;case 12:return R(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;\ne=b.pendingProps;g=b.memoizedProps;f=e.value;sg(b,f);if(null!==g){var h=g.value;f=of(h,f)?0:(\"function\"===typeof d._calculateChangedBits?d._calculateChangedBits(h,f):1073741823)|0;if(0===f){if(g.children===e.children&&!K.current){b=oi(a,b,c);break a}}else for(h=b.child,null!==h&&(h.return=b);null!==h;){var k=h.dependencies;if(null!==k){g=h.child;for(var l=k.firstContext;null!==l;){if(l.context===d&&0!==(l.observedBits&f)){1===h.tag&&(l=Bg(c,null),l.tag=2,Dg(h,l));h.expirationTime<c&&(h.expirationTime=\nc);l=h.alternate;null!==l&&l.expirationTime<c&&(l.expirationTime=c);ug(h.return,c);k.expirationTime<c&&(k.expirationTime=c);break}l=l.next}}else g=10===h.tag?h.type===b.type?null:h.child:h.child;if(null!==g)g.return=h;else for(g=h;null!==g;){if(g===b){g=null;break}h=g.sibling;if(null!==h){h.return=g.return;g=h;break}g=g.return}h=g}}R(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,f=b.pendingProps,d=f.children,vg(b,c),e=xg(e,f.unstable_observedBits),d=d(e),b.effectTag|=1,R(a,b,d,c),b.child;\ncase 14:return e=b.type,f=mg(e,b.pendingProps),f=mg(e.type,f),pi(a,b,e,f,d,c);case 15:return ri(a,b,b.type,b.pendingProps,d,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2),b.tag=1,L(d)?(a=!0,Jf(b)):a=!1,vg(b,c),Ug(b,d,e,c),Wg(b,d,e,c),vi(null,b,d,!0,a,c);case 19:return Bi(a,b,c)}throw Error(u(156,b.tag));};var kk=null,Wi=null;\nfunction ok(a){if(\"undefined\"===typeof __REACT_DEVTOOLS_GLOBAL_HOOK__)return!1;var b=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(b.isDisabled||!b.supportsFiber)return!0;try{var c=b.inject(a);kk=function(a){try{b.onCommitFiberRoot(c,a,void 0,64===(a.current.effectTag&64))}catch(e){}};Wi=function(a){try{b.onCommitFiberUnmount(c,a)}catch(e){}}}catch(d){}return!0}\nfunction pk(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.effectTag=0;this.lastEffect=this.firstEffect=this.nextEffect=null;this.childExpirationTime=this.expirationTime=0;this.alternate=null}function gi(a,b,c,d){return new pk(a,b,c,d)}\nfunction qi(a){a=a.prototype;return!(!a||!a.isReactComponent)}function nk(a){if(\"function\"===typeof a)return qi(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Oa)return 11;if(a===Ra)return 14}return 2}\nfunction ah(a,b){var c=a.alternate;null===c?(c=gi(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.effectTag=0,c.nextEffect=null,c.firstEffect=null,c.lastEffect=null);c.childExpirationTime=a.childExpirationTime;c.expirationTime=a.expirationTime;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{expirationTime:b.expirationTime,\nfirstContext:b.firstContext,responders:b.responders};c.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction ch(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)qi(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case Ia:return eh(c.children,e,f,b);case Na:g=8;e|=7;break;case Ja:g=8;e|=1;break;case Ka:return a=gi(12,c,b,e|8),a.elementType=Ka,a.type=Ka,a.expirationTime=f,a;case Pa:return a=gi(13,c,b,e),a.type=Pa,a.elementType=Pa,a.expirationTime=f,a;case Qa:return a=gi(19,c,b,e),a.elementType=Qa,a.expirationTime=f,a;default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case La:g=\n10;break a;case Ma:g=9;break a;case Oa:g=11;break a;case Ra:g=14;break a;case Sa:g=16;d=null;break a}throw Error(u(130,null==a?a:typeof a,\"\"));}b=gi(g,c,b,e);b.elementType=a;b.type=d;b.expirationTime=f;return b}function eh(a,b,c,d){a=gi(7,a,d,b);a.expirationTime=c;return a}function bh(a,b,c){a=gi(6,a,null,b);a.expirationTime=c;return a}\nfunction dh(a,b,c){b=gi(4,null!==a.children?a.children:[],a.key,b);b.expirationTime=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction qk(a,b,c){this.tag=b;this.current=null;this.containerInfo=a;this.pingCache=this.pendingChildren=null;this.finishedExpirationTime=0;this.finishedWork=null;this.timeoutHandle=-1;this.pendingContext=this.context=null;this.hydrate=c;this.callbackNode=null;this.callbackPriority=90;this.lastExpiredTime=this.lastPingedTime=this.nextKnownPendingLevel=this.lastSuspendedTime=this.firstSuspendedTime=this.firstPendingTime=0}\nfunction Pj(a,b){var c=a.firstSuspendedTime;a=a.lastSuspendedTime;return 0!==c&&c>=b&&a<=b}function Mj(a,b){var c=a.firstSuspendedTime,d=a.lastSuspendedTime;c<b&&(a.firstSuspendedTime=b);if(d>b||0===c)a.lastSuspendedTime=b;b<=a.lastPingedTime&&(a.lastPingedTime=0);b<=a.lastExpiredTime&&(a.lastExpiredTime=0)}\nfunction Nj(a,b){b>a.firstPendingTime&&(a.firstPendingTime=b);var c=a.firstSuspendedTime;0!==c&&(b>=c?a.firstSuspendedTime=a.lastSuspendedTime=a.nextKnownPendingLevel=0:b>=a.lastSuspendedTime&&(a.lastSuspendedTime=b+1),b>a.nextKnownPendingLevel&&(a.nextKnownPendingLevel=b))}function Rj(a,b){var c=a.lastExpiredTime;if(0===c||c>b)a.lastExpiredTime=b}\nfunction rk(a,b,c,d){var e=b.current,f=Pg(),g=Mg.suspense;f=Qg(f,e,g);a:if(c){c=c._reactInternalFiber;b:{if(ec(c)!==c||1!==c.tag)throw Error(u(170));var h=c;do{switch(h.tag){case 3:h=h.stateNode.context;break b;case 1:if(L(h.type)){h=h.stateNode.__reactInternalMemoizedMergedChildContext;break b}}h=h.return}while(null!==h);throw Error(u(171));}if(1===c.tag){var k=c.type;if(L(k)){c=If(c,k,h);break a}}c=h}else c=Cf;null===b.context?b.context=c:b.pendingContext=c;b=Bg(f,g);b.payload={element:a};d=void 0===\nd?null:d;null!==d&&(b.callback=d);Dg(e,b);Rg(e,f);return f}function sk(a){a=a.current;if(!a.child)return null;switch(a.child.tag){case 5:return a.child.stateNode;default:return a.child.stateNode}}function tk(a,b){a=a.memoizedState;null!==a&&null!==a.dehydrated&&a.retryTime<b&&(a.retryTime=b)}function uk(a,b){tk(a,b);(a=a.alternate)&&tk(a,b)}\nfunction vk(a,b,c){c=null!=c&&!0===c.hydrate;var d=new qk(a,b,c),e=gi(3,null,null,2===b?7:1===b?3:0);d.current=e;e.stateNode=d;a[we]=d.current;c&&0!==b&&wc(9===a.nodeType?a:a.ownerDocument);this._internalRoot=d}vk.prototype.render=function(a,b){rk(a,this._internalRoot,null,void 0===b?null:b)};vk.prototype.unmount=function(a){var b=this._internalRoot,c=void 0===a?null:a,d=b.containerInfo;rk(null,b,null,function(){d[we]=null;null!==c&&c()})};\nfunction wk(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType&&(8!==a.nodeType||\" react-mount-point-unstable \"!==a.nodeValue))}function yk(a,b){b||(b=a?9===a.nodeType?a.documentElement:a.firstChild:null,b=!(!b||1!==b.nodeType||!b.hasAttribute(\"data-reactroot\")));if(!b)for(var c;c=a.lastChild;)a.removeChild(c);return new vk(a,0,b?{hydrate:!0}:void 0)}\nfunction zk(a,b,c,d,e){var f=c._reactRootContainer;if(f){var g=f._internalRoot;if(\"function\"===typeof e){var h=e;e=function(){var a=sk(g);h.call(a)}}rk(b,g,a,e)}else{f=c._reactRootContainer=yk(c,d);g=f._internalRoot;if(\"function\"===typeof e){var k=e;e=function(){var a=sk(g);k.call(a)}}ck(function(){rk(b,g,a,e)})}return sk(g)}function Ak(a,b,c){var d=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:Ha,key:null==d?null:\"\"+d,children:a,containerInfo:b,implementation:c}}\njc=function(a){if(13===a.tag){var b=lg(Pg(),150,100);Rg(a,b);uk(a,b)}};kc=function(a){if(13===a.tag){Pg();var b=kg++;Rg(a,b);uk(a,b)}};lc=function(a){if(13===a.tag){var b=Pg();b=Qg(b,a,null);Rg(a,b);uk(a,b)}};\nZa=function(a,b,c){switch(b){case \"input\":Eb(a,c);b=c.name;if(\"radio\"===c.type&&null!=b){for(c=a;c.parentNode;)c=c.parentNode;c=c.querySelectorAll(\"input[name=\"+JSON.stringify(\"\"+b)+'][type=\"radio\"]');for(b=0;b<c.length;b++){var d=c[b];if(d!==a&&d.form===a.form){var e=ye(d);if(!e)throw Error(u(90));zb(d);Eb(d,e)}}}break;case \"textarea\":Mb(a,c);break;case \"select\":b=c.value,null!=b&&Jb(a,!!c.multiple,b,!1)}};eb=bk;\nfb=function(a,b,c,d){var e=T;T|=4;try{return fg(98,a.bind(null,b,c,d))}finally{T=e,T===S&&jg()}};gb=function(){(T&(1|oj|pj))===S&&(ak(),Sj())};hb=function(a,b){var c=T;T|=2;try{return a(b)}finally{T=c,T===S&&jg()}};function Bk(a,b){var c=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!wk(b))throw Error(u(200));return Ak(a,b,null,c)}\nvar Ck={createPortal:Bk,findDOMNode:function(a){if(null==a)return null;if(1===a.nodeType)return a;var b=a._reactInternalFiber;if(void 0===b){if(\"function\"===typeof a.render)throw Error(u(188));throw Error(u(268,Object.keys(a)));}a=ic(b);a=null===a?null:a.stateNode;return a},hydrate:function(a,b,c){if(!wk(b))throw Error(u(200));return zk(null,a,b,!0,c)},render:function(a,b,c){if(!wk(b))throw Error(u(200));return zk(null,a,b,!1,c)},unstable_renderSubtreeIntoContainer:function(a,b,c,d){if(!wk(c))throw Error(u(200));\nif(null==a||void 0===a._reactInternalFiber)throw Error(u(38));return zk(a,b,c,!1,d)},unmountComponentAtNode:function(a){if(!wk(a))throw Error(u(40));return a._reactRootContainer?(ck(function(){zk(null,null,a,!1,function(){a._reactRootContainer=null;a[we]=null})}),!0):!1},unstable_createPortal:function(){return Bk.apply(void 0,arguments)},unstable_batchedUpdates:bk,flushSync:function(a,b){if((T&(oj|pj))!==S)throw Error(u(187));var c=T;T|=1;try{return fg(99,a.bind(null,b))}finally{T=c,jg()}},__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{Events:[Cc,\nxe,ye,Ca.injectEventPluginsByName,fa,Sc,function(a){ya(a,Rc)},cb,db,Pd,Ba,Sj,{current:!1}]}};\n(function(a){var b=a.findFiberByHostInstance;return ok(n({},a,{overrideHookState:null,overrideProps:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:Ea.ReactCurrentDispatcher,findHostInstanceByFiber:function(a){a=ic(a);return null===a?null:a.stateNode},findFiberByHostInstance:function(a){return b?b(a):null},findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null}))})({findFiberByHostInstance:Fc,bundleType:0,version:\"16.12.0\",\nrendererPackageName:\"react-dom\"});var Dk={default:Ck},Ek=Dk&&Ck||Dk;module.exports=Ek.default||Ek;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","/** @license React v0.18.0\n * scheduler.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';Object.defineProperty(exports,\"__esModule\",{value:!0});var f,g,h,k,l;\nif(\"undefined\"===typeof window||\"function\"!==typeof MessageChannel){var p=null,q=null,t=function(){if(null!==p)try{var a=exports.unstable_now();p(!0,a);p=null}catch(b){throw setTimeout(t,0),b;}},u=Date.now();exports.unstable_now=function(){return Date.now()-u};f=function(a){null!==p?setTimeout(f,0,a):(p=a,setTimeout(t,0))};g=function(a,b){q=setTimeout(a,b)};h=function(){clearTimeout(q)};k=function(){return!1};l=exports.unstable_forceFrameRate=function(){}}else{var w=window.performance,x=window.Date,\ny=window.setTimeout,z=window.clearTimeout;if(\"undefined\"!==typeof console){var A=window.cancelAnimationFrame;\"function\"!==typeof window.requestAnimationFrame&&console.error(\"This browser doesn't support requestAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills\");\"function\"!==typeof A&&console.error(\"This browser doesn't support cancelAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills\")}if(\"object\"===\ntypeof w&&\"function\"===typeof w.now)exports.unstable_now=function(){return w.now()};else{var B=x.now();exports.unstable_now=function(){return x.now()-B}}var C=!1,D=null,E=-1,F=5,G=0;k=function(){return exports.unstable_now()>=G};l=function(){};exports.unstable_forceFrameRate=function(a){0>a||125<a?console.error(\"forceFrameRate takes a positive int between 0 and 125, forcing framerates higher than 125 fps is not unsupported\"):F=0<a?Math.floor(1E3/a):5};var H=new MessageChannel,I=H.port2;H.port1.onmessage=\nfunction(){if(null!==D){var a=exports.unstable_now();G=a+F;try{D(!0,a)?I.postMessage(null):(C=!1,D=null)}catch(b){throw I.postMessage(null),b;}}else C=!1};f=function(a){D=a;C||(C=!0,I.postMessage(null))};g=function(a,b){E=y(function(){a(exports.unstable_now())},b)};h=function(){z(E);E=-1}}function J(a,b){var c=a.length;a.push(b);a:for(;;){var d=Math.floor((c-1)/2),e=a[d];if(void 0!==e&&0<K(e,b))a[d]=b,a[c]=e,c=d;else break a}}function L(a){a=a[0];return void 0===a?null:a}\nfunction M(a){var b=a[0];if(void 0!==b){var c=a.pop();if(c!==b){a[0]=c;a:for(var d=0,e=a.length;d<e;){var m=2*(d+1)-1,n=a[m],v=m+1,r=a[v];if(void 0!==n&&0>K(n,c))void 0!==r&&0>K(r,n)?(a[d]=r,a[v]=c,d=v):(a[d]=n,a[m]=c,d=m);else if(void 0!==r&&0>K(r,c))a[d]=r,a[v]=c,d=v;else break a}}return b}return null}function K(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}var N=[],O=[],P=1,Q=null,R=3,S=!1,T=!1,U=!1;\nfunction V(a){for(var b=L(O);null!==b;){if(null===b.callback)M(O);else if(b.startTime<=a)M(O),b.sortIndex=b.expirationTime,J(N,b);else break;b=L(O)}}function W(a){U=!1;V(a);if(!T)if(null!==L(N))T=!0,f(X);else{var b=L(O);null!==b&&g(W,b.startTime-a)}}\nfunction X(a,b){T=!1;U&&(U=!1,h());S=!0;var c=R;try{V(b);for(Q=L(N);null!==Q&&(!(Q.expirationTime>b)||a&&!k());){var d=Q.callback;if(null!==d){Q.callback=null;R=Q.priorityLevel;var e=d(Q.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?Q.callback=e:Q===L(N)&&M(N);V(b)}else M(N);Q=L(N)}if(null!==Q)var m=!0;else{var n=L(O);null!==n&&g(W,n.startTime-b);m=!1}return m}finally{Q=null,R=c,S=!1}}\nfunction Y(a){switch(a){case 1:return-1;case 2:return 250;case 5:return 1073741823;case 4:return 1E4;default:return 5E3}}var Z=l;exports.unstable_ImmediatePriority=1;exports.unstable_UserBlockingPriority=2;exports.unstable_NormalPriority=3;exports.unstable_IdlePriority=5;exports.unstable_LowPriority=4;exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=R;R=a;try{return b()}finally{R=c}};\nexports.unstable_next=function(a){switch(R){case 1:case 2:case 3:var b=3;break;default:b=R}var c=R;R=b;try{return a()}finally{R=c}};\nexports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();if(\"object\"===typeof c&&null!==c){var e=c.delay;e=\"number\"===typeof e&&0<e?d+e:d;c=\"number\"===typeof c.timeout?c.timeout:Y(a)}else c=Y(a),e=d;c=e+c;a={id:P++,callback:b,priorityLevel:a,startTime:e,expirationTime:c,sortIndex:-1};e>d?(a.sortIndex=e,J(O,a),null===L(N)&&a===L(O)&&(U?h():U=!0,g(W,e-d))):(a.sortIndex=c,J(N,a),T||S||(T=!0,f(X)));return a};exports.unstable_cancelCallback=function(a){a.callback=null};\nexports.unstable_wrapCallback=function(a){var b=R;return function(){var c=R;R=b;try{return a.apply(this,arguments)}finally{R=c}}};exports.unstable_getCurrentPriorityLevel=function(){return R};exports.unstable_shouldYield=function(){var a=exports.unstable_now();V(a);var b=L(N);return b!==Q&&null!==Q&&null!==b&&null!==b.callback&&b.startTime<=a&&b.expirationTime<Q.expirationTime||k()};exports.unstable_requestPaint=Z;exports.unstable_continueExecution=function(){T||S||(T=!0,f(X))};\nexports.unstable_pauseExecution=function(){};exports.unstable_getFirstCallbackNode=function(){return L(N)};exports.unstable_Profiling=null;\n","'use strict';\n\nvar utils = require('./utils');\nvar bind = require('./helpers/bind');\nvar Axios = require('./core/Axios');\nvar mergeConfig = require('./core/mergeConfig');\nvar defaults = require('./defaults');\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n * @return {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n var context = new Axios(defaultConfig);\n var instance = bind(Axios.prototype.request, context);\n\n // Copy axios.prototype to instance\n utils.extend(instance, Axios.prototype, context);\n\n // Copy context to instance\n utils.extend(instance, context);\n\n return instance;\n}\n\n// Create the default instance to be exported\nvar axios = createInstance(defaults);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios;\n\n// Factory for creating new instances\naxios.create = function create(instanceConfig) {\n return createInstance(mergeConfig(axios.defaults, instanceConfig));\n};\n\n// Expose Cancel & CancelToken\naxios.Cancel = require('./cancel/Cancel');\naxios.CancelToken = require('./cancel/CancelToken');\naxios.isCancel = require('./cancel/isCancel');\n\n// Expose all/spread\naxios.all = function all(promises) {\n return Promise.all(promises);\n};\naxios.spread = require('./helpers/spread');\n\nmodule.exports = axios;\n\n// Allow use of default import syntax in TypeScript\nmodule.exports.default = axios;\n","'use strict';\n\nvar utils = require('./../utils');\nvar buildURL = require('../helpers/buildURL');\nvar InterceptorManager = require('./InterceptorManager');\nvar dispatchRequest = require('./dispatchRequest');\nvar mergeConfig = require('./mergeConfig');\n\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n */\nfunction Axios(instanceConfig) {\n this.defaults = instanceConfig;\n this.interceptors = {\n request: new InterceptorManager(),\n response: new InterceptorManager()\n };\n}\n\n/**\n * Dispatch a request\n *\n * @param {Object} config The config specific for this request (merged with this.defaults)\n */\nAxios.prototype.request = function request(config) {\n /*eslint no-param-reassign:0*/\n // Allow for axios('example/url'[, config]) a la fetch API\n if (typeof config === 'string') {\n config = arguments[1] || {};\n config.url = arguments[0];\n } else {\n config = config || {};\n }\n\n config = mergeConfig(this.defaults, config);\n\n // Set config.method\n if (config.method) {\n config.method = config.method.toLowerCase();\n } else if (this.defaults.method) {\n config.method = this.defaults.method.toLowerCase();\n } else {\n config.method = 'get';\n }\n\n // Hook up interceptors middleware\n var chain = [dispatchRequest, undefined];\n var promise = Promise.resolve(config);\n\n this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n chain.unshift(interceptor.fulfilled, interceptor.rejected);\n });\n\n this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n chain.push(interceptor.fulfilled, interceptor.rejected);\n });\n\n while (chain.length) {\n promise = promise.then(chain.shift(), chain.shift());\n }\n\n return promise;\n};\n\nAxios.prototype.getUri = function getUri(config) {\n config = mergeConfig(this.defaults, config);\n return buildURL(config.url, config.params, config.paramsSerializer).replace(/^\\?/, '');\n};\n\n// Provide aliases for supported request methods\nutils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function(url, config) {\n return this.request(utils.merge(config || {}, {\n method: method,\n url: url\n }));\n };\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function(url, data, config) {\n return this.request(utils.merge(config || {}, {\n method: method,\n url: url,\n data: data\n }));\n };\n});\n\nmodule.exports = Axios;\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction InterceptorManager() {\n this.handlers = [];\n}\n\n/**\n * Add a new interceptor to the stack\n *\n * @param {Function} fulfilled The function to handle `then` for a `Promise`\n * @param {Function} rejected The function to handle `reject` for a `Promise`\n *\n * @return {Number} An ID used to remove interceptor later\n */\nInterceptorManager.prototype.use = function use(fulfilled, rejected) {\n this.handlers.push({\n fulfilled: fulfilled,\n rejected: rejected\n });\n return this.handlers.length - 1;\n};\n\n/**\n * Remove an interceptor from the stack\n *\n * @param {Number} id The ID that was returned by `use`\n */\nInterceptorManager.prototype.eject = function eject(id) {\n if (this.handlers[id]) {\n this.handlers[id] = null;\n }\n};\n\n/**\n * Iterate over all the registered interceptors\n *\n * This method is particularly useful for skipping over any\n * interceptors that may have become `null` calling `eject`.\n *\n * @param {Function} fn The function to call for each interceptor\n */\nInterceptorManager.prototype.forEach = function forEach(fn) {\n utils.forEach(this.handlers, function forEachHandler(h) {\n if (h !== null) {\n fn(h);\n }\n });\n};\n\nmodule.exports = InterceptorManager;\n","'use strict';\n\nvar utils = require('./../utils');\nvar transformData = require('./transformData');\nvar isCancel = require('../cancel/isCancel');\nvar defaults = require('../defaults');\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nfunction throwIfCancellationRequested(config) {\n if (config.cancelToken) {\n config.cancelToken.throwIfRequested();\n }\n}\n\n/**\n * Dispatch a request to the server using the configured adapter.\n *\n * @param {object} config The config that is to be used for the request\n * @returns {Promise} The Promise to be fulfilled\n */\nmodule.exports = function dispatchRequest(config) {\n throwIfCancellationRequested(config);\n\n // Ensure headers exist\n config.headers = config.headers || {};\n\n // Transform request data\n config.data = transformData(\n config.data,\n config.headers,\n config.transformRequest\n );\n\n // Flatten headers\n config.headers = utils.merge(\n config.headers.common || {},\n config.headers[config.method] || {},\n config.headers\n );\n\n utils.forEach(\n ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],\n function cleanHeaderConfig(method) {\n delete config.headers[method];\n }\n );\n\n var adapter = config.adapter || defaults.adapter;\n\n return adapter(config).then(function onAdapterResolution(response) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n response.data = transformData(\n response.data,\n response.headers,\n config.transformResponse\n );\n\n return response;\n }, function onAdapterRejection(reason) {\n if (!isCancel(reason)) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n if (reason && reason.response) {\n reason.response.data = transformData(\n reason.response.data,\n reason.response.headers,\n config.transformResponse\n );\n }\n }\n\n return Promise.reject(reason);\n });\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Object|String} data The data to be transformed\n * @param {Array} headers The headers for the request or response\n * @param {Array|Function} fns A single function or Array of functions\n * @returns {*} The resulting transformed data\n */\nmodule.exports = function transformData(data, headers, fns) {\n /*eslint no-param-reassign:0*/\n utils.forEach(fns, function transform(fn) {\n data = fn(data, headers);\n });\n\n return data;\n};\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\n\nvar utils = require('../utils');\n\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n utils.forEach(headers, function processHeader(value, name) {\n if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n headers[normalizedName] = value;\n delete headers[name];\n }\n });\n};\n","'use strict';\n\nvar createError = require('./createError');\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n */\nmodule.exports = function settle(resolve, reject, response) {\n var validateStatus = response.config.validateStatus;\n if (!validateStatus || validateStatus(response.status)) {\n resolve(response);\n } else {\n reject(createError(\n 'Request failed with status code ' + response.status,\n response.config,\n null,\n response.request,\n response\n ));\n }\n};\n","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n error.config = config;\n if (code) {\n error.code = code;\n }\n\n error.request = request;\n error.response = response;\n error.isAxiosError = true;\n\n error.toJSON = function() {\n return {\n // Standard\n message: this.message,\n name: this.name,\n // Microsoft\n description: this.description,\n number: this.number,\n // Mozilla\n fileName: this.fileName,\n lineNumber: this.lineNumber,\n columnNumber: this.columnNumber,\n stack: this.stack,\n // Axios\n config: this.config,\n code: this.code\n };\n };\n return error;\n};\n","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n if (baseURL && !isAbsoluteURL(requestedURL)) {\n return combineURLs(baseURL, requestedURL);\n }\n return requestedURL;\n};\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n // A URL is considered absolute if it begins with \"<scheme>://\" or \"//\" (protocol-relative URL).\n // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n // by any combination of letters, digits, plus, period, or hyphen.\n return /^([a-z][a-z\\d\\+\\-\\.]*:)?\\/\\//i.test(url);\n};\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n return relativeURL\n ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n : baseURL;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = [\n 'age', 'authorization', 'content-length', 'content-type', 'etag',\n 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n 'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n 'referer', 'retry-after', 'user-agent'\n];\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n var parsed = {};\n var key;\n var val;\n var i;\n\n if (!headers) { return parsed; }\n\n utils.forEach(headers.split('\\n'), function parser(line) {\n i = line.indexOf(':');\n key = utils.trim(line.substr(0, i)).toLowerCase();\n val = utils.trim(line.substr(i + 1));\n\n if (key) {\n if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n return;\n }\n if (key === 'set-cookie') {\n parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n } else {\n parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n }\n }\n });\n\n return parsed;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs have full support of the APIs needed to test\n // whether the request URL is of the same origin as current location.\n (function standardBrowserEnv() {\n var msie = /(msie|trident)/i.test(navigator.userAgent);\n var urlParsingNode = document.createElement('a');\n var originURL;\n\n /**\n * Parse a URL to discover it's components\n *\n * @param {String} url The URL to be parsed\n * @returns {Object}\n */\n function resolveURL(url) {\n var href = url;\n\n if (msie) {\n // IE needs attribute set twice to normalize properties\n urlParsingNode.setAttribute('href', href);\n href = urlParsingNode.href;\n }\n\n urlParsingNode.setAttribute('href', href);\n\n // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n return {\n href: urlParsingNode.href,\n protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n host: urlParsingNode.host,\n search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n hostname: urlParsingNode.hostname,\n port: urlParsingNode.port,\n pathname: (urlParsingNode.pathname.charAt(0) === '/') ?\n urlParsingNode.pathname :\n '/' + urlParsingNode.pathname\n };\n }\n\n originURL = resolveURL(window.location.href);\n\n /**\n * Determine if a URL shares the same origin as the current location\n *\n * @param {String} requestURL The URL to test\n * @returns {boolean} True if URL shares the same origin, otherwise false\n */\n return function isURLSameOrigin(requestURL) {\n var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;\n return (parsed.protocol === originURL.protocol &&\n parsed.host === originURL.host);\n };\n })() :\n\n // Non standard browser envs (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return function isURLSameOrigin() {\n return true;\n };\n })()\n);\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs support document.cookie\n (function standardBrowserEnv() {\n return {\n write: function write(name, value, expires, path, domain, secure) {\n var cookie = [];\n cookie.push(name + '=' + encodeURIComponent(value));\n\n if (utils.isNumber(expires)) {\n cookie.push('expires=' + new Date(expires).toGMTString());\n }\n\n if (utils.isString(path)) {\n cookie.push('path=' + path);\n }\n\n if (utils.isString(domain)) {\n cookie.push('domain=' + domain);\n }\n\n if (secure === true) {\n cookie.push('secure');\n }\n\n document.cookie = cookie.join('; ');\n },\n\n read: function read(name) {\n var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n return (match ? decodeURIComponent(match[3]) : null);\n },\n\n remove: function remove(name) {\n this.write(name, '', Date.now() - 86400000);\n }\n };\n })() :\n\n // Non standard browser env (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return {\n write: function write() {},\n read: function read() { return null; },\n remove: function remove() {}\n };\n })()\n);\n","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n if (typeof executor !== 'function') {\n throw new TypeError('executor must be a function.');\n }\n\n var resolvePromise;\n this.promise = new Promise(function promiseExecutor(resolve) {\n resolvePromise = resolve;\n });\n\n var token = this;\n executor(function cancel(message) {\n if (token.reason) {\n // Cancellation has already been requested\n return;\n }\n\n token.reason = new Cancel(message);\n resolvePromise(token.reason);\n });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n if (this.reason) {\n throw this.reason;\n }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n var cancel;\n var token = new CancelToken(function executor(c) {\n cancel = c;\n });\n return {\n token: token,\n cancel: cancel\n };\n};\n\nmodule.exports = CancelToken;\n","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n * ```js\n * function f(x, y, z) {}\n * var args = [1, 2, 3];\n * f.apply(null, args);\n * ```\n *\n * With `spread` this example can be re-written.\n *\n * ```js\n * spread(function(x, y, z) {})([1, 2, 3]);\n * ```\n *\n * @param {Function} callback\n * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/** @license React v16.12.0\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';Object.defineProperty(exports,\"__esModule\",{value:!0});\nvar b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?Symbol.for(\"react.suspense_list\"):\n60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.fundamental\"):60117,w=b?Symbol.for(\"react.responder\"):60118,x=b?Symbol.for(\"react.scope\"):60119;function y(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function z(a){return y(a)===m}\nexports.typeOf=y;exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;exports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===v||a.$$typeof===w||a.$$typeof===x)};exports.isAsyncMode=function(a){return z(a)||y(a)===l};exports.isConcurrentMode=z;exports.isContextConsumer=function(a){return y(a)===k};exports.isContextProvider=function(a){return y(a)===h};\nexports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return y(a)===n};exports.isFragment=function(a){return y(a)===e};exports.isLazy=function(a){return y(a)===t};exports.isMemo=function(a){return y(a)===r};exports.isPortal=function(a){return y(a)===d};exports.isProfiler=function(a){return y(a)===g};exports.isStrictMode=function(a){return y(a)===f};exports.isSuspense=function(a){return y(a)===p};\n","function _extends() {\n module.exports = _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nmodule.exports = _extends;","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","module.exports = Array.isArray || function (arr) {\n return Object.prototype.toString.call(arr) == '[object Array]';\n};\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n margin: 0\n },\n\n /* Styles applied to the root element if `variant=\"body2\"`. */\n body2: theme.typography.body2,\n\n /* Styles applied to the root element if `variant=\"body1\"`. */\n body1: theme.typography.body1,\n\n /* Styles applied to the root element if `variant=\"caption\"`. */\n caption: theme.typography.caption,\n\n /* Styles applied to the root element if `variant=\"button\"`. */\n button: theme.typography.button,\n\n /* Styles applied to the root element if `variant=\"h1\"`. */\n h1: theme.typography.h1,\n\n /* Styles applied to the root element if `variant=\"h2\"`. */\n h2: theme.typography.h2,\n\n /* Styles applied to the root element if `variant=\"h3\"`. */\n h3: theme.typography.h3,\n\n /* Styles applied to the root element if `variant=\"h4\"`. */\n h4: theme.typography.h4,\n\n /* Styles applied to the root element if `variant=\"h5\"`. */\n h5: theme.typography.h5,\n\n /* Styles applied to the root element if `variant=\"h6\"`. */\n h6: theme.typography.h6,\n\n /* Styles applied to the root element if `variant=\"subtitle1\"`. */\n subtitle1: theme.typography.subtitle1,\n\n /* Styles applied to the root element if `variant=\"subtitle2\"`. */\n subtitle2: theme.typography.subtitle2,\n\n /* Styles applied to the root element if `variant=\"overline\"`. */\n overline: theme.typography.overline,\n\n /* Styles applied to the root element if `variant=\"srOnly\"`. Only accessible to screen readers. */\n srOnly: {\n position: 'absolute',\n height: 1,\n width: 1,\n overflow: 'hidden'\n },\n\n /* Styles applied to the root element if `align=\"left\"`. */\n alignLeft: {\n textAlign: 'left'\n },\n\n /* Styles applied to the root element if `align=\"center\"`. */\n alignCenter: {\n textAlign: 'center'\n },\n\n /* Styles applied to the root element if `align=\"right\"`. */\n alignRight: {\n textAlign: 'right'\n },\n\n /* Styles applied to the root element if `align=\"justify\"`. */\n alignJustify: {\n textAlign: 'justify'\n },\n\n /* Styles applied to the root element if `nowrap={true}`. */\n noWrap: {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap'\n },\n\n /* Styles applied to the root element if `gutterBottom={true}`. */\n gutterBottom: {\n marginBottom: '0.35em'\n },\n\n /* Styles applied to the root element if `paragraph={true}`. */\n paragraph: {\n marginBottom: 16\n },\n\n /* Styles applied to the root element if `color=\"inherit\"`. */\n colorInherit: {\n color: 'inherit'\n },\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n color: theme.palette.primary.main\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n color: theme.palette.secondary.main\n },\n\n /* Styles applied to the root element if `color=\"textPrimary\"`. */\n colorTextPrimary: {\n color: theme.palette.text.primary\n },\n\n /* Styles applied to the root element if `color=\"textSecondary\"`. */\n colorTextSecondary: {\n color: theme.palette.text.secondary\n },\n\n /* Styles applied to the root element if `color=\"error\"`. */\n colorError: {\n color: theme.palette.error.main\n },\n\n /* Styles applied to the root element if `display=\"inline\"`. */\n displayInline: {\n display: 'inline'\n },\n\n /* Styles applied to the root element if `display=\"block\"`. */\n displayBlock: {\n display: 'block'\n }\n };\n};\nvar defaultVariantMapping = {\n h1: 'h1',\n h2: 'h2',\n h3: 'h3',\n h4: 'h4',\n h5: 'h5',\n h6: 'h6',\n subtitle1: 'h6',\n subtitle2: 'h6',\n body1: 'p',\n body2: 'p'\n};\nvar Typography = React.forwardRef(function Typography(props, ref) {\n var _props$align = props.align,\n align = _props$align === void 0 ? 'inherit' : _props$align,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'initial' : _props$color,\n component = props.component,\n _props$display = props.display,\n display = _props$display === void 0 ? 'initial' : _props$display,\n _props$gutterBottom = props.gutterBottom,\n gutterBottom = _props$gutterBottom === void 0 ? false : _props$gutterBottom,\n _props$noWrap = props.noWrap,\n noWrap = _props$noWrap === void 0 ? false : _props$noWrap,\n _props$paragraph = props.paragraph,\n paragraph = _props$paragraph === void 0 ? false : _props$paragraph,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'body1' : _props$variant,\n _props$variantMapping = props.variantMapping,\n variantMapping = _props$variantMapping === void 0 ? defaultVariantMapping : _props$variantMapping,\n other = _objectWithoutProperties(props, [\"align\", \"classes\", \"className\", \"color\", \"component\", \"display\", \"gutterBottom\", \"noWrap\", \"paragraph\", \"variant\", \"variantMapping\"]);\n\n var Component = component || (paragraph ? 'p' : variantMapping[variant] || defaultVariantMapping[variant]) || 'span';\n return React.createElement(Component, _extends({\n className: clsx(classes.root, className, variant !== 'inherit' && classes[variant], color !== 'initial' && classes[\"color\".concat(capitalize(color))], noWrap && classes.noWrap, gutterBottom && classes.gutterBottom, paragraph && classes.paragraph, align !== 'inherit' && classes[\"align\".concat(capitalize(align))], display !== 'initial' && classes[\"display\".concat(capitalize(display))]),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Typography.propTypes = {\n /**\n * Set the text-align on the component.\n */\n align: PropTypes.oneOf(['inherit', 'left', 'center', 'right', 'justify']),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['initial', 'inherit', 'primary', 'secondary', 'textPrimary', 'textSecondary', 'error']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n * Overrides the behavior of the `variantMapping` prop.\n */\n component: PropTypes.elementType,\n\n /**\n * Controls the display type\n */\n display: PropTypes.oneOf(['initial', 'block', 'inline']),\n\n /**\n * If `true`, the text will have a bottom margin.\n */\n gutterBottom: PropTypes.bool,\n\n /**\n * If `true`, the text will not wrap, but instead will truncate with a text overflow ellipsis.\n *\n * Note that text overflow can only happen with block or inline-block level elements\n * (the element needs to have a width in order to overflow).\n */\n noWrap: PropTypes.bool,\n\n /**\n * If `true`, the text will have a bottom margin.\n */\n paragraph: PropTypes.bool,\n\n /**\n * Applies the theme typography styles.\n */\n variant: PropTypes.oneOf(['h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'subtitle1', 'subtitle2', 'body1', 'body2', 'caption', 'button', 'overline', 'srOnly', 'inherit']),\n\n /**\n * The component maps the variant prop to a range of different DOM element types.\n * For instance, subtitle1 to `<h6>`.\n * If you wish to change that mapping, you can provide your own.\n * Alternatively, you can use the `component` prop.\n */\n variantMapping: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTypography'\n})(Typography);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { chainPropTypes } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport { fade } from '../styles/colorManipulator';\nimport ButtonBase from '../ButtonBase';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n textAlign: 'center',\n flex: '0 0 auto',\n fontSize: theme.typography.pxToRem(24),\n padding: 12,\n borderRadius: '50%',\n overflow: 'visible',\n // Explicitly set the default value to solve a bug on IE 11.\n color: theme.palette.action.active,\n transition: theme.transitions.create('background-color', {\n duration: theme.transitions.duration.shortest\n }),\n '&:hover': {\n backgroundColor: fade(theme.palette.action.active, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n },\n '&$disabled': {\n backgroundColor: 'transparent',\n color: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if `edge=\"start\"`. */\n edgeStart: {\n marginLeft: -12,\n '$sizeSmall&': {\n marginLeft: -3\n }\n },\n\n /* Styles applied to the root element if `edge=\"end\"`. */\n edgeEnd: {\n marginRight: -12,\n '$sizeSmall&': {\n marginRight: -3\n }\n },\n\n /* Styles applied to the root element if `color=\"inherit\"`. */\n colorInherit: {\n color: 'inherit'\n },\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `size=\"small\"`. */\n sizeSmall: {\n padding: 3,\n fontSize: theme.typography.pxToRem(18)\n },\n\n /* Styles applied to the children container element. */\n label: {\n width: '100%',\n display: 'flex',\n alignItems: 'inherit',\n justifyContent: 'inherit'\n }\n };\n};\n/**\n * Refer to the [Icons](/components/icons/) section of the documentation\n * regarding the available icon options.\n */\n\nvar IconButton = React.forwardRef(function IconButton(props, ref) {\n var _props$edge = props.edge,\n edge = _props$edge === void 0 ? false : _props$edge,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'default' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableFocusRi = props.disableFocusRipple,\n disableFocusRipple = _props$disableFocusRi === void 0 ? false : _props$disableFocusRi,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"edge\", \"children\", \"classes\", \"className\", \"color\", \"disabled\", \"disableFocusRipple\", \"size\"]);\n\n return React.createElement(ButtonBase, _extends({\n className: clsx(classes.root, className, color !== 'default' && classes[\"color\".concat(capitalize(color))], disabled && classes.disabled, {\n small: classes[\"size\".concat(capitalize(size))]\n }[size], {\n start: classes.edgeStart,\n end: classes.edgeEnd\n }[edge]),\n centerRipple: true,\n focusRipple: !disableFocusRipple,\n disabled: disabled,\n ref: ref\n }, other), React.createElement(\"span\", {\n className: classes.label\n }, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? IconButton.propTypes = {\n /**\n * The icon element.\n */\n children: chainPropTypes(PropTypes.node, function (props) {\n var found = React.Children.toArray(props.children).some(function (child) {\n return React.isValidElement(child) && child.props.onClick;\n });\n\n if (found) {\n return new Error(['Material-UI: you are providing an onClick event listener ' + 'to a child of a button element.', 'Firefox will never trigger the event.', 'You should move the onClick listener to the parent button element.', 'https://github.com/mui-org/material-ui/issues/13957'].join('\\n'));\n }\n\n return null;\n }),\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['default', 'inherit', 'primary', 'secondary']),\n\n /**\n * If `true`, the button will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the keyboard focus ripple will be disabled.\n * `disableRipple` must also be true.\n */\n disableFocusRipple: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * If given, uses a negative margin to counteract the padding on one\n * side (this is often helpful for aligning the left or right\n * side of the icon with content above or below, without ruining the border\n * size and shape).\n */\n edge: PropTypes.oneOf(['start', 'end', false]),\n\n /**\n * The size of the button.\n * `small` is equivalent to the dense button styling.\n */\n size: PropTypes.oneOf(['small', 'medium'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiIconButton'\n})(IconButton);","var _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nexport var isBrowser = (typeof window === \"undefined\" ? \"undefined\" : _typeof(window)) === \"object\" && (typeof document === \"undefined\" ? \"undefined\" : _typeof(document)) === 'object' && document.nodeType === 9;\n\nexport default isBrowser;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport isInBrowser from 'is-in-browser';\nimport warning from 'tiny-warning';\nimport _createClass from '@babel/runtime/helpers/esm/createClass';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport _assertThisInitialized from '@babel/runtime/helpers/esm/assertThisInitialized';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\n\nvar plainObjectConstrurctor = {}.constructor;\nfunction cloneStyle(style) {\n if (style == null || typeof style !== 'object') return style;\n if (Array.isArray(style)) return style.map(cloneStyle);\n if (style.constructor !== plainObjectConstrurctor) return style;\n var newStyle = {};\n\n for (var name in style) {\n newStyle[name] = cloneStyle(style[name]);\n }\n\n return newStyle;\n}\n\n/**\n * Create a rule instance.\n */\n\nfunction createRule(name, decl, options) {\n if (name === void 0) {\n name = 'unnamed';\n }\n\n var jss = options.jss;\n var declCopy = cloneStyle(decl);\n var rule = jss.plugins.onCreateRule(name, declCopy, options);\n if (rule) return rule; // It is an at-rule and it has no instance.\n\n if (name[0] === '@') {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Unknown rule \" + name) : void 0;\n }\n\n return null;\n}\n\nvar join = function join(value, by) {\n var result = '';\n\n for (var i = 0; i < value.length; i++) {\n // Remove !important from the value, it will be readded later.\n if (value[i] === '!important') break;\n if (result) result += by;\n result += value[i];\n }\n\n return result;\n};\n/**\n * Converts array values to string.\n *\n * `margin: [['5px', '10px']]` > `margin: 5px 10px;`\n * `border: ['1px', '2px']` > `border: 1px, 2px;`\n * `margin: [['5px', '10px'], '!important']` > `margin: 5px 10px !important;`\n * `color: ['red', !important]` > `color: red !important;`\n */\n\n\nfunction toCssValue(value, ignoreImportant) {\n if (ignoreImportant === void 0) {\n ignoreImportant = false;\n }\n\n if (!Array.isArray(value)) return value;\n var cssValue = ''; // Support space separated values via `[['5px', '10px']]`.\n\n if (Array.isArray(value[0])) {\n for (var i = 0; i < value.length; i++) {\n if (value[i] === '!important') break;\n if (cssValue) cssValue += ', ';\n cssValue += join(value[i], ' ');\n }\n } else cssValue = join(value, ', '); // Add !important, because it was ignored.\n\n\n if (!ignoreImportant && value[value.length - 1] === '!important') {\n cssValue += ' !important';\n }\n\n return cssValue;\n}\n\n/**\n * Indent a string.\n * http://jsperf.com/array-join-vs-for\n */\nfunction indentStr(str, indent) {\n var result = '';\n\n for (var index = 0; index < indent; index++) {\n result += ' ';\n }\n\n return result + str;\n}\n/**\n * Converts a Rule to CSS string.\n */\n\n\nfunction toCss(selector, style, options) {\n if (options === void 0) {\n options = {};\n }\n\n var result = '';\n if (!style) return result;\n var _options = options,\n _options$indent = _options.indent,\n indent = _options$indent === void 0 ? 0 : _options$indent;\n var fallbacks = style.fallbacks;\n if (selector) indent++; // Apply fallbacks first.\n\n if (fallbacks) {\n // Array syntax {fallbacks: [{prop: value}]}\n if (Array.isArray(fallbacks)) {\n for (var index = 0; index < fallbacks.length; index++) {\n var fallback = fallbacks[index];\n\n for (var prop in fallback) {\n var value = fallback[prop];\n\n if (value != null) {\n if (result) result += '\\n';\n result += \"\" + indentStr(prop + \": \" + toCssValue(value) + \";\", indent);\n }\n }\n }\n } else {\n // Object syntax {fallbacks: {prop: value}}\n for (var _prop in fallbacks) {\n var _value = fallbacks[_prop];\n\n if (_value != null) {\n if (result) result += '\\n';\n result += \"\" + indentStr(_prop + \": \" + toCssValue(_value) + \";\", indent);\n }\n }\n }\n }\n\n for (var _prop2 in style) {\n var _value2 = style[_prop2];\n\n if (_value2 != null && _prop2 !== 'fallbacks') {\n if (result) result += '\\n';\n result += \"\" + indentStr(_prop2 + \": \" + toCssValue(_value2) + \";\", indent);\n }\n } // Allow empty style in this case, because properties will be added dynamically.\n\n\n if (!result && !options.allowEmpty) return result; // When rule is being stringified before selector was defined.\n\n if (!selector) return result;\n indent--;\n if (result) result = \"\\n\" + result + \"\\n\";\n return indentStr(selector + \" {\" + result, indent) + indentStr('}', indent);\n}\n\nvar escapeRegex = /([[\\].#*$><+~=|^:(),\"'`\\s])/g;\nvar nativeEscape = typeof CSS !== 'undefined' && CSS.escape;\nvar escape = (function (str) {\n return nativeEscape ? nativeEscape(str) : str.replace(escapeRegex, '\\\\$1');\n});\n\nvar BaseStyleRule =\n/*#__PURE__*/\nfunction () {\n function BaseStyleRule(key, style, options) {\n this.type = 'style';\n this.key = void 0;\n this.isProcessed = false;\n this.style = void 0;\n this.renderer = void 0;\n this.renderable = void 0;\n this.options = void 0;\n var sheet = options.sheet,\n Renderer = options.Renderer;\n this.key = key;\n this.options = options;\n this.style = style;\n if (sheet) this.renderer = sheet.renderer;else if (Renderer) this.renderer = new Renderer();\n }\n /**\n * Get or set a style property.\n */\n\n\n var _proto = BaseStyleRule.prototype;\n\n _proto.prop = function prop(name, value, options) {\n // It's a getter.\n if (value === undefined) return this.style[name]; // Don't do anything if the value has not changed.\n\n var force = options ? options.force : false;\n if (!force && this.style[name] === value) return this;\n var newValue = value;\n\n if (!options || options.process !== false) {\n newValue = this.options.jss.plugins.onChangeValue(value, name, this);\n }\n\n var isEmpty = newValue == null || newValue === false;\n var isDefined = name in this.style; // Value is empty and wasn't defined before.\n\n if (isEmpty && !isDefined && !force) return this; // We are going to remove this value.\n\n var remove = isEmpty && isDefined;\n if (remove) delete this.style[name];else this.style[name] = newValue; // Renderable is defined if StyleSheet option `link` is true.\n\n if (this.renderable && this.renderer) {\n if (remove) this.renderer.removeProperty(this.renderable, name);else this.renderer.setProperty(this.renderable, name, newValue);\n return this;\n }\n\n var sheet = this.options.sheet;\n\n if (sheet && sheet.attached) {\n process.env.NODE_ENV !== \"production\" ? warning(false, '[JSS] Rule is not linked. Missing sheet option \"link: true\".') : void 0;\n }\n\n return this;\n };\n\n return BaseStyleRule;\n}();\nvar StyleRule =\n/*#__PURE__*/\nfunction (_BaseStyleRule) {\n _inheritsLoose(StyleRule, _BaseStyleRule);\n\n function StyleRule(key, style, options) {\n var _this;\n\n _this = _BaseStyleRule.call(this, key, style, options) || this;\n _this.selectorText = void 0;\n _this.id = void 0;\n _this.renderable = void 0;\n var selector = options.selector,\n scoped = options.scoped,\n sheet = options.sheet,\n generateId = options.generateId;\n\n if (selector) {\n _this.selectorText = selector;\n } else if (scoped !== false) {\n _this.id = generateId(_assertThisInitialized(_assertThisInitialized(_this)), sheet);\n _this.selectorText = \".\" + escape(_this.id);\n }\n\n return _this;\n }\n /**\n * Set selector string.\n * Attention: use this with caution. Most browsers didn't implement\n * selectorText setter, so this may result in rerendering of entire Style Sheet.\n */\n\n\n var _proto2 = StyleRule.prototype;\n\n /**\n * Apply rule to an element inline.\n */\n _proto2.applyTo = function applyTo(renderable) {\n var renderer = this.renderer;\n\n if (renderer) {\n var json = this.toJSON();\n\n for (var prop in json) {\n renderer.setProperty(renderable, prop, json[prop]);\n }\n }\n\n return this;\n }\n /**\n * Returns JSON representation of the rule.\n * Fallbacks are not supported.\n * Useful for inline styles.\n */\n ;\n\n _proto2.toJSON = function toJSON() {\n var json = {};\n\n for (var prop in this.style) {\n var value = this.style[prop];\n if (typeof value !== 'object') json[prop] = value;else if (Array.isArray(value)) json[prop] = toCssValue(value);\n }\n\n return json;\n }\n /**\n * Generates a CSS string.\n */\n ;\n\n _proto2.toString = function toString(options) {\n var sheet = this.options.sheet;\n var link = sheet ? sheet.options.link : false;\n var opts = link ? _extends({}, options, {\n allowEmpty: true\n }) : options;\n return toCss(this.selectorText, this.style, opts);\n };\n\n _createClass(StyleRule, [{\n key: \"selector\",\n set: function set(selector) {\n if (selector === this.selectorText) return;\n this.selectorText = selector;\n var renderer = this.renderer,\n renderable = this.renderable;\n if (!renderable || !renderer) return;\n var hasChanged = renderer.setSelector(renderable, selector); // If selector setter is not implemented, rerender the rule.\n\n if (!hasChanged) {\n renderer.replaceRule(renderable, this);\n }\n }\n /**\n * Get selector string.\n */\n ,\n get: function get() {\n return this.selectorText;\n }\n }]);\n\n return StyleRule;\n}(BaseStyleRule);\nvar pluginStyleRule = {\n onCreateRule: function onCreateRule(name, style, options) {\n if (name[0] === '@' || options.parent && options.parent.type === 'keyframes') {\n return null;\n }\n\n return new StyleRule(name, style, options);\n }\n};\n\nvar defaultToStringOptions = {\n indent: 1,\n children: true\n};\nvar atRegExp = /@([\\w-]+)/;\n/**\n * Conditional rule for @media, @supports\n */\n\nvar ConditionalRule =\n/*#__PURE__*/\nfunction () {\n function ConditionalRule(key, styles, options) {\n this.type = 'conditional';\n this.at = void 0;\n this.key = void 0;\n this.query = void 0;\n this.rules = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key; // Key might contain a unique suffix in case the `name` passed by user was duplicate.\n\n this.query = options.name;\n var atMatch = key.match(atRegExp);\n this.at = atMatch ? atMatch[1] : 'unknown';\n this.options = options;\n this.rules = new RuleList(_extends({}, options, {\n parent: this\n }));\n\n for (var name in styles) {\n this.rules.add(name, styles[name]);\n }\n\n this.rules.process();\n }\n /**\n * Get a rule.\n */\n\n\n var _proto = ConditionalRule.prototype;\n\n _proto.getRule = function getRule(name) {\n return this.rules.get(name);\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.rules.indexOf(rule);\n }\n /**\n * Create and register rule, run plugins.\n */\n ;\n\n _proto.addRule = function addRule(name, style, options) {\n var rule = this.rules.add(name, style, options);\n if (!rule) return null;\n this.options.jss.plugins.onProcessRule(rule);\n return rule;\n }\n /**\n * Generates a CSS string.\n */\n ;\n\n _proto.toString = function toString(options) {\n if (options === void 0) {\n options = defaultToStringOptions;\n }\n\n if (options.indent == null) options.indent = defaultToStringOptions.indent;\n if (options.children == null) options.children = defaultToStringOptions.children;\n\n if (options.children === false) {\n return this.query + \" {}\";\n }\n\n var children = this.rules.toString(options);\n return children ? this.query + \" {\\n\" + children + \"\\n}\" : '';\n };\n\n return ConditionalRule;\n}();\nvar keyRegExp = /@media|@supports\\s+/;\nvar pluginConditionalRule = {\n onCreateRule: function onCreateRule(key, styles, options) {\n return keyRegExp.test(key) ? new ConditionalRule(key, styles, options) : null;\n }\n};\n\nvar defaultToStringOptions$1 = {\n indent: 1,\n children: true\n};\nvar nameRegExp = /@keyframes\\s+([\\w-]+)/;\n/**\n * Rule for @keyframes\n */\n\nvar KeyframesRule =\n/*#__PURE__*/\nfunction () {\n function KeyframesRule(key, frames, options) {\n this.type = 'keyframes';\n this.at = '@keyframes';\n this.key = void 0;\n this.name = void 0;\n this.id = void 0;\n this.rules = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n var nameMatch = key.match(nameRegExp);\n\n if (nameMatch && nameMatch[1]) {\n this.name = nameMatch[1];\n } else {\n this.name = 'noname';\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Bad keyframes name \" + key) : void 0;\n }\n\n this.key = this.type + \"-\" + this.name;\n this.options = options;\n var scoped = options.scoped,\n sheet = options.sheet,\n generateId = options.generateId;\n this.id = scoped === false ? this.name : escape(generateId(this, sheet));\n this.rules = new RuleList(_extends({}, options, {\n parent: this\n }));\n\n for (var name in frames) {\n this.rules.add(name, frames[name], _extends({}, options, {\n parent: this\n }));\n }\n\n this.rules.process();\n }\n /**\n * Generates a CSS string.\n */\n\n\n var _proto = KeyframesRule.prototype;\n\n _proto.toString = function toString(options) {\n if (options === void 0) {\n options = defaultToStringOptions$1;\n }\n\n if (options.indent == null) options.indent = defaultToStringOptions$1.indent;\n if (options.children == null) options.children = defaultToStringOptions$1.children;\n\n if (options.children === false) {\n return this.at + \" \" + this.id + \" {}\";\n }\n\n var children = this.rules.toString(options);\n if (children) children = \"\\n\" + children + \"\\n\";\n return this.at + \" \" + this.id + \" {\" + children + \"}\";\n };\n\n return KeyframesRule;\n}();\nvar keyRegExp$1 = /@keyframes\\s+/;\nvar refRegExp = /\\$([\\w-]+)/g;\n\nvar findReferencedKeyframe = function findReferencedKeyframe(val, keyframes) {\n if (typeof val === 'string') {\n return val.replace(refRegExp, function (match, name) {\n if (name in keyframes) {\n return keyframes[name];\n }\n\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Referenced keyframes rule \\\"\" + name + \"\\\" is not defined.\") : void 0;\n return match;\n });\n }\n\n return val;\n};\n/**\n * Replace the reference for a animation name.\n */\n\n\nvar replaceRef = function replaceRef(style, prop, keyframes) {\n var value = style[prop];\n var refKeyframe = findReferencedKeyframe(value, keyframes);\n\n if (refKeyframe !== value) {\n style[prop] = refKeyframe;\n }\n};\n\nvar plugin = {\n onCreateRule: function onCreateRule(key, frames, options) {\n return typeof key === 'string' && keyRegExp$1.test(key) ? new KeyframesRule(key, frames, options) : null;\n },\n // Animation name ref replacer.\n onProcessStyle: function onProcessStyle(style, rule, sheet) {\n if (rule.type !== 'style' || !sheet) return style;\n if ('animation-name' in style) replaceRef(style, 'animation-name', sheet.keyframes);\n if ('animation' in style) replaceRef(style, 'animation', sheet.keyframes);\n return style;\n },\n onChangeValue: function onChangeValue(val, prop, rule) {\n var sheet = rule.options.sheet;\n\n if (!sheet) {\n return val;\n }\n\n switch (prop) {\n case 'animation':\n return findReferencedKeyframe(val, sheet.keyframes);\n\n case 'animation-name':\n return findReferencedKeyframe(val, sheet.keyframes);\n\n default:\n return val;\n }\n }\n};\n\nvar KeyframeRule =\n/*#__PURE__*/\nfunction (_BaseStyleRule) {\n _inheritsLoose(KeyframeRule, _BaseStyleRule);\n\n function KeyframeRule() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _BaseStyleRule.call.apply(_BaseStyleRule, [this].concat(args)) || this;\n _this.renderable = void 0;\n return _this;\n }\n\n var _proto = KeyframeRule.prototype;\n\n /**\n * Generates a CSS string.\n */\n _proto.toString = function toString(options) {\n var sheet = this.options.sheet;\n var link = sheet ? sheet.options.link : false;\n var opts = link ? _extends({}, options, {\n allowEmpty: true\n }) : options;\n return toCss(this.key, this.style, opts);\n };\n\n return KeyframeRule;\n}(BaseStyleRule);\nvar pluginKeyframeRule = {\n onCreateRule: function onCreateRule(key, style, options) {\n if (options.parent && options.parent.type === 'keyframes') {\n return new KeyframeRule(key, style, options);\n }\n\n return null;\n }\n};\n\nvar FontFaceRule =\n/*#__PURE__*/\nfunction () {\n function FontFaceRule(key, style, options) {\n this.type = 'font-face';\n this.at = '@font-face';\n this.key = void 0;\n this.style = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key;\n this.style = style;\n this.options = options;\n }\n /**\n * Generates a CSS string.\n */\n\n\n var _proto = FontFaceRule.prototype;\n\n _proto.toString = function toString(options) {\n if (Array.isArray(this.style)) {\n var str = '';\n\n for (var index = 0; index < this.style.length; index++) {\n str += toCss(this.key, this.style[index]);\n if (this.style[index + 1]) str += '\\n';\n }\n\n return str;\n }\n\n return toCss(this.key, this.style, options);\n };\n\n return FontFaceRule;\n}();\nvar pluginFontFaceRule = {\n onCreateRule: function onCreateRule(key, style, options) {\n return key === '@font-face' ? new FontFaceRule(key, style, options) : null;\n }\n};\n\nvar ViewportRule =\n/*#__PURE__*/\nfunction () {\n function ViewportRule(key, style, options) {\n this.type = 'viewport';\n this.at = '@viewport';\n this.key = void 0;\n this.style = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key;\n this.style = style;\n this.options = options;\n }\n /**\n * Generates a CSS string.\n */\n\n\n var _proto = ViewportRule.prototype;\n\n _proto.toString = function toString(options) {\n return toCss(this.key, this.style, options);\n };\n\n return ViewportRule;\n}();\nvar pluginViewportRule = {\n onCreateRule: function onCreateRule(key, style, options) {\n return key === '@viewport' || key === '@-ms-viewport' ? new ViewportRule(key, style, options) : null;\n }\n};\n\nvar SimpleRule =\n/*#__PURE__*/\nfunction () {\n function SimpleRule(key, value, options) {\n this.type = 'simple';\n this.key = void 0;\n this.value = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key;\n this.value = value;\n this.options = options;\n }\n /**\n * Generates a CSS string.\n */\n // eslint-disable-next-line no-unused-vars\n\n\n var _proto = SimpleRule.prototype;\n\n _proto.toString = function toString(options) {\n if (Array.isArray(this.value)) {\n var str = '';\n\n for (var index = 0; index < this.value.length; index++) {\n str += this.key + \" \" + this.value[index] + \";\";\n if (this.value[index + 1]) str += '\\n';\n }\n\n return str;\n }\n\n return this.key + \" \" + this.value + \";\";\n };\n\n return SimpleRule;\n}();\nvar keysMap = {\n '@charset': true,\n '@import': true,\n '@namespace': true\n};\nvar pluginSimpleRule = {\n onCreateRule: function onCreateRule(key, value, options) {\n return key in keysMap ? new SimpleRule(key, value, options) : null;\n }\n};\n\nvar plugins = [pluginStyleRule, pluginConditionalRule, plugin, pluginKeyframeRule, pluginFontFaceRule, pluginViewportRule, pluginSimpleRule];\n\nvar defaultUpdateOptions = {\n process: true\n};\nvar forceUpdateOptions = {\n force: true,\n process: true\n /**\n * Contains rules objects and allows adding/removing etc.\n * Is used for e.g. by `StyleSheet` or `ConditionalRule`.\n */\n\n};\n\nvar RuleList =\n/*#__PURE__*/\nfunction () {\n // Rules registry for access by .get() method.\n // It contains the same rule registered by name and by selector.\n // Original styles object.\n // Used to ensure correct rules order.\n function RuleList(options) {\n this.map = {};\n this.raw = {};\n this.index = [];\n this.counter = 0;\n this.options = void 0;\n this.classes = void 0;\n this.keyframes = void 0;\n this.options = options;\n this.classes = options.classes;\n this.keyframes = options.keyframes;\n }\n /**\n * Create and register rule.\n *\n * Will not render after Style Sheet was rendered the first time.\n */\n\n\n var _proto = RuleList.prototype;\n\n _proto.add = function add(name, decl, ruleOptions) {\n var _this$options = this.options,\n parent = _this$options.parent,\n sheet = _this$options.sheet,\n jss = _this$options.jss,\n Renderer = _this$options.Renderer,\n generateId = _this$options.generateId,\n scoped = _this$options.scoped;\n\n var options = _extends({\n classes: this.classes,\n parent: parent,\n sheet: sheet,\n jss: jss,\n Renderer: Renderer,\n generateId: generateId,\n scoped: scoped,\n name: name\n }, ruleOptions); // When user uses .createStyleSheet(), duplicate names are not possible, but\n // `sheet.addRule()` opens the door for any duplicate rule name. When this happens\n // we need to make the key unique within this RuleList instance scope.\n\n\n var key = name;\n\n if (name in this.raw) {\n key = name + \"-d\" + this.counter++;\n } // We need to save the original decl before creating the rule\n // because cache plugin needs to use it as a key to return a cached rule.\n\n\n this.raw[key] = decl;\n\n if (key in this.classes) {\n // E.g. rules inside of @media container\n options.selector = \".\" + escape(this.classes[key]);\n }\n\n var rule = createRule(key, decl, options);\n if (!rule) return null;\n this.register(rule);\n var index = options.index === undefined ? this.index.length : options.index;\n this.index.splice(index, 0, rule);\n return rule;\n }\n /**\n * Get a rule.\n */\n ;\n\n _proto.get = function get(name) {\n return this.map[name];\n }\n /**\n * Delete a rule.\n */\n ;\n\n _proto.remove = function remove(rule) {\n this.unregister(rule);\n delete this.raw[rule.key];\n this.index.splice(this.index.indexOf(rule), 1);\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.index.indexOf(rule);\n }\n /**\n * Run `onProcessRule()` plugins on every rule.\n */\n ;\n\n _proto.process = function process() {\n var plugins$$1 = this.options.jss.plugins; // We need to clone array because if we modify the index somewhere else during a loop\n // we end up with very hard-to-track-down side effects.\n\n this.index.slice(0).forEach(plugins$$1.onProcessRule, plugins$$1);\n }\n /**\n * Register a rule in `.map`, `.classes` and `.keyframes` maps.\n */\n ;\n\n _proto.register = function register(rule) {\n this.map[rule.key] = rule;\n\n if (rule instanceof StyleRule) {\n this.map[rule.selector] = rule;\n if (rule.id) this.classes[rule.key] = rule.id;\n } else if (rule instanceof KeyframesRule && this.keyframes) {\n this.keyframes[rule.name] = rule.id;\n }\n }\n /**\n * Unregister a rule.\n */\n ;\n\n _proto.unregister = function unregister(rule) {\n delete this.map[rule.key];\n\n if (rule instanceof StyleRule) {\n delete this.map[rule.selector];\n delete this.classes[rule.key];\n } else if (rule instanceof KeyframesRule) {\n delete this.keyframes[rule.name];\n }\n }\n /**\n * Update the function values with a new data.\n */\n ;\n\n _proto.update = function update() {\n var name;\n var data;\n var options;\n\n if (typeof (arguments.length <= 0 ? undefined : arguments[0]) === 'string') {\n name = arguments.length <= 0 ? undefined : arguments[0]; // $FlowFixMe\n\n data = arguments.length <= 1 ? undefined : arguments[1]; // $FlowFixMe\n\n options = arguments.length <= 2 ? undefined : arguments[2];\n } else {\n data = arguments.length <= 0 ? undefined : arguments[0]; // $FlowFixMe\n\n options = arguments.length <= 1 ? undefined : arguments[1];\n name = null;\n }\n\n if (name) {\n this.updateOne(this.map[name], data, options);\n } else {\n for (var index = 0; index < this.index.length; index++) {\n this.updateOne(this.index[index], data, options);\n }\n }\n }\n /**\n * Execute plugins, update rule props.\n */\n ;\n\n _proto.updateOne = function updateOne(rule, data, options) {\n if (options === void 0) {\n options = defaultUpdateOptions;\n }\n\n var _this$options2 = this.options,\n plugins$$1 = _this$options2.jss.plugins,\n sheet = _this$options2.sheet; // It is a rules container like for e.g. ConditionalRule.\n\n if (rule.rules instanceof RuleList) {\n rule.rules.update(data, options);\n return;\n }\n\n var styleRule = rule;\n var style = styleRule.style;\n plugins$$1.onUpdate(data, rule, sheet, options); // We rely on a new `style` ref in case it was mutated during onUpdate hook.\n\n if (options.process && style && style !== styleRule.style) {\n // We need to run the plugins in case new `style` relies on syntax plugins.\n plugins$$1.onProcessStyle(styleRule.style, styleRule, sheet); // Update and add props.\n\n for (var prop in styleRule.style) {\n var nextValue = styleRule.style[prop];\n var prevValue = style[prop]; // We need to use `force: true` because `rule.style` has been updated during onUpdate hook, so `rule.prop()` will not update the CSSOM rule.\n // We do this comparison to avoid unneeded `rule.prop()` calls, since we have the old `style` object here.\n\n if (nextValue !== prevValue) {\n styleRule.prop(prop, nextValue, forceUpdateOptions);\n }\n } // Remove props.\n\n\n for (var _prop in style) {\n var _nextValue = styleRule.style[_prop];\n var _prevValue = style[_prop]; // We need to use `force: true` because `rule.style` has been updated during onUpdate hook, so `rule.prop()` will not update the CSSOM rule.\n // We do this comparison to avoid unneeded `rule.prop()` calls, since we have the old `style` object here.\n\n if (_nextValue == null && _nextValue !== _prevValue) {\n styleRule.prop(_prop, null, forceUpdateOptions);\n }\n }\n }\n }\n /**\n * Convert rules to a CSS string.\n */\n ;\n\n _proto.toString = function toString(options) {\n var str = '';\n var sheet = this.options.sheet;\n var link = sheet ? sheet.options.link : false;\n\n for (var index = 0; index < this.index.length; index++) {\n var rule = this.index[index];\n var css = rule.toString(options); // No need to render an empty rule.\n\n if (!css && !link) continue;\n if (str) str += '\\n';\n str += css;\n }\n\n return str;\n };\n\n return RuleList;\n}();\n\nvar StyleSheet =\n/*#__PURE__*/\nfunction () {\n function StyleSheet(styles, options) {\n this.options = void 0;\n this.deployed = void 0;\n this.attached = void 0;\n this.rules = void 0;\n this.renderer = void 0;\n this.classes = void 0;\n this.keyframes = void 0;\n this.queue = void 0;\n this.attached = false;\n this.deployed = false;\n this.classes = {};\n this.keyframes = {};\n this.options = _extends({}, options, {\n sheet: this,\n parent: this,\n classes: this.classes,\n keyframes: this.keyframes\n });\n\n if (options.Renderer) {\n this.renderer = new options.Renderer(this);\n }\n\n this.rules = new RuleList(this.options);\n\n for (var name in styles) {\n this.rules.add(name, styles[name]);\n }\n\n this.rules.process();\n }\n /**\n * Attach renderable to the render tree.\n */\n\n\n var _proto = StyleSheet.prototype;\n\n _proto.attach = function attach() {\n if (this.attached) return this;\n if (this.renderer) this.renderer.attach();\n this.attached = true; // Order is important, because we can't use insertRule API if style element is not attached.\n\n if (!this.deployed) this.deploy();\n return this;\n }\n /**\n * Remove renderable from render tree.\n */\n ;\n\n _proto.detach = function detach() {\n if (!this.attached) return this;\n if (this.renderer) this.renderer.detach();\n this.attached = false;\n return this;\n }\n /**\n * Add a rule to the current stylesheet.\n * Will insert a rule also after the stylesheet has been rendered first time.\n */\n ;\n\n _proto.addRule = function addRule(name, decl, options) {\n var queue = this.queue; // Plugins can create rules.\n // In order to preserve the right order, we need to queue all `.addRule` calls,\n // which happen after the first `rules.add()` call.\n\n if (this.attached && !queue) this.queue = [];\n var rule = this.rules.add(name, decl, options);\n if (!rule) return null;\n this.options.jss.plugins.onProcessRule(rule);\n\n if (this.attached) {\n if (!this.deployed) return rule; // Don't insert rule directly if there is no stringified version yet.\n // It will be inserted all together when .attach is called.\n\n if (queue) queue.push(rule);else {\n this.insertRule(rule);\n\n if (this.queue) {\n this.queue.forEach(this.insertRule, this);\n this.queue = undefined;\n }\n }\n return rule;\n } // We can't add rules to a detached style node.\n // We will redeploy the sheet once user will attach it.\n\n\n this.deployed = false;\n return rule;\n }\n /**\n * Insert rule into the StyleSheet\n */\n ;\n\n _proto.insertRule = function insertRule(rule) {\n if (this.renderer) {\n this.renderer.insertRule(rule);\n }\n }\n /**\n * Create and add rules.\n * Will render also after Style Sheet was rendered the first time.\n */\n ;\n\n _proto.addRules = function addRules(styles, options) {\n var added = [];\n\n for (var name in styles) {\n var rule = this.addRule(name, styles[name], options);\n if (rule) added.push(rule);\n }\n\n return added;\n }\n /**\n * Get a rule by name.\n */\n ;\n\n _proto.getRule = function getRule(name) {\n return this.rules.get(name);\n }\n /**\n * Delete a rule by name.\n * Returns `true`: if rule has been deleted from the DOM.\n */\n ;\n\n _proto.deleteRule = function deleteRule(name) {\n var rule = typeof name === 'object' ? name : this.rules.get(name);\n if (!rule) return false;\n this.rules.remove(rule);\n\n if (this.attached && rule.renderable && this.renderer) {\n return this.renderer.deleteRule(rule.renderable);\n }\n\n return true;\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.rules.indexOf(rule);\n }\n /**\n * Deploy pure CSS string to a renderable.\n */\n ;\n\n _proto.deploy = function deploy() {\n if (this.renderer) this.renderer.deploy();\n this.deployed = true;\n return this;\n }\n /**\n * Update the function values with a new data.\n */\n ;\n\n _proto.update = function update() {\n var _this$rules;\n\n (_this$rules = this.rules).update.apply(_this$rules, arguments);\n\n return this;\n }\n /**\n * Updates a single rule.\n */\n ;\n\n _proto.updateOne = function updateOne(rule, data, options) {\n this.rules.updateOne(rule, data, options);\n return this;\n }\n /**\n * Convert rules to a CSS string.\n */\n ;\n\n _proto.toString = function toString(options) {\n return this.rules.toString(options);\n };\n\n return StyleSheet;\n}();\n\nvar PluginsRegistry =\n/*#__PURE__*/\nfunction () {\n function PluginsRegistry() {\n this.plugins = {\n internal: [],\n external: []\n };\n this.registry = void 0;\n }\n\n var _proto = PluginsRegistry.prototype;\n\n /**\n * Call `onCreateRule` hooks and return an object if returned by a hook.\n */\n _proto.onCreateRule = function onCreateRule(name, decl, options) {\n for (var i = 0; i < this.registry.onCreateRule.length; i++) {\n var rule = this.registry.onCreateRule[i](name, decl, options);\n if (rule) return rule;\n }\n\n return null;\n }\n /**\n * Call `onProcessRule` hooks.\n */\n ;\n\n _proto.onProcessRule = function onProcessRule(rule) {\n if (rule.isProcessed) return;\n var sheet = rule.options.sheet;\n\n for (var i = 0; i < this.registry.onProcessRule.length; i++) {\n this.registry.onProcessRule[i](rule, sheet);\n }\n\n if (rule.style) this.onProcessStyle(rule.style, rule, sheet);\n rule.isProcessed = true;\n }\n /**\n * Call `onProcessStyle` hooks.\n */\n ;\n\n _proto.onProcessStyle = function onProcessStyle(style, rule, sheet) {\n for (var i = 0; i < this.registry.onProcessStyle.length; i++) {\n // $FlowFixMe\n rule.style = this.registry.onProcessStyle[i](rule.style, rule, sheet);\n }\n }\n /**\n * Call `onProcessSheet` hooks.\n */\n ;\n\n _proto.onProcessSheet = function onProcessSheet(sheet) {\n for (var i = 0; i < this.registry.onProcessSheet.length; i++) {\n this.registry.onProcessSheet[i](sheet);\n }\n }\n /**\n * Call `onUpdate` hooks.\n */\n ;\n\n _proto.onUpdate = function onUpdate(data, rule, sheet, options) {\n for (var i = 0; i < this.registry.onUpdate.length; i++) {\n this.registry.onUpdate[i](data, rule, sheet, options);\n }\n }\n /**\n * Call `onChangeValue` hooks.\n */\n ;\n\n _proto.onChangeValue = function onChangeValue(value, prop, rule) {\n var processedValue = value;\n\n for (var i = 0; i < this.registry.onChangeValue.length; i++) {\n processedValue = this.registry.onChangeValue[i](processedValue, prop, rule);\n }\n\n return processedValue;\n }\n /**\n * Register a plugin.\n */\n ;\n\n _proto.use = function use(newPlugin, options) {\n if (options === void 0) {\n options = {\n queue: 'external'\n };\n }\n\n var plugins = this.plugins[options.queue]; // Avoids applying same plugin twice, at least based on ref.\n\n if (plugins.indexOf(newPlugin) !== -1) {\n return;\n }\n\n plugins.push(newPlugin);\n this.registry = [].concat(this.plugins.external, this.plugins.internal).reduce(function (registry, plugin) {\n for (var name in plugin) {\n if (name in registry) {\n registry[name].push(plugin[name]);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Unknown hook \\\"\" + name + \"\\\".\") : void 0;\n }\n }\n\n return registry;\n }, {\n onCreateRule: [],\n onProcessRule: [],\n onProcessStyle: [],\n onProcessSheet: [],\n onChangeValue: [],\n onUpdate: []\n });\n };\n\n return PluginsRegistry;\n}();\n\n/**\n * Sheets registry to access them all at one place.\n */\nvar SheetsRegistry =\n/*#__PURE__*/\nfunction () {\n function SheetsRegistry() {\n this.registry = [];\n }\n\n var _proto = SheetsRegistry.prototype;\n\n /**\n * Register a Style Sheet.\n */\n _proto.add = function add(sheet) {\n var registry = this.registry;\n var index = sheet.options.index;\n if (registry.indexOf(sheet) !== -1) return;\n\n if (registry.length === 0 || index >= this.index) {\n registry.push(sheet);\n return;\n } // Find a position.\n\n\n for (var i = 0; i < registry.length; i++) {\n if (registry[i].options.index > index) {\n registry.splice(i, 0, sheet);\n return;\n }\n }\n }\n /**\n * Reset the registry.\n */\n ;\n\n _proto.reset = function reset() {\n this.registry = [];\n }\n /**\n * Remove a Style Sheet.\n */\n ;\n\n _proto.remove = function remove(sheet) {\n var index = this.registry.indexOf(sheet);\n this.registry.splice(index, 1);\n }\n /**\n * Convert all attached sheets to a CSS string.\n */\n ;\n\n _proto.toString = function toString(_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n attached = _ref.attached,\n options = _objectWithoutPropertiesLoose(_ref, [\"attached\"]);\n\n var css = '';\n\n for (var i = 0; i < this.registry.length; i++) {\n var sheet = this.registry[i];\n\n if (attached != null && sheet.attached !== attached) {\n continue;\n }\n\n if (css) css += '\\n';\n css += sheet.toString(options);\n }\n\n return css;\n };\n\n _createClass(SheetsRegistry, [{\n key: \"index\",\n\n /**\n * Current highest index number.\n */\n get: function get() {\n return this.registry.length === 0 ? 0 : this.registry[this.registry.length - 1].options.index;\n }\n }]);\n\n return SheetsRegistry;\n}();\n\n/**\n * This is a global sheets registry. Only DomRenderer will add sheets to it.\n * On the server one should use an own SheetsRegistry instance and add the\n * sheets to it, because you need to make sure to create a new registry for\n * each request in order to not leak sheets across requests.\n */\n\nvar sheets = new SheetsRegistry();\n\n/* eslint-disable */\n// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar globalThis = typeof window != 'undefined' && window.Math == Math ? window : typeof self != 'undefined' && self.Math == Math ? self : Function('return this')();\n\nvar ns = '2f1acc6c3a606b082e5eef5e54414ffb';\nif (globalThis[ns] == null) globalThis[ns] = 0; // Bundle may contain multiple JSS versions at the same time. In order to identify\n// the current version with just one short number and use it for classes generation\n// we use a counter. Also it is more accurate, because user can manually reevaluate\n// the module.\n\nvar moduleId = globalThis[ns]++;\n\nvar maxRules = 1e10;\n\n/**\n * Returns a function which generates unique class names based on counters.\n * When new generator function is created, rule counter is reseted.\n * We need to reset the rule counter for SSR for each request.\n */\nvar createGenerateId = function createGenerateId(options) {\n if (options === void 0) {\n options = {};\n }\n\n var ruleCounter = 0;\n return function (rule, sheet) {\n ruleCounter += 1;\n\n if (ruleCounter > maxRules) {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] You might have a memory leak. Rule counter is at \" + ruleCounter + \".\") : void 0;\n }\n\n var jssId = '';\n var prefix = '';\n\n if (sheet) {\n if (sheet.options.classNamePrefix) {\n prefix = sheet.options.classNamePrefix;\n }\n\n if (sheet.options.jss.id != null) {\n jssId = String(sheet.options.jss.id);\n }\n }\n\n if (options.minify) {\n // Using \"c\" because a number can't be the first char in a class name.\n return \"\" + (prefix || 'c') + moduleId + jssId + ruleCounter;\n }\n\n return prefix + rule.key + \"-\" + moduleId + (jssId ? \"-\" + jssId : '') + \"-\" + ruleCounter;\n };\n};\n\n/**\n * Cache the value from the first time a function is called.\n */\nvar memoize = function memoize(fn) {\n var value;\n return function () {\n if (!value) value = fn();\n return value;\n };\n};\n/**\n * Get a style property value.\n */\n\n\nfunction getPropertyValue(cssRule, prop) {\n try {\n // Support CSSTOM.\n if (cssRule.attributeStyleMap) {\n return cssRule.attributeStyleMap.get(prop);\n }\n\n return cssRule.style.getPropertyValue(prop);\n } catch (err) {\n // IE may throw if property is unknown.\n return '';\n }\n}\n/**\n * Set a style property.\n */\n\n\nfunction setProperty(cssRule, prop, value) {\n try {\n var cssValue = value;\n\n if (Array.isArray(value)) {\n cssValue = toCssValue(value, true);\n\n if (value[value.length - 1] === '!important') {\n cssRule.style.setProperty(prop, cssValue, 'important');\n return true;\n }\n } // Support CSSTOM.\n\n\n if (cssRule.attributeStyleMap) {\n cssRule.attributeStyleMap.set(prop, cssValue);\n } else {\n cssRule.style.setProperty(prop, cssValue);\n }\n } catch (err) {\n // IE may throw if property is unknown.\n return false;\n }\n\n return true;\n}\n/**\n * Remove a style property.\n */\n\n\nfunction removeProperty(cssRule, prop) {\n try {\n // Support CSSTOM.\n if (cssRule.attributeStyleMap) {\n cssRule.attributeStyleMap.delete(prop);\n } else {\n cssRule.style.removeProperty(prop);\n }\n } catch (err) {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] DOMException \\\"\" + err.message + \"\\\" was thrown. Tried to remove property \\\"\" + prop + \"\\\".\") : void 0;\n }\n}\n/**\n * Set the selector.\n */\n\n\nfunction setSelector(cssRule, selectorText) {\n cssRule.selectorText = selectorText; // Return false if setter was not successful.\n // Currently works in chrome only.\n\n return cssRule.selectorText === selectorText;\n}\n/**\n * Gets the `head` element upon the first call and caches it.\n * We assume it can't be null.\n */\n\n\nvar getHead = memoize(function () {\n return document.querySelector('head');\n});\n/**\n * Find attached sheet with an index higher than the passed one.\n */\n\nfunction findHigherSheet(registry, options) {\n for (var i = 0; i < registry.length; i++) {\n var sheet = registry[i];\n\n if (sheet.attached && sheet.options.index > options.index && sheet.options.insertionPoint === options.insertionPoint) {\n return sheet;\n }\n }\n\n return null;\n}\n/**\n * Find attached sheet with the highest index.\n */\n\n\nfunction findHighestSheet(registry, options) {\n for (var i = registry.length - 1; i >= 0; i--) {\n var sheet = registry[i];\n\n if (sheet.attached && sheet.options.insertionPoint === options.insertionPoint) {\n return sheet;\n }\n }\n\n return null;\n}\n/**\n * Find a comment with \"jss\" inside.\n */\n\n\nfunction findCommentNode(text) {\n var head = getHead();\n\n for (var i = 0; i < head.childNodes.length; i++) {\n var node = head.childNodes[i];\n\n if (node.nodeType === 8 && node.nodeValue.trim() === text) {\n return node;\n }\n }\n\n return null;\n}\n\n/**\n * Find a node before which we can insert the sheet.\n */\nfunction findPrevNode(options) {\n var registry = sheets.registry;\n\n if (registry.length > 0) {\n // Try to insert before the next higher sheet.\n var sheet = findHigherSheet(registry, options);\n\n if (sheet && sheet.renderer) {\n return {\n parent: sheet.renderer.element.parentNode,\n node: sheet.renderer.element\n };\n } // Otherwise insert after the last attached.\n\n\n sheet = findHighestSheet(registry, options);\n\n if (sheet && sheet.renderer) {\n return {\n parent: sheet.renderer.element.parentNode,\n node: sheet.renderer.element.nextSibling\n };\n }\n } // Try to find a comment placeholder if registry is empty.\n\n\n var insertionPoint = options.insertionPoint;\n\n if (insertionPoint && typeof insertionPoint === 'string') {\n var comment = findCommentNode(insertionPoint);\n\n if (comment) {\n return {\n parent: comment.parentNode,\n node: comment.nextSibling\n };\n } // If user specifies an insertion point and it can't be found in the document -\n // bad specificity issues may appear.\n\n\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Insertion point \\\"\" + insertionPoint + \"\\\" not found.\") : void 0;\n }\n\n return false;\n}\n/**\n * Insert style element into the DOM.\n */\n\n\nfunction insertStyle(style, options) {\n var insertionPoint = options.insertionPoint;\n var nextNode = findPrevNode(options);\n\n if (nextNode !== false && nextNode.parent) {\n nextNode.parent.insertBefore(style, nextNode.node);\n return;\n } // Works with iframes and any node types.\n\n\n if (insertionPoint && typeof insertionPoint.nodeType === 'number') {\n // https://stackoverflow.com/questions/41328728/force-casting-in-flow\n var insertionPointElement = insertionPoint;\n var parentNode = insertionPointElement.parentNode;\n if (parentNode) parentNode.insertBefore(style, insertionPointElement.nextSibling);else process.env.NODE_ENV !== \"production\" ? warning(false, '[JSS] Insertion point is not in the DOM.') : void 0;\n return;\n }\n\n getHead().appendChild(style);\n}\n/**\n * Read jss nonce setting from the page if the user has set it.\n */\n\n\nvar getNonce = memoize(function () {\n var node = document.querySelector('meta[property=\"csp-nonce\"]');\n return node ? node.getAttribute('content') : null;\n});\n\nvar _insertRule = function insertRule(container, rule, index) {\n var maxIndex = container.cssRules.length; // In case previous insertion fails, passed index might be wrong\n\n if (index === undefined || index > maxIndex) {\n // eslint-disable-next-line no-param-reassign\n index = maxIndex;\n }\n\n try {\n if ('insertRule' in container) {\n var c = container;\n c.insertRule(rule, index);\n } // Keyframes rule.\n else if ('appendRule' in container) {\n var _c = container;\n\n _c.appendRule(rule);\n }\n } catch (err) {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] \" + err.message) : void 0;\n return false;\n }\n\n return container.cssRules[index];\n};\n\nvar createStyle = function createStyle() {\n var el = document.createElement('style'); // Without it, IE will have a broken source order specificity if we\n // insert rules after we insert the style tag.\n // It seems to kick-off the source order specificity algorithm.\n\n el.textContent = '\\n';\n return el;\n};\n\nvar DomRenderer =\n/*#__PURE__*/\nfunction () {\n // HTMLStyleElement needs fixing https://github.com/facebook/flow/issues/2696\n function DomRenderer(sheet) {\n this.getPropertyValue = getPropertyValue;\n this.setProperty = setProperty;\n this.removeProperty = removeProperty;\n this.setSelector = setSelector;\n this.element = void 0;\n this.sheet = void 0;\n this.hasInsertedRules = false;\n // There is no sheet when the renderer is used from a standalone StyleRule.\n if (sheet) sheets.add(sheet);\n this.sheet = sheet;\n\n var _ref = this.sheet ? this.sheet.options : {},\n media = _ref.media,\n meta = _ref.meta,\n element = _ref.element;\n\n this.element = element || createStyle();\n this.element.setAttribute('data-jss', '');\n if (media) this.element.setAttribute('media', media);\n if (meta) this.element.setAttribute('data-meta', meta);\n var nonce = getNonce();\n if (nonce) this.element.setAttribute('nonce', nonce);\n }\n /**\n * Insert style element into render tree.\n */\n\n\n var _proto = DomRenderer.prototype;\n\n _proto.attach = function attach() {\n // In the case the element node is external and it is already in the DOM.\n if (this.element.parentNode || !this.sheet) return;\n insertStyle(this.element, this.sheet.options); // When rules are inserted using `insertRule` API, after `sheet.detach().attach()`\n // most browsers create a new CSSStyleSheet, except of all IEs.\n\n var deployed = Boolean(this.sheet && this.sheet.deployed);\n\n if (this.hasInsertedRules && deployed) {\n this.hasInsertedRules = false;\n this.deploy();\n }\n }\n /**\n * Remove style element from render tree.\n */\n ;\n\n _proto.detach = function detach() {\n var parentNode = this.element.parentNode;\n if (parentNode) parentNode.removeChild(this.element);\n }\n /**\n * Inject CSS string into element.\n */\n ;\n\n _proto.deploy = function deploy() {\n var sheet = this.sheet;\n if (!sheet) return;\n\n if (sheet.options.link) {\n this.insertRules(sheet.rules);\n return;\n }\n\n this.element.textContent = \"\\n\" + sheet.toString() + \"\\n\";\n }\n /**\n * Insert RuleList into an element.\n */\n ;\n\n _proto.insertRules = function insertRules(rules, nativeParent) {\n for (var i = 0; i < rules.index.length; i++) {\n this.insertRule(rules.index[i], i, nativeParent);\n }\n }\n /**\n * Insert a rule into element.\n */\n ;\n\n _proto.insertRule = function insertRule(rule, index, nativeParent) {\n if (nativeParent === void 0) {\n nativeParent = this.element.sheet;\n }\n\n if (rule.rules) {\n var parent = rule;\n var latestNativeParent = nativeParent;\n\n if (rule.type === 'conditional' || rule.type === 'keyframes') {\n // We need to render the container without children first.\n latestNativeParent = _insertRule(nativeParent, parent.toString({\n children: false\n }), index);\n\n if (latestNativeParent === false) {\n return false;\n }\n }\n\n this.insertRules(parent.rules, latestNativeParent);\n return latestNativeParent;\n } // IE keeps the CSSStyleSheet after style node has been reattached,\n // so we need to check if the `renderable` reference the right style sheet and not\n // rerender those rules.\n\n\n if (rule.renderable && rule.renderable.parentStyleSheet === this.element.sheet) {\n return rule.renderable;\n }\n\n var ruleStr = rule.toString();\n if (!ruleStr) return false;\n\n var nativeRule = _insertRule(nativeParent, ruleStr, index);\n\n if (nativeRule === false) {\n return false;\n }\n\n this.hasInsertedRules = true;\n rule.renderable = nativeRule;\n return nativeRule;\n }\n /**\n * Delete a rule.\n */\n ;\n\n _proto.deleteRule = function deleteRule(cssRule) {\n var sheet = this.element.sheet;\n var index = this.indexOf(cssRule);\n if (index === -1) return false;\n sheet.deleteRule(index);\n return true;\n }\n /**\n * Get index of a CSS Rule.\n */\n ;\n\n _proto.indexOf = function indexOf(cssRule) {\n var cssRules = this.element.sheet.cssRules;\n\n for (var index = 0; index < cssRules.length; index++) {\n if (cssRule === cssRules[index]) return index;\n }\n\n return -1;\n }\n /**\n * Generate a new CSS rule and replace the existing one.\n *\n * Only used for some old browsers because they can't set a selector.\n */\n ;\n\n _proto.replaceRule = function replaceRule(cssRule, rule) {\n var index = this.indexOf(cssRule);\n if (index === -1) return false;\n this.element.sheet.deleteRule(index);\n return this.insertRule(rule, index);\n }\n /**\n * Get all rules elements.\n */\n ;\n\n _proto.getRules = function getRules() {\n return this.element.sheet.cssRules;\n };\n\n return DomRenderer;\n}();\n\nvar instanceCounter = 0;\n\nvar Jss =\n/*#__PURE__*/\nfunction () {\n function Jss(options) {\n this.id = instanceCounter++;\n this.version = \"10.0.3\";\n this.plugins = new PluginsRegistry();\n this.options = {\n id: {\n minify: false\n },\n createGenerateId: createGenerateId,\n Renderer: isInBrowser ? DomRenderer : null,\n plugins: []\n };\n this.generateId = createGenerateId({\n minify: false\n });\n\n for (var i = 0; i < plugins.length; i++) {\n this.plugins.use(plugins[i], {\n queue: 'internal'\n });\n }\n\n this.setup(options);\n }\n /**\n * Prepares various options, applies plugins.\n * Should not be used twice on the same instance, because there is no plugins\n * deduplication logic.\n */\n\n\n var _proto = Jss.prototype;\n\n _proto.setup = function setup(options) {\n if (options === void 0) {\n options = {};\n }\n\n if (options.createGenerateId) {\n this.options.createGenerateId = options.createGenerateId;\n }\n\n if (options.id) {\n this.options.id = _extends({}, this.options.id, options.id);\n }\n\n if (options.createGenerateId || options.id) {\n this.generateId = this.options.createGenerateId(this.options.id);\n }\n\n if (options.insertionPoint != null) this.options.insertionPoint = options.insertionPoint;\n\n if ('Renderer' in options) {\n this.options.Renderer = options.Renderer;\n } // eslint-disable-next-line prefer-spread\n\n\n if (options.plugins) this.use.apply(this, options.plugins);\n return this;\n }\n /**\n * Create a Style Sheet.\n */\n ;\n\n _proto.createStyleSheet = function createStyleSheet(styles, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n index = _options.index;\n\n if (typeof index !== 'number') {\n index = sheets.index === 0 ? 0 : sheets.index + 1;\n }\n\n var sheet = new StyleSheet(styles, _extends({}, options, {\n jss: this,\n generateId: options.generateId || this.generateId,\n insertionPoint: this.options.insertionPoint,\n Renderer: this.options.Renderer,\n index: index\n }));\n this.plugins.onProcessSheet(sheet);\n return sheet;\n }\n /**\n * Detach the Style Sheet and remove it from the registry.\n */\n ;\n\n _proto.removeStyleSheet = function removeStyleSheet(sheet) {\n sheet.detach();\n sheets.remove(sheet);\n return this;\n }\n /**\n * Create a rule without a Style Sheet.\n * [Deprecated] will be removed in the next major version.\n */\n ;\n\n _proto.createRule = function createRule$$1(name, style, options) {\n if (style === void 0) {\n style = {};\n }\n\n if (options === void 0) {\n options = {};\n }\n\n // Enable rule without name for inline styles.\n if (typeof name === 'object') {\n return this.createRule(undefined, name, style);\n }\n\n var ruleOptions = _extends({}, options, {\n name: name,\n jss: this,\n Renderer: this.options.Renderer\n });\n\n if (!ruleOptions.generateId) ruleOptions.generateId = this.generateId;\n if (!ruleOptions.classes) ruleOptions.classes = {};\n if (!ruleOptions.keyframes) ruleOptions.keyframes = {};\n\n var rule = createRule(name, style, ruleOptions);\n\n if (rule) this.plugins.onProcessRule(rule);\n return rule;\n }\n /**\n * Register plugin. Passed function will be invoked with a rule instance.\n */\n ;\n\n _proto.use = function use() {\n var _this = this;\n\n for (var _len = arguments.length, plugins$$1 = new Array(_len), _key = 0; _key < _len; _key++) {\n plugins$$1[_key] = arguments[_key];\n }\n\n plugins$$1.forEach(function (plugin) {\n _this.plugins.use(plugin);\n });\n return this;\n };\n\n return Jss;\n}();\n\n/**\n * Extracts a styles object with only props that contain function values.\n */\nfunction getDynamicStyles(styles) {\n var to = null;\n\n for (var key in styles) {\n var value = styles[key];\n var type = typeof value;\n\n if (type === 'function') {\n if (!to) to = {};\n to[key] = value;\n } else if (type === 'object' && value !== null && !Array.isArray(value)) {\n var extracted = getDynamicStyles(value);\n\n if (extracted) {\n if (!to) to = {};\n to[key] = extracted;\n }\n }\n }\n\n return to;\n}\n\n/**\n * SheetsManager is like a WeakMap which is designed to count StyleSheet\n * instances and attach/detach automatically.\n */\nvar SheetsManager =\n/*#__PURE__*/\nfunction () {\n function SheetsManager() {\n this.length = 0;\n this.sheets = new WeakMap();\n }\n\n var _proto = SheetsManager.prototype;\n\n _proto.get = function get(key) {\n var entry = this.sheets.get(key);\n return entry && entry.sheet;\n };\n\n _proto.add = function add(key, sheet) {\n if (this.sheets.has(key)) return;\n this.length++;\n this.sheets.set(key, {\n sheet: sheet,\n refs: 0\n });\n };\n\n _proto.manage = function manage(key) {\n var entry = this.sheets.get(key);\n\n if (entry) {\n if (entry.refs === 0) {\n entry.sheet.attach();\n }\n\n entry.refs++;\n return entry.sheet;\n }\n\n warning(false, \"[JSS] SheetsManager: can't find sheet to manage\");\n return undefined;\n };\n\n _proto.unmanage = function unmanage(key) {\n var entry = this.sheets.get(key);\n\n if (entry) {\n if (entry.refs > 0) {\n entry.refs--;\n if (entry.refs === 0) entry.sheet.detach();\n }\n } else {\n warning(false, \"SheetsManager: can't find sheet to unmanage\");\n }\n };\n\n _createClass(SheetsManager, [{\n key: \"size\",\n get: function get() {\n return this.length;\n }\n }]);\n\n return SheetsManager;\n}();\n\n/**\n * A better abstraction over CSS.\n *\n * @copyright Oleg Isonen (Slobodskoi) / Isonen 2014-present\n * @website https://github.com/cssinjs/jss\n * @license MIT\n */\n\n/**\n * Export a constant indicating if this browser has CSSTOM support.\n * https://developers.google.com/web/updates/2018/03/cssom\n */\nvar hasCSSTOMSupport = typeof CSS !== 'undefined' && CSS && 'number' in CSS;\n/**\n * Creates a new instance of Jss.\n */\n\nvar create = function create(options) {\n return new Jss(options);\n};\n/**\n * A global Jss instance.\n */\n\nvar index = create();\n\nexport default index;\nexport { hasCSSTOMSupport, create, getDynamicStyles, toCssValue, createRule, SheetsRegistry, SheetsManager, RuleList, sheets, createGenerateId };\n","// Used https://github.com/thinkloop/multi-key-cache as inspiration\nvar multiKeyStore = {\n set: function set(cache, key1, key2, value) {\n var subCache = cache.get(key1);\n\n if (!subCache) {\n subCache = new Map();\n cache.set(key1, subCache);\n }\n\n subCache.set(key2, value);\n },\n get: function get(cache, key1, key2) {\n var subCache = cache.get(key1);\n return subCache ? subCache.get(key2) : undefined;\n },\n delete: function _delete(cache, key1, key2) {\n var subCache = cache.get(key1);\n subCache.delete(key2);\n }\n};\nexport default multiKeyStore;","import nested from '../ThemeProvider/nested';\n/**\n * This is the list of the style rule name we use as drop in replacement for the built-in\n * pseudo classes (:checked, :disabled, :focused, etc.).\n *\n * Why do they exist in the first place?\n * These classes are used at a specificity of 2.\n * It allows them to override previously definied styles as well as\n * being untouched by simple user overrides.\n */\n\nvar pseudoClasses = ['checked', 'disabled', 'error', 'focused', 'focusVisible', 'required', 'expanded', 'selected']; // Returns a function which generates unique class names based on counters.\n// When new generator function is created, rule counter is reset.\n// We need to reset the rule counter for SSR for each request.\n//\n// It's inspired by\n// https://github.com/cssinjs/jss/blob/4e6a05dd3f7b6572fdd3ab216861d9e446c20331/src/utils/createGenerateClassName.js\n\nexport default function createGenerateClassName() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var _options$disableGloba = options.disableGlobal,\n disableGlobal = _options$disableGloba === void 0 ? false : _options$disableGloba,\n _options$productionPr = options.productionPrefix,\n productionPrefix = _options$productionPr === void 0 ? 'jss' : _options$productionPr,\n _options$seed = options.seed,\n seed = _options$seed === void 0 ? '' : _options$seed;\n var seedPrefix = seed === '' ? '' : \"\".concat(seed, \"-\");\n var ruleCounter = 0;\n return function (rule, styleSheet) {\n ruleCounter += 1;\n\n if (process.env.NODE_ENV !== 'production') {\n if (ruleCounter >= 1e10) {\n console.warn(['Material-UI: you might have a memory leak.', 'The ruleCounter is not supposed to grow that much.'].join(''));\n }\n }\n\n var name = styleSheet.options.name; // Is a global static MUI style?\n\n if (name && name.indexOf('Mui') === 0 && !styleSheet.options.link && !disableGlobal) {\n // We can use a shorthand class name, we never use the keys to style the components.\n if (pseudoClasses.indexOf(rule.key) !== -1) {\n return \"Mui-\".concat(rule.key);\n }\n\n var prefix = \"\".concat(seedPrefix).concat(name, \"-\").concat(rule.key);\n\n if (!styleSheet.options.theme[nested] || seed !== '') {\n return prefix;\n }\n\n return \"\".concat(prefix, \"-\").concat(ruleCounter);\n }\n\n if (process.env.NODE_ENV === 'production') {\n return \"\".concat(seedPrefix).concat(productionPrefix).concat(ruleCounter);\n }\n\n var suffix = \"\".concat(rule.key, \"-\").concat(ruleCounter); // Help with debuggability.\n\n if (styleSheet.options.classNamePrefix) {\n return \"\".concat(seedPrefix).concat(styleSheet.options.classNamePrefix, \"-\").concat(suffix);\n }\n\n return \"\".concat(seedPrefix).concat(suffix);\n };\n}","import { createRule } from 'jss';\n\nvar now = Date.now();\nvar fnValuesNs = \"fnValues\" + now;\nvar fnRuleNs = \"fnStyle\" + ++now;\nfunction functionPlugin() {\n return {\n onCreateRule: function onCreateRule(name, decl, options) {\n if (typeof decl !== 'function') return null;\n var rule = createRule(name, {}, options);\n rule[fnRuleNs] = decl;\n return rule;\n },\n onProcessStyle: function onProcessStyle(style, rule) {\n // We need to extract function values from the declaration, so that we can keep core unaware of them.\n // We need to do that only once.\n // We don't need to extract functions on each style update, since this can happen only once.\n // We don't support function values inside of function rules.\n if (fnValuesNs in rule || fnRuleNs in rule) return style;\n var fnValues = {};\n\n for (var prop in style) {\n var value = style[prop];\n if (typeof value !== 'function') continue;\n delete style[prop];\n fnValues[prop] = value;\n } // $FlowFixMe\n\n\n rule[fnValuesNs] = fnValues;\n return style;\n },\n onUpdate: function onUpdate(data, rule, sheet, options) {\n var styleRule = rule;\n var fnRule = styleRule[fnRuleNs]; // If we have a style function, the entire rule is dynamic and style object\n // will be returned from that function.\n\n if (fnRule) {\n // Empty object will remove all currently defined props\n // in case function rule returns a falsy value.\n styleRule.style = fnRule(data) || {};\n }\n\n var fnValues = styleRule[fnValuesNs]; // If we have a fn values map, it is a rule with function values.\n\n if (fnValues) {\n for (var prop in fnValues) {\n styleRule.prop(prop, fnValues[prop](data), options);\n }\n }\n }\n };\n}\n\nexport default functionPlugin;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport { RuleList } from 'jss';\n\nvar at = '@global';\nvar atPrefix = '@global ';\n\nvar GlobalContainerRule =\n/*#__PURE__*/\nfunction () {\n function GlobalContainerRule(key, styles, options) {\n this.type = 'global';\n this.at = at;\n this.rules = void 0;\n this.options = void 0;\n this.key = void 0;\n this.isProcessed = false;\n this.key = key;\n this.options = options;\n this.rules = new RuleList(_extends({}, options, {\n parent: this\n }));\n\n for (var selector in styles) {\n this.rules.add(selector, styles[selector]);\n }\n\n this.rules.process();\n }\n /**\n * Get a rule.\n */\n\n\n var _proto = GlobalContainerRule.prototype;\n\n _proto.getRule = function getRule(name) {\n return this.rules.get(name);\n }\n /**\n * Create and register rule, run plugins.\n */\n ;\n\n _proto.addRule = function addRule(name, style, options) {\n var rule = this.rules.add(name, style, options);\n this.options.jss.plugins.onProcessRule(rule);\n return rule;\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.rules.indexOf(rule);\n }\n /**\n * Generates a CSS string.\n */\n ;\n\n _proto.toString = function toString() {\n return this.rules.toString();\n };\n\n return GlobalContainerRule;\n}();\n\nvar GlobalPrefixedRule =\n/*#__PURE__*/\nfunction () {\n function GlobalPrefixedRule(key, style, options) {\n this.type = 'global';\n this.at = at;\n this.options = void 0;\n this.rule = void 0;\n this.isProcessed = false;\n this.key = void 0;\n this.key = key;\n this.options = options;\n var selector = key.substr(atPrefix.length);\n this.rule = options.jss.createRule(selector, style, _extends({}, options, {\n parent: this\n }));\n }\n\n var _proto2 = GlobalPrefixedRule.prototype;\n\n _proto2.toString = function toString(options) {\n return this.rule ? this.rule.toString(options) : '';\n };\n\n return GlobalPrefixedRule;\n}();\n\nvar separatorRegExp = /\\s*,\\s*/g;\n\nfunction addScope(selector, scope) {\n var parts = selector.split(separatorRegExp);\n var scoped = '';\n\n for (var i = 0; i < parts.length; i++) {\n scoped += scope + \" \" + parts[i].trim();\n if (parts[i + 1]) scoped += ', ';\n }\n\n return scoped;\n}\n\nfunction handleNestedGlobalContainerRule(rule) {\n var options = rule.options,\n style = rule.style;\n var rules = style ? style[at] : null;\n if (!rules) return;\n\n for (var name in rules) {\n options.sheet.addRule(name, rules[name], _extends({}, options, {\n selector: addScope(name, rule.selector)\n }));\n }\n\n delete style[at];\n}\n\nfunction handlePrefixedGlobalRule(rule) {\n var options = rule.options,\n style = rule.style;\n\n for (var prop in style) {\n if (prop[0] !== '@' || prop.substr(0, at.length) !== at) continue;\n var selector = addScope(prop.substr(at.length), rule.selector);\n options.sheet.addRule(selector, style[prop], _extends({}, options, {\n selector: selector\n }));\n delete style[prop];\n }\n}\n/**\n * Convert nested rules to separate, remove them from original styles.\n *\n * @param {Rule} rule\n * @api public\n */\n\n\nfunction jssGlobal() {\n function onCreateRule(name, styles, options) {\n if (!name) return null;\n\n if (name === at) {\n return new GlobalContainerRule(name, styles, options);\n }\n\n if (name[0] === '@' && name.substr(0, atPrefix.length) === atPrefix) {\n return new GlobalPrefixedRule(name, styles, options);\n }\n\n var parent = options.parent;\n\n if (parent) {\n if (parent.type === 'global' || parent.options.parent && parent.options.parent.type === 'global') {\n options.scoped = false;\n }\n }\n\n if (options.scoped === false) {\n options.selector = name;\n }\n\n return null;\n }\n\n function onProcessRule(rule) {\n if (rule.type !== 'style') return;\n handleNestedGlobalContainerRule(rule);\n handlePrefixedGlobalRule(rule);\n }\n\n return {\n onCreateRule: onCreateRule,\n onProcessRule: onProcessRule\n };\n}\n\nexport default jssGlobal;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport warning from 'tiny-warning';\n\nvar separatorRegExp = /\\s*,\\s*/g;\nvar parentRegExp = /&/g;\nvar refRegExp = /\\$([\\w-]+)/g;\n/**\n * Convert nested rules to separate, remove them from original styles.\n *\n * @param {Rule} rule\n * @api public\n */\n\nfunction jssNested() {\n // Get a function to be used for $ref replacement.\n function getReplaceRef(container, sheet) {\n return function (match, key) {\n var rule = container.getRule(key) || sheet && sheet.getRule(key);\n\n if (rule) {\n rule = rule;\n return rule.selector;\n }\n\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Could not find the referenced rule \\\"\" + key + \"\\\" in \\\"\" + (container.options.meta || container.toString()) + \"\\\".\") : void 0;\n return key;\n };\n }\n\n function replaceParentRefs(nestedProp, parentProp) {\n var parentSelectors = parentProp.split(separatorRegExp);\n var nestedSelectors = nestedProp.split(separatorRegExp);\n var result = '';\n\n for (var i = 0; i < parentSelectors.length; i++) {\n var parent = parentSelectors[i];\n\n for (var j = 0; j < nestedSelectors.length; j++) {\n var nested = nestedSelectors[j];\n if (result) result += ', '; // Replace all & by the parent or prefix & with the parent.\n\n result += nested.indexOf('&') !== -1 ? nested.replace(parentRegExp, parent) : parent + \" \" + nested;\n }\n }\n\n return result;\n }\n\n function getOptions(rule, container, prevOptions) {\n // Options has been already created, now we only increase index.\n if (prevOptions) return _extends({}, prevOptions, {\n index: prevOptions.index + 1\n });\n var nestingLevel = rule.options.nestingLevel;\n nestingLevel = nestingLevel === undefined ? 1 : nestingLevel + 1;\n\n var options = _extends({}, rule.options, {\n nestingLevel: nestingLevel,\n index: container.indexOf(rule) + 1 // We don't need the parent name to be set options for chlid.\n\n });\n\n delete options.name;\n return options;\n }\n\n function onProcessStyle(style, rule, sheet) {\n if (rule.type !== 'style') return style;\n var styleRule = rule;\n var container = styleRule.options.parent;\n var options;\n var replaceRef;\n\n for (var prop in style) {\n var isNested = prop.indexOf('&') !== -1;\n var isNestedConditional = prop[0] === '@';\n if (!isNested && !isNestedConditional) continue;\n options = getOptions(styleRule, container, options);\n\n if (isNested) {\n var selector = replaceParentRefs(prop, styleRule.selector); // Lazily create the ref replacer function just once for\n // all nested rules within the sheet.\n\n if (!replaceRef) replaceRef = getReplaceRef(container, sheet); // Replace all $refs.\n\n selector = selector.replace(refRegExp, replaceRef);\n container.addRule(selector, style[prop], _extends({}, options, {\n selector: selector\n }));\n } else if (isNestedConditional) {\n // Place conditional right after the parent rule to ensure right ordering.\n container.addRule(prop, {}, options) // Flow expects more options but they aren't required\n // And flow doesn't know this will always be a StyleRule which has the addRule method\n // $FlowFixMe\n .addRule(styleRule.key, style[prop], {\n selector: styleRule.selector\n });\n }\n\n delete style[prop];\n }\n\n return style;\n }\n\n return {\n onProcessStyle: onProcessStyle\n };\n}\n\nexport default jssNested;\n","/* eslint-disable no-var, prefer-template */\nvar uppercasePattern = /[A-Z]/g\nvar msPattern = /^ms-/\nvar cache = {}\n\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase()\n}\n\nfunction hyphenateStyleName(name) {\n if (cache.hasOwnProperty(name)) {\n return cache[name]\n }\n\n var hName = name.replace(uppercasePattern, toHyphenLower)\n return (cache[name] = msPattern.test(hName) ? '-' + hName : hName)\n}\n\nexport default hyphenateStyleName\n","import hyphenate from 'hyphenate-style-name';\n\n/**\n * Convert camel cased property names to dash separated.\n *\n * @param {Object} style\n * @return {Object}\n */\n\nfunction convertCase(style) {\n var converted = {};\n\n for (var prop in style) {\n var key = prop.indexOf('--') === 0 ? prop : hyphenate(prop);\n converted[key] = style[prop];\n }\n\n if (style.fallbacks) {\n if (Array.isArray(style.fallbacks)) converted.fallbacks = style.fallbacks.map(convertCase);else converted.fallbacks = convertCase(style.fallbacks);\n }\n\n return converted;\n}\n/**\n * Allow camel cased property names by converting them back to dasherized.\n *\n * @param {Rule} rule\n */\n\n\nfunction camelCase() {\n function onProcessStyle(style) {\n if (Array.isArray(style)) {\n // Handle rules like @font-face, which can have multiple styles in an array\n for (var index = 0; index < style.length; index++) {\n style[index] = convertCase(style[index]);\n }\n\n return style;\n }\n\n return convertCase(style);\n }\n\n function onChangeValue(value, prop, rule) {\n if (prop.indexOf('--') === 0) {\n return value;\n }\n\n var hyphenatedProp = hyphenate(prop); // There was no camel case in place\n\n if (prop === hyphenatedProp) return value;\n rule.prop(hyphenatedProp, value); // Core will ignore that property value we set the proper one above.\n\n return null;\n }\n\n return {\n onProcessStyle: onProcessStyle,\n onChangeValue: onChangeValue\n };\n}\n\nexport default camelCase;\n","import { hasCSSTOMSupport } from 'jss';\n\nvar px = hasCSSTOMSupport && CSS ? CSS.px : 'px';\nvar ms = hasCSSTOMSupport && CSS ? CSS.ms : 'ms';\nvar percent = hasCSSTOMSupport && CSS ? CSS.percent : '%';\n/**\n * Generated jss-plugin-default-unit CSS property units\n *\n * @type object\n */\n\nvar defaultUnits = {\n // Animation properties\n 'animation-delay': ms,\n 'animation-duration': ms,\n // Background properties\n 'background-position': px,\n 'background-position-x': px,\n 'background-position-y': px,\n 'background-size': px,\n // Border Properties\n border: px,\n 'border-bottom': px,\n 'border-bottom-left-radius': px,\n 'border-bottom-right-radius': px,\n 'border-bottom-width': px,\n 'border-left': px,\n 'border-left-width': px,\n 'border-radius': px,\n 'border-right': px,\n 'border-right-width': px,\n 'border-top': px,\n 'border-top-left-radius': px,\n 'border-top-right-radius': px,\n 'border-top-width': px,\n 'border-width': px,\n // Margin properties\n margin: px,\n 'margin-bottom': px,\n 'margin-left': px,\n 'margin-right': px,\n 'margin-top': px,\n // Padding properties\n padding: px,\n 'padding-bottom': px,\n 'padding-left': px,\n 'padding-right': px,\n 'padding-top': px,\n // Mask properties\n 'mask-position-x': px,\n 'mask-position-y': px,\n 'mask-size': px,\n // Width and height properties\n height: px,\n width: px,\n 'min-height': px,\n 'max-height': px,\n 'min-width': px,\n 'max-width': px,\n // Position properties\n bottom: px,\n left: px,\n top: px,\n right: px,\n // Shadow properties\n 'box-shadow': px,\n 'text-shadow': px,\n // Column properties\n 'column-gap': px,\n 'column-rule': px,\n 'column-rule-width': px,\n 'column-width': px,\n // Font and text properties\n 'font-size': px,\n 'font-size-delta': px,\n 'letter-spacing': px,\n 'text-indent': px,\n 'text-stroke': px,\n 'text-stroke-width': px,\n 'word-spacing': px,\n // Motion properties\n motion: px,\n 'motion-offset': px,\n // Outline properties\n outline: px,\n 'outline-offset': px,\n 'outline-width': px,\n // Perspective properties\n perspective: px,\n 'perspective-origin-x': percent,\n 'perspective-origin-y': percent,\n // Transform properties\n 'transform-origin': percent,\n 'transform-origin-x': percent,\n 'transform-origin-y': percent,\n 'transform-origin-z': percent,\n // Transition properties\n 'transition-delay': ms,\n 'transition-duration': ms,\n // Alignment properties\n 'vertical-align': px,\n 'flex-basis': px,\n // Some random properties\n 'shape-margin': px,\n size: px,\n // Grid properties\n grid: px,\n 'grid-gap': px,\n 'grid-row-gap': px,\n 'grid-column-gap': px,\n 'grid-template-rows': px,\n 'grid-template-columns': px,\n 'grid-auto-rows': px,\n 'grid-auto-columns': px,\n // Not existing properties.\n // Used to avoid issues with jss-plugin-expand integration.\n 'box-shadow-x': px,\n 'box-shadow-y': px,\n 'box-shadow-blur': px,\n 'box-shadow-spread': px,\n 'font-line-height': px,\n 'text-shadow-x': px,\n 'text-shadow-y': px,\n 'text-shadow-blur': px\n};\n\n/**\n * Clones the object and adds a camel cased property version.\n */\nfunction addCamelCasedVersion(obj) {\n var regExp = /(-[a-z])/g;\n\n var replace = function replace(str) {\n return str[1].toUpperCase();\n };\n\n var newObj = {};\n\n for (var _key in obj) {\n newObj[_key] = obj[_key];\n newObj[_key.replace(regExp, replace)] = obj[_key];\n }\n\n return newObj;\n}\n\nvar units = addCamelCasedVersion(defaultUnits);\n/**\n * Recursive deep style passing function\n */\n\nfunction iterate(prop, value, options) {\n if (!value) return value;\n\n if (Array.isArray(value)) {\n for (var i = 0; i < value.length; i++) {\n value[i] = iterate(prop, value[i], options);\n }\n } else if (typeof value === 'object') {\n if (prop === 'fallbacks') {\n for (var innerProp in value) {\n value[innerProp] = iterate(innerProp, value[innerProp], options);\n }\n } else {\n for (var _innerProp in value) {\n value[_innerProp] = iterate(prop + \"-\" + _innerProp, value[_innerProp], options);\n }\n }\n } else if (typeof value === 'number') {\n if (options[prop]) {\n return \"\" + value + options[prop];\n }\n\n if (units[prop]) {\n return typeof units[prop] === 'function' ? units[prop](value).toString() : \"\" + value + units[prop];\n }\n\n return value.toString();\n }\n\n return value;\n}\n/**\n * Add unit to numeric values.\n */\n\n\nfunction defaultUnit(options) {\n if (options === void 0) {\n options = {};\n }\n\n var camelCasedOptions = addCamelCasedVersion(options);\n\n function onProcessStyle(style, rule) {\n if (rule.type !== 'style') return style;\n\n for (var prop in style) {\n style[prop] = iterate(prop, style[prop], camelCasedOptions);\n }\n\n return style;\n }\n\n function onChangeValue(value, prop) {\n return iterate(prop, value, camelCasedOptions);\n }\n\n return {\n onProcessStyle: onProcessStyle,\n onChangeValue: onChangeValue\n };\n}\n\nexport default defaultUnit;\n","import isInBrowser from 'is-in-browser';\nimport _toConsumableArray from '@babel/runtime/helpers/esm/toConsumableArray';\n\n// Export javascript style and css style vendor prefixes.\nvar js = '';\nvar css = '';\nvar vendor = '';\nvar browser = '';\nvar isTouch = isInBrowser && 'ontouchstart' in document.documentElement; // We should not do anything if required serverside.\n\nif (isInBrowser) {\n // Order matters. We need to check Webkit the last one because\n // other vendors use to add Webkit prefixes to some properties\n var jsCssMap = {\n Moz: '-moz-',\n ms: '-ms-',\n O: '-o-',\n Webkit: '-webkit-'\n };\n\n var _document$createEleme = document.createElement('p'),\n style = _document$createEleme.style;\n\n var testProp = 'Transform';\n\n for (var key in jsCssMap) {\n if (key + testProp in style) {\n js = key;\n css = jsCssMap[key];\n break;\n }\n } // Correctly detect the Edge browser.\n\n\n if (js === 'Webkit' && 'msHyphens' in style) {\n js = 'ms';\n css = jsCssMap.ms;\n browser = 'edge';\n } // Correctly detect the Safari browser.\n\n\n if (js === 'Webkit' && '-apple-trailing-word' in style) {\n vendor = 'apple';\n }\n}\n/**\n * Vendor prefix string for the current browser.\n *\n * @type {{js: String, css: String, vendor: String, browser: String}}\n * @api public\n */\n\n\nvar prefix = {\n js: js,\n css: css,\n vendor: vendor,\n browser: browser,\n isTouch: isTouch\n};\n\n/**\n * Test if a keyframe at-rule should be prefixed or not\n *\n * @param {String} vendor prefix string for the current browser.\n * @return {String}\n * @api public\n */\n\nfunction supportedKeyframes(key) {\n // Keyframes is already prefixed. e.g. key = '@-webkit-keyframes a'\n if (key[1] === '-') return key; // No need to prefix IE/Edge. Older browsers will ignore unsupported rules.\n // https://caniuse.com/#search=keyframes\n\n if (prefix.js === 'ms') return key;\n return \"@\" + prefix.css + \"keyframes\" + key.substr(10);\n}\n\n// https://caniuse.com/#search=appearance\n\nvar appearence = {\n noPrefill: ['appearance'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'appearance') return false;\n if (prefix.js === 'ms') return \"-webkit-\" + prop;\n return prefix.css + prop;\n }\n};\n\n// https://caniuse.com/#search=color-adjust\n\nvar colorAdjust = {\n noPrefill: ['color-adjust'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'color-adjust') return false;\n if (prefix.js === 'Webkit') return prefix.css + \"print-\" + prop;\n return prop;\n }\n};\n\nvar regExp = /[-\\s]+(.)?/g;\n/**\n * Replaces the letter with the capital letter\n *\n * @param {String} match\n * @param {String} c\n * @return {String}\n * @api private\n */\n\nfunction toUpper(match, c) {\n return c ? c.toUpperCase() : '';\n}\n/**\n * Convert dash separated strings to camel-cased.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\n\nfunction camelize(str) {\n return str.replace(regExp, toUpper);\n}\n\n/**\n * Convert dash separated strings to pascal cased.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\nfunction pascalize(str) {\n return camelize(\"-\" + str);\n}\n\n// but we can use a longhand property instead.\n// https://caniuse.com/#search=mask\n\nvar mask = {\n noPrefill: ['mask'],\n supportedProperty: function supportedProperty(prop, style) {\n if (!/^mask/.test(prop)) return false;\n\n if (prefix.js === 'Webkit') {\n var longhand = 'mask-image';\n\n if (camelize(longhand) in style) {\n return prop;\n }\n\n if (prefix.js + pascalize(longhand) in style) {\n return prefix.css + prop;\n }\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=text-orientation\n\nvar textOrientation = {\n noPrefill: ['text-orientation'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'text-orientation') return false;\n\n if (prefix.vendor === 'apple' && !prefix.isTouch) {\n return prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=transform\n\nvar transform = {\n noPrefill: ['transform'],\n supportedProperty: function supportedProperty(prop, style, options) {\n if (prop !== 'transform') return false;\n\n if (options.transform) {\n return prop;\n }\n\n return prefix.css + prop;\n }\n};\n\n// https://caniuse.com/#search=transition\n\nvar transition = {\n noPrefill: ['transition'],\n supportedProperty: function supportedProperty(prop, style, options) {\n if (prop !== 'transition') return false;\n\n if (options.transition) {\n return prop;\n }\n\n return prefix.css + prop;\n }\n};\n\n// https://caniuse.com/#search=writing-mode\n\nvar writingMode = {\n noPrefill: ['writing-mode'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'writing-mode') return false;\n\n if (prefix.js === 'Webkit' || prefix.js === 'ms') {\n return prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=user-select\n\nvar userSelect = {\n noPrefill: ['user-select'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'user-select') return false;\n\n if (prefix.js === 'Moz' || prefix.js === 'ms' || prefix.vendor === 'apple') {\n return prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=multicolumn\n// https://github.com/postcss/autoprefixer/issues/491\n// https://github.com/postcss/autoprefixer/issues/177\n\nvar breakPropsOld = {\n supportedProperty: function supportedProperty(prop, style) {\n if (!/^break-/.test(prop)) return false;\n\n if (prefix.js === 'Webkit') {\n var jsProp = \"WebkitColumn\" + pascalize(prop);\n return jsProp in style ? prefix.css + \"column-\" + prop : false;\n }\n\n if (prefix.js === 'Moz') {\n var _jsProp = \"page\" + pascalize(prop);\n\n return _jsProp in style ? \"page-\" + prop : false;\n }\n\n return false;\n }\n};\n\n// See https://github.com/postcss/autoprefixer/issues/324.\n\nvar inlineLogicalOld = {\n supportedProperty: function supportedProperty(prop, style) {\n if (!/^(border|margin|padding)-inline/.test(prop)) return false;\n if (prefix.js === 'Moz') return prop;\n var newProp = prop.replace('-inline', '');\n return prefix.js + pascalize(newProp) in style ? prefix.css + newProp : false;\n }\n};\n\n// Camelization is required because we can't test using.\n// CSS syntax for e.g. in FF.\n\nvar unprefixed = {\n supportedProperty: function supportedProperty(prop, style) {\n return camelize(prop) in style ? prop : false;\n }\n};\n\nvar prefixed = {\n supportedProperty: function supportedProperty(prop, style) {\n var pascalized = pascalize(prop); // Return custom CSS variable without prefixing.\n\n if (prop[0] === '-') return prop; // Return already prefixed value without prefixing.\n\n if (prop[0] === '-' && prop[1] === '-') return prop;\n if (prefix.js + pascalized in style) return prefix.css + prop; // Try webkit fallback.\n\n if (prefix.js !== 'Webkit' && \"Webkit\" + pascalized in style) return \"-webkit-\" + prop;\n return false;\n }\n};\n\n// https://caniuse.com/#search=scroll-snap\n\nvar scrollSnap = {\n supportedProperty: function supportedProperty(prop) {\n if (prop.substring(0, 11) !== 'scroll-snap') return false;\n\n if (prefix.js === 'ms') {\n return \"\" + prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=overscroll-behavior\n\nvar overscrollBehavior = {\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'overscroll-behavior') return false;\n\n if (prefix.js === 'ms') {\n return prefix.css + \"scroll-chaining\";\n }\n\n return prop;\n }\n};\n\nvar propMap = {\n 'flex-grow': 'flex-positive',\n 'flex-shrink': 'flex-negative',\n 'flex-basis': 'flex-preferred-size',\n 'justify-content': 'flex-pack',\n order: 'flex-order',\n 'align-items': 'flex-align',\n 'align-content': 'flex-line-pack' // 'align-self' is handled by 'align-self' plugin.\n\n}; // Support old flex spec from 2012.\n\nvar flex2012 = {\n supportedProperty: function supportedProperty(prop, style) {\n var newProp = propMap[prop];\n if (!newProp) return false;\n return prefix.js + pascalize(newProp) in style ? prefix.css + newProp : false;\n }\n};\n\nvar propMap$1 = {\n flex: 'box-flex',\n 'flex-grow': 'box-flex',\n 'flex-direction': ['box-orient', 'box-direction'],\n order: 'box-ordinal-group',\n 'align-items': 'box-align',\n 'flex-flow': ['box-orient', 'box-direction'],\n 'justify-content': 'box-pack'\n};\nvar propKeys = Object.keys(propMap$1);\n\nvar prefixCss = function prefixCss(p) {\n return prefix.css + p;\n}; // Support old flex spec from 2009.\n\n\nvar flex2009 = {\n supportedProperty: function supportedProperty(prop, style, _ref) {\n var multiple = _ref.multiple;\n\n if (propKeys.indexOf(prop) > -1) {\n var newProp = propMap$1[prop];\n\n if (!Array.isArray(newProp)) {\n return prefix.js + pascalize(newProp) in style ? prefix.css + newProp : false;\n }\n\n if (!multiple) return false;\n\n for (var i = 0; i < newProp.length; i++) {\n if (!(prefix.js + pascalize(newProp[0]) in style)) {\n return false;\n }\n }\n\n return newProp.map(prefixCss);\n }\n\n return false;\n }\n};\n\n// plugins = [\n// ...plugins,\n// breakPropsOld,\n// inlineLogicalOld,\n// unprefixed,\n// prefixed,\n// scrollSnap,\n// flex2012,\n// flex2009\n// ]\n// Plugins without 'noPrefill' value, going last.\n// 'flex-*' plugins should be at the bottom.\n// 'flex2009' going after 'flex2012'.\n// 'prefixed' going after 'unprefixed'\n\nvar plugins = [appearence, colorAdjust, mask, textOrientation, transform, transition, writingMode, userSelect, breakPropsOld, inlineLogicalOld, unprefixed, prefixed, scrollSnap, overscrollBehavior, flex2012, flex2009];\nvar propertyDetectors = plugins.filter(function (p) {\n return p.supportedProperty;\n}).map(function (p) {\n return p.supportedProperty;\n});\nvar noPrefill = plugins.filter(function (p) {\n return p.noPrefill;\n}).reduce(function (a, p) {\n a.push.apply(a, _toConsumableArray(p.noPrefill));\n return a;\n}, []);\n\nvar el;\nvar cache = {};\n\nif (isInBrowser) {\n el = document.createElement('p'); // We test every property on vendor prefix requirement.\n // Once tested, result is cached. It gives us up to 70% perf boost.\n // http://jsperf.com/element-style-object-access-vs-plain-object\n //\n // Prefill cache with known css properties to reduce amount of\n // properties we need to feature test at runtime.\n // http://davidwalsh.name/vendor-prefix\n\n var computed = window.getComputedStyle(document.documentElement, '');\n\n for (var key$1 in computed) {\n // eslint-disable-next-line no-restricted-globals\n if (!isNaN(key$1)) cache[computed[key$1]] = computed[key$1];\n } // Properties that cannot be correctly detected using the\n // cache prefill method.\n\n\n noPrefill.forEach(function (x) {\n return delete cache[x];\n });\n}\n/**\n * Test if a property is supported, returns supported property with vendor\n * prefix if required. Returns `false` if not supported.\n *\n * @param {String} prop dash separated\n * @param {Object} [options]\n * @return {String|Boolean}\n * @api public\n */\n\n\nfunction supportedProperty(prop, options) {\n if (options === void 0) {\n options = {};\n }\n\n // For server-side rendering.\n if (!el) return prop; // Remove cache for benchmark tests or return property from the cache.\n\n if (process.env.NODE_ENV !== 'benchmark' && cache[prop] != null) {\n return cache[prop];\n } // Check if 'transition' or 'transform' natively supported in browser.\n\n\n if (prop === 'transition' || prop === 'transform') {\n options[prop] = prop in el.style;\n } // Find a plugin for current prefix property.\n\n\n for (var i = 0; i < propertyDetectors.length; i++) {\n cache[prop] = propertyDetectors[i](prop, el.style, options); // Break loop, if value found.\n\n if (cache[prop]) break;\n } // Reset styles for current property.\n // Firefox can even throw an error for invalid properties, e.g., \"0\".\n\n\n try {\n el.style[prop] = '';\n } catch (err) {\n return false;\n }\n\n return cache[prop];\n}\n\nvar cache$1 = {};\nvar transitionProperties = {\n transition: 1,\n 'transition-property': 1,\n '-webkit-transition': 1,\n '-webkit-transition-property': 1\n};\nvar transPropsRegExp = /(^\\s*[\\w-]+)|, (\\s*[\\w-]+)(?![^()]*\\))/g;\nvar el$1;\n/**\n * Returns prefixed value transition/transform if needed.\n *\n * @param {String} match\n * @param {String} p1\n * @param {String} p2\n * @return {String}\n * @api private\n */\n\nfunction prefixTransitionCallback(match, p1, p2) {\n if (p1 === 'var') return 'var';\n if (p1 === 'all') return 'all';\n if (p2 === 'all') return ', all';\n var prefixedValue = p1 ? supportedProperty(p1) : \", \" + supportedProperty(p2);\n if (!prefixedValue) return p1 || p2;\n return prefixedValue;\n}\n\nif (isInBrowser) el$1 = document.createElement('p');\n/**\n * Returns prefixed value if needed. Returns `false` if value is not supported.\n *\n * @param {String} property\n * @param {String} value\n * @return {String|Boolean}\n * @api public\n */\n\nfunction supportedValue(property, value) {\n // For server-side rendering.\n var prefixedValue = value;\n if (!el$1 || property === 'content') return value; // It is a string or a number as a string like '1'.\n // We want only prefixable values here.\n // eslint-disable-next-line no-restricted-globals\n\n if (typeof prefixedValue !== 'string' || !isNaN(parseInt(prefixedValue, 10))) {\n return prefixedValue;\n } // Create cache key for current value.\n\n\n var cacheKey = property + prefixedValue; // Remove cache for benchmark tests or return value from cache.\n\n if (process.env.NODE_ENV !== 'benchmark' && cache$1[cacheKey] != null) {\n return cache$1[cacheKey];\n } // IE can even throw an error in some cases, for e.g. style.content = 'bar'.\n\n\n try {\n // Test value as it is.\n el$1.style[property] = prefixedValue;\n } catch (err) {\n // Return false if value not supported.\n cache$1[cacheKey] = false;\n return false;\n } // If 'transition' or 'transition-property' property.\n\n\n if (transitionProperties[property]) {\n prefixedValue = prefixedValue.replace(transPropsRegExp, prefixTransitionCallback);\n } else if (el$1.style[property] === '') {\n // Value with a vendor prefix.\n prefixedValue = prefix.css + prefixedValue; // Hardcode test to convert \"flex\" to \"-ms-flexbox\" for IE10.\n\n if (prefixedValue === '-ms-flex') el$1.style[property] = '-ms-flexbox'; // Test prefixed value.\n\n el$1.style[property] = prefixedValue; // Return false if value not supported.\n\n if (el$1.style[property] === '') {\n cache$1[cacheKey] = false;\n return false;\n }\n } // Reset styles for current property.\n\n\n el$1.style[property] = ''; // Write current value to cache.\n\n cache$1[cacheKey] = prefixedValue;\n return cache$1[cacheKey];\n}\n\nexport { prefix, supportedKeyframes, supportedProperty, supportedValue };\n","import { supportedKeyframes, supportedValue, supportedProperty } from 'css-vendor';\nimport { toCssValue } from 'jss';\n\n/**\n * Add vendor prefix to a property name when needed.\n *\n * @api public\n */\n\nfunction jssVendorPrefixer() {\n function onProcessRule(rule) {\n if (rule.type === 'keyframes') {\n var atRule = rule;\n atRule.at = supportedKeyframes(atRule.at);\n }\n }\n\n function prefixStyle(style) {\n for (var prop in style) {\n var value = style[prop];\n\n if (prop === 'fallbacks' && Array.isArray(value)) {\n style[prop] = value.map(prefixStyle);\n continue;\n }\n\n var changeProp = false;\n var supportedProp = supportedProperty(prop);\n if (supportedProp && supportedProp !== prop) changeProp = true;\n var changeValue = false;\n var supportedValue$$1 = supportedValue(supportedProp, toCssValue(value));\n if (supportedValue$$1 && supportedValue$$1 !== value) changeValue = true;\n\n if (changeProp || changeValue) {\n if (changeProp) delete style[prop];\n style[supportedProp || prop] = supportedValue$$1 || value;\n }\n }\n\n return style;\n }\n\n function onProcessStyle(style, rule) {\n if (rule.type !== 'style') return style;\n return prefixStyle(style);\n }\n\n function onChangeValue(value, prop) {\n return supportedValue(prop, toCssValue(value)) || value;\n }\n\n return {\n onProcessRule: onProcessRule,\n onProcessStyle: onProcessStyle,\n onChangeValue: onChangeValue\n };\n}\n\nexport default jssVendorPrefixer;\n","/**\n * Sort props by length.\n */\nfunction jssPropsSort() {\n var sort = function sort(prop0, prop1) {\n if (prop0.length === prop1.length) {\n return prop0 > prop1 ? 1 : -1;\n }\n\n return prop0.length - prop1.length;\n };\n\n return {\n onProcessStyle: function onProcessStyle(style, rule) {\n if (rule.type !== 'style') return style;\n var newStyle = {};\n var props = Object.keys(style).sort(sort);\n\n for (var i = 0; i < props.length; i++) {\n newStyle[props[i]] = style[props[i]];\n }\n\n return newStyle;\n }\n };\n}\n\nexport default jssPropsSort;\n","import functions from 'jss-plugin-rule-value-function';\nimport global from 'jss-plugin-global';\nimport nested from 'jss-plugin-nested';\nimport camelCase from 'jss-plugin-camel-case';\nimport defaultUnit from 'jss-plugin-default-unit';\nimport vendorPrefixer from 'jss-plugin-vendor-prefixer';\nimport propsSort from 'jss-plugin-props-sort'; // Subset of jss-preset-default with only the plugins the Material-UI components are using.\n\nfunction jssPreset() {\n return {\n plugins: [functions(), global(), nested(), camelCase(), defaultUnit(), // Disable the vendor prefixer server-side, it does nothing.\n // This way, we can get a performance boost.\n // In the documentation, we are using `autoprefixer` to solve this problem.\n typeof window === 'undefined' ? null : vendorPrefixer(), propsSort()]\n };\n}\n\nexport default jssPreset;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nimport createGenerateClassName from '../createGenerateClassName';\nimport { create } from 'jss';\nimport jssPreset from '../jssPreset'; // Default JSS instance.\n\nvar jss = create(jssPreset()); // Use a singleton or the provided one by the context.\n//\n// The counter-based approach doesn't tolerate any mistake.\n// It's much safer to use the same counter everywhere.\n\nvar generateClassName = createGenerateClassName(); // Exported for test purposes\n\nexport var sheetsManager = new Map();\nvar defaultOptions = {\n disableGeneration: false,\n generateClassName: generateClassName,\n jss: jss,\n sheetsCache: null,\n sheetsManager: sheetsManager,\n sheetsRegistry: null\n};\nexport var StylesContext = React.createContext(defaultOptions);\n\nif (process.env.NODE_ENV !== 'production') {\n StylesContext.displayName = 'StylesContext';\n}\n\nvar injectFirstNode;\n\nfunction StylesProvider(props) {\n var children = props.children,\n _props$injectFirst = props.injectFirst,\n injectFirst = _props$injectFirst === void 0 ? false : _props$injectFirst,\n _props$disableGenerat = props.disableGeneration,\n disableGeneration = _props$disableGenerat === void 0 ? false : _props$disableGenerat,\n localOptions = _objectWithoutProperties(props, [\"children\", \"injectFirst\", \"disableGeneration\"]);\n\n var outerOptions = React.useContext(StylesContext);\n\n var context = _extends({}, outerOptions, {\n disableGeneration: disableGeneration\n }, localOptions);\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof window === 'undefined' && !context.sheetsManager) {\n console.error('Material-UI: you need to use the ServerStyleSheets API when rendering on the server.');\n }\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (context.jss.options.insertionPoint && injectFirst) {\n console.error('Material-UI: you cannot use a custom insertionPoint and <StylesContext injectFirst> at the same time.');\n }\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (injectFirst && localOptions.jss) {\n console.error('Material-UI: you cannot use the jss and injectFirst props at the same time.');\n }\n }\n\n if (!context.jss.options.insertionPoint && injectFirst && typeof window !== 'undefined') {\n if (!injectFirstNode) {\n var head = document.head;\n injectFirstNode = document.createComment('mui-inject-first');\n head.insertBefore(injectFirstNode, head.firstChild);\n }\n\n context.jss = create({\n plugins: jssPreset().plugins,\n insertionPoint: injectFirstNode\n });\n }\n\n return React.createElement(StylesContext.Provider, {\n value: context\n }, children);\n}\n\nprocess.env.NODE_ENV !== \"production\" ? StylesProvider.propTypes = {\n /**\n * Your component tree.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * You can disable the generation of the styles with this option.\n * It can be useful when traversing the React tree outside of the HTML\n * rendering step on the server.\n * Let's say you are using react-apollo to extract all\n * the queries made by the interface server-side - you can significantly speed up the traversal with this prop.\n */\n disableGeneration: PropTypes.bool,\n\n /**\n * JSS's class name generator.\n */\n generateClassName: PropTypes.func,\n\n /**\n * By default, the styles are injected last in the <head> element of the page.\n * As a result, they gain more specificity than any other style sheet.\n * If you want to override Material-UI's styles, set this prop.\n */\n injectFirst: PropTypes.bool,\n\n /**\n * JSS's instance.\n */\n jss: PropTypes.object,\n\n /**\n * @ignore\n */\n serverGenerateClassName: PropTypes.func,\n\n /**\n * @ignore\n *\n * Beta feature.\n *\n * Cache for the sheets.\n */\n sheetsCache: PropTypes.object,\n\n /**\n * @ignore\n *\n * The sheetsManager is used to deduplicate style sheet injection in the page.\n * It's deduplicating using the (theme, styles) couple.\n * On the server, you should provide a new instance for each request.\n */\n sheetsManager: PropTypes.object,\n\n /**\n * @ignore\n *\n * Collect the sheets.\n */\n sheetsRegistry: PropTypes.object\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n process.env.NODE_ENV !== \"production\" ? StylesProvider.propTypes = exactProp(StylesProvider.propTypes) : void 0;\n}\n\nexport default StylesProvider;","/* eslint-disable import/prefer-default-export */\n// Global index counter to preserve source order.\n// We create the style sheet during at the creation of the component,\n// children are handled after the parents, so the order of style elements would be parent->child.\n// It is a problem though when a parent passes a className\n// which needs to override any child's styles.\n// StyleSheet of the child has a higher specificity, because of the source order.\n// So our solution is to render sheets them in the reverse order child->sheet, so\n// that parent has a higher specificity.\nvar indexCounter = -1e9;\nexport function increment() {\n indexCounter += 1;\n\n if (process.env.NODE_ENV !== 'production') {\n if (indexCounter >= 0) {\n console.warn(['Material-UI: you might have a memory leak.', 'The indexCounter is not supposed to grow that much.'].join('\\n'));\n }\n }\n\n return indexCounter;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _typeof from \"@babel/runtime/helpers/esm/typeof\";\nimport { deepmerge } from '@material-ui/utils';\nimport noopTheme from './noopTheme';\n\nfunction getStylesCreator(stylesOrCreator) {\n var themingEnabled = typeof stylesOrCreator === 'function';\n\n if (process.env.NODE_ENV !== 'production') {\n if (_typeof(stylesOrCreator) !== 'object' && !themingEnabled) {\n console.error(['Material-UI: the `styles` argument provided is invalid.', 'You need to provide a function generating the styles or a styles object.'].join('\\n'));\n }\n }\n\n return {\n create: function create(theme, name) {\n var styles;\n\n try {\n styles = themingEnabled ? stylesOrCreator(theme) : stylesOrCreator;\n } catch (err) {\n if (process.env.NODE_ENV !== 'production') {\n if (themingEnabled === true && theme === noopTheme) {\n // TODO: prepend error message/name instead\n console.error(['Material-UI: the `styles` argument provided is invalid.', 'You are providing a function without a theme in the context.', 'One of the parent elements needs to use a ThemeProvider.'].join('\\n'));\n }\n }\n\n throw err;\n }\n\n if (!name || !theme.overrides || !theme.overrides[name]) {\n return styles;\n }\n\n var overrides = theme.overrides[name];\n\n var stylesWithOverrides = _extends({}, styles);\n\n Object.keys(overrides).forEach(function (key) {\n if (process.env.NODE_ENV !== 'production') {\n if (!stylesWithOverrides[key]) {\n console.warn(['Material-UI: you are trying to override a style that does not exist.', \"Fix the `\".concat(key, \"` key of `theme.overrides.\").concat(name, \"`.\")].join('\\n'));\n }\n }\n\n stylesWithOverrides[key] = deepmerge(stylesWithOverrides[key], overrides[key]);\n });\n return stylesWithOverrides;\n },\n options: {}\n };\n}\n\nexport default getStylesCreator;","// We use the same empty object to ref count the styles that don't need a theme object.\nvar noopTheme = {};\nexport default noopTheme;","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport { getDynamicStyles } from 'jss';\nimport mergeClasses from '../mergeClasses';\nimport multiKeyStore from './multiKeyStore';\nimport useTheme from '../useTheme';\nimport { StylesContext } from '../StylesProvider';\nimport { increment } from './indexCounter';\nimport getStylesCreator from '../getStylesCreator';\nimport noopTheme from '../getStylesCreator/noopTheme';\n\nfunction getClasses(_ref, classes, Component) {\n var state = _ref.state,\n stylesOptions = _ref.stylesOptions;\n\n if (stylesOptions.disableGeneration) {\n return classes || {};\n }\n\n if (!state.cacheClasses) {\n state.cacheClasses = {\n // Cache for the finalized classes value.\n value: null,\n // Cache for the last used classes prop pointer.\n lastProp: null,\n // Cache for the last used rendered classes pointer.\n lastJSS: {}\n };\n } // Tracks if either the rendered classes or classes prop has changed,\n // requiring the generation of a new finalized classes object.\n\n\n var generate = false;\n\n if (state.classes !== state.cacheClasses.lastJSS) {\n state.cacheClasses.lastJSS = state.classes;\n generate = true;\n }\n\n if (classes !== state.cacheClasses.lastProp) {\n state.cacheClasses.lastProp = classes;\n generate = true;\n }\n\n if (generate) {\n state.cacheClasses.value = mergeClasses({\n baseClasses: state.cacheClasses.lastJSS,\n newClasses: classes,\n Component: Component\n });\n }\n\n return state.cacheClasses.value;\n}\n\nfunction attach(_ref2, props) {\n var state = _ref2.state,\n theme = _ref2.theme,\n stylesOptions = _ref2.stylesOptions,\n stylesCreator = _ref2.stylesCreator,\n name = _ref2.name;\n\n if (stylesOptions.disableGeneration) {\n return;\n }\n\n var sheetManager = multiKeyStore.get(stylesOptions.sheetsManager, stylesCreator, theme);\n\n if (!sheetManager) {\n sheetManager = {\n refs: 0,\n staticSheet: null,\n dynamicStyles: null\n };\n multiKeyStore.set(stylesOptions.sheetsManager, stylesCreator, theme, sheetManager);\n }\n\n var options = _extends({}, stylesCreator.options, {}, stylesOptions, {\n theme: theme,\n flip: typeof stylesOptions.flip === 'boolean' ? stylesOptions.flip : theme.direction === 'rtl'\n });\n\n options.generateId = options.serverGenerateClassName || options.generateClassName;\n var sheetsRegistry = stylesOptions.sheetsRegistry;\n\n if (sheetManager.refs === 0) {\n var staticSheet;\n\n if (stylesOptions.sheetsCache) {\n staticSheet = multiKeyStore.get(stylesOptions.sheetsCache, stylesCreator, theme);\n }\n\n var styles = stylesCreator.create(theme, name);\n\n if (!staticSheet) {\n staticSheet = stylesOptions.jss.createStyleSheet(styles, _extends({\n link: false\n }, options));\n staticSheet.attach();\n\n if (stylesOptions.sheetsCache) {\n multiKeyStore.set(stylesOptions.sheetsCache, stylesCreator, theme, staticSheet);\n }\n }\n\n if (sheetsRegistry) {\n sheetsRegistry.add(staticSheet);\n }\n\n sheetManager.staticSheet = staticSheet;\n sheetManager.dynamicStyles = getDynamicStyles(styles);\n }\n\n if (sheetManager.dynamicStyles) {\n var dynamicSheet = stylesOptions.jss.createStyleSheet(sheetManager.dynamicStyles, _extends({\n link: true\n }, options));\n dynamicSheet.update(props);\n dynamicSheet.attach();\n state.dynamicSheet = dynamicSheet;\n state.classes = mergeClasses({\n baseClasses: sheetManager.staticSheet.classes,\n newClasses: dynamicSheet.classes\n });\n\n if (sheetsRegistry) {\n sheetsRegistry.add(dynamicSheet);\n }\n } else {\n state.classes = sheetManager.staticSheet.classes;\n }\n\n sheetManager.refs += 1;\n}\n\nfunction update(_ref3, props) {\n var state = _ref3.state;\n\n if (state.dynamicSheet) {\n state.dynamicSheet.update(props);\n }\n}\n\nfunction detach(_ref4) {\n var state = _ref4.state,\n theme = _ref4.theme,\n stylesOptions = _ref4.stylesOptions,\n stylesCreator = _ref4.stylesCreator;\n\n if (stylesOptions.disableGeneration) {\n return;\n }\n\n var sheetManager = multiKeyStore.get(stylesOptions.sheetsManager, stylesCreator, theme);\n sheetManager.refs -= 1;\n var sheetsRegistry = stylesOptions.sheetsRegistry;\n\n if (sheetManager.refs === 0) {\n multiKeyStore.delete(stylesOptions.sheetsManager, stylesCreator, theme);\n stylesOptions.jss.removeStyleSheet(sheetManager.staticSheet);\n\n if (sheetsRegistry) {\n sheetsRegistry.remove(sheetManager.staticSheet);\n }\n }\n\n if (state.dynamicSheet) {\n stylesOptions.jss.removeStyleSheet(state.dynamicSheet);\n\n if (sheetsRegistry) {\n sheetsRegistry.remove(state.dynamicSheet);\n }\n }\n}\n\nfunction useSynchronousEffect(func, values) {\n var key = React.useRef([]);\n var output; // Store \"generation\" key. Just returns a new object every time\n\n var currentKey = React.useMemo(function () {\n return {};\n }, values); // eslint-disable-line react-hooks/exhaustive-deps\n // \"the first render\", or \"memo dropped the value\"\n\n if (key.current !== currentKey) {\n key.current = currentKey;\n output = func();\n }\n\n React.useEffect(function () {\n return function () {\n if (output) {\n output();\n }\n };\n }, [currentKey] // eslint-disable-line react-hooks/exhaustive-deps\n );\n}\n\nfunction makeStyles(stylesOrCreator) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var name = options.name,\n classNamePrefixOption = options.classNamePrefix,\n Component = options.Component,\n _options$defaultTheme = options.defaultTheme,\n defaultTheme = _options$defaultTheme === void 0 ? noopTheme : _options$defaultTheme,\n stylesOptions2 = _objectWithoutProperties(options, [\"name\", \"classNamePrefix\", \"Component\", \"defaultTheme\"]);\n\n var stylesCreator = getStylesCreator(stylesOrCreator);\n var classNamePrefix = name || classNamePrefixOption || 'makeStyles';\n stylesCreator.options = {\n index: increment(),\n name: name,\n meta: classNamePrefix,\n classNamePrefix: classNamePrefix\n };\n return function () {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var theme = useTheme() || defaultTheme;\n\n var stylesOptions = _extends({}, React.useContext(StylesContext), {}, stylesOptions2);\n\n var instance = React.useRef();\n var shouldUpdate = React.useRef();\n useSynchronousEffect(function () {\n var current = {\n name: name,\n state: {},\n stylesCreator: stylesCreator,\n stylesOptions: stylesOptions,\n theme: theme\n };\n attach(current, props);\n shouldUpdate.current = false;\n instance.current = current;\n return function () {\n detach(current);\n };\n }, [theme, stylesCreator]);\n React.useEffect(function () {\n if (shouldUpdate.current) {\n update(instance.current, props);\n }\n\n shouldUpdate.current = true;\n });\n return getClasses(instance.current, props.classes, Component);\n };\n}\n\nexport default makeStyles;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport { useFormControl } from '../FormControl';\nimport withStyles from '../styles/withStyles';\nimport Typography from '../Typography';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n cursor: 'pointer',\n // For correct alignment with the text.\n verticalAlign: 'middle',\n WebkitTapHighlightColor: 'transparent',\n marginLeft: -11,\n marginRight: 16,\n // used for row presentation of radio/checkbox\n '&$disabled': {\n cursor: 'default'\n }\n },\n\n /* Styles applied to the root element if `labelPlacement=\"start\"`. */\n labelPlacementStart: {\n flexDirection: 'row-reverse',\n marginLeft: 16,\n // used for row presentation of radio/checkbox\n marginRight: -11\n },\n\n /* Styles applied to the root element if `labelPlacement=\"top\"`. */\n labelPlacementTop: {\n flexDirection: 'column-reverse',\n marginLeft: 16\n },\n\n /* Styles applied to the root element if `labelPlacement=\"bottom\"`. */\n labelPlacementBottom: {\n flexDirection: 'column',\n marginLeft: 16\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the label's Typography component. */\n label: {\n '&$disabled': {\n color: theme.palette.text.disabled\n }\n }\n };\n};\n/**\n * Drop in replacement of the `Radio`, `Switch` and `Checkbox` component.\n * Use this component if you want to display an extra label.\n */\n\nvar FormControlLabel = React.forwardRef(function FormControlLabel(props, ref) {\n var checked = props.checked,\n classes = props.classes,\n className = props.className,\n control = props.control,\n disabledProp = props.disabled,\n inputRef = props.inputRef,\n label = props.label,\n _props$labelPlacement = props.labelPlacement,\n labelPlacement = _props$labelPlacement === void 0 ? 'end' : _props$labelPlacement,\n name = props.name,\n onChange = props.onChange,\n value = props.value,\n other = _objectWithoutProperties(props, [\"checked\", \"classes\", \"className\", \"control\", \"disabled\", \"inputRef\", \"label\", \"labelPlacement\", \"name\", \"onChange\", \"value\"]);\n\n var muiFormControl = useFormControl();\n var disabled = disabledProp;\n\n if (typeof disabled === 'undefined' && typeof control.props.disabled !== 'undefined') {\n disabled = control.props.disabled;\n }\n\n if (typeof disabled === 'undefined' && muiFormControl) {\n disabled = muiFormControl.disabled;\n }\n\n var controlProps = {\n disabled: disabled\n };\n ['checked', 'name', 'onChange', 'value', 'inputRef'].forEach(function (key) {\n if (typeof control.props[key] === 'undefined' && typeof props[key] !== 'undefined') {\n controlProps[key] = props[key];\n }\n });\n return React.createElement(\"label\", _extends({\n className: clsx(classes.root, className, labelPlacement !== 'end' && classes[\"labelPlacement\".concat(capitalize(labelPlacement))], disabled && classes.disabled),\n ref: ref\n }, other), React.cloneElement(control, controlProps), React.createElement(Typography, {\n component: \"span\",\n className: clsx(classes.label, disabled && classes.disabled)\n }, label));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormControlLabel.propTypes = {\n /**\n * If `true`, the component appears selected.\n */\n checked: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * A control element. For instance, it can be be a `Radio`, a `Switch` or a `Checkbox`.\n */\n control: PropTypes.element,\n\n /**\n * If `true`, the control will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * The text to be used in an enclosing label element.\n */\n label: PropTypes.node,\n\n /**\n * The position of the label.\n */\n labelPlacement: PropTypes.oneOf(['end', 'start', 'top', 'bottom']),\n\n /*\n * @ignore\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * The value of the component.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormControlLabel'\n})(FormControlLabel);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { getDisplayName } from '@material-ui/utils';\n\nfunction mergeClasses() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var baseClasses = options.baseClasses,\n newClasses = options.newClasses,\n Component = options.Component;\n\n if (!newClasses) {\n return baseClasses;\n }\n\n var nextClasses = _extends({}, baseClasses);\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof newClasses === 'string') {\n console.error([\"Material-UI: the value `\".concat(newClasses, \"` \") + \"provided to the classes prop of \".concat(getDisplayName(Component), \" is incorrect.\"), 'You might want to use the className prop instead.'].join('\\n'));\n return baseClasses;\n }\n }\n\n Object.keys(newClasses).forEach(function (key) {\n if (process.env.NODE_ENV !== 'production') {\n if (!baseClasses[key] && newClasses[key]) {\n console.error([\"Material-UI: the key `\".concat(key, \"` \") + \"provided to the classes prop is not implemented in \".concat(getDisplayName(Component), \".\"), \"You can only override one of the following: \".concat(Object.keys(baseClasses).join(','), \".\")].join('\\n'));\n }\n\n if (newClasses[key] && typeof newClasses[key] !== 'string') {\n console.error([\"Material-UI: the key `\".concat(key, \"` \") + \"provided to the classes prop is not valid for \".concat(getDisplayName(Component), \".\"), \"You need to provide a non empty string instead of: \".concat(newClasses[key], \".\")].join('\\n'));\n }\n }\n\n if (newClasses[key]) {\n nextClasses[key] = \"\".concat(baseClasses[key], \" \").concat(newClasses[key]);\n }\n });\n return nextClasses;\n}\n\nexport default mergeClasses;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _typeof from \"@babel/runtime/helpers/esm/typeof\";\nexport function isObject(item) {\n return item && _typeof(item) === 'object' && !Array.isArray(item);\n}\nexport default function deepmerge(target, source) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n clone: true\n };\n var output = options.clone ? _extends({}, target) : target;\n\n if (isObject(target) && isObject(source)) {\n Object.keys(source).forEach(function (key) {\n // Avoid prototype pollution\n if (key === '__proto__') {\n return;\n }\n\n if (isObject(source[key]) && key in target) {\n output[key] = deepmerge(target[key], source[key], options);\n } else {\n output[key] = source[key];\n }\n });\n }\n\n return output;\n}","/* eslint-disable no-restricted-syntax */\nfunction getThemeProps(params) {\n var theme = params.theme,\n name = params.name,\n props = params.props;\n\n if (!theme || !theme.props || !theme.props[name]) {\n return props;\n } // Resolve default props, code borrow from React source.\n // https://github.com/facebook/react/blob/15a8f031838a553e41c0b66eb1bcf1da8448104d/packages/react/src/ReactElement.js#L221\n\n\n var defaultProps = theme.props[name];\n var propName;\n\n for (propName in defaultProps) {\n if (props[propName] === undefined) {\n props[propName] = defaultProps[propName];\n }\n }\n\n return props;\n}\n\nexport default getThemeProps;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n// @inheritedComponent IconButton\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport { fade } from '../styles/colorManipulator';\nimport capitalize from '../utils/capitalize';\nimport SwitchBase from '../internal/SwitchBase';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n width: 34 + 12 * 2,\n height: 14 + 12 * 2,\n overflow: 'hidden',\n padding: 12,\n boxSizing: 'border-box',\n position: 'relative',\n flexShrink: 0,\n zIndex: 0,\n // Reset the stacking context.\n verticalAlign: 'middle' // For correct alignment with the text.\n\n },\n\n /* Styles applied to the root element if `edge=\"start\"`. */\n edgeStart: {\n marginLeft: -8\n },\n\n /* Styles applied to the root element if `edge=\"end\"`. */\n edgeEnd: {\n marginRight: -8\n },\n\n /* Styles applied to the internal `SwitchBase` component's `root` class. */\n switchBase: {\n position: 'absolute',\n top: 0,\n left: 0,\n zIndex: 1,\n // Render above the focus ripple.\n color: theme.palette.type === 'light' ? theme.palette.grey[50] : theme.palette.grey[400],\n transition: theme.transitions.create(['left', 'transform'], {\n duration: theme.transitions.duration.shortest\n }),\n '&$checked': {\n transform: 'translateX(20px)'\n },\n '&$disabled': {\n color: theme.palette.type === 'light' ? theme.palette.grey[400] : theme.palette.grey[800]\n },\n '&$checked + $track': {\n opacity: 0.5\n },\n '&$disabled + $track': {\n opacity: theme.palette.type === 'light' ? 0.12 : 0.1\n }\n },\n\n /* Styles applied to the internal SwitchBase component's root element if `color=\"primary\"`. */\n colorPrimary: {\n '&$checked': {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.type === 'light' ? theme.palette.grey[400] : theme.palette.grey[800]\n },\n '&$checked + $track': {\n backgroundColor: theme.palette.primary.main\n },\n '&$disabled + $track': {\n backgroundColor: theme.palette.type === 'light' ? theme.palette.common.black : theme.palette.common.white\n }\n },\n\n /* Styles applied to the internal SwitchBase component's root element if `color=\"secondary\"`. */\n colorSecondary: {\n '&$checked': {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.type === 'light' ? theme.palette.grey[400] : theme.palette.grey[800]\n },\n '&$checked + $track': {\n backgroundColor: theme.palette.secondary.main\n },\n '&$disabled + $track': {\n backgroundColor: theme.palette.type === 'light' ? theme.palette.common.black : theme.palette.common.white\n }\n },\n\n /* Styles applied to the root element if `size=\"small\"`. */\n sizeSmall: {\n width: 40,\n height: 24,\n padding: 7,\n '& $thumb': {\n width: 16,\n height: 16\n },\n '& $switchBase': {\n padding: 4,\n '&$checked': {\n transform: 'translateX(16px)'\n }\n }\n },\n\n /* Pseudo-class applied to the internal `SwitchBase` component's `checked` class. */\n checked: {},\n\n /* Pseudo-class applied to the internal SwitchBase component's disabled class. */\n disabled: {},\n\n /* Styles applied to the internal SwitchBase component's input element. */\n input: {\n left: '-100%',\n width: '300%'\n },\n\n /* Styles used to create the thumb passed to the internal `SwitchBase` component `icon` prop. */\n thumb: {\n boxShadow: theme.shadows[1],\n backgroundColor: 'currentColor',\n width: 20,\n height: 20,\n borderRadius: '50%'\n },\n\n /* Styles applied to the track element. */\n track: {\n height: '100%',\n width: '100%',\n borderRadius: 14 / 2,\n zIndex: -1,\n transition: theme.transitions.create(['opacity', 'background-color'], {\n duration: theme.transitions.duration.shortest\n }),\n backgroundColor: theme.palette.type === 'light' ? theme.palette.common.black : theme.palette.common.white,\n opacity: theme.palette.type === 'light' ? 0.38 : 0.3\n }\n };\n};\nvar Switch = React.forwardRef(function Switch(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'secondary' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$edge = props.edge,\n edge = _props$edge === void 0 ? false : _props$edge,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"color\", \"disabled\", \"edge\", \"size\"]);\n\n var icon = React.createElement(\"span\", {\n className: classes.thumb\n });\n return React.createElement(\"span\", {\n className: clsx(classes.root, className, {\n start: classes.edgeStart,\n end: classes.edgeEnd\n }[edge], {\n small: classes[\"size\".concat(capitalize(size))]\n }[size])\n }, React.createElement(SwitchBase, _extends({\n type: \"checkbox\",\n icon: icon,\n checkedIcon: icon,\n classes: {\n root: clsx(classes.switchBase, classes[\"color\".concat(capitalize(color))]),\n input: classes.input,\n checked: classes.checked,\n disabled: classes.disabled\n },\n ref: ref,\n disabled: disabled\n }, other)), React.createElement(\"span\", {\n className: classes.track\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? Switch.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary', 'default']),\n\n /**\n * @ignore\n */\n defaultChecked: PropTypes.bool,\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * If given, uses a negative margin to counteract the padding on one\n * side (this is often helpful for aligning the left or right\n * side of the icon with content above or below, without ruining the border\n * size and shape).\n */\n edge: PropTypes.oneOf(['start', 'end', false]),\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the switch.\n * `small` is equivalent to the dense switch styling.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string,\n\n /**\n * The value of the component. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiSwitch'\n})(Switch);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { makeStyles as makeStylesWithoutDefault } from '@material-ui/styles';\nimport defaultTheme from './defaultTheme';\n\nfunction makeStyles(stylesOrCreator) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return makeStylesWithoutDefault(stylesOrCreator, _extends({\n defaultTheme: defaultTheme\n }, options));\n}\n\nexport default makeStyles;","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var elevations = {};\n theme.shadows.forEach(function (shadow, index) {\n elevations[\"elevation\".concat(index)] = {\n boxShadow: shadow\n };\n });\n return _extends({\n /* Styles applied to the root element. */\n root: {\n backgroundColor: theme.palette.background.paper,\n color: theme.palette.text.primary,\n transition: theme.transitions.create('box-shadow')\n },\n\n /* Styles applied to the root element if `square={false}`. */\n rounded: {\n borderRadius: theme.shape.borderRadius\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"` */\n outlined: {\n border: \"1px solid \".concat(theme.palette.divider)\n }\n }, elevations);\n};\nvar Paper = React.forwardRef(function Paper(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$square = props.square,\n square = _props$square === void 0 ? false : _props$square,\n _props$elevation = props.elevation,\n elevation = _props$elevation === void 0 ? 1 : _props$elevation,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'elevation' : _props$variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"square\", \"elevation\", \"variant\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (classes[\"elevation\".concat(elevation)] === undefined) {\n console.error(\"Material-UI: this elevation `\".concat(elevation, \"` is not implemented.\"));\n }\n }\n\n return React.createElement(Component, _extends({\n className: clsx(classes.root, className, variant === 'outlined' ? classes.outlined : classes[\"elevation\".concat(elevation)], !square && classes.rounded),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Paper.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * Shadow depth, corresponds to `dp` in the spec.\n * It accepts values between 0 and 24 inclusive.\n */\n elevation: PropTypes.number,\n\n /**\n * If `true`, rounded corners are disabled.\n */\n square: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['elevation', 'outlined'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiPaper'\n})(Paper);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\n// A grid component using the following libs as inspiration.\n//\n// For the implementation:\n// - https://getbootstrap.com/docs/4.3/layout/grid/\n// - https://github.com/kristoferjoseph/flexboxgrid/blob/master/src/css/flexboxgrid.css\n// - https://github.com/roylee0704/react-flexbox-grid\n// - https://material.angularjs.org/latest/layout/introduction\n//\n// Follow this flexbox Guide to better understand the underlying model:\n// - https://css-tricks.com/snippets/css/a-guide-to-flexbox/\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport requirePropFactory from '../utils/requirePropFactory';\nvar SPACINGS = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];\nvar GRID_SIZES = ['auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12];\n\nfunction generateGrid(globalStyles, theme, breakpoint) {\n var styles = {};\n GRID_SIZES.forEach(function (size) {\n var key = \"grid-\".concat(breakpoint, \"-\").concat(size);\n\n if (size === true) {\n // For the auto layouting\n styles[key] = {\n flexBasis: 0,\n flexGrow: 1,\n maxWidth: '100%'\n };\n return;\n }\n\n if (size === 'auto') {\n styles[key] = {\n flexBasis: 'auto',\n flexGrow: 0,\n maxWidth: 'none'\n };\n return;\n } // Keep 7 significant numbers.\n\n\n var width = \"\".concat(Math.round(size / 12 * 10e7) / 10e5, \"%\"); // Close to the bootstrap implementation:\n // https://github.com/twbs/bootstrap/blob/8fccaa2439e97ec72a4b7dc42ccc1f649790adb0/scss/mixins/_grid.scss#L41\n\n styles[key] = {\n flexBasis: width,\n flexGrow: 0,\n maxWidth: width\n };\n }); // No need for a media query for the first size.\n\n if (breakpoint === 'xs') {\n _extends(globalStyles, styles);\n } else {\n globalStyles[theme.breakpoints.up(breakpoint)] = styles;\n }\n}\n\nfunction getOffset(val) {\n var div = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n var parse = parseFloat(val);\n return \"\".concat(parse / div).concat(String(val).replace(String(parse), '') || 'px');\n}\n\nfunction generateGutter(theme, breakpoint) {\n var styles = {};\n SPACINGS.forEach(function (spacing) {\n var themeSpacing = theme.spacing(spacing);\n\n if (themeSpacing === 0) {\n return;\n }\n\n styles[\"spacing-\".concat(breakpoint, \"-\").concat(spacing)] = {\n margin: \"-\".concat(getOffset(themeSpacing, 2)),\n width: \"calc(100% + \".concat(getOffset(themeSpacing), \")\"),\n '& > $item': {\n padding: getOffset(themeSpacing, 2)\n }\n };\n });\n return styles;\n} // Default CSS values\n// flex: '0 1 auto',\n// flexDirection: 'row',\n// alignItems: 'flex-start',\n// flexWrap: 'nowrap',\n// justifyContent: 'flex-start',\n\n\nexport var styles = function styles(theme) {\n return _extends({\n /* Styles applied to the root element */\n root: {},\n\n /* Styles applied to the root element if `container={true}`. */\n container: {\n boxSizing: 'border-box',\n display: 'flex',\n flexWrap: 'wrap',\n width: '100%'\n },\n\n /* Styles applied to the root element if `item={true}`. */\n item: {\n boxSizing: 'border-box',\n margin: '0' // For instance, it's useful when used with a `figure` element.\n\n },\n\n /* Styles applied to the root element if `zeroMinWidth={true}`. */\n zeroMinWidth: {\n minWidth: 0\n },\n\n /* Styles applied to the root element if `direction=\"column\"`. */\n 'direction-xs-column': {\n flexDirection: 'column'\n },\n\n /* Styles applied to the root element if `direction=\"column-reverse\"`. */\n 'direction-xs-column-reverse': {\n flexDirection: 'column-reverse'\n },\n\n /* Styles applied to the root element if `direction=\"rwo-reverse\"`. */\n 'direction-xs-row-reverse': {\n flexDirection: 'row-reverse'\n },\n\n /* Styles applied to the root element if `wrap=\"nowrap\"`. */\n 'wrap-xs-nowrap': {\n flexWrap: 'nowrap'\n },\n\n /* Styles applied to the root element if `wrap=\"reverse\"`. */\n 'wrap-xs-wrap-reverse': {\n flexWrap: 'wrap-reverse'\n },\n\n /* Styles applied to the root element if `alignItems=\"center\"`. */\n 'align-items-xs-center': {\n alignItems: 'center'\n },\n\n /* Styles applied to the root element if `alignItems=\"flex-start\"`. */\n 'align-items-xs-flex-start': {\n alignItems: 'flex-start'\n },\n\n /* Styles applied to the root element if `alignItems=\"flex-end\"`. */\n 'align-items-xs-flex-end': {\n alignItems: 'flex-end'\n },\n\n /* Styles applied to the root element if `alignItems=\"baseline\"`. */\n 'align-items-xs-baseline': {\n alignItems: 'baseline'\n },\n\n /* Styles applied to the root element if `alignContent=\"center\"`. */\n 'align-content-xs-center': {\n alignContent: 'center'\n },\n\n /* Styles applied to the root element if `alignContent=\"flex-start\"`. */\n 'align-content-xs-flex-start': {\n alignContent: 'flex-start'\n },\n\n /* Styles applied to the root element if `alignContent=\"flex-end\"`. */\n 'align-content-xs-flex-end': {\n alignContent: 'flex-end'\n },\n\n /* Styles applied to the root element if `alignContent=\"space-between\"`. */\n 'align-content-xs-space-between': {\n alignContent: 'space-between'\n },\n\n /* Styles applied to the root element if `alignContent=\"space-around\"`. */\n 'align-content-xs-space-around': {\n alignContent: 'space-around'\n },\n\n /* Styles applied to the root element if `justify=\"center\"`. */\n 'justify-xs-center': {\n justifyContent: 'center'\n },\n\n /* Styles applied to the root element if `justify=\"flex-end\"`. */\n 'justify-xs-flex-end': {\n justifyContent: 'flex-end'\n },\n\n /* Styles applied to the root element if `justify=\"space-between\"`. */\n 'justify-xs-space-between': {\n justifyContent: 'space-between'\n },\n\n /* Styles applied to the root element if `justify=\"space-around\"`. */\n 'justify-xs-space-around': {\n justifyContent: 'space-around'\n },\n\n /* Styles applied to the root element if `justify=\"space-evenly\"`. */\n 'justify-xs-space-evenly': {\n justifyContent: 'space-evenly'\n }\n }, generateGutter(theme, 'xs'), {}, theme.breakpoints.keys.reduce(function (accumulator, key) {\n // Use side effect over immutability for better performance.\n generateGrid(accumulator, theme, key);\n return accumulator;\n }, {}));\n};\nvar Grid = React.forwardRef(function Grid(props, ref) {\n var _props$alignContent = props.alignContent,\n alignContent = _props$alignContent === void 0 ? 'stretch' : _props$alignContent,\n _props$alignItems = props.alignItems,\n alignItems = _props$alignItems === void 0 ? 'stretch' : _props$alignItems,\n classes = props.classes,\n classNameProp = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$container = props.container,\n container = _props$container === void 0 ? false : _props$container,\n _props$direction = props.direction,\n direction = _props$direction === void 0 ? 'row' : _props$direction,\n _props$item = props.item,\n item = _props$item === void 0 ? false : _props$item,\n _props$justify = props.justify,\n justify = _props$justify === void 0 ? 'flex-start' : _props$justify,\n _props$lg = props.lg,\n lg = _props$lg === void 0 ? false : _props$lg,\n _props$md = props.md,\n md = _props$md === void 0 ? false : _props$md,\n _props$sm = props.sm,\n sm = _props$sm === void 0 ? false : _props$sm,\n _props$spacing = props.spacing,\n spacing = _props$spacing === void 0 ? 0 : _props$spacing,\n _props$wrap = props.wrap,\n wrap = _props$wrap === void 0 ? 'wrap' : _props$wrap,\n _props$xl = props.xl,\n xl = _props$xl === void 0 ? false : _props$xl,\n _props$xs = props.xs,\n xs = _props$xs === void 0 ? false : _props$xs,\n _props$zeroMinWidth = props.zeroMinWidth,\n zeroMinWidth = _props$zeroMinWidth === void 0 ? false : _props$zeroMinWidth,\n other = _objectWithoutProperties(props, [\"alignContent\", \"alignItems\", \"classes\", \"className\", \"component\", \"container\", \"direction\", \"item\", \"justify\", \"lg\", \"md\", \"sm\", \"spacing\", \"wrap\", \"xl\", \"xs\", \"zeroMinWidth\"]);\n\n var className = clsx(classes.root, classNameProp, container && [classes.container, spacing !== 0 && classes[\"spacing-xs-\".concat(String(spacing))]], item && classes.item, zeroMinWidth && classes.zeroMinWidth, direction !== 'row' && classes[\"direction-xs-\".concat(String(direction))], wrap !== 'wrap' && classes[\"wrap-xs-\".concat(String(wrap))], alignItems !== 'stretch' && classes[\"align-items-xs-\".concat(String(alignItems))], alignContent !== 'stretch' && classes[\"align-content-xs-\".concat(String(alignContent))], justify !== 'flex-start' && classes[\"justify-xs-\".concat(String(justify))], xs !== false && classes[\"grid-xs-\".concat(String(xs))], sm !== false && classes[\"grid-sm-\".concat(String(sm))], md !== false && classes[\"grid-md-\".concat(String(md))], lg !== false && classes[\"grid-lg-\".concat(String(lg))], xl !== false && classes[\"grid-xl-\".concat(String(xl))]);\n return React.createElement(Component, _extends({\n className: className,\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Grid.propTypes = {\n /**\n * Defines the `align-content` style property.\n * It's applied for all screen sizes.\n */\n alignContent: PropTypes.oneOf(['stretch', 'center', 'flex-start', 'flex-end', 'space-between', 'space-around']),\n\n /**\n * Defines the `align-items` style property.\n * It's applied for all screen sizes.\n */\n alignItems: PropTypes.oneOf(['flex-start', 'center', 'flex-end', 'stretch', 'baseline']),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the component will have the flex *container* behavior.\n * You should be wrapping *items* with a *container*.\n */\n container: PropTypes.bool,\n\n /**\n * Defines the `flex-direction` style property.\n * It is applied for all screen sizes.\n */\n direction: PropTypes.oneOf(['row', 'row-reverse', 'column', 'column-reverse']),\n\n /**\n * If `true`, the component will have the flex *item* behavior.\n * You should be wrapping *items* with a *container*.\n */\n item: PropTypes.bool,\n\n /**\n * Defines the `justify-content` style property.\n * It is applied for all screen sizes.\n */\n justify: PropTypes.oneOf(['flex-start', 'center', 'flex-end', 'space-between', 'space-around', 'space-evenly']),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `lg` breakpoint and wider screens if not overridden.\n */\n lg: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `md` breakpoint and wider screens if not overridden.\n */\n md: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `sm` breakpoint and wider screens if not overridden.\n */\n sm: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the space between the type `item` component.\n * It can only be used on a type `container` component.\n */\n spacing: PropTypes.oneOf(SPACINGS),\n\n /**\n * Defines the `flex-wrap` style property.\n * It's applied for all screen sizes.\n */\n wrap: PropTypes.oneOf(['nowrap', 'wrap', 'wrap-reverse']),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `xl` breakpoint and wider screens.\n */\n xl: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for all the screen sizes with the lowest priority.\n */\n xs: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * If `true`, it sets `min-width: 0` on the item.\n * Refer to the limitations section of the documentation to better understand the use case.\n */\n zeroMinWidth: PropTypes.bool\n} : void 0;\nvar StyledGrid = withStyles(styles, {\n name: 'MuiGrid'\n})(Grid);\n\nif (process.env.NODE_ENV !== 'production') {\n var requireProp = requirePropFactory('Grid');\n StyledGrid.propTypes = _extends({}, StyledGrid.propTypes, {\n alignContent: requireProp('container'),\n alignItems: requireProp('container'),\n direction: requireProp('container'),\n justify: requireProp('container'),\n lg: requireProp('item'),\n md: requireProp('item'),\n sm: requireProp('item'),\n spacing: requireProp('container'),\n wrap: requireProp('container'),\n xs: requireProp('item'),\n zeroMinWidth: requireProp('item')\n });\n}\n\nexport default StyledGrid;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport InputBase from '../InputBase';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var light = theme.palette.type === 'light';\n var bottomLineColor = light ? 'rgba(0, 0, 0, 0.42)' : 'rgba(255, 255, 255, 0.7)';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'relative'\n },\n\n /* Styles applied to the root element if the component is a descendant of `FormControl`. */\n formControl: {\n 'label + &': {\n marginTop: 16\n }\n },\n\n /* Styles applied to the root element if the component is focused. */\n focused: {},\n\n /* Styles applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if color secondary. */\n colorSecondary: {\n '&$underline:after': {\n borderBottomColor: theme.palette.secondary.main\n }\n },\n\n /* Styles applied to the root element if `disableUnderline={false}`. */\n underline: {\n '&:after': {\n borderBottom: \"2px solid \".concat(theme.palette.primary.main),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\"',\n position: 'absolute',\n right: 0,\n transform: 'scaleX(0)',\n transition: theme.transitions.create('transform', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&$focused:after': {\n transform: 'scaleX(1)'\n },\n '&$error:after': {\n borderBottomColor: theme.palette.error.main,\n transform: 'scaleX(1)' // error is always underlined in red\n\n },\n '&:before': {\n borderBottom: \"1px solid \".concat(bottomLineColor),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\\\\00a0\"',\n position: 'absolute',\n right: 0,\n transition: theme.transitions.create('border-bottom-color', {\n duration: theme.transitions.duration.shorter\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&:hover:not($disabled):before': {\n borderBottom: \"2px solid \".concat(theme.palette.text.primary),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n borderBottom: \"1px solid \".concat(bottomLineColor)\n }\n },\n '&$disabled:before': {\n borderBottomStyle: 'dotted'\n }\n },\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {},\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {},\n\n /* Styles applied to the `input` element. */\n input: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {},\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {},\n\n /* Styles applied to the `input` element if `type=\"search\"`. */\n inputTypeSearch: {}\n };\n};\nvar Input = React.forwardRef(function Input(props, ref) {\n var disableUnderline = props.disableUnderline,\n classes = props.classes,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n other = _objectWithoutProperties(props, [\"disableUnderline\", \"classes\", \"fullWidth\", \"inputComponent\", \"multiline\", \"type\"]);\n\n return React.createElement(InputBase, _extends({\n classes: _extends({}, classes, {\n root: clsx(classes.root, !disableUnderline && classes.underline),\n underline: null\n }),\n fullWidth: fullWidth,\n inputComponent: inputComponent,\n multiline: multiline,\n ref: ref,\n type: type\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Input.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the input will not have an underline.\n */\n disableUnderline: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the native input.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nInput.muiName = 'Input';\nexport default withStyles(styles, {\n name: 'MuiInput'\n})(Input);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport InputBase from '../InputBase';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var light = theme.palette.type === 'light';\n var bottomLineColor = light ? 'rgba(0, 0, 0, 0.42)' : 'rgba(255, 255, 255, 0.7)';\n var backgroundColor = light ? 'rgba(0, 0, 0, 0.09)' : 'rgba(255, 255, 255, 0.09)';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'relative',\n backgroundColor: backgroundColor,\n borderTopLeftRadius: theme.shape.borderRadius,\n borderTopRightRadius: theme.shape.borderRadius,\n transition: theme.transitions.create('background-color', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n }),\n '&:hover': {\n backgroundColor: light ? 'rgba(0, 0, 0, 0.13)' : 'rgba(255, 255, 255, 0.13)',\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: backgroundColor\n }\n },\n '&$focused': {\n backgroundColor: light ? 'rgba(0, 0, 0, 0.09)' : 'rgba(255, 255, 255, 0.09)'\n },\n '&$disabled': {\n backgroundColor: light ? 'rgba(0, 0, 0, 0.12)' : 'rgba(255, 255, 255, 0.12)'\n }\n },\n\n /* Styles applied to the root element if color secondary. */\n colorSecondary: {\n '&$underline:after': {\n borderBottomColor: theme.palette.secondary.main\n }\n },\n\n /* Styles applied to the root element if `disableUnderline={false}`. */\n underline: {\n '&:after': {\n borderBottom: \"2px solid \".concat(theme.palette.primary.main),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\"',\n position: 'absolute',\n right: 0,\n transform: 'scaleX(0)',\n transition: theme.transitions.create('transform', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&$focused:after': {\n transform: 'scaleX(1)'\n },\n '&$error:after': {\n borderBottomColor: theme.palette.error.main,\n transform: 'scaleX(1)' // error is always underlined in red\n\n },\n '&:before': {\n borderBottom: \"1px solid \".concat(bottomLineColor),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\\\\00a0\"',\n position: 'absolute',\n right: 0,\n transition: theme.transitions.create('border-bottom-color', {\n duration: theme.transitions.duration.shorter\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&:hover:before': {\n borderBottom: \"1px solid \".concat(theme.palette.text.primary)\n },\n '&$disabled:before': {\n borderBottomStyle: 'dotted'\n }\n },\n\n /* Pseudo-class applied to the root element if the component is focused. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `startAdornment` is provided. */\n adornedStart: {\n paddingLeft: 12\n },\n\n /* Styles applied to the root element if `endAdornment` is provided. */\n adornedEnd: {\n paddingRight: 12\n },\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {\n padding: '27px 12px 10px',\n '&$marginDense': {\n paddingTop: 23,\n paddingBottom: 6\n }\n },\n\n /* Styles applied to the `input` element. */\n input: {\n padding: '27px 12px 10px',\n '&:-webkit-autofill': {\n WebkitBoxShadow: theme.palette.type === 'dark' ? '0 0 0 100px #266798 inset' : null,\n WebkitTextFillColor: theme.palette.type === 'dark' ? '#fff' : null,\n borderTopLeftRadius: 'inherit',\n borderTopRightRadius: 'inherit'\n }\n },\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {\n paddingTop: 23,\n paddingBottom: 6\n },\n\n /* Styles applied to the `input` if in `<FormControl hiddenLabel />`. */\n inputHiddenLabel: {\n paddingTop: 18,\n paddingBottom: 19,\n '&$inputMarginDense': {\n paddingTop: 10,\n paddingBottom: 11\n }\n },\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {\n padding: 0\n },\n\n /* Styles applied to the `input` element if `startAdornment` is provided. */\n inputAdornedStart: {\n paddingLeft: 0\n },\n\n /* Styles applied to the `input` element if `endAdornment` is provided. */\n inputAdornedEnd: {\n paddingRight: 0\n }\n };\n};\nvar FilledInput = React.forwardRef(function FilledInput(props, ref) {\n var disableUnderline = props.disableUnderline,\n classes = props.classes,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n other = _objectWithoutProperties(props, [\"disableUnderline\", \"classes\", \"fullWidth\", \"inputComponent\", \"multiline\", \"type\"]);\n\n return React.createElement(InputBase, _extends({\n classes: _extends({}, classes, {\n root: clsx(classes.root, !disableUnderline && classes.underline),\n underline: null\n }),\n fullWidth: fullWidth,\n inputComponent: inputComponent,\n multiline: multiline,\n ref: ref,\n type: type\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? FilledInput.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the input will not have an underline.\n */\n disableUnderline: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the native input.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nFilledInput.muiName = 'Input';\nexport default withStyles(styles, {\n name: 'MuiFilledInput'\n})(FilledInput);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport { fade } from '../styles/colorManipulator';\nimport ButtonBase from '../ButtonBase';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({}, theme.typography.button, {\n boxSizing: 'border-box',\n minWidth: 64,\n padding: '6px 16px',\n borderRadius: theme.shape.borderRadius,\n color: theme.palette.text.primary,\n transition: theme.transitions.create(['background-color', 'box-shadow', 'border'], {\n duration: theme.transitions.duration.short\n }),\n '&:hover': {\n textDecoration: 'none',\n backgroundColor: fade(theme.palette.text.primary, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n },\n '&$disabled': {\n backgroundColor: 'transparent'\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n }),\n\n /* Styles applied to the span element that wraps the children. */\n label: {\n width: '100%',\n // Ensure the correct width for iOS Safari\n display: 'inherit',\n alignItems: 'inherit',\n justifyContent: 'inherit'\n },\n\n /* Styles applied to the root element if `variant=\"text\"`. */\n text: {\n padding: '6px 8px'\n },\n\n /* Styles applied to the root element if `variant=\"text\"` and `color=\"primary\"`. */\n textPrimary: {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"text\"` and `color=\"secondary\"`. */\n textSecondary: {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"`. */\n outlined: {\n padding: '5px 15px',\n border: \"1px solid \".concat(theme.palette.type === 'light' ? 'rgba(0, 0, 0, 0.23)' : 'rgba(255, 255, 255, 0.23)'),\n '&$disabled': {\n border: \"1px solid \".concat(theme.palette.action.disabled)\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"` and `color=\"primary\"`. */\n outlinedPrimary: {\n color: theme.palette.primary.main,\n border: \"1px solid \".concat(fade(theme.palette.primary.main, 0.5)),\n '&:hover': {\n border: \"1px solid \".concat(theme.palette.primary.main),\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"` and `color=\"secondary\"`. */\n outlinedSecondary: {\n color: theme.palette.secondary.main,\n border: \"1px solid \".concat(fade(theme.palette.secondary.main, 0.5)),\n '&:hover': {\n border: \"1px solid \".concat(theme.palette.secondary.main),\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n },\n '&$disabled': {\n border: \"1px solid \".concat(theme.palette.action.disabled)\n }\n },\n\n /* Styles applied to the root element if `variant=\"contained\"`. */\n contained: {\n color: theme.palette.getContrastText(theme.palette.grey[300]),\n backgroundColor: theme.palette.grey[300],\n boxShadow: theme.shadows[2],\n '&:hover': {\n backgroundColor: theme.palette.grey.A100,\n boxShadow: theme.shadows[4],\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n boxShadow: theme.shadows[2],\n backgroundColor: theme.palette.grey[300]\n },\n '&$disabled': {\n backgroundColor: theme.palette.action.disabledBackground\n }\n },\n '&$focusVisible': {\n boxShadow: theme.shadows[6]\n },\n '&:active': {\n boxShadow: theme.shadows[8]\n },\n '&$disabled': {\n color: theme.palette.action.disabled,\n boxShadow: theme.shadows[0],\n backgroundColor: theme.palette.action.disabledBackground\n }\n },\n\n /* Styles applied to the root element if `variant=\"contained\"` and `color=\"primary\"`. */\n containedPrimary: {\n color: theme.palette.primary.contrastText,\n backgroundColor: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: theme.palette.primary.dark,\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: theme.palette.primary.main\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"contained\"` and `color=\"secondary\"`. */\n containedSecondary: {\n color: theme.palette.secondary.contrastText,\n backgroundColor: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: theme.palette.secondary.dark,\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: theme.palette.secondary.main\n }\n }\n },\n\n /* Styles applied to the root element if `disableElevation={true}`. */\n disableElevation: {\n boxShadow: 'none',\n '&:hover': {\n boxShadow: 'none'\n },\n '&$focusVisible': {\n boxShadow: 'none'\n },\n '&:active': {\n boxShadow: 'none'\n },\n '&$disabled': {\n boxShadow: 'none'\n }\n },\n\n /* Pseudo-class applied to the ButtonBase root element if the button is keyboard focused. */\n focusVisible: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `color=\"inherit\"`. */\n colorInherit: {\n color: 'inherit',\n borderColor: 'currentColor'\n },\n\n /* Styles applied to the root element if `size=\"small\"` and `variant=\"text\"`. */\n textSizeSmall: {\n padding: '4px 5px',\n fontSize: theme.typography.pxToRem(13)\n },\n\n /* Styles applied to the root element if `size=\"large\"` and `variant=\"text\"`. */\n textSizeLarge: {\n padding: '8px 11px',\n fontSize: theme.typography.pxToRem(15)\n },\n\n /* Styles applied to the root element if `size=\"small\"` and `variant=\"outlined\"`. */\n outlinedSizeSmall: {\n padding: '3px 9px',\n fontSize: theme.typography.pxToRem(13)\n },\n\n /* Styles applied to the root element if `size=\"large\"` and `variant=\"outlined\"`. */\n outlinedSizeLarge: {\n padding: '7px 21px',\n fontSize: theme.typography.pxToRem(15)\n },\n\n /* Styles applied to the root element if `size=\"small\"` and `variant=\"contained\"`. */\n containedSizeSmall: {\n padding: '4px 10px',\n fontSize: theme.typography.pxToRem(13)\n },\n\n /* Styles applied to the root element if `size=\"large\"` and `variant=\"contained\"`. */\n containedSizeLarge: {\n padding: '8px 22px',\n fontSize: theme.typography.pxToRem(15)\n },\n\n /* Styles applied to the root element if `size=\"small\"`. */\n sizeSmall: {},\n\n /* Styles applied to the root element if `size=\"large\"`. */\n sizeLarge: {},\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {\n width: '100%'\n },\n\n /* Styles applied to the startIcon element if supplied. */\n startIcon: {\n display: 'inherit',\n marginRight: 8,\n marginLeft: -4,\n '&$iconSizeSmall': {\n marginLeft: -2\n }\n },\n\n /* Styles applied to the endIcon element if supplied. */\n endIcon: {\n display: 'inherit',\n marginRight: -4,\n marginLeft: 8,\n '&$iconSizeSmall': {\n marginRight: -2\n }\n },\n\n /* Styles applied to the icon element if supplied and `size=\"small\"`. */\n iconSizeSmall: {\n '& > *:first-child': {\n fontSize: 18\n }\n },\n\n /* Styles applied to the icon element if supplied and `size=\"medium\"`. */\n iconSizeMedium: {\n '& > *:first-child': {\n fontSize: 20\n }\n },\n\n /* Styles applied to the icon element if supplied and `size=\"large\"`. */\n iconSizeLarge: {\n '& > *:first-child': {\n fontSize: 22\n }\n }\n };\n};\nvar Button = React.forwardRef(function Button(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'default' : _props$color,\n _props$component = props.component,\n component = _props$component === void 0 ? 'button' : _props$component,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableElevati = props.disableElevation,\n disableElevation = _props$disableElevati === void 0 ? false : _props$disableElevati,\n _props$disableFocusRi = props.disableFocusRipple,\n disableFocusRipple = _props$disableFocusRi === void 0 ? false : _props$disableFocusRi,\n endIconProp = props.endIcon,\n focusVisibleClassName = props.focusVisibleClassName,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n startIconProp = props.startIcon,\n _props$type = props.type,\n type = _props$type === void 0 ? 'button' : _props$type,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'text' : _props$variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"disabled\", \"disableElevation\", \"disableFocusRipple\", \"endIcon\", \"focusVisibleClassName\", \"fullWidth\", \"size\", \"startIcon\", \"type\", \"variant\"]);\n\n var startIcon = startIconProp && React.createElement(\"span\", {\n className: clsx(classes.startIcon, classes[\"iconSize\".concat(capitalize(size))])\n }, startIconProp);\n var endIcon = endIconProp && React.createElement(\"span\", {\n className: clsx(classes.endIcon, classes[\"iconSize\".concat(capitalize(size))])\n }, endIconProp);\n return React.createElement(ButtonBase, _extends({\n className: clsx(classes.root, classes[variant], className, color === 'inherit' ? classes.colorInherit : color !== 'default' && classes[\"\".concat(variant).concat(capitalize(color))], size !== 'medium' && [classes[\"\".concat(variant, \"Size\").concat(capitalize(size))], classes[\"size\".concat(capitalize(size))]], disableElevation && classes.disableElevation, disabled && classes.disabled, fullWidth && classes.fullWidth),\n component: component,\n disabled: disabled,\n focusRipple: !disableFocusRipple,\n focusVisibleClassName: clsx(classes.focusVisible, focusVisibleClassName),\n ref: ref,\n type: type\n }, other), React.createElement(\"span\", {\n className: classes.label\n }, startIcon, children, endIcon));\n});\nprocess.env.NODE_ENV !== \"production\" ? Button.propTypes = {\n /**\n * The content of the button.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['default', 'inherit', 'primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the button will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, no elevation is used.\n */\n disableElevation: PropTypes.bool,\n\n /**\n * If `true`, the keyboard focus ripple will be disabled.\n * `disableRipple` must also be true.\n */\n disableFocusRipple: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n *\n * âš ï¸ Without a ripple there is no styling for :focus-visible by default. Be sure\n * to highlight the element by applying separate styles with the `focusVisibleClassName`.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * Element placed after the children.\n */\n endIcon: PropTypes.node,\n\n /**\n * @ignore\n */\n focusVisibleClassName: PropTypes.string,\n\n /**\n * If `true`, the button will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The URL to link to when the button is clicked.\n * If defined, an `a` element will be used as the root node.\n */\n href: PropTypes.string,\n\n /**\n * The size of the button.\n * `small` is equivalent to the dense button styling.\n */\n size: PropTypes.oneOf(['small', 'medium', 'large']),\n\n /**\n * Element placed before the children.\n */\n startIcon: PropTypes.node,\n\n /**\n * @ignore\n */\n type: PropTypes.string,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['text', 'outlined', 'contained'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiButton'\n})(Button);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nimport ThemeContext from '../useTheme/ThemeContext';\nimport useTheme from '../useTheme';\nimport nested from './nested'; // To support composition of theme.\n\nfunction mergeOuterLocalTheme(outerTheme, localTheme) {\n if (typeof localTheme === 'function') {\n var mergedTheme = localTheme(outerTheme);\n\n if (process.env.NODE_ENV !== 'production') {\n if (!mergedTheme) {\n console.error(['Material-UI: you should return an object from your theme function, i.e.', '<ThemeProvider theme={() => ({})} />'].join('\\n'));\n }\n }\n\n return mergedTheme;\n }\n\n return _extends({}, outerTheme, {}, localTheme);\n}\n/**\n * This component takes a `theme` prop.\n * It makes the `theme` available down the React tree thanks to React context.\n * This component should preferably be used at **the root of your component tree**.\n */\n\n\nfunction ThemeProvider(props) {\n var children = props.children,\n localTheme = props.theme;\n var outerTheme = useTheme();\n\n if (process.env.NODE_ENV !== 'production') {\n if (outerTheme === null && typeof localTheme === 'function') {\n console.error(['Material-UI: you are providing a theme function prop to the ThemeProvider component:', '<ThemeProvider theme={outerTheme => outerTheme} />', '', 'However, no outer theme is present.', 'Make sure a theme is already injected higher in the React tree ' + 'or provide a theme object.'].join('\\n'));\n }\n }\n\n var theme = React.useMemo(function () {\n var output = outerTheme === null ? localTheme : mergeOuterLocalTheme(outerTheme, localTheme);\n\n if (output != null) {\n output[nested] = outerTheme !== null;\n }\n\n return output;\n }, [localTheme, outerTheme]);\n return React.createElement(ThemeContext.Provider, {\n value: theme\n }, children);\n}\n\nprocess.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = {\n /**\n * Your component tree.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * A theme object. You can provide a function to extend the outer theme.\n */\n theme: PropTypes.oneOfType([PropTypes.object, PropTypes.func]).isRequired\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n process.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = exactProp(ThemeProvider.propTypes) : void 0;\n}\n\nexport default ThemeProvider;","function ownerDocument(node) {\n return node && node.ownerDocument || document;\n}\n\nexport default ownerDocument;","import ownerDocument from './ownerDocument';\n\nfunction ownerWindow(node) {\n var doc = ownerDocument(node);\n return doc.defaultView || window;\n}\n\nexport default ownerWindow;","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nimport setRef from '../utils/setRef';\nimport useForkRef from '../utils/useForkRef';\n\nfunction getContainer(container) {\n container = typeof container === 'function' ? container() : container; // #StrictMode ready\n\n return ReactDOM.findDOMNode(container);\n}\n\nvar useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\n/**\n * Portals provide a first-class way to render children into a DOM node\n * that exists outside the DOM hierarchy of the parent component.\n */\n\nvar Portal = React.forwardRef(function Portal(props, ref) {\n var children = props.children,\n container = props.container,\n _props$disablePortal = props.disablePortal,\n disablePortal = _props$disablePortal === void 0 ? false : _props$disablePortal,\n onRendered = props.onRendered;\n\n var _React$useState = React.useState(null),\n mountNode = _React$useState[0],\n setMountNode = _React$useState[1];\n\n var handleRef = useForkRef(React.isValidElement(children) ? children.ref : null, ref);\n useEnhancedEffect(function () {\n if (!disablePortal) {\n setMountNode(getContainer(container) || document.body);\n }\n }, [container, disablePortal]);\n useEnhancedEffect(function () {\n if (mountNode && !disablePortal) {\n setRef(ref, mountNode);\n return function () {\n setRef(ref, null);\n };\n }\n\n return undefined;\n }, [ref, mountNode, disablePortal]);\n useEnhancedEffect(function () {\n if (onRendered && (mountNode || disablePortal)) {\n onRendered();\n }\n }, [onRendered, mountNode, disablePortal]);\n\n if (disablePortal) {\n if (React.isValidElement(children)) {\n return React.cloneElement(children, {\n ref: handleRef\n });\n }\n\n return children;\n }\n\n return mountNode ? ReactDOM.createPortal(children, mountNode) : mountNode;\n});\nprocess.env.NODE_ENV !== \"production\" ? Portal.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The children to render into the `container`.\n */\n children: PropTypes.node,\n\n /**\n * A node, component instance, or function that returns either.\n * The `container` will have the portal children appended to it.\n * By default, it uses the body of the top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes.oneOfType([PropTypes.func, PropTypes.instanceOf(React.Component), PropTypes.instanceOf(typeof Element === 'undefined' ? Object : Element)]),\n\n /**\n * Disable the portal behavior.\n * The children stay within it's parent DOM hierarchy.\n */\n disablePortal: PropTypes.bool,\n\n /**\n * Callback fired once the children has been mounted into the `container`.\n *\n * This prop will be deprecated and removed in v5, the ref can be used instead.\n */\n onRendered: PropTypes.func\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n Portal['propTypes' + ''] = exactProp(Portal.propTypes);\n}\n\nexport default Portal;","// A change of the browser zoom change the scrollbar size.\n// Credit https://github.com/twbs/bootstrap/blob/3ffe3a5d82f6f561b82ff78d82b32a7d14aed558/js/src/modal.js#L512-L519\nfunction getScrollbarSize() {\n var scrollDiv = document.createElement('div');\n scrollDiv.style.width = '99px';\n scrollDiv.style.height = '99px';\n scrollDiv.style.position = 'absolute';\n scrollDiv.style.top = '-9999px';\n scrollDiv.style.overflow = 'scroll';\n document.body.appendChild(scrollDiv);\n var scrollbarSize = scrollDiv.offsetWidth - scrollDiv.clientWidth;\n document.body.removeChild(scrollDiv);\n return scrollbarSize;\n}\n\nexport default getScrollbarSize;","import _classCallCheck from \"@babel/runtime/helpers/esm/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/esm/createClass\";\nimport _toConsumableArray from \"@babel/runtime/helpers/esm/toConsumableArray\";\nimport getScrollbarSize from '../utils/getScrollbarSize';\nimport ownerDocument from '../utils/ownerDocument';\nimport ownerWindow from '../utils/ownerWindow'; // Is a vertical scrollbar displayed?\n\nfunction isOverflowing(container) {\n var doc = ownerDocument(container);\n\n if (doc.body === container) {\n return ownerWindow(doc).innerWidth > doc.documentElement.clientWidth;\n }\n\n return container.scrollHeight > container.clientHeight;\n}\n\nexport function ariaHidden(node, show) {\n if (show) {\n node.setAttribute('aria-hidden', 'true');\n } else {\n node.removeAttribute('aria-hidden');\n }\n}\n\nfunction getPaddingRight(node) {\n return parseInt(window.getComputedStyle(node)['padding-right'], 10) || 0;\n}\n\nfunction ariaHiddenSiblings(container, mountNode, currentNode) {\n var nodesToExclude = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];\n var show = arguments.length > 4 ? arguments[4] : undefined;\n var blacklist = [mountNode, currentNode].concat(_toConsumableArray(nodesToExclude));\n var blacklistTagNames = ['TEMPLATE', 'SCRIPT', 'STYLE'];\n [].forEach.call(container.children, function (node) {\n if (node.nodeType === 1 && blacklist.indexOf(node) === -1 && blacklistTagNames.indexOf(node.tagName) === -1) {\n ariaHidden(node, show);\n }\n });\n}\n\nfunction findIndexOf(containerInfo, callback) {\n var idx = -1;\n containerInfo.some(function (item, index) {\n if (callback(item)) {\n idx = index;\n return true;\n }\n\n return false;\n });\n return idx;\n}\n\nfunction handleContainer(containerInfo, props) {\n var restoreStyle = [];\n var restorePaddings = [];\n var container = containerInfo.container;\n var fixedNodes;\n\n if (!props.disableScrollLock) {\n if (isOverflowing(container)) {\n // Compute the size before applying overflow hidden to avoid any scroll jumps.\n var scrollbarSize = getScrollbarSize();\n restoreStyle.push({\n value: container.style.paddingRight,\n key: 'padding-right',\n el: container\n }); // Use computed style, here to get the real padding to add our scrollbar width.\n\n container.style['padding-right'] = \"\".concat(getPaddingRight(container) + scrollbarSize, \"px\"); // .mui-fixed is a global helper.\n\n fixedNodes = ownerDocument(container).querySelectorAll('.mui-fixed');\n [].forEach.call(fixedNodes, function (node) {\n restorePaddings.push(node.style.paddingRight);\n node.style.paddingRight = \"\".concat(getPaddingRight(node) + scrollbarSize, \"px\");\n });\n } // Improve Gatsby support\n // https://css-tricks.com/snippets/css/force-vertical-scrollbar/\n\n\n var parent = container.parentElement;\n var scrollContainer = parent.nodeName === 'HTML' && window.getComputedStyle(parent)['overflow-y'] === 'scroll' ? parent : container; // Block the scroll even if no scrollbar is visible to account for mobile keyboard\n // screensize shrink.\n\n restoreStyle.push({\n value: scrollContainer.style.overflow,\n key: 'overflow',\n el: scrollContainer\n });\n scrollContainer.style.overflow = 'hidden';\n }\n\n var restore = function restore() {\n if (fixedNodes) {\n [].forEach.call(fixedNodes, function (node, i) {\n if (restorePaddings[i]) {\n node.style.paddingRight = restorePaddings[i];\n } else {\n node.style.removeProperty('padding-right');\n }\n });\n }\n\n restoreStyle.forEach(function (_ref) {\n var value = _ref.value,\n el = _ref.el,\n key = _ref.key;\n\n if (value) {\n el.style.setProperty(key, value);\n } else {\n el.style.removeProperty(key);\n }\n });\n };\n\n return restore;\n}\n\nfunction getHiddenSiblings(container) {\n var hiddenSiblings = [];\n [].forEach.call(container.children, function (node) {\n if (node.getAttribute && node.getAttribute('aria-hidden') === 'true') {\n hiddenSiblings.push(node);\n }\n });\n return hiddenSiblings;\n}\n/**\n * @ignore - do not document.\n *\n * Proper state management for containers and the modals in those containers.\n * Simplified, but inspired by react-overlay's ModalManager class.\n * Used by the Modal to ensure proper styling of containers.\n */\n\n\nvar ModalManager =\n/*#__PURE__*/\nfunction () {\n function ModalManager() {\n _classCallCheck(this, ModalManager);\n\n // this.modals[modalIndex] = modal\n this.modals = []; // this.containers[containerIndex] = {\n // modals: [],\n // container,\n // restore: null,\n // }\n\n this.containers = [];\n }\n\n _createClass(ModalManager, [{\n key: \"add\",\n value: function add(modal, container) {\n var modalIndex = this.modals.indexOf(modal);\n\n if (modalIndex !== -1) {\n return modalIndex;\n }\n\n modalIndex = this.modals.length;\n this.modals.push(modal); // If the modal we are adding is already in the DOM.\n\n if (modal.modalRef) {\n ariaHidden(modal.modalRef, false);\n }\n\n var hiddenSiblingNodes = getHiddenSiblings(container);\n ariaHiddenSiblings(container, modal.mountNode, modal.modalRef, hiddenSiblingNodes, true);\n var containerIndex = findIndexOf(this.containers, function (item) {\n return item.container === container;\n });\n\n if (containerIndex !== -1) {\n this.containers[containerIndex].modals.push(modal);\n return modalIndex;\n }\n\n this.containers.push({\n modals: [modal],\n container: container,\n restore: null,\n hiddenSiblingNodes: hiddenSiblingNodes\n });\n return modalIndex;\n }\n }, {\n key: \"mount\",\n value: function mount(modal, props) {\n var containerIndex = findIndexOf(this.containers, function (item) {\n return item.modals.indexOf(modal) !== -1;\n });\n var containerInfo = this.containers[containerIndex];\n\n if (!containerInfo.restore) {\n containerInfo.restore = handleContainer(containerInfo, props);\n }\n }\n }, {\n key: \"remove\",\n value: function remove(modal) {\n var modalIndex = this.modals.indexOf(modal);\n\n if (modalIndex === -1) {\n return modalIndex;\n }\n\n var containerIndex = findIndexOf(this.containers, function (item) {\n return item.modals.indexOf(modal) !== -1;\n });\n var containerInfo = this.containers[containerIndex];\n containerInfo.modals.splice(containerInfo.modals.indexOf(modal), 1);\n this.modals.splice(modalIndex, 1); // If that was the last modal in a container, clean up the container.\n\n if (containerInfo.modals.length === 0) {\n // The modal might be closed before it had the chance to be mounted in the DOM.\n if (containerInfo.restore) {\n containerInfo.restore();\n }\n\n if (modal.modalRef) {\n // In case the modal wasn't in the DOM yet.\n ariaHidden(modal.modalRef, true);\n }\n\n ariaHiddenSiblings(containerInfo.container, modal.mountNode, modal.modalRef, containerInfo.hiddenSiblingNodes, false);\n this.containers.splice(containerIndex, 1);\n } else {\n // Otherwise make sure the next top modal is visible to a screen reader.\n var nextTop = containerInfo.modals[containerInfo.modals.length - 1]; // as soon as a modal is adding its modalRef is undefined. it can't set\n // aria-hidden because the dom element doesn't exist either\n // when modal was unmounted before modalRef gets null\n\n if (nextTop.modalRef) {\n ariaHidden(nextTop.modalRef, false);\n }\n }\n\n return modalIndex;\n }\n }, {\n key: \"isTopModal\",\n value: function isTopModal(modal) {\n return this.modals.length > 0 && this.modals[this.modals.length - 1] === modal;\n }\n }]);\n\n return ModalManager;\n}();\n\nexport { ModalManager as default };","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","/* eslint-disable consistent-return, jsx-a11y/no-noninteractive-tabindex */\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport ownerDocument from '../utils/ownerDocument';\nimport useForkRef from '../utils/useForkRef';\n/**\n * @ignore - internal component.\n */\n\nfunction TrapFocus(props) {\n var children = props.children,\n _props$disableAutoFoc = props.disableAutoFocus,\n disableAutoFocus = _props$disableAutoFoc === void 0 ? false : _props$disableAutoFoc,\n _props$disableEnforce = props.disableEnforceFocus,\n disableEnforceFocus = _props$disableEnforce === void 0 ? false : _props$disableEnforce,\n _props$disableRestore = props.disableRestoreFocus,\n disableRestoreFocus = _props$disableRestore === void 0 ? false : _props$disableRestore,\n getDoc = props.getDoc,\n isEnabled = props.isEnabled,\n open = props.open;\n var ignoreNextEnforceFocus = React.useRef();\n var sentinelStart = React.useRef(null);\n var sentinelEnd = React.useRef(null);\n var nodeToRestore = React.useRef();\n var rootRef = React.useRef(null); // can be removed once we drop support for non ref forwarding class components\n\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n rootRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n var handleRef = useForkRef(children.ref, handleOwnRef); // âš ï¸ You may rely on React.useMemo as a performance optimization, not as a semantic guarantee.\n // https://reactjs.org/docs/hooks-reference.html#usememo\n\n React.useMemo(function () {\n if (!open || typeof window === 'undefined') {\n return;\n }\n\n nodeToRestore.current = getDoc().activeElement;\n }, [open]); // eslint-disable-line react-hooks/exhaustive-deps\n\n React.useEffect(function () {\n if (!open) {\n return;\n }\n\n var doc = ownerDocument(rootRef.current); // We might render an empty child.\n\n if (!disableAutoFocus && rootRef.current && !rootRef.current.contains(doc.activeElement)) {\n if (!rootRef.current.hasAttribute('tabIndex')) {\n if (process.env.NODE_ENV !== 'production') {\n console.error(['Material-UI: the modal content node does not accept focus.', 'For the benefit of assistive technologies, ' + 'the tabIndex of the node is being set to \"-1\".'].join('\\n'));\n }\n\n rootRef.current.setAttribute('tabIndex', -1);\n }\n\n rootRef.current.focus();\n }\n\n var contain = function contain() {\n if (disableEnforceFocus || !isEnabled() || ignoreNextEnforceFocus.current) {\n ignoreNextEnforceFocus.current = false;\n return;\n }\n\n if (rootRef.current && !rootRef.current.contains(doc.activeElement)) {\n rootRef.current.focus();\n }\n };\n\n var loopFocus = function loopFocus(event) {\n // 9 = Tab\n if (disableEnforceFocus || !isEnabled() || event.keyCode !== 9) {\n return;\n } // Make sure the next tab starts from the right place.\n\n\n if (doc.activeElement === rootRef.current) {\n // We need to ignore the next contain as\n // it will try to move the focus back to the rootRef element.\n ignoreNextEnforceFocus.current = true;\n\n if (event.shiftKey) {\n sentinelEnd.current.focus();\n } else {\n sentinelStart.current.focus();\n }\n }\n };\n\n doc.addEventListener('focus', contain, true);\n doc.addEventListener('keydown', loopFocus, true); // With Edge, Safari and Firefox, no focus related events are fired when the focused area stops being a focused area\n // e.g. https://bugzilla.mozilla.org/show_bug.cgi?id=559561.\n //\n // The whatwg spec defines how the browser should behave but does not explicitly mention any events:\n // https://html.spec.whatwg.org/multipage/interaction.html#focus-fixup-rule.\n\n var interval = setInterval(function () {\n contain();\n }, 50);\n return function () {\n clearInterval(interval);\n doc.removeEventListener('focus', contain, true);\n doc.removeEventListener('keydown', loopFocus, true); // restoreLastFocus()\n\n if (!disableRestoreFocus) {\n // In IE 11 it is possible for document.activeElement to be null resulting\n // in nodeToRestore.current being null.\n // Not all elements in IE 11 have a focus method.\n // Once IE 11 support is dropped the focus() call can be unconditional.\n if (nodeToRestore.current && nodeToRestore.current.focus) {\n nodeToRestore.current.focus();\n }\n\n nodeToRestore.current = null;\n }\n };\n }, [disableAutoFocus, disableEnforceFocus, disableRestoreFocus, isEnabled, open]);\n return React.createElement(React.Fragment, null, React.createElement(\"div\", {\n tabIndex: 0,\n ref: sentinelStart,\n \"data-test\": \"sentinelStart\"\n }), React.cloneElement(children, {\n ref: handleRef\n }), React.createElement(\"div\", {\n tabIndex: 0,\n ref: sentinelEnd,\n \"data-test\": \"sentinelEnd\"\n }));\n}\n\nprocess.env.NODE_ENV !== \"production\" ? TrapFocus.propTypes = {\n /**\n * A single child content element.\n */\n children: PropTypes.element.isRequired,\n\n /**\n * If `true`, the modal will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any modal children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableAutoFocus: PropTypes.bool,\n\n /**\n * If `true`, the modal will not prevent focus from leaving the modal while open.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableEnforceFocus: PropTypes.bool,\n\n /**\n * If `true`, the modal will not restore focus to previously focused element once\n * modal is hidden.\n */\n disableRestoreFocus: PropTypes.bool,\n\n /**\n * Return the document to consider.\n * We use it to implement the restore focus between different browser documents.\n */\n getDoc: PropTypes.func.isRequired,\n\n /**\n * Do we still want to enforce the focus?\n * This prop helps nesting TrapFocus elements.\n */\n isEnabled: PropTypes.func.isRequired,\n\n /**\n * If `true`, the modal is open.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\n/*\n\nIn the future, we should be able to replace TrapFocus with:\nhttps://github.com/facebook/react/blob/master/packages/react-events/docs/FocusScope.md\n\n```jsx\nimport FocusScope from 'react-dom/FocusScope';\n\nfunction TrapFocus(props) {\n const {\n children\n disableAutoFocus = false,\n disableEnforceFocus = false,\n disableRestoreFocus = false,\n open,\n } = props;\n\n if (!open) {\n return children;\n }\n\n return (\n <FocusScope\n autoFocus={!disableAutoFocus}\n contain={!disableEnforceFocus}\n restoreFocus={!disableRestoreFocus}\n >\n {children}\n </FocusScope>\n );\n}\n```\n\n*/\n\nexport default TrapFocus;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n zIndex: -1,\n position: 'fixed',\n right: 0,\n bottom: 0,\n top: 0,\n left: 0,\n backgroundColor: 'rgba(0, 0, 0, 0.5)',\n WebkitTapHighlightColor: 'transparent',\n // Disable scroll capabilities.\n touchAction: 'none'\n },\n\n /* Styles applied to the root element if `invisible={true}`. */\n invisible: {\n backgroundColor: 'transparent'\n }\n};\n/**\n * @ignore - internal component.\n */\n\nvar SimpleBackdrop = React.forwardRef(function SimpleBackdrop(props, ref) {\n var _props$invisible = props.invisible,\n invisible = _props$invisible === void 0 ? false : _props$invisible,\n open = props.open,\n other = _objectWithoutProperties(props, [\"invisible\", \"open\"]);\n\n return open ? React.createElement(\"div\", _extends({\n \"aria-hidden\": true,\n ref: ref\n }, other, {\n style: _extends({}, styles.root, {}, invisible ? styles.invisible : {}, {}, other.style)\n })) : null;\n});\nprocess.env.NODE_ENV !== \"production\" ? SimpleBackdrop.propTypes = {\n /**\n * If `true`, the backdrop is invisible.\n * It can be used when rendering a popover or a custom select component.\n */\n invisible: PropTypes.bool,\n\n /**\n * If `true`, the backdrop is open.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\nexport default SimpleBackdrop;","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport { getThemeProps, useTheme } from '@material-ui/styles';\nimport { elementAcceptingRef } from '@material-ui/utils';\nimport ownerDocument from '../utils/ownerDocument';\nimport Portal from '../Portal';\nimport createChainedFunction from '../utils/createChainedFunction';\nimport useForkRef from '../utils/useForkRef';\nimport useEventCallback from '../utils/useEventCallback';\nimport zIndex from '../styles/zIndex';\nimport ModalManager, { ariaHidden } from './ModalManager';\nimport TrapFocus from './TrapFocus';\nimport SimpleBackdrop from './SimpleBackdrop';\n\nfunction getContainer(container) {\n container = typeof container === 'function' ? container() : container;\n return ReactDOM.findDOMNode(container);\n}\n\nfunction getHasTransition(props) {\n return props.children ? props.children.props.hasOwnProperty('in') : false;\n} // A modal manager used to track and manage the state of open Modals.\n// Modals don't open on the server so this won't conflict with concurrent requests.\n\n\nvar defaultManager = new ModalManager();\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'fixed',\n zIndex: theme.zIndex.modal,\n right: 0,\n bottom: 0,\n top: 0,\n left: 0\n },\n\n /* Styles applied to the root element if the `Modal` has exited. */\n hidden: {\n visibility: 'hidden'\n }\n };\n};\n/**\n * Modal is a lower-level construct that is leveraged by the following components:\n *\n * - [Dialog](/api/dialog/)\n * - [Drawer](/api/drawer/)\n * - [Menu](/api/menu/)\n * - [Popover](/api/popover/)\n *\n * If you are creating a modal dialog, you probably want to use the [Dialog](/api/dialog/) component\n * rather than directly using Modal.\n *\n * This component shares many concepts with [react-overlays](https://react-bootstrap.github.io/react-overlays/#modals).\n */\n\nvar Modal = React.forwardRef(function Modal(inProps, ref) {\n var theme = useTheme();\n var props = getThemeProps({\n name: 'MuiModal',\n props: _extends({}, inProps),\n theme: theme\n });\n\n var _props$BackdropCompon = props.BackdropComponent,\n BackdropComponent = _props$BackdropCompon === void 0 ? SimpleBackdrop : _props$BackdropCompon,\n BackdropProps = props.BackdropProps,\n children = props.children,\n _props$closeAfterTran = props.closeAfterTransition,\n closeAfterTransition = _props$closeAfterTran === void 0 ? false : _props$closeAfterTran,\n container = props.container,\n _props$disableAutoFoc = props.disableAutoFocus,\n disableAutoFocus = _props$disableAutoFoc === void 0 ? false : _props$disableAutoFoc,\n _props$disableBackdro = props.disableBackdropClick,\n disableBackdropClick = _props$disableBackdro === void 0 ? false : _props$disableBackdro,\n _props$disableEnforce = props.disableEnforceFocus,\n disableEnforceFocus = _props$disableEnforce === void 0 ? false : _props$disableEnforce,\n _props$disableEscapeK = props.disableEscapeKeyDown,\n disableEscapeKeyDown = _props$disableEscapeK === void 0 ? false : _props$disableEscapeK,\n _props$disablePortal = props.disablePortal,\n disablePortal = _props$disablePortal === void 0 ? false : _props$disablePortal,\n _props$disableRestore = props.disableRestoreFocus,\n disableRestoreFocus = _props$disableRestore === void 0 ? false : _props$disableRestore,\n _props$disableScrollL = props.disableScrollLock,\n disableScrollLock = _props$disableScrollL === void 0 ? false : _props$disableScrollL,\n _props$hideBackdrop = props.hideBackdrop,\n hideBackdrop = _props$hideBackdrop === void 0 ? false : _props$hideBackdrop,\n _props$keepMounted = props.keepMounted,\n keepMounted = _props$keepMounted === void 0 ? false : _props$keepMounted,\n _props$manager = props.manager,\n manager = _props$manager === void 0 ? defaultManager : _props$manager,\n onBackdropClick = props.onBackdropClick,\n onClose = props.onClose,\n onEscapeKeyDown = props.onEscapeKeyDown,\n onRendered = props.onRendered,\n open = props.open,\n other = _objectWithoutProperties(props, [\"BackdropComponent\", \"BackdropProps\", \"children\", \"closeAfterTransition\", \"container\", \"disableAutoFocus\", \"disableBackdropClick\", \"disableEnforceFocus\", \"disableEscapeKeyDown\", \"disablePortal\", \"disableRestoreFocus\", \"disableScrollLock\", \"hideBackdrop\", \"keepMounted\", \"manager\", \"onBackdropClick\", \"onClose\", \"onEscapeKeyDown\", \"onRendered\", \"open\"]);\n\n var _React$useState = React.useState(true),\n exited = _React$useState[0],\n setExited = _React$useState[1];\n\n var modal = React.useRef({});\n var mountNodeRef = React.useRef(null);\n var modalRef = React.useRef(null);\n var handleRef = useForkRef(modalRef, ref);\n var hasTransition = getHasTransition(props);\n\n var getDoc = function getDoc() {\n return ownerDocument(mountNodeRef.current);\n };\n\n var getModal = function getModal() {\n modal.current.modalRef = modalRef.current;\n modal.current.mountNode = mountNodeRef.current;\n return modal.current;\n };\n\n var handleMounted = function handleMounted() {\n manager.mount(getModal(), {\n disableScrollLock: disableScrollLock\n }); // Fix a bug on Chrome where the scroll isn't initially 0.\n\n modalRef.current.scrollTop = 0;\n };\n\n var handleOpen = useEventCallback(function () {\n var resolvedContainer = getContainer(container) || getDoc().body;\n manager.add(getModal(), resolvedContainer); // The element was already mounted.\n\n if (modalRef.current) {\n handleMounted();\n }\n });\n var isTopModal = React.useCallback(function () {\n return manager.isTopModal(getModal());\n }, [manager]);\n var handlePortalRef = useEventCallback(function (node) {\n mountNodeRef.current = node;\n\n if (!node) {\n return;\n }\n\n if (onRendered) {\n onRendered();\n }\n\n if (open && isTopModal()) {\n handleMounted();\n } else {\n ariaHidden(modalRef.current, true);\n }\n });\n var handleClose = React.useCallback(function () {\n manager.remove(getModal());\n }, [manager]);\n React.useEffect(function () {\n return function () {\n handleClose();\n };\n }, [handleClose]);\n React.useEffect(function () {\n if (open) {\n handleOpen();\n } else if (!hasTransition || !closeAfterTransition) {\n handleClose();\n }\n }, [open, handleClose, hasTransition, closeAfterTransition, handleOpen]);\n\n if (!keepMounted && !open && (!hasTransition || exited)) {\n return null;\n }\n\n var handleEnter = function handleEnter() {\n setExited(false);\n };\n\n var handleExited = function handleExited() {\n setExited(true);\n\n if (closeAfterTransition) {\n handleClose();\n }\n };\n\n var handleBackdropClick = function handleBackdropClick(event) {\n if (event.target !== event.currentTarget) {\n return;\n }\n\n if (onBackdropClick) {\n onBackdropClick(event);\n }\n\n if (!disableBackdropClick && onClose) {\n onClose(event, 'backdropClick');\n }\n };\n\n var handleKeyDown = function handleKeyDown(event) {\n // The handler doesn't take event.defaultPrevented into account:\n //\n // event.preventDefault() is meant to stop default behaviours like\n // clicking a checkbox to check it, hitting a button to submit a form,\n // and hitting left arrow to move the cursor in a text input etc.\n // Only special HTML elements have these default behaviors.\n if (event.key !== 'Escape' || !isTopModal()) {\n return;\n } // Swallow the event, in case someone is listening for the escape key on the body.\n\n\n event.stopPropagation();\n\n if (onEscapeKeyDown) {\n onEscapeKeyDown(event);\n }\n\n if (!disableEscapeKeyDown && onClose) {\n onClose(event, 'escapeKeyDown');\n }\n };\n\n var inlineStyle = styles(theme || {\n zIndex: zIndex\n });\n var childProps = {};\n\n if (children.props.tabIndex === undefined) {\n childProps.tabIndex = children.props.tabIndex || '-1';\n } // It's a Transition like component\n\n\n if (hasTransition) {\n childProps.onEnter = createChainedFunction(handleEnter, children.props.onEnter);\n childProps.onExited = createChainedFunction(handleExited, children.props.onExited);\n }\n\n return React.createElement(Portal, {\n ref: handlePortalRef,\n container: container,\n disablePortal: disablePortal\n }, React.createElement(\"div\", _extends({\n ref: handleRef,\n onKeyDown: handleKeyDown,\n role: \"presentation\"\n }, other, {\n style: _extends({}, inlineStyle.root, {}, !open && exited ? inlineStyle.hidden : {}, {}, other.style)\n }), hideBackdrop ? null : React.createElement(BackdropComponent, _extends({\n open: open,\n onClick: handleBackdropClick\n }, BackdropProps)), React.createElement(TrapFocus, {\n disableEnforceFocus: disableEnforceFocus,\n disableAutoFocus: disableAutoFocus,\n disableRestoreFocus: disableRestoreFocus,\n getDoc: getDoc,\n isEnabled: isTopModal,\n open: open\n }, React.cloneElement(children, childProps))));\n});\nprocess.env.NODE_ENV !== \"production\" ? Modal.propTypes = {\n /**\n * A backdrop component. This prop enables custom backdrop rendering.\n */\n BackdropComponent: PropTypes.elementType,\n\n /**\n * Props applied to the [`Backdrop`](/api/backdrop/) element.\n */\n BackdropProps: PropTypes.object,\n\n /**\n * A single child content element.\n */\n children: elementAcceptingRef.isRequired,\n\n /**\n * When set to true the Modal waits until a nested Transition is completed before closing.\n */\n closeAfterTransition: PropTypes.bool,\n\n /**\n * A node, component instance, or function that returns either.\n * The `container` will have the portal children appended to it.\n */\n container: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n /**\n * If `true`, the modal will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any modal children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableAutoFocus: PropTypes.bool,\n\n /**\n * If `true`, clicking the backdrop will not fire any callback.\n */\n disableBackdropClick: PropTypes.bool,\n\n /**\n * If `true`, the modal will not prevent focus from leaving the modal while open.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableEnforceFocus: PropTypes.bool,\n\n /**\n * If `true`, hitting escape will not fire any callback.\n */\n disableEscapeKeyDown: PropTypes.bool,\n\n /**\n * Disable the portal behavior.\n * The children stay within it's parent DOM hierarchy.\n */\n disablePortal: PropTypes.bool,\n\n /**\n * If `true`, the modal will not restore focus to previously focused element once\n * modal is hidden.\n */\n disableRestoreFocus: PropTypes.bool,\n\n /**\n * Disable the scroll lock behavior.\n */\n disableScrollLock: PropTypes.bool,\n\n /**\n * If `true`, the backdrop is not rendered.\n */\n hideBackdrop: PropTypes.bool,\n\n /**\n * Always keep the children in the DOM.\n * This prop can be useful in SEO situation or\n * when you want to maximize the responsiveness of the Modal.\n */\n keepMounted: PropTypes.bool,\n\n /**\n * @ignore\n */\n manager: PropTypes.object,\n\n /**\n * Callback fired when the backdrop is clicked.\n */\n onBackdropClick: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be closed.\n * The `reason` parameter can optionally be used to control the response to `onClose`.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired when the escape key is pressed,\n * `disableEscapeKeyDown` is false and the modal is in focus.\n */\n onEscapeKeyDown: PropTypes.func,\n\n /**\n * Callback fired once the children has been mounted into the `container`.\n * It signals that the `open={true}` prop took effect.\n *\n * This prop will be deprecated and removed in v5, the ref can be used instead.\n */\n onRendered: PropTypes.func,\n\n /**\n * If `true`, the modal is open.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\nexport default Modal;","export default {\n disabled: false\n};","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport config from './config';\nimport { timeoutsShape } from './utils/PropTypes';\nimport TransitionGroupContext from './TransitionGroupContext';\nexport var UNMOUNTED = 'unmounted';\nexport var EXITED = 'exited';\nexport var ENTERING = 'entering';\nexport var ENTERED = 'entered';\nexport var EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n * transition: `opacity ${duration}ms ease-in-out`,\n * opacity: 0,\n * }\n *\n * const transitionStyles = {\n * entering: { opacity: 1 },\n * entered: { opacity: 1 },\n * exiting: { opacity: 0 },\n * exited: { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n * <Transition in={inProp} timeout={duration}>\n * {state => (\n * <div style={{\n * ...defaultStyle,\n * ...transitionStyles[state]\n * }}>\n * I'm a fade Transition!\n * </div>\n * )}\n * </Transition>\n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n * - `'entering'`\n * - `'entered'`\n * - `'exiting'`\n * - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n * <div>\n * <Transition in={inProp} timeout={500}>\n * {state => (\n * // ...\n * )}\n * </Transition>\n * <button onClick={() => setInProp(true)}>\n * Click to Enter\n * </button>\n * </div>\n * );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state\n * and stay there for 500ms (the value of `timeout`) before it finally switches\n * to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from\n * `'exiting'` to `'exited'`.\n */\n\nvar Transition =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(Transition, _React$Component);\n\n function Transition(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n var parentGroup = context; // In the context of a TransitionGroup all enters are really appears\n\n var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n var initialStatus;\n _this.appearStatus = null;\n\n if (props.in) {\n if (appear) {\n initialStatus = EXITED;\n _this.appearStatus = ENTERING;\n } else {\n initialStatus = ENTERED;\n }\n } else {\n if (props.unmountOnExit || props.mountOnEnter) {\n initialStatus = UNMOUNTED;\n } else {\n initialStatus = EXITED;\n }\n }\n\n _this.state = {\n status: initialStatus\n };\n _this.nextCallback = null;\n return _this;\n }\n\n Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n var nextIn = _ref.in;\n\n if (nextIn && prevState.status === UNMOUNTED) {\n return {\n status: EXITED\n };\n }\n\n return null;\n }; // getSnapshotBeforeUpdate(prevProps) {\n // let nextStatus = null\n // if (prevProps !== this.props) {\n // const { status } = this.state\n // if (this.props.in) {\n // if (status !== ENTERING && status !== ENTERED) {\n // nextStatus = ENTERING\n // }\n // } else {\n // if (status === ENTERING || status === ENTERED) {\n // nextStatus = EXITING\n // }\n // }\n // }\n // return { nextStatus }\n // }\n\n\n var _proto = Transition.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.updateStatus(true, this.appearStatus);\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var nextStatus = null;\n\n if (prevProps !== this.props) {\n var status = this.state.status;\n\n if (this.props.in) {\n if (status !== ENTERING && status !== ENTERED) {\n nextStatus = ENTERING;\n }\n } else {\n if (status === ENTERING || status === ENTERED) {\n nextStatus = EXITING;\n }\n }\n }\n\n this.updateStatus(false, nextStatus);\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.cancelNextCallback();\n };\n\n _proto.getTimeouts = function getTimeouts() {\n var timeout = this.props.timeout;\n var exit, enter, appear;\n exit = enter = appear = timeout;\n\n if (timeout != null && typeof timeout !== 'number') {\n exit = timeout.exit;\n enter = timeout.enter; // TODO: remove fallback for next major\n\n appear = timeout.appear !== undefined ? timeout.appear : enter;\n }\n\n return {\n exit: exit,\n enter: enter,\n appear: appear\n };\n };\n\n _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n if (mounting === void 0) {\n mounting = false;\n }\n\n if (nextStatus !== null) {\n // nextStatus will always be ENTERING or EXITING.\n this.cancelNextCallback();\n var node = ReactDOM.findDOMNode(this);\n\n if (nextStatus === ENTERING) {\n this.performEnter(node, mounting);\n } else {\n this.performExit(node);\n }\n } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n this.setState({\n status: UNMOUNTED\n });\n }\n };\n\n _proto.performEnter = function performEnter(node, mounting) {\n var _this2 = this;\n\n var enter = this.props.enter;\n var appearing = this.context ? this.context.isMounting : mounting;\n var timeouts = this.getTimeouts();\n var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED\n // if we are mounting and running this it means appear _must_ be set\n\n if (!mounting && !enter || config.disabled) {\n this.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(node);\n });\n return;\n }\n\n this.props.onEnter(node, appearing);\n this.safeSetState({\n status: ENTERING\n }, function () {\n _this2.props.onEntering(node, appearing);\n\n _this2.onTransitionEnd(node, enterTimeout, function () {\n _this2.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(node, appearing);\n });\n });\n });\n };\n\n _proto.performExit = function performExit(node) {\n var _this3 = this;\n\n var exit = this.props.exit;\n var timeouts = this.getTimeouts(); // no exit animation skip right to EXITED\n\n if (!exit || config.disabled) {\n this.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(node);\n });\n return;\n }\n\n this.props.onExit(node);\n this.safeSetState({\n status: EXITING\n }, function () {\n _this3.props.onExiting(node);\n\n _this3.onTransitionEnd(node, timeouts.exit, function () {\n _this3.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(node);\n });\n });\n });\n };\n\n _proto.cancelNextCallback = function cancelNextCallback() {\n if (this.nextCallback !== null) {\n this.nextCallback.cancel();\n this.nextCallback = null;\n }\n };\n\n _proto.safeSetState = function safeSetState(nextState, callback) {\n // This shouldn't be necessary, but there are weird race conditions with\n // setState callbacks and unmounting in testing, so always make sure that\n // we can cancel any pending setState callbacks after we unmount.\n callback = this.setNextCallback(callback);\n this.setState(nextState, callback);\n };\n\n _proto.setNextCallback = function setNextCallback(callback) {\n var _this4 = this;\n\n var active = true;\n\n this.nextCallback = function (event) {\n if (active) {\n active = false;\n _this4.nextCallback = null;\n callback(event);\n }\n };\n\n this.nextCallback.cancel = function () {\n active = false;\n };\n\n return this.nextCallback;\n };\n\n _proto.onTransitionEnd = function onTransitionEnd(node, timeout, handler) {\n this.setNextCallback(handler);\n var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;\n\n if (!node || doesNotHaveTimeoutOrListener) {\n setTimeout(this.nextCallback, 0);\n return;\n }\n\n if (this.props.addEndListener) {\n this.props.addEndListener(node, this.nextCallback);\n }\n\n if (timeout != null) {\n setTimeout(this.nextCallback, timeout);\n }\n };\n\n _proto.render = function render() {\n var status = this.state.status;\n\n if (status === UNMOUNTED) {\n return null;\n }\n\n var _this$props = this.props,\n children = _this$props.children,\n childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\"]); // filter props for Transtition\n\n\n delete childProps.in;\n delete childProps.mountOnEnter;\n delete childProps.unmountOnExit;\n delete childProps.appear;\n delete childProps.enter;\n delete childProps.exit;\n delete childProps.timeout;\n delete childProps.addEndListener;\n delete childProps.onEnter;\n delete childProps.onEntering;\n delete childProps.onEntered;\n delete childProps.onExit;\n delete childProps.onExiting;\n delete childProps.onExited;\n\n if (typeof children === 'function') {\n // allows for nested Transitions\n return React.createElement(TransitionGroupContext.Provider, {\n value: null\n }, children(status, childProps));\n }\n\n var child = React.Children.only(children);\n return (// allows for nested Transitions\n React.createElement(TransitionGroupContext.Provider, {\n value: null\n }, React.cloneElement(child, childProps))\n );\n };\n\n return Transition;\n}(React.Component);\n\nTransition.contextType = TransitionGroupContext;\nTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * A `function` child can be used instead of a React element. This function is\n * called with the current transition status (`'entering'`, `'entered'`,\n * `'exiting'`, `'exited'`), which can be used to apply context\n * specific props to a component.\n *\n * ```jsx\n * <Transition in={this.state.in} timeout={150}>\n * {state => (\n * <MyComponent className={`fade fade-${state}`} />\n * )}\n * </Transition>\n * ```\n */\n children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,\n\n /**\n * Show the component; triggers the enter or exit states\n */\n in: PropTypes.bool,\n\n /**\n * By default the child component is mounted immediately along with\n * the parent `Transition` component. If you want to \"lazy mount\" the component on the\n * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay\n * mounted, even on \"exited\", unless you also specify `unmountOnExit`.\n */\n mountOnEnter: PropTypes.bool,\n\n /**\n * By default the child component stays mounted after it reaches the `'exited'` state.\n * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.\n */\n unmountOnExit: PropTypes.bool,\n\n /**\n * Normally a component is not transitioned if it is shown when the\n * `<Transition>` component mounts. If you want to transition on the first\n * mount set `appear` to `true`, and the component will transition in as soon\n * as the `<Transition>` mounts.\n *\n * > **Note**: there are no special appear states like `appearing`/`appeared`, this prop\n * > only adds an additional enter transition. However, in the\n * > `<CSSTransition>` component that first enter transition does result in\n * > additional `.appear-*` classes, that way you can choose to style it\n * > differently.\n */\n appear: PropTypes.bool,\n\n /**\n * Enable or disable enter transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * Enable or disable exit transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * The duration of the transition, in milliseconds.\n * Required unless `addEndListener` is provided.\n *\n * You may specify a single timeout for all transitions:\n *\n * ```jsx\n * timeout={500}\n * ```\n *\n * or individually:\n *\n * ```jsx\n * timeout={{\n * appear: 500,\n * enter: 300,\n * exit: 500,\n * }}\n * ```\n *\n * - `appear` defaults to the value of `enter`\n * - `enter` defaults to `0`\n * - `exit` defaults to `0`\n *\n * @type {number | { enter?: number, exit?: number, appear?: number }}\n */\n timeout: function timeout(props) {\n var pt = timeoutsShape;\n if (!props.addEndListener) pt = pt.isRequired;\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return pt.apply(void 0, [props].concat(args));\n },\n\n /**\n * Add a custom transition end trigger. Called with the transitioning\n * DOM node and a `done` callback. Allows for more fine grained transition end\n * logic. **Note:** Timeouts are still used as a fallback if provided.\n *\n * ```jsx\n * addEndListener={(node, done) => {\n * // use the css transitionend event to mark the finish of a transition\n * node.addEventListener('transitionend', done, false);\n * }}\n * ```\n */\n addEndListener: PropTypes.func,\n\n /**\n * Callback fired before the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired after the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired after the \"entered\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired before the \"exiting\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired after the \"exiting\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExiting: PropTypes.func,\n\n /**\n * Callback fired after the \"exited\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExited: PropTypes.func // Name the function so it is clearer in the documentation\n\n} : {};\n\nfunction noop() {}\n\nTransition.defaultProps = {\n in: false,\n mountOnEnter: false,\n unmountOnExit: false,\n appear: false,\n enter: true,\n exit: true,\n onEnter: noop,\n onEntering: noop,\n onEntered: noop,\n onExit: noop,\n onExiting: noop,\n onExited: noop\n};\nTransition.UNMOUNTED = 0;\nTransition.EXITED = 1;\nTransition.ENTERING = 2;\nTransition.ENTERED = 3;\nTransition.EXITING = 4;\nexport default Transition;","export var reflow = function reflow(node) {\n return node.scrollTop;\n};\nexport function getTransitionProps(props, options) {\n var timeout = props.timeout,\n _props$style = props.style,\n style = _props$style === void 0 ? {} : _props$style;\n return {\n duration: style.transitionDuration || typeof timeout === 'number' ? timeout : timeout[options.mode] || 0,\n delay: style.transitionDelay\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { Transition } from 'react-transition-group';\nimport useTheme from '../styles/useTheme';\nimport { reflow, getTransitionProps } from '../transitions/utils';\nimport useForkRef from '../utils/useForkRef';\n\nfunction getScale(value) {\n return \"scale(\".concat(value, \", \").concat(Math.pow(value, 2), \")\");\n}\n\nvar styles = {\n entering: {\n opacity: 1,\n transform: getScale(1)\n },\n entered: {\n opacity: 1,\n transform: 'none'\n }\n};\n/**\n * The Grow transition is used by the [Tooltip](/components/tooltips/) and\n * [Popover](/components/popover/) components.\n * It uses [react-transition-group](https://github.com/reactjs/react-transition-group) internally.\n */\n\nvar Grow = React.forwardRef(function Grow(props, ref) {\n var children = props.children,\n inProp = props.in,\n onEnter = props.onEnter,\n onExit = props.onExit,\n style = props.style,\n _props$timeout = props.timeout,\n timeout = _props$timeout === void 0 ? 'auto' : _props$timeout,\n other = _objectWithoutProperties(props, [\"children\", \"in\", \"onEnter\", \"onExit\", \"style\", \"timeout\"]);\n\n var timer = React.useRef();\n var autoTimeout = React.useRef();\n var handleRef = useForkRef(children.ref, ref);\n var theme = useTheme();\n\n var handleEnter = function handleEnter(node, isAppearing) {\n reflow(node); // So the animation always start from the start.\n\n var _getTransitionProps = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'enter'\n }),\n transitionDuration = _getTransitionProps.duration,\n delay = _getTransitionProps.delay;\n\n var duration;\n\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n\n node.style.transition = [theme.transitions.create('opacity', {\n duration: duration,\n delay: delay\n }), theme.transitions.create('transform', {\n duration: duration * 0.666,\n delay: delay\n })].join(',');\n\n if (onEnter) {\n onEnter(node, isAppearing);\n }\n };\n\n var handleExit = function handleExit(node) {\n var _getTransitionProps2 = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'exit'\n }),\n transitionDuration = _getTransitionProps2.duration,\n delay = _getTransitionProps2.delay;\n\n var duration;\n\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n\n node.style.transition = [theme.transitions.create('opacity', {\n duration: duration,\n delay: delay\n }), theme.transitions.create('transform', {\n duration: duration * 0.666,\n delay: delay || duration * 0.333\n })].join(',');\n node.style.opacity = '0';\n node.style.transform = getScale(0.75);\n\n if (onExit) {\n onExit(node);\n }\n };\n\n var addEndListener = function addEndListener(_, next) {\n if (timeout === 'auto') {\n timer.current = setTimeout(next, autoTimeout.current || 0);\n }\n };\n\n React.useEffect(function () {\n return function () {\n clearTimeout(timer.current);\n };\n }, []);\n return React.createElement(Transition, _extends({\n appear: true,\n in: inProp,\n onEnter: handleEnter,\n onExit: handleExit,\n addEndListener: addEndListener,\n timeout: timeout === 'auto' ? null : timeout\n }, other), function (state, childProps) {\n return React.cloneElement(children, _extends({\n style: _extends({\n opacity: 0,\n transform: getScale(0.75),\n visibility: state === 'exited' && !inProp ? 'hidden' : undefined\n }, styles[state], {}, style, {}, children.props.style),\n ref: handleRef\n }, childProps));\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Grow.propTypes = {\n /**\n * A single child content element.\n */\n children: PropTypes.element,\n\n /**\n * If `true`, show the component; triggers the enter or exit animation.\n */\n in: PropTypes.bool,\n\n /**\n * @ignore\n */\n onEnter: PropTypes.func,\n\n /**\n * @ignore\n */\n onExit: PropTypes.func,\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n *\n * Set to 'auto' to automatically calculate transition time based on height.\n */\n timeout: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n enter: PropTypes.number,\n exit: PropTypes.number\n }), PropTypes.oneOf(['auto'])])\n} : void 0;\nGrow.muiSupportAuto = true;\nexport default Grow;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport debounce from '../utils/debounce';\nimport clsx from 'clsx';\nimport { chainPropTypes, elementTypeAcceptingRef, refType } from '@material-ui/utils';\nimport ownerDocument from '../utils/ownerDocument';\nimport ownerWindow from '../utils/ownerWindow';\nimport createChainedFunction from '../utils/createChainedFunction';\nimport withStyles from '../styles/withStyles';\nimport Modal from '../Modal';\nimport Grow from '../Grow';\nimport Paper from '../Paper';\nexport function getOffsetTop(rect, vertical) {\n var offset = 0;\n\n if (typeof vertical === 'number') {\n offset = vertical;\n } else if (vertical === 'center') {\n offset = rect.height / 2;\n } else if (vertical === 'bottom') {\n offset = rect.height;\n }\n\n return offset;\n}\nexport function getOffsetLeft(rect, horizontal) {\n var offset = 0;\n\n if (typeof horizontal === 'number') {\n offset = horizontal;\n } else if (horizontal === 'center') {\n offset = rect.width / 2;\n } else if (horizontal === 'right') {\n offset = rect.width;\n }\n\n return offset;\n}\n\nfunction getTransformOriginValue(transformOrigin) {\n return [transformOrigin.horizontal, transformOrigin.vertical].map(function (n) {\n return typeof n === 'number' ? \"\".concat(n, \"px\") : n;\n }).join(' ');\n} // Sum the scrollTop between two elements.\n\n\nfunction getScrollParent(parent, child) {\n var element = child;\n var scrollTop = 0;\n\n while (element && element !== parent) {\n element = element.parentElement;\n scrollTop += element.scrollTop;\n }\n\n return scrollTop;\n}\n\nfunction getAnchorEl(anchorEl) {\n return typeof anchorEl === 'function' ? anchorEl() : anchorEl;\n}\n\nexport var styles = {\n /* Styles applied to the root element */\n root: {},\n\n /* Styles applied to the `Paper` component. */\n paper: {\n position: 'absolute',\n overflowY: 'auto',\n overflowX: 'hidden',\n // So we see the popover when it's empty.\n // It's most likely on issue on userland.\n minWidth: 16,\n minHeight: 16,\n maxWidth: 'calc(100% - 32px)',\n maxHeight: 'calc(100% - 32px)',\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0\n }\n};\nvar Popover = React.forwardRef(function Popover(props, ref) {\n var action = props.action,\n anchorEl = props.anchorEl,\n _props$anchorOrigin = props.anchorOrigin,\n anchorOrigin = _props$anchorOrigin === void 0 ? {\n vertical: 'top',\n horizontal: 'left'\n } : _props$anchorOrigin,\n anchorPosition = props.anchorPosition,\n _props$anchorReferenc = props.anchorReference,\n anchorReference = _props$anchorReferenc === void 0 ? 'anchorEl' : _props$anchorReferenc,\n children = props.children,\n classes = props.classes,\n className = props.className,\n containerProp = props.container,\n _props$elevation = props.elevation,\n elevation = _props$elevation === void 0 ? 8 : _props$elevation,\n getContentAnchorEl = props.getContentAnchorEl,\n _props$marginThreshol = props.marginThreshold,\n marginThreshold = _props$marginThreshol === void 0 ? 16 : _props$marginThreshol,\n onEnter = props.onEnter,\n onEntered = props.onEntered,\n onEntering = props.onEntering,\n onExit = props.onExit,\n onExited = props.onExited,\n onExiting = props.onExiting,\n open = props.open,\n _props$PaperProps = props.PaperProps,\n PaperProps = _props$PaperProps === void 0 ? {} : _props$PaperProps,\n _props$transformOrigi = props.transformOrigin,\n transformOrigin = _props$transformOrigi === void 0 ? {\n vertical: 'top',\n horizontal: 'left'\n } : _props$transformOrigi,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Grow : _props$TransitionComp,\n _props$transitionDura = props.transitionDuration,\n transitionDurationProp = _props$transitionDura === void 0 ? 'auto' : _props$transitionDura,\n _props$TransitionProp = props.TransitionProps,\n TransitionProps = _props$TransitionProp === void 0 ? {} : _props$TransitionProp,\n other = _objectWithoutProperties(props, [\"action\", \"anchorEl\", \"anchorOrigin\", \"anchorPosition\", \"anchorReference\", \"children\", \"classes\", \"className\", \"container\", \"elevation\", \"getContentAnchorEl\", \"marginThreshold\", \"onEnter\", \"onEntered\", \"onEntering\", \"onExit\", \"onExited\", \"onExiting\", \"open\", \"PaperProps\", \"transformOrigin\", \"TransitionComponent\", \"transitionDuration\", \"TransitionProps\"]);\n\n var paperRef = React.useRef(); // Returns the top/left offset of the position\n // to attach to on the anchor element (or body if none is provided)\n\n var getAnchorOffset = React.useCallback(function (contentAnchorOffset) {\n if (anchorReference === 'anchorPosition') {\n if (process.env.NODE_ENV !== 'production') {\n if (!anchorPosition) {\n console.error('Material-UI: you need to provide a `anchorPosition` prop when using ' + '<Popover anchorReference=\"anchorPosition\" />.');\n }\n }\n\n return anchorPosition;\n }\n\n var resolvedAnchorEl = getAnchorEl(anchorEl);\n var containerWindow = ownerWindow(resolvedAnchorEl); // If an anchor element wasn't provided, just use the parent body element of this Popover\n\n var anchorElement = resolvedAnchorEl instanceof containerWindow.Element ? resolvedAnchorEl : ownerDocument(paperRef.current).body;\n var anchorRect = anchorElement.getBoundingClientRect();\n\n if (process.env.NODE_ENV !== 'production') {\n var box = anchorElement.getBoundingClientRect();\n\n if (process.env.NODE_ENV !== 'test' && box.top === 0 && box.left === 0 && box.right === 0 && box.bottom === 0) {\n console.warn(['Material-UI: the `anchorEl` prop provided to the component is invalid.', 'The anchor element should be part of the document layout.', \"Make sure the element is present in the document or that it's not display none.\"].join('\\n'));\n }\n }\n\n var anchorVertical = contentAnchorOffset === 0 ? anchorOrigin.vertical : 'center';\n return {\n top: anchorRect.top + getOffsetTop(anchorRect, anchorVertical),\n left: anchorRect.left + getOffsetLeft(anchorRect, anchorOrigin.horizontal)\n };\n }, [anchorEl, anchorOrigin.horizontal, anchorOrigin.vertical, anchorPosition, anchorReference]); // Returns the vertical offset of inner content to anchor the transform on if provided\n\n var getContentAnchorOffset = React.useCallback(function (element) {\n var contentAnchorOffset = 0;\n\n if (getContentAnchorEl && anchorReference === 'anchorEl') {\n var contentAnchorEl = getContentAnchorEl(element);\n\n if (contentAnchorEl && element.contains(contentAnchorEl)) {\n var scrollTop = getScrollParent(element, contentAnchorEl);\n contentAnchorOffset = contentAnchorEl.offsetTop + contentAnchorEl.clientHeight / 2 - scrollTop || 0;\n } // != the default value\n\n\n if (process.env.NODE_ENV !== 'production') {\n if (anchorOrigin.vertical !== 'top') {\n console.error(['Material-UI: you can not change the default `anchorOrigin.vertical` value ', 'when also providing the `getContentAnchorEl` prop to the popover component.', 'Only use one of the two props.', 'Set `getContentAnchorEl` to `null | undefined`' + ' or leave `anchorOrigin.vertical` unchanged.'].join('\\n'));\n }\n }\n }\n\n return contentAnchorOffset;\n }, [anchorOrigin.vertical, anchorReference, getContentAnchorEl]); // Return the base transform origin using the element\n // and taking the content anchor offset into account if in use\n\n var getTransformOrigin = React.useCallback(function (elemRect) {\n var contentAnchorOffset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n return {\n vertical: getOffsetTop(elemRect, transformOrigin.vertical) + contentAnchorOffset,\n horizontal: getOffsetLeft(elemRect, transformOrigin.horizontal)\n };\n }, [transformOrigin.horizontal, transformOrigin.vertical]);\n var getPositioningStyle = React.useCallback(function (element) {\n // Check if the parent has requested anchoring on an inner content node\n var contentAnchorOffset = getContentAnchorOffset(element);\n var elemRect = {\n width: element.offsetWidth,\n height: element.offsetHeight\n }; // Get the transform origin point on the element itself\n\n var elemTransformOrigin = getTransformOrigin(elemRect, contentAnchorOffset);\n\n if (anchorReference === 'none') {\n return {\n top: null,\n left: null,\n transformOrigin: getTransformOriginValue(elemTransformOrigin)\n };\n } // Get the offset of of the anchoring element\n\n\n var anchorOffset = getAnchorOffset(contentAnchorOffset); // Calculate element positioning\n\n var top = anchorOffset.top - elemTransformOrigin.vertical;\n var left = anchorOffset.left - elemTransformOrigin.horizontal;\n var bottom = top + elemRect.height;\n var right = left + elemRect.width; // Use the parent window of the anchorEl if provided\n\n var containerWindow = ownerWindow(getAnchorEl(anchorEl)); // Window thresholds taking required margin into account\n\n var heightThreshold = containerWindow.innerHeight - marginThreshold;\n var widthThreshold = containerWindow.innerWidth - marginThreshold; // Check if the vertical axis needs shifting\n\n if (top < marginThreshold) {\n var diff = top - marginThreshold;\n top -= diff;\n elemTransformOrigin.vertical += diff;\n } else if (bottom > heightThreshold) {\n var _diff = bottom - heightThreshold;\n\n top -= _diff;\n elemTransformOrigin.vertical += _diff;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (elemRect.height > heightThreshold && elemRect.height && heightThreshold) {\n console.error(['Material-UI: the popover component is too tall.', \"Some part of it can not be seen on the screen (\".concat(elemRect.height - heightThreshold, \"px).\"), 'Please consider adding a `max-height` to improve the user-experience.'].join('\\n'));\n }\n } // Check if the horizontal axis needs shifting\n\n\n if (left < marginThreshold) {\n var _diff2 = left - marginThreshold;\n\n left -= _diff2;\n elemTransformOrigin.horizontal += _diff2;\n } else if (right > widthThreshold) {\n var _diff3 = right - widthThreshold;\n\n left -= _diff3;\n elemTransformOrigin.horizontal += _diff3;\n }\n\n return {\n top: \"\".concat(Math.round(top), \"px\"),\n left: \"\".concat(Math.round(left), \"px\"),\n transformOrigin: getTransformOriginValue(elemTransformOrigin)\n };\n }, [anchorEl, anchorReference, getAnchorOffset, getContentAnchorOffset, getTransformOrigin, marginThreshold]);\n var setPositioningStyles = React.useCallback(function () {\n var element = paperRef.current;\n\n if (!element) {\n return;\n }\n\n var positioning = getPositioningStyle(element);\n\n if (positioning.top !== null) {\n element.style.top = positioning.top;\n }\n\n if (positioning.left !== null) {\n element.style.left = positioning.left;\n }\n\n element.style.transformOrigin = positioning.transformOrigin;\n }, [getPositioningStyle]);\n\n var handleEntering = function handleEntering(element, isAppearing) {\n if (onEntering) {\n onEntering(element, isAppearing);\n }\n\n setPositioningStyles();\n };\n\n var handlePaperRef = React.useCallback(function (instance) {\n // #StrictMode ready\n paperRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n React.useEffect(function () {\n if (open) {\n setPositioningStyles();\n }\n });\n React.useImperativeHandle(action, function () {\n return open ? {\n updatePosition: function updatePosition() {\n setPositioningStyles();\n }\n } : null;\n }, [open, setPositioningStyles]);\n React.useEffect(function () {\n if (!open) {\n return undefined;\n }\n\n var handleResize = debounce(function () {\n setPositioningStyles();\n });\n window.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n window.removeEventListener('rezise', handleResize);\n };\n }, [open, setPositioningStyles]);\n var transitionDuration = transitionDurationProp;\n\n if (transitionDurationProp === 'auto' && !TransitionComponent.muiSupportAuto) {\n transitionDuration = undefined;\n } // If the container prop is provided, use that\n // If the anchorEl prop is provided, use its parent body element as the container\n // If neither are provided let the Modal take care of choosing the container\n\n\n var container = containerProp || (anchorEl ? ownerDocument(getAnchorEl(anchorEl)).body : undefined);\n return React.createElement(Modal, _extends({\n container: container,\n open: open,\n ref: ref,\n BackdropProps: {\n invisible: true\n },\n className: clsx(classes.root, className)\n }, other), React.createElement(TransitionComponent, _extends({\n appear: true,\n in: open,\n onEnter: onEnter,\n onEntered: onEntered,\n onExit: onExit,\n onExited: onExited,\n onExiting: onExiting,\n timeout: transitionDuration\n }, TransitionProps, {\n onEntering: createChainedFunction(handleEntering, TransitionProps.onEntering)\n }), React.createElement(Paper, _extends({\n elevation: elevation,\n ref: handlePaperRef\n }, PaperProps, {\n className: clsx(classes.paper, PaperProps.className)\n }), children)));\n});\nprocess.env.NODE_ENV !== \"production\" ? Popover.propTypes = {\n /**\n * A ref for imperative actions.\n * It currently only supports updatePosition() action.\n */\n action: refType,\n\n /**\n * This is the DOM element, or a function that returns the DOM element,\n * that may be used to set the position of the popover.\n */\n anchorEl: chainPropTypes(PropTypes.oneOfType([PropTypes.object, PropTypes.func]), function (props) {\n if (props.open && (!props.anchorReference || props.anchorReference === 'anchorEl')) {\n var resolvedAnchorEl = getAnchorEl(props.anchorEl);\n var containerWindow = ownerWindow(resolvedAnchorEl);\n\n if (resolvedAnchorEl instanceof containerWindow.Element) {\n var box = resolvedAnchorEl.getBoundingClientRect();\n\n if (process.env.NODE_ENV !== 'test' && box.top === 0 && box.left === 0 && box.right === 0 && box.bottom === 0) {\n return new Error(['Material-UI: the `anchorEl` prop provided to the component is invalid.', 'The anchor element should be part of the document layout.', \"Make sure the element is present in the document or that it's not display none.\"].join('\\n'));\n }\n } else {\n return new Error(['Material-UI: the `anchorEl` prop provided to the component is invalid.', \"It should be an Element instance but it's `\".concat(resolvedAnchorEl, \"` instead.\")].join('\\n'));\n }\n }\n\n return null;\n }),\n\n /**\n * This is the point on the anchor where the popover's\n * `anchorEl` will attach to. This is not used when the\n * anchorReference is 'anchorPosition'.\n *\n * Options:\n * vertical: [top, center, bottom];\n * horizontal: [left, center, right].\n */\n anchorOrigin: PropTypes.shape({\n horizontal: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['left', 'center', 'right'])]).isRequired,\n vertical: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['top', 'center', 'bottom'])]).isRequired\n }),\n\n /**\n * This is the position that may be used\n * to set the position of the popover.\n * The coordinates are relative to\n * the application's client area.\n */\n anchorPosition: PropTypes.shape({\n left: PropTypes.number.isRequired,\n top: PropTypes.number.isRequired\n }),\n\n /*\n * This determines which anchor prop to refer to to set\n * the position of the popover.\n */\n anchorReference: PropTypes.oneOf(['anchorEl', 'anchorPosition', 'none']),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * A node, component instance, or function that returns either.\n * The `container` will passed to the Modal component.\n * By default, it uses the body of the anchorEl's top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n /**\n * The elevation of the popover.\n */\n elevation: PropTypes.number,\n\n /**\n * This function is called in order to retrieve the content anchor element.\n * It's the opposite of the `anchorEl` prop.\n * The content anchor element should be an element inside the popover.\n * It's used to correctly scroll and set the position of the popover.\n * The positioning strategy tries to make the content anchor element just above the\n * anchor element.\n */\n getContentAnchorEl: PropTypes.func,\n\n /**\n * Specifies how close to the edge of the window the popover can appear.\n */\n marginThreshold: PropTypes.number,\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired before the component is entering.\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired when the component has entered.\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired when the component is entering.\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired before the component is exiting.\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired when the component has exited.\n */\n onExited: PropTypes.func,\n\n /**\n * Callback fired when the component is exiting.\n */\n onExiting: PropTypes.func,\n\n /**\n * If `true`, the popover is visible.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * Props applied to the [`Paper`](/api/paper/) element.\n */\n PaperProps: PropTypes.shape({\n component: elementTypeAcceptingRef\n }),\n\n /**\n * This is the point on the popover which\n * will attach to the anchor's origin.\n *\n * Options:\n * vertical: [top, center, bottom, x(px)];\n * horizontal: [left, center, right, x(px)].\n */\n transformOrigin: PropTypes.shape({\n horizontal: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['left', 'center', 'right'])]).isRequired,\n vertical: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['top', 'center', 'bottom'])]).isRequired\n }),\n\n /**\n * The component used for the transition.\n */\n TransitionComponent: PropTypes.elementType,\n\n /**\n * Set to 'auto' to automatically calculate transition time based on height.\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n enter: PropTypes.number,\n exit: PropTypes.number\n }), PropTypes.oneOf(['auto'])]),\n\n /**\n * Props applied to the `Transition` element.\n */\n TransitionProps: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiPopover'\n})(Popover);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport ListContext from './ListContext';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n listStyle: 'none',\n margin: 0,\n padding: 0,\n position: 'relative'\n },\n\n /* Styles applied to the root element if `disablePadding={false}`. */\n padding: {\n paddingTop: 8,\n paddingBottom: 8\n },\n\n /* Styles applied to the root element if dense. */\n dense: {},\n\n /* Styles applied to the root element if a `subheader` is provided. */\n subheader: {\n paddingTop: 0\n }\n};\nvar List = React.forwardRef(function List(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'ul' : _props$component,\n _props$dense = props.dense,\n dense = _props$dense === void 0 ? false : _props$dense,\n _props$disablePadding = props.disablePadding,\n disablePadding = _props$disablePadding === void 0 ? false : _props$disablePadding,\n subheader = props.subheader,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"component\", \"dense\", \"disablePadding\", \"subheader\"]);\n\n var context = React.useMemo(function () {\n return {\n dense: dense\n };\n }, [dense]);\n return React.createElement(ListContext.Provider, {\n value: context\n }, React.createElement(Component, _extends({\n className: clsx(classes.root, className, dense && classes.dense, !disablePadding && classes.padding, subheader && classes.subheader),\n ref: ref\n }, other), subheader, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? List.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, compact vertical padding designed for keyboard and mouse input will be used for\n * the list and list items.\n * The prop is available to descendant components as the `dense` context.\n */\n dense: PropTypes.bool,\n\n /**\n * If `true`, vertical padding will be removed from the list.\n */\n disablePadding: PropTypes.bool,\n\n /**\n * The content of the subheader, normally `ListSubheader`.\n */\n subheader: PropTypes.node\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiList'\n})(List);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport ownerDocument from '../utils/ownerDocument';\nimport List from '../List';\nimport getScrollbarSize from '../utils/getScrollbarSize';\nimport useForkRef from '../utils/useForkRef';\n\nfunction nextItem(list, item, disableListWrap) {\n if (list === item) {\n return list.firstChild;\n }\n\n if (item && item.nextElementSibling) {\n return item.nextElementSibling;\n }\n\n return disableListWrap ? null : list.firstChild;\n}\n\nfunction previousItem(list, item, disableListWrap) {\n if (list === item) {\n return disableListWrap ? list.firstChild : list.lastChild;\n }\n\n if (item && item.previousElementSibling) {\n return item.previousElementSibling;\n }\n\n return disableListWrap ? null : list.lastChild;\n}\n\nfunction textCriteriaMatches(nextFocus, textCriteria) {\n if (textCriteria === undefined) {\n return true;\n }\n\n var text = nextFocus.innerText;\n\n if (text === undefined) {\n // jsdom doesn't support innerText\n text = nextFocus.textContent;\n }\n\n text = text.trim().toLowerCase();\n\n if (text.length === 0) {\n return false;\n }\n\n if (textCriteria.repeating) {\n return text[0] === textCriteria.keys[0];\n }\n\n return text.indexOf(textCriteria.keys.join('')) === 0;\n}\n\nfunction moveFocus(list, currentFocus, disableListWrap, traversalFunction, textCriteria) {\n var wrappedOnce = false;\n var nextFocus = traversalFunction(list, currentFocus, currentFocus ? disableListWrap : false);\n\n while (nextFocus) {\n // Prevent infinite loop.\n if (nextFocus === list.firstChild) {\n if (wrappedOnce) {\n return false;\n }\n\n wrappedOnce = true;\n } // Move to the next element.\n\n\n if (!nextFocus.hasAttribute('tabindex') || nextFocus.disabled || nextFocus.getAttribute('aria-disabled') === 'true' || !textCriteriaMatches(nextFocus, textCriteria)) {\n nextFocus = traversalFunction(list, nextFocus, disableListWrap);\n } else {\n nextFocus.focus();\n return true;\n }\n }\n\n return false;\n}\n\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * A permanently displayed menu following https://www.w3.org/TR/wai-aria-practices/#menubutton\n * It's exposed to help customization of the [`Menu`](/api/menu/) component. If you\n * use it separately you need to move focus into the component manually. Once\n * the focus is placed inside the component it is fully keyboard accessible.\n */\n\nvar MenuList = React.forwardRef(function MenuList(props, ref) {\n var actions = props.actions,\n _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n _props$autoFocusItem = props.autoFocusItem,\n autoFocusItem = _props$autoFocusItem === void 0 ? false : _props$autoFocusItem,\n children = props.children,\n className = props.className,\n onKeyDown = props.onKeyDown,\n _props$disableListWra = props.disableListWrap,\n disableListWrap = _props$disableListWra === void 0 ? false : _props$disableListWra,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'selectedMenu' : _props$variant,\n other = _objectWithoutProperties(props, [\"actions\", \"autoFocus\", \"autoFocusItem\", \"children\", \"className\", \"onKeyDown\", \"disableListWrap\", \"variant\"]);\n\n var listRef = React.useRef(null);\n var textCriteriaRef = React.useRef({\n keys: [],\n repeating: true,\n previousKeyMatched: true,\n lastTime: null\n });\n useEnhancedEffect(function () {\n if (autoFocus) {\n listRef.current.focus();\n }\n }, [autoFocus]);\n React.useImperativeHandle(actions, function () {\n return {\n adjustStyleForScrollbar: function adjustStyleForScrollbar(containerElement, theme) {\n // Let's ignore that piece of logic if users are already overriding the width\n // of the menu.\n var noExplicitWidth = !listRef.current.style.width;\n\n if (containerElement.clientHeight < listRef.current.clientHeight && noExplicitWidth) {\n var scrollbarSize = \"\".concat(getScrollbarSize(true), \"px\");\n listRef.current.style[theme.direction === 'rtl' ? 'paddingLeft' : 'paddingRight'] = scrollbarSize;\n listRef.current.style.width = \"calc(100% + \".concat(scrollbarSize, \")\");\n }\n\n return listRef.current;\n }\n };\n }, []);\n\n var handleKeyDown = function handleKeyDown(event) {\n var list = listRef.current;\n var key = event.key;\n /**\n * @type {Element} - will always be defined since we are in a keydown handler\n * attached to an element. A keydown event is either dispatched to the activeElement\n * or document.body or document.documentElement. Only the first case will\n * trigger this specific handler.\n */\n\n var currentFocus = ownerDocument(list).activeElement;\n\n if (key === 'ArrowDown') {\n // Prevent scroll of the page\n event.preventDefault();\n moveFocus(list, currentFocus, disableListWrap, nextItem);\n } else if (key === 'ArrowUp') {\n event.preventDefault();\n moveFocus(list, currentFocus, disableListWrap, previousItem);\n } else if (key === 'Home') {\n event.preventDefault();\n moveFocus(list, null, disableListWrap, nextItem);\n } else if (key === 'End') {\n event.preventDefault();\n moveFocus(list, null, disableListWrap, previousItem);\n } else if (key.length === 1) {\n var criteria = textCriteriaRef.current;\n var lowerKey = key.toLowerCase();\n var currTime = performance.now();\n\n if (criteria.keys.length > 0) {\n // Reset\n if (currTime - criteria.lastTime > 500) {\n criteria.keys = [];\n criteria.repeating = true;\n criteria.previousKeyMatched = true;\n } else if (criteria.repeating && lowerKey !== criteria.keys[0]) {\n criteria.repeating = false;\n }\n }\n\n criteria.lastTime = currTime;\n criteria.keys.push(lowerKey);\n var keepFocusOnCurrent = currentFocus && !criteria.repeating && textCriteriaMatches(currentFocus, criteria);\n\n if (criteria.previousKeyMatched && (keepFocusOnCurrent || moveFocus(list, currentFocus, false, nextItem, criteria))) {\n event.preventDefault();\n } else {\n criteria.previousKeyMatched = false;\n }\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n };\n\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n listRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n var handleRef = useForkRef(handleOwnRef, ref);\n /**\n * the index of the item should receive focus\n * in a `variant=\"selectedMenu\"` it's the first `selected` item\n * otherwise it's the very first item.\n */\n\n var activeItemIndex = -1; // since we inject focus related props into children we have to do a lookahead\n // to check if there is a `selected` item. We're looking for the last `selected`\n // item and use the first valid item as a fallback\n\n React.Children.forEach(children, function (child, index) {\n if (!React.isValidElement(child)) {\n return;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: the Menu component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n if (!child.props.disabled) {\n if (variant === 'selectedMenu' && child.props.selected) {\n activeItemIndex = index;\n } else if (activeItemIndex === -1) {\n activeItemIndex = index;\n }\n }\n });\n var items = React.Children.map(children, function (child, index) {\n if (index === activeItemIndex) {\n var newChildProps = {};\n\n if (autoFocusItem) {\n newChildProps.autoFocus = true;\n }\n\n if (child.props.tabIndex === undefined && variant === 'selectedMenu') {\n newChildProps.tabIndex = 0;\n }\n\n if (newChildProps !== null) {\n return React.cloneElement(child, newChildProps);\n }\n }\n\n return child;\n });\n return React.createElement(List, _extends({\n role: \"menu\",\n ref: handleRef,\n className: className,\n onKeyDown: handleKeyDown,\n tabIndex: autoFocus ? 0 : -1\n }, other), items);\n});\nprocess.env.NODE_ENV !== \"production\" ? MenuList.propTypes = {\n /**\n * @ignore\n */\n actions: PropTypes.shape({\n current: PropTypes.object\n }),\n\n /**\n * If `true`, will focus the `[role=\"menu\"]` container and move into tab order\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, will focus the first menuitem if `variant=\"menu\"` or selected item\n * if `variant=\"selectedMenu\"`\n */\n autoFocusItem: PropTypes.bool,\n\n /**\n * MenuList contents, normally `MenuItem`s.\n */\n children: PropTypes.node,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the menu items will not wrap focus.\n */\n disableListWrap: PropTypes.bool,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * The variant to use. Use `menu` to prevent selected items from impacting the initial focus\n * and the vertical alignment relative to the anchor element.\n */\n variant: PropTypes.oneOf(['menu', 'selectedMenu'])\n} : void 0;\nexport default MenuList;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Popover from '../Popover';\nimport MenuList from '../MenuList';\nimport ReactDOM from 'react-dom';\nimport setRef from '../utils/setRef';\nimport useTheme from '../styles/useTheme';\nvar RTL_ORIGIN = {\n vertical: 'top',\n horizontal: 'right'\n};\nvar LTR_ORIGIN = {\n vertical: 'top',\n horizontal: 'left'\n};\nexport var styles = {\n /* Styles applied to the `Paper` component. */\n paper: {\n // specZ: The maximum height of a simple menu should be one or more rows less than the view\n // height. This ensures a tapable area outside of the simple menu with which to dismiss\n // the menu.\n maxHeight: 'calc(100% - 96px)',\n // Add iOS momentum scrolling.\n WebkitOverflowScrolling: 'touch'\n },\n\n /* Styles applied to the `List` component via `MenuList`. */\n list: {\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0\n }\n};\nvar Menu = React.forwardRef(function Menu(props, ref) {\n var _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? true : _props$autoFocus,\n children = props.children,\n classes = props.classes,\n _props$disableAutoFoc = props.disableAutoFocusItem,\n disableAutoFocusItem = _props$disableAutoFoc === void 0 ? false : _props$disableAutoFoc,\n _props$MenuListProps = props.MenuListProps,\n MenuListProps = _props$MenuListProps === void 0 ? {} : _props$MenuListProps,\n onClose = props.onClose,\n onEntering = props.onEntering,\n open = props.open,\n _props$PaperProps = props.PaperProps,\n PaperProps = _props$PaperProps === void 0 ? {} : _props$PaperProps,\n PopoverClasses = props.PopoverClasses,\n _props$transitionDura = props.transitionDuration,\n transitionDuration = _props$transitionDura === void 0 ? 'auto' : _props$transitionDura,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'selectedMenu' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoFocus\", \"children\", \"classes\", \"disableAutoFocusItem\", \"MenuListProps\", \"onClose\", \"onEntering\", \"open\", \"PaperProps\", \"PopoverClasses\", \"transitionDuration\", \"variant\"]);\n\n var theme = useTheme();\n var autoFocusItem = autoFocus && !disableAutoFocusItem && open;\n var menuListActionsRef = React.useRef(null);\n var contentAnchorRef = React.useRef(null);\n\n var getContentAnchorEl = function getContentAnchorEl() {\n return contentAnchorRef.current;\n };\n\n var handleEntering = function handleEntering(element, isAppearing) {\n if (menuListActionsRef.current) {\n menuListActionsRef.current.adjustStyleForScrollbar(element, theme);\n }\n\n if (onEntering) {\n onEntering(element, isAppearing);\n }\n };\n\n var handleListKeyDown = function handleListKeyDown(event) {\n if (event.key === 'Tab') {\n event.preventDefault();\n\n if (onClose) {\n onClose(event, 'tabKeyDown');\n }\n }\n };\n /**\n * the index of the item should receive focus\n * in a `variant=\"selectedMenu\"` it's the first `selected` item\n * otherwise it's the very first item.\n */\n\n\n var activeItemIndex = -1; // since we inject focus related props into children we have to do a lookahead\n // to check if there is a `selected` item. We're looking for the last `selected`\n // item and use the first valid item as a fallback\n\n React.Children.map(children, function (child, index) {\n if (!React.isValidElement(child)) {\n return;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: the Menu component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n if (!child.props.disabled) {\n if (variant !== \"menu\" && child.props.selected) {\n activeItemIndex = index;\n } else if (activeItemIndex === -1) {\n activeItemIndex = index;\n }\n }\n });\n var items = React.Children.map(children, function (child, index) {\n if (index === activeItemIndex) {\n return React.cloneElement(child, {\n ref: function ref(instance) {\n // #StrictMode ready\n contentAnchorRef.current = ReactDOM.findDOMNode(instance);\n setRef(child.ref, instance);\n }\n });\n }\n\n return child;\n });\n return React.createElement(Popover, _extends({\n getContentAnchorEl: getContentAnchorEl,\n classes: PopoverClasses,\n onClose: onClose,\n onEntering: handleEntering,\n anchorOrigin: theme.direction === 'rtl' ? RTL_ORIGIN : LTR_ORIGIN,\n transformOrigin: theme.direction === 'rtl' ? RTL_ORIGIN : LTR_ORIGIN,\n PaperProps: _extends({}, PaperProps, {\n classes: _extends({}, PaperProps.classes, {\n root: classes.paper\n })\n }),\n open: open,\n ref: ref,\n transitionDuration: transitionDuration\n }, other), React.createElement(MenuList, _extends({\n onKeyDown: handleListKeyDown,\n actions: menuListActionsRef,\n autoFocus: autoFocus && (activeItemIndex === -1 || disableAutoFocusItem),\n autoFocusItem: autoFocusItem,\n variant: variant\n }, MenuListProps, {\n className: clsx(classes.list, MenuListProps.className)\n }), items));\n});\nprocess.env.NODE_ENV !== \"production\" ? Menu.propTypes = {\n /**\n * The DOM element used to set the position of the menu.\n */\n anchorEl: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n /**\n * If `true` (Default) will focus the `[role=\"menu\"]` if no focusable child is found. Disabled\n * children are not focusable. If you set this prop to `false` focus will be placed\n * on the parent modal container. This has severe accessibility implications\n * and should only be considered if you manage focus otherwise.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Menu contents, normally `MenuItem`s.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * When opening the menu will not focus the active item but the `[role=\"menu\"]`\n * unless `autoFocus` is also set to `false`. Not using the default means not\n * following WAI-ARIA authoring practices. Please be considerate about possible\n * accessibility implications.\n */\n disableAutoFocusItem: PropTypes.bool,\n\n /**\n * Props applied to the [`MenuList`](/api/menu-list/) element.\n */\n MenuListProps: PropTypes.object,\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`, `\"tabKeyDown\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired before the Menu enters.\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired when the Menu has entered.\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired when the Menu is entering.\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired before the Menu exits.\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired when the Menu has exited.\n */\n onExited: PropTypes.func,\n\n /**\n * Callback fired when the Menu is exiting.\n */\n onExiting: PropTypes.func,\n\n /**\n * If `true`, the menu is visible.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * @ignore\n */\n PaperProps: PropTypes.object,\n\n /**\n * `classes` prop applied to the [`Popover`](/api/popover/) element.\n */\n PopoverClasses: PropTypes.object,\n\n /**\n * The length of the transition in `ms`, or 'auto'\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n enter: PropTypes.number,\n exit: PropTypes.number\n }), PropTypes.oneOf(['auto'])]),\n\n /**\n * The variant to use. Use `menu` to prevent selected items from impacting the initial focus\n * and the vertical alignment relative to the anchor element.\n */\n variant: PropTypes.oneOf(['menu', 'selectedMenu'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiMenu'\n})(Menu);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _toConsumableArray from \"@babel/runtime/helpers/esm/toConsumableArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _typeof from \"@babel/runtime/helpers/esm/typeof\";\nimport React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport capitalize from '../utils/capitalize';\nimport { refType } from '@material-ui/utils';\nimport Menu from '../Menu/Menu';\nimport { isFilled } from '../InputBase/utils';\nimport useForkRef from '../utils/useForkRef';\n\nfunction areEqualValues(a, b) {\n if (_typeof(b) === 'object' && b !== null) {\n return a === b;\n }\n\n return String(a) === String(b);\n}\n\nfunction isEmpty(display) {\n return display == null || typeof display === 'string' && !display.trim();\n}\n/**\n * @ignore - internal component.\n */\n\n\nvar SelectInput = React.forwardRef(function SelectInput(props, ref) {\n var autoFocus = props.autoFocus,\n autoWidth = props.autoWidth,\n children = props.children,\n classes = props.classes,\n className = props.className,\n defaultValue = props.defaultValue,\n disabled = props.disabled,\n displayEmpty = props.displayEmpty,\n IconComponent = props.IconComponent,\n inputRefProp = props.inputRef,\n labelId = props.labelId,\n _props$MenuProps = props.MenuProps,\n MenuProps = _props$MenuProps === void 0 ? {} : _props$MenuProps,\n multiple = props.multiple,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onClose = props.onClose,\n onFocus = props.onFocus,\n onOpen = props.onOpen,\n openProp = props.open,\n readOnly = props.readOnly,\n renderValue = props.renderValue,\n required = props.required,\n _props$SelectDisplayP = props.SelectDisplayProps,\n SelectDisplayProps = _props$SelectDisplayP === void 0 ? {} : _props$SelectDisplayP,\n tabIndexProp = props.tabIndex,\n type = props.type,\n valueProp = props.value,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoFocus\", \"autoWidth\", \"children\", \"classes\", \"className\", \"defaultValue\", \"disabled\", \"displayEmpty\", \"IconComponent\", \"inputRef\", \"labelId\", \"MenuProps\", \"multiple\", \"name\", \"onBlur\", \"onChange\", \"onClose\", \"onFocus\", \"onOpen\", \"open\", \"readOnly\", \"renderValue\", \"required\", \"SelectDisplayProps\", \"tabIndex\", \"type\", \"value\", \"variant\"]);\n\n var _React$useRef = React.useRef(valueProp != null),\n isControlled = _React$useRef.current;\n\n var _React$useState = React.useState(defaultValue),\n valueState = _React$useState[0],\n setValueState = _React$useState[1];\n\n var value = isControlled ? valueProp : valueState;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (isControlled !== (valueProp != null)) {\n console.error([\"Material-UI: A component is changing \".concat(isControlled ? 'a ' : 'an un', \"controlled Select to be \").concat(isControlled ? 'un' : '', \"controlled.\"), 'Elements should not switch from uncontrolled to controlled (or vice versa).', 'Decide between using a controlled or uncontrolled Select ' + 'element for the lifetime of the component.', 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [valueProp, isControlled]);\n }\n\n var inputRef = React.useRef(null);\n\n var _React$useState2 = React.useState(null),\n displayNode = _React$useState2[0],\n setDisplayNode = _React$useState2[1];\n\n var _React$useRef2 = React.useRef(openProp != null),\n isOpenControlled = _React$useRef2.current;\n\n var _React$useState3 = React.useState(),\n menuMinWidthState = _React$useState3[0],\n setMenuMinWidthState = _React$useState3[1];\n\n var _React$useState4 = React.useState(false),\n openState = _React$useState4[0],\n setOpenState = _React$useState4[1];\n\n var handleRef = useForkRef(ref, inputRefProp);\n React.useImperativeHandle(handleRef, function () {\n return {\n focus: function focus() {\n displayNode.focus();\n },\n node: inputRef.current,\n value: value\n };\n }, [displayNode, value]);\n React.useEffect(function () {\n if (autoFocus && displayNode) {\n displayNode.focus();\n }\n }, [autoFocus, displayNode]);\n\n var update = function update(open, event) {\n if (open) {\n if (onOpen) {\n onOpen(event);\n }\n } else if (onClose) {\n onClose(event);\n }\n\n if (!isOpenControlled) {\n setMenuMinWidthState(autoWidth ? null : displayNode.clientWidth);\n setOpenState(open);\n }\n };\n\n var handleMouseDown = function handleMouseDown(event) {\n // Hijack the default focus behavior.\n event.preventDefault();\n displayNode.focus();\n update(true, event);\n };\n\n var handleClose = function handleClose(event) {\n update(false, event);\n };\n\n var handleItemClick = function handleItemClick(child) {\n return function (event) {\n if (!multiple) {\n update(false, event);\n }\n\n var newValue;\n\n if (multiple) {\n newValue = Array.isArray(value) ? _toConsumableArray(value) : [];\n var itemIndex = value.indexOf(child.props.value);\n\n if (itemIndex === -1) {\n newValue.push(child.props.value);\n } else {\n newValue.splice(itemIndex, 1);\n }\n } else {\n newValue = child.props.value;\n }\n\n if (!isControlled) {\n setValueState(newValue);\n }\n\n if (onChange) {\n event.persist(); // Preact support, target is read only property on a native event.\n\n Object.defineProperty(event, 'target', {\n writable: true,\n value: {\n value: newValue,\n name: name\n }\n });\n onChange(event, child);\n }\n };\n };\n\n var handleKeyDown = function handleKeyDown(event) {\n if (!readOnly) {\n var validKeys = [' ', 'ArrowUp', 'ArrowDown', // The native select doesn't respond to enter on MacOS, but it's recommended by\n // https://www.w3.org/TR/wai-aria-practices/examples/listbox/listbox-collapsible.html\n 'Enter'];\n\n if (validKeys.indexOf(event.key) !== -1) {\n event.preventDefault();\n update(true, event);\n }\n }\n };\n\n var open = displayNode !== null && (isOpenControlled ? openProp : openState);\n\n var handleBlur = function handleBlur(event) {\n // if open event.stopImmediatePropagation\n if (!open && onBlur) {\n event.persist(); // Preact support, target is read only property on a native event.\n\n Object.defineProperty(event, 'target', {\n writable: true,\n value: {\n value: value,\n name: name\n }\n });\n onBlur(event);\n }\n };\n\n delete other['aria-invalid'];\n var display;\n var displaySingle;\n var displayMultiple = [];\n var computeDisplay = false;\n var foundMatch = false; // No need to display any value if the field is empty.\n\n if (isFilled({\n value: value\n }) || displayEmpty) {\n if (renderValue) {\n display = renderValue(value);\n } else {\n computeDisplay = true;\n }\n }\n\n var items = React.Children.map(children, function (child) {\n if (!React.isValidElement(child)) {\n return null;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: the Select component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n var selected;\n\n if (multiple) {\n if (!Array.isArray(value)) {\n throw new Error('Material-UI: the `value` prop must be an array ' + 'when using the `Select` component with `multiple`.');\n }\n\n selected = value.some(function (v) {\n return areEqualValues(v, child.props.value);\n });\n\n if (selected && computeDisplay) {\n displayMultiple.push(child.props.children);\n }\n } else {\n selected = areEqualValues(value, child.props.value);\n\n if (selected && computeDisplay) {\n displaySingle = child.props.children;\n }\n }\n\n if (selected) {\n foundMatch = true;\n }\n\n return React.cloneElement(child, {\n 'aria-selected': selected ? 'true' : undefined,\n onClick: handleItemClick(child),\n onKeyUp: function onKeyUp(event) {\n if (event.key === ' ') {\n // otherwise our MenuItems dispatches a click event\n // it's not behavior of the native <option> and causes\n // the select to close immediately since we open on space keydown\n event.preventDefault();\n }\n\n var onKeyUp = child.props.onKeyUp;\n\n if (typeof onKeyUp === 'function') {\n onKeyUp(event);\n }\n },\n role: 'option',\n selected: selected,\n value: undefined,\n // The value is most likely not a valid HTML attribute.\n 'data-value': child.props.value // Instead, we provide it as a data attribute.\n\n });\n });\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (!foundMatch && !multiple && value !== '') {\n var values = React.Children.toArray(children).map(function (child) {\n return child.props.value;\n });\n console.warn([\"Material-UI: you have provided an out-of-range value `\".concat(value, \"` for the select \").concat(name ? \"(name=\\\"\".concat(name, \"\\\") \") : '', \"component.\"), \"Consider providing a value that matches one of the available options or ''.\", \"The available values are \".concat(values.filter(function (x) {\n return x != null;\n }).map(function (x) {\n return \"`\".concat(x, \"`\");\n }).join(', ') || '\"\"', \".\")].join('\\n'));\n }\n }, [foundMatch, children, multiple, name, value]);\n }\n\n if (computeDisplay) {\n display = multiple ? displayMultiple.join(', ') : displaySingle;\n } // Avoid performing a layout computation in the render method.\n\n\n var menuMinWidth = menuMinWidthState;\n\n if (!autoWidth && isOpenControlled && displayNode) {\n menuMinWidth = displayNode.clientWidth;\n }\n\n var tabIndex;\n\n if (typeof tabIndexProp !== 'undefined') {\n tabIndex = tabIndexProp;\n } else {\n tabIndex = disabled ? null : 0;\n }\n\n var buttonId = SelectDisplayProps.id || (name ? \"mui-component-select-\".concat(name) : undefined);\n return React.createElement(React.Fragment, null, React.createElement(\"div\", _extends({\n className: clsx(classes.root, // TODO v5: merge root and select\n classes.select, classes.selectMenu, classes[variant], className, disabled && classes.disabled),\n ref: setDisplayNode,\n tabIndex: tabIndex,\n role: \"button\",\n \"aria-expanded\": open ? 'true' : undefined,\n \"aria-labelledby\": \"\".concat(labelId || '', \" \").concat(buttonId || ''),\n \"aria-haspopup\": \"listbox\",\n onKeyDown: handleKeyDown,\n onMouseDown: disabled || readOnly ? null : handleMouseDown,\n onBlur: handleBlur,\n onFocus: onFocus\n }, SelectDisplayProps, {\n // The id is required for proper a11y\n id: buttonId\n }), isEmpty(display) ? // eslint-disable-next-line react/no-danger\n React.createElement(\"span\", {\n dangerouslySetInnerHTML: {\n __html: '​'\n }\n }) : display), React.createElement(\"input\", _extends({\n value: Array.isArray(value) ? value.join(',') : value,\n name: name,\n ref: inputRef,\n type: \"hidden\",\n autoFocus: autoFocus\n }, other)), React.createElement(IconComponent, {\n className: clsx(classes.icon, classes[\"icon\".concat(capitalize(variant))], open && classes.iconOpen)\n }), React.createElement(Menu, _extends({\n id: \"menu-\".concat(name || ''),\n anchorEl: displayNode,\n open: open,\n onClose: handleClose\n }, MenuProps, {\n MenuListProps: _extends({\n 'aria-labelledby': labelId,\n role: 'listbox',\n disableListWrap: true\n }, MenuProps.MenuListProps),\n PaperProps: _extends({}, MenuProps.PaperProps, {\n style: _extends({\n minWidth: menuMinWidth\n }, MenuProps.PaperProps != null ? MenuProps.PaperProps.style : null)\n })\n }), items));\n});\nprocess.env.NODE_ENV !== \"production\" ? SelectInput.propTypes = {\n /**\n * @ignore\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, the width of the popover will automatically be set according to the items inside the\n * menu, otherwise it will be at least the width of the select input.\n */\n autoWidth: PropTypes.bool,\n\n /**\n * The option elements to populate the select with.\n * Can be some `<MenuItem>` elements.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the select element.\n */\n className: PropTypes.string,\n\n /**\n * The default element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the select will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the selected item is displayed even if its value is empty.\n */\n displayEmpty: PropTypes.bool,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType.isRequired,\n\n /**\n * Imperative handle implementing `{ value: T, node: HTMLElement, focus(): void }`\n * Equivalent to `ref`\n */\n inputRef: refType,\n\n /**\n * The idea of an element that acts as an additional label. The Select will\n * be labelled by the additional label and the selected value.\n */\n labelId: PropTypes.string,\n\n /**\n * Props applied to the [`Menu`](/api/menu/) element.\n */\n MenuProps: PropTypes.object,\n\n /**\n * If `true`, `value` must be an array and the menu will support multiple selections.\n */\n multiple: PropTypes.bool,\n\n /**\n * Name attribute of the `select` or hidden `input` element.\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (any).\n * @param {object} [child] The react element that was selected.\n */\n onChange: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be closed.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onClose: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be opened.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onOpen: PropTypes.func,\n\n /**\n * Control `select` open state.\n */\n open: PropTypes.bool,\n\n /**\n * @ignore\n */\n readOnly: PropTypes.bool,\n\n /**\n * Render the selected value.\n *\n * @param {any} value The `value` provided to the component.\n * @returns {ReactNode}\n */\n renderValue: PropTypes.func,\n\n /**\n * @ignore\n */\n required: PropTypes.bool,\n\n /**\n * Props applied to the clickable div element.\n */\n SelectDisplayProps: PropTypes.object,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * @ignore\n */\n type: PropTypes.any,\n\n /**\n * The input value.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default SelectInput;","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M7 10l5 5 5-5z\"\n}), 'ArrowDropDown');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport capitalize from '../utils/capitalize';\n/**\n * @ignore - internal component.\n */\n\nvar NativeSelectInput = React.forwardRef(function NativeSelectInput(props, ref) {\n var classes = props.classes,\n className = props.className,\n disabled = props.disabled,\n IconComponent = props.IconComponent,\n inputRef = props.inputRef,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"disabled\", \"IconComponent\", \"inputRef\", \"variant\"]);\n\n return React.createElement(React.Fragment, null, React.createElement(\"select\", _extends({\n className: clsx(classes.root, // TODO v5: merge root and select\n classes.select, classes[variant], className, disabled && classes.disabled),\n disabled: disabled,\n ref: inputRef || ref\n }, other)), props.multiple ? null : React.createElement(IconComponent, {\n className: clsx(classes.icon, classes[\"icon\".concat(capitalize(variant))])\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? NativeSelectInput.propTypes = {\n /**\n * The option elements to populate the select with.\n * Can be some `<option>` elements.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the select element.\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the select will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType.isRequired,\n\n /**\n * Use that prop to pass a ref to the native select element.\n * @deprecated\n */\n inputRef: refType,\n\n /**\n * @ignore\n */\n multiple: PropTypes.bool,\n\n /**\n * Name attribute of the `select` or hidden `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The input value.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default NativeSelectInput;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport NativeSelectInput from './NativeSelectInput';\nimport withStyles from '../styles/withStyles';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport ArrowDropDownIcon from '../internal/svg-icons/ArrowDropDown';\nimport Input from '../Input';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the select component `root` class. */\n root: {},\n\n /* Styles applied to the select component `select` class. */\n select: {\n '-moz-appearance': 'none',\n // Reset\n '-webkit-appearance': 'none',\n // Reset\n // When interacting quickly, the text can end up selected.\n // Native select can't be selected either.\n userSelect: 'none',\n borderRadius: 0,\n // Reset\n minWidth: 16,\n // So it doesn't collapse.\n cursor: 'pointer',\n '&:focus': {\n // Show that it's not an text input\n backgroundColor: theme.palette.type === 'light' ? 'rgba(0, 0, 0, 0.05)' : 'rgba(255, 255, 255, 0.05)',\n borderRadius: 0 // Reset Chrome style\n\n },\n // Remove IE 11 arrow\n '&::-ms-expand': {\n display: 'none'\n },\n '&$disabled': {\n cursor: 'default'\n },\n '&[multiple]': {\n height: 'auto'\n },\n '&:not([multiple]) option, &:not([multiple]) optgroup': {\n backgroundColor: theme.palette.background.paper\n },\n '&&': {\n paddingRight: 24\n }\n },\n\n /* Styles applied to the select component if `variant=\"filled\"`. */\n filled: {\n '&&': {\n paddingRight: 32\n }\n },\n\n /* Styles applied to the select component if `variant=\"outlined\"`. */\n outlined: {\n borderRadius: theme.shape.borderRadius,\n '&&': {\n paddingRight: 32\n }\n },\n\n /* Styles applied to the select component `selectMenu` class. */\n selectMenu: {\n height: 'auto',\n // Reset\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n overflow: 'hidden'\n },\n\n /* Pseudo-class applied to the select component `disabled` class. */\n disabled: {},\n\n /* Styles applied to the icon component. */\n icon: {\n // We use a position absolute over a flexbox in order to forward the pointer events\n // to the input and to support wrapping tags..\n position: 'absolute',\n right: 0,\n top: 'calc(50% - 12px)',\n // Center vertically\n color: theme.palette.action.active,\n pointerEvents: 'none' // Don't block pointer events on the select under the icon.\n\n },\n\n /* Styles applied to the icon component if the popup is open. */\n iconOpen: {\n transform: 'rotate(180deg)'\n },\n\n /* Styles applied to the icon component if `variant=\"filled\"`. */\n iconFilled: {\n right: 7\n },\n\n /* Styles applied to the icon component if `variant=\"outlined\"`. */\n iconOutlined: {\n right: 7\n }\n };\n};\nvar defaultInput = React.createElement(Input, null);\n/**\n * An alternative to `<Select native />` with a much smaller bundle size footprint.\n */\n\nvar NativeSelect = React.forwardRef(function NativeSelect(props, ref) {\n var children = props.children,\n classes = props.classes,\n _props$IconComponent = props.IconComponent,\n IconComponent = _props$IconComponent === void 0 ? ArrowDropDownIcon : _props$IconComponent,\n _props$input = props.input,\n input = _props$input === void 0 ? defaultInput : _props$input,\n inputProps = props.inputProps,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"IconComponent\", \"input\", \"inputProps\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['variant']\n });\n return React.cloneElement(input, _extends({\n // Most of the logic is implemented in `NativeSelectInput`.\n // The `Select` component is a simple API wrapper to expose something better to play with.\n inputComponent: NativeSelectInput,\n inputProps: _extends({\n children: children,\n classes: classes,\n IconComponent: IconComponent,\n variant: fcs.variant,\n type: undefined\n }, inputProps, {}, input ? input.props.inputProps : {}),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? NativeSelect.propTypes = {\n /**\n * The option elements to populate the select with.\n * Can be some `<option>` elements.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType,\n\n /**\n * An `Input` element; does not have to be a material-ui specific `Input`.\n */\n input: PropTypes.element,\n\n /**\n * Attributes applied to the `select` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The input value. The DOM API casts this to a string.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nNativeSelect.muiName = 'Select';\nexport default withStyles(styles, {\n name: 'MuiNativeSelect'\n})(NativeSelect);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { mergeClasses } from '@material-ui/styles';\nimport SelectInput from './SelectInput';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nimport ArrowDropDownIcon from '../internal/svg-icons/ArrowDropDown';\nimport Input from '../Input';\nimport { styles as nativeSelectStyles } from '../NativeSelect/NativeSelect';\nimport NativeSelectInput from '../NativeSelect/NativeSelectInput';\nimport FilledInput from '../FilledInput';\nimport OutlinedInput from '../OutlinedInput';\nexport var styles = nativeSelectStyles;\n\nvar _ref = React.createElement(Input, null);\n\nvar _ref2 = React.createElement(FilledInput, null);\n\nvar Select = React.forwardRef(function Select(props, ref) {\n var _props$autoWidth = props.autoWidth,\n autoWidth = _props$autoWidth === void 0 ? false : _props$autoWidth,\n children = props.children,\n classes = props.classes,\n _props$displayEmpty = props.displayEmpty,\n displayEmpty = _props$displayEmpty === void 0 ? false : _props$displayEmpty,\n _props$IconComponent = props.IconComponent,\n IconComponent = _props$IconComponent === void 0 ? ArrowDropDownIcon : _props$IconComponent,\n id = props.id,\n input = props.input,\n inputProps = props.inputProps,\n labelId = props.labelId,\n _props$labelWidth = props.labelWidth,\n labelWidth = _props$labelWidth === void 0 ? 0 : _props$labelWidth,\n MenuProps = props.MenuProps,\n _props$multiple = props.multiple,\n multiple = _props$multiple === void 0 ? false : _props$multiple,\n _props$native = props.native,\n native = _props$native === void 0 ? false : _props$native,\n onClose = props.onClose,\n onOpen = props.onOpen,\n open = props.open,\n renderValue = props.renderValue,\n SelectDisplayProps = props.SelectDisplayProps,\n _props$variant = props.variant,\n variantProps = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoWidth\", \"children\", \"classes\", \"displayEmpty\", \"IconComponent\", \"id\", \"input\", \"inputProps\", \"labelId\", \"labelWidth\", \"MenuProps\", \"multiple\", \"native\", \"onClose\", \"onOpen\", \"open\", \"renderValue\", \"SelectDisplayProps\", \"variant\"]);\n\n var inputComponent = native ? NativeSelectInput : SelectInput;\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['variant']\n });\n var variant = fcs.variant || variantProps;\n var InputComponent = input || {\n standard: _ref,\n outlined: React.createElement(OutlinedInput, {\n labelWidth: labelWidth\n }),\n filled: _ref2\n }[variant];\n return React.cloneElement(InputComponent, _extends({\n // Most of the logic is implemented in `SelectInput`.\n // The `Select` component is a simple API wrapper to expose something better to play with.\n inputComponent: inputComponent,\n inputProps: _extends({\n children: children,\n IconComponent: IconComponent,\n variant: variant,\n type: undefined,\n // We render a select. We can ignore the type provided by the `Input`.\n multiple: multiple\n }, native ? {\n id: id\n } : {\n autoWidth: autoWidth,\n displayEmpty: displayEmpty,\n labelId: labelId,\n MenuProps: MenuProps,\n onClose: onClose,\n onOpen: onOpen,\n open: open,\n renderValue: renderValue,\n SelectDisplayProps: _extends({\n id: id\n }, SelectDisplayProps)\n }, {}, inputProps, {\n classes: inputProps ? mergeClasses({\n baseClasses: classes,\n newClasses: inputProps.classes,\n Component: Select\n }) : classes\n }, input ? input.props.inputProps : {}),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Select.propTypes = {\n /**\n * If `true`, the width of the popover will automatically be set according to the items inside the\n * menu, otherwise it will be at least the width of the select input.\n */\n autoWidth: PropTypes.bool,\n\n /**\n * The option elements to populate the select with.\n * Can be some `MenuItem` when `native` is false and `option` when `native` is true.\n *\n * âš ï¸The `MenuItem` elements **must** be direct descendants when `native` is false.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The default element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, a value is displayed even if no items are selected.\n *\n * In order to display a meaningful value, a function should be passed to the `renderValue` prop which returns the value to be displayed when no items are selected.\n * You can only use it when the `native` prop is `false` (default).\n */\n displayEmpty: PropTypes.bool,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType,\n\n /**\n * @ignore\n */\n id: PropTypes.string,\n\n /**\n * An `Input` element; does not have to be a material-ui specific `Input`.\n */\n input: PropTypes.element,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n * When `native` is `true`, the attributes are applied on the `select` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * The idea of an element that acts as an additional label. The Select will\n * be labelled by the additional label and the selected value.\n */\n labelId: PropTypes.string,\n\n /**\n * The label width to be used on OutlinedInput.\n * This prop is required when the `variant` prop is `outlined`.\n */\n labelWidth: PropTypes.number,\n\n /**\n * Props applied to the [`Menu`](/api/menu/) element.\n */\n MenuProps: PropTypes.object,\n\n /**\n * If `true`, `value` must be an array and the menu will support multiple selections.\n */\n multiple: PropTypes.bool,\n\n /**\n * If `true`, the component will be using a native `select` element.\n */\n native: PropTypes.bool,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (any).\n * @param {object} [child] The react element that was selected when `native` is `false` (default).\n */\n onChange: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be closed.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be opened.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onOpen: PropTypes.func,\n\n /**\n * Control `select` open state.\n * You can only use it when the `native` prop is `false` (default).\n */\n open: PropTypes.bool,\n\n /**\n * Render the selected value.\n * You can only use it when the `native` prop is `false` (default).\n *\n * @param {any} value The `value` provided to the component.\n * @returns {ReactNode}\n */\n renderValue: PropTypes.func,\n\n /**\n * Props applied to the clickable div element.\n */\n SelectDisplayProps: PropTypes.object,\n\n /**\n * The input value. Providing an empty string will select no options.\n * This prop is required when the `native` prop is `false` (default).\n * Set to an empty string `''` if you don't want any of the available options to be selected.\n *\n * If the value is an object it must have reference equality with the option in order to be selected.\n * If the value is not an object, the string representation must match with the string representation of the option in order to be selected.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nSelect.muiName = 'Select';\nexport default withStyles(styles, {\n name: 'MuiSelect'\n})(Select);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport capitalize from '../utils/capitalize';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({\n color: theme.palette.text.secondary\n }, theme.typography.body1, {\n lineHeight: 1,\n padding: 0,\n '&$focused': {\n color: theme.palette.primary.main\n },\n '&$disabled': {\n color: theme.palette.text.disabled\n },\n '&$error': {\n color: theme.palette.error.main\n }\n }),\n\n /* Styles applied to the root element if the color is secondary. */\n colorSecondary: {\n '&$focused': {\n color: theme.palette.secondary.main\n }\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `filled={true}`. */\n filled: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {},\n\n /* Styles applied to the asterisk element. */\n asterisk: {\n '&$error': {\n color: theme.palette.error.main\n }\n }\n };\n};\nvar FormLabel = React.forwardRef(function FormLabel(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n color = props.color,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'label' : _props$component,\n disabled = props.disabled,\n error = props.error,\n filled = props.filled,\n focused = props.focused,\n required = props.required,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"disabled\", \"error\", \"filled\", \"focused\", \"required\"]);\n\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['color', 'required', 'focused', 'disabled', 'error', 'filled']\n });\n return React.createElement(Component, _extends({\n className: clsx(classes.root, classes[\"color\".concat(capitalize(fcs.color || 'primary'))], className, fcs.disabled && classes.disabled, fcs.error && classes.error, fcs.filled && classes.filled, fcs.focused && classes.focused, fcs.required && classes.required),\n ref: ref\n }, other), children, fcs.required && React.createElement(\"span\", {\n className: clsx(classes.asterisk, fcs.error && classes.error)\n }, \"\\u2009\", '*'));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormLabel.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the label should be displayed in a disabled state.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label should be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the label should use filled classes key.\n */\n filled: PropTypes.bool,\n\n /**\n * If `true`, the input of this label is focused (used by `FormGroup` components).\n */\n focused: PropTypes.bool,\n\n /**\n * If `true`, the label will indicate that the input is required.\n */\n required: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormLabel'\n})(FormLabel);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nimport FormLabel from '../FormLabel';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'block',\n transformOrigin: 'top left'\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {},\n\n /* Pseudo-class applied to the asterisk element. */\n asterisk: {},\n\n /* Styles applied to the root element if the component is a descendant of `FormControl`. */\n formControl: {\n position: 'absolute',\n left: 0,\n top: 0,\n // slight alteration to spec spacing to match visual spec result\n transform: 'translate(0, 24px) scale(1)'\n },\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n // Compensation for the `Input.inputDense` style.\n transform: 'translate(0, 21px) scale(1)'\n },\n\n /* Styles applied to the `input` element if `shrink={true}`. */\n shrink: {\n transform: 'translate(0, 1.5px) scale(0.75)',\n transformOrigin: 'top left'\n },\n\n /* Styles applied to the `input` element if `disableAnimation={false}`. */\n animated: {\n transition: theme.transitions.create(['color', 'transform'], {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n })\n },\n\n /* Styles applied to the root element if `variant=\"filled\"`. */\n filled: {\n // Chrome's autofill feature gives the input field a yellow background.\n // Since the input field is behind the label in the HTML tree,\n // the input field is drawn last and hides the label with an opaque background color.\n // zIndex: 1 will raise the label above opaque background-colors of input.\n zIndex: 1,\n pointerEvents: 'none',\n transform: 'translate(12px, 20px) scale(1)',\n '&$marginDense': {\n transform: 'translate(12px, 17px) scale(1)'\n },\n '&$shrink': {\n transform: 'translate(12px, 10px) scale(0.75)',\n '&$marginDense': {\n transform: 'translate(12px, 7px) scale(0.75)'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"`. */\n outlined: {\n // see comment above on filled.zIndex\n zIndex: 1,\n pointerEvents: 'none',\n transform: 'translate(14px, 20px) scale(1)',\n '&$marginDense': {\n transform: 'translate(14px, 12px) scale(1)'\n },\n '&$shrink': {\n transform: 'translate(14px, -6px) scale(0.75)'\n }\n }\n };\n};\nvar InputLabel = React.forwardRef(function InputLabel(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$disableAnimati = props.disableAnimation,\n disableAnimation = _props$disableAnimati === void 0 ? false : _props$disableAnimati,\n margin = props.margin,\n shrinkProp = props.shrink,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"disableAnimation\", \"margin\", \"shrink\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var shrink = shrinkProp;\n\n if (typeof shrink === 'undefined' && muiFormControl) {\n shrink = muiFormControl.filled || muiFormControl.focused || muiFormControl.adornedStart;\n }\n\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['margin', 'variant']\n });\n return React.createElement(FormLabel, _extends({\n \"data-shrink\": shrink,\n className: clsx(classes.root, className, muiFormControl && classes.formControl, !disableAnimation && classes.animated, shrink && classes.shrink, {\n dense: classes.marginDense\n }[fcs.margin], {\n filled: classes.filled,\n outlined: classes.outlined\n }[fcs.variant]),\n classes: {\n focused: classes.focused,\n disabled: classes.disabled,\n error: classes.error,\n required: classes.required,\n asterisk: classes.asterisk\n },\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? InputLabel.propTypes = {\n /**\n * The contents of the `InputLabel`.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * If `true`, the transition animation is disabled.\n */\n disableAnimation: PropTypes.bool,\n\n /**\n * If `true`, apply disabled class.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label will be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input of this label is focused.\n */\n focused: PropTypes.bool,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense']),\n\n /**\n * if `true`, the label will indicate that the input is required.\n */\n required: PropTypes.bool,\n\n /**\n * If `true`, the label is shrunk.\n */\n shrink: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiInputLabel'\n})(InputLabel);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { isFilled, isAdornedStart } from '../InputBase/utils';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport isMuiElement from '../utils/isMuiElement';\nimport FormControlContext from './FormControlContext';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n flexDirection: 'column',\n position: 'relative',\n // Reset fieldset default style.\n minWidth: 0,\n padding: 0,\n margin: 0,\n border: 0,\n verticalAlign: 'top' // Fix alignment issue on Safari.\n\n },\n\n /* Styles applied to the root element if `margin=\"normal\"`. */\n marginNormal: {\n marginTop: 16,\n marginBottom: 8\n },\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n marginTop: 8,\n marginBottom: 4\n },\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {\n width: '100%'\n }\n};\n/**\n * Provides context such as filled/focused/error/required for form inputs.\n * Relying on the context provides high flexibility and ensures that the state always stays\n * consistent across the children of the `FormControl`.\n * This context is used by the following components:\n *\n * - FormLabel\n * - FormHelperText\n * - Input\n * - InputLabel\n *\n * You can find one composition example below and more going to [the demos](/components/text-fields/#components).\n *\n * ```jsx\n * <FormControl>\n * <InputLabel htmlFor=\"my-input\">Email address</InputLabel>\n * <Input id=\"my-input\" aria-describedby=\"my-helper-text\" />\n * <FormHelperText id=\"my-helper-text\">We'll never share your email.</FormHelperText>\n * </FormControl>\n * ```\n *\n * âš ï¸Only one input can be used within a FormControl.\n */\n\nvar FormControl = React.forwardRef(function FormControl(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'primary' : _props$color,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$error = props.error,\n error = _props$error === void 0 ? false : _props$error,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$hiddenLabel = props.hiddenLabel,\n hiddenLabel = _props$hiddenLabel === void 0 ? false : _props$hiddenLabel,\n _props$margin = props.margin,\n margin = _props$margin === void 0 ? 'none' : _props$margin,\n _props$required = props.required,\n required = _props$required === void 0 ? false : _props$required,\n size = props.size,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"disabled\", \"error\", \"fullWidth\", \"hiddenLabel\", \"margin\", \"required\", \"size\", \"variant\"]);\n\n var _React$useState = React.useState(function () {\n // We need to iterate through the children and find the Input in order\n // to fully support server-side rendering.\n var initialAdornedStart = false;\n\n if (children) {\n React.Children.forEach(children, function (child) {\n if (!isMuiElement(child, ['Input', 'Select'])) {\n return;\n }\n\n var input = isMuiElement(child, ['Select']) ? child.props.input : child;\n\n if (input && isAdornedStart(input.props)) {\n initialAdornedStart = true;\n }\n });\n }\n\n return initialAdornedStart;\n }),\n adornedStart = _React$useState[0],\n setAdornedStart = _React$useState[1];\n\n var _React$useState2 = React.useState(function () {\n // We need to iterate through the children and find the Input in order\n // to fully support server-side rendering.\n var initialFilled = false;\n\n if (children) {\n React.Children.forEach(children, function (child) {\n if (!isMuiElement(child, ['Input', 'Select'])) {\n return;\n }\n\n if (isFilled(child.props, true)) {\n initialFilled = true;\n }\n });\n }\n\n return initialFilled;\n }),\n filled = _React$useState2[0],\n setFilled = _React$useState2[1];\n\n var _React$useState3 = React.useState(false),\n focused = _React$useState3[0],\n setFocused = _React$useState3[1];\n\n if (disabled && focused) {\n setFocused(false);\n }\n\n var registerEffect;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n var registeredInput = React.useRef(false);\n\n registerEffect = function registerEffect() {\n if (registeredInput.current) {\n console.error(['Material-UI: there are multiple InputBase components inside a FormControl.', 'This is not supported. It might cause infinite rendering loops.', 'Only use one InputBase.'].join('\\n'));\n }\n\n registeredInput.current = true;\n return function () {\n registeredInput.current = false;\n };\n };\n }\n\n var onFilled = React.useCallback(function () {\n setFilled(true);\n }, []);\n var onEmpty = React.useCallback(function () {\n setFilled(false);\n }, []);\n var childContext = {\n adornedStart: adornedStart,\n setAdornedStart: setAdornedStart,\n color: color,\n disabled: disabled,\n error: error,\n filled: filled,\n focused: focused,\n hiddenLabel: hiddenLabel,\n margin: (size === 'small' ? 'dense' : undefined) || margin,\n onBlur: function onBlur() {\n setFocused(false);\n },\n onEmpty: onEmpty,\n onFilled: onFilled,\n onFocus: function onFocus() {\n setFocused(true);\n },\n registerEffect: registerEffect,\n required: required,\n variant: variant\n };\n return React.createElement(FormControlContext.Provider, {\n value: childContext\n }, React.createElement(Component, _extends({\n className: clsx(classes.root, className, margin !== 'none' && classes[\"margin\".concat(capitalize(margin))], fullWidth && classes.fullWidth),\n ref: ref\n }, other), children));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormControl.propTypes = {\n /**\n * The contents of the form control.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the label, input and helper text should be displayed in a disabled state.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label should be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the component will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * If `true`, the label will be hidden.\n * This is used to increase density for a `FilledInput`.\n * Be sure to add `aria-label` to the `input` element.\n */\n hiddenLabel: PropTypes.bool,\n\n /**\n * If `dense` or `normal`, will adjust vertical spacing of this and contained components.\n */\n margin: PropTypes.oneOf(['none', 'dense', 'normal']),\n\n /**\n * If `true`, the label will indicate that the input is required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the text field.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormControl'\n})(FormControl);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({\n color: theme.palette.text.secondary\n }, theme.typography.caption, {\n textAlign: 'left',\n marginTop: 8,\n lineHeight: '1em',\n minHeight: '1em',\n margin: 0,\n '&$disabled': {\n color: theme.palette.text.disabled\n },\n '&$error': {\n color: theme.palette.error.main\n }\n }),\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n marginTop: 4\n },\n\n /* Styles applied to the root element if `variant=\"filled\"` or `variant=\"outlined\"`. */\n contained: {\n margin: '8px 14px 0'\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `filled={true}`. */\n filled: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {}\n };\n};\nvar FormHelperText = React.forwardRef(function FormHelperText(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'p' : _props$component,\n disabled = props.disabled,\n error = props.error,\n filled = props.filled,\n focused = props.focused,\n margin = props.margin,\n required = props.required,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"disabled\", \"error\", \"filled\", \"focused\", \"margin\", \"required\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['variant', 'margin', 'disabled', 'error', 'filled', 'focused', 'required']\n });\n return React.createElement(Component, _extends({\n className: clsx(classes.root, (fcs.variant === 'filled' || fcs.variant === 'outlined') && classes.contained, className, fcs.disabled && classes.disabled, fcs.error && classes.error, fcs.filled && classes.filled, fcs.focused && classes.focused, fcs.required && classes.required, {\n dense: classes.marginDense\n }[fcs.margin]),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormHelperText.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the helper text should be displayed in a disabled state.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, helper text should be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the helper text should use filled classes key.\n */\n filled: PropTypes.bool,\n\n /**\n * If `true`, the helper text should use focused classes key.\n */\n focused: PropTypes.bool,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense']),\n\n /**\n * If `true`, the helper text should use required classes key.\n */\n required: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormHelperText'\n})(FormHelperText);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport Input from '../Input';\nimport FilledInput from '../FilledInput';\nimport OutlinedInput from '../OutlinedInput';\nimport InputLabel from '../InputLabel';\nimport FormControl from '../FormControl';\nimport FormHelperText from '../FormHelperText';\nimport Select from '../Select';\nimport withStyles from '../styles/withStyles';\nvar variantComponent = {\n standard: Input,\n filled: FilledInput,\n outlined: OutlinedInput\n};\nexport var styles = {\n /* Styles applied to the root element. */\n root: {}\n};\n/**\n * The `TextField` is a convenience wrapper for the most common cases (80%).\n * It cannot be all things to all people, otherwise the API would grow out of control.\n *\n * ## Advanced Configuration\n *\n * It's important to understand that the text field is a simple abstraction\n * on top of the following components:\n *\n * - [FormControl](/api/form-control/)\n * - [InputLabel](/api/input-label/)\n * - [FilledInput](/api/filled-input/)\n * - [OutlinedInput](/api/outlined-input/)\n * - [Input](/api/input/)\n * - [FormHelperText](/api/form-helper-text/)\n *\n * If you wish to alter the props applied to the `input` element, you can do so as follows:\n *\n * ```jsx\n * const inputProps = {\n * step: 300,\n * };\n *\n * return <TextField id=\"time\" type=\"time\" inputProps={inputProps} />;\n * ```\n *\n * For advanced cases, please look at the source of TextField by clicking on the\n * \"Edit this page\" button above. Consider either:\n *\n * - using the upper case props for passing values directly to the components\n * - using the underlying components directly as shown in the demos\n */\n\nvar TextField = React.forwardRef(function TextField(props, ref) {\n var autoComplete = props.autoComplete,\n _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'primary' : _props$color,\n defaultValue = props.defaultValue,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$error = props.error,\n error = _props$error === void 0 ? false : _props$error,\n FormHelperTextProps = props.FormHelperTextProps,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n helperText = props.helperText,\n hiddenLabel = props.hiddenLabel,\n id = props.id,\n InputLabelProps = props.InputLabelProps,\n inputProps = props.inputProps,\n InputProps = props.InputProps,\n inputRef = props.inputRef,\n label = props.label,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onFocus = props.onFocus,\n placeholder = props.placeholder,\n _props$required = props.required,\n required = _props$required === void 0 ? false : _props$required,\n rows = props.rows,\n rowsMax = props.rowsMax,\n _props$select = props.select,\n select = _props$select === void 0 ? false : _props$select,\n SelectProps = props.SelectProps,\n type = props.type,\n value = props.value,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoComplete\", \"autoFocus\", \"children\", \"classes\", \"className\", \"color\", \"defaultValue\", \"disabled\", \"error\", \"FormHelperTextProps\", \"fullWidth\", \"helperText\", \"hiddenLabel\", \"id\", \"InputLabelProps\", \"inputProps\", \"InputProps\", \"inputRef\", \"label\", \"multiline\", \"name\", \"onBlur\", \"onChange\", \"onFocus\", \"placeholder\", \"required\", \"rows\", \"rowsMax\", \"select\", \"SelectProps\", \"type\", \"value\", \"variant\"]);\n\n var _React$useState = React.useState(0),\n labelWidth = _React$useState[0],\n setLabelWidth = _React$useState[1];\n\n var labelRef = React.useRef(null);\n React.useEffect(function () {\n if (variant === 'outlined') {\n // #StrictMode ready\n var labelNode = ReactDOM.findDOMNode(labelRef.current);\n setLabelWidth(labelNode != null ? labelNode.offsetWidth : 0);\n }\n }, [variant, required, label]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (select && !children) {\n console.error('Material-UI: `children` must be passed when using the `TextField` component with `select`.');\n }\n }\n\n var InputMore = {};\n\n if (variant === 'outlined') {\n if (InputLabelProps && typeof InputLabelProps.shrink !== 'undefined') {\n InputMore.notched = InputLabelProps.shrink;\n }\n\n InputMore.labelWidth = labelWidth;\n }\n\n if (select) {\n // unset defaults from textbox inputs\n if (!SelectProps || !SelectProps.native) {\n InputMore.id = undefined;\n }\n\n InputMore['aria-describedby'] = undefined;\n }\n\n var helperTextId = helperText && id ? \"\".concat(id, \"-helper-text\") : undefined;\n var inputLabelId = label && id ? \"\".concat(id, \"-label\") : undefined;\n var InputComponent = variantComponent[variant];\n var InputElement = React.createElement(InputComponent, _extends({\n \"aria-describedby\": helperTextId,\n autoComplete: autoComplete,\n autoFocus: autoFocus,\n defaultValue: defaultValue,\n fullWidth: fullWidth,\n multiline: multiline,\n name: name,\n rows: rows,\n rowsMax: rowsMax,\n type: type,\n value: value,\n id: id,\n inputRef: inputRef,\n onBlur: onBlur,\n onChange: onChange,\n onFocus: onFocus,\n placeholder: placeholder,\n inputProps: inputProps\n }, InputMore, InputProps));\n return React.createElement(FormControl, _extends({\n className: clsx(classes.root, className),\n disabled: disabled,\n error: error,\n fullWidth: fullWidth,\n hiddenLabel: hiddenLabel,\n ref: ref,\n required: required,\n color: color,\n variant: variant\n }, other), label && React.createElement(InputLabel, _extends({\n htmlFor: id,\n ref: labelRef,\n id: inputLabelId\n }, InputLabelProps), label), select ? React.createElement(Select, _extends({\n \"aria-describedby\": helperTextId,\n id: id,\n labelId: inputLabelId,\n value: value,\n input: InputElement\n }, SelectProps), children) : InputElement, helperText && React.createElement(FormHelperText, _extends({\n id: helperTextId\n }, FormHelperTextProps), helperText));\n});\nprocess.env.NODE_ENV !== \"production\" ? TextField.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * @ignore\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default value of the `input` element.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label will be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * Props applied to the [`FormHelperText`](/api/form-helper-text/) element.\n */\n FormHelperTextProps: PropTypes.object,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The helper text content.\n */\n helperText: PropTypes.node,\n\n /**\n * @ignore\n */\n hiddenLabel: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n * Use this prop to make `label` and `helperText` accessible for screen readers.\n */\n id: PropTypes.string,\n\n /**\n * Props applied to the [`InputLabel`](/api/input-label/) element.\n */\n InputLabelProps: PropTypes.object,\n\n /**\n * Props applied to the Input element.\n * It will be a [`FilledInput`](/api/filled-input/),\n * [`OutlinedInput`](/api/outlined-input/) or [`Input`](/api/input/)\n * component depending on the `variant` prop value.\n */\n InputProps: PropTypes.object,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * The label content.\n */\n label: PropTypes.node,\n\n /**\n * If `dense` or `normal`, will adjust vertical spacing of this and contained components.\n */\n margin: PropTypes.oneOf(['none', 'dense', 'normal']),\n\n /**\n * If `true`, a textarea element will be rendered instead of an input.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * If `true`, the label is displayed as required and the `input` element` will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Render a [`Select`](/api/select/) element while passing the Input element to `Select` as `input` parameter.\n * If this option is set you must pass the options of the select as children.\n */\n select: PropTypes.bool,\n\n /**\n * Props applied to the [`Select`](/api/select/) element.\n */\n SelectProps: PropTypes.object,\n\n /**\n * The size of the text field.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTextField'\n})(TextField);","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"\n}), 'RadioButtonUnchecked');","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M8.465 8.465C9.37 7.56 10.62 7 12 7C14.76 7 17 9.24 17 12C17 13.38 16.44 14.63 15.535 15.535C14.63 16.44 13.38 17 12 17C9.24 17 7 14.76 7 12C7 10.62 7.56 9.37 8.465 8.465Z\"\n}), 'RadioButtonChecked');","import React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport RadioButtonUncheckedIcon from '../internal/svg-icons/RadioButtonUnchecked';\nimport RadioButtonCheckedIcon from '../internal/svg-icons/RadioButtonChecked';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n root: {\n position: 'relative',\n display: 'flex',\n '&$checked $layer': {\n transform: 'scale(1)',\n transition: theme.transitions.create('transform', {\n easing: theme.transitions.easing.easeOut,\n duration: theme.transitions.duration.shortest\n })\n }\n },\n layer: {\n left: 0,\n position: 'absolute',\n transform: 'scale(0)',\n transition: theme.transitions.create('transform', {\n easing: theme.transitions.easing.easeIn,\n duration: theme.transitions.duration.shortest\n })\n },\n checked: {}\n };\n};\n/**\n * @ignore - internal component.\n */\n\nfunction RadioButtonIcon(props) {\n var checked = props.checked,\n classes = props.classes,\n fontSize = props.fontSize;\n return React.createElement(\"div\", {\n className: clsx(classes.root, checked && classes.checked)\n }, React.createElement(RadioButtonUncheckedIcon, {\n fontSize: fontSize\n }), React.createElement(RadioButtonCheckedIcon, {\n fontSize: fontSize,\n className: classes.layer\n }));\n}\n\nprocess.env.NODE_ENV !== \"production\" ? RadioButtonIcon.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The size of the radio.\n * `small` is equivalent to the dense radio styling.\n */\n fontSize: PropTypes.oneOf(['small', 'default'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateRadioButtonIcon'\n})(RadioButtonIcon);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport SwitchBase from '../internal/SwitchBase';\nimport RadioButtonIcon from './RadioButtonIcon';\nimport { fade } from '../styles/colorManipulator';\nimport capitalize from '../utils/capitalize';\nimport createChainedFunction from '../utils/createChainedFunction';\nimport withStyles from '../styles/withStyles';\nimport useRadioGroup from '../RadioGroup/useRadioGroup';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n color: theme.palette.text.secondary\n },\n\n /* Pseudo-class applied to the root element if `checked={true}`. */\n checked: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n '&$checked': {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n '&$checked': {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n }\n };\n};\nvar defaultCheckedIcon = React.createElement(RadioButtonIcon, {\n checked: true\n});\nvar defaultIcon = React.createElement(RadioButtonIcon, null);\nvar Radio = React.forwardRef(function Radio(props, ref) {\n var checkedProp = props.checked,\n classes = props.classes,\n _props$color = props.color,\n color = _props$color === void 0 ? 'secondary' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n nameProp = props.name,\n onChangeProp = props.onChange,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"checked\", \"classes\", \"color\", \"disabled\", \"name\", \"onChange\", \"size\"]);\n\n var radioGroup = useRadioGroup();\n var checked = checkedProp;\n var onChange = createChainedFunction(onChangeProp, radioGroup && radioGroup.onChange);\n var name = nameProp;\n\n if (radioGroup) {\n if (typeof checked === 'undefined') {\n checked = radioGroup.value === props.value;\n }\n\n if (typeof name === 'undefined') {\n name = radioGroup.name;\n }\n }\n\n return React.createElement(SwitchBase, _extends({\n color: color,\n type: \"radio\",\n icon: React.cloneElement(defaultIcon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n checkedIcon: React.cloneElement(defaultCheckedIcon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n classes: {\n root: clsx(classes.root, classes[\"color\".concat(capitalize(color))]),\n checked: classes.checked,\n disabled: classes.disabled\n },\n name: name,\n checked: checked,\n onChange: onChange,\n ref: ref,\n disabled: disabled\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Radio.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary', 'default']),\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the radio.\n * `small` is equivalent to the dense radio styling.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string,\n\n /**\n * The value of the component. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiRadio'\n})(Radio);","import React from 'react';\nimport RadioGroupContext from './RadioGroupContext';\nexport default function useRadioGroup() {\n return React.useContext(RadioGroupContext);\n}","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z\"\n}), 'CheckBoxOutlineBlank');","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z\"\n}), 'CheckBox');","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z\"\n}), 'IndeterminateCheckBox');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport SwitchBase from '../internal/SwitchBase';\nimport CheckBoxOutlineBlankIcon from '../internal/svg-icons/CheckBoxOutlineBlank';\nimport CheckBoxIcon from '../internal/svg-icons/CheckBox';\nimport { fade } from '../styles/colorManipulator';\nimport IndeterminateCheckBoxIcon from '../internal/svg-icons/IndeterminateCheckBox';\nimport capitalize from '../utils/capitalize';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n color: theme.palette.text.secondary\n },\n\n /* Pseudo-class applied to the root element if `checked={true}`. */\n checked: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if `indeterminate={true}`. */\n indeterminate: {},\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n '&$checked': {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n '&$checked': {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n }\n };\n};\nvar defaultCheckedIcon = React.createElement(CheckBoxIcon, null);\nvar defaultIcon = React.createElement(CheckBoxOutlineBlankIcon, null);\nvar defaultIndeterminateIcon = React.createElement(IndeterminateCheckBoxIcon, null);\nvar Checkbox = React.forwardRef(function Checkbox(props, ref) {\n var _props$checkedIcon = props.checkedIcon,\n checkedIcon = _props$checkedIcon === void 0 ? defaultCheckedIcon : _props$checkedIcon,\n classes = props.classes,\n _props$color = props.color,\n color = _props$color === void 0 ? 'secondary' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$icon = props.icon,\n icon = _props$icon === void 0 ? defaultIcon : _props$icon,\n _props$indeterminate = props.indeterminate,\n indeterminate = _props$indeterminate === void 0 ? false : _props$indeterminate,\n _props$indeterminateI = props.indeterminateIcon,\n indeterminateIcon = _props$indeterminateI === void 0 ? defaultIndeterminateIcon : _props$indeterminateI,\n inputProps = props.inputProps,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"checkedIcon\", \"classes\", \"color\", \"disabled\", \"icon\", \"indeterminate\", \"indeterminateIcon\", \"inputProps\", \"size\"]);\n\n return React.createElement(SwitchBase, _extends({\n type: \"checkbox\",\n classes: {\n root: clsx(classes.root, classes[\"color\".concat(capitalize(color))], indeterminate && classes.indeterminate),\n checked: classes.checked,\n disabled: classes.disabled\n },\n color: color,\n inputProps: _extends({\n 'data-indeterminate': indeterminate\n }, inputProps),\n icon: React.cloneElement(indeterminate ? indeterminateIcon : icon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n checkedIcon: React.cloneElement(indeterminate ? indeterminateIcon : checkedIcon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n ref: ref,\n disabled: disabled\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Checkbox.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary', 'default']),\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * If `true`, the component appears indeterminate.\n * This does not set the native input element to indeterminate due\n * to inconsistent behavior across browsers.\n * However, we set a `data-indeterminate` attribute on the input.\n */\n indeterminate: PropTypes.bool,\n\n /**\n * The icon to display when the component is indeterminate.\n */\n indeterminateIcon: PropTypes.node,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the checkbox.\n * `small` is equivalent to the dense checkbox styling.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string,\n\n /**\n * The value of the component. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiCheckbox'\n})(Checkbox);","import _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport useTheme from '../styles/useTheme';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n var align = theme.direction === 'rtl' ? 'right' : 'left';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'absolute',\n bottom: 0,\n right: 0,\n top: -5,\n left: 0,\n margin: 0,\n padding: 0,\n pointerEvents: 'none',\n borderRadius: 'inherit',\n borderStyle: 'solid',\n borderWidth: 1,\n // Match the Input Label\n transition: theme.transitions.create([\"padding-\".concat(align), 'border-color', 'border-width'], {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n })\n },\n\n /* Styles applied to the legend element. */\n legend: {\n textAlign: 'left',\n padding: 0,\n lineHeight: '11px',\n transition: theme.transitions.create('width', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n })\n }\n };\n};\n/**\n * @ignore - internal component.\n */\n\nvar NotchedOutline = React.forwardRef(function NotchedOutline(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n labelWidthProp = props.labelWidth,\n notched = props.notched,\n style = props.style,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"labelWidth\", \"notched\", \"style\"]);\n\n var theme = useTheme();\n var align = theme.direction === 'rtl' ? 'right' : 'left';\n var labelWidth = labelWidthProp > 0 ? labelWidthProp * 0.75 + 8 : 0;\n return React.createElement(\"fieldset\", _extends({\n \"aria-hidden\": true,\n style: _extends(_defineProperty({}, \"padding\".concat(capitalize(align)), 8 + (notched ? 0 : labelWidth / 2)), style),\n className: clsx(classes.root, className),\n ref: ref\n }, other), React.createElement(\"legend\", {\n className: classes.legend,\n style: {\n // IE 11: fieldset with legend does not render\n // a border radius. This maintains consistency\n // by always having a legend rendered\n width: notched ? labelWidth : 0.01\n }\n }, React.createElement(\"span\", {\n dangerouslySetInnerHTML: {\n __html: '​'\n }\n })));\n});\nprocess.env.NODE_ENV !== \"production\" ? NotchedOutline.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The width of the label.\n */\n labelWidth: PropTypes.number.isRequired,\n\n /**\n * If `true`, the outline is notched to accommodate the label.\n */\n notched: PropTypes.bool.isRequired,\n\n /**\n * @ignore\n */\n style: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateNotchedOutline'\n})(NotchedOutline);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport InputBase from '../InputBase';\nimport NotchedOutline from './NotchedOutline';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var borderColor = theme.palette.type === 'light' ? 'rgba(0, 0, 0, 0.23)' : 'rgba(255, 255, 255, 0.23)';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'relative',\n borderRadius: theme.shape.borderRadius,\n '&:hover $notchedOutline': {\n borderColor: theme.palette.text.primary\n },\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n '&:hover $notchedOutline': {\n borderColor: borderColor\n }\n },\n '&$focused $notchedOutline': {\n borderColor: theme.palette.primary.main,\n borderWidth: 2\n },\n '&$error $notchedOutline': {\n borderColor: theme.palette.error.main\n },\n '&$disabled $notchedOutline': {\n borderColor: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if the color is secondary. */\n colorSecondary: {\n '&$focused $notchedOutline': {\n borderColor: theme.palette.secondary.main\n }\n },\n\n /* Styles applied to the root element if the component is focused. */\n focused: {},\n\n /* Styles applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `startAdornment` is provided. */\n adornedStart: {\n paddingLeft: 14\n },\n\n /* Styles applied to the root element if `endAdornment` is provided. */\n adornedEnd: {\n paddingRight: 14\n },\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {\n padding: '18.5px 14px',\n '&$marginDense': {\n paddingTop: 10.5,\n paddingBottom: 10.5\n }\n },\n\n /* Styles applied to the `NotchedOutline` element. */\n notchedOutline: {\n borderColor: borderColor\n },\n\n /* Styles applied to the `input` element. */\n input: {\n padding: '18.5px 14px',\n '&:-webkit-autofill': {\n WebkitBoxShadow: theme.palette.type === 'dark' ? '0 0 0 100px #266798 inset' : null,\n WebkitTextFillColor: theme.palette.type === 'dark' ? '#fff' : null,\n borderRadius: 'inherit'\n }\n },\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {\n paddingTop: 10.5,\n paddingBottom: 10.5\n },\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {\n padding: 0\n },\n\n /* Styles applied to the `input` element if `startAdornment` is provided. */\n inputAdornedStart: {\n paddingLeft: 0\n },\n\n /* Styles applied to the `input` element if `endAdornment` is provided. */\n inputAdornedEnd: {\n paddingRight: 0\n }\n };\n};\nvar OutlinedInput = React.forwardRef(function OutlinedInput(props, ref) {\n var classes = props.classes,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$labelWidth = props.labelWidth,\n labelWidth = _props$labelWidth === void 0 ? 0 : _props$labelWidth,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n notched = props.notched,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n other = _objectWithoutProperties(props, [\"classes\", \"fullWidth\", \"inputComponent\", \"labelWidth\", \"multiline\", \"notched\", \"type\"]);\n\n return React.createElement(InputBase, _extends({\n renderSuffix: function renderSuffix(state) {\n return React.createElement(NotchedOutline, {\n className: classes.notchedOutline,\n labelWidth: labelWidth,\n notched: typeof notched !== 'undefined' ? notched : Boolean(state.startAdornment || state.filled || state.focused)\n });\n },\n classes: _extends({}, classes, {\n root: clsx(classes.root, classes.underline),\n notchedOutline: null\n }),\n fullWidth: fullWidth,\n inputComponent: inputComponent,\n multiline: multiline,\n ref: ref,\n type: type\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? OutlinedInput.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the native input.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * The width of the label.\n */\n labelWidth: PropTypes.number,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * If `true`, the outline is notched to accommodate the label.\n */\n notched: PropTypes.bool,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nOutlinedInput.muiName = 'Input';\nexport default withStyles(styles, {\n name: 'MuiOutlinedInput'\n})(OutlinedInput);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { chainPropTypes } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport ButtonBase from '../ButtonBase';\nimport isMuiElement from '../utils/isMuiElement';\nimport useForkRef from '../utils/useForkRef';\nimport ListContext from '../List/ListContext';\nimport ReactDOM from 'react-dom';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the (normally root) `component` element. May be wrapped by a `container`. */\n root: {\n display: 'flex',\n justifyContent: 'flex-start',\n alignItems: 'center',\n position: 'relative',\n textDecoration: 'none',\n width: '100%',\n boxSizing: 'border-box',\n textAlign: 'left',\n paddingTop: 8,\n paddingBottom: 8,\n '&$focusVisible': {\n backgroundColor: theme.palette.action.selected\n },\n '&$selected, &$selected:hover': {\n backgroundColor: theme.palette.action.selected\n },\n '&$disabled': {\n opacity: 0.5\n }\n },\n\n /* Styles applied to the `container` element if `children` includes `ListItemSecondaryAction`. */\n container: {\n position: 'relative'\n },\n\n /* Pseudo-class applied to the `component`'s `focusVisibleClassName` prop if `button={true}`. */\n focusVisible: {},\n\n /* Styles applied to the `component` element if dense. */\n dense: {\n paddingTop: 4,\n paddingBottom: 4\n },\n\n /* Styles applied to the `component` element if `alignItems=\"flex-start\"`. */\n alignItemsFlexStart: {\n alignItems: 'flex-start'\n },\n\n /* Pseudo-class applied to the inner `component` element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the inner `component` element if `divider={true}`. */\n divider: {\n borderBottom: \"1px solid \".concat(theme.palette.divider),\n backgroundClip: 'padding-box'\n },\n\n /* Styles applied to the inner `component` element if `disableGutters={false}`. */\n gutters: {\n paddingLeft: 16,\n paddingRight: 16\n },\n\n /* Styles applied to the inner `component` element if `button={true}`. */\n button: {\n transition: theme.transitions.create('background-color', {\n duration: theme.transitions.duration.shortest\n }),\n '&:hover': {\n textDecoration: 'none',\n backgroundColor: theme.palette.action.hover,\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the `component` element if `children` includes `ListItemSecondaryAction`. */\n secondaryAction: {\n // Add some space to avoid collision as `ListItemSecondaryAction`\n // is absolutely positioned.\n paddingRight: 48\n },\n\n /* Pseudo-class applied to the root element if `selected={true}`. */\n selected: {}\n };\n};\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * Uses an additional container component if `ListItemSecondaryAction` is the last child.\n */\n\nvar ListItem = React.forwardRef(function ListItem(props, ref) {\n var _props$alignItems = props.alignItems,\n alignItems = _props$alignItems === void 0 ? 'center' : _props$alignItems,\n _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n _props$button = props.button,\n button = _props$button === void 0 ? false : _props$button,\n childrenProp = props.children,\n classes = props.classes,\n className = props.className,\n componentProp = props.component,\n _props$ContainerCompo = props.ContainerComponent,\n ContainerComponent = _props$ContainerCompo === void 0 ? 'li' : _props$ContainerCompo,\n _props$ContainerProps = props.ContainerProps;\n _props$ContainerProps = _props$ContainerProps === void 0 ? {} : _props$ContainerProps;\n\n var ContainerClassName = _props$ContainerProps.className,\n ContainerProps = _objectWithoutProperties(_props$ContainerProps, [\"className\"]),\n _props$dense = props.dense,\n dense = _props$dense === void 0 ? false : _props$dense,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableGutters = props.disableGutters,\n disableGutters = _props$disableGutters === void 0 ? false : _props$disableGutters,\n _props$divider = props.divider,\n divider = _props$divider === void 0 ? false : _props$divider,\n focusVisibleClassName = props.focusVisibleClassName,\n _props$selected = props.selected,\n selected = _props$selected === void 0 ? false : _props$selected,\n other = _objectWithoutProperties(props, [\"alignItems\", \"autoFocus\", \"button\", \"children\", \"classes\", \"className\", \"component\", \"ContainerComponent\", \"ContainerProps\", \"dense\", \"disabled\", \"disableGutters\", \"divider\", \"focusVisibleClassName\", \"selected\"]);\n\n var context = React.useContext(ListContext);\n var childContext = {\n dense: dense || context.dense || false,\n alignItems: alignItems\n };\n var listItemRef = React.useRef(null);\n useEnhancedEffect(function () {\n if (autoFocus) {\n if (listItemRef.current) {\n listItemRef.current.focus();\n } else if (process.env.NODE_ENV !== 'production') {\n console.error('Material-UI: unable to set focus to a ListItem whose component has not been rendered.');\n }\n }\n }, [autoFocus]);\n var children = React.Children.toArray(childrenProp);\n var hasSecondaryAction = children.length && isMuiElement(children[children.length - 1], ['ListItemSecondaryAction']);\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n listItemRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n var handleRef = useForkRef(handleOwnRef, ref);\n\n var componentProps = _extends({\n className: clsx(classes.root, className, childContext.dense && classes.dense, !disableGutters && classes.gutters, divider && classes.divider, disabled && classes.disabled, button && classes.button, alignItems !== \"center\" && classes.alignItemsFlexStart, hasSecondaryAction && classes.secondaryAction, selected && classes.selected),\n disabled: disabled\n }, other);\n\n var Component = componentProp || 'li';\n\n if (button) {\n componentProps.component = componentProp || 'div';\n componentProps.focusVisibleClassName = clsx(classes.focusVisible, focusVisibleClassName);\n Component = ButtonBase;\n }\n\n if (hasSecondaryAction) {\n // Use div by default.\n Component = !componentProps.component && !componentProp ? 'div' : Component; // Avoid nesting of li > li.\n\n if (ContainerComponent === 'li') {\n if (Component === 'li') {\n Component = 'div';\n } else if (componentProps.component === 'li') {\n componentProps.component = 'div';\n }\n }\n\n return React.createElement(ListContext.Provider, {\n value: childContext\n }, React.createElement(ContainerComponent, _extends({\n className: clsx(classes.container, ContainerClassName),\n ref: handleRef\n }, ContainerProps), React.createElement(Component, componentProps, children), children.pop()));\n }\n\n return React.createElement(ListContext.Provider, {\n value: childContext\n }, React.createElement(Component, _extends({\n ref: handleRef\n }, componentProps), children));\n});\nprocess.env.NODE_ENV !== \"production\" ? ListItem.propTypes = {\n /**\n * Defines the `align-items` style property.\n */\n alignItems: PropTypes.oneOf(['flex-start', 'center']),\n\n /**\n * If `true`, the list item will be focused during the first mount.\n * Focus will also be triggered if the value changes from false to true.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, the list item will be a button (using `ButtonBase`). Props intended\n * for `ButtonBase` can then be applied to `ListItem`.\n */\n button: PropTypes.bool,\n\n /**\n * The content of the component. If a `ListItemSecondaryAction` is used it must\n * be the last child.\n */\n children: chainPropTypes(PropTypes.node, function (props) {\n var children = React.Children.toArray(props.children); // React.Children.toArray(props.children).findLastIndex(isListItemSecondaryAction)\n\n var secondaryActionIndex = -1;\n\n for (var i = children.length - 1; i >= 0; i -= 1) {\n var child = children[i];\n\n if (isMuiElement(child, ['ListItemSecondaryAction'])) {\n secondaryActionIndex = i;\n break;\n }\n } // is ListItemSecondaryAction the last child of ListItem\n\n\n if (secondaryActionIndex !== -1 && secondaryActionIndex !== children.length - 1) {\n return new Error('Material-UI: you used an element after ListItemSecondaryAction. ' + 'For ListItem to detect that it has a secondary action ' + 'you must pass it as the last child to ListItem.');\n }\n\n return null;\n }),\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n * By default, it's a `li` when `button` is `false` and a `div` when `button` is `true`.\n */\n component: PropTypes.elementType,\n\n /**\n * The container component used when a `ListItemSecondaryAction` is the last child.\n */\n ContainerComponent: PropTypes.elementType,\n\n /**\n * Props applied to the container component if used.\n */\n ContainerProps: PropTypes.object,\n\n /**\n * If `true`, compact vertical padding designed for keyboard and mouse input will be used.\n */\n dense: PropTypes.bool,\n\n /**\n * If `true`, the list item will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the left and right padding is removed.\n */\n disableGutters: PropTypes.bool,\n\n /**\n * If `true`, a 1px light border is added to the bottom of the list item.\n */\n divider: PropTypes.bool,\n\n /**\n * @ignore\n */\n focusVisibleClassName: PropTypes.string,\n\n /**\n * Use to apply selected styling.\n */\n selected: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiListItem'\n})(ListItem);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport ListItem from '../ListItem';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({}, theme.typography.body1, _defineProperty({\n minHeight: 48,\n paddingTop: 6,\n paddingBottom: 6,\n boxSizing: 'border-box',\n width: 'auto',\n overflow: 'hidden',\n whiteSpace: 'nowrap'\n }, theme.breakpoints.up('sm'), {\n minHeight: 'auto'\n })),\n // TODO To remove in v5?\n\n /* Styles applied to the root element if `disableGutters={false}`. */\n gutters: {},\n\n /* Styles applied to the root element if `selected={true}`. */\n selected: {},\n\n /* Styles applied to the root element if dense. */\n dense: _extends({}, theme.typography.body2, {\n minHeight: 'auto'\n })\n };\n};\nvar MenuItem = React.forwardRef(function MenuItem(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n component = _props$component === void 0 ? 'li' : _props$component,\n _props$disableGutters = props.disableGutters,\n disableGutters = _props$disableGutters === void 0 ? false : _props$disableGutters,\n _props$role = props.role,\n role = _props$role === void 0 ? 'menuitem' : _props$role,\n selected = props.selected,\n tabIndexProp = props.tabIndex,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"disableGutters\", \"role\", \"selected\", \"tabIndex\"]);\n\n var tabIndex;\n\n if (!props.disabled) {\n tabIndex = tabIndexProp !== undefined ? tabIndexProp : -1;\n }\n\n return React.createElement(ListItem, _extends({\n button: true,\n role: role,\n tabIndex: tabIndex,\n component: component,\n selected: selected,\n disableGutters: disableGutters,\n classes: {\n dense: classes.dense\n },\n className: clsx(classes.root, className, selected && classes.selected, !disableGutters && classes.gutters),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? MenuItem.propTypes = {\n /**\n * Menu item contents.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, compact vertical padding designed for keyboard and mouse input will be used.\n */\n dense: PropTypes.bool,\n\n /**\n * @ignore\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the left and right padding is removed.\n */\n disableGutters: PropTypes.bool,\n\n /**\n * @ignore\n */\n role: PropTypes.string,\n\n /**\n * @ignore\n */\n selected: PropTypes.bool,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.number\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiMenuItem'\n})(MenuItem);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'flex',\n flexDirection: 'column',\n flexWrap: 'wrap'\n },\n\n /* Styles applied to the root element if `row={true}`. */\n row: {\n flexDirection: 'row'\n }\n};\n/**\n * `FormGroup` wraps controls such as `Checkbox` and `Switch`.\n * It provides compact row layout.\n * For the `Radio`, you should be using the `RadioGroup` component instead of this one.\n */\n\nvar FormGroup = React.forwardRef(function FormGroup(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$row = props.row,\n row = _props$row === void 0 ? false : _props$row,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"row\"]);\n\n return React.createElement(\"div\", _extends({\n className: clsx(classes.root, className, row && classes.row),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormGroup.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * Display group of elements in a compact row.\n */\n row: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormGroup'\n})(FormGroup);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport FormGroup from '../FormGroup';\nimport useForkRef from '../utils/useForkRef';\nimport RadioGroupContext from './RadioGroupContext';\nvar RadioGroup = React.forwardRef(function RadioGroup(props, ref) {\n var actions = props.actions,\n children = props.children,\n name = props.name,\n valueProp = props.value,\n onChange = props.onChange,\n other = _objectWithoutProperties(props, [\"actions\", \"children\", \"name\", \"value\", \"onChange\"]);\n\n var rootRef = React.useRef(null);\n\n var _React$useRef = React.useRef(valueProp != null),\n isControlled = _React$useRef.current;\n\n var _React$useState = React.useState(props.defaultValue),\n valueState = _React$useState[0],\n setValue = _React$useState[1];\n\n var value = isControlled ? valueProp : valueState;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (isControlled !== (valueProp != null)) {\n console.error([\"Material-UI: A component is changing \".concat(isControlled ? 'a ' : 'an un', \"controlled RadioGroup to be \").concat(isControlled ? 'un' : '', \"controlled.\"), 'Elements should not switch from uncontrolled to controlled (or vice versa).', 'Decide between using a controlled or uncontrolled RadioGroup ' + 'element for the lifetime of the component.', 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [valueProp, isControlled]);\n }\n\n React.useImperativeHandle(actions, function () {\n return {\n focus: function focus() {\n var input = rootRef.current.querySelector('input:not(:disabled):checked');\n\n if (!input) {\n input = rootRef.current.querySelector('input:not(:disabled)');\n }\n\n if (input) {\n input.focus();\n }\n }\n };\n }, []);\n var handleRef = useForkRef(ref, rootRef);\n\n var handleChange = function handleChange(event) {\n if (!isControlled) {\n setValue(event.target.value);\n }\n\n if (onChange) {\n onChange(event, event.target.value);\n }\n };\n\n return React.createElement(RadioGroupContext.Provider, {\n value: {\n name: name,\n onChange: handleChange,\n value: value\n }\n }, React.createElement(FormGroup, _extends({\n role: \"radiogroup\",\n ref: handleRef\n }, other), children));\n});\nprocess.env.NODE_ENV !== \"production\" ? RadioGroup.propTypes = {\n /**\n * @ignore\n */\n actions: PropTypes.shape({\n current: PropTypes.object\n }),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * The name used to reference the value of the control.\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when a radio button is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * Value of the selected radio button. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default RadioGroup;"],"sourceRoot":""} \ No newline at end of file diff --git a/build/static/js/main.928fa077.chunk.js b/build/static/js/main.928fa077.chunk.js new file mode 100644 index 0000000..42cb51a --- /dev/null +++ b/build/static/js/main.928fa077.chunk.js @@ -0,0 +1,2 @@ +(this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[]).push([[0],{101:function(e,t,a){e.exports=a(130)},106:function(e,t,a){},130:function(e,t,a){"use strict";a.r(t);var n=a(0),i=a.n(n),r=a(9),o=a.n(r),c=(a(106),a(66)),l=a(36),s=a(11),u=a(34),m=a(165),d=a(167),p=a(166),g=a(63),f=a.n(g),E=a(132),q=a(64),h=a.n(q),v=a(65),x=a.n(v),b=a(54),y=a.n(b),j=a(170),w=a(55),O=a.n(w),F=a(173),N=a(19),C=a.n(N),S=a(164),k=a(160);var G=function(e){return i.a.createElement(i.a.Fragment,null,i.a.createElement(k.a,{control:i.a.createElement(S.a,{onChange:function(t){return e.setRequiredField(e.idq)},value:"required",color:"primary",checked:e.required}),label:"Obrigat\xf3ria"}),i.a.createElement(E.a,{"aria-label":"delete",onClick:function(){e.deleteFromForm(e.idq)}},i.a.createElement(C.a,null)))},I=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var R=function(e){var t=I();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(F.a,{disabled:!0,id:"outlined-disabled",label:"",defaultValue:"Resposta curta"})),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},B=a(28),A=a.n(B),W=a(27),_=a.n(W),z=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var U=function(e){var t=z();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},e.options.map((function(t,a){return i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:11},i.a.createElement(F.a,{label:"op\xe7\xe3o "+a,value:t,fullWidth:!0,onChange:function(t){return e.setSelectOption(t.target.value,e.idq,a)}})),i.a.createElement(d.a,{item:!0,xs:1},i.a.createElement(E.a,{"aria-label":"remove option",onClick:function(){e.removeSelectOption(e.idq,a)}},i.a.createElement(_.a,null))))}))),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:4},i.a.createElement(E.a,{"aria-label":"add option",onClick:function(){e.addSelectOption(e.idq)}},i.a.createElement(A.a,null))),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},T=a(87),Q=a.n(T),P=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var L=function(e){var t=P();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},e.options.map((function(t,a){return i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,container:!0,justify:"center",alignItems:"center",xs:1},i.a.createElement(Q.a,null)),i.a.createElement(d.a,{item:!0,xs:10},i.a.createElement(F.a,{label:"op\xe7\xe3o "+a,value:t,fullWidth:!0,onChange:function(t){return e.setSelectOption(t.target.value,e.idq,a)}})),i.a.createElement(d.a,{item:!0,xs:1},i.a.createElement(E.a,{"aria-label":"remove option",onClick:function(){e.removeSelectOption(e.idq,a)}},i.a.createElement(_.a,null))))}))),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:4},i.a.createElement(E.a,{"aria-label":"add option",onClick:function(){e.addSelectOption(e.idq)}},i.a.createElement(A.a,null))),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},D=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var Z=function(e){var t=D();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},e.options.map((function(t,a){return i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,container:!0,justify:"center",alignItems:"center",xs:1},i.a.createElement(y.a,null)),i.a.createElement(d.a,{item:!0,xs:10},i.a.createElement(F.a,{label:"op\xe7\xe3o "+a,value:t,fullWidth:!0,onChange:function(t){return e.setSelectOption(t.target.value,e.idq,a)}})),i.a.createElement(d.a,{item:!0,xs:1},i.a.createElement(E.a,{"aria-label":"remove option",onClick:function(){e.removeSelectOption(e.idq,a)}},i.a.createElement(_.a,null))))}))),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:4},i.a.createElement(E.a,{"aria-label":"add option",onClick:function(){e.addSelectOption(e.idq)}},i.a.createElement(A.a,null))),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},$=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"},title:{fontSize:"xx-large"},description:{fontSize:"x-large"}}}));var J=function(e){var t=$();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"Formul\xe1rio sem t\xedtulo",fullWidth:!0,onChange:function(t){return e.setTitleField(t.target.value,e.idq)},InputProps:{classes:{input:t.title}}})),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"Descri\xe7\xe3o do formul\xe1rio",onChange:function(t){return e.setDescriptionField(t.target.value,e.idq)},InputProps:{classes:{input:t.description}}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3})))},V="production"===Object({NODE_ENV:"production",PUBLIC_URL:""}).REACT_APP_STAGE?{genformsapi:{url:""}}:{genformsapi:{url:"http://200.236.31.188/api/"}},M=Object(m.a)((function(e){return{menu:{width:e.spacing(6),minheight:e.spacing(15),position:"fixed",top:e.spacing(10),left:"90%",padding:e.spacing(1)}}}));var H=function(){var e=M(),t=Object(n.useState)([{type:"title",title:"",description:""}]),a=Object(u.a)(t,2),r=a[0],o=a[1];function c(e){r[e].options.push(""),o(Object(s.a)(r)),console.log(r)}function l(e){console.log(e),r.splice(e,1),console.log(r),o(Object(s.a)(r))}function m(e,t){r[e].options.splice(t,1),o(Object(s.a)(r)),console.log(r)}function g(e,t){r[t].question=e,o(Object(s.a)(r)),console.log(r)}function q(e,t,a){r[t].options[a]=e,o(Object(s.a)(r)),console.log(r)}function v(e){r[e].required=!r[e].required,o(Object(s.a)(r)),console.log(r)}function b(e,t){r[t].title=e,o(Object(s.a)(r)),console.log(r)}function w(e,t){r[t].description=e,o(Object(s.a)(r)),console.log(r)}return i.a.createElement("div",null,i.a.createElement(d.a,{container:!0,direction:"column",alignItems:"center",justify:"center"},r.map((function(e,t){return"question"===e.type?i.a.createElement(R,{question:e.question,idq:t,deleteFromForm:l,setQuestionField:g,setRequiredField:v,required:e.required}):"select"===e.type?i.a.createElement(U,{question:e.question,options:e.options,idq:t,deleteFromForm:l,addSelectOption:c,removeSelectOption:m,setSelectOption:q,setQuestionField:g,setRequiredField:v,required:e.required}):"radio"===e.type?i.a.createElement(L,{question:e.question,options:e.options,idq:t,deleteFromForm:l,addSelectOption:c,removeSelectOption:m,setSelectOption:q,setQuestionField:g,setRequiredField:v,required:e.required}):"checkbox"===e.type?i.a.createElement(Z,{question:e.question,options:e.options,idq:t,deleteFromForm:l,addSelectOption:c,removeSelectOption:m,setSelectOption:q,setQuestionField:g,setRequiredField:v,required:e.required}):"title"===e.type?i.a.createElement(J,{question:e.question,idq:t,deleteFromForm:l,setTitleField:b,setDescriptionField:w}):void 0})),i.a.createElement(j.a,{variant:"contained",color:"primary",onClick:function(){var e={title:r[0].title,description:r[0].description,inputs:[]};r.forEach((function(t,a){"question"===t.type?e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:0,validation:t.required?[{type:2,arguments:""}]:[]}):"select"===t.type?e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:3,validation:t.required?[{type:2,arguments:""}]:[],sugestions:t.options.map((function(e,t){return{value:e,placement:t}}))}):"checkbox"===t.type?e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:1,validation:t.required?[{type:2,arguments:""}]:[],sugestions:t.options.map((function(e,t){return{value:e,placement:t}}))}):"radio"===t.type&&e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:2,validation:t.required?[{type:2,arguments:""}]:[],sugestions:t.options.map((function(e,t){return{value:e,placement:t}}))})})),console.log(e),O.a.post("".concat(V.genformsapi.url,"/form"),e).then((function(e){console.log(e),console.log(e.data),window.location.reload()}))}},"Criar")),i.a.createElement(p.a,{className:e.menu},i.a.createElement(d.a,{container:!0,spacing:0,direction:"column",alignItems:"center",justify:"center"},i.a.createElement(d.a,{item:!0,xs:0},i.a.createElement(E.a,{"aria-label":"add question",onClick:function(){o([].concat(Object(s.a)(r),[{type:"question",required:!1,question:""}])),console.log(r)}},i.a.createElement(f.a,null)),i.a.createElement(E.a,{"aria-label":"add select",onClick:function(){o([].concat(Object(s.a)(r),[{type:"select",question:"",required:!1,options:[""]}])),console.log(r)}},i.a.createElement(h.a,null)),i.a.createElement(E.a,{"aria-label":"add radio",onClick:function(){o([].concat(Object(s.a)(r),[{type:"radio",question:"",required:!1,options:[""]}])),console.log(r)}},i.a.createElement(x.a,null)),i.a.createElement(E.a,{"aria-label":"add checkbox",onClick:function(){o([].concat(Object(s.a)(r),[{type:"checkbox",question:"",required:!1,options:[""]}])),console.log(r)}},i.a.createElement(y.a,null))))))},K=a(131);var X=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var Y=function(e){var t=X();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(F.a,{id:"outlined-disabled",label:"",placeholder:"Resposta curta"})),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3})))},ee=a(172),te=a(177),ae=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var ne=function(e){var t=ae(),a=e.options.map((function(e){return i.a.createElement(te.a,{value:e.value},e.value)}));return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},i.a.createElement(ee.a,{labelId:"demo-simple-select-label",id:"demo-simple-select"},a))))},ie=a(174),re=a(178),oe=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var ce=function(e){var t=oe(),a=i.a.useState(),n=Object(u.a)(a,2),r=n[0],o=n[1],c=function(e){o(e.target.value)},l=e.options.map((function(e){return i.a.createElement("span",null,e.value,i.a.createElement(ie.a,{checked:r===e.value,onChange:c,value:e.value}))}));return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},i.a.createElement(re.a,null,l))))},le=a(175),se=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var ue=function(e){var t=se(),a=e.options.map((function(e){return i.a.createElement("span",null,e.value," ",i.a.createElement(le.a,null))}));return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},a)))},me=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"},title:{fontSize:"xx-large"},description:{fontSize:"x-large"}}}));var de=function(e){var t=me();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h3",gutterBottom:!0},e.title)),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h4",gutterBottom:!0},e.description)),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3})))},pe=Object(m.a)((function(e){return{menu:{width:e.spacing(6),minheight:e.spacing(15),position:"fixed",top:e.spacing(10),left:"90%",padding:e.spacing(1)}}}));var ge=function(){pe();var e=Object(l.e)().id,t=Object(n.useState)(0),a=Object(u.a)(t,2),r=a[0],o=a[1];return Object(n.useEffect)((function(){!function(e){O.a.get("".concat(V.genformsapi.url,"/form/").concat(e)).then((function(e){console.log(e),console.log(e.data),o(e.data)}))}(e)}),[]),i.a.createElement("div",null,i.a.createElement(d.a,{container:!0,direction:"column",alignItems:"center",justify:"center"},r?i.a.createElement("div",null,i.a.createElement(de,{title:r.title,description:r.description}),r.inputs.map((function(e,t){return 0===e.type?i.a.createElement(Y,{question:e.question}):4===e.type?i.a.createElement(ne,{question:e.question,options:e.sugestions}):2===e.type?i.a.createElement(ce,{question:e.question,options:e.sugestions}):1===e.type?i.a.createElement(ue,{question:e.question,options:e.sugestions}):void 0}))):i.a.createElement("p",null,"Loading..."),i.a.createElement(j.a,{variant:"contained",color:"primary",onClick:function(){O.a.post("".concat(V.genformsapi.url,"/form")).then((function(e){console.log(e),console.log(e.data)}))}},"Responder")))},fe=a(90),Ee=a(20),qe=a(92),he=a(171),ve=a(91),xe=a.n(ve);var be=function(e){return i.a.createElement(F.a,{required:!0,onChange:e.onUpdate(e.param),style:{width:"45%"},id:"standart-basic",label:e.label,type:"password"==e.param?"password":"text",autoComplete:"off"})},ye=Object(m.a)((function(e){return{register:{maxWidth:"1000px",background:"#ffffff",boxShadow:"0 0 3px 0 #35c7fc",borderRadius:"2px",padding:"2% 1%",margin:"0 auto",marginTop:"9%"},custom_strong:{fontSize:"25px",textAlign:"center",display:"block",color:"#46525d"},strong_description:{fontSize:"14px",color:"#c2c6ca"},form:{marginTop:"3%",alignItems:"center",textAlign:"center"},button:Object(Ee.a)({type:"submit",width:"30%",marginTop:"4%",background:"#6ec46c",borderRadius:"2px",padding:"10px 20px",fontSize:"18px",color:"#ffffff","&:hover":{backgroundColor:"rgb(25, 109, 23)"}},"@media (max-width:550px)",{width:"55%"})}}));function je(){var e=ye(),t=i.a.useState({name:"",email:"",password:"",password_confirm:""}),a=Object(u.a)(t,2),n=a[0],r=a[1],o=function(e){return function(t){r(Object(fe.a)({},n,Object(Ee.a)({},e,t.target.value)))}};function c(){return!(n.password!=n.password_confirm&&(alert("As senhas n\xe3o conferem"),1)||!(/^[a-zA-Z ]+$/.test(n.name)&&n.name.length<=225||(alert("Nome inv\xe1lido"),0))||!/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\.[A-Za-z]+$/.test(n.email)&&(alert("E-mail inv\xe1lido"),1))}function l(){n.name&&n.email&&n.password&&n.password_confirm&&c()}var s=Object(qe.a)({overrides:{MuiInput:{underline:{"&:before":{borderBottom:"1px solid #35c7fc"},"&:after":{borderBottom:"1px solid #3f51b5"}}}}});return i.a.createElement(he.a,{theme:s},i.a.createElement(d.a,{className:e.register,justify:"center"},i.a.createElement("strong",{className:e.custom_strong},"Cadastro de Usu\xe1rio",i.a.createElement("p",{className:e.strong_description},"Insira as informa\xe7\xf5es abaixo")),i.a.createElement("form",{className:e.form,autocomplete:"off"},i.a.createElement(d.a,null,i.a.createElement(be,{label:"Nome Completo",param:"name",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(be,{label:"E-mail",param:"email",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(be,{label:"Senha",param:"password",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(be,{label:"Confirmar Senha",param:"password_confirm",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(E.a,{type:"submit",size:"medium",className:e.button,onClick:function(){return l()}},i.a.createElement(xe.a,null),"Cadastre-se")))))}var we=function(){return i.a.createElement(c.a,null,i.a.createElement(l.a,{path:"/create",component:H}),i.a.createElement(l.a,{path:"/answer/:id",component:ge}),i.a.createElement(l.a,{path:"/SignUp",component:je}))},Oe=Boolean("localhost"===window.location.hostname||"[::1]"===window.location.hostname||window.location.hostname.match(/^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/));function Fe(e,t){navigator.serviceWorker.register(e).then((function(e){e.onupdatefound=function(){var a=e.installing;null!=a&&(a.onstatechange=function(){"installed"===a.state&&(navigator.serviceWorker.controller?(console.log("New content is available and will be used when all tabs for this page are closed. See https://bit.ly/CRA-PWA."),t&&t.onUpdate&&t.onUpdate(e)):(console.log("Content is cached for offline use."),t&&t.onSuccess&&t.onSuccess(e)))})}})).catch((function(e){console.error("Error during service worker registration:",e)}))}o.a.render(i.a.createElement(we,null),document.getElementById("root")),function(e){if("serviceWorker"in navigator){if(new URL("",window.location.href).origin!==window.location.origin)return;window.addEventListener("load",(function(){var t="".concat("","/service-worker.js");Oe?(!function(e,t){fetch(e,{headers:{"Service-Worker":"script"}}).then((function(a){var n=a.headers.get("content-type");404===a.status||null!=n&&-1===n.indexOf("javascript")?navigator.serviceWorker.ready.then((function(e){e.unregister().then((function(){window.location.reload()}))})):Fe(e,t)})).catch((function(){console.log("No internet connection found. App is running in offline mode.")}))}(t,e),navigator.serviceWorker.ready.then((function(){console.log("This web app is being served cache-first by a service worker. To learn more, visit https://bit.ly/CRA-PWA")}))):Fe(t,e)}))}}()}},[[101,1,2]]]); +//# sourceMappingURL=main.928fa077.chunk.js.map \ No newline at end of file diff --git a/build/static/js/main.928fa077.chunk.js.map b/build/static/js/main.928fa077.chunk.js.map new file mode 100644 index 0000000..42d9363 --- /dev/null +++ b/build/static/js/main.928fa077.chunk.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["components/fieldsCreateForm/FieldFooterOptions.js","components/fieldsCreateForm/FormFieldText.js","components/fieldsCreateForm/FormFieldSelect.js","components/fieldsCreateForm/FormFieldRadio.js","components/fieldsCreateForm/FormFieldCheckbox.js","components/fieldsCreateForm/FormFieldTitle.js","config.js","pages/CreateForm.js","components/fieldsAnswerForm/FieldFooterOptions.js","components/fieldsAnswerForm/FormFieldText.js","components/fieldsAnswerForm/FormFieldSelect.js","components/fieldsAnswerForm/FormFieldRadio.js","components/fieldsAnswerForm/FormFieldCheckbox.js","components/fieldsAnswerForm/FormFieldTitle.js","pages/AnswerForm.js","components/fieldsSignUp/FormInput.jsx","pages/SignUp.js","App.js","serviceWorker.js","index.js"],"names":["FieldFooterOptions","props","FormControlLabel","control","Switch","onChange","e","setRequiredField","idq","value","color","checked","required","label","IconButton","aria-label","onClick","deleteFromForm","useStyles","makeStyles","theme","paper","padding","spacing","width","height","margin","questionsGrid","marginBottom","FormFieldText","classes","Paper","className","Grid","container","item","xs","TextField","question","setQuestionField","target","disabled","id","defaultValue","direction","justify","alignItems","minheight","FormFieldSelect","options","map","x","index","fullWidth","setSelectOption","removeSelectOption","addSelectOption","FormFieldRadio","FormFieldCheckbox","title","fontSize","description","setTitleField","InputProps","input","setDescriptionField","config","process","REACT_APP_STAGE","genformsapi","url","menu","position","top","left","CreateForm","useState","type","form","setForm","push","console","log","splice","idopt","FormFieldTitle","Button","variant","json","inputs","forEach","y","placement","axios","post","then","res","data","window","location","reload","Typography","gutterBottom","placeholder","MenuItem","Select","labelId","React","selectedValue","setSelectedValue","handleChange","event","Radio","RadioGroup","Checkbox","AnwserForm","useParams","formData","setFormData","useEffect","get","getForm","sugestions","FormInput","onUpdate","param","style","autoComplete","register","maxWidth","background","boxShadow","borderRadius","marginTop","custom_strong","textAlign","display","strong_description","button","backgroundColor","SignUp","name","email","password","password_confirm","values","setValues","prop","verifyValuesContent","alert","test","length","submit","createMuiTheme","overrides","MuiInput","underline","borderBottom","autocomplete","size","App","path","component","AnswerForm","isLocalhost","Boolean","hostname","match","registerValidSW","swUrl","navigator","serviceWorker","registration","onupdatefound","installingWorker","installing","onstatechange","state","controller","onSuccess","catch","error","ReactDOM","render","document","getElementById","URL","href","origin","addEventListener","fetch","headers","response","contentType","status","indexOf","ready","unregister","checkValidServiceWorker"],"mappings":"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","file":"static/js/main.928fa077.chunk.js","sourcesContent":["import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\n\nfunction FieldFooterOptions(props) {\n\n\treturn (\n\t\t\t<>\n\t\t\t<FormControlLabel\n\t\t\t\tcontrol={\n\t\t\t\t<Switch\n\t\t\t\t\tonChange={e => props.setRequiredField(props.idq) }\n\t\t\t\t\tvalue=\"required\"\n\t\t\t\t\tcolor=\"primary\"\n\t\t\t\t\tchecked={props.required}\n\t\t\t\t/>\n\t\t\t\t}\n\t\t\t\tlabel=\"Obrigatória\"\n\t\t\t/>\n\t\t\t<IconButton aria-label=\"delete\" onClick={() => { props.deleteFromForm(props.idq) } }>\n\t\t\t\t<DeleteOutlinedIcon />\n\t\t\t</IconButton>\n\t\t\t</>\n\t);\n\n\n}\n\n\nexport default FieldFooterOptions;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\"\n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <TextField\n disabled\n id=\"outlined-disabled\"\n label=\"\"\n defaultValue=\"Resposta curta\"\n />\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required} />\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldSelect(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\" \n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {\n props.options.map((x, index) => {\n return <Grid container>\n <Grid item xs={11}>\n <TextField label={\"opção \"+index} value={x} fullWidth\n onChange={e => props.setSelectOption(e.target.value, props.idq, index)} />\n </Grid>\n <Grid item xs={1}>\n <IconButton aria-label=\"remove option\"\n onClick={() => { props.removeSelectOption(props.idq, index) } }>\n <CloseIcon />\n </IconButton>\n </Grid>\n </Grid>\n })\n }\n </Grid>\n <Grid item container \n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\"\n xs={4}\n >\n <IconButton aria-label=\"add option\" onClick={() => { props.addSelectOption(props.idq) } }>\n <AddCircleIcon />\n </IconButton>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required} />\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldSelect;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport RadioButtonUncheckedIcon from '@material-ui/icons/RadioButtonUnchecked';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldRadio(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\" \n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {\n props.options.map((x, index) => {\n return <Grid container>\n\t\t\t\t\t\t\t\t\t\t\t<Grid item container\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tjustify=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\talignItems=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\txs={1}\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t<RadioButtonUncheckedIcon/>\n\t\t\t\t\t\t\t\t\t\t\t</Grid>\n <Grid item xs={10}>\n <TextField label={\"opção \"+index} value={x} fullWidth\n onChange={e => props.setSelectOption(e.target.value, props.idq, index)} />\n </Grid>\n <Grid item xs={1}>\n <IconButton aria-label=\"remove option\"\n onClick={() => { props.removeSelectOption(props.idq, index) } }>\n <CloseIcon />\n </IconButton>\n </Grid>\n </Grid>\n })\n }\n </Grid>\n <Grid item container \n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\"\n xs={4}\n >\n <IconButton aria-label=\"add option\" onClick={() => { props.addSelectOption(props.idq) } }>\n <AddCircleIcon />\n </IconButton>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required} />\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldRadio;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank';\n\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldCheckbox(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\" \n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {\n props.options.map((x, index) => {\n return <Grid container>\n\t\t\t\t\t\t\t\t\t\t\t<Grid item container\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tjustify=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\talignItems=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\txs={1}\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t<CheckBoxOutlineBlankIcon/>\n\t\t\t\t\t\t\t\t\t\t\t</Grid>\n <Grid item xs={10}>\n <TextField label={\"opção \"+index} value={x} fullWidth\n onChange={e => props.setSelectOption(e.target.value, props.idq, index)} />\n </Grid>\n <Grid item xs={1}>\n <IconButton aria-label=\"remove option\"\n onClick={() => { props.removeSelectOption(props.idq, index) } }>\n <CloseIcon />\n </IconButton>\n </Grid>\n </Grid>\n })\n }\n </Grid>\n <Grid item container \n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\"\n xs={4}\n >\n <IconButton aria-label=\"add option\" onClick={() => { props.addSelectOption(props.idq) } }>\n <AddCircleIcon />\n </IconButton>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required}/>\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldCheckbox;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n\t\tmarginBottom: '20px'\n\t},\n\ttitle: {\n\t\tfontSize: 'xx-large'\n\t},\n\tdescription: {\n\t\tfontSize: 'x-large'\n\t},\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"Formulário sem tÃtulo\" fullWidth \n onChange={e => props.setTitleField(e.target.value, props.idq)}\n\t\t\t\t\t\t\t\t\t\t\tInputProps={{\n\t\t\t\t\t\t\t\t\t\t\t\tclasses: {\n\t\t\t\t\t\t\t\t\t\t\t\t\tinput: classes.title,\n\t\t\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t\t\t}}/>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"Descrição do formulário\"\n onChange={e => props.setDescriptionField(e.target.value, props.idq)}\n\t\t\t\t\t\t\t\t\t\t\tInputProps={{\n\t\t\t\t\t\t\t\t\t\t\t\tclasses: {\n\t\t\t\t\t\t\t\t\t\t\t\t\tinput: classes.description,\n\t\t\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t\t\t}}/>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","const development = {\n genformsapi: {\n url: \"http://200.236.31.188/api/\"\n }\n};\n\nconst production = {\n genformsapi: {\n url: \"\"\n }\n};\n\n\nlet conf;\nif(process.env.REACT_APP_STAGE === \"production\") {\n conf = production;\n} else {\n conf = development;\n}\n\nconst config = conf;\nexport default config;\n","import React, { useState } from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport AddIcon from '@material-ui/icons/Add';\nimport IconButton from '@material-ui/core/IconButton';\nimport ReorderIcon from '@material-ui/icons/Reorder';\nimport RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked';\nimport CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank';\nimport Button from '@material-ui/core/Button';\nimport axios from 'axios';\n\nimport FormFieldText from '../components/fieldsCreateForm/FormFieldText';\nimport FormFieldSelect from '../components/fieldsCreateForm/FormFieldSelect';\nimport FormFieldRadio from '../components/fieldsCreateForm/FormFieldRadio';\nimport FormFieldCheckbox from '../components/fieldsCreateForm/FormFieldCheckbox';\nimport FormFieldTitle from '../components/fieldsCreateForm/FormFieldTitle';\n\nimport config from '../config';\n\n\nconst useStyles = makeStyles(theme => ({\n menu: {\n width: theme.spacing(6),\n minheight: theme.spacing(15),\n position: 'fixed',\n top: theme.spacing(10),\n left: '90%',\n padding: theme.spacing(1)\n },\n}));\n\nfunction CreateForm() {\n const classes = useStyles();\n\n const [form, setForm] = useState([{type: \"title\", title: \"\", description: \"\"}]);\n\n function addToFormQuestion() {\n setForm([...form, {type: \"question\", required: false, question: \"\"}]);\n console.log(form);\n }\n\n function addToFormSelect() {\n setForm([...form, {type: \"select\", question: \"\", required: false, options: [\"\"]}]);\n console.log(form);\n }\n\n function addToFormRadio() {\n setForm([...form, {type: \"radio\", question: \"\", required: false, options: [\"\"]}]);\n console.log(form);\n }\n\n function addToFormCheckbox() {\n setForm([...form, {type: \"checkbox\", question: \"\", required: false, options: [\"\"]}]);\n console.log(form);\n }\n\n function addSelectOption(index) {\n form[index].options.push(\"\");\n setForm([...form]);\n console.log(form);\n }\n\n function deleteFromForm(index) {\n console.log(index);\n form.splice(index, 1)\n console.log(form);\n setForm([...form]);\n }\n\n function removeSelectOption(index, idopt) {\n form[index].options.splice(idopt, 1);\n setForm([...form]);\n console.log(form);\n }\n\n function setQuestionField(value, index) {\n form[index].question = value;\n setForm([...form]);\n console.log(form);\n }\n \n function setSelectOption(value, index, idopt) {\n form[index].options[idopt] = value;\n setForm([...form]);\n console.log(form);\n }\n\n function setRequiredField(index) {\n form[index].required = !form[index].required;\n setForm([...form]);\n console.log(form);\n }\n\n function setTitleField(value, index) {\n form[index].title = value;\n setForm([...form]);\n console.log(form);\n }\n\n function setDescriptionField(value, index) {\n form[index].description = value;\n setForm([...form]);\n console.log(form);\n }\n\n function createForm() {\n let json = {\n title: form[0].title,\n description: form[0].description,\n inputs: []\n }\n \n form.forEach(function(x, index){\n if(x.type === \"question\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 0, // question type = 0\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : []\n });\n } else if(x.type === \"select\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 3, // select type = 3\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : [],\n \"sugestions\": x.options.map(function(y, index) { return {value: y, placement: index} })\n });\n } else if(x.type === \"checkbox\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 1, // checkbox type = 1\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : [],\n \"sugestions\": x.options.map(function(y, index) { return {value: y, placement: index} })\n });\n } else if(x.type === \"radio\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 2, // radio type = 2\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : [],\n \"sugestions\": x.options.map(function(y, index) { return {value: y, placement: index} })\n });\n }\n });\n \n\n console.log(json);\n axios.post(`${config.genformsapi.url}/form`, json )\n .then(res => {\n console.log(res);\n console.log(res.data);\n\n window.location.reload();\n });\n \n }\n\n return (\n <div>\n <Grid\n container\n direction=\"column\"\n alignItems=\"center\"\n justify=\"center\"\n >\n {\n form.map((x, index) => {\n if(x.type === \"question\")\n return <FormFieldText question={x.question} idq={index} \n deleteFromForm={deleteFromForm} setQuestionField={setQuestionField} \n setRequiredField={setRequiredField} required={x.required}/>\n else if(x.type === \"select\")\n return <FormFieldSelect question={x.question} options={x.options} idq={index} \n deleteFromForm={deleteFromForm} addSelectOption={addSelectOption}\n removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} \n setQuestionField={setQuestionField} setRequiredField={setRequiredField} \n required={x.required} />\n else if(x.type === \"radio\")\n return <FormFieldRadio question={x.question} options={x.options} idq={index} \n deleteFromForm={deleteFromForm} addSelectOption={addSelectOption}\n removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} \n setQuestionField={setQuestionField} setRequiredField={setRequiredField} \n required={x.required} />\n else if(x.type === \"checkbox\")\n return <FormFieldCheckbox question={x.question} options={x.options} idq={index} \n deleteFromForm={deleteFromForm} addSelectOption={addSelectOption}\n removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} \n setQuestionField={setQuestionField} setRequiredField={setRequiredField} \n required={x.required} />\n else if(x.type === \"title\")\n return <FormFieldTitle question={x.question} idq={index} \n deleteFromForm={deleteFromForm} setTitleField={setTitleField} \n setDescriptionField={setDescriptionField}/>\n })\n }\n <Button variant=\"contained\" color=\"primary\" onClick={createForm}>\n Criar\n </Button>\n </Grid>\n \n <Paper className={classes.menu}>\n <Grid\n container\n spacing={0}\n direction=\"column\"\n alignItems=\"center\"\n justify=\"center\"\n >\n <Grid item xs={0}>\n <IconButton aria-label=\"add question\" onClick={addToFormQuestion}>\n <AddIcon />\n </IconButton>\n <IconButton aria-label=\"add select\" onClick={addToFormSelect}>\n <ReorderIcon />\n </IconButton>\n <IconButton aria-label=\"add radio\" onClick={addToFormRadio}>\n <RadioButtonCheckedIcon />\n </IconButton>\n <IconButton aria-label=\"add checkbox\" onClick={addToFormCheckbox}>\n <CheckBoxOutlineBlankIcon />\n </IconButton>\n </Grid>\n </Grid>\n </Paper>\n \n </div>\n );\n}\n\nexport default CreateForm;\n","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\n\nfunction FieldFooterOptions(props) {\n\n\treturn (\n\t\t\t<>\n\t\t\t<FormControlLabel\n\t\t\t\tcontrol={\n\t\t\t\t<Switch\n\t\t\t\t\tonChange={e => props.setRequiredField(props.idq) }\n\t\t\t\t\tvalue=\"required\"\n\t\t\t\t\tcolor=\"primary\"\n\t\t\t\t\tchecked={props.required}\n\t\t\t\t/>\n\t\t\t\t}\n\t\t\t\tlabel=\"Obrigatória\"\n\t\t\t/>\n\t\t\t<IconButton aria-label=\"delete\" onClick={() => { props.deleteFromForm(props.idq) } }>\n\t\t\t\t<DeleteOutlinedIcon />\n\t\t\t</IconButton>\n\t\t\t</>\n\t);\n\n\n}\n\n\nexport default FieldFooterOptions;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Typography from '@material-ui/core/Typography';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <TextField\n id=\"outlined-disabled\"\n label=\"\"\n placeholder=\"Resposta curta\"\n />\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Typography from '@material-ui/core/Typography';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldSelect(props) {\n const classes = useStyles();\n\n const options = props.options.map(function(x) {\n return <MenuItem value={x.value}>{x.value}</MenuItem>;\n });\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n <Select\n labelId=\"demo-simple-select-label\"\n id=\"demo-simple-select\"\n // onChange={handleChange}\n >\n {options}\n </Select>\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldSelect;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Typography from '@material-ui/core/Typography';\nimport Radio from '@material-ui/core/Radio';\nimport RadioGroup from '@material-ui/core/RadioGroup';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldRadio(props) {\n const classes = useStyles();\n\n const [selectedValue, setSelectedValue] = React.useState();\n\n const handleChange = event => {\n setSelectedValue(event.target.value);\n };\n\n const options = props.options.map(function(x) {\n return <span>\n {x.value} \n <Radio checked={selectedValue === x.value}\n onChange={handleChange}\n value={x.value}\n />\n </span>;\n });\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n <RadioGroup>\n {options}\n </RadioGroup>\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldRadio;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Typography from '@material-ui/core/Typography';\nimport Checkbox from '@material-ui/core/Checkbox';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldCheckbox(props) {\n const classes = useStyles();\n\n const options = props.options.map(function(x) {\n return <span>{x.value} <Checkbox /></span>;\n });\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {options}\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldCheckbox;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Typography from '@material-ui/core/Typography';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n\t\tmarginBottom: '20px'\n\t},\n\ttitle: {\n\t\tfontSize: 'xx-large'\n\t},\n\tdescription: {\n\t\tfontSize: 'x-large'\n\t},\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h3\" gutterBottom>\n {props.title}\n </Typography>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <Typography variant=\"h4\" gutterBottom>\n {props.description}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","import React, { useState, useEffect } from 'react';\nimport { useParams } from \"react-router-dom\";\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport AddIcon from '@material-ui/icons/Add';\nimport IconButton from '@material-ui/core/IconButton';\nimport ReorderIcon from '@material-ui/icons/Reorder';\nimport RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked';\nimport CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank';\nimport Button from '@material-ui/core/Button';\nimport axios from 'axios';\n\nimport FormFieldText from '../components/fieldsAnswerForm/FormFieldText';\nimport FormFieldSelect from '../components/fieldsAnswerForm/FormFieldSelect';\nimport FormFieldRadio from '../components/fieldsAnswerForm/FormFieldRadio';\nimport FormFieldCheckbox from '../components/fieldsAnswerForm/FormFieldCheckbox';\nimport FormFieldTitle from '../components/fieldsAnswerForm/FormFieldTitle';\n\nimport config from '../config';\n\n\nconst useStyles = makeStyles(theme => ({\n menu: {\n width: theme.spacing(6),\n minheight: theme.spacing(15),\n position: 'fixed',\n top: theme.spacing(10),\n left: '90%',\n padding: theme.spacing(1)\n },\n}));\n\nfunction AnwserForm() {\n const classes = useStyles();\n\n const { id } = useParams();\n\n const [formData, setFormData] = useState(0);\n\n function getForm(id) {\n axios.get(`${config.genformsapi.url}/form/${id}`)\n .then(res => {\n console.log(res);\n console.log(res.data);\n setFormData(res.data);\n });\n\t}\n\t\n\tfunction answerForm() {\n axios.post(`${config.genformsapi.url}/form`)\n .then(res => {\n console.log(res);\n console.log(res.data);\n });\n }\n\n useEffect(() => {\n getForm(id);\n }, []);\n\n return (\n <div>\n <Grid\n container\n direction=\"column\"\n alignItems=\"center\"\n justify=\"center\"\n >\n\n {\n formData ? \n <div>\n <FormFieldTitle title={formData.title} description={formData.description}/>\n {\n formData.inputs.map((x, index) => {\n if(x.type === 0)\n return <FormFieldText question={x.question}/>\n else if(x.type === 4)\n return <FormFieldSelect question={x.question} options={x.sugestions}/>\n else if(x.type === 2)\n return <FormFieldRadio question={x.question} options={x.sugestions}/>\n else if(x.type === 1)\n return <FormFieldCheckbox question={x.question} options={x.sugestions}/>\n })\n } \n </div> : <p>Loading...</p>\n }\n <Button variant=\"contained\" color=\"primary\" onClick={answerForm}>\n Responder\n </Button>\n </Grid>\n </div>\n );\n}\n\nexport default AnwserForm;\n","import React, { Component } from \"react\";\nimport TextField from \"@material-ui/core/TextField\";\n\nfunction FormInput(props) {\n return (\n <TextField\n required\n onChange={props.onUpdate(props.param)}\n style={{ width: \"45%\" }}\n id=\"standart-basic\"\n label={props.label}\n type={\n props.param == (\"password\" || \"password_confirm\") ? \"password\" : \"text\"\n }\n autoComplete=\"off\"\n ></TextField>\n );\n}\nexport default FormInput;\n","import React from \"react\";\nimport Grid from \"@material-ui/core/Grid\";\nimport TextField from \"@material-ui/core/TextField\";\nimport { createMuiTheme, MuiThemeProvider } from \"@material-ui/core\";\nimport IconButton from \"@material-ui/core/IconButton\";\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport KeyboardArrowRightIcon from \"@material-ui/icons/KeyboardArrowRight\";\nimport FormInput from \"../components/fieldsSignUp/FormInput\";\n\nconst useStyles = makeStyles(theme => ({\n register: {\n maxWidth: \"1000px\",\n background: \"#ffffff\",\n boxShadow: \"0 0 3px 0 #35c7fc\",\n borderRadius: \"2px\",\n padding: \"2% 1%\",\n margin: \"0 auto\",\n marginTop: \"9%\"\n },\n custom_strong: {\n fontSize: \"25px\",\n textAlign: \"center\",\n display: \"block\",\n color: \"#46525d\"\n },\n strong_description: {\n fontSize: \"14px\",\n color: \"#c2c6ca\"\n },\n form: {\n marginTop: \"3%\",\n alignItems: \"center\",\n textAlign: \"center\"\n },\n button: {\n type: \"submit\",\n width: \"30%\",\n marginTop: \"4%\",\n background: \"#6ec46c\",\n borderRadius: \"2px\",\n padding: \"10px 20px\",\n fontSize: \"18px\",\n color: \"#ffffff\",\n \"&:hover\": {\n backgroundColor: \"rgb(25, 109, 23)\"\n },\n [\"@media (max-width:550px)\"]: {\n width: \"55%\"\n }\n }\n}));\nexport default function SignUp() {\n const classes = useStyles();\n const [values, setValues] = React.useState({\n name: \"\",\n email: \"\",\n password: \"\",\n password_confirm: \"\"\n });\n const handleChange = prop => event => {\n setValues({ ...values, [prop]: event.target.value });\n };\n function checkPassword() {\n if (values.password != values.password_confirm) {\n alert(\"As senhas não conferem\");\n return false;\n }\n return true;\n }\n function checkName() {\n if (/^[a-zA-Z ]+$/.test(values.name) && values.name.length <= 225) {\n return true;\n }\n alert(\"Nome inválido\");\n return false;\n }\n function checkEmail() {\n if (/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\\.[A-Za-z]+$/.test(values.email)) {\n return true;\n }\n alert(\"E-mail inválido\");\n return false;\n }\n function verifyValues() {\n if (\n values.name &&\n values.email &&\n values.password &&\n values.password_confirm\n ) {\n return true;\n }\n return false;\n }\n function verifyValuesContent() {\n if (checkPassword() && checkName() && checkEmail()) {\n return true;\n }\n return false;\n }\n function submit() {\n if (verifyValues()) {\n if (verifyValuesContent()) {\n // backend integration\n }\n }\n }\n const theme = createMuiTheme({\n overrides: {\n MuiInput: {\n underline: {\n \"&:before\": {\n borderBottom: \"1px solid #35c7fc\"\n },\n \"&:after\": {\n borderBottom: \"1px solid #3f51b5\"\n }\n }\n }\n }\n });\n return (\n <MuiThemeProvider theme={theme}>\n <Grid className={classes.register} justify=\"center\">\n <strong className={classes.custom_strong}>\n Cadastro de Usuário\n <p className={classes.strong_description}>\n Insira as informações abaixo\n </p>\n </strong>\n <form className={classes.form} autocomplete=\"off\">\n <Grid>\n <FormInput\n label=\"Nome Completo\"\n param=\"name\"\n onUpdate={handleChange}\n />\n </Grid>\n <Grid>\n <FormInput label=\"E-mail\" param=\"email\" onUpdate={handleChange} />\n </Grid>\n <Grid>\n <FormInput label=\"Senha\" param=\"password\" onUpdate={handleChange} />\n </Grid>\n <Grid>\n <FormInput\n label=\"Confirmar Senha\"\n param=\"password_confirm\"\n onUpdate={handleChange}\n />\n </Grid>\n <Grid>\n <IconButton\n type=\"submit\"\n size=\"medium\"\n className={classes.button}\n onClick={() => submit()}\n >\n <KeyboardArrowRightIcon />\n Cadastre-se\n </IconButton>\n </Grid>\n </form>\n </Grid>\n </MuiThemeProvider>\n );\n}\n","import React from \"react\";\nimport { HashRouter, Route } from \"react-router-dom\";\n\nimport CreateForm from \"./pages/CreateForm\";\nimport AnswerForm from \"./pages/AnswerForm\";\nimport SignUp from \"./pages/SignUp\";\n\nfunction App() {\n return (\n <HashRouter>\n <Route path=\"/create\" component={CreateForm} />\n <Route path=\"/answer/:id\" component={AnswerForm} />\n <Route path=\"/SignUp\" component={SignUp} />\n </HashRouter>\n );\n}\n\nexport default App;\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.0/8 are considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport function register(config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl, config) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl, {\n headers: { 'Service-Worker': 'script' }\n })\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister();\n });\n }\n}\n","import React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport \"./index.css\";\nimport App from \"./App\";\nimport * as serviceWorker from \"./serviceWorker\";\n\nReactDOM.render(<App />, document.getElementById(\"root\"));\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.register();\n"],"sourceRoot":""} \ No newline at end of file diff --git a/build/static/js/runtime-main.889ad4b6.js b/build/static/js/runtime-main.889ad4b6.js new file mode 100644 index 0000000..f13a1ae --- /dev/null +++ b/build/static/js/runtime-main.889ad4b6.js @@ -0,0 +1,2 @@ +!function(e){function r(r){for(var n,p,l=r[0],a=r[1],f=r[2],c=0,s=[];c<l.length;c++)p=l[c],Object.prototype.hasOwnProperty.call(o,p)&&o[p]&&s.push(o[p][0]),o[p]=0;for(n in a)Object.prototype.hasOwnProperty.call(a,n)&&(e[n]=a[n]);for(i&&i(r);s.length;)s.shift()();return u.push.apply(u,f||[]),t()}function t(){for(var e,r=0;r<u.length;r++){for(var t=u[r],n=!0,l=1;l<t.length;l++){var a=t[l];0!==o[a]&&(n=!1)}n&&(u.splice(r--,1),e=p(p.s=t[0]))}return e}var n={},o={1:0},u=[];function p(r){if(n[r])return n[r].exports;var t=n[r]={i:r,l:!1,exports:{}};return e[r].call(t.exports,t,t.exports,p),t.l=!0,t.exports}p.m=e,p.c=n,p.d=function(e,r,t){p.o(e,r)||Object.defineProperty(e,r,{enumerable:!0,get:t})},p.r=function(e){"undefined"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},p.t=function(e,r){if(1&r&&(e=p(e)),8&r)return e;if(4&r&&"object"===typeof e&&e&&e.__esModule)return e;var t=Object.create(null);if(p.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:e}),2&r&&"string"!=typeof e)for(var n in e)p.d(t,n,function(r){return e[r]}.bind(null,n));return t},p.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return p.d(r,"a",r),r},p.o=function(e,r){return Object.prototype.hasOwnProperty.call(e,r)},p.p="/";var l=this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[],a=l.push.bind(l);l.push=r,l=l.slice();for(var f=0;f<l.length;f++)r(l[f]);var i=a;t()}([]); +//# sourceMappingURL=runtime-main.889ad4b6.js.map \ No newline at end of file diff --git a/build/static/js/runtime-main.889ad4b6.js.map b/build/static/js/runtime-main.889ad4b6.js.map new file mode 100644 index 0000000..62ea654 --- /dev/null +++ b/build/static/js/runtime-main.889ad4b6.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["../webpack/bootstrap"],"names":["webpackJsonpCallback","data","moduleId","chunkId","chunkIds","moreModules","executeModules","i","resolves","length","Object","prototype","hasOwnProperty","call","installedChunks","push","modules","parentJsonpFunction","shift","deferredModules","apply","checkDeferredModules","result","deferredModule","fulfilled","j","depId","splice","__webpack_require__","s","installedModules","1","exports","module","l","m","c","d","name","getter","o","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","p","jsonpArray","this","oldJsonpFunction","slice"],"mappings":"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","file":"static/js/runtime-main.889ad4b6.js","sourcesContent":[" \t// install a JSONP callback for chunk loading\n \tfunction webpackJsonpCallback(data) {\n \t\tvar chunkIds = data[0];\n \t\tvar moreModules = data[1];\n \t\tvar executeModules = data[2];\n\n \t\t// add \"moreModules\" to the modules object,\n \t\t// then flag all \"chunkIds\" as loaded and fire callback\n \t\tvar moduleId, chunkId, i = 0, resolves = [];\n \t\tfor(;i < chunkIds.length; i++) {\n \t\t\tchunkId = chunkIds[i];\n \t\t\tif(Object.prototype.hasOwnProperty.call(installedChunks, chunkId) && installedChunks[chunkId]) {\n \t\t\t\tresolves.push(installedChunks[chunkId][0]);\n \t\t\t}\n \t\t\tinstalledChunks[chunkId] = 0;\n \t\t}\n \t\tfor(moduleId in moreModules) {\n \t\t\tif(Object.prototype.hasOwnProperty.call(moreModules, moduleId)) {\n \t\t\t\tmodules[moduleId] = moreModules[moduleId];\n \t\t\t}\n \t\t}\n \t\tif(parentJsonpFunction) parentJsonpFunction(data);\n\n \t\twhile(resolves.length) {\n \t\t\tresolves.shift()();\n \t\t}\n\n \t\t// add entry modules from loaded chunk to deferred list\n \t\tdeferredModules.push.apply(deferredModules, executeModules || []);\n\n \t\t// run deferred modules when all chunks ready\n \t\treturn checkDeferredModules();\n \t};\n \tfunction checkDeferredModules() {\n \t\tvar result;\n \t\tfor(var i = 0; i < deferredModules.length; i++) {\n \t\t\tvar deferredModule = deferredModules[i];\n \t\t\tvar fulfilled = true;\n \t\t\tfor(var j = 1; j < deferredModule.length; j++) {\n \t\t\t\tvar depId = deferredModule[j];\n \t\t\t\tif(installedChunks[depId] !== 0) fulfilled = false;\n \t\t\t}\n \t\t\tif(fulfilled) {\n \t\t\t\tdeferredModules.splice(i--, 1);\n \t\t\t\tresult = __webpack_require__(__webpack_require__.s = deferredModule[0]);\n \t\t\t}\n \t\t}\n\n \t\treturn result;\n \t}\n\n \t// The module cache\n \tvar installedModules = {};\n\n \t// object to store loaded and loading chunks\n \t// undefined = chunk not loaded, null = chunk preloaded/prefetched\n \t// Promise = chunk loading, 0 = chunk loaded\n \tvar installedChunks = {\n \t\t1: 0\n \t};\n\n \tvar deferredModules = [];\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \tvar jsonpArray = this[\"webpackJsonpmy-app\"] = this[\"webpackJsonpmy-app\"] || [];\n \tvar oldJsonpFunction = jsonpArray.push.bind(jsonpArray);\n \tjsonpArray.push = webpackJsonpCallback;\n \tjsonpArray = jsonpArray.slice();\n \tfor(var i = 0; i < jsonpArray.length; i++) webpackJsonpCallback(jsonpArray[i]);\n \tvar parentJsonpFunction = oldJsonpFunction;\n\n\n \t// run deferred modules from other chunks\n \tcheckDeferredModules();\n"],"sourceRoot":""} \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index c964a0d..0e5b74d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2291,6 +2291,37 @@ "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.0.tgz", "integrity": "sha512-Uvq6hVe90D0B2WEnUqtdgY1bATGz3mw33nH9Y+dmA+w5DHvUmBgkr5rM/KCHpCsiFNRUfokW/szpPPgMK2hm4A==" }, + "axios": { + "version": "0.19.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-0.19.2.tgz", + "integrity": "sha512-fjgm5MvRHLhx+osE2xoekY70AhARk3a6hkN+3Io1jc00jtquGvxYlKlsFUhmUET0V5te6CcZI7lcv2Ym61mjHA==", + "requires": { + "follow-redirects": "1.5.10" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "requires": { + "ms": "2.0.0" + } + }, + "follow-redirects": { + "version": "1.5.10", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.5.10.tgz", + "integrity": "sha512-0V5l4Cizzvqt5D44aTXbFZz+FtyXV1vrDN6qrelxtfYQKW0KO0W2T/hkE8xvGa/540LkZlkaUjO4ailYTFtHVQ==", + "requires": { + "debug": "=3.1.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, "axobject-query": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-2.1.1.tgz", @@ -6465,6 +6496,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", @@ -6595,6 +6631,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", @@ -7567,7 +7616,8 @@ }, "ansi-regex": { "version": "2.1.1", - "bundled": true + "bundled": true, + "optional": true }, "aproba": { "version": "1.2.0", @@ -7604,7 +7654,8 @@ }, "code-point-at": { "version": "1.1.0", - "bundled": true + "bundled": true, + "optional": true }, "concat-map": { "version": "0.0.1", @@ -7613,7 +7664,8 @@ }, "console-control-strings": { "version": "1.1.0", - "bundled": true + "bundled": true, + "optional": true }, "core-util-is": { "version": "1.0.2", @@ -7716,7 +7768,8 @@ }, "inherits": { "version": "2.0.4", - "bundled": true + "bundled": true, + "optional": true }, "ini": { "version": "1.3.5", @@ -7726,6 +7779,7 @@ "is-fullwidth-code-point": { "version": "1.0.0", "bundled": true, + "optional": true, "requires": { "number-is-nan": "^1.0.0" } @@ -7745,11 +7799,13 @@ }, "minimist": { "version": "0.0.8", - "bundled": true + "bundled": true, + "optional": true }, "minipass": { "version": "2.9.0", "bundled": true, + "optional": true, "requires": { "safe-buffer": "^5.1.2", "yallist": "^3.0.0" @@ -7766,6 +7822,7 @@ "mkdirp": { "version": "0.5.1", "bundled": true, + "optional": true, "requires": { "minimist": "0.0.8" } @@ -7846,7 +7903,8 @@ }, "number-is-nan": { "version": "1.0.1", - "bundled": true + "bundled": true, + "optional": true }, "object-assign": { "version": "4.1.1", @@ -7856,6 +7914,7 @@ "once": { "version": "1.4.0", "bundled": true, + "optional": true, "requires": { "wrappy": "1" } @@ -7931,7 +7990,8 @@ }, "safe-buffer": { "version": "5.1.2", - "bundled": true + "bundled": true, + "optional": true }, "safer-buffer": { "version": "2.1.2", @@ -7961,6 +8021,7 @@ "string-width": { "version": "1.0.2", "bundled": true, + "optional": true, "requires": { "code-point-at": "^1.0.0", "is-fullwidth-code-point": "^1.0.0", @@ -7978,6 +8039,7 @@ "strip-ansi": { "version": "3.0.1", "bundled": true, + "optional": true, "requires": { "ansi-regex": "^2.0.0" } @@ -8016,11 +8078,13 @@ }, "wrappy": { "version": "1.0.2", - "bundled": true + "bundled": true, + "optional": true }, "yallist": { "version": "3.1.1", - "bundled": true + "bundled": true, + "optional": true } } } @@ -9037,6 +9101,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.8.0", "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.8.0.tgz", @@ -11493,6 +11567,60 @@ "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": { + "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" + } + }, + "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-router-dom": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-5.1.2.tgz", + "integrity": "sha512-7BPHAaIwWpZS074UKaw1FjVdZBSVWEk8IuDXdB+OkLb8vd/WRQIpA4ag9WQk61aEfQs47wHyjWUoUGGZxpQXew==", + "requires": { + "@babel/runtime": "^7.1.2", + "history": "^4.9.0", + "loose-envify": "^1.3.1", + "prop-types": "^15.6.2", + "react-router": "5.1.2", + "tiny-invariant": "^1.0.2", + "tiny-warning": "^1.0.0" + } + }, "react-scripts": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/react-scripts/-/react-scripts-3.3.0.tgz", @@ -11920,6 +12048,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", @@ -13279,6 +13412,11 @@ "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", @@ -13684,6 +13822,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", diff --git a/package.json b/package.json index b9d1dac..ac7cf9b 100644 --- a/package.json +++ b/package.json @@ -8,9 +8,11 @@ "@testing-library/jest-dom": "^4.2.4", "@testing-library/react": "^9.4.0", "@testing-library/user-event": "^7.2.1", + "axios": "^0.19.2", "material-ui": "^0.20.2", "react": "^16.12.0", "react-dom": "^16.12.0", + "react-router-dom": "^5.1.2", "react-scripts": "3.3.0" }, "scripts": { diff --git a/src/App.js b/src/App.js index c84cf5e..90dd131 100644 --- a/src/App.js +++ b/src/App.js @@ -5,6 +5,7 @@ import CreateForm from "./pages/CreateForm"; import AnswerForm from "./pages/AnswerForm"; import Header from "./components/header/header"; import Footer from "./components/footer/footer"; +import SignUp from "./pages/SignUp"; function App() { return ( @@ -12,6 +13,7 @@ function App() { <Header /> <Route path="/create" component={CreateForm} /> <Route path="/answer/:id" component={AnswerForm} /> + <Route path="/SignUp" component={SignUp} /> </HashRouter> ); } diff --git a/src/api.jsx b/src/api.jsx new file mode 100644 index 0000000..169f14e --- /dev/null +++ b/src/api.jsx @@ -0,0 +1,8 @@ +import axios from 'axios'; + +const api = axios.create({ + baseURL: "http://localhost:3333", + responseType: "json" +}) + +export default api; \ No newline at end of file diff --git a/src/components/fieldsSignUp/FormInput.jsx b/src/components/fieldsSignUp/FormInput.jsx new file mode 100644 index 0000000..972941d --- /dev/null +++ b/src/components/fieldsSignUp/FormInput.jsx @@ -0,0 +1,28 @@ +import React from "react"; +import TextField from "@material-ui/core/TextField"; + +function FormInput(props) { + return ( + <TextField + required + error={props.error} + id="validation-input" + onChange={props.onUpdate(props.param)} + style={{ width: "45%" }} + id={ + props.param === "password" || props.param === "password_confirm" + ? "standart-password-input" + : "standart-basic" + } + label={props.label} + type={ + props.param === "password" || props.param === "password_confirm" + ? "password" + : "text" + } + autoComplete="off" + onFocusOut={props.verify} + ></TextField> + ); +} +export default FormInput; diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 1ffafe7..4f5369c 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -3,33 +3,8 @@ import Grid from "@material-ui/core/Grid"; import logo from "./header_imgs/imgsimmc-01.png"; import { makeStyles } from "@material-ui/core"; import MenuListComposition from "./header_components/MenuList"; -import { Avatar } from "@material-ui/core"; - -import MenuItem from "@material-ui/core/MenuItem"; -import MenuList from "@material-ui/core/MenuList"; -import Button from "@material-ui/core/Button"; -import Popper from "@material-ui/core/Popper"; -import Grow from "@material-ui/core/Grow"; -import Paper from "@material-ui/core/Paper"; -import ClickAwayListener from "@material-ui/core/ClickAwayListener"; const useStyles = makeStyles(theme => ({ - barraBrasil: { - background: "#7F7F7F", - height: "20px", - padding: "0 0 0 10px", - display: "block" - }, - menuBarraTemp: { - listStyle: "none" - }, - menuBarraTempInterno: { - display: "inline", - float: "left", - paddingRight: "10px", - marginRight: "10px", - borderRight: "1px solid #EDEDED" - }, header: { background: "#05a5dd", width: "auto", @@ -133,7 +108,7 @@ export default function Header() { </Grid> <Grid container item xs={6} sm={6} md={4} justify="center"> <a - href="https://google.com.br" + href="https://google.com.br" // mudar para a main page quando estiver feita title="Ir para a página inicial do Gerenciador de Formulários" className={classes.link} > diff --git a/src/components/header/header_components/MenuList.jsx b/src/components/header/header_components/MenuList.jsx index 7c8613e..4134513 100644 --- a/src/components/header/header_components/MenuList.jsx +++ b/src/components/header/header_components/MenuList.jsx @@ -30,7 +30,8 @@ const useStyles = makeStyles(theme => ({ } }, menuList: { - alignItems: "flex-start" + alignItems: "flex-start", + color: "grey" } })); @@ -73,6 +74,7 @@ function MenuListComposition(props) { return ( <div> <Button + id="notWhiteButton" ref={anchorRef} aria-controls={open ? "menu-list-grow" : undefined} aria-haspopup="true" diff --git a/src/components/header/logo/imgsimmc-01.png b/src/components/header/logo/imgsimmc-01.png new file mode 100644 index 0000000000000000000000000000000000000000..c549ed8b629749b0ca98d74230f7b1edf7928a15 GIT binary patch literal 217087 zcmXtf1yq#J|Ml+DjWp6oE8UGtcXx*%Aq^7JNH<G&HwcI{EG;eFE#0wzl<)fe{oixg z!*jNtotZnIxc5$^nu;tI`fGFm0DvVgC#3-ZfTaFCP?6!!+-(XQ!2h8+%jvrT02p}x z9>D1}|0e)|8XzzAUdwCwq*Fh^Sl5&O$3*Mh_@6K(D+X(7ptCh0KCN_0rNRgB8Furm zr#q*Q+C9#Jb7(iY`qOo|Skx<Q!Cq78zf0z_3A^9KA0%l~SLc7N;T7n}vsCK63*<({ zl~c<2DR@2pS!jsrZvAdT)G6-~@0|`|c;g$njxXmEeM`sHop;Mh3TXE8)%uOr<C#r$ z4KBWD|GVb3C&K;jN#1|2N?46&{&&%64NUyMi}7XMWuyPz&NpBHn82Wc3WnougDf#) zH~}BgXeJo*Xi5<GJCMxuH{=YUJtQFzE@L8agu7u;z|8K9hroW(q=o{=V66i4oeX#T z{oUJ``pz2xppi-dG1zD;`+UjJ7Jk!YPQwq@@LMeuLx}OHU1|Q<p+Pl3EGBYLDRho} zKn!M!{9o-f#ctI!<p9O*g=X2BtmY2TNPe8<tQfDvE&uQa{CiV=?~e|18vRiH`hUYZ z9ktni#VtaNH@FK1;hE$^!(W=QwWhn76D*eFuuV#XsJ}*L0xV|RSg19F;(fB2S0I$( zZC&VR5X+~m-;blio@@w<mNCZl@sR)jjc#_}2#oA&dgfh?-rMiRkWmKQq@ka`gNV=p z71YCsLRw~p!K@S!<iA^(Zso9s)c57;wOEQuYKz#){Oi7%=>kt^tW$IV)q2*$nY<Vg z@Kw02YAT_#*%t}C))=|YzMk=Zr%D+p_dXQONXar*3sAttBSg(fLDi(vCW@YYU^WUp zQ$q3-nvn(;+EPaf)U5z&0WC?txs8F}EU5JD=igB`z$cO&)xQ|Bk3YCCvfaPOFmRzJ z$U6fzAP`Vr&<#q&4s)kAUoP$Pqj;wt$bd6efvNS7gMNbTv&taB7fV{?nq0c*kDdfD zQVC2#lK=m>2x$t%-51;^{<lJVWf^IW+~ZUGoDALo85DgMv!4j6GZLTyu8fIzi;9~K z_poF0S|sgD&jgXOaNZnc#oPKkK+z~TVl?~uZG@!rKPU$NghP??F+^ZW@Izqgb#~kE zROOhO$>NE*#MF1#O?H8ZnPt#QP|%7t^X@L)m?tUUEF8T^QuEb*89+5qFdN69%5gq} zN2YfxKTe;V8n(d)Fq1QQ_ph3n1PT_4x$c##OS#+lD2>q1rVJw5?7^4cK{={@*cssH zFz2;XL=xj4fd5;BM_R+T6;Ex{p<b_`hm-Q#PHgyv2#K~S7T%jd4=PpjKII-bAb0Fu zfcmBsPJ#Lmw=xFvIXO<lU*>&xLxn$Wc-D<HeE*yKQ#bp4U<XsESE5_jlPw8irQIlE zq5HQ&A#F|OHrurj$PZP^{3~)e$Y$LN749nBN|Q2_1N+_AaWJGxIVBl9WyMQHHf=4C zaiAu~DH>f9f&mmRy+7c)@!!gxE{uRWQ8z*RPXpgUV-3vRo_xDdb524B^;1cu%|yGm z;2;sdEEMJG2@ISgZ%d7lXZSEx^yo$@;k*3bp6-VKUcG!cg3tHRo-&eL$^^Yx<QMxv z86!|-Y=}YxpP&WB{cld~Qp<ZD_%sT5$Bg#TDQA%gYO18H=Z0F$VkeP1TKHp+psHu8 z3niBabyLxsH!YaE#sA-mnu1W<`bi95AkU3*o*^3AVjq!oOuU$J@+&swJZ@23MugPV zx{GEjsZt52>P#s=%B88s8mQXXihU~lPB}eh2`LQ{fw^@kM{?jL$h{{<pr$ElJJn)G z!?)YKY;Bx6Kiax4=y<^4_cZmr9y~h^xL=cH6@Wt?L~B1UMu7@)mPf76CJy7|#P@C$ zEOpk)oe@Lbu|QX*nANA^8M6Xmp#afvW>#W^HbO#CuR{r8z7+_iB7t&2auf->yFn$7 zSVgFP5>O0!WdBeOJXGn9>QO-{P@n*TwF71ffTP@o9Vo{PB~|s0{oB2ObMf-br^EMX zhN+vT%4aGZ(DvuyvNZ}x_Ww2wDWW{HDMTYKom#W(wj=JebVJKJ2>qJ8xPlp}OUZ6@ zW@J&hdh~mD#c|?LFnMvCN;g}nz3k~7wV=d9Td93Iikb3|mzr&8?2qtq_+M@OEw$7J z#w#g2bvo)|pEUtGMSuz@D2b8rkLp)hP6>;ma{&O_AOJ0lI_B3k7!yH4B46EQim5$< zt`@w_i`?<DVJz^e2M&XOQ9n$l7qJu3Ob`b`9_sgtV(-0ygBlIP$e%qlT#bpPTaHJV z0;yCY^o3f=7uTX{$NbY|pUg_1%tA;4<}a|nr6zFdx6^P&j2K4w=;iO`;Yr#*)$G7c z7N{xk;(^NlPCYB((|@bdWpP`GyN$R1)Xu=b;L*ZogWQU#l&dbtUFybPuk1cCwx3py z4+hIc!k%fwjE;Bqe2B9soDeNZ5Xgy8n$Y7y8b*6Elw1R}pvi2LJyt}BB@!RM%d`b> zzT^TUXwldSE|8$4k`+*OPp@7Ec`QmGz@IK~;Uzr4=hj15O7Fio!(JiJJgLac4s7Wc zbkaDHHJM94gEH^Qpx_XE<E$5e;5XL@k716zPj57pJ&r?pl>Fk=9g<QbcKi6s$AshI z^q11BA)B}9S<Hn-o8`Jj5F_jfJ-ml$KtU2a9Zj-aMwgcBSaxiYJ=*Hh@gJ{q6S6#q zTXi<)cX@W(6_zk73J*WvV3LgqI>+EG>7qTJ*Xe9Q)SO_$Z3@SN3CP~m)t(+4$u7^F zrfpL$JT_ae5y#FR&k)ZmPf>~<HT!{?x+HC06H5CmRyXt1*Fd4=rSjoJxn)^g2ndZK zU&c>Wd$8p3SK0zFuFDu5Gb5C2jw3hsKKFCC#<4fenFG$nr2#RO_(3m@rHoDKiABA7 zZ$Soa9FL-&L+TWha5=%6y7VH?T4f02<~Tr+nbXk2#l{x^a2DvBvL+oeC<&3n=K+4f zf!-BEbV)7i0A3V7&}#lmUXK<TxZ5I@C-j4h(b?D5M`|AX79gUdJFPQ0%8-0v3z%>6 z&NOh4$E-luCpmcnV<@Bdi%)l>NVq+Sg5leT5yt5rR3tj)Kn~VP``2%zcO@!@DiOf= z2UxU0WXGZ%9&W@qx1s>@+8wjnz3tVl*Ik~4K?5@K2-(R1-G%ql@ALi7-5I#alB`I= zK<YjwfG3VjRKp`^s@ZC438aoC|A0`>!{I-$-?la@YK)}K&XaZ@oUA~!6u)M9NaQzw zj~+_xm@5k^Bi|S5;h?9h(Fm_GS9&HKy@h2nCGgcuE82`*T?LdLvQ$82yC;NN)PYDI z-Q}LIy`dO@4(eW6d*cqb=2+Md6z4df;eiF!*~|NS(lH46tb!vOhJ3ws>6f?Y2}e-T zb^q*Uiob6G0!2PNF#W=_s-RW}1!i{F33gCRCZK5HB*F4@)ME7?7~GRJ*yuy9DFbzZ z?=;P^38fAyCo5*AmOviDZEqB8&MWanKjPi+@X6*?V9+pRryY&WxoKt~JnJ!qNg??O z;cB>jEw|6lW7OWOI~#ImWi~6_w?16a><jX~i)@=<2$O$SM(SrEsuf1P*s>#bsyo>^ zy9H=~%5bzVVjEdS+Gl&GtkGZ%7~$M+-tc`rq|>KGZ#fuZmU?%~gy&Zz(9Ptld~>Z` zSK`xwm~Wh_(Zy1-iVyCf4b^LSllVVWz?P5zb&AYRXf$1EV`jsy9-SI7=sC)xYw|f? z+n#T@cfVaFeb(NuZB!N#_;r^tw5*1iiY>!rR`NGT=snAKYYWxcW62zLBv83XF2R9X zAY_DCqg(f`AUEWt+5eg85STMC^WF_trlnO7y3)L&w{pGZjG~CaeScfz=5?lo9~)(9 z<?l`uZ^3r`@KararBiq5u@}1Nm7fNFoi}uot&9l)lJJvSZtP@lfG*l_w}UBC|EqqN z>wbpfromxe3~>V7*9tY3k$)BYc}!Czaw&lyQY5T#^tehK|C67KlcF@6-mhEBKVc-S z0vZp}At>Ump;i3w@y5RVOz{J)mNS^58N0CjBA2;N76p;z+X#Zc7QPO;SIG+Mo5*%y zO0kxW9+?#sK(=x9W>)+U=W6ZXK7C|4H3`P^j&l2o@CPQo$uE8aP{H&qQk}l!QklLZ zVQam!_UvnZ+<ju>hBqlq?3qjCwDzV1_V65I5o5faoyYgprJS5BXIQ@bIvCZM9lQ~} z`4!Yh4aP-BjCB2$Q13a4dJ`iRoV<t1HSa1vnvzT<``4y&<Quw)m4Ql*qieO;J9?;B zZzkPJ3a*))_>ev|mmqTL?Kh2{P-M&<3rDnYZs&dj9_h3qC~4&f;wD<zn%@ZpH2C<^ zg0_`3?@|(K!rIH94~~xj!JslNf1(uA;>LFj1=7j0;I>sC--x{R)xOgjO6s6wH$r%5 z+&lq)qMfavYW9zvv;0|Q#KXHg7c|^2ws=2Guq^zZBF~m9|ID!aE|c{QwsAM+CNE9@ z+iW+(oc|?ze|2iQP_Ib07rbqa&B!OBoWy)Q+npYAR9c`o-T@YZ!)L$hQ}4xNl*MDD z15C-AXNf7Bsq9*oP+2DA_`kVE0Ud0NsbuVVYbZT&AN+Sl%&k(QnZvW#G+lQzE)14> z9GU|A#__QE6+dcYFcAwFi6Of_H1W}=ALm^sH7W0&FyJPZ)fDe9su6yyye?g&)+9-> z7!ufr-|EZv<$+ijB_Oh>hO6uH=evn_T8#5E_}$m;S=g1b(z~MSX1s&Pcyd7=8cQ-2 zshT7ET6*zqVuEeTWhIae)%7)9j)`k{r}nR;q3lfsbYyEaB_Mpa<tWY0g5ZTv_c9)f zuIimzw3C_RhF<idn)eSzmf??d1_$yRAqaqhZ;gT^EQ-0RCEwHr5v!c^&3e)x3?i0R zR|J>b6SE_B)W)CILjA&b9*||1T%60*``?7y3kVwaf{U_8rPLyi?ABwkqm*7twq*ct zny}XN_ah~bhNQJARP6b(mQn76yzU$sDJ3wlRmdwXYzv|aM`NpT2lCY)XX$auxxRSl z6Pg{)xx`$iXAs~80``#rnBE3PrD#Y^;zwey-7_-*U3pJ;eW8K|^^)2D#fvOZXfcEx zq2(ibce=u~wrnZ(#G3iL^v_P8BZOBFs?WViIi{J2)!Bv1i6{uj<G@!sa^I}Na(oc! z@+`H@nLm)vE2JiBc%ViNenW)*7ML9bFzn#2GP$QR;o6XS$BC<kF3PNsQzdWf4A~E& z5TcA*RfEZ;pd7ddzQEgXnzlY%KU9Z1gcF$L>YArZwRTVB5?9=W4wp)%>u;1-K4bW1 zBIT7l15dx@nbWmOV81dSvfAq8{g}gYiMQ7$a7Ecc01=;-u)3V`qTj9!T=5p#*tBsO zWho{5*9RvP_vyCl8Ud=a9@nme<=0;6Vy?qtZ0Iy>t`n>r4gb~T5P0H;Pk`G5`(EUI z#v<Yzb8!gl7Y-*XVr`9wGfaipuv6eq(}61id6-XY=pUI^;dV%43yL3gj3F4<QEaLV z^LQFR)oCjUX#XhrP4cL53H{_0u(;&nLUOQU{*j;{mT;vndQSI5qYWJzOp(0YP?C1s znbZK_MbN?H!<u=-vwuWQTzu>VZu=S_M8d*tqtAM%uW61lSIA^YGpIk&8f}-B3g(mF z`?j>pzSPP-XKo4@$Ncvvoxw*1nKG~j1dlf*ywu5lQ?{jPX-H)ffm+SkNW{Y(dB|XQ z>~=1Sb>vE7=sR-n!-J67SlF8kP_3m_f6B2u&<MR>ZDB$yBHu(+)S;5qS6#t7k@HrP zrhhcs4I}2ikPM<3TpR_k?eT7F+05%-3d#$apoIwwOFo_KiOsK=a1{}k6Htiw7l$Q> zR|>4YE6{L<(rmSn*K%Wf4Xo@K%q3bLNSwb80wJxExXJC?yNV=lCa4}toa3(jPL5)f zn+=t!GJw|WQ^#yuUFDcWsLt=C;;$7*K!f5bZ=CI`;&+p=;Grtt#FKkFTx&gIq&7Xf zH5cHQfPHh+RJ_>R(SI(oSsEVbu2yQW5%2u`o>+Jd7ip-c;t$^I6i~)&H3*#Czz@sG zCHYio#={(3wIQwUiix`^zc{!1?mAlqgY0NL7KU5mA2-W)W4Ta_495k#0&_sRQpCIe z;L%i<%?k9&;Pgy%MJ0F(VRR^enI{dq_o|7$JOAwRng49(w-9FhyZQR>Y6Fq2=+^dM zl_rLMJMbUhP{^_-Q-#pLd=)eqJOS=x$Se*#Vnj+et%c36+C`Y@$r)LLCXap<f1=g6 z`niSah~8lomeCNsWCx7p8cNh5trC`8U8gW>CWc-IRect^kc=#gTW~4X2kpC4Dwyo1 zRiG=`@G;D#(zlAT^jm@oS$+=NPg$^xsxBO2f>+l_sR{5Jn?Si@Q&5K*voY_&%(Fch zm^-LQ1j(&)Kii*OfXq#5E-9poDlRoLwBK=I=*W}Ggrq>7)dF6l)|!A@p|R$+eim2E zz1Fi$ZA>Nbruv=+@IP3bzU@J6Du&e2UHwIQEmuLx$GZ|2Dlv(F@7xs9>~v~gMjR|C z(Rs4H`UPt;$9CJfk!RU|U1^1&fdj~+334#O*D*d&HC3@;WpWWQRtZ#iJ-<YD^o2Zp zN3JS(Kn5+IvUa=E*BIUeMCatfo38$qw~r*quX2TFdK0a^5qsS~y@ru1ZINqA>S^Yt z`(w{c(AS|DnRts4_LAjfA^vEmeDFsMEYN1%90L=k6k1k0a07Xx{uC3mUSGwQA6M*q z3#xROOt}Px(l4JqTu1^Z0=tN}lbiTn`c~{04<GchS$EVrLoMA1vjw#J96BQmhNWvx z3bi(!zwaklK$WJEW?PRPK3;7|1Bk!kiYxiNTCU{zSLZ%X>tjF_hp884bEI=A(UD}z zyR`gFH$&#IYu6nuo2fv6Jr*|q<JEVRqDGP>2TBeb#mirQAv*e9ltBYCkSy@E4H&{} z8s!Px@`a=+s1InEI&X|cyX=Ms{>&(o=dte8q=*_B9`{Dm!joLjiPEdaCfX4sG2oNZ zyF~x<t6m*%18D+@eCVK+Trz1>Qu!?lLH;s41)qf->c9gylVCEIzH;R3Y*)p%0)Nq2 zUupVmO)gM|Jwm<-Ghp)o6Xf6=nF7P!Bl~b~9-31de|L6f?&pN+|JIrmWA%MKlyiY; zD{=?x%XK7@h?_N0jX~m<AMO`<X@84V5pS+F*5jiACWseNkSoIf!^x-xJ54Q<?Ow|9 zo;FH`EAzBnCN*BmOMY}!^WC?(NQ#ANFsZ5V6tpPZzC3kR-o`xt0Y=(gkr`$Yq$FQa zi9hu|RxE4&E^VP4;wr%qDABZ$ABbNpH3d|mtPFGuQwZAWYhrtl4ElV2(q|5J%E>}n zXsgluqgHBN>s@l`ogWU$Y~yOi&c1fFQc^aAT`y9FE*?E3XcX$WI)5w;3_ezxBPz@# zuGA&rCC!I6VG}T?I5E?=^`TO2Yz#HQ#A??+?S!=ZIzxXkaT=K}4Sw$OM6`(?qmBuD z?uzds4&=mU?w#t=`Rvouy*4xsV_WyK!HTDF+UB2_*t*2WYQRGCh`+J7wE(~hBl@RZ zpZ_Hq?m?4!$%=oe*N;Y7!8?-kwgGbWow?XKVU?zmTo{3tq^~BHa=m?FP-h5bA6sQ2 z<?=)WUzM_o%=WQkNst$M?AK7rDeGMr1WC?st0lW)jcMicHr``qV5_4uLJit!+)c*< z^*!FTFP=Sk`F@~koC8fz*7j%{Xr=o&Rdi=b;lhwxONoeP8{hNx&gF4a@MHvLRLuB& zCb0<ElvFVLq0_&r<U-e&kS1vjG9_rVoJPo;zk4UTQ9xzhd~9B|v-P~v?)8{V@x{3; z7N!09o&*U>zWHX5!;pQ;xe7B4fqsEgtj|}JO1!%@r1`7F&a?8<8Mo|3`y~0G<<RSY z4SaMh=dc(;L!^BHg5=SfLakG>+Y5p?0sGq0S@+Y=t&D|}1G|3(m?=Sf0tcA=0KLcO zz`~#<rqXOG$AFHmc6Dj!=nOXo2v5ado~;n}iR|ex@*7F>N=@}m2q9=ByKw#~R)krZ zT-51JoltDs3&Sf#g_IV3&kL9)*3C0+UbXBZ72<uC{YpA>yMUN(hO;XJz!H65{S$Aw zJtwQFG}34(E~H}Pb;@QfWe9OUs|g_Az@58QlAyfQr%*j#(TO~ZG2vq+ROxhQj_+l= zM!Unq5`TpPCkPO%7AU-Aug@aD1dkrWxv`Hva?D(v6UDeuQi!sXIG1^~wcCsfe3zzT zZY1n4x6Ik18vG5N1a2}w;U*i30Zf+XE0r{({kgx#Lw9UzYm^;N;TwK84HR}YaDm{| z&9<5EQPGB|5?-*CbF)Ai)hcc~dU7*GOE>-$K-Y4Be9J)E9yK;+5#Q2Cx9ECTjsc$Z zY?j^cO!H>TN^1~ZOCjC0j7&h!cO87KH@ceZDQI4YL&-YR6t<9yrzL#{53s{`Q3ua| zVFtcQrYZ^LIx|BcmYVxuUY(Lqe3;ExKf_`7;YkcLq=K@YN&%h|oVB9Jo02dl4*7_@ z&1A%h6s!Y%WUjAV9jiSq_l6Ab4`H8-+MC03;`qB%)E>4zuuN`0(GFUOz8m~Q0w_tb z%|@U#;qPL=doI4)Fg4a6@@I!<_09+<QO<aSr6(2jcLpXCgh)Js`)0JkeZaI)V!-9# z-<QD=oWH}G*X-i1Ue*I~UH|ym+g7+nGX>LW>NoMZY_%-%w|p2|(;BuM>EsXuh}u{b zoo?;JGs*p{5u`ZA__>SO`iv<|lk-7GuFfw@vvSEJ`co(#=p5=Q>xg!x^bk#Mm(Jb@ zyc!-L8w<NEidPJ0c6!z3)EnNL4%|+_{r!6??hnM1Y`mMeC%<^8<$z+zEP^QjWn)Er zrlP>F71Q#nU{(E}-#ep6NsWfSP(IYB6ErH1EcyKDs0cS|r`qgm_q{*<Ot~p;>=!se zO~NTO^Nxsr!L<ZW4f0BH-%_n)dG7@`;AP&g+QF0a0{rE87-@`uWYDPF_AcOcpu*(J zuu2#k`YT2g#+dJLYB}Mbtn^HK8_?nMDD7+n+}W^^NVfQ@bP^)8xG$)Q{;T-7`qa0j zbxIOf{@u9lWe($>I&+&<NxZ>p6=pomK$%I8pU2W4EVz|6<KRiooI80(J6=>&93O#a zoJL*Q02WnkqcVTlUr!2vI<iAgYk<f>JX}sJ_R@Z3lzFd()a$a)4i2c3ePpyGvQZF~ zYq%KBvjWX5rzBzC8ibYF&Nck%$^k{qI9%^4L+qI8UoLl)pYr~03B7EeYTtxy(S6(e zGTY162Z-gzYfgPd0=qTK4xxEbWy#bj`XEKFpxEqd*%U(cGKclFyHZtT4>p!fehPWO z);QPQdrrjT+NzRreKPxqPSeF6s`uU~<$r30|L%|PZNe>>apFMd*IcE`$`bGME=%JK zCm-{FzrZ?Zs2!{7f1K|O`rw!sc6_m}kIK-<CVPK~c?giL+vB1@DY*vM6Ea*Brm1O4 z41O2e)new88n@8^em&Exh!XU8oQ3I9+^j0SQoPoljV1@n=&g}$7R_P%m`H)BG<{Lf zQIGPqKS0afN?pg@zZL6VR_x2>G(Q-<UJ^vZYtgJxWHM8t2=_NtPWh1S=8huva#Hhn zzti0w`&rj>iV8WR@Z+oj!?RNo;cEnn@;iDUKYpP69l@7r%lr2c!daqE1CwVvs{XFT zkMh3cGr|Sp(GQ6IbViw9g4AcAzw@X2JtzLy0s=sr4G`C1?8*N&$=mwkKS!*Cix`;i zcIcGk2UsN3ZKf)BgyoWdUB-~N{Fv`~UIPkP3bgC>9R7(?FIMpYLz3rnUeU9pIZC4F zlrFIiD5(w4&LGmljw>6P2!5)^tJm>x@9rGbkh<?NJU_}chPs8@Gqt(E=7jH-;VHLO zbX1A(gE!i-mN16qfSCyfW^x~|M{(I1)z@$)h6%0ty72CDToNQ751A5f)Qe>MmHPm; zjebM^AFt5<RIG1>gw|3HinTSz2i)a3ZBf;J8YmD3eaT9fI5IhkwW&DnBVk}*0!I*& zST>tUe*ABcqdYYINPxE*Bj@qi#U!y$fuZ&70x7yh(K8hY`IIkH_^fYe>g&&Ya1f2c zw|*ND)<g+&Uh7gMzZNUFv1URZDy}NZrAk?>3KmQ8%fFJnk~*2*P+n&9i5UDID}o{o zBtkbT(RnNEwXH`1ufY%l$A5@dLNf=`EB<iKULH(?ylKN9Jb1oJ;(#!3oMT7yY>Dx+ zTNogjZAbSNuKpAd^+1gPzS`B*9;&}<=w}YF#{GhCV7eK}O}WG{wy$Ga$ra{&gQ%tQ zqSjv%+ZqYErO(&ag%c8N*F`z$p%^sNv!yNOoW+MZ&t13{^rVgdsXxm$)~q!B$8e4c zkWH!WS3F)XB_yCcad8u*;vvF7B;_Q``D#7^Pq>rXb`d=g2t%i8V#&`Ym7c8nyI23- zTUoH;lls2$E{1vxnul@uc{xi}NT_*vgN*{+w7UryRRB|f)38TLaK0{*HV9rEnkQ@+ zNPhP6ek{=Y-eF%COxwAwxWSH;u1%fwwvR)IpG4AI=#7+UNU5*=2rxRde{GzSt-Co6 z=d5Wfe0xg*H@<3MI*L;+kP+*Q#HPqO)7J3t^Wojm#$f<h&Zx6BmVaHpPlcZ&SQY<G z>4uXi&_CNu9PE%lJKAE4hgT-J?<B`;nx^sNgv0S)rO;h&4EhGzY{$o5NGPt_Up|nZ z(prz6KtF7>n+tj<WPJYn|GfYO{UOgZ9URC~FjwGiaI#A<14q$|3O%e+DFuz=K!|tt z$Lu)_(I8nS4%?~}_MlOh6KOj&7kI6(aUGaGp$9=HZ)~!l9Yb~a?sszAVHBRGE2I)+ z!7?TXd=o|U>n#$@w;JIM7mqc-eAc4~ob}MeVXK?5C;>BYXcm3?vr^@Cy-bAce?!`} ze#K4k4o-gr{M|x+*-6npx$84h*CISnvXquRFT%D$t5*b_`16zYu`O+_{!?Bl{nH_? z@(SLh&?-5FL&hs>62(fj(5b}Vu#Cd&)9<)=08GiC97hfdI-+A~0g>+AFv{M1avVZh z%^czsQ%lz*ACO>EOznh{;7A8L=Lp*IA3^VTkYR7C;z>BO<u(U;okCmudy(q?0Q*f6 zspfk&Bq4V`X)OE9q?5VR{jYp5XIhv@rt4R(Q7#DyYUSTZB;I~ZxK)m(PNDW*cMO1y z8W`KlQ`ud8D}TC~wT4+jaLAO6WFZfNtWjMGd3=K99+Th#1gS7kwk;N-K8@eXe<%8M zFy7wMw4PIbRaBcc0ony!LsH^K*BCP1g}nYUEq<vDNCUoGdbR#<{MdGIk*1Dg(Bv1z zP_ZRxS}v-5xI(#6rY-mJjj){>COC3}I+O}sD++thT7gL@u0BfP1F{nOl+RfdnpgQ& zeh8%bcuN=^QGLJKG)+XA0cKkHT@c4g<Bu`}pcJ8XUg=e=U3T*vX{bEo{X1bktlt`I z%i6ffX-_I1(Rq7n9z;nN2r#?8@A7s&$RNDLUKzDku?N8eAHC8fpH5yZK(&MWWiyq7 zS&?YyFZU4l{K63WhV7X6G(vDpD5*9sq}B#xY?qtZcJ4)<py&OoNBC{~qKXtPOkT=F z5hq8QyQw5HK2o_s4jKw-0V$aRoTX7OlPLE76@ILfsY#@>I0F01ysHx0e6b7;5=qGt zqj$$jNZQD%^;8Vu2S~4k`fw8y;Cu|vTQ;Nc<Yjtq8gzWrB0SRyjtnu}EQKu(K1op- z(FIwYx{8IV;xg`7-sym{%3ZBrnax-*FME0v?h*m5rR!dGrXejyRbZ^`9i8g=FrAq^ zy}>bI*sPycz(Nq0?yaf2Ad7UGh)xu5VdVhRyh<nI5$w;OanYyK$K$-V!ZB1S!O4!s zyb@{fws?1U+-Dt6dFvF5o~ugb!{JwNHr_mwP7$8Xtbas9a9pDO*EVN4yZ>8QfY<xa z*jg`=A|E-ewAN5@opGs?_B)0%!~x>NR4f9R(rE|@R>T(_99SM-+Dwwfpc>BuN--KH zf4R^_D)MDNZ?d?7fyy59Il3A(d5z2VY%>h+TknMK6&Kir$mxfG)SI#{j>LowGag^d zIjkw$`8{xFk|4|liuf0Nz|lzGfk9Q%VRNRo@5Kln6D*3Q{IMlx(V6?d|IpN~t@Isv z;;2jQV}GdZf^ySTV;UBRwl-927=1|naTn3Pp2Zu<wSi%^#Poscyyj#x$FQC5TS4y} zK}2a@WO^O`J4Z%~5zd+OpouRE%%%w%CW#sbKYqRjthDXCb<!At3wZX~*ThUVxm4SU zxUQJtp#-ft?G<#o_#dZ%@;bk;Pzy;Wg=31eHaD}C>2QyaHMdZ62uDUu3z2O+_*9$B zIAFzv2Ehl|z2C9Wza1`oF&M})N&GM^Q3%j^@ar*W5~#5ICc#9v1QV;%XQyXOcsc$G z5@io2mU7u=W#)eFD^_YAiuh80+2B)^BEM%h=3aRWe0TOZ5O_<iuon+%e@1O?eke~t zccH`}p`$~`mMwv**IiTqCfqk>Hy%ww@6J!QCaj$hJ!hTM(A8$uh*BPtLAi_BmyO9c zyfbMzdb&$PQeufe)(?b%t7|8gpUUFD%Gln-sUQ^3E+!!H4!7YI`AQpW`r(y{-wg{X z1H=Ir+vBk>C5_Q@gvW&cYWunGiZS)N03PlAvJix|jCkw5<>FY*Ho{<Zt#T9Xhrkly zfJ)&%A4T@-XDkq@^M$(i0g{$i-_dY0uae-ES2I!po;b71kS$be{J3!B&_kkRBda6s z%BReAB=WMjH^v~ZO=Y&eVxd2t&ZiIeF$9of9@=RVSW67WKq|I!$wE_0ado{3C=Dk6 zR^O+q7XM&~zCH6vvVm?(FPIy90)Pe=(Cb0h&p9+<{-Lf@KuZ^S5jr(z3aw~(a}*-e z6zBsdk@}~qiF&AqDP6n)75tbNcT}I^08=)$m@df+Jnx^<KHzww+;5(V`Clgr^4OO| z+5{gV37i^_XCwANjwS`@g$v@bG)9PTA9_;$?rv;&9R@r(QF@QJA^#&2JgSj4d6`OX zAPg}TaOkvIyQQiacu$M^HY9hhyF=_gbFhA<J5HyE4yG_12G)YoJ6I^A1~TW}Ar|)K z_L8U3EYAy*iJ%aI_EHd9r?{4hT*QbuCy<+EHb1x_QS%j^-LYyd+L8K%asY#cC)U9u z=*|<lrEzTtu7@~$er_p!yB4tLiT-QKALh$hApMgho{DUjzt+JZ#4qDCE^X^SEeHkQ zSKW)<S$5mGD5eoZJKL~&ORfqr)vUpGYxSn>rW2QH&EB&8xa^Aq!|#&t+M7O|Gzwlv ziu%^e08ZfGAgib=Nq&9kR61)CZia7B-O3rt{e=mcYOX_}eiovnk4fT7?bNx>vR14r zPk9N0!Gl{_{HqujIGc4^yMS4AFbD4sn~3v_?TjCucl&(jwe{dVwW7m+rm}?s$n<_a zgO5kX!?QyZDnF72ppu@kFXA_Buh2TwyAcc%h(<z@4v*D?Yc89=wW`&iUoBXfu&ATf zrmJd{jwVa-HakK;Dp*apuR`27Ik{(wF_l<}m?U`Hnqz2^Y&m_hHDz|K4@D=mj=f)< zIed1p><owf2=^4X4xP62q*iwoB%jz`C3;TWCW)lCejlUpjG9PpdZc75hb+g;vsmQ# zl`%94V2O?Fk0?%n8<8@l$R-=a4N$?vpbIDddJ*iEWlrZ3@Hw#4BqEDUl-xG;;(khK zf}&QLBVUL~<?kmP(CWt7P)sWF$D5;Cbpa(SNxjNN3!yYzjeII8k_UBi*O5az)iceH z=DeJ(Ukq-$#V=g0-`f;hsmSB2%~|mzS1X(7J&mbvIn9t*D**35)<mn$`vL^WQ8sdF z2z6*_Ox*?A9Xi9{nYt_c7JdK87t*IiVS+nAQ_<4TpNT0bk2WaS)(1$OHmu&4hU<E$ zA<meutq>=?$TI_bspUAao#?jE@R>%{HZe)=EsR`}$J&g;9YqWF@G}&4mH$X;VaLkv zGsOpS@oMqXyJzVMMOBO(qwr!$DI2oKOJ@;HbBtfiOp3Di9ywAqH;1=0&J8WE;{w!} zg#<jxgJlM!Ym6jHpj)oULtD0?bl8)$^H2+0Vt0B*>seEFeHq%?z?hWJR%2n`7QM^n zEV;;>$u1crI>uly%3ARQ5I|)@+u6D+%C)CQj!+g<fJ<@@GNJx;CwYPeI`ITopJLVj z;D?)a%**z7#=uzN*68>P>K}le)V<HAVnQLCjd=v}n=iTXzP<=!+R<i8nexr1zu-2f z6*6PYj$eyz?B{<b-!bws=(9`%UmusN;3=IeRs*oBPjN2K)*z8PURR5lDwDcdm{(YV z&vgKY>85`ZE%gKPeO)itiYN)4ks}nG&y6`n`cIWilyk$>DwTwKY{NW#fDc`W&{yb@ zDdWIkIa<^=08Cotd8Hg;%biuK55989?Uym$+2=i4LzrO-!vja_xT4}Jt}t+9jY^<Q zNub@7ybjs^j|2K$lnR!@Kp@;0@F^1y?7>k4Vqq~Ig8ZtU$W?B%ADL3Igea9<&FHZX z>h*S^7PpEVIb<6+kx0P_-;lhu<-QO<r~aF99SpB4J%o6Qnl0x>2%WlWm=?^wB5(A& z8&Cb$?-M#5CjS$1$jKS4tGr%L-WjRzGZ2BPlQ7}o=H99^K7M}r02BPBVQMILoXy{@ z;_JDHKk8f|S)-Pecw^@+;4{B3`eVu0A_734(w)q)ATod!F9NYI<VW~QmLCMWY%(eR z;B#p+GEKZB<6eXuOvN|CTta-MRIOg9o|KhLnj{`w1i3rx2SurG#v0XySwLW3&532_ zX%J_=I`by~<k<Gds_fb;Q2;TV%;g%?seW4@_;Z<f5pG=|v8;2R$ZC^J)!6Ro3P<s! zq&&f?U%=qRq`glJ{aL<X&CNQk??NISNs=dpi}ugD5<lNoG(zTjBa;gWcp=aR_nHS% zMNRqNJ&5_cS`sf%x_{GS-|lxnV#L-~XH&u<R0jq46qZf+l&=)y{bJtFSy(b={j`8D zah?66?Ysk><vIQ4n!Db}hdw`dpOa-s*VUDdBV{THPj7{6JEz^ay4mu!NXPYJtb&13 z+(5STq);a+gE$pI@5a73PnD8ny2ru9R?I^=gb9p`)`A>~Fd>)@5#ZF7fva>&11#&^ z3q8W0@1S%SQ+7Be)R*n5<3$BLbUJwjp5jo)g>bcadPb|%Ke-XqmD&~>=%E@GHn>|y zooqfPW2kP7Cj3PPtb;2l8cOaDYIkYFtQxlqIEc&ghQvop^LbT9)I}`XWjF*q>qnF9 zP3O<=BXG`#whY(-nRB!gd9{{5bbbZFTxqo)@wQhL|5ICn^)Xx`P71L@eM}<Y20fHd zRQA3I4ksv!NB0ETw7^%q6cDa6OCGd9F<}XU{a~x+gK&@`1r=EijiZww+_vK4YZLfp z951eEB)x`^(K?19%H(gZg=8rVG>RduUOm&NwOBrSq@<bqf;+&l8%b8VAc2B*beH@H zX^mP2I0x|OCT^@z0swK7sh5jWq$1w#$c@}36*x`Iw%H0|Wl1v?#g3w?F>UjeOcuEE zm``w&N`lI71Te7s9Ae?)k!Xdgv2u3!Hpk`?Z*}@oXep9U<~nYxb@C(*%~OOep8D8L z{+?V#HVO4)m*^KfnoBpwqD7mG$BkgZW)*TpbT76-q_)`6p)z~3`!R#zNfu6Q5}VV- zj1@)7YXRBz$<0aVH83*1{v1}I+!+=e(i!S&|Ge@~qzj@dIBD~`xxno5?1)pCCRX>| z%LGU00*wF{c>AjiMuzaTh+(mxoH5oQger&T-YGDAz2AK2^4W$1{j)%J5H|`^I9%&h zV{Rz^EkGGK4UtKu%i;o<kXV$FQAcdU_K)cyMwFlDQaMXlWm~~BfJC5N42%7C2X^?7 zpj5jk&U?sjoJ+4~4gxqIIWUeD2Uk9KH9bW93WJsm%pp(8K+L(sjKJs#mUM+-M$%Vp zpfJ3`nViOoLggB^QG2I+#tOWXty$+x<{18ofuy4LAu|;|VlZ_KomdN%Fikj6HuJ+j zD^>E4HM|7dsXxS2q5N13O~yv{h(wwZw3bK(_0F8oYBm+tD$<8Sr*uf+AGoK1tNmn& z5f|}!Cq)|Wmn(B1BgPfi0SsFAaPy}ZQoM9|9Xaom@;KO`Ah7^~C0;h?_skCvy;srP z^aL2>*_@#Tq37Z9(Rglpj@vnSE~p}(`dMgP%GG;%9Xz)GXxBOAa&`KM|6!7iVI(ZI zHm)E3WtY9*w19KDz6R%l&hpPO;N*hMUe&)y|C*3LZqwc}u%R>hpY5N`Wui_`*Akf6 zG}&wnf=g@-72&2rl0k2qKVMFTP<pn#pazf4qw5)zZ>iM;{_#PZOF{^@=RUUjMuu~R zmz4tuc)aBEd<5Fjqipy)V8fHshy!^Mc_b&B9P-<riH_>orUdM7Xm|@cTs-7idOZU^ zN928JfOGcolHAfFE)K}jX_g*N5y$ovQs8{yo6CtDY)2<7=NEVU(X!XA)bIbU^VpBi zoT;Oj8V9-<T&pD`0%4+anZb6+@3s5X$JJm<ZOrl3T!IEn&T<LW;}P1RzDcL^tz`oo za*3MX+lTmABCb|=n1|*#og1WcZpuzm62|+s-jWcRam1`tso1NV1|_ph&dooK$~RBA z3p$pc3RVme$n8^{zx;?v>QzE4kc%Rt%NZ(48P?RccEQ*Ekb$@gcWi73=*!j^AX~ES z8A>A-NEK=HYYy4`3x9hyQE;mg&BxvS8z!X`$YE17bkjLZrbGf{f=+PwsMyUeKt7k0 zOrVC!aTZLruFXQXd<|M%f4yBa$98spJ9Q_?fh^MS3+j|>3(sR8zwkHR*~4uDq%I9G z`}y5}W#zSP9kmK5+xZ?o`&6sv+iSkYCpcf=ESh(D@SAaTA~GcMtQxqpL5;ahX1@UE zqX|<|(r36~*yTtKX^xh0G;;2J*mPGxFByXjqueb<{~yM9^4bD@7Z;1#m_8VYZ&~cj z;cf@<vUop(3SGpbBg~+}%z@BCL#;F}(r%)HUssz#m{&sc51y8u5(@o;4?|egvZ+a7 zv;TVOYQb1jg1%V15DGK>tq)Ml;JoNmnyK|mKc>1lqaT?NZZX)nO>)BW@#e8;kK&M8 z(Ns)7u;Xs_@^Ik>?!`3~UxJ#j_gfGBE3b6VPb|Akz*E|jNYqp_;ZthAd1%PKzFMZh z@iVm;ik3mb$ax>3K$BYkQ74K7^NaJ~rU3Js(%h~qOosgfXWlZ_7yrYbn3*ZT>gigY zIt+yOH-ZtgK}@fs8x+!k&UD+~N{Pb`yj?st9@cTI+9`GJL;#>z1z<cy#nxq!M|Ni2 zZ=%<@=KBnmCv%~(&DtOT$?)X*iVEHtoIk2@p77uf>i(3KPaOf`v1xAExpiAl708sr zLfpI%FnyM%XwaN7j;}G5Ig=WDJKSSn7e$naW>ox$%jNhC1W13S|5+vW3Jk@djbI|O zQIvE|p&e3c4c@82^YjJ!d#()l-U(d<quTpYdit)Er;>~K&wd@%XA`!t6E6%#<c*g( z9r&P8JMmU9x4d+id1ewJZ6-a+)<D{uQ2gQC(&i^*m2KJZF|i*m+}%C^=>p*t)V?aO zS{;ELM`3sa6LPr4B-4=G*Ks9K2E*5@^r`-qZAD+?aw8rVemK#t*BH7Xum%-hT^#Ti z??0^(`yoVWJu=tw%e0^7Ab2#^_*h<j5FwKa{pr3>c{U20JiOps-b)>k8F5|dt_L6m za07(9aY%9gRNv*4fub@Au))3a-Z&)aF<W=t-mm|{8i%$yjIJ7N3}Q)o9hJ!3jKXO! zk>KTIn~9P6Q8<W<f~t|13PF4X@WY(x7iH+;>BHiIm);shZ}j6cbQd$l;?-n!<qp3} zvrOdaY_Sy5e3((sIsLLDF<`NS7T&WyXP$lmg=Nl;u8_)j{WU>ZSP&+;2S%|CUEA1P zE+)Rlo>OeCA-z%<dGrsR>!cC${xz_*#AVP_m^j7xd>Rg|fngWQZ63}v%9F5eWRw}V zmBd`5()MuNNTTY8CRZ<%x7?q)xe2VZ?3~w~n-!g!lb}BJ!9Hn4W2;cH?6Wv)?km<K z2}y8xgqK-&mzp@v^1*6vgdz$h=#U&sne8>T^^Q189aQ&>(&<QPJ@T^J5#X|DkvOWF zCrKRdTYRVtQYb+}=^|@J-|Rt+;f<K*%)>G%tU@5~BfcfNYUY`J&F_B}y}L7yZyR^7 zq{y3_!~U7rwOL~pi9SQxi*E3^E5KEAW`}+V#(a6fg-kISG(A>@g2>c(BM+CXSfOoo z5!IfSV^qxw@_f5(<l=v<$W}d|J+Gu59t-Tm52eX`?jA@E5WyCkB?ih+xJ}0EuRjWH z)IwyMWj&h~on`%)T8v%^t&P{o0VcfQ8=BHV<Nh!tV4dOmjC$)r3RM8bIG7~D`v`xE zRLE?1rmnY}ePjIRbI)%ZIBIMHUMC;1{%v-Lxtt?v<;Zd{syi}JZ0TfY!Wzf$ky7RR zh}W&VrG;o`1LL#*r_T{oo!-PNr!={~zj1Q~mcTt3CIix6r9%-5<?=WCA6Z+l(b+C$ zFOf+s?+?d~S64{Q{5Ie|h2@W0Mq_hP8GPuah`Y8SMHTv0xnu?BHU@QkcH&x#${XTy z*}8v~>OXtu?7?y^eRhlnlMsCn($`KNTG~Y=nCP)5A<k#cgh=6u!xIb%1>z`LWQ0*m zoVM!+L-H^}Zu*6)$uKsM9lG?<=#NUIZ2fYxvh$*I>6Whbfx|!O26F<%hHu+H&Y~9? zbyeIlFDFXZJ9w1RM;N%WYa1mot}>O&Fb5`U)qMI4y3o2vu_f{Oj>f5hnpfNf@hz-o z50&yI0ZCfjWaa~82kEU9*!HZWKI#~eJNExE7}{rfqptGYm6>j$N%M7@?sgyW!uo$R z-o#MyC6?1uo#NvhsVB+6?g3RD?Ar<klw@ccjMeSpL*&+EQOyh@Zz-^w*XME%qq%LP zG)lAdYY)jY-q91&A6ihIEHrXwxY8TMPBU*m-MVVWxhUd4ha)cR@Alz9Xk6KKn0q*0 z06(@V2kUHcl$e-D2lgPG(vz?u(Ou+aVapX4j#ik;F!L*|XDt=8h3Mr|x@u84<`(f{ z^=h%jib-TGisi6!aw-!P@qltO_tY~lCNy9lx0haNSakC{4sn{YZ`~V_A~DwL@W4ch z7KQP%Y!u4H<jztLUn>DPNF|ZjIC|_#R(@h^9qtp!fZ(<T7aFJ!PSz>SExxwhAW3Eu zEm3BQI!({L6{khOY_XjTbLaKDEV{^joum);>5I9`$W}*uN&5vx&K!oUmX4()2(&cG zxSvyzl1TD2OAEoL)M*@21#l<nt6-+ugsPP6mIm#pVx~8#AZPtmt7h%D`RaQDe1<(! zI^M;qp16ba#m3TNR691;bD?nQyA$#c`G2a_qB%YPWsB5rM?_M1;+?JGaN{cgl#&$9 z9X+Q9B(e5>vPByQ;L1myae$k&pnql>y(W=<+@aieZ?t?3xE2O=U(aq!Rop~$nnAlC zFVW#DuJ8TwFvH6LzshE-EV0aoOP>_{rPUN5NT1$bA)CYa1@27S@cu#>@Z4klPWao> z5WcL9n(LtmIfWeg_tUSGz0*s)gmj0r2{S?kS(();q}hxU(H5dtByV$Ar+S)|Fs7wN z6ek<JC2VjD&%=v6UeDDR3Z&3EB5!>^0nSOJTTEO{IK39mT>GJ>wb1A-CDdNFVd&8f zw?<kt##oo2#@$n#`c56R7-|z=!!*7qM~2n<sJx<&6R7X#1*w~}SMUhuK;=S@nhwu- z`aK-Gf&=_tIC91LQ3eyHT$8|YywRZm5~{BQ8u{5kNJ2ztzbAXYs`ygh^BT<veV9|O zy}4}xdf<Dy*j!Qs@`+6j<cS@Y=HNaVYNG(0il~{6N7-GtF#Sxstrdn5!<nUP1+Q#P zlX6flge*_oDRbEAzs+4b+xVi26EL;a16JQe^AeD|dGigpt9kl1#vdOWJ7d4gbKE-A z^tkt<3V5Cndbv7<3usS?YCFH;Hw7@G$GM`A;>heNj9Obm++>gL(>8=+_bD?ZTMrmQ z2#n8age(V15(#p?5ynXhEy5|CjIS(vWb~_RN0yDJTMs@|@WuC8%4wnWd5e{k@$)#K z)Kpe;mpsMS%1)#Lp~QCFyuz}evR?@tO5g@Q6>fBR$Q!AakAxo(^Cbau<!eM-w|ily za|2&f+#KBnStOP}N{AYkUJ&aSAh(reMY{Yv{%9&!$*p<p>msdHGp1IT>TFj}#4Xi- zI**@B@6U-e)bbUZA(UAB`8KdI+~y+7#xT8(SpHigBcZturQI&>`NlB-mq`E{n|~Dk z!m!noZE(Dg-k8>wyf)7sXWel9JA{^`?@!;nrT-N~F{jcr{cwqaA%!Qi27poDzzgMw zfRgrsJ44|P+u6~HpwFqgBM<OSf=`$-3cJr}ZQ$C5c#|VcmD2s<Gga-54gU{ZX?TlI zrG7WGSD9YXa)0knHks|Xz40`G*Y!M0izcP?VRr|}QcGZtEobwdSJ#6g3{LREj{)3- z)4-2g41$Y7mudOYzL6TLsVRj<E^&_YdF*}2ye`&5p23{gvUaTO=R(uk%enK~n~<qZ zw|z_n`1nTzQN33PvThAk=%H!;WYMp5syS;z|E!AwX&X#H|5$PSeitW}ya<xP;;Gq{ zj7FVtW?OO)$eE}mBM%Rl3T%=+9?tGRf(NWgMZ3kP5j2*vW6a+4%%@8vcPUv5qYO)H zEc<d?#Ng7At%-+eMswri$8|&oS13M{Bq$;(1oKG3&zqQij5$y4im7POpu$%o4AHC< zRYhot(IY$aIPMkuJ9tWe4_;IRydc(p>8MY%d02s;(i@MZ?BI}U>UZ|(3f9<;z~*{` zFOOoohUS4xv);Ng7$S<pT|!HAOb@r=s53jehXF%z4{+X`xQm>?I>)L#ECT`!kB#MM z)T#*7;iVu^un<vGHN`Ns9$QN}A-ao2vD6^5Mu=1E=H{veRyY|wDqzK!YK0=+NOhwb zjpxAcTPdeB!6TQli~bs8$}wc2R<iqt7GC|?m)X;!O>j5Pn^}awka$Stt{xMz`807n z0#h3~Hg{u!%o^2p_BEuyBfLbBPHlMd$hRc-7;#bQd*$4&yN(=E)gf%UDSjG8fekSt z2FPyUP}4!Zo@!I0u_?uuz%>FHf0M(;WVB6uP?b?cK!elIH@?XYu>O5IG+{!2t@qjr zgsB+hLvSX`xl#VQ)MoC+q<k`0A{!l7x1T<xRCBgw&R6Kuw$1B+^1E4{L+Zib)?A*3 zHMFB}0Arr;_PbsVilD*hQ#35vcXoQZaF_*&$UbBn##H$zeR@6XJPvnDy(JTc(=6aP z!|%7xsCS;>EuErJ7532Meu?8f1C)icldX{UpC4yt{=XN%_n&%Tg8Knk7Y)cD5ZuB> z1aP)#3=jA_<EyuJXj!TuCw1^U-QGsYrS`I#TU0EZ(`e&hYxw~XLft<zfNW&b&=fMU zDuAiy0C6tX9~>VC($aieyPkr9XQOHh&ABpKs`+_%nW^@HRL0&JcAf7JcMj%0m8x7Z zK&=hp&^OeTFa}zzuF}#&GY<<Ulitwm@UZ~|(wxcp=1A2YQsm#rb?<5APJLHs3(-lf zD60r&eQv2x0BatEF?zEBaAjO}ArR22i`rYk`#pS&7XJXMQ~v~{cQF$%b^X`c6+(VE za~0pv5Hln+_xSJ^8H^cft!s9EIv~Xb9nREch=r+VssJSE22X{kk#4M=7{WZ4MR_aI zt0s+1<WvJ3BS)6000NUF?N-MB*$<{)o{nUW@6w1(Q7(dQFY;NcrqRD~Og#zkX!cJn zaT$fHqM}!>#L#_f;)m|u&0p>{v7X$8crDSP)pJ7@kN#YK#+Gb60pEyxX=sRrA2&U7 zV*D=F*KbyhlX=(t*wVZ-(Ehf)TsIn5BMzvQq&1xI{n1R`Fy4yXlfo<j*Swu7P>{T- zAq4ge#2#<K|L}+(*_`lE2c3x{ObwJ{9&s8MfAx+kh{XdiW~s^)UdxTF)lg^qqxyI; z-PPx&@@>@N=<!@iS-qt8Oa>SwIgVyU*Y3;sI89MUmz6jA?Ej<bDudc+yLNE*;4a0B zd-3A#8r&U<Q;NI0ySo&3w-$GbyA~~4px-|4%r}$#%_N(>&$;ZJeQ|Zl>LD-Lo2E(2 zw4z0$wiTh}5mS_lXA*|<VnoQzajb>(->RV;$1S^<wQw#Y%VqLQHSz0S@aQTj2UdhP zwok=ntV-LWOmVOXy26GNl}5g@-1lbtEU4lHbD8rPN`oddRqm7?i^Jvb7%}g^mWhZg z(2{FNmgVKAuS$aCfdG?(s}8`5NN3;6$qnp;+7>&ROCe=R!VFsUa5zI0LF8o&b)s`4 z6+ukOpDe0>?<)VhA$vdj!MN;!kYJn{$dP1r!!ru;f+1h;`YaRSwLChSTPMw_lKKfV zxoP_AI!r?@6hCJv{Dta!2rLx?1>E(6^tp8^U)+qA3R8zvdCI%~$1jspV6#RkR`Ho= zj=a#U&C}rG%M-U{I_2H~qJVp`)f8>9(_0nepRllheyhAlbV5L>1y!G5<%(z(la6x& z+1WkzZjGP0%M!vFeJYyVU-&bt!0zEW<xUbx68&X7RGRVbYHg7WyIh%@-?7yWVoVBk z2dJfqp4R7SUkusieS!)C72tE63B=^fFtVr)=%qE?EG;e~A5*N_J{hs@wUOtK6=t>< zEiK}Wru?zDMHf_cqs-)>9p6Y}^484qq1W_BSH!h0vr30v`|)5XnxpLorM33rYQ+<N z;%fQtF5ggOW<Z-_U+MnL9#VdKKO6PmL{|`gq)rYhNoo+xw+$r(H23u`QVjopbF{!{ z`L#IGHa?<6jdga_uOEmBSQJH=VifGC&`*gHG`jP0pGir+^TX{VE9+xM%sp`adtRFf zj9B_2BocBQejSXd3X&-7zuW>{LAIrwFcl#9?riGGI#xeio`16?5rk0<y`Qgy{=k|r z!!2XbK7X60FPGgkQ%8&y;9>kHKNURzL*aw*UC?6$>@&`$W24UWp`;9k<o*-mv6TP& zL}1J;VbKuFIGXwyD$G3zA_I0upzMR(%+$PC&O7=Y3FUmV`K!J%%ibqt*0=%86KC9g zK@=r(;kzL+)2Eg6CD#nKY^Rj#4eD@b+rl)c&x;2V|F&QgI3JaJFqoxQQ(hxvB@(k# z)ULeqwlXTAzUQ%4@Rn;nbf6l;xhyqs168^B!l}+7U)d5vvFa1QCT=mtEla%QWJ1Fg z+{(s3IZ{AhtND%kJ*wH1`DK)F=hkJ+8%Z?EJdD<?<8^K)<29F1hO<fLkQW{{Q8a_o z<E})vq;s;O9y_{vEl5UzPcN!cmRr_zEX+KNC0T`(dWgt-7t@wUo?Spg37wm1>CTYe zp|l&Bttz@b60LAB5d5j6Nx5^CmaZ<|=7H7q66;XGO-w1-i@HS^cX>9DI`wObQT>F+ z2evS^3cLCy@uM8POp_J0uLnA$eUBUL-Tt2B)t}z@Smo!4Il{VArcO|q;liX+&0>hf zv@b8RIDPjcC4G-ihg|+OkzC8Mr@wrg7i*k09(@!&`oVnis9LWy$>dm&g>XKZ82P*q zA2`lr$1%!6rzhFUybT1@vJ9&5o~zl>v1GPg<bppa8}_QYs4@)8&9Nva^PHYhEfKC* zMK$jAL~tyLqr0jwcLC#eBvrUla`o&dk#I|k9sUCF<xT1wH|lY2_X8k%PoWwIv=dk* z^yVrSWR|g`-gvD1Vi51>8mwj=h9Px1vLvCl>0-JZM)s+(x}qfy6wx;d?zww!xprH% zJFZ5FZ}9S(l9{*R3Y?Zb`1m6#7Aw(Te~h3SYrU#U$o}-e+LmD$D}B}g?Azwdx<&>h zEd&7{Y@fWzz$}nMm7JWuhKvb%%i#x1<z{->zz&bM`>(z}g<<%;tr2~%&qO?r;W(lr z1oPN#8K@+gXH5`eIP+g$GsGR6?vZ=%hoPrGpcO}=-;6@Y?mJaqR8Bwr&{*=E__A(y zLNQVDSbC|9fu(*?Dc~{}&tD&k;ewVG)0mG!`Tp_vmHQm}BgJ=k<EGyRx70Uhj=VB# z02IMlwf;)T@V7B|a{5&*7mNfi5;IFCHGx9cxPsBJaEB$yfJ1{7#U~9o1TTIOGN7xi z&7ppLLSq$r0k4M}>h|kDR7Gq-5maCUI=p3h1W9+c<oyI_?bV{WfFCKobd*rj&Lx_o zeluh7BCGu~B5MOmE5wIvT-9)bO<d7VA{_yiwGmTql>Z}s*Oz{lvn!Qua=IQ|b})Nk zGNSVecsQo^v_j;Y?Ab|yicK?uo7pv6Q4}+ut%`5;6jlC?!${`0BCJL%^_$D6{*V|G zaKyzJr3nG!1Sn&$W)6!hUJ$!)yJMQ0HqeJF@N1UpDnOr2Qu2Qj@g7TaOrUEnXW;iN z)E(`6s!d*X{QA_?c1gIFrLdI;A0vgdjHF)zO<9FiqnfLy@ZLI0zu)&ZZ6o;aL@=r@ zSszFVIdeem+;B%jd7z%qZj*ldUKq^&)|+w5QR%6RP_g(`F7$=|D3NbPJGq{j{(Hbl zwZp&drTcWg1B|f1e#>?8=X+p3Mw{dBV9MWf#p8pD8s5W&1r$lw!H5_F0})ESJxlSQ z)e=KOLNI0MJ>f+#t-nH1K|u`GBrzjH<|5lRtF#-s7YFZ-kDTwsi0$;hJtfwOB_o$k z&@gbq6Jm0Fina^@7Y<UgkE;}DGVN_73P8fm96SSZ>v;7J04U>so%=!X-}uJ3_is1B zjja<COhlm|6Vz(+fVts*i?VUW!lG`d1r1w8eqBZhGi)cW&<?kLHpRD<VRIGJ6rX9V zB^U<?)JIUJyAmO$0J8s=;(fM2&L4qi#v!H)w~PIE;t>mS&4e;o!e%3xM7P<i<tF3; z8BFaY@&GNH$rB38jSKg5yfWF5&R^pz;S|L%3qSkt+GG{KYvgy%#VG0Mi@{*Y#yS>( z{VC)Y{b$K{RsZnC8SkYCa7HFAs;zC7!r>oP+(Hdg@7rfh28(F+hp77~Jj`z&e#gIW z#~Z;oCzexK{i#B+_Y7Y>^)7Bt2#Cl<`Z>SD7(0`U#UuB{lrNyG3ua@Tm^SFk#2+PE z${6zwpAI(5yp+J3iDGvR{_7QO?Hh9c-l)I<1S_?s(n_QH_gv{G8$cO<8ngVpkoC zTmFr;g*uL#jKMJ|9lm)cikn$+etXaO5ak+4P>CfG9OKqIBXyk1TRa5=_IZ!4wCHcX zy|6j#@@_In=3IhGL5Hm%q3Ut%uGA2EH;frHw{dBkreSAeBeYsX$rYN+)I8_B73>HQ z+>tnpP>_!+cfHKGMUM?^W<Zd%82EE-dqhZ7NR_7%H%Fv)>N6w4gR!#vwEccz*6r`a z>gTcKXSGp4%GE2oHrjy1NmH6(9M>#HTkKYQx!)(?5Bu+By&TAR6q9@w*bdJFA3&v{ z%E+3NWK6~ddQ*rvWtSaTpMB%_aC$!Rx_DLAz&b$i4st2F|8P$Fk>W*e4dZ?9$nFrj zZybmeC5U1oheQCoH)0AkWJKi$dxwijLDDfIO<pDPU`5P8sKgM&{WY@*7a*(?5@VVs zdkgFzDLfIN?;@cC^kmY&M-jh(S#ol-4j^U{_PaHHGcMeO9!dfS=8(V=_6M_`CA<j^ z#jn#BK(RU^M(RsJ{h@~F_9E=)^vAivFbaVT1SG&#f00|qY0&e_CyNKId0=z6>@ncb z(h&)(af&7<wMIr}((XyIODqh+mr0d@vr~EZ%X0dg4J`!t)B{PR97w(g$VyCH$&SY` zp(Zl0LuL@>CGi!7cK<*qqr^A@^Mf~zZ(g8dMkqPen+$(YX5YRONM&$f=}%&C;_?mM zX6n8^_Wh&x`;+{s{q+(?!lw&e;Ru#}h$9nI7y5@xQH0gD`zSwNmc{GcaoqkRaQ~aR zYTkNj5+bXMi9YCxv#cs_KRyZb(R{AxMbOBmX2i-ebyhGjuj=*}Z{V^b$(WD7HoeV; z17wMB+!uf>-~ABlS{uzkeZYp!8sY4}GE_Uo0@`tI3K@%^1}Thwd6%0&B*c@;=^>Zf z_(f#wUXC#uQ2LClG^K3{w_$F{R2s1F3>bZKb0fgs4A&Ou_djFkojt}HW#q_#6xcgC zg=#FIo*m9Uyu%>QFDyRyzk@fS-k-=Xjl1?u>I?^8E<sLy&HR^%9-=RwI1?<O`Rq6F zW#xBrmSvU>Anrm`x!#$0ECtOf=v2lP7|UgXH0mu>?r(n_FMar&CmH8=g_1eA;6^KE zI)m8*l^8QO7GdIk+|RjZ(3f5{&#Tg=Mv9}5AAQg`e>N$bt?@C`#TvY5m4id*dwYV0 zOshEaZ*}#=BYX``BsgbXXOu*cK4yHP`zd`>-|LNCtLL%@QS^4CU4vKuY*EEV)e<z6 z5~U|4>;y)f&xcBW$Gj&|F;SLV`UN|D?;>lFmg+t~4T}fX75#JADl@*4C$i98F(Vja z4om@JFzFk}FgUmC4m;)A9ezh%JO&UbY_`rOVGw&*X((f!fo&2eM;*!M;xjtd4vim9 zx*YA9*|KNI?KqK{Y;?A9mS4Ys1;_2J{4w|H>uUA@K?n-;CI%~l+|>N7>Jp`?-Ov(` zQKIO96-3sAFD}DIryunR4K<T-xS|SsA;1oKS0$F(J#f$l&43|I#wkqB!&SSrp1ds& zhnwtzUqbC)`MGc<sv6^nu^ivh8s(2U)tz9u$?5gH$W%7XMI_3-uxj+3@JgO^lBG`y zFf$rn7QV{rtsGI?wEW)w_sAW8e5dnshZ;K=S%Ao~$hSKdN8uA9rpenav51?lns8uu zl8hEZCy8>t?JkDjF<0;X0W>5$eiZBN={6&=8-8N(?qia8f(`{wujPmIp<TB_x{-|x z@uHU|C$*^Z<vB5&5Abp=UsSg-zNsbG__IH61px+DuP<$gHTx)wYna8D`}Y_SL54XH z>oLw5a@k8a@GL+l*LFV1-^a(6#nsHYfH<4Fw7G5G6eN=-_=*tO+{ED8jX`xaXHvs? z%=gMMSaTdvsswYktG(0(qxYNiC(~u=Sf{y|)dt63wPA^x4?%^|=zkB_m}j9Bb`iEk zt!_f@q-sHm$P$hCQAEPkxNsn&V9;KkI(rTzyxkS$p?O08aO{rr1q<6;Rvqu2P~c-G z;51nyJ7<b2l4VSurzwTD(vuS6WU%0pYRIv?&Ps2mpP+pn_n8|PR7FkaM-9g+C=riZ zykjU086u1$t=h|HAs+#}38&4~foyW8-51-huYR^!rZoCi^y}Jzs&j{4mx*w``#0W# zF5QvR@zXKpLT)^>;4fTANk^Jql{1hOaCnJ=PRl{j$!+8;4LAD9m<e*>>3PPVm<mRz zH=$(<G6e^@iq~HAbzrVq9!Nx+Xx0KXnj?^M`q_eV`1?elCxVIEgRp55ttHFZq(OQ9 z!thKUK5gwMQ&B95g*EhPenD0f!$n4l%#+$z<T@-kFd*vs{*8ot-EtjsF>eiuzq<Nw zUJ66o>34yMMs7TfRl(602RQ{ab3agOe-8d_0Rg4@Dn-3^2ARi?YCO(w(nu4k6N?&% zCcmCbWtVir>qD`qGKs~Dk_yV95E(PG=21EB&5PxJD;`&}=(FOp@v2L7U73~R8#nFm zZtVVoU7e~<%f{QweGpcmG^T{b%eI(YiS~Mxz$wS8YX4$~@5$q{`uoWm1I7&=gZzx8 zlcdEIsy34fPal_=G;g3SPp98W$Okd*Go4g6s2qJ<(c2bWT?M^Ikpuu<VA%=SAPyLq zUn(-|_M;u~Nj?Z-uos%pXsn#k*?K-?j|ee7K>@J<@sZVcE1=*K)}#u~{_NbJ%LQ4v z1hpu<n5#{v%Kah!6zUQdqv8wZj?N@_B~3#LWS<^;k8QL+M@y9=C$-~YUszO7vq&h3 z;AgL#$w<~zp47ZS*w!7)93kR6*0D}$=;Z9*oI-yYG7bq<`<4{kK<7fHT4P3~GZ-Mt z4;_S|?ag(1PzkG4H7|p~S^?8&<6H`_x^SVB@2++WI(xVa&>#bu<a}t8kEtTn43inn z!YckcG9VKc2K{}}o$Z5IHskRhSUdF!SG_v*p2`0<WQDU|JP6r0_x#K6d9+PB=$wb` z`?@LAEMt&b3I~FQO8~8bhcX?htt^*@E<LXHg%j^!mb3n%gxxjF9PIz<#k@lyGHY$M z>#|&r&AT-5ROgn#OrlRM{my7{f{6ck8617x?lSGJtRg0n0hNhMI5>j4{XEUTo&KEQ z0-bflSD;=lFxGIR2D8YX`RG@yIr8u6{^yfZuP;<vKI(N-Jo?S0A^Fwiy)#<|OUd}{ z-GaFru_pe?OpEhA1jXo^BMz(4@4XE@(mbYP4wRT~xYW@D5I@{O$E6A->?_6K&_2>j zGNv6GM%OtvSG8j$JdA6%%GfxmE7p*H8B0u;C76IK);ScjUXEdV_{TqcxCr6j#xizq zWte-Kwx4xll;**o%XH;E6jy0IAs76Qx<BYf?Qz^qf@S(XkJu-saM-~e^(*EXDxYIc zvZQsNx7v_Z;=o!*jd<7fUrJF&%P{2ydlW-6<TBT$lZrqQO%$2e?nAqCUqvO&8*ZyF zQVvOmY7mWUZJV>y0bICmCe4=f9EVScGH$A2NpNbL7{&AlETKH+DKnOpvu4~xu@2~r zNVSC@tgcNX+fR6)mQ8@*wL*lObFP6^@#Gt>9-2sAXy7_=#UQ6_IhNSG!34{{hSre9 z^E^{JEh!f$wKO81zS6K(x07wOIxxXz8Ko319EZR@gdIv`Qp9l7dGobX5#zj;QNSJF zu9oqaJN|kuQK#(OpKh~RL&0e%xE}#4-7_R?K#Wv{NLi^&MdgHx1hQQ<l={<^w#QIX zz?jF_O5N)ixyK<lTH(m})ZLPZ9bckebPgHw+slGE5RJQQuK##e{vA$IwTNG=l%DtW zE_s&g7UIPkwLa!=6kj}m>i_paxc7@I%zah#{s8z&h_9s#6opI~nu22LbyNh%7PL)6 zOG3_bm9?&;-EA6w^ip`(d13TZlzQUiS8$<hY-?s`7LIMQF>=yLJo~0zSRLb3Bu{z1 z75gIFG---eADIej@{uC6e`Om)Io7ZEpvA8t7dHPz57hFZj@9aZ5ce25fI1K*TM@F# zb)?}RwaX=eS=Ihk6I2JbUWC+eGgY*AXM7k7JFK_Bl*)i5!V!r%|E96=Av-R1B*gs{ zBhh=v29e=ANMXFaR}C4el$(r1(K&1KO~po#FH4*@*Pp7oO`?nmKGCCaMA^r2Ls$Qf zh6ooS@4O)(QhrM9$1&}>5tv@Jl7ppyV>wUT_1%g|r5RcxpUje8?5;lRcZoN7&d8rI zt~6vZ4zb0OLcMDXEl^L+1Eu671)jjf(d3jkwBya!F9!79mR1uo^A`|ZJ}v%weYwtl zwZ?XYaGdV<mA0D$uNahUwC=wJ;eGy(gi6xyrgBPl);%XGN|89zsmW%vO6H`F#&6N> zp)s$JGT{L{p=>UGIG+jus;Z@QXlXExIg`)fna^soI*+-TmNQhw2~BFIg?{u1<J2N$ z3#Dp|4wlYg%x4Dy>7yQd4HAf9{qE2k<qHn^l?b6pwdTlk9Yq(8!wyH+qf4RT<PirE z4@7QE&`K$s;os`TV#AtPB^MjQAU_X{8j<o>PC>rBJzf8(1(%39X7LhmQ4X`NANPb2 zWpN=IgVm)skX|vvuF&DpLMB0nc@=RYH{Z^V`cal&z~NBi6?+2-v|N%bXK^v9jYBzi zzi=}xJ}#1iZ)(Wm_*1IZV3G3sE>JwN!!1h~N4zGZ2$$kTqw({9Q;~;iEG2SmZgHE5 zDn!dCnZ+l`A~a0OIZ;KTxE4M((8P(0+}0n*(K*y-9SYwoA{56<SC3A`Cl?&$s8o<K z(8r!c{9g#}qk^}F$5j1^@O_AL*=@o}()WsVIZR$*330!;3qY*o{ccJGocO5K*QKU2 z$JH1(>nKuSY&32v9bAkA(Hr|QKXL-Vo+{R&8d-gg-^tY^>t3y@4-(j}n{STO+I%W_ zI0oF)dm|_gB<Q{*Xx{|+atb`>#xC{TPd_<KE)IH&(!fv5nZ~U@`AxgVCVB0wvfV)( z`g4)#+r_Ua=ATYZ5&PE2_pJFo`xBXRL}N0D!D<{4XruHYQJQ@?>lQ!Y;_Acgt>5`e zdDro?9wA_V7d6i9`r0c@>05wnu0XGIVWgct+C!fDO1ymbdInW8cS*mOYD2=;%O&&p z=Lg$11E?b9mwk7J!?ub*#gD??cppUQN<MHL+tEc(=`iTjW^&B!l9NMh1%-*M&WSW< zN?cdYYc}O`=(N_{;M$%u1;inb1o(t%0pZbH{1&!VUnfbVEqy|wRVv{+&nB2hpog)M zp6yO#3ic4&We0kX5xwHf2|4b*Dim0mZPJr7F(#Gku%csTv>4wbJDYW7+P?~y1r8$o zrMCCnV_~%=%X}cUP)qbS8RdA9vh2yJ&CN9vnPN9FgsJ;_;RW7#Sisu)#??QxZ!<dC z%!q!5i=nAJm?%)aot@oXa?05<i<ksWg%(<ME^ZS$G=LgxlK^!-r3JSc7R?rgCpzN` z$CV-Z5mS<=iEWr>_9XW6pHX2llBwBjSU#djXYb;;S`Y4Ox{{-Ke&L_1cNy+#DX{QX zWb(CZ9gS}vhb<en4IDa{ME^wkTGtxki~Ej2x+|B}lNq9lC~R8dWi3_;>F~Ju@eIo~ z8O!Y~h$l5-=R^Kwh^D2Nuaahy20V9i^^E>PqT&DN`=~oAyw<ECp~gG1N|O<jrN+3j zLYvl4Ggjy9&_O$75`FUX1Sz#}b;>#y=L;9FDf;ZG1OaE%?Izckf%@omb4gR?51}${ zO?$v1Z0dOdyvt;C@SYxSEq4(;9BI~uTLoI!{8M8og<>pW9ZCeYL$huMR~7nn{gU&s zaZDxo?n?ZNwFc>{HmeisDVqzaYxFPPn|t+$P^P<uOtl@JW0BI!Np^LJKwSiB@mNFu zoN-v&1H9Mq4Jg<Kkuo3)r)|h+tH!MO)TCB-0v5agvfAw$_I-~ue@miLYIEdbI#K@o z`W7zzWNkErft$r0xl-49Gat%RCYC~AbbcUYTNuXikt053bU2<ZM~aUOuHBPu)XxdN zl-sXKWKeo0?CICNyYI6tgpPLj%e5{na|cBYBH}u7UnRH^N~SNl+YK&CE8qkto%XAN z+%qZTN2yZ7$w;uoO-TH`^PWuBt;qKlWv0~alZBN#hP>C3(gkjt#uh^mHwpzkXJrly zJ`USQ5cQ-8wTDc4f;bDlaCs$8w5t8Xb3|HHD1Tq|B8~$;mA1S+ibcbO!!IzWIa66V zj|`*afX%@{e4<@u8&u&dv~Wfk0i9%n4MpEm%X6sk))05V7ES+xpS>t^$fz^k-oz=_ zS0_vx!Qaa4_r>j;c6jHH8bXmWHX4vfk10u^xunJ=)=YOvNr!bFNjqY@v2PyltBwZN zW_*#?$)Cz+^-Qj;gD~=9oWFI&RWZqW1Xii)6BM)MuatJBDX<xojE$ULIonVpTMPgG z`*ipwEWAN($`)DcmM5}3h|=}(!mX;p8(VWFkeVAZHlaf?)li8tmO{$QMl8Wc^pp`s zX<IkUg#XFw-4|suEZj1qgj~$i@32qZ2E(MpS##;;wF5ryPubJb7D)Mp(;D&hMU^~J z?dfI8-JXkSS>vm4=uZP)7K*(y62)1^IMTQ|m<DJ`;Al+9Cm+ssYUae70(yrV$qxO^ ziLDmNqL86XoE=j+)o*WvaH^5%C^B*6lkH;3q>t)tYjt}|=jS?hOFJFVz4g~mZZV(! zekOUaBE($K)1%f)R-L7(n3D%J$4rHNv~4aep+C!IDk&jgwB6-48sm>ve#0Ew#|)N@ zSa1p0;){S2!U>}{dSY}_s!<2cB15~Z%<x4xCq1n*)Vf?5$IK~MjP@4J6DUBV(z@90 zn}c_9!@pgSDi)@QkEB{JL7J1&uBI&Eayx^oj=^XAnaojy&M7xV#VMh8D>=}KdUkHa zWR3>*`vW(yf8QAL9;}{DbJZ7xBJI}EJj_aH2o?uBCa;pu`9lk`%zUDTh4~9UL(Lu1 zVg@#n@AgQ;yuO%_FNhXuy1U##aOxqp`@cMr;gX_{af0nm4~`G^db&ONM(ZDZym&Ii zkOQO7xx0NULu1SEoeU%Q`nYPolAI>&uqs}8oUu&1S66&x+4{;c+%v=;wt#shOxB+Y zZPeEhsI;jF>qhtgSpbU_UB*<y*1*9<%HkSexv3pixIy55U3Iu*qBos5q2?G{^CH_Q zAwEnv53LLYUe4C6X=B_GPUb|*bt>a0BFowgz_*1?F_f_x;Z}4}b@$6xb`Kl38*opO zmHk>++OlZcOMO6CxEU+(e(bb4+~TU(Y)dA!0P=sl<a}Kc*%%u*rGfv9-PjUQ+G~Zx zMPpPu@`WhsHm(T7P;MkXL7l-31Fqo4*VTWC)2Cr*uqc{QvAG~szIhlDCL^0-%XuM` z7IQy6=o-@4)9HK7;_LC?`h%n5#OO6zpY=o(FHU~)e1|6N?a+0!7rIHCC$chp>4V0t zEiR{8#hw56lS!y(S?(=Gpc&F#E(FxDb$h*ZZt(gCy<t0hcVG^d{4##l!Ar-^Yb|G2 ztr(?1Q$|z@GeUFM;huVus2P@I$~dMvmNO7#NjH`JXR&TXd|uqm+yZ5p7$O6ypl5HS z(*|Tnt4j(V=E&Rmf#KAS8ck4`Y=5kee{|D|8q}{;9)<6*zG|zzwgZLwSHgS0BX0O- z`Y#<P9}w3ixdK}zLpP8rP-+WHXKiib%CE&ssQSGROJ3>i#PKs{Iq|n(@|b6env*Pp zfBUag?SPZ``=>h0J%q)AQd{13bV7y?=m^4=6I;!jb*6NgPnK>oisKz>_j~M!vp6;k z_i3E&Q^DD=0|}=!BPDW0!nI3D#>H!yt$!eT>WPb(rSa0zX0K!au6Xpg5$c$*q>%r^ zc7j>vI||Y_+!eG@EsNscFKlS`z@cRW@a5-bQmf!QD`DxDc=c%N^k2KEIt;tw`ss<w zM1RXUyIWSqwr*g18i9fyoLj}DTJP1UTNYQab5Nl2a$SJ60xf2(VCkaoUbGkKGa}YQ zg-;+U60zrDQ@SIAFjW;?#l((69b-v}?I4O;CcO0xY;xrsb3D^_eU^&8oSm22(ikcK zYtr)$wSbUfRqyR?rR|cx-McOlIQ0XIW7c@Pn{+S|di&WkwR8nCI=oH{hu!x|gpAv9 zpI>@(xmz=ChTv>lXO1#*cew^<E=l&i2nO9rAR86`LA9DCp$7s&tzax@xJ%NQo8(VI zg2IstjdhFd?v1hdtj*txUccLj+U6V_PbsxUIc-74%<;;Ft;B%cv%+G<dpjMjQ-j9A zU3riNSnXr0uPR$nlfAbvrHhp*xA#lS-Ov*L&TJ(u?{iMXn={ns6vZ<$?$sw;5S};j z(ycwD(dhj($fVgX-S;^b8m7qlKnjfvI2SqE2=HLZv~4f8)GSDF!tQUzT+hd;k&k}% zZWz7tXUX8rD^kUqyDmDfs~beU;d_(gU)=VsOghzF)=QfuN7TK`(H6&dgW9$Gi^1n0 zk-o1{T?j4+JF&U&j+b1jk0cTdn2SU+KAgUP+(LkBIF%NDJk8y>R7atJY#`l)_~sH( z{>Gpr<@cIHp5Ehs|3ajv*{dI~o>|sEa3#>0&avF$?a~&iV$=Or5WmYjxQ>Aku>4;y z(dIGxaELwkrdD7IgjYYOCL6Npo=|~?1J7Q!>HI=^ijf|^va77wY6Iu+yuDjB{QSq@ zv$=j>NeaPVEJqRI-4%?Nc27(Mq0P?dbk-K<b5r8lD*5k4mdHyreZ^bJ24<ixJ5AsF zQKDBBlRn-7Kc}d_2-Far`bI+=aC?z0!qlKwlN(@OsETFPMv5ce6dzpukFohTjM;(w zhWW`|;bJukt^BcfhTfpyn=l8Vc+PO`n;CV9`6X+!Y7%vGs&PJnFynq74JJ0yg}F<K z512b#qA=78Iwi1{&>lUC`=E}pWS>w0>sxxAdJIPTx?4hB&(RhIBLQ5M+e0SR#D-@z zN&kenz_!&;sp#aLxI7&6LpoKm?v|(2On<#SmUNE>c07xIH1rdED$$TlNZaM(_0~RA zNJ2#?HvY0LaMuL`f5uz|vnSJ9oY31_?$~EhIlfu1LsMd-?hS)q1(&p>Lgo9Q&9LC( z8D1Bg;$Aj#B`INHUyi}Q%3*vYPXq|;4JV5v-5K^Fi=(4RacNNPU_J&$;quW@t*#(e zqf?3qE&wj<0sR^OQOSi35mSO_rHwd2d?;~TjSaq~^SU|{oz)Co9twKBof$e+BTxh+ zD4h8p`Yv&!fP!q*?2l|}nGmJR-Iu#d5V_3a(1)%oOFvC);t2kp+L_Qnyc<DLe67ak zG1W?f3Xr_ThY0Du_plmR@4A6^*80QMu;Qek$jFqh2cPjiSx%P0y9)7~Z&pyG{nbx2 zhrZYC=sA=IZOOgs3jrwa5j||H1Qe(EG+jd|moGvF=XEuQI5tEG$RgWbjxe8c8PEL` za3@*7e-8y(HAY9POC#-$uG0k+u?t5uWId5~F#G9@sE6NJ5*Bf6Qr{fQUgodzo+<P4 zCNZUmaAyL^CHO9s*-?&ccx%m2f&kW_&3j(qgPx6-10$Z;CGhiO;|7(bV~*sY0}n>= zYmh=@PiBp3-X@cr<Uu^I8j(oHx0rPVGtp7_(t3l_o##7;MJDX2s;*fJE9CLai>zfL zzY?Hlh(T8Cz_yw|t?Np$g@&~ho4kM$ErAP?`8XBcF4GYjP3*qm$1|w^sLY=8^fb0! z4txc}-c_nklv5r3ExGGaUpv6cx}pCqa-2f$_3Mdl2@5yc5E{9m9}X_YqV)@SB-3tO zuigEj1=F?3Xu96BaRetC_4MLZ7p*rE3XZl9TB^ukQ!3SwpT3Jts@MU&?o#v*C9{i{ zUhh5g81~LK2Q^b^9@Cp(KE}~{{d#Ql7Z{kE4G$R}i4`#HnICPbg=eh$4F6@Zdk=Zm z!64$)tjS<NsVnGh3l-t5U1%Ft!ZK^!zL7UDZfa->-q8UKD#y0t#tWx0>mC_g3!1z7 z-I#{jT-On}+Fhg|AWV8fE=0VafA!cPl2Ldj*X`UJn$FU!>VDdKBd9KMx-}dVP`NVb z$&Tx=(HK#e3%w#YQjhaRHasFa<XA9P?}9@<s%l|uG2Z#=6jS;$MqLc=Lhu3uE&rij zqC^Hz?t<ir-63oC4F+x~#HMl0-`xXL;eMw$rJ?PpD5NUd&p=M>@hEAXr~Sjo83hIN zfMP&ND;DCoIg$_2AF4(92(YE|2E|g)E%Et{b6EZc|H$09G<RhS(7J!#GYV||ar;vH zCPNv4Xd(gn-5IVmCE0aE5d+@xUX^wt**ktznyc$-|E@aI58I;anwyhj4!yLe;BJyO z7oH?;+@m@2GcPy_W&_B65ACx9O&oZUkttrEm<QE*;I98h?nJ}*ofQpyYK2>o2;SfL zB|$nIgo9zMT0B8G1CNwukd>4@bl}h~Y7>RuztUL7I!9jl@_}HsLFPq*zfiP(A;~TQ z`zFj$?c3Q!B9T@HQq@7k>xz(Vo4rvbYO^qV8-_c>?1IS@{9WXWHa)VsD=ud)^x5n% zujR*yyFF(2b|Ri1|6<JY6^->%Ou1o>HoQG?{#MxO==#<Gf8|SIiy_RlCC6-9ku_)f z&lVY5v=}SOxG<>q-D0y15t1Pn8b^EH>v=~M?s&)4GBt)H2}QfW@8fIzlqAGrj<eXA z?%}woiD1OE?nya_(XIDPG#a4+oz`udI5VMX7}3+zJK`h8*s4MGfNRN;iEp8o;IYR{ zhq7ySd<Rl`VN2yq0gnZzfo<<hb4LN*7SO*u$uZb+Y}>_mI&x`y-AaSAj+tXw>*zPk z@rGpfCniua;`fQ-Hyz>XA!h}d;1*U#t;S^)J;YC$Qi$SNnKCoQ>(|$%KS?Kp5c_=C zhJ*K!wtk)O4(ffh%WlQJRGUJO967hRz?lT2-M`gVMY9^|kEMPj@AKK&eWQaxrK5yj zz$6zW+zY1r>~_Y&;<yMLM6+sxfrTxw7#QWd5=^Mo8-ryb!b)N$@tf}jVzol3mH?8{ z@VuY_SS%Mo9wNu|ZCLW5-<hb07d@#|Y%rb+eu2%>uCTBurEv->p(Ktuf~(B$zec^U zS|fRX;ub}baXfElh>F?g+Y()GXf(6BuF<^!8w9bPfxV(_Zz%0s=f*$o($pX^#*@f^ zE9A}{fnr@J_?Wy^dISg8T$9^;)94n8>BLyt`>_=AKSHo66oTnQUuxKLs=R8eJfH7Z zaeW>R^ZKPed_NHbso+x1*Q6~J<-DboKE)KJ1_%A7D5F(|RWIiwxgGpjiXk*#rAgI% zv?g!OFE>LDqmL-uSwOU3wL?krWS*sIc+|RDf2{A@y&#JNk4k-K#-#Y`>jRdQUqta7 z^YgU5=Fk8|e{nJcON}PJ^+Tv4`^x1<N|^)`WRomr<U<xEC~Ey?2PWH6fhBrUGU8yi zHcbNRkiq*}_+H-@814BOaEptI@y`1k0l<UIA;w)t#-6oVfwQ5m8pzz*1(*B@2`91N z6oQ;jiLybK#hL?$Q}BLo&WK0_BIs;6@T=CE=>%wT?BAz8<K%n^9oNW398)^H8t@q! zTB)nw9rb|mM3-v!=Nl;AM*>B@(+r<XU_N4$U6TY-L}7=??9APO>53^@JI6;`C!=;o zf{c%-`sb)v#-kP8U6YWgR({)XDVf7p=pBL7gmn@cvjt5<Pj{Kc8QZRx0p9M*A=fK^ z6rlCvW!i!y1wJL}1NkePgsm7}y($0)>;O~+19YU-$qP<vycAO)8KVe?1EK7}gwA6! ztH#2rM=vb;q{47*I;~t+Jl#qQ{!PhqEg_3S^UqIH?pZ2H_<v2*^VZA2?(Jh$ad@%% zUGm2mDw25doETq0fy`arztkk?duZQ)8#bNA)7i{wOU;(4tXYw{*4=(I%ldB#w#bqB zKBRdnoccqzIRfbi8^$DDHJw}g7@;V0%4#mOqSZM8x~qJ45^C~)hdov&Jd73X*i96J zz}1RF@Vg{{qI=#be<SpBc?9R`udh0ja_nKNS$4@mW*vAn4>C}*%hOJM961D9f8k#G zxxPqS>M{AFmluPIGoeccI~?JTJGq%YTX_s*OlpD|fSNhIT6nifWY{??HsVeJ%TfC0 z&tHSF0n4r^kNG506z;Ildw#XyyCT)plUVAQGD`GtC_QdgSGw{#+>v?JNkUDgQ3unU zbbQa5`8#VZ(q>yUfYh_N*?F}t4A1pTJ7EL5g)v_&M?tbJ`;>U7ZpD{mTXbJM?t%uc zT@J+xi4J~rIdB3uH~qU%%`W4NDXJwFd=sKL(+R9Kl0&cO+TxNsS7$8pG7*aa8UpbY zUu=7q*5|Gx=0JaaC_em?HD*_Zv{BgcIxvclOe;kw$M3R!e9w)M(TQ%01pY1iUR$|J zrw;~JfYx{j2rBDkKYGhs-sAZBE8#eDx%PEK=ri2{kzM!@ogdc-9^<9>PR5#>j%9$t z)9Y0kT)(XozCZi@ua!+(tbVT92NMQ!=0Bs&=<3Ncz6!yJanvsE<)Qej?k@k<oY~>5 zzzWAJ;?uom13_Ad-CmW^xsIebB7>6{$5-muZzcgoTSAd*;pPLR2v}js6m65pUg$f> z#(4C;4I-l>v6Q`T9RP8&*2fmwMxDRp(Qo`<buy0o6Mt^!Xw)GZTJb2XcvrE%BxQ6} zdyU)H>pLc@>T!D94MnB2j~j<%iK$&Ct3hPfV#Q<G*kXl@+c`@}#38nlR3nE+*O4W+ zm<DOsF`_+}(4SGLSDAfdwxJFs+|)2DMHBFvib@hrYn%{HgUgQ*@LfsDpdQuYQ&1dX zT6qs)-h(9{(e!n*$j}^{D0rl@vMM~p1_!nwApowO8PSHt&ErT!8e27n1~kh-ft(sd zE`f*>dYVP2;_@NH0}V^r^Ym$cdQ@q1NN;FBuPG>333Ya=^?@TOB&C6J<Rt?Q3gU8y zEgBy5BXc?n1KHRWkKA(BltagRXAG_rlA93QK^xR~1=2y{tpm-C`2&FX9eP$ohaf_Z z6_+TR|E2B0C*%2M&xH$>4GC=NNAxxV^Y51jalOIsok2bB$U0nEBv&_K-b^@-xKAu3 z%MDqOUpzPA(q@RDe{b5Xdw^FsI%nKkp=Tg^{L6QIUh6Tt%K?=Z>iul&(PcKDg;{RK z=wiqJncQ*rr30@dV&?E_`&$(6`zhsCuV<2^OB@dCceI%iYk?sVKQ~l{fci}xt4bT2 z5)vA9PYsE9^%h=@=%!lunivlhx>*@rC~LHsH$*>zXxdggO)kc|`@701dVjw$Gjfsl zDF*Zxbr~ecFKc67?Uf-1TNk~L%Y0ezSaD&(4{@VjyS~J@>GjdhC8BMrf#(XC46&K@ z-@##uxm`7N;PfxdYB0x92X`~-xdq~gT-E4x_RB6NJz)TgB6lL+HzyE93XQddGwPfl ziOsb<vdM@_J>!C-MXU^8oL%HX;k=SAddc+*Q&QVwFwR_gW%f&_h8vXGx8@qsfAsP4 z6_6ZpzlqI0Z+9;Yy<y%vj*jb_a5oh_;D=TN#o_$B)Nw1Va8!!J-Ge2p)a#}as$VqM zI;sm)1T`Z@sO-nSd>R3{);>e%Ox`=$FBUMGmmh)lSmW`COChkZ|L^JiYrRdx3RJ2B zR%5^O33Cvp3z~wIgWaDo6E*sd4CS*$gNwS6Ki7w`@GMTtoB<~1R1K21D4_|^6<$he zblB2<eib!)Zm#~UJ<S=y{ABx1TYf>6<b$sJm*jDcGTTl+Z?dnVQw9;@U%b8uj*9p? zM-+>(S>;ODlfBG%#@(D)r<`*1{A&n*U!D2b>9Tv7|IGwN4uu5Ol0fP6>s^mJpW5EY zCavvOH{uos_h^&X&`nY(Aza+HWr-F~OPUcZzq>B+Y7w3oI>llASMbPSSS7OC2-bDX zvPBd6g#GD^NS`Oyz|3Xt-qtPwGEq9u+0*D0H=rqN1*H0|Xsr(cLc*3m$M6Jw|8FZZ zLH}L{xDaUBF-^6MYAzkii#G2J1`PeiR^5%CaI{DFQ~By6sn^(<!E+jv8tf-tH{!&A z_*txZH}374_6KFm{1=atzMKj}=zUuFx-wmVC5ALK0AB1{8CUIb@iDV^%v|1z0_ob8 zU2JHpSYqTXTsCb81Ab^dnQ|I1((g^`^AC)_T4f!ZFwODFBUBAM^~Py_dPm00J-q3A zE5}#{bwe?9QGBXAf*W#GF5`c#>~Kt~i&RIsj|vBb57$jbKoe=)d`P41h<vJ~A5TM% zI1dk~f?0I6@3+RIP!q7!A*jt{rs7&|&LrQZBPZDd-Yg{(3V7D1PEp3kjgwFMxfh|s zLqkaKkN?i!J`g8_ZsQyt05EaL3vcf~h)4^C4ln$E)B|H}4N#p(kB?i|fEw~n16wd# zf!u7jrPdbvvBexlP!ibIuP-J`31(nf520u}cH<IZt;Lj_o3|WdS3cc-L*%<uyjCX9 z1^5b<X}%DKQTO7&l<O4SzOw!gmuiC%d3-%DHzIsA5rIs=L>zi{M2p+0cU?vcZP#M9 z0PIZdGoln(lVAO|z0vV7D2q}~IMA>G16;$bz>#ql3|;Q`p?)}(8^DCacDVNg%iHwE z%T2A;1@hy!L>*<<;UQAD^he>^oIAhRKsqCF(o3=sqjYr7GVFgT%u-|$-~Clw-lDBF znKsj(kes{U?KhkwO7^wXwtIsQSkcP0ViMIjYuv2sMcS!KgEnR0T7spJdoIl2?d(_x zSZ>^bR1@K+wN{~%5Uxn6<YJcbQKhS~7qhqq|A8RfR|PlAS&~=-y<nMWYf#)+$v9DE z4aN9_kgN?u*>sT+8U5ivQl<W|d%@bgGdP<Kg*r#Sde><C*Pv0KX9R%RR^zWdugHr; z(63qZ^rd_DOo^(7{ZT5kN!-pHnHO|S?+yfJ6f6tIBY^mH$<InI(1%e=4jDB$iNv53 zs`H0AfmXD`Kgkup!c=U0+eP|kuJZPr*;c;2yxhBYf2sW3`O}p-iwSPp-R@)=k`n_R z^NQK$H!Hp5-mrE%9$|D&FmCg)=_biTRrQpG*t#W<j!{TV^28ztds=F^yZ14k_Gv9w z9q7>9GX@P2J31zH#yQpe2lfV03eI<CpNN&^Oz;>aW*b3%b=YhoewF9;JlM_;^ozf& zvP|(wd6(G7*_BBOBKq_#{;k=YMJ=N=-NguyD`7+}G%)=jSzWHpDZ1Aj_VKB&_4tcR z@m=^*n7HSC+t21$Q~!)HzYa^>n1vNTxX5xTRLUNt>+%6IVV4D_^hwq#oo6^QU8(D^ z)-?EIMfspi=jFvA)^$lWjXrlg@1S)(Qhok3b0s(xvNzB3q7yH3Ym5*by0B&^$ugFK zAGs_`?9z+5{sd{F&xVo4)!s{GGN3QrMcjFIRiv-I`H3L3;m<P)$hX=UFB$O2$1Ao# z5+rCI3vvno_%O$z(DPXhp$~7$k@u=ng-1O+ylO0xVv>Cj2j~@Vc#vudCIhJ_$04`_ z&_+g);gOY<%G*5&*10Yo%RqbZ0s8ps|4Fz}FnHrGHL`8HyVbnQ>?q*82N>UL^O&sT z9p$?ELQU6nUZ2_q8Qsy5ZcE0{FBQu5Xd`6K+(bNAOpJ&ox_Z%YD46=0-95bhtMOvb zmwISMy~~otRI*Z0>b_-a)Qc^R9p%{+8PKDrcEvJN13?j22;7%bS0%&p9d6|JL~#=w zP;ejUf0WiZ7!*|k>#Y7-8fr6+mqgt#uuCG_yHwtA1mb<L600$)hxQ_^o^HaW*dtRd z>HX?neM1`erR?O+_fmJPNFX8Uiw;62YZ)F_RdCFF-Y!9SY+3kEAT`n_(mzMvzZuM4 z=fwT}!Rqc6WZYyh;{TY6ay^9D=Pf9TDbcu-CB<CB6OG3eD=1y0=^6V{MM9AzJ68tm z<gj{v(#F1+97qu@;Rbvglaw}^NYdZcsqLST^oCq%47(Rc`kv>#n{iC~qnNHo<ViIQ zkZJ>pOUh2H0F|S%3o*I%sETf`4#?cIXg8Ti71N><RcG$1hZW&vaHBS<hLPd-ono ztnhK1Z!DpJ+u;yk5rt$3XO3LnVZ@CBkq20EAySJArRt;IRC$Nj=;IYt_d~U_R5J)3 zC>qo2RGhfSCE(pji9I6>5W6wCSs!?#2`4wCoNSLybV}l(s~6pymV8txB7dn&ewClH z_#qwlYaACgE?n5pr9Pi<&*Kaiu+d@xH*LNx0fq_8WTkIqe{2P#ed;Y8$yYR<Oo!Uf zaLdklm20CZ2F0i)m?n$mA{u6v_yfGR4g!z-`Er+bK3)>yTRC(5fb7bwcB}|%u`Rn; zV`TLEok`SO*wB^ax%kkU5qP>6w-(9RgevJzk;<tcb+RLR7e)h1DWMJVqLxw1>L8|U z_YHm$6C!KD^Jjv;$iD?vQ^cw-_p(_X&ARl5K7B3s@(>72zz%i^_>1tlyUjD|hB-u~ z5$YnemiGP6GEf)Gc};OvOCp7A%HtLsp%Xf`T~+<<>9h4;vAMSz$@j*tNR9uQC-t=I zy55X18C*E>%vKDKv>q>?d!2qknECC&(Nprr$8g)xv`KS-^)hd71>-NlU)8cwn$m#d zvRoZx%^8#5812*eO^EZ$25Mj^R}5rCbz;F5LLc<m3W13$bV2Q;0#-GmzdeLxfJZlw z{GaIa>fE~zEFuL2eY^J7CDD1XmJX-+cdO^ne=i<5bj6r`KF(45bEqOc>qEvwdrT_= znb)SwECjUs)=D3vuur3k&P`h_){m&iq*m3kEh$p`rWY0%-cKKp$Vf)aekG#!-fRf; zCS(+UsicVu)I%Oe6qRDf-S}2~!8&=#B6QWKr*l=Im*Gnx>h7Cqk6p^Ikw#ePS581V z&FYMVdHN)X%jwULrP&D<OZXa8i#|I_<7zhNrqF=vPJDVxPU$#igsWQ*QsvoM0RWzw z#*JEuHd}y$A-~3SMzQ47uc9I@-S;<c<(+v;(#@>sO!6JTG%oj4zOK*P9`;$FcD?5? z(KhV;9tJp|VaXtIM3Vb*ufOjMuWW<G#q3pa!Lk)VjkJ5ZbArTm^(CQm3jNzDxnpUQ zrD2|(cgKosvFqfM4IJPTbviNIlLp$+q$QSPj??~(A%8f))8;A!oJ%B{&WxMX%|O6p zQgu*0<lMAJQ?^D(%7sYQE+-E9KkF@dfv~DhwCSu+-BZ>51EZs_ki>ErbIgIFucPiy z*URTcVGH)!EKBs`{H9r!T730}yUD%VV-xgGO+35JI4Bb?l!^2*u^i=zgZm3MM+m&~ zXBA-!h}0r@sJ~;OQOjIa`=g1`AltUURY23`IY-G;^KOultlNM`9S(~A56g+%02()z z&pyaW<idn2+S!50QFhx_d$#gxg*OMg2rke*7JK&a{F4cHx{D_FIe5pKBCNg#p!PTQ z#`g>%T?!KKUhcxm*|-s-_j+|i<4^M@rtg~YT7$Fa@Rkr=>We3fr_S5lm@7{?qYlxd z=6!O;@ZqdGg3Pn=*OPpFBEjx*p`|~zcw*Vk-hk1+m79^JF4engnerHHwU)Ikg1ckI z(#00d#Cv4G_vFRd#!m`ul>FB!rYH3`y!i87k*UTmeVb@`e&g1k|2!w0K61|%!INTj z*PB#3mnrzv_vnAo3s%{``Skj_mn52wid63#`~{_Isn~PEo|2DwT;3qjn;CKeD(CRm zPRiwcZCan3j!ciF+nbk$^99=if3AP5eoWF;>0GO$n*Yx*<x}fVgpRF(DNT4{e9nw= zD!(k!bys!S*RoE8iY1|u!==L635RP)>SLuU7q2`%8z?hYh)SDpD|z(W%{ov~zw}fT zZTVAg0*<DD286?%o-r6ffjkOCTq(bhEk4l_iLx|^>ppvT0bkkwX8{&!1XiuR+dCG9 zV}A=w<f+2-O6KxBd%K#{Mrqf3?DC_N<txl(KRw+KL6MOt-wZy(=Y3iMQLtr5=-w}I zMa*W0M7Y&e2<7`Mc^jcv5PP|ne!*o~ipjuZMd7xuWJ#DK%`|ka4P=YDPqGxVH}3T0 z8|aFcLZpIQ!P0T^_BvEUG3shWpMlaf`|My0K~u=gBGI3UspYZkot}h~`i?gb{jZLS zwZCYZ=gymW-RdeKJKH4tT!3LR^N~T#<2N~@ru>?fO4T}~D(;+vWr*f5wW;H;7`OUC zjIqe0<T8^e?5hgmjqO}WiB4+KR34Mw0sOa2#FV1XmEm-7y&h(yZ?XYK8|P5Sz%LXQ zl-{x9UEUEu&rB<(y=lqCV{zm;N_t4tlTlR#*XhcOAuX?QX#!=Jr}uf!qg7j$GGSRb z-Q`xP&y@}7`f{HV$X*1HGeXvFcT#_nh9r*eCo^1<#LVW8wj#a(X_Ux(90x95t<31e z1uL39sN|@D(>q3Qxg%zhj1ly*9_Wv7g<ocljYz}#P5i@#-kCqqrk3zAiSG<r0{#tA zojrHM(ihdcoYlBs)te)GGrs=jjeFRQ4I9%o{ULyIb-(R^G2+WlVy&J=gvhT1&xTU5 z1EerVtN`8ySQ-GG{!(foRV8JyLu*MFyXQ}dpDD;-R=6Y>wsb_o#k(iz%$Q_)#WsKa zdB^Qy-|fPTOC3=>R@5#;6;^t5v)rhoH4Jc2ydrhkaT|~Q)!@!}6sb7f2LrVkKaSyI zN;B3?{LrBsZ<kNGUS;}TR3NHANX{CyTQKhf{$xZ`(*b(2$XZU<?QBI1P>V_MzG}ae zID5<4bJwMik##%h0%h*JYl1{zuX}(b$}6C7q3p1BNCuw$D6sXcfSX!Iw?Ar_>QjgF z<|&KfC`?f+pn@~(>I{=DxZWzpQj)^j^5z2aIsmrIJ;hy9z#^3%bOEhkEw{Sd{c-{G zS$#8R3BuLJTV7Ftt9kANjPmOTLvjFO1Jj$iozbii>)p^hV8=D!8t*;dDaL#YjU+d@ zkj@B07ON=0r6|ec6jGUGP*Hf>!?gR(oRWA-qMu@wFki=D(ydaSFWKNHFatZqd*EiK zM_@AH5^=D?roneI<1B!_!;jv&4$#&Oo$dv971s}En)p+4IX)L$f^O$z5G!_W%c|Wk z;?B=syGzc+nIC}X5c8O-?*lL{d<<vf6Ny<L?}%3!lmvU#0=5_|AkFR+kc<BKKbp=m zD$1@4!$Tw8-6}A2cT0D7cMT09sB{h8-8rOmBa+hH(gM;Y((pa+k8dr0%aZe)eRf>; zy$SyOhKtT9mcYwCs@5@PBjsXgpt*lc$m$#y_qpWN9Mw;IYw<5wz8`x5J`l2GY%H=g zus0#ZR;%aUqc!mk*ZF$5`aAe-k$ezE?O3#vS~;A~!!!JTFSDg8qr?w~WA$Mx^ryB- z6;*ub(H+lHVg{-53x0$8Q-XqI{ef~#1i>0aiPhsh(Jya)$pV?NV|HA0zMdX{fEMTY zn}xFzL1DkGPd?eb>}6dB3T7pqoGG&brK|Yw8kYwHy~ttfvdatWV4y4a^(%jHcrP$T z1Yi^1DX>UDHbR?${y3-ce$jxpx*JS^J5?UG60T?^68#^WlRJ#i^=O^|Q3fV9Tl=c$ zHzjVx8Ze8GkgwHq5*B2@Oylz3VdS8S8>a(r9hxF(1O^VOf=d%qqukH(0qK^)tZc)) zZFw!LYoWK@32a*T=Y;TIaklL~s<{gRsZ0mZf<R}_ag|Vvf--A(B2maCJqWkhr#518 z@RL_k<{6%31C!cQ{pRN<L(KTN;pOu|<cbi3$V}=gC^OQXdcr88v>>56GY!<N)7d(U zeot9f{WmD_=SKeba!n=)*omsJW`Rz$4TWP~i0Z^3a323Pw|b0d56~IjN`Sky9OOOc zif0`uLZs_SwN+G^`s;g3BpV$VEBn)!-WJ5gHui5X3RTtzF@0<Cc4GS+!9gY-nL>vm zA6>%ZTogkvrbS<4uN1W^wA$8e>hugOH#NG;VKN9Xg_{A+#Jf~`sl{At|FiK+I#b22 zgwhK``a?b8M-Qo3ZQT46JYZt}a)N$**NGkIA7Mp-_2uc{Hs1ZCRZKb?&*hT~xsF~^ zayKKdoD9c&k@NA-Ekk*j%s>wZ2<4gdKgIwBU<{}xb|zHO0Dfk7Y-w@2#-GKvx}*Le zsrI-JZUFAhnYRp;!QXqoMFQ5$qMxk$r_Z#Ys7mH<i!my)2UgaCJ9~~{%A%ynrzJyy zBV}1jRxn>}5Pu8#f9Ych?-})w5A7}XPHlB=OGJ$-<^(iaLPmnG#WL{SfMu)Q{v07g zv*vPEHv=Vy&;nmy7Y><0<_uj%u2Wp;fVSmMGAJB+Tx1fx(h^%n&h1hgs+=iYY?WX| z+(u_X?qrD{{(C@w!d;$F;=nB3I}?n=xUropq;@8VhT}m~5J`9t%#4rfF>X8>ZnH>f zSifH0vb!tc_|RA#6UdrtKc`#7)8|~U0<tv$)iIa$Jbz+oc<F*KqGl>JWvz0uI2v`k z-zu6+E&8+eWa>EWL1$dH`{}FuB}EVrO+R0Mij~#bT9<pP{DcbBJjLQ~+;81tPJIZE zClodHPYO)k0og#Xv}1c5-K()r+z@;g7wP5Y_}cY#T`Nr3j*;QMaN)BgzGfdb!IQid z#~XK^tIH<-eqfM4(>rWV_L%EUPT1vDADixD1R!mh_u%v)W%MkF%%-7}fTrOd!R*xd zk|XOc{_9Vk?%ouPrCS_X+H}J_rTM9gpX9-~m0rcV_1GDUZWN}nfk%_utI@EE6zB$w z)2VSJfotE@IFba!D=H#D_5p2c)d!uw<=B4VS5Ch939SJCJ3{2*a!*Zc*&qHx<WcVz z+5NxE4s|#bg;FY%Tl~^_<6Da`1(blC-^v2NzbS*PTiFImK}w9#Vw7mzoiK^bC(y^| zoCNHCSNJg`AO8Ne1};zuqKiA+nJkshAEkFqsMWj9W-*YBWP%m!C%v((;El-Ex<6Lr zw2*05`BlGc&5$%)r8!Ey<H@*s*A9?i$LGMxwEj#_&E%TuA9Stegbp|w-w(7t5HJti z&FdS$j@M#KN{s=-zy3>(-mk9V&l`w3YL=Zwa;^IXYZueXNH~B8`^mNEhQm)5+Wk8l zm!wD}Lf2gGa=eU?(mVb4Z=})!@&nW=0xwylT`4RBI0i4>OmWsL+n1en+^ou@*iFw0 za=jKcc-i-h?0pK|n%XnzIL@)l`CPQ5%lL#{wtq{brOuM5A&ldR7Rn!13rAo7<cdB- zCmNUfLd>12JFj3pDY)dVeq-q~m<SK>>+3f{j(IGiORpR(c`VLN-%7<Rgh&*RM;GOL z9cTy%ziT<mK8W7et7Szib`nBaDP3x9WL`eYfc4j&8ytjZZXp{tq~(r;2B5D*MDg6% z`)AmCaf$hA+LSoFM57gz+$uQvN;5-Kgfz2;W*>|d)Y$M^up+u1Sc#)F@Ry`-a-@aj zQZ?&}g%+JPtnv(&PZuxDzH9yfGLa|8y7-7;tx%>G=Vf7vAGlmINbu&`sx;A<Fqf)3 zZz+14D#v@1YqJAN-TQO-A2D2Lk{Oj{)!zg)aYHAcVD&4o?ZI^-(_avanzMqVcIydH zE2?KAHIi6G#oSN<!NPC#-8jwW{m}baxg(`?HF$M&+U@XeFRXb^^{vF&+Y#4q1iOm$ zl`x%9>Vd&iG9VYW+=-|VsBP}eco1PyvD;9B-ZW>rW;sb}{DmY(ZL#n}5fNdrX-xL5 zZ^AsPWxqO0D;{V@dI^P-UCUHH@Tqa48GF9O$>h55eRKS3tIT!eY_g-sBrx%|QnkVP z5KgB|a)KPq&7=7Xus=F5Q&7$`Gljo2<rW~78t;AIjwB`_%#`6<U#D(+{FQ-myA)+< zH>h|;N0+oo8Gx;{=CXw`fk~HNGH43fy~BYc%1!8UI|8>PO*V`6r3ZwDH-je-m2|3C z6=~=b6QbN1>;Xng&5*;Zi{B>}ikRH5bI=j3ZWaMr@ypJ--&X#8Td6EC^2ASdA7pA> zg{nbVFi<j_Z)|>v?gN|TUfj{|ulx~16W;vH@y~QO|5>(YEsUI9gUI_80y`*G(K`Nx zETT3?<ZY)xZcoLy5|h%dGM84nKPyRKzvs+7&gYoD9vy4a!YR3rEDy=LzZooJm4&IV z>3d%LGHwmsyJQwDmK|y(J?kG`mDXy#crh-<S(QMoB`dVaY;=vS!TmMDDf>9QWzJTD z3k-NtT|rZcVlxNGIPVv(>pVbx$ePYg;xc<4XMZS?`%ASeWP1Kc-ot5-yH6yyH7o=! zk`)_-+JzwE#D0l+Lbb?Plg5`JOKkp3ZW*RzY8x&pw?U%&rxclm*3x0`Q)>8R=`ZPj zf;jL}<t8Te1QHA0(-lKS!N6;`NKREk5XK`^3hzRWK+kNosOF~p7NrL&q~?5>$3@P< zTiYI%c70qN7Y{E^@sn#<y!p*H@bCAe!8sjp`0E}^t0}=-B$RBq)>;BBH7MHYgz044 zS**%stk3I+85DE2!lv2QLq$U3wDE;JW7-6za?zTDDVi-4ISYu!^!;N&a-Ni1B*sRo zQJr}?si-Jvkga;g8mC$$+grQDRCTzye~z=U&+XF;4_%-lSHKXafl+0s{saA<i;KQ( ziJ5kt`I_5AkeM!AmS%JFr>EbWa~1NxmR$_r5;0{lJ#NvZHGW;R<bfSH&?*gMG3=?a z+PB!JH=-ASSetv7#|^G;0~7?)E3Aro6Go^MVM(f00&uW;7EBAE_e_wqn!rdjq5Jp) zGBn>DeLQD*`F&m}x-)<N^NwS{&vRNY!!|D>lnj_xGArfKp`eCx0_%cm5UNqG<qK7I zHjAAg!P=QU9zp7gHJC447~5zyU&%<Lnqp~CrzQN1<rwGIVBgT$ssQ5P!<76ZNDl2u z-TU+WfjVsB*TZW%XajVyZ%4@}|M?%ali@M{RWzv7C5!q`PGMQ*Tp2P>tNwvF_xJlu z@?g?Z4Vj)_$X3S^WB&D-=(M+D+1`;WiYhQzR=%8!tt~5Z>sH1V3(|*uC*|H`e%+EI zdgmmRdENs}915BS8K)K}Ted8E39hM+U^JEQ2=#eM=JuCQ863wBSI+o4A?8A3T2}q^ zsS=#VE4&0`Qt+BppG3*}J(eA1Dx~b8qCXqiT5ebNX@><oJdjhWBSv`A;jRy#>%qs_ z$60SQ83UW|&OfCa?5C$2DUDy+yDa}|=BTR^Y=NBfE>(zpW5z2k8IV3m6XaSWYj?Mr zR5*IjJjP4kDKp%exQCd&g}N7+YRyY3);QTZ8vQpcX$H!ozv8CEQeG1((}-YWve2SN z*kD=3ZqRCsGG7GLO@OwcNIu6ye=?xFJu(wC{KTRfn_&cM8*w08C2CI4OcC^szse?S zKFqfC;k!@_!lU;9-0AMaVi8Jh^>EVtI1Dh(KF>`>)A8O~;QySBy!Y>`58rQ24Ic;` zF?7d7<daQ2ax_|H<f!|qc={H)Pm81uR-ua1;8amd&s5N{Z*mYG`ix__A%5KkrVp$P zDC#f-FE+(|CG(y<yfGsomgcarQjK0zQT?%@+tUlDM$T=O<-^|CCuG+fQ)*cFbi*|@ zMejJqIcxkdd&1RX;Qjj`UZtA*`&q^@$om|_ZGP~eVE3dED-x&-r(l@<wt5z1@E#jn zV@PAOhH{o)#qBnJveIa?hQwxaTwk>OjJiT9qEqBH<doDRZFa?4b~`~KEL?-ePt4Q5 z&r+EAr=1(Y+QFnak$LjrWs`pQLoT&mr~?|6X5d^R*G3a4G%@m29@U@ZOys(EB8Qzm zp%@-?wvkPak(xFuRLhOtM>0Q%shSlN3ai&{2_IE%Rv*VK4Iclb<&F{03XuuYJ`-DO za$_tQ&GpaxWYYlVY*X#RNG34M8~jH4(*x*O#HI?`Rm=;&*Ha(haEDDI{UhOmg~hxU zci^;>X~glCOx82L*WGVyFUUx;(8rT{-$4cb=KA?OA4oAffm&;Fn74Eu8}>%Bw2X0A z0vgLntm3lGuIbX^jsF`ix&5cdj)`_wEElBIFa~BUrjwykuWF<DR{OW}^;zMp_x_H} z+J*CrEAR<}C{p`=pB1ZA#8rJPsKwRcaF*@!l2iGmK;plkfMEw{@hs7OV2tzDoE2<b zMj#1@s?GAiUty_IfH%PbV@@U7FNtUyj}R4PVKAp2?U3l;&u6VG(f96<L_Q&>eD~3I zXBlS6xRKF*rsUlmpVxTFI#|Mk))X!Od2*s4MOP^^IFf%O?U#AFQ-WO)$8sb_;C;Fh zOkGJMBJL`H?5lw%(;vUTG?5ydbDP5?jO5#P6TD{T{6m<ZsNyD;8JlCtn=RTxaq##4 z2sZwG7H~_NN=HFnDrlKZ=G>$>p1tZ|c=B%?;E$8}k;R{34^-STnk9iw_}EQRAsS`5 zEh#}Y=BYxeqd_Y^zve}mD+fo|v1FQj5=B8bnFM>|hq@~gbUIZsgnb9%W4d~YW;m4K zX;`~ksRW6G$ng{h=FZO^`Q)&<z3rxYC|Y^@RAXjJoE>hQ99$D}W!}JjGZUGP>*2F8 zgv!oJq8{NF1&5ZgO_7)5uZ&@b=o7F%0n^RcmpanB45zdjj`eEXu{Z<NCP&kKxQeDB zb22*ZEENL{FjcK>gYvgbyLwn!0F<;41cOXasUiS!QbdjFPVJj_q~@!d0mcx<L38&9 z?=eg~uL8yTc7lwZMbx7g^{kIWf?vzD?D7>PN>U!E0$nxGY12IlO`RHujmx#aa%h5) zN0&wxWpojR7;XDXGF61u_fM^keK=v~MZp?Om^M@l3#D=kvg!rUD-rH<1Up^}rT$cf zYl0yCBTq1=1a!7MZpGSZe7^SnQ<>a6fR*N|5`ut&eP{9q$yezyfee~dp^xO*cBW=* zqDnz{o>u5|u>kw^q%Ik$@BO*lB#7Ao07uhpK-B43zn9;6s;)XtGYX?sy2N&3$?OIx zYI$BKEA?j{3_|WMH-oYmW-8ww-6(FGZ|&M|*}=Hinv1g#+5$rmVr>p!;28Tj{Oq+a z0hNFP7EN3mz~@i1l#mN;6v>^B`4~2wI=|lYu2_ptkkJ{9ZVv5dd5Q&`$Jpk$Zga1O zzZxJ)10DZOexn$bJ#}tYo3(l8RY`hL7uomPODZ#cN|3XCco()>zK?q%CXPf09-qE& zGi?*;u!;5^=Bdv_jqoiaUR1;`j(2CbAne=z@OH@vr2GCei=16=JSRZ3R9uQM5y;2D z1y)3T2g81O?kk7d7qg{Aj(O1`LGi8sR5{V_`m8Jc!-YON{>nPc;$l6~hTwtzW06n0 zsQ>`5bANkP7eQx<c2EIwwyq6Hg(UB17&EOK4$Lnf@mEYtT8lv!QEG+b(Bz$Y>9ji{ zs;Z6`O}y|te?Ow&0}w8|{a1GwUG`V3);#qSLK`8a`t=+cG#kqtYW@(1$nIiXy3!el z?|<4PA&$z8S!G%eClWnZML5?r!yia?+6Y+9b#91oOTO0CHJd0GnM%1|h~P99b!1DO z7)R5_X0j3To!+-L_h+NCr4An)nJ_Y=c!rd9HC6nT{p!g)3M0-98F6#tr88clN=0U# zYqqiachwtPwONqCUAb2Aa|z0HS3<{AxxN^)55C!d3ZEbh)f#QLMKK5D(*SU}mdgYL zomcx{0KEn{+L&&7W5*cF3Pyh{G<EeW{C&I9;ma-i7yzaMP#+|m$8*tu+L1+_6%vVT z1193-jNR<Df{D#B<agSmYt{JHooA7pqxFThw>V3Y5~VEy9G;&VgMb<kL*$oeMgc!o zwMl5p>N}%EUKGAI4@4uf*)HOF-v2bgx8^ZX)W<unElhygXrw`xfZ33K(0PL#`dkLx zg@E;#)cMaTZHg@?l^kDwFA2TPcu_8!6mtr+r_~uc)Lpg@Q2jXY>ob&5b8W|U_Ced- z8dtt>+-z(ViNHJ6y;)7$1fMq%%(Ri?HjixQg4`mdUhDF+8nzRd%v#C2LVM<?X*G%% zLEu~P4xu8l`DbNV@#r<WYx(}xgAXu`LYLTLXjQwM6D|iNv={x_VZNC%90pX$_r<e< z+L#pSj@j|}u^gJHsY3u-3$WSvU9Z-tNCi6HfVz|3r=uBZ9juxW*KunrJ<f@dqS-o< z_j`qet!4t8v6i96)C{mYGB3XOyF6N4GBQK-A<mP@z-{NBYF1Zri~@KTF<&le*ApYS zx21@XMuDQ)4ejCFnz9IwH(P<HJnFs&GdQjJaUf8w*SAjH;d|A=QGJbBVv6Dc&Wn3^ zU&jDO_&o~dpQW~fLpe#)1^?K0^S<nB+U1i<q-gg9e6KKH;j>^I`RG#5lZoI`U&N=r zHc;<S>6VKj10T@B7z;faBXIMmY}nr)=QNkOEn*yYx!&fQqu^tG8&^~|na|Ww9*Dls zH^KQ{8wGz*N)rq^%FE`p)|ndo4|0W+XQEOt0USr)>+={O;ykqyIh??e#cfy6l1a18 ziXh*dZ!588vP~RH-oOaB{ek<k*_v;0ZVi=p0)#%Uo2x^66Mlu=ae{H}PPV}^wV=fo zTmpzK0kg>>O6+Xd4hhE*!$SRVDZw?ccK#!52&t5S&xp`?-MP>69RQ2JdL1BQ$J^;5 zhgi-)`pR+=m<L0br8OWv%!iKv!}hNc7tldV2kd-6-C8Uqs&!fX$pUBN&|jbUE6Zqz zDN?cj;5-`QqTxi!%YNOP$8^S~b&I^kohpQHBg`O%6!>SNWZB7KYZ*fj;&Ddd?UbC* z`bmqBurYH(LA&bx#}mNcrEZUiam{`0b8SV~T#lC=YeLgH!gZbpm2^(kr<wki3pW$L zUym>{dZQZcL~4SMbz?c%nrQK=|NW`(ff!}Z5jzDlNpAZ#(`!5SVck>x((*u{6jYP= zW&sX{tn#&AL(n#=kxCxuk%Y@uBC~Ly(_xh3#tn-BcpGjgT0%Yhx>6_W(;<5HMa~rw zpY}s!rQJ?#{)9@Gas=_7vZ>d2i>mM%nYPbaMvnpCkG>)ad2pCK0x<EoyNnoa`zR0; z+}Auo-{WV6xy0vGp=Y9-{L?3nZ|of#3FGeZV9g+iBL@r|?|?A&qpz<B9LRXJVtb7p zvU?@_1ttc?=P1#1m^XAFmuvBCfGMtl==i@vvNUAsis5x=2R7mF{s9&#!J0OP$J7L$ zB2z8IoXJJ>XpEZ7J<#EYpE7vWw7-Cw&DEnjYeGuK%M6F&t5E-@B8kj*H)I~A8T3YD zV8Q4-&x|MGo5r!yxt5ACmK)ZUMwP$;nBhHrYA*R(|1n|ZxJ8V}G?&D`?<`ZFUAGVK zS}7hSX2<UXz&o1+oHYeV0FY`(h*D=_(4SuC4M<};;^{6W&zf60D7i~VOOdCp3eHGT z&?fOR+%d4;bDC$j${gome)~^R8ZRyaD9~v&$<}hwUiPm46WRg9lLWmFXWUzZki#PH z=8DK%#pBgr-cp{FMRl@_Ff>>3KfA=YYBS_WIPd~Xu<hn5lV2UniacG=b7pTg?JZj) zCtxCD6_56<tswcK>nY=4A6sYH_4=B7aUdXKN<w9(oC*hAx)_Rc+qAgOmH3(Toy!`A z%3>%2vMp1^&(;1GdyjEl4Z}+LrvyVr2>RdQ?l^*8&f<1DH;X(5Bt-DgAC?pK71Zcx z3_%GwPHAd8t7piBdn)wC>Yu+BKz;Y^;!^|MfhK}J?K{MF3PwB}Rysz7V4Bn}Q#=|* zBr7bQ$+{)?FI92JMwre`%=Yh<Kj4zE!z&s$nG!swt(hNkY7G3%99Cb%$U?`cnCDKP z-JZ<?1o@EKcspD%KcT*W`wNoc;x_q!8jZoQ8?su+QhlfHpll=j6fU)Ym)53A5a!YO z{4*xOG&#zDVt|bql1EW$fKx|vXS#4&TKaEp91G1}*(Zd>csj*~saRwxIIgo=Moz*n zPhf<$rxEZr5@hWDD@j=b<p69jH8D;%ZRyiB7jD{$p8-)x4sTyWbA47w68`UEB1xl% z@M58{5{EV(gPF(ZUi|b~rewMX87mt}@{jD!<W{89cLws^R2ZKDke>qk3q~27ZJ|_3 z>8M9$?O)==lHRN1Fq{!54;uM*hs}Q@;x?I^er~XVPz$#^upING%a6=!4!55SDc3tX z6}!I%Yt`K^AtnxW#y{L$i~wOf76%N66n5%^WK@GDbc5!Y7rHwDTXt5KV7GwK4n7%_ z?$p1Z9dPpNYPTrop^?c6)ghA_J@G{HxG{=)Yl;I_MhM&H836jK$%)uBx?4RBI{lsp zS-uvn&4>efuqEzN(^ve!@A_~>;<F!|o*}@U`@G0sr?Wooc>Mt3XTKK9PTYQ{p7B5% znm~%jWQp&L&i8R6Q8RPOa4@yv(^ac!lV0}Hd8<oB1>D}u2!?p4KlCvIU%4MuvLw=l z(&1a|7<f@IJL4(;b951YgC<v9^1w$rQhzp=Jg1%1XjbDD$8QJUE6Jq}Icu9=mZT#2 z{}WeVx1nq~YK&IeHx@XeLOp8c4?J1o1^+;JTs688^vtwc&Vr6)nV8I*fcANwSPN!* zWb8JPpAiHXNw)pEaI#MR`X{pd==|;HSp!808fZ~teM)=euTf1pJ|{vc2?r$bI~q%+ zNJ6FiLpyMYJkb5W_-zf9W8nTJPPXeS@S#NPY=ds4>C~goM^LA#V7Y^jHV|M_*=m;D zu8k3d*U8B85SDPOB+ftL|5+a{Z#zDj!-(v`-r7u${nPems3mc2R$W`tMWZJlL2-V^ zb?h+fhF>PzTcf9QT-F(Z%6LYF<8uA~EWpQ^BJ*H`#>i>ik5)>gMD@gW1_P6tjH+K+ zAv5)qZ&6lZD$vKcB2Py6L;@!V@(69wXbA2;v{&%$gpSG<Lnpnu!<PNlt}lfp$0cWu zOa>BK;_S2#@{knj+gqCxaR)L!rD6I{EhTL#d;I&qUJr5;MsELnvQ$NTBZt<eS)lc? ze(~?OMK||aqs9iYdGF_U3y4|%NP6F`jRL?r$6Qv!M2JkKFCi&ckAMau!rxd+ah(-j ziXzvAn}@Y=StB{ph-Z>Zvh9skv2-+%<B^D9ucay|Zsl9hB$tU7!SwFN*db!7f}}^T zo(<7sqt6|I%mN>M;3`HtkLrx*exL;Iqt7CN>CAJP^v(FhuYD)o6c;h2gR+|Gykkc$ ztqJY5e+IRXmDtgLVwD>g$>VWTQn3y=wA${H0Zd(i6bU0|_&fzSQlmsT(}wS-Xdgvi z1k-~e4TeAECMM85qGI+c2$6`&6&xuD4Bgi(Uv8oce-$0s0<?3~TbJ~BGDnTmkv2pR z4Kawr9I3IRW77{gm~cyz4lT+aGhZ^J)Cp`fXNo?tLVIDSR2pL9GN86`DeW?wG^_K; zQ7ZS-DVw;*YO8F+EeHluYvRi1axttqU3!)NQpB+a5sIITN2*OoA7muPkX@V$if9_x zDAa6(C)&(m_Ev0)8fkD3Expq|STaFG>84DLx`dp+ZJh2ZoU{l^JdQDl<vk4*@4Z9e z9a=P_8?L93!=WUKyIHR_DOYR2N%()YuXzPj)p|1KVF(=Bj%DNiQ)GncHX#)<?Wim1 zD_w0?VDgEq1Ftj!%}iZ0N4Vl6<BEAhjmm0e$5CW@@G~~sQOiPwI(i9YmwlG7K6Z?b z!+woNfWt`l`)FFnw#X4Q(9u9*n056#X0d%kg-tIy;SbMj&%_p81EP2YQ=6l#(S~^& zlClOrXPLln<5|`SiZ+Yzaqq#NYHegyji#GLm+HS0%(IL6NRcapB8;$|F-eWr#NAn6 z89=W8X%}zZv1Ms*pm}C9*Ht?=Q@o<zla_lGEv??yUq&5k_OOSx{d0gP&gWxqJa?+8 z%R*TA+gM2dzLit!5bVOWX2^b>C(EbEDXww-x)(q9_g&FbO~nNNbMAHicA%62Hsdw# ze*Hl#55zp^3bpYbc_puvw1Wsv#<Q^aETpD%kq3>pj&*O)`e7rJN-l>z=RWzWiJP?V z>880<=PKWhY;~Vl>Uwom<Zs(G^Obp#zNBglcK}6-fA^uYn#tS7kZ`5z-vI|NLz$~t z!w`5!PmFBO=xfd5j1P`1*}Ka_B`cxtY7%)ZycA99x&jQpVq}6MuV<MJrz*nn*UD6p zO6GqR<uRl6z%FfS^K<0#Sf_ckdg*;9<1Mmj>+ichy-pll-DaTSMEM8kfN!1&Km2|C zWISj1y|nr4t5k}hlFTRpju7*lrnGzB`v|je(nd~%mWn9L;kG|ZzX+fnOU7*ZtJ2Z4 zamJIIy8b%aI1nF0cW-!lCG|4ydJH3}(sk$&;iz;=%dt*N_TgOGtS(LlGVYUfH5XKS z_KxQq%4BWW4BbN=uw>VM_<V9GJKn9G2D<J6Uu6xM<#@S_l+YNkbOjvVj2wV-V+4OY z?#*(tAcjs~P@oX%6#=fUamJ-hdf?Oe?AbGi8Z&&UUq*06o2R?ppiKip&8wJ^$^;J` z`FlCG5*8EC<cRLF$cb}7nQ{$Es^2Wm#RtI70N{A+i2xDiO#WTQ9a<rLu=?I(9$t)9 zCGzBJuHK{W8?uo}>G1&TK!zZB&kMRFJMD1W9o4FPy92n%r;qJ!A}gzGUXytrU&wNK zYlqS13>^T@>zblX3V^!+(%<Wtkf)MUB5Arp#~AfbA83+dPG&vR<~Y8B0JAwS9qGwN zt4#*3ROMX?{Hu-Tx^Y$}JO{zCValrTSk9hipK%BG?Nb2a#X8XVS{Lo9NqHc5DQ2%i zRD=}CFm^a+Uyt(qb0+^i%F`mC*lfa2UaUVbnL_!&M#XB3ph44*;hyso(et+k4Z&8` z-&4D8TUO`3!OwG~SSVV58EA`8QE{^aj~Ers6H<|(_xxtD2{6tB74Jm;6<&;w3dttd z*M!$O#&?tV%vbQ?(U#%$HBbav0tzrqSZD$npjN)lCF5Ho1PlnR%8eeoGltSgqqT*` zt+!qi%If(r%Nwpc5G(GQvWLDh5mbv42FinP%2KY3>?E6P5iON$2%{cXp!j;YvrJM< zof(9zy|%d$q|?TTzoVB0$$LeeS~XYT^^Xh*gZ#6*#|`4$IbwmPPjEQ`HA4vSAK<2l z50<gn8!#OpbSE20JbW_b@zXkdnutdAAaQuXqPaPn4V?ajL*VZ<6Ug|wJ`zr!bo=2q zo@exM5{g)~gu*b8C&`rt$vcE9(#CKZ^kb-hnw4xlv@F;9;Zqe1%wE}C=QXaaEvB`t zLzP6${%xckt}=~Xq}%X8l-YPUqetIPu6paupX%^c^`1u9YDLs^6<P<rw1RrN;ibPn z?{<Q|HhGA=j#p)~<q-3(=*1o6vkZHZzx7EQ?1?nEGZD;-x1$~E>2v)T;rl3wjZ(~E zYYp;^lLoS#w)){!zhbEFMA!kEeBrhbo~o`Bel()(x3}E56S+=~&e>6zbPS9c^qYT0 zPMh7T1qb&|TtEHj8(gBX`!3aO3s<q%`>W3zKTubK1bnA~5gFcy8lr$G9<wEf)(Apv zf=Z^svq5+-2bCbk>(#{??&|J{6m~j#?Uhy5$4sx3JG1G)=f=8R=&w0i^@~P-#jg5< z+d2DaRLsgIA8x=~0`L&r(Zlxp&v!z#KL+lQPsDf~_yz!XfL5r_gye!JjhFG$TbsCS zaKn^5T5{@QLX_o|D<nUWIYsrq8M<)^YtlKv8~M@iWq&%aWER2FT2Z@CERh@;p#o$` zzN`7$Gc$-NAqL|G4ncl0mc^&rd*~3LHj(Y#sfHid2^=vAQR|voVITv_j~<57ryvN2 zrpsL6tos%N6#OXOwALiS^45&+S$7EXz{0C8bMK#Bi_v=Mj`YLkCIvbfu*dg>zSY4A z6aVH*imV>#>IM;^ho#%TXyZy7!3xanuxIcf2mrMHb4n4O3ST})0ueao4J_0k`v?J+ zD@^)MZGZSgnjBpmre8l*exR6;0xlB(!UD7mRo>)(B2B|#aQk&GQ>`oi#jkeyS_r?M zcVv~2G_dNt^hFQ6hYjSOC-J-kbTKAp$WEB!QeiZjsC2PWfSng6_Xo+u;)G_tj&bRp zeyhYIWKef6-NfN(+o`T~O{IgfO!Dl|U|hDTMqQizlCicZL-Ao%ZSu@T6~!&}`(cP^ zIajkpizgWGyrhK2nPv)^N~{*!a0N31>I`vglL>3INy&-UOrDn&K<5SE&x^5csttdU zz{S7=fj@i{z>INcagYztvx_g@i5)*ZwJFOQw8Td52bgWd{-;>E>8JgN#XvIoRK5Ra zaGejR#wiavbmqG}!WNm&WwRFeLd=YgPPBfnFV7hQ(fGfjXN3xACZ0p^t;iUEiIVI( zYz`Oia;gr)rKF+iq@+-KpwD|u4Lz}sNErU60r*HGqk}r-P9BLa;Y}nu=_kEmI71zj zPA6XA3)?-?<u;PgJsM#4-bod@bgff;IxB|z>V8h3ruya1;xnYqb?GAZfDb6*CRTsy z9Szv&G2|iP{?}D>i!nR9aX(l=Gz1Y6>(}XBOdKp;j_#>CB;2@b?#RHjj7$y<3{vUb z9J4!RoT66tbZk}ANt5kT2N)Ypwlq&$JZ%G40unU81|UU_Vqfvn4v5xxr+2gi)9Ox? zx4*=*0Pi;fhJG5Oiz}5fyue99o-0U|z8`xUD3z{P<IMA21H1|r&LAZ?dU&@3%STAZ znO78GskR?{5RNC%^3Pupoe*Qcgl)VVaKkglV~nxIEt5nn<xNo}ZL{t>e)>J*{`{d< zAa#EwhHhpsJiprBdlGplADxClw|qyn@R$GYEu&T6!P`G=NWw-<2~~COh$Wz-+7Q5Z zscOGK$8)Au(0-vSRTf9AM>e5GEEvBnMbnaq>GPd+DA1R7KX=2Reb>QD4DfN=_t)OW zn=XTfVrgC$E61+Kbgca}Usr|A`{k|9?PEHphJ0^FaJm&x3kd<h?eZp@91wjb+Z5|k ze#>9OS~j&jyo|Dn0xZyHjsYSkV`lVqY9pIf!Nc0XQf^`V*Jm?2t`_6B#3x7v>N?%^ z*(ZmIq-eyre0g`h=|c>G0qXhF`5eE=H{}yE9U4aR!e-Y`YNZGR`>=jfkv{Hsu2qhr z82vJSuFSIY*6}Vvd!sNST@n$|o_Vz3c`kZO!5#xtCca)mKOz8PEnn6gR7n(ZtnXHB zO*c@ZUm-|AfdS8T>=9&BWDA>K;bO4saSJon_LvwPx8^#^imI7F`QXb{mIz-o7|53| zfB6B9U721msX>eb-AV#=-UMCz*XhorEhTvkld;{+;)?h%K`8M6s%4Y`jul6=o7k1R z2!@;B8$h*^amSgqA4kliD-o!V7FtQeS98G{%g27)$MU_7hUsfrz7Bi}`ljhe)@ojg zYJTQrd%bTPUehq)3Vn(NC{o0(u=k-^qs0|V<mHxc@b}k!yy3Ule1OcJqN`<YNVs+N z&pf5o>_x7{6?-|GD5mAplLqzoWpWE1beuO)$4=f)E5~}@7HZ$s-vj^9IY#oq?Qwub zO!qA%4by8g`c~pYuO;o};0r4CIi}mMTTXN<d1T}B1vl5mpqjX7*@bW?PXS%7qETWT zbe;v|3}(D`p6Z{Q%mLF<!IvjfzwIVp^DYt^>JIYX9tgiT-?^CW=V!pDFdhfF%`+1% zX7hc0HN|Fk<^4%>N5=>mmMW880AsO<#&qLY<iLp*9scB&P5<eNVxm@TlytuYh4)eV zK5nkqP|a2D>M#qEZ;z7-a**t#_kV8%9NgzlLyP6J#fw!{gpYhjBVX=R9sFq}UYM%v zsm0EAL*%~XsJ#u<h%q|mecE29s{NNVb5SCHZ$b#s32b*H#5BKn8}uAa`tt7>U8M6u zy*}u_zs~kLn~N*oSGy|vs-|xNa#i-Nf(P+t?=CF92QCy+S7Cdc$lUGw2CLm7`}&C? zfPe$?{Zt-ir01ybDrB!m={ETi)vY-;&1}Q`S2438LqE!buHSHd$fp&$8x+Bg#UMcS zkYPHIaEo&BA&9@W+1ztA)GZay*<I2$JMqYX7@@$WNI@}*Cdv0R-{5W|;Fv%Qq%(*b zvoDPT{XXTu3o6^+tWoDC5ErYss%t5jY{J$%6-ICHBdg#Ke5ymkZ;+m*wNJ-7eIuXV zD!m2XCm4rQ4UAO~c<5s!59{|>g=m8~k}ir#OldeX-nU?vC*ypj;kZDY9L5FQxZ~Bz z+nQ&3CwPe$peB`)C1cVmD5WFH`V;R|BvT(&{z|gBi$!r<zf}$ycy$tM>Log>OVKAo zC^szSdX9$+t1FK%l^kOTP!Za~35U-YA>Xmihza}NvEFySerWlz*i?TiI={*nHC098 zC@<Y_O64+Q=U)BRh&R9V?7QRNDzY%m52)WK-}F}YyW2IwafH8~XQPV<W^Z2}VyydV zf+s3KHqvKYjq8LC#P2xtOOxbIS&zs@e;&`jfW@59QmTbY<#o&}&P!K2g=k<N)GAME zN9`Fo*w6r?+UsH8A1tD#O=vT<DOVbov_p7zmH{yVpWUK%e_-Tr0xd${YgrUmQ`f?? zRoQnh5Y6r9KMvI5Uw8%-Hc>!-$%tNVZu#7=6)9^c@`X|V7@E+}ma|<*OBIQ~x%}%4 zjnButJh4Q^!Wuy|)FJQg2mwYTOG{4rPTJG3wR_&|CZ~Cc3lZpmW3O4**5lZdp-$Km zIuaW_++;Z5_M`CV#(~LkDQ&2L*VdyuEZi#8=3N@DJF$2)@P~<nJs8cEB6{G72RRN| z>>nGT=|;e?!+qiyGUm?&@1kSOKkXHvc@`CP>7OT~zcQem|Cn{*1xe#_Tm>Wgt`NQa zQN?y$cP>7pKlLJ{_{?8;cbu*Mbh3i;I#q5*^2jOVP42qsyc^MJGH-Hh#94SJGE2Ov z!k9K}m@7th@WhwoaCHvCy*%DTrG266w9sI2<3qc+-OSmoDkcq0SUzgI+jc?u*m`8I zL;1wz^jlCCG2f|UK)a~a?|{hzi!P}A0C0XB2J!+r0it2s;UCoByW-Mk{~3_#{a)Hb z@>;&VXdM3X`3uhvmKa)Ty2k*k?(mN;?+w}}NS&EsUHUl;eO`C#m+*@1JE+AZ^$Dmu zzk9wsI7dDXTgi`DxQF{p4CMlDlNY5_9o}|2>;<z|9fupDYT1P+1^ExSJwjPq$Ng`x zP^g~dCD79FmsPZKqE8hH9g@?&99)?rC^2ge0uo&lW3wvY0}WrQYo68ZxKGg6p;jt? zQx=?|^SA6Pxr{CQkeJvC`F45yBXDg22jSO#Y@cs49zFP(&#KlfcU0^tm&fP`k)b%9 zIoEQ7C|s9-lj4-x<-{e4mbh%E?hovb!oH8XD46f(3JeuChY|-F)9x-5sHsIsx2%C( zx<TS?bN%^UU2&CGd&$~W9Sh>@+gi_l@7_`6t6r|W-~icGhK$14;gBC@E5BpgVim9* zv`DvJmne|uO-rhcVp-b8HE7GMOx)Fwxr56S=M4q+XA!~totGH`|8y;o#8|WY$Hpjr z*OqVorL`u-HiS(F_c7nmXeT3v0fVN@?U5A%xex5Gew{}^KCmSu;x08M+CBSHp3;8o zH!Cy;DhfM$pWmuqn)5x&T|P4-UQymxQZqCA;gW))-nwCC2O}FoyyVB*)iBpv!+did zDiDAml_Moj@z?IIm6~$biy+W5d~@w|JJ$$O&7W(Qjbmp(ekT0kf_N6^iO=dJtOBo_ zgQ7?|ou<=3gT)>AA_jk;O1_(RW9@S9j?$~+^W-S8J+WCxY6vv@oRGrZ;J~Sgr~@^J z{Tp6z`X+EO=|Vh5Gqm>`&jRBlcj{uxIyk*0+f5*L!#kDD(drLhRYyWU<IoIEuNu|g z%RgQiAp16~TAwQ5!sFMOIVF?EM75e%62NW~DzR$F#-leIp?B}R?K65CYs>3QldU+7 zkK30IJM8r!+7#i>O4xuU3j4qCi#`(GVW~QcVoRfU`GF7P^qehRs<TYJY70NE`bdTm zsHsJ$wz7*I9##Yvv!Z4WY&(Npij#2C6SYy{21n@{)6HWj92gC?0XuZ#u^c7srdqdZ zL=I5_GApuyj0a9W!;w&GtKP%u;T3^i3-QDQl25cOli%iQ`daS#9vF8~YT$qA!F^B~ zy&0voFx;K*C}B!l5&GFv3r~da@chXzBt_}r^A~vXQ>HTrAIBA)Z(*<9<J)R}O5n$e zSNkKi3Lyp)E{Et_=$MSCp5xCT=vs7su7hZ=*Hju*p<^4x8;G{yv*t`ryhjqTZ>(W7 z43EMx28B#AVN;L0#HEUVi$Fyt;5{<};^mc}{rtnbU5p#BPTyl$l-w+pVB+=A2p2DP znYzI(4P%f{Jn4~LorioCdhF5tTF$OtT{xft!D9QIgYn@raF?@>dE0pH-mAAlbyY~q zEjXetZh#suT?-YYGu%hMlm(m=xf5nNPo&LKQPt5Ocu!7!7z!b;P%S!F$CfOdp^5P2 zr^xa$v;v5GmtS+#gesx<7vCr|5lRpa@QzAe7{mnJ3?a7&5oKQ1Ce_qdRwxApHXJ3T z;Q14CKRquI3s8nTq=s+roeFKVFAUm_1wjlzh%7FthWk&IT&CgHN!Lnne;GJQc731y z@Wq!;_tPk;MNW1v4Y(o!Jxh2!!^LJm06sY+9Wk&YM(?AVUX7}z#6x<09tWmIMGZH8 z;8IOJS3EP*8=YI7yeEmR(`*Qa9cPaKi4|UGTTVERLrgK&CfBqAWrdAGel7ZyNUH4- zh5nuxEWaLAU)fy&1zyFrvO`+GTbGH5ARz6*dya~6Na@B8x>UP+Q+EDL3}*CuqNGv$ z`m8@eqAEw*BS`i(<}DzeG~K8zHfpsn*bf{f=}(?}Gl@*a2b8HkRZ6E6mHCq-{qymc zhso$Cxf5H<BKZ`JBp0g_Y%Zp-ev4WAlyal#4wgK}Tm`Uuv)-T)|Ed6WuGP-40BL9& zNd$Tq*aWsd5K+Kn##DeWB@w(m7J@6bN!=Td=!c2oYV5RqQ^o4+4Qvz*@yn0S{*LOQ zoJvHQQMej>gv?U)wPN?DV_9(()6om7KQ;8c5IzkGv1lB;=wD|u&fZP#hU-$_0-}-` zRg6Zxpb)SB`?oSCY4;+pb-JhXq8ZI%0AwY$M!oHzSaLp3+2vjnC7jI*#PIzE8YsVZ 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�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Ⓢ+!p`{Dva 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 V3ydWK@dW{2>dHDw^$IqT{}18$!(0FW literal 0 HcmV?d00001 diff --git a/src/global.css b/src/global.css index 879e608..9583b1d 100644 --- a/src/global.css +++ b/src/global.css @@ -1,12 +1,15 @@ @import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap"); -* { +*{ margin: 0; padding: 0; outline: 0; box-sizing: border-box; color: #667079; } +* :not(.Button){ + color: white; +} html, body, diff --git a/src/index.js b/src/index.js index 87d1be5..e1a002a 100644 --- a/src/index.js +++ b/src/index.js @@ -1,12 +1,12 @@ -import React from 'react'; -import ReactDOM from 'react-dom'; -import './index.css'; -import App from './App'; -import * as serviceWorker from './serviceWorker'; +import React from "react"; +import ReactDOM from "react-dom"; +import "./index.css"; +import App from "./App"; +import * as serviceWorker from "./serviceWorker"; -ReactDOM.render(<App />, document.getElementById('root')); +ReactDOM.render(<App />, document.getElementById("root")); // If you want your app to work offline and load faster, you can change // unregister() to register() below. Note this comes with some pitfalls. // Learn more about service workers: https://bit.ly/CRA-PWA -serviceWorker.unregister(); +serviceWorker.register(); diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js new file mode 100644 index 0000000..50e755a --- /dev/null +++ b/src/pages/SignUp.js @@ -0,0 +1,240 @@ +import React from "react"; +import Grid from "@material-ui/core/Grid"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import IconButton from "@material-ui/core/IconButton"; +import { makeStyles } from "@material-ui/core/styles"; +import KeyboardArrowRightIcon from "@material-ui/icons/KeyboardArrowRight"; +import FormInput from "../components/fieldsSignUp/FormInput"; +import Paper from "@material-ui/core/Paper"; +import api from "../api"; + +const useStyles = makeStyles(theme => ({ + register: { + maxWidth: "1000px", + background: "#ffffff", + borderRadius: "2px", + padding: "2% 1%", + margin: "0 auto", + marginTop: "9%", + width: "95%" + }, + custom_strong: { + fontSize: "25px", + textAlign: "center", + display: "block", + color: "#46525d" + }, + strong_description: { + fontSize: "14px", + color: "#c2c6ca" + }, + form: { + marginTop: "3%", + alignItems: "center", + textAlign: "center" + }, + button: { + type: "submit", + width: "30%", + marginTop: "4%", + background: "#6ec46c", + borderRadius: "2px", + padding: "10px 20px", + fontSize: "18px", + "&:hover": { + backgroundColor: "rgb(25, 109, 23)" + }, + ["@media (max-width:550px)"]: { + width: "55%" + } + } +})); +export default function SignUp() { + const classes = useStyles(); + const [values, setValues] = React.useState({ + name: "", + email: "", + password: "", + password_confirm: "", + nameError: false, + emailError: false + }); + async function update(prop, event) { + await setValues({ ...values, [prop]: event.target.value }); + } + + const handleChange = prop => event => { + switch (prop) { + case "name": + if (!checkName()) { + values.nameError = true; + } else { + values.nameError = false; + } + break; + case "email": + if (!checkEmail()) { + values.emailError = true; + } else { + values.emailError = false; + } + } + update(prop, event); + }; + function checkPassword() { + if (values.password !== values.password_confirm) { + alert("As senhas não conferem"); + return false; + } + return true; + } + function checkName() { + if (/^[a-zA-Z ]+$/.test(values.name) && !(/^$|\s+/.test(values.name)) &&values.name.length <= 225) { + return true; + } + return false; + } + function checkEmail() { + if (/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\.[A-Za-z]+$/.test(values.email)) { + return true; + } + return false; + } + function verifyValues() { + if ( + values.name && + values.email && + values.password && + values.password_confirm + ) { + return true; + } + return false; + } + // Ficou com essa configuração porque as funções para verificar nome e email são chamadas em 'tempo real' para deixar o campo em vermelho. + function verifyValuesContent() { + if (!checkName()){ + alert("Nome inválido"); + return false; + }else if (!checkEmail()) { + alert("Email invalido"); + return false; + }else if (!checkPassword()){ + return false; + } + else{ + return true; + } + } + async function handleSubmit() { + const response = await api + .post(`/user/signUp`, { + email: values.email, + name: values.name, + hash: values.password + }) + .then(function(error) { + if (!error.response) { + alert("Usuário criado com sucesso"); + // redirecionar para a main page + } + }) + .catch(function(error) { + if (error.response) { + switch (error.response.data.error) { + case 'duplicate key value violates unique constraint "form_user_name_key"': + alert("Você já tem uma conta."); + break; + case "Email exists on the database.": + alert("Email já cadastrado"); + break; + case "data and salt arguments required": + alert( + "Ocorreu um erro com sua senha. Tente novamente em alguns minutos ou tente mudá-la" + ); + default: + alert("Um erro ocorreu. Tente novamente mais tarde."); + } + return; + // console.log(error.response.data); + } + }); + } + function submit() { + if (verifyValues()) { + if (verifyValuesContent()) { + handleSubmit(); + } + } + } + const theme = createMuiTheme({ + overrides: { + root: { + color: "white" + }, + MuiInput: { + underline: { + "&:before": { + borderBottom: "1px solid #35c7fc" + }, + "&:after": { + borderBottom: "1px solid #3f51b5" + } + } + }, + } + }); + return ( + <MuiThemeProvider theme={theme}> + <Paper className={classes.register} justify="center"> + <strong className={classes.custom_strong}> + Cadastro de Usuário + <p className={classes.strong_description}> + Insira as informações abaixo + </p> + </strong> + <form className={classes.form} autocomplete="off"> + <Grid> + <FormInput + label="Nome Completo" + param="name" + onUpdate={handleChange} + error={values.nameError} + /> + </Grid> + <Grid> + <FormInput + label="E-mail" + param="email" + onUpdate={handleChange} + verify={checkEmail} + error={values.emailError} + /> + </Grid> + <Grid> + <FormInput label="Senha" param="password" onUpdate={handleChange} /> + </Grid> + <Grid> + <FormInput + label="Confirmar Senha" + param="password_confirm" + onUpdate={handleChange} + /> + </Grid> + <Grid> + <IconButton + type="submit" + size="medium" + className={classes.button} + id="whiteTextedButton" + onClick={() => submit()} + > + <KeyboardArrowRightIcon /> + Cadastre-se + </IconButton> + </Grid> + </form> + </Paper> + </MuiThemeProvider> + ); +} diff --git a/src/pages/teste.css b/src/pages/teste.css new file mode 100644 index 0000000..e69de29 -- GitLab From 61fa654230b56d376d090d66e6469dddaf5d6fa1 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 23 Mar 2020 10:16:48 -0300 Subject: [PATCH 29/72] Issue #6: Add SignIn screen Signed-off-by: RichardHeise <richardfhf5@gmail.com> --- src/App.js | 3 + src/pages/SignIn.js | 176 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 179 insertions(+) create mode 100644 src/pages/SignIn.js diff --git a/src/App.js b/src/App.js index 90dd131..a2f07a0 100644 --- a/src/App.js +++ b/src/App.js @@ -6,6 +6,7 @@ import AnswerForm from "./pages/AnswerForm"; import Header from "./components/header/header"; import Footer from "./components/footer/footer"; import SignUp from "./pages/SignUp"; +import SignIn from "./pages/SignIn"; function App() { return ( @@ -14,6 +15,8 @@ function App() { <Route path="/create" component={CreateForm} /> <Route path="/answer/:id" component={AnswerForm} /> <Route path="/SignUp" component={SignUp} /> + <Route path="/SignIn" component={SignIn} /> + <Footer /> </HashRouter> ); } diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js new file mode 100644 index 0000000..fec62b5 --- /dev/null +++ b/src/pages/SignIn.js @@ -0,0 +1,176 @@ +import React from "react"; +import Grid from "@material-ui/core/Grid"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import IconButton from "@material-ui/core/IconButton"; +import { makeStyles } from "@material-ui/core/styles"; +import KeyboardArrowRightIcon from "@material-ui/icons/KeyboardArrowRight"; +import FormInput from "../components/fieldsSignUp/FormInput"; +import Paper from "@material-ui/core/Paper"; +import api from "../api"; + +const useStyles = makeStyles(theme => ({ + register: { + maxWidth: "1000px", + background: "#ffffff", + borderRadius: "2px", + padding: "2% 1%", + margin: "0 auto", + marginTop: "9%", + width: "95%" + }, + custom_strong: { + fontSize: "25px", + textAlign: "center", + display: "block", + color: "#46525d" + }, + strong_description: { + fontSize: "14px", + color: "#c2c6ca" + }, + form: { + marginTop: "3%", + alignItems: "center", + textAlign: "center" + }, + button: { + type: "submit", + width: "30%", + marginTop: "4%", + background: "#6ec46c", + borderRadius: "2px", + padding: "10px 20px", + fontSize: "18px", + "&:hover": { + backgroundColor: "rgb(25, 109, 23)" + }, + ["@media (max-width:550px)"]: { + width: "55%" + } + } +})); +export default function SignIn() { + const classes = useStyles(); + const [values, setValues] = React.useState({ + email: "", + password: "", + emailError: false + }); + async function update(prop, event) { + await setValues({ ...values, [prop]: event.target.value }); + } + + const handleChange = prop => event => { + if (!checkEmail()) { + values.emailError = true; + } else { + values.emailError = false; + } + update(prop, event); + }; + function checkEmail() { + if (/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\.[A-Za-z]+$/.test(values.email)) { + return true; + } + return false; + } + function verifyValues() { + if ( + values.email && + values.password + ) { + return true; + } + return false; + } + function verifyValuesContent() { + if (!checkEmail()) { + alert("Falha de autenticação. Certifique-se que email e senha estão corretos."); + return false; + } + return true; + } + async function handleSubmit() { + const response = await api + .post(`/user/signIn`, { + email: values.email, + hash: values.password + }) + .then(function(response) { + if (!response.data.error) { + alert("Você logou com sucesso.") + window.sessionStorage.setItem("token", response.data.token); + // redirecionar para a main page + } + }) + .catch(function(error) { + if (error.response) { + alert("Falha de autenticação. Certifique-se que email e senha estão corretos.") + } + }); + } + function submit() { + if (verifyValues()) { + if (verifyValuesContent()) { + handleSubmit(); + } + } + } + const theme = createMuiTheme({ + overrides: { + root: { + color: "white" + }, + MuiInput: { + underline: { + "&:before": { + borderBottom: "1px solid #35c7fc" + }, + "&:after": { + borderBottom: "1px solid #3f51b5" + } + } + }, + } + }); + return ( + <MuiThemeProvider theme={theme}> + <Paper className={classes.register} justify="center"> + <strong className={classes.custom_strong}> + Login de Usuário + <p className={classes.strong_description}> + Insira as informações abaixo + </p> + </strong> + <form className={classes.form} autocomplete="off"> + <Grid> + <FormInput + label="E-mail" + param="email" + onUpdate={handleChange} + verify={checkEmail} + error={values.emailError} + /> + </Grid> + <Grid> + <FormInput + label="Senha" + param="password" onUpdate={handleChange} /> + </Grid> + <Grid> + <IconButton + type="submit" + size="medium" + className={classes.button} + id="whiteTextedButton" + onClick={() => submit()} + > + <KeyboardArrowRightIcon /> + Conecte-se + </IconButton> + </Grid> + </form> + </Paper> + </MuiThemeProvider> + ); +} -- GitLab From e94d77b4f72bc98e2019aec3443d211456b87390 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Wed, 15 Apr 2020 09:38:21 -0300 Subject: [PATCH 30/72] Issue #17: Fix SignIn route Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/pages/SignIn.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index fec62b5..ab1441d 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -100,6 +100,7 @@ export default function SignIn() { if (!response.data.error) { alert("Você logou com sucesso.") window.sessionStorage.setItem("token", response.data.token); + window.sessionStorage.setItem("userId", response.data.id); // redirecionar para a main page } }) -- GitLab From 2c4cd59f7f4d465a0a3a082fc2b34f2cb2e983be Mon Sep 17 00:00:00 2001 From: rgcastro <rgcastro@inf.ufpr.br> Date: Mon, 27 Apr 2020 10:31:55 -0300 Subject: [PATCH 31/72] Fixed footer responsivity. --- src/components/footer/bkp_footer.js | 108 ++++++++++++++++++++++++++++ src/components/footer/footer.js | 49 +++++++------ src/components/footer/footer.js~ | 98 +++++++++++++++++++++++++ 3 files changed, 235 insertions(+), 20 deletions(-) create mode 100644 src/components/footer/bkp_footer.js create mode 100644 src/components/footer/footer.js~ diff --git a/src/components/footer/bkp_footer.js b/src/components/footer/bkp_footer.js new file mode 100644 index 0000000..1b71c44 --- /dev/null +++ b/src/components/footer/bkp_footer.js @@ -0,0 +1,108 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Typography from "@material-ui/core/Typography"; +import Logo from "./c3sl.png"; + +const useStyles = makeStyles(theme => ({ + footer: { + background: "#66a6c2", + position: "fixed", + left: 0, + bottom: 0, + right: 0, + width: "100%", + height: "78px" + }, + + img: { + width: "50px", + marginTop: "5px", + marginBottom: "5px", + justifyCenter: "center" + ["@media (min-width:1200px)"]: { + marginLeft: "15px", + }, + ["@media (max-width:1200px)"]: { + marginLeft: "50%", + width: "50px", + justifyCenter: "center" + } + }, + + item: { + marginTop: "5px", + marginBottom: "5px", + display: "flex", + justifyContent: "space-evenly", + flexDirection: "column", + ["@media (max-width:525px)"]: { + width: "50px", + ["@media (max-width:338px)"]: { + marginTop: "3%" + } + }, + ["@media (max-height:681px)"]: { + width: "65px" + }, + ["@media (max-width:1040px)"]: { + justifyCenter: "center" + } + }, + + text: { + color: "#46525d", + fontSize: "15px", + textAlign: "center", + ["@media (max-width:1200px)"]: { + display:"none" + } + }, + + adress: { + color: "#46525d", + fontSize: "12px", + textAlign: "right", + marginRight: "15px", + ["@media (max-width:1200px)"]: { + display:"none" + } + } +})); + +function Footer() { + const classes = useStyles(); + return ( + <Grid container className={classes.footer}> + <Grid item xs={12} md={2} lg={2} className={classes.item}> + <img src={Logo} className={classes.img}></img> + </Grid> + + <Grid item md={8} lg={8} className={classes.item}> + <Typography className={classes.text}> + Ministério da + <b> + <br /> + Ciência, Tecnologia, + <br /> + Inovações e Comunicações + </b> + </Typography> + </Grid> + + <Grid item md={2} lg={2} className={classes.item}> + <Typography className={classes.adress}> + Esplanada dos Ministérios, Bloco R + <br /> + CEP: 70044-900 – BrasÃlia-DF + <br /> + Telefone: 61 2027-6000 + </Typography> + </Grid> + + + </Grid> + ); +} + +export default Footer; diff --git a/src/components/footer/footer.js b/src/components/footer/footer.js index 524635c..3e2ee4e 100644 --- a/src/components/footer/footer.js +++ b/src/components/footer/footer.js @@ -12,44 +12,51 @@ const useStyles = makeStyles(theme => ({ bottom: 0, right: 0, width: "100%", - height: "auto" + height: "78px" }, img: { width: "50px", - marginTop: "5px", - marginBottom: "5px", - marginLeft: "15px", - ["@media (max-width:525px)"]: { - width: "50px", - ["@media (max-width:338px)"]: { - marginTop: "3%" - } - }, - ["@media (max-height:681px)"]: { - width: "65px" + display: "block", + marginTop: "auto", + marginBottom: "auto", + marginLeft: "auto", + marginRight: "auto", + ["@media (min-width: 960px)"]: { + marginLeft: "5px", } }, item: { - marginTop: "5px", - marginBottom: "5px", display: "flex", justifyContent: "space-evenly", - flexDirection: "column" + flexDirection: "column", + alignItems: "center" }, text: { color: "#46525d", fontSize: "15px", - textAlign: "center" + textAlign: "center", + left: "50%", + ["@media (max-width: 960px)"]: { + display: "none" + } }, adress: { + display: "block", + marginTop: "auto", + marginBottom: "auto", + marginLeft: "auto", + paddingRight: "10px", + color: "#46525d", fontSize: "12px", textAlign: "right", - marginRight: "15px" + ["@media (max-width: 960px)"]: { + display: "none" + } } })); @@ -57,11 +64,11 @@ function Footer() { const classes = useStyles(); return ( <Grid container className={classes.footer}> - <Grid item xs={2} className={classes.item}> + <Grid item xs={12} sm={12} md={3} lg={2} className={classes.item}> <img src={Logo} className={classes.img}></img> </Grid> - <Grid item xs={8} className={classes.item}> + <Grid item md={6} lg={8} className={classes.item}> <Typography className={classes.text}> Ministério da <b> @@ -73,7 +80,7 @@ function Footer() { </Typography> </Grid> - <Grid item xs={2} className={classes.item}> + <Grid item md={3} lg={2} className={classes.item}> <Typography className={classes.adress}> Esplanada dos Ministérios, Bloco R <br /> @@ -82,6 +89,8 @@ function Footer() { Telefone: 61 2027-6000 </Typography> </Grid> + + </Grid> ); } diff --git a/src/components/footer/footer.js~ b/src/components/footer/footer.js~ new file mode 100644 index 0000000..3e2ee4e --- /dev/null +++ b/src/components/footer/footer.js~ @@ -0,0 +1,98 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Typography from "@material-ui/core/Typography"; +import Logo from "./c3sl.png"; + +const useStyles = makeStyles(theme => ({ + footer: { + background: "#66a6c2", + position: "fixed", + left: 0, + bottom: 0, + right: 0, + width: "100%", + height: "78px" + }, + + img: { + width: "50px", + display: "block", + marginTop: "auto", + marginBottom: "auto", + marginLeft: "auto", + marginRight: "auto", + ["@media (min-width: 960px)"]: { + marginLeft: "5px", + } + }, + + item: { + display: "flex", + justifyContent: "space-evenly", + flexDirection: "column", + alignItems: "center" + }, + + text: { + color: "#46525d", + fontSize: "15px", + textAlign: "center", + left: "50%", + ["@media (max-width: 960px)"]: { + display: "none" + } + }, + + adress: { + display: "block", + marginTop: "auto", + marginBottom: "auto", + marginLeft: "auto", + paddingRight: "10px", + + color: "#46525d", + fontSize: "12px", + textAlign: "right", + ["@media (max-width: 960px)"]: { + display: "none" + } + } +})); + +function Footer() { + const classes = useStyles(); + return ( + <Grid container className={classes.footer}> + <Grid item xs={12} sm={12} md={3} lg={2} className={classes.item}> + <img src={Logo} className={classes.img}></img> + </Grid> + + <Grid item md={6} lg={8} className={classes.item}> + <Typography className={classes.text}> + Ministério da + <b> + <br /> + Ciência, Tecnologia, + <br /> + Inovações e Comunicações + </b> + </Typography> + </Grid> + + <Grid item md={3} lg={2} className={classes.item}> + <Typography className={classes.adress}> + Esplanada dos Ministérios, Bloco R + <br /> + CEP: 70044-900 – BrasÃlia-DF + <br /> + Telefone: 61 2027-6000 + </Typography> + </Grid> + + + </Grid> + ); +} + +export default Footer; -- GitLab From a1130b4237acc852a70f197aeb6c2c7f14246568 Mon Sep 17 00:00:00 2001 From: GabrielHome <gash18@inf.ufpr.br> Date: Mon, 23 Mar 2020 12:12:09 -0300 Subject: [PATCH 32/72] =?UTF-8?q?"Issue=20#4:=20Criar=20tela=20de=20criar?= =?UTF-8?q?=20formul=C3=A1rios"?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .vscode/settings.json | 3 + npm-debug.log | 45 ++ package-lock.json | 678 ++++++++++++++---- package.json | 17 +- .../fieldsAnswerForm/FormFieldCheckbox.js | 60 +- .../fieldsCreateForm/DefaultField.js | 48 ++ .../fieldsCreateForm/FieldFooterOptions.js | 77 +- .../fieldsCreateForm/FormFieldCheckbox.js | 256 ++++--- .../fieldsCreateForm/FormFieldRadio.js | 254 +++++-- .../fieldsCreateForm/FormFieldSelect.js | 232 ++++-- .../fieldsCreateForm/FormFieldSubform.js | 219 ++++++ .../fieldsCreateForm/FormFieldText.js | 236 ++++-- .../fieldsCreateForm/FormFieldTitle.js | 114 +-- src/components/fieldsCreateForm/SideMenu.js | 128 ++++ .../utils/BackendTranslation.js | 106 +++ .../fieldsCreateForm/utils/schemas.js | 158 ++++ src/components/footer/footer.js | 24 +- src/components/global.css | 26 - src/components/header/header.jsx | 36 +- .../header/header_components/MenuList.jsx | 24 +- src/global.css | 5 +- src/pages/AnswerForm.js | 4 +- src/pages/CreateForm.js | 643 ++++++++++++----- src/pages/SignIn.js | 77 +- src/pages/teste.css | 0 src/services/auth.js | 9 + yarn-error.log | 68 ++ 27 files changed, 2698 insertions(+), 849 deletions(-) create mode 100644 .vscode/settings.json create mode 100644 npm-debug.log create mode 100644 src/components/fieldsCreateForm/DefaultField.js create mode 100644 src/components/fieldsCreateForm/FormFieldSubform.js create mode 100644 src/components/fieldsCreateForm/SideMenu.js create mode 100644 src/components/fieldsCreateForm/utils/BackendTranslation.js create mode 100644 src/components/fieldsCreateForm/utils/schemas.js delete mode 100644 src/components/global.css delete mode 100644 src/pages/teste.css create mode 100644 src/services/auth.js create mode 100644 yarn-error.log diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..23fd35f --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "editor.formatOnSave": true +} \ No newline at end of file diff --git a/npm-debug.log b/npm-debug.log new file mode 100644 index 0000000..a1e64b3 --- /dev/null +++ b/npm-debug.log @@ -0,0 +1,45 @@ +0 info it worked if it ends with ok +1 verbose cli [ '/usr/bin/node', '/usr/bin/npm', 'start' ] +2 info using npm@3.5.2 +3 info using node@v8.10.0 +4 verbose run-script [ 'prestart', 'start', 'poststart' ] +5 info lifecycle my-app@0.1.0~prestart: my-app@0.1.0 +6 silly lifecycle my-app@0.1.0~prestart: no script for prestart, continuing +7 info lifecycle my-app@0.1.0~start: my-app@0.1.0 +8 verbose lifecycle my-app@0.1.0~start: unsafe-perm in lifecycle true +9 verbose lifecycle my-app@0.1.0~start: PATH: /usr/share/npm/bin/node-gyp-bin:/home/gabriel/Documents/c3sl/form-creator-ui/node_modules/.bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/home/gabriel/.npm-packages/bin:/snap/bin:/home/gabriel/.npm-packages/bin:/snap/bin +10 verbose lifecycle my-app@0.1.0~start: CWD: /home/gabriel/Documents/c3sl/form-creator-ui +11 silly lifecycle my-app@0.1.0~start: Args: [ '-c', 'react-scripts start' ] +12 silly lifecycle my-app@0.1.0~start: Returned: code: 1 signal: null +13 info lifecycle my-app@0.1.0~start: Failed to exec start script +14 verbose stack Error: my-app@0.1.0 start: `react-scripts start` +14 verbose stack Exit status 1 +14 verbose stack at EventEmitter.<anonymous> (/usr/share/npm/lib/utils/lifecycle.js:232:16) +14 verbose stack at emitTwo (events.js:126:13) +14 verbose stack at EventEmitter.emit (events.js:214:7) +14 verbose stack at ChildProcess.<anonymous> (/usr/share/npm/lib/utils/spawn.js:24:14) +14 verbose stack at emitTwo (events.js:126:13) +14 verbose stack at ChildProcess.emit (events.js:214:7) +14 verbose stack at maybeClose (internal/child_process.js:925:16) +14 verbose stack at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5) +15 verbose pkgid my-app@0.1.0 +16 verbose cwd /home/gabriel/Documents/c3sl/form-creator-ui +17 error Linux 5.3.0-42-generic +18 error argv "/usr/bin/node" "/usr/bin/npm" "start" +19 error node v8.10.0 +20 error npm v3.5.2 +21 error code ELIFECYCLE +22 error my-app@0.1.0 start: `react-scripts start` +22 error Exit status 1 +23 error Failed at the my-app@0.1.0 start script 'react-scripts start'. +23 error Make sure you have the latest version of node.js and npm installed. +23 error If you do, this is most likely a problem with the my-app package, +23 error not with npm itself. +23 error Tell the author that this fails on your system: +23 error react-scripts start +23 error You can get information on how to open an issue for this project with: +23 error npm bugs my-app +23 error Or if that isn't available, you can get their info via: +23 error npm owner ls my-app +23 error There is likely additional logging output above. +24 verbose exit [ 1, true ] diff --git a/package-lock.json b/package-lock.json index 0e5b74d..4f2a33b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1044,9 +1044,9 @@ "integrity": "sha512-ij4wRiunFfaJxjB0BdrYHIH8FxBJpOwNPhhAcunlmPdXudL1WQV1qoP9un6JsEBAgQH+7UXyyjh0g7jTxXK6tg==" }, "@emotion/hash": { - "version": "0.7.4", - "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.7.4.tgz", - "integrity": "sha512-fxfMSBMX3tlIbKUdtGKxqB1fyrH6gVrX39Gsv3y8lRYKUqlgDt3UMqQyGnR1bQMa2B8aGnhLZokZgg8vT0Le+A==" + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.8.0.tgz", + "integrity": "sha512-kBJtf7PH6aWwZ6fka3zQ0p6SBYzx4fl1LoZXE2RrnYST9Xljm7WfKJrU4g/Xr3Beg72MLrp1AWNUmuYJTL7Cow==" }, "@hapi/address": { "version": "2.1.4", @@ -1274,20 +1274,18 @@ } }, "@material-ui/core": { - "version": "4.8.3", - "resolved": "https://registry.npmjs.org/@material-ui/core/-/core-4.8.3.tgz", - "integrity": "sha512-ZJbfJQmkuZCSQTf0nzpfZwizmDdCq8ruZxnPNFnhoKDqgJpMvV8TJRi8vdI9ls1tMuTqxlhyhw8556fxOpWpFQ==", + "version": "4.9.7", + "resolved": "https://registry.npmjs.org/@material-ui/core/-/core-4.9.7.tgz", + "integrity": "sha512-RTRibZgq572GHEskMAG4sP+bt3P3XyIkv3pOTR8grZAW2rSUd6JoGZLRM4S2HkuO7wS7cAU5SpU2s1EsmTgWog==", "requires": { "@babel/runtime": "^7.4.4", - "@material-ui/styles": "^4.8.2", - "@material-ui/system": "^4.7.1", - "@material-ui/types": "^4.1.1", - "@material-ui/utils": "^4.7.1", + "@material-ui/styles": "^4.9.6", + "@material-ui/system": "^4.9.6", + "@material-ui/types": "^5.0.0", + "@material-ui/utils": "^4.9.6", "@types/react-transition-group": "^4.2.0", "clsx": "^1.0.2", - "convert-css-length": "^2.0.1", - "hoist-non-react-statics": "^3.2.1", - "normalize-scroll-left": "^0.2.0", + "hoist-non-react-statics": "^3.3.2", "popper.js": "^1.14.1", "prop-types": "^15.7.2", "react-is": "^16.8.0", @@ -1304,9 +1302,9 @@ } }, "hoist-non-react-statics": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.1.tgz", - "integrity": "sha512-wbg3bpgA/ZqWrZuMOeJi8+SKMhr7X9TesL/rXMjTzh0p0JUBo3II8DHboYbuIXWRlttrUFxwcu/5kygrCw8fJw==", + "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" } @@ -1325,40 +1323,64 @@ } }, "@material-ui/icons": { - "version": "4.5.1", - "resolved": "https://registry.npmjs.org/@material-ui/icons/-/icons-4.5.1.tgz", - "integrity": "sha512-YZ/BgJbXX4a0gOuKWb30mBaHaoXRqPanlePam83JQPZ/y4kl+3aW0Wv9tlR70hB5EGAkEJGW5m4ktJwMgxQAeA==", + "version": "4.9.1", + "resolved": "https://registry.npmjs.org/@material-ui/icons/-/icons-4.9.1.tgz", + "integrity": "sha512-GBitL3oBWO0hzBhvA9KxqcowRUsA0qzwKkURyC8nppnC3fw54KPKZ+d4V1Eeg/UnDRSzDaI9nGCdel/eh9AQMg==", "requires": { "@babel/runtime": "^7.4.4" } }, + "@material-ui/lab": { + "version": "4.0.0-alpha.46", + "resolved": "https://registry.npmjs.org/@material-ui/lab/-/lab-4.0.0-alpha.46.tgz", + "integrity": "sha512-JGgZmj1UNP8bbYNAGvndipjXRK3x2+9mFBzbX7MyCj+WpfnJbeqTmJK2No9MXvPj/EZJ1piaKif46FdDc4U93A==", + "requires": { + "@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" + }, + "dependencies": { + "@material-ui/utils": { + "version": "4.9.6", + "resolved": "https://registry.npmjs.org/@material-ui/utils/-/utils-4.9.6.tgz", + "integrity": "sha512-gqlBn0JPPTUZeAktn1rgMcy9Iczrr74ecx31tyZLVGdBGGzsxzM6PP6zeS7FuoLS6vG4hoZP7hWnOoHtkR0Kvw==", + "requires": { + "@babel/runtime": "^7.4.4", + "prop-types": "^15.7.2", + "react-is": "^16.8.0" + } + } + } + }, "@material-ui/styles": { - "version": "4.8.2", - "resolved": "https://registry.npmjs.org/@material-ui/styles/-/styles-4.8.2.tgz", - "integrity": "sha512-r5U+93pkpwQOmHTmwyn2sqTio6PHd873xvSHiKP6fdybAXXX6CZgVvh3W8saZNbYr/QXsS8OHmFv7sYJLt5Yfg==", + "version": "4.9.6", + "resolved": "https://registry.npmjs.org/@material-ui/styles/-/styles-4.9.6.tgz", + "integrity": "sha512-ijgwStEkw1OZ6gCz18hkjycpr/3lKs1hYPi88O/AUn4vMuuGEGAIrqKVFq/lADmZUNF3DOFIk8LDkp7zmjPxtA==", "requires": { "@babel/runtime": "^7.4.4", - "@emotion/hash": "^0.7.4", - "@material-ui/types": "^4.1.1", - "@material-ui/utils": "^4.7.1", + "@emotion/hash": "^0.8.0", + "@material-ui/types": "^5.0.0", + "@material-ui/utils": "^4.9.6", "clsx": "^1.0.2", "csstype": "^2.5.2", - "hoist-non-react-statics": "^3.2.1", - "jss": "^10.0.0", - "jss-plugin-camel-case": "^10.0.0", - "jss-plugin-default-unit": "^10.0.0", - "jss-plugin-global": "^10.0.0", - "jss-plugin-nested": "^10.0.0", - "jss-plugin-props-sort": "^10.0.0", - "jss-plugin-rule-value-function": "^10.0.0", - "jss-plugin-vendor-prefixer": "^10.0.0", + "hoist-non-react-statics": "^3.3.2", + "jss": "^10.0.3", + "jss-plugin-camel-case": "^10.0.3", + "jss-plugin-default-unit": "^10.0.3", + "jss-plugin-global": "^10.0.3", + "jss-plugin-nested": "^10.0.3", + "jss-plugin-props-sort": "^10.0.3", + "jss-plugin-rule-value-function": "^10.0.3", + "jss-plugin-vendor-prefixer": "^10.0.3", "prop-types": "^15.7.2" }, "dependencies": { "hoist-non-react-statics": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.1.tgz", - "integrity": "sha512-wbg3bpgA/ZqWrZuMOeJi8+SKMhr7X9TesL/rXMjTzh0p0JUBo3II8DHboYbuIXWRlttrUFxwcu/5kygrCw8fJw==", + "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" } @@ -1366,27 +1388,24 @@ } }, "@material-ui/system": { - "version": "4.7.1", - "resolved": "https://registry.npmjs.org/@material-ui/system/-/system-4.7.1.tgz", - "integrity": "sha512-zH02p+FOimXLSKOW/OT2laYkl9bB3dD1AvnZqsHYoseUaq0aVrpbl2BGjQi+vJ5lg8w73uYlt9zOWzb3+1UdMQ==", + "version": "4.9.6", + "resolved": "https://registry.npmjs.org/@material-ui/system/-/system-4.9.6.tgz", + "integrity": "sha512-QtfoAePyqXoZ2HUVSwGb1Ro0kucMCvVjbI0CdYIR21t0Opgfm1Oer6ni9P5lfeXA39xSt0wCierw37j+YES48Q==", "requires": { "@babel/runtime": "^7.4.4", - "@material-ui/utils": "^4.7.1", + "@material-ui/utils": "^4.9.6", "prop-types": "^15.7.2" } }, "@material-ui/types": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/@material-ui/types/-/types-4.1.1.tgz", - "integrity": "sha512-AN+GZNXytX9yxGi0JOfxHrRTbhFybjUJ05rnsBVjcB+16e466Z0Xe5IxawuOayVZgTBNDxmPKo5j4V6OnMtaSQ==", - "requires": { - "@types/react": "*" - } + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/@material-ui/types/-/types-5.0.0.tgz", + "integrity": "sha512-UeH2BuKkwDndtMSS0qgx1kCzSMw+ydtj0xx/XbFtxNSTlXydKwzs5gVW5ZKsFlAkwoOOQ9TIsyoCC8hq18tOwg==" }, "@material-ui/utils": { - "version": "4.7.1", - "resolved": "https://registry.npmjs.org/@material-ui/utils/-/utils-4.7.1.tgz", - "integrity": "sha512-+ux0SlLdlehvzCk2zdQ3KiS3/ylWvuo/JwAGhvb8dFVvwR21K28z0PU9OQW2PGogrMEdvX3miEI5tGxTwwWiwQ==", + "version": "4.9.6", + "resolved": "https://registry.npmjs.org/@material-ui/utils/-/utils-4.9.6.tgz", + "integrity": "sha512-gqlBn0JPPTUZeAktn1rgMcy9Iczrr74ecx31tyZLVGdBGGzsxzM6PP6zeS7FuoLS6vG4hoZP7hWnOoHtkR0Kvw==", "requires": { "@babel/runtime": "^7.4.4", "prop-types": "^15.7.2", @@ -1408,9 +1427,9 @@ "integrity": "sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw==" }, "@sheerun/mutationobserver-shim": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@sheerun/mutationobserver-shim/-/mutationobserver-shim-0.3.2.tgz", - "integrity": "sha512-vTCdPp/T/Q3oSqwHmZ5Kpa9oI7iLtGl3RQaA/NyLHikvcrPxACkkKVr/XzkSPJWXHRhKGzVvb0urJsbMlRxi1Q==" + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/@sheerun/mutationobserver-shim/-/mutationobserver-shim-0.3.3.tgz", + "integrity": "sha512-DetpxZw1fzPD5xUBrIAoplLChO2VB8DlL5Gg+I1IR9b2wPqYIca2WSUxL5g1vLeR4MsQq1NeWriXAVffV+U1Fw==" }, "@svgr/babel-plugin-add-jsx-attribute": { "version": "4.2.0", @@ -1522,16 +1541,115 @@ } }, "@testing-library/dom": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/@testing-library/dom/-/dom-6.11.0.tgz", - "integrity": "sha512-Pkx9LMIGshyNbfmecjt18rrAp/ayMqGH674jYER0SXj0iG9xZc+zWRjk2Pg9JgPBDvwI//xGrI/oOQkAi4YEew==", + "version": "6.16.0", + "resolved": "https://registry.npmjs.org/@testing-library/dom/-/dom-6.16.0.tgz", + "integrity": "sha512-lBD88ssxqEfz0wFL6MeUyyWZfV/2cjEZZV3YRpb2IoJRej/4f1jB0TzqIOznTpfR1r34CNesrubxwIlAQ8zgPA==", "requires": { - "@babel/runtime": "^7.6.2", + "@babel/runtime": "^7.8.4", "@sheerun/mutationobserver-shim": "^0.3.2", - "@types/testing-library__dom": "^6.0.0", - "aria-query": "3.0.0", - "pretty-format": "^24.9.0", - "wait-for-expect": "^3.0.0" + "@types/testing-library__dom": "^6.12.1", + "aria-query": "^4.0.2", + "dom-accessibility-api": "^0.3.0", + "pretty-format": "^25.1.0", + "wait-for-expect": "^3.0.2" + }, + "dependencies": { + "@babel/runtime": { + "version": "7.9.2", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.9.2.tgz", + "integrity": "sha512-NE2DtOdufG7R5vnfQUTehdTfNycfUANEtCa9PssN9O/xmTzP4E08UI797ixaei6hBEVL9BI/PsdJS5x7mWoB9Q==", + "requires": { + "regenerator-runtime": "^0.13.4" + } + }, + "@jest/types": { + "version": "25.2.3", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-25.2.3.tgz", + "integrity": "sha512-6oLQwO9mKif3Uph3RX5J1i3S7X7xtDHWBaaaoeKw8hOzV6YUd0qDcYcHZ6QXMHDIzSr7zzrEa51o2Ovlj6AtKQ==", + "requires": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^1.1.1", + "@types/yargs": "^15.0.0", + "chalk": "^3.0.0" + } + }, + "@types/yargs": { + "version": "15.0.4", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.4.tgz", + "integrity": "sha512-9T1auFmbPZoxHz0enUFlUuKRy3it01R+hlggyVUMtnCTQRunsQYifnSGb8hET4Xo8yiC0o0r1paW3ud5+rbURg==", + "requires": { + "@types/yargs-parser": "*" + } + }, + "ansi-styles": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", + "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", + "requires": { + "@types/color-name": "^1.1.1", + "color-convert": "^2.0.1" + } + }, + "aria-query": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-4.0.2.tgz", + "integrity": "sha512-S1G1V790fTaigUSM/Gd0NngzEfiMy9uTUfMyHhKhVyy4cH5O/eTuR01ydhGL0z4Za1PXFTRGH3qL8VhUQuEO5w==", + "requires": { + "@babel/runtime": "^7.7.4", + "@babel/runtime-corejs3": "^7.7.4" + } + }, + "chalk": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", + "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" + }, + "pretty-format": { + "version": "25.2.3", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-25.2.3.tgz", + "integrity": "sha512-IP4+5UOAVGoyqC/DiomOeHBUKN6q00gfyT2qpAsRH64tgOKB2yF7FHJXC18OCiU0/YFierACup/zdCOWw0F/0w==", + "requires": { + "@jest/types": "^25.2.3", + "ansi-regex": "^5.0.0", + "ansi-styles": "^4.0.0", + "react-is": "^16.12.0" + } + }, + "regenerator-runtime": { + "version": "0.13.5", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", + "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==" + }, + "supports-color": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", + "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", + "requires": { + "has-flag": "^4.0.0" + } + } } }, "@testing-library/jest-dom": { @@ -1551,22 +1669,27 @@ } }, "@testing-library/react": { - "version": "9.4.0", - "resolved": "https://registry.npmjs.org/@testing-library/react/-/react-9.4.0.tgz", - "integrity": "sha512-XdhDWkI4GktUPsz0AYyeQ8M9qS/JFie06kcSnUVcpgOwFjAu9vhwR83qBl+lw9yZWkbECjL8Hd+n5hH6C0oWqg==", + "version": "9.5.0", + "resolved": "https://registry.npmjs.org/@testing-library/react/-/react-9.5.0.tgz", + "integrity": "sha512-di1b+D0p+rfeboHO5W7gTVeZDIK5+maEgstrZbWZSSvxDyfDRkkyBE1AJR5Psd6doNldluXlCWqXriUfqu/9Qg==", "requires": { - "@babel/runtime": "^7.7.6", - "@testing-library/dom": "^6.11.0", + "@babel/runtime": "^7.8.4", + "@testing-library/dom": "^6.15.0", "@types/testing-library__react": "^9.1.2" }, "dependencies": { "@babel/runtime": { - "version": "7.8.0", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.8.0.tgz", - "integrity": "sha512-Z7ti+HB0puCcLmFE3x90kzaVgbx6TRrYIReaygW6EkBEnJh1ajS4/inhF7CypzWeDV3NFl1AfWj0eMtdihojxw==", + "version": "7.9.2", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.9.2.tgz", + "integrity": "sha512-NE2DtOdufG7R5vnfQUTehdTfNycfUANEtCa9PssN9O/xmTzP4E08UI797ixaei6hBEVL9BI/PsdJS5x7mWoB9Q==", "requires": { - "regenerator-runtime": "^0.13.2" + "regenerator-runtime": "^0.13.4" } + }, + "regenerator-runtime": { + "version": "0.13.5", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", + "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==" } } }, @@ -1612,6 +1735,11 @@ "@babel/types": "^7.3.0" } }, + "@types/color-name": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", + "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==" + }, "@types/eslint-visitor-keys": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", @@ -1685,26 +1813,26 @@ "integrity": "sha512-ce5d3q03Ex0sy4R14722Rmt6MT07Ua+k4FwDfdcToYJcMKNtRVQvJ6JCAPdAmAnbRb6CsX6aYb9m96NGod9uTw==" }, "@types/react": { - "version": "16.9.17", - "resolved": "https://registry.npmjs.org/@types/react/-/react-16.9.17.tgz", - "integrity": "sha512-UP27In4fp4sWF5JgyV6pwVPAQM83Fj76JOcg02X5BZcpSu5Wx+fP9RMqc2v0ssBoQIFvD5JdKY41gjJJKmw6Bg==", + "version": "16.9.26", + "resolved": "https://registry.npmjs.org/@types/react/-/react-16.9.26.tgz", + "integrity": "sha512-dGuSM+B0Pq1MKXYUMlUQWeS6Jj9IhSAUf9v8Ikaimj+YhkBcQrihWBkmyEhK/1fzkJTwZQkhZp5YhmWa2CH+Rw==", "requires": { "@types/prop-types": "*", "csstype": "^2.2.0" } }, "@types/react-dom": { - "version": "16.9.4", - "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-16.9.4.tgz", - "integrity": "sha512-fya9xteU/n90tda0s+FtN5Ym4tbgxpq/hb/Af24dvs6uYnYn+fspaxw5USlw0R8apDNwxsqumdRoCoKitckQqw==", + "version": "16.9.5", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-16.9.5.tgz", + "integrity": "sha512-BX6RQ8s9D+2/gDhxrj8OW+YD4R+8hj7FEM/OJHGNR0KipE1h1mSsf39YeyC81qafkq+N3rU3h3RFbLSwE5VqUg==", "requires": { "@types/react": "*" } }, "@types/react-transition-group": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.2.3.tgz", - "integrity": "sha512-Hk8jiuT7iLOHrcjKP/ZVSyCNXK73wJAUz60xm0mVhiRujrdiI++j4duLiL282VGxwAgxetHQFfqA29LgEeSkFA==", + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.2.4.tgz", + "integrity": "sha512-8DMUaDqh0S70TjkqU0DxOu80tFUiiaS9rxkWip/nb7gtvAsbqOXm02UCmR8zdcjWujgeYPiPNTVpVpKzUDotwA==", "requires": { "@types/react": "*" } @@ -1715,20 +1843,97 @@ "integrity": "sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw==" }, "@types/testing-library__dom": { - "version": "6.11.1", - "resolved": "https://registry.npmjs.org/@types/testing-library__dom/-/testing-library__dom-6.11.1.tgz", - "integrity": "sha512-ImChHtQqmjwraRLqBC2sgSQFtczeFvBmBcfhTYZn/3KwXbyD07LQykEQ0xJo7QHc1GbVvf7pRyGaIe6PkCdxEw==", + "version": "6.14.0", + "resolved": "https://registry.npmjs.org/@types/testing-library__dom/-/testing-library__dom-6.14.0.tgz", + "integrity": "sha512-sMl7OSv0AvMOqn1UJ6j1unPMIHRXen0Ita1ujnMX912rrOcawe4f7wu0Zt9GIQhBhJvH2BaibqFgQ3lP+Pj2hA==", "requires": { "pretty-format": "^24.3.0" } }, "@types/testing-library__react": { - "version": "9.1.2", - "resolved": "https://registry.npmjs.org/@types/testing-library__react/-/testing-library__react-9.1.2.tgz", - "integrity": "sha512-CYaMqrswQ+cJACy268jsLAw355DZtPZGt3Jwmmotlcu8O/tkoXBI6AeZ84oZBJsIsesozPKzWzmv/0TIU+1E9Q==", + "version": "9.1.3", + "resolved": "https://registry.npmjs.org/@types/testing-library__react/-/testing-library__react-9.1.3.tgz", + "integrity": "sha512-iCdNPKU3IsYwRK9JieSYAiX0+aYDXOGAmrC/3/M7AqqSDKnWWVv07X+Zk1uFSL7cMTUYzv4lQRfohucEocn5/w==", "requires": { "@types/react-dom": "*", - "@types/testing-library__dom": "*" + "@types/testing-library__dom": "*", + "pretty-format": "^25.1.0" + }, + "dependencies": { + "@jest/types": { + "version": "25.2.3", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-25.2.3.tgz", + "integrity": "sha512-6oLQwO9mKif3Uph3RX5J1i3S7X7xtDHWBaaaoeKw8hOzV6YUd0qDcYcHZ6QXMHDIzSr7zzrEa51o2Ovlj6AtKQ==", + "requires": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^1.1.1", + "@types/yargs": "^15.0.0", + "chalk": "^3.0.0" + } + }, + "@types/yargs": { + "version": "15.0.4", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.4.tgz", + "integrity": "sha512-9T1auFmbPZoxHz0enUFlUuKRy3it01R+hlggyVUMtnCTQRunsQYifnSGb8hET4Xo8yiC0o0r1paW3ud5+rbURg==", + "requires": { + "@types/yargs-parser": "*" + } + }, + "ansi-styles": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", + "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", + "requires": { + "@types/color-name": "^1.1.1", + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", + "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" + }, + "pretty-format": { + "version": "25.2.3", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-25.2.3.tgz", + "integrity": "sha512-IP4+5UOAVGoyqC/DiomOeHBUKN6q00gfyT2qpAsRH64tgOKB2yF7FHJXC18OCiU0/YFierACup/zdCOWw0F/0w==", + "requires": { + "@jest/types": "^25.2.3", + "ansi-regex": "^5.0.0", + "ansi-styles": "^4.0.0", + "react-is": "^16.12.0" + } + }, + "supports-color": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", + "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", + "requires": { + "has-flag": "^4.0.0" + } + } } }, "@types/yargs": { @@ -4107,11 +4312,6 @@ "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" }, - "convert-css-length": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/convert-css-length/-/convert-css-length-2.0.1.tgz", - "integrity": "sha512-iGpbcvhLPRKUbBc0Quxx7w/bV14AC3ItuBEGMahA5WTYqB8lq9jH0kTXFheCBASsYnqeMFZhiTruNxr1N59Axg==" - }, "convert-source-map": { "version": "1.7.0", "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", @@ -4287,6 +4487,14 @@ "postcss": "^7.0.5" } }, + "css-box-model": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/css-box-model/-/css-box-model-1.2.0.tgz", + "integrity": "sha512-lri0br+jSNV0kkkiGEp9y9y3Njq2PmpqbeGWRFQJuZteZzY9iC9GZhQ8Y4WpPwM/2YocjHePxy14igJY7YKzkA==", + "requires": { + "tiny-invariant": "^1.0.6" + } + }, "css-color-names": { "version": "0.0.4", "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", @@ -4529,9 +4737,9 @@ } }, "csstype": { - "version": "2.6.8", - "resolved": "https://registry.npmjs.org/csstype/-/csstype-2.6.8.tgz", - "integrity": "sha512-msVS9qTuMT5zwAGCVm4mxfrZ18BNc6Csd0oJAtiFMZ1FAx1CCvy2+5MDmYoix63LM/6NDbNtodCiGYGmFgO0dA==" + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-2.6.9.tgz", + "integrity": "sha512-xz39Sb4+OaTsULgUERcCk+TJj8ylkL4aSVDQiX/ksxbELSqwkgt4d4RD7fovIdgJGSuNYqwZEiVjYY5l0ask+Q==" }, "cyclist": { "version": "1.0.1", @@ -4618,6 +4826,11 @@ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" }, + "deepmerge": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-2.2.1.tgz", + "integrity": "sha512-R9hc1Xa/NOBi9WRVUWg19rl1UB7Tt4kuPd+thNJgFZoxXsTz7ncaPaeIm+40oSGuP33DfMb4sZt1QIGiJzC4EA==" + }, "default-gateway": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-4.2.0.tgz", @@ -4834,6 +5047,11 @@ "esutils": "^2.0.2" } }, + "dom-accessibility-api": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/dom-accessibility-api/-/dom-accessibility-api-0.3.0.tgz", + "integrity": "sha512-PzwHEmsRP3IGY4gv/Ug+rMeaTIyTJvadCb+ujYXYeIylbHJezIyNToe8KfEgHTCEYyC+/bUghYOGg8yMGlZ6vA==" + }, "dom-converter": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/dom-converter/-/dom-converter-0.2.0.tgz", @@ -6180,6 +6398,11 @@ } } }, + "fn-name": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/fn-name/-/fn-name-3.0.0.tgz", + "integrity": "sha512-eNMNr5exLoavuAMhIUVsOKF79SWd/zG104ef6sxBTSw+cZc6BXdQXDvYcGvp0VbxVVSp1XDUNoz7mg1xMtSznA==" + }, "follow-redirects": { "version": "1.9.0", "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.9.0.tgz", @@ -6248,6 +6471,40 @@ "mime-types": "^2.1.12" } }, + "formik": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/formik/-/formik-2.1.4.tgz", + "integrity": "sha512-oKz8S+yQBzuQVSEoxkqqJrKQS5XJASWGVn6mrs+oTWrBoHgByVwwI1qHiVc9GKDpZBU9vAxXYAKz2BvujlwunA==", + "requires": { + "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" + }, + "dependencies": { + "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" + } + }, + "scheduler": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.18.0.tgz", + "integrity": "sha512-agTSHR1Nbfi6ulI0kYNK0203joW2Y5W4po4l+v03tOoiJKpTBbxpNhWDvqc/4IcOw+KLmSiQLTasZ4cab2/UWQ==", + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1" + } + } + } + }, "forwarded": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", @@ -8523,9 +8780,9 @@ } }, "jss": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss/-/jss-10.0.3.tgz", - "integrity": "sha512-AcDvFdOk16If9qvC9KN3oFXsrkHWM9+TaPMpVB9orm3z+nq1Xw3ofHyflRe/mkSucRZnaQtlhZs1hdP3DR9uRw==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss/-/jss-10.1.1.tgz", + "integrity": "sha512-Xz3qgRUFlxbWk1czCZibUJqhVPObrZHxY3FPsjCXhDld4NOj1BgM14Ir5hVm+Qr6OLqVljjGvoMcCdXNOAbdkQ==", "requires": { "@babel/runtime": "^7.3.1", "csstype": "^2.6.5", @@ -8534,69 +8791,69 @@ } }, "jss-plugin-camel-case": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss-plugin-camel-case/-/jss-plugin-camel-case-10.0.3.tgz", - "integrity": "sha512-rild/oFKFkmRP7AoiX9D6bdDAUfmJv8c7sEBvFoi+JP31dn2W8nw4txMKGnV1LJKlFkYprdZt1X99Uvztl1hug==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss-plugin-camel-case/-/jss-plugin-camel-case-10.1.1.tgz", + "integrity": "sha512-MDIaw8FeD5uFz1seQBKz4pnvDLnj5vIKV5hXSVdMaAVq13xR6SVTVWkIV/keyTs5txxTvzGJ9hXoxgd1WTUlBw==", "requires": { "@babel/runtime": "^7.3.1", "hyphenate-style-name": "^1.0.3", - "jss": "^10.0.3" + "jss": "10.1.1" } }, "jss-plugin-default-unit": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss-plugin-default-unit/-/jss-plugin-default-unit-10.0.3.tgz", - "integrity": "sha512-n+XfVLPF9Qh7IOTdQ8M4oRpjpg6egjr/r0NNytubbCafMgCILJYIVrMTGgOTydH+uvak8onQY3f/F9hasPUx6g==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss-plugin-default-unit/-/jss-plugin-default-unit-10.1.1.tgz", + "integrity": "sha512-UkeVCA/b3QEA4k0nIKS4uWXDCNmV73WLHdh2oDGZZc3GsQtlOCuiH3EkB/qI60v2MiCq356/SYWsDXt21yjwdg==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "^10.0.3" + "jss": "10.1.1" } }, "jss-plugin-global": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss-plugin-global/-/jss-plugin-global-10.0.3.tgz", - "integrity": "sha512-kNotkAciJIXpIGYnmueaIifBne9rdq31O8Xq1nF7KMfKlskNRANTcEX5rVnsGKl2yubTMYfjKBFCeDgcQn6+gA==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss-plugin-global/-/jss-plugin-global-10.1.1.tgz", + "integrity": "sha512-VBG3wRyi3Z8S4kMhm8rZV6caYBegsk+QnQZSVmrWw6GVOT/Z4FA7eyMu5SdkorDlG/HVpHh91oFN56O4R9m2VA==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "^10.0.3" + "jss": "10.1.1" } }, "jss-plugin-nested": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss-plugin-nested/-/jss-plugin-nested-10.0.3.tgz", - "integrity": "sha512-OMucRs9YLvWlZ3Ew+VhdgNVMwSS2zZy/2vy+s/etvopnPUzDHgCnJwdY2Wx/SlhLGERJeKKufyih2seH+ui0iw==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss-plugin-nested/-/jss-plugin-nested-10.1.1.tgz", + "integrity": "sha512-ozEu7ZBSVrMYxSDplPX3H82XHNQk2DQEJ9TEyo7OVTPJ1hEieqjDFiOQOxXEj9z3PMqkylnUbvWIZRDKCFYw5Q==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "^10.0.3", + "jss": "10.1.1", "tiny-warning": "^1.0.2" } }, "jss-plugin-props-sort": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss-plugin-props-sort/-/jss-plugin-props-sort-10.0.3.tgz", - "integrity": "sha512-ufhvdCMnRcDa0tNHoZ12OcVNQQyE10yLMohxo/UIMarLV245rM6n9D19A12epjldRgyiS13SoSyLFCJEobprYg==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss-plugin-props-sort/-/jss-plugin-props-sort-10.1.1.tgz", + "integrity": "sha512-g/joK3eTDZB4pkqpZB38257yD4LXB0X15jxtZAGbUzcKAVUHPl9Jb47Y7lYmiGsShiV4YmQRqG1p2DHMYoK91g==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "^10.0.3" + "jss": "10.1.1" } }, "jss-plugin-rule-value-function": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss-plugin-rule-value-function/-/jss-plugin-rule-value-function-10.0.3.tgz", - "integrity": "sha512-RWwIT2UBAIwf3f6DQtt5gyjxHMRJoeO9TQku+ueR8dBMakqSSe8vFwQNfjXEoe0W+Tez5HZCTkZKNMulv3Z+9A==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss-plugin-rule-value-function/-/jss-plugin-rule-value-function-10.1.1.tgz", + "integrity": "sha512-ClV1lvJ3laU9la1CUzaDugEcwnpjPTuJ0yGy2YtcU+gG/w9HMInD5vEv7xKAz53Bk4WiJm5uLOElSEshHyhKNw==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "^10.0.3" + "jss": "10.1.1" } }, "jss-plugin-vendor-prefixer": { - "version": "10.0.3", - "resolved": "https://registry.npmjs.org/jss-plugin-vendor-prefixer/-/jss-plugin-vendor-prefixer-10.0.3.tgz", - "integrity": "sha512-zVs6e5z4tFRK/fJ5kuTLzXlTFQbLeFTVwk7lTZiYNufmZwKT0kSmnOJDUukcSe7JLGSRztjWhnHB/6voP174gw==", + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/jss-plugin-vendor-prefixer/-/jss-plugin-vendor-prefixer-10.1.1.tgz", + "integrity": "sha512-09MZpQ6onQrhaVSF6GHC4iYifQ7+4YC/tAP6D4ZWeZotvCMq1mHLqNKRIaqQ2lkgANjlEot2JnVi1ktu4+L4pw==", "requires": { "@babel/runtime": "^7.3.1", "css-vendor": "^2.0.7", - "jss": "^10.0.3" + "jss": "10.1.1" } }, "jsx-ast-utils": { @@ -8781,6 +9038,11 @@ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" }, + "lodash-es": { + "version": "4.17.15", + "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.15.tgz", + "integrity": "sha512-rlrc3yU3+JNOpZ9zj5pQtxnx2THmvRykwL4Xlxoa8I9lHBlVbbyPhgyPMioxVZ4NqyxaVVtaJnzsyOidQIhyyQ==" + }, "lodash._reinterpolate": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", @@ -8969,6 +9231,11 @@ "p-is-promise": "^2.0.0" } }, + "memoize-one": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/memoize-one/-/memoize-one-5.1.1.tgz", + "integrity": "sha512-HKeeBpWvqiVJD57ZUAsJNm71eHTykffzcLZVYWiVfQeI1rJtuEaS7hQiEpWfVVk18donPwJEcFKIkCmPJNOhHA==" + }, "memory-fs": { "version": "0.4.1", "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", @@ -9515,11 +9782,6 @@ "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=" }, - "normalize-scroll-left": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/normalize-scroll-left/-/normalize-scroll-left-0.2.0.tgz", - "integrity": "sha512-t5oCENZJl8TGusJKoCJm7+asaSsPuNmK6+iEjrZ5TyBj2f02brCRsd4c83hwtu+e5d4LCSBZ0uoDlMjBo+A8yA==" - }, "normalize-url": { "version": "1.9.1", "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-1.9.1.tgz", @@ -10118,9 +10380,9 @@ } }, "popper.js": { - "version": "1.16.0", - "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.0.tgz", - "integrity": "sha512-+G+EkOPoE5S/zChTpmBSSDYmhXJ5PsW8eMhH8cP/CQHMFPBG/kC9Y5IIw6qNYgdJ+/COf0ddY2li28iHaZRSjw==" + "version": "1.16.1", + "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.1.tgz", + "integrity": "sha512-Wb4p1J4zyFTbM+u6WuO4XstYx4Ky9Cewe4DWrel7B0w6VVICvPwdOpotjzcf6eD8TsckVnIMNONQyPIUFOUbCQ==" }, "portfinder": { "version": "1.0.25", @@ -11206,6 +11468,11 @@ "react-is": "^16.8.1" } }, + "property-expr": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/property-expr/-/property-expr-2.0.2.tgz", + "integrity": "sha512-bc/5ggaYZxNkFKj374aLbEDqVADdYaLcFo8XBkishUWbaAdjlphaBFns9TvRA2pUseVL/wMFmui9X3IdNDU37g==" + }, "proxy-addr": { "version": "2.0.5", "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", @@ -11315,6 +11582,11 @@ "performance-now": "^2.1.0" } }, + "raf-schd": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/raf-schd/-/raf-schd-4.0.2.tgz", + "integrity": "sha512-VhlMZmGy6A6hrkJWHLNTGl5gtgMUm+xfGza6wbwnE914yeQ5Ybm18vgM734RZhMgfw4tacUrWseGZlpUrrakEQ==" + }, "randombytes": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", @@ -11356,9 +11628,9 @@ } }, "react": { - "version": "16.12.0", - "resolved": "https://registry.npmjs.org/react/-/react-16.12.0.tgz", - "integrity": "sha512-fglqy3k5E+81pA8s+7K0/T3DBCF0ZDOher1elBFzF7O6arXJgzyu/FW+COxFvAWXJoJN9KIZbT2LXlukwphYTA==", + "version": "16.13.1", + "resolved": "https://registry.npmjs.org/react/-/react-16.13.1.tgz", + "integrity": "sha512-YMZQQq32xHLX0bz5Mnibv1/LHb3Sqzngu7xstSM+vrkE5Kzr9xE0yMByK5kMoTK30YVJE61WfbxIFFvfeDKT1w==", "requires": { "loose-envify": "^1.1.0", "object-assign": "^4.1.1", @@ -11378,6 +11650,35 @@ "whatwg-fetch": "^3.0.0" } }, + "react-beautiful-dnd": { + "version": "13.0.0", + "resolved": "https://registry.npmjs.org/react-beautiful-dnd/-/react-beautiful-dnd-13.0.0.tgz", + "integrity": "sha512-87It8sN0ineoC3nBW0SbQuTFXM6bUqM62uJGY4BtTf0yzPl8/3+bHMWkgIe0Z6m8e+gJgjWxefGRVfpE3VcdEg==", + "requires": { + "@babel/runtime": "^7.8.4", + "css-box-model": "^1.2.0", + "memoize-one": "^5.1.1", + "raf-schd": "^4.0.2", + "react-redux": "^7.1.1", + "redux": "^4.0.4", + "use-memo-one": "^1.1.1" + }, + "dependencies": { + "@babel/runtime": { + "version": "7.9.2", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.9.2.tgz", + "integrity": "sha512-NE2DtOdufG7R5vnfQUTehdTfNycfUANEtCa9PssN9O/xmTzP4E08UI797ixaei6hBEVL9BI/PsdJS5x7mWoB9Q==", + "requires": { + "regenerator-runtime": "^0.13.4" + } + }, + "regenerator-runtime": { + "version": "0.13.5", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", + "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==" + } + } + }, "react-dev-utils": { "version": "10.0.0", "resolved": "https://registry.npmjs.org/react-dev-utils/-/react-dev-utils-10.0.0.tgz", @@ -11527,14 +11828,14 @@ } }, "react-dom": { - "version": "16.12.0", - "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.12.0.tgz", - "integrity": "sha512-LMxFfAGrcS3kETtQaCkTKjMiifahaMySFDn71fZUNpPHZQEzmk/GiAeIT8JSOrHB23fnuCOMruL2a8NYlw+8Gw==", + "version": "16.13.1", + "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.13.1.tgz", + "integrity": "sha512-81PIMmVLnCNLO/fFOQxdQkvEq/+Hfpv24XNJfpyZhTRfO0QcmQIF/PgCa1zCOj2w1hrn12MFLyaJ/G0+Mxtfag==", "requires": { "loose-envify": "^1.1.0", "object-assign": "^4.1.1", "prop-types": "^15.6.2", - "scheduler": "^0.18.0" + "scheduler": "^0.19.1" } }, "react-error-overlay": { @@ -11562,11 +11863,43 @@ } } }, + "react-fast-compare": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/react-fast-compare/-/react-fast-compare-2.0.4.tgz", + "integrity": "sha512-suNP+J1VU1MWFKcyt7RtjiSWUjvidmQSlqu+eHslq+342xCbGTYmC0mEhPCOHxlW0CywylOC1u2DFAT+bv4dBw==" + }, "react-is": { "version": "16.12.0", "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.12.0.tgz", "integrity": "sha512-rPCkf/mWBtKc97aLL9/txD8DZdemK0vkA3JMLShjlJB3Pj3s+lpf1KaBzMfQrAmhMQB0n1cU/SUGgKKBCe837Q==" }, + "react-os": { + "version": "0.0.9", + "resolved": "https://registry.npmjs.org/react-os/-/react-os-0.0.9.tgz", + "integrity": "sha1-kM+AyDZntZVBCbh3f9iFXxtvdHY=" + }, + "react-redux": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/react-redux/-/react-redux-7.2.0.tgz", + "integrity": "sha512-EvCAZYGfOLqwV7gh849xy9/pt55rJXPwmYvI4lilPM5rUT/1NxuuN59ipdBksRVSvz0KInbPnp4IfoXJXCqiDA==", + "requires": { + "@babel/runtime": "^7.5.5", + "hoist-non-react-statics": "^3.3.0", + "loose-envify": "^1.4.0", + "prop-types": "^15.7.2", + "react-is": "^16.9.0" + }, + "dependencies": { + "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" + } + } + } + }, "react-router": { "version": "5.1.2", "resolved": "https://registry.npmjs.org/react-router/-/react-router-5.1.2.tgz", @@ -11792,6 +12125,15 @@ "strip-indent": "^3.0.0" } }, + "redux": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/redux/-/redux-4.0.5.tgz", + "integrity": "sha512-VSz1uMAH24DM6MF72vcojpYPtrTUu3ByVWfPL1nPfVRb5mZVTve5GnNCUV53QM/BZ66xfWrm0CTWoM+Xlz8V1w==", + "requires": { + "loose-envify": "^1.4.0", + "symbol-observable": "^1.2.0" + } + }, "regenerate": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.0.tgz", @@ -12286,9 +12628,9 @@ } }, "scheduler": { - "version": "0.18.0", - "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.18.0.tgz", - "integrity": "sha512-agTSHR1Nbfi6ulI0kYNK0203joW2Y5W4po4l+v03tOoiJKpTBbxpNhWDvqc/4IcOw+KLmSiQLTasZ4cab2/UWQ==", + "version": "0.19.1", + "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.19.1.tgz", + "integrity": "sha512-n/zwRWRYSUj0/3g/otKDRPMh6qv2SYMWNq85IEa8iZyAv8od9zDYpGSnpBEjNgcMNq6Scbu5KfIPxNF72R/2EA==", "requires": { "loose-envify": "^1.1.0", "object-assign": "^4.1.1" @@ -13202,6 +13544,11 @@ "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==" }, + "synchronous-promise": { + "version": "2.0.10", + "resolved": "https://registry.npmjs.org/synchronous-promise/-/synchronous-promise-2.0.10.tgz", + "integrity": "sha512-6PC+JRGmNjiG3kJ56ZMNWDPL8hjyghF5cMXIFOKg+NiwwEZZIvxTWd0pinWKyD227odg9ygF8xVhhz7gb8Uq7A==" + }, "table": { "version": "5.4.6", "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", @@ -13478,6 +13825,11 @@ "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" }, + "toposort": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/toposort/-/toposort-2.0.2.tgz", + "integrity": "sha1-riF2gXXRVZ1IvvNUILL0li8JwzA=" + }, "tough-cookie": { "version": "2.5.0", "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", @@ -13764,6 +14116,11 @@ "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==" }, + "use-memo-one": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/use-memo-one/-/use-memo-one-1.1.1.tgz", + "integrity": "sha512-oFfsyun+bP7RX8X2AskHNTxu+R3QdE/RC5IefMbqptmACAA/gfol1KDD5KRzPsGMa62sWxGZw+Ui43u6x4ddoQ==" + }, "util": { "version": "0.10.3", "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", @@ -13871,9 +14228,9 @@ } }, "wait-for-expect": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/wait-for-expect/-/wait-for-expect-3.0.1.tgz", - "integrity": "sha512-3Ha7lu+zshEG/CeHdcpmQsZnnZpPj/UsG3DuKO8FskjuDbkx3jE3845H+CuwZjA2YWYDfKMU2KhnCaXMLd3wVw==" + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/wait-for-expect/-/wait-for-expect-3.0.2.tgz", + "integrity": "sha512-cfS1+DZxuav1aBYbaO/kE06EOS8yRw7qOFoD3XtjTkYvCvh3zUvNST8DXK/nPaeqIzIv3P3kL3lRJn8iwOiSag==" }, "walker": { "version": "1.0.7", @@ -14669,6 +15026,35 @@ "camelcase": "^5.0.0", "decamelize": "^1.2.0" } + }, + "yup": { + "version": "0.28.3", + "resolved": "https://registry.npmjs.org/yup/-/yup-0.28.3.tgz", + "integrity": "sha512-amVkCgFWe5bGjrrUiODkbIzrSwtB8JpZrQYSrfj2YsbRdrV+tn9LquWdZDlfOx2HXyfEA8FGnlwidE/bFDxO7Q==", + "requires": { + "@babel/runtime": "^7.8.7", + "fn-name": "~3.0.0", + "lodash": "^4.17.15", + "lodash-es": "^4.17.11", + "property-expr": "^2.0.0", + "synchronous-promise": "^2.0.10", + "toposort": "^2.0.2" + }, + "dependencies": { + "@babel/runtime": { + "version": "7.9.2", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.9.2.tgz", + "integrity": "sha512-NE2DtOdufG7R5vnfQUTehdTfNycfUANEtCa9PssN9O/xmTzP4E08UI797ixaei6hBEVL9BI/PsdJS5x7mWoB9Q==", + "requires": { + "regenerator-runtime": "^0.13.4" + } + }, + "regenerator-runtime": { + "version": "0.13.5", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", + "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==" + } + } } } } diff --git a/package.json b/package.json index ac7cf9b..7e622c1 100644 --- a/package.json +++ b/package.json @@ -3,17 +3,22 @@ "version": "0.1.0", "private": true, "dependencies": { - "@material-ui/core": "^4.8.3", - "@material-ui/icons": "^4.5.1", + "@material-ui/core": "^4.9.7", + "@material-ui/icons": "^4.9.1", + "@material-ui/lab": "^4.0.0-alpha.46", "@testing-library/jest-dom": "^4.2.4", - "@testing-library/react": "^9.4.0", + "@testing-library/react": "^9.5.0", "@testing-library/user-event": "^7.2.1", "axios": "^0.19.2", + "formik": "^2.1.4", "material-ui": "^0.20.2", - "react": "^16.12.0", - "react-dom": "^16.12.0", + "react": "^16.13.1", + "react-beautiful-dnd": "^13.0.0", + "react-dom": "^16.13.1", + "react-os": "0.0.9", "react-router-dom": "^5.1.2", - "react-scripts": "3.3.0" + "react-scripts": "3.3.0", + "yup": "^0.28.3" }, "scripts": { "start": "react-scripts start", diff --git a/src/components/fieldsAnswerForm/FormFieldCheckbox.js b/src/components/fieldsAnswerForm/FormFieldCheckbox.js index 7b4adf5..462b63f 100644 --- a/src/components/fieldsAnswerForm/FormFieldCheckbox.js +++ b/src/components/fieldsAnswerForm/FormFieldCheckbox.js @@ -1,41 +1,42 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import Typography from '@material-ui/core/Typography'; -import Checkbox from '@material-ui/core/Checkbox'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import AddCircleIcon from "@material-ui/icons/AddCircle"; +import CloseIcon from "@material-ui/icons/Close"; +import Switch from "@material-ui/core/Switch"; +import FormControlLabel from "@material-ui/core/FormControlLabel"; +import Typography from "@material-ui/core/Typography"; +import Checkbox from "@material-ui/core/Checkbox"; -import FieldFooterOptions from './FieldFooterOptions'; +import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), minheight: theme.spacing(16), - margin: theme.spacing(2) + margin: theme.spacing(2), }, questionsGrid: { - marginBottom: '20px' + marginBottom: "20px", }, })); - - function FormFieldCheckbox(props) { const classes = useStyles(); - const options = props.options.map(function(x) { - return <span>{x.value} <Checkbox /></span>; + const options = props.options.map(function (x) { + return ( + <span> + {x.value} <Checkbox /> + </span> + ); }); return ( @@ -46,17 +47,20 @@ function FormFieldCheckbox(props) { {props.question} </Typography> </Grid> - <Grid item container + <Grid + item + container direction="column" justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} > {options} </Grid> </Grid> </Paper> ); - } -export default FormFieldCheckbox; \ No newline at end of file +export default FormFieldCheckbox; diff --git a/src/components/fieldsCreateForm/DefaultField.js b/src/components/fieldsCreateForm/DefaultField.js new file mode 100644 index 0000000..258abf4 --- /dev/null +++ b/src/components/fieldsCreateForm/DefaultField.js @@ -0,0 +1,48 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import TextField from "@material-ui/core/TextField"; +const useStyles = makeStyles((theme) => ({ + questionsGrid: { + marginBottom: "20px", + }, + errorGrid: { + marginTop: "1%", + color: "#ff4646", + width: "40%", + fontSize: "13px", + }, + textFieldStyle: { + width: "80%", + }, +})); + +export default function DefaultField(props) { + const classes = useStyles(); + return ( + <> + <Grid item xs={12} sm={6} className={classes.questionsGrid}> + <TextField + value={props.question} + label="Pergunta" + className={classes.textFieldStyle} + onChange={(e) => props.setQuestionField(e.target.value, props.idq)} + /> + <Grid className={classes.errorGrid}> + {props.error.errorMsg.question} + </Grid> + </Grid> + <Grid item xs={12} sm={6} className={classes.questionsGrid}> + <TextField + value={props.description} + label="Descrição" + className={classes.textFieldStyle} + onChange={(e) => props.setDescriptionField(e.target.value, props.idq)} + /> + <Grid className={classes.errorGrid}> + {props.error.errorMsg.description} + </Grid> + </Grid> + </> + ); +} diff --git a/src/components/fieldsCreateForm/FieldFooterOptions.js b/src/components/fieldsCreateForm/FieldFooterOptions.js index f6446f0..8890267 100644 --- a/src/components/fieldsCreateForm/FieldFooterOptions.js +++ b/src/components/fieldsCreateForm/FieldFooterOptions.js @@ -1,40 +1,45 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Switch from "@material-ui/core/Switch"; +import FormControlLabel from "@material-ui/core/FormControlLabel"; +import Tooltip from "@material-ui/core/Tooltip"; +/** Main function that return the component's 'footer' options, handling the required validation and deleting the field as necessary. */ function FieldFooterOptions(props) { - - return ( - <> - <FormControlLabel - control={ - <Switch - onChange={e => props.setRequiredField(props.idq) } - value="required" - color="primary" - checked={props.required} - /> - } - label="Obrigatória" - /> - <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> - <DeleteOutlinedIcon /> - </IconButton> - </> - ); - - + return ( + <Grid> + <FormControlLabel + control={ + <Tooltip + title="Marcar como obrigatório" + aria-label="Marcar como obrigatório" + > + <Switch + onChange={(e) => props.setRequiredField(props.idq)} + value="required" + color="primary" + checked={props.required} + /> + </Tooltip> + } + style={{ size: "0px" }} + label="Obrigatória" + /> + <Tooltip title="Remover a pergunta" aria-label="Remover a pergunta"> + <IconButton + aria-label="Remover a pergunta" + onClick={() => { + props.deleteFromForm(props.idq); + }} + > + <DeleteOutlinedIcon /> + </IconButton> + </Tooltip> + </Grid> + ); } - -export default FieldFooterOptions; \ No newline at end of file +export default FieldFooterOptions; diff --git a/src/components/fieldsCreateForm/FormFieldCheckbox.js b/src/components/fieldsCreateForm/FormFieldCheckbox.js index c4f88cd..fc8d1ba 100644 --- a/src/components/fieldsCreateForm/FormFieldCheckbox.js +++ b/src/components/fieldsCreateForm/FormFieldCheckbox.js @@ -1,98 +1,194 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import IconButton from "@material-ui/core/IconButton"; +import AddCircleIcon from "@material-ui/icons/AddCircle"; +import CloseIcon from "@material-ui/icons/Close"; +import CheckBoxOutlineBlankIcon from "@material-ui/icons/CheckBoxOutlineBlank"; +import Tooltip from "@material-ui/core/Tooltip"; +import FieldFooterOptions from "./FieldFooterOptions"; +import { Draggable } from "react-beautiful-dnd"; +import DefaultField from "./DefaultField"; - -import FieldFooterOptions from './FieldFooterOptions'; - - -const useStyles = makeStyles(theme => ({ +/** CSS styles used on page components. */ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) + ["@media (max-width:1050px)"]: { + width: theme.spacing(63), + ["@media (max-width:849px)"]: { + width: "100%", + }, + }, + marginBottom: "2%", + ["@media (min-width:600px)"]: { + marginLeft: "4%", + }, }, questionsGrid: { - marginBottom: '20px' + marginBottom: "20px", + }, + errorGrid: { + marginTop: "1%", + color: "#ff4646", + width: "40%", + fontSize: "13px", + }, + textFieldStyle: { + width: "80%", + }, + iconAdjustment: { + marginTop: "17px", }, })); - - - +/** Main function that returns the 'checkbox' field. */ function FormFieldCheckbox(props) { const classes = useStyles(); return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setQuestionField(e.target.value, props.idq)}/> - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} - > - { - props.options.map((x, index) => { - return <Grid container> - <Grid item container - justify="center" - alignItems="center" - xs={1} - > - <CheckBoxOutlineBlankIcon/> - </Grid> - <Grid item xs={10}> - <TextField label={"opção "+index} value={x} fullWidth - onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + <Draggable key={props.id} draggableId={props.id} index={props.idq}> + {(provided, snapshot) => { + return ( + <Paper + className={classes.paper} + ref={provided.innerRef} + {...provided.draggableProps} + {...provided.dragHandleProps} + > + <Grid container> + <DefaultField + question={props.question} + description={props.description} + idq={props.idq} + setQuestionField={props.setQuestionField} + setDescriptionField={props.setDescriptionField} + error={props.error} + /> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={12} + sm={8} + className={classes.questionsGrid} + > + {props.options.map((x, index) => { + return ( + <Grid container> + <Grid + item + container + justify="center" + alignItems="center" + xs={1} + className={ + props.error.errorMsg.options[index] + ? null + : classes.iconAdjustment + } + > + <CheckBoxOutlineBlankIcon /> </Grid> - <Grid item xs={1}> - <IconButton aria-label="remove option" - onClick={() => { props.removeSelectOption(props.idq, index) } }> - <CloseIcon /> - </IconButton> + <Grid item xs={8}> + <TextField + label={"Opção " + index} + value={x} + className={classes.textFieldStyle} + onChange={(e) => + props.setSelectOption( + e.target.value, + props.idq, + index + ) + } + /> + <Grid + item + className={classes.errorGrid} + style={{ width: "100%" }} + > + {props.error.errorMsg.options[index]} + </Grid> + </Grid> + <Grid item xs={2}> + <Tooltip + title="Remover a opção" + aria-label="Remover a opção" + > + <IconButton + aria-label="remove option" + onClick={() => { + props.removeSelectOption(props.idq, index); + }} + > + <CloseIcon /> + </IconButton> + </Tooltip> </Grid> </Grid> - }) - } - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" - xs={4} - > - <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> - <AddCircleIcon /> - </IconButton> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.required}/> - </Grid> - </Grid> - </Paper> + ); + })} + </Grid> + <Grid + item + className={classes.errorGrid} + container + direction="column" + justify="flex-start" + alignItems="flex-start" + sm={4} //antes era 3 + xs={12} + > + {props.error.errorMsg.optionsNumber} + </Grid> + <Grid + item + container + direction="column" + alignItems="center" + xs={6} + > + <Tooltip + title="Adicionar uma nova opção" + aria-label="Adicionar uma nova opção" + > + <IconButton + aria-label="add option" + onClick={() => { + props.addSelectOption(props.idq); + }} + > + <AddCircleIcon /> + </IconButton> + </Tooltip> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + sm={6} + xs={12} + > + <FieldFooterOptions + deleteFromForm={props.deleteFromForm} + idq={props.idq} + setRequiredField={props.setRequiredField} + required={props.validation[0].value} + /> + </Grid> + </Grid> + </Paper> + ); + }} + </Draggable> ); - } -export default FormFieldCheckbox; \ No newline at end of file +export default FormFieldCheckbox; diff --git a/src/components/fieldsCreateForm/FormFieldRadio.js b/src/components/fieldsCreateForm/FormFieldRadio.js index ce10709..9518569 100644 --- a/src/components/fieldsCreateForm/FormFieldRadio.js +++ b/src/components/fieldsCreateForm/FormFieldRadio.js @@ -1,97 +1,193 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import RadioButtonUncheckedIcon from '@material-ui/icons/RadioButtonUnchecked'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import IconButton from "@material-ui/core/IconButton"; +import AddCircleIcon from "@material-ui/icons/AddCircle"; +import CloseIcon from "@material-ui/icons/Close"; +import RadioButtonUncheckedIcon from "@material-ui/icons/RadioButtonUnchecked"; +import Tooltip from "@material-ui/core/Tooltip"; +import { Draggable } from "react-beautiful-dnd"; +import FieldFooterOptions from "./FieldFooterOptions"; +import DefaultField from "./DefaultField"; -import FieldFooterOptions from './FieldFooterOptions'; - - -const useStyles = makeStyles(theme => ({ +/** CSS styles used on page components. */ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) + ["@media (max-width:1050px)"]: { + width: theme.spacing(63), + ["@media (max-width:849px)"]: { + width: "100%", + }, + }, + marginBottom: "2%", + ["@media (min-width:600px)"]: { + marginLeft: "4%", + }, }, questionsGrid: { - marginBottom: '20px' + marginBottom: "20px", + }, + errorGrid: { + marginTop: "1%", + color: "#ff4646", + width: "40%", + fontSize: "13px", + }, + textFieldStyle: { + width: "80%", + }, + iconAdjustment: { + marginTop: "17px", }, })); - - - +/** Main function that returns the 'radio' field. */ function FormFieldRadio(props) { const classes = useStyles(); return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setQuestionField(e.target.value, props.idq)}/> - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} - > - { - props.options.map((x, index) => { - return <Grid container> - <Grid item container - justify="center" - alignItems="center" - xs={1} - > - <RadioButtonUncheckedIcon/> - </Grid> - <Grid item xs={10}> - <TextField label={"opção "+index} value={x} fullWidth - onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + <Draggable key={props.id} draggableId={props.id} index={props.idq}> + {(provided, snapshot) => { + return ( + <Paper + className={classes.paper} + ref={provided.innerRef} + {...provided.draggableProps} + {...provided.dragHandleProps} + > + <Grid container> + <DefaultField + question={props.question} + description={props.description} + idq={props.idq} + setQuestionField={props.setQuestionField} + setDescriptionField={props.setDescriptionField} + error={props.error} + /> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={12} + sm={8} + className={classes.questionsGrid} + > + {props.options.map((x, index) => { + return ( + <Grid container> + <Grid + item + container + justify="center" + alignItems="center" + xs={1} + className={ + props.error.errorMsg.options[index] + ? null + : classes.iconAdjustment + } + > + <RadioButtonUncheckedIcon /> </Grid> - <Grid item xs={1}> - <IconButton aria-label="remove option" - onClick={() => { props.removeSelectOption(props.idq, index) } }> - <CloseIcon /> - </IconButton> + <Grid item xs={8}> + <TextField + label={"Opção " + index} + value={x} + className={classes.textFieldStyle} + onChange={(e) => + props.setSelectOption( + e.target.value, + props.idq, + index + ) + } + /> + <Grid + item + className={classes.errorGrid} + style={{ width: "100%" }} + > + {props.error.errorMsg.options[index]} + </Grid> + </Grid> + <Grid item xs={2}> + <Tooltip + title="Remover a opção" + aria-label="Remover a opção" + > + <IconButton + onClick={() => { + props.removeSelectOption(props.idq, index); + }} + > + <CloseIcon /> + </IconButton> + </Tooltip> </Grid> </Grid> - }) - } - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" - xs={4} - > - <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> - <AddCircleIcon /> - </IconButton> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.required} /> - </Grid> - </Grid> - </Paper> + ); + })} + </Grid> + <Grid + item + className={classes.errorGrid} + container + direction="column" + justify="flex-start" + alignItems="flex-start" + sm={4} + xs={12} + > + {props.error.errorMsg.optionsNumber} + </Grid> + <Grid + item + container + direction="column" + alignItems="center" + xs={6} + > + <Tooltip + title="Adicionar uma nova opção" + aria-label="Adicionar uma nova opção" + > + <IconButton + aria-label="adicionar opção" + onClick={() => { + props.addSelectOption(props.idq); + }} + > + <AddCircleIcon /> + </IconButton> + </Tooltip> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={12} + sm={6} + > + <FieldFooterOptions + deleteFromForm={props.deleteFromForm} + idq={props.idq} + setRequiredField={props.setRequiredField} + required={props.validation[0].value} + /> + </Grid> + </Grid> + </Paper> + ); + }} + </Draggable> ); - } -export default FormFieldRadio; \ No newline at end of file +export default FormFieldRadio; diff --git a/src/components/fieldsCreateForm/FormFieldSelect.js b/src/components/fieldsCreateForm/FormFieldSelect.js index 3158b46..7555ef5 100644 --- a/src/components/fieldsCreateForm/FormFieldSelect.js +++ b/src/components/fieldsCreateForm/FormFieldSelect.js @@ -1,89 +1,179 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import IconButton from "@material-ui/core/IconButton"; +import AddCircleIcon from "@material-ui/icons/AddCircle"; +import CloseIcon from "@material-ui/icons/Close"; +import Tooltip from "@material-ui/core/Tooltip"; +import FieldFooterOptions from "./FieldFooterOptions"; +import { Draggable } from "react-beautiful-dnd"; +import DefaultField from "./DefaultField"; -import FieldFooterOptions from './FieldFooterOptions'; - - -const useStyles = makeStyles(theme => ({ +/** CSS styles used on page components. */ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) + ["@media (max-width:1050px)"]: { + width: theme.spacing(63), + ["@media (max-width:849px)"]: { + width: "100%", + }, + }, + marginBottom: "2%", + ["@media (min-width:600px)"]: { + marginLeft: "4%", + }, }, questionsGrid: { - marginBottom: '20px' + marginBottom: "20px", + }, + errorGrid: { + marginTop: "1%", + color: "#ff4646", + width: "40%", + fontSize: "13px", + }, + errorGridOpts: { + marginTop: "1%", + color: "#ff4646", + width: "100%", + fontSize: "13px", + }, + textFieldStyle: { + width: "80%", }, })); - - - +/** Main function that returns the 'select' field. */ function FormFieldSelect(props) { + /** Style class. */ const classes = useStyles(); - return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setQuestionField(e.target.value, props.idq)}/> - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} - > - { - props.options.map((x, index) => { - return <Grid container> - <Grid item xs={11}> - <TextField label={"opção "+index} value={x} fullWidth - onChange={e => props.setSelectOption(e.target.value, props.idq, index)} /> + <Draggable key={props.id} draggableId={props.id} index={props.idq}> + {(provided, snapshot) => { + return ( + <Paper + className={classes.paper} + ref={provided.innerRef} + {...provided.draggableProps} + {...provided.dragHandleProps} + > + <Grid container> + <DefaultField + question={props.question} + description={props.description} + idq={props.idq} + setQuestionField={props.setQuestionField} + setDescriptionField={props.setDescriptionField} + error={props.error} + /> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={12} + sm={8} + className={classes.questionsGrid} + > + {props.options.map((x, index) => { + return ( + <Grid container> + <Grid itemxs={1}></Grid> + <Grid item xs={10}> + <TextField + label={"Opção " + index} + value={x} + className={classes.textFieldStyle} + onChange={(e) => + props.setSelectOption( + e.target.value, + props.idq, + index + ) + } + /> + <Grid item className={classes.errorGridOpts}> + {props.error.errorMsg.options[index]} + </Grid> </Grid> <Grid item xs={1}> - <IconButton aria-label="remove option" - onClick={() => { props.removeSelectOption(props.idq, index) } }> - <CloseIcon /> - </IconButton> + <Tooltip + title="Remover a opção" + aria-label="Remover a opção" + > + <IconButton + aria-label="remove option" + onClick={() => { + props.removeSelectOption(props.idq, index); + }} + > + <CloseIcon /> + </IconButton> + </Tooltip> </Grid> </Grid> - }) - } - </Grid> - <Grid item container - direction="column" - justify="flex-start" - alignItems="flex-start" - xs={4} - > - <IconButton aria-label="add option" onClick={() => { props.addSelectOption(props.idq) } }> - <AddCircleIcon /> - </IconButton> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.required} /> - </Grid> - </Grid> - </Paper> + ); + })} + </Grid> + <Grid + item + className={classes.errorGrid} + container + direction="column" + justify="flex-start" + alignItems="flex-start" + sm={4} + xs={12} + > + {props.error.errorMsg.optionsNumber} + </Grid> + <Grid + item + container + direction="column" + alignItems="center" + xs={6} + > + <Tooltip + title="Adicionar uma nova opção" + aria-label="Adicionar uma nova opção" + > + <IconButton + aria-label="add option" + onClick={() => { + props.addSelectOption(props.idq); + }} + > + <AddCircleIcon /> + </IconButton> + </Tooltip> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + sm={6} + xs={12} + > + <FieldFooterOptions + deleteFromForm={props.deleteFromForm} + idq={props.idq} + setRequiredField={props.setRequiredField} + required={props.validation[0].value} + /> + </Grid> + </Grid> + </Paper> + ); + }} + </Draggable> ); - } -export default FormFieldSelect; \ No newline at end of file +export default FormFieldSelect; diff --git a/src/components/fieldsCreateForm/FormFieldSubform.js b/src/components/fieldsCreateForm/FormFieldSubform.js new file mode 100644 index 0000000..628b6b3 --- /dev/null +++ b/src/components/fieldsCreateForm/FormFieldSubform.js @@ -0,0 +1,219 @@ +import React, { useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import api from "../../api"; +import FieldFooterOptions from "./FieldFooterOptions"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import FormControl from "@material-ui/core/FormControl"; +import InputLabel from "@material-ui/core/InputLabel"; +import InfoIcon from "@material-ui/icons/Info"; +import { Draggable } from "react-beautiful-dnd"; +import Tooltip from "@material-ui/core/Tooltip"; +import DefaultField from "./DefaultField"; + +/** CSS styles used on page components. */ +const useStyles = makeStyles((theme) => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + ["@media (max-width:1050px)"]: { + width: theme.spacing(63), + ["@media (max-width:849px)"]: { + width: "100%", + }, + }, + marginBottom: "2%", + ["@media (min-width:600px)"]: { + marginLeft: "4%", + }, + }, + questionsGrid: { + marginBottom: "20px", + }, + subformSelect: { + width: "90%", + }, + errorGrid: { + marginTop: "1%", + color: "#ff4646", + width: "40%", + fontSize: "13px", + }, + errorGridSubform: { + color: "#ff4646", + marginTop: "2%", + width: "100%", + fontSize: "13px", + }, + textFieldStyle: { + width: "80%", + }, + textFieldDescriptionStyle: { + width: "96%", + ["@media (max-width: 600px)"]: { + width: "80%", + }, + }, + tooltipAdjustment: { + ["@media (max-width: 600px)"]: { + flexDirection: "column-reverse", + }, + }, + footerOptsAdjustment: { + ["@media (min-width: 600px)"]: { + marginBottom: "3%", + }, + }, +})); + +/** Function that returns the component to select te subform to be used. */ +function SubformSelect(props) { + /** State to store the form being used. */ + const [usedForm, setUsedForm] = React.useState({}); + /** Style class. */ + const classes = useStyles(); + /** State to manage errors. */ + const [error, setError] = React.useState(true); + /** Functions that handle the input changes to save it at the father component. */ + const handleChange = (event) => { + setUsedForm(props.array.filter((x) => x.id === event.target.value)); + props.setSubformId(event.target.value, props.idq); + setError(false); + }; + /** Initial error state setting. */ + useEffect(() => { + if ( + props.error.errorMsg.subformUsage || + props.error.errorMsg.subformSelected + ) + setError(true); + }, []); + + return ( + <FormControl variant="outlined" className={classes.subformSelect}> + <InputLabel + // style={{ fontSize: "5px" }} + className={classes.subformSelect} + id="demo-simple-select-outlined-label" + htmlFor="outlined-subform-simple" + > + Selecione um formulário + </InputLabel> + <Select + labelId="demo-simple-select-outlined-label" + id="demo-simple-select-outlined" + value={usedForm.title} + renderValue={usedForm.title} + onChange={handleChange} + label="Selecione um subformulário" + style={{ width: "100%" }} + error={error ? true : false} + > + {props.array.length > 0 ? ( + props.array.map((form) => ( + <MenuItem key={form.id} value={form.id}> + {form.title} + </MenuItem> + )) + ) : ( + <MenuItem key={0} value={0} disabled> + {"Você não tem formulários para usar aqui"} + </MenuItem> + )} + </Select> + </FormControl> + ); +} +/** Main function that returns the 'subform' field. */ +export default function FormFieldSubform(props) { + /** Style class. */ + const classes = useStyles(); + /** State to store the subform options the user can use. */ + const [forms, setForms] = React.useState([]); + /** UseEffect to make an api call and list the forms the current user has to be used as subform. */ + useEffect(() => { + const fetchData = async () => { + var forms_response = await api + .get(`/user/list/${window.sessionStorage.getItem("userId")}`, {}) + .then((response) => { + setForms(response.data); + }); + }; + fetchData(); + }, []); + return ( + <Draggable key={props.id} draggableId={props.id} index={props.idq}> + {(provided, snapshot) => { + return ( + <Paper + className={classes.paper} + ref={provided.innerRef} + {...provided.draggableProps} + {...provided.dragHandleProps} + > + <Grid container> + <Grid container item className={classes.tooltipAdjustment}> + <Grid container item xs={11}> + <DefaultField + question={props.question} + description={props.description} + idq={props.idq} + setQuestionField={props.setQuestionField} + setDescriptionField={props.setDescriptionField} + error={props.error} + /> + </Grid> + <Grid + container + item + xs={12} + sm={1} + className={classes.questionsGrid} + > + <Tooltip + // style={{ position: "absolute" }} + title="Por favor, reordene este campo antes de lhe atribuir valor" + aria-label="Por favor, reordene este campo antes de lhe atribuir valor" + > + <InfoIcon /> + </Tooltip> + </Grid> + </Grid> + <Grid item xs={12} sm={6} className={classes.questionsGrid}> + <SubformSelect + array={forms} + setSubformId={props.setSubformId} + idq={props.idq} + error={props.error} + /> + </Grid> + <Grid item sm={2} xs={12} className={classes.errorGridSubform}> + {props.error.errorMsg.subformUsage} + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={12} + sm={4} + className={classes.footerOptsAdjustment} + > + <FieldFooterOptions + deleteFromForm={props.deleteFromForm} + idq={props.idq} + setRequiredField={props.setRequiredField} + required={props.validation[0].value} + /> + </Grid> + </Grid> + </Paper> + ); + }} + </Draggable> + ); +} diff --git a/src/components/fieldsCreateForm/FormFieldText.js b/src/components/fieldsCreateForm/FormFieldText.js index 7b032df..6fc95fb 100644 --- a/src/components/fieldsCreateForm/FormFieldText.js +++ b/src/components/fieldsCreateForm/FormFieldText.js @@ -1,56 +1,210 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; +import React, { useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import IconButton from "@material-ui/core/IconButton"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import Tooltip from "@material-ui/core/Tooltip"; +import AddCircleIcon from "@material-ui/icons/AddCircle"; +import FormControl from "@material-ui/core/FormControl"; +import InputLabel from "@material-ui/core/InputLabel"; +import InfoIcon from "@material-ui/icons/Info"; +import { Draggable } from "react-beautiful-dnd"; +import FieldFooterOptions from "./FieldFooterOptions"; +import DefaultField from "./DefaultField"; -import FieldFooterOptions from './FieldFooterOptions'; - -const useStyles = makeStyles(theme => ({ +/** CSS styles used on page components. */ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - height: theme.spacing(16), - margin: theme.spacing(2) + ["@media (max-width:1050px)"]: { + width: theme.spacing(63), + ["@media (max-width:849px)"]: { + width: "100%", + }, + }, + marginBottom: "2%", + ["@media (min-width:600px)"]: { + marginLeft: "4%", + }, }, questionsGrid: { - marginBottom: '20px' + marginBottom: "20px", + }, + errorGrid: { + marginTop: "1%", + color: "#ff4646", + width: "40%", + fontSize: "13px", + }, + row: { + display: "flex", + flexDirection: "row", }, })); - +/** Main function that returns the content of the option 'question'. */ function FormFieldText(props) { + /** Style class. */ const classes = useStyles(); + /** Representation of the possible 'extra' validations to be used. */ + const validationOpts = [ + { type: "minChar", name: "MÃnimo de caracteres", value: "" }, + { type: "maxChar", name: "Máximo de caracteres", value: "" }, + ]; + /** State to store the validation being used. */ + const [usedValidation, setUsedValidation] = React.useState(); + /** State to manage error properties. */ + const [error, setError] = React.useState(true); + /** An specific handle change function that updates the type of the chosen validation. */ + const handleChangeType = (event) => { + setUsedValidation(validationOpts[event.target.value]); + setError(false); + }; + /** An specific handle change function that updates the value of the chosen validation. */ + const handleChangeValue = (event) => { + setUsedValidation({ + type: usedValidation.type, + name: usedValidation.name, + value: event.target.value, + }); + }; + /** useEffect being used as a handle change function to send data (the chosen type of validation and the value) to the father component. */ + useEffect(() => { + if (usedValidation) { + props.setValidation(usedValidation, props.idq); + } + }, [usedValidation]); return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="sua pergunta" - onChange={e => props.setQuestionField(e.target.value, props.idq)}/> - </Grid> - <Grid item xs={9} className={classes.questionsGrid}> - <TextField - disabled - id="outlined-disabled" - label="" - defaultValue="Resposta curta" - /> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > - <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.required} /> - </Grid> - </Grid> - </Paper> + <Draggable key={props.id} draggableId={props.id} index={props.idq}> + {(provided, snapshot) => { + return ( + <Paper + className={classes.paper} + ref={provided.innerRef} + {...provided.draggableProps} + {...provided.dragHandleProps} + > + <Grid container> + <DefaultField + question={props.question} + description={props.description} + idq={props.idq} + setQuestionField={props.setQuestionField} + setDescriptionField={props.setDescriptionField} + error={props.error} + /> + <Grid item xs={12} sm={8} className={classes.questionsGrid}> + <TextField + disabled + id="outlined-disabled" + label="" + defaultValue="Resposta curta" + /> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={12} + sm={4} + className={classes.row} + > + <FieldFooterOptions + deleteFromForm={props.deleteFromForm} + idq={props.idq} + setRequiredField={props.setRequiredField} + required={props.validation[0].value} + /> + </Grid> + </Grid> + {props.validation.length > 1 ? ( + <FormControl variant="outlined" className={classes.row}> + <Grid item xs={12} sm={5} className={classes.questionsGrid}> + <InputLabel + className={classes.subformSelect} + id="demo-simple-select-outlined-label" + htmlFor="outlined-subform-simple" + > + Selecione uma validação + </InputLabel> + <Select + labelId="demo-simple-select-outlined-label" + id="demo-simple-select-outlined" + onChange={handleChangeType} + label="Selecione uma validação" + style={{ minWidth: "250px" }} + error={error ? true : false} + > + {validationOpts.map((x, index) => ( + <MenuItem key={index} value={index}> + {x.name} + </MenuItem> + ))} + </Select> + </Grid> + <Grid + container + item + xs={12} + sm={1} + className={classes.questionsGrid} + > + <Tooltip + // style={{ position: "absolute" }} + title="Por favor, reordene este campo antes de lhe atribuir valor" + aria-label="Por favor, reordene este campo antes de lhe atribuir valor" + > + <InfoIcon /> + </Tooltip> + </Grid> + {usedValidation ? ( + <Grid item xs={12} sm={4} className={classes.questionsGrid}> + <TextField + style={{ width: "45%" }} + label="Quantidade" + value={usedValidation.value} + onChange={handleChangeValue} + /> + <Grid className={classes.errorGrid}> + {props.error.errorMsg.validation.value} + </Grid> + </Grid> + ) : null} + </FormControl> + ) : ( + <Grid + item + container + direction="column" + alignItems="center" + xs={6} + > + <Tooltip + title="Adicionar uma validação para a resposta" + aria-label="Adicionar uma validação para a resposta" + > + <IconButton + aria-label="adicionar opção" + onClick={() => { + props.addValidation(props.idq); + }} + > + <AddCircleIcon /> + </IconButton> + </Tooltip> + </Grid> + )} + </Paper> + ); + }} + </Draggable> ); - } -export default FormFieldText; \ No newline at end of file +export default FormFieldText; diff --git a/src/components/fieldsCreateForm/FormFieldTitle.js b/src/components/fieldsCreateForm/FormFieldTitle.js index 0197652..2042a9c 100644 --- a/src/components/fieldsCreateForm/FormFieldTitle.js +++ b/src/components/fieldsCreateForm/FormFieldTitle.js @@ -1,66 +1,84 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; -import FieldFooterOptions from './FieldFooterOptions'; - -const useStyles = makeStyles(theme => ({ +/** CSS styles used on page components. */ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - height: theme.spacing(16), - margin: theme.spacing(2) + ["@media (max-width:1050px)"]: { + width: theme.spacing(63), + ["@media (max-width:849px)"]: { + width: "100%", + }, + }, + marginBottom: "2%", + ["@media (min-width:600px)"]: { + marginLeft: "4%", + }, }, questionsGrid: { - marginBottom: '20px' - }, - title: { - fontSize: 'xx-large' - }, - description: { - fontSize: 'x-large' - }, + marginBottom: "20px", + }, + title: { + fontSize: "xx-large", + }, + description: { + fontSize: "x-large", + }, + errorGrid: { + marginTop: "1%", + color: "#ff4646", + width: "40%", + fontSize: "13px", + }, })); - +/** Main function that returns the 'title' field. */ function FormFieldText(props) { + /** Style class. */ const classes = useStyles(); return ( <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <TextField value={props.question} label="Formulário sem tÃtulo" fullWidth - onChange={e => props.setTitleField(e.target.value, props.idq)} - InputProps={{ - classes: { - input: classes.title, - }, - }}/> - </Grid> - <Grid item xs={9} className={classes.questionsGrid}> - <TextField value={props.question} label="Descrição do formulário" - onChange={e => props.setDescriptionField(e.target.value, props.idq)} - InputProps={{ - classes: { - input: classes.description, - }, - }}/> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > + <TextField + value={props.question} + label="TÃtulo do formulário" + fullWidth + onChange={(e) => props.setTitleField(e.target.value, props.idq)} + InputProps={{ + classes: { + input: classes.title, + }, + }} + /> + <Grid className={classes.errorGrid}>{props.error.errorMsg.question}</Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <TextField + label="Descrição do formulário" + onChange={(e) => props.setDescriptionField(e.target.value, props.idq)} + InputProps={{ + classes: { + input: classes.description, + }, + }} + /> + <Grid className={classes.errorGrid}> + {props.error.errorMsg.description} </Grid> </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + ></Grid> </Paper> ); - } -export default FormFieldText; \ No newline at end of file +export default FormFieldText; diff --git a/src/components/fieldsCreateForm/SideMenu.js b/src/components/fieldsCreateForm/SideMenu.js new file mode 100644 index 0000000..fb51492 --- /dev/null +++ b/src/components/fieldsCreateForm/SideMenu.js @@ -0,0 +1,128 @@ +import React, { useState } from "react"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import AddIcon from "@material-ui/icons/Add"; +import IconButton from "@material-ui/core/IconButton"; +import ReorderIcon from "@material-ui/icons/Reorder"; +import RadioButtonCheckedIcon from "@material-ui/icons/RadioButtonChecked"; +import CheckBoxOutlineBlankIcon from "@material-ui/icons/CheckBoxOutlineBlank"; +import Grid from "@material-ui/core/Grid"; +import { makeStyles } from "@material-ui/core"; +import ListAltIcon from "@material-ui/icons/ListAlt"; +import TextFieldsIcon from "@material-ui/icons/TextFields"; + +const useStyles = makeStyles((theme) => ({ + addButton: { + fontSize: "100%", + }, + outerGrid: { + // alignItems: "flex-start", + + flexDirection: "column", + ["@media(max-width: 600px)"]: { + flexDirection: "row", + justifyContent: "space-between", + }, + ["@media(max-width: 1050px)"]: { + fontSize: "0", + }, + }, + paper: { + ["@media (min-width: 600px)"]: { + position: "fixed", + }, + ["@media (min-width:600px)"]: { + maxWidth: "190px", + }, + ["@media(max-width: 1050px)"]: { + ["@media(min-width: 600px)"]: { + width: "85px", + }, + }, + justifyContent: "flex-start", + // minWidth: "160.167px", + }, + newQuestionGrid: { + marginTop: "5%", + }, + test: { + display: "flex", + flexDirection: "row", + maxWidth: "190px", + // minWidth: "160.167px", + height: "268.5", + }, + flex: {}, + newQuestionGrid: { + ["@media(max-width: 1050px)"]: { + display: "none", + }, + }, +})); +// fazer com que desca comforme a rolagem da página +function SideMenu(props) { + const classes = useStyles(); + return ( + <Paper className={classes.paper}> + <Grid item container justify="flex-start" className={classes.outerGrid}> + <Grid className={classes.newQuestionGrid} container justify="center"> + <h4>Adicionar pergunta:</h4> + </Grid> + {/* <Grid> */} + <IconButton + aria-label="add select" + type="submit" + size="medium" + className={classes.addButton} + onClick={props.addToFormQuestion} + > + <TextFieldsIcon /> + Caixa de texto + </IconButton> + <IconButton + aria-label="add select" + type="submit" + size="medium" + className={classes.addButton} + onClick={props.addToFormSelect} + > + <ReorderIcon /> + Lista Suspensa + </IconButton> + <IconButton + aria-label="add radio" + type="submit" + size="medium" + className={classes.addButton} + onClick={props.addToFormRadio} + > + <RadioButtonCheckedIcon /> + Múltipla escolha + </IconButton> + <IconButton + aria-label="add checkbox" + type="submit" + size="medium" + className={classes.addButton} + onClick={props.addToFormCheckbox} + > + <CheckBoxOutlineBlankIcon /> + Seleção Única + </IconButton> + <IconButton + aria-label="add subform" + type="submit" + size="medium" + className={classes.addButton} + onClick={props.addToFormSubForm} + > + <ListAltIcon /> + Subformulário + </IconButton> + </Grid> + {/* </Grid> */} + </Paper> + ); +} + +export default SideMenu; diff --git a/src/components/fieldsCreateForm/utils/BackendTranslation.js b/src/components/fieldsCreateForm/utils/BackendTranslation.js new file mode 100644 index 0000000..6acb5c1 --- /dev/null +++ b/src/components/fieldsCreateForm/utils/BackendTranslation.js @@ -0,0 +1,106 @@ +/** Functions that create the json object to be sent to the backend. */ + +/** Function that pushes the 'translated' object into the new array, wich will be sent to the backend. */ +function setInput(form, index, json, sugestions, validation, subForm, type) { + //the case when the input has a subform -> backend requires it to be different + if (subForm) { + json.inputs.push({ + placement: index, + description: form.description, + question: form.question, + type: type, + validation: validation, + sugestions: sugestions, + subForm: subForm, + }); + } else { + json.inputs.push({ + placement: index, + description: form.description, + question: form.question, + type: type, + validation: validation, + sugestions: sugestions, + }); + } +} + +/** Returns the type of the question as the backend padronization. */ +function getType(stringified_type) { + switch (stringified_type) { + case "question": + return 0; + case "select": + return 3; + case "radio": + return 2; + case "checkbox": + return 1; + case "subForm": + return 4; + default: + return -1; + } +} +/** Translates the 'options' array to the backend padronization. */ +function setSugestions(sugestions) { + let tmp = []; + if (!sugestions) return tmp; + sugestions.forEach((value, index) => { + tmp.push({ + value: value, + placement: index, + }); + }); + return tmp; +} + +/** Sets the validation field to be sent to the backend. */ +function setValidation(form) { + if (!form.validation[0].value) return []; + let val = []; + if (form.type === "checkbox") + val.push({ + type: 6, + arguments: [], + }); + else if (form.type === "question" && form.validation.length > 1) { + if (form.validation[1].type === "maxChar") { + val.push({ type: 3, arguments: [form.validation[1].value] }); + } else { + val.push({ type: 4, arguments: [form.validation[1].value] }); + } + } else + val.push({ + type: 2, + arguments: [], + }); + return val; +} +/** Set the subform as the backend padronization. */ +function setSubform(form, idq) { + if (form.type !== "subForm") return null; + return { + contentFormId: form.subformId, + }; +} +/** The function that triggers the 'translation' */ +export default function createForm(form) { + let json = { + title: form[0].title, + description: form[0].description, + inputs: [], + }; + for (var i = 1; i < form.length; i++) { + setInput( + form[i], + i, + json, + setSugestions(form[i].options), + setValidation(form[i]), + setSubform(form[i], i), + getType(form[i].type) + ); + } + return json; +} diff --git a/src/components/fieldsCreateForm/utils/schemas.js b/src/components/fieldsCreateForm/utils/schemas.js new file mode 100644 index 0000000..3255a31 --- /dev/null +++ b/src/components/fieldsCreateForm/utils/schemas.js @@ -0,0 +1,158 @@ +import * as Yup from "yup"; +/** The validation through Yup is schema based, so there are schemas and it's validations. */ + +/** Schema to validate the question field from every form array object. */ +const questionTextSchema = Yup.string() + .required("Este campo é obrigatório!") + .test("alphabets", "O caractere não é permitido", (value) => { + return /^[A-Za-z!?$%,. 1234567890à èìòùáéÃóúâêîôûãõç]+$/.test(value); + }); +/** Function that applies the validation of it's used schema and sets the error messages. */ +export async function testQuestionTextSchema(form, value, index) { + await questionTextSchema + .validate(value) + .then((x) => { + form[index].error.errorMsg.question = ""; + }) + .catch((err) => { + form[index].error.errorMsg.question = err.message; + }); +} +/** Schema to validate the description field from every form array object. */ +const descriptionTextSchema = Yup.string().test( + "alphabets", + "O caractere não é permitido", + (value) => { + if (!value) return true; + return /^[A-Za-z!?$%,. 1234567890à èìòùáéÃóúâêîôûãõ\b- ]+$/.test(value); + } +); +/** Function that applies the validation of it's used schema and sets the error messages. */ +export async function testDescriptionTextSchema(form, value, index) { + await descriptionTextSchema + .validate(value) + .then((x) => { + form[index].error.errorMsg.description = ""; + }) + .catch((err) => { + form[index].error.errorMsg.description = err.message; + }); +} +/** Schema to validate the number of options at options field from FormFieldSelect, FormFieldCheckbox and FormFieldRadio. */ +const selectOptionsSchema = Yup.array() + .of(Yup.string()) + .test("minimo 2", "O campo precisa ter pelo menos duas opções!", (value) => { + if (value.length < 2) return false; + else return true; + }); +/** Function that applies the validation of it's used schema and sets the error messages. */ +export async function selectOptionsTesting(form, index) { + await selectOptionsSchema + .validate(form[index].options) + .then((x) => { + form[index].error.errorMsg.optionsNumber = ""; + }) + .catch((err) => { + form[index].error.errorMsg.optionsNumber = err.message; + }); +} +/** Schema to validate the subform field from FormFieldSubform. */ +const subformSchema = Yup.array().test( + "repetition", + "Este formulário já está sendo usado!", + (form) => { + for (let i = 1; i < form.length; i++) { + if (form[i].type === "subForm") { + for (let j = i + 1; j < form.length; j++) { + if ( + form[j].type === "subForm" && + form[j].subformId === form[i].subformId + ) { + return false; + } + } + } + } + return true; + } +); +/** Function that applies the validation of it's used schema and sets the error messages. */ +export async function testSubformSchema(form, index) { + await subformSchema + .validate(form) + .then((x) => { + form[index].error.errorMsg.subformUsage = ""; + form[index].error.errorMsg.subformSelected = false; + }) + .catch((err) => { + form[index].error.errorMsg.subformUsage = err.message; + }); +} +/** Schema to validate the content of the options field from FormFieldSelect, FormFieldCheckbox and FormFieldRadio. */ +const optSchema = Yup.string() + .required("Por favor, preencha esta opção") + .test("alphabets", "O caractere não é permitido", (value) => { + if (!value) return true; + return /^[A-Za-z!?$%,. à èìòùáéÃóúâêîôûãõ\b- ]+$/.test(value); + }); +/** Function that applies the validation of it's used schema and sets the error messages. */ +export async function selectOptionTextTesting(form, value, index, idopt) { + await optSchema + .validate(value) + .then((x) => { + form[index].error.errorMsg.options[idopt] = ""; + }) + .catch((err) => { + form[index].error.errorMsg.options[idopt] = err.message; + }); +} +/** Schema to validate the quantity field of the validation from FormFieldText. */ +const textValidationSchema = Yup.string() + .required("Por favor, digite um número") + .test("numeric", "Digite um número válido", (value) => { + return /^\d+$/.test(value); + }); +/** Function that applies the validation of it's used schema and sets the error messages. */ +export async function testTextValidation(form, index, value) { + await textValidationSchema + .validate(value) + .then((x) => { + form[index].error.errorMsg.validation.value = ""; + }) + .catch( + (err) => (form[index].error.errorMsg.validation.value = err.message) + ); +} +/** Functions that verify if the form array can be sent to the backend. */ +export function verifyError(form) { + if (form.length === 1) return false; + let valid = true; + form.map(function (x) { + if (x.error.errorMsg.question || x.error.errorMsg.description) { + valid = false; + return; + } + if (x.type === "question") { + if (x.error.errorMsg.validation.value) { + valid = false; + return; + } + } + if (x.type === "subForm") { + if (x.error.errorMsg.subformUsage || x.error.errorMsg.subformSelected) { + valid = false; + return; + } + } + if (x.type === "checkbox" || x.type === "radio" || x.type === "select") { + if (x.error.errorMsg.optionsNumber) valid = false; + x.error.errorMsg.options.forEach((y) => { + if (y) { + valid = false; + } + }); + return; + } + }); + return valid; +} diff --git a/src/components/footer/footer.js b/src/components/footer/footer.js index 3e2ee4e..5e01cd8 100644 --- a/src/components/footer/footer.js +++ b/src/components/footer/footer.js @@ -4,15 +4,15 @@ import Grid from "@material-ui/core/Grid"; import Typography from "@material-ui/core/Typography"; import Logo from "./c3sl.png"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ footer: { background: "#66a6c2", - position: "fixed", + position: "relative", left: 0, bottom: 0, right: 0, width: "100%", - height: "78px" + height: "78px", }, img: { @@ -23,15 +23,15 @@ const useStyles = makeStyles(theme => ({ marginLeft: "auto", marginRight: "auto", ["@media (min-width: 960px)"]: { - marginLeft: "5px", - } + marginLeft: "5px", + }, }, item: { display: "flex", justifyContent: "space-evenly", flexDirection: "column", - alignItems: "center" + alignItems: "center", }, text: { @@ -40,8 +40,8 @@ const useStyles = makeStyles(theme => ({ textAlign: "center", left: "50%", ["@media (max-width: 960px)"]: { - display: "none" - } + display: "none", + }, }, adress: { @@ -55,9 +55,9 @@ const useStyles = makeStyles(theme => ({ fontSize: "12px", textAlign: "right", ["@media (max-width: 960px)"]: { - display: "none" - } - } + display: "none", + }, + }, })); function Footer() { @@ -89,8 +89,6 @@ function Footer() { Telefone: 61 2027-6000 </Typography> </Grid> - - </Grid> ); } diff --git a/src/components/global.css b/src/components/global.css deleted file mode 100644 index deeb81c..0000000 --- a/src/components/global.css +++ /dev/null @@ -1,26 +0,0 @@ -@import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap"); - -* { - margin: 0; - padding: 0; - outline: 0; - box-sizing: border-box; - background: "#05a5dd"; -} - -html, -body, -#root { - height: 100%; -} - -body { - background: #eceff3; - -webkit-font-smoothing: antialiased; -} - -body, -input, -button { - font-family: Roboto, sans-serif; -} diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 4f5369c..4846204 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -4,14 +4,14 @@ import logo from "./header_imgs/imgsimmc-01.png"; import { makeStyles } from "@material-ui/core"; import MenuListComposition from "./header_components/MenuList"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ header: { background: "#05a5dd", width: "auto", display: "flex", flexDirection: "column", justifyContent: "center", - height: "13%" + height: "13%", }, simmc: { marginTop: "5%", @@ -19,11 +19,11 @@ const useStyles = makeStyles(theme => ({ color: "#ffffff", marginLeft: "2%", ["@media (max-width:1040px)"]: { - display: "none" + display: "none", }, - ["@media (max-height:681px)"]: { - display: "none" - } + // ["@media (max-height:681px)"]: { + // display: "none" + // } }, form_creator: { color: "#ffffff", @@ -32,37 +32,31 @@ const useStyles = makeStyles(theme => ({ fontSize: "21px", ["@media (max-width:525px)"]: { marginTop: "5%", - marginLeft: "10%" + marginLeft: "10%", }, ["@media (max-width:337px)"]: { - fontSize: "19px" - } + fontSize: "19px", + }, }, - ["@media (max-height:681px)"]: { - marginTop: "5%" - } }, link: { - textDecoration: "none" + textDecoration: "none", }, logo: { marginLeft: "2.5%", marginTop: "4%", width: "85px", - ["@media (max-width:525px)"]: { + ["@media (max-width:600px)"]: { width: "65px", ["@media (max-width:338px)"]: { - marginTop: "3%" - } + marginTop: "3%", + }, }, - ["@media (max-height:681px)"]: { - width: "65px" - } }, userImgContainer: { display: "flex", - flexDirection: "column" - } + flexDirection: "column", + }, })); export default function Header() { diff --git a/src/components/header/header_components/MenuList.jsx b/src/components/header/header_components/MenuList.jsx index 4134513..e4491ce 100644 --- a/src/components/header/header_components/MenuList.jsx +++ b/src/components/header/header_components/MenuList.jsx @@ -11,28 +11,28 @@ import UserImg from "./../header_imgs/user.png"; import { Avatar } from "@material-ui/core"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ menuPopUp: { alignContent: "start", ["@media (max-width:346px)"]: { - width: "23%" - } + width: "23%", + }, }, menuPopUpText: { ["@media (max-width:525px)"]: { - fontSize: "13px" - } + fontSize: "13px", + }, }, popUpPaper: { marginRight: "14%", ["@media (max-width:525px)"]: { - marginRight: "0" - } + marginRight: "0", + }, }, menuList: { alignItems: "flex-start", - color: "grey" - } + color: "grey", + }, })); /** @@ -47,9 +47,9 @@ function MenuListComposition(props) { const anchorRef = React.useRef(null); const handleToggle = () => { - setOpen(prevOpen => !prevOpen); + setOpen((prevOpen) => !prevOpen); }; - const handleClose = event => { + const handleClose = (event) => { if (anchorRef.current && anchorRef.current.contains(event.target)) { return; } @@ -95,7 +95,7 @@ function MenuListComposition(props) { {...TransitionProps} style={{ transformOrigin: - placement === "bottom" ? "center top" : "center bottom" + placement === "bottom" ? "center top" : "center bottom", }} > <Paper className={classes.popUpPaper}> diff --git a/src/global.css b/src/global.css index 9583b1d..879e608 100644 --- a/src/global.css +++ b/src/global.css @@ -1,15 +1,12 @@ @import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap"); -*{ +* { margin: 0; padding: 0; outline: 0; box-sizing: border-box; color: #667079; } -* :not(.Button){ - color: white; -} html, body, diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index edcb312..f123fd5 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -47,7 +47,7 @@ function AnwserForm() { setFormData(res.data); }); } - + function answerForm() { axios.post(`${config.genformsapi.url}/form`) .then(res => { @@ -70,7 +70,7 @@ function AnwserForm() { > { - formData ? + formData ? <div> <FormFieldTitle title={formData.title} description={formData.description}/> { diff --git a/src/pages/CreateForm.js b/src/pages/CreateForm.js index 677e396..b75453f 100644 --- a/src/pages/CreateForm.js +++ b/src/pages/CreateForm.js @@ -1,241 +1,490 @@ -import React, { useState } from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import AddIcon from '@material-ui/icons/Add'; -import IconButton from '@material-ui/core/IconButton'; -import ReorderIcon from '@material-ui/icons/Reorder'; -import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; -import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; -import Button from '@material-ui/core/Button'; -import axios from 'axios'; +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Button from "@material-ui/core/Button"; +import { DragDropContext, Droppable } from "react-beautiful-dnd"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import FormFieldText from "../components/fieldsCreateForm/FormFieldText"; +import FormFieldSelect from "../components/fieldsCreateForm/FormFieldSelect"; +import FormFieldRadio from "../components/fieldsCreateForm/FormFieldRadio"; +import FormFieldCheckbox from "../components/fieldsCreateForm/FormFieldCheckbox"; +import FormFieldTitle from "../components/fieldsCreateForm/FormFieldTitle"; +import FormFieldSubForm from "../components/fieldsCreateForm/FormFieldSubform"; +import uuid from "uuid/v4"; +import { + testQuestionTextSchema, + testDescriptionTextSchema, + selectOptionsTesting, + testSubformSchema, + selectOptionTextTesting, + testTextValidation, + verifyError, +} from "../components/fieldsCreateForm/utils/schemas"; +import createForm from "../components/fieldsCreateForm/utils/BackendTranslation"; +import SideMenu from "../components/fieldsCreateForm/SideMenu"; +import api from "../api"; -import FormFieldText from '../components/fieldsCreateForm/FormFieldText'; -import FormFieldSelect from '../components/fieldsCreateForm/FormFieldSelect'; -import FormFieldRadio from '../components/fieldsCreateForm/FormFieldRadio'; -import FormFieldCheckbox from '../components/fieldsCreateForm/FormFieldCheckbox'; -import FormFieldTitle from '../components/fieldsCreateForm/FormFieldTitle'; +import Tooltip from "@material-ui/core/Tooltip"; -import config from '../config'; - - -const useStyles = makeStyles(theme => ({ - menu: { - width: theme.spacing(6), - minheight: theme.spacing(15), - position: 'fixed', - top: theme.spacing(10), - left: '90%', - padding: theme.spacing(1) +/** CSS styles used on page components */ +const useStyles = makeStyles((theme) => ({ + app: { + margin: "0", + padding: "40px", + display: "flex", + ["@media (max-width: 600px)"]: { + flexDirection: "column-reverse", + justifyContent: "flex-end", + }, + paddingBottom: "78px", + ["@media (min-width: 600px)"]: { + minHeight: "calc(100vh - 92.4px - 78px)", + }, + minHeight: "calc(100vh - 71.6px - 78px)", + }, + addButton: { + fontSize: "100%", + }, + buttonOk: { + backgroundColor: "#6ec46c", + "&:hover": { + backgroundColor: "rgb(25, 109, 23)", + }, + width: "20%", + ["@media (max-width:600px)"]: { + marginTop: "52px", + }, + }, + button: { + ["@media (max-width:600px)"]: { + marginTop: "52px", + }, + }, + questionsGrid: { + // da pra mexer no deslocamento do titulo por aqui; + ["@media (max-width:600px)"]: { + // marginBottom: "100%", + // padding: 0, + }, + }, + sideMenuFormatingGrid: { + ["@media (max-width:600px)"]: { + marginTop: "-90px", + }, }, })); - +/** CSS style used through Material Ui. */ +const theme = createMuiTheme({ + overrides: { + MuiInput: { + underline: { + "&:before": { + borderBottom: "1px solid #35c7fc", + }, + "&:after": { + borderBottom: "1px solid #3f51b5", + }, + }, + }, + MuiButton: { + label: { + color: "white", + }, + }, + }, +}); +/** Main function that returns the children that composes the form creation page. */ function CreateForm() { + /** Style class. */ const classes = useStyles(); + /** An unique string to be used as ID for drag and drop function. */ + const columnId = uuid(); + /** Error state. */ + const [validToSend, setValidToSend] = useState(); - const [form, setForm] = useState([{type: "title", title: "", description: ""}]); - + /** Form state being started with the title, it's an array where each position stands for a question selected by the user. */ + const [form, setForm] = useState([ + { + type: "title", + title: "", + description: "", + error: { + errorMsg: { question: "Este campo é obrigatório!", description: "" }, + }, + }, + ]); + /** Function used on 'sidemenu' that adds to the form array the object of a question. */ function addToFormQuestion() { - setForm([...form, {type: "question", required: false, question: ""}]); - console.log(form); + setForm([ + ...form, + { + type: "question", + validation: [{ type: "required", value: false }], + question: "", + description: "", + id: uuid(), + error: { + errorMsg: { + question: "Este campo é obrigatório!", + description: "", + validation: { + value: "", + }, + }, + }, + }, + ]); } - + /** Function used on 'sidemenu' that adds to the form array the object of a select question. */ function addToFormSelect() { - setForm([...form, {type: "select", question: "", required: false, options: [""]}]); - console.log(form); + setForm([ + ...form, + { + type: "select", + question: "", + validation: [{ type: "required", value: false }], + options: [""], + description: "", + id: uuid(), + error: { + errorMsg: { + question: "Este campo é obrigatório!", + description: "", + optionsNumber: "O campo precisa ter pelo menos duas opções!", + options: ["Por favor, preencha esta opção"], + }, + }, + }, + ]); } - + /** Function used on 'sidemenu' that adds to the form array the object of a radio question. */ function addToFormRadio() { - setForm([...form, {type: "radio", question: "", required: false, options: [""]}]); - console.log(form); + setForm([ + ...form, + { + type: "radio", + question: "", + validation: [{ type: "required", value: false }], + options: [""], + description: "", + id: uuid(), + error: { + errorMsg: { + question: "Este campo é obrigatório!", + description: "", + optionsNumber: "O campo precisa ter pelo menos duas opções!", + options: ["Por favor, preencha esta opção"], + }, + }, + }, + ]); } - + /** Function used on 'sidemenu' that adds to the form array the object of a checkbox question. */ function addToFormCheckbox() { - setForm([...form, {type: "checkbox", question: "", required: false, options: [""]}]); - console.log(form); + setForm([ + ...form, + { + type: "checkbox", + question: "", + validation: [{ type: "required", value: false }], + options: [""], + description: "", + id: uuid(), + error: { + errorMsg: { + question: "Este campo é obrigatório!", + description: "", + optionsNumber: "O campo precisa ter pelo menos duas opções!", + options: ["Por favor, preencha esta opção"], + }, + }, + }, + ]); } - - function addSelectOption(index) { + /** Function used on 'sidemenu' that adds to the form array the object of a subform question. */ + function addToFormSubForm() { + setForm([ + ...form, + { + type: "subForm", + validation: [{ type: "required", value: false }], + description: "", + question: "", + subformId: "", + id: uuid(), + error: { + errorMsg: { + question: "Este campo é obrigatório!", + description: "", + subformUsage: "", + subformSelected: true, + }, + }, + }, + ]); + } + /** Function used on FormFieldRadio, FormFieldCheckbox and FormFieldSelect, it adds a new option field for those questions. */ + async function addSelectOption(index) { form[index].options.push(""); + form[index].error.errorMsg.options.push("Por favor, preencha esta opção"); + await selectOptionsTesting(form, index); setForm([...form]); - console.log(form); } - + /** Function used on FormFieldRadio, FormFieldCheckbox and FormFieldSelect, it removes an option field for those questions. */ + async function removeSelectOption(index, idopt) { + form[index].options.splice(idopt, 1); + form[index].error.errorMsg.options.splice(idopt, 1); + await selectOptionsTesting(form, index); + setForm([...form]); + } + /** Function used on every FormField, it deletes the question from the array. */ function deleteFromForm(index) { - console.log(index); - form.splice(index, 1) - console.log(form); + form.splice(index, 1); setForm([...form]); } - - function removeSelectOption(index, idopt) { - form[index].options.splice(idopt, 1); + /** Function used on FormFieldQuestion, it handles the validation the user chooses. + * Currently, only handle max and min number of characters. + */ + function addValidation(index) { + form[index].validation.push({ type: "", value: "" }); + form[index].error.errorMsg.validation.value = "Por favor, digite um número"; setForm([...form]); - console.log(form); } - - function setQuestionField(value, index) { + /** Function used on every FormField, it updates the value of the question property on the form array. */ + async function setQuestionField(value, index) { form[index].question = value; + await testQuestionTextSchema(form, value, index); + setForm([...form]); + } + /** Function used on every FormField, it updates the value of the description property on the array. */ + async function setDescriptionField(value, index) { + form[index].description = value; + await testDescriptionTextSchema(form, value, index); setForm([...form]); - console.log(form); } - - function setSelectOption(value, index, idopt) { + /** Function used on every FormField, it updates the value of the oprion property of the object on the array. */ + async function setSelectOption(value, index, idopt) { form[index].options[idopt] = value; + await selectOptionTextTesting(form, value, index, idopt); setForm([...form]); - console.log(form); } - + /** Function used on every FormField, it updates the value of the required property of a question. */ function setRequiredField(index) { - form[index].required = !form[index].required; + form[index].validation[0].value = !form[index].validation[0].value; setForm([...form]); - console.log(form); } - - function setTitleField(value, index) { - form[index].title = value; + /** Function to update the title, used on FormFieldTitle. */ + async function setTitleField(value) { + await testQuestionTextSchema(form, value, 0); + form[0].title = value; setForm([...form]); - console.log(form); } - - function setDescriptionField(value, index) { - form[index].description = value; + /** Function to store the selected subform Id on it's corresponding object. */ + async function setSubformId(value, index) { + form[index].subformId = value; + await testSubformSchema(form, index); setForm([...form]); - console.log(form); } - - function createForm() { - let json = { - title: form[0].title, - description: form[0].description, - inputs: [] - } - - form.forEach(function(x, index){ - if(x.type === "question") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 0, // question type = 0 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [] - }); - } else if(x.type === "select") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 3, // select type = 3 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [], - "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) - }); - } else if(x.type === "checkbox") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 1, // checkbox type = 1 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [], - "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) - }); - } else if(x.type === "radio") { - json.inputs.push({ - "placement": index-1, - "description": "Adicionar esse campo no front", - "question": x.question, - "enabled": true, - "type": 2, // radio type = 2 - "validation": x.required ? [{"type": 2, "arguments": ""}] : [], - "sugestions": x.options.map(function(y, index) { return {value: y, placement: index} }) - }); - } - }); - - - console.log(json); - axios.post(`${config.genformsapi.url}/form`, json ) - .then(res => { - console.log(res); - console.log(res.data); - - window.location.reload(); + /** Function used on FormFieldText to set the chosen validation, currently min and max char. */ + async function setValidation(value, index) { + form[index].validation[1] = value; + await testTextValidation(form, index, value.value); + setForm([...form]); + } + /** The submit function. It's triggered when the submit button is pressed on the interface. */ + async function submit(event) { + if (!validToSend) return; + let data = createForm(form); + const post_response = await api + .post(`/form`, data, { + headers: { + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, + }) + .then(function (error) { + if (!error.response) alert("Seu formulário foi criado com sucesso."); + }) + .catch(function (error) { + alert("Um erro ocorreu."); }); - } + /** Reordering the form array based on the place the question is being dragged over. */ + const onDragEnd = (result) => { + if (!result.destination) return; + const { source, destination } = result; + + const copiedForm = [...form]; + const [removed] = copiedForm.splice(source.index, 1); + copiedForm.splice(destination.index, 0, removed); + setForm(copiedForm); + }; + /** Error handling -> every time the form object is updated, it is verified to evaluate it's error messages, + * so the submit button can be enabled or disabled. + */ + useEffect(() => { + setValidToSend(verifyError(form)); + }, [form]); return ( - <div> - <Grid - container - direction="column" - alignItems="center" - justify="center" - > - { - form.map((x, index) => { - if(x.type === "question") - return <FormFieldText question={x.question} idq={index} - deleteFromForm={deleteFromForm} setQuestionField={setQuestionField} - setRequiredField={setRequiredField} required={x.required}/> - else if(x.type === "select") - return <FormFieldSelect question={x.question} options={x.options} idq={index} - deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setQuestionField={setQuestionField} setRequiredField={setRequiredField} - required={x.required} /> - else if(x.type === "radio") - return <FormFieldRadio question={x.question} options={x.options} idq={index} - deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setQuestionField={setQuestionField} setRequiredField={setRequiredField} - required={x.required} /> - else if(x.type === "checkbox") - return <FormFieldCheckbox question={x.question} options={x.options} idq={index} - deleteFromForm={deleteFromForm} addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} - setQuestionField={setQuestionField} setRequiredField={setRequiredField} - required={x.required} /> - else if(x.type === "title") - return <FormFieldTitle question={x.question} idq={index} - deleteFromForm={deleteFromForm} setTitleField={setTitleField} - setDescriptionField={setDescriptionField}/> - }) - } - <Button variant="contained" color="primary" onClick={createForm}> - Criar - </Button> - </Grid> - - <Paper className={classes.menu}> - <Grid - container - spacing={0} - direction="column" - alignItems="center" - justify="center" - > - <Grid item xs={0}> - <IconButton aria-label="add question" onClick={addToFormQuestion}> - <AddIcon /> - </IconButton> - <IconButton aria-label="add select" onClick={addToFormSelect}> - <ReorderIcon /> - </IconButton> - <IconButton aria-label="add radio" onClick={addToFormRadio}> - <RadioButtonCheckedIcon /> - </IconButton> - <IconButton aria-label="add checkbox" onClick={addToFormCheckbox}> - <CheckBoxOutlineBlankIcon /> - </IconButton> - </Grid> + <MuiThemeProvider theme={theme}> + <Grid className={classes.app}> + <Grid xs={12} sm={2} className={classes.sideMenuFormatingGrid}> + <SideMenu + addToFormQuestion={addToFormQuestion} + addToFormSelect={addToFormSelect} + addToFormRadio={addToFormRadio} + addToFormCheckbox={addToFormCheckbox} + addToFormSubForm={addToFormSubForm} + /> </Grid> - </Paper> - - </div> + <DragDropContext onDragEnd={onDragEnd}> + <Grid + dragOver + container + xs={12} + sm={8} + direction="column" + alignItems="center" + className={classes.questionsGrid} + > + <Droppable droppableId={columnId}> + {(provided, snapshot) => { + return ( + <Grid {...provided.droppableProps} ref={provided.innerRef}> + {form.map((x, index) => { + if (x.type === "question") + return ( + <FormFieldText + question={x.question} + idq={index} + description={x.description} + deleteFromForm={deleteFromForm} + setQuestionField={setQuestionField} + setRequiredField={setRequiredField} + setDescriptionField={setDescriptionField} + id={x.id} + error={x.error} + validation={x.validation} + addValidation={addValidation} + setValidation={setValidation} + /> + ); + else if (x.type === "select") + return ( + <FormFieldSelect + question={x.question} + options={x.options} + idq={index} + description={x.description} + deleteFromForm={deleteFromForm} + addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} + setSelectOption={setSelectOption} + setQuestionField={setQuestionField} + setRequiredField={setRequiredField} + setDescriptionField={setDescriptionField} + validation={x.validation} + id={x.id} + error={x.error} + /> + ); + else if (x.type === "radio") + return ( + <FormFieldRadio + question={x.question} + options={x.options} + idq={index} + description={x.description} + deleteFromForm={deleteFromForm} + addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} + setSelectOption={setSelectOption} + setQuestionField={setQuestionField} + setRequiredField={setRequiredField} + setDescriptionField={setDescriptionField} + validation={x.validation} + id={x.id} + error={x.error} + /> + ); + else if (x.type === "checkbox") + return ( + <FormFieldCheckbox + question={x.question} + options={x.options} + idq={index} + description={x.description} + deleteFromForm={deleteFromForm} + addSelectOption={addSelectOption} + removeSelectOption={removeSelectOption} + setSelectOption={setSelectOption} + setQuestionField={setQuestionField} + setRequiredField={setRequiredField} + setDescriptionField={setDescriptionField} + validation={x.validation} + id={x.id} + error={x.error} + /> + ); + else if (x.type === "subForm") + return ( + <FormFieldSubForm + question={x.question} + idq={index} + description={x.description} + deleteFromForm={deleteFromForm} + setQuestionField={setQuestionField} + setRequiredField={setRequiredField} + setDescriptionField={setDescriptionField} + setSubformId={setSubformId} + validation={x.validation} + id={x.id} + error={x.error} + validToSend={validToSend} + /> + ); + else if (x.type === "title") + return ( + <FormFieldTitle + question={x.question} + idq={index} + deleteFromForm={deleteFromForm} + setTitleField={setTitleField} + setDescriptionField={setDescriptionField} + error={x.error} + /> + ); + })} + {provided.placeholder} + </Grid> + ); + }} + </Droppable> + <Tooltip + title={ + validToSend + ? "Criar seu formulário" + : "Verifique se você criou pelo menos uma pergunta e se as perguntas estão propriamente construÃdas" + } + aria-label={ + validToSend + ? "Criar seu formulário" + : "Verifique se você criou pelo menos uma pergunta e se as perguntas estão propriamente construÃdas" + } + > + <Button + className={validToSend ? classes.buttonOk : classes.button} + variant="contained" + type="submit" + onClick={submit} + > + Criar + </Button> + </Tooltip> + </Grid> + </DragDropContext> + </Grid> + </MuiThemeProvider> ); } diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index ab1441d..4e6b3a5 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -8,7 +8,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -16,22 +16,22 @@ const useStyles = makeStyles(theme => ({ padding: "2% 1%", margin: "0 auto", marginTop: "9%", - width: "95%" + width: "95%", }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d" + color: "#46525d", }, strong_description: { fontSize: "14px", - color: "#c2c6ca" + color: "#c2c6ca", }, form: { marginTop: "3%", alignItems: "center", - textAlign: "center" + textAlign: "center", }, button: { type: "submit", @@ -42,25 +42,25 @@ const useStyles = makeStyles(theme => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)" + backgroundColor: "rgb(25, 109, 23)", }, ["@media (max-width:550px)"]: { - width: "55%" - } - } + width: "55%", + }, + }, })); export default function SignIn() { const classes = useStyles(); const [values, setValues] = React.useState({ email: "", password: "", - emailError: false + emailError: false, }); async function update(prop, event) { await setValues({ ...values, [prop]: event.target.value }); } - const handleChange = prop => event => { + const handleChange = (prop) => (event) => { if (!checkEmail()) { values.emailError = true; } else { @@ -75,64 +75,65 @@ export default function SignIn() { return false; } function verifyValues() { - if ( - values.email && - values.password - ) { + if (values.email && values.password) { return true; } return false; } function verifyValuesContent() { if (!checkEmail()) { - alert("Falha de autenticação. Certifique-se que email e senha estão corretos."); + alert( + "Falha de autenticação. Certifique-se que email e senha estão corretos." + ); return false; } return true; } async function handleSubmit() { const response = await api - .post(`/user/signIn`, { - email: values.email, - hash: values.password - }) - .then(function(response) { - if (!response.data.error) { - alert("Você logou com sucesso.") - window.sessionStorage.setItem("token", response.data.token); - window.sessionStorage.setItem("userId", response.data.id); - // redirecionar para a main page - } + .post(`/user/signIn`, { + email: values.email, + hash: values.password, }) - .catch(function(error) { + .then(function (response) { + if (!response.data.error) { + alert("Você logou com sucesso."); + window.sessionStorage.setItem("token", response.data.token); + window.sessionStorage.setItem("userId", response.data.id); + // redirecionar para a main page + } + }) + .catch(function (error) { if (error.response) { - alert("Falha de autenticação. Certifique-se que email e senha estão corretos.") + alert( + "Falha de autenticação. Certifique-se que email e senha estão corretos." + ); } }); } function submit() { if (verifyValues()) { if (verifyValuesContent()) { - handleSubmit(); + handleSubmit(); } } } const theme = createMuiTheme({ overrides: { root: { - color: "white" + color: "white", }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc" + borderBottom: "1px solid #35c7fc", }, "&:after": { - borderBottom: "1px solid #3f51b5" - } - } + borderBottom: "1px solid #3f51b5", + }, + }, }, - } + }, }); return ( <MuiThemeProvider theme={theme}> @@ -154,9 +155,7 @@ export default function SignIn() { /> </Grid> <Grid> - <FormInput - label="Senha" - param="password" onUpdate={handleChange} /> + <FormInput label="Senha" param="password" onUpdate={handleChange} /> </Grid> <Grid> <IconButton diff --git a/src/pages/teste.css b/src/pages/teste.css deleted file mode 100644 index e69de29..0000000 diff --git a/src/services/auth.js b/src/services/auth.js new file mode 100644 index 0000000..e684aee --- /dev/null +++ b/src/services/auth.js @@ -0,0 +1,9 @@ +export const TOKEN = "token"; + +export function isAuthenticated() { + return localStorage.getItem(TOKEN) !== null ? true : false; +} + +export function getToken() { + return localStorage.getItem(TOKEN); +} diff --git a/yarn-error.log b/yarn-error.log new file mode 100644 index 0000000..603f88e --- /dev/null +++ b/yarn-error.log @@ -0,0 +1,68 @@ +Arguments: + /usr/bin/node /home/gabriel/.npm-packages/bin/yarn add formik + +PATH: + /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/home/gabriel/.npm-packages/bin:/snap/bin:/home/gabriel/.npm-packages/bin:/snap/bin + +Yarn version: + 1.22.4 + +Node version: + 10.20.1 + +Platform: + linux x64 + +Trace: + Error: EACCES: permission denied, rmdir '/home/gabriel/Documents/c3sl/form-creator-ui/node_modules/@testing-library/.react.DELETE/node_modules/@babel' + +npm manifest: + { + "name": "my-app", + "version": "0.1.0", + "private": true, + "dependencies": { + "@material-ui/core": "^4.9.7", + "@material-ui/icons": "^4.9.1", + "@material-ui/lab": "^4.0.0-alpha.46", + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.5.0", + "@testing-library/user-event": "^7.2.1", + "axios": "^0.19.2", + "material-ui": "^0.20.2", + "react": "^16.13.1", + "react-beautiful-dnd": "^13.0.0", + "react-dom": "^16.13.1", + "react-os": "0.0.9", + "react-router-dom": "^5.1.2", + "react-scripts": "3.3.0", + "yup": "^0.28.3" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } + } + +yarn manifest: + No manifest + +Lockfile: + No lockfile -- GitLab From 0f1eed318123f3f774955db8ba80cb6dfd2af190 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Tue, 26 May 2020 10:33:34 -0300 Subject: [PATCH 33/72] Issue #8: Page to answer forms with subforms --- .../fieldsAnswerForm/FormFieldCheckbox.js | 110 +++++- .../fieldsAnswerForm/FormFieldRadio.js | 116 +++++- .../fieldsAnswerForm/FormFieldSelect.js | 144 ++++++-- .../fieldsAnswerForm/FormFieldSubform.js | 116 ++++++ .../fieldsAnswerForm/FormFieldText.js | 89 ++++- .../fieldsAnswerForm/FormFieldTitle.js | 90 +++-- src/pages/AnswerForm.js | 334 ++++++++++++++---- 7 files changed, 832 insertions(+), 167 deletions(-) create mode 100644 src/components/fieldsAnswerForm/FormFieldSubform.js diff --git a/src/components/fieldsAnswerForm/FormFieldCheckbox.js b/src/components/fieldsAnswerForm/FormFieldCheckbox.js index 462b63f..f658a90 100644 --- a/src/components/fieldsAnswerForm/FormFieldCheckbox.js +++ b/src/components/fieldsAnswerForm/FormFieldCheckbox.js @@ -1,51 +1,126 @@ -import React from "react"; +import React, { useEffect } from "react"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; -import TextField from "@material-ui/core/TextField"; -import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; -import IconButton from "@material-ui/core/IconButton"; -import Select from "@material-ui/core/Select"; -import MenuItem from "@material-ui/core/MenuItem"; -import AddCircleIcon from "@material-ui/icons/AddCircle"; -import CloseIcon from "@material-ui/icons/Close"; -import Switch from "@material-ui/core/Switch"; -import FormControlLabel from "@material-ui/core/FormControlLabel"; import Typography from "@material-ui/core/Typography"; import Checkbox from "@material-ui/core/Checkbox"; import FieldFooterOptions from "./FieldFooterOptions"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(16), + minheight: theme.spacing(18), margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } }, questionsGrid: { - marginBottom: "20px", + marginBottom: "20px" }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" + } })); function FormFieldCheckbox(props) { const classes = useStyles(); - const options = props.options.map(function (x) { + /** Temporary array to be used as a type. */ + function vetorTmp() { + let tmp = []; + props.options.map(x => { + tmp.push(false); + }); + return tmp; + } + + /** Variable that displays the validation message. */ + const [valid, setValid] = React.useState(); + + /** Array of boolean to specify what is selected as true */ + const [checkedArray, setcheckedArray] = React.useState(vetorTmp()); + + /** Function to send answer to the father component. */ + function sendArray() { + if (validate(checkedArray)) { + props.createAnswer(props.id, checkedArray, false); + } else { + props.createAnswer(props.id, checkedArray, true); + } + } + + /** + * Function that changes the array based on selected index. + * @param index - Selected value from input. + */ + function handleArray(index) { + checkedArray[index] = !checkedArray[index]; + sendArray(); + } + + /** + * Function to validate an input based on input validation. + * @param answer - Input to be validated. + */ + function validate(answer) { + let isValid = true; + + setValid(""); + props.validation.map(val => { + switch (val.type) { + case 6: + if ( + !answer.some(value => { + return value === true; + }) + ) { + setValid("Preencha pelo menos uma caixa."); + isValid = false; + } + break; + default: + isValid = true; + } + }); + + return isValid; + } + + /** HTML to be displayed. */ + const options = props.options.map((x, index) => { return ( <span> - {x.value} <Checkbox /> + <Typography className={classes.text} variant="h7"> + {x.value} + </Typography> + <Checkbox onChange={() => handleArray(index)} /> </span> ); }); + /** First validates an empty array. */ + useEffect(() => { + validate([]); + }, []); + return ( <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography variant="h6" gutterBottom> + <Typography className={classes.text} variant="h6"> {props.question} </Typography> + <Typography variant="h8">{props.description}</Typography> </Grid> <Grid item @@ -57,6 +132,9 @@ function FormFieldCheckbox(props) { className={classes.questionsGrid} > {options} + <div> + <Typography className={classes.validation}>{valid}</Typography> + </div> </Grid> </Grid> </Paper> diff --git a/src/components/fieldsAnswerForm/FormFieldRadio.js b/src/components/fieldsAnswerForm/FormFieldRadio.js index 68a79e4..3b2724e 100644 --- a/src/components/fieldsAnswerForm/FormFieldRadio.js +++ b/src/components/fieldsAnswerForm/FormFieldRadio.js @@ -1,16 +1,7 @@ -import React from "react"; +import React, { useState, useEffect } from "react"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; -import TextField from "@material-ui/core/TextField"; -import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; -import IconButton from "@material-ui/core/IconButton"; -import Select from "@material-ui/core/Select"; -import MenuItem from "@material-ui/core/MenuItem"; -import AddCircleIcon from "@material-ui/icons/AddCircle"; -import CloseIcon from "@material-ui/icons/Close"; -import Switch from "@material-ui/core/Switch"; -import FormControlLabel from "@material-ui/core/FormControlLabel"; import Typography from "@material-ui/core/Typography"; import Radio from "@material-ui/core/Radio"; import RadioGroup from "@material-ui/core/RadioGroup"; @@ -21,43 +12,131 @@ const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) + minheight: theme.spacing(18), + margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } }, questionsGrid: { marginBottom: "20px" + }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" } })); function FormFieldRadio(props) { const classes = useStyles(); + /** Temporary array to be used as a type. */ + function vetorTmp() { + let tmp = []; + props.options.map(x => { + tmp.push(false); + }); + return tmp; + } + + /** Input number that was just selected. */ const [selectedValue, setSelectedValue] = React.useState(); + /** Variable that displays the validation message. */ + const [valid, setValid] = React.useState(); + + /** Array of boolean to specify what is selected as true */ + const [checkedArray, setCheckedArray] = React.useState(vetorTmp()); + + /** + * Function to validate an input based on input validation. + * @param answer - Input to be validated. + */ + function validate(answer) { + let isValid = true; + + setValid(""); + props.validation.map(val => { + switch (val.type) { + case 2: + if ( + !answer.some(value => { + return value === true; + }) + ) { + setValid("Campo obrigatório."); + isValid = false; + } + break; + default: + isValid = true; + } + }); + + return isValid; + } + + /** + * Function to send answer to the father component. + * @param index - Number of the selected value. + */ + function handleArray(index) { + for (let i = 0; i < checkedArray.length; ++i) { + checkedArray[i] = false; + } + + checkedArray[index] = !checkedArray[index]; + if (validate(checkedArray)) { + props.createAnswer(props.id, checkedArray, false); + } else { + props.createAnswer(props.id, checkedArray, true); + } + } + + /** + * Function to set the selectedValue as the event. + * @param event - React event to get what is selected. + */ const handleChange = event => { setSelectedValue(event.target.value); }; - const options = props.options.map(function(x) { + /** HTML object to be displayed on component return. */ + const options = props.options.map(function(x, index) { return ( <span> - {x.value} + <Typography className={classes.text} variant="h7"> + {x.value} + </Typography> <Radio + onClick={handleChange} checked={selectedValue === x.value} - onChange={handleChange} + onChange={() => handleArray(index)} value={x.value} /> </span> ); }); + /** First validates an empty array. */ + useEffect(() => { + validate([]); + }, []); + return ( <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography variant="h6" gutterBottom> + <Typography className={classes.text} variant="h6"> {props.question} </Typography> + <Typography variant="h8">{props.description}</Typography> </Grid> <Grid item @@ -68,7 +147,10 @@ function FormFieldRadio(props) { xs={5} className={classes.questionsGrid} > - <RadioGroup>{options}</RadioGroup> + <RadioGroup> + {options} + <Typography className={classes.validation}>{valid}</Typography> + </RadioGroup> </Grid> </Grid> </Paper> diff --git a/src/components/fieldsAnswerForm/FormFieldSelect.js b/src/components/fieldsAnswerForm/FormFieldSelect.js index 46ee77b..d00a1ba 100644 --- a/src/components/fieldsAnswerForm/FormFieldSelect.js +++ b/src/components/fieldsAnswerForm/FormFieldSelect.js @@ -1,67 +1,155 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; -import Typography from '@material-ui/core/Typography'; - -import FieldFooterOptions from './FieldFooterOptions'; +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import Typography from "@material-ui/core/Typography"; +import FieldFooterOptions from "./FieldFooterOptions"; const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(16), - margin: theme.spacing(2) + minheight: theme.spacing(18), + margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } }, questionsGrid: { - marginBottom: '20px' + marginBottom: "20px" }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" + } })); - - function FormFieldSelect(props) { const classes = useStyles(); + /** Temporary array to be used as a type. */ + function vetorTmp() { + let tmp = []; + props.options.map(x => { + tmp.push(false); + }); + return tmp; + } + + /** Variable that displays the validation message. */ + const [valid, setValid] = React.useState(); + + /** Input number that was just selected. */ + const [selectedValue, setselectedValue] = React.useState(); + + /** + * Function to validate an input based on input validation. + * @param answer - Input to be validated. + */ + function validate(answer) { + let isValid = true; + + setValid(""); + props.validation.map(val => { + switch (val.type) { + case 2: + if ( + !answer.some(value => { + return value === true; + }) + ) { + setValid("Campo obrigatório."); + isValid = false; + } + break; + default: + isValid = true; + } + }); + + return isValid; + } + + /** + * Function to set the selectedValue as the event. + * @param event - React event to get what is selected. + */ + const handleChange = event => { + validate([]); + setselectedValue(event.target.value); + }; + + /** Array of boolean to specify what is selected as true */ + const [checkedArray, setcheckedArray] = React.useState(vetorTmp()); + + /** + * Function to send answer to the father component. + * @param index - Number of the selected value. + */ + function handleArray(index) { + for (let i = 0; i < checkedArray.length; ++i) { + checkedArray[i] = false; + } + + checkedArray[index] = !checkedArray[index]; + if (validate(checkedArray)) { + props.createAnswer(props.id, checkedArray, false); + } else { + props.createAnswer(props.id, checkedArray, true); + } + } + + /** HTML object to be displayed on component return. */ const options = props.options.map(function(x) { - return <MenuItem value={x.value}>{x.value}</MenuItem>; + return <MenuItem value={x.placement}>{x.value}</MenuItem>; }); + /** Everytime selectedValue is changed it's sent to the father component. */ + useEffect(() => { + handleArray(selectedValue); + }, [selectedValue]); + return ( <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography variant="h6" gutterBottom> + <Typography className={classes.text} variant="h6"> {props.question} </Typography> + <Typography variant="h8" gutterBottom> + {props.description} + </Typography> </Grid> - <Grid item container + <Grid + item + container direction="column" justify="flex-start" - alignItems="flex-start" xs={5} className={classes.questionsGrid} + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} > <Select labelId="demo-simple-select-label" id="demo-simple-select" - // onChange={handleChange} + onChange={handleChange} > {options} </Select> + <Typography className={classes.validation}>{valid}</Typography> </Grid> </Grid> </Paper> ); - } -export default FormFieldSelect; \ No newline at end of file +export default FormFieldSelect; diff --git a/src/components/fieldsAnswerForm/FormFieldSubform.js b/src/components/fieldsAnswerForm/FormFieldSubform.js new file mode 100644 index 0000000..7a14fb8 --- /dev/null +++ b/src/components/fieldsAnswerForm/FormFieldSubform.js @@ -0,0 +1,116 @@ +import React, { useState, useEffect } from "react"; +import { useParams } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Button from "@material-ui/core/Button"; +import api from "../../api"; + +import FormFieldText from "./FormFieldText"; +import FormFieldSelect from "./FormFieldSelect"; +import FormFieldRadio from "./FormFieldRadio"; +import FormFieldCheckbox from "./FormFieldCheckbox"; + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + } +})); + +function FormFieldSubform(props) { + const classes = useStyles(); + + /** Subform id */ + const id = props.id; + + /** Maped subform */ + const [formData, setFormData] = useState(0); + + /** Get subform */ + async function getForm(id) { + const res = await api.get(`/form/${id}`).then(function(res) { + setFormData(res.data); + props.mapInputs(res.data); + }); + } + + /** First gets info from the backend */ + useEffect(() => { + getForm(id); + }, []); + + return ( + <div> + <Grid container direction="column" alignItems="center" justify="center"> + {formData ? ( + <div> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + validation={input.validation} + description={input.description} + id={input.id} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + validation={input.validation} + id={input.id} + description={input.description} + options={input.sugestions} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + validation={input.validation} + options={input.sugestions} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + validation={input.validation} + options={input.sugestions} + id={input.id} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + createAnswer={props.createAnswer} + mapInputs={props.mapInputs} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + </Grid> + </div> + ); +} + +export default FormFieldSubform; diff --git a/src/components/fieldsAnswerForm/FormFieldText.js b/src/components/fieldsAnswerForm/FormFieldText.js index 91e2f59..1ad6d0c 100644 --- a/src/components/fieldsAnswerForm/FormFieldText.js +++ b/src/components/fieldsAnswerForm/FormFieldText.js @@ -1,10 +1,8 @@ -import React from "react"; +import React, { useState, useEffect } from "react"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; import TextField from "@material-ui/core/TextField"; -import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; -import IconButton from "@material-ui/core/IconButton"; import Typography from "@material-ui/core/Typography"; import FieldFooterOptions from "./FieldFooterOptions"; @@ -13,31 +11,108 @@ const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - height: theme.spacing(16), - margin: theme.spacing(2) + height: "15%", + margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } }, questionsGrid: { marginBottom: "20px" + }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" } })); function FormFieldText(props) { const classes = useStyles(); + /** Variable that displays the validation message. */ + const [valid, setValid] = React.useState(); + + /** + * Function to validate an input based on input validation. + * @param answer - Input to be validated. + */ + function validate(answer) { + let isValid = true; + + setValid(""); + props.validation.map(val => { + switch (val.type) { + case 2: + if (answer === "") { + setValid("Campo obrigatório."); + isValid = false; + } + break; + case 3: + if (answer.length > Number(val.arguments[0])) { + setValid( + "Este campo requer o máximo de " + val.arguments[0] + " digitos." + ); + isValid = false; + } + break; + case 4: + if (answer.length < Number(val.arguments[0])) { + setValid( + "Este campo requer o mÃnimo de " + val.arguments[0] + " digitos." + ); + isValid = false; + } + break; + default: + isValid = true; + } + }); + + return isValid; + } + + /** + * Function to send answer to the father component. + * @param event - React event to get what is typed in. + */ + const handleChange = event => { + if (validate(event.target.value)) { + props.createAnswer(props.id, event.target.value, false); + } else { + props.createAnswer(props.id, event.target.value, true); + } + }; + + /** First validates an empty string. */ + useEffect(() => { + validate(""); + }, []); + return ( <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography variant="h6" gutterBottom> + <Typography className={classes.text} variant="h6"> {props.question} </Typography> + <Typography variant="h8">{props.description}</Typography> </Grid> <Grid item xs={9} className={classes.questionsGrid}> <TextField + multiline id="outlined-disabled" label="" - placeholder="Resposta curta" + placeholder="Resposta" + onChange={handleChange} /> + <Typography className={classes.validation}>{valid}</Typography> </Grid> <Grid item diff --git a/src/components/fieldsAnswerForm/FormFieldTitle.js b/src/components/fieldsAnswerForm/FormFieldTitle.js index 52c907b..34a2d79 100644 --- a/src/components/fieldsAnswerForm/FormFieldTitle.js +++ b/src/components/fieldsAnswerForm/FormFieldTitle.js @@ -2,9 +2,6 @@ import React from 'react'; import { makeStyles } from '@material-ui/core/styles'; import Grid from '@material-ui/core/Grid'; import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; import Typography from '@material-ui/core/Typography'; import FieldFooterOptions from './FieldFooterOptions'; @@ -13,45 +10,72 @@ const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - height: theme.spacing(16), - margin: theme.spacing(2) + height: theme.spacing(22), + margin: theme.spacing(2), + color: '#000000', + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } }, questionsGrid: { - marginBottom: '20px' - }, - title: { - fontSize: 'xx-large' - }, - description: { - fontSize: 'x-large' - }, + marginBottom: '20px', + color: '#000000', + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + } + }, + title: { + fontSize: '45px', + color: '#000000', + ["@media (max-width:827px)"]: { + fontSize: '35px' + }, + ["@media (max-width:590px)"]: { + fontSize: '25px' + } + }, + description: { + fontSize: '30px', + color: '#000000', + ["@media (max-width:827px)"]: { + fontSize: '25px' + }, + ["@media (max-width:590px)"]: { + fontSize: '15px' + } + }, })); function FormFieldText(props) { const classes = useStyles(); return ( - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <Typography variant="h3" gutterBottom> - {props.title} - </Typography> - </Grid> - <Grid item xs={9} className={classes.questionsGrid}> - <Typography variant="h4" gutterBottom> - {props.description} - </Typography> - </Grid> - <Grid item container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - > + <Grid> + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography className={classes.title} variant="h3" gutterBottom> + {props.title} + </Typography> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <Typography className={classes.description} variant="h4" gutterBottom> + {props.description} + </Typography> + </Grid> + <Grid item container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + > + </Grid> </Grid> - </Grid> - </Paper> + </Paper> + </Grid> ); } diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index f123fd5..f09d9e0 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -1,97 +1,299 @@ -import React, { useState, useEffect } from 'react'; +import React, { useState, useEffect } from "react"; import { useParams } from "react-router-dom"; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import AddIcon from '@material-ui/icons/Add'; -import IconButton from '@material-ui/core/IconButton'; -import ReorderIcon from '@material-ui/icons/Reorder'; -import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked'; -import CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank'; -import Button from '@material-ui/core/Button'; -import axios from 'axios'; - -import FormFieldText from '../components/fieldsAnswerForm/FormFieldText'; -import FormFieldSelect from '../components/fieldsAnswerForm/FormFieldSelect'; -import FormFieldRadio from '../components/fieldsAnswerForm/FormFieldRadio'; -import FormFieldCheckbox from '../components/fieldsAnswerForm/FormFieldCheckbox'; -import FormFieldTitle from '../components/fieldsAnswerForm/FormFieldTitle'; - -import config from '../config'; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import api from "../api"; +import Button from "@material-ui/core/Button"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import FormFieldText from "../components/fieldsAnswerForm/FormFieldText"; +import FormFieldSelect from "../components/fieldsAnswerForm/FormFieldSelect"; +import FormFieldRadio from "../components/fieldsAnswerForm/FormFieldRadio"; +import FormFieldCheckbox from "../components/fieldsAnswerForm/FormFieldCheckbox"; +import FormFieldTitle from "../components/fieldsAnswerForm/FormFieldTitle"; +import FormFieldSubform from "../components/fieldsAnswerForm/FormFieldSubform"; +import { validate } from "json-schema"; const useStyles = makeStyles(theme => ({ menu: { width: theme.spacing(6), minheight: theme.spacing(15), - position: 'fixed', + position: "fixed", top: theme.spacing(10), - left: '90%', + left: "90%", padding: theme.spacing(1) }, + button: { + type: "submit", + width: "100%", + background: "#6ec46c", + borderRadius: "2px", + padding: "10px 20px", + fontSize: "18px", + "&:hover": { + backgroundColor: "rgb(25, 109, 23)" + } + }, + pageBody: { + minHeight: "calc(100vh - 92.4px - 78px)", + paddingBottom: "78px" + } })); +const theme = createMuiTheme({ + overrides: { + MuiInput: { + underline: { + "&:before": { + borderBottom: "1px solid #35c7fc" + }, + "&:after": { + borderBottom: "1px solid #3f51b5" + } + } + }, + MuiButton: { + label: { + color: "black" + } + } + } +}); + function AnwserForm() { const classes = useStyles(); + /** Array of answers created when form is maped from the api */ + const [answerArray, setanswerArray] = React.useState([]); + + /** + * Function to update the array of answers. + * @param id - Input's id that was just answered. + * @param inputAnswer - Input's answer that was just answered. + * @param error - Boolean variable that indicates if answer is valid or not. + */ + function createAnswer(id, inputAnswer, error) { + for (const answer of answerArray) { + if (id === answer.idInput) { + answer.answerInput = inputAnswer; + answer.error = error; + } + } + } + + /** Function to check if answers are valid */ + function isError() { + return answerArray.some(value => { + return value.error; + }); + } + + /** + * Function to check if some question was answered. + * It wouldn't make sense to have a form answered without any answers on it. + */ + function isAnswer() { + return answerArray.some(value => { + return value.answerInput.length !== 0; + }); + } + + /** Function to check if the answers of a form can generate a JSON */ + function isValid() { + if (!isAnswer()) { + alert("Não há respostas no form"); + return false; + } + + if (isError()) { + alert( + "Erro. Verifique se suas respostas estão de acordo com as validações." + ); + return false; + } + + return true; + } + + /** + * Funtion to generate the JSON object that is sent to the API + */ + function backendTranslation() { + let id; + let retVal = {}; + + if (!isValid()) { + return; + } + + for (const answerObj of answerArray) { + if (answerObj.typeInput === 0 && answerObj.answerInput.length !== 0) { + id = answerObj.idInput; + var answer = answerObj.answerInput; + retVal[id] = [answer]; + } else if ( + (answerObj.typeInput === 1 || + answerObj.typeInput === 2 || + answerObj.typeInput === 3) && + answerObj.answerInput.length !== 0 + ) { + let tmpArray = []; + id = answerObj.idInput; + for (const value of answerObj.answerInput) { + tmpArray.push(String(value)); + } + retVal[id] = tmpArray; + } + } + + return retVal; + } + + /** Form id got from the browser's URL */ const { id } = useParams(); + /** Maped form from backend */ const [formData, setFormData] = useState(0); - function getForm(id) { - axios.get(`${config.genformsapi.url}/form/${id}`) - .then(res => { - console.log(res); - console.log(res.data); - setFormData(res.data); + /** + * Function to send some form answers to the API + * @param id - Form id got from the broswer's URL + */ + async function answerForm(id) { + const res = await api + .post(`/answer/${id}`, backendTranslation()) + .then(function(res) { + alert("Formulário respondido!"); }); - } + } - function answerForm() { - axios.post(`${config.genformsapi.url}/form`) - .then(res => { - console.log(res); - console.log(res.data); - }); + /** + * Function to map form inputs from the backend. + * @param form - Form object that just came from the API. + */ + function mapInputs(form) { + form.inputs.map(input => { + if ( + input.validation.some(value => { + return value.type === 2 || value.type === 6; + }) + ) { + answerArray.push({ + idInput: input.id, + typeInput: input.type, + answerInput: [], + error: true + }); + } else { + answerArray.push({ + idInput: input.id, + typeInput: input.type, + answerInput: [], + error: false + }); + } + }); } + /** + * Function to get form object from the API. + * @param id - Form id got from the broswer's URL + */ + async function getForm(id) { + const res = await api.get(`/form/${id}`).then(function(res) { + setFormData(res.data); + mapInputs(res.data); + }); + } + + /** First thing the page does is getting the form from the API. */ useEffect(() => { getForm(id); }, []); return ( - <div> - <Grid - container - direction="column" - alignItems="center" - justify="center" - > - - { - formData ? - <div> - <FormFieldTitle title={formData.title} description={formData.description}/> - { - formData.inputs.map((x, index) => { - if(x.type === 0) - return <FormFieldText question={x.question}/> - else if(x.type === 4) - return <FormFieldSelect question={x.question} options={x.sugestions}/> - else if(x.type === 2) - return <FormFieldRadio question={x.question} options={x.sugestions}/> - else if(x.type === 1) - return <FormFieldCheckbox question={x.question} options={x.sugestions}/> - }) - } - </div> : <p>Loading...</p> - } - <Button variant="contained" color="primary" onClick={answerForm}> - Responder - </Button> - </Grid> - </div> + <MuiThemeProvider theme={theme}> + <div className={classes.pageBody}> + <Grid container direction="column" alignItems="center" justify="center"> + {formData ? ( + <div> + <FormFieldTitle + title={formData.title} + description={formData.description} + /> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + validation={input.validation} + description={input.description} + id={input.id} + createAnswer={createAnswer} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + validation={input.validation} + id={input.id} + description={input.description} + options={input.sugestions} + createAnswer={createAnswer} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + validation={input.validation} + options={input.sugestions} + createAnswer={createAnswer} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + validation={input.validation} + options={input.sugestions} + id={input.id} + createAnswer={createAnswer} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + createAnswer={createAnswer} + mapInputs={mapInputs} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + <Grid> + <Button + type="submit" + variant="contained" + className={classes.button} + onClick={() => answerForm(id)} + > + Responder + </Button> + </Grid> + </Grid> + </div> + </MuiThemeProvider> ); } -- GitLab From 69a7e1386d943f1403babc6896f4f8c883ce6ea6 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Tue, 26 May 2020 08:12:58 -0300 Subject: [PATCH 34/72] =?UTF-8?q?Issue=20#19:=20Corre=C3=A7=C3=A3o=20de=20?= =?UTF-8?q?problemas=20na=20tela=20de=20cria=C3=A7=C3=A3o=20de=20formul?= =?UTF-8?q?=C3=A1rios?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- .../fieldsCreateForm/FormFieldSubform.js | 50 ++-------- .../fieldsCreateForm/FormFieldText.js | 91 ++++++++----------- .../utils/BackendTranslation.js | 9 +- .../fieldsCreateForm/utils/schemas.js | 3 +- src/pages/CreateForm.js | 34 +++++-- 5 files changed, 77 insertions(+), 110 deletions(-) diff --git a/src/components/fieldsCreateForm/FormFieldSubform.js b/src/components/fieldsCreateForm/FormFieldSubform.js index 628b6b3..b99dce2 100644 --- a/src/components/fieldsCreateForm/FormFieldSubform.js +++ b/src/components/fieldsCreateForm/FormFieldSubform.js @@ -2,16 +2,13 @@ import React, { useEffect } from "react"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; -import TextField from "@material-ui/core/TextField"; import api from "../../api"; import FieldFooterOptions from "./FieldFooterOptions"; import Select from "@material-ui/core/Select"; import MenuItem from "@material-ui/core/MenuItem"; import FormControl from "@material-ui/core/FormControl"; import InputLabel from "@material-ui/core/InputLabel"; -import InfoIcon from "@material-ui/icons/Info"; import { Draggable } from "react-beautiful-dnd"; -import Tooltip from "@material-ui/core/Tooltip"; import DefaultField from "./DefaultField"; /** CSS styles used on page components. */ @@ -57,11 +54,6 @@ const useStyles = makeStyles((theme) => ({ width: "80%", }, }, - tooltipAdjustment: { - ["@media (max-width: 600px)"]: { - flexDirection: "column-reverse", - }, - }, footerOptsAdjustment: { ["@media (min-width: 600px)"]: { marginBottom: "3%", @@ -71,27 +63,13 @@ const useStyles = makeStyles((theme) => ({ /** Function that returns the component to select te subform to be used. */ function SubformSelect(props) { - /** State to store the form being used. */ - const [usedForm, setUsedForm] = React.useState({}); /** Style class. */ const classes = useStyles(); - /** State to manage errors. */ - const [error, setError] = React.useState(true); /** Functions that handle the input changes to save it at the father component. */ const handleChange = (event) => { - setUsedForm(props.array.filter((x) => x.id === event.target.value)); + console.log(event.target); props.setSubformId(event.target.value, props.idq); - setError(false); }; - /** Initial error state setting. */ - useEffect(() => { - if ( - props.error.errorMsg.subformUsage || - props.error.errorMsg.subformSelected - ) - setError(true); - }, []); - return ( <FormControl variant="outlined" className={classes.subformSelect}> <InputLabel @@ -105,12 +83,11 @@ function SubformSelect(props) { <Select labelId="demo-simple-select-outlined-label" id="demo-simple-select-outlined" - value={usedForm.title} - renderValue={usedForm.title} + value={props.subformId} onChange={handleChange} label="Selecione um subformulário" style={{ width: "100%" }} - error={error ? true : false} + error={props.subformId ? false : true} > {props.array.length > 0 ? ( props.array.map((form) => ( @@ -155,8 +132,8 @@ export default function FormFieldSubform(props) { {...provided.dragHandleProps} > <Grid container> - <Grid container item className={classes.tooltipAdjustment}> - <Grid container item xs={11}> + <Grid container item> + <Grid container item xs={12}> <DefaultField question={props.question} description={props.description} @@ -166,21 +143,6 @@ export default function FormFieldSubform(props) { error={props.error} /> </Grid> - <Grid - container - item - xs={12} - sm={1} - className={classes.questionsGrid} - > - <Tooltip - // style={{ position: "absolute" }} - title="Por favor, reordene este campo antes de lhe atribuir valor" - aria-label="Por favor, reordene este campo antes de lhe atribuir valor" - > - <InfoIcon /> - </Tooltip> - </Grid> </Grid> <Grid item xs={12} sm={6} className={classes.questionsGrid}> <SubformSelect @@ -188,6 +150,8 @@ export default function FormFieldSubform(props) { setSubformId={props.setSubformId} idq={props.idq} error={props.error} + subformId={props.subformId} + subformId={props.subformId} /> </Grid> <Grid item sm={2} xs={12} className={classes.errorGridSubform}> diff --git a/src/components/fieldsCreateForm/FormFieldText.js b/src/components/fieldsCreateForm/FormFieldText.js index 6fc95fb..18b4750 100644 --- a/src/components/fieldsCreateForm/FormFieldText.js +++ b/src/components/fieldsCreateForm/FormFieldText.js @@ -1,4 +1,4 @@ -import React, { useEffect } from "react"; +import React from "react"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; @@ -10,10 +10,10 @@ import Tooltip from "@material-ui/core/Tooltip"; import AddCircleIcon from "@material-ui/icons/AddCircle"; import FormControl from "@material-ui/core/FormControl"; import InputLabel from "@material-ui/core/InputLabel"; -import InfoIcon from "@material-ui/icons/Info"; import { Draggable } from "react-beautiful-dnd"; import FieldFooterOptions from "./FieldFooterOptions"; import DefaultField from "./DefaultField"; +import CloseIcon from "@material-ui/icons/Close"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -43,40 +43,23 @@ const useStyles = makeStyles((theme) => ({ row: { display: "flex", flexDirection: "row", + ["@media (max-width:600px)"]: { + flexDirection: "column", + marginTop: "5%", + }, }, })); /** Main function that returns the content of the option 'question'. */ function FormFieldText(props) { /** Style class. */ const classes = useStyles(); - /** Representation of the possible 'extra' validations to be used. */ + /** Representation of the possible 'extra' validations to be used. + * The types are equivalent to the backend. + */ const validationOpts = [ - { type: "minChar", name: "MÃnimo de caracteres", value: "" }, - { type: "maxChar", name: "Máximo de caracteres", value: "" }, + { type: 3, name: "MÃnimo de caracteres", value: "" }, + { type: 4, name: "Máximo de caracteres", value: "" }, ]; - /** State to store the validation being used. */ - const [usedValidation, setUsedValidation] = React.useState(); - /** State to manage error properties. */ - const [error, setError] = React.useState(true); - /** An specific handle change function that updates the type of the chosen validation. */ - const handleChangeType = (event) => { - setUsedValidation(validationOpts[event.target.value]); - setError(false); - }; - /** An specific handle change function that updates the value of the chosen validation. */ - const handleChangeValue = (event) => { - setUsedValidation({ - type: usedValidation.type, - name: usedValidation.name, - value: event.target.value, - }); - }; - /** useEffect being used as a handle change function to send data (the chosen type of validation and the value) to the father component. */ - useEffect(() => { - if (usedValidation) { - props.setValidation(usedValidation, props.idq); - } - }, [usedValidation]); return ( <Draggable key={props.id} draggableId={props.id} index={props.idq}> @@ -113,7 +96,6 @@ function FormFieldText(props) { alignItems="flex-end" xs={12} sm={4} - className={classes.row} > <FieldFooterOptions deleteFromForm={props.deleteFromForm} @@ -136,46 +118,51 @@ function FormFieldText(props) { <Select labelId="demo-simple-select-outlined-label" id="demo-simple-select-outlined" - onChange={handleChangeType} + onChange={(event) => + props.setValidationType(event.target.value, props.idq) + } + value={props.validationType} label="Selecione uma validação" style={{ minWidth: "250px" }} - error={error ? true : false} + error={props.validationType ? false : true} > - {validationOpts.map((x, index) => ( - <MenuItem key={index} value={index}> + {validationOpts.map((x) => ( + <MenuItem key={x.type} value={x.type}> {x.name} </MenuItem> ))} </Select> </Grid> - <Grid - container - item - xs={12} - sm={1} - className={classes.questionsGrid} - > - <Tooltip - // style={{ position: "absolute" }} - title="Por favor, reordene este campo antes de lhe atribuir valor" - aria-label="Por favor, reordene este campo antes de lhe atribuir valor" - > - <InfoIcon /> - </Tooltip> - </Grid> - {usedValidation ? ( - <Grid item xs={12} sm={4} className={classes.questionsGrid}> + {props.validationType ? ( + <Grid item xs={12} sm={5} className={classes.questionsGrid}> <TextField style={{ width: "45%" }} label="Quantidade" - value={usedValidation.value} - onChange={handleChangeValue} + value={props.validationValue} + onChange={(event) => + props.setValidationValue(event.target.value, props.idq) + } /> <Grid className={classes.errorGrid}> {props.error.errorMsg.validation.value} </Grid> </Grid> ) : null} + <Grid item xs={1}> + <Tooltip + title="Remover a validação" + aria-label="Remover a validação" + > + <IconButton + aria-label="remove validation" + onClick={() => { + props.removeValidation(props.idq); + }} + > + <CloseIcon /> + </IconButton> + </Tooltip> + </Grid> </FormControl> ) : ( <Grid diff --git a/src/components/fieldsCreateForm/utils/BackendTranslation.js b/src/components/fieldsCreateForm/utils/BackendTranslation.js index 6acb5c1..698eee3 100644 --- a/src/components/fieldsCreateForm/utils/BackendTranslation.js +++ b/src/components/fieldsCreateForm/utils/BackendTranslation.js @@ -65,11 +65,10 @@ function setValidation(form) { arguments: [], }); else if (form.type === "question" && form.validation.length > 1) { - if (form.validation[1].type === "maxChar") { - val.push({ type: 3, arguments: [form.validation[1].value] }); - } else { - val.push({ type: 4, arguments: [form.validation[1].value] }); - } + val.push({ + type: form.validation[1].type, + arguments: [form.validation[1].value], + }); } else val.push({ type: 2, diff --git a/src/components/fieldsCreateForm/utils/schemas.js b/src/components/fieldsCreateForm/utils/schemas.js index 3255a31..1995384 100644 --- a/src/components/fieldsCreateForm/utils/schemas.js +++ b/src/components/fieldsCreateForm/utils/schemas.js @@ -82,7 +82,6 @@ export async function testSubformSchema(form, index) { .validate(form) .then((x) => { form[index].error.errorMsg.subformUsage = ""; - form[index].error.errorMsg.subformSelected = false; }) .catch((err) => { form[index].error.errorMsg.subformUsage = err.message; @@ -139,7 +138,7 @@ export function verifyError(form) { } } if (x.type === "subForm") { - if (x.error.errorMsg.subformUsage || x.error.errorMsg.subformSelected) { + if (x.error.errorMsg.subformUsage || !x.subformId) { valid = false; return; } diff --git a/src/pages/CreateForm.js b/src/pages/CreateForm.js index b75453f..9a2a477 100644 --- a/src/pages/CreateForm.js +++ b/src/pages/CreateForm.js @@ -25,7 +25,6 @@ import SideMenu from "../components/fieldsCreateForm/SideMenu"; import api from "../api"; import Tooltip from "@material-ui/core/Tooltip"; - /** CSS styles used on page components */ const useStyles = makeStyles((theme) => ({ app: { @@ -217,7 +216,6 @@ function CreateForm() { question: "Este campo é obrigatório!", description: "", subformUsage: "", - subformSelected: true, }, }, }, @@ -275,8 +273,8 @@ function CreateForm() { } /** Function to update the title, used on FormFieldTitle. */ async function setTitleField(value) { - await testQuestionTextSchema(form, value, 0); form[0].title = value; + await testQuestionTextSchema(form, value, 0); setForm([...form]); } /** Function to store the selected subform Id on it's corresponding object. */ @@ -285,10 +283,21 @@ function CreateForm() { await testSubformSchema(form, index); setForm([...form]); } - /** Function used on FormFieldText to set the chosen validation, currently min and max char. */ - async function setValidation(value, index) { - form[index].validation[1] = value; - await testTextValidation(form, index, value.value); + /** Function used on FormFieldText to set the chosen validation type, currently min and max char. */ + async function setValidationType(value, index) { + form[index].validation[1].type = value; + + setForm([...form]); + } + /** Function used on FormFieldText to set the value of the validation*/ + async function setValidationValue(value, index) { + form[index].validation[1].value = value; + await testTextValidation(form, index, value); + setForm([...form]); + } + /** Function used on FormFieldText to remove the validaiton. */ + function removeValidation(index) { + form[index].validation.splice(-1, 1); setForm([...form]); } /** The submit function. It's triggered when the submit button is pressed on the interface. */ @@ -366,7 +375,15 @@ function CreateForm() { error={x.error} validation={x.validation} addValidation={addValidation} - setValidation={setValidation} + setValidationType={setValidationType} + setValidationValue={setValidationValue} + removeValidation={removeValidation} + validationValue={ + x.validation[1] ? x.validation[1].value : null + } + validationType={ + x.validation[1] ? x.validation[1].type : null + } /> ); else if (x.type === "select") @@ -441,6 +458,7 @@ function CreateForm() { id={x.id} error={x.error} validToSend={validToSend} + subformId={x.subformId ? x.subformId : null} /> ); else if (x.type === "title") -- GitLab From 70c1499b80d71cbfbfee90961ec61cb88a0b276c Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 15 Jun 2020 09:24:53 -0300 Subject: [PATCH 35/72] =?UTF-8?q?Resolve=20"Criar=20tela=20inicial=20(list?= =?UTF-8?q?a=20de=20formul=C3=A1rios)"?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package-lock.json | 31 +++- package.json | 2 +- src/App.js | 2 + .../fieldsCreateForm/FormFieldSubform.js | 9 +- src/components/fieldsListForms/CardForm.jsx | 142 ++++++++++++++++++ .../fieldsListForms/DeleteButton.jsx | 72 +++++++++ src/components/fieldsListForms/SearchBar.jsx | 53 +++++++ .../fieldsListForms/ShareButton.jsx | 51 +++++++ src/components/fieldsListForms/Tab.jsx | 113 ++++++++++++++ src/components/footer/footer.js | 22 +-- src/components/footer/footer.js~ | 98 ------------ src/global.css | 8 - src/pages/ListForms.js | 104 +++++++++++++ 13 files changed, 577 insertions(+), 130 deletions(-) create mode 100644 src/components/fieldsListForms/CardForm.jsx create mode 100644 src/components/fieldsListForms/DeleteButton.jsx create mode 100644 src/components/fieldsListForms/SearchBar.jsx create mode 100644 src/components/fieldsListForms/ShareButton.jsx create mode 100644 src/components/fieldsListForms/Tab.jsx delete mode 100644 src/components/footer/footer.js~ create mode 100644 src/pages/ListForms.js diff --git a/package-lock.json b/package-lock.json index 4f2a33b..67494d4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1293,12 +1293,22 @@ }, "dependencies": { "dom-helpers": { - "version": "5.1.3", - "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-5.1.3.tgz", - "integrity": "sha512-nZD1OtwfWGRBWlpANxacBEZrEuLa16o1nh7YopFWeoF68Zt8GGEmzHu6Xv4F3XaFIC+YXtTLrzgqKxFgLEe4jw==", + "version": "5.1.4", + "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-5.1.4.tgz", + "integrity": "sha512-TjMyeVUvNEnOnhzs6uAn9Ya47GmMo3qq7m+Lr/3ON0Rs5kHvb8I+SQYjLUSYn7qhEm0QjW0yrBkvz9yOrwwz1A==", "requires": { - "@babel/runtime": "^7.6.3", + "@babel/runtime": "^7.8.7", "csstype": "^2.6.7" + }, + "dependencies": { + "@babel/runtime": { + "version": "7.9.2", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.9.2.tgz", + "integrity": "sha512-NE2DtOdufG7R5vnfQUTehdTfNycfUANEtCa9PssN9O/xmTzP4E08UI797ixaei6hBEVL9BI/PsdJS5x7mWoB9Q==", + "requires": { + "regenerator-runtime": "^0.13.4" + } + } } }, "hoist-non-react-statics": { @@ -1319,6 +1329,11 @@ "loose-envify": "^1.4.0", "prop-types": "^15.6.2" } + }, + "regenerator-runtime": { + "version": "0.13.5", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", + "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==" } } }, @@ -4097,9 +4112,9 @@ } }, "clsx": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/clsx/-/clsx-1.0.4.tgz", - "integrity": "sha512-1mQ557MIZTrL/140j+JVdRM6e31/OA4vTYxXgqIIZlndyfjHpyawKZia1Im05Vp9BWmImkcNrNtFYQMyFcgJDg==" + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/clsx/-/clsx-1.1.0.tgz", + "integrity": "sha512-3avwM37fSK5oP6M5rQ9CNe99lwxhXDOeSWVPAOYF6OazUTgZCMb0yWlJpmdD74REy1gkEaFiub2ULv4fq9GUhA==" }, "co": { "version": "4.6.0", @@ -15057,4 +15072,4 @@ } } } -} +} \ No newline at end of file diff --git a/package.json b/package.json index 7e622c1..215caa1 100644 --- a/package.json +++ b/package.json @@ -41,4 +41,4 @@ "last 1 safari version" ] } -} +} \ No newline at end of file diff --git a/src/App.js b/src/App.js index a2f07a0..a11c029 100644 --- a/src/App.js +++ b/src/App.js @@ -7,6 +7,7 @@ import Header from "./components/header/header"; import Footer from "./components/footer/footer"; import SignUp from "./pages/SignUp"; import SignIn from "./pages/SignIn"; +import ListForms from "./pages/ListForms"; function App() { return ( @@ -16,6 +17,7 @@ function App() { <Route path="/answer/:id" component={AnswerForm} /> <Route path="/SignUp" component={SignUp} /> <Route path="/SignIn" component={SignIn} /> + <Route path="/list/:id" component={ListForms} /> <Footer /> </HashRouter> ); diff --git a/src/components/fieldsCreateForm/FormFieldSubform.js b/src/components/fieldsCreateForm/FormFieldSubform.js index b99dce2..e04e839 100644 --- a/src/components/fieldsCreateForm/FormFieldSubform.js +++ b/src/components/fieldsCreateForm/FormFieldSubform.js @@ -67,7 +67,6 @@ function SubformSelect(props) { const classes = useStyles(); /** Functions that handle the input changes to save it at the father component. */ const handleChange = (event) => { - console.log(event.target); props.setSubformId(event.target.value, props.idq); }; return ( @@ -96,10 +95,10 @@ function SubformSelect(props) { </MenuItem> )) ) : ( - <MenuItem key={0} value={0} disabled> - {"Você não tem formulários para usar aqui"} - </MenuItem> - )} + <MenuItem key={0} value={0} disabled> + {"Você não tem formulários para usar aqui"} + </MenuItem> + )} </Select> </FormControl> ); diff --git a/src/components/fieldsListForms/CardForm.jsx b/src/components/fieldsListForms/CardForm.jsx new file mode 100644 index 0000000..40fc1f8 --- /dev/null +++ b/src/components/fieldsListForms/CardForm.jsx @@ -0,0 +1,142 @@ +import React, { useState, useEffect } from "react"; +import Divider from "@material-ui/core/Divider"; +import ExpansionPanel from "@material-ui/core/ExpansionPanel"; +import ExpansionPanelSummary from "@material-ui/core/ExpansionPanelSummary"; +import ExpansionPanelDetails from "@material-ui/core/ExpansionPanelDetails"; +import IconButton from "@material-ui/core/IconButton"; +import Tooltip from "@material-ui/core/Tooltip"; +import Typography from "@material-ui/core/Typography"; +import { makeStyles } from "@material-ui/core/styles"; + +// Icons +import MoreVertOutlinedIcon from "@material-ui/icons/MoreVertOutlined"; +import DeleteButton from "./DeleteButton"; +import EditOutlinedIcon from "@material-ui/icons/EditOutlined"; +import ShareButton from "./ShareButton"; +import VisibilityOutlinedIcon from "@material-ui/icons/VisibilityOutlined"; +import QuestionAnswerOutlinedIcon from "@material-ui/icons/QuestionAnswerOutlined"; + +const useStyles = makeStyles(theme => ({ + title: { + fontSize: 20, + flex: 1, + width: 0, + textAlign: "center", + color: "#667079" + }, + + description: { + alignSelf: "center" + }, + + container: { + display: "flex", + flexWrap: "wrap", + justifyContent: "flex-start", + color: "#667079" + }, + + item: { + margin: "5px" + }, + + expPainelD: { + display: "block" + }, + + date: { + fontSize: 16, + textAlign: "center", + color: "#667079" + }, + + create: { + fontSize: 13, + textAlign: "center", + color: "#667079" + }, + + numberOfAnswers: { + fontSize: 18, + textAlign: "left", + margin: "7px" + } +})); + +function CardForm(props) { + const classes = useStyles(); + + const handleAnswer = () => { + //redirecionar para /answer/props.id + }; + + const handleVisualize = () => { + //redirecionar para /visual/props.id + }; + + const handleEdit = () => { + //redirecionar para /edit/props.id + }; + + function handleDelete(value) { + if (value) { + //deletar o form + } + } + + function manageDate(date) { + if (date === "") { + return ""; + } + + let newDate = new Date(date); + let options = { year: "numeric", month: "2-digit", day: "2-digit" }; + return newDate.toLocaleDateString("pt-BR", options); + } + + return ( + <ExpansionPanel> + <ExpansionPanelSummary expandIcon={<MoreVertOutlinedIcon />}> + <Typography className={classes.title}> + {props.title} + <br /> + <div className={classes.create} noWrap> + {props.description} + </div> + <Divider /> + <div className={classes.numberOfAnswers}> + {props.numberOfAnswers} Respostas + </div> + </Typography> + </ExpansionPanelSummary> + <ExpansionPanelDetails className={classes.expPainelD}> + <Typography className={classes.date}> + {props.date ? "Data de modificação: " + manageDate(props.date) : ""} + </Typography> + <Tooltip title="Editar" arrow> + <IconButton onClick={handleEdit}> + <EditOutlinedIcon /> + </IconButton> + </Tooltip> + + <ShareButton id={props.id} /> + + <Tooltip title="Visualizar" arrow> + <IconButton aria-label="visualize" onClick={handleVisualize}> + <VisibilityOutlinedIcon /> + </IconButton> + </Tooltip> + + <Tooltip title="Respostas" arrow> + <IconButton aria-label="delete" onClick={handleAnswer}> + <QuestionAnswerOutlinedIcon /> + </IconButton> + </Tooltip> + + <DeleteButton handleDelete={handleDelete} /> + </ExpansionPanelDetails> + </ExpansionPanel> + ); +} + +export default CardForm; \ No newline at end of file diff --git a/src/components/fieldsListForms/DeleteButton.jsx b/src/components/fieldsListForms/DeleteButton.jsx new file mode 100644 index 0000000..244545b --- /dev/null +++ b/src/components/fieldsListForms/DeleteButton.jsx @@ -0,0 +1,72 @@ +import React from "react"; +import Button from "@material-ui/core/Button"; +import Dialog from "@material-ui/core/Dialog"; +import DeleteOutlineOutlinedIcon from "@material-ui/icons/DeleteOutlineOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import DialogActions from "@material-ui/core/DialogActions"; +import Tooltip from "@material-ui/core/Tooltip"; +import DialogTitle from "@material-ui/core/DialogTitle"; +import { useTheme } from "@material-ui/core/styles"; + +import { makeStyles } from "@material-ui/core/styles"; +const useStyles = makeStyles(theme => ({ + buttonNo: { + color: "red" + }, + buttonYes: { + color: "blue" + } +})); + +function DeleteButton(props) { + const classes = useStyles(); + const [open, setOpen] = React.useState(false); + const theme = useTheme(); + + const handleClickOpen = () => { + setOpen(true); + }; + + const handleCloseFalse = () => { + setOpen(false); + props.handleDelete(false); + }; + + const handleCloseTrue = () => { + setOpen(false); + props.handleDelete(true); + }; + + const handleClose = () => { + setOpen(false); + }; + + return ( + <> + <Tooltip title="Deletar" arrow> + <IconButton aria-label="delete" onClick={handleClickOpen}> + <DeleteOutlineOutlinedIcon /> + </IconButton> + </Tooltip> + <Dialog + open={open} + onClose={handleClose} + aria-labelledby="responsive-dialog-title" + > + <DialogTitle id="responsive-dialog-title"> + {"Tem certeza que deseja deletar este formulário?"} + </DialogTitle> + <DialogActions> + <Button autoFocus onClick={handleCloseFalse} className={classes.buttonYes} color="primary"> + Não deletar + </Button> + <Button onClick={handleCloseTrue} className={classes.buttonNo} autoFocus> + Deletar + </Button> + </DialogActions> + </Dialog> + </> + ); +} + +export default DeleteButton; \ No newline at end of file diff --git a/src/components/fieldsListForms/SearchBar.jsx b/src/components/fieldsListForms/SearchBar.jsx new file mode 100644 index 0000000..a3c03f0 --- /dev/null +++ b/src/components/fieldsListForms/SearchBar.jsx @@ -0,0 +1,53 @@ +import React, { useState, useEffect } from "react"; +import TextField from "@material-ui/core/TextField"; +import Grid from "@material-ui/core/Grid"; +import SearchIcon from "@material-ui/icons/Search"; +import { makeStyles } from "@material-ui/core/styles"; +import InputAdornment from "@material-ui/core/InputAdornment"; + +const useStyles = makeStyles(theme => ({ + container: { + height: "50px", + marginTop: "15px", + marginBottom: "15px", + ["@media (max-width: 446px)"]: { + marginLeft: "60px", + marginBottom: "20px" + }, + ["@media (max-width: 658px)"]: { + marginRight: "20px" + } + }, + Icon: { + height: "30px", + fontSize: "20px" + } +})); + +function SearchBar(props) { + const classes = useStyles(); + + const handleChange = event => { + props.searching(event.target.value); + }; + + return ( + <Grid className={classes.container} container> + <TextField + id="outlined-basic" + label="Busque um formulário" + variant="outlined" + InputProps={{ + startAdornment: ( + <InputAdornment position="start"> + <SearchIcon color="grey" className={classes.Icon} /> + </InputAdornment> + ) + }} + onChange={handleChange} + /> + </Grid> + ); +} + +export default SearchBar; \ No newline at end of file diff --git a/src/components/fieldsListForms/ShareButton.jsx b/src/components/fieldsListForms/ShareButton.jsx new file mode 100644 index 0000000..7ef16fc --- /dev/null +++ b/src/components/fieldsListForms/ShareButton.jsx @@ -0,0 +1,51 @@ +import React from "react"; +import Dialog from "@material-ui/core/Dialog"; +import ShareOutlinedIcon from "@material-ui/icons/ShareOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Tooltip from "@material-ui/core/Tooltip"; +import Grid from "@material-ui/core/Grid"; +import DialogContent from "@material-ui/core/DialogContent"; +import DialogContentText from "@material-ui/core/DialogContentText"; +import DialogTitle from "@material-ui/core/DialogTitle"; +import { useTheme } from "@material-ui/core/styles"; + +function ShareButton(props) { + const [open, setOpen] = React.useState(false); + const theme = useTheme(); + + const handleClickOpen = () => { + setOpen(true); + }; + + const handleClose = () => { + setOpen(false); + }; + + return ( + <> + <Tooltip title="Compartilhar" arrow> + <IconButton onClick={handleClickOpen}> + <ShareOutlinedIcon /> + </IconButton> + </Tooltip> + <Dialog + open={open} + onClose={handleClose} + aria-labelledby="responsive-dialog-title" + > + <DialogTitle id="responsive-dialog-title"> + { + "Aqui está a URL do seu formulário, copie-a e envie-a para ser respondida: " + } + </DialogTitle> + <DialogContent> + <DialogContentText id="alert-dialog-description"> + http://localhost:3000/#/answer/{props.id} + </DialogContentText> + </DialogContent> + </Dialog> + </> + ); +} + +export default ShareButton; \ No newline at end of file diff --git a/src/components/fieldsListForms/Tab.jsx b/src/components/fieldsListForms/Tab.jsx new file mode 100644 index 0000000..721bf7e --- /dev/null +++ b/src/components/fieldsListForms/Tab.jsx @@ -0,0 +1,113 @@ +import React, { useState, useEffect } from "react"; +import Button from "@material-ui/core/Button"; +import FormControl from "@material-ui/core/FormControl"; +import Grid from "@material-ui/core/Grid"; +import InputLabel from "@material-ui/core/InputLabel"; +import MenuItem from "@material-ui/core/MenuItem"; +import Select from "@material-ui/core/Select"; +import FormHelperText from "@material-ui/core/FormHelperText"; +import SearchBar from "./SearchBar.jsx"; + +import { makeStyles } from "@material-ui/core/styles"; +const useStyles = makeStyles(theme => ({ + container: { + flexDirection: "row", + justifyContent: "space-between", + backgroundColor: "white", + marginBottom: "20px" + }, + + formControl: { + margin: theme.spacing(1), + minWidth: 120, + ["@media (max-width: 446px)"]: { + marginLeft: "100px", + marginBottom: "20px" + } + }, + + selectEmpty: { + marginTop: theme.spacing(2) + }, + + button: { + fontSize: 16, + height: "54px", + width: "251px", + backgroundColor: "#6ec46c", + color: "white", + ["@media (max-width: 710px)"]: { + marginBottom: "20px", + marginLeft: "170px", + marginBottom: "20px" + }, + ["@media (max-width: 446px)"]: { + marginLeft: "60px", + marginBottom: "20px" + } + }, + + gridButton: { + display: "flex", + alignItems: "center", + marginRight: "20px", + color: "white" + }, + + gridMenu: { + display: "flex", + alignItems: "center", + marginLeft: "20px" + }, + + searchBar: { + display: "flex", + justifyContent: "center" + } +})); + +function Tab(props) { + const classes = useStyles(); + const [seletectedValue, setseletectedValue] = React.useState(""); + + /** Function to handle event */ + const handleChange = event => { + props.sort(event.target.value); + setseletectedValue(event.target.value); + }; + + return ( + <Grid container className={classes.container}> + <Grid item className={classes.gridMenu}> + <FormControl className={classes.formControl}> + <Select + value={seletectedValue} + onChange={handleChange} + displayEmpty + className={classes.selectEmpty} + inputProps={{ "aria-label": "Without label" }} + > + <MenuItem value=""> + <em>Original</em> + </MenuItem> + <MenuItem value={1}>Alfabética</MenuItem> + <MenuItem value={2}>Mais recente</MenuItem> + <MenuItem value={3}>Relevância</MenuItem> + <MenuItem value={4}>Data de modificação</MenuItem> + </Select> + <FormHelperText>Ordenar</FormHelperText> + </FormControl> + </Grid> + <Grid justify="center" className={classes.searchBar}> + <SearchBar searching={props.searching} /> + </Grid> + <Grid item className={classes.gridButton}> + <Button className={classes.button} variant="contained"> + CRIAR NOVO FORMULÃRIO + </Button> + </Grid> + </Grid> + ); +} + +export default Tab; \ No newline at end of file diff --git a/src/components/footer/footer.js b/src/components/footer/footer.js index 5e01cd8..07c7650 100644 --- a/src/components/footer/footer.js +++ b/src/components/footer/footer.js @@ -4,15 +4,15 @@ import Grid from "@material-ui/core/Grid"; import Typography from "@material-ui/core/Typography"; import Logo from "./c3sl.png"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ footer: { background: "#66a6c2", - position: "relative", + position: "fixed", left: 0, bottom: 0, right: 0, width: "100%", - height: "78px", + height: "78px" }, img: { @@ -24,14 +24,14 @@ const useStyles = makeStyles((theme) => ({ marginRight: "auto", ["@media (min-width: 960px)"]: { marginLeft: "5px", - }, + } }, item: { display: "flex", justifyContent: "space-evenly", flexDirection: "column", - alignItems: "center", + alignItems: "center" }, text: { @@ -40,8 +40,8 @@ const useStyles = makeStyles((theme) => ({ textAlign: "center", left: "50%", ["@media (max-width: 960px)"]: { - display: "none", - }, + display: "none" + } }, adress: { @@ -55,9 +55,9 @@ const useStyles = makeStyles((theme) => ({ fontSize: "12px", textAlign: "right", ["@media (max-width: 960px)"]: { - display: "none", - }, - }, + display: "none" + } + } })); function Footer() { @@ -89,6 +89,8 @@ function Footer() { Telefone: 61 2027-6000 </Typography> </Grid> + + </Grid> ); } diff --git a/src/components/footer/footer.js~ b/src/components/footer/footer.js~ deleted file mode 100644 index 3e2ee4e..0000000 --- a/src/components/footer/footer.js~ +++ /dev/null @@ -1,98 +0,0 @@ -import React from "react"; -import { makeStyles } from "@material-ui/core/styles"; -import Grid from "@material-ui/core/Grid"; -import Typography from "@material-ui/core/Typography"; -import Logo from "./c3sl.png"; - -const useStyles = makeStyles(theme => ({ - footer: { - background: "#66a6c2", - position: "fixed", - left: 0, - bottom: 0, - right: 0, - width: "100%", - height: "78px" - }, - - img: { - width: "50px", - display: "block", - marginTop: "auto", - marginBottom: "auto", - marginLeft: "auto", - marginRight: "auto", - ["@media (min-width: 960px)"]: { - marginLeft: "5px", - } - }, - - item: { - display: "flex", - justifyContent: "space-evenly", - flexDirection: "column", - alignItems: "center" - }, - - text: { - color: "#46525d", - fontSize: "15px", - textAlign: "center", - left: "50%", - ["@media (max-width: 960px)"]: { - display: "none" - } - }, - - adress: { - display: "block", - marginTop: "auto", - marginBottom: "auto", - marginLeft: "auto", - paddingRight: "10px", - - color: "#46525d", - fontSize: "12px", - textAlign: "right", - ["@media (max-width: 960px)"]: { - display: "none" - } - } -})); - -function Footer() { - const classes = useStyles(); - return ( - <Grid container className={classes.footer}> - <Grid item xs={12} sm={12} md={3} lg={2} className={classes.item}> - <img src={Logo} className={classes.img}></img> - </Grid> - - <Grid item md={6} lg={8} className={classes.item}> - <Typography className={classes.text}> - Ministério da - <b> - <br /> - Ciência, Tecnologia, - <br /> - Inovações e Comunicações - </b> - </Typography> - </Grid> - - <Grid item md={3} lg={2} className={classes.item}> - <Typography className={classes.adress}> - Esplanada dos Ministérios, Bloco R - <br /> - CEP: 70044-900 – BrasÃlia-DF - <br /> - Telefone: 61 2027-6000 - </Typography> - </Grid> - - - </Grid> - ); -} - -export default Footer; diff --git a/src/global.css b/src/global.css index 879e608..9570e8b 100644 --- a/src/global.css +++ b/src/global.css @@ -1,13 +1,5 @@ @import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap"); -* { - margin: 0; - padding: 0; - outline: 0; - box-sizing: border-box; - color: #667079; -} - html, body, #root { diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js new file mode 100644 index 0000000..92d90d4 --- /dev/null +++ b/src/pages/ListForms.js @@ -0,0 +1,104 @@ +import React, { useState, useEffect } from "react"; +import api from "../api"; +import { useParams } from "react-router-dom"; +import Grid from "@material-ui/core/Grid"; +import Container from "@material-ui/core/Container"; +import { makeStyles } from "@material-ui/core/styles"; + +// Components +import CardForm from "../components/fieldsListForms/CardForm.jsx"; +import Tab from "../components/fieldsListForms/Tab.jsx"; + +export default function ListForms() { + + // Get the ID from the URL + const { id } = useParams(); + + // Hooks + const [forms, setForms] = React.useState([]); + const [isLoaded, setisLoaded] = React.useState(false); + const [auxForms, setAuxForms] = React.useState([]); + + /** + * Sorting function to sort the forms by some especified type. + * @param type - the type of the sorting that was selected. + */ + function sort(type) { + setAuxForms([]); + if (type === "") { + const tmp = [...forms].sort((a, b) => a.id > b.id); + setAuxForms(tmp); + } else if (type === 1) { + const tmp = [...forms].sort((a, b) => a.title > b.title); + setAuxForms(tmp); + } else if (type === 2) { + const tmp = [...forms].sort((a, b) => a.id < b.id); + setAuxForms(tmp); + } else if (type === 3) { + const tmp = [...forms].sort((a, b) => a.answersNumber < b.answersNumber); + setAuxForms(tmp); + } else if (type === 4) { + let tmp = [...forms].filter(value => { + return value.date; + }).sort((a, b) => a.date > b.date).concat( + [...forms].filter(value => { + return value.date === ""; + }) + ); + setAuxForms(tmp); + } + } + + /** + * Function to search for a form title. + * @param string - the string value to be searched. + */ + function searching(string) { + setAuxForms( + [...forms].filter(value => { + return value.title.includes(string); + }) + ); + } + + /** + * Async function to get all of the forms from an user. + * @param id - the user's id to have the forms listed. + */ + async function fetchData(id) { + const res = await api.get(`/user/list/${id}`).then(function (res) { + setForms(res.data.sort((a, b) => a.id > b.id)); + setAuxForms(res.data.sort((a, b) => a.id > b.id)); + setisLoaded(true); + }); + } + + useEffect(() => { + fetchData(id); + }, []); + + return isLoaded ? ( + <div> + <Tab sort={sort} searching={searching} /> + <Container> + <Grid container spacing={3}> + {auxForms.map(form => ( + <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> + <CardForm + id={form.id} + title={form.title} + description={form.description} + numberOfAnswers={form.answersNumber} + date={form.date} + /> + </Grid> + ))} + </Grid> + </Container> + </div> + ) : ( + <Grid justify="center"> + <p>loading...</p> + </Grid> + ); +} \ No newline at end of file -- GitLab From b7762c472ab487e08c96de6e81bdd9c9979954a6 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 22 Jun 2020 09:08:46 -0300 Subject: [PATCH 36/72] Issue #20: FIX typography no wrapping long strings Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- .../fieldsAnswerForm/FormFieldCheckbox.js | 23 +++++-- .../fieldsAnswerForm/FormFieldRadio.js | 23 +++++-- .../fieldsAnswerForm/FormFieldSelect.js | 19 +++++- .../fieldsAnswerForm/FormFieldText.js | 17 +++++- .../fieldsAnswerForm/FormFieldTitle.js | 60 +++++++++++-------- src/components/fieldsListForms/CardForm.jsx | 4 +- 6 files changed, 105 insertions(+), 41 deletions(-) diff --git a/src/components/fieldsAnswerForm/FormFieldCheckbox.js b/src/components/fieldsAnswerForm/FormFieldCheckbox.js index f658a90..c1e7479 100644 --- a/src/components/fieldsAnswerForm/FormFieldCheckbox.js +++ b/src/components/fieldsAnswerForm/FormFieldCheckbox.js @@ -100,7 +100,11 @@ function FormFieldCheckbox(props) { const options = props.options.map((x, index) => { return ( <span> - <Typography className={classes.text} variant="h7"> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h7" + > {x.value} </Typography> <Checkbox onChange={() => handleArray(index)} /> @@ -117,10 +121,16 @@ function FormFieldCheckbox(props) { <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography className={classes.text} variant="h6"> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > {props.question} </Typography> - <Typography variant="h8">{props.description}</Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> </Grid> <Grid item @@ -133,7 +143,12 @@ function FormFieldCheckbox(props) { > {options} <div> - <Typography className={classes.validation}>{valid}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.validation} + > + {valid} + </Typography> </div> </Grid> </Grid> diff --git a/src/components/fieldsAnswerForm/FormFieldRadio.js b/src/components/fieldsAnswerForm/FormFieldRadio.js index 3b2724e..2398fe7 100644 --- a/src/components/fieldsAnswerForm/FormFieldRadio.js +++ b/src/components/fieldsAnswerForm/FormFieldRadio.js @@ -111,7 +111,11 @@ function FormFieldRadio(props) { const options = props.options.map(function(x, index) { return ( <span> - <Typography className={classes.text} variant="h7"> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h7" + > {x.value} </Typography> <Radio @@ -133,10 +137,16 @@ function FormFieldRadio(props) { <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography className={classes.text} variant="h6"> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > {props.question} </Typography> - <Typography variant="h8">{props.description}</Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> </Grid> <Grid item @@ -149,7 +159,12 @@ function FormFieldRadio(props) { > <RadioGroup> {options} - <Typography className={classes.validation}>{valid}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.validation} + > + {valid} + </Typography> </RadioGroup> </Grid> </Grid> diff --git a/src/components/fieldsAnswerForm/FormFieldSelect.js b/src/components/fieldsAnswerForm/FormFieldSelect.js index d00a1ba..e4845ae 100644 --- a/src/components/fieldsAnswerForm/FormFieldSelect.js +++ b/src/components/fieldsAnswerForm/FormFieldSelect.js @@ -122,10 +122,18 @@ function FormFieldSelect(props) { <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography className={classes.text} variant="h6"> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > {props.question} </Typography> - <Typography variant="h8" gutterBottom> + <Typography + style={{ wordWrap: "break-word" }} + variant="h8" + gutterBottom + > {props.description} </Typography> </Grid> @@ -145,7 +153,12 @@ function FormFieldSelect(props) { > {options} </Select> - <Typography className={classes.validation}>{valid}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.validation} + > + {valid} + </Typography> </Grid> </Grid> </Paper> diff --git a/src/components/fieldsAnswerForm/FormFieldText.js b/src/components/fieldsAnswerForm/FormFieldText.js index 1ad6d0c..97a5315 100644 --- a/src/components/fieldsAnswerForm/FormFieldText.js +++ b/src/components/fieldsAnswerForm/FormFieldText.js @@ -99,10 +99,16 @@ function FormFieldText(props) { <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography className={classes.text} variant="h6"> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > {props.question} </Typography> - <Typography variant="h8">{props.description}</Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> </Grid> <Grid item xs={9} className={classes.questionsGrid}> <TextField @@ -112,7 +118,12 @@ function FormFieldText(props) { placeholder="Resposta" onChange={handleChange} /> - <Typography className={classes.validation}>{valid}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.validation} + > + {valid} + </Typography> </Grid> <Grid item diff --git a/src/components/fieldsAnswerForm/FormFieldTitle.js b/src/components/fieldsAnswerForm/FormFieldTitle.js index 34a2d79..cf2c22e 100644 --- a/src/components/fieldsAnswerForm/FormFieldTitle.js +++ b/src/components/fieldsAnswerForm/FormFieldTitle.js @@ -1,10 +1,10 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import Typography from '@material-ui/core/Typography'; +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from './FieldFooterOptions'; +import FieldFooterOptions from "./FieldFooterOptions"; const useStyles = makeStyles(theme => ({ paper: { @@ -12,7 +12,7 @@ const useStyles = makeStyles(theme => ({ width: theme.spacing(100), height: theme.spacing(22), margin: theme.spacing(2), - color: '#000000', + color: "#000000", ["@media (max-width:827px)"]: { width: theme.spacing(70) }, @@ -21,32 +21,32 @@ const useStyles = makeStyles(theme => ({ } }, questionsGrid: { - marginBottom: '20px', - color: '#000000', + marginBottom: "20px", + color: "#000000", ["@media (max-width:827px)"]: { width: theme.spacing(70) } }, title: { - fontSize: '45px', - color: '#000000', + fontSize: "45px", + color: "#000000", ["@media (max-width:827px)"]: { - fontSize: '35px' + fontSize: "35px" }, ["@media (max-width:590px)"]: { - fontSize: '25px' + fontSize: "25px" } }, description: { - fontSize: '30px', - color: '#000000', + fontSize: "30px", + color: "#000000", ["@media (max-width:827px)"]: { - fontSize: '25px' + fontSize: "25px" }, ["@media (max-width:590px)"]: { - fontSize: '15px' + fontSize: "15px" } - }, + } })); function FormFieldText(props) { @@ -57,27 +57,37 @@ function FormFieldText(props) { <Paper className={classes.paper}> <Grid container> <Grid item xs={12} className={classes.questionsGrid}> - <Typography className={classes.title} variant="h3" gutterBottom> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.title} + variant="h3" + gutterBottom + > {props.title} </Typography> </Grid> <Grid item xs={9} className={classes.questionsGrid}> - <Typography className={classes.description} variant="h4" gutterBottom> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.description} + variant="h4" + gutterBottom + > {props.description} </Typography> </Grid> - <Grid item container + <Grid + item + container direction="row" justify="flex-end" alignItems="flex-end" xs={3} - > - </Grid> + ></Grid> </Grid> </Paper> </Grid> ); - } -export default FormFieldText; \ No newline at end of file +export default FormFieldText; diff --git a/src/components/fieldsListForms/CardForm.jsx b/src/components/fieldsListForms/CardForm.jsx index 40fc1f8..9dca0c0 100644 --- a/src/components/fieldsListForms/CardForm.jsx +++ b/src/components/fieldsListForms/CardForm.jsx @@ -97,7 +97,7 @@ function CardForm(props) { return ( <ExpansionPanel> <ExpansionPanelSummary expandIcon={<MoreVertOutlinedIcon />}> - <Typography className={classes.title}> + <Typography noWrap className={classes.title}> {props.title} <br /> <div className={classes.create} noWrap> @@ -139,4 +139,4 @@ function CardForm(props) { ); } -export default CardForm; \ No newline at end of file +export default CardForm; -- GitLab From 00329478267351fc3cc73b228586ca7135ae12be Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Mon, 22 Jun 2020 13:27:57 -0300 Subject: [PATCH 37/72] Issue #7: Criar tela de editar formularios Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/App.js | 3 +- .../utils/BackendTranslation.js | 105 ---- .../DefaultField.js | 10 +- .../fieldsDisplayForm/DisplayForm.js | 201 +++++++ .../FieldFooterOptions.js | 7 +- .../FormFieldCheckbox.js | 20 +- .../FormFieldRadio.js | 19 +- .../FormFieldSelect.js | 20 +- .../FormFieldSubform.js | 19 +- .../FormFieldText.js | 23 +- .../FormFieldTitle.js | 24 +- .../SideMenu.js | 37 +- .../fieldsDisplayForm/SubmitButton.js | 62 +++ .../utils/BackendTranslation.js | 108 ++++ .../utils/FormComposition.js | 205 +++++++ .../utils/FrontEndTranslation.js | 89 +++ .../utils/schemas.js | 16 +- src/components/fieldsListForms/CardForm.jsx | 4 +- src/components/header/header.jsx | 3 - src/contexts/FormContext.js | 48 ++ src/contexts/useForm.js | 338 ++++++++++++ src/pages/CreateForm.js | 514 +----------------- src/pages/EditForm.js | 11 + src/pages/SignUp.js | 56 +- 24 files changed, 1205 insertions(+), 737 deletions(-) delete mode 100644 src/components/fieldsCreateForm/utils/BackendTranslation.js rename src/components/{fieldsCreateForm => fieldsDisplayForm}/DefaultField.js (73%) create mode 100644 src/components/fieldsDisplayForm/DisplayForm.js rename src/components/{fieldsCreateForm => fieldsDisplayForm}/FieldFooterOptions.js (82%) rename src/components/{fieldsCreateForm => fieldsDisplayForm}/FormFieldCheckbox.js (90%) rename src/components/{fieldsCreateForm => fieldsDisplayForm}/FormFieldRadio.js (90%) rename src/components/{fieldsCreateForm => fieldsDisplayForm}/FormFieldSelect.js (88%) rename src/components/{fieldsCreateForm => fieldsDisplayForm}/FormFieldSubform.js (90%) rename src/components/{fieldsCreateForm => fieldsDisplayForm}/FormFieldText.js (91%) rename src/components/{fieldsCreateForm => fieldsDisplayForm}/FormFieldTitle.js (74%) rename src/components/{fieldsCreateForm => fieldsDisplayForm}/SideMenu.js (84%) create mode 100644 src/components/fieldsDisplayForm/SubmitButton.js create mode 100644 src/components/fieldsDisplayForm/utils/BackendTranslation.js create mode 100644 src/components/fieldsDisplayForm/utils/FormComposition.js create mode 100644 src/components/fieldsDisplayForm/utils/FrontEndTranslation.js rename src/components/{fieldsCreateForm => fieldsDisplayForm}/utils/schemas.js (93%) create mode 100644 src/contexts/FormContext.js create mode 100644 src/contexts/useForm.js create mode 100644 src/pages/EditForm.js diff --git a/src/App.js b/src/App.js index a11c029..f909603 100644 --- a/src/App.js +++ b/src/App.js @@ -8,13 +8,14 @@ import Footer from "./components/footer/footer"; import SignUp from "./pages/SignUp"; import SignIn from "./pages/SignIn"; import ListForms from "./pages/ListForms"; - +import EditForm from "./pages/EditForm"; function App() { return ( <HashRouter> <Header /> <Route path="/create" component={CreateForm} /> <Route path="/answer/:id" component={AnswerForm} /> + <Route path="/edit/:id" component={EditForm} /> <Route path="/SignUp" component={SignUp} /> <Route path="/SignIn" component={SignIn} /> <Route path="/list/:id" component={ListForms} /> diff --git a/src/components/fieldsCreateForm/utils/BackendTranslation.js b/src/components/fieldsCreateForm/utils/BackendTranslation.js deleted file mode 100644 index 698eee3..0000000 --- a/src/components/fieldsCreateForm/utils/BackendTranslation.js +++ /dev/null @@ -1,105 +0,0 @@ -/** Functions that create the json object to be sent to the backend. */ - -/** Function that pushes the 'translated' object into the new array, wich will be sent to the backend. */ -function setInput(form, index, json, sugestions, validation, subForm, type) { - //the case when the input has a subform -> backend requires it to be different - if (subForm) { - json.inputs.push({ - placement: index, - description: form.description, - question: form.question, - type: type, - validation: validation, - sugestions: sugestions, - subForm: subForm, - }); - } else { - json.inputs.push({ - placement: index, - description: form.description, - question: form.question, - type: type, - validation: validation, - sugestions: sugestions, - }); - } -} - -/** Returns the type of the question as the backend padronization. */ -function getType(stringified_type) { - switch (stringified_type) { - case "question": - return 0; - case "select": - return 3; - case "radio": - return 2; - case "checkbox": - return 1; - case "subForm": - return 4; - default: - return -1; - } -} -/** Translates the 'options' array to the backend padronization. */ -function setSugestions(sugestions) { - let tmp = []; - if (!sugestions) return tmp; - sugestions.forEach((value, index) => { - tmp.push({ - value: value, - placement: index, - }); - }); - return tmp; -} - -/** Sets the validation field to be sent to the backend. */ -function setValidation(form) { - if (!form.validation[0].value) return []; - let val = []; - if (form.type === "checkbox") - val.push({ - type: 6, - arguments: [], - }); - else if (form.type === "question" && form.validation.length > 1) { - val.push({ - type: form.validation[1].type, - arguments: [form.validation[1].value], - }); - } else - val.push({ - type: 2, - arguments: [], - }); - return val; -} -/** Set the subform as the backend padronization. */ -function setSubform(form, idq) { - if (form.type !== "subForm") return null; - return { - contentFormId: form.subformId, - }; -} -/** The function that triggers the 'translation' */ -export default function createForm(form) { - let json = { - title: form[0].title, - description: form[0].description, - inputs: [], - }; - for (var i = 1; i < form.length; i++) { - setInput( - form[i], - i, - json, - setSugestions(form[i].options), - setValidation(form[i]), - setSubform(form[i], i), - getType(form[i].type) - ); - } - return json; -} diff --git a/src/components/fieldsCreateForm/DefaultField.js b/src/components/fieldsDisplayForm/DefaultField.js similarity index 73% rename from src/components/fieldsCreateForm/DefaultField.js rename to src/components/fieldsDisplayForm/DefaultField.js index 258abf4..5c2c127 100644 --- a/src/components/fieldsCreateForm/DefaultField.js +++ b/src/components/fieldsDisplayForm/DefaultField.js @@ -2,6 +2,7 @@ import React from "react"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import TextField from "@material-ui/core/TextField"; +import useForm from "../../contexts/useForm"; const useStyles = makeStyles((theme) => ({ questionsGrid: { marginBottom: "20px", @@ -16,9 +17,12 @@ const useStyles = makeStyles((theme) => ({ width: "80%", }, })); - +/** Function that returns the question and description components. */ export default function DefaultField(props) { + /** Style class. */ const classes = useStyles(); + /** Importing functions to set question and description fields values. */ + const { setQuestionField, setDescriptionField } = useForm(); return ( <> <Grid item xs={12} sm={6} className={classes.questionsGrid}> @@ -26,7 +30,7 @@ export default function DefaultField(props) { value={props.question} label="Pergunta" className={classes.textFieldStyle} - onChange={(e) => props.setQuestionField(e.target.value, props.idq)} + onChange={(e) => setQuestionField(e.target.value, props.idq)} /> <Grid className={classes.errorGrid}> {props.error.errorMsg.question} @@ -37,7 +41,7 @@ export default function DefaultField(props) { value={props.description} label="Descrição" className={classes.textFieldStyle} - onChange={(e) => props.setDescriptionField(e.target.value, props.idq)} + onChange={(e) => setDescriptionField(e.target.value, props.idq)} /> <Grid className={classes.errorGrid}> {props.error.errorMsg.description} diff --git a/src/components/fieldsDisplayForm/DisplayForm.js b/src/components/fieldsDisplayForm/DisplayForm.js new file mode 100644 index 0000000..6591e03 --- /dev/null +++ b/src/components/fieldsDisplayForm/DisplayForm.js @@ -0,0 +1,201 @@ +import React, { useState, useEffect, useContext } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import { DragDropContext, Droppable } from "react-beautiful-dnd"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import FormFieldText from "./FormFieldText"; +import FormFieldSelect from "./FormFieldSelect"; +import FormFieldRadio from "./FormFieldRadio"; +import FormFieldCheckbox from "./FormFieldCheckbox"; +import FormFieldTitle from "./FormFieldTitle"; +import FormFieldSubForm from "./FormFieldSubform"; +import uuid from "uuid/v4"; +import { verifyError } from "./utils/schemas"; +import SideMenu from "./SideMenu"; + +import { FormEditionContext } from "../../contexts/FormContext"; +import useForm from "../../contexts/useForm"; +import SubmitButton from "./SubmitButton"; +/** CSS styles used on page components */ +const useStyles = makeStyles((theme) => ({ + app: { + margin: "0", + padding: "40px", + display: "flex", + ["@media (max-width: 600px)"]: { + flexDirection: "column-reverse", + justifyContent: "flex-end", + }, + paddingBottom: "78px", + ["@media (min-width: 600px)"]: { + minHeight: "calc(100vh - 92.4px - 78px -60px)", + }, + minHeight: "calc(100vh - 71.6px - 78px -60px)", + marginBottom: "60px", + }, + addButton: { + fontSize: "100%", + }, + sideMenuFormatingGrid: { + ["@media (max-width:600px)"]: { + marginTop: "-90px", + }, + }, +})); +/** CSS style used through Material Ui. */ +const theme = createMuiTheme({ + overrides: { + MuiInput: { + underline: { + "&:before": { + borderBottom: "1px solid #35c7fc", + }, + "&:after": { + borderBottom: "1px solid #3f51b5", + }, + }, + }, + MuiButton: { + label: { + color: "white", + }, + }, + }, +}); +/** Main function that returns the children that composes the form creation or edition page. */ +function DisplayForm() { + /** Importing and using form state from the context */ + const { formState } = useContext(FormEditionContext); + const [form] = formState; + /** Style class. */ + const classes = useStyles(); + /** Importing the function to reorder the questions as consequence of drag'n'drop event */ + const { onDragEnd } = useForm(); + /** An unique string to be used as ID for drag and drop function. */ + const columnId = uuid(); + /** Error state. */ + const [validToSend, setValidToSend] = useState(); + + /** Error handling -> every time the form object is updated, it is verified to evaluate it's error messages, + * so the submit button can be enabled or disabled. + */ + useEffect(() => { + setValidToSend(verifyError(form)); + }, [form]); + return ( + <MuiThemeProvider theme={theme}> + <Grid className={classes.app}> + <Grid xs={12} sm={2} className={classes.sideMenuFormatingGrid}> + <SideMenu /> + </Grid> + <DragDropContext onDragEnd={onDragEnd}> + <Grid + dragOver + container + xs={12} + sm={8} + direction="column" + alignItems="center" + > + <Droppable droppableId={columnId}> + {(provided, snapshot) => { + return ( + <Grid {...provided.droppableProps} ref={provided.innerRef}> + {form ? ( + form.map((x, index) => { + if (x.type === 0) + return ( + <FormFieldText + question={x.question} + idq={index} + description={x.description} + id={x.id} + error={x.error} + validation={x.validation} + validationValue={ + x.validation[1] ? x.validation[1].value : null + } + validationType={ + x.validation[1] ? x.validation[1].type : null + } + /> + ); + else if (x.type === 3) + return ( + <FormFieldSelect + question={x.question} + options={x.options} + idq={index} + description={x.description} + validation={x.validation} + id={x.id} + error={x.error} + /> + ); + else if (x.type === 2) + return ( + <FormFieldRadio + question={x.question} + options={x.options} + idq={index} + description={x.description} + validation={x.validation} + id={x.id} + error={x.error} + /> + ); + else if (x.type === 1) + return ( + <FormFieldCheckbox + question={x.question} + options={x.options} + idq={index} + description={x.description} + validation={x.validation} + id={x.id} + error={x.error} + /> + ); + else if (x.type === 4) + return ( + <FormFieldSubForm + question={x.question} + idq={index} + description={x.description} + validation={x.validation} + id={x.id} + error={x.error} + validToSend={validToSend} + subformId={x.subformId ? x.subformId : null} + /> + ); + else if (x.type === "title") + return ( + <FormFieldTitle + question={x.question} + description={x.description} + idq={index} + error={x.error} + /> + ); + }) + ) : ( + <p> carregando... </p> + )} + {provided.placeholder} + </Grid> + ); + }} + </Droppable> + <SubmitButton + validToSend={validToSend} + formId={form ? (form[0] ? form[0].id : false) : false} + /> + </Grid> + </DragDropContext> + </Grid> + </MuiThemeProvider> + ); +} + +export default DisplayForm; diff --git a/src/components/fieldsCreateForm/FieldFooterOptions.js b/src/components/fieldsDisplayForm/FieldFooterOptions.js similarity index 82% rename from src/components/fieldsCreateForm/FieldFooterOptions.js rename to src/components/fieldsDisplayForm/FieldFooterOptions.js index 8890267..b7a8b91 100644 --- a/src/components/fieldsCreateForm/FieldFooterOptions.js +++ b/src/components/fieldsDisplayForm/FieldFooterOptions.js @@ -6,9 +6,12 @@ import IconButton from "@material-ui/core/IconButton"; import Switch from "@material-ui/core/Switch"; import FormControlLabel from "@material-ui/core/FormControlLabel"; import Tooltip from "@material-ui/core/Tooltip"; +import useForm from "../../contexts/useForm"; /** Main function that return the component's 'footer' options, handling the required validation and deleting the field as necessary. */ function FieldFooterOptions(props) { + /** Importing functions to set a question as required and to delete the question. */ + const { setRequiredField, deleteFromForm } = useForm(); return ( <Grid> <FormControlLabel @@ -18,7 +21,7 @@ function FieldFooterOptions(props) { aria-label="Marcar como obrigatório" > <Switch - onChange={(e) => props.setRequiredField(props.idq)} + onChange={(e) => setRequiredField(props.idq)} value="required" color="primary" checked={props.required} @@ -32,7 +35,7 @@ function FieldFooterOptions(props) { <IconButton aria-label="Remover a pergunta" onClick={() => { - props.deleteFromForm(props.idq); + deleteFromForm(props.idq); }} > <DeleteOutlinedIcon /> diff --git a/src/components/fieldsCreateForm/FormFieldCheckbox.js b/src/components/fieldsDisplayForm/FormFieldCheckbox.js similarity index 90% rename from src/components/fieldsCreateForm/FormFieldCheckbox.js rename to src/components/fieldsDisplayForm/FormFieldCheckbox.js index fc8d1ba..a35fe25 100644 --- a/src/components/fieldsCreateForm/FormFieldCheckbox.js +++ b/src/components/fieldsDisplayForm/FormFieldCheckbox.js @@ -11,6 +11,7 @@ import Tooltip from "@material-ui/core/Tooltip"; import FieldFooterOptions from "./FieldFooterOptions"; import { Draggable } from "react-beautiful-dnd"; import DefaultField from "./DefaultField"; +import useForm from "../../contexts/useForm"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -46,7 +47,10 @@ const useStyles = makeStyles((theme) => ({ })); /** Main function that returns the 'checkbox' field. */ function FormFieldCheckbox(props) { + /** Style class. */ const classes = useStyles(); + /** Importing functions to add, remove and set Options and its value. */ + const { setSelectOption, removeSelectOption, addSelectOption } = useForm(); return ( <Draggable key={props.id} draggableId={props.id} index={props.idq}> @@ -63,8 +67,6 @@ function FormFieldCheckbox(props) { question={props.question} description={props.description} idq={props.idq} - setQuestionField={props.setQuestionField} - setDescriptionField={props.setDescriptionField} error={props.error} /> <Grid @@ -100,11 +102,7 @@ function FormFieldCheckbox(props) { value={x} className={classes.textFieldStyle} onChange={(e) => - props.setSelectOption( - e.target.value, - props.idq, - index - ) + setSelectOption(e.target.value, props.idq, index) } /> <Grid @@ -123,7 +121,7 @@ function FormFieldCheckbox(props) { <IconButton aria-label="remove option" onClick={() => { - props.removeSelectOption(props.idq, index); + removeSelectOption(props.idq, index); }} > <CloseIcon /> @@ -141,7 +139,7 @@ function FormFieldCheckbox(props) { direction="column" justify="flex-start" alignItems="flex-start" - sm={4} //antes era 3 + sm={4} xs={12} > {props.error.errorMsg.optionsNumber} @@ -160,7 +158,7 @@ function FormFieldCheckbox(props) { <IconButton aria-label="add option" onClick={() => { - props.addSelectOption(props.idq); + addSelectOption(props.idq); }} > <AddCircleIcon /> @@ -177,9 +175,7 @@ function FormFieldCheckbox(props) { xs={12} > <FieldFooterOptions - deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.validation[0].value} /> </Grid> diff --git a/src/components/fieldsCreateForm/FormFieldRadio.js b/src/components/fieldsDisplayForm/FormFieldRadio.js similarity index 90% rename from src/components/fieldsCreateForm/FormFieldRadio.js rename to src/components/fieldsDisplayForm/FormFieldRadio.js index 9518569..9abb836 100644 --- a/src/components/fieldsCreateForm/FormFieldRadio.js +++ b/src/components/fieldsDisplayForm/FormFieldRadio.js @@ -11,6 +11,7 @@ import Tooltip from "@material-ui/core/Tooltip"; import { Draggable } from "react-beautiful-dnd"; import FieldFooterOptions from "./FieldFooterOptions"; import DefaultField from "./DefaultField"; +import useForm from "../../contexts/useForm"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -46,8 +47,10 @@ const useStyles = makeStyles((theme) => ({ })); /** Main function that returns the 'radio' field. */ function FormFieldRadio(props) { + /** Style clas. */ const classes = useStyles(); - + /** Importing functions to add, remove and set Options and its value. */ + const { setSelectOption, removeSelectOption, addSelectOption } = useForm(); return ( <Draggable key={props.id} draggableId={props.id} index={props.idq}> {(provided, snapshot) => { @@ -63,8 +66,6 @@ function FormFieldRadio(props) { question={props.question} description={props.description} idq={props.idq} - setQuestionField={props.setQuestionField} - setDescriptionField={props.setDescriptionField} error={props.error} /> <Grid @@ -100,11 +101,7 @@ function FormFieldRadio(props) { value={x} className={classes.textFieldStyle} onChange={(e) => - props.setSelectOption( - e.target.value, - props.idq, - index - ) + setSelectOption(e.target.value, props.idq, index) } /> <Grid @@ -122,7 +119,7 @@ function FormFieldRadio(props) { > <IconButton onClick={() => { - props.removeSelectOption(props.idq, index); + removeSelectOption(props.idq, index); }} > <CloseIcon /> @@ -159,7 +156,7 @@ function FormFieldRadio(props) { <IconButton aria-label="adicionar opção" onClick={() => { - props.addSelectOption(props.idq); + addSelectOption(props.idq); }} > <AddCircleIcon /> @@ -176,9 +173,7 @@ function FormFieldRadio(props) { sm={6} > <FieldFooterOptions - deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.validation[0].value} /> </Grid> diff --git a/src/components/fieldsCreateForm/FormFieldSelect.js b/src/components/fieldsDisplayForm/FormFieldSelect.js similarity index 88% rename from src/components/fieldsCreateForm/FormFieldSelect.js rename to src/components/fieldsDisplayForm/FormFieldSelect.js index 7555ef5..1ae1057 100644 --- a/src/components/fieldsCreateForm/FormFieldSelect.js +++ b/src/components/fieldsDisplayForm/FormFieldSelect.js @@ -10,6 +10,7 @@ import Tooltip from "@material-ui/core/Tooltip"; import FieldFooterOptions from "./FieldFooterOptions"; import { Draggable } from "react-beautiful-dnd"; import DefaultField from "./DefaultField"; +import useForm from "../../contexts/useForm"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -50,6 +51,8 @@ const useStyles = makeStyles((theme) => ({ function FormFieldSelect(props) { /** Style class. */ const classes = useStyles(); + /** Importing functions to add, remove and set Options and its value. */ + const { setSelectOption, removeSelectOption, addSelectOption } = useForm(); return ( <Draggable key={props.id} draggableId={props.id} index={props.idq}> {(provided, snapshot) => { @@ -65,8 +68,6 @@ function FormFieldSelect(props) { question={props.question} description={props.description} idq={props.idq} - setQuestionField={props.setQuestionField} - setDescriptionField={props.setDescriptionField} error={props.error} /> <Grid @@ -82,25 +83,20 @@ function FormFieldSelect(props) { {props.options.map((x, index) => { return ( <Grid container> - <Grid itemxs={1}></Grid> <Grid item xs={10}> <TextField label={"Opção " + index} value={x} className={classes.textFieldStyle} onChange={(e) => - props.setSelectOption( - e.target.value, - props.idq, - index - ) + setSelectOption(e.target.value, props.idq, index) } /> <Grid item className={classes.errorGridOpts}> {props.error.errorMsg.options[index]} </Grid> </Grid> - <Grid item xs={1}> + <Grid item xs={2}> <Tooltip title="Remover a opção" aria-label="Remover a opção" @@ -108,7 +104,7 @@ function FormFieldSelect(props) { <IconButton aria-label="remove option" onClick={() => { - props.removeSelectOption(props.idq, index); + removeSelectOption(props.idq, index); }} > <CloseIcon /> @@ -145,7 +141,7 @@ function FormFieldSelect(props) { <IconButton aria-label="add option" onClick={() => { - props.addSelectOption(props.idq); + addSelectOption(props.idq); }} > <AddCircleIcon /> @@ -162,9 +158,7 @@ function FormFieldSelect(props) { xs={12} > <FieldFooterOptions - deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.validation[0].value} /> </Grid> diff --git a/src/components/fieldsCreateForm/FormFieldSubform.js b/src/components/fieldsDisplayForm/FormFieldSubform.js similarity index 90% rename from src/components/fieldsCreateForm/FormFieldSubform.js rename to src/components/fieldsDisplayForm/FormFieldSubform.js index e04e839..08d4201 100644 --- a/src/components/fieldsCreateForm/FormFieldSubform.js +++ b/src/components/fieldsDisplayForm/FormFieldSubform.js @@ -10,6 +10,7 @@ import FormControl from "@material-ui/core/FormControl"; import InputLabel from "@material-ui/core/InputLabel"; import { Draggable } from "react-beautiful-dnd"; import DefaultField from "./DefaultField"; +import useForm from "../../contexts/useForm"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -65,14 +66,15 @@ const useStyles = makeStyles((theme) => ({ function SubformSelect(props) { /** Style class. */ const classes = useStyles(); + /** Importing function to save the chosen form id as a subform. */ + const { setSubformId } = useForm(); /** Functions that handle the input changes to save it at the father component. */ const handleChange = (event) => { - props.setSubformId(event.target.value, props.idq); + setSubformId(event.target.value, props.idq); }; return ( <FormControl variant="outlined" className={classes.subformSelect}> <InputLabel - // style={{ fontSize: "5px" }} className={classes.subformSelect} id="demo-simple-select-outlined-label" htmlFor="outlined-subform-simple" @@ -95,10 +97,10 @@ function SubformSelect(props) { </MenuItem> )) ) : ( - <MenuItem key={0} value={0} disabled> - {"Você não tem formulários para usar aqui"} - </MenuItem> - )} + <MenuItem key={0} value={0} disabled> + {"Você não tem formulários para usar aqui"} + </MenuItem> + )} </Select> </FormControl> ); @@ -137,8 +139,6 @@ export default function FormFieldSubform(props) { question={props.question} description={props.description} idq={props.idq} - setQuestionField={props.setQuestionField} - setDescriptionField={props.setDescriptionField} error={props.error} /> </Grid> @@ -150,7 +150,6 @@ export default function FormFieldSubform(props) { idq={props.idq} error={props.error} subformId={props.subformId} - subformId={props.subformId} /> </Grid> <Grid item sm={2} xs={12} className={classes.errorGridSubform}> @@ -167,9 +166,7 @@ export default function FormFieldSubform(props) { className={classes.footerOptsAdjustment} > <FieldFooterOptions - deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.validation[0].value} /> </Grid> diff --git a/src/components/fieldsCreateForm/FormFieldText.js b/src/components/fieldsDisplayForm/FormFieldText.js similarity index 91% rename from src/components/fieldsCreateForm/FormFieldText.js rename to src/components/fieldsDisplayForm/FormFieldText.js index 18b4750..595841d 100644 --- a/src/components/fieldsCreateForm/FormFieldText.js +++ b/src/components/fieldsDisplayForm/FormFieldText.js @@ -14,6 +14,7 @@ import { Draggable } from "react-beautiful-dnd"; import FieldFooterOptions from "./FieldFooterOptions"; import DefaultField from "./DefaultField"; import CloseIcon from "@material-ui/icons/Close"; +import useForm from "../../contexts/useForm"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -60,7 +61,13 @@ function FormFieldText(props) { { type: 3, name: "MÃnimo de caracteres", value: "" }, { type: 4, name: "Máximo de caracteres", value: "" }, ]; - + /** Importing functions to add, remove and set validations and it's properties. */ + const { + setValidationType, + setValidationValue, + removeValidation, + addValidation, + } = useForm(); return ( <Draggable key={props.id} draggableId={props.id} index={props.idq}> {(provided, snapshot) => { @@ -76,8 +83,6 @@ function FormFieldText(props) { question={props.question} description={props.description} idq={props.idq} - setQuestionField={props.setQuestionField} - setDescriptionField={props.setDescriptionField} error={props.error} /> <Grid item xs={12} sm={8} className={classes.questionsGrid}> @@ -98,9 +103,7 @@ function FormFieldText(props) { sm={4} > <FieldFooterOptions - deleteFromForm={props.deleteFromForm} idq={props.idq} - setRequiredField={props.setRequiredField} required={props.validation[0].value} /> </Grid> @@ -119,7 +122,7 @@ function FormFieldText(props) { labelId="demo-simple-select-outlined-label" id="demo-simple-select-outlined" onChange={(event) => - props.setValidationType(event.target.value, props.idq) + setValidationType(event.target.value, props.idq) } value={props.validationType} label="Selecione uma validação" @@ -140,11 +143,11 @@ function FormFieldText(props) { label="Quantidade" value={props.validationValue} onChange={(event) => - props.setValidationValue(event.target.value, props.idq) + setValidationValue(event.target.value, props.idq) } /> <Grid className={classes.errorGrid}> - {props.error.errorMsg.validation.value} + {props.error.errorMsg.validationValue} </Grid> </Grid> ) : null} @@ -156,7 +159,7 @@ function FormFieldText(props) { <IconButton aria-label="remove validation" onClick={() => { - props.removeValidation(props.idq); + removeValidation(props.idq); }} > <CloseIcon /> @@ -179,7 +182,7 @@ function FormFieldText(props) { <IconButton aria-label="adicionar opção" onClick={() => { - props.addValidation(props.idq); + addValidation(props.idq); }} > <AddCircleIcon /> diff --git a/src/components/fieldsCreateForm/FormFieldTitle.js b/src/components/fieldsDisplayForm/FormFieldTitle.js similarity index 74% rename from src/components/fieldsCreateForm/FormFieldTitle.js rename to src/components/fieldsDisplayForm/FormFieldTitle.js index 2042a9c..ca1b0c0 100644 --- a/src/components/fieldsCreateForm/FormFieldTitle.js +++ b/src/components/fieldsDisplayForm/FormFieldTitle.js @@ -3,6 +3,7 @@ import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; import TextField from "@material-ui/core/TextField"; +import useForm from "../../contexts/useForm"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -40,34 +41,43 @@ const useStyles = makeStyles((theme) => ({ function FormFieldText(props) { /** Style class. */ const classes = useStyles(); - + /** Importing functions to change the question and the description values. */ + const { setQuestionField, setDescriptionField } = useForm(); return ( <Paper className={classes.paper}> <TextField value={props.question} label="TÃtulo do formulário" fullWidth - onChange={(e) => props.setTitleField(e.target.value, props.idq)} + onChange={(e) => setQuestionField(e.target.value, props.idq)} InputProps={{ classes: { input: classes.title, }, }} /> - <Grid className={classes.errorGrid}>{props.error.errorMsg.question}</Grid> + {props.error ? ( + <Grid className={classes.errorGrid}> + {props.error.errorMsg.question} + </Grid> + ) : null} + <Grid item xs={9} className={classes.questionsGrid}> <TextField + value={props.description} label="Descrição do formulário" - onChange={(e) => props.setDescriptionField(e.target.value, props.idq)} + onChange={(e) => setDescriptionField(e.target.value, props.idq)} InputProps={{ classes: { input: classes.description, }, }} /> - <Grid className={classes.errorGrid}> - {props.error.errorMsg.description} - </Grid> + {props.error ? ( + <Grid className={classes.errorGrid}> + {props.error.errorMsg.description} + </Grid> + ) : null} </Grid> <Grid item diff --git a/src/components/fieldsCreateForm/SideMenu.js b/src/components/fieldsDisplayForm/SideMenu.js similarity index 84% rename from src/components/fieldsCreateForm/SideMenu.js rename to src/components/fieldsDisplayForm/SideMenu.js index fb51492..1c5764c 100644 --- a/src/components/fieldsCreateForm/SideMenu.js +++ b/src/components/fieldsDisplayForm/SideMenu.js @@ -1,7 +1,5 @@ import React, { useState } from "react"; import Paper from "@material-ui/core/Paper"; -import TextField from "@material-ui/core/TextField"; -import AddIcon from "@material-ui/icons/Add"; import IconButton from "@material-ui/core/IconButton"; import ReorderIcon from "@material-ui/icons/Reorder"; import RadioButtonCheckedIcon from "@material-ui/icons/RadioButtonChecked"; @@ -10,14 +8,13 @@ import Grid from "@material-ui/core/Grid"; import { makeStyles } from "@material-ui/core"; import ListAltIcon from "@material-ui/icons/ListAlt"; import TextFieldsIcon from "@material-ui/icons/TextFields"; +import useForm from "../../contexts/useForm"; const useStyles = makeStyles((theme) => ({ addButton: { fontSize: "100%", }, outerGrid: { - // alignItems: "flex-start", - flexDirection: "column", ["@media(max-width: 600px)"]: { flexDirection: "row", @@ -40,7 +37,6 @@ const useStyles = makeStyles((theme) => ({ }, }, justifyContent: "flex-start", - // minWidth: "160.167px", }, newQuestionGrid: { marginTop: "5%", @@ -49,7 +45,6 @@ const useStyles = makeStyles((theme) => ({ display: "flex", flexDirection: "row", maxWidth: "190px", - // minWidth: "160.167px", height: "268.5", }, flex: {}, @@ -59,8 +54,14 @@ const useStyles = makeStyles((theme) => ({ }, }, })); -// fazer com que desca comforme a rolagem da página function SideMenu(props) { + const { + addToFormQuestion, + addToFormSelect, + addToFormRadio, + addToFormCheckbox, + addToFormSubform, + } = useForm(); const classes = useStyles(); return ( <Paper className={classes.paper}> @@ -68,13 +69,14 @@ function SideMenu(props) { <Grid className={classes.newQuestionGrid} container justify="center"> <h4>Adicionar pergunta:</h4> </Grid> - {/* <Grid> */} <IconButton aria-label="add select" type="submit" size="medium" className={classes.addButton} - onClick={props.addToFormQuestion} + onClick={() => { + addToFormQuestion(); + }} > <TextFieldsIcon /> Caixa de texto @@ -84,7 +86,9 @@ function SideMenu(props) { type="submit" size="medium" className={classes.addButton} - onClick={props.addToFormSelect} + onClick={() => { + addToFormSelect(); + }} > <ReorderIcon /> Lista Suspensa @@ -94,7 +98,9 @@ function SideMenu(props) { type="submit" size="medium" className={classes.addButton} - onClick={props.addToFormRadio} + onClick={() => { + addToFormRadio(); + }} > <RadioButtonCheckedIcon /> Múltipla escolha @@ -104,7 +110,9 @@ function SideMenu(props) { type="submit" size="medium" className={classes.addButton} - onClick={props.addToFormCheckbox} + onClick={() => { + addToFormCheckbox(); + }} > <CheckBoxOutlineBlankIcon /> Seleção Única @@ -114,13 +122,14 @@ function SideMenu(props) { type="submit" size="medium" className={classes.addButton} - onClick={props.addToFormSubForm} + onClick={() => { + addToFormSubform(); + }} > <ListAltIcon /> Subformulário </IconButton> </Grid> - {/* </Grid> */} </Paper> ); } diff --git a/src/components/fieldsDisplayForm/SubmitButton.js b/src/components/fieldsDisplayForm/SubmitButton.js new file mode 100644 index 0000000..528737a --- /dev/null +++ b/src/components/fieldsDisplayForm/SubmitButton.js @@ -0,0 +1,62 @@ +import React from "react"; +import Tooltip from "@material-ui/core/Tooltip"; +import Button from "@material-ui/core/Button"; +import useForm from "../../contexts/useForm"; +import { makeStyles } from "@material-ui/core"; + +const useStyles = makeStyles((theme) => ({ + buttonOk: { + minWidth: "92px", + backgroundColor: "#6ec46c", + "&:hover": { + backgroundColor: "rgb(25, 109, 23)", + }, + width: "20%", + ["@media (max-width:600px)"]: { + marginTop: "52px", + }, + }, + button: { + minWidth: "92px", + ["@media (max-width:600px)"]: { + marginTop: "52px", + }, + }, +})); +/** Main function that returns the button to submit the form, it may vary between a form creation and edition. + * @param formId - if an id is passed, then it's the edition operation that's being done. + */ +export default function SubmitButton({ validToSend, formId }) { + /** Importing the submit function. */ + const { submit } = useForm(); + /** Style class. */ + const classes = useStyles(); + /** Handling the variables between the creation and the edition screens */ + let submitMsg, + unabledMsg = + "Verifique se você criou pelo menos uma pergunta e se as perguntas estão propriamente construÃdas", + buttonLabel; + if (formId) { + submitMsg = "Submeter edição"; + buttonLabel = "Confirmar"; + } else { + submitMsg = "Criar seu formulário"; + buttonLabel = "Criar"; + } + + return ( + <Tooltip + title={validToSend ? submitMsg : unabledMsg} + aria-label={validToSend ? submitMsg : unabledMsg} + > + <Button + className={validToSend ? classes.buttonOk : classes.button} + variant="contained" + type="submit" + onClick={() => submit(validToSend)} + > + {buttonLabel} + </Button> + </Tooltip> + ); +} diff --git a/src/components/fieldsDisplayForm/utils/BackendTranslation.js b/src/components/fieldsDisplayForm/utils/BackendTranslation.js new file mode 100644 index 0000000..06687d9 --- /dev/null +++ b/src/components/fieldsDisplayForm/utils/BackendTranslation.js @@ -0,0 +1,108 @@ +/** Functions that create the json object to be sent to the backend. */ +import api from "../../../api"; +import { createFrontendForm } from "./FrontEndTranslation"; +/** Function that pushes the 'translated' object into the new array, wich will be sent to the backend. + * @param form - the form object; + * @param index - the position of the question inside the array, to be used as the placement. + * @param json - the object that will recieve the 'translation', to be sent to the bakcend; + * @param {sugestions, validation, subForm, type} - translated properties to be used on the backend object. + */ +function setInput( + form, + placement, + json, + sugestions, + validation, + subForm, + type, + id +) { + json.inputs.push({ + placement: placement, + description: form.description, + question: form.question, + type: type, + validation: validation, + sugestions: sugestions, + subForm: subForm ? subForm : null, + id: id, + }); +} + +/** Translates the 'options' array to the backend padronization. + * @param sugestions - the 'options' property from the frontend object; + */ +function setSugestions(sugestions) { + let tmp = []; + if (!sugestions) return tmp; + sugestions.forEach((value, index) => { + tmp.push({ + value: value, + placement: index, + }); + }); + return tmp; +} + +/** Sets the validation field to be sent to the backend. + * @param form - the form[i] position of the array. + */ +function setValidation(form) { + if (!form.validation[0].value && form.validation.length <= 1) return []; + let val = []; + if (form.type === 1) { + val.push({ + type: 6, + arguments: [], + }); + return val; + } + + if (form.validation[0].value) { + val.push({ + type: 2, + arguments: [], + }); + } + if (form.type === 0 && form.validation.length > 1) { + val.push({ + type: form.validation[1].type, + arguments: [form.validation[1].value], + }); + } + return val; +} +/** Set the subform as the backend padronization. + * @param form - the form[i] position of the array. + */ +function setSubform(form) { + if (form.type !== 4) return null; + return { + contentFormId: form.subformId, + }; +} + +/** The function that triggers the 'translation' + * @param form - the form[i] position of the array. + */ +export default async function createBackendForm(form) { + let json = { + id: form[0].id ? form[0].id : "", + title: form[0].question, + description: form[0].description, + inputs: [], + }; + for (var i = 1; i < form.length; i++) { + setInput( + form[i], + i, + json, + setSugestions(form[i].options), + setValidation(form[i]), + setSubform(form[i], i), + form[i].type, + form[i].inputId + ); + } + return json; +} diff --git a/src/components/fieldsDisplayForm/utils/FormComposition.js b/src/components/fieldsDisplayForm/utils/FormComposition.js new file mode 100644 index 0000000..b09b3e7 --- /dev/null +++ b/src/components/fieldsDisplayForm/utils/FormComposition.js @@ -0,0 +1,205 @@ +import uuid from "uuid/v4"; + +/** Function that pushes the title object into the form array. + * @param form - the form where the field will be pushed; + * @param title - the title; + * @param description - the description of the form. + */ +export function pushTitle(form, title, description, id) { + return form.push({ + type: "title", + question: title ? title : "", + description: description ? description : "", + id: id ? id : "", + error: { + errorMsg: { + question: title ? "" : "Este campo é obrigatório!", + description: "", + }, + }, + }); +} +/** Function that pushes a 'question' object into the form array. + * @param form - the form where the field will be pushed; + * @param question - the question; + * @param description - the description of the question; + * @param validation - optional validation the question may have. + */ +export function pushQuestion(form, question, description, validation, id) { + form.push({ + type: 0, + validation: validation ? validation : [{ type: "required", value: false }], + question: question ? question : "", + description: description ? description : "", + id: uuid(), + inputId: id ? id : null, + error: { + errorMsg: { + question: question ? "" : "Este campo é obrigatório!", + description: "", + validationValue: validation + ? validation[1] + ? validation[1].value + ? "" + : "Por favor, digite um número" + : "" + : "", + }, + }, + }); +} + +/** Function that pushes a 'select' object into the form array. + * @param form - the form where the field will be pushed; + * @param question - the question; + * @param description - the description of the question; + * @param options - the options array; + * @param validation - optional validation the question may have. + */ +export function pushSelect( + form, + question, + description, + options, + validation, + id +) { + let value = { + type: 3, + question: question ? question : "", + validation: validation ? validation : [{ type: "required", value: false }], + options: options ? options.map((x) => x.value) : [""], + description: description ? description : "", + id: uuid(), + inputId: id ? id : null, + error: { + errorMsg: { + question: question ? "" : "Este campo é obrigatório!", + description: "", + optionsNumber: options + ? options.length < 2 + ? "O campo precisa ter pelo menos duas opções!" + : "" + : "O campo precisa ter pelo menos duas opções!", + options: options + ? options.map((x) => (x = "")) + : ["Por favor, preencha esta opção"], + }, + }, + }; + return form.push(value); +} + +/** Function that pushes a 'radio' object into the form array. + * @param form - the form where the field will be pushed; + * @param question - the question; + * @param description - the description of the question; + * @param options - the options array; + * @param validation - optional validation the question may have. + */ +export function pushRadio( + form, + question, + description, + options, + validation, + id +) { + let value = { + type: 2, + question: question ? question : "", + validation: validation ? validation : [{ type: "required", value: false }], + options: options ? options.map((x) => x.value) : [""], + description: description ? description : "", + id: uuid(), + inputId: id ? id : null, + error: { + errorMsg: { + question: question ? "" : "Este campo é obrigatório!", + description: "", + optionsNumber: options + ? options.length < 2 + ? "O campo precisa ter pelo menos duas opções!" + : "" + : "O campo precisa ter pelo menos duas opções!", + options: options + ? options.map((x) => (x = "")) + : ["Por favor, preencha esta opção"], + }, + }, + }; + return form.push(value); +} + +/** Function that pushes a 'checkbox' object into the form array. + * @param form - the form where the field will be pushed; + * @param question - the question; + * @param description - the description of the question; + * @param options - the options array; + * @param validation - optional validation the question may have. + */ +export function pushCheckbox( + form, + question, + description, + options, + validation, + id +) { + let value = { + type: 1, + question: question ? question : "", + validation: validation ? validation : [{ type: "required", value: false }], + options: options ? options.map((x) => x.value) : [""], + description: description ? description : "", + id: uuid(), + inputId: id ? id : null, + error: { + errorMsg: { + question: question ? "" : "Este campo é obrigatório!", + description: "", + optionsNumber: options + ? options.length < 2 + ? "O campo precisa ter pelo menos duas opções!" + : "" + : "O campo precisa ter pelo menos duas opções!", + options: options + ? options.map((x) => (x = "")) + : ["Por favor, preencha esta opção"], + }, + }, + }; + return form.push(value); +} +/** Function that pushes a 'select' object into the form array. + * @param form - the form where the field will be pushed; + * @param question - the question; + * @param description - the description of the question; + * @param subformId - id of the form being used as a subform; + * @param validation - optional validation the question may have. + */ +export function pushSubform( + form, + question, + description, + subformId, + validation, + id +) { + return form.push({ + type: 4, + validation: validation ? validation : [{ type: "required", value: false }], + question: question ? question : "", + description: description ? description : "", + subformId: subformId, + id: uuid(), + inputId: id ? id : null, + error: { + errorMsg: { + question: question ? "" : "Este campo é obrigatório!", + description: "", + subformUsage: "", + }, + }, + }); +} diff --git a/src/components/fieldsDisplayForm/utils/FrontEndTranslation.js b/src/components/fieldsDisplayForm/utils/FrontEndTranslation.js new file mode 100644 index 0000000..d0f158e --- /dev/null +++ b/src/components/fieldsDisplayForm/utils/FrontEndTranslation.js @@ -0,0 +1,89 @@ +import { + pushTitle, + pushQuestion, + pushSelect, + pushRadio, + pushCheckbox, + pushSubform, +} from "./FormComposition"; + +/** Function that recieves the validation from the backend to translate it to the frontend. + * @param validaiton - the validation as it comes from the backend. + */ +function validationTranslate(validation) { + let val = [{ type: "required", value: false }]; + if (!validation) return val; + validation.forEach((opt) => { + if (opt.type === 6) { + val[0].value = true; + } else if (opt.type === 2) { + val[0].value = true; + } else { + val.push({ type: opt.type, value: opt.arguments[0] }); + } + }); + return val; +} + +/** Function that converts the backend form to an structure to be used on frontend. + * @param formData - the backend data. + */ +export function createFrontendForm(formData) { + let json = []; + pushTitle(json, formData.title, formData.description, formData.id); + + formData.inputs.forEach((option) => { + switch (option.type) { + case 0: + pushQuestion( + json, + option.question, + option.description, + validationTranslate(option.validation), + option.id + ); + break; + case 1: + pushCheckbox( + json, + option.question, + option.description, + option.sugestions, + validationTranslate(option.validation), + option.id + ); + break; + case 2: + pushRadio( + json, + option.question, + option.description, + option.sugestions, + validationTranslate(option.validation), + option.id + ); + break; + case 3: + pushSelect( + json, + option.question, + option.description, + option.sugestions, + validationTranslate(option.validation), + option.id + ); + break; + case 4: + pushSubform( + json, + option.question, + option.description, + option.subForm.contentFormId, + validationTranslate(option.validation), + option.id + ); + default: + } + }); + return json; +} diff --git a/src/components/fieldsCreateForm/utils/schemas.js b/src/components/fieldsDisplayForm/utils/schemas.js similarity index 93% rename from src/components/fieldsCreateForm/utils/schemas.js rename to src/components/fieldsDisplayForm/utils/schemas.js index 1995384..3ec954c 100644 --- a/src/components/fieldsCreateForm/utils/schemas.js +++ b/src/components/fieldsDisplayForm/utils/schemas.js @@ -116,34 +116,32 @@ export async function testTextValidation(form, index, value) { await textValidationSchema .validate(value) .then((x) => { - form[index].error.errorMsg.validation.value = ""; + form[index].error.errorMsg.validationValue = ""; }) - .catch( - (err) => (form[index].error.errorMsg.validation.value = err.message) - ); + .catch((err) => (form[index].error.errorMsg.validationValue = err.message)); } /** Functions that verify if the form array can be sent to the backend. */ export function verifyError(form) { - if (form.length === 1) return false; + if (!form || form.length < 2) return false; let valid = true; form.map(function (x) { if (x.error.errorMsg.question || x.error.errorMsg.description) { valid = false; return; } - if (x.type === "question") { - if (x.error.errorMsg.validation.value) { + if (x.type === 0) { + if (x.error.errorMsg.validationValue) { valid = false; return; } } - if (x.type === "subForm") { + if (x.type === 4) { if (x.error.errorMsg.subformUsage || !x.subformId) { valid = false; return; } } - if (x.type === "checkbox" || x.type === "radio" || x.type === "select") { + if (x.type === 1 || x.type === 2 || x.type === 3) { if (x.error.errorMsg.optionsNumber) valid = false; x.error.errorMsg.options.forEach((y) => { if (y) { diff --git a/src/components/fieldsListForms/CardForm.jsx b/src/components/fieldsListForms/CardForm.jsx index 9dca0c0..40fc1f8 100644 --- a/src/components/fieldsListForms/CardForm.jsx +++ b/src/components/fieldsListForms/CardForm.jsx @@ -97,7 +97,7 @@ function CardForm(props) { return ( <ExpansionPanel> <ExpansionPanelSummary expandIcon={<MoreVertOutlinedIcon />}> - <Typography noWrap className={classes.title}> + <Typography className={classes.title}> {props.title} <br /> <div className={classes.create} noWrap> @@ -139,4 +139,4 @@ function CardForm(props) { ); } -export default CardForm; +export default CardForm; \ No newline at end of file diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 4846204..d714258 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -21,9 +21,6 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:1040px)"]: { display: "none", }, - // ["@media (max-height:681px)"]: { - // display: "none" - // } }, form_creator: { color: "#ffffff", diff --git a/src/contexts/FormContext.js b/src/contexts/FormContext.js new file mode 100644 index 0000000..bd70c89 --- /dev/null +++ b/src/contexts/FormContext.js @@ -0,0 +1,48 @@ +import React, { useState, createContext, useEffect } from "react"; +import { useParams } from "react-router-dom"; +import api from "../api"; +import { createFrontendForm } from "../components/fieldsDisplayForm/utils/FrontEndTranslation"; +export const FormEditionContext = createContext(); + +const FormProvider = (props) => { + /** Getting the id from the route information */ + const { id } = useParams(); + /** Form state being started with the title in the case of the creation or 0 when editing (to be overrided by the backend data afterwards) + * it's an array where each position stands for a question selected by the user. */ + const [form, setForm] = useState( + id + ? 0 + : [ + { + type: "title", + question: "", + description: "", + error: { + errorMsg: { + question: "Este campo é obrigatório!", + description: "", + }, + }, + }, + ] + ); + + /** Hook to access the API in the case a edition is being done */ + useEffect(() => { + const fetchData = async () => { + api.get(`/form/${id}`).then(async function (res) { + setForm(await createFrontendForm(res.data)); + }); + }; + if (id) fetchData(); + }, []); + return ( + <FormEditionContext.Provider + value={{ formState: [form, setForm], idValue: id }} + > + {props.children} + </FormEditionContext.Provider> + ); +}; + +export default FormProvider; diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js new file mode 100644 index 0000000..71fc926 --- /dev/null +++ b/src/contexts/useForm.js @@ -0,0 +1,338 @@ +import { useContext, useEffect } from "react"; +import { FormEditionContext } from "./FormContext"; +import uuid from "uuid/v4"; +import { + testQuestionTextSchema, + testDescriptionTextSchema, + selectOptionsTesting, + testSubformSchema, + selectOptionTextTesting, + testTextValidation, +} from "../components/fieldsDisplayForm/utils/schemas"; +import { + pushTitle, + pushQuestion, + pushSelect, + pushRadio, + pushCheckbox, + pushSubform, +} from "../components/fieldsDisplayForm/utils/FormComposition"; + +import api from "../api"; + +import createBackendForm from "../components/fieldsDisplayForm/utils/BackendTranslation"; +import { createFrontendForm } from "../components/fieldsDisplayForm/utils/FrontEndTranslation"; + +const useForm = () => { + const { formState, idValue } = useContext(FormEditionContext); + const [form, setForm] = formState; + + const routeId = idValue; + + /** Function that adds the title object into the form array. + * Its parameters are used on the translation of the backend data. + * @param title - the title; + * @param description - the description of the form; + * @param id - optional parameter, it is used when editing a form. + */ + function addToFormTitle(title, description, id) { + setForm(pushTitle(form, title, description, id)); + } + /** Function that adds a 'question' object into the form array. + * Its parameters are used on the translation of the backend data. + * @param question - the question; + * @param description - the description of the question; + * @param validation - optional validation the question may have. + */ + function addToFormQuestion(question, description, validation) { + pushQuestion(form, question, description, validation); + setForm([...form]); + } + /** Function that adds a 'select' object into the form array. + * Its parameters are used on the translation of the backend data. + * @param question - the question; + * @param description - the description of the question; + * @param options - the options array; + * @param validation - optional validation the question may have. + */ + function addToFormSelect(question, description, options, validation) { + pushSelect(form, question, description, options, validation); + setForm([...form]); + } + /** Function that adds a 'radio' object into the form array. + * Its parameters are used on the translation of the backend data. + * @param question - the question; + * @param description - the description of the question; + * @param options - the options array; + * @param validation - optional validation the question may have. + */ + function addToFormRadio(question, description, options, validation) { + pushRadio(form, question, description, options, validation); + setForm([...form]); + } + /** Function that adds a 'checkbox' object into the form array. + * Its parameters are used on the translation of the backend data. + * @param question - the question; + * @param description - the description of the question; + * @param options - the options array; + * @param validation - optional validation the question may have. + */ + function addToFormCheckbox(question, description, options, validation) { + pushCheckbox(form, question, description, options, validation); + setForm([...form]); + } + /** Function that adds a 'select' object into the form array. + * Its parameters are used on the translation of the backend data. + * @param question - the question; + * @param description - the description of the question; + * @param subformId - id of the form being used as a subform; + * @param validation - optional validation the question may have. + */ + function addToFormSubform(question, description, subformId, validation) { + pushSubform(form, question, description, subformId, validation); + setForm([...form]); + } + + /** Function used on FormFieldRadio, FormFieldCheckbox and FormFieldSelect, it adds a new option field for those types of questions. + * @param index - the position on the array that the operation needs to be done. + */ + async function addSelectOption(index) { + form[index].options.push(""); + form[index].error.errorMsg.options.push("Por favor, preencha esta opção"); + await selectOptionsTesting(form, index); + setForm([...form]); + } + + /** Function used on FormFieldRadio, FormFieldCheckbox and FormFieldSelect, it removes an option field for those types of questions. + * @param index - the position on the array that the operation needs to be done. + */ + async function removeSelectOption(index, idopt) { + form[index].options.splice(idopt, 1); + form[index].error.errorMsg.options.splice(idopt, 1); + await selectOptionsTesting(form, index); + setForm([...form]); + } + + /** Function used on every FormField, it deletes the question from the array. + * @param index - the position on the array that the operation needs to be done. + */ + function deleteFromForm(index) { + form.splice(index, 1); + setForm([...form]); + } + + /** Function used on FormFieldQuestion, it handles the validation the user chooses. + * Currently, only handle max and min number of characters. + * @param index - the position on the array that the operation needs to be done. + */ + function addValidation(index) { + form[index].validation.push({ type: "", value: "" }); + form[index].error.errorMsg.validationValue = "Por favor, digite um número"; + setForm([...form]); + } + + /** Function used on every FormField, it updates the value of the question property on the form array. + * @param value - the value being typed by the user; + * @param index - the position on the array that the operation needs to be done. + */ + async function setQuestionField(value, index) { + form[index].question = value; + await testQuestionTextSchema(form, value, index); + setForm([...form]); + } + + /** Function used on every FormField, it updates the value of the description property on the array. + * @param value - the value being typed by the user; + * @param index - the position on the array that the operation needs to be done. + */ + async function setDescriptionField(value, index) { + form[index].description = value; + await testDescriptionTextSchema(form, value, index); + setForm([...form]); + } + + /** Function used on every FormField, it updates the value of the oprion property of the object on the array. + * @param value - the value being typed by the user; + * @param index - the position on the array that the operation needs to be done; + * @param idopt - the id of the options being changed, inside the form[index]. + */ + async function setSelectOption(value, index, idopt) { + form[index].options[idopt] = value; + await selectOptionTextTesting(form, value, index, idopt); + setForm([...form]); + } + + /** Function used on every FormField, it updates the value of the required property of a question. + * @param index - the position on the array that the operation needs to be done. + */ + function setRequiredField(index) { + form[index].validation[0].value = !form[index].validation[0].value; + setForm([...form]); + } + /** Function to store the selected subform Id on it's corresponding object. + * @param value - the id of the selected form; + * @param index - the position on the array that the operation needs to be done. + */ + async function setSubformId(value, index) { + form[index].subformId = value; + await testSubformSchema(form, index); + setForm([...form]); + } + + /** Function used on FormFieldText to set the chosen validation type, currently min and max char. + * @param value - the type of the chosen validation; + * @param index - the position on the array that the operation needs to be done. + */ + async function setValidationType(value, index) { + form[index].validation[1].type = value; + setForm([...form]); + } + + /** Function used on FormFieldText to set the value of the validation + * @param value - the value for the chosen validation; + * @param index - the position on the array that the operation needs to be done. + */ + async function setValidationValue(value, index) { + form[index].validation[1].value = value; + await testTextValidation(form, index, value); + setForm([...form]); + } + + /** Function used on FormFieldText to remove the validaiton. + * @param index - the position on the array that the operation needs to be done. + */ + function removeValidation(index) { + form[index].validation.splice(-1, 1); + form[index].error.errorMsg.validationValue = ""; + setForm([...form]); + } + /** Reordering the form array based on the place the question is being dragged over. + * @param result - an composed object bringing info about the drag event. + */ + function onDragEnd(result) { + if (!result.destination) return; + const { source, destination } = result; + const copiedForm = [...form]; + const [removed] = copiedForm.splice(source.index, 1); + copiedForm.splice(destination.index, 0, removed); + setForm(copiedForm); + } + /** Verify if the validation was changed on the edition. + * @param backForm - form that came from the backend; + * @param form - form being edited. + */ + function differentValidation(backForm, form) { + for (let i = 0; i < form.validation.length; i++) { + if ( + JSON.stringify(form.validation[i]) !== + JSON.stringify(backForm.validation[i]) + ) { + return true; + } + } + return false; + } + /** Comparing the edited form with the 'original' form that is on the backend. + * If some property of the input was changed in the edition, its id becomes null. + */ + async function setId() { + const fetchData = async () => { + await api.get(`/form/${routeId}`).then(async function (res) { + let backForm = createFrontendForm(res.data); + for (let i = 1; i < backForm.length; i++) { + for (let j = 1; j < form.length; j++) { + if (backForm[i].inputId === form[j].inputId) { + if ( + JSON.stringify(backForm[i], [ + "question", + "description", + "options", + "subformId", + ]) !== + JSON.stringify(form[j], [ + "question", + "description", + "options", + "subformId", + ]) || + differentValidation(backForm[i], form[j]) + ) { + form[j].inputId = null; + } + } + } + } + }); + }; + await fetchData(); + } + /** The submit function. It's triggered when the submit button is pressed on the interface. + * Its api call may be to create or to edit a form. + */ + async function submit(validToSend) { + if (!validToSend) return; + if (form[0].id) { + await setId(); + let data = await createBackendForm(form, routeId); + const post_response = await api + .put(`/form/${routeId}`, data, { + headers: { + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, + }) + .then(function (error) { + if (!error.response) + alert("Seu formulário foi atualizado com sucesso."); + }) + .catch(function (error) { + if (error.response.data.error === "User dont own this form.") + alert("Você não tem permissão para alterar este formulário"); + else if (error.response.data.error === "Found a subform loop") + alert( + "Foi encontrada uma recursão de subformulários. Por favor, altere o subformulário selecionado ou o exclua." + ); + else alert("Um erro ocorreu."); + }); + } else { + const post_response = await api + .post(`/form`, await createBackendForm(form), { + headers: { + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, + }) + .then(function (error) { + if (!error.response) alert("Seu formulário foi criado com sucesso."); + else console.log("ERROR NO POST_RESPONSE", error); + }) + .catch(function (error) { + console.log("ERROR NO POST RESPONSE", error.response); + alert("Um erro ocorreu."); + }); + } + } + + return { + addToFormTitle, + addToFormQuestion, + addToFormSelect, + addToFormRadio, + addToFormCheckbox, + addToFormSubform, + addSelectOption, + removeSelectOption, + deleteFromForm, + addValidation, + setQuestionField, + setDescriptionField, + setSelectOption, + setRequiredField, + setSubformId, + setValidationType, + setValidationValue, + removeValidation, + onDragEnd, + submit, + }; +}; + +export default useForm; diff --git a/src/pages/CreateForm.js b/src/pages/CreateForm.js index 9a2a477..670a86f 100644 --- a/src/pages/CreateForm.js +++ b/src/pages/CreateForm.js @@ -1,509 +1,11 @@ -import React, { useState, useEffect } from "react"; -import { makeStyles } from "@material-ui/core/styles"; -import Grid from "@material-ui/core/Grid"; -import Button from "@material-ui/core/Button"; -import { DragDropContext, Droppable } from "react-beautiful-dnd"; -import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; -import FormFieldText from "../components/fieldsCreateForm/FormFieldText"; -import FormFieldSelect from "../components/fieldsCreateForm/FormFieldSelect"; -import FormFieldRadio from "../components/fieldsCreateForm/FormFieldRadio"; -import FormFieldCheckbox from "../components/fieldsCreateForm/FormFieldCheckbox"; -import FormFieldTitle from "../components/fieldsCreateForm/FormFieldTitle"; -import FormFieldSubForm from "../components/fieldsCreateForm/FormFieldSubform"; -import uuid from "uuid/v4"; -import { - testQuestionTextSchema, - testDescriptionTextSchema, - selectOptionsTesting, - testSubformSchema, - selectOptionTextTesting, - testTextValidation, - verifyError, -} from "../components/fieldsCreateForm/utils/schemas"; -import createForm from "../components/fieldsCreateForm/utils/BackendTranslation"; -import SideMenu from "../components/fieldsCreateForm/SideMenu"; -import api from "../api"; - -import Tooltip from "@material-ui/core/Tooltip"; -/** CSS styles used on page components */ -const useStyles = makeStyles((theme) => ({ - app: { - margin: "0", - padding: "40px", - display: "flex", - ["@media (max-width: 600px)"]: { - flexDirection: "column-reverse", - justifyContent: "flex-end", - }, - paddingBottom: "78px", - ["@media (min-width: 600px)"]: { - minHeight: "calc(100vh - 92.4px - 78px)", - }, - minHeight: "calc(100vh - 71.6px - 78px)", - }, - addButton: { - fontSize: "100%", - }, - buttonOk: { - backgroundColor: "#6ec46c", - "&:hover": { - backgroundColor: "rgb(25, 109, 23)", - }, - width: "20%", - ["@media (max-width:600px)"]: { - marginTop: "52px", - }, - }, - button: { - ["@media (max-width:600px)"]: { - marginTop: "52px", - }, - }, - questionsGrid: { - // da pra mexer no deslocamento do titulo por aqui; - ["@media (max-width:600px)"]: { - // marginBottom: "100%", - // padding: 0, - }, - }, - sideMenuFormatingGrid: { - ["@media (max-width:600px)"]: { - marginTop: "-90px", - }, - }, -})); -/** CSS style used through Material Ui. */ -const theme = createMuiTheme({ - overrides: { - MuiInput: { - underline: { - "&:before": { - borderBottom: "1px solid #35c7fc", - }, - "&:after": { - borderBottom: "1px solid #3f51b5", - }, - }, - }, - MuiButton: { - label: { - color: "white", - }, - }, - }, -}); -/** Main function that returns the children that composes the form creation page. */ -function CreateForm() { - /** Style class. */ - const classes = useStyles(); - /** An unique string to be used as ID for drag and drop function. */ - const columnId = uuid(); - /** Error state. */ - const [validToSend, setValidToSend] = useState(); - - /** Form state being started with the title, it's an array where each position stands for a question selected by the user. */ - const [form, setForm] = useState([ - { - type: "title", - title: "", - description: "", - error: { - errorMsg: { question: "Este campo é obrigatório!", description: "" }, - }, - }, - ]); - /** Function used on 'sidemenu' that adds to the form array the object of a question. */ - function addToFormQuestion() { - setForm([ - ...form, - { - type: "question", - validation: [{ type: "required", value: false }], - question: "", - description: "", - id: uuid(), - error: { - errorMsg: { - question: "Este campo é obrigatório!", - description: "", - validation: { - value: "", - }, - }, - }, - }, - ]); - } - /** Function used on 'sidemenu' that adds to the form array the object of a select question. */ - function addToFormSelect() { - setForm([ - ...form, - { - type: "select", - question: "", - validation: [{ type: "required", value: false }], - options: [""], - description: "", - id: uuid(), - error: { - errorMsg: { - question: "Este campo é obrigatório!", - description: "", - optionsNumber: "O campo precisa ter pelo menos duas opções!", - options: ["Por favor, preencha esta opção"], - }, - }, - }, - ]); - } - /** Function used on 'sidemenu' that adds to the form array the object of a radio question. */ - function addToFormRadio() { - setForm([ - ...form, - { - type: "radio", - question: "", - validation: [{ type: "required", value: false }], - options: [""], - description: "", - id: uuid(), - error: { - errorMsg: { - question: "Este campo é obrigatório!", - description: "", - optionsNumber: "O campo precisa ter pelo menos duas opções!", - options: ["Por favor, preencha esta opção"], - }, - }, - }, - ]); - } - /** Function used on 'sidemenu' that adds to the form array the object of a checkbox question. */ - function addToFormCheckbox() { - setForm([ - ...form, - { - type: "checkbox", - question: "", - validation: [{ type: "required", value: false }], - options: [""], - description: "", - id: uuid(), - error: { - errorMsg: { - question: "Este campo é obrigatório!", - description: "", - optionsNumber: "O campo precisa ter pelo menos duas opções!", - options: ["Por favor, preencha esta opção"], - }, - }, - }, - ]); - } - /** Function used on 'sidemenu' that adds to the form array the object of a subform question. */ - function addToFormSubForm() { - setForm([ - ...form, - { - type: "subForm", - validation: [{ type: "required", value: false }], - description: "", - question: "", - subformId: "", - id: uuid(), - error: { - errorMsg: { - question: "Este campo é obrigatório!", - description: "", - subformUsage: "", - }, - }, - }, - ]); - } - /** Function used on FormFieldRadio, FormFieldCheckbox and FormFieldSelect, it adds a new option field for those questions. */ - async function addSelectOption(index) { - form[index].options.push(""); - form[index].error.errorMsg.options.push("Por favor, preencha esta opção"); - await selectOptionsTesting(form, index); - setForm([...form]); - } - /** Function used on FormFieldRadio, FormFieldCheckbox and FormFieldSelect, it removes an option field for those questions. */ - async function removeSelectOption(index, idopt) { - form[index].options.splice(idopt, 1); - form[index].error.errorMsg.options.splice(idopt, 1); - await selectOptionsTesting(form, index); - setForm([...form]); - } - /** Function used on every FormField, it deletes the question from the array. */ - function deleteFromForm(index) { - form.splice(index, 1); - setForm([...form]); - } - /** Function used on FormFieldQuestion, it handles the validation the user chooses. - * Currently, only handle max and min number of characters. - */ - function addValidation(index) { - form[index].validation.push({ type: "", value: "" }); - form[index].error.errorMsg.validation.value = "Por favor, digite um número"; - setForm([...form]); - } - /** Function used on every FormField, it updates the value of the question property on the form array. */ - async function setQuestionField(value, index) { - form[index].question = value; - await testQuestionTextSchema(form, value, index); - setForm([...form]); - } - /** Function used on every FormField, it updates the value of the description property on the array. */ - async function setDescriptionField(value, index) { - form[index].description = value; - await testDescriptionTextSchema(form, value, index); - setForm([...form]); - } - /** Function used on every FormField, it updates the value of the oprion property of the object on the array. */ - async function setSelectOption(value, index, idopt) { - form[index].options[idopt] = value; - await selectOptionTextTesting(form, value, index, idopt); - setForm([...form]); - } - /** Function used on every FormField, it updates the value of the required property of a question. */ - function setRequiredField(index) { - form[index].validation[0].value = !form[index].validation[0].value; - setForm([...form]); - } - /** Function to update the title, used on FormFieldTitle. */ - async function setTitleField(value) { - form[0].title = value; - await testQuestionTextSchema(form, value, 0); - setForm([...form]); - } - /** Function to store the selected subform Id on it's corresponding object. */ - async function setSubformId(value, index) { - form[index].subformId = value; - await testSubformSchema(form, index); - setForm([...form]); - } - /** Function used on FormFieldText to set the chosen validation type, currently min and max char. */ - async function setValidationType(value, index) { - form[index].validation[1].type = value; - - setForm([...form]); - } - /** Function used on FormFieldText to set the value of the validation*/ - async function setValidationValue(value, index) { - form[index].validation[1].value = value; - await testTextValidation(form, index, value); - setForm([...form]); - } - /** Function used on FormFieldText to remove the validaiton. */ - function removeValidation(index) { - form[index].validation.splice(-1, 1); - setForm([...form]); - } - /** The submit function. It's triggered when the submit button is pressed on the interface. */ - async function submit(event) { - if (!validToSend) return; - let data = createForm(form); - const post_response = await api - .post(`/form`, data, { - headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}`, - }, - }) - .then(function (error) { - if (!error.response) alert("Seu formulário foi criado com sucesso."); - }) - .catch(function (error) { - alert("Um erro ocorreu."); - }); - } - /** Reordering the form array based on the place the question is being dragged over. */ - const onDragEnd = (result) => { - if (!result.destination) return; - const { source, destination } = result; - - const copiedForm = [...form]; - const [removed] = copiedForm.splice(source.index, 1); - copiedForm.splice(destination.index, 0, removed); - setForm(copiedForm); - }; - /** Error handling -> every time the form object is updated, it is verified to evaluate it's error messages, - * so the submit button can be enabled or disabled. - */ - useEffect(() => { - setValidToSend(verifyError(form)); - }, [form]); - +import React from "react"; +import DisplayForm from "../components/fieldsDisplayForm/DisplayForm"; +import FormProvider from "../contexts/FormContext"; +/** External component that wraps the display page into the form context. */ +export default function CreateForm() { return ( - <MuiThemeProvider theme={theme}> - <Grid className={classes.app}> - <Grid xs={12} sm={2} className={classes.sideMenuFormatingGrid}> - <SideMenu - addToFormQuestion={addToFormQuestion} - addToFormSelect={addToFormSelect} - addToFormRadio={addToFormRadio} - addToFormCheckbox={addToFormCheckbox} - addToFormSubForm={addToFormSubForm} - /> - </Grid> - <DragDropContext onDragEnd={onDragEnd}> - <Grid - dragOver - container - xs={12} - sm={8} - direction="column" - alignItems="center" - className={classes.questionsGrid} - > - <Droppable droppableId={columnId}> - {(provided, snapshot) => { - return ( - <Grid {...provided.droppableProps} ref={provided.innerRef}> - {form.map((x, index) => { - if (x.type === "question") - return ( - <FormFieldText - question={x.question} - idq={index} - description={x.description} - deleteFromForm={deleteFromForm} - setQuestionField={setQuestionField} - setRequiredField={setRequiredField} - setDescriptionField={setDescriptionField} - id={x.id} - error={x.error} - validation={x.validation} - addValidation={addValidation} - setValidationType={setValidationType} - setValidationValue={setValidationValue} - removeValidation={removeValidation} - validationValue={ - x.validation[1] ? x.validation[1].value : null - } - validationType={ - x.validation[1] ? x.validation[1].type : null - } - /> - ); - else if (x.type === "select") - return ( - <FormFieldSelect - question={x.question} - options={x.options} - idq={index} - description={x.description} - deleteFromForm={deleteFromForm} - addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} - setSelectOption={setSelectOption} - setQuestionField={setQuestionField} - setRequiredField={setRequiredField} - setDescriptionField={setDescriptionField} - validation={x.validation} - id={x.id} - error={x.error} - /> - ); - else if (x.type === "radio") - return ( - <FormFieldRadio - question={x.question} - options={x.options} - idq={index} - description={x.description} - deleteFromForm={deleteFromForm} - addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} - setSelectOption={setSelectOption} - setQuestionField={setQuestionField} - setRequiredField={setRequiredField} - setDescriptionField={setDescriptionField} - validation={x.validation} - id={x.id} - error={x.error} - /> - ); - else if (x.type === "checkbox") - return ( - <FormFieldCheckbox - question={x.question} - options={x.options} - idq={index} - description={x.description} - deleteFromForm={deleteFromForm} - addSelectOption={addSelectOption} - removeSelectOption={removeSelectOption} - setSelectOption={setSelectOption} - setQuestionField={setQuestionField} - setRequiredField={setRequiredField} - setDescriptionField={setDescriptionField} - validation={x.validation} - id={x.id} - error={x.error} - /> - ); - else if (x.type === "subForm") - return ( - <FormFieldSubForm - question={x.question} - idq={index} - description={x.description} - deleteFromForm={deleteFromForm} - setQuestionField={setQuestionField} - setRequiredField={setRequiredField} - setDescriptionField={setDescriptionField} - setSubformId={setSubformId} - validation={x.validation} - id={x.id} - error={x.error} - validToSend={validToSend} - subformId={x.subformId ? x.subformId : null} - /> - ); - else if (x.type === "title") - return ( - <FormFieldTitle - question={x.question} - idq={index} - deleteFromForm={deleteFromForm} - setTitleField={setTitleField} - setDescriptionField={setDescriptionField} - error={x.error} - /> - ); - })} - {provided.placeholder} - </Grid> - ); - }} - </Droppable> - <Tooltip - title={ - validToSend - ? "Criar seu formulário" - : "Verifique se você criou pelo menos uma pergunta e se as perguntas estão propriamente construÃdas" - } - aria-label={ - validToSend - ? "Criar seu formulário" - : "Verifique se você criou pelo menos uma pergunta e se as perguntas estão propriamente construÃdas" - } - > - <Button - className={validToSend ? classes.buttonOk : classes.button} - variant="contained" - type="submit" - onClick={submit} - > - Criar - </Button> - </Tooltip> - </Grid> - </DragDropContext> - </Grid> - </MuiThemeProvider> + <FormProvider> + <DisplayForm /> + </FormProvider> ); } - -export default CreateForm; diff --git a/src/pages/EditForm.js b/src/pages/EditForm.js new file mode 100644 index 0000000..cdda379 --- /dev/null +++ b/src/pages/EditForm.js @@ -0,0 +1,11 @@ +import React from "react"; +import DisplayForm from "../components/fieldsDisplayForm/DisplayForm"; +import FormProvider from "../contexts/FormContext"; +/** External component that wraps the display page into the form context. */ +export default function EditForm() { + return ( + <FormProvider> + <DisplayForm /> + </FormProvider> + ); +} diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index 50e755a..e9a0af5 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -8,7 +8,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -16,22 +16,22 @@ const useStyles = makeStyles(theme => ({ padding: "2% 1%", margin: "0 auto", marginTop: "9%", - width: "95%" + width: "95%", }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d" + color: "#46525d", }, strong_description: { fontSize: "14px", - color: "#c2c6ca" + color: "#c2c6ca", }, form: { marginTop: "3%", alignItems: "center", - textAlign: "center" + textAlign: "center", }, button: { type: "submit", @@ -42,12 +42,12 @@ const useStyles = makeStyles(theme => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)" + backgroundColor: "rgb(25, 109, 23)", }, ["@media (max-width:550px)"]: { - width: "55%" - } - } + width: "55%", + }, + }, })); export default function SignUp() { const classes = useStyles(); @@ -57,13 +57,13 @@ export default function SignUp() { password: "", password_confirm: "", nameError: false, - emailError: false + emailError: false, }); async function update(prop, event) { await setValues({ ...values, [prop]: event.target.value }); } - const handleChange = prop => event => { + const handleChange = (prop) => (event) => { switch (prop) { case "name": if (!checkName()) { @@ -89,7 +89,11 @@ export default function SignUp() { return true; } function checkName() { - if (/^[a-zA-Z ]+$/.test(values.name) && !(/^$|\s+/.test(values.name)) &&values.name.length <= 225) { + if ( + /^[a-zA-Z ]+$/.test(values.name) && + !/^$|\s+/.test(values.name) && + values.name.length <= 225 + ) { return true; } return false; @@ -113,16 +117,15 @@ export default function SignUp() { } // Ficou com essa configuração porque as funções para verificar nome e email são chamadas em 'tempo real' para deixar o campo em vermelho. function verifyValuesContent() { - if (!checkName()){ + if (!checkName()) { alert("Nome inválido"); return false; - }else if (!checkEmail()) { + } else if (!checkEmail()) { alert("Email invalido"); return false; - }else if (!checkPassword()){ + } else if (!checkPassword()) { return false; - } - else{ + } else { return true; } } @@ -131,15 +134,15 @@ export default function SignUp() { .post(`/user/signUp`, { email: values.email, name: values.name, - hash: values.password + hash: values.password, }) - .then(function(error) { + .then(function (error) { if (!error.response) { alert("Usuário criado com sucesso"); // redirecionar para a main page } }) - .catch(function(error) { + .catch(function (error) { if (error.response) { switch (error.response.data.error) { case 'duplicate key value violates unique constraint "form_user_name_key"': @@ -156,7 +159,6 @@ export default function SignUp() { alert("Um erro ocorreu. Tente novamente mais tarde."); } return; - // console.log(error.response.data); } }); } @@ -170,19 +172,19 @@ export default function SignUp() { const theme = createMuiTheme({ overrides: { root: { - color: "white" + color: "white", }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc" + borderBottom: "1px solid #35c7fc", }, "&:after": { - borderBottom: "1px solid #3f51b5" - } - } + borderBottom: "1px solid #3f51b5", + }, + }, }, - } + }, }); return ( <MuiThemeProvider theme={theme}> -- GitLab From 302554c9d9413abcd9fb4438abd6263eec6f1223 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Fri, 17 Jul 2020 12:31:57 -0300 Subject: [PATCH 38/72] Issue #13: Add visualize form page Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/App.js | 2 + .../JornalFolder/FieldFooterOptions.js | 40 +++ .../JornalFolder/FormFieldCheckbox.js | 88 +++++++ .../JornalFolder/FormFieldRadio.js | 89 +++++++ .../JornalFolder/FormFieldSelect.js | 95 ++++++++ .../JornalFolder/FormFieldSubform.js | 123 ++++++++++ .../JornalFolder/FormFieldText.js | 93 +++++++ .../JornalFolder/FormFieldTitle.js | 87 +++++++ .../fieldsGetForm/JornalFolder/FormJornal.js | 181 ++++++++++++++ .../JornalFolder/FormPagination.js | 164 +++++++++++++ .../fieldsGetForm/JornalFolder/JornalTab.js | 43 ++++ .../SummaryFolder/FieldFooterOptions.js | 33 +++ .../SummaryFolder/FormFieldCheckbox.js | 93 +++++++ .../SummaryFolder/FormFieldRadio.js | 96 ++++++++ .../SummaryFolder/FormFieldSelect.js | 95 ++++++++ .../SummaryFolder/FormFieldSubform.js | 126 ++++++++++ .../SummaryFolder/FormFieldText.js | 144 +++++++++++ .../SummaryFolder/FormFieldTitle.js | 93 +++++++ .../SummaryFolder/FormSummary.js | 161 ++++++++++++ src/pages/GetForm.js | 229 ++++++++++++++++++ 20 files changed, 2075 insertions(+) create mode 100644 src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormFieldText.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormJornal.js create mode 100644 src/components/fieldsGetForm/JornalFolder/FormPagination.js create mode 100644 src/components/fieldsGetForm/JornalFolder/JornalTab.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FormFieldCheckbox.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FormFieldRadio.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FormFieldSelect.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FormFieldText.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js create mode 100644 src/components/fieldsGetForm/SummaryFolder/FormSummary.js create mode 100644 src/pages/GetForm.js diff --git a/src/App.js b/src/App.js index f909603..64dc8a2 100644 --- a/src/App.js +++ b/src/App.js @@ -9,6 +9,7 @@ import SignUp from "./pages/SignUp"; import SignIn from "./pages/SignIn"; import ListForms from "./pages/ListForms"; import EditForm from "./pages/EditForm"; +import GetForm from "./pages/GetForm"; function App() { return ( <HashRouter> @@ -19,6 +20,7 @@ function App() { <Route path="/SignUp" component={SignUp} /> <Route path="/SignIn" component={SignIn} /> <Route path="/list/:id" component={ListForms} /> + <Route path="/form/:id" component={GetForm} /> <Footer /> </HashRouter> ); diff --git a/src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js b/src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js new file mode 100644 index 0000000..f6446f0 --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js @@ -0,0 +1,40 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; + +function FieldFooterOptions(props) { + + return ( + <> + <FormControlLabel + control={ + <Switch + onChange={e => props.setRequiredField(props.idq) } + value="required" + color="primary" + checked={props.required} + /> + } + label="Obrigatória" + /> + <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> + <DeleteOutlinedIcon /> + </IconButton> + </> + ); + + +} + + +export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js b/src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js new file mode 100644 index 0000000..119e9a9 --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js @@ -0,0 +1,88 @@ +import React, { useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; +import Checkbox from "@material-ui/core/Checkbox"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + } +})); + +function FormFieldCheckbox(props) { + const classes = useStyles(); + + /** + * Function to check if an index has a true value. + * @param index - Index of a given value. + */ + function handleProps(index) { + if (props.answer) { + if (props.answer[index].value === "false") { + return false; + } + return true; + } + return false; + } + + /** HTML to be displayed. */ + const options = props.options.map((x, index) => { + return ( + <span> + <Typography className={classes.text} variant="h7"> + {x.value} + </Typography> + <Checkbox checked={handleProps(index)} disabled /> + </span> + ); + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography>id: {Number(props.place)}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + {options} + </Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldCheckbox; diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js b/src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js new file mode 100644 index 0000000..441eb79 --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js @@ -0,0 +1,89 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; +import Radio from "@material-ui/core/Radio"; +import RadioGroup from "@material-ui/core/RadioGroup"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + } +})); + +function FormFieldRadio(props) { + const classes = useStyles(); + + /** + * Function to check if an index has a true value. + * @param index - Index of a given value. + */ + function handleProps(index) { + if (props.answer) { + if (props.answer[index].value === "false") { + return false; + } + return true; + } + return false; + } + + /** HTML object to be displayed on component return. */ + const options = props.options.map(function(x, index) { + return ( + <span> + <Typography className={classes.text} variant="h7"> + {x.value} + </Typography> + <Radio disabled checked={handleProps(index)} value={x.value} /> + </span> + ); + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography>id: {Number(props.place)}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + <RadioGroup>{options}</RadioGroup> + </Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldRadio; diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js new file mode 100644 index 0000000..5c175d1 --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js @@ -0,0 +1,95 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import Typography from "@material-ui/core/Typography"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + } +})); + +function FormFieldSelect(props) { + const classes = useStyles(); + + /** Variable to track if there's an answer. */ + const [hasAnswer, setHasAnswer] = useState(false); + + /** + * Function to handle the selected answer. + */ + function handleProps() { + if (props.answer) { + setHasAnswer(true); + return props.answer.filter(each => { + return each.value === "true"; + })[0].placement; + } else { + setHasAnswer(false); + } + } + + /** + * Function to prevent page from broking if there's no answer. + */ + function answer() { + if (hasAnswer) { + return props.options[handleProps()].value; + } + } + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography>id: {Number(props.place)}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography + style={{ wordWrap: "break-word" }} + variant="h8" + gutterBottom + > + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + <Select disabled value={""} displayEmpty> + <MenuItem value="">{answer()}</MenuItem> + </Select> + </Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldSelect; diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js b/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js new file mode 100644 index 0000000..980d51d --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js @@ -0,0 +1,123 @@ +import React, { useState, useEffect } from "react"; +import { useParams } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Button from "@material-ui/core/Button"; +import api from "../../../api"; + +import FormFieldText from "./FormFieldText"; +import FormFieldSelect from "./FormFieldSelect"; +import FormFieldRadio from "./FormFieldRadio"; +import FormFieldCheckbox from "./FormFieldCheckbox"; + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + } +})); + +function FormFieldSubform(props) { + const classes = useStyles(); + + /** Subform id */ + const id = props.id; + + /** Maped subform */ + const [formData, setFormData] = useState(0); + + /** Get subform */ + async function getForm(id) { + const res = await api + .get(`/form/${id}`) + .then(function(res) { + setFormData(res.data); + }) + .catch(error => { + alert( + "Um erro inesperado ocorreu ao tentar obter o subform na tela de Jornal." + ); + }); + } + + /** First gets info from the backend */ + useEffect(() => { + getForm(id); + }, []); + + return ( + <div> + <Grid container direction="column" alignItems="center" justify="center"> + {formData ? ( + <div> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + description={input.description} + id={input.id} + answer={props.findAnswer(input.id)} + place={input.placement + props.place} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + id={input.id} + description={input.description} + options={input.sugestions} + answer={props.findAnswer(input.id)} + place={input.placement + props.place} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + options={input.sugestions} + answer={props.findAnswer(input.id)} + place={input.placement + props.place} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + options={input.sugestions} + id={input.id} + answer={props.findAnswer(input.id)} + place={input.placement + props.place} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + findAnswer={props.findAnswer} + answer={props.findAnswer(input.id)} + place={input.placement} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + </Grid> + </div> + ); +} + +export default FormFieldSubform; diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldText.js b/src/components/fieldsGetForm/JornalFolder/FormFieldText.js new file mode 100644 index 0000000..f0969f4 --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldText.js @@ -0,0 +1,93 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + answersGrid: { + flexDirection: "column", + color: "black" + }, + description: { + marginBottom: "10px" + }, + questionsGrid: { + marginBottom: "10px" + }, + answer: { + color: "black", + marginBottom: "5px" + } +})); + +function FormFieldText(props) { + const classes = useStyles(); + + /** + * Function to display an answer or an messange if there's no answer. + */ + function answer() { + if (props.answer) { + return props.answer[0].value; + } + + return "Nenhuma resposta"; + } + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography>id: {Number(props.place)}</Typography> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + gutterBottom + > + {"Pergunta: " + props.question} + </Typography> + <Grid className={classes.description} container> + <Typography + style={{ wordWrap: "break-word" }} + container + item + variant="h8" + > + {"Descrição: " + props.description} + </Typography> + </Grid> + <Typography + style={{ wordWrap: "break-word" }} + gutterBottom + variant="h6" + > + Resposta: + </Typography> + </Grid> + <Grid container wrap="wrap" container className={classes.answersGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.answer} + container + wrap="wrap" + variant="body1" + > + {answer()} + </Typography> + </Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldText; diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js b/src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js new file mode 100644 index 0000000..d334754 --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js @@ -0,0 +1,87 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(22), + margin: theme.spacing(2), + color: "#000000" + }, + questionsGrid: { + marginBottom: "20px", + color: "#000000", + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + } + }, + title: { + fontSize: "45px", + color: "#000000", + ["@media (max-width:827px)"]: { + fontSize: "35px" + }, + ["@media (max-width:590px)"]: { + fontSize: "25px" + } + }, + description: { + fontSize: "30px", + color: "#000000", + ["@media (max-width:827px)"]: { + fontSize: "25px" + }, + ["@media (max-width:590px)"]: { + fontSize: "15px" + } + } +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Grid> + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.title} + variant="h3" + gutterBottom + > + {props.title} + </Typography> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.description} + variant="h4" + gutterBottom + > + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + ></Grid> + </Grid> + </Paper> + </Grid> + ); +} + +export default FormFieldText; diff --git a/src/components/fieldsGetForm/JornalFolder/FormJornal.js b/src/components/fieldsGetForm/JornalFolder/FormJornal.js new file mode 100644 index 0000000..d7826dc --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormJornal.js @@ -0,0 +1,181 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import Typography from "@material-ui/core/Typography"; + +import FormFieldText from "./FormFieldText"; +import FormFieldSelect from "./FormFieldSelect"; +import FormFieldRadio from "./FormFieldRadio"; +import FormFieldCheckbox from "./FormFieldCheckbox"; +import FormFieldTitle from "./FormFieldTitle"; +import FormFieldSubform from "./FormFieldSubform"; +import JornalTab from "./JornalTab"; +import { validate } from "json-schema"; + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + }, + formControl: { + margin: theme.spacing(1), + minWidth: 120, + ["@media (max-width: 446px)"]: { + marginRight: "100px", + marginBottom: "20px" + } + }, + container: { + flexDirection: "column", + justifyContent: "space-between", + backgroundColor: "white", + marginBottom: "20px", + marginLeft: "2%", + minHeight: "calc(100vh - 92.4px - 78px)", + paddingBottom: "78px", + justifyContent: "center" + }, + gridMenu: { + display: "flex", + alignItems: "center", + marginLeft: "20px" + }, + formTitle: { + marginTop: "10px" + }, + + date: { + marginLeft: "30%", + ["@media (max-width: 494px)"]: { + marginLeft: "3%" + } + } +})); + +function Jornal(props) { + const classes = useStyles(); + + /** Variable of the selected form number in an array of forms. */ + const [selectedForm, setSelectedForm] = useState(0); + + /** + * Date parser and validator. + * @param date - Date string to be parsed. + */ + function manageDate(date) { + if (date === "") { + return ""; + } + + let newDate = new Date(date); + let options = { year: "numeric", month: "2-digit", day: "2-digit" }; + return newDate.toLocaleDateString("pt-BR", options); + } + + /** + * Function to find the array of answers of a given question. + * @param questionId - Question's ID. + */ + function findAnswer(questionId) { + if (props.formArray[selectedForm].inputAnswers[questionId]) { + return Object.values( + props.formArray[selectedForm].inputAnswers[questionId] + ); + } + } + + /** + * Function to change the current page to a new one. + * @param page - Selected page. + */ + function changePage(page) { + setSelectedForm(page - 1); + } + + return ( + <> + <JornalTab + answerNumber={props.answerNumber} + pagesNum={props.formArray.length} + changePage={changePage} + /> + <Grid + container + direction="column" + className={classes.container} + alignItems="center" + justify="center" + > + <div> + <Grid container item className={classes.date}> + <Typography> + Data da resposta: {manageDate(props.timestamp[selectedForm])} + </Typography> + </Grid> + {props.formArray[selectedForm].form.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + description={input.description} + id={input.id} + answer={findAnswer(input.id)} + place={input.placement} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + id={input.id} + description={input.description} + options={input.sugestions} + answer={findAnswer(input.id)} + place={input.placement} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + options={input.sugestions} + answer={findAnswer(input.id)} + place={input.placement} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + options={input.sugestions} + id={input.id} + answer={findAnswer(input.id)} + place={input.placement} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + findAnswer={findAnswer} + place={input.placement - 1} + /> + ); + })} + </div> + </Grid> + </> + ); +} +export default Jornal; diff --git a/src/components/fieldsGetForm/JornalFolder/FormPagination.js b/src/components/fieldsGetForm/JornalFolder/FormPagination.js new file mode 100644 index 0000000..e64429c --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/FormPagination.js @@ -0,0 +1,164 @@ +import React, { useState, useEffect } from "react"; +import Grid from "@material-ui/core/Grid"; +import TextField from "@material-ui/core/TextField"; +import Button from "@material-ui/core/Button"; +import NavigateBeforeIcon from "@material-ui/icons/NavigateBefore"; +import NavigateNextIcon from "@material-ui/icons/NavigateNext"; + +import { makeStyles } from "@material-ui/core/styles"; +import { Typography } from "@material-ui/core"; +const useStyles = makeStyles(theme => ({ + container: { + flexDirection: "row", + backgroundColor: "white", + marginBottom: "20px" + }, + + text: { + width: "50px", + marginRight: "1px", + marginLeft: "1px" + }, + + button: { + fontSize: "30px", + height: "30px" + }, + + buttonDisabled: { + fontSize: "30px", + height: "30px", + color: "grey" + }, + + valid: { + color: "red" + } +})); + +function FormPagination(props) { + const classes = useStyles(); + + /** Variables declarition */ + const [selectedPage, setSelectedPage] = React.useState(1); + const [isFirst, setIsFirst] = React.useState(true); + const [isLast, setIsLast] = React.useState(false); + const [valid, setValid] = React.useState(""); + + /** + * Function that checks if a value is beetwen 0 and the last page number. + * @param value - Value to be checked. + */ + function checksValid(value) { + if (value <= 0 || value > props.pagesNum) { + return false; + } + + return true; + } + + /** + * Handler of pagination's text field. + * @param event - React event. + */ + const handlePage = event => { + checkPage(event.target.value); + setSelectedPage(event.target.value); + if (/^[0-9\b]+$/.test(event.target.value)) { + if (checksValid(event.target.value)) { + setValid(""); + props.changePage(event.target.value); + } else { + setSelectedPage(setSelectedPage); + setValid("Página não encontrada"); + } + } + }; + + /** + * Function to handle if user cicked on minus button. + */ + function handleMinus() { + checkPage(Number(selectedPage) - 1); + setSelectedPage(Number(selectedPage) - 1); + if (Number(selectedPage) - 1 <= props.pagesNum) { + setValid(""); + } + if (checksValid(selectedPage - 1)) { + props.changePage(selectedPage - 1); + } + } + + /** + * Function to handle if user cicked on plus button. + */ + function handlePlus() { + checkPage(Number(selectedPage) + 1); + setSelectedPage(Number(selectedPage) + 1); + if (Number(selectedPage) + 1 <= props.pagesNum) { + setValid(""); + } + if (checksValid(Number(selectedPage) + 1)) { + props.changePage(Number(selectedPage) + 1); + } + } + + /** + * Function to set the states of isFirs and isLast, uses a value as reference. + * @param value - Value to be used as reference. + */ + function checkPage(value) { + if (value === 1 || value === "") { + setIsFirst(true); + setIsLast(false); + } else { + setIsFirst(false); + if (value >= props.pagesNum) { + setIsLast(true); + } else { + setIsLast(false); + } + } + } + + /** Prevents a bug if there's only one page. */ + useEffect(() => { + if (props.pagesNum === 1) { + setIsLast(true); + } + }, []); + + return ( + <> + <Grid container className={classes.container}> + {isFirst ? ( + <Button disabled onClick={handleMinus}> + <NavigateBeforeIcon + color="grey" + className={classes.buttonDisabled} + /> + </Button> + ) : ( + <Button onClick={handleMinus}> + <NavigateBeforeIcon className={classes.button} /> + </Button> + )} + <Grid className={classes.text} item> + <TextField value={selectedPage} onChange={handlePage} /> + </Grid> + {isLast ? ( + <Button disabled onClick={handlePlus}> + <NavigateNextIcon className={classes.buttonDisabled} /> + </Button> + ) : ( + <Button onClick={handlePlus}> + <NavigateNextIcon className={classes.button} /> + </Button> + )} + </Grid> + <Typography className={classes.valid}>{valid}</Typography> + </> + ); +} + +export default FormPagination; diff --git a/src/components/fieldsGetForm/JornalFolder/JornalTab.js b/src/components/fieldsGetForm/JornalFolder/JornalTab.js new file mode 100644 index 0000000..417fea8 --- /dev/null +++ b/src/components/fieldsGetForm/JornalFolder/JornalTab.js @@ -0,0 +1,43 @@ +import React, { useState, useEffect } from "react"; +import FormControl from "@material-ui/core/FormControl"; +import Grid from "@material-ui/core/Grid"; +import FormPagination from "./FormPagination"; + +import { makeStyles } from "@material-ui/core/styles"; +const useStyles = makeStyles(theme => ({ + container: { + flexDirection: "row", + justifyContent: "space-between", + backgroundColor: "white", + marginBottom: "20px" + }, + + formControl: { + margin: theme.spacing(1), + minWidth: 120 + }, + + gridMenu: { + display: "flex", + alignItems: "center" + } +})); + +function JornalTab(props) { + const classes = useStyles(); + + return ( + <Grid container className={classes.container}> + <Grid item className={classes.gridMenu}> + <FormControl className={classes.formControl}> + <FormPagination + changePage={props.changePage} + pagesNum={props.pagesNum} + /> + </FormControl> + </Grid> + </Grid> + ); +} + +export default JornalTab; diff --git a/src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js b/src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js new file mode 100644 index 0000000..ebc8504 --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js @@ -0,0 +1,33 @@ +import React from "react"; +import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; +import IconButton from "@material-ui/core/IconButton"; +import Switch from "@material-ui/core/Switch"; +import FormControlLabel from "@material-ui/core/FormControlLabel"; + +function FieldFooterOptions(props) { + return ( + <> + <FormControlLabel + control={ + <Switch + onChange={e => props.setRequiredField(props.idq)} + value="required" + color="primary" + checked={props.required} + /> + } + label="Obrigatória" + /> + <IconButton + aria-label="delete" + onClick={() => { + props.deleteFromForm(props.idq); + }} + > + <DeleteOutlinedIcon /> + </IconButton> + </> + ); +} + +export default FieldFooterOptions; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldCheckbox.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldCheckbox.js new file mode 100644 index 0000000..8c71c26 --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldCheckbox.js @@ -0,0 +1,93 @@ +import React, { useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Typography from "@material-ui/core/Typography"; +import ExpansionPanel from "@material-ui/core/ExpansionPanel"; +import ExpansionPanelSummary from "@material-ui/core/ExpansionPanelSummary"; +import ExpansionPanelDetails from "@material-ui/core/ExpansionPanelDetails"; +import ArrowDownwardOutlinedIcon from "@material-ui/icons/ArrowDownwardOutlined"; +import Checkbox from "@material-ui/core/Checkbox"; +import Tooltip from "@material-ui/core/Tooltip"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + }, + expPainelD: { + display: "block" + }, + type: { + width: "50px" + } +})); + +function FormFieldCheckbox(props) { + const classes = useStyles(); + + /** HTML object to be displayed on component return. */ + const options = props.options.map((x, index) => { + return props.answer[x.placement] ? ( + <Typography + style={{ wordWrap: "break-word" }} + gutterBottom + className={classes.text} + > + Opção {x.value} foi marcada por {props.answer[x.placement]} pessoa(s). + </Typography> + ) : ( + <Typography style={{ wordWrap: "break-word" }} gutterBottom> + Opção {x.value} não foi marcada. + </Typography> + ); + }); + + return ( + <ExpansionPanel className={classes.paper}> + <ExpansionPanelSummary expandIcon={<ArrowDownwardOutlinedIcon />}> + <Grid item xs={12} className={classes.questionsGrid}> + <Tooltip placement="left" title="Múltipla escolha" arrow> + <Grid container className={classes.type}> + <Checkbox disabled /> + </Grid> + </Tooltip> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> + </Grid> + </ExpansionPanelSummary> + <ExpansionPanelDetails className={classes.expPainelD}> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + {options} + </Grid> + </ExpansionPanelDetails> + </ExpansionPanel> + ); +} + +export default FormFieldCheckbox; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldRadio.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldRadio.js new file mode 100644 index 0000000..65f1086 --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldRadio.js @@ -0,0 +1,96 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import ExpansionPanel from "@material-ui/core/ExpansionPanel"; +import ExpansionPanelSummary from "@material-ui/core/ExpansionPanelSummary"; +import ExpansionPanelDetails from "@material-ui/core/ExpansionPanelDetails"; +import ArrowDownwardOutlinedIcon from "@material-ui/icons/ArrowDownwardOutlined"; +import Typography from "@material-ui/core/Typography"; +import Radio from "@material-ui/core/Radio"; +import Tooltip from "@material-ui/core/Tooltip"; +import RadioGroup from "@material-ui/core/RadioGroup"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + }, + expPainelD: { + display: "block" + }, + type: { + width: "50px" + } +})); + +function FormFieldRadio(props) { + const classes = useStyles(); + + /** HTML object to be displayed on component return. */ + const options = props.options.map(function(x, index) { + return props.answer[x.placement] ? ( + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + gutterBottom + > + Opção {x.value} foi marcada por {props.answer[x.placement]} pessoa(s). + </Typography> + ) : ( + <Typography style={{ wordWrap: "break-word" }} gutterBottom> + Opção {x.value} não foi marcada. + </Typography> + ); + }); + + return ( + <ExpansionPanel className={classes.paper}> + <ExpansionPanelSummary expandIcon={<ArrowDownwardOutlinedIcon />}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Tooltip placement="left" title="Seleção única" arrow> + <Grid container className={classes.type}> + <Radio disabled /> + </Grid> + </Tooltip> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> + </Grid> + </Grid> + </ExpansionPanelSummary> + <ExpansionPanelDetails className={classes.expPainelD}> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + <RadioGroup>{options}</RadioGroup> + </Grid> + </ExpansionPanelDetails> + </ExpansionPanel> + ); +} + +export default FormFieldRadio; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldSelect.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldSelect.js new file mode 100644 index 0000000..17e5398 --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldSelect.js @@ -0,0 +1,95 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import ExpansionPanel from "@material-ui/core/ExpansionPanel"; +import ExpansionPanelSummary from "@material-ui/core/ExpansionPanelSummary"; +import ExpansionPanelDetails from "@material-ui/core/ExpansionPanelDetails"; +import ArrowDownwardOutlinedIcon from "@material-ui/icons/ArrowDownwardOutlined"; +import Typography from "@material-ui/core/Typography"; +import Select from "@material-ui/core/Select"; +import Tooltip from "@material-ui/core/Tooltip"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + }, + expPainelD: { + display: "block" + }, + type: { + width: "50px" + } +})); + +function FormFieldSelect(props) { + const classes = useStyles(); + + /** HTML object to be displayed on component return. */ + const options = props.options.map(function(x) { + return props.answer[x.placement] ? ( + <Typography style={{ wordWrap: "break-word" }} gutterBottom> + Opção {x.value} foi marcada por {props.answer[x.placement]} pessoa(s). + </Typography> + ) : ( + <Typography style={{ wordWrap: "break-word" }} gutterBottom> + Opção {x.value} não foi marcada. + </Typography> + ); + }); + + return ( + <ExpansionPanel className={classes.paper}> + <ExpansionPanelSummary expandIcon={<ArrowDownwardOutlinedIcon />}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Tooltip placement="left" title="Lista Suspensa" arrow> + <Grid container className={classes.type}> + <Select disabled /> + </Grid> + </Tooltip> + <Typography + style={{ wordWrap: "break-word" }} + lassName={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography + style={{ wordWrap: "break-word" }} + variant="h8" + gutterBottom + > + {props.description} + </Typography> + </Grid> + </Grid> + </ExpansionPanelSummary> + <ExpansionPanelDetails className={classes.expPainelD}> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + {options} + </Grid> + </ExpansionPanelDetails> + </ExpansionPanel> + ); +} + +export default FormFieldSelect; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js new file mode 100644 index 0000000..50d40f9 --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js @@ -0,0 +1,126 @@ +import React, { useState, useEffect } from "react"; +import { useParams } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import api from "../../../api"; + +import FormFieldText from "./FormFieldText"; +import FormFieldSelect from "./FormFieldSelect"; +import FormFieldRadio from "./FormFieldRadio"; +import FormFieldCheckbox from "./FormFieldCheckbox"; + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + } +})); + +function FormFieldSubform(props) { + const classes = useStyles(); + + /** Subform id */ + const id = props.id; + + /** Maped subform */ + const [formData, setFormData] = useState(0); + + /** Get subform */ + async function getForm(id) { + const res = await api + .get(`/form/${id}`) + .then(function(res) { + setFormData(res.data); + }) + .catch(error => { + alert( + "Um erro inesperado ocorreu ao tentar obter o subform na tela de resumo." + ); + }); + } + + /** First gets info from the backend */ + useEffect(() => { + getForm(id); + }, []); + + return ( + <> + <Grid + container + direction="column" + className={classes.container} + alignItems="center" + justify="center" + > + {formData ? ( + <div> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + description={input.description} + id={input.id} + answers={props.findAnswer(input.id)} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + id={input.id} + description={input.description} + options={input.sugestions} + answer={props.result(input.id)} + place={input.placement} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + options={input.sugestions} + answer={props.result(input.id)} + place={input.placement} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + options={input.sugestions} + id={input.id} + answer={props.result(input.id)} + place={input.placement} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + result={props.result} + findAnswer={props.findAnswer} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + </Grid> + </> + ); +} + +export default FormFieldSubform; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldText.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldText.js new file mode 100644 index 0000000..6b94208 --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldText.js @@ -0,0 +1,144 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import ExpansionPanel from "@material-ui/core/ExpansionPanel"; +import ExpansionPanelSummary from "@material-ui/core/ExpansionPanelSummary"; +import ExpansionPanelDetails from "@material-ui/core/ExpansionPanelDetails"; +import ArrowDownwardOutlinedIcon from "@material-ui/icons/ArrowDownwardOutlined"; +import Typography from "@material-ui/core/Typography"; +import TextFieldsIcon from "@material-ui/icons/TextFields"; +import Tooltip from "@material-ui/core/Tooltip"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + marginBottom: "2%", + ["@media (max-width: 896px)"]: { + width: "300px" + } + }, + answersGrid: { + flexDirection: "column", + color: "black" + }, + description: { + marginBottom: "10px" + }, + questionsGrid: { + marginBottom: "10px" + }, + expPainelD: { + display: "block" + }, + answer: { + color: "black", + marginBottom: "5px", + background: "#80d4ff" + }, + noAnswer: { + color: "black", + marginBottom: "5px" + }, + type: { + width: "50px" + } +})); + +function FormFieldText(props) { + const classes = useStyles(); + + /** Counter to text answers. */ + let counter = 0; + + /** HTML object to be displayed on component return. */ + const answer = props.answers.map(function(value) { + counter += 1; + if (!value) { + return ( + <> + <Typography>{counter}:</Typography> + <Paper className={classes.noAnswer}> + <Typography + container + wrap="wrap" + style={{ wordWrap: "break-word" }} + variant="body1" + > + Não respondido. + </Typography> + </Paper> + </> + ); + } + return ( + <> + <Typography>{counter}:</Typography> + <Paper className={classes.answer}> + <Typography + container + wrap="wrap" + style={{ wordWrap: "break-word" }} + variant="body1" + > + {value} + </Typography> + </Paper> + </> + ); + }); + + /** + * Function to check if there's an answer to be display. + * @param ans - Answer array. + */ + function checkAnswer(ans) { + if (ans.length) { + return ans; + } + + return "Não há respostas."; + } + + return ( + <ExpansionPanel className={classes.paper}> + <ExpansionPanelSummary expandIcon={<ArrowDownwardOutlinedIcon />}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Tooltip placement="left" title="Texto" arrow> + <Grid container className={classes.type}> + <TextFieldsIcon /> + </Grid> + </Tooltip> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + gutterBottom + > + {"Pergunta: " + props.question} + </Typography> + <Grid className={classes.description} container> + <Typography + style={{ wordWrap: "break-word" }} + container + item + variant="h8" + > + {"Descrição: " + props.description} + </Typography> + </Grid> + </Grid> + </Grid> + </ExpansionPanelSummary> + <ExpansionPanelDetails className={classes.expPainelD}> + <Grid container wrap="wrap" container className={classes.answersGrid}> + {checkAnswer(answer)} + </Grid> + </ExpansionPanelDetails> + </ExpansionPanel> + ); +} + +export default FormFieldText; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js new file mode 100644 index 0000000..cf2c22e --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js @@ -0,0 +1,93 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: theme.spacing(22), + margin: theme.spacing(2), + color: "#000000", + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } + }, + questionsGrid: { + marginBottom: "20px", + color: "#000000", + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + } + }, + title: { + fontSize: "45px", + color: "#000000", + ["@media (max-width:827px)"]: { + fontSize: "35px" + }, + ["@media (max-width:590px)"]: { + fontSize: "25px" + } + }, + description: { + fontSize: "30px", + color: "#000000", + ["@media (max-width:827px)"]: { + fontSize: "25px" + }, + ["@media (max-width:590px)"]: { + fontSize: "15px" + } + } +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Grid> + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.title} + variant="h3" + gutterBottom + > + {props.title} + </Typography> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.description} + variant="h4" + gutterBottom + > + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + ></Grid> + </Grid> + </Paper> + </Grid> + ); +} + +export default FormFieldText; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormSummary.js b/src/components/fieldsGetForm/SummaryFolder/FormSummary.js new file mode 100644 index 0000000..660eb19 --- /dev/null +++ b/src/components/fieldsGetForm/SummaryFolder/FormSummary.js @@ -0,0 +1,161 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; + +import FormFieldText from "./FormFieldText"; +import FormFieldSelect from "./FormFieldSelect"; +import FormFieldRadio from "./FormFieldRadio"; +import FormFieldCheckbox from "./FormFieldCheckbox"; +import FormFieldSubform from "./FormFieldSubform"; + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + }, + + formControl: { + margin: theme.spacing(1), + minWidth: 120, + ["@media (max-width: 446px)"]: { + marginRight: "100px", + marginBottom: "20px" + } + }, + container: { + flexDirection: "column", + justifyContent: "space-between", + backgroundColor: "white", + marginBottom: "20px", + marginTop: "25px", + marginLeft: "2%", + minHeight: "calc(100vh - 92.4px - 78px)", + paddingBottom: "78px", + justifyContent: "center" + }, + gridMenu: { + display: "flex", + alignItems: "center", + marginLeft: "20px" + }, + formTitle: { + marginTop: "10px" + } +})); +function Summary(props) { + const classes = useStyles(); + + /** + * Finds all the answers from a question. + * @param questionId - Qustion's ID to have answers associated with. + * @returns - All the question's answer in an array + */ + function findAnswer(questionId) { + let tmp = []; + props.answers.filter(value => { + if (value[questionId]) { + tmp.push(value[questionId][0].value); + } else { + tmp.push(""); + } + }); + return tmp; + } + + /** + * Function to count how many answers a checkbox/radio/select has + * @param questionId - Question's ID. + */ + function result(questionId) { + let result = []; + props.formArray.map(form => { + if (form.inputAnswers[questionId]) { + form.inputAnswers[questionId].map((answer, index) => { + if (answer.value === "true") { + if (result[index]) { + result[index] += 1; + } else { + result[index] = 1; + } + } + }); + } + }); + return result; + } + + return ( + <> + <Grid + container + direction="column" + className={classes.container} + alignItems="center" + justify="center" + > + <div> + {props.formArray[0].form.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + description={input.description} + id={input.id} + answers={findAnswer(input.id)} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + id={input.id} + description={input.description} + options={input.sugestions} + answer={result(input.id)} + place={input.placement} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + options={input.sugestions} + answer={result(input.id)} + place={input.placement} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + options={input.sugestions} + id={input.id} + answer={result(input.id)} + place={input.placement} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + result={result} + findAnswer={findAnswer} + /> + ); + })} + </div> + </Grid> + </> + ); +} +export default Summary; diff --git a/src/pages/GetForm.js b/src/pages/GetForm.js new file mode 100644 index 0000000..fb24c5f --- /dev/null +++ b/src/pages/GetForm.js @@ -0,0 +1,229 @@ +import React, { useState, useEffect } from "react"; +import { useParams, Route, Redirect } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import api from "../api"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import FormControl from "@material-ui/core/FormControl"; +import MenuItem from "@material-ui/core/MenuItem"; +import Select from "@material-ui/core/Select"; +import FormHelperText from "@material-ui/core/FormHelperText"; +import Typography from "@material-ui/core/Typography"; + +import Jornal from "../components/fieldsGetForm/JornalFolder/FormJornal"; +import Summary from "../components/fieldsGetForm/SummaryFolder/FormSummary"; +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + }, + selector: { + width: "100%", + borderRadius: "2px", + padding: "10px 20px" + }, + formControl: { + margin: theme.spacing(1), + minWidth: 120, + ["@media (max-width: 738px)"]: { + marginBottom: "20px", + marginLeft: "225px" + }, + ["@media (max-width: 460px)"]: { + marginLeft: "20px" + } + }, + container: { + flexDirection: "row", + justifyContent: "space-between", + backgroundColor: "white", + marginBottom: "20px" + }, + answerNum: { + display: "flex", + alignItems: "center", + marginLeft: "20px", + ["@media (max-width: 654px)"]: { + marginBottom: "10px", + marginLeft: "225px" + }, + ["@media (max-width: 460px)"]: { + marginLeft: "20px" + } + }, + formTitle: { + textAlign: "center", + marginTop: "10px", + width: "450px", + ["@media (max-width: 738px)"]: { + marginBottom: "20px", + marginRight: "50px" + }, + ["@media (max-width: 654px)"]: { + marginBottom: "10px", + marginLeft: "100px" + }, + ["@media (max-width: 460px)"]: { + marginLeft: "20px" + } + } +})); + +const theme = createMuiTheme({ + overrides: { + MuiInput: { + underline: { + "&:before": { + borderBottom: "1px solid #35c7fc" + }, + "&:after": { + borderBottom: "1px solid #3f51b5" + } + } + }, + MuiButton: { + label: { + color: "black" + } + } + } +}); + +function GetForm() { + const classes = useStyles(); + + /** Form id got from the browser's URL */ + const { id } = useParams(); + + /** Maped form from backend */ + const [formArray, setFormArray] = useState([]); + const [answers, setAnswers] = useState([]); + const [answerNum, setAnswerNum] = useState(0); + const [isReady, setIsReady] = useState(false); + const [selectedValue, setSelectedValue] = useState(""); + const [times, setTimes] = useState([]); + const [toLogin, setToLogin] = useState(false); + + /** + * Set selectedValue variable to the right value. + */ + const handleChange = event => { + setSelectedValue(event.target.value); + }; + + /** + * Function to get form object from the API. + * @param id - Form id got from the broswer's URL + */ + async function getForm(id) { + const res = await api + .get(`/answer/${id}`, { + headers: { + authorization: `bearer ${window.sessionStorage.getItem("token")}` + } + }) + .then(function(res) { + if (!res.data.length) { + alert("Não há respostas!"); + return; + } + setFormArray(res.data); + res.data.map(value => { + answers.push(value.inputAnswers); + times.push(value.timestamp); + }); + getAnswerNumber(id); + }) + .catch(error => { + if (error.response.status === 401) { + setToLogin(true); + return; + } + + if (error.response.status === 500) { + if (error.response.data.error === "User dont own this form.") { + alert("Você não é o dono deste formulário."); + } else { + alert("Ocorreu um erro inesperado. Tente novamente mais tarde."); + } + } + return; + }); + } + + /** + * Gets the number of answers from a form. + * @param id - Form's id. + */ + async function getAnswerNumber(id) { + const res = await api + .get(`/answerNumber/${id}`) + .then(function(res) { + setAnswerNum(res.data.answerNumber); + }) + .catch(error => { + alert( + "Um erro inesperado ocorreu. Contate os desenvolvedores (código 500-2)" + ); + }); + setIsReady(true); + } + + /** First thing the page does is getting the form from the API. */ + useEffect(() => { + getForm(id); + }, []); + + return toLogin ? ( + <Redirect to="/signin" /> + ) : isReady ? ( + <Grid container className={classes.container}> + <Grid item className={classes.answerNum}> + <Typography style={{ wordWrap: "break-word" }} variant="h5"> + {answerNum + " Respostas"} + </Typography> + </Grid> + <Grid item className={classes.formTitle}> + <Typography style={{ wordWrap: "break-word" }} variant="h4"> + {formArray[0].form.title} + </Typography> + </Grid> + <Grid item> + <FormControl className={classes.formControl}> + <Select + value={selectedValue} + onChange={handleChange} + displayEmpty + className={classes.selector} + inputProps={{ "aria-label": "Without label" }} + > + <MenuItem value=""> + <em>Jornal</em> + </MenuItem> + <MenuItem value={1}>Resumo</MenuItem> + </Select> + <FormHelperText>Visualização</FormHelperText> + </FormControl> + </Grid> + <Grid container item> + {selectedValue ? ( + <Summary formArray={formArray} answers={answers} /> + ) : ( + <Jornal + formArray={formArray} + timestamp={times} + answerNumber={answerNum} + /> + )} + </Grid> + </Grid> + ) : ( + <p>loading...</p> + ); +} + +export default GetForm; -- GitLab From 7d75298c054910093beead0e91ac116513b99195 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Wed, 22 Jul 2020 12:01:23 -0300 Subject: [PATCH 39/72] Issue #21: Minor fix on listForms responsivity Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/components/fieldsListForms/Tab.jsx | 5 ++-- src/pages/ListForms.js | 40 +++++++++++++++----------- 2 files changed, 27 insertions(+), 18 deletions(-) diff --git a/src/components/fieldsListForms/Tab.jsx b/src/components/fieldsListForms/Tab.jsx index 721bf7e..50a2fec 100644 --- a/src/components/fieldsListForms/Tab.jsx +++ b/src/components/fieldsListForms/Tab.jsx @@ -2,11 +2,11 @@ import React, { useState, useEffect } from "react"; import Button from "@material-ui/core/Button"; import FormControl from "@material-ui/core/FormControl"; import Grid from "@material-ui/core/Grid"; -import InputLabel from "@material-ui/core/InputLabel"; import MenuItem from "@material-ui/core/MenuItem"; import Select from "@material-ui/core/Select"; import FormHelperText from "@material-ui/core/FormHelperText"; import SearchBar from "./SearchBar.jsx"; +import { useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; const useStyles = makeStyles(theme => ({ @@ -68,6 +68,7 @@ const useStyles = makeStyles(theme => ({ function Tab(props) { const classes = useStyles(); + const history = useHistory(); const [seletectedValue, setseletectedValue] = React.useState(""); /** Function to handle event */ @@ -110,4 +111,4 @@ function Tab(props) { ); } -export default Tab; \ No newline at end of file +export default Tab; diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index 92d90d4..a09fc5b 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -8,8 +8,13 @@ import { makeStyles } from "@material-ui/core/styles"; // Components import CardForm from "../components/fieldsListForms/CardForm.jsx"; import Tab from "../components/fieldsListForms/Tab.jsx"; - +const useStyles = makeStyles(theme => ({ + body: { + marginBottom: "15%" + } +})); export default function ListForms() { + const classes = useStyles(); // Get the ID from the URL const { id } = useParams(); @@ -21,7 +26,7 @@ export default function ListForms() { /** * Sorting function to sort the forms by some especified type. - * @param type - the type of the sorting that was selected. + * @param type - the type of the sorting that was selected. */ function sort(type) { setAuxForms([]); @@ -38,20 +43,23 @@ export default function ListForms() { const tmp = [...forms].sort((a, b) => a.answersNumber < b.answersNumber); setAuxForms(tmp); } else if (type === 4) { - let tmp = [...forms].filter(value => { - return value.date; - }).sort((a, b) => a.date > b.date).concat( - [...forms].filter(value => { - return value.date === ""; + let tmp = [...forms] + .filter(value => { + return value.date; }) - ); + .sort((a, b) => a.date > b.date) + .concat( + [...forms].filter(value => { + return value.date === ""; + }) + ); setAuxForms(tmp); } } /** * Function to search for a form title. - * @param string - the string value to be searched. + * @param string - the string value to be searched. */ function searching(string) { setAuxForms( @@ -66,7 +74,7 @@ export default function ListForms() { * @param id - the user's id to have the forms listed. */ async function fetchData(id) { - const res = await api.get(`/user/list/${id}`).then(function (res) { + const res = await api.get(`/user/list/${id}`).then(function(res) { setForms(res.data.sort((a, b) => a.id > b.id)); setAuxForms(res.data.sort((a, b) => a.id > b.id)); setisLoaded(true); @@ -81,7 +89,7 @@ export default function ListForms() { <div> <Tab sort={sort} searching={searching} /> <Container> - <Grid container spacing={3}> + <Grid container spacing={3} className={classes.body}> {auxForms.map(form => ( <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> <CardForm @@ -97,8 +105,8 @@ export default function ListForms() { </Container> </div> ) : ( - <Grid justify="center"> - <p>loading...</p> - </Grid> - ); -} \ No newline at end of file + <Grid justify="center"> + <p>loading...</p> + </Grid> + ); +} -- GitLab From ced646cfe4ad472de8806a400cb98f720ccae255 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Fri, 24 Jul 2020 09:23:49 -0300 Subject: [PATCH 40/72] Issue #22: Fix answer page form description. --- .../fieldsAnswerForm/FormFieldTitle.js | 70 +++++++++---------- src/pages/AnswerForm.js | 24 +++++-- 2 files changed, 54 insertions(+), 40 deletions(-) diff --git a/src/components/fieldsAnswerForm/FormFieldTitle.js b/src/components/fieldsAnswerForm/FormFieldTitle.js index cf2c22e..9a41a54 100644 --- a/src/components/fieldsAnswerForm/FormFieldTitle.js +++ b/src/components/fieldsAnswerForm/FormFieldTitle.js @@ -10,7 +10,7 @@ const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - height: theme.spacing(22), + height: "40%", margin: theme.spacing(2), color: "#000000", ["@media (max-width:827px)"]: { @@ -38,10 +38,10 @@ const useStyles = makeStyles(theme => ({ } }, description: { - fontSize: "30px", + fontSize: "25px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "25px" + fontSize: "20px" }, ["@media (max-width:590px)"]: { fontSize: "15px" @@ -53,40 +53,38 @@ function FormFieldText(props) { const classes = useStyles(); return ( - <Grid> - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <Typography - style={{ wordWrap: "break-word" }} - className={classes.title} - variant="h3" - gutterBottom - > - {props.title} - </Typography> - </Grid> - <Grid item xs={9} className={classes.questionsGrid}> - <Typography - style={{ wordWrap: "break-word" }} - className={classes.description} - variant="h4" - gutterBottom - > - {props.description} - </Typography> - </Grid> - <Grid - item - container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - ></Grid> + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.title} + variant="h3" + gutterBottom + > + {props.title} + </Typography> + </Grid> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.description} + variant="h6" + gutterBottom + > + {props.description} + </Typography> </Grid> - </Paper> - </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + ></Grid> + </Grid> + </Paper> ); } diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index f09d9e0..47fc791 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -164,6 +164,10 @@ function AnwserForm() { .post(`/answer/${id}`, backendTranslation()) .then(function(res) { alert("Formulário respondido!"); + }) + .catch(error => { + alert("Ocorreu um erro ao responder seu formulário."); + return; }); } @@ -200,10 +204,22 @@ function AnwserForm() { * @param id - Form id got from the broswer's URL */ async function getForm(id) { - const res = await api.get(`/form/${id}`).then(function(res) { - setFormData(res.data); - mapInputs(res.data); - }); + const res = await api + .get(`/form/${id}`) + .then(function(res) { + setFormData(res.data); + mapInputs(res.data); + }) + .catch(error => { + if (error.response.status === 401) { + alert("Você não está logado."); + return; + } + if (error.response.status === 500) { + alert("Ocorreu um erro: formulário não encontrado."); + return; + } + }); } /** First thing the page does is getting the form from the API. */ -- GitLab From 434e61968ba043549a3fa952ed8326b4447cd8b0 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 27 Jul 2020 09:15:44 -0300 Subject: [PATCH 41/72] Issue #14: Redirecting pages --- src/App.js | 2 + src/components/fieldsListForms/CardForm.jsx | 34 +++- .../fieldsListForms/ShareButton.jsx | 4 +- src/components/fieldsListForms/Tab.jsx | 11 +- .../fieldsVisualizeForm/FieldFooterOptions.js | 40 ++++ .../fieldsVisualizeForm/FormFieldCheckbox.js | 85 +++++++++ .../fieldsVisualizeForm/FormFieldRadio.js | 86 +++++++++ .../fieldsVisualizeForm/FormFieldSelect.js | 85 +++++++++ .../fieldsVisualizeForm/FormFieldSubform.js | 110 +++++++++++ .../fieldsVisualizeForm/FormFieldText.js | 73 ++++++++ .../fieldsVisualizeForm/FormFieldTitle.js | 93 ++++++++++ src/components/footer/footer.js | 19 +- src/components/header/header.jsx | 69 ++++--- .../header/header_components/MenuList.jsx | 107 +++++++---- src/contexts/FormContext.js | 27 ++- src/contexts/useForm.js | 35 ++-- src/pages/AnswerForm.js | 5 +- src/pages/ListForms.js | 21 ++- src/pages/SignIn.js | 48 ++--- src/pages/SignUp.js | 48 ++--- src/pages/VisualizeForm.js | 171 ++++++++++++++++++ 21 files changed, 1025 insertions(+), 148 deletions(-) create mode 100644 src/components/fieldsVisualizeForm/FieldFooterOptions.js create mode 100644 src/components/fieldsVisualizeForm/FormFieldCheckbox.js create mode 100644 src/components/fieldsVisualizeForm/FormFieldRadio.js create mode 100644 src/components/fieldsVisualizeForm/FormFieldSelect.js create mode 100644 src/components/fieldsVisualizeForm/FormFieldSubform.js create mode 100644 src/components/fieldsVisualizeForm/FormFieldText.js create mode 100644 src/components/fieldsVisualizeForm/FormFieldTitle.js create mode 100644 src/pages/VisualizeForm.js diff --git a/src/App.js b/src/App.js index 64dc8a2..be756c9 100644 --- a/src/App.js +++ b/src/App.js @@ -10,10 +10,12 @@ import SignIn from "./pages/SignIn"; import ListForms from "./pages/ListForms"; import EditForm from "./pages/EditForm"; import GetForm from "./pages/GetForm"; +import VisualizeForm from "./pages/VisualizeForm"; function App() { return ( <HashRouter> <Header /> + <Route path="/visualize/:id" component={VisualizeForm} /> <Route path="/create" component={CreateForm} /> <Route path="/answer/:id" component={AnswerForm} /> <Route path="/edit/:id" component={EditForm} /> diff --git a/src/components/fieldsListForms/CardForm.jsx b/src/components/fieldsListForms/CardForm.jsx index 40fc1f8..102d08e 100644 --- a/src/components/fieldsListForms/CardForm.jsx +++ b/src/components/fieldsListForms/CardForm.jsx @@ -7,7 +7,7 @@ import IconButton from "@material-ui/core/IconButton"; import Tooltip from "@material-ui/core/Tooltip"; import Typography from "@material-ui/core/Typography"; import { makeStyles } from "@material-ui/core/styles"; - +import { useHistory } from "react-router-dom"; // Icons import MoreVertOutlinedIcon from "@material-ui/icons/MoreVertOutlined"; import DeleteButton from "./DeleteButton"; @@ -56,6 +56,13 @@ const useStyles = makeStyles(theme => ({ color: "#667079" }, + icons: { + marginLeft: "20%", + ["@media (max-width: 370px)"]: { + marginLeft: "10%" + } + }, + numberOfAnswers: { fontSize: 18, textAlign: "left", @@ -65,25 +72,36 @@ const useStyles = makeStyles(theme => ({ function CardForm(props) { const classes = useStyles(); + const history = useHistory(); const handleAnswer = () => { //redirecionar para /answer/props.id + let path = `/form/${props.id}`; + history.push(path); }; const handleVisualize = () => { //redirecionar para /visual/props.id + let path = `/visualize/${props.id}`; + history.push(path); }; const handleEdit = () => { //redirecionar para /edit/props.id + let path = `/edit/${props.id}`; + history.push(path); }; function handleDelete(value) { if (value) { - //deletar o form + // deleteForm(); } } + async function deleteForm() { + // const res = await api + } + function manageDate(date) { if (date === "") { return ""; @@ -97,12 +115,10 @@ function CardForm(props) { return ( <ExpansionPanel> <ExpansionPanelSummary expandIcon={<MoreVertOutlinedIcon />}> - <Typography className={classes.title}> + <Typography noWrap className={classes.title}> {props.title} <br /> - <div className={classes.create} noWrap> - {props.description} - </div> + <div className={classes.create}>{props.description}</div> <Divider /> <div className={classes.numberOfAnswers}> {props.numberOfAnswers} Respostas @@ -113,7 +129,7 @@ function CardForm(props) { <Typography className={classes.date}> {props.date ? "Data de modificação: " + manageDate(props.date) : ""} </Typography> - <Tooltip title="Editar" arrow> + <Tooltip className={classes.icons} title="Editar" arrow> <IconButton onClick={handleEdit}> <EditOutlinedIcon /> </IconButton> @@ -133,10 +149,10 @@ function CardForm(props) { </IconButton> </Tooltip> - <DeleteButton handleDelete={handleDelete} /> + {/*<DeleteButton handleDelete={handleDelete} />*/} </ExpansionPanelDetails> </ExpansionPanel> ); } -export default CardForm; \ No newline at end of file +export default CardForm; diff --git a/src/components/fieldsListForms/ShareButton.jsx b/src/components/fieldsListForms/ShareButton.jsx index 7ef16fc..c93a55e 100644 --- a/src/components/fieldsListForms/ShareButton.jsx +++ b/src/components/fieldsListForms/ShareButton.jsx @@ -35,7 +35,7 @@ function ShareButton(props) { > <DialogTitle id="responsive-dialog-title"> { - "Aqui está a URL do seu formulário, copie-a e envie-a para ser respondida: " + "Aqui está a URL do seu formulário, copie-a e envie-a para ser respondido: " } </DialogTitle> <DialogContent> @@ -48,4 +48,4 @@ function ShareButton(props) { ); } -export default ShareButton; \ No newline at end of file +export default ShareButton; diff --git a/src/components/fieldsListForms/Tab.jsx b/src/components/fieldsListForms/Tab.jsx index 50a2fec..fdcc5dc 100644 --- a/src/components/fieldsListForms/Tab.jsx +++ b/src/components/fieldsListForms/Tab.jsx @@ -77,6 +77,11 @@ function Tab(props) { setseletectedValue(event.target.value); }; + const handleClick = () => { + let path = `/create`; + history.push(path); + }; + return ( <Grid container className={classes.container}> <Grid item className={classes.gridMenu}> @@ -103,7 +108,11 @@ function Tab(props) { <SearchBar searching={props.searching} /> </Grid> <Grid item className={classes.gridButton}> - <Button className={classes.button} variant="contained"> + <Button + className={classes.button} + onClick={handleClick} + variant="contained" + > CRIAR NOVO FORMULÃRIO </Button> </Grid> diff --git a/src/components/fieldsVisualizeForm/FieldFooterOptions.js b/src/components/fieldsVisualizeForm/FieldFooterOptions.js new file mode 100644 index 0000000..f6446f0 --- /dev/null +++ b/src/components/fieldsVisualizeForm/FieldFooterOptions.js @@ -0,0 +1,40 @@ +import React from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import TextField from '@material-ui/core/TextField'; +import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; +import IconButton from '@material-ui/core/IconButton'; +import Select from '@material-ui/core/Select'; +import MenuItem from '@material-ui/core/MenuItem'; +import AddCircleIcon from '@material-ui/icons/AddCircle'; +import CloseIcon from '@material-ui/icons/Close'; +import Switch from '@material-ui/core/Switch'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; + +function FieldFooterOptions(props) { + + return ( + <> + <FormControlLabel + control={ + <Switch + onChange={e => props.setRequiredField(props.idq) } + value="required" + color="primary" + checked={props.required} + /> + } + label="Obrigatória" + /> + <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> + <DeleteOutlinedIcon /> + </IconButton> + </> + ); + + +} + + +export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/fieldsVisualizeForm/FormFieldCheckbox.js b/src/components/fieldsVisualizeForm/FormFieldCheckbox.js new file mode 100644 index 0000000..2ff9e25 --- /dev/null +++ b/src/components/fieldsVisualizeForm/FormFieldCheckbox.js @@ -0,0 +1,85 @@ +import React, { useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; +import Checkbox from "@material-ui/core/Checkbox"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(18), + margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" + } +})); + +function FormFieldCheckbox(props) { + const classes = useStyles(); + + /** HTML to be displayed. */ + const options = props.options.map((x, index) => { + return ( + <span> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h7" + > + {x.value} + </Typography> + <Checkbox disabled /> + </span> + ); + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + {options} + </Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldCheckbox; diff --git a/src/components/fieldsVisualizeForm/FormFieldRadio.js b/src/components/fieldsVisualizeForm/FormFieldRadio.js new file mode 100644 index 0000000..c470b27 --- /dev/null +++ b/src/components/fieldsVisualizeForm/FormFieldRadio.js @@ -0,0 +1,86 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; +import Radio from "@material-ui/core/Radio"; +import RadioGroup from "@material-ui/core/RadioGroup"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(18), + margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" + } +})); + +function FormFieldRadio(props) { + const classes = useStyles(); + + /** HTML object to be displayed on component return. */ + const options = props.options.map(function(x, index) { + return ( + <span> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h7" + > + {x.value} + </Typography> + <Radio disabled value={x.value} /> + </span> + ); + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + <RadioGroup>{options}</RadioGroup> + </Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldRadio; diff --git a/src/components/fieldsVisualizeForm/FormFieldSelect.js b/src/components/fieldsVisualizeForm/FormFieldSelect.js new file mode 100644 index 0000000..a52bb58 --- /dev/null +++ b/src/components/fieldsVisualizeForm/FormFieldSelect.js @@ -0,0 +1,85 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Select from "@material-ui/core/Select"; +import MenuItem from "@material-ui/core/MenuItem"; +import Typography from "@material-ui/core/Typography"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + minheight: theme.spacing(18), + margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" + } +})); + +function FormFieldSelect(props) { + const classes = useStyles(); + + /** HTML object to be displayed on component return. */ + const options = props.options.map(function(x) { + return <MenuItem value={x.placement}>{x.value}</MenuItem>; + }); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography + style={{ wordWrap: "break-word" }} + variant="h8" + gutterBottom + > + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="column" + justify="flex-start" + alignItems="flex-start" + xs={5} + className={classes.questionsGrid} + > + <Select + labelId="demo-simple-select-label" + id="demo-simple-select" + disabled + > + {options} + </Select> + </Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldSelect; diff --git a/src/components/fieldsVisualizeForm/FormFieldSubform.js b/src/components/fieldsVisualizeForm/FormFieldSubform.js new file mode 100644 index 0000000..f87e04a --- /dev/null +++ b/src/components/fieldsVisualizeForm/FormFieldSubform.js @@ -0,0 +1,110 @@ +import React, { useState, useEffect } from "react"; +import { useParams } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Button from "@material-ui/core/Button"; +import api from "../../api"; + +import FormFieldText from "./FormFieldText"; +import FormFieldSelect from "./FormFieldSelect"; +import FormFieldRadio from "./FormFieldRadio"; +import FormFieldCheckbox from "./FormFieldCheckbox"; + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + } +})); + +function FormFieldSubform(props) { + const classes = useStyles(); + + /** Subform id */ + const id = props.id; + + /** Maped subform */ + const [formData, setFormData] = useState(0); + + /** Get subform */ + async function getForm(id) { + const res = await api + .get(`/form/${id}`) + .then(function(res) { + setFormData(res.data); + }) + .catch(error => { + alert("Um erro inesperado ocorreu ao tentar obter o subform."); + }); + } + + /** First gets info from the backend */ + useEffect(() => { + getForm(id); + }, []); + + return ( + <div> + <Grid container direction="column" alignItems="center" justify="center"> + {formData ? ( + <div> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + description={input.description} + id={input.id} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + id={input.id} + description={input.description} + options={input.sugestions} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + options={input.sugestions} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + options={input.sugestions} + id={input.id} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + </Grid> + </div> + ); +} + +export default FormFieldSubform; diff --git a/src/components/fieldsVisualizeForm/FormFieldText.js b/src/components/fieldsVisualizeForm/FormFieldText.js new file mode 100644 index 0000000..92d7cc0 --- /dev/null +++ b/src/components/fieldsVisualizeForm/FormFieldText.js @@ -0,0 +1,73 @@ +import React, { useState, useEffect } from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import TextField from "@material-ui/core/TextField"; +import Typography from "@material-ui/core/Typography"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: "15%", + margin: theme.spacing(2), + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } + }, + questionsGrid: { + marginBottom: "20px" + }, + text: { + color: "black" + }, + validation: { + fontSize: "14px", + color: "red" + } +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.text} + variant="h6" + > + {props.question} + </Typography> + <Typography style={{ wordWrap: "break-word" }} variant="h8"> + {props.description} + </Typography> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <TextField + multiline + id="outlined-disabled" + label="" + placeholder="Resposta" + disabled + /> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + ></Grid> + </Grid> + </Paper> + ); +} + +export default FormFieldText; diff --git a/src/components/fieldsVisualizeForm/FormFieldTitle.js b/src/components/fieldsVisualizeForm/FormFieldTitle.js new file mode 100644 index 0000000..530c7f3 --- /dev/null +++ b/src/components/fieldsVisualizeForm/FormFieldTitle.js @@ -0,0 +1,93 @@ +import React from "react"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import Paper from "@material-ui/core/Paper"; +import Typography from "@material-ui/core/Typography"; + +import FieldFooterOptions from "./FieldFooterOptions"; + +const useStyles = makeStyles(theme => ({ + paper: { + padding: theme.spacing(3), + width: theme.spacing(100), + height: "40%", + margin: theme.spacing(2), + color: "#000000", + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + }, + ["@media (max-width:590px)"]: { + width: theme.spacing(40) + } + }, + questionsGrid: { + marginBottom: "20px", + color: "#000000", + ["@media (max-width:827px)"]: { + width: theme.spacing(70) + } + }, + title: { + fontSize: "45px", + color: "#000000", + ["@media (max-width:827px)"]: { + fontSize: "35px" + }, + ["@media (max-width:590px)"]: { + fontSize: "25px" + } + }, + description: { + fontSize: "30px", + color: "#000000", + ["@media (max-width:827px)"]: { + fontSize: "25px" + }, + ["@media (max-width:590px)"]: { + fontSize: "15px" + } + } +})); + +function FormFieldText(props) { + const classes = useStyles(); + + return ( + <Grid> + <Paper className={classes.paper}> + <Grid container> + <Grid item xs={12} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.title} + variant="h3" + gutterBottom + > + {props.title} + </Typography> + </Grid> + <Grid item xs={9} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.description} + variant="h4" + gutterBottom + > + {props.description} + </Typography> + </Grid> + <Grid + item + container + direction="row" + justify="flex-end" + alignItems="flex-end" + xs={3} + ></Grid> + </Grid> + </Paper> + </Grid> + ); +} + +export default FormFieldText; diff --git a/src/components/footer/footer.js b/src/components/footer/footer.js index 07c7650..f538dca 100644 --- a/src/components/footer/footer.js +++ b/src/components/footer/footer.js @@ -23,15 +23,18 @@ const useStyles = makeStyles(theme => ({ marginLeft: "auto", marginRight: "auto", ["@media (min-width: 960px)"]: { - marginLeft: "5px", + marginLeft: "5px" } }, item: { display: "flex", justifyContent: "space-evenly", - flexDirection: "column", - alignItems: "center" + flexDirection: "column" + }, + + link: { + textDecoration: "none" }, text: { @@ -65,7 +68,13 @@ function Footer() { return ( <Grid container className={classes.footer}> <Grid item xs={12} sm={12} md={3} lg={2} className={classes.item}> - <img src={Logo} className={classes.img}></img> + <a + href="https://www.c3sl.ufpr.br/" + title="Ir para a página inicial do C3SL" + className={classes.link} + > + <img src={Logo} className={classes.img} /> + </a> </Grid> <Grid item md={6} lg={8} className={classes.item}> @@ -89,8 +98,6 @@ function Footer() { Telefone: 61 2027-6000 </Typography> </Grid> - - </Grid> ); } diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index d714258..8a52a8c 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -4,14 +4,14 @@ import logo from "./header_imgs/imgsimmc-01.png"; import { makeStyles } from "@material-ui/core"; import MenuListComposition from "./header_components/MenuList"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ header: { background: "#05a5dd", width: "auto", display: "flex", flexDirection: "column", justifyContent: "center", - height: "13%", + height: "13%" }, simmc: { marginTop: "5%", @@ -19,8 +19,8 @@ const useStyles = makeStyles((theme) => ({ color: "#ffffff", marginLeft: "2%", ["@media (max-width:1040px)"]: { - display: "none", - }, + display: "none" + } }, form_creator: { color: "#ffffff", @@ -29,15 +29,15 @@ const useStyles = makeStyles((theme) => ({ fontSize: "21px", ["@media (max-width:525px)"]: { marginTop: "5%", - marginLeft: "10%", + marginLeft: "10%" }, ["@media (max-width:337px)"]: { - fontSize: "19px", - }, - }, + fontSize: "19px" + } + } }, link: { - textDecoration: "none", + textDecoration: "none" }, logo: { marginLeft: "2.5%", @@ -46,18 +46,27 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:600px)"]: { width: "65px", ["@media (max-width:338px)"]: { - marginTop: "3%", - }, - }, + marginTop: "3%" + } + } }, userImgContainer: { display: "flex", - flexDirection: "column", - }, + flexDirection: "column" + } })); export default function Header() { const classes = useStyles(); + const [isLoged, setIsLoged] = React.useState(checkLoged()); + + function checkLoged() { + if (window.sessionStorage.getItem("token")) { + return true; + } + + return false; + } return ( <Grid> @@ -98,15 +107,27 @@ export default function Header() { </Grid> </Grid> <Grid container item xs={6} sm={6} md={4} justify="center"> - <a - href="https://google.com.br" // mudar para a main page quando estiver feita - title="Ir para a página inicial do Gerenciador de Formulários" - className={classes.link} - > - <h2 className={classes.form_creator}> - Gerenciador de Formulários - </h2> - </a> + {isLoged ? ( + <a + href="http://localhost:3000/#/signup" + title="Ir para a página de SignUp" + className={classes.link} + > + <h2 className={classes.form_creator}> + Gerenciador de Formulários + </h2> + </a> + ) : ( + <a + href="http://localhost:3000/#/signin" + title="Ir para a página de SignIn" + className={classes.link} + > + <h2 className={classes.form_creator}> + Gerenciador de Formulários + </h2> + </a> + )} </Grid> <Grid container @@ -118,7 +139,7 @@ export default function Header() { justify="center" alignContent="flex-end" > - <MenuListComposition /> + <MenuListComposition isLoged={isLoged} checkLoged={checkLoged} /> </Grid> </Grid> </header> diff --git a/src/components/header/header_components/MenuList.jsx b/src/components/header/header_components/MenuList.jsx index e4491ce..21bd701 100644 --- a/src/components/header/header_components/MenuList.jsx +++ b/src/components/header/header_components/MenuList.jsx @@ -5,34 +5,35 @@ import Grow from "@material-ui/core/Grow"; import Paper from "@material-ui/core/Paper"; import Popper from "@material-ui/core/Popper"; import MenuItem from "@material-ui/core/MenuItem"; +import { useHistory } from "react-router-dom"; import MenuList from "@material-ui/core/MenuList"; import { makeStyles } from "@material-ui/core/styles"; import UserImg from "./../header_imgs/user.png"; import { Avatar } from "@material-ui/core"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ menuPopUp: { alignContent: "start", ["@media (max-width:346px)"]: { - width: "23%", - }, + width: "23%" + } }, menuPopUpText: { ["@media (max-width:525px)"]: { - fontSize: "13px", - }, + fontSize: "13px" + } }, popUpPaper: { marginRight: "14%", ["@media (max-width:525px)"]: { - marginRight: "0", - }, + marginRight: "0" + } }, menuList: { alignItems: "flex-start", - color: "grey", - }, + color: "grey" + } })); /** @@ -42,14 +43,35 @@ const useStyles = makeStyles((theme) => ({ function MenuListComposition(props) { const [open, setOpen] = React.useState(false); + const history = useHistory(); + + const handleLogin = () => { + let path = `/signin`; + history.push(path); + }; const prevOpen = React.useRef(open); const anchorRef = React.useRef(null); const handleToggle = () => { - setOpen((prevOpen) => !prevOpen); + setOpen(prevOpen => !prevOpen); + }; + const handleProfile = event => { + if (window.sessionStorage.getItem("userId")) { + let path = `/list/${window.sessionStorage.getItem("userId")}`; + history.push(path); + } + + alert("Você não está logado."); + }; + const handleLogOut = event => { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + props.checkLoged(); + let path = `/signin`; + history.push(path); }; - const handleClose = (event) => { + const handleClose = event => { if (anchorRef.current && anchorRef.current.contains(event.target)) { return; } @@ -64,6 +86,7 @@ function MenuListComposition(props) { React.useEffect(() => { if (prevOpen.current === true && open === false) { anchorRef.current.focus(); + props.checkLoged(); } prevOpen.current = open; @@ -84,6 +107,7 @@ function MenuListComposition(props) { </Button> <Popper open={open} + placement="left" anchorEl={anchorRef.current} role={undefined} transition @@ -95,32 +119,51 @@ function MenuListComposition(props) { {...TransitionProps} style={{ transformOrigin: - placement === "bottom" ? "center top" : "center bottom", + placement === "bottom" ? "center top" : "center bottom" }} > <Paper className={classes.popUpPaper}> - <ClickAwayListener onClickAway={handleClose}> - <MenuList - className={classes.menuList} - autoFocusItem={open} - id="menu-list-grow" - onKeyDown={handleListKeyDown} - alignContent="flex-start" - > - <MenuItem - onClick={handleClose} - className={classes.menuPopUpText} + {props.isLoged ? ( + <ClickAwayListener onClickAway={handleClose}> + <MenuList + className={classes.menuList} + autoFocusItem={open} + id="menu-list-grow" + onKeyDown={handleListKeyDown} + alignContent="flex-start" > - Perfil - </MenuItem> - <MenuItem - onClick={handleClose} - className={classes.menuPopUpText} + <MenuItem + onClick={handleProfile} + className={classes.menuPopUpText} + > + Perfil + </MenuItem> + <MenuItem + onClick={handleLogOut} + className={classes.menuPopUpText} + > + Logout + </MenuItem> + </MenuList> + </ClickAwayListener> + ) : ( + <ClickAwayListener onClickAway={handleClose}> + <MenuList + className={classes.menuList} + autoFocusItem={open} + id="menu-list-grow" + onKeyDown={handleListKeyDown} + alignContent="flex-start" > - Logout - </MenuItem> - </MenuList> - </ClickAwayListener> + <MenuItem + onClick={handleLogin} + className={classes.menuPopUpText} + > + Login + </MenuItem> + </MenuList> + </ClickAwayListener> + )} </Paper> </Grow> )} diff --git a/src/contexts/FormContext.js b/src/contexts/FormContext.js index bd70c89..015c9e9 100644 --- a/src/contexts/FormContext.js +++ b/src/contexts/FormContext.js @@ -2,9 +2,11 @@ import React, { useState, createContext, useEffect } from "react"; import { useParams } from "react-router-dom"; import api from "../api"; import { createFrontendForm } from "../components/fieldsDisplayForm/utils/FrontEndTranslation"; +import { useHistory } from "react-router-dom"; export const FormEditionContext = createContext(); -const FormProvider = (props) => { +const FormProvider = props => { + const history = useHistory(); /** Getting the id from the route information */ const { id } = useParams(); /** Form state being started with the title in the case of the creation or 0 when editing (to be overrided by the backend data afterwards) @@ -20,19 +22,28 @@ const FormProvider = (props) => { error: { errorMsg: { question: "Este campo é obrigatório!", - description: "", - }, - }, - }, + description: "" + } + } + } ] ); /** Hook to access the API in the case a edition is being done */ useEffect(() => { const fetchData = async () => { - api.get(`/form/${id}`).then(async function (res) { - setForm(await createFrontendForm(res.data)); - }); + api + .get(`/form/${id}`) + .then(async function(res) { + setForm(await createFrontendForm(res.data)); + }) + .catch(error => { + if (error.response.status === 401) { + let path = `/signin`; + history.push(path); + return; + } + }); }; if (id) fetchData(); }, []); diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js index 71fc926..d7b17c2 100644 --- a/src/contexts/useForm.js +++ b/src/contexts/useForm.js @@ -1,13 +1,14 @@ import { useContext, useEffect } from "react"; import { FormEditionContext } from "./FormContext"; import uuid from "uuid/v4"; +import { useHistory } from "react-router-dom"; import { testQuestionTextSchema, testDescriptionTextSchema, selectOptionsTesting, testSubformSchema, selectOptionTextTesting, - testTextValidation, + testTextValidation } from "../components/fieldsDisplayForm/utils/schemas"; import { pushTitle, @@ -15,7 +16,7 @@ import { pushSelect, pushRadio, pushCheckbox, - pushSubform, + pushSubform } from "../components/fieldsDisplayForm/utils/FormComposition"; import api from "../api"; @@ -237,7 +238,7 @@ const useForm = () => { */ async function setId() { const fetchData = async () => { - await api.get(`/form/${routeId}`).then(async function (res) { + await api.get(`/form/${routeId}`).then(async function(res) { let backForm = createFrontendForm(res.data); for (let i = 1; i < backForm.length; i++) { for (let j = 1; j < form.length; j++) { @@ -247,13 +248,13 @@ const useForm = () => { "question", "description", "options", - "subformId", + "subformId" ]) !== JSON.stringify(form[j], [ "question", "description", "options", - "subformId", + "subformId" ]) || differentValidation(backForm[i], form[j]) ) { @@ -266,6 +267,7 @@ const useForm = () => { }; await fetchData(); } + const history = useHistory(); /** The submit function. It's triggered when the submit button is pressed on the interface. * Its api call may be to create or to edit a form. */ @@ -277,14 +279,19 @@ const useForm = () => { const post_response = await api .put(`/form/${routeId}`, data, { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}`, - }, + authorization: `bearer ${window.sessionStorage.getItem("token")}` + } }) - .then(function (error) { + .then(function(error) { if (!error.response) alert("Seu formulário foi atualizado com sucesso."); }) - .catch(function (error) { + .catch(function(error) { + if (error.response.status === 401) { + let path = `/signin`; + history.push(path); + return; + } if (error.response.data.error === "User dont own this form.") alert("Você não tem permissão para alterar este formulário"); else if (error.response.data.error === "Found a subform loop") @@ -297,14 +304,14 @@ const useForm = () => { const post_response = await api .post(`/form`, await createBackendForm(form), { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}`, - }, + authorization: `bearer ${window.sessionStorage.getItem("token")}` + } }) - .then(function (error) { + .then(function(error) { if (!error.response) alert("Seu formulário foi criado com sucesso."); else console.log("ERROR NO POST_RESPONSE", error); }) - .catch(function (error) { + .catch(function(error) { console.log("ERROR NO POST RESPONSE", error.response); alert("Um erro ocorreu."); }); @@ -331,7 +338,7 @@ const useForm = () => { setValidationValue, removeValidation, onDragEnd, - submit, + submit }; }; diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index 47fc791..1f46fe8 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -5,6 +5,7 @@ import Grid from "@material-ui/core/Grid"; import api from "../api"; import Button from "@material-ui/core/Button"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import { useHistory } from "react-router-dom"; import FormFieldText from "../components/fieldsAnswerForm/FormFieldText"; import FormFieldSelect from "../components/fieldsAnswerForm/FormFieldSelect"; @@ -62,6 +63,7 @@ const theme = createMuiTheme({ function AnwserForm() { const classes = useStyles(); + const history = useHistory(); /** Array of answers created when form is maped from the api */ const [answerArray, setanswerArray] = React.useState([]); @@ -212,7 +214,8 @@ function AnwserForm() { }) .catch(error => { if (error.response.status === 401) { - alert("Você não está logado."); + let path = `/signin`; + history.push(path); return; } if (error.response.status === 500) { diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index a09fc5b..2c97add 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -4,6 +4,7 @@ import { useParams } from "react-router-dom"; import Grid from "@material-ui/core/Grid"; import Container from "@material-ui/core/Container"; import { makeStyles } from "@material-ui/core/styles"; +import { useHistory } from "react-router-dom"; // Components import CardForm from "../components/fieldsListForms/CardForm.jsx"; @@ -15,6 +16,7 @@ const useStyles = makeStyles(theme => ({ })); export default function ListForms() { const classes = useStyles(); + const history = useHistory(); // Get the ID from the URL const { id } = useParams(); @@ -74,11 +76,20 @@ export default function ListForms() { * @param id - the user's id to have the forms listed. */ async function fetchData(id) { - const res = await api.get(`/user/list/${id}`).then(function(res) { - setForms(res.data.sort((a, b) => a.id > b.id)); - setAuxForms(res.data.sort((a, b) => a.id > b.id)); - setisLoaded(true); - }); + const res = await api + .get(`/user/list/${id}`) + .then(function(res) { + setForms(res.data.sort((a, b) => a.id > b.id)); + setAuxForms(res.data.sort((a, b) => a.id > b.id)); + setisLoaded(true); + }) + .catch(error => { + if (error.response.status === 401) { + let path = `/signin`; + history.push(path); + return; + } + }); } useEffect(() => { diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index 4e6b3a5..c3c9244 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -1,4 +1,5 @@ import React from "react"; +import { useHistory } from "react-router-dom"; import Grid from "@material-ui/core/Grid"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import IconButton from "@material-ui/core/IconButton"; @@ -8,7 +9,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -16,22 +17,22 @@ const useStyles = makeStyles((theme) => ({ padding: "2% 1%", margin: "0 auto", marginTop: "9%", - width: "95%", + width: "95%" }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d", + color: "#46525d" }, strong_description: { fontSize: "14px", - color: "#c2c6ca", + color: "#c2c6ca" }, form: { marginTop: "3%", alignItems: "center", - textAlign: "center", + textAlign: "center" }, button: { type: "submit", @@ -42,25 +43,26 @@ const useStyles = makeStyles((theme) => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)", + backgroundColor: "rgb(25, 109, 23)" }, ["@media (max-width:550px)"]: { - width: "55%", - }, - }, + width: "55%" + } + } })); export default function SignIn() { const classes = useStyles(); + const history = useHistory(); const [values, setValues] = React.useState({ email: "", password: "", - emailError: false, + emailError: false }); async function update(prop, event) { await setValues({ ...values, [prop]: event.target.value }); } - const handleChange = (prop) => (event) => { + const handleChange = prop => event => { if (!checkEmail()) { values.emailError = true; } else { @@ -93,17 +95,17 @@ export default function SignIn() { const response = await api .post(`/user/signIn`, { email: values.email, - hash: values.password, + hash: values.password }) - .then(function (response) { + .then(function(response) { if (!response.data.error) { - alert("Você logou com sucesso."); window.sessionStorage.setItem("token", response.data.token); window.sessionStorage.setItem("userId", response.data.id); - // redirecionar para a main page + let path = `list/${response.data.id}`; + history.push(path); } }) - .catch(function (error) { + .catch(function(error) { if (error.response) { alert( "Falha de autenticação. Certifique-se que email e senha estão corretos." @@ -121,19 +123,19 @@ export default function SignIn() { const theme = createMuiTheme({ overrides: { root: { - color: "white", + color: "white" }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc", + borderBottom: "1px solid #35c7fc" }, "&:after": { - borderBottom: "1px solid #3f51b5", - }, - }, - }, - }, + borderBottom: "1px solid #3f51b5" + } + } + } + } }); return ( <MuiThemeProvider theme={theme}> diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index e9a0af5..97472a8 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -2,13 +2,14 @@ import React from "react"; import Grid from "@material-ui/core/Grid"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import IconButton from "@material-ui/core/IconButton"; +import { useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import KeyboardArrowRightIcon from "@material-ui/icons/KeyboardArrowRight"; import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -16,22 +17,22 @@ const useStyles = makeStyles((theme) => ({ padding: "2% 1%", margin: "0 auto", marginTop: "9%", - width: "95%", + width: "95%" }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d", + color: "#46525d" }, strong_description: { fontSize: "14px", - color: "#c2c6ca", + color: "#c2c6ca" }, form: { marginTop: "3%", alignItems: "center", - textAlign: "center", + textAlign: "center" }, button: { type: "submit", @@ -42,14 +43,15 @@ const useStyles = makeStyles((theme) => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)", + backgroundColor: "rgb(25, 109, 23)" }, ["@media (max-width:550px)"]: { - width: "55%", - }, - }, + width: "55%" + } + } })); export default function SignUp() { + const history = useHistory(); const classes = useStyles(); const [values, setValues] = React.useState({ name: "", @@ -57,13 +59,13 @@ export default function SignUp() { password: "", password_confirm: "", nameError: false, - emailError: false, + emailError: false }); async function update(prop, event) { await setValues({ ...values, [prop]: event.target.value }); } - const handleChange = (prop) => (event) => { + const handleChange = prop => event => { switch (prop) { case "name": if (!checkName()) { @@ -134,15 +136,15 @@ export default function SignUp() { .post(`/user/signUp`, { email: values.email, name: values.name, - hash: values.password, + hash: values.password }) - .then(function (error) { + .then(function(error) { if (!error.response) { - alert("Usuário criado com sucesso"); - // redirecionar para a main page + let path = `signin`; + history.push(path); } }) - .catch(function (error) { + .catch(function(error) { if (error.response) { switch (error.response.data.error) { case 'duplicate key value violates unique constraint "form_user_name_key"': @@ -172,19 +174,19 @@ export default function SignUp() { const theme = createMuiTheme({ overrides: { root: { - color: "white", + color: "white" }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc", + borderBottom: "1px solid #35c7fc" }, "&:after": { - borderBottom: "1px solid #3f51b5", - }, - }, - }, - }, + borderBottom: "1px solid #3f51b5" + } + } + } + } }); return ( <MuiThemeProvider theme={theme}> diff --git a/src/pages/VisualizeForm.js b/src/pages/VisualizeForm.js new file mode 100644 index 0000000..a161ada --- /dev/null +++ b/src/pages/VisualizeForm.js @@ -0,0 +1,171 @@ +import React, { useState, useEffect } from "react"; +import { useParams } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; +import Grid from "@material-ui/core/Grid"; +import api from "../api"; +import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import { useHistory } from "react-router-dom"; + +import FormFieldText from "../components/fieldsVisualizeForm/FormFieldText"; +import FormFieldSelect from "../components/fieldsVisualizeForm/FormFieldSelect"; +import FormFieldRadio from "../components/fieldsVisualizeForm/FormFieldRadio"; +import FormFieldCheckbox from "../components/fieldsVisualizeForm/FormFieldCheckbox"; +import FormFieldTitle from "../components/fieldsVisualizeForm/FormFieldTitle"; +import FormFieldSubform from "../components/fieldsVisualizeForm/FormFieldSubform"; + +const useStyles = makeStyles(theme => ({ + menu: { + width: theme.spacing(6), + minheight: theme.spacing(15), + position: "fixed", + top: theme.spacing(10), + left: "90%", + padding: theme.spacing(1) + }, + button: { + type: "submit", + width: "100%", + background: "#6ec46c", + borderRadius: "2px", + padding: "10px 20px", + fontSize: "18px", + "&:hover": { + backgroundColor: "rgb(25, 109, 23)" + } + }, + pageBody: { + minHeight: "calc(100vh - 92.4px - 78px)", + paddingBottom: "78px" + } +})); + +const theme = createMuiTheme({ + overrides: { + MuiInput: { + underline: { + "&:before": { + borderBottom: "1px solid #35c7fc" + }, + "&:after": { + borderBottom: "1px solid #3f51b5" + } + } + }, + MuiButton: { + label: { + color: "black" + } + } + } +}); + +function VisualizeForm() { + const classes = useStyles(); + const history = useHistory(); + + /** Form id got from the browser's URL */ + const { id } = useParams(); + + /** Maped form from backend */ + const [formData, setFormData] = useState(0); + + /** + * Function to get form object from the API. + * @param id - Form id got from the broswer's URL + */ + async function getForm(id) { + const res = await api + .get(`/form/${id}`) + .then(function(res) { + setFormData(res.data); + }) + .catch(error => { + if (error.response.status === 401) { + let path = `/signin`; + history.push(path); + return; + } + + if (error.response.status === 500) { + if (error.response.data.error === "User dont own this form.") { + alert("Você não é o dono deste formulário."); + } else { + alert("Ocorreu um erro inesperado. Tente novamente mais tarde."); + } + } + return; + }); + } + + /** First thing the page does is getting the form from the API. */ + useEffect(() => { + getForm(id); + }, []); + + return ( + <MuiThemeProvider theme={theme}> + <div className={classes.pageBody}> + <Grid container direction="column" alignItems="center" justify="center"> + {formData ? ( + <div> + <FormFieldTitle + title={formData.title} + description={formData.description} + /> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + description={input.description} + id={input.id} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + id={input.id} + description={input.description} + options={input.sugestions} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + options={input.sugestions} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + options={input.sugestions} + id={input.id} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + </Grid> + </div> + </MuiThemeProvider> + ); +} + +export default VisualizeForm; -- GitLab From 27acfc850b88365713b3e5d97c584af2289fab2a Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 10 Aug 2020 09:20:49 -0300 Subject: [PATCH 42/72] Issue #23: Fixes in CSS and select logic. Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- build/asset-manifest.json | 22 -- build/favicon.ico | Bin 3870 -> 0 bytes build/index.html | 1 - build/logo192.png | Bin 5347 -> 0 bytes build/logo512.png | Bin 9664 -> 0 bytes build/manifest.json | 25 -- ...nifest.4e6796295cf8cef3d8c75de5ce61be3e.js | 26 -- build/robots.txt | 2 - build/service-worker.js | 39 --- build/static/css/main.5ecd60fb.chunk.css | 2 - build/static/css/main.5ecd60fb.chunk.css.map | 1 - build/static/js/2.6a72c269.chunk.js | 3 - build/static/js/2.6a72c269.chunk.js.LICENSE | 49 ---- build/static/js/2.6a72c269.chunk.js.map | 1 - build/static/js/main.928fa077.chunk.js | 2 - build/static/js/main.928fa077.chunk.js.map | 1 - build/static/js/runtime-main.889ad4b6.js | 2 - build/static/js/runtime-main.889ad4b6.js.map | 1 - package-lock.json | 261 +++++++++--------- package.json | 13 +- .../fieldsAnswerForm/FormFieldCheckbox.js | 3 +- .../fieldsAnswerForm/FormFieldSubform.js | 136 ++++----- .../fieldsAnswerForm/FormFieldTitle.js | 1 - .../JornalFolder/FormFieldSelect.js | 12 +- .../fieldsListForms/ShareButton.jsx | 2 +- src/pages/AnswerForm.js | 194 ++++++------- 26 files changed, 306 insertions(+), 493 deletions(-) delete mode 100644 build/asset-manifest.json delete mode 100644 build/favicon.ico delete mode 100644 build/index.html delete mode 100644 build/logo192.png delete mode 100644 build/logo512.png delete mode 100644 build/manifest.json delete mode 100644 build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js delete mode 100644 build/robots.txt delete mode 100644 build/service-worker.js delete mode 100644 build/static/css/main.5ecd60fb.chunk.css delete mode 100644 build/static/css/main.5ecd60fb.chunk.css.map delete mode 100644 build/static/js/2.6a72c269.chunk.js delete mode 100644 build/static/js/2.6a72c269.chunk.js.LICENSE delete mode 100644 build/static/js/2.6a72c269.chunk.js.map delete mode 100644 build/static/js/main.928fa077.chunk.js delete mode 100644 build/static/js/main.928fa077.chunk.js.map delete mode 100644 build/static/js/runtime-main.889ad4b6.js delete mode 100644 build/static/js/runtime-main.889ad4b6.js.map diff --git a/build/asset-manifest.json b/build/asset-manifest.json deleted file mode 100644 index c588fd2..0000000 --- a/build/asset-manifest.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "files": { - "main.css": "/static/css/main.5ecd60fb.chunk.css", - "main.js": "/static/js/main.928fa077.chunk.js", - "main.js.map": "/static/js/main.928fa077.chunk.js.map", - "runtime-main.js": "/static/js/runtime-main.889ad4b6.js", - "runtime-main.js.map": "/static/js/runtime-main.889ad4b6.js.map", - "static/js/2.6a72c269.chunk.js": "/static/js/2.6a72c269.chunk.js", - "static/js/2.6a72c269.chunk.js.map": "/static/js/2.6a72c269.chunk.js.map", - "index.html": "/index.html", - "precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js": "/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js", - "service-worker.js": "/service-worker.js", - "static/css/main.5ecd60fb.chunk.css.map": "/static/css/main.5ecd60fb.chunk.css.map", - "static/js/2.6a72c269.chunk.js.LICENSE": "/static/js/2.6a72c269.chunk.js.LICENSE" - }, - "entrypoints": [ - "static/js/runtime-main.889ad4b6.js", - "static/js/2.6a72c269.chunk.js", - "static/css/main.5ecd60fb.chunk.css", - "static/js/main.928fa077.chunk.js" - ] -} \ No newline at end of file diff --git a/build/favicon.ico b/build/favicon.ico deleted file mode 100644 index a11777cc471a4344702741ab1c8a588998b1311a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3870 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 baj7?x%VD!5Cxk2YbYLNVeiXvvpMCWYo=by@ diff --git a/build/index.html b/build/index.html deleted file mode 100644 index 54fd1fa..0000000 --- a/build/index.html +++ /dev/null @@ -1 +0,0 @@ -<!doctype html><html lang="en"><head><meta charset="utf-8"/><link rel="icon" href="/favicon.ico"/><meta name="viewport" content="width=device-width,initial-scale=1"/><meta name="theme-color" content="#000000"/><meta name="description" content="Web site created using create-react-app"/><link rel="apple-touch-icon" href="/logo192.png"/><link rel="manifest" href="/manifest.json"/><title>React App</title><link href="/static/css/main.5ecd60fb.chunk.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div><script>!function(a){function e(e){for(var r,t,n=e[0],o=e[1],u=e[2],p=0,l=[];p<n.length;p++)t=n[p],Object.prototype.hasOwnProperty.call(i,t)&&i[t]&&l.push(i[t][0]),i[t]=0;for(r in o)Object.prototype.hasOwnProperty.call(o,r)&&(a[r]=o[r]);for(s&&s(e);l.length;)l.shift()();return c.push.apply(c,u||[]),f()}function f(){for(var e,r=0;r<c.length;r++){for(var t=c[r],n=!0,o=1;o<t.length;o++){var u=t[o];0!==i[u]&&(n=!1)}n&&(c.splice(r--,1),e=p(p.s=t[0]))}return e}var t={},i={1:0},c=[];function p(e){if(t[e])return t[e].exports;var r=t[e]={i:e,l:!1,exports:{}};return a[e].call(r.exports,r,r.exports,p),r.l=!0,r.exports}p.m=a,p.c=t,p.d=function(e,r,t){p.o(e,r)||Object.defineProperty(e,r,{enumerable:!0,get:t})},p.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},p.t=function(r,e){if(1&e&&(r=p(r)),8&e)return r;if(4&e&&"object"==typeof r&&r&&r.__esModule)return r;var t=Object.create(null);if(p.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:r}),2&e&&"string"!=typeof r)for(var n in r)p.d(t,n,function(e){return r[e]}.bind(null,n));return t},p.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return p.d(r,"a",r),r},p.o=function(e,r){return Object.prototype.hasOwnProperty.call(e,r)},p.p="/";var r=this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[],n=r.push.bind(r);r.push=e,r=r.slice();for(var o=0;o<r.length;o++)e(r[o]);var s=n;f()}([])</script><script src="/static/js/2.6a72c269.chunk.js"></script><script src="/static/js/main.928fa077.chunk.js"></script></body></html> \ No newline at end of file diff --git a/build/logo192.png b/build/logo192.png deleted file mode 100644 index fc44b0a3796c0e0a64c3d858ca038bd4570465d9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5347 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 X@eDJUQo;Ye2mwlRs<JiGX2Jghdw)}T diff --git a/build/logo512.png b/build/logo512.png deleted file mode 100644 index a4e47a6545bc15971f8f63fba70e4013df88a664..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9664 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 b{|{}U^kRn2wo}j7|0ATu<;8xA7zX}7|B6mN diff --git a/build/manifest.json b/build/manifest.json deleted file mode 100644 index 080d6c7..0000000 --- a/build/manifest.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "short_name": "React App", - "name": "Create React App Sample", - "icons": [ - { - "src": "favicon.ico", - "sizes": "64x64 32x32 24x24 16x16", - "type": "image/x-icon" - }, - { - "src": "logo192.png", - "type": "image/png", - "sizes": "192x192" - }, - { - "src": "logo512.png", - "type": "image/png", - "sizes": "512x512" - } - ], - "start_url": ".", - "display": "standalone", - "theme_color": "#000000", - "background_color": "#ffffff" -} diff --git a/build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js b/build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js deleted file mode 100644 index e1c039a..0000000 --- a/build/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js +++ /dev/null @@ -1,26 +0,0 @@ -self.__precacheManifest = (self.__precacheManifest || []).concat([ - { - "revision": "f40581dfdfeab5d31ffe77d8b69c70dd", - "url": "/index.html" - }, - { - "revision": "f1eb2669e963bc86acde", - "url": "/static/css/main.5ecd60fb.chunk.css" - }, - { - "revision": "cb64c341987a0716d9ea", - "url": "/static/js/2.6a72c269.chunk.js" - }, - { - "revision": "b51e62edbcf7a9c4f4ad13f506021d3e", - "url": "/static/js/2.6a72c269.chunk.js.LICENSE" - }, - { - "revision": "f1eb2669e963bc86acde", - "url": "/static/js/main.928fa077.chunk.js" - }, - { - "revision": "696942293a92ac3a2bb6", - "url": "/static/js/runtime-main.889ad4b6.js" - } -]); \ No newline at end of file diff --git a/build/robots.txt b/build/robots.txt deleted file mode 100644 index 01b0f9a..0000000 --- a/build/robots.txt +++ /dev/null @@ -1,2 +0,0 @@ -# https://www.robotstxt.org/robotstxt.html -User-agent: * diff --git a/build/service-worker.js b/build/service-worker.js deleted file mode 100644 index ef97193..0000000 --- a/build/service-worker.js +++ /dev/null @@ -1,39 +0,0 @@ -/** - * Welcome to your Workbox-powered service worker! - * - * You'll need to register this file in your web app and you should - * disable HTTP caching for this file too. - * See https://goo.gl/nhQhGp - * - * The rest of the code is auto-generated. Please don't update this file - * directly; instead, make changes to your Workbox build configuration - * and re-run your build process. - * See https://goo.gl/2aRDsh - */ - -importScripts("https://storage.googleapis.com/workbox-cdn/releases/4.3.1/workbox-sw.js"); - -importScripts( - "/precache-manifest.4e6796295cf8cef3d8c75de5ce61be3e.js" -); - -self.addEventListener('message', (event) => { - if (event.data && event.data.type === 'SKIP_WAITING') { - self.skipWaiting(); - } -}); - -workbox.core.clientsClaim(); - -/** - * The workboxSW.precacheAndRoute() method efficiently caches and responds to - * requests for URLs in the manifest. - * See https://goo.gl/S9QRab - */ -self.__precacheManifest = [].concat(self.__precacheManifest || []); -workbox.precaching.precacheAndRoute(self.__precacheManifest, {}); - -workbox.routing.registerNavigationRoute(workbox.precaching.getCacheKeyForURL("/index.html"), { - - blacklist: [/^\/_/,/\/[^/?]+\.[^/]+$/], -}); diff --git a/build/static/css/main.5ecd60fb.chunk.css b/build/static/css/main.5ecd60fb.chunk.css deleted file mode 100644 index 5418557..0000000 --- a/build/static/css/main.5ecd60fb.chunk.css +++ /dev/null @@ -1,2 +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} -/*# sourceMappingURL=main.5ecd60fb.chunk.css.map */ \ No newline at end of file diff --git a/build/static/css/main.5ecd60fb.chunk.css.map b/build/static/css/main.5ecd60fb.chunk.css.map deleted file mode 100644 index ab2a007..0000000 --- a/build/static/css/main.5ecd60fb.chunk.css.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["index.css"],"names":[],"mappings":"AAAA,KACE,QAAS,CACT,mIAEY,CACZ,kCAAmC,CACnC,iCACF,CAEA,KACE,uEAEF","file":"main.5ecd60fb.chunk.css","sourcesContent":["body {\n margin: 0;\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen',\n 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',\n sans-serif;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\ncode {\n font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',\n monospace;\n}\n"]} \ No newline at end of file diff --git a/build/static/js/2.6a72c269.chunk.js b/build/static/js/2.6a72c269.chunk.js deleted file mode 100644 index 6224c5e..0000000 --- a/build/static/js/2.6a72c269.chunk.js +++ /dev/null @@ -1,3 +0,0 @@ -/*! For license information please see 2.6a72c269.chunk.js.LICENSE */ -(this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[]).push([[2],[function(e,t,n){"use strict";e.exports=n(102)},function(e,t,n){"use strict";function r(){return(r=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e}).apply(this,arguments)}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";n.d(t,"a",(function(){return o}));var r=n(15);function o(e,t){if(null==e)return{};var n,o,a=Object(r.a)(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(o=0;o<i.length;o++)n=i[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}},function(e,t,n){"use strict";function r(e){var t,n,o="";if(e)if("object"===typeof e)if(e.push)for(t=0;t<e.length;t++)e[t]&&(n=r(e[t]))&&(o&&(o+=" "),o+=n);else for(t in e)e[t]&&(n=r(t))&&(o&&(o+=" "),o+=n);else"boolean"===typeof e||e.call||(o&&(o+=" "),o+=e);return o}t.a=function(){for(var e,t=0,n="";t<arguments.length;)(e=r(arguments[t++]))&&(n&&(n+=" "),n+=e);return n}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(86)),u=n.n(l),c=n(133),s=n(163),d=n(93),f=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return function(n){var a=t.defaultTheme,l=t.withTheme,f=void 0!==l&&l,p=t.name,h=Object(o.a)(t,["defaultTheme","withTheme","name"]);var m=p,v=Object(c.a)(e,Object(r.a)({defaultTheme:a,Component:n,name:p||n.displayName,classNamePrefix:m},h)),b=i.a.forwardRef((function(e,t){e.classes;var l,u=e.innerRef,c=Object(o.a)(e,["classes","innerRef"]),h=v(e),m=c;return("string"===typeof p||f)&&(l=Object(d.a)()||a,p&&(m=Object(s.a)({theme:l,name:p,props:c})),f&&!m.theme&&(m.theme=l)),i.a.createElement(n,Object(r.a)({ref:u||t,classes:h},m))}));return b.defaultProps=n.defaultProps,u()(b,n),b}},p=n(45);t.a=function(e,t){return f(e,Object(r.a)({defaultTheme:p.a},t))}},function(e,t,n){e.exports=n(124)()},function(e,t,n){"use strict";function r(e){return e.charAt(0).toUpperCase()+e.slice(1)}n.d(t,"a",(function(){return r}))},,function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a=n(35);function i(e,t){return o.a.useMemo((function(){return null==e&&null==t?null:function(n){Object(a.a)(e,n),Object(a.a)(t,n)}}),[e,t])}},function(e,t,n){"use strict";!function e(){if("undefined"!==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__&&"function"===typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE){0;try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(e)}catch(t){console.error(t)}}}(),e.exports=n(103)},function(e,t,n){"use strict";function r(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;return Math.min(Math.max(t,e),n)}function o(e){if(e.type)return e;if("#"===e.charAt(0))return o(function(e){e=e.substr(1);var t=new RegExp(".{1,".concat(e.length/3,"}"),"g"),n=e.match(t);return n&&1===n[0].length&&(n=n.map((function(e){return e+e}))),n?"rgb(".concat(n.map((function(e){return parseInt(e,16)})).join(", "),")"):""}(e));var t=e.indexOf("("),n=e.substring(0,t);if(-1===["rgb","rgba","hsl","hsla"].indexOf(n))throw new Error(["Material-UI: unsupported `".concat(e,"` color."),"We support the following formats: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()."].join("\n"));var r=e.substring(t+1,e.length-1).split(",");return{type:n,values:r=r.map((function(e){return parseFloat(e)}))}}function a(e){var t=e.type,n=e.values;return-1!==t.indexOf("rgb")?n=n.map((function(e,t){return t<3?parseInt(e,10):e})):-1!==t.indexOf("hsl")&&(n[1]="".concat(n[1],"%"),n[2]="".concat(n[2],"%")),"".concat(t,"(").concat(n.join(", "),")")}function i(e,t){var n=l(e),r=l(t);return(Math.max(n,r)+.05)/(Math.min(n,r)+.05)}function l(e){var t="hsl"===(e=o(e)).type?o(function(e){var t=(e=o(e)).values,n=t[0],r=t[1]/100,i=t[2]/100,l=r*Math.min(i,1-i),u=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:(e+n/30)%12;return i-l*Math.max(Math.min(t-3,9-t,1),-1)},c="rgb",s=[Math.round(255*u(0)),Math.round(255*u(8)),Math.round(255*u(4))];return"hsla"===e.type&&(c+="a",s.push(t[3])),a({type:c,values:s})}(e)).values:e.values;return t=t.map((function(e){return(e/=255)<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4)})),Number((.2126*t[0]+.7152*t[1]+.0722*t[2]).toFixed(3))}function u(e,t){return e=o(e),t=r(t),"rgb"!==e.type&&"hsl"!==e.type||(e.type+="a"),e.values[3]=t,a(e)}function c(e,t){if(e=o(e),t=r(t),-1!==e.type.indexOf("hsl"))e.values[2]*=1-t;else if(-1!==e.type.indexOf("rgb"))for(var n=0;n<3;n+=1)e.values[n]*=1-t;return a(e)}function s(e,t){if(e=o(e),t=r(t),-1!==e.type.indexOf("hsl"))e.values[2]+=(100-e.values[2])*t;else if(-1!==e.type.indexOf("rgb"))for(var n=0;n<3;n+=1)e.values[n]+=(255-e.values[n])*t;return a(e)}n.d(t,"c",(function(){return i})),n.d(t,"b",(function(){return u})),n.d(t,"a",(function(){return c})),n.d(t,"d",(function(){return s}))},function(e,t,n){"use strict";var r=n(83);function o(e){return function(e){if(Array.isArray(e)){for(var t=0,n=new Array(e.length);t<e.length;t++)n[t]=e[t];return n}}(e)||Object(r.a)(e)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance")}()}n.d(t,"a",(function(){return o}))},function(e,t,n){"use strict";function r(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}n.d(t,"a",(function(){return r}))},,,function(e,t,n){"use strict";function r(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r<a.length;r++)n=a[r],t.indexOf(n)>=0||(o[n]=e[n]);return o}n.d(t,"a",(function(){return r}))},,,,function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M16 9v10H8V9h8m-1.5-6h-5l-1 1H5v2h14V4h-3.5l-1-1zM18 7H6v12c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7z"}),"DeleteOutlined");t.default=a},function(e,t,n){"use strict";function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(74),o=Object.prototype.toString;function a(e){return"[object Array]"===o.call(e)}function i(e){return"undefined"===typeof e}function l(e){return null!==e&&"object"===typeof e}function u(e){return"[object Function]"===o.call(e)}function c(e,t){if(null!==e&&"undefined"!==typeof e)if("object"!==typeof e&&(e=[e]),a(e))for(var n=0,r=e.length;n<r;n++)t.call(null,e[n],n,e);else for(var o in e)Object.prototype.hasOwnProperty.call(e,o)&&t.call(null,e[o],o,e)}e.exports={isArray:a,isArrayBuffer:function(e){return"[object ArrayBuffer]"===o.call(e)},isBuffer:function(e){return null!==e&&!i(e)&&null!==e.constructor&&!i(e.constructor)&&"function"===typeof e.constructor.isBuffer&&e.constructor.isBuffer(e)},isFormData:function(e){return"undefined"!==typeof FormData&&e instanceof FormData},isArrayBufferView:function(e){return"undefined"!==typeof ArrayBuffer&&ArrayBuffer.isView?ArrayBuffer.isView(e):e&&e.buffer&&e.buffer instanceof ArrayBuffer},isString:function(e){return"string"===typeof e},isNumber:function(e){return"number"===typeof e},isObject:l,isUndefined:i,isDate:function(e){return"[object Date]"===o.call(e)},isFile:function(e){return"[object File]"===o.call(e)},isBlob:function(e){return"[object Blob]"===o.call(e)},isFunction:u,isStream:function(e){return l(e)&&u(e.pipe)},isURLSearchParams:function(e){return"undefined"!==typeof URLSearchParams&&e instanceof URLSearchParams},isStandardBrowserEnv:function(){return("undefined"===typeof navigator||"ReactNative"!==navigator.product&&"NativeScript"!==navigator.product&&"NS"!==navigator.product)&&("undefined"!==typeof window&&"undefined"!==typeof document)},forEach:c,merge:function e(){var t={};function n(n,r){"object"===typeof t[r]&&"object"===typeof n?t[r]=e(t[r],n):t[r]=n}for(var r=0,o=arguments.length;r<o;r++)c(arguments[r],n);return t},deepMerge:function e(){var t={};function n(n,r){"object"===typeof t[r]&&"object"===typeof n?t[r]=e(t[r],n):t[r]="object"===typeof n?e({},n):n}for(var r=0,o=arguments.length;r<o;r++)c(arguments[r],n);return t},extend:function(e,t,n){return c(t,(function(t,o){e[o]=n&&"function"===typeof t?r(t,n):t})),e},trim:function(e){return e.replace(/^\s*/,"").replace(/\s*$/,"")}}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a=n(40);function i(){return o.a.useContext(a.a)}},function(e,t,n){"use strict";t.a=function(e,t){if(!e)throw new Error("Invariant failed")}},function(e,t,n){"use strict";function r(e){var t=e.props,n=e.states,r=e.muiFormControl;return n.reduce((function(e,n){return e[n]=t[n],r&&"undefined"===typeof t[n]&&(e[n]=r[n]),e}),{})}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";n.d(t,"a",(function(){return l}));var r=n(1),o=n(0),a=n.n(o),i=n(60);function l(e,t){var n=a.a.memo(a.a.forwardRef((function(t,n){return a.a.createElement(i.a,Object(r.a)({},t,{ref:n}),e)})));return n.muiName=i.a.muiName,n}},function(e,t,n){"use strict";var r=n(1);function o(e){return"/"===e.charAt(0)}function a(e,t){for(var n=t,r=n+1,o=e.length;r<o;n+=1,r+=1)e[n]=e[r];e.pop()}var i=function(e,t){void 0===t&&(t="");var n,r=e&&e.split("/")||[],i=t&&t.split("/")||[],l=e&&o(e),u=t&&o(t),c=l||u;if(e&&o(e)?i=r:r.length&&(i.pop(),i=i.concat(r)),!i.length)return"/";if(i.length){var s=i[i.length-1];n="."===s||".."===s||""===s}else n=!1;for(var d=0,f=i.length;f>=0;f--){var p=i[f];"."===p?a(i,f):".."===p?(a(i,f),d++):d&&(a(i,f),d--)}if(!c)for(;d--;d)i.unshift("..");!c||""===i[0]||i[0]&&o(i[0])||i.unshift("");var h=i.join("/");return n&&"/"!==h.substr(-1)&&(h+="/"),h};function l(e){return e.valueOf?e.valueOf():Object.prototype.valueOf.call(e)}var u=function e(t,n){if(t===n)return!0;if(null==t||null==n)return!1;if(Array.isArray(t))return Array.isArray(n)&&t.length===n.length&&t.every((function(t,r){return e(t,n[r])}));if("object"===typeof t||"object"===typeof n){var r=l(t),o=l(n);return r!==t||o!==n?e(r,o):Object.keys(Object.assign({},t,n)).every((function(r){return e(t[r],n[r])}))}return!1},c=n(23);function s(e){return"/"===e.charAt(0)?e:"/"+e}function d(e){return"/"===e.charAt(0)?e.substr(1):e}function f(e,t){return function(e,t){return 0===e.toLowerCase().indexOf(t.toLowerCase())&&-1!=="/?#".indexOf(e.charAt(t.length))}(e,t)?e.substr(t.length):e}function p(e){return"/"===e.charAt(e.length-1)?e.slice(0,-1):e}function h(e){var t=e.pathname,n=e.search,r=e.hash,o=t||"/";return n&&"?"!==n&&(o+="?"===n.charAt(0)?n:"?"+n),r&&"#"!==r&&(o+="#"===r.charAt(0)?r:"#"+r),o}function m(e,t,n,o){var a;"string"===typeof e?(a=function(e){var t=e||"/",n="",r="",o=t.indexOf("#");-1!==o&&(r=t.substr(o),t=t.substr(0,o));var a=t.indexOf("?");return-1!==a&&(n=t.substr(a),t=t.substr(0,a)),{pathname:t,search:"?"===n?"":n,hash:"#"===r?"":r}}(e)).state=t:(void 0===(a=Object(r.a)({},e)).pathname&&(a.pathname=""),a.search?"?"!==a.search.charAt(0)&&(a.search="?"+a.search):a.search="",a.hash?"#"!==a.hash.charAt(0)&&(a.hash="#"+a.hash):a.hash="",void 0!==t&&void 0===a.state&&(a.state=t));try{a.pathname=decodeURI(a.pathname)}catch(l){throw l instanceof URIError?new URIError('Pathname "'+a.pathname+'" could not be decoded. This is likely caused by an invalid percent-encoding.'):l}return n&&(a.key=n),o?a.pathname?"/"!==a.pathname.charAt(0)&&(a.pathname=i(a.pathname,o.pathname)):a.pathname=o.pathname:a.pathname||(a.pathname="/"),a}function v(e,t){return e.pathname===t.pathname&&e.search===t.search&&e.hash===t.hash&&e.key===t.key&&u(e.state,t.state)}function b(){var e=null;var t=[];return{setPrompt:function(t){return e=t,function(){e===t&&(e=null)}},confirmTransitionTo:function(t,n,r,o){if(null!=e){var a="function"===typeof e?e(t,n):e;"string"===typeof a?"function"===typeof r?r(a,o):o(!0):o(!1!==a)}else o(!0)},appendListener:function(e){var n=!0;function r(){n&&e.apply(void 0,arguments)}return t.push(r),function(){n=!1,t=t.filter((function(e){return e!==r}))}},notifyListeners:function(){for(var e=arguments.length,n=new Array(e),r=0;r<e;r++)n[r]=arguments[r];t.forEach((function(e){return e.apply(void 0,n)}))}}}n.d(t,"a",(function(){return w})),n.d(t,"b",(function(){return C})),n.d(t,"d",(function(){return j})),n.d(t,"c",(function(){return m})),n.d(t,"f",(function(){return v})),n.d(t,"e",(function(){return h}));var y=!("undefined"===typeof window||!window.document||!window.document.createElement);function g(e,t){t(window.confirm(e))}function x(){try{return window.history.state||{}}catch(e){return{}}}function w(e){void 0===e&&(e={}),y||Object(c.a)(!1);var t=window.history,n=function(){var e=window.navigator.userAgent;return(-1===e.indexOf("Android 2.")&&-1===e.indexOf("Android 4.0")||-1===e.indexOf("Mobile Safari")||-1!==e.indexOf("Chrome")||-1!==e.indexOf("Windows Phone"))&&(window.history&&"pushState"in window.history)}(),o=!(-1===window.navigator.userAgent.indexOf("Trident")),a=e,i=a.forceRefresh,l=void 0!==i&&i,u=a.getUserConfirmation,d=void 0===u?g:u,v=a.keyLength,w=void 0===v?6:v,k=e.basename?p(s(e.basename)):"";function E(e){var t=e||{},n=t.key,r=t.state,o=window.location,a=o.pathname+o.search+o.hash;return k&&(a=f(a,k)),m(a,r,n)}function O(){return Math.random().toString(36).substr(2,w)}var S=b();function C(e){Object(r.a)(D,e),D.length=t.length,S.notifyListeners(D.location,D.action)}function T(e){(function(e){return void 0===e.state&&-1===navigator.userAgent.indexOf("CriOS")})(e)||R(E(e.state))}function j(){R(E(x()))}var P=!1;function R(e){if(P)P=!1,C();else{S.confirmTransitionTo(e,"POP",d,(function(t){t?C({action:"POP",location:e}):function(e){var t=D.location,n=M.indexOf(t.key);-1===n&&(n=0);var r=M.indexOf(e.key);-1===r&&(r=0);var o=n-r;o&&(P=!0,A(o))}(e)}))}}var N=E(x()),M=[N.key];function _(e){return k+h(e)}function A(e){t.go(e)}var z=0;function I(e){1===(z+=e)&&1===e?(window.addEventListener("popstate",T),o&&window.addEventListener("hashchange",j)):0===z&&(window.removeEventListener("popstate",T),o&&window.removeEventListener("hashchange",j))}var L=!1;var D={length:t.length,action:"POP",location:N,createHref:_,push:function(e,r){var o=m(e,r,O(),D.location);S.confirmTransitionTo(o,"PUSH",d,(function(e){if(e){var r=_(o),a=o.key,i=o.state;if(n)if(t.pushState({key:a,state:i},null,r),l)window.location.href=r;else{var u=M.indexOf(D.location.key),c=M.slice(0,u+1);c.push(o.key),M=c,C({action:"PUSH",location:o})}else window.location.href=r}}))},replace:function(e,r){var o=m(e,r,O(),D.location);S.confirmTransitionTo(o,"REPLACE",d,(function(e){if(e){var r=_(o),a=o.key,i=o.state;if(n)if(t.replaceState({key:a,state:i},null,r),l)window.location.replace(r);else{var u=M.indexOf(D.location.key);-1!==u&&(M[u]=o.key),C({action:"REPLACE",location:o})}else window.location.replace(r)}}))},go:A,goBack:function(){A(-1)},goForward:function(){A(1)},block:function(e){void 0===e&&(e=!1);var t=S.setPrompt(e);return L||(I(1),L=!0),function(){return L&&(L=!1,I(-1)),t()}},listen:function(e){var t=S.appendListener(e);return I(1),function(){I(-1),t()}}};return D}var k={hashbang:{encodePath:function(e){return"!"===e.charAt(0)?e:"!/"+d(e)},decodePath:function(e){return"!"===e.charAt(0)?e.substr(1):e}},noslash:{encodePath:d,decodePath:s},slash:{encodePath:s,decodePath:s}};function E(e){var t=e.indexOf("#");return-1===t?e:e.slice(0,t)}function O(){var e=window.location.href,t=e.indexOf("#");return-1===t?"":e.substring(t+1)}function S(e){window.location.replace(E(window.location.href)+"#"+e)}function C(e){void 0===e&&(e={}),y||Object(c.a)(!1);var t=window.history,n=(window.navigator.userAgent.indexOf("Firefox"),e),o=n.getUserConfirmation,a=void 0===o?g:o,i=n.hashType,l=void 0===i?"slash":i,u=e.basename?p(s(e.basename)):"",d=k[l],v=d.encodePath,x=d.decodePath;function w(){var e=x(O());return u&&(e=f(e,u)),m(e)}var C=b();function T(e){Object(r.a)(F,e),F.length=t.length,C.notifyListeners(F.location,F.action)}var j=!1,P=null;function R(){var e,t,n=O(),r=v(n);if(n!==r)S(r);else{var o=w(),i=F.location;if(!j&&(t=o,(e=i).pathname===t.pathname&&e.search===t.search&&e.hash===t.hash))return;if(P===h(o))return;P=null,function(e){if(j)j=!1,T();else{C.confirmTransitionTo(e,"POP",a,(function(t){t?T({action:"POP",location:e}):function(e){var t=F.location,n=A.lastIndexOf(h(t));-1===n&&(n=0);var r=A.lastIndexOf(h(e));-1===r&&(r=0);var o=n-r;o&&(j=!0,z(o))}(e)}))}}(o)}}var N=O(),M=v(N);N!==M&&S(M);var _=w(),A=[h(_)];function z(e){t.go(e)}var I=0;function L(e){1===(I+=e)&&1===e?window.addEventListener("hashchange",R):0===I&&window.removeEventListener("hashchange",R)}var D=!1;var F={length:t.length,action:"POP",location:_,createHref:function(e){var t=document.querySelector("base"),n="";return t&&t.getAttribute("href")&&(n=E(window.location.href)),n+"#"+v(u+h(e))},push:function(e,t){var n=m(e,void 0,void 0,F.location);C.confirmTransitionTo(n,"PUSH",a,(function(e){if(e){var t=h(n),r=v(u+t);if(O()!==r){P=t,function(e){window.location.hash=e}(r);var o=A.lastIndexOf(h(F.location)),a=A.slice(0,o+1);a.push(t),A=a,T({action:"PUSH",location:n})}else T()}}))},replace:function(e,t){var n=m(e,void 0,void 0,F.location);C.confirmTransitionTo(n,"REPLACE",a,(function(e){if(e){var t=h(n),r=v(u+t);O()!==r&&(P=t,S(r));var o=A.indexOf(h(F.location));-1!==o&&(A[o]=t),T({action:"REPLACE",location:n})}}))},go:z,goBack:function(){z(-1)},goForward:function(){z(1)},block:function(e){void 0===e&&(e=!1);var t=C.setPrompt(e);return D||(L(1),D=!0),function(){return D&&(D=!1,L(-1)),t()}},listen:function(e){var t=C.appendListener(e);return L(1),function(){L(-1),t()}}};return F}function T(e,t,n){return Math.min(Math.max(e,t),n)}function j(e){void 0===e&&(e={});var t=e,n=t.getUserConfirmation,o=t.initialEntries,a=void 0===o?["/"]:o,i=t.initialIndex,l=void 0===i?0:i,u=t.keyLength,c=void 0===u?6:u,s=b();function d(e){Object(r.a)(x,e),x.length=x.entries.length,s.notifyListeners(x.location,x.action)}function f(){return Math.random().toString(36).substr(2,c)}var p=T(l,0,a.length-1),v=a.map((function(e){return m(e,void 0,"string"===typeof e?f():e.key||f())})),y=h;function g(e){var t=T(x.index+e,0,x.entries.length-1),r=x.entries[t];s.confirmTransitionTo(r,"POP",n,(function(e){e?d({action:"POP",location:r,index:t}):d()}))}var x={length:v.length,action:"POP",location:v[p],index:p,entries:v,createHref:y,push:function(e,t){var r=m(e,t,f(),x.location);s.confirmTransitionTo(r,"PUSH",n,(function(e){if(e){var t=x.index+1,n=x.entries.slice(0);n.length>t?n.splice(t,n.length-t,r):n.push(r),d({action:"PUSH",location:r,index:t,entries:n})}}))},replace:function(e,t){var r=m(e,t,f(),x.location);s.confirmTransitionTo(r,"REPLACE",n,(function(e){e&&(x.entries[x.index]=r,d({action:"REPLACE",location:r}))}))},go:g,goBack:function(){g(-1)},goForward:function(){g(1)},canGo:function(e){var t=x.index+e;return t>=0&&t<x.entries.length},block:function(e){return void 0===e&&(e=!1),s.setPrompt(e)},listen:function(e){return s.appendListener(e)}};return x}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close");t.default=a},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11h-4v4h-2v-4H7v-2h4V7h2v4h4v2z"}),"AddCircle");t.default=a},function(e,t){e.exports=function(e){return e&&e.__esModule?e:{default:e}}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a="undefined"!==typeof window?o.a.useLayoutEffect:o.a.useEffect;function i(e){var t=o.a.useRef(e);return a((function(){t.current=e})),o.a.useCallback((function(){return t.current.apply(void 0,arguments)}),[])}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){var n=a.default.memo(a.default.forwardRef((function(t,n){return a.default.createElement(i.default,(0,o.default)({ref:n},t),e)})));0;return n.muiName=i.default.muiName,n};var o=r(n(127)),a=r(n(0)),i=r(n(82))},,function(e,t,n){"use strict";t.a=function(e,t){}},function(e,t,n){"use strict";var r=n(84);var o=n(85);function a(e,t){return Object(r.a)(e)||function(e,t){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e)){var n=[],r=!0,o=!1,a=void 0;try{for(var i,l=e[Symbol.iterator]();!(r=(i=l.next()).done)&&(n.push(i.value),!t||n.length!==t);r=!0);}catch(u){o=!0,a=u}finally{try{r||null==l.return||l.return()}finally{if(o)throw a}}return n}}(e,t)||Object(o.a)()}n.d(t,"a",(function(){return a}))},function(e,t,n){"use strict";function r(e,t){"function"===typeof e?e(t):e&&(e.current=t)}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(12),o=n(0),a=n.n(o),i=n(5),l=n.n(i),u=n(26),c=n(67),s=n.n(c),d=n(88),f=n.n(d);function p(e){var t=[];return{on:function(e){t.push(e)},off:function(e){t=t.filter((function(t){return t!==e}))},get:function(){return e},set:function(n,r){e=n,t.forEach((function(t){return t(e,r)}))}}}var h=a.a.createContext||function(e,t){var n,r,a="__create-react-context-"+f()()+"__",i=function(e){function n(){var t;return(t=e.apply(this,arguments)||this).emitter=p(t.props.value),t}s()(n,e);var r=n.prototype;return r.getChildContext=function(){var e;return(e={})[a]=this.emitter,e},r.componentWillReceiveProps=function(e){if(this.props.value!==e.value){var n,r=this.props.value,o=e.value;((a=r)===(i=o)?0!==a||1/a===1/i:a!==a&&i!==i)?n=0:(n="function"===typeof t?t(r,o):1073741823,0!==(n|=0)&&this.emitter.set(e.value,n))}var a,i},r.render=function(){return this.props.children},n}(o.Component);i.childContextTypes=((n={})[a]=l.a.object.isRequired,n);var u=function(t){function n(){var e;return(e=t.apply(this,arguments)||this).state={value:e.getValue()},e.onUpdate=function(t,n){0!==((0|e.observedBits)&n)&&e.setState({value:e.getValue()})},e}s()(n,t);var r=n.prototype;return r.componentWillReceiveProps=function(e){var t=e.observedBits;this.observedBits=void 0===t||null===t?1073741823:t},r.componentDidMount=function(){this.context[a]&&this.context[a].on(this.onUpdate);var e=this.props.observedBits;this.observedBits=void 0===e||null===e?1073741823:e},r.componentWillUnmount=function(){this.context[a]&&this.context[a].off(this.onUpdate)},r.getValue=function(){return this.context[a]?this.context[a].get():e},r.render=function(){return(e=this.props.children,Array.isArray(e)?e[0]:e)(this.state.value);var e},n}(o.Component);return u.contextTypes=((r={})[a]=l.a.object,r),{Provider:i,Consumer:u}},m=n(23),v=n(1),b=n(68),y=n.n(b),g=(n(44),n(15));n(89);n.d(t,"a",(function(){return S})),n.d(t,"b",(function(){return w})),n.d(t,"c",(function(){return x})),n.d(t,"d",(function(){return O})),n.d(t,"e",(function(){return M}));var x=function(e){var t=h();return t.displayName=e,t}("Router"),w=function(e){function t(t){var n;return(n=e.call(this,t)||this).state={location:t.history.location},n._isMounted=!1,n._pendingLocation=null,t.staticContext||(n.unlisten=t.history.listen((function(e){n._isMounted?n.setState({location:e}):n._pendingLocation=e}))),n}Object(r.a)(t,e),t.computeRootMatch=function(e){return{path:"/",url:"/",params:{},isExact:"/"===e}};var n=t.prototype;return n.componentDidMount=function(){this._isMounted=!0,this._pendingLocation&&this.setState({location:this._pendingLocation})},n.componentWillUnmount=function(){this.unlisten&&this.unlisten()},n.render=function(){return a.a.createElement(x.Provider,{children:this.props.children||null,value:{history:this.props.history,location:this.state.location,match:t.computeRootMatch(this.state.location.pathname),staticContext:this.props.staticContext}})},t}(a.a.Component);a.a.Component;a.a.Component;var k={},E=0;function O(e,t){void 0===t&&(t={}),("string"===typeof t||Array.isArray(t))&&(t={path:t});var n=t,r=n.path,o=n.exact,a=void 0!==o&&o,i=n.strict,l=void 0!==i&&i,u=n.sensitive,c=void 0!==u&&u;return[].concat(r).reduce((function(t,n){if(!n&&""!==n)return null;if(t)return t;var r=function(e,t){var n=""+t.end+t.strict+t.sensitive,r=k[n]||(k[n]={});if(r[e])return r[e];var o=[],a={regexp:y()(e,o,t),keys:o};return E<1e4&&(r[e]=a,E++),a}(n,{end:a,strict:l,sensitive:c}),o=r.regexp,i=r.keys,u=o.exec(e);if(!u)return null;var s=u[0],d=u.slice(1),f=e===s;return a&&!f?null:{path:n,url:"/"===n&&""===s?"/":s,isExact:f,params:i.reduce((function(e,t,n){return e[t.name]=d[n],e}),{})}}),null)}var S=function(e){function t(){return e.apply(this,arguments)||this}return Object(r.a)(t,e),t.prototype.render=function(){var e=this;return a.a.createElement(x.Consumer,null,(function(t){t||Object(m.a)(!1);var n=e.props.location||t.location,r=e.props.computedMatch?e.props.computedMatch:e.props.path?O(n.pathname,e.props):t.match,o=Object(v.a)({},t,{location:n,match:r}),i=e.props,l=i.children,u=i.component,c=i.render;return Array.isArray(l)&&0===l.length&&(l=null),a.a.createElement(x.Provider,{value:o},o.match?l?"function"===typeof l?l(o):l:u?a.a.createElement(u,o):c?c(o):null:"function"===typeof l?l(o):null)}))},t}(a.a.Component);function C(e){return"/"===e.charAt(0)?e:"/"+e}function T(e,t){if(!e)return t;var n=C(e);return 0!==t.pathname.indexOf(n)?t:Object(v.a)({},t,{pathname:t.pathname.substr(n.length)})}function j(e){return"string"===typeof e?e:Object(u.e)(e)}function P(e){return function(){Object(m.a)(!1)}}function R(){}a.a.Component;a.a.Component;var N=a.a.useContext;function M(){var e=N(x).match;return e?e.params:{}}},,,,function(e,t,n){"use strict";n.d(t,"b",(function(){return i}));var r=n(0),o=n.n(r),a=o.a.createContext();function i(){return o.a.useContext(a)}t.a=a},function(e,t,n){"use strict";function r(e){return null!=e&&!(Array.isArray(e)&&0===e.length)}function o(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return e&&(r(e.value)&&""!==e.value||t&&r(e.defaultValue)&&""!==e.defaultValue)}function a(e){return e.startAdornment}n.d(t,"b",(function(){return o})),n.d(t,"a",(function(){return a}))},function(e,t,n){"use strict";function r(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];return t.reduce((function(e,t){return null==t?e:function(){for(var n=arguments.length,r=new Array(n),o=0;o<n;o++)r[o]=arguments[o];e.apply(this,r),t.apply(this,r)}}),(function(){}))}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(0),o=n.n(r);t.a=o.a.createContext(null)},function(e,t,n){"use strict";e.exports=n(126)},function(e,t,n){"use strict";var r=n(92),o=Object(r.a)();t.a=o},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(22),c=n(4),s=n(132),d=i.a.forwardRef((function(e,t){var n=e.autoFocus,a=e.checked,c=e.checkedIcon,d=e.classes,f=e.className,p=e.defaultChecked,h=e.disabled,m=e.icon,v=e.id,b=e.inputProps,y=e.inputRef,g=e.name,x=e.onBlur,w=e.onChange,k=e.onFocus,E=e.readOnly,O=e.required,S=e.tabIndex,C=e.type,T=e.value,j=Object(o.a)(e,["autoFocus","checked","checkedIcon","classes","className","defaultChecked","disabled","icon","id","inputProps","inputRef","name","onBlur","onChange","onFocus","readOnly","required","tabIndex","type","value"]),P=i.a.useRef(null!=a).current,R=i.a.useState(Boolean(p)),N=R[0],M=R[1],_=P?a:N,A=Object(u.a)(),z=h;A&&"undefined"===typeof z&&(z=A.disabled);var I="checkbox"===C||"radio"===C;return i.a.createElement(s.a,Object(r.a)({component:"span",className:Object(l.a)(d.root,f,_&&d.checked,z&&d.disabled),disabled:z,tabIndex:null,role:void 0,onFocus:function(e){k&&k(e),A&&A.onFocus&&A.onFocus(e)},onBlur:function(e){x&&x(e),A&&A.onBlur&&A.onBlur(e)},ref:t},j),i.a.createElement("input",Object(r.a)({autoFocus:n,checked:a,defaultChecked:p,className:d.input,disabled:z,id:I&&v,name:g,onChange:function(e){var t=e.target.checked;P||M(t),w&&w(e,t)},readOnly:E,ref:y,required:O,tabIndex:S,type:C,value:T},b)),_?c:m)}));t.a=Object(c.a)({root:{padding:9},checked:{},disabled:{},input:{cursor:"inherit",position:"absolute",opacity:0,width:"100%",height:"100%",top:0,left:0,margin:0,padding:0,zIndex:1}},{name:"PrivateSwitchBase"})(d)},function(e,t,n){"use strict";n.d(t,"a",(function(){return a}));var r=n(93),o=n(45);function a(){return Object(r.a)()||o.a}},function(e,t,n){"use strict";function r(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}function o(e,t,n){return t&&r(e.prototype,t),n&&r(e,n),e}n.d(t,"a",(function(){return o}))},function(e,t,n){"use strict";function r(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";n.d(t,"a",(function(){return a}));var r=n(0),o=n.n(r);function a(e,t){return o.a.isValidElement(e)&&-1!==t.indexOf(e.type.muiName)}},function(e,t,n){"use strict";var r=n(0),o=n.n(r).a.createContext({});t.a=o},,function(e,t,n){"use strict";function r(e){return(r="function"===typeof Symbol&&"symbol"===typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"===typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function o(e){return(o="function"===typeof Symbol&&"symbol"===r(Symbol.iterator)?function(e){return r(e)}:function(e){return e&&"function"===typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":r(e)})(e)}n.d(t,"a",(function(){return o}))},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z"}),"CheckBoxOutlineBlank");t.default=a},function(e,t,n){e.exports=n(107)},,function(e,t,n){"use strict";var r=n(0),o=n.n(r).a.createContext(null);t.a=o},function(e,t,n){"use strict";var r="function"===typeof Symbol&&Symbol.for;t.a=r?Symbol.for("mui.nested"):"__THEME_NESTED__"},function(e,t,n){"use strict";t.a={mobileStepper:1e3,speedDial:1050,appBar:1100,drawer:1200,modal:1300,snackbar:1400,tooltip:1500}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(6),s=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,u=e.className,s=e.color,d=void 0===s?"inherit":s,f=e.component,p=void 0===f?"svg":f,h=e.fontSize,m=void 0===h?"default":h,v=e.htmlColor,b=e.titleAccess,y=e.viewBox,g=void 0===y?"0 0 24 24":y,x=Object(o.a)(e,["children","classes","className","color","component","fontSize","htmlColor","titleAccess","viewBox"]);return i.a.createElement(p,Object(r.a)({className:Object(l.a)(a.root,u,"inherit"!==d&&a["color".concat(Object(c.a)(d))],"default"!==m&&a["fontSize".concat(Object(c.a)(m))]),focusable:"false",viewBox:g,color:v,"aria-hidden":b?null:"true",role:b?"img":"presentation",ref:t},x),n,b?i.a.createElement("title",null,b):null)}));s.muiName="SvgIcon",t.a=Object(u.a)((function(e){return{root:{userSelect:"none",width:"1em",height:"1em",display:"inline-block",fill:"currentColor",flexShrink:0,fontSize:e.typography.pxToRem(24),transition:e.transitions.create("fill",{duration:e.transitions.duration.shorter})},colorPrimary:{color:e.palette.primary.main},colorSecondary:{color:e.palette.secondary.main},colorAction:{color:e.palette.action.active},colorError:{color:e.palette.error.main},colorDisabled:{color:e.palette.action.disabled},fontSizeInherit:{fontSize:"inherit"},fontSizeSmall:{fontSize:e.typography.pxToRem(20)},fontSizeLarge:{fontSize:e.typography.pxToRem(35)}}}),{name:"MuiSvgIcon"})(s)},function(e,t,n){"use strict";function r(e){var t,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:166;function r(){for(var r=arguments.length,o=new Array(r),a=0;a<r;a++)o[a]=arguments[a];var i=this,l=function(){e.apply(i,o)};clearTimeout(t),t=setTimeout(l,n)}return r.clear=function(){clearTimeout(t)},r}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(0),o=n.n(r).a.createContext();t.a=o},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"}),"Add");t.default=a},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M3 15h18v-2H3v2zm0 4h18v-2H3v2zm0-8h18V9H3v2zm0-6v2h18V5H3z"}),"Reorder");t.default=a},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"}),"RadioButtonChecked");t.default=a},function(e,t,n){"use strict";n.d(t,"a",(function(){return d}));var r=n(36),o=n(12),a=n(0),i=n.n(a),l=n(26),u=(n(5),n(1)),c=n(15),s=n(23);i.a.Component;var d=function(e){function t(){for(var t,n=arguments.length,r=new Array(n),o=0;o<n;o++)r[o]=arguments[o];return(t=e.call.apply(e,[this].concat(r))||this).history=Object(l.b)(t.props),t}return Object(o.a)(t,e),t.prototype.render=function(){return i.a.createElement(r.b,{history:this.history,children:this.props.children})},t}(i.a.Component);var f=function(e,t){return"function"===typeof e?e(t):e},p=function(e,t){return"string"===typeof e?Object(l.c)(e,null,null,t):e},h=function(e){return e},m=i.a.forwardRef;"undefined"===typeof m&&(m=h);var v=m((function(e,t){var n=e.innerRef,r=e.navigate,o=e.onClick,a=Object(c.a)(e,["innerRef","navigate","onClick"]),l=a.target,s=Object(u.a)({},a,{onClick:function(e){try{o&&o(e)}catch(t){throw e.preventDefault(),t}e.defaultPrevented||0!==e.button||l&&"_self"!==l||function(e){return!!(e.metaKey||e.altKey||e.ctrlKey||e.shiftKey)}(e)||(e.preventDefault(),r())}});return s.ref=h!==m&&t||n,i.a.createElement("a",s)}));var b=m((function(e,t){var n=e.component,o=void 0===n?v:n,a=e.replace,l=e.to,d=e.innerRef,b=Object(c.a)(e,["component","replace","to","innerRef"]);return i.a.createElement(r.c.Consumer,null,(function(e){e||Object(s.a)(!1);var n=e.history,r=p(f(l,e.location),e.location),c=r?n.createHref(r):"",v=Object(u.a)({},b,{href:c,navigate:function(){var t=f(l,e.location);(a?n.replace:n.push)(t)}});return h!==m?v.ref=t||d:v.innerRef=d,i.a.createElement(o,v)}))})),y=function(e){return e},g=i.a.forwardRef;"undefined"===typeof g&&(g=y);g((function(e,t){var n=e["aria-current"],o=void 0===n?"page":n,a=e.activeClassName,l=void 0===a?"active":a,d=e.activeStyle,h=e.className,m=e.exact,v=e.isActive,x=e.location,w=e.strict,k=e.style,E=e.to,O=e.innerRef,S=Object(c.a)(e,["aria-current","activeClassName","activeStyle","className","exact","isActive","location","strict","style","to","innerRef"]);return i.a.createElement(r.c.Consumer,null,(function(e){e||Object(s.a)(!1);var n=x||e.location,a=p(f(E,n),n),c=a.pathname,C=c&&c.replace(/([.+*?=^!:${}()[\]|/\\])/g,"\\$1"),T=C?Object(r.d)(n.pathname,{path:C,exact:m,strict:w}):null,j=!!(v?v(T,n):T),P=j?function(){for(var e=arguments.length,t=new Array(e),n=0;n<e;n++)t[n]=arguments[n];return t.filter((function(e){return e})).join(" ")}(h,l):h,R=j?Object(u.a)({},k,{},d):k,N=Object(u.a)({"aria-current":j&&o||null,className:P,style:R,to:a},S);return y!==g?N.ref=t||O:N.innerRef=O,i.a.createElement(b,N)}))}))},function(e,t){e.exports=function(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}},function(e,t,n){var r=n(129);e.exports=p,e.exports.parse=a,e.exports.compile=function(e,t){return l(a(e,t),t)},e.exports.tokensToFunction=l,e.exports.tokensToRegExp=f;var o=new RegExp(["(\\\\.)","([\\/.])?(?:(?:\\:(\\w+)(?:\\(((?:\\\\.|[^\\\\()])+)\\))?|\\(((?:\\\\.|[^\\\\()])+)\\))([+*?])?|(\\*))"].join("|"),"g");function a(e,t){for(var n,r=[],a=0,i=0,l="",s=t&&t.delimiter||"/";null!=(n=o.exec(e));){var d=n[0],f=n[1],p=n.index;if(l+=e.slice(i,p),i=p+d.length,f)l+=f[1];else{var h=e[i],m=n[2],v=n[3],b=n[4],y=n[5],g=n[6],x=n[7];l&&(r.push(l),l="");var w=null!=m&&null!=h&&h!==m,k="+"===g||"*"===g,E="?"===g||"*"===g,O=n[2]||s,S=b||y;r.push({name:v||a++,prefix:m||"",delimiter:O,optional:E,repeat:k,partial:w,asterisk:!!x,pattern:S?c(S):x?".*":"[^"+u(O)+"]+?"})}}return i<e.length&&(l+=e.substr(i)),l&&r.push(l),r}function i(e){return encodeURI(e).replace(/[\/?#]/g,(function(e){return"%"+e.charCodeAt(0).toString(16).toUpperCase()}))}function l(e,t){for(var n=new Array(e.length),o=0;o<e.length;o++)"object"===typeof e[o]&&(n[o]=new RegExp("^(?:"+e[o].pattern+")$",d(t)));return function(t,o){for(var a="",l=t||{},u=(o||{}).pretty?i:encodeURIComponent,c=0;c<e.length;c++){var s=e[c];if("string"!==typeof s){var d,f=l[s.name];if(null==f){if(s.optional){s.partial&&(a+=s.prefix);continue}throw new TypeError('Expected "'+s.name+'" to be defined')}if(r(f)){if(!s.repeat)throw new TypeError('Expected "'+s.name+'" to not repeat, but received `'+JSON.stringify(f)+"`");if(0===f.length){if(s.optional)continue;throw new TypeError('Expected "'+s.name+'" to not be empty')}for(var p=0;p<f.length;p++){if(d=u(f[p]),!n[c].test(d))throw new TypeError('Expected all "'+s.name+'" to match "'+s.pattern+'", but received `'+JSON.stringify(d)+"`");a+=(0===p?s.prefix:s.delimiter)+d}}else{if(d=s.asterisk?encodeURI(f).replace(/[?#]/g,(function(e){return"%"+e.charCodeAt(0).toString(16).toUpperCase()})):u(f),!n[c].test(d))throw new TypeError('Expected "'+s.name+'" to match "'+s.pattern+'", but received "'+d+'"');a+=s.prefix+d}}else a+=s}return a}}function u(e){return e.replace(/([.+*?=^!:${}()[\]|\/\\])/g,"\\$1")}function c(e){return e.replace(/([=!:$\/()])/g,"\\$1")}function s(e,t){return e.keys=t,e}function d(e){return e&&e.sensitive?"":"i"}function f(e,t,n){r(t)||(n=t||n,t=[]);for(var o=(n=n||{}).strict,a=!1!==n.end,i="",l=0;l<e.length;l++){var c=e[l];if("string"===typeof c)i+=u(c);else{var f=u(c.prefix),p="(?:"+c.pattern+")";t.push(c),c.repeat&&(p+="(?:"+f+p+")*"),i+=p=c.optional?c.partial?f+"("+p+")?":"(?:"+f+"("+p+"))?":f+"("+p+")"}}var h=u(n.delimiter||"/"),m=i.slice(-h.length)===h;return o||(i=(m?i.slice(0,-h.length):i)+"(?:"+h+"(?=$))?"),i+=a?"$":o&&m?"":"(?="+h+"|$)",s(new RegExp("^"+i,d(n)),t)}function p(e,t,n){return r(t)||(n=t||n,t=[]),n=n||{},e instanceof RegExp?function(e,t){var n=e.source.match(/\((?!\?)/g);if(n)for(var r=0;r<n.length;r++)t.push({name:r,prefix:null,delimiter:null,optional:!1,repeat:!1,partial:!1,asterisk:!1,pattern:null});return s(e,t)}(e,t):r(e)?function(e,t,n){for(var r=[],o=0;o<e.length;o++)r.push(p(e[o],t,n).source);return s(new RegExp("(?:"+r.join("|")+")",d(n)),t)}(e,t,n):function(e,t,n){return f(a(e,n),t,n)}(e,t,n)}},,,,,function(e,t,n){"use strict";var r=Object.getOwnPropertySymbols,o=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;function i(e){if(null===e||void 0===e)throw new TypeError("Object.assign cannot be called with null or undefined");return Object(e)}e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map((function(e){return t[e]})).join(""))return!1;var r={};return"abcdefghijklmnopqrst".split("").forEach((function(e){r[e]=e})),"abcdefghijklmnopqrst"===Object.keys(Object.assign({},r)).join("")}catch(o){return!1}}()?Object.assign:function(e,t){for(var n,l,u=i(e),c=1;c<arguments.length;c++){for(var s in n=Object(arguments[c]))o.call(n,s)&&(u[s]=n[s]);if(r){l=r(n);for(var d=0;d<l.length;d++)a.call(n,l[d])&&(u[l[d]]=n[l[d]])}}return u}},function(e,t,n){"use strict";e.exports=function(e,t){return function(){for(var n=new Array(arguments.length),r=0;r<n.length;r++)n[r]=arguments[r];return e.apply(t,n)}}},function(e,t,n){"use strict";var r=n(21);function o(e){return encodeURIComponent(e).replace(/%40/gi,"@").replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}e.exports=function(e,t,n){if(!t)return e;var a;if(n)a=n(t);else if(r.isURLSearchParams(t))a=t.toString();else{var i=[];r.forEach(t,(function(e,t){null!==e&&"undefined"!==typeof e&&(r.isArray(e)?t+="[]":e=[e],r.forEach(e,(function(e){r.isDate(e)?e=e.toISOString():r.isObject(e)&&(e=JSON.stringify(e)),i.push(o(t)+"="+o(e))})))})),a=i.join("&")}if(a){var l=e.indexOf("#");-1!==l&&(e=e.slice(0,l)),e+=(-1===e.indexOf("?")?"?":"&")+a}return e}},function(e,t,n){"use strict";e.exports=function(e){return!(!e||!e.__CANCEL__)}},function(e,t,n){"use strict";(function(t){var r=n(21),o=n(113),a={"Content-Type":"application/x-www-form-urlencoded"};function i(e,t){!r.isUndefined(e)&&r.isUndefined(e["Content-Type"])&&(e["Content-Type"]=t)}var l={adapter:function(){var e;return"undefined"!==typeof XMLHttpRequest?e=n(78):"undefined"!==typeof t&&"[object process]"===Object.prototype.toString.call(t)&&(e=n(78)),e}(),transformRequest:[function(e,t){return o(t,"Accept"),o(t,"Content-Type"),r.isFormData(e)||r.isArrayBuffer(e)||r.isBuffer(e)||r.isStream(e)||r.isFile(e)||r.isBlob(e)?e:r.isArrayBufferView(e)?e.buffer:r.isURLSearchParams(e)?(i(t,"application/x-www-form-urlencoded;charset=utf-8"),e.toString()):r.isObject(e)?(i(t,"application/json;charset=utf-8"),JSON.stringify(e)):e}],transformResponse:[function(e){if("string"===typeof e)try{e=JSON.parse(e)}catch(t){}return e}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,validateStatus:function(e){return e>=200&&e<300},headers:{common:{Accept:"application/json, text/plain, */*"}}};r.forEach(["delete","get","head"],(function(e){l.headers[e]={}})),r.forEach(["post","put","patch"],(function(e){l.headers[e]=r.merge(a)})),e.exports=l}).call(this,n(112))},function(e,t,n){"use strict";var r=n(21),o=n(114),a=n(75),i=n(116),l=n(119),u=n(120),c=n(79);e.exports=function(e){return new Promise((function(t,s){var d=e.data,f=e.headers;r.isFormData(d)&&delete f["Content-Type"];var p=new XMLHttpRequest;if(e.auth){var h=e.auth.username||"",m=e.auth.password||"";f.Authorization="Basic "+btoa(h+":"+m)}var v=i(e.baseURL,e.url);if(p.open(e.method.toUpperCase(),a(v,e.params,e.paramsSerializer),!0),p.timeout=e.timeout,p.onreadystatechange=function(){if(p&&4===p.readyState&&(0!==p.status||p.responseURL&&0===p.responseURL.indexOf("file:"))){var n="getAllResponseHeaders"in p?l(p.getAllResponseHeaders()):null,r={data:e.responseType&&"text"!==e.responseType?p.response:p.responseText,status:p.status,statusText:p.statusText,headers:n,config:e,request:p};o(t,s,r),p=null}},p.onabort=function(){p&&(s(c("Request aborted",e,"ECONNABORTED",p)),p=null)},p.onerror=function(){s(c("Network Error",e,null,p)),p=null},p.ontimeout=function(){var t="timeout of "+e.timeout+"ms exceeded";e.timeoutErrorMessage&&(t=e.timeoutErrorMessage),s(c(t,e,"ECONNABORTED",p)),p=null},r.isStandardBrowserEnv()){var b=n(121),y=(e.withCredentials||u(v))&&e.xsrfCookieName?b.read(e.xsrfCookieName):void 0;y&&(f[e.xsrfHeaderName]=y)}if("setRequestHeader"in p&&r.forEach(f,(function(e,t){"undefined"===typeof d&&"content-type"===t.toLowerCase()?delete f[t]:p.setRequestHeader(t,e)})),r.isUndefined(e.withCredentials)||(p.withCredentials=!!e.withCredentials),e.responseType)try{p.responseType=e.responseType}catch(g){if("json"!==e.responseType)throw g}"function"===typeof e.onDownloadProgress&&p.addEventListener("progress",e.onDownloadProgress),"function"===typeof e.onUploadProgress&&p.upload&&p.upload.addEventListener("progress",e.onUploadProgress),e.cancelToken&&e.cancelToken.promise.then((function(e){p&&(p.abort(),s(e),p=null)})),void 0===d&&(d=null),p.send(d)}))}},function(e,t,n){"use strict";var r=n(115);e.exports=function(e,t,n,o,a){var i=new Error(e);return r(i,t,n,o,a)}},function(e,t,n){"use strict";var r=n(21);e.exports=function(e,t){t=t||{};var n={},o=["url","method","params","data"],a=["headers","auth","proxy"],i=["baseURL","url","transformRequest","transformResponse","paramsSerializer","timeout","withCredentials","adapter","responseType","xsrfCookieName","xsrfHeaderName","onUploadProgress","onDownloadProgress","maxContentLength","validateStatus","maxRedirects","httpAgent","httpsAgent","cancelToken","socketPath"];r.forEach(o,(function(e){"undefined"!==typeof t[e]&&(n[e]=t[e])})),r.forEach(a,(function(o){r.isObject(t[o])?n[o]=r.deepMerge(e[o],t[o]):"undefined"!==typeof t[o]?n[o]=t[o]:r.isObject(e[o])?n[o]=r.deepMerge(e[o]):"undefined"!==typeof e[o]&&(n[o]=e[o])})),r.forEach(i,(function(r){"undefined"!==typeof t[r]?n[r]=t[r]:"undefined"!==typeof e[r]&&(n[r]=e[r])}));var l=o.concat(a).concat(i),u=Object.keys(t).filter((function(e){return-1===l.indexOf(e)}));return r.forEach(u,(function(r){"undefined"!==typeof t[r]?n[r]=t[r]:"undefined"!==typeof e[r]&&(n[r]=e[r])})),n}},function(e,t,n){"use strict";function r(e){this.message=e}r.prototype.toString=function(){return"Cancel"+(this.message?": "+this.message:"")},r.prototype.__CANCEL__=!0,e.exports=r},function(e,t,n){"use strict";n.r(t);var r=n(60);n.d(t,"default",(function(){return r.a}))},function(e,t,n){"use strict";function r(e){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e))return Array.from(e)}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";function r(e){if(Array.isArray(e))return e}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";function r(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}n.d(t,"a",(function(){return r}))},function(e,t,n){"use strict";var r=n(44),o={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},a={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},i={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},l={};function u(e){return r.isMemo(e)?i:l[e.$$typeof]||o}l[r.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0};var c=Object.defineProperty,s=Object.getOwnPropertyNames,d=Object.getOwnPropertySymbols,f=Object.getOwnPropertyDescriptor,p=Object.getPrototypeOf,h=Object.prototype;e.exports=function e(t,n,r){if("string"!==typeof n){if(h){var o=p(n);o&&o!==h&&e(t,o,r)}var i=s(n);d&&(i=i.concat(d(n)));for(var l=u(t),m=u(n),v=0;v<i.length;++v){var b=i[v];if(!a[b]&&(!r||!r[b])&&(!m||!m[b])&&(!l||!l[b])){var y=f(n,b);try{c(t,b,y)}catch(g){}}}}return t}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"}),"RadioButtonUnchecked");t.default=a},function(e,t,n){"use strict";(function(t){var n="__global_unique_id__";e.exports=function(){return t[n]=(t[n]||0)+1}}).call(this,n(128))},function(e,t,n){"use strict";var r=n(44),o={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},a={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},i={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},l={};function u(e){return r.isMemo(e)?i:l[e.$$typeof]||o}l[r.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},l[r.Memo]=i;var c=Object.defineProperty,s=Object.getOwnPropertyNames,d=Object.getOwnPropertySymbols,f=Object.getOwnPropertyDescriptor,p=Object.getPrototypeOf,h=Object.prototype;e.exports=function e(t,n,r){if("string"!==typeof n){if(h){var o=p(n);o&&o!==h&&e(t,o,r)}var i=s(n);d&&(i=i.concat(d(n)));for(var l=u(t),m=u(n),v=0;v<i.length;++v){var b=i[v];if(!a[b]&&(!r||!r[b])&&(!m||!m[b])&&(!l||!l[b])){var y=f(n,b);try{c(t,b,y)}catch(g){}}}}return t}},function(e,t,n){"use strict";n.d(t,"a",(function(){return a}));var r=n(20);function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function a(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?o(Object(n),!0).forEach((function(t){Object(r.a)(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):o(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}},function(e,t,n){"use strict";var r=n(29);Object.defineProperty(t,"__esModule",{value:!0}),t.default=void 0;var o=r(n(0)),a=(0,r(n(31)).default)(o.default.createElement("path",{d:"M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z"}),"KeyboardArrowRight");t.default=a},function(e,t,n){"use strict";var r=n(20),o=n(2),a=n(162),i=n(1),l=["xs","sm","md","lg","xl"];function u(e){var t=e.values,n=void 0===t?{xs:0,sm:600,md:960,lg:1280,xl:1920}:t,r=e.unit,a=void 0===r?"px":r,u=e.step,c=void 0===u?5:u,s=Object(o.a)(e,["values","unit","step"]);function d(e){var t="number"===typeof n[e]?n[e]:e;return"@media (min-width:".concat(t).concat(a,")")}function f(e,t){var r=l.indexOf(t);return r===l.length-1?d(e):"@media (min-width:".concat("number"===typeof n[e]?n[e]:e).concat(a,") and ")+"(max-width:".concat((-1!==r&&"number"===typeof n[l[r+1]]?n[l[r+1]]:t)-c/100).concat(a,")")}return Object(i.a)({keys:l,values:n,up:d,down:function(e){var t=l.indexOf(e)+1,r=n[l[t]];return t===l.length?d("xs"):"@media (max-width:".concat(("number"===typeof r&&t>0?r:e)-c/100).concat(a,")")},between:f,only:function(e){return f(e,e)},width:function(e){return n[e]}},s)}function c(e,t,n){var o;return Object(i.a)({gutters:function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return Object(i.a)({paddingLeft:t(2),paddingRight:t(2)},n,Object(r.a)({},e.up("sm"),Object(i.a)({paddingLeft:t(3),paddingRight:t(3)},n[e.up("sm")])))},toolbar:(o={minHeight:56},Object(r.a)(o,"".concat(e.up("xs")," and (orientation: landscape)"),{minHeight:48}),Object(r.a)(o,e.up("sm"),{minHeight:64}),o)},n)}var s={black:"#000",white:"#fff"},d={50:"#fafafa",100:"#f5f5f5",200:"#eeeeee",300:"#e0e0e0",400:"#bdbdbd",500:"#9e9e9e",600:"#757575",700:"#616161",800:"#424242",900:"#212121",A100:"#d5d5d5",A200:"#aaaaaa",A400:"#303030",A700:"#616161"},f={50:"#e8eaf6",100:"#c5cae9",200:"#9fa8da",300:"#7986cb",400:"#5c6bc0",500:"#3f51b5",600:"#3949ab",700:"#303f9f",800:"#283593",900:"#1a237e",A100:"#8c9eff",A200:"#536dfe",A400:"#3d5afe",A700:"#304ffe"},p={50:"#fce4ec",100:"#f8bbd0",200:"#f48fb1",300:"#f06292",400:"#ec407a",500:"#e91e63",600:"#d81b60",700:"#c2185b",800:"#ad1457",900:"#880e4f",A100:"#ff80ab",A200:"#ff4081",A400:"#f50057",A700:"#c51162"},h={50:"#ffebee",100:"#ffcdd2",200:"#ef9a9a",300:"#e57373",400:"#ef5350",500:"#f44336",600:"#e53935",700:"#d32f2f",800:"#c62828",900:"#b71c1c",A100:"#ff8a80",A200:"#ff5252",A400:"#ff1744",A700:"#d50000"},m={50:"#fff3e0",100:"#ffe0b2",200:"#ffcc80",300:"#ffb74d",400:"#ffa726",500:"#ff9800",600:"#fb8c00",700:"#f57c00",800:"#ef6c00",900:"#e65100",A100:"#ffd180",A200:"#ffab40",A400:"#ff9100",A700:"#ff6d00"},v={50:"#e3f2fd",100:"#bbdefb",200:"#90caf9",300:"#64b5f6",400:"#42a5f5",500:"#2196f3",600:"#1e88e5",700:"#1976d2",800:"#1565c0",900:"#0d47a1",A100:"#82b1ff",A200:"#448aff",A400:"#2979ff",A700:"#2962ff"},b={50:"#e8f5e9",100:"#c8e6c9",200:"#a5d6a7",300:"#81c784",400:"#66bb6a",500:"#4caf50",600:"#43a047",700:"#388e3c",800:"#2e7d32",900:"#1b5e20",A100:"#b9f6ca",A200:"#69f0ae",A400:"#00e676",A700:"#00c853"},y=n(10),g={text:{primary:"rgba(0, 0, 0, 0.87)",secondary:"rgba(0, 0, 0, 0.54)",disabled:"rgba(0, 0, 0, 0.38)",hint:"rgba(0, 0, 0, 0.38)"},divider:"rgba(0, 0, 0, 0.12)",background:{paper:s.white,default:d[50]},action:{active:"rgba(0, 0, 0, 0.54)",hover:"rgba(0, 0, 0, 0.08)",hoverOpacity:.08,selected:"rgba(0, 0, 0, 0.14)",disabled:"rgba(0, 0, 0, 0.26)",disabledBackground:"rgba(0, 0, 0, 0.12)"}},x={text:{primary:s.white,secondary:"rgba(255, 255, 255, 0.7)",disabled:"rgba(255, 255, 255, 0.5)",hint:"rgba(255, 255, 255, 0.5)",icon:"rgba(255, 255, 255, 0.5)"},divider:"rgba(255, 255, 255, 0.12)",background:{paper:d[800],default:"#303030"},action:{active:s.white,hover:"rgba(255, 255, 255, 0.1)",hoverOpacity:.1,selected:"rgba(255, 255, 255, 0.2)",disabled:"rgba(255, 255, 255, 0.3)",disabledBackground:"rgba(255, 255, 255, 0.12)"}};function w(e,t,n,r){e[t]||(e.hasOwnProperty(n)?e[t]=e[n]:"light"===t?e.light=Object(y.d)(e.main,r):"dark"===t&&(e.dark=Object(y.a)(e.main,1.5*r)))}function k(e){var t=e.primary,n=void 0===t?{light:f[300],main:f[500],dark:f[700]}:t,r=e.secondary,l=void 0===r?{light:p.A200,main:p.A400,dark:p.A700}:r,u=e.error,c=void 0===u?{light:h[300],main:h[500],dark:h[700]}:u,k=e.warning,E=void 0===k?{light:m[300],main:m[500],dark:m[700]}:k,O=e.info,S=void 0===O?{light:v[300],main:v[500],dark:v[700]}:O,C=e.success,T=void 0===C?{light:b[300],main:b[500],dark:b[700]}:C,j=e.type,P=void 0===j?"light":j,R=e.contrastThreshold,N=void 0===R?3:R,M=e.tonalOffset,_=void 0===M?.2:M,A=Object(o.a)(e,["primary","secondary","error","warning","info","success","type","contrastThreshold","tonalOffset"]);function z(e){if(!e)throw new TypeError("Material-UI: missing background argument in getContrastText(".concat(e,")."));return Object(y.c)(e,x.text.primary)>=N?x.text.primary:g.text.primary}function I(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:500,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:300,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:700;return!(e=Object(i.a)({},e)).main&&e[t]&&(e.main=e[t]),w(e,"light",n,_),w(e,"dark",r,_),e.contrastText||(e.contrastText=z(e.main)),e}var L={dark:x,light:g};return Object(a.a)(Object(i.a)({common:s,type:P,primary:I(n),secondary:I(l,"A400","A200","A700"),error:I(c),warning:I(E),info:I(S),success:I(T),grey:d,contrastThreshold:N,getContrastText:z,augmentColor:I,tonalOffset:_},L[P]),A)}function E(e){return Math.round(1e5*e)/1e5}var O={textTransform:"uppercase"};function S(e,t){var n="function"===typeof t?t(e):t,r=n.fontFamily,l=void 0===r?'"Roboto", "Helvetica", "Arial", sans-serif':r,u=n.fontSize,c=void 0===u?14:u,s=n.fontWeightLight,d=void 0===s?300:s,f=n.fontWeightRegular,p=void 0===f?400:f,h=n.fontWeightMedium,m=void 0===h?500:h,v=n.fontWeightBold,b=void 0===v?700:v,y=n.htmlFontSize,g=void 0===y?16:y,x=n.allVariants,w=n.pxToRem,k=Object(o.a)(n,["fontFamily","fontSize","fontWeightLight","fontWeightRegular","fontWeightMedium","fontWeightBold","htmlFontSize","allVariants","pxToRem"]);var S=c/14,C=w||function(e){return"".concat(e/g*S,"rem")},T=function(e,t,n,r,o){return Object(i.a)({fontFamily:l,fontWeight:e,fontSize:C(t),lineHeight:n},'"Roboto", "Helvetica", "Arial", sans-serif'===l?{letterSpacing:"".concat(E(r/t),"em")}:{},{},o,{},x)},j={h1:T(d,96,1.167,-1.5),h2:T(d,60,1.2,-.5),h3:T(p,48,1.167,0),h4:T(p,34,1.235,.25),h5:T(p,24,1.334,0),h6:T(m,20,1.6,.15),subtitle1:T(p,16,1.75,.15),subtitle2:T(m,14,1.57,.1),body1:T(p,16,1.5,.15),body2:T(p,14,1.43,.15),button:T(m,14,1.75,.4,O),caption:T(p,12,1.66,.4),overline:T(p,12,2.66,1,O)};return Object(a.a)(Object(i.a)({htmlFontSize:g,pxToRem:C,round:E,fontFamily:l,fontSize:c,fontWeightLight:d,fontWeightRegular:p,fontWeightMedium:m,fontWeightBold:b},j),k,{clone:!1})}function C(){return["".concat(arguments.length<=0?void 0:arguments[0],"px ").concat(arguments.length<=1?void 0:arguments[1],"px ").concat(arguments.length<=2?void 0:arguments[2],"px ").concat(arguments.length<=3?void 0:arguments[3],"px rgba(0,0,0,").concat(.2,")"),"".concat(arguments.length<=4?void 0:arguments[4],"px ").concat(arguments.length<=5?void 0:arguments[5],"px ").concat(arguments.length<=6?void 0:arguments[6],"px ").concat(arguments.length<=7?void 0:arguments[7],"px rgba(0,0,0,").concat(.14,")"),"".concat(arguments.length<=8?void 0:arguments[8],"px ").concat(arguments.length<=9?void 0:arguments[9],"px ").concat(arguments.length<=10?void 0:arguments[10],"px ").concat(arguments.length<=11?void 0:arguments[11],"px rgba(0,0,0,").concat(.12,")")].join(",")}var T=["none",C(0,2,1,-1,0,1,1,0,0,1,3,0),C(0,3,1,-2,0,2,2,0,0,1,5,0),C(0,3,3,-2,0,3,4,0,0,1,8,0),C(0,2,4,-1,0,4,5,0,0,1,10,0),C(0,3,5,-1,0,5,8,0,0,1,14,0),C(0,3,5,-1,0,6,10,0,0,1,18,0),C(0,4,5,-2,0,7,10,1,0,2,16,1),C(0,5,5,-3,0,8,10,1,0,3,14,2),C(0,5,6,-3,0,9,12,1,0,3,16,2),C(0,6,6,-3,0,10,14,1,0,4,18,3),C(0,6,7,-4,0,11,15,1,0,4,20,3),C(0,7,8,-4,0,12,17,2,0,5,22,4),C(0,7,8,-4,0,13,19,2,0,5,24,4),C(0,7,9,-4,0,14,21,2,0,5,26,4),C(0,8,9,-5,0,15,22,2,0,6,28,5),C(0,8,10,-5,0,16,24,2,0,6,30,5),C(0,8,11,-5,0,17,26,2,0,6,32,5),C(0,9,11,-5,0,18,28,2,0,7,34,6),C(0,9,12,-6,0,19,29,2,0,7,36,6),C(0,10,13,-6,0,20,31,3,0,8,38,7),C(0,10,13,-6,0,21,33,3,0,8,40,7),C(0,10,14,-6,0,22,35,3,0,8,42,7),C(0,11,14,-7,0,23,36,3,0,9,44,8),C(0,11,15,-7,0,24,38,3,0,9,46,8)],j={borderRadius:4};function P(){var e,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:8;if(t.mui)return t;e="function"===typeof t?t:function(e){return t*e};var n=function(){for(var t=arguments.length,n=new Array(t),r=0;r<t;r++)n[r]=arguments[r];return 0===n.length?e(1):1===n.length?e(n[0]):n.map((function(t){var n=e(t);return"number"===typeof n?"".concat(n,"px"):n})).join(" ")};return Object.defineProperty(n,"unit",{get:function(){return t}}),n.mui=!0,n}var R={easeInOut:"cubic-bezier(0.4, 0, 0.2, 1)",easeOut:"cubic-bezier(0.0, 0, 0.2, 1)",easeIn:"cubic-bezier(0.4, 0, 1, 1)",sharp:"cubic-bezier(0.4, 0, 0.6, 1)"},N={shortest:150,shorter:200,short:250,standard:300,complex:375,enteringScreen:225,leavingScreen:195},M=function(e){return"".concat(Math.round(e),"ms")},_={easing:R,duration:N,create:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:["all"],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.duration,r=void 0===n?N.standard:n,a=t.easing,i=void 0===a?R.easeInOut:a,l=t.delay,u=void 0===l?0:l;Object(o.a)(t,["duration","easing","delay"]);return(Array.isArray(e)?e:[e]).map((function(e){return"".concat(e," ").concat("string"===typeof r?r:M(r)," ").concat(i," ").concat("string"===typeof u?u:M(u))})).join(",")},getAutoHeightDuration:function(e){if(!e)return 0;var t=e/36;return Math.round(10*(4+15*Math.pow(t,.25)+t/5))}},A=n(59);t.a=function(){for(var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.breakpoints,n=void 0===t?{}:t,r=e.mixins,i=void 0===r?{}:r,l=e.palette,s=void 0===l?{}:l,d=e.spacing,f=e.typography,p=void 0===f?{}:f,h=Object(o.a)(e,["breakpoints","mixins","palette","spacing","typography"]),m=k(s),v=u(n),b=P(d),y=Object(a.a)({breakpoints:v,direction:"ltr",mixins:c(v,b,i),overrides:{},palette:m,props:{},shadows:T,typography:S(m,p),spacing:b,shape:j,transitions:_,zIndex:A.a},h),g=arguments.length,x=new Array(g>1?g-1:0),w=1;w<g;w++)x[w-1]=arguments[w];return y=x.reduce((function(e,t){return Object(a.a)(e,t)}),y)}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(0),o=n.n(r),a=n(57);function i(){return o.a.useContext(a.a)}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(9)),u=n.n(l),c=n(3),s=n(8),d=n(30),f=n(4),p="undefined"!==typeof window?i.a.useLayoutEffect:i.a.useEffect;var h=function(e){var t=e.children,n=e.defer,r=void 0!==n&&n,o=e.fallback,a=void 0===o?null:o,l=i.a.useState(!1),u=l[0],c=l[1];return p((function(){r||c(!0)}),[r]),i.a.useEffect((function(){r&&c(!0)}),[r]),i.a.createElement(i.a.Fragment,null,u?t:a)},m=!0,v=!1,b=null,y={text:!0,search:!0,url:!0,tel:!0,email:!0,password:!0,number:!0,date:!0,month:!0,week:!0,time:!0,datetime:!0,"datetime-local":!0};function g(e){e.metaKey||e.altKey||e.ctrlKey||(m=!0)}function x(){m=!1}function w(){"hidden"===this.visibilityState&&v&&(m=!0)}function k(e){var t=e.target;try{return t.matches(":focus-visible")}catch(n){}return m||function(e){var t=e.type,n=e.tagName;return!("INPUT"!==n||!y[t]||e.readOnly)||("TEXTAREA"===n&&!e.readOnly||!!e.isContentEditable)}(t)}function E(){v=!0,window.clearTimeout(b),b=window.setTimeout((function(){v=!1}),100)}function O(){return{isFocusVisible:k,onBlurVisible:E,ref:i.a.useCallback((function(e){var t,n=u.a.findDOMNode(e);null!=n&&((t=n.ownerDocument).addEventListener("keydown",g,!0),t.addEventListener("mousedown",x,!0),t.addEventListener("pointerdown",x,!0),t.addEventListener("touchstart",x,!0),t.addEventListener("visibilitychange",w,!0))}),[])}}var S=n(11),C=n(15),T=n(12),j=n(49),P=n(43);function R(e,t){var n=Object.create(null);return e&&a.Children.map(e,(function(e){return e})).forEach((function(e){n[e.key]=function(e){return t&&Object(a.isValidElement)(e)?t(e):e}(e)})),n}function N(e,t,n){return null!=n[t]?n[t]:e.props[t]}function M(e,t,n){var r=R(e.children),o=function(e,t){function n(n){return n in t?t[n]:e[n]}e=e||{},t=t||{};var r,o=Object.create(null),a=[];for(var i in e)i in t?a.length&&(o[i]=a,a=[]):a.push(i);var l={};for(var u in t){if(o[u])for(r=0;r<o[u].length;r++){var c=o[u][r];l[o[u][r]]=n(c)}l[u]=n(u)}for(r=0;r<a.length;r++)l[a[r]]=n(a[r]);return l}(t,r);return Object.keys(o).forEach((function(i){var l=o[i];if(Object(a.isValidElement)(l)){var u=i in t,c=i in r,s=t[i],d=Object(a.isValidElement)(s)&&!s.props.in;!c||u&&!d?c||!u||d?c&&u&&Object(a.isValidElement)(s)&&(o[i]=Object(a.cloneElement)(l,{onExited:n.bind(null,l),in:s.props.in,exit:N(l,"exit",e),enter:N(l,"enter",e)})):o[i]=Object(a.cloneElement)(l,{in:!1}):o[i]=Object(a.cloneElement)(l,{onExited:n.bind(null,l),in:!0,exit:N(l,"exit",e),enter:N(l,"enter",e)})}})),o}var _=Object.values||function(e){return Object.keys(e).map((function(t){return e[t]}))},A=function(e){function t(t,n){var r,o=(r=e.call(this,t,n)||this).handleExited.bind(Object(j.a)(Object(j.a)(r)));return r.state={contextValue:{isMounting:!0},handleExited:o,firstRender:!0},r}Object(T.a)(t,e);var n=t.prototype;return n.componentDidMount=function(){this.mounted=!0,this.setState({contextValue:{isMounting:!1}})},n.componentWillUnmount=function(){this.mounted=!1},t.getDerivedStateFromProps=function(e,t){var n,r,o=t.children,i=t.handleExited;return{children:t.firstRender?(n=e,r=i,R(n.children,(function(e){return Object(a.cloneElement)(e,{onExited:r.bind(null,e),in:!0,appear:N(e,"appear",n),enter:N(e,"enter",n),exit:N(e,"exit",n)})}))):M(e,o,i),firstRender:!1}},n.handleExited=function(e,t){var n=R(this.props.children);e.key in n||(e.props.onExited&&e.props.onExited(t),this.mounted&&this.setState((function(t){var n=Object(r.a)({},t.children);return delete n[e.key],{children:n}})))},n.render=function(){var e=this.props,t=e.component,n=e.childFactory,r=Object(C.a)(e,["component","childFactory"]),o=this.state.contextValue,a=_(this.state.children).map(n);return delete r.appear,delete r.enter,delete r.exit,null===t?i.a.createElement(P.a.Provider,{value:o},a):i.a.createElement(P.a.Provider,{value:o},i.a.createElement(t,r,a))},t}(i.a.Component);A.propTypes={},A.defaultProps={component:"div",childFactory:function(e){return e}};var z=A,I="undefined"===typeof window?i.a.useEffect:i.a.useLayoutEffect;var L=function(e){var t=e.classes,n=e.pulsate,r=void 0!==n&&n,o=e.rippleX,a=e.rippleY,l=e.rippleSize,u=e.in,s=e.onExited,f=void 0===s?function(){}:s,p=e.timeout,h=i.a.useState(!1),m=h[0],v=h[1],b=Object(c.a)(t.ripple,t.rippleVisible,r&&t.ripplePulsate),y={width:l,height:l,top:-l/2+a,left:-l/2+o},g=Object(c.a)(t.child,m&&t.childLeaving,r&&t.childPulsate),x=Object(d.a)(f);return I((function(){if(!u){v(!0);var e=setTimeout(x,p);return function(){clearTimeout(e)}}}),[x,u,p]),i.a.createElement("span",{className:b,style:y},i.a.createElement("span",{className:g}))},D=i.a.forwardRef((function(e,t){var n=e.center,a=void 0!==n&&n,l=e.classes,u=e.className,s=Object(o.a)(e,["center","classes","className"]),d=i.a.useState([]),f=d[0],p=d[1],h=i.a.useRef(0),m=i.a.useRef(null);i.a.useEffect((function(){m.current&&(m.current(),m.current=null)}),[f]);var v=i.a.useRef(!1),b=i.a.useRef(null),y=i.a.useRef(null),g=i.a.useRef(null);i.a.useEffect((function(){return function(){clearTimeout(b.current)}}),[]);var x=i.a.useCallback((function(e){var t=e.pulsate,n=e.rippleX,r=e.rippleY,o=e.rippleSize,a=e.cb;p((function(e){return[].concat(Object(S.a)(e),[i.a.createElement(L,{key:h.current,classes:l,timeout:550,pulsate:t,rippleX:n,rippleY:r,rippleSize:o})])})),h.current+=1,m.current=a}),[l]),w=i.a.useCallback((function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=arguments.length>2?arguments[2]:void 0,r=t.pulsate,o=void 0!==r&&r,i=t.center,l=void 0===i?a||t.pulsate:i,u=t.fakeElement,c=void 0!==u&&u;if("mousedown"===e.type&&v.current)v.current=!1;else{"touchstart"===e.type&&(v.current=!0);var s,d,f,p=c?null:g.current,h=p?p.getBoundingClientRect():{width:0,height:0,left:0,top:0};if(l||0===e.clientX&&0===e.clientY||!e.clientX&&!e.touches)s=Math.round(h.width/2),d=Math.round(h.height/2);else{var m=e.clientX?e.clientX:e.touches[0].clientX,w=e.clientY?e.clientY:e.touches[0].clientY;s=Math.round(m-h.left),d=Math.round(w-h.top)}if(l)(f=Math.sqrt((2*Math.pow(h.width,2)+Math.pow(h.height,2))/3))%2===0&&(f+=1);else{var k=2*Math.max(Math.abs((p?p.clientWidth:0)-s),s)+2,E=2*Math.max(Math.abs((p?p.clientHeight:0)-d),d)+2;f=Math.sqrt(Math.pow(k,2)+Math.pow(E,2))}e.touches?(y.current=function(){x({pulsate:o,rippleX:s,rippleY:d,rippleSize:f,cb:n})},b.current=setTimeout((function(){y.current&&(y.current(),y.current=null)}),80)):x({pulsate:o,rippleX:s,rippleY:d,rippleSize:f,cb:n})}}),[a,x]),k=i.a.useCallback((function(){w({},{pulsate:!0})}),[w]),E=i.a.useCallback((function(e,t){if(clearTimeout(b.current),"touchend"===e.type&&y.current)return e.persist(),y.current(),y.current=null,void(b.current=setTimeout((function(){E(e,t)})));y.current=null,p((function(e){return e.length>0?e.slice(1):e})),m.current=t}),[]);return i.a.useImperativeHandle(t,(function(){return{pulsate:k,start:w,stop:E}}),[k,w,E]),i.a.createElement("span",Object(r.a)({className:Object(c.a)(l.root,u),ref:g},s),i.a.createElement(z,{component:null,exit:!0},f))}));var F,U=Object(f.a)((function(e){return{root:{overflow:"hidden",pointerEvents:"none",position:"absolute",zIndex:0,top:0,right:0,bottom:0,left:0,borderRadius:"inherit"},ripple:{opacity:0,position:"absolute"},rippleVisible:{opacity:.3,transform:"scale(1)",animation:"$enter ".concat(550,"ms ").concat(e.transitions.easing.easeInOut)},ripplePulsate:{animationDuration:"".concat(e.transitions.duration.shorter,"ms")},child:{opacity:1,display:"block",width:"100%",height:"100%",borderRadius:"50%",backgroundColor:"currentColor"},childLeaving:{opacity:0,animation:"$exit ".concat(550,"ms ").concat(e.transitions.easing.easeInOut)},childPulsate:{position:"absolute",left:0,top:0,animation:"$pulsate 2500ms ".concat(e.transitions.easing.easeInOut," 200ms infinite")},"@keyframes enter":{"0%":{transform:"scale(0)",opacity:.1},"100%":{transform:"scale(1)",opacity:.3}},"@keyframes exit":{"0%":{opacity:1},"100%":{opacity:0}},"@keyframes pulsate":{"0%":{transform:"scale(1)"},"50%":{transform:"scale(0.92)"},"100%":{transform:"scale(1)"}}}}),{flip:!1,name:"MuiTouchRipple"})(((F=i.a.memo(D)).muiName="MuiTouchRipple",F)),$=i.a.forwardRef((function(e,t){var n=e.action,a=e.buttonRef,l=e.centerRipple,f=void 0!==l&&l,p=e.children,m=e.classes,v=e.className,b=e.component,y=void 0===b?"button":b,g=e.disabled,x=void 0!==g&&g,w=e.disableRipple,k=void 0!==w&&w,E=e.disableTouchRipple,S=void 0!==E&&E,C=e.focusRipple,T=void 0!==C&&C,j=e.focusVisibleClassName,P=e.onBlur,R=e.onClick,N=e.onFocus,M=e.onFocusVisible,_=e.onKeyDown,A=e.onKeyUp,z=e.onMouseDown,I=e.onMouseLeave,L=e.onMouseUp,D=e.onTouchEnd,F=e.onTouchMove,$=e.onTouchStart,B=e.onDragLeave,W=e.tabIndex,V=void 0===W?0:W,H=e.TouchRippleProps,q=e.type,K=void 0===q?"button":q,Q=Object(o.a)(e,["action","buttonRef","centerRipple","children","classes","className","component","disabled","disableRipple","disableTouchRipple","focusRipple","focusVisibleClassName","onBlur","onClick","onFocus","onFocusVisible","onKeyDown","onKeyUp","onMouseDown","onMouseLeave","onMouseUp","onTouchEnd","onTouchMove","onTouchStart","onDragLeave","tabIndex","TouchRippleProps","type"]),X=i.a.useRef(null);var G=i.a.useRef(null),Y=i.a.useState(!1),J=Y[0],Z=Y[1];x&&J&&Z(!1);var ee=O(),te=ee.isFocusVisible,ne=ee.onBlurVisible,re=ee.ref;function oe(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:S;return Object(d.a)((function(r){return t&&t(r),!n&&G.current&&G.current[e](r),!0}))}i.a.useImperativeHandle(n,(function(){return{focusVisible:function(){Z(!0),X.current.focus()}}}),[]),i.a.useEffect((function(){J&&T&&!k&&G.current.pulsate()}),[k,T,J]);var ae=oe("start",z),ie=oe("stop",B),le=oe("stop",L),ue=oe("stop",(function(e){J&&e.preventDefault(),I&&I(e)})),ce=oe("start",$),se=oe("stop",D),de=oe("stop",F),fe=oe("stop",(function(e){J&&(ne(e),Z(!1)),P&&P(e)}),!1),pe=Object(d.a)((function(e){x||(X.current||(X.current=e.currentTarget),te(e)&&(Z(!0),M&&M(e)),N&&N(e))})),he=function(){var e=u.a.findDOMNode(X.current);return y&&"button"!==y&&!("A"===e.tagName&&e.href)},me=i.a.useRef(!1),ve=Object(d.a)((function(e){T&&!me.current&&J&&G.current&&" "===e.key&&(me.current=!0,e.persist(),G.current.stop(e,(function(){G.current.start(e)}))),_&&_(e),e.target===e.currentTarget&&he()&&"Enter"===e.key&&(e.preventDefault(),R&&R(e))})),be=Object(d.a)((function(e){T&&" "===e.key&&G.current&&J&&!e.defaultPrevented&&(me.current=!1,e.persist(),G.current.stop(e,(function(){G.current.pulsate(e)}))),A&&A(e),e.target===e.currentTarget&&he()&&" "===e.key&&!e.defaultPrevented&&(e.preventDefault(),R&&R(e))})),ye=y;"button"===ye&&Q.href&&(ye="a");var ge={};"button"===ye?(ge.type=K,ge.disabled=x):("a"===ye&&Q.href||(ge.role="button"),ge["aria-disabled"]=x);var xe=Object(s.a)(a,t),we=Object(s.a)(re,X),ke=Object(s.a)(xe,we);return i.a.createElement(ye,Object(r.a)({className:Object(c.a)(m.root,v,J&&[m.focusVisible,j],x&&m.disabled),onBlur:fe,onClick:R,onFocus:pe,onKeyDown:ve,onKeyUp:be,onMouseDown:ae,onMouseLeave:ue,onMouseUp:le,onDragLeave:ie,onTouchEnd:se,onTouchMove:de,onTouchStart:ce,ref:ke,tabIndex:x?-1:V},ge,Q),p,k||x?null:i.a.createElement(h,null,i.a.createElement(U,Object(r.a)({ref:G,center:f},H))))}));t.a=Object(f.a)({root:{display:"inline-flex",alignItems:"center",justifyContent:"center",position:"relative",WebkitTapHighlightColor:"transparent",backgroundColor:"transparent",outline:0,border:0,margin:0,borderRadius:0,padding:0,cursor:"pointer",userSelect:"none",verticalAlign:"middle","-moz-appearance":"none","-webkit-appearance":"none",textDecoration:"none",color:"inherit","&::-moz-focus-inner":{borderStyle:"none"},"&$disabled":{pointerEvents:"none",cursor:"default"}},disabled:{},focusVisible:{}},{name:"MuiButtonBase"})($)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(24),c=n(40),s=n(4),d=n(6),f=n(8),p=n(61);function h(e,t){return parseInt(e[t],10)||0}var m="undefined"!==typeof window?i.a.useLayoutEffect:i.a.useEffect,v={visibility:"hidden",position:"absolute",overflow:"hidden",height:0,top:0,left:0,transform:"translateZ(0)"},b=i.a.forwardRef((function(e,t){var n=e.onChange,a=e.rows,l=e.rowsMax,u=e.rowsMin,c=void 0===u?1:u,s=e.style,d=e.value,b=Object(o.a)(e,["onChange","rows","rowsMax","rowsMin","style","value"]),y=a||c,g=i.a.useRef(null!=d).current,x=i.a.useRef(null),w=Object(f.a)(t,x),k=i.a.useRef(null),E=i.a.useState({}),O=E[0],S=E[1],C=i.a.useCallback((function(){var t=x.current,n=window.getComputedStyle(t),r=k.current;r.style.width=n.width,r.value=t.value||e.placeholder||"x";var o=n["box-sizing"],a=h(n,"padding-bottom")+h(n,"padding-top"),i=h(n,"border-bottom-width")+h(n,"border-top-width"),u=r.scrollHeight-a;r.value="x";var c=r.scrollHeight-a,s=u;y&&(s=Math.max(Number(y)*c,s)),l&&(s=Math.min(Number(l)*c,s));var d=(s=Math.max(s,c))+("border-box"===o?a+i:0),f=Math.abs(s-u)<=1;S((function(e){return d>0&&Math.abs((e.outerHeightStyle||0)-d)>1||e.overflow!==f?{overflow:f,outerHeightStyle:d}:e}))}),[l,y,e.placeholder]);i.a.useEffect((function(){var e=Object(p.a)((function(){C()}));return window.addEventListener("resize",e),function(){e.clear(),window.removeEventListener("resize",e)}}),[C]),m((function(){C()}));return i.a.createElement(i.a.Fragment,null,i.a.createElement("textarea",Object(r.a)({value:d,onChange:function(e){g||C(),n&&n(e)},ref:w,rows:y,style:Object(r.a)({height:O.outerHeightStyle,overflow:O.overflow?"hidden":null},s)},b)),i.a.createElement("textarea",{"aria-hidden":!0,className:e.className,readOnly:!0,ref:k,tabIndex:-1,style:Object(r.a)({},v,{},s)}))})),y=n(41),g="undefined"===typeof window?i.a.useEffect:i.a.useLayoutEffect,x=i.a.forwardRef((function(e,t){var n=e["aria-describedby"],a=e.autoComplete,s=e.autoFocus,p=e.classes,h=e.className,m=(e.color,e.defaultValue),v=e.disabled,x=e.endAdornment,w=(e.error,e.fullWidth),k=void 0!==w&&w,E=e.id,O=e.inputComponent,S=void 0===O?"input":O,C=e.inputProps,T=void 0===C?{}:C,j=e.inputRef,P=(e.margin,e.multiline),R=void 0!==P&&P,N=e.name,M=e.onBlur,_=e.onChange,A=e.onClick,z=e.onFocus,I=e.onKeyDown,L=e.onKeyUp,D=e.placeholder,F=e.readOnly,U=e.renderSuffix,$=e.rows,B=e.rowsMax,W=e.rowsMin,V=e.startAdornment,H=e.type,q=void 0===H?"text":H,K=e.value,Q=Object(o.a)(e,["aria-describedby","autoComplete","autoFocus","classes","className","color","defaultValue","disabled","endAdornment","error","fullWidth","id","inputComponent","inputProps","inputRef","margin","multiline","name","onBlur","onChange","onClick","onFocus","onKeyDown","onKeyUp","placeholder","readOnly","renderSuffix","rows","rowsMax","rowsMin","startAdornment","type","value"]),X=null!=T.value?T.value:K,G=i.a.useRef(null!=X).current,Y=i.a.useRef(),J=i.a.useCallback((function(e){0}),[]),Z=Object(f.a)(T.ref,J),ee=Object(f.a)(j,Z),te=Object(f.a)(Y,ee),ne=i.a.useState(!1),re=ne[0],oe=ne[1],ae=Object(c.b)();var ie=Object(u.a)({props:e,muiFormControl:ae,states:["color","disabled","error","hiddenLabel","margin","required","filled"]});ie.focused=ae?ae.focused:re,i.a.useEffect((function(){!ae&&v&&re&&(oe(!1),M&&M())}),[ae,v,re,M]);var le=ae&&ae.onFilled,ue=ae&&ae.onEmpty,ce=i.a.useCallback((function(e){Object(y.b)(e)?le&&le():ue&&ue()}),[le,ue]);g((function(){G&&ce({value:X})}),[X,ce,G]);i.a.useEffect((function(){ce(Y.current)}),[]);var se=S,de=Object(r.a)({},T,{ref:te});"string"!==typeof se?de=Object(r.a)({inputRef:te,type:q},de,{ref:null}):R?!$||B||W?(de=Object(r.a)({rows:$,rowsMax:B},de),se=b):se="textarea":de=Object(r.a)({type:q},de);return i.a.useEffect((function(){ae&&ae.setAdornedStart(Boolean(V))}),[ae,V]),i.a.createElement("div",Object(r.a)({className:Object(l.a)(p.root,p["color".concat(Object(d.a)(ie.color||"primary"))],h,ie.disabled&&p.disabled,ie.error&&p.error,k&&p.fullWidth,ie.focused&&p.focused,ae&&p.formControl,R&&p.multiline,V&&p.adornedStart,x&&p.adornedEnd,{dense:p.marginDense}[ie.margin]),onClick:function(e){Y.current&&e.currentTarget===e.target&&Y.current.focus(),A&&A(e)},ref:t},Q),V,i.a.createElement(c.a.Provider,{value:null},i.a.createElement(se,Object(r.a)({"aria-invalid":ie.error,"aria-describedby":n,autoComplete:a,autoFocus:s,defaultValue:m,disabled:ie.disabled,id:E,onAnimationStart:function(e){ce(-1!==e.animationName.indexOf("auto-fill-cancel")?Y.current:{value:"x"})},name:N,placeholder:D,readOnly:F,required:ie.required,rows:$,value:X,onKeyDown:I,onKeyUp:L},de,{className:Object(l.a)(p.input,T.className,ie.disabled&&p.disabled,R&&p.inputMultiline,ie.hiddenLabel&&p.inputHiddenLabel,V&&p.inputAdornedStart,x&&p.inputAdornedEnd,{search:p.inputTypeSearch}[q],{dense:p.inputMarginDense}[ie.margin]),onBlur:function(e){M&&M(e),T.onBlur&&T.onBlur(e),ae&&ae.onBlur?ae.onBlur(e):oe(!1)},onChange:function(e){if(!G){var t=e.target||Y.current;if(null==t)throw new TypeError("Material-UI: Expected valid input target. Did you use a custom `inputComponent` and forget to forward refs? See https://material-ui.com/r/input-component-ref-interface for more info.");ce({value:t.value})}for(var n=arguments.length,r=new Array(n>1?n-1:0),o=1;o<n;o++)r[o-1]=arguments[o];T.onChange&&T.onChange.apply(T,[e].concat(r)),_&&_.apply(void 0,[e].concat(r))},onFocus:function(e){ie.disabled?e.stopPropagation():(z&&z(e),T.onFocus&&T.onFocus(e),ae&&ae.onFocus?ae.onFocus(e):oe(!0))}}))),x,U?U(Object(r.a)({},ie,{startAdornment:V})):null)}));t.a=Object(s.a)((function(e){var t="light"===e.palette.type,n={color:"currentColor",opacity:t?.42:.5,transition:e.transitions.create("opacity",{duration:e.transitions.duration.shorter})},r={opacity:"0 !important"},o={opacity:t?.42:.5};return{root:{fontFamily:e.typography.fontFamily,color:e.palette.text.primary,fontSize:e.typography.pxToRem(16),lineHeight:"1.1875em",boxSizing:"border-box",position:"relative",cursor:"text",display:"inline-flex",alignItems:"center","&$disabled":{color:e.palette.text.disabled,cursor:"default"}},formControl:{},focused:{},disabled:{},adornedStart:{},adornedEnd:{},error:{},marginDense:{},multiline:{padding:"".concat(6,"px 0 ").concat(7,"px"),"&$marginDense":{paddingTop:3}},colorSecondary:{},fullWidth:{width:"100%"},input:{font:"inherit",color:"currentColor",padding:"".concat(6,"px 0 ").concat(7,"px"),border:0,boxSizing:"content-box",background:"none",height:"1.1875em",margin:0,WebkitTapHighlightColor:"transparent",display:"block",minWidth:0,width:"100%",animationName:"$auto-fill-cancel","&::-webkit-input-placeholder":n,"&::-moz-placeholder":n,"&:-ms-input-placeholder":n,"&::-ms-input-placeholder":n,"&:focus":{outline:0},"&:invalid":{boxShadow:"none"},"&::-webkit-search-decoration":{"-webkit-appearance":"none"},"label[data-shrink=false] + $formControl &":{"&::-webkit-input-placeholder":r,"&::-moz-placeholder":r,"&:-ms-input-placeholder":r,"&::-ms-input-placeholder":r,"&:focus::-webkit-input-placeholder":o,"&:focus::-moz-placeholder":o,"&:focus:-ms-input-placeholder":o,"&:focus::-ms-input-placeholder":o},"&$disabled":{opacity:1},"&:-webkit-autofill":{animationDuration:"5000s",animationName:"$auto-fill"}},"@keyframes auto-fill":{from:{}},"@keyframes auto-fill-cancel":{from:{}},inputMarginDense:{paddingTop:3},inputMultiline:{height:"auto",resize:"none",padding:0},inputTypeSearch:{"-moz-appearance":"textfield","-webkit-appearance":"textfield"},inputAdornedStart:{},inputAdornedEnd:{},inputHiddenLabel:{}}}),{name:"MuiInputBase"})(x)},,,,,,,function(e,t,n){"use strict";var r=n(73),o="function"===typeof Symbol&&Symbol.for,a=o?Symbol.for("react.element"):60103,i=o?Symbol.for("react.portal"):60106,l=o?Symbol.for("react.fragment"):60107,u=o?Symbol.for("react.strict_mode"):60108,c=o?Symbol.for("react.profiler"):60114,s=o?Symbol.for("react.provider"):60109,d=o?Symbol.for("react.context"):60110,f=o?Symbol.for("react.forward_ref"):60112,p=o?Symbol.for("react.suspense"):60113;o&&Symbol.for("react.suspense_list");var h=o?Symbol.for("react.memo"):60115,m=o?Symbol.for("react.lazy"):60116;o&&Symbol.for("react.fundamental"),o&&Symbol.for("react.responder"),o&&Symbol.for("react.scope");var v="function"===typeof Symbol&&Symbol.iterator;function b(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n<arguments.length;n++)t+="&args[]="+encodeURIComponent(arguments[n]);return"Minified React error #"+e+"; visit "+t+" for the full message or use the non-minified dev environment for full errors and additional helpful warnings."}var y={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},g={};function x(e,t,n){this.props=e,this.context=t,this.refs=g,this.updater=n||y}function w(){}function k(e,t,n){this.props=e,this.context=t,this.refs=g,this.updater=n||y}x.prototype.isReactComponent={},x.prototype.setState=function(e,t){if("object"!==typeof e&&"function"!==typeof e&&null!=e)throw Error(b(85));this.updater.enqueueSetState(this,e,t,"setState")},x.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")},w.prototype=x.prototype;var E=k.prototype=new w;E.constructor=k,r(E,x.prototype),E.isPureReactComponent=!0;var O={current:null},S={current:null},C=Object.prototype.hasOwnProperty,T={key:!0,ref:!0,__self:!0,__source:!0};function j(e,t,n){var r,o={},i=null,l=null;if(null!=t)for(r in void 0!==t.ref&&(l=t.ref),void 0!==t.key&&(i=""+t.key),t)C.call(t,r)&&!T.hasOwnProperty(r)&&(o[r]=t[r]);var u=arguments.length-2;if(1===u)o.children=n;else if(1<u){for(var c=Array(u),s=0;s<u;s++)c[s]=arguments[s+2];o.children=c}if(e&&e.defaultProps)for(r in u=e.defaultProps)void 0===o[r]&&(o[r]=u[r]);return{$$typeof:a,type:e,key:i,ref:l,props:o,_owner:S.current}}function P(e){return"object"===typeof e&&null!==e&&e.$$typeof===a}var R=/\/+/g,N=[];function M(e,t,n,r){if(N.length){var o=N.pop();return o.result=e,o.keyPrefix=t,o.func=n,o.context=r,o.count=0,o}return{result:e,keyPrefix:t,func:n,context:r,count:0}}function _(e){e.result=null,e.keyPrefix=null,e.func=null,e.context=null,e.count=0,10>N.length&&N.push(e)}function A(e,t,n){return null==e?0:function e(t,n,r,o){var l=typeof t;"undefined"!==l&&"boolean"!==l||(t=null);var u=!1;if(null===t)u=!0;else switch(l){case"string":case"number":u=!0;break;case"object":switch(t.$$typeof){case a:case i:u=!0}}if(u)return r(o,t,""===n?"."+z(t,0):n),1;if(u=0,n=""===n?".":n+":",Array.isArray(t))for(var c=0;c<t.length;c++){var s=n+z(l=t[c],c);u+=e(l,s,r,o)}else if(null===t||"object"!==typeof t?s=null:s="function"===typeof(s=v&&t[v]||t["@@iterator"])?s:null,"function"===typeof s)for(t=s.call(t),c=0;!(l=t.next()).done;)u+=e(l=l.value,s=n+z(l,c++),r,o);else if("object"===l)throw r=""+t,Error(b(31,"[object Object]"===r?"object with keys {"+Object.keys(t).join(", ")+"}":r,""));return u}(e,"",t,n)}function z(e,t){return"object"===typeof e&&null!==e&&null!=e.key?function(e){var t={"=":"=0",":":"=2"};return"$"+(""+e).replace(/[=:]/g,(function(e){return t[e]}))}(e.key):t.toString(36)}function I(e,t){e.func.call(e.context,t,e.count++)}function L(e,t,n){var r=e.result,o=e.keyPrefix;e=e.func.call(e.context,t,e.count++),Array.isArray(e)?D(e,r,n,(function(e){return e})):null!=e&&(P(e)&&(e=function(e,t){return{$$typeof:a,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}(e,o+(!e.key||t&&t.key===e.key?"":(""+e.key).replace(R,"$&/")+"/")+n)),r.push(e))}function D(e,t,n,r,o){var a="";null!=n&&(a=(""+n).replace(R,"$&/")+"/"),A(e,L,t=M(t,a,r,o)),_(t)}function F(){var e=O.current;if(null===e)throw Error(b(321));return e}var U={Children:{map:function(e,t,n){if(null==e)return e;var r=[];return D(e,r,null,t,n),r},forEach:function(e,t,n){if(null==e)return e;A(e,I,t=M(null,null,t,n)),_(t)},count:function(e){return A(e,(function(){return null}),null)},toArray:function(e){var t=[];return D(e,t,null,(function(e){return e})),t},only:function(e){if(!P(e))throw Error(b(143));return e}},createRef:function(){return{current:null}},Component:x,PureComponent:k,createContext:function(e,t){return void 0===t&&(t=null),(e={$$typeof:d,_calculateChangedBits:t,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null}).Provider={$$typeof:s,_context:e},e.Consumer=e},forwardRef:function(e){return{$$typeof:f,render:e}},lazy:function(e){return{$$typeof:m,_ctor:e,_status:-1,_result:null}},memo:function(e,t){return{$$typeof:h,type:e,compare:void 0===t?null:t}},useCallback:function(e,t){return F().useCallback(e,t)},useContext:function(e,t){return F().useContext(e,t)},useEffect:function(e,t){return F().useEffect(e,t)},useImperativeHandle:function(e,t,n){return F().useImperativeHandle(e,t,n)},useDebugValue:function(){},useLayoutEffect:function(e,t){return F().useLayoutEffect(e,t)},useMemo:function(e,t){return F().useMemo(e,t)},useReducer:function(e,t,n){return F().useReducer(e,t,n)},useRef:function(e){return F().useRef(e)},useState:function(e){return F().useState(e)},Fragment:l,Profiler:c,StrictMode:u,Suspense:p,createElement:j,cloneElement:function(e,t,n){if(null===e||void 0===e)throw Error(b(267,e));var o=r({},e.props),i=e.key,l=e.ref,u=e._owner;if(null!=t){if(void 0!==t.ref&&(l=t.ref,u=S.current),void 0!==t.key&&(i=""+t.key),e.type&&e.type.defaultProps)var c=e.type.defaultProps;for(s in t)C.call(t,s)&&!T.hasOwnProperty(s)&&(o[s]=void 0===t[s]&&void 0!==c?c[s]:t[s])}var s=arguments.length-2;if(1===s)o.children=n;else if(1<s){c=Array(s);for(var d=0;d<s;d++)c[d]=arguments[d+2];o.children=c}return{$$typeof:a,type:e.type,key:i,ref:l,props:o,_owner:u}},createFactory:function(e){var t=j.bind(null,e);return t.type=e,t},isValidElement:P,version:"16.12.0",__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{ReactCurrentDispatcher:O,ReactCurrentBatchConfig:{suspense:null},ReactCurrentOwner:S,IsSomeRendererActing:{current:!1},assign:r}},$={default:U},B=$&&U||$;e.exports=B.default||B},function(e,t,n){"use strict";var r=n(0),o=n(73),a=n(104);function i(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n<arguments.length;n++)t+="&args[]="+encodeURIComponent(arguments[n]);return"Minified React error #"+e+"; visit "+t+" for the full message or use the non-minified dev environment for full errors and additional helpful warnings."}if(!r)throw Error(i(227));var l=null,u={};function c(){if(l)for(var e in u){var t=u[e],n=l.indexOf(e);if(!(-1<n))throw Error(i(96,e));if(!d[n]){if(!t.extractEvents)throw Error(i(97,e));for(var r in d[n]=t,n=t.eventTypes){var o=void 0,a=n[r],c=t,p=r;if(f.hasOwnProperty(p))throw Error(i(99,p));f[p]=a;var h=a.phasedRegistrationNames;if(h){for(o in h)h.hasOwnProperty(o)&&s(h[o],c,p);o=!0}else a.registrationName?(s(a.registrationName,c,p),o=!0):o=!1;if(!o)throw Error(i(98,r,e))}}}}function s(e,t,n){if(p[e])throw Error(i(100,e));p[e]=t,h[e]=t.eventTypes[n].dependencies}var d=[],f={},p={},h={};function m(e,t,n,r,o,a,i,l,u){var c=Array.prototype.slice.call(arguments,3);try{t.apply(n,c)}catch(s){this.onError(s)}}var v=!1,b=null,y=!1,g=null,x={onError:function(e){v=!0,b=e}};function w(e,t,n,r,o,a,i,l,u){v=!1,b=null,m.apply(x,arguments)}var k=null,E=null,O=null;function S(e,t,n){var r=e.type||"unknown-event";e.currentTarget=O(n),function(e,t,n,r,o,a,l,u,c){if(w.apply(this,arguments),v){if(!v)throw Error(i(198));var s=b;v=!1,b=null,y||(y=!0,g=s)}}(r,t,void 0,e),e.currentTarget=null}function C(e,t){if(null==t)throw Error(i(30));return null==e?t:Array.isArray(e)?Array.isArray(t)?(e.push.apply(e,t),e):(e.push(t),e):Array.isArray(t)?[e].concat(t):[e,t]}function T(e,t,n){Array.isArray(e)?e.forEach(t,n):e&&t.call(n,e)}var j=null;function P(e){if(e){var t=e._dispatchListeners,n=e._dispatchInstances;if(Array.isArray(t))for(var r=0;r<t.length&&!e.isPropagationStopped();r++)S(e,t[r],n[r]);else t&&S(e,t,n);e._dispatchListeners=null,e._dispatchInstances=null,e.isPersistent()||e.constructor.release(e)}}function R(e){if(null!==e&&(j=C(j,e)),e=j,j=null,e){if(T(e,P),j)throw Error(i(95));if(y)throw e=g,y=!1,g=null,e}}var N={injectEventPluginOrder:function(e){if(l)throw Error(i(101));l=Array.prototype.slice.call(e),c()},injectEventPluginsByName:function(e){var t,n=!1;for(t in e)if(e.hasOwnProperty(t)){var r=e[t];if(!u.hasOwnProperty(t)||u[t]!==r){if(u[t])throw Error(i(102,t));u[t]=r,n=!0}}n&&c()}};function M(e,t){var n=e.stateNode;if(!n)return null;var r=k(n);if(!r)return null;n=r[t];e:switch(t){case"onClick":case"onClickCapture":case"onDoubleClick":case"onDoubleClickCapture":case"onMouseDown":case"onMouseDownCapture":case"onMouseMove":case"onMouseMoveCapture":case"onMouseUp":case"onMouseUpCapture":(r=!r.disabled)||(r=!("button"===(e=e.type)||"input"===e||"select"===e||"textarea"===e)),e=!r;break e;default:e=!1}if(e)return null;if(n&&"function"!==typeof n)throw Error(i(231,t,typeof n));return n}var _=r.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;_.hasOwnProperty("ReactCurrentDispatcher")||(_.ReactCurrentDispatcher={current:null}),_.hasOwnProperty("ReactCurrentBatchConfig")||(_.ReactCurrentBatchConfig={suspense:null});var A=/^(.*)[\\\/]/,z="function"===typeof Symbol&&Symbol.for,I=z?Symbol.for("react.element"):60103,L=z?Symbol.for("react.portal"):60106,D=z?Symbol.for("react.fragment"):60107,F=z?Symbol.for("react.strict_mode"):60108,U=z?Symbol.for("react.profiler"):60114,$=z?Symbol.for("react.provider"):60109,B=z?Symbol.for("react.context"):60110,W=z?Symbol.for("react.concurrent_mode"):60111,V=z?Symbol.for("react.forward_ref"):60112,H=z?Symbol.for("react.suspense"):60113,q=z?Symbol.for("react.suspense_list"):60120,K=z?Symbol.for("react.memo"):60115,Q=z?Symbol.for("react.lazy"):60116;z&&Symbol.for("react.fundamental"),z&&Symbol.for("react.responder"),z&&Symbol.for("react.scope");var X="function"===typeof Symbol&&Symbol.iterator;function G(e){return null===e||"object"!==typeof e?null:"function"===typeof(e=X&&e[X]||e["@@iterator"])?e:null}function Y(e){if(null==e)return null;if("function"===typeof e)return e.displayName||e.name||null;if("string"===typeof e)return e;switch(e){case D:return"Fragment";case L:return"Portal";case U:return"Profiler";case F:return"StrictMode";case H:return"Suspense";case q:return"SuspenseList"}if("object"===typeof e)switch(e.$$typeof){case B:return"Context.Consumer";case $:return"Context.Provider";case V:var t=e.render;return t=t.displayName||t.name||"",e.displayName||(""!==t?"ForwardRef("+t+")":"ForwardRef");case K:return Y(e.type);case Q:if(e=1===e._status?e._result:null)return Y(e)}return null}function J(e){var t="";do{e:switch(e.tag){case 3:case 4:case 6:case 7:case 10:case 9:var n="";break e;default:var r=e._debugOwner,o=e._debugSource,a=Y(e.type);n=null,r&&(n=Y(r.type)),r=a,a="",o?a=" (at "+o.fileName.replace(A,"")+":"+o.lineNumber+")":n&&(a=" (created by "+n+")"),n="\n in "+(r||"Unknown")+a}t+=n,e=e.return}while(e);return t}var Z=!("undefined"===typeof window||"undefined"===typeof window.document||"undefined"===typeof window.document.createElement),ee=null,te=null,ne=null;function re(e){if(e=E(e)){if("function"!==typeof ee)throw Error(i(280));var t=k(e.stateNode);ee(e.stateNode,e.type,t)}}function oe(e){te?ne?ne.push(e):ne=[e]:te=e}function ae(){if(te){var e=te,t=ne;if(ne=te=null,re(e),t)for(e=0;e<t.length;e++)re(t[e])}}function ie(e,t){return e(t)}function le(e,t,n,r){return e(t,n,r)}function ue(){}var ce=ie,se=!1,de=!1;function fe(){null===te&&null===ne||(ue(),ae())}new Map;var pe=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,he=Object.prototype.hasOwnProperty,me={},ve={};function be(e,t,n,r,o,a){this.acceptsBooleans=2===t||3===t||4===t,this.attributeName=r,this.attributeNamespace=o,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=a}var ye={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach((function(e){ye[e]=new be(e,0,!1,e,null,!1)})),[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach((function(e){var t=e[0];ye[t]=new be(t,1,!1,e[1],null,!1)})),["contentEditable","draggable","spellCheck","value"].forEach((function(e){ye[e]=new be(e,2,!1,e.toLowerCase(),null,!1)})),["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach((function(e){ye[e]=new be(e,2,!1,e,null,!1)})),"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach((function(e){ye[e]=new be(e,3,!1,e.toLowerCase(),null,!1)})),["checked","multiple","muted","selected"].forEach((function(e){ye[e]=new be(e,3,!0,e,null,!1)})),["capture","download"].forEach((function(e){ye[e]=new be(e,4,!1,e,null,!1)})),["cols","rows","size","span"].forEach((function(e){ye[e]=new be(e,6,!1,e,null,!1)})),["rowSpan","start"].forEach((function(e){ye[e]=new be(e,5,!1,e.toLowerCase(),null,!1)}));var ge=/[\-:]([a-z])/g;function xe(e){return e[1].toUpperCase()}function we(e){switch(typeof e){case"boolean":case"number":case"object":case"string":case"undefined":return e;default:return""}}function ke(e,t,n,r){var o=ye.hasOwnProperty(t)?ye[t]:null;(null!==o?0===o.type:!r&&(2<t.length&&("o"===t[0]||"O"===t[0])&&("n"===t[1]||"N"===t[1])))||(function(e,t,n,r){if(null===t||"undefined"===typeof t||function(e,t,n,r){if(null!==n&&0===n.type)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return!r&&(null!==n?!n.acceptsBooleans:"data-"!==(e=e.toLowerCase().slice(0,5))&&"aria-"!==e);default:return!1}}(e,t,n,r))return!0;if(r)return!1;if(null!==n)switch(n.type){case 3:return!t;case 4:return!1===t;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}(t,n,o,r)&&(n=null),r||null===o?function(e){return!!he.call(ve,e)||!he.call(me,e)&&(pe.test(e)?ve[e]=!0:(me[e]=!0,!1))}(t)&&(null===n?e.removeAttribute(t):e.setAttribute(t,""+n)):o.mustUseProperty?e[o.propertyName]=null===n?3!==o.type&&"":n:(t=o.attributeName,r=o.attributeNamespace,null===n?e.removeAttribute(t):(n=3===(o=o.type)||4===o&&!0===n?"":""+n,r?e.setAttributeNS(r,t,n):e.setAttribute(t,n))))}function Ee(e){var t=e.type;return(e=e.nodeName)&&"input"===e.toLowerCase()&&("checkbox"===t||"radio"===t)}function Oe(e){e._valueTracker||(e._valueTracker=function(e){var t=Ee(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&"undefined"!==typeof n&&"function"===typeof n.get&&"function"===typeof n.set){var o=n.get,a=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return o.call(this)},set:function(e){r=""+e,a.call(this,e)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(e){r=""+e},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}(e))}function Se(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=Ee(e)?e.checked?"true":"false":e.value),(e=r)!==n&&(t.setValue(e),!0)}function Ce(e,t){var n=t.checked;return o({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=n?n:e._wrapperState.initialChecked})}function Te(e,t){var n=null==t.defaultValue?"":t.defaultValue,r=null!=t.checked?t.checked:t.defaultChecked;n=we(null!=t.value?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:"checkbox"===t.type||"radio"===t.type?null!=t.checked:null!=t.value}}function je(e,t){null!=(t=t.checked)&&ke(e,"checked",t,!1)}function Pe(e,t){je(e,t);var n=we(t.value),r=t.type;if(null!=n)"number"===r?(0===n&&""===e.value||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if("submit"===r||"reset"===r)return void e.removeAttribute("value");t.hasOwnProperty("value")?Ne(e,t.type,n):t.hasOwnProperty("defaultValue")&&Ne(e,t.type,we(t.defaultValue)),null==t.checked&&null!=t.defaultChecked&&(e.defaultChecked=!!t.defaultChecked)}function Re(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!("submit"!==r&&"reset"!==r||void 0!==t.value&&null!==t.value))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}""!==(n=e.name)&&(e.name=""),e.defaultChecked=!e.defaultChecked,e.defaultChecked=!!e._wrapperState.initialChecked,""!==n&&(e.name=n)}function Ne(e,t,n){"number"===t&&e.ownerDocument.activeElement===e||(null==n?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}function Me(e,t){return e=o({children:void 0},t),(t=function(e){var t="";return r.Children.forEach(e,(function(e){null!=e&&(t+=e)})),t}(t.children))&&(e.children=t),e}function _e(e,t,n,r){if(e=e.options,t){t={};for(var o=0;o<n.length;o++)t["$"+n[o]]=!0;for(n=0;n<e.length;n++)o=t.hasOwnProperty("$"+e[n].value),e[n].selected!==o&&(e[n].selected=o),o&&r&&(e[n].defaultSelected=!0)}else{for(n=""+we(n),t=null,o=0;o<e.length;o++){if(e[o].value===n)return e[o].selected=!0,void(r&&(e[o].defaultSelected=!0));null!==t||e[o].disabled||(t=e[o])}null!==t&&(t.selected=!0)}}function Ae(e,t){if(null!=t.dangerouslySetInnerHTML)throw Error(i(91));return o({},t,{value:void 0,defaultValue:void 0,children:""+e._wrapperState.initialValue})}function ze(e,t){var n=t.value;if(null==n){if(n=t.defaultValue,null!=(t=t.children)){if(null!=n)throw Error(i(92));if(Array.isArray(t)){if(!(1>=t.length))throw Error(i(93));t=t[0]}n=t}null==n&&(n="")}e._wrapperState={initialValue:we(n)}}function Ie(e,t){var n=we(t.value),r=we(t.defaultValue);null!=n&&((n=""+n)!==e.value&&(e.value=n),null==t.defaultValue&&e.defaultValue!==n&&(e.defaultValue=n)),null!=r&&(e.defaultValue=""+r)}function Le(e){var t=e.textContent;t===e._wrapperState.initialValue&&""!==t&&null!==t&&(e.value=t)}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach((function(e){var t=e.replace(ge,xe);ye[t]=new be(t,1,!1,e,null,!1)})),"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach((function(e){var t=e.replace(ge,xe);ye[t]=new be(t,1,!1,e,"http://www.w3.org/1999/xlink",!1)})),["xml:base","xml:lang","xml:space"].forEach((function(e){var t=e.replace(ge,xe);ye[t]=new be(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1)})),["tabIndex","crossOrigin"].forEach((function(e){ye[e]=new be(e,1,!1,e.toLowerCase(),null,!1)})),ye.xlinkHref=new be("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0),["src","href","action","formAction"].forEach((function(e){ye[e]=new be(e,1,!1,e.toLowerCase(),null,!0)}));var De="http://www.w3.org/1999/xhtml",Fe="http://www.w3.org/2000/svg";function Ue(e){switch(e){case"svg":return"http://www.w3.org/2000/svg";case"math":return"http://www.w3.org/1998/Math/MathML";default:return"http://www.w3.org/1999/xhtml"}}function $e(e,t){return null==e||"http://www.w3.org/1999/xhtml"===e?Ue(t):"http://www.w3.org/2000/svg"===e&&"foreignObject"===t?"http://www.w3.org/1999/xhtml":e}var Be,We=function(e){return"undefined"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(t,n,r,o){MSApp.execUnsafeLocalFunction((function(){return e(t,n)}))}:e}((function(e,t){if(e.namespaceURI!==Fe||"innerHTML"in e)e.innerHTML=t;else{for((Be=Be||document.createElement("div")).innerHTML="<svg>"+t.valueOf().toString()+"</svg>",t=Be.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}}));function Ve(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&3===n.nodeType)return void(n.nodeValue=t)}e.textContent=t}function He(e,t){var n={};return n[e.toLowerCase()]=t.toLowerCase(),n["Webkit"+e]="webkit"+t,n["Moz"+e]="moz"+t,n}var qe={animationend:He("Animation","AnimationEnd"),animationiteration:He("Animation","AnimationIteration"),animationstart:He("Animation","AnimationStart"),transitionend:He("Transition","TransitionEnd")},Ke={},Qe={};function Xe(e){if(Ke[e])return Ke[e];if(!qe[e])return e;var t,n=qe[e];for(t in n)if(n.hasOwnProperty(t)&&t in Qe)return Ke[e]=n[t];return e}Z&&(Qe=document.createElement("div").style,"AnimationEvent"in window||(delete qe.animationend.animation,delete qe.animationiteration.animation,delete qe.animationstart.animation),"TransitionEvent"in window||delete qe.transitionend.transition);var Ge=Xe("animationend"),Ye=Xe("animationiteration"),Je=Xe("animationstart"),Ze=Xe("transitionend"),et="abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange seeked seeking stalled suspend timeupdate volumechange waiting".split(" ");function tt(e){var t=e,n=e;if(e.alternate)for(;t.return;)t=t.return;else{e=t;do{0!==(1026&(t=e).effectTag)&&(n=t.return),e=t.return}while(e)}return 3===t.tag?n:null}function nt(e){if(13===e.tag){var t=e.memoizedState;if(null===t&&(null!==(e=e.alternate)&&(t=e.memoizedState)),null!==t)return t.dehydrated}return null}function rt(e){if(tt(e)!==e)throw Error(i(188))}function ot(e){if(!(e=function(e){var t=e.alternate;if(!t){if(null===(t=tt(e)))throw Error(i(188));return t!==e?null:e}for(var n=e,r=t;;){var o=n.return;if(null===o)break;var a=o.alternate;if(null===a){if(null!==(r=o.return)){n=r;continue}break}if(o.child===a.child){for(a=o.child;a;){if(a===n)return rt(o),e;if(a===r)return rt(o),t;a=a.sibling}throw Error(i(188))}if(n.return!==r.return)n=o,r=a;else{for(var l=!1,u=o.child;u;){if(u===n){l=!0,n=o,r=a;break}if(u===r){l=!0,r=o,n=a;break}u=u.sibling}if(!l){for(u=a.child;u;){if(u===n){l=!0,n=a,r=o;break}if(u===r){l=!0,r=a,n=o;break}u=u.sibling}if(!l)throw Error(i(189))}}if(n.alternate!==r)throw Error(i(190))}if(3!==n.tag)throw Error(i(188));return n.stateNode.current===n?e:t}(e)))return null;for(var t=e;;){if(5===t.tag||6===t.tag)return t;if(t.child)t.child.return=t,t=t.child;else{if(t===e)break;for(;!t.sibling;){if(!t.return||t.return===e)return null;t=t.return}t.sibling.return=t.return,t=t.sibling}}return null}var at,it,lt,ut=!1,ct=[],st=null,dt=null,ft=null,pt=new Map,ht=new Map,mt=[],vt="mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput close cancel copy cut paste click change contextmenu reset submit".split(" "),bt="focus blur dragenter dragleave mouseover mouseout pointerover pointerout gotpointercapture lostpointercapture".split(" ");function yt(e,t,n,r){return{blockedOn:e,topLevelType:t,eventSystemFlags:32|n,nativeEvent:r}}function gt(e,t){switch(e){case"focus":case"blur":st=null;break;case"dragenter":case"dragleave":dt=null;break;case"mouseover":case"mouseout":ft=null;break;case"pointerover":case"pointerout":pt.delete(t.pointerId);break;case"gotpointercapture":case"lostpointercapture":ht.delete(t.pointerId)}}function xt(e,t,n,r,o){return null===e||e.nativeEvent!==o?(e=yt(t,n,r,o),null!==t&&(null!==(t=cr(t))&&it(t)),e):(e.eventSystemFlags|=r,e)}function wt(e){var t=ur(e.target);if(null!==t){var n=tt(t);if(null!==n)if(13===(t=n.tag)){if(null!==(t=nt(n)))return e.blockedOn=t,void a.unstable_runWithPriority(e.priority,(function(){lt(n)}))}else if(3===t&&n.stateNode.hydrate)return void(e.blockedOn=3===n.tag?n.stateNode.containerInfo:null)}e.blockedOn=null}function kt(e){if(null!==e.blockedOn)return!1;var t=Nn(e.topLevelType,e.eventSystemFlags,e.nativeEvent);if(null!==t){var n=cr(t);return null!==n&&it(n),e.blockedOn=t,!1}return!0}function Et(e,t,n){kt(e)&&n.delete(t)}function Ot(){for(ut=!1;0<ct.length;){var e=ct[0];if(null!==e.blockedOn){null!==(e=cr(e.blockedOn))&&at(e);break}var t=Nn(e.topLevelType,e.eventSystemFlags,e.nativeEvent);null!==t?e.blockedOn=t:ct.shift()}null!==st&&kt(st)&&(st=null),null!==dt&&kt(dt)&&(dt=null),null!==ft&&kt(ft)&&(ft=null),pt.forEach(Et),ht.forEach(Et)}function St(e,t){e.blockedOn===t&&(e.blockedOn=null,ut||(ut=!0,a.unstable_scheduleCallback(a.unstable_NormalPriority,Ot)))}function Ct(e){function t(t){return St(t,e)}if(0<ct.length){St(ct[0],e);for(var n=1;n<ct.length;n++){var r=ct[n];r.blockedOn===e&&(r.blockedOn=null)}}for(null!==st&&St(st,e),null!==dt&&St(dt,e),null!==ft&&St(ft,e),pt.forEach(t),ht.forEach(t),n=0;n<mt.length;n++)(r=mt[n]).blockedOn===e&&(r.blockedOn=null);for(;0<mt.length&&null===(n=mt[0]).blockedOn;)wt(n),null===n.blockedOn&&mt.shift()}function Tt(e){return(e=e.target||e.srcElement||window).correspondingUseElement&&(e=e.correspondingUseElement),3===e.nodeType?e.parentNode:e}function jt(e){do{e=e.return}while(e&&5!==e.tag);return e||null}function Pt(e,t,n){(t=M(e,n.dispatchConfig.phasedRegistrationNames[t]))&&(n._dispatchListeners=C(n._dispatchListeners,t),n._dispatchInstances=C(n._dispatchInstances,e))}function Rt(e){if(e&&e.dispatchConfig.phasedRegistrationNames){for(var t=e._targetInst,n=[];t;)n.push(t),t=jt(t);for(t=n.length;0<t--;)Pt(n[t],"captured",e);for(t=0;t<n.length;t++)Pt(n[t],"bubbled",e)}}function Nt(e,t,n){e&&n&&n.dispatchConfig.registrationName&&(t=M(e,n.dispatchConfig.registrationName))&&(n._dispatchListeners=C(n._dispatchListeners,t),n._dispatchInstances=C(n._dispatchInstances,e))}function Mt(e){e&&e.dispatchConfig.registrationName&&Nt(e._targetInst,null,e)}function _t(e){T(e,Rt)}function At(){return!0}function zt(){return!1}function It(e,t,n,r){for(var o in this.dispatchConfig=e,this._targetInst=t,this.nativeEvent=n,e=this.constructor.Interface)e.hasOwnProperty(o)&&((t=e[o])?this[o]=t(n):"target"===o?this.target=r:this[o]=n[o]);return this.isDefaultPrevented=(null!=n.defaultPrevented?n.defaultPrevented:!1===n.returnValue)?At:zt,this.isPropagationStopped=zt,this}function Lt(e,t,n,r){if(this.eventPool.length){var o=this.eventPool.pop();return this.call(o,e,t,n,r),o}return new this(e,t,n,r)}function Dt(e){if(!(e instanceof this))throw Error(i(279));e.destructor(),10>this.eventPool.length&&this.eventPool.push(e)}function Ft(e){e.eventPool=[],e.getPooled=Lt,e.release=Dt}o(It.prototype,{preventDefault:function(){this.defaultPrevented=!0;var e=this.nativeEvent;e&&(e.preventDefault?e.preventDefault():"unknown"!==typeof e.returnValue&&(e.returnValue=!1),this.isDefaultPrevented=At)},stopPropagation:function(){var e=this.nativeEvent;e&&(e.stopPropagation?e.stopPropagation():"unknown"!==typeof e.cancelBubble&&(e.cancelBubble=!0),this.isPropagationStopped=At)},persist:function(){this.isPersistent=At},isPersistent:zt,destructor:function(){var e,t=this.constructor.Interface;for(e in t)this[e]=null;this.nativeEvent=this._targetInst=this.dispatchConfig=null,this.isPropagationStopped=this.isDefaultPrevented=zt,this._dispatchInstances=this._dispatchListeners=null}}),It.Interface={type:null,target:null,currentTarget:function(){return null},eventPhase:null,bubbles:null,cancelable:null,timeStamp:function(e){return e.timeStamp||Date.now()},defaultPrevented:null,isTrusted:null},It.extend=function(e){function t(){}function n(){return r.apply(this,arguments)}var r=this;t.prototype=r.prototype;var a=new t;return o(a,n.prototype),n.prototype=a,n.prototype.constructor=n,n.Interface=o({},r.Interface,e),n.extend=r.extend,Ft(n),n},Ft(It);var Ut=It.extend({animationName:null,elapsedTime:null,pseudoElement:null}),$t=It.extend({clipboardData:function(e){return"clipboardData"in e?e.clipboardData:window.clipboardData}}),Bt=It.extend({view:null,detail:null}),Wt=Bt.extend({relatedTarget:null});function Vt(e){var t=e.keyCode;return"charCode"in e?0===(e=e.charCode)&&13===t&&(e=13):e=t,10===e&&(e=13),32<=e||13===e?e:0}var Ht={Esc:"Escape",Spacebar:" ",Left:"ArrowLeft",Up:"ArrowUp",Right:"ArrowRight",Down:"ArrowDown",Del:"Delete",Win:"OS",Menu:"ContextMenu",Apps:"ContextMenu",Scroll:"ScrollLock",MozPrintableKey:"Unidentified"},qt={8:"Backspace",9:"Tab",12:"Clear",13:"Enter",16:"Shift",17:"Control",18:"Alt",19:"Pause",20:"CapsLock",27:"Escape",32:" ",33:"PageUp",34:"PageDown",35:"End",36:"Home",37:"ArrowLeft",38:"ArrowUp",39:"ArrowRight",40:"ArrowDown",45:"Insert",46:"Delete",112:"F1",113:"F2",114:"F3",115:"F4",116:"F5",117:"F6",118:"F7",119:"F8",120:"F9",121:"F10",122:"F11",123:"F12",144:"NumLock",145:"ScrollLock",224:"Meta"},Kt={Alt:"altKey",Control:"ctrlKey",Meta:"metaKey",Shift:"shiftKey"};function Qt(e){var t=this.nativeEvent;return t.getModifierState?t.getModifierState(e):!!(e=Kt[e])&&!!t[e]}function Xt(){return Qt}for(var Gt=Bt.extend({key:function(e){if(e.key){var t=Ht[e.key]||e.key;if("Unidentified"!==t)return t}return"keypress"===e.type?13===(e=Vt(e))?"Enter":String.fromCharCode(e):"keydown"===e.type||"keyup"===e.type?qt[e.keyCode]||"Unidentified":""},location:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,repeat:null,locale:null,getModifierState:Xt,charCode:function(e){return"keypress"===e.type?Vt(e):0},keyCode:function(e){return"keydown"===e.type||"keyup"===e.type?e.keyCode:0},which:function(e){return"keypress"===e.type?Vt(e):"keydown"===e.type||"keyup"===e.type?e.keyCode:0}}),Yt=0,Jt=0,Zt=!1,en=!1,tn=Bt.extend({screenX:null,screenY:null,clientX:null,clientY:null,pageX:null,pageY:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,getModifierState:Xt,button:null,buttons:null,relatedTarget:function(e){return e.relatedTarget||(e.fromElement===e.srcElement?e.toElement:e.fromElement)},movementX:function(e){if("movementX"in e)return e.movementX;var t=Yt;return Yt=e.screenX,Zt?"mousemove"===e.type?e.screenX-t:0:(Zt=!0,0)},movementY:function(e){if("movementY"in e)return e.movementY;var t=Jt;return Jt=e.screenY,en?"mousemove"===e.type?e.screenY-t:0:(en=!0,0)}}),nn=tn.extend({pointerId:null,width:null,height:null,pressure:null,tangentialPressure:null,tiltX:null,tiltY:null,twist:null,pointerType:null,isPrimary:null}),rn=tn.extend({dataTransfer:null}),on=Bt.extend({touches:null,targetTouches:null,changedTouches:null,altKey:null,metaKey:null,ctrlKey:null,shiftKey:null,getModifierState:Xt}),an=It.extend({propertyName:null,elapsedTime:null,pseudoElement:null}),ln=tn.extend({deltaX:function(e){return"deltaX"in e?e.deltaX:"wheelDeltaX"in e?-e.wheelDeltaX:0},deltaY:function(e){return"deltaY"in e?e.deltaY:"wheelDeltaY"in e?-e.wheelDeltaY:"wheelDelta"in e?-e.wheelDelta:0},deltaZ:null,deltaMode:null}),un=[["blur","blur",0],["cancel","cancel",0],["click","click",0],["close","close",0],["contextmenu","contextMenu",0],["copy","copy",0],["cut","cut",0],["auxclick","auxClick",0],["dblclick","doubleClick",0],["dragend","dragEnd",0],["dragstart","dragStart",0],["drop","drop",0],["focus","focus",0],["input","input",0],["invalid","invalid",0],["keydown","keyDown",0],["keypress","keyPress",0],["keyup","keyUp",0],["mousedown","mouseDown",0],["mouseup","mouseUp",0],["paste","paste",0],["pause","pause",0],["play","play",0],["pointercancel","pointerCancel",0],["pointerdown","pointerDown",0],["pointerup","pointerUp",0],["ratechange","rateChange",0],["reset","reset",0],["seeked","seeked",0],["submit","submit",0],["touchcancel","touchCancel",0],["touchend","touchEnd",0],["touchstart","touchStart",0],["volumechange","volumeChange",0],["drag","drag",1],["dragenter","dragEnter",1],["dragexit","dragExit",1],["dragleave","dragLeave",1],["dragover","dragOver",1],["mousemove","mouseMove",1],["mouseout","mouseOut",1],["mouseover","mouseOver",1],["pointermove","pointerMove",1],["pointerout","pointerOut",1],["pointerover","pointerOver",1],["scroll","scroll",1],["toggle","toggle",1],["touchmove","touchMove",1],["wheel","wheel",1],["abort","abort",2],[Ge,"animationEnd",2],[Ye,"animationIteration",2],[Je,"animationStart",2],["canplay","canPlay",2],["canplaythrough","canPlayThrough",2],["durationchange","durationChange",2],["emptied","emptied",2],["encrypted","encrypted",2],["ended","ended",2],["error","error",2],["gotpointercapture","gotPointerCapture",2],["load","load",2],["loadeddata","loadedData",2],["loadedmetadata","loadedMetadata",2],["loadstart","loadStart",2],["lostpointercapture","lostPointerCapture",2],["playing","playing",2],["progress","progress",2],["seeking","seeking",2],["stalled","stalled",2],["suspend","suspend",2],["timeupdate","timeUpdate",2],[Ze,"transitionEnd",2],["waiting","waiting",2]],cn={},sn={},dn=0;dn<un.length;dn++){var fn=un[dn],pn=fn[0],hn=fn[1],mn=fn[2],vn="on"+(hn[0].toUpperCase()+hn.slice(1)),bn={phasedRegistrationNames:{bubbled:vn,captured:vn+"Capture"},dependencies:[pn],eventPriority:mn};cn[hn]=bn,sn[pn]=bn}var yn={eventTypes:cn,getEventPriority:function(e){return void 0!==(e=sn[e])?e.eventPriority:2},extractEvents:function(e,t,n,r){var o=sn[e];if(!o)return null;switch(e){case"keypress":if(0===Vt(n))return null;case"keydown":case"keyup":e=Gt;break;case"blur":case"focus":e=Wt;break;case"click":if(2===n.button)return null;case"auxclick":case"dblclick":case"mousedown":case"mousemove":case"mouseup":case"mouseout":case"mouseover":case"contextmenu":e=tn;break;case"drag":case"dragend":case"dragenter":case"dragexit":case"dragleave":case"dragover":case"dragstart":case"drop":e=rn;break;case"touchcancel":case"touchend":case"touchmove":case"touchstart":e=on;break;case Ge:case Ye:case Je:e=Ut;break;case Ze:e=an;break;case"scroll":e=Bt;break;case"wheel":e=ln;break;case"copy":case"cut":case"paste":e=$t;break;case"gotpointercapture":case"lostpointercapture":case"pointercancel":case"pointerdown":case"pointermove":case"pointerout":case"pointerover":case"pointerup":e=nn;break;default:e=It}return _t(t=e.getPooled(o,t,n,r)),t}},gn=a.unstable_UserBlockingPriority,xn=a.unstable_runWithPriority,wn=yn.getEventPriority,kn=[];function En(e){var t=e.targetInst,n=t;do{if(!n){e.ancestors.push(n);break}var r=n;if(3===r.tag)r=r.stateNode.containerInfo;else{for(;r.return;)r=r.return;r=3!==r.tag?null:r.stateNode.containerInfo}if(!r)break;5!==(t=n.tag)&&6!==t||e.ancestors.push(n),n=ur(r)}while(n);for(n=0;n<e.ancestors.length;n++){t=e.ancestors[n];var o=Tt(e.nativeEvent);r=e.topLevelType;for(var a=e.nativeEvent,i=e.eventSystemFlags,l=null,u=0;u<d.length;u++){var c=d[u];c&&(c=c.extractEvents(r,t,a,o,i))&&(l=C(l,c))}R(l)}}var On=!0;function Sn(e,t){Cn(t,e,!1)}function Cn(e,t,n){switch(wn(t)){case 0:var r=Tn.bind(null,t,1);break;case 1:r=jn.bind(null,t,1);break;default:r=Rn.bind(null,t,1)}n?e.addEventListener(t,r,!0):e.addEventListener(t,r,!1)}function Tn(e,t,n){se||ue();var r=Rn,o=se;se=!0;try{le(r,e,t,n)}finally{(se=o)||fe()}}function jn(e,t,n){xn(gn,Rn.bind(null,e,t,n))}function Pn(e,t,n,r){if(kn.length){var o=kn.pop();o.topLevelType=e,o.eventSystemFlags=t,o.nativeEvent=n,o.targetInst=r,e=o}else e={topLevelType:e,eventSystemFlags:t,nativeEvent:n,targetInst:r,ancestors:[]};try{if(t=En,n=e,de)t(n,void 0);else{de=!0;try{ce(t,n,void 0)}finally{de=!1,fe()}}}finally{e.topLevelType=null,e.nativeEvent=null,e.targetInst=null,e.ancestors.length=0,kn.length<10&&kn.push(e)}}function Rn(e,t,n){if(On)if(0<ct.length&&-1<vt.indexOf(e))e=yt(null,e,t,n),ct.push(e);else{var r=Nn(e,t,n);null===r?gt(e,n):-1<vt.indexOf(e)?(e=yt(r,e,t,n),ct.push(e)):function(e,t,n,r){switch(t){case"focus":return st=xt(st,e,t,n,r),!0;case"dragenter":return dt=xt(dt,e,t,n,r),!0;case"mouseover":return ft=xt(ft,e,t,n,r),!0;case"pointerover":var o=r.pointerId;return pt.set(o,xt(pt.get(o)||null,e,t,n,r)),!0;case"gotpointercapture":return o=r.pointerId,ht.set(o,xt(ht.get(o)||null,e,t,n,r)),!0}return!1}(r,e,t,n)||(gt(e,n),Pn(e,t,n,null))}}function Nn(e,t,n){var r=Tt(n);if(null!==(r=ur(r))){var o=tt(r);if(null===o)r=null;else{var a=o.tag;if(13===a){if(null!==(r=nt(o)))return r;r=null}else if(3===a){if(o.stateNode.hydrate)return 3===o.tag?o.stateNode.containerInfo:null;r=null}else o!==r&&(r=null)}}return Pn(e,t,n,r),null}function Mn(e){if(!Z)return!1;var t=(e="on"+e)in document;return t||((t=document.createElement("div")).setAttribute(e,"return;"),t="function"===typeof t[e]),t}var _n=new("function"===typeof WeakMap?WeakMap:Map);function An(e){var t=_n.get(e);return void 0===t&&(t=new Set,_n.set(e,t)),t}function zn(e,t,n){if(!n.has(e)){switch(e){case"scroll":Cn(t,"scroll",!0);break;case"focus":case"blur":Cn(t,"focus",!0),Cn(t,"blur",!0),n.add("blur"),n.add("focus");break;case"cancel":case"close":Mn(e)&&Cn(t,e,!0);break;case"invalid":case"submit":case"reset":break;default:-1===et.indexOf(e)&&Sn(e,t)}n.add(e)}}var In={animationIterationCount:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},Ln=["Webkit","ms","Moz","O"];function Dn(e,t,n){return null==t||"boolean"===typeof t||""===t?"":n||"number"!==typeof t||0===t||In.hasOwnProperty(e)&&In[e]?(""+t).trim():t+"px"}function Fn(e,t){for(var n in e=e.style,t)if(t.hasOwnProperty(n)){var r=0===n.indexOf("--"),o=Dn(n,t[n],r);"float"===n&&(n="cssFloat"),r?e.setProperty(n,o):e[n]=o}}Object.keys(In).forEach((function(e){Ln.forEach((function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),In[t]=In[e]}))}));var Un=o({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function $n(e,t){if(t){if(Un[e]&&(null!=t.children||null!=t.dangerouslySetInnerHTML))throw Error(i(137,e,""));if(null!=t.dangerouslySetInnerHTML){if(null!=t.children)throw Error(i(60));if(!("object"===typeof t.dangerouslySetInnerHTML&&"__html"in t.dangerouslySetInnerHTML))throw Error(i(61))}if(null!=t.style&&"object"!==typeof t.style)throw Error(i(62,""))}}function Bn(e,t){if(-1===e.indexOf("-"))return"string"===typeof t.is;switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}function Wn(e,t){var n=An(e=9===e.nodeType||11===e.nodeType?e:e.ownerDocument);t=h[t];for(var r=0;r<t.length;r++)zn(t[r],e,n)}function Vn(){}function Hn(e){if("undefined"===typeof(e=e||("undefined"!==typeof document?document:void 0)))return null;try{return e.activeElement||e.body}catch(t){return e.body}}function qn(e){for(;e&&e.firstChild;)e=e.firstChild;return e}function Kn(e,t){var n,r=qn(e);for(e=0;r;){if(3===r.nodeType){if(n=e+r.textContent.length,e<=t&&n>=t)return{node:r,offset:t-e};e=n}e:{for(;r;){if(r.nextSibling){r=r.nextSibling;break e}r=r.parentNode}r=void 0}r=qn(r)}}function Qn(){for(var e=window,t=Hn();t instanceof e.HTMLIFrameElement;){try{var n="string"===typeof t.contentWindow.location.href}catch(r){n=!1}if(!n)break;t=Hn((e=t.contentWindow).document)}return t}function Xn(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&("input"===t&&("text"===e.type||"search"===e.type||"tel"===e.type||"url"===e.type||"password"===e.type)||"textarea"===t||"true"===e.contentEditable)}var Gn=null,Yn=null;function Jn(e,t){switch(e){case"button":case"input":case"select":case"textarea":return!!t.autoFocus}return!1}function Zn(e,t){return"textarea"===e||"option"===e||"noscript"===e||"string"===typeof t.children||"number"===typeof t.children||"object"===typeof t.dangerouslySetInnerHTML&&null!==t.dangerouslySetInnerHTML&&null!=t.dangerouslySetInnerHTML.__html}var er="function"===typeof setTimeout?setTimeout:void 0,tr="function"===typeof clearTimeout?clearTimeout:void 0;function nr(e){for(;null!=e;e=e.nextSibling){var t=e.nodeType;if(1===t||3===t)break}return e}function rr(e){e=e.previousSibling;for(var t=0;e;){if(8===e.nodeType){var n=e.data;if("$"===n||"$!"===n||"$?"===n){if(0===t)return e;t--}else"/$"===n&&t++}e=e.previousSibling}return null}var or=Math.random().toString(36).slice(2),ar="__reactInternalInstance$"+or,ir="__reactEventHandlers$"+or,lr="__reactContainere$"+or;function ur(e){var t=e[ar];if(t)return t;for(var n=e.parentNode;n;){if(t=n[lr]||n[ar]){if(n=t.alternate,null!==t.child||null!==n&&null!==n.child)for(e=rr(e);null!==e;){if(n=e[ar])return n;e=rr(e)}return t}n=(e=n).parentNode}return null}function cr(e){return!(e=e[ar]||e[lr])||5!==e.tag&&6!==e.tag&&13!==e.tag&&3!==e.tag?null:e}function sr(e){if(5===e.tag||6===e.tag)return e.stateNode;throw Error(i(33))}function dr(e){return e[ir]||null}var fr=null,pr=null,hr=null;function mr(){if(hr)return hr;var e,t,n=pr,r=n.length,o="value"in fr?fr.value:fr.textContent,a=o.length;for(e=0;e<r&&n[e]===o[e];e++);var i=r-e;for(t=1;t<=i&&n[r-t]===o[a-t];t++);return hr=o.slice(e,1<t?1-t:void 0)}var vr=It.extend({data:null}),br=It.extend({data:null}),yr=[9,13,27,32],gr=Z&&"CompositionEvent"in window,xr=null;Z&&"documentMode"in document&&(xr=document.documentMode);var wr=Z&&"TextEvent"in window&&!xr,kr=Z&&(!gr||xr&&8<xr&&11>=xr),Er=String.fromCharCode(32),Or={beforeInput:{phasedRegistrationNames:{bubbled:"onBeforeInput",captured:"onBeforeInputCapture"},dependencies:["compositionend","keypress","textInput","paste"]},compositionEnd:{phasedRegistrationNames:{bubbled:"onCompositionEnd",captured:"onCompositionEndCapture"},dependencies:"blur compositionend keydown keypress keyup mousedown".split(" ")},compositionStart:{phasedRegistrationNames:{bubbled:"onCompositionStart",captured:"onCompositionStartCapture"},dependencies:"blur compositionstart keydown keypress keyup mousedown".split(" ")},compositionUpdate:{phasedRegistrationNames:{bubbled:"onCompositionUpdate",captured:"onCompositionUpdateCapture"},dependencies:"blur compositionupdate keydown keypress keyup mousedown".split(" ")}},Sr=!1;function Cr(e,t){switch(e){case"keyup":return-1!==yr.indexOf(t.keyCode);case"keydown":return 229!==t.keyCode;case"keypress":case"mousedown":case"blur":return!0;default:return!1}}function Tr(e){return"object"===typeof(e=e.detail)&&"data"in e?e.data:null}var jr=!1;var Pr={eventTypes:Or,extractEvents:function(e,t,n,r){var o;if(gr)e:{switch(e){case"compositionstart":var a=Or.compositionStart;break e;case"compositionend":a=Or.compositionEnd;break e;case"compositionupdate":a=Or.compositionUpdate;break e}a=void 0}else jr?Cr(e,n)&&(a=Or.compositionEnd):"keydown"===e&&229===n.keyCode&&(a=Or.compositionStart);return a?(kr&&"ko"!==n.locale&&(jr||a!==Or.compositionStart?a===Or.compositionEnd&&jr&&(o=mr()):(pr="value"in(fr=r)?fr.value:fr.textContent,jr=!0)),a=vr.getPooled(a,t,n,r),o?a.data=o:null!==(o=Tr(n))&&(a.data=o),_t(a),o=a):o=null,(e=wr?function(e,t){switch(e){case"compositionend":return Tr(t);case"keypress":return 32!==t.which?null:(Sr=!0,Er);case"textInput":return(e=t.data)===Er&&Sr?null:e;default:return null}}(e,n):function(e,t){if(jr)return"compositionend"===e||!gr&&Cr(e,t)?(e=mr(),hr=pr=fr=null,jr=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1<t.char.length)return t.char;if(t.which)return String.fromCharCode(t.which)}return null;case"compositionend":return kr&&"ko"!==t.locale?null:t.data;default:return null}}(e,n))?((t=br.getPooled(Or.beforeInput,t,n,r)).data=e,_t(t)):t=null,null===o?t:null===t?o:[o,t]}},Rr={color:!0,date:!0,datetime:!0,"datetime-local":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function Nr(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return"input"===t?!!Rr[e.type]:"textarea"===t}var Mr={change:{phasedRegistrationNames:{bubbled:"onChange",captured:"onChangeCapture"},dependencies:"blur change click focus input keydown keyup selectionchange".split(" ")}};function _r(e,t,n){return(e=It.getPooled(Mr.change,e,t,n)).type="change",oe(n),_t(e),e}var Ar=null,zr=null;function Ir(e){R(e)}function Lr(e){if(Se(sr(e)))return e}function Dr(e,t){if("change"===e)return t}var Fr=!1;function Ur(){Ar&&(Ar.detachEvent("onpropertychange",$r),zr=Ar=null)}function $r(e){if("value"===e.propertyName&&Lr(zr))if(e=_r(zr,e,Tt(e)),se)R(e);else{se=!0;try{ie(Ir,e)}finally{se=!1,fe()}}}function Br(e,t,n){"focus"===e?(Ur(),zr=n,(Ar=t).attachEvent("onpropertychange",$r)):"blur"===e&&Ur()}function Wr(e){if("selectionchange"===e||"keyup"===e||"keydown"===e)return Lr(zr)}function Vr(e,t){if("click"===e)return Lr(t)}function Hr(e,t){if("input"===e||"change"===e)return Lr(t)}Z&&(Fr=Mn("input")&&(!document.documentMode||9<document.documentMode));var qr,Kr={eventTypes:Mr,_isInputEventSupported:Fr,extractEvents:function(e,t,n,r){var o=t?sr(t):window,a=o.nodeName&&o.nodeName.toLowerCase();if("select"===a||"input"===a&&"file"===o.type)var i=Dr;else if(Nr(o))if(Fr)i=Hr;else{i=Wr;var l=Br}else(a=o.nodeName)&&"input"===a.toLowerCase()&&("checkbox"===o.type||"radio"===o.type)&&(i=Vr);if(i&&(i=i(e,t)))return _r(i,n,r);l&&l(e,o,t),"blur"===e&&(e=o._wrapperState)&&e.controlled&&"number"===o.type&&Ne(o,"number",o.value)}},Qr={mouseEnter:{registrationName:"onMouseEnter",dependencies:["mouseout","mouseover"]},mouseLeave:{registrationName:"onMouseLeave",dependencies:["mouseout","mouseover"]},pointerEnter:{registrationName:"onPointerEnter",dependencies:["pointerout","pointerover"]},pointerLeave:{registrationName:"onPointerLeave",dependencies:["pointerout","pointerover"]}},Xr={eventTypes:Qr,extractEvents:function(e,t,n,r,o){var a="mouseover"===e||"pointerover"===e,i="mouseout"===e||"pointerout"===e;if(a&&0===(32&o)&&(n.relatedTarget||n.fromElement)||!i&&!a)return null;if(o=r.window===r?r:(o=r.ownerDocument)?o.defaultView||o.parentWindow:window,i?(i=t,null!==(t=(t=n.relatedTarget||n.toElement)?ur(t):null)&&(t!==(a=tt(t))||5!==t.tag&&6!==t.tag)&&(t=null)):i=null,i===t)return null;if("mouseout"===e||"mouseover"===e)var l=tn,u=Qr.mouseLeave,c=Qr.mouseEnter,s="mouse";else"pointerout"!==e&&"pointerover"!==e||(l=nn,u=Qr.pointerLeave,c=Qr.pointerEnter,s="pointer");if(e=null==i?o:sr(i),o=null==t?o:sr(t),(u=l.getPooled(u,i,n,r)).type=s+"leave",u.target=e,u.relatedTarget=o,(r=l.getPooled(c,t,n,r)).type=s+"enter",r.target=o,r.relatedTarget=e,s=t,(l=i)&&s)e:{for(e=s,i=0,t=c=l;t;t=jt(t))i++;for(t=0,o=e;o;o=jt(o))t++;for(;0<i-t;)c=jt(c),i--;for(;0<t-i;)e=jt(e),t--;for(;i--;){if(c===e||c===e.alternate)break e;c=jt(c),e=jt(e)}c=null}else c=null;for(e=c,c=[];l&&l!==e&&(null===(i=l.alternate)||i!==e);)c.push(l),l=jt(l);for(l=[];s&&s!==e&&(null===(i=s.alternate)||i!==e);)l.push(s),s=jt(s);for(s=0;s<c.length;s++)Nt(c[s],"bubbled",u);for(s=l.length;0<s--;)Nt(l[s],"captured",r);return n===qr?(qr=null,[u]):(qr=n,[u,r])}};var Gr="function"===typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e===1/t)||e!==e&&t!==t},Yr=Object.prototype.hasOwnProperty;function Jr(e,t){if(Gr(e,t))return!0;if("object"!==typeof e||null===e||"object"!==typeof t||null===t)return!1;var n=Object.keys(e),r=Object.keys(t);if(n.length!==r.length)return!1;for(r=0;r<n.length;r++)if(!Yr.call(t,n[r])||!Gr(e[n[r]],t[n[r]]))return!1;return!0}var Zr=Z&&"documentMode"in document&&11>=document.documentMode,eo={select:{phasedRegistrationNames:{bubbled:"onSelect",captured:"onSelectCapture"},dependencies:"blur contextmenu dragend focus keydown keyup mousedown mouseup selectionchange".split(" ")}},to=null,no=null,ro=null,oo=!1;function ao(e,t){var n=t.window===t?t.document:9===t.nodeType?t:t.ownerDocument;return oo||null==to||to!==Hn(n)?null:("selectionStart"in(n=to)&&Xn(n)?n={start:n.selectionStart,end:n.selectionEnd}:n={anchorNode:(n=(n.ownerDocument&&n.ownerDocument.defaultView||window).getSelection()).anchorNode,anchorOffset:n.anchorOffset,focusNode:n.focusNode,focusOffset:n.focusOffset},ro&&Jr(ro,n)?null:(ro=n,(e=It.getPooled(eo.select,no,e,t)).type="select",e.target=to,_t(e),e))}var io={eventTypes:eo,extractEvents:function(e,t,n,r){var o,a=r.window===r?r.document:9===r.nodeType?r:r.ownerDocument;if(!(o=!a)){e:{a=An(a),o=h.onSelect;for(var i=0;i<o.length;i++)if(!a.has(o[i])){a=!1;break e}a=!0}o=!a}if(o)return null;switch(a=t?sr(t):window,e){case"focus":(Nr(a)||"true"===a.contentEditable)&&(to=a,no=t,ro=null);break;case"blur":ro=no=to=null;break;case"mousedown":oo=!0;break;case"contextmenu":case"mouseup":case"dragend":return oo=!1,ao(n,r);case"selectionchange":if(Zr)break;case"keydown":case"keyup":return ao(n,r)}return null}};N.injectEventPluginOrder("ResponderEventPlugin SimpleEventPlugin EnterLeaveEventPlugin ChangeEventPlugin SelectEventPlugin BeforeInputEventPlugin".split(" ")),k=dr,E=cr,O=sr,N.injectEventPluginsByName({SimpleEventPlugin:yn,EnterLeaveEventPlugin:Xr,ChangeEventPlugin:Kr,SelectEventPlugin:io,BeforeInputEventPlugin:Pr}),new Set;var lo=[],uo=-1;function co(e){0>uo||(e.current=lo[uo],lo[uo]=null,uo--)}function so(e,t){uo++,lo[uo]=e.current,e.current=t}var fo={},po={current:fo},ho={current:!1},mo=fo;function vo(e,t){var n=e.type.contextTypes;if(!n)return fo;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var o,a={};for(o in n)a[o]=t[o];return r&&((e=e.stateNode).__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=a),a}function bo(e){return null!==(e=e.childContextTypes)&&void 0!==e}function yo(e){co(ho),co(po)}function go(e){co(ho),co(po)}function xo(e,t,n){if(po.current!==fo)throw Error(i(168));so(po,t),so(ho,n)}function wo(e,t,n){var r=e.stateNode;if(e=t.childContextTypes,"function"!==typeof r.getChildContext)return n;for(var a in r=r.getChildContext())if(!(a in e))throw Error(i(108,Y(t)||"Unknown",a));return o({},n,{},r)}function ko(e){var t=e.stateNode;return t=t&&t.__reactInternalMemoizedMergedChildContext||fo,mo=po.current,so(po,t),so(ho,ho.current),!0}function Eo(e,t,n){var r=e.stateNode;if(!r)throw Error(i(169));n?(t=wo(e,t,mo),r.__reactInternalMemoizedMergedChildContext=t,co(ho),co(po),so(po,t)):co(ho),so(ho,n)}var Oo=a.unstable_runWithPriority,So=a.unstable_scheduleCallback,Co=a.unstable_cancelCallback,To=a.unstable_shouldYield,jo=a.unstable_requestPaint,Po=a.unstable_now,Ro=a.unstable_getCurrentPriorityLevel,No=a.unstable_ImmediatePriority,Mo=a.unstable_UserBlockingPriority,_o=a.unstable_NormalPriority,Ao=a.unstable_LowPriority,zo=a.unstable_IdlePriority,Io={},Lo=void 0!==jo?jo:function(){},Do=null,Fo=null,Uo=!1,$o=Po(),Bo=1e4>$o?Po:function(){return Po()-$o};function Wo(){switch(Ro()){case No:return 99;case Mo:return 98;case _o:return 97;case Ao:return 96;case zo:return 95;default:throw Error(i(332))}}function Vo(e){switch(e){case 99:return No;case 98:return Mo;case 97:return _o;case 96:return Ao;case 95:return zo;default:throw Error(i(332))}}function Ho(e,t){return e=Vo(e),Oo(e,t)}function qo(e,t,n){return e=Vo(e),So(e,t,n)}function Ko(e){return null===Do?(Do=[e],Fo=So(No,Xo)):Do.push(e),Io}function Qo(){if(null!==Fo){var e=Fo;Fo=null,Co(e)}Xo()}function Xo(){if(!Uo&&null!==Do){Uo=!0;var e=0;try{var t=Do;Ho(99,(function(){for(;e<t.length;e++){var n=t[e];do{n=n(!0)}while(null!==n)}})),Do=null}catch(n){throw null!==Do&&(Do=Do.slice(e+1)),So(No,Qo),n}finally{Uo=!1}}}var Go=3;function Yo(e,t,n){return 1073741821-(1+((1073741821-e+t/10)/(n/=10)|0))*n}function Jo(e,t){if(e&&e.defaultProps)for(var n in t=o({},t),e=e.defaultProps)void 0===t[n]&&(t[n]=e[n]);return t}var Zo={current:null},ea=null,ta=null,na=null;function ra(){na=ta=ea=null}function oa(e,t){var n=e.type._context;so(Zo,n._currentValue),n._currentValue=t}function aa(e){var t=Zo.current;co(Zo),e.type._context._currentValue=t}function ia(e,t){for(;null!==e;){var n=e.alternate;if(e.childExpirationTime<t)e.childExpirationTime=t,null!==n&&n.childExpirationTime<t&&(n.childExpirationTime=t);else{if(!(null!==n&&n.childExpirationTime<t))break;n.childExpirationTime=t}e=e.return}}function la(e,t){ea=e,na=ta=null,null!==(e=e.dependencies)&&null!==e.firstContext&&(e.expirationTime>=t&&($i=!0),e.firstContext=null)}function ua(e,t){if(na!==e&&!1!==t&&0!==t)if("number"===typeof t&&1073741823!==t||(na=e,t=1073741823),t={context:e,observedBits:t,next:null},null===ta){if(null===ea)throw Error(i(308));ta=t,ea.dependencies={expirationTime:0,firstContext:t,responders:null}}else ta=ta.next=t;return e._currentValue}var ca=!1;function sa(e){return{baseState:e,firstUpdate:null,lastUpdate:null,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}function da(e){return{baseState:e.baseState,firstUpdate:e.firstUpdate,lastUpdate:e.lastUpdate,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}function fa(e,t){return{expirationTime:e,suspenseConfig:t,tag:0,payload:null,callback:null,next:null,nextEffect:null}}function pa(e,t){null===e.lastUpdate?e.firstUpdate=e.lastUpdate=t:(e.lastUpdate.next=t,e.lastUpdate=t)}function ha(e,t){var n=e.alternate;if(null===n){var r=e.updateQueue,o=null;null===r&&(r=e.updateQueue=sa(e.memoizedState))}else r=e.updateQueue,o=n.updateQueue,null===r?null===o?(r=e.updateQueue=sa(e.memoizedState),o=n.updateQueue=sa(n.memoizedState)):r=e.updateQueue=da(o):null===o&&(o=n.updateQueue=da(r));null===o||r===o?pa(r,t):null===r.lastUpdate||null===o.lastUpdate?(pa(r,t),pa(o,t)):(pa(r,t),o.lastUpdate=t)}function ma(e,t){var n=e.updateQueue;null===(n=null===n?e.updateQueue=sa(e.memoizedState):va(e,n)).lastCapturedUpdate?n.firstCapturedUpdate=n.lastCapturedUpdate=t:(n.lastCapturedUpdate.next=t,n.lastCapturedUpdate=t)}function va(e,t){var n=e.alternate;return null!==n&&t===n.updateQueue&&(t=e.updateQueue=da(t)),t}function ba(e,t,n,r,a,i){switch(n.tag){case 1:return"function"===typeof(e=n.payload)?e.call(i,r,a):e;case 3:e.effectTag=-4097&e.effectTag|64;case 0:if(null===(a="function"===typeof(e=n.payload)?e.call(i,r,a):e)||void 0===a)break;return o({},r,a);case 2:ca=!0}return r}function ya(e,t,n,r,o){ca=!1;for(var a=(t=va(e,t)).baseState,i=null,l=0,u=t.firstUpdate,c=a;null!==u;){var s=u.expirationTime;s<o?(null===i&&(i=u,a=c),l<s&&(l=s)):(du(s,u.suspenseConfig),c=ba(e,0,u,c,n,r),null!==u.callback&&(e.effectTag|=32,u.nextEffect=null,null===t.lastEffect?t.firstEffect=t.lastEffect=u:(t.lastEffect.nextEffect=u,t.lastEffect=u))),u=u.next}for(s=null,u=t.firstCapturedUpdate;null!==u;){var d=u.expirationTime;d<o?(null===s&&(s=u,null===i&&(a=c)),l<d&&(l=d)):(c=ba(e,0,u,c,n,r),null!==u.callback&&(e.effectTag|=32,u.nextEffect=null,null===t.lastCapturedEffect?t.firstCapturedEffect=t.lastCapturedEffect=u:(t.lastCapturedEffect.nextEffect=u,t.lastCapturedEffect=u))),u=u.next}null===i&&(t.lastUpdate=null),null===s?t.lastCapturedUpdate=null:e.effectTag|=32,null===i&&null===s&&(a=c),t.baseState=a,t.firstUpdate=i,t.firstCapturedUpdate=s,fu(l),e.expirationTime=l,e.memoizedState=c}function ga(e,t,n){null!==t.firstCapturedUpdate&&(null!==t.lastUpdate&&(t.lastUpdate.next=t.firstCapturedUpdate,t.lastUpdate=t.lastCapturedUpdate),t.firstCapturedUpdate=t.lastCapturedUpdate=null),xa(t.firstEffect,n),t.firstEffect=t.lastEffect=null,xa(t.firstCapturedEffect,n),t.firstCapturedEffect=t.lastCapturedEffect=null}function xa(e,t){for(;null!==e;){var n=e.callback;if(null!==n){e.callback=null;var r=t;if("function"!==typeof n)throw Error(i(191,n));n.call(r)}e=e.nextEffect}}var wa=_.ReactCurrentBatchConfig,ka=(new r.Component).refs;function Ea(e,t,n,r){n=null===(n=n(r,t=e.memoizedState))||void 0===n?t:o({},t,n),e.memoizedState=n,null!==(r=e.updateQueue)&&0===e.expirationTime&&(r.baseState=n)}var Oa={isMounted:function(e){return!!(e=e._reactInternalFiber)&&tt(e)===e},enqueueSetState:function(e,t,n){e=e._reactInternalFiber;var r=Jl(),o=wa.suspense;(o=fa(r=Zl(r,e,o),o)).payload=t,void 0!==n&&null!==n&&(o.callback=n),ha(e,o),eu(e,r)},enqueueReplaceState:function(e,t,n){e=e._reactInternalFiber;var r=Jl(),o=wa.suspense;(o=fa(r=Zl(r,e,o),o)).tag=1,o.payload=t,void 0!==n&&null!==n&&(o.callback=n),ha(e,o),eu(e,r)},enqueueForceUpdate:function(e,t){e=e._reactInternalFiber;var n=Jl(),r=wa.suspense;(r=fa(n=Zl(n,e,r),r)).tag=2,void 0!==t&&null!==t&&(r.callback=t),ha(e,r),eu(e,n)}};function Sa(e,t,n,r,o,a,i){return"function"===typeof(e=e.stateNode).shouldComponentUpdate?e.shouldComponentUpdate(r,a,i):!t.prototype||!t.prototype.isPureReactComponent||(!Jr(n,r)||!Jr(o,a))}function Ca(e,t,n){var r=!1,o=fo,a=t.contextType;return"object"===typeof a&&null!==a?a=ua(a):(o=bo(t)?mo:po.current,a=(r=null!==(r=t.contextTypes)&&void 0!==r)?vo(e,o):fo),t=new t(n,a),e.memoizedState=null!==t.state&&void 0!==t.state?t.state:null,t.updater=Oa,e.stateNode=t,t._reactInternalFiber=e,r&&((e=e.stateNode).__reactInternalMemoizedUnmaskedChildContext=o,e.__reactInternalMemoizedMaskedChildContext=a),t}function Ta(e,t,n,r){e=t.state,"function"===typeof t.componentWillReceiveProps&&t.componentWillReceiveProps(n,r),"function"===typeof t.UNSAFE_componentWillReceiveProps&&t.UNSAFE_componentWillReceiveProps(n,r),t.state!==e&&Oa.enqueueReplaceState(t,t.state,null)}function ja(e,t,n,r){var o=e.stateNode;o.props=n,o.state=e.memoizedState,o.refs=ka;var a=t.contextType;"object"===typeof a&&null!==a?o.context=ua(a):(a=bo(t)?mo:po.current,o.context=vo(e,a)),null!==(a=e.updateQueue)&&(ya(e,a,n,o,r),o.state=e.memoizedState),"function"===typeof(a=t.getDerivedStateFromProps)&&(Ea(e,t,a,n),o.state=e.memoizedState),"function"===typeof t.getDerivedStateFromProps||"function"===typeof o.getSnapshotBeforeUpdate||"function"!==typeof o.UNSAFE_componentWillMount&&"function"!==typeof o.componentWillMount||(t=o.state,"function"===typeof o.componentWillMount&&o.componentWillMount(),"function"===typeof o.UNSAFE_componentWillMount&&o.UNSAFE_componentWillMount(),t!==o.state&&Oa.enqueueReplaceState(o,o.state,null),null!==(a=e.updateQueue)&&(ya(e,a,n,o,r),o.state=e.memoizedState)),"function"===typeof o.componentDidMount&&(e.effectTag|=4)}var Pa=Array.isArray;function Ra(e,t,n){if(null!==(e=n.ref)&&"function"!==typeof e&&"object"!==typeof e){if(n._owner){if(n=n._owner){if(1!==n.tag)throw Error(i(309));var r=n.stateNode}if(!r)throw Error(i(147,e));var o=""+e;return null!==t&&null!==t.ref&&"function"===typeof t.ref&&t.ref._stringRef===o?t.ref:((t=function(e){var t=r.refs;t===ka&&(t=r.refs={}),null===e?delete t[o]:t[o]=e})._stringRef=o,t)}if("string"!==typeof e)throw Error(i(284));if(!n._owner)throw Error(i(290,e))}return e}function Na(e,t){if("textarea"!==e.type)throw Error(i(31,"[object Object]"===Object.prototype.toString.call(t)?"object with keys {"+Object.keys(t).join(", ")+"}":t,""))}function Ma(e){function t(t,n){if(e){var r=t.lastEffect;null!==r?(r.nextEffect=n,t.lastEffect=n):t.firstEffect=t.lastEffect=n,n.nextEffect=null,n.effectTag=8}}function n(n,r){if(!e)return null;for(;null!==r;)t(n,r),r=r.sibling;return null}function r(e,t){for(e=new Map;null!==t;)null!==t.key?e.set(t.key,t):e.set(t.index,t),t=t.sibling;return e}function o(e,t,n){return(e=Mu(e,t)).index=0,e.sibling=null,e}function a(t,n,r){return t.index=r,e?null!==(r=t.alternate)?(r=r.index)<n?(t.effectTag=2,n):r:(t.effectTag=2,n):n}function l(t){return e&&null===t.alternate&&(t.effectTag=2),t}function u(e,t,n,r){return null===t||6!==t.tag?((t=zu(n,e.mode,r)).return=e,t):((t=o(t,n)).return=e,t)}function c(e,t,n,r){return null!==t&&t.elementType===n.type?((r=o(t,n.props)).ref=Ra(e,t,n),r.return=e,r):((r=_u(n.type,n.key,n.props,null,e.mode,r)).ref=Ra(e,t,n),r.return=e,r)}function s(e,t,n,r){return null===t||4!==t.tag||t.stateNode.containerInfo!==n.containerInfo||t.stateNode.implementation!==n.implementation?((t=Iu(n,e.mode,r)).return=e,t):((t=o(t,n.children||[])).return=e,t)}function d(e,t,n,r,a){return null===t||7!==t.tag?((t=Au(n,e.mode,r,a)).return=e,t):((t=o(t,n)).return=e,t)}function f(e,t,n){if("string"===typeof t||"number"===typeof t)return(t=zu(""+t,e.mode,n)).return=e,t;if("object"===typeof t&&null!==t){switch(t.$$typeof){case I:return(n=_u(t.type,t.key,t.props,null,e.mode,n)).ref=Ra(e,null,t),n.return=e,n;case L:return(t=Iu(t,e.mode,n)).return=e,t}if(Pa(t)||G(t))return(t=Au(t,e.mode,n,null)).return=e,t;Na(e,t)}return null}function p(e,t,n,r){var o=null!==t?t.key:null;if("string"===typeof n||"number"===typeof n)return null!==o?null:u(e,t,""+n,r);if("object"===typeof n&&null!==n){switch(n.$$typeof){case I:return n.key===o?n.type===D?d(e,t,n.props.children,r,o):c(e,t,n,r):null;case L:return n.key===o?s(e,t,n,r):null}if(Pa(n)||G(n))return null!==o?null:d(e,t,n,r,null);Na(e,n)}return null}function h(e,t,n,r,o){if("string"===typeof r||"number"===typeof r)return u(t,e=e.get(n)||null,""+r,o);if("object"===typeof r&&null!==r){switch(r.$$typeof){case I:return e=e.get(null===r.key?n:r.key)||null,r.type===D?d(t,e,r.props.children,o,r.key):c(t,e,r,o);case L:return s(t,e=e.get(null===r.key?n:r.key)||null,r,o)}if(Pa(r)||G(r))return d(t,e=e.get(n)||null,r,o,null);Na(t,r)}return null}function m(o,i,l,u){for(var c=null,s=null,d=i,m=i=0,v=null;null!==d&&m<l.length;m++){d.index>m?(v=d,d=null):v=d.sibling;var b=p(o,d,l[m],u);if(null===b){null===d&&(d=v);break}e&&d&&null===b.alternate&&t(o,d),i=a(b,i,m),null===s?c=b:s.sibling=b,s=b,d=v}if(m===l.length)return n(o,d),c;if(null===d){for(;m<l.length;m++)null!==(d=f(o,l[m],u))&&(i=a(d,i,m),null===s?c=d:s.sibling=d,s=d);return c}for(d=r(o,d);m<l.length;m++)null!==(v=h(d,o,m,l[m],u))&&(e&&null!==v.alternate&&d.delete(null===v.key?m:v.key),i=a(v,i,m),null===s?c=v:s.sibling=v,s=v);return e&&d.forEach((function(e){return t(o,e)})),c}function v(o,l,u,c){var s=G(u);if("function"!==typeof s)throw Error(i(150));if(null==(u=s.call(u)))throw Error(i(151));for(var d=s=null,m=l,v=l=0,b=null,y=u.next();null!==m&&!y.done;v++,y=u.next()){m.index>v?(b=m,m=null):b=m.sibling;var g=p(o,m,y.value,c);if(null===g){null===m&&(m=b);break}e&&m&&null===g.alternate&&t(o,m),l=a(g,l,v),null===d?s=g:d.sibling=g,d=g,m=b}if(y.done)return n(o,m),s;if(null===m){for(;!y.done;v++,y=u.next())null!==(y=f(o,y.value,c))&&(l=a(y,l,v),null===d?s=y:d.sibling=y,d=y);return s}for(m=r(o,m);!y.done;v++,y=u.next())null!==(y=h(m,o,v,y.value,c))&&(e&&null!==y.alternate&&m.delete(null===y.key?v:y.key),l=a(y,l,v),null===d?s=y:d.sibling=y,d=y);return e&&m.forEach((function(e){return t(o,e)})),s}return function(e,r,a,u){var c="object"===typeof a&&null!==a&&a.type===D&&null===a.key;c&&(a=a.props.children);var s="object"===typeof a&&null!==a;if(s)switch(a.$$typeof){case I:e:{for(s=a.key,c=r;null!==c;){if(c.key===s){if(7===c.tag?a.type===D:c.elementType===a.type){n(e,c.sibling),(r=o(c,a.type===D?a.props.children:a.props)).ref=Ra(e,c,a),r.return=e,e=r;break e}n(e,c);break}t(e,c),c=c.sibling}a.type===D?((r=Au(a.props.children,e.mode,u,a.key)).return=e,e=r):((u=_u(a.type,a.key,a.props,null,e.mode,u)).ref=Ra(e,r,a),u.return=e,e=u)}return l(e);case L:e:{for(c=a.key;null!==r;){if(r.key===c){if(4===r.tag&&r.stateNode.containerInfo===a.containerInfo&&r.stateNode.implementation===a.implementation){n(e,r.sibling),(r=o(r,a.children||[])).return=e,e=r;break e}n(e,r);break}t(e,r),r=r.sibling}(r=Iu(a,e.mode,u)).return=e,e=r}return l(e)}if("string"===typeof a||"number"===typeof a)return a=""+a,null!==r&&6===r.tag?(n(e,r.sibling),(r=o(r,a)).return=e,e=r):(n(e,r),(r=zu(a,e.mode,u)).return=e,e=r),l(e);if(Pa(a))return m(e,r,a,u);if(G(a))return v(e,r,a,u);if(s&&Na(e,a),"undefined"===typeof a&&!c)switch(e.tag){case 1:case 0:throw e=e.type,Error(i(152,e.displayName||e.name||"Component"))}return n(e,r)}}var _a=Ma(!0),Aa=Ma(!1),za={},Ia={current:za},La={current:za},Da={current:za};function Fa(e){if(e===za)throw Error(i(174));return e}function Ua(e,t){so(Da,t),so(La,e),so(Ia,za);var n=t.nodeType;switch(n){case 9:case 11:t=(t=t.documentElement)?t.namespaceURI:$e(null,"");break;default:t=$e(t=(n=8===n?t.parentNode:t).namespaceURI||null,n=n.tagName)}co(Ia),so(Ia,t)}function $a(e){co(Ia),co(La),co(Da)}function Ba(e){Fa(Da.current);var t=Fa(Ia.current),n=$e(t,e.type);t!==n&&(so(La,e),so(Ia,n))}function Wa(e){La.current===e&&(co(Ia),co(La))}var Va={current:0};function Ha(e){for(var t=e;null!==t;){if(13===t.tag){var n=t.memoizedState;if(null!==n&&(null===(n=n.dehydrated)||"$?"===n.data||"$!"===n.data))return t}else if(19===t.tag&&void 0!==t.memoizedProps.revealOrder){if(0!==(64&t.effectTag))return t}else if(null!==t.child){t.child.return=t,t=t.child;continue}if(t===e)break;for(;null===t.sibling;){if(null===t.return||t.return===e)return null;t=t.return}t.sibling.return=t.return,t=t.sibling}return null}function qa(e,t){return{responder:e,props:t}}var Ka=_.ReactCurrentDispatcher,Qa=_.ReactCurrentBatchConfig,Xa=0,Ga=null,Ya=null,Ja=null,Za=null,ei=null,ti=null,ni=0,ri=null,oi=0,ai=!1,ii=null,li=0;function ui(){throw Error(i(321))}function ci(e,t){if(null===t)return!1;for(var n=0;n<t.length&&n<e.length;n++)if(!Gr(e[n],t[n]))return!1;return!0}function si(e,t,n,r,o,a){if(Xa=a,Ga=t,Ja=null!==e?e.memoizedState:null,Ka.current=null===Ja?Pi:Ri,t=n(r,o),ai){do{ai=!1,li+=1,Ja=null!==e?e.memoizedState:null,ti=Za,ri=ei=Ya=null,Ka.current=Ri,t=n(r,o)}while(ai);ii=null,li=0}if(Ka.current=ji,(e=Ga).memoizedState=Za,e.expirationTime=ni,e.updateQueue=ri,e.effectTag|=oi,e=null!==Ya&&null!==Ya.next,Xa=0,ti=ei=Za=Ja=Ya=Ga=null,ni=0,ri=null,oi=0,e)throw Error(i(300));return t}function di(){Ka.current=ji,Xa=0,ti=ei=Za=Ja=Ya=Ga=null,ni=0,ri=null,oi=0,ai=!1,ii=null,li=0}function fi(){var e={memoizedState:null,baseState:null,queue:null,baseUpdate:null,next:null};return null===ei?Za=ei=e:ei=ei.next=e,ei}function pi(){if(null!==ti)ti=(ei=ti).next,Ja=null!==(Ya=Ja)?Ya.next:null;else{if(null===Ja)throw Error(i(310));var e={memoizedState:(Ya=Ja).memoizedState,baseState:Ya.baseState,queue:Ya.queue,baseUpdate:Ya.baseUpdate,next:null};ei=null===ei?Za=e:ei.next=e,Ja=Ya.next}return ei}function hi(e,t){return"function"===typeof t?t(e):t}function mi(e){var t=pi(),n=t.queue;if(null===n)throw Error(i(311));if(n.lastRenderedReducer=e,0<li){var r=n.dispatch;if(null!==ii){var o=ii.get(n);if(void 0!==o){ii.delete(n);var a=t.memoizedState;do{a=e(a,o.action),o=o.next}while(null!==o);return Gr(a,t.memoizedState)||($i=!0),t.memoizedState=a,t.baseUpdate===n.last&&(t.baseState=a),n.lastRenderedState=a,[a,r]}}return[t.memoizedState,r]}r=n.last;var l=t.baseUpdate;if(a=t.baseState,null!==l?(null!==r&&(r.next=null),r=l.next):r=null!==r?r.next:null,null!==r){var u=o=null,c=r,s=!1;do{var d=c.expirationTime;d<Xa?(s||(s=!0,u=l,o=a),d>ni&&fu(ni=d)):(du(d,c.suspenseConfig),a=c.eagerReducer===e?c.eagerState:e(a,c.action)),l=c,c=c.next}while(null!==c&&c!==r);s||(u=l,o=a),Gr(a,t.memoizedState)||($i=!0),t.memoizedState=a,t.baseUpdate=u,t.baseState=o,n.lastRenderedState=a}return[t.memoizedState,n.dispatch]}function vi(e){var t=fi();return"function"===typeof e&&(e=e()),t.memoizedState=t.baseState=e,e=(e=t.queue={last:null,dispatch:null,lastRenderedReducer:hi,lastRenderedState:e}).dispatch=Ti.bind(null,Ga,e),[t.memoizedState,e]}function bi(e){return mi(hi)}function yi(e,t,n,r){return e={tag:e,create:t,destroy:n,deps:r,next:null},null===ri?(ri={lastEffect:null}).lastEffect=e.next=e:null===(t=ri.lastEffect)?ri.lastEffect=e.next=e:(n=t.next,t.next=e,e.next=n,ri.lastEffect=e),e}function gi(e,t,n,r){var o=fi();oi|=e,o.memoizedState=yi(t,n,void 0,void 0===r?null:r)}function xi(e,t,n,r){var o=pi();r=void 0===r?null:r;var a=void 0;if(null!==Ya){var i=Ya.memoizedState;if(a=i.destroy,null!==r&&ci(r,i.deps))return void yi(0,n,a,r)}oi|=e,o.memoizedState=yi(t,n,a,r)}function wi(e,t){return gi(516,192,e,t)}function ki(e,t){return xi(516,192,e,t)}function Ei(e,t){return"function"===typeof t?(e=e(),t(e),function(){t(null)}):null!==t&&void 0!==t?(e=e(),t.current=e,function(){t.current=null}):void 0}function Oi(){}function Si(e,t){return fi().memoizedState=[e,void 0===t?null:t],e}function Ci(e,t){var n=pi();t=void 0===t?null:t;var r=n.memoizedState;return null!==r&&null!==t&&ci(t,r[1])?r[0]:(n.memoizedState=[e,t],e)}function Ti(e,t,n){if(!(25>li))throw Error(i(301));var r=e.alternate;if(e===Ga||null!==r&&r===Ga)if(ai=!0,e={expirationTime:Xa,suspenseConfig:null,action:n,eagerReducer:null,eagerState:null,next:null},null===ii&&(ii=new Map),void 0===(n=ii.get(t)))ii.set(t,e);else{for(t=n;null!==t.next;)t=t.next;t.next=e}else{var o=Jl(),a=wa.suspense;a={expirationTime:o=Zl(o,e,a),suspenseConfig:a,action:n,eagerReducer:null,eagerState:null,next:null};var l=t.last;if(null===l)a.next=a;else{var u=l.next;null!==u&&(a.next=u),l.next=a}if(t.last=a,0===e.expirationTime&&(null===r||0===r.expirationTime)&&null!==(r=t.lastRenderedReducer))try{var c=t.lastRenderedState,s=r(c,n);if(a.eagerReducer=r,a.eagerState=s,Gr(s,c))return}catch(d){}eu(e,o)}}var ji={readContext:ua,useCallback:ui,useContext:ui,useEffect:ui,useImperativeHandle:ui,useLayoutEffect:ui,useMemo:ui,useReducer:ui,useRef:ui,useState:ui,useDebugValue:ui,useResponder:ui,useDeferredValue:ui,useTransition:ui},Pi={readContext:ua,useCallback:Si,useContext:ua,useEffect:wi,useImperativeHandle:function(e,t,n){return n=null!==n&&void 0!==n?n.concat([e]):null,gi(4,36,Ei.bind(null,t,e),n)},useLayoutEffect:function(e,t){return gi(4,36,e,t)},useMemo:function(e,t){var n=fi();return t=void 0===t?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=fi();return t=void 0!==n?n(t):t,r.memoizedState=r.baseState=t,e=(e=r.queue={last:null,dispatch:null,lastRenderedReducer:e,lastRenderedState:t}).dispatch=Ti.bind(null,Ga,e),[r.memoizedState,e]},useRef:function(e){return e={current:e},fi().memoizedState=e},useState:vi,useDebugValue:Oi,useResponder:qa,useDeferredValue:function(e,t){var n=vi(e),r=n[0],o=n[1];return wi((function(){a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===t?null:t;try{o(e)}finally{Qa.suspense=n}}))}),[e,t]),r},useTransition:function(e){var t=vi(!1),n=t[0],r=t[1];return[Si((function(t){r(!0),a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===e?null:e;try{r(!1),t()}finally{Qa.suspense=n}}))}),[e,n]),n]}},Ri={readContext:ua,useCallback:Ci,useContext:ua,useEffect:ki,useImperativeHandle:function(e,t,n){return n=null!==n&&void 0!==n?n.concat([e]):null,xi(4,36,Ei.bind(null,t,e),n)},useLayoutEffect:function(e,t){return xi(4,36,e,t)},useMemo:function(e,t){var n=pi();t=void 0===t?null:t;var r=n.memoizedState;return null!==r&&null!==t&&ci(t,r[1])?r[0]:(e=e(),n.memoizedState=[e,t],e)},useReducer:mi,useRef:function(){return pi().memoizedState},useState:bi,useDebugValue:Oi,useResponder:qa,useDeferredValue:function(e,t){var n=bi(),r=n[0],o=n[1];return ki((function(){a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===t?null:t;try{o(e)}finally{Qa.suspense=n}}))}),[e,t]),r},useTransition:function(e){var t=bi(),n=t[0],r=t[1];return[Ci((function(t){r(!0),a.unstable_next((function(){var n=Qa.suspense;Qa.suspense=void 0===e?null:e;try{r(!1),t()}finally{Qa.suspense=n}}))}),[e,n]),n]}},Ni=null,Mi=null,_i=!1;function Ai(e,t){var n=Ru(5,null,null,0);n.elementType="DELETED",n.type="DELETED",n.stateNode=t,n.return=e,n.effectTag=8,null!==e.lastEffect?(e.lastEffect.nextEffect=n,e.lastEffect=n):e.firstEffect=e.lastEffect=n}function zi(e,t){switch(e.tag){case 5:var n=e.type;return null!==(t=1!==t.nodeType||n.toLowerCase()!==t.nodeName.toLowerCase()?null:t)&&(e.stateNode=t,!0);case 6:return null!==(t=""===e.pendingProps||3!==t.nodeType?null:t)&&(e.stateNode=t,!0);case 13:default:return!1}}function Ii(e){if(_i){var t=Mi;if(t){var n=t;if(!zi(e,t)){if(!(t=nr(n.nextSibling))||!zi(e,t))return e.effectTag=-1025&e.effectTag|2,_i=!1,void(Ni=e);Ai(Ni,n)}Ni=e,Mi=nr(t.firstChild)}else e.effectTag=-1025&e.effectTag|2,_i=!1,Ni=e}}function Li(e){for(e=e.return;null!==e&&5!==e.tag&&3!==e.tag&&13!==e.tag;)e=e.return;Ni=e}function Di(e){if(e!==Ni)return!1;if(!_i)return Li(e),_i=!0,!1;var t=e.type;if(5!==e.tag||"head"!==t&&"body"!==t&&!Zn(t,e.memoizedProps))for(t=Mi;t;)Ai(e,t),t=nr(t.nextSibling);if(Li(e),13===e.tag){if(!(e=null!==(e=e.memoizedState)?e.dehydrated:null))throw Error(i(317));e:{for(e=e.nextSibling,t=0;e;){if(8===e.nodeType){var n=e.data;if("/$"===n){if(0===t){Mi=nr(e.nextSibling);break e}t--}else"$"!==n&&"$!"!==n&&"$?"!==n||t++}e=e.nextSibling}Mi=null}}else Mi=Ni?nr(e.stateNode.nextSibling):null;return!0}function Fi(){Mi=Ni=null,_i=!1}var Ui=_.ReactCurrentOwner,$i=!1;function Bi(e,t,n,r){t.child=null===e?Aa(t,null,n,r):_a(t,e.child,n,r)}function Wi(e,t,n,r,o){n=n.render;var a=t.ref;return la(t,o),r=si(e,t,n,r,a,o),null===e||$i?(t.effectTag|=1,Bi(e,t,r,o),t.child):(t.updateQueue=e.updateQueue,t.effectTag&=-517,e.expirationTime<=o&&(e.expirationTime=0),al(e,t,o))}function Vi(e,t,n,r,o,a){if(null===e){var i=n.type;return"function"!==typeof i||Nu(i)||void 0!==i.defaultProps||null!==n.compare||void 0!==n.defaultProps?((e=_u(n.type,null,r,null,t.mode,a)).ref=t.ref,e.return=t,t.child=e):(t.tag=15,t.type=i,Hi(e,t,i,r,o,a))}return i=e.child,o<a&&(o=i.memoizedProps,(n=null!==(n=n.compare)?n:Jr)(o,r)&&e.ref===t.ref)?al(e,t,a):(t.effectTag|=1,(e=Mu(i,r)).ref=t.ref,e.return=t,t.child=e)}function Hi(e,t,n,r,o,a){return null!==e&&Jr(e.memoizedProps,r)&&e.ref===t.ref&&($i=!1,o<a)?al(e,t,a):Ki(e,t,n,r,a)}function qi(e,t){var n=t.ref;(null===e&&null!==n||null!==e&&e.ref!==n)&&(t.effectTag|=128)}function Ki(e,t,n,r,o){var a=bo(n)?mo:po.current;return a=vo(t,a),la(t,o),n=si(e,t,n,r,a,o),null===e||$i?(t.effectTag|=1,Bi(e,t,n,o),t.child):(t.updateQueue=e.updateQueue,t.effectTag&=-517,e.expirationTime<=o&&(e.expirationTime=0),al(e,t,o))}function Qi(e,t,n,r,o){if(bo(n)){var a=!0;ko(t)}else a=!1;if(la(t,o),null===t.stateNode)null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),Ca(t,n,r),ja(t,n,r,o),r=!0;else if(null===e){var i=t.stateNode,l=t.memoizedProps;i.props=l;var u=i.context,c=n.contextType;"object"===typeof c&&null!==c?c=ua(c):c=vo(t,c=bo(n)?mo:po.current);var s=n.getDerivedStateFromProps,d="function"===typeof s||"function"===typeof i.getSnapshotBeforeUpdate;d||"function"!==typeof i.UNSAFE_componentWillReceiveProps&&"function"!==typeof i.componentWillReceiveProps||(l!==r||u!==c)&&Ta(t,i,r,c),ca=!1;var f=t.memoizedState;u=i.state=f;var p=t.updateQueue;null!==p&&(ya(t,p,r,i,o),u=t.memoizedState),l!==r||f!==u||ho.current||ca?("function"===typeof s&&(Ea(t,n,s,r),u=t.memoizedState),(l=ca||Sa(t,n,l,r,f,u,c))?(d||"function"!==typeof i.UNSAFE_componentWillMount&&"function"!==typeof i.componentWillMount||("function"===typeof i.componentWillMount&&i.componentWillMount(),"function"===typeof i.UNSAFE_componentWillMount&&i.UNSAFE_componentWillMount()),"function"===typeof i.componentDidMount&&(t.effectTag|=4)):("function"===typeof i.componentDidMount&&(t.effectTag|=4),t.memoizedProps=r,t.memoizedState=u),i.props=r,i.state=u,i.context=c,r=l):("function"===typeof i.componentDidMount&&(t.effectTag|=4),r=!1)}else i=t.stateNode,l=t.memoizedProps,i.props=t.type===t.elementType?l:Jo(t.type,l),u=i.context,"object"===typeof(c=n.contextType)&&null!==c?c=ua(c):c=vo(t,c=bo(n)?mo:po.current),(d="function"===typeof(s=n.getDerivedStateFromProps)||"function"===typeof i.getSnapshotBeforeUpdate)||"function"!==typeof i.UNSAFE_componentWillReceiveProps&&"function"!==typeof i.componentWillReceiveProps||(l!==r||u!==c)&&Ta(t,i,r,c),ca=!1,u=t.memoizedState,f=i.state=u,null!==(p=t.updateQueue)&&(ya(t,p,r,i,o),f=t.memoizedState),l!==r||u!==f||ho.current||ca?("function"===typeof s&&(Ea(t,n,s,r),f=t.memoizedState),(s=ca||Sa(t,n,l,r,u,f,c))?(d||"function"!==typeof i.UNSAFE_componentWillUpdate&&"function"!==typeof i.componentWillUpdate||("function"===typeof i.componentWillUpdate&&i.componentWillUpdate(r,f,c),"function"===typeof i.UNSAFE_componentWillUpdate&&i.UNSAFE_componentWillUpdate(r,f,c)),"function"===typeof i.componentDidUpdate&&(t.effectTag|=4),"function"===typeof i.getSnapshotBeforeUpdate&&(t.effectTag|=256)):("function"!==typeof i.componentDidUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=4),"function"!==typeof i.getSnapshotBeforeUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=256),t.memoizedProps=r,t.memoizedState=f),i.props=r,i.state=f,i.context=c,r=s):("function"!==typeof i.componentDidUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=4),"function"!==typeof i.getSnapshotBeforeUpdate||l===e.memoizedProps&&u===e.memoizedState||(t.effectTag|=256),r=!1);return Xi(e,t,n,r,a,o)}function Xi(e,t,n,r,o,a){qi(e,t);var i=0!==(64&t.effectTag);if(!r&&!i)return o&&Eo(t,n,!1),al(e,t,a);r=t.stateNode,Ui.current=t;var l=i&&"function"!==typeof n.getDerivedStateFromError?null:r.render();return t.effectTag|=1,null!==e&&i?(t.child=_a(t,e.child,null,a),t.child=_a(t,null,l,a)):Bi(e,t,l,a),t.memoizedState=r.state,o&&Eo(t,n,!0),t.child}function Gi(e){var t=e.stateNode;t.pendingContext?xo(0,t.pendingContext,t.pendingContext!==t.context):t.context&&xo(0,t.context,!1),Ua(e,t.containerInfo)}var Yi,Ji,Zi,el={dehydrated:null,retryTime:0};function tl(e,t,n){var r,o=t.mode,a=t.pendingProps,i=Va.current,l=!1;if((r=0!==(64&t.effectTag))||(r=0!==(2&i)&&(null===e||null!==e.memoizedState)),r?(l=!0,t.effectTag&=-65):null!==e&&null===e.memoizedState||void 0===a.fallback||!0===a.unstable_avoidThisFallback||(i|=1),so(Va,1&i),null===e){if(void 0!==a.fallback&&Ii(t),l){if(l=a.fallback,(a=Au(null,o,0,null)).return=t,0===(2&t.mode))for(e=null!==t.memoizedState?t.child.child:t.child,a.child=e;null!==e;)e.return=a,e=e.sibling;return(n=Au(l,o,n,null)).return=t,a.sibling=n,t.memoizedState=el,t.child=a,n}return o=a.children,t.memoizedState=null,t.child=Aa(t,null,o,n)}if(null!==e.memoizedState){if(o=(e=e.child).sibling,l){if(a=a.fallback,(n=Mu(e,e.pendingProps)).return=t,0===(2&t.mode)&&(l=null!==t.memoizedState?t.child.child:t.child)!==e.child)for(n.child=l;null!==l;)l.return=n,l=l.sibling;return(o=Mu(o,a,o.expirationTime)).return=t,n.sibling=o,n.childExpirationTime=0,t.memoizedState=el,t.child=n,o}return n=_a(t,e.child,a.children,n),t.memoizedState=null,t.child=n}if(e=e.child,l){if(l=a.fallback,(a=Au(null,o,0,null)).return=t,a.child=e,null!==e&&(e.return=a),0===(2&t.mode))for(e=null!==t.memoizedState?t.child.child:t.child,a.child=e;null!==e;)e.return=a,e=e.sibling;return(n=Au(l,o,n,null)).return=t,a.sibling=n,n.effectTag|=2,a.childExpirationTime=0,t.memoizedState=el,t.child=a,n}return t.memoizedState=null,t.child=_a(t,e,a.children,n)}function nl(e,t){e.expirationTime<t&&(e.expirationTime=t);var n=e.alternate;null!==n&&n.expirationTime<t&&(n.expirationTime=t),ia(e.return,t)}function rl(e,t,n,r,o,a){var i=e.memoizedState;null===i?e.memoizedState={isBackwards:t,rendering:null,last:r,tail:n,tailExpiration:0,tailMode:o,lastEffect:a}:(i.isBackwards=t,i.rendering=null,i.last=r,i.tail=n,i.tailExpiration=0,i.tailMode=o,i.lastEffect=a)}function ol(e,t,n){var r=t.pendingProps,o=r.revealOrder,a=r.tail;if(Bi(e,t,r.children,n),0!==(2&(r=Va.current)))r=1&r|2,t.effectTag|=64;else{if(null!==e&&0!==(64&e.effectTag))e:for(e=t.child;null!==e;){if(13===e.tag)null!==e.memoizedState&&nl(e,n);else if(19===e.tag)nl(e,n);else if(null!==e.child){e.child.return=e,e=e.child;continue}if(e===t)break e;for(;null===e.sibling;){if(null===e.return||e.return===t)break e;e=e.return}e.sibling.return=e.return,e=e.sibling}r&=1}if(so(Va,r),0===(2&t.mode))t.memoizedState=null;else switch(o){case"forwards":for(n=t.child,o=null;null!==n;)null!==(e=n.alternate)&&null===Ha(e)&&(o=n),n=n.sibling;null===(n=o)?(o=t.child,t.child=null):(o=n.sibling,n.sibling=null),rl(t,!1,o,n,a,t.lastEffect);break;case"backwards":for(n=null,o=t.child,t.child=null;null!==o;){if(null!==(e=o.alternate)&&null===Ha(e)){t.child=o;break}e=o.sibling,o.sibling=n,n=o,o=e}rl(t,!0,n,null,a,t.lastEffect);break;case"together":rl(t,!1,null,null,void 0,t.lastEffect);break;default:t.memoizedState=null}return t.child}function al(e,t,n){null!==e&&(t.dependencies=e.dependencies);var r=t.expirationTime;if(0!==r&&fu(r),t.childExpirationTime<n)return null;if(null!==e&&t.child!==e.child)throw Error(i(153));if(null!==t.child){for(n=Mu(e=t.child,e.pendingProps,e.expirationTime),t.child=n,n.return=t;null!==e.sibling;)e=e.sibling,(n=n.sibling=Mu(e,e.pendingProps,e.expirationTime)).return=t;n.sibling=null}return t.child}function il(e){e.effectTag|=4}function ll(e,t){switch(e.tailMode){case"hidden":t=e.tail;for(var n=null;null!==t;)null!==t.alternate&&(n=t),t=t.sibling;null===n?e.tail=null:n.sibling=null;break;case"collapsed":n=e.tail;for(var r=null;null!==n;)null!==n.alternate&&(r=n),n=n.sibling;null===r?t||null===e.tail?e.tail=null:e.tail.sibling=null:r.sibling=null}}function ul(e){switch(e.tag){case 1:bo(e.type)&&yo();var t=e.effectTag;return 4096&t?(e.effectTag=-4097&t|64,e):null;case 3:if($a(),go(),0!==(64&(t=e.effectTag)))throw Error(i(285));return e.effectTag=-4097&t|64,e;case 5:return Wa(e),null;case 13:return co(Va),4096&(t=e.effectTag)?(e.effectTag=-4097&t|64,e):null;case 19:return co(Va),null;case 4:return $a(),null;case 10:return aa(e),null;default:return null}}function cl(e,t){return{value:e,source:t,stack:J(t)}}Yi=function(e,t){for(var n=t.child;null!==n;){if(5===n.tag||6===n.tag)e.appendChild(n.stateNode);else if(4!==n.tag&&null!==n.child){n.child.return=n,n=n.child;continue}if(n===t)break;for(;null===n.sibling;){if(null===n.return||n.return===t)return;n=n.return}n.sibling.return=n.return,n=n.sibling}},Ji=function(e,t,n,r,a){var i=e.memoizedProps;if(i!==r){var l,u,c=t.stateNode;switch(Fa(Ia.current),e=null,n){case"input":i=Ce(c,i),r=Ce(c,r),e=[];break;case"option":i=Me(c,i),r=Me(c,r),e=[];break;case"select":i=o({},i,{value:void 0}),r=o({},r,{value:void 0}),e=[];break;case"textarea":i=Ae(c,i),r=Ae(c,r),e=[];break;default:"function"!==typeof i.onClick&&"function"===typeof r.onClick&&(c.onclick=Vn)}for(l in $n(n,r),n=null,i)if(!r.hasOwnProperty(l)&&i.hasOwnProperty(l)&&null!=i[l])if("style"===l)for(u in c=i[l])c.hasOwnProperty(u)&&(n||(n={}),n[u]="");else"dangerouslySetInnerHTML"!==l&&"children"!==l&&"suppressContentEditableWarning"!==l&&"suppressHydrationWarning"!==l&&"autoFocus"!==l&&(p.hasOwnProperty(l)?e||(e=[]):(e=e||[]).push(l,null));for(l in r){var s=r[l];if(c=null!=i?i[l]:void 0,r.hasOwnProperty(l)&&s!==c&&(null!=s||null!=c))if("style"===l)if(c){for(u in c)!c.hasOwnProperty(u)||s&&s.hasOwnProperty(u)||(n||(n={}),n[u]="");for(u in s)s.hasOwnProperty(u)&&c[u]!==s[u]&&(n||(n={}),n[u]=s[u])}else n||(e||(e=[]),e.push(l,n)),n=s;else"dangerouslySetInnerHTML"===l?(s=s?s.__html:void 0,c=c?c.__html:void 0,null!=s&&c!==s&&(e=e||[]).push(l,""+s)):"children"===l?c===s||"string"!==typeof s&&"number"!==typeof s||(e=e||[]).push(l,""+s):"suppressContentEditableWarning"!==l&&"suppressHydrationWarning"!==l&&(p.hasOwnProperty(l)?(null!=s&&Wn(a,l),e||c===s||(e=[])):(e=e||[]).push(l,s))}n&&(e=e||[]).push("style",n),a=e,(t.updateQueue=a)&&il(t)}},Zi=function(e,t,n,r){n!==r&&il(t)};var sl="function"===typeof WeakSet?WeakSet:Set;function dl(e,t){var n=t.source,r=t.stack;null===r&&null!==n&&(r=J(n)),null!==n&&Y(n.type),t=t.value,null!==e&&1===e.tag&&Y(e.type);try{console.error(t)}catch(o){setTimeout((function(){throw o}))}}function fl(e){var t=e.ref;if(null!==t)if("function"===typeof t)try{t(null)}catch(n){Ou(e,n)}else t.current=null}function pl(e,t){switch(t.tag){case 0:case 11:case 15:hl(2,0,t);break;case 1:if(256&t.effectTag&&null!==e){var n=e.memoizedProps,r=e.memoizedState;t=(e=t.stateNode).getSnapshotBeforeUpdate(t.elementType===t.type?n:Jo(t.type,n),r),e.__reactInternalSnapshotBeforeUpdate=t}break;case 3:case 5:case 6:case 4:case 17:break;default:throw Error(i(163))}}function hl(e,t,n){if(null!==(n=null!==(n=n.updateQueue)?n.lastEffect:null)){var r=n=n.next;do{if(0!==(r.tag&e)){var o=r.destroy;r.destroy=void 0,void 0!==o&&o()}0!==(r.tag&t)&&(o=r.create,r.destroy=o()),r=r.next}while(r!==n)}}function ml(e,t,n){switch("function"===typeof ju&&ju(t),t.tag){case 0:case 11:case 14:case 15:if(null!==(e=t.updateQueue)&&null!==(e=e.lastEffect)){var r=e.next;Ho(97<n?97:n,(function(){var e=r;do{var n=e.destroy;if(void 0!==n){var o=t;try{n()}catch(a){Ou(o,a)}}e=e.next}while(e!==r)}))}break;case 1:fl(t),"function"===typeof(n=t.stateNode).componentWillUnmount&&function(e,t){try{t.props=e.memoizedProps,t.state=e.memoizedState,t.componentWillUnmount()}catch(n){Ou(e,n)}}(t,n);break;case 5:fl(t);break;case 4:gl(e,t,n)}}function vl(e){var t=e.alternate;e.return=null,e.child=null,e.memoizedState=null,e.updateQueue=null,e.dependencies=null,e.alternate=null,e.firstEffect=null,e.lastEffect=null,e.pendingProps=null,e.memoizedProps=null,null!==t&&vl(t)}function bl(e){return 5===e.tag||3===e.tag||4===e.tag}function yl(e){e:{for(var t=e.return;null!==t;){if(bl(t)){var n=t;break e}t=t.return}throw Error(i(160))}switch(t=n.stateNode,n.tag){case 5:var r=!1;break;case 3:case 4:t=t.containerInfo,r=!0;break;default:throw Error(i(161))}16&n.effectTag&&(Ve(t,""),n.effectTag&=-17);e:t:for(n=e;;){for(;null===n.sibling;){if(null===n.return||bl(n.return)){n=null;break e}n=n.return}for(n.sibling.return=n.return,n=n.sibling;5!==n.tag&&6!==n.tag&&18!==n.tag;){if(2&n.effectTag)continue t;if(null===n.child||4===n.tag)continue t;n.child.return=n,n=n.child}if(!(2&n.effectTag)){n=n.stateNode;break e}}for(var o=e;;){var a=5===o.tag||6===o.tag;if(a){var l=a?o.stateNode:o.stateNode.instance;if(n)if(r){var u=l;l=n,8===(a=t).nodeType?a.parentNode.insertBefore(u,l):a.insertBefore(u,l)}else t.insertBefore(l,n);else r?(8===(u=t).nodeType?(a=u.parentNode).insertBefore(l,u):(a=u).appendChild(l),null!==(u=u._reactRootContainer)&&void 0!==u||null!==a.onclick||(a.onclick=Vn)):t.appendChild(l)}else if(4!==o.tag&&null!==o.child){o.child.return=o,o=o.child;continue}if(o===e)break;for(;null===o.sibling;){if(null===o.return||o.return===e)return;o=o.return}o.sibling.return=o.return,o=o.sibling}}function gl(e,t,n){for(var r,o,a=t,l=!1;;){if(!l){l=a.return;e:for(;;){if(null===l)throw Error(i(160));switch(r=l.stateNode,l.tag){case 5:o=!1;break e;case 3:case 4:r=r.containerInfo,o=!0;break e}l=l.return}l=!0}if(5===a.tag||6===a.tag){e:for(var u=e,c=a,s=n,d=c;;)if(ml(u,d,s),null!==d.child&&4!==d.tag)d.child.return=d,d=d.child;else{if(d===c)break;for(;null===d.sibling;){if(null===d.return||d.return===c)break e;d=d.return}d.sibling.return=d.return,d=d.sibling}o?(u=r,c=a.stateNode,8===u.nodeType?u.parentNode.removeChild(c):u.removeChild(c)):r.removeChild(a.stateNode)}else if(4===a.tag){if(null!==a.child){r=a.stateNode.containerInfo,o=!0,a.child.return=a,a=a.child;continue}}else if(ml(e,a,n),null!==a.child){a.child.return=a,a=a.child;continue}if(a===t)break;for(;null===a.sibling;){if(null===a.return||a.return===t)return;4===(a=a.return).tag&&(l=!1)}a.sibling.return=a.return,a=a.sibling}}function xl(e,t){switch(t.tag){case 0:case 11:case 14:case 15:hl(4,8,t);break;case 1:break;case 5:var n=t.stateNode;if(null!=n){var r=t.memoizedProps,o=null!==e?e.memoizedProps:r;e=t.type;var a=t.updateQueue;if(t.updateQueue=null,null!==a){for(n[ir]=r,"input"===e&&"radio"===r.type&&null!=r.name&&je(n,r),Bn(e,o),t=Bn(e,r),o=0;o<a.length;o+=2){var l=a[o],u=a[o+1];"style"===l?Fn(n,u):"dangerouslySetInnerHTML"===l?We(n,u):"children"===l?Ve(n,u):ke(n,l,u,t)}switch(e){case"input":Pe(n,r);break;case"textarea":Ie(n,r);break;case"select":t=n._wrapperState.wasMultiple,n._wrapperState.wasMultiple=!!r.multiple,null!=(e=r.value)?_e(n,!!r.multiple,e,!1):t!==!!r.multiple&&(null!=r.defaultValue?_e(n,!!r.multiple,r.defaultValue,!0):_e(n,!!r.multiple,r.multiple?[]:"",!1))}}}break;case 6:if(null===t.stateNode)throw Error(i(162));t.stateNode.nodeValue=t.memoizedProps;break;case 3:(t=t.stateNode).hydrate&&(t.hydrate=!1,Ct(t.containerInfo));break;case 12:break;case 13:if(n=t,null===t.memoizedState?r=!1:(r=!0,n=t.child,Ul=Bo()),null!==n)e:for(e=n;;){if(5===e.tag)a=e.stateNode,r?"function"===typeof(a=a.style).setProperty?a.setProperty("display","none","important"):a.display="none":(a=e.stateNode,o=void 0!==(o=e.memoizedProps.style)&&null!==o&&o.hasOwnProperty("display")?o.display:null,a.style.display=Dn("display",o));else if(6===e.tag)e.stateNode.nodeValue=r?"":e.memoizedProps;else{if(13===e.tag&&null!==e.memoizedState&&null===e.memoizedState.dehydrated){(a=e.child.sibling).return=e,e=a;continue}if(null!==e.child){e.child.return=e,e=e.child;continue}}if(e===n)break e;for(;null===e.sibling;){if(null===e.return||e.return===n)break e;e=e.return}e.sibling.return=e.return,e=e.sibling}wl(t);break;case 19:wl(t);break;case 17:case 20:case 21:break;default:throw Error(i(163))}}function wl(e){var t=e.updateQueue;if(null!==t){e.updateQueue=null;var n=e.stateNode;null===n&&(n=e.stateNode=new sl),t.forEach((function(t){var r=Cu.bind(null,e,t);n.has(t)||(n.add(t),t.then(r,r))}))}}var kl="function"===typeof WeakMap?WeakMap:Map;function El(e,t,n){(n=fa(n,null)).tag=3,n.payload={element:null};var r=t.value;return n.callback=function(){Bl||(Bl=!0,Wl=r),dl(e,t)},n}function Ol(e,t,n){(n=fa(n,null)).tag=3;var r=e.type.getDerivedStateFromError;if("function"===typeof r){var o=t.value;n.payload=function(){return dl(e,t),r(o)}}var a=e.stateNode;return null!==a&&"function"===typeof a.componentDidCatch&&(n.callback=function(){"function"!==typeof r&&(null===Vl?Vl=new Set([this]):Vl.add(this),dl(e,t));var n=t.stack;this.componentDidCatch(t.value,{componentStack:null!==n?n:""})}),n}var Sl,Cl=Math.ceil,Tl=_.ReactCurrentDispatcher,jl=_.ReactCurrentOwner,Pl=0,Rl=null,Nl=null,Ml=0,_l=0,Al=null,zl=1073741823,Il=1073741823,Ll=null,Dl=0,Fl=!1,Ul=0,$l=null,Bl=!1,Wl=null,Vl=null,Hl=!1,ql=null,Kl=90,Ql=null,Xl=0,Gl=null,Yl=0;function Jl(){return 0!==(48&Pl)?1073741821-(Bo()/10|0):0!==Yl?Yl:Yl=1073741821-(Bo()/10|0)}function Zl(e,t,n){if(0===(2&(t=t.mode)))return 1073741823;var r=Wo();if(0===(4&t))return 99===r?1073741823:1073741822;if(0!==(16&Pl))return Ml;if(null!==n)e=Yo(e,0|n.timeoutMs||5e3,250);else switch(r){case 99:e=1073741823;break;case 98:e=Yo(e,150,100);break;case 97:case 96:e=Yo(e,5e3,250);break;case 95:e=2;break;default:throw Error(i(326))}return null!==Rl&&e===Ml&&--e,e}function eu(e,t){if(50<Xl)throw Xl=0,Gl=null,Error(i(185));if(null!==(e=tu(e,t))){var n=Wo();1073741823===t?0!==(8&Pl)&&0===(48&Pl)?au(e):(ru(e),0===Pl&&Qo()):ru(e),0===(4&Pl)||98!==n&&99!==n||(null===Ql?Ql=new Map([[e,t]]):(void 0===(n=Ql.get(e))||n>t)&&Ql.set(e,t))}}function tu(e,t){e.expirationTime<t&&(e.expirationTime=t);var n=e.alternate;null!==n&&n.expirationTime<t&&(n.expirationTime=t);var r=e.return,o=null;if(null===r&&3===e.tag)o=e.stateNode;else for(;null!==r;){if(n=r.alternate,r.childExpirationTime<t&&(r.childExpirationTime=t),null!==n&&n.childExpirationTime<t&&(n.childExpirationTime=t),null===r.return&&3===r.tag){o=r.stateNode;break}r=r.return}return null!==o&&(Rl===o&&(fu(t),4===_l&&Fu(o,Ml)),Uu(o,t)),o}function nu(e){var t=e.lastExpiredTime;return 0!==t?t:Du(e,t=e.firstPendingTime)?(t=e.lastPingedTime)>(e=e.nextKnownPendingLevel)?t:e:t}function ru(e){if(0!==e.lastExpiredTime)e.callbackExpirationTime=1073741823,e.callbackPriority=99,e.callbackNode=Ko(au.bind(null,e));else{var t=nu(e),n=e.callbackNode;if(0===t)null!==n&&(e.callbackNode=null,e.callbackExpirationTime=0,e.callbackPriority=90);else{var r=Jl();if(1073741823===t?r=99:1===t||2===t?r=95:r=0>=(r=10*(1073741821-t)-10*(1073741821-r))?99:250>=r?98:5250>=r?97:95,null!==n){var o=e.callbackPriority;if(e.callbackExpirationTime===t&&o>=r)return;n!==Io&&Co(n)}e.callbackExpirationTime=t,e.callbackPriority=r,t=1073741823===t?Ko(au.bind(null,e)):qo(r,ou.bind(null,e),{timeout:10*(1073741821-t)-Bo()}),e.callbackNode=t}}}function ou(e,t){if(Yl=0,t)return $u(e,t=Jl()),ru(e),null;var n=nu(e);if(0!==n){if(t=e.callbackNode,0!==(48&Pl))throw Error(i(327));if(wu(),e===Rl&&n===Ml||uu(e,n),null!==Nl){var r=Pl;Pl|=16;for(var o=su();;)try{hu();break}catch(u){cu(e,u)}if(ra(),Pl=r,Tl.current=o,1===_l)throw t=Al,uu(e,n),Fu(e,n),ru(e),t;if(null===Nl)switch(o=e.finishedWork=e.current.alternate,e.finishedExpirationTime=n,r=_l,Rl=null,r){case 0:case 1:throw Error(i(345));case 2:$u(e,2<n?2:n);break;case 3:if(Fu(e,n),n===(r=e.lastSuspendedTime)&&(e.nextKnownPendingLevel=bu(o)),1073741823===zl&&10<(o=Ul+500-Bo())){if(Fl){var a=e.lastPingedTime;if(0===a||a>=n){e.lastPingedTime=n,uu(e,n);break}}if(0!==(a=nu(e))&&a!==n)break;if(0!==r&&r!==n){e.lastPingedTime=r;break}e.timeoutHandle=er(yu.bind(null,e),o);break}yu(e);break;case 4:if(Fu(e,n),n===(r=e.lastSuspendedTime)&&(e.nextKnownPendingLevel=bu(o)),Fl&&(0===(o=e.lastPingedTime)||o>=n)){e.lastPingedTime=n,uu(e,n);break}if(0!==(o=nu(e))&&o!==n)break;if(0!==r&&r!==n){e.lastPingedTime=r;break}if(1073741823!==Il?r=10*(1073741821-Il)-Bo():1073741823===zl?r=0:(r=10*(1073741821-zl)-5e3,0>(r=(o=Bo())-r)&&(r=0),(n=10*(1073741821-n)-o)<(r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*Cl(r/1960))-r)&&(r=n)),10<r){e.timeoutHandle=er(yu.bind(null,e),r);break}yu(e);break;case 5:if(1073741823!==zl&&null!==Ll){a=zl;var l=Ll;if(0>=(r=0|l.busyMinDurationMs)?r=0:(o=0|l.busyDelayMs,r=(a=Bo()-(10*(1073741821-a)-(0|l.timeoutMs||5e3)))<=o?0:o+r-a),10<r){Fu(e,n),e.timeoutHandle=er(yu.bind(null,e),r);break}}yu(e);break;default:throw Error(i(329))}if(ru(e),e.callbackNode===t)return ou.bind(null,e)}}return null}function au(e){var t=e.lastExpiredTime;if(t=0!==t?t:1073741823,e.finishedExpirationTime===t)yu(e);else{if(0!==(48&Pl))throw Error(i(327));if(wu(),e===Rl&&t===Ml||uu(e,t),null!==Nl){var n=Pl;Pl|=16;for(var r=su();;)try{pu();break}catch(o){cu(e,o)}if(ra(),Pl=n,Tl.current=r,1===_l)throw n=Al,uu(e,t),Fu(e,t),ru(e),n;if(null!==Nl)throw Error(i(261));e.finishedWork=e.current.alternate,e.finishedExpirationTime=t,Rl=null,yu(e),ru(e)}}return null}function iu(e,t){var n=Pl;Pl|=1;try{return e(t)}finally{0===(Pl=n)&&Qo()}}function lu(e,t){var n=Pl;Pl&=-2,Pl|=8;try{return e(t)}finally{0===(Pl=n)&&Qo()}}function uu(e,t){e.finishedWork=null,e.finishedExpirationTime=0;var n=e.timeoutHandle;if(-1!==n&&(e.timeoutHandle=-1,tr(n)),null!==Nl)for(n=Nl.return;null!==n;){var r=n;switch(r.tag){case 1:var o=r.type.childContextTypes;null!==o&&void 0!==o&&yo();break;case 3:$a(),go();break;case 5:Wa(r);break;case 4:$a();break;case 13:case 19:co(Va);break;case 10:aa(r)}n=n.return}Rl=e,Nl=Mu(e.current,null),Ml=t,_l=0,Al=null,Il=zl=1073741823,Ll=null,Dl=0,Fl=!1}function cu(e,t){for(;;){try{if(ra(),di(),null===Nl||null===Nl.return)return _l=1,Al=t,null;e:{var n=e,r=Nl.return,o=Nl,a=t;if(t=Ml,o.effectTag|=2048,o.firstEffect=o.lastEffect=null,null!==a&&"object"===typeof a&&"function"===typeof a.then){var i=a,l=0!==(1&Va.current),u=r;do{var c;if(c=13===u.tag){var s=u.memoizedState;if(null!==s)c=null!==s.dehydrated;else{var d=u.memoizedProps;c=void 0!==d.fallback&&(!0!==d.unstable_avoidThisFallback||!l)}}if(c){var f=u.updateQueue;if(null===f){var p=new Set;p.add(i),u.updateQueue=p}else f.add(i);if(0===(2&u.mode)){if(u.effectTag|=64,o.effectTag&=-2981,1===o.tag)if(null===o.alternate)o.tag=17;else{var h=fa(1073741823,null);h.tag=2,ha(o,h)}o.expirationTime=1073741823;break e}a=void 0,o=t;var m=n.pingCache;if(null===m?(m=n.pingCache=new kl,a=new Set,m.set(i,a)):void 0===(a=m.get(i))&&(a=new Set,m.set(i,a)),!a.has(o)){a.add(o);var v=Su.bind(null,n,i,o);i.then(v,v)}u.effectTag|=4096,u.expirationTime=t;break e}u=u.return}while(null!==u);a=Error((Y(o.type)||"A React component")+" suspended while rendering, but no fallback UI was specified.\n\nAdd a <Suspense fallback=...> component higher in the tree to provide a loading indicator or placeholder to display."+J(o))}5!==_l&&(_l=2),a=cl(a,o),u=r;do{switch(u.tag){case 3:i=a,u.effectTag|=4096,u.expirationTime=t,ma(u,El(u,i,t));break e;case 1:i=a;var b=u.type,y=u.stateNode;if(0===(64&u.effectTag)&&("function"===typeof b.getDerivedStateFromError||null!==y&&"function"===typeof y.componentDidCatch&&(null===Vl||!Vl.has(y)))){u.effectTag|=4096,u.expirationTime=t,ma(u,Ol(u,i,t));break e}}u=u.return}while(null!==u)}Nl=vu(Nl)}catch(g){t=g;continue}break}}function su(){var e=Tl.current;return Tl.current=ji,null===e?ji:e}function du(e,t){e<zl&&2<e&&(zl=e),null!==t&&e<Il&&2<e&&(Il=e,Ll=t)}function fu(e){e>Dl&&(Dl=e)}function pu(){for(;null!==Nl;)Nl=mu(Nl)}function hu(){for(;null!==Nl&&!To();)Nl=mu(Nl)}function mu(e){var t=Sl(e.alternate,e,Ml);return e.memoizedProps=e.pendingProps,null===t&&(t=vu(e)),jl.current=null,t}function vu(e){Nl=e;do{var t=Nl.alternate;if(e=Nl.return,0===(2048&Nl.effectTag)){e:{var n=t,r=Ml,a=(t=Nl).pendingProps;switch(t.tag){case 2:case 16:break;case 15:case 0:break;case 1:bo(t.type)&&yo();break;case 3:$a(),go(),(a=t.stateNode).pendingContext&&(a.context=a.pendingContext,a.pendingContext=null),(null===n||null===n.child)&&Di(t)&&il(t);break;case 5:Wa(t),r=Fa(Da.current);var l=t.type;if(null!==n&&null!=t.stateNode)Ji(n,t,l,a,r),n.ref!==t.ref&&(t.effectTag|=128);else if(a){var u=Fa(Ia.current);if(Di(t)){var c=(a=t).stateNode;n=a.type;var s=a.memoizedProps,d=r;switch(c[ar]=a,c[ir]=s,l=void 0,r=c,n){case"iframe":case"object":case"embed":Sn("load",r);break;case"video":case"audio":for(c=0;c<et.length;c++)Sn(et[c],r);break;case"source":Sn("error",r);break;case"img":case"image":case"link":Sn("error",r),Sn("load",r);break;case"form":Sn("reset",r),Sn("submit",r);break;case"details":Sn("toggle",r);break;case"input":Te(r,s),Sn("invalid",r),Wn(d,"onChange");break;case"select":r._wrapperState={wasMultiple:!!s.multiple},Sn("invalid",r),Wn(d,"onChange");break;case"textarea":ze(r,s),Sn("invalid",r),Wn(d,"onChange")}for(l in $n(n,s),c=null,s)s.hasOwnProperty(l)&&(u=s[l],"children"===l?"string"===typeof u?r.textContent!==u&&(c=["children",u]):"number"===typeof u&&r.textContent!==""+u&&(c=["children",""+u]):p.hasOwnProperty(l)&&null!=u&&Wn(d,l));switch(n){case"input":Oe(r),Re(r,s,!0);break;case"textarea":Oe(r),Le(r);break;case"select":case"option":break;default:"function"===typeof s.onClick&&(r.onclick=Vn)}l=c,a.updateQueue=l,(a=null!==l)&&il(t)}else{n=t,d=l,s=a,c=9===r.nodeType?r:r.ownerDocument,u===De&&(u=Ue(d)),u===De?"script"===d?((s=c.createElement("div")).innerHTML="<script><\/script>",c=s.removeChild(s.firstChild)):"string"===typeof s.is?c=c.createElement(d,{is:s.is}):(c=c.createElement(d),"select"===d&&(d=c,s.multiple?d.multiple=!0:s.size&&(d.size=s.size))):c=c.createElementNS(u,d),(s=c)[ar]=n,s[ir]=a,Yi(s,t),t.stateNode=s;var f=r,h=Bn(d=l,n=a);switch(d){case"iframe":case"object":case"embed":Sn("load",s),r=n;break;case"video":case"audio":for(r=0;r<et.length;r++)Sn(et[r],s);r=n;break;case"source":Sn("error",s),r=n;break;case"img":case"image":case"link":Sn("error",s),Sn("load",s),r=n;break;case"form":Sn("reset",s),Sn("submit",s),r=n;break;case"details":Sn("toggle",s),r=n;break;case"input":Te(s,n),r=Ce(s,n),Sn("invalid",s),Wn(f,"onChange");break;case"option":r=Me(s,n);break;case"select":s._wrapperState={wasMultiple:!!n.multiple},r=o({},n,{value:void 0}),Sn("invalid",s),Wn(f,"onChange");break;case"textarea":ze(s,n),r=Ae(s,n),Sn("invalid",s),Wn(f,"onChange");break;default:r=n}$n(d,r),c=void 0,u=d;var m=s,v=r;for(c in v)if(v.hasOwnProperty(c)){var b=v[c];"style"===c?Fn(m,b):"dangerouslySetInnerHTML"===c?null!=(b=b?b.__html:void 0)&&We(m,b):"children"===c?"string"===typeof b?("textarea"!==u||""!==b)&&Ve(m,b):"number"===typeof b&&Ve(m,""+b):"suppressContentEditableWarning"!==c&&"suppressHydrationWarning"!==c&&"autoFocus"!==c&&(p.hasOwnProperty(c)?null!=b&&Wn(f,c):null!=b&&ke(m,c,b,h))}switch(d){case"input":Oe(s),Re(s,n,!1);break;case"textarea":Oe(s),Le(s);break;case"option":null!=n.value&&s.setAttribute("value",""+we(n.value));break;case"select":(r=s).multiple=!!n.multiple,null!=(s=n.value)?_e(r,!!n.multiple,s,!1):null!=n.defaultValue&&_e(r,!!n.multiple,n.defaultValue,!0);break;default:"function"===typeof r.onClick&&(s.onclick=Vn)}(a=Jn(l,a))&&il(t)}null!==t.ref&&(t.effectTag|=128)}else if(null===t.stateNode)throw Error(i(166));break;case 6:if(n&&null!=t.stateNode)Zi(0,t,n.memoizedProps,a);else{if("string"!==typeof a&&null===t.stateNode)throw Error(i(166));r=Fa(Da.current),Fa(Ia.current),Di(t)?(l=(a=t).stateNode,r=a.memoizedProps,l[ar]=a,(a=l.nodeValue!==r)&&il(t)):(l=t,(a=(9===r.nodeType?r:r.ownerDocument).createTextNode(a))[ar]=l,t.stateNode=a)}break;case 11:break;case 13:if(co(Va),a=t.memoizedState,0!==(64&t.effectTag)){t.expirationTime=r;break e}a=null!==a,l=!1,null===n?void 0!==t.memoizedProps.fallback&&Di(t):(l=null!==(r=n.memoizedState),a||null===r||null!==(r=n.child.sibling)&&(null!==(s=t.firstEffect)?(t.firstEffect=r,r.nextEffect=s):(t.firstEffect=t.lastEffect=r,r.nextEffect=null),r.effectTag=8)),a&&!l&&0!==(2&t.mode)&&(null===n&&!0!==t.memoizedProps.unstable_avoidThisFallback||0!==(1&Va.current)?0===_l&&(_l=3):(0!==_l&&3!==_l||(_l=4),0!==Dl&&null!==Rl&&(Fu(Rl,Ml),Uu(Rl,Dl)))),(a||l)&&(t.effectTag|=4);break;case 7:case 8:case 12:break;case 4:$a();break;case 10:aa(t);break;case 9:case 14:break;case 17:bo(t.type)&&yo();break;case 19:if(co(Va),null===(a=t.memoizedState))break;if(l=0!==(64&t.effectTag),null===(s=a.rendering)){if(l)ll(a,!1);else if(0!==_l||null!==n&&0!==(64&n.effectTag))for(n=t.child;null!==n;){if(null!==(s=Ha(n))){for(t.effectTag|=64,ll(a,!1),null!==(l=s.updateQueue)&&(t.updateQueue=l,t.effectTag|=4),null===a.lastEffect&&(t.firstEffect=null),t.lastEffect=a.lastEffect,a=r,l=t.child;null!==l;)n=a,(r=l).effectTag&=2,r.nextEffect=null,r.firstEffect=null,r.lastEffect=null,null===(s=r.alternate)?(r.childExpirationTime=0,r.expirationTime=n,r.child=null,r.memoizedProps=null,r.memoizedState=null,r.updateQueue=null,r.dependencies=null):(r.childExpirationTime=s.childExpirationTime,r.expirationTime=s.expirationTime,r.child=s.child,r.memoizedProps=s.memoizedProps,r.memoizedState=s.memoizedState,r.updateQueue=s.updateQueue,n=s.dependencies,r.dependencies=null===n?null:{expirationTime:n.expirationTime,firstContext:n.firstContext,responders:n.responders}),l=l.sibling;so(Va,1&Va.current|2),t=t.child;break e}n=n.sibling}}else{if(!l)if(null!==(n=Ha(s))){if(t.effectTag|=64,l=!0,null!==(r=n.updateQueue)&&(t.updateQueue=r,t.effectTag|=4),ll(a,!0),null===a.tail&&"hidden"===a.tailMode&&!s.alternate){null!==(t=t.lastEffect=a.lastEffect)&&(t.nextEffect=null);break}}else Bo()>a.tailExpiration&&1<r&&(t.effectTag|=64,l=!0,ll(a,!1),t.expirationTime=t.childExpirationTime=r-1);a.isBackwards?(s.sibling=t.child,t.child=s):(null!==(r=a.last)?r.sibling=s:t.child=s,a.last=s)}if(null!==a.tail){0===a.tailExpiration&&(a.tailExpiration=Bo()+500),r=a.tail,a.rendering=r,a.tail=r.sibling,a.lastEffect=t.lastEffect,r.sibling=null,a=Va.current,so(Va,a=l?1&a|2:1&a),t=r;break e}break;case 20:case 21:break;default:throw Error(i(156,t.tag))}t=null}if(a=Nl,1===Ml||1!==a.childExpirationTime){for(l=0,r=a.child;null!==r;)(n=r.expirationTime)>l&&(l=n),(s=r.childExpirationTime)>l&&(l=s),r=r.sibling;a.childExpirationTime=l}if(null!==t)return t;null!==e&&0===(2048&e.effectTag)&&(null===e.firstEffect&&(e.firstEffect=Nl.firstEffect),null!==Nl.lastEffect&&(null!==e.lastEffect&&(e.lastEffect.nextEffect=Nl.firstEffect),e.lastEffect=Nl.lastEffect),1<Nl.effectTag&&(null!==e.lastEffect?e.lastEffect.nextEffect=Nl:e.firstEffect=Nl,e.lastEffect=Nl))}else{if(null!==(t=ul(Nl)))return t.effectTag&=2047,t;null!==e&&(e.firstEffect=e.lastEffect=null,e.effectTag|=2048)}if(null!==(t=Nl.sibling))return t;Nl=e}while(null!==Nl);return 0===_l&&(_l=5),null}function bu(e){var t=e.expirationTime;return t>(e=e.childExpirationTime)?t:e}function yu(e){var t=Wo();return Ho(99,gu.bind(null,e,t)),null}function gu(e,t){do{wu()}while(null!==ql);if(0!==(48&Pl))throw Error(i(327));var n=e.finishedWork,r=e.finishedExpirationTime;if(null===n)return null;if(e.finishedWork=null,e.finishedExpirationTime=0,n===e.current)throw Error(i(177));e.callbackNode=null,e.callbackExpirationTime=0,e.callbackPriority=90,e.nextKnownPendingLevel=0;var o=bu(n);if(e.firstPendingTime=o,r<=e.lastSuspendedTime?e.firstSuspendedTime=e.lastSuspendedTime=e.nextKnownPendingLevel=0:r<=e.firstSuspendedTime&&(e.firstSuspendedTime=r-1),r<=e.lastPingedTime&&(e.lastPingedTime=0),r<=e.lastExpiredTime&&(e.lastExpiredTime=0),e===Rl&&(Nl=Rl=null,Ml=0),1<n.effectTag?null!==n.lastEffect?(n.lastEffect.nextEffect=n,o=n.firstEffect):o=n:o=n.firstEffect,null!==o){var a=Pl;Pl|=32,jl.current=null,Gn=On;var l=Qn();if(Xn(l)){if("selectionStart"in l)var u={start:l.selectionStart,end:l.selectionEnd};else e:{var c=(u=(u=l.ownerDocument)&&u.defaultView||window).getSelection&&u.getSelection();if(c&&0!==c.rangeCount){u=c.anchorNode;var s=c.anchorOffset,d=c.focusNode;c=c.focusOffset;try{u.nodeType,d.nodeType}catch(z){u=null;break e}var f=0,p=-1,h=-1,m=0,v=0,b=l,y=null;t:for(;;){for(var g;b!==u||0!==s&&3!==b.nodeType||(p=f+s),b!==d||0!==c&&3!==b.nodeType||(h=f+c),3===b.nodeType&&(f+=b.nodeValue.length),null!==(g=b.firstChild);)y=b,b=g;for(;;){if(b===l)break t;if(y===u&&++m===s&&(p=f),y===d&&++v===c&&(h=f),null!==(g=b.nextSibling))break;y=(b=y).parentNode}b=g}u=-1===p||-1===h?null:{start:p,end:h}}else u=null}u=u||{start:0,end:0}}else u=null;Yn={focusedElem:l,selectionRange:u},On=!1,$l=o;do{try{xu()}catch(z){if(null===$l)throw Error(i(330));Ou($l,z),$l=$l.nextEffect}}while(null!==$l);$l=o;do{try{for(l=e,u=t;null!==$l;){var x=$l.effectTag;if(16&x&&Ve($l.stateNode,""),128&x){var w=$l.alternate;if(null!==w){var k=w.ref;null!==k&&("function"===typeof k?k(null):k.current=null)}}switch(1038&x){case 2:yl($l),$l.effectTag&=-3;break;case 6:yl($l),$l.effectTag&=-3,xl($l.alternate,$l);break;case 1024:$l.effectTag&=-1025;break;case 1028:$l.effectTag&=-1025,xl($l.alternate,$l);break;case 4:xl($l.alternate,$l);break;case 8:gl(l,s=$l,u),vl(s)}$l=$l.nextEffect}}catch(z){if(null===$l)throw Error(i(330));Ou($l,z),$l=$l.nextEffect}}while(null!==$l);if(k=Yn,w=Qn(),x=k.focusedElem,u=k.selectionRange,w!==x&&x&&x.ownerDocument&&function e(t,n){return!(!t||!n)&&(t===n||(!t||3!==t.nodeType)&&(n&&3===n.nodeType?e(t,n.parentNode):"contains"in t?t.contains(n):!!t.compareDocumentPosition&&!!(16&t.compareDocumentPosition(n))))}(x.ownerDocument.documentElement,x)){null!==u&&Xn(x)&&(w=u.start,void 0===(k=u.end)&&(k=w),"selectionStart"in x?(x.selectionStart=w,x.selectionEnd=Math.min(k,x.value.length)):(k=(w=x.ownerDocument||document)&&w.defaultView||window).getSelection&&(k=k.getSelection(),s=x.textContent.length,l=Math.min(u.start,s),u=void 0===u.end?l:Math.min(u.end,s),!k.extend&&l>u&&(s=u,u=l,l=s),s=Kn(x,l),d=Kn(x,u),s&&d&&(1!==k.rangeCount||k.anchorNode!==s.node||k.anchorOffset!==s.offset||k.focusNode!==d.node||k.focusOffset!==d.offset)&&((w=w.createRange()).setStart(s.node,s.offset),k.removeAllRanges(),l>u?(k.addRange(w),k.extend(d.node,d.offset)):(w.setEnd(d.node,d.offset),k.addRange(w))))),w=[];for(k=x;k=k.parentNode;)1===k.nodeType&&w.push({element:k,left:k.scrollLeft,top:k.scrollTop});for("function"===typeof x.focus&&x.focus(),x=0;x<w.length;x++)(k=w[x]).element.scrollLeft=k.left,k.element.scrollTop=k.top}Yn=null,On=!!Gn,Gn=null,e.current=n,$l=o;do{try{for(x=r;null!==$l;){var E=$l.effectTag;if(36&E){var O=$l.alternate;switch(k=x,(w=$l).tag){case 0:case 11:case 15:hl(16,32,w);break;case 1:var S=w.stateNode;if(4&w.effectTag)if(null===O)S.componentDidMount();else{var C=w.elementType===w.type?O.memoizedProps:Jo(w.type,O.memoizedProps);S.componentDidUpdate(C,O.memoizedState,S.__reactInternalSnapshotBeforeUpdate)}var T=w.updateQueue;null!==T&&ga(0,T,S);break;case 3:var j=w.updateQueue;if(null!==j){if(l=null,null!==w.child)switch(w.child.tag){case 5:l=w.child.stateNode;break;case 1:l=w.child.stateNode}ga(0,j,l)}break;case 5:var P=w.stateNode;null===O&&4&w.effectTag&&Jn(w.type,w.memoizedProps)&&P.focus();break;case 6:case 4:case 12:break;case 13:if(null===w.memoizedState){var R=w.alternate;if(null!==R){var N=R.memoizedState;if(null!==N){var M=N.dehydrated;null!==M&&Ct(M)}}}break;case 19:case 17:case 20:case 21:break;default:throw Error(i(163))}}if(128&E){w=void 0;var _=$l.ref;if(null!==_){var A=$l.stateNode;switch($l.tag){case 5:w=A;break;default:w=A}"function"===typeof _?_(w):_.current=w}}$l=$l.nextEffect}}catch(z){if(null===$l)throw Error(i(330));Ou($l,z),$l=$l.nextEffect}}while(null!==$l);$l=null,Lo(),Pl=a}else e.current=n;if(Hl)Hl=!1,ql=e,Kl=t;else for($l=o;null!==$l;)t=$l.nextEffect,$l.nextEffect=null,$l=t;if(0===(t=e.firstPendingTime)&&(Vl=null),1073741823===t?e===Gl?Xl++:(Xl=0,Gl=e):Xl=0,"function"===typeof Tu&&Tu(n.stateNode,r),ru(e),Bl)throw Bl=!1,e=Wl,Wl=null,e;return 0!==(8&Pl)?null:(Qo(),null)}function xu(){for(;null!==$l;){var e=$l.effectTag;0!==(256&e)&&pl($l.alternate,$l),0===(512&e)||Hl||(Hl=!0,qo(97,(function(){return wu(),null}))),$l=$l.nextEffect}}function wu(){if(90!==Kl){var e=97<Kl?97:Kl;return Kl=90,Ho(e,ku)}}function ku(){if(null===ql)return!1;var e=ql;if(ql=null,0!==(48&Pl))throw Error(i(331));var t=Pl;for(Pl|=32,e=e.current.firstEffect;null!==e;){try{var n=e;if(0!==(512&n.effectTag))switch(n.tag){case 0:case 11:case 15:hl(128,0,n),hl(0,64,n)}}catch(r){if(null===e)throw Error(i(330));Ou(e,r)}n=e.nextEffect,e.nextEffect=null,e=n}return Pl=t,Qo(),!0}function Eu(e,t,n){ha(e,t=El(e,t=cl(n,t),1073741823)),null!==(e=tu(e,1073741823))&&ru(e)}function Ou(e,t){if(3===e.tag)Eu(e,e,t);else for(var n=e.return;null!==n;){if(3===n.tag){Eu(n,e,t);break}if(1===n.tag){var r=n.stateNode;if("function"===typeof n.type.getDerivedStateFromError||"function"===typeof r.componentDidCatch&&(null===Vl||!Vl.has(r))){ha(n,e=Ol(n,e=cl(t,e),1073741823)),null!==(n=tu(n,1073741823))&&ru(n);break}}n=n.return}}function Su(e,t,n){var r=e.pingCache;null!==r&&r.delete(t),Rl===e&&Ml===n?4===_l||3===_l&&1073741823===zl&&Bo()-Ul<500?uu(e,Ml):Fl=!0:Du(e,n)&&(0!==(t=e.lastPingedTime)&&t<n||(e.lastPingedTime=n,e.finishedExpirationTime===n&&(e.finishedExpirationTime=0,e.finishedWork=null),ru(e)))}function Cu(e,t){var n=e.stateNode;null!==n&&n.delete(t),0===(t=0)&&(t=Zl(t=Jl(),e,null)),null!==(e=tu(e,t))&&ru(e)}Sl=function(e,t,n){var r=t.expirationTime;if(null!==e){var o=t.pendingProps;if(e.memoizedProps!==o||ho.current)$i=!0;else{if(r<n){switch($i=!1,t.tag){case 3:Gi(t),Fi();break;case 5:if(Ba(t),4&t.mode&&1!==n&&o.hidden)return t.expirationTime=t.childExpirationTime=1,null;break;case 1:bo(t.type)&&ko(t);break;case 4:Ua(t,t.stateNode.containerInfo);break;case 10:oa(t,t.memoizedProps.value);break;case 13:if(null!==t.memoizedState)return 0!==(r=t.child.childExpirationTime)&&r>=n?tl(e,t,n):(so(Va,1&Va.current),null!==(t=al(e,t,n))?t.sibling:null);so(Va,1&Va.current);break;case 19:if(r=t.childExpirationTime>=n,0!==(64&e.effectTag)){if(r)return ol(e,t,n);t.effectTag|=64}if(null!==(o=t.memoizedState)&&(o.rendering=null,o.tail=null),so(Va,Va.current),!r)return null}return al(e,t,n)}$i=!1}}else $i=!1;switch(t.expirationTime=0,t.tag){case 2:if(r=t.type,null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),e=t.pendingProps,o=vo(t,po.current),la(t,n),o=si(null,t,r,e,o,n),t.effectTag|=1,"object"===typeof o&&null!==o&&"function"===typeof o.render&&void 0===o.$$typeof){if(t.tag=1,di(),bo(r)){var a=!0;ko(t)}else a=!1;t.memoizedState=null!==o.state&&void 0!==o.state?o.state:null;var l=r.getDerivedStateFromProps;"function"===typeof l&&Ea(t,r,l,e),o.updater=Oa,t.stateNode=o,o._reactInternalFiber=t,ja(t,r,e,n),t=Xi(null,t,r,!0,a,n)}else t.tag=0,Bi(null,t,o,n),t=t.child;return t;case 16:if(o=t.elementType,null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),e=t.pendingProps,function(e){if(-1===e._status){e._status=0;var t=e._ctor;t=t(),e._result=t,t.then((function(t){0===e._status&&(t=t.default,e._status=1,e._result=t)}),(function(t){0===e._status&&(e._status=2,e._result=t)}))}}(o),1!==o._status)throw o._result;switch(o=o._result,t.type=o,a=t.tag=function(e){if("function"===typeof e)return Nu(e)?1:0;if(void 0!==e&&null!==e){if((e=e.$$typeof)===V)return 11;if(e===K)return 14}return 2}(o),e=Jo(o,e),a){case 0:t=Ki(null,t,o,e,n);break;case 1:t=Qi(null,t,o,e,n);break;case 11:t=Wi(null,t,o,e,n);break;case 14:t=Vi(null,t,o,Jo(o.type,e),r,n);break;default:throw Error(i(306,o,""))}return t;case 0:return r=t.type,o=t.pendingProps,Ki(e,t,r,o=t.elementType===r?o:Jo(r,o),n);case 1:return r=t.type,o=t.pendingProps,Qi(e,t,r,o=t.elementType===r?o:Jo(r,o),n);case 3:if(Gi(t),null===(r=t.updateQueue))throw Error(i(282));if(o=null!==(o=t.memoizedState)?o.element:null,ya(t,r,t.pendingProps,null,n),(r=t.memoizedState.element)===o)Fi(),t=al(e,t,n);else{if((o=t.stateNode.hydrate)&&(Mi=nr(t.stateNode.containerInfo.firstChild),Ni=t,o=_i=!0),o)for(n=Aa(t,null,r,n),t.child=n;n;)n.effectTag=-3&n.effectTag|1024,n=n.sibling;else Bi(e,t,r,n),Fi();t=t.child}return t;case 5:return Ba(t),null===e&&Ii(t),r=t.type,o=t.pendingProps,a=null!==e?e.memoizedProps:null,l=o.children,Zn(r,o)?l=null:null!==a&&Zn(r,a)&&(t.effectTag|=16),qi(e,t),4&t.mode&&1!==n&&o.hidden?(t.expirationTime=t.childExpirationTime=1,t=null):(Bi(e,t,l,n),t=t.child),t;case 6:return null===e&&Ii(t),null;case 13:return tl(e,t,n);case 4:return Ua(t,t.stateNode.containerInfo),r=t.pendingProps,null===e?t.child=_a(t,null,r,n):Bi(e,t,r,n),t.child;case 11:return r=t.type,o=t.pendingProps,Wi(e,t,r,o=t.elementType===r?o:Jo(r,o),n);case 7:return Bi(e,t,t.pendingProps,n),t.child;case 8:case 12:return Bi(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,o=t.pendingProps,l=t.memoizedProps,oa(t,a=o.value),null!==l){var u=l.value;if(0===(a=Gr(u,a)?0:0|("function"===typeof r._calculateChangedBits?r._calculateChangedBits(u,a):1073741823))){if(l.children===o.children&&!ho.current){t=al(e,t,n);break e}}else for(null!==(u=t.child)&&(u.return=t);null!==u;){var c=u.dependencies;if(null!==c){l=u.child;for(var s=c.firstContext;null!==s;){if(s.context===r&&0!==(s.observedBits&a)){1===u.tag&&((s=fa(n,null)).tag=2,ha(u,s)),u.expirationTime<n&&(u.expirationTime=n),null!==(s=u.alternate)&&s.expirationTime<n&&(s.expirationTime=n),ia(u.return,n),c.expirationTime<n&&(c.expirationTime=n);break}s=s.next}}else l=10===u.tag&&u.type===t.type?null:u.child;if(null!==l)l.return=u;else for(l=u;null!==l;){if(l===t){l=null;break}if(null!==(u=l.sibling)){u.return=l.return,l=u;break}l=l.return}u=l}}Bi(e,t,o.children,n),t=t.child}return t;case 9:return o=t.type,r=(a=t.pendingProps).children,la(t,n),r=r(o=ua(o,a.unstable_observedBits)),t.effectTag|=1,Bi(e,t,r,n),t.child;case 14:return a=Jo(o=t.type,t.pendingProps),Vi(e,t,o,a=Jo(o.type,a),r,n);case 15:return Hi(e,t,t.type,t.pendingProps,r,n);case 17:return r=t.type,o=t.pendingProps,o=t.elementType===r?o:Jo(r,o),null!==e&&(e.alternate=null,t.alternate=null,t.effectTag|=2),t.tag=1,bo(r)?(e=!0,ko(t)):e=!1,la(t,n),Ca(t,r,o),ja(t,r,o,n),Xi(null,t,r,!0,e,n);case 19:return ol(e,t,n)}throw Error(i(156,t.tag))};var Tu=null,ju=null;function Pu(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.effectTag=0,this.lastEffect=this.firstEffect=this.nextEffect=null,this.childExpirationTime=this.expirationTime=0,this.alternate=null}function Ru(e,t,n,r){return new Pu(e,t,n,r)}function Nu(e){return!(!(e=e.prototype)||!e.isReactComponent)}function Mu(e,t){var n=e.alternate;return null===n?((n=Ru(e.tag,t,e.key,e.mode)).elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.effectTag=0,n.nextEffect=null,n.firstEffect=null,n.lastEffect=null),n.childExpirationTime=e.childExpirationTime,n.expirationTime=e.expirationTime,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=null===t?null:{expirationTime:t.expirationTime,firstContext:t.firstContext,responders:t.responders},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function _u(e,t,n,r,o,a){var l=2;if(r=e,"function"===typeof e)Nu(e)&&(l=1);else if("string"===typeof e)l=5;else e:switch(e){case D:return Au(n.children,o,a,t);case W:l=8,o|=7;break;case F:l=8,o|=1;break;case U:return(e=Ru(12,n,t,8|o)).elementType=U,e.type=U,e.expirationTime=a,e;case H:return(e=Ru(13,n,t,o)).type=H,e.elementType=H,e.expirationTime=a,e;case q:return(e=Ru(19,n,t,o)).elementType=q,e.expirationTime=a,e;default:if("object"===typeof e&&null!==e)switch(e.$$typeof){case $:l=10;break e;case B:l=9;break e;case V:l=11;break e;case K:l=14;break e;case Q:l=16,r=null;break e}throw Error(i(130,null==e?e:typeof e,""))}return(t=Ru(l,n,t,o)).elementType=e,t.type=r,t.expirationTime=a,t}function Au(e,t,n,r){return(e=Ru(7,e,r,t)).expirationTime=n,e}function zu(e,t,n){return(e=Ru(6,e,null,t)).expirationTime=n,e}function Iu(e,t,n){return(t=Ru(4,null!==e.children?e.children:[],e.key,t)).expirationTime=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function Lu(e,t,n){this.tag=t,this.current=null,this.containerInfo=e,this.pingCache=this.pendingChildren=null,this.finishedExpirationTime=0,this.finishedWork=null,this.timeoutHandle=-1,this.pendingContext=this.context=null,this.hydrate=n,this.callbackNode=null,this.callbackPriority=90,this.lastExpiredTime=this.lastPingedTime=this.nextKnownPendingLevel=this.lastSuspendedTime=this.firstSuspendedTime=this.firstPendingTime=0}function Du(e,t){var n=e.firstSuspendedTime;return e=e.lastSuspendedTime,0!==n&&n>=t&&e<=t}function Fu(e,t){var n=e.firstSuspendedTime,r=e.lastSuspendedTime;n<t&&(e.firstSuspendedTime=t),(r>t||0===n)&&(e.lastSuspendedTime=t),t<=e.lastPingedTime&&(e.lastPingedTime=0),t<=e.lastExpiredTime&&(e.lastExpiredTime=0)}function Uu(e,t){t>e.firstPendingTime&&(e.firstPendingTime=t);var n=e.firstSuspendedTime;0!==n&&(t>=n?e.firstSuspendedTime=e.lastSuspendedTime=e.nextKnownPendingLevel=0:t>=e.lastSuspendedTime&&(e.lastSuspendedTime=t+1),t>e.nextKnownPendingLevel&&(e.nextKnownPendingLevel=t))}function $u(e,t){var n=e.lastExpiredTime;(0===n||n>t)&&(e.lastExpiredTime=t)}function Bu(e,t,n,r){var o=t.current,a=Jl(),l=wa.suspense;a=Zl(a,o,l);e:if(n){t:{if(tt(n=n._reactInternalFiber)!==n||1!==n.tag)throw Error(i(170));var u=n;do{switch(u.tag){case 3:u=u.stateNode.context;break t;case 1:if(bo(u.type)){u=u.stateNode.__reactInternalMemoizedMergedChildContext;break t}}u=u.return}while(null!==u);throw Error(i(171))}if(1===n.tag){var c=n.type;if(bo(c)){n=wo(n,c,u);break e}}n=u}else n=fo;return null===t.context?t.context=n:t.pendingContext=n,(t=fa(a,l)).payload={element:e},null!==(r=void 0===r?null:r)&&(t.callback=r),ha(o,t),eu(o,a),a}function Wu(e){if(!(e=e.current).child)return null;switch(e.child.tag){case 5:default:return e.child.stateNode}}function Vu(e,t){null!==(e=e.memoizedState)&&null!==e.dehydrated&&e.retryTime<t&&(e.retryTime=t)}function Hu(e,t){Vu(e,t),(e=e.alternate)&&Vu(e,t)}function qu(e,t,n){var r=new Lu(e,t,n=null!=n&&!0===n.hydrate),o=Ru(3,null,null,2===t?7:1===t?3:0);r.current=o,o.stateNode=r,e[lr]=r.current,n&&0!==t&&function(e){var t=An(e);vt.forEach((function(n){zn(n,e,t)})),bt.forEach((function(n){zn(n,e,t)}))}(9===e.nodeType?e:e.ownerDocument),this._internalRoot=r}function Ku(e){return!(!e||1!==e.nodeType&&9!==e.nodeType&&11!==e.nodeType&&(8!==e.nodeType||" react-mount-point-unstable "!==e.nodeValue))}function Qu(e,t,n,r,o){var a=n._reactRootContainer;if(a){var i=a._internalRoot;if("function"===typeof o){var l=o;o=function(){var e=Wu(i);l.call(e)}}Bu(t,i,e,o)}else{if(a=n._reactRootContainer=function(e,t){if(t||(t=!(!(t=e?9===e.nodeType?e.documentElement:e.firstChild:null)||1!==t.nodeType||!t.hasAttribute("data-reactroot"))),!t)for(var n;n=e.lastChild;)e.removeChild(n);return new qu(e,0,t?{hydrate:!0}:void 0)}(n,r),i=a._internalRoot,"function"===typeof o){var u=o;o=function(){var e=Wu(i);u.call(e)}}lu((function(){Bu(t,i,e,o)}))}return Wu(i)}function Xu(e,t,n){var r=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:L,key:null==r?null:""+r,children:e,containerInfo:t,implementation:n}}function Gu(e,t){var n=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!Ku(t))throw Error(i(200));return Xu(e,t,null,n)}qu.prototype.render=function(e,t){Bu(e,this._internalRoot,null,void 0===t?null:t)},qu.prototype.unmount=function(e){var t=this._internalRoot,n=void 0===e?null:e,r=t.containerInfo;Bu(null,t,null,(function(){r[lr]=null,null!==n&&n()}))},at=function(e){if(13===e.tag){var t=Yo(Jl(),150,100);eu(e,t),Hu(e,t)}},it=function(e){if(13===e.tag){Jl();var t=Go++;eu(e,t),Hu(e,t)}},lt=function(e){if(13===e.tag){var t=Jl();eu(e,t=Zl(t,e,null)),Hu(e,t)}},ee=function(e,t,n){switch(t){case"input":if(Pe(e,n),t=n.name,"radio"===n.type&&null!=t){for(n=e;n.parentNode;)n=n.parentNode;for(n=n.querySelectorAll("input[name="+JSON.stringify(""+t)+'][type="radio"]'),t=0;t<n.length;t++){var r=n[t];if(r!==e&&r.form===e.form){var o=dr(r);if(!o)throw Error(i(90));Se(r),Pe(r,o)}}}break;case"textarea":Ie(e,n);break;case"select":null!=(t=n.value)&&_e(e,!!n.multiple,t,!1)}},ie=iu,le=function(e,t,n,r){var o=Pl;Pl|=4;try{return Ho(98,e.bind(null,t,n,r))}finally{0===(Pl=o)&&Qo()}},ue=function(){0===(49&Pl)&&(function(){if(null!==Ql){var e=Ql;Ql=null,e.forEach((function(e,t){$u(t,e),ru(t)})),Qo()}}(),wu())},ce=function(e,t){var n=Pl;Pl|=2;try{return e(t)}finally{0===(Pl=n)&&Qo()}};var Yu={createPortal:Gu,findDOMNode:function(e){if(null==e)return null;if(1===e.nodeType)return e;var t=e._reactInternalFiber;if(void 0===t){if("function"===typeof e.render)throw Error(i(188));throw Error(i(268,Object.keys(e)))}return e=null===(e=ot(t))?null:e.stateNode},hydrate:function(e,t,n){if(!Ku(t))throw Error(i(200));return Qu(null,e,t,!0,n)},render:function(e,t,n){if(!Ku(t))throw Error(i(200));return Qu(null,e,t,!1,n)},unstable_renderSubtreeIntoContainer:function(e,t,n,r){if(!Ku(n))throw Error(i(200));if(null==e||void 0===e._reactInternalFiber)throw Error(i(38));return Qu(e,t,n,!1,r)},unmountComponentAtNode:function(e){if(!Ku(e))throw Error(i(40));return!!e._reactRootContainer&&(lu((function(){Qu(null,null,e,!1,(function(){e._reactRootContainer=null,e[lr]=null}))})),!0)},unstable_createPortal:function(){return Gu.apply(void 0,arguments)},unstable_batchedUpdates:iu,flushSync:function(e,t){if(0!==(48&Pl))throw Error(i(187));var n=Pl;Pl|=1;try{return Ho(99,e.bind(null,t))}finally{Pl=n,Qo()}},__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{Events:[cr,sr,dr,N.injectEventPluginsByName,f,_t,function(e){T(e,Mt)},oe,ae,Rn,R,wu,{current:!1}]}};!function(e){var t=e.findFiberByHostInstance;(function(e){if("undefined"===typeof __REACT_DEVTOOLS_GLOBAL_HOOK__)return!1;var t=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(t.isDisabled||!t.supportsFiber)return!0;try{var n=t.inject(e);Tu=function(e){try{t.onCommitFiberRoot(n,e,void 0,64===(64&e.current.effectTag))}catch(r){}},ju=function(e){try{t.onCommitFiberUnmount(n,e)}catch(r){}}}catch(r){}})(o({},e,{overrideHookState:null,overrideProps:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:_.ReactCurrentDispatcher,findHostInstanceByFiber:function(e){return null===(e=ot(e))?null:e.stateNode},findFiberByHostInstance:function(e){return t?t(e):null},findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null}))}({findFiberByHostInstance:ur,bundleType:0,version:"16.12.0",rendererPackageName:"react-dom"});var Ju={default:Yu},Zu=Ju&&Yu||Ju;e.exports=Zu.default||Zu},function(e,t,n){"use strict";e.exports=n(105)},function(e,t,n){"use strict";var r,o,a,i,l;if(Object.defineProperty(t,"__esModule",{value:!0}),"undefined"===typeof window||"function"!==typeof MessageChannel){var u=null,c=null,s=function e(){if(null!==u)try{var n=t.unstable_now();u(!0,n),u=null}catch(r){throw setTimeout(e,0),r}},d=Date.now();t.unstable_now=function(){return Date.now()-d},r=function(e){null!==u?setTimeout(r,0,e):(u=e,setTimeout(s,0))},o=function(e,t){c=setTimeout(e,t)},a=function(){clearTimeout(c)},i=function(){return!1},l=t.unstable_forceFrameRate=function(){}}else{var f=window.performance,p=window.Date,h=window.setTimeout,m=window.clearTimeout;if("undefined"!==typeof console){var v=window.cancelAnimationFrame;"function"!==typeof window.requestAnimationFrame&&console.error("This browser doesn't support requestAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills"),"function"!==typeof v&&console.error("This browser doesn't support cancelAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills")}if("object"===typeof f&&"function"===typeof f.now)t.unstable_now=function(){return f.now()};else{var b=p.now();t.unstable_now=function(){return p.now()-b}}var y=!1,g=null,x=-1,w=5,k=0;i=function(){return t.unstable_now()>=k},l=function(){},t.unstable_forceFrameRate=function(e){0>e||125<e?console.error("forceFrameRate takes a positive int between 0 and 125, forcing framerates higher than 125 fps is not unsupported"):w=0<e?Math.floor(1e3/e):5};var E=new MessageChannel,O=E.port2;E.port1.onmessage=function(){if(null!==g){var e=t.unstable_now();k=e+w;try{g(!0,e)?O.postMessage(null):(y=!1,g=null)}catch(n){throw O.postMessage(null),n}}else y=!1},r=function(e){g=e,y||(y=!0,O.postMessage(null))},o=function(e,n){x=h((function(){e(t.unstable_now())}),n)},a=function(){m(x),x=-1}}function S(e,t){var n=e.length;e.push(t);e:for(;;){var r=Math.floor((n-1)/2),o=e[r];if(!(void 0!==o&&0<j(o,t)))break e;e[r]=t,e[n]=o,n=r}}function C(e){return void 0===(e=e[0])?null:e}function T(e){var t=e[0];if(void 0!==t){var n=e.pop();if(n!==t){e[0]=n;e:for(var r=0,o=e.length;r<o;){var a=2*(r+1)-1,i=e[a],l=a+1,u=e[l];if(void 0!==i&&0>j(i,n))void 0!==u&&0>j(u,i)?(e[r]=u,e[l]=n,r=l):(e[r]=i,e[a]=n,r=a);else{if(!(void 0!==u&&0>j(u,n)))break e;e[r]=u,e[l]=n,r=l}}}return t}return null}function j(e,t){var n=e.sortIndex-t.sortIndex;return 0!==n?n:e.id-t.id}var P=[],R=[],N=1,M=null,_=3,A=!1,z=!1,I=!1;function L(e){for(var t=C(R);null!==t;){if(null===t.callback)T(R);else{if(!(t.startTime<=e))break;T(R),t.sortIndex=t.expirationTime,S(P,t)}t=C(R)}}function D(e){if(I=!1,L(e),!z)if(null!==C(P))z=!0,r(F);else{var t=C(R);null!==t&&o(D,t.startTime-e)}}function F(e,n){z=!1,I&&(I=!1,a()),A=!0;var r=_;try{for(L(n),M=C(P);null!==M&&(!(M.expirationTime>n)||e&&!i());){var l=M.callback;if(null!==l){M.callback=null,_=M.priorityLevel;var u=l(M.expirationTime<=n);n=t.unstable_now(),"function"===typeof u?M.callback=u:M===C(P)&&T(P),L(n)}else T(P);M=C(P)}if(null!==M)var c=!0;else{var s=C(R);null!==s&&o(D,s.startTime-n),c=!1}return c}finally{M=null,_=r,A=!1}}function U(e){switch(e){case 1:return-1;case 2:return 250;case 5:return 1073741823;case 4:return 1e4;default:return 5e3}}var $=l;t.unstable_ImmediatePriority=1,t.unstable_UserBlockingPriority=2,t.unstable_NormalPriority=3,t.unstable_IdlePriority=5,t.unstable_LowPriority=4,t.unstable_runWithPriority=function(e,t){switch(e){case 1:case 2:case 3:case 4:case 5:break;default:e=3}var n=_;_=e;try{return t()}finally{_=n}},t.unstable_next=function(e){switch(_){case 1:case 2:case 3:var t=3;break;default:t=_}var n=_;_=t;try{return e()}finally{_=n}},t.unstable_scheduleCallback=function(e,n,i){var l=t.unstable_now();if("object"===typeof i&&null!==i){var u=i.delay;u="number"===typeof u&&0<u?l+u:l,i="number"===typeof i.timeout?i.timeout:U(e)}else i=U(e),u=l;return e={id:N++,callback:n,priorityLevel:e,startTime:u,expirationTime:i=u+i,sortIndex:-1},u>l?(e.sortIndex=u,S(R,e),null===C(P)&&e===C(R)&&(I?a():I=!0,o(D,u-l))):(e.sortIndex=i,S(P,e),z||A||(z=!0,r(F))),e},t.unstable_cancelCallback=function(e){e.callback=null},t.unstable_wrapCallback=function(e){var t=_;return function(){var n=_;_=t;try{return e.apply(this,arguments)}finally{_=n}}},t.unstable_getCurrentPriorityLevel=function(){return _},t.unstable_shouldYield=function(){var e=t.unstable_now();L(e);var n=C(P);return n!==M&&null!==M&&null!==n&&null!==n.callback&&n.startTime<=e&&n.expirationTime<M.expirationTime||i()},t.unstable_requestPaint=$,t.unstable_continueExecution=function(){z||A||(z=!0,r(F))},t.unstable_pauseExecution=function(){},t.unstable_getFirstCallbackNode=function(){return C(P)},t.unstable_Profiling=null},,function(e,t,n){"use strict";var r=n(21),o=n(74),a=n(108),i=n(80);function l(e){var t=new a(e),n=o(a.prototype.request,t);return r.extend(n,a.prototype,t),r.extend(n,t),n}var u=l(n(77));u.Axios=a,u.create=function(e){return l(i(u.defaults,e))},u.Cancel=n(81),u.CancelToken=n(122),u.isCancel=n(76),u.all=function(e){return Promise.all(e)},u.spread=n(123),e.exports=u,e.exports.default=u},function(e,t,n){"use strict";var r=n(21),o=n(75),a=n(109),i=n(110),l=n(80);function u(e){this.defaults=e,this.interceptors={request:new a,response:new a}}u.prototype.request=function(e){"string"===typeof e?(e=arguments[1]||{}).url=arguments[0]:e=e||{},(e=l(this.defaults,e)).method?e.method=e.method.toLowerCase():this.defaults.method?e.method=this.defaults.method.toLowerCase():e.method="get";var t=[i,void 0],n=Promise.resolve(e);for(this.interceptors.request.forEach((function(e){t.unshift(e.fulfilled,e.rejected)})),this.interceptors.response.forEach((function(e){t.push(e.fulfilled,e.rejected)}));t.length;)n=n.then(t.shift(),t.shift());return n},u.prototype.getUri=function(e){return e=l(this.defaults,e),o(e.url,e.params,e.paramsSerializer).replace(/^\?/,"")},r.forEach(["delete","get","head","options"],(function(e){u.prototype[e]=function(t,n){return this.request(r.merge(n||{},{method:e,url:t}))}})),r.forEach(["post","put","patch"],(function(e){u.prototype[e]=function(t,n,o){return this.request(r.merge(o||{},{method:e,url:t,data:n}))}})),e.exports=u},function(e,t,n){"use strict";var r=n(21);function o(){this.handlers=[]}o.prototype.use=function(e,t){return this.handlers.push({fulfilled:e,rejected:t}),this.handlers.length-1},o.prototype.eject=function(e){this.handlers[e]&&(this.handlers[e]=null)},o.prototype.forEach=function(e){r.forEach(this.handlers,(function(t){null!==t&&e(t)}))},e.exports=o},function(e,t,n){"use strict";var r=n(21),o=n(111),a=n(76),i=n(77);function l(e){e.cancelToken&&e.cancelToken.throwIfRequested()}e.exports=function(e){return l(e),e.headers=e.headers||{},e.data=o(e.data,e.headers,e.transformRequest),e.headers=r.merge(e.headers.common||{},e.headers[e.method]||{},e.headers),r.forEach(["delete","get","head","post","put","patch","common"],(function(t){delete e.headers[t]})),(e.adapter||i.adapter)(e).then((function(t){return l(e),t.data=o(t.data,t.headers,e.transformResponse),t}),(function(t){return a(t)||(l(e),t&&t.response&&(t.response.data=o(t.response.data,t.response.headers,e.transformResponse))),Promise.reject(t)}))}},function(e,t,n){"use strict";var r=n(21);e.exports=function(e,t,n){return r.forEach(n,(function(n){e=n(e,t)})),e}},function(e,t){var n,r,o=e.exports={};function a(){throw new Error("setTimeout has not been defined")}function i(){throw new Error("clearTimeout has not been defined")}function l(e){if(n===setTimeout)return setTimeout(e,0);if((n===a||!n)&&setTimeout)return n=setTimeout,setTimeout(e,0);try{return n(e,0)}catch(t){try{return n.call(null,e,0)}catch(t){return n.call(this,e,0)}}}!function(){try{n="function"===typeof setTimeout?setTimeout:a}catch(e){n=a}try{r="function"===typeof clearTimeout?clearTimeout:i}catch(e){r=i}}();var u,c=[],s=!1,d=-1;function f(){s&&u&&(s=!1,u.length?c=u.concat(c):d=-1,c.length&&p())}function p(){if(!s){var e=l(f);s=!0;for(var t=c.length;t;){for(u=c,c=[];++d<t;)u&&u[d].run();d=-1,t=c.length}u=null,s=!1,function(e){if(r===clearTimeout)return clearTimeout(e);if((r===i||!r)&&clearTimeout)return r=clearTimeout,clearTimeout(e);try{r(e)}catch(t){try{return r.call(null,e)}catch(t){return r.call(this,e)}}}(e)}}function h(e,t){this.fun=e,this.array=t}function m(){}o.nextTick=function(e){var t=new Array(arguments.length-1);if(arguments.length>1)for(var n=1;n<arguments.length;n++)t[n-1]=arguments[n];c.push(new h(e,t)),1!==c.length||s||l(p)},h.prototype.run=function(){this.fun.apply(null,this.array)},o.title="browser",o.browser=!0,o.env={},o.argv=[],o.version="",o.versions={},o.on=m,o.addListener=m,o.once=m,o.off=m,o.removeListener=m,o.removeAllListeners=m,o.emit=m,o.prependListener=m,o.prependOnceListener=m,o.listeners=function(e){return[]},o.binding=function(e){throw new Error("process.binding is not supported")},o.cwd=function(){return"/"},o.chdir=function(e){throw new Error("process.chdir is not supported")},o.umask=function(){return 0}},function(e,t,n){"use strict";var r=n(21);e.exports=function(e,t){r.forEach(e,(function(n,r){r!==t&&r.toUpperCase()===t.toUpperCase()&&(e[t]=n,delete e[r])}))}},function(e,t,n){"use strict";var r=n(79);e.exports=function(e,t,n){var o=n.config.validateStatus;!o||o(n.status)?e(n):t(r("Request failed with status code "+n.status,n.config,null,n.request,n))}},function(e,t,n){"use strict";e.exports=function(e,t,n,r,o){return e.config=t,n&&(e.code=n),e.request=r,e.response=o,e.isAxiosError=!0,e.toJSON=function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:this.config,code:this.code}},e}},function(e,t,n){"use strict";var r=n(117),o=n(118);e.exports=function(e,t){return e&&!r(t)?o(e,t):t}},function(e,t,n){"use strict";e.exports=function(e){return/^([a-z][a-z\d\+\-\.]*:)?\/\//i.test(e)}},function(e,t,n){"use strict";e.exports=function(e,t){return t?e.replace(/\/+$/,"")+"/"+t.replace(/^\/+/,""):e}},function(e,t,n){"use strict";var r=n(21),o=["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"];e.exports=function(e){var t,n,a,i={};return e?(r.forEach(e.split("\n"),(function(e){if(a=e.indexOf(":"),t=r.trim(e.substr(0,a)).toLowerCase(),n=r.trim(e.substr(a+1)),t){if(i[t]&&o.indexOf(t)>=0)return;i[t]="set-cookie"===t?(i[t]?i[t]:[]).concat([n]):i[t]?i[t]+", "+n:n}})),i):i}},function(e,t,n){"use strict";var r=n(21);e.exports=r.isStandardBrowserEnv()?function(){var e,t=/(msie|trident)/i.test(navigator.userAgent),n=document.createElement("a");function o(e){var r=e;return t&&(n.setAttribute("href",r),r=n.href),n.setAttribute("href",r),{href:n.href,protocol:n.protocol?n.protocol.replace(/:$/,""):"",host:n.host,search:n.search?n.search.replace(/^\?/,""):"",hash:n.hash?n.hash.replace(/^#/,""):"",hostname:n.hostname,port:n.port,pathname:"/"===n.pathname.charAt(0)?n.pathname:"/"+n.pathname}}return e=o(window.location.href),function(t){var n=r.isString(t)?o(t):t;return n.protocol===e.protocol&&n.host===e.host}}():function(){return!0}},function(e,t,n){"use strict";var r=n(21);e.exports=r.isStandardBrowserEnv()?{write:function(e,t,n,o,a,i){var l=[];l.push(e+"="+encodeURIComponent(t)),r.isNumber(n)&&l.push("expires="+new Date(n).toGMTString()),r.isString(o)&&l.push("path="+o),r.isString(a)&&l.push("domain="+a),!0===i&&l.push("secure"),document.cookie=l.join("; ")},read:function(e){var t=document.cookie.match(new RegExp("(^|;\\s*)("+e+")=([^;]*)"));return t?decodeURIComponent(t[3]):null},remove:function(e){this.write(e,"",Date.now()-864e5)}}:{write:function(){},read:function(){return null},remove:function(){}}},function(e,t,n){"use strict";var r=n(81);function o(e){if("function"!==typeof e)throw new TypeError("executor must be a function.");var t;this.promise=new Promise((function(e){t=e}));var n=this;e((function(e){n.reason||(n.reason=new r(e),t(n.reason))}))}o.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},o.source=function(){var e;return{token:new o((function(t){e=t})),cancel:e}},e.exports=o},function(e,t,n){"use strict";e.exports=function(e){return function(t){return e.apply(null,t)}}},function(e,t,n){"use strict";var r=n(125);function o(){}function a(){}a.resetWarningCache=o,e.exports=function(){function e(e,t,n,o,a,i){if(i!==r){var l=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw l.name="Invariant Violation",l}}function t(){return e}e.isRequired=e;var n={array:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:a,resetWarningCache:o};return n.PropTypes=n,n}},function(e,t,n){"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r="function"===typeof Symbol&&Symbol.for,o=r?Symbol.for("react.element"):60103,a=r?Symbol.for("react.portal"):60106,i=r?Symbol.for("react.fragment"):60107,l=r?Symbol.for("react.strict_mode"):60108,u=r?Symbol.for("react.profiler"):60114,c=r?Symbol.for("react.provider"):60109,s=r?Symbol.for("react.context"):60110,d=r?Symbol.for("react.async_mode"):60111,f=r?Symbol.for("react.concurrent_mode"):60111,p=r?Symbol.for("react.forward_ref"):60112,h=r?Symbol.for("react.suspense"):60113,m=r?Symbol.for("react.suspense_list"):60120,v=r?Symbol.for("react.memo"):60115,b=r?Symbol.for("react.lazy"):60116,y=r?Symbol.for("react.fundamental"):60117,g=r?Symbol.for("react.responder"):60118,x=r?Symbol.for("react.scope"):60119;function w(e){if("object"===typeof e&&null!==e){var t=e.$$typeof;switch(t){case o:switch(e=e.type){case d:case f:case i:case u:case l:case h:return e;default:switch(e=e&&e.$$typeof){case s:case p:case b:case v:case c:return e;default:return t}}case a:return t}}}function k(e){return w(e)===f}t.typeOf=w,t.AsyncMode=d,t.ConcurrentMode=f,t.ContextConsumer=s,t.ContextProvider=c,t.Element=o,t.ForwardRef=p,t.Fragment=i,t.Lazy=b,t.Memo=v,t.Portal=a,t.Profiler=u,t.StrictMode=l,t.Suspense=h,t.isValidElementType=function(e){return"string"===typeof e||"function"===typeof e||e===i||e===f||e===u||e===l||e===h||e===m||"object"===typeof e&&null!==e&&(e.$$typeof===b||e.$$typeof===v||e.$$typeof===c||e.$$typeof===s||e.$$typeof===p||e.$$typeof===y||e.$$typeof===g||e.$$typeof===x)},t.isAsyncMode=function(e){return k(e)||w(e)===d},t.isConcurrentMode=k,t.isContextConsumer=function(e){return w(e)===s},t.isContextProvider=function(e){return w(e)===c},t.isElement=function(e){return"object"===typeof e&&null!==e&&e.$$typeof===o},t.isForwardRef=function(e){return w(e)===p},t.isFragment=function(e){return w(e)===i},t.isLazy=function(e){return w(e)===b},t.isMemo=function(e){return w(e)===v},t.isPortal=function(e){return w(e)===a},t.isProfiler=function(e){return w(e)===u},t.isStrictMode=function(e){return w(e)===l},t.isSuspense=function(e){return w(e)===h}},function(e,t){function n(){return e.exports=n=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},n.apply(this,arguments)}e.exports=n},function(e,t){var n;n=function(){return this}();try{n=n||new Function("return this")()}catch(r){"object"===typeof window&&(n=window)}e.exports=n},function(e,t){e.exports=Array.isArray||function(e){return"[object Array]"==Object.prototype.toString.call(e)}},,function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(6),s={h1:"h1",h2:"h2",h3:"h3",h4:"h4",h5:"h5",h6:"h6",subtitle1:"h6",subtitle2:"h6",body1:"p",body2:"p"},d=i.a.forwardRef((function(e,t){var n=e.align,a=void 0===n?"inherit":n,u=e.classes,d=e.className,f=e.color,p=void 0===f?"initial":f,h=e.component,m=e.display,v=void 0===m?"initial":m,b=e.gutterBottom,y=void 0!==b&&b,g=e.noWrap,x=void 0!==g&&g,w=e.paragraph,k=void 0!==w&&w,E=e.variant,O=void 0===E?"body1":E,S=e.variantMapping,C=void 0===S?s:S,T=Object(o.a)(e,["align","classes","className","color","component","display","gutterBottom","noWrap","paragraph","variant","variantMapping"]),j=h||(k?"p":C[O]||s[O])||"span";return i.a.createElement(j,Object(r.a)({className:Object(l.a)(u.root,d,"inherit"!==O&&u[O],"initial"!==p&&u["color".concat(Object(c.a)(p))],x&&u.noWrap,y&&u.gutterBottom,k&&u.paragraph,"inherit"!==a&&u["align".concat(Object(c.a)(a))],"initial"!==v&&u["display".concat(Object(c.a)(v))]),ref:t},T))}));t.a=Object(u.a)((function(e){return{root:{margin:0},body2:e.typography.body2,body1:e.typography.body1,caption:e.typography.caption,button:e.typography.button,h1:e.typography.h1,h2:e.typography.h2,h3:e.typography.h3,h4:e.typography.h4,h5:e.typography.h5,h6:e.typography.h6,subtitle1:e.typography.subtitle1,subtitle2:e.typography.subtitle2,overline:e.typography.overline,srOnly:{position:"absolute",height:1,width:1,overflow:"hidden"},alignLeft:{textAlign:"left"},alignCenter:{textAlign:"center"},alignRight:{textAlign:"right"},alignJustify:{textAlign:"justify"},noWrap:{overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},gutterBottom:{marginBottom:"0.35em"},paragraph:{marginBottom:16},colorInherit:{color:"inherit"},colorPrimary:{color:e.palette.primary.main},colorSecondary:{color:e.palette.secondary.main},colorTextPrimary:{color:e.palette.text.primary},colorTextSecondary:{color:e.palette.text.secondary},colorError:{color:e.palette.error.main},displayInline:{display:"inline"},displayBlock:{display:"block"}}}),{name:"MuiTypography"})(d)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(10),s=n(94),d=n(6),f=i.a.forwardRef((function(e,t){var n=e.edge,a=void 0!==n&&n,u=e.children,c=e.classes,f=e.className,p=e.color,h=void 0===p?"default":p,m=e.disabled,v=void 0!==m&&m,b=e.disableFocusRipple,y=void 0!==b&&b,g=e.size,x=void 0===g?"medium":g,w=Object(o.a)(e,["edge","children","classes","className","color","disabled","disableFocusRipple","size"]);return i.a.createElement(s.a,Object(r.a)({className:Object(l.a)(c.root,f,"default"!==h&&c["color".concat(Object(d.a)(h))],v&&c.disabled,{small:c["size".concat(Object(d.a)(x))]}[x],{start:c.edgeStart,end:c.edgeEnd}[a]),centerRipple:!0,focusRipple:!y,disabled:v,ref:t},w),i.a.createElement("span",{className:c.label},u))}));t.a=Object(u.a)((function(e){return{root:{textAlign:"center",flex:"0 0 auto",fontSize:e.typography.pxToRem(24),padding:12,borderRadius:"50%",overflow:"visible",color:e.palette.action.active,transition:e.transitions.create("background-color",{duration:e.transitions.duration.shortest}),"&:hover":{backgroundColor:Object(c.b)(e.palette.action.active,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},"&$disabled":{backgroundColor:"transparent",color:e.palette.action.disabled}},edgeStart:{marginLeft:-12,"$sizeSmall&":{marginLeft:-3}},edgeEnd:{marginRight:-12,"$sizeSmall&":{marginRight:-3}},colorInherit:{color:"inherit"},colorPrimary:{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},colorSecondary:{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},disabled:{},sizeSmall:{padding:3,fontSize:e.typography.pxToRem(18)},label:{width:"100%",display:"flex",alignItems:"inherit",justifyContent:"inherit"}}}),{name:"MuiIconButton"})(f)},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l="function"===typeof Symbol&&"symbol"===typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"===typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},u="object"===("undefined"===typeof window?"undefined":l(window))&&"object"===("undefined"===typeof document?"undefined":l(document))&&9===document.nodeType,c=(n(33),n(48)),s=n(12),d=n(49),f=n(15),p={}.constructor;function h(e){if(null==e||"object"!==typeof e)return e;if(Array.isArray(e))return e.map(h);if(e.constructor!==p)return e;var t={};for(var n in e)t[n]=h(e[n]);return t}function m(e,t,n){void 0===e&&(e="unnamed");var r=n.jss,o=h(t),a=r.plugins.onCreateRule(e,o,n);return a||(e[0],null)}var v=function(e,t){for(var n="",r=0;r<e.length&&"!important"!==e[r];r++)n&&(n+=t),n+=e[r];return n};function b(e,t){if(void 0===t&&(t=!1),!Array.isArray(e))return e;var n="";if(Array.isArray(e[0]))for(var r=0;r<e.length&&"!important"!==e[r];r++)n&&(n+=", "),n+=v(e[r]," ");else n=v(e,", ");return t||"!important"!==e[e.length-1]||(n+=" !important"),n}function y(e,t){for(var n="",r=0;r<t;r++)n+=" ";return n+e}function g(e,t,n){void 0===n&&(n={});var r="";if(!t)return r;var o=n.indent,a=void 0===o?0:o,i=t.fallbacks;if(e&&a++,i)if(Array.isArray(i))for(var l=0;l<i.length;l++){var u=i[l];for(var c in u){var s=u[c];null!=s&&(r&&(r+="\n"),r+=""+y(c+": "+b(s)+";",a))}}else for(var d in i){var f=i[d];null!=f&&(r&&(r+="\n"),r+=""+y(d+": "+b(f)+";",a))}for(var p in t){var h=t[p];null!=h&&"fallbacks"!==p&&(r&&(r+="\n"),r+=""+y(p+": "+b(h)+";",a))}return(r||n.allowEmpty)&&e?(r&&(r="\n"+r+"\n"),y(e+" {"+r,--a)+y("}",a)):r}var x=/([[\].#*$><+~=|^:(),"'`\s])/g,w="undefined"!==typeof CSS&&CSS.escape,k=function(e){return w?w(e):e.replace(x,"\\$1")},E=function(){function e(e,t,n){this.type="style",this.key=void 0,this.isProcessed=!1,this.style=void 0,this.renderer=void 0,this.renderable=void 0,this.options=void 0;var r=n.sheet,o=n.Renderer;this.key=e,this.options=n,this.style=t,r?this.renderer=r.renderer:o&&(this.renderer=new o)}return e.prototype.prop=function(e,t,n){if(void 0===t)return this.style[e];var r=!!n&&n.force;if(!r&&this.style[e]===t)return this;var o=t;n&&!1===n.process||(o=this.options.jss.plugins.onChangeValue(t,e,this));var a=null==o||!1===o,i=e in this.style;if(a&&!i&&!r)return this;var l=a&&i;if(l?delete this.style[e]:this.style[e]=o,this.renderable&&this.renderer)return l?this.renderer.removeProperty(this.renderable,e):this.renderer.setProperty(this.renderable,e,o),this;var u=this.options.sheet;return u&&u.attached,this},e}(),O=function(e){function t(t,n,r){var o;(o=e.call(this,t,n,r)||this).selectorText=void 0,o.id=void 0,o.renderable=void 0;var a=r.selector,i=r.scoped,l=r.sheet,u=r.generateId;return a?o.selectorText=a:!1!==i&&(o.id=u(Object(d.a)(Object(d.a)(o)),l),o.selectorText="."+k(o.id)),o}Object(s.a)(t,e);var n=t.prototype;return n.applyTo=function(e){var t=this.renderer;if(t){var n=this.toJSON();for(var r in n)t.setProperty(e,r,n[r])}return this},n.toJSON=function(){var e={};for(var t in this.style){var n=this.style[t];"object"!==typeof n?e[t]=n:Array.isArray(n)&&(e[t]=b(n))}return e},n.toString=function(e){var t=this.options.sheet,n=!!t&&t.options.link?Object(o.a)({},e,{allowEmpty:!0}):e;return g(this.selectorText,this.style,n)},Object(c.a)(t,[{key:"selector",set:function(e){if(e!==this.selectorText){this.selectorText=e;var t=this.renderer,n=this.renderable;if(n&&t)t.setSelector(n,e)||t.replaceRule(n,this)}},get:function(){return this.selectorText}}]),t}(E),S={onCreateRule:function(e,t,n){return"@"===e[0]||n.parent&&"keyframes"===n.parent.type?null:new O(e,t,n)}},C={indent:1,children:!0},T=/@([\w-]+)/,j=function(){function e(e,t,n){this.type="conditional",this.at=void 0,this.key=void 0,this.query=void 0,this.rules=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.query=n.name;var r=e.match(T);for(var a in this.at=r?r[1]:"unknown",this.options=n,this.rules=new G(Object(o.a)({},n,{parent:this})),t)this.rules.add(a,t[a]);this.rules.process()}var t=e.prototype;return t.getRule=function(e){return this.rules.get(e)},t.indexOf=function(e){return this.rules.indexOf(e)},t.addRule=function(e,t,n){var r=this.rules.add(e,t,n);return r?(this.options.jss.plugins.onProcessRule(r),r):null},t.toString=function(e){if(void 0===e&&(e=C),null==e.indent&&(e.indent=C.indent),null==e.children&&(e.children=C.children),!1===e.children)return this.query+" {}";var t=this.rules.toString(e);return t?this.query+" {\n"+t+"\n}":""},e}(),P=/@media|@supports\s+/,R={onCreateRule:function(e,t,n){return P.test(e)?new j(e,t,n):null}},N={indent:1,children:!0},M=/@keyframes\s+([\w-]+)/,_=function(){function e(e,t,n){this.type="keyframes",this.at="@keyframes",this.key=void 0,this.name=void 0,this.id=void 0,this.rules=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0;var r=e.match(M);r&&r[1]?this.name=r[1]:this.name="noname",this.key=this.type+"-"+this.name,this.options=n;var a=n.scoped,i=n.sheet,l=n.generateId;for(var u in this.id=!1===a?this.name:k(l(this,i)),this.rules=new G(Object(o.a)({},n,{parent:this})),t)this.rules.add(u,t[u],Object(o.a)({},n,{parent:this}));this.rules.process()}return e.prototype.toString=function(e){if(void 0===e&&(e=N),null==e.indent&&(e.indent=N.indent),null==e.children&&(e.children=N.children),!1===e.children)return this.at+" "+this.id+" {}";var t=this.rules.toString(e);return t&&(t="\n"+t+"\n"),this.at+" "+this.id+" {"+t+"}"},e}(),A=/@keyframes\s+/,z=/\$([\w-]+)/g,I=function(e,t){return"string"===typeof e?e.replace(z,(function(e,n){return n in t?t[n]:e})):e},L=function(e,t,n){var r=e[t],o=I(r,n);o!==r&&(e[t]=o)},D={onCreateRule:function(e,t,n){return"string"===typeof e&&A.test(e)?new _(e,t,n):null},onProcessStyle:function(e,t,n){return"style"===t.type&&n?("animation-name"in e&&L(e,"animation-name",n.keyframes),"animation"in e&&L(e,"animation",n.keyframes),e):e},onChangeValue:function(e,t,n){var r=n.options.sheet;if(!r)return e;switch(t){case"animation":case"animation-name":return I(e,r.keyframes);default:return e}}},F=function(e){function t(){for(var t,n=arguments.length,r=new Array(n),o=0;o<n;o++)r[o]=arguments[o];return(t=e.call.apply(e,[this].concat(r))||this).renderable=void 0,t}return Object(s.a)(t,e),t.prototype.toString=function(e){var t=this.options.sheet,n=!!t&&t.options.link?Object(o.a)({},e,{allowEmpty:!0}):e;return g(this.key,this.style,n)},t}(E),U={onCreateRule:function(e,t,n){return n.parent&&"keyframes"===n.parent.type?new F(e,t,n):null}},$=function(){function e(e,t,n){this.type="font-face",this.at="@font-face",this.key=void 0,this.style=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.style=t,this.options=n}return e.prototype.toString=function(e){if(Array.isArray(this.style)){for(var t="",n=0;n<this.style.length;n++)t+=g(this.key,this.style[n]),this.style[n+1]&&(t+="\n");return t}return g(this.key,this.style,e)},e}(),B={onCreateRule:function(e,t,n){return"@font-face"===e?new $(e,t,n):null}},W=function(){function e(e,t,n){this.type="viewport",this.at="@viewport",this.key=void 0,this.style=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.style=t,this.options=n}return e.prototype.toString=function(e){return g(this.key,this.style,e)},e}(),V={onCreateRule:function(e,t,n){return"@viewport"===e||"@-ms-viewport"===e?new W(e,t,n):null}},H=function(){function e(e,t,n){this.type="simple",this.key=void 0,this.value=void 0,this.options=void 0,this.isProcessed=!1,this.renderable=void 0,this.key=e,this.value=t,this.options=n}return e.prototype.toString=function(e){if(Array.isArray(this.value)){for(var t="",n=0;n<this.value.length;n++)t+=this.key+" "+this.value[n]+";",this.value[n+1]&&(t+="\n");return t}return this.key+" "+this.value+";"},e}(),q={"@charset":!0,"@import":!0,"@namespace":!0},K=[S,R,D,U,B,V,{onCreateRule:function(e,t,n){return e in q?new H(e,t,n):null}}],Q={process:!0},X={force:!0,process:!0},G=function(){function e(e){this.map={},this.raw={},this.index=[],this.counter=0,this.options=void 0,this.classes=void 0,this.keyframes=void 0,this.options=e,this.classes=e.classes,this.keyframes=e.keyframes}var t=e.prototype;return t.add=function(e,t,n){var r=this.options,a=r.parent,i=r.sheet,l=r.jss,u=r.Renderer,c=r.generateId,s=r.scoped,d=Object(o.a)({classes:this.classes,parent:a,sheet:i,jss:l,Renderer:u,generateId:c,scoped:s,name:e},n),f=e;e in this.raw&&(f=e+"-d"+this.counter++),this.raw[f]=t,f in this.classes&&(d.selector="."+k(this.classes[f]));var p=m(f,t,d);if(!p)return null;this.register(p);var h=void 0===d.index?this.index.length:d.index;return this.index.splice(h,0,p),p},t.get=function(e){return this.map[e]},t.remove=function(e){this.unregister(e),delete this.raw[e.key],this.index.splice(this.index.indexOf(e),1)},t.indexOf=function(e){return this.index.indexOf(e)},t.process=function(){var e=this.options.jss.plugins;this.index.slice(0).forEach(e.onProcessRule,e)},t.register=function(e){this.map[e.key]=e,e instanceof O?(this.map[e.selector]=e,e.id&&(this.classes[e.key]=e.id)):e instanceof _&&this.keyframes&&(this.keyframes[e.name]=e.id)},t.unregister=function(e){delete this.map[e.key],e instanceof O?(delete this.map[e.selector],delete this.classes[e.key]):e instanceof _&&delete this.keyframes[e.name]},t.update=function(){var e,t,n;if("string"===typeof(arguments.length<=0?void 0:arguments[0])?(e=arguments.length<=0?void 0:arguments[0],t=arguments.length<=1?void 0:arguments[1],n=arguments.length<=2?void 0:arguments[2]):(t=arguments.length<=0?void 0:arguments[0],n=arguments.length<=1?void 0:arguments[1],e=null),e)this.updateOne(this.map[e],t,n);else for(var r=0;r<this.index.length;r++)this.updateOne(this.index[r],t,n)},t.updateOne=function(t,n,r){void 0===r&&(r=Q);var o=this.options,a=o.jss.plugins,i=o.sheet;if(t.rules instanceof e)t.rules.update(n,r);else{var l=t,u=l.style;if(a.onUpdate(n,t,i,r),r.process&&u&&u!==l.style){for(var c in a.onProcessStyle(l.style,l,i),l.style){var s=l.style[c];s!==u[c]&&l.prop(c,s,X)}for(var d in u){var f=l.style[d],p=u[d];null==f&&f!==p&&l.prop(d,null,X)}}}},t.toString=function(e){for(var t="",n=this.options.sheet,r=!!n&&n.options.link,o=0;o<this.index.length;o++){var a=this.index[o].toString(e);(a||r)&&(t&&(t+="\n"),t+=a)}return t},e}(),Y=function(){function e(e,t){for(var n in this.options=void 0,this.deployed=void 0,this.attached=void 0,this.rules=void 0,this.renderer=void 0,this.classes=void 0,this.keyframes=void 0,this.queue=void 0,this.attached=!1,this.deployed=!1,this.classes={},this.keyframes={},this.options=Object(o.a)({},t,{sheet:this,parent:this,classes:this.classes,keyframes:this.keyframes}),t.Renderer&&(this.renderer=new t.Renderer(this)),this.rules=new G(this.options),e)this.rules.add(n,e[n]);this.rules.process()}var t=e.prototype;return t.attach=function(){return this.attached?this:(this.renderer&&this.renderer.attach(),this.attached=!0,this.deployed||this.deploy(),this)},t.detach=function(){return this.attached?(this.renderer&&this.renderer.detach(),this.attached=!1,this):this},t.addRule=function(e,t,n){var r=this.queue;this.attached&&!r&&(this.queue=[]);var o=this.rules.add(e,t,n);return o?(this.options.jss.plugins.onProcessRule(o),this.attached?this.deployed?(r?r.push(o):(this.insertRule(o),this.queue&&(this.queue.forEach(this.insertRule,this),this.queue=void 0)),o):o:(this.deployed=!1,o)):null},t.insertRule=function(e){this.renderer&&this.renderer.insertRule(e)},t.addRules=function(e,t){var n=[];for(var r in e){var o=this.addRule(r,e[r],t);o&&n.push(o)}return n},t.getRule=function(e){return this.rules.get(e)},t.deleteRule=function(e){var t="object"===typeof e?e:this.rules.get(e);return!!t&&(this.rules.remove(t),!(this.attached&&t.renderable&&this.renderer)||this.renderer.deleteRule(t.renderable))},t.indexOf=function(e){return this.rules.indexOf(e)},t.deploy=function(){return this.renderer&&this.renderer.deploy(),this.deployed=!0,this},t.update=function(){var e;return(e=this.rules).update.apply(e,arguments),this},t.updateOne=function(e,t,n){return this.rules.updateOne(e,t,n),this},t.toString=function(e){return this.rules.toString(e)},e}(),J=function(){function e(){this.plugins={internal:[],external:[]},this.registry=void 0}var t=e.prototype;return t.onCreateRule=function(e,t,n){for(var r=0;r<this.registry.onCreateRule.length;r++){var o=this.registry.onCreateRule[r](e,t,n);if(o)return o}return null},t.onProcessRule=function(e){if(!e.isProcessed){for(var t=e.options.sheet,n=0;n<this.registry.onProcessRule.length;n++)this.registry.onProcessRule[n](e,t);e.style&&this.onProcessStyle(e.style,e,t),e.isProcessed=!0}},t.onProcessStyle=function(e,t,n){for(var r=0;r<this.registry.onProcessStyle.length;r++)t.style=this.registry.onProcessStyle[r](t.style,t,n)},t.onProcessSheet=function(e){for(var t=0;t<this.registry.onProcessSheet.length;t++)this.registry.onProcessSheet[t](e)},t.onUpdate=function(e,t,n,r){for(var o=0;o<this.registry.onUpdate.length;o++)this.registry.onUpdate[o](e,t,n,r)},t.onChangeValue=function(e,t,n){for(var r=e,o=0;o<this.registry.onChangeValue.length;o++)r=this.registry.onChangeValue[o](r,t,n);return r},t.use=function(e,t){void 0===t&&(t={queue:"external"});var n=this.plugins[t.queue];-1===n.indexOf(e)&&(n.push(e),this.registry=[].concat(this.plugins.external,this.plugins.internal).reduce((function(e,t){for(var n in t)n in e&&e[n].push(t[n]);return e}),{onCreateRule:[],onProcessRule:[],onProcessStyle:[],onProcessSheet:[],onChangeValue:[],onUpdate:[]}))},e}(),Z=new(function(){function e(){this.registry=[]}var t=e.prototype;return t.add=function(e){var t=this.registry,n=e.options.index;if(-1===t.indexOf(e))if(0===t.length||n>=this.index)t.push(e);else for(var r=0;r<t.length;r++)if(t[r].options.index>n)return void t.splice(r,0,e)},t.reset=function(){this.registry=[]},t.remove=function(e){var t=this.registry.indexOf(e);this.registry.splice(t,1)},t.toString=function(e){for(var t=void 0===e?{}:e,n=t.attached,r=Object(f.a)(t,["attached"]),o="",a=0;a<this.registry.length;a++){var i=this.registry[a];null!=n&&i.attached!==n||(o&&(o+="\n"),o+=i.toString(r))}return o},Object(c.a)(e,[{key:"index",get:function(){return 0===this.registry.length?0:this.registry[this.registry.length-1].options.index}}]),e}()),ee="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")(),te="2f1acc6c3a606b082e5eef5e54414ffb";null==ee[te]&&(ee[te]=0);var ne=ee[te]++,re=function(e){void 0===e&&(e={});var t=0;return function(n,r){t+=1;var o="",a="";return r&&(r.options.classNamePrefix&&(a=r.options.classNamePrefix),null!=r.options.jss.id&&(o=String(r.options.jss.id))),e.minify?""+(a||"c")+ne+o+t:a+n.key+"-"+ne+(o?"-"+o:"")+"-"+t}},oe=function(e){var t;return function(){return t||(t=e()),t}};function ae(e,t){try{return e.attributeStyleMap?e.attributeStyleMap.get(t):e.style.getPropertyValue(t)}catch(n){return""}}function ie(e,t,n){try{var r=n;if(Array.isArray(n)&&(r=b(n,!0),"!important"===n[n.length-1]))return e.style.setProperty(t,r,"important"),!0;e.attributeStyleMap?e.attributeStyleMap.set(t,r):e.style.setProperty(t,r)}catch(o){return!1}return!0}function le(e,t){try{e.attributeStyleMap?e.attributeStyleMap.delete(t):e.style.removeProperty(t)}catch(n){}}function ue(e,t){return e.selectorText=t,e.selectorText===t}var ce=oe((function(){return document.querySelector("head")}));function se(e){var t=Z.registry;if(t.length>0){var n=function(e,t){for(var n=0;n<e.length;n++){var r=e[n];if(r.attached&&r.options.index>t.index&&r.options.insertionPoint===t.insertionPoint)return r}return null}(t,e);if(n&&n.renderer)return{parent:n.renderer.element.parentNode,node:n.renderer.element};if((n=function(e,t){for(var n=e.length-1;n>=0;n--){var r=e[n];if(r.attached&&r.options.insertionPoint===t.insertionPoint)return r}return null}(t,e))&&n.renderer)return{parent:n.renderer.element.parentNode,node:n.renderer.element.nextSibling}}var r=e.insertionPoint;if(r&&"string"===typeof r){var o=function(e){for(var t=ce(),n=0;n<t.childNodes.length;n++){var r=t.childNodes[n];if(8===r.nodeType&&r.nodeValue.trim()===e)return r}return null}(r);if(o)return{parent:o.parentNode,node:o.nextSibling}}return!1}var de=oe((function(){var e=document.querySelector('meta[property="csp-nonce"]');return e?e.getAttribute("content"):null})),fe=function(e,t,n){var r=e.cssRules.length;(void 0===n||n>r)&&(n=r);try{if("insertRule"in e)e.insertRule(t,n);else if("appendRule"in e){e.appendRule(t)}}catch(o){return!1}return e.cssRules[n]},pe=function(){function e(e){this.getPropertyValue=ae,this.setProperty=ie,this.removeProperty=le,this.setSelector=ue,this.element=void 0,this.sheet=void 0,this.hasInsertedRules=!1,e&&Z.add(e),this.sheet=e;var t=this.sheet?this.sheet.options:{},n=t.media,r=t.meta,o=t.element;this.element=o||function(){var e=document.createElement("style");return e.textContent="\n",e}(),this.element.setAttribute("data-jss",""),n&&this.element.setAttribute("media",n),r&&this.element.setAttribute("data-meta",r);var a=de();a&&this.element.setAttribute("nonce",a)}var t=e.prototype;return t.attach=function(){if(!this.element.parentNode&&this.sheet){!function(e,t){var n=t.insertionPoint,r=se(t);if(!1!==r&&r.parent)r.parent.insertBefore(e,r.node);else if(n&&"number"===typeof n.nodeType){var o=n,a=o.parentNode;a&&a.insertBefore(e,o.nextSibling)}else ce().appendChild(e)}(this.element,this.sheet.options);var e=Boolean(this.sheet&&this.sheet.deployed);this.hasInsertedRules&&e&&(this.hasInsertedRules=!1,this.deploy())}},t.detach=function(){var e=this.element.parentNode;e&&e.removeChild(this.element)},t.deploy=function(){var e=this.sheet;e&&(e.options.link?this.insertRules(e.rules):this.element.textContent="\n"+e.toString()+"\n")},t.insertRules=function(e,t){for(var n=0;n<e.index.length;n++)this.insertRule(e.index[n],n,t)},t.insertRule=function(e,t,n){if(void 0===n&&(n=this.element.sheet),e.rules){var r=e,o=n;return("conditional"!==e.type&&"keyframes"!==e.type||!1!==(o=fe(n,r.toString({children:!1}),t)))&&(this.insertRules(r.rules,o),o)}if(e.renderable&&e.renderable.parentStyleSheet===this.element.sheet)return e.renderable;var a=e.toString();if(!a)return!1;var i=fe(n,a,t);return!1!==i&&(this.hasInsertedRules=!0,e.renderable=i,i)},t.deleteRule=function(e){var t=this.element.sheet,n=this.indexOf(e);return-1!==n&&(t.deleteRule(n),!0)},t.indexOf=function(e){for(var t=this.element.sheet.cssRules,n=0;n<t.length;n++)if(e===t[n])return n;return-1},t.replaceRule=function(e,t){var n=this.indexOf(e);return-1!==n&&(this.element.sheet.deleteRule(n),this.insertRule(t,n))},t.getRules=function(){return this.element.sheet.cssRules},e}(),he=0,me=function(){function e(e){this.id=he++,this.version="10.0.3",this.plugins=new J,this.options={id:{minify:!1},createGenerateId:re,Renderer:u?pe:null,plugins:[]},this.generateId=re({minify:!1});for(var t=0;t<K.length;t++)this.plugins.use(K[t],{queue:"internal"});this.setup(e)}var t=e.prototype;return t.setup=function(e){return void 0===e&&(e={}),e.createGenerateId&&(this.options.createGenerateId=e.createGenerateId),e.id&&(this.options.id=Object(o.a)({},this.options.id,e.id)),(e.createGenerateId||e.id)&&(this.generateId=this.options.createGenerateId(this.options.id)),null!=e.insertionPoint&&(this.options.insertionPoint=e.insertionPoint),"Renderer"in e&&(this.options.Renderer=e.Renderer),e.plugins&&this.use.apply(this,e.plugins),this},t.createStyleSheet=function(e,t){void 0===t&&(t={});var n=t.index;"number"!==typeof n&&(n=0===Z.index?0:Z.index+1);var r=new Y(e,Object(o.a)({},t,{jss:this,generateId:t.generateId||this.generateId,insertionPoint:this.options.insertionPoint,Renderer:this.options.Renderer,index:n}));return this.plugins.onProcessSheet(r),r},t.removeStyleSheet=function(e){return e.detach(),Z.remove(e),this},t.createRule=function(e,t,n){if(void 0===t&&(t={}),void 0===n&&(n={}),"object"===typeof e)return this.createRule(void 0,e,t);var r=Object(o.a)({},n,{name:e,jss:this,Renderer:this.options.Renderer});r.generateId||(r.generateId=this.generateId),r.classes||(r.classes={}),r.keyframes||(r.keyframes={});var a=m(e,t,r);return a&&this.plugins.onProcessRule(a),a},t.use=function(){for(var e=this,t=arguments.length,n=new Array(t),r=0;r<t;r++)n[r]=arguments[r];return n.forEach((function(t){e.plugins.use(t)})),this},e}();var ve="undefined"!==typeof CSS&&CSS&&"number"in CSS,be=function(e){return new me(e)},ye=(be(),n(161)),ge={set:function(e,t,n,r){var o=e.get(t);o||(o=new Map,e.set(t,o)),o.set(n,r)},get:function(e,t,n){var r=e.get(t);return r?r.get(n):void 0},delete:function(e,t,n){e.get(t).delete(n)}},xe=n(93),we=(n(5),n(58)),ke=["checked","disabled","error","focused","focusVisible","required","expanded","selected"];var Ee=Date.now(),Oe="fnValues"+Ee,Se="fnStyle"+ ++Ee;var Ce=function(){return{onCreateRule:function(e,t,n){if("function"!==typeof t)return null;var r=m(e,{},n);return r[Se]=t,r},onProcessStyle:function(e,t){if(Oe in t||Se in t)return e;var n={};for(var r in e){var o=e[r];"function"===typeof o&&(delete e[r],n[r]=o)}return t[Oe]=n,e},onUpdate:function(e,t,n,r){var o=t,a=o[Se];a&&(o.style=a(e)||{});var i=o[Oe];if(i)for(var l in i)o.prop(l,i[l](e),r)}}},Te="@global",je=function(){function e(e,t,n){for(var r in this.type="global",this.at=Te,this.rules=void 0,this.options=void 0,this.key=void 0,this.isProcessed=!1,this.key=e,this.options=n,this.rules=new G(Object(o.a)({},n,{parent:this})),t)this.rules.add(r,t[r]);this.rules.process()}var t=e.prototype;return t.getRule=function(e){return this.rules.get(e)},t.addRule=function(e,t,n){var r=this.rules.add(e,t,n);return this.options.jss.plugins.onProcessRule(r),r},t.indexOf=function(e){return this.rules.indexOf(e)},t.toString=function(){return this.rules.toString()},e}(),Pe=function(){function e(e,t,n){this.type="global",this.at=Te,this.options=void 0,this.rule=void 0,this.isProcessed=!1,this.key=void 0,this.key=e,this.options=n;var r=e.substr("@global ".length);this.rule=n.jss.createRule(r,t,Object(o.a)({},n,{parent:this}))}return e.prototype.toString=function(e){return this.rule?this.rule.toString(e):""},e}(),Re=/\s*,\s*/g;function Ne(e,t){for(var n=e.split(Re),r="",o=0;o<n.length;o++)r+=t+" "+n[o].trim(),n[o+1]&&(r+=", ");return r}var Me=function(){return{onCreateRule:function(e,t,n){if(!e)return null;if(e===Te)return new je(e,t,n);if("@"===e[0]&&"@global "===e.substr(0,"@global ".length))return new Pe(e,t,n);var r=n.parent;return r&&("global"===r.type||r.options.parent&&"global"===r.options.parent.type)&&(n.scoped=!1),!1===n.scoped&&(n.selector=e),null},onProcessRule:function(e){"style"===e.type&&(function(e){var t=e.options,n=e.style,r=n?n[Te]:null;if(r){for(var a in r)t.sheet.addRule(a,r[a],Object(o.a)({},t,{selector:Ne(a,e.selector)}));delete n[Te]}}(e),function(e){var t=e.options,n=e.style;for(var r in n)if("@"===r[0]&&r.substr(0,Te.length)===Te){var a=Ne(r.substr(Te.length),e.selector);t.sheet.addRule(a,n[r],Object(o.a)({},t,{selector:a})),delete n[r]}}(e))}}},_e=/\s*,\s*/g,Ae=/&/g,ze=/\$([\w-]+)/g;var Ie=function(){function e(e,t){return function(n,r){var o=e.getRule(r)||t&&t.getRule(r);return o?(o=o).selector:r}}function t(e,t){for(var n=t.split(_e),r=e.split(_e),o="",a=0;a<n.length;a++)for(var i=n[a],l=0;l<r.length;l++){var u=r[l];o&&(o+=", "),o+=-1!==u.indexOf("&")?u.replace(Ae,i):i+" "+u}return o}function n(e,t,n){if(n)return Object(o.a)({},n,{index:n.index+1});var r=e.options.nestingLevel;r=void 0===r?1:r+1;var a=Object(o.a)({},e.options,{nestingLevel:r,index:t.indexOf(e)+1});return delete a.name,a}return{onProcessStyle:function(r,a,i){if("style"!==a.type)return r;var l,u,c=a,s=c.options.parent;for(var d in r){var f=-1!==d.indexOf("&"),p="@"===d[0];if(f||p){if(l=n(c,s,l),f){var h=t(d,c.selector);u||(u=e(s,i)),h=h.replace(ze,u),s.addRule(h,r[d],Object(o.a)({},l,{selector:h}))}else p&&s.addRule(d,{},l).addRule(c.key,r[d],{selector:c.selector});delete r[d]}}return r}}},Le=/[A-Z]/g,De=/^ms-/,Fe={};function Ue(e){return"-"+e.toLowerCase()}var $e=function(e){if(Fe.hasOwnProperty(e))return Fe[e];var t=e.replace(Le,Ue);return Fe[e]=De.test(t)?"-"+t:t};function Be(e){var t={};for(var n in e){t[0===n.indexOf("--")?n:$e(n)]=e[n]}return e.fallbacks&&(Array.isArray(e.fallbacks)?t.fallbacks=e.fallbacks.map(Be):t.fallbacks=Be(e.fallbacks)),t}var We=function(){return{onProcessStyle:function(e){if(Array.isArray(e)){for(var t=0;t<e.length;t++)e[t]=Be(e[t]);return e}return Be(e)},onChangeValue:function(e,t,n){if(0===t.indexOf("--"))return e;var r=$e(t);return t===r?e:(n.prop(r,e),null)}}},Ve=ve&&CSS?CSS.px:"px",He=ve&&CSS?CSS.ms:"ms",qe=ve&&CSS?CSS.percent:"%";function Ke(e){var t=/(-[a-z])/g,n=function(e){return e[1].toUpperCase()},r={};for(var o in e)r[o]=e[o],r[o.replace(t,n)]=e[o];return r}var Qe=Ke({"animation-delay":He,"animation-duration":He,"background-position":Ve,"background-position-x":Ve,"background-position-y":Ve,"background-size":Ve,border:Ve,"border-bottom":Ve,"border-bottom-left-radius":Ve,"border-bottom-right-radius":Ve,"border-bottom-width":Ve,"border-left":Ve,"border-left-width":Ve,"border-radius":Ve,"border-right":Ve,"border-right-width":Ve,"border-top":Ve,"border-top-left-radius":Ve,"border-top-right-radius":Ve,"border-top-width":Ve,"border-width":Ve,margin:Ve,"margin-bottom":Ve,"margin-left":Ve,"margin-right":Ve,"margin-top":Ve,padding:Ve,"padding-bottom":Ve,"padding-left":Ve,"padding-right":Ve,"padding-top":Ve,"mask-position-x":Ve,"mask-position-y":Ve,"mask-size":Ve,height:Ve,width:Ve,"min-height":Ve,"max-height":Ve,"min-width":Ve,"max-width":Ve,bottom:Ve,left:Ve,top:Ve,right:Ve,"box-shadow":Ve,"text-shadow":Ve,"column-gap":Ve,"column-rule":Ve,"column-rule-width":Ve,"column-width":Ve,"font-size":Ve,"font-size-delta":Ve,"letter-spacing":Ve,"text-indent":Ve,"text-stroke":Ve,"text-stroke-width":Ve,"word-spacing":Ve,motion:Ve,"motion-offset":Ve,outline:Ve,"outline-offset":Ve,"outline-width":Ve,perspective:Ve,"perspective-origin-x":qe,"perspective-origin-y":qe,"transform-origin":qe,"transform-origin-x":qe,"transform-origin-y":qe,"transform-origin-z":qe,"transition-delay":He,"transition-duration":He,"vertical-align":Ve,"flex-basis":Ve,"shape-margin":Ve,size:Ve,grid:Ve,"grid-gap":Ve,"grid-row-gap":Ve,"grid-column-gap":Ve,"grid-template-rows":Ve,"grid-template-columns":Ve,"grid-auto-rows":Ve,"grid-auto-columns":Ve,"box-shadow-x":Ve,"box-shadow-y":Ve,"box-shadow-blur":Ve,"box-shadow-spread":Ve,"font-line-height":Ve,"text-shadow-x":Ve,"text-shadow-y":Ve,"text-shadow-blur":Ve});function Xe(e,t,n){if(!t)return t;if(Array.isArray(t))for(var r=0;r<t.length;r++)t[r]=Xe(e,t[r],n);else if("object"===typeof t)if("fallbacks"===e)for(var o in t)t[o]=Xe(o,t[o],n);else for(var a in t)t[a]=Xe(e+"-"+a,t[a],n);else if("number"===typeof t)return n[e]?""+t+n[e]:Qe[e]?"function"===typeof Qe[e]?Qe[e](t).toString():""+t+Qe[e]:t.toString();return t}var Ge=function(e){void 0===e&&(e={});var t=Ke(e);return{onProcessStyle:function(e,n){if("style"!==n.type)return e;for(var r in e)e[r]=Xe(r,e[r],t);return e},onChangeValue:function(e,n){return Xe(n,e,t)}}},Ye=n(11),Je="",Ze="",et="",tt=u&&"ontouchstart"in document.documentElement;if(u){var nt={Moz:"-moz-",ms:"-ms-",O:"-o-",Webkit:"-webkit-"},rt=document.createElement("p").style;for(var ot in nt)if(ot+"Transform"in rt){Je=ot,Ze=nt[ot];break}"Webkit"===Je&&"msHyphens"in rt&&(Je="ms",Ze=nt.ms,"edge"),"Webkit"===Je&&"-apple-trailing-word"in rt&&(et="apple")}var at=Je,it=Ze,lt=et,ut=tt;var ct={noPrefill:["appearance"],supportedProperty:function(e){return"appearance"===e&&("ms"===at?"-webkit-"+e:it+e)}},st={noPrefill:["color-adjust"],supportedProperty:function(e){return"color-adjust"===e&&("Webkit"===at?it+"print-"+e:e)}},dt=/[-\s]+(.)?/g;function ft(e,t){return t?t.toUpperCase():""}function pt(e){return e.replace(dt,ft)}function ht(e){return pt("-"+e)}var mt,vt={noPrefill:["mask"],supportedProperty:function(e,t){if(!/^mask/.test(e))return!1;if("Webkit"===at){if(pt("mask-image")in t)return e;if(at+ht("mask-image")in t)return it+e}return e}},bt={noPrefill:["text-orientation"],supportedProperty:function(e){return"text-orientation"===e&&("apple"!==lt||ut?e:it+e)}},yt={noPrefill:["transform"],supportedProperty:function(e,t,n){return"transform"===e&&(n.transform?e:it+e)}},gt={noPrefill:["transition"],supportedProperty:function(e,t,n){return"transition"===e&&(n.transition?e:it+e)}},xt={noPrefill:["writing-mode"],supportedProperty:function(e){return"writing-mode"===e&&("Webkit"===at||"ms"===at?it+e:e)}},wt={noPrefill:["user-select"],supportedProperty:function(e){return"user-select"===e&&("Moz"===at||"ms"===at||"apple"===lt?it+e:e)}},kt={supportedProperty:function(e,t){return!!/^break-/.test(e)&&("Webkit"===at?"WebkitColumn"+ht(e)in t&&it+"column-"+e:"Moz"===at&&("page"+ht(e)in t&&"page-"+e))}},Et={supportedProperty:function(e,t){if(!/^(border|margin|padding)-inline/.test(e))return!1;if("Moz"===at)return e;var n=e.replace("-inline","");return at+ht(n)in t&&it+n}},Ot={supportedProperty:function(e,t){return pt(e)in t&&e}},St={supportedProperty:function(e,t){var n=ht(e);return"-"===e[0]?e:"-"===e[0]&&"-"===e[1]?e:at+n in t?it+e:"Webkit"!==at&&"Webkit"+n in t&&"-webkit-"+e}},Ct={supportedProperty:function(e){return"scroll-snap"===e.substring(0,11)&&("ms"===at?""+it+e:e)}},Tt={supportedProperty:function(e){return"overscroll-behavior"===e&&("ms"===at?it+"scroll-chaining":e)}},jt={"flex-grow":"flex-positive","flex-shrink":"flex-negative","flex-basis":"flex-preferred-size","justify-content":"flex-pack",order:"flex-order","align-items":"flex-align","align-content":"flex-line-pack"},Pt={supportedProperty:function(e,t){var n=jt[e];return!!n&&(at+ht(n)in t&&it+n)}},Rt={flex:"box-flex","flex-grow":"box-flex","flex-direction":["box-orient","box-direction"],order:"box-ordinal-group","align-items":"box-align","flex-flow":["box-orient","box-direction"],"justify-content":"box-pack"},Nt=Object.keys(Rt),Mt=function(e){return it+e},_t=[ct,st,vt,bt,yt,gt,xt,wt,kt,Et,Ot,St,Ct,Tt,Pt,{supportedProperty:function(e,t,n){var r=n.multiple;if(Nt.indexOf(e)>-1){var o=Rt[e];if(!Array.isArray(o))return at+ht(o)in t&&it+o;if(!r)return!1;for(var a=0;a<o.length;a++)if(!(at+ht(o[0])in t))return!1;return o.map(Mt)}return!1}}],At=_t.filter((function(e){return e.supportedProperty})).map((function(e){return e.supportedProperty})),zt=_t.filter((function(e){return e.noPrefill})).reduce((function(e,t){return e.push.apply(e,Object(Ye.a)(t.noPrefill)),e}),[]),It={};if(u){mt=document.createElement("p");var Lt=window.getComputedStyle(document.documentElement,"");for(var Dt in Lt)isNaN(Dt)||(It[Lt[Dt]]=Lt[Dt]);zt.forEach((function(e){return delete It[e]}))}function Ft(e,t){if(void 0===t&&(t={}),!mt)return e;if(null!=It[e])return It[e];"transition"!==e&&"transform"!==e||(t[e]=e in mt.style);for(var n=0;n<At.length&&(It[e]=At[n](e,mt.style,t),!It[e]);n++);try{mt.style[e]=""}catch(r){return!1}return It[e]}var Ut,$t={},Bt={transition:1,"transition-property":1,"-webkit-transition":1,"-webkit-transition-property":1},Wt=/(^\s*[\w-]+)|, (\s*[\w-]+)(?![^()]*\))/g;function Vt(e,t,n){if("var"===t)return"var";if("all"===t)return"all";if("all"===n)return", all";var r=t?Ft(t):", "+Ft(n);return r||(t||n)}function Ht(e,t){var n=t;if(!Ut||"content"===e)return t;if("string"!==typeof n||!isNaN(parseInt(n,10)))return n;var r=e+n;if(null!=$t[r])return $t[r];try{Ut.style[e]=n}catch(o){return $t[r]=!1,!1}if(Bt[e])n=n.replace(Wt,Vt);else if(""===Ut.style[e]&&("-ms-flex"===(n=it+n)&&(Ut.style[e]="-ms-flexbox"),Ut.style[e]=n,""===Ut.style[e]))return $t[r]=!1,!1;return Ut.style[e]="",$t[r]=n,$t[r]}u&&(Ut=document.createElement("p"));var qt=function(){function e(t){for(var n in t){var r=t[n];if("fallbacks"===n&&Array.isArray(r))t[n]=r.map(e);else{var o=!1,a=Ft(n);a&&a!==n&&(o=!0);var i=!1,l=Ht(a,b(r));l&&l!==r&&(i=!0),(o||i)&&(o&&delete t[n],t[a||n]=l||r)}}return t}return{onProcessRule:function(e){if("keyframes"===e.type){var t=e;t.at="-"===(n=t.at)[1]?n:"ms"===at?n:"@"+it+"keyframes"+n.substr(10)}var n},onProcessStyle:function(t,n){return"style"!==n.type?t:e(t)},onChangeValue:function(e,t){return Ht(t,b(e))||e}}};var Kt=function(){var e=function(e,t){return e.length===t.length?e>t?1:-1:e.length-t.length};return{onProcessStyle:function(t,n){if("style"!==n.type)return t;for(var r={},o=Object.keys(t).sort(e),a=0;a<o.length;a++)r[o[a]]=t[o[a]];return r}}};var Qt=function(){return{plugins:[Ce(),Me(),Ie(),We(),Ge(),"undefined"===typeof window?null:qt(),Kt()]}},Xt=be(Qt()),Gt={disableGeneration:!1,generateClassName:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.disableGlobal,n=void 0!==t&&t,r=e.productionPrefix,o=void 0===r?"jss":r,a=e.seed,i=void 0===a?"":a,l=""===i?"":"".concat(i,"-"),u=0;return function(e,t){u+=1;var r=t.options.name;if(r&&0===r.indexOf("Mui")&&!t.options.link&&!n){if(-1!==ke.indexOf(e.key))return"Mui-".concat(e.key);var a="".concat(l).concat(r,"-").concat(e.key);return t.options.theme[we.a]&&""===i?"".concat(a,"-").concat(u):a}return"".concat(l).concat(o).concat(u)}}(),jss:Xt,sheetsCache:null,sheetsManager:new Map,sheetsRegistry:null},Yt=i.a.createContext(Gt);var Jt=-1e9;function Zt(){return Jt+=1}n(53);var en=n(162);var tn=function(e){var t="function"===typeof e;return{create:function(n,r){var a;try{a=t?e(n):e}catch(u){throw u}if(!r||!n.overrides||!n.overrides[r])return a;var i=n.overrides[r],l=Object(o.a)({},a);return Object.keys(i).forEach((function(e){l[e]=Object(en.a)(l[e],i[e])})),l},options:{}}},nn={};function rn(e,t,n){var r=e.state;if(e.stylesOptions.disableGeneration)return t||{};r.cacheClasses||(r.cacheClasses={value:null,lastProp:null,lastJSS:{}});var o=!1;return r.classes!==r.cacheClasses.lastJSS&&(r.cacheClasses.lastJSS=r.classes,o=!0),t!==r.cacheClasses.lastProp&&(r.cacheClasses.lastProp=t,o=!0),o&&(r.cacheClasses.value=Object(ye.a)({baseClasses:r.cacheClasses.lastJSS,newClasses:t,Component:n})),r.cacheClasses.value}function on(e,t){var n=e.state,r=e.theme,a=e.stylesOptions,i=e.stylesCreator,l=e.name;if(!a.disableGeneration){var u=ge.get(a.sheetsManager,i,r);u||(u={refs:0,staticSheet:null,dynamicStyles:null},ge.set(a.sheetsManager,i,r,u));var c=Object(o.a)({},i.options,{},a,{theme:r,flip:"boolean"===typeof a.flip?a.flip:"rtl"===r.direction});c.generateId=c.serverGenerateClassName||c.generateClassName;var s=a.sheetsRegistry;if(0===u.refs){var d;a.sheetsCache&&(d=ge.get(a.sheetsCache,i,r));var f=i.create(r,l);d||((d=a.jss.createStyleSheet(f,Object(o.a)({link:!1},c))).attach(),a.sheetsCache&&ge.set(a.sheetsCache,i,r,d)),s&&s.add(d),u.staticSheet=d,u.dynamicStyles=function e(t){var n=null;for(var r in t){var o=t[r],a=typeof o;if("function"===a)n||(n={}),n[r]=o;else if("object"===a&&null!==o&&!Array.isArray(o)){var i=e(o);i&&(n||(n={}),n[r]=i)}}return n}(f)}if(u.dynamicStyles){var p=a.jss.createStyleSheet(u.dynamicStyles,Object(o.a)({link:!0},c));p.update(t),p.attach(),n.dynamicSheet=p,n.classes=Object(ye.a)({baseClasses:u.staticSheet.classes,newClasses:p.classes}),s&&s.add(p)}else n.classes=u.staticSheet.classes;u.refs+=1}}function an(e,t){var n=e.state;n.dynamicSheet&&n.dynamicSheet.update(t)}function ln(e){var t=e.state,n=e.theme,r=e.stylesOptions,o=e.stylesCreator;if(!r.disableGeneration){var a=ge.get(r.sheetsManager,o,n);a.refs-=1;var i=r.sheetsRegistry;0===a.refs&&(ge.delete(r.sheetsManager,o,n),r.jss.removeStyleSheet(a.staticSheet),i&&i.remove(a.staticSheet)),t.dynamicSheet&&(r.jss.removeStyleSheet(t.dynamicSheet),i&&i.remove(t.dynamicSheet))}}function un(e,t){var n,r=i.a.useRef([]),o=i.a.useMemo((function(){return{}}),t);r.current!==o&&(r.current=o,n=e()),i.a.useEffect((function(){return function(){n&&n()}}),[o])}t.a=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.name,a=t.classNamePrefix,l=t.Component,u=t.defaultTheme,c=void 0===u?nn:u,s=Object(r.a)(t,["name","classNamePrefix","Component","defaultTheme"]),d=tn(e),f=n||a||"makeStyles";return d.options={index:Zt(),name:n,meta:f,classNamePrefix:f},function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=Object(xe.a)()||c,r=Object(o.a)({},i.a.useContext(Yt),{},s),a=i.a.useRef(),u=i.a.useRef();return un((function(){var o={name:n,state:{},stylesCreator:d,stylesOptions:r,theme:t};return on(o,e),u.current=!1,a.current=o,function(){ln(o)}}),[t,d]),i.a.useEffect((function(){u.current&&an(a.current,e),u.current=!0})),rn(a.current,e.classes,l)}}},,,,,,,,,,,,,,,,,,,,,,,,,,,function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(22),c=n(4),s=n(131),d=n(6),f=i.a.forwardRef((function(e,t){e.checked;var n=e.classes,a=e.className,c=e.control,f=e.disabled,p=(e.inputRef,e.label),h=e.labelPlacement,m=void 0===h?"end":h,v=(e.name,e.onChange,e.value,Object(o.a)(e,["checked","classes","className","control","disabled","inputRef","label","labelPlacement","name","onChange","value"])),b=Object(u.a)(),y=f;"undefined"===typeof y&&"undefined"!==typeof c.props.disabled&&(y=c.props.disabled),"undefined"===typeof y&&b&&(y=b.disabled);var g={disabled:y};return["checked","name","onChange","value","inputRef"].forEach((function(t){"undefined"===typeof c.props[t]&&"undefined"!==typeof e[t]&&(g[t]=e[t])})),i.a.createElement("label",Object(r.a)({className:Object(l.a)(n.root,a,"end"!==m&&n["labelPlacement".concat(Object(d.a)(m))],y&&n.disabled),ref:t},v),i.a.cloneElement(c,g),i.a.createElement(s.a,{component:"span",className:Object(l.a)(n.label,y&&n.disabled)},p))}));t.a=Object(c.a)((function(e){return{root:{display:"inline-flex",alignItems:"center",cursor:"pointer",verticalAlign:"middle",WebkitTapHighlightColor:"transparent",marginLeft:-11,marginRight:16,"&$disabled":{cursor:"default"}},labelPlacementStart:{flexDirection:"row-reverse",marginLeft:16,marginRight:-11},labelPlacementTop:{flexDirection:"column-reverse",marginLeft:16},labelPlacementBottom:{flexDirection:"column",marginLeft:16},disabled:{},label:{"&$disabled":{color:e.palette.text.disabled}}}}),{name:"MuiFormControlLabel"})(f)},function(e,t,n){"use strict";var r=n(1);t.a=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.baseClasses,n=e.newClasses;if(e.Component,!n)return t;var o=Object(r.a)({},t);return Object.keys(n).forEach((function(e){n[e]&&(o[e]="".concat(t[e]," ").concat(n[e]))})),o}},function(e,t,n){"use strict";n.d(t,"a",(function(){return i}));var r=n(1),o=n(53);function a(e){return e&&"object"===Object(o.a)(e)&&!Array.isArray(e)}function i(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{clone:!0},o=n.clone?Object(r.a)({},e):e;return a(e)&&a(t)&&Object.keys(t).forEach((function(r){"__proto__"!==r&&(a(t[r])&&r in e?o[r]=i(e[r],t[r],n):o[r]=t[r])})),o}},function(e,t,n){"use strict";t.a=function(e){var t=e.theme,n=e.name,r=e.props;if(!t||!t.props||!t.props[n])return r;var o,a=t.props[n];for(o in a)void 0===r[o]&&(r[o]=a[o]);return r}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(10),s=n(6),d=n(46),f=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,u=e.color,c=void 0===u?"secondary":u,f=e.disabled,p=void 0!==f&&f,h=e.edge,m=void 0!==h&&h,v=e.size,b=void 0===v?"medium":v,y=Object(o.a)(e,["classes","className","color","disabled","edge","size"]),g=i.a.createElement("span",{className:n.thumb});return i.a.createElement("span",{className:Object(l.a)(n.root,a,{start:n.edgeStart,end:n.edgeEnd}[m],{small:n["size".concat(Object(s.a)(b))]}[b])},i.a.createElement(d.a,Object(r.a)({type:"checkbox",icon:g,checkedIcon:g,classes:{root:Object(l.a)(n.switchBase,n["color".concat(Object(s.a)(c))]),input:n.input,checked:n.checked,disabled:n.disabled},ref:t,disabled:p},y)),i.a.createElement("span",{className:n.track}))}));t.a=Object(u.a)((function(e){return{root:{display:"inline-flex",width:58,height:38,overflow:"hidden",padding:12,boxSizing:"border-box",position:"relative",flexShrink:0,zIndex:0,verticalAlign:"middle"},edgeStart:{marginLeft:-8},edgeEnd:{marginRight:-8},switchBase:{position:"absolute",top:0,left:0,zIndex:1,color:"light"===e.palette.type?e.palette.grey[50]:e.palette.grey[400],transition:e.transitions.create(["left","transform"],{duration:e.transitions.duration.shortest}),"&$checked":{transform:"translateX(20px)"},"&$disabled":{color:"light"===e.palette.type?e.palette.grey[400]:e.palette.grey[800]},"&$checked + $track":{opacity:.5},"&$disabled + $track":{opacity:"light"===e.palette.type?.12:.1}},colorPrimary:{"&$checked":{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:"light"===e.palette.type?e.palette.grey[400]:e.palette.grey[800]},"&$checked + $track":{backgroundColor:e.palette.primary.main},"&$disabled + $track":{backgroundColor:"light"===e.palette.type?e.palette.common.black:e.palette.common.white}},colorSecondary:{"&$checked":{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:"light"===e.palette.type?e.palette.grey[400]:e.palette.grey[800]},"&$checked + $track":{backgroundColor:e.palette.secondary.main},"&$disabled + $track":{backgroundColor:"light"===e.palette.type?e.palette.common.black:e.palette.common.white}},sizeSmall:{width:40,height:24,padding:7,"& $thumb":{width:16,height:16},"& $switchBase":{padding:4,"&$checked":{transform:"translateX(16px)"}}},checked:{},disabled:{},input:{left:"-100%",width:"300%"},thumb:{boxShadow:e.shadows[1],backgroundColor:"currentColor",width:20,height:20,borderRadius:"50%"},track:{height:"100%",width:"100%",borderRadius:7,zIndex:-1,transition:e.transitions.create(["opacity","background-color"],{duration:e.transitions.duration.shortest}),backgroundColor:"light"===e.palette.type?e.palette.common.black:e.palette.common.white,opacity:"light"===e.palette.type?.38:.3}}}),{name:"MuiSwitch"})(f)},function(e,t,n){"use strict";var r=n(1),o=n(133),a=n(45);t.a=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return Object(o.a)(e,Object(r.a)({defaultTheme:a.a},t))}},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,u=e.component,c=void 0===u?"div":u,s=e.square,d=void 0!==s&&s,f=e.elevation,p=void 0===f?1:f,h=e.variant,m=void 0===h?"elevation":h,v=Object(r.a)(e,["classes","className","component","square","elevation","variant"]);return i.a.createElement(c,Object(o.a)({className:Object(l.a)(n.root,a,"outlined"===m?n.outlined:n["elevation".concat(p)],!d&&n.rounded),ref:t},v))}));t.a=Object(u.a)((function(e){var t={};return e.shadows.forEach((function(e,n){t["elevation".concat(n)]={boxShadow:e}})),Object(o.a)({root:{backgroundColor:e.palette.background.paper,color:e.palette.text.primary,transition:e.transitions.create("box-shadow")},rounded:{borderRadius:e.shape.borderRadius},outlined:{border:"1px solid ".concat(e.palette.divider)}},t)}),{name:"MuiPaper"})(c)},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=[0,1,2,3,4,5,6,7,8,9,10],s=["auto",!0,1,2,3,4,5,6,7,8,9,10,11,12];function d(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,n=parseFloat(e);return"".concat(n/t).concat(String(e).replace(String(n),"")||"px")}var f=i.a.forwardRef((function(e,t){var n=e.alignContent,a=void 0===n?"stretch":n,u=e.alignItems,c=void 0===u?"stretch":u,s=e.classes,d=e.className,f=e.component,p=void 0===f?"div":f,h=e.container,m=void 0!==h&&h,v=e.direction,b=void 0===v?"row":v,y=e.item,g=void 0!==y&&y,x=e.justify,w=void 0===x?"flex-start":x,k=e.lg,E=void 0!==k&&k,O=e.md,S=void 0!==O&&O,C=e.sm,T=void 0!==C&&C,j=e.spacing,P=void 0===j?0:j,R=e.wrap,N=void 0===R?"wrap":R,M=e.xl,_=void 0!==M&&M,A=e.xs,z=void 0!==A&&A,I=e.zeroMinWidth,L=void 0!==I&&I,D=Object(r.a)(e,["alignContent","alignItems","classes","className","component","container","direction","item","justify","lg","md","sm","spacing","wrap","xl","xs","zeroMinWidth"]),F=Object(l.a)(s.root,d,m&&[s.container,0!==P&&s["spacing-xs-".concat(String(P))]],g&&s.item,L&&s.zeroMinWidth,"row"!==b&&s["direction-xs-".concat(String(b))],"wrap"!==N&&s["wrap-xs-".concat(String(N))],"stretch"!==c&&s["align-items-xs-".concat(String(c))],"stretch"!==a&&s["align-content-xs-".concat(String(a))],"flex-start"!==w&&s["justify-xs-".concat(String(w))],!1!==z&&s["grid-xs-".concat(String(z))],!1!==T&&s["grid-sm-".concat(String(T))],!1!==S&&s["grid-md-".concat(String(S))],!1!==E&&s["grid-lg-".concat(String(E))],!1!==_&&s["grid-xl-".concat(String(_))]);return i.a.createElement(p,Object(o.a)({className:F,ref:t},D))})),p=Object(u.a)((function(e){return Object(o.a)({root:{},container:{boxSizing:"border-box",display:"flex",flexWrap:"wrap",width:"100%"},item:{boxSizing:"border-box",margin:"0"},zeroMinWidth:{minWidth:0},"direction-xs-column":{flexDirection:"column"},"direction-xs-column-reverse":{flexDirection:"column-reverse"},"direction-xs-row-reverse":{flexDirection:"row-reverse"},"wrap-xs-nowrap":{flexWrap:"nowrap"},"wrap-xs-wrap-reverse":{flexWrap:"wrap-reverse"},"align-items-xs-center":{alignItems:"center"},"align-items-xs-flex-start":{alignItems:"flex-start"},"align-items-xs-flex-end":{alignItems:"flex-end"},"align-items-xs-baseline":{alignItems:"baseline"},"align-content-xs-center":{alignContent:"center"},"align-content-xs-flex-start":{alignContent:"flex-start"},"align-content-xs-flex-end":{alignContent:"flex-end"},"align-content-xs-space-between":{alignContent:"space-between"},"align-content-xs-space-around":{alignContent:"space-around"},"justify-xs-center":{justifyContent:"center"},"justify-xs-flex-end":{justifyContent:"flex-end"},"justify-xs-space-between":{justifyContent:"space-between"},"justify-xs-space-around":{justifyContent:"space-around"},"justify-xs-space-evenly":{justifyContent:"space-evenly"}},function(e,t){var n={};return c.forEach((function(r){var o=e.spacing(r);0!==o&&(n["spacing-".concat(t,"-").concat(r)]={margin:"-".concat(d(o,2)),width:"calc(100% + ".concat(d(o),")"),"& > $item":{padding:d(o,2)}})})),n}(e,"xs"),{},e.breakpoints.keys.reduce((function(t,n){return function(e,t,n){var r={};s.forEach((function(e){var t="grid-".concat(n,"-").concat(e);if(!0!==e)if("auto"!==e){var o="".concat(Math.round(e/12*1e8)/1e6,"%");r[t]={flexBasis:o,flexGrow:0,maxWidth:o}}else r[t]={flexBasis:"auto",flexGrow:0,maxWidth:"none"};else r[t]={flexBasis:0,flexGrow:1,maxWidth:"100%"}})),"xs"===n?Object(o.a)(e,r):e[t.breakpoints.up(n)]=r}(t,e,n),t}),{}))}),{name:"MuiGrid"})(f);t.a=p},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(95),c=n(4),s=i.a.forwardRef((function(e,t){var n=e.disableUnderline,a=e.classes,c=e.fullWidth,s=void 0!==c&&c,d=e.inputComponent,f=void 0===d?"input":d,p=e.multiline,h=void 0!==p&&p,m=e.type,v=void 0===m?"text":m,b=Object(o.a)(e,["disableUnderline","classes","fullWidth","inputComponent","multiline","type"]);return i.a.createElement(u.a,Object(r.a)({classes:Object(r.a)({},a,{root:Object(l.a)(a.root,!n&&a.underline),underline:null}),fullWidth:s,inputComponent:f,multiline:h,ref:t,type:v},b))}));s.muiName="Input",t.a=Object(c.a)((function(e){var t="light"===e.palette.type?"rgba(0, 0, 0, 0.42)":"rgba(255, 255, 255, 0.7)";return{root:{position:"relative"},formControl:{"label + &":{marginTop:16}},focused:{},disabled:{},colorSecondary:{"&$underline:after":{borderBottomColor:e.palette.secondary.main}},underline:{"&:after":{borderBottom:"2px solid ".concat(e.palette.primary.main),left:0,bottom:0,content:'""',position:"absolute",right:0,transform:"scaleX(0)",transition:e.transitions.create("transform",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut}),pointerEvents:"none"},"&$focused:after":{transform:"scaleX(1)"},"&$error:after":{borderBottomColor:e.palette.error.main,transform:"scaleX(1)"},"&:before":{borderBottom:"1px solid ".concat(t),left:0,bottom:0,content:'"\\00a0"',position:"absolute",right:0,transition:e.transitions.create("border-bottom-color",{duration:e.transitions.duration.shorter}),pointerEvents:"none"},"&:hover:not($disabled):before":{borderBottom:"2px solid ".concat(e.palette.text.primary),"@media (hover: none)":{borderBottom:"1px solid ".concat(t)}},"&$disabled:before":{borderBottomStyle:"dotted"}},error:{},marginDense:{},multiline:{},fullWidth:{},input:{},inputMarginDense:{},inputMultiline:{},inputTypeSearch:{}}}),{name:"MuiInput"})(s)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(95),c=n(4),s=i.a.forwardRef((function(e,t){var n=e.disableUnderline,a=e.classes,c=e.fullWidth,s=void 0!==c&&c,d=e.inputComponent,f=void 0===d?"input":d,p=e.multiline,h=void 0!==p&&p,m=e.type,v=void 0===m?"text":m,b=Object(o.a)(e,["disableUnderline","classes","fullWidth","inputComponent","multiline","type"]);return i.a.createElement(u.a,Object(r.a)({classes:Object(r.a)({},a,{root:Object(l.a)(a.root,!n&&a.underline),underline:null}),fullWidth:s,inputComponent:f,multiline:h,ref:t,type:v},b))}));s.muiName="Input",t.a=Object(c.a)((function(e){var t="light"===e.palette.type,n=t?"rgba(0, 0, 0, 0.42)":"rgba(255, 255, 255, 0.7)",r=t?"rgba(0, 0, 0, 0.09)":"rgba(255, 255, 255, 0.09)";return{root:{position:"relative",backgroundColor:r,borderTopLeftRadius:e.shape.borderRadius,borderTopRightRadius:e.shape.borderRadius,transition:e.transitions.create("background-color",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut}),"&:hover":{backgroundColor:t?"rgba(0, 0, 0, 0.13)":"rgba(255, 255, 255, 0.13)","@media (hover: none)":{backgroundColor:r}},"&$focused":{backgroundColor:t?"rgba(0, 0, 0, 0.09)":"rgba(255, 255, 255, 0.09)"},"&$disabled":{backgroundColor:t?"rgba(0, 0, 0, 0.12)":"rgba(255, 255, 255, 0.12)"}},colorSecondary:{"&$underline:after":{borderBottomColor:e.palette.secondary.main}},underline:{"&:after":{borderBottom:"2px solid ".concat(e.palette.primary.main),left:0,bottom:0,content:'""',position:"absolute",right:0,transform:"scaleX(0)",transition:e.transitions.create("transform",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut}),pointerEvents:"none"},"&$focused:after":{transform:"scaleX(1)"},"&$error:after":{borderBottomColor:e.palette.error.main,transform:"scaleX(1)"},"&:before":{borderBottom:"1px solid ".concat(n),left:0,bottom:0,content:'"\\00a0"',position:"absolute",right:0,transition:e.transitions.create("border-bottom-color",{duration:e.transitions.duration.shorter}),pointerEvents:"none"},"&:hover:before":{borderBottom:"1px solid ".concat(e.palette.text.primary)},"&$disabled:before":{borderBottomStyle:"dotted"}},focused:{},disabled:{},adornedStart:{paddingLeft:12},adornedEnd:{paddingRight:12},error:{},marginDense:{},multiline:{padding:"27px 12px 10px","&$marginDense":{paddingTop:23,paddingBottom:6}},input:{padding:"27px 12px 10px","&:-webkit-autofill":{WebkitBoxShadow:"dark"===e.palette.type?"0 0 0 100px #266798 inset":null,WebkitTextFillColor:"dark"===e.palette.type?"#fff":null,borderTopLeftRadius:"inherit",borderTopRightRadius:"inherit"}},inputMarginDense:{paddingTop:23,paddingBottom:6},inputHiddenLabel:{paddingTop:18,paddingBottom:19,"&$inputMarginDense":{paddingTop:10,paddingBottom:11}},inputMultiline:{padding:0},inputAdornedStart:{paddingLeft:0},inputAdornedEnd:{paddingRight:0}}}),{name:"MuiFilledInput"})(s)},function(e,t,n){"use strict";var r=n(2),o=n(1),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=n(10),s=n(94),d=n(6),f=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,u=e.className,c=e.color,f=void 0===c?"default":c,p=e.component,h=void 0===p?"button":p,m=e.disabled,v=void 0!==m&&m,b=e.disableElevation,y=void 0!==b&&b,g=e.disableFocusRipple,x=void 0!==g&&g,w=e.endIcon,k=e.focusVisibleClassName,E=e.fullWidth,O=void 0!==E&&E,S=e.size,C=void 0===S?"medium":S,T=e.startIcon,j=e.type,P=void 0===j?"button":j,R=e.variant,N=void 0===R?"text":R,M=Object(r.a)(e,["children","classes","className","color","component","disabled","disableElevation","disableFocusRipple","endIcon","focusVisibleClassName","fullWidth","size","startIcon","type","variant"]),_=T&&i.a.createElement("span",{className:Object(l.a)(a.startIcon,a["iconSize".concat(Object(d.a)(C))])},T),A=w&&i.a.createElement("span",{className:Object(l.a)(a.endIcon,a["iconSize".concat(Object(d.a)(C))])},w);return i.a.createElement(s.a,Object(o.a)({className:Object(l.a)(a.root,a[N],u,"inherit"===f?a.colorInherit:"default"!==f&&a["".concat(N).concat(Object(d.a)(f))],"medium"!==C&&[a["".concat(N,"Size").concat(Object(d.a)(C))],a["size".concat(Object(d.a)(C))]],y&&a.disableElevation,v&&a.disabled,O&&a.fullWidth),component:h,disabled:v,focusRipple:!x,focusVisibleClassName:Object(l.a)(a.focusVisible,k),ref:t,type:P},M),i.a.createElement("span",{className:a.label},_,n,A))}));t.a=Object(u.a)((function(e){return{root:Object(o.a)({},e.typography.button,{boxSizing:"border-box",minWidth:64,padding:"6px 16px",borderRadius:e.shape.borderRadius,color:e.palette.text.primary,transition:e.transitions.create(["background-color","box-shadow","border"],{duration:e.transitions.duration.short}),"&:hover":{textDecoration:"none",backgroundColor:Object(c.b)(e.palette.text.primary,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"},"&$disabled":{backgroundColor:"transparent"}},"&$disabled":{color:e.palette.action.disabled}}),label:{width:"100%",display:"inherit",alignItems:"inherit",justifyContent:"inherit"},text:{padding:"6px 8px"},textPrimary:{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},textSecondary:{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},outlined:{padding:"5px 15px",border:"1px solid ".concat("light"===e.palette.type?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)"),"&$disabled":{border:"1px solid ".concat(e.palette.action.disabled)}},outlinedPrimary:{color:e.palette.primary.main,border:"1px solid ".concat(Object(c.b)(e.palette.primary.main,.5)),"&:hover":{border:"1px solid ".concat(e.palette.primary.main),backgroundColor:Object(c.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},outlinedSecondary:{color:e.palette.secondary.main,border:"1px solid ".concat(Object(c.b)(e.palette.secondary.main,.5)),"&:hover":{border:"1px solid ".concat(e.palette.secondary.main),backgroundColor:Object(c.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},"&$disabled":{border:"1px solid ".concat(e.palette.action.disabled)}},contained:{color:e.palette.getContrastText(e.palette.grey[300]),backgroundColor:e.palette.grey[300],boxShadow:e.shadows[2],"&:hover":{backgroundColor:e.palette.grey.A100,boxShadow:e.shadows[4],"@media (hover: none)":{boxShadow:e.shadows[2],backgroundColor:e.palette.grey[300]},"&$disabled":{backgroundColor:e.palette.action.disabledBackground}},"&$focusVisible":{boxShadow:e.shadows[6]},"&:active":{boxShadow:e.shadows[8]},"&$disabled":{color:e.palette.action.disabled,boxShadow:e.shadows[0],backgroundColor:e.palette.action.disabledBackground}},containedPrimary:{color:e.palette.primary.contrastText,backgroundColor:e.palette.primary.main,"&:hover":{backgroundColor:e.palette.primary.dark,"@media (hover: none)":{backgroundColor:e.palette.primary.main}}},containedSecondary:{color:e.palette.secondary.contrastText,backgroundColor:e.palette.secondary.main,"&:hover":{backgroundColor:e.palette.secondary.dark,"@media (hover: none)":{backgroundColor:e.palette.secondary.main}}},disableElevation:{boxShadow:"none","&:hover":{boxShadow:"none"},"&$focusVisible":{boxShadow:"none"},"&:active":{boxShadow:"none"},"&$disabled":{boxShadow:"none"}},focusVisible:{},disabled:{},colorInherit:{color:"inherit",borderColor:"currentColor"},textSizeSmall:{padding:"4px 5px",fontSize:e.typography.pxToRem(13)},textSizeLarge:{padding:"8px 11px",fontSize:e.typography.pxToRem(15)},outlinedSizeSmall:{padding:"3px 9px",fontSize:e.typography.pxToRem(13)},outlinedSizeLarge:{padding:"7px 21px",fontSize:e.typography.pxToRem(15)},containedSizeSmall:{padding:"4px 10px",fontSize:e.typography.pxToRem(13)},containedSizeLarge:{padding:"8px 22px",fontSize:e.typography.pxToRem(15)},sizeSmall:{},sizeLarge:{},fullWidth:{width:"100%"},startIcon:{display:"inherit",marginRight:8,marginLeft:-4,"&$iconSizeSmall":{marginLeft:-2}},endIcon:{display:"inherit",marginRight:-4,marginLeft:8,"&$iconSizeSmall":{marginRight:-2}},iconSizeSmall:{"& > *:first-child":{fontSize:18}},iconSizeMedium:{"& > *:first-child":{fontSize:20}},iconSizeLarge:{"& > *:first-child":{fontSize:22}}}}),{name:"MuiButton"})(f)},function(e,t,n){"use strict";var r=n(1),o=n(0),a=n.n(o),i=(n(5),n(57)),l=n(93),u=n(58);t.a=function(e){var t=e.children,n=e.theme,o=Object(l.a)(),c=a.a.useMemo((function(){var e=null===o?n:function(e,t){return"function"===typeof t?t(e):Object(r.a)({},e,{},t)}(o,n);return null!=e&&(e[u.a]=null!==o),e}),[n,o]);return a.a.createElement(i.a.Provider,{value:c},t)}},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(161)),u=n(11),c=n(53),s=(n(44),n(3)),d=n(6),f=n(4),p=n(9),h=n.n(p),m=n(61);var v=function(e){return e&&e.ownerDocument||document};var b=function(e){return v(e).defaultView||window},y=n(42),g=n(93),x=n(163),w=n(35),k=n(8);var E="undefined"!==typeof window?i.a.useLayoutEffect:i.a.useEffect;var O=i.a.forwardRef((function(e,t){var n=e.children,r=e.container,o=e.disablePortal,a=void 0!==o&&o,l=e.onRendered,u=i.a.useState(null),c=u[0],s=u[1],d=Object(k.a)(i.a.isValidElement(n)?n.ref:null,t);return E((function(){a||s(function(e){return e="function"===typeof e?e():e,h.a.findDOMNode(e)}(r)||document.body)}),[r,a]),E((function(){if(c&&!a)return Object(w.a)(t,c),function(){Object(w.a)(t,null)}}),[t,c,a]),E((function(){l&&(c||a)&&l()}),[l,c,a]),a?i.a.isValidElement(n)?i.a.cloneElement(n,{ref:d}):n:c?h.a.createPortal(n,c):c})),S=n(30),C=n(59);var T=n(48);var j=function(){var e=document.createElement("div");e.style.width="99px",e.style.height="99px",e.style.position="absolute",e.style.top="-9999px",e.style.overflow="scroll",document.body.appendChild(e);var t=e.offsetWidth-e.clientWidth;return document.body.removeChild(e),t};function P(e,t){t?e.setAttribute("aria-hidden","true"):e.removeAttribute("aria-hidden")}function R(e){return parseInt(window.getComputedStyle(e)["padding-right"],10)||0}function N(e,t,n){var r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],o=arguments.length>4?arguments[4]:void 0,a=[t,n].concat(Object(u.a)(r)),i=["TEMPLATE","SCRIPT","STYLE"];[].forEach.call(e.children,(function(e){1===e.nodeType&&-1===a.indexOf(e)&&-1===i.indexOf(e.tagName)&&P(e,o)}))}function M(e,t){var n=-1;return e.some((function(e,r){return!!t(e)&&(n=r,!0)})),n}function _(e,t){var n,r=[],o=[],a=e.container;if(!t.disableScrollLock){if(function(e){var t=v(e);return t.body===e?b(t).innerWidth>t.documentElement.clientWidth:e.scrollHeight>e.clientHeight}(a)){var i=j();r.push({value:a.style.paddingRight,key:"padding-right",el:a}),a.style["padding-right"]="".concat(R(a)+i,"px"),n=v(a).querySelectorAll(".mui-fixed"),[].forEach.call(n,(function(e){o.push(e.style.paddingRight),e.style.paddingRight="".concat(R(e)+i,"px")}))}var l=a.parentElement,u="HTML"===l.nodeName&&"scroll"===window.getComputedStyle(l)["overflow-y"]?l:a;r.push({value:u.style.overflow,key:"overflow",el:u}),u.style.overflow="hidden"}return function(){n&&[].forEach.call(n,(function(e,t){o[t]?e.style.paddingRight=o[t]:e.style.removeProperty("padding-right")})),r.forEach((function(e){var t=e.value,n=e.el,r=e.key;t?n.style.setProperty(r,t):n.style.removeProperty(r)}))}}var A=function(){function e(){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.modals=[],this.containers=[]}return Object(T.a)(e,[{key:"add",value:function(e,t){var n=this.modals.indexOf(e);if(-1!==n)return n;n=this.modals.length,this.modals.push(e),e.modalRef&&P(e.modalRef,!1);var r=function(e){var t=[];return[].forEach.call(e.children,(function(e){e.getAttribute&&"true"===e.getAttribute("aria-hidden")&&t.push(e)})),t}(t);N(t,e.mountNode,e.modalRef,r,!0);var o=M(this.containers,(function(e){return e.container===t}));return-1!==o?(this.containers[o].modals.push(e),n):(this.containers.push({modals:[e],container:t,restore:null,hiddenSiblingNodes:r}),n)}},{key:"mount",value:function(e,t){var n=M(this.containers,(function(t){return-1!==t.modals.indexOf(e)})),r=this.containers[n];r.restore||(r.restore=_(r,t))}},{key:"remove",value:function(e){var t=this.modals.indexOf(e);if(-1===t)return t;var n=M(this.containers,(function(t){return-1!==t.modals.indexOf(e)})),r=this.containers[n];if(r.modals.splice(r.modals.indexOf(e),1),this.modals.splice(t,1),0===r.modals.length)r.restore&&r.restore(),e.modalRef&&P(e.modalRef,!0),N(r.container,e.mountNode,e.modalRef,r.hiddenSiblingNodes,!1),this.containers.splice(n,1);else{var o=r.modals[r.modals.length-1];o.modalRef&&P(o.modalRef,!1)}return t}},{key:"isTopModal",value:function(e){return this.modals.length>0&&this.modals[this.modals.length-1]===e}}]),e}();var z=function(e){var t=e.children,n=e.disableAutoFocus,r=void 0!==n&&n,o=e.disableEnforceFocus,a=void 0!==o&&o,l=e.disableRestoreFocus,u=void 0!==l&&l,c=e.getDoc,s=e.isEnabled,d=e.open,f=i.a.useRef(),p=i.a.useRef(null),m=i.a.useRef(null),b=i.a.useRef(),y=i.a.useRef(null),g=i.a.useCallback((function(e){y.current=h.a.findDOMNode(e)}),[]),x=Object(k.a)(t.ref,g);return i.a.useMemo((function(){d&&"undefined"!==typeof window&&(b.current=c().activeElement)}),[d]),i.a.useEffect((function(){if(d){var e=v(y.current);r||!y.current||y.current.contains(e.activeElement)||(y.current.hasAttribute("tabIndex")||y.current.setAttribute("tabIndex",-1),y.current.focus());var t=function(){a||!s()||f.current?f.current=!1:y.current&&!y.current.contains(e.activeElement)&&y.current.focus()},n=function(t){!a&&s()&&9===t.keyCode&&e.activeElement===y.current&&(f.current=!0,t.shiftKey?m.current.focus():p.current.focus())};e.addEventListener("focus",t,!0),e.addEventListener("keydown",n,!0);var o=setInterval((function(){t()}),50);return function(){clearInterval(o),e.removeEventListener("focus",t,!0),e.removeEventListener("keydown",n,!0),u||(b.current&&b.current.focus&&b.current.focus(),b.current=null)}}}),[r,a,u,s,d]),i.a.createElement(i.a.Fragment,null,i.a.createElement("div",{tabIndex:0,ref:p,"data-test":"sentinelStart"}),i.a.cloneElement(t,{ref:x}),i.a.createElement("div",{tabIndex:0,ref:m,"data-test":"sentinelEnd"}))},I={root:{zIndex:-1,position:"fixed",right:0,bottom:0,top:0,left:0,backgroundColor:"rgba(0, 0, 0, 0.5)",WebkitTapHighlightColor:"transparent",touchAction:"none"},invisible:{backgroundColor:"transparent"}},L=i.a.forwardRef((function(e,t){var n=e.invisible,a=void 0!==n&&n,l=e.open,u=Object(o.a)(e,["invisible","open"]);return l?i.a.createElement("div",Object(r.a)({"aria-hidden":!0,ref:t},u,{style:Object(r.a)({},I.root,{},a?I.invisible:{},{},u.style)})):null}));var D=new A,F=i.a.forwardRef((function(e,t){var n=Object(g.a)(),a=Object(x.a)({name:"MuiModal",props:Object(r.a)({},e),theme:n}),l=a.BackdropComponent,u=void 0===l?L:l,c=a.BackdropProps,s=a.children,d=a.closeAfterTransition,f=void 0!==d&&d,p=a.container,m=a.disableAutoFocus,b=void 0!==m&&m,w=a.disableBackdropClick,E=void 0!==w&&w,T=a.disableEnforceFocus,j=void 0!==T&&T,R=a.disableEscapeKeyDown,N=void 0!==R&&R,M=a.disablePortal,_=void 0!==M&&M,A=a.disableRestoreFocus,I=void 0!==A&&A,F=a.disableScrollLock,U=void 0!==F&&F,$=a.hideBackdrop,B=void 0!==$&&$,W=a.keepMounted,V=void 0!==W&&W,H=a.manager,q=void 0===H?D:H,K=a.onBackdropClick,Q=a.onClose,X=a.onEscapeKeyDown,G=a.onRendered,Y=a.open,J=Object(o.a)(a,["BackdropComponent","BackdropProps","children","closeAfterTransition","container","disableAutoFocus","disableBackdropClick","disableEnforceFocus","disableEscapeKeyDown","disablePortal","disableRestoreFocus","disableScrollLock","hideBackdrop","keepMounted","manager","onBackdropClick","onClose","onEscapeKeyDown","onRendered","open"]),Z=i.a.useState(!0),ee=Z[0],te=Z[1],ne=i.a.useRef({}),re=i.a.useRef(null),oe=i.a.useRef(null),ae=Object(k.a)(oe,t),ie=function(e){return!!e.children&&e.children.props.hasOwnProperty("in")}(a),le=function(){return v(re.current)},ue=function(){return ne.current.modalRef=oe.current,ne.current.mountNode=re.current,ne.current},ce=function(){q.mount(ue(),{disableScrollLock:U}),oe.current.scrollTop=0},se=Object(S.a)((function(){var e=function(e){return e="function"===typeof e?e():e,h.a.findDOMNode(e)}(p)||le().body;q.add(ue(),e),oe.current&&ce()})),de=i.a.useCallback((function(){return q.isTopModal(ue())}),[q]),fe=Object(S.a)((function(e){re.current=e,e&&(G&&G(),Y&&de()?ce():P(oe.current,!0))})),pe=i.a.useCallback((function(){q.remove(ue())}),[q]);if(i.a.useEffect((function(){return function(){pe()}}),[pe]),i.a.useEffect((function(){Y?se():ie&&f||pe()}),[Y,pe,ie,f,se]),!V&&!Y&&(!ie||ee))return null;var he=function(e){return{root:{position:"fixed",zIndex:e.zIndex.modal,right:0,bottom:0,top:0,left:0},hidden:{visibility:"hidden"}}}(n||{zIndex:C.a}),me={};return void 0===s.props.tabIndex&&(me.tabIndex=s.props.tabIndex||"-1"),ie&&(me.onEnter=Object(y.a)((function(){te(!1)}),s.props.onEnter),me.onExited=Object(y.a)((function(){te(!0),f&&pe()}),s.props.onExited)),i.a.createElement(O,{ref:fe,container:p,disablePortal:_},i.a.createElement("div",Object(r.a)({ref:ae,onKeyDown:function(e){"Escape"===e.key&&de()&&(e.stopPropagation(),X&&X(e),!N&&Q&&Q(e,"escapeKeyDown"))},role:"presentation"},J,{style:Object(r.a)({},he.root,{},!Y&&ee?he.hidden:{},{},J.style)}),B?null:i.a.createElement(u,Object(r.a)({open:Y,onClick:function(e){e.target===e.currentTarget&&(K&&K(e),!E&&Q&&Q(e,"backdropClick"))}},c)),i.a.createElement(z,{disableEnforceFocus:j,disableAutoFocus:b,disableRestoreFocus:I,getDoc:le,isEnabled:de,open:Y},i.a.cloneElement(s,me))))})),U=n(15),$=n(12),B=!1,W=n(43),V=function(e){function t(t,n){var r;r=e.call(this,t,n)||this;var o,a=n&&!n.isMounting?t.enter:t.appear;return r.appearStatus=null,t.in?a?(o="exited",r.appearStatus="entering"):o="entered":o=t.unmountOnExit||t.mountOnEnter?"unmounted":"exited",r.state={status:o},r.nextCallback=null,r}Object($.a)(t,e),t.getDerivedStateFromProps=function(e,t){return e.in&&"unmounted"===t.status?{status:"exited"}:null};var n=t.prototype;return n.componentDidMount=function(){this.updateStatus(!0,this.appearStatus)},n.componentDidUpdate=function(e){var t=null;if(e!==this.props){var n=this.state.status;this.props.in?"entering"!==n&&"entered"!==n&&(t="entering"):"entering"!==n&&"entered"!==n||(t="exiting")}this.updateStatus(!1,t)},n.componentWillUnmount=function(){this.cancelNextCallback()},n.getTimeouts=function(){var e,t,n,r=this.props.timeout;return e=t=n=r,null!=r&&"number"!==typeof r&&(e=r.exit,t=r.enter,n=void 0!==r.appear?r.appear:t),{exit:e,enter:t,appear:n}},n.updateStatus=function(e,t){if(void 0===e&&(e=!1),null!==t){this.cancelNextCallback();var n=h.a.findDOMNode(this);"entering"===t?this.performEnter(n,e):this.performExit(n)}else this.props.unmountOnExit&&"exited"===this.state.status&&this.setState({status:"unmounted"})},n.performEnter=function(e,t){var n=this,r=this.props.enter,o=this.context?this.context.isMounting:t,a=this.getTimeouts(),i=o?a.appear:a.enter;!t&&!r||B?this.safeSetState({status:"entered"},(function(){n.props.onEntered(e)})):(this.props.onEnter(e,o),this.safeSetState({status:"entering"},(function(){n.props.onEntering(e,o),n.onTransitionEnd(e,i,(function(){n.safeSetState({status:"entered"},(function(){n.props.onEntered(e,o)}))}))})))},n.performExit=function(e){var t=this,n=this.props.exit,r=this.getTimeouts();n&&!B?(this.props.onExit(e),this.safeSetState({status:"exiting"},(function(){t.props.onExiting(e),t.onTransitionEnd(e,r.exit,(function(){t.safeSetState({status:"exited"},(function(){t.props.onExited(e)}))}))}))):this.safeSetState({status:"exited"},(function(){t.props.onExited(e)}))},n.cancelNextCallback=function(){null!==this.nextCallback&&(this.nextCallback.cancel(),this.nextCallback=null)},n.safeSetState=function(e,t){t=this.setNextCallback(t),this.setState(e,t)},n.setNextCallback=function(e){var t=this,n=!0;return this.nextCallback=function(r){n&&(n=!1,t.nextCallback=null,e(r))},this.nextCallback.cancel=function(){n=!1},this.nextCallback},n.onTransitionEnd=function(e,t,n){this.setNextCallback(n);var r=null==t&&!this.props.addEndListener;e&&!r?(this.props.addEndListener&&this.props.addEndListener(e,this.nextCallback),null!=t&&setTimeout(this.nextCallback,t)):setTimeout(this.nextCallback,0)},n.render=function(){var e=this.state.status;if("unmounted"===e)return null;var t=this.props,n=t.children,r=Object(U.a)(t,["children"]);if(delete r.in,delete r.mountOnEnter,delete r.unmountOnExit,delete r.appear,delete r.enter,delete r.exit,delete r.timeout,delete r.addEndListener,delete r.onEnter,delete r.onEntering,delete r.onEntered,delete r.onExit,delete r.onExiting,delete r.onExited,"function"===typeof n)return i.a.createElement(W.a.Provider,{value:null},n(e,r));var o=i.a.Children.only(n);return(i.a.createElement(W.a.Provider,{value:null},i.a.cloneElement(o,r)))},t}(i.a.Component);function H(){}V.contextType=W.a,V.propTypes={},V.defaultProps={in:!1,mountOnEnter:!1,unmountOnExit:!1,appear:!1,enter:!0,exit:!0,onEnter:H,onEntering:H,onEntered:H,onExit:H,onExiting:H,onExited:H},V.UNMOUNTED=0,V.EXITED=1,V.ENTERING=2,V.ENTERED=3,V.EXITING=4;var q=V,K=n(47);function Q(e,t){var n=e.timeout,r=e.style,o=void 0===r?{}:r;return{duration:o.transitionDuration||"number"===typeof n?n:n[t.mode]||0,delay:o.transitionDelay}}function X(e){return"scale(".concat(e,", ").concat(Math.pow(e,2),")")}var G={entering:{opacity:1,transform:X(1)},entered:{opacity:1,transform:"none"}},Y=i.a.forwardRef((function(e,t){var n=e.children,a=e.in,l=e.onEnter,u=e.onExit,c=e.style,s=e.timeout,d=void 0===s?"auto":s,f=Object(o.a)(e,["children","in","onEnter","onExit","style","timeout"]),p=i.a.useRef(),h=i.a.useRef(),m=Object(k.a)(n.ref,t),v=Object(K.a)();return i.a.useEffect((function(){return function(){clearTimeout(p.current)}}),[]),i.a.createElement(q,Object(r.a)({appear:!0,in:a,onEnter:function(e,t){!function(e){e.scrollTop}(e);var n,r=Q({style:c,timeout:d},{mode:"enter"}),o=r.duration,a=r.delay;"auto"===d?(n=v.transitions.getAutoHeightDuration(e.clientHeight),h.current=n):n=o,e.style.transition=[v.transitions.create("opacity",{duration:n,delay:a}),v.transitions.create("transform",{duration:.666*n,delay:a})].join(","),l&&l(e,t)},onExit:function(e){var t,n=Q({style:c,timeout:d},{mode:"exit"}),r=n.duration,o=n.delay;"auto"===d?(t=v.transitions.getAutoHeightDuration(e.clientHeight),h.current=t):t=r,e.style.transition=[v.transitions.create("opacity",{duration:t,delay:o}),v.transitions.create("transform",{duration:.666*t,delay:o||.333*t})].join(","),e.style.opacity="0",e.style.transform=X(.75),u&&u(e)},addEndListener:function(e,t){"auto"===d&&(p.current=setTimeout(t,h.current||0))},timeout:"auto"===d?null:d},f),(function(e,t){return i.a.cloneElement(n,Object(r.a)({style:Object(r.a)({opacity:0,transform:X(.75),visibility:"exited"!==e||a?void 0:"hidden"},G[e],{},c,{},n.props.style),ref:m},t))}))}));Y.muiSupportAuto=!0;var J=Y,Z=n(166);function ee(e,t){var n=0;return"number"===typeof t?n=t:"center"===t?n=e.height/2:"bottom"===t&&(n=e.height),n}function te(e,t){var n=0;return"number"===typeof t?n=t:"center"===t?n=e.width/2:"right"===t&&(n=e.width),n}function ne(e){return[e.horizontal,e.vertical].map((function(e){return"number"===typeof e?"".concat(e,"px"):e})).join(" ")}function re(e){return"function"===typeof e?e():e}var oe=i.a.forwardRef((function(e,t){var n=e.action,a=e.anchorEl,l=e.anchorOrigin,u=void 0===l?{vertical:"top",horizontal:"left"}:l,c=e.anchorPosition,d=e.anchorReference,f=void 0===d?"anchorEl":d,p=e.children,g=e.classes,x=e.className,w=e.container,k=e.elevation,E=void 0===k?8:k,O=e.getContentAnchorEl,S=e.marginThreshold,C=void 0===S?16:S,T=e.onEnter,j=e.onEntered,P=e.onEntering,R=e.onExit,N=e.onExited,M=e.onExiting,_=e.open,A=e.PaperProps,z=void 0===A?{}:A,I=e.transformOrigin,L=void 0===I?{vertical:"top",horizontal:"left"}:I,D=e.TransitionComponent,U=void 0===D?J:D,$=e.transitionDuration,B=void 0===$?"auto":$,W=e.TransitionProps,V=void 0===W?{}:W,H=Object(o.a)(e,["action","anchorEl","anchorOrigin","anchorPosition","anchorReference","children","classes","className","container","elevation","getContentAnchorEl","marginThreshold","onEnter","onEntered","onEntering","onExit","onExited","onExiting","open","PaperProps","transformOrigin","TransitionComponent","transitionDuration","TransitionProps"]),q=i.a.useRef(),K=i.a.useCallback((function(e){if("anchorPosition"===f)return c;var t=re(a),n=(t instanceof b(t).Element?t:v(q.current).body).getBoundingClientRect(),r=0===e?u.vertical:"center";return{top:n.top+ee(n,r),left:n.left+te(n,u.horizontal)}}),[a,u.horizontal,u.vertical,c,f]),Q=i.a.useCallback((function(e){var t=0;if(O&&"anchorEl"===f){var n=O(e);if(n&&e.contains(n)){var r=function(e,t){for(var n=t,r=0;n&&n!==e;)r+=(n=n.parentElement).scrollTop;return r}(e,n);t=n.offsetTop+n.clientHeight/2-r||0}0}return t}),[u.vertical,f,O]),X=i.a.useCallback((function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return{vertical:ee(e,L.vertical)+t,horizontal:te(e,L.horizontal)}}),[L.horizontal,L.vertical]),G=i.a.useCallback((function(e){var t=Q(e),n={width:e.offsetWidth,height:e.offsetHeight},r=X(n,t);if("none"===f)return{top:null,left:null,transformOrigin:ne(r)};var o=K(t),i=o.top-r.vertical,l=o.left-r.horizontal,u=i+n.height,c=l+n.width,s=b(re(a)),d=s.innerHeight-C,p=s.innerWidth-C;if(i<C){var h=i-C;i-=h,r.vertical+=h}else if(u>d){var m=u-d;i-=m,r.vertical+=m}if(l<C){var v=l-C;l-=v,r.horizontal+=v}else if(c>p){var y=c-p;l-=y,r.horizontal+=y}return{top:"".concat(Math.round(i),"px"),left:"".concat(Math.round(l),"px"),transformOrigin:ne(r)}}),[a,f,K,Q,X,C]),Y=i.a.useCallback((function(){var e=q.current;if(e){var t=G(e);null!==t.top&&(e.style.top=t.top),null!==t.left&&(e.style.left=t.left),e.style.transformOrigin=t.transformOrigin}}),[G]),oe=i.a.useCallback((function(e){q.current=h.a.findDOMNode(e)}),[]);i.a.useEffect((function(){_&&Y()})),i.a.useImperativeHandle(n,(function(){return _?{updatePosition:function(){Y()}}:null}),[_,Y]),i.a.useEffect((function(){if(_){var e=Object(m.a)((function(){Y()}));return window.addEventListener("resize",e),function(){e.clear(),window.removeEventListener("rezise",e)}}}),[_,Y]);var ae=B;"auto"!==B||U.muiSupportAuto||(ae=void 0);var ie=w||(a?v(re(a)).body:void 0);return i.a.createElement(F,Object(r.a)({container:ie,open:_,ref:t,BackdropProps:{invisible:!0},className:Object(s.a)(g.root,x)},H),i.a.createElement(U,Object(r.a)({appear:!0,in:_,onEnter:T,onEntered:j,onExit:R,onExited:N,onExiting:M,timeout:ae},V,{onEntering:Object(y.a)((function(e,t){P&&P(e,t),Y()}),V.onEntering)}),i.a.createElement(Z.a,Object(r.a)({elevation:E,ref:oe},z,{className:Object(s.a)(g.paper,z.className)}),p)))})),ae=Object(f.a)({root:{},paper:{position:"absolute",overflowY:"auto",overflowX:"hidden",minWidth:16,minHeight:16,maxWidth:"calc(100% - 32px)",maxHeight:"calc(100% - 32px)",outline:0}},{name:"MuiPopover"})(oe),ie=n(51),le=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.className,u=e.component,c=void 0===u?"ul":u,d=e.dense,f=void 0!==d&&d,p=e.disablePadding,h=void 0!==p&&p,m=e.subheader,v=Object(o.a)(e,["children","classes","className","component","dense","disablePadding","subheader"]),b=i.a.useMemo((function(){return{dense:f}}),[f]);return i.a.createElement(ie.a.Provider,{value:b},i.a.createElement(c,Object(r.a)({className:Object(s.a)(a.root,l,f&&a.dense,!h&&a.padding,m&&a.subheader),ref:t},v),m,n))})),ue=Object(f.a)({root:{listStyle:"none",margin:0,padding:0,position:"relative"},padding:{paddingTop:8,paddingBottom:8},dense:{},subheader:{paddingTop:0}},{name:"MuiList"})(le);function ce(e,t,n){return e===t?e.firstChild:t&&t.nextElementSibling?t.nextElementSibling:n?null:e.firstChild}function se(e,t,n){return e===t?n?e.firstChild:e.lastChild:t&&t.previousElementSibling?t.previousElementSibling:n?null:e.lastChild}function de(e,t){if(void 0===t)return!0;var n=e.innerText;return void 0===n&&(n=e.textContent),0!==(n=n.trim().toLowerCase()).length&&(t.repeating?n[0]===t.keys[0]:0===n.indexOf(t.keys.join("")))}function fe(e,t,n,r,o){for(var a=!1,i=r(e,t,!!t&&n);i;){if(i===e.firstChild){if(a)return!1;a=!0}if(i.hasAttribute("tabindex")&&!i.disabled&&"true"!==i.getAttribute("aria-disabled")&&de(i,o))return i.focus(),!0;i=r(e,i,n)}return!1}var pe="undefined"===typeof window?i.a.useEffect:i.a.useLayoutEffect,he=i.a.forwardRef((function(e,t){var n=e.actions,a=e.autoFocus,l=void 0!==a&&a,u=e.autoFocusItem,c=void 0!==u&&u,s=e.children,d=e.className,f=e.onKeyDown,p=e.disableListWrap,m=void 0!==p&&p,b=e.variant,y=void 0===b?"selectedMenu":b,g=Object(o.a)(e,["actions","autoFocus","autoFocusItem","children","className","onKeyDown","disableListWrap","variant"]),x=i.a.useRef(null),w=i.a.useRef({keys:[],repeating:!0,previousKeyMatched:!0,lastTime:null});pe((function(){l&&x.current.focus()}),[l]),i.a.useImperativeHandle(n,(function(){return{adjustStyleForScrollbar:function(e,t){var n=!x.current.style.width;if(e.clientHeight<x.current.clientHeight&&n){var r="".concat(j(!0),"px");x.current.style["rtl"===t.direction?"paddingLeft":"paddingRight"]=r,x.current.style.width="calc(100% + ".concat(r,")")}return x.current}}}),[]);var E=i.a.useCallback((function(e){x.current=h.a.findDOMNode(e)}),[]),O=Object(k.a)(E,t),S=-1;i.a.Children.forEach(s,(function(e,t){i.a.isValidElement(e)&&(e.props.disabled||("selectedMenu"===y&&e.props.selected?S=t:-1===S&&(S=t)))}));var C=i.a.Children.map(s,(function(e,t){if(t===S){var n={};if(c&&(n.autoFocus=!0),void 0===e.props.tabIndex&&"selectedMenu"===y&&(n.tabIndex=0),null!==n)return i.a.cloneElement(e,n)}return e}));return i.a.createElement(ue,Object(r.a)({role:"menu",ref:O,className:d,onKeyDown:function(e){var t=x.current,n=e.key,r=v(t).activeElement;if("ArrowDown"===n)e.preventDefault(),fe(t,r,m,ce);else if("ArrowUp"===n)e.preventDefault(),fe(t,r,m,se);else if("Home"===n)e.preventDefault(),fe(t,null,m,ce);else if("End"===n)e.preventDefault(),fe(t,null,m,se);else if(1===n.length){var o=w.current,a=n.toLowerCase(),i=performance.now();o.keys.length>0&&(i-o.lastTime>500?(o.keys=[],o.repeating=!0,o.previousKeyMatched=!0):o.repeating&&a!==o.keys[0]&&(o.repeating=!1)),o.lastTime=i,o.keys.push(a);var l=r&&!o.repeating&&de(r,o);o.previousKeyMatched&&(l||fe(t,r,!1,ce,o))?e.preventDefault():o.previousKeyMatched=!1}f&&f(e)},tabIndex:l?0:-1},g),C)})),me={vertical:"top",horizontal:"right"},ve={vertical:"top",horizontal:"left"},be=i.a.forwardRef((function(e,t){var n=e.autoFocus,a=void 0===n||n,l=e.children,u=e.classes,c=e.disableAutoFocusItem,d=void 0!==c&&c,f=e.MenuListProps,p=void 0===f?{}:f,m=e.onClose,v=e.onEntering,b=e.open,y=e.PaperProps,g=void 0===y?{}:y,x=e.PopoverClasses,k=e.transitionDuration,E=void 0===k?"auto":k,O=e.variant,S=void 0===O?"selectedMenu":O,C=Object(o.a)(e,["autoFocus","children","classes","disableAutoFocusItem","MenuListProps","onClose","onEntering","open","PaperProps","PopoverClasses","transitionDuration","variant"]),T=Object(K.a)(),j=a&&!d&&b,P=i.a.useRef(null),R=i.a.useRef(null),N=-1;i.a.Children.map(l,(function(e,t){i.a.isValidElement(e)&&(e.props.disabled||("menu"!==S&&e.props.selected?N=t:-1===N&&(N=t)))}));var M=i.a.Children.map(l,(function(e,t){return t===N?i.a.cloneElement(e,{ref:function(t){R.current=h.a.findDOMNode(t),Object(w.a)(e.ref,t)}}):e}));return i.a.createElement(ae,Object(r.a)({getContentAnchorEl:function(){return R.current},classes:x,onClose:m,onEntering:function(e,t){P.current&&P.current.adjustStyleForScrollbar(e,T),v&&v(e,t)},anchorOrigin:"rtl"===T.direction?me:ve,transformOrigin:"rtl"===T.direction?me:ve,PaperProps:Object(r.a)({},g,{classes:Object(r.a)({},g.classes,{root:u.paper})}),open:b,ref:t,transitionDuration:E},C),i.a.createElement(he,Object(r.a)({onKeyDown:function(e){"Tab"===e.key&&(e.preventDefault(),m&&m(e,"tabKeyDown"))},actions:P,autoFocus:a&&(-1===N||d),autoFocusItem:j,variant:S},p,{className:Object(s.a)(u.list,p.className)}),M))})),ye=Object(f.a)({paper:{maxHeight:"calc(100% - 96px)",WebkitOverflowScrolling:"touch"},list:{outline:0}},{name:"MuiMenu"})(be),ge=n(41);function xe(e,t){return"object"===Object(c.a)(t)&&null!==t?e===t:String(e)===String(t)}var we=i.a.forwardRef((function(e,t){var n=e.autoFocus,a=e.autoWidth,l=e.children,c=e.classes,f=e.className,p=e.defaultValue,h=e.disabled,m=e.displayEmpty,v=e.IconComponent,b=e.inputRef,y=e.labelId,g=e.MenuProps,x=void 0===g?{}:g,w=e.multiple,E=e.name,O=e.onBlur,S=e.onChange,C=e.onClose,T=e.onFocus,j=e.onOpen,P=e.open,R=e.readOnly,N=e.renderValue,M=(e.required,e.SelectDisplayProps),_=void 0===M?{}:M,A=e.tabIndex,z=(e.type,e.value),I=e.variant,L=void 0===I?"standard":I,D=Object(o.a)(e,["autoFocus","autoWidth","children","classes","className","defaultValue","disabled","displayEmpty","IconComponent","inputRef","labelId","MenuProps","multiple","name","onBlur","onChange","onClose","onFocus","onOpen","open","readOnly","renderValue","required","SelectDisplayProps","tabIndex","type","value","variant"]),F=i.a.useRef(null!=z).current,U=i.a.useState(p),$=U[0],B=U[1],W=F?z:$;var V=i.a.useRef(null),H=i.a.useState(null),q=H[0],K=H[1],Q=i.a.useRef(null!=P).current,X=i.a.useState(),G=X[0],Y=X[1],J=i.a.useState(!1),Z=J[0],ee=J[1],te=Object(k.a)(t,b);i.a.useImperativeHandle(te,(function(){return{focus:function(){q.focus()},node:V.current,value:W}}),[q,W]),i.a.useEffect((function(){n&&q&&q.focus()}),[n,q]);var ne,re,oe=function(e,t){e?j&&j(t):C&&C(t),Q||(Y(a?null:q.clientWidth),ee(e))},ae=function(e){return function(t){var n;if(w||oe(!1,t),w){n=Array.isArray(W)?Object(u.a)(W):[];var r=W.indexOf(e.props.value);-1===r?n.push(e.props.value):n.splice(r,1)}else n=e.props.value;F||B(n),S&&(t.persist(),Object.defineProperty(t,"target",{writable:!0,value:{value:n,name:E}}),S(t,e))}},ie=null!==q&&(Q?P:Z);delete D["aria-invalid"];var le=[],ue=!1;(Object(ge.b)({value:W})||m)&&(N?ne=N(W):ue=!0);var ce=i.a.Children.map(l,(function(e){if(!i.a.isValidElement(e))return null;var t;if(w){if(!Array.isArray(W))throw new Error("Material-UI: the `value` prop must be an array when using the `Select` component with `multiple`.");(t=W.some((function(t){return xe(t,e.props.value)})))&&ue&&le.push(e.props.children)}else(t=xe(W,e.props.value))&&ue&&(re=e.props.children);return t&&!0,i.a.cloneElement(e,{"aria-selected":t?"true":void 0,onClick:ae(e),onKeyUp:function(t){" "===t.key&&t.preventDefault();var n=e.props.onKeyUp;"function"===typeof n&&n(t)},role:"option",selected:t,value:void 0,"data-value":e.props.value})}));ue&&(ne=w?le.join(", "):re);var se,de=G;!a&&Q&&q&&(de=q.clientWidth),se="undefined"!==typeof A?A:h?null:0;var fe=_.id||(E?"mui-component-select-".concat(E):void 0);return i.a.createElement(i.a.Fragment,null,i.a.createElement("div",Object(r.a)({className:Object(s.a)(c.root,c.select,c.selectMenu,c[L],f,h&&c.disabled),ref:K,tabIndex:se,role:"button","aria-expanded":ie?"true":void 0,"aria-labelledby":"".concat(y||""," ").concat(fe||""),"aria-haspopup":"listbox",onKeyDown:function(e){if(!R){-1!==[" ","ArrowUp","ArrowDown","Enter"].indexOf(e.key)&&(e.preventDefault(),oe(!0,e))}},onMouseDown:h||R?null:function(e){e.preventDefault(),q.focus(),oe(!0,e)},onBlur:function(e){!ie&&O&&(e.persist(),Object.defineProperty(e,"target",{writable:!0,value:{value:W,name:E}}),O(e))},onFocus:T},_,{id:fe}),function(e){return null==e||"string"===typeof e&&!e.trim()}(ne)?i.a.createElement("span",{dangerouslySetInnerHTML:{__html:"​"}}):ne),i.a.createElement("input",Object(r.a)({value:Array.isArray(W)?W.join(","):W,name:E,ref:V,type:"hidden",autoFocus:n},D)),i.a.createElement(v,{className:Object(s.a)(c.icon,c["icon".concat(Object(d.a)(L))],ie&&c.iconOpen)}),i.a.createElement(ye,Object(r.a)({id:"menu-".concat(E||""),anchorEl:q,open:ie,onClose:function(e){oe(!1,e)}},x,{MenuListProps:Object(r.a)({"aria-labelledby":y,role:"listbox",disableListWrap:!0},x.MenuListProps),PaperProps:Object(r.a)({},x.PaperProps,{style:Object(r.a)({minWidth:de},null!=x.PaperProps?x.PaperProps.style:null)})}),ce))})),ke=n(24),Ee=n(22),Oe=n(25),Se=Object(Oe.a)(i.a.createElement("path",{d:"M7 10l5 5 5-5z"}),"ArrowDropDown"),Ce=n(168),Te=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,l=e.disabled,u=e.IconComponent,c=e.inputRef,f=e.variant,p=void 0===f?"standard":f,h=Object(o.a)(e,["classes","className","disabled","IconComponent","inputRef","variant"]);return i.a.createElement(i.a.Fragment,null,i.a.createElement("select",Object(r.a)({className:Object(s.a)(n.root,n.select,n[p],a,l&&n.disabled),disabled:l,ref:c||t},h)),e.multiple?null:i.a.createElement(u,{className:Object(s.a)(n.icon,n["icon".concat(Object(d.a)(p))])}))})),je=function(e){return{root:{},select:{"-moz-appearance":"none","-webkit-appearance":"none",userSelect:"none",borderRadius:0,minWidth:16,cursor:"pointer","&:focus":{backgroundColor:"light"===e.palette.type?"rgba(0, 0, 0, 0.05)":"rgba(255, 255, 255, 0.05)",borderRadius:0},"&::-ms-expand":{display:"none"},"&$disabled":{cursor:"default"},"&[multiple]":{height:"auto"},"&:not([multiple]) option, &:not([multiple]) optgroup":{backgroundColor:e.palette.background.paper},"&&":{paddingRight:24}},filled:{"&&":{paddingRight:32}},outlined:{borderRadius:e.shape.borderRadius,"&&":{paddingRight:32}},selectMenu:{height:"auto",textOverflow:"ellipsis",whiteSpace:"nowrap",overflow:"hidden"},disabled:{},icon:{position:"absolute",right:0,top:"calc(50% - 12px)",color:e.palette.action.active,pointerEvents:"none"},iconOpen:{transform:"rotate(180deg)"},iconFilled:{right:7},iconOutlined:{right:7}}},Pe=i.a.createElement(Ce.a,null),Re=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.IconComponent,u=void 0===l?Se:l,c=e.input,s=void 0===c?Pe:c,d=e.inputProps,f=(e.variant,Object(o.a)(e,["children","classes","IconComponent","input","inputProps","variant"])),p=Object(Ee.a)(),h=Object(ke.a)({props:e,muiFormControl:p,states:["variant"]});return i.a.cloneElement(s,Object(r.a)({inputComponent:Te,inputProps:Object(r.a)({children:n,classes:a,IconComponent:u,variant:h.variant,type:void 0},d,{},s?s.props.inputProps:{}),ref:t},f))}));Re.muiName="Select";Object(f.a)(je,{name:"MuiNativeSelect"})(Re);var Ne=n(169),Me=n(176),_e=je,Ae=i.a.createElement(Ce.a,null),ze=i.a.createElement(Ne.a,null),Ie=i.a.forwardRef((function e(t,n){var a=t.autoWidth,u=void 0!==a&&a,c=t.children,s=t.classes,d=t.displayEmpty,f=void 0!==d&&d,p=t.IconComponent,h=void 0===p?Se:p,m=t.id,v=t.input,b=t.inputProps,y=t.labelId,g=t.labelWidth,x=void 0===g?0:g,w=t.MenuProps,k=t.multiple,E=void 0!==k&&k,O=t.native,S=void 0!==O&&O,C=t.onClose,T=t.onOpen,j=t.open,P=t.renderValue,R=t.SelectDisplayProps,N=t.variant,M=void 0===N?"standard":N,_=Object(o.a)(t,["autoWidth","children","classes","displayEmpty","IconComponent","id","input","inputProps","labelId","labelWidth","MenuProps","multiple","native","onClose","onOpen","open","renderValue","SelectDisplayProps","variant"]),A=S?Te:we,z=Object(Ee.a)(),I=Object(ke.a)({props:t,muiFormControl:z,states:["variant"]}).variant||M,L=v||{standard:Ae,outlined:i.a.createElement(Me.a,{labelWidth:x}),filled:ze}[I];return i.a.cloneElement(L,Object(r.a)({inputComponent:A,inputProps:Object(r.a)({children:c,IconComponent:h,variant:I,type:void 0,multiple:E},S?{id:m}:{autoWidth:u,displayEmpty:f,labelId:y,MenuProps:w,onClose:C,onOpen:T,open:j,renderValue:P,SelectDisplayProps:Object(r.a)({id:m},R)},{},b,{classes:b?Object(l.a)({baseClasses:s,newClasses:b.classes,Component:e}):s},v?v.props.inputProps:{}),ref:n},_))}));Ie.muiName="Select";t.a=Object(f.a)(_e,{name:"MuiSelect"})(Ie)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=n(9),u=n.n(l),c=(n(5),n(3)),s=n(168),d=n(169),f=n(176),p=n(24),h=n(22),m=n(4),v=n(6),b=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.className,u=(e.color,e.component),s=void 0===u?"label":u,d=(e.disabled,e.error,e.filled,e.focused,e.required,Object(o.a)(e,["children","classes","className","color","component","disabled","error","filled","focused","required"])),f=Object(h.a)(),m=Object(p.a)({props:e,muiFormControl:f,states:["color","required","focused","disabled","error","filled"]});return i.a.createElement(s,Object(r.a)({className:Object(c.a)(a.root,a["color".concat(Object(v.a)(m.color||"primary"))],l,m.disabled&&a.disabled,m.error&&a.error,m.filled&&a.filled,m.focused&&a.focused,m.required&&a.required),ref:t},d),n,m.required&&i.a.createElement("span",{className:Object(c.a)(a.asterisk,m.error&&a.error)},"\u2009","*"))})),y=Object(m.a)((function(e){return{root:Object(r.a)({color:e.palette.text.secondary},e.typography.body1,{lineHeight:1,padding:0,"&$focused":{color:e.palette.primary.main},"&$disabled":{color:e.palette.text.disabled},"&$error":{color:e.palette.error.main}}),colorSecondary:{"&$focused":{color:e.palette.secondary.main}},focused:{},disabled:{},error:{},filled:{},required:{},asterisk:{"&$error":{color:e.palette.error.main}}}}),{name:"MuiFormLabel"})(b),g=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,l=e.disableAnimation,u=void 0!==l&&l,s=(e.margin,e.shrink),d=(e.variant,Object(o.a)(e,["classes","className","disableAnimation","margin","shrink","variant"])),f=Object(h.a)(),m=s;"undefined"===typeof m&&f&&(m=f.filled||f.focused||f.adornedStart);var v=Object(p.a)({props:e,muiFormControl:f,states:["margin","variant"]});return i.a.createElement(y,Object(r.a)({"data-shrink":m,className:Object(c.a)(n.root,a,f&&n.formControl,!u&&n.animated,m&&n.shrink,{dense:n.marginDense}[v.margin],{filled:n.filled,outlined:n.outlined}[v.variant]),classes:{focused:n.focused,disabled:n.disabled,error:n.error,required:n.required,asterisk:n.asterisk},ref:t},d))})),x=Object(m.a)((function(e){return{root:{display:"block",transformOrigin:"top left"},focused:{},disabled:{},error:{},required:{},asterisk:{},formControl:{position:"absolute",left:0,top:0,transform:"translate(0, 24px) scale(1)"},marginDense:{transform:"translate(0, 21px) scale(1)"},shrink:{transform:"translate(0, 1.5px) scale(0.75)",transformOrigin:"top left"},animated:{transition:e.transitions.create(["color","transform"],{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut})},filled:{zIndex:1,pointerEvents:"none",transform:"translate(12px, 20px) scale(1)","&$marginDense":{transform:"translate(12px, 17px) scale(1)"},"&$shrink":{transform:"translate(12px, 10px) scale(0.75)","&$marginDense":{transform:"translate(12px, 7px) scale(0.75)"}}},outlined:{zIndex:1,pointerEvents:"none",transform:"translate(14px, 20px) scale(1)","&$marginDense":{transform:"translate(14px, 12px) scale(1)"},"&$shrink":{transform:"translate(14px, -6px) scale(0.75)"}}}}),{name:"MuiInputLabel"})(g),w=n(41),k=n(50),E=n(40),O=i.a.forwardRef((function(e,t){var n=e.children,a=e.classes,l=e.className,u=e.color,s=void 0===u?"primary":u,d=e.component,f=void 0===d?"div":d,p=e.disabled,h=void 0!==p&&p,m=e.error,b=void 0!==m&&m,y=e.fullWidth,g=void 0!==y&&y,x=e.hiddenLabel,O=void 0!==x&&x,S=e.margin,C=void 0===S?"none":S,T=e.required,j=void 0!==T&&T,P=e.size,R=e.variant,N=void 0===R?"standard":R,M=Object(o.a)(e,["children","classes","className","color","component","disabled","error","fullWidth","hiddenLabel","margin","required","size","variant"]),_=i.a.useState((function(){var e=!1;return n&&i.a.Children.forEach(n,(function(t){if(Object(k.a)(t,["Input","Select"])){var n=Object(k.a)(t,["Select"])?t.props.input:t;n&&Object(w.a)(n.props)&&(e=!0)}})),e})),A=_[0],z=_[1],I=i.a.useState((function(){var e=!1;return n&&i.a.Children.forEach(n,(function(t){Object(k.a)(t,["Input","Select"])&&Object(w.b)(t.props,!0)&&(e=!0)})),e})),L=I[0],D=I[1],F=i.a.useState(!1),U=F[0],$=F[1];h&&U&&$(!1);var B=i.a.useCallback((function(){D(!0)}),[]),W={adornedStart:A,setAdornedStart:z,color:s,disabled:h,error:b,filled:L,focused:U,hiddenLabel:O,margin:("small"===P?"dense":void 0)||C,onBlur:function(){$(!1)},onEmpty:i.a.useCallback((function(){D(!1)}),[]),onFilled:B,onFocus:function(){$(!0)},registerEffect:void 0,required:j,variant:N};return i.a.createElement(E.a.Provider,{value:W},i.a.createElement(f,Object(r.a)({className:Object(c.a)(a.root,l,"none"!==C&&a["margin".concat(Object(v.a)(C))],g&&a.fullWidth),ref:t},M),n))})),S=Object(m.a)({root:{display:"inline-flex",flexDirection:"column",position:"relative",minWidth:0,padding:0,margin:0,border:0,verticalAlign:"top"},marginNormal:{marginTop:16,marginBottom:8},marginDense:{marginTop:8,marginBottom:4},fullWidth:{width:"100%"}},{name:"MuiFormControl"})(O),C=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,l=e.component,u=void 0===l?"p":l,s=(e.disabled,e.error,e.filled,e.focused,e.margin,e.required,e.variant,Object(o.a)(e,["classes","className","component","disabled","error","filled","focused","margin","required","variant"])),d=Object(h.a)(),f=Object(p.a)({props:e,muiFormControl:d,states:["variant","margin","disabled","error","filled","focused","required"]});return i.a.createElement(u,Object(r.a)({className:Object(c.a)(n.root,("filled"===f.variant||"outlined"===f.variant)&&n.contained,a,f.disabled&&n.disabled,f.error&&n.error,f.filled&&n.filled,f.focused&&n.focused,f.required&&n.required,{dense:n.marginDense}[f.margin]),ref:t},s))})),T=Object(m.a)((function(e){return{root:Object(r.a)({color:e.palette.text.secondary},e.typography.caption,{textAlign:"left",marginTop:8,lineHeight:"1em",minHeight:"1em",margin:0,"&$disabled":{color:e.palette.text.disabled},"&$error":{color:e.palette.error.main}}),error:{},disabled:{},marginDense:{marginTop:4},contained:{margin:"8px 14px 0"},focused:{},filled:{},required:{}}}),{name:"MuiFormHelperText"})(C),j=n(172),P={standard:s.a,filled:d.a,outlined:f.a},R=i.a.forwardRef((function(e,t){var n=e.autoComplete,a=e.autoFocus,l=void 0!==a&&a,s=e.children,d=e.classes,f=e.className,p=e.color,h=void 0===p?"primary":p,m=e.defaultValue,v=e.disabled,b=void 0!==v&&v,y=e.error,g=void 0!==y&&y,w=e.FormHelperTextProps,k=e.fullWidth,E=void 0!==k&&k,O=e.helperText,C=e.hiddenLabel,R=e.id,N=e.InputLabelProps,M=e.inputProps,_=e.InputProps,A=e.inputRef,z=e.label,I=e.multiline,L=void 0!==I&&I,D=e.name,F=e.onBlur,U=e.onChange,$=e.onFocus,B=e.placeholder,W=e.required,V=void 0!==W&&W,H=e.rows,q=e.rowsMax,K=e.select,Q=void 0!==K&&K,X=e.SelectProps,G=e.type,Y=e.value,J=e.variant,Z=void 0===J?"standard":J,ee=Object(o.a)(e,["autoComplete","autoFocus","children","classes","className","color","defaultValue","disabled","error","FormHelperTextProps","fullWidth","helperText","hiddenLabel","id","InputLabelProps","inputProps","InputProps","inputRef","label","multiline","name","onBlur","onChange","onFocus","placeholder","required","rows","rowsMax","select","SelectProps","type","value","variant"]),te=i.a.useState(0),ne=te[0],re=te[1],oe=i.a.useRef(null);i.a.useEffect((function(){if("outlined"===Z){var e=u.a.findDOMNode(oe.current);re(null!=e?e.offsetWidth:0)}}),[Z,V,z]);var ae={};"outlined"===Z&&(N&&"undefined"!==typeof N.shrink&&(ae.notched=N.shrink),ae.labelWidth=ne),Q&&(X&&X.native||(ae.id=void 0),ae["aria-describedby"]=void 0);var ie=O&&R?"".concat(R,"-helper-text"):void 0,le=z&&R?"".concat(R,"-label"):void 0,ue=P[Z],ce=i.a.createElement(ue,Object(r.a)({"aria-describedby":ie,autoComplete:n,autoFocus:l,defaultValue:m,fullWidth:E,multiline:L,name:D,rows:H,rowsMax:q,type:G,value:Y,id:R,inputRef:A,onBlur:F,onChange:U,onFocus:$,placeholder:B,inputProps:M},ae,_));return i.a.createElement(S,Object(r.a)({className:Object(c.a)(d.root,f),disabled:b,error:g,fullWidth:E,hiddenLabel:C,ref:t,required:V,color:h,variant:Z},ee),z&&i.a.createElement(x,Object(r.a)({htmlFor:R,ref:oe,id:le},N),z),Q?i.a.createElement(j.a,Object(r.a)({"aria-describedby":ie,id:R,labelId:le,value:Y,input:ce},X),s):ce,O&&i.a.createElement(T,Object(r.a)({id:ie},w),O))}));t.a=Object(m.a)({root:{}},{name:"MuiTextField"})(R)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(46),c=n(25),s=Object(c.a)(i.a.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"}),"RadioButtonUnchecked"),d=Object(c.a)(i.a.createElement("path",{d:"M8.465 8.465C9.37 7.56 10.62 7 12 7C14.76 7 17 9.24 17 12C17 13.38 16.44 14.63 15.535 15.535C14.63 16.44 13.38 17 12 17C9.24 17 7 14.76 7 12C7 10.62 7.56 9.37 8.465 8.465Z"}),"RadioButtonChecked"),f=n(4);var p=Object(f.a)((function(e){return{root:{position:"relative",display:"flex","&$checked $layer":{transform:"scale(1)",transition:e.transitions.create("transform",{easing:e.transitions.easing.easeOut,duration:e.transitions.duration.shortest})}},layer:{left:0,position:"absolute",transform:"scale(0)",transition:e.transitions.create("transform",{easing:e.transitions.easing.easeIn,duration:e.transitions.duration.shortest})},checked:{}}}),{name:"PrivateRadioButtonIcon"})((function(e){var t=e.checked,n=e.classes,r=e.fontSize;return i.a.createElement("div",{className:Object(l.a)(n.root,t&&n.checked)},i.a.createElement(s,{fontSize:r}),i.a.createElement(d,{fontSize:r,className:n.layer}))})),h=n(10),m=n(6),v=n(42),b=n(62);var y=i.a.createElement(p,{checked:!0}),g=i.a.createElement(p,null),x=i.a.forwardRef((function(e,t){var n=e.checked,a=e.classes,c=e.color,s=void 0===c?"secondary":c,d=e.disabled,f=void 0!==d&&d,p=e.name,h=e.onChange,x=e.size,w=void 0===x?"medium":x,k=Object(o.a)(e,["checked","classes","color","disabled","name","onChange","size"]),E=i.a.useContext(b.a),O=n,S=Object(v.a)(h,E&&E.onChange),C=p;return E&&("undefined"===typeof O&&(O=E.value===e.value),"undefined"===typeof C&&(C=E.name)),i.a.createElement(u.a,Object(r.a)({color:s,type:"radio",icon:i.a.cloneElement(g,{fontSize:"small"===w?"small":"default"}),checkedIcon:i.a.cloneElement(y,{fontSize:"small"===w?"small":"default"}),classes:{root:Object(l.a)(a.root,a["color".concat(Object(m.a)(s))]),checked:a.checked,disabled:a.disabled},name:C,checked:O,onChange:S,ref:t,disabled:f},k))}));t.a=Object(f.a)((function(e){return{root:{color:e.palette.text.secondary},checked:{},disabled:{},colorPrimary:{"&$checked":{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(h.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}},colorSecondary:{"&$checked":{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(h.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}}}}),{name:"MuiRadio"})(x)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(46),c=n(25),s=Object(c.a)(i.a.createElement("path",{d:"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z"}),"CheckBoxOutlineBlank"),d=Object(c.a)(i.a.createElement("path",{d:"M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"}),"CheckBox"),f=n(10),p=Object(c.a)(i.a.createElement("path",{d:"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z"}),"IndeterminateCheckBox"),h=n(6),m=n(4),v=i.a.createElement(d,null),b=i.a.createElement(s,null),y=i.a.createElement(p,null),g=i.a.forwardRef((function(e,t){var n=e.checkedIcon,a=void 0===n?v:n,c=e.classes,s=e.color,d=void 0===s?"secondary":s,f=e.disabled,p=void 0!==f&&f,m=e.icon,g=void 0===m?b:m,x=e.indeterminate,w=void 0!==x&&x,k=e.indeterminateIcon,E=void 0===k?y:k,O=e.inputProps,S=e.size,C=void 0===S?"medium":S,T=Object(o.a)(e,["checkedIcon","classes","color","disabled","icon","indeterminate","indeterminateIcon","inputProps","size"]);return i.a.createElement(u.a,Object(r.a)({type:"checkbox",classes:{root:Object(l.a)(c.root,c["color".concat(Object(h.a)(d))],w&&c.indeterminate),checked:c.checked,disabled:c.disabled},color:d,inputProps:Object(r.a)({"data-indeterminate":w},O),icon:i.a.cloneElement(w?E:g,{fontSize:"small"===C?"small":"default"}),checkedIcon:i.a.cloneElement(w?E:a,{fontSize:"small"===C?"small":"default"}),ref:t,disabled:p},T))}));t.a=Object(m.a)((function(e){return{root:{color:e.palette.text.secondary},checked:{},disabled:{},indeterminate:{},colorPrimary:{"&$checked":{color:e.palette.primary.main,"&:hover":{backgroundColor:Object(f.b)(e.palette.primary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}},colorSecondary:{"&$checked":{color:e.palette.secondary.main,"&:hover":{backgroundColor:Object(f.b)(e.palette.secondary.main,e.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"&$disabled":{color:e.palette.action.disabled}}}}),{name:"MuiCheckbox"})(g)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(95),c=n(20),s=n(4),d=n(47),f=n(6),p=i.a.forwardRef((function(e,t){e.children;var n=e.classes,a=e.className,u=e.labelWidth,s=e.notched,p=e.style,h=Object(o.a)(e,["children","classes","className","labelWidth","notched","style"]),m="rtl"===Object(d.a)().direction?"right":"left",v=u>0?.75*u+8:0;return i.a.createElement("fieldset",Object(r.a)({"aria-hidden":!0,style:Object(r.a)(Object(c.a)({},"padding".concat(Object(f.a)(m)),8+(s?0:v/2)),p),className:Object(l.a)(n.root,a),ref:t},h),i.a.createElement("legend",{className:n.legend,style:{width:s?v:.01}},i.a.createElement("span",{dangerouslySetInnerHTML:{__html:"​"}})))})),h=Object(s.a)((function(e){var t="rtl"===e.direction?"right":"left";return{root:{position:"absolute",bottom:0,right:0,top:-5,left:0,margin:0,padding:0,pointerEvents:"none",borderRadius:"inherit",borderStyle:"solid",borderWidth:1,transition:e.transitions.create(["padding-".concat(t),"border-color","border-width"],{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut})},legend:{textAlign:"left",padding:0,lineHeight:"11px",transition:e.transitions.create("width",{duration:e.transitions.duration.shorter,easing:e.transitions.easing.easeOut})}}}),{name:"PrivateNotchedOutline"})(p),m=i.a.forwardRef((function(e,t){var n=e.classes,a=e.fullWidth,c=void 0!==a&&a,s=e.inputComponent,d=void 0===s?"input":s,f=e.labelWidth,p=void 0===f?0:f,m=e.multiline,v=void 0!==m&&m,b=e.notched,y=e.type,g=void 0===y?"text":y,x=Object(o.a)(e,["classes","fullWidth","inputComponent","labelWidth","multiline","notched","type"]);return i.a.createElement(u.a,Object(r.a)({renderSuffix:function(e){return i.a.createElement(h,{className:n.notchedOutline,labelWidth:p,notched:"undefined"!==typeof b?b:Boolean(e.startAdornment||e.filled||e.focused)})},classes:Object(r.a)({},n,{root:Object(l.a)(n.root,n.underline),notchedOutline:null}),fullWidth:c,inputComponent:d,multiline:v,ref:t,type:g},x))}));m.muiName="Input";t.a=Object(s.a)((function(e){var t="light"===e.palette.type?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)";return{root:{position:"relative",borderRadius:e.shape.borderRadius,"&:hover $notchedOutline":{borderColor:e.palette.text.primary},"@media (hover: none)":{"&:hover $notchedOutline":{borderColor:t}},"&$focused $notchedOutline":{borderColor:e.palette.primary.main,borderWidth:2},"&$error $notchedOutline":{borderColor:e.palette.error.main},"&$disabled $notchedOutline":{borderColor:e.palette.action.disabled}},colorSecondary:{"&$focused $notchedOutline":{borderColor:e.palette.secondary.main}},focused:{},disabled:{},adornedStart:{paddingLeft:14},adornedEnd:{paddingRight:14},error:{},marginDense:{},multiline:{padding:"18.5px 14px","&$marginDense":{paddingTop:10.5,paddingBottom:10.5}},notchedOutline:{borderColor:t},input:{padding:"18.5px 14px","&:-webkit-autofill":{WebkitBoxShadow:"dark"===e.palette.type?"0 0 0 100px #266798 inset":null,WebkitTextFillColor:"dark"===e.palette.type?"#fff":null,borderRadius:"inherit"}},inputMarginDense:{paddingTop:10.5,paddingBottom:10.5},inputMultiline:{padding:0},inputAdornedStart:{paddingLeft:0},inputAdornedEnd:{paddingRight:0}}}),{name:"MuiOutlinedInput"})(m)},function(e,t,n){"use strict";var r=n(2),o=n(20),a=n(1),i=n(0),l=n.n(i),u=(n(5),n(3)),c=n(4),s=n(94),d=n(50),f=n(8),p=n(51),h=n(9),m=n.n(h),v="undefined"===typeof window?l.a.useEffect:l.a.useLayoutEffect,b=l.a.forwardRef((function(e,t){var n=e.alignItems,o=void 0===n?"center":n,i=e.autoFocus,c=void 0!==i&&i,h=e.button,b=void 0!==h&&h,y=e.children,g=e.classes,x=e.className,w=e.component,k=e.ContainerComponent,E=void 0===k?"li":k,O=e.ContainerProps,S=(O=void 0===O?{}:O).className,C=Object(r.a)(O,["className"]),T=e.dense,j=void 0!==T&&T,P=e.disabled,R=void 0!==P&&P,N=e.disableGutters,M=void 0!==N&&N,_=e.divider,A=void 0!==_&&_,z=e.focusVisibleClassName,I=e.selected,L=void 0!==I&&I,D=Object(r.a)(e,["alignItems","autoFocus","button","children","classes","className","component","ContainerComponent","ContainerProps","dense","disabled","disableGutters","divider","focusVisibleClassName","selected"]),F=l.a.useContext(p.a),U={dense:j||F.dense||!1,alignItems:o},$=l.a.useRef(null);v((function(){c&&$.current&&$.current.focus()}),[c]);var B=l.a.Children.toArray(y),W=B.length&&Object(d.a)(B[B.length-1],["ListItemSecondaryAction"]),V=l.a.useCallback((function(e){$.current=m.a.findDOMNode(e)}),[]),H=Object(f.a)(V,t),q=Object(a.a)({className:Object(u.a)(g.root,x,U.dense&&g.dense,!M&&g.gutters,A&&g.divider,R&&g.disabled,b&&g.button,"center"!==o&&g.alignItemsFlexStart,W&&g.secondaryAction,L&&g.selected),disabled:R},D),K=w||"li";return b&&(q.component=w||"div",q.focusVisibleClassName=Object(u.a)(g.focusVisible,z),K=s.a),W?(K=q.component||w?K:"div","li"===E&&("li"===K?K="div":"li"===q.component&&(q.component="div")),l.a.createElement(p.a.Provider,{value:U},l.a.createElement(E,Object(a.a)({className:Object(u.a)(g.container,S),ref:H},C),l.a.createElement(K,q,B),B.pop()))):l.a.createElement(p.a.Provider,{value:U},l.a.createElement(K,Object(a.a)({ref:H},q),B))})),y=Object(c.a)((function(e){return{root:{display:"flex",justifyContent:"flex-start",alignItems:"center",position:"relative",textDecoration:"none",width:"100%",boxSizing:"border-box",textAlign:"left",paddingTop:8,paddingBottom:8,"&$focusVisible":{backgroundColor:e.palette.action.selected},"&$selected, &$selected:hover":{backgroundColor:e.palette.action.selected},"&$disabled":{opacity:.5}},container:{position:"relative"},focusVisible:{},dense:{paddingTop:4,paddingBottom:4},alignItemsFlexStart:{alignItems:"flex-start"},disabled:{},divider:{borderBottom:"1px solid ".concat(e.palette.divider),backgroundClip:"padding-box"},gutters:{paddingLeft:16,paddingRight:16},button:{transition:e.transitions.create("background-color",{duration:e.transitions.duration.shortest}),"&:hover":{textDecoration:"none",backgroundColor:e.palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}}},secondaryAction:{paddingRight:48},selected:{}}}),{name:"MuiListItem"})(b),g=l.a.forwardRef((function(e,t){var n,o=e.classes,i=e.className,c=e.component,s=void 0===c?"li":c,d=e.disableGutters,f=void 0!==d&&d,p=e.role,h=void 0===p?"menuitem":p,m=e.selected,v=e.tabIndex,b=Object(r.a)(e,["classes","className","component","disableGutters","role","selected","tabIndex"]);return e.disabled||(n=void 0!==v?v:-1),l.a.createElement(y,Object(a.a)({button:!0,role:h,tabIndex:n,component:s,selected:m,disableGutters:f,classes:{dense:o.dense},className:Object(u.a)(o.root,i,m&&o.selected,!f&&o.gutters),ref:t},b))}));t.a=Object(c.a)((function(e){return{root:Object(a.a)({},e.typography.body1,Object(o.a)({minHeight:48,paddingTop:6,paddingBottom:6,boxSizing:"border-box",width:"auto",overflow:"hidden",whiteSpace:"nowrap"},e.breakpoints.up("sm"),{minHeight:"auto"})),gutters:{},selected:{},dense:Object(a.a)({},e.typography.body2,{minHeight:"auto"})}}),{name:"MuiMenuItem"})(g)},function(e,t,n){"use strict";var r=n(1),o=n(2),a=n(0),i=n.n(a),l=(n(5),n(3)),u=n(4),c=i.a.forwardRef((function(e,t){var n=e.classes,a=e.className,u=e.row,c=void 0!==u&&u,s=Object(o.a)(e,["classes","className","row"]);return i.a.createElement("div",Object(r.a)({className:Object(l.a)(n.root,a,c&&n.row),ref:t},s))})),s=Object(u.a)({root:{display:"flex",flexDirection:"column",flexWrap:"wrap"},row:{flexDirection:"row"}},{name:"MuiFormGroup"})(c),d=n(8),f=n(62),p=i.a.forwardRef((function(e,t){var n=e.actions,a=e.children,l=e.name,u=e.value,c=e.onChange,p=Object(o.a)(e,["actions","children","name","value","onChange"]),h=i.a.useRef(null),m=i.a.useRef(null!=u).current,v=i.a.useState(e.defaultValue),b=v[0],y=v[1],g=m?u:b;i.a.useImperativeHandle(n,(function(){return{focus:function(){var e=h.current.querySelector("input:not(:disabled):checked");e||(e=h.current.querySelector("input:not(:disabled)")),e&&e.focus()}}}),[]);var x=Object(d.a)(t,h);return i.a.createElement(f.a.Provider,{value:{name:l,onChange:function(e){m||y(e.target.value),c&&c(e,e.target.value)},value:g}},i.a.createElement(s,Object(r.a)({role:"radiogroup",ref:x},p),a))}));t.a=p}]]); -//# sourceMappingURL=2.6a72c269.chunk.js.map \ No newline at end of file diff --git a/build/static/js/2.6a72c269.chunk.js.LICENSE b/build/static/js/2.6a72c269.chunk.js.LICENSE deleted file mode 100644 index bfef83c..0000000 --- a/build/static/js/2.6a72c269.chunk.js.LICENSE +++ /dev/null @@ -1,49 +0,0 @@ -/* -object-assign -(c) Sindre Sorhus -@license MIT -*/ - -/** @license React v16.12.0 - * react.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -/** @license React v16.12.0 - * react-dom.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -/** @license React v0.18.0 - * scheduler.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -/** @license React v16.12.0 - * react-is.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -/** - * A better abstraction over CSS. - * - * @copyright Oleg Isonen (Slobodskoi) / Isonen 2014-present - * @website https://github.com/cssinjs/jss - * @license MIT - */ diff --git a/build/static/js/2.6a72c269.chunk.js.map b/build/static/js/2.6a72c269.chunk.js.map deleted file mode 100644 index a9ed7e6..0000000 --- a/build/static/js/2.6a72c269.chunk.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["../node_modules/react/index.js","../node_modules/@babel/runtime/helpers/esm/extends.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/clsx/dist/clsx.m.js","../node_modules/@material-ui/styles/esm/withStyles/withStyles.js","../node_modules/@material-ui/core/esm/styles/withStyles.js","../node_modules/prop-types/index.js","../node_modules/@material-ui/core/esm/utils/capitalize.js","../node_modules/@material-ui/core/esm/utils/useForkRef.js","../node_modules/react-dom/index.js","../node_modules/@material-ui/core/esm/styles/colorManipulator.js","../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@material-ui/icons/DeleteOutlined.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/axios/lib/utils.js","../node_modules/@material-ui/core/esm/FormControl/useFormControl.js","../node_modules/tiny-invariant/dist/tiny-invariant.esm.js","../node_modules/@material-ui/core/esm/FormControl/formControlState.js","../node_modules/@material-ui/core/esm/internal/svg-icons/createSvgIcon.js","../node_modules/resolve-pathname/esm/resolve-pathname.js","../node_modules/value-equal/esm/value-equal.js","../node_modules/history/esm/history.js","../node_modules/@material-ui/icons/Close.js","../node_modules/@material-ui/icons/AddCircle.js","../node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/@material-ui/core/esm/utils/useEventCallback.js","../node_modules/@material-ui/icons/utils/createSvgIcon.js","../node_modules/tiny-warning/dist/tiny-warning.esm.js","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/@material-ui/core/esm/utils/setRef.js","../node_modules/mini-create-react-context/dist/esm/index.js","../../modules/RouterContext.js","../../modules/Router.js","../../modules/MemoryRouter.js","../../modules/Lifecycle.js","../../modules/matchPath.js","../../modules/Route.js","../../modules/StaticRouter.js","../../modules/Switch.js","../../modules/hooks.js","../node_modules/@material-ui/core/esm/FormControl/FormControlContext.js","../node_modules/@material-ui/core/esm/InputBase/utils.js","../node_modules/@material-ui/core/esm/utils/createChainedFunction.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/TransitionGroupContext.js","../node_modules/react-is/index.js","../node_modules/@material-ui/core/esm/styles/defaultTheme.js","../node_modules/@material-ui/core/esm/internal/SwitchBase.js","../node_modules/@material-ui/core/esm/styles/useTheme.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@material-ui/core/esm/utils/isMuiElement.js","../node_modules/@material-ui/core/esm/List/ListContext.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@material-ui/icons/CheckBoxOutlineBlank.js","../node_modules/axios/index.js","../node_modules/@material-ui/styles/esm/useTheme/ThemeContext.js","../node_modules/@material-ui/styles/esm/ThemeProvider/nested.js","../node_modules/@material-ui/core/esm/styles/zIndex.js","../node_modules/@material-ui/core/esm/SvgIcon/SvgIcon.js","../node_modules/@material-ui/core/esm/utils/debounce.js","../node_modules/@material-ui/core/esm/RadioGroup/RadioGroupContext.js","../node_modules/@material-ui/icons/Add.js","../node_modules/@material-ui/icons/Reorder.js","../node_modules/@material-ui/icons/RadioButtonChecked.js","../../modules/BrowserRouter.js","../../modules/HashRouter.js","../../modules/utils/locationUtils.js","../../modules/Link.js","../../modules/NavLink.js","../node_modules/@babel/runtime/helpers/inheritsLoose.js","../node_modules/react-router/node_modules/path-to-regexp/index.js","../node_modules/object-assign/index.js","../node_modules/axios/lib/helpers/bind.js","../node_modules/axios/lib/helpers/buildURL.js","../node_modules/axios/lib/cancel/isCancel.js","../node_modules/axios/lib/defaults.js","../node_modules/axios/lib/adapters/xhr.js","../node_modules/axios/lib/core/createError.js","../node_modules/axios/lib/core/mergeConfig.js","../node_modules/axios/lib/cancel/Cancel.js","../node_modules/@material-ui/core/esm/SvgIcon/index.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@material-ui/styles/node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/@material-ui/icons/RadioButtonUnchecked.js","../node_modules/gud/index.js","../node_modules/react-router/node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/@material-ui/icons/KeyboardArrowRight.js","../node_modules/@material-ui/core/esm/styles/createBreakpoints.js","../node_modules/@material-ui/core/esm/styles/createMixins.js","../node_modules/@material-ui/core/esm/colors/common.js","../node_modules/@material-ui/core/esm/colors/grey.js","../node_modules/@material-ui/core/esm/colors/indigo.js","../node_modules/@material-ui/core/esm/colors/pink.js","../node_modules/@material-ui/core/esm/colors/red.js","../node_modules/@material-ui/core/esm/colors/orange.js","../node_modules/@material-ui/core/esm/colors/blue.js","../node_modules/@material-ui/core/esm/colors/green.js","../node_modules/@material-ui/core/esm/styles/createPalette.js","../node_modules/@material-ui/core/esm/styles/createTypography.js","../node_modules/@material-ui/core/esm/styles/shadows.js","../node_modules/@material-ui/core/esm/styles/shape.js","../node_modules/@material-ui/core/esm/styles/createSpacing.js","../node_modules/@material-ui/core/esm/styles/transitions.js","../node_modules/@material-ui/core/esm/styles/createMuiTheme.js","../node_modules/@material-ui/styles/esm/useTheme/useTheme.js","../node_modules/@material-ui/core/esm/NoSsr/NoSsr.js","../node_modules/@material-ui/core/esm/utils/focusVisible.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/utils/ChildMapping.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/TransitionGroup.js","../node_modules/@material-ui/core/esm/ButtonBase/Ripple.js","../node_modules/@material-ui/core/esm/ButtonBase/TouchRipple.js","../node_modules/@material-ui/core/esm/ButtonBase/ButtonBase.js","../node_modules/@material-ui/core/esm/TextareaAutosize/TextareaAutosize.js","../node_modules/@material-ui/core/esm/InputBase/InputBase.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/scheduler/index.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/axios/lib/axios.js","../node_modules/axios/lib/core/Axios.js","../node_modules/axios/lib/core/InterceptorManager.js","../node_modules/axios/lib/core/dispatchRequest.js","../node_modules/axios/lib/core/transformData.js","../node_modules/process/browser.js","../node_modules/axios/lib/helpers/normalizeHeaderName.js","../node_modules/axios/lib/core/settle.js","../node_modules/axios/lib/core/enhanceError.js","../node_modules/axios/lib/core/buildFullPath.js","../node_modules/axios/lib/helpers/isAbsoluteURL.js","../node_modules/axios/lib/helpers/combineURLs.js","../node_modules/axios/lib/helpers/parseHeaders.js","../node_modules/axios/lib/helpers/isURLSameOrigin.js","../node_modules/axios/lib/helpers/cookies.js","../node_modules/axios/lib/cancel/CancelToken.js","../node_modules/axios/lib/helpers/spread.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/@babel/runtime/helpers/extends.js","../node_modules/webpack/buildin/global.js","../node_modules/react-router/node_modules/isarray/index.js","../node_modules/@material-ui/core/esm/Typography/Typography.js","../node_modules/@material-ui/core/esm/IconButton/IconButton.js","../node_modules/is-in-browser/dist/module.js","../node_modules/jss/dist/jss.esm.js","../node_modules/@material-ui/styles/esm/makeStyles/multiKeyStore.js","../node_modules/@material-ui/styles/esm/createGenerateClassName/createGenerateClassName.js","../node_modules/jss-plugin-rule-value-function/dist/jss-plugin-rule-value-function.esm.js","../node_modules/jss-plugin-global/dist/jss-plugin-global.esm.js","../node_modules/jss-plugin-nested/dist/jss-plugin-nested.esm.js","../node_modules/hyphenate-style-name/index.js","../node_modules/jss-plugin-camel-case/dist/jss-plugin-camel-case.esm.js","../node_modules/jss-plugin-default-unit/dist/jss-plugin-default-unit.esm.js","../node_modules/css-vendor/dist/css-vendor.esm.js","../node_modules/jss-plugin-vendor-prefixer/dist/jss-plugin-vendor-prefixer.esm.js","../node_modules/jss-plugin-props-sort/dist/jss-plugin-props-sort.esm.js","../node_modules/@material-ui/styles/esm/jssPreset/jssPreset.js","../node_modules/@material-ui/styles/esm/StylesProvider/StylesProvider.js","../node_modules/@material-ui/styles/esm/makeStyles/indexCounter.js","../node_modules/@material-ui/styles/esm/getStylesCreator/getStylesCreator.js","../node_modules/@material-ui/styles/esm/getStylesCreator/noopTheme.js","../node_modules/@material-ui/styles/esm/makeStyles/makeStyles.js","../node_modules/@material-ui/core/esm/FormControlLabel/FormControlLabel.js","../node_modules/@material-ui/styles/esm/mergeClasses/mergeClasses.js","../node_modules/@material-ui/utils/esm/deepmerge.js","../node_modules/@material-ui/styles/esm/getThemeProps/getThemeProps.js","../node_modules/@material-ui/core/esm/Switch/Switch.js","../node_modules/@material-ui/core/esm/styles/makeStyles.js","../node_modules/@material-ui/core/esm/Paper/Paper.js","../node_modules/@material-ui/core/esm/Grid/Grid.js","../node_modules/@material-ui/core/esm/Input/Input.js","../node_modules/@material-ui/core/esm/FilledInput/FilledInput.js","../node_modules/@material-ui/core/esm/Button/Button.js","../node_modules/@material-ui/styles/esm/ThemeProvider/ThemeProvider.js","../node_modules/@material-ui/core/esm/utils/ownerDocument.js","../node_modules/@material-ui/core/esm/utils/ownerWindow.js","../node_modules/@material-ui/core/esm/Portal/Portal.js","../node_modules/@material-ui/core/esm/utils/getScrollbarSize.js","../node_modules/@material-ui/core/esm/Modal/ModalManager.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@material-ui/core/esm/Modal/TrapFocus.js","../node_modules/@material-ui/core/esm/Modal/SimpleBackdrop.js","../node_modules/@material-ui/core/esm/Modal/Modal.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/config.js","../node_modules/@material-ui/core/node_modules/react-transition-group/esm/Transition.js","../node_modules/@material-ui/core/esm/transitions/utils.js","../node_modules/@material-ui/core/esm/Grow/Grow.js","../node_modules/@material-ui/core/esm/Popover/Popover.js","../node_modules/@material-ui/core/esm/List/List.js","../node_modules/@material-ui/core/esm/MenuList/MenuList.js","../node_modules/@material-ui/core/esm/Menu/Menu.js","../node_modules/@material-ui/core/esm/Select/SelectInput.js","../node_modules/@material-ui/core/esm/internal/svg-icons/ArrowDropDown.js","../node_modules/@material-ui/core/esm/NativeSelect/NativeSelectInput.js","../node_modules/@material-ui/core/esm/NativeSelect/NativeSelect.js","../node_modules/@material-ui/core/esm/Select/Select.js","../node_modules/@material-ui/core/esm/FormLabel/FormLabel.js","../node_modules/@material-ui/core/esm/InputLabel/InputLabel.js","../node_modules/@material-ui/core/esm/FormControl/FormControl.js","../node_modules/@material-ui/core/esm/FormHelperText/FormHelperText.js","../node_modules/@material-ui/core/esm/TextField/TextField.js","../node_modules/@material-ui/core/esm/internal/svg-icons/RadioButtonUnchecked.js","../node_modules/@material-ui/core/esm/internal/svg-icons/RadioButtonChecked.js","../node_modules/@material-ui/core/esm/Radio/RadioButtonIcon.js","../node_modules/@material-ui/core/esm/Radio/Radio.js","../node_modules/@material-ui/core/esm/RadioGroup/useRadioGroup.js","../node_modules/@material-ui/core/esm/internal/svg-icons/CheckBoxOutlineBlank.js","../node_modules/@material-ui/core/esm/internal/svg-icons/CheckBox.js","../node_modules/@material-ui/core/esm/internal/svg-icons/IndeterminateCheckBox.js","../node_modules/@material-ui/core/esm/Checkbox/Checkbox.js","../node_modules/@material-ui/core/esm/OutlinedInput/NotchedOutline.js","../node_modules/@material-ui/core/esm/OutlinedInput/OutlinedInput.js","../node_modules/@material-ui/core/esm/ListItem/ListItem.js","../node_modules/@material-ui/core/esm/MenuItem/MenuItem.js","../node_modules/@material-ui/core/esm/FormGroup/FormGroup.js","../node_modules/@material-ui/core/esm/RadioGroup/RadioGroup.js"],"names":["module","exports","require","_extends","Object","assign","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","_objectWithoutProperties","excluded","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","toVal","mix","k","y","str","push","x","withStyles","stylesOrCreator","options","undefined","Component","defaultTheme","_options$withTheme","withTheme","name","stylesOptions","classNamePrefix","useStyles","makeStyles","displayName","WithStyles","React","forwardRef","props","ref","classes","theme","innerRef","other","more","useTheme","getThemeProps","createElement","defaultProps","hoistNonReactStatics","withStylesWithoutDefault","capitalize","string","charAt","toUpperCase","slice","useForkRef","refA","refB","useMemo","refValue","setRef","checkDCE","__REACT_DEVTOOLS_GLOBAL_HOOK__","process","err","console","error","clamp","value","min","max","Math","decomposeColor","color","type","substr","re","RegExp","concat","colors","match","map","n","parseInt","join","hexToRgb","marker","substring","Error","values","split","parseFloat","recomposeColor","getContrastRatio","foreground","background","lumA","getLuminance","lumB","rgb","h","s","l","a","f","round","hslToRgb","val","pow","Number","toFixed","fade","darken","coefficient","lighten","_toConsumableArray","arr","Array","isArray","arr2","iterableToArray","TypeError","_inheritsLoose","subClass","superClass","create","constructor","__proto__","_objectWithoutPropertiesLoose","sourceKeys","keys","_interopRequireDefault","defineProperty","default","_react","_default","d","_defineProperty","obj","enumerable","configurable","writable","bind","toString","isUndefined","isObject","isFunction","forEach","fn","isArrayBuffer","isBuffer","isFormData","FormData","isArrayBufferView","ArrayBuffer","isView","buffer","isString","isNumber","isDate","isFile","isBlob","isStream","pipe","isURLSearchParams","URLSearchParams","isStandardBrowserEnv","navigator","product","window","document","merge","result","assignValue","deepMerge","extend","b","thisArg","trim","replace","useFormControl","useContext","FormControlContext","invariant","condition","message","formControlState","_ref","states","muiFormControl","reduce","acc","state","createSvgIcon","path","memo","SvgIcon","muiName","isAbsolute","pathname","spliceOne","list","index","pop","resolvePathname","to","from","hasTrailingSlash","toParts","fromParts","isToAbs","isFromAbs","mustEndAbs","last","up","part","unshift","valueOf","valueEqual","every","item","aValue","bValue","addLeadingSlash","stripLeadingSlash","stripBasename","prefix","toLowerCase","hasBasename","stripTrailingSlash","createPath","location","search","hash","createLocation","currentLocation","hashIndex","searchIndex","parsePath","decodeURI","e","URIError","locationsAreEqual","createTransitionManager","prompt","listeners","setPrompt","nextPrompt","confirmTransitionTo","action","getUserConfirmation","callback","appendListener","isActive","listener","filter","notifyListeners","_len","args","_key","canUseDOM","getConfirmation","confirm","getHistoryState","history","createBrowserHistory","globalHistory","canUseHistory","ua","userAgent","supportsHistory","needsHashChangeListener","_props","_props$forceRefresh","forceRefresh","_props$getUserConfirm","_props$keyLength","keyLength","basename","getDOMLocation","historyState","_window$location","createKey","random","transitionManager","setState","nextState","handlePopState","event","isExtraneousPopstateEvent","handlePop","handleHashChange","forceNextPop","ok","fromLocation","toLocation","toIndex","allKeys","fromIndex","delta","go","revertPop","initialLocation","createHref","listenerCount","checkDOMListeners","addEventListener","removeEventListener","isBlocked","href","pushState","prevIndex","nextKeys","replaceState","goBack","goForward","block","unblock","listen","unlisten","HashPathCoders","hashbang","encodePath","decodePath","noslash","slash","stripHash","url","getHashPath","replaceHashPath","createHashHistory","_props$hashType","hashType","_HashPathCoders$hashT","ignorePath","encodedPath","prevLocation","allPaths","lastIndexOf","baseTag","querySelector","getAttribute","pushHashPath","nextPaths","lowerBound","upperBound","createMemoryHistory","_props$initialEntries","initialEntries","_props$initialIndex","initialIndex","entries","entry","nextIndex","nextEntries","splice","canGo","__esModule","useEnhancedEffect","useLayoutEffect","useEffect","useEventCallback","useRef","current","useCallback","_SvgIcon","_extends2","warning","_slicedToArray","arrayWithHoles","Symbol","iterator","_arr","_n","_d","_e","_s","_i","next","done","nonIterableRest","createEventEmitter","handlers","on","handler","off","get","set","newValue","changedBits","createContext","defaultValue","calculateChangedBits","_Provider$childContex","_Consumer$contextType","contextProp","gud","Provider","_Component","_this","emitter","_proto","getChildContext","componentWillReceiveProps","nextProps","oldValue","render","children","childContextTypes","PropTypes","object","isRequired","Consumer","_Component2","_this2","getValue","onUpdate","observedBits","_proto2","componentDidMount","context","componentWillUnmount","contextTypes","createNamedContext","Router","computeRootMatch","params","isExact","_pendingLocation","RouterContext","staticContext","cache","cacheCount","matchPath","exact","strict","sensitive","matched","cacheKey","pathCache","regexp","pathToRegexp","compilePath","end","Route","component","base","createURL","staticHandler","methodName","noop","useParams","hasValue","isFilled","SSR","isAdornedStart","startAdornment","createChainedFunction","funcs","func","_len2","_key2","createMuiTheme","SwitchBase","autoFocus","checkedProp","checked","checkedIcon","className","defaultChecked","disabledProp","disabled","icon","id","inputProps","inputRef","onBlur","onChange","onFocus","readOnly","required","tabIndex","isControlled","_React$useState","useState","Boolean","checkedState","setCheckedState","hasLabelFor","IconButton","clsx","root","role","input","newChecked","padding","cursor","position","opacity","width","height","top","left","margin","zIndex","useThemeWithoutDefault","_defineProperties","descriptor","_createClass","Constructor","protoProps","staticProps","_assertThisInitialized","self","ReferenceError","isMuiElement","element","muiNames","isValidElement","ListContext","_typeof2","_typeof","ThemeContext","hasSymbol","for","mobileStepper","speedDial","appBar","drawer","modal","snackbar","tooltip","_props$color","_props$component","_props$fontSize","fontSize","htmlColor","titleAccess","_props$viewBox","viewBox","focusable","userSelect","display","fill","flexShrink","typography","pxToRem","transition","transitions","duration","shorter","colorPrimary","palette","primary","main","colorSecondary","secondary","colorAction","active","colorError","colorDisabled","fontSizeInherit","fontSizeSmall","fontSizeLarge","debounce","timeout","wait","debounced","that","later","clearTimeout","setTimeout","clear","RadioGroupContext","HashRouter","createHistory","resolveToLocation","normalizeToLocation","forwardRefShim","C","LinkAnchor","navigate","onClick","rest","ex","isModifiedEvent","forwardedRef","Link","method","ariaCurrent","activeClassName","activeStyle","classNameProp","isActiveProp","locationProp","styleProp","style","escapedPath","classnames","joinClassnames","isarray","parse","compile","tokensToFunction","tokensToRegExp","PATH_REGEXP","res","tokens","defaultDelimiter","delimiter","exec","m","escaped","offset","capture","group","modifier","asterisk","partial","repeat","optional","pattern","escapeGroup","escapeString","encodeURIComponentPretty","encodeURI","c","charCodeAt","matches","flags","opts","data","encode","pretty","encodeURIComponent","token","segment","JSON","stringify","j","test","attachKeys","route","endsWithDelimiter","groups","regexpToRegexp","parts","arrayToRegexp","stringToRegexp","propIsEnumerable","toObject","test1","String","getOwnPropertyNames","test2","fromCharCode","test3","letter","shouldUseNative","symbols","utils","paramsSerializer","serializedParams","v","toISOString","hashmarkIndex","__CANCEL__","normalizeHeaderName","DEFAULT_CONTENT_TYPE","setContentTypeIfUnset","headers","defaults","adapter","XMLHttpRequest","getDefaultAdapter","transformRequest","transformResponse","xsrfCookieName","xsrfHeaderName","maxContentLength","validateStatus","status","common","settle","buildURL","buildFullPath","parseHeaders","isURLSameOrigin","createError","config","Promise","resolve","reject","requestData","requestHeaders","request","auth","username","password","Authorization","btoa","fullPath","baseURL","open","onreadystatechange","readyState","responseURL","responseHeaders","getAllResponseHeaders","response","responseType","responseText","statusText","onabort","onerror","ontimeout","timeoutErrorMessage","cookies","xsrfValue","withCredentials","read","setRequestHeader","onDownloadProgress","onUploadProgress","upload","cancelToken","promise","then","cancel","abort","send","enhanceError","code","config1","config2","valueFromConfig2Keys","mergeDeepPropertiesKeys","defaultToConfig2Keys","prop","axiosKeys","otherKeys","Cancel","_iterableToArray","iter","_arrayWithHoles","_nonIterableRest","reactIs","REACT_STATICS","contextType","getDefaultProps","getDerivedStateFromError","getDerivedStateFromProps","mixins","propTypes","KNOWN_STATICS","caller","callee","arity","MEMO_STATICS","compare","TYPE_STATICS","getStatics","isMemo","ForwardRef","getOwnPropertyDescriptor","getPrototypeOf","objectPrototype","targetComponent","sourceComponent","blacklist","inheritedComponent","targetStatics","sourceStatics","global","Memo","ownKeys","enumerableOnly","sym","_objectSpread2","getOwnPropertyDescriptors","defineProperties","createBreakpoints","breakpoints","_breakpoints$values","xs","sm","md","lg","xl","_breakpoints$unit","unit","_breakpoints$step","step","between","start","endIndex","down","upperbound","only","createMixins","spacing","_toolbar","gutters","styles","paddingLeft","paddingRight","toolbar","minHeight","black","white","grey","50","100","200","300","400","500","600","700","800","900","A100","A200","A400","A700","indigo","pink","red","orange","blue","green","light","text","hint","divider","paper","hover","hoverOpacity","selected","disabledBackground","dark","addLightOrDark","intent","direction","shade","tonalOffset","createPalette","_palette$primary","_palette$secondary","_palette$error","_palette$warning","_palette$info","info","_palette$success","success","_palette$type","_palette$contrastThre","contrastThreshold","_palette$tonalOffset","getContrastText","augmentColor","mainShade","lightShade","darkShade","contrastText","types","deepmerge","caseAllCaps","textTransform","createTypography","_ref$fontFamily","fontFamily","_ref$fontSize","_ref$fontWeightLight","fontWeightLight","_ref$fontWeightRegula","fontWeightRegular","_ref$fontWeightMedium","fontWeightMedium","_ref$fontWeightBold","fontWeightBold","_ref$htmlFontSize","htmlFontSize","allVariants","pxToRem2","coef","size","buildVariant","fontWeight","lineHeight","letterSpacing","casing","variants","h1","h2","h3","h4","h5","h6","subtitle1","subtitle2","body1","body2","button","caption","overline","clone","createShadow","shadows","shape","borderRadius","createSpacing","transform","spacingInput","mui","factor","output","easing","easeInOut","easeOut","easeIn","sharp","shortest","short","standard","complex","enteringScreen","leavingScreen","formatMs","milliseconds","_options$duration","durationOption","_options$easing","easingOption","_options$delay","delay","animatedProp","getAutoHeightDuration","constant","_options$breakpoints","breakpointsInput","_options$mixins","mixinsInput","_options$palette","paletteInput","_options$typography","typographyInput","muiTheme","overrides","argument","NoSsr","_props$defer","defer","_props$fallback","fallback","mountedState","setMountedState","Fragment","hadKeyboardEvent","hadFocusVisibleRecently","hadFocusVisibleRecentlyTimeout","inputTypesWhitelist","tel","email","number","date","month","week","time","datetime","handleKeyDown","metaKey","altKey","ctrlKey","handlePointerDown","handleVisibilityChange","visibilityState","isFocusVisible","node","tagName","isContentEditable","focusTriggersKeyboardModality","handleBlurVisible","useIsFocusVisible","onBlurVisible","instance","doc","ReactDOM","findDOMNode","ownerDocument","getChildMapping","mapFn","Children","child","mapper","getProp","getNextChildMapping","prevChildMapping","onExited","nextChildMapping","prev","getValueForKey","nextKeysPending","pendingKeys","prevKey","childMapping","nextKey","pendingNextKey","mergeChildMappings","hasPrev","hasNext","prevChild","isLeaving","in","cloneElement","exit","enter","TransitionGroup","_React$Component","handleExited","contextValue","isMounting","firstRender","mounted","appear","currentChildMapping","_this$props","childFactory","TransitionGroupContext","Ripple","_props$pulsate","pulsate","rippleX","rippleY","rippleSize","inProp","_props$onExited","leaving","setLeaving","rippleClassName","ripple","rippleVisible","ripplePulsate","rippleStyles","childClassName","childLeaving","childPulsate","timeoutId","TouchRipple","_props$center","center","centerProp","ripples","setRipples","rippleCallback","ignoringMouseDown","startTimer","startTimerCommit","container","startCommit","cb","oldRipples","_options$pulsate","_options$center","_options$fakeElement","fakeElement","rect","getBoundingClientRect","clientX","clientY","touches","sqrt","sizeX","abs","clientWidth","sizeY","clientHeight","stop","persist","useImperativeHandle","overflow","pointerEvents","right","bottom","animation","animationDuration","backgroundColor","flip","ButtonBase","buttonRefProp","buttonRef","_props$centerRipple","centerRipple","_props$disabled","_props$disableRipple","disableRipple","_props$disableTouchRi","disableTouchRipple","_props$focusRipple","focusRipple","focusVisibleClassName","onFocusVisible","onKeyDown","onKeyUp","onMouseDown","onMouseLeave","onMouseUp","onTouchEnd","onTouchMove","onTouchStart","onDragLeave","_props$tabIndex","TouchRippleProps","_props$type","rippleRef","focusVisible","setFocusVisible","_useIsFocusVisible","focusVisibleRef","useRippleHandler","rippleAction","eventCallback","skipRippleAction","focus","handleMouseDown","handleDragLeave","handleMouseUp","handleMouseLeave","preventDefault","handleTouchStart","handleTouchEnd","handleTouchMove","handleBlur","handleFocus","currentTarget","isNonNativeButton","keydownRef","handleKeyUp","defaultPrevented","ComponentProp","buttonProps","handleUserRef","handleOwnRef","handleRef","alignItems","justifyContent","WebkitTapHighlightColor","outline","border","verticalAlign","textDecoration","borderStyle","getStyleValue","computedStyle","property","visibility","TextareaAutosize","rows","rowsMax","_props$rowsMin","rowsMin","rowsMinProp","shadowRef","syncHeight","getComputedStyle","inputShallow","placeholder","boxSizing","innerHeight","scrollHeight","singleRowHeight","outerHeight","outerHeightStyle","prevState","handleResize","InputBase","ariaDescribedby","autoComplete","endAdornment","_props$fullWidth","fullWidth","_props$inputComponent","inputComponent","_props$inputProps","inputPropsProp","inputRefProp","_props$multiline","multiline","renderSuffix","valueProp","handleInputRefWarning","handleInputPropsRefProp","handleInputRefProp","handleInputRef","focused","setFocused","fcs","onFilled","onEmpty","checkDirty","InputComponent","setAdornedStart","formControl","adornedStart","adornedEnd","dense","marginDense","onAnimationStart","animationName","inputMultiline","hiddenLabel","inputHiddenLabel","inputAdornedStart","inputAdornedEnd","inputTypeSearch","inputMarginDense","stopPropagation","placeholderHidden","placeholderVisible","paddingTop","font","minWidth","boxShadow","resize","p","q","r","t","u","w","z","aa","A","B","isMounted","enqueueForceUpdate","enqueueReplaceState","enqueueSetState","D","E","refs","updater","F","G","isReactComponent","forceUpdate","H","isPureReactComponent","I","J","K","L","__self","__source","M","g","$$typeof","_owner","N","O","P","Q","keyPrefix","count","R","U","S","T","escape","ca","da","V","ba","W","X","toArray","createRef","PureComponent","_calculateChangedBits","_currentValue","_currentValue2","_threadCount","_context","lazy","_ctor","_status","_result","useDebugValue","useReducer","Profiler","StrictMode","Suspense","createFactory","version","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","ReactCurrentDispatcher","ReactCurrentBatchConfig","suspense","ReactCurrentOwner","IsSomeRendererActing","Y","Z","ea","extractEvents","eventTypes","fa","phasedRegistrationNames","ha","registrationName","ia","ja","dependencies","ka","onError","la","ma","na","oa","pa","qa","sa","va","wa","ra","xa","ya","za","Aa","_dispatchListeners","_dispatchInstances","isPropagationStopped","isPersistent","release","Ba","Ca","injectEventPluginOrder","injectEventPluginsByName","Da","stateNode","Ea","Fa","Ga","Ha","Ia","Ja","Ka","La","Ma","Na","Oa","Pa","Qa","Ra","Sa","Ta","Ua","Wa","Xa","tag","_debugOwner","_debugSource","fileName","lineNumber","return","Ya","Za","$a","ab","bb","db","eb","fb","gb","hb","ib","jb","kb","Map","lb","mb","nb","ob","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","sb","tb","ub","vb","qb","isNaN","rb","pb","removeAttribute","setAttribute","setAttributeNS","wb","nodeName","yb","_valueTracker","setValue","stopTracking","xb","zb","Ab","_wrapperState","initialChecked","Bb","initialValue","controlled","Cb","Eb","Fb","Gb","activeElement","Ib","Hb","Jb","defaultSelected","Kb","dangerouslySetInnerHTML","Lb","Mb","Nb","textContent","xlinkHref","Ob","Pb","Qb","Rb","Sb","MSApp","execUnsafeLocalFunction","namespaceURI","innerHTML","firstChild","removeChild","appendChild","Tb","lastChild","nodeType","nodeValue","Ub","Vb","animationend","animationiteration","animationstart","transitionend","Wb","Xb","Yb","Zb","$b","ac","bc","cc","ec","alternate","effectTag","fc","memoizedState","dehydrated","gc","ic","sibling","hc","jc","kc","lc","mc","nc","oc","pc","qc","rc","sc","tc","uc","vc","zc","blockedOn","topLevelType","eventSystemFlags","nativeEvent","Ac","delete","pointerId","Bc","Cc","Ec","Fc","unstable_runWithPriority","priority","hydrate","containerInfo","Gc","Hc","Ic","Jc","shift","Kc","unstable_scheduleCallback","unstable_NormalPriority","Lc","Mc","srcElement","correspondingUseElement","parentNode","Nc","Oc","dispatchConfig","Pc","_targetInst","Qc","Rc","Sc","Tc","Uc","Interface","isDefaultPrevented","returnValue","Wc","eventPool","Xc","destructor","Vc","getPooled","cancelBubble","eventPhase","bubbles","cancelable","timeStamp","Date","now","isTrusted","Yc","elapsedTime","pseudoElement","Zc","clipboardData","$c","view","detail","ad","relatedTarget","bd","keyCode","charCode","cd","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","dd","8","9","12","13","16","17","18","19","20","27","32","33","34","35","36","37","38","39","40","45","46","112","113","114","115","116","117","118","119","120","121","122","123","144","145","224","ed","Alt","Control","Meta","Shift","gd","getModifierState","hd","shiftKey","locale","which","jd","kd","ld","nd","screenX","screenY","pageX","pageY","buttons","fromElement","toElement","movementX","movementY","od","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","pd","dataTransfer","qd","targetTouches","changedTouches","rd","sd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","td","ud","vd","wd","yd","zd","Ad","Bd","Cd","Dd","bubbled","captured","eventPriority","Ed","getEventPriority","Fd","unstable_UserBlockingPriority","Gd","Hd","Jd","Kd","targetInst","ancestors","Ld","Md","Nd","Od","Pd","Qd","Dc","Rd","Sd","WeakMap","xc","Set","yc","has","add","Td","animationIterationCount","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexGrow","flexPositive","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","lineClamp","order","orphans","tabSize","widows","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","Ud","Vd","Wd","setProperty","Xd","menuitem","area","br","col","embed","hr","img","keygen","link","meta","param","track","wbr","Yd","Zd","is","$d","ae","be","body","ce","de","nextSibling","fe","HTMLIFrameElement","contentWindow","ge","contentEditable","le","me","ne","oe","__html","pe","qe","se","previousSibling","te","ue","ve","we","xe","ye","ze","Ae","Be","Ce","De","Ee","Fe","Ge","He","documentMode","Ie","Je","Ke","Le","beforeInput","compositionEnd","compositionStart","compositionUpdate","Me","Ne","Oe","Pe","Se","Qe","char","Re","Te","range","Ue","Ve","change","We","Xe","Ye","Ze","$e","af","bf","cf","detachEvent","df","ef","attachEvent","ff","gf","hf","lf","jf","_isInputEventSupported","kf","mouseEnter","mouseLeave","pointerEnter","pointerLeave","mf","defaultView","parentWindow","of","pf","qf","rf","sf","select","tf","uf","vf","wf","xf","selectionStart","selectionEnd","anchorNode","getSelection","anchorOffset","focusNode","focusOffset","yf","onSelect","SimpleEventPlugin","EnterLeaveEventPlugin","ChangeEventPlugin","SelectEventPlugin","BeforeInputEventPlugin","Af","Bf","Cf","Df","Ef","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Ff","Gf","Hf","If","Jf","__reactInternalMemoizedMergedChildContext","Kf","Lf","Mf","Nf","unstable_cancelCallback","Of","unstable_shouldYield","Pf","unstable_requestPaint","Qf","unstable_now","Rf","unstable_getCurrentPriorityLevel","Sf","unstable_ImmediatePriority","Tf","Uf","Vf","unstable_LowPriority","Wf","unstable_IdlePriority","Xf","Yf","Zf","$f","ag","bg","cg","dg","eg","fg","gg","hg","ig","jg","kg","mg","ng","og","pg","qg","rg","sg","tg","ug","childExpirationTime","vg","firstContext","expirationTime","wg","xg","responders","yg","zg","baseState","firstUpdate","lastUpdate","firstCapturedUpdate","lastCapturedUpdate","firstEffect","lastEffect","firstCapturedEffect","lastCapturedEffect","Ag","Bg","suspenseConfig","payload","nextEffect","Cg","Dg","updateQueue","Eg","Fg","Gg","Hg","Ig","Jg","Kg","Lg","Mg","Ng","Og","Sg","_reactInternalFiber","Pg","Qg","Rg","Tg","shouldComponentUpdate","Ug","Vg","UNSAFE_componentWillReceiveProps","Wg","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","Xg","Yg","_stringRef","Zg","$g","ah","bh","mode","elementType","ch","implementation","dh","eh","ta","fh","gh","hh","ih","jh","kh","lh","mh","documentElement","nh","oh","ph","qh","memoizedProps","revealOrder","rh","responder","sh","th","uh","vh","wh","xh","yh","zh","Ah","Bh","Ch","Gh","Hh","Ih","Jh","Kh","Lh","Mh","Nh","queue","baseUpdate","Oh","Ph","Qh","lastRenderedReducer","dispatch","lastRenderedState","eagerReducer","eagerState","Rh","Sh","Th","Uh","destroy","deps","Vh","Wh","Xh","Yh","Zh","$h","ai","bi","readContext","useResponder","useDeferredValue","useTransition","unstable_next","ci","di","ei","fi","gi","hi","pendingProps","ii","ji","ki","li","mi","ni","oi","pi","qi","ri","si","ti","ui","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","vi","wi","pendingContext","Hi","Ji","Ki","xi","retryTime","yi","unstable_avoidThisFallback","zi","Ai","isBackwards","rendering","tail","tailExpiration","tailMode","Bi","Ci","Li","Mi","Ni","stack","onclick","Oi","WeakSet","Pi","Si","Ri","Ti","Ui","__reactInternalSnapshotBeforeUpdate","Vi","Wi","Qi","Xi","Yi","Zi","$i","insertBefore","_reactRootContainer","aj","wasMultiple","multiple","bj","cj","dj","ej","fj","gj","hj","ij","componentDidCatch","jj","componentStack","gk","kj","ceil","lj","mj","wj","xj","yj","zj","Aj","Bj","Dj","Ej","Fj","Gj","Hj","Ij","Jj","timeoutMs","Kj","Lj","Mj","Nj","Oj","lastExpiredTime","Pj","firstPendingTime","lastPingedTime","nextKnownPendingLevel","callbackExpirationTime","callbackPriority","callbackNode","Qj","Rj","Sj","Tj","Uj","Vj","Wj","finishedWork","finishedExpirationTime","lastSuspendedTime","Xj","timeoutHandle","Yj","busyMinDurationMs","busyDelayMs","Zj","bk","ck","pingCache","dk","ek","fk","createElementNS","createTextNode","ik","firstSuspendedTime","rangeCount","Db","focusedElem","selectionRange","jk","ee","contains","compareDocumentPosition","createRange","setStart","removeAllRanges","addRange","setEnd","scrollLeft","scrollTop","Dh","dc","fd","hk","Eh","Fh","xk","Di","Ei","Fi","xd","Gi","kk","lk","mk","hidden","Va","nk","unstable_observedBits","pk","pendingChildren","qk","rk","sk","tk","uk","vk","wc","_internalRoot","wk","zk","hasAttribute","yk","Ak","Bk","unmount","querySelectorAll","form","ak","Ck","createPortal","unstable_renderSubtreeIntoContainer","unmountComponentAtNode","unstable_createPortal","unstable_batchedUpdates","flushSync","Events","findFiberByHostInstance","isDisabled","supportsFiber","inject","onCommitFiberRoot","onCommitFiberUnmount","overrideHookState","overrideProps","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","bundleType","rendererPackageName","Dk","Ek","MessageChannel","unstable_forceFrameRate","performance","cancelAnimationFrame","requestAnimationFrame","floor","port2","port1","onmessage","postMessage","sortIndex","startTime","priorityLevel","unstable_wrapCallback","unstable_continueExecution","unstable_pauseExecution","unstable_getFirstCallbackNode","unstable_Profiling","Axios","mergeConfig","createInstance","defaultConfig","axios","instanceConfig","CancelToken","isCancel","all","promises","spread","InterceptorManager","dispatchRequest","interceptors","chain","interceptor","fulfilled","rejected","getUri","use","eject","transformData","throwIfCancellationRequested","throwIfRequested","reason","fns","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","draining","queueIndex","cleanUpNextTick","drainQueue","len","run","runClearTimeout","Item","array","nextTick","title","browser","env","argv","versions","addListener","once","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","binding","cwd","chdir","dir","umask","normalizedName","isAxiosError","toJSON","description","columnNumber","isAbsoluteURL","combineURLs","requestedURL","relativeURL","ignoreDuplicateOf","parsed","line","originURL","msie","urlParsingNode","resolveURL","protocol","host","hostname","port","requestURL","write","expires","domain","secure","cookie","toGMTString","decodeURIComponent","remove","executor","resolvePromise","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","propName","componentName","propFullName","secret","getShim","ReactPropTypes","bool","symbol","any","arrayOf","instanceOf","objectOf","oneOf","oneOfType","checkPropTypes","typeOf","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","Lazy","Portal","isValidElementType","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isPortal","isProfiler","isStrictMode","isSuspense","Function","defaultVariantMapping","Typography","_props$align","align","_props$display","_props$gutterBottom","gutterBottom","_props$noWrap","noWrap","_props$paragraph","paragraph","_props$variant","variant","_props$variantMapping","variantMapping","srOnly","alignLeft","textAlign","alignCenter","alignRight","alignJustify","textOverflow","whiteSpace","marginBottom","colorInherit","colorTextPrimary","colorTextSecondary","displayInline","displayBlock","_props$edge","edge","_props$disableFocusRi","disableFocusRipple","_props$size","small","edgeStart","edgeEnd","label","marginLeft","marginRight","sizeSmall","isBrowser","plainObjectConstrurctor","cloneStyle","newStyle","createRule","decl","jss","declCopy","rule","plugins","onCreateRule","by","toCssValue","ignoreImportant","cssValue","indentStr","indent","toCss","selector","_options$indent","fallbacks","_prop","_value","_prop2","_value2","allowEmpty","escapeRegex","nativeEscape","CSS","BaseStyleRule","isProcessed","renderer","renderable","sheet","Renderer","force","onChangeValue","isEmpty","isDefined","removeProperty","attached","StyleRule","_BaseStyleRule","selectorText","scoped","generateId","applyTo","json","setSelector","replaceRule","pluginStyleRule","parent","defaultToStringOptions","atRegExp","ConditionalRule","at","query","rules","atMatch","RuleList","getRule","addRule","onProcessRule","keyRegExp","pluginConditionalRule","defaultToStringOptions$1","nameRegExp","KeyframesRule","frames","nameMatch","keyRegExp$1","refRegExp","findReferencedKeyframe","keyframes","replaceRef","refKeyframe","plugin","onProcessStyle","KeyframeRule","pluginKeyframeRule","FontFaceRule","pluginFontFaceRule","ViewportRule","pluginViewportRule","SimpleRule","keysMap","defaultUpdateOptions","forceUpdateOptions","raw","counter","ruleOptions","_this$options","register","unregister","plugins$$1","update","updateOne","_this$options2","styleRule","nextValue","_nextValue","_prevValue","css","StyleSheet","deployed","attach","deploy","detach","insertRule","addRules","added","deleteRule","_this$rules","PluginsRegistry","internal","external","registry","onProcessSheet","processedValue","newPlugin","sheets","SheetsRegistry","reset","_temp","globalThis","ns","moduleId","createGenerateId","ruleCounter","jssId","minify","memoize","getPropertyValue","cssRule","attributeStyleMap","getHead","findPrevNode","insertionPoint","findHigherSheet","findHighestSheet","comment","head","childNodes","findCommentNode","getNonce","_insertRule","maxIndex","cssRules","appendRule","DomRenderer","hasInsertedRules","media","el","createStyle","nonce","nextNode","insertionPointElement","insertStyle","insertRules","nativeParent","latestNativeParent","parentStyleSheet","ruleStr","nativeRule","getRules","instanceCounter","Jss","isInBrowser","setup","createStyleSheet","removeStyleSheet","hasCSSTOMSupport","multiKeyStore","key1","key2","subCache","pseudoClasses","fnValuesNs","fnRuleNs","functionPlugin","fnValues","fnRule","GlobalContainerRule","GlobalPrefixedRule","separatorRegExp","addScope","scope","jssGlobal","handleNestedGlobalContainerRule","handlePrefixedGlobalRule","parentRegExp","jssNested","getReplaceRef","replaceParentRefs","nestedProp","parentProp","parentSelectors","nestedSelectors","nested","getOptions","prevOptions","nestingLevel","isNested","isNestedConditional","uppercasePattern","msPattern","toHyphenLower","hyphenateStyleName","hName","convertCase","converted","hyphenate","camelCase","hyphenatedProp","px","ms","percent","addCamelCasedVersion","regExp","newObj","units","motion","perspective","grid","iterate","innerProp","_innerProp","defaultUnit","camelCasedOptions","js","vendor","isTouch","jsCssMap","Moz","Webkit","appearence","noPrefill","supportedProperty","colorAdjust","toUpper","camelize","pascalize","mask","textOrientation","writingMode","breakPropsOld","inlineLogicalOld","newProp","unprefixed","prefixed","pascalized","scrollSnap","overscrollBehavior","propMap","flex2012","propMap$1","propKeys","prefixCss","propertyDetectors","computed","key$1","el$1","cache$1","transitionProperties","transPropsRegExp","prefixTransitionCallback","p1","p2","prefixedValue","supportedValue","jssVendorPrefixer","prefixStyle","changeProp","supportedProp","changeValue","supportedValue$$1","atRule","jssPropsSort","sort","prop0","prop1","jssPreset","functions","vendorPrefixer","propsSort","defaultOptions","disableGeneration","generateClassName","_options$disableGloba","disableGlobal","_options$productionPr","productionPrefix","_options$seed","seed","seedPrefix","styleSheet","createGenerateClassName","sheetsCache","sheetsManager","sheetsRegistry","StylesContext","StylesProvider","indexCounter","increment","getStylesCreator","themingEnabled","stylesWithOverrides","noopTheme","getClasses","cacheClasses","lastProp","lastJSS","generate","mergeClasses","baseClasses","newClasses","_ref2","stylesCreator","sheetManager","staticSheet","dynamicStyles","serverGenerateClassName","getDynamicStyles","extracted","dynamicSheet","_ref3","_ref4","useSynchronousEffect","currentKey","classNamePrefixOption","_options$defaultTheme","stylesOptions2","shouldUpdate","FormControlLabel","control","_props$labelPlacement","labelPlacement","controlProps","labelPlacementStart","flexDirection","labelPlacementTop","labelPlacementBottom","nextClasses","Switch","thumb","switchBase","makeStylesWithoutDefault","Paper","_props$square","square","_props$elevation","elevation","outlined","rounded","elevations","shadow","SPACINGS","GRID_SIZES","getOffset","div","Grid","_props$alignContent","alignContent","_props$alignItems","_props$container","_props$direction","_props$item","_props$justify","justify","_props$lg","_props$md","_props$sm","_props$spacing","_props$wrap","wrap","_props$xl","_props$xs","_props$zeroMinWidth","zeroMinWidth","StyledGrid","flexWrap","breakpoint","themeSpacing","generateGutter","accumulator","globalStyles","flexBasis","maxWidth","generateGrid","Input","disableUnderline","underline","bottomLineColor","marginTop","borderBottomColor","borderBottom","content","borderBottomStyle","FilledInput","borderTopLeftRadius","borderTopRightRadius","paddingBottom","WebkitBoxShadow","WebkitTextFillColor","Button","_props$disableElevati","disableElevation","endIconProp","endIcon","startIconProp","startIcon","textPrimary","textSecondary","outlinedPrimary","outlinedSecondary","contained","containedPrimary","containedSecondary","borderColor","textSizeSmall","textSizeLarge","outlinedSizeSmall","outlinedSizeLarge","containedSizeSmall","containedSizeLarge","sizeLarge","iconSizeSmall","iconSizeMedium","iconSizeLarge","ThemeProvider","localTheme","outerTheme","mergeOuterLocalTheme","ownerWindow","_props$disablePortal","disablePortal","onRendered","mountNode","setMountNode","getContainer","getScrollbarSize","scrollDiv","scrollbarSize","offsetWidth","ariaHidden","show","getPaddingRight","ariaHiddenSiblings","currentNode","nodesToExclude","blacklistTagNames","findIndexOf","idx","some","handleContainer","fixedNodes","restoreStyle","restorePaddings","disableScrollLock","innerWidth","isOverflowing","parentElement","scrollContainer","ModalManager","_classCallCheck","modals","containers","modalIndex","modalRef","hiddenSiblingNodes","hiddenSiblings","getHiddenSiblings","containerIndex","restore","nextTop","TrapFocus","_props$disableAutoFoc","disableAutoFocus","_props$disableEnforce","disableEnforceFocus","_props$disableRestore","disableRestoreFocus","getDoc","isEnabled","ignoreNextEnforceFocus","sentinelStart","sentinelEnd","nodeToRestore","rootRef","contain","loopFocus","interval","setInterval","clearInterval","touchAction","invisible","SimpleBackdrop","_props$invisible","defaultManager","Modal","inProps","_props$BackdropCompon","BackdropComponent","BackdropProps","_props$closeAfterTran","closeAfterTransition","_props$disableBackdro","disableBackdropClick","_props$disableEscapeK","disableEscapeKeyDown","_props$disableScrollL","_props$hideBackdrop","hideBackdrop","_props$keepMounted","keepMounted","_props$manager","manager","onBackdropClick","onClose","onEscapeKeyDown","exited","setExited","mountNodeRef","hasTransition","getHasTransition","getModal","handleMounted","mount","handleOpen","resolvedContainer","isTopModal","handlePortalRef","handleClose","inlineStyle","childProps","onEnter","Transition","initialStatus","appearStatus","unmountOnExit","mountOnEnter","nextCallback","updateStatus","prevProps","nextStatus","cancelNextCallback","getTimeouts","mounting","performEnter","performExit","appearing","timeouts","enterTimeout","safeSetState","onEntered","onEntering","onTransitionEnd","_this3","onExit","onExiting","setNextCallback","_this4","doesNotHaveTimeoutOrListener","addEndListener","UNMOUNTED","EXITED","ENTERING","ENTERED","EXITING","getTransitionProps","_props$style","transitionDuration","transitionDelay","getScale","entering","entered","Grow","_props$timeout","timer","autoTimeout","isAppearing","reflow","_getTransitionProps","_getTransitionProps2","_","muiSupportAuto","getOffsetTop","vertical","getOffsetLeft","horizontal","getTransformOriginValue","transformOrigin","getAnchorEl","anchorEl","Popover","_props$anchorOrigin","anchorOrigin","anchorPosition","_props$anchorReferenc","anchorReference","containerProp","getContentAnchorEl","_props$marginThreshol","marginThreshold","_props$PaperProps","PaperProps","_props$transformOrigi","_props$TransitionComp","TransitionComponent","_props$transitionDura","transitionDurationProp","_props$TransitionProp","TransitionProps","paperRef","getAnchorOffset","contentAnchorOffset","resolvedAnchorEl","anchorRect","anchorVertical","getContentAnchorOffset","contentAnchorEl","getScrollParent","offsetTop","getTransformOrigin","elemRect","getPositioningStyle","offsetHeight","elemTransformOrigin","containerWindow","heightThreshold","widthThreshold","diff","_diff","_diff2","_diff3","setPositioningStyles","positioning","handlePaperRef","updatePosition","overflowY","overflowX","maxHeight","List","_props$dense","_props$disablePadding","disablePadding","subheader","listStyle","nextItem","disableListWrap","nextElementSibling","previousItem","previousElementSibling","textCriteriaMatches","nextFocus","textCriteria","innerText","repeating","moveFocus","currentFocus","traversalFunction","wrappedOnce","MenuList","actions","_props$autoFocus","_props$autoFocusItem","autoFocusItem","_props$disableListWra","listRef","textCriteriaRef","previousKeyMatched","lastTime","adjustStyleForScrollbar","containerElement","noExplicitWidth","activeItemIndex","items","newChildProps","criteria","lowerKey","currTime","keepFocusOnCurrent","RTL_ORIGIN","LTR_ORIGIN","disableAutoFocusItem","_props$MenuListProps","MenuListProps","PopoverClasses","menuListActionsRef","contentAnchorRef","WebkitOverflowScrolling","areEqualValues","SelectInput","autoWidth","displayEmpty","IconComponent","labelId","_props$MenuProps","MenuProps","onOpen","openProp","renderValue","_props$SelectDisplayP","SelectDisplayProps","tabIndexProp","valueState","setValueState","_React$useState2","displayNode","setDisplayNode","isOpenControlled","_React$useState3","menuMinWidthState","setMenuMinWidthState","_React$useState4","openState","setOpenState","displaySingle","handleItemClick","itemIndex","displayMultiple","computeDisplay","menuMinWidth","buttonId","selectMenu","iconOpen","NativeSelectInput","filled","iconFilled","iconOutlined","defaultInput","NativeSelect","_props$IconComponent","ArrowDropDownIcon","_props$input","nativeSelectStyles","Select","_props$autoWidth","_props$displayEmpty","_props$labelWidth","labelWidth","_props$multiple","_props$native","native","variantProps","OutlinedInput","FormLabel","InputLabel","_props$disableAnimati","disableAnimation","shrinkProp","shrink","animated","FormControl","_props$error","_props$hiddenLabel","_props$margin","_props$required","initialAdornedStart","initialFilled","setFilled","childContext","registerEffect","marginNormal","FormHelperText","variantComponent","TextField","FormHelperTextProps","helperText","InputLabelProps","InputProps","_props$select","SelectProps","setLabelWidth","labelRef","labelNode","InputMore","notched","helperTextId","inputLabelId","InputElement","htmlFor","layer","RadioButtonUncheckedIcon","RadioButtonCheckedIcon","defaultCheckedIcon","RadioButtonIcon","defaultIcon","Radio","nameProp","onChangeProp","radioGroup","CheckBoxIcon","CheckBoxOutlineBlankIcon","defaultIndeterminateIcon","IndeterminateCheckBoxIcon","Checkbox","_props$checkedIcon","_props$icon","_props$indeterminate","indeterminate","_props$indeterminateI","indeterminateIcon","NotchedOutline","labelWidthProp","legend","borderWidth","notchedOutline","ListItem","_props$button","childrenProp","componentProp","_props$ContainerCompo","ContainerComponent","_props$ContainerProps","ContainerProps","ContainerClassName","_props$disableGutters","disableGutters","_props$divider","_props$selected","listItemRef","hasSecondaryAction","componentProps","alignItemsFlexStart","secondaryAction","backgroundClip","MenuItem","_props$role","FormGroup","_props$row","row","RadioGroup"],"mappings":"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AAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,EAAG,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,GAAI,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,GAAI,IAAK,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAIA,EAAa,EAAG,GAAI,IAAK,EAAG,EAAG,GAAI,GAA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","file":"static/js/2.6a72c269.chunk.js","sourcesContent":["'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","export default function _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n\n return target;\n}","function toVal(mix) {\n\tvar k, y, str='';\n\tif (mix) {\n\t\tif (typeof mix === 'object') {\n\t\t\tif (!!mix.push) {\n\t\t\t\tfor (k=0; k < mix.length; k++) {\n\t\t\t\t\tif (mix[k] && (y = toVal(mix[k]))) {\n\t\t\t\t\t\tstr && (str += ' ');\n\t\t\t\t\t\tstr += y;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor (k in mix) {\n\t\t\t\t\tif (mix[k] && (y = toVal(k))) {\n\t\t\t\t\t\tstr && (str += ' ');\n\t\t\t\t\t\tstr += y;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (typeof mix !== 'boolean' && !mix.call) {\n\t\t\tstr && (str += ' ');\n\t\t\tstr += mix;\n\t\t}\n\t}\n\treturn str;\n}\n\nexport default function () {\n\tvar i=0, x, str='';\n\twhile (i < arguments.length) {\n\t\tif (x = toVal(arguments[i++])) {\n\t\t\tstr && (str += ' ');\n\t\t\tstr += x\n\t\t}\n\t}\n\treturn str;\n}\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport hoistNonReactStatics from 'hoist-non-react-statics';\nimport { chainPropTypes, getDisplayName } from '@material-ui/utils';\nimport makeStyles from '../makeStyles';\nimport getThemeProps from '../getThemeProps';\nimport useTheme from '../useTheme'; // Link a style sheet with a component.\n// It does not modify the component passed to it;\n// instead, it returns a new component, with a `classes` property.\n\nvar withStyles = function withStyles(stylesOrCreator) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return function (Component) {\n var defaultTheme = options.defaultTheme,\n _options$withTheme = options.withTheme,\n withTheme = _options$withTheme === void 0 ? false : _options$withTheme,\n name = options.name,\n stylesOptions = _objectWithoutProperties(options, [\"defaultTheme\", \"withTheme\", \"name\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (Component === undefined) {\n throw new Error(['You are calling withStyles(styles)(Component) with an undefined component.', 'You may have forgotten to import it.'].join('\\n'));\n }\n }\n\n var classNamePrefix = name;\n\n if (process.env.NODE_ENV !== 'production') {\n if (!name) {\n // Provide a better DX outside production.\n var displayName = getDisplayName(Component);\n\n if (displayName !== undefined) {\n classNamePrefix = displayName;\n }\n }\n }\n\n var useStyles = makeStyles(stylesOrCreator, _extends({\n defaultTheme: defaultTheme,\n Component: Component,\n name: name || Component.displayName,\n classNamePrefix: classNamePrefix\n }, stylesOptions));\n var WithStyles = React.forwardRef(function WithStyles(props, ref) {\n var classesProp = props.classes,\n innerRef = props.innerRef,\n other = _objectWithoutProperties(props, [\"classes\", \"innerRef\"]);\n\n var classes = useStyles(props);\n var theme;\n var more = other;\n\n if (typeof name === 'string' || withTheme) {\n // name and withTheme are invariant in the outer scope\n // eslint-disable-next-line react-hooks/rules-of-hooks\n theme = useTheme() || defaultTheme;\n\n if (name) {\n more = getThemeProps({\n theme: theme,\n name: name,\n props: other\n });\n } // Provide the theme to the wrapped component.\n // So we don't have to use the `withTheme()` Higher-order Component.\n\n\n if (withTheme && !more.theme) {\n more.theme = theme;\n }\n }\n\n return React.createElement(Component, _extends({\n ref: innerRef || ref,\n classes: classes\n }, more));\n });\n process.env.NODE_ENV !== \"production\" ? WithStyles.propTypes = {\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n\n /**\n * Use that prop to pass a ref to the decorated component.\n * @deprecated\n */\n innerRef: chainPropTypes(PropTypes.oneOfType([PropTypes.func, PropTypes.object]), function (props) {\n if (props.innerRef == null) {\n return null;\n }\n\n return null; // return new Error(\n // 'Material-UI: the `innerRef` prop is deprecated and will be removed in v5. ' +\n // 'Refs are now automatically forwarded to the inner component.',\n // );\n })\n } : void 0; // The wrapper receives only user supplied props, which could be a subset of\n // the actual props Component might receive due to merging with defaultProps.\n // So copying it here would give us the same result in the wrapper as well.\n\n WithStyles.defaultProps = Component.defaultProps;\n\n if (process.env.NODE_ENV !== 'production') {\n WithStyles.displayName = \"WithStyles(\".concat(getDisplayName(Component), \")\");\n }\n\n hoistNonReactStatics(WithStyles, Component);\n\n if (process.env.NODE_ENV !== 'production') {\n // Exposed for test purposes.\n WithStyles.Naked = Component;\n WithStyles.options = options;\n WithStyles.useStyles = useStyles;\n }\n\n return WithStyles;\n };\n};\n\nexport default withStyles;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { withStyles as withStylesWithoutDefault } from '@material-ui/styles';\nimport defaultTheme from './defaultTheme';\n\nfunction withStyles(stylesOrCreator, options) {\n return withStylesWithoutDefault(stylesOrCreator, _extends({\n defaultTheme: defaultTheme\n }, options));\n}\n\nexport default withStyles;","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","// It should to be noted that this function isn't equivalent to `text-transform: capitalize`.\n//\n// A strict capitalization should uppercase the first letter of each word a the sentence.\n// We only handle the first word.\nexport default function capitalize(string) {\n if (process.env.NODE_ENV !== 'production') {\n if (typeof string !== 'string') {\n throw new Error('Material-UI: capitalize(string) expects a string argument.');\n }\n }\n\n return string.charAt(0).toUpperCase() + string.slice(1);\n}","import React from 'react';\nimport setRef from './setRef';\nexport default function useForkRef(refA, refB) {\n /**\n * This will create a new function if the ref props change and are defined.\n * This means react will call the old forkRef with `null` and the new forkRef\n * with the ref. Cleanup naturally emerges from this behavior\n */\n return React.useMemo(function () {\n if (refA == null && refB == null) {\n return null;\n }\n\n return function (refValue) {\n setRef(refA, refValue);\n setRef(refB, refValue);\n };\n }, [refA, refB]);\n}","'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n","/* eslint-disable no-use-before-define */\n\n/**\n * Returns a number whose value is limited to the given range.\n *\n * @param {number} value The value to be clamped\n * @param {number} min The lower boundary of the output range\n * @param {number} max The upper boundary of the output range\n * @returns {number} A number in the range [min, max]\n */\nfunction clamp(value) {\n var min = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n var max = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;\n\n if (process.env.NODE_ENV !== 'production') {\n if (value < min || value > max) {\n console.error(\"Material-UI: the value provided \".concat(value, \" is out of range [\").concat(min, \", \").concat(max, \"].\"));\n }\n }\n\n return Math.min(Math.max(min, value), max);\n}\n/**\n * Converts a color from CSS hex format to CSS rgb format.\n *\n * @param {string} color - Hex color, i.e. #nnn or #nnnnnn\n * @returns {string} A CSS rgb color string\n */\n\n\nexport function hexToRgb(color) {\n color = color.substr(1);\n var re = new RegExp(\".{1,\".concat(color.length / 3, \"}\"), 'g');\n var colors = color.match(re);\n\n if (colors && colors[0].length === 1) {\n colors = colors.map(function (n) {\n return n + n;\n });\n }\n\n return colors ? \"rgb(\".concat(colors.map(function (n) {\n return parseInt(n, 16);\n }).join(', '), \")\") : '';\n}\n\nfunction intToHex(int) {\n var hex = int.toString(16);\n return hex.length === 1 ? \"0\".concat(hex) : hex;\n}\n/**\n * Converts a color from CSS rgb format to CSS hex format.\n *\n * @param {string} color - RGB color, i.e. rgb(n, n, n)\n * @returns {string} A CSS rgb color string, i.e. #nnnnnn\n */\n\n\nexport function rgbToHex(color) {\n // Idempotent\n if (color.indexOf('#') === 0) {\n return color;\n }\n\n var _decomposeColor = decomposeColor(color),\n values = _decomposeColor.values;\n\n return \"#\".concat(values.map(function (n) {\n return intToHex(n);\n }).join(''));\n}\n/**\n * Converts a color from hsl format to rgb format.\n *\n * @param {string} color - HSL color values\n * @returns {string} rgb color values\n */\n\nexport function hslToRgb(color) {\n color = decomposeColor(color);\n var _color = color,\n values = _color.values;\n var h = values[0];\n var s = values[1] / 100;\n var l = values[2] / 100;\n var a = s * Math.min(l, 1 - l);\n\n var f = function f(n) {\n var k = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (n + h / 30) % 12;\n return l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n };\n\n var type = 'rgb';\n var rgb = [Math.round(f(0) * 255), Math.round(f(8) * 255), Math.round(f(4) * 255)];\n\n if (color.type === 'hsla') {\n type += 'a';\n rgb.push(values[3]);\n }\n\n return recomposeColor({\n type: type,\n values: rgb\n });\n}\n/**\n * Returns an object with the type and values of a color.\n *\n * Note: Does not support rgb % values.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {object} - A MUI color object: {type: string, values: number[]}\n */\n\nexport function decomposeColor(color) {\n // Idempotent\n if (color.type) {\n return color;\n }\n\n if (color.charAt(0) === '#') {\n return decomposeColor(hexToRgb(color));\n }\n\n var marker = color.indexOf('(');\n var type = color.substring(0, marker);\n\n if (['rgb', 'rgba', 'hsl', 'hsla'].indexOf(type) === -1) {\n throw new Error([\"Material-UI: unsupported `\".concat(color, \"` color.\"), 'We support the following formats: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla().'].join('\\n'));\n }\n\n var values = color.substring(marker + 1, color.length - 1).split(',');\n values = values.map(function (value) {\n return parseFloat(value);\n });\n return {\n type: type,\n values: values\n };\n}\n/**\n * Converts a color object with type and values to a string.\n *\n * @param {object} color - Decomposed color\n * @param {string} color.type - One of: 'rgb', 'rgba', 'hsl', 'hsla'\n * @param {array} color.values - [n,n,n] or [n,n,n,n]\n * @returns {string} A CSS color string\n */\n\nexport function recomposeColor(color) {\n var type = color.type;\n var values = color.values;\n\n if (type.indexOf('rgb') !== -1) {\n // Only convert the first 3 values to int (i.e. not alpha)\n values = values.map(function (n, i) {\n return i < 3 ? parseInt(n, 10) : n;\n });\n } else if (type.indexOf('hsl') !== -1) {\n values[1] = \"\".concat(values[1], \"%\");\n values[2] = \"\".concat(values[2], \"%\");\n }\n\n return \"\".concat(type, \"(\").concat(values.join(', '), \")\");\n}\n/**\n * Calculates the contrast ratio between two colors.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n *\n * @param {string} foreground - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {string} background - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {number} A contrast ratio value in the range 0 - 21.\n */\n\nexport function getContrastRatio(foreground, background) {\n var lumA = getLuminance(foreground);\n var lumB = getLuminance(background);\n return (Math.max(lumA, lumB) + 0.05) / (Math.min(lumA, lumB) + 0.05);\n}\n/**\n * The relative brightness of any point in a color space,\n * normalized to 0 for darkest black and 1 for lightest white.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {number} The relative brightness of the color in the range 0 - 1\n */\n\nexport function getLuminance(color) {\n color = decomposeColor(color);\n var rgb = color.type === 'hsl' ? decomposeColor(hslToRgb(color)).values : color.values;\n rgb = rgb.map(function (val) {\n val /= 255; // normalized\n\n return val <= 0.03928 ? val / 12.92 : Math.pow((val + 0.055) / 1.055, 2.4);\n }); // Truncate at 3 digits\n\n return Number((0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2]).toFixed(3));\n}\n/**\n * Darken or lighten a color, depending on its luminance.\n * Light colors are darkened, dark colors are lightened.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} coefficient=0.15 - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function emphasize(color) {\n var coefficient = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0.15;\n return getLuminance(color) > 0.5 ? darken(color, coefficient) : lighten(color, coefficient);\n}\n/**\n * Set the absolute transparency of a color.\n * Any existing alpha values are overwritten.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} value - value to set the alpha channel to in the range 0 -1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function fade(color, value) {\n color = decomposeColor(color);\n value = clamp(value);\n\n if (color.type === 'rgb' || color.type === 'hsl') {\n color.type += 'a';\n }\n\n color.values[3] = value;\n return recomposeColor(color);\n}\n/**\n * Darkens a color.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function darken(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clamp(coefficient);\n\n if (color.type.indexOf('hsl') !== -1) {\n color.values[2] *= 1 - coefficient;\n } else if (color.type.indexOf('rgb') !== -1) {\n for (var i = 0; i < 3; i += 1) {\n color.values[i] *= 1 - coefficient;\n }\n }\n\n return recomposeColor(color);\n}\n/**\n * Lightens a color.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\n\nexport function lighten(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clamp(coefficient);\n\n if (color.type.indexOf('hsl') !== -1) {\n color.values[2] += (100 - color.values[2]) * coefficient;\n } else if (color.type.indexOf('rgb') !== -1) {\n for (var i = 0; i < 3; i += 1) {\n color.values[i] += (255 - color.values[i]) * coefficient;\n }\n }\n\n return recomposeColor(color);\n}","import arrayWithoutHoles from \"./arrayWithoutHoles\";\nimport iterableToArray from \"./iterableToArray\";\nimport nonIterableSpread from \"./nonIterableSpread\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();\n}","export default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) {\n for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n }\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}","export default function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M16 9v10H8V9h8m-1.5-6h-5l-1 1H5v2h14V4h-3.5l-1-1zM18 7H6v12c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7z\"\n}), 'DeleteOutlined');\n\nexports.default = _default;","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","'use strict';\n\nvar bind = require('./helpers/bind');\n\n/*global toString:true*/\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n return (typeof FormData !== 'undefined') && (val instanceof FormData);\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n var result;\n if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n result = ArrayBuffer.isView(val);\n } else {\n result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n return str.replace(/^\\s*/, '').replace(/\\s*$/, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n * typeof window -> undefined\n * typeof document -> undefined\n *\n * react-native:\n * navigator.product -> 'ReactNative'\n * nativescript\n * navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||\n navigator.product === 'NativeScript' ||\n navigator.product === 'NS')) {\n return false;\n }\n return (\n typeof window !== 'undefined' &&\n typeof document !== 'undefined'\n );\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\n\n // Force an array if not already something iterable\n if (typeof obj !== 'object') {\n /*eslint no-param-reassign:0*/\n obj = [obj];\n }\n\n if (isArray(obj)) {\n // Iterate over array values\n for (var i = 0, l = obj.length; i < l; i++) {\n fn.call(null, obj[i], i, obj);\n }\n } else {\n // Iterate over object keys\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n fn.call(null, obj[key], key, obj);\n }\n }\n }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n var result = {};\n function assignValue(val, key) {\n if (typeof result[key] === 'object' && typeof val === 'object') {\n result[key] = merge(result[key], val);\n } else {\n result[key] = val;\n }\n }\n\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Function equal to merge with the difference being that no reference\n * to original objects is kept.\n *\n * @see merge\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction deepMerge(/* obj1, obj2, obj3, ... */) {\n var result = {};\n function assignValue(val, key) {\n if (typeof result[key] === 'object' && typeof val === 'object') {\n result[key] = deepMerge(result[key], val);\n } else if (typeof val === 'object') {\n result[key] = deepMerge({}, val);\n } else {\n result[key] = val;\n }\n }\n\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n forEach(b, function assignValue(val, key) {\n if (thisArg && typeof val === 'function') {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n });\n return a;\n}\n\nmodule.exports = {\n isArray: isArray,\n isArrayBuffer: isArrayBuffer,\n isBuffer: isBuffer,\n isFormData: isFormData,\n isArrayBufferView: isArrayBufferView,\n isString: isString,\n isNumber: isNumber,\n isObject: isObject,\n isUndefined: isUndefined,\n isDate: isDate,\n isFile: isFile,\n isBlob: isBlob,\n isFunction: isFunction,\n isStream: isStream,\n isURLSearchParams: isURLSearchParams,\n isStandardBrowserEnv: isStandardBrowserEnv,\n forEach: forEach,\n merge: merge,\n deepMerge: deepMerge,\n extend: extend,\n trim: trim\n};\n","import React from 'react';\nimport FormControlContext from './FormControlContext';\nexport default function useFormControl() {\n return React.useContext(FormControlContext);\n}","var isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n throw new Error(prefix + \": \" + (message || ''));\n}\n\nexport default invariant;\n","export default function formControlState(_ref) {\n var props = _ref.props,\n states = _ref.states,\n muiFormControl = _ref.muiFormControl;\n return states.reduce(function (acc, state) {\n acc[state] = props[state];\n\n if (muiFormControl) {\n if (typeof props[state] === 'undefined') {\n acc[state] = muiFormControl[state];\n }\n }\n\n return acc;\n }, {});\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport SvgIcon from '../../SvgIcon';\nexport default function createSvgIcon(path, displayName) {\n var Component = React.memo(React.forwardRef(function (props, ref) {\n return React.createElement(SvgIcon, _extends({}, props, {\n ref: ref\n }), path);\n }));\n\n if (process.env.NODE_ENV !== 'production') {\n Component.displayName = \"\".concat(displayName, \"Icon\");\n }\n\n Component.muiName = SvgIcon.muiName;\n return Component;\n}","function isAbsolute(pathname) {\n return pathname.charAt(0) === '/';\n}\n\n// About 1.5x faster than the two-arg version of Array#splice()\nfunction spliceOne(list, index) {\n for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) {\n list[i] = list[k];\n }\n\n list.pop();\n}\n\n// This implementation is based heavily on node's url.parse\nfunction resolvePathname(to, from) {\n if (from === undefined) from = '';\n\n var toParts = (to && to.split('/')) || [];\n var fromParts = (from && from.split('/')) || [];\n\n var isToAbs = to && isAbsolute(to);\n var isFromAbs = from && isAbsolute(from);\n var mustEndAbs = isToAbs || isFromAbs;\n\n if (to && isAbsolute(to)) {\n // to is absolute\n fromParts = toParts;\n } else if (toParts.length) {\n // to is relative, drop the filename\n fromParts.pop();\n fromParts = fromParts.concat(toParts);\n }\n\n if (!fromParts.length) return '/';\n\n var hasTrailingSlash;\n if (fromParts.length) {\n var last = fromParts[fromParts.length - 1];\n hasTrailingSlash = last === '.' || last === '..' || last === '';\n } else {\n hasTrailingSlash = false;\n }\n\n var up = 0;\n for (var i = fromParts.length; i >= 0; i--) {\n var part = fromParts[i];\n\n if (part === '.') {\n spliceOne(fromParts, i);\n } else if (part === '..') {\n spliceOne(fromParts, i);\n up++;\n } else if (up) {\n spliceOne(fromParts, i);\n up--;\n }\n }\n\n if (!mustEndAbs) for (; up--; up) fromParts.unshift('..');\n\n if (\n mustEndAbs &&\n fromParts[0] !== '' &&\n (!fromParts[0] || !isAbsolute(fromParts[0]))\n )\n fromParts.unshift('');\n\n var result = fromParts.join('/');\n\n if (hasTrailingSlash && result.substr(-1) !== '/') result += '/';\n\n return result;\n}\n\nexport default resolvePathname;\n","function valueOf(obj) {\n return obj.valueOf ? obj.valueOf() : Object.prototype.valueOf.call(obj);\n}\n\nfunction valueEqual(a, b) {\n // Test for strict equality first.\n if (a === b) return true;\n\n // Otherwise, if either of them == null they are not equal.\n if (a == null || b == null) return false;\n\n if (Array.isArray(a)) {\n return (\n Array.isArray(b) &&\n a.length === b.length &&\n a.every(function(item, index) {\n return valueEqual(item, b[index]);\n })\n );\n }\n\n if (typeof a === 'object' || typeof b === 'object') {\n var aValue = valueOf(a);\n var bValue = valueOf(b);\n\n if (aValue !== a || bValue !== b) return valueEqual(aValue, bValue);\n\n return Object.keys(Object.assign({}, a, b)).every(function(key) {\n return valueEqual(a[key], b[key]);\n });\n }\n\n return false;\n}\n\nexport default valueEqual;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport resolvePathname from 'resolve-pathname';\nimport valueEqual from 'value-equal';\nimport warning from 'tiny-warning';\nimport invariant from 'tiny-invariant';\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === '/' ? path : '/' + path;\n}\nfunction stripLeadingSlash(path) {\n return path.charAt(0) === '/' ? path.substr(1) : path;\n}\nfunction hasBasename(path, prefix) {\n return path.toLowerCase().indexOf(prefix.toLowerCase()) === 0 && '/?#'.indexOf(path.charAt(prefix.length)) !== -1;\n}\nfunction stripBasename(path, prefix) {\n return hasBasename(path, prefix) ? path.substr(prefix.length) : path;\n}\nfunction stripTrailingSlash(path) {\n return path.charAt(path.length - 1) === '/' ? path.slice(0, -1) : path;\n}\nfunction parsePath(path) {\n var pathname = path || '/';\n var search = '';\n var hash = '';\n var hashIndex = pathname.indexOf('#');\n\n if (hashIndex !== -1) {\n hash = pathname.substr(hashIndex);\n pathname = pathname.substr(0, hashIndex);\n }\n\n var searchIndex = pathname.indexOf('?');\n\n if (searchIndex !== -1) {\n search = pathname.substr(searchIndex);\n pathname = pathname.substr(0, searchIndex);\n }\n\n return {\n pathname: pathname,\n search: search === '?' ? '' : search,\n hash: hash === '#' ? '' : hash\n };\n}\nfunction createPath(location) {\n var pathname = location.pathname,\n search = location.search,\n hash = location.hash;\n var path = pathname || '/';\n if (search && search !== '?') path += search.charAt(0) === '?' ? search : \"?\" + search;\n if (hash && hash !== '#') path += hash.charAt(0) === '#' ? hash : \"#\" + hash;\n return path;\n}\n\nfunction createLocation(path, state, key, currentLocation) {\n var location;\n\n if (typeof path === 'string') {\n // Two-arg form: push(path, state)\n location = parsePath(path);\n location.state = state;\n } else {\n // One-arg form: push(location)\n location = _extends({}, path);\n if (location.pathname === undefined) location.pathname = '';\n\n if (location.search) {\n if (location.search.charAt(0) !== '?') location.search = '?' + location.search;\n } else {\n location.search = '';\n }\n\n if (location.hash) {\n if (location.hash.charAt(0) !== '#') location.hash = '#' + location.hash;\n } else {\n location.hash = '';\n }\n\n if (state !== undefined && location.state === undefined) location.state = state;\n }\n\n try {\n location.pathname = decodeURI(location.pathname);\n } catch (e) {\n if (e instanceof URIError) {\n throw new URIError('Pathname \"' + location.pathname + '\" could not be decoded. ' + 'This is likely caused by an invalid percent-encoding.');\n } else {\n throw e;\n }\n }\n\n if (key) location.key = key;\n\n if (currentLocation) {\n // Resolve incomplete/relative pathname relative to current location.\n if (!location.pathname) {\n location.pathname = currentLocation.pathname;\n } else if (location.pathname.charAt(0) !== '/') {\n location.pathname = resolvePathname(location.pathname, currentLocation.pathname);\n }\n } else {\n // When there is no prior location and pathname is empty, set it to /\n if (!location.pathname) {\n location.pathname = '/';\n }\n }\n\n return location;\n}\nfunction locationsAreEqual(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash && a.key === b.key && valueEqual(a.state, b.state);\n}\n\nfunction createTransitionManager() {\n var prompt = null;\n\n function setPrompt(nextPrompt) {\n process.env.NODE_ENV !== \"production\" ? warning(prompt == null, 'A history supports only one prompt at a time') : void 0;\n prompt = nextPrompt;\n return function () {\n if (prompt === nextPrompt) prompt = null;\n };\n }\n\n function confirmTransitionTo(location, action, getUserConfirmation, callback) {\n // TODO: If another transition starts while we're still confirming\n // the previous one, we may end up in a weird state. Figure out the\n // best way to handle this.\n if (prompt != null) {\n var result = typeof prompt === 'function' ? prompt(location, action) : prompt;\n\n if (typeof result === 'string') {\n if (typeof getUserConfirmation === 'function') {\n getUserConfirmation(result, callback);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'A history needs a getUserConfirmation function in order to use a prompt message') : void 0;\n callback(true);\n }\n } else {\n // Return false from a transition hook to cancel the transition.\n callback(result !== false);\n }\n } else {\n callback(true);\n }\n }\n\n var listeners = [];\n\n function appendListener(fn) {\n var isActive = true;\n\n function listener() {\n if (isActive) fn.apply(void 0, arguments);\n }\n\n listeners.push(listener);\n return function () {\n isActive = false;\n listeners = listeners.filter(function (item) {\n return item !== listener;\n });\n };\n }\n\n function notifyListeners() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n listeners.forEach(function (listener) {\n return listener.apply(void 0, args);\n });\n }\n\n return {\n setPrompt: setPrompt,\n confirmTransitionTo: confirmTransitionTo,\n appendListener: appendListener,\n notifyListeners: notifyListeners\n };\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction getConfirmation(message, callback) {\n callback(window.confirm(message)); // eslint-disable-line no-alert\n}\n/**\n * Returns true if the HTML5 history API is supported. Taken from Modernizr.\n *\n * https://github.com/Modernizr/Modernizr/blob/master/LICENSE\n * https://github.com/Modernizr/Modernizr/blob/master/feature-detects/history.js\n * changed to avoid false negatives for Windows Phones: https://github.com/reactjs/react-router/issues/586\n */\n\nfunction supportsHistory() {\n var ua = window.navigator.userAgent;\n if ((ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) && ua.indexOf('Mobile Safari') !== -1 && ua.indexOf('Chrome') === -1 && ua.indexOf('Windows Phone') === -1) return false;\n return window.history && 'pushState' in window.history;\n}\n/**\n * Returns true if browser fires popstate on hash change.\n * IE10 and IE11 do not.\n */\n\nfunction supportsPopStateOnHashChange() {\n return window.navigator.userAgent.indexOf('Trident') === -1;\n}\n/**\n * Returns false if using go(n) with hash history causes a full page reload.\n */\n\nfunction supportsGoWithoutReloadUsingHash() {\n return window.navigator.userAgent.indexOf('Firefox') === -1;\n}\n/**\n * Returns true if a given popstate event is an extraneous WebKit event.\n * Accounts for the fact that Chrome on iOS fires real popstate events\n * containing undefined state when pressing the back button.\n */\n\nfunction isExtraneousPopstateEvent(event) {\n return event.state === undefined && navigator.userAgent.indexOf('CriOS') === -1;\n}\n\nvar PopStateEvent = 'popstate';\nvar HashChangeEvent = 'hashchange';\n\nfunction getHistoryState() {\n try {\n return window.history.state || {};\n } catch (e) {\n // IE 11 sometimes throws when accessing window.history.state\n // See https://github.com/ReactTraining/history/pull/289\n return {};\n }\n}\n/**\n * Creates a history object that uses the HTML5 history API including\n * pushState, replaceState, and the popstate event.\n */\n\n\nfunction createBrowserHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Browser history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canUseHistory = supportsHistory();\n var needsHashChangeListener = !supportsPopStateOnHashChange();\n var _props = props,\n _props$forceRefresh = _props.forceRefresh,\n forceRefresh = _props$forceRefresh === void 0 ? false : _props$forceRefresh,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n\n function getDOMLocation(historyState) {\n var _ref = historyState || {},\n key = _ref.key,\n state = _ref.state;\n\n var _window$location = window.location,\n pathname = _window$location.pathname,\n search = _window$location.search,\n hash = _window$location.hash;\n var path = pathname + search + hash;\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path, state, key);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function handlePopState(event) {\n // Ignore extraneous popstate events in WebKit.\n if (isExtraneousPopstateEvent(event)) return;\n handlePop(getDOMLocation(event.state));\n }\n\n function handleHashChange() {\n handlePop(getDOMLocation(getHistoryState()));\n }\n\n var forceNextPop = false;\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of keys we've seen in sessionStorage.\n // Instead, we just default to 0 for keys we don't know.\n\n var toIndex = allKeys.indexOf(toLocation.key);\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allKeys.indexOf(fromLocation.key);\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n }\n\n var initialLocation = getDOMLocation(getHistoryState());\n var allKeys = [initialLocation.key]; // Public interface\n\n function createHref(location) {\n return basename + createPath(location);\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.pushState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.href = href;\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n var nextKeys = allKeys.slice(0, prevIndex + 1);\n nextKeys.push(location.key);\n allKeys = nextKeys;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot push state in browsers that do not support HTML5 history') : void 0;\n window.location.href = href;\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.replaceState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.replace(href);\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n if (prevIndex !== -1) allKeys[prevIndex] = location.key;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot replace state in browsers that do not support HTML5 history') : void 0;\n window.location.replace(href);\n }\n });\n }\n\n function go(n) {\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.addEventListener(HashChangeEvent, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.removeEventListener(HashChangeEvent, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nvar HashChangeEvent$1 = 'hashchange';\nvar HashPathCoders = {\n hashbang: {\n encodePath: function encodePath(path) {\n return path.charAt(0) === '!' ? path : '!/' + stripLeadingSlash(path);\n },\n decodePath: function decodePath(path) {\n return path.charAt(0) === '!' ? path.substr(1) : path;\n }\n },\n noslash: {\n encodePath: stripLeadingSlash,\n decodePath: addLeadingSlash\n },\n slash: {\n encodePath: addLeadingSlash,\n decodePath: addLeadingSlash\n }\n};\n\nfunction stripHash(url) {\n var hashIndex = url.indexOf('#');\n return hashIndex === -1 ? url : url.slice(0, hashIndex);\n}\n\nfunction getHashPath() {\n // We can't use window.location.hash here because it's not\n // consistent across browsers - Firefox will pre-decode it!\n var href = window.location.href;\n var hashIndex = href.indexOf('#');\n return hashIndex === -1 ? '' : href.substring(hashIndex + 1);\n}\n\nfunction pushHashPath(path) {\n window.location.hash = path;\n}\n\nfunction replaceHashPath(path) {\n window.location.replace(stripHash(window.location.href) + '#' + path);\n}\n\nfunction createHashHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Hash history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canGoWithoutReload = supportsGoWithoutReloadUsingHash();\n var _props = props,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$hashType = _props.hashType,\n hashType = _props$hashType === void 0 ? 'slash' : _props$hashType;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n var _HashPathCoders$hashT = HashPathCoders[hashType],\n encodePath = _HashPathCoders$hashT.encodePath,\n decodePath = _HashPathCoders$hashT.decodePath;\n\n function getDOMLocation() {\n var path = decodePath(getHashPath());\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n var forceNextPop = false;\n var ignorePath = null;\n\n function locationsAreEqual$$1(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash;\n }\n\n function handleHashChange() {\n var path = getHashPath();\n var encodedPath = encodePath(path);\n\n if (path !== encodedPath) {\n // Ensure we always have a properly-encoded hash.\n replaceHashPath(encodedPath);\n } else {\n var location = getDOMLocation();\n var prevLocation = history.location;\n if (!forceNextPop && locationsAreEqual$$1(prevLocation, location)) return; // A hashchange doesn't always == location change.\n\n if (ignorePath === createPath(location)) return; // Ignore this change; we already setState in push/replace.\n\n ignorePath = null;\n handlePop(location);\n }\n }\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of paths we've seen in sessionStorage.\n // Instead, we just default to 0 for paths we don't know.\n\n var toIndex = allPaths.lastIndexOf(createPath(toLocation));\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allPaths.lastIndexOf(createPath(fromLocation));\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n } // Ensure the hash is encoded properly before doing anything else.\n\n\n var path = getHashPath();\n var encodedPath = encodePath(path);\n if (path !== encodedPath) replaceHashPath(encodedPath);\n var initialLocation = getDOMLocation();\n var allPaths = [createPath(initialLocation)]; // Public interface\n\n function createHref(location) {\n var baseTag = document.querySelector('base');\n var href = '';\n\n if (baseTag && baseTag.getAttribute('href')) {\n href = stripHash(window.location.href);\n }\n\n return href + '#' + encodePath(basename + createPath(location));\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot push state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a PUSH, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n pushHashPath(encodedPath);\n var prevIndex = allPaths.lastIndexOf(createPath(history.location));\n var nextPaths = allPaths.slice(0, prevIndex + 1);\n nextPaths.push(path);\n allPaths = nextPaths;\n setState({\n action: action,\n location: location\n });\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'Hash history cannot PUSH the same path; a new entry will not be added to the history stack') : void 0;\n setState();\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot replace state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a REPLACE, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n replaceHashPath(encodedPath);\n }\n\n var prevIndex = allPaths.indexOf(createPath(history.location));\n if (prevIndex !== -1) allPaths[prevIndex] = path;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n process.env.NODE_ENV !== \"production\" ? warning(canGoWithoutReload, 'Hash history go(n) causes a full page reload in this browser') : void 0;\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(HashChangeEvent$1, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(HashChangeEvent$1, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nfunction clamp(n, lowerBound, upperBound) {\n return Math.min(Math.max(n, lowerBound), upperBound);\n}\n/**\n * Creates a history object that stores locations in memory.\n */\n\n\nfunction createMemoryHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n var _props = props,\n getUserConfirmation = _props.getUserConfirmation,\n _props$initialEntries = _props.initialEntries,\n initialEntries = _props$initialEntries === void 0 ? ['/'] : _props$initialEntries,\n _props$initialIndex = _props.initialIndex,\n initialIndex = _props$initialIndex === void 0 ? 0 : _props$initialIndex,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = history.entries.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var index = clamp(initialIndex, 0, initialEntries.length - 1);\n var entries = initialEntries.map(function (entry) {\n return typeof entry === 'string' ? createLocation(entry, undefined, createKey()) : createLocation(entry, undefined, entry.key || createKey());\n }); // Public interface\n\n var createHref = createPath;\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var prevIndex = history.index;\n var nextIndex = prevIndex + 1;\n var nextEntries = history.entries.slice(0);\n\n if (nextEntries.length > nextIndex) {\n nextEntries.splice(nextIndex, nextEntries.length - nextIndex, location);\n } else {\n nextEntries.push(location);\n }\n\n setState({\n action: action,\n location: location,\n index: nextIndex,\n entries: nextEntries\n });\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n history.entries[history.index] = location;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n var nextIndex = clamp(history.index + n, 0, history.entries.length - 1);\n var action = 'POP';\n var location = history.entries[nextIndex];\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location,\n index: nextIndex\n });\n } else {\n // Mimic the behavior of DOM histories by\n // causing a render after a cancelled POP.\n setState();\n }\n });\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n function canGo(n) {\n var nextIndex = history.index + n;\n return nextIndex >= 0 && nextIndex < history.entries.length;\n }\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n return transitionManager.setPrompt(prompt);\n }\n\n function listen(listener) {\n return transitionManager.appendListener(listener);\n }\n\n var history = {\n length: entries.length,\n action: 'POP',\n location: entries[index],\n index: index,\n entries: entries,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n canGo: canGo,\n block: block,\n listen: listen\n };\n return history;\n}\n\nexport { createBrowserHistory, createHashHistory, createMemoryHistory, createLocation, locationsAreEqual, parsePath, createPath };\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"\n}), 'Close');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11h-4v4h-2v-4H7v-2h4V7h2v4h4v2z\"\n}), 'AddCircle');\n\nexports.default = _default;","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault;","import React from 'react';\nvar useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\n/**\n * https://github.com/facebook/react/issues/14099#issuecomment-440013892\n *\n * @param {function} fn\n */\n\nexport default function useEventCallback(fn) {\n var ref = React.useRef(fn);\n useEnhancedEffect(function () {\n ref.current = fn;\n });\n return React.useCallback(function () {\n return (0, ref.current).apply(void 0, arguments);\n }, []);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = createSvgIcon;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _SvgIcon = _interopRequireDefault(require(\"@material-ui/core/SvgIcon\"));\n\nfunction createSvgIcon(path, displayName) {\n var Component = _react.default.memo(_react.default.forwardRef(function (props, ref) {\n return _react.default.createElement(_SvgIcon.default, (0, _extends2.default)({\n ref: ref\n }, props), path);\n }));\n\n if (process.env.NODE_ENV !== 'production') {\n Component.displayName = \"\".concat(displayName, \"Icon\");\n }\n\n Component.muiName = _SvgIcon.default.muiName;\n return Component;\n}","var isProduction = process.env.NODE_ENV === 'production';\nfunction warning(condition, message) {\n if (!isProduction) {\n if (condition) {\n return;\n }\n\n var text = \"Warning: \" + message;\n\n if (typeof console !== 'undefined') {\n console.warn(text);\n }\n\n try {\n throw Error(text);\n } catch (x) {}\n }\n}\n\nexport default warning;\n","import arrayWithHoles from \"./arrayWithHoles\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit\";\nimport nonIterableRest from \"./nonIterableRest\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}","export default function _iterableToArrayLimit(arr, i) {\n if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === \"[object Arguments]\")) {\n return;\n }\n\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","// TODO: Make it private only in v5\nexport default function setRef(ref, value) {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref) {\n ref.current = value;\n }\n}","import React, { Component } from 'react';\nimport _inheritsLoose from '@babel/runtime/helpers/inheritsLoose';\nimport PropTypes from 'prop-types';\nimport gud from 'gud';\nimport warning from 'tiny-warning';\n\nvar MAX_SIGNED_31_BIT_INT = 1073741823;\n\nfunction objectIs(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nfunction createEventEmitter(value) {\n var handlers = [];\n return {\n on: function on(handler) {\n handlers.push(handler);\n },\n off: function off(handler) {\n handlers = handlers.filter(function (h) {\n return h !== handler;\n });\n },\n get: function get() {\n return value;\n },\n set: function set(newValue, changedBits) {\n value = newValue;\n handlers.forEach(function (handler) {\n return handler(value, changedBits);\n });\n }\n };\n}\n\nfunction onlyChild(children) {\n return Array.isArray(children) ? children[0] : children;\n}\n\nfunction createReactContext(defaultValue, calculateChangedBits) {\n var _Provider$childContex, _Consumer$contextType;\n\n var contextProp = '__create-react-context-' + gud() + '__';\n\n var Provider =\n /*#__PURE__*/\n function (_Component) {\n _inheritsLoose(Provider, _Component);\n\n function Provider() {\n var _this;\n\n _this = _Component.apply(this, arguments) || this;\n _this.emitter = createEventEmitter(_this.props.value);\n return _this;\n }\n\n var _proto = Provider.prototype;\n\n _proto.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[contextProp] = this.emitter, _ref;\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n if (this.props.value !== nextProps.value) {\n var oldValue = this.props.value;\n var newValue = nextProps.value;\n var changedBits;\n\n if (objectIs(oldValue, newValue)) {\n changedBits = 0;\n } else {\n changedBits = typeof calculateChangedBits === 'function' ? calculateChangedBits(oldValue, newValue) : MAX_SIGNED_31_BIT_INT;\n\n if (process.env.NODE_ENV !== 'production') {\n warning((changedBits & MAX_SIGNED_31_BIT_INT) === changedBits, 'calculateChangedBits: Expected the return value to be a ' + '31-bit integer. Instead received: ' + changedBits);\n }\n\n changedBits |= 0;\n\n if (changedBits !== 0) {\n this.emitter.set(nextProps.value, changedBits);\n }\n }\n }\n };\n\n _proto.render = function render() {\n return this.props.children;\n };\n\n return Provider;\n }(Component);\n\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[contextProp] = PropTypes.object.isRequired, _Provider$childContex);\n\n var Consumer =\n /*#__PURE__*/\n function (_Component2) {\n _inheritsLoose(Consumer, _Component2);\n\n function Consumer() {\n var _this2;\n\n _this2 = _Component2.apply(this, arguments) || this;\n _this2.state = {\n value: _this2.getValue()\n };\n\n _this2.onUpdate = function (newValue, changedBits) {\n var observedBits = _this2.observedBits | 0;\n\n if ((observedBits & changedBits) !== 0) {\n _this2.setState({\n value: _this2.getValue()\n });\n }\n };\n\n return _this2;\n }\n\n var _proto2 = Consumer.prototype;\n\n _proto2.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var observedBits = nextProps.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentDidMount = function componentDidMount() {\n if (this.context[contextProp]) {\n this.context[contextProp].on(this.onUpdate);\n }\n\n var observedBits = this.props.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentWillUnmount = function componentWillUnmount() {\n if (this.context[contextProp]) {\n this.context[contextProp].off(this.onUpdate);\n }\n };\n\n _proto2.getValue = function getValue() {\n if (this.context[contextProp]) {\n return this.context[contextProp].get();\n } else {\n return defaultValue;\n }\n };\n\n _proto2.render = function render() {\n return onlyChild(this.props.children)(this.state.value);\n };\n\n return Consumer;\n }(Component);\n\n Consumer.contextTypes = (_Consumer$contextType = {}, _Consumer$contextType[contextProp] = PropTypes.object, _Consumer$contextType);\n return {\n Provider: Provider,\n Consumer: Consumer\n };\n}\n\nvar index = React.createContext || createReactContext;\n\nexport default index;\n","// TODO: Replace with React.createContext once we can assume React 16+\nimport createContext from \"mini-create-react-context\";\n\nconst createNamedContext = name => {\n const context = createContext();\n context.displayName = name;\n\n return context;\n};\n\nconst context = /*#__PURE__*/ createNamedContext(\"Router\");\nexport default context;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext\";\n\n/**\n * The public API for putting history on context.\n */\nclass Router extends React.Component {\n static computeRootMatch(pathname) {\n return { path: \"/\", url: \"/\", params: {}, isExact: pathname === \"/\" };\n }\n\n constructor(props) {\n super(props);\n\n this.state = {\n location: props.history.location\n };\n\n // This is a bit of a hack. We have to start listening for location\n // changes here in the constructor in case there are any <Redirect>s\n // on the initial render. If there are, they will replace/push when\n // they mount and since cDM fires in children before parents, we may\n // get a new location before the <Router> is mounted.\n this._isMounted = false;\n this._pendingLocation = null;\n\n if (!props.staticContext) {\n this.unlisten = props.history.listen(location => {\n if (this._isMounted) {\n this.setState({ location });\n } else {\n this._pendingLocation = location;\n }\n });\n }\n }\n\n componentDidMount() {\n this._isMounted = true;\n\n if (this._pendingLocation) {\n this.setState({ location: this._pendingLocation });\n }\n }\n\n componentWillUnmount() {\n if (this.unlisten) this.unlisten();\n }\n\n render() {\n return (\n <RouterContext.Provider\n children={this.props.children || null}\n value={{\n history: this.props.history,\n location: this.state.location,\n match: Router.computeRootMatch(this.state.location.pathname),\n staticContext: this.props.staticContext\n }}\n />\n );\n }\n}\n\nif (__DEV__) {\n Router.propTypes = {\n children: PropTypes.node,\n history: PropTypes.object.isRequired,\n staticContext: PropTypes.object\n };\n\n Router.prototype.componentDidUpdate = function(prevProps) {\n warning(\n prevProps.history === this.props.history,\n \"You cannot change <Router history>\"\n );\n };\n}\n\nexport default Router;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createMemoryHistory as createHistory } from \"history\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router\";\n\n/**\n * The public API for a <Router> that stores location in memory.\n */\nclass MemoryRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n MemoryRouter.propTypes = {\n initialEntries: PropTypes.array,\n initialIndex: PropTypes.number,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number,\n children: PropTypes.node\n };\n\n MemoryRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<MemoryRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { MemoryRouter as Router }`.\"\n );\n };\n}\n\nexport default MemoryRouter;\n","import React from \"react\";\n\nclass Lifecycle extends React.Component {\n componentDidMount() {\n if (this.props.onMount) this.props.onMount.call(this, this);\n }\n\n componentDidUpdate(prevProps) {\n if (this.props.onUpdate) this.props.onUpdate.call(this, this, prevProps);\n }\n\n componentWillUnmount() {\n if (this.props.onUnmount) this.props.onUnmount.call(this, this);\n }\n\n render() {\n return null;\n }\n}\n\nexport default Lifecycle;\n","import pathToRegexp from \"path-to-regexp\";\n\nconst cache = {};\nconst cacheLimit = 10000;\nlet cacheCount = 0;\n\nfunction compilePath(path, options) {\n const cacheKey = `${options.end}${options.strict}${options.sensitive}`;\n const pathCache = cache[cacheKey] || (cache[cacheKey] = {});\n\n if (pathCache[path]) return pathCache[path];\n\n const keys = [];\n const regexp = pathToRegexp(path, keys, options);\n const result = { regexp, keys };\n\n if (cacheCount < cacheLimit) {\n pathCache[path] = result;\n cacheCount++;\n }\n\n return result;\n}\n\n/**\n * Public API for matching a URL pathname to a path.\n */\nfunction matchPath(pathname, options = {}) {\n if (typeof options === \"string\" || Array.isArray(options)) {\n options = { path: options };\n }\n\n const { path, exact = false, strict = false, sensitive = false } = options;\n\n const paths = [].concat(path);\n\n return paths.reduce((matched, path) => {\n if (!path && path !== \"\") return null;\n if (matched) return matched;\n\n const { regexp, keys } = compilePath(path, {\n end: exact,\n strict,\n sensitive\n });\n const match = regexp.exec(pathname);\n\n if (!match) return null;\n\n const [url, ...values] = match;\n const isExact = pathname === url;\n\n if (exact && !isExact) return null;\n\n return {\n path, // the path used to match\n url: path === \"/\" && url === \"\" ? \"/\" : url, // the matched portion of the URL\n isExact, // whether or not we matched exactly\n params: keys.reduce((memo, key, index) => {\n memo[key.name] = values[index];\n return memo;\n }, {})\n };\n }, null);\n}\n\nexport default matchPath;\n","import React from \"react\";\nimport { isValidElementType } from \"react-is\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext\";\nimport matchPath from \"./matchPath\";\n\nfunction isEmptyChildren(children) {\n return React.Children.count(children) === 0;\n}\n\nfunction evalChildrenDev(children, props, path) {\n const value = children(props);\n\n warning(\n value !== undefined,\n \"You returned `undefined` from the `children` function of \" +\n `<Route${path ? ` path=\"${path}\"` : \"\"}>, but you ` +\n \"should have returned a React element or `null`\"\n );\n\n return value || null;\n}\n\n/**\n * The public API for matching a single path and rendering.\n */\nclass Route extends React.Component {\n render() {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Route> outside a <Router>\");\n\n const location = this.props.location || context.location;\n const match = this.props.computedMatch\n ? this.props.computedMatch // <Switch> already computed the match for us\n : this.props.path\n ? matchPath(location.pathname, this.props)\n : context.match;\n\n const props = { ...context, location, match };\n\n let { children, component, render } = this.props;\n\n // Preact uses an empty array as children by\n // default, so use null if that's the case.\n if (Array.isArray(children) && children.length === 0) {\n children = null;\n }\n\n return (\n <RouterContext.Provider value={props}>\n {props.match\n ? children\n ? typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : children\n : component\n ? React.createElement(component, props)\n : render\n ? render(props)\n : null\n : typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : null}\n </RouterContext.Provider>\n );\n }}\n </RouterContext.Consumer>\n );\n }\n}\n\nif (__DEV__) {\n Route.propTypes = {\n children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),\n component: (props, propName) => {\n if (props[propName] && !isValidElementType(props[propName])) {\n return new Error(\n `Invalid prop 'component' supplied to 'Route': the prop is not a valid React component`\n );\n }\n },\n exact: PropTypes.bool,\n location: PropTypes.object,\n path: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.arrayOf(PropTypes.string)\n ]),\n render: PropTypes.func,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool\n };\n\n Route.prototype.componentDidMount = function() {\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.component\n ),\n \"You should not use <Route component> and <Route children> in the same route; <Route component> will be ignored\"\n );\n\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.render\n ),\n \"You should not use <Route render> and <Route children> in the same route; <Route render> will be ignored\"\n );\n\n warning(\n !(this.props.component && this.props.render),\n \"You should not use <Route component> and <Route render> in the same route; <Route render> will be ignored\"\n );\n };\n\n Route.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n '<Route> elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n '<Route> elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Route;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createLocation, createPath } from \"history\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router\";\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === \"/\" ? path : \"/\" + path;\n}\n\nfunction addBasename(basename, location) {\n if (!basename) return location;\n\n return {\n ...location,\n pathname: addLeadingSlash(basename) + location.pathname\n };\n}\n\nfunction stripBasename(basename, location) {\n if (!basename) return location;\n\n const base = addLeadingSlash(basename);\n\n if (location.pathname.indexOf(base) !== 0) return location;\n\n return {\n ...location,\n pathname: location.pathname.substr(base.length)\n };\n}\n\nfunction createURL(location) {\n return typeof location === \"string\" ? location : createPath(location);\n}\n\nfunction staticHandler(methodName) {\n return () => {\n invariant(false, \"You cannot %s with <StaticRouter>\", methodName);\n };\n}\n\nfunction noop() {}\n\n/**\n * The public top-level API for a \"static\" <Router>, so-called because it\n * can't actually change the current location. Instead, it just records\n * location changes in a context object. Useful mainly in testing and\n * server-rendering scenarios.\n */\nclass StaticRouter extends React.Component {\n navigateTo(location, action) {\n const { basename = \"\", context = {} } = this.props;\n context.action = action;\n context.location = addBasename(basename, createLocation(location));\n context.url = createURL(context.location);\n }\n\n handlePush = location => this.navigateTo(location, \"PUSH\");\n handleReplace = location => this.navigateTo(location, \"REPLACE\");\n handleListen = () => noop;\n handleBlock = () => noop;\n\n render() {\n const { basename = \"\", context = {}, location = \"/\", ...rest } = this.props;\n\n const history = {\n createHref: path => addLeadingSlash(basename + createURL(path)),\n action: \"POP\",\n location: stripBasename(basename, createLocation(location)),\n push: this.handlePush,\n replace: this.handleReplace,\n go: staticHandler(\"go\"),\n goBack: staticHandler(\"goBack\"),\n goForward: staticHandler(\"goForward\"),\n listen: this.handleListen,\n block: this.handleBlock\n };\n\n return <Router {...rest} history={history} staticContext={context} />;\n }\n}\n\nif (__DEV__) {\n StaticRouter.propTypes = {\n basename: PropTypes.string,\n context: PropTypes.object,\n location: PropTypes.oneOfType([PropTypes.string, PropTypes.object])\n };\n\n StaticRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<StaticRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { StaticRouter as Router }`.\"\n );\n };\n}\n\nexport default StaticRouter;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext\";\nimport matchPath from \"./matchPath\";\n\n/**\n * The public API for rendering the first <Route> that matches.\n */\nclass Switch extends React.Component {\n render() {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Switch> outside a <Router>\");\n\n const location = this.props.location || context.location;\n\n let element, match;\n\n // We use React.Children.forEach instead of React.Children.toArray().find()\n // here because toArray adds keys to all child elements and we do not want\n // to trigger an unmount/remount for two <Route>s that render the same\n // component at different URLs.\n React.Children.forEach(this.props.children, child => {\n if (match == null && React.isValidElement(child)) {\n element = child;\n\n const path = child.props.path || child.props.from;\n\n match = path\n ? matchPath(location.pathname, { ...child.props, path })\n : context.match;\n }\n });\n\n return match\n ? React.cloneElement(element, { location, computedMatch: match })\n : null;\n }}\n </RouterContext.Consumer>\n );\n }\n}\n\nif (__DEV__) {\n Switch.propTypes = {\n children: PropTypes.node,\n location: PropTypes.object\n };\n\n Switch.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n '<Switch> elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n '<Switch> elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Switch;\n","import React from \"react\";\nimport invariant from \"tiny-invariant\";\n\nimport Context from \"./RouterContext.js\";\nimport matchPath from \"./matchPath.js\";\n\nconst useContext = React.useContext;\n\nexport function useHistory() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useHistory()\"\n );\n }\n\n return useContext(Context).history;\n}\n\nexport function useLocation() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useLocation()\"\n );\n }\n\n return useContext(Context).location;\n}\n\nexport function useParams() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useParams()\"\n );\n }\n\n const match = useContext(Context).match;\n return match ? match.params : {};\n}\n\nexport function useRouteMatch(path) {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useRouteMatch()\"\n );\n }\n\n return path\n ? matchPath(useLocation().pathname, path)\n : useContext(Context).match;\n}\n","import React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar FormControlContext = React.createContext();\n\nif (process.env.NODE_ENV !== 'production') {\n FormControlContext.displayName = 'FormControlContext';\n}\n\nexport function useFormControl() {\n return React.useContext(FormControlContext);\n}\nexport default FormControlContext;","// Supports determination of isControlled().\n// Controlled input accepts its current value as a prop.\n//\n// @see https://facebook.github.io/react/docs/forms.html#controlled-components\n// @param value\n// @returns {boolean} true if string (including '') or number (including zero)\nexport function hasValue(value) {\n return value != null && !(Array.isArray(value) && value.length === 0);\n} // Determine if field is empty or filled.\n// Response determines if label is presented above field or as placeholder.\n//\n// @param obj\n// @param SSR\n// @returns {boolean} False when not present or empty string.\n// True when any number or string with length.\n\nexport function isFilled(obj) {\n var SSR = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n return obj && (hasValue(obj.value) && obj.value !== '' || SSR && hasValue(obj.defaultValue) && obj.defaultValue !== '');\n} // Determine if an Input is adorned on start.\n// It's corresponding to the left with LTR.\n//\n// @param obj\n// @returns {boolean} False when no adornments.\n// True when adorned at the start.\n\nexport function isAdornedStart(obj) {\n return obj.startAdornment;\n}","/**\n * Safe chained function\n *\n * Will only create a new function if needed,\n * otherwise will pass back existing functions or null.\n *\n * @param {function} functions to chain\n * @returns {function|null}\n */\nexport default function createChainedFunction() {\n for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) {\n funcs[_key] = arguments[_key];\n }\n\n return funcs.reduce(function (acc, func) {\n if (func == null) {\n return acc;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof func !== 'function') {\n console.error('Material-UI: invalid Argument Type, must only provide functions, undefined, or null.');\n }\n }\n\n return function chainedFunction() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n acc.apply(this, args);\n func.apply(this, args);\n };\n }, function () {});\n}","import React from 'react';\nexport default React.createContext(null);","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","import createMuiTheme from './createMuiTheme';\nvar defaultTheme = createMuiTheme();\nexport default defaultTheme;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nimport IconButton from '../IconButton';\nexport var styles = {\n root: {\n padding: 9\n },\n checked: {},\n disabled: {},\n input: {\n cursor: 'inherit',\n position: 'absolute',\n opacity: 0,\n width: '100%',\n height: '100%',\n top: 0,\n left: 0,\n margin: 0,\n padding: 0,\n zIndex: 1\n }\n};\n/**\n * @ignore - internal component.\n */\n\nvar SwitchBase = React.forwardRef(function SwitchBase(props, ref) {\n var autoFocus = props.autoFocus,\n checkedProp = props.checked,\n checkedIcon = props.checkedIcon,\n classes = props.classes,\n className = props.className,\n defaultChecked = props.defaultChecked,\n disabledProp = props.disabled,\n icon = props.icon,\n id = props.id,\n inputProps = props.inputProps,\n inputRef = props.inputRef,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onFocus = props.onFocus,\n readOnly = props.readOnly,\n required = props.required,\n tabIndex = props.tabIndex,\n type = props.type,\n value = props.value,\n other = _objectWithoutProperties(props, [\"autoFocus\", \"checked\", \"checkedIcon\", \"classes\", \"className\", \"defaultChecked\", \"disabled\", \"icon\", \"id\", \"inputProps\", \"inputRef\", \"name\", \"onBlur\", \"onChange\", \"onFocus\", \"readOnly\", \"required\", \"tabIndex\", \"type\", \"value\"]);\n\n var _React$useRef = React.useRef(checkedProp != null),\n isControlled = _React$useRef.current;\n\n var _React$useState = React.useState(Boolean(defaultChecked)),\n checkedState = _React$useState[0],\n setCheckedState = _React$useState[1];\n\n var checked = isControlled ? checkedProp : checkedState;\n var muiFormControl = useFormControl();\n\n var handleFocus = function handleFocus(event) {\n if (onFocus) {\n onFocus(event);\n }\n\n if (muiFormControl && muiFormControl.onFocus) {\n muiFormControl.onFocus(event);\n }\n };\n\n var handleBlur = function handleBlur(event) {\n if (onBlur) {\n onBlur(event);\n }\n\n if (muiFormControl && muiFormControl.onBlur) {\n muiFormControl.onBlur(event);\n }\n };\n\n var handleInputChange = function handleInputChange(event) {\n var newChecked = event.target.checked;\n\n if (!isControlled) {\n setCheckedState(newChecked);\n }\n\n if (onChange) {\n onChange(event, newChecked);\n }\n };\n\n var disabled = disabledProp;\n\n if (muiFormControl) {\n if (typeof disabled === 'undefined') {\n disabled = muiFormControl.disabled;\n }\n }\n\n var hasLabelFor = type === 'checkbox' || type === 'radio';\n return React.createElement(IconButton, _extends({\n component: \"span\",\n className: clsx(classes.root, className, checked && classes.checked, disabled && classes.disabled),\n disabled: disabled,\n tabIndex: null,\n role: undefined,\n onFocus: handleFocus,\n onBlur: handleBlur,\n ref: ref\n }, other), React.createElement(\"input\", _extends({\n autoFocus: autoFocus,\n checked: checkedProp,\n defaultChecked: defaultChecked,\n className: classes.input,\n disabled: disabled,\n id: hasLabelFor && id,\n name: name,\n onChange: handleInputChange,\n readOnly: readOnly,\n ref: inputRef,\n required: required,\n tabIndex: tabIndex,\n type: type,\n value: value\n }, inputProps)), checked ? checkedIcon : icon);\n}); // NB: If changed, please update Checkbox, Switch and Radio\n// so that the API documentation is updated.\n\nprocess.env.NODE_ENV !== \"production\" ? SwitchBase.propTypes = {\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node.isRequired,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * @ignore\n */\n defaultChecked: PropTypes.bool,\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node.isRequired,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /*\n * @ignore\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string.isRequired,\n\n /**\n * The value of the component.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateSwitchBase'\n})(SwitchBase);","import { useTheme as useThemeWithoutDefault } from '@material-ui/styles';\nimport defaultTheme from './defaultTheme';\nexport default function useTheme() {\n return useThemeWithoutDefault() || defaultTheme;\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}","import React from 'react';\nexport default function isMuiElement(element, muiNames) {\n return React.isValidElement(element) && muiNames.indexOf(element.type.muiName) !== -1;\n}","import React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar ListContext = React.createContext({});\n\nif (process.env.NODE_ENV !== 'production') {\n ListContext.displayName = 'ListContext';\n}\n\nexport default ListContext;","function _typeof2(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof2(obj); }\n\nexport default function _typeof(obj) {\n if (typeof Symbol === \"function\" && _typeof2(Symbol.iterator) === \"symbol\") {\n _typeof = function _typeof(obj) {\n return _typeof2(obj);\n };\n } else {\n _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : _typeof2(obj);\n };\n }\n\n return _typeof(obj);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z\"\n}), 'CheckBoxOutlineBlank');\n\nexports.default = _default;","module.exports = require('./lib/axios');","import React from 'react';\nvar ThemeContext = React.createContext(null);\n\nif (process.env.NODE_ENV !== 'production') {\n ThemeContext.displayName = 'ThemeContext';\n}\n\nexport default ThemeContext;","var hasSymbol = typeof Symbol === 'function' && Symbol.for;\nexport default hasSymbol ? Symbol.for('mui.nested') : '__THEME_NESTED__';","// We need to centralize the zIndex definitions as they work\n// like global values in the browser.\nvar zIndex = {\n mobileStepper: 1000,\n speedDial: 1050,\n appBar: 1100,\n drawer: 1200,\n modal: 1300,\n snackbar: 1400,\n tooltip: 1500\n};\nexport default zIndex;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n userSelect: 'none',\n width: '1em',\n height: '1em',\n display: 'inline-block',\n fill: 'currentColor',\n flexShrink: 0,\n fontSize: theme.typography.pxToRem(24),\n transition: theme.transitions.create('fill', {\n duration: theme.transitions.duration.shorter\n })\n },\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n color: theme.palette.primary.main\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n color: theme.palette.secondary.main\n },\n\n /* Styles applied to the root element if `color=\"action\"`. */\n colorAction: {\n color: theme.palette.action.active\n },\n\n /* Styles applied to the root element if `color=\"error\"`. */\n colorError: {\n color: theme.palette.error.main\n },\n\n /* Styles applied to the root element if `color=\"disabled\"`. */\n colorDisabled: {\n color: theme.palette.action.disabled\n },\n\n /* Styles applied to the root element if `fontSize=\"inherit\"`. */\n fontSizeInherit: {\n fontSize: 'inherit'\n },\n\n /* Styles applied to the root element if `fontSize=\"small\"`. */\n fontSizeSmall: {\n fontSize: theme.typography.pxToRem(20)\n },\n\n /* Styles applied to the root element if `fontSize=\"large\"`. */\n fontSizeLarge: {\n fontSize: theme.typography.pxToRem(35)\n }\n };\n};\nvar SvgIcon = React.forwardRef(function SvgIcon(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'inherit' : _props$color,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'svg' : _props$component,\n _props$fontSize = props.fontSize,\n fontSize = _props$fontSize === void 0 ? 'default' : _props$fontSize,\n htmlColor = props.htmlColor,\n titleAccess = props.titleAccess,\n _props$viewBox = props.viewBox,\n viewBox = _props$viewBox === void 0 ? '0 0 24 24' : _props$viewBox,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"fontSize\", \"htmlColor\", \"titleAccess\", \"viewBox\"]);\n\n return React.createElement(Component, _extends({\n className: clsx(classes.root, className, color !== 'inherit' && classes[\"color\".concat(capitalize(color))], fontSize !== 'default' && classes[\"fontSize\".concat(capitalize(fontSize))]),\n focusable: \"false\",\n viewBox: viewBox,\n color: htmlColor,\n \"aria-hidden\": titleAccess ? null : 'true',\n role: titleAccess ? 'img' : 'presentation',\n ref: ref\n }, other), children, titleAccess ? React.createElement(\"title\", null, titleAccess) : null);\n});\nprocess.env.NODE_ENV !== \"production\" ? SvgIcon.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * Node passed into the SVG element.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n * You can use the `htmlColor` prop to apply a color attribute to the SVG element.\n */\n color: PropTypes.oneOf(['action', 'disabled', 'error', 'inherit', 'primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * The fontSize applied to the icon. Defaults to 24px, but can be configure to inherit font size.\n */\n fontSize: PropTypes.oneOf(['default', 'inherit', 'large', 'small']),\n\n /**\n * Applies a color attribute to the SVG element.\n */\n htmlColor: PropTypes.string,\n\n /**\n * The shape-rendering attribute. The behavior of the different options is described on the\n * [MDN Web Docs](https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/shape-rendering).\n * If you are having issues with blurry icons you should investigate this property.\n */\n shapeRendering: PropTypes.string,\n\n /**\n * Provides a human-readable title for the element that contains it.\n * https://www.w3.org/TR/SVG-access/#Equivalent\n */\n titleAccess: PropTypes.string,\n\n /**\n * Allows you to redefine what the coordinates without units mean inside an SVG element.\n * For example, if the SVG element is 500 (width) by 200 (height),\n * and you pass viewBox=\"0 0 50 20\",\n * this means that the coordinates inside the SVG will go from the top left corner (0,0)\n * to bottom right (50,20) and each unit will be worth 10px.\n */\n viewBox: PropTypes.string\n} : void 0;\nSvgIcon.muiName = 'SvgIcon';\nexport default withStyles(styles, {\n name: 'MuiSvgIcon'\n})(SvgIcon);","// Corresponds to 10 frames at 60 Hz.\n// A few bytes payload overhead when lodash/debounce is ~3 kB and debounce ~300 B.\nexport default function debounce(func) {\n var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 166;\n var timeout;\n\n function debounced() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n // eslint-disable-next-line consistent-this\n var that = this;\n\n var later = function later() {\n func.apply(that, args);\n };\n\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n }\n\n debounced.clear = function () {\n clearTimeout(timeout);\n };\n\n return debounced;\n}","import React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar RadioGroupContext = React.createContext();\n\nif (process.env.NODE_ENV !== 'production') {\n RadioGroupContext.displayName = 'RadioGroupContext';\n}\n\nexport default RadioGroupContext;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z\"\n}), 'Add');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M3 15h18v-2H3v2zm0 4h18v-2H3v2zm0-8h18V9H3v2zm0-6v2h18V5H3z\"\n}), 'Reorder');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"\n}), 'RadioButtonChecked');\n\nexports.default = _default;","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createBrowserHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a <Router> that uses HTML5 history.\n */\nclass BrowserRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n BrowserRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n forceRefresh: PropTypes.bool,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number\n };\n\n BrowserRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<BrowserRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { BrowserRouter as Router }`.\"\n );\n };\n}\n\nexport default BrowserRouter;\n","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createHashHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a <Router> that uses window.location.hash.\n */\nclass HashRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n HashRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n getUserConfirmation: PropTypes.func,\n hashType: PropTypes.oneOf([\"hashbang\", \"noslash\", \"slash\"])\n };\n\n HashRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<HashRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { HashRouter as Router }`.\"\n );\n };\n}\n\nexport default HashRouter;\n","import { createLocation } from \"history\";\n\nexport const resolveToLocation = (to, currentLocation) =>\n typeof to === \"function\" ? to(currentLocation) : to;\n\nexport const normalizeToLocation = (to, currentLocation) => {\n return typeof to === \"string\"\n ? createLocation(to, null, null, currentLocation)\n : to;\n};\n","import React from \"react\";\nimport { __RouterContext as RouterContext } from \"react-router\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport { resolveToLocation, normalizeToLocation } from \"./utils/locationUtils\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction isModifiedEvent(event) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\n\nconst LinkAnchor = forwardRef(\n (\n {\n innerRef, // TODO: deprecate\n navigate,\n onClick,\n ...rest\n },\n forwardedRef\n ) => {\n const { target } = rest;\n\n let props = {\n ...rest,\n onClick: event => {\n try {\n if (onClick) onClick(event);\n } catch (ex) {\n event.preventDefault();\n throw ex;\n }\n\n if (\n !event.defaultPrevented && // onClick prevented default\n event.button === 0 && // ignore everything but left clicks\n (!target || target === \"_self\") && // let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event) // ignore clicks with modifier keys\n ) {\n event.preventDefault();\n navigate();\n }\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.ref = innerRef;\n }\n\n return <a {...props} />;\n }\n);\n\nif (__DEV__) {\n LinkAnchor.displayName = \"LinkAnchor\";\n}\n\n/**\n * The public API for rendering a history-aware <a>.\n */\nconst Link = forwardRef(\n (\n {\n component = LinkAnchor,\n replace,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Link> outside a <Router>\");\n\n const { history } = context;\n\n const location = normalizeToLocation(\n resolveToLocation(to, context.location),\n context.location\n );\n\n const href = location ? history.createHref(location) : \"\";\n const props = {\n ...rest,\n href,\n navigate() {\n const location = resolveToLocation(to, context.location);\n const method = replace ? history.replace : history.push;\n\n method(location);\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return React.createElement(component, props);\n }}\n </RouterContext.Consumer>\n );\n }\n);\n\nif (__DEV__) {\n const toType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n PropTypes.func\n ]);\n const refType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.shape({ current: PropTypes.any })\n ]);\n\n Link.displayName = \"Link\";\n\n Link.propTypes = {\n innerRef: refType,\n onClick: PropTypes.func,\n replace: PropTypes.bool,\n target: PropTypes.string,\n to: toType.isRequired\n };\n}\n\nexport default Link;\n","import React from \"react\";\nimport { __RouterContext as RouterContext, matchPath } from \"react-router\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport Link from \"./Link\";\nimport { resolveToLocation, normalizeToLocation } from \"./utils/locationUtils\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction joinClassnames(...classnames) {\n return classnames.filter(i => i).join(\" \");\n}\n\n/**\n * A <Link> wrapper that knows if it's \"active\" or not.\n */\nconst NavLink = forwardRef(\n (\n {\n \"aria-current\": ariaCurrent = \"page\",\n activeClassName = \"active\",\n activeStyle,\n className: classNameProp,\n exact,\n isActive: isActiveProp,\n location: locationProp,\n strict,\n style: styleProp,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <NavLink> outside a <Router>\");\n\n const currentLocation = locationProp || context.location;\n const toLocation = normalizeToLocation(\n resolveToLocation(to, currentLocation),\n currentLocation\n );\n const { pathname: path } = toLocation;\n // Regex taken from: https://github.com/pillarjs/path-to-regexp/blob/master/index.js#L202\n const escapedPath =\n path && path.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n\n const match = escapedPath\n ? matchPath(currentLocation.pathname, {\n path: escapedPath,\n exact,\n strict\n })\n : null;\n const isActive = !!(isActiveProp\n ? isActiveProp(match, currentLocation)\n : match);\n\n const className = isActive\n ? joinClassnames(classNameProp, activeClassName)\n : classNameProp;\n const style = isActive ? { ...styleProp, ...activeStyle } : styleProp;\n\n const props = {\n \"aria-current\": (isActive && ariaCurrent) || null,\n className,\n style,\n to: toLocation,\n ...rest\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return <Link {...props} />;\n }}\n </RouterContext.Consumer>\n );\n }\n);\n\nif (__DEV__) {\n NavLink.displayName = \"NavLink\";\n\n const ariaCurrentType = PropTypes.oneOf([\n \"page\",\n \"step\",\n \"location\",\n \"date\",\n \"time\",\n \"true\"\n ]);\n\n NavLink.propTypes = {\n ...Link.propTypes,\n \"aria-current\": ariaCurrentType,\n activeClassName: PropTypes.string,\n activeStyle: PropTypes.object,\n className: PropTypes.string,\n exact: PropTypes.bool,\n isActive: PropTypes.func,\n location: PropTypes.object,\n strict: PropTypes.bool,\n style: PropTypes.object\n };\n}\n\nexport default NavLink;\n","function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nmodule.exports = _inheritsLoose;","var isarray = require('isarray')\n\n/**\n * Expose `pathToRegexp`.\n */\nmodule.exports = pathToRegexp\nmodule.exports.parse = parse\nmodule.exports.compile = compile\nmodule.exports.tokensToFunction = tokensToFunction\nmodule.exports.tokensToRegExp = tokensToRegExp\n\n/**\n * The main path matching regexp utility.\n *\n * @type {RegExp}\n */\nvar PATH_REGEXP = new RegExp([\n // Match escaped characters that would otherwise appear in future matches.\n // This allows the user to escape special characters that won't transform.\n '(\\\\\\\\.)',\n // Match Express-style parameters and un-named parameters with a prefix\n // and optional suffixes. Matches appear as:\n //\n // \"/:test(\\\\d+)?\" => [\"/\", \"test\", \"\\d+\", undefined, \"?\", undefined]\n // \"/route(\\\\d+)\" => [undefined, undefined, undefined, \"\\d+\", undefined, undefined]\n // \"/*\" => [\"/\", undefined, undefined, undefined, undefined, \"*\"]\n '([\\\\/.])?(?:(?:\\\\:(\\\\w+)(?:\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))?|\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))([+*?])?|(\\\\*))'\n].join('|'), 'g')\n\n/**\n * Parse a string for the raw tokens.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!Array}\n */\nfunction parse (str, options) {\n var tokens = []\n var key = 0\n var index = 0\n var path = ''\n var defaultDelimiter = options && options.delimiter || '/'\n var res\n\n while ((res = PATH_REGEXP.exec(str)) != null) {\n var m = res[0]\n var escaped = res[1]\n var offset = res.index\n path += str.slice(index, offset)\n index = offset + m.length\n\n // Ignore already escaped sequences.\n if (escaped) {\n path += escaped[1]\n continue\n }\n\n var next = str[index]\n var prefix = res[2]\n var name = res[3]\n var capture = res[4]\n var group = res[5]\n var modifier = res[6]\n var asterisk = res[7]\n\n // Push the current path onto the tokens.\n if (path) {\n tokens.push(path)\n path = ''\n }\n\n var partial = prefix != null && next != null && next !== prefix\n var repeat = modifier === '+' || modifier === '*'\n var optional = modifier === '?' || modifier === '*'\n var delimiter = res[2] || defaultDelimiter\n var pattern = capture || group\n\n tokens.push({\n name: name || key++,\n prefix: prefix || '',\n delimiter: delimiter,\n optional: optional,\n repeat: repeat,\n partial: partial,\n asterisk: !!asterisk,\n pattern: pattern ? escapeGroup(pattern) : (asterisk ? '.*' : '[^' + escapeString(delimiter) + ']+?')\n })\n }\n\n // Match any characters still remaining.\n if (index < str.length) {\n path += str.substr(index)\n }\n\n // If the path exists, push it onto the end.\n if (path) {\n tokens.push(path)\n }\n\n return tokens\n}\n\n/**\n * Compile a string to a template function for the path.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!function(Object=, Object=)}\n */\nfunction compile (str, options) {\n return tokensToFunction(parse(str, options), options)\n}\n\n/**\n * Prettier encoding of URI path segments.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeURIComponentPretty (str) {\n return encodeURI(str).replace(/[\\/?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeAsterisk (str) {\n return encodeURI(str).replace(/[?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Expose a method for transforming tokens into the path function.\n */\nfunction tokensToFunction (tokens, options) {\n // Compile all the tokens into regexps.\n var matches = new Array(tokens.length)\n\n // Compile all the patterns before compilation.\n for (var i = 0; i < tokens.length; i++) {\n if (typeof tokens[i] === 'object') {\n matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$', flags(options))\n }\n }\n\n return function (obj, opts) {\n var path = ''\n var data = obj || {}\n var options = opts || {}\n var encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent\n\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n path += token\n\n continue\n }\n\n var value = data[token.name]\n var segment\n\n if (value == null) {\n if (token.optional) {\n // Prepend partial segment prefixes.\n if (token.partial) {\n path += token.prefix\n }\n\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to be defined')\n }\n }\n\n if (isarray(value)) {\n if (!token.repeat) {\n throw new TypeError('Expected \"' + token.name + '\" to not repeat, but received `' + JSON.stringify(value) + '`')\n }\n\n if (value.length === 0) {\n if (token.optional) {\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to not be empty')\n }\n }\n\n for (var j = 0; j < value.length; j++) {\n segment = encode(value[j])\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected all \"' + token.name + '\" to match \"' + token.pattern + '\", but received `' + JSON.stringify(segment) + '`')\n }\n\n path += (j === 0 ? token.prefix : token.delimiter) + segment\n }\n\n continue\n }\n\n segment = token.asterisk ? encodeAsterisk(value) : encode(value)\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected \"' + token.name + '\" to match \"' + token.pattern + '\", but received \"' + segment + '\"')\n }\n\n path += token.prefix + segment\n }\n\n return path\n }\n}\n\n/**\n * Escape a regular expression string.\n *\n * @param {string} str\n * @return {string}\n */\nfunction escapeString (str) {\n return str.replace(/([.+*?=^!:${}()[\\]|\\/\\\\])/g, '\\\\$1')\n}\n\n/**\n * Escape the capturing group by escaping special characters and meaning.\n *\n * @param {string} group\n * @return {string}\n */\nfunction escapeGroup (group) {\n return group.replace(/([=!:$\\/()])/g, '\\\\$1')\n}\n\n/**\n * Attach the keys as a property of the regexp.\n *\n * @param {!RegExp} re\n * @param {Array} keys\n * @return {!RegExp}\n */\nfunction attachKeys (re, keys) {\n re.keys = keys\n return re\n}\n\n/**\n * Get the flags for a regexp from the options.\n *\n * @param {Object} options\n * @return {string}\n */\nfunction flags (options) {\n return options && options.sensitive ? '' : 'i'\n}\n\n/**\n * Pull out keys from a regexp.\n *\n * @param {!RegExp} path\n * @param {!Array} keys\n * @return {!RegExp}\n */\nfunction regexpToRegexp (path, keys) {\n // Use a negative lookahead to match only capturing groups.\n var groups = path.source.match(/\\((?!\\?)/g)\n\n if (groups) {\n for (var i = 0; i < groups.length; i++) {\n keys.push({\n name: i,\n prefix: null,\n delimiter: null,\n optional: false,\n repeat: false,\n partial: false,\n asterisk: false,\n pattern: null\n })\n }\n }\n\n return attachKeys(path, keys)\n}\n\n/**\n * Transform an array into a regexp.\n *\n * @param {!Array} path\n * @param {Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction arrayToRegexp (path, keys, options) {\n var parts = []\n\n for (var i = 0; i < path.length; i++) {\n parts.push(pathToRegexp(path[i], keys, options).source)\n }\n\n var regexp = new RegExp('(?:' + parts.join('|') + ')', flags(options))\n\n return attachKeys(regexp, keys)\n}\n\n/**\n * Create a path regexp from string input.\n *\n * @param {string} path\n * @param {!Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction stringToRegexp (path, keys, options) {\n return tokensToRegExp(parse(path, options), keys, options)\n}\n\n/**\n * Expose a function for taking tokens and returning a RegExp.\n *\n * @param {!Array} tokens\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction tokensToRegExp (tokens, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n var strict = options.strict\n var end = options.end !== false\n var route = ''\n\n // Iterate over the tokens and create our regexp string.\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n route += escapeString(token)\n } else {\n var prefix = escapeString(token.prefix)\n var capture = '(?:' + token.pattern + ')'\n\n keys.push(token)\n\n if (token.repeat) {\n capture += '(?:' + prefix + capture + ')*'\n }\n\n if (token.optional) {\n if (!token.partial) {\n capture = '(?:' + prefix + '(' + capture + '))?'\n } else {\n capture = prefix + '(' + capture + ')?'\n }\n } else {\n capture = prefix + '(' + capture + ')'\n }\n\n route += capture\n }\n }\n\n var delimiter = escapeString(options.delimiter || '/')\n var endsWithDelimiter = route.slice(-delimiter.length) === delimiter\n\n // In non-strict mode we allow a slash at the end of match. If the path to\n // match already ends with a slash, we remove it for consistency. The slash\n // is valid at the end of a path match, not in the middle. This is important\n // in non-ending mode, where \"/test/\" shouldn't match \"/test//route\".\n if (!strict) {\n route = (endsWithDelimiter ? route.slice(0, -delimiter.length) : route) + '(?:' + delimiter + '(?=$))?'\n }\n\n if (end) {\n route += '$'\n } else {\n // In non-ending mode, we need the capturing groups to match as much as\n // possible by using a positive lookahead to the end or next path segment.\n route += strict && endsWithDelimiter ? '' : '(?=' + delimiter + '|$)'\n }\n\n return attachKeys(new RegExp('^' + route, flags(options)), keys)\n}\n\n/**\n * Normalize the given path string, returning a regular expression.\n *\n * An empty array can be passed in for the keys, which will hold the\n * placeholder key descriptions. For example, using `/user/:id`, `keys` will\n * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.\n *\n * @param {(string|RegExp|Array)} path\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction pathToRegexp (path, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n if (path instanceof RegExp) {\n return regexpToRegexp(path, /** @type {!Array} */ (keys))\n }\n\n if (isarray(path)) {\n return arrayToRegexp(/** @type {!Array} */ (path), /** @type {!Array} */ (keys), options)\n }\n\n return stringToRegexp(/** @type {string} */ (path), /** @type {!Array} */ (keys), options)\n}\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n return function wrap() {\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n return fn.apply(thisArg, args);\n };\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction encode(val) {\n return encodeURIComponent(val).\n replace(/%40/gi, '@').\n replace(/%3A/gi, ':').\n replace(/%24/g, '$').\n replace(/%2C/gi, ',').\n replace(/%20/g, '+').\n replace(/%5B/gi, '[').\n replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n\n var serializedParams;\n if (paramsSerializer) {\n serializedParams = paramsSerializer(params);\n } else if (utils.isURLSearchParams(params)) {\n serializedParams = params.toString();\n } else {\n var parts = [];\n\n utils.forEach(params, function serialize(val, key) {\n if (val === null || typeof val === 'undefined') {\n return;\n }\n\n if (utils.isArray(val)) {\n key = key + '[]';\n } else {\n val = [val];\n }\n\n utils.forEach(val, function parseValue(v) {\n if (utils.isDate(v)) {\n v = v.toISOString();\n } else if (utils.isObject(v)) {\n v = JSON.stringify(v);\n }\n parts.push(encode(key) + '=' + encode(v));\n });\n });\n\n serializedParams = parts.join('&');\n }\n\n if (serializedParams) {\n var hashmarkIndex = url.indexOf('#');\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n\n return url;\n};\n","'use strict';\n\nmodule.exports = function isCancel(value) {\n return !!(value && value.__CANCEL__);\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\n\nvar DEFAULT_CONTENT_TYPE = {\n 'Content-Type': 'application/x-www-form-urlencoded'\n};\n\nfunction setContentTypeIfUnset(headers, value) {\n if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n headers['Content-Type'] = value;\n }\n}\n\nfunction getDefaultAdapter() {\n var adapter;\n if (typeof XMLHttpRequest !== 'undefined') {\n // For browsers use XHR adapter\n adapter = require('./adapters/xhr');\n } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n // For node use HTTP adapter\n adapter = require('./adapters/http');\n }\n return adapter;\n}\n\nvar defaults = {\n adapter: getDefaultAdapter(),\n\n transformRequest: [function transformRequest(data, headers) {\n normalizeHeaderName(headers, 'Accept');\n normalizeHeaderName(headers, 'Content-Type');\n if (utils.isFormData(data) ||\n utils.isArrayBuffer(data) ||\n utils.isBuffer(data) ||\n utils.isStream(data) ||\n utils.isFile(data) ||\n utils.isBlob(data)\n ) {\n return data;\n }\n if (utils.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils.isURLSearchParams(data)) {\n setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n return data.toString();\n }\n if (utils.isObject(data)) {\n setContentTypeIfUnset(headers, 'application/json;charset=utf-8');\n return JSON.stringify(data);\n }\n return data;\n }],\n\n transformResponse: [function transformResponse(data) {\n /*eslint no-param-reassign:0*/\n if (typeof data === 'string') {\n try {\n data = JSON.parse(data);\n } catch (e) { /* Ignore */ }\n }\n return data;\n }],\n\n /**\n * A timeout in milliseconds to abort a request. If set to 0 (default) a\n * timeout is not created.\n */\n timeout: 0,\n\n xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n\n maxContentLength: -1,\n\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n }\n};\n\ndefaults.headers = {\n common: {\n 'Accept': 'application/json, text/plain, */*'\n }\n};\n\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n defaults.headers[method] = {};\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\n\nmodule.exports = defaults;\n","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\n\nmodule.exports = function xhrAdapter(config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n var requestData = config.data;\n var requestHeaders = config.headers;\n\n if (utils.isFormData(requestData)) {\n delete requestHeaders['Content-Type']; // Let the browser set it\n }\n\n var request = new XMLHttpRequest();\n\n // HTTP basic authentication\n if (config.auth) {\n var username = config.auth.username || '';\n var password = config.auth.password || '';\n requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n }\n\n var fullPath = buildFullPath(config.baseURL, config.url);\n request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n // Set the request timeout in MS\n request.timeout = config.timeout;\n\n // Listen for ready state\n request.onreadystatechange = function handleLoad() {\n if (!request || request.readyState !== 4) {\n return;\n }\n\n // The request errored out and we didn't get a response, this will be\n // handled by onerror instead\n // With one exception: request that using file: protocol, most browsers\n // will return status as 0 even though it's a successful request\n if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n return;\n }\n\n // Prepare the response\n var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;\n var response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config: config,\n request: request\n };\n\n settle(resolve, reject, response);\n\n // Clean up request\n request = null;\n };\n\n // Handle browser request cancellation (as opposed to a manual cancellation)\n request.onabort = function handleAbort() {\n if (!request) {\n return;\n }\n\n reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\n };\n\n // Handle low level network errors\n request.onerror = function handleError() {\n // Real errors are hidden from us by the browser\n // onerror should only fire if it's a network error\n reject(createError('Network Error', config, null, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle timeout\n request.ontimeout = function handleTimeout() {\n var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n if (config.timeoutErrorMessage) {\n timeoutErrorMessage = config.timeoutErrorMessage;\n }\n reject(createError(timeoutErrorMessage, config, 'ECONNABORTED',\n request));\n\n // Clean up request\n request = null;\n };\n\n // Add xsrf header\n // This is only done if running in a standard browser environment.\n // Specifically not if we're in a web worker, or react-native.\n if (utils.isStandardBrowserEnv()) {\n var cookies = require('./../helpers/cookies');\n\n // Add xsrf header\n var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?\n cookies.read(config.xsrfCookieName) :\n undefined;\n\n if (xsrfValue) {\n requestHeaders[config.xsrfHeaderName] = xsrfValue;\n }\n }\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n // Remove Content-Type if data is undefined\n delete requestHeaders[key];\n } else {\n // Otherwise add header to the request\n request.setRequestHeader(key, val);\n }\n });\n }\n\n // Add withCredentials to request if needed\n if (!utils.isUndefined(config.withCredentials)) {\n request.withCredentials = !!config.withCredentials;\n }\n\n // Add responseType to request if needed\n if (config.responseType) {\n try {\n request.responseType = config.responseType;\n } catch (e) {\n // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.\n // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.\n if (config.responseType !== 'json') {\n throw e;\n }\n }\n }\n\n // Handle progress if needed\n if (typeof config.onDownloadProgress === 'function') {\n request.addEventListener('progress', config.onDownloadProgress);\n }\n\n // Not all browsers support upload events\n if (typeof config.onUploadProgress === 'function' && request.upload) {\n request.upload.addEventListener('progress', config.onUploadProgress);\n }\n\n if (config.cancelToken) {\n // Handle cancellation\n config.cancelToken.promise.then(function onCanceled(cancel) {\n if (!request) {\n return;\n }\n\n request.abort();\n reject(cancel);\n // Clean up request\n request = null;\n });\n }\n\n if (requestData === undefined) {\n requestData = null;\n }\n\n // Send the request\n request.send(requestData);\n });\n};\n","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n var error = new Error(message);\n return enhanceError(error, config, code, request, response);\n};\n","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n var config = {};\n\n var valueFromConfig2Keys = ['url', 'method', 'params', 'data'];\n var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy'];\n var defaultToConfig2Keys = [\n 'baseURL', 'url', 'transformRequest', 'transformResponse', 'paramsSerializer',\n 'timeout', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',\n 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress',\n 'maxContentLength', 'validateStatus', 'maxRedirects', 'httpAgent',\n 'httpsAgent', 'cancelToken', 'socketPath'\n ];\n\n utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n }\n });\n\n utils.forEach(mergeDeepPropertiesKeys, function mergeDeepProperties(prop) {\n if (utils.isObject(config2[prop])) {\n config[prop] = utils.deepMerge(config1[prop], config2[prop]);\n } else if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (utils.isObject(config1[prop])) {\n config[prop] = utils.deepMerge(config1[prop]);\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n\n utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n\n var axiosKeys = valueFromConfig2Keys\n .concat(mergeDeepPropertiesKeys)\n .concat(defaultToConfig2Keys);\n\n var otherKeys = Object\n .keys(config2)\n .filter(function filterAxiosKeys(key) {\n return axiosKeys.indexOf(key) === -1;\n });\n\n utils.forEach(otherKeys, function otherKeysDefaultToConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n\n return config;\n};\n","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n this.message = message;\n}\n\nCancel.prototype.toString = function toString() {\n return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\n\nCancel.prototype.__CANCEL__ = true;\n\nmodule.exports = Cancel;\n","export { default } from './SvgIcon';","export default function _iterableToArray(iter) {\n if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\n\nfunction getStatics(component) {\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n }\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"\n}), 'RadioButtonUnchecked');\n\nexports.default = _default;","// @flow\n'use strict';\n\nvar key = '__global_unique_id__';\n\nmodule.exports = function() {\n return global[key] = (global[key] || 0) + 1;\n};\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","import defineProperty from \"./defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n if (enumerableOnly) symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n keys.push.apply(keys, symbols);\n }\n\n return keys;\n}\n\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? arguments[i] : {};\n\n if (i % 2) {\n ownKeys(Object(source), true).forEach(function (key) {\n defineProperty(target, key, source[key]);\n });\n } else if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n }\n\n return target;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z\"\n}), 'KeyboardArrowRight');\n\nexports.default = _default;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n// Sorted ASC by size. That's important.\n// It can't be configured as it's used statically for propTypes.\nexport var keys = ['xs', 'sm', 'md', 'lg', 'xl']; // Keep in mind that @media is inclusive by the CSS specification.\n\nexport default function createBreakpoints(breakpoints) {\n var _breakpoints$values = breakpoints.values,\n values = _breakpoints$values === void 0 ? {\n xs: 0,\n sm: 600,\n md: 960,\n lg: 1280,\n xl: 1920\n } : _breakpoints$values,\n _breakpoints$unit = breakpoints.unit,\n unit = _breakpoints$unit === void 0 ? 'px' : _breakpoints$unit,\n _breakpoints$step = breakpoints.step,\n step = _breakpoints$step === void 0 ? 5 : _breakpoints$step,\n other = _objectWithoutProperties(breakpoints, [\"values\", \"unit\", \"step\"]);\n\n function up(key) {\n var value = typeof values[key] === 'number' ? values[key] : key;\n return \"@media (min-width:\".concat(value).concat(unit, \")\");\n }\n\n function down(key) {\n var endIndex = keys.indexOf(key) + 1;\n var upperbound = values[keys[endIndex]];\n\n if (endIndex === keys.length) {\n // xl down applies to all sizes\n return up('xs');\n }\n\n var value = typeof upperbound === 'number' && endIndex > 0 ? upperbound : key;\n return \"@media (max-width:\".concat(value - step / 100).concat(unit, \")\");\n }\n\n function between(start, end) {\n var endIndex = keys.indexOf(end);\n\n if (endIndex === keys.length - 1) {\n return up(start);\n }\n\n return \"@media (min-width:\".concat(typeof values[start] === 'number' ? values[start] : start).concat(unit, \") and \") + \"(max-width:\".concat((endIndex !== -1 && typeof values[keys[endIndex + 1]] === 'number' ? values[keys[endIndex + 1]] : end) - step / 100).concat(unit, \")\");\n }\n\n function only(key) {\n return between(key, key);\n }\n\n function width(key) {\n return values[key];\n }\n\n return _extends({\n keys: keys,\n values: values,\n up: up,\n down: down,\n between: between,\n only: only,\n width: width\n }, other);\n}","import _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nexport default function createMixins(breakpoints, spacing, mixins) {\n var _toolbar;\n\n return _extends({\n gutters: function gutters() {\n var styles = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n // To deprecate in v4.1\n // warning(\n // false,\n // [\n // 'Material-UI: theme.mixins.gutters() is deprecated.',\n // 'You can use the source of the mixin directly:',\n // `\n // paddingLeft: theme.spacing(2),\n // paddingRight: theme.spacing(2),\n // [theme.breakpoints.up('sm')]: {\n // paddingLeft: theme.spacing(3),\n // paddingRight: theme.spacing(3),\n // },\n // `,\n // ].join('\\n'),\n // );\n return _extends({\n paddingLeft: spacing(2),\n paddingRight: spacing(2)\n }, styles, _defineProperty({}, breakpoints.up('sm'), _extends({\n paddingLeft: spacing(3),\n paddingRight: spacing(3)\n }, styles[breakpoints.up('sm')])));\n },\n toolbar: (_toolbar = {\n minHeight: 56\n }, _defineProperty(_toolbar, \"\".concat(breakpoints.up('xs'), \" and (orientation: landscape)\"), {\n minHeight: 48\n }), _defineProperty(_toolbar, breakpoints.up('sm'), {\n minHeight: 64\n }), _toolbar)\n }, mixins);\n}","var common = {\n black: '#000',\n white: '#fff'\n};\nexport default common;","var grey = {\n 50: '#fafafa',\n 100: '#f5f5f5',\n 200: '#eeeeee',\n 300: '#e0e0e0',\n 400: '#bdbdbd',\n 500: '#9e9e9e',\n 600: '#757575',\n 700: '#616161',\n 800: '#424242',\n 900: '#212121',\n A100: '#d5d5d5',\n A200: '#aaaaaa',\n A400: '#303030',\n A700: '#616161'\n};\nexport default grey;","var indigo = {\n 50: '#e8eaf6',\n 100: '#c5cae9',\n 200: '#9fa8da',\n 300: '#7986cb',\n 400: '#5c6bc0',\n 500: '#3f51b5',\n 600: '#3949ab',\n 700: '#303f9f',\n 800: '#283593',\n 900: '#1a237e',\n A100: '#8c9eff',\n A200: '#536dfe',\n A400: '#3d5afe',\n A700: '#304ffe'\n};\nexport default indigo;","var pink = {\n 50: '#fce4ec',\n 100: '#f8bbd0',\n 200: '#f48fb1',\n 300: '#f06292',\n 400: '#ec407a',\n 500: '#e91e63',\n 600: '#d81b60',\n 700: '#c2185b',\n 800: '#ad1457',\n 900: '#880e4f',\n A100: '#ff80ab',\n A200: '#ff4081',\n A400: '#f50057',\n A700: '#c51162'\n};\nexport default pink;","var red = {\n 50: '#ffebee',\n 100: '#ffcdd2',\n 200: '#ef9a9a',\n 300: '#e57373',\n 400: '#ef5350',\n 500: '#f44336',\n 600: '#e53935',\n 700: '#d32f2f',\n 800: '#c62828',\n 900: '#b71c1c',\n A100: '#ff8a80',\n A200: '#ff5252',\n A400: '#ff1744',\n A700: '#d50000'\n};\nexport default red;","var orange = {\n 50: '#fff3e0',\n 100: '#ffe0b2',\n 200: '#ffcc80',\n 300: '#ffb74d',\n 400: '#ffa726',\n 500: '#ff9800',\n 600: '#fb8c00',\n 700: '#f57c00',\n 800: '#ef6c00',\n 900: '#e65100',\n A100: '#ffd180',\n A200: '#ffab40',\n A400: '#ff9100',\n A700: '#ff6d00'\n};\nexport default orange;","var blue = {\n 50: '#e3f2fd',\n 100: '#bbdefb',\n 200: '#90caf9',\n 300: '#64b5f6',\n 400: '#42a5f5',\n 500: '#2196f3',\n 600: '#1e88e5',\n 700: '#1976d2',\n 800: '#1565c0',\n 900: '#0d47a1',\n A100: '#82b1ff',\n A200: '#448aff',\n A400: '#2979ff',\n A700: '#2962ff'\n};\nexport default blue;","var green = {\n 50: '#e8f5e9',\n 100: '#c8e6c9',\n 200: '#a5d6a7',\n 300: '#81c784',\n 400: '#66bb6a',\n 500: '#4caf50',\n 600: '#43a047',\n 700: '#388e3c',\n 800: '#2e7d32',\n 900: '#1b5e20',\n A100: '#b9f6ca',\n A200: '#69f0ae',\n A400: '#00e676',\n A700: '#00c853'\n};\nexport default green;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport { deepmerge } from '@material-ui/utils';\nimport common from '../colors/common';\nimport grey from '../colors/grey';\nimport indigo from '../colors/indigo';\nimport pink from '../colors/pink';\nimport red from '../colors/red';\nimport orange from '../colors/orange';\nimport blue from '../colors/blue';\nimport green from '../colors/green';\nimport { darken, getContrastRatio, lighten } from './colorManipulator';\nexport var light = {\n // The colors used to style the text.\n text: {\n // The most important text.\n primary: 'rgba(0, 0, 0, 0.87)',\n // Secondary text.\n secondary: 'rgba(0, 0, 0, 0.54)',\n // Disabled text have even lower visual prominence.\n disabled: 'rgba(0, 0, 0, 0.38)',\n // Text hints.\n hint: 'rgba(0, 0, 0, 0.38)'\n },\n // The color used to divide different elements.\n divider: 'rgba(0, 0, 0, 0.12)',\n // The background colors used to style the surfaces.\n // Consistency between these values is important.\n background: {\n paper: common.white,\n default: grey[50]\n },\n // The colors used to style the action elements.\n action: {\n // The color of an active action like an icon button.\n active: 'rgba(0, 0, 0, 0.54)',\n // The color of an hovered action.\n hover: 'rgba(0, 0, 0, 0.08)',\n hoverOpacity: 0.08,\n // The color of a selected action.\n selected: 'rgba(0, 0, 0, 0.14)',\n // The color of a disabled action.\n disabled: 'rgba(0, 0, 0, 0.26)',\n // The background color of a disabled action.\n disabledBackground: 'rgba(0, 0, 0, 0.12)'\n }\n};\nexport var dark = {\n text: {\n primary: common.white,\n secondary: 'rgba(255, 255, 255, 0.7)',\n disabled: 'rgba(255, 255, 255, 0.5)',\n hint: 'rgba(255, 255, 255, 0.5)',\n icon: 'rgba(255, 255, 255, 0.5)'\n },\n divider: 'rgba(255, 255, 255, 0.12)',\n background: {\n paper: grey[800],\n default: '#303030'\n },\n action: {\n active: common.white,\n hover: 'rgba(255, 255, 255, 0.1)',\n hoverOpacity: 0.1,\n selected: 'rgba(255, 255, 255, 0.2)',\n disabled: 'rgba(255, 255, 255, 0.3)',\n disabledBackground: 'rgba(255, 255, 255, 0.12)'\n }\n};\n\nfunction addLightOrDark(intent, direction, shade, tonalOffset) {\n if (!intent[direction]) {\n if (intent.hasOwnProperty(shade)) {\n intent[direction] = intent[shade];\n } else if (direction === 'light') {\n intent.light = lighten(intent.main, tonalOffset);\n } else if (direction === 'dark') {\n intent.dark = darken(intent.main, tonalOffset * 1.5);\n }\n }\n}\n\nexport default function createPalette(palette) {\n var _palette$primary = palette.primary,\n primary = _palette$primary === void 0 ? {\n light: indigo[300],\n main: indigo[500],\n dark: indigo[700]\n } : _palette$primary,\n _palette$secondary = palette.secondary,\n secondary = _palette$secondary === void 0 ? {\n light: pink.A200,\n main: pink.A400,\n dark: pink.A700\n } : _palette$secondary,\n _palette$error = palette.error,\n error = _palette$error === void 0 ? {\n light: red[300],\n main: red[500],\n dark: red[700]\n } : _palette$error,\n _palette$warning = palette.warning,\n warning = _palette$warning === void 0 ? {\n light: orange[300],\n main: orange[500],\n dark: orange[700]\n } : _palette$warning,\n _palette$info = palette.info,\n info = _palette$info === void 0 ? {\n light: blue[300],\n main: blue[500],\n dark: blue[700]\n } : _palette$info,\n _palette$success = palette.success,\n success = _palette$success === void 0 ? {\n light: green[300],\n main: green[500],\n dark: green[700]\n } : _palette$success,\n _palette$type = palette.type,\n type = _palette$type === void 0 ? 'light' : _palette$type,\n _palette$contrastThre = palette.contrastThreshold,\n contrastThreshold = _palette$contrastThre === void 0 ? 3 : _palette$contrastThre,\n _palette$tonalOffset = palette.tonalOffset,\n tonalOffset = _palette$tonalOffset === void 0 ? 0.2 : _palette$tonalOffset,\n other = _objectWithoutProperties(palette, [\"primary\", \"secondary\", \"error\", \"warning\", \"info\", \"success\", \"type\", \"contrastThreshold\", \"tonalOffset\"]); // Use the same logic as\n // Bootstrap: https://github.com/twbs/bootstrap/blob/1d6e3710dd447de1a200f29e8fa521f8a0908f70/scss/_functions.scss#L59\n // and material-components-web https://github.com/material-components/material-components-web/blob/ac46b8863c4dab9fc22c4c662dc6bd1b65dd652f/packages/mdc-theme/_functions.scss#L54\n\n\n function getContrastText(background) {\n if (!background) {\n throw new TypeError(\"Material-UI: missing background argument in getContrastText(\".concat(background, \").\"));\n }\n\n var contrastText = getContrastRatio(background, dark.text.primary) >= contrastThreshold ? dark.text.primary : light.text.primary;\n\n if (process.env.NODE_ENV !== 'production') {\n var contrast = getContrastRatio(background, contrastText);\n\n if (contrast < 3) {\n console.error([\"Material-UI: the contrast ratio of \".concat(contrast, \":1 for \").concat(contrastText, \" on \").concat(background), 'falls below the WCAG recommended absolute minimum contrast ratio of 3:1.', 'https://www.w3.org/TR/2008/REC-WCAG20-20081211/#visual-audio-contrast-contrast'].join('\\n'));\n }\n }\n\n return contrastText;\n }\n\n function augmentColor(color) {\n var mainShade = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 500;\n var lightShade = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 300;\n var darkShade = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 700;\n color = _extends({}, color);\n\n if (!color.main && color[mainShade]) {\n color.main = color[mainShade];\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (!color.main) {\n throw new Error(['Material-UI: the color provided to augmentColor(color) is invalid.', \"The color object needs to have a `main` property or a `\".concat(mainShade, \"` property.\")].join('\\n'));\n }\n }\n\n addLightOrDark(color, 'light', lightShade, tonalOffset);\n addLightOrDark(color, 'dark', darkShade, tonalOffset);\n\n if (!color.contrastText) {\n color.contrastText = getContrastText(color.main);\n }\n\n return color;\n }\n\n var types = {\n dark: dark,\n light: light\n };\n\n if (process.env.NODE_ENV !== 'production') {\n if (!types[type]) {\n console.error(\"Material-UI: the palette type `\".concat(type, \"` is not supported.\"));\n }\n }\n\n var paletteOutput = deepmerge(_extends({\n // A collection of common colors.\n common: common,\n // The palette type, can be light or dark.\n type: type,\n // The colors used to represent primary interface elements for a user.\n primary: augmentColor(primary),\n // The colors used to represent secondary interface elements for a user.\n secondary: augmentColor(secondary, 'A400', 'A200', 'A700'),\n // The colors used to represent interface elements that the user should be made aware of.\n error: augmentColor(error),\n // The colors used to represent potentially dangerous actions or important messages.\n warning: augmentColor(warning),\n // The colors used to present information to the user that is neutral and not necessarily important.\n info: augmentColor(info),\n // The colors used to indicate the successful completion of an action that user triggered.\n success: augmentColor(success),\n // The grey colors.\n grey: grey,\n // Used by `getContrastText()` to maximize the contrast between\n // the background and the text.\n contrastThreshold: contrastThreshold,\n // Takes a background color and returns the text color that maximizes the contrast.\n getContrastText: getContrastText,\n // Generate a rich color object.\n augmentColor: augmentColor,\n // Used by the functions below to shift a color's luminance by approximately\n // two indexes within its tonal palette.\n // E.g., shift from Red 500 to Red 300 or Red 700.\n tonalOffset: tonalOffset\n }, types[type]), other);\n return paletteOutput;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport { deepmerge } from '@material-ui/utils';\n\nfunction round(value) {\n return Math.round(value * 1e5) / 1e5;\n}\n\nvar caseAllCaps = {\n textTransform: 'uppercase'\n};\nvar defaultFontFamily = '\"Roboto\", \"Helvetica\", \"Arial\", sans-serif';\n/**\n * @see @link{https://material.io/design/typography/the-type-system.html}\n * @see @link{https://material.io/design/typography/understanding-typography.html}\n */\n\nexport default function createTypography(palette, typography) {\n var _ref = typeof typography === 'function' ? typography(palette) : typography,\n _ref$fontFamily = _ref.fontFamily,\n fontFamily = _ref$fontFamily === void 0 ? defaultFontFamily : _ref$fontFamily,\n _ref$fontSize = _ref.fontSize,\n fontSize = _ref$fontSize === void 0 ? 14 : _ref$fontSize,\n _ref$fontWeightLight = _ref.fontWeightLight,\n fontWeightLight = _ref$fontWeightLight === void 0 ? 300 : _ref$fontWeightLight,\n _ref$fontWeightRegula = _ref.fontWeightRegular,\n fontWeightRegular = _ref$fontWeightRegula === void 0 ? 400 : _ref$fontWeightRegula,\n _ref$fontWeightMedium = _ref.fontWeightMedium,\n fontWeightMedium = _ref$fontWeightMedium === void 0 ? 500 : _ref$fontWeightMedium,\n _ref$fontWeightBold = _ref.fontWeightBold,\n fontWeightBold = _ref$fontWeightBold === void 0 ? 700 : _ref$fontWeightBold,\n _ref$htmlFontSize = _ref.htmlFontSize,\n htmlFontSize = _ref$htmlFontSize === void 0 ? 16 : _ref$htmlFontSize,\n allVariants = _ref.allVariants,\n pxToRem2 = _ref.pxToRem,\n other = _objectWithoutProperties(_ref, [\"fontFamily\", \"fontSize\", \"fontWeightLight\", \"fontWeightRegular\", \"fontWeightMedium\", \"fontWeightBold\", \"htmlFontSize\", \"allVariants\", \"pxToRem\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof fontSize !== 'number') {\n console.error('Material-UI: `fontSize` is required to be a number.');\n }\n\n if (typeof htmlFontSize !== 'number') {\n console.error('Material-UI: `htmlFontSize` is required to be a number.');\n }\n }\n\n var coef = fontSize / 14;\n\n var pxToRem = pxToRem2 || function (size) {\n return \"\".concat(size / htmlFontSize * coef, \"rem\");\n };\n\n var buildVariant = function buildVariant(fontWeight, size, lineHeight, letterSpacing, casing) {\n return _extends({\n fontFamily: fontFamily,\n fontWeight: fontWeight,\n fontSize: pxToRem(size),\n // Unitless following https://meyerweb.com/eric/thoughts/2006/02/08/unitless-line-heights/\n lineHeight: lineHeight\n }, fontFamily === defaultFontFamily ? {\n letterSpacing: \"\".concat(round(letterSpacing / size), \"em\")\n } : {}, {}, casing, {}, allVariants);\n };\n\n var variants = {\n h1: buildVariant(fontWeightLight, 96, 1.167, -1.5),\n h2: buildVariant(fontWeightLight, 60, 1.2, -0.5),\n h3: buildVariant(fontWeightRegular, 48, 1.167, 0),\n h4: buildVariant(fontWeightRegular, 34, 1.235, 0.25),\n h5: buildVariant(fontWeightRegular, 24, 1.334, 0),\n h6: buildVariant(fontWeightMedium, 20, 1.6, 0.15),\n subtitle1: buildVariant(fontWeightRegular, 16, 1.75, 0.15),\n subtitle2: buildVariant(fontWeightMedium, 14, 1.57, 0.1),\n body1: buildVariant(fontWeightRegular, 16, 1.5, 0.15),\n body2: buildVariant(fontWeightRegular, 14, 1.43, 0.15),\n button: buildVariant(fontWeightMedium, 14, 1.75, 0.4, caseAllCaps),\n caption: buildVariant(fontWeightRegular, 12, 1.66, 0.4),\n overline: buildVariant(fontWeightRegular, 12, 2.66, 1, caseAllCaps)\n };\n return deepmerge(_extends({\n htmlFontSize: htmlFontSize,\n pxToRem: pxToRem,\n round: round,\n // TODO To remove in v5?\n fontFamily: fontFamily,\n fontSize: fontSize,\n fontWeightLight: fontWeightLight,\n fontWeightRegular: fontWeightRegular,\n fontWeightMedium: fontWeightMedium,\n fontWeightBold: fontWeightBold\n }, variants), other, {\n clone: false // No need to clone deep\n\n });\n}","var shadowKeyUmbraOpacity = 0.2;\nvar shadowKeyPenumbraOpacity = 0.14;\nvar shadowAmbientShadowOpacity = 0.12;\n\nfunction createShadow() {\n return [\"\".concat(arguments.length <= 0 ? undefined : arguments[0], \"px \").concat(arguments.length <= 1 ? undefined : arguments[1], \"px \").concat(arguments.length <= 2 ? undefined : arguments[2], \"px \").concat(arguments.length <= 3 ? undefined : arguments[3], \"px rgba(0,0,0,\").concat(shadowKeyUmbraOpacity, \")\"), \"\".concat(arguments.length <= 4 ? undefined : arguments[4], \"px \").concat(arguments.length <= 5 ? undefined : arguments[5], \"px \").concat(arguments.length <= 6 ? undefined : arguments[6], \"px \").concat(arguments.length <= 7 ? undefined : arguments[7], \"px rgba(0,0,0,\").concat(shadowKeyPenumbraOpacity, \")\"), \"\".concat(arguments.length <= 8 ? undefined : arguments[8], \"px \").concat(arguments.length <= 9 ? undefined : arguments[9], \"px \").concat(arguments.length <= 10 ? undefined : arguments[10], \"px \").concat(arguments.length <= 11 ? undefined : arguments[11], \"px rgba(0,0,0,\").concat(shadowAmbientShadowOpacity, \")\")].join(',');\n} // Values from https://github.com/material-components/material-components-web/blob/be8747f94574669cb5e7add1a7c54fa41a89cec7/packages/mdc-elevation/_variables.scss\n\n\nvar shadows = ['none', createShadow(0, 2, 1, -1, 0, 1, 1, 0, 0, 1, 3, 0), createShadow(0, 3, 1, -2, 0, 2, 2, 0, 0, 1, 5, 0), createShadow(0, 3, 3, -2, 0, 3, 4, 0, 0, 1, 8, 0), createShadow(0, 2, 4, -1, 0, 4, 5, 0, 0, 1, 10, 0), createShadow(0, 3, 5, -1, 0, 5, 8, 0, 0, 1, 14, 0), createShadow(0, 3, 5, -1, 0, 6, 10, 0, 0, 1, 18, 0), createShadow(0, 4, 5, -2, 0, 7, 10, 1, 0, 2, 16, 1), createShadow(0, 5, 5, -3, 0, 8, 10, 1, 0, 3, 14, 2), createShadow(0, 5, 6, -3, 0, 9, 12, 1, 0, 3, 16, 2), createShadow(0, 6, 6, -3, 0, 10, 14, 1, 0, 4, 18, 3), createShadow(0, 6, 7, -4, 0, 11, 15, 1, 0, 4, 20, 3), createShadow(0, 7, 8, -4, 0, 12, 17, 2, 0, 5, 22, 4), createShadow(0, 7, 8, -4, 0, 13, 19, 2, 0, 5, 24, 4), createShadow(0, 7, 9, -4, 0, 14, 21, 2, 0, 5, 26, 4), createShadow(0, 8, 9, -5, 0, 15, 22, 2, 0, 6, 28, 5), createShadow(0, 8, 10, -5, 0, 16, 24, 2, 0, 6, 30, 5), createShadow(0, 8, 11, -5, 0, 17, 26, 2, 0, 6, 32, 5), createShadow(0, 9, 11, -5, 0, 18, 28, 2, 0, 7, 34, 6), createShadow(0, 9, 12, -6, 0, 19, 29, 2, 0, 7, 36, 6), createShadow(0, 10, 13, -6, 0, 20, 31, 3, 0, 8, 38, 7), createShadow(0, 10, 13, -6, 0, 21, 33, 3, 0, 8, 40, 7), createShadow(0, 10, 14, -6, 0, 22, 35, 3, 0, 8, 42, 7), createShadow(0, 11, 14, -7, 0, 23, 36, 3, 0, 9, 44, 8), createShadow(0, 11, 15, -7, 0, 24, 38, 3, 0, 9, 46, 8)];\nexport default shadows;","var shape = {\n borderRadius: 4\n};\nexport default shape;","var warnOnce;\nexport default function createSpacing() {\n var spacingInput = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 8;\n\n // Already transformed.\n if (spacingInput.mui) {\n return spacingInput;\n } // All components align to an 8dp square baseline grid for mobile, tablet, and desktop.\n // https://material.io/design/layout/understanding-layout.html#pixel-density\n\n\n var transform;\n\n if (typeof spacingInput === 'function') {\n transform = spacingInput;\n } else {\n if (process.env.NODE_ENV !== 'production') {\n if (typeof spacingInput !== 'number') {\n console.error([\"Material-UI: the `theme.spacing` value (\".concat(spacingInput, \") is invalid.\"), 'It should be a number or a function.'].join('\\n'));\n }\n }\n\n transform = function transform(factor) {\n if (process.env.NODE_ENV !== 'production') {\n if (typeof factor !== 'number') {\n console.error(\"Expected spacing argument to be a number, got \".concat(factor));\n }\n }\n\n return spacingInput * factor;\n };\n }\n\n var spacing = function spacing() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (!(args.length <= 4)) {\n console.error(\"Material-UI: Too many arguments provided, expected between 0 and 4, got \".concat(args.length));\n }\n }\n\n if (args.length === 0) {\n return transform(1);\n }\n\n if (args.length === 1) {\n return transform(args[0]);\n }\n\n return args.map(function (factor) {\n var output = transform(factor);\n return typeof output === 'number' ? \"\".concat(output, \"px\") : output;\n }).join(' ');\n }; // Backward compatibility, to remove in v5.\n\n\n Object.defineProperty(spacing, 'unit', {\n get: function get() {\n if (process.env.NODE_ENV !== 'production') {\n if (!warnOnce || process.env.NODE_ENV === 'test') {\n console.error(['Material-UI: theme.spacing.unit usage has been deprecated.', 'It will be removed in v5.', 'You can replace `theme.spacing.unit * y` with `theme.spacing(y)`.', '', 'You can use the `https://github.com/mui-org/material-ui/tree/master/packages/material-ui-codemod/README.md#theme-spacing-api` migration helper to make the process smoother.'].join('\\n'));\n }\n\n warnOnce = true;\n }\n\n return spacingInput;\n }\n });\n spacing.mui = true;\n return spacing;\n}","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n// Follow https://material.google.com/motion/duration-easing.html#duration-easing-natural-easing-curves\n// to learn the context in which each easing should be used.\nexport var easing = {\n // This is the most common easing curve.\n easeInOut: 'cubic-bezier(0.4, 0, 0.2, 1)',\n // Objects enter the screen at full velocity from off-screen and\n // slowly decelerate to a resting point.\n easeOut: 'cubic-bezier(0.0, 0, 0.2, 1)',\n // Objects leave the screen at full velocity. They do not decelerate when off-screen.\n easeIn: 'cubic-bezier(0.4, 0, 1, 1)',\n // The sharp curve is used by objects that may return to the screen at any time.\n sharp: 'cubic-bezier(0.4, 0, 0.6, 1)'\n}; // Follow https://material.io/guidelines/motion/duration-easing.html#duration-easing-common-durations\n// to learn when use what timing\n\nexport var duration = {\n shortest: 150,\n shorter: 200,\n short: 250,\n // most basic recommended timing\n standard: 300,\n // this is to be used in complex animations\n complex: 375,\n // recommended when something is entering screen\n enteringScreen: 225,\n // recommended when something is leaving screen\n leavingScreen: 195\n};\nexport var formatMs = function formatMs(milliseconds) {\n return \"\".concat(Math.round(milliseconds), \"ms\");\n};\nexport var isString = function isString(value) {\n return typeof value === 'string';\n};\nexport var isNumber = function isNumber(value) {\n return !isNaN(parseFloat(value));\n};\n/**\n * @param {string|Array} props\n * @param {object} param\n * @param {string} param.prop\n * @param {number} param.duration\n * @param {string} param.easing\n * @param {number} param.delay\n */\n\nexport default {\n easing: easing,\n duration: duration,\n create: function create() {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ['all'];\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var _options$duration = options.duration,\n durationOption = _options$duration === void 0 ? duration.standard : _options$duration,\n _options$easing = options.easing,\n easingOption = _options$easing === void 0 ? easing.easeInOut : _options$easing,\n _options$delay = options.delay,\n delay = _options$delay === void 0 ? 0 : _options$delay,\n other = _objectWithoutProperties(options, [\"duration\", \"easing\", \"delay\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (!isString(props) && !Array.isArray(props)) {\n console.error('Material-UI: argument \"props\" must be a string or Array.');\n }\n\n if (!isNumber(durationOption) && !isString(durationOption)) {\n console.error(\"Material-UI: argument \\\"duration\\\" must be a number or a string but found \".concat(durationOption, \".\"));\n }\n\n if (!isString(easingOption)) {\n console.error('Material-UI: argument \"easing\" must be a string.');\n }\n\n if (!isNumber(delay) && !isString(delay)) {\n console.error('Material-UI: argument \"delay\" must be a number or a string.');\n }\n\n if (Object.keys(other).length !== 0) {\n console.error(\"Material-UI: unrecognized argument(s) [\".concat(Object.keys(other).join(','), \"]\"));\n }\n }\n\n return (Array.isArray(props) ? props : [props]).map(function (animatedProp) {\n return \"\".concat(animatedProp, \" \").concat(typeof durationOption === 'string' ? durationOption : formatMs(durationOption), \" \").concat(easingOption, \" \").concat(typeof delay === 'string' ? delay : formatMs(delay));\n }).join(',');\n },\n getAutoHeightDuration: function getAutoHeightDuration(height) {\n if (!height) {\n return 0;\n }\n\n var constant = height / 36; // https://www.wolframalpha.com/input/?i=(4+%2B+15+*+(x+%2F+36+)+**+0.25+%2B+(x+%2F+36)+%2F+5)+*+10\n\n return Math.round((4 + 15 * Math.pow(constant, 0.25) + constant / 5) * 10);\n }\n};","import _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport { deepmerge } from '@material-ui/utils';\nimport createBreakpoints from './createBreakpoints';\nimport createMixins from './createMixins';\nimport createPalette from './createPalette';\nimport createTypography from './createTypography';\nimport shadows from './shadows';\nimport shape from './shape';\nimport createSpacing from './createSpacing';\nimport transitions from './transitions';\nimport zIndex from './zIndex';\n\nfunction createMuiTheme() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n var _options$breakpoints = options.breakpoints,\n breakpointsInput = _options$breakpoints === void 0 ? {} : _options$breakpoints,\n _options$mixins = options.mixins,\n mixinsInput = _options$mixins === void 0 ? {} : _options$mixins,\n _options$palette = options.palette,\n paletteInput = _options$palette === void 0 ? {} : _options$palette,\n spacingInput = options.spacing,\n _options$typography = options.typography,\n typographyInput = _options$typography === void 0 ? {} : _options$typography,\n other = _objectWithoutProperties(options, [\"breakpoints\", \"mixins\", \"palette\", \"spacing\", \"typography\"]);\n\n var palette = createPalette(paletteInput);\n var breakpoints = createBreakpoints(breakpointsInput);\n var spacing = createSpacing(spacingInput);\n var muiTheme = deepmerge({\n breakpoints: breakpoints,\n direction: 'ltr',\n mixins: createMixins(breakpoints, spacing, mixinsInput),\n overrides: {},\n // Inject custom styles\n palette: palette,\n props: {},\n // Provide default props\n shadows: shadows,\n typography: createTypography(palette, typographyInput),\n spacing: spacing,\n shape: shape,\n transitions: transitions,\n zIndex: zIndex\n }, other);\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n muiTheme = args.reduce(function (acc, argument) {\n return deepmerge(acc, argument);\n }, muiTheme);\n\n if (process.env.NODE_ENV !== 'production') {\n var pseudoClasses = ['checked', 'disabled', 'error', 'focused', 'focusVisible', 'required', 'expanded', 'selected'];\n\n var traverse = function traverse(node, parentKey) {\n var depth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;\n var key; // eslint-disable-next-line guard-for-in, no-restricted-syntax\n\n for (key in node) {\n var child = node[key];\n\n if (depth === 1) {\n if (key.indexOf('Mui') === 0 && child) {\n traverse(child, key, depth + 1);\n }\n } else if (pseudoClasses.indexOf(key) !== -1 && Object.keys(child).length > 0) {\n if (process.env.NODE_ENV !== 'production') {\n console.error([\"Material-UI: the `\".concat(parentKey, \"` component increases \") + \"the CSS specificity of the `\".concat(key, \"` internal state.\"), 'You can not override it like this: ', JSON.stringify(node, null, 2), '', 'Instead, you need to use the $ruleName syntax:', JSON.stringify({\n root: _defineProperty({}, \"&$\".concat(key), child)\n }, null, 2), '', 'https://material-ui.com/r/pseudo-classes-guide'].join('\\n'));\n } // Remove the style to prevent global conflicts.\n\n\n node[key] = {};\n }\n }\n };\n\n traverse(muiTheme.overrides);\n }\n\n return muiTheme;\n}\n\nexport default createMuiTheme;","import React from 'react';\nimport ThemeContext from './ThemeContext';\nexport default function useTheme() {\n return React.useContext(ThemeContext);\n}","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nvar useEnhancedEffect = typeof window !== 'undefined' && process.env.NODE_ENV !== 'test' ? React.useLayoutEffect : React.useEffect;\n/**\n * NoSsr purposely removes components from the subject of Server Side Rendering (SSR).\n *\n * This component can be useful in a variety of situations:\n * - Escape hatch for broken dependencies not supporting SSR.\n * - Improve the time-to-first paint on the client by only rendering above the fold.\n * - Reduce the rendering time on the server.\n * - Under too heavy server load, you can turn on service degradation.\n */\n\nfunction NoSsr(props) {\n var children = props.children,\n _props$defer = props.defer,\n defer = _props$defer === void 0 ? false : _props$defer,\n _props$fallback = props.fallback,\n fallback = _props$fallback === void 0 ? null : _props$fallback;\n\n var _React$useState = React.useState(false),\n mountedState = _React$useState[0],\n setMountedState = _React$useState[1];\n\n useEnhancedEffect(function () {\n if (!defer) {\n setMountedState(true);\n }\n }, [defer]);\n React.useEffect(function () {\n if (defer) {\n setMountedState(true);\n }\n }, [defer]); // We need the Fragment here to force react-docgen to recognise NoSsr as a component.\n\n return React.createElement(React.Fragment, null, mountedState ? children : fallback);\n}\n\nprocess.env.NODE_ENV !== \"production\" ? NoSsr.propTypes = {\n /**\n * You can wrap a node.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * If `true`, the component will not only prevent server-side rendering.\n * It will also defer the rendering of the children into a different screen frame.\n */\n defer: PropTypes.bool,\n\n /**\n * The fallback content to display.\n */\n fallback: PropTypes.node\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n NoSsr['propTypes' + ''] = exactProp(NoSsr.propTypes);\n}\n\nexport default NoSsr;","// based on https://github.com/WICG/focus-visible/blob/v4.1.5/src/focus-visible.js\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nvar hadKeyboardEvent = true;\nvar hadFocusVisibleRecently = false;\nvar hadFocusVisibleRecentlyTimeout = null;\nvar inputTypesWhitelist = {\n text: true,\n search: true,\n url: true,\n tel: true,\n email: true,\n password: true,\n number: true,\n date: true,\n month: true,\n week: true,\n time: true,\n datetime: true,\n 'datetime-local': true\n};\n/**\n * Computes whether the given element should automatically trigger the\n * `focus-visible` class being added, i.e. whether it should always match\n * `:focus-visible` when focused.\n * @param {Element} node\n * @return {boolean}\n */\n\nfunction focusTriggersKeyboardModality(node) {\n var type = node.type,\n tagName = node.tagName;\n\n if (tagName === 'INPUT' && inputTypesWhitelist[type] && !node.readOnly) {\n return true;\n }\n\n if (tagName === 'TEXTAREA' && !node.readOnly) {\n return true;\n }\n\n if (node.isContentEditable) {\n return true;\n }\n\n return false;\n}\n/**\n * Keep track of our keyboard modality state with `hadKeyboardEvent`.\n * If the most recent user interaction was via the keyboard;\n * and the key press did not include a meta, alt/option, or control key;\n * then the modality is keyboard. Otherwise, the modality is not keyboard.\n * @param {KeyboardEvent} event\n */\n\n\nfunction handleKeyDown(event) {\n if (event.metaKey || event.altKey || event.ctrlKey) {\n return;\n }\n\n hadKeyboardEvent = true;\n}\n/**\n * If at any point a user clicks with a pointing device, ensure that we change\n * the modality away from keyboard.\n * This avoids the situation where a user presses a key on an already focused\n * element, and then clicks on a different element, focusing it with a\n * pointing device, while we still think we're in keyboard modality.\n */\n\n\nfunction handlePointerDown() {\n hadKeyboardEvent = false;\n}\n\nfunction handleVisibilityChange() {\n if (this.visibilityState === 'hidden') {\n // If the tab becomes active again, the browser will handle calling focus\n // on the element (Safari actually calls it twice).\n // If this tab change caused a blur on an element with focus-visible,\n // re-apply the class when the user switches back to the tab.\n if (hadFocusVisibleRecently) {\n hadKeyboardEvent = true;\n }\n }\n}\n\nfunction prepare(doc) {\n doc.addEventListener('keydown', handleKeyDown, true);\n doc.addEventListener('mousedown', handlePointerDown, true);\n doc.addEventListener('pointerdown', handlePointerDown, true);\n doc.addEventListener('touchstart', handlePointerDown, true);\n doc.addEventListener('visibilitychange', handleVisibilityChange, true);\n}\n\nexport function teardown(doc) {\n doc.removeEventListener('keydown', handleKeyDown, true);\n doc.removeEventListener('mousedown', handlePointerDown, true);\n doc.removeEventListener('pointerdown', handlePointerDown, true);\n doc.removeEventListener('touchstart', handlePointerDown, true);\n doc.removeEventListener('visibilitychange', handleVisibilityChange, true);\n}\n\nfunction isFocusVisible(event) {\n var target = event.target;\n\n try {\n return target.matches(':focus-visible');\n } catch (error) {} // browsers not implementing :focus-visible will throw a SyntaxError\n // we use our own heuristic for those browsers\n // rethrow might be better if it's not the expected error but do we really\n // want to crash if focus-visible malfunctioned?\n // no need for validFocusTarget check. the user does that by attaching it to\n // focusable events only\n\n\n return hadKeyboardEvent || focusTriggersKeyboardModality(target);\n}\n/**\n * Should be called if a blur event is fired on a focus-visible element\n */\n\n\nfunction handleBlurVisible() {\n // To detect a tab/window switch, we look for a blur event followed\n // rapidly by a visibility change.\n // If we don't see a visibility change within 100ms, it's probably a\n // regular focus change.\n hadFocusVisibleRecently = true;\n window.clearTimeout(hadFocusVisibleRecentlyTimeout);\n hadFocusVisibleRecentlyTimeout = window.setTimeout(function () {\n hadFocusVisibleRecently = false;\n }, 100);\n}\n\nexport function useIsFocusVisible() {\n var ref = React.useCallback(function (instance) {\n var node = ReactDOM.findDOMNode(instance);\n\n if (node != null) {\n prepare(node.ownerDocument);\n }\n }, []);\n return {\n isFocusVisible: isFocusVisible,\n onBlurVisible: handleBlurVisible,\n ref: ref\n };\n}","import { Children, cloneElement, isValidElement } from 'react';\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\n\nexport function getChildMapping(children, mapFn) {\n var mapper = function mapper(child) {\n return mapFn && isValidElement(child) ? mapFn(child) : child;\n };\n\n var result = Object.create(null);\n if (children) Children.map(children, function (c) {\n return c;\n }).forEach(function (child) {\n // run the map function here instead so that the key is the computed one\n result[child.key] = mapper(child);\n });\n return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\nexport function mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n return key in next ? next[key] : prev[key];\n } // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n\n\n var nextKeysPending = Object.create(null);\n var pendingKeys = [];\n\n for (var prevKey in prev) {\n if (prevKey in next) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i;\n var childMapping = {};\n\n for (var nextKey in next) {\n if (nextKeysPending[nextKey]) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n\n childMapping[nextKey] = getValueForKey(nextKey);\n } // Finally, add the keys which didn't appear before any key in `next`\n\n\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nexport function getInitialChildMapping(props, onExited) {\n return getChildMapping(props.children, function (child) {\n return cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n appear: getProp(child, 'appear', props),\n enter: getProp(child, 'enter', props),\n exit: getProp(child, 'exit', props)\n });\n });\n}\nexport function getNextChildMapping(nextProps, prevChildMapping, onExited) {\n var nextChildMapping = getChildMapping(nextProps.children);\n var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n Object.keys(children).forEach(function (key) {\n var child = children[key];\n if (!isValidElement(child)) return;\n var hasPrev = key in prevChildMapping;\n var hasNext = key in nextChildMapping;\n var prevChild = prevChildMapping[key];\n var isLeaving = isValidElement(prevChild) && !prevChild.props.in; // item is new (entering)\n\n if (hasNext && (!hasPrev || isLeaving)) {\n // console.log('entering', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n } else if (!hasNext && hasPrev && !isLeaving) {\n // item is old (exiting)\n // console.log('leaving', key)\n children[key] = cloneElement(child, {\n in: false\n });\n } else if (hasNext && hasPrev && isValidElement(prevChild)) {\n // item hasn't changed transition states\n // copy over the last transition props;\n // console.log('unchanged', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: prevChild.props.in,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n }\n });\n return children;\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { getChildMapping, getInitialChildMapping, getNextChildMapping } from './utils/ChildMapping';\n\nvar values = Object.values || function (obj) {\n return Object.keys(obj).map(function (k) {\n return obj[k];\n });\n};\n\nvar defaultProps = {\n component: 'div',\n childFactory: function childFactory(child) {\n return child;\n }\n /**\n * The `<TransitionGroup>` component manages a set of transition components\n * (`<Transition>` and `<CSSTransition>`) in a list. Like with the transition\n * components, `<TransitionGroup>` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the `<TransitionGroup>`.\n *\n * Note that `<TransitionGroup>` does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\n};\n\nvar TransitionGroup =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n\n var handleExited = _this.handleExited.bind(_assertThisInitialized(_assertThisInitialized(_this))); // Initial children should all be entering, dependent on appear\n\n\n _this.state = {\n contextValue: {\n isMounting: true\n },\n handleExited: handleExited,\n firstRender: true\n };\n return _this;\n }\n\n var _proto = TransitionGroup.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.mounted = true;\n this.setState({\n contextValue: {\n isMounting: false\n }\n });\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.mounted = false;\n };\n\n TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n var prevChildMapping = _ref.children,\n handleExited = _ref.handleExited,\n firstRender = _ref.firstRender;\n return {\n children: firstRender ? getInitialChildMapping(nextProps, handleExited) : getNextChildMapping(nextProps, prevChildMapping, handleExited),\n firstRender: false\n };\n };\n\n _proto.handleExited = function handleExited(child, node) {\n var currentChildMapping = getChildMapping(this.props.children);\n if (child.key in currentChildMapping) return;\n\n if (child.props.onExited) {\n child.props.onExited(node);\n }\n\n if (this.mounted) {\n this.setState(function (state) {\n var children = _extends({}, state.children);\n\n delete children[child.key];\n return {\n children: children\n };\n });\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n Component = _this$props.component,\n childFactory = _this$props.childFactory,\n props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n var contextValue = this.state.contextValue;\n var children = values(this.state.children).map(childFactory);\n delete props.appear;\n delete props.enter;\n delete props.exit;\n\n if (Component === null) {\n return React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, children);\n }\n\n return React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, React.createElement(Component, props, children));\n };\n\n return TransitionGroup;\n}(React.Component);\n\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * `<TransitionGroup>` renders a `<div>` by default. You can change this\n * behavior by providing a `component` prop.\n * If you use React v16+ and would like to avoid a wrapping `<div>` element\n * you can pass in `component={null}`. This is useful if the wrapping div\n * borks your css styles.\n */\n component: PropTypes.any,\n\n /**\n * A set of `<Transition>` components, that are toggled `in` and out as they\n * leave. the `<TransitionGroup>` will inject specific transition props, so\n * remember to spread them through if you are wrapping the `<Transition>` as\n * with our `<Fade>` example.\n *\n * While this component is meant for multiple `Transition` or `CSSTransition`\n * children, sometimes you may want to have a single transition child with\n * content that you want to be transitioned out and in when you change it\n * (e.g. routes, images etc.) In that case you can change the `key` prop of\n * the transition child as you change its content, this will cause\n * `TransitionGroup` to transition the child out and back in.\n */\n children: PropTypes.node,\n\n /**\n * A convenience prop that enables or disables appear animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n appear: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables enter animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables exit animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * You may need to apply reactive updates to a child as it is exiting.\n * This is generally done by using `cloneElement` however in the case of an exiting\n * child the element has already been removed and not accessible to the consumer.\n *\n * If you do need to update a child as it leaves you can provide a `childFactory`\n * to wrap every child, even the ones that are leaving.\n *\n * @type Function(child: ReactElement) -> ReactElement\n */\n childFactory: PropTypes.func\n} : {};\nTransitionGroup.defaultProps = defaultProps;\nexport default TransitionGroup;","import React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport useEventCallback from '../utils/useEventCallback';\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * @ignore - internal component.\n */\n\nfunction Ripple(props) {\n var classes = props.classes,\n _props$pulsate = props.pulsate,\n pulsate = _props$pulsate === void 0 ? false : _props$pulsate,\n rippleX = props.rippleX,\n rippleY = props.rippleY,\n rippleSize = props.rippleSize,\n inProp = props.in,\n _props$onExited = props.onExited,\n onExited = _props$onExited === void 0 ? function () {} : _props$onExited,\n timeout = props.timeout;\n\n var _React$useState = React.useState(false),\n leaving = _React$useState[0],\n setLeaving = _React$useState[1];\n\n var rippleClassName = clsx(classes.ripple, classes.rippleVisible, pulsate && classes.ripplePulsate);\n var rippleStyles = {\n width: rippleSize,\n height: rippleSize,\n top: -(rippleSize / 2) + rippleY,\n left: -(rippleSize / 2) + rippleX\n };\n var childClassName = clsx(classes.child, leaving && classes.childLeaving, pulsate && classes.childPulsate);\n var handleExited = useEventCallback(onExited); // Ripple is used for user feedback (e.g. click or press) so we want to apply styles with the highest priority\n\n useEnhancedEffect(function () {\n if (!inProp) {\n // react-transition-group#onExit\n setLeaving(true); // react-transition-group#onExited\n\n var timeoutId = setTimeout(handleExited, timeout);\n return function () {\n clearTimeout(timeoutId);\n };\n }\n\n return undefined;\n }, [handleExited, inProp, timeout]);\n return React.createElement(\"span\", {\n className: rippleClassName,\n style: rippleStyles\n }, React.createElement(\"span\", {\n className: childClassName\n }));\n}\n\nprocess.env.NODE_ENV !== \"production\" ? Ripple.propTypes = {\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore - injected from TransitionGroup\n */\n in: PropTypes.bool,\n\n /**\n * @ignore - injected from TransitionGroup\n */\n onExited: PropTypes.func,\n\n /**\n * If `true`, the ripple pulsates, typically indicating the keyboard focus state of an element.\n */\n pulsate: PropTypes.bool,\n\n /**\n * Diameter of the ripple.\n */\n rippleSize: PropTypes.number,\n\n /**\n * Horizontal position of the ripple center.\n */\n rippleX: PropTypes.number,\n\n /**\n * Vertical position of the ripple center.\n */\n rippleY: PropTypes.number,\n\n /**\n * exit delay\n */\n timeout: PropTypes.number.isRequired\n} : void 0;\nexport default Ripple;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _toConsumableArray from \"@babel/runtime/helpers/esm/toConsumableArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { TransitionGroup } from 'react-transition-group';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Ripple from './Ripple';\nvar DURATION = 550;\nexport var DELAY_RIPPLE = 80;\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n overflow: 'hidden',\n pointerEvents: 'none',\n position: 'absolute',\n zIndex: 0,\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n borderRadius: 'inherit'\n },\n\n /* Styles applied to the internal `Ripple` components `ripple` class. */\n ripple: {\n opacity: 0,\n position: 'absolute'\n },\n\n /* Styles applied to the internal `Ripple` components `rippleVisible` class. */\n rippleVisible: {\n opacity: 0.3,\n transform: 'scale(1)',\n animation: \"$enter \".concat(DURATION, \"ms \").concat(theme.transitions.easing.easeInOut)\n },\n\n /* Styles applied to the internal `Ripple` components `ripplePulsate` class. */\n ripplePulsate: {\n animationDuration: \"\".concat(theme.transitions.duration.shorter, \"ms\")\n },\n\n /* Styles applied to the internal `Ripple` components `child` class. */\n child: {\n opacity: 1,\n display: 'block',\n width: '100%',\n height: '100%',\n borderRadius: '50%',\n backgroundColor: 'currentColor'\n },\n\n /* Styles applied to the internal `Ripple` components `childLeaving` class. */\n childLeaving: {\n opacity: 0,\n animation: \"$exit \".concat(DURATION, \"ms \").concat(theme.transitions.easing.easeInOut)\n },\n\n /* Styles applied to the internal `Ripple` components `childPulsate` class. */\n childPulsate: {\n position: 'absolute',\n left: 0,\n top: 0,\n animation: \"$pulsate 2500ms \".concat(theme.transitions.easing.easeInOut, \" 200ms infinite\")\n },\n '@keyframes enter': {\n '0%': {\n transform: 'scale(0)',\n opacity: 0.1\n },\n '100%': {\n transform: 'scale(1)',\n opacity: 0.3\n }\n },\n '@keyframes exit': {\n '0%': {\n opacity: 1\n },\n '100%': {\n opacity: 0\n }\n },\n '@keyframes pulsate': {\n '0%': {\n transform: 'scale(1)'\n },\n '50%': {\n transform: 'scale(0.92)'\n },\n '100%': {\n transform: 'scale(1)'\n }\n }\n };\n};\n/**\n * @ignore - internal component.\n *\n * TODO v5: Make private\n */\n\nvar TouchRipple = React.forwardRef(function TouchRipple(props, ref) {\n var _props$center = props.center,\n centerProp = _props$center === void 0 ? false : _props$center,\n classes = props.classes,\n className = props.className,\n other = _objectWithoutProperties(props, [\"center\", \"classes\", \"className\"]);\n\n var _React$useState = React.useState([]),\n ripples = _React$useState[0],\n setRipples = _React$useState[1];\n\n var nextKey = React.useRef(0);\n var rippleCallback = React.useRef(null);\n React.useEffect(function () {\n if (rippleCallback.current) {\n rippleCallback.current();\n rippleCallback.current = null;\n }\n }, [ripples]); // Used to filter out mouse emulated events on mobile.\n\n var ignoringMouseDown = React.useRef(false); // We use a timer in order to only show the ripples for touch \"click\" like events.\n // We don't want to display the ripple for touch scroll events.\n\n var startTimer = React.useRef(null); // This is the hook called once the previous timeout is ready.\n\n var startTimerCommit = React.useRef(null);\n var container = React.useRef(null);\n React.useEffect(function () {\n return function () {\n clearTimeout(startTimer.current);\n };\n }, []);\n var startCommit = React.useCallback(function (params) {\n var pulsate = params.pulsate,\n rippleX = params.rippleX,\n rippleY = params.rippleY,\n rippleSize = params.rippleSize,\n cb = params.cb;\n setRipples(function (oldRipples) {\n return [].concat(_toConsumableArray(oldRipples), [React.createElement(Ripple, {\n key: nextKey.current,\n classes: classes,\n timeout: DURATION,\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize\n })]);\n });\n nextKey.current += 1;\n rippleCallback.current = cb;\n }, [classes]);\n var start = React.useCallback(function () {\n var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var cb = arguments.length > 2 ? arguments[2] : undefined;\n var _options$pulsate = options.pulsate,\n pulsate = _options$pulsate === void 0 ? false : _options$pulsate,\n _options$center = options.center,\n center = _options$center === void 0 ? centerProp || options.pulsate : _options$center,\n _options$fakeElement = options.fakeElement,\n fakeElement = _options$fakeElement === void 0 ? false : _options$fakeElement;\n\n if (event.type === 'mousedown' && ignoringMouseDown.current) {\n ignoringMouseDown.current = false;\n return;\n }\n\n if (event.type === 'touchstart') {\n ignoringMouseDown.current = true;\n }\n\n var element = fakeElement ? null : container.current;\n var rect = element ? element.getBoundingClientRect() : {\n width: 0,\n height: 0,\n left: 0,\n top: 0\n }; // Get the size of the ripple\n\n var rippleX;\n var rippleY;\n var rippleSize;\n\n if (center || event.clientX === 0 && event.clientY === 0 || !event.clientX && !event.touches) {\n rippleX = Math.round(rect.width / 2);\n rippleY = Math.round(rect.height / 2);\n } else {\n var clientX = event.clientX ? event.clientX : event.touches[0].clientX;\n var clientY = event.clientY ? event.clientY : event.touches[0].clientY;\n rippleX = Math.round(clientX - rect.left);\n rippleY = Math.round(clientY - rect.top);\n }\n\n if (center) {\n rippleSize = Math.sqrt((2 * Math.pow(rect.width, 2) + Math.pow(rect.height, 2)) / 3); // For some reason the animation is broken on Mobile Chrome if the size if even.\n\n if (rippleSize % 2 === 0) {\n rippleSize += 1;\n }\n } else {\n var sizeX = Math.max(Math.abs((element ? element.clientWidth : 0) - rippleX), rippleX) * 2 + 2;\n var sizeY = Math.max(Math.abs((element ? element.clientHeight : 0) - rippleY), rippleY) * 2 + 2;\n rippleSize = Math.sqrt(Math.pow(sizeX, 2) + Math.pow(sizeY, 2));\n } // Touche devices\n\n\n if (event.touches) {\n // Prepare the ripple effect.\n startTimerCommit.current = function () {\n startCommit({\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize,\n cb: cb\n });\n }; // Delay the execution of the ripple effect.\n\n\n startTimer.current = setTimeout(function () {\n if (startTimerCommit.current) {\n startTimerCommit.current();\n startTimerCommit.current = null;\n }\n }, DELAY_RIPPLE); // We have to make a tradeoff with this value.\n } else {\n startCommit({\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize,\n cb: cb\n });\n }\n }, [centerProp, startCommit]);\n var pulsate = React.useCallback(function () {\n start({}, {\n pulsate: true\n });\n }, [start]);\n var stop = React.useCallback(function (event, cb) {\n clearTimeout(startTimer.current); // The touch interaction occurs too quickly.\n // We still want to show ripple effect.\n\n if (event.type === 'touchend' && startTimerCommit.current) {\n event.persist();\n startTimerCommit.current();\n startTimerCommit.current = null;\n startTimer.current = setTimeout(function () {\n stop(event, cb);\n });\n return;\n }\n\n startTimerCommit.current = null;\n setRipples(function (oldRipples) {\n if (oldRipples.length > 0) {\n return oldRipples.slice(1);\n }\n\n return oldRipples;\n });\n rippleCallback.current = cb;\n }, []);\n React.useImperativeHandle(ref, function () {\n return {\n pulsate: pulsate,\n start: start,\n stop: stop\n };\n }, [pulsate, start, stop]);\n return React.createElement(\"span\", _extends({\n className: clsx(classes.root, className),\n ref: container\n }, other), React.createElement(TransitionGroup, {\n component: null,\n exit: true\n }, ripples));\n}); // TODO cleanup after https://github.com/reactjs/react-docgen/pull/378 is released\n\nfunction withMuiName(Component) {\n Component.muiName = 'MuiTouchRipple';\n return Component;\n}\n\nprocess.env.NODE_ENV !== \"production\" ? TouchRipple.propTypes = {\n /**\n * If `true`, the ripple starts at the center of the component\n * rather than at the point of interaction.\n */\n center: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string\n} : void 0;\nexport default withStyles(styles, {\n flip: false,\n name: 'MuiTouchRipple'\n})(withMuiName(React.memo(TouchRipple)));","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport clsx from 'clsx';\nimport { elementTypeAcceptingRef, refType } from '@material-ui/utils';\nimport useForkRef from '../utils/useForkRef';\nimport useEventCallback from '../utils/useEventCallback';\nimport withStyles from '../styles/withStyles';\nimport NoSsr from '../NoSsr';\nimport { useIsFocusVisible } from '../utils/focusVisible';\nimport TouchRipple from './TouchRipple';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n position: 'relative',\n WebkitTapHighlightColor: 'transparent',\n backgroundColor: 'transparent',\n // Reset default value\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0,\n border: 0,\n margin: 0,\n // Remove the margin in Safari\n borderRadius: 0,\n padding: 0,\n // Remove the padding in Firefox\n cursor: 'pointer',\n userSelect: 'none',\n verticalAlign: 'middle',\n '-moz-appearance': 'none',\n // Reset\n '-webkit-appearance': 'none',\n // Reset\n textDecoration: 'none',\n // So we take precedent over the style of a native <a /> element.\n color: 'inherit',\n '&::-moz-focus-inner': {\n borderStyle: 'none' // Remove Firefox dotted outline.\n\n },\n '&$disabled': {\n pointerEvents: 'none',\n // Disable link interactions\n cursor: 'default'\n }\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if keyboard focused. */\n focusVisible: {}\n};\n/**\n * `ButtonBase` contains as few styles as possible.\n * It aims to be a simple building block for creating a button.\n * It contains a load of style reset and some focus/ripple logic.\n */\n\nvar ButtonBase = React.forwardRef(function ButtonBase(props, ref) {\n var action = props.action,\n buttonRefProp = props.buttonRef,\n _props$centerRipple = props.centerRipple,\n centerRipple = _props$centerRipple === void 0 ? false : _props$centerRipple,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n component = _props$component === void 0 ? 'button' : _props$component,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableRipple = props.disableRipple,\n disableRipple = _props$disableRipple === void 0 ? false : _props$disableRipple,\n _props$disableTouchRi = props.disableTouchRipple,\n disableTouchRipple = _props$disableTouchRi === void 0 ? false : _props$disableTouchRi,\n _props$focusRipple = props.focusRipple,\n focusRipple = _props$focusRipple === void 0 ? false : _props$focusRipple,\n focusVisibleClassName = props.focusVisibleClassName,\n onBlur = props.onBlur,\n onClick = props.onClick,\n onFocus = props.onFocus,\n onFocusVisible = props.onFocusVisible,\n onKeyDown = props.onKeyDown,\n onKeyUp = props.onKeyUp,\n onMouseDown = props.onMouseDown,\n onMouseLeave = props.onMouseLeave,\n onMouseUp = props.onMouseUp,\n onTouchEnd = props.onTouchEnd,\n onTouchMove = props.onTouchMove,\n onTouchStart = props.onTouchStart,\n onDragLeave = props.onDragLeave,\n _props$tabIndex = props.tabIndex,\n tabIndex = _props$tabIndex === void 0 ? 0 : _props$tabIndex,\n TouchRippleProps = props.TouchRippleProps,\n _props$type = props.type,\n type = _props$type === void 0 ? 'button' : _props$type,\n other = _objectWithoutProperties(props, [\"action\", \"buttonRef\", \"centerRipple\", \"children\", \"classes\", \"className\", \"component\", \"disabled\", \"disableRipple\", \"disableTouchRipple\", \"focusRipple\", \"focusVisibleClassName\", \"onBlur\", \"onClick\", \"onFocus\", \"onFocusVisible\", \"onKeyDown\", \"onKeyUp\", \"onMouseDown\", \"onMouseLeave\", \"onMouseUp\", \"onTouchEnd\", \"onTouchMove\", \"onTouchStart\", \"onDragLeave\", \"tabIndex\", \"TouchRippleProps\", \"type\"]);\n\n var buttonRef = React.useRef(null);\n\n function getButtonNode() {\n // #StrictMode ready\n return ReactDOM.findDOMNode(buttonRef.current);\n }\n\n var rippleRef = React.useRef(null);\n\n var _React$useState = React.useState(false),\n focusVisible = _React$useState[0],\n setFocusVisible = _React$useState[1];\n\n if (disabled && focusVisible) {\n setFocusVisible(false);\n }\n\n var _useIsFocusVisible = useIsFocusVisible(),\n isFocusVisible = _useIsFocusVisible.isFocusVisible,\n onBlurVisible = _useIsFocusVisible.onBlurVisible,\n focusVisibleRef = _useIsFocusVisible.ref;\n\n React.useImperativeHandle(action, function () {\n return {\n focusVisible: function focusVisible() {\n setFocusVisible(true);\n buttonRef.current.focus();\n }\n };\n }, []);\n React.useEffect(function () {\n if (focusVisible && focusRipple && !disableRipple) {\n rippleRef.current.pulsate();\n }\n }, [disableRipple, focusRipple, focusVisible]);\n\n function useRippleHandler(rippleAction, eventCallback) {\n var skipRippleAction = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : disableTouchRipple;\n return useEventCallback(function (event) {\n if (eventCallback) {\n eventCallback(event);\n }\n\n var ignore = skipRippleAction;\n\n if (!ignore && rippleRef.current) {\n rippleRef.current[rippleAction](event);\n }\n\n return true;\n });\n }\n\n var handleMouseDown = useRippleHandler('start', onMouseDown);\n var handleDragLeave = useRippleHandler('stop', onDragLeave);\n var handleMouseUp = useRippleHandler('stop', onMouseUp);\n var handleMouseLeave = useRippleHandler('stop', function (event) {\n if (focusVisible) {\n event.preventDefault();\n }\n\n if (onMouseLeave) {\n onMouseLeave(event);\n }\n });\n var handleTouchStart = useRippleHandler('start', onTouchStart);\n var handleTouchEnd = useRippleHandler('stop', onTouchEnd);\n var handleTouchMove = useRippleHandler('stop', onTouchMove);\n var handleBlur = useRippleHandler('stop', function (event) {\n if (focusVisible) {\n onBlurVisible(event);\n setFocusVisible(false);\n }\n\n if (onBlur) {\n onBlur(event);\n }\n }, false);\n var handleFocus = useEventCallback(function (event) {\n if (disabled) {\n return;\n } // Fix for https://github.com/facebook/react/issues/7769\n\n\n if (!buttonRef.current) {\n buttonRef.current = event.currentTarget;\n }\n\n if (isFocusVisible(event)) {\n setFocusVisible(true);\n\n if (onFocusVisible) {\n onFocusVisible(event);\n }\n }\n\n if (onFocus) {\n onFocus(event);\n }\n });\n\n var isNonNativeButton = function isNonNativeButton() {\n var button = getButtonNode();\n return component && component !== 'button' && !(button.tagName === 'A' && button.href);\n };\n /**\n * IE 11 shim for https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/repeat\n */\n\n\n var keydownRef = React.useRef(false);\n var handleKeyDown = useEventCallback(function (event) {\n // Check if key is already down to avoid repeats being counted as multiple activations\n if (focusRipple && !keydownRef.current && focusVisible && rippleRef.current && event.key === ' ') {\n keydownRef.current = true;\n event.persist();\n rippleRef.current.stop(event, function () {\n rippleRef.current.start(event);\n });\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n } // Keyboard accessibility for non interactive elements\n\n\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === 'Enter') {\n event.preventDefault();\n\n if (onClick) {\n onClick(event);\n }\n }\n });\n var handleKeyUp = useEventCallback(function (event) {\n // calling preventDefault in keyUp on a <button> will not dispatch a click event if Space is pressed\n // https://codesandbox.io/s/button-keyup-preventdefault-dn7f0\n if (focusRipple && event.key === ' ' && rippleRef.current && focusVisible && !event.defaultPrevented) {\n keydownRef.current = false;\n event.persist();\n rippleRef.current.stop(event, function () {\n rippleRef.current.pulsate(event);\n });\n }\n\n if (onKeyUp) {\n onKeyUp(event);\n } // Keyboard accessibility for non interactive elements\n\n\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === ' ' && !event.defaultPrevented) {\n event.preventDefault();\n\n if (onClick) {\n onClick(event);\n }\n }\n });\n var ComponentProp = component;\n\n if (ComponentProp === 'button' && other.href) {\n ComponentProp = 'a';\n }\n\n var buttonProps = {};\n\n if (ComponentProp === 'button') {\n buttonProps.type = type;\n buttonProps.disabled = disabled;\n } else {\n if (ComponentProp !== 'a' || !other.href) {\n buttonProps.role = 'button';\n }\n\n buttonProps['aria-disabled'] = disabled;\n }\n\n var handleUserRef = useForkRef(buttonRefProp, ref);\n var handleOwnRef = useForkRef(focusVisibleRef, buttonRef);\n var handleRef = useForkRef(handleUserRef, handleOwnRef);\n return React.createElement(ComponentProp, _extends({\n className: clsx(classes.root, className, focusVisible && [classes.focusVisible, focusVisibleClassName], disabled && classes.disabled),\n onBlur: handleBlur,\n onClick: onClick,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n onKeyUp: handleKeyUp,\n onMouseDown: handleMouseDown,\n onMouseLeave: handleMouseLeave,\n onMouseUp: handleMouseUp,\n onDragLeave: handleDragLeave,\n onTouchEnd: handleTouchEnd,\n onTouchMove: handleTouchMove,\n onTouchStart: handleTouchStart,\n ref: handleRef,\n tabIndex: disabled ? -1 : tabIndex\n }, buttonProps, other), children, !disableRipple && !disabled ? React.createElement(NoSsr, null, React.createElement(TouchRipple, _extends({\n ref: rippleRef,\n center: centerRipple\n }, TouchRippleProps))) : null);\n});\nprocess.env.NODE_ENV !== \"production\" ? ButtonBase.propTypes = {\n /**\n * A ref for imperative actions.\n * It currently only supports `focusVisible()` action.\n */\n action: refType,\n\n /**\n * @ignore\n *\n * Use that prop to pass a ref to the native button component.\n * @deprecated Use `ref` instead.\n */\n buttonRef: refType,\n\n /**\n * If `true`, the ripples will be centered.\n * They won't start at the cursor interaction position.\n */\n centerRipple: PropTypes.bool,\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: elementTypeAcceptingRef,\n\n /**\n * If `true`, the base button will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n *\n * âš ï¸ Without a ripple there is no styling for :focus-visible by default. Be sure\n * to highlight the element by applying separate styles with the `focusVisibleClassName`.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * If `true`, the touch ripple effect will be disabled.\n */\n disableTouchRipple: PropTypes.bool,\n\n /**\n * If `true`, the base button will have a keyboard focus ripple.\n * `disableRipple` must also be `false`.\n */\n focusRipple: PropTypes.bool,\n\n /**\n * This prop can help a person know which element has the keyboard focus.\n * The class name will be applied when the element gain the focus through a keyboard interaction.\n * It's a polyfill for the [CSS :focus-visible selector](https://drafts.csswg.org/selectors-4/#the-focus-visible-pseudo).\n * The rationale for using this feature [is explained here](https://github.com/WICG/focus-visible/blob/master/explainer.md).\n * A [polyfill can be used](https://github.com/WICG/focus-visible) to apply a `focus-visible` class to other components\n * if needed.\n */\n focusVisibleClassName: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onDragLeave: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * Callback fired when the component is focused with a keyboard.\n * We trigger a `onFocus` callback too.\n */\n onFocusVisible: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyUp: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseDown: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseLeave: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseUp: PropTypes.func,\n\n /**\n * @ignore\n */\n onTouchEnd: PropTypes.func,\n\n /**\n * @ignore\n */\n onTouchMove: PropTypes.func,\n\n /**\n * @ignore\n */\n onTouchStart: PropTypes.func,\n\n /**\n * @ignore\n */\n role: PropTypes.string,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * Props applied to the `TouchRipple` element.\n */\n TouchRippleProps: PropTypes.object,\n\n /**\n * Used to control the button's purpose.\n * This prop passes the value to the `type` attribute of the native button component.\n */\n type: PropTypes.oneOf(['submit', 'reset', 'button'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiButtonBase'\n})(ButtonBase);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport debounce from '../utils/debounce';\nimport useForkRef from '../utils/useForkRef';\n\nfunction getStyleValue(computedStyle, property) {\n return parseInt(computedStyle[property], 10) || 0;\n}\n\nvar useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\nvar styles = {\n /* Styles applied to the shadow textarea element. */\n shadow: {\n // Visibility needed to hide the extra text area on iPads\n visibility: 'hidden',\n // Remove from the content flow\n position: 'absolute',\n // Ignore the scrollbar width\n overflow: 'hidden',\n height: 0,\n top: 0,\n left: 0,\n // Create a new layer, increase the isolation of the computed values\n transform: 'translateZ(0)'\n }\n};\nvar TextareaAutosize = React.forwardRef(function TextareaAutosize(props, ref) {\n var onChange = props.onChange,\n rows = props.rows,\n rowsMax = props.rowsMax,\n _props$rowsMin = props.rowsMin,\n rowsMinProp = _props$rowsMin === void 0 ? 1 : _props$rowsMin,\n style = props.style,\n value = props.value,\n other = _objectWithoutProperties(props, [\"onChange\", \"rows\", \"rowsMax\", \"rowsMin\", \"style\", \"value\"]);\n\n var rowsMin = rows || rowsMinProp;\n\n var _React$useRef = React.useRef(value != null),\n isControlled = _React$useRef.current;\n\n var inputRef = React.useRef(null);\n var handleRef = useForkRef(ref, inputRef);\n var shadowRef = React.useRef(null);\n\n var _React$useState = React.useState({}),\n state = _React$useState[0],\n setState = _React$useState[1];\n\n var syncHeight = React.useCallback(function () {\n var input = inputRef.current;\n var computedStyle = window.getComputedStyle(input);\n var inputShallow = shadowRef.current;\n inputShallow.style.width = computedStyle.width;\n inputShallow.value = input.value || props.placeholder || 'x';\n var boxSizing = computedStyle['box-sizing'];\n var padding = getStyleValue(computedStyle, 'padding-bottom') + getStyleValue(computedStyle, 'padding-top');\n var border = getStyleValue(computedStyle, 'border-bottom-width') + getStyleValue(computedStyle, 'border-top-width'); // The height of the inner content\n\n var innerHeight = inputShallow.scrollHeight - padding; // Measure height of a textarea with a single row\n\n inputShallow.value = 'x';\n var singleRowHeight = inputShallow.scrollHeight - padding; // The height of the outer content\n\n var outerHeight = innerHeight;\n\n if (rowsMin) {\n outerHeight = Math.max(Number(rowsMin) * singleRowHeight, outerHeight);\n }\n\n if (rowsMax) {\n outerHeight = Math.min(Number(rowsMax) * singleRowHeight, outerHeight);\n }\n\n outerHeight = Math.max(outerHeight, singleRowHeight); // Take the box sizing into account for applying this value as a style.\n\n var outerHeightStyle = outerHeight + (boxSizing === 'border-box' ? padding + border : 0);\n var overflow = Math.abs(outerHeight - innerHeight) <= 1;\n setState(function (prevState) {\n // Need a large enough different to update the height.\n // This prevents infinite rendering loop.\n if (outerHeightStyle > 0 && Math.abs((prevState.outerHeightStyle || 0) - outerHeightStyle) > 1 || prevState.overflow !== overflow) {\n return {\n overflow: overflow,\n outerHeightStyle: outerHeightStyle\n };\n }\n\n return prevState;\n });\n }, [rowsMax, rowsMin, props.placeholder]);\n React.useEffect(function () {\n var handleResize = debounce(function () {\n syncHeight();\n });\n window.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n window.removeEventListener('resize', handleResize);\n };\n }, [syncHeight]);\n useEnhancedEffect(function () {\n syncHeight();\n });\n\n var handleChange = function handleChange(event) {\n if (!isControlled) {\n syncHeight();\n }\n\n if (onChange) {\n onChange(event);\n }\n };\n\n return React.createElement(React.Fragment, null, React.createElement(\"textarea\", _extends({\n value: value,\n onChange: handleChange,\n ref: handleRef // Apply the rows prop to get a \"correct\" first SSR paint\n ,\n rows: rowsMin,\n style: _extends({\n height: state.outerHeightStyle,\n // Need a large enough different to allow scrolling.\n // This prevents infinite rendering loop.\n overflow: state.overflow ? 'hidden' : null\n }, style)\n }, other)), React.createElement(\"textarea\", {\n \"aria-hidden\": true,\n className: props.className,\n readOnly: true,\n ref: shadowRef,\n tabIndex: -1,\n style: _extends({}, styles.shadow, {}, style)\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? TextareaAutosize.propTypes = {\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * @ignore\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n placeholder: PropTypes.string,\n\n /**\n * Use `rowsMin` instead. The prop will be removed in v5.\n *\n * @deprecated\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Minimum number of rows to display.\n */\n rowsMin: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * @ignore\n */\n value: PropTypes.any\n} : void 0;\nexport default TextareaAutosize;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n\n/* eslint-disable jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport formControlState from '../FormControl/formControlState';\nimport FormControlContext, { useFormControl } from '../FormControl/FormControlContext';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport useForkRef from '../utils/useForkRef';\nimport TextareaAutosize from '../TextareaAutosize';\nimport { isFilled } from './utils';\nexport var styles = function styles(theme) {\n var light = theme.palette.type === 'light';\n var placeholder = {\n color: 'currentColor',\n opacity: light ? 0.42 : 0.5,\n transition: theme.transitions.create('opacity', {\n duration: theme.transitions.duration.shorter\n })\n };\n var placeholderHidden = {\n opacity: '0 !important'\n };\n var placeholderVisible = {\n opacity: light ? 0.42 : 0.5\n };\n return {\n /* Styles applied to the root element. */\n root: {\n // Mimics the default input display property used by browsers for an input.\n fontFamily: theme.typography.fontFamily,\n color: theme.palette.text.primary,\n fontSize: theme.typography.pxToRem(16),\n lineHeight: '1.1875em',\n // Reset (19px), match the native input line-height\n boxSizing: 'border-box',\n // Prevent padding issue with fullWidth.\n position: 'relative',\n cursor: 'text',\n display: 'inline-flex',\n alignItems: 'center',\n '&$disabled': {\n color: theme.palette.text.disabled,\n cursor: 'default'\n }\n },\n\n /* Styles applied to the root element if the component is a descendant of `FormControl`. */\n formControl: {},\n\n /* Styles applied to the root element if the component is focused. */\n focused: {},\n\n /* Styles applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `startAdornment` is provided. */\n adornedStart: {},\n\n /* Styles applied to the root element if `endAdornment` is provided. */\n adornedEnd: {},\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {\n padding: \"\".concat(8 - 2, \"px 0 \").concat(8 - 1, \"px\"),\n '&$marginDense': {\n paddingTop: 4 - 1\n }\n },\n\n /* Styles applied to the root element if the color is secondary. */\n colorSecondary: {},\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {\n width: '100%'\n },\n\n /* Styles applied to the `input` element. */\n input: {\n font: 'inherit',\n color: 'currentColor',\n padding: \"\".concat(8 - 2, \"px 0 \").concat(8 - 1, \"px\"),\n border: 0,\n boxSizing: 'content-box',\n background: 'none',\n height: '1.1875em',\n // Reset (19px), match the native input line-height\n margin: 0,\n // Reset for Safari\n WebkitTapHighlightColor: 'transparent',\n display: 'block',\n // Make the flex item shrink with Firefox\n minWidth: 0,\n width: '100%',\n // Fix IE 11 width issue\n animationName: '$auto-fill-cancel',\n '&::-webkit-input-placeholder': placeholder,\n '&::-moz-placeholder': placeholder,\n // Firefox 19+\n '&:-ms-input-placeholder': placeholder,\n // IE 11\n '&::-ms-input-placeholder': placeholder,\n // Edge\n '&:focus': {\n outline: 0\n },\n // Reset Firefox invalid required input style\n '&:invalid': {\n boxShadow: 'none'\n },\n '&::-webkit-search-decoration': {\n // Remove the padding when type=search.\n '-webkit-appearance': 'none'\n },\n // Show and hide the placeholder logic\n 'label[data-shrink=false] + $formControl &': {\n '&::-webkit-input-placeholder': placeholderHidden,\n '&::-moz-placeholder': placeholderHidden,\n // Firefox 19+\n '&:-ms-input-placeholder': placeholderHidden,\n // IE 11\n '&::-ms-input-placeholder': placeholderHidden,\n // Edge\n '&:focus::-webkit-input-placeholder': placeholderVisible,\n '&:focus::-moz-placeholder': placeholderVisible,\n // Firefox 19+\n '&:focus:-ms-input-placeholder': placeholderVisible,\n // IE 11\n '&:focus::-ms-input-placeholder': placeholderVisible // Edge\n\n },\n '&$disabled': {\n opacity: 1 // Reset iOS opacity\n\n },\n '&:-webkit-autofill': {\n animationDuration: '5000s',\n animationName: '$auto-fill'\n }\n },\n '@keyframes auto-fill': {\n from: {}\n },\n '@keyframes auto-fill-cancel': {\n from: {}\n },\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {\n paddingTop: 4 - 1\n },\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {\n height: 'auto',\n resize: 'none',\n padding: 0\n },\n\n /* Styles applied to the `input` element if `type=\"search\"`. */\n inputTypeSearch: {\n // Improve type search style.\n '-moz-appearance': 'textfield',\n '-webkit-appearance': 'textfield'\n },\n\n /* Styles applied to the `input` element if `startAdornment` is provided. */\n inputAdornedStart: {},\n\n /* Styles applied to the `input` element if `endAdornment` is provided. */\n inputAdornedEnd: {},\n\n /* Styles applied to the `input` element if `hiddenLabel={true}`. */\n inputHiddenLabel: {}\n };\n};\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * `InputBase` contains as few styles as possible.\n * It aims to be a simple building block for creating an input.\n * It contains a load of style reset and some state logic.\n */\n\nvar InputBase = React.forwardRef(function InputBase(props, ref) {\n var ariaDescribedby = props['aria-describedby'],\n autoComplete = props.autoComplete,\n autoFocus = props.autoFocus,\n classes = props.classes,\n className = props.className,\n color = props.color,\n defaultValue = props.defaultValue,\n disabled = props.disabled,\n endAdornment = props.endAdornment,\n error = props.error,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n id = props.id,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$inputProps = props.inputProps,\n inputPropsProp = _props$inputProps === void 0 ? {} : _props$inputProps,\n inputRefProp = props.inputRef,\n margin = props.margin,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onClick = props.onClick,\n onFocus = props.onFocus,\n onKeyDown = props.onKeyDown,\n onKeyUp = props.onKeyUp,\n placeholder = props.placeholder,\n readOnly = props.readOnly,\n renderSuffix = props.renderSuffix,\n rows = props.rows,\n rowsMax = props.rowsMax,\n rowsMin = props.rowsMin,\n startAdornment = props.startAdornment,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n valueProp = props.value,\n other = _objectWithoutProperties(props, [\"aria-describedby\", \"autoComplete\", \"autoFocus\", \"classes\", \"className\", \"color\", \"defaultValue\", \"disabled\", \"endAdornment\", \"error\", \"fullWidth\", \"id\", \"inputComponent\", \"inputProps\", \"inputRef\", \"margin\", \"multiline\", \"name\", \"onBlur\", \"onChange\", \"onClick\", \"onFocus\", \"onKeyDown\", \"onKeyUp\", \"placeholder\", \"readOnly\", \"renderSuffix\", \"rows\", \"rowsMax\", \"rowsMin\", \"startAdornment\", \"type\", \"value\"]);\n\n var value = inputPropsProp.value != null ? inputPropsProp.value : valueProp;\n\n var _React$useRef = React.useRef(value != null),\n isControlled = _React$useRef.current;\n\n var inputRef = React.useRef();\n var handleInputRefWarning = React.useCallback(function (instance) {\n if (process.env.NODE_ENV !== 'production') {\n if (instance && !(instance instanceof HTMLInputElement) && !instance.focus) {\n console.error(['Material-UI: you have provided a `inputComponent` to the input component', 'that does not correctly handle the `inputRef` prop.', 'Make sure the `inputRef` prop is called with a HTMLInputElement.'].join('\\n'));\n }\n }\n }, []);\n var handleInputPropsRefProp = useForkRef(inputPropsProp.ref, handleInputRefWarning);\n var handleInputRefProp = useForkRef(inputRefProp, handleInputPropsRefProp);\n var handleInputRef = useForkRef(inputRef, handleInputRefProp);\n\n var _React$useState = React.useState(false),\n focused = _React$useState[0],\n setFocused = _React$useState[1];\n\n var muiFormControl = useFormControl();\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (muiFormControl) {\n return muiFormControl.registerEffect();\n }\n\n return undefined;\n }, [muiFormControl]);\n }\n\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['color', 'disabled', 'error', 'hiddenLabel', 'margin', 'required', 'filled']\n });\n fcs.focused = muiFormControl ? muiFormControl.focused : focused; // The blur won't fire when the disabled state is set on a focused input.\n // We need to book keep the focused state manually.\n\n React.useEffect(function () {\n if (!muiFormControl && disabled && focused) {\n setFocused(false);\n\n if (onBlur) {\n onBlur();\n }\n }\n }, [muiFormControl, disabled, focused, onBlur]);\n var onFilled = muiFormControl && muiFormControl.onFilled;\n var onEmpty = muiFormControl && muiFormControl.onEmpty;\n var checkDirty = React.useCallback(function (obj) {\n if (isFilled(obj)) {\n if (onFilled) {\n onFilled();\n }\n } else if (onEmpty) {\n onEmpty();\n }\n }, [onFilled, onEmpty]);\n useEnhancedEffect(function () {\n if (isControlled) {\n checkDirty({\n value: value\n });\n }\n }, [value, checkDirty, isControlled]);\n\n var handleFocus = function handleFocus(event) {\n // Fix a bug with IE 11 where the focus/blur events are triggered\n // while the input is disabled.\n if (fcs.disabled) {\n event.stopPropagation();\n return;\n }\n\n if (onFocus) {\n onFocus(event);\n }\n\n if (inputPropsProp.onFocus) {\n inputPropsProp.onFocus(event);\n }\n\n if (muiFormControl && muiFormControl.onFocus) {\n muiFormControl.onFocus(event);\n } else {\n setFocused(true);\n }\n };\n\n var handleBlur = function handleBlur(event) {\n if (onBlur) {\n onBlur(event);\n }\n\n if (inputPropsProp.onBlur) {\n inputPropsProp.onBlur(event);\n }\n\n if (muiFormControl && muiFormControl.onBlur) {\n muiFormControl.onBlur(event);\n } else {\n setFocused(false);\n }\n };\n\n var handleChange = function handleChange(event) {\n if (!isControlled) {\n var element = event.target || inputRef.current;\n\n if (element == null) {\n throw new TypeError('Material-UI: Expected valid input target. ' + 'Did you use a custom `inputComponent` and forget to forward refs? ' + 'See https://material-ui.com/r/input-component-ref-interface for more info.');\n }\n\n checkDirty({\n value: element.value\n });\n }\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n if (inputPropsProp.onChange) {\n inputPropsProp.onChange.apply(inputPropsProp, [event].concat(args));\n } // Perform in the willUpdate\n\n\n if (onChange) {\n onChange.apply(void 0, [event].concat(args));\n }\n }; // Check the input state on mount, in case it was filled by the user\n // or auto filled by the browser before the hydration (for SSR).\n\n\n React.useEffect(function () {\n checkDirty(inputRef.current);\n }, []); // eslint-disable-line react-hooks/exhaustive-deps\n\n var handleClick = function handleClick(event) {\n if (inputRef.current && event.currentTarget === event.target) {\n inputRef.current.focus();\n }\n\n if (onClick) {\n onClick(event);\n }\n };\n\n var InputComponent = inputComponent;\n\n var inputProps = _extends({}, inputPropsProp, {\n ref: handleInputRef\n });\n\n if (typeof InputComponent !== 'string') {\n inputProps = _extends({\n // Rename ref to inputRef as we don't know the\n // provided `inputComponent` structure.\n inputRef: handleInputRef,\n type: type\n }, inputProps, {\n ref: null\n });\n } else if (multiline) {\n if (rows && !rowsMax && !rowsMin) {\n InputComponent = 'textarea';\n } else {\n inputProps = _extends({\n rows: rows,\n rowsMax: rowsMax\n }, inputProps);\n InputComponent = TextareaAutosize;\n }\n } else {\n inputProps = _extends({\n type: type\n }, inputProps);\n }\n\n var handleAutoFill = function handleAutoFill(event) {\n // Provide a fake value as Chrome might not let you access it for security reasons.\n checkDirty(event.animationName.indexOf('auto-fill-cancel') !== -1 ? inputRef.current : {\n value: 'x'\n });\n };\n\n React.useEffect(function () {\n if (muiFormControl) {\n muiFormControl.setAdornedStart(Boolean(startAdornment));\n }\n }, [muiFormControl, startAdornment]);\n return React.createElement(\"div\", _extends({\n className: clsx(classes.root, classes[\"color\".concat(capitalize(fcs.color || 'primary'))], className, fcs.disabled && classes.disabled, fcs.error && classes.error, fullWidth && classes.fullWidth, fcs.focused && classes.focused, muiFormControl && classes.formControl, multiline && classes.multiline, startAdornment && classes.adornedStart, endAdornment && classes.adornedEnd, {\n dense: classes.marginDense\n }[fcs.margin]),\n onClick: handleClick,\n ref: ref\n }, other), startAdornment, React.createElement(FormControlContext.Provider, {\n value: null\n }, React.createElement(InputComponent, _extends({\n \"aria-invalid\": fcs.error,\n \"aria-describedby\": ariaDescribedby,\n autoComplete: autoComplete,\n autoFocus: autoFocus,\n defaultValue: defaultValue,\n disabled: fcs.disabled,\n id: id,\n onAnimationStart: handleAutoFill,\n name: name,\n placeholder: placeholder,\n readOnly: readOnly,\n required: fcs.required,\n rows: rows,\n value: value,\n onKeyDown: onKeyDown,\n onKeyUp: onKeyUp\n }, inputProps, {\n className: clsx(classes.input, inputPropsProp.className, fcs.disabled && classes.disabled, multiline && classes.inputMultiline, fcs.hiddenLabel && classes.inputHiddenLabel, startAdornment && classes.inputAdornedStart, endAdornment && classes.inputAdornedEnd, {\n search: classes.inputTypeSearch\n }[type], {\n dense: classes.inputMarginDense\n }[fcs.margin]),\n onBlur: handleBlur,\n onChange: handleChange,\n onFocus: handleFocus\n }))), endAdornment, renderSuffix ? renderSuffix(_extends({}, fcs, {\n startAdornment: startAdornment\n })) : null);\n});\nprocess.env.NODE_ENV !== \"production\" ? InputBase.propTypes = {\n /**\n * @ignore\n */\n 'aria-describedby': PropTypes.string,\n\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the `input` element.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the input is blurred.\n *\n * Notice that the first argument (event) might be undefined.\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyUp: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * @ignore\n */\n renderSuffix: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Minimum number of rows to display when multiline option is set to true.\n */\n rowsMin: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiInputBase'\n})(InputBase);","/** @license React v16.12.0\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var h=require(\"object-assign\"),n=\"function\"===typeof Symbol&&Symbol.for,p=n?Symbol.for(\"react.element\"):60103,q=n?Symbol.for(\"react.portal\"):60106,r=n?Symbol.for(\"react.fragment\"):60107,t=n?Symbol.for(\"react.strict_mode\"):60108,u=n?Symbol.for(\"react.profiler\"):60114,v=n?Symbol.for(\"react.provider\"):60109,w=n?Symbol.for(\"react.context\"):60110,x=n?Symbol.for(\"react.forward_ref\"):60112,y=n?Symbol.for(\"react.suspense\"):60113;n&&Symbol.for(\"react.suspense_list\");\nvar z=n?Symbol.for(\"react.memo\"):60115,aa=n?Symbol.for(\"react.lazy\"):60116;n&&Symbol.for(\"react.fundamental\");n&&Symbol.for(\"react.responder\");n&&Symbol.for(\"react.scope\");var A=\"function\"===typeof Symbol&&Symbol.iterator;\nfunction B(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}var C={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},D={};\nfunction E(a,b,c){this.props=a;this.context=b;this.refs=D;this.updater=c||C}E.prototype.isReactComponent={};E.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(B(85));this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,c){this.props=a;this.context=b;this.refs=D;this.updater=c||C}var H=G.prototype=new F;\nH.constructor=G;h(H,E.prototype);H.isPureReactComponent=!0;var I={current:null},J={current:null},K=Object.prototype.hasOwnProperty,L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,c){var e,d={},g=null,l=null;if(null!=b)for(e in void 0!==b.ref&&(l=b.ref),void 0!==b.key&&(g=\"\"+b.key),b)K.call(b,e)&&!L.hasOwnProperty(e)&&(d[e]=b[e]);var f=arguments.length-2;if(1===f)d.children=c;else if(1<f){for(var k=Array(f),m=0;m<f;m++)k[m]=arguments[m+2];d.children=k}if(a&&a.defaultProps)for(e in f=a.defaultProps,f)void 0===d[e]&&(d[e]=f[e]);return{$$typeof:p,type:a,key:g,ref:l,props:d,_owner:J.current}}\nfunction ba(a,b){return{$$typeof:p,type:a.type,key:b,ref:a.ref,props:a.props,_owner:a._owner}}function N(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===p}function escape(a){var b={\"=\":\"=0\",\":\":\"=2\"};return\"$\"+(\"\"+a).replace(/[=:]/g,function(a){return b[a]})}var O=/\\/+/g,P=[];function Q(a,b,c,e){if(P.length){var d=P.pop();d.result=a;d.keyPrefix=b;d.func=c;d.context=e;d.count=0;return d}return{result:a,keyPrefix:b,func:c,context:e,count:0}}\nfunction R(a){a.result=null;a.keyPrefix=null;a.func=null;a.context=null;a.count=0;10>P.length&&P.push(a)}\nfunction S(a,b,c,e){var d=typeof a;if(\"undefined\"===d||\"boolean\"===d)a=null;var g=!1;if(null===a)g=!0;else switch(d){case \"string\":case \"number\":g=!0;break;case \"object\":switch(a.$$typeof){case p:case q:g=!0}}if(g)return c(e,a,\"\"===b?\".\"+T(a,0):b),1;g=0;b=\"\"===b?\".\":b+\":\";if(Array.isArray(a))for(var l=0;l<a.length;l++){d=a[l];var f=b+T(d,l);g+=S(d,f,c,e)}else if(null===a||\"object\"!==typeof a?f=null:(f=A&&a[A]||a[\"@@iterator\"],f=\"function\"===typeof f?f:null),\"function\"===typeof f)for(a=f.call(a),l=\n0;!(d=a.next()).done;)d=d.value,f=b+T(d,l++),g+=S(d,f,c,e);else if(\"object\"===d)throw c=\"\"+a,Error(B(31,\"[object Object]\"===c?\"object with keys {\"+Object.keys(a).join(\", \")+\"}\":c,\"\"));return g}function U(a,b,c){return null==a?0:S(a,\"\",b,c)}function T(a,b){return\"object\"===typeof a&&null!==a&&null!=a.key?escape(a.key):b.toString(36)}function ca(a,b){a.func.call(a.context,b,a.count++)}\nfunction da(a,b,c){var e=a.result,d=a.keyPrefix;a=a.func.call(a.context,b,a.count++);Array.isArray(a)?V(a,e,c,function(a){return a}):null!=a&&(N(a)&&(a=ba(a,d+(!a.key||b&&b.key===a.key?\"\":(\"\"+a.key).replace(O,\"$&/\")+\"/\")+c)),e.push(a))}function V(a,b,c,e,d){var g=\"\";null!=c&&(g=(\"\"+c).replace(O,\"$&/\")+\"/\");b=Q(b,g,e,d);U(a,da,b);R(b)}function W(){var a=I.current;if(null===a)throw Error(B(321));return a}\nvar X={Children:{map:function(a,b,c){if(null==a)return a;var e=[];V(a,e,null,b,c);return e},forEach:function(a,b,c){if(null==a)return a;b=Q(null,null,b,c);U(a,ca,b);R(b)},count:function(a){return U(a,function(){return null},null)},toArray:function(a){var b=[];V(a,b,null,function(a){return a});return b},only:function(a){if(!N(a))throw Error(B(143));return a}},createRef:function(){return{current:null}},Component:E,PureComponent:G,createContext:function(a,b){void 0===b&&(b=null);a={$$typeof:w,_calculateChangedBits:b,\n_currentValue:a,_currentValue2:a,_threadCount:0,Provider:null,Consumer:null};a.Provider={$$typeof:v,_context:a};return a.Consumer=a},forwardRef:function(a){return{$$typeof:x,render:a}},lazy:function(a){return{$$typeof:aa,_ctor:a,_status:-1,_result:null}},memo:function(a,b){return{$$typeof:z,type:a,compare:void 0===b?null:b}},useCallback:function(a,b){return W().useCallback(a,b)},useContext:function(a,b){return W().useContext(a,b)},useEffect:function(a,b){return W().useEffect(a,b)},useImperativeHandle:function(a,\nb,c){return W().useImperativeHandle(a,b,c)},useDebugValue:function(){},useLayoutEffect:function(a,b){return W().useLayoutEffect(a,b)},useMemo:function(a,b){return W().useMemo(a,b)},useReducer:function(a,b,c){return W().useReducer(a,b,c)},useRef:function(a){return W().useRef(a)},useState:function(a){return W().useState(a)},Fragment:r,Profiler:u,StrictMode:t,Suspense:y,createElement:M,cloneElement:function(a,b,c){if(null===a||void 0===a)throw Error(B(267,a));var e=h({},a.props),d=a.key,g=a.ref,l=a._owner;\nif(null!=b){void 0!==b.ref&&(g=b.ref,l=J.current);void 0!==b.key&&(d=\"\"+b.key);if(a.type&&a.type.defaultProps)var f=a.type.defaultProps;for(k in b)K.call(b,k)&&!L.hasOwnProperty(k)&&(e[k]=void 0===b[k]&&void 0!==f?f[k]:b[k])}var k=arguments.length-2;if(1===k)e.children=c;else if(1<k){f=Array(k);for(var m=0;m<k;m++)f[m]=arguments[m+2];e.children=f}return{$$typeof:p,type:a.type,key:d,ref:g,props:e,_owner:l}},createFactory:function(a){var b=M.bind(null,a);b.type=a;return b},isValidElement:N,version:\"16.12.0\",\n__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{ReactCurrentDispatcher:I,ReactCurrentBatchConfig:{suspense:null},ReactCurrentOwner:J,IsSomeRendererActing:{current:!1},assign:h}},Y={default:X},Z=Y&&X||Y;module.exports=Z.default||Z;\n","/** @license React v16.12.0\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),n=require(\"object-assign\"),q=require(\"scheduler\");function u(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}if(!aa)throw Error(u(227));var ba=null,ca={};\nfunction da(){if(ba)for(var a in ca){var b=ca[a],c=ba.indexOf(a);if(!(-1<c))throw Error(u(96,a));if(!ea[c]){if(!b.extractEvents)throw Error(u(97,a));ea[c]=b;c=b.eventTypes;for(var d in c){var e=void 0;var f=c[d],g=b,h=d;if(fa.hasOwnProperty(h))throw Error(u(99,h));fa[h]=f;var k=f.phasedRegistrationNames;if(k){for(e in k)k.hasOwnProperty(e)&&ha(k[e],g,h);e=!0}else f.registrationName?(ha(f.registrationName,g,h),e=!0):e=!1;if(!e)throw Error(u(98,d,a));}}}}\nfunction ha(a,b,c){if(ia[a])throw Error(u(100,a));ia[a]=b;ja[a]=b.eventTypes[c].dependencies}var ea=[],fa={},ia={},ja={};function ka(a,b,c,d,e,f,g,h,k){var l=Array.prototype.slice.call(arguments,3);try{b.apply(c,l)}catch(m){this.onError(m)}}var la=!1,ma=null,na=!1,oa=null,pa={onError:function(a){la=!0;ma=a}};function qa(a,b,c,d,e,f,g,h,k){la=!1;ma=null;ka.apply(pa,arguments)}\nfunction ra(a,b,c,d,e,f,g,h,k){qa.apply(this,arguments);if(la){if(la){var l=ma;la=!1;ma=null}else throw Error(u(198));na||(na=!0,oa=l)}}var sa=null,ua=null,va=null;function wa(a,b,c){var d=a.type||\"unknown-event\";a.currentTarget=va(c);ra(d,b,void 0,a);a.currentTarget=null}function xa(a,b){if(null==b)throw Error(u(30));if(null==a)return b;if(Array.isArray(a)){if(Array.isArray(b))return a.push.apply(a,b),a;a.push(b);return a}return Array.isArray(b)?[a].concat(b):[a,b]}\nfunction ya(a,b,c){Array.isArray(a)?a.forEach(b,c):a&&b.call(c,a)}var za=null;function Aa(a){if(a){var b=a._dispatchListeners,c=a._dispatchInstances;if(Array.isArray(b))for(var d=0;d<b.length&&!a.isPropagationStopped();d++)wa(a,b[d],c[d]);else b&&wa(a,b,c);a._dispatchListeners=null;a._dispatchInstances=null;a.isPersistent()||a.constructor.release(a)}}function Ba(a){null!==a&&(za=xa(za,a));a=za;za=null;if(a){ya(a,Aa);if(za)throw Error(u(95));if(na)throw a=oa,na=!1,oa=null,a;}}\nvar Ca={injectEventPluginOrder:function(a){if(ba)throw Error(u(101));ba=Array.prototype.slice.call(a);da()},injectEventPluginsByName:function(a){var b=!1,c;for(c in a)if(a.hasOwnProperty(c)){var d=a[c];if(!ca.hasOwnProperty(c)||ca[c]!==d){if(ca[c])throw Error(u(102,c));ca[c]=d;b=!0}}b&&da()}};\nfunction Da(a,b){var c=a.stateNode;if(!c)return null;var d=sa(c);if(!d)return null;c=d[b];a:switch(b){case \"onClick\":case \"onClickCapture\":case \"onDoubleClick\":case \"onDoubleClickCapture\":case \"onMouseDown\":case \"onMouseDownCapture\":case \"onMouseMove\":case \"onMouseMoveCapture\":case \"onMouseUp\":case \"onMouseUpCapture\":(d=!d.disabled)||(a=a.type,d=!(\"button\"===a||\"input\"===a||\"select\"===a||\"textarea\"===a));a=!d;break a;default:a=!1}if(a)return null;if(c&&\"function\"!==typeof c)throw Error(u(231,b,typeof c));\nreturn c}var Ea=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;Ea.hasOwnProperty(\"ReactCurrentDispatcher\")||(Ea.ReactCurrentDispatcher={current:null});Ea.hasOwnProperty(\"ReactCurrentBatchConfig\")||(Ea.ReactCurrentBatchConfig={suspense:null});\nvar Fa=/^(.*)[\\\\\\/]/,w=\"function\"===typeof Symbol&&Symbol.for,Ga=w?Symbol.for(\"react.element\"):60103,Ha=w?Symbol.for(\"react.portal\"):60106,Ia=w?Symbol.for(\"react.fragment\"):60107,Ja=w?Symbol.for(\"react.strict_mode\"):60108,Ka=w?Symbol.for(\"react.profiler\"):60114,La=w?Symbol.for(\"react.provider\"):60109,Ma=w?Symbol.for(\"react.context\"):60110,Na=w?Symbol.for(\"react.concurrent_mode\"):60111,Oa=w?Symbol.for(\"react.forward_ref\"):60112,Pa=w?Symbol.for(\"react.suspense\"):60113,Qa=w?Symbol.for(\"react.suspense_list\"):\n60120,Ra=w?Symbol.for(\"react.memo\"):60115,Sa=w?Symbol.for(\"react.lazy\"):60116;w&&Symbol.for(\"react.fundamental\");w&&Symbol.for(\"react.responder\");w&&Symbol.for(\"react.scope\");var Ta=\"function\"===typeof Symbol&&Symbol.iterator;function Ua(a){if(null===a||\"object\"!==typeof a)return null;a=Ta&&a[Ta]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nfunction Va(a){if(-1===a._status){a._status=0;var b=a._ctor;b=b();a._result=b;b.then(function(b){0===a._status&&(b=b.default,a._status=1,a._result=b)},function(b){0===a._status&&(a._status=2,a._result=b)})}}\nfunction Wa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case Ia:return\"Fragment\";case Ha:return\"Portal\";case Ka:return\"Profiler\";case Ja:return\"StrictMode\";case Pa:return\"Suspense\";case Qa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ma:return\"Context.Consumer\";case La:return\"Context.Provider\";case Oa:var b=a.render;b=b.displayName||b.name||\"\";return a.displayName||(\"\"!==b?\"ForwardRef(\"+b+\")\":\n\"ForwardRef\");case Ra:return Wa(a.type);case Sa:if(a=1===a._status?a._result:null)return Wa(a)}return null}function Xa(a){var b=\"\";do{a:switch(a.tag){case 3:case 4:case 6:case 7:case 10:case 9:var c=\"\";break a;default:var d=a._debugOwner,e=a._debugSource,f=Wa(a.type);c=null;d&&(c=Wa(d.type));d=f;f=\"\";e?f=\" (at \"+e.fileName.replace(Fa,\"\")+\":\"+e.lineNumber+\")\":c&&(f=\" (created by \"+c+\")\");c=\"\\n in \"+(d||\"Unknown\")+f}b+=c;a=a.return}while(a);return b}\nvar Ya=!(\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement),Za=null,$a=null,ab=null;function bb(a){if(a=ua(a)){if(\"function\"!==typeof Za)throw Error(u(280));var b=sa(a.stateNode);Za(a.stateNode,a.type,b)}}function cb(a){$a?ab?ab.push(a):ab=[a]:$a=a}function db(){if($a){var a=$a,b=ab;ab=$a=null;bb(a);if(b)for(a=0;a<b.length;a++)bb(b[a])}}function eb(a,b){return a(b)}function fb(a,b,c,d){return a(b,c,d)}function gb(){}\nvar hb=eb,ib=!1,jb=!1;function kb(){if(null!==$a||null!==ab)gb(),db()}new Map;var lb=/^[:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD][:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD\\-.0-9\\u00B7\\u0300-\\u036F\\u203F-\\u2040]*$/,mb=Object.prototype.hasOwnProperty,nb={},ob={};\nfunction pb(a){if(mb.call(ob,a))return!0;if(mb.call(nb,a))return!1;if(lb.test(a))return ob[a]=!0;nb[a]=!0;return!1}function qb(a,b,c,d){if(null!==c&&0===c.type)return!1;switch(typeof b){case \"function\":case \"symbol\":return!0;case \"boolean\":if(d)return!1;if(null!==c)return!c.acceptsBooleans;a=a.toLowerCase().slice(0,5);return\"data-\"!==a&&\"aria-\"!==a;default:return!1}}\nfunction rb(a,b,c,d){if(null===b||\"undefined\"===typeof b||qb(a,b,c,d))return!0;if(d)return!1;if(null!==c)switch(c.type){case 3:return!b;case 4:return!1===b;case 5:return isNaN(b);case 6:return isNaN(b)||1>b}return!1}function B(a,b,c,d,e,f){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f}var D={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){D[a]=new B(a,0,!1,a,null,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];D[b]=new B(b,1,!1,a[1],null,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){D[a]=new B(a,2,!1,a.toLowerCase(),null,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){D[a]=new B(a,2,!1,a,null,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){D[a]=new B(a,3,!1,a.toLowerCase(),null,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){D[a]=new B(a,3,!0,a,null,!1)});[\"capture\",\"download\"].forEach(function(a){D[a]=new B(a,4,!1,a,null,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){D[a]=new B(a,6,!1,a,null,!1)});[\"rowSpan\",\"start\"].forEach(function(a){D[a]=new B(a,5,!1,a.toLowerCase(),null,!1)});var sb=/[\\-:]([a-z])/g;function tb(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(sb,\ntb);D[b]=new B(b,1,!1,a,null,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(sb,tb);D[b]=new B(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(sb,tb);D[b]=new B(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!1)});\nD.xlinkHref=new B(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!0)});function ub(a){switch(typeof a){case \"boolean\":case \"number\":case \"object\":case \"string\":case \"undefined\":return a;default:return\"\"}}\nfunction vb(a,b,c,d){var e=D.hasOwnProperty(b)?D[b]:null;var f=null!==e?0===e.type:d?!1:!(2<b.length)||\"o\"!==b[0]&&\"O\"!==b[0]||\"n\"!==b[1]&&\"N\"!==b[1]?!1:!0;f||(rb(b,c,e,d)&&(c=null),d||null===e?pb(b)&&(null===c?a.removeAttribute(b):a.setAttribute(b,\"\"+c)):e.mustUseProperty?a[e.propertyName]=null===c?3===e.type?!1:\"\":c:(b=e.attributeName,d=e.attributeNamespace,null===c?a.removeAttribute(b):(e=e.type,c=3===e||4===e&&!0===c?\"\":\"\"+c,d?a.setAttributeNS(d,b,c):a.setAttribute(b,c))))}\nfunction wb(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction xb(a){var b=wb(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function yb(a){a._valueTracker||(a._valueTracker=xb(a))}function zb(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=wb(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Ab(a,b){var c=b.checked;return n({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}\nfunction Bb(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=ub(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function Cb(a,b){b=b.checked;null!=b&&vb(a,\"checked\",b,!1)}\nfunction Eb(a,b){Cb(a,b);var c=ub(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?Fb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&Fb(a,b.type,ub(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction Gb(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!a.defaultChecked;a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction Fb(a,b,c){if(\"number\"!==b||a.ownerDocument.activeElement!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}function Hb(a){var b=\"\";aa.Children.forEach(a,function(a){null!=a&&(b+=a)});return b}function Ib(a,b){a=n({children:void 0},b);if(b=Hb(b.children))a.children=b;return a}\nfunction Jb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e<c.length;e++)b[\"$\"+c[e]]=!0;for(c=0;c<a.length;c++)e=b.hasOwnProperty(\"$\"+a[c].value),a[c].selected!==e&&(a[c].selected=e),e&&d&&(a[c].defaultSelected=!0)}else{c=\"\"+ub(c);b=null;for(e=0;e<a.length;e++){if(a[e].value===c){a[e].selected=!0;d&&(a[e].defaultSelected=!0);return}null!==b||a[e].disabled||(b=a[e])}null!==b&&(b.selected=!0)}}\nfunction Kb(a,b){if(null!=b.dangerouslySetInnerHTML)throw Error(u(91));return n({},b,{value:void 0,defaultValue:void 0,children:\"\"+a._wrapperState.initialValue})}function Lb(a,b){var c=b.value;if(null==c){c=b.defaultValue;b=b.children;if(null!=b){if(null!=c)throw Error(u(92));if(Array.isArray(b)){if(!(1>=b.length))throw Error(u(93));b=b[0]}c=b}null==c&&(c=\"\")}a._wrapperState={initialValue:ub(c)}}\nfunction Mb(a,b){var c=ub(b.value),d=ub(b.defaultValue);null!=c&&(c=\"\"+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=\"\"+d)}function Nb(a){var b=a.textContent;b===a._wrapperState.initialValue&&\"\"!==b&&null!==b&&(a.value=b)}var Ob={html:\"http://www.w3.org/1999/xhtml\",mathml:\"http://www.w3.org/1998/Math/MathML\",svg:\"http://www.w3.org/2000/svg\"};\nfunction Pb(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}function Qb(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?Pb(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}\nvar Rb,Sb=function(a){return\"undefined\"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if(a.namespaceURI!==Ob.svg||\"innerHTML\"in a)a.innerHTML=b;else{Rb=Rb||document.createElement(\"div\");Rb.innerHTML=\"<svg>\"+b.valueOf().toString()+\"</svg>\";for(b=Rb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction Tb(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}function Ub(a,b){var c={};c[a.toLowerCase()]=b.toLowerCase();c[\"Webkit\"+a]=\"webkit\"+b;c[\"Moz\"+a]=\"moz\"+b;return c}var Vb={animationend:Ub(\"Animation\",\"AnimationEnd\"),animationiteration:Ub(\"Animation\",\"AnimationIteration\"),animationstart:Ub(\"Animation\",\"AnimationStart\"),transitionend:Ub(\"Transition\",\"TransitionEnd\")},Wb={},Xb={};\nYa&&(Xb=document.createElement(\"div\").style,\"AnimationEvent\"in window||(delete Vb.animationend.animation,delete Vb.animationiteration.animation,delete Vb.animationstart.animation),\"TransitionEvent\"in window||delete Vb.transitionend.transition);function Yb(a){if(Wb[a])return Wb[a];if(!Vb[a])return a;var b=Vb[a],c;for(c in b)if(b.hasOwnProperty(c)&&c in Xb)return Wb[a]=b[c];return a}var Zb=Yb(\"animationend\"),$b=Yb(\"animationiteration\"),ac=Yb(\"animationstart\"),bc=Yb(\"transitionend\"),cc=\"abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange seeked seeking stalled suspend timeupdate volumechange waiting\".split(\" \");\nfunction ec(a){var b=a,c=a;if(a.alternate)for(;b.return;)b=b.return;else{a=b;do b=a,0!==(b.effectTag&1026)&&(c=b.return),a=b.return;while(a)}return 3===b.tag?c:null}function fc(a){if(13===a.tag){var b=a.memoizedState;null===b&&(a=a.alternate,null!==a&&(b=a.memoizedState));if(null!==b)return b.dehydrated}return null}function gc(a){if(ec(a)!==a)throw Error(u(188));}\nfunction hc(a){var b=a.alternate;if(!b){b=ec(a);if(null===b)throw Error(u(188));return b!==a?null:a}for(var c=a,d=b;;){var e=c.return;if(null===e)break;var f=e.alternate;if(null===f){d=e.return;if(null!==d){c=d;continue}break}if(e.child===f.child){for(f=e.child;f;){if(f===c)return gc(e),a;if(f===d)return gc(e),b;f=f.sibling}throw Error(u(188));}if(c.return!==d.return)c=e,d=f;else{for(var g=!1,h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===\nc){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}if(!g)throw Error(u(189));}}if(c.alternate!==d)throw Error(u(190));}if(3!==c.tag)throw Error(u(188));return c.stateNode.current===c?a:b}function ic(a){a=hc(a);if(!a)return null;for(var b=a;;){if(5===b.tag||6===b.tag)return b;if(b.child)b.child.return=b,b=b.child;else{if(b===a)break;for(;!b.sibling;){if(!b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}}return null}\nvar jc,kc,lc,mc=!1,nc=[],oc=null,pc=null,qc=null,rc=new Map,sc=new Map,tc=[],uc=\"mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput close cancel copy cut paste click change contextmenu reset submit\".split(\" \"),vc=\"focus blur dragenter dragleave mouseover mouseout pointerover pointerout gotpointercapture lostpointercapture\".split(\" \");\nfunction wc(a){var b=xc(a);uc.forEach(function(c){yc(c,a,b)});vc.forEach(function(c){yc(c,a,b)})}function zc(a,b,c,d){return{blockedOn:a,topLevelType:b,eventSystemFlags:c|32,nativeEvent:d}}function Ac(a,b){switch(a){case \"focus\":case \"blur\":oc=null;break;case \"dragenter\":case \"dragleave\":pc=null;break;case \"mouseover\":case \"mouseout\":qc=null;break;case \"pointerover\":case \"pointerout\":rc.delete(b.pointerId);break;case \"gotpointercapture\":case \"lostpointercapture\":sc.delete(b.pointerId)}}\nfunction Bc(a,b,c,d,e){if(null===a||a.nativeEvent!==e)return a=zc(b,c,d,e),null!==b&&(b=Cc(b),null!==b&&kc(b)),a;a.eventSystemFlags|=d;return a}function Dc(a,b,c,d){switch(b){case \"focus\":return oc=Bc(oc,a,b,c,d),!0;case \"dragenter\":return pc=Bc(pc,a,b,c,d),!0;case \"mouseover\":return qc=Bc(qc,a,b,c,d),!0;case \"pointerover\":var e=d.pointerId;rc.set(e,Bc(rc.get(e)||null,a,b,c,d));return!0;case \"gotpointercapture\":return e=d.pointerId,sc.set(e,Bc(sc.get(e)||null,a,b,c,d)),!0}return!1}\nfunction Ec(a){var b=Fc(a.target);if(null!==b){var c=ec(b);if(null!==c)if(b=c.tag,13===b){if(b=fc(c),null!==b){a.blockedOn=b;q.unstable_runWithPriority(a.priority,function(){lc(c)});return}}else if(3===b&&c.stateNode.hydrate){a.blockedOn=3===c.tag?c.stateNode.containerInfo:null;return}}a.blockedOn=null}function Gc(a){if(null!==a.blockedOn)return!1;var b=Hc(a.topLevelType,a.eventSystemFlags,a.nativeEvent);if(null!==b){var c=Cc(b);null!==c&&kc(c);a.blockedOn=b;return!1}return!0}\nfunction Ic(a,b,c){Gc(a)&&c.delete(b)}function Jc(){for(mc=!1;0<nc.length;){var a=nc[0];if(null!==a.blockedOn){a=Cc(a.blockedOn);null!==a&&jc(a);break}var b=Hc(a.topLevelType,a.eventSystemFlags,a.nativeEvent);null!==b?a.blockedOn=b:nc.shift()}null!==oc&&Gc(oc)&&(oc=null);null!==pc&&Gc(pc)&&(pc=null);null!==qc&&Gc(qc)&&(qc=null);rc.forEach(Ic);sc.forEach(Ic)}function Kc(a,b){a.blockedOn===b&&(a.blockedOn=null,mc||(mc=!0,q.unstable_scheduleCallback(q.unstable_NormalPriority,Jc)))}\nfunction Lc(a){function b(b){return Kc(b,a)}if(0<nc.length){Kc(nc[0],a);for(var c=1;c<nc.length;c++){var d=nc[c];d.blockedOn===a&&(d.blockedOn=null)}}null!==oc&&Kc(oc,a);null!==pc&&Kc(pc,a);null!==qc&&Kc(qc,a);rc.forEach(b);sc.forEach(b);for(c=0;c<tc.length;c++)d=tc[c],d.blockedOn===a&&(d.blockedOn=null);for(;0<tc.length&&(c=tc[0],null===c.blockedOn);)Ec(c),null===c.blockedOn&&tc.shift()}\nfunction Mc(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}function Nc(a){do a=a.return;while(a&&5!==a.tag);return a?a:null}function Oc(a,b,c){if(b=Da(a,c.dispatchConfig.phasedRegistrationNames[b]))c._dispatchListeners=xa(c._dispatchListeners,b),c._dispatchInstances=xa(c._dispatchInstances,a)}\nfunction Pc(a){if(a&&a.dispatchConfig.phasedRegistrationNames){for(var b=a._targetInst,c=[];b;)c.push(b),b=Nc(b);for(b=c.length;0<b--;)Oc(c[b],\"captured\",a);for(b=0;b<c.length;b++)Oc(c[b],\"bubbled\",a)}}function Qc(a,b,c){a&&c&&c.dispatchConfig.registrationName&&(b=Da(a,c.dispatchConfig.registrationName))&&(c._dispatchListeners=xa(c._dispatchListeners,b),c._dispatchInstances=xa(c._dispatchInstances,a))}function Rc(a){a&&a.dispatchConfig.registrationName&&Qc(a._targetInst,null,a)}\nfunction Sc(a){ya(a,Pc)}function Tc(){return!0}function Uc(){return!1}function E(a,b,c,d){this.dispatchConfig=a;this._targetInst=b;this.nativeEvent=c;a=this.constructor.Interface;for(var e in a)a.hasOwnProperty(e)&&((b=a[e])?this[e]=b(c):\"target\"===e?this.target=d:this[e]=c[e]);this.isDefaultPrevented=(null!=c.defaultPrevented?c.defaultPrevented:!1===c.returnValue)?Tc:Uc;this.isPropagationStopped=Uc;return this}\nn(E.prototype,{preventDefault:function(){this.defaultPrevented=!0;var a=this.nativeEvent;a&&(a.preventDefault?a.preventDefault():\"unknown\"!==typeof a.returnValue&&(a.returnValue=!1),this.isDefaultPrevented=Tc)},stopPropagation:function(){var a=this.nativeEvent;a&&(a.stopPropagation?a.stopPropagation():\"unknown\"!==typeof a.cancelBubble&&(a.cancelBubble=!0),this.isPropagationStopped=Tc)},persist:function(){this.isPersistent=Tc},isPersistent:Uc,destructor:function(){var a=this.constructor.Interface,\nb;for(b in a)this[b]=null;this.nativeEvent=this._targetInst=this.dispatchConfig=null;this.isPropagationStopped=this.isDefaultPrevented=Uc;this._dispatchInstances=this._dispatchListeners=null}});E.Interface={type:null,target:null,currentTarget:function(){return null},eventPhase:null,bubbles:null,cancelable:null,timeStamp:function(a){return a.timeStamp||Date.now()},defaultPrevented:null,isTrusted:null};\nE.extend=function(a){function b(){}function c(){return d.apply(this,arguments)}var d=this;b.prototype=d.prototype;var e=new b;n(e,c.prototype);c.prototype=e;c.prototype.constructor=c;c.Interface=n({},d.Interface,a);c.extend=d.extend;Vc(c);return c};Vc(E);function Wc(a,b,c,d){if(this.eventPool.length){var e=this.eventPool.pop();this.call(e,a,b,c,d);return e}return new this(a,b,c,d)}\nfunction Xc(a){if(!(a instanceof this))throw Error(u(279));a.destructor();10>this.eventPool.length&&this.eventPool.push(a)}function Vc(a){a.eventPool=[];a.getPooled=Wc;a.release=Xc}var Yc=E.extend({animationName:null,elapsedTime:null,pseudoElement:null}),Zc=E.extend({clipboardData:function(a){return\"clipboardData\"in a?a.clipboardData:window.clipboardData}}),$c=E.extend({view:null,detail:null}),ad=$c.extend({relatedTarget:null});\nfunction bd(a){var b=a.keyCode;\"charCode\"in a?(a=a.charCode,0===a&&13===b&&(a=13)):a=b;10===a&&(a=13);return 32<=a||13===a?a:0}\nvar cd={Esc:\"Escape\",Spacebar:\" \",Left:\"ArrowLeft\",Up:\"ArrowUp\",Right:\"ArrowRight\",Down:\"ArrowDown\",Del:\"Delete\",Win:\"OS\",Menu:\"ContextMenu\",Apps:\"ContextMenu\",Scroll:\"ScrollLock\",MozPrintableKey:\"Unidentified\"},dd={8:\"Backspace\",9:\"Tab\",12:\"Clear\",13:\"Enter\",16:\"Shift\",17:\"Control\",18:\"Alt\",19:\"Pause\",20:\"CapsLock\",27:\"Escape\",32:\" \",33:\"PageUp\",34:\"PageDown\",35:\"End\",36:\"Home\",37:\"ArrowLeft\",38:\"ArrowUp\",39:\"ArrowRight\",40:\"ArrowDown\",45:\"Insert\",46:\"Delete\",112:\"F1\",113:\"F2\",114:\"F3\",115:\"F4\",\n116:\"F5\",117:\"F6\",118:\"F7\",119:\"F8\",120:\"F9\",121:\"F10\",122:\"F11\",123:\"F12\",144:\"NumLock\",145:\"ScrollLock\",224:\"Meta\"},ed={Alt:\"altKey\",Control:\"ctrlKey\",Meta:\"metaKey\",Shift:\"shiftKey\"};function gd(a){var b=this.nativeEvent;return b.getModifierState?b.getModifierState(a):(a=ed[a])?!!b[a]:!1}function hd(){return gd}\nvar id=$c.extend({key:function(a){if(a.key){var b=cd[a.key]||a.key;if(\"Unidentified\"!==b)return b}return\"keypress\"===a.type?(a=bd(a),13===a?\"Enter\":String.fromCharCode(a)):\"keydown\"===a.type||\"keyup\"===a.type?dd[a.keyCode]||\"Unidentified\":\"\"},location:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,repeat:null,locale:null,getModifierState:hd,charCode:function(a){return\"keypress\"===a.type?bd(a):0},keyCode:function(a){return\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0},which:function(a){return\"keypress\"===\na.type?bd(a):\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0}}),jd=0,kd=0,ld=!1,md=!1,nd=$c.extend({screenX:null,screenY:null,clientX:null,clientY:null,pageX:null,pageY:null,ctrlKey:null,shiftKey:null,altKey:null,metaKey:null,getModifierState:hd,button:null,buttons:null,relatedTarget:function(a){return a.relatedTarget||(a.fromElement===a.srcElement?a.toElement:a.fromElement)},movementX:function(a){if(\"movementX\"in a)return a.movementX;var b=jd;jd=a.screenX;return ld?\"mousemove\"===a.type?a.screenX-\nb:0:(ld=!0,0)},movementY:function(a){if(\"movementY\"in a)return a.movementY;var b=kd;kd=a.screenY;return md?\"mousemove\"===a.type?a.screenY-b:0:(md=!0,0)}}),od=nd.extend({pointerId:null,width:null,height:null,pressure:null,tangentialPressure:null,tiltX:null,tiltY:null,twist:null,pointerType:null,isPrimary:null}),pd=nd.extend({dataTransfer:null}),qd=$c.extend({touches:null,targetTouches:null,changedTouches:null,altKey:null,metaKey:null,ctrlKey:null,shiftKey:null,getModifierState:hd}),rd=E.extend({propertyName:null,\nelapsedTime:null,pseudoElement:null}),sd=nd.extend({deltaX:function(a){return\"deltaX\"in a?a.deltaX:\"wheelDeltaX\"in a?-a.wheelDeltaX:0},deltaY:function(a){return\"deltaY\"in a?a.deltaY:\"wheelDeltaY\"in a?-a.wheelDeltaY:\"wheelDelta\"in a?-a.wheelDelta:0},deltaZ:null,deltaMode:null}),td=[[\"blur\",\"blur\",0],[\"cancel\",\"cancel\",0],[\"click\",\"click\",0],[\"close\",\"close\",0],[\"contextmenu\",\"contextMenu\",0],[\"copy\",\"copy\",0],[\"cut\",\"cut\",0],[\"auxclick\",\"auxClick\",0],[\"dblclick\",\"doubleClick\",0],[\"dragend\",\"dragEnd\",\n0],[\"dragstart\",\"dragStart\",0],[\"drop\",\"drop\",0],[\"focus\",\"focus\",0],[\"input\",\"input\",0],[\"invalid\",\"invalid\",0],[\"keydown\",\"keyDown\",0],[\"keypress\",\"keyPress\",0],[\"keyup\",\"keyUp\",0],[\"mousedown\",\"mouseDown\",0],[\"mouseup\",\"mouseUp\",0],[\"paste\",\"paste\",0],[\"pause\",\"pause\",0],[\"play\",\"play\",0],[\"pointercancel\",\"pointerCancel\",0],[\"pointerdown\",\"pointerDown\",0],[\"pointerup\",\"pointerUp\",0],[\"ratechange\",\"rateChange\",0],[\"reset\",\"reset\",0],[\"seeked\",\"seeked\",0],[\"submit\",\"submit\",0],[\"touchcancel\",\"touchCancel\",\n0],[\"touchend\",\"touchEnd\",0],[\"touchstart\",\"touchStart\",0],[\"volumechange\",\"volumeChange\",0],[\"drag\",\"drag\",1],[\"dragenter\",\"dragEnter\",1],[\"dragexit\",\"dragExit\",1],[\"dragleave\",\"dragLeave\",1],[\"dragover\",\"dragOver\",1],[\"mousemove\",\"mouseMove\",1],[\"mouseout\",\"mouseOut\",1],[\"mouseover\",\"mouseOver\",1],[\"pointermove\",\"pointerMove\",1],[\"pointerout\",\"pointerOut\",1],[\"pointerover\",\"pointerOver\",1],[\"scroll\",\"scroll\",1],[\"toggle\",\"toggle\",1],[\"touchmove\",\"touchMove\",1],[\"wheel\",\"wheel\",1],[\"abort\",\"abort\",\n2],[Zb,\"animationEnd\",2],[$b,\"animationIteration\",2],[ac,\"animationStart\",2],[\"canplay\",\"canPlay\",2],[\"canplaythrough\",\"canPlayThrough\",2],[\"durationchange\",\"durationChange\",2],[\"emptied\",\"emptied\",2],[\"encrypted\",\"encrypted\",2],[\"ended\",\"ended\",2],[\"error\",\"error\",2],[\"gotpointercapture\",\"gotPointerCapture\",2],[\"load\",\"load\",2],[\"loadeddata\",\"loadedData\",2],[\"loadedmetadata\",\"loadedMetadata\",2],[\"loadstart\",\"loadStart\",2],[\"lostpointercapture\",\"lostPointerCapture\",2],[\"playing\",\"playing\",2],[\"progress\",\n\"progress\",2],[\"seeking\",\"seeking\",2],[\"stalled\",\"stalled\",2],[\"suspend\",\"suspend\",2],[\"timeupdate\",\"timeUpdate\",2],[bc,\"transitionEnd\",2],[\"waiting\",\"waiting\",2]],ud={},vd={},wd=0;for(;wd<td.length;wd++){var yd=td[wd],zd=yd[0],Ad=yd[1],Bd=yd[2],Cd=\"on\"+(Ad[0].toUpperCase()+Ad.slice(1)),Dd={phasedRegistrationNames:{bubbled:Cd,captured:Cd+\"Capture\"},dependencies:[zd],eventPriority:Bd};ud[Ad]=Dd;vd[zd]=Dd}\nvar Ed={eventTypes:ud,getEventPriority:function(a){a=vd[a];return void 0!==a?a.eventPriority:2},extractEvents:function(a,b,c,d){var e=vd[a];if(!e)return null;switch(a){case \"keypress\":if(0===bd(c))return null;case \"keydown\":case \"keyup\":a=id;break;case \"blur\":case \"focus\":a=ad;break;case \"click\":if(2===c.button)return null;case \"auxclick\":case \"dblclick\":case \"mousedown\":case \"mousemove\":case \"mouseup\":case \"mouseout\":case \"mouseover\":case \"contextmenu\":a=nd;break;case \"drag\":case \"dragend\":case \"dragenter\":case \"dragexit\":case \"dragleave\":case \"dragover\":case \"dragstart\":case \"drop\":a=\npd;break;case \"touchcancel\":case \"touchend\":case \"touchmove\":case \"touchstart\":a=qd;break;case Zb:case $b:case ac:a=Yc;break;case bc:a=rd;break;case \"scroll\":a=$c;break;case \"wheel\":a=sd;break;case \"copy\":case \"cut\":case \"paste\":a=Zc;break;case \"gotpointercapture\":case \"lostpointercapture\":case \"pointercancel\":case \"pointerdown\":case \"pointermove\":case \"pointerout\":case \"pointerover\":case \"pointerup\":a=od;break;default:a=E}b=a.getPooled(e,b,c,d);Sc(b);return b}},Fd=q.unstable_UserBlockingPriority,\nGd=q.unstable_runWithPriority,Hd=Ed.getEventPriority,Id=10,Jd=[];\nfunction Kd(a){var b=a.targetInst,c=b;do{if(!c){a.ancestors.push(c);break}var d=c;if(3===d.tag)d=d.stateNode.containerInfo;else{for(;d.return;)d=d.return;d=3!==d.tag?null:d.stateNode.containerInfo}if(!d)break;b=c.tag;5!==b&&6!==b||a.ancestors.push(c);c=Fc(d)}while(c);for(c=0;c<a.ancestors.length;c++){b=a.ancestors[c];var e=Mc(a.nativeEvent);d=a.topLevelType;for(var f=a.nativeEvent,g=a.eventSystemFlags,h=null,k=0;k<ea.length;k++){var l=ea[k];l&&(l=l.extractEvents(d,b,f,e,g))&&(h=xa(h,l))}Ba(h)}}\nvar Ld=!0;function F(a,b){Md(b,a,!1)}function Md(a,b,c){switch(Hd(b)){case 0:var d=Nd.bind(null,b,1);break;case 1:d=Od.bind(null,b,1);break;default:d=Pd.bind(null,b,1)}c?a.addEventListener(b,d,!0):a.addEventListener(b,d,!1)}function Nd(a,b,c){ib||gb();var d=Pd,e=ib;ib=!0;try{fb(d,a,b,c)}finally{(ib=e)||kb()}}function Od(a,b,c){Gd(Fd,Pd.bind(null,a,b,c))}\nfunction Qd(a,b,c,d){if(Jd.length){var e=Jd.pop();e.topLevelType=a;e.eventSystemFlags=b;e.nativeEvent=c;e.targetInst=d;a=e}else a={topLevelType:a,eventSystemFlags:b,nativeEvent:c,targetInst:d,ancestors:[]};try{if(b=Kd,c=a,jb)b(c,void 0);else{jb=!0;try{hb(b,c,void 0)}finally{jb=!1,kb()}}}finally{a.topLevelType=null,a.nativeEvent=null,a.targetInst=null,a.ancestors.length=0,Jd.length<Id&&Jd.push(a)}}\nfunction Pd(a,b,c){if(Ld)if(0<nc.length&&-1<uc.indexOf(a))a=zc(null,a,b,c),nc.push(a);else{var d=Hc(a,b,c);null===d?Ac(a,c):-1<uc.indexOf(a)?(a=zc(d,a,b,c),nc.push(a)):Dc(d,a,b,c)||(Ac(a,c),Qd(a,b,c,null))}}function Hc(a,b,c){var d=Mc(c);d=Fc(d);if(null!==d){var e=ec(d);if(null===e)d=null;else{var f=e.tag;if(13===f){d=fc(e);if(null!==d)return d;d=null}else if(3===f){if(e.stateNode.hydrate)return 3===e.tag?e.stateNode.containerInfo:null;d=null}else e!==d&&(d=null)}}Qd(a,b,c,d);return null}\nfunction Rd(a){if(!Ya)return!1;a=\"on\"+a;var b=a in document;b||(b=document.createElement(\"div\"),b.setAttribute(a,\"return;\"),b=\"function\"===typeof b[a]);return b}var Sd=new (\"function\"===typeof WeakMap?WeakMap:Map);function xc(a){var b=Sd.get(a);void 0===b&&(b=new Set,Sd.set(a,b));return b}\nfunction yc(a,b,c){if(!c.has(a)){switch(a){case \"scroll\":Md(b,\"scroll\",!0);break;case \"focus\":case \"blur\":Md(b,\"focus\",!0);Md(b,\"blur\",!0);c.add(\"blur\");c.add(\"focus\");break;case \"cancel\":case \"close\":Rd(a)&&Md(b,a,!0);break;case \"invalid\":case \"submit\":case \"reset\":break;default:-1===cc.indexOf(a)&&F(a,b)}c.add(a)}}\nvar Td={animationIterationCount:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,\nfloodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},Ud=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(Td).forEach(function(a){Ud.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);Td[b]=Td[a]})});function Vd(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||Td.hasOwnProperty(a)&&Td[a]?(\"\"+b).trim():b+\"px\"}\nfunction Wd(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=Vd(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var Xd=n({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction Yd(a,b){if(b){if(Xd[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(u(137,a,\"\"));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(u(60));if(!(\"object\"===typeof b.dangerouslySetInnerHTML&&\"__html\"in b.dangerouslySetInnerHTML))throw Error(u(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(u(62,\"\"));}}\nfunction Zd(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}function $d(a,b){a=9===a.nodeType||11===a.nodeType?a:a.ownerDocument;var c=xc(a);b=ja[b];for(var d=0;d<b.length;d++)yc(b[d],a,c)}function ae(){}\nfunction be(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}function ce(a){for(;a&&a.firstChild;)a=a.firstChild;return a}function de(a,b){var c=ce(a);a=0;for(var d;c;){if(3===c.nodeType){d=a+c.textContent.length;if(a<=b&&d>=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=ce(c)}}\nfunction ee(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?ee(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}function fe(){for(var a=window,b=be();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=be(a.document)}return b}\nfunction ge(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}var he=\"$\",ie=\"/$\",je=\"$?\",ke=\"$!\",le=null,me=null;function ne(a,b){switch(a){case \"button\":case \"input\":case \"select\":case \"textarea\":return!!b.autoFocus}return!1}\nfunction oe(a,b){return\"textarea\"===a||\"option\"===a||\"noscript\"===a||\"string\"===typeof b.children||\"number\"===typeof b.children||\"object\"===typeof b.dangerouslySetInnerHTML&&null!==b.dangerouslySetInnerHTML&&null!=b.dangerouslySetInnerHTML.__html}var pe=\"function\"===typeof setTimeout?setTimeout:void 0,qe=\"function\"===typeof clearTimeout?clearTimeout:void 0;function re(a){for(;null!=a;a=a.nextSibling){var b=a.nodeType;if(1===b||3===b)break}return a}\nfunction se(a){a=a.previousSibling;for(var b=0;a;){if(8===a.nodeType){var c=a.data;if(c===he||c===ke||c===je){if(0===b)return a;b--}else c===ie&&b++}a=a.previousSibling}return null}var te=Math.random().toString(36).slice(2),ue=\"__reactInternalInstance$\"+te,ve=\"__reactEventHandlers$\"+te,we=\"__reactContainere$\"+te;\nfunction Fc(a){var b=a[ue];if(b)return b;for(var c=a.parentNode;c;){if(b=c[we]||c[ue]){c=b.alternate;if(null!==b.child||null!==c&&null!==c.child)for(a=se(a);null!==a;){if(c=a[ue])return c;a=se(a)}return b}a=c;c=a.parentNode}return null}function Cc(a){a=a[ue]||a[we];return!a||5!==a.tag&&6!==a.tag&&13!==a.tag&&3!==a.tag?null:a}function xe(a){if(5===a.tag||6===a.tag)return a.stateNode;throw Error(u(33));}function ye(a){return a[ve]||null}var ze=null,Ae=null,Be=null;\nfunction Ce(){if(Be)return Be;var a,b=Ae,c=b.length,d,e=\"value\"in ze?ze.value:ze.textContent,f=e.length;for(a=0;a<c&&b[a]===e[a];a++);var g=c-a;for(d=1;d<=g&&b[c-d]===e[f-d];d++);return Be=e.slice(a,1<d?1-d:void 0)}var De=E.extend({data:null}),Ee=E.extend({data:null}),Fe=[9,13,27,32],Ge=Ya&&\"CompositionEvent\"in window,He=null;Ya&&\"documentMode\"in document&&(He=document.documentMode);\nvar Ie=Ya&&\"TextEvent\"in window&&!He,Je=Ya&&(!Ge||He&&8<He&&11>=He),Ke=String.fromCharCode(32),Le={beforeInput:{phasedRegistrationNames:{bubbled:\"onBeforeInput\",captured:\"onBeforeInputCapture\"},dependencies:[\"compositionend\",\"keypress\",\"textInput\",\"paste\"]},compositionEnd:{phasedRegistrationNames:{bubbled:\"onCompositionEnd\",captured:\"onCompositionEndCapture\"},dependencies:\"blur compositionend keydown keypress keyup mousedown\".split(\" \")},compositionStart:{phasedRegistrationNames:{bubbled:\"onCompositionStart\",\ncaptured:\"onCompositionStartCapture\"},dependencies:\"blur compositionstart keydown keypress keyup mousedown\".split(\" \")},compositionUpdate:{phasedRegistrationNames:{bubbled:\"onCompositionUpdate\",captured:\"onCompositionUpdateCapture\"},dependencies:\"blur compositionupdate keydown keypress keyup mousedown\".split(\" \")}},Me=!1;\nfunction Ne(a,b){switch(a){case \"keyup\":return-1!==Fe.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"blur\":return!0;default:return!1}}function Oe(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var Pe=!1;function Qe(a,b){switch(a){case \"compositionend\":return Oe(b);case \"keypress\":if(32!==b.which)return null;Me=!0;return Ke;case \"textInput\":return a=b.data,a===Ke&&Me?null:a;default:return null}}\nfunction Re(a,b){if(Pe)return\"compositionend\"===a||!Ge&&Ne(a,b)?(a=Ce(),Be=Ae=ze=null,Pe=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1<b.char.length)return b.char;if(b.which)return String.fromCharCode(b.which)}return null;case \"compositionend\":return Je&&\"ko\"!==b.locale?null:b.data;default:return null}}\nvar Se={eventTypes:Le,extractEvents:function(a,b,c,d){var e;if(Ge)b:{switch(a){case \"compositionstart\":var f=Le.compositionStart;break b;case \"compositionend\":f=Le.compositionEnd;break b;case \"compositionupdate\":f=Le.compositionUpdate;break b}f=void 0}else Pe?Ne(a,c)&&(f=Le.compositionEnd):\"keydown\"===a&&229===c.keyCode&&(f=Le.compositionStart);f?(Je&&\"ko\"!==c.locale&&(Pe||f!==Le.compositionStart?f===Le.compositionEnd&&Pe&&(e=Ce()):(ze=d,Ae=\"value\"in ze?ze.value:ze.textContent,Pe=!0)),f=De.getPooled(f,\nb,c,d),e?f.data=e:(e=Oe(c),null!==e&&(f.data=e)),Sc(f),e=f):e=null;(a=Ie?Qe(a,c):Re(a,c))?(b=Ee.getPooled(Le.beforeInput,b,c,d),b.data=a,Sc(b)):b=null;return null===e?b:null===b?e:[e,b]}},Te={color:!0,date:!0,datetime:!0,\"datetime-local\":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function Ue(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return\"input\"===b?!!Te[a.type]:\"textarea\"===b?!0:!1}\nvar Ve={change:{phasedRegistrationNames:{bubbled:\"onChange\",captured:\"onChangeCapture\"},dependencies:\"blur change click focus input keydown keyup selectionchange\".split(\" \")}};function We(a,b,c){a=E.getPooled(Ve.change,a,b,c);a.type=\"change\";cb(c);Sc(a);return a}var Xe=null,Ye=null;function Ze(a){Ba(a)}function $e(a){var b=xe(a);if(zb(b))return a}function af(a,b){if(\"change\"===a)return b}var bf=!1;Ya&&(bf=Rd(\"input\")&&(!document.documentMode||9<document.documentMode));\nfunction cf(){Xe&&(Xe.detachEvent(\"onpropertychange\",df),Ye=Xe=null)}function df(a){if(\"value\"===a.propertyName&&$e(Ye))if(a=We(Ye,a,Mc(a)),ib)Ba(a);else{ib=!0;try{eb(Ze,a)}finally{ib=!1,kb()}}}function ef(a,b,c){\"focus\"===a?(cf(),Xe=b,Ye=c,Xe.attachEvent(\"onpropertychange\",df)):\"blur\"===a&&cf()}function ff(a){if(\"selectionchange\"===a||\"keyup\"===a||\"keydown\"===a)return $e(Ye)}function gf(a,b){if(\"click\"===a)return $e(b)}function hf(a,b){if(\"input\"===a||\"change\"===a)return $e(b)}\nvar jf={eventTypes:Ve,_isInputEventSupported:bf,extractEvents:function(a,b,c,d){var e=b?xe(b):window,f=e.nodeName&&e.nodeName.toLowerCase();if(\"select\"===f||\"input\"===f&&\"file\"===e.type)var g=af;else if(Ue(e))if(bf)g=hf;else{g=ff;var h=ef}else(f=e.nodeName)&&\"input\"===f.toLowerCase()&&(\"checkbox\"===e.type||\"radio\"===e.type)&&(g=gf);if(g&&(g=g(a,b)))return We(g,c,d);h&&h(a,e,b);\"blur\"===a&&(a=e._wrapperState)&&a.controlled&&\"number\"===e.type&&Fb(e,\"number\",e.value)}},kf={mouseEnter:{registrationName:\"onMouseEnter\",\ndependencies:[\"mouseout\",\"mouseover\"]},mouseLeave:{registrationName:\"onMouseLeave\",dependencies:[\"mouseout\",\"mouseover\"]},pointerEnter:{registrationName:\"onPointerEnter\",dependencies:[\"pointerout\",\"pointerover\"]},pointerLeave:{registrationName:\"onPointerLeave\",dependencies:[\"pointerout\",\"pointerover\"]}},lf,mf={eventTypes:kf,extractEvents:function(a,b,c,d,e){var f=\"mouseover\"===a||\"pointerover\"===a,g=\"mouseout\"===a||\"pointerout\"===a;if(f&&0===(e&32)&&(c.relatedTarget||c.fromElement)||!g&&!f)return null;\ne=d.window===d?d:(e=d.ownerDocument)?e.defaultView||e.parentWindow:window;if(g){if(g=b,b=(b=c.relatedTarget||c.toElement)?Fc(b):null,null!==b&&(f=ec(b),b!==f||5!==b.tag&&6!==b.tag))b=null}else g=null;if(g===b)return null;if(\"mouseout\"===a||\"mouseover\"===a){var h=nd;var k=kf.mouseLeave;var l=kf.mouseEnter;var m=\"mouse\"}else if(\"pointerout\"===a||\"pointerover\"===a)h=od,k=kf.pointerLeave,l=kf.pointerEnter,m=\"pointer\";a=null==g?e:xe(g);e=null==b?e:xe(b);k=h.getPooled(k,g,c,d);k.type=m+\"leave\";k.target=\na;k.relatedTarget=e;d=h.getPooled(l,b,c,d);d.type=m+\"enter\";d.target=e;d.relatedTarget=a;h=g;m=b;if(h&&m)a:{l=h;a=m;g=0;for(b=l;b;b=Nc(b))g++;b=0;for(e=a;e;e=Nc(e))b++;for(;0<g-b;)l=Nc(l),g--;for(;0<b-g;)a=Nc(a),b--;for(;g--;){if(l===a||l===a.alternate)break a;l=Nc(l);a=Nc(a)}l=null}else l=null;a=l;for(l=[];h&&h!==a;){g=h.alternate;if(null!==g&&g===a)break;l.push(h);h=Nc(h)}for(h=[];m&&m!==a;){g=m.alternate;if(null!==g&&g===a)break;h.push(m);m=Nc(m)}for(m=0;m<l.length;m++)Qc(l[m],\"bubbled\",k);for(m=\nh.length;0<m--;)Qc(h[m],\"captured\",d);if(c===lf)return lf=null,[k];lf=c;return[k,d]}};function nf(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var of=\"function\"===typeof Object.is?Object.is:nf,pf=Object.prototype.hasOwnProperty;function qf(a,b){if(of(a,b))return!0;if(\"object\"!==typeof a||null===a||\"object\"!==typeof b||null===b)return!1;var c=Object.keys(a),d=Object.keys(b);if(c.length!==d.length)return!1;for(d=0;d<c.length;d++)if(!pf.call(b,c[d])||!of(a[c[d]],b[c[d]]))return!1;return!0}\nvar rf=Ya&&\"documentMode\"in document&&11>=document.documentMode,sf={select:{phasedRegistrationNames:{bubbled:\"onSelect\",captured:\"onSelectCapture\"},dependencies:\"blur contextmenu dragend focus keydown keyup mousedown mouseup selectionchange\".split(\" \")}},tf=null,uf=null,vf=null,wf=!1;\nfunction xf(a,b){var c=b.window===b?b.document:9===b.nodeType?b:b.ownerDocument;if(wf||null==tf||tf!==be(c))return null;c=tf;\"selectionStart\"in c&&ge(c)?c={start:c.selectionStart,end:c.selectionEnd}:(c=(c.ownerDocument&&c.ownerDocument.defaultView||window).getSelection(),c={anchorNode:c.anchorNode,anchorOffset:c.anchorOffset,focusNode:c.focusNode,focusOffset:c.focusOffset});return vf&&qf(vf,c)?null:(vf=c,a=E.getPooled(sf.select,uf,a,b),a.type=\"select\",a.target=tf,Sc(a),a)}\nvar yf={eventTypes:sf,extractEvents:function(a,b,c,d){var e=d.window===d?d.document:9===d.nodeType?d:d.ownerDocument,f;if(!(f=!e)){a:{e=xc(e);f=ja.onSelect;for(var g=0;g<f.length;g++)if(!e.has(f[g])){e=!1;break a}e=!0}f=!e}if(f)return null;e=b?xe(b):window;switch(a){case \"focus\":if(Ue(e)||\"true\"===e.contentEditable)tf=e,uf=b,vf=null;break;case \"blur\":vf=uf=tf=null;break;case \"mousedown\":wf=!0;break;case \"contextmenu\":case \"mouseup\":case \"dragend\":return wf=!1,xf(c,d);case \"selectionchange\":if(rf)break;\ncase \"keydown\":case \"keyup\":return xf(c,d)}return null}};Ca.injectEventPluginOrder(\"ResponderEventPlugin SimpleEventPlugin EnterLeaveEventPlugin ChangeEventPlugin SelectEventPlugin BeforeInputEventPlugin\".split(\" \"));var zf=Cc;sa=ye;ua=zf;va=xe;Ca.injectEventPluginsByName({SimpleEventPlugin:Ed,EnterLeaveEventPlugin:mf,ChangeEventPlugin:jf,SelectEventPlugin:yf,BeforeInputEventPlugin:Se});new Set;var Af=[],Bf=-1;function G(a){0>Bf||(a.current=Af[Bf],Af[Bf]=null,Bf--)}\nfunction I(a,b){Bf++;Af[Bf]=a.current;a.current=b}var Cf={},J={current:Cf},K={current:!1},Df=Cf;function Ef(a,b){var c=a.type.contextTypes;if(!c)return Cf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}function L(a){a=a.childContextTypes;return null!==a&&void 0!==a}\nfunction Ff(a){G(K,a);G(J,a)}function Gf(a){G(K,a);G(J,a)}function Hf(a,b,c){if(J.current!==Cf)throw Error(u(168));I(J,b,a);I(K,c,a)}function If(a,b,c){var d=a.stateNode;a=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in a))throw Error(u(108,Wa(b)||\"Unknown\",e));return n({},c,{},d)}function Jf(a){var b=a.stateNode;b=b&&b.__reactInternalMemoizedMergedChildContext||Cf;Df=J.current;I(J,b,a);I(K,K.current,a);return!0}\nfunction Kf(a,b,c){var d=a.stateNode;if(!d)throw Error(u(169));c?(b=If(a,b,Df),d.__reactInternalMemoizedMergedChildContext=b,G(K,a),G(J,a),I(J,b,a)):G(K,a);I(K,c,a)}\nvar Lf=q.unstable_runWithPriority,Mf=q.unstable_scheduleCallback,Nf=q.unstable_cancelCallback,Of=q.unstable_shouldYield,Pf=q.unstable_requestPaint,Qf=q.unstable_now,Rf=q.unstable_getCurrentPriorityLevel,Sf=q.unstable_ImmediatePriority,Tf=q.unstable_UserBlockingPriority,Uf=q.unstable_NormalPriority,Vf=q.unstable_LowPriority,Wf=q.unstable_IdlePriority,Xf={},Yf=void 0!==Pf?Pf:function(){},Zf=null,$f=null,ag=!1,bg=Qf(),cg=1E4>bg?Qf:function(){return Qf()-bg};\nfunction dg(){switch(Rf()){case Sf:return 99;case Tf:return 98;case Uf:return 97;case Vf:return 96;case Wf:return 95;default:throw Error(u(332));}}function eg(a){switch(a){case 99:return Sf;case 98:return Tf;case 97:return Uf;case 96:return Vf;case 95:return Wf;default:throw Error(u(332));}}function fg(a,b){a=eg(a);return Lf(a,b)}function gg(a,b,c){a=eg(a);return Mf(a,b,c)}function hg(a){null===Zf?(Zf=[a],$f=Mf(Sf,ig)):Zf.push(a);return Xf}function jg(){if(null!==$f){var a=$f;$f=null;Nf(a)}ig()}\nfunction ig(){if(!ag&&null!==Zf){ag=!0;var a=0;try{var b=Zf;fg(99,function(){for(;a<b.length;a++){var c=b[a];do c=c(!0);while(null!==c)}});Zf=null}catch(c){throw null!==Zf&&(Zf=Zf.slice(a+1)),Mf(Sf,jg),c;}finally{ag=!1}}}var kg=3;function lg(a,b,c){c/=10;return 1073741821-(((1073741821-a+b/10)/c|0)+1)*c}function mg(a,b){if(a&&a.defaultProps){b=n({},b);a=a.defaultProps;for(var c in a)void 0===b[c]&&(b[c]=a[c])}return b}var ng={current:null},og=null,pg=null,qg=null;function rg(){qg=pg=og=null}\nfunction sg(a,b){var c=a.type._context;I(ng,c._currentValue,a);c._currentValue=b}function tg(a){var b=ng.current;G(ng,a);a.type._context._currentValue=b}function ug(a,b){for(;null!==a;){var c=a.alternate;if(a.childExpirationTime<b)a.childExpirationTime=b,null!==c&&c.childExpirationTime<b&&(c.childExpirationTime=b);else if(null!==c&&c.childExpirationTime<b)c.childExpirationTime=b;else break;a=a.return}}\nfunction vg(a,b){og=a;qg=pg=null;a=a.dependencies;null!==a&&null!==a.firstContext&&(a.expirationTime>=b&&(wg=!0),a.firstContext=null)}function xg(a,b){if(qg!==a&&!1!==b&&0!==b){if(\"number\"!==typeof b||1073741823===b)qg=a,b=1073741823;b={context:a,observedBits:b,next:null};if(null===pg){if(null===og)throw Error(u(308));pg=b;og.dependencies={expirationTime:0,firstContext:b,responders:null}}else pg=pg.next=b}return a._currentValue}var yg=!1;\nfunction zg(a){return{baseState:a,firstUpdate:null,lastUpdate:null,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}function Ag(a){return{baseState:a.baseState,firstUpdate:a.firstUpdate,lastUpdate:a.lastUpdate,firstCapturedUpdate:null,lastCapturedUpdate:null,firstEffect:null,lastEffect:null,firstCapturedEffect:null,lastCapturedEffect:null}}\nfunction Bg(a,b){return{expirationTime:a,suspenseConfig:b,tag:0,payload:null,callback:null,next:null,nextEffect:null}}function Cg(a,b){null===a.lastUpdate?a.firstUpdate=a.lastUpdate=b:(a.lastUpdate.next=b,a.lastUpdate=b)}\nfunction Dg(a,b){var c=a.alternate;if(null===c){var d=a.updateQueue;var e=null;null===d&&(d=a.updateQueue=zg(a.memoizedState))}else d=a.updateQueue,e=c.updateQueue,null===d?null===e?(d=a.updateQueue=zg(a.memoizedState),e=c.updateQueue=zg(c.memoizedState)):d=a.updateQueue=Ag(e):null===e&&(e=c.updateQueue=Ag(d));null===e||d===e?Cg(d,b):null===d.lastUpdate||null===e.lastUpdate?(Cg(d,b),Cg(e,b)):(Cg(d,b),e.lastUpdate=b)}\nfunction Eg(a,b){var c=a.updateQueue;c=null===c?a.updateQueue=zg(a.memoizedState):Fg(a,c);null===c.lastCapturedUpdate?c.firstCapturedUpdate=c.lastCapturedUpdate=b:(c.lastCapturedUpdate.next=b,c.lastCapturedUpdate=b)}function Fg(a,b){var c=a.alternate;null!==c&&b===c.updateQueue&&(b=a.updateQueue=Ag(b));return b}\nfunction Gg(a,b,c,d,e,f){switch(c.tag){case 1:return a=c.payload,\"function\"===typeof a?a.call(f,d,e):a;case 3:a.effectTag=a.effectTag&-4097|64;case 0:a=c.payload;e=\"function\"===typeof a?a.call(f,d,e):a;if(null===e||void 0===e)break;return n({},d,e);case 2:yg=!0}return d}\nfunction Hg(a,b,c,d,e){yg=!1;b=Fg(a,b);for(var f=b.baseState,g=null,h=0,k=b.firstUpdate,l=f;null!==k;){var m=k.expirationTime;m<e?(null===g&&(g=k,f=l),h<m&&(h=m)):(Ig(m,k.suspenseConfig),l=Gg(a,b,k,l,c,d),null!==k.callback&&(a.effectTag|=32,k.nextEffect=null,null===b.lastEffect?b.firstEffect=b.lastEffect=k:(b.lastEffect.nextEffect=k,b.lastEffect=k)));k=k.next}m=null;for(k=b.firstCapturedUpdate;null!==k;){var C=k.expirationTime;C<e?(null===m&&(m=k,null===g&&(f=l)),h<C&&(h=C)):(l=Gg(a,b,k,l,c,d),null!==\nk.callback&&(a.effectTag|=32,k.nextEffect=null,null===b.lastCapturedEffect?b.firstCapturedEffect=b.lastCapturedEffect=k:(b.lastCapturedEffect.nextEffect=k,b.lastCapturedEffect=k)));k=k.next}null===g&&(b.lastUpdate=null);null===m?b.lastCapturedUpdate=null:a.effectTag|=32;null===g&&null===m&&(f=l);b.baseState=f;b.firstUpdate=g;b.firstCapturedUpdate=m;Jg(h);a.expirationTime=h;a.memoizedState=l}\nfunction Kg(a,b,c){null!==b.firstCapturedUpdate&&(null!==b.lastUpdate&&(b.lastUpdate.next=b.firstCapturedUpdate,b.lastUpdate=b.lastCapturedUpdate),b.firstCapturedUpdate=b.lastCapturedUpdate=null);Lg(b.firstEffect,c);b.firstEffect=b.lastEffect=null;Lg(b.firstCapturedEffect,c);b.firstCapturedEffect=b.lastCapturedEffect=null}function Lg(a,b){for(;null!==a;){var c=a.callback;if(null!==c){a.callback=null;var d=b;if(\"function\"!==typeof c)throw Error(u(191,c));c.call(d)}a=a.nextEffect}}\nvar Mg=Ea.ReactCurrentBatchConfig,Ng=(new aa.Component).refs;function Og(a,b,c,d){b=a.memoizedState;c=c(d,b);c=null===c||void 0===c?b:n({},b,c);a.memoizedState=c;d=a.updateQueue;null!==d&&0===a.expirationTime&&(d.baseState=c)}\nvar Sg={isMounted:function(a){return(a=a._reactInternalFiber)?ec(a)===a:!1},enqueueSetState:function(a,b,c){a=a._reactInternalFiber;var d=Pg(),e=Mg.suspense;d=Qg(d,a,e);e=Bg(d,e);e.payload=b;void 0!==c&&null!==c&&(e.callback=c);Dg(a,e);Rg(a,d)},enqueueReplaceState:function(a,b,c){a=a._reactInternalFiber;var d=Pg(),e=Mg.suspense;d=Qg(d,a,e);e=Bg(d,e);e.tag=1;e.payload=b;void 0!==c&&null!==c&&(e.callback=c);Dg(a,e);Rg(a,d)},enqueueForceUpdate:function(a,b){a=a._reactInternalFiber;var c=Pg(),d=Mg.suspense;\nc=Qg(c,a,d);d=Bg(c,d);d.tag=2;void 0!==b&&null!==b&&(d.callback=b);Dg(a,d);Rg(a,c)}};function Tg(a,b,c,d,e,f,g){a=a.stateNode;return\"function\"===typeof a.shouldComponentUpdate?a.shouldComponentUpdate(d,f,g):b.prototype&&b.prototype.isPureReactComponent?!qf(c,d)||!qf(e,f):!0}\nfunction Ug(a,b,c){var d=!1,e=Cf;var f=b.contextType;\"object\"===typeof f&&null!==f?f=xg(f):(e=L(b)?Df:J.current,d=b.contextTypes,f=(d=null!==d&&void 0!==d)?Ef(a,e):Cf);b=new b(c,f);a.memoizedState=null!==b.state&&void 0!==b.state?b.state:null;b.updater=Sg;a.stateNode=b;b._reactInternalFiber=a;d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=e,a.__reactInternalMemoizedMaskedChildContext=f);return b}\nfunction Vg(a,b,c,d){a=b.state;\"function\"===typeof b.componentWillReceiveProps&&b.componentWillReceiveProps(c,d);\"function\"===typeof b.UNSAFE_componentWillReceiveProps&&b.UNSAFE_componentWillReceiveProps(c,d);b.state!==a&&Sg.enqueueReplaceState(b,b.state,null)}\nfunction Wg(a,b,c,d){var e=a.stateNode;e.props=c;e.state=a.memoizedState;e.refs=Ng;var f=b.contextType;\"object\"===typeof f&&null!==f?e.context=xg(f):(f=L(b)?Df:J.current,e.context=Ef(a,f));f=a.updateQueue;null!==f&&(Hg(a,f,c,e,d),e.state=a.memoizedState);f=b.getDerivedStateFromProps;\"function\"===typeof f&&(Og(a,b,f,c),e.state=a.memoizedState);\"function\"===typeof b.getDerivedStateFromProps||\"function\"===typeof e.getSnapshotBeforeUpdate||\"function\"!==typeof e.UNSAFE_componentWillMount&&\"function\"!==\ntypeof e.componentWillMount||(b=e.state,\"function\"===typeof e.componentWillMount&&e.componentWillMount(),\"function\"===typeof e.UNSAFE_componentWillMount&&e.UNSAFE_componentWillMount(),b!==e.state&&Sg.enqueueReplaceState(e,e.state,null),f=a.updateQueue,null!==f&&(Hg(a,f,c,e,d),e.state=a.memoizedState));\"function\"===typeof e.componentDidMount&&(a.effectTag|=4)}var Xg=Array.isArray;\nfunction Yg(a,b,c){a=c.ref;if(null!==a&&\"function\"!==typeof a&&\"object\"!==typeof a){if(c._owner){c=c._owner;if(c){if(1!==c.tag)throw Error(u(309));var d=c.stateNode}if(!d)throw Error(u(147,a));var e=\"\"+a;if(null!==b&&null!==b.ref&&\"function\"===typeof b.ref&&b.ref._stringRef===e)return b.ref;b=function(a){var b=d.refs;b===Ng&&(b=d.refs={});null===a?delete b[e]:b[e]=a};b._stringRef=e;return b}if(\"string\"!==typeof a)throw Error(u(284));if(!c._owner)throw Error(u(290,a));}return a}\nfunction Zg(a,b){if(\"textarea\"!==a.type)throw Error(u(31,\"[object Object]\"===Object.prototype.toString.call(b)?\"object with keys {\"+Object.keys(b).join(\", \")+\"}\":b,\"\"));}\nfunction $g(a){function b(b,c){if(a){var d=b.lastEffect;null!==d?(d.nextEffect=c,b.lastEffect=c):b.firstEffect=b.lastEffect=c;c.nextEffect=null;c.effectTag=8}}function c(c,d){if(!a)return null;for(;null!==d;)b(c,d),d=d.sibling;return null}function d(a,b){for(a=new Map;null!==b;)null!==b.key?a.set(b.key,b):a.set(b.index,b),b=b.sibling;return a}function e(a,b,c){a=ah(a,b,c);a.index=0;a.sibling=null;return a}function f(b,c,d){b.index=d;if(!a)return c;d=b.alternate;if(null!==d)return d=d.index,d<c?(b.effectTag=\n2,c):d;b.effectTag=2;return c}function g(b){a&&null===b.alternate&&(b.effectTag=2);return b}function h(a,b,c,d){if(null===b||6!==b.tag)return b=bh(c,a.mode,d),b.return=a,b;b=e(b,c,d);b.return=a;return b}function k(a,b,c,d){if(null!==b&&b.elementType===c.type)return d=e(b,c.props,d),d.ref=Yg(a,b,c),d.return=a,d;d=ch(c.type,c.key,c.props,null,a.mode,d);d.ref=Yg(a,b,c);d.return=a;return d}function l(a,b,c,d){if(null===b||4!==b.tag||b.stateNode.containerInfo!==c.containerInfo||b.stateNode.implementation!==\nc.implementation)return b=dh(c,a.mode,d),b.return=a,b;b=e(b,c.children||[],d);b.return=a;return b}function m(a,b,c,d,f){if(null===b||7!==b.tag)return b=eh(c,a.mode,d,f),b.return=a,b;b=e(b,c,d);b.return=a;return b}function C(a,b,c){if(\"string\"===typeof b||\"number\"===typeof b)return b=bh(\"\"+b,a.mode,c),b.return=a,b;if(\"object\"===typeof b&&null!==b){switch(b.$$typeof){case Ga:return c=ch(b.type,b.key,b.props,null,a.mode,c),c.ref=Yg(a,null,b),c.return=a,c;case Ha:return b=dh(b,a.mode,c),b.return=a,b}if(Xg(b)||\nUa(b))return b=eh(b,a.mode,c,null),b.return=a,b;Zg(a,b)}return null}function y(a,b,c,d){var e=null!==b?b.key:null;if(\"string\"===typeof c||\"number\"===typeof c)return null!==e?null:h(a,b,\"\"+c,d);if(\"object\"===typeof c&&null!==c){switch(c.$$typeof){case Ga:return c.key===e?c.type===Ia?m(a,b,c.props.children,d,e):k(a,b,c,d):null;case Ha:return c.key===e?l(a,b,c,d):null}if(Xg(c)||Ua(c))return null!==e?null:m(a,b,c,d,null);Zg(a,c)}return null}function H(a,b,c,d,e){if(\"string\"===typeof d||\"number\"===typeof d)return a=\na.get(c)||null,h(b,a,\"\"+d,e);if(\"object\"===typeof d&&null!==d){switch(d.$$typeof){case Ga:return a=a.get(null===d.key?c:d.key)||null,d.type===Ia?m(b,a,d.props.children,e,d.key):k(b,a,d,e);case Ha:return a=a.get(null===d.key?c:d.key)||null,l(b,a,d,e)}if(Xg(d)||Ua(d))return a=a.get(c)||null,m(b,a,d,e,null);Zg(b,d)}return null}function z(e,g,h,k){for(var l=null,m=null,r=g,x=g=0,A=null;null!==r&&x<h.length;x++){r.index>x?(A=r,r=null):A=r.sibling;var p=y(e,r,h[x],k);if(null===p){null===r&&(r=A);break}a&&\nr&&null===p.alternate&&b(e,r);g=f(p,g,x);null===m?l=p:m.sibling=p;m=p;r=A}if(x===h.length)return c(e,r),l;if(null===r){for(;x<h.length;x++)r=C(e,h[x],k),null!==r&&(g=f(r,g,x),null===m?l=r:m.sibling=r,m=r);return l}for(r=d(e,r);x<h.length;x++)A=H(r,e,x,h[x],k),null!==A&&(a&&null!==A.alternate&&r.delete(null===A.key?x:A.key),g=f(A,g,x),null===m?l=A:m.sibling=A,m=A);a&&r.forEach(function(a){return b(e,a)});return l}function ta(e,g,h,k){var l=Ua(h);if(\"function\"!==typeof l)throw Error(u(150));h=l.call(h);\nif(null==h)throw Error(u(151));for(var m=l=null,r=g,x=g=0,A=null,p=h.next();null!==r&&!p.done;x++,p=h.next()){r.index>x?(A=r,r=null):A=r.sibling;var z=y(e,r,p.value,k);if(null===z){null===r&&(r=A);break}a&&r&&null===z.alternate&&b(e,r);g=f(z,g,x);null===m?l=z:m.sibling=z;m=z;r=A}if(p.done)return c(e,r),l;if(null===r){for(;!p.done;x++,p=h.next())p=C(e,p.value,k),null!==p&&(g=f(p,g,x),null===m?l=p:m.sibling=p,m=p);return l}for(r=d(e,r);!p.done;x++,p=h.next())p=H(r,e,x,p.value,k),null!==p&&(a&&null!==\np.alternate&&r.delete(null===p.key?x:p.key),g=f(p,g,x),null===m?l=p:m.sibling=p,m=p);a&&r.forEach(function(a){return b(e,a)});return l}return function(a,d,f,h){var k=\"object\"===typeof f&&null!==f&&f.type===Ia&&null===f.key;k&&(f=f.props.children);var l=\"object\"===typeof f&&null!==f;if(l)switch(f.$$typeof){case Ga:a:{l=f.key;for(k=d;null!==k;){if(k.key===l)if(7===k.tag?f.type===Ia:k.elementType===f.type){c(a,k.sibling);d=e(k,f.type===Ia?f.props.children:f.props,h);d.ref=Yg(a,k,f);d.return=a;a=d;break a}else{c(a,\nk);break}else b(a,k);k=k.sibling}f.type===Ia?(d=eh(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=ch(f.type,f.key,f.props,null,a.mode,h),h.ref=Yg(a,d,f),h.return=a,a=h)}return g(a);case Ha:a:{for(k=f.key;null!==d;){if(d.key===k)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[],h);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=dh(f,a.mode,h);d.return=a;a=d}return g(a)}if(\"string\"===\ntypeof f||\"number\"===typeof f)return f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f,h),d.return=a,a=d):(c(a,d),d=bh(f,a.mode,h),d.return=a,a=d),g(a);if(Xg(f))return z(a,d,f,h);if(Ua(f))return ta(a,d,f,h);l&&Zg(a,f);if(\"undefined\"===typeof f&&!k)switch(a.tag){case 1:case 0:throw a=a.type,Error(u(152,a.displayName||a.name||\"Component\"));}return c(a,d)}}var fh=$g(!0),gh=$g(!1),hh={},ih={current:hh},jh={current:hh},kh={current:hh};function lh(a){if(a===hh)throw Error(u(174));return a}\nfunction mh(a,b){I(kh,b,a);I(jh,a,a);I(ih,hh,a);var c=b.nodeType;switch(c){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:Qb(null,\"\");break;default:c=8===c?b.parentNode:b,b=c.namespaceURI||null,c=c.tagName,b=Qb(b,c)}G(ih,a);I(ih,b,a)}function nh(a){G(ih,a);G(jh,a);G(kh,a)}function oh(a){lh(kh.current);var b=lh(ih.current);var c=Qb(b,a.type);b!==c&&(I(jh,a,a),I(ih,c,a))}function ph(a){jh.current===a&&(G(ih,a),G(jh,a))}var M={current:0};\nfunction qh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||c.data===je||c.data===ke))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.effectTag&64))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}function rh(a,b){return{responder:a,props:b}}\nvar sh=Ea.ReactCurrentDispatcher,N=Ea.ReactCurrentBatchConfig,th=0,uh=null,O=null,vh=null,wh=null,P=null,xh=null,yh=0,zh=null,Ah=0,Bh=!1,Ch=null,Gh=0;function Q(){throw Error(u(321));}function Hh(a,b){if(null===b)return!1;for(var c=0;c<b.length&&c<a.length;c++)if(!of(a[c],b[c]))return!1;return!0}\nfunction Ih(a,b,c,d,e,f){th=f;uh=b;vh=null!==a?a.memoizedState:null;sh.current=null===vh?Jh:Kh;b=c(d,e);if(Bh){do Bh=!1,Gh+=1,vh=null!==a?a.memoizedState:null,xh=wh,zh=P=O=null,sh.current=Kh,b=c(d,e);while(Bh);Ch=null;Gh=0}sh.current=Lh;a=uh;a.memoizedState=wh;a.expirationTime=yh;a.updateQueue=zh;a.effectTag|=Ah;a=null!==O&&null!==O.next;th=0;xh=P=wh=vh=O=uh=null;yh=0;zh=null;Ah=0;if(a)throw Error(u(300));return b}\nfunction Mh(){sh.current=Lh;th=0;xh=P=wh=vh=O=uh=null;yh=0;zh=null;Ah=0;Bh=!1;Ch=null;Gh=0}function Nh(){var a={memoizedState:null,baseState:null,queue:null,baseUpdate:null,next:null};null===P?wh=P=a:P=P.next=a;return P}function Oh(){if(null!==xh)P=xh,xh=P.next,O=vh,vh=null!==O?O.next:null;else{if(null===vh)throw Error(u(310));O=vh;var a={memoizedState:O.memoizedState,baseState:O.baseState,queue:O.queue,baseUpdate:O.baseUpdate,next:null};P=null===P?wh=a:P.next=a;vh=O.next}return P}\nfunction Ph(a,b){return\"function\"===typeof b?b(a):b}\nfunction Qh(a){var b=Oh(),c=b.queue;if(null===c)throw Error(u(311));c.lastRenderedReducer=a;if(0<Gh){var d=c.dispatch;if(null!==Ch){var e=Ch.get(c);if(void 0!==e){Ch.delete(c);var f=b.memoizedState;do f=a(f,e.action),e=e.next;while(null!==e);of(f,b.memoizedState)||(wg=!0);b.memoizedState=f;b.baseUpdate===c.last&&(b.baseState=f);c.lastRenderedState=f;return[f,d]}}return[b.memoizedState,d]}d=c.last;var g=b.baseUpdate;f=b.baseState;null!==g?(null!==d&&(d.next=null),d=g.next):d=null!==d?d.next:null;if(null!==\nd){var h=e=null,k=d,l=!1;do{var m=k.expirationTime;m<th?(l||(l=!0,h=g,e=f),m>yh&&(yh=m,Jg(yh))):(Ig(m,k.suspenseConfig),f=k.eagerReducer===a?k.eagerState:a(f,k.action));g=k;k=k.next}while(null!==k&&k!==d);l||(h=g,e=f);of(f,b.memoizedState)||(wg=!0);b.memoizedState=f;b.baseUpdate=h;b.baseState=e;c.lastRenderedState=f}return[b.memoizedState,c.dispatch]}\nfunction Rh(a){var b=Nh();\"function\"===typeof a&&(a=a());b.memoizedState=b.baseState=a;a=b.queue={last:null,dispatch:null,lastRenderedReducer:Ph,lastRenderedState:a};a=a.dispatch=Sh.bind(null,uh,a);return[b.memoizedState,a]}function Th(a){return Qh(Ph,a)}function Uh(a,b,c,d){a={tag:a,create:b,destroy:c,deps:d,next:null};null===zh?(zh={lastEffect:null},zh.lastEffect=a.next=a):(b=zh.lastEffect,null===b?zh.lastEffect=a.next=a:(c=b.next,b.next=a,a.next=c,zh.lastEffect=a));return a}\nfunction Vh(a,b,c,d){var e=Nh();Ah|=a;e.memoizedState=Uh(b,c,void 0,void 0===d?null:d)}function Wh(a,b,c,d){var e=Oh();d=void 0===d?null:d;var f=void 0;if(null!==O){var g=O.memoizedState;f=g.destroy;if(null!==d&&Hh(d,g.deps)){Uh(0,c,f,d);return}}Ah|=a;e.memoizedState=Uh(b,c,f,d)}function Xh(a,b){return Vh(516,192,a,b)}function Yh(a,b){return Wh(516,192,a,b)}\nfunction Zh(a,b){if(\"function\"===typeof b)return a=a(),b(a),function(){b(null)};if(null!==b&&void 0!==b)return a=a(),b.current=a,function(){b.current=null}}function $h(){}function ai(a,b){Nh().memoizedState=[a,void 0===b?null:b];return a}function bi(a,b){var c=Oh();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Hh(b,d[1]))return d[0];c.memoizedState=[a,b];return a}\nfunction Sh(a,b,c){if(!(25>Gh))throw Error(u(301));var d=a.alternate;if(a===uh||null!==d&&d===uh)if(Bh=!0,a={expirationTime:th,suspenseConfig:null,action:c,eagerReducer:null,eagerState:null,next:null},null===Ch&&(Ch=new Map),c=Ch.get(b),void 0===c)Ch.set(b,a);else{for(b=c;null!==b.next;)b=b.next;b.next=a}else{var e=Pg(),f=Mg.suspense;e=Qg(e,a,f);f={expirationTime:e,suspenseConfig:f,action:c,eagerReducer:null,eagerState:null,next:null};var g=b.last;if(null===g)f.next=f;else{var h=g.next;null!==h&&\n(f.next=h);g.next=f}b.last=f;if(0===a.expirationTime&&(null===d||0===d.expirationTime)&&(d=b.lastRenderedReducer,null!==d))try{var k=b.lastRenderedState,l=d(k,c);f.eagerReducer=d;f.eagerState=l;if(of(l,k))return}catch(m){}finally{}Rg(a,e)}}\nvar Lh={readContext:xg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useResponder:Q,useDeferredValue:Q,useTransition:Q},Jh={readContext:xg,useCallback:ai,useContext:xg,useEffect:Xh,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return Vh(4,36,Zh.bind(null,b,a),c)},useLayoutEffect:function(a,b){return Vh(4,36,a,b)},useMemo:function(a,b){var c=Nh();b=void 0===b?null:b;a=a();c.memoizedState=\n[a,b];return a},useReducer:function(a,b,c){var d=Nh();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a=d.queue={last:null,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};a=a.dispatch=Sh.bind(null,uh,a);return[d.memoizedState,a]},useRef:function(a){var b=Nh();a={current:a};return b.memoizedState=a},useState:Rh,useDebugValue:$h,useResponder:rh,useDeferredValue:function(a,b){var c=Rh(a),d=c[0],e=c[1];Xh(function(){q.unstable_next(function(){var c=N.suspense;N.suspense=void 0===b?null:b;try{e(a)}finally{N.suspense=\nc}})},[a,b]);return d},useTransition:function(a){var b=Rh(!1),c=b[0],d=b[1];return[ai(function(b){d(!0);q.unstable_next(function(){var c=N.suspense;N.suspense=void 0===a?null:a;try{d(!1),b()}finally{N.suspense=c}})},[a,c]),c]}},Kh={readContext:xg,useCallback:bi,useContext:xg,useEffect:Yh,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return Wh(4,36,Zh.bind(null,b,a),c)},useLayoutEffect:function(a,b){return Wh(4,36,a,b)},useMemo:function(a,b){var c=Oh();b=void 0===b?\nnull:b;var d=c.memoizedState;if(null!==d&&null!==b&&Hh(b,d[1]))return d[0];a=a();c.memoizedState=[a,b];return a},useReducer:Qh,useRef:function(){return Oh().memoizedState},useState:Th,useDebugValue:$h,useResponder:rh,useDeferredValue:function(a,b){var c=Th(a),d=c[0],e=c[1];Yh(function(){q.unstable_next(function(){var c=N.suspense;N.suspense=void 0===b?null:b;try{e(a)}finally{N.suspense=c}})},[a,b]);return d},useTransition:function(a){var b=Th(!1),c=b[0],d=b[1];return[bi(function(b){d(!0);q.unstable_next(function(){var c=\nN.suspense;N.suspense=void 0===a?null:a;try{d(!1),b()}finally{N.suspense=c}})},[a,c]),c]}},ci=null,di=null,ei=!1;function fi(a,b){var c=gi(5,null,null,0);c.elementType=\"DELETED\";c.type=\"DELETED\";c.stateNode=b;c.return=a;c.effectTag=8;null!==a.lastEffect?(a.lastEffect.nextEffect=c,a.lastEffect=c):a.firstEffect=a.lastEffect=c}\nfunction hi(a,b){switch(a.tag){case 5:var c=a.type;b=1!==b.nodeType||c.toLowerCase()!==b.nodeName.toLowerCase()?null:b;return null!==b?(a.stateNode=b,!0):!1;case 6:return b=\"\"===a.pendingProps||3!==b.nodeType?null:b,null!==b?(a.stateNode=b,!0):!1;case 13:return!1;default:return!1}}\nfunction ii(a){if(ei){var b=di;if(b){var c=b;if(!hi(a,b)){b=re(c.nextSibling);if(!b||!hi(a,b)){a.effectTag=a.effectTag&-1025|2;ei=!1;ci=a;return}fi(ci,c)}ci=a;di=re(b.firstChild)}else a.effectTag=a.effectTag&-1025|2,ei=!1,ci=a}}function ji(a){for(a=a.return;null!==a&&5!==a.tag&&3!==a.tag&&13!==a.tag;)a=a.return;ci=a}\nfunction ki(a){if(a!==ci)return!1;if(!ei)return ji(a),ei=!0,!1;var b=a.type;if(5!==a.tag||\"head\"!==b&&\"body\"!==b&&!oe(b,a.memoizedProps))for(b=di;b;)fi(a,b),b=re(b.nextSibling);ji(a);if(13===a.tag){a=a.memoizedState;a=null!==a?a.dehydrated:null;if(!a)throw Error(u(317));a:{a=a.nextSibling;for(b=0;a;){if(8===a.nodeType){var c=a.data;if(c===ie){if(0===b){di=re(a.nextSibling);break a}b--}else c!==he&&c!==ke&&c!==je||b++}a=a.nextSibling}di=null}}else di=ci?re(a.stateNode.nextSibling):null;return!0}\nfunction li(){di=ci=null;ei=!1}var mi=Ea.ReactCurrentOwner,wg=!1;function R(a,b,c,d){b.child=null===a?gh(b,null,c,d):fh(b,a.child,c,d)}function ni(a,b,c,d,e){c=c.render;var f=b.ref;vg(b,e);d=Ih(a,b,c,d,f,e);if(null!==a&&!wg)return b.updateQueue=a.updateQueue,b.effectTag&=-517,a.expirationTime<=e&&(a.expirationTime=0),oi(a,b,e);b.effectTag|=1;R(a,b,d,e);return b.child}\nfunction pi(a,b,c,d,e,f){if(null===a){var g=c.type;if(\"function\"===typeof g&&!qi(g)&&void 0===g.defaultProps&&null===c.compare&&void 0===c.defaultProps)return b.tag=15,b.type=g,ri(a,b,g,d,e,f);a=ch(c.type,null,d,null,b.mode,f);a.ref=b.ref;a.return=b;return b.child=a}g=a.child;if(e<f&&(e=g.memoizedProps,c=c.compare,c=null!==c?c:qf,c(e,d)&&a.ref===b.ref))return oi(a,b,f);b.effectTag|=1;a=ah(g,d,f);a.ref=b.ref;a.return=b;return b.child=a}\nfunction ri(a,b,c,d,e,f){return null!==a&&qf(a.memoizedProps,d)&&a.ref===b.ref&&(wg=!1,e<f)?oi(a,b,f):si(a,b,c,d,f)}function ti(a,b){var c=b.ref;if(null===a&&null!==c||null!==a&&a.ref!==c)b.effectTag|=128}function si(a,b,c,d,e){var f=L(c)?Df:J.current;f=Ef(b,f);vg(b,e);c=Ih(a,b,c,d,f,e);if(null!==a&&!wg)return b.updateQueue=a.updateQueue,b.effectTag&=-517,a.expirationTime<=e&&(a.expirationTime=0),oi(a,b,e);b.effectTag|=1;R(a,b,c,e);return b.child}\nfunction ui(a,b,c,d,e){if(L(c)){var f=!0;Jf(b)}else f=!1;vg(b,e);if(null===b.stateNode)null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2),Ug(b,c,d,e),Wg(b,c,d,e),d=!0;else if(null===a){var g=b.stateNode,h=b.memoizedProps;g.props=h;var k=g.context,l=c.contextType;\"object\"===typeof l&&null!==l?l=xg(l):(l=L(c)?Df:J.current,l=Ef(b,l));var m=c.getDerivedStateFromProps,C=\"function\"===typeof m||\"function\"===typeof g.getSnapshotBeforeUpdate;C||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\n\"function\"!==typeof g.componentWillReceiveProps||(h!==d||k!==l)&&Vg(b,g,d,l);yg=!1;var y=b.memoizedState;k=g.state=y;var H=b.updateQueue;null!==H&&(Hg(b,H,d,g,e),k=b.memoizedState);h!==d||y!==k||K.current||yg?(\"function\"===typeof m&&(Og(b,c,m,d),k=b.memoizedState),(h=yg||Tg(b,c,h,d,y,k,l))?(C||\"function\"!==typeof g.UNSAFE_componentWillMount&&\"function\"!==typeof g.componentWillMount||(\"function\"===typeof g.componentWillMount&&g.componentWillMount(),\"function\"===typeof g.UNSAFE_componentWillMount&&\ng.UNSAFE_componentWillMount()),\"function\"===typeof g.componentDidMount&&(b.effectTag|=4)):(\"function\"===typeof g.componentDidMount&&(b.effectTag|=4),b.memoizedProps=d,b.memoizedState=k),g.props=d,g.state=k,g.context=l,d=h):(\"function\"===typeof g.componentDidMount&&(b.effectTag|=4),d=!1)}else g=b.stateNode,h=b.memoizedProps,g.props=b.type===b.elementType?h:mg(b.type,h),k=g.context,l=c.contextType,\"object\"===typeof l&&null!==l?l=xg(l):(l=L(c)?Df:J.current,l=Ef(b,l)),m=c.getDerivedStateFromProps,(C=\n\"function\"===typeof m||\"function\"===typeof g.getSnapshotBeforeUpdate)||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\"function\"!==typeof g.componentWillReceiveProps||(h!==d||k!==l)&&Vg(b,g,d,l),yg=!1,k=b.memoizedState,y=g.state=k,H=b.updateQueue,null!==H&&(Hg(b,H,d,g,e),y=b.memoizedState),h!==d||k!==y||K.current||yg?(\"function\"===typeof m&&(Og(b,c,m,d),y=b.memoizedState),(m=yg||Tg(b,c,h,d,k,y,l))?(C||\"function\"!==typeof g.UNSAFE_componentWillUpdate&&\"function\"!==typeof g.componentWillUpdate||\n(\"function\"===typeof g.componentWillUpdate&&g.componentWillUpdate(d,y,l),\"function\"===typeof g.UNSAFE_componentWillUpdate&&g.UNSAFE_componentWillUpdate(d,y,l)),\"function\"===typeof g.componentDidUpdate&&(b.effectTag|=4),\"function\"===typeof g.getSnapshotBeforeUpdate&&(b.effectTag|=256)):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=256),b.memoizedProps=\nd,b.memoizedState=y),g.props=d,g.state=y,g.context=l,d=m):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&k===a.memoizedState||(b.effectTag|=256),d=!1);return vi(a,b,c,d,f,e)}\nfunction vi(a,b,c,d,e,f){ti(a,b);var g=0!==(b.effectTag&64);if(!d&&!g)return e&&Kf(b,c,!1),oi(a,b,f);d=b.stateNode;mi.current=b;var h=g&&\"function\"!==typeof c.getDerivedStateFromError?null:d.render();b.effectTag|=1;null!==a&&g?(b.child=fh(b,a.child,null,f),b.child=fh(b,null,h,f)):R(a,b,h,f);b.memoizedState=d.state;e&&Kf(b,c,!0);return b.child}function wi(a){var b=a.stateNode;b.pendingContext?Hf(a,b.pendingContext,b.pendingContext!==b.context):b.context&&Hf(a,b.context,!1);mh(a,b.containerInfo)}\nvar xi={dehydrated:null,retryTime:0};\nfunction yi(a,b,c){var d=b.mode,e=b.pendingProps,f=M.current,g=!1,h;(h=0!==(b.effectTag&64))||(h=0!==(f&2)&&(null===a||null!==a.memoizedState));h?(g=!0,b.effectTag&=-65):null!==a&&null===a.memoizedState||void 0===e.fallback||!0===e.unstable_avoidThisFallback||(f|=1);I(M,f&1,b);if(null===a){void 0!==e.fallback&&ii(b);if(g){g=e.fallback;e=eh(null,d,0,null);e.return=b;if(0===(b.mode&2))for(a=null!==b.memoizedState?b.child.child:b.child,e.child=a;null!==a;)a.return=e,a=a.sibling;c=eh(g,d,c,null);c.return=\nb;e.sibling=c;b.memoizedState=xi;b.child=e;return c}d=e.children;b.memoizedState=null;return b.child=gh(b,null,d,c)}if(null!==a.memoizedState){a=a.child;d=a.sibling;if(g){e=e.fallback;c=ah(a,a.pendingProps,0);c.return=b;if(0===(b.mode&2)&&(g=null!==b.memoizedState?b.child.child:b.child,g!==a.child))for(c.child=g;null!==g;)g.return=c,g=g.sibling;d=ah(d,e,d.expirationTime);d.return=b;c.sibling=d;c.childExpirationTime=0;b.memoizedState=xi;b.child=c;return d}c=fh(b,a.child,e.children,c);b.memoizedState=\nnull;return b.child=c}a=a.child;if(g){g=e.fallback;e=eh(null,d,0,null);e.return=b;e.child=a;null!==a&&(a.return=e);if(0===(b.mode&2))for(a=null!==b.memoizedState?b.child.child:b.child,e.child=a;null!==a;)a.return=e,a=a.sibling;c=eh(g,d,c,null);c.return=b;e.sibling=c;c.effectTag|=2;e.childExpirationTime=0;b.memoizedState=xi;b.child=e;return c}b.memoizedState=null;return b.child=fh(b,a,e.children,c)}\nfunction zi(a,b){a.expirationTime<b&&(a.expirationTime=b);var c=a.alternate;null!==c&&c.expirationTime<b&&(c.expirationTime=b);ug(a.return,b)}function Ai(a,b,c,d,e,f){var g=a.memoizedState;null===g?a.memoizedState={isBackwards:b,rendering:null,last:d,tail:c,tailExpiration:0,tailMode:e,lastEffect:f}:(g.isBackwards=b,g.rendering=null,g.last=d,g.tail=c,g.tailExpiration=0,g.tailMode=e,g.lastEffect=f)}\nfunction Bi(a,b,c){var d=b.pendingProps,e=d.revealOrder,f=d.tail;R(a,b,d.children,c);d=M.current;if(0!==(d&2))d=d&1|2,b.effectTag|=64;else{if(null!==a&&0!==(a.effectTag&64))a:for(a=b.child;null!==a;){if(13===a.tag)null!==a.memoizedState&&zi(a,c);else if(19===a.tag)zi(a,c);else if(null!==a.child){a.child.return=a;a=a.child;continue}if(a===b)break a;for(;null===a.sibling;){if(null===a.return||a.return===b)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}d&=1}I(M,d,b);if(0===(b.mode&2))b.memoizedState=\nnull;else switch(e){case \"forwards\":c=b.child;for(e=null;null!==c;)a=c.alternate,null!==a&&null===qh(a)&&(e=c),c=c.sibling;c=e;null===c?(e=b.child,b.child=null):(e=c.sibling,c.sibling=null);Ai(b,!1,e,c,f,b.lastEffect);break;case \"backwards\":c=null;e=b.child;for(b.child=null;null!==e;){a=e.alternate;if(null!==a&&null===qh(a)){b.child=e;break}a=e.sibling;e.sibling=c;c=e;e=a}Ai(b,!0,c,null,f,b.lastEffect);break;case \"together\":Ai(b,!1,null,null,void 0,b.lastEffect);break;default:b.memoizedState=null}return b.child}\nfunction oi(a,b,c){null!==a&&(b.dependencies=a.dependencies);var d=b.expirationTime;0!==d&&Jg(d);if(b.childExpirationTime<c)return null;if(null!==a&&b.child!==a.child)throw Error(u(153));if(null!==b.child){a=b.child;c=ah(a,a.pendingProps,a.expirationTime);b.child=c;for(c.return=b;null!==a.sibling;)a=a.sibling,c=c.sibling=ah(a,a.pendingProps,a.expirationTime),c.return=b;c.sibling=null}return b.child}function Ci(a){a.effectTag|=4}var Hi,Ii,Ji,Ki;\nHi=function(a,b){for(var c=b.child;null!==c;){if(5===c.tag||6===c.tag)a.appendChild(c.stateNode);else if(4!==c.tag&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return}c.sibling.return=c.return;c=c.sibling}};Ii=function(){};\nJi=function(a,b,c,d,e){var f=a.memoizedProps;if(f!==d){var g=b.stateNode;lh(ih.current);a=null;switch(c){case \"input\":f=Ab(g,f);d=Ab(g,d);a=[];break;case \"option\":f=Ib(g,f);d=Ib(g,d);a=[];break;case \"select\":f=n({},f,{value:void 0});d=n({},d,{value:void 0});a=[];break;case \"textarea\":f=Kb(g,f);d=Kb(g,d);a=[];break;default:\"function\"!==typeof f.onClick&&\"function\"===typeof d.onClick&&(g.onclick=ae)}Yd(c,d);var h,k;c=null;for(h in f)if(!d.hasOwnProperty(h)&&f.hasOwnProperty(h)&&null!=f[h])if(\"style\"===\nh)for(k in g=f[h],g)g.hasOwnProperty(k)&&(c||(c={}),c[k]=\"\");else\"dangerouslySetInnerHTML\"!==h&&\"children\"!==h&&\"suppressContentEditableWarning\"!==h&&\"suppressHydrationWarning\"!==h&&\"autoFocus\"!==h&&(ia.hasOwnProperty(h)?a||(a=[]):(a=a||[]).push(h,null));for(h in d){var l=d[h];g=null!=f?f[h]:void 0;if(d.hasOwnProperty(h)&&l!==g&&(null!=l||null!=g))if(\"style\"===h)if(g){for(k in g)!g.hasOwnProperty(k)||l&&l.hasOwnProperty(k)||(c||(c={}),c[k]=\"\");for(k in l)l.hasOwnProperty(k)&&g[k]!==l[k]&&(c||(c={}),\nc[k]=l[k])}else c||(a||(a=[]),a.push(h,c)),c=l;else\"dangerouslySetInnerHTML\"===h?(l=l?l.__html:void 0,g=g?g.__html:void 0,null!=l&&g!==l&&(a=a||[]).push(h,\"\"+l)):\"children\"===h?g===l||\"string\"!==typeof l&&\"number\"!==typeof l||(a=a||[]).push(h,\"\"+l):\"suppressContentEditableWarning\"!==h&&\"suppressHydrationWarning\"!==h&&(ia.hasOwnProperty(h)?(null!=l&&$d(e,h),a||g===l||(a=[])):(a=a||[]).push(h,l))}c&&(a=a||[]).push(\"style\",c);e=a;(b.updateQueue=e)&&Ci(b)}};Ki=function(a,b,c,d){c!==d&&Ci(b)};\nfunction Li(a,b){switch(a.tailMode){case \"hidden\":b=a.tail;for(var c=null;null!==b;)null!==b.alternate&&(c=b),b=b.sibling;null===c?a.tail=null:c.sibling=null;break;case \"collapsed\":c=a.tail;for(var d=null;null!==c;)null!==c.alternate&&(d=c),c=c.sibling;null===d?b||null===a.tail?a.tail=null:a.tail.sibling=null:d.sibling=null}}\nfunction Mi(a){switch(a.tag){case 1:L(a.type)&&Ff(a);var b=a.effectTag;return b&4096?(a.effectTag=b&-4097|64,a):null;case 3:nh(a);Gf(a);b=a.effectTag;if(0!==(b&64))throw Error(u(285));a.effectTag=b&-4097|64;return a;case 5:return ph(a),null;case 13:return G(M,a),b=a.effectTag,b&4096?(a.effectTag=b&-4097|64,a):null;case 19:return G(M,a),null;case 4:return nh(a),null;case 10:return tg(a),null;default:return null}}function Ni(a,b){return{value:a,source:b,stack:Xa(b)}}\nvar Oi=\"function\"===typeof WeakSet?WeakSet:Set;function Pi(a,b){var c=b.source,d=b.stack;null===d&&null!==c&&(d=Xa(c));null!==c&&Wa(c.type);b=b.value;null!==a&&1===a.tag&&Wa(a.type);try{console.error(b)}catch(e){setTimeout(function(){throw e;})}}function Qi(a,b){try{b.props=a.memoizedProps,b.state=a.memoizedState,b.componentWillUnmount()}catch(c){Ri(a,c)}}function Si(a){var b=a.ref;if(null!==b)if(\"function\"===typeof b)try{b(null)}catch(c){Ri(a,c)}else b.current=null}\nfunction Ti(a,b){switch(b.tag){case 0:case 11:case 15:Ui(2,0,b);break;case 1:if(b.effectTag&256&&null!==a){var c=a.memoizedProps,d=a.memoizedState;a=b.stateNode;b=a.getSnapshotBeforeUpdate(b.elementType===b.type?c:mg(b.type,c),d);a.__reactInternalSnapshotBeforeUpdate=b}break;case 3:case 5:case 6:case 4:case 17:break;default:throw Error(u(163));}}\nfunction Ui(a,b,c){c=c.updateQueue;c=null!==c?c.lastEffect:null;if(null!==c){var d=c=c.next;do{if(0!==(d.tag&a)){var e=d.destroy;d.destroy=void 0;void 0!==e&&e()}0!==(d.tag&b)&&(e=d.create,d.destroy=e());d=d.next}while(d!==c)}}\nfunction Vi(a,b,c){\"function\"===typeof Wi&&Wi(b);switch(b.tag){case 0:case 11:case 14:case 15:a=b.updateQueue;if(null!==a&&(a=a.lastEffect,null!==a)){var d=a.next;fg(97<c?97:c,function(){var a=d;do{var c=a.destroy;if(void 0!==c){var g=b;try{c()}catch(h){Ri(g,h)}}a=a.next}while(a!==d)})}break;case 1:Si(b);c=b.stateNode;\"function\"===typeof c.componentWillUnmount&&Qi(b,c);break;case 5:Si(b);break;case 4:Xi(a,b,c)}}\nfunction Yi(a){var b=a.alternate;a.return=null;a.child=null;a.memoizedState=null;a.updateQueue=null;a.dependencies=null;a.alternate=null;a.firstEffect=null;a.lastEffect=null;a.pendingProps=null;a.memoizedProps=null;null!==b&&Yi(b)}function Zi(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction $i(a){a:{for(var b=a.return;null!==b;){if(Zi(b)){var c=b;break a}b=b.return}throw Error(u(160));}b=c.stateNode;switch(c.tag){case 5:var d=!1;break;case 3:b=b.containerInfo;d=!0;break;case 4:b=b.containerInfo;d=!0;break;default:throw Error(u(161));}c.effectTag&16&&(Tb(b,\"\"),c.effectTag&=-17);a:b:for(c=a;;){for(;null===c.sibling;){if(null===c.return||Zi(c.return)){c=null;break a}c=c.return}c.sibling.return=c.return;for(c=c.sibling;5!==c.tag&&6!==c.tag&&18!==c.tag;){if(c.effectTag&2)continue b;\nif(null===c.child||4===c.tag)continue b;else c.child.return=c,c=c.child}if(!(c.effectTag&2)){c=c.stateNode;break a}}for(var e=a;;){var f=5===e.tag||6===e.tag;if(f){var g=f?e.stateNode:e.stateNode.instance;if(c)if(d){f=b;var h=g;g=c;8===f.nodeType?f.parentNode.insertBefore(h,g):f.insertBefore(h,g)}else b.insertBefore(g,c);else d?(h=b,8===h.nodeType?(f=h.parentNode,f.insertBefore(g,h)):(f=h,f.appendChild(g)),h=h._reactRootContainer,null!==h&&void 0!==h||null!==f.onclick||(f.onclick=ae)):b.appendChild(g)}else if(4!==\ne.tag&&null!==e.child){e.child.return=e;e=e.child;continue}if(e===a)break;for(;null===e.sibling;){if(null===e.return||e.return===a)return;e=e.return}e.sibling.return=e.return;e=e.sibling}}\nfunction Xi(a,b,c){for(var d=b,e=!1,f,g;;){if(!e){e=d.return;a:for(;;){if(null===e)throw Error(u(160));f=e.stateNode;switch(e.tag){case 5:g=!1;break a;case 3:f=f.containerInfo;g=!0;break a;case 4:f=f.containerInfo;g=!0;break a}e=e.return}e=!0}if(5===d.tag||6===d.tag){a:for(var h=a,k=d,l=c,m=k;;)if(Vi(h,m,l),null!==m.child&&4!==m.tag)m.child.return=m,m=m.child;else{if(m===k)break;for(;null===m.sibling;){if(null===m.return||m.return===k)break a;m=m.return}m.sibling.return=m.return;m=m.sibling}g?(h=\nf,k=d.stateNode,8===h.nodeType?h.parentNode.removeChild(k):h.removeChild(k)):f.removeChild(d.stateNode)}else if(4===d.tag){if(null!==d.child){f=d.stateNode.containerInfo;g=!0;d.child.return=d;d=d.child;continue}}else if(Vi(a,d,c),null!==d.child){d.child.return=d;d=d.child;continue}if(d===b)break;for(;null===d.sibling;){if(null===d.return||d.return===b)return;d=d.return;4===d.tag&&(e=!1)}d.sibling.return=d.return;d=d.sibling}}\nfunction aj(a,b){switch(b.tag){case 0:case 11:case 14:case 15:Ui(4,8,b);break;case 1:break;case 5:var c=b.stateNode;if(null!=c){var d=b.memoizedProps,e=null!==a?a.memoizedProps:d;a=b.type;var f=b.updateQueue;b.updateQueue=null;if(null!==f){c[ve]=d;\"input\"===a&&\"radio\"===d.type&&null!=d.name&&Cb(c,d);Zd(a,e);b=Zd(a,d);for(e=0;e<f.length;e+=2){var g=f[e],h=f[e+1];\"style\"===g?Wd(c,h):\"dangerouslySetInnerHTML\"===g?Sb(c,h):\"children\"===g?Tb(c,h):vb(c,g,h,b)}switch(a){case \"input\":Eb(c,d);break;case \"textarea\":Mb(c,\nd);break;case \"select\":b=c._wrapperState.wasMultiple,c._wrapperState.wasMultiple=!!d.multiple,a=d.value,null!=a?Jb(c,!!d.multiple,a,!1):b!==!!d.multiple&&(null!=d.defaultValue?Jb(c,!!d.multiple,d.defaultValue,!0):Jb(c,!!d.multiple,d.multiple?[]:\"\",!1))}}}break;case 6:if(null===b.stateNode)throw Error(u(162));b.stateNode.nodeValue=b.memoizedProps;break;case 3:b=b.stateNode;b.hydrate&&(b.hydrate=!1,Lc(b.containerInfo));break;case 12:break;case 13:c=b;null===b.memoizedState?d=!1:(d=!0,c=b.child,bj=cg());\nif(null!==c)a:for(a=c;;){if(5===a.tag)f=a.stateNode,d?(f=f.style,\"function\"===typeof f.setProperty?f.setProperty(\"display\",\"none\",\"important\"):f.display=\"none\"):(f=a.stateNode,e=a.memoizedProps.style,e=void 0!==e&&null!==e&&e.hasOwnProperty(\"display\")?e.display:null,f.style.display=Vd(\"display\",e));else if(6===a.tag)a.stateNode.nodeValue=d?\"\":a.memoizedProps;else if(13===a.tag&&null!==a.memoizedState&&null===a.memoizedState.dehydrated){f=a.child.sibling;f.return=a;a=f;continue}else if(null!==a.child){a.child.return=\na;a=a.child;continue}if(a===c)break a;for(;null===a.sibling;){if(null===a.return||a.return===c)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}cj(b);break;case 19:cj(b);break;case 17:break;case 20:break;case 21:break;default:throw Error(u(163));}}function cj(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Oi);b.forEach(function(b){var d=dj.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}var ej=\"function\"===typeof WeakMap?WeakMap:Map;\nfunction fj(a,b,c){c=Bg(c,null);c.tag=3;c.payload={element:null};var d=b.value;c.callback=function(){gj||(gj=!0,hj=d);Pi(a,b)};return c}\nfunction ij(a,b,c){c=Bg(c,null);c.tag=3;var d=a.type.getDerivedStateFromError;if(\"function\"===typeof d){var e=b.value;c.payload=function(){Pi(a,b);return d(e)}}var f=a.stateNode;null!==f&&\"function\"===typeof f.componentDidCatch&&(c.callback=function(){\"function\"!==typeof d&&(null===jj?jj=new Set([this]):jj.add(this),Pi(a,b));var c=b.stack;this.componentDidCatch(b.value,{componentStack:null!==c?c:\"\"})});return c}\nvar kj=Math.ceil,lj=Ea.ReactCurrentDispatcher,mj=Ea.ReactCurrentOwner,S=0,nj=8,oj=16,pj=32,qj=0,rj=1,sj=2,tj=3,uj=4,vj=5,T=S,U=null,V=null,W=0,X=qj,wj=null,xj=1073741823,yj=1073741823,zj=null,Aj=0,Bj=!1,bj=0,Cj=500,Y=null,gj=!1,hj=null,jj=null,Dj=!1,Ej=null,Fj=90,Gj=null,Hj=0,Ij=null,Jj=0;function Pg(){return(T&(oj|pj))!==S?1073741821-(cg()/10|0):0!==Jj?Jj:Jj=1073741821-(cg()/10|0)}\nfunction Qg(a,b,c){b=b.mode;if(0===(b&2))return 1073741823;var d=dg();if(0===(b&4))return 99===d?1073741823:1073741822;if((T&oj)!==S)return W;if(null!==c)a=lg(a,c.timeoutMs|0||5E3,250);else switch(d){case 99:a=1073741823;break;case 98:a=lg(a,150,100);break;case 97:case 96:a=lg(a,5E3,250);break;case 95:a=2;break;default:throw Error(u(326));}null!==U&&a===W&&--a;return a}\nfunction Rg(a,b){if(50<Hj)throw Hj=0,Ij=null,Error(u(185));a=Kj(a,b);if(null!==a){var c=dg();1073741823===b?(T&nj)!==S&&(T&(oj|pj))===S?Lj(a):(Z(a),T===S&&jg()):Z(a);(T&4)===S||98!==c&&99!==c||(null===Gj?Gj=new Map([[a,b]]):(c=Gj.get(a),(void 0===c||c>b)&&Gj.set(a,b)))}}\nfunction Kj(a,b){a.expirationTime<b&&(a.expirationTime=b);var c=a.alternate;null!==c&&c.expirationTime<b&&(c.expirationTime=b);var d=a.return,e=null;if(null===d&&3===a.tag)e=a.stateNode;else for(;null!==d;){c=d.alternate;d.childExpirationTime<b&&(d.childExpirationTime=b);null!==c&&c.childExpirationTime<b&&(c.childExpirationTime=b);if(null===d.return&&3===d.tag){e=d.stateNode;break}d=d.return}null!==e&&(U===e&&(Jg(b),X===uj&&Mj(e,W)),Nj(e,b));return e}\nfunction Oj(a){var b=a.lastExpiredTime;if(0!==b)return b;b=a.firstPendingTime;if(!Pj(a,b))return b;b=a.lastPingedTime;a=a.nextKnownPendingLevel;return b>a?b:a}\nfunction Z(a){if(0!==a.lastExpiredTime)a.callbackExpirationTime=1073741823,a.callbackPriority=99,a.callbackNode=hg(Lj.bind(null,a));else{var b=Oj(a),c=a.callbackNode;if(0===b)null!==c&&(a.callbackNode=null,a.callbackExpirationTime=0,a.callbackPriority=90);else{var d=Pg();1073741823===b?d=99:1===b||2===b?d=95:(d=10*(1073741821-b)-10*(1073741821-d),d=0>=d?99:250>=d?98:5250>=d?97:95);if(null!==c){var e=a.callbackPriority;if(a.callbackExpirationTime===b&&e>=d)return;c!==Xf&&Nf(c)}a.callbackExpirationTime=\nb;a.callbackPriority=d;b=1073741823===b?hg(Lj.bind(null,a)):gg(d,Qj.bind(null,a),{timeout:10*(1073741821-b)-cg()});a.callbackNode=b}}}\nfunction Qj(a,b){Jj=0;if(b)return b=Pg(),Rj(a,b),Z(a),null;var c=Oj(a);if(0!==c){b=a.callbackNode;if((T&(oj|pj))!==S)throw Error(u(327));Sj();a===U&&c===W||Tj(a,c);if(null!==V){var d=T;T|=oj;var e=Uj(a);do try{Vj();break}catch(h){Wj(a,h)}while(1);rg();T=d;lj.current=e;if(X===rj)throw b=wj,Tj(a,c),Mj(a,c),Z(a),b;if(null===V)switch(e=a.finishedWork=a.current.alternate,a.finishedExpirationTime=c,d=X,U=null,d){case qj:case rj:throw Error(u(345));case sj:Rj(a,2<c?2:c);break;case tj:Mj(a,c);d=a.lastSuspendedTime;\nc===d&&(a.nextKnownPendingLevel=Xj(e));if(1073741823===xj&&(e=bj+Cj-cg(),10<e)){if(Bj){var f=a.lastPingedTime;if(0===f||f>=c){a.lastPingedTime=c;Tj(a,c);break}}f=Oj(a);if(0!==f&&f!==c)break;if(0!==d&&d!==c){a.lastPingedTime=d;break}a.timeoutHandle=pe(Yj.bind(null,a),e);break}Yj(a);break;case uj:Mj(a,c);d=a.lastSuspendedTime;c===d&&(a.nextKnownPendingLevel=Xj(e));if(Bj&&(e=a.lastPingedTime,0===e||e>=c)){a.lastPingedTime=c;Tj(a,c);break}e=Oj(a);if(0!==e&&e!==c)break;if(0!==d&&d!==c){a.lastPingedTime=\nd;break}1073741823!==yj?d=10*(1073741821-yj)-cg():1073741823===xj?d=0:(d=10*(1073741821-xj)-5E3,e=cg(),c=10*(1073741821-c)-e,d=e-d,0>d&&(d=0),d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*kj(d/1960))-d,c<d&&(d=c));if(10<d){a.timeoutHandle=pe(Yj.bind(null,a),d);break}Yj(a);break;case vj:if(1073741823!==xj&&null!==zj){f=xj;var g=zj;d=g.busyMinDurationMs|0;0>=d?d=0:(e=g.busyDelayMs|0,f=cg()-(10*(1073741821-f)-(g.timeoutMs|0||5E3)),d=f<=e?0:e+d-f);if(10<d){Mj(a,c);a.timeoutHandle=\npe(Yj.bind(null,a),d);break}}Yj(a);break;default:throw Error(u(329));}Z(a);if(a.callbackNode===b)return Qj.bind(null,a)}}return null}\nfunction Lj(a){var b=a.lastExpiredTime;b=0!==b?b:1073741823;if(a.finishedExpirationTime===b)Yj(a);else{if((T&(oj|pj))!==S)throw Error(u(327));Sj();a===U&&b===W||Tj(a,b);if(null!==V){var c=T;T|=oj;var d=Uj(a);do try{Zj();break}catch(e){Wj(a,e)}while(1);rg();T=c;lj.current=d;if(X===rj)throw c=wj,Tj(a,b),Mj(a,b),Z(a),c;if(null!==V)throw Error(u(261));a.finishedWork=a.current.alternate;a.finishedExpirationTime=b;U=null;Yj(a);Z(a)}}return null}\nfunction ak(){if(null!==Gj){var a=Gj;Gj=null;a.forEach(function(a,c){Rj(c,a);Z(c)});jg()}}function bk(a,b){var c=T;T|=1;try{return a(b)}finally{T=c,T===S&&jg()}}function ck(a,b){var c=T;T&=-2;T|=nj;try{return a(b)}finally{T=c,T===S&&jg()}}\nfunction Tj(a,b){a.finishedWork=null;a.finishedExpirationTime=0;var c=a.timeoutHandle;-1!==c&&(a.timeoutHandle=-1,qe(c));if(null!==V)for(c=V.return;null!==c;){var d=c;switch(d.tag){case 1:var e=d.type.childContextTypes;null!==e&&void 0!==e&&Ff(d);break;case 3:nh(d);Gf(d);break;case 5:ph(d);break;case 4:nh(d);break;case 13:G(M,d);break;case 19:G(M,d);break;case 10:tg(d)}c=c.return}U=a;V=ah(a.current,null,b);W=b;X=qj;wj=null;yj=xj=1073741823;zj=null;Aj=0;Bj=!1}\nfunction Wj(a,b){do{try{rg();Mh();if(null===V||null===V.return)return X=rj,wj=b,null;a:{var c=a,d=V.return,e=V,f=b;b=W;e.effectTag|=2048;e.firstEffect=e.lastEffect=null;if(null!==f&&\"object\"===typeof f&&\"function\"===typeof f.then){var g=f,h=0!==(M.current&1),k=d;do{var l;if(l=13===k.tag){var m=k.memoizedState;if(null!==m)l=null!==m.dehydrated?!0:!1;else{var C=k.memoizedProps;l=void 0===C.fallback?!1:!0!==C.unstable_avoidThisFallback?!0:h?!1:!0}}if(l){var y=k.updateQueue;if(null===y){var H=new Set;\nH.add(g);k.updateQueue=H}else y.add(g);if(0===(k.mode&2)){k.effectTag|=64;e.effectTag&=-2981;if(1===e.tag)if(null===e.alternate)e.tag=17;else{var z=Bg(1073741823,null);z.tag=2;Dg(e,z)}e.expirationTime=1073741823;break a}f=void 0;e=b;var ta=c.pingCache;null===ta?(ta=c.pingCache=new ej,f=new Set,ta.set(g,f)):(f=ta.get(g),void 0===f&&(f=new Set,ta.set(g,f)));if(!f.has(e)){f.add(e);var r=dk.bind(null,c,g,e);g.then(r,r)}k.effectTag|=4096;k.expirationTime=b;break a}k=k.return}while(null!==k);f=Error((Wa(e.type)||\n\"A React component\")+\" suspended while rendering, but no fallback UI was specified.\\n\\nAdd a <Suspense fallback=...> component higher in the tree to provide a loading indicator or placeholder to display.\"+Xa(e))}X!==vj&&(X=sj);f=Ni(f,e);k=d;do{switch(k.tag){case 3:g=f;k.effectTag|=4096;k.expirationTime=b;var x=fj(k,g,b);Eg(k,x);break a;case 1:g=f;var A=k.type,p=k.stateNode;if(0===(k.effectTag&64)&&(\"function\"===typeof A.getDerivedStateFromError||null!==p&&\"function\"===typeof p.componentDidCatch&&\n(null===jj||!jj.has(p)))){k.effectTag|=4096;k.expirationTime=b;var t=ij(k,g,b);Eg(k,t);break a}}k=k.return}while(null!==k)}V=ek(V)}catch(v){b=v;continue}break}while(1)}function Uj(){var a=lj.current;lj.current=Lh;return null===a?Lh:a}function Ig(a,b){a<xj&&2<a&&(xj=a);null!==b&&a<yj&&2<a&&(yj=a,zj=b)}function Jg(a){a>Aj&&(Aj=a)}function Zj(){for(;null!==V;)V=fk(V)}function Vj(){for(;null!==V&&!Of();)V=fk(V)}\nfunction fk(a){var b=gk(a.alternate,a,W);a.memoizedProps=a.pendingProps;null===b&&(b=ek(a));mj.current=null;return b}\nfunction ek(a){V=a;do{var b=V.alternate;a=V.return;if(0===(V.effectTag&2048)){a:{var c=b;b=V;var d=W;var e=b.pendingProps;switch(b.tag){case 2:break;case 16:break;case 15:case 0:break;case 1:L(b.type)&&Ff(b);break;case 3:nh(b);Gf(b);e=b.stateNode;e.pendingContext&&(e.context=e.pendingContext,e.pendingContext=null);(null===c||null===c.child)&&ki(b)&&Ci(b);Ii(b);break;case 5:ph(b);d=lh(kh.current);var f=b.type;if(null!==c&&null!=b.stateNode)Ji(c,b,f,e,d),c.ref!==b.ref&&(b.effectTag|=128);else if(e){var g=\nlh(ih.current);if(ki(b)){e=b;var h=e.stateNode;c=e.type;var k=e.memoizedProps,l=d;h[ue]=e;h[ve]=k;f=void 0;d=h;switch(c){case \"iframe\":case \"object\":case \"embed\":F(\"load\",d);break;case \"video\":case \"audio\":for(h=0;h<cc.length;h++)F(cc[h],d);break;case \"source\":F(\"error\",d);break;case \"img\":case \"image\":case \"link\":F(\"error\",d);F(\"load\",d);break;case \"form\":F(\"reset\",d);F(\"submit\",d);break;case \"details\":F(\"toggle\",d);break;case \"input\":Bb(d,k);F(\"invalid\",d);$d(l,\"onChange\");break;case \"select\":d._wrapperState=\n{wasMultiple:!!k.multiple};F(\"invalid\",d);$d(l,\"onChange\");break;case \"textarea\":Lb(d,k),F(\"invalid\",d),$d(l,\"onChange\")}Yd(c,k);h=null;for(f in k)k.hasOwnProperty(f)&&(g=k[f],\"children\"===f?\"string\"===typeof g?d.textContent!==g&&(h=[\"children\",g]):\"number\"===typeof g&&d.textContent!==\"\"+g&&(h=[\"children\",\"\"+g]):ia.hasOwnProperty(f)&&null!=g&&$d(l,f));switch(c){case \"input\":yb(d);Gb(d,k,!0);break;case \"textarea\":yb(d);Nb(d,k);break;case \"select\":case \"option\":break;default:\"function\"===typeof k.onClick&&\n(d.onclick=ae)}f=h;e.updateQueue=f;e=null!==f?!0:!1;e&&Ci(b)}else{c=b;l=f;k=e;h=9===d.nodeType?d:d.ownerDocument;g===Ob.html&&(g=Pb(l));g===Ob.html?\"script\"===l?(k=h.createElement(\"div\"),k.innerHTML=\"<script>\\x3c/script>\",h=k.removeChild(k.firstChild)):\"string\"===typeof k.is?h=h.createElement(l,{is:k.is}):(h=h.createElement(l),\"select\"===l&&(l=h,k.multiple?l.multiple=!0:k.size&&(l.size=k.size))):h=h.createElementNS(g,l);k=h;k[ue]=c;k[ve]=e;Hi(k,b,!1,!1);b.stateNode=k;l=f;c=e;var m=d,C=Zd(l,c);switch(l){case \"iframe\":case \"object\":case \"embed\":F(\"load\",\nk);d=c;break;case \"video\":case \"audio\":for(d=0;d<cc.length;d++)F(cc[d],k);d=c;break;case \"source\":F(\"error\",k);d=c;break;case \"img\":case \"image\":case \"link\":F(\"error\",k);F(\"load\",k);d=c;break;case \"form\":F(\"reset\",k);F(\"submit\",k);d=c;break;case \"details\":F(\"toggle\",k);d=c;break;case \"input\":Bb(k,c);d=Ab(k,c);F(\"invalid\",k);$d(m,\"onChange\");break;case \"option\":d=Ib(k,c);break;case \"select\":k._wrapperState={wasMultiple:!!c.multiple};d=n({},c,{value:void 0});F(\"invalid\",k);$d(m,\"onChange\");break;case \"textarea\":Lb(k,\nc);d=Kb(k,c);F(\"invalid\",k);$d(m,\"onChange\");break;default:d=c}Yd(l,d);h=void 0;g=l;var y=k,H=d;for(h in H)if(H.hasOwnProperty(h)){var z=H[h];\"style\"===h?Wd(y,z):\"dangerouslySetInnerHTML\"===h?(z=z?z.__html:void 0,null!=z&&Sb(y,z)):\"children\"===h?\"string\"===typeof z?(\"textarea\"!==g||\"\"!==z)&&Tb(y,z):\"number\"===typeof z&&Tb(y,\"\"+z):\"suppressContentEditableWarning\"!==h&&\"suppressHydrationWarning\"!==h&&\"autoFocus\"!==h&&(ia.hasOwnProperty(h)?null!=z&&$d(m,h):null!=z&&vb(y,h,z,C))}switch(l){case \"input\":yb(k);\nGb(k,c,!1);break;case \"textarea\":yb(k);Nb(k,c);break;case \"option\":null!=c.value&&k.setAttribute(\"value\",\"\"+ub(c.value));break;case \"select\":d=k;d.multiple=!!c.multiple;k=c.value;null!=k?Jb(d,!!c.multiple,k,!1):null!=c.defaultValue&&Jb(d,!!c.multiple,c.defaultValue,!0);break;default:\"function\"===typeof d.onClick&&(k.onclick=ae)}(e=ne(f,e))&&Ci(b)}null!==b.ref&&(b.effectTag|=128)}else if(null===b.stateNode)throw Error(u(166));break;case 6:if(c&&null!=b.stateNode)Ki(c,b,c.memoizedProps,e);else{if(\"string\"!==\ntypeof e&&null===b.stateNode)throw Error(u(166));d=lh(kh.current);lh(ih.current);ki(b)?(e=b,f=e.stateNode,d=e.memoizedProps,f[ue]=e,(e=f.nodeValue!==d)&&Ci(b)):(f=b,e=(9===d.nodeType?d:d.ownerDocument).createTextNode(e),e[ue]=f,b.stateNode=e)}break;case 11:break;case 13:G(M,b);e=b.memoizedState;if(0!==(b.effectTag&64)){b.expirationTime=d;break a}e=null!==e;f=!1;null===c?void 0!==b.memoizedProps.fallback&&ki(b):(d=c.memoizedState,f=null!==d,e||null===d||(d=c.child.sibling,null!==d&&(k=b.firstEffect,\nnull!==k?(b.firstEffect=d,d.nextEffect=k):(b.firstEffect=b.lastEffect=d,d.nextEffect=null),d.effectTag=8)));if(e&&!f&&0!==(b.mode&2))if(null===c&&!0!==b.memoizedProps.unstable_avoidThisFallback||0!==(M.current&1))X===qj&&(X=tj);else{if(X===qj||X===tj)X=uj;0!==Aj&&null!==U&&(Mj(U,W),Nj(U,Aj))}if(e||f)b.effectTag|=4;break;case 7:break;case 8:break;case 12:break;case 4:nh(b);Ii(b);break;case 10:tg(b);break;case 9:break;case 14:break;case 17:L(b.type)&&Ff(b);break;case 19:G(M,b);e=b.memoizedState;if(null===\ne)break;f=0!==(b.effectTag&64);k=e.rendering;if(null===k)if(f)Li(e,!1);else{if(X!==qj||null!==c&&0!==(c.effectTag&64))for(c=b.child;null!==c;){k=qh(c);if(null!==k){b.effectTag|=64;Li(e,!1);f=k.updateQueue;null!==f&&(b.updateQueue=f,b.effectTag|=4);null===e.lastEffect&&(b.firstEffect=null);b.lastEffect=e.lastEffect;e=d;for(f=b.child;null!==f;)d=f,c=e,d.effectTag&=2,d.nextEffect=null,d.firstEffect=null,d.lastEffect=null,k=d.alternate,null===k?(d.childExpirationTime=0,d.expirationTime=c,d.child=null,\nd.memoizedProps=null,d.memoizedState=null,d.updateQueue=null,d.dependencies=null):(d.childExpirationTime=k.childExpirationTime,d.expirationTime=k.expirationTime,d.child=k.child,d.memoizedProps=k.memoizedProps,d.memoizedState=k.memoizedState,d.updateQueue=k.updateQueue,c=k.dependencies,d.dependencies=null===c?null:{expirationTime:c.expirationTime,firstContext:c.firstContext,responders:c.responders}),f=f.sibling;I(M,M.current&1|2,b);b=b.child;break a}c=c.sibling}}else{if(!f)if(c=qh(k),null!==c){if(b.effectTag|=\n64,f=!0,d=c.updateQueue,null!==d&&(b.updateQueue=d,b.effectTag|=4),Li(e,!0),null===e.tail&&\"hidden\"===e.tailMode&&!k.alternate){b=b.lastEffect=e.lastEffect;null!==b&&(b.nextEffect=null);break}}else cg()>e.tailExpiration&&1<d&&(b.effectTag|=64,f=!0,Li(e,!1),b.expirationTime=b.childExpirationTime=d-1);e.isBackwards?(k.sibling=b.child,b.child=k):(d=e.last,null!==d?d.sibling=k:b.child=k,e.last=k)}if(null!==e.tail){0===e.tailExpiration&&(e.tailExpiration=cg()+500);d=e.tail;e.rendering=d;e.tail=d.sibling;\ne.lastEffect=b.lastEffect;d.sibling=null;e=M.current;e=f?e&1|2:e&1;I(M,e,b);b=d;break a}break;case 20:break;case 21:break;default:throw Error(u(156,b.tag));}b=null}e=V;if(1===W||1!==e.childExpirationTime){f=0;for(d=e.child;null!==d;)c=d.expirationTime,k=d.childExpirationTime,c>f&&(f=c),k>f&&(f=k),d=d.sibling;e.childExpirationTime=f}if(null!==b)return b;null!==a&&0===(a.effectTag&2048)&&(null===a.firstEffect&&(a.firstEffect=V.firstEffect),null!==V.lastEffect&&(null!==a.lastEffect&&(a.lastEffect.nextEffect=\nV.firstEffect),a.lastEffect=V.lastEffect),1<V.effectTag&&(null!==a.lastEffect?a.lastEffect.nextEffect=V:a.firstEffect=V,a.lastEffect=V))}else{b=Mi(V,W);if(null!==b)return b.effectTag&=2047,b;null!==a&&(a.firstEffect=a.lastEffect=null,a.effectTag|=2048)}b=V.sibling;if(null!==b)return b;V=a}while(null!==V);X===qj&&(X=vj);return null}function Xj(a){var b=a.expirationTime;a=a.childExpirationTime;return b>a?b:a}function Yj(a){var b=dg();fg(99,ik.bind(null,a,b));return null}\nfunction ik(a,b){do Sj();while(null!==Ej);if((T&(oj|pj))!==S)throw Error(u(327));var c=a.finishedWork,d=a.finishedExpirationTime;if(null===c)return null;a.finishedWork=null;a.finishedExpirationTime=0;if(c===a.current)throw Error(u(177));a.callbackNode=null;a.callbackExpirationTime=0;a.callbackPriority=90;a.nextKnownPendingLevel=0;var e=Xj(c);a.firstPendingTime=e;d<=a.lastSuspendedTime?a.firstSuspendedTime=a.lastSuspendedTime=a.nextKnownPendingLevel=0:d<=a.firstSuspendedTime&&(a.firstSuspendedTime=\nd-1);d<=a.lastPingedTime&&(a.lastPingedTime=0);d<=a.lastExpiredTime&&(a.lastExpiredTime=0);a===U&&(V=U=null,W=0);1<c.effectTag?null!==c.lastEffect?(c.lastEffect.nextEffect=c,e=c.firstEffect):e=c:e=c.firstEffect;if(null!==e){var f=T;T|=pj;mj.current=null;le=Ld;var g=fe();if(ge(g)){if(\"selectionStart\"in g)var h={start:g.selectionStart,end:g.selectionEnd};else a:{h=(h=g.ownerDocument)&&h.defaultView||window;var k=h.getSelection&&h.getSelection();if(k&&0!==k.rangeCount){h=k.anchorNode;var l=k.anchorOffset,\nm=k.focusNode;k=k.focusOffset;try{h.nodeType,m.nodeType}catch(Db){h=null;break a}var C=0,y=-1,H=-1,z=0,ta=0,r=g,x=null;b:for(;;){for(var A;;){r!==h||0!==l&&3!==r.nodeType||(y=C+l);r!==m||0!==k&&3!==r.nodeType||(H=C+k);3===r.nodeType&&(C+=r.nodeValue.length);if(null===(A=r.firstChild))break;x=r;r=A}for(;;){if(r===g)break b;x===h&&++z===l&&(y=C);x===m&&++ta===k&&(H=C);if(null!==(A=r.nextSibling))break;r=x;x=r.parentNode}r=A}h=-1===y||-1===H?null:{start:y,end:H}}else h=null}h=h||{start:0,end:0}}else h=\nnull;me={focusedElem:g,selectionRange:h};Ld=!1;Y=e;do try{jk()}catch(Db){if(null===Y)throw Error(u(330));Ri(Y,Db);Y=Y.nextEffect}while(null!==Y);Y=e;do try{for(g=a,h=b;null!==Y;){var p=Y.effectTag;p&16&&Tb(Y.stateNode,\"\");if(p&128){var t=Y.alternate;if(null!==t){var v=t.ref;null!==v&&(\"function\"===typeof v?v(null):v.current=null)}}switch(p&1038){case 2:$i(Y);Y.effectTag&=-3;break;case 6:$i(Y);Y.effectTag&=-3;aj(Y.alternate,Y);break;case 1024:Y.effectTag&=-1025;break;case 1028:Y.effectTag&=-1025;aj(Y.alternate,\nY);break;case 4:aj(Y.alternate,Y);break;case 8:l=Y,Xi(g,l,h),Yi(l)}Y=Y.nextEffect}}catch(Db){if(null===Y)throw Error(u(330));Ri(Y,Db);Y=Y.nextEffect}while(null!==Y);v=me;t=fe();p=v.focusedElem;h=v.selectionRange;if(t!==p&&p&&p.ownerDocument&&ee(p.ownerDocument.documentElement,p)){null!==h&&ge(p)&&(t=h.start,v=h.end,void 0===v&&(v=t),\"selectionStart\"in p?(p.selectionStart=t,p.selectionEnd=Math.min(v,p.value.length)):(v=(t=p.ownerDocument||document)&&t.defaultView||window,v.getSelection&&(v=v.getSelection(),\nl=p.textContent.length,g=Math.min(h.start,l),h=void 0===h.end?g:Math.min(h.end,l),!v.extend&&g>h&&(l=h,h=g,g=l),l=de(p,g),m=de(p,h),l&&m&&(1!==v.rangeCount||v.anchorNode!==l.node||v.anchorOffset!==l.offset||v.focusNode!==m.node||v.focusOffset!==m.offset)&&(t=t.createRange(),t.setStart(l.node,l.offset),v.removeAllRanges(),g>h?(v.addRange(t),v.extend(m.node,m.offset)):(t.setEnd(m.node,m.offset),v.addRange(t))))));t=[];for(v=p;v=v.parentNode;)1===v.nodeType&&t.push({element:v,left:v.scrollLeft,top:v.scrollTop});\n\"function\"===typeof p.focus&&p.focus();for(p=0;p<t.length;p++)v=t[p],v.element.scrollLeft=v.left,v.element.scrollTop=v.top}me=null;Ld=!!le;le=null;a.current=c;Y=e;do try{for(p=d;null!==Y;){var Dh=Y.effectTag;if(Dh&36){var dc=Y.alternate;t=Y;v=p;switch(t.tag){case 0:case 11:case 15:Ui(16,32,t);break;case 1:var fd=t.stateNode;if(t.effectTag&4)if(null===dc)fd.componentDidMount();else{var hk=t.elementType===t.type?dc.memoizedProps:mg(t.type,dc.memoizedProps);fd.componentDidUpdate(hk,dc.memoizedState,\nfd.__reactInternalSnapshotBeforeUpdate)}var Eh=t.updateQueue;null!==Eh&&Kg(t,Eh,fd,v);break;case 3:var Fh=t.updateQueue;if(null!==Fh){g=null;if(null!==t.child)switch(t.child.tag){case 5:g=t.child.stateNode;break;case 1:g=t.child.stateNode}Kg(t,Fh,g,v)}break;case 5:var xk=t.stateNode;null===dc&&t.effectTag&4&&ne(t.type,t.memoizedProps)&&xk.focus();break;case 6:break;case 4:break;case 12:break;case 13:if(null===t.memoizedState){var Di=t.alternate;if(null!==Di){var Ei=Di.memoizedState;if(null!==Ei){var Fi=\nEi.dehydrated;null!==Fi&&Lc(Fi)}}}break;case 19:case 17:case 20:case 21:break;default:throw Error(u(163));}}if(Dh&128){t=void 0;var xd=Y.ref;if(null!==xd){var Gi=Y.stateNode;switch(Y.tag){case 5:t=Gi;break;default:t=Gi}\"function\"===typeof xd?xd(t):xd.current=t}}Y=Y.nextEffect}}catch(Db){if(null===Y)throw Error(u(330));Ri(Y,Db);Y=Y.nextEffect}while(null!==Y);Y=null;Yf();T=f}else a.current=c;if(Dj)Dj=!1,Ej=a,Fj=b;else for(Y=e;null!==Y;)b=Y.nextEffect,Y.nextEffect=null,Y=b;b=a.firstPendingTime;0===b&&\n(jj=null);1073741823===b?a===Ij?Hj++:(Hj=0,Ij=a):Hj=0;\"function\"===typeof kk&&kk(c.stateNode,d);Z(a);if(gj)throw gj=!1,a=hj,hj=null,a;if((T&nj)!==S)return null;jg();return null}function jk(){for(;null!==Y;){var a=Y.effectTag;0!==(a&256)&&Ti(Y.alternate,Y);0===(a&512)||Dj||(Dj=!0,gg(97,function(){Sj();return null}));Y=Y.nextEffect}}function Sj(){if(90!==Fj){var a=97<Fj?97:Fj;Fj=90;return fg(a,lk)}}\nfunction lk(){if(null===Ej)return!1;var a=Ej;Ej=null;if((T&(oj|pj))!==S)throw Error(u(331));var b=T;T|=pj;for(a=a.current.firstEffect;null!==a;){try{var c=a;if(0!==(c.effectTag&512))switch(c.tag){case 0:case 11:case 15:Ui(128,0,c),Ui(0,64,c)}}catch(d){if(null===a)throw Error(u(330));Ri(a,d)}c=a.nextEffect;a.nextEffect=null;a=c}T=b;jg();return!0}function mk(a,b,c){b=Ni(c,b);b=fj(a,b,1073741823);Dg(a,b);a=Kj(a,1073741823);null!==a&&Z(a)}\nfunction Ri(a,b){if(3===a.tag)mk(a,a,b);else for(var c=a.return;null!==c;){if(3===c.tag){mk(c,a,b);break}else if(1===c.tag){var d=c.stateNode;if(\"function\"===typeof c.type.getDerivedStateFromError||\"function\"===typeof d.componentDidCatch&&(null===jj||!jj.has(d))){a=Ni(b,a);a=ij(c,a,1073741823);Dg(c,a);c=Kj(c,1073741823);null!==c&&Z(c);break}}c=c.return}}\nfunction dk(a,b,c){var d=a.pingCache;null!==d&&d.delete(b);U===a&&W===c?X===uj||X===tj&&1073741823===xj&&cg()-bj<Cj?Tj(a,W):Bj=!0:Pj(a,c)&&(b=a.lastPingedTime,0!==b&&b<c||(a.lastPingedTime=c,a.finishedExpirationTime===c&&(a.finishedExpirationTime=0,a.finishedWork=null),Z(a)))}function dj(a,b){var c=a.stateNode;null!==c&&c.delete(b);b=0;0===b&&(b=Pg(),b=Qg(b,a,null));a=Kj(a,b);null!==a&&Z(a)}var gk;\ngk=function(a,b,c){var d=b.expirationTime;if(null!==a){var e=b.pendingProps;if(a.memoizedProps!==e||K.current)wg=!0;else{if(d<c){wg=!1;switch(b.tag){case 3:wi(b);li();break;case 5:oh(b);if(b.mode&4&&1!==c&&e.hidden)return b.expirationTime=b.childExpirationTime=1,null;break;case 1:L(b.type)&&Jf(b);break;case 4:mh(b,b.stateNode.containerInfo);break;case 10:sg(b,b.memoizedProps.value);break;case 13:if(null!==b.memoizedState){d=b.child.childExpirationTime;if(0!==d&&d>=c)return yi(a,b,c);I(M,M.current&\n1,b);b=oi(a,b,c);return null!==b?b.sibling:null}I(M,M.current&1,b);break;case 19:d=b.childExpirationTime>=c;if(0!==(a.effectTag&64)){if(d)return Bi(a,b,c);b.effectTag|=64}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null);I(M,M.current,b);if(!d)return null}return oi(a,b,c)}wg=!1}}else wg=!1;b.expirationTime=0;switch(b.tag){case 2:d=b.type;null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2);a=b.pendingProps;e=Ef(b,J.current);vg(b,c);e=Ih(null,b,d,a,e,c);b.effectTag|=1;if(\"object\"===\ntypeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof){b.tag=1;Mh();if(L(d)){var f=!0;Jf(b)}else f=!1;b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null;var g=d.getDerivedStateFromProps;\"function\"===typeof g&&Og(b,d,g,a);e.updater=Sg;b.stateNode=e;e._reactInternalFiber=b;Wg(b,d,a,c);b=vi(null,b,d,!0,f,c)}else b.tag=0,R(null,b,e,c),b=b.child;return b;case 16:e=b.elementType;null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2);a=b.pendingProps;Va(e);if(1!==e._status)throw e._result;\ne=e._result;b.type=e;f=b.tag=nk(e);a=mg(e,a);switch(f){case 0:b=si(null,b,e,a,c);break;case 1:b=ui(null,b,e,a,c);break;case 11:b=ni(null,b,e,a,c);break;case 14:b=pi(null,b,e,mg(e.type,a),d,c);break;default:throw Error(u(306,e,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),si(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),ui(a,b,d,e,c);case 3:wi(b);d=b.updateQueue;if(null===d)throw Error(u(282));e=b.memoizedState;e=null!==e?e.element:\nnull;Hg(b,d,b.pendingProps,null,c);d=b.memoizedState.element;if(d===e)li(),b=oi(a,b,c);else{if(e=b.stateNode.hydrate)di=re(b.stateNode.containerInfo.firstChild),ci=b,e=ei=!0;if(e)for(c=gh(b,null,d,c),b.child=c;c;)c.effectTag=c.effectTag&-3|1024,c=c.sibling;else R(a,b,d,c),li();b=b.child}return b;case 5:return oh(b),null===a&&ii(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,oe(d,e)?g=null:null!==f&&oe(d,f)&&(b.effectTag|=16),ti(a,b),b.mode&4&&1!==c&&e.hidden?(b.expirationTime=\nb.childExpirationTime=1,b=null):(R(a,b,g,c),b=b.child),b;case 6:return null===a&&ii(b),null;case 13:return yi(a,b,c);case 4:return mh(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=fh(b,null,d,c):R(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),ni(a,b,d,e,c);case 7:return R(a,b,b.pendingProps,c),b.child;case 8:return R(a,b,b.pendingProps.children,c),b.child;case 12:return R(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;\ne=b.pendingProps;g=b.memoizedProps;f=e.value;sg(b,f);if(null!==g){var h=g.value;f=of(h,f)?0:(\"function\"===typeof d._calculateChangedBits?d._calculateChangedBits(h,f):1073741823)|0;if(0===f){if(g.children===e.children&&!K.current){b=oi(a,b,c);break a}}else for(h=b.child,null!==h&&(h.return=b);null!==h;){var k=h.dependencies;if(null!==k){g=h.child;for(var l=k.firstContext;null!==l;){if(l.context===d&&0!==(l.observedBits&f)){1===h.tag&&(l=Bg(c,null),l.tag=2,Dg(h,l));h.expirationTime<c&&(h.expirationTime=\nc);l=h.alternate;null!==l&&l.expirationTime<c&&(l.expirationTime=c);ug(h.return,c);k.expirationTime<c&&(k.expirationTime=c);break}l=l.next}}else g=10===h.tag?h.type===b.type?null:h.child:h.child;if(null!==g)g.return=h;else for(g=h;null!==g;){if(g===b){g=null;break}h=g.sibling;if(null!==h){h.return=g.return;g=h;break}g=g.return}h=g}}R(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,f=b.pendingProps,d=f.children,vg(b,c),e=xg(e,f.unstable_observedBits),d=d(e),b.effectTag|=1,R(a,b,d,c),b.child;\ncase 14:return e=b.type,f=mg(e,b.pendingProps),f=mg(e.type,f),pi(a,b,e,f,d,c);case 15:return ri(a,b,b.type,b.pendingProps,d,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:mg(d,e),null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2),b.tag=1,L(d)?(a=!0,Jf(b)):a=!1,vg(b,c),Ug(b,d,e,c),Wg(b,d,e,c),vi(null,b,d,!0,a,c);case 19:return Bi(a,b,c)}throw Error(u(156,b.tag));};var kk=null,Wi=null;\nfunction ok(a){if(\"undefined\"===typeof __REACT_DEVTOOLS_GLOBAL_HOOK__)return!1;var b=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(b.isDisabled||!b.supportsFiber)return!0;try{var c=b.inject(a);kk=function(a){try{b.onCommitFiberRoot(c,a,void 0,64===(a.current.effectTag&64))}catch(e){}};Wi=function(a){try{b.onCommitFiberUnmount(c,a)}catch(e){}}}catch(d){}return!0}\nfunction pk(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.effectTag=0;this.lastEffect=this.firstEffect=this.nextEffect=null;this.childExpirationTime=this.expirationTime=0;this.alternate=null}function gi(a,b,c,d){return new pk(a,b,c,d)}\nfunction qi(a){a=a.prototype;return!(!a||!a.isReactComponent)}function nk(a){if(\"function\"===typeof a)return qi(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Oa)return 11;if(a===Ra)return 14}return 2}\nfunction ah(a,b){var c=a.alternate;null===c?(c=gi(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.effectTag=0,c.nextEffect=null,c.firstEffect=null,c.lastEffect=null);c.childExpirationTime=a.childExpirationTime;c.expirationTime=a.expirationTime;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{expirationTime:b.expirationTime,\nfirstContext:b.firstContext,responders:b.responders};c.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction ch(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)qi(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case Ia:return eh(c.children,e,f,b);case Na:g=8;e|=7;break;case Ja:g=8;e|=1;break;case Ka:return a=gi(12,c,b,e|8),a.elementType=Ka,a.type=Ka,a.expirationTime=f,a;case Pa:return a=gi(13,c,b,e),a.type=Pa,a.elementType=Pa,a.expirationTime=f,a;case Qa:return a=gi(19,c,b,e),a.elementType=Qa,a.expirationTime=f,a;default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case La:g=\n10;break a;case Ma:g=9;break a;case Oa:g=11;break a;case Ra:g=14;break a;case Sa:g=16;d=null;break a}throw Error(u(130,null==a?a:typeof a,\"\"));}b=gi(g,c,b,e);b.elementType=a;b.type=d;b.expirationTime=f;return b}function eh(a,b,c,d){a=gi(7,a,d,b);a.expirationTime=c;return a}function bh(a,b,c){a=gi(6,a,null,b);a.expirationTime=c;return a}\nfunction dh(a,b,c){b=gi(4,null!==a.children?a.children:[],a.key,b);b.expirationTime=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction qk(a,b,c){this.tag=b;this.current=null;this.containerInfo=a;this.pingCache=this.pendingChildren=null;this.finishedExpirationTime=0;this.finishedWork=null;this.timeoutHandle=-1;this.pendingContext=this.context=null;this.hydrate=c;this.callbackNode=null;this.callbackPriority=90;this.lastExpiredTime=this.lastPingedTime=this.nextKnownPendingLevel=this.lastSuspendedTime=this.firstSuspendedTime=this.firstPendingTime=0}\nfunction Pj(a,b){var c=a.firstSuspendedTime;a=a.lastSuspendedTime;return 0!==c&&c>=b&&a<=b}function Mj(a,b){var c=a.firstSuspendedTime,d=a.lastSuspendedTime;c<b&&(a.firstSuspendedTime=b);if(d>b||0===c)a.lastSuspendedTime=b;b<=a.lastPingedTime&&(a.lastPingedTime=0);b<=a.lastExpiredTime&&(a.lastExpiredTime=0)}\nfunction Nj(a,b){b>a.firstPendingTime&&(a.firstPendingTime=b);var c=a.firstSuspendedTime;0!==c&&(b>=c?a.firstSuspendedTime=a.lastSuspendedTime=a.nextKnownPendingLevel=0:b>=a.lastSuspendedTime&&(a.lastSuspendedTime=b+1),b>a.nextKnownPendingLevel&&(a.nextKnownPendingLevel=b))}function Rj(a,b){var c=a.lastExpiredTime;if(0===c||c>b)a.lastExpiredTime=b}\nfunction rk(a,b,c,d){var e=b.current,f=Pg(),g=Mg.suspense;f=Qg(f,e,g);a:if(c){c=c._reactInternalFiber;b:{if(ec(c)!==c||1!==c.tag)throw Error(u(170));var h=c;do{switch(h.tag){case 3:h=h.stateNode.context;break b;case 1:if(L(h.type)){h=h.stateNode.__reactInternalMemoizedMergedChildContext;break b}}h=h.return}while(null!==h);throw Error(u(171));}if(1===c.tag){var k=c.type;if(L(k)){c=If(c,k,h);break a}}c=h}else c=Cf;null===b.context?b.context=c:b.pendingContext=c;b=Bg(f,g);b.payload={element:a};d=void 0===\nd?null:d;null!==d&&(b.callback=d);Dg(e,b);Rg(e,f);return f}function sk(a){a=a.current;if(!a.child)return null;switch(a.child.tag){case 5:return a.child.stateNode;default:return a.child.stateNode}}function tk(a,b){a=a.memoizedState;null!==a&&null!==a.dehydrated&&a.retryTime<b&&(a.retryTime=b)}function uk(a,b){tk(a,b);(a=a.alternate)&&tk(a,b)}\nfunction vk(a,b,c){c=null!=c&&!0===c.hydrate;var d=new qk(a,b,c),e=gi(3,null,null,2===b?7:1===b?3:0);d.current=e;e.stateNode=d;a[we]=d.current;c&&0!==b&&wc(9===a.nodeType?a:a.ownerDocument);this._internalRoot=d}vk.prototype.render=function(a,b){rk(a,this._internalRoot,null,void 0===b?null:b)};vk.prototype.unmount=function(a){var b=this._internalRoot,c=void 0===a?null:a,d=b.containerInfo;rk(null,b,null,function(){d[we]=null;null!==c&&c()})};\nfunction wk(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType&&(8!==a.nodeType||\" react-mount-point-unstable \"!==a.nodeValue))}function yk(a,b){b||(b=a?9===a.nodeType?a.documentElement:a.firstChild:null,b=!(!b||1!==b.nodeType||!b.hasAttribute(\"data-reactroot\")));if(!b)for(var c;c=a.lastChild;)a.removeChild(c);return new vk(a,0,b?{hydrate:!0}:void 0)}\nfunction zk(a,b,c,d,e){var f=c._reactRootContainer;if(f){var g=f._internalRoot;if(\"function\"===typeof e){var h=e;e=function(){var a=sk(g);h.call(a)}}rk(b,g,a,e)}else{f=c._reactRootContainer=yk(c,d);g=f._internalRoot;if(\"function\"===typeof e){var k=e;e=function(){var a=sk(g);k.call(a)}}ck(function(){rk(b,g,a,e)})}return sk(g)}function Ak(a,b,c){var d=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:Ha,key:null==d?null:\"\"+d,children:a,containerInfo:b,implementation:c}}\njc=function(a){if(13===a.tag){var b=lg(Pg(),150,100);Rg(a,b);uk(a,b)}};kc=function(a){if(13===a.tag){Pg();var b=kg++;Rg(a,b);uk(a,b)}};lc=function(a){if(13===a.tag){var b=Pg();b=Qg(b,a,null);Rg(a,b);uk(a,b)}};\nZa=function(a,b,c){switch(b){case \"input\":Eb(a,c);b=c.name;if(\"radio\"===c.type&&null!=b){for(c=a;c.parentNode;)c=c.parentNode;c=c.querySelectorAll(\"input[name=\"+JSON.stringify(\"\"+b)+'][type=\"radio\"]');for(b=0;b<c.length;b++){var d=c[b];if(d!==a&&d.form===a.form){var e=ye(d);if(!e)throw Error(u(90));zb(d);Eb(d,e)}}}break;case \"textarea\":Mb(a,c);break;case \"select\":b=c.value,null!=b&&Jb(a,!!c.multiple,b,!1)}};eb=bk;\nfb=function(a,b,c,d){var e=T;T|=4;try{return fg(98,a.bind(null,b,c,d))}finally{T=e,T===S&&jg()}};gb=function(){(T&(1|oj|pj))===S&&(ak(),Sj())};hb=function(a,b){var c=T;T|=2;try{return a(b)}finally{T=c,T===S&&jg()}};function Bk(a,b){var c=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!wk(b))throw Error(u(200));return Ak(a,b,null,c)}\nvar Ck={createPortal:Bk,findDOMNode:function(a){if(null==a)return null;if(1===a.nodeType)return a;var b=a._reactInternalFiber;if(void 0===b){if(\"function\"===typeof a.render)throw Error(u(188));throw Error(u(268,Object.keys(a)));}a=ic(b);a=null===a?null:a.stateNode;return a},hydrate:function(a,b,c){if(!wk(b))throw Error(u(200));return zk(null,a,b,!0,c)},render:function(a,b,c){if(!wk(b))throw Error(u(200));return zk(null,a,b,!1,c)},unstable_renderSubtreeIntoContainer:function(a,b,c,d){if(!wk(c))throw Error(u(200));\nif(null==a||void 0===a._reactInternalFiber)throw Error(u(38));return zk(a,b,c,!1,d)},unmountComponentAtNode:function(a){if(!wk(a))throw Error(u(40));return a._reactRootContainer?(ck(function(){zk(null,null,a,!1,function(){a._reactRootContainer=null;a[we]=null})}),!0):!1},unstable_createPortal:function(){return Bk.apply(void 0,arguments)},unstable_batchedUpdates:bk,flushSync:function(a,b){if((T&(oj|pj))!==S)throw Error(u(187));var c=T;T|=1;try{return fg(99,a.bind(null,b))}finally{T=c,jg()}},__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:{Events:[Cc,\nxe,ye,Ca.injectEventPluginsByName,fa,Sc,function(a){ya(a,Rc)},cb,db,Pd,Ba,Sj,{current:!1}]}};\n(function(a){var b=a.findFiberByHostInstance;return ok(n({},a,{overrideHookState:null,overrideProps:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:Ea.ReactCurrentDispatcher,findHostInstanceByFiber:function(a){a=ic(a);return null===a?null:a.stateNode},findFiberByHostInstance:function(a){return b?b(a):null},findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null}))})({findFiberByHostInstance:Fc,bundleType:0,version:\"16.12.0\",\nrendererPackageName:\"react-dom\"});var Dk={default:Ck},Ek=Dk&&Ck||Dk;module.exports=Ek.default||Ek;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","/** @license React v0.18.0\n * scheduler.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';Object.defineProperty(exports,\"__esModule\",{value:!0});var f,g,h,k,l;\nif(\"undefined\"===typeof window||\"function\"!==typeof MessageChannel){var p=null,q=null,t=function(){if(null!==p)try{var a=exports.unstable_now();p(!0,a);p=null}catch(b){throw setTimeout(t,0),b;}},u=Date.now();exports.unstable_now=function(){return Date.now()-u};f=function(a){null!==p?setTimeout(f,0,a):(p=a,setTimeout(t,0))};g=function(a,b){q=setTimeout(a,b)};h=function(){clearTimeout(q)};k=function(){return!1};l=exports.unstable_forceFrameRate=function(){}}else{var w=window.performance,x=window.Date,\ny=window.setTimeout,z=window.clearTimeout;if(\"undefined\"!==typeof console){var A=window.cancelAnimationFrame;\"function\"!==typeof window.requestAnimationFrame&&console.error(\"This browser doesn't support requestAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills\");\"function\"!==typeof A&&console.error(\"This browser doesn't support cancelAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills\")}if(\"object\"===\ntypeof w&&\"function\"===typeof w.now)exports.unstable_now=function(){return w.now()};else{var B=x.now();exports.unstable_now=function(){return x.now()-B}}var C=!1,D=null,E=-1,F=5,G=0;k=function(){return exports.unstable_now()>=G};l=function(){};exports.unstable_forceFrameRate=function(a){0>a||125<a?console.error(\"forceFrameRate takes a positive int between 0 and 125, forcing framerates higher than 125 fps is not unsupported\"):F=0<a?Math.floor(1E3/a):5};var H=new MessageChannel,I=H.port2;H.port1.onmessage=\nfunction(){if(null!==D){var a=exports.unstable_now();G=a+F;try{D(!0,a)?I.postMessage(null):(C=!1,D=null)}catch(b){throw I.postMessage(null),b;}}else C=!1};f=function(a){D=a;C||(C=!0,I.postMessage(null))};g=function(a,b){E=y(function(){a(exports.unstable_now())},b)};h=function(){z(E);E=-1}}function J(a,b){var c=a.length;a.push(b);a:for(;;){var d=Math.floor((c-1)/2),e=a[d];if(void 0!==e&&0<K(e,b))a[d]=b,a[c]=e,c=d;else break a}}function L(a){a=a[0];return void 0===a?null:a}\nfunction M(a){var b=a[0];if(void 0!==b){var c=a.pop();if(c!==b){a[0]=c;a:for(var d=0,e=a.length;d<e;){var m=2*(d+1)-1,n=a[m],v=m+1,r=a[v];if(void 0!==n&&0>K(n,c))void 0!==r&&0>K(r,n)?(a[d]=r,a[v]=c,d=v):(a[d]=n,a[m]=c,d=m);else if(void 0!==r&&0>K(r,c))a[d]=r,a[v]=c,d=v;else break a}}return b}return null}function K(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}var N=[],O=[],P=1,Q=null,R=3,S=!1,T=!1,U=!1;\nfunction V(a){for(var b=L(O);null!==b;){if(null===b.callback)M(O);else if(b.startTime<=a)M(O),b.sortIndex=b.expirationTime,J(N,b);else break;b=L(O)}}function W(a){U=!1;V(a);if(!T)if(null!==L(N))T=!0,f(X);else{var b=L(O);null!==b&&g(W,b.startTime-a)}}\nfunction X(a,b){T=!1;U&&(U=!1,h());S=!0;var c=R;try{V(b);for(Q=L(N);null!==Q&&(!(Q.expirationTime>b)||a&&!k());){var d=Q.callback;if(null!==d){Q.callback=null;R=Q.priorityLevel;var e=d(Q.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?Q.callback=e:Q===L(N)&&M(N);V(b)}else M(N);Q=L(N)}if(null!==Q)var m=!0;else{var n=L(O);null!==n&&g(W,n.startTime-b);m=!1}return m}finally{Q=null,R=c,S=!1}}\nfunction Y(a){switch(a){case 1:return-1;case 2:return 250;case 5:return 1073741823;case 4:return 1E4;default:return 5E3}}var Z=l;exports.unstable_ImmediatePriority=1;exports.unstable_UserBlockingPriority=2;exports.unstable_NormalPriority=3;exports.unstable_IdlePriority=5;exports.unstable_LowPriority=4;exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=R;R=a;try{return b()}finally{R=c}};\nexports.unstable_next=function(a){switch(R){case 1:case 2:case 3:var b=3;break;default:b=R}var c=R;R=b;try{return a()}finally{R=c}};\nexports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();if(\"object\"===typeof c&&null!==c){var e=c.delay;e=\"number\"===typeof e&&0<e?d+e:d;c=\"number\"===typeof c.timeout?c.timeout:Y(a)}else c=Y(a),e=d;c=e+c;a={id:P++,callback:b,priorityLevel:a,startTime:e,expirationTime:c,sortIndex:-1};e>d?(a.sortIndex=e,J(O,a),null===L(N)&&a===L(O)&&(U?h():U=!0,g(W,e-d))):(a.sortIndex=c,J(N,a),T||S||(T=!0,f(X)));return a};exports.unstable_cancelCallback=function(a){a.callback=null};\nexports.unstable_wrapCallback=function(a){var b=R;return function(){var c=R;R=b;try{return a.apply(this,arguments)}finally{R=c}}};exports.unstable_getCurrentPriorityLevel=function(){return R};exports.unstable_shouldYield=function(){var a=exports.unstable_now();V(a);var b=L(N);return b!==Q&&null!==Q&&null!==b&&null!==b.callback&&b.startTime<=a&&b.expirationTime<Q.expirationTime||k()};exports.unstable_requestPaint=Z;exports.unstable_continueExecution=function(){T||S||(T=!0,f(X))};\nexports.unstable_pauseExecution=function(){};exports.unstable_getFirstCallbackNode=function(){return L(N)};exports.unstable_Profiling=null;\n","'use strict';\n\nvar utils = require('./utils');\nvar bind = require('./helpers/bind');\nvar Axios = require('./core/Axios');\nvar mergeConfig = require('./core/mergeConfig');\nvar defaults = require('./defaults');\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n * @return {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n var context = new Axios(defaultConfig);\n var instance = bind(Axios.prototype.request, context);\n\n // Copy axios.prototype to instance\n utils.extend(instance, Axios.prototype, context);\n\n // Copy context to instance\n utils.extend(instance, context);\n\n return instance;\n}\n\n// Create the default instance to be exported\nvar axios = createInstance(defaults);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios;\n\n// Factory for creating new instances\naxios.create = function create(instanceConfig) {\n return createInstance(mergeConfig(axios.defaults, instanceConfig));\n};\n\n// Expose Cancel & CancelToken\naxios.Cancel = require('./cancel/Cancel');\naxios.CancelToken = require('./cancel/CancelToken');\naxios.isCancel = require('./cancel/isCancel');\n\n// Expose all/spread\naxios.all = function all(promises) {\n return Promise.all(promises);\n};\naxios.spread = require('./helpers/spread');\n\nmodule.exports = axios;\n\n// Allow use of default import syntax in TypeScript\nmodule.exports.default = axios;\n","'use strict';\n\nvar utils = require('./../utils');\nvar buildURL = require('../helpers/buildURL');\nvar InterceptorManager = require('./InterceptorManager');\nvar dispatchRequest = require('./dispatchRequest');\nvar mergeConfig = require('./mergeConfig');\n\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n */\nfunction Axios(instanceConfig) {\n this.defaults = instanceConfig;\n this.interceptors = {\n request: new InterceptorManager(),\n response: new InterceptorManager()\n };\n}\n\n/**\n * Dispatch a request\n *\n * @param {Object} config The config specific for this request (merged with this.defaults)\n */\nAxios.prototype.request = function request(config) {\n /*eslint no-param-reassign:0*/\n // Allow for axios('example/url'[, config]) a la fetch API\n if (typeof config === 'string') {\n config = arguments[1] || {};\n config.url = arguments[0];\n } else {\n config = config || {};\n }\n\n config = mergeConfig(this.defaults, config);\n\n // Set config.method\n if (config.method) {\n config.method = config.method.toLowerCase();\n } else if (this.defaults.method) {\n config.method = this.defaults.method.toLowerCase();\n } else {\n config.method = 'get';\n }\n\n // Hook up interceptors middleware\n var chain = [dispatchRequest, undefined];\n var promise = Promise.resolve(config);\n\n this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n chain.unshift(interceptor.fulfilled, interceptor.rejected);\n });\n\n this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n chain.push(interceptor.fulfilled, interceptor.rejected);\n });\n\n while (chain.length) {\n promise = promise.then(chain.shift(), chain.shift());\n }\n\n return promise;\n};\n\nAxios.prototype.getUri = function getUri(config) {\n config = mergeConfig(this.defaults, config);\n return buildURL(config.url, config.params, config.paramsSerializer).replace(/^\\?/, '');\n};\n\n// Provide aliases for supported request methods\nutils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function(url, config) {\n return this.request(utils.merge(config || {}, {\n method: method,\n url: url\n }));\n };\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function(url, data, config) {\n return this.request(utils.merge(config || {}, {\n method: method,\n url: url,\n data: data\n }));\n };\n});\n\nmodule.exports = Axios;\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction InterceptorManager() {\n this.handlers = [];\n}\n\n/**\n * Add a new interceptor to the stack\n *\n * @param {Function} fulfilled The function to handle `then` for a `Promise`\n * @param {Function} rejected The function to handle `reject` for a `Promise`\n *\n * @return {Number} An ID used to remove interceptor later\n */\nInterceptorManager.prototype.use = function use(fulfilled, rejected) {\n this.handlers.push({\n fulfilled: fulfilled,\n rejected: rejected\n });\n return this.handlers.length - 1;\n};\n\n/**\n * Remove an interceptor from the stack\n *\n * @param {Number} id The ID that was returned by `use`\n */\nInterceptorManager.prototype.eject = function eject(id) {\n if (this.handlers[id]) {\n this.handlers[id] = null;\n }\n};\n\n/**\n * Iterate over all the registered interceptors\n *\n * This method is particularly useful for skipping over any\n * interceptors that may have become `null` calling `eject`.\n *\n * @param {Function} fn The function to call for each interceptor\n */\nInterceptorManager.prototype.forEach = function forEach(fn) {\n utils.forEach(this.handlers, function forEachHandler(h) {\n if (h !== null) {\n fn(h);\n }\n });\n};\n\nmodule.exports = InterceptorManager;\n","'use strict';\n\nvar utils = require('./../utils');\nvar transformData = require('./transformData');\nvar isCancel = require('../cancel/isCancel');\nvar defaults = require('../defaults');\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nfunction throwIfCancellationRequested(config) {\n if (config.cancelToken) {\n config.cancelToken.throwIfRequested();\n }\n}\n\n/**\n * Dispatch a request to the server using the configured adapter.\n *\n * @param {object} config The config that is to be used for the request\n * @returns {Promise} The Promise to be fulfilled\n */\nmodule.exports = function dispatchRequest(config) {\n throwIfCancellationRequested(config);\n\n // Ensure headers exist\n config.headers = config.headers || {};\n\n // Transform request data\n config.data = transformData(\n config.data,\n config.headers,\n config.transformRequest\n );\n\n // Flatten headers\n config.headers = utils.merge(\n config.headers.common || {},\n config.headers[config.method] || {},\n config.headers\n );\n\n utils.forEach(\n ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],\n function cleanHeaderConfig(method) {\n delete config.headers[method];\n }\n );\n\n var adapter = config.adapter || defaults.adapter;\n\n return adapter(config).then(function onAdapterResolution(response) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n response.data = transformData(\n response.data,\n response.headers,\n config.transformResponse\n );\n\n return response;\n }, function onAdapterRejection(reason) {\n if (!isCancel(reason)) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n if (reason && reason.response) {\n reason.response.data = transformData(\n reason.response.data,\n reason.response.headers,\n config.transformResponse\n );\n }\n }\n\n return Promise.reject(reason);\n });\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Object|String} data The data to be transformed\n * @param {Array} headers The headers for the request or response\n * @param {Array|Function} fns A single function or Array of functions\n * @returns {*} The resulting transformed data\n */\nmodule.exports = function transformData(data, headers, fns) {\n /*eslint no-param-reassign:0*/\n utils.forEach(fns, function transform(fn) {\n data = fn(data, headers);\n });\n\n return data;\n};\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\n\nvar utils = require('../utils');\n\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n utils.forEach(headers, function processHeader(value, name) {\n if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n headers[normalizedName] = value;\n delete headers[name];\n }\n });\n};\n","'use strict';\n\nvar createError = require('./createError');\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n */\nmodule.exports = function settle(resolve, reject, response) {\n var validateStatus = response.config.validateStatus;\n if (!validateStatus || validateStatus(response.status)) {\n resolve(response);\n } else {\n reject(createError(\n 'Request failed with status code ' + response.status,\n response.config,\n null,\n response.request,\n response\n ));\n }\n};\n","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n error.config = config;\n if (code) {\n error.code = code;\n }\n\n error.request = request;\n error.response = response;\n error.isAxiosError = true;\n\n error.toJSON = function() {\n return {\n // Standard\n message: this.message,\n name: this.name,\n // Microsoft\n description: this.description,\n number: this.number,\n // Mozilla\n fileName: this.fileName,\n lineNumber: this.lineNumber,\n columnNumber: this.columnNumber,\n stack: this.stack,\n // Axios\n config: this.config,\n code: this.code\n };\n };\n return error;\n};\n","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n if (baseURL && !isAbsoluteURL(requestedURL)) {\n return combineURLs(baseURL, requestedURL);\n }\n return requestedURL;\n};\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n // A URL is considered absolute if it begins with \"<scheme>://\" or \"//\" (protocol-relative URL).\n // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n // by any combination of letters, digits, plus, period, or hyphen.\n return /^([a-z][a-z\\d\\+\\-\\.]*:)?\\/\\//i.test(url);\n};\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n return relativeURL\n ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n : baseURL;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = [\n 'age', 'authorization', 'content-length', 'content-type', 'etag',\n 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n 'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n 'referer', 'retry-after', 'user-agent'\n];\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n var parsed = {};\n var key;\n var val;\n var i;\n\n if (!headers) { return parsed; }\n\n utils.forEach(headers.split('\\n'), function parser(line) {\n i = line.indexOf(':');\n key = utils.trim(line.substr(0, i)).toLowerCase();\n val = utils.trim(line.substr(i + 1));\n\n if (key) {\n if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n return;\n }\n if (key === 'set-cookie') {\n parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n } else {\n parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n }\n }\n });\n\n return parsed;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs have full support of the APIs needed to test\n // whether the request URL is of the same origin as current location.\n (function standardBrowserEnv() {\n var msie = /(msie|trident)/i.test(navigator.userAgent);\n var urlParsingNode = document.createElement('a');\n var originURL;\n\n /**\n * Parse a URL to discover it's components\n *\n * @param {String} url The URL to be parsed\n * @returns {Object}\n */\n function resolveURL(url) {\n var href = url;\n\n if (msie) {\n // IE needs attribute set twice to normalize properties\n urlParsingNode.setAttribute('href', href);\n href = urlParsingNode.href;\n }\n\n urlParsingNode.setAttribute('href', href);\n\n // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n return {\n href: urlParsingNode.href,\n protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n host: urlParsingNode.host,\n search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n hostname: urlParsingNode.hostname,\n port: urlParsingNode.port,\n pathname: (urlParsingNode.pathname.charAt(0) === '/') ?\n urlParsingNode.pathname :\n '/' + urlParsingNode.pathname\n };\n }\n\n originURL = resolveURL(window.location.href);\n\n /**\n * Determine if a URL shares the same origin as the current location\n *\n * @param {String} requestURL The URL to test\n * @returns {boolean} True if URL shares the same origin, otherwise false\n */\n return function isURLSameOrigin(requestURL) {\n var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;\n return (parsed.protocol === originURL.protocol &&\n parsed.host === originURL.host);\n };\n })() :\n\n // Non standard browser envs (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return function isURLSameOrigin() {\n return true;\n };\n })()\n);\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs support document.cookie\n (function standardBrowserEnv() {\n return {\n write: function write(name, value, expires, path, domain, secure) {\n var cookie = [];\n cookie.push(name + '=' + encodeURIComponent(value));\n\n if (utils.isNumber(expires)) {\n cookie.push('expires=' + new Date(expires).toGMTString());\n }\n\n if (utils.isString(path)) {\n cookie.push('path=' + path);\n }\n\n if (utils.isString(domain)) {\n cookie.push('domain=' + domain);\n }\n\n if (secure === true) {\n cookie.push('secure');\n }\n\n document.cookie = cookie.join('; ');\n },\n\n read: function read(name) {\n var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n return (match ? decodeURIComponent(match[3]) : null);\n },\n\n remove: function remove(name) {\n this.write(name, '', Date.now() - 86400000);\n }\n };\n })() :\n\n // Non standard browser env (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return {\n write: function write() {},\n read: function read() { return null; },\n remove: function remove() {}\n };\n })()\n);\n","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n if (typeof executor !== 'function') {\n throw new TypeError('executor must be a function.');\n }\n\n var resolvePromise;\n this.promise = new Promise(function promiseExecutor(resolve) {\n resolvePromise = resolve;\n });\n\n var token = this;\n executor(function cancel(message) {\n if (token.reason) {\n // Cancellation has already been requested\n return;\n }\n\n token.reason = new Cancel(message);\n resolvePromise(token.reason);\n });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n if (this.reason) {\n throw this.reason;\n }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n var cancel;\n var token = new CancelToken(function executor(c) {\n cancel = c;\n });\n return {\n token: token,\n cancel: cancel\n };\n};\n\nmodule.exports = CancelToken;\n","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n * ```js\n * function f(x, y, z) {}\n * var args = [1, 2, 3];\n * f.apply(null, args);\n * ```\n *\n * With `spread` this example can be re-written.\n *\n * ```js\n * spread(function(x, y, z) {})([1, 2, 3]);\n * ```\n *\n * @param {Function} callback\n * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/** @license React v16.12.0\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';Object.defineProperty(exports,\"__esModule\",{value:!0});\nvar b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?Symbol.for(\"react.suspense_list\"):\n60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.fundamental\"):60117,w=b?Symbol.for(\"react.responder\"):60118,x=b?Symbol.for(\"react.scope\"):60119;function y(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function z(a){return y(a)===m}\nexports.typeOf=y;exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;exports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===v||a.$$typeof===w||a.$$typeof===x)};exports.isAsyncMode=function(a){return z(a)||y(a)===l};exports.isConcurrentMode=z;exports.isContextConsumer=function(a){return y(a)===k};exports.isContextProvider=function(a){return y(a)===h};\nexports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return y(a)===n};exports.isFragment=function(a){return y(a)===e};exports.isLazy=function(a){return y(a)===t};exports.isMemo=function(a){return y(a)===r};exports.isPortal=function(a){return y(a)===d};exports.isProfiler=function(a){return y(a)===g};exports.isStrictMode=function(a){return y(a)===f};exports.isSuspense=function(a){return y(a)===p};\n","function _extends() {\n module.exports = _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nmodule.exports = _extends;","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","module.exports = Array.isArray || function (arr) {\n return Object.prototype.toString.call(arr) == '[object Array]';\n};\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n margin: 0\n },\n\n /* Styles applied to the root element if `variant=\"body2\"`. */\n body2: theme.typography.body2,\n\n /* Styles applied to the root element if `variant=\"body1\"`. */\n body1: theme.typography.body1,\n\n /* Styles applied to the root element if `variant=\"caption\"`. */\n caption: theme.typography.caption,\n\n /* Styles applied to the root element if `variant=\"button\"`. */\n button: theme.typography.button,\n\n /* Styles applied to the root element if `variant=\"h1\"`. */\n h1: theme.typography.h1,\n\n /* Styles applied to the root element if `variant=\"h2\"`. */\n h2: theme.typography.h2,\n\n /* Styles applied to the root element if `variant=\"h3\"`. */\n h3: theme.typography.h3,\n\n /* Styles applied to the root element if `variant=\"h4\"`. */\n h4: theme.typography.h4,\n\n /* Styles applied to the root element if `variant=\"h5\"`. */\n h5: theme.typography.h5,\n\n /* Styles applied to the root element if `variant=\"h6\"`. */\n h6: theme.typography.h6,\n\n /* Styles applied to the root element if `variant=\"subtitle1\"`. */\n subtitle1: theme.typography.subtitle1,\n\n /* Styles applied to the root element if `variant=\"subtitle2\"`. */\n subtitle2: theme.typography.subtitle2,\n\n /* Styles applied to the root element if `variant=\"overline\"`. */\n overline: theme.typography.overline,\n\n /* Styles applied to the root element if `variant=\"srOnly\"`. Only accessible to screen readers. */\n srOnly: {\n position: 'absolute',\n height: 1,\n width: 1,\n overflow: 'hidden'\n },\n\n /* Styles applied to the root element if `align=\"left\"`. */\n alignLeft: {\n textAlign: 'left'\n },\n\n /* Styles applied to the root element if `align=\"center\"`. */\n alignCenter: {\n textAlign: 'center'\n },\n\n /* Styles applied to the root element if `align=\"right\"`. */\n alignRight: {\n textAlign: 'right'\n },\n\n /* Styles applied to the root element if `align=\"justify\"`. */\n alignJustify: {\n textAlign: 'justify'\n },\n\n /* Styles applied to the root element if `nowrap={true}`. */\n noWrap: {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap'\n },\n\n /* Styles applied to the root element if `gutterBottom={true}`. */\n gutterBottom: {\n marginBottom: '0.35em'\n },\n\n /* Styles applied to the root element if `paragraph={true}`. */\n paragraph: {\n marginBottom: 16\n },\n\n /* Styles applied to the root element if `color=\"inherit\"`. */\n colorInherit: {\n color: 'inherit'\n },\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n color: theme.palette.primary.main\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n color: theme.palette.secondary.main\n },\n\n /* Styles applied to the root element if `color=\"textPrimary\"`. */\n colorTextPrimary: {\n color: theme.palette.text.primary\n },\n\n /* Styles applied to the root element if `color=\"textSecondary\"`. */\n colorTextSecondary: {\n color: theme.palette.text.secondary\n },\n\n /* Styles applied to the root element if `color=\"error\"`. */\n colorError: {\n color: theme.palette.error.main\n },\n\n /* Styles applied to the root element if `display=\"inline\"`. */\n displayInline: {\n display: 'inline'\n },\n\n /* Styles applied to the root element if `display=\"block\"`. */\n displayBlock: {\n display: 'block'\n }\n };\n};\nvar defaultVariantMapping = {\n h1: 'h1',\n h2: 'h2',\n h3: 'h3',\n h4: 'h4',\n h5: 'h5',\n h6: 'h6',\n subtitle1: 'h6',\n subtitle2: 'h6',\n body1: 'p',\n body2: 'p'\n};\nvar Typography = React.forwardRef(function Typography(props, ref) {\n var _props$align = props.align,\n align = _props$align === void 0 ? 'inherit' : _props$align,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'initial' : _props$color,\n component = props.component,\n _props$display = props.display,\n display = _props$display === void 0 ? 'initial' : _props$display,\n _props$gutterBottom = props.gutterBottom,\n gutterBottom = _props$gutterBottom === void 0 ? false : _props$gutterBottom,\n _props$noWrap = props.noWrap,\n noWrap = _props$noWrap === void 0 ? false : _props$noWrap,\n _props$paragraph = props.paragraph,\n paragraph = _props$paragraph === void 0 ? false : _props$paragraph,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'body1' : _props$variant,\n _props$variantMapping = props.variantMapping,\n variantMapping = _props$variantMapping === void 0 ? defaultVariantMapping : _props$variantMapping,\n other = _objectWithoutProperties(props, [\"align\", \"classes\", \"className\", \"color\", \"component\", \"display\", \"gutterBottom\", \"noWrap\", \"paragraph\", \"variant\", \"variantMapping\"]);\n\n var Component = component || (paragraph ? 'p' : variantMapping[variant] || defaultVariantMapping[variant]) || 'span';\n return React.createElement(Component, _extends({\n className: clsx(classes.root, className, variant !== 'inherit' && classes[variant], color !== 'initial' && classes[\"color\".concat(capitalize(color))], noWrap && classes.noWrap, gutterBottom && classes.gutterBottom, paragraph && classes.paragraph, align !== 'inherit' && classes[\"align\".concat(capitalize(align))], display !== 'initial' && classes[\"display\".concat(capitalize(display))]),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Typography.propTypes = {\n /**\n * Set the text-align on the component.\n */\n align: PropTypes.oneOf(['inherit', 'left', 'center', 'right', 'justify']),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['initial', 'inherit', 'primary', 'secondary', 'textPrimary', 'textSecondary', 'error']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n * Overrides the behavior of the `variantMapping` prop.\n */\n component: PropTypes.elementType,\n\n /**\n * Controls the display type\n */\n display: PropTypes.oneOf(['initial', 'block', 'inline']),\n\n /**\n * If `true`, the text will have a bottom margin.\n */\n gutterBottom: PropTypes.bool,\n\n /**\n * If `true`, the text will not wrap, but instead will truncate with a text overflow ellipsis.\n *\n * Note that text overflow can only happen with block or inline-block level elements\n * (the element needs to have a width in order to overflow).\n */\n noWrap: PropTypes.bool,\n\n /**\n * If `true`, the text will have a bottom margin.\n */\n paragraph: PropTypes.bool,\n\n /**\n * Applies the theme typography styles.\n */\n variant: PropTypes.oneOf(['h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'subtitle1', 'subtitle2', 'body1', 'body2', 'caption', 'button', 'overline', 'srOnly', 'inherit']),\n\n /**\n * The component maps the variant prop to a range of different DOM element types.\n * For instance, subtitle1 to `<h6>`.\n * If you wish to change that mapping, you can provide your own.\n * Alternatively, you can use the `component` prop.\n */\n variantMapping: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTypography'\n})(Typography);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { chainPropTypes } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport { fade } from '../styles/colorManipulator';\nimport ButtonBase from '../ButtonBase';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n textAlign: 'center',\n flex: '0 0 auto',\n fontSize: theme.typography.pxToRem(24),\n padding: 12,\n borderRadius: '50%',\n overflow: 'visible',\n // Explicitly set the default value to solve a bug on IE 11.\n color: theme.palette.action.active,\n transition: theme.transitions.create('background-color', {\n duration: theme.transitions.duration.shortest\n }),\n '&:hover': {\n backgroundColor: fade(theme.palette.action.active, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n },\n '&$disabled': {\n backgroundColor: 'transparent',\n color: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if `edge=\"start\"`. */\n edgeStart: {\n marginLeft: -12,\n '$sizeSmall&': {\n marginLeft: -3\n }\n },\n\n /* Styles applied to the root element if `edge=\"end\"`. */\n edgeEnd: {\n marginRight: -12,\n '$sizeSmall&': {\n marginRight: -3\n }\n },\n\n /* Styles applied to the root element if `color=\"inherit\"`. */\n colorInherit: {\n color: 'inherit'\n },\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `size=\"small\"`. */\n sizeSmall: {\n padding: 3,\n fontSize: theme.typography.pxToRem(18)\n },\n\n /* Styles applied to the children container element. */\n label: {\n width: '100%',\n display: 'flex',\n alignItems: 'inherit',\n justifyContent: 'inherit'\n }\n };\n};\n/**\n * Refer to the [Icons](/components/icons/) section of the documentation\n * regarding the available icon options.\n */\n\nvar IconButton = React.forwardRef(function IconButton(props, ref) {\n var _props$edge = props.edge,\n edge = _props$edge === void 0 ? false : _props$edge,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'default' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableFocusRi = props.disableFocusRipple,\n disableFocusRipple = _props$disableFocusRi === void 0 ? false : _props$disableFocusRi,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"edge\", \"children\", \"classes\", \"className\", \"color\", \"disabled\", \"disableFocusRipple\", \"size\"]);\n\n return React.createElement(ButtonBase, _extends({\n className: clsx(classes.root, className, color !== 'default' && classes[\"color\".concat(capitalize(color))], disabled && classes.disabled, {\n small: classes[\"size\".concat(capitalize(size))]\n }[size], {\n start: classes.edgeStart,\n end: classes.edgeEnd\n }[edge]),\n centerRipple: true,\n focusRipple: !disableFocusRipple,\n disabled: disabled,\n ref: ref\n }, other), React.createElement(\"span\", {\n className: classes.label\n }, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? IconButton.propTypes = {\n /**\n * The icon element.\n */\n children: chainPropTypes(PropTypes.node, function (props) {\n var found = React.Children.toArray(props.children).some(function (child) {\n return React.isValidElement(child) && child.props.onClick;\n });\n\n if (found) {\n return new Error(['Material-UI: you are providing an onClick event listener ' + 'to a child of a button element.', 'Firefox will never trigger the event.', 'You should move the onClick listener to the parent button element.', 'https://github.com/mui-org/material-ui/issues/13957'].join('\\n'));\n }\n\n return null;\n }),\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['default', 'inherit', 'primary', 'secondary']),\n\n /**\n * If `true`, the button will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the keyboard focus ripple will be disabled.\n * `disableRipple` must also be true.\n */\n disableFocusRipple: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * If given, uses a negative margin to counteract the padding on one\n * side (this is often helpful for aligning the left or right\n * side of the icon with content above or below, without ruining the border\n * size and shape).\n */\n edge: PropTypes.oneOf(['start', 'end', false]),\n\n /**\n * The size of the button.\n * `small` is equivalent to the dense button styling.\n */\n size: PropTypes.oneOf(['small', 'medium'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiIconButton'\n})(IconButton);","var _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nexport var isBrowser = (typeof window === \"undefined\" ? \"undefined\" : _typeof(window)) === \"object\" && (typeof document === \"undefined\" ? \"undefined\" : _typeof(document)) === 'object' && document.nodeType === 9;\n\nexport default isBrowser;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport isInBrowser from 'is-in-browser';\nimport warning from 'tiny-warning';\nimport _createClass from '@babel/runtime/helpers/esm/createClass';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport _assertThisInitialized from '@babel/runtime/helpers/esm/assertThisInitialized';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\n\nvar plainObjectConstrurctor = {}.constructor;\nfunction cloneStyle(style) {\n if (style == null || typeof style !== 'object') return style;\n if (Array.isArray(style)) return style.map(cloneStyle);\n if (style.constructor !== plainObjectConstrurctor) return style;\n var newStyle = {};\n\n for (var name in style) {\n newStyle[name] = cloneStyle(style[name]);\n }\n\n return newStyle;\n}\n\n/**\n * Create a rule instance.\n */\n\nfunction createRule(name, decl, options) {\n if (name === void 0) {\n name = 'unnamed';\n }\n\n var jss = options.jss;\n var declCopy = cloneStyle(decl);\n var rule = jss.plugins.onCreateRule(name, declCopy, options);\n if (rule) return rule; // It is an at-rule and it has no instance.\n\n if (name[0] === '@') {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Unknown rule \" + name) : void 0;\n }\n\n return null;\n}\n\nvar join = function join(value, by) {\n var result = '';\n\n for (var i = 0; i < value.length; i++) {\n // Remove !important from the value, it will be readded later.\n if (value[i] === '!important') break;\n if (result) result += by;\n result += value[i];\n }\n\n return result;\n};\n/**\n * Converts array values to string.\n *\n * `margin: [['5px', '10px']]` > `margin: 5px 10px;`\n * `border: ['1px', '2px']` > `border: 1px, 2px;`\n * `margin: [['5px', '10px'], '!important']` > `margin: 5px 10px !important;`\n * `color: ['red', !important]` > `color: red !important;`\n */\n\n\nfunction toCssValue(value, ignoreImportant) {\n if (ignoreImportant === void 0) {\n ignoreImportant = false;\n }\n\n if (!Array.isArray(value)) return value;\n var cssValue = ''; // Support space separated values via `[['5px', '10px']]`.\n\n if (Array.isArray(value[0])) {\n for (var i = 0; i < value.length; i++) {\n if (value[i] === '!important') break;\n if (cssValue) cssValue += ', ';\n cssValue += join(value[i], ' ');\n }\n } else cssValue = join(value, ', '); // Add !important, because it was ignored.\n\n\n if (!ignoreImportant && value[value.length - 1] === '!important') {\n cssValue += ' !important';\n }\n\n return cssValue;\n}\n\n/**\n * Indent a string.\n * http://jsperf.com/array-join-vs-for\n */\nfunction indentStr(str, indent) {\n var result = '';\n\n for (var index = 0; index < indent; index++) {\n result += ' ';\n }\n\n return result + str;\n}\n/**\n * Converts a Rule to CSS string.\n */\n\n\nfunction toCss(selector, style, options) {\n if (options === void 0) {\n options = {};\n }\n\n var result = '';\n if (!style) return result;\n var _options = options,\n _options$indent = _options.indent,\n indent = _options$indent === void 0 ? 0 : _options$indent;\n var fallbacks = style.fallbacks;\n if (selector) indent++; // Apply fallbacks first.\n\n if (fallbacks) {\n // Array syntax {fallbacks: [{prop: value}]}\n if (Array.isArray(fallbacks)) {\n for (var index = 0; index < fallbacks.length; index++) {\n var fallback = fallbacks[index];\n\n for (var prop in fallback) {\n var value = fallback[prop];\n\n if (value != null) {\n if (result) result += '\\n';\n result += \"\" + indentStr(prop + \": \" + toCssValue(value) + \";\", indent);\n }\n }\n }\n } else {\n // Object syntax {fallbacks: {prop: value}}\n for (var _prop in fallbacks) {\n var _value = fallbacks[_prop];\n\n if (_value != null) {\n if (result) result += '\\n';\n result += \"\" + indentStr(_prop + \": \" + toCssValue(_value) + \";\", indent);\n }\n }\n }\n }\n\n for (var _prop2 in style) {\n var _value2 = style[_prop2];\n\n if (_value2 != null && _prop2 !== 'fallbacks') {\n if (result) result += '\\n';\n result += \"\" + indentStr(_prop2 + \": \" + toCssValue(_value2) + \";\", indent);\n }\n } // Allow empty style in this case, because properties will be added dynamically.\n\n\n if (!result && !options.allowEmpty) return result; // When rule is being stringified before selector was defined.\n\n if (!selector) return result;\n indent--;\n if (result) result = \"\\n\" + result + \"\\n\";\n return indentStr(selector + \" {\" + result, indent) + indentStr('}', indent);\n}\n\nvar escapeRegex = /([[\\].#*$><+~=|^:(),\"'`\\s])/g;\nvar nativeEscape = typeof CSS !== 'undefined' && CSS.escape;\nvar escape = (function (str) {\n return nativeEscape ? nativeEscape(str) : str.replace(escapeRegex, '\\\\$1');\n});\n\nvar BaseStyleRule =\n/*#__PURE__*/\nfunction () {\n function BaseStyleRule(key, style, options) {\n this.type = 'style';\n this.key = void 0;\n this.isProcessed = false;\n this.style = void 0;\n this.renderer = void 0;\n this.renderable = void 0;\n this.options = void 0;\n var sheet = options.sheet,\n Renderer = options.Renderer;\n this.key = key;\n this.options = options;\n this.style = style;\n if (sheet) this.renderer = sheet.renderer;else if (Renderer) this.renderer = new Renderer();\n }\n /**\n * Get or set a style property.\n */\n\n\n var _proto = BaseStyleRule.prototype;\n\n _proto.prop = function prop(name, value, options) {\n // It's a getter.\n if (value === undefined) return this.style[name]; // Don't do anything if the value has not changed.\n\n var force = options ? options.force : false;\n if (!force && this.style[name] === value) return this;\n var newValue = value;\n\n if (!options || options.process !== false) {\n newValue = this.options.jss.plugins.onChangeValue(value, name, this);\n }\n\n var isEmpty = newValue == null || newValue === false;\n var isDefined = name in this.style; // Value is empty and wasn't defined before.\n\n if (isEmpty && !isDefined && !force) return this; // We are going to remove this value.\n\n var remove = isEmpty && isDefined;\n if (remove) delete this.style[name];else this.style[name] = newValue; // Renderable is defined if StyleSheet option `link` is true.\n\n if (this.renderable && this.renderer) {\n if (remove) this.renderer.removeProperty(this.renderable, name);else this.renderer.setProperty(this.renderable, name, newValue);\n return this;\n }\n\n var sheet = this.options.sheet;\n\n if (sheet && sheet.attached) {\n process.env.NODE_ENV !== \"production\" ? warning(false, '[JSS] Rule is not linked. Missing sheet option \"link: true\".') : void 0;\n }\n\n return this;\n };\n\n return BaseStyleRule;\n}();\nvar StyleRule =\n/*#__PURE__*/\nfunction (_BaseStyleRule) {\n _inheritsLoose(StyleRule, _BaseStyleRule);\n\n function StyleRule(key, style, options) {\n var _this;\n\n _this = _BaseStyleRule.call(this, key, style, options) || this;\n _this.selectorText = void 0;\n _this.id = void 0;\n _this.renderable = void 0;\n var selector = options.selector,\n scoped = options.scoped,\n sheet = options.sheet,\n generateId = options.generateId;\n\n if (selector) {\n _this.selectorText = selector;\n } else if (scoped !== false) {\n _this.id = generateId(_assertThisInitialized(_assertThisInitialized(_this)), sheet);\n _this.selectorText = \".\" + escape(_this.id);\n }\n\n return _this;\n }\n /**\n * Set selector string.\n * Attention: use this with caution. Most browsers didn't implement\n * selectorText setter, so this may result in rerendering of entire Style Sheet.\n */\n\n\n var _proto2 = StyleRule.prototype;\n\n /**\n * Apply rule to an element inline.\n */\n _proto2.applyTo = function applyTo(renderable) {\n var renderer = this.renderer;\n\n if (renderer) {\n var json = this.toJSON();\n\n for (var prop in json) {\n renderer.setProperty(renderable, prop, json[prop]);\n }\n }\n\n return this;\n }\n /**\n * Returns JSON representation of the rule.\n * Fallbacks are not supported.\n * Useful for inline styles.\n */\n ;\n\n _proto2.toJSON = function toJSON() {\n var json = {};\n\n for (var prop in this.style) {\n var value = this.style[prop];\n if (typeof value !== 'object') json[prop] = value;else if (Array.isArray(value)) json[prop] = toCssValue(value);\n }\n\n return json;\n }\n /**\n * Generates a CSS string.\n */\n ;\n\n _proto2.toString = function toString(options) {\n var sheet = this.options.sheet;\n var link = sheet ? sheet.options.link : false;\n var opts = link ? _extends({}, options, {\n allowEmpty: true\n }) : options;\n return toCss(this.selectorText, this.style, opts);\n };\n\n _createClass(StyleRule, [{\n key: \"selector\",\n set: function set(selector) {\n if (selector === this.selectorText) return;\n this.selectorText = selector;\n var renderer = this.renderer,\n renderable = this.renderable;\n if (!renderable || !renderer) return;\n var hasChanged = renderer.setSelector(renderable, selector); // If selector setter is not implemented, rerender the rule.\n\n if (!hasChanged) {\n renderer.replaceRule(renderable, this);\n }\n }\n /**\n * Get selector string.\n */\n ,\n get: function get() {\n return this.selectorText;\n }\n }]);\n\n return StyleRule;\n}(BaseStyleRule);\nvar pluginStyleRule = {\n onCreateRule: function onCreateRule(name, style, options) {\n if (name[0] === '@' || options.parent && options.parent.type === 'keyframes') {\n return null;\n }\n\n return new StyleRule(name, style, options);\n }\n};\n\nvar defaultToStringOptions = {\n indent: 1,\n children: true\n};\nvar atRegExp = /@([\\w-]+)/;\n/**\n * Conditional rule for @media, @supports\n */\n\nvar ConditionalRule =\n/*#__PURE__*/\nfunction () {\n function ConditionalRule(key, styles, options) {\n this.type = 'conditional';\n this.at = void 0;\n this.key = void 0;\n this.query = void 0;\n this.rules = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key; // Key might contain a unique suffix in case the `name` passed by user was duplicate.\n\n this.query = options.name;\n var atMatch = key.match(atRegExp);\n this.at = atMatch ? atMatch[1] : 'unknown';\n this.options = options;\n this.rules = new RuleList(_extends({}, options, {\n parent: this\n }));\n\n for (var name in styles) {\n this.rules.add(name, styles[name]);\n }\n\n this.rules.process();\n }\n /**\n * Get a rule.\n */\n\n\n var _proto = ConditionalRule.prototype;\n\n _proto.getRule = function getRule(name) {\n return this.rules.get(name);\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.rules.indexOf(rule);\n }\n /**\n * Create and register rule, run plugins.\n */\n ;\n\n _proto.addRule = function addRule(name, style, options) {\n var rule = this.rules.add(name, style, options);\n if (!rule) return null;\n this.options.jss.plugins.onProcessRule(rule);\n return rule;\n }\n /**\n * Generates a CSS string.\n */\n ;\n\n _proto.toString = function toString(options) {\n if (options === void 0) {\n options = defaultToStringOptions;\n }\n\n if (options.indent == null) options.indent = defaultToStringOptions.indent;\n if (options.children == null) options.children = defaultToStringOptions.children;\n\n if (options.children === false) {\n return this.query + \" {}\";\n }\n\n var children = this.rules.toString(options);\n return children ? this.query + \" {\\n\" + children + \"\\n}\" : '';\n };\n\n return ConditionalRule;\n}();\nvar keyRegExp = /@media|@supports\\s+/;\nvar pluginConditionalRule = {\n onCreateRule: function onCreateRule(key, styles, options) {\n return keyRegExp.test(key) ? new ConditionalRule(key, styles, options) : null;\n }\n};\n\nvar defaultToStringOptions$1 = {\n indent: 1,\n children: true\n};\nvar nameRegExp = /@keyframes\\s+([\\w-]+)/;\n/**\n * Rule for @keyframes\n */\n\nvar KeyframesRule =\n/*#__PURE__*/\nfunction () {\n function KeyframesRule(key, frames, options) {\n this.type = 'keyframes';\n this.at = '@keyframes';\n this.key = void 0;\n this.name = void 0;\n this.id = void 0;\n this.rules = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n var nameMatch = key.match(nameRegExp);\n\n if (nameMatch && nameMatch[1]) {\n this.name = nameMatch[1];\n } else {\n this.name = 'noname';\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Bad keyframes name \" + key) : void 0;\n }\n\n this.key = this.type + \"-\" + this.name;\n this.options = options;\n var scoped = options.scoped,\n sheet = options.sheet,\n generateId = options.generateId;\n this.id = scoped === false ? this.name : escape(generateId(this, sheet));\n this.rules = new RuleList(_extends({}, options, {\n parent: this\n }));\n\n for (var name in frames) {\n this.rules.add(name, frames[name], _extends({}, options, {\n parent: this\n }));\n }\n\n this.rules.process();\n }\n /**\n * Generates a CSS string.\n */\n\n\n var _proto = KeyframesRule.prototype;\n\n _proto.toString = function toString(options) {\n if (options === void 0) {\n options = defaultToStringOptions$1;\n }\n\n if (options.indent == null) options.indent = defaultToStringOptions$1.indent;\n if (options.children == null) options.children = defaultToStringOptions$1.children;\n\n if (options.children === false) {\n return this.at + \" \" + this.id + \" {}\";\n }\n\n var children = this.rules.toString(options);\n if (children) children = \"\\n\" + children + \"\\n\";\n return this.at + \" \" + this.id + \" {\" + children + \"}\";\n };\n\n return KeyframesRule;\n}();\nvar keyRegExp$1 = /@keyframes\\s+/;\nvar refRegExp = /\\$([\\w-]+)/g;\n\nvar findReferencedKeyframe = function findReferencedKeyframe(val, keyframes) {\n if (typeof val === 'string') {\n return val.replace(refRegExp, function (match, name) {\n if (name in keyframes) {\n return keyframes[name];\n }\n\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Referenced keyframes rule \\\"\" + name + \"\\\" is not defined.\") : void 0;\n return match;\n });\n }\n\n return val;\n};\n/**\n * Replace the reference for a animation name.\n */\n\n\nvar replaceRef = function replaceRef(style, prop, keyframes) {\n var value = style[prop];\n var refKeyframe = findReferencedKeyframe(value, keyframes);\n\n if (refKeyframe !== value) {\n style[prop] = refKeyframe;\n }\n};\n\nvar plugin = {\n onCreateRule: function onCreateRule(key, frames, options) {\n return typeof key === 'string' && keyRegExp$1.test(key) ? new KeyframesRule(key, frames, options) : null;\n },\n // Animation name ref replacer.\n onProcessStyle: function onProcessStyle(style, rule, sheet) {\n if (rule.type !== 'style' || !sheet) return style;\n if ('animation-name' in style) replaceRef(style, 'animation-name', sheet.keyframes);\n if ('animation' in style) replaceRef(style, 'animation', sheet.keyframes);\n return style;\n },\n onChangeValue: function onChangeValue(val, prop, rule) {\n var sheet = rule.options.sheet;\n\n if (!sheet) {\n return val;\n }\n\n switch (prop) {\n case 'animation':\n return findReferencedKeyframe(val, sheet.keyframes);\n\n case 'animation-name':\n return findReferencedKeyframe(val, sheet.keyframes);\n\n default:\n return val;\n }\n }\n};\n\nvar KeyframeRule =\n/*#__PURE__*/\nfunction (_BaseStyleRule) {\n _inheritsLoose(KeyframeRule, _BaseStyleRule);\n\n function KeyframeRule() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _BaseStyleRule.call.apply(_BaseStyleRule, [this].concat(args)) || this;\n _this.renderable = void 0;\n return _this;\n }\n\n var _proto = KeyframeRule.prototype;\n\n /**\n * Generates a CSS string.\n */\n _proto.toString = function toString(options) {\n var sheet = this.options.sheet;\n var link = sheet ? sheet.options.link : false;\n var opts = link ? _extends({}, options, {\n allowEmpty: true\n }) : options;\n return toCss(this.key, this.style, opts);\n };\n\n return KeyframeRule;\n}(BaseStyleRule);\nvar pluginKeyframeRule = {\n onCreateRule: function onCreateRule(key, style, options) {\n if (options.parent && options.parent.type === 'keyframes') {\n return new KeyframeRule(key, style, options);\n }\n\n return null;\n }\n};\n\nvar FontFaceRule =\n/*#__PURE__*/\nfunction () {\n function FontFaceRule(key, style, options) {\n this.type = 'font-face';\n this.at = '@font-face';\n this.key = void 0;\n this.style = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key;\n this.style = style;\n this.options = options;\n }\n /**\n * Generates a CSS string.\n */\n\n\n var _proto = FontFaceRule.prototype;\n\n _proto.toString = function toString(options) {\n if (Array.isArray(this.style)) {\n var str = '';\n\n for (var index = 0; index < this.style.length; index++) {\n str += toCss(this.key, this.style[index]);\n if (this.style[index + 1]) str += '\\n';\n }\n\n return str;\n }\n\n return toCss(this.key, this.style, options);\n };\n\n return FontFaceRule;\n}();\nvar pluginFontFaceRule = {\n onCreateRule: function onCreateRule(key, style, options) {\n return key === '@font-face' ? new FontFaceRule(key, style, options) : null;\n }\n};\n\nvar ViewportRule =\n/*#__PURE__*/\nfunction () {\n function ViewportRule(key, style, options) {\n this.type = 'viewport';\n this.at = '@viewport';\n this.key = void 0;\n this.style = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key;\n this.style = style;\n this.options = options;\n }\n /**\n * Generates a CSS string.\n */\n\n\n var _proto = ViewportRule.prototype;\n\n _proto.toString = function toString(options) {\n return toCss(this.key, this.style, options);\n };\n\n return ViewportRule;\n}();\nvar pluginViewportRule = {\n onCreateRule: function onCreateRule(key, style, options) {\n return key === '@viewport' || key === '@-ms-viewport' ? new ViewportRule(key, style, options) : null;\n }\n};\n\nvar SimpleRule =\n/*#__PURE__*/\nfunction () {\n function SimpleRule(key, value, options) {\n this.type = 'simple';\n this.key = void 0;\n this.value = void 0;\n this.options = void 0;\n this.isProcessed = false;\n this.renderable = void 0;\n this.key = key;\n this.value = value;\n this.options = options;\n }\n /**\n * Generates a CSS string.\n */\n // eslint-disable-next-line no-unused-vars\n\n\n var _proto = SimpleRule.prototype;\n\n _proto.toString = function toString(options) {\n if (Array.isArray(this.value)) {\n var str = '';\n\n for (var index = 0; index < this.value.length; index++) {\n str += this.key + \" \" + this.value[index] + \";\";\n if (this.value[index + 1]) str += '\\n';\n }\n\n return str;\n }\n\n return this.key + \" \" + this.value + \";\";\n };\n\n return SimpleRule;\n}();\nvar keysMap = {\n '@charset': true,\n '@import': true,\n '@namespace': true\n};\nvar pluginSimpleRule = {\n onCreateRule: function onCreateRule(key, value, options) {\n return key in keysMap ? new SimpleRule(key, value, options) : null;\n }\n};\n\nvar plugins = [pluginStyleRule, pluginConditionalRule, plugin, pluginKeyframeRule, pluginFontFaceRule, pluginViewportRule, pluginSimpleRule];\n\nvar defaultUpdateOptions = {\n process: true\n};\nvar forceUpdateOptions = {\n force: true,\n process: true\n /**\n * Contains rules objects and allows adding/removing etc.\n * Is used for e.g. by `StyleSheet` or `ConditionalRule`.\n */\n\n};\n\nvar RuleList =\n/*#__PURE__*/\nfunction () {\n // Rules registry for access by .get() method.\n // It contains the same rule registered by name and by selector.\n // Original styles object.\n // Used to ensure correct rules order.\n function RuleList(options) {\n this.map = {};\n this.raw = {};\n this.index = [];\n this.counter = 0;\n this.options = void 0;\n this.classes = void 0;\n this.keyframes = void 0;\n this.options = options;\n this.classes = options.classes;\n this.keyframes = options.keyframes;\n }\n /**\n * Create and register rule.\n *\n * Will not render after Style Sheet was rendered the first time.\n */\n\n\n var _proto = RuleList.prototype;\n\n _proto.add = function add(name, decl, ruleOptions) {\n var _this$options = this.options,\n parent = _this$options.parent,\n sheet = _this$options.sheet,\n jss = _this$options.jss,\n Renderer = _this$options.Renderer,\n generateId = _this$options.generateId,\n scoped = _this$options.scoped;\n\n var options = _extends({\n classes: this.classes,\n parent: parent,\n sheet: sheet,\n jss: jss,\n Renderer: Renderer,\n generateId: generateId,\n scoped: scoped,\n name: name\n }, ruleOptions); // When user uses .createStyleSheet(), duplicate names are not possible, but\n // `sheet.addRule()` opens the door for any duplicate rule name. When this happens\n // we need to make the key unique within this RuleList instance scope.\n\n\n var key = name;\n\n if (name in this.raw) {\n key = name + \"-d\" + this.counter++;\n } // We need to save the original decl before creating the rule\n // because cache plugin needs to use it as a key to return a cached rule.\n\n\n this.raw[key] = decl;\n\n if (key in this.classes) {\n // E.g. rules inside of @media container\n options.selector = \".\" + escape(this.classes[key]);\n }\n\n var rule = createRule(key, decl, options);\n if (!rule) return null;\n this.register(rule);\n var index = options.index === undefined ? this.index.length : options.index;\n this.index.splice(index, 0, rule);\n return rule;\n }\n /**\n * Get a rule.\n */\n ;\n\n _proto.get = function get(name) {\n return this.map[name];\n }\n /**\n * Delete a rule.\n */\n ;\n\n _proto.remove = function remove(rule) {\n this.unregister(rule);\n delete this.raw[rule.key];\n this.index.splice(this.index.indexOf(rule), 1);\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.index.indexOf(rule);\n }\n /**\n * Run `onProcessRule()` plugins on every rule.\n */\n ;\n\n _proto.process = function process() {\n var plugins$$1 = this.options.jss.plugins; // We need to clone array because if we modify the index somewhere else during a loop\n // we end up with very hard-to-track-down side effects.\n\n this.index.slice(0).forEach(plugins$$1.onProcessRule, plugins$$1);\n }\n /**\n * Register a rule in `.map`, `.classes` and `.keyframes` maps.\n */\n ;\n\n _proto.register = function register(rule) {\n this.map[rule.key] = rule;\n\n if (rule instanceof StyleRule) {\n this.map[rule.selector] = rule;\n if (rule.id) this.classes[rule.key] = rule.id;\n } else if (rule instanceof KeyframesRule && this.keyframes) {\n this.keyframes[rule.name] = rule.id;\n }\n }\n /**\n * Unregister a rule.\n */\n ;\n\n _proto.unregister = function unregister(rule) {\n delete this.map[rule.key];\n\n if (rule instanceof StyleRule) {\n delete this.map[rule.selector];\n delete this.classes[rule.key];\n } else if (rule instanceof KeyframesRule) {\n delete this.keyframes[rule.name];\n }\n }\n /**\n * Update the function values with a new data.\n */\n ;\n\n _proto.update = function update() {\n var name;\n var data;\n var options;\n\n if (typeof (arguments.length <= 0 ? undefined : arguments[0]) === 'string') {\n name = arguments.length <= 0 ? undefined : arguments[0]; // $FlowFixMe\n\n data = arguments.length <= 1 ? undefined : arguments[1]; // $FlowFixMe\n\n options = arguments.length <= 2 ? undefined : arguments[2];\n } else {\n data = arguments.length <= 0 ? undefined : arguments[0]; // $FlowFixMe\n\n options = arguments.length <= 1 ? undefined : arguments[1];\n name = null;\n }\n\n if (name) {\n this.updateOne(this.map[name], data, options);\n } else {\n for (var index = 0; index < this.index.length; index++) {\n this.updateOne(this.index[index], data, options);\n }\n }\n }\n /**\n * Execute plugins, update rule props.\n */\n ;\n\n _proto.updateOne = function updateOne(rule, data, options) {\n if (options === void 0) {\n options = defaultUpdateOptions;\n }\n\n var _this$options2 = this.options,\n plugins$$1 = _this$options2.jss.plugins,\n sheet = _this$options2.sheet; // It is a rules container like for e.g. ConditionalRule.\n\n if (rule.rules instanceof RuleList) {\n rule.rules.update(data, options);\n return;\n }\n\n var styleRule = rule;\n var style = styleRule.style;\n plugins$$1.onUpdate(data, rule, sheet, options); // We rely on a new `style` ref in case it was mutated during onUpdate hook.\n\n if (options.process && style && style !== styleRule.style) {\n // We need to run the plugins in case new `style` relies on syntax plugins.\n plugins$$1.onProcessStyle(styleRule.style, styleRule, sheet); // Update and add props.\n\n for (var prop in styleRule.style) {\n var nextValue = styleRule.style[prop];\n var prevValue = style[prop]; // We need to use `force: true` because `rule.style` has been updated during onUpdate hook, so `rule.prop()` will not update the CSSOM rule.\n // We do this comparison to avoid unneeded `rule.prop()` calls, since we have the old `style` object here.\n\n if (nextValue !== prevValue) {\n styleRule.prop(prop, nextValue, forceUpdateOptions);\n }\n } // Remove props.\n\n\n for (var _prop in style) {\n var _nextValue = styleRule.style[_prop];\n var _prevValue = style[_prop]; // We need to use `force: true` because `rule.style` has been updated during onUpdate hook, so `rule.prop()` will not update the CSSOM rule.\n // We do this comparison to avoid unneeded `rule.prop()` calls, since we have the old `style` object here.\n\n if (_nextValue == null && _nextValue !== _prevValue) {\n styleRule.prop(_prop, null, forceUpdateOptions);\n }\n }\n }\n }\n /**\n * Convert rules to a CSS string.\n */\n ;\n\n _proto.toString = function toString(options) {\n var str = '';\n var sheet = this.options.sheet;\n var link = sheet ? sheet.options.link : false;\n\n for (var index = 0; index < this.index.length; index++) {\n var rule = this.index[index];\n var css = rule.toString(options); // No need to render an empty rule.\n\n if (!css && !link) continue;\n if (str) str += '\\n';\n str += css;\n }\n\n return str;\n };\n\n return RuleList;\n}();\n\nvar StyleSheet =\n/*#__PURE__*/\nfunction () {\n function StyleSheet(styles, options) {\n this.options = void 0;\n this.deployed = void 0;\n this.attached = void 0;\n this.rules = void 0;\n this.renderer = void 0;\n this.classes = void 0;\n this.keyframes = void 0;\n this.queue = void 0;\n this.attached = false;\n this.deployed = false;\n this.classes = {};\n this.keyframes = {};\n this.options = _extends({}, options, {\n sheet: this,\n parent: this,\n classes: this.classes,\n keyframes: this.keyframes\n });\n\n if (options.Renderer) {\n this.renderer = new options.Renderer(this);\n }\n\n this.rules = new RuleList(this.options);\n\n for (var name in styles) {\n this.rules.add(name, styles[name]);\n }\n\n this.rules.process();\n }\n /**\n * Attach renderable to the render tree.\n */\n\n\n var _proto = StyleSheet.prototype;\n\n _proto.attach = function attach() {\n if (this.attached) return this;\n if (this.renderer) this.renderer.attach();\n this.attached = true; // Order is important, because we can't use insertRule API if style element is not attached.\n\n if (!this.deployed) this.deploy();\n return this;\n }\n /**\n * Remove renderable from render tree.\n */\n ;\n\n _proto.detach = function detach() {\n if (!this.attached) return this;\n if (this.renderer) this.renderer.detach();\n this.attached = false;\n return this;\n }\n /**\n * Add a rule to the current stylesheet.\n * Will insert a rule also after the stylesheet has been rendered first time.\n */\n ;\n\n _proto.addRule = function addRule(name, decl, options) {\n var queue = this.queue; // Plugins can create rules.\n // In order to preserve the right order, we need to queue all `.addRule` calls,\n // which happen after the first `rules.add()` call.\n\n if (this.attached && !queue) this.queue = [];\n var rule = this.rules.add(name, decl, options);\n if (!rule) return null;\n this.options.jss.plugins.onProcessRule(rule);\n\n if (this.attached) {\n if (!this.deployed) return rule; // Don't insert rule directly if there is no stringified version yet.\n // It will be inserted all together when .attach is called.\n\n if (queue) queue.push(rule);else {\n this.insertRule(rule);\n\n if (this.queue) {\n this.queue.forEach(this.insertRule, this);\n this.queue = undefined;\n }\n }\n return rule;\n } // We can't add rules to a detached style node.\n // We will redeploy the sheet once user will attach it.\n\n\n this.deployed = false;\n return rule;\n }\n /**\n * Insert rule into the StyleSheet\n */\n ;\n\n _proto.insertRule = function insertRule(rule) {\n if (this.renderer) {\n this.renderer.insertRule(rule);\n }\n }\n /**\n * Create and add rules.\n * Will render also after Style Sheet was rendered the first time.\n */\n ;\n\n _proto.addRules = function addRules(styles, options) {\n var added = [];\n\n for (var name in styles) {\n var rule = this.addRule(name, styles[name], options);\n if (rule) added.push(rule);\n }\n\n return added;\n }\n /**\n * Get a rule by name.\n */\n ;\n\n _proto.getRule = function getRule(name) {\n return this.rules.get(name);\n }\n /**\n * Delete a rule by name.\n * Returns `true`: if rule has been deleted from the DOM.\n */\n ;\n\n _proto.deleteRule = function deleteRule(name) {\n var rule = typeof name === 'object' ? name : this.rules.get(name);\n if (!rule) return false;\n this.rules.remove(rule);\n\n if (this.attached && rule.renderable && this.renderer) {\n return this.renderer.deleteRule(rule.renderable);\n }\n\n return true;\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.rules.indexOf(rule);\n }\n /**\n * Deploy pure CSS string to a renderable.\n */\n ;\n\n _proto.deploy = function deploy() {\n if (this.renderer) this.renderer.deploy();\n this.deployed = true;\n return this;\n }\n /**\n * Update the function values with a new data.\n */\n ;\n\n _proto.update = function update() {\n var _this$rules;\n\n (_this$rules = this.rules).update.apply(_this$rules, arguments);\n\n return this;\n }\n /**\n * Updates a single rule.\n */\n ;\n\n _proto.updateOne = function updateOne(rule, data, options) {\n this.rules.updateOne(rule, data, options);\n return this;\n }\n /**\n * Convert rules to a CSS string.\n */\n ;\n\n _proto.toString = function toString(options) {\n return this.rules.toString(options);\n };\n\n return StyleSheet;\n}();\n\nvar PluginsRegistry =\n/*#__PURE__*/\nfunction () {\n function PluginsRegistry() {\n this.plugins = {\n internal: [],\n external: []\n };\n this.registry = void 0;\n }\n\n var _proto = PluginsRegistry.prototype;\n\n /**\n * Call `onCreateRule` hooks and return an object if returned by a hook.\n */\n _proto.onCreateRule = function onCreateRule(name, decl, options) {\n for (var i = 0; i < this.registry.onCreateRule.length; i++) {\n var rule = this.registry.onCreateRule[i](name, decl, options);\n if (rule) return rule;\n }\n\n return null;\n }\n /**\n * Call `onProcessRule` hooks.\n */\n ;\n\n _proto.onProcessRule = function onProcessRule(rule) {\n if (rule.isProcessed) return;\n var sheet = rule.options.sheet;\n\n for (var i = 0; i < this.registry.onProcessRule.length; i++) {\n this.registry.onProcessRule[i](rule, sheet);\n }\n\n if (rule.style) this.onProcessStyle(rule.style, rule, sheet);\n rule.isProcessed = true;\n }\n /**\n * Call `onProcessStyle` hooks.\n */\n ;\n\n _proto.onProcessStyle = function onProcessStyle(style, rule, sheet) {\n for (var i = 0; i < this.registry.onProcessStyle.length; i++) {\n // $FlowFixMe\n rule.style = this.registry.onProcessStyle[i](rule.style, rule, sheet);\n }\n }\n /**\n * Call `onProcessSheet` hooks.\n */\n ;\n\n _proto.onProcessSheet = function onProcessSheet(sheet) {\n for (var i = 0; i < this.registry.onProcessSheet.length; i++) {\n this.registry.onProcessSheet[i](sheet);\n }\n }\n /**\n * Call `onUpdate` hooks.\n */\n ;\n\n _proto.onUpdate = function onUpdate(data, rule, sheet, options) {\n for (var i = 0; i < this.registry.onUpdate.length; i++) {\n this.registry.onUpdate[i](data, rule, sheet, options);\n }\n }\n /**\n * Call `onChangeValue` hooks.\n */\n ;\n\n _proto.onChangeValue = function onChangeValue(value, prop, rule) {\n var processedValue = value;\n\n for (var i = 0; i < this.registry.onChangeValue.length; i++) {\n processedValue = this.registry.onChangeValue[i](processedValue, prop, rule);\n }\n\n return processedValue;\n }\n /**\n * Register a plugin.\n */\n ;\n\n _proto.use = function use(newPlugin, options) {\n if (options === void 0) {\n options = {\n queue: 'external'\n };\n }\n\n var plugins = this.plugins[options.queue]; // Avoids applying same plugin twice, at least based on ref.\n\n if (plugins.indexOf(newPlugin) !== -1) {\n return;\n }\n\n plugins.push(newPlugin);\n this.registry = [].concat(this.plugins.external, this.plugins.internal).reduce(function (registry, plugin) {\n for (var name in plugin) {\n if (name in registry) {\n registry[name].push(plugin[name]);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Unknown hook \\\"\" + name + \"\\\".\") : void 0;\n }\n }\n\n return registry;\n }, {\n onCreateRule: [],\n onProcessRule: [],\n onProcessStyle: [],\n onProcessSheet: [],\n onChangeValue: [],\n onUpdate: []\n });\n };\n\n return PluginsRegistry;\n}();\n\n/**\n * Sheets registry to access them all at one place.\n */\nvar SheetsRegistry =\n/*#__PURE__*/\nfunction () {\n function SheetsRegistry() {\n this.registry = [];\n }\n\n var _proto = SheetsRegistry.prototype;\n\n /**\n * Register a Style Sheet.\n */\n _proto.add = function add(sheet) {\n var registry = this.registry;\n var index = sheet.options.index;\n if (registry.indexOf(sheet) !== -1) return;\n\n if (registry.length === 0 || index >= this.index) {\n registry.push(sheet);\n return;\n } // Find a position.\n\n\n for (var i = 0; i < registry.length; i++) {\n if (registry[i].options.index > index) {\n registry.splice(i, 0, sheet);\n return;\n }\n }\n }\n /**\n * Reset the registry.\n */\n ;\n\n _proto.reset = function reset() {\n this.registry = [];\n }\n /**\n * Remove a Style Sheet.\n */\n ;\n\n _proto.remove = function remove(sheet) {\n var index = this.registry.indexOf(sheet);\n this.registry.splice(index, 1);\n }\n /**\n * Convert all attached sheets to a CSS string.\n */\n ;\n\n _proto.toString = function toString(_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n attached = _ref.attached,\n options = _objectWithoutPropertiesLoose(_ref, [\"attached\"]);\n\n var css = '';\n\n for (var i = 0; i < this.registry.length; i++) {\n var sheet = this.registry[i];\n\n if (attached != null && sheet.attached !== attached) {\n continue;\n }\n\n if (css) css += '\\n';\n css += sheet.toString(options);\n }\n\n return css;\n };\n\n _createClass(SheetsRegistry, [{\n key: \"index\",\n\n /**\n * Current highest index number.\n */\n get: function get() {\n return this.registry.length === 0 ? 0 : this.registry[this.registry.length - 1].options.index;\n }\n }]);\n\n return SheetsRegistry;\n}();\n\n/**\n * This is a global sheets registry. Only DomRenderer will add sheets to it.\n * On the server one should use an own SheetsRegistry instance and add the\n * sheets to it, because you need to make sure to create a new registry for\n * each request in order to not leak sheets across requests.\n */\n\nvar sheets = new SheetsRegistry();\n\n/* eslint-disable */\n// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar globalThis = typeof window != 'undefined' && window.Math == Math ? window : typeof self != 'undefined' && self.Math == Math ? self : Function('return this')();\n\nvar ns = '2f1acc6c3a606b082e5eef5e54414ffb';\nif (globalThis[ns] == null) globalThis[ns] = 0; // Bundle may contain multiple JSS versions at the same time. In order to identify\n// the current version with just one short number and use it for classes generation\n// we use a counter. Also it is more accurate, because user can manually reevaluate\n// the module.\n\nvar moduleId = globalThis[ns]++;\n\nvar maxRules = 1e10;\n\n/**\n * Returns a function which generates unique class names based on counters.\n * When new generator function is created, rule counter is reseted.\n * We need to reset the rule counter for SSR for each request.\n */\nvar createGenerateId = function createGenerateId(options) {\n if (options === void 0) {\n options = {};\n }\n\n var ruleCounter = 0;\n return function (rule, sheet) {\n ruleCounter += 1;\n\n if (ruleCounter > maxRules) {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] You might have a memory leak. Rule counter is at \" + ruleCounter + \".\") : void 0;\n }\n\n var jssId = '';\n var prefix = '';\n\n if (sheet) {\n if (sheet.options.classNamePrefix) {\n prefix = sheet.options.classNamePrefix;\n }\n\n if (sheet.options.jss.id != null) {\n jssId = String(sheet.options.jss.id);\n }\n }\n\n if (options.minify) {\n // Using \"c\" because a number can't be the first char in a class name.\n return \"\" + (prefix || 'c') + moduleId + jssId + ruleCounter;\n }\n\n return prefix + rule.key + \"-\" + moduleId + (jssId ? \"-\" + jssId : '') + \"-\" + ruleCounter;\n };\n};\n\n/**\n * Cache the value from the first time a function is called.\n */\nvar memoize = function memoize(fn) {\n var value;\n return function () {\n if (!value) value = fn();\n return value;\n };\n};\n/**\n * Get a style property value.\n */\n\n\nfunction getPropertyValue(cssRule, prop) {\n try {\n // Support CSSTOM.\n if (cssRule.attributeStyleMap) {\n return cssRule.attributeStyleMap.get(prop);\n }\n\n return cssRule.style.getPropertyValue(prop);\n } catch (err) {\n // IE may throw if property is unknown.\n return '';\n }\n}\n/**\n * Set a style property.\n */\n\n\nfunction setProperty(cssRule, prop, value) {\n try {\n var cssValue = value;\n\n if (Array.isArray(value)) {\n cssValue = toCssValue(value, true);\n\n if (value[value.length - 1] === '!important') {\n cssRule.style.setProperty(prop, cssValue, 'important');\n return true;\n }\n } // Support CSSTOM.\n\n\n if (cssRule.attributeStyleMap) {\n cssRule.attributeStyleMap.set(prop, cssValue);\n } else {\n cssRule.style.setProperty(prop, cssValue);\n }\n } catch (err) {\n // IE may throw if property is unknown.\n return false;\n }\n\n return true;\n}\n/**\n * Remove a style property.\n */\n\n\nfunction removeProperty(cssRule, prop) {\n try {\n // Support CSSTOM.\n if (cssRule.attributeStyleMap) {\n cssRule.attributeStyleMap.delete(prop);\n } else {\n cssRule.style.removeProperty(prop);\n }\n } catch (err) {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] DOMException \\\"\" + err.message + \"\\\" was thrown. Tried to remove property \\\"\" + prop + \"\\\".\") : void 0;\n }\n}\n/**\n * Set the selector.\n */\n\n\nfunction setSelector(cssRule, selectorText) {\n cssRule.selectorText = selectorText; // Return false if setter was not successful.\n // Currently works in chrome only.\n\n return cssRule.selectorText === selectorText;\n}\n/**\n * Gets the `head` element upon the first call and caches it.\n * We assume it can't be null.\n */\n\n\nvar getHead = memoize(function () {\n return document.querySelector('head');\n});\n/**\n * Find attached sheet with an index higher than the passed one.\n */\n\nfunction findHigherSheet(registry, options) {\n for (var i = 0; i < registry.length; i++) {\n var sheet = registry[i];\n\n if (sheet.attached && sheet.options.index > options.index && sheet.options.insertionPoint === options.insertionPoint) {\n return sheet;\n }\n }\n\n return null;\n}\n/**\n * Find attached sheet with the highest index.\n */\n\n\nfunction findHighestSheet(registry, options) {\n for (var i = registry.length - 1; i >= 0; i--) {\n var sheet = registry[i];\n\n if (sheet.attached && sheet.options.insertionPoint === options.insertionPoint) {\n return sheet;\n }\n }\n\n return null;\n}\n/**\n * Find a comment with \"jss\" inside.\n */\n\n\nfunction findCommentNode(text) {\n var head = getHead();\n\n for (var i = 0; i < head.childNodes.length; i++) {\n var node = head.childNodes[i];\n\n if (node.nodeType === 8 && node.nodeValue.trim() === text) {\n return node;\n }\n }\n\n return null;\n}\n\n/**\n * Find a node before which we can insert the sheet.\n */\nfunction findPrevNode(options) {\n var registry = sheets.registry;\n\n if (registry.length > 0) {\n // Try to insert before the next higher sheet.\n var sheet = findHigherSheet(registry, options);\n\n if (sheet && sheet.renderer) {\n return {\n parent: sheet.renderer.element.parentNode,\n node: sheet.renderer.element\n };\n } // Otherwise insert after the last attached.\n\n\n sheet = findHighestSheet(registry, options);\n\n if (sheet && sheet.renderer) {\n return {\n parent: sheet.renderer.element.parentNode,\n node: sheet.renderer.element.nextSibling\n };\n }\n } // Try to find a comment placeholder if registry is empty.\n\n\n var insertionPoint = options.insertionPoint;\n\n if (insertionPoint && typeof insertionPoint === 'string') {\n var comment = findCommentNode(insertionPoint);\n\n if (comment) {\n return {\n parent: comment.parentNode,\n node: comment.nextSibling\n };\n } // If user specifies an insertion point and it can't be found in the document -\n // bad specificity issues may appear.\n\n\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Insertion point \\\"\" + insertionPoint + \"\\\" not found.\") : void 0;\n }\n\n return false;\n}\n/**\n * Insert style element into the DOM.\n */\n\n\nfunction insertStyle(style, options) {\n var insertionPoint = options.insertionPoint;\n var nextNode = findPrevNode(options);\n\n if (nextNode !== false && nextNode.parent) {\n nextNode.parent.insertBefore(style, nextNode.node);\n return;\n } // Works with iframes and any node types.\n\n\n if (insertionPoint && typeof insertionPoint.nodeType === 'number') {\n // https://stackoverflow.com/questions/41328728/force-casting-in-flow\n var insertionPointElement = insertionPoint;\n var parentNode = insertionPointElement.parentNode;\n if (parentNode) parentNode.insertBefore(style, insertionPointElement.nextSibling);else process.env.NODE_ENV !== \"production\" ? warning(false, '[JSS] Insertion point is not in the DOM.') : void 0;\n return;\n }\n\n getHead().appendChild(style);\n}\n/**\n * Read jss nonce setting from the page if the user has set it.\n */\n\n\nvar getNonce = memoize(function () {\n var node = document.querySelector('meta[property=\"csp-nonce\"]');\n return node ? node.getAttribute('content') : null;\n});\n\nvar _insertRule = function insertRule(container, rule, index) {\n var maxIndex = container.cssRules.length; // In case previous insertion fails, passed index might be wrong\n\n if (index === undefined || index > maxIndex) {\n // eslint-disable-next-line no-param-reassign\n index = maxIndex;\n }\n\n try {\n if ('insertRule' in container) {\n var c = container;\n c.insertRule(rule, index);\n } // Keyframes rule.\n else if ('appendRule' in container) {\n var _c = container;\n\n _c.appendRule(rule);\n }\n } catch (err) {\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] \" + err.message) : void 0;\n return false;\n }\n\n return container.cssRules[index];\n};\n\nvar createStyle = function createStyle() {\n var el = document.createElement('style'); // Without it, IE will have a broken source order specificity if we\n // insert rules after we insert the style tag.\n // It seems to kick-off the source order specificity algorithm.\n\n el.textContent = '\\n';\n return el;\n};\n\nvar DomRenderer =\n/*#__PURE__*/\nfunction () {\n // HTMLStyleElement needs fixing https://github.com/facebook/flow/issues/2696\n function DomRenderer(sheet) {\n this.getPropertyValue = getPropertyValue;\n this.setProperty = setProperty;\n this.removeProperty = removeProperty;\n this.setSelector = setSelector;\n this.element = void 0;\n this.sheet = void 0;\n this.hasInsertedRules = false;\n // There is no sheet when the renderer is used from a standalone StyleRule.\n if (sheet) sheets.add(sheet);\n this.sheet = sheet;\n\n var _ref = this.sheet ? this.sheet.options : {},\n media = _ref.media,\n meta = _ref.meta,\n element = _ref.element;\n\n this.element = element || createStyle();\n this.element.setAttribute('data-jss', '');\n if (media) this.element.setAttribute('media', media);\n if (meta) this.element.setAttribute('data-meta', meta);\n var nonce = getNonce();\n if (nonce) this.element.setAttribute('nonce', nonce);\n }\n /**\n * Insert style element into render tree.\n */\n\n\n var _proto = DomRenderer.prototype;\n\n _proto.attach = function attach() {\n // In the case the element node is external and it is already in the DOM.\n if (this.element.parentNode || !this.sheet) return;\n insertStyle(this.element, this.sheet.options); // When rules are inserted using `insertRule` API, after `sheet.detach().attach()`\n // most browsers create a new CSSStyleSheet, except of all IEs.\n\n var deployed = Boolean(this.sheet && this.sheet.deployed);\n\n if (this.hasInsertedRules && deployed) {\n this.hasInsertedRules = false;\n this.deploy();\n }\n }\n /**\n * Remove style element from render tree.\n */\n ;\n\n _proto.detach = function detach() {\n var parentNode = this.element.parentNode;\n if (parentNode) parentNode.removeChild(this.element);\n }\n /**\n * Inject CSS string into element.\n */\n ;\n\n _proto.deploy = function deploy() {\n var sheet = this.sheet;\n if (!sheet) return;\n\n if (sheet.options.link) {\n this.insertRules(sheet.rules);\n return;\n }\n\n this.element.textContent = \"\\n\" + sheet.toString() + \"\\n\";\n }\n /**\n * Insert RuleList into an element.\n */\n ;\n\n _proto.insertRules = function insertRules(rules, nativeParent) {\n for (var i = 0; i < rules.index.length; i++) {\n this.insertRule(rules.index[i], i, nativeParent);\n }\n }\n /**\n * Insert a rule into element.\n */\n ;\n\n _proto.insertRule = function insertRule(rule, index, nativeParent) {\n if (nativeParent === void 0) {\n nativeParent = this.element.sheet;\n }\n\n if (rule.rules) {\n var parent = rule;\n var latestNativeParent = nativeParent;\n\n if (rule.type === 'conditional' || rule.type === 'keyframes') {\n // We need to render the container without children first.\n latestNativeParent = _insertRule(nativeParent, parent.toString({\n children: false\n }), index);\n\n if (latestNativeParent === false) {\n return false;\n }\n }\n\n this.insertRules(parent.rules, latestNativeParent);\n return latestNativeParent;\n } // IE keeps the CSSStyleSheet after style node has been reattached,\n // so we need to check if the `renderable` reference the right style sheet and not\n // rerender those rules.\n\n\n if (rule.renderable && rule.renderable.parentStyleSheet === this.element.sheet) {\n return rule.renderable;\n }\n\n var ruleStr = rule.toString();\n if (!ruleStr) return false;\n\n var nativeRule = _insertRule(nativeParent, ruleStr, index);\n\n if (nativeRule === false) {\n return false;\n }\n\n this.hasInsertedRules = true;\n rule.renderable = nativeRule;\n return nativeRule;\n }\n /**\n * Delete a rule.\n */\n ;\n\n _proto.deleteRule = function deleteRule(cssRule) {\n var sheet = this.element.sheet;\n var index = this.indexOf(cssRule);\n if (index === -1) return false;\n sheet.deleteRule(index);\n return true;\n }\n /**\n * Get index of a CSS Rule.\n */\n ;\n\n _proto.indexOf = function indexOf(cssRule) {\n var cssRules = this.element.sheet.cssRules;\n\n for (var index = 0; index < cssRules.length; index++) {\n if (cssRule === cssRules[index]) return index;\n }\n\n return -1;\n }\n /**\n * Generate a new CSS rule and replace the existing one.\n *\n * Only used for some old browsers because they can't set a selector.\n */\n ;\n\n _proto.replaceRule = function replaceRule(cssRule, rule) {\n var index = this.indexOf(cssRule);\n if (index === -1) return false;\n this.element.sheet.deleteRule(index);\n return this.insertRule(rule, index);\n }\n /**\n * Get all rules elements.\n */\n ;\n\n _proto.getRules = function getRules() {\n return this.element.sheet.cssRules;\n };\n\n return DomRenderer;\n}();\n\nvar instanceCounter = 0;\n\nvar Jss =\n/*#__PURE__*/\nfunction () {\n function Jss(options) {\n this.id = instanceCounter++;\n this.version = \"10.0.3\";\n this.plugins = new PluginsRegistry();\n this.options = {\n id: {\n minify: false\n },\n createGenerateId: createGenerateId,\n Renderer: isInBrowser ? DomRenderer : null,\n plugins: []\n };\n this.generateId = createGenerateId({\n minify: false\n });\n\n for (var i = 0; i < plugins.length; i++) {\n this.plugins.use(plugins[i], {\n queue: 'internal'\n });\n }\n\n this.setup(options);\n }\n /**\n * Prepares various options, applies plugins.\n * Should not be used twice on the same instance, because there is no plugins\n * deduplication logic.\n */\n\n\n var _proto = Jss.prototype;\n\n _proto.setup = function setup(options) {\n if (options === void 0) {\n options = {};\n }\n\n if (options.createGenerateId) {\n this.options.createGenerateId = options.createGenerateId;\n }\n\n if (options.id) {\n this.options.id = _extends({}, this.options.id, options.id);\n }\n\n if (options.createGenerateId || options.id) {\n this.generateId = this.options.createGenerateId(this.options.id);\n }\n\n if (options.insertionPoint != null) this.options.insertionPoint = options.insertionPoint;\n\n if ('Renderer' in options) {\n this.options.Renderer = options.Renderer;\n } // eslint-disable-next-line prefer-spread\n\n\n if (options.plugins) this.use.apply(this, options.plugins);\n return this;\n }\n /**\n * Create a Style Sheet.\n */\n ;\n\n _proto.createStyleSheet = function createStyleSheet(styles, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n index = _options.index;\n\n if (typeof index !== 'number') {\n index = sheets.index === 0 ? 0 : sheets.index + 1;\n }\n\n var sheet = new StyleSheet(styles, _extends({}, options, {\n jss: this,\n generateId: options.generateId || this.generateId,\n insertionPoint: this.options.insertionPoint,\n Renderer: this.options.Renderer,\n index: index\n }));\n this.plugins.onProcessSheet(sheet);\n return sheet;\n }\n /**\n * Detach the Style Sheet and remove it from the registry.\n */\n ;\n\n _proto.removeStyleSheet = function removeStyleSheet(sheet) {\n sheet.detach();\n sheets.remove(sheet);\n return this;\n }\n /**\n * Create a rule without a Style Sheet.\n * [Deprecated] will be removed in the next major version.\n */\n ;\n\n _proto.createRule = function createRule$$1(name, style, options) {\n if (style === void 0) {\n style = {};\n }\n\n if (options === void 0) {\n options = {};\n }\n\n // Enable rule without name for inline styles.\n if (typeof name === 'object') {\n return this.createRule(undefined, name, style);\n }\n\n var ruleOptions = _extends({}, options, {\n name: name,\n jss: this,\n Renderer: this.options.Renderer\n });\n\n if (!ruleOptions.generateId) ruleOptions.generateId = this.generateId;\n if (!ruleOptions.classes) ruleOptions.classes = {};\n if (!ruleOptions.keyframes) ruleOptions.keyframes = {};\n\n var rule = createRule(name, style, ruleOptions);\n\n if (rule) this.plugins.onProcessRule(rule);\n return rule;\n }\n /**\n * Register plugin. Passed function will be invoked with a rule instance.\n */\n ;\n\n _proto.use = function use() {\n var _this = this;\n\n for (var _len = arguments.length, plugins$$1 = new Array(_len), _key = 0; _key < _len; _key++) {\n plugins$$1[_key] = arguments[_key];\n }\n\n plugins$$1.forEach(function (plugin) {\n _this.plugins.use(plugin);\n });\n return this;\n };\n\n return Jss;\n}();\n\n/**\n * Extracts a styles object with only props that contain function values.\n */\nfunction getDynamicStyles(styles) {\n var to = null;\n\n for (var key in styles) {\n var value = styles[key];\n var type = typeof value;\n\n if (type === 'function') {\n if (!to) to = {};\n to[key] = value;\n } else if (type === 'object' && value !== null && !Array.isArray(value)) {\n var extracted = getDynamicStyles(value);\n\n if (extracted) {\n if (!to) to = {};\n to[key] = extracted;\n }\n }\n }\n\n return to;\n}\n\n/**\n * SheetsManager is like a WeakMap which is designed to count StyleSheet\n * instances and attach/detach automatically.\n */\nvar SheetsManager =\n/*#__PURE__*/\nfunction () {\n function SheetsManager() {\n this.length = 0;\n this.sheets = new WeakMap();\n }\n\n var _proto = SheetsManager.prototype;\n\n _proto.get = function get(key) {\n var entry = this.sheets.get(key);\n return entry && entry.sheet;\n };\n\n _proto.add = function add(key, sheet) {\n if (this.sheets.has(key)) return;\n this.length++;\n this.sheets.set(key, {\n sheet: sheet,\n refs: 0\n });\n };\n\n _proto.manage = function manage(key) {\n var entry = this.sheets.get(key);\n\n if (entry) {\n if (entry.refs === 0) {\n entry.sheet.attach();\n }\n\n entry.refs++;\n return entry.sheet;\n }\n\n warning(false, \"[JSS] SheetsManager: can't find sheet to manage\");\n return undefined;\n };\n\n _proto.unmanage = function unmanage(key) {\n var entry = this.sheets.get(key);\n\n if (entry) {\n if (entry.refs > 0) {\n entry.refs--;\n if (entry.refs === 0) entry.sheet.detach();\n }\n } else {\n warning(false, \"SheetsManager: can't find sheet to unmanage\");\n }\n };\n\n _createClass(SheetsManager, [{\n key: \"size\",\n get: function get() {\n return this.length;\n }\n }]);\n\n return SheetsManager;\n}();\n\n/**\n * A better abstraction over CSS.\n *\n * @copyright Oleg Isonen (Slobodskoi) / Isonen 2014-present\n * @website https://github.com/cssinjs/jss\n * @license MIT\n */\n\n/**\n * Export a constant indicating if this browser has CSSTOM support.\n * https://developers.google.com/web/updates/2018/03/cssom\n */\nvar hasCSSTOMSupport = typeof CSS !== 'undefined' && CSS && 'number' in CSS;\n/**\n * Creates a new instance of Jss.\n */\n\nvar create = function create(options) {\n return new Jss(options);\n};\n/**\n * A global Jss instance.\n */\n\nvar index = create();\n\nexport default index;\nexport { hasCSSTOMSupport, create, getDynamicStyles, toCssValue, createRule, SheetsRegistry, SheetsManager, RuleList, sheets, createGenerateId };\n","// Used https://github.com/thinkloop/multi-key-cache as inspiration\nvar multiKeyStore = {\n set: function set(cache, key1, key2, value) {\n var subCache = cache.get(key1);\n\n if (!subCache) {\n subCache = new Map();\n cache.set(key1, subCache);\n }\n\n subCache.set(key2, value);\n },\n get: function get(cache, key1, key2) {\n var subCache = cache.get(key1);\n return subCache ? subCache.get(key2) : undefined;\n },\n delete: function _delete(cache, key1, key2) {\n var subCache = cache.get(key1);\n subCache.delete(key2);\n }\n};\nexport default multiKeyStore;","import nested from '../ThemeProvider/nested';\n/**\n * This is the list of the style rule name we use as drop in replacement for the built-in\n * pseudo classes (:checked, :disabled, :focused, etc.).\n *\n * Why do they exist in the first place?\n * These classes are used at a specificity of 2.\n * It allows them to override previously definied styles as well as\n * being untouched by simple user overrides.\n */\n\nvar pseudoClasses = ['checked', 'disabled', 'error', 'focused', 'focusVisible', 'required', 'expanded', 'selected']; // Returns a function which generates unique class names based on counters.\n// When new generator function is created, rule counter is reset.\n// We need to reset the rule counter for SSR for each request.\n//\n// It's inspired by\n// https://github.com/cssinjs/jss/blob/4e6a05dd3f7b6572fdd3ab216861d9e446c20331/src/utils/createGenerateClassName.js\n\nexport default function createGenerateClassName() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var _options$disableGloba = options.disableGlobal,\n disableGlobal = _options$disableGloba === void 0 ? false : _options$disableGloba,\n _options$productionPr = options.productionPrefix,\n productionPrefix = _options$productionPr === void 0 ? 'jss' : _options$productionPr,\n _options$seed = options.seed,\n seed = _options$seed === void 0 ? '' : _options$seed;\n var seedPrefix = seed === '' ? '' : \"\".concat(seed, \"-\");\n var ruleCounter = 0;\n return function (rule, styleSheet) {\n ruleCounter += 1;\n\n if (process.env.NODE_ENV !== 'production') {\n if (ruleCounter >= 1e10) {\n console.warn(['Material-UI: you might have a memory leak.', 'The ruleCounter is not supposed to grow that much.'].join(''));\n }\n }\n\n var name = styleSheet.options.name; // Is a global static MUI style?\n\n if (name && name.indexOf('Mui') === 0 && !styleSheet.options.link && !disableGlobal) {\n // We can use a shorthand class name, we never use the keys to style the components.\n if (pseudoClasses.indexOf(rule.key) !== -1) {\n return \"Mui-\".concat(rule.key);\n }\n\n var prefix = \"\".concat(seedPrefix).concat(name, \"-\").concat(rule.key);\n\n if (!styleSheet.options.theme[nested] || seed !== '') {\n return prefix;\n }\n\n return \"\".concat(prefix, \"-\").concat(ruleCounter);\n }\n\n if (process.env.NODE_ENV === 'production') {\n return \"\".concat(seedPrefix).concat(productionPrefix).concat(ruleCounter);\n }\n\n var suffix = \"\".concat(rule.key, \"-\").concat(ruleCounter); // Help with debuggability.\n\n if (styleSheet.options.classNamePrefix) {\n return \"\".concat(seedPrefix).concat(styleSheet.options.classNamePrefix, \"-\").concat(suffix);\n }\n\n return \"\".concat(seedPrefix).concat(suffix);\n };\n}","import { createRule } from 'jss';\n\nvar now = Date.now();\nvar fnValuesNs = \"fnValues\" + now;\nvar fnRuleNs = \"fnStyle\" + ++now;\nfunction functionPlugin() {\n return {\n onCreateRule: function onCreateRule(name, decl, options) {\n if (typeof decl !== 'function') return null;\n var rule = createRule(name, {}, options);\n rule[fnRuleNs] = decl;\n return rule;\n },\n onProcessStyle: function onProcessStyle(style, rule) {\n // We need to extract function values from the declaration, so that we can keep core unaware of them.\n // We need to do that only once.\n // We don't need to extract functions on each style update, since this can happen only once.\n // We don't support function values inside of function rules.\n if (fnValuesNs in rule || fnRuleNs in rule) return style;\n var fnValues = {};\n\n for (var prop in style) {\n var value = style[prop];\n if (typeof value !== 'function') continue;\n delete style[prop];\n fnValues[prop] = value;\n } // $FlowFixMe\n\n\n rule[fnValuesNs] = fnValues;\n return style;\n },\n onUpdate: function onUpdate(data, rule, sheet, options) {\n var styleRule = rule;\n var fnRule = styleRule[fnRuleNs]; // If we have a style function, the entire rule is dynamic and style object\n // will be returned from that function.\n\n if (fnRule) {\n // Empty object will remove all currently defined props\n // in case function rule returns a falsy value.\n styleRule.style = fnRule(data) || {};\n }\n\n var fnValues = styleRule[fnValuesNs]; // If we have a fn values map, it is a rule with function values.\n\n if (fnValues) {\n for (var prop in fnValues) {\n styleRule.prop(prop, fnValues[prop](data), options);\n }\n }\n }\n };\n}\n\nexport default functionPlugin;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport { RuleList } from 'jss';\n\nvar at = '@global';\nvar atPrefix = '@global ';\n\nvar GlobalContainerRule =\n/*#__PURE__*/\nfunction () {\n function GlobalContainerRule(key, styles, options) {\n this.type = 'global';\n this.at = at;\n this.rules = void 0;\n this.options = void 0;\n this.key = void 0;\n this.isProcessed = false;\n this.key = key;\n this.options = options;\n this.rules = new RuleList(_extends({}, options, {\n parent: this\n }));\n\n for (var selector in styles) {\n this.rules.add(selector, styles[selector]);\n }\n\n this.rules.process();\n }\n /**\n * Get a rule.\n */\n\n\n var _proto = GlobalContainerRule.prototype;\n\n _proto.getRule = function getRule(name) {\n return this.rules.get(name);\n }\n /**\n * Create and register rule, run plugins.\n */\n ;\n\n _proto.addRule = function addRule(name, style, options) {\n var rule = this.rules.add(name, style, options);\n this.options.jss.plugins.onProcessRule(rule);\n return rule;\n }\n /**\n * Get index of a rule.\n */\n ;\n\n _proto.indexOf = function indexOf(rule) {\n return this.rules.indexOf(rule);\n }\n /**\n * Generates a CSS string.\n */\n ;\n\n _proto.toString = function toString() {\n return this.rules.toString();\n };\n\n return GlobalContainerRule;\n}();\n\nvar GlobalPrefixedRule =\n/*#__PURE__*/\nfunction () {\n function GlobalPrefixedRule(key, style, options) {\n this.type = 'global';\n this.at = at;\n this.options = void 0;\n this.rule = void 0;\n this.isProcessed = false;\n this.key = void 0;\n this.key = key;\n this.options = options;\n var selector = key.substr(atPrefix.length);\n this.rule = options.jss.createRule(selector, style, _extends({}, options, {\n parent: this\n }));\n }\n\n var _proto2 = GlobalPrefixedRule.prototype;\n\n _proto2.toString = function toString(options) {\n return this.rule ? this.rule.toString(options) : '';\n };\n\n return GlobalPrefixedRule;\n}();\n\nvar separatorRegExp = /\\s*,\\s*/g;\n\nfunction addScope(selector, scope) {\n var parts = selector.split(separatorRegExp);\n var scoped = '';\n\n for (var i = 0; i < parts.length; i++) {\n scoped += scope + \" \" + parts[i].trim();\n if (parts[i + 1]) scoped += ', ';\n }\n\n return scoped;\n}\n\nfunction handleNestedGlobalContainerRule(rule) {\n var options = rule.options,\n style = rule.style;\n var rules = style ? style[at] : null;\n if (!rules) return;\n\n for (var name in rules) {\n options.sheet.addRule(name, rules[name], _extends({}, options, {\n selector: addScope(name, rule.selector)\n }));\n }\n\n delete style[at];\n}\n\nfunction handlePrefixedGlobalRule(rule) {\n var options = rule.options,\n style = rule.style;\n\n for (var prop in style) {\n if (prop[0] !== '@' || prop.substr(0, at.length) !== at) continue;\n var selector = addScope(prop.substr(at.length), rule.selector);\n options.sheet.addRule(selector, style[prop], _extends({}, options, {\n selector: selector\n }));\n delete style[prop];\n }\n}\n/**\n * Convert nested rules to separate, remove them from original styles.\n *\n * @param {Rule} rule\n * @api public\n */\n\n\nfunction jssGlobal() {\n function onCreateRule(name, styles, options) {\n if (!name) return null;\n\n if (name === at) {\n return new GlobalContainerRule(name, styles, options);\n }\n\n if (name[0] === '@' && name.substr(0, atPrefix.length) === atPrefix) {\n return new GlobalPrefixedRule(name, styles, options);\n }\n\n var parent = options.parent;\n\n if (parent) {\n if (parent.type === 'global' || parent.options.parent && parent.options.parent.type === 'global') {\n options.scoped = false;\n }\n }\n\n if (options.scoped === false) {\n options.selector = name;\n }\n\n return null;\n }\n\n function onProcessRule(rule) {\n if (rule.type !== 'style') return;\n handleNestedGlobalContainerRule(rule);\n handlePrefixedGlobalRule(rule);\n }\n\n return {\n onCreateRule: onCreateRule,\n onProcessRule: onProcessRule\n };\n}\n\nexport default jssGlobal;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport warning from 'tiny-warning';\n\nvar separatorRegExp = /\\s*,\\s*/g;\nvar parentRegExp = /&/g;\nvar refRegExp = /\\$([\\w-]+)/g;\n/**\n * Convert nested rules to separate, remove them from original styles.\n *\n * @param {Rule} rule\n * @api public\n */\n\nfunction jssNested() {\n // Get a function to be used for $ref replacement.\n function getReplaceRef(container, sheet) {\n return function (match, key) {\n var rule = container.getRule(key) || sheet && sheet.getRule(key);\n\n if (rule) {\n rule = rule;\n return rule.selector;\n }\n\n process.env.NODE_ENV !== \"production\" ? warning(false, \"[JSS] Could not find the referenced rule \\\"\" + key + \"\\\" in \\\"\" + (container.options.meta || container.toString()) + \"\\\".\") : void 0;\n return key;\n };\n }\n\n function replaceParentRefs(nestedProp, parentProp) {\n var parentSelectors = parentProp.split(separatorRegExp);\n var nestedSelectors = nestedProp.split(separatorRegExp);\n var result = '';\n\n for (var i = 0; i < parentSelectors.length; i++) {\n var parent = parentSelectors[i];\n\n for (var j = 0; j < nestedSelectors.length; j++) {\n var nested = nestedSelectors[j];\n if (result) result += ', '; // Replace all & by the parent or prefix & with the parent.\n\n result += nested.indexOf('&') !== -1 ? nested.replace(parentRegExp, parent) : parent + \" \" + nested;\n }\n }\n\n return result;\n }\n\n function getOptions(rule, container, prevOptions) {\n // Options has been already created, now we only increase index.\n if (prevOptions) return _extends({}, prevOptions, {\n index: prevOptions.index + 1\n });\n var nestingLevel = rule.options.nestingLevel;\n nestingLevel = nestingLevel === undefined ? 1 : nestingLevel + 1;\n\n var options = _extends({}, rule.options, {\n nestingLevel: nestingLevel,\n index: container.indexOf(rule) + 1 // We don't need the parent name to be set options for chlid.\n\n });\n\n delete options.name;\n return options;\n }\n\n function onProcessStyle(style, rule, sheet) {\n if (rule.type !== 'style') return style;\n var styleRule = rule;\n var container = styleRule.options.parent;\n var options;\n var replaceRef;\n\n for (var prop in style) {\n var isNested = prop.indexOf('&') !== -1;\n var isNestedConditional = prop[0] === '@';\n if (!isNested && !isNestedConditional) continue;\n options = getOptions(styleRule, container, options);\n\n if (isNested) {\n var selector = replaceParentRefs(prop, styleRule.selector); // Lazily create the ref replacer function just once for\n // all nested rules within the sheet.\n\n if (!replaceRef) replaceRef = getReplaceRef(container, sheet); // Replace all $refs.\n\n selector = selector.replace(refRegExp, replaceRef);\n container.addRule(selector, style[prop], _extends({}, options, {\n selector: selector\n }));\n } else if (isNestedConditional) {\n // Place conditional right after the parent rule to ensure right ordering.\n container.addRule(prop, {}, options) // Flow expects more options but they aren't required\n // And flow doesn't know this will always be a StyleRule which has the addRule method\n // $FlowFixMe\n .addRule(styleRule.key, style[prop], {\n selector: styleRule.selector\n });\n }\n\n delete style[prop];\n }\n\n return style;\n }\n\n return {\n onProcessStyle: onProcessStyle\n };\n}\n\nexport default jssNested;\n","/* eslint-disable no-var, prefer-template */\nvar uppercasePattern = /[A-Z]/g\nvar msPattern = /^ms-/\nvar cache = {}\n\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase()\n}\n\nfunction hyphenateStyleName(name) {\n if (cache.hasOwnProperty(name)) {\n return cache[name]\n }\n\n var hName = name.replace(uppercasePattern, toHyphenLower)\n return (cache[name] = msPattern.test(hName) ? '-' + hName : hName)\n}\n\nexport default hyphenateStyleName\n","import hyphenate from 'hyphenate-style-name';\n\n/**\n * Convert camel cased property names to dash separated.\n *\n * @param {Object} style\n * @return {Object}\n */\n\nfunction convertCase(style) {\n var converted = {};\n\n for (var prop in style) {\n var key = prop.indexOf('--') === 0 ? prop : hyphenate(prop);\n converted[key] = style[prop];\n }\n\n if (style.fallbacks) {\n if (Array.isArray(style.fallbacks)) converted.fallbacks = style.fallbacks.map(convertCase);else converted.fallbacks = convertCase(style.fallbacks);\n }\n\n return converted;\n}\n/**\n * Allow camel cased property names by converting them back to dasherized.\n *\n * @param {Rule} rule\n */\n\n\nfunction camelCase() {\n function onProcessStyle(style) {\n if (Array.isArray(style)) {\n // Handle rules like @font-face, which can have multiple styles in an array\n for (var index = 0; index < style.length; index++) {\n style[index] = convertCase(style[index]);\n }\n\n return style;\n }\n\n return convertCase(style);\n }\n\n function onChangeValue(value, prop, rule) {\n if (prop.indexOf('--') === 0) {\n return value;\n }\n\n var hyphenatedProp = hyphenate(prop); // There was no camel case in place\n\n if (prop === hyphenatedProp) return value;\n rule.prop(hyphenatedProp, value); // Core will ignore that property value we set the proper one above.\n\n return null;\n }\n\n return {\n onProcessStyle: onProcessStyle,\n onChangeValue: onChangeValue\n };\n}\n\nexport default camelCase;\n","import { hasCSSTOMSupport } from 'jss';\n\nvar px = hasCSSTOMSupport && CSS ? CSS.px : 'px';\nvar ms = hasCSSTOMSupport && CSS ? CSS.ms : 'ms';\nvar percent = hasCSSTOMSupport && CSS ? CSS.percent : '%';\n/**\n * Generated jss-plugin-default-unit CSS property units\n *\n * @type object\n */\n\nvar defaultUnits = {\n // Animation properties\n 'animation-delay': ms,\n 'animation-duration': ms,\n // Background properties\n 'background-position': px,\n 'background-position-x': px,\n 'background-position-y': px,\n 'background-size': px,\n // Border Properties\n border: px,\n 'border-bottom': px,\n 'border-bottom-left-radius': px,\n 'border-bottom-right-radius': px,\n 'border-bottom-width': px,\n 'border-left': px,\n 'border-left-width': px,\n 'border-radius': px,\n 'border-right': px,\n 'border-right-width': px,\n 'border-top': px,\n 'border-top-left-radius': px,\n 'border-top-right-radius': px,\n 'border-top-width': px,\n 'border-width': px,\n // Margin properties\n margin: px,\n 'margin-bottom': px,\n 'margin-left': px,\n 'margin-right': px,\n 'margin-top': px,\n // Padding properties\n padding: px,\n 'padding-bottom': px,\n 'padding-left': px,\n 'padding-right': px,\n 'padding-top': px,\n // Mask properties\n 'mask-position-x': px,\n 'mask-position-y': px,\n 'mask-size': px,\n // Width and height properties\n height: px,\n width: px,\n 'min-height': px,\n 'max-height': px,\n 'min-width': px,\n 'max-width': px,\n // Position properties\n bottom: px,\n left: px,\n top: px,\n right: px,\n // Shadow properties\n 'box-shadow': px,\n 'text-shadow': px,\n // Column properties\n 'column-gap': px,\n 'column-rule': px,\n 'column-rule-width': px,\n 'column-width': px,\n // Font and text properties\n 'font-size': px,\n 'font-size-delta': px,\n 'letter-spacing': px,\n 'text-indent': px,\n 'text-stroke': px,\n 'text-stroke-width': px,\n 'word-spacing': px,\n // Motion properties\n motion: px,\n 'motion-offset': px,\n // Outline properties\n outline: px,\n 'outline-offset': px,\n 'outline-width': px,\n // Perspective properties\n perspective: px,\n 'perspective-origin-x': percent,\n 'perspective-origin-y': percent,\n // Transform properties\n 'transform-origin': percent,\n 'transform-origin-x': percent,\n 'transform-origin-y': percent,\n 'transform-origin-z': percent,\n // Transition properties\n 'transition-delay': ms,\n 'transition-duration': ms,\n // Alignment properties\n 'vertical-align': px,\n 'flex-basis': px,\n // Some random properties\n 'shape-margin': px,\n size: px,\n // Grid properties\n grid: px,\n 'grid-gap': px,\n 'grid-row-gap': px,\n 'grid-column-gap': px,\n 'grid-template-rows': px,\n 'grid-template-columns': px,\n 'grid-auto-rows': px,\n 'grid-auto-columns': px,\n // Not existing properties.\n // Used to avoid issues with jss-plugin-expand integration.\n 'box-shadow-x': px,\n 'box-shadow-y': px,\n 'box-shadow-blur': px,\n 'box-shadow-spread': px,\n 'font-line-height': px,\n 'text-shadow-x': px,\n 'text-shadow-y': px,\n 'text-shadow-blur': px\n};\n\n/**\n * Clones the object and adds a camel cased property version.\n */\nfunction addCamelCasedVersion(obj) {\n var regExp = /(-[a-z])/g;\n\n var replace = function replace(str) {\n return str[1].toUpperCase();\n };\n\n var newObj = {};\n\n for (var _key in obj) {\n newObj[_key] = obj[_key];\n newObj[_key.replace(regExp, replace)] = obj[_key];\n }\n\n return newObj;\n}\n\nvar units = addCamelCasedVersion(defaultUnits);\n/**\n * Recursive deep style passing function\n */\n\nfunction iterate(prop, value, options) {\n if (!value) return value;\n\n if (Array.isArray(value)) {\n for (var i = 0; i < value.length; i++) {\n value[i] = iterate(prop, value[i], options);\n }\n } else if (typeof value === 'object') {\n if (prop === 'fallbacks') {\n for (var innerProp in value) {\n value[innerProp] = iterate(innerProp, value[innerProp], options);\n }\n } else {\n for (var _innerProp in value) {\n value[_innerProp] = iterate(prop + \"-\" + _innerProp, value[_innerProp], options);\n }\n }\n } else if (typeof value === 'number') {\n if (options[prop]) {\n return \"\" + value + options[prop];\n }\n\n if (units[prop]) {\n return typeof units[prop] === 'function' ? units[prop](value).toString() : \"\" + value + units[prop];\n }\n\n return value.toString();\n }\n\n return value;\n}\n/**\n * Add unit to numeric values.\n */\n\n\nfunction defaultUnit(options) {\n if (options === void 0) {\n options = {};\n }\n\n var camelCasedOptions = addCamelCasedVersion(options);\n\n function onProcessStyle(style, rule) {\n if (rule.type !== 'style') return style;\n\n for (var prop in style) {\n style[prop] = iterate(prop, style[prop], camelCasedOptions);\n }\n\n return style;\n }\n\n function onChangeValue(value, prop) {\n return iterate(prop, value, camelCasedOptions);\n }\n\n return {\n onProcessStyle: onProcessStyle,\n onChangeValue: onChangeValue\n };\n}\n\nexport default defaultUnit;\n","import isInBrowser from 'is-in-browser';\nimport _toConsumableArray from '@babel/runtime/helpers/esm/toConsumableArray';\n\n// Export javascript style and css style vendor prefixes.\nvar js = '';\nvar css = '';\nvar vendor = '';\nvar browser = '';\nvar isTouch = isInBrowser && 'ontouchstart' in document.documentElement; // We should not do anything if required serverside.\n\nif (isInBrowser) {\n // Order matters. We need to check Webkit the last one because\n // other vendors use to add Webkit prefixes to some properties\n var jsCssMap = {\n Moz: '-moz-',\n ms: '-ms-',\n O: '-o-',\n Webkit: '-webkit-'\n };\n\n var _document$createEleme = document.createElement('p'),\n style = _document$createEleme.style;\n\n var testProp = 'Transform';\n\n for (var key in jsCssMap) {\n if (key + testProp in style) {\n js = key;\n css = jsCssMap[key];\n break;\n }\n } // Correctly detect the Edge browser.\n\n\n if (js === 'Webkit' && 'msHyphens' in style) {\n js = 'ms';\n css = jsCssMap.ms;\n browser = 'edge';\n } // Correctly detect the Safari browser.\n\n\n if (js === 'Webkit' && '-apple-trailing-word' in style) {\n vendor = 'apple';\n }\n}\n/**\n * Vendor prefix string for the current browser.\n *\n * @type {{js: String, css: String, vendor: String, browser: String}}\n * @api public\n */\n\n\nvar prefix = {\n js: js,\n css: css,\n vendor: vendor,\n browser: browser,\n isTouch: isTouch\n};\n\n/**\n * Test if a keyframe at-rule should be prefixed or not\n *\n * @param {String} vendor prefix string for the current browser.\n * @return {String}\n * @api public\n */\n\nfunction supportedKeyframes(key) {\n // Keyframes is already prefixed. e.g. key = '@-webkit-keyframes a'\n if (key[1] === '-') return key; // No need to prefix IE/Edge. Older browsers will ignore unsupported rules.\n // https://caniuse.com/#search=keyframes\n\n if (prefix.js === 'ms') return key;\n return \"@\" + prefix.css + \"keyframes\" + key.substr(10);\n}\n\n// https://caniuse.com/#search=appearance\n\nvar appearence = {\n noPrefill: ['appearance'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'appearance') return false;\n if (prefix.js === 'ms') return \"-webkit-\" + prop;\n return prefix.css + prop;\n }\n};\n\n// https://caniuse.com/#search=color-adjust\n\nvar colorAdjust = {\n noPrefill: ['color-adjust'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'color-adjust') return false;\n if (prefix.js === 'Webkit') return prefix.css + \"print-\" + prop;\n return prop;\n }\n};\n\nvar regExp = /[-\\s]+(.)?/g;\n/**\n * Replaces the letter with the capital letter\n *\n * @param {String} match\n * @param {String} c\n * @return {String}\n * @api private\n */\n\nfunction toUpper(match, c) {\n return c ? c.toUpperCase() : '';\n}\n/**\n * Convert dash separated strings to camel-cased.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\n\nfunction camelize(str) {\n return str.replace(regExp, toUpper);\n}\n\n/**\n * Convert dash separated strings to pascal cased.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\nfunction pascalize(str) {\n return camelize(\"-\" + str);\n}\n\n// but we can use a longhand property instead.\n// https://caniuse.com/#search=mask\n\nvar mask = {\n noPrefill: ['mask'],\n supportedProperty: function supportedProperty(prop, style) {\n if (!/^mask/.test(prop)) return false;\n\n if (prefix.js === 'Webkit') {\n var longhand = 'mask-image';\n\n if (camelize(longhand) in style) {\n return prop;\n }\n\n if (prefix.js + pascalize(longhand) in style) {\n return prefix.css + prop;\n }\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=text-orientation\n\nvar textOrientation = {\n noPrefill: ['text-orientation'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'text-orientation') return false;\n\n if (prefix.vendor === 'apple' && !prefix.isTouch) {\n return prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=transform\n\nvar transform = {\n noPrefill: ['transform'],\n supportedProperty: function supportedProperty(prop, style, options) {\n if (prop !== 'transform') return false;\n\n if (options.transform) {\n return prop;\n }\n\n return prefix.css + prop;\n }\n};\n\n// https://caniuse.com/#search=transition\n\nvar transition = {\n noPrefill: ['transition'],\n supportedProperty: function supportedProperty(prop, style, options) {\n if (prop !== 'transition') return false;\n\n if (options.transition) {\n return prop;\n }\n\n return prefix.css + prop;\n }\n};\n\n// https://caniuse.com/#search=writing-mode\n\nvar writingMode = {\n noPrefill: ['writing-mode'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'writing-mode') return false;\n\n if (prefix.js === 'Webkit' || prefix.js === 'ms') {\n return prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=user-select\n\nvar userSelect = {\n noPrefill: ['user-select'],\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'user-select') return false;\n\n if (prefix.js === 'Moz' || prefix.js === 'ms' || prefix.vendor === 'apple') {\n return prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=multicolumn\n// https://github.com/postcss/autoprefixer/issues/491\n// https://github.com/postcss/autoprefixer/issues/177\n\nvar breakPropsOld = {\n supportedProperty: function supportedProperty(prop, style) {\n if (!/^break-/.test(prop)) return false;\n\n if (prefix.js === 'Webkit') {\n var jsProp = \"WebkitColumn\" + pascalize(prop);\n return jsProp in style ? prefix.css + \"column-\" + prop : false;\n }\n\n if (prefix.js === 'Moz') {\n var _jsProp = \"page\" + pascalize(prop);\n\n return _jsProp in style ? \"page-\" + prop : false;\n }\n\n return false;\n }\n};\n\n// See https://github.com/postcss/autoprefixer/issues/324.\n\nvar inlineLogicalOld = {\n supportedProperty: function supportedProperty(prop, style) {\n if (!/^(border|margin|padding)-inline/.test(prop)) return false;\n if (prefix.js === 'Moz') return prop;\n var newProp = prop.replace('-inline', '');\n return prefix.js + pascalize(newProp) in style ? prefix.css + newProp : false;\n }\n};\n\n// Camelization is required because we can't test using.\n// CSS syntax for e.g. in FF.\n\nvar unprefixed = {\n supportedProperty: function supportedProperty(prop, style) {\n return camelize(prop) in style ? prop : false;\n }\n};\n\nvar prefixed = {\n supportedProperty: function supportedProperty(prop, style) {\n var pascalized = pascalize(prop); // Return custom CSS variable without prefixing.\n\n if (prop[0] === '-') return prop; // Return already prefixed value without prefixing.\n\n if (prop[0] === '-' && prop[1] === '-') return prop;\n if (prefix.js + pascalized in style) return prefix.css + prop; // Try webkit fallback.\n\n if (prefix.js !== 'Webkit' && \"Webkit\" + pascalized in style) return \"-webkit-\" + prop;\n return false;\n }\n};\n\n// https://caniuse.com/#search=scroll-snap\n\nvar scrollSnap = {\n supportedProperty: function supportedProperty(prop) {\n if (prop.substring(0, 11) !== 'scroll-snap') return false;\n\n if (prefix.js === 'ms') {\n return \"\" + prefix.css + prop;\n }\n\n return prop;\n }\n};\n\n// https://caniuse.com/#search=overscroll-behavior\n\nvar overscrollBehavior = {\n supportedProperty: function supportedProperty(prop) {\n if (prop !== 'overscroll-behavior') return false;\n\n if (prefix.js === 'ms') {\n return prefix.css + \"scroll-chaining\";\n }\n\n return prop;\n }\n};\n\nvar propMap = {\n 'flex-grow': 'flex-positive',\n 'flex-shrink': 'flex-negative',\n 'flex-basis': 'flex-preferred-size',\n 'justify-content': 'flex-pack',\n order: 'flex-order',\n 'align-items': 'flex-align',\n 'align-content': 'flex-line-pack' // 'align-self' is handled by 'align-self' plugin.\n\n}; // Support old flex spec from 2012.\n\nvar flex2012 = {\n supportedProperty: function supportedProperty(prop, style) {\n var newProp = propMap[prop];\n if (!newProp) return false;\n return prefix.js + pascalize(newProp) in style ? prefix.css + newProp : false;\n }\n};\n\nvar propMap$1 = {\n flex: 'box-flex',\n 'flex-grow': 'box-flex',\n 'flex-direction': ['box-orient', 'box-direction'],\n order: 'box-ordinal-group',\n 'align-items': 'box-align',\n 'flex-flow': ['box-orient', 'box-direction'],\n 'justify-content': 'box-pack'\n};\nvar propKeys = Object.keys(propMap$1);\n\nvar prefixCss = function prefixCss(p) {\n return prefix.css + p;\n}; // Support old flex spec from 2009.\n\n\nvar flex2009 = {\n supportedProperty: function supportedProperty(prop, style, _ref) {\n var multiple = _ref.multiple;\n\n if (propKeys.indexOf(prop) > -1) {\n var newProp = propMap$1[prop];\n\n if (!Array.isArray(newProp)) {\n return prefix.js + pascalize(newProp) in style ? prefix.css + newProp : false;\n }\n\n if (!multiple) return false;\n\n for (var i = 0; i < newProp.length; i++) {\n if (!(prefix.js + pascalize(newProp[0]) in style)) {\n return false;\n }\n }\n\n return newProp.map(prefixCss);\n }\n\n return false;\n }\n};\n\n// plugins = [\n// ...plugins,\n// breakPropsOld,\n// inlineLogicalOld,\n// unprefixed,\n// prefixed,\n// scrollSnap,\n// flex2012,\n// flex2009\n// ]\n// Plugins without 'noPrefill' value, going last.\n// 'flex-*' plugins should be at the bottom.\n// 'flex2009' going after 'flex2012'.\n// 'prefixed' going after 'unprefixed'\n\nvar plugins = [appearence, colorAdjust, mask, textOrientation, transform, transition, writingMode, userSelect, breakPropsOld, inlineLogicalOld, unprefixed, prefixed, scrollSnap, overscrollBehavior, flex2012, flex2009];\nvar propertyDetectors = plugins.filter(function (p) {\n return p.supportedProperty;\n}).map(function (p) {\n return p.supportedProperty;\n});\nvar noPrefill = plugins.filter(function (p) {\n return p.noPrefill;\n}).reduce(function (a, p) {\n a.push.apply(a, _toConsumableArray(p.noPrefill));\n return a;\n}, []);\n\nvar el;\nvar cache = {};\n\nif (isInBrowser) {\n el = document.createElement('p'); // We test every property on vendor prefix requirement.\n // Once tested, result is cached. It gives us up to 70% perf boost.\n // http://jsperf.com/element-style-object-access-vs-plain-object\n //\n // Prefill cache with known css properties to reduce amount of\n // properties we need to feature test at runtime.\n // http://davidwalsh.name/vendor-prefix\n\n var computed = window.getComputedStyle(document.documentElement, '');\n\n for (var key$1 in computed) {\n // eslint-disable-next-line no-restricted-globals\n if (!isNaN(key$1)) cache[computed[key$1]] = computed[key$1];\n } // Properties that cannot be correctly detected using the\n // cache prefill method.\n\n\n noPrefill.forEach(function (x) {\n return delete cache[x];\n });\n}\n/**\n * Test if a property is supported, returns supported property with vendor\n * prefix if required. Returns `false` if not supported.\n *\n * @param {String} prop dash separated\n * @param {Object} [options]\n * @return {String|Boolean}\n * @api public\n */\n\n\nfunction supportedProperty(prop, options) {\n if (options === void 0) {\n options = {};\n }\n\n // For server-side rendering.\n if (!el) return prop; // Remove cache for benchmark tests or return property from the cache.\n\n if (process.env.NODE_ENV !== 'benchmark' && cache[prop] != null) {\n return cache[prop];\n } // Check if 'transition' or 'transform' natively supported in browser.\n\n\n if (prop === 'transition' || prop === 'transform') {\n options[prop] = prop in el.style;\n } // Find a plugin for current prefix property.\n\n\n for (var i = 0; i < propertyDetectors.length; i++) {\n cache[prop] = propertyDetectors[i](prop, el.style, options); // Break loop, if value found.\n\n if (cache[prop]) break;\n } // Reset styles for current property.\n // Firefox can even throw an error for invalid properties, e.g., \"0\".\n\n\n try {\n el.style[prop] = '';\n } catch (err) {\n return false;\n }\n\n return cache[prop];\n}\n\nvar cache$1 = {};\nvar transitionProperties = {\n transition: 1,\n 'transition-property': 1,\n '-webkit-transition': 1,\n '-webkit-transition-property': 1\n};\nvar transPropsRegExp = /(^\\s*[\\w-]+)|, (\\s*[\\w-]+)(?![^()]*\\))/g;\nvar el$1;\n/**\n * Returns prefixed value transition/transform if needed.\n *\n * @param {String} match\n * @param {String} p1\n * @param {String} p2\n * @return {String}\n * @api private\n */\n\nfunction prefixTransitionCallback(match, p1, p2) {\n if (p1 === 'var') return 'var';\n if (p1 === 'all') return 'all';\n if (p2 === 'all') return ', all';\n var prefixedValue = p1 ? supportedProperty(p1) : \", \" + supportedProperty(p2);\n if (!prefixedValue) return p1 || p2;\n return prefixedValue;\n}\n\nif (isInBrowser) el$1 = document.createElement('p');\n/**\n * Returns prefixed value if needed. Returns `false` if value is not supported.\n *\n * @param {String} property\n * @param {String} value\n * @return {String|Boolean}\n * @api public\n */\n\nfunction supportedValue(property, value) {\n // For server-side rendering.\n var prefixedValue = value;\n if (!el$1 || property === 'content') return value; // It is a string or a number as a string like '1'.\n // We want only prefixable values here.\n // eslint-disable-next-line no-restricted-globals\n\n if (typeof prefixedValue !== 'string' || !isNaN(parseInt(prefixedValue, 10))) {\n return prefixedValue;\n } // Create cache key for current value.\n\n\n var cacheKey = property + prefixedValue; // Remove cache for benchmark tests or return value from cache.\n\n if (process.env.NODE_ENV !== 'benchmark' && cache$1[cacheKey] != null) {\n return cache$1[cacheKey];\n } // IE can even throw an error in some cases, for e.g. style.content = 'bar'.\n\n\n try {\n // Test value as it is.\n el$1.style[property] = prefixedValue;\n } catch (err) {\n // Return false if value not supported.\n cache$1[cacheKey] = false;\n return false;\n } // If 'transition' or 'transition-property' property.\n\n\n if (transitionProperties[property]) {\n prefixedValue = prefixedValue.replace(transPropsRegExp, prefixTransitionCallback);\n } else if (el$1.style[property] === '') {\n // Value with a vendor prefix.\n prefixedValue = prefix.css + prefixedValue; // Hardcode test to convert \"flex\" to \"-ms-flexbox\" for IE10.\n\n if (prefixedValue === '-ms-flex') el$1.style[property] = '-ms-flexbox'; // Test prefixed value.\n\n el$1.style[property] = prefixedValue; // Return false if value not supported.\n\n if (el$1.style[property] === '') {\n cache$1[cacheKey] = false;\n return false;\n }\n } // Reset styles for current property.\n\n\n el$1.style[property] = ''; // Write current value to cache.\n\n cache$1[cacheKey] = prefixedValue;\n return cache$1[cacheKey];\n}\n\nexport { prefix, supportedKeyframes, supportedProperty, supportedValue };\n","import { supportedKeyframes, supportedValue, supportedProperty } from 'css-vendor';\nimport { toCssValue } from 'jss';\n\n/**\n * Add vendor prefix to a property name when needed.\n *\n * @api public\n */\n\nfunction jssVendorPrefixer() {\n function onProcessRule(rule) {\n if (rule.type === 'keyframes') {\n var atRule = rule;\n atRule.at = supportedKeyframes(atRule.at);\n }\n }\n\n function prefixStyle(style) {\n for (var prop in style) {\n var value = style[prop];\n\n if (prop === 'fallbacks' && Array.isArray(value)) {\n style[prop] = value.map(prefixStyle);\n continue;\n }\n\n var changeProp = false;\n var supportedProp = supportedProperty(prop);\n if (supportedProp && supportedProp !== prop) changeProp = true;\n var changeValue = false;\n var supportedValue$$1 = supportedValue(supportedProp, toCssValue(value));\n if (supportedValue$$1 && supportedValue$$1 !== value) changeValue = true;\n\n if (changeProp || changeValue) {\n if (changeProp) delete style[prop];\n style[supportedProp || prop] = supportedValue$$1 || value;\n }\n }\n\n return style;\n }\n\n function onProcessStyle(style, rule) {\n if (rule.type !== 'style') return style;\n return prefixStyle(style);\n }\n\n function onChangeValue(value, prop) {\n return supportedValue(prop, toCssValue(value)) || value;\n }\n\n return {\n onProcessRule: onProcessRule,\n onProcessStyle: onProcessStyle,\n onChangeValue: onChangeValue\n };\n}\n\nexport default jssVendorPrefixer;\n","/**\n * Sort props by length.\n */\nfunction jssPropsSort() {\n var sort = function sort(prop0, prop1) {\n if (prop0.length === prop1.length) {\n return prop0 > prop1 ? 1 : -1;\n }\n\n return prop0.length - prop1.length;\n };\n\n return {\n onProcessStyle: function onProcessStyle(style, rule) {\n if (rule.type !== 'style') return style;\n var newStyle = {};\n var props = Object.keys(style).sort(sort);\n\n for (var i = 0; i < props.length; i++) {\n newStyle[props[i]] = style[props[i]];\n }\n\n return newStyle;\n }\n };\n}\n\nexport default jssPropsSort;\n","import functions from 'jss-plugin-rule-value-function';\nimport global from 'jss-plugin-global';\nimport nested from 'jss-plugin-nested';\nimport camelCase from 'jss-plugin-camel-case';\nimport defaultUnit from 'jss-plugin-default-unit';\nimport vendorPrefixer from 'jss-plugin-vendor-prefixer';\nimport propsSort from 'jss-plugin-props-sort'; // Subset of jss-preset-default with only the plugins the Material-UI components are using.\n\nfunction jssPreset() {\n return {\n plugins: [functions(), global(), nested(), camelCase(), defaultUnit(), // Disable the vendor prefixer server-side, it does nothing.\n // This way, we can get a performance boost.\n // In the documentation, we are using `autoprefixer` to solve this problem.\n typeof window === 'undefined' ? null : vendorPrefixer(), propsSort()]\n };\n}\n\nexport default jssPreset;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nimport createGenerateClassName from '../createGenerateClassName';\nimport { create } from 'jss';\nimport jssPreset from '../jssPreset'; // Default JSS instance.\n\nvar jss = create(jssPreset()); // Use a singleton or the provided one by the context.\n//\n// The counter-based approach doesn't tolerate any mistake.\n// It's much safer to use the same counter everywhere.\n\nvar generateClassName = createGenerateClassName(); // Exported for test purposes\n\nexport var sheetsManager = new Map();\nvar defaultOptions = {\n disableGeneration: false,\n generateClassName: generateClassName,\n jss: jss,\n sheetsCache: null,\n sheetsManager: sheetsManager,\n sheetsRegistry: null\n};\nexport var StylesContext = React.createContext(defaultOptions);\n\nif (process.env.NODE_ENV !== 'production') {\n StylesContext.displayName = 'StylesContext';\n}\n\nvar injectFirstNode;\n\nfunction StylesProvider(props) {\n var children = props.children,\n _props$injectFirst = props.injectFirst,\n injectFirst = _props$injectFirst === void 0 ? false : _props$injectFirst,\n _props$disableGenerat = props.disableGeneration,\n disableGeneration = _props$disableGenerat === void 0 ? false : _props$disableGenerat,\n localOptions = _objectWithoutProperties(props, [\"children\", \"injectFirst\", \"disableGeneration\"]);\n\n var outerOptions = React.useContext(StylesContext);\n\n var context = _extends({}, outerOptions, {\n disableGeneration: disableGeneration\n }, localOptions);\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof window === 'undefined' && !context.sheetsManager) {\n console.error('Material-UI: you need to use the ServerStyleSheets API when rendering on the server.');\n }\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (context.jss.options.insertionPoint && injectFirst) {\n console.error('Material-UI: you cannot use a custom insertionPoint and <StylesContext injectFirst> at the same time.');\n }\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (injectFirst && localOptions.jss) {\n console.error('Material-UI: you cannot use the jss and injectFirst props at the same time.');\n }\n }\n\n if (!context.jss.options.insertionPoint && injectFirst && typeof window !== 'undefined') {\n if (!injectFirstNode) {\n var head = document.head;\n injectFirstNode = document.createComment('mui-inject-first');\n head.insertBefore(injectFirstNode, head.firstChild);\n }\n\n context.jss = create({\n plugins: jssPreset().plugins,\n insertionPoint: injectFirstNode\n });\n }\n\n return React.createElement(StylesContext.Provider, {\n value: context\n }, children);\n}\n\nprocess.env.NODE_ENV !== \"production\" ? StylesProvider.propTypes = {\n /**\n * Your component tree.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * You can disable the generation of the styles with this option.\n * It can be useful when traversing the React tree outside of the HTML\n * rendering step on the server.\n * Let's say you are using react-apollo to extract all\n * the queries made by the interface server-side - you can significantly speed up the traversal with this prop.\n */\n disableGeneration: PropTypes.bool,\n\n /**\n * JSS's class name generator.\n */\n generateClassName: PropTypes.func,\n\n /**\n * By default, the styles are injected last in the <head> element of the page.\n * As a result, they gain more specificity than any other style sheet.\n * If you want to override Material-UI's styles, set this prop.\n */\n injectFirst: PropTypes.bool,\n\n /**\n * JSS's instance.\n */\n jss: PropTypes.object,\n\n /**\n * @ignore\n */\n serverGenerateClassName: PropTypes.func,\n\n /**\n * @ignore\n *\n * Beta feature.\n *\n * Cache for the sheets.\n */\n sheetsCache: PropTypes.object,\n\n /**\n * @ignore\n *\n * The sheetsManager is used to deduplicate style sheet injection in the page.\n * It's deduplicating using the (theme, styles) couple.\n * On the server, you should provide a new instance for each request.\n */\n sheetsManager: PropTypes.object,\n\n /**\n * @ignore\n *\n * Collect the sheets.\n */\n sheetsRegistry: PropTypes.object\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n process.env.NODE_ENV !== \"production\" ? StylesProvider.propTypes = exactProp(StylesProvider.propTypes) : void 0;\n}\n\nexport default StylesProvider;","/* eslint-disable import/prefer-default-export */\n// Global index counter to preserve source order.\n// We create the style sheet during at the creation of the component,\n// children are handled after the parents, so the order of style elements would be parent->child.\n// It is a problem though when a parent passes a className\n// which needs to override any child's styles.\n// StyleSheet of the child has a higher specificity, because of the source order.\n// So our solution is to render sheets them in the reverse order child->sheet, so\n// that parent has a higher specificity.\nvar indexCounter = -1e9;\nexport function increment() {\n indexCounter += 1;\n\n if (process.env.NODE_ENV !== 'production') {\n if (indexCounter >= 0) {\n console.warn(['Material-UI: you might have a memory leak.', 'The indexCounter is not supposed to grow that much.'].join('\\n'));\n }\n }\n\n return indexCounter;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _typeof from \"@babel/runtime/helpers/esm/typeof\";\nimport { deepmerge } from '@material-ui/utils';\nimport noopTheme from './noopTheme';\n\nfunction getStylesCreator(stylesOrCreator) {\n var themingEnabled = typeof stylesOrCreator === 'function';\n\n if (process.env.NODE_ENV !== 'production') {\n if (_typeof(stylesOrCreator) !== 'object' && !themingEnabled) {\n console.error(['Material-UI: the `styles` argument provided is invalid.', 'You need to provide a function generating the styles or a styles object.'].join('\\n'));\n }\n }\n\n return {\n create: function create(theme, name) {\n var styles;\n\n try {\n styles = themingEnabled ? stylesOrCreator(theme) : stylesOrCreator;\n } catch (err) {\n if (process.env.NODE_ENV !== 'production') {\n if (themingEnabled === true && theme === noopTheme) {\n // TODO: prepend error message/name instead\n console.error(['Material-UI: the `styles` argument provided is invalid.', 'You are providing a function without a theme in the context.', 'One of the parent elements needs to use a ThemeProvider.'].join('\\n'));\n }\n }\n\n throw err;\n }\n\n if (!name || !theme.overrides || !theme.overrides[name]) {\n return styles;\n }\n\n var overrides = theme.overrides[name];\n\n var stylesWithOverrides = _extends({}, styles);\n\n Object.keys(overrides).forEach(function (key) {\n if (process.env.NODE_ENV !== 'production') {\n if (!stylesWithOverrides[key]) {\n console.warn(['Material-UI: you are trying to override a style that does not exist.', \"Fix the `\".concat(key, \"` key of `theme.overrides.\").concat(name, \"`.\")].join('\\n'));\n }\n }\n\n stylesWithOverrides[key] = deepmerge(stylesWithOverrides[key], overrides[key]);\n });\n return stylesWithOverrides;\n },\n options: {}\n };\n}\n\nexport default getStylesCreator;","// We use the same empty object to ref count the styles that don't need a theme object.\nvar noopTheme = {};\nexport default noopTheme;","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport { getDynamicStyles } from 'jss';\nimport mergeClasses from '../mergeClasses';\nimport multiKeyStore from './multiKeyStore';\nimport useTheme from '../useTheme';\nimport { StylesContext } from '../StylesProvider';\nimport { increment } from './indexCounter';\nimport getStylesCreator from '../getStylesCreator';\nimport noopTheme from '../getStylesCreator/noopTheme';\n\nfunction getClasses(_ref, classes, Component) {\n var state = _ref.state,\n stylesOptions = _ref.stylesOptions;\n\n if (stylesOptions.disableGeneration) {\n return classes || {};\n }\n\n if (!state.cacheClasses) {\n state.cacheClasses = {\n // Cache for the finalized classes value.\n value: null,\n // Cache for the last used classes prop pointer.\n lastProp: null,\n // Cache for the last used rendered classes pointer.\n lastJSS: {}\n };\n } // Tracks if either the rendered classes or classes prop has changed,\n // requiring the generation of a new finalized classes object.\n\n\n var generate = false;\n\n if (state.classes !== state.cacheClasses.lastJSS) {\n state.cacheClasses.lastJSS = state.classes;\n generate = true;\n }\n\n if (classes !== state.cacheClasses.lastProp) {\n state.cacheClasses.lastProp = classes;\n generate = true;\n }\n\n if (generate) {\n state.cacheClasses.value = mergeClasses({\n baseClasses: state.cacheClasses.lastJSS,\n newClasses: classes,\n Component: Component\n });\n }\n\n return state.cacheClasses.value;\n}\n\nfunction attach(_ref2, props) {\n var state = _ref2.state,\n theme = _ref2.theme,\n stylesOptions = _ref2.stylesOptions,\n stylesCreator = _ref2.stylesCreator,\n name = _ref2.name;\n\n if (stylesOptions.disableGeneration) {\n return;\n }\n\n var sheetManager = multiKeyStore.get(stylesOptions.sheetsManager, stylesCreator, theme);\n\n if (!sheetManager) {\n sheetManager = {\n refs: 0,\n staticSheet: null,\n dynamicStyles: null\n };\n multiKeyStore.set(stylesOptions.sheetsManager, stylesCreator, theme, sheetManager);\n }\n\n var options = _extends({}, stylesCreator.options, {}, stylesOptions, {\n theme: theme,\n flip: typeof stylesOptions.flip === 'boolean' ? stylesOptions.flip : theme.direction === 'rtl'\n });\n\n options.generateId = options.serverGenerateClassName || options.generateClassName;\n var sheetsRegistry = stylesOptions.sheetsRegistry;\n\n if (sheetManager.refs === 0) {\n var staticSheet;\n\n if (stylesOptions.sheetsCache) {\n staticSheet = multiKeyStore.get(stylesOptions.sheetsCache, stylesCreator, theme);\n }\n\n var styles = stylesCreator.create(theme, name);\n\n if (!staticSheet) {\n staticSheet = stylesOptions.jss.createStyleSheet(styles, _extends({\n link: false\n }, options));\n staticSheet.attach();\n\n if (stylesOptions.sheetsCache) {\n multiKeyStore.set(stylesOptions.sheetsCache, stylesCreator, theme, staticSheet);\n }\n }\n\n if (sheetsRegistry) {\n sheetsRegistry.add(staticSheet);\n }\n\n sheetManager.staticSheet = staticSheet;\n sheetManager.dynamicStyles = getDynamicStyles(styles);\n }\n\n if (sheetManager.dynamicStyles) {\n var dynamicSheet = stylesOptions.jss.createStyleSheet(sheetManager.dynamicStyles, _extends({\n link: true\n }, options));\n dynamicSheet.update(props);\n dynamicSheet.attach();\n state.dynamicSheet = dynamicSheet;\n state.classes = mergeClasses({\n baseClasses: sheetManager.staticSheet.classes,\n newClasses: dynamicSheet.classes\n });\n\n if (sheetsRegistry) {\n sheetsRegistry.add(dynamicSheet);\n }\n } else {\n state.classes = sheetManager.staticSheet.classes;\n }\n\n sheetManager.refs += 1;\n}\n\nfunction update(_ref3, props) {\n var state = _ref3.state;\n\n if (state.dynamicSheet) {\n state.dynamicSheet.update(props);\n }\n}\n\nfunction detach(_ref4) {\n var state = _ref4.state,\n theme = _ref4.theme,\n stylesOptions = _ref4.stylesOptions,\n stylesCreator = _ref4.stylesCreator;\n\n if (stylesOptions.disableGeneration) {\n return;\n }\n\n var sheetManager = multiKeyStore.get(stylesOptions.sheetsManager, stylesCreator, theme);\n sheetManager.refs -= 1;\n var sheetsRegistry = stylesOptions.sheetsRegistry;\n\n if (sheetManager.refs === 0) {\n multiKeyStore.delete(stylesOptions.sheetsManager, stylesCreator, theme);\n stylesOptions.jss.removeStyleSheet(sheetManager.staticSheet);\n\n if (sheetsRegistry) {\n sheetsRegistry.remove(sheetManager.staticSheet);\n }\n }\n\n if (state.dynamicSheet) {\n stylesOptions.jss.removeStyleSheet(state.dynamicSheet);\n\n if (sheetsRegistry) {\n sheetsRegistry.remove(state.dynamicSheet);\n }\n }\n}\n\nfunction useSynchronousEffect(func, values) {\n var key = React.useRef([]);\n var output; // Store \"generation\" key. Just returns a new object every time\n\n var currentKey = React.useMemo(function () {\n return {};\n }, values); // eslint-disable-line react-hooks/exhaustive-deps\n // \"the first render\", or \"memo dropped the value\"\n\n if (key.current !== currentKey) {\n key.current = currentKey;\n output = func();\n }\n\n React.useEffect(function () {\n return function () {\n if (output) {\n output();\n }\n };\n }, [currentKey] // eslint-disable-line react-hooks/exhaustive-deps\n );\n}\n\nfunction makeStyles(stylesOrCreator) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var name = options.name,\n classNamePrefixOption = options.classNamePrefix,\n Component = options.Component,\n _options$defaultTheme = options.defaultTheme,\n defaultTheme = _options$defaultTheme === void 0 ? noopTheme : _options$defaultTheme,\n stylesOptions2 = _objectWithoutProperties(options, [\"name\", \"classNamePrefix\", \"Component\", \"defaultTheme\"]);\n\n var stylesCreator = getStylesCreator(stylesOrCreator);\n var classNamePrefix = name || classNamePrefixOption || 'makeStyles';\n stylesCreator.options = {\n index: increment(),\n name: name,\n meta: classNamePrefix,\n classNamePrefix: classNamePrefix\n };\n return function () {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var theme = useTheme() || defaultTheme;\n\n var stylesOptions = _extends({}, React.useContext(StylesContext), {}, stylesOptions2);\n\n var instance = React.useRef();\n var shouldUpdate = React.useRef();\n useSynchronousEffect(function () {\n var current = {\n name: name,\n state: {},\n stylesCreator: stylesCreator,\n stylesOptions: stylesOptions,\n theme: theme\n };\n attach(current, props);\n shouldUpdate.current = false;\n instance.current = current;\n return function () {\n detach(current);\n };\n }, [theme, stylesCreator]);\n React.useEffect(function () {\n if (shouldUpdate.current) {\n update(instance.current, props);\n }\n\n shouldUpdate.current = true;\n });\n return getClasses(instance.current, props.classes, Component);\n };\n}\n\nexport default makeStyles;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport { useFormControl } from '../FormControl';\nimport withStyles from '../styles/withStyles';\nimport Typography from '../Typography';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n cursor: 'pointer',\n // For correct alignment with the text.\n verticalAlign: 'middle',\n WebkitTapHighlightColor: 'transparent',\n marginLeft: -11,\n marginRight: 16,\n // used for row presentation of radio/checkbox\n '&$disabled': {\n cursor: 'default'\n }\n },\n\n /* Styles applied to the root element if `labelPlacement=\"start\"`. */\n labelPlacementStart: {\n flexDirection: 'row-reverse',\n marginLeft: 16,\n // used for row presentation of radio/checkbox\n marginRight: -11\n },\n\n /* Styles applied to the root element if `labelPlacement=\"top\"`. */\n labelPlacementTop: {\n flexDirection: 'column-reverse',\n marginLeft: 16\n },\n\n /* Styles applied to the root element if `labelPlacement=\"bottom\"`. */\n labelPlacementBottom: {\n flexDirection: 'column',\n marginLeft: 16\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the label's Typography component. */\n label: {\n '&$disabled': {\n color: theme.palette.text.disabled\n }\n }\n };\n};\n/**\n * Drop in replacement of the `Radio`, `Switch` and `Checkbox` component.\n * Use this component if you want to display an extra label.\n */\n\nvar FormControlLabel = React.forwardRef(function FormControlLabel(props, ref) {\n var checked = props.checked,\n classes = props.classes,\n className = props.className,\n control = props.control,\n disabledProp = props.disabled,\n inputRef = props.inputRef,\n label = props.label,\n _props$labelPlacement = props.labelPlacement,\n labelPlacement = _props$labelPlacement === void 0 ? 'end' : _props$labelPlacement,\n name = props.name,\n onChange = props.onChange,\n value = props.value,\n other = _objectWithoutProperties(props, [\"checked\", \"classes\", \"className\", \"control\", \"disabled\", \"inputRef\", \"label\", \"labelPlacement\", \"name\", \"onChange\", \"value\"]);\n\n var muiFormControl = useFormControl();\n var disabled = disabledProp;\n\n if (typeof disabled === 'undefined' && typeof control.props.disabled !== 'undefined') {\n disabled = control.props.disabled;\n }\n\n if (typeof disabled === 'undefined' && muiFormControl) {\n disabled = muiFormControl.disabled;\n }\n\n var controlProps = {\n disabled: disabled\n };\n ['checked', 'name', 'onChange', 'value', 'inputRef'].forEach(function (key) {\n if (typeof control.props[key] === 'undefined' && typeof props[key] !== 'undefined') {\n controlProps[key] = props[key];\n }\n });\n return React.createElement(\"label\", _extends({\n className: clsx(classes.root, className, labelPlacement !== 'end' && classes[\"labelPlacement\".concat(capitalize(labelPlacement))], disabled && classes.disabled),\n ref: ref\n }, other), React.cloneElement(control, controlProps), React.createElement(Typography, {\n component: \"span\",\n className: clsx(classes.label, disabled && classes.disabled)\n }, label));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormControlLabel.propTypes = {\n /**\n * If `true`, the component appears selected.\n */\n checked: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * A control element. For instance, it can be be a `Radio`, a `Switch` or a `Checkbox`.\n */\n control: PropTypes.element,\n\n /**\n * If `true`, the control will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * The text to be used in an enclosing label element.\n */\n label: PropTypes.node,\n\n /**\n * The position of the label.\n */\n labelPlacement: PropTypes.oneOf(['end', 'start', 'top', 'bottom']),\n\n /*\n * @ignore\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * The value of the component.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormControlLabel'\n})(FormControlLabel);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { getDisplayName } from '@material-ui/utils';\n\nfunction mergeClasses() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var baseClasses = options.baseClasses,\n newClasses = options.newClasses,\n Component = options.Component;\n\n if (!newClasses) {\n return baseClasses;\n }\n\n var nextClasses = _extends({}, baseClasses);\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof newClasses === 'string') {\n console.error([\"Material-UI: the value `\".concat(newClasses, \"` \") + \"provided to the classes prop of \".concat(getDisplayName(Component), \" is incorrect.\"), 'You might want to use the className prop instead.'].join('\\n'));\n return baseClasses;\n }\n }\n\n Object.keys(newClasses).forEach(function (key) {\n if (process.env.NODE_ENV !== 'production') {\n if (!baseClasses[key] && newClasses[key]) {\n console.error([\"Material-UI: the key `\".concat(key, \"` \") + \"provided to the classes prop is not implemented in \".concat(getDisplayName(Component), \".\"), \"You can only override one of the following: \".concat(Object.keys(baseClasses).join(','), \".\")].join('\\n'));\n }\n\n if (newClasses[key] && typeof newClasses[key] !== 'string') {\n console.error([\"Material-UI: the key `\".concat(key, \"` \") + \"provided to the classes prop is not valid for \".concat(getDisplayName(Component), \".\"), \"You need to provide a non empty string instead of: \".concat(newClasses[key], \".\")].join('\\n'));\n }\n }\n\n if (newClasses[key]) {\n nextClasses[key] = \"\".concat(baseClasses[key], \" \").concat(newClasses[key]);\n }\n });\n return nextClasses;\n}\n\nexport default mergeClasses;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _typeof from \"@babel/runtime/helpers/esm/typeof\";\nexport function isObject(item) {\n return item && _typeof(item) === 'object' && !Array.isArray(item);\n}\nexport default function deepmerge(target, source) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n clone: true\n };\n var output = options.clone ? _extends({}, target) : target;\n\n if (isObject(target) && isObject(source)) {\n Object.keys(source).forEach(function (key) {\n // Avoid prototype pollution\n if (key === '__proto__') {\n return;\n }\n\n if (isObject(source[key]) && key in target) {\n output[key] = deepmerge(target[key], source[key], options);\n } else {\n output[key] = source[key];\n }\n });\n }\n\n return output;\n}","/* eslint-disable no-restricted-syntax */\nfunction getThemeProps(params) {\n var theme = params.theme,\n name = params.name,\n props = params.props;\n\n if (!theme || !theme.props || !theme.props[name]) {\n return props;\n } // Resolve default props, code borrow from React source.\n // https://github.com/facebook/react/blob/15a8f031838a553e41c0b66eb1bcf1da8448104d/packages/react/src/ReactElement.js#L221\n\n\n var defaultProps = theme.props[name];\n var propName;\n\n for (propName in defaultProps) {\n if (props[propName] === undefined) {\n props[propName] = defaultProps[propName];\n }\n }\n\n return props;\n}\n\nexport default getThemeProps;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n// @inheritedComponent IconButton\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport { fade } from '../styles/colorManipulator';\nimport capitalize from '../utils/capitalize';\nimport SwitchBase from '../internal/SwitchBase';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n width: 34 + 12 * 2,\n height: 14 + 12 * 2,\n overflow: 'hidden',\n padding: 12,\n boxSizing: 'border-box',\n position: 'relative',\n flexShrink: 0,\n zIndex: 0,\n // Reset the stacking context.\n verticalAlign: 'middle' // For correct alignment with the text.\n\n },\n\n /* Styles applied to the root element if `edge=\"start\"`. */\n edgeStart: {\n marginLeft: -8\n },\n\n /* Styles applied to the root element if `edge=\"end\"`. */\n edgeEnd: {\n marginRight: -8\n },\n\n /* Styles applied to the internal `SwitchBase` component's `root` class. */\n switchBase: {\n position: 'absolute',\n top: 0,\n left: 0,\n zIndex: 1,\n // Render above the focus ripple.\n color: theme.palette.type === 'light' ? theme.palette.grey[50] : theme.palette.grey[400],\n transition: theme.transitions.create(['left', 'transform'], {\n duration: theme.transitions.duration.shortest\n }),\n '&$checked': {\n transform: 'translateX(20px)'\n },\n '&$disabled': {\n color: theme.palette.type === 'light' ? theme.palette.grey[400] : theme.palette.grey[800]\n },\n '&$checked + $track': {\n opacity: 0.5\n },\n '&$disabled + $track': {\n opacity: theme.palette.type === 'light' ? 0.12 : 0.1\n }\n },\n\n /* Styles applied to the internal SwitchBase component's root element if `color=\"primary\"`. */\n colorPrimary: {\n '&$checked': {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.type === 'light' ? theme.palette.grey[400] : theme.palette.grey[800]\n },\n '&$checked + $track': {\n backgroundColor: theme.palette.primary.main\n },\n '&$disabled + $track': {\n backgroundColor: theme.palette.type === 'light' ? theme.palette.common.black : theme.palette.common.white\n }\n },\n\n /* Styles applied to the internal SwitchBase component's root element if `color=\"secondary\"`. */\n colorSecondary: {\n '&$checked': {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.type === 'light' ? theme.palette.grey[400] : theme.palette.grey[800]\n },\n '&$checked + $track': {\n backgroundColor: theme.palette.secondary.main\n },\n '&$disabled + $track': {\n backgroundColor: theme.palette.type === 'light' ? theme.palette.common.black : theme.palette.common.white\n }\n },\n\n /* Styles applied to the root element if `size=\"small\"`. */\n sizeSmall: {\n width: 40,\n height: 24,\n padding: 7,\n '& $thumb': {\n width: 16,\n height: 16\n },\n '& $switchBase': {\n padding: 4,\n '&$checked': {\n transform: 'translateX(16px)'\n }\n }\n },\n\n /* Pseudo-class applied to the internal `SwitchBase` component's `checked` class. */\n checked: {},\n\n /* Pseudo-class applied to the internal SwitchBase component's disabled class. */\n disabled: {},\n\n /* Styles applied to the internal SwitchBase component's input element. */\n input: {\n left: '-100%',\n width: '300%'\n },\n\n /* Styles used to create the thumb passed to the internal `SwitchBase` component `icon` prop. */\n thumb: {\n boxShadow: theme.shadows[1],\n backgroundColor: 'currentColor',\n width: 20,\n height: 20,\n borderRadius: '50%'\n },\n\n /* Styles applied to the track element. */\n track: {\n height: '100%',\n width: '100%',\n borderRadius: 14 / 2,\n zIndex: -1,\n transition: theme.transitions.create(['opacity', 'background-color'], {\n duration: theme.transitions.duration.shortest\n }),\n backgroundColor: theme.palette.type === 'light' ? theme.palette.common.black : theme.palette.common.white,\n opacity: theme.palette.type === 'light' ? 0.38 : 0.3\n }\n };\n};\nvar Switch = React.forwardRef(function Switch(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'secondary' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$edge = props.edge,\n edge = _props$edge === void 0 ? false : _props$edge,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"color\", \"disabled\", \"edge\", \"size\"]);\n\n var icon = React.createElement(\"span\", {\n className: classes.thumb\n });\n return React.createElement(\"span\", {\n className: clsx(classes.root, className, {\n start: classes.edgeStart,\n end: classes.edgeEnd\n }[edge], {\n small: classes[\"size\".concat(capitalize(size))]\n }[size])\n }, React.createElement(SwitchBase, _extends({\n type: \"checkbox\",\n icon: icon,\n checkedIcon: icon,\n classes: {\n root: clsx(classes.switchBase, classes[\"color\".concat(capitalize(color))]),\n input: classes.input,\n checked: classes.checked,\n disabled: classes.disabled\n },\n ref: ref,\n disabled: disabled\n }, other)), React.createElement(\"span\", {\n className: classes.track\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? Switch.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary', 'default']),\n\n /**\n * @ignore\n */\n defaultChecked: PropTypes.bool,\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * If given, uses a negative margin to counteract the padding on one\n * side (this is often helpful for aligning the left or right\n * side of the icon with content above or below, without ruining the border\n * size and shape).\n */\n edge: PropTypes.oneOf(['start', 'end', false]),\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the switch.\n * `small` is equivalent to the dense switch styling.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string,\n\n /**\n * The value of the component. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiSwitch'\n})(Switch);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { makeStyles as makeStylesWithoutDefault } from '@material-ui/styles';\nimport defaultTheme from './defaultTheme';\n\nfunction makeStyles(stylesOrCreator) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return makeStylesWithoutDefault(stylesOrCreator, _extends({\n defaultTheme: defaultTheme\n }, options));\n}\n\nexport default makeStyles;","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var elevations = {};\n theme.shadows.forEach(function (shadow, index) {\n elevations[\"elevation\".concat(index)] = {\n boxShadow: shadow\n };\n });\n return _extends({\n /* Styles applied to the root element. */\n root: {\n backgroundColor: theme.palette.background.paper,\n color: theme.palette.text.primary,\n transition: theme.transitions.create('box-shadow')\n },\n\n /* Styles applied to the root element if `square={false}`. */\n rounded: {\n borderRadius: theme.shape.borderRadius\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"` */\n outlined: {\n border: \"1px solid \".concat(theme.palette.divider)\n }\n }, elevations);\n};\nvar Paper = React.forwardRef(function Paper(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$square = props.square,\n square = _props$square === void 0 ? false : _props$square,\n _props$elevation = props.elevation,\n elevation = _props$elevation === void 0 ? 1 : _props$elevation,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'elevation' : _props$variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"square\", \"elevation\", \"variant\"]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (classes[\"elevation\".concat(elevation)] === undefined) {\n console.error(\"Material-UI: this elevation `\".concat(elevation, \"` is not implemented.\"));\n }\n }\n\n return React.createElement(Component, _extends({\n className: clsx(classes.root, className, variant === 'outlined' ? classes.outlined : classes[\"elevation\".concat(elevation)], !square && classes.rounded),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Paper.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * Shadow depth, corresponds to `dp` in the spec.\n * It accepts values between 0 and 24 inclusive.\n */\n elevation: PropTypes.number,\n\n /**\n * If `true`, rounded corners are disabled.\n */\n square: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['elevation', 'outlined'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiPaper'\n})(Paper);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\n// A grid component using the following libs as inspiration.\n//\n// For the implementation:\n// - https://getbootstrap.com/docs/4.3/layout/grid/\n// - https://github.com/kristoferjoseph/flexboxgrid/blob/master/src/css/flexboxgrid.css\n// - https://github.com/roylee0704/react-flexbox-grid\n// - https://material.angularjs.org/latest/layout/introduction\n//\n// Follow this flexbox Guide to better understand the underlying model:\n// - https://css-tricks.com/snippets/css/a-guide-to-flexbox/\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport requirePropFactory from '../utils/requirePropFactory';\nvar SPACINGS = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];\nvar GRID_SIZES = ['auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12];\n\nfunction generateGrid(globalStyles, theme, breakpoint) {\n var styles = {};\n GRID_SIZES.forEach(function (size) {\n var key = \"grid-\".concat(breakpoint, \"-\").concat(size);\n\n if (size === true) {\n // For the auto layouting\n styles[key] = {\n flexBasis: 0,\n flexGrow: 1,\n maxWidth: '100%'\n };\n return;\n }\n\n if (size === 'auto') {\n styles[key] = {\n flexBasis: 'auto',\n flexGrow: 0,\n maxWidth: 'none'\n };\n return;\n } // Keep 7 significant numbers.\n\n\n var width = \"\".concat(Math.round(size / 12 * 10e7) / 10e5, \"%\"); // Close to the bootstrap implementation:\n // https://github.com/twbs/bootstrap/blob/8fccaa2439e97ec72a4b7dc42ccc1f649790adb0/scss/mixins/_grid.scss#L41\n\n styles[key] = {\n flexBasis: width,\n flexGrow: 0,\n maxWidth: width\n };\n }); // No need for a media query for the first size.\n\n if (breakpoint === 'xs') {\n _extends(globalStyles, styles);\n } else {\n globalStyles[theme.breakpoints.up(breakpoint)] = styles;\n }\n}\n\nfunction getOffset(val) {\n var div = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n var parse = parseFloat(val);\n return \"\".concat(parse / div).concat(String(val).replace(String(parse), '') || 'px');\n}\n\nfunction generateGutter(theme, breakpoint) {\n var styles = {};\n SPACINGS.forEach(function (spacing) {\n var themeSpacing = theme.spacing(spacing);\n\n if (themeSpacing === 0) {\n return;\n }\n\n styles[\"spacing-\".concat(breakpoint, \"-\").concat(spacing)] = {\n margin: \"-\".concat(getOffset(themeSpacing, 2)),\n width: \"calc(100% + \".concat(getOffset(themeSpacing), \")\"),\n '& > $item': {\n padding: getOffset(themeSpacing, 2)\n }\n };\n });\n return styles;\n} // Default CSS values\n// flex: '0 1 auto',\n// flexDirection: 'row',\n// alignItems: 'flex-start',\n// flexWrap: 'nowrap',\n// justifyContent: 'flex-start',\n\n\nexport var styles = function styles(theme) {\n return _extends({\n /* Styles applied to the root element */\n root: {},\n\n /* Styles applied to the root element if `container={true}`. */\n container: {\n boxSizing: 'border-box',\n display: 'flex',\n flexWrap: 'wrap',\n width: '100%'\n },\n\n /* Styles applied to the root element if `item={true}`. */\n item: {\n boxSizing: 'border-box',\n margin: '0' // For instance, it's useful when used with a `figure` element.\n\n },\n\n /* Styles applied to the root element if `zeroMinWidth={true}`. */\n zeroMinWidth: {\n minWidth: 0\n },\n\n /* Styles applied to the root element if `direction=\"column\"`. */\n 'direction-xs-column': {\n flexDirection: 'column'\n },\n\n /* Styles applied to the root element if `direction=\"column-reverse\"`. */\n 'direction-xs-column-reverse': {\n flexDirection: 'column-reverse'\n },\n\n /* Styles applied to the root element if `direction=\"rwo-reverse\"`. */\n 'direction-xs-row-reverse': {\n flexDirection: 'row-reverse'\n },\n\n /* Styles applied to the root element if `wrap=\"nowrap\"`. */\n 'wrap-xs-nowrap': {\n flexWrap: 'nowrap'\n },\n\n /* Styles applied to the root element if `wrap=\"reverse\"`. */\n 'wrap-xs-wrap-reverse': {\n flexWrap: 'wrap-reverse'\n },\n\n /* Styles applied to the root element if `alignItems=\"center\"`. */\n 'align-items-xs-center': {\n alignItems: 'center'\n },\n\n /* Styles applied to the root element if `alignItems=\"flex-start\"`. */\n 'align-items-xs-flex-start': {\n alignItems: 'flex-start'\n },\n\n /* Styles applied to the root element if `alignItems=\"flex-end\"`. */\n 'align-items-xs-flex-end': {\n alignItems: 'flex-end'\n },\n\n /* Styles applied to the root element if `alignItems=\"baseline\"`. */\n 'align-items-xs-baseline': {\n alignItems: 'baseline'\n },\n\n /* Styles applied to the root element if `alignContent=\"center\"`. */\n 'align-content-xs-center': {\n alignContent: 'center'\n },\n\n /* Styles applied to the root element if `alignContent=\"flex-start\"`. */\n 'align-content-xs-flex-start': {\n alignContent: 'flex-start'\n },\n\n /* Styles applied to the root element if `alignContent=\"flex-end\"`. */\n 'align-content-xs-flex-end': {\n alignContent: 'flex-end'\n },\n\n /* Styles applied to the root element if `alignContent=\"space-between\"`. */\n 'align-content-xs-space-between': {\n alignContent: 'space-between'\n },\n\n /* Styles applied to the root element if `alignContent=\"space-around\"`. */\n 'align-content-xs-space-around': {\n alignContent: 'space-around'\n },\n\n /* Styles applied to the root element if `justify=\"center\"`. */\n 'justify-xs-center': {\n justifyContent: 'center'\n },\n\n /* Styles applied to the root element if `justify=\"flex-end\"`. */\n 'justify-xs-flex-end': {\n justifyContent: 'flex-end'\n },\n\n /* Styles applied to the root element if `justify=\"space-between\"`. */\n 'justify-xs-space-between': {\n justifyContent: 'space-between'\n },\n\n /* Styles applied to the root element if `justify=\"space-around\"`. */\n 'justify-xs-space-around': {\n justifyContent: 'space-around'\n },\n\n /* Styles applied to the root element if `justify=\"space-evenly\"`. */\n 'justify-xs-space-evenly': {\n justifyContent: 'space-evenly'\n }\n }, generateGutter(theme, 'xs'), {}, theme.breakpoints.keys.reduce(function (accumulator, key) {\n // Use side effect over immutability for better performance.\n generateGrid(accumulator, theme, key);\n return accumulator;\n }, {}));\n};\nvar Grid = React.forwardRef(function Grid(props, ref) {\n var _props$alignContent = props.alignContent,\n alignContent = _props$alignContent === void 0 ? 'stretch' : _props$alignContent,\n _props$alignItems = props.alignItems,\n alignItems = _props$alignItems === void 0 ? 'stretch' : _props$alignItems,\n classes = props.classes,\n classNameProp = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$container = props.container,\n container = _props$container === void 0 ? false : _props$container,\n _props$direction = props.direction,\n direction = _props$direction === void 0 ? 'row' : _props$direction,\n _props$item = props.item,\n item = _props$item === void 0 ? false : _props$item,\n _props$justify = props.justify,\n justify = _props$justify === void 0 ? 'flex-start' : _props$justify,\n _props$lg = props.lg,\n lg = _props$lg === void 0 ? false : _props$lg,\n _props$md = props.md,\n md = _props$md === void 0 ? false : _props$md,\n _props$sm = props.sm,\n sm = _props$sm === void 0 ? false : _props$sm,\n _props$spacing = props.spacing,\n spacing = _props$spacing === void 0 ? 0 : _props$spacing,\n _props$wrap = props.wrap,\n wrap = _props$wrap === void 0 ? 'wrap' : _props$wrap,\n _props$xl = props.xl,\n xl = _props$xl === void 0 ? false : _props$xl,\n _props$xs = props.xs,\n xs = _props$xs === void 0 ? false : _props$xs,\n _props$zeroMinWidth = props.zeroMinWidth,\n zeroMinWidth = _props$zeroMinWidth === void 0 ? false : _props$zeroMinWidth,\n other = _objectWithoutProperties(props, [\"alignContent\", \"alignItems\", \"classes\", \"className\", \"component\", \"container\", \"direction\", \"item\", \"justify\", \"lg\", \"md\", \"sm\", \"spacing\", \"wrap\", \"xl\", \"xs\", \"zeroMinWidth\"]);\n\n var className = clsx(classes.root, classNameProp, container && [classes.container, spacing !== 0 && classes[\"spacing-xs-\".concat(String(spacing))]], item && classes.item, zeroMinWidth && classes.zeroMinWidth, direction !== 'row' && classes[\"direction-xs-\".concat(String(direction))], wrap !== 'wrap' && classes[\"wrap-xs-\".concat(String(wrap))], alignItems !== 'stretch' && classes[\"align-items-xs-\".concat(String(alignItems))], alignContent !== 'stretch' && classes[\"align-content-xs-\".concat(String(alignContent))], justify !== 'flex-start' && classes[\"justify-xs-\".concat(String(justify))], xs !== false && classes[\"grid-xs-\".concat(String(xs))], sm !== false && classes[\"grid-sm-\".concat(String(sm))], md !== false && classes[\"grid-md-\".concat(String(md))], lg !== false && classes[\"grid-lg-\".concat(String(lg))], xl !== false && classes[\"grid-xl-\".concat(String(xl))]);\n return React.createElement(Component, _extends({\n className: className,\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Grid.propTypes = {\n /**\n * Defines the `align-content` style property.\n * It's applied for all screen sizes.\n */\n alignContent: PropTypes.oneOf(['stretch', 'center', 'flex-start', 'flex-end', 'space-between', 'space-around']),\n\n /**\n * Defines the `align-items` style property.\n * It's applied for all screen sizes.\n */\n alignItems: PropTypes.oneOf(['flex-start', 'center', 'flex-end', 'stretch', 'baseline']),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the component will have the flex *container* behavior.\n * You should be wrapping *items* with a *container*.\n */\n container: PropTypes.bool,\n\n /**\n * Defines the `flex-direction` style property.\n * It is applied for all screen sizes.\n */\n direction: PropTypes.oneOf(['row', 'row-reverse', 'column', 'column-reverse']),\n\n /**\n * If `true`, the component will have the flex *item* behavior.\n * You should be wrapping *items* with a *container*.\n */\n item: PropTypes.bool,\n\n /**\n * Defines the `justify-content` style property.\n * It is applied for all screen sizes.\n */\n justify: PropTypes.oneOf(['flex-start', 'center', 'flex-end', 'space-between', 'space-around', 'space-evenly']),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `lg` breakpoint and wider screens if not overridden.\n */\n lg: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `md` breakpoint and wider screens if not overridden.\n */\n md: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `sm` breakpoint and wider screens if not overridden.\n */\n sm: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the space between the type `item` component.\n * It can only be used on a type `container` component.\n */\n spacing: PropTypes.oneOf(SPACINGS),\n\n /**\n * Defines the `flex-wrap` style property.\n * It's applied for all screen sizes.\n */\n wrap: PropTypes.oneOf(['nowrap', 'wrap', 'wrap-reverse']),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for the `xl` breakpoint and wider screens.\n */\n xl: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * Defines the number of grids the component is going to use.\n * It's applied for all the screen sizes with the lowest priority.\n */\n xs: PropTypes.oneOf([false, 'auto', true, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),\n\n /**\n * If `true`, it sets `min-width: 0` on the item.\n * Refer to the limitations section of the documentation to better understand the use case.\n */\n zeroMinWidth: PropTypes.bool\n} : void 0;\nvar StyledGrid = withStyles(styles, {\n name: 'MuiGrid'\n})(Grid);\n\nif (process.env.NODE_ENV !== 'production') {\n var requireProp = requirePropFactory('Grid');\n StyledGrid.propTypes = _extends({}, StyledGrid.propTypes, {\n alignContent: requireProp('container'),\n alignItems: requireProp('container'),\n direction: requireProp('container'),\n justify: requireProp('container'),\n lg: requireProp('item'),\n md: requireProp('item'),\n sm: requireProp('item'),\n spacing: requireProp('container'),\n wrap: requireProp('container'),\n xs: requireProp('item'),\n zeroMinWidth: requireProp('item')\n });\n}\n\nexport default StyledGrid;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport InputBase from '../InputBase';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var light = theme.palette.type === 'light';\n var bottomLineColor = light ? 'rgba(0, 0, 0, 0.42)' : 'rgba(255, 255, 255, 0.7)';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'relative'\n },\n\n /* Styles applied to the root element if the component is a descendant of `FormControl`. */\n formControl: {\n 'label + &': {\n marginTop: 16\n }\n },\n\n /* Styles applied to the root element if the component is focused. */\n focused: {},\n\n /* Styles applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if color secondary. */\n colorSecondary: {\n '&$underline:after': {\n borderBottomColor: theme.palette.secondary.main\n }\n },\n\n /* Styles applied to the root element if `disableUnderline={false}`. */\n underline: {\n '&:after': {\n borderBottom: \"2px solid \".concat(theme.palette.primary.main),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\"',\n position: 'absolute',\n right: 0,\n transform: 'scaleX(0)',\n transition: theme.transitions.create('transform', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&$focused:after': {\n transform: 'scaleX(1)'\n },\n '&$error:after': {\n borderBottomColor: theme.palette.error.main,\n transform: 'scaleX(1)' // error is always underlined in red\n\n },\n '&:before': {\n borderBottom: \"1px solid \".concat(bottomLineColor),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\\\\00a0\"',\n position: 'absolute',\n right: 0,\n transition: theme.transitions.create('border-bottom-color', {\n duration: theme.transitions.duration.shorter\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&:hover:not($disabled):before': {\n borderBottom: \"2px solid \".concat(theme.palette.text.primary),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n borderBottom: \"1px solid \".concat(bottomLineColor)\n }\n },\n '&$disabled:before': {\n borderBottomStyle: 'dotted'\n }\n },\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {},\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {},\n\n /* Styles applied to the `input` element. */\n input: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {},\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {},\n\n /* Styles applied to the `input` element if `type=\"search\"`. */\n inputTypeSearch: {}\n };\n};\nvar Input = React.forwardRef(function Input(props, ref) {\n var disableUnderline = props.disableUnderline,\n classes = props.classes,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n other = _objectWithoutProperties(props, [\"disableUnderline\", \"classes\", \"fullWidth\", \"inputComponent\", \"multiline\", \"type\"]);\n\n return React.createElement(InputBase, _extends({\n classes: _extends({}, classes, {\n root: clsx(classes.root, !disableUnderline && classes.underline),\n underline: null\n }),\n fullWidth: fullWidth,\n inputComponent: inputComponent,\n multiline: multiline,\n ref: ref,\n type: type\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Input.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the input will not have an underline.\n */\n disableUnderline: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the native input.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nInput.muiName = 'Input';\nexport default withStyles(styles, {\n name: 'MuiInput'\n})(Input);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport InputBase from '../InputBase';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var light = theme.palette.type === 'light';\n var bottomLineColor = light ? 'rgba(0, 0, 0, 0.42)' : 'rgba(255, 255, 255, 0.7)';\n var backgroundColor = light ? 'rgba(0, 0, 0, 0.09)' : 'rgba(255, 255, 255, 0.09)';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'relative',\n backgroundColor: backgroundColor,\n borderTopLeftRadius: theme.shape.borderRadius,\n borderTopRightRadius: theme.shape.borderRadius,\n transition: theme.transitions.create('background-color', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n }),\n '&:hover': {\n backgroundColor: light ? 'rgba(0, 0, 0, 0.13)' : 'rgba(255, 255, 255, 0.13)',\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: backgroundColor\n }\n },\n '&$focused': {\n backgroundColor: light ? 'rgba(0, 0, 0, 0.09)' : 'rgba(255, 255, 255, 0.09)'\n },\n '&$disabled': {\n backgroundColor: light ? 'rgba(0, 0, 0, 0.12)' : 'rgba(255, 255, 255, 0.12)'\n }\n },\n\n /* Styles applied to the root element if color secondary. */\n colorSecondary: {\n '&$underline:after': {\n borderBottomColor: theme.palette.secondary.main\n }\n },\n\n /* Styles applied to the root element if `disableUnderline={false}`. */\n underline: {\n '&:after': {\n borderBottom: \"2px solid \".concat(theme.palette.primary.main),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\"',\n position: 'absolute',\n right: 0,\n transform: 'scaleX(0)',\n transition: theme.transitions.create('transform', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&$focused:after': {\n transform: 'scaleX(1)'\n },\n '&$error:after': {\n borderBottomColor: theme.palette.error.main,\n transform: 'scaleX(1)' // error is always underlined in red\n\n },\n '&:before': {\n borderBottom: \"1px solid \".concat(bottomLineColor),\n left: 0,\n bottom: 0,\n // Doing the other way around crash on IE 11 \"''\" https://github.com/cssinjs/jss/issues/242\n content: '\"\\\\00a0\"',\n position: 'absolute',\n right: 0,\n transition: theme.transitions.create('border-bottom-color', {\n duration: theme.transitions.duration.shorter\n }),\n pointerEvents: 'none' // Transparent to the hover style.\n\n },\n '&:hover:before': {\n borderBottom: \"1px solid \".concat(theme.palette.text.primary)\n },\n '&$disabled:before': {\n borderBottomStyle: 'dotted'\n }\n },\n\n /* Pseudo-class applied to the root element if the component is focused. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `startAdornment` is provided. */\n adornedStart: {\n paddingLeft: 12\n },\n\n /* Styles applied to the root element if `endAdornment` is provided. */\n adornedEnd: {\n paddingRight: 12\n },\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {\n padding: '27px 12px 10px',\n '&$marginDense': {\n paddingTop: 23,\n paddingBottom: 6\n }\n },\n\n /* Styles applied to the `input` element. */\n input: {\n padding: '27px 12px 10px',\n '&:-webkit-autofill': {\n WebkitBoxShadow: theme.palette.type === 'dark' ? '0 0 0 100px #266798 inset' : null,\n WebkitTextFillColor: theme.palette.type === 'dark' ? '#fff' : null,\n borderTopLeftRadius: 'inherit',\n borderTopRightRadius: 'inherit'\n }\n },\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {\n paddingTop: 23,\n paddingBottom: 6\n },\n\n /* Styles applied to the `input` if in `<FormControl hiddenLabel />`. */\n inputHiddenLabel: {\n paddingTop: 18,\n paddingBottom: 19,\n '&$inputMarginDense': {\n paddingTop: 10,\n paddingBottom: 11\n }\n },\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {\n padding: 0\n },\n\n /* Styles applied to the `input` element if `startAdornment` is provided. */\n inputAdornedStart: {\n paddingLeft: 0\n },\n\n /* Styles applied to the `input` element if `endAdornment` is provided. */\n inputAdornedEnd: {\n paddingRight: 0\n }\n };\n};\nvar FilledInput = React.forwardRef(function FilledInput(props, ref) {\n var disableUnderline = props.disableUnderline,\n classes = props.classes,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n other = _objectWithoutProperties(props, [\"disableUnderline\", \"classes\", \"fullWidth\", \"inputComponent\", \"multiline\", \"type\"]);\n\n return React.createElement(InputBase, _extends({\n classes: _extends({}, classes, {\n root: clsx(classes.root, !disableUnderline && classes.underline),\n underline: null\n }),\n fullWidth: fullWidth,\n inputComponent: inputComponent,\n multiline: multiline,\n ref: ref,\n type: type\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? FilledInput.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the input will not have an underline.\n */\n disableUnderline: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the native input.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nFilledInput.muiName = 'Input';\nexport default withStyles(styles, {\n name: 'MuiFilledInput'\n})(FilledInput);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport { fade } from '../styles/colorManipulator';\nimport ButtonBase from '../ButtonBase';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({}, theme.typography.button, {\n boxSizing: 'border-box',\n minWidth: 64,\n padding: '6px 16px',\n borderRadius: theme.shape.borderRadius,\n color: theme.palette.text.primary,\n transition: theme.transitions.create(['background-color', 'box-shadow', 'border'], {\n duration: theme.transitions.duration.short\n }),\n '&:hover': {\n textDecoration: 'none',\n backgroundColor: fade(theme.palette.text.primary, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n },\n '&$disabled': {\n backgroundColor: 'transparent'\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n }),\n\n /* Styles applied to the span element that wraps the children. */\n label: {\n width: '100%',\n // Ensure the correct width for iOS Safari\n display: 'inherit',\n alignItems: 'inherit',\n justifyContent: 'inherit'\n },\n\n /* Styles applied to the root element if `variant=\"text\"`. */\n text: {\n padding: '6px 8px'\n },\n\n /* Styles applied to the root element if `variant=\"text\"` and `color=\"primary\"`. */\n textPrimary: {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"text\"` and `color=\"secondary\"`. */\n textSecondary: {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"`. */\n outlined: {\n padding: '5px 15px',\n border: \"1px solid \".concat(theme.palette.type === 'light' ? 'rgba(0, 0, 0, 0.23)' : 'rgba(255, 255, 255, 0.23)'),\n '&$disabled': {\n border: \"1px solid \".concat(theme.palette.action.disabled)\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"` and `color=\"primary\"`. */\n outlinedPrimary: {\n color: theme.palette.primary.main,\n border: \"1px solid \".concat(fade(theme.palette.primary.main, 0.5)),\n '&:hover': {\n border: \"1px solid \".concat(theme.palette.primary.main),\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"` and `color=\"secondary\"`. */\n outlinedSecondary: {\n color: theme.palette.secondary.main,\n border: \"1px solid \".concat(fade(theme.palette.secondary.main, 0.5)),\n '&:hover': {\n border: \"1px solid \".concat(theme.palette.secondary.main),\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n },\n '&$disabled': {\n border: \"1px solid \".concat(theme.palette.action.disabled)\n }\n },\n\n /* Styles applied to the root element if `variant=\"contained\"`. */\n contained: {\n color: theme.palette.getContrastText(theme.palette.grey[300]),\n backgroundColor: theme.palette.grey[300],\n boxShadow: theme.shadows[2],\n '&:hover': {\n backgroundColor: theme.palette.grey.A100,\n boxShadow: theme.shadows[4],\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n boxShadow: theme.shadows[2],\n backgroundColor: theme.palette.grey[300]\n },\n '&$disabled': {\n backgroundColor: theme.palette.action.disabledBackground\n }\n },\n '&$focusVisible': {\n boxShadow: theme.shadows[6]\n },\n '&:active': {\n boxShadow: theme.shadows[8]\n },\n '&$disabled': {\n color: theme.palette.action.disabled,\n boxShadow: theme.shadows[0],\n backgroundColor: theme.palette.action.disabledBackground\n }\n },\n\n /* Styles applied to the root element if `variant=\"contained\"` and `color=\"primary\"`. */\n containedPrimary: {\n color: theme.palette.primary.contrastText,\n backgroundColor: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: theme.palette.primary.dark,\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: theme.palette.primary.main\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"contained\"` and `color=\"secondary\"`. */\n containedSecondary: {\n color: theme.palette.secondary.contrastText,\n backgroundColor: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: theme.palette.secondary.dark,\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: theme.palette.secondary.main\n }\n }\n },\n\n /* Styles applied to the root element if `disableElevation={true}`. */\n disableElevation: {\n boxShadow: 'none',\n '&:hover': {\n boxShadow: 'none'\n },\n '&$focusVisible': {\n boxShadow: 'none'\n },\n '&:active': {\n boxShadow: 'none'\n },\n '&$disabled': {\n boxShadow: 'none'\n }\n },\n\n /* Pseudo-class applied to the ButtonBase root element if the button is keyboard focused. */\n focusVisible: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `color=\"inherit\"`. */\n colorInherit: {\n color: 'inherit',\n borderColor: 'currentColor'\n },\n\n /* Styles applied to the root element if `size=\"small\"` and `variant=\"text\"`. */\n textSizeSmall: {\n padding: '4px 5px',\n fontSize: theme.typography.pxToRem(13)\n },\n\n /* Styles applied to the root element if `size=\"large\"` and `variant=\"text\"`. */\n textSizeLarge: {\n padding: '8px 11px',\n fontSize: theme.typography.pxToRem(15)\n },\n\n /* Styles applied to the root element if `size=\"small\"` and `variant=\"outlined\"`. */\n outlinedSizeSmall: {\n padding: '3px 9px',\n fontSize: theme.typography.pxToRem(13)\n },\n\n /* Styles applied to the root element if `size=\"large\"` and `variant=\"outlined\"`. */\n outlinedSizeLarge: {\n padding: '7px 21px',\n fontSize: theme.typography.pxToRem(15)\n },\n\n /* Styles applied to the root element if `size=\"small\"` and `variant=\"contained\"`. */\n containedSizeSmall: {\n padding: '4px 10px',\n fontSize: theme.typography.pxToRem(13)\n },\n\n /* Styles applied to the root element if `size=\"large\"` and `variant=\"contained\"`. */\n containedSizeLarge: {\n padding: '8px 22px',\n fontSize: theme.typography.pxToRem(15)\n },\n\n /* Styles applied to the root element if `size=\"small\"`. */\n sizeSmall: {},\n\n /* Styles applied to the root element if `size=\"large\"`. */\n sizeLarge: {},\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {\n width: '100%'\n },\n\n /* Styles applied to the startIcon element if supplied. */\n startIcon: {\n display: 'inherit',\n marginRight: 8,\n marginLeft: -4,\n '&$iconSizeSmall': {\n marginLeft: -2\n }\n },\n\n /* Styles applied to the endIcon element if supplied. */\n endIcon: {\n display: 'inherit',\n marginRight: -4,\n marginLeft: 8,\n '&$iconSizeSmall': {\n marginRight: -2\n }\n },\n\n /* Styles applied to the icon element if supplied and `size=\"small\"`. */\n iconSizeSmall: {\n '& > *:first-child': {\n fontSize: 18\n }\n },\n\n /* Styles applied to the icon element if supplied and `size=\"medium\"`. */\n iconSizeMedium: {\n '& > *:first-child': {\n fontSize: 20\n }\n },\n\n /* Styles applied to the icon element if supplied and `size=\"large\"`. */\n iconSizeLarge: {\n '& > *:first-child': {\n fontSize: 22\n }\n }\n };\n};\nvar Button = React.forwardRef(function Button(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'default' : _props$color,\n _props$component = props.component,\n component = _props$component === void 0 ? 'button' : _props$component,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableElevati = props.disableElevation,\n disableElevation = _props$disableElevati === void 0 ? false : _props$disableElevati,\n _props$disableFocusRi = props.disableFocusRipple,\n disableFocusRipple = _props$disableFocusRi === void 0 ? false : _props$disableFocusRi,\n endIconProp = props.endIcon,\n focusVisibleClassName = props.focusVisibleClassName,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n startIconProp = props.startIcon,\n _props$type = props.type,\n type = _props$type === void 0 ? 'button' : _props$type,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'text' : _props$variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"disabled\", \"disableElevation\", \"disableFocusRipple\", \"endIcon\", \"focusVisibleClassName\", \"fullWidth\", \"size\", \"startIcon\", \"type\", \"variant\"]);\n\n var startIcon = startIconProp && React.createElement(\"span\", {\n className: clsx(classes.startIcon, classes[\"iconSize\".concat(capitalize(size))])\n }, startIconProp);\n var endIcon = endIconProp && React.createElement(\"span\", {\n className: clsx(classes.endIcon, classes[\"iconSize\".concat(capitalize(size))])\n }, endIconProp);\n return React.createElement(ButtonBase, _extends({\n className: clsx(classes.root, classes[variant], className, color === 'inherit' ? classes.colorInherit : color !== 'default' && classes[\"\".concat(variant).concat(capitalize(color))], size !== 'medium' && [classes[\"\".concat(variant, \"Size\").concat(capitalize(size))], classes[\"size\".concat(capitalize(size))]], disableElevation && classes.disableElevation, disabled && classes.disabled, fullWidth && classes.fullWidth),\n component: component,\n disabled: disabled,\n focusRipple: !disableFocusRipple,\n focusVisibleClassName: clsx(classes.focusVisible, focusVisibleClassName),\n ref: ref,\n type: type\n }, other), React.createElement(\"span\", {\n className: classes.label\n }, startIcon, children, endIcon));\n});\nprocess.env.NODE_ENV !== \"production\" ? Button.propTypes = {\n /**\n * The content of the button.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['default', 'inherit', 'primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the button will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, no elevation is used.\n */\n disableElevation: PropTypes.bool,\n\n /**\n * If `true`, the keyboard focus ripple will be disabled.\n * `disableRipple` must also be true.\n */\n disableFocusRipple: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n *\n * âš ï¸ Without a ripple there is no styling for :focus-visible by default. Be sure\n * to highlight the element by applying separate styles with the `focusVisibleClassName`.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * Element placed after the children.\n */\n endIcon: PropTypes.node,\n\n /**\n * @ignore\n */\n focusVisibleClassName: PropTypes.string,\n\n /**\n * If `true`, the button will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The URL to link to when the button is clicked.\n * If defined, an `a` element will be used as the root node.\n */\n href: PropTypes.string,\n\n /**\n * The size of the button.\n * `small` is equivalent to the dense button styling.\n */\n size: PropTypes.oneOf(['small', 'medium', 'large']),\n\n /**\n * Element placed before the children.\n */\n startIcon: PropTypes.node,\n\n /**\n * @ignore\n */\n type: PropTypes.string,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['text', 'outlined', 'contained'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiButton'\n})(Button);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nimport ThemeContext from '../useTheme/ThemeContext';\nimport useTheme from '../useTheme';\nimport nested from './nested'; // To support composition of theme.\n\nfunction mergeOuterLocalTheme(outerTheme, localTheme) {\n if (typeof localTheme === 'function') {\n var mergedTheme = localTheme(outerTheme);\n\n if (process.env.NODE_ENV !== 'production') {\n if (!mergedTheme) {\n console.error(['Material-UI: you should return an object from your theme function, i.e.', '<ThemeProvider theme={() => ({})} />'].join('\\n'));\n }\n }\n\n return mergedTheme;\n }\n\n return _extends({}, outerTheme, {}, localTheme);\n}\n/**\n * This component takes a `theme` prop.\n * It makes the `theme` available down the React tree thanks to React context.\n * This component should preferably be used at **the root of your component tree**.\n */\n\n\nfunction ThemeProvider(props) {\n var children = props.children,\n localTheme = props.theme;\n var outerTheme = useTheme();\n\n if (process.env.NODE_ENV !== 'production') {\n if (outerTheme === null && typeof localTheme === 'function') {\n console.error(['Material-UI: you are providing a theme function prop to the ThemeProvider component:', '<ThemeProvider theme={outerTheme => outerTheme} />', '', 'However, no outer theme is present.', 'Make sure a theme is already injected higher in the React tree ' + 'or provide a theme object.'].join('\\n'));\n }\n }\n\n var theme = React.useMemo(function () {\n var output = outerTheme === null ? localTheme : mergeOuterLocalTheme(outerTheme, localTheme);\n\n if (output != null) {\n output[nested] = outerTheme !== null;\n }\n\n return output;\n }, [localTheme, outerTheme]);\n return React.createElement(ThemeContext.Provider, {\n value: theme\n }, children);\n}\n\nprocess.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = {\n /**\n * Your component tree.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * A theme object. You can provide a function to extend the outer theme.\n */\n theme: PropTypes.oneOfType([PropTypes.object, PropTypes.func]).isRequired\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n process.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = exactProp(ThemeProvider.propTypes) : void 0;\n}\n\nexport default ThemeProvider;","function ownerDocument(node) {\n return node && node.ownerDocument || document;\n}\n\nexport default ownerDocument;","import ownerDocument from './ownerDocument';\n\nfunction ownerWindow(node) {\n var doc = ownerDocument(node);\n return doc.defaultView || window;\n}\n\nexport default ownerWindow;","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@material-ui/utils';\nimport setRef from '../utils/setRef';\nimport useForkRef from '../utils/useForkRef';\n\nfunction getContainer(container) {\n container = typeof container === 'function' ? container() : container; // #StrictMode ready\n\n return ReactDOM.findDOMNode(container);\n}\n\nvar useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\n/**\n * Portals provide a first-class way to render children into a DOM node\n * that exists outside the DOM hierarchy of the parent component.\n */\n\nvar Portal = React.forwardRef(function Portal(props, ref) {\n var children = props.children,\n container = props.container,\n _props$disablePortal = props.disablePortal,\n disablePortal = _props$disablePortal === void 0 ? false : _props$disablePortal,\n onRendered = props.onRendered;\n\n var _React$useState = React.useState(null),\n mountNode = _React$useState[0],\n setMountNode = _React$useState[1];\n\n var handleRef = useForkRef(React.isValidElement(children) ? children.ref : null, ref);\n useEnhancedEffect(function () {\n if (!disablePortal) {\n setMountNode(getContainer(container) || document.body);\n }\n }, [container, disablePortal]);\n useEnhancedEffect(function () {\n if (mountNode && !disablePortal) {\n setRef(ref, mountNode);\n return function () {\n setRef(ref, null);\n };\n }\n\n return undefined;\n }, [ref, mountNode, disablePortal]);\n useEnhancedEffect(function () {\n if (onRendered && (mountNode || disablePortal)) {\n onRendered();\n }\n }, [onRendered, mountNode, disablePortal]);\n\n if (disablePortal) {\n if (React.isValidElement(children)) {\n return React.cloneElement(children, {\n ref: handleRef\n });\n }\n\n return children;\n }\n\n return mountNode ? ReactDOM.createPortal(children, mountNode) : mountNode;\n});\nprocess.env.NODE_ENV !== \"production\" ? Portal.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The children to render into the `container`.\n */\n children: PropTypes.node,\n\n /**\n * A node, component instance, or function that returns either.\n * The `container` will have the portal children appended to it.\n * By default, it uses the body of the top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes.oneOfType([PropTypes.func, PropTypes.instanceOf(React.Component), PropTypes.instanceOf(typeof Element === 'undefined' ? Object : Element)]),\n\n /**\n * Disable the portal behavior.\n * The children stay within it's parent DOM hierarchy.\n */\n disablePortal: PropTypes.bool,\n\n /**\n * Callback fired once the children has been mounted into the `container`.\n *\n * This prop will be deprecated and removed in v5, the ref can be used instead.\n */\n onRendered: PropTypes.func\n} : void 0;\n\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n Portal['propTypes' + ''] = exactProp(Portal.propTypes);\n}\n\nexport default Portal;","// A change of the browser zoom change the scrollbar size.\n// Credit https://github.com/twbs/bootstrap/blob/3ffe3a5d82f6f561b82ff78d82b32a7d14aed558/js/src/modal.js#L512-L519\nfunction getScrollbarSize() {\n var scrollDiv = document.createElement('div');\n scrollDiv.style.width = '99px';\n scrollDiv.style.height = '99px';\n scrollDiv.style.position = 'absolute';\n scrollDiv.style.top = '-9999px';\n scrollDiv.style.overflow = 'scroll';\n document.body.appendChild(scrollDiv);\n var scrollbarSize = scrollDiv.offsetWidth - scrollDiv.clientWidth;\n document.body.removeChild(scrollDiv);\n return scrollbarSize;\n}\n\nexport default getScrollbarSize;","import _classCallCheck from \"@babel/runtime/helpers/esm/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/esm/createClass\";\nimport _toConsumableArray from \"@babel/runtime/helpers/esm/toConsumableArray\";\nimport getScrollbarSize from '../utils/getScrollbarSize';\nimport ownerDocument from '../utils/ownerDocument';\nimport ownerWindow from '../utils/ownerWindow'; // Is a vertical scrollbar displayed?\n\nfunction isOverflowing(container) {\n var doc = ownerDocument(container);\n\n if (doc.body === container) {\n return ownerWindow(doc).innerWidth > doc.documentElement.clientWidth;\n }\n\n return container.scrollHeight > container.clientHeight;\n}\n\nexport function ariaHidden(node, show) {\n if (show) {\n node.setAttribute('aria-hidden', 'true');\n } else {\n node.removeAttribute('aria-hidden');\n }\n}\n\nfunction getPaddingRight(node) {\n return parseInt(window.getComputedStyle(node)['padding-right'], 10) || 0;\n}\n\nfunction ariaHiddenSiblings(container, mountNode, currentNode) {\n var nodesToExclude = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];\n var show = arguments.length > 4 ? arguments[4] : undefined;\n var blacklist = [mountNode, currentNode].concat(_toConsumableArray(nodesToExclude));\n var blacklistTagNames = ['TEMPLATE', 'SCRIPT', 'STYLE'];\n [].forEach.call(container.children, function (node) {\n if (node.nodeType === 1 && blacklist.indexOf(node) === -1 && blacklistTagNames.indexOf(node.tagName) === -1) {\n ariaHidden(node, show);\n }\n });\n}\n\nfunction findIndexOf(containerInfo, callback) {\n var idx = -1;\n containerInfo.some(function (item, index) {\n if (callback(item)) {\n idx = index;\n return true;\n }\n\n return false;\n });\n return idx;\n}\n\nfunction handleContainer(containerInfo, props) {\n var restoreStyle = [];\n var restorePaddings = [];\n var container = containerInfo.container;\n var fixedNodes;\n\n if (!props.disableScrollLock) {\n if (isOverflowing(container)) {\n // Compute the size before applying overflow hidden to avoid any scroll jumps.\n var scrollbarSize = getScrollbarSize();\n restoreStyle.push({\n value: container.style.paddingRight,\n key: 'padding-right',\n el: container\n }); // Use computed style, here to get the real padding to add our scrollbar width.\n\n container.style['padding-right'] = \"\".concat(getPaddingRight(container) + scrollbarSize, \"px\"); // .mui-fixed is a global helper.\n\n fixedNodes = ownerDocument(container).querySelectorAll('.mui-fixed');\n [].forEach.call(fixedNodes, function (node) {\n restorePaddings.push(node.style.paddingRight);\n node.style.paddingRight = \"\".concat(getPaddingRight(node) + scrollbarSize, \"px\");\n });\n } // Improve Gatsby support\n // https://css-tricks.com/snippets/css/force-vertical-scrollbar/\n\n\n var parent = container.parentElement;\n var scrollContainer = parent.nodeName === 'HTML' && window.getComputedStyle(parent)['overflow-y'] === 'scroll' ? parent : container; // Block the scroll even if no scrollbar is visible to account for mobile keyboard\n // screensize shrink.\n\n restoreStyle.push({\n value: scrollContainer.style.overflow,\n key: 'overflow',\n el: scrollContainer\n });\n scrollContainer.style.overflow = 'hidden';\n }\n\n var restore = function restore() {\n if (fixedNodes) {\n [].forEach.call(fixedNodes, function (node, i) {\n if (restorePaddings[i]) {\n node.style.paddingRight = restorePaddings[i];\n } else {\n node.style.removeProperty('padding-right');\n }\n });\n }\n\n restoreStyle.forEach(function (_ref) {\n var value = _ref.value,\n el = _ref.el,\n key = _ref.key;\n\n if (value) {\n el.style.setProperty(key, value);\n } else {\n el.style.removeProperty(key);\n }\n });\n };\n\n return restore;\n}\n\nfunction getHiddenSiblings(container) {\n var hiddenSiblings = [];\n [].forEach.call(container.children, function (node) {\n if (node.getAttribute && node.getAttribute('aria-hidden') === 'true') {\n hiddenSiblings.push(node);\n }\n });\n return hiddenSiblings;\n}\n/**\n * @ignore - do not document.\n *\n * Proper state management for containers and the modals in those containers.\n * Simplified, but inspired by react-overlay's ModalManager class.\n * Used by the Modal to ensure proper styling of containers.\n */\n\n\nvar ModalManager =\n/*#__PURE__*/\nfunction () {\n function ModalManager() {\n _classCallCheck(this, ModalManager);\n\n // this.modals[modalIndex] = modal\n this.modals = []; // this.containers[containerIndex] = {\n // modals: [],\n // container,\n // restore: null,\n // }\n\n this.containers = [];\n }\n\n _createClass(ModalManager, [{\n key: \"add\",\n value: function add(modal, container) {\n var modalIndex = this.modals.indexOf(modal);\n\n if (modalIndex !== -1) {\n return modalIndex;\n }\n\n modalIndex = this.modals.length;\n this.modals.push(modal); // If the modal we are adding is already in the DOM.\n\n if (modal.modalRef) {\n ariaHidden(modal.modalRef, false);\n }\n\n var hiddenSiblingNodes = getHiddenSiblings(container);\n ariaHiddenSiblings(container, modal.mountNode, modal.modalRef, hiddenSiblingNodes, true);\n var containerIndex = findIndexOf(this.containers, function (item) {\n return item.container === container;\n });\n\n if (containerIndex !== -1) {\n this.containers[containerIndex].modals.push(modal);\n return modalIndex;\n }\n\n this.containers.push({\n modals: [modal],\n container: container,\n restore: null,\n hiddenSiblingNodes: hiddenSiblingNodes\n });\n return modalIndex;\n }\n }, {\n key: \"mount\",\n value: function mount(modal, props) {\n var containerIndex = findIndexOf(this.containers, function (item) {\n return item.modals.indexOf(modal) !== -1;\n });\n var containerInfo = this.containers[containerIndex];\n\n if (!containerInfo.restore) {\n containerInfo.restore = handleContainer(containerInfo, props);\n }\n }\n }, {\n key: \"remove\",\n value: function remove(modal) {\n var modalIndex = this.modals.indexOf(modal);\n\n if (modalIndex === -1) {\n return modalIndex;\n }\n\n var containerIndex = findIndexOf(this.containers, function (item) {\n return item.modals.indexOf(modal) !== -1;\n });\n var containerInfo = this.containers[containerIndex];\n containerInfo.modals.splice(containerInfo.modals.indexOf(modal), 1);\n this.modals.splice(modalIndex, 1); // If that was the last modal in a container, clean up the container.\n\n if (containerInfo.modals.length === 0) {\n // The modal might be closed before it had the chance to be mounted in the DOM.\n if (containerInfo.restore) {\n containerInfo.restore();\n }\n\n if (modal.modalRef) {\n // In case the modal wasn't in the DOM yet.\n ariaHidden(modal.modalRef, true);\n }\n\n ariaHiddenSiblings(containerInfo.container, modal.mountNode, modal.modalRef, containerInfo.hiddenSiblingNodes, false);\n this.containers.splice(containerIndex, 1);\n } else {\n // Otherwise make sure the next top modal is visible to a screen reader.\n var nextTop = containerInfo.modals[containerInfo.modals.length - 1]; // as soon as a modal is adding its modalRef is undefined. it can't set\n // aria-hidden because the dom element doesn't exist either\n // when modal was unmounted before modalRef gets null\n\n if (nextTop.modalRef) {\n ariaHidden(nextTop.modalRef, false);\n }\n }\n\n return modalIndex;\n }\n }, {\n key: \"isTopModal\",\n value: function isTopModal(modal) {\n return this.modals.length > 0 && this.modals[this.modals.length - 1] === modal;\n }\n }]);\n\n return ModalManager;\n}();\n\nexport { ModalManager as default };","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","/* eslint-disable consistent-return, jsx-a11y/no-noninteractive-tabindex */\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport ownerDocument from '../utils/ownerDocument';\nimport useForkRef from '../utils/useForkRef';\n/**\n * @ignore - internal component.\n */\n\nfunction TrapFocus(props) {\n var children = props.children,\n _props$disableAutoFoc = props.disableAutoFocus,\n disableAutoFocus = _props$disableAutoFoc === void 0 ? false : _props$disableAutoFoc,\n _props$disableEnforce = props.disableEnforceFocus,\n disableEnforceFocus = _props$disableEnforce === void 0 ? false : _props$disableEnforce,\n _props$disableRestore = props.disableRestoreFocus,\n disableRestoreFocus = _props$disableRestore === void 0 ? false : _props$disableRestore,\n getDoc = props.getDoc,\n isEnabled = props.isEnabled,\n open = props.open;\n var ignoreNextEnforceFocus = React.useRef();\n var sentinelStart = React.useRef(null);\n var sentinelEnd = React.useRef(null);\n var nodeToRestore = React.useRef();\n var rootRef = React.useRef(null); // can be removed once we drop support for non ref forwarding class components\n\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n rootRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n var handleRef = useForkRef(children.ref, handleOwnRef); // âš ï¸ You may rely on React.useMemo as a performance optimization, not as a semantic guarantee.\n // https://reactjs.org/docs/hooks-reference.html#usememo\n\n React.useMemo(function () {\n if (!open || typeof window === 'undefined') {\n return;\n }\n\n nodeToRestore.current = getDoc().activeElement;\n }, [open]); // eslint-disable-line react-hooks/exhaustive-deps\n\n React.useEffect(function () {\n if (!open) {\n return;\n }\n\n var doc = ownerDocument(rootRef.current); // We might render an empty child.\n\n if (!disableAutoFocus && rootRef.current && !rootRef.current.contains(doc.activeElement)) {\n if (!rootRef.current.hasAttribute('tabIndex')) {\n if (process.env.NODE_ENV !== 'production') {\n console.error(['Material-UI: the modal content node does not accept focus.', 'For the benefit of assistive technologies, ' + 'the tabIndex of the node is being set to \"-1\".'].join('\\n'));\n }\n\n rootRef.current.setAttribute('tabIndex', -1);\n }\n\n rootRef.current.focus();\n }\n\n var contain = function contain() {\n if (disableEnforceFocus || !isEnabled() || ignoreNextEnforceFocus.current) {\n ignoreNextEnforceFocus.current = false;\n return;\n }\n\n if (rootRef.current && !rootRef.current.contains(doc.activeElement)) {\n rootRef.current.focus();\n }\n };\n\n var loopFocus = function loopFocus(event) {\n // 9 = Tab\n if (disableEnforceFocus || !isEnabled() || event.keyCode !== 9) {\n return;\n } // Make sure the next tab starts from the right place.\n\n\n if (doc.activeElement === rootRef.current) {\n // We need to ignore the next contain as\n // it will try to move the focus back to the rootRef element.\n ignoreNextEnforceFocus.current = true;\n\n if (event.shiftKey) {\n sentinelEnd.current.focus();\n } else {\n sentinelStart.current.focus();\n }\n }\n };\n\n doc.addEventListener('focus', contain, true);\n doc.addEventListener('keydown', loopFocus, true); // With Edge, Safari and Firefox, no focus related events are fired when the focused area stops being a focused area\n // e.g. https://bugzilla.mozilla.org/show_bug.cgi?id=559561.\n //\n // The whatwg spec defines how the browser should behave but does not explicitly mention any events:\n // https://html.spec.whatwg.org/multipage/interaction.html#focus-fixup-rule.\n\n var interval = setInterval(function () {\n contain();\n }, 50);\n return function () {\n clearInterval(interval);\n doc.removeEventListener('focus', contain, true);\n doc.removeEventListener('keydown', loopFocus, true); // restoreLastFocus()\n\n if (!disableRestoreFocus) {\n // In IE 11 it is possible for document.activeElement to be null resulting\n // in nodeToRestore.current being null.\n // Not all elements in IE 11 have a focus method.\n // Once IE 11 support is dropped the focus() call can be unconditional.\n if (nodeToRestore.current && nodeToRestore.current.focus) {\n nodeToRestore.current.focus();\n }\n\n nodeToRestore.current = null;\n }\n };\n }, [disableAutoFocus, disableEnforceFocus, disableRestoreFocus, isEnabled, open]);\n return React.createElement(React.Fragment, null, React.createElement(\"div\", {\n tabIndex: 0,\n ref: sentinelStart,\n \"data-test\": \"sentinelStart\"\n }), React.cloneElement(children, {\n ref: handleRef\n }), React.createElement(\"div\", {\n tabIndex: 0,\n ref: sentinelEnd,\n \"data-test\": \"sentinelEnd\"\n }));\n}\n\nprocess.env.NODE_ENV !== \"production\" ? TrapFocus.propTypes = {\n /**\n * A single child content element.\n */\n children: PropTypes.element.isRequired,\n\n /**\n * If `true`, the modal will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any modal children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableAutoFocus: PropTypes.bool,\n\n /**\n * If `true`, the modal will not prevent focus from leaving the modal while open.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableEnforceFocus: PropTypes.bool,\n\n /**\n * If `true`, the modal will not restore focus to previously focused element once\n * modal is hidden.\n */\n disableRestoreFocus: PropTypes.bool,\n\n /**\n * Return the document to consider.\n * We use it to implement the restore focus between different browser documents.\n */\n getDoc: PropTypes.func.isRequired,\n\n /**\n * Do we still want to enforce the focus?\n * This prop helps nesting TrapFocus elements.\n */\n isEnabled: PropTypes.func.isRequired,\n\n /**\n * If `true`, the modal is open.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\n/*\n\nIn the future, we should be able to replace TrapFocus with:\nhttps://github.com/facebook/react/blob/master/packages/react-events/docs/FocusScope.md\n\n```jsx\nimport FocusScope from 'react-dom/FocusScope';\n\nfunction TrapFocus(props) {\n const {\n children\n disableAutoFocus = false,\n disableEnforceFocus = false,\n disableRestoreFocus = false,\n open,\n } = props;\n\n if (!open) {\n return children;\n }\n\n return (\n <FocusScope\n autoFocus={!disableAutoFocus}\n contain={!disableEnforceFocus}\n restoreFocus={!disableRestoreFocus}\n >\n {children}\n </FocusScope>\n );\n}\n```\n\n*/\n\nexport default TrapFocus;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n zIndex: -1,\n position: 'fixed',\n right: 0,\n bottom: 0,\n top: 0,\n left: 0,\n backgroundColor: 'rgba(0, 0, 0, 0.5)',\n WebkitTapHighlightColor: 'transparent',\n // Disable scroll capabilities.\n touchAction: 'none'\n },\n\n /* Styles applied to the root element if `invisible={true}`. */\n invisible: {\n backgroundColor: 'transparent'\n }\n};\n/**\n * @ignore - internal component.\n */\n\nvar SimpleBackdrop = React.forwardRef(function SimpleBackdrop(props, ref) {\n var _props$invisible = props.invisible,\n invisible = _props$invisible === void 0 ? false : _props$invisible,\n open = props.open,\n other = _objectWithoutProperties(props, [\"invisible\", \"open\"]);\n\n return open ? React.createElement(\"div\", _extends({\n \"aria-hidden\": true,\n ref: ref\n }, other, {\n style: _extends({}, styles.root, {}, invisible ? styles.invisible : {}, {}, other.style)\n })) : null;\n});\nprocess.env.NODE_ENV !== \"production\" ? SimpleBackdrop.propTypes = {\n /**\n * If `true`, the backdrop is invisible.\n * It can be used when rendering a popover or a custom select component.\n */\n invisible: PropTypes.bool,\n\n /**\n * If `true`, the backdrop is open.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\nexport default SimpleBackdrop;","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport { getThemeProps, useTheme } from '@material-ui/styles';\nimport { elementAcceptingRef } from '@material-ui/utils';\nimport ownerDocument from '../utils/ownerDocument';\nimport Portal from '../Portal';\nimport createChainedFunction from '../utils/createChainedFunction';\nimport useForkRef from '../utils/useForkRef';\nimport useEventCallback from '../utils/useEventCallback';\nimport zIndex from '../styles/zIndex';\nimport ModalManager, { ariaHidden } from './ModalManager';\nimport TrapFocus from './TrapFocus';\nimport SimpleBackdrop from './SimpleBackdrop';\n\nfunction getContainer(container) {\n container = typeof container === 'function' ? container() : container;\n return ReactDOM.findDOMNode(container);\n}\n\nfunction getHasTransition(props) {\n return props.children ? props.children.props.hasOwnProperty('in') : false;\n} // A modal manager used to track and manage the state of open Modals.\n// Modals don't open on the server so this won't conflict with concurrent requests.\n\n\nvar defaultManager = new ModalManager();\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'fixed',\n zIndex: theme.zIndex.modal,\n right: 0,\n bottom: 0,\n top: 0,\n left: 0\n },\n\n /* Styles applied to the root element if the `Modal` has exited. */\n hidden: {\n visibility: 'hidden'\n }\n };\n};\n/**\n * Modal is a lower-level construct that is leveraged by the following components:\n *\n * - [Dialog](/api/dialog/)\n * - [Drawer](/api/drawer/)\n * - [Menu](/api/menu/)\n * - [Popover](/api/popover/)\n *\n * If you are creating a modal dialog, you probably want to use the [Dialog](/api/dialog/) component\n * rather than directly using Modal.\n *\n * This component shares many concepts with [react-overlays](https://react-bootstrap.github.io/react-overlays/#modals).\n */\n\nvar Modal = React.forwardRef(function Modal(inProps, ref) {\n var theme = useTheme();\n var props = getThemeProps({\n name: 'MuiModal',\n props: _extends({}, inProps),\n theme: theme\n });\n\n var _props$BackdropCompon = props.BackdropComponent,\n BackdropComponent = _props$BackdropCompon === void 0 ? SimpleBackdrop : _props$BackdropCompon,\n BackdropProps = props.BackdropProps,\n children = props.children,\n _props$closeAfterTran = props.closeAfterTransition,\n closeAfterTransition = _props$closeAfterTran === void 0 ? false : _props$closeAfterTran,\n container = props.container,\n _props$disableAutoFoc = props.disableAutoFocus,\n disableAutoFocus = _props$disableAutoFoc === void 0 ? false : _props$disableAutoFoc,\n _props$disableBackdro = props.disableBackdropClick,\n disableBackdropClick = _props$disableBackdro === void 0 ? false : _props$disableBackdro,\n _props$disableEnforce = props.disableEnforceFocus,\n disableEnforceFocus = _props$disableEnforce === void 0 ? false : _props$disableEnforce,\n _props$disableEscapeK = props.disableEscapeKeyDown,\n disableEscapeKeyDown = _props$disableEscapeK === void 0 ? false : _props$disableEscapeK,\n _props$disablePortal = props.disablePortal,\n disablePortal = _props$disablePortal === void 0 ? false : _props$disablePortal,\n _props$disableRestore = props.disableRestoreFocus,\n disableRestoreFocus = _props$disableRestore === void 0 ? false : _props$disableRestore,\n _props$disableScrollL = props.disableScrollLock,\n disableScrollLock = _props$disableScrollL === void 0 ? false : _props$disableScrollL,\n _props$hideBackdrop = props.hideBackdrop,\n hideBackdrop = _props$hideBackdrop === void 0 ? false : _props$hideBackdrop,\n _props$keepMounted = props.keepMounted,\n keepMounted = _props$keepMounted === void 0 ? false : _props$keepMounted,\n _props$manager = props.manager,\n manager = _props$manager === void 0 ? defaultManager : _props$manager,\n onBackdropClick = props.onBackdropClick,\n onClose = props.onClose,\n onEscapeKeyDown = props.onEscapeKeyDown,\n onRendered = props.onRendered,\n open = props.open,\n other = _objectWithoutProperties(props, [\"BackdropComponent\", \"BackdropProps\", \"children\", \"closeAfterTransition\", \"container\", \"disableAutoFocus\", \"disableBackdropClick\", \"disableEnforceFocus\", \"disableEscapeKeyDown\", \"disablePortal\", \"disableRestoreFocus\", \"disableScrollLock\", \"hideBackdrop\", \"keepMounted\", \"manager\", \"onBackdropClick\", \"onClose\", \"onEscapeKeyDown\", \"onRendered\", \"open\"]);\n\n var _React$useState = React.useState(true),\n exited = _React$useState[0],\n setExited = _React$useState[1];\n\n var modal = React.useRef({});\n var mountNodeRef = React.useRef(null);\n var modalRef = React.useRef(null);\n var handleRef = useForkRef(modalRef, ref);\n var hasTransition = getHasTransition(props);\n\n var getDoc = function getDoc() {\n return ownerDocument(mountNodeRef.current);\n };\n\n var getModal = function getModal() {\n modal.current.modalRef = modalRef.current;\n modal.current.mountNode = mountNodeRef.current;\n return modal.current;\n };\n\n var handleMounted = function handleMounted() {\n manager.mount(getModal(), {\n disableScrollLock: disableScrollLock\n }); // Fix a bug on Chrome where the scroll isn't initially 0.\n\n modalRef.current.scrollTop = 0;\n };\n\n var handleOpen = useEventCallback(function () {\n var resolvedContainer = getContainer(container) || getDoc().body;\n manager.add(getModal(), resolvedContainer); // The element was already mounted.\n\n if (modalRef.current) {\n handleMounted();\n }\n });\n var isTopModal = React.useCallback(function () {\n return manager.isTopModal(getModal());\n }, [manager]);\n var handlePortalRef = useEventCallback(function (node) {\n mountNodeRef.current = node;\n\n if (!node) {\n return;\n }\n\n if (onRendered) {\n onRendered();\n }\n\n if (open && isTopModal()) {\n handleMounted();\n } else {\n ariaHidden(modalRef.current, true);\n }\n });\n var handleClose = React.useCallback(function () {\n manager.remove(getModal());\n }, [manager]);\n React.useEffect(function () {\n return function () {\n handleClose();\n };\n }, [handleClose]);\n React.useEffect(function () {\n if (open) {\n handleOpen();\n } else if (!hasTransition || !closeAfterTransition) {\n handleClose();\n }\n }, [open, handleClose, hasTransition, closeAfterTransition, handleOpen]);\n\n if (!keepMounted && !open && (!hasTransition || exited)) {\n return null;\n }\n\n var handleEnter = function handleEnter() {\n setExited(false);\n };\n\n var handleExited = function handleExited() {\n setExited(true);\n\n if (closeAfterTransition) {\n handleClose();\n }\n };\n\n var handleBackdropClick = function handleBackdropClick(event) {\n if (event.target !== event.currentTarget) {\n return;\n }\n\n if (onBackdropClick) {\n onBackdropClick(event);\n }\n\n if (!disableBackdropClick && onClose) {\n onClose(event, 'backdropClick');\n }\n };\n\n var handleKeyDown = function handleKeyDown(event) {\n // The handler doesn't take event.defaultPrevented into account:\n //\n // event.preventDefault() is meant to stop default behaviours like\n // clicking a checkbox to check it, hitting a button to submit a form,\n // and hitting left arrow to move the cursor in a text input etc.\n // Only special HTML elements have these default behaviors.\n if (event.key !== 'Escape' || !isTopModal()) {\n return;\n } // Swallow the event, in case someone is listening for the escape key on the body.\n\n\n event.stopPropagation();\n\n if (onEscapeKeyDown) {\n onEscapeKeyDown(event);\n }\n\n if (!disableEscapeKeyDown && onClose) {\n onClose(event, 'escapeKeyDown');\n }\n };\n\n var inlineStyle = styles(theme || {\n zIndex: zIndex\n });\n var childProps = {};\n\n if (children.props.tabIndex === undefined) {\n childProps.tabIndex = children.props.tabIndex || '-1';\n } // It's a Transition like component\n\n\n if (hasTransition) {\n childProps.onEnter = createChainedFunction(handleEnter, children.props.onEnter);\n childProps.onExited = createChainedFunction(handleExited, children.props.onExited);\n }\n\n return React.createElement(Portal, {\n ref: handlePortalRef,\n container: container,\n disablePortal: disablePortal\n }, React.createElement(\"div\", _extends({\n ref: handleRef,\n onKeyDown: handleKeyDown,\n role: \"presentation\"\n }, other, {\n style: _extends({}, inlineStyle.root, {}, !open && exited ? inlineStyle.hidden : {}, {}, other.style)\n }), hideBackdrop ? null : React.createElement(BackdropComponent, _extends({\n open: open,\n onClick: handleBackdropClick\n }, BackdropProps)), React.createElement(TrapFocus, {\n disableEnforceFocus: disableEnforceFocus,\n disableAutoFocus: disableAutoFocus,\n disableRestoreFocus: disableRestoreFocus,\n getDoc: getDoc,\n isEnabled: isTopModal,\n open: open\n }, React.cloneElement(children, childProps))));\n});\nprocess.env.NODE_ENV !== \"production\" ? Modal.propTypes = {\n /**\n * A backdrop component. This prop enables custom backdrop rendering.\n */\n BackdropComponent: PropTypes.elementType,\n\n /**\n * Props applied to the [`Backdrop`](/api/backdrop/) element.\n */\n BackdropProps: PropTypes.object,\n\n /**\n * A single child content element.\n */\n children: elementAcceptingRef.isRequired,\n\n /**\n * When set to true the Modal waits until a nested Transition is completed before closing.\n */\n closeAfterTransition: PropTypes.bool,\n\n /**\n * A node, component instance, or function that returns either.\n * The `container` will have the portal children appended to it.\n */\n container: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n /**\n * If `true`, the modal will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any modal children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableAutoFocus: PropTypes.bool,\n\n /**\n * If `true`, clicking the backdrop will not fire any callback.\n */\n disableBackdropClick: PropTypes.bool,\n\n /**\n * If `true`, the modal will not prevent focus from leaving the modal while open.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n */\n disableEnforceFocus: PropTypes.bool,\n\n /**\n * If `true`, hitting escape will not fire any callback.\n */\n disableEscapeKeyDown: PropTypes.bool,\n\n /**\n * Disable the portal behavior.\n * The children stay within it's parent DOM hierarchy.\n */\n disablePortal: PropTypes.bool,\n\n /**\n * If `true`, the modal will not restore focus to previously focused element once\n * modal is hidden.\n */\n disableRestoreFocus: PropTypes.bool,\n\n /**\n * Disable the scroll lock behavior.\n */\n disableScrollLock: PropTypes.bool,\n\n /**\n * If `true`, the backdrop is not rendered.\n */\n hideBackdrop: PropTypes.bool,\n\n /**\n * Always keep the children in the DOM.\n * This prop can be useful in SEO situation or\n * when you want to maximize the responsiveness of the Modal.\n */\n keepMounted: PropTypes.bool,\n\n /**\n * @ignore\n */\n manager: PropTypes.object,\n\n /**\n * Callback fired when the backdrop is clicked.\n */\n onBackdropClick: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be closed.\n * The `reason` parameter can optionally be used to control the response to `onClose`.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired when the escape key is pressed,\n * `disableEscapeKeyDown` is false and the modal is in focus.\n */\n onEscapeKeyDown: PropTypes.func,\n\n /**\n * Callback fired once the children has been mounted into the `container`.\n * It signals that the `open={true}` prop took effect.\n *\n * This prop will be deprecated and removed in v5, the ref can be used instead.\n */\n onRendered: PropTypes.func,\n\n /**\n * If `true`, the modal is open.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\nexport default Modal;","export default {\n disabled: false\n};","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport config from './config';\nimport { timeoutsShape } from './utils/PropTypes';\nimport TransitionGroupContext from './TransitionGroupContext';\nexport var UNMOUNTED = 'unmounted';\nexport var EXITED = 'exited';\nexport var ENTERING = 'entering';\nexport var ENTERED = 'entered';\nexport var EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n * transition: `opacity ${duration}ms ease-in-out`,\n * opacity: 0,\n * }\n *\n * const transitionStyles = {\n * entering: { opacity: 1 },\n * entered: { opacity: 1 },\n * exiting: { opacity: 0 },\n * exited: { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n * <Transition in={inProp} timeout={duration}>\n * {state => (\n * <div style={{\n * ...defaultStyle,\n * ...transitionStyles[state]\n * }}>\n * I'm a fade Transition!\n * </div>\n * )}\n * </Transition>\n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n * - `'entering'`\n * - `'entered'`\n * - `'exiting'`\n * - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n * <div>\n * <Transition in={inProp} timeout={500}>\n * {state => (\n * // ...\n * )}\n * </Transition>\n * <button onClick={() => setInProp(true)}>\n * Click to Enter\n * </button>\n * </div>\n * );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state\n * and stay there for 500ms (the value of `timeout`) before it finally switches\n * to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from\n * `'exiting'` to `'exited'`.\n */\n\nvar Transition =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(Transition, _React$Component);\n\n function Transition(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n var parentGroup = context; // In the context of a TransitionGroup all enters are really appears\n\n var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n var initialStatus;\n _this.appearStatus = null;\n\n if (props.in) {\n if (appear) {\n initialStatus = EXITED;\n _this.appearStatus = ENTERING;\n } else {\n initialStatus = ENTERED;\n }\n } else {\n if (props.unmountOnExit || props.mountOnEnter) {\n initialStatus = UNMOUNTED;\n } else {\n initialStatus = EXITED;\n }\n }\n\n _this.state = {\n status: initialStatus\n };\n _this.nextCallback = null;\n return _this;\n }\n\n Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n var nextIn = _ref.in;\n\n if (nextIn && prevState.status === UNMOUNTED) {\n return {\n status: EXITED\n };\n }\n\n return null;\n }; // getSnapshotBeforeUpdate(prevProps) {\n // let nextStatus = null\n // if (prevProps !== this.props) {\n // const { status } = this.state\n // if (this.props.in) {\n // if (status !== ENTERING && status !== ENTERED) {\n // nextStatus = ENTERING\n // }\n // } else {\n // if (status === ENTERING || status === ENTERED) {\n // nextStatus = EXITING\n // }\n // }\n // }\n // return { nextStatus }\n // }\n\n\n var _proto = Transition.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.updateStatus(true, this.appearStatus);\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var nextStatus = null;\n\n if (prevProps !== this.props) {\n var status = this.state.status;\n\n if (this.props.in) {\n if (status !== ENTERING && status !== ENTERED) {\n nextStatus = ENTERING;\n }\n } else {\n if (status === ENTERING || status === ENTERED) {\n nextStatus = EXITING;\n }\n }\n }\n\n this.updateStatus(false, nextStatus);\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.cancelNextCallback();\n };\n\n _proto.getTimeouts = function getTimeouts() {\n var timeout = this.props.timeout;\n var exit, enter, appear;\n exit = enter = appear = timeout;\n\n if (timeout != null && typeof timeout !== 'number') {\n exit = timeout.exit;\n enter = timeout.enter; // TODO: remove fallback for next major\n\n appear = timeout.appear !== undefined ? timeout.appear : enter;\n }\n\n return {\n exit: exit,\n enter: enter,\n appear: appear\n };\n };\n\n _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n if (mounting === void 0) {\n mounting = false;\n }\n\n if (nextStatus !== null) {\n // nextStatus will always be ENTERING or EXITING.\n this.cancelNextCallback();\n var node = ReactDOM.findDOMNode(this);\n\n if (nextStatus === ENTERING) {\n this.performEnter(node, mounting);\n } else {\n this.performExit(node);\n }\n } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n this.setState({\n status: UNMOUNTED\n });\n }\n };\n\n _proto.performEnter = function performEnter(node, mounting) {\n var _this2 = this;\n\n var enter = this.props.enter;\n var appearing = this.context ? this.context.isMounting : mounting;\n var timeouts = this.getTimeouts();\n var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED\n // if we are mounting and running this it means appear _must_ be set\n\n if (!mounting && !enter || config.disabled) {\n this.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(node);\n });\n return;\n }\n\n this.props.onEnter(node, appearing);\n this.safeSetState({\n status: ENTERING\n }, function () {\n _this2.props.onEntering(node, appearing);\n\n _this2.onTransitionEnd(node, enterTimeout, function () {\n _this2.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(node, appearing);\n });\n });\n });\n };\n\n _proto.performExit = function performExit(node) {\n var _this3 = this;\n\n var exit = this.props.exit;\n var timeouts = this.getTimeouts(); // no exit animation skip right to EXITED\n\n if (!exit || config.disabled) {\n this.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(node);\n });\n return;\n }\n\n this.props.onExit(node);\n this.safeSetState({\n status: EXITING\n }, function () {\n _this3.props.onExiting(node);\n\n _this3.onTransitionEnd(node, timeouts.exit, function () {\n _this3.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(node);\n });\n });\n });\n };\n\n _proto.cancelNextCallback = function cancelNextCallback() {\n if (this.nextCallback !== null) {\n this.nextCallback.cancel();\n this.nextCallback = null;\n }\n };\n\n _proto.safeSetState = function safeSetState(nextState, callback) {\n // This shouldn't be necessary, but there are weird race conditions with\n // setState callbacks and unmounting in testing, so always make sure that\n // we can cancel any pending setState callbacks after we unmount.\n callback = this.setNextCallback(callback);\n this.setState(nextState, callback);\n };\n\n _proto.setNextCallback = function setNextCallback(callback) {\n var _this4 = this;\n\n var active = true;\n\n this.nextCallback = function (event) {\n if (active) {\n active = false;\n _this4.nextCallback = null;\n callback(event);\n }\n };\n\n this.nextCallback.cancel = function () {\n active = false;\n };\n\n return this.nextCallback;\n };\n\n _proto.onTransitionEnd = function onTransitionEnd(node, timeout, handler) {\n this.setNextCallback(handler);\n var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;\n\n if (!node || doesNotHaveTimeoutOrListener) {\n setTimeout(this.nextCallback, 0);\n return;\n }\n\n if (this.props.addEndListener) {\n this.props.addEndListener(node, this.nextCallback);\n }\n\n if (timeout != null) {\n setTimeout(this.nextCallback, timeout);\n }\n };\n\n _proto.render = function render() {\n var status = this.state.status;\n\n if (status === UNMOUNTED) {\n return null;\n }\n\n var _this$props = this.props,\n children = _this$props.children,\n childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\"]); // filter props for Transtition\n\n\n delete childProps.in;\n delete childProps.mountOnEnter;\n delete childProps.unmountOnExit;\n delete childProps.appear;\n delete childProps.enter;\n delete childProps.exit;\n delete childProps.timeout;\n delete childProps.addEndListener;\n delete childProps.onEnter;\n delete childProps.onEntering;\n delete childProps.onEntered;\n delete childProps.onExit;\n delete childProps.onExiting;\n delete childProps.onExited;\n\n if (typeof children === 'function') {\n // allows for nested Transitions\n return React.createElement(TransitionGroupContext.Provider, {\n value: null\n }, children(status, childProps));\n }\n\n var child = React.Children.only(children);\n return (// allows for nested Transitions\n React.createElement(TransitionGroupContext.Provider, {\n value: null\n }, React.cloneElement(child, childProps))\n );\n };\n\n return Transition;\n}(React.Component);\n\nTransition.contextType = TransitionGroupContext;\nTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * A `function` child can be used instead of a React element. This function is\n * called with the current transition status (`'entering'`, `'entered'`,\n * `'exiting'`, `'exited'`), which can be used to apply context\n * specific props to a component.\n *\n * ```jsx\n * <Transition in={this.state.in} timeout={150}>\n * {state => (\n * <MyComponent className={`fade fade-${state}`} />\n * )}\n * </Transition>\n * ```\n */\n children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,\n\n /**\n * Show the component; triggers the enter or exit states\n */\n in: PropTypes.bool,\n\n /**\n * By default the child component is mounted immediately along with\n * the parent `Transition` component. If you want to \"lazy mount\" the component on the\n * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay\n * mounted, even on \"exited\", unless you also specify `unmountOnExit`.\n */\n mountOnEnter: PropTypes.bool,\n\n /**\n * By default the child component stays mounted after it reaches the `'exited'` state.\n * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.\n */\n unmountOnExit: PropTypes.bool,\n\n /**\n * Normally a component is not transitioned if it is shown when the\n * `<Transition>` component mounts. If you want to transition on the first\n * mount set `appear` to `true`, and the component will transition in as soon\n * as the `<Transition>` mounts.\n *\n * > **Note**: there are no special appear states like `appearing`/`appeared`, this prop\n * > only adds an additional enter transition. However, in the\n * > `<CSSTransition>` component that first enter transition does result in\n * > additional `.appear-*` classes, that way you can choose to style it\n * > differently.\n */\n appear: PropTypes.bool,\n\n /**\n * Enable or disable enter transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * Enable or disable exit transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * The duration of the transition, in milliseconds.\n * Required unless `addEndListener` is provided.\n *\n * You may specify a single timeout for all transitions:\n *\n * ```jsx\n * timeout={500}\n * ```\n *\n * or individually:\n *\n * ```jsx\n * timeout={{\n * appear: 500,\n * enter: 300,\n * exit: 500,\n * }}\n * ```\n *\n * - `appear` defaults to the value of `enter`\n * - `enter` defaults to `0`\n * - `exit` defaults to `0`\n *\n * @type {number | { enter?: number, exit?: number, appear?: number }}\n */\n timeout: function timeout(props) {\n var pt = timeoutsShape;\n if (!props.addEndListener) pt = pt.isRequired;\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return pt.apply(void 0, [props].concat(args));\n },\n\n /**\n * Add a custom transition end trigger. Called with the transitioning\n * DOM node and a `done` callback. Allows for more fine grained transition end\n * logic. **Note:** Timeouts are still used as a fallback if provided.\n *\n * ```jsx\n * addEndListener={(node, done) => {\n * // use the css transitionend event to mark the finish of a transition\n * node.addEventListener('transitionend', done, false);\n * }}\n * ```\n */\n addEndListener: PropTypes.func,\n\n /**\n * Callback fired before the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired after the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired after the \"entered\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired before the \"exiting\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired after the \"exiting\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExiting: PropTypes.func,\n\n /**\n * Callback fired after the \"exited\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExited: PropTypes.func // Name the function so it is clearer in the documentation\n\n} : {};\n\nfunction noop() {}\n\nTransition.defaultProps = {\n in: false,\n mountOnEnter: false,\n unmountOnExit: false,\n appear: false,\n enter: true,\n exit: true,\n onEnter: noop,\n onEntering: noop,\n onEntered: noop,\n onExit: noop,\n onExiting: noop,\n onExited: noop\n};\nTransition.UNMOUNTED = 0;\nTransition.EXITED = 1;\nTransition.ENTERING = 2;\nTransition.ENTERED = 3;\nTransition.EXITING = 4;\nexport default Transition;","export var reflow = function reflow(node) {\n return node.scrollTop;\n};\nexport function getTransitionProps(props, options) {\n var timeout = props.timeout,\n _props$style = props.style,\n style = _props$style === void 0 ? {} : _props$style;\n return {\n duration: style.transitionDuration || typeof timeout === 'number' ? timeout : timeout[options.mode] || 0,\n delay: style.transitionDelay\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { Transition } from 'react-transition-group';\nimport useTheme from '../styles/useTheme';\nimport { reflow, getTransitionProps } from '../transitions/utils';\nimport useForkRef from '../utils/useForkRef';\n\nfunction getScale(value) {\n return \"scale(\".concat(value, \", \").concat(Math.pow(value, 2), \")\");\n}\n\nvar styles = {\n entering: {\n opacity: 1,\n transform: getScale(1)\n },\n entered: {\n opacity: 1,\n transform: 'none'\n }\n};\n/**\n * The Grow transition is used by the [Tooltip](/components/tooltips/) and\n * [Popover](/components/popover/) components.\n * It uses [react-transition-group](https://github.com/reactjs/react-transition-group) internally.\n */\n\nvar Grow = React.forwardRef(function Grow(props, ref) {\n var children = props.children,\n inProp = props.in,\n onEnter = props.onEnter,\n onExit = props.onExit,\n style = props.style,\n _props$timeout = props.timeout,\n timeout = _props$timeout === void 0 ? 'auto' : _props$timeout,\n other = _objectWithoutProperties(props, [\"children\", \"in\", \"onEnter\", \"onExit\", \"style\", \"timeout\"]);\n\n var timer = React.useRef();\n var autoTimeout = React.useRef();\n var handleRef = useForkRef(children.ref, ref);\n var theme = useTheme();\n\n var handleEnter = function handleEnter(node, isAppearing) {\n reflow(node); // So the animation always start from the start.\n\n var _getTransitionProps = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'enter'\n }),\n transitionDuration = _getTransitionProps.duration,\n delay = _getTransitionProps.delay;\n\n var duration;\n\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n\n node.style.transition = [theme.transitions.create('opacity', {\n duration: duration,\n delay: delay\n }), theme.transitions.create('transform', {\n duration: duration * 0.666,\n delay: delay\n })].join(',');\n\n if (onEnter) {\n onEnter(node, isAppearing);\n }\n };\n\n var handleExit = function handleExit(node) {\n var _getTransitionProps2 = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'exit'\n }),\n transitionDuration = _getTransitionProps2.duration,\n delay = _getTransitionProps2.delay;\n\n var duration;\n\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n\n node.style.transition = [theme.transitions.create('opacity', {\n duration: duration,\n delay: delay\n }), theme.transitions.create('transform', {\n duration: duration * 0.666,\n delay: delay || duration * 0.333\n })].join(',');\n node.style.opacity = '0';\n node.style.transform = getScale(0.75);\n\n if (onExit) {\n onExit(node);\n }\n };\n\n var addEndListener = function addEndListener(_, next) {\n if (timeout === 'auto') {\n timer.current = setTimeout(next, autoTimeout.current || 0);\n }\n };\n\n React.useEffect(function () {\n return function () {\n clearTimeout(timer.current);\n };\n }, []);\n return React.createElement(Transition, _extends({\n appear: true,\n in: inProp,\n onEnter: handleEnter,\n onExit: handleExit,\n addEndListener: addEndListener,\n timeout: timeout === 'auto' ? null : timeout\n }, other), function (state, childProps) {\n return React.cloneElement(children, _extends({\n style: _extends({\n opacity: 0,\n transform: getScale(0.75),\n visibility: state === 'exited' && !inProp ? 'hidden' : undefined\n }, styles[state], {}, style, {}, children.props.style),\n ref: handleRef\n }, childProps));\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Grow.propTypes = {\n /**\n * A single child content element.\n */\n children: PropTypes.element,\n\n /**\n * If `true`, show the component; triggers the enter or exit animation.\n */\n in: PropTypes.bool,\n\n /**\n * @ignore\n */\n onEnter: PropTypes.func,\n\n /**\n * @ignore\n */\n onExit: PropTypes.func,\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n *\n * Set to 'auto' to automatically calculate transition time based on height.\n */\n timeout: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n enter: PropTypes.number,\n exit: PropTypes.number\n }), PropTypes.oneOf(['auto'])])\n} : void 0;\nGrow.muiSupportAuto = true;\nexport default Grow;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport debounce from '../utils/debounce';\nimport clsx from 'clsx';\nimport { chainPropTypes, elementTypeAcceptingRef, refType } from '@material-ui/utils';\nimport ownerDocument from '../utils/ownerDocument';\nimport ownerWindow from '../utils/ownerWindow';\nimport createChainedFunction from '../utils/createChainedFunction';\nimport withStyles from '../styles/withStyles';\nimport Modal from '../Modal';\nimport Grow from '../Grow';\nimport Paper from '../Paper';\nexport function getOffsetTop(rect, vertical) {\n var offset = 0;\n\n if (typeof vertical === 'number') {\n offset = vertical;\n } else if (vertical === 'center') {\n offset = rect.height / 2;\n } else if (vertical === 'bottom') {\n offset = rect.height;\n }\n\n return offset;\n}\nexport function getOffsetLeft(rect, horizontal) {\n var offset = 0;\n\n if (typeof horizontal === 'number') {\n offset = horizontal;\n } else if (horizontal === 'center') {\n offset = rect.width / 2;\n } else if (horizontal === 'right') {\n offset = rect.width;\n }\n\n return offset;\n}\n\nfunction getTransformOriginValue(transformOrigin) {\n return [transformOrigin.horizontal, transformOrigin.vertical].map(function (n) {\n return typeof n === 'number' ? \"\".concat(n, \"px\") : n;\n }).join(' ');\n} // Sum the scrollTop between two elements.\n\n\nfunction getScrollParent(parent, child) {\n var element = child;\n var scrollTop = 0;\n\n while (element && element !== parent) {\n element = element.parentElement;\n scrollTop += element.scrollTop;\n }\n\n return scrollTop;\n}\n\nfunction getAnchorEl(anchorEl) {\n return typeof anchorEl === 'function' ? anchorEl() : anchorEl;\n}\n\nexport var styles = {\n /* Styles applied to the root element */\n root: {},\n\n /* Styles applied to the `Paper` component. */\n paper: {\n position: 'absolute',\n overflowY: 'auto',\n overflowX: 'hidden',\n // So we see the popover when it's empty.\n // It's most likely on issue on userland.\n minWidth: 16,\n minHeight: 16,\n maxWidth: 'calc(100% - 32px)',\n maxHeight: 'calc(100% - 32px)',\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0\n }\n};\nvar Popover = React.forwardRef(function Popover(props, ref) {\n var action = props.action,\n anchorEl = props.anchorEl,\n _props$anchorOrigin = props.anchorOrigin,\n anchorOrigin = _props$anchorOrigin === void 0 ? {\n vertical: 'top',\n horizontal: 'left'\n } : _props$anchorOrigin,\n anchorPosition = props.anchorPosition,\n _props$anchorReferenc = props.anchorReference,\n anchorReference = _props$anchorReferenc === void 0 ? 'anchorEl' : _props$anchorReferenc,\n children = props.children,\n classes = props.classes,\n className = props.className,\n containerProp = props.container,\n _props$elevation = props.elevation,\n elevation = _props$elevation === void 0 ? 8 : _props$elevation,\n getContentAnchorEl = props.getContentAnchorEl,\n _props$marginThreshol = props.marginThreshold,\n marginThreshold = _props$marginThreshol === void 0 ? 16 : _props$marginThreshol,\n onEnter = props.onEnter,\n onEntered = props.onEntered,\n onEntering = props.onEntering,\n onExit = props.onExit,\n onExited = props.onExited,\n onExiting = props.onExiting,\n open = props.open,\n _props$PaperProps = props.PaperProps,\n PaperProps = _props$PaperProps === void 0 ? {} : _props$PaperProps,\n _props$transformOrigi = props.transformOrigin,\n transformOrigin = _props$transformOrigi === void 0 ? {\n vertical: 'top',\n horizontal: 'left'\n } : _props$transformOrigi,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Grow : _props$TransitionComp,\n _props$transitionDura = props.transitionDuration,\n transitionDurationProp = _props$transitionDura === void 0 ? 'auto' : _props$transitionDura,\n _props$TransitionProp = props.TransitionProps,\n TransitionProps = _props$TransitionProp === void 0 ? {} : _props$TransitionProp,\n other = _objectWithoutProperties(props, [\"action\", \"anchorEl\", \"anchorOrigin\", \"anchorPosition\", \"anchorReference\", \"children\", \"classes\", \"className\", \"container\", \"elevation\", \"getContentAnchorEl\", \"marginThreshold\", \"onEnter\", \"onEntered\", \"onEntering\", \"onExit\", \"onExited\", \"onExiting\", \"open\", \"PaperProps\", \"transformOrigin\", \"TransitionComponent\", \"transitionDuration\", \"TransitionProps\"]);\n\n var paperRef = React.useRef(); // Returns the top/left offset of the position\n // to attach to on the anchor element (or body if none is provided)\n\n var getAnchorOffset = React.useCallback(function (contentAnchorOffset) {\n if (anchorReference === 'anchorPosition') {\n if (process.env.NODE_ENV !== 'production') {\n if (!anchorPosition) {\n console.error('Material-UI: you need to provide a `anchorPosition` prop when using ' + '<Popover anchorReference=\"anchorPosition\" />.');\n }\n }\n\n return anchorPosition;\n }\n\n var resolvedAnchorEl = getAnchorEl(anchorEl);\n var containerWindow = ownerWindow(resolvedAnchorEl); // If an anchor element wasn't provided, just use the parent body element of this Popover\n\n var anchorElement = resolvedAnchorEl instanceof containerWindow.Element ? resolvedAnchorEl : ownerDocument(paperRef.current).body;\n var anchorRect = anchorElement.getBoundingClientRect();\n\n if (process.env.NODE_ENV !== 'production') {\n var box = anchorElement.getBoundingClientRect();\n\n if (process.env.NODE_ENV !== 'test' && box.top === 0 && box.left === 0 && box.right === 0 && box.bottom === 0) {\n console.warn(['Material-UI: the `anchorEl` prop provided to the component is invalid.', 'The anchor element should be part of the document layout.', \"Make sure the element is present in the document or that it's not display none.\"].join('\\n'));\n }\n }\n\n var anchorVertical = contentAnchorOffset === 0 ? anchorOrigin.vertical : 'center';\n return {\n top: anchorRect.top + getOffsetTop(anchorRect, anchorVertical),\n left: anchorRect.left + getOffsetLeft(anchorRect, anchorOrigin.horizontal)\n };\n }, [anchorEl, anchorOrigin.horizontal, anchorOrigin.vertical, anchorPosition, anchorReference]); // Returns the vertical offset of inner content to anchor the transform on if provided\n\n var getContentAnchorOffset = React.useCallback(function (element) {\n var contentAnchorOffset = 0;\n\n if (getContentAnchorEl && anchorReference === 'anchorEl') {\n var contentAnchorEl = getContentAnchorEl(element);\n\n if (contentAnchorEl && element.contains(contentAnchorEl)) {\n var scrollTop = getScrollParent(element, contentAnchorEl);\n contentAnchorOffset = contentAnchorEl.offsetTop + contentAnchorEl.clientHeight / 2 - scrollTop || 0;\n } // != the default value\n\n\n if (process.env.NODE_ENV !== 'production') {\n if (anchorOrigin.vertical !== 'top') {\n console.error(['Material-UI: you can not change the default `anchorOrigin.vertical` value ', 'when also providing the `getContentAnchorEl` prop to the popover component.', 'Only use one of the two props.', 'Set `getContentAnchorEl` to `null | undefined`' + ' or leave `anchorOrigin.vertical` unchanged.'].join('\\n'));\n }\n }\n }\n\n return contentAnchorOffset;\n }, [anchorOrigin.vertical, anchorReference, getContentAnchorEl]); // Return the base transform origin using the element\n // and taking the content anchor offset into account if in use\n\n var getTransformOrigin = React.useCallback(function (elemRect) {\n var contentAnchorOffset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n return {\n vertical: getOffsetTop(elemRect, transformOrigin.vertical) + contentAnchorOffset,\n horizontal: getOffsetLeft(elemRect, transformOrigin.horizontal)\n };\n }, [transformOrigin.horizontal, transformOrigin.vertical]);\n var getPositioningStyle = React.useCallback(function (element) {\n // Check if the parent has requested anchoring on an inner content node\n var contentAnchorOffset = getContentAnchorOffset(element);\n var elemRect = {\n width: element.offsetWidth,\n height: element.offsetHeight\n }; // Get the transform origin point on the element itself\n\n var elemTransformOrigin = getTransformOrigin(elemRect, contentAnchorOffset);\n\n if (anchorReference === 'none') {\n return {\n top: null,\n left: null,\n transformOrigin: getTransformOriginValue(elemTransformOrigin)\n };\n } // Get the offset of of the anchoring element\n\n\n var anchorOffset = getAnchorOffset(contentAnchorOffset); // Calculate element positioning\n\n var top = anchorOffset.top - elemTransformOrigin.vertical;\n var left = anchorOffset.left - elemTransformOrigin.horizontal;\n var bottom = top + elemRect.height;\n var right = left + elemRect.width; // Use the parent window of the anchorEl if provided\n\n var containerWindow = ownerWindow(getAnchorEl(anchorEl)); // Window thresholds taking required margin into account\n\n var heightThreshold = containerWindow.innerHeight - marginThreshold;\n var widthThreshold = containerWindow.innerWidth - marginThreshold; // Check if the vertical axis needs shifting\n\n if (top < marginThreshold) {\n var diff = top - marginThreshold;\n top -= diff;\n elemTransformOrigin.vertical += diff;\n } else if (bottom > heightThreshold) {\n var _diff = bottom - heightThreshold;\n\n top -= _diff;\n elemTransformOrigin.vertical += _diff;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (elemRect.height > heightThreshold && elemRect.height && heightThreshold) {\n console.error(['Material-UI: the popover component is too tall.', \"Some part of it can not be seen on the screen (\".concat(elemRect.height - heightThreshold, \"px).\"), 'Please consider adding a `max-height` to improve the user-experience.'].join('\\n'));\n }\n } // Check if the horizontal axis needs shifting\n\n\n if (left < marginThreshold) {\n var _diff2 = left - marginThreshold;\n\n left -= _diff2;\n elemTransformOrigin.horizontal += _diff2;\n } else if (right > widthThreshold) {\n var _diff3 = right - widthThreshold;\n\n left -= _diff3;\n elemTransformOrigin.horizontal += _diff3;\n }\n\n return {\n top: \"\".concat(Math.round(top), \"px\"),\n left: \"\".concat(Math.round(left), \"px\"),\n transformOrigin: getTransformOriginValue(elemTransformOrigin)\n };\n }, [anchorEl, anchorReference, getAnchorOffset, getContentAnchorOffset, getTransformOrigin, marginThreshold]);\n var setPositioningStyles = React.useCallback(function () {\n var element = paperRef.current;\n\n if (!element) {\n return;\n }\n\n var positioning = getPositioningStyle(element);\n\n if (positioning.top !== null) {\n element.style.top = positioning.top;\n }\n\n if (positioning.left !== null) {\n element.style.left = positioning.left;\n }\n\n element.style.transformOrigin = positioning.transformOrigin;\n }, [getPositioningStyle]);\n\n var handleEntering = function handleEntering(element, isAppearing) {\n if (onEntering) {\n onEntering(element, isAppearing);\n }\n\n setPositioningStyles();\n };\n\n var handlePaperRef = React.useCallback(function (instance) {\n // #StrictMode ready\n paperRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n React.useEffect(function () {\n if (open) {\n setPositioningStyles();\n }\n });\n React.useImperativeHandle(action, function () {\n return open ? {\n updatePosition: function updatePosition() {\n setPositioningStyles();\n }\n } : null;\n }, [open, setPositioningStyles]);\n React.useEffect(function () {\n if (!open) {\n return undefined;\n }\n\n var handleResize = debounce(function () {\n setPositioningStyles();\n });\n window.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n window.removeEventListener('rezise', handleResize);\n };\n }, [open, setPositioningStyles]);\n var transitionDuration = transitionDurationProp;\n\n if (transitionDurationProp === 'auto' && !TransitionComponent.muiSupportAuto) {\n transitionDuration = undefined;\n } // If the container prop is provided, use that\n // If the anchorEl prop is provided, use its parent body element as the container\n // If neither are provided let the Modal take care of choosing the container\n\n\n var container = containerProp || (anchorEl ? ownerDocument(getAnchorEl(anchorEl)).body : undefined);\n return React.createElement(Modal, _extends({\n container: container,\n open: open,\n ref: ref,\n BackdropProps: {\n invisible: true\n },\n className: clsx(classes.root, className)\n }, other), React.createElement(TransitionComponent, _extends({\n appear: true,\n in: open,\n onEnter: onEnter,\n onEntered: onEntered,\n onExit: onExit,\n onExited: onExited,\n onExiting: onExiting,\n timeout: transitionDuration\n }, TransitionProps, {\n onEntering: createChainedFunction(handleEntering, TransitionProps.onEntering)\n }), React.createElement(Paper, _extends({\n elevation: elevation,\n ref: handlePaperRef\n }, PaperProps, {\n className: clsx(classes.paper, PaperProps.className)\n }), children)));\n});\nprocess.env.NODE_ENV !== \"production\" ? Popover.propTypes = {\n /**\n * A ref for imperative actions.\n * It currently only supports updatePosition() action.\n */\n action: refType,\n\n /**\n * This is the DOM element, or a function that returns the DOM element,\n * that may be used to set the position of the popover.\n */\n anchorEl: chainPropTypes(PropTypes.oneOfType([PropTypes.object, PropTypes.func]), function (props) {\n if (props.open && (!props.anchorReference || props.anchorReference === 'anchorEl')) {\n var resolvedAnchorEl = getAnchorEl(props.anchorEl);\n var containerWindow = ownerWindow(resolvedAnchorEl);\n\n if (resolvedAnchorEl instanceof containerWindow.Element) {\n var box = resolvedAnchorEl.getBoundingClientRect();\n\n if (process.env.NODE_ENV !== 'test' && box.top === 0 && box.left === 0 && box.right === 0 && box.bottom === 0) {\n return new Error(['Material-UI: the `anchorEl` prop provided to the component is invalid.', 'The anchor element should be part of the document layout.', \"Make sure the element is present in the document or that it's not display none.\"].join('\\n'));\n }\n } else {\n return new Error(['Material-UI: the `anchorEl` prop provided to the component is invalid.', \"It should be an Element instance but it's `\".concat(resolvedAnchorEl, \"` instead.\")].join('\\n'));\n }\n }\n\n return null;\n }),\n\n /**\n * This is the point on the anchor where the popover's\n * `anchorEl` will attach to. This is not used when the\n * anchorReference is 'anchorPosition'.\n *\n * Options:\n * vertical: [top, center, bottom];\n * horizontal: [left, center, right].\n */\n anchorOrigin: PropTypes.shape({\n horizontal: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['left', 'center', 'right'])]).isRequired,\n vertical: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['top', 'center', 'bottom'])]).isRequired\n }),\n\n /**\n * This is the position that may be used\n * to set the position of the popover.\n * The coordinates are relative to\n * the application's client area.\n */\n anchorPosition: PropTypes.shape({\n left: PropTypes.number.isRequired,\n top: PropTypes.number.isRequired\n }),\n\n /*\n * This determines which anchor prop to refer to to set\n * the position of the popover.\n */\n anchorReference: PropTypes.oneOf(['anchorEl', 'anchorPosition', 'none']),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * A node, component instance, or function that returns either.\n * The `container` will passed to the Modal component.\n * By default, it uses the body of the anchorEl's top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n /**\n * The elevation of the popover.\n */\n elevation: PropTypes.number,\n\n /**\n * This function is called in order to retrieve the content anchor element.\n * It's the opposite of the `anchorEl` prop.\n * The content anchor element should be an element inside the popover.\n * It's used to correctly scroll and set the position of the popover.\n * The positioning strategy tries to make the content anchor element just above the\n * anchor element.\n */\n getContentAnchorEl: PropTypes.func,\n\n /**\n * Specifies how close to the edge of the window the popover can appear.\n */\n marginThreshold: PropTypes.number,\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired before the component is entering.\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired when the component has entered.\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired when the component is entering.\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired before the component is exiting.\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired when the component has exited.\n */\n onExited: PropTypes.func,\n\n /**\n * Callback fired when the component is exiting.\n */\n onExiting: PropTypes.func,\n\n /**\n * If `true`, the popover is visible.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * Props applied to the [`Paper`](/api/paper/) element.\n */\n PaperProps: PropTypes.shape({\n component: elementTypeAcceptingRef\n }),\n\n /**\n * This is the point on the popover which\n * will attach to the anchor's origin.\n *\n * Options:\n * vertical: [top, center, bottom, x(px)];\n * horizontal: [left, center, right, x(px)].\n */\n transformOrigin: PropTypes.shape({\n horizontal: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['left', 'center', 'right'])]).isRequired,\n vertical: PropTypes.oneOfType([PropTypes.number, PropTypes.oneOf(['top', 'center', 'bottom'])]).isRequired\n }),\n\n /**\n * The component used for the transition.\n */\n TransitionComponent: PropTypes.elementType,\n\n /**\n * Set to 'auto' to automatically calculate transition time based on height.\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n enter: PropTypes.number,\n exit: PropTypes.number\n }), PropTypes.oneOf(['auto'])]),\n\n /**\n * Props applied to the `Transition` element.\n */\n TransitionProps: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiPopover'\n})(Popover);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport ListContext from './ListContext';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n listStyle: 'none',\n margin: 0,\n padding: 0,\n position: 'relative'\n },\n\n /* Styles applied to the root element if `disablePadding={false}`. */\n padding: {\n paddingTop: 8,\n paddingBottom: 8\n },\n\n /* Styles applied to the root element if dense. */\n dense: {},\n\n /* Styles applied to the root element if a `subheader` is provided. */\n subheader: {\n paddingTop: 0\n }\n};\nvar List = React.forwardRef(function List(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'ul' : _props$component,\n _props$dense = props.dense,\n dense = _props$dense === void 0 ? false : _props$dense,\n _props$disablePadding = props.disablePadding,\n disablePadding = _props$disablePadding === void 0 ? false : _props$disablePadding,\n subheader = props.subheader,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"component\", \"dense\", \"disablePadding\", \"subheader\"]);\n\n var context = React.useMemo(function () {\n return {\n dense: dense\n };\n }, [dense]);\n return React.createElement(ListContext.Provider, {\n value: context\n }, React.createElement(Component, _extends({\n className: clsx(classes.root, className, dense && classes.dense, !disablePadding && classes.padding, subheader && classes.subheader),\n ref: ref\n }, other), subheader, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? List.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, compact vertical padding designed for keyboard and mouse input will be used for\n * the list and list items.\n * The prop is available to descendant components as the `dense` context.\n */\n dense: PropTypes.bool,\n\n /**\n * If `true`, vertical padding will be removed from the list.\n */\n disablePadding: PropTypes.bool,\n\n /**\n * The content of the subheader, normally `ListSubheader`.\n */\n subheader: PropTypes.node\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiList'\n})(List);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport ownerDocument from '../utils/ownerDocument';\nimport List from '../List';\nimport getScrollbarSize from '../utils/getScrollbarSize';\nimport useForkRef from '../utils/useForkRef';\n\nfunction nextItem(list, item, disableListWrap) {\n if (list === item) {\n return list.firstChild;\n }\n\n if (item && item.nextElementSibling) {\n return item.nextElementSibling;\n }\n\n return disableListWrap ? null : list.firstChild;\n}\n\nfunction previousItem(list, item, disableListWrap) {\n if (list === item) {\n return disableListWrap ? list.firstChild : list.lastChild;\n }\n\n if (item && item.previousElementSibling) {\n return item.previousElementSibling;\n }\n\n return disableListWrap ? null : list.lastChild;\n}\n\nfunction textCriteriaMatches(nextFocus, textCriteria) {\n if (textCriteria === undefined) {\n return true;\n }\n\n var text = nextFocus.innerText;\n\n if (text === undefined) {\n // jsdom doesn't support innerText\n text = nextFocus.textContent;\n }\n\n text = text.trim().toLowerCase();\n\n if (text.length === 0) {\n return false;\n }\n\n if (textCriteria.repeating) {\n return text[0] === textCriteria.keys[0];\n }\n\n return text.indexOf(textCriteria.keys.join('')) === 0;\n}\n\nfunction moveFocus(list, currentFocus, disableListWrap, traversalFunction, textCriteria) {\n var wrappedOnce = false;\n var nextFocus = traversalFunction(list, currentFocus, currentFocus ? disableListWrap : false);\n\n while (nextFocus) {\n // Prevent infinite loop.\n if (nextFocus === list.firstChild) {\n if (wrappedOnce) {\n return false;\n }\n\n wrappedOnce = true;\n } // Move to the next element.\n\n\n if (!nextFocus.hasAttribute('tabindex') || nextFocus.disabled || nextFocus.getAttribute('aria-disabled') === 'true' || !textCriteriaMatches(nextFocus, textCriteria)) {\n nextFocus = traversalFunction(list, nextFocus, disableListWrap);\n } else {\n nextFocus.focus();\n return true;\n }\n }\n\n return false;\n}\n\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * A permanently displayed menu following https://www.w3.org/TR/wai-aria-practices/#menubutton\n * It's exposed to help customization of the [`Menu`](/api/menu/) component. If you\n * use it separately you need to move focus into the component manually. Once\n * the focus is placed inside the component it is fully keyboard accessible.\n */\n\nvar MenuList = React.forwardRef(function MenuList(props, ref) {\n var actions = props.actions,\n _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n _props$autoFocusItem = props.autoFocusItem,\n autoFocusItem = _props$autoFocusItem === void 0 ? false : _props$autoFocusItem,\n children = props.children,\n className = props.className,\n onKeyDown = props.onKeyDown,\n _props$disableListWra = props.disableListWrap,\n disableListWrap = _props$disableListWra === void 0 ? false : _props$disableListWra,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'selectedMenu' : _props$variant,\n other = _objectWithoutProperties(props, [\"actions\", \"autoFocus\", \"autoFocusItem\", \"children\", \"className\", \"onKeyDown\", \"disableListWrap\", \"variant\"]);\n\n var listRef = React.useRef(null);\n var textCriteriaRef = React.useRef({\n keys: [],\n repeating: true,\n previousKeyMatched: true,\n lastTime: null\n });\n useEnhancedEffect(function () {\n if (autoFocus) {\n listRef.current.focus();\n }\n }, [autoFocus]);\n React.useImperativeHandle(actions, function () {\n return {\n adjustStyleForScrollbar: function adjustStyleForScrollbar(containerElement, theme) {\n // Let's ignore that piece of logic if users are already overriding the width\n // of the menu.\n var noExplicitWidth = !listRef.current.style.width;\n\n if (containerElement.clientHeight < listRef.current.clientHeight && noExplicitWidth) {\n var scrollbarSize = \"\".concat(getScrollbarSize(true), \"px\");\n listRef.current.style[theme.direction === 'rtl' ? 'paddingLeft' : 'paddingRight'] = scrollbarSize;\n listRef.current.style.width = \"calc(100% + \".concat(scrollbarSize, \")\");\n }\n\n return listRef.current;\n }\n };\n }, []);\n\n var handleKeyDown = function handleKeyDown(event) {\n var list = listRef.current;\n var key = event.key;\n /**\n * @type {Element} - will always be defined since we are in a keydown handler\n * attached to an element. A keydown event is either dispatched to the activeElement\n * or document.body or document.documentElement. Only the first case will\n * trigger this specific handler.\n */\n\n var currentFocus = ownerDocument(list).activeElement;\n\n if (key === 'ArrowDown') {\n // Prevent scroll of the page\n event.preventDefault();\n moveFocus(list, currentFocus, disableListWrap, nextItem);\n } else if (key === 'ArrowUp') {\n event.preventDefault();\n moveFocus(list, currentFocus, disableListWrap, previousItem);\n } else if (key === 'Home') {\n event.preventDefault();\n moveFocus(list, null, disableListWrap, nextItem);\n } else if (key === 'End') {\n event.preventDefault();\n moveFocus(list, null, disableListWrap, previousItem);\n } else if (key.length === 1) {\n var criteria = textCriteriaRef.current;\n var lowerKey = key.toLowerCase();\n var currTime = performance.now();\n\n if (criteria.keys.length > 0) {\n // Reset\n if (currTime - criteria.lastTime > 500) {\n criteria.keys = [];\n criteria.repeating = true;\n criteria.previousKeyMatched = true;\n } else if (criteria.repeating && lowerKey !== criteria.keys[0]) {\n criteria.repeating = false;\n }\n }\n\n criteria.lastTime = currTime;\n criteria.keys.push(lowerKey);\n var keepFocusOnCurrent = currentFocus && !criteria.repeating && textCriteriaMatches(currentFocus, criteria);\n\n if (criteria.previousKeyMatched && (keepFocusOnCurrent || moveFocus(list, currentFocus, false, nextItem, criteria))) {\n event.preventDefault();\n } else {\n criteria.previousKeyMatched = false;\n }\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n };\n\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n listRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n var handleRef = useForkRef(handleOwnRef, ref);\n /**\n * the index of the item should receive focus\n * in a `variant=\"selectedMenu\"` it's the first `selected` item\n * otherwise it's the very first item.\n */\n\n var activeItemIndex = -1; // since we inject focus related props into children we have to do a lookahead\n // to check if there is a `selected` item. We're looking for the last `selected`\n // item and use the first valid item as a fallback\n\n React.Children.forEach(children, function (child, index) {\n if (!React.isValidElement(child)) {\n return;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: the Menu component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n if (!child.props.disabled) {\n if (variant === 'selectedMenu' && child.props.selected) {\n activeItemIndex = index;\n } else if (activeItemIndex === -1) {\n activeItemIndex = index;\n }\n }\n });\n var items = React.Children.map(children, function (child, index) {\n if (index === activeItemIndex) {\n var newChildProps = {};\n\n if (autoFocusItem) {\n newChildProps.autoFocus = true;\n }\n\n if (child.props.tabIndex === undefined && variant === 'selectedMenu') {\n newChildProps.tabIndex = 0;\n }\n\n if (newChildProps !== null) {\n return React.cloneElement(child, newChildProps);\n }\n }\n\n return child;\n });\n return React.createElement(List, _extends({\n role: \"menu\",\n ref: handleRef,\n className: className,\n onKeyDown: handleKeyDown,\n tabIndex: autoFocus ? 0 : -1\n }, other), items);\n});\nprocess.env.NODE_ENV !== \"production\" ? MenuList.propTypes = {\n /**\n * @ignore\n */\n actions: PropTypes.shape({\n current: PropTypes.object\n }),\n\n /**\n * If `true`, will focus the `[role=\"menu\"]` container and move into tab order\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, will focus the first menuitem if `variant=\"menu\"` or selected item\n * if `variant=\"selectedMenu\"`\n */\n autoFocusItem: PropTypes.bool,\n\n /**\n * MenuList contents, normally `MenuItem`s.\n */\n children: PropTypes.node,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the menu items will not wrap focus.\n */\n disableListWrap: PropTypes.bool,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * The variant to use. Use `menu` to prevent selected items from impacting the initial focus\n * and the vertical alignment relative to the anchor element.\n */\n variant: PropTypes.oneOf(['menu', 'selectedMenu'])\n} : void 0;\nexport default MenuList;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Popover from '../Popover';\nimport MenuList from '../MenuList';\nimport ReactDOM from 'react-dom';\nimport setRef from '../utils/setRef';\nimport useTheme from '../styles/useTheme';\nvar RTL_ORIGIN = {\n vertical: 'top',\n horizontal: 'right'\n};\nvar LTR_ORIGIN = {\n vertical: 'top',\n horizontal: 'left'\n};\nexport var styles = {\n /* Styles applied to the `Paper` component. */\n paper: {\n // specZ: The maximum height of a simple menu should be one or more rows less than the view\n // height. This ensures a tapable area outside of the simple menu with which to dismiss\n // the menu.\n maxHeight: 'calc(100% - 96px)',\n // Add iOS momentum scrolling.\n WebkitOverflowScrolling: 'touch'\n },\n\n /* Styles applied to the `List` component via `MenuList`. */\n list: {\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0\n }\n};\nvar Menu = React.forwardRef(function Menu(props, ref) {\n var _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? true : _props$autoFocus,\n children = props.children,\n classes = props.classes,\n _props$disableAutoFoc = props.disableAutoFocusItem,\n disableAutoFocusItem = _props$disableAutoFoc === void 0 ? false : _props$disableAutoFoc,\n _props$MenuListProps = props.MenuListProps,\n MenuListProps = _props$MenuListProps === void 0 ? {} : _props$MenuListProps,\n onClose = props.onClose,\n onEntering = props.onEntering,\n open = props.open,\n _props$PaperProps = props.PaperProps,\n PaperProps = _props$PaperProps === void 0 ? {} : _props$PaperProps,\n PopoverClasses = props.PopoverClasses,\n _props$transitionDura = props.transitionDuration,\n transitionDuration = _props$transitionDura === void 0 ? 'auto' : _props$transitionDura,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'selectedMenu' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoFocus\", \"children\", \"classes\", \"disableAutoFocusItem\", \"MenuListProps\", \"onClose\", \"onEntering\", \"open\", \"PaperProps\", \"PopoverClasses\", \"transitionDuration\", \"variant\"]);\n\n var theme = useTheme();\n var autoFocusItem = autoFocus && !disableAutoFocusItem && open;\n var menuListActionsRef = React.useRef(null);\n var contentAnchorRef = React.useRef(null);\n\n var getContentAnchorEl = function getContentAnchorEl() {\n return contentAnchorRef.current;\n };\n\n var handleEntering = function handleEntering(element, isAppearing) {\n if (menuListActionsRef.current) {\n menuListActionsRef.current.adjustStyleForScrollbar(element, theme);\n }\n\n if (onEntering) {\n onEntering(element, isAppearing);\n }\n };\n\n var handleListKeyDown = function handleListKeyDown(event) {\n if (event.key === 'Tab') {\n event.preventDefault();\n\n if (onClose) {\n onClose(event, 'tabKeyDown');\n }\n }\n };\n /**\n * the index of the item should receive focus\n * in a `variant=\"selectedMenu\"` it's the first `selected` item\n * otherwise it's the very first item.\n */\n\n\n var activeItemIndex = -1; // since we inject focus related props into children we have to do a lookahead\n // to check if there is a `selected` item. We're looking for the last `selected`\n // item and use the first valid item as a fallback\n\n React.Children.map(children, function (child, index) {\n if (!React.isValidElement(child)) {\n return;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: the Menu component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n if (!child.props.disabled) {\n if (variant !== \"menu\" && child.props.selected) {\n activeItemIndex = index;\n } else if (activeItemIndex === -1) {\n activeItemIndex = index;\n }\n }\n });\n var items = React.Children.map(children, function (child, index) {\n if (index === activeItemIndex) {\n return React.cloneElement(child, {\n ref: function ref(instance) {\n // #StrictMode ready\n contentAnchorRef.current = ReactDOM.findDOMNode(instance);\n setRef(child.ref, instance);\n }\n });\n }\n\n return child;\n });\n return React.createElement(Popover, _extends({\n getContentAnchorEl: getContentAnchorEl,\n classes: PopoverClasses,\n onClose: onClose,\n onEntering: handleEntering,\n anchorOrigin: theme.direction === 'rtl' ? RTL_ORIGIN : LTR_ORIGIN,\n transformOrigin: theme.direction === 'rtl' ? RTL_ORIGIN : LTR_ORIGIN,\n PaperProps: _extends({}, PaperProps, {\n classes: _extends({}, PaperProps.classes, {\n root: classes.paper\n })\n }),\n open: open,\n ref: ref,\n transitionDuration: transitionDuration\n }, other), React.createElement(MenuList, _extends({\n onKeyDown: handleListKeyDown,\n actions: menuListActionsRef,\n autoFocus: autoFocus && (activeItemIndex === -1 || disableAutoFocusItem),\n autoFocusItem: autoFocusItem,\n variant: variant\n }, MenuListProps, {\n className: clsx(classes.list, MenuListProps.className)\n }), items));\n});\nprocess.env.NODE_ENV !== \"production\" ? Menu.propTypes = {\n /**\n * The DOM element used to set the position of the menu.\n */\n anchorEl: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n /**\n * If `true` (Default) will focus the `[role=\"menu\"]` if no focusable child is found. Disabled\n * children are not focusable. If you set this prop to `false` focus will be placed\n * on the parent modal container. This has severe accessibility implications\n * and should only be considered if you manage focus otherwise.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Menu contents, normally `MenuItem`s.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * When opening the menu will not focus the active item but the `[role=\"menu\"]`\n * unless `autoFocus` is also set to `false`. Not using the default means not\n * following WAI-ARIA authoring practices. Please be considerate about possible\n * accessibility implications.\n */\n disableAutoFocusItem: PropTypes.bool,\n\n /**\n * Props applied to the [`MenuList`](/api/menu-list/) element.\n */\n MenuListProps: PropTypes.object,\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`, `\"tabKeyDown\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired before the Menu enters.\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired when the Menu has entered.\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired when the Menu is entering.\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired before the Menu exits.\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired when the Menu has exited.\n */\n onExited: PropTypes.func,\n\n /**\n * Callback fired when the Menu is exiting.\n */\n onExiting: PropTypes.func,\n\n /**\n * If `true`, the menu is visible.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * @ignore\n */\n PaperProps: PropTypes.object,\n\n /**\n * `classes` prop applied to the [`Popover`](/api/popover/) element.\n */\n PopoverClasses: PropTypes.object,\n\n /**\n * The length of the transition in `ms`, or 'auto'\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n enter: PropTypes.number,\n exit: PropTypes.number\n }), PropTypes.oneOf(['auto'])]),\n\n /**\n * The variant to use. Use `menu` to prevent selected items from impacting the initial focus\n * and the vertical alignment relative to the anchor element.\n */\n variant: PropTypes.oneOf(['menu', 'selectedMenu'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiMenu'\n})(Menu);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _toConsumableArray from \"@babel/runtime/helpers/esm/toConsumableArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _typeof from \"@babel/runtime/helpers/esm/typeof\";\nimport React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport capitalize from '../utils/capitalize';\nimport { refType } from '@material-ui/utils';\nimport Menu from '../Menu/Menu';\nimport { isFilled } from '../InputBase/utils';\nimport useForkRef from '../utils/useForkRef';\n\nfunction areEqualValues(a, b) {\n if (_typeof(b) === 'object' && b !== null) {\n return a === b;\n }\n\n return String(a) === String(b);\n}\n\nfunction isEmpty(display) {\n return display == null || typeof display === 'string' && !display.trim();\n}\n/**\n * @ignore - internal component.\n */\n\n\nvar SelectInput = React.forwardRef(function SelectInput(props, ref) {\n var autoFocus = props.autoFocus,\n autoWidth = props.autoWidth,\n children = props.children,\n classes = props.classes,\n className = props.className,\n defaultValue = props.defaultValue,\n disabled = props.disabled,\n displayEmpty = props.displayEmpty,\n IconComponent = props.IconComponent,\n inputRefProp = props.inputRef,\n labelId = props.labelId,\n _props$MenuProps = props.MenuProps,\n MenuProps = _props$MenuProps === void 0 ? {} : _props$MenuProps,\n multiple = props.multiple,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onClose = props.onClose,\n onFocus = props.onFocus,\n onOpen = props.onOpen,\n openProp = props.open,\n readOnly = props.readOnly,\n renderValue = props.renderValue,\n required = props.required,\n _props$SelectDisplayP = props.SelectDisplayProps,\n SelectDisplayProps = _props$SelectDisplayP === void 0 ? {} : _props$SelectDisplayP,\n tabIndexProp = props.tabIndex,\n type = props.type,\n valueProp = props.value,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoFocus\", \"autoWidth\", \"children\", \"classes\", \"className\", \"defaultValue\", \"disabled\", \"displayEmpty\", \"IconComponent\", \"inputRef\", \"labelId\", \"MenuProps\", \"multiple\", \"name\", \"onBlur\", \"onChange\", \"onClose\", \"onFocus\", \"onOpen\", \"open\", \"readOnly\", \"renderValue\", \"required\", \"SelectDisplayProps\", \"tabIndex\", \"type\", \"value\", \"variant\"]);\n\n var _React$useRef = React.useRef(valueProp != null),\n isControlled = _React$useRef.current;\n\n var _React$useState = React.useState(defaultValue),\n valueState = _React$useState[0],\n setValueState = _React$useState[1];\n\n var value = isControlled ? valueProp : valueState;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (isControlled !== (valueProp != null)) {\n console.error([\"Material-UI: A component is changing \".concat(isControlled ? 'a ' : 'an un', \"controlled Select to be \").concat(isControlled ? 'un' : '', \"controlled.\"), 'Elements should not switch from uncontrolled to controlled (or vice versa).', 'Decide between using a controlled or uncontrolled Select ' + 'element for the lifetime of the component.', 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [valueProp, isControlled]);\n }\n\n var inputRef = React.useRef(null);\n\n var _React$useState2 = React.useState(null),\n displayNode = _React$useState2[0],\n setDisplayNode = _React$useState2[1];\n\n var _React$useRef2 = React.useRef(openProp != null),\n isOpenControlled = _React$useRef2.current;\n\n var _React$useState3 = React.useState(),\n menuMinWidthState = _React$useState3[0],\n setMenuMinWidthState = _React$useState3[1];\n\n var _React$useState4 = React.useState(false),\n openState = _React$useState4[0],\n setOpenState = _React$useState4[1];\n\n var handleRef = useForkRef(ref, inputRefProp);\n React.useImperativeHandle(handleRef, function () {\n return {\n focus: function focus() {\n displayNode.focus();\n },\n node: inputRef.current,\n value: value\n };\n }, [displayNode, value]);\n React.useEffect(function () {\n if (autoFocus && displayNode) {\n displayNode.focus();\n }\n }, [autoFocus, displayNode]);\n\n var update = function update(open, event) {\n if (open) {\n if (onOpen) {\n onOpen(event);\n }\n } else if (onClose) {\n onClose(event);\n }\n\n if (!isOpenControlled) {\n setMenuMinWidthState(autoWidth ? null : displayNode.clientWidth);\n setOpenState(open);\n }\n };\n\n var handleMouseDown = function handleMouseDown(event) {\n // Hijack the default focus behavior.\n event.preventDefault();\n displayNode.focus();\n update(true, event);\n };\n\n var handleClose = function handleClose(event) {\n update(false, event);\n };\n\n var handleItemClick = function handleItemClick(child) {\n return function (event) {\n if (!multiple) {\n update(false, event);\n }\n\n var newValue;\n\n if (multiple) {\n newValue = Array.isArray(value) ? _toConsumableArray(value) : [];\n var itemIndex = value.indexOf(child.props.value);\n\n if (itemIndex === -1) {\n newValue.push(child.props.value);\n } else {\n newValue.splice(itemIndex, 1);\n }\n } else {\n newValue = child.props.value;\n }\n\n if (!isControlled) {\n setValueState(newValue);\n }\n\n if (onChange) {\n event.persist(); // Preact support, target is read only property on a native event.\n\n Object.defineProperty(event, 'target', {\n writable: true,\n value: {\n value: newValue,\n name: name\n }\n });\n onChange(event, child);\n }\n };\n };\n\n var handleKeyDown = function handleKeyDown(event) {\n if (!readOnly) {\n var validKeys = [' ', 'ArrowUp', 'ArrowDown', // The native select doesn't respond to enter on MacOS, but it's recommended by\n // https://www.w3.org/TR/wai-aria-practices/examples/listbox/listbox-collapsible.html\n 'Enter'];\n\n if (validKeys.indexOf(event.key) !== -1) {\n event.preventDefault();\n update(true, event);\n }\n }\n };\n\n var open = displayNode !== null && (isOpenControlled ? openProp : openState);\n\n var handleBlur = function handleBlur(event) {\n // if open event.stopImmediatePropagation\n if (!open && onBlur) {\n event.persist(); // Preact support, target is read only property on a native event.\n\n Object.defineProperty(event, 'target', {\n writable: true,\n value: {\n value: value,\n name: name\n }\n });\n onBlur(event);\n }\n };\n\n delete other['aria-invalid'];\n var display;\n var displaySingle;\n var displayMultiple = [];\n var computeDisplay = false;\n var foundMatch = false; // No need to display any value if the field is empty.\n\n if (isFilled({\n value: value\n }) || displayEmpty) {\n if (renderValue) {\n display = renderValue(value);\n } else {\n computeDisplay = true;\n }\n }\n\n var items = React.Children.map(children, function (child) {\n if (!React.isValidElement(child)) {\n return null;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: the Select component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n var selected;\n\n if (multiple) {\n if (!Array.isArray(value)) {\n throw new Error('Material-UI: the `value` prop must be an array ' + 'when using the `Select` component with `multiple`.');\n }\n\n selected = value.some(function (v) {\n return areEqualValues(v, child.props.value);\n });\n\n if (selected && computeDisplay) {\n displayMultiple.push(child.props.children);\n }\n } else {\n selected = areEqualValues(value, child.props.value);\n\n if (selected && computeDisplay) {\n displaySingle = child.props.children;\n }\n }\n\n if (selected) {\n foundMatch = true;\n }\n\n return React.cloneElement(child, {\n 'aria-selected': selected ? 'true' : undefined,\n onClick: handleItemClick(child),\n onKeyUp: function onKeyUp(event) {\n if (event.key === ' ') {\n // otherwise our MenuItems dispatches a click event\n // it's not behavior of the native <option> and causes\n // the select to close immediately since we open on space keydown\n event.preventDefault();\n }\n\n var onKeyUp = child.props.onKeyUp;\n\n if (typeof onKeyUp === 'function') {\n onKeyUp(event);\n }\n },\n role: 'option',\n selected: selected,\n value: undefined,\n // The value is most likely not a valid HTML attribute.\n 'data-value': child.props.value // Instead, we provide it as a data attribute.\n\n });\n });\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (!foundMatch && !multiple && value !== '') {\n var values = React.Children.toArray(children).map(function (child) {\n return child.props.value;\n });\n console.warn([\"Material-UI: you have provided an out-of-range value `\".concat(value, \"` for the select \").concat(name ? \"(name=\\\"\".concat(name, \"\\\") \") : '', \"component.\"), \"Consider providing a value that matches one of the available options or ''.\", \"The available values are \".concat(values.filter(function (x) {\n return x != null;\n }).map(function (x) {\n return \"`\".concat(x, \"`\");\n }).join(', ') || '\"\"', \".\")].join('\\n'));\n }\n }, [foundMatch, children, multiple, name, value]);\n }\n\n if (computeDisplay) {\n display = multiple ? displayMultiple.join(', ') : displaySingle;\n } // Avoid performing a layout computation in the render method.\n\n\n var menuMinWidth = menuMinWidthState;\n\n if (!autoWidth && isOpenControlled && displayNode) {\n menuMinWidth = displayNode.clientWidth;\n }\n\n var tabIndex;\n\n if (typeof tabIndexProp !== 'undefined') {\n tabIndex = tabIndexProp;\n } else {\n tabIndex = disabled ? null : 0;\n }\n\n var buttonId = SelectDisplayProps.id || (name ? \"mui-component-select-\".concat(name) : undefined);\n return React.createElement(React.Fragment, null, React.createElement(\"div\", _extends({\n className: clsx(classes.root, // TODO v5: merge root and select\n classes.select, classes.selectMenu, classes[variant], className, disabled && classes.disabled),\n ref: setDisplayNode,\n tabIndex: tabIndex,\n role: \"button\",\n \"aria-expanded\": open ? 'true' : undefined,\n \"aria-labelledby\": \"\".concat(labelId || '', \" \").concat(buttonId || ''),\n \"aria-haspopup\": \"listbox\",\n onKeyDown: handleKeyDown,\n onMouseDown: disabled || readOnly ? null : handleMouseDown,\n onBlur: handleBlur,\n onFocus: onFocus\n }, SelectDisplayProps, {\n // The id is required for proper a11y\n id: buttonId\n }), isEmpty(display) ? // eslint-disable-next-line react/no-danger\n React.createElement(\"span\", {\n dangerouslySetInnerHTML: {\n __html: '​'\n }\n }) : display), React.createElement(\"input\", _extends({\n value: Array.isArray(value) ? value.join(',') : value,\n name: name,\n ref: inputRef,\n type: \"hidden\",\n autoFocus: autoFocus\n }, other)), React.createElement(IconComponent, {\n className: clsx(classes.icon, classes[\"icon\".concat(capitalize(variant))], open && classes.iconOpen)\n }), React.createElement(Menu, _extends({\n id: \"menu-\".concat(name || ''),\n anchorEl: displayNode,\n open: open,\n onClose: handleClose\n }, MenuProps, {\n MenuListProps: _extends({\n 'aria-labelledby': labelId,\n role: 'listbox',\n disableListWrap: true\n }, MenuProps.MenuListProps),\n PaperProps: _extends({}, MenuProps.PaperProps, {\n style: _extends({\n minWidth: menuMinWidth\n }, MenuProps.PaperProps != null ? MenuProps.PaperProps.style : null)\n })\n }), items));\n});\nprocess.env.NODE_ENV !== \"production\" ? SelectInput.propTypes = {\n /**\n * @ignore\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, the width of the popover will automatically be set according to the items inside the\n * menu, otherwise it will be at least the width of the select input.\n */\n autoWidth: PropTypes.bool,\n\n /**\n * The option elements to populate the select with.\n * Can be some `<MenuItem>` elements.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the select element.\n */\n className: PropTypes.string,\n\n /**\n * The default element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the select will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the selected item is displayed even if its value is empty.\n */\n displayEmpty: PropTypes.bool,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType.isRequired,\n\n /**\n * Imperative handle implementing `{ value: T, node: HTMLElement, focus(): void }`\n * Equivalent to `ref`\n */\n inputRef: refType,\n\n /**\n * The idea of an element that acts as an additional label. The Select will\n * be labelled by the additional label and the selected value.\n */\n labelId: PropTypes.string,\n\n /**\n * Props applied to the [`Menu`](/api/menu/) element.\n */\n MenuProps: PropTypes.object,\n\n /**\n * If `true`, `value` must be an array and the menu will support multiple selections.\n */\n multiple: PropTypes.bool,\n\n /**\n * Name attribute of the `select` or hidden `input` element.\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (any).\n * @param {object} [child] The react element that was selected.\n */\n onChange: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be closed.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onClose: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be opened.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onOpen: PropTypes.func,\n\n /**\n * Control `select` open state.\n */\n open: PropTypes.bool,\n\n /**\n * @ignore\n */\n readOnly: PropTypes.bool,\n\n /**\n * Render the selected value.\n *\n * @param {any} value The `value` provided to the component.\n * @returns {ReactNode}\n */\n renderValue: PropTypes.func,\n\n /**\n * @ignore\n */\n required: PropTypes.bool,\n\n /**\n * Props applied to the clickable div element.\n */\n SelectDisplayProps: PropTypes.object,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /**\n * @ignore\n */\n type: PropTypes.any,\n\n /**\n * The input value.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default SelectInput;","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M7 10l5 5 5-5z\"\n}), 'ArrowDropDown');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport capitalize from '../utils/capitalize';\n/**\n * @ignore - internal component.\n */\n\nvar NativeSelectInput = React.forwardRef(function NativeSelectInput(props, ref) {\n var classes = props.classes,\n className = props.className,\n disabled = props.disabled,\n IconComponent = props.IconComponent,\n inputRef = props.inputRef,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"disabled\", \"IconComponent\", \"inputRef\", \"variant\"]);\n\n return React.createElement(React.Fragment, null, React.createElement(\"select\", _extends({\n className: clsx(classes.root, // TODO v5: merge root and select\n classes.select, classes[variant], className, disabled && classes.disabled),\n disabled: disabled,\n ref: inputRef || ref\n }, other)), props.multiple ? null : React.createElement(IconComponent, {\n className: clsx(classes.icon, classes[\"icon\".concat(capitalize(variant))])\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? NativeSelectInput.propTypes = {\n /**\n * The option elements to populate the select with.\n * Can be some `<option>` elements.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the select element.\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the select will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType.isRequired,\n\n /**\n * Use that prop to pass a ref to the native select element.\n * @deprecated\n */\n inputRef: refType,\n\n /**\n * @ignore\n */\n multiple: PropTypes.bool,\n\n /**\n * Name attribute of the `select` or hidden `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The input value.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default NativeSelectInput;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport NativeSelectInput from './NativeSelectInput';\nimport withStyles from '../styles/withStyles';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport ArrowDropDownIcon from '../internal/svg-icons/ArrowDropDown';\nimport Input from '../Input';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the select component `root` class. */\n root: {},\n\n /* Styles applied to the select component `select` class. */\n select: {\n '-moz-appearance': 'none',\n // Reset\n '-webkit-appearance': 'none',\n // Reset\n // When interacting quickly, the text can end up selected.\n // Native select can't be selected either.\n userSelect: 'none',\n borderRadius: 0,\n // Reset\n minWidth: 16,\n // So it doesn't collapse.\n cursor: 'pointer',\n '&:focus': {\n // Show that it's not an text input\n backgroundColor: theme.palette.type === 'light' ? 'rgba(0, 0, 0, 0.05)' : 'rgba(255, 255, 255, 0.05)',\n borderRadius: 0 // Reset Chrome style\n\n },\n // Remove IE 11 arrow\n '&::-ms-expand': {\n display: 'none'\n },\n '&$disabled': {\n cursor: 'default'\n },\n '&[multiple]': {\n height: 'auto'\n },\n '&:not([multiple]) option, &:not([multiple]) optgroup': {\n backgroundColor: theme.palette.background.paper\n },\n '&&': {\n paddingRight: 24\n }\n },\n\n /* Styles applied to the select component if `variant=\"filled\"`. */\n filled: {\n '&&': {\n paddingRight: 32\n }\n },\n\n /* Styles applied to the select component if `variant=\"outlined\"`. */\n outlined: {\n borderRadius: theme.shape.borderRadius,\n '&&': {\n paddingRight: 32\n }\n },\n\n /* Styles applied to the select component `selectMenu` class. */\n selectMenu: {\n height: 'auto',\n // Reset\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n overflow: 'hidden'\n },\n\n /* Pseudo-class applied to the select component `disabled` class. */\n disabled: {},\n\n /* Styles applied to the icon component. */\n icon: {\n // We use a position absolute over a flexbox in order to forward the pointer events\n // to the input and to support wrapping tags..\n position: 'absolute',\n right: 0,\n top: 'calc(50% - 12px)',\n // Center vertically\n color: theme.palette.action.active,\n pointerEvents: 'none' // Don't block pointer events on the select under the icon.\n\n },\n\n /* Styles applied to the icon component if the popup is open. */\n iconOpen: {\n transform: 'rotate(180deg)'\n },\n\n /* Styles applied to the icon component if `variant=\"filled\"`. */\n iconFilled: {\n right: 7\n },\n\n /* Styles applied to the icon component if `variant=\"outlined\"`. */\n iconOutlined: {\n right: 7\n }\n };\n};\nvar defaultInput = React.createElement(Input, null);\n/**\n * An alternative to `<Select native />` with a much smaller bundle size footprint.\n */\n\nvar NativeSelect = React.forwardRef(function NativeSelect(props, ref) {\n var children = props.children,\n classes = props.classes,\n _props$IconComponent = props.IconComponent,\n IconComponent = _props$IconComponent === void 0 ? ArrowDropDownIcon : _props$IconComponent,\n _props$input = props.input,\n input = _props$input === void 0 ? defaultInput : _props$input,\n inputProps = props.inputProps,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"IconComponent\", \"input\", \"inputProps\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['variant']\n });\n return React.cloneElement(input, _extends({\n // Most of the logic is implemented in `NativeSelectInput`.\n // The `Select` component is a simple API wrapper to expose something better to play with.\n inputComponent: NativeSelectInput,\n inputProps: _extends({\n children: children,\n classes: classes,\n IconComponent: IconComponent,\n variant: fcs.variant,\n type: undefined\n }, inputProps, {}, input ? input.props.inputProps : {}),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? NativeSelect.propTypes = {\n /**\n * The option elements to populate the select with.\n * Can be some `<option>` elements.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType,\n\n /**\n * An `Input` element; does not have to be a material-ui specific `Input`.\n */\n input: PropTypes.element,\n\n /**\n * Attributes applied to the `select` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The input value. The DOM API casts this to a string.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nNativeSelect.muiName = 'Select';\nexport default withStyles(styles, {\n name: 'MuiNativeSelect'\n})(NativeSelect);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { mergeClasses } from '@material-ui/styles';\nimport SelectInput from './SelectInput';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nimport ArrowDropDownIcon from '../internal/svg-icons/ArrowDropDown';\nimport Input from '../Input';\nimport { styles as nativeSelectStyles } from '../NativeSelect/NativeSelect';\nimport NativeSelectInput from '../NativeSelect/NativeSelectInput';\nimport FilledInput from '../FilledInput';\nimport OutlinedInput from '../OutlinedInput';\nexport var styles = nativeSelectStyles;\n\nvar _ref = React.createElement(Input, null);\n\nvar _ref2 = React.createElement(FilledInput, null);\n\nvar Select = React.forwardRef(function Select(props, ref) {\n var _props$autoWidth = props.autoWidth,\n autoWidth = _props$autoWidth === void 0 ? false : _props$autoWidth,\n children = props.children,\n classes = props.classes,\n _props$displayEmpty = props.displayEmpty,\n displayEmpty = _props$displayEmpty === void 0 ? false : _props$displayEmpty,\n _props$IconComponent = props.IconComponent,\n IconComponent = _props$IconComponent === void 0 ? ArrowDropDownIcon : _props$IconComponent,\n id = props.id,\n input = props.input,\n inputProps = props.inputProps,\n labelId = props.labelId,\n _props$labelWidth = props.labelWidth,\n labelWidth = _props$labelWidth === void 0 ? 0 : _props$labelWidth,\n MenuProps = props.MenuProps,\n _props$multiple = props.multiple,\n multiple = _props$multiple === void 0 ? false : _props$multiple,\n _props$native = props.native,\n native = _props$native === void 0 ? false : _props$native,\n onClose = props.onClose,\n onOpen = props.onOpen,\n open = props.open,\n renderValue = props.renderValue,\n SelectDisplayProps = props.SelectDisplayProps,\n _props$variant = props.variant,\n variantProps = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoWidth\", \"children\", \"classes\", \"displayEmpty\", \"IconComponent\", \"id\", \"input\", \"inputProps\", \"labelId\", \"labelWidth\", \"MenuProps\", \"multiple\", \"native\", \"onClose\", \"onOpen\", \"open\", \"renderValue\", \"SelectDisplayProps\", \"variant\"]);\n\n var inputComponent = native ? NativeSelectInput : SelectInput;\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['variant']\n });\n var variant = fcs.variant || variantProps;\n var InputComponent = input || {\n standard: _ref,\n outlined: React.createElement(OutlinedInput, {\n labelWidth: labelWidth\n }),\n filled: _ref2\n }[variant];\n return React.cloneElement(InputComponent, _extends({\n // Most of the logic is implemented in `SelectInput`.\n // The `Select` component is a simple API wrapper to expose something better to play with.\n inputComponent: inputComponent,\n inputProps: _extends({\n children: children,\n IconComponent: IconComponent,\n variant: variant,\n type: undefined,\n // We render a select. We can ignore the type provided by the `Input`.\n multiple: multiple\n }, native ? {\n id: id\n } : {\n autoWidth: autoWidth,\n displayEmpty: displayEmpty,\n labelId: labelId,\n MenuProps: MenuProps,\n onClose: onClose,\n onOpen: onOpen,\n open: open,\n renderValue: renderValue,\n SelectDisplayProps: _extends({\n id: id\n }, SelectDisplayProps)\n }, {}, inputProps, {\n classes: inputProps ? mergeClasses({\n baseClasses: classes,\n newClasses: inputProps.classes,\n Component: Select\n }) : classes\n }, input ? input.props.inputProps : {}),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Select.propTypes = {\n /**\n * If `true`, the width of the popover will automatically be set according to the items inside the\n * menu, otherwise it will be at least the width of the select input.\n */\n autoWidth: PropTypes.bool,\n\n /**\n * The option elements to populate the select with.\n * Can be some `MenuItem` when `native` is false and `option` when `native` is true.\n *\n * âš ï¸The `MenuItem` elements **must** be direct descendants when `native` is false.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The default element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, a value is displayed even if no items are selected.\n *\n * In order to display a meaningful value, a function should be passed to the `renderValue` prop which returns the value to be displayed when no items are selected.\n * You can only use it when the `native` prop is `false` (default).\n */\n displayEmpty: PropTypes.bool,\n\n /**\n * The icon that displays the arrow.\n */\n IconComponent: PropTypes.elementType,\n\n /**\n * @ignore\n */\n id: PropTypes.string,\n\n /**\n * An `Input` element; does not have to be a material-ui specific `Input`.\n */\n input: PropTypes.element,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n * When `native` is `true`, the attributes are applied on the `select` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * The idea of an element that acts as an additional label. The Select will\n * be labelled by the additional label and the selected value.\n */\n labelId: PropTypes.string,\n\n /**\n * The label width to be used on OutlinedInput.\n * This prop is required when the `variant` prop is `outlined`.\n */\n labelWidth: PropTypes.number,\n\n /**\n * Props applied to the [`Menu`](/api/menu/) element.\n */\n MenuProps: PropTypes.object,\n\n /**\n * If `true`, `value` must be an array and the menu will support multiple selections.\n */\n multiple: PropTypes.bool,\n\n /**\n * If `true`, the component will be using a native `select` element.\n */\n native: PropTypes.bool,\n\n /**\n * Callback function fired when a menu item is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (any).\n * @param {object} [child] The react element that was selected when `native` is `false` (default).\n */\n onChange: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be closed.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be opened.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onOpen: PropTypes.func,\n\n /**\n * Control `select` open state.\n * You can only use it when the `native` prop is `false` (default).\n */\n open: PropTypes.bool,\n\n /**\n * Render the selected value.\n * You can only use it when the `native` prop is `false` (default).\n *\n * @param {any} value The `value` provided to the component.\n * @returns {ReactNode}\n */\n renderValue: PropTypes.func,\n\n /**\n * Props applied to the clickable div element.\n */\n SelectDisplayProps: PropTypes.object,\n\n /**\n * The input value. Providing an empty string will select no options.\n * This prop is required when the `native` prop is `false` (default).\n * Set to an empty string `''` if you don't want any of the available options to be selected.\n *\n * If the value is an object it must have reference equality with the option in order to be selected.\n * If the value is not an object, the string representation must match with the string representation of the option in order to be selected.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nSelect.muiName = 'Select';\nexport default withStyles(styles, {\n name: 'MuiSelect'\n})(Select);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport capitalize from '../utils/capitalize';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({\n color: theme.palette.text.secondary\n }, theme.typography.body1, {\n lineHeight: 1,\n padding: 0,\n '&$focused': {\n color: theme.palette.primary.main\n },\n '&$disabled': {\n color: theme.palette.text.disabled\n },\n '&$error': {\n color: theme.palette.error.main\n }\n }),\n\n /* Styles applied to the root element if the color is secondary. */\n colorSecondary: {\n '&$focused': {\n color: theme.palette.secondary.main\n }\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `filled={true}`. */\n filled: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {},\n\n /* Styles applied to the asterisk element. */\n asterisk: {\n '&$error': {\n color: theme.palette.error.main\n }\n }\n };\n};\nvar FormLabel = React.forwardRef(function FormLabel(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n color = props.color,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'label' : _props$component,\n disabled = props.disabled,\n error = props.error,\n filled = props.filled,\n focused = props.focused,\n required = props.required,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"disabled\", \"error\", \"filled\", \"focused\", \"required\"]);\n\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['color', 'required', 'focused', 'disabled', 'error', 'filled']\n });\n return React.createElement(Component, _extends({\n className: clsx(classes.root, classes[\"color\".concat(capitalize(fcs.color || 'primary'))], className, fcs.disabled && classes.disabled, fcs.error && classes.error, fcs.filled && classes.filled, fcs.focused && classes.focused, fcs.required && classes.required),\n ref: ref\n }, other), children, fcs.required && React.createElement(\"span\", {\n className: clsx(classes.asterisk, fcs.error && classes.error)\n }, \"\\u2009\", '*'));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormLabel.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the label should be displayed in a disabled state.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label should be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the label should use filled classes key.\n */\n filled: PropTypes.bool,\n\n /**\n * If `true`, the input of this label is focused (used by `FormGroup` components).\n */\n focused: PropTypes.bool,\n\n /**\n * If `true`, the label will indicate that the input is required.\n */\n required: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormLabel'\n})(FormLabel);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nimport FormLabel from '../FormLabel';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'block',\n transformOrigin: 'top left'\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {},\n\n /* Pseudo-class applied to the asterisk element. */\n asterisk: {},\n\n /* Styles applied to the root element if the component is a descendant of `FormControl`. */\n formControl: {\n position: 'absolute',\n left: 0,\n top: 0,\n // slight alteration to spec spacing to match visual spec result\n transform: 'translate(0, 24px) scale(1)'\n },\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n // Compensation for the `Input.inputDense` style.\n transform: 'translate(0, 21px) scale(1)'\n },\n\n /* Styles applied to the `input` element if `shrink={true}`. */\n shrink: {\n transform: 'translate(0, 1.5px) scale(0.75)',\n transformOrigin: 'top left'\n },\n\n /* Styles applied to the `input` element if `disableAnimation={false}`. */\n animated: {\n transition: theme.transitions.create(['color', 'transform'], {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n })\n },\n\n /* Styles applied to the root element if `variant=\"filled\"`. */\n filled: {\n // Chrome's autofill feature gives the input field a yellow background.\n // Since the input field is behind the label in the HTML tree,\n // the input field is drawn last and hides the label with an opaque background color.\n // zIndex: 1 will raise the label above opaque background-colors of input.\n zIndex: 1,\n pointerEvents: 'none',\n transform: 'translate(12px, 20px) scale(1)',\n '&$marginDense': {\n transform: 'translate(12px, 17px) scale(1)'\n },\n '&$shrink': {\n transform: 'translate(12px, 10px) scale(0.75)',\n '&$marginDense': {\n transform: 'translate(12px, 7px) scale(0.75)'\n }\n }\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"`. */\n outlined: {\n // see comment above on filled.zIndex\n zIndex: 1,\n pointerEvents: 'none',\n transform: 'translate(14px, 20px) scale(1)',\n '&$marginDense': {\n transform: 'translate(14px, 12px) scale(1)'\n },\n '&$shrink': {\n transform: 'translate(14px, -6px) scale(0.75)'\n }\n }\n };\n};\nvar InputLabel = React.forwardRef(function InputLabel(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$disableAnimati = props.disableAnimation,\n disableAnimation = _props$disableAnimati === void 0 ? false : _props$disableAnimati,\n margin = props.margin,\n shrinkProp = props.shrink,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"disableAnimation\", \"margin\", \"shrink\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var shrink = shrinkProp;\n\n if (typeof shrink === 'undefined' && muiFormControl) {\n shrink = muiFormControl.filled || muiFormControl.focused || muiFormControl.adornedStart;\n }\n\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['margin', 'variant']\n });\n return React.createElement(FormLabel, _extends({\n \"data-shrink\": shrink,\n className: clsx(classes.root, className, muiFormControl && classes.formControl, !disableAnimation && classes.animated, shrink && classes.shrink, {\n dense: classes.marginDense\n }[fcs.margin], {\n filled: classes.filled,\n outlined: classes.outlined\n }[fcs.variant]),\n classes: {\n focused: classes.focused,\n disabled: classes.disabled,\n error: classes.error,\n required: classes.required,\n asterisk: classes.asterisk\n },\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? InputLabel.propTypes = {\n /**\n * The contents of the `InputLabel`.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * If `true`, the transition animation is disabled.\n */\n disableAnimation: PropTypes.bool,\n\n /**\n * If `true`, apply disabled class.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label will be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input of this label is focused.\n */\n focused: PropTypes.bool,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense']),\n\n /**\n * if `true`, the label will indicate that the input is required.\n */\n required: PropTypes.bool,\n\n /**\n * If `true`, the label is shrunk.\n */\n shrink: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiInputLabel'\n})(InputLabel);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { isFilled, isAdornedStart } from '../InputBase/utils';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport isMuiElement from '../utils/isMuiElement';\nimport FormControlContext from './FormControlContext';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'inline-flex',\n flexDirection: 'column',\n position: 'relative',\n // Reset fieldset default style.\n minWidth: 0,\n padding: 0,\n margin: 0,\n border: 0,\n verticalAlign: 'top' // Fix alignment issue on Safari.\n\n },\n\n /* Styles applied to the root element if `margin=\"normal\"`. */\n marginNormal: {\n marginTop: 16,\n marginBottom: 8\n },\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n marginTop: 8,\n marginBottom: 4\n },\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {\n width: '100%'\n }\n};\n/**\n * Provides context such as filled/focused/error/required for form inputs.\n * Relying on the context provides high flexibility and ensures that the state always stays\n * consistent across the children of the `FormControl`.\n * This context is used by the following components:\n *\n * - FormLabel\n * - FormHelperText\n * - Input\n * - InputLabel\n *\n * You can find one composition example below and more going to [the demos](/components/text-fields/#components).\n *\n * ```jsx\n * <FormControl>\n * <InputLabel htmlFor=\"my-input\">Email address</InputLabel>\n * <Input id=\"my-input\" aria-describedby=\"my-helper-text\" />\n * <FormHelperText id=\"my-helper-text\">We'll never share your email.</FormHelperText>\n * </FormControl>\n * ```\n *\n * âš ï¸Only one input can be used within a FormControl.\n */\n\nvar FormControl = React.forwardRef(function FormControl(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'primary' : _props$color,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$error = props.error,\n error = _props$error === void 0 ? false : _props$error,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$hiddenLabel = props.hiddenLabel,\n hiddenLabel = _props$hiddenLabel === void 0 ? false : _props$hiddenLabel,\n _props$margin = props.margin,\n margin = _props$margin === void 0 ? 'none' : _props$margin,\n _props$required = props.required,\n required = _props$required === void 0 ? false : _props$required,\n size = props.size,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"color\", \"component\", \"disabled\", \"error\", \"fullWidth\", \"hiddenLabel\", \"margin\", \"required\", \"size\", \"variant\"]);\n\n var _React$useState = React.useState(function () {\n // We need to iterate through the children and find the Input in order\n // to fully support server-side rendering.\n var initialAdornedStart = false;\n\n if (children) {\n React.Children.forEach(children, function (child) {\n if (!isMuiElement(child, ['Input', 'Select'])) {\n return;\n }\n\n var input = isMuiElement(child, ['Select']) ? child.props.input : child;\n\n if (input && isAdornedStart(input.props)) {\n initialAdornedStart = true;\n }\n });\n }\n\n return initialAdornedStart;\n }),\n adornedStart = _React$useState[0],\n setAdornedStart = _React$useState[1];\n\n var _React$useState2 = React.useState(function () {\n // We need to iterate through the children and find the Input in order\n // to fully support server-side rendering.\n var initialFilled = false;\n\n if (children) {\n React.Children.forEach(children, function (child) {\n if (!isMuiElement(child, ['Input', 'Select'])) {\n return;\n }\n\n if (isFilled(child.props, true)) {\n initialFilled = true;\n }\n });\n }\n\n return initialFilled;\n }),\n filled = _React$useState2[0],\n setFilled = _React$useState2[1];\n\n var _React$useState3 = React.useState(false),\n focused = _React$useState3[0],\n setFocused = _React$useState3[1];\n\n if (disabled && focused) {\n setFocused(false);\n }\n\n var registerEffect;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n var registeredInput = React.useRef(false);\n\n registerEffect = function registerEffect() {\n if (registeredInput.current) {\n console.error(['Material-UI: there are multiple InputBase components inside a FormControl.', 'This is not supported. It might cause infinite rendering loops.', 'Only use one InputBase.'].join('\\n'));\n }\n\n registeredInput.current = true;\n return function () {\n registeredInput.current = false;\n };\n };\n }\n\n var onFilled = React.useCallback(function () {\n setFilled(true);\n }, []);\n var onEmpty = React.useCallback(function () {\n setFilled(false);\n }, []);\n var childContext = {\n adornedStart: adornedStart,\n setAdornedStart: setAdornedStart,\n color: color,\n disabled: disabled,\n error: error,\n filled: filled,\n focused: focused,\n hiddenLabel: hiddenLabel,\n margin: (size === 'small' ? 'dense' : undefined) || margin,\n onBlur: function onBlur() {\n setFocused(false);\n },\n onEmpty: onEmpty,\n onFilled: onFilled,\n onFocus: function onFocus() {\n setFocused(true);\n },\n registerEffect: registerEffect,\n required: required,\n variant: variant\n };\n return React.createElement(FormControlContext.Provider, {\n value: childContext\n }, React.createElement(Component, _extends({\n className: clsx(classes.root, className, margin !== 'none' && classes[\"margin\".concat(capitalize(margin))], fullWidth && classes.fullWidth),\n ref: ref\n }, other), children));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormControl.propTypes = {\n /**\n * The contents of the form control.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the label, input and helper text should be displayed in a disabled state.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label should be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the component will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * If `true`, the label will be hidden.\n * This is used to increase density for a `FilledInput`.\n * Be sure to add `aria-label` to the `input` element.\n */\n hiddenLabel: PropTypes.bool,\n\n /**\n * If `dense` or `normal`, will adjust vertical spacing of this and contained components.\n */\n margin: PropTypes.oneOf(['none', 'dense', 'normal']),\n\n /**\n * If `true`, the label will indicate that the input is required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the text field.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormControl'\n})(FormControl);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport formControlState from '../FormControl/formControlState';\nimport useFormControl from '../FormControl/useFormControl';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({\n color: theme.palette.text.secondary\n }, theme.typography.caption, {\n textAlign: 'left',\n marginTop: 8,\n lineHeight: '1em',\n minHeight: '1em',\n margin: 0,\n '&$disabled': {\n color: theme.palette.text.disabled\n },\n '&$error': {\n color: theme.palette.error.main\n }\n }),\n\n /* Pseudo-class applied to the root element if `error={true}`. */\n error: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `margin=\"dense\"`. */\n marginDense: {\n marginTop: 4\n },\n\n /* Styles applied to the root element if `variant=\"filled\"` or `variant=\"outlined\"`. */\n contained: {\n margin: '8px 14px 0'\n },\n\n /* Pseudo-class applied to the root element if `focused={true}`. */\n focused: {},\n\n /* Pseudo-class applied to the root element if `filled={true}`. */\n filled: {},\n\n /* Pseudo-class applied to the root element if `required={true}`. */\n required: {}\n };\n};\nvar FormHelperText = React.forwardRef(function FormHelperText(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'p' : _props$component,\n disabled = props.disabled,\n error = props.error,\n filled = props.filled,\n focused = props.focused,\n margin = props.margin,\n required = props.required,\n variant = props.variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"disabled\", \"error\", \"filled\", \"focused\", \"margin\", \"required\", \"variant\"]);\n\n var muiFormControl = useFormControl();\n var fcs = formControlState({\n props: props,\n muiFormControl: muiFormControl,\n states: ['variant', 'margin', 'disabled', 'error', 'filled', 'focused', 'required']\n });\n return React.createElement(Component, _extends({\n className: clsx(classes.root, (fcs.variant === 'filled' || fcs.variant === 'outlined') && classes.contained, className, fcs.disabled && classes.disabled, fcs.error && classes.error, fcs.filled && classes.filled, fcs.focused && classes.focused, fcs.required && classes.required, {\n dense: classes.marginDense\n }[fcs.margin]),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormHelperText.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, the helper text should be displayed in a disabled state.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, helper text should be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the helper text should use filled classes key.\n */\n filled: PropTypes.bool,\n\n /**\n * If `true`, the helper text should use focused classes key.\n */\n focused: PropTypes.bool,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense']),\n\n /**\n * If `true`, the helper text should use required classes key.\n */\n required: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormHelperText'\n})(FormHelperText);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport Input from '../Input';\nimport FilledInput from '../FilledInput';\nimport OutlinedInput from '../OutlinedInput';\nimport InputLabel from '../InputLabel';\nimport FormControl from '../FormControl';\nimport FormHelperText from '../FormHelperText';\nimport Select from '../Select';\nimport withStyles from '../styles/withStyles';\nvar variantComponent = {\n standard: Input,\n filled: FilledInput,\n outlined: OutlinedInput\n};\nexport var styles = {\n /* Styles applied to the root element. */\n root: {}\n};\n/**\n * The `TextField` is a convenience wrapper for the most common cases (80%).\n * It cannot be all things to all people, otherwise the API would grow out of control.\n *\n * ## Advanced Configuration\n *\n * It's important to understand that the text field is a simple abstraction\n * on top of the following components:\n *\n * - [FormControl](/api/form-control/)\n * - [InputLabel](/api/input-label/)\n * - [FilledInput](/api/filled-input/)\n * - [OutlinedInput](/api/outlined-input/)\n * - [Input](/api/input/)\n * - [FormHelperText](/api/form-helper-text/)\n *\n * If you wish to alter the props applied to the `input` element, you can do so as follows:\n *\n * ```jsx\n * const inputProps = {\n * step: 300,\n * };\n *\n * return <TextField id=\"time\" type=\"time\" inputProps={inputProps} />;\n * ```\n *\n * For advanced cases, please look at the source of TextField by clicking on the\n * \"Edit this page\" button above. Consider either:\n *\n * - using the upper case props for passing values directly to the components\n * - using the underlying components directly as shown in the demos\n */\n\nvar TextField = React.forwardRef(function TextField(props, ref) {\n var autoComplete = props.autoComplete,\n _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'primary' : _props$color,\n defaultValue = props.defaultValue,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$error = props.error,\n error = _props$error === void 0 ? false : _props$error,\n FormHelperTextProps = props.FormHelperTextProps,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n helperText = props.helperText,\n hiddenLabel = props.hiddenLabel,\n id = props.id,\n InputLabelProps = props.InputLabelProps,\n inputProps = props.inputProps,\n InputProps = props.InputProps,\n inputRef = props.inputRef,\n label = props.label,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n name = props.name,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onFocus = props.onFocus,\n placeholder = props.placeholder,\n _props$required = props.required,\n required = _props$required === void 0 ? false : _props$required,\n rows = props.rows,\n rowsMax = props.rowsMax,\n _props$select = props.select,\n select = _props$select === void 0 ? false : _props$select,\n SelectProps = props.SelectProps,\n type = props.type,\n value = props.value,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"autoComplete\", \"autoFocus\", \"children\", \"classes\", \"className\", \"color\", \"defaultValue\", \"disabled\", \"error\", \"FormHelperTextProps\", \"fullWidth\", \"helperText\", \"hiddenLabel\", \"id\", \"InputLabelProps\", \"inputProps\", \"InputProps\", \"inputRef\", \"label\", \"multiline\", \"name\", \"onBlur\", \"onChange\", \"onFocus\", \"placeholder\", \"required\", \"rows\", \"rowsMax\", \"select\", \"SelectProps\", \"type\", \"value\", \"variant\"]);\n\n var _React$useState = React.useState(0),\n labelWidth = _React$useState[0],\n setLabelWidth = _React$useState[1];\n\n var labelRef = React.useRef(null);\n React.useEffect(function () {\n if (variant === 'outlined') {\n // #StrictMode ready\n var labelNode = ReactDOM.findDOMNode(labelRef.current);\n setLabelWidth(labelNode != null ? labelNode.offsetWidth : 0);\n }\n }, [variant, required, label]);\n\n if (process.env.NODE_ENV !== 'production') {\n if (select && !children) {\n console.error('Material-UI: `children` must be passed when using the `TextField` component with `select`.');\n }\n }\n\n var InputMore = {};\n\n if (variant === 'outlined') {\n if (InputLabelProps && typeof InputLabelProps.shrink !== 'undefined') {\n InputMore.notched = InputLabelProps.shrink;\n }\n\n InputMore.labelWidth = labelWidth;\n }\n\n if (select) {\n // unset defaults from textbox inputs\n if (!SelectProps || !SelectProps.native) {\n InputMore.id = undefined;\n }\n\n InputMore['aria-describedby'] = undefined;\n }\n\n var helperTextId = helperText && id ? \"\".concat(id, \"-helper-text\") : undefined;\n var inputLabelId = label && id ? \"\".concat(id, \"-label\") : undefined;\n var InputComponent = variantComponent[variant];\n var InputElement = React.createElement(InputComponent, _extends({\n \"aria-describedby\": helperTextId,\n autoComplete: autoComplete,\n autoFocus: autoFocus,\n defaultValue: defaultValue,\n fullWidth: fullWidth,\n multiline: multiline,\n name: name,\n rows: rows,\n rowsMax: rowsMax,\n type: type,\n value: value,\n id: id,\n inputRef: inputRef,\n onBlur: onBlur,\n onChange: onChange,\n onFocus: onFocus,\n placeholder: placeholder,\n inputProps: inputProps\n }, InputMore, InputProps));\n return React.createElement(FormControl, _extends({\n className: clsx(classes.root, className),\n disabled: disabled,\n error: error,\n fullWidth: fullWidth,\n hiddenLabel: hiddenLabel,\n ref: ref,\n required: required,\n color: color,\n variant: variant\n }, other), label && React.createElement(InputLabel, _extends({\n htmlFor: id,\n ref: labelRef,\n id: inputLabelId\n }, InputLabelProps), label), select ? React.createElement(Select, _extends({\n \"aria-describedby\": helperTextId,\n id: id,\n labelId: inputLabelId,\n value: value,\n input: InputElement\n }, SelectProps), children) : InputElement, helperText && React.createElement(FormHelperText, _extends({\n id: helperTextId\n }, FormHelperTextProps), helperText));\n});\nprocess.env.NODE_ENV !== \"production\" ? TextField.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * @ignore\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default value of the `input` element.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the label will be displayed in an error state.\n */\n error: PropTypes.bool,\n\n /**\n * Props applied to the [`FormHelperText`](/api/form-helper-text/) element.\n */\n FormHelperTextProps: PropTypes.object,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The helper text content.\n */\n helperText: PropTypes.node,\n\n /**\n * @ignore\n */\n hiddenLabel: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n * Use this prop to make `label` and `helperText` accessible for screen readers.\n */\n id: PropTypes.string,\n\n /**\n * Props applied to the [`InputLabel`](/api/input-label/) element.\n */\n InputLabelProps: PropTypes.object,\n\n /**\n * Props applied to the Input element.\n * It will be a [`FilledInput`](/api/filled-input/),\n * [`OutlinedInput`](/api/outlined-input/) or [`Input`](/api/input/)\n * component depending on the `variant` prop value.\n */\n InputProps: PropTypes.object,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * The label content.\n */\n label: PropTypes.node,\n\n /**\n * If `dense` or `normal`, will adjust vertical spacing of this and contained components.\n */\n margin: PropTypes.oneOf(['none', 'dense', 'normal']),\n\n /**\n * If `true`, a textarea element will be rendered instead of an input.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * If `true`, the label is displayed as required and the `input` element` will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Render a [`Select`](/api/select/) element while passing the Input element to `Select` as `input` parameter.\n * If this option is set you must pass the options of the select as children.\n */\n select: PropTypes.bool,\n\n /**\n * Props applied to the [`Select`](/api/select/) element.\n */\n SelectProps: PropTypes.object,\n\n /**\n * The size of the text field.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['standard', 'outlined', 'filled'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTextField'\n})(TextField);","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"\n}), 'RadioButtonUnchecked');","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M8.465 8.465C9.37 7.56 10.62 7 12 7C14.76 7 17 9.24 17 12C17 13.38 16.44 14.63 15.535 15.535C14.63 16.44 13.38 17 12 17C9.24 17 7 14.76 7 12C7 10.62 7.56 9.37 8.465 8.465Z\"\n}), 'RadioButtonChecked');","import React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport RadioButtonUncheckedIcon from '../internal/svg-icons/RadioButtonUnchecked';\nimport RadioButtonCheckedIcon from '../internal/svg-icons/RadioButtonChecked';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n root: {\n position: 'relative',\n display: 'flex',\n '&$checked $layer': {\n transform: 'scale(1)',\n transition: theme.transitions.create('transform', {\n easing: theme.transitions.easing.easeOut,\n duration: theme.transitions.duration.shortest\n })\n }\n },\n layer: {\n left: 0,\n position: 'absolute',\n transform: 'scale(0)',\n transition: theme.transitions.create('transform', {\n easing: theme.transitions.easing.easeIn,\n duration: theme.transitions.duration.shortest\n })\n },\n checked: {}\n };\n};\n/**\n * @ignore - internal component.\n */\n\nfunction RadioButtonIcon(props) {\n var checked = props.checked,\n classes = props.classes,\n fontSize = props.fontSize;\n return React.createElement(\"div\", {\n className: clsx(classes.root, checked && classes.checked)\n }, React.createElement(RadioButtonUncheckedIcon, {\n fontSize: fontSize\n }), React.createElement(RadioButtonCheckedIcon, {\n fontSize: fontSize,\n className: classes.layer\n }));\n}\n\nprocess.env.NODE_ENV !== \"production\" ? RadioButtonIcon.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The size of the radio.\n * `small` is equivalent to the dense radio styling.\n */\n fontSize: PropTypes.oneOf(['small', 'default'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateRadioButtonIcon'\n})(RadioButtonIcon);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport SwitchBase from '../internal/SwitchBase';\nimport RadioButtonIcon from './RadioButtonIcon';\nimport { fade } from '../styles/colorManipulator';\nimport capitalize from '../utils/capitalize';\nimport createChainedFunction from '../utils/createChainedFunction';\nimport withStyles from '../styles/withStyles';\nimport useRadioGroup from '../RadioGroup/useRadioGroup';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n color: theme.palette.text.secondary\n },\n\n /* Pseudo-class applied to the root element if `checked={true}`. */\n checked: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n '&$checked': {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n '&$checked': {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n }\n };\n};\nvar defaultCheckedIcon = React.createElement(RadioButtonIcon, {\n checked: true\n});\nvar defaultIcon = React.createElement(RadioButtonIcon, null);\nvar Radio = React.forwardRef(function Radio(props, ref) {\n var checkedProp = props.checked,\n classes = props.classes,\n _props$color = props.color,\n color = _props$color === void 0 ? 'secondary' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n nameProp = props.name,\n onChangeProp = props.onChange,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"checked\", \"classes\", \"color\", \"disabled\", \"name\", \"onChange\", \"size\"]);\n\n var radioGroup = useRadioGroup();\n var checked = checkedProp;\n var onChange = createChainedFunction(onChangeProp, radioGroup && radioGroup.onChange);\n var name = nameProp;\n\n if (radioGroup) {\n if (typeof checked === 'undefined') {\n checked = radioGroup.value === props.value;\n }\n\n if (typeof name === 'undefined') {\n name = radioGroup.name;\n }\n }\n\n return React.createElement(SwitchBase, _extends({\n color: color,\n type: \"radio\",\n icon: React.cloneElement(defaultIcon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n checkedIcon: React.cloneElement(defaultCheckedIcon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n classes: {\n root: clsx(classes.root, classes[\"color\".concat(capitalize(color))]),\n checked: classes.checked,\n disabled: classes.disabled\n },\n name: name,\n checked: checked,\n onChange: onChange,\n ref: ref,\n disabled: disabled\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Radio.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary', 'default']),\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the radio.\n * `small` is equivalent to the dense radio styling.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string,\n\n /**\n * The value of the component. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiRadio'\n})(Radio);","import React from 'react';\nimport RadioGroupContext from './RadioGroupContext';\nexport default function useRadioGroup() {\n return React.useContext(RadioGroupContext);\n}","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z\"\n}), 'CheckBoxOutlineBlank');","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z\"\n}), 'CheckBox');","import React from 'react';\nimport createSvgIcon from './createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon(React.createElement(\"path\", {\n d: \"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z\"\n}), 'IndeterminateCheckBox');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport SwitchBase from '../internal/SwitchBase';\nimport CheckBoxOutlineBlankIcon from '../internal/svg-icons/CheckBoxOutlineBlank';\nimport CheckBoxIcon from '../internal/svg-icons/CheckBox';\nimport { fade } from '../styles/colorManipulator';\nimport IndeterminateCheckBoxIcon from '../internal/svg-icons/IndeterminateCheckBox';\nimport capitalize from '../utils/capitalize';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n color: theme.palette.text.secondary\n },\n\n /* Pseudo-class applied to the root element if `checked={true}`. */\n checked: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Pseudo-class applied to the root element if `indeterminate={true}`. */\n indeterminate: {},\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n '&$checked': {\n color: theme.palette.primary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n '&$checked': {\n color: theme.palette.secondary.main,\n '&:hover': {\n backgroundColor: fade(theme.palette.secondary.main, theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n '&$disabled': {\n color: theme.palette.action.disabled\n }\n }\n };\n};\nvar defaultCheckedIcon = React.createElement(CheckBoxIcon, null);\nvar defaultIcon = React.createElement(CheckBoxOutlineBlankIcon, null);\nvar defaultIndeterminateIcon = React.createElement(IndeterminateCheckBoxIcon, null);\nvar Checkbox = React.forwardRef(function Checkbox(props, ref) {\n var _props$checkedIcon = props.checkedIcon,\n checkedIcon = _props$checkedIcon === void 0 ? defaultCheckedIcon : _props$checkedIcon,\n classes = props.classes,\n _props$color = props.color,\n color = _props$color === void 0 ? 'secondary' : _props$color,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$icon = props.icon,\n icon = _props$icon === void 0 ? defaultIcon : _props$icon,\n _props$indeterminate = props.indeterminate,\n indeterminate = _props$indeterminate === void 0 ? false : _props$indeterminate,\n _props$indeterminateI = props.indeterminateIcon,\n indeterminateIcon = _props$indeterminateI === void 0 ? defaultIndeterminateIcon : _props$indeterminateI,\n inputProps = props.inputProps,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n other = _objectWithoutProperties(props, [\"checkedIcon\", \"classes\", \"color\", \"disabled\", \"icon\", \"indeterminate\", \"indeterminateIcon\", \"inputProps\", \"size\"]);\n\n return React.createElement(SwitchBase, _extends({\n type: \"checkbox\",\n classes: {\n root: clsx(classes.root, classes[\"color\".concat(capitalize(color))], indeterminate && classes.indeterminate),\n checked: classes.checked,\n disabled: classes.disabled\n },\n color: color,\n inputProps: _extends({\n 'data-indeterminate': indeterminate\n }, inputProps),\n icon: React.cloneElement(indeterminate ? indeterminateIcon : icon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n checkedIcon: React.cloneElement(indeterminate ? indeterminateIcon : checkedIcon, {\n fontSize: size === 'small' ? 'small' : 'default'\n }),\n ref: ref,\n disabled: disabled\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Checkbox.propTypes = {\n /**\n * If `true`, the component is checked.\n */\n checked: PropTypes.bool,\n\n /**\n * The icon to display when the component is checked.\n */\n checkedIcon: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary', 'default']),\n\n /**\n * If `true`, the switch will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * The icon to display when the component is unchecked.\n */\n icon: PropTypes.node,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * If `true`, the component appears indeterminate.\n * This does not set the native input element to indeterminate due\n * to inconsistent behavior across browsers.\n * However, we set a `data-indeterminate` attribute on the input.\n */\n indeterminate: PropTypes.bool,\n\n /**\n * The icon to display when the component is indeterminate.\n */\n indeterminateIcon: PropTypes.node,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * Callback fired when the state is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new checked state by accessing `event.target.checked` (boolean).\n */\n onChange: PropTypes.func,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * The size of the checkbox.\n * `small` is equivalent to the dense checkbox styling.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * The input component prop `type`.\n */\n type: PropTypes.string,\n\n /**\n * The value of the component. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiCheckbox'\n})(Checkbox);","import _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport useTheme from '../styles/useTheme';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n var align = theme.direction === 'rtl' ? 'right' : 'left';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'absolute',\n bottom: 0,\n right: 0,\n top: -5,\n left: 0,\n margin: 0,\n padding: 0,\n pointerEvents: 'none',\n borderRadius: 'inherit',\n borderStyle: 'solid',\n borderWidth: 1,\n // Match the Input Label\n transition: theme.transitions.create([\"padding-\".concat(align), 'border-color', 'border-width'], {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n })\n },\n\n /* Styles applied to the legend element. */\n legend: {\n textAlign: 'left',\n padding: 0,\n lineHeight: '11px',\n transition: theme.transitions.create('width', {\n duration: theme.transitions.duration.shorter,\n easing: theme.transitions.easing.easeOut\n })\n }\n };\n};\n/**\n * @ignore - internal component.\n */\n\nvar NotchedOutline = React.forwardRef(function NotchedOutline(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n labelWidthProp = props.labelWidth,\n notched = props.notched,\n style = props.style,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"labelWidth\", \"notched\", \"style\"]);\n\n var theme = useTheme();\n var align = theme.direction === 'rtl' ? 'right' : 'left';\n var labelWidth = labelWidthProp > 0 ? labelWidthProp * 0.75 + 8 : 0;\n return React.createElement(\"fieldset\", _extends({\n \"aria-hidden\": true,\n style: _extends(_defineProperty({}, \"padding\".concat(capitalize(align)), 8 + (notched ? 0 : labelWidth / 2)), style),\n className: clsx(classes.root, className),\n ref: ref\n }, other), React.createElement(\"legend\", {\n className: classes.legend,\n style: {\n // IE 11: fieldset with legend does not render\n // a border radius. This maintains consistency\n // by always having a legend rendered\n width: notched ? labelWidth : 0.01\n }\n }, React.createElement(\"span\", {\n dangerouslySetInnerHTML: {\n __html: '​'\n }\n })));\n});\nprocess.env.NODE_ENV !== \"production\" ? NotchedOutline.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The width of the label.\n */\n labelWidth: PropTypes.number.isRequired,\n\n /**\n * If `true`, the outline is notched to accommodate the label.\n */\n notched: PropTypes.bool.isRequired,\n\n /**\n * @ignore\n */\n style: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateNotchedOutline'\n})(NotchedOutline);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport InputBase from '../InputBase';\nimport NotchedOutline from './NotchedOutline';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var borderColor = theme.palette.type === 'light' ? 'rgba(0, 0, 0, 0.23)' : 'rgba(255, 255, 255, 0.23)';\n return {\n /* Styles applied to the root element. */\n root: {\n position: 'relative',\n borderRadius: theme.shape.borderRadius,\n '&:hover $notchedOutline': {\n borderColor: theme.palette.text.primary\n },\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n '&:hover $notchedOutline': {\n borderColor: borderColor\n }\n },\n '&$focused $notchedOutline': {\n borderColor: theme.palette.primary.main,\n borderWidth: 2\n },\n '&$error $notchedOutline': {\n borderColor: theme.palette.error.main\n },\n '&$disabled $notchedOutline': {\n borderColor: theme.palette.action.disabled\n }\n },\n\n /* Styles applied to the root element if the color is secondary. */\n colorSecondary: {\n '&$focused $notchedOutline': {\n borderColor: theme.palette.secondary.main\n }\n },\n\n /* Styles applied to the root element if the component is focused. */\n focused: {},\n\n /* Styles applied to the root element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the root element if `startAdornment` is provided. */\n adornedStart: {\n paddingLeft: 14\n },\n\n /* Styles applied to the root element if `endAdornment` is provided. */\n adornedEnd: {\n paddingRight: 14\n },\n\n /* Styles applied to the root element if `error={true}`. */\n error: {},\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n marginDense: {},\n\n /* Styles applied to the root element if `multiline={true}`. */\n multiline: {\n padding: '18.5px 14px',\n '&$marginDense': {\n paddingTop: 10.5,\n paddingBottom: 10.5\n }\n },\n\n /* Styles applied to the `NotchedOutline` element. */\n notchedOutline: {\n borderColor: borderColor\n },\n\n /* Styles applied to the `input` element. */\n input: {\n padding: '18.5px 14px',\n '&:-webkit-autofill': {\n WebkitBoxShadow: theme.palette.type === 'dark' ? '0 0 0 100px #266798 inset' : null,\n WebkitTextFillColor: theme.palette.type === 'dark' ? '#fff' : null,\n borderRadius: 'inherit'\n }\n },\n\n /* Styles applied to the `input` element if `margin=\"dense\"`. */\n inputMarginDense: {\n paddingTop: 10.5,\n paddingBottom: 10.5\n },\n\n /* Styles applied to the `input` element if `multiline={true}`. */\n inputMultiline: {\n padding: 0\n },\n\n /* Styles applied to the `input` element if `startAdornment` is provided. */\n inputAdornedStart: {\n paddingLeft: 0\n },\n\n /* Styles applied to the `input` element if `endAdornment` is provided. */\n inputAdornedEnd: {\n paddingRight: 0\n }\n };\n};\nvar OutlinedInput = React.forwardRef(function OutlinedInput(props, ref) {\n var classes = props.classes,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$inputComponent = props.inputComponent,\n inputComponent = _props$inputComponent === void 0 ? 'input' : _props$inputComponent,\n _props$labelWidth = props.labelWidth,\n labelWidth = _props$labelWidth === void 0 ? 0 : _props$labelWidth,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n notched = props.notched,\n _props$type = props.type,\n type = _props$type === void 0 ? 'text' : _props$type,\n other = _objectWithoutProperties(props, [\"classes\", \"fullWidth\", \"inputComponent\", \"labelWidth\", \"multiline\", \"notched\", \"type\"]);\n\n return React.createElement(InputBase, _extends({\n renderSuffix: function renderSuffix(state) {\n return React.createElement(NotchedOutline, {\n className: classes.notchedOutline,\n labelWidth: labelWidth,\n notched: typeof notched !== 'undefined' ? notched : Boolean(state.startAdornment || state.filled || state.focused)\n });\n },\n classes: _extends({}, classes, {\n root: clsx(classes.root, classes.underline),\n notchedOutline: null\n }),\n fullWidth: fullWidth,\n inputComponent: inputComponent,\n multiline: multiline,\n ref: ref,\n type: type\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? OutlinedInput.propTypes = {\n /**\n * This prop helps users to fill forms faster, especially on mobile devices.\n * The name can be confusing, as it's more like an autofill.\n * You can learn more about it [following the specification](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill).\n */\n autoComplete: PropTypes.string,\n\n /**\n * If `true`, the `input` element will be focused during the first mount.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * The CSS class name of the wrapper element.\n */\n className: PropTypes.string,\n\n /**\n * The color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the `input` element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * End `InputAdornment` for this component.\n */\n endAdornment: PropTypes.node,\n\n /**\n * If `true`, the input will indicate an error. This is normally obtained via context from\n * FormControl.\n */\n error: PropTypes.bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The id of the `input` element.\n */\n id: PropTypes.string,\n\n /**\n * The component used for the native input.\n * Either a string to use a DOM element or a component.\n */\n inputComponent: PropTypes.elementType,\n\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps: PropTypes.object,\n\n /**\n * Pass a ref to the `input` element.\n */\n inputRef: refType,\n\n /**\n * The width of the label.\n */\n labelWidth: PropTypes.number,\n\n /**\n * If `dense`, will adjust vertical spacing. This is normally obtained via context from\n * FormControl.\n */\n margin: PropTypes.oneOf(['dense', 'none']),\n\n /**\n * If `true`, a textarea element will be rendered.\n */\n multiline: PropTypes.bool,\n\n /**\n * Name attribute of the `input` element.\n */\n name: PropTypes.string,\n\n /**\n * If `true`, the outline is notched to accommodate the label.\n */\n notched: PropTypes.bool,\n\n /**\n * Callback fired when the value is changed.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * The short hint displayed in the input before the user enters a value.\n */\n placeholder: PropTypes.string,\n\n /**\n * It prevents the user from changing the value of the field\n * (not from interacting with the field).\n */\n readOnly: PropTypes.bool,\n\n /**\n * If `true`, the `input` element will be required.\n */\n required: PropTypes.bool,\n\n /**\n * Number of rows to display when multiline option is set to true.\n */\n rows: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Maximum number of rows to display when multiline option is set to true.\n */\n rowsMax: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Start `InputAdornment` for this component.\n */\n startAdornment: PropTypes.node,\n\n /**\n * Type of the `input` element. It should be [a valid HTML5 input type](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Form_%3Cinput%3E_types).\n */\n type: PropTypes.string,\n\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value: PropTypes.any\n} : void 0;\nOutlinedInput.muiName = 'Input';\nexport default withStyles(styles, {\n name: 'MuiOutlinedInput'\n})(OutlinedInput);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { chainPropTypes } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport ButtonBase from '../ButtonBase';\nimport isMuiElement from '../utils/isMuiElement';\nimport useForkRef from '../utils/useForkRef';\nimport ListContext from '../List/ListContext';\nimport ReactDOM from 'react-dom';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the (normally root) `component` element. May be wrapped by a `container`. */\n root: {\n display: 'flex',\n justifyContent: 'flex-start',\n alignItems: 'center',\n position: 'relative',\n textDecoration: 'none',\n width: '100%',\n boxSizing: 'border-box',\n textAlign: 'left',\n paddingTop: 8,\n paddingBottom: 8,\n '&$focusVisible': {\n backgroundColor: theme.palette.action.selected\n },\n '&$selected, &$selected:hover': {\n backgroundColor: theme.palette.action.selected\n },\n '&$disabled': {\n opacity: 0.5\n }\n },\n\n /* Styles applied to the `container` element if `children` includes `ListItemSecondaryAction`. */\n container: {\n position: 'relative'\n },\n\n /* Pseudo-class applied to the `component`'s `focusVisibleClassName` prop if `button={true}`. */\n focusVisible: {},\n\n /* Styles applied to the `component` element if dense. */\n dense: {\n paddingTop: 4,\n paddingBottom: 4\n },\n\n /* Styles applied to the `component` element if `alignItems=\"flex-start\"`. */\n alignItemsFlexStart: {\n alignItems: 'flex-start'\n },\n\n /* Pseudo-class applied to the inner `component` element if `disabled={true}`. */\n disabled: {},\n\n /* Styles applied to the inner `component` element if `divider={true}`. */\n divider: {\n borderBottom: \"1px solid \".concat(theme.palette.divider),\n backgroundClip: 'padding-box'\n },\n\n /* Styles applied to the inner `component` element if `disableGutters={false}`. */\n gutters: {\n paddingLeft: 16,\n paddingRight: 16\n },\n\n /* Styles applied to the inner `component` element if `button={true}`. */\n button: {\n transition: theme.transitions.create('background-color', {\n duration: theme.transitions.duration.shortest\n }),\n '&:hover': {\n textDecoration: 'none',\n backgroundColor: theme.palette.action.hover,\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Styles applied to the `component` element if `children` includes `ListItemSecondaryAction`. */\n secondaryAction: {\n // Add some space to avoid collision as `ListItemSecondaryAction`\n // is absolutely positioned.\n paddingRight: 48\n },\n\n /* Pseudo-class applied to the root element if `selected={true}`. */\n selected: {}\n };\n};\nvar useEnhancedEffect = typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect;\n/**\n * Uses an additional container component if `ListItemSecondaryAction` is the last child.\n */\n\nvar ListItem = React.forwardRef(function ListItem(props, ref) {\n var _props$alignItems = props.alignItems,\n alignItems = _props$alignItems === void 0 ? 'center' : _props$alignItems,\n _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n _props$button = props.button,\n button = _props$button === void 0 ? false : _props$button,\n childrenProp = props.children,\n classes = props.classes,\n className = props.className,\n componentProp = props.component,\n _props$ContainerCompo = props.ContainerComponent,\n ContainerComponent = _props$ContainerCompo === void 0 ? 'li' : _props$ContainerCompo,\n _props$ContainerProps = props.ContainerProps;\n _props$ContainerProps = _props$ContainerProps === void 0 ? {} : _props$ContainerProps;\n\n var ContainerClassName = _props$ContainerProps.className,\n ContainerProps = _objectWithoutProperties(_props$ContainerProps, [\"className\"]),\n _props$dense = props.dense,\n dense = _props$dense === void 0 ? false : _props$dense,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableGutters = props.disableGutters,\n disableGutters = _props$disableGutters === void 0 ? false : _props$disableGutters,\n _props$divider = props.divider,\n divider = _props$divider === void 0 ? false : _props$divider,\n focusVisibleClassName = props.focusVisibleClassName,\n _props$selected = props.selected,\n selected = _props$selected === void 0 ? false : _props$selected,\n other = _objectWithoutProperties(props, [\"alignItems\", \"autoFocus\", \"button\", \"children\", \"classes\", \"className\", \"component\", \"ContainerComponent\", \"ContainerProps\", \"dense\", \"disabled\", \"disableGutters\", \"divider\", \"focusVisibleClassName\", \"selected\"]);\n\n var context = React.useContext(ListContext);\n var childContext = {\n dense: dense || context.dense || false,\n alignItems: alignItems\n };\n var listItemRef = React.useRef(null);\n useEnhancedEffect(function () {\n if (autoFocus) {\n if (listItemRef.current) {\n listItemRef.current.focus();\n } else if (process.env.NODE_ENV !== 'production') {\n console.error('Material-UI: unable to set focus to a ListItem whose component has not been rendered.');\n }\n }\n }, [autoFocus]);\n var children = React.Children.toArray(childrenProp);\n var hasSecondaryAction = children.length && isMuiElement(children[children.length - 1], ['ListItemSecondaryAction']);\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n listItemRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n var handleRef = useForkRef(handleOwnRef, ref);\n\n var componentProps = _extends({\n className: clsx(classes.root, className, childContext.dense && classes.dense, !disableGutters && classes.gutters, divider && classes.divider, disabled && classes.disabled, button && classes.button, alignItems !== \"center\" && classes.alignItemsFlexStart, hasSecondaryAction && classes.secondaryAction, selected && classes.selected),\n disabled: disabled\n }, other);\n\n var Component = componentProp || 'li';\n\n if (button) {\n componentProps.component = componentProp || 'div';\n componentProps.focusVisibleClassName = clsx(classes.focusVisible, focusVisibleClassName);\n Component = ButtonBase;\n }\n\n if (hasSecondaryAction) {\n // Use div by default.\n Component = !componentProps.component && !componentProp ? 'div' : Component; // Avoid nesting of li > li.\n\n if (ContainerComponent === 'li') {\n if (Component === 'li') {\n Component = 'div';\n } else if (componentProps.component === 'li') {\n componentProps.component = 'div';\n }\n }\n\n return React.createElement(ListContext.Provider, {\n value: childContext\n }, React.createElement(ContainerComponent, _extends({\n className: clsx(classes.container, ContainerClassName),\n ref: handleRef\n }, ContainerProps), React.createElement(Component, componentProps, children), children.pop()));\n }\n\n return React.createElement(ListContext.Provider, {\n value: childContext\n }, React.createElement(Component, _extends({\n ref: handleRef\n }, componentProps), children));\n});\nprocess.env.NODE_ENV !== \"production\" ? ListItem.propTypes = {\n /**\n * Defines the `align-items` style property.\n */\n alignItems: PropTypes.oneOf(['flex-start', 'center']),\n\n /**\n * If `true`, the list item will be focused during the first mount.\n * Focus will also be triggered if the value changes from false to true.\n */\n autoFocus: PropTypes.bool,\n\n /**\n * If `true`, the list item will be a button (using `ButtonBase`). Props intended\n * for `ButtonBase` can then be applied to `ListItem`.\n */\n button: PropTypes.bool,\n\n /**\n * The content of the component. If a `ListItemSecondaryAction` is used it must\n * be the last child.\n */\n children: chainPropTypes(PropTypes.node, function (props) {\n var children = React.Children.toArray(props.children); // React.Children.toArray(props.children).findLastIndex(isListItemSecondaryAction)\n\n var secondaryActionIndex = -1;\n\n for (var i = children.length - 1; i >= 0; i -= 1) {\n var child = children[i];\n\n if (isMuiElement(child, ['ListItemSecondaryAction'])) {\n secondaryActionIndex = i;\n break;\n }\n } // is ListItemSecondaryAction the last child of ListItem\n\n\n if (secondaryActionIndex !== -1 && secondaryActionIndex !== children.length - 1) {\n return new Error('Material-UI: you used an element after ListItemSecondaryAction. ' + 'For ListItem to detect that it has a secondary action ' + 'you must pass it as the last child to ListItem.');\n }\n\n return null;\n }),\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n * By default, it's a `li` when `button` is `false` and a `div` when `button` is `true`.\n */\n component: PropTypes.elementType,\n\n /**\n * The container component used when a `ListItemSecondaryAction` is the last child.\n */\n ContainerComponent: PropTypes.elementType,\n\n /**\n * Props applied to the container component if used.\n */\n ContainerProps: PropTypes.object,\n\n /**\n * If `true`, compact vertical padding designed for keyboard and mouse input will be used.\n */\n dense: PropTypes.bool,\n\n /**\n * If `true`, the list item will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the left and right padding is removed.\n */\n disableGutters: PropTypes.bool,\n\n /**\n * If `true`, a 1px light border is added to the bottom of the list item.\n */\n divider: PropTypes.bool,\n\n /**\n * @ignore\n */\n focusVisibleClassName: PropTypes.string,\n\n /**\n * Use to apply selected styling.\n */\n selected: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiListItem'\n})(ListItem);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport ListItem from '../ListItem';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({}, theme.typography.body1, _defineProperty({\n minHeight: 48,\n paddingTop: 6,\n paddingBottom: 6,\n boxSizing: 'border-box',\n width: 'auto',\n overflow: 'hidden',\n whiteSpace: 'nowrap'\n }, theme.breakpoints.up('sm'), {\n minHeight: 'auto'\n })),\n // TODO To remove in v5?\n\n /* Styles applied to the root element if `disableGutters={false}`. */\n gutters: {},\n\n /* Styles applied to the root element if `selected={true}`. */\n selected: {},\n\n /* Styles applied to the root element if dense. */\n dense: _extends({}, theme.typography.body2, {\n minHeight: 'auto'\n })\n };\n};\nvar MenuItem = React.forwardRef(function MenuItem(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n component = _props$component === void 0 ? 'li' : _props$component,\n _props$disableGutters = props.disableGutters,\n disableGutters = _props$disableGutters === void 0 ? false : _props$disableGutters,\n _props$role = props.role,\n role = _props$role === void 0 ? 'menuitem' : _props$role,\n selected = props.selected,\n tabIndexProp = props.tabIndex,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"disableGutters\", \"role\", \"selected\", \"tabIndex\"]);\n\n var tabIndex;\n\n if (!props.disabled) {\n tabIndex = tabIndexProp !== undefined ? tabIndexProp : -1;\n }\n\n return React.createElement(ListItem, _extends({\n button: true,\n role: role,\n tabIndex: tabIndex,\n component: component,\n selected: selected,\n disableGutters: disableGutters,\n classes: {\n dense: classes.dense\n },\n className: clsx(classes.root, className, selected && classes.selected, !disableGutters && classes.gutters),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? MenuItem.propTypes = {\n /**\n * Menu item contents.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a DOM element or a component.\n */\n component: PropTypes.elementType,\n\n /**\n * If `true`, compact vertical padding designed for keyboard and mouse input will be used.\n */\n dense: PropTypes.bool,\n\n /**\n * @ignore\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the left and right padding is removed.\n */\n disableGutters: PropTypes.bool,\n\n /**\n * @ignore\n */\n role: PropTypes.string,\n\n /**\n * @ignore\n */\n selected: PropTypes.bool,\n\n /**\n * @ignore\n */\n tabIndex: PropTypes.number\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiMenuItem'\n})(MenuItem);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'flex',\n flexDirection: 'column',\n flexWrap: 'wrap'\n },\n\n /* Styles applied to the root element if `row={true}`. */\n row: {\n flexDirection: 'row'\n }\n};\n/**\n * `FormGroup` wraps controls such as `Checkbox` and `Switch`.\n * It provides compact row layout.\n * For the `Radio`, you should be using the `RadioGroup` component instead of this one.\n */\n\nvar FormGroup = React.forwardRef(function FormGroup(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$row = props.row,\n row = _props$row === void 0 ? false : _props$row,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"row\"]);\n\n return React.createElement(\"div\", _extends({\n className: clsx(classes.root, className, row && classes.row),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? FormGroup.propTypes = {\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * Display group of elements in a compact row.\n */\n row: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiFormGroup'\n})(FormGroup);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport FormGroup from '../FormGroup';\nimport useForkRef from '../utils/useForkRef';\nimport RadioGroupContext from './RadioGroupContext';\nvar RadioGroup = React.forwardRef(function RadioGroup(props, ref) {\n var actions = props.actions,\n children = props.children,\n name = props.name,\n valueProp = props.value,\n onChange = props.onChange,\n other = _objectWithoutProperties(props, [\"actions\", \"children\", \"name\", \"value\", \"onChange\"]);\n\n var rootRef = React.useRef(null);\n\n var _React$useRef = React.useRef(valueProp != null),\n isControlled = _React$useRef.current;\n\n var _React$useState = React.useState(props.defaultValue),\n valueState = _React$useState[0],\n setValue = _React$useState[1];\n\n var value = isControlled ? valueProp : valueState;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useEffect(function () {\n if (isControlled !== (valueProp != null)) {\n console.error([\"Material-UI: A component is changing \".concat(isControlled ? 'a ' : 'an un', \"controlled RadioGroup to be \").concat(isControlled ? 'un' : '', \"controlled.\"), 'Elements should not switch from uncontrolled to controlled (or vice versa).', 'Decide between using a controlled or uncontrolled RadioGroup ' + 'element for the lifetime of the component.', 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [valueProp, isControlled]);\n }\n\n React.useImperativeHandle(actions, function () {\n return {\n focus: function focus() {\n var input = rootRef.current.querySelector('input:not(:disabled):checked');\n\n if (!input) {\n input = rootRef.current.querySelector('input:not(:disabled)');\n }\n\n if (input) {\n input.focus();\n }\n }\n };\n }, []);\n var handleRef = useForkRef(ref, rootRef);\n\n var handleChange = function handleChange(event) {\n if (!isControlled) {\n setValue(event.target.value);\n }\n\n if (onChange) {\n onChange(event, event.target.value);\n }\n };\n\n return React.createElement(RadioGroupContext.Provider, {\n value: {\n name: name,\n onChange: handleChange,\n value: value\n }\n }, React.createElement(FormGroup, _extends({\n role: \"radiogroup\",\n ref: handleRef\n }, other), children));\n});\nprocess.env.NODE_ENV !== \"production\" ? RadioGroup.propTypes = {\n /**\n * @ignore\n */\n actions: PropTypes.shape({\n current: PropTypes.object\n }),\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * The default `input` element value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * The name used to reference the value of the control.\n */\n name: PropTypes.string,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when a radio button is selected.\n *\n * @param {object} event The event source of the callback.\n * You can pull out the new value by accessing `event.target.value` (string).\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * Value of the selected radio button. The DOM API casts this to a string.\n */\n value: PropTypes.any\n} : void 0;\nexport default RadioGroup;"],"sourceRoot":""} \ No newline at end of file diff --git a/build/static/js/main.928fa077.chunk.js b/build/static/js/main.928fa077.chunk.js deleted file mode 100644 index 42cb51a..0000000 --- a/build/static/js/main.928fa077.chunk.js +++ /dev/null @@ -1,2 +0,0 @@ -(this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[]).push([[0],{101:function(e,t,a){e.exports=a(130)},106:function(e,t,a){},130:function(e,t,a){"use strict";a.r(t);var n=a(0),i=a.n(n),r=a(9),o=a.n(r),c=(a(106),a(66)),l=a(36),s=a(11),u=a(34),m=a(165),d=a(167),p=a(166),g=a(63),f=a.n(g),E=a(132),q=a(64),h=a.n(q),v=a(65),x=a.n(v),b=a(54),y=a.n(b),j=a(170),w=a(55),O=a.n(w),F=a(173),N=a(19),C=a.n(N),S=a(164),k=a(160);var G=function(e){return i.a.createElement(i.a.Fragment,null,i.a.createElement(k.a,{control:i.a.createElement(S.a,{onChange:function(t){return e.setRequiredField(e.idq)},value:"required",color:"primary",checked:e.required}),label:"Obrigat\xf3ria"}),i.a.createElement(E.a,{"aria-label":"delete",onClick:function(){e.deleteFromForm(e.idq)}},i.a.createElement(C.a,null)))},I=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var R=function(e){var t=I();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(F.a,{disabled:!0,id:"outlined-disabled",label:"",defaultValue:"Resposta curta"})),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},B=a(28),A=a.n(B),W=a(27),_=a.n(W),z=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var U=function(e){var t=z();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},e.options.map((function(t,a){return i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:11},i.a.createElement(F.a,{label:"op\xe7\xe3o "+a,value:t,fullWidth:!0,onChange:function(t){return e.setSelectOption(t.target.value,e.idq,a)}})),i.a.createElement(d.a,{item:!0,xs:1},i.a.createElement(E.a,{"aria-label":"remove option",onClick:function(){e.removeSelectOption(e.idq,a)}},i.a.createElement(_.a,null))))}))),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:4},i.a.createElement(E.a,{"aria-label":"add option",onClick:function(){e.addSelectOption(e.idq)}},i.a.createElement(A.a,null))),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},T=a(87),Q=a.n(T),P=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var L=function(e){var t=P();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},e.options.map((function(t,a){return i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,container:!0,justify:"center",alignItems:"center",xs:1},i.a.createElement(Q.a,null)),i.a.createElement(d.a,{item:!0,xs:10},i.a.createElement(F.a,{label:"op\xe7\xe3o "+a,value:t,fullWidth:!0,onChange:function(t){return e.setSelectOption(t.target.value,e.idq,a)}})),i.a.createElement(d.a,{item:!0,xs:1},i.a.createElement(E.a,{"aria-label":"remove option",onClick:function(){e.removeSelectOption(e.idq,a)}},i.a.createElement(_.a,null))))}))),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:4},i.a.createElement(E.a,{"aria-label":"add option",onClick:function(){e.addSelectOption(e.idq)}},i.a.createElement(A.a,null))),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},D=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var Z=function(e){var t=D();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"sua pergunta",onChange:function(t){return e.setQuestionField(t.target.value,e.idq)}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},e.options.map((function(t,a){return i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,container:!0,justify:"center",alignItems:"center",xs:1},i.a.createElement(y.a,null)),i.a.createElement(d.a,{item:!0,xs:10},i.a.createElement(F.a,{label:"op\xe7\xe3o "+a,value:t,fullWidth:!0,onChange:function(t){return e.setSelectOption(t.target.value,e.idq,a)}})),i.a.createElement(d.a,{item:!0,xs:1},i.a.createElement(E.a,{"aria-label":"remove option",onClick:function(){e.removeSelectOption(e.idq,a)}},i.a.createElement(_.a,null))))}))),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:4},i.a.createElement(E.a,{"aria-label":"add option",onClick:function(){e.addSelectOption(e.idq)}},i.a.createElement(A.a,null))),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3},i.a.createElement(G,{deleteFromForm:e.deleteFromForm,idq:e.idq,setRequiredField:e.setRequiredField,required:e.required}))))},$=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"},title:{fontSize:"xx-large"},description:{fontSize:"x-large"}}}));var J=function(e){var t=$();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"Formul\xe1rio sem t\xedtulo",fullWidth:!0,onChange:function(t){return e.setTitleField(t.target.value,e.idq)},InputProps:{classes:{input:t.title}}})),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(F.a,{value:e.question,label:"Descri\xe7\xe3o do formul\xe1rio",onChange:function(t){return e.setDescriptionField(t.target.value,e.idq)},InputProps:{classes:{input:t.description}}})),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3})))},V="production"===Object({NODE_ENV:"production",PUBLIC_URL:""}).REACT_APP_STAGE?{genformsapi:{url:""}}:{genformsapi:{url:"http://200.236.31.188/api/"}},M=Object(m.a)((function(e){return{menu:{width:e.spacing(6),minheight:e.spacing(15),position:"fixed",top:e.spacing(10),left:"90%",padding:e.spacing(1)}}}));var H=function(){var e=M(),t=Object(n.useState)([{type:"title",title:"",description:""}]),a=Object(u.a)(t,2),r=a[0],o=a[1];function c(e){r[e].options.push(""),o(Object(s.a)(r)),console.log(r)}function l(e){console.log(e),r.splice(e,1),console.log(r),o(Object(s.a)(r))}function m(e,t){r[e].options.splice(t,1),o(Object(s.a)(r)),console.log(r)}function g(e,t){r[t].question=e,o(Object(s.a)(r)),console.log(r)}function q(e,t,a){r[t].options[a]=e,o(Object(s.a)(r)),console.log(r)}function v(e){r[e].required=!r[e].required,o(Object(s.a)(r)),console.log(r)}function b(e,t){r[t].title=e,o(Object(s.a)(r)),console.log(r)}function w(e,t){r[t].description=e,o(Object(s.a)(r)),console.log(r)}return i.a.createElement("div",null,i.a.createElement(d.a,{container:!0,direction:"column",alignItems:"center",justify:"center"},r.map((function(e,t){return"question"===e.type?i.a.createElement(R,{question:e.question,idq:t,deleteFromForm:l,setQuestionField:g,setRequiredField:v,required:e.required}):"select"===e.type?i.a.createElement(U,{question:e.question,options:e.options,idq:t,deleteFromForm:l,addSelectOption:c,removeSelectOption:m,setSelectOption:q,setQuestionField:g,setRequiredField:v,required:e.required}):"radio"===e.type?i.a.createElement(L,{question:e.question,options:e.options,idq:t,deleteFromForm:l,addSelectOption:c,removeSelectOption:m,setSelectOption:q,setQuestionField:g,setRequiredField:v,required:e.required}):"checkbox"===e.type?i.a.createElement(Z,{question:e.question,options:e.options,idq:t,deleteFromForm:l,addSelectOption:c,removeSelectOption:m,setSelectOption:q,setQuestionField:g,setRequiredField:v,required:e.required}):"title"===e.type?i.a.createElement(J,{question:e.question,idq:t,deleteFromForm:l,setTitleField:b,setDescriptionField:w}):void 0})),i.a.createElement(j.a,{variant:"contained",color:"primary",onClick:function(){var e={title:r[0].title,description:r[0].description,inputs:[]};r.forEach((function(t,a){"question"===t.type?e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:0,validation:t.required?[{type:2,arguments:""}]:[]}):"select"===t.type?e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:3,validation:t.required?[{type:2,arguments:""}]:[],sugestions:t.options.map((function(e,t){return{value:e,placement:t}}))}):"checkbox"===t.type?e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:1,validation:t.required?[{type:2,arguments:""}]:[],sugestions:t.options.map((function(e,t){return{value:e,placement:t}}))}):"radio"===t.type&&e.inputs.push({placement:a-1,description:"Adicionar esse campo no front",question:t.question,enabled:!0,type:2,validation:t.required?[{type:2,arguments:""}]:[],sugestions:t.options.map((function(e,t){return{value:e,placement:t}}))})})),console.log(e),O.a.post("".concat(V.genformsapi.url,"/form"),e).then((function(e){console.log(e),console.log(e.data),window.location.reload()}))}},"Criar")),i.a.createElement(p.a,{className:e.menu},i.a.createElement(d.a,{container:!0,spacing:0,direction:"column",alignItems:"center",justify:"center"},i.a.createElement(d.a,{item:!0,xs:0},i.a.createElement(E.a,{"aria-label":"add question",onClick:function(){o([].concat(Object(s.a)(r),[{type:"question",required:!1,question:""}])),console.log(r)}},i.a.createElement(f.a,null)),i.a.createElement(E.a,{"aria-label":"add select",onClick:function(){o([].concat(Object(s.a)(r),[{type:"select",question:"",required:!1,options:[""]}])),console.log(r)}},i.a.createElement(h.a,null)),i.a.createElement(E.a,{"aria-label":"add radio",onClick:function(){o([].concat(Object(s.a)(r),[{type:"radio",question:"",required:!1,options:[""]}])),console.log(r)}},i.a.createElement(x.a,null)),i.a.createElement(E.a,{"aria-label":"add checkbox",onClick:function(){o([].concat(Object(s.a)(r),[{type:"checkbox",question:"",required:!1,options:[""]}])),console.log(r)}},i.a.createElement(y.a,null))))))},K=a(131);var X=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var Y=function(e){var t=X();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(F.a,{id:"outlined-disabled",label:"",placeholder:"Resposta curta"})),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3})))},ee=a(172),te=a(177),ae=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var ne=function(e){var t=ae(),a=e.options.map((function(e){return i.a.createElement(te.a,{value:e.value},e.value)}));return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},i.a.createElement(ee.a,{labelId:"demo-simple-select-label",id:"demo-simple-select"},a))))},ie=a(174),re=a(178),oe=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var ce=function(e){var t=oe(),a=i.a.useState(),n=Object(u.a)(a,2),r=n[0],o=n[1],c=function(e){o(e.target.value)},l=e.options.map((function(e){return i.a.createElement("span",null,e.value,i.a.createElement(ie.a,{checked:r===e.value,onChange:c,value:e.value}))}));return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},i.a.createElement(re.a,null,l))))},le=a(175),se=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),minheight:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"}}}));var ue=function(e){var t=se(),a=e.options.map((function(e){return i.a.createElement("span",null,e.value," ",i.a.createElement(le.a,null))}));return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h6",gutterBottom:!0},e.question)),i.a.createElement(d.a,{item:!0,container:!0,direction:"column",justify:"flex-start",alignItems:"flex-start",xs:5,className:t.questionsGrid},a)))},me=Object(m.a)((function(e){return{paper:{padding:e.spacing(3),width:e.spacing(100),height:e.spacing(16),margin:e.spacing(2)},questionsGrid:{marginBottom:"20px"},title:{fontSize:"xx-large"},description:{fontSize:"x-large"}}}));var de=function(e){var t=me();return i.a.createElement(p.a,{className:t.paper},i.a.createElement(d.a,{container:!0},i.a.createElement(d.a,{item:!0,xs:12,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h3",gutterBottom:!0},e.title)),i.a.createElement(d.a,{item:!0,xs:9,className:t.questionsGrid},i.a.createElement(K.a,{variant:"h4",gutterBottom:!0},e.description)),i.a.createElement(d.a,{item:!0,container:!0,direction:"row",justify:"flex-end",alignItems:"flex-end",xs:3})))},pe=Object(m.a)((function(e){return{menu:{width:e.spacing(6),minheight:e.spacing(15),position:"fixed",top:e.spacing(10),left:"90%",padding:e.spacing(1)}}}));var ge=function(){pe();var e=Object(l.e)().id,t=Object(n.useState)(0),a=Object(u.a)(t,2),r=a[0],o=a[1];return Object(n.useEffect)((function(){!function(e){O.a.get("".concat(V.genformsapi.url,"/form/").concat(e)).then((function(e){console.log(e),console.log(e.data),o(e.data)}))}(e)}),[]),i.a.createElement("div",null,i.a.createElement(d.a,{container:!0,direction:"column",alignItems:"center",justify:"center"},r?i.a.createElement("div",null,i.a.createElement(de,{title:r.title,description:r.description}),r.inputs.map((function(e,t){return 0===e.type?i.a.createElement(Y,{question:e.question}):4===e.type?i.a.createElement(ne,{question:e.question,options:e.sugestions}):2===e.type?i.a.createElement(ce,{question:e.question,options:e.sugestions}):1===e.type?i.a.createElement(ue,{question:e.question,options:e.sugestions}):void 0}))):i.a.createElement("p",null,"Loading..."),i.a.createElement(j.a,{variant:"contained",color:"primary",onClick:function(){O.a.post("".concat(V.genformsapi.url,"/form")).then((function(e){console.log(e),console.log(e.data)}))}},"Responder")))},fe=a(90),Ee=a(20),qe=a(92),he=a(171),ve=a(91),xe=a.n(ve);var be=function(e){return i.a.createElement(F.a,{required:!0,onChange:e.onUpdate(e.param),style:{width:"45%"},id:"standart-basic",label:e.label,type:"password"==e.param?"password":"text",autoComplete:"off"})},ye=Object(m.a)((function(e){return{register:{maxWidth:"1000px",background:"#ffffff",boxShadow:"0 0 3px 0 #35c7fc",borderRadius:"2px",padding:"2% 1%",margin:"0 auto",marginTop:"9%"},custom_strong:{fontSize:"25px",textAlign:"center",display:"block",color:"#46525d"},strong_description:{fontSize:"14px",color:"#c2c6ca"},form:{marginTop:"3%",alignItems:"center",textAlign:"center"},button:Object(Ee.a)({type:"submit",width:"30%",marginTop:"4%",background:"#6ec46c",borderRadius:"2px",padding:"10px 20px",fontSize:"18px",color:"#ffffff","&:hover":{backgroundColor:"rgb(25, 109, 23)"}},"@media (max-width:550px)",{width:"55%"})}}));function je(){var e=ye(),t=i.a.useState({name:"",email:"",password:"",password_confirm:""}),a=Object(u.a)(t,2),n=a[0],r=a[1],o=function(e){return function(t){r(Object(fe.a)({},n,Object(Ee.a)({},e,t.target.value)))}};function c(){return!(n.password!=n.password_confirm&&(alert("As senhas n\xe3o conferem"),1)||!(/^[a-zA-Z ]+$/.test(n.name)&&n.name.length<=225||(alert("Nome inv\xe1lido"),0))||!/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\.[A-Za-z]+$/.test(n.email)&&(alert("E-mail inv\xe1lido"),1))}function l(){n.name&&n.email&&n.password&&n.password_confirm&&c()}var s=Object(qe.a)({overrides:{MuiInput:{underline:{"&:before":{borderBottom:"1px solid #35c7fc"},"&:after":{borderBottom:"1px solid #3f51b5"}}}}});return i.a.createElement(he.a,{theme:s},i.a.createElement(d.a,{className:e.register,justify:"center"},i.a.createElement("strong",{className:e.custom_strong},"Cadastro de Usu\xe1rio",i.a.createElement("p",{className:e.strong_description},"Insira as informa\xe7\xf5es abaixo")),i.a.createElement("form",{className:e.form,autocomplete:"off"},i.a.createElement(d.a,null,i.a.createElement(be,{label:"Nome Completo",param:"name",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(be,{label:"E-mail",param:"email",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(be,{label:"Senha",param:"password",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(be,{label:"Confirmar Senha",param:"password_confirm",onUpdate:o})),i.a.createElement(d.a,null,i.a.createElement(E.a,{type:"submit",size:"medium",className:e.button,onClick:function(){return l()}},i.a.createElement(xe.a,null),"Cadastre-se")))))}var we=function(){return i.a.createElement(c.a,null,i.a.createElement(l.a,{path:"/create",component:H}),i.a.createElement(l.a,{path:"/answer/:id",component:ge}),i.a.createElement(l.a,{path:"/SignUp",component:je}))},Oe=Boolean("localhost"===window.location.hostname||"[::1]"===window.location.hostname||window.location.hostname.match(/^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/));function Fe(e,t){navigator.serviceWorker.register(e).then((function(e){e.onupdatefound=function(){var a=e.installing;null!=a&&(a.onstatechange=function(){"installed"===a.state&&(navigator.serviceWorker.controller?(console.log("New content is available and will be used when all tabs for this page are closed. See https://bit.ly/CRA-PWA."),t&&t.onUpdate&&t.onUpdate(e)):(console.log("Content is cached for offline use."),t&&t.onSuccess&&t.onSuccess(e)))})}})).catch((function(e){console.error("Error during service worker registration:",e)}))}o.a.render(i.a.createElement(we,null),document.getElementById("root")),function(e){if("serviceWorker"in navigator){if(new URL("",window.location.href).origin!==window.location.origin)return;window.addEventListener("load",(function(){var t="".concat("","/service-worker.js");Oe?(!function(e,t){fetch(e,{headers:{"Service-Worker":"script"}}).then((function(a){var n=a.headers.get("content-type");404===a.status||null!=n&&-1===n.indexOf("javascript")?navigator.serviceWorker.ready.then((function(e){e.unregister().then((function(){window.location.reload()}))})):Fe(e,t)})).catch((function(){console.log("No internet connection found. App is running in offline mode.")}))}(t,e),navigator.serviceWorker.ready.then((function(){console.log("This web app is being served cache-first by a service worker. To learn more, visit https://bit.ly/CRA-PWA")}))):Fe(t,e)}))}}()}},[[101,1,2]]]); -//# sourceMappingURL=main.928fa077.chunk.js.map \ No newline at end of file diff --git a/build/static/js/main.928fa077.chunk.js.map b/build/static/js/main.928fa077.chunk.js.map deleted file mode 100644 index 42d9363..0000000 --- a/build/static/js/main.928fa077.chunk.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["components/fieldsCreateForm/FieldFooterOptions.js","components/fieldsCreateForm/FormFieldText.js","components/fieldsCreateForm/FormFieldSelect.js","components/fieldsCreateForm/FormFieldRadio.js","components/fieldsCreateForm/FormFieldCheckbox.js","components/fieldsCreateForm/FormFieldTitle.js","config.js","pages/CreateForm.js","components/fieldsAnswerForm/FieldFooterOptions.js","components/fieldsAnswerForm/FormFieldText.js","components/fieldsAnswerForm/FormFieldSelect.js","components/fieldsAnswerForm/FormFieldRadio.js","components/fieldsAnswerForm/FormFieldCheckbox.js","components/fieldsAnswerForm/FormFieldTitle.js","pages/AnswerForm.js","components/fieldsSignUp/FormInput.jsx","pages/SignUp.js","App.js","serviceWorker.js","index.js"],"names":["FieldFooterOptions","props","FormControlLabel","control","Switch","onChange","e","setRequiredField","idq","value","color","checked","required","label","IconButton","aria-label","onClick","deleteFromForm","useStyles","makeStyles","theme","paper","padding","spacing","width","height","margin","questionsGrid","marginBottom","FormFieldText","classes","Paper","className","Grid","container","item","xs","TextField","question","setQuestionField","target","disabled","id","defaultValue","direction","justify","alignItems","minheight","FormFieldSelect","options","map","x","index","fullWidth","setSelectOption","removeSelectOption","addSelectOption","FormFieldRadio","FormFieldCheckbox","title","fontSize","description","setTitleField","InputProps","input","setDescriptionField","config","process","REACT_APP_STAGE","genformsapi","url","menu","position","top","left","CreateForm","useState","type","form","setForm","push","console","log","splice","idopt","FormFieldTitle","Button","variant","json","inputs","forEach","y","placement","axios","post","then","res","data","window","location","reload","Typography","gutterBottom","placeholder","MenuItem","Select","labelId","React","selectedValue","setSelectedValue","handleChange","event","Radio","RadioGroup","Checkbox","AnwserForm","useParams","formData","setFormData","useEffect","get","getForm","sugestions","FormInput","onUpdate","param","style","autoComplete","register","maxWidth","background","boxShadow","borderRadius","marginTop","custom_strong","textAlign","display","strong_description","button","backgroundColor","SignUp","name","email","password","password_confirm","values","setValues","prop","verifyValuesContent","alert","test","length","submit","createMuiTheme","overrides","MuiInput","underline","borderBottom","autocomplete","size","App","path","component","AnswerForm","isLocalhost","Boolean","hostname","match","registerValidSW","swUrl","navigator","serviceWorker","registration","onupdatefound","installingWorker","installing","onstatechange","state","controller","onSuccess","catch","error","ReactDOM","render","document","getElementById","URL","href","origin","addEventListener","fetch","headers","response","contentType","status","indexOf","ready","unregister","checkValidServiceWorker"],"mappings":"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","file":"static/js/main.928fa077.chunk.js","sourcesContent":["import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\n\nfunction FieldFooterOptions(props) {\n\n\treturn (\n\t\t\t<>\n\t\t\t<FormControlLabel\n\t\t\t\tcontrol={\n\t\t\t\t<Switch\n\t\t\t\t\tonChange={e => props.setRequiredField(props.idq) }\n\t\t\t\t\tvalue=\"required\"\n\t\t\t\t\tcolor=\"primary\"\n\t\t\t\t\tchecked={props.required}\n\t\t\t\t/>\n\t\t\t\t}\n\t\t\t\tlabel=\"Obrigatória\"\n\t\t\t/>\n\t\t\t<IconButton aria-label=\"delete\" onClick={() => { props.deleteFromForm(props.idq) } }>\n\t\t\t\t<DeleteOutlinedIcon />\n\t\t\t</IconButton>\n\t\t\t</>\n\t);\n\n\n}\n\n\nexport default FieldFooterOptions;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\"\n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <TextField\n disabled\n id=\"outlined-disabled\"\n label=\"\"\n defaultValue=\"Resposta curta\"\n />\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required} />\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldSelect(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\" \n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {\n props.options.map((x, index) => {\n return <Grid container>\n <Grid item xs={11}>\n <TextField label={\"opção \"+index} value={x} fullWidth\n onChange={e => props.setSelectOption(e.target.value, props.idq, index)} />\n </Grid>\n <Grid item xs={1}>\n <IconButton aria-label=\"remove option\"\n onClick={() => { props.removeSelectOption(props.idq, index) } }>\n <CloseIcon />\n </IconButton>\n </Grid>\n </Grid>\n })\n }\n </Grid>\n <Grid item container \n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\"\n xs={4}\n >\n <IconButton aria-label=\"add option\" onClick={() => { props.addSelectOption(props.idq) } }>\n <AddCircleIcon />\n </IconButton>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required} />\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldSelect;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport RadioButtonUncheckedIcon from '@material-ui/icons/RadioButtonUnchecked';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldRadio(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\" \n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {\n props.options.map((x, index) => {\n return <Grid container>\n\t\t\t\t\t\t\t\t\t\t\t<Grid item container\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tjustify=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\talignItems=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\txs={1}\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t<RadioButtonUncheckedIcon/>\n\t\t\t\t\t\t\t\t\t\t\t</Grid>\n <Grid item xs={10}>\n <TextField label={\"opção \"+index} value={x} fullWidth\n onChange={e => props.setSelectOption(e.target.value, props.idq, index)} />\n </Grid>\n <Grid item xs={1}>\n <IconButton aria-label=\"remove option\"\n onClick={() => { props.removeSelectOption(props.idq, index) } }>\n <CloseIcon />\n </IconButton>\n </Grid>\n </Grid>\n })\n }\n </Grid>\n <Grid item container \n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\"\n xs={4}\n >\n <IconButton aria-label=\"add option\" onClick={() => { props.addSelectOption(props.idq) } }>\n <AddCircleIcon />\n </IconButton>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required} />\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldRadio;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank';\n\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldCheckbox(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"sua pergunta\" \n onChange={e => props.setQuestionField(e.target.value, props.idq)}/>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {\n props.options.map((x, index) => {\n return <Grid container>\n\t\t\t\t\t\t\t\t\t\t\t<Grid item container\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tjustify=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\talignItems=\"center\"\n\t\t\t\t\t\t\t\t\t\t\t\t\t\txs={1}\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t<CheckBoxOutlineBlankIcon/>\n\t\t\t\t\t\t\t\t\t\t\t</Grid>\n <Grid item xs={10}>\n <TextField label={\"opção \"+index} value={x} fullWidth\n onChange={e => props.setSelectOption(e.target.value, props.idq, index)} />\n </Grid>\n <Grid item xs={1}>\n <IconButton aria-label=\"remove option\"\n onClick={() => { props.removeSelectOption(props.idq, index) } }>\n <CloseIcon />\n </IconButton>\n </Grid>\n </Grid>\n })\n }\n </Grid>\n <Grid item container \n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\"\n xs={4}\n >\n <IconButton aria-label=\"add option\" onClick={() => { props.addSelectOption(props.idq) } }>\n <AddCircleIcon />\n </IconButton>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n <FieldFooterOptions deleteFromForm={props.deleteFromForm} idq={props.idq}\n setRequiredField={props.setRequiredField} required={props.required}/>\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldCheckbox;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n\t\tmarginBottom: '20px'\n\t},\n\ttitle: {\n\t\tfontSize: 'xx-large'\n\t},\n\tdescription: {\n\t\tfontSize: 'x-large'\n\t},\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"Formulário sem tÃtulo\" fullWidth \n onChange={e => props.setTitleField(e.target.value, props.idq)}\n\t\t\t\t\t\t\t\t\t\t\tInputProps={{\n\t\t\t\t\t\t\t\t\t\t\t\tclasses: {\n\t\t\t\t\t\t\t\t\t\t\t\t\tinput: classes.title,\n\t\t\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t\t\t}}/>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <TextField value={props.question} label=\"Descrição do formulário\"\n onChange={e => props.setDescriptionField(e.target.value, props.idq)}\n\t\t\t\t\t\t\t\t\t\t\tInputProps={{\n\t\t\t\t\t\t\t\t\t\t\t\tclasses: {\n\t\t\t\t\t\t\t\t\t\t\t\t\tinput: classes.description,\n\t\t\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t\t\t}}/>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","const development = {\n genformsapi: {\n url: \"http://200.236.31.188/api/\"\n }\n};\n\nconst production = {\n genformsapi: {\n url: \"\"\n }\n};\n\n\nlet conf;\nif(process.env.REACT_APP_STAGE === \"production\") {\n conf = production;\n} else {\n conf = development;\n}\n\nconst config = conf;\nexport default config;\n","import React, { useState } from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport AddIcon from '@material-ui/icons/Add';\nimport IconButton from '@material-ui/core/IconButton';\nimport ReorderIcon from '@material-ui/icons/Reorder';\nimport RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked';\nimport CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank';\nimport Button from '@material-ui/core/Button';\nimport axios from 'axios';\n\nimport FormFieldText from '../components/fieldsCreateForm/FormFieldText';\nimport FormFieldSelect from '../components/fieldsCreateForm/FormFieldSelect';\nimport FormFieldRadio from '../components/fieldsCreateForm/FormFieldRadio';\nimport FormFieldCheckbox from '../components/fieldsCreateForm/FormFieldCheckbox';\nimport FormFieldTitle from '../components/fieldsCreateForm/FormFieldTitle';\n\nimport config from '../config';\n\n\nconst useStyles = makeStyles(theme => ({\n menu: {\n width: theme.spacing(6),\n minheight: theme.spacing(15),\n position: 'fixed',\n top: theme.spacing(10),\n left: '90%',\n padding: theme.spacing(1)\n },\n}));\n\nfunction CreateForm() {\n const classes = useStyles();\n\n const [form, setForm] = useState([{type: \"title\", title: \"\", description: \"\"}]);\n\n function addToFormQuestion() {\n setForm([...form, {type: \"question\", required: false, question: \"\"}]);\n console.log(form);\n }\n\n function addToFormSelect() {\n setForm([...form, {type: \"select\", question: \"\", required: false, options: [\"\"]}]);\n console.log(form);\n }\n\n function addToFormRadio() {\n setForm([...form, {type: \"radio\", question: \"\", required: false, options: [\"\"]}]);\n console.log(form);\n }\n\n function addToFormCheckbox() {\n setForm([...form, {type: \"checkbox\", question: \"\", required: false, options: [\"\"]}]);\n console.log(form);\n }\n\n function addSelectOption(index) {\n form[index].options.push(\"\");\n setForm([...form]);\n console.log(form);\n }\n\n function deleteFromForm(index) {\n console.log(index);\n form.splice(index, 1)\n console.log(form);\n setForm([...form]);\n }\n\n function removeSelectOption(index, idopt) {\n form[index].options.splice(idopt, 1);\n setForm([...form]);\n console.log(form);\n }\n\n function setQuestionField(value, index) {\n form[index].question = value;\n setForm([...form]);\n console.log(form);\n }\n \n function setSelectOption(value, index, idopt) {\n form[index].options[idopt] = value;\n setForm([...form]);\n console.log(form);\n }\n\n function setRequiredField(index) {\n form[index].required = !form[index].required;\n setForm([...form]);\n console.log(form);\n }\n\n function setTitleField(value, index) {\n form[index].title = value;\n setForm([...form]);\n console.log(form);\n }\n\n function setDescriptionField(value, index) {\n form[index].description = value;\n setForm([...form]);\n console.log(form);\n }\n\n function createForm() {\n let json = {\n title: form[0].title,\n description: form[0].description,\n inputs: []\n }\n \n form.forEach(function(x, index){\n if(x.type === \"question\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 0, // question type = 0\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : []\n });\n } else if(x.type === \"select\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 3, // select type = 3\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : [],\n \"sugestions\": x.options.map(function(y, index) { return {value: y, placement: index} })\n });\n } else if(x.type === \"checkbox\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 1, // checkbox type = 1\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : [],\n \"sugestions\": x.options.map(function(y, index) { return {value: y, placement: index} })\n });\n } else if(x.type === \"radio\") {\n json.inputs.push({\n \"placement\": index-1,\n \"description\": \"Adicionar esse campo no front\",\n \"question\": x.question,\n \"enabled\": true,\n \"type\": 2, // radio type = 2\n \"validation\": x.required ? [{\"type\": 2, \"arguments\": \"\"}] : [],\n \"sugestions\": x.options.map(function(y, index) { return {value: y, placement: index} })\n });\n }\n });\n \n\n console.log(json);\n axios.post(`${config.genformsapi.url}/form`, json )\n .then(res => {\n console.log(res);\n console.log(res.data);\n\n window.location.reload();\n });\n \n }\n\n return (\n <div>\n <Grid\n container\n direction=\"column\"\n alignItems=\"center\"\n justify=\"center\"\n >\n {\n form.map((x, index) => {\n if(x.type === \"question\")\n return <FormFieldText question={x.question} idq={index} \n deleteFromForm={deleteFromForm} setQuestionField={setQuestionField} \n setRequiredField={setRequiredField} required={x.required}/>\n else if(x.type === \"select\")\n return <FormFieldSelect question={x.question} options={x.options} idq={index} \n deleteFromForm={deleteFromForm} addSelectOption={addSelectOption}\n removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} \n setQuestionField={setQuestionField} setRequiredField={setRequiredField} \n required={x.required} />\n else if(x.type === \"radio\")\n return <FormFieldRadio question={x.question} options={x.options} idq={index} \n deleteFromForm={deleteFromForm} addSelectOption={addSelectOption}\n removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} \n setQuestionField={setQuestionField} setRequiredField={setRequiredField} \n required={x.required} />\n else if(x.type === \"checkbox\")\n return <FormFieldCheckbox question={x.question} options={x.options} idq={index} \n deleteFromForm={deleteFromForm} addSelectOption={addSelectOption}\n removeSelectOption={removeSelectOption} setSelectOption={setSelectOption} \n setQuestionField={setQuestionField} setRequiredField={setRequiredField} \n required={x.required} />\n else if(x.type === \"title\")\n return <FormFieldTitle question={x.question} idq={index} \n deleteFromForm={deleteFromForm} setTitleField={setTitleField} \n setDescriptionField={setDescriptionField}/>\n })\n }\n <Button variant=\"contained\" color=\"primary\" onClick={createForm}>\n Criar\n </Button>\n </Grid>\n \n <Paper className={classes.menu}>\n <Grid\n container\n spacing={0}\n direction=\"column\"\n alignItems=\"center\"\n justify=\"center\"\n >\n <Grid item xs={0}>\n <IconButton aria-label=\"add question\" onClick={addToFormQuestion}>\n <AddIcon />\n </IconButton>\n <IconButton aria-label=\"add select\" onClick={addToFormSelect}>\n <ReorderIcon />\n </IconButton>\n <IconButton aria-label=\"add radio\" onClick={addToFormRadio}>\n <RadioButtonCheckedIcon />\n </IconButton>\n <IconButton aria-label=\"add checkbox\" onClick={addToFormCheckbox}>\n <CheckBoxOutlineBlankIcon />\n </IconButton>\n </Grid>\n </Grid>\n </Paper>\n \n </div>\n );\n}\n\nexport default CreateForm;\n","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\n\nfunction FieldFooterOptions(props) {\n\n\treturn (\n\t\t\t<>\n\t\t\t<FormControlLabel\n\t\t\t\tcontrol={\n\t\t\t\t<Switch\n\t\t\t\t\tonChange={e => props.setRequiredField(props.idq) }\n\t\t\t\t\tvalue=\"required\"\n\t\t\t\t\tcolor=\"primary\"\n\t\t\t\t\tchecked={props.required}\n\t\t\t\t/>\n\t\t\t\t}\n\t\t\t\tlabel=\"Obrigatória\"\n\t\t\t/>\n\t\t\t<IconButton aria-label=\"delete\" onClick={() => { props.deleteFromForm(props.idq) } }>\n\t\t\t\t<DeleteOutlinedIcon />\n\t\t\t</IconButton>\n\t\t\t</>\n\t);\n\n\n}\n\n\nexport default FieldFooterOptions;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Typography from '@material-ui/core/Typography';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <TextField\n id=\"outlined-disabled\"\n label=\"\"\n placeholder=\"Resposta curta\"\n />\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Typography from '@material-ui/core/Typography';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldSelect(props) {\n const classes = useStyles();\n\n const options = props.options.map(function(x) {\n return <MenuItem value={x.value}>{x.value}</MenuItem>;\n });\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n <Select\n labelId=\"demo-simple-select-label\"\n id=\"demo-simple-select\"\n // onChange={handleChange}\n >\n {options}\n </Select>\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldSelect;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Typography from '@material-ui/core/Typography';\nimport Radio from '@material-ui/core/Radio';\nimport RadioGroup from '@material-ui/core/RadioGroup';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldRadio(props) {\n const classes = useStyles();\n\n const [selectedValue, setSelectedValue] = React.useState();\n\n const handleChange = event => {\n setSelectedValue(event.target.value);\n };\n\n const options = props.options.map(function(x) {\n return <span>\n {x.value} \n <Radio checked={selectedValue === x.value}\n onChange={handleChange}\n value={x.value}\n />\n </span>;\n });\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n <RadioGroup>\n {options}\n </RadioGroup>\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldRadio;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Select from '@material-ui/core/Select';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport CloseIcon from '@material-ui/icons/Close';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Typography from '@material-ui/core/Typography';\nimport Checkbox from '@material-ui/core/Checkbox';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n minheight: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n marginBottom: '20px'\n },\n}));\n\n\n\nfunction FormFieldCheckbox(props) {\n const classes = useStyles();\n\n const options = props.options.map(function(x) {\n return <span>{x.value} <Checkbox /></span>;\n });\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h6\" gutterBottom>\n {props.question}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"column\"\n justify=\"flex-start\"\n alignItems=\"flex-start\" xs={5} className={classes.questionsGrid}\n >\n {options}\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldCheckbox;","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport IconButton from '@material-ui/core/IconButton';\nimport Typography from '@material-ui/core/Typography';\n\nimport FieldFooterOptions from './FieldFooterOptions';\n\nconst useStyles = makeStyles(theme => ({\n paper: {\n padding: theme.spacing(3),\n width: theme.spacing(100),\n height: theme.spacing(16),\n margin: theme.spacing(2)\n },\n questionsGrid: {\n\t\tmarginBottom: '20px'\n\t},\n\ttitle: {\n\t\tfontSize: 'xx-large'\n\t},\n\tdescription: {\n\t\tfontSize: 'x-large'\n\t},\n}));\n\nfunction FormFieldText(props) {\n const classes = useStyles();\n\n return (\n <Paper className={classes.paper}>\n <Grid container>\n <Grid item xs={12} className={classes.questionsGrid}>\n <Typography variant=\"h3\" gutterBottom>\n {props.title}\n </Typography>\n </Grid>\n <Grid item xs={9} className={classes.questionsGrid}>\n <Typography variant=\"h4\" gutterBottom>\n {props.description}\n </Typography>\n </Grid>\n <Grid item container\n direction=\"row\"\n justify=\"flex-end\"\n alignItems=\"flex-end\"\n xs={3}\n >\n </Grid>\n </Grid>\n </Paper>\n );\n\n}\n\nexport default FormFieldText;","import React, { useState, useEffect } from 'react';\nimport { useParams } from \"react-router-dom\";\nimport { makeStyles } from '@material-ui/core/styles';\nimport Grid from '@material-ui/core/Grid';\nimport Paper from '@material-ui/core/Paper';\nimport TextField from '@material-ui/core/TextField';\nimport AddIcon from '@material-ui/icons/Add';\nimport IconButton from '@material-ui/core/IconButton';\nimport ReorderIcon from '@material-ui/icons/Reorder';\nimport RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked';\nimport CheckBoxOutlineBlankIcon from '@material-ui/icons/CheckBoxOutlineBlank';\nimport Button from '@material-ui/core/Button';\nimport axios from 'axios';\n\nimport FormFieldText from '../components/fieldsAnswerForm/FormFieldText';\nimport FormFieldSelect from '../components/fieldsAnswerForm/FormFieldSelect';\nimport FormFieldRadio from '../components/fieldsAnswerForm/FormFieldRadio';\nimport FormFieldCheckbox from '../components/fieldsAnswerForm/FormFieldCheckbox';\nimport FormFieldTitle from '../components/fieldsAnswerForm/FormFieldTitle';\n\nimport config from '../config';\n\n\nconst useStyles = makeStyles(theme => ({\n menu: {\n width: theme.spacing(6),\n minheight: theme.spacing(15),\n position: 'fixed',\n top: theme.spacing(10),\n left: '90%',\n padding: theme.spacing(1)\n },\n}));\n\nfunction AnwserForm() {\n const classes = useStyles();\n\n const { id } = useParams();\n\n const [formData, setFormData] = useState(0);\n\n function getForm(id) {\n axios.get(`${config.genformsapi.url}/form/${id}`)\n .then(res => {\n console.log(res);\n console.log(res.data);\n setFormData(res.data);\n });\n\t}\n\t\n\tfunction answerForm() {\n axios.post(`${config.genformsapi.url}/form`)\n .then(res => {\n console.log(res);\n console.log(res.data);\n });\n }\n\n useEffect(() => {\n getForm(id);\n }, []);\n\n return (\n <div>\n <Grid\n container\n direction=\"column\"\n alignItems=\"center\"\n justify=\"center\"\n >\n\n {\n formData ? \n <div>\n <FormFieldTitle title={formData.title} description={formData.description}/>\n {\n formData.inputs.map((x, index) => {\n if(x.type === 0)\n return <FormFieldText question={x.question}/>\n else if(x.type === 4)\n return <FormFieldSelect question={x.question} options={x.sugestions}/>\n else if(x.type === 2)\n return <FormFieldRadio question={x.question} options={x.sugestions}/>\n else if(x.type === 1)\n return <FormFieldCheckbox question={x.question} options={x.sugestions}/>\n })\n } \n </div> : <p>Loading...</p>\n }\n <Button variant=\"contained\" color=\"primary\" onClick={answerForm}>\n Responder\n </Button>\n </Grid>\n </div>\n );\n}\n\nexport default AnwserForm;\n","import React, { Component } from \"react\";\nimport TextField from \"@material-ui/core/TextField\";\n\nfunction FormInput(props) {\n return (\n <TextField\n required\n onChange={props.onUpdate(props.param)}\n style={{ width: \"45%\" }}\n id=\"standart-basic\"\n label={props.label}\n type={\n props.param == (\"password\" || \"password_confirm\") ? \"password\" : \"text\"\n }\n autoComplete=\"off\"\n ></TextField>\n );\n}\nexport default FormInput;\n","import React from \"react\";\nimport Grid from \"@material-ui/core/Grid\";\nimport TextField from \"@material-ui/core/TextField\";\nimport { createMuiTheme, MuiThemeProvider } from \"@material-ui/core\";\nimport IconButton from \"@material-ui/core/IconButton\";\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport KeyboardArrowRightIcon from \"@material-ui/icons/KeyboardArrowRight\";\nimport FormInput from \"../components/fieldsSignUp/FormInput\";\n\nconst useStyles = makeStyles(theme => ({\n register: {\n maxWidth: \"1000px\",\n background: \"#ffffff\",\n boxShadow: \"0 0 3px 0 #35c7fc\",\n borderRadius: \"2px\",\n padding: \"2% 1%\",\n margin: \"0 auto\",\n marginTop: \"9%\"\n },\n custom_strong: {\n fontSize: \"25px\",\n textAlign: \"center\",\n display: \"block\",\n color: \"#46525d\"\n },\n strong_description: {\n fontSize: \"14px\",\n color: \"#c2c6ca\"\n },\n form: {\n marginTop: \"3%\",\n alignItems: \"center\",\n textAlign: \"center\"\n },\n button: {\n type: \"submit\",\n width: \"30%\",\n marginTop: \"4%\",\n background: \"#6ec46c\",\n borderRadius: \"2px\",\n padding: \"10px 20px\",\n fontSize: \"18px\",\n color: \"#ffffff\",\n \"&:hover\": {\n backgroundColor: \"rgb(25, 109, 23)\"\n },\n [\"@media (max-width:550px)\"]: {\n width: \"55%\"\n }\n }\n}));\nexport default function SignUp() {\n const classes = useStyles();\n const [values, setValues] = React.useState({\n name: \"\",\n email: \"\",\n password: \"\",\n password_confirm: \"\"\n });\n const handleChange = prop => event => {\n setValues({ ...values, [prop]: event.target.value });\n };\n function checkPassword() {\n if (values.password != values.password_confirm) {\n alert(\"As senhas não conferem\");\n return false;\n }\n return true;\n }\n function checkName() {\n if (/^[a-zA-Z ]+$/.test(values.name) && values.name.length <= 225) {\n return true;\n }\n alert(\"Nome inválido\");\n return false;\n }\n function checkEmail() {\n if (/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\\.[A-Za-z]+$/.test(values.email)) {\n return true;\n }\n alert(\"E-mail inválido\");\n return false;\n }\n function verifyValues() {\n if (\n values.name &&\n values.email &&\n values.password &&\n values.password_confirm\n ) {\n return true;\n }\n return false;\n }\n function verifyValuesContent() {\n if (checkPassword() && checkName() && checkEmail()) {\n return true;\n }\n return false;\n }\n function submit() {\n if (verifyValues()) {\n if (verifyValuesContent()) {\n // backend integration\n }\n }\n }\n const theme = createMuiTheme({\n overrides: {\n MuiInput: {\n underline: {\n \"&:before\": {\n borderBottom: \"1px solid #35c7fc\"\n },\n \"&:after\": {\n borderBottom: \"1px solid #3f51b5\"\n }\n }\n }\n }\n });\n return (\n <MuiThemeProvider theme={theme}>\n <Grid className={classes.register} justify=\"center\">\n <strong className={classes.custom_strong}>\n Cadastro de Usuário\n <p className={classes.strong_description}>\n Insira as informações abaixo\n </p>\n </strong>\n <form className={classes.form} autocomplete=\"off\">\n <Grid>\n <FormInput\n label=\"Nome Completo\"\n param=\"name\"\n onUpdate={handleChange}\n />\n </Grid>\n <Grid>\n <FormInput label=\"E-mail\" param=\"email\" onUpdate={handleChange} />\n </Grid>\n <Grid>\n <FormInput label=\"Senha\" param=\"password\" onUpdate={handleChange} />\n </Grid>\n <Grid>\n <FormInput\n label=\"Confirmar Senha\"\n param=\"password_confirm\"\n onUpdate={handleChange}\n />\n </Grid>\n <Grid>\n <IconButton\n type=\"submit\"\n size=\"medium\"\n className={classes.button}\n onClick={() => submit()}\n >\n <KeyboardArrowRightIcon />\n Cadastre-se\n </IconButton>\n </Grid>\n </form>\n </Grid>\n </MuiThemeProvider>\n );\n}\n","import React from \"react\";\nimport { HashRouter, Route } from \"react-router-dom\";\n\nimport CreateForm from \"./pages/CreateForm\";\nimport AnswerForm from \"./pages/AnswerForm\";\nimport SignUp from \"./pages/SignUp\";\n\nfunction App() {\n return (\n <HashRouter>\n <Route path=\"/create\" component={CreateForm} />\n <Route path=\"/answer/:id\" component={AnswerForm} />\n <Route path=\"/SignUp\" component={SignUp} />\n </HashRouter>\n );\n}\n\nexport default App;\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.0/8 are considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport function register(config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl, config) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl, {\n headers: { 'Service-Worker': 'script' }\n })\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister();\n });\n }\n}\n","import React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport \"./index.css\";\nimport App from \"./App\";\nimport * as serviceWorker from \"./serviceWorker\";\n\nReactDOM.render(<App />, document.getElementById(\"root\"));\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.register();\n"],"sourceRoot":""} \ No newline at end of file diff --git a/build/static/js/runtime-main.889ad4b6.js b/build/static/js/runtime-main.889ad4b6.js deleted file mode 100644 index f13a1ae..0000000 --- a/build/static/js/runtime-main.889ad4b6.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(e){function r(r){for(var n,p,l=r[0],a=r[1],f=r[2],c=0,s=[];c<l.length;c++)p=l[c],Object.prototype.hasOwnProperty.call(o,p)&&o[p]&&s.push(o[p][0]),o[p]=0;for(n in a)Object.prototype.hasOwnProperty.call(a,n)&&(e[n]=a[n]);for(i&&i(r);s.length;)s.shift()();return u.push.apply(u,f||[]),t()}function t(){for(var e,r=0;r<u.length;r++){for(var t=u[r],n=!0,l=1;l<t.length;l++){var a=t[l];0!==o[a]&&(n=!1)}n&&(u.splice(r--,1),e=p(p.s=t[0]))}return e}var n={},o={1:0},u=[];function p(r){if(n[r])return n[r].exports;var t=n[r]={i:r,l:!1,exports:{}};return e[r].call(t.exports,t,t.exports,p),t.l=!0,t.exports}p.m=e,p.c=n,p.d=function(e,r,t){p.o(e,r)||Object.defineProperty(e,r,{enumerable:!0,get:t})},p.r=function(e){"undefined"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},p.t=function(e,r){if(1&r&&(e=p(e)),8&r)return e;if(4&r&&"object"===typeof e&&e&&e.__esModule)return e;var t=Object.create(null);if(p.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:e}),2&r&&"string"!=typeof e)for(var n in e)p.d(t,n,function(r){return e[r]}.bind(null,n));return t},p.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return p.d(r,"a",r),r},p.o=function(e,r){return Object.prototype.hasOwnProperty.call(e,r)},p.p="/";var l=this["webpackJsonpmy-app"]=this["webpackJsonpmy-app"]||[],a=l.push.bind(l);l.push=r,l=l.slice();for(var f=0;f<l.length;f++)r(l[f]);var i=a;t()}([]); -//# sourceMappingURL=runtime-main.889ad4b6.js.map \ No newline at end of file diff --git a/build/static/js/runtime-main.889ad4b6.js.map b/build/static/js/runtime-main.889ad4b6.js.map deleted file mode 100644 index 62ea654..0000000 --- a/build/static/js/runtime-main.889ad4b6.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["../webpack/bootstrap"],"names":["webpackJsonpCallback","data","moduleId","chunkId","chunkIds","moreModules","executeModules","i","resolves","length","Object","prototype","hasOwnProperty","call","installedChunks","push","modules","parentJsonpFunction","shift","deferredModules","apply","checkDeferredModules","result","deferredModule","fulfilled","j","depId","splice","__webpack_require__","s","installedModules","1","exports","module","l","m","c","d","name","getter","o","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","p","jsonpArray","this","oldJsonpFunction","slice"],"mappings":"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","file":"static/js/runtime-main.889ad4b6.js","sourcesContent":[" \t// install a JSONP callback for chunk loading\n \tfunction webpackJsonpCallback(data) {\n \t\tvar chunkIds = data[0];\n \t\tvar moreModules = data[1];\n \t\tvar executeModules = data[2];\n\n \t\t// add \"moreModules\" to the modules object,\n \t\t// then flag all \"chunkIds\" as loaded and fire callback\n \t\tvar moduleId, chunkId, i = 0, resolves = [];\n \t\tfor(;i < chunkIds.length; i++) {\n \t\t\tchunkId = chunkIds[i];\n \t\t\tif(Object.prototype.hasOwnProperty.call(installedChunks, chunkId) && installedChunks[chunkId]) {\n \t\t\t\tresolves.push(installedChunks[chunkId][0]);\n \t\t\t}\n \t\t\tinstalledChunks[chunkId] = 0;\n \t\t}\n \t\tfor(moduleId in moreModules) {\n \t\t\tif(Object.prototype.hasOwnProperty.call(moreModules, moduleId)) {\n \t\t\t\tmodules[moduleId] = moreModules[moduleId];\n \t\t\t}\n \t\t}\n \t\tif(parentJsonpFunction) parentJsonpFunction(data);\n\n \t\twhile(resolves.length) {\n \t\t\tresolves.shift()();\n \t\t}\n\n \t\t// add entry modules from loaded chunk to deferred list\n \t\tdeferredModules.push.apply(deferredModules, executeModules || []);\n\n \t\t// run deferred modules when all chunks ready\n \t\treturn checkDeferredModules();\n \t};\n \tfunction checkDeferredModules() {\n \t\tvar result;\n \t\tfor(var i = 0; i < deferredModules.length; i++) {\n \t\t\tvar deferredModule = deferredModules[i];\n \t\t\tvar fulfilled = true;\n \t\t\tfor(var j = 1; j < deferredModule.length; j++) {\n \t\t\t\tvar depId = deferredModule[j];\n \t\t\t\tif(installedChunks[depId] !== 0) fulfilled = false;\n \t\t\t}\n \t\t\tif(fulfilled) {\n \t\t\t\tdeferredModules.splice(i--, 1);\n \t\t\t\tresult = __webpack_require__(__webpack_require__.s = deferredModule[0]);\n \t\t\t}\n \t\t}\n\n \t\treturn result;\n \t}\n\n \t// The module cache\n \tvar installedModules = {};\n\n \t// object to store loaded and loading chunks\n \t// undefined = chunk not loaded, null = chunk preloaded/prefetched\n \t// Promise = chunk loading, 0 = chunk loaded\n \tvar installedChunks = {\n \t\t1: 0\n \t};\n\n \tvar deferredModules = [];\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \tvar jsonpArray = this[\"webpackJsonpmy-app\"] = this[\"webpackJsonpmy-app\"] || [];\n \tvar oldJsonpFunction = jsonpArray.push.bind(jsonpArray);\n \tjsonpArray.push = webpackJsonpCallback;\n \tjsonpArray = jsonpArray.slice();\n \tfor(var i = 0; i < jsonpArray.length; i++) webpackJsonpCallback(jsonpArray[i]);\n \tvar parentJsonpFunction = oldJsonpFunction;\n\n\n \t// run deferred modules from other chunks\n \tcheckDeferredModules();\n"],"sourceRoot":""} \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index 67494d4..20c7db6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1274,22 +1274,22 @@ } }, "@material-ui/core": { - "version": "4.9.7", - "resolved": "https://registry.npmjs.org/@material-ui/core/-/core-4.9.7.tgz", - "integrity": "sha512-RTRibZgq572GHEskMAG4sP+bt3P3XyIkv3pOTR8grZAW2rSUd6JoGZLRM4S2HkuO7wS7cAU5SpU2s1EsmTgWog==", + "version": "4.11.0", + "resolved": "https://registry.npmjs.org/@material-ui/core/-/core-4.11.0.tgz", + "integrity": "sha512-bYo9uIub8wGhZySHqLQ833zi4ZML+XCBE1XwJ8EuUVSpTWWG57Pm+YugQToJNFsEyiKFhPh8DPD0bgupz8n01g==", "requires": { "@babel/runtime": "^7.4.4", - "@material-ui/styles": "^4.9.6", - "@material-ui/system": "^4.9.6", - "@material-ui/types": "^5.0.0", - "@material-ui/utils": "^4.9.6", + "@material-ui/styles": "^4.10.0", + "@material-ui/system": "^4.9.14", + "@material-ui/types": "^5.1.0", + "@material-ui/utils": "^4.10.2", "@types/react-transition-group": "^4.2.0", - "clsx": "^1.0.2", + "clsx": "^1.0.4", "hoist-non-react-statics": "^3.3.2", - "popper.js": "^1.14.1", + "popper.js": "1.16.1-lts", "prop-types": "^15.7.2", "react-is": "^16.8.0", - "react-transition-group": "^4.3.0" + "react-transition-group": "^4.4.0" }, "dependencies": { "dom-helpers": { @@ -1302,9 +1302,9 @@ }, "dependencies": { "@babel/runtime": { - "version": "7.9.2", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.9.2.tgz", - "integrity": "sha512-NE2DtOdufG7R5vnfQUTehdTfNycfUANEtCa9PssN9O/xmTzP4E08UI797ixaei6hBEVL9BI/PsdJS5x7mWoB9Q==", + "version": "7.10.5", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.10.5.tgz", + "integrity": "sha512-otddXKhdNn7d0ptoFRHtMLa8LqDxLYwTjB4nYgM1yy5N6gU/MUf8zqyyLltCH3yAVitBzmwK4us+DD0l/MauAg==", "requires": { "regenerator-runtime": "^0.13.4" } @@ -1320,9 +1320,9 @@ } }, "react-transition-group": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.3.0.tgz", - "integrity": "sha512-1qRV1ZuVSdxPlPf4O8t7inxUGpdyO5zG9IoNfJxSO0ImU2A1YWkEQvFPuIPZmMLkg5hYs7vv5mMOyfgSkvAwvw==", + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.4.1.tgz", + "integrity": "sha512-Djqr7OQ2aPUiYurhPalTrVy9ddmFCCzwhqQmtN+J3+3DzLO209Fdr70QrN8Z3DsglWql6iY1lDWAfpFiBtuKGw==", "requires": { "@babel/runtime": "^7.5.5", "dom-helpers": "^5.0.1", @@ -1331,9 +1331,9 @@ } }, "regenerator-runtime": { - "version": "0.13.5", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", - "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==" + "version": "0.13.7", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz", + "integrity": "sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew==" } } }, @@ -1346,39 +1346,27 @@ } }, "@material-ui/lab": { - "version": "4.0.0-alpha.46", - "resolved": "https://registry.npmjs.org/@material-ui/lab/-/lab-4.0.0-alpha.46.tgz", - "integrity": "sha512-JGgZmj1UNP8bbYNAGvndipjXRK3x2+9mFBzbX7MyCj+WpfnJbeqTmJK2No9MXvPj/EZJ1piaKif46FdDc4U93A==", + "version": "4.0.0-alpha.56", + "resolved": "https://registry.npmjs.org/@material-ui/lab/-/lab-4.0.0-alpha.56.tgz", + "integrity": "sha512-xPlkK+z/6y/24ka4gVJgwPfoCF4RCh8dXb1BNE7MtF9bXEBLN/lBxNTK8VAa0qm3V2oinA6xtUIdcRh0aeRtVw==", "requires": { "@babel/runtime": "^7.4.4", - "@material-ui/utils": "^4.9.6", + "@material-ui/utils": "^4.10.2", "clsx": "^1.0.4", "prop-types": "^15.7.2", "react-is": "^16.8.0" - }, - "dependencies": { - "@material-ui/utils": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@material-ui/utils/-/utils-4.9.6.tgz", - "integrity": "sha512-gqlBn0JPPTUZeAktn1rgMcy9Iczrr74ecx31tyZLVGdBGGzsxzM6PP6zeS7FuoLS6vG4hoZP7hWnOoHtkR0Kvw==", - "requires": { - "@babel/runtime": "^7.4.4", - "prop-types": "^15.7.2", - "react-is": "^16.8.0" - } - } } }, "@material-ui/styles": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@material-ui/styles/-/styles-4.9.6.tgz", - "integrity": "sha512-ijgwStEkw1OZ6gCz18hkjycpr/3lKs1hYPi88O/AUn4vMuuGEGAIrqKVFq/lADmZUNF3DOFIk8LDkp7zmjPxtA==", + "version": "4.10.0", + "resolved": "https://registry.npmjs.org/@material-ui/styles/-/styles-4.10.0.tgz", + "integrity": "sha512-XPwiVTpd3rlnbfrgtEJ1eJJdFCXZkHxy8TrdieaTvwxNYj42VnnCyFzxYeNW9Lhj4V1oD8YtQ6S5Gie7bZDf7Q==", "requires": { "@babel/runtime": "^7.4.4", "@emotion/hash": "^0.8.0", - "@material-ui/types": "^5.0.0", + "@material-ui/types": "^5.1.0", "@material-ui/utils": "^4.9.6", - "clsx": "^1.0.2", + "clsx": "^1.0.4", "csstype": "^2.5.2", "hoist-non-react-statics": "^3.3.2", "jss": "^10.0.3", @@ -1403,24 +1391,25 @@ } }, "@material-ui/system": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@material-ui/system/-/system-4.9.6.tgz", - "integrity": "sha512-QtfoAePyqXoZ2HUVSwGb1Ro0kucMCvVjbI0CdYIR21t0Opgfm1Oer6ni9P5lfeXA39xSt0wCierw37j+YES48Q==", + "version": "4.9.14", + "resolved": "https://registry.npmjs.org/@material-ui/system/-/system-4.9.14.tgz", + "integrity": "sha512-oQbaqfSnNlEkXEziDcJDDIy8pbvwUmZXWNqlmIwDqr/ZdCK8FuV3f4nxikUh7hvClKV2gnQ9djh5CZFTHkZj3w==", "requires": { "@babel/runtime": "^7.4.4", "@material-ui/utils": "^4.9.6", + "csstype": "^2.5.2", "prop-types": "^15.7.2" } }, "@material-ui/types": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/@material-ui/types/-/types-5.0.0.tgz", - "integrity": "sha512-UeH2BuKkwDndtMSS0qgx1kCzSMw+ydtj0xx/XbFtxNSTlXydKwzs5gVW5ZKsFlAkwoOOQ9TIsyoCC8hq18tOwg==" + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@material-ui/types/-/types-5.1.0.tgz", + "integrity": "sha512-7cqRjrY50b8QzRSYyhSpx4WRw2YuO0KKIGQEVk5J8uoz2BanawykgZGoWEqKm7pVIbzFDN0SpPcVV4IhOFkl8A==" }, "@material-ui/utils": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@material-ui/utils/-/utils-4.9.6.tgz", - "integrity": "sha512-gqlBn0JPPTUZeAktn1rgMcy9Iczrr74ecx31tyZLVGdBGGzsxzM6PP6zeS7FuoLS6vG4hoZP7hWnOoHtkR0Kvw==", + "version": "4.10.2", + "resolved": "https://registry.npmjs.org/@material-ui/utils/-/utils-4.10.2.tgz", + "integrity": "sha512-eg29v74P7W5r6a4tWWDAAfZldXIzfyO1am2fIsC39hdUUHm/33k6pGOKPbgDjg/U/4ifmgAePy/1OjkKN6rFRw==", "requires": { "@babel/runtime": "^7.4.4", "prop-types": "^15.7.2", @@ -1845,9 +1834,9 @@ } }, "@types/react-transition-group": { - "version": "4.2.4", - "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.2.4.tgz", - "integrity": "sha512-8DMUaDqh0S70TjkqU0DxOu80tFUiiaS9rxkWip/nb7gtvAsbqOXm02UCmR8zdcjWujgeYPiPNTVpVpKzUDotwA==", + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.4.0.tgz", + "integrity": "sha512-/QfLHGpu+2fQOqQaXh8MG9q03bFENooTb/it4jr5kKaZlDQfWvjqWZg48AwzPVMBHlRuTRAY7hRHCEOXz5kV6w==", "requires": { "@types/react": "*" } @@ -4112,9 +4101,9 @@ } }, "clsx": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/clsx/-/clsx-1.1.0.tgz", - "integrity": "sha512-3avwM37fSK5oP6M5rQ9CNe99lwxhXDOeSWVPAOYF6OazUTgZCMb0yWlJpmdD74REy1gkEaFiub2ULv4fq9GUhA==" + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/clsx/-/clsx-1.1.1.tgz", + "integrity": "sha512-6/bPho624p3S2pMyvP5kKBPXnI3ufHLObBFCfgx+LkeR5lg2XYy2hqZqUf45ypD8COn2bhgGJSUE+l5dhNBieA==" }, "co": { "version": "4.6.0", @@ -4631,12 +4620,27 @@ "integrity": "sha1-2bkoGtz9jO2TW9urqDeGiX9k6ZY=" }, "css-vendor": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/css-vendor/-/css-vendor-2.0.7.tgz", - "integrity": "sha512-VS9Rjt79+p7M0WkPqcAza4Yq1ZHrsHrwf7hPL/bjQB+c1lwmAI+1FXxYTYt818D/50fFVflw0XKleiBN5RITkg==", + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/css-vendor/-/css-vendor-2.0.8.tgz", + "integrity": "sha512-x9Aq0XTInxrkuFeHKbYC7zWY8ai7qJ04Kxd9MnvbC1uO5DagxoHQjm4JvG+vCdXOoFtCjbL2XSZfxmoYa9uQVQ==", "requires": { - "@babel/runtime": "^7.6.2", + "@babel/runtime": "^7.8.3", "is-in-browser": "^1.0.2" + }, + "dependencies": { + "@babel/runtime": { + "version": "7.10.5", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.10.5.tgz", + "integrity": "sha512-otddXKhdNn7d0ptoFRHtMLa8LqDxLYwTjB4nYgM1yy5N6gU/MUf8zqyyLltCH3yAVitBzmwK4us+DD0l/MauAg==", + "requires": { + "regenerator-runtime": "^0.13.4" + } + }, + "regenerator-runtime": { + "version": "0.13.7", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz", + "integrity": "sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew==" + } } }, "css-what": { @@ -6487,9 +6491,9 @@ } }, "formik": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/formik/-/formik-2.1.4.tgz", - "integrity": "sha512-oKz8S+yQBzuQVSEoxkqqJrKQS5XJASWGVn6mrs+oTWrBoHgByVwwI1qHiVc9GKDpZBU9vAxXYAKz2BvujlwunA==", + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/formik/-/formik-2.1.5.tgz", + "integrity": "sha512-bWpo3PiqVDYslvrRjTq0Isrm0mFXHiO33D8MS6t6dWcqSFGeYF52nlpCM2xwOJ6tRVRznDkL+zz/iHPL4LDuvQ==", "requires": { "deepmerge": "^2.1.1", "hoist-non-react-statics": "^3.3.0", @@ -6768,11 +6772,6 @@ "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", @@ -8795,9 +8794,9 @@ } }, "jss": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss/-/jss-10.1.1.tgz", - "integrity": "sha512-Xz3qgRUFlxbWk1czCZibUJqhVPObrZHxY3FPsjCXhDld4NOj1BgM14Ir5hVm+Qr6OLqVljjGvoMcCdXNOAbdkQ==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss/-/jss-10.3.0.tgz", + "integrity": "sha512-B5sTRW9B6uHaUVzSo9YiMEOEp3UX8lWevU0Fsv+xtRnsShmgCfIYX44bTH8bPJe6LQKqEXku3ulKuHLbxBS97Q==", "requires": { "@babel/runtime": "^7.3.1", "csstype": "^2.6.5", @@ -8806,69 +8805,70 @@ } }, "jss-plugin-camel-case": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss-plugin-camel-case/-/jss-plugin-camel-case-10.1.1.tgz", - "integrity": "sha512-MDIaw8FeD5uFz1seQBKz4pnvDLnj5vIKV5hXSVdMaAVq13xR6SVTVWkIV/keyTs5txxTvzGJ9hXoxgd1WTUlBw==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss-plugin-camel-case/-/jss-plugin-camel-case-10.3.0.tgz", + "integrity": "sha512-tadWRi/SLWqLK3EUZEdDNJL71F3ST93Zrl9JYMjV0QDqKPAl0Liue81q7m/nFUpnSTXczbKDy4wq8rI8o7WFqA==", "requires": { "@babel/runtime": "^7.3.1", "hyphenate-style-name": "^1.0.3", - "jss": "10.1.1" + "jss": "^10.3.0" } }, "jss-plugin-default-unit": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss-plugin-default-unit/-/jss-plugin-default-unit-10.1.1.tgz", - "integrity": "sha512-UkeVCA/b3QEA4k0nIKS4uWXDCNmV73WLHdh2oDGZZc3GsQtlOCuiH3EkB/qI60v2MiCq356/SYWsDXt21yjwdg==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss-plugin-default-unit/-/jss-plugin-default-unit-10.3.0.tgz", + "integrity": "sha512-tT5KkIXAsZOSS9WDSe8m8lEHIjoEOj4Pr0WrG0WZZsMXZ1mVLFCSsD2jdWarQWDaRNyMj/I4d7czRRObhOxSuw==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "10.1.1" + "jss": "^10.3.0" } }, "jss-plugin-global": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss-plugin-global/-/jss-plugin-global-10.1.1.tgz", - "integrity": "sha512-VBG3wRyi3Z8S4kMhm8rZV6caYBegsk+QnQZSVmrWw6GVOT/Z4FA7eyMu5SdkorDlG/HVpHh91oFN56O4R9m2VA==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss-plugin-global/-/jss-plugin-global-10.3.0.tgz", + "integrity": "sha512-etYTG/y3qIR/vxZnKY+J3wXwObyBDNhBiB3l/EW9/pE3WHE//BZdK8LFvQcrCO48sZW1Z6paHo6klxUPP7WbzA==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "10.1.1" + "jss": "^10.3.0" } }, "jss-plugin-nested": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss-plugin-nested/-/jss-plugin-nested-10.1.1.tgz", - "integrity": "sha512-ozEu7ZBSVrMYxSDplPX3H82XHNQk2DQEJ9TEyo7OVTPJ1hEieqjDFiOQOxXEj9z3PMqkylnUbvWIZRDKCFYw5Q==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss-plugin-nested/-/jss-plugin-nested-10.3.0.tgz", + "integrity": "sha512-qWiEkoXNEkkZ+FZrWmUGpf+zBsnEOmKXhkjNX85/ZfWhH9dfGxUCKuJFuOWFM+rjQfxV4csfesq4hY0jk8Qt0w==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "10.1.1", + "jss": "^10.3.0", "tiny-warning": "^1.0.2" } }, "jss-plugin-props-sort": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss-plugin-props-sort/-/jss-plugin-props-sort-10.1.1.tgz", - "integrity": "sha512-g/joK3eTDZB4pkqpZB38257yD4LXB0X15jxtZAGbUzcKAVUHPl9Jb47Y7lYmiGsShiV4YmQRqG1p2DHMYoK91g==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss-plugin-props-sort/-/jss-plugin-props-sort-10.3.0.tgz", + "integrity": "sha512-boetORqL/lfd7BWeFD3K+IyPqyIC+l3CRrdZr+NPq7Noqp+xyg/0MR7QisgzpxCEulk+j2CRcEUoZsvgPC4nTg==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "10.1.1" + "jss": "^10.3.0" } }, "jss-plugin-rule-value-function": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss-plugin-rule-value-function/-/jss-plugin-rule-value-function-10.1.1.tgz", - "integrity": "sha512-ClV1lvJ3laU9la1CUzaDugEcwnpjPTuJ0yGy2YtcU+gG/w9HMInD5vEv7xKAz53Bk4WiJm5uLOElSEshHyhKNw==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss-plugin-rule-value-function/-/jss-plugin-rule-value-function-10.3.0.tgz", + "integrity": "sha512-7WiMrKIHH3rwxTuJki9+7nY11r1UXqaUZRhHvqTD4/ZE+SVhvtD5Tx21ivNxotwUSleucA/8boX+NF21oXzr5Q==", "requires": { "@babel/runtime": "^7.3.1", - "jss": "10.1.1" + "jss": "^10.3.0", + "tiny-warning": "^1.0.2" } }, "jss-plugin-vendor-prefixer": { - "version": "10.1.1", - "resolved": "https://registry.npmjs.org/jss-plugin-vendor-prefixer/-/jss-plugin-vendor-prefixer-10.1.1.tgz", - "integrity": "sha512-09MZpQ6onQrhaVSF6GHC4iYifQ7+4YC/tAP6D4ZWeZotvCMq1mHLqNKRIaqQ2lkgANjlEot2JnVi1ktu4+L4pw==", + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/jss-plugin-vendor-prefixer/-/jss-plugin-vendor-prefixer-10.3.0.tgz", + "integrity": "sha512-sZQbrcZyP5V0ADjCLwUA1spVWoaZvM7XZ+2fSeieZFBj31cRsnV7X70FFDerMHeiHAXKWzYek+67nMDjhrZAVQ==", "requires": { "@babel/runtime": "^7.3.1", - "css-vendor": "^2.0.7", - "jss": "10.1.1" + "css-vendor": "^2.0.8", + "jss": "^10.3.0" } }, "jsx-ast-utils": { @@ -9384,13 +9384,12 @@ "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==", + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/mini-create-react-context/-/mini-create-react-context-0.4.0.tgz", + "integrity": "sha512-b0TytUgFSbgFJGzJqXPKCFCBWigAjpjo+Fl7Vf7ZbKRDptszpppKxXH6DRXEABZ/gcEQczeb0iZ7JvL8e8jjCA==", "requires": { - "@babel/runtime": "^7.4.0", - "gud": "^1.0.0", - "tiny-warning": "^1.0.2" + "@babel/runtime": "^7.5.5", + "tiny-warning": "^1.0.3" } }, "mini-css-extract-plugin": { @@ -10395,9 +10394,9 @@ } }, "popper.js": { - "version": "1.16.1", - "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.1.tgz", - "integrity": "sha512-Wb4p1J4zyFTbM+u6WuO4XstYx4Ky9Cewe4DWrel7B0w6VVICvPwdOpotjzcf6eD8TsckVnIMNONQyPIUFOUbCQ==" + "version": "1.16.1-lts", + "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.1-lts.tgz", + "integrity": "sha512-Kjw8nKRl1m+VrSFCoVGPph93W/qrSO7ZkqPpTf7F4bk/sqcfWK019dWBUpE/fBOsOQY1dks/Bmcbfn1heM/IsA==" }, "portfinder": { "version": "1.0.25", @@ -11916,15 +11915,15 @@ } }, "react-router": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/react-router/-/react-router-5.1.2.tgz", - "integrity": "sha512-yjEuMFy1ONK246B+rsa0cUam5OeAQ8pyclRDgpxuSCrAlJ1qN9uZ5IgyKC7gQg0w8OM50NXHEegPh/ks9YuR2A==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/react-router/-/react-router-5.2.0.tgz", + "integrity": "sha512-smz1DUuFHRKdcJC0jobGo8cVbhO3x50tCL4icacOlcwDOEQPq4TMqwx3sY1TP+DvtTgz4nm3thuo7A+BK2U0Dw==", "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", + "mini-create-react-context": "^0.4.0", "path-to-regexp": "^1.7.0", "prop-types": "^15.6.2", "react-is": "^16.6.0", @@ -11956,15 +11955,15 @@ } }, "react-router-dom": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-5.1.2.tgz", - "integrity": "sha512-7BPHAaIwWpZS074UKaw1FjVdZBSVWEk8IuDXdB+OkLb8vd/WRQIpA4ag9WQk61aEfQs47wHyjWUoUGGZxpQXew==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-5.2.0.tgz", + "integrity": "sha512-gxAmfylo2QUjcwxI63RhQ5G85Qqt4voZpUXSEqCwykV0baaOTQDR1f0PmY8AELqIyVc0NEZUj0Gov5lNGcXgsA==", "requires": { "@babel/runtime": "^7.1.2", "history": "^4.9.0", "loose-envify": "^1.3.1", "prop-types": "^15.6.2", - "react-router": "5.1.2", + "react-router": "5.2.0", "tiny-invariant": "^1.0.2", "tiny-warning": "^1.0.0" } @@ -13560,9 +13559,9 @@ "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==" }, "synchronous-promise": { - "version": "2.0.10", - "resolved": "https://registry.npmjs.org/synchronous-promise/-/synchronous-promise-2.0.10.tgz", - "integrity": "sha512-6PC+JRGmNjiG3kJ56ZMNWDPL8hjyghF5cMXIFOKg+NiwwEZZIvxTWd0pinWKyD227odg9ygF8xVhhz7gb8Uq7A==" + "version": "2.0.13", + "resolved": "https://registry.npmjs.org/synchronous-promise/-/synchronous-promise-2.0.13.tgz", + "integrity": "sha512-R9N6uDkVsghHePKh1TEqbnLddO2IY25OcsksyFp/qBe7XYd0PVbKEWxhcdMhpLzE1I6skj5l4aEZ3CRxcbArlA==" }, "table": { "version": "5.4.6", @@ -15043,33 +15042,33 @@ } }, "yup": { - "version": "0.28.3", - "resolved": "https://registry.npmjs.org/yup/-/yup-0.28.3.tgz", - "integrity": "sha512-amVkCgFWe5bGjrrUiODkbIzrSwtB8JpZrQYSrfj2YsbRdrV+tn9LquWdZDlfOx2HXyfEA8FGnlwidE/bFDxO7Q==", + "version": "0.28.5", + "resolved": "https://registry.npmjs.org/yup/-/yup-0.28.5.tgz", + "integrity": "sha512-7JZcvpUGUxMKoaEtcoMEM8lCWRaueGNH/A3EhL/UWqfbFm3uloiI+x59Yq4nzhbbYWUTwAsCteaZOJ+VbqI1uw==", "requires": { - "@babel/runtime": "^7.8.7", + "@babel/runtime": "^7.9.6", "fn-name": "~3.0.0", "lodash": "^4.17.15", "lodash-es": "^4.17.11", - "property-expr": "^2.0.0", + "property-expr": "^2.0.2", "synchronous-promise": "^2.0.10", "toposort": "^2.0.2" }, "dependencies": { "@babel/runtime": { - "version": "7.9.2", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.9.2.tgz", - "integrity": "sha512-NE2DtOdufG7R5vnfQUTehdTfNycfUANEtCa9PssN9O/xmTzP4E08UI797ixaei6hBEVL9BI/PsdJS5x7mWoB9Q==", + "version": "7.10.5", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.10.5.tgz", + "integrity": "sha512-otddXKhdNn7d0ptoFRHtMLa8LqDxLYwTjB4nYgM1yy5N6gU/MUf8zqyyLltCH3yAVitBzmwK4us+DD0l/MauAg==", "requires": { "regenerator-runtime": "^0.13.4" } }, "regenerator-runtime": { - "version": "0.13.5", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", - "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==" + "version": "0.13.7", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz", + "integrity": "sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew==" } } } } -} \ No newline at end of file +} diff --git a/package.json b/package.json index 215caa1..c701fe5 100644 --- a/package.json +++ b/package.json @@ -3,22 +3,22 @@ "version": "0.1.0", "private": true, "dependencies": { - "@material-ui/core": "^4.9.7", + "@material-ui/core": "^4.11.0", "@material-ui/icons": "^4.9.1", - "@material-ui/lab": "^4.0.0-alpha.46", + "@material-ui/lab": "^4.0.0-alpha.56", "@testing-library/jest-dom": "^4.2.4", "@testing-library/react": "^9.5.0", "@testing-library/user-event": "^7.2.1", "axios": "^0.19.2", - "formik": "^2.1.4", + "formik": "^2.1.5", "material-ui": "^0.20.2", "react": "^16.13.1", "react-beautiful-dnd": "^13.0.0", "react-dom": "^16.13.1", "react-os": "0.0.9", - "react-router-dom": "^5.1.2", + "react-router-dom": "^5.2.0", "react-scripts": "3.3.0", - "yup": "^0.28.3" + "yup": "^0.28.5" }, "scripts": { "start": "react-scripts start", @@ -26,6 +26,7 @@ "test": "react-scripts test", "eject": "react-scripts eject" }, + "homepage": "./", "eslintConfig": { "extends": "react-app" }, @@ -41,4 +42,4 @@ "last 1 safari version" ] } -} \ No newline at end of file +} diff --git a/src/components/fieldsAnswerForm/FormFieldCheckbox.js b/src/components/fieldsAnswerForm/FormFieldCheckbox.js index c1e7479..3cb3848 100644 --- a/src/components/fieldsAnswerForm/FormFieldCheckbox.js +++ b/src/components/fieldsAnswerForm/FormFieldCheckbox.js @@ -11,7 +11,7 @@ const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(18), + minHeight: "15%", margin: theme.spacing(2), ["@media (max-width:827px)"]: { width: theme.spacing(70) @@ -101,6 +101,7 @@ function FormFieldCheckbox(props) { return ( <span> <Typography + gutterBottom style={{ wordWrap: "break-word" }} className={classes.text} variant="h7" diff --git a/src/components/fieldsAnswerForm/FormFieldSubform.js b/src/components/fieldsAnswerForm/FormFieldSubform.js index 7a14fb8..e8a139f 100644 --- a/src/components/fieldsAnswerForm/FormFieldSubform.js +++ b/src/components/fieldsAnswerForm/FormFieldSubform.js @@ -44,72 +44,76 @@ function FormFieldSubform(props) { }, []); return ( - <div> - <Grid container direction="column" alignItems="center" justify="center"> - {formData ? ( - <div> - {formData.inputs.map((input, index) => { - if (input.type === 0) - return ( - <FormFieldText - question={input.question} - validation={input.validation} - description={input.description} - id={input.id} - createAnswer={props.createAnswer} - /> - ); - else if (input.type === 3) - return ( - <FormFieldSelect - question={input.question} - validation={input.validation} - id={input.id} - description={input.description} - options={input.sugestions} - createAnswer={props.createAnswer} - /> - ); - else if (input.type === 2) - return ( - <FormFieldRadio - question={input.question} - description={input.description} - id={input.id} - validation={input.validation} - options={input.sugestions} - createAnswer={props.createAnswer} - /> - ); - else if (input.type === 1) - return ( - <FormFieldCheckbox - question={input.question} - description={input.description} - validation={input.validation} - options={input.sugestions} - id={input.id} - createAnswer={props.createAnswer} - /> - ); - else if (input.type === 4) - return ( - <FormFieldSubform - question={input.question} - description={input.description} - options={input.sugestions} - id={input.subForm.contentFormId} - createAnswer={props.createAnswer} - mapInputs={props.mapInputs} - /> - ); - })} - </div> - ) : ( - <p>Loading...</p> - )} - </Grid> - </div> + <Grid + container + direction="column" + item + alignItems="center" + justify="center" + > + {formData ? ( + <div> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + validation={input.validation} + description={input.description} + id={input.id} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + validation={input.validation} + id={input.id} + description={input.description} + options={input.sugestions} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + validation={input.validation} + options={input.sugestions} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + validation={input.validation} + options={input.sugestions} + id={input.id} + createAnswer={props.createAnswer} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + createAnswer={props.createAnswer} + mapInputs={props.mapInputs} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + </Grid> ); } diff --git a/src/components/fieldsAnswerForm/FormFieldTitle.js b/src/components/fieldsAnswerForm/FormFieldTitle.js index 9a41a54..028d969 100644 --- a/src/components/fieldsAnswerForm/FormFieldTitle.js +++ b/src/components/fieldsAnswerForm/FormFieldTitle.js @@ -10,7 +10,6 @@ const useStyles = makeStyles(theme => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - height: "40%", margin: theme.spacing(2), color: "#000000", ["@media (max-width:827px)"]: { diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js index 5c175d1..d83bf41 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js @@ -28,20 +28,17 @@ const useStyles = makeStyles(theme => ({ function FormFieldSelect(props) { const classes = useStyles(); - /** Variable to track if there's an answer. */ - const [hasAnswer, setHasAnswer] = useState(false); - /** * Function to handle the selected answer. */ function handleProps() { + console.log(props.answer); if (props.answer) { - setHasAnswer(true); return props.answer.filter(each => { return each.value === "true"; })[0].placement; } else { - setHasAnswer(false); + return ""; } } @@ -49,9 +46,10 @@ function FormFieldSelect(props) { * Function to prevent page from broking if there's no answer. */ function answer() { - if (hasAnswer) { - return props.options[handleProps()].value; + if (handleProps() === "") { + return ""; } + return props.options[handleProps()].value; } return ( diff --git a/src/components/fieldsListForms/ShareButton.jsx b/src/components/fieldsListForms/ShareButton.jsx index c93a55e..0040628 100644 --- a/src/components/fieldsListForms/ShareButton.jsx +++ b/src/components/fieldsListForms/ShareButton.jsx @@ -40,7 +40,7 @@ function ShareButton(props) { </DialogTitle> <DialogContent> <DialogContentText id="alert-dialog-description"> - http://localhost:3000/#/answer/{props.id} + https://www.genforms.c3sl.ufpr.br/#/answer/{props.id} </DialogContentText> </DialogContent> </Dialog> diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index 1f46fe8..e4b535e 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -27,6 +27,7 @@ const useStyles = makeStyles(theme => ({ button: { type: "submit", width: "100%", + marginBottom: "50px", background: "#6ec46c", borderRadius: "2px", padding: "10px 20px", @@ -37,30 +38,14 @@ const useStyles = makeStyles(theme => ({ }, pageBody: { minHeight: "calc(100vh - 92.4px - 78px)", - paddingBottom: "78px" + paddingBottom: "78px", + flexDirection: "column" + }, + questions: { + marginBottom: "7%" } })); -const theme = createMuiTheme({ - overrides: { - MuiInput: { - underline: { - "&:before": { - borderBottom: "1px solid #35c7fc" - }, - "&:after": { - borderBottom: "1px solid #3f51b5" - } - } - }, - MuiButton: { - label: { - color: "black" - } - } - } -}); - function AnwserForm() { const classes = useStyles(); const history = useHistory(); @@ -231,88 +216,91 @@ function AnwserForm() { }, []); return ( - <MuiThemeProvider theme={theme}> - <div className={classes.pageBody}> - <Grid container direction="column" alignItems="center" justify="center"> - {formData ? ( - <div> - <FormFieldTitle - title={formData.title} - description={formData.description} - /> - {formData.inputs.map((input, index) => { - if (input.type === 0) - return ( - <FormFieldText - question={input.question} - validation={input.validation} - description={input.description} - id={input.id} - createAnswer={createAnswer} - /> - ); - else if (input.type === 3) - return ( - <FormFieldSelect - question={input.question} - validation={input.validation} - id={input.id} - description={input.description} - options={input.sugestions} - createAnswer={createAnswer} - /> - ); - else if (input.type === 2) - return ( - <FormFieldRadio - question={input.question} - description={input.description} - id={input.id} - validation={input.validation} - options={input.sugestions} - createAnswer={createAnswer} - /> - ); - else if (input.type === 1) - return ( - <FormFieldCheckbox - question={input.question} - description={input.description} - validation={input.validation} - options={input.sugestions} - id={input.id} - createAnswer={createAnswer} - /> - ); - else if (input.type === 4) - return ( - <FormFieldSubform - question={input.question} - description={input.description} - options={input.sugestions} - id={input.subForm.contentFormId} - createAnswer={createAnswer} - mapInputs={mapInputs} - /> - ); - })} - </div> - ) : ( - <p>Loading...</p> - )} - <Grid> - <Button - type="submit" - variant="contained" - className={classes.button} - onClick={() => answerForm(id)} - > - Responder - </Button> - </Grid> - </Grid> - </div> - </MuiThemeProvider> + <Grid + className={classes.pageBody} + container + alignItems="center" + justify="center" + > + <Grid item className={classes.questions}> + {formData ? ( + <div> + <FormFieldTitle + title={formData.title} + description={formData.description} + /> + {formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + validation={input.validation} + description={input.description} + id={input.id} + createAnswer={createAnswer} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + validation={input.validation} + id={input.id} + description={input.description} + options={input.sugestions} + createAnswer={createAnswer} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + validation={input.validation} + options={input.sugestions} + createAnswer={createAnswer} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + validation={input.validation} + options={input.sugestions} + id={input.id} + createAnswer={createAnswer} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + createAnswer={createAnswer} + mapInputs={mapInputs} + /> + ); + })} + </div> + ) : ( + <p>Loading...</p> + )} + </Grid> + <Grid> + <Button + type="submit" + variant="contained" + className={classes.button} + onClick={() => answerForm(id)} + > + Responder + </Button> + </Grid> + </Grid> ); } -- GitLab From 3484d6c710595624f1ace5ae4cbd8a461d985c6e Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Wed, 19 Aug 2020 12:24:12 -0300 Subject: [PATCH 43/72] Issue #24:Minor fixes in footer and header Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/components/footer/footer.js | 2 +- src/components/header/header.jsx | 28 +++++-------------- .../header/header_components/MenuList.jsx | 1 + src/pages/SignUp.js | 4 +-- 4 files changed, 11 insertions(+), 24 deletions(-) diff --git a/src/components/footer/footer.js b/src/components/footer/footer.js index f538dca..f4f56ca 100644 --- a/src/components/footer/footer.js +++ b/src/components/footer/footer.js @@ -7,8 +7,8 @@ import Logo from "./c3sl.png"; const useStyles = makeStyles(theme => ({ footer: { background: "#66a6c2", - position: "fixed", left: 0, + position: "fixed", bottom: 0, right: 0, width: "100%", diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 8a52a8c..64486a9 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -1,5 +1,6 @@ import React from "react"; import Grid from "@material-ui/core/Grid"; +import { useHistory } from "react-router-dom"; import logo from "./header_imgs/imgsimmc-01.png"; import { makeStyles } from "@material-ui/core"; import MenuListComposition from "./header_components/MenuList"; @@ -59,6 +60,7 @@ const useStyles = makeStyles(theme => ({ export default function Header() { const classes = useStyles(); const [isLoged, setIsLoged] = React.useState(checkLoged()); + const history = useHistory(); function checkLoged() { if (window.sessionStorage.getItem("token")) { @@ -107,27 +109,11 @@ export default function Header() { </Grid> </Grid> <Grid container item xs={6} sm={6} md={4} justify="center"> - {isLoged ? ( - <a - href="http://localhost:3000/#/signup" - title="Ir para a página de SignUp" - className={classes.link} - > - <h2 className={classes.form_creator}> - Gerenciador de Formulários - </h2> - </a> - ) : ( - <a - href="http://localhost:3000/#/signin" - title="Ir para a página de SignIn" - className={classes.link} - > - <h2 className={classes.form_creator}> - Gerenciador de Formulários - </h2> - </a> - )} + <a className={classes.link}> + <h2 className={classes.form_creator}> + Gerenciador de Formulários + </h2> + </a> </Grid> <Grid container diff --git a/src/components/header/header_components/MenuList.jsx b/src/components/header/header_components/MenuList.jsx index 21bd701..7f7d54c 100644 --- a/src/components/header/header_components/MenuList.jsx +++ b/src/components/header/header_components/MenuList.jsx @@ -60,6 +60,7 @@ function MenuListComposition(props) { if (window.sessionStorage.getItem("userId")) { let path = `/list/${window.sessionStorage.getItem("userId")}`; history.push(path); + return; } alert("Você não está logado."); diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index 97472a8..1a894a0 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -15,8 +15,8 @@ const useStyles = makeStyles(theme => ({ background: "#ffffff", borderRadius: "2px", padding: "2% 1%", + marginTop: "3%", margin: "0 auto", - marginTop: "9%", width: "95%" }, custom_strong: { @@ -30,7 +30,6 @@ const useStyles = makeStyles(theme => ({ color: "#c2c6ca" }, form: { - marginTop: "3%", alignItems: "center", textAlign: "center" }, @@ -38,6 +37,7 @@ const useStyles = makeStyles(theme => ({ type: "submit", width: "30%", marginTop: "4%", + marginBottom: "10%", background: "#6ec46c", borderRadius: "2px", padding: "10px 20px", -- GitLab From 928d418e94d00767baa5d0ca51835c6a1e1af91d Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Tue, 1 Sep 2020 09:01:16 -0300 Subject: [PATCH 44/72] Issue #26: Fixing Regex Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/components/fieldsSignUp/FormInput.jsx | 1 - src/contexts/useForm.js | 30 +++--- src/pages/SignIn.js | 54 +++++----- src/pages/SignUp.js | 114 ++++++++++------------ 4 files changed, 95 insertions(+), 104 deletions(-) diff --git a/src/components/fieldsSignUp/FormInput.jsx b/src/components/fieldsSignUp/FormInput.jsx index 972941d..3fa0c7e 100644 --- a/src/components/fieldsSignUp/FormInput.jsx +++ b/src/components/fieldsSignUp/FormInput.jsx @@ -21,7 +21,6 @@ function FormInput(props) { : "text" } autoComplete="off" - onFocusOut={props.verify} ></TextField> ); } diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js index d7b17c2..e349fad 100644 --- a/src/contexts/useForm.js +++ b/src/contexts/useForm.js @@ -8,7 +8,7 @@ import { selectOptionsTesting, testSubformSchema, selectOptionTextTesting, - testTextValidation + testTextValidation, } from "../components/fieldsDisplayForm/utils/schemas"; import { pushTitle, @@ -16,7 +16,7 @@ import { pushSelect, pushRadio, pushCheckbox, - pushSubform + pushSubform, } from "../components/fieldsDisplayForm/utils/FormComposition"; import api from "../api"; @@ -238,7 +238,7 @@ const useForm = () => { */ async function setId() { const fetchData = async () => { - await api.get(`/form/${routeId}`).then(async function(res) { + await api.get(`/form/${routeId}`).then(async function (res) { let backForm = createFrontendForm(res.data); for (let i = 1; i < backForm.length; i++) { for (let j = 1; j < form.length; j++) { @@ -248,13 +248,13 @@ const useForm = () => { "question", "description", "options", - "subformId" + "subformId", ]) !== JSON.stringify(form[j], [ "question", "description", "options", - "subformId" + "subformId", ]) || differentValidation(backForm[i], form[j]) ) { @@ -279,14 +279,14 @@ const useForm = () => { const post_response = await api .put(`/form/${routeId}`, data, { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}` - } + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, }) - .then(function(error) { + .then(function (error) { if (!error.response) alert("Seu formulário foi atualizado com sucesso."); }) - .catch(function(error) { + .catch(function (error) { if (error.response.status === 401) { let path = `/signin`; history.push(path); @@ -304,15 +304,13 @@ const useForm = () => { const post_response = await api .post(`/form`, await createBackendForm(form), { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}` - } + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, }) - .then(function(error) { + .then(function (error) { if (!error.response) alert("Seu formulário foi criado com sucesso."); - else console.log("ERROR NO POST_RESPONSE", error); }) - .catch(function(error) { - console.log("ERROR NO POST RESPONSE", error.response); + .catch(function (error) { alert("Um erro ocorreu."); }); } @@ -338,7 +336,7 @@ const useForm = () => { setValidationValue, removeValidation, onDragEnd, - submit + submit, }; }; diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index c3c9244..c86bc00 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -9,7 +9,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -17,22 +17,22 @@ const useStyles = makeStyles(theme => ({ padding: "2% 1%", margin: "0 auto", marginTop: "9%", - width: "95%" + width: "95%", }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d" + color: "#46525d", }, strong_description: { fontSize: "14px", - color: "#c2c6ca" + color: "#c2c6ca", }, form: { marginTop: "3%", alignItems: "center", - textAlign: "center" + textAlign: "center", }, button: { type: "submit", @@ -43,12 +43,12 @@ const useStyles = makeStyles(theme => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)" + backgroundColor: "rgb(25, 109, 23)", }, ["@media (max-width:550px)"]: { - width: "55%" - } - } + width: "55%", + }, + }, })); export default function SignIn() { const classes = useStyles(); @@ -56,13 +56,13 @@ export default function SignIn() { const [values, setValues] = React.useState({ email: "", password: "", - emailError: false + emailError: false, }); async function update(prop, event) { await setValues({ ...values, [prop]: event.target.value }); } - const handleChange = prop => event => { + const handleChange = (prop) => (event) => { if (!checkEmail()) { values.emailError = true; } else { @@ -71,10 +71,11 @@ export default function SignIn() { update(prop, event); }; function checkEmail() { - if (/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\.[A-Za-z]+$/.test(values.email)) { - return true; - } - return false; + return values.email + ? /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/.test(values.email) + ? true + : false + : true; } function verifyValues() { if (values.email && values.password) { @@ -95,9 +96,9 @@ export default function SignIn() { const response = await api .post(`/user/signIn`, { email: values.email, - hash: values.password + hash: values.password, }) - .then(function(response) { + .then(function (response) { if (!response.data.error) { window.sessionStorage.setItem("token", response.data.token); window.sessionStorage.setItem("userId", response.data.id); @@ -105,7 +106,7 @@ export default function SignIn() { history.push(path); } }) - .catch(function(error) { + .catch(function (error) { if (error.response) { alert( "Falha de autenticação. Certifique-se que email e senha estão corretos." @@ -123,19 +124,19 @@ export default function SignIn() { const theme = createMuiTheme({ overrides: { root: { - color: "white" + color: "white", }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc" + borderBottom: "1px solid #35c7fc", }, "&:after": { - borderBottom: "1px solid #3f51b5" - } - } - } - } + borderBottom: "1px solid #3f51b5", + }, + }, + }, + }, }); return ( <MuiThemeProvider theme={theme}> @@ -152,8 +153,7 @@ export default function SignIn() { label="E-mail" param="email" onUpdate={handleChange} - verify={checkEmail} - error={values.emailError} + error={!checkEmail()} /> </Grid> <Grid> diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index 1a894a0..f470639 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -1,4 +1,4 @@ -import React from "react"; +import React, { useEffect } from "react"; import Grid from "@material-ui/core/Grid"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import IconButton from "@material-ui/core/IconButton"; @@ -9,7 +9,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -17,21 +17,21 @@ const useStyles = makeStyles(theme => ({ padding: "2% 1%", marginTop: "3%", margin: "0 auto", - width: "95%" + width: "95%", }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d" + color: "#46525d", }, strong_description: { fontSize: "14px", - color: "#c2c6ca" + color: "#c2c6ca", }, form: { alignItems: "center", - textAlign: "center" + textAlign: "center", }, button: { type: "submit", @@ -43,45 +43,34 @@ const useStyles = makeStyles(theme => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)" + backgroundColor: "rgb(25, 109, 23)", }, ["@media (max-width:550px)"]: { - width: "55%" - } - } + width: "55%", + }, + }, })); export default function SignUp() { const history = useHistory(); const classes = useStyles(); + const [values, setValues] = React.useState({ name: "", email: "", password: "", password_confirm: "", nameError: false, - emailError: false + emailError: false, }); - async function update(prop, event) { - await setValues({ ...values, [prop]: event.target.value }); - } + useEffect(() => { + !checkName() ? (values.nameError = true) : (values.nameError = false); + }, [values.name]); + useEffect(() => { + !checkEmail() ? (values.emailError = true) : (values.emailError = false); + }, [values.email]); - const handleChange = prop => event => { - switch (prop) { - case "name": - if (!checkName()) { - values.nameError = true; - } else { - values.nameError = false; - } - break; - case "email": - if (!checkEmail()) { - values.emailError = true; - } else { - values.emailError = false; - } - } - update(prop, event); + const handleChange = (prop) => (event) => { + setValues({ ...values, [prop]: event.target.value }); }; function checkPassword() { if (values.password !== values.password_confirm) { @@ -91,20 +80,19 @@ export default function SignUp() { return true; } function checkName() { - if ( - /^[a-zA-Z ]+$/.test(values.name) && - !/^$|\s+/.test(values.name) && - values.name.length <= 225 - ) { - return true; - } - return false; + return values.name + ? /^[A-Za-záà âãéèêÃïóôõöúçñÃÀÂÃÉÈÃÃÓÔÕÖÚÇÑ ]+$/.test(values.name) && + values.name.length <= 225 + ? true + : false + : true; } function checkEmail() { - if (/^[a-zA-Z0-9._-]+@[a-zA-Z0-9]+\.[A-Za-z]+$/.test(values.email)) { - return true; - } - return false; + return values.email + ? /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/.test(values.email) + ? true + : false + : true; } function verifyValues() { if ( @@ -113,7 +101,9 @@ export default function SignUp() { values.password && values.password_confirm ) { - return true; + if (verifyValuesContent()) { + return true; + } else return false; } return false; } @@ -136,15 +126,15 @@ export default function SignUp() { .post(`/user/signUp`, { email: values.email, name: values.name, - hash: values.password + hash: values.password, }) - .then(function(error) { + .then(function (error) { if (!error.response) { let path = `signin`; history.push(path); } }) - .catch(function(error) { + .catch(function (error) { if (error.response) { switch (error.response.data.error) { case 'duplicate key value violates unique constraint "form_user_name_key"': @@ -166,27 +156,25 @@ export default function SignUp() { } function submit() { if (verifyValues()) { - if (verifyValuesContent()) { - handleSubmit(); - } + handleSubmit(); } } const theme = createMuiTheme({ overrides: { root: { - color: "white" + color: "white", }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc" + borderBottom: "1px solid #35c7fc", }, "&:after": { - borderBottom: "1px solid #3f51b5" - } - } - } - } + borderBottom: "1px solid #3f51b5", + }, + }, + }, + }, }); return ( <MuiThemeProvider theme={theme}> @@ -203,7 +191,7 @@ export default function SignUp() { label="Nome Completo" param="name" onUpdate={handleChange} - error={values.nameError} + error={!checkName()} /> </Grid> <Grid> @@ -211,8 +199,7 @@ export default function SignUp() { label="E-mail" param="email" onUpdate={handleChange} - verify={checkEmail} - error={values.emailError} + error={!checkEmail()} /> </Grid> <Grid> @@ -223,6 +210,13 @@ export default function SignUp() { label="Confirmar Senha" param="password_confirm" onUpdate={handleChange} + error={ + values.password_confirm + ? values.password === values.password_confirm + ? false + : true + : false + } /> </Grid> <Grid> -- GitLab From ff041f164de44c47defef7533fb3678dd3ac7b63 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Thu, 10 Sep 2020 09:55:55 -0300 Subject: [PATCH 45/72] Issue #27:Fix redirects in signIn and signUp --- src/App.js | 9 ++- .../fieldsListForms/ShareButton.jsx | 2 +- src/pages/ListForms.js | 45 ++++++++------ src/pages/SignIn.js | 16 ++++- src/pages/SignUp.js | 60 ++++++++++++------- 5 files changed, 86 insertions(+), 46 deletions(-) diff --git a/src/App.js b/src/App.js index be756c9..a0e2b1b 100644 --- a/src/App.js +++ b/src/App.js @@ -1,5 +1,5 @@ import React from "react"; -import { HashRouter, Route } from "react-router-dom"; +import { HashRouter, Route, Redirect } from "react-router-dom"; import "./global.css"; import CreateForm from "./pages/CreateForm"; import AnswerForm from "./pages/AnswerForm"; @@ -15,12 +15,15 @@ function App() { return ( <HashRouter> <Header /> + <Route exact path="/"> + <Redirect to="/SignIn" /> + </Route> + <Route path="/SignUp" component={SignUp} /> + <Route path="/SignIn" component={SignIn} /> <Route path="/visualize/:id" component={VisualizeForm} /> <Route path="/create" component={CreateForm} /> <Route path="/answer/:id" component={AnswerForm} /> <Route path="/edit/:id" component={EditForm} /> - <Route path="/SignUp" component={SignUp} /> - <Route path="/SignIn" component={SignIn} /> <Route path="/list/:id" component={ListForms} /> <Route path="/form/:id" component={GetForm} /> <Footer /> diff --git a/src/components/fieldsListForms/ShareButton.jsx b/src/components/fieldsListForms/ShareButton.jsx index 0040628..3d94dd6 100644 --- a/src/components/fieldsListForms/ShareButton.jsx +++ b/src/components/fieldsListForms/ShareButton.jsx @@ -40,7 +40,7 @@ function ShareButton(props) { </DialogTitle> <DialogContent> <DialogContentText id="alert-dialog-description"> - https://www.genforms.c3sl.ufpr.br/#/answer/{props.id} + https://genforms.c3sl.ufpr.br/#/answer/{props.id} </DialogContentText> </DialogContent> </Dialog> diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index 2c97add..70732de 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -12,6 +12,12 @@ import Tab from "../components/fieldsListForms/Tab.jsx"; const useStyles = makeStyles(theme => ({ body: { marginBottom: "15%" + }, + + Forms: { + textAlign: "center", + marginBottom: "3%", + fontSize: "20px" } })); export default function ListForms() { @@ -97,24 +103,27 @@ export default function ListForms() { }, []); return isLoaded ? ( - <div> - <Tab sort={sort} searching={searching} /> - <Container> - <Grid container spacing={3} className={classes.body}> - {auxForms.map(form => ( - <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> - <CardForm - id={form.id} - title={form.title} - description={form.description} - numberOfAnswers={form.answersNumber} - date={form.date} - /> - </Grid> - ))} - </Grid> - </Container> - </div> + <> + <div> + <Tab sort={sort} searching={searching} /> + <Container> + <Grid className={classes.Forms}>Seus Formulários:</Grid> + <Grid container spacing={3} className={classes.body}> + {auxForms.map(form => ( + <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> + <CardForm + id={form.id} + title={form.title} + description={form.description} + numberOfAnswers={form.answersNumber} + date={form.date} + /> + </Grid> + ))} + </Grid> + </Container> + </div> + </> ) : ( <Grid justify="center"> <p>loading...</p> diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index c86bc00..f34aacc 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -1,5 +1,6 @@ import React from "react"; import { useHistory } from "react-router-dom"; +import { Redirect } from "react-router-dom"; import Grid from "@material-ui/core/Grid"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import IconButton from "@material-ui/core/IconButton"; @@ -34,6 +35,9 @@ const useStyles = makeStyles((theme) => ({ alignItems: "center", textAlign: "center", }, + noAcc: { + marginTop: "10px" + }, button: { type: "submit", width: "30%", @@ -53,6 +57,9 @@ const useStyles = makeStyles((theme) => ({ export default function SignIn() { const classes = useStyles(); const history = useHistory(); + const [isLoged, setIsLoged] = React.useState( + window.sessionStorage.getItem("token") + ); const [values, setValues] = React.useState({ email: "", password: "", @@ -138,7 +145,9 @@ export default function SignIn() { }, }, }); - return ( + return isLoged ? ( + <Redirect to={`/list/${window.sessionStorage.getItem("userId")}`} /> + ) : ( <MuiThemeProvider theme={theme}> <Paper className={classes.register} justify="center"> <strong className={classes.custom_strong}> @@ -159,6 +168,11 @@ export default function SignIn() { <Grid> <FormInput label="Senha" param="password" onUpdate={handleChange} /> </Grid> + <Grid className={classes.noAcc}> + <a href="https://genforms.c3sl.ufpr.br/#/signup"> + Não é cadastrado? + </a> + </Grid> <Grid> <IconButton type="submit" diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index f470639..ef6b531 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -1,5 +1,6 @@ import React, { useEffect } from "react"; import Grid from "@material-ui/core/Grid"; +import { Redirect } from "react-router-dom"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import IconButton from "@material-ui/core/IconButton"; import { useHistory } from "react-router-dom"; @@ -9,7 +10,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -17,21 +18,24 @@ const useStyles = makeStyles((theme) => ({ padding: "2% 1%", marginTop: "3%", margin: "0 auto", - width: "95%", + width: "95%" }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d", + color: "#46525d" }, strong_description: { fontSize: "14px", - color: "#c2c6ca", + color: "#c2c6ca" }, form: { alignItems: "center", - textAlign: "center", + textAlign: "center" + }, + alreadyAcc: { + marginTop: "10px" }, button: { type: "submit", @@ -43,24 +47,26 @@ const useStyles = makeStyles((theme) => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)", + backgroundColor: "rgb(25, 109, 23)" }, ["@media (max-width:550px)"]: { - width: "55%", - }, - }, + width: "55%" + } + } })); export default function SignUp() { const history = useHistory(); const classes = useStyles(); - + const [isLoged, setIsLoged] = React.useState( + window.sessionStorage.getItem("token") + ); const [values, setValues] = React.useState({ name: "", email: "", password: "", password_confirm: "", nameError: false, - emailError: false, + emailError: false }); useEffect(() => { !checkName() ? (values.nameError = true) : (values.nameError = false); @@ -69,7 +75,7 @@ export default function SignUp() { !checkEmail() ? (values.emailError = true) : (values.emailError = false); }, [values.email]); - const handleChange = (prop) => (event) => { + const handleChange = prop => event => { setValues({ ...values, [prop]: event.target.value }); }; function checkPassword() { @@ -87,6 +93,7 @@ export default function SignUp() { : false : true; } + function checkEmail() { return values.email ? /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/.test(values.email) @@ -126,15 +133,15 @@ export default function SignUp() { .post(`/user/signUp`, { email: values.email, name: values.name, - hash: values.password, + hash: values.password }) - .then(function (error) { + .then(function(error) { if (!error.response) { let path = `signin`; history.push(path); } }) - .catch(function (error) { + .catch(function(error) { if (error.response) { switch (error.response.data.error) { case 'duplicate key value violates unique constraint "form_user_name_key"': @@ -162,21 +169,23 @@ export default function SignUp() { const theme = createMuiTheme({ overrides: { root: { - color: "white", + color: "white" }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc", + borderBottom: "1px solid #35c7fc" }, "&:after": { - borderBottom: "1px solid #3f51b5", - }, - }, - }, - }, + borderBottom: "1px solid #3f51b5" + } + } + } + } }); - return ( + return isLoged ? ( + <Redirect to="/signin" /> + ) : ( <MuiThemeProvider theme={theme}> <Paper className={classes.register} justify="center"> <strong className={classes.custom_strong}> @@ -219,6 +228,11 @@ export default function SignUp() { } /> </Grid> + <Grid className={classes.alreadyAcc}> + <a href="https://genforms.c3sl.ufpr.br/#/signin"> + Já é cadastrado? + </a> + </Grid> <Grid> <IconButton type="submit" -- GitLab From ce67dc0f9e225cacc128223e7f896e0a3859a4f9 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 10 Sep 2020 10:51:33 -0300 Subject: [PATCH 46/72] Issue #28: Fix mouse being pushed in /create and /edit Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- .../fieldsDisplayForm/utils/schemas.js | 69 ++++++------------- src/contexts/useForm.js | 8 +-- 2 files changed, 24 insertions(+), 53 deletions(-) diff --git a/src/components/fieldsDisplayForm/utils/schemas.js b/src/components/fieldsDisplayForm/utils/schemas.js index 3ec954c..ce0fffa 100644 --- a/src/components/fieldsDisplayForm/utils/schemas.js +++ b/src/components/fieldsDisplayForm/utils/schemas.js @@ -1,42 +1,23 @@ import * as Yup from "yup"; /** The validation through Yup is schema based, so there are schemas and it's validations. */ -/** Schema to validate the question field from every form array object. */ -const questionTextSchema = Yup.string() - .required("Este campo é obrigatório!") - .test("alphabets", "O caractere não é permitido", (value) => { - return /^[A-Za-z!?$%,. 1234567890à èìòùáéÃóúâêîôûãõç]+$/.test(value); - }); +/**Function that compares the value with a regex, to assure the input is valid */ +function checkText(value) { + return /^[A-Za-z!?$%,. 1234567890à èìòùáéÃóúâêîôûãõç]+$/.test(value); +} /** Function that applies the validation of it's used schema and sets the error messages. */ -export async function testQuestionTextSchema(form, value, index) { - await questionTextSchema - .validate(value) - .then((x) => { - form[index].error.errorMsg.question = ""; - }) - .catch((err) => { - form[index].error.errorMsg.question = err.message; - }); +export async function testQuestionTextSchema(error, value) { + value + ? checkText(value) + ? (error.errorMsg.question = "") + : (error.errorMsg.question = "O caractere não é permitido") + : (error.errorMsg.question = "Este campo é obrigatório!"); } -/** Schema to validate the description field from every form array object. */ -const descriptionTextSchema = Yup.string().test( - "alphabets", - "O caractere não é permitido", - (value) => { - if (!value) return true; - return /^[A-Za-z!?$%,. 1234567890à èìòùáéÃóúâêîôûãõ\b- ]+$/.test(value); - } -); /** Function that applies the validation of it's used schema and sets the error messages. */ -export async function testDescriptionTextSchema(form, value, index) { - await descriptionTextSchema - .validate(value) - .then((x) => { - form[index].error.errorMsg.description = ""; - }) - .catch((err) => { - form[index].error.errorMsg.description = err.message; - }); +export async function testDescriptionTextSchema(error, value) { + value && checkText(value) + ? (error.errorMsg.description = "") + : (error.errorMsg.description = "O caractere não é permitido"); } /** Schema to validate the number of options at options field from FormFieldSelect, FormFieldCheckbox and FormFieldRadio. */ const selectOptionsSchema = Yup.array() @@ -87,23 +68,13 @@ export async function testSubformSchema(form, index) { form[index].error.errorMsg.subformUsage = err.message; }); } -/** Schema to validate the content of the options field from FormFieldSelect, FormFieldCheckbox and FormFieldRadio. */ -const optSchema = Yup.string() - .required("Por favor, preencha esta opção") - .test("alphabets", "O caractere não é permitido", (value) => { - if (!value) return true; - return /^[A-Za-z!?$%,. à èìòùáéÃóúâêîôûãõ\b- ]+$/.test(value); - }); /** Function that applies the validation of it's used schema and sets the error messages. */ -export async function selectOptionTextTesting(form, value, index, idopt) { - await optSchema - .validate(value) - .then((x) => { - form[index].error.errorMsg.options[idopt] = ""; - }) - .catch((err) => { - form[index].error.errorMsg.options[idopt] = err.message; - }); +export async function selectOptionTextTesting(error, value, idopt) { + value + ? checkText(value) + ? (error.errorMsg.options[idopt] = "") + : (error.errorMsg.options[idopt] = "O caractere não é permitido") + : (error.errorMsg.options[idopt] = "Por favor, preencha esta opção"); } /** Schema to validate the quantity field of the validation from FormFieldText. */ const textValidationSchema = Yup.string() diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js index e349fad..3d0bdbf 100644 --- a/src/contexts/useForm.js +++ b/src/contexts/useForm.js @@ -138,7 +138,7 @@ const useForm = () => { */ async function setQuestionField(value, index) { form[index].question = value; - await testQuestionTextSchema(form, value, index); + testQuestionTextSchema(form[index].error, value); setForm([...form]); } @@ -148,7 +148,7 @@ const useForm = () => { */ async function setDescriptionField(value, index) { form[index].description = value; - await testDescriptionTextSchema(form, value, index); + testDescriptionTextSchema(form[index].error, value); setForm([...form]); } @@ -157,9 +157,9 @@ const useForm = () => { * @param index - the position on the array that the operation needs to be done; * @param idopt - the id of the options being changed, inside the form[index]. */ - async function setSelectOption(value, index, idopt) { + function setSelectOption(value, index, idopt) { form[index].options[idopt] = value; - await selectOptionTextTesting(form, value, index, idopt); + selectOptionTextTesting(form[index].error, value, idopt); setForm([...form]); } -- GitLab From 14e0bc3963b276afe8f3a6174495f798189df0c9 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Thu, 10 Sep 2020 12:42:52 -0300 Subject: [PATCH 47/72] Issue #30: Add redirects and adjusting others Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/components/header/header.jsx | 6 ++++- src/contexts/useForm.js | 39 +++++++++++++++++++------------- 2 files changed, 28 insertions(+), 17 deletions(-) diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 64486a9..8c66485 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -109,7 +109,11 @@ export default function Header() { </Grid> </Grid> <Grid container item xs={6} sm={6} md={4} justify="center"> - <a className={classes.link}> + <a + href="https://genforms.c3sl.ufpr.br/" + title="Home" + className={classes.link} + > <h2 className={classes.form_creator}> Gerenciador de Formulários </h2> diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js index 3d0bdbf..03c0d60 100644 --- a/src/contexts/useForm.js +++ b/src/contexts/useForm.js @@ -8,7 +8,7 @@ import { selectOptionsTesting, testSubformSchema, selectOptionTextTesting, - testTextValidation, + testTextValidation } from "../components/fieldsDisplayForm/utils/schemas"; import { pushTitle, @@ -16,7 +16,7 @@ import { pushSelect, pushRadio, pushCheckbox, - pushSubform, + pushSubform } from "../components/fieldsDisplayForm/utils/FormComposition"; import api from "../api"; @@ -238,7 +238,7 @@ const useForm = () => { */ async function setId() { const fetchData = async () => { - await api.get(`/form/${routeId}`).then(async function (res) { + await api.get(`/form/${routeId}`).then(async function(res) { let backForm = createFrontendForm(res.data); for (let i = 1; i < backForm.length; i++) { for (let j = 1; j < form.length; j++) { @@ -248,13 +248,13 @@ const useForm = () => { "question", "description", "options", - "subformId", + "subformId" ]) !== JSON.stringify(form[j], [ "question", "description", "options", - "subformId", + "subformId" ]) || differentValidation(backForm[i], form[j]) ) { @@ -279,14 +279,17 @@ const useForm = () => { const post_response = await api .put(`/form/${routeId}`, data, { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}`, - }, + authorization: `bearer ${window.sessionStorage.getItem("token")}` + } }) - .then(function (error) { - if (!error.response) + .then(function(error) { + if (!error.response) { alert("Seu formulário foi atualizado com sucesso."); + let path = `/signin`; + history.push(path); + } }) - .catch(function (error) { + .catch(function(error) { if (error.response.status === 401) { let path = `/signin`; history.push(path); @@ -304,13 +307,17 @@ const useForm = () => { const post_response = await api .post(`/form`, await createBackendForm(form), { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}`, - }, + authorization: `bearer ${window.sessionStorage.getItem("token")}` + } }) - .then(function (error) { - if (!error.response) alert("Seu formulário foi criado com sucesso."); + .then(function(error) { + if (!error.response) { + alert("Seu formulário foi criado com sucesso."); + let path = `/signin`; + history.push(path); + } }) - .catch(function (error) { + .catch(function(error) { alert("Um erro ocorreu."); }); } @@ -336,7 +343,7 @@ const useForm = () => { setValidationValue, removeValidation, onDragEnd, - submit, + submit }; }; -- GitLab From 0b7c7e117a412300c8630c609ed9f8955ba87898 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 3 Sep 2020 11:18:38 -0300 Subject: [PATCH 48/72] Issue #31: Fixing /create and /edit formating Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- .../fieldsDisplayForm/DefaultField.js | 10 ++-- .../fieldsDisplayForm/DisplayForm.js | 10 ++++ .../fieldsDisplayForm/FormFieldCheckbox.js | 3 +- .../fieldsDisplayForm/FormFieldRadio.js | 3 +- .../fieldsDisplayForm/FormFieldSelect.js | 3 +- .../fieldsDisplayForm/FormFieldSubform.js | 2 +- .../fieldsDisplayForm/FormFieldText.js | 52 ++++++++++++++++--- .../fieldsDisplayForm/FormFieldTitle.js | 5 +- src/components/fieldsDisplayForm/SideMenu.js | 12 ++--- 9 files changed, 77 insertions(+), 23 deletions(-) diff --git a/src/components/fieldsDisplayForm/DefaultField.js b/src/components/fieldsDisplayForm/DefaultField.js index 5c2c127..a2bb4c2 100644 --- a/src/components/fieldsDisplayForm/DefaultField.js +++ b/src/components/fieldsDisplayForm/DefaultField.js @@ -27,17 +27,21 @@ export default function DefaultField(props) { <> <Grid item xs={12} sm={6} className={classes.questionsGrid}> <TextField + multiline value={props.question} label="Pergunta" className={classes.textFieldStyle} onChange={(e) => setQuestionField(e.target.value, props.idq)} /> - <Grid className={classes.errorGrid}> - {props.error.errorMsg.question} - </Grid> + {props.error.errorMsg.question && ( + <Grid className={classes.errorGrid}> + {props.error.errorMsg.question} + </Grid> + )} </Grid> <Grid item xs={12} sm={6} className={classes.questionsGrid}> <TextField + multiline value={props.description} label="Descrição" className={classes.textFieldStyle} diff --git a/src/components/fieldsDisplayForm/DisplayForm.js b/src/components/fieldsDisplayForm/DisplayForm.js index 6591e03..a1f257e 100644 --- a/src/components/fieldsDisplayForm/DisplayForm.js +++ b/src/components/fieldsDisplayForm/DisplayForm.js @@ -41,6 +41,15 @@ const useStyles = makeStyles((theme) => ({ marginTop: "-90px", }, }, + sizeFormating: { + ["@media (max-width:600px)"]: { + ["@media (max-width:430px)"]: { + marginLeft: "1%", + width: "95%", + }, + marginLeft: "2%", + }, + }, })); /** CSS style used through Material Ui. */ const theme = createMuiTheme({ @@ -96,6 +105,7 @@ function DisplayForm() { sm={8} direction="column" alignItems="center" + className={classes.sizeFormating} > <Droppable droppableId={columnId}> {(provided, snapshot) => { diff --git a/src/components/fieldsDisplayForm/FormFieldCheckbox.js b/src/components/fieldsDisplayForm/FormFieldCheckbox.js index a35fe25..0595faf 100644 --- a/src/components/fieldsDisplayForm/FormFieldCheckbox.js +++ b/src/components/fieldsDisplayForm/FormFieldCheckbox.js @@ -21,7 +21,7 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:1050px)"]: { width: theme.spacing(63), ["@media (max-width:849px)"]: { - width: "100%", + width: "85%", }, }, marginBottom: "2%", @@ -98,6 +98,7 @@ function FormFieldCheckbox(props) { </Grid> <Grid item xs={8}> <TextField + multiline label={"Opção " + index} value={x} className={classes.textFieldStyle} diff --git a/src/components/fieldsDisplayForm/FormFieldRadio.js b/src/components/fieldsDisplayForm/FormFieldRadio.js index 9abb836..b877721 100644 --- a/src/components/fieldsDisplayForm/FormFieldRadio.js +++ b/src/components/fieldsDisplayForm/FormFieldRadio.js @@ -21,7 +21,7 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:1050px)"]: { width: theme.spacing(63), ["@media (max-width:849px)"]: { - width: "100%", + width: "85%", }, }, marginBottom: "2%", @@ -97,6 +97,7 @@ function FormFieldRadio(props) { </Grid> <Grid item xs={8}> <TextField + multiline label={"Opção " + index} value={x} className={classes.textFieldStyle} diff --git a/src/components/fieldsDisplayForm/FormFieldSelect.js b/src/components/fieldsDisplayForm/FormFieldSelect.js index 1ae1057..959cb50 100644 --- a/src/components/fieldsDisplayForm/FormFieldSelect.js +++ b/src/components/fieldsDisplayForm/FormFieldSelect.js @@ -20,7 +20,7 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:1050px)"]: { width: theme.spacing(63), ["@media (max-width:849px)"]: { - width: "100%", + width: "85%", }, }, marginBottom: "2%", @@ -85,6 +85,7 @@ function FormFieldSelect(props) { <Grid container> <Grid item xs={10}> <TextField + multiline label={"Opção " + index} value={x} className={classes.textFieldStyle} diff --git a/src/components/fieldsDisplayForm/FormFieldSubform.js b/src/components/fieldsDisplayForm/FormFieldSubform.js index 08d4201..cd497ee 100644 --- a/src/components/fieldsDisplayForm/FormFieldSubform.js +++ b/src/components/fieldsDisplayForm/FormFieldSubform.js @@ -20,7 +20,7 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:1050px)"]: { width: theme.spacing(63), ["@media (max-width:849px)"]: { - width: "100%", + width: "85%", }, }, marginBottom: "2%", diff --git a/src/components/fieldsDisplayForm/FormFieldText.js b/src/components/fieldsDisplayForm/FormFieldText.js index 595841d..7c4d19a 100644 --- a/src/components/fieldsDisplayForm/FormFieldText.js +++ b/src/components/fieldsDisplayForm/FormFieldText.js @@ -24,7 +24,7 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:1050px)"]: { width: theme.spacing(63), ["@media (max-width:849px)"]: { - width: "100%", + width: "85%", }, }, marginBottom: "2%", @@ -35,10 +35,17 @@ const useStyles = makeStyles((theme) => ({ questionsGrid: { marginBottom: "20px", }, + validationGrid: { + marginBottom: "20px", + marginLeft: "15%", + ["@media (max-width:600px)"]: { + marginLeft: "0px", + }, + }, errorGrid: { marginTop: "1%", color: "#ff4646", - width: "40%", + width: "80%", fontSize: "13px", }, row: { @@ -49,6 +56,32 @@ const useStyles = makeStyles((theme) => ({ marginTop: "5%", }, }, + selectFormating: { + ["@media (max-width:430px)"]: { + minWidth: "0px", + width: "85%", + }, + minWidth: "250px", + }, + subformSelect: { + ["@media (max-width:430px)"]: { + width: "70%", + fontSize: "76%", + }, + }, + excludeFormating: { + ["@media (max-width:1050px)"]: { + marginLeft: "40%", + }, + }, + excludeFormatingSmall: { + ["@media (max-width:1050px)"]: { + marginLeft: "10%", + }, + ["@media (max-width: 600px)"]: { + marginLeft: "50%", + }, + }, })); /** Main function that returns the content of the option 'question'. */ function FormFieldText(props) { @@ -119,6 +152,7 @@ function FormFieldText(props) { Selecione uma validação </InputLabel> <Select + className={classes.selectFormating} labelId="demo-simple-select-outlined-label" id="demo-simple-select-outlined" onChange={(event) => @@ -126,7 +160,6 @@ function FormFieldText(props) { } value={props.validationType} label="Selecione uma validação" - style={{ minWidth: "250px" }} error={props.validationType ? false : true} > {validationOpts.map((x) => ( @@ -137,9 +170,8 @@ function FormFieldText(props) { </Select> </Grid> {props.validationType ? ( - <Grid item xs={12} sm={5} className={classes.questionsGrid}> + <Grid item xs={12} className={classes.validationGrid}> <TextField - style={{ width: "45%" }} label="Quantidade" value={props.validationValue} onChange={(event) => @@ -151,7 +183,15 @@ function FormFieldText(props) { </Grid> </Grid> ) : null} - <Grid item xs={1}> + <Grid + item + xs={1} + className={ + props.validationType + ? classes.excludeFormatingSmall + : classes.excludeFormating + } + > <Tooltip title="Remover a validação" aria-label="Remover a validação" diff --git a/src/components/fieldsDisplayForm/FormFieldTitle.js b/src/components/fieldsDisplayForm/FormFieldTitle.js index ca1b0c0..e42eeea 100644 --- a/src/components/fieldsDisplayForm/FormFieldTitle.js +++ b/src/components/fieldsDisplayForm/FormFieldTitle.js @@ -13,7 +13,7 @@ const useStyles = makeStyles((theme) => ({ ["@media (max-width:1050px)"]: { width: theme.spacing(63), ["@media (max-width:849px)"]: { - width: "100%", + width: "85%", }, }, marginBottom: "2%", @@ -29,6 +29,7 @@ const useStyles = makeStyles((theme) => ({ }, description: { fontSize: "x-large", + marginBottom: "2%", }, errorGrid: { marginTop: "1%", @@ -46,6 +47,7 @@ function FormFieldText(props) { return ( <Paper className={classes.paper}> <TextField + multiline value={props.question} label="TÃtulo do formulário" fullWidth @@ -64,6 +66,7 @@ function FormFieldText(props) { <Grid item xs={9} className={classes.questionsGrid}> <TextField + multiline value={props.description} label="Descrição do formulário" onChange={(e) => setDescriptionField(e.target.value, props.idq)} diff --git a/src/components/fieldsDisplayForm/SideMenu.js b/src/components/fieldsDisplayForm/SideMenu.js index 1c5764c..51a29fb 100644 --- a/src/components/fieldsDisplayForm/SideMenu.js +++ b/src/components/fieldsDisplayForm/SideMenu.js @@ -41,12 +41,6 @@ const useStyles = makeStyles((theme) => ({ newQuestionGrid: { marginTop: "5%", }, - test: { - display: "flex", - flexDirection: "row", - maxWidth: "190px", - height: "268.5", - }, flex: {}, newQuestionGrid: { ["@media(max-width: 1050px)"]: { @@ -70,7 +64,7 @@ function SideMenu(props) { <h4>Adicionar pergunta:</h4> </Grid> <IconButton - aria-label="add select" + aria-label="add question" type="submit" size="medium" className={classes.addButton} @@ -103,7 +97,7 @@ function SideMenu(props) { }} > <RadioButtonCheckedIcon /> - Múltipla escolha + Seleção Única </IconButton> <IconButton aria-label="add checkbox" @@ -115,7 +109,7 @@ function SideMenu(props) { }} > <CheckBoxOutlineBlankIcon /> - Seleção Única + Múltipla Escolha </IconButton> <IconButton aria-label="add subform" -- GitLab From dfd372d5c25665dbbc728af2b228aed8cb1ddecd Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 17 Sep 2020 10:09:35 -0300 Subject: [PATCH 49/72] Issue #43: general /create and /edit fixes Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- .../fieldsDisplayForm/FieldFooterOptions.js | 36 ++--- .../fieldsDisplayForm/FormFieldCheckbox.js | 3 + .../fieldsDisplayForm/FormFieldRadio.js | 3 + .../fieldsDisplayForm/FormFieldSelect.js | 3 + .../fieldsDisplayForm/FormFieldSubform.js | 10 +- .../fieldsDisplayForm/FormFieldText.js | 7 +- .../fieldsDisplayForm/FormFieldTitle.js | 7 +- src/components/fieldsDisplayForm/SideMenu.js | 143 ++++++++++-------- .../utils/FormComposition.js | 2 - .../fieldsDisplayForm/utils/schemas.js | 8 +- src/components/header/header.jsx | 28 ++-- src/pages/SignIn.js | 2 +- 12 files changed, 143 insertions(+), 109 deletions(-) diff --git a/src/components/fieldsDisplayForm/FieldFooterOptions.js b/src/components/fieldsDisplayForm/FieldFooterOptions.js index b7a8b91..7cea2c3 100644 --- a/src/components/fieldsDisplayForm/FieldFooterOptions.js +++ b/src/components/fieldsDisplayForm/FieldFooterOptions.js @@ -14,23 +14,25 @@ function FieldFooterOptions(props) { const { setRequiredField, deleteFromForm } = useForm(); return ( <Grid> - <FormControlLabel - control={ - <Tooltip - title="Marcar como obrigatório" - aria-label="Marcar como obrigatório" - > - <Switch - onChange={(e) => setRequiredField(props.idq)} - value="required" - color="primary" - checked={props.required} - /> - </Tooltip> - } - style={{ size: "0px" }} - label="Obrigatória" - /> + {!props.subform && ( + <FormControlLabel + control={ + <Tooltip + title="Marcar como obrigatório" + aria-label="Marcar como obrigatório" + > + <Switch + onChange={(e) => setRequiredField(props.idq)} + value="required" + color="primary" + checked={props.required} + /> + </Tooltip> + } + style={{ size: "0px" }} + label="Obrigatória" + /> + )} <Tooltip title="Remover a pergunta" aria-label="Remover a pergunta"> <IconButton aria-label="Remover a pergunta" diff --git a/src/components/fieldsDisplayForm/FormFieldCheckbox.js b/src/components/fieldsDisplayForm/FormFieldCheckbox.js index 0595faf..36849f7 100644 --- a/src/components/fieldsDisplayForm/FormFieldCheckbox.js +++ b/src/components/fieldsDisplayForm/FormFieldCheckbox.js @@ -62,6 +62,9 @@ function FormFieldCheckbox(props) { {...provided.draggableProps} {...provided.dragHandleProps} > + <Grid container item xs={12} justify="center"> + <h4>Múltipla Escolha</h4> + </Grid> <Grid container> <DefaultField question={props.question} diff --git a/src/components/fieldsDisplayForm/FormFieldRadio.js b/src/components/fieldsDisplayForm/FormFieldRadio.js index b877721..ab98b69 100644 --- a/src/components/fieldsDisplayForm/FormFieldRadio.js +++ b/src/components/fieldsDisplayForm/FormFieldRadio.js @@ -61,6 +61,9 @@ function FormFieldRadio(props) { {...provided.draggableProps} {...provided.dragHandleProps} > + <Grid container item xs={12} justify="center"> + <h4>Seleção Única</h4> + </Grid> <Grid container> <DefaultField question={props.question} diff --git a/src/components/fieldsDisplayForm/FormFieldSelect.js b/src/components/fieldsDisplayForm/FormFieldSelect.js index 959cb50..55d8727 100644 --- a/src/components/fieldsDisplayForm/FormFieldSelect.js +++ b/src/components/fieldsDisplayForm/FormFieldSelect.js @@ -63,6 +63,9 @@ function FormFieldSelect(props) { {...provided.draggableProps} {...provided.dragHandleProps} > + <Grid container item xs={12} justify="center"> + <h4>Lista Suspensa</h4> + </Grid> <Grid container> <DefaultField question={props.question} diff --git a/src/components/fieldsDisplayForm/FormFieldSubform.js b/src/components/fieldsDisplayForm/FormFieldSubform.js index cd497ee..9a3422c 100644 --- a/src/components/fieldsDisplayForm/FormFieldSubform.js +++ b/src/components/fieldsDisplayForm/FormFieldSubform.js @@ -134,13 +134,8 @@ export default function FormFieldSubform(props) { > <Grid container> <Grid container item> - <Grid container item xs={12}> - <DefaultField - question={props.question} - description={props.description} - idq={props.idq} - error={props.error} - /> + <Grid container item xs={12} justify="center"> + <h4>Subformulário</h4> </Grid> </Grid> <Grid item xs={12} sm={6} className={classes.questionsGrid}> @@ -166,6 +161,7 @@ export default function FormFieldSubform(props) { className={classes.footerOptsAdjustment} > <FieldFooterOptions + subform={true} idq={props.idq} required={props.validation[0].value} /> diff --git a/src/components/fieldsDisplayForm/FormFieldText.js b/src/components/fieldsDisplayForm/FormFieldText.js index 7c4d19a..b91f185 100644 --- a/src/components/fieldsDisplayForm/FormFieldText.js +++ b/src/components/fieldsDisplayForm/FormFieldText.js @@ -91,8 +91,8 @@ function FormFieldText(props) { * The types are equivalent to the backend. */ const validationOpts = [ - { type: 3, name: "MÃnimo de caracteres", value: "" }, - { type: 4, name: "Máximo de caracteres", value: "" }, + { type: 3, name: "Máximo de caracteres", value: "" }, + { type: 4, name: "MÃnimo de caracteres", value: "" }, ]; /** Importing functions to add, remove and set validations and it's properties. */ const { @@ -111,6 +111,9 @@ function FormFieldText(props) { {...provided.draggableProps} {...provided.dragHandleProps} > + <Grid container item xs={12} justify="center"> + <h4>Caixa de Texto</h4> + </Grid> <Grid container> <DefaultField question={props.question} diff --git a/src/components/fieldsDisplayForm/FormFieldTitle.js b/src/components/fieldsDisplayForm/FormFieldTitle.js index e42eeea..8eff7e5 100644 --- a/src/components/fieldsDisplayForm/FormFieldTitle.js +++ b/src/components/fieldsDisplayForm/FormFieldTitle.js @@ -25,11 +25,14 @@ const useStyles = makeStyles((theme) => ({ marginBottom: "20px", }, title: { - fontSize: "xx-large", + fontSize: "x-large", }, description: { - fontSize: "x-large", + fontSize: "large", marginBottom: "2%", + ["@media (max-width:370px)"]: { + marginBottom: "4%", + }, }, errorGrid: { marginTop: "1%", diff --git a/src/components/fieldsDisplayForm/SideMenu.js b/src/components/fieldsDisplayForm/SideMenu.js index 51a29fb..0ef7863 100644 --- a/src/components/fieldsDisplayForm/SideMenu.js +++ b/src/components/fieldsDisplayForm/SideMenu.js @@ -9,6 +9,7 @@ import { makeStyles } from "@material-ui/core"; import ListAltIcon from "@material-ui/icons/ListAlt"; import TextFieldsIcon from "@material-ui/icons/TextFields"; import useForm from "../../contexts/useForm"; +import Tooltip from "@material-ui/core/Tooltip"; const useStyles = makeStyles((theme) => ({ addButton: { @@ -22,7 +23,9 @@ const useStyles = makeStyles((theme) => ({ }, ["@media(max-width: 1050px)"]: { fontSize: "0", + alignItems: "center", }, + alignItems: "flex-start", }, paper: { ["@media (min-width: 600px)"]: { @@ -57,72 +60,90 @@ function SideMenu(props) { addToFormSubform, } = useForm(); const classes = useStyles(); + const msg = { + text: "Adicionar uma caixa de texto", + susp: "Adicionar lista suspensa", + uniq: "Adicionar seleção única", + mult: "Adicionar múltipla escolha", + sub: "Adicionar subformulário", + }; + return ( <Paper className={classes.paper}> - <Grid item container justify="flex-start" className={classes.outerGrid}> + <Grid item container className={classes.outerGrid}> <Grid className={classes.newQuestionGrid} container justify="center"> <h4>Adicionar pergunta:</h4> </Grid> - <IconButton - aria-label="add question" - type="submit" - size="medium" - className={classes.addButton} - onClick={() => { - addToFormQuestion(); - }} - > - <TextFieldsIcon /> - Caixa de texto - </IconButton> - <IconButton - aria-label="add select" - type="submit" - size="medium" - className={classes.addButton} - onClick={() => { - addToFormSelect(); - }} - > - <ReorderIcon /> - Lista Suspensa - </IconButton> - <IconButton - aria-label="add radio" - type="submit" - size="medium" - className={classes.addButton} - onClick={() => { - addToFormRadio(); - }} - > - <RadioButtonCheckedIcon /> - Seleção Única - </IconButton> - <IconButton - aria-label="add checkbox" - type="submit" - size="medium" - className={classes.addButton} - onClick={() => { - addToFormCheckbox(); - }} - > - <CheckBoxOutlineBlankIcon /> - Múltipla Escolha - </IconButton> - <IconButton - aria-label="add subform" - type="submit" - size="medium" - className={classes.addButton} - onClick={() => { - addToFormSubform(); - }} - > - <ListAltIcon /> - Subformulário - </IconButton> + <Tooltip title={msg.text} aria-label={msg.text}> + <IconButton + aria-label="add question" + type="submit" + size="medium" + className={classes.addButton} + onClick={() => { + addToFormQuestion(); + }} + > + <TextFieldsIcon /> + Caixa de Texto + </IconButton> + </Tooltip> + <Tooltip title={msg.susp} aria-label={msg.susp}> + <IconButton + aria-label="add select" + type="submit" + size="medium" + className={classes.addButton} + onClick={() => { + addToFormSelect(); + }} + > + <ReorderIcon /> + Lista Suspensa + </IconButton> + </Tooltip> + <Tooltip title={msg.uniq} aria-label={msg.uniq}> + <IconButton + aria-label="add radio" + type="submit" + size="medium" + className={classes.addButton} + onClick={() => { + addToFormRadio(); + }} + > + <RadioButtonCheckedIcon /> + Seleção Única + </IconButton> + </Tooltip> + <Tooltip title={msg.mult} aria-label={msg.mult}> + <IconButton + aria-label="add checkbox" + type="submit" + size="medium" + className={classes.addButton} + onClick={() => { + addToFormCheckbox(); + }} + > + <CheckBoxOutlineBlankIcon /> + Múltipla Escolha + </IconButton> + </Tooltip> + <Tooltip title={msg.sub} aria-label={msg.sub}> + <IconButton + aria-label="add subform" + type="submit" + size="medium" + className={classes.addButton} + onClick={() => { + addToFormSubform(); + }} + > + <ListAltIcon /> + Subformulário + </IconButton> + </Tooltip> </Grid> </Paper> ); diff --git a/src/components/fieldsDisplayForm/utils/FormComposition.js b/src/components/fieldsDisplayForm/utils/FormComposition.js index b09b3e7..133b30c 100644 --- a/src/components/fieldsDisplayForm/utils/FormComposition.js +++ b/src/components/fieldsDisplayForm/utils/FormComposition.js @@ -196,8 +196,6 @@ export function pushSubform( inputId: id ? id : null, error: { errorMsg: { - question: question ? "" : "Este campo é obrigatório!", - description: "", subformUsage: "", }, }, diff --git a/src/components/fieldsDisplayForm/utils/schemas.js b/src/components/fieldsDisplayForm/utils/schemas.js index ce0fffa..95c57f6 100644 --- a/src/components/fieldsDisplayForm/utils/schemas.js +++ b/src/components/fieldsDisplayForm/utils/schemas.js @@ -15,9 +15,11 @@ export async function testQuestionTextSchema(error, value) { } /** Function that applies the validation of it's used schema and sets the error messages. */ export async function testDescriptionTextSchema(error, value) { - value && checkText(value) - ? (error.errorMsg.description = "") - : (error.errorMsg.description = "O caractere não é permitido"); + value + ? checkText(value) + ? (error.errorMsg.description = "") + : (error.errorMsg.description = "O caractere não é permitido") + : (error.errorMsg.description = ""); } /** Schema to validate the number of options at options field from FormFieldSelect, FormFieldCheckbox and FormFieldRadio. */ const selectOptionsSchema = Yup.array() diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 8c66485..d532abc 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -5,14 +5,14 @@ import logo from "./header_imgs/imgsimmc-01.png"; import { makeStyles } from "@material-ui/core"; import MenuListComposition from "./header_components/MenuList"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ header: { background: "#05a5dd", width: "auto", display: "flex", flexDirection: "column", justifyContent: "center", - height: "13%" + height: "13%", }, simmc: { marginTop: "5%", @@ -20,8 +20,8 @@ const useStyles = makeStyles(theme => ({ color: "#ffffff", marginLeft: "2%", ["@media (max-width:1040px)"]: { - display: "none" - } + display: "none", + }, }, form_creator: { color: "#ffffff", @@ -30,15 +30,15 @@ const useStyles = makeStyles(theme => ({ fontSize: "21px", ["@media (max-width:525px)"]: { marginTop: "5%", - marginLeft: "10%" + marginLeft: "10%", }, ["@media (max-width:337px)"]: { - fontSize: "19px" - } - } + fontSize: "19px", + }, + }, }, link: { - textDecoration: "none" + textDecoration: "none", }, logo: { marginLeft: "2.5%", @@ -47,14 +47,14 @@ const useStyles = makeStyles(theme => ({ ["@media (max-width:600px)"]: { width: "65px", ["@media (max-width:338px)"]: { - marginTop: "3%" - } - } + marginTop: "3%", + }, + }, }, userImgContainer: { display: "flex", - flexDirection: "column" - } + flexDirection: "column", + }, })); export default function Header() { diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index f34aacc..33ba0f7 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -36,7 +36,7 @@ const useStyles = makeStyles((theme) => ({ textAlign: "center", }, noAcc: { - marginTop: "10px" + marginTop: "10px", }, button: { type: "submit", -- GitLab From 1d37c24f9d470febf7a356878eed5b153d760074 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Fri, 18 Sep 2020 11:27:12 -0300 Subject: [PATCH 50/72] Issue/41: FIX SearchBar now display a not found message Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/components/fieldsListForms/CardForm.jsx | 2 +- src/pages/ListForms.js | 34 +++++++++++++-------- 2 files changed, 23 insertions(+), 13 deletions(-) diff --git a/src/components/fieldsListForms/CardForm.jsx b/src/components/fieldsListForms/CardForm.jsx index 102d08e..da88546 100644 --- a/src/components/fieldsListForms/CardForm.jsx +++ b/src/components/fieldsListForms/CardForm.jsx @@ -65,7 +65,7 @@ const useStyles = makeStyles(theme => ({ numberOfAnswers: { fontSize: 18, - textAlign: "left", + textAlign: "center", margin: "7px" } })); diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index 70732de..d609b39 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -9,6 +9,7 @@ import { useHistory } from "react-router-dom"; // Components import CardForm from "../components/fieldsListForms/CardForm.jsx"; import Tab from "../components/fieldsListForms/Tab.jsx"; +import { Typography } from "@material-ui/core"; const useStyles = makeStyles(theme => ({ body: { marginBottom: "15%" @@ -70,9 +71,10 @@ export default function ListForms() { * @param string - the string value to be searched. */ function searching(string) { + console.log(string); setAuxForms( [...forms].filter(value => { - return value.title.includes(string); + return value.title.toLowerCase().includes(string.toLowerCase()); }) ); } @@ -108,18 +110,26 @@ export default function ListForms() { <Tab sort={sort} searching={searching} /> <Container> <Grid className={classes.Forms}>Seus Formulários:</Grid> - <Grid container spacing={3} className={classes.body}> - {auxForms.map(form => ( - <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> - <CardForm - id={form.id} - title={form.title} - description={form.description} - numberOfAnswers={form.answersNumber} - date={form.date} - /> + <Grid container justify="center" spacing={3} className={classes.body}> + {auxForms.length ? ( + auxForms.map(form => ( + <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> + <CardForm + id={form.id} + title={form.title} + description={form.description} + numberOfAnswers={form.answersNumber} + date={form.date} + /> + </Grid> + )) + ) : ( + <Grid item> + <Typography variant="h4"> + Nenhum formulário foi encontrado! + </Typography> </Grid> - ))} + )} </Grid> </Container> </div> -- GitLab From 493ea143e7df32fba7272c4d3cc142d7bcdaa0d3 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 21 Sep 2020 11:51:43 -0300 Subject: [PATCH 51/72] Issue/9: Milestone met Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index c701fe5..a2c87a3 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "my-app", - "version": "0.1.0", + "version": "1.0.0", "private": true, "dependencies": { "@material-ui/core": "^4.11.0", -- GitLab From 479fe1204be625974f24d2019d169da327429a0a Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Wed, 23 Sep 2020 11:33:26 -0300 Subject: [PATCH 52/72] Issue #38: Regexes Update Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- .../fieldsDisplayForm/FormFieldTitle.js | 2 ++ .../fieldsDisplayForm/utils/schemas.js | 8 ++--- src/contexts/useForm.js | 29 +++++++++---------- 3 files changed, 18 insertions(+), 21 deletions(-) diff --git a/src/components/fieldsDisplayForm/FormFieldTitle.js b/src/components/fieldsDisplayForm/FormFieldTitle.js index 8eff7e5..257f5ec 100644 --- a/src/components/fieldsDisplayForm/FormFieldTitle.js +++ b/src/components/fieldsDisplayForm/FormFieldTitle.js @@ -26,6 +26,7 @@ const useStyles = makeStyles((theme) => ({ }, title: { fontSize: "x-large", + lineHeight: "normal", }, description: { fontSize: "large", @@ -60,6 +61,7 @@ function FormFieldText(props) { input: classes.title, }, }} + InputLabelProps={classes.test} /> {props.error ? ( <Grid className={classes.errorGrid}> diff --git a/src/components/fieldsDisplayForm/utils/schemas.js b/src/components/fieldsDisplayForm/utils/schemas.js index 95c57f6..deae1e9 100644 --- a/src/components/fieldsDisplayForm/utils/schemas.js +++ b/src/components/fieldsDisplayForm/utils/schemas.js @@ -8,9 +8,7 @@ function checkText(value) { /** Function that applies the validation of it's used schema and sets the error messages. */ export async function testQuestionTextSchema(error, value) { value - ? checkText(value) - ? (error.errorMsg.question = "") - : (error.errorMsg.question = "O caractere não é permitido") + ? (error.errorMsg.question = "") : (error.errorMsg.question = "Este campo é obrigatório!"); } /** Function that applies the validation of it's used schema and sets the error messages. */ @@ -73,9 +71,7 @@ export async function testSubformSchema(form, index) { /** Function that applies the validation of it's used schema and sets the error messages. */ export async function selectOptionTextTesting(error, value, idopt) { value - ? checkText(value) - ? (error.errorMsg.options[idopt] = "") - : (error.errorMsg.options[idopt] = "O caractere não é permitido") + ? (error.errorMsg.options[idopt] = "") : (error.errorMsg.options[idopt] = "Por favor, preencha esta opção"); } /** Schema to validate the quantity field of the validation from FormFieldText. */ diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js index 03c0d60..54e8174 100644 --- a/src/contexts/useForm.js +++ b/src/contexts/useForm.js @@ -8,7 +8,7 @@ import { selectOptionsTesting, testSubformSchema, selectOptionTextTesting, - testTextValidation + testTextValidation, } from "../components/fieldsDisplayForm/utils/schemas"; import { pushTitle, @@ -16,7 +16,7 @@ import { pushSelect, pushRadio, pushCheckbox, - pushSubform + pushSubform, } from "../components/fieldsDisplayForm/utils/FormComposition"; import api from "../api"; @@ -148,7 +148,6 @@ const useForm = () => { */ async function setDescriptionField(value, index) { form[index].description = value; - testDescriptionTextSchema(form[index].error, value); setForm([...form]); } @@ -238,7 +237,7 @@ const useForm = () => { */ async function setId() { const fetchData = async () => { - await api.get(`/form/${routeId}`).then(async function(res) { + await api.get(`/form/${routeId}`).then(async function (res) { let backForm = createFrontendForm(res.data); for (let i = 1; i < backForm.length; i++) { for (let j = 1; j < form.length; j++) { @@ -248,13 +247,13 @@ const useForm = () => { "question", "description", "options", - "subformId" + "subformId", ]) !== JSON.stringify(form[j], [ "question", "description", "options", - "subformId" + "subformId", ]) || differentValidation(backForm[i], form[j]) ) { @@ -279,17 +278,17 @@ const useForm = () => { const post_response = await api .put(`/form/${routeId}`, data, { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}` - } + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, }) - .then(function(error) { + .then(function (error) { if (!error.response) { alert("Seu formulário foi atualizado com sucesso."); let path = `/signin`; history.push(path); } }) - .catch(function(error) { + .catch(function (error) { if (error.response.status === 401) { let path = `/signin`; history.push(path); @@ -307,17 +306,17 @@ const useForm = () => { const post_response = await api .post(`/form`, await createBackendForm(form), { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}` - } + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, }) - .then(function(error) { + .then(function (error) { if (!error.response) { alert("Seu formulário foi criado com sucesso."); let path = `/signin`; history.push(path); } }) - .catch(function(error) { + .catch(function (error) { alert("Um erro ocorreu."); }); } @@ -343,7 +342,7 @@ const useForm = () => { setValidationValue, removeValidation, onDragEnd, - submit + submit, }; }; -- GitLab From ceaf90416575ccd9def9012f11f7bcf39aacdc99 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 24 Sep 2020 10:09:10 -0300 Subject: [PATCH 53/72] Issue #44: /view small screen format correction Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- .../fieldsVisualizeForm/FormFieldCheckbox.js | 19 ++- .../fieldsVisualizeForm/FormFieldRadio.js | 21 ++-- .../fieldsVisualizeForm/FormFieldSelect.js | 21 ++-- .../fieldsVisualizeForm/FormFieldSubform.js | 118 +++++++++--------- .../fieldsVisualizeForm/FormFieldText.js | 17 ++- .../fieldsVisualizeForm/FormFieldTitle.js | 82 +++++------- src/pages/VisualizeForm.js | 57 +++++---- 7 files changed, 154 insertions(+), 181 deletions(-) diff --git a/src/components/fieldsVisualizeForm/FormFieldCheckbox.js b/src/components/fieldsVisualizeForm/FormFieldCheckbox.js index 2ff9e25..3f23367 100644 --- a/src/components/fieldsVisualizeForm/FormFieldCheckbox.js +++ b/src/components/fieldsVisualizeForm/FormFieldCheckbox.js @@ -7,29 +7,26 @@ import Checkbox from "@material-ui/core/Checkbox"; import FieldFooterOptions from "./FieldFooterOptions"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), minheight: theme.spacing(18), - margin: theme.spacing(2), ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: "85%", }, - ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + marginBottom: "12px", }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldCheckbox(props) { @@ -72,7 +69,7 @@ function FormFieldCheckbox(props) { direction="column" justify="flex-start" alignItems="flex-start" - xs={5} + xs={12} className={classes.questionsGrid} > {options} diff --git a/src/components/fieldsVisualizeForm/FormFieldRadio.js b/src/components/fieldsVisualizeForm/FormFieldRadio.js index c470b27..24d8e1b 100644 --- a/src/components/fieldsVisualizeForm/FormFieldRadio.js +++ b/src/components/fieldsVisualizeForm/FormFieldRadio.js @@ -8,36 +8,33 @@ import RadioGroup from "@material-ui/core/RadioGroup"; import FieldFooterOptions from "./FieldFooterOptions"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), minheight: theme.spacing(18), - margin: theme.spacing(2), ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: "85%", }, - ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + marginBottom: "12px", }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldRadio(props) { const classes = useStyles(); /** HTML object to be displayed on component return. */ - const options = props.options.map(function(x, index) { + const options = props.options.map(function (x, index) { return ( <span> <Typography @@ -73,7 +70,7 @@ function FormFieldRadio(props) { direction="column" justify="flex-start" alignItems="flex-start" - xs={5} + xs={12} className={classes.questionsGrid} > <RadioGroup>{options}</RadioGroup> diff --git a/src/components/fieldsVisualizeForm/FormFieldSelect.js b/src/components/fieldsVisualizeForm/FormFieldSelect.js index a52bb58..991dd25 100644 --- a/src/components/fieldsVisualizeForm/FormFieldSelect.js +++ b/src/components/fieldsVisualizeForm/FormFieldSelect.js @@ -8,36 +8,33 @@ import Typography from "@material-ui/core/Typography"; import FieldFooterOptions from "./FieldFooterOptions"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), - minheight: theme.spacing(18), - margin: theme.spacing(2), + height: "15%", ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: "85%", }, - ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + marginBottom: "12px", }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldSelect(props) { const classes = useStyles(); /** HTML object to be displayed on component return. */ - const options = props.options.map(function(x) { + const options = props.options.map(function (x) { return <MenuItem value={x.placement}>{x.value}</MenuItem>; }); diff --git a/src/components/fieldsVisualizeForm/FormFieldSubform.js b/src/components/fieldsVisualizeForm/FormFieldSubform.js index f87e04a..5812a36 100644 --- a/src/components/fieldsVisualizeForm/FormFieldSubform.js +++ b/src/components/fieldsVisualizeForm/FormFieldSubform.js @@ -10,15 +10,15 @@ import FormFieldSelect from "./FormFieldSelect"; import FormFieldRadio from "./FormFieldRadio"; import FormFieldCheckbox from "./FormFieldCheckbox"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ menu: { width: theme.spacing(6), minheight: theme.spacing(15), position: "fixed", top: theme.spacing(10), left: "90%", - padding: theme.spacing(1) - } + padding: theme.spacing(1), + }, })); function FormFieldSubform(props) { @@ -34,10 +34,10 @@ function FormFieldSubform(props) { async function getForm(id) { const res = await api .get(`/form/${id}`) - .then(function(res) { + .then(function (res) { setFormData(res.data); }) - .catch(error => { + .catch((error) => { alert("Um erro inesperado ocorreu ao tentar obter o subform."); }); } @@ -48,62 +48,58 @@ function FormFieldSubform(props) { }, []); return ( - <div> - <Grid container direction="column" alignItems="center" justify="center"> - {formData ? ( - <div> - {formData.inputs.map((input, index) => { - if (input.type === 0) - return ( - <FormFieldText - question={input.question} - description={input.description} - id={input.id} - /> - ); - else if (input.type === 3) - return ( - <FormFieldSelect - question={input.question} - id={input.id} - description={input.description} - options={input.sugestions} - /> - ); - else if (input.type === 2) - return ( - <FormFieldRadio - question={input.question} - description={input.description} - id={input.id} - options={input.sugestions} - /> - ); - else if (input.type === 1) - return ( - <FormFieldCheckbox - question={input.question} - description={input.description} - options={input.sugestions} - id={input.id} - /> - ); - else if (input.type === 4) - return ( - <FormFieldSubform - question={input.question} - description={input.description} - options={input.sugestions} - id={input.subForm.contentFormId} - /> - ); - })} - </div> - ) : ( - <p>Loading...</p> - )} - </Grid> - </div> + <> + {formData ? ( + formData.inputs.map((input, index) => { + if (input.type === 0) + return ( + <FormFieldText + question={input.question} + description={input.description} + id={input.id} + /> + ); + else if (input.type === 3) + return ( + <FormFieldSelect + question={input.question} + id={input.id} + description={input.description} + options={input.sugestions} + /> + ); + else if (input.type === 2) + return ( + <FormFieldRadio + question={input.question} + description={input.description} + id={input.id} + options={input.sugestions} + /> + ); + else if (input.type === 1) + return ( + <FormFieldCheckbox + question={input.question} + description={input.description} + options={input.sugestions} + id={input.id} + /> + ); + else if (input.type === 4) + return ( + <FormFieldSubform + question={input.question} + description={input.description} + options={input.sugestions} + id={input.subForm.contentFormId} + /> + ); + }) + ) : ( + <p>Loading...</p> + )} + </> ); } diff --git a/src/components/fieldsVisualizeForm/FormFieldText.js b/src/components/fieldsVisualizeForm/FormFieldText.js index 92d7cc0..ce3d8bf 100644 --- a/src/components/fieldsVisualizeForm/FormFieldText.js +++ b/src/components/fieldsVisualizeForm/FormFieldText.js @@ -5,29 +5,26 @@ import Paper from "@material-ui/core/Paper"; import TextField from "@material-ui/core/TextField"; import Typography from "@material-ui/core/Typography"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), height: "15%", - margin: theme.spacing(2), ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: "85%", }, - ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + marginBottom: "12px", }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldText(props) { diff --git a/src/components/fieldsVisualizeForm/FormFieldTitle.js b/src/components/fieldsVisualizeForm/FormFieldTitle.js index 530c7f3..97bfb3a 100644 --- a/src/components/fieldsVisualizeForm/FormFieldTitle.js +++ b/src/components/fieldsVisualizeForm/FormFieldTitle.js @@ -6,87 +6,71 @@ import Typography from "@material-ui/core/Typography"; import FieldFooterOptions from "./FieldFooterOptions"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), height: "40%", - margin: theme.spacing(2), color: "#000000", ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: "85%", }, - ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + marginBottom: "12px", + marginTop: "16px", }, questionsGrid: { marginBottom: "20px", color: "#000000", ["@media (max-width:827px)"]: { - width: theme.spacing(70) - } + width: theme.spacing(70), + }, }, title: { fontSize: "45px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "35px" + fontSize: "35px", }, ["@media (max-width:590px)"]: { - fontSize: "25px" - } + fontSize: "25px", + }, }, description: { fontSize: "30px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "25px" + fontSize: "25px", }, ["@media (max-width:590px)"]: { - fontSize: "15px" - } - } + fontSize: "15px", + }, + }, })); function FormFieldText(props) { const classes = useStyles(); return ( - <Grid> - <Paper className={classes.paper}> - <Grid container> - <Grid item xs={12} className={classes.questionsGrid}> - <Typography - style={{ wordWrap: "break-word" }} - className={classes.title} - variant="h3" - gutterBottom - > - {props.title} - </Typography> - </Grid> - <Grid item xs={9} className={classes.questionsGrid}> - <Typography - style={{ wordWrap: "break-word" }} - className={classes.description} - variant="h4" - gutterBottom - > - {props.description} - </Typography> - </Grid> - <Grid - item - container - direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - ></Grid> - </Grid> - </Paper> - </Grid> + <Paper className={classes.paper}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.title} + variant="h3" + gutterBottom + > + {props.title} + </Typography> + <Grid item xs={9} className={classes.questionsGrid}> + <Typography + style={{ wordWrap: "break-word" }} + className={classes.description} + variant="h4" + gutterBottom + > + {props.description} + </Typography> + </Grid> + </Paper> ); } diff --git a/src/pages/VisualizeForm.js b/src/pages/VisualizeForm.js index a161ada..1408c85 100644 --- a/src/pages/VisualizeForm.js +++ b/src/pages/VisualizeForm.js @@ -13,15 +13,7 @@ import FormFieldCheckbox from "../components/fieldsVisualizeForm/FormFieldCheckb import FormFieldTitle from "../components/fieldsVisualizeForm/FormFieldTitle"; import FormFieldSubform from "../components/fieldsVisualizeForm/FormFieldSubform"; -const useStyles = makeStyles(theme => ({ - menu: { - width: theme.spacing(6), - minheight: theme.spacing(15), - position: "fixed", - top: theme.spacing(10), - left: "90%", - padding: theme.spacing(1) - }, +const useStyles = makeStyles((theme) => ({ button: { type: "submit", width: "100%", @@ -30,13 +22,19 @@ const useStyles = makeStyles(theme => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)" - } + backgroundColor: "rgb(25, 109, 23)", + }, }, pageBody: { minHeight: "calc(100vh - 92.4px - 78px)", - paddingBottom: "78px" - } + paddingBottom: "78px", + }, + sizeFormating: { + ["@media (max-width:430px)"]: { + marginLeft: "3%", + width: "92%", + }, + }, })); const theme = createMuiTheme({ @@ -44,19 +42,19 @@ const theme = createMuiTheme({ MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc" + borderBottom: "1px solid #35c7fc", }, "&:after": { - borderBottom: "1px solid #3f51b5" - } - } + borderBottom: "1px solid #3f51b5", + }, + }, }, MuiButton: { label: { - color: "black" - } - } - } + color: "black", + }, + }, + }, }); function VisualizeForm() { @@ -76,10 +74,10 @@ function VisualizeForm() { async function getForm(id) { const res = await api .get(`/form/${id}`) - .then(function(res) { + .then(function (res) { setFormData(res.data); }) - .catch(error => { + .catch((error) => { if (error.response.status === 401) { let path = `/signin`; history.push(path); @@ -105,9 +103,16 @@ function VisualizeForm() { return ( <MuiThemeProvider theme={theme}> <div className={classes.pageBody}> - <Grid container direction="column" alignItems="center" justify="center"> + <Grid + container + xs={12} + direction="column" + alignItems="center" + justify="center" + className={classes.sizeFormating} + > {formData ? ( - <div> + <> <FormFieldTitle title={formData.title} description={formData.description} @@ -158,7 +163,7 @@ function VisualizeForm() { /> ); })} - </div> + </> ) : ( <p>Loading...</p> )} -- GitLab From 71c1ed1f6634a5c48a581f7704bb850eb9ccfbea Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Thu, 24 Sep 2020 10:25:04 -0300 Subject: [PATCH 54/72] Issue/47: FIX BUG: Token is now deleted if it expires Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- .../JornalFolder/FormFieldSubform.js | 10 ++++- .../SummaryFolder/FormFieldSubform.js | 10 ++++- .../fieldsVisualizeForm/FormFieldSubform.js | 20 +++++++--- src/contexts/FormContext.js | 2 + src/contexts/useForm.js | 37 ++++++++++++------- src/pages/AnswerForm.js | 9 +++++ src/pages/GetForm.js | 16 ++++++-- src/pages/ListForms.js | 2 + src/pages/VisualizeForm.js | 2 + 9 files changed, 82 insertions(+), 26 deletions(-) diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js b/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js index 980d51d..78d14e5 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js @@ -1,5 +1,5 @@ import React, { useState, useEffect } from "react"; -import { useParams } from "react-router-dom"; +import { useParams, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Button from "@material-ui/core/Button"; @@ -23,6 +23,7 @@ const useStyles = makeStyles(theme => ({ function FormFieldSubform(props) { const classes = useStyles(); + const history = useHistory(); /** Subform id */ const id = props.id; @@ -38,6 +39,13 @@ function FormFieldSubform(props) { setFormData(res.data); }) .catch(error => { + if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + let path = `/signin`; + history.push(path); + return; + } alert( "Um erro inesperado ocorreu ao tentar obter o subform na tela de Jornal." ); diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js index 50d40f9..b784f80 100644 --- a/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js @@ -1,5 +1,5 @@ import React, { useState, useEffect } from "react"; -import { useParams } from "react-router-dom"; +import { useParams, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import api from "../../../api"; @@ -22,6 +22,7 @@ const useStyles = makeStyles(theme => ({ function FormFieldSubform(props) { const classes = useStyles(); + const history = useHistory(); /** Subform id */ const id = props.id; @@ -37,6 +38,13 @@ function FormFieldSubform(props) { setFormData(res.data); }) .catch(error => { + if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + let path = `/signin`; + history.push(path); + return; + } alert( "Um erro inesperado ocorreu ao tentar obter o subform na tela de resumo." ); diff --git a/src/components/fieldsVisualizeForm/FormFieldSubform.js b/src/components/fieldsVisualizeForm/FormFieldSubform.js index 5812a36..ce45234 100644 --- a/src/components/fieldsVisualizeForm/FormFieldSubform.js +++ b/src/components/fieldsVisualizeForm/FormFieldSubform.js @@ -1,5 +1,5 @@ import React, { useState, useEffect } from "react"; -import { useParams } from "react-router-dom"; +import { useParams, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import Button from "@material-ui/core/Button"; @@ -10,19 +10,20 @@ import FormFieldSelect from "./FormFieldSelect"; import FormFieldRadio from "./FormFieldRadio"; import FormFieldCheckbox from "./FormFieldCheckbox"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ menu: { width: theme.spacing(6), minheight: theme.spacing(15), position: "fixed", top: theme.spacing(10), left: "90%", - padding: theme.spacing(1), - }, + padding: theme.spacing(1) + } })); function FormFieldSubform(props) { const classes = useStyles(); + const history = useHistory(); /** Subform id */ const id = props.id; @@ -34,10 +35,17 @@ function FormFieldSubform(props) { async function getForm(id) { const res = await api .get(`/form/${id}`) - .then(function (res) { + .then(function(res) { setFormData(res.data); }) - .catch((error) => { + .catch(error => { + if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + let path = `/signin`; + history.push(path); + return; + } alert("Um erro inesperado ocorreu ao tentar obter o subform."); }); } diff --git a/src/contexts/FormContext.js b/src/contexts/FormContext.js index 015c9e9..e49b2a1 100644 --- a/src/contexts/FormContext.js +++ b/src/contexts/FormContext.js @@ -39,6 +39,8 @@ const FormProvider = props => { }) .catch(error => { if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); let path = `/signin`; history.push(path); return; diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js index 54e8174..f9ad274 100644 --- a/src/contexts/useForm.js +++ b/src/contexts/useForm.js @@ -8,7 +8,7 @@ import { selectOptionsTesting, testSubformSchema, selectOptionTextTesting, - testTextValidation, + testTextValidation } from "../components/fieldsDisplayForm/utils/schemas"; import { pushTitle, @@ -16,7 +16,7 @@ import { pushSelect, pushRadio, pushCheckbox, - pushSubform, + pushSubform } from "../components/fieldsDisplayForm/utils/FormComposition"; import api from "../api"; @@ -237,7 +237,7 @@ const useForm = () => { */ async function setId() { const fetchData = async () => { - await api.get(`/form/${routeId}`).then(async function (res) { + await api.get(`/form/${routeId}`).then(async function(res) { let backForm = createFrontendForm(res.data); for (let i = 1; i < backForm.length; i++) { for (let j = 1; j < form.length; j++) { @@ -247,13 +247,13 @@ const useForm = () => { "question", "description", "options", - "subformId", + "subformId" ]) !== JSON.stringify(form[j], [ "question", "description", "options", - "subformId", + "subformId" ]) || differentValidation(backForm[i], form[j]) ) { @@ -278,18 +278,20 @@ const useForm = () => { const post_response = await api .put(`/form/${routeId}`, data, { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}`, - }, + authorization: `bearer ${window.sessionStorage.getItem("token")}` + } }) - .then(function (error) { + .then(function(error) { if (!error.response) { alert("Seu formulário foi atualizado com sucesso."); let path = `/signin`; history.push(path); } }) - .catch(function (error) { + .catch(function(error) { if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); let path = `/signin`; history.push(path); return; @@ -306,17 +308,24 @@ const useForm = () => { const post_response = await api .post(`/form`, await createBackendForm(form), { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}`, - }, + authorization: `bearer ${window.sessionStorage.getItem("token")}` + } }) - .then(function (error) { + .then(function(error) { if (!error.response) { alert("Seu formulário foi criado com sucesso."); let path = `/signin`; history.push(path); } }) - .catch(function (error) { + .catch(function(error) { + if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + let path = `/signin`; + history.push(path); + return; + } alert("Um erro ocorreu."); }); } @@ -342,7 +351,7 @@ const useForm = () => { setValidationValue, removeValidation, onDragEnd, - submit, + submit }; }; diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index e4b535e..f86d909 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -153,6 +153,13 @@ function AnwserForm() { alert("Formulário respondido!"); }) .catch(error => { + if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + let path = `/signin`; + history.push(path); + return; + } alert("Ocorreu um erro ao responder seu formulário."); return; }); @@ -199,6 +206,8 @@ function AnwserForm() { }) .catch(error => { if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); let path = `/signin`; history.push(path); return; diff --git a/src/pages/GetForm.js b/src/pages/GetForm.js index fb24c5f..b9eabe1 100644 --- a/src/pages/GetForm.js +++ b/src/pages/GetForm.js @@ -1,5 +1,5 @@ import React, { useState, useEffect } from "react"; -import { useParams, Route, Redirect } from "react-router-dom"; +import { useParams, Route, Redirect, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import api from "../api"; @@ -95,6 +95,7 @@ const theme = createMuiTheme({ function GetForm() { const classes = useStyles(); + const history = useHistory(); /** Form id got from the browser's URL */ const { id } = useParams(); @@ -140,6 +141,8 @@ function GetForm() { }) .catch(error => { if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); setToLogin(true); return; } @@ -166,9 +169,14 @@ function GetForm() { setAnswerNum(res.data.answerNumber); }) .catch(error => { - alert( - "Um erro inesperado ocorreu. Contate os desenvolvedores (código 500-2)" - ); + if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + let path = `/signin`; + history.push(path); + return; + } + alert("Um erro inesperado ocorreu. Contate os desenvolvedores"); }); setIsReady(true); } diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index d609b39..0f71c7a 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -93,6 +93,8 @@ export default function ListForms() { }) .catch(error => { if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); let path = `/signin`; history.push(path); return; diff --git a/src/pages/VisualizeForm.js b/src/pages/VisualizeForm.js index 1408c85..81c2279 100644 --- a/src/pages/VisualizeForm.js +++ b/src/pages/VisualizeForm.js @@ -79,6 +79,8 @@ function VisualizeForm() { }) .catch((error) => { if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); let path = `/signin`; history.push(path); return; -- GitLab From dc07e177884da57b56db39ab7b7af0f01f9527fe Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Thu, 24 Sep 2020 11:36:36 -0300 Subject: [PATCH 55/72] Issue #42: Detection on user leaving --- .../fieldsDisplayForm/DisplayForm.js | 42 ++++++++++--------- src/pages/AnswerForm.js | 4 ++ 2 files changed, 27 insertions(+), 19 deletions(-) diff --git a/src/components/fieldsDisplayForm/DisplayForm.js b/src/components/fieldsDisplayForm/DisplayForm.js index a1f257e..8c5d8f2 100644 --- a/src/components/fieldsDisplayForm/DisplayForm.js +++ b/src/components/fieldsDisplayForm/DisplayForm.js @@ -17,39 +17,39 @@ import { FormEditionContext } from "../../contexts/FormContext"; import useForm from "../../contexts/useForm"; import SubmitButton from "./SubmitButton"; /** CSS styles used on page components */ -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ app: { margin: "0", padding: "40px", display: "flex", ["@media (max-width: 600px)"]: { flexDirection: "column-reverse", - justifyContent: "flex-end", + justifyContent: "flex-end" }, paddingBottom: "78px", ["@media (min-width: 600px)"]: { - minHeight: "calc(100vh - 92.4px - 78px -60px)", + minHeight: "calc(100vh - 92.4px - 78px -60px)" }, minHeight: "calc(100vh - 71.6px - 78px -60px)", - marginBottom: "60px", + marginBottom: "60px" }, addButton: { - fontSize: "100%", + fontSize: "100%" }, sideMenuFormatingGrid: { ["@media (max-width:600px)"]: { - marginTop: "-90px", - }, + marginTop: "-90px" + } }, sizeFormating: { ["@media (max-width:600px)"]: { ["@media (max-width:430px)"]: { marginLeft: "1%", - width: "95%", + width: "95%" }, - marginLeft: "2%", - }, - }, + marginLeft: "2%" + } + } })); /** CSS style used through Material Ui. */ const theme = createMuiTheme({ @@ -57,19 +57,19 @@ const theme = createMuiTheme({ MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc", + borderBottom: "1px solid #35c7fc" }, "&:after": { - borderBottom: "1px solid #3f51b5", - }, - }, + borderBottom: "1px solid #3f51b5" + } + } }, MuiButton: { label: { - color: "white", - }, - }, - }, + color: "white" + } + } + } }); /** Main function that returns the children that composes the form creation or edition page. */ function DisplayForm() { @@ -90,6 +90,10 @@ function DisplayForm() { */ useEffect(() => { setValidToSend(verifyError(form)); + window.onbeforeunload = confirmExit; + function confirmExit() { + return "show warning"; + } }, [form]); return ( <MuiThemeProvider theme={theme}> diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index f86d909..22b11ae 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -222,6 +222,10 @@ function AnwserForm() { /** First thing the page does is getting the form from the API. */ useEffect(() => { getForm(id); + window.onbeforeunload = confirmExit; + function confirmExit() { + return "show warning"; + } }, []); return ( -- GitLab From bb1f0ee4c0a82b33d52677b91476cd7d2e95d22c Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Fri, 25 Sep 2020 10:09:59 -0300 Subject: [PATCH 56/72] Issue #45: User movimentation implemented Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- .../fieldsDisplayForm/DisplayForm.js | 40 ++++++++++-- .../fieldsGetForm/JornalFolder/FormJornal.js | 2 - .../SummaryFolder/FormSummary.js | 2 - src/pages/GetForm.js | 50 +++++++-------- src/pages/VisualizeForm.js | 64 +++++++++++-------- 5 files changed, 99 insertions(+), 59 deletions(-) diff --git a/src/components/fieldsDisplayForm/DisplayForm.js b/src/components/fieldsDisplayForm/DisplayForm.js index 8c5d8f2..236742f 100644 --- a/src/components/fieldsDisplayForm/DisplayForm.js +++ b/src/components/fieldsDisplayForm/DisplayForm.js @@ -1,5 +1,6 @@ import React, { useState, useEffect, useContext } from "react"; import { makeStyles } from "@material-ui/core/styles"; +import Button from "@material-ui/core/Button"; import Grid from "@material-ui/core/Grid"; import { DragDropContext, Droppable } from "react-beautiful-dnd"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; @@ -12,6 +13,7 @@ import FormFieldSubForm from "./FormFieldSubform"; import uuid from "uuid/v4"; import { verifyError } from "./utils/schemas"; import SideMenu from "./SideMenu"; +import { useHistory } from "react-router-dom"; import { FormEditionContext } from "../../contexts/FormContext"; import useForm from "../../contexts/useForm"; @@ -49,6 +51,18 @@ const useStyles = makeStyles(theme => ({ }, marginLeft: "2%" } + }, + button: { + marginLeft: "5%", + backgroundColor: "#a30202", + minWidth: "92px", + ["@media (max-width:600px)"]: { + marginTop: "52px" + }, + width: "12%", + ["@media (max-width:600px)"]: { + marginTop: "52px" + } } })); /** CSS style used through Material Ui. */ @@ -84,6 +98,15 @@ function DisplayForm() { const columnId = uuid(); /** Error state. */ const [validToSend, setValidToSend] = useState(); + /** variable to redirect */ + const history = useHistory(); + + const toLogin = () => { + if (window.confirm("Tem certeza que deseja sair?")) { + let path = "/signin"; + history.push(path); + } + }; /** Error handling -> every time the form object is updated, it is verified to evaluate it's error messages, * so the submit button can be enabled or disabled. @@ -201,10 +224,19 @@ function DisplayForm() { ); }} </Droppable> - <SubmitButton - validToSend={validToSend} - formId={form ? (form[0] ? form[0].id : false) : false} - /> + <Grid container justify="center"> + <SubmitButton + validToSend={validToSend} + formId={form ? (form[0] ? form[0].id : false) : false} + /> + <Button + variant="contained" + className={classes.button} + onClick={toLogin} + > + Cancelar + </Button> + </Grid> </Grid> </DragDropContext> </Grid> diff --git a/src/components/fieldsGetForm/JornalFolder/FormJornal.js b/src/components/fieldsGetForm/JornalFolder/FormJornal.js index d7826dc..102d5d2 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormJornal.js +++ b/src/components/fieldsGetForm/JornalFolder/FormJornal.js @@ -36,8 +36,6 @@ const useStyles = makeStyles(theme => ({ backgroundColor: "white", marginBottom: "20px", marginLeft: "2%", - minHeight: "calc(100vh - 92.4px - 78px)", - paddingBottom: "78px", justifyContent: "center" }, gridMenu: { diff --git a/src/components/fieldsGetForm/SummaryFolder/FormSummary.js b/src/components/fieldsGetForm/SummaryFolder/FormSummary.js index 660eb19..0904563 100644 --- a/src/components/fieldsGetForm/SummaryFolder/FormSummary.js +++ b/src/components/fieldsGetForm/SummaryFolder/FormSummary.js @@ -33,8 +33,6 @@ const useStyles = makeStyles(theme => ({ marginBottom: "20px", marginTop: "25px", marginLeft: "2%", - minHeight: "calc(100vh - 92.4px - 78px)", - paddingBottom: "78px", justifyContent: "center" }, gridMenu: { diff --git a/src/pages/GetForm.js b/src/pages/GetForm.js index b9eabe1..7c190b3 100644 --- a/src/pages/GetForm.js +++ b/src/pages/GetForm.js @@ -1,15 +1,14 @@ import React, { useState, useEffect } from "react"; -import { useParams, Route, Redirect, useHistory } from "react-router-dom"; +import { useParams, Redirect, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import api from "../api"; -import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import FormControl from "@material-ui/core/FormControl"; import MenuItem from "@material-ui/core/MenuItem"; import Select from "@material-ui/core/Select"; import FormHelperText from "@material-ui/core/FormHelperText"; import Typography from "@material-ui/core/Typography"; - +import Button from "@material-ui/core/Button"; import Jornal from "../components/fieldsGetForm/JornalFolder/FormJornal"; import Summary from "../components/fieldsGetForm/SummaryFolder/FormSummary"; const useStyles = makeStyles(theme => ({ @@ -40,8 +39,7 @@ const useStyles = makeStyles(theme => ({ container: { flexDirection: "row", justifyContent: "space-between", - backgroundColor: "white", - marginBottom: "20px" + backgroundColor: "white" }, answerNum: { display: "flex", @@ -55,6 +53,15 @@ const useStyles = makeStyles(theme => ({ marginLeft: "20px" } }, + button: { + marginBottom: "15%", + backgroundColor: "#d3d609", + minWidth: "92px", + width: "12%", + ["@media (max-width:580px)"]: { + marginBottom: "40%" + } + }, formTitle: { textAlign: "center", marginTop: "10px", @@ -73,35 +80,15 @@ const useStyles = makeStyles(theme => ({ } })); -const theme = createMuiTheme({ - overrides: { - MuiInput: { - underline: { - "&:before": { - borderBottom: "1px solid #35c7fc" - }, - "&:after": { - borderBottom: "1px solid #3f51b5" - } - } - }, - MuiButton: { - label: { - color: "black" - } - } - } -}); - function GetForm() { const classes = useStyles(); const history = useHistory(); - /** Form id got from the browser's URL */ const { id } = useParams(); /** Maped form from backend */ const [formArray, setFormArray] = useState([]); + const [answers, setAnswers] = useState([]); const [answerNum, setAnswerNum] = useState(0); const [isReady, setIsReady] = useState(false); @@ -109,6 +96,12 @@ function GetForm() { const [times, setTimes] = useState([]); const [toLogin, setToLogin] = useState(false); + const GoBack = () => { + if (window.confirm("Tem certeza que deseja sair?")) { + let path = "/signin"; + history.push(path); + } + }; /** * Set selectedValue variable to the right value. */ @@ -228,6 +221,11 @@ function GetForm() { /> )} </Grid> + <Grid container justify="center"> + <Button variant="contained" className={classes.button} onClick={GoBack}> + Voltar + </Button> + </Grid> </Grid> ) : ( <p>loading...</p> diff --git a/src/pages/VisualizeForm.js b/src/pages/VisualizeForm.js index 81c2279..ea9951e 100644 --- a/src/pages/VisualizeForm.js +++ b/src/pages/VisualizeForm.js @@ -3,7 +3,7 @@ import { useParams } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import api from "../api"; -import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import { createMuiTheme, MuiThemeProvider, Button } from "@material-ui/core"; import { useHistory } from "react-router-dom"; import FormFieldText from "../components/fieldsVisualizeForm/FormFieldText"; @@ -13,28 +13,26 @@ import FormFieldCheckbox from "../components/fieldsVisualizeForm/FormFieldCheckb import FormFieldTitle from "../components/fieldsVisualizeForm/FormFieldTitle"; import FormFieldSubform from "../components/fieldsVisualizeForm/FormFieldSubform"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ button: { - type: "submit", - width: "100%", - background: "#6ec46c", - borderRadius: "2px", - padding: "10px 20px", - fontSize: "18px", - "&:hover": { - backgroundColor: "rgb(25, 109, 23)", - }, + marginBottom: "15%", + backgroundColor: "#d3d609", + minWidth: "92px", + width: "12%", + ["@media (max-width:600px)"]: { + marginBottom: "20%" + } }, pageBody: { minHeight: "calc(100vh - 92.4px - 78px)", - paddingBottom: "78px", + paddingBottom: "78px" }, sizeFormating: { ["@media (max-width:430px)"]: { marginLeft: "3%", - width: "92%", - }, - }, + width: "92%" + } + } })); const theme = createMuiTheme({ @@ -42,19 +40,19 @@ const theme = createMuiTheme({ MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc", + borderBottom: "1px solid #35c7fc" }, "&:after": { - borderBottom: "1px solid #3f51b5", - }, - }, + borderBottom: "1px solid #3f51b5" + } + } }, MuiButton: { label: { - color: "black", - }, - }, - }, + color: "black" + } + } + } }); function VisualizeForm() { @@ -74,10 +72,10 @@ function VisualizeForm() { async function getForm(id) { const res = await api .get(`/form/${id}`) - .then(function (res) { + .then(function(res) { setFormData(res.data); }) - .catch((error) => { + .catch(error => { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); @@ -97,6 +95,13 @@ function VisualizeForm() { }); } + const toLogin = () => { + if (window.confirm("Tem certeza que deseja sair?")) { + let path = "/signin"; + history.push(path); + } + }; + /** First thing the page does is getting the form from the API. */ useEffect(() => { getForm(id); @@ -165,6 +170,15 @@ function VisualizeForm() { /> ); })} + <Grid container justify="center"> + <Button + variant="contained" + className={classes.button} + onClick={toLogin} + > + Voltar + </Button> + </Grid> </> ) : ( <p>Loading...</p> -- GitLab From 9a78a022cba8ee40d6b6a94d1c7e3913f2d554a2 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Fri, 25 Sep 2020 11:02:32 -0300 Subject: [PATCH 57/72] Issue #33: Header updates properly Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/components/header/header.jsx | 8 ++++-- .../header/header_components/MenuList.jsx | 28 +++++++++---------- src/pages/ListForms.js | 20 ++++++------- 3 files changed, 30 insertions(+), 26 deletions(-) diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index d532abc..696c62b 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -1,4 +1,4 @@ -import React from "react"; +import React, { useEffect } from "react"; import Grid from "@material-ui/core/Grid"; import { useHistory } from "react-router-dom"; import logo from "./header_imgs/imgsimmc-01.png"; @@ -59,7 +59,7 @@ const useStyles = makeStyles((theme) => ({ export default function Header() { const classes = useStyles(); - const [isLoged, setIsLoged] = React.useState(checkLoged()); + const [isLoged, setIsLoged] = React.useState(false); const history = useHistory(); function checkLoged() { @@ -69,6 +69,10 @@ export default function Header() { return false; } + useEffect(() => { + console.log("O TOKEN MUDOU"); + setIsLoged(!isLoged); + }, [window.sessionStorage.getItem("token")]); return ( <Grid> diff --git a/src/components/header/header_components/MenuList.jsx b/src/components/header/header_components/MenuList.jsx index 7f7d54c..e6d9fa6 100644 --- a/src/components/header/header_components/MenuList.jsx +++ b/src/components/header/header_components/MenuList.jsx @@ -12,28 +12,28 @@ import UserImg from "./../header_imgs/user.png"; import { Avatar } from "@material-ui/core"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ menuPopUp: { alignContent: "start", ["@media (max-width:346px)"]: { - width: "23%" - } + width: "23%", + }, }, menuPopUpText: { ["@media (max-width:525px)"]: { - fontSize: "13px" - } + fontSize: "13px", + }, }, popUpPaper: { marginRight: "14%", ["@media (max-width:525px)"]: { - marginRight: "0" - } + marginRight: "0", + }, }, menuList: { alignItems: "flex-start", - color: "grey" - } + color: "grey", + }, })); /** @@ -54,9 +54,9 @@ function MenuListComposition(props) { const anchorRef = React.useRef(null); const handleToggle = () => { - setOpen(prevOpen => !prevOpen); + setOpen((prevOpen) => !prevOpen); }; - const handleProfile = event => { + const handleProfile = (event) => { if (window.sessionStorage.getItem("userId")) { let path = `/list/${window.sessionStorage.getItem("userId")}`; history.push(path); @@ -65,14 +65,14 @@ function MenuListComposition(props) { alert("Você não está logado."); }; - const handleLogOut = event => { + const handleLogOut = (event) => { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); props.checkLoged(); let path = `/signin`; history.push(path); }; - const handleClose = event => { + const handleClose = (event) => { if (anchorRef.current && anchorRef.current.contains(event.target)) { return; } @@ -120,7 +120,7 @@ function MenuListComposition(props) { {...TransitionProps} style={{ transformOrigin: - placement === "bottom" ? "center top" : "center bottom" + placement === "bottom" ? "center top" : "center bottom", }} > <Paper className={classes.popUpPaper}> diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index 0f71c7a..a845790 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -10,16 +10,16 @@ import { useHistory } from "react-router-dom"; import CardForm from "../components/fieldsListForms/CardForm.jsx"; import Tab from "../components/fieldsListForms/Tab.jsx"; import { Typography } from "@material-ui/core"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ body: { - marginBottom: "15%" + marginBottom: "15%", }, Forms: { textAlign: "center", marginBottom: "3%", - fontSize: "20px" - } + fontSize: "20px", + }, })); export default function ListForms() { const classes = useStyles(); @@ -53,12 +53,12 @@ export default function ListForms() { setAuxForms(tmp); } else if (type === 4) { let tmp = [...forms] - .filter(value => { + .filter((value) => { return value.date; }) .sort((a, b) => a.date > b.date) .concat( - [...forms].filter(value => { + [...forms].filter((value) => { return value.date === ""; }) ); @@ -73,7 +73,7 @@ export default function ListForms() { function searching(string) { console.log(string); setAuxForms( - [...forms].filter(value => { + [...forms].filter((value) => { return value.title.toLowerCase().includes(string.toLowerCase()); }) ); @@ -86,12 +86,12 @@ export default function ListForms() { async function fetchData(id) { const res = await api .get(`/user/list/${id}`) - .then(function(res) { + .then(function (res) { setForms(res.data.sort((a, b) => a.id > b.id)); setAuxForms(res.data.sort((a, b) => a.id > b.id)); setisLoaded(true); }) - .catch(error => { + .catch((error) => { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); @@ -114,7 +114,7 @@ export default function ListForms() { <Grid className={classes.Forms}>Seus Formulários:</Grid> <Grid container justify="center" spacing={3} className={classes.body}> {auxForms.length ? ( - auxForms.map(form => ( + auxForms.map((form) => ( <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> <CardForm id={form.id} -- GitLab From fbddd6028d8dbbbbbb2d0dd04f85dc64cc32b147 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Fri, 25 Sep 2020 11:52:05 -0300 Subject: [PATCH 58/72] Issue #36: FIX redirect user to an empty page Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/components/fieldsListForms/CardForm.jsx | 8 ++++++-- src/pages/GetForm.js | 1 + 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/components/fieldsListForms/CardForm.jsx b/src/components/fieldsListForms/CardForm.jsx index da88546..639a67d 100644 --- a/src/components/fieldsListForms/CardForm.jsx +++ b/src/components/fieldsListForms/CardForm.jsx @@ -76,8 +76,12 @@ function CardForm(props) { const handleAnswer = () => { //redirecionar para /answer/props.id - let path = `/form/${props.id}`; - history.push(path); + if (props.numberOfAnswers) { + let path = `/form/${props.id}`; + history.push(path); + } else { + alert("Não há respostas nesse form."); + } }; const handleVisualize = () => { diff --git a/src/pages/GetForm.js b/src/pages/GetForm.js index 7c190b3..849869e 100644 --- a/src/pages/GetForm.js +++ b/src/pages/GetForm.js @@ -123,6 +123,7 @@ function GetForm() { .then(function(res) { if (!res.data.length) { alert("Não há respostas!"); + setToLogin(true); return; } setFormArray(res.data); -- GitLab From 0fb0a13eb8f8939a72a794852925800718b851e8 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 24 Sep 2020 15:43:43 -0300 Subject: [PATCH 59/72] Issue #39: password validation Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/pages/SignUp.js | 79 ++++++++++++++++++++++++++++++--------------- 1 file changed, 53 insertions(+), 26 deletions(-) diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index ef6b531..8b3ac05 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -10,7 +10,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -18,24 +18,24 @@ const useStyles = makeStyles(theme => ({ padding: "2% 1%", marginTop: "3%", margin: "0 auto", - width: "95%" + width: "95%", }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d" + color: "#46525d", }, strong_description: { fontSize: "14px", - color: "#c2c6ca" + color: "#c2c6ca", }, form: { alignItems: "center", - textAlign: "center" + textAlign: "center", }, alreadyAcc: { - marginTop: "10px" + marginTop: "10px", }, button: { type: "submit", @@ -47,12 +47,18 @@ const useStyles = makeStyles(theme => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)" + backgroundColor: "rgb(25, 109, 23)", }, ["@media (max-width:550px)"]: { - width: "55%" - } - } + width: "55%", + }, + }, + errorGridOpts: { + marginTop: "1%", + color: "#ff4646", + width: "100%", + fontSize: "13px", + }, })); export default function SignUp() { const history = useHistory(); @@ -66,7 +72,7 @@ export default function SignUp() { password: "", password_confirm: "", nameError: false, - emailError: false + emailError: false, }); useEffect(() => { !checkName() ? (values.nameError = true) : (values.nameError = false); @@ -75,7 +81,7 @@ export default function SignUp() { !checkEmail() ? (values.emailError = true) : (values.emailError = false); }, [values.email]); - const handleChange = prop => event => { + const handleChange = (prop) => (event) => { setValues({ ...values, [prop]: event.target.value }); }; function checkPassword() { @@ -101,6 +107,15 @@ export default function SignUp() { : false : true; } + + function checkPasswordString() { + return values.password + ? /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&+_ ():;/?\|"'-])[A-Za-z\d@$!%*?&+_ ():;/?\|"'-]{8,24}$/.test( + values.password + ) + : true; + } + function verifyValues() { if ( values.name && @@ -123,25 +138,26 @@ export default function SignUp() { alert("Email invalido"); return false; } else if (!checkPassword()) { + alert("Verifique se sua senha satisfaz as condições mencionadas"); return false; - } else { - return true; - } + } else if (!checkPasswordString()) { + return false; + } else return true; } async function handleSubmit() { const response = await api .post(`/user/signUp`, { email: values.email, name: values.name, - hash: values.password + hash: values.password, }) - .then(function(error) { + .then(function (error) { if (!error.response) { let path = `signin`; history.push(path); } }) - .catch(function(error) { + .catch(function (error) { if (error.response) { switch (error.response.data.error) { case 'duplicate key value violates unique constraint "form_user_name_key"': @@ -169,19 +185,19 @@ export default function SignUp() { const theme = createMuiTheme({ overrides: { root: { - color: "white" + color: "white", }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc" + borderBottom: "1px solid #35c7fc", }, "&:after": { - borderBottom: "1px solid #3f51b5" - } - } - } - } + borderBottom: "1px solid #3f51b5", + }, + }, + }, + }, }); return isLoged ? ( <Redirect to="/signin" /> @@ -212,7 +228,18 @@ export default function SignUp() { /> </Grid> <Grid> - <FormInput label="Senha" param="password" onUpdate={handleChange} /> + <FormInput + label="Senha" + param="password" + onUpdate={handleChange} + error={!checkPasswordString()} + /> + {(!checkPasswordString() || !values.password) && ( + <Grid className={classes.errorGridOpts}> + Sua senha deve conter entre 8 e 24 caracteres, uma letra + maiúscula, uma minúscula e um número + </Grid> + )} </Grid> <Grid> <FormInput -- GitLab From cfe38df037c7d2296505c3d0537f29e57290429e Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 28 Sep 2020 11:35:49 -0300 Subject: [PATCH 60/72] Issue #46:FIX ? in URL solved Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/pages/SignIn.js | 45 ++++++++++++++++++++++----------------------- 1 file changed, 22 insertions(+), 23 deletions(-) diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index 33ba0f7..f7d5a76 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -10,7 +10,7 @@ import FormInput from "../components/fieldsSignUp/FormInput"; import Paper from "@material-ui/core/Paper"; import api from "../api"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ register: { maxWidth: "1000px", background: "#ffffff", @@ -18,25 +18,25 @@ const useStyles = makeStyles((theme) => ({ padding: "2% 1%", margin: "0 auto", marginTop: "9%", - width: "95%", + width: "95%" }, custom_strong: { fontSize: "25px", textAlign: "center", display: "block", - color: "#46525d", + color: "#46525d" }, strong_description: { fontSize: "14px", - color: "#c2c6ca", + color: "#c2c6ca" }, form: { marginTop: "3%", alignItems: "center", - textAlign: "center", + textAlign: "center" }, noAcc: { - marginTop: "10px", + marginTop: "10px" }, button: { type: "submit", @@ -47,12 +47,12 @@ const useStyles = makeStyles((theme) => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)", + backgroundColor: "rgb(25, 109, 23)" }, ["@media (max-width:550px)"]: { - width: "55%", - }, - }, + width: "55%" + } + } })); export default function SignIn() { const classes = useStyles(); @@ -63,13 +63,13 @@ export default function SignIn() { const [values, setValues] = React.useState({ email: "", password: "", - emailError: false, + emailError: false }); async function update(prop, event) { await setValues({ ...values, [prop]: event.target.value }); } - const handleChange = (prop) => (event) => { + const handleChange = prop => event => { if (!checkEmail()) { values.emailError = true; } else { @@ -103,9 +103,9 @@ export default function SignIn() { const response = await api .post(`/user/signIn`, { email: values.email, - hash: values.password, + hash: values.password }) - .then(function (response) { + .then(function(response) { if (!response.data.error) { window.sessionStorage.setItem("token", response.data.token); window.sessionStorage.setItem("userId", response.data.id); @@ -113,7 +113,7 @@ export default function SignIn() { history.push(path); } }) - .catch(function (error) { + .catch(function(error) { if (error.response) { alert( "Falha de autenticação. Certifique-se que email e senha estão corretos." @@ -131,19 +131,19 @@ export default function SignIn() { const theme = createMuiTheme({ overrides: { root: { - color: "white", + color: "white" }, MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc", + borderBottom: "1px solid #35c7fc" }, "&:after": { - borderBottom: "1px solid #3f51b5", - }, - }, - }, - }, + borderBottom: "1px solid #3f51b5" + } + } + } + } }); return isLoged ? ( <Redirect to={`/list/${window.sessionStorage.getItem("userId")}`} /> @@ -175,7 +175,6 @@ export default function SignIn() { </Grid> <Grid> <IconButton - type="submit" size="medium" className={classes.button} id="whiteTextedButton" -- GitLab From 1f5c2531ab15b601caeef6f267aaef6737132ffa Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Wed, 30 Sep 2020 09:40:20 -0300 Subject: [PATCH 61/72] Issue #48: FIX double error msg while answering Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/pages/AnswerForm.js | 34 +++++++++++++++++----------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index 22b11ae..35425ac 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -4,7 +4,6 @@ import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import api from "../api"; import Button from "@material-ui/core/Button"; -import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import { useHistory } from "react-router-dom"; import FormFieldText from "../components/fieldsAnswerForm/FormFieldText"; @@ -13,7 +12,6 @@ import FormFieldRadio from "../components/fieldsAnswerForm/FormFieldRadio"; import FormFieldCheckbox from "../components/fieldsAnswerForm/FormFieldCheckbox"; import FormFieldTitle from "../components/fieldsAnswerForm/FormFieldTitle"; import FormFieldSubform from "../components/fieldsAnswerForm/FormFieldSubform"; -import { validate } from "json-schema"; const useStyles = makeStyles(theme => ({ menu: { @@ -147,22 +145,24 @@ function AnwserForm() { * @param id - Form id got from the broswer's URL */ async function answerForm(id) { - const res = await api - .post(`/answer/${id}`, backendTranslation()) - .then(function(res) { - alert("Formulário respondido!"); - }) - .catch(error => { - if (error.response.status === 401) { - window.sessionStorage.removeItem("token"); - window.sessionStorage.removeItem("userId"); - let path = `/signin`; - history.push(path); + if (backendTranslation()) { + const res = await api + .post(`/answer/${id}`, backendTranslation()) + .then(function(res) { + alert("Formulário respondido!"); + }) + .catch(error => { + if (error.response.status === 401) { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + let path = `/signin`; + history.push(path); + return; + } + alert("Ocorreu um erro ao responder seu formulário."); return; - } - alert("Ocorreu um erro ao responder seu formulário."); - return; - }); + }); + } } /** -- GitLab From 7ec48f4a752d9d289e0f4ad4baef979b5e8f904c Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Wed, 30 Sep 2020 10:52:23 -0300 Subject: [PATCH 62/72] Issue #37: FIX Chrome ordenation behavior Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/pages/ListForms.js | 36 ++++++++++++++++++++++-------------- 1 file changed, 22 insertions(+), 14 deletions(-) diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index a845790..08788a3 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -10,16 +10,16 @@ import { useHistory } from "react-router-dom"; import CardForm from "../components/fieldsListForms/CardForm.jsx"; import Tab from "../components/fieldsListForms/Tab.jsx"; import { Typography } from "@material-ui/core"; -const useStyles = makeStyles((theme) => ({ +const useStyles = makeStyles(theme => ({ body: { - marginBottom: "15%", + marginBottom: "15%" }, Forms: { textAlign: "center", marginBottom: "3%", - fontSize: "20px", - }, + fontSize: "20px" + } })); export default function ListForms() { const classes = useStyles(); @@ -40,25 +40,33 @@ export default function ListForms() { function sort(type) { setAuxForms([]); if (type === "") { - const tmp = [...forms].sort((a, b) => a.id > b.id); + const tmp = [...forms].sort(function(a, b) { + return a.id > b.id ? 1 : -1; + }); setAuxForms(tmp); } else if (type === 1) { - const tmp = [...forms].sort((a, b) => a.title > b.title); + const tmp = [...forms].sort(function(a, b) { + return a.tittle > b.tittle ? 1 : -1; + }); setAuxForms(tmp); } else if (type === 2) { - const tmp = [...forms].sort((a, b) => a.id < b.id); + const tmp = [...forms].sort(function(a, b) { + return a.id < b.id ? 1 : -1; + }); setAuxForms(tmp); } else if (type === 3) { - const tmp = [...forms].sort((a, b) => a.answersNumber < b.answersNumber); + const tmp = [...forms].sort(function(a, b) { + return a.answersNumber < b.answersNumber ? 1 : -1; + }); setAuxForms(tmp); } else if (type === 4) { let tmp = [...forms] - .filter((value) => { + .filter(value => { return value.date; }) .sort((a, b) => a.date > b.date) .concat( - [...forms].filter((value) => { + [...forms].filter(value => { return value.date === ""; }) ); @@ -73,7 +81,7 @@ export default function ListForms() { function searching(string) { console.log(string); setAuxForms( - [...forms].filter((value) => { + [...forms].filter(value => { return value.title.toLowerCase().includes(string.toLowerCase()); }) ); @@ -86,12 +94,12 @@ export default function ListForms() { async function fetchData(id) { const res = await api .get(`/user/list/${id}`) - .then(function (res) { + .then(function(res) { setForms(res.data.sort((a, b) => a.id > b.id)); setAuxForms(res.data.sort((a, b) => a.id > b.id)); setisLoaded(true); }) - .catch((error) => { + .catch(error => { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); @@ -114,7 +122,7 @@ export default function ListForms() { <Grid className={classes.Forms}>Seus Formulários:</Grid> <Grid container justify="center" spacing={3} className={classes.body}> {auxForms.length ? ( - auxForms.map((form) => ( + auxForms.map(form => ( <Grid item xl={4} lg={4} md={4} sm={6} xs={12} zeroMinWidth> <CardForm id={form.id} -- GitLab From 03249787040e5a2490aa3ab6b251e430a1a146d9 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Wed, 30 Sep 2020 10:57:38 -0300 Subject: [PATCH 63/72] =?UTF-8?q?Issue=20#49:=20Adicionar=20seguran=C3=A7a?= =?UTF-8?q?=20nas=20rotas?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/App.js | 31 ++-------- .../JornalFolder/FormFieldSelect.js | 15 +++-- src/components/header/header.jsx | 1 - src/pages/ListForms.js | 1 - src/pages/SignUp.js | 1 - src/routes.js | 58 +++++++++++++++++++ 6 files changed, 70 insertions(+), 37 deletions(-) create mode 100644 src/routes.js diff --git a/src/App.js b/src/App.js index a0e2b1b..269c83b 100644 --- a/src/App.js +++ b/src/App.js @@ -1,33 +1,12 @@ import React from "react"; -import { HashRouter, Route, Redirect } from "react-router-dom"; import "./global.css"; -import CreateForm from "./pages/CreateForm"; -import AnswerForm from "./pages/AnswerForm"; -import Header from "./components/header/header"; -import Footer from "./components/footer/footer"; -import SignUp from "./pages/SignUp"; -import SignIn from "./pages/SignIn"; -import ListForms from "./pages/ListForms"; -import EditForm from "./pages/EditForm"; -import GetForm from "./pages/GetForm"; -import VisualizeForm from "./pages/VisualizeForm"; +import Routes from "./routes"; +import { BrowserRouter as Router } from "react-router-dom"; function App() { return ( - <HashRouter> - <Header /> - <Route exact path="/"> - <Redirect to="/SignIn" /> - </Route> - <Route path="/SignUp" component={SignUp} /> - <Route path="/SignIn" component={SignIn} /> - <Route path="/visualize/:id" component={VisualizeForm} /> - <Route path="/create" component={CreateForm} /> - <Route path="/answer/:id" component={AnswerForm} /> - <Route path="/edit/:id" component={EditForm} /> - <Route path="/list/:id" component={ListForms} /> - <Route path="/form/:id" component={GetForm} /> - <Footer /> - </HashRouter> + <Router> + <Routes /> + </Router> ); } diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js index d83bf41..db34cfe 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js @@ -8,21 +8,21 @@ import Typography from "@material-ui/core/Typography"; import FieldFooterOptions from "./FieldFooterOptions"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), marginBottom: "2%", ["@media (max-width: 896px)"]: { - width: "300px" - } + width: "300px", + }, }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" - } + color: "black", + }, })); function FormFieldSelect(props) { @@ -32,9 +32,8 @@ function FormFieldSelect(props) { * Function to handle the selected answer. */ function handleProps() { - console.log(props.answer); if (props.answer) { - return props.answer.filter(each => { + return props.answer.filter((each) => { return each.value === "true"; })[0].placement; } else { diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 696c62b..61c014d 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -70,7 +70,6 @@ export default function Header() { return false; } useEffect(() => { - console.log("O TOKEN MUDOU"); setIsLoged(!isLoged); }, [window.sessionStorage.getItem("token")]); diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index 08788a3..c65df33 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -79,7 +79,6 @@ export default function ListForms() { * @param string - the string value to be searched. */ function searching(string) { - console.log(string); setAuxForms( [...forms].filter(value => { return value.title.toLowerCase().includes(string.toLowerCase()); diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index 8b3ac05..ae6891b 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -262,7 +262,6 @@ export default function SignUp() { </Grid> <Grid> <IconButton - type="submit" size="medium" className={classes.button} id="whiteTextedButton" diff --git a/src/routes.js b/src/routes.js new file mode 100644 index 0000000..42bab39 --- /dev/null +++ b/src/routes.js @@ -0,0 +1,58 @@ +import React, { useEffect } from "react"; +import CreateForm from "./pages/CreateForm"; +import AnswerForm from "./pages/AnswerForm"; +import Header from "./components/header/header"; +import Footer from "./components/footer/footer"; +import SignUp from "./pages/SignUp"; +import SignIn from "./pages/SignIn"; +import ListForms from "./pages/ListForms"; +import EditForm from "./pages/EditForm"; +import GetForm from "./pages/GetForm"; +import VisualizeForm from "./pages/VisualizeForm"; +import { BrowserRouter, Route, Switch, Redirect } from "react-router-dom"; + +const PrivateRoute = ({ component: Component, ...rest }) => { + let usr; + rest.path === "/list/:id" && + rest.computedMatch.params.id === window.sessionStorage.getItem("userId") && + (usr = true); + + return ( + <Route + {...rest} + render={(props) => + usr && window.sessionStorage.getItem("token") !== null ? ( + <Component {...props} /> + ) : ( + <Redirect to={{ pathname: "/" }} /> + ) + } + /> + ); +}; + +const Routes = () => ( + <BrowserRouter> + <Header /> + <Switch> + <Route exact path="/"> + <Redirect to="/SignIn" /> + </Route> + <Route exact path="/SignUp" component={SignUp} /> + <Route exact path="/SignIn" component={SignIn} /> + <PrivateRoute + exact + path="/visualize/:id" + component={() => <VisualizeForm />} + /> + <PrivateRoute exact path="/create" component={() => <CreateForm />} /> + <PrivateRoute exact path="/answer/:id" component={() => <AnswerForm />} /> + <PrivateRoute exact path="/edit/:id" component={() => <EditForm />} /> + <PrivateRoute exact path="/list/:id" component={() => <ListForms />} /> + <PrivateRoute exact path="/form/:id" component={() => <GetForm />} /> + </Switch> + <Footer /> + </BrowserRouter> +); + +export default Routes; -- GitLab From 3a9514bc5086cdf99b741c618f56377d3d896d4b Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Wed, 30 Sep 2020 11:02:26 -0300 Subject: [PATCH 64/72] Issue #35: Loading is now a progress gif Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/components/fieldsAnswerForm/FormFieldSubform.js | 10 +++++++--- .../fieldsGetForm/JornalFolder/FormFieldSubform.js | 10 +++++++--- .../fieldsGetForm/SummaryFolder/FormFieldSubform.js | 8 +++++++- .../fieldsVisualizeForm/FormFieldSubform.js | 11 ++++++++--- src/pages/AnswerForm.js | 8 +++++++- src/pages/GetForm.js | 8 +++++++- src/pages/ListForms.js | 9 +++++++-- src/pages/VisualizeForm.js | 8 +++++++- 8 files changed, 57 insertions(+), 15 deletions(-) diff --git a/src/components/fieldsAnswerForm/FormFieldSubform.js b/src/components/fieldsAnswerForm/FormFieldSubform.js index e8a139f..6d87aa6 100644 --- a/src/components/fieldsAnswerForm/FormFieldSubform.js +++ b/src/components/fieldsAnswerForm/FormFieldSubform.js @@ -1,9 +1,8 @@ import React, { useState, useEffect } from "react"; -import { useParams } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; -import Button from "@material-ui/core/Button"; import api from "../../api"; +import CircularProgress from "@material-ui/core/CircularProgress"; import FormFieldText from "./FormFieldText"; import FormFieldSelect from "./FormFieldSelect"; @@ -18,6 +17,9 @@ const useStyles = makeStyles(theme => ({ top: theme.spacing(10), left: "90%", padding: theme.spacing(1) + }, + progress: { + marginTop: "5%" } })); @@ -111,7 +113,9 @@ function FormFieldSubform(props) { })} </div> ) : ( - <p>Loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> )} </Grid> ); diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js b/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js index 78d14e5..f92ab2f 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldSubform.js @@ -2,9 +2,8 @@ import React, { useState, useEffect } from "react"; import { useParams, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; -import Button from "@material-ui/core/Button"; import api from "../../../api"; - +import CircularProgress from "@material-ui/core/CircularProgress"; import FormFieldText from "./FormFieldText"; import FormFieldSelect from "./FormFieldSelect"; import FormFieldRadio from "./FormFieldRadio"; @@ -18,6 +17,9 @@ const useStyles = makeStyles(theme => ({ top: theme.spacing(10), left: "90%", padding: theme.spacing(1) + }, + progress: { + marginTop: "5%" } })); @@ -121,7 +123,9 @@ function FormFieldSubform(props) { })} </div> ) : ( - <p>Loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> )} </Grid> </div> diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js index b784f80..cea4392 100644 --- a/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldSubform.js @@ -3,6 +3,7 @@ import { useParams, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; import api from "../../../api"; +import CircularProgress from "@material-ui/core/CircularProgress"; import FormFieldText from "./FormFieldText"; import FormFieldSelect from "./FormFieldSelect"; @@ -17,6 +18,9 @@ const useStyles = makeStyles(theme => ({ top: theme.spacing(10), left: "90%", padding: theme.spacing(1) + }, + progress: { + marginTop: "5%" } })); @@ -124,7 +128,9 @@ function FormFieldSubform(props) { })} </div> ) : ( - <p>Loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> )} </Grid> </> diff --git a/src/components/fieldsVisualizeForm/FormFieldSubform.js b/src/components/fieldsVisualizeForm/FormFieldSubform.js index ce45234..038d612 100644 --- a/src/components/fieldsVisualizeForm/FormFieldSubform.js +++ b/src/components/fieldsVisualizeForm/FormFieldSubform.js @@ -1,14 +1,14 @@ import React, { useState, useEffect } from "react"; import { useParams, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; -import Grid from "@material-ui/core/Grid"; -import Button from "@material-ui/core/Button"; import api from "../../api"; +import Grid from "@material-ui/core/Grid"; import FormFieldText from "./FormFieldText"; import FormFieldSelect from "./FormFieldSelect"; import FormFieldRadio from "./FormFieldRadio"; import FormFieldCheckbox from "./FormFieldCheckbox"; +import CircularProgress from "@material-ui/core/CircularProgress"; const useStyles = makeStyles(theme => ({ menu: { @@ -18,6 +18,9 @@ const useStyles = makeStyles(theme => ({ top: theme.spacing(10), left: "90%", padding: theme.spacing(1) + }, + progress: { + marginTop: "5%" } })); @@ -105,7 +108,9 @@ function FormFieldSubform(props) { ); }) ) : ( - <p>Loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> )} </> ); diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index 35425ac..08e0795 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -5,6 +5,7 @@ import Grid from "@material-ui/core/Grid"; import api from "../api"; import Button from "@material-ui/core/Button"; import { useHistory } from "react-router-dom"; +import CircularProgress from "@material-ui/core/CircularProgress"; import FormFieldText from "../components/fieldsAnswerForm/FormFieldText"; import FormFieldSelect from "../components/fieldsAnswerForm/FormFieldSelect"; @@ -22,6 +23,9 @@ const useStyles = makeStyles(theme => ({ left: "90%", padding: theme.spacing(1) }, + progress: { + marginTop: "5%" + }, button: { type: "submit", width: "100%", @@ -300,7 +304,9 @@ function AnwserForm() { })} </div> ) : ( - <p>Loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> )} </Grid> <Grid> diff --git a/src/pages/GetForm.js b/src/pages/GetForm.js index 849869e..0449266 100644 --- a/src/pages/GetForm.js +++ b/src/pages/GetForm.js @@ -1,6 +1,7 @@ import React, { useState, useEffect } from "react"; import { useParams, Redirect, useHistory } from "react-router-dom"; import { makeStyles } from "@material-ui/core/styles"; +import CircularProgress from "@material-ui/core/CircularProgress"; import Grid from "@material-ui/core/Grid"; import api from "../api"; import FormControl from "@material-ui/core/FormControl"; @@ -20,6 +21,9 @@ const useStyles = makeStyles(theme => ({ left: "90%", padding: theme.spacing(1) }, + progress: { + marginTop: "5%" + }, selector: { width: "100%", borderRadius: "2px", @@ -229,7 +233,9 @@ function GetForm() { </Grid> </Grid> ) : ( - <p>loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> ); } diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index c65df33..7ecefdc 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -5,6 +5,7 @@ import Grid from "@material-ui/core/Grid"; import Container from "@material-ui/core/Container"; import { makeStyles } from "@material-ui/core/styles"; import { useHistory } from "react-router-dom"; +import CircularProgress from "@material-ui/core/CircularProgress"; // Components import CardForm from "../components/fieldsListForms/CardForm.jsx"; @@ -15,6 +16,10 @@ const useStyles = makeStyles(theme => ({ marginBottom: "15%" }, + progress: { + marginTop: "5%" + }, + Forms: { textAlign: "center", marginBottom: "3%", @@ -144,8 +149,8 @@ export default function ListForms() { </div> </> ) : ( - <Grid justify="center"> - <p>loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> </Grid> ); } diff --git a/src/pages/VisualizeForm.js b/src/pages/VisualizeForm.js index ea9951e..e4ff0a4 100644 --- a/src/pages/VisualizeForm.js +++ b/src/pages/VisualizeForm.js @@ -5,6 +5,7 @@ import Grid from "@material-ui/core/Grid"; import api from "../api"; import { createMuiTheme, MuiThemeProvider, Button } from "@material-ui/core"; import { useHistory } from "react-router-dom"; +import CircularProgress from "@material-ui/core/CircularProgress"; import FormFieldText from "../components/fieldsVisualizeForm/FormFieldText"; import FormFieldSelect from "../components/fieldsVisualizeForm/FormFieldSelect"; @@ -23,6 +24,9 @@ const useStyles = makeStyles(theme => ({ marginBottom: "20%" } }, + progress: { + marginTop: "5%" + }, pageBody: { minHeight: "calc(100vh - 92.4px - 78px)", paddingBottom: "78px" @@ -181,7 +185,9 @@ function VisualizeForm() { </Grid> </> ) : ( - <p>Loading...</p> + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> )} </Grid> </div> -- GitLab From b6ae53aab80cb30eb7c63eb83ef14feaa92edd24 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Wed, 30 Sep 2020 11:51:47 -0300 Subject: [PATCH 65/72] Issue #50: Fix redirecionamento rotas Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/routes.js | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/routes.js b/src/routes.js index 42bab39..8a23828 100644 --- a/src/routes.js +++ b/src/routes.js @@ -12,11 +12,10 @@ import VisualizeForm from "./pages/VisualizeForm"; import { BrowserRouter, Route, Switch, Redirect } from "react-router-dom"; const PrivateRoute = ({ component: Component, ...rest }) => { - let usr; + let usr = true; rest.path === "/list/:id" && - rest.computedMatch.params.id === window.sessionStorage.getItem("userId") && - (usr = true); - + rest.computedMatch.params.id !== window.sessionStorage.getItem("userId") && + (usr = false); return ( <Route {...rest} -- GitLab From 95e1efca7adc0162780228e8de47ee8b50b97673 Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Fri, 2 Oct 2020 10:20:57 -0300 Subject: [PATCH 66/72] Issue #51: FIX Chrome string sort --- src/pages/ListForms.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index 7ecefdc..f72a1f8 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -50,8 +50,8 @@ export default function ListForms() { }); setAuxForms(tmp); } else if (type === 1) { - const tmp = [...forms].sort(function(a, b) { - return a.tittle > b.tittle ? 1 : -1; + const tmp = [...forms].sort((a, b) => { + return a.title.toLowerCase().localeCompare(b.title.toLowerCase()); }); setAuxForms(tmp); } else if (type === 2) { -- GitLab From 624974539259c3e2d5dd43d39110be89c05c6b9f Mon Sep 17 00:00:00 2001 From: Richard Fernando Heise Ferreira <rfhf19@inf.ufpr.br> Date: Mon, 5 Oct 2020 09:27:49 -0300 Subject: [PATCH 67/72] Issue #29: User can't answer a form twice Signed-off-by: Richard Heise <rfhf19@inf.ufpr.br> --- src/pages/AnswerForm.js | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index 08e0795..0887a12 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -153,6 +153,7 @@ function AnwserForm() { const res = await api .post(`/answer/${id}`, backendTranslation()) .then(function(res) { + setCookie("answerForm", id, 92); alert("Formulário respondido!"); }) .catch(error => { @@ -205,6 +206,7 @@ function AnwserForm() { const res = await api .get(`/form/${id}`) .then(function(res) { + checkCookie(id); setFormData(res.data); mapInputs(res.data); }) @@ -223,6 +225,38 @@ function AnwserForm() { }); } + function setCookie(cookieName, cookieValue, expirationsDays) { + var date = new Date(); + date.setTime(date.getTime() + expirationsDays * 60 * 60 * 24 * 1000); + var expires = "expires=" + date.toUTCString(); + document.cookie = + cookieName + "=" + cookieValue + ";" + expires + ";path=/"; + } + + function getCookie(cookieName) { + var name = cookieName + "="; + var ca = document.cookie.split(";"); + for (var i = 0; i < ca.length; i++) { + var c = ca[i]; + while (c.charAt(0) == " ") { + c = c.substring(1); + } + if (c.indexOf(name) == 0) { + return c.substring(name.length, c.length); + } + } + return ""; + } + + function checkCookie(id) { + var answer = getCookie("answerForm"); + if (answer == id) { + alert("Você já respondeu esse formulário! "); + let path = `/signin`; + history.push(path); + } + } + /** First thing the page does is getting the form from the API. */ useEffect(() => { getForm(id); -- GitLab From 3f7f4b004970ea132d0a1356ba3bcc603019bd6b Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Mon, 5 Oct 2020 21:00:26 -0300 Subject: [PATCH 68/72] =?UTF-8?q?Issue=20#32:=20Mudan=C3=A7as=20icone=20de?= =?UTF-8?q?=20usuario=20no=20header?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/components/header/header.jsx | 8 +- .../header/header_components/LogoutButton.jsx | 64 +++++++ .../header/header_components/MenuList.jsx | 176 ------------------ 3 files changed, 69 insertions(+), 179 deletions(-) create mode 100644 src/components/header/header_components/LogoutButton.jsx delete mode 100644 src/components/header/header_components/MenuList.jsx diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index 61c014d..b7e6287 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -3,7 +3,7 @@ import Grid from "@material-ui/core/Grid"; import { useHistory } from "react-router-dom"; import logo from "./header_imgs/imgsimmc-01.png"; import { makeStyles } from "@material-ui/core"; -import MenuListComposition from "./header_components/MenuList"; +import LogoutButton from "./header_components/LogoutButton"; const useStyles = makeStyles((theme) => ({ header: { @@ -70,7 +70,7 @@ export default function Header() { return false; } useEffect(() => { - setIsLoged(!isLoged); + setIsLoged(checkLoged); }, [window.sessionStorage.getItem("token")]); return ( @@ -132,7 +132,9 @@ export default function Header() { justify="center" alignContent="flex-end" > - <MenuListComposition isLoged={isLoged} checkLoged={checkLoged} /> + {isLoged && ( + <LogoutButton isLoged={isLoged} checkLoged={checkLoged} /> + )} </Grid> </Grid> </header> diff --git a/src/components/header/header_components/LogoutButton.jsx b/src/components/header/header_components/LogoutButton.jsx new file mode 100644 index 0000000..7c8bfc9 --- /dev/null +++ b/src/components/header/header_components/LogoutButton.jsx @@ -0,0 +1,64 @@ +import React from "react"; +import Button from "@material-ui/core/Button"; +import { useHistory } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; + +const useStyles = makeStyles((theme) => ({ + menuPopUp: { + alignContent: "start", + ["@media (max-width:346px)"]: { + width: "23%", + }, + }, + menuList: { + alignItems: "flex-start", + color: "grey", + }, + button: { + marginRight: "10px", + fontSize: 14, + width: "80px", + backgroundColor: "#0480ab", + color: "white", + ["@media (max-width: 600px)"]: { + width: "60px", + fontSize: 12, + }, + }, +})); + +/** + * Para fazer com que o componente não apareça em telas em que o usuário não está logado, basta fazer uma função de verificação para tal e retornar o componente, + * caso logado, ou NULL, caso não-logado. + */ + +function LogoutButton(props) { + const [open, setOpen] = React.useState(false); + const history = useHistory(); + + const handleLogOut = (event) => { + window.sessionStorage.removeItem("token"); + window.sessionStorage.removeItem("userId"); + props.checkLoged(); + let path = `/signin`; + history.push(path); + }; + + const classes = useStyles(); + + return ( + <div> + <Button + className={classes.button} + id="notWhiteButton" + aria-haspopup="true" + onClick={handleLogOut} + variant="contained" + > + LogOut + </Button> + </div> + ); +} + +export default LogoutButton; diff --git a/src/components/header/header_components/MenuList.jsx b/src/components/header/header_components/MenuList.jsx deleted file mode 100644 index e6d9fa6..0000000 --- a/src/components/header/header_components/MenuList.jsx +++ /dev/null @@ -1,176 +0,0 @@ -import React from "react"; -import Button from "@material-ui/core/Button"; -import ClickAwayListener from "@material-ui/core/ClickAwayListener"; -import Grow from "@material-ui/core/Grow"; -import Paper from "@material-ui/core/Paper"; -import Popper from "@material-ui/core/Popper"; -import MenuItem from "@material-ui/core/MenuItem"; -import { useHistory } from "react-router-dom"; -import MenuList from "@material-ui/core/MenuList"; -import { makeStyles } from "@material-ui/core/styles"; -import UserImg from "./../header_imgs/user.png"; - -import { Avatar } from "@material-ui/core"; - -const useStyles = makeStyles((theme) => ({ - menuPopUp: { - alignContent: "start", - ["@media (max-width:346px)"]: { - width: "23%", - }, - }, - menuPopUpText: { - ["@media (max-width:525px)"]: { - fontSize: "13px", - }, - }, - popUpPaper: { - marginRight: "14%", - ["@media (max-width:525px)"]: { - marginRight: "0", - }, - }, - menuList: { - alignItems: "flex-start", - color: "grey", - }, -})); - -/** - * Para fazer com que o componente não apareça em telas em que o usuário não está logado, basta fazer uma função de verificação para tal e retornar o componente, - * caso logado, ou NULL, caso não-logado. - */ - -function MenuListComposition(props) { - const [open, setOpen] = React.useState(false); - const history = useHistory(); - - const handleLogin = () => { - let path = `/signin`; - history.push(path); - }; - - const prevOpen = React.useRef(open); - - const anchorRef = React.useRef(null); - const handleToggle = () => { - setOpen((prevOpen) => !prevOpen); - }; - const handleProfile = (event) => { - if (window.sessionStorage.getItem("userId")) { - let path = `/list/${window.sessionStorage.getItem("userId")}`; - history.push(path); - return; - } - - alert("Você não está logado."); - }; - const handleLogOut = (event) => { - window.sessionStorage.removeItem("token"); - window.sessionStorage.removeItem("userId"); - props.checkLoged(); - let path = `/signin`; - history.push(path); - }; - const handleClose = (event) => { - if (anchorRef.current && anchorRef.current.contains(event.target)) { - return; - } - setOpen(false); - }; - function handleListKeyDown(event) { - if (event.key === "Tab") { - event.preventDefault(); - setOpen(false); - } - } - React.useEffect(() => { - if (prevOpen.current === true && open === false) { - anchorRef.current.focus(); - props.checkLoged(); - } - - prevOpen.current = open; - }, [open]); - - const classes = useStyles(); - - return ( - <div> - <Button - id="notWhiteButton" - ref={anchorRef} - aria-controls={open ? "menu-list-grow" : undefined} - aria-haspopup="true" - onClick={handleToggle} - > - <Avatar alt="user_avatar" src={UserImg} className={classes.userImg} />{" "} - </Button> - <Popper - open={open} - placement="left" - anchorEl={anchorRef.current} - role={undefined} - transition - disablePortal - className={classes.menuPopUp} - > - {({ TransitionProps, placement }) => ( - <Grow - {...TransitionProps} - style={{ - transformOrigin: - placement === "bottom" ? "center top" : "center bottom", - }} - > - <Paper className={classes.popUpPaper}> - {props.isLoged ? ( - <ClickAwayListener onClickAway={handleClose}> - <MenuList - className={classes.menuList} - autoFocusItem={open} - id="menu-list-grow" - onKeyDown={handleListKeyDown} - alignContent="flex-start" - > - <MenuItem - onClick={handleProfile} - className={classes.menuPopUpText} - > - Perfil - </MenuItem> - <MenuItem - onClick={handleLogOut} - className={classes.menuPopUpText} - > - Logout - </MenuItem> - </MenuList> - </ClickAwayListener> - ) : ( - <ClickAwayListener onClickAway={handleClose}> - <MenuList - className={classes.menuList} - autoFocusItem={open} - id="menu-list-grow" - onKeyDown={handleListKeyDown} - alignContent="flex-start" - > - <MenuItem - onClick={handleLogin} - className={classes.menuPopUpText} - > - Login - </MenuItem> - </MenuList> - </ClickAwayListener> - )} - </Paper> - </Grow> - )} - </Popper> - </div> - ); -} - -export default MenuListComposition; -- GitLab From 80ff48dcb189f163e4d606e244d9fb8a7799014e Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Thu, 15 Oct 2020 11:42:48 -0300 Subject: [PATCH 69/72] Issue #52: Add multiple answers interface Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- .../fieldsAnswerForm/FieldFooterOptions.js | 40 ----- .../fieldsAnswerForm/FormFieldCheckbox.js | 24 ++- .../fieldsAnswerForm/FormFieldRadio.js | 28 ++-- .../fieldsAnswerForm/FormFieldSelect.js | 28 ++-- .../fieldsAnswerForm/FormFieldText.js | 22 ++- .../fieldsAnswerForm/FormFieldTitle.js | 28 ++-- .../fieldsDisplayForm/DisplayForm.js | 52 ++++--- .../fieldsDisplayForm/FormFieldTitle.js | 35 ++++- .../utils/BackendTranslation.js | 1 + .../utils/FormComposition.js | 3 +- .../utils/FrontEndTranslation.js | 8 +- .../JornalFolder/FieldFooterOptions.js | 40 ----- .../JornalFolder/FormFieldCheckbox.js | 14 +- .../JornalFolder/FormFieldRadio.js | 16 +- .../JornalFolder/FormFieldSelect.js | 2 - .../JornalFolder/FormFieldTitle.js | 24 ++- .../fieldsGetForm/JornalFolder/FormJornal.js | 18 ++- .../SummaryFolder/FieldFooterOptions.js | 33 ----- .../SummaryFolder/FormFieldTitle.js | 28 ++-- .../SummaryFolder/FormSummary.js | 14 ++ .../fieldsVisualizeForm/FieldFooterOptions.js | 40 ----- .../fieldsVisualizeForm/FormFieldCheckbox.js | 2 - .../fieldsVisualizeForm/FormFieldRadio.js | 2 - .../fieldsVisualizeForm/FormFieldSelect.js | 2 - .../fieldsVisualizeForm/FormFieldTitle.js | 2 - src/contexts/FormContext.js | 15 +- src/contexts/useForm.js | 59 ++++---- src/pages/Acknowledgement.js | 79 ++++++++++ src/pages/AnswerForm.js | 52 ++++--- src/pages/GetForm.js | 29 ++-- src/pages/ListForms.js | 26 ++-- src/pages/SignUp.js | 140 +++++++++--------- src/pages/VisualizeForm.js | 26 +++- src/routes.js | 4 +- 34 files changed, 459 insertions(+), 477 deletions(-) delete mode 100644 src/components/fieldsAnswerForm/FieldFooterOptions.js delete mode 100644 src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js delete mode 100644 src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js delete mode 100644 src/components/fieldsVisualizeForm/FieldFooterOptions.js create mode 100644 src/pages/Acknowledgement.js diff --git a/src/components/fieldsAnswerForm/FieldFooterOptions.js b/src/components/fieldsAnswerForm/FieldFooterOptions.js deleted file mode 100644 index f6446f0..0000000 --- a/src/components/fieldsAnswerForm/FieldFooterOptions.js +++ /dev/null @@ -1,40 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; - -function FieldFooterOptions(props) { - - return ( - <> - <FormControlLabel - control={ - <Switch - onChange={e => props.setRequiredField(props.idq) } - value="required" - color="primary" - checked={props.required} - /> - } - label="Obrigatória" - /> - <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> - <DeleteOutlinedIcon /> - </IconButton> - </> - ); - - -} - - -export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/fieldsAnswerForm/FormFieldCheckbox.js b/src/components/fieldsAnswerForm/FormFieldCheckbox.js index 3cb3848..f2f9eb7 100644 --- a/src/components/fieldsAnswerForm/FormFieldCheckbox.js +++ b/src/components/fieldsAnswerForm/FormFieldCheckbox.js @@ -5,31 +5,29 @@ import Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; import Checkbox from "@material-ui/core/Checkbox"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), minHeight: "15%", margin: theme.spacing(2), ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: theme.spacing(70), }, ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + width: theme.spacing(40), + }, }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldCheckbox(props) { @@ -38,7 +36,7 @@ function FormFieldCheckbox(props) { /** Temporary array to be used as a type. */ function vetorTmp() { let tmp = []; - props.options.map(x => { + props.options.map((x) => { tmp.push(false); }); return tmp; @@ -76,11 +74,11 @@ function FormFieldCheckbox(props) { let isValid = true; setValid(""); - props.validation.map(val => { + props.validation.map((val) => { switch (val.type) { case 6: if ( - !answer.some(value => { + !answer.some((value) => { return value === true; }) ) { diff --git a/src/components/fieldsAnswerForm/FormFieldRadio.js b/src/components/fieldsAnswerForm/FormFieldRadio.js index 2398fe7..ef01713 100644 --- a/src/components/fieldsAnswerForm/FormFieldRadio.js +++ b/src/components/fieldsAnswerForm/FormFieldRadio.js @@ -6,31 +6,29 @@ import Typography from "@material-ui/core/Typography"; import Radio from "@material-ui/core/Radio"; import RadioGroup from "@material-ui/core/RadioGroup"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), minheight: theme.spacing(18), margin: theme.spacing(2), ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: theme.spacing(70), }, ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + width: theme.spacing(40), + }, }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldRadio(props) { @@ -39,7 +37,7 @@ function FormFieldRadio(props) { /** Temporary array to be used as a type. */ function vetorTmp() { let tmp = []; - props.options.map(x => { + props.options.map((x) => { tmp.push(false); }); return tmp; @@ -62,11 +60,11 @@ function FormFieldRadio(props) { let isValid = true; setValid(""); - props.validation.map(val => { + props.validation.map((val) => { switch (val.type) { case 2: if ( - !answer.some(value => { + !answer.some((value) => { return value === true; }) ) { @@ -103,12 +101,12 @@ function FormFieldRadio(props) { * Function to set the selectedValue as the event. * @param event - React event to get what is selected. */ - const handleChange = event => { + const handleChange = (event) => { setSelectedValue(event.target.value); }; /** HTML object to be displayed on component return. */ - const options = props.options.map(function(x, index) { + const options = props.options.map(function (x, index) { return ( <span> <Typography diff --git a/src/components/fieldsAnswerForm/FormFieldSelect.js b/src/components/fieldsAnswerForm/FormFieldSelect.js index e4845ae..e5b7964 100644 --- a/src/components/fieldsAnswerForm/FormFieldSelect.js +++ b/src/components/fieldsAnswerForm/FormFieldSelect.js @@ -6,31 +6,29 @@ import Select from "@material-ui/core/Select"; import MenuItem from "@material-ui/core/MenuItem"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), minheight: theme.spacing(18), margin: theme.spacing(2), ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: theme.spacing(70), }, ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + width: theme.spacing(40), + }, }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldSelect(props) { @@ -39,7 +37,7 @@ function FormFieldSelect(props) { /** Temporary array to be used as a type. */ function vetorTmp() { let tmp = []; - props.options.map(x => { + props.options.map((x) => { tmp.push(false); }); return tmp; @@ -59,11 +57,11 @@ function FormFieldSelect(props) { let isValid = true; setValid(""); - props.validation.map(val => { + props.validation.map((val) => { switch (val.type) { case 2: if ( - !answer.some(value => { + !answer.some((value) => { return value === true; }) ) { @@ -83,7 +81,7 @@ function FormFieldSelect(props) { * Function to set the selectedValue as the event. * @param event - React event to get what is selected. */ - const handleChange = event => { + const handleChange = (event) => { validate([]); setselectedValue(event.target.value); }; @@ -109,7 +107,7 @@ function FormFieldSelect(props) { } /** HTML object to be displayed on component return. */ - const options = props.options.map(function(x) { + const options = props.options.map(function (x) { return <MenuItem value={x.placement}>{x.value}</MenuItem>; }); diff --git a/src/components/fieldsAnswerForm/FormFieldText.js b/src/components/fieldsAnswerForm/FormFieldText.js index 97a5315..bb856bc 100644 --- a/src/components/fieldsAnswerForm/FormFieldText.js +++ b/src/components/fieldsAnswerForm/FormFieldText.js @@ -5,31 +5,29 @@ import Paper from "@material-ui/core/Paper"; import TextField from "@material-ui/core/TextField"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), height: "15%", margin: theme.spacing(2), ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: theme.spacing(70), }, ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + width: theme.spacing(40), + }, }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" + color: "black", }, validation: { fontSize: "14px", - color: "red" - } + color: "red", + }, })); function FormFieldText(props) { @@ -46,7 +44,7 @@ function FormFieldText(props) { let isValid = true; setValid(""); - props.validation.map(val => { + props.validation.map((val) => { switch (val.type) { case 2: if (answer === "") { @@ -82,7 +80,7 @@ function FormFieldText(props) { * Function to send answer to the father component. * @param event - React event to get what is typed in. */ - const handleChange = event => { + const handleChange = (event) => { if (validate(event.target.value)) { props.createAnswer(props.id, event.target.value, false); } else { diff --git a/src/components/fieldsAnswerForm/FormFieldTitle.js b/src/components/fieldsAnswerForm/FormFieldTitle.js index 028d969..ce4906d 100644 --- a/src/components/fieldsAnswerForm/FormFieldTitle.js +++ b/src/components/fieldsAnswerForm/FormFieldTitle.js @@ -4,48 +4,46 @@ import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), margin: theme.spacing(2), color: "#000000", ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: theme.spacing(70), }, ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + width: theme.spacing(40), + }, }, questionsGrid: { marginBottom: "20px", color: "#000000", ["@media (max-width:827px)"]: { - width: theme.spacing(70) - } + width: theme.spacing(70), + }, }, title: { fontSize: "45px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "35px" + fontSize: "35px", }, ["@media (max-width:590px)"]: { - fontSize: "25px" - } + fontSize: "25px", + }, }, description: { fontSize: "25px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "20px" + fontSize: "20px", }, ["@media (max-width:590px)"]: { - fontSize: "15px" - } - } + fontSize: "15px", + }, + }, })); function FormFieldText(props) { diff --git a/src/components/fieldsDisplayForm/DisplayForm.js b/src/components/fieldsDisplayForm/DisplayForm.js index 236742f..682db7b 100644 --- a/src/components/fieldsDisplayForm/DisplayForm.js +++ b/src/components/fieldsDisplayForm/DisplayForm.js @@ -19,51 +19,51 @@ import { FormEditionContext } from "../../contexts/FormContext"; import useForm from "../../contexts/useForm"; import SubmitButton from "./SubmitButton"; /** CSS styles used on page components */ -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ app: { margin: "0", padding: "40px", display: "flex", ["@media (max-width: 600px)"]: { flexDirection: "column-reverse", - justifyContent: "flex-end" + justifyContent: "flex-end", }, paddingBottom: "78px", ["@media (min-width: 600px)"]: { - minHeight: "calc(100vh - 92.4px - 78px -60px)" + minHeight: "calc(100vh - 92.4px - 78px -60px)", }, minHeight: "calc(100vh - 71.6px - 78px -60px)", - marginBottom: "60px" + marginBottom: "60px", }, addButton: { - fontSize: "100%" + fontSize: "100%", }, sideMenuFormatingGrid: { ["@media (max-width:600px)"]: { - marginTop: "-90px" - } + marginTop: "-90px", + }, }, sizeFormating: { ["@media (max-width:600px)"]: { ["@media (max-width:430px)"]: { marginLeft: "1%", - width: "95%" + width: "95%", }, - marginLeft: "2%" - } + marginLeft: "2%", + }, }, button: { marginLeft: "5%", backgroundColor: "#a30202", minWidth: "92px", ["@media (max-width:600px)"]: { - marginTop: "52px" + marginTop: "52px", }, width: "12%", ["@media (max-width:600px)"]: { - marginTop: "52px" - } - } + marginTop: "52px", + }, + }, })); /** CSS style used through Material Ui. */ const theme = createMuiTheme({ @@ -71,19 +71,19 @@ const theme = createMuiTheme({ MuiInput: { underline: { "&:before": { - borderBottom: "1px solid #35c7fc" + borderBottom: "1px solid #35c7fc", }, "&:after": { - borderBottom: "1px solid #3f51b5" - } - } + borderBottom: "1px solid #3f51b5", + }, + }, }, MuiButton: { label: { - color: "white" - } - } - } + color: "white", + }, + }, + }, }); /** Main function that returns the children that composes the form creation or edition page. */ function DisplayForm() { @@ -107,6 +107,9 @@ function DisplayForm() { history.push(path); } }; + useEffect(() => { + console.log(form); + }, [form]); /** Error handling -> every time the form object is updated, it is verified to evaluate it's error messages, * so the submit button can be enabled or disabled. @@ -213,12 +216,13 @@ function DisplayForm() { description={x.description} idq={index} error={x.error} + multAnswer={x.mult_answer} /> ); }) ) : ( - <p> carregando... </p> - )} + <p> carregando... </p> + )} {provided.placeholder} </Grid> ); diff --git a/src/components/fieldsDisplayForm/FormFieldTitle.js b/src/components/fieldsDisplayForm/FormFieldTitle.js index 257f5ec..108af54 100644 --- a/src/components/fieldsDisplayForm/FormFieldTitle.js +++ b/src/components/fieldsDisplayForm/FormFieldTitle.js @@ -4,6 +4,9 @@ import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; import TextField from "@material-ui/core/TextField"; import useForm from "../../contexts/useForm"; +import FormControlLabel from "@material-ui/core/FormControlLabel"; +import Tooltip from "@material-ui/core/Tooltip"; +import Switch from "@material-ui/core/Switch"; /** CSS styles used on page components. */ const useStyles = makeStyles((theme) => ({ @@ -47,7 +50,11 @@ function FormFieldText(props) { /** Style class. */ const classes = useStyles(); /** Importing functions to change the question and the description values. */ - const { setQuestionField, setDescriptionField } = useForm(); + const { + setQuestionField, + setDescriptionField, + setMultipleAnswer, + } = useForm(); return ( <Paper className={classes.paper}> <TextField @@ -91,10 +98,28 @@ function FormFieldText(props) { item container direction="row" - justify="flex-end" - alignItems="flex-end" - xs={3} - ></Grid> + justify="flex-start" + alignItems="flex-start" + xs={12} + > + <Tooltip + title="Marcar como obrigatório" + aria-label="Marcar como obrigatório" + > + <FormControlLabel + control={ + <Switch + onChange={(e) => setMultipleAnswer()} + value="required" + color="primary" + checked={props.multAnswer} + /> + } + style={{ size: "0px" }} + label="Habilitar resposta múltipla por usuário" + /> + </Tooltip> + </Grid> </Paper> ); } diff --git a/src/components/fieldsDisplayForm/utils/BackendTranslation.js b/src/components/fieldsDisplayForm/utils/BackendTranslation.js index 06687d9..6e973d1 100644 --- a/src/components/fieldsDisplayForm/utils/BackendTranslation.js +++ b/src/components/fieldsDisplayForm/utils/BackendTranslation.js @@ -91,6 +91,7 @@ export default async function createBackendForm(form) { title: form[0].question, description: form[0].description, inputs: [], + answerTimes: form[0].mult_answer, }; for (var i = 1; i < form.length; i++) { setInput( diff --git a/src/components/fieldsDisplayForm/utils/FormComposition.js b/src/components/fieldsDisplayForm/utils/FormComposition.js index 133b30c..6ba7816 100644 --- a/src/components/fieldsDisplayForm/utils/FormComposition.js +++ b/src/components/fieldsDisplayForm/utils/FormComposition.js @@ -5,11 +5,12 @@ import uuid from "uuid/v4"; * @param title - the title; * @param description - the description of the form. */ -export function pushTitle(form, title, description, id) { +export function pushTitle(form, title, description, id, answerTimes) { return form.push({ type: "title", question: title ? title : "", description: description ? description : "", + mult_answer: answerTimes, id: id ? id : "", error: { errorMsg: { diff --git a/src/components/fieldsDisplayForm/utils/FrontEndTranslation.js b/src/components/fieldsDisplayForm/utils/FrontEndTranslation.js index d0f158e..66b6fa7 100644 --- a/src/components/fieldsDisplayForm/utils/FrontEndTranslation.js +++ b/src/components/fieldsDisplayForm/utils/FrontEndTranslation.js @@ -30,7 +30,13 @@ function validationTranslate(validation) { */ export function createFrontendForm(formData) { let json = []; - pushTitle(json, formData.title, formData.description, formData.id); + pushTitle( + json, + formData.title, + formData.description, + formData.id, + formData.answerTimes + ); formData.inputs.forEach((option) => { switch (option.type) { diff --git a/src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js b/src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js deleted file mode 100644 index f6446f0..0000000 --- a/src/components/fieldsGetForm/JornalFolder/FieldFooterOptions.js +++ /dev/null @@ -1,40 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; - -function FieldFooterOptions(props) { - - return ( - <> - <FormControlLabel - control={ - <Switch - onChange={e => props.setRequiredField(props.idq) } - value="required" - color="primary" - checked={props.required} - /> - } - label="Obrigatória" - /> - <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> - <DeleteOutlinedIcon /> - </IconButton> - </> - ); - - -} - - -export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js b/src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js index 119e9a9..5430e4d 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldCheckbox.js @@ -5,23 +5,21 @@ import Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; import Checkbox from "@material-ui/core/Checkbox"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), marginBottom: "2%", ["@media (max-width: 896px)"]: { - width: "300px" - } + width: "300px", + }, }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" - } + color: "black", + }, })); function FormFieldCheckbox(props) { diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js b/src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js index 441eb79..5a58cbe 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldRadio.js @@ -6,23 +6,21 @@ import Typography from "@material-ui/core/Typography"; import Radio from "@material-ui/core/Radio"; import RadioGroup from "@material-ui/core/RadioGroup"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), marginBottom: "2%", ["@media (max-width: 896px)"]: { - width: "300px" - } + width: "300px", + }, }, questionsGrid: { - marginBottom: "20px" + marginBottom: "20px", }, text: { - color: "black" - } + color: "black", + }, })); function FormFieldRadio(props) { @@ -43,7 +41,7 @@ function FormFieldRadio(props) { } /** HTML object to be displayed on component return. */ - const options = props.options.map(function(x, index) { + const options = props.options.map(function (x, index) { return ( <span> <Typography className={classes.text} variant="h7"> diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js index db34cfe..55ff6fc 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldSelect.js @@ -6,8 +6,6 @@ import Select from "@material-ui/core/Select"; import MenuItem from "@material-ui/core/MenuItem"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), diff --git a/src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js b/src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js index d334754..7c270de 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js +++ b/src/components/fieldsGetForm/JornalFolder/FormFieldTitle.js @@ -4,43 +4,41 @@ import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), height: theme.spacing(22), margin: theme.spacing(2), - color: "#000000" + color: "#000000", }, questionsGrid: { marginBottom: "20px", color: "#000000", ["@media (max-width:827px)"]: { - width: theme.spacing(70) - } + width: theme.spacing(70), + }, }, title: { fontSize: "45px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "35px" + fontSize: "35px", }, ["@media (max-width:590px)"]: { - fontSize: "25px" - } + fontSize: "25px", + }, }, description: { fontSize: "30px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "25px" + fontSize: "25px", }, ["@media (max-width:590px)"]: { - fontSize: "15px" - } - } + fontSize: "15px", + }, + }, })); function FormFieldText(props) { diff --git a/src/components/fieldsGetForm/JornalFolder/FormJornal.js b/src/components/fieldsGetForm/JornalFolder/FormJornal.js index 102d5d2..7a5db6a 100644 --- a/src/components/fieldsGetForm/JornalFolder/FormJornal.js +++ b/src/components/fieldsGetForm/JornalFolder/FormJornal.js @@ -47,11 +47,8 @@ const useStyles = makeStyles(theme => ({ marginTop: "10px" }, - date: { - marginLeft: "30%", - ["@media (max-width: 494px)"]: { - marginLeft: "3%" - } + msg: { + textAlign: "center" } })); @@ -110,7 +107,16 @@ function Jornal(props) { justify="center" > <div> - <Grid container item className={classes.date}> + {props.multAnswer ? ( + <Grid className={classes.msg}> + <Typography style={{ wordWrap: "break-word" }} gutterBottom> + Esse formulário permite multiplas respostas de um mesmo usuário + </Typography> + </Grid> + ) : ( + <Grid /> + )} + <Grid className={classes.msg}> <Typography> Data da resposta: {manageDate(props.timestamp[selectedForm])} </Typography> diff --git a/src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js b/src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js deleted file mode 100644 index ebc8504..0000000 --- a/src/components/fieldsGetForm/SummaryFolder/FieldFooterOptions.js +++ /dev/null @@ -1,33 +0,0 @@ -import React from "react"; -import DeleteOutlinedIcon from "@material-ui/icons/DeleteOutlined"; -import IconButton from "@material-ui/core/IconButton"; -import Switch from "@material-ui/core/Switch"; -import FormControlLabel from "@material-ui/core/FormControlLabel"; - -function FieldFooterOptions(props) { - return ( - <> - <FormControlLabel - control={ - <Switch - onChange={e => props.setRequiredField(props.idq)} - value="required" - color="primary" - checked={props.required} - /> - } - label="Obrigatória" - /> - <IconButton - aria-label="delete" - onClick={() => { - props.deleteFromForm(props.idq); - }} - > - <DeleteOutlinedIcon /> - </IconButton> - </> - ); -} - -export default FieldFooterOptions; diff --git a/src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js b/src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js index cf2c22e..43fc977 100644 --- a/src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js +++ b/src/components/fieldsGetForm/SummaryFolder/FormFieldTitle.js @@ -4,9 +4,7 @@ import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), width: theme.spacing(100), @@ -14,39 +12,39 @@ const useStyles = makeStyles(theme => ({ margin: theme.spacing(2), color: "#000000", ["@media (max-width:827px)"]: { - width: theme.spacing(70) + width: theme.spacing(70), }, ["@media (max-width:590px)"]: { - width: theme.spacing(40) - } + width: theme.spacing(40), + }, }, questionsGrid: { marginBottom: "20px", color: "#000000", ["@media (max-width:827px)"]: { - width: theme.spacing(70) - } + width: theme.spacing(70), + }, }, title: { fontSize: "45px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "35px" + fontSize: "35px", }, ["@media (max-width:590px)"]: { - fontSize: "25px" - } + fontSize: "25px", + }, }, description: { fontSize: "30px", color: "#000000", ["@media (max-width:827px)"]: { - fontSize: "25px" + fontSize: "25px", }, ["@media (max-width:590px)"]: { - fontSize: "15px" - } - } + fontSize: "15px", + }, + }, })); function FormFieldText(props) { diff --git a/src/components/fieldsGetForm/SummaryFolder/FormSummary.js b/src/components/fieldsGetForm/SummaryFolder/FormSummary.js index 0904563..54144a9 100644 --- a/src/components/fieldsGetForm/SummaryFolder/FormSummary.js +++ b/src/components/fieldsGetForm/SummaryFolder/FormSummary.js @@ -1,6 +1,7 @@ import React from "react"; import { makeStyles } from "@material-ui/core/styles"; import Grid from "@material-ui/core/Grid"; +import Typography from "@material-ui/core/Typography"; import FormFieldText from "./FormFieldText"; import FormFieldSelect from "./FormFieldSelect"; @@ -42,6 +43,10 @@ const useStyles = makeStyles(theme => ({ }, formTitle: { marginTop: "10px" + }, + + msg: { + textAlign: "center" } })); function Summary(props) { @@ -96,6 +101,15 @@ function Summary(props) { justify="center" > <div> + {props.multAnswer ? ( + <Grid className={classes.msg}> + <Typography style={{ wordWrap: "break-word" }} gutterBottom> + Esse formulário permite multiplas respostas de um mesmo usuário + </Typography> + </Grid> + ) : ( + <Grid /> + )} {props.formArray[0].form.inputs.map((input, index) => { if (input.type === 0) return ( diff --git a/src/components/fieldsVisualizeForm/FieldFooterOptions.js b/src/components/fieldsVisualizeForm/FieldFooterOptions.js deleted file mode 100644 index f6446f0..0000000 --- a/src/components/fieldsVisualizeForm/FieldFooterOptions.js +++ /dev/null @@ -1,40 +0,0 @@ -import React from 'react'; -import { makeStyles } from '@material-ui/core/styles'; -import Grid from '@material-ui/core/Grid'; -import Paper from '@material-ui/core/Paper'; -import TextField from '@material-ui/core/TextField'; -import DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined'; -import IconButton from '@material-ui/core/IconButton'; -import Select from '@material-ui/core/Select'; -import MenuItem from '@material-ui/core/MenuItem'; -import AddCircleIcon from '@material-ui/icons/AddCircle'; -import CloseIcon from '@material-ui/icons/Close'; -import Switch from '@material-ui/core/Switch'; -import FormControlLabel from '@material-ui/core/FormControlLabel'; - -function FieldFooterOptions(props) { - - return ( - <> - <FormControlLabel - control={ - <Switch - onChange={e => props.setRequiredField(props.idq) } - value="required" - color="primary" - checked={props.required} - /> - } - label="Obrigatória" - /> - <IconButton aria-label="delete" onClick={() => { props.deleteFromForm(props.idq) } }> - <DeleteOutlinedIcon /> - </IconButton> - </> - ); - - -} - - -export default FieldFooterOptions; \ No newline at end of file diff --git a/src/components/fieldsVisualizeForm/FormFieldCheckbox.js b/src/components/fieldsVisualizeForm/FormFieldCheckbox.js index 3f23367..8bc1def 100644 --- a/src/components/fieldsVisualizeForm/FormFieldCheckbox.js +++ b/src/components/fieldsVisualizeForm/FormFieldCheckbox.js @@ -5,8 +5,6 @@ import Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; import Checkbox from "@material-ui/core/Checkbox"; -import FieldFooterOptions from "./FieldFooterOptions"; - const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), diff --git a/src/components/fieldsVisualizeForm/FormFieldRadio.js b/src/components/fieldsVisualizeForm/FormFieldRadio.js index 24d8e1b..727f7fc 100644 --- a/src/components/fieldsVisualizeForm/FormFieldRadio.js +++ b/src/components/fieldsVisualizeForm/FormFieldRadio.js @@ -6,8 +6,6 @@ import Typography from "@material-ui/core/Typography"; import Radio from "@material-ui/core/Radio"; import RadioGroup from "@material-ui/core/RadioGroup"; -import FieldFooterOptions from "./FieldFooterOptions"; - const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), diff --git a/src/components/fieldsVisualizeForm/FormFieldSelect.js b/src/components/fieldsVisualizeForm/FormFieldSelect.js index 991dd25..4501ede 100644 --- a/src/components/fieldsVisualizeForm/FormFieldSelect.js +++ b/src/components/fieldsVisualizeForm/FormFieldSelect.js @@ -6,8 +6,6 @@ import Select from "@material-ui/core/Select"; import MenuItem from "@material-ui/core/MenuItem"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), diff --git a/src/components/fieldsVisualizeForm/FormFieldTitle.js b/src/components/fieldsVisualizeForm/FormFieldTitle.js index 97bfb3a..722462e 100644 --- a/src/components/fieldsVisualizeForm/FormFieldTitle.js +++ b/src/components/fieldsVisualizeForm/FormFieldTitle.js @@ -4,8 +4,6 @@ import Grid from "@material-ui/core/Grid"; import Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; -import FieldFooterOptions from "./FieldFooterOptions"; - const useStyles = makeStyles((theme) => ({ paper: { padding: theme.spacing(3), diff --git a/src/contexts/FormContext.js b/src/contexts/FormContext.js index e49b2a1..2ceccfd 100644 --- a/src/contexts/FormContext.js +++ b/src/contexts/FormContext.js @@ -5,7 +5,7 @@ import { createFrontendForm } from "../components/fieldsDisplayForm/utils/FrontE import { useHistory } from "react-router-dom"; export const FormEditionContext = createContext(); -const FormProvider = props => { +const FormProvider = (props) => { const history = useHistory(); /** Getting the id from the route information */ const { id } = useParams(); @@ -19,13 +19,14 @@ const FormProvider = props => { type: "title", question: "", description: "", + mult_answer: false, error: { errorMsg: { question: "Este campo é obrigatório!", - description: "" - } - } - } + description: "", + }, + }, + }, ] ); @@ -34,10 +35,10 @@ const FormProvider = props => { const fetchData = async () => { api .get(`/form/${id}`) - .then(async function(res) { + .then(async function (res) { setForm(await createFrontendForm(res.data)); }) - .catch(error => { + .catch((error) => { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); diff --git a/src/contexts/useForm.js b/src/contexts/useForm.js index f9ad274..32675eb 100644 --- a/src/contexts/useForm.js +++ b/src/contexts/useForm.js @@ -8,7 +8,7 @@ import { selectOptionsTesting, testSubformSchema, selectOptionTextTesting, - testTextValidation + testTextValidation, } from "../components/fieldsDisplayForm/utils/schemas"; import { pushTitle, @@ -16,7 +16,7 @@ import { pushSelect, pushRadio, pushCheckbox, - pushSubform + pushSubform, } from "../components/fieldsDisplayForm/utils/FormComposition"; import api from "../api"; @@ -30,15 +30,6 @@ const useForm = () => { const routeId = idValue; - /** Function that adds the title object into the form array. - * Its parameters are used on the translation of the backend data. - * @param title - the title; - * @param description - the description of the form; - * @param id - optional parameter, it is used when editing a form. - */ - function addToFormTitle(title, description, id) { - setForm(pushTitle(form, title, description, id)); - } /** Function that adds a 'question' object into the form array. * Its parameters are used on the translation of the backend data. * @param question - the question; @@ -206,6 +197,13 @@ const useForm = () => { form[index].error.errorMsg.validationValue = ""; setForm([...form]); } + /** Function used on FormFieldTitle to use the multiple answer property + */ + function setMultipleAnswer() { + + form[0].mult_answer = !form[0].mult_answer; + setForm([...form]); + } /** Reordering the form array based on the place the question is being dragged over. * @param result - an composed object bringing info about the drag event. */ @@ -237,7 +235,7 @@ const useForm = () => { */ async function setId() { const fetchData = async () => { - await api.get(`/form/${routeId}`).then(async function(res) { + await api.get(`/form/${routeId}`).then(async function (res) { let backForm = createFrontendForm(res.data); for (let i = 1; i < backForm.length; i++) { for (let j = 1; j < form.length; j++) { @@ -247,14 +245,14 @@ const useForm = () => { "question", "description", "options", - "subformId" + "subformId", ]) !== - JSON.stringify(form[j], [ - "question", - "description", - "options", - "subformId" - ]) || + JSON.stringify(form[j], [ + "question", + "description", + "options", + "subformId", + ]) || differentValidation(backForm[i], form[j]) ) { form[j].inputId = null; @@ -272,23 +270,26 @@ const useForm = () => { */ async function submit(validToSend) { if (!validToSend) return; + if (form[0].mult_answer) { + document.cookie = `answerForm=${form[0].id}; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`; + } if (form[0].id) { await setId(); let data = await createBackendForm(form, routeId); const post_response = await api .put(`/form/${routeId}`, data, { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}` - } + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, }) - .then(function(error) { + .then(function (error) { if (!error.response) { alert("Seu formulário foi atualizado com sucesso."); let path = `/signin`; history.push(path); } }) - .catch(function(error) { + .catch(function (error) { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); @@ -308,17 +309,17 @@ const useForm = () => { const post_response = await api .post(`/form`, await createBackendForm(form), { headers: { - authorization: `bearer ${window.sessionStorage.getItem("token")}` - } + authorization: `bearer ${window.sessionStorage.getItem("token")}`, + }, }) - .then(function(error) { + .then(function (error) { if (!error.response) { alert("Seu formulário foi criado com sucesso."); let path = `/signin`; history.push(path); } }) - .catch(function(error) { + .catch(function (error) { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); @@ -332,7 +333,6 @@ const useForm = () => { } return { - addToFormTitle, addToFormQuestion, addToFormSelect, addToFormRadio, @@ -350,8 +350,9 @@ const useForm = () => { setValidationType, setValidationValue, removeValidation, + setMultipleAnswer, onDragEnd, - submit + submit, }; }; diff --git a/src/pages/Acknowledgement.js b/src/pages/Acknowledgement.js new file mode 100644 index 0000000..684238d --- /dev/null +++ b/src/pages/Acknowledgement.js @@ -0,0 +1,79 @@ +import React, { useEffect } from "react"; +import Grid from "@material-ui/core/Grid"; +import { Redirect, useParams } from "react-router-dom"; +import { Button, createMuiTheme, MuiThemeProvider } from "@material-ui/core"; +import IconButton from "@material-ui/core/IconButton"; +import { useHistory } from "react-router-dom"; +import { makeStyles } from "@material-ui/core/styles"; +import KeyboardArrowRightIcon from "@material-ui/icons/KeyboardArrowRight"; +import FormInput from "../components/fieldsSignUp/FormInput"; +import Paper from "@material-ui/core/Paper"; +import api from "../api"; + +const useStyles = makeStyles((theme) => ({ + register: { + maxWidth: "1000px", + background: "#ffffff", + borderRadius: "2px", + padding: "2% 1%", + marginTop: "3%", + ["@media (max-width:590px)"]: { + marginTop: "20%", + }, + margin: "0 auto", + width: "95%", + }, + custom_strong: { + fontSize: "25px", + ["@media (max-width:590px)"]: { + fontSize: "17px", + }, + textAlign: "center", + display: "block", + color: "#46525d", + marginBottom: "4%", + marginTop: "3%", + }, + button: { + type: "submit", + // width: "30%", + marginTop: "4%", + background: "#0480ab", + color: "white", + borderRadius: "2px", + padding: "10px 20px", + // fontSize: "18px", + "&:hover": { + backgroundColor: "#045d7b", + }, + ["@media (max-width:550px)"]: { + width: "55%", + fontSize: "60%", + }, + }, +})); +export default function SignUp() { + const history = useHistory(); + const classes = useStyles(); + const { again } = useParams(); + console.log(again); + again > 0 ? console.log("É ZERO") : console.log("Não dá"); + + const handleClick = () => { + let path = `/answer/${again}`; + history.push(path); + }; + return ( + <Paper className={classes.register} justify="center"> + <strong className={classes.custom_strong}> + Sua resposta foi registrada em nossa base de dados. <br></br> + Agradecemos pela sua participação.<br></br> + {again > 0 ? ( + <Button className={classes.button} onClick={() => handleClick()}> + Responda novamente o formulário + </Button> + ) : null} + </strong> + </Paper> + ); +} diff --git a/src/pages/AnswerForm.js b/src/pages/AnswerForm.js index 0887a12..494a09b 100644 --- a/src/pages/AnswerForm.js +++ b/src/pages/AnswerForm.js @@ -14,17 +14,17 @@ import FormFieldCheckbox from "../components/fieldsAnswerForm/FormFieldCheckbox" import FormFieldTitle from "../components/fieldsAnswerForm/FormFieldTitle"; import FormFieldSubform from "../components/fieldsAnswerForm/FormFieldSubform"; -const useStyles = makeStyles(theme => ({ +const useStyles = makeStyles((theme) => ({ menu: { width: theme.spacing(6), minheight: theme.spacing(15), position: "fixed", top: theme.spacing(10), left: "90%", - padding: theme.spacing(1) + padding: theme.spacing(1), }, progress: { - marginTop: "5%" + marginTop: "5%", }, button: { type: "submit", @@ -35,17 +35,17 @@ const useStyles = makeStyles(theme => ({ padding: "10px 20px", fontSize: "18px", "&:hover": { - backgroundColor: "rgb(25, 109, 23)" - } + backgroundColor: "rgb(25, 109, 23)", + }, }, pageBody: { minHeight: "calc(100vh - 92.4px - 78px)", paddingBottom: "78px", - flexDirection: "column" + flexDirection: "column", }, questions: { - marginBottom: "7%" - } + marginBottom: "7%", + }, })); function AnwserForm() { @@ -72,7 +72,7 @@ function AnwserForm() { /** Function to check if answers are valid */ function isError() { - return answerArray.some(value => { + return answerArray.some((value) => { return value.error; }); } @@ -82,7 +82,7 @@ function AnwserForm() { * It wouldn't make sense to have a form answered without any answers on it. */ function isAnswer() { - return answerArray.some(value => { + return answerArray.some((value) => { return value.answerInput.length !== 0; }); } @@ -152,11 +152,15 @@ function AnwserForm() { if (backendTranslation()) { const res = await api .post(`/answer/${id}`, backendTranslation()) - .then(function(res) { - setCookie("answerForm", id, 92); + .then(function (res) { + if (!formData.answerTimes) { + setCookie("answerForm", id, 92); + } alert("Formulário respondido!"); + let path = formData.answerTimes ? `/post/${id}` : `/post/0`; + history.push(path); }) - .catch(error => { + .catch((error) => { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); @@ -175,9 +179,9 @@ function AnwserForm() { * @param form - Form object that just came from the API. */ function mapInputs(form) { - form.inputs.map(input => { + form.inputs.map((input) => { if ( - input.validation.some(value => { + input.validation.some((value) => { return value.type === 2 || value.type === 6; }) ) { @@ -185,14 +189,14 @@ function AnwserForm() { idInput: input.id, typeInput: input.type, answerInput: [], - error: true + error: true, }); } else { answerArray.push({ idInput: input.id, typeInput: input.type, answerInput: [], - error: false + error: false, }); } }); @@ -205,12 +209,12 @@ function AnwserForm() { async function getForm(id) { const res = await api .get(`/form/${id}`) - .then(function(res) { + .then(function (res) { checkCookie(id); setFormData(res.data); mapInputs(res.data); }) - .catch(error => { + .catch((error) => { if (error.response.status === 401) { window.sessionStorage.removeItem("token"); window.sessionStorage.removeItem("userId"); @@ -265,7 +269,7 @@ function AnwserForm() { return "show warning"; } }, []); - + console.log(formData); return ( <Grid className={classes.pageBody} @@ -338,10 +342,10 @@ function AnwserForm() { })} </div> ) : ( - <Grid container justify="center" className={classes.progress}> - <CircularProgress /> - </Grid> - )} + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> + )} </Grid> <Grid> <Button diff --git a/src/pages/GetForm.js b/src/pages/GetForm.js index 0449266..247d633 100644 --- a/src/pages/GetForm.js +++ b/src/pages/GetForm.js @@ -99,6 +99,7 @@ function GetForm() { const [selectedValue, setSelectedValue] = useState(""); const [times, setTimes] = useState([]); const [toLogin, setToLogin] = useState(false); + const [multAnswer, setMultAnswer] = useState(); const GoBack = () => { if (window.confirm("Tem certeza que deseja sair?")) { @@ -124,13 +125,14 @@ function GetForm() { authorization: `bearer ${window.sessionStorage.getItem("token")}` } }) - .then(function(res) { + .then(function (res) { if (!res.data.length) { alert("Não há respostas!"); setToLogin(true); return; } setFormArray(res.data); + setMultAnswer(res.data[0].form.answerTimes) res.data.map(value => { answers.push(value.inputAnswers); times.push(value.timestamp); @@ -163,7 +165,7 @@ function GetForm() { async function getAnswerNumber(id) { const res = await api .get(`/answerNumber/${id}`) - .then(function(res) { + .then(function (res) { setAnswerNum(res.data.answerNumber); }) .catch(error => { @@ -217,14 +219,15 @@ function GetForm() { </Grid> <Grid container item> {selectedValue ? ( - <Summary formArray={formArray} answers={answers} /> + <Summary multAnswer={multAnswer} formArray={formArray} answers={answers} /> ) : ( - <Jornal - formArray={formArray} - timestamp={times} - answerNumber={answerNum} - /> - )} + <Jornal + multAnswer={multAnswer} + formArray={formArray} + timestamp={times} + answerNumber={answerNum} + /> + )} </Grid> <Grid container justify="center"> <Button variant="contained" className={classes.button} onClick={GoBack}> @@ -233,10 +236,10 @@ function GetForm() { </Grid> </Grid> ) : ( - <Grid container justify="center" className={classes.progress}> - <CircularProgress /> - </Grid> - ); + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> + ); } export default GetForm; diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index f72a1f8..dc08ca8 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -45,7 +45,7 @@ export default function ListForms() { function sort(type) { setAuxForms([]); if (type === "") { - const tmp = [...forms].sort(function(a, b) { + const tmp = [...forms].sort(function (a, b) { return a.id > b.id ? 1 : -1; }); setAuxForms(tmp); @@ -55,12 +55,12 @@ export default function ListForms() { }); setAuxForms(tmp); } else if (type === 2) { - const tmp = [...forms].sort(function(a, b) { + const tmp = [...forms].sort(function (a, b) { return a.id < b.id ? 1 : -1; }); setAuxForms(tmp); } else if (type === 3) { - const tmp = [...forms].sort(function(a, b) { + const tmp = [...forms].sort(function (a, b) { return a.answersNumber < b.answersNumber ? 1 : -1; }); setAuxForms(tmp); @@ -98,7 +98,7 @@ export default function ListForms() { async function fetchData(id) { const res = await api .get(`/user/list/${id}`) - .then(function(res) { + .then(function (res) { setForms(res.data.sort((a, b) => a.id > b.id)); setAuxForms(res.data.sort((a, b) => a.id > b.id)); setisLoaded(true); @@ -138,19 +138,19 @@ export default function ListForms() { </Grid> )) ) : ( - <Grid item> - <Typography variant="h4"> - Nenhum formulário foi encontrado! + <Grid item> + <Typography variant="h4"> + Nenhum formulário foi encontrado! </Typography> - </Grid> - )} + </Grid> + )} </Grid> </Container> </div> </> ) : ( - <Grid container justify="center" className={classes.progress}> - <CircularProgress /> - </Grid> - ); + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> + ); } diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index ae6891b..a3d5964 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -111,8 +111,8 @@ export default function SignUp() { function checkPasswordString() { return values.password ? /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&+_ ():;/?\|"'-])[A-Za-z\d@$!%*?&+_ ():;/?\|"'-]{8,24}$/.test( - values.password - ) + values.password + ) : true; } @@ -202,77 +202,77 @@ export default function SignUp() { return isLoged ? ( <Redirect to="/signin" /> ) : ( - <MuiThemeProvider theme={theme}> - <Paper className={classes.register} justify="center"> - <strong className={classes.custom_strong}> - Cadastro de Usuário + <MuiThemeProvider theme={theme}> + <Paper className={classes.register} justify="center"> + <strong className={classes.custom_strong}> + Cadastro de Usuário <p className={classes.strong_description}> - Insira as informações abaixo + Insira as informações abaixo </p> - </strong> - <form className={classes.form} autocomplete="off"> - <Grid> - <FormInput - label="Nome Completo" - param="name" - onUpdate={handleChange} - error={!checkName()} - /> - </Grid> - <Grid> - <FormInput - label="E-mail" - param="email" - onUpdate={handleChange} - error={!checkEmail()} - /> - </Grid> - <Grid> - <FormInput - label="Senha" - param="password" - onUpdate={handleChange} - error={!checkPasswordString()} - /> - {(!checkPasswordString() || !values.password) && ( - <Grid className={classes.errorGridOpts}> - Sua senha deve conter entre 8 e 24 caracteres, uma letra - maiúscula, uma minúscula e um número + </strong> + <form className={classes.form} autocomplete="off"> + <Grid> + <FormInput + label="Nome Completo" + param="name" + onUpdate={handleChange} + error={!checkName()} + /> + </Grid> + <Grid> + <FormInput + label="E-mail" + param="email" + onUpdate={handleChange} + error={!checkEmail()} + /> + </Grid> + <Grid> + <FormInput + label="Senha" + param="password" + onUpdate={handleChange} + error={!checkPasswordString()} + /> + {(!checkPasswordString() || !values.password) && ( + <Grid className={classes.errorGridOpts}> + Sua senha deve conter entre 8 e 24 caracteres, uma letra + maiúscula, uma minúscula e um número </Grid> - )} - </Grid> - <Grid> - <FormInput - label="Confirmar Senha" - param="password_confirm" - onUpdate={handleChange} - error={ - values.password_confirm - ? values.password === values.password_confirm - ? false - : true - : false - } - /> - </Grid> - <Grid className={classes.alreadyAcc}> - <a href="https://genforms.c3sl.ufpr.br/#/signin"> - Já é cadastrado? + )} + </Grid> + <Grid> + <FormInput + label="Confirmar Senha" + param="password_confirm" + onUpdate={handleChange} + error={ + values.password_confirm + ? values.password === values.password_confirm + ? false + : true + : false + } + /> + </Grid> + <Grid className={classes.alreadyAcc}> + <a href="https://genforms.c3sl.ufpr.br/#/signin"> + Já é cadastrado? </a> - </Grid> - <Grid> - <IconButton - size="medium" - className={classes.button} - id="whiteTextedButton" - onClick={() => submit()} - > - <KeyboardArrowRightIcon /> - Cadastre-se + </Grid> + <Grid> + <IconButton + size="medium" + className={classes.button} + id="whiteTextedButton" + onClick={() => submit()} + > + <KeyboardArrowRightIcon /> + Cadastre-se </IconButton> - </Grid> - </form> - </Paper> - </MuiThemeProvider> - ); + </Grid> + </form> + </Paper> + </MuiThemeProvider> + ); } diff --git a/src/pages/VisualizeForm.js b/src/pages/VisualizeForm.js index e4ff0a4..b77e491 100644 --- a/src/pages/VisualizeForm.js +++ b/src/pages/VisualizeForm.js @@ -6,6 +6,7 @@ import api from "../api"; import { createMuiTheme, MuiThemeProvider, Button } from "@material-ui/core"; import { useHistory } from "react-router-dom"; import CircularProgress from "@material-ui/core/CircularProgress"; +import Typography from "@material-ui/core/Typography"; import FormFieldText from "../components/fieldsVisualizeForm/FormFieldText"; import FormFieldSelect from "../components/fieldsVisualizeForm/FormFieldSelect"; @@ -36,6 +37,9 @@ const useStyles = makeStyles(theme => ({ marginLeft: "3%", width: "92%" } + }, + msg: { + textAlign: "center" } })); @@ -68,6 +72,7 @@ function VisualizeForm() { /** Maped form from backend */ const [formData, setFormData] = useState(0); + const [multAnswer, setMultAnswer] = useState(); /** * Function to get form object from the API. @@ -76,7 +81,9 @@ function VisualizeForm() { async function getForm(id) { const res = await api .get(`/form/${id}`) - .then(function(res) { + .then(function (res) { + console.log(res.data) + setMultAnswer(res.data.answerTimes) setFormData(res.data); }) .catch(error => { @@ -122,6 +129,15 @@ function VisualizeForm() { justify="center" className={classes.sizeFormating} > + {multAnswer ? ( + <Grid className={classes.msg}> + <Typography style={{ wordWrap: "break-word" }} gutterBottom> + Esse formulário permite multiplas respostas de um mesmo usuário + </Typography> + </Grid> + ) : ( + <Grid /> + )} {formData ? ( <> <FormFieldTitle @@ -185,10 +201,10 @@ function VisualizeForm() { </Grid> </> ) : ( - <Grid container justify="center" className={classes.progress}> - <CircularProgress /> - </Grid> - )} + <Grid container justify="center" className={classes.progress}> + <CircularProgress /> + </Grid> + )} </Grid> </div> </MuiThemeProvider> diff --git a/src/routes.js b/src/routes.js index 8a23828..5e8ac2b 100644 --- a/src/routes.js +++ b/src/routes.js @@ -9,6 +9,7 @@ import ListForms from "./pages/ListForms"; import EditForm from "./pages/EditForm"; import GetForm from "./pages/GetForm"; import VisualizeForm from "./pages/VisualizeForm"; +import Acknowledgement from "./pages/Acknowledgement"; import { BrowserRouter, Route, Switch, Redirect } from "react-router-dom"; const PrivateRoute = ({ component: Component, ...rest }) => { @@ -45,10 +46,11 @@ const Routes = () => ( component={() => <VisualizeForm />} /> <PrivateRoute exact path="/create" component={() => <CreateForm />} /> - <PrivateRoute exact path="/answer/:id" component={() => <AnswerForm />} /> + <Route exact path="/answer/:id" component={() => <AnswerForm />} /> <PrivateRoute exact path="/edit/:id" component={() => <EditForm />} /> <PrivateRoute exact path="/list/:id" component={() => <ListForms />} /> <PrivateRoute exact path="/form/:id" component={() => <GetForm />} /> + <Route exact path="/post/:again" component={() => <Acknowledgement />} /> </Switch> <Footer /> </BrowserRouter> -- GitLab From db5ba57c5a31b99483a03ba91a07590e23a18b14 Mon Sep 17 00:00:00 2001 From: Gabriel Silva Hermida <gash18@inf.ufpr.br> Date: Tue, 17 Nov 2020 12:43:20 -0300 Subject: [PATCH 70/72] Issue #53: Fix password info Signed-off-by: Gabriel Silva Hermida <gash18@inf.ufpr.br> --- src/pages/SignUp.js | 146 +++++++++++++++++++++++--------------------- 1 file changed, 75 insertions(+), 71 deletions(-) diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index a3d5964..ab39dee 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -110,9 +110,9 @@ export default function SignUp() { function checkPasswordString() { return values.password - ? /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&+_ ():;/?\|"'-])[A-Za-z\d@$!%*?&+_ ():;/?\|"'-]{8,24}$/.test( - values.password - ) + ? /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&+_ ():;/?\|"'-])[A-Za-z\d@$!%*?&+_ ():;/\|"'-]{8,24}$/.test( + values.password + ) : true; } @@ -182,6 +182,7 @@ export default function SignUp() { handleSubmit(); } } + const theme = createMuiTheme({ overrides: { root: { @@ -199,80 +200,83 @@ export default function SignUp() { }, }, }); + let msg = + "Sua senha deve conter entre 8 e 24 caracteres, uma letra maiúscula, uma minúscula, um número e um caractere dentre @$!%*?&+_ ():;/|\"'-"; return isLoged ? ( <Redirect to="/signin" /> ) : ( - <MuiThemeProvider theme={theme}> - <Paper className={classes.register} justify="center"> - <strong className={classes.custom_strong}> - Cadastro de Usuário + <MuiThemeProvider theme={theme}> + <Paper className={classes.register} justify="center"> + <strong className={classes.custom_strong}> + Cadastro de Usuário <p className={classes.strong_description}> - Insira as informações abaixo + Insira as informações abaixo </p> - </strong> - <form className={classes.form} autocomplete="off"> - <Grid> - <FormInput - label="Nome Completo" - param="name" - onUpdate={handleChange} - error={!checkName()} - /> - </Grid> - <Grid> - <FormInput - label="E-mail" - param="email" - onUpdate={handleChange} - error={!checkEmail()} - /> - </Grid> - <Grid> - <FormInput - label="Senha" - param="password" - onUpdate={handleChange} - error={!checkPasswordString()} - /> - {(!checkPasswordString() || !values.password) && ( - <Grid className={classes.errorGridOpts}> - Sua senha deve conter entre 8 e 24 caracteres, uma letra - maiúscula, uma minúscula e um número + </strong> + <form className={classes.form} autocomplete="off"> + <Grid> + <FormInput + label="Nome Completo" + param="name" + onUpdate={handleChange} + error={!checkName()} + /> + </Grid> + <Grid> + <FormInput + label="E-mail" + param="email" + onUpdate={handleChange} + error={!checkEmail()} + /> + </Grid> + <Grid> + <FormInput + label="Senha" + param="password" + onUpdate={handleChange} + error={!checkPasswordString()} + /> + {(!checkPasswordString() || !values.password) && ( + <Grid className={classes.errorGridOpts}> + Sua senha deve conter entre 8 e 24 caracteres, uma letra + maiúscula, uma minúscula, um número e um caractere dentre + @$!%*?+_ ():;/?\|"'- </Grid> - )} - </Grid> - <Grid> - <FormInput - label="Confirmar Senha" - param="password_confirm" - onUpdate={handleChange} - error={ - values.password_confirm - ? values.password === values.password_confirm - ? false - : true - : false - } - /> - </Grid> - <Grid className={classes.alreadyAcc}> - <a href="https://genforms.c3sl.ufpr.br/#/signin"> - Já é cadastrado? + )} + </Grid> + <Grid> + <FormInput + label="Confirmar Senha" + param="password_confirm" + onUpdate={handleChange} + error={ + values.password_confirm + ? values.password === values.password_confirm + ? false + : true + : false + } + /> + </Grid> + <Grid className={classes.alreadyAcc}> + <a href="https://genforms.c3sl.ufpr.br/#/signin"> + Já é cadastrado? </a> - </Grid> - <Grid> - <IconButton - size="medium" - className={classes.button} - id="whiteTextedButton" - onClick={() => submit()} - > - <KeyboardArrowRightIcon /> - Cadastre-se + </Grid> + <Grid> + <IconButton + size="medium" + className={classes.button} + id="whiteTextedButton" + onClick={() => submit()} + > + <KeyboardArrowRightIcon /> + Cadastre-se </IconButton> - </Grid> - </form> - </Paper> - </MuiThemeProvider> - ); + </Grid> + </form> + </Paper> + </MuiThemeProvider> + ); } -- GitLab From a1dc9550c700034c4a3119732e90438803329ca0 Mon Sep 17 00:00:00 2001 From: Richard Heise <rfhf19@inf.ufpr.br> Date: Fri, 11 Dec 2020 11:50:28 -0300 Subject: [PATCH 71/72] Issue #54: Fix changes to be like prod --- src/pages/SignIn.js | 80 ++++++++++++------------ src/pages/SignUp.js | 146 ++++++++++++++++++++++---------------------- src/routes.js | 10 +-- 3 files changed, 118 insertions(+), 118 deletions(-) diff --git a/src/pages/SignIn.js b/src/pages/SignIn.js index f7d5a76..8ec8c83 100644 --- a/src/pages/SignIn.js +++ b/src/pages/SignIn.js @@ -1,5 +1,5 @@ import React from "react"; -import { useHistory } from "react-router-dom"; +import { useHistory, Link } from "react-router-dom"; import { Redirect } from "react-router-dom"; import Grid from "@material-ui/core/Grid"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; @@ -105,7 +105,7 @@ export default function SignIn() { email: values.email, hash: values.password }) - .then(function(response) { + .then(function (response) { if (!response.data.error) { window.sessionStorage.setItem("token", response.data.token); window.sessionStorage.setItem("userId", response.data.id); @@ -113,7 +113,7 @@ export default function SignIn() { history.push(path); } }) - .catch(function(error) { + .catch(function (error) { if (error.response) { alert( "Falha de autenticação. Certifique-se que email e senha estão corretos." @@ -148,44 +148,44 @@ export default function SignIn() { return isLoged ? ( <Redirect to={`/list/${window.sessionStorage.getItem("userId")}`} /> ) : ( - <MuiThemeProvider theme={theme}> - <Paper className={classes.register} justify="center"> - <strong className={classes.custom_strong}> - Login de Usuário + <MuiThemeProvider theme={theme}> + <Paper className={classes.register} justify="center"> + <strong className={classes.custom_strong}> + Login de Usuário <p className={classes.strong_description}> - Insira as informações abaixo + Insira as informações abaixo </p> - </strong> - <form className={classes.form} autocomplete="off"> - <Grid> - <FormInput - label="E-mail" - param="email" - onUpdate={handleChange} - error={!checkEmail()} - /> - </Grid> - <Grid> - <FormInput label="Senha" param="password" onUpdate={handleChange} /> - </Grid> - <Grid className={classes.noAcc}> - <a href="https://genforms.c3sl.ufpr.br/#/signup"> - Não é cadastrado? - </a> - </Grid> - <Grid> - <IconButton - size="medium" - className={classes.button} - id="whiteTextedButton" - onClick={() => submit()} - > - <KeyboardArrowRightIcon /> - Conecte-se + </strong> + <form className={classes.form} autocomplete="off"> + <Grid> + <FormInput + label="E-mail" + param="email" + onUpdate={handleChange} + error={!checkEmail()} + /> + </Grid> + <Grid> + <FormInput label="Senha" param="password" onUpdate={handleChange} /> + </Grid> + <Grid className={classes.noAcc}> + <Link to="/signup"> + Não é cadastrado? + </Link> + </Grid> + <Grid> + <IconButton + size="medium" + className={classes.button} + id="whiteTextedButton" + onClick={() => submit()} + > + <KeyboardArrowRightIcon /> + Conecte-se </IconButton> - </Grid> - </form> - </Paper> - </MuiThemeProvider> - ); + </Grid> + </form> + </Paper> + </MuiThemeProvider> + ); } diff --git a/src/pages/SignUp.js b/src/pages/SignUp.js index ab39dee..8372c2e 100644 --- a/src/pages/SignUp.js +++ b/src/pages/SignUp.js @@ -1,6 +1,6 @@ import React, { useEffect } from "react"; import Grid from "@material-ui/core/Grid"; -import { Redirect } from "react-router-dom"; +import { Redirect, Link } from "react-router-dom"; import { createMuiTheme, MuiThemeProvider } from "@material-ui/core"; import IconButton from "@material-ui/core/IconButton"; import { useHistory } from "react-router-dom"; @@ -111,8 +111,8 @@ export default function SignUp() { function checkPasswordString() { return values.password ? /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&+_ ():;/?\|"'-])[A-Za-z\d@$!%*?&+_ ():;/\|"'-]{8,24}$/.test( - values.password - ) + values.password + ) : true; } @@ -205,78 +205,78 @@ export default function SignUp() { return isLoged ? ( <Redirect to="/signin" /> ) : ( - <MuiThemeProvider theme={theme}> - <Paper className={classes.register} justify="center"> - <strong className={classes.custom_strong}> - Cadastro de Usuário + <MuiThemeProvider theme={theme}> + <Paper className={classes.register} justify="center"> + <strong className={classes.custom_strong}> + Cadastro de Usuário <p className={classes.strong_description}> - Insira as informações abaixo + Insira as informações abaixo </p> - </strong> - <form className={classes.form} autocomplete="off"> - <Grid> - <FormInput - label="Nome Completo" - param="name" - onUpdate={handleChange} - error={!checkName()} - /> - </Grid> - <Grid> - <FormInput - label="E-mail" - param="email" - onUpdate={handleChange} - error={!checkEmail()} - /> - </Grid> - <Grid> - <FormInput - label="Senha" - param="password" - onUpdate={handleChange} - error={!checkPasswordString()} - /> - {(!checkPasswordString() || !values.password) && ( - <Grid className={classes.errorGridOpts}> - Sua senha deve conter entre 8 e 24 caracteres, uma letra - maiúscula, uma minúscula, um número e um caractere dentre - @$!%*?+_ ():;/?\|"'- + </strong> + <form className={classes.form} autocomplete="off"> + <Grid> + <FormInput + label="Nome Completo" + param="name" + onUpdate={handleChange} + error={!checkName()} + /> + </Grid> + <Grid> + <FormInput + label="E-mail" + param="email" + onUpdate={handleChange} + error={!checkEmail()} + /> + </Grid> + <Grid> + <FormInput + label="Senha" + param="password" + onUpdate={handleChange} + error={!checkPasswordString()} + /> + {(!checkPasswordString() || !values.password) && ( + <Grid className={classes.errorGridOpts}> + Sua senha deve conter entre 8 e 24 caracteres, uma letra + maiúscula, uma minúscula, um número e um caractere dentre + @$!%*?+_ ():;/?\|"'- </Grid> - )} - </Grid> - <Grid> - <FormInput - label="Confirmar Senha" - param="password_confirm" - onUpdate={handleChange} - error={ - values.password_confirm - ? values.password === values.password_confirm - ? false - : true - : false - } - /> - </Grid> - <Grid className={classes.alreadyAcc}> - <a href="https://genforms.c3sl.ufpr.br/#/signin"> - Já é cadastrado? - </a> - </Grid> - <Grid> - <IconButton - size="medium" - className={classes.button} - id="whiteTextedButton" - onClick={() => submit()} - > - <KeyboardArrowRightIcon /> - Cadastre-se + )} + </Grid> + <Grid> + <FormInput + label="Confirmar Senha" + param="password_confirm" + onUpdate={handleChange} + error={ + values.password_confirm + ? values.password === values.password_confirm + ? false + : true + : false + } + /> + </Grid> + <Grid className={classes.alreadyAcc}> + <Link to="/signin"> + Já é cadastrado? + </Link> + </Grid> + <Grid> + <IconButton + size="medium" + className={classes.button} + id="whiteTextedButton" + onClick={() => submit()} + > + <KeyboardArrowRightIcon /> + Cadastre-se </IconButton> - </Grid> - </form> - </Paper> - </MuiThemeProvider> - ); + </Grid> + </form> + </Paper> + </MuiThemeProvider> + ); } diff --git a/src/routes.js b/src/routes.js index 5e8ac2b..bfc5bc0 100644 --- a/src/routes.js +++ b/src/routes.js @@ -10,7 +10,7 @@ import EditForm from "./pages/EditForm"; import GetForm from "./pages/GetForm"; import VisualizeForm from "./pages/VisualizeForm"; import Acknowledgement from "./pages/Acknowledgement"; -import { BrowserRouter, Route, Switch, Redirect } from "react-router-dom"; +import { HashRouter, Route, Switch, Redirect } from "react-router-dom"; const PrivateRoute = ({ component: Component, ...rest }) => { let usr = true; @@ -24,15 +24,15 @@ const PrivateRoute = ({ component: Component, ...rest }) => { usr && window.sessionStorage.getItem("token") !== null ? ( <Component {...props} /> ) : ( - <Redirect to={{ pathname: "/" }} /> - ) + <Redirect to={{ pathname: "/" }} /> + ) } /> ); }; const Routes = () => ( - <BrowserRouter> + <HashRouter> <Header /> <Switch> <Route exact path="/"> @@ -53,7 +53,7 @@ const Routes = () => ( <Route exact path="/post/:again" component={() => <Acknowledgement />} /> </Switch> <Footer /> - </BrowserRouter> + </HashRouter> ); export default Routes; -- GitLab From 6ab72cb598e189dbf3b4e89551da665cd7040946 Mon Sep 17 00:00:00 2001 From: Richard Heise <rfhf19@inf.ufpr.br> Date: Thu, 17 Dec 2020 11:49:04 -0300 Subject: [PATCH 72/72] Issue #32: Changed Icon and name in browser --- public/favicon.ico | Bin 3870 -> 3516 bytes public/index.html | 42 +++++++++---------- public/logo192.png | Bin 5347 -> 0 bytes public/logo512.png | Bin 9664 -> 0 bytes public/manifest.json | 16 ++----- src/components/fieldsListForms/SearchBar.jsx | 1 + src/components/fieldsListForms/Tab.jsx | 3 +- src/components/header/header.jsx | 2 +- src/pages/ListForms.js | 2 +- 9 files changed, 29 insertions(+), 37 deletions(-) delete mode 100644 public/logo192.png delete mode 100644 public/logo512.png diff --git a/public/favicon.ico b/public/favicon.ico index a11777cc471a4344702741ab1c8a588998b1311a..a79ec18b87a2e63e2fba8023cea8b3199ccae1a5 100644 GIT binary patch literal 3516 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 M=60xRGxV+h0+j)adH?_b literal 3870 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 baj7?x%VD!5Cxk2YbYLNVeiXvvpMCWYo=by@ diff --git a/public/index.html b/public/index.html index aa069f2..536e1e1 100644 --- a/public/index.html +++ b/public/index.html @@ -1,21 +1,19 @@ <!DOCTYPE html> <html lang="en"> - <head> - <meta charset="utf-8" /> - <link rel="icon" href="%PUBLIC_URL%/favicon.ico" /> - <meta name="viewport" content="width=device-width, initial-scale=1" /> - <meta name="theme-color" content="#000000" /> - <meta - name="description" - content="Web site created using create-react-app" - /> - <link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" /> - <!-- + +<head> + <meta charset="utf-8" /> + <link rel="icon" href="%PUBLIC_URL%/favicon.ico" /> + <meta name="viewport" content="width=device-width, initial-scale=1" /> + <meta name="theme-color" content="#000000" /> + <meta name="description" content="Web site created using create-react-app" /> + <link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" /> + <!-- manifest.json provides metadata used when your web app is installed on a user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/ --> - <link rel="manifest" href="%PUBLIC_URL%/manifest.json" /> - <!-- + <link rel="manifest" href="%PUBLIC_URL%/manifest.json" /> + <!-- Notice the use of %PUBLIC_URL% in the tags above. It will be replaced with the URL of the `public` folder during the build. Only files inside the `public` folder can be referenced from the HTML. @@ -24,12 +22,13 @@ 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`. --> - <title>React App</title> - </head> - <body> - <noscript>You need to enable JavaScript to run this app.</noscript> - <div id="root"></div> - <!-- + <title>Gerador de Formulários</title> +</head> + +<body> + <noscript>You need to enable JavaScript to run this app.</noscript> + <div id="root"></div> + <!-- This HTML file is a template. If you open it directly in the browser, you will see an empty page. @@ -39,5 +38,6 @@ To begin the development, run `npm start` or `yarn start`. To create a production bundle, use `npm run build` or `yarn build`. --> - </body> -</html> +</body> + +</html> \ No newline at end of file diff --git a/public/logo192.png b/public/logo192.png deleted file mode 100644 index fc44b0a3796c0e0a64c3d858ca038bd4570465d9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5347 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 X@eDJUQo;Ye2mwlRs<JiGX2Jghdw)}T diff --git a/public/logo512.png b/public/logo512.png deleted file mode 100644 index a4e47a6545bc15971f8f63fba70e4013df88a664..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9664 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 b{|{}U^kRn2wo}j7|0ATu<;8xA7zX}7|B6mN diff --git a/public/manifest.json b/public/manifest.json index 080d6c7..b7787e4 100644 --- a/public/manifest.json +++ b/public/manifest.json @@ -1,25 +1,15 @@ { - "short_name": "React App", - "name": "Create React App Sample", + "short_name": "Gerador de formulários", + "name": "Gerador de formulários", "icons": [ { "src": "favicon.ico", "sizes": "64x64 32x32 24x24 16x16", "type": "image/x-icon" - }, - { - "src": "logo192.png", - "type": "image/png", - "sizes": "192x192" - }, - { - "src": "logo512.png", - "type": "image/png", - "sizes": "512x512" } ], "start_url": ".", "display": "standalone", "theme_color": "#000000", "background_color": "#ffffff" -} +} \ No newline at end of file diff --git a/src/components/fieldsListForms/SearchBar.jsx b/src/components/fieldsListForms/SearchBar.jsx index a3c03f0..b84e24b 100644 --- a/src/components/fieldsListForms/SearchBar.jsx +++ b/src/components/fieldsListForms/SearchBar.jsx @@ -7,6 +7,7 @@ import InputAdornment from "@material-ui/core/InputAdornment"; const useStyles = makeStyles(theme => ({ container: { + width: "254px", height: "50px", marginTop: "15px", marginBottom: "15px", diff --git a/src/components/fieldsListForms/Tab.jsx b/src/components/fieldsListForms/Tab.jsx index fdcc5dc..e4b96d6 100644 --- a/src/components/fieldsListForms/Tab.jsx +++ b/src/components/fieldsListForms/Tab.jsx @@ -55,6 +55,7 @@ const useStyles = makeStyles(theme => ({ }, gridMenu: { + width: "254px", display: "flex", alignItems: "center", marginLeft: "20px" @@ -94,7 +95,7 @@ function Tab(props) { inputProps={{ "aria-label": "Without label" }} > <MenuItem value=""> - <em>Original</em> + Original </MenuItem> <MenuItem value={1}>Alfabética</MenuItem> <MenuItem value={2}>Mais recente</MenuItem> diff --git a/src/components/header/header.jsx b/src/components/header/header.jsx index b7e6287..76c6b2a 100644 --- a/src/components/header/header.jsx +++ b/src/components/header/header.jsx @@ -118,7 +118,7 @@ export default function Header() { className={classes.link} > <h2 className={classes.form_creator}> - Gerenciador de Formulários + Gerador de Formulários </h2> </a> </Grid> diff --git a/src/pages/ListForms.js b/src/pages/ListForms.js index dc08ca8..7c5e07b 100644 --- a/src/pages/ListForms.js +++ b/src/pages/ListForms.js @@ -140,7 +140,7 @@ export default function ListForms() { ) : ( <Grid item> <Typography variant="h4"> - Nenhum formulário foi encontrado! + Nenhum formulário foi encontrado </Typography> </Grid> )} -- GitLab