diff --git a/README.md b/README.md
index 763ec537cf8f086611fc5d3a5a238ee45684a314..8af9339c27c9b854bd0e75de7e7c6b17d556d590 100755
--- a/README.md
+++ b/README.md
@@ -17,6 +17,10 @@ You will also see any lint errors in the console.
 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 analyze`
+
+Source map explorer analyzes JavaScript bundles using the source maps. This helps you understand where code bloat is coming from. (https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size)
+
 ### `npm run build`
 
 Builds the app for production to the `build` folder.<br>
diff --git a/package-lock.json b/package-lock.json
index 43a1c84dc653fe49e201e1273ea0054d40e3f1d0..5fdb31796f1799db9b5ed5b01b469464a961da40 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -4,64 +4,6 @@
   "lockfileVersion": 1,
   "requires": true,
   "dependencies": {
-    "@ant-design/colors": {
-      "version": "6.0.0",
-      "resolved": "https://registry.npmjs.org/@ant-design/colors/-/colors-6.0.0.tgz",
-      "integrity": "sha512-qAZRvPzfdWHtfameEGP2Qvuf838NhergR35o+EuVyB5XvSA98xod5r4utvi4TJ3ywmevm290g9nsCG5MryrdWQ==",
-      "requires": {
-        "@ctrl/tinycolor": "^3.4.0"
-      }
-    },
-    "@ant-design/icons": {
-      "version": "4.5.0",
-      "resolved": "https://registry.npmjs.org/@ant-design/icons/-/icons-4.5.0.tgz",
-      "integrity": "sha512-ZAKJcmr4DBV3NWr8wm2dCxNKN4eFrX+qCaPsuFejP6FRsf+m5OKxvCVi9bSp1lmKWeOI5yECAx5s0uFm4QHuPw==",
-      "requires": {
-        "@ant-design/colors": "^6.0.0",
-        "@ant-design/icons-svg": "^4.0.0",
-        "@babel/runtime": "^7.11.2",
-        "classnames": "^2.2.6",
-        "insert-css": "^2.0.0",
-        "rc-util": "^5.0.1"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "@ant-design/icons-svg": {
-      "version": "4.1.0",
-      "resolved": "https://registry.npmjs.org/@ant-design/icons-svg/-/icons-svg-4.1.0.tgz",
-      "integrity": "sha512-Fi03PfuUqRs76aI3UWYpP864lkrfPo0hluwGqh7NJdLhvH4iRDc3jbJqZIvRDLHKbXrvAfPPV3+zjUccfFvWOQ=="
-    },
-    "@ant-design/react-slick": {
-      "version": "0.28.2",
-      "resolved": "https://registry.npmjs.org/@ant-design/react-slick/-/react-slick-0.28.2.tgz",
-      "integrity": "sha512-nkrvXsO29pLToFaBb3MlJY4McaUFR4UHtXTz6A5HBzYmxH4SwKerX54mWdGc/6tKpHvS3vUwjEOt2T5XqZEo8Q==",
-      "requires": {
-        "@babel/runtime": "^7.10.4",
-        "classnames": "^2.2.5",
-        "json2mq": "^0.2.0",
-        "lodash": "^4.17.15",
-        "resize-observer-polyfill": "^1.5.0"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
     "@babel/code-frame": {
       "version": "7.10.1",
       "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.1.tgz",
@@ -1443,45 +1385,6 @@
       "resolved": "https://registry.npmjs.org/@csstools/convert-colors/-/convert-colors-1.4.0.tgz",
       "integrity": "sha512-5a6wqoJV/xEdbRNKVo6I4hO3VjyDq//8q2f9I6PBAvMesJHFauXDorcNCsr9RzvsZnaWi5NYCcfyqP1QeFHFbw=="
     },
-    "@ctrl/tinycolor": {
-      "version": "3.4.0",
-      "resolved": "https://registry.npmjs.org/@ctrl/tinycolor/-/tinycolor-3.4.0.tgz",
-      "integrity": "sha512-JZButFdZ1+/xAfpguQHoabIXkcqRRKpMrWKBkpEZZyxfY9C1DpADFB8PEqGSTeFr135SaTRfKqGKx5xSCLI7ZQ=="
-    },
-    "@emotion/cache": {
-      "version": "10.0.29",
-      "resolved": "https://registry.npmjs.org/@emotion/cache/-/cache-10.0.29.tgz",
-      "integrity": "sha512-fU2VtSVlHiF27empSbxi1O2JFdNWZO+2NFHfwO0pxgTep6Xa3uGb+3pVKfLww2l/IBGLNEZl5Xf/++A4wAYDYQ==",
-      "requires": {
-        "@emotion/sheet": "0.9.4",
-        "@emotion/stylis": "0.8.5",
-        "@emotion/utils": "0.11.3",
-        "@emotion/weak-memoize": "0.2.5"
-      }
-    },
-    "@emotion/core": {
-      "version": "10.0.28",
-      "resolved": "https://registry.npmjs.org/@emotion/core/-/core-10.0.28.tgz",
-      "integrity": "sha512-pH8UueKYO5jgg0Iq+AmCLxBsvuGtvlmiDCOuv8fGNYn3cowFpLN98L8zO56U0H1PjDIyAlXymgL3Wu7u7v6hbA==",
-      "requires": {
-        "@babel/runtime": "^7.5.5",
-        "@emotion/cache": "^10.0.27",
-        "@emotion/css": "^10.0.27",
-        "@emotion/serialize": "^0.11.15",
-        "@emotion/sheet": "0.9.4",
-        "@emotion/utils": "0.11.3"
-      }
-    },
-    "@emotion/css": {
-      "version": "10.0.27",
-      "resolved": "https://registry.npmjs.org/@emotion/css/-/css-10.0.27.tgz",
-      "integrity": "sha512-6wZjsvYeBhyZQYNrGoR5yPMYbMBNEnanDrqmsqS1mzDm1cOTu12shvl2j4QHNS36UaTE0USIJawCH9C8oW34Zw==",
-      "requires": {
-        "@emotion/serialize": "^0.11.15",
-        "@emotion/utils": "0.11.3",
-        "babel-plugin-emotion": "^10.0.27"
-      }
-    },
     "@emotion/hash": {
       "version": "0.8.0",
       "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.8.0.tgz",
@@ -1500,92 +1403,11 @@
       "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.7.4.tgz",
       "integrity": "sha512-Ja/Vfqe3HpuzRsG1oBtWTHk2PGZ7GR+2Vz5iYGelAw8dx32K0y7PjVuxK6z1nMpZOqAFsRUPCkK1YjJ56qJlgw=="
     },
-    "@emotion/serialize": {
-      "version": "0.11.16",
-      "resolved": "https://registry.npmjs.org/@emotion/serialize/-/serialize-0.11.16.tgz",
-      "integrity": "sha512-G3J4o8by0VRrO+PFeSc3js2myYNOXVJ3Ya+RGVxnshRYgsvErfAOglKAiy1Eo1vhzxqtUvjCyS5gtewzkmvSSg==",
-      "requires": {
-        "@emotion/hash": "0.8.0",
-        "@emotion/memoize": "0.7.4",
-        "@emotion/unitless": "0.7.5",
-        "@emotion/utils": "0.11.3",
-        "csstype": "^2.5.7"
-      }
-    },
-    "@emotion/sheet": {
-      "version": "0.9.4",
-      "resolved": "https://registry.npmjs.org/@emotion/sheet/-/sheet-0.9.4.tgz",
-      "integrity": "sha512-zM9PFmgVSqBw4zL101Q0HrBVTGmpAxFZH/pYx/cjJT5advXguvcgjHFTCaIO3enL/xr89vK2bh0Mfyj9aa0ANA=="
-    },
-    "@emotion/styled": {
-      "version": "10.0.27",
-      "resolved": "https://registry.npmjs.org/@emotion/styled/-/styled-10.0.27.tgz",
-      "integrity": "sha512-iK/8Sh7+NLJzyp9a5+vIQIXTYxfT4yB/OJbjzQanB2RZpvmzBQOHZWhpAMZWYEKRNNbsD6WfBw5sVWkb6WzS/Q==",
-      "requires": {
-        "@emotion/styled-base": "^10.0.27",
-        "babel-plugin-emotion": "^10.0.27"
-      }
-    },
-    "@emotion/styled-base": {
-      "version": "10.0.31",
-      "resolved": "https://registry.npmjs.org/@emotion/styled-base/-/styled-base-10.0.31.tgz",
-      "integrity": "sha512-wTOE1NcXmqMWlyrtwdkqg87Mu6Rj1MaukEoEmEkHirO5IoHDJ8LgCQL4MjJODgxWxXibGR3opGp1p7YvkNEdXQ==",
-      "requires": {
-        "@babel/runtime": "^7.5.5",
-        "@emotion/is-prop-valid": "0.8.8",
-        "@emotion/serialize": "^0.11.15",
-        "@emotion/utils": "0.11.3"
-      }
-    },
-    "@emotion/stylis": {
-      "version": "0.8.5",
-      "resolved": "https://registry.npmjs.org/@emotion/stylis/-/stylis-0.8.5.tgz",
-      "integrity": "sha512-h6KtPihKFn3T9fuIrwvXXUOwlx3rfUvfZIcP5a6rh8Y7zjE3O06hT5Ss4S/YI1AYhuZ1kjaE/5EaOOI2NqSylQ=="
-    },
     "@emotion/unitless": {
       "version": "0.7.5",
       "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.7.5.tgz",
       "integrity": "sha512-OWORNpfjMsSSUBVrRBVGECkhWcULOAJz9ZW8uK9qgxD+87M7jHRcvh/A96XXNhXTLmKcoYSQtBEX7lHMO7YRwg=="
     },
-    "@emotion/utils": {
-      "version": "0.11.3",
-      "resolved": "https://registry.npmjs.org/@emotion/utils/-/utils-0.11.3.tgz",
-      "integrity": "sha512-0o4l6pZC+hI88+bzuaX/6BgOvQVhbt2PfmxauVaYOGgbsAw14wdKyvMCZXnsnsHys94iadcF+RG/wZyx6+ZZBw=="
-    },
-    "@emotion/weak-memoize": {
-      "version": "0.2.5",
-      "resolved": "https://registry.npmjs.org/@emotion/weak-memoize/-/weak-memoize-0.2.5.tgz",
-      "integrity": "sha512-6U71C2Wp7r5XtFtQzYrW5iKFT67OixrSxjI4MptCHzdSVlgabczzqLe0ZSgnub/5Kp4hSbpDB1tMytZY9pwxxA=="
-    },
-    "@fortawesome/fontawesome": {
-      "version": "1.1.8",
-      "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome/-/fontawesome-1.1.8.tgz",
-      "integrity": "sha512-c0/MtkPVT0fmiFcCyYoPjkG9PkMOvfrZw2+0BaJ+Rh6UEcK1AR/LaRgrHHjUkbAbs9LXxQJhFS8CJ4uSnK2+JA==",
-      "requires": {
-        "@fortawesome/fontawesome-common-types": "^0.1.7"
-      }
-    },
-    "@fortawesome/fontawesome-common-types": {
-      "version": "0.1.7",
-      "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-0.1.7.tgz",
-      "integrity": "sha512-ego8jRVSHfq/iq4KRZJKQeUAdi3ZjGNrqw4oPN3fNdvTBnLCSntwVCnc37bsAJP9UB8MhrTfPnZYxkv2vpS4pg=="
-    },
-    "@fortawesome/fontawesome-free-solid": {
-      "version": "5.0.13",
-      "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-free-solid/-/fontawesome-free-solid-5.0.13.tgz",
-      "integrity": "sha512-b+krVnqkdDt52Yfev0x0ZZgtxBQsLw00Zfa3uaVWIDzpNZVtrEXuxldUSUaN/ihgGhSNi8VpvDAdNPVgCKOSxw==",
-      "requires": {
-        "@fortawesome/fontawesome-common-types": "^0.1.7"
-      }
-    },
-    "@fortawesome/react-fontawesome": {
-      "version": "0.1.14",
-      "resolved": "https://registry.npmjs.org/@fortawesome/react-fontawesome/-/react-fontawesome-0.1.14.tgz",
-      "integrity": "sha512-4wqNb0gRLVaBm/h+lGe8UfPPivcbuJ6ecI4hIgW0LjI7kzpYB9FkN0L9apbVzg+lsBdcTf0AlBtODjcSX5mmKA==",
-      "requires": {
-        "prop-types": "^15.7.2"
-      }
-    },
     "@material-ui/core": {
       "version": "4.11.2",
       "resolved": "https://registry.npmjs.org/@material-ui/core/-/core-4.11.2.tgz",
@@ -1925,93 +1747,6 @@
         "loader-utils": "^1.1.0"
       }
     },
-    "@syncfusion/ej2-base": {
-      "version": "18.3.52",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-base/-/ej2-base-18.3.52.tgz",
-      "integrity": "sha512-g32+xrxnktzz7PhAPlmVhM/Lu4Ad+VuEYDOIw6+/tTHc4FkfNglZxyNmom+9J4bfDkz9AyVv0JmbPyeBxDvETg==",
-      "requires": {
-        "@syncfusion/ej2-icons": "~18.3.47"
-      }
-    },
-    "@syncfusion/ej2-buttons": {
-      "version": "18.3.47",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-buttons/-/ej2-buttons-18.3.47.tgz",
-      "integrity": "sha512-V/uzgfaE4f0bfbxKbztIs4Px6cVEVYKKoSMMTWxGFOAD1Ol2Hp055MJzDjQTzmoaq7TlLjyHXGZDsYoKGuguGw==",
-      "requires": {
-        "@syncfusion/ej2-base": "~18.3.47"
-      }
-    },
-    "@syncfusion/ej2-icons": {
-      "version": "18.3.47",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-icons/-/ej2-icons-18.3.47.tgz",
-      "integrity": "sha512-SSasO60RF0wZuPvz7KUMhvqeZgHCBOrCy2IjPywg3YDOgH244E90NasE0jfGm/1HDdkkVhxWATh8bZh79Ivg/g=="
-    },
-    "@syncfusion/ej2-inputs": {
-      "version": "18.3.52",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-inputs/-/ej2-inputs-18.3.52.tgz",
-      "integrity": "sha512-+uN/eGlCsoPISsx/j/HA3MO1TQALDiRVVPe/Cr9kmtxirgIFfkFeY5kOZ3vbYho+5fomSU/4JQX1FMXNV3xQ9A==",
-      "requires": {
-        "@syncfusion/ej2-base": "~18.3.52",
-        "@syncfusion/ej2-buttons": "~18.3.47",
-        "@syncfusion/ej2-popups": "~18.3.52",
-        "@syncfusion/ej2-splitbuttons": "~18.3.52"
-      }
-    },
-    "@syncfusion/ej2-popups": {
-      "version": "18.3.52",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-popups/-/ej2-popups-18.3.52.tgz",
-      "integrity": "sha512-5+dAQaUkMYH59Ka82Rg7d4RvjP5dQm5GtZWGbAkN9TpIh4wfDhLTeBOhN87f7n8RsuDA9bBtCRk1YEdBfTpEGw==",
-      "requires": {
-        "@syncfusion/ej2-base": "~18.3.52",
-        "@syncfusion/ej2-buttons": "~18.3.47"
-      }
-    },
-    "@syncfusion/ej2-react-base": {
-      "version": "18.3.52",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-react-base/-/ej2-react-base-18.3.52.tgz",
-      "integrity": "sha512-dpNnTPjUUxfkdb0BxeUcBs9DPJ/ngf9ipbd5eLwJPE7XFlrOJ1owEoqDqXIeW9pI+eVu9L3hF25TI287T5b9Sw==",
-      "requires": {
-        "@syncfusion/ej2-base": "~18.3.52"
-      }
-    },
-    "@syncfusion/ej2-react-inputs": {
-      "version": "18.3.52",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-react-inputs/-/ej2-react-inputs-18.3.52.tgz",
-      "integrity": "sha512-qhMFm4uMUKTashS/mX+jbxwWP3dm49V2t6b7XyZ03wAxDk2wUxchqx2AwhSNBBzTWGYXh1ZvWIujjegXIS9kqQ==",
-      "requires": {
-        "@syncfusion/ej2-base": "~18.3.52",
-        "@syncfusion/ej2-inputs": "18.3.52",
-        "@syncfusion/ej2-react-base": "~18.3.52"
-      }
-    },
-    "@syncfusion/ej2-splitbuttons": {
-      "version": "18.3.52",
-      "resolved": "https://registry.npmjs.org/@syncfusion/ej2-splitbuttons/-/ej2-splitbuttons-18.3.52.tgz",
-      "integrity": "sha512-KgZ4MGpohJzhX5HoRE+unMkeiU0d9tJbNgEhmhLKK4IsXeVx579gc9ftlTtmofjtOU9UyyHvjmYI6y+gobprww==",
-      "requires": {
-        "@syncfusion/ej2-base": "~18.3.52",
-        "@syncfusion/ej2-popups": "~18.3.52"
-      }
-    },
-    "@types/cookie": {
-      "version": "0.3.3",
-      "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.3.3.tgz",
-      "integrity": "sha512-LKVP3cgXBT9RYj+t+9FDKwS5tdI+rPBXaNSkma7hvqy35lc7mAokC2zsqWJH0LaqIt3B962nuYI77hsJoT1gow=="
-    },
-    "@types/hoist-non-react-statics": {
-      "version": "3.3.1",
-      "resolved": "https://registry.npmjs.org/@types/hoist-non-react-statics/-/hoist-non-react-statics-3.3.1.tgz",
-      "integrity": "sha512-iMIqiko6ooLrTh1joXodJK5X9xeEALT1kM5G3ZLhD3hszxBdIEd5C75U834D9mLcINgD4OyZf5uQXjkuYydWvA==",
-      "requires": {
-        "@types/react": "*",
-        "hoist-non-react-statics": "^3.3.0"
-      }
-    },
-    "@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",
@@ -2038,14 +1773,6 @@
         }
       }
     },
-    "@types/react-recaptcha": {
-      "version": "2.3.3",
-      "resolved": "https://registry.npmjs.org/@types/react-recaptcha/-/react-recaptcha-2.3.3.tgz",
-      "integrity": "sha512-1IdhJxBbPN+QL/eARSl/qwV2+03kwewJmZ43CWJJoGVZd4S4wGiascCl1HVe8PRtNPzXDqAi+nXIufvEDIsAPg==",
-      "requires": {
-        "@types/react": "*"
-      }
-    },
     "@types/react-transition-group": {
       "version": "4.4.0",
       "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.4.0.tgz",
@@ -2281,15 +2008,6 @@
       "resolved": "https://registry.npmjs.org/address/-/address-1.0.3.tgz",
       "integrity": "sha512-z55ocwKBRLryBs394Sm3ushTtBeg6VAeuku7utSoSnsJKvKcnXFIyC6vh27n3rXyxSgkJBBCAvyOn7gSUcTYjg=="
     },
-    "ajax-request": {
-      "version": "1.2.3",
-      "resolved": "https://registry.npmjs.org/ajax-request/-/ajax-request-1.2.3.tgz",
-      "integrity": "sha1-mfy+wdbSeS+F+pSVNTMr0U9fN5A=",
-      "requires": {
-        "file-system": "^2.1.1",
-        "utils-extend": "^1.0.7"
-      }
-    },
     "ajv": {
       "version": "6.12.2",
       "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.2.tgz",
@@ -2344,65 +2062,6 @@
         "color-convert": "^1.9.0"
       }
     },
-    "antd": {
-      "version": "4.13.1",
-      "resolved": "https://registry.npmjs.org/antd/-/antd-4.13.1.tgz",
-      "integrity": "sha512-KaveTRGKOFrbas3FO0ktXaZrSMDpDWz3FpuLbafV7R973BNz2yo+IG8ia2KPEfpRtGYUvpnKlDUNQZWhotoYhQ==",
-      "requires": {
-        "@ant-design/colors": "^6.0.0",
-        "@ant-design/icons": "^4.5.0",
-        "@ant-design/react-slick": "~0.28.1",
-        "@babel/runtime": "^7.12.5",
-        "array-tree-filter": "^2.1.0",
-        "classnames": "^2.2.6",
-        "copy-to-clipboard": "^3.2.0",
-        "lodash": "^4.17.20",
-        "moment": "^2.25.3",
-        "rc-cascader": "~1.4.0",
-        "rc-checkbox": "~2.3.0",
-        "rc-collapse": "~3.1.0",
-        "rc-dialog": "~8.5.1",
-        "rc-drawer": "~4.3.0",
-        "rc-dropdown": "~3.2.0",
-        "rc-field-form": "~1.19.0",
-        "rc-image": "~5.2.3",
-        "rc-input-number": "~7.0.0-alpha.4",
-        "rc-mentions": "~1.5.0",
-        "rc-menu": "~8.10.0",
-        "rc-motion": "^2.4.0",
-        "rc-notification": "~4.5.2",
-        "rc-pagination": "~3.1.2",
-        "rc-picker": "~2.5.1",
-        "rc-progress": "~3.1.0",
-        "rc-rate": "~2.9.0",
-        "rc-resize-observer": "^1.0.0",
-        "rc-select": "~12.1.0",
-        "rc-slider": "~9.7.1",
-        "rc-steps": "~4.1.0",
-        "rc-switch": "~3.2.0",
-        "rc-table": "~7.13.0",
-        "rc-tabs": "~11.7.0",
-        "rc-textarea": "~0.3.0",
-        "rc-tooltip": "~5.1.0",
-        "rc-tree": "~4.1.0",
-        "rc-tree-select": "~4.3.0",
-        "rc-trigger": "^5.2.1",
-        "rc-upload": "~4.0.0-alpha.6",
-        "rc-util": "^5.8.1",
-        "scroll-into-view-if-needed": "^2.2.25",
-        "warning": "^4.0.3"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
     "anymatch": {
       "version": "2.0.0",
       "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
@@ -2748,11 +2407,6 @@
       "resolved": "https://registry.npmjs.org/array-reduce/-/array-reduce-0.0.0.tgz",
       "integrity": "sha1-FziZ0//Rx9k4PkR5Ul2+J4yrXys="
     },
-    "array-tree-filter": {
-      "version": "2.1.0",
-      "resolved": "https://registry.npmjs.org/array-tree-filter/-/array-tree-filter-2.1.0.tgz",
-      "integrity": "sha512-4ROwICNlNw/Hqa9v+rk5h22KjmzB1JGTMVKP2AKJBOCgb0yL0ASf0+YvCcLNNwquOHNX48jkeZIJ3a+oOQqKcw=="
-    },
     "array-union": {
       "version": "1.0.2",
       "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz",
@@ -2935,11 +2589,6 @@
       "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz",
       "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ=="
     },
-    "async-validator": {
-      "version": "3.5.1",
-      "resolved": "https://registry.npmjs.org/async-validator/-/async-validator-3.5.1.tgz",
-      "integrity": "sha512-DDmKA7sdSAJtTVeNZHrnr2yojfFaoeW8MfQN8CeuXg8DDQHTqKk9Fdv38dSvnesHoO8MUwMI2HphOeSyIF+wmQ=="
-    },
     "asynckit": {
       "version": "0.4.0",
       "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
@@ -3156,23 +2805,6 @@
         "object.assign": "^4.1.0"
       }
     },
-    "babel-plugin-emotion": {
-      "version": "10.0.33",
-      "resolved": "https://registry.npmjs.org/babel-plugin-emotion/-/babel-plugin-emotion-10.0.33.tgz",
-      "integrity": "sha512-bxZbTTGz0AJQDHm8k6Rf3RQJ8tX2scsfsRyKVgAbiUPUNIRtlK+7JxP+TAd1kRLABFxe0CFm2VdK4ePkoA9FxQ==",
-      "requires": {
-        "@babel/helper-module-imports": "^7.0.0",
-        "@emotion/hash": "0.8.0",
-        "@emotion/memoize": "0.7.4",
-        "@emotion/serialize": "^0.11.16",
-        "babel-plugin-macros": "^2.0.0",
-        "babel-plugin-syntax-jsx": "^6.18.0",
-        "convert-source-map": "^1.5.0",
-        "escape-string-regexp": "^1.0.5",
-        "find-root": "^1.1.0",
-        "source-map": "^0.5.7"
-      }
-    },
     "babel-plugin-istanbul": {
       "version": "4.1.6",
       "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-4.1.6.tgz",
@@ -3189,16 +2821,6 @@
       "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-23.2.0.tgz",
       "integrity": "sha1-5h+uBaHKiAGq3uV6bWa4zvr0QWc="
     },
-    "babel-plugin-macros": {
-      "version": "2.8.0",
-      "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-2.8.0.tgz",
-      "integrity": "sha512-SEP5kJpfGYqYKpBrj5XU3ahw5p5GOHJ0U5ssOSQ/WBVdwkD2Dzlce95exQTs3jOVWPPKLBN2rlEWkCK7dSmLvg==",
-      "requires": {
-        "@babel/runtime": "^7.7.2",
-        "cosmiconfig": "^6.0.0",
-        "resolve": "^1.12.0"
-      }
-    },
     "babel-plugin-named-asset-import": {
       "version": "0.3.6",
       "resolved": "https://registry.npmjs.org/babel-plugin-named-asset-import/-/babel-plugin-named-asset-import-0.3.6.tgz",
@@ -3684,15 +3306,6 @@
         }
       }
     },
-    "base64-img": {
-      "version": "1.0.4",
-      "resolved": "https://registry.npmjs.org/base64-img/-/base64-img-1.0.4.tgz",
-      "integrity": "sha1-PiLVXWx0okVT2EDSsbwSp9sHjTU=",
-      "requires": {
-        "ajax-request": "^1.2.0",
-        "file-system": "^2.1.0"
-      }
-    },
     "base64-js": {
       "version": "1.3.1",
       "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz",
@@ -3730,7 +3343,17 @@
     "binary-extensions": {
       "version": "2.1.0",
       "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz",
-      "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ=="
+      "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==",
+      "optional": true
+    },
+    "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",
@@ -3952,6 +3575,12 @@
         "node-int64": "^0.4.0"
       }
     },
+    "btoa": {
+      "version": "1.2.1",
+      "resolved": "https://registry.npmjs.org/btoa/-/btoa-1.2.1.tgz",
+      "integrity": "sha512-SB4/MIGlsiVkMcHmT+pSmIPoNDoHg+7cMzmt3Uxt628MTz2487DKSqK/fuhFBrkuqrYv5UCEnACpF4dTFNKc/g==",
+      "dev": true
+    },
     "buffer": {
       "version": "4.9.2",
       "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz",
@@ -3977,23 +3606,6 @@
       "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz",
       "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk="
     },
-    "build": {
-      "version": "0.1.4",
-      "resolved": "https://registry.npmjs.org/build/-/build-0.1.4.tgz",
-      "integrity": "sha1-cH/gJv/O3crL/c3zVur9pk8VEEY=",
-      "requires": {
-        "cssmin": "0.3.x",
-        "jsmin": "1.x",
-        "jxLoader": "*",
-        "moo-server": "*",
-        "promised-io": "*",
-        "timespan": "2.x",
-        "uglify-js": "1.x",
-        "walker": "1.x",
-        "winston": "*",
-        "wrench": "1.3.x"
-      }
-    },
     "builtin-status-codes": {
       "version": "3.0.0",
       "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz",
@@ -4230,6 +3842,7 @@
           "integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==",
           "optional": true,
           "requires": {
+            "bindings": "^1.5.0",
             "nan": "^2.12.1"
           }
         },
@@ -4492,25 +4105,6 @@
       "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.2.2.tgz",
       "integrity": "sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w=="
     },
-    "colornames": {
-      "version": "1.1.1",
-      "resolved": "https://registry.npmjs.org/colornames/-/colornames-1.1.1.tgz",
-      "integrity": "sha1-+IiQMGhcfE/54qVZ9Qd+t2qBb5Y="
-    },
-    "colors": {
-      "version": "1.4.0",
-      "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz",
-      "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA=="
-    },
-    "colorspace": {
-      "version": "1.1.2",
-      "resolved": "https://registry.npmjs.org/colorspace/-/colorspace-1.1.2.tgz",
-      "integrity": "sha512-vt+OoIP2d76xLhjwbBaucYlNSpPsrJWPlBTtwCpQKIu6/CSMutyzX93O/Do0qzpH3YoHEes8YEFXyZ797rEhzQ==",
-      "requires": {
-        "color": "3.0.x",
-        "text-hex": "1.0.x"
-      }
-    },
     "combined-stream": {
       "version": "1.0.8",
       "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
@@ -4576,11 +4170,6 @@
         }
       }
     },
-    "compute-scroll-into-view": {
-      "version": "1.0.17",
-      "resolved": "https://registry.npmjs.org/compute-scroll-into-view/-/compute-scroll-into-view-1.0.17.tgz",
-      "integrity": "sha512-j4dx+Fb0URmzbwwMUrhqWM2BEWHdFGx+qZ9qqASHRPqvTYdqvWnHg0H1hIbcyLnvgnoNAVMlwkepyqM3DaIFUg=="
-    },
     "concat-map": {
       "version": "0.0.1",
       "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
@@ -4686,11 +4275,6 @@
         }
       }
     },
-    "cookie": {
-      "version": "0.4.1",
-      "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz",
-      "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA=="
-    },
     "cookie-signature": {
       "version": "1.0.6",
       "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
@@ -4714,14 +4298,6 @@
       "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz",
       "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40="
     },
-    "copy-to-clipboard": {
-      "version": "3.3.1",
-      "resolved": "https://registry.npmjs.org/copy-to-clipboard/-/copy-to-clipboard-3.3.1.tgz",
-      "integrity": "sha512-i13qo6kIHTTpCm8/Wup+0b1mVWETvu2kIMzKoK8FpkLkFxlt0znUAHcMzox+T8sPlqtZXq3CulEjQHsYiGFJUw==",
-      "requires": {
-        "toggle-selection": "^1.0.6"
-      }
-    },
     "core-js": {
       "version": "3.8.0",
       "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.8.0.tgz",
@@ -4748,18 +4324,6 @@
       "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
       "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac="
     },
-    "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"
-      }
-    },
     "create-ecdh": {
       "version": "4.0.3",
       "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.3.tgz",
@@ -5085,11 +4649,6 @@
       "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz",
       "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg=="
     },
-    "cssmin": {
-      "version": "0.3.2",
-      "resolved": "https://registry.npmjs.org/cssmin/-/cssmin-0.3.2.tgz",
-      "integrity": "sha1-3c5MVHtRCuDVlKjx+/iq+OLFwA0="
-    },
     "cssnano": {
       "version": "4.1.10",
       "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-4.1.10.tgz",
@@ -5366,11 +4925,6 @@
         }
       }
     },
-    "date-fns": {
-      "version": "2.19.0",
-      "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-2.19.0.tgz",
-      "integrity": "sha512-X3bf2iTPgCAQp9wvjOQytnf5vO5rESYRXlPIVcgSbtT5OTScPcsf9eZU+B/YIkKAtYr5WeCii58BgATrNitlWg=="
-    },
     "debug": {
       "version": "3.1.0",
       "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz",
@@ -5595,16 +5149,6 @@
         }
       }
     },
-    "diagnostics": {
-      "version": "1.1.1",
-      "resolved": "https://registry.npmjs.org/diagnostics/-/diagnostics-1.1.1.tgz",
-      "integrity": "sha512-8wn1PmdunLJ9Tqbx+Fx/ZEuHfJf4NKSN2ZBj7SJC/OWRWha843+WsTjqMe1B5E3p28jqBlp+mJ2fPVxPyNgYKQ==",
-      "requires": {
-        "colorspace": "1.1.x",
-        "enabled": "1.0.x",
-        "kuler": "1.0.x"
-      }
-    },
     "diff": {
       "version": "3.5.0",
       "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz",
@@ -5681,11 +5225,6 @@
         "esutils": "^2.0.2"
       }
     },
-    "dom-align": {
-      "version": "1.12.0",
-      "resolved": "https://registry.npmjs.org/dom-align/-/dom-align-1.12.0.tgz",
-      "integrity": "sha512-YkoezQuhp3SLFGdOlr5xkqZ640iXrnHAwVYcDg8ZKRUtO7mSzSC2BA5V0VuyAwPSJA4CLIc6EDDJh4bEsD2+zA=="
-    },
     "dom-converter": {
       "version": "0.2.0",
       "resolved": "https://registry.npmjs.org/dom-converter/-/dom-converter-0.2.0.tgz",
@@ -5845,6 +5384,15 @@
       "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
       "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
     },
+    "ejs": {
+      "version": "3.1.6",
+      "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.6.tgz",
+      "integrity": "sha512-9lt9Zse4hPucPkoP7FHDF0LQAlGyF9JVpnClFLFH3aSSbxmyoqINRpp/9wePWJTUl4KOQwRL72Iw3InHPDkoGw==",
+      "dev": true,
+      "requires": {
+        "jake": "^10.6.1"
+      }
+    },
     "electron-to-chromium": {
       "version": "1.3.473",
       "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.473.tgz",
@@ -5881,14 +5429,6 @@
       "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz",
       "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q=="
     },
-    "enabled": {
-      "version": "1.0.2",
-      "resolved": "https://registry.npmjs.org/enabled/-/enabled-1.0.2.tgz",
-      "integrity": "sha1-ll9lE9LC0cX0ZStkouM5ZGf8L5M=",
-      "requires": {
-        "env-variable": "0.0.x"
-      }
-    },
     "encodeurl": {
       "version": "1.0.2",
       "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
@@ -5955,11 +5495,6 @@
       "resolved": "https://registry.npmjs.org/entities/-/entities-2.0.3.tgz",
       "integrity": "sha512-MyoZ0jgnLvB2X3Lg5HqpFmn1kybDiIfEQmKzTb5apr51Rb+T3KdmMiqa70T+bhGnyv7bQ6WMj2QMHpGMmlrUYQ=="
     },
-    "env-variable": {
-      "version": "0.0.6",
-      "resolved": "https://registry.npmjs.org/env-variable/-/env-variable-0.0.6.tgz",
-      "integrity": "sha512-bHz59NlBbtS0NhftmR8+ExBEekE7br0e01jw+kk0NDro7TtZzBYZ5ScGPs3OmwnpyfHTHOtr1Y6uedCdrIldtg=="
-    },
     "errno": {
       "version": "0.1.7",
       "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz",
@@ -6970,11 +6505,6 @@
       "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
       "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc="
     },
-    "fast-safe-stringify": {
-      "version": "2.0.7",
-      "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.7.tgz",
-      "integrity": "sha512-Utm6CdzT+6xsDk2m8S6uL8VHxNwI6Jub+e9NYTcAms28T84pTa25GJQV9j0CY0N1rM8hK4x6grpF2BQf+2qwVA=="
-    },
     "fastparse": {
       "version": "1.1.2",
       "resolved": "https://registry.npmjs.org/fastparse/-/fastparse-1.1.2.tgz",
@@ -6996,11 +6526,6 @@
         "bser": "2.1.1"
       }
     },
-    "fecha": {
-      "version": "2.3.3",
-      "resolved": "https://registry.npmjs.org/fecha/-/fecha-2.3.3.tgz",
-      "integrity": "sha512-lUGBnIamTAwk4znq5BcqsDaxSmZ9nDVJaij6NvRt/Tg4R69gERA+otPKbS86ROw9nxVMw2/mp1fnaiWqbs6Sdg=="
-    },
     "figgy-pudding": {
       "version": "3.5.2",
       "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.2.tgz",
@@ -7032,21 +6557,19 @@
         "schema-utils": "^1.0.0"
       }
     },
-    "file-match": {
-      "version": "1.0.2",
-      "resolved": "https://registry.npmjs.org/file-match/-/file-match-1.0.2.tgz",
-      "integrity": "sha1-ycrSZdLIrfOoFHWw30dYWQafrvc=",
-      "requires": {
-        "utils-extend": "^1.0.6"
-      }
+    "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
     },
-    "file-system": {
-      "version": "2.2.2",
-      "resolved": "https://registry.npmjs.org/file-system/-/file-system-2.2.2.tgz",
-      "integrity": "sha1-fWWDPjojR9zZVqgTxncVPtPt2Yc=",
+    "filelist": {
+      "version": "1.0.2",
+      "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.2.tgz",
+      "integrity": "sha512-z7O0IS8Plc39rTCq6i6iHxk43duYOn8uFJiWSewIq0Bww1RNybVHSCjahmcC87ZqAm4OTvFzlzeGu3XAzG1ctQ==",
+      "dev": true,
       "requires": {
-        "file-match": "^1.0.1",
-        "utils-extend": "^1.0.4"
+        "minimatch": "^3.0.4"
       }
     },
     "filename-regex": {
@@ -7124,11 +6647,6 @@
         "pkg-dir": "^3.0.0"
       }
     },
-    "find-root": {
-      "version": "1.1.0",
-      "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz",
-      "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng=="
-    },
     "find-up": {
       "version": "2.1.0",
       "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz",
@@ -7137,26 +6655,6 @@
         "locate-path": "^2.0.0"
       }
     },
-    "fine-uploader": {
-      "version": "5.16.2",
-      "resolved": "https://registry.npmjs.org/fine-uploader/-/fine-uploader-5.16.2.tgz",
-      "integrity": "sha1-DYeNoc0nU/gGg6wJHfXa/5/7jEQ="
-    },
-    "fine-uploader-wrappers": {
-      "version": "1.0.1",
-      "resolved": "https://registry.npmjs.org/fine-uploader-wrappers/-/fine-uploader-wrappers-1.0.1.tgz",
-      "integrity": "sha1-BEqUMgdr0CrBQEhm7G4Zf8Zi/L8=",
-      "requires": {
-        "object-assign": "4.1.0"
-      },
-      "dependencies": {
-        "object-assign": {
-          "version": "4.1.0",
-          "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.0.tgz",
-          "integrity": "sha1-ejs9DpgGPUP0wD8uiubNUahog6A="
-        }
-      }
-    },
     "flat-cache": {
       "version": "1.3.4",
       "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.4.tgz",
@@ -9045,14 +8543,6 @@
       "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz",
       "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg=="
     },
-    "image-to-base64": {
-      "version": "2.1.1",
-      "resolved": "https://registry.npmjs.org/image-to-base64/-/image-to-base64-2.1.1.tgz",
-      "integrity": "sha512-G8EZaxl8dmYUXCmaC/1W4oqwj+yiY+qhF9A81TbdOtxdK9BAN3oV440Jofexp4J2oRsbHIUJtl3rlDqdjmiZOQ==",
-      "requires": {
-        "node-fetch": "^2.6.0"
-      }
-    },
     "immer": {
       "version": "1.10.0",
       "resolved": "https://registry.npmjs.org/immer/-/immer-1.10.0.tgz",
@@ -9186,16 +8676,6 @@
         }
       }
     },
-    "insert-css": {
-      "version": "2.0.0",
-      "resolved": "https://registry.npmjs.org/insert-css/-/insert-css-2.0.0.tgz",
-      "integrity": "sha1-610Ql7dUL0x56jBg067gfQU4gPQ="
-    },
-    "install": {
-      "version": "0.13.0",
-      "resolved": "https://registry.npmjs.org/install/-/install-0.13.0.tgz",
-      "integrity": "sha512-zDml/jzr2PKU9I8J/xyZBQn8rPCAY//UOYNmR01XwNwyfhEWObo2SWfSl1+0tm1u6PhxLwDnfsT/6jB7OUxqFA=="
-    },
     "internal-ip": {
       "version": "3.0.1",
       "resolved": "https://registry.npmjs.org/internal-ip/-/internal-ip-3.0.1.tgz",
@@ -9357,6 +8837,12 @@
       "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz",
       "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE="
     },
+    "is-docker": {
+      "version": "2.2.1",
+      "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz",
+      "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==",
+      "dev": true
+    },
     "is-dotfile": {
       "version": "1.0.3",
       "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz",
@@ -9670,6 +9156,26 @@
         "handlebars": "^4.0.3"
       }
     },
+    "jake": {
+      "version": "10.8.2",
+      "resolved": "https://registry.npmjs.org/jake/-/jake-10.8.2.tgz",
+      "integrity": "sha512-eLpKyrfG3mzvGE2Du8VoPbeSkRry093+tyNjdYaBbJS9v17knImYGNXQCUV0gLxQtF82m3E8iRb/wdSQZLoq7A==",
+      "dev": true,
+      "requires": {
+        "async": "0.9.x",
+        "chalk": "^2.4.2",
+        "filelist": "^1.0.1",
+        "minimatch": "^3.0.4"
+      },
+      "dependencies": {
+        "async": {
+          "version": "0.9.2",
+          "resolved": "https://registry.npmjs.org/async/-/async-0.9.2.tgz",
+          "integrity": "sha1-rqdNXmHB+JlhO/ZL2mbUx48v0X0=",
+          "dev": true
+        }
+      }
+    },
     "jest": {
       "version": "23.6.0",
       "resolved": "https://registry.npmjs.org/jest/-/jest-23.6.0.tgz",
@@ -10205,11 +9711,6 @@
       "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
       "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ=="
     },
-    "js-yaml": {
-      "version": "0.3.7",
-      "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-0.3.7.tgz",
-      "integrity": "sha1-1znY7oZGHlSzVNan19HyrZoWf2I="
-    },
     "jsbn": {
       "version": "0.1.1",
       "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz",
@@ -10260,11 +9761,6 @@
       "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
       "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA=="
     },
-    "jsmin": {
-      "version": "1.0.1",
-      "resolved": "https://registry.npmjs.org/jsmin/-/jsmin-1.0.1.tgz",
-      "integrity": "sha1-570NzWSWw79IYyNb9GGj2YqjuYw="
-    },
     "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",
@@ -10298,14 +9794,6 @@
       "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz",
       "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus="
     },
-    "json2mq": {
-      "version": "0.2.0",
-      "resolved": "https://registry.npmjs.org/json2mq/-/json2mq-0.2.0.tgz",
-      "integrity": "sha1-tje9O6nqvhIsg+lyBIOusQ0skEo=",
-      "requires": {
-        "string-convert": "^0.2.0"
-      }
-    },
     "json3": {
       "version": "3.3.3",
       "resolved": "https://registry.npmjs.org/json3/-/json3-3.3.3.tgz",
@@ -10438,17 +9926,6 @@
         "object.assign": "^4.1.0"
       }
     },
-    "jxLoader": {
-      "version": "0.1.1",
-      "resolved": "https://registry.npmjs.org/jxLoader/-/jxLoader-0.1.1.tgz",
-      "integrity": "sha1-ATTqUUTlM7WU/B/yX/GU4jXFPs0=",
-      "requires": {
-        "js-yaml": "0.3.x",
-        "moo-server": "1.3.x",
-        "promised-io": "*",
-        "walker": "1.x"
-      }
-    },
     "keycode": {
       "version": "2.2.0",
       "resolved": "https://registry.npmjs.org/keycode/-/keycode-2.2.0.tgz",
@@ -10472,14 +9949,6 @@
       "resolved": "https://registry.npmjs.org/kleur/-/kleur-2.0.2.tgz",
       "integrity": "sha512-77XF9iTllATmG9lSlIv0qdQ2BQ/h9t0bJllHlbvsQ0zUWfU7Yi0S8L5JXzPZgkefIiajLmBJJ4BsMJmqcf7oxQ=="
     },
-    "kuler": {
-      "version": "1.0.1",
-      "resolved": "https://registry.npmjs.org/kuler/-/kuler-1.0.1.tgz",
-      "integrity": "sha512-J9nVUucG1p/skKul6DU3PUZrhs0LPulNaeUOox0IyXDi8S4CztTHs1gQphhuZmzXG7VOQSf6NJfKuzteQLv9gQ==",
-      "requires": {
-        "colornames": "^1.1.1"
-      }
-    },
     "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",
@@ -10529,11 +9998,6 @@
         "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": "1.1.0",
       "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz",
@@ -10693,25 +10157,6 @@
       "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz",
       "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M="
     },
-    "logform": {
-      "version": "2.1.2",
-      "resolved": "https://registry.npmjs.org/logform/-/logform-2.1.2.tgz",
-      "integrity": "sha512-+lZh4OpERDBLqjiwDLpAWNQu6KMjnlXH2ByZwCuSqVPJletw0kTWJf5CgSNAUKn1KUkv3m2cUz/LK8zyEy7wzQ==",
-      "requires": {
-        "colors": "^1.2.1",
-        "fast-safe-stringify": "^2.0.4",
-        "fecha": "^2.3.3",
-        "ms": "^2.1.1",
-        "triple-beam": "^1.3.0"
-      },
-      "dependencies": {
-        "ms": {
-          "version": "2.1.2",
-          "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
-          "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
-        }
-      }
-    },
     "loglevel": {
       "version": "1.6.8",
       "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.6.8.tgz",
@@ -10783,40 +10228,6 @@
         "object-visit": "^1.0.0"
       }
     },
-    "material-design-icons": {
-      "version": "3.0.1",
-      "resolved": "https://registry.npmjs.org/material-design-icons/-/material-design-icons-3.0.1.tgz",
-      "integrity": "sha1-mnHEh0chjrylHlGmbaaCA4zct78="
-    },
-    "material-ui-popup-state": {
-      "version": "1.8.0",
-      "resolved": "https://registry.npmjs.org/material-ui-popup-state/-/material-ui-popup-state-1.8.0.tgz",
-      "integrity": "sha512-czXksi+b1I1Dgemp82UNUBjIy9DV60ttw6a9fyk60UX/Axqmf4hzcp/ulhd3JcMS5HgmmO1Vw/DNkV10ngj16A==",
-      "requires": {
-        "@babel/runtime": "^7.12.5",
-        "@material-ui/types": "^4.1.1",
-        "classnames": "^2.2.6",
-        "prop-types": "^15.7.2"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        },
-        "@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": "*"
-          }
-        }
-      }
-    },
     "math-random": {
       "version": "1.0.4",
       "resolved": "https://registry.npmjs.org/math-random/-/math-random-1.0.4.tgz",
@@ -11055,15 +10466,6 @@
         "webpack-sources": "^1.1.0"
       }
     },
-    "mini-store": {
-      "version": "3.0.6",
-      "resolved": "https://registry.npmjs.org/mini-store/-/mini-store-3.0.6.tgz",
-      "integrity": "sha512-YzffKHbYsMQGUWQRKdsearR79QsMzzJcDDmZKlJBqt5JNkqpyJHYlK6gP61O36X+sLf76sO9G6mhKBe83gIZIQ==",
-      "requires": {
-        "hoist-non-react-statics": "^3.3.2",
-        "shallowequal": "^1.0.2"
-      }
-    },
     "minimalistic-assert": {
       "version": "1.0.1",
       "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz",
@@ -11152,11 +10554,6 @@
       "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz",
       "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ=="
     },
-    "moo-server": {
-      "version": "1.3.0",
-      "resolved": "https://registry.npmjs.org/moo-server/-/moo-server-1.3.0.tgz",
-      "integrity": "sha1-XceVaVZaENbv7VQ5SR5p0jkuWPE="
-    },
     "move-concurrently": {
       "version": "1.0.1",
       "resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz",
@@ -11263,11 +10660,6 @@
         "lower-case": "^1.1.1"
       }
     },
-    "node-fetch": {
-      "version": "2.6.1",
-      "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz",
-      "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw=="
-    },
     "node-int64": {
       "version": "0.4.0",
       "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz",
@@ -11334,1826 +10726,57 @@
         },
         "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=="
-        }
-      }
-    },
-    "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"
-      }
-    },
-    "node-releases": {
-      "version": "1.1.58",
-      "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.58.tgz",
-      "integrity": "sha512-NxBudgVKiRh/2aPWMgPR7bPTX0VPmGx5QBwCtdHitnqFE5/O8DeBXuIMH1nwNnw/aMo6AjOrpsHzfY3UbUJ7yg=="
-    },
-    "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"
-      }
-    },
-    "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-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=="
-    },
-    "npm": {
-      "version": "7.6.2",
-      "resolved": "https://registry.npmjs.org/npm/-/npm-7.6.2.tgz",
-      "integrity": "sha512-XXlLw6+HNG5GXt/T+xOAK8QXQ3x3VhIOBmWtiTw6yavFeTelleN2uAf8zG7HwSv9pBxLA4FHx7vGmlMKxAkqDQ==",
-      "requires": {
-        "@npmcli/arborist": "^2.2.7",
-        "@npmcli/ci-detect": "^1.2.0",
-        "@npmcli/config": "^1.2.9",
-        "@npmcli/run-script": "^1.8.3",
-        "abbrev": "~1.1.1",
-        "ansicolors": "~0.3.2",
-        "ansistyles": "~0.1.3",
-        "archy": "~1.0.0",
-        "byte-size": "^7.0.1",
-        "cacache": "^15.0.5",
-        "chalk": "^4.1.0",
-        "chownr": "^2.0.0",
-        "cli-columns": "^3.1.2",
-        "cli-table3": "^0.6.0",
-        "columnify": "~1.5.4",
-        "glob": "^7.1.4",
-        "graceful-fs": "^4.2.6",
-        "hosted-git-info": "^3.0.8",
-        "ini": "^2.0.0",
-        "init-package-json": "^2.0.2",
-        "is-cidr": "^4.0.2",
-        "json-parse-even-better-errors": "^2.3.1",
-        "leven": "^3.1.0",
-        "libnpmaccess": "^4.0.1",
-        "libnpmdiff": "^2.0.4",
-        "libnpmfund": "^1.0.2",
-        "libnpmhook": "^6.0.1",
-        "libnpmorg": "^2.0.1",
-        "libnpmpack": "^2.0.1",
-        "libnpmpublish": "^4.0.0",
-        "libnpmsearch": "^3.1.0",
-        "libnpmteam": "^2.0.2",
-        "libnpmversion": "^1.0.11",
-        "make-fetch-happen": "^8.0.14",
-        "minipass": "^3.1.3",
-        "minipass-pipeline": "^1.2.4",
-        "mkdirp": "^1.0.4",
-        "mkdirp-infer-owner": "^2.0.0",
-        "ms": "^2.1.2",
-        "node-gyp": "^7.1.2",
-        "nopt": "^5.0.0",
-        "npm-audit-report": "^2.1.4",
-        "npm-package-arg": "^8.1.1",
-        "npm-pick-manifest": "^6.1.0",
-        "npm-profile": "^5.0.2",
-        "npm-registry-fetch": "^9.0.0",
-        "npm-user-validate": "^1.0.1",
-        "npmlog": "~4.1.2",
-        "opener": "^1.5.2",
-        "pacote": "^11.3.0",
-        "parse-conflict-json": "^1.1.1",
-        "qrcode-terminal": "^0.12.0",
-        "read": "~1.0.7",
-        "read-package-json": "^3.0.1",
-        "read-package-json-fast": "^2.0.2",
-        "readdir-scoped-modules": "^1.1.0",
-        "rimraf": "^3.0.2",
-        "semver": "^7.3.4",
-        "ssri": "^8.0.1",
-        "tar": "^6.1.0",
-        "text-table": "~0.2.0",
-        "tiny-relative-date": "^1.3.0",
-        "treeverse": "^1.0.4",
-        "validate-npm-package-name": "~3.0.0",
-        "which": "^2.0.2",
-        "write-file-atomic": "^3.0.3"
-      },
-      "dependencies": {
-        "@npmcli/arborist": {
-          "version": "2.2.7",
-          "bundled": true,
-          "requires": {
-            "@npmcli/installed-package-contents": "^1.0.7",
-            "@npmcli/map-workspaces": "^1.0.2",
-            "@npmcli/metavuln-calculator": "^1.1.0",
-            "@npmcli/move-file": "^1.1.0",
-            "@npmcli/name-from-folder": "^1.0.1",
-            "@npmcli/node-gyp": "^1.0.1",
-            "@npmcli/run-script": "^1.8.2",
-            "bin-links": "^2.2.1",
-            "cacache": "^15.0.3",
-            "common-ancestor-path": "^1.0.1",
-            "json-parse-even-better-errors": "^2.3.1",
-            "json-stringify-nice": "^1.1.1",
-            "mkdirp-infer-owner": "^2.0.0",
-            "npm-install-checks": "^4.0.0",
-            "npm-package-arg": "^8.1.0",
-            "npm-pick-manifest": "^6.1.0",
-            "npm-registry-fetch": "^9.0.0",
-            "pacote": "^11.2.6",
-            "parse-conflict-json": "^1.1.1",
-            "promise-all-reject-late": "^1.0.0",
-            "promise-call-limit": "^1.0.1",
-            "read-package-json-fast": "^2.0.2",
-            "readdir-scoped-modules": "^1.1.0",
-            "semver": "^7.3.4",
-            "tar": "^6.1.0",
-            "treeverse": "^1.0.4",
-            "walk-up-path": "^1.0.0"
-          }
-        },
-        "@npmcli/ci-detect": {
-          "version": "1.3.0",
-          "bundled": true
-        },
-        "@npmcli/config": {
-          "version": "1.2.9",
-          "bundled": true,
-          "requires": {
-            "ini": "^2.0.0",
-            "mkdirp-infer-owner": "^2.0.0",
-            "nopt": "^5.0.0",
-            "semver": "^7.3.4",
-            "walk-up-path": "^1.0.0"
-          }
-        },
-        "@npmcli/disparity-colors": {
-          "version": "1.0.1",
-          "bundled": true,
-          "requires": {
-            "ansi-styles": "^4.3.0"
-          }
-        },
-        "@npmcli/git": {
-          "version": "2.0.6",
-          "bundled": true,
-          "requires": {
-            "@npmcli/promise-spawn": "^1.1.0",
-            "lru-cache": "^6.0.0",
-            "mkdirp": "^1.0.3",
-            "npm-pick-manifest": "^6.0.0",
-            "promise-inflight": "^1.0.1",
-            "promise-retry": "^2.0.1",
-            "semver": "^7.3.2",
-            "unique-filename": "^1.1.1",
-            "which": "^2.0.2"
-          }
-        },
-        "@npmcli/installed-package-contents": {
-          "version": "1.0.7",
-          "bundled": true,
-          "requires": {
-            "npm-bundled": "^1.1.1",
-            "npm-normalize-package-bin": "^1.0.1"
-          }
-        },
-        "@npmcli/map-workspaces": {
-          "version": "1.0.3",
-          "bundled": true,
-          "requires": {
-            "@npmcli/name-from-folder": "^1.0.1",
-            "glob": "^7.1.6",
-            "minimatch": "^3.0.4",
-            "read-package-json-fast": "^2.0.1"
-          }
-        },
-        "@npmcli/metavuln-calculator": {
-          "version": "1.1.0",
-          "bundled": true,
-          "requires": {
-            "cacache": "^15.0.5",
-            "pacote": "^11.1.11",
-            "semver": "^7.3.2"
-          }
-        },
-        "@npmcli/move-file": {
-          "version": "1.1.2",
-          "bundled": true,
-          "requires": {
-            "mkdirp": "^1.0.4",
-            "rimraf": "^3.0.2"
-          }
-        },
-        "@npmcli/name-from-folder": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "@npmcli/node-gyp": {
-          "version": "1.0.2",
-          "bundled": true
-        },
-        "@npmcli/promise-spawn": {
-          "version": "1.3.2",
-          "bundled": true,
-          "requires": {
-            "infer-owner": "^1.0.4"
-          }
-        },
-        "@npmcli/run-script": {
-          "version": "1.8.3",
-          "bundled": true,
-          "requires": {
-            "@npmcli/node-gyp": "^1.0.2",
-            "@npmcli/promise-spawn": "^1.3.2",
-            "infer-owner": "^1.0.4",
-            "node-gyp": "^7.1.0",
-            "puka": "^1.0.1",
-            "read-package-json-fast": "^2.0.1"
-          }
-        },
-        "@tootallnate/once": {
-          "version": "1.1.2",
-          "bundled": true
-        },
-        "abbrev": {
-          "version": "1.1.1",
-          "bundled": true
-        },
-        "agent-base": {
-          "version": "6.0.2",
-          "bundled": true,
-          "requires": {
-            "debug": "4"
-          }
-        },
-        "agentkeepalive": {
-          "version": "4.1.4",
-          "bundled": true,
-          "requires": {
-            "debug": "^4.1.0",
-            "depd": "^1.1.2",
-            "humanize-ms": "^1.2.1"
-          }
-        },
-        "aggregate-error": {
-          "version": "3.1.0",
-          "bundled": true,
-          "requires": {
-            "clean-stack": "^2.0.0",
-            "indent-string": "^4.0.0"
-          }
-        },
-        "ajv": {
-          "version": "6.12.6",
-          "bundled": true,
-          "requires": {
-            "fast-deep-equal": "^3.1.1",
-            "fast-json-stable-stringify": "^2.0.0",
-            "json-schema-traverse": "^0.4.1",
-            "uri-js": "^4.2.2"
-          }
-        },
-        "ansi-regex": {
-          "version": "2.1.1",
-          "bundled": true
-        },
-        "ansi-styles": {
-          "version": "4.3.0",
-          "bundled": true,
-          "requires": {
-            "color-convert": "^2.0.1"
-          }
-        },
-        "ansicolors": {
-          "version": "0.3.2",
-          "bundled": true
-        },
-        "ansistyles": {
-          "version": "0.1.3",
-          "bundled": true
-        },
-        "aproba": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "archy": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "are-we-there-yet": {
-          "version": "1.1.5",
-          "bundled": true,
-          "requires": {
-            "delegates": "^1.0.0",
-            "readable-stream": "^2.0.6"
-          }
-        },
-        "asap": {
-          "version": "2.0.6",
-          "bundled": true
-        },
-        "asn1": {
-          "version": "0.2.4",
-          "bundled": true,
-          "requires": {
-            "safer-buffer": "~2.1.0"
-          }
-        },
-        "assert-plus": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "asynckit": {
-          "version": "0.4.0",
-          "bundled": true
-        },
-        "aws-sign2": {
-          "version": "0.7.0",
-          "bundled": true
-        },
-        "aws4": {
-          "version": "1.11.0",
-          "bundled": true
-        },
-        "balanced-match": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "bcrypt-pbkdf": {
-          "version": "1.0.2",
-          "bundled": true,
-          "requires": {
-            "tweetnacl": "^0.14.3"
-          }
-        },
-        "bin-links": {
-          "version": "2.2.1",
-          "bundled": true,
-          "requires": {
-            "cmd-shim": "^4.0.1",
-            "mkdirp": "^1.0.3",
-            "npm-normalize-package-bin": "^1.0.0",
-            "read-cmd-shim": "^2.0.0",
-            "rimraf": "^3.0.0",
-            "write-file-atomic": "^3.0.3"
-          }
-        },
-        "binary-extensions": {
-          "version": "2.2.0",
-          "bundled": true
-        },
-        "brace-expansion": {
-          "version": "1.1.11",
-          "bundled": true,
-          "requires": {
-            "balanced-match": "^1.0.0",
-            "concat-map": "0.0.1"
-          }
-        },
-        "builtins": {
-          "version": "1.0.3",
-          "bundled": true
-        },
-        "byte-size": {
-          "version": "7.0.1",
-          "bundled": true
-        },
-        "cacache": {
-          "version": "15.0.5",
-          "bundled": true,
-          "requires": {
-            "@npmcli/move-file": "^1.0.1",
-            "chownr": "^2.0.0",
-            "fs-minipass": "^2.0.0",
-            "glob": "^7.1.4",
-            "infer-owner": "^1.0.4",
-            "lru-cache": "^6.0.0",
-            "minipass": "^3.1.1",
-            "minipass-collect": "^1.0.2",
-            "minipass-flush": "^1.0.5",
-            "minipass-pipeline": "^1.2.2",
-            "mkdirp": "^1.0.3",
-            "p-map": "^4.0.0",
-            "promise-inflight": "^1.0.1",
-            "rimraf": "^3.0.2",
-            "ssri": "^8.0.0",
-            "tar": "^6.0.2",
-            "unique-filename": "^1.1.1"
-          }
-        },
-        "caseless": {
-          "version": "0.12.0",
-          "bundled": true
-        },
-        "chalk": {
-          "version": "4.1.0",
-          "bundled": true,
-          "requires": {
-            "ansi-styles": "^4.1.0",
-            "supports-color": "^7.1.0"
-          }
-        },
-        "chownr": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "cidr-regex": {
-          "version": "3.1.1",
-          "bundled": true,
-          "requires": {
-            "ip-regex": "^4.1.0"
-          }
-        },
-        "clean-stack": {
-          "version": "2.2.0",
-          "bundled": true
-        },
-        "cli-columns": {
-          "version": "3.1.2",
-          "bundled": true,
-          "requires": {
-            "string-width": "^2.0.0",
-            "strip-ansi": "^3.0.1"
-          }
-        },
-        "cli-table3": {
-          "version": "0.6.0",
-          "bundled": true,
-          "requires": {
-            "colors": "^1.1.2",
-            "object-assign": "^4.1.0",
-            "string-width": "^4.2.0"
-          },
-          "dependencies": {
-            "ansi-regex": {
-              "version": "5.0.0",
-              "bundled": true
-            },
-            "is-fullwidth-code-point": {
-              "version": "3.0.0",
-              "bundled": true
-            },
-            "string-width": {
-              "version": "4.2.0",
-              "bundled": true,
-              "requires": {
-                "emoji-regex": "^8.0.0",
-                "is-fullwidth-code-point": "^3.0.0",
-                "strip-ansi": "^6.0.0"
-              }
-            },
-            "strip-ansi": {
-              "version": "6.0.0",
-              "bundled": true,
-              "requires": {
-                "ansi-regex": "^5.0.0"
-              }
-            }
-          }
-        },
-        "clone": {
-          "version": "1.0.4",
-          "bundled": true
-        },
-        "cmd-shim": {
-          "version": "4.1.0",
-          "bundled": true,
-          "requires": {
-            "mkdirp-infer-owner": "^2.0.0"
-          }
-        },
-        "code-point-at": {
-          "version": "1.1.0",
-          "bundled": true
-        },
-        "color-convert": {
-          "version": "2.0.1",
-          "bundled": true,
-          "requires": {
-            "color-name": "~1.1.4"
-          }
-        },
-        "color-name": {
-          "version": "1.1.4",
-          "bundled": true
-        },
-        "colors": {
-          "version": "1.4.0",
-          "bundled": true,
-          "optional": true
-        },
-        "columnify": {
-          "version": "1.5.4",
-          "bundled": true,
-          "requires": {
-            "strip-ansi": "^3.0.0",
-            "wcwidth": "^1.0.0"
-          }
-        },
-        "combined-stream": {
-          "version": "1.0.8",
-          "bundled": true,
-          "requires": {
-            "delayed-stream": "~1.0.0"
-          }
-        },
-        "common-ancestor-path": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "concat-map": {
-          "version": "0.0.1",
-          "bundled": true
-        },
-        "console-control-strings": {
-          "version": "1.1.0",
-          "bundled": true
-        },
-        "core-util-is": {
-          "version": "1.0.2",
-          "bundled": true
-        },
-        "dashdash": {
-          "version": "1.14.1",
-          "bundled": true,
-          "requires": {
-            "assert-plus": "^1.0.0"
-          }
-        },
-        "debug": {
-          "version": "4.3.1",
-          "bundled": true,
-          "requires": {
-            "ms": "2.1.2"
-          },
-          "dependencies": {
-            "ms": {
-              "version": "2.1.2",
-              "bundled": true
-            }
-          }
-        },
-        "debuglog": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "defaults": {
-          "version": "1.0.3",
-          "bundled": true,
-          "requires": {
-            "clone": "^1.0.2"
-          }
-        },
-        "delayed-stream": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "delegates": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "depd": {
-          "version": "1.1.2",
-          "bundled": true
-        },
-        "dezalgo": {
-          "version": "1.0.3",
-          "bundled": true,
-          "requires": {
-            "asap": "^2.0.0",
-            "wrappy": "1"
-          }
-        },
-        "diff": {
-          "version": "5.0.0",
-          "bundled": true
-        },
-        "ecc-jsbn": {
-          "version": "0.1.2",
-          "bundled": true,
-          "requires": {
-            "jsbn": "~0.1.0",
-            "safer-buffer": "^2.1.0"
-          }
-        },
-        "emoji-regex": {
-          "version": "8.0.0",
-          "bundled": true
-        },
-        "encoding": {
-          "version": "0.1.13",
-          "bundled": true,
-          "optional": true,
-          "requires": {
-            "iconv-lite": "^0.6.2"
-          }
-        },
-        "env-paths": {
-          "version": "2.2.0",
-          "bundled": true
-        },
-        "err-code": {
-          "version": "2.0.3",
-          "bundled": true
-        },
-        "extend": {
-          "version": "3.0.2",
-          "bundled": true
-        },
-        "extsprintf": {
-          "version": "1.3.0",
-          "bundled": true
-        },
-        "fast-deep-equal": {
-          "version": "3.1.3",
-          "bundled": true
-        },
-        "fast-json-stable-stringify": {
-          "version": "2.1.0",
-          "bundled": true
-        },
-        "forever-agent": {
-          "version": "0.6.1",
-          "bundled": true
-        },
-        "form-data": {
-          "version": "2.3.3",
-          "bundled": true,
-          "requires": {
-            "asynckit": "^0.4.0",
-            "combined-stream": "^1.0.6",
-            "mime-types": "^2.1.12"
-          }
-        },
-        "fs-minipass": {
-          "version": "2.1.0",
-          "bundled": true,
-          "requires": {
-            "minipass": "^3.0.0"
-          }
-        },
-        "fs.realpath": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "function-bind": {
-          "version": "1.1.1",
-          "bundled": true
-        },
-        "gauge": {
-          "version": "2.7.4",
-          "bundled": 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"
-          },
-          "dependencies": {
-            "aproba": {
-              "version": "1.2.0",
-              "bundled": true
-            },
-            "is-fullwidth-code-point": {
-              "version": "1.0.0",
-              "bundled": true,
-              "requires": {
-                "number-is-nan": "^1.0.0"
-              }
-            },
-            "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"
-              }
-            }
-          }
-        },
-        "getpass": {
-          "version": "0.1.7",
-          "bundled": true,
-          "requires": {
-            "assert-plus": "^1.0.0"
-          }
-        },
-        "glob": {
-          "version": "7.1.6",
-          "bundled": 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"
-          }
-        },
-        "graceful-fs": {
-          "version": "4.2.6",
-          "bundled": true
-        },
-        "har-schema": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "har-validator": {
-          "version": "5.1.5",
-          "bundled": true,
-          "requires": {
-            "ajv": "^6.12.3",
-            "har-schema": "^2.0.0"
-          }
-        },
-        "has": {
-          "version": "1.0.3",
-          "bundled": true,
-          "requires": {
-            "function-bind": "^1.1.1"
-          }
-        },
-        "has-flag": {
-          "version": "4.0.0",
-          "bundled": true
-        },
-        "has-unicode": {
-          "version": "2.0.1",
-          "bundled": true
-        },
-        "hosted-git-info": {
-          "version": "3.0.8",
-          "bundled": true,
-          "requires": {
-            "lru-cache": "^6.0.0"
-          }
-        },
-        "http-cache-semantics": {
-          "version": "4.1.0",
-          "bundled": true
-        },
-        "http-proxy-agent": {
-          "version": "4.0.1",
-          "bundled": true,
-          "requires": {
-            "@tootallnate/once": "1",
-            "agent-base": "6",
-            "debug": "4"
-          }
-        },
-        "http-signature": {
-          "version": "1.2.0",
-          "bundled": true,
-          "requires": {
-            "assert-plus": "^1.0.0",
-            "jsprim": "^1.2.2",
-            "sshpk": "^1.7.0"
-          }
-        },
-        "https-proxy-agent": {
-          "version": "5.0.0",
-          "bundled": true,
-          "requires": {
-            "agent-base": "6",
-            "debug": "4"
-          }
-        },
-        "humanize-ms": {
-          "version": "1.2.1",
-          "bundled": true,
-          "requires": {
-            "ms": "^2.0.0"
-          }
-        },
-        "iconv-lite": {
-          "version": "0.6.2",
-          "bundled": true,
-          "optional": true,
-          "requires": {
-            "safer-buffer": ">= 2.1.2 < 3.0.0"
-          }
-        },
-        "ignore-walk": {
-          "version": "3.0.3",
-          "bundled": true,
-          "requires": {
-            "minimatch": "^3.0.4"
-          }
-        },
-        "imurmurhash": {
-          "version": "0.1.4",
-          "bundled": true
-        },
-        "indent-string": {
-          "version": "4.0.0",
-          "bundled": true
-        },
-        "infer-owner": {
-          "version": "1.0.4",
-          "bundled": true
-        },
-        "inflight": {
-          "version": "1.0.6",
-          "bundled": true,
-          "requires": {
-            "once": "^1.3.0",
-            "wrappy": "1"
-          }
-        },
-        "inherits": {
-          "version": "2.0.4",
-          "bundled": true
-        },
-        "ini": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "init-package-json": {
-          "version": "2.0.2",
-          "bundled": true,
-          "requires": {
-            "glob": "^7.1.1",
-            "npm-package-arg": "^8.1.0",
-            "promzard": "^0.3.0",
-            "read": "~1.0.1",
-            "read-package-json": "^3.0.0",
-            "semver": "^7.3.2",
-            "validate-npm-package-license": "^3.0.4",
-            "validate-npm-package-name": "^3.0.0"
-          }
-        },
-        "ip": {
-          "version": "1.1.5",
-          "bundled": true
-        },
-        "ip-regex": {
-          "version": "4.3.0",
-          "bundled": true
-        },
-        "is-cidr": {
-          "version": "4.0.2",
-          "bundled": true,
-          "requires": {
-            "cidr-regex": "^3.1.1"
-          }
-        },
-        "is-core-module": {
-          "version": "2.2.0",
-          "bundled": true,
-          "requires": {
-            "has": "^1.0.3"
-          }
-        },
-        "is-fullwidth-code-point": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "is-lambda": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "is-typedarray": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "isarray": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "isexe": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "isstream": {
-          "version": "0.1.2",
-          "bundled": true
-        },
-        "jsbn": {
-          "version": "0.1.1",
-          "bundled": true
-        },
-        "json-parse-even-better-errors": {
-          "version": "2.3.1",
-          "bundled": true
-        },
-        "json-schema": {
-          "version": "0.2.3",
-          "bundled": true
-        },
-        "json-schema-traverse": {
-          "version": "0.4.1",
-          "bundled": true
-        },
-        "json-stringify-nice": {
-          "version": "1.1.1",
-          "bundled": true
-        },
-        "json-stringify-safe": {
-          "version": "5.0.1",
-          "bundled": true
-        },
-        "jsonparse": {
-          "version": "1.3.1",
-          "bundled": true
-        },
-        "jsprim": {
-          "version": "1.4.1",
-          "bundled": true,
-          "requires": {
-            "assert-plus": "1.0.0",
-            "extsprintf": "1.3.0",
-            "json-schema": "0.2.3",
-            "verror": "1.10.0"
-          }
-        },
-        "just-diff": {
-          "version": "3.0.2",
-          "bundled": true
-        },
-        "just-diff-apply": {
-          "version": "3.0.0",
-          "bundled": true
-        },
-        "leven": {
-          "version": "3.1.0",
-          "bundled": true
-        },
-        "libnpmaccess": {
-          "version": "4.0.1",
-          "bundled": true,
-          "requires": {
-            "aproba": "^2.0.0",
-            "minipass": "^3.1.1",
-            "npm-package-arg": "^8.0.0",
-            "npm-registry-fetch": "^9.0.0"
-          }
-        },
-        "libnpmdiff": {
-          "version": "2.0.4",
-          "bundled": true,
-          "requires": {
-            "@npmcli/disparity-colors": "^1.0.1",
-            "@npmcli/installed-package-contents": "^1.0.7",
-            "binary-extensions": "^2.2.0",
-            "diff": "^5.0.0",
-            "minimatch": "^3.0.4",
-            "npm-package-arg": "^8.1.1",
-            "pacote": "^11.3.0",
-            "tar": "^6.1.0"
-          }
-        },
-        "libnpmfund": {
-          "version": "1.0.2",
-          "bundled": true,
-          "requires": {
-            "@npmcli/arborist": "^2.0.0"
-          }
-        },
-        "libnpmhook": {
-          "version": "6.0.1",
-          "bundled": true,
-          "requires": {
-            "aproba": "^2.0.0",
-            "npm-registry-fetch": "^9.0.0"
-          }
-        },
-        "libnpmorg": {
-          "version": "2.0.1",
-          "bundled": true,
-          "requires": {
-            "aproba": "^2.0.0",
-            "npm-registry-fetch": "^9.0.0"
-          }
-        },
-        "libnpmpack": {
-          "version": "2.0.1",
-          "bundled": true,
-          "requires": {
-            "@npmcli/run-script": "^1.8.3",
-            "npm-package-arg": "^8.1.0",
-            "pacote": "^11.2.6"
-          }
-        },
-        "libnpmpublish": {
-          "version": "4.0.0",
-          "bundled": true,
-          "requires": {
-            "normalize-package-data": "^3.0.0",
-            "npm-package-arg": "^8.1.0",
-            "npm-registry-fetch": "^9.0.0",
-            "semver": "^7.1.3",
-            "ssri": "^8.0.0"
-          }
-        },
-        "libnpmsearch": {
-          "version": "3.1.0",
-          "bundled": true,
-          "requires": {
-            "npm-registry-fetch": "^9.0.0"
-          }
-        },
-        "libnpmteam": {
-          "version": "2.0.2",
-          "bundled": true,
-          "requires": {
-            "aproba": "^2.0.0",
-            "npm-registry-fetch": "^9.0.0"
-          }
-        },
-        "libnpmversion": {
-          "version": "1.0.11",
-          "bundled": true,
-          "requires": {
-            "@npmcli/git": "^2.0.6",
-            "@npmcli/run-script": "^1.8.3",
-            "read-package-json-fast": "^2.0.1",
-            "semver": "^7.3.4",
-            "stringify-package": "^1.0.1"
-          }
-        },
-        "lru-cache": {
-          "version": "6.0.0",
-          "bundled": true,
-          "requires": {
-            "yallist": "^4.0.0"
-          }
-        },
-        "make-fetch-happen": {
-          "version": "8.0.14",
-          "bundled": true,
-          "requires": {
-            "agentkeepalive": "^4.1.3",
-            "cacache": "^15.0.5",
-            "http-cache-semantics": "^4.1.0",
-            "http-proxy-agent": "^4.0.1",
-            "https-proxy-agent": "^5.0.0",
-            "is-lambda": "^1.0.1",
-            "lru-cache": "^6.0.0",
-            "minipass": "^3.1.3",
-            "minipass-collect": "^1.0.2",
-            "minipass-fetch": "^1.3.2",
-            "minipass-flush": "^1.0.5",
-            "minipass-pipeline": "^1.2.4",
-            "promise-retry": "^2.0.1",
-            "socks-proxy-agent": "^5.0.0",
-            "ssri": "^8.0.0"
-          }
-        },
-        "mime-db": {
-          "version": "1.45.0",
-          "bundled": true
-        },
-        "mime-types": {
-          "version": "2.1.28",
-          "bundled": true,
-          "requires": {
-            "mime-db": "1.45.0"
-          }
-        },
-        "minimatch": {
-          "version": "3.0.4",
-          "bundled": true,
-          "requires": {
-            "brace-expansion": "^1.1.7"
-          }
-        },
-        "minipass": {
-          "version": "3.1.3",
-          "bundled": true,
-          "requires": {
-            "yallist": "^4.0.0"
-          }
-        },
-        "minipass-collect": {
-          "version": "1.0.2",
-          "bundled": true,
-          "requires": {
-            "minipass": "^3.0.0"
-          }
-        },
-        "minipass-fetch": {
-          "version": "1.3.3",
-          "bundled": true,
-          "requires": {
-            "encoding": "^0.1.12",
-            "minipass": "^3.1.0",
-            "minipass-sized": "^1.0.3",
-            "minizlib": "^2.0.0"
-          }
-        },
-        "minipass-flush": {
-          "version": "1.0.5",
-          "bundled": true,
-          "requires": {
-            "minipass": "^3.0.0"
-          }
-        },
-        "minipass-json-stream": {
-          "version": "1.0.1",
-          "bundled": true,
-          "requires": {
-            "jsonparse": "^1.3.1",
-            "minipass": "^3.0.0"
-          }
-        },
-        "minipass-pipeline": {
-          "version": "1.2.4",
-          "bundled": true,
-          "requires": {
-            "minipass": "^3.0.0"
-          }
-        },
-        "minipass-sized": {
-          "version": "1.0.3",
-          "bundled": true,
-          "requires": {
-            "minipass": "^3.0.0"
-          }
-        },
-        "minizlib": {
-          "version": "2.1.2",
-          "bundled": true,
-          "requires": {
-            "minipass": "^3.0.0",
-            "yallist": "^4.0.0"
-          }
-        },
-        "mkdirp": {
-          "version": "1.0.4",
-          "bundled": true
-        },
-        "mkdirp-infer-owner": {
-          "version": "2.0.0",
-          "bundled": true,
-          "requires": {
-            "chownr": "^2.0.0",
-            "infer-owner": "^1.0.4",
-            "mkdirp": "^1.0.3"
-          }
-        },
-        "ms": {
-          "version": "2.1.3",
-          "bundled": true
-        },
-        "mute-stream": {
-          "version": "0.0.8",
-          "bundled": true
-        },
-        "node-gyp": {
-          "version": "7.1.2",
-          "bundled": true,
-          "requires": {
-            "env-paths": "^2.2.0",
-            "glob": "^7.1.4",
-            "graceful-fs": "^4.2.3",
-            "nopt": "^5.0.0",
-            "npmlog": "^4.1.2",
-            "request": "^2.88.2",
-            "rimraf": "^3.0.2",
-            "semver": "^7.3.2",
-            "tar": "^6.0.2",
-            "which": "^2.0.2"
-          }
-        },
-        "nopt": {
-          "version": "5.0.0",
-          "bundled": true,
-          "requires": {
-            "abbrev": "1"
-          }
-        },
-        "normalize-package-data": {
-          "version": "3.0.0",
-          "bundled": true,
-          "requires": {
-            "hosted-git-info": "^3.0.6",
-            "resolve": "^1.17.0",
-            "semver": "^7.3.2",
-            "validate-npm-package-license": "^3.0.1"
-          }
-        },
-        "npm-audit-report": {
-          "version": "2.1.4",
-          "bundled": true,
-          "requires": {
-            "chalk": "^4.0.0"
-          }
-        },
-        "npm-bundled": {
-          "version": "1.1.1",
-          "bundled": true,
-          "requires": {
-            "npm-normalize-package-bin": "^1.0.1"
-          }
-        },
-        "npm-install-checks": {
-          "version": "4.0.0",
-          "bundled": true,
-          "requires": {
-            "semver": "^7.1.1"
-          }
-        },
-        "npm-normalize-package-bin": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "npm-package-arg": {
-          "version": "8.1.1",
-          "bundled": true,
-          "requires": {
-            "hosted-git-info": "^3.0.6",
-            "semver": "^7.0.0",
-            "validate-npm-package-name": "^3.0.0"
-          }
-        },
-        "npm-packlist": {
-          "version": "2.1.4",
-          "bundled": true,
-          "requires": {
-            "glob": "^7.1.6",
-            "ignore-walk": "^3.0.3",
-            "npm-bundled": "^1.1.1",
-            "npm-normalize-package-bin": "^1.0.1"
-          }
-        },
-        "npm-pick-manifest": {
-          "version": "6.1.0",
-          "bundled": true,
-          "requires": {
-            "npm-install-checks": "^4.0.0",
-            "npm-package-arg": "^8.0.0",
-            "semver": "^7.0.0"
-          }
-        },
-        "npm-profile": {
-          "version": "5.0.2",
-          "bundled": true,
-          "requires": {
-            "npm-registry-fetch": "^9.0.0"
-          }
-        },
-        "npm-registry-fetch": {
-          "version": "9.0.0",
-          "bundled": true,
-          "requires": {
-            "@npmcli/ci-detect": "^1.0.0",
-            "lru-cache": "^6.0.0",
-            "make-fetch-happen": "^8.0.9",
-            "minipass": "^3.1.3",
-            "minipass-fetch": "^1.3.0",
-            "minipass-json-stream": "^1.0.1",
-            "minizlib": "^2.0.0",
-            "npm-package-arg": "^8.0.0"
-          }
-        },
-        "npm-user-validate": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "npmlog": {
-          "version": "4.1.2",
-          "bundled": 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
-        },
-        "oauth-sign": {
-          "version": "0.9.0",
-          "bundled": true
-        },
-        "object-assign": {
-          "version": "4.1.1",
-          "bundled": true
-        },
-        "once": {
-          "version": "1.4.0",
-          "bundled": true,
-          "requires": {
-            "wrappy": "1"
-          }
-        },
-        "opener": {
-          "version": "1.5.2",
-          "bundled": true
-        },
-        "p-map": {
-          "version": "4.0.0",
-          "bundled": true,
-          "requires": {
-            "aggregate-error": "^3.0.0"
-          }
-        },
-        "pacote": {
-          "version": "11.3.0",
-          "bundled": true,
-          "requires": {
-            "@npmcli/git": "^2.0.1",
-            "@npmcli/installed-package-contents": "^1.0.6",
-            "@npmcli/promise-spawn": "^1.2.0",
-            "@npmcli/run-script": "^1.8.2",
-            "cacache": "^15.0.5",
-            "chownr": "^2.0.0",
-            "fs-minipass": "^2.1.0",
-            "infer-owner": "^1.0.4",
-            "minipass": "^3.1.3",
-            "mkdirp": "^1.0.3",
-            "npm-package-arg": "^8.0.1",
-            "npm-packlist": "^2.1.4",
-            "npm-pick-manifest": "^6.0.0",
-            "npm-registry-fetch": "^9.0.0",
-            "promise-retry": "^2.0.1",
-            "read-package-json-fast": "^2.0.1",
-            "rimraf": "^3.0.2",
-            "ssri": "^8.0.1",
-            "tar": "^6.1.0"
-          }
-        },
-        "parse-conflict-json": {
-          "version": "1.1.1",
-          "bundled": true,
-          "requires": {
-            "json-parse-even-better-errors": "^2.3.0",
-            "just-diff": "^3.0.1",
-            "just-diff-apply": "^3.0.0"
-          }
-        },
-        "path-is-absolute": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "path-parse": {
-          "version": "1.0.6",
-          "bundled": true
-        },
-        "performance-now": {
-          "version": "2.1.0",
-          "bundled": true
-        },
-        "process-nextick-args": {
-          "version": "2.0.1",
-          "bundled": true
-        },
-        "promise-all-reject-late": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "promise-call-limit": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "promise-inflight": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "promise-retry": {
-          "version": "2.0.1",
-          "bundled": true,
-          "requires": {
-            "err-code": "^2.0.2",
-            "retry": "^0.12.0"
-          }
-        },
-        "promzard": {
-          "version": "0.3.0",
-          "bundled": true,
-          "requires": {
-            "read": "1"
-          }
-        },
-        "psl": {
-          "version": "1.8.0",
-          "bundled": true
-        },
-        "puka": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "punycode": {
-          "version": "2.1.1",
-          "bundled": true
-        },
-        "qrcode-terminal": {
-          "version": "0.12.0",
-          "bundled": true
-        },
-        "qs": {
-          "version": "6.5.2",
-          "bundled": true
-        },
-        "read": {
-          "version": "1.0.7",
-          "bundled": true,
-          "requires": {
-            "mute-stream": "~0.0.4"
-          }
-        },
-        "read-cmd-shim": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "read-package-json": {
-          "version": "3.0.1",
-          "bundled": true,
-          "requires": {
-            "glob": "^7.1.1",
-            "json-parse-even-better-errors": "^2.3.0",
-            "normalize-package-data": "^3.0.0",
-            "npm-normalize-package-bin": "^1.0.0"
-          }
-        },
-        "read-package-json-fast": {
-          "version": "2.0.2",
-          "bundled": true,
-          "requires": {
-            "json-parse-even-better-errors": "^2.3.0",
-            "npm-normalize-package-bin": "^1.0.1"
-          }
-        },
-        "readable-stream": {
-          "version": "2.3.7",
-          "bundled": 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"
-          }
-        },
-        "readdir-scoped-modules": {
-          "version": "1.1.0",
-          "bundled": true,
-          "requires": {
-            "debuglog": "^1.0.1",
-            "dezalgo": "^1.0.0",
-            "graceful-fs": "^4.1.2",
-            "once": "^1.3.0"
-          }
-        },
-        "request": {
-          "version": "2.88.2",
-          "bundled": true,
-          "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.3",
-            "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.5.0",
-            "tunnel-agent": "^0.6.0",
-            "uuid": "^3.3.2"
-          },
-          "dependencies": {
-            "tough-cookie": {
-              "version": "2.5.0",
-              "bundled": true,
-              "requires": {
-                "psl": "^1.1.28",
-                "punycode": "^2.1.1"
-              }
-            }
-          }
-        },
-        "resolve": {
-          "version": "1.20.0",
-          "bundled": true,
-          "requires": {
-            "is-core-module": "^2.2.0",
-            "path-parse": "^1.0.6"
-          }
-        },
-        "retry": {
-          "version": "0.12.0",
-          "bundled": true
-        },
-        "rimraf": {
-          "version": "3.0.2",
-          "bundled": true,
-          "requires": {
-            "glob": "^7.1.3"
-          }
-        },
-        "safe-buffer": {
-          "version": "5.1.2",
-          "bundled": true
-        },
-        "safer-buffer": {
-          "version": "2.1.2",
-          "bundled": true
-        },
-        "semver": {
-          "version": "7.3.4",
-          "bundled": true,
-          "requires": {
-            "lru-cache": "^6.0.0"
-          }
-        },
-        "set-blocking": {
-          "version": "2.0.0",
-          "bundled": true
-        },
-        "signal-exit": {
-          "version": "3.0.3",
-          "bundled": true
-        },
-        "smart-buffer": {
-          "version": "4.1.0",
-          "bundled": true
-        },
-        "socks": {
-          "version": "2.5.1",
-          "bundled": true,
-          "requires": {
-            "ip": "^1.1.5",
-            "smart-buffer": "^4.1.0"
-          }
-        },
-        "socks-proxy-agent": {
-          "version": "5.0.0",
-          "bundled": true,
-          "requires": {
-            "agent-base": "6",
-            "debug": "4",
-            "socks": "^2.3.3"
-          }
-        },
-        "spdx-correct": {
-          "version": "3.1.1",
-          "bundled": true,
-          "requires": {
-            "spdx-expression-parse": "^3.0.0",
-            "spdx-license-ids": "^3.0.0"
-          }
-        },
-        "spdx-exceptions": {
-          "version": "2.3.0",
-          "bundled": true
-        },
-        "spdx-expression-parse": {
-          "version": "3.0.1",
-          "bundled": true,
-          "requires": {
-            "spdx-exceptions": "^2.1.0",
-            "spdx-license-ids": "^3.0.0"
-          }
-        },
-        "spdx-license-ids": {
-          "version": "3.0.7",
-          "bundled": true
-        },
-        "sshpk": {
-          "version": "1.16.1",
-          "bundled": true,
-          "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": "8.0.1",
-          "bundled": true,
-          "requires": {
-            "minipass": "^3.1.1"
-          }
-        },
-        "string-width": {
-          "version": "2.1.1",
-          "bundled": true,
-          "requires": {
-            "is-fullwidth-code-point": "^2.0.0",
-            "strip-ansi": "^4.0.0"
-          },
-          "dependencies": {
-            "ansi-regex": {
-              "version": "3.0.0",
-              "bundled": true
-            },
-            "strip-ansi": {
-              "version": "4.0.0",
-              "bundled": true,
-              "requires": {
-                "ansi-regex": "^3.0.0"
-              }
-            }
-          }
-        },
-        "string_decoder": {
-          "version": "1.1.1",
-          "bundled": true,
-          "requires": {
-            "safe-buffer": "~5.1.0"
-          }
-        },
-        "stringify-package": {
-          "version": "1.0.1",
-          "bundled": true
-        },
-        "strip-ansi": {
-          "version": "3.0.1",
-          "bundled": true,
-          "requires": {
-            "ansi-regex": "^2.0.0"
-          }
-        },
-        "supports-color": {
-          "version": "7.2.0",
-          "bundled": true,
-          "requires": {
-            "has-flag": "^4.0.0"
-          }
-        },
-        "tar": {
-          "version": "6.1.0",
-          "bundled": true,
-          "requires": {
-            "chownr": "^2.0.0",
-            "fs-minipass": "^2.0.0",
-            "minipass": "^3.0.0",
-            "minizlib": "^2.1.1",
-            "mkdirp": "^1.0.3",
-            "yallist": "^4.0.0"
-          }
-        },
-        "text-table": {
-          "version": "0.2.0",
-          "bundled": true
-        },
-        "tiny-relative-date": {
-          "version": "1.3.0",
-          "bundled": true
-        },
-        "treeverse": {
-          "version": "1.0.4",
-          "bundled": true
-        },
-        "tunnel-agent": {
-          "version": "0.6.0",
-          "bundled": true,
-          "requires": {
-            "safe-buffer": "^5.0.1"
-          }
-        },
-        "tweetnacl": {
-          "version": "0.14.5",
-          "bundled": true
-        },
-        "typedarray-to-buffer": {
-          "version": "3.1.5",
-          "bundled": true,
-          "requires": {
-            "is-typedarray": "^1.0.0"
-          }
-        },
-        "unique-filename": {
-          "version": "1.1.1",
-          "bundled": true,
-          "requires": {
-            "unique-slug": "^2.0.0"
-          }
-        },
-        "unique-slug": {
-          "version": "2.0.2",
-          "bundled": true,
-          "requires": {
-            "imurmurhash": "^0.1.4"
-          }
-        },
-        "uri-js": {
-          "version": "4.4.1",
-          "bundled": true,
-          "requires": {
-            "punycode": "^2.1.0"
-          }
-        },
-        "util-deprecate": {
-          "version": "1.0.2",
-          "bundled": true
-        },
-        "uuid": {
-          "version": "3.4.0",
-          "bundled": true
-        },
-        "validate-npm-package-license": {
-          "version": "3.0.4",
-          "bundled": true,
-          "requires": {
-            "spdx-correct": "^3.0.0",
-            "spdx-expression-parse": "^3.0.0"
-          }
-        },
-        "validate-npm-package-name": {
-          "version": "3.0.0",
-          "bundled": true,
-          "requires": {
-            "builtins": "^1.0.3"
-          }
-        },
-        "verror": {
-          "version": "1.10.0",
-          "bundled": true,
-          "requires": {
-            "assert-plus": "^1.0.0",
-            "core-util-is": "1.0.2",
-            "extsprintf": "^1.2.0"
-          }
-        },
-        "walk-up-path": {
-          "version": "1.0.0",
-          "bundled": true
-        },
-        "wcwidth": {
-          "version": "1.0.1",
-          "bundled": true,
-          "requires": {
-            "defaults": "^1.0.3"
-          }
-        },
-        "which": {
-          "version": "2.0.2",
-          "bundled": true,
-          "requires": {
-            "isexe": "^2.0.0"
-          }
-        },
-        "wide-align": {
-          "version": "1.1.3",
-          "bundled": true,
-          "requires": {
-            "string-width": "^1.0.2 || 2"
-          }
-        },
-        "wrappy": {
-          "version": "1.0.2",
-          "bundled": true
-        },
-        "write-file-atomic": {
-          "version": "3.0.3",
-          "bundled": true,
-          "requires": {
-            "imurmurhash": "^0.1.4",
-            "is-typedarray": "^1.0.0",
-            "signal-exit": "^3.0.2",
-            "typedarray-to-buffer": "^3.1.5"
-          }
-        },
-        "yallist": {
-          "version": "4.0.0",
-          "bundled": true
+          "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+          "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
         }
       }
     },
+    "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"
+      }
+    },
+    "node-releases": {
+      "version": "1.1.58",
+      "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.58.tgz",
+      "integrity": "sha512-NxBudgVKiRh/2aPWMgPR7bPTX0VPmGx5QBwCtdHitnqFE5/O8DeBXuIMH1nwNnw/aMo6AjOrpsHzfY3UbUJ7yg=="
+    },
+    "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"
+      }
+    },
+    "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-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=="
+    },
     "npm-run-path": {
       "version": "2.0.2",
       "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz",
@@ -13399,11 +11022,6 @@
         "wrappy": "1"
       }
     },
-    "one-time": {
-      "version": "0.0.4",
-      "resolved": "https://registry.npmjs.org/one-time/-/one-time-0.0.4.tgz",
-      "integrity": "sha1-+M33eISCb+Tf+T46nMN7HkSAdC4="
-    },
     "onetime": {
       "version": "2.0.1",
       "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz",
@@ -13412,6 +11030,27 @@
         "mimic-fn": "^1.0.0"
       }
     },
+    "open": {
+      "version": "7.4.2",
+      "resolved": "https://registry.npmjs.org/open/-/open-7.4.2.tgz",
+      "integrity": "sha512-MVHddDVweXZF3awtlAS+6pgKLlm/JgxZ90+/NBurBoQctVOOB/zDdVjcyPzQ+0laDGbsWgrRkflI65sQeOgT9Q==",
+      "dev": true,
+      "requires": {
+        "is-docker": "^2.0.0",
+        "is-wsl": "^2.1.1"
+      },
+      "dependencies": {
+        "is-wsl": {
+          "version": "2.2.0",
+          "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz",
+          "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==",
+          "dev": true,
+          "requires": {
+            "is-docker": "^2.0.0"
+          }
+        }
+      }
+    },
     "opn": {
       "version": "5.4.0",
       "resolved": "https://registry.npmjs.org/opn/-/opn-5.4.0.tgz",
@@ -13600,17 +11239,6 @@
         "is-glob": "^2.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"
-      }
-    },
     "parse5": {
       "version": "4.0.0",
       "resolved": "https://registry.npmjs.org/parse5/-/parse5-4.0.0.tgz",
@@ -13676,11 +11304,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=="
-    },
     "pbkdf2": {
       "version": "3.1.1",
       "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.1.1.tgz",
@@ -16237,11 +13860,6 @@
       "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz",
       "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM="
     },
-    "promised-io": {
-      "version": "0.3.6",
-      "resolved": "https://registry.npmjs.org/promised-io/-/promised-io-0.3.6.tgz",
-      "integrity": "sha512-bNwZusuNIW4m0SPR8jooSyndD35ggirHlxVl/UhIaZD/F0OBv9ebfc6tNmbpZts3QXHggkjIBH8lvtnzhtcz0A=="
-    },
     "prompts": {
       "version": "0.1.14",
       "resolved": "https://registry.npmjs.org/prompts/-/prompts-0.1.14.tgz",
@@ -16399,494 +14017,37 @@
       }
     },
     "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=="
-        }
-      }
-    },
-    "rc-align": {
-      "version": "4.0.9",
-      "resolved": "https://registry.npmjs.org/rc-align/-/rc-align-4.0.9.tgz",
-      "integrity": "sha512-myAM2R4qoB6LqBul0leaqY8gFaiECDJ3MtQDmzDo9xM9NRT/04TvWOYd2YHU9zvGzqk9QXF6S9/MifzSKDZeMw==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "2.x",
-        "dom-align": "^1.7.0",
-        "rc-util": "^5.3.0",
-        "resize-observer-polyfill": "^1.5.1"
-      }
-    },
-    "rc-cascader": {
-      "version": "1.4.2",
-      "resolved": "https://registry.npmjs.org/rc-cascader/-/rc-cascader-1.4.2.tgz",
-      "integrity": "sha512-JVuLGrSi+3G8DZyPvlKlGVWJjhoi9NTz6REHIgRspa5WnznRkKGm2ejb0jJtz0m2IL8Q9BG4ZA2sXuqAu71ltQ==",
-      "requires": {
-        "@babel/runtime": "^7.12.5",
-        "array-tree-filter": "^2.1.0",
-        "rc-trigger": "^5.0.4",
-        "rc-util": "^5.0.1",
-        "warning": "^4.0.1"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "rc-checkbox": {
-      "version": "2.3.2",
-      "resolved": "https://registry.npmjs.org/rc-checkbox/-/rc-checkbox-2.3.2.tgz",
-      "integrity": "sha512-afVi1FYiGv1U0JlpNH/UaEXdh6WUJjcWokj/nUN2TgG80bfG+MDdbfHKlLcNNba94mbjy2/SXJ1HDgrOkXGAjg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.1"
-      }
-    },
-    "rc-collapse": {
-      "version": "3.1.0",
-      "resolved": "https://registry.npmjs.org/rc-collapse/-/rc-collapse-3.1.0.tgz",
-      "integrity": "sha512-EwpNPJcLe7b+5JfyaxM9ZNnkCgqArt3QQO0Cr5p5plwz/C9h8liAmjYY5I4+hl9lAjBqb7ZwLu94+z+rt5g1WQ==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "2.x",
-        "rc-motion": "^2.3.4",
-        "rc-util": "^5.2.1",
-        "shallowequal": "^1.1.0"
-      }
-    },
-    "rc-dialog": {
-      "version": "8.5.2",
-      "resolved": "https://registry.npmjs.org/rc-dialog/-/rc-dialog-8.5.2.tgz",
-      "integrity": "sha512-3n4taFcjqhTE9uNuzjB+nPDeqgRBTEGBfe46mb1e7r88DgDo0lL4NnxY/PZ6PJKd2tsCt+RrgF/+YeTvJ/Thsw==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.6",
-        "rc-motion": "^2.3.0",
-        "rc-util": "^5.6.1"
-      }
-    },
-    "rc-drawer": {
-      "version": "4.3.1",
-      "resolved": "https://registry.npmjs.org/rc-drawer/-/rc-drawer-4.3.1.tgz",
-      "integrity": "sha512-GMfFy4maqxS9faYXEhQ+0cA1xtkddEQzraf6SAdzWbn444DrrLogwYPk1NXSpdXjLCLxgxOj9MYtyYG42JsfXg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.6",
-        "rc-util": "^5.7.0"
-      }
-    },
-    "rc-dropdown": {
-      "version": "3.2.0",
-      "resolved": "https://registry.npmjs.org/rc-dropdown/-/rc-dropdown-3.2.0.tgz",
-      "integrity": "sha512-j1HSw+/QqlhxyTEF6BArVZnTmezw2LnSmRk6I9W7BCqNCKaRwleRmMMs1PHbuaG8dKHVqP6e21RQ7vPBLVnnNw==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.6",
-        "rc-trigger": "^5.0.4"
-      }
-    },
-    "rc-field-form": {
-      "version": "1.19.0",
-      "resolved": "https://registry.npmjs.org/rc-field-form/-/rc-field-form-1.19.0.tgz",
-      "integrity": "sha512-FZFyE6FmhR4xGO3MVo86J2sHIM6t/W4UqN94nVqZC/9PLhzSaKuM0i9UfwFMtuENP2hxFANEQZMBrD/2Zd43pg==",
-      "requires": {
-        "@babel/runtime": "^7.8.4",
-        "async-validator": "^3.0.3",
-        "rc-util": "^5.8.0"
-      }
-    },
-    "rc-image": {
-      "version": "5.2.3",
-      "resolved": "https://registry.npmjs.org/rc-image/-/rc-image-5.2.3.tgz",
-      "integrity": "sha512-8qWNerW1rN0s4zAF6oEa+Zm7UzM+PwTxbGdufvnR3Gcp2M0bcfoEPk9V+RgTxmzGNNELxmrMHloPL4LV5BZu3Q==",
-      "requires": {
-        "@babel/runtime": "^7.11.2",
-        "classnames": "^2.2.6",
-        "rc-dialog": "~8.5.0",
-        "rc-util": "^5.0.6"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "rc-input-number": {
-      "version": "7.0.1",
-      "resolved": "https://registry.npmjs.org/rc-input-number/-/rc-input-number-7.0.1.tgz",
-      "integrity": "sha512-LOPEwhEjkJzDd+0mOMNZdRKjEsZJOXVxmNr3sfiONu9PUCRf366GDlARh+AcSd/jWvFzEa070wpr2gg0i/5BfQ==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.5",
-        "rc-util": "^5.0.1"
-      }
-    },
-    "rc-mentions": {
-      "version": "1.5.3",
-      "resolved": "https://registry.npmjs.org/rc-mentions/-/rc-mentions-1.5.3.tgz",
-      "integrity": "sha512-NG/KB8YiKBCJPHHvr/QapAb4f9YzLJn7kDHtmI1K6t7ZMM5YgrjIxNNhoRKKP9zJvb9PdPts69Hbg4ZMvLVIFQ==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.6",
-        "rc-menu": "^8.0.1",
-        "rc-textarea": "^0.3.0",
-        "rc-trigger": "^5.0.4",
-        "rc-util": "^5.0.1"
-      }
-    },
-    "rc-menu": {
-      "version": "8.10.6",
-      "resolved": "https://registry.npmjs.org/rc-menu/-/rc-menu-8.10.6.tgz",
-      "integrity": "sha512-RVkd8XChwSmVOdNULbqLNnABthRZWnhqct1Q74onEXTClsXvsLADMhlIJtw/umglVSECM+14TJdIli9rl2Bzlw==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "2.x",
-        "mini-store": "^3.0.1",
-        "rc-motion": "^2.0.1",
-        "rc-trigger": "^5.1.2",
-        "rc-util": "^5.7.0",
-        "resize-observer-polyfill": "^1.5.0",
-        "shallowequal": "^1.1.0"
-      }
-    },
-    "rc-motion": {
-      "version": "2.4.1",
-      "resolved": "https://registry.npmjs.org/rc-motion/-/rc-motion-2.4.1.tgz",
-      "integrity": "sha512-TWLvymfMu8SngPx5MDH8dQ0D2RYbluNTfam4hY/dNNx9RQ3WtGuZ/GXHi2ymLMzH+UNd6EEFYkOuR5JTTtm8Xg==",
-      "requires": {
-        "@babel/runtime": "^7.11.1",
-        "classnames": "^2.2.1",
-        "rc-util": "^5.2.1"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "rc-notification": {
-      "version": "4.5.5",
-      "resolved": "https://registry.npmjs.org/rc-notification/-/rc-notification-4.5.5.tgz",
-      "integrity": "sha512-YIfhTSw+h5GsSdgMnuMx24wqiPlg3FeamuOlkh9RkyHx+SeZVAKzQ0juy2NGvPEF2hDWi5xTqxUqLdo0L2AmGg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "2.x",
-        "rc-motion": "^2.2.0",
-        "rc-util": "^5.0.1"
-      }
-    },
-    "rc-overflow": {
-      "version": "1.0.2",
-      "resolved": "https://registry.npmjs.org/rc-overflow/-/rc-overflow-1.0.2.tgz",
-      "integrity": "sha512-GXj4DAyNxm4f57LvXLwhJaZoJHzSge2l2lQq64MZP7NJAfLpQqOLD+v9JMV9ONTvDPZe8kdzR+UMmkAn7qlzFA==",
-      "requires": {
-        "@babel/runtime": "^7.11.1",
-        "classnames": "^2.2.1",
-        "rc-resize-observer": "^1.0.0",
-        "rc-util": "^5.5.1"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "rc-pagination": {
-      "version": "3.1.4",
-      "resolved": "https://registry.npmjs.org/rc-pagination/-/rc-pagination-3.1.4.tgz",
-      "integrity": "sha512-6nFsNXGfBb6Hh3SNeTHuEaAWiq33PdDA4rdi2Ba2LIri6XUeOCmWLFPUwZyx+NJn+ODGCxsl5BEVcfLbNsxtGg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.1"
-      }
-    },
-    "rc-picker": {
-      "version": "2.5.7",
-      "resolved": "https://registry.npmjs.org/rc-picker/-/rc-picker-2.5.7.tgz",
-      "integrity": "sha512-b5ZWCKds1u4H9fP0EpJ8YUX16VhueK6E7TxgK+rRjpbKwI1bOUy59F/OkUXjdACJdDmbsDMDZogpW7KzoqtzvA==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.1",
-        "date-fns": "^2.15.0",
-        "moment": "^2.24.0",
-        "rc-trigger": "^5.0.4",
-        "rc-util": "^5.4.0",
-        "shallowequal": "^1.1.0"
-      }
-    },
-    "rc-progress": {
-      "version": "3.1.3",
-      "resolved": "https://registry.npmjs.org/rc-progress/-/rc-progress-3.1.3.tgz",
-      "integrity": "sha512-Jl4fzbBExHYMoC6HBPzel0a9VmhcSXx24LVt/mdhDM90MuzoMCJjXZAlhA0V0CJi+SKjMhfBoIQ6Lla1nD4QNw==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.6"
-      }
-    },
-    "rc-rate": {
-      "version": "2.9.1",
-      "resolved": "https://registry.npmjs.org/rc-rate/-/rc-rate-2.9.1.tgz",
-      "integrity": "sha512-MmIU7FT8W4LYRRHJD1sgG366qKtSaKb67D0/vVvJYR0lrCuRrCiVQ5qhfT5ghVO4wuVIORGpZs7ZKaYu+KMUzA==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.5",
-        "rc-util": "^5.0.1"
-      }
-    },
-    "rc-resize-observer": {
-      "version": "1.0.0",
-      "resolved": "https://registry.npmjs.org/rc-resize-observer/-/rc-resize-observer-1.0.0.tgz",
-      "integrity": "sha512-RgKGukg1mlzyGdvzF7o/LGFC8AeoMH9aGzXTUdp6m+OApvmRdUuOscq/Y2O45cJA+rXt1ApWlpFoOIioXL3AGg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.1",
-        "rc-util": "^5.0.0",
-        "resize-observer-polyfill": "^1.5.1"
-      }
-    },
-    "rc-select": {
-      "version": "12.1.5",
-      "resolved": "https://registry.npmjs.org/rc-select/-/rc-select-12.1.5.tgz",
-      "integrity": "sha512-UElTMw0+XvYJmVfsHTWvLR42RKNf5qyN3Ed/JfuZQceIPK1/3ugGRjdEOKBsPmPyNB5389NAROCV4tQd9fmqwg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "2.x",
-        "rc-motion": "^2.0.1",
-        "rc-overflow": "^1.0.0",
-        "rc-trigger": "^5.0.4",
-        "rc-util": "^5.0.1",
-        "rc-virtual-list": "^3.2.0"
-      }
-    },
-    "rc-slider": {
-      "version": "9.7.1",
-      "resolved": "https://registry.npmjs.org/rc-slider/-/rc-slider-9.7.1.tgz",
-      "integrity": "sha512-r9r0dpFA3PEvxBhIfVi1lVzxuSogWxeY+tGvi2AqMM1rPgaOXQ7WbtT+9kVFkJ9K8TntA/vYPgiCCKfN29KTkw==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.5",
-        "rc-tooltip": "^5.0.1",
-        "rc-util": "^5.0.0",
-        "shallowequal": "^1.1.0"
-      }
-    },
-    "rc-steps": {
-      "version": "4.1.3",
-      "resolved": "https://registry.npmjs.org/rc-steps/-/rc-steps-4.1.3.tgz",
-      "integrity": "sha512-GXrMfWQOhN3sVze3JnzNboHpQdNHcdFubOETUHyDpa/U3HEKBZC3xJ8XK4paBgF4OJ3bdUVLC+uBPc6dCxvDYA==",
-      "requires": {
-        "@babel/runtime": "^7.10.2",
-        "classnames": "^2.2.3",
-        "rc-util": "^5.0.1"
-      }
-    },
-    "rc-switch": {
-      "version": "3.2.2",
-      "resolved": "https://registry.npmjs.org/rc-switch/-/rc-switch-3.2.2.tgz",
-      "integrity": "sha512-+gUJClsZZzvAHGy1vZfnwySxj+MjLlGRyXKXScrtCTcmiYNPzxDFOxdQ/3pK1Kt/0POvwJ/6ALOR8gwdXGhs+A==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.1",
-        "rc-util": "^5.0.1"
-      }
-    },
-    "rc-table": {
-      "version": "7.13.1",
-      "resolved": "https://registry.npmjs.org/rc-table/-/rc-table-7.13.1.tgz",
-      "integrity": "sha512-zg2ldSRHj1ENGsSykSKV5axnWkSaaly+wjRcD1Bspx4WHrf3m/I1WYjpVvOeer2e06bfKb6lmkK0HLxQ1cZtsg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.5",
-        "rc-resize-observer": "^1.0.0",
-        "rc-util": "^5.4.0",
-        "shallowequal": "^1.1.0"
-      }
-    },
-    "rc-tabs": {
-      "version": "11.7.3",
-      "resolved": "https://registry.npmjs.org/rc-tabs/-/rc-tabs-11.7.3.tgz",
-      "integrity": "sha512-5nd2NVss9TprPRV9r8N05SjQyAE7zDrLejxFLcbJ+BdLxSwnGnk3ws/Iq0smqKZUnPQC0XEvnpF3+zlllUUT2w==",
-      "requires": {
-        "@babel/runtime": "^7.11.2",
-        "classnames": "2.x",
-        "rc-dropdown": "^3.1.3",
-        "rc-menu": "^8.6.1",
-        "rc-resize-observer": "^1.0.0",
-        "rc-util": "^5.5.0"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "rc-textarea": {
-      "version": "0.3.4",
-      "resolved": "https://registry.npmjs.org/rc-textarea/-/rc-textarea-0.3.4.tgz",
-      "integrity": "sha512-ILUYx831ZukQPv3m7R4RGRtVVWmL1LV4ME03L22mvT56US0DGCJJaRTHs4vmpcSjFHItph5OTmhodY4BOwy81A==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.1",
-        "rc-resize-observer": "^1.0.0",
-        "rc-util": "^5.7.0"
-      }
-    },
-    "rc-tooltip": {
-      "version": "5.1.0",
-      "resolved": "https://registry.npmjs.org/rc-tooltip/-/rc-tooltip-5.1.0.tgz",
-      "integrity": "sha512-pFqD1JZwNIpbdcefB7k5xREoHAWM/k3yQwYF0iminbmDXERgq4rvBfUwIvlCqqZSM7HDr9hYeYr6ZsVNaKtvCQ==",
-      "requires": {
-        "@babel/runtime": "^7.11.2",
-        "rc-trigger": "^5.0.0"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "rc-tree": {
-      "version": "4.1.5",
-      "resolved": "https://registry.npmjs.org/rc-tree/-/rc-tree-4.1.5.tgz",
-      "integrity": "sha512-q2vjcmnBDylGZ9/ZW4F9oZMKMJdbFWC7um+DAQhZG1nqyg1iwoowbBggUDUaUOEryJP+08bpliEAYnzJXbI5xQ==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "2.x",
-        "rc-motion": "^2.0.1",
-        "rc-util": "^5.0.0",
-        "rc-virtual-list": "^3.0.1"
-      }
-    },
-    "rc-tree-select": {
-      "version": "4.3.0",
-      "resolved": "https://registry.npmjs.org/rc-tree-select/-/rc-tree-select-4.3.0.tgz",
-      "integrity": "sha512-EEXB9dKBsJNJuKIU5NERZsaJ71GDGIj5uWLl7A4XiYr2jXM4JICfScvvp3O5jHMDfhqmgpqNc0z90mHkgh3hKg==",
-      "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "2.x",
-        "rc-select": "^12.0.0",
-        "rc-tree": "^4.0.0",
-        "rc-util": "^5.0.5"
-      }
-    },
-    "rc-trigger": {
-      "version": "5.2.3",
-      "resolved": "https://registry.npmjs.org/rc-trigger/-/rc-trigger-5.2.3.tgz",
-      "integrity": "sha512-6Fokao07HUbqKIDkDRFEM0AGZvsvK0Fbp8A/KFgl1ngaqfO1nY037cISCG1Jm5fxImVsXp9awdkP7Vu5cxjjog==",
-      "requires": {
-        "@babel/runtime": "^7.11.2",
-        "classnames": "^2.2.6",
-        "rc-align": "^4.0.0",
-        "rc-motion": "^2.0.0",
-        "rc-util": "^5.5.0"
-      },
-      "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
-        }
-      }
-    },
-    "rc-upload": {
-      "version": "4.0.1",
-      "resolved": "https://registry.npmjs.org/rc-upload/-/rc-upload-4.0.1.tgz",
-      "integrity": "sha512-h7iLt22U0C2ObpqTU7MDoAV/FDwHTUEFjMd6uidA4ipoJ7gP7C74gOQOtl5OPQTVUDATUndnSAt9uyC1znlo9A==",
+      "version": "1.0.4",
+      "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.4.tgz",
+      "integrity": "sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw==",
       "requires": {
-        "@babel/runtime": "^7.10.1",
-        "classnames": "^2.2.5",
-        "rc-util": "^5.2.0"
+        "randombytes": "^2.0.5",
+        "safe-buffer": "^5.1.0"
       }
     },
-    "rc-util": {
-      "version": "5.8.1",
-      "resolved": "https://registry.npmjs.org/rc-util/-/rc-util-5.8.1.tgz",
-      "integrity": "sha512-kXV/QjL+azh3AxMk68gm8+nltVoL6bjeJJULAZLRCLus2Fhvo/aaMZokxYov/E0dbfjo31I78pF4yVljqQB7bA==",
+    "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": {
-        "@babel/runtime": "^7.12.5",
-        "react-is": "^16.12.0",
-        "shallowequal": "^1.1.0"
+        "bytes": "3.1.0",
+        "http-errors": "1.7.2",
+        "iconv-lite": "0.4.24",
+        "unpipe": "1.0.0"
       },
       "dependencies": {
-        "@babel/runtime": {
-          "version": "7.13.10",
-          "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.13.10.tgz",
-          "integrity": "sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw==",
-          "requires": {
-            "regenerator-runtime": "^0.13.4"
-          }
+        "bytes": {
+          "version": "3.1.0",
+          "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz",
+          "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg=="
         }
       }
     },
-    "rc-virtual-list": {
-      "version": "3.2.6",
-      "resolved": "https://registry.npmjs.org/rc-virtual-list/-/rc-virtual-list-3.2.6.tgz",
-      "integrity": "sha512-8FiQLDzm3c/tMX0d62SQtKDhLH7zFlSI6pWBAPt+TUntEqd3Lz9zFAmpvTu8gkvUom/HCsDSZs4wfV4wDPWC0Q==",
-      "requires": {
-        "classnames": "^2.2.6",
-        "rc-resize-observer": "^1.0.0",
-        "rc-util": "^5.0.7"
-      }
-    },
     "react": {
       "version": "16.14.0",
       "resolved": "https://registry.npmjs.org/react/-/react-16.14.0.tgz",
@@ -16916,16 +14077,6 @@
         }
       }
     },
-    "react-cookie": {
-      "version": "4.0.3",
-      "resolved": "https://registry.npmjs.org/react-cookie/-/react-cookie-4.0.3.tgz",
-      "integrity": "sha512-cmi6IpdVgTSvjqssqIEvo779Gfqc4uPGHRrKMEdHcqkmGtPmxolGfsyKj95bhdLEKqMdbX8MLBCwezlnhkHK0g==",
-      "requires": {
-        "@types/hoist-non-react-statics": "^3.0.1",
-        "hoist-non-react-statics": "^3.0.0",
-        "universal-cookie": "^4.0.0"
-      }
-    },
     "react-dev-utils": {
       "version": "8.0.0",
       "resolved": "https://registry.npmjs.org/react-dev-utils/-/react-dev-utils-8.0.0.tgz",
@@ -17083,33 +14234,6 @@
         "scheduler": "^0.19.1"
       }
     },
-    "react-dropdown": {
-      "version": "1.9.2",
-      "resolved": "https://registry.npmjs.org/react-dropdown/-/react-dropdown-1.9.2.tgz",
-      "integrity": "sha512-g4eufErTi5P5T5bGK+VmLl//qvAHy79jm6KKx8G2Tl3mG90bpigb+Aw85P+C2JUdAnIIQdv8kP/oHN314GvAfw==",
-      "requires": {
-        "classnames": "^2.2.3"
-      }
-    },
-    "react-dropdown-select": {
-      "version": "4.7.1",
-      "resolved": "https://registry.npmjs.org/react-dropdown-select/-/react-dropdown-select-4.7.1.tgz",
-      "integrity": "sha512-yoF39vFN+F2TaRK1EXnhiz+8jyv40E7+MRUD/X/UsMr2dnYFWoFMMrTIVXcjVnDCFlU+yAvZYRqb+8b60bUuyw==",
-      "requires": {
-        "@emotion/core": "^10.0.27",
-        "@emotion/styled": "^10.0.27"
-      }
-    },
-    "react-easy-crop": {
-      "version": "2.1.2",
-      "resolved": "https://registry.npmjs.org/react-easy-crop/-/react-easy-crop-2.1.2.tgz",
-      "integrity": "sha512-LHXQFyJVXGMgmjSzX1KMeX1uE/dI26O2608DsrlCDwRKOkaS7Kb6pQjeS30efGfzrRkUD5Qff+ANxhaPO+pVNg==",
-      "requires": {
-        "@emotion/core": "^10.0.27",
-        "@emotion/styled": "^10.0.27",
-        "tslib": "1.11.2"
-      }
-    },
     "react-easy-swipe": {
       "version": "0.0.21",
       "resolved": "https://registry.npmjs.org/react-easy-swipe/-/react-easy-swipe-0.0.21.tgz",
@@ -17133,37 +14257,6 @@
         "warning": "^4.0.1"
       }
     },
-    "react-fine-uploader": {
-      "version": "1.1.1",
-      "resolved": "https://registry.npmjs.org/react-fine-uploader/-/react-fine-uploader-1.1.1.tgz",
-      "integrity": "sha512-aUOZO3Wr8OynK2LyF2QMPHSe6gWSonNyk/hgo6olBRim92T/sa07pcy/sR2ljucrv9IaJC61Qb8ZGGfcs/I82A==",
-      "requires": {
-        "fine-uploader-wrappers": "^1.0.1",
-        "object-assign": "4.1.1",
-        "react-transition-group": "2.x"
-      },
-      "dependencies": {
-        "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"
-          }
-        },
-        "react-transition-group": {
-          "version": "2.9.0",
-          "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-2.9.0.tgz",
-          "integrity": "sha512-+HzNTCHpeQyl4MJ/bdE0u6XRMe9+XG/+aL4mCxVN4DnPBQ0/5bfHWPDuOZUzYdMj94daZaZdCCc1Dzt9R/xSSg==",
-          "requires": {
-            "dom-helpers": "^3.4.0",
-            "loose-envify": "^1.4.0",
-            "prop-types": "^15.6.2",
-            "react-lifecycles-compat": "^3.0.4"
-          }
-        }
-      }
-    },
     "react-google-login": {
       "version": "5.1.25",
       "resolved": "https://registry.npmjs.org/react-google-login/-/react-google-login-5.1.25.tgz",
@@ -17199,30 +14292,11 @@
         "prop-types": "^15.7.2"
       }
     },
-    "react-input-mask": {
-      "version": "2.0.4",
-      "resolved": "https://registry.npmjs.org/react-input-mask/-/react-input-mask-2.0.4.tgz",
-      "integrity": "sha512-1hwzMr/aO9tXfiroiVCx5EtKohKwLk/NT8QlJXHQ4N+yJJFyUuMT+zfTpLBwX/lK3PkuMlievIffncpMZ3HGRQ==",
-      "requires": {
-        "invariant": "^2.2.4",
-        "warning": "^4.0.2"
-      }
-    },
     "react-is": {
       "version": "16.13.1",
       "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz",
       "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="
     },
-    "react-lifecycles-compat": {
-      "version": "3.0.4",
-      "resolved": "https://registry.npmjs.org/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz",
-      "integrity": "sha512-fBASbA6LnOU9dOU2eW7aQ8xmYBSXUIWr+UmF9b1efZBazGNO+rcXT/icdKnYm2pTwcRylVUYwW7H1PHfLekVzA=="
-    },
-    "react-moment": {
-      "version": "1.0.0",
-      "resolved": "https://registry.npmjs.org/react-moment/-/react-moment-1.0.0.tgz",
-      "integrity": "sha512-J4iIiwUT4oZcL7cp2U7naQKbQtqvmzGXXBMg/DLj+Pi7n9EW0VhBRx/1aJ1Tp2poCqTCAPoadLEoUIkReGnNNg=="
-    },
     "react-recaptcha": {
       "version": "2.3.10",
       "resolved": "https://registry.npmjs.org/react-recaptcha/-/react-recaptcha-2.3.10.tgz",
@@ -17375,16 +14449,6 @@
         }
       }
     },
-    "react-star-ratings": {
-      "version": "2.3.0",
-      "resolved": "https://registry.npmjs.org/react-star-ratings/-/react-star-ratings-2.3.0.tgz",
-      "integrity": "sha512-34Z/oFNDRRn4ZcX7F3t9ccnpo7SQ32gD/vsusQOBc6B6vlqaGR6tke1/Yx3jTDjemKRSmXqhKgpPTR7/JAXq6A==",
-      "requires": {
-        "classnames": "^2.2.1",
-        "prop-types": "^15.6.0",
-        "react": "^16.1.0"
-      }
-    },
     "react-swipeable-views": {
       "version": "0.13.9",
       "resolved": "https://registry.npmjs.org/react-swipeable-views/-/react-swipeable-views-0.13.9.tgz",
@@ -17475,15 +14539,6 @@
         "prop-types": "^15.6.2"
       }
     },
-    "react-window": {
-      "version": "1.8.6",
-      "resolved": "https://registry.npmjs.org/react-window/-/react-window-1.8.6.tgz",
-      "integrity": "sha512-8VwEEYyjz6DCnGBsd+MgkD0KJ2/OXFULyDtorIiTz+QzwoP94tBoA7CnbtyXMm+cCeAUER5KJcPtWl9cpKbOBg==",
-      "requires": {
-        "@babel/runtime": "^7.0.0",
-        "memoize-one": ">=3.1.1 <6"
-      }
-    },
     "read-pkg": {
       "version": "1.1.0",
       "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz",
@@ -18100,11 +15155,6 @@
       "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz",
       "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8="
     },
-    "resize-observer-polyfill": {
-      "version": "1.5.1",
-      "resolved": "https://registry.npmjs.org/resize-observer-polyfill/-/resize-observer-polyfill-1.5.1.tgz",
-      "integrity": "sha512-LwZrotdHOo12nQuZlHEmtuXdqGoOD0OhaxopaNFxWzInpEgaLWoVuAMbTzixuosCx2nEG58ngzW3vxdWoxIgdg=="
-    },
     "resolve": {
       "version": "1.17.0",
       "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz",
@@ -18582,14 +15632,6 @@
         "ajv-keywords": "^3.1.0"
       }
     },
-    "scroll-into-view-if-needed": {
-      "version": "2.2.27",
-      "resolved": "https://registry.npmjs.org/scroll-into-view-if-needed/-/scroll-into-view-if-needed-2.2.27.tgz",
-      "integrity": "sha512-BKiRstRm4u1bZvw+Wu9TxXhyMZ9fskb/9fbuSGuRzwHhlbKlDetL4dBdYaPfQbEFTttQmpkNtFH7sQpk4rZf9w==",
-      "requires": {
-        "compute-scroll-into-view": "^1.0.16"
-      }
-    },
     "select-hose": {
       "version": "2.0.0",
       "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz",
@@ -18799,11 +15841,6 @@
       "resolved": "https://registry.npmjs.org/shallow-equal/-/shallow-equal-1.2.1.tgz",
       "integrity": "sha512-S4vJDjHHMBaiZuT9NPb616CSmLf618jawtv3sufLl6ivK8WocjAo58cXwbRV1cgqxH0Qbv+iUt6m05eqEa2IRA=="
     },
-    "shallowequal": {
-      "version": "1.1.0",
-      "resolved": "https://registry.npmjs.org/shallowequal/-/shallowequal-1.1.0.tgz",
-      "integrity": "sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ=="
-    },
     "shebang-command": {
       "version": "1.2.0",
       "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
@@ -19093,6 +16130,191 @@
       "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
       "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w="
     },
+    "source-map-explorer": {
+      "version": "2.5.2",
+      "resolved": "https://registry.npmjs.org/source-map-explorer/-/source-map-explorer-2.5.2.tgz",
+      "integrity": "sha512-gBwOyCcHPHcdLbgw6Y6kgoH1uLKL6hN3zz0xJcNI2lpnElZliIlmSYAjUVwAWnc7+HscoTyh1ScR7ITtFuEnxg==",
+      "dev": true,
+      "requires": {
+        "btoa": "^1.2.1",
+        "chalk": "^4.1.0",
+        "convert-source-map": "^1.7.0",
+        "ejs": "^3.1.5",
+        "escape-html": "^1.0.3",
+        "glob": "^7.1.6",
+        "gzip-size": "^6.0.0",
+        "lodash": "^4.17.20",
+        "open": "^7.3.1",
+        "source-map": "^0.7.3",
+        "temp": "^0.9.4",
+        "yargs": "^16.2.0"
+      },
+      "dependencies": {
+        "ansi-regex": {
+          "version": "5.0.0",
+          "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz",
+          "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==",
+          "dev": true
+        },
+        "ansi-styles": {
+          "version": "4.3.0",
+          "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+          "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+          "dev": true,
+          "requires": {
+            "color-convert": "^2.0.1"
+          }
+        },
+        "chalk": {
+          "version": "4.1.1",
+          "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz",
+          "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==",
+          "dev": true,
+          "requires": {
+            "ansi-styles": "^4.1.0",
+            "supports-color": "^7.1.0"
+          }
+        },
+        "cliui": {
+          "version": "7.0.4",
+          "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz",
+          "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==",
+          "dev": true,
+          "requires": {
+            "string-width": "^4.2.0",
+            "strip-ansi": "^6.0.0",
+            "wrap-ansi": "^7.0.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==",
+          "dev": true,
+          "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==",
+          "dev": true
+        },
+        "duplexer": {
+          "version": "0.1.2",
+          "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz",
+          "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==",
+          "dev": true
+        },
+        "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==",
+          "dev": true
+        },
+        "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==",
+          "dev": true
+        },
+        "gzip-size": {
+          "version": "6.0.0",
+          "resolved": "https://registry.npmjs.org/gzip-size/-/gzip-size-6.0.0.tgz",
+          "integrity": "sha512-ax7ZYomf6jqPTQ4+XCpUGyXKHk5WweS+e05MBO4/y3WJ5RkmPXNKvX+bx1behVILVwr6JSQvZAku021CHPXG3Q==",
+          "dev": true,
+          "requires": {
+            "duplexer": "^0.1.2"
+          }
+        },
+        "has-flag": {
+          "version": "4.0.0",
+          "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+          "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+          "dev": true
+        },
+        "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==",
+          "dev": true
+        },
+        "source-map": {
+          "version": "0.7.3",
+          "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz",
+          "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==",
+          "dev": true
+        },
+        "string-width": {
+          "version": "4.2.2",
+          "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz",
+          "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==",
+          "dev": true,
+          "requires": {
+            "emoji-regex": "^8.0.0",
+            "is-fullwidth-code-point": "^3.0.0",
+            "strip-ansi": "^6.0.0"
+          }
+        },
+        "strip-ansi": {
+          "version": "6.0.0",
+          "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
+          "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
+          "dev": true,
+          "requires": {
+            "ansi-regex": "^5.0.0"
+          }
+        },
+        "supports-color": {
+          "version": "7.2.0",
+          "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+          "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+          "dev": true,
+          "requires": {
+            "has-flag": "^4.0.0"
+          }
+        },
+        "wrap-ansi": {
+          "version": "7.0.0",
+          "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+          "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+          "dev": true,
+          "requires": {
+            "ansi-styles": "^4.0.0",
+            "string-width": "^4.1.0",
+            "strip-ansi": "^6.0.0"
+          }
+        },
+        "y18n": {
+          "version": "5.0.8",
+          "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
+          "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
+          "dev": true
+        },
+        "yargs": {
+          "version": "16.2.0",
+          "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz",
+          "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==",
+          "dev": true,
+          "requires": {
+            "cliui": "^7.0.2",
+            "escalade": "^3.1.1",
+            "get-caller-file": "^2.0.5",
+            "require-directory": "^2.1.1",
+            "string-width": "^4.2.0",
+            "y18n": "^5.0.5",
+            "yargs-parser": "^20.2.2"
+          }
+        },
+        "yargs-parser": {
+          "version": "20.2.9",
+          "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz",
+          "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==",
+          "dev": true
+        }
+      }
+    },
     "source-map-resolve": {
       "version": "0.5.3",
       "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.3.tgz",
@@ -19243,11 +16465,6 @@
       "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz",
       "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w=="
     },
-    "stack-trace": {
-      "version": "0.0.10",
-      "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz",
-      "integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA="
-    },
     "stack-utils": {
       "version": "1.0.2",
       "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.2.tgz",
@@ -19375,11 +16592,6 @@
       "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz",
       "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ=="
     },
-    "string-convert": {
-      "version": "0.2.1",
-      "resolved": "https://registry.npmjs.org/string-convert/-/string-convert-0.2.1.tgz",
-      "integrity": "sha1-aYLMMEn7tM2F+LJFaLnZvznu/5c="
-    },
     "string-length": {
       "version": "2.0.0",
       "resolved": "https://registry.npmjs.org/string-length/-/string-length-2.0.0.tgz",
@@ -19755,6 +16967,16 @@
       "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.3.tgz",
       "integrity": "sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA=="
     },
+    "temp": {
+      "version": "0.9.4",
+      "resolved": "https://registry.npmjs.org/temp/-/temp-0.9.4.tgz",
+      "integrity": "sha512-yYrrsWnrXMcdsnu/7YMYAofM1ktpL5By7vZhf15CrXijWWrEYZks5AXBudalfSWJLlnen/QUJUB5aoB0kqZUGA==",
+      "dev": true,
+      "requires": {
+        "mkdirp": "^0.5.1",
+        "rimraf": "~2.6.2"
+      }
+    },
     "terser": {
       "version": "3.17.0",
       "resolved": "https://registry.npmjs.org/terser/-/terser-3.17.0.tgz",
@@ -19870,11 +17092,6 @@
         "require-main-filename": "^1.0.1"
       }
     },
-    "text-hex": {
-      "version": "1.0.0",
-      "resolved": "https://registry.npmjs.org/text-hex/-/text-hex-1.0.0.tgz",
-      "integrity": "sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg=="
-    },
     "text-table": {
       "version": "0.2.0",
       "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
@@ -19941,11 +17158,6 @@
         "setimmediate": "^1.0.4"
       }
     },
-    "timespan": {
-      "version": "2.3.0",
-      "resolved": "https://registry.npmjs.org/timespan/-/timespan-2.3.0.tgz",
-      "integrity": "sha1-SQLOBAvRPYRcj1myfp1ZutbzmSk="
-    },
     "timsort": {
       "version": "0.3.0",
       "resolved": "https://registry.npmjs.org/timsort/-/timsort-0.3.0.tgz",
@@ -20022,11 +17234,6 @@
         }
       }
     },
-    "toggle-selection": {
-      "version": "1.0.6",
-      "resolved": "https://registry.npmjs.org/toggle-selection/-/toggle-selection-1.0.6.tgz",
-      "integrity": "sha1-bkWxJj8gF/oKzH2J14sVuL932jI="
-    },
     "toidentifier": {
       "version": "1.0.0",
       "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz",
@@ -20062,11 +17269,6 @@
       "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz",
       "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM="
     },
-    "triple-beam": {
-      "version": "1.3.0",
-      "resolved": "https://registry.npmjs.org/triple-beam/-/triple-beam-1.3.0.tgz",
-      "integrity": "sha512-XrHUvV5HpdLmIj4uVMxHggLbFSZYIn7HEWsqePZcI50pco+MPqJ50wMGY794X7AOOhxOBAjbkqfAbEe/QMp2Lw=="
-    },
     "tryer": {
       "version": "1.0.1",
       "resolved": "https://registry.npmjs.org/tryer/-/tryer-1.0.1.tgz",
@@ -20122,16 +17324,6 @@
       "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz",
       "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c="
     },
-    "typescript": {
-      "version": "3.9.7",
-      "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.7.tgz",
-      "integrity": "sha512-BLbiRkiBzAwsjut4x/dsibSTB6yWpwT5qWmC2OfuCg3GgVQCSgMs4vEctYPhsaGtd0AeuuHMkjZ2h2WG8MSzRw=="
-    },
-    "uglify-js": {
-      "version": "1.3.5",
-      "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-1.3.5.tgz",
-      "integrity": "sha1-S1v/+Rhu/7qoiOTJ6UvZ/EyUkp0="
-    },
     "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",
@@ -20193,15 +17385,6 @@
         "imurmurhash": "^0.1.4"
       }
     },
-    "universal-cookie": {
-      "version": "4.0.4",
-      "resolved": "https://registry.npmjs.org/universal-cookie/-/universal-cookie-4.0.4.tgz",
-      "integrity": "sha512-lbRVHoOMtItjWbM7TwDLdl8wug7izB0tq3/YVKhT/ahB4VDvWMyvnADfnJI8y6fSvsjh51Ix7lTGC6Tn4rMPhw==",
-      "requires": {
-        "@types/cookie": "^0.3.3",
-        "cookie": "^0.4.0"
-      }
-    },
     "universalify": {
       "version": "0.1.2",
       "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz",
@@ -20321,11 +17504,6 @@
       "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz",
       "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ=="
     },
-    "use-cookie-state": {
-      "version": "1.0.0",
-      "resolved": "https://registry.npmjs.org/use-cookie-state/-/use-cookie-state-1.0.0.tgz",
-      "integrity": "sha512-I76Rg8olmAqUQL3mWnHxfSWaXNhc7UEfjX2frRrFnaCWjoyTxNggL5rE5a4LY1bnhEFOCc2BT3q0ctG6tizz4g=="
-    },
     "util": {
       "version": "0.11.1",
       "resolved": "https://registry.npmjs.org/util/-/util-0.11.1.tgz",
@@ -20362,11 +17540,6 @@
       "resolved": "https://registry.npmjs.org/utila/-/utila-0.4.0.tgz",
       "integrity": "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw="
     },
-    "utils-extend": {
-      "version": "1.0.8",
-      "resolved": "https://registry.npmjs.org/utils-extend/-/utils-extend-1.0.8.tgz",
-      "integrity": "sha1-zP17ZFQPjpDuIe7Fd2nQZRyril8="
-    },
     "utils-merge": {
       "version": "1.0.1",
       "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
@@ -21139,60 +18312,6 @@
       "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz",
       "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho="
     },
-    "winston": {
-      "version": "3.2.1",
-      "resolved": "https://registry.npmjs.org/winston/-/winston-3.2.1.tgz",
-      "integrity": "sha512-zU6vgnS9dAWCEKg/QYigd6cgMVVNwyTzKs81XZtTFuRwJOcDdBg7AU0mXVyNbs7O5RH2zdv+BdNZUlx7mXPuOw==",
-      "requires": {
-        "async": "^2.6.1",
-        "diagnostics": "^1.1.1",
-        "is-stream": "^1.1.0",
-        "logform": "^2.1.1",
-        "one-time": "0.0.4",
-        "readable-stream": "^3.1.1",
-        "stack-trace": "0.0.x",
-        "triple-beam": "^1.3.0",
-        "winston-transport": "^4.3.0"
-      }
-    },
-    "winston-transport": {
-      "version": "4.3.0",
-      "resolved": "https://registry.npmjs.org/winston-transport/-/winston-transport-4.3.0.tgz",
-      "integrity": "sha512-B2wPuwUi3vhzn/51Uukcao4dIduEiPOcOt9HJ3QeaXgkJ5Z7UwpBzxS4ZGNHtrxrUvTwemsQiSys0ihOf8Mp1A==",
-      "requires": {
-        "readable-stream": "^2.3.6",
-        "triple-beam": "^1.2.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"
-          }
-        },
-        "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=="
-        },
-        "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"
-          }
-        }
-      }
-    },
     "word-wrap": {
       "version": "1.2.3",
       "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
@@ -21397,11 +18516,6 @@
       "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
       "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8="
     },
-    "wrench": {
-      "version": "1.3.9",
-      "resolved": "https://registry.npmjs.org/wrench/-/wrench-1.3.9.tgz",
-      "integrity": "sha1-bxPsNRRTF+spLKX2UxORskQRFBE="
-    },
     "write": {
       "version": "0.2.1",
       "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz",
@@ -21445,18 +18559,14 @@
     },
     "y18n": {
       "version": "3.2.1",
-      "resolved": ""
+      "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz",
+      "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE="
     },
     "yallist": {
       "version": "3.1.1",
       "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
       "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g=="
     },
-    "yaml": {
-      "version": "1.10.0",
-      "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.0.tgz",
-      "integrity": "sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg=="
-    },
     "yargs": {
       "version": "11.1.1",
       "resolved": "https://registry.npmjs.org/yargs/-/yargs-11.1.1.tgz",
diff --git a/package.json b/package.json
index e0d4bec3b7d19d0b1719c4cc9da338be771cd854..b2d7301750402498b1c650e4656e05ddc5146d43 100644
--- a/package.json
+++ b/package.json
@@ -5,53 +5,26 @@
   "dependencies": {
     "@ckeditor/ckeditor5-build-classic": "^26.0.0",
     "@ckeditor/ckeditor5-react": "^3.0.2",
-    "@fortawesome/fontawesome": "^1.1.8",
-    "@fortawesome/fontawesome-free-solid": "^5.0.13",
-    "@fortawesome/react-fontawesome": "^0.1.14",
     "@material-ui/core": "^4.11.2",
     "@material-ui/icons": "^4.11.2",
     "@material-ui/lab": "^4.0.0-alpha.57",
     "@material-ui/styles": "^4.11.2",
-    "@syncfusion/ej2-react-inputs": "^18.3.52",
-    "@types/react-recaptcha": "^2.3.3",
-    "antd": "^4.13.1",
     "axios": "^0.21.1",
-    "base64-img": "^1.0.4",
-    "binary-extensions": "^2.1.0",
-    "build": "^0.1.4",
-    "cookie": "^0.4.1",
-    "fine-uploader": "^5.16.2",
-    "image-to-base64": "^2.1.1",
-    "install": "^0.13.0",
-    "material-design-icons": "^3.0.1",
-    "material-ui-popup-state": "^1.8.0",
     "moment": "^2.29.1",
-    "npm": "^7.6.2",
     "piwik-react-router": "^0.12.1",
     "react": "^16.14.0",
-    "react-cookie": "^4.0.3",
     "react-dom": "^16.14.0",
-    "react-dropdown": "^1.9.2",
-    "react-dropdown-select": "^4.7.1",
-    "react-easy-crop": "^2.1.0",
-    "react-fine-uploader": "^1.1.1",
     "react-google-login": "^5.1.25",
     "react-grid-system": "^4.4.11",
     "react-icons": "^3.11.0",
     "react-image-crop": "^8.6.6",
-    "react-input-mask": "^2.0.4",
-    "react-moment": "^1.0.0",
     "react-recaptcha": "^2.3.10",
     "react-responsive-carousel": "^3.2.10",
     "react-router-dom": "^5.1.2",
     "react-router-hash-link": "^2.3.1",
     "react-scripts": "^2.1.8",
-    "react-star-ratings": "^2.3.0",
     "react-swipeable-views": "^0.13.9",
-    "react-window": "^1.8.6",
     "styled-components": "^4.4.1",
-    "typescript": "^3.9.7",
-    "use-cookie-state": "^1.0.0",
     "uuid": "^8.3.2"
   },
   "devDependencies": {
@@ -59,7 +32,8 @@
     "eslint-plugin-prettier": "^3.1.2",
     "eslint-plugin-react": "^7.21.5",
     "eslint-plugin-react-hooks": "^1.6.1",
-    "prettier": "1.18.2"
+    "prettier": "1.18.2",
+    "source-map-explorer": "^2.5.2"
   },
   "watch": {
     "build": {
@@ -70,10 +44,11 @@
     }
   },
   "scripts": {
-    "start": "PORT=4000 react-scripts start watch",
-    "build": "react-scripts build",
-    "test": "react-scripts test",
-    "eject": "react-scripts eject"
+    "analyze": "NODE_PATH=src/ source-map-explorer 'build/static/js/*.js'",
+    "start": "NODE_PATH=src/ PORT=4000 react-scripts start watch",
+    "build": "NODE_PATH=src/ react-scripts build",
+    "test": "NODE_PATH=src/ react-scripts test",
+    "eject": "NODE_PATH=src/ react-scripts eject"
   },
   "eslintConfig": {
     "extends": "react-app"
diff --git a/public/img/logo_small_192x192.png b/public/img/logo_small_192x192.png
new file mode 100644
index 0000000000000000000000000000000000000000..ac3a892e76b5d9578712931ef0f871fa479dd482
Binary files /dev/null and b/public/img/logo_small_192x192.png differ
diff --git a/public/img/logo_small_512x512.png b/public/img/logo_small_512x512.png
new file mode 100644
index 0000000000000000000000000000000000000000..42f78a31245cb6d7b1404cf62b6c152e78925824
Binary files /dev/null and b/public/img/logo_small_512x512.png differ
diff --git a/public/img/maskable_icon_192x192.png b/public/img/maskable_icon_192x192.png
new file mode 100644
index 0000000000000000000000000000000000000000..48fd79dbcd0f9bee0fb0346125aa3641325ae4a7
Binary files /dev/null and b/public/img/maskable_icon_192x192.png differ
diff --git a/public/img/maskable_icon_512x512.png b/public/img/maskable_icon_512x512.png
new file mode 100644
index 0000000000000000000000000000000000000000..251ab3fd9802c0c3497b1ecbff045fd526effc49
Binary files /dev/null and b/public/img/maskable_icon_512x512.png differ
diff --git a/public/img/maskable_logo.png b/public/img/maskable_logo.png
new file mode 100644
index 0000000000000000000000000000000000000000..ed306b076773fe318391efdd7acc6917232f682a
Binary files /dev/null and b/public/img/maskable_logo.png differ
diff --git a/public/index.html b/public/index.html
index 5a55d5b2604173be763d84d95092a495275df599..7752207aacd17c5703b914e3dd5931a4b0179363 100755
--- a/public/index.html
+++ b/public/index.html
@@ -1,3 +1,3 @@
 
 
-<!-- Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre Departamento de Informatica - Universidade Federal do Parana This file is part of Plataforma Integrada MEC. Plataforma Integrada MEC is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Plataforma Integrada MEC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with Plataforma Integrada MEC.  If not, see http://www.gnu.org/licenses/. --> <!DOCTYPE html> <html lang="pt-br">   <head>     <meta charset="utf-8" /> <meta http-equiv='cache-control' content='no-cache'/> <meta http-equiv='expires' content='0'/> <meta http-equiv='pragma' content='no-cache'/>         <!-- google sign-in -->         <meta name="google-signin-client_id" content="288460085642-k4veg4fo8kddvjer8b055n9da5qtgha7.apps.googleusercontent.com">         <script src="https://apis.google.com/js/platform.js" async defer></script>     <meta name="viewport" content="width=device-width, initial-scale=1">     <title>Plataforma integrada MEC RED</title>   </head>   <body >     <noscript>You need to enable JavaScript to run this app.</noscript>     <div id="root"/>   <script src="https://www.google.com/recaptcha/api.js" async defer></script> </body> </html>
\ No newline at end of file
+<!-- Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre Departamento de Informatica - Universidade Federal do Parana This file is part of Plataforma Integrada MEC. Plataforma Integrada MEC is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Plataforma Integrada MEC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with Plataforma Integrada MEC.  If not, see http://www.gnu.org/licenses/. --> <!DOCTYPE html> <html lang="pt-br">   <head>     <meta charset="utf-8" /> <meta http-equiv='cache-control' content='no-cache'/> <meta http-equiv='expires' content='0'/> <meta http-equiv='pragma' content='no-cache'/>         <!-- google sign-in -->         <meta name="google-signin-client_id" content="288460085642-k4veg4fo8kddvjer8b055n9da5qtgha7.apps.googleusercontent.com">         <script src="https://apis.google.com/js/platform.js" async defer></script>     <meta name="viewport" content="width=device-width, initial-scale=1">  <link rel="apple-touch-icon" href="/logo_small_192x192.png">  <meta name="theme-color" content="#f07e05">  <link rel="manifest" href="/manifest.webmanifest">   <title>Plataforma integrada MEC RED</title>   </head>   <body >     <noscript>You need to enable JavaScript to run this app.</noscript>     <div id="root"/>   <script src="https://www.google.com/recaptcha/api.js" async defer></script> </body> </html>
\ No newline at end of file
diff --git a/public/manifest.json b/public/manifest.json
deleted file mode 100755
index a9daa45daef9d3069d34440d8f368b37d3532cd8..0000000000000000000000000000000000000000
--- a/public/manifest.json
+++ /dev/null
@@ -1,15 +0,0 @@
-{
-  "short_name": "MEC RED",
-  "name": "Platafoma Integrada MEC",
-  "icons": [
-    {
-      "src": "logo_small.svg",
-      "sizes": "64x64 32x32 24x24 16x16",
-      "type": "image/svg"
-    }
-  ],
-  "start_url": ".",
-  "display": "standalone",
-  "theme_color": "#000000",
-  "background_color": "#ffffff"
-}
diff --git a/public/manifest.webmanifest b/public/manifest.webmanifest
new file mode 100644
index 0000000000000000000000000000000000000000..1f321e7cd13798a8c31e32d4326afc2bf3bfc142
--- /dev/null
+++ b/public/manifest.webmanifest
@@ -0,0 +1,35 @@
+{
+    "short_name": "MEC RED",
+    "name": "Platafoma Integrada MEC RED",
+    "icons": [
+        {
+            "src": "/img/logo_small_192x192.png",
+            "type": "image/png",
+            "sizes": "192x192",
+            "purpose": "any"
+        },
+        {
+            "src": "/img/logo_small_512x512.png",
+            "type": "image/png",
+            "sizes": "512x512",
+            "purpose": "any"
+        },
+        {
+            "src": "/img/maskable_icon_192x192.png",
+            "type": "image/png",
+            "sizes": "192x192",
+            "purpose": "maskable"
+        },
+        {
+            "src": "/img/maskable_icon_512x512.png",
+            "type": "image/png",
+            "sizes": "512x512",
+            "purpose": "maskable"
+        }
+    ],
+    "start_url": "/",
+    "display": "standalone",
+    "theme_color": "#f07e05",
+    "background_color": "#ffffff",
+    "description": "Plataforma MEC de Recursos Educacionais Digitais. Encontre e compartilhe vídeos, animações e muitos outros Recursos."
+}
\ No newline at end of file
diff --git a/src/Admin/Components/Components/AdminTemplate.js b/src/Admin/Components/Components/AdminTemplate.js
new file mode 100644
index 0000000000000000000000000000000000000000..e0affe5c4b124d0f81166da51626efac58575d62
--- /dev/null
+++ b/src/Admin/Components/Components/AdminTemplate.js
@@ -0,0 +1,64 @@
+/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
+Departamento de Informatica - Universidade Federal do Parana
+
+This file is part of Plataforma Integrada MEC.
+
+Plataforma Integrada MEC is free software: you can redistribute it and/or modify
+it under the terms of the GNU Affero General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+
+Plataforma Integrada MEC is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+GNU Affero General Public License for more details.
+
+You should have received a copy of the GNU Affero General Public License
+along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
+
+import React, { useContext } from "react";
+import { Store } from 'Store'
+
+const Unauthorized = React.lazy(() => import('./Unauthorized'));
+const AppBarAdmin = React.lazy(() => import('./AppBar'));
+
+const AdminTemplate = (props) => {
+
+    const { state } = useContext(Store);
+
+    const CheckUserPermission = () => {
+        let canUserEdit = false;
+    
+        if (state.userIsLoggedIn) {
+            const roles = [...state.currentUser.roles];
+            for (let i = 0; i < roles.length; i++)
+                if (roles[i].name === 'admin' || roles[i].name === 'editor')
+                canUserEdit = true;
+        }
+        else {
+        canUserEdit = false;
+        }
+    
+        return canUserEdit;
+    }
+
+    if (CheckUserPermission())
+        return (
+            <div style={{ backgroundColor: "	#D3D3D3" }}>
+                <AppBarAdmin />
+                <div style={{ padding: "2em" }}>
+                    {props.inner}
+                </div>
+            </div>
+        )
+    else
+        return (
+            <div style={{ backgroundColor: "	#D3D3D3" }}>
+                <div style={{ padding: "2em" }}>
+                    <Unauthorized />
+                </div>
+            </div>
+        )
+}
+
+export default AdminTemplate;
diff --git a/src/Admin/Components/Components/DataCard.js b/src/Admin/Components/Components/DataCard.js
deleted file mode 100644
index 9f5c565d6374808b1a0abc830cdfaba9e805881a..0000000000000000000000000000000000000000
--- a/src/Admin/Components/Components/DataCard.js
+++ /dev/null
@@ -1,140 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, { useState } from "react";
-// Maerial ui components
-import Card from "@material-ui/core/Card";
-import CardContent from "@material-ui/core/CardContent";
-import Typography from "@material-ui/core/Typography";
-import Button from "@material-ui/core/Button";
-import ListRoundedIcon from "@material-ui/icons/ListRounded";
-import ButtonGroup from "@material-ui/core/ButtonGroup";
-import { useStyles } from "../Styles/DataCard"; 
-// Icons
-import EditRoundedIcon from "@material-ui/icons/EditRounded";
-import ArrowBackIosIcon from "@material-ui/icons/ArrowBackIos";
-
-const DataCard = (params) => {
-    console.log(params)
-    return(
-        <div>
-            {params.data}
-        </div>
-    )
-    // const classes = useStyles();
-    // const [edit, setEdit] = useState(false);
-
-    // const buttonArr = [
-    //     {
-    //         label: "Listar",
-    //         icon: <ListRoundedIcon />,
-    //     },
-    //     edit
-    //         ? {
-    //             label: "Voltar",
-    //             icon: <ArrowBackIosIcon />,
-    //         }
-    //         : {
-    //             label: "Editar",
-    //             icon: <EditRoundedIcon />,
-    //         },
-    // ];
-
-    // //Change state of the var edit
-    // const EditHandler = () => {
-    //     setEdit(!edit);
-    // };
-
-    // // it stores an function that will be called when a button is clicked
-    // const functionArr = [props.viewData, EditHandler];
-
-    // return (
-    //     edit ?
-    //         <Card className={classes.root} variant="outlined">
-    //             <CardContent>
-    //                 <div className={classes.displayRow}>
-    //                     <Typography
-    //                         className={classes.title}
-    //                         color="inherit"
-    //                         gutterBottom
-    //                     >
-    //                         {props.data[1].prop}
-    //                     </Typography>
-    //                     <ButtonGroup
-    //                         color="primary"
-    //                         aria-label="outlined primary button group"
-    //                     >
-    //                         {buttonArr.map((button, index) => (
-    //                             <Button onClick={functionArr[index]}>
-    //                                 <div className={classes.displayRow}>
-    //                                     {button.icon}
-    //                                     {button.label}
-    //                                 </div>
-    //                             </Button>
-    //                         ))}
-    //                     </ButtonGroup>
-    //                 </div>
-                    
-    //                 {/* Display the edit area */}
-    //                 {props.component} 
-
-    //             </CardContent>
-    //         </Card>
-    //         :
-    //         <Card className={classes.root} variant="outlined">
-    //             <CardContent>
-    //                 <div className={classes.displayRow}>
-    //                     <Typography
-    //                         className={classes.title}
-    //                         color="inherit"
-    //                         gutterBottom
-    //                     >
-    //                         {props.data[1].prop}
-    //                     </Typography>
-    //                     <ButtonGroup
-    //                         color="primary"
-    //                         aria-label="outlined primary button group"
-    //                     >
-    //                         {buttonArr.map((button, index) => (
-    //                             <Button onClick={functionArr[index]}>
-    //                                 <div className={classes.displayRow}>
-    //                                     {button.icon}
-    //                                     {button.label}
-    //                                 </div>
-    //                             </Button>
-    //                         ))}
-    //                     </ButtonGroup>
-    //                 </div>
-    //                 {props.data.map((info , index) => (
-    //                     <div className={classes.displayColumn} key={index}>
-    //                         <Typography color="initial" className={classes.subTitle}>
-    //                             {info.subTitle}
-    //                         </Typography>
-    //                         <Typography color='textSecondary'>
-    //                             {
-    //                                 info.prop === null ? 'Sem dados' : info.prop
-    //                             }
-    //                         </Typography>
-    //                     </div>
-    //                 ))}
-    //             </CardContent>
-    //         </Card>
-    // );
-}
-
-export default DataCard;
diff --git a/src/Admin/Components/Components/DataCards/UserCard.js b/src/Admin/Components/Components/DataCards/UserCard.js
index a34f96b390a075eed4c3aed1a28b3baacc968734..0e5563ec5de0e6cf27e3c5cac7e295b91fd789e4 100644
--- a/src/Admin/Components/Components/DataCards/UserCard.js
+++ b/src/Admin/Components/Components/DataCards/UserCard.js
@@ -37,13 +37,14 @@ import CloseRoundedIcon from "@material-ui/icons/CloseRounded";
 //imports from local files
 import { GetAData } from "../../../Filters";
 import { apiDomain } from '../../../../env';
-import noAvatar from "../../../../img/default_profile.png";
 import { Link, useHistory } from "react-router-dom";
 import LoadingSpinner from '../../../../Components/LoadingSpinner';
 import SnackBar from '../../../../Components/SnackbarComponent';
 import { getRequest, postRequest, deleteRequest, putRequest } from '../../../../Components/HelperFunctions/getAxiosConfig'
 //styles
 import styled from 'styled-components';
+//Image Import
+import { noAvatar } from "ImportImages.js";
 
 const CollectionCard = () => {
     let history = useHistory()
diff --git a/src/Admin/Pages/Pages/SubPages/AproveTeacher.js b/src/Admin/Pages/Pages/SubPages/AproveTeacher.js
index b8f7203ab10a3c0dfbb9ee471b47b77acd2ffe35..dca8669260e3795ccc28c98d97ce9eea5e9c6b28 100644
--- a/src/Admin/Pages/Pages/SubPages/AproveTeacher.js
+++ b/src/Admin/Pages/Pages/SubPages/AproveTeacher.js
@@ -32,7 +32,6 @@ import MobileList from "../../../Components/Components/MobileComponents/SimpleLi
 import MobilePageHeader from "../../../Components/Components/MobileComponents/MobilePageHeader";
 import PageHeader from "../../../Components/Components/PageHeader";
 import { apiDomain } from '../../../../env';
-import noAvatar from "../../../../img/default_profile.png"
 //imports from material ui
 import { withStyles } from "@material-ui/core/styles";
 import TableBody from "@material-ui/core/TableBody";
@@ -53,6 +52,9 @@ import EmailRoundedIcon from '@material-ui/icons/EmailRounded';
 //routers
 import { Link } from "react-router-dom";
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 
 const StyledTableCell = withStyles((theme) => ({
   head: {
diff --git a/src/Admin/Pages/Pages/SubPages/BlockedUsers.js b/src/Admin/Pages/Pages/SubPages/BlockedUsers.js
index 84a4419b44d2cbb0a7c3d485b9c0b840fabd2014..ba077fdae792fd4eb6c7d6a4cc9a7362631e877d 100644
--- a/src/Admin/Pages/Pages/SubPages/BlockedUsers.js
+++ b/src/Admin/Pages/Pages/SubPages/BlockedUsers.js
@@ -40,7 +40,6 @@ import SnackBar from '../../../../Components/SnackbarComponent';
 import LoadingSpinner from '../../../../Components/LoadingSpinner';
 import MobileList from "../../../Components/Components/MobileComponents/SimpleList"
 import { apiDomain } from '../../../../env';
-import noAvatar from "../../../../img/default_profile.png";
 import MobilePageHeader from "../../../Components/Components/MobileComponents/MobilePageHeader"
 import PageHeader from "../../../Components/Components/PageHeader"
 //Services
@@ -49,6 +48,9 @@ import { Url } from '../../../Filters';
 //routers
 import { Link } from 'react-router-dom';
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 const StyledTableCell = withStyles((theme) => ({
   head: {
     backgroundColor: theme.palette.common.black,
diff --git a/src/Admin/Pages/Pages/SubPages/Users.js b/src/Admin/Pages/Pages/SubPages/Users.js
index cb31af1e213e65b7c8d13be01fb48c68a75dd190..dfb320d805bed3ad175195bbef2eaf886140bff5 100644
--- a/src/Admin/Pages/Pages/SubPages/Users.js
+++ b/src/Admin/Pages/Pages/SubPages/Users.js
@@ -47,7 +47,9 @@ import moment from 'moment';
 import styled from 'styled-components'
 import EmailRoundedIcon from '@material-ui/icons/EmailRounded';
 import { apiDomain } from '../../../../env';
-import noAvatar from "../../../../img/default_profile.png";
+
+//Image Import
+import { noAvatar } from "ImportImages.js";
 
 const StyledTableCell = withStyles((theme) => ({
   head: {
diff --git a/src/App.js b/src/App.js
index b5a80b2f2b1902af6232cdb5c49b1ca956a4d0c0..5f23ceaa5a4823aa5c854c155d6271efcee540e0 100644
--- a/src/App.js
+++ b/src/App.js
@@ -16,452 +16,452 @@ GNU Affero General Public License for more details.
 You should have received a copy of the GNU Affero General Public License
 along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
 
+// const = React.lazy(() => import());
+
 import React, { useContext, useEffect, useState } from "react";
 import { Store } from './Store'
-import Unauthorized from './Admin/Components/Components/Unauthorized'
-import Home from "./Pages/HomeFunction";
-import Search from "./Pages/Search";
-import Header from "./Components/Header";
-import EcFooter from "./Components/EcFooter";
-import GNUAGPLfooter from "./Components/AGPLFooter";
-import UserPage from "./Pages/UserPage";
-import UserTerms from "./Pages/UserTerms";
-import Contact from "./Pages/Contact";
-import Teste from "./Pages/Teste";
-import AboutPage from "./Pages/AboutPage";
-import HelpCenter from "./Pages/HelpCenter";
-import TabResoursePub from "./Pages/TabsHelp/TabResoursePub";
-import TabResourseFind from "./Pages/TabsHelp/TabResourseFind";
-import TabNetPart from "./Pages/TabsHelp/TabNetPart";
-import TabManageAc from "./Pages/TabsHelp/TabManageAc";
-import PasswordRecoveryPage from "./Pages/PasswordRecoveryPage.js";
-import PageProfessor from "./Pages/PageProfessor.js";
-import ResourcePage from "./Pages/ResourcePage";
+import LoadingSpinner from './Components/LoadingSpinner';
 import { BrowserRouter, Switch, Route, Redirect } from "react-router-dom";
-import TermsPage from "./Pages/TermsPage.js";
-import PublicationPermissionsPage from "./Pages/PublicationPermissionsPage.js";
-import TabPlataformaMEC from "./Pages/TabsHelp/TabPlataformaMEC";
-import ItemStore from "./Pages/ItemStore.js";
-import EditProfilePage from "./Pages/EditProfilePage.js";
-import PublicUserPage from "./Pages/PublicUserPage.js";
-import UploadPage from "./Pages/UploadPage.js";
-import EditLearningObjectPage from "./Pages/EditLearningObjectPage.js";
-import SiteMap from "./Pages/SiteMap";
-import Accessibility from "./Pages/Accessibility";
-import CollectionPage from "./Pages/CollectionPage.js";
-import FormationMaterialPage from "./Pages/FormationMaterialPage.js";
-import FormationMaterialIframe from "./Pages/FormationMaterialIframe.js";
-import MaterialPage from "./Pages/MaterialPage";
-import PageNotFound from "./Pages/PageNotFound.js";
-
-import NoteVariables from "./Admin/Pages/Pages/SubPages/NoteVariables";
-import Institution from "./Admin/Pages/Pages/SubPages/Institutions";
-import SendEmail from "./Admin/Pages/Pages/SubPages/SendEmail";
-import Inframe from "./Admin/Pages/Pages/SubPages/Inframe";
-import Languages from "./Admin/Pages/Pages/SubPages/Languages";
-import Activity from "./Admin/Pages/Pages/SubPages/Activity";
-import InstitutionCard from "./Admin/Components/Components/DataCards/InstitutionsCard";
-import InstitutionsInput from "./Admin/Components/Components/Inputs/IntitutionsInputs";
-import CreateInstitution from "./Admin/Components/Components/Inputs/CreateInstitution";
-import NoteVarCard from "./Admin/Components/Components/DataCards/NoteVarCard";
-import NoteVarInputs from "./Admin/Components/Components/Inputs/NoteVarInputs";
-import EditLanguage from "./Admin/Components/Components/Inputs/EditLanguage";
-import CreateLanguage from "./Admin/Components/Components/Inputs/CreateLanguage";
-import ActivityCard from "./Admin/Components/Components/DataCards/ActivityCard";
-import CommunityQuestions from "./Admin/Pages/Pages/SubPages/CommunityQuestions";
-import CommunityCard from "./Admin/Components/Components/DataCards/CommunityQuestionCard";
-import Collections from "./Admin/Pages/Pages/SubPages/Collections";
-import CollectionCard from "./Admin/Components/Components/DataCards/CollectionCard";
-import EditCollection from "./Admin/Components/Components/Inputs/EditCollection";
-import Ratings from "./Admin/Pages/Pages/SubPages/Rating";
-import RatingCard from "./Admin/Components/Components/DataCards/RatingCard";
-import EditRating from "./Admin/Components/Components/Inputs/EditRating";
-import CreateRating from "./Admin/Components/Components/Inputs/CreateRating";
-import Questions from "./Admin/Pages/Pages/SubPages/Questions";
-import CreateQuestions from "./Admin/Components/Components/Inputs/CreateQuestion";
-import EducationalObject from "./Admin/Pages/Pages/SubPages/EducationalObjects";
-import EducationalObjectCard from "./Admin/Components/Components/DataCards/EducationalObjectsCard";
-import EducationalObjectEdit from "./Admin/Components/Components/Inputs/EditEducationalObect";
-import Complaints from "./Admin/Pages/Pages/SubPages/Complaints";
-import ComplaintCard from "./Admin/Components/Components/DataCards/ComplaintsCard";
-import AproveTeacher from "./Admin/Pages/Pages/SubPages/AproveTeacher";
-import UserCard from "./Admin/Components/Components/DataCards/UserCard";
-import EditUser from "./Admin/Components/Components/Inputs/EditUser";
-import UserList from "./Admin/Pages/Pages/SubPages/Users";
-import UserPermissions from "./Admin/Pages/Pages/SubPages/Permissions";
-import EditRole from "./Admin/Components/Components/Inputs/EditRoles";
-import CreateRole from "./Admin/Components/Components/Inputs/CreateRole";
-import BlockedUser from "./Admin/Pages/Pages/SubPages/BlockedUsers";
-import AppBarAdmin from './Admin/Components/Components/AppBar'
 import createBrowserHistory from 'history/createBrowserHistory'
 
-export default function App() {
-  // eslint-disable-next-line
-  const { state, dispatch } = useContext(Store);
-  const [hideFooter, setHideFooter] = useState(false);
-  const PiwikReactRouter = require('piwik-react-router');
-  const piwik = PiwikReactRouter({
-    url: '//piwik.c3sl.ufpr.br/',
-    siteId: 5
-  });
-  const customHistory = createBrowserHistory()
+const AdminTemplate = React.lazy(() => import('./Admin/Components/Components/AdminTemplate'));
+const Header = React.lazy(() => import("./Components/Header"));
+const Home = React.lazy(() => import('./Pages/HomeFunction'));
+const Search = React.lazy(() => import("./Pages/Search"));
+const EcFooter = React.lazy(() => import("./Components/EcFooter"));
+const GNUAGPLfooter = React.lazy(() => import("./Components/AGPLFooter"));
+const UserPage = React.lazy(() => import("./Pages/UserPage"));
+const UserTerms = React.lazy(() => import("./Pages/UserTerms"));
+const Contact = React.lazy(() => import("./Pages/Contact"));
+const AboutPage = React.lazy(() => import("./Pages/AboutPage"));
+const HelpCenter = React.lazy(() => import("./Pages/HelpCenter"));
+const TabResoursePub = React.lazy(() => import("./Pages/TabsHelp/TabResoursePub"));
+const TabResourseFind = React.lazy(() => import("./Pages/TabsHelp/TabResourseFind"));
+const TabNetPart = React.lazy(() => import("./Pages/TabsHelp/TabNetPart"));
+const TabManageAc = React.lazy(() => import("./Pages/TabsHelp/TabManageAc"));
+const PasswordRecoveryPage = React.lazy(() => import("./Pages/PasswordRecoveryPage.js"));
+const PageProfessor = React.lazy(() => import("./Pages/PageProfessor.js"));
+const ResourcePage = React.lazy(() => import("./Pages/ResourcePage"));
+const TermsPage = React.lazy(() => import("./Pages/TermsPage.js"));
+const PublicationPermissionsPage = React.lazy(() => import("./Pages/PublicationPermissionsPage.js"));
+const TabPlataformaMEC = React.lazy(() => import("./Pages/TabsHelp/TabPlataformaMEC"));
+const ItemStore = React.lazy(() => import("./Pages/ItemStore.js"));
+const EditProfilePage = React.lazy(() => import("./Pages/EditProfilePage.js"));
+const PublicUserPage = React.lazy(() => import("./Pages/PublicUserPage.js"));
+const UploadPage = React.lazy(() => import("./Pages/UploadPage.js"));
+const EditLearningObjectPage = React.lazy(() => import("./Pages/EditLearningObjectPage.js"));
+const SiteMap = React.lazy(() => import("./Pages/SiteMap"));
+const Accessibility = React.lazy(() => import("./Pages/Accessibility"));
+const CollectionPage = React.lazy(() => import("./Pages/CollectionPage.js"));
+const FormationMaterialPage = React.lazy(() => import("./Pages/FormationMaterialPage.js"));
+const FormationMaterialIframe = React.lazy(() => import("./Pages/FormationMaterialIframe.js"));
+const MaterialPage = React.lazy(() => import("./Pages/MaterialPage"));
+const PageNotFound = React.lazy(() => import("./Pages/PageNotFound.js"));
 
-  const CheckUserPermission = () => {
-    let canUserEdit = false;
+const NoteVariables = React.lazy(() => import("./Admin/Pages/Pages/SubPages/NoteVariables"));
+const Institution = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Institutions"));
+const SendEmail = React.lazy(() => import("./Admin/Pages/Pages/SubPages/SendEmail"));
+const Inframe = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Inframe"));
+const Languages = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Languages"));
+const Activity = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Activity"));
+const InstitutionCard = React.lazy(() => import("./Admin/Components/Components/DataCards/InstitutionsCard"));
+const InstitutionsInput = React.lazy(() => import("./Admin/Components/Components/Inputs/IntitutionsInputs"));
+const CreateInstitution = React.lazy(() => import("./Admin/Components/Components/Inputs/CreateInstitution"));
+const NoteVarCard = React.lazy(() => import("./Admin/Components/Components/DataCards/NoteVarCard"));
+const NoteVarInputs = React.lazy(() => import("./Admin/Components/Components/Inputs/NoteVarInputs"));
+const EditLanguage = React.lazy(() => import("./Admin/Components/Components/Inputs/EditLanguage"));
+const CreateLanguage = React.lazy(() => import("./Admin/Components/Components/Inputs/CreateLanguage"));
+const ActivityCard = React.lazy(() => import("./Admin/Components/Components/DataCards/ActivityCard"));
+const CommunityQuestions = React.lazy(() => import("./Admin/Pages/Pages/SubPages/CommunityQuestions"));
+const CommunityCard = React.lazy(() => import("./Admin/Components/Components/DataCards/CommunityQuestionCard"));
+const Collections = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Collections"));
+const CollectionCard = React.lazy(() => import("./Admin/Components/Components/DataCards/CollectionCard"));
+const EditCollection = React.lazy(() => import("./Admin/Components/Components/Inputs/EditCollection"));
+const Ratings = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Rating"));
+const RatingCard = React.lazy(() => import("./Admin/Components/Components/DataCards/RatingCard"));
+const EditRating = React.lazy(() => import("./Admin/Components/Components/Inputs/EditRating"));
+const CreateRating = React.lazy(() => import("./Admin/Components/Components/Inputs/CreateRating"));
+const Questions = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Questions"));
+const CreateQuestions = React.lazy(() => import("./Admin/Components/Components/Inputs/CreateQuestion"));
+const EducationalObject = React.lazy(() => import("./Admin/Pages/Pages/SubPages/EducationalObjects"));
+const EducationalObjectCard = React.lazy(() => import("./Admin/Components/Components/DataCards/EducationalObjectsCard"));
+const EducationalObjectEdit = React.lazy(() => import("./Admin/Components/Components/Inputs/EditEducationalObect"));
+const Complaints = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Complaints"));
+const ComplaintCard = React.lazy(() => import("./Admin/Components/Components/DataCards/ComplaintsCard"));
+const AproveTeacher = React.lazy(() => import("./Admin/Pages/Pages/SubPages/AproveTeacher"));
+const UserCard = React.lazy(() => import("./Admin/Components/Components/DataCards/UserCard"));
+const EditUser = React.lazy(() => import("./Admin/Components/Components/Inputs/EditUser"));
+const UserList = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Users"));
+const UserPermissions = React.lazy(() => import("./Admin/Pages/Pages/SubPages/Permissions"));
+const EditRole = React.lazy(() => import("./Admin/Components/Components/Inputs/EditRoles"));
+const CreateRole = React.lazy(() => import("./Admin/Components/Components/Inputs/CreateRole"));
+const BlockedUser = React.lazy(() => import("./Admin/Pages/Pages/SubPages/BlockedUsers"));
 
-    if (state.userIsLoggedIn) {
-      const roles = [...state.currentUser.roles];
-      for (let i = 0; i < roles.length; i++)
-        if (roles[i].name === 'admin' || roles[i].name === 'editor')
-          canUserEdit = true;
+export default function App() {
+    // eslint-disable-next-line
+    const { state, dispatch } = useContext(Store);
+    const [hideFooter, setHideFooter] = useState(false);
+    const [awaitTest, setAwait] = useState(true);
+    const PiwikReactRouter = require('piwik-react-router');
+    const piwik = PiwikReactRouter({
+        url: '//piwik.c3sl.ufpr.br/',
+        siteId: 5
+    });
+    const customHistory = createBrowserHistory()
+    
+    async function supportsWebp() {
+        if (!createImageBitmap) return false;
+        
+        const webpData = '';
+        const blob = await fetch(webpData).then(r => r.blob());
+        return createImageBitmap(blob).then(() => true, () => false);
     }
-    else {
-      canUserEdit = false;
+    
+    async function testWebpSupport() {
+        if(await supportsWebp()) {
+            localStorage.setItem('webpSupport', 'True');
+        } else {
+            localStorage.setItem('webpSupport', 'False');
+        }
+        setAwait(false);
     }
 
-    return canUserEdit;
-  }
+    useEffect(() => {
+        setHideFooter(String(window.location.href).includes("iframe-colecao"));
+    }, [window.location.href]);
 
-  useEffect(() => {
-    setHideFooter(String(window.location.href).includes("iframe-colecao"));
-  }, [window.location.href]);
+    useEffect(() => {
+        dispatch({
+            type: "WINDOW_SIZE",
+            innerWindow: {
+                width: window.innerWidth,
+                height: window.innerHeight,
+            },
+        });
+        testWebpSupport();
+    }, []);
 
-  useEffect(() => {
-    dispatch({
-      type: "WINDOW_SIZE",
-      innerWindow: {
-        width: window.innerWidth,
-        height: window.innerHeight,
-      },
-    });
-  }, []);
-
-  useEffect(() => {
-    const setWindowSize = () => {
-      dispatch({
-        type: "WINDOW_SIZE",
-        innerWindow: {
-          width: window.innerWidth,
-          height: window.innerHeight,
-        },
-      });
-    };
+    useEffect(() => {
+        const setWindowSize = () => {
+            dispatch({
+                type: "WINDOW_SIZE",
+                innerWindow: {
+                    width: window.innerWidth,
+                    height: window.innerHeight,
+                },
+            });
+        };
 
-    window.addEventListener("resize", setWindowSize);
+        window.addEventListener("resize", setWindowSize);
 
-    return () => window.removeEventListener("resize", setWindowSize);
-  }, [window.innerWidth, window.innerHeight]);
+        return () => window.removeEventListener("resize", setWindowSize);
+    }, [window.innerWidth, window.innerHeight]);
 
-  const AdminTemplate = (props) => {
-    if (CheckUserPermission())
-      return (
-          <div style={{ backgroundColor: "	#D3D3D3" }}>
-            <AppBarAdmin />
-            <div style={{ padding: "2em" }}>
-              {props.inner}
-            </div>
-          </div>
-        )
-    else
-      return (
-        <div style={{ backgroundColor: "	#D3D3D3" }}>
-            <div style={{ padding: "2em" }}>
-              <Unauthorized />
-            </div>
-          </div>
-      )
-  }
+    const LoadingScreen = () => (  
+        <div style={{
+            position: "absolute",
+            top: "50%",
+            left: "50%",
+            transform: "translate(-50%, -50%)"
+        }}>
+            <LoadingSpinner/>
+        </div>
+    );
 
   return (
     // add piwik later
     // history={piwik.connectToHistory(customHistory)}
-    <BrowserRouter>
-      <Header />
-      <div
-        style={{
-          backgroundImage:
-            "linear-gradient(to right,#ff7f00,#e81f4f,#673ab7,#00bcd4)",
-          height: "5px",
-        }}
-      ></div>
-      <link
-        href="https://fonts.googleapis.com/css?family=Kalam|Pompiere|Roboto&display=swap"
-        rel="stylesheet"
-      />
-      <Switch>
-        <Redirect from="/home" to="/" />
-        <Route path="/" exact={true} component={Home} />
-        <Route path="/busca" component={Search} />
-        <Route path="/perfil" component={UserPage} />
-        <Route path="/editarperfil" component={EditProfilePage} />
-        <Route path="/recurso/:recursoId" component={ResourcePage} />
-        <Route path="/termos-publicar-recurso" component={TermsPage} />
-        <Route path="/permission" component={PublicationPermissionsPage} />
-        {/*<Route path="termos-de-uso#publicacoes-de-usuario" component={}*/}
-        <Route path="/ajuda" component={HelpCenter} />
-        <Route path="/contato" component={Contact} />
-        <Route path="/termos" component={UserTerms} />
-        <Route path="/teste" component={Teste} />
-        <Route path="/sobre" component={AboutPage} />
-        <Route path="/mapa-site" component={SiteMap} />
-        <Route path="/acessibilidade" component={Accessibility} />
-        <Route path="/publicando-recurso" component={TabResoursePub} />
-        <Route path="/encontrando-recurso" component={TabResourseFind} />
-        <Route path="/participando-da-rede" component={TabNetPart} />
-        <Route path="/gerenciando-conta" component={TabManageAc} />
-        <Route path="/plataforma-mec" component={TabPlataformaMEC} />
-        <Route path="/recuperar-senha" component={PasswordRecoveryPage} />
-        <Route path="/usuario-publico/:userId" component={PublicUserPage} />
-        <Route
-          path="/editar-recurso/:recursoId"
-          component={EditLearningObjectPage}
-        />
-        <Route path="/professor" component={PageProfessor} />
-        <Route path="/upload" component={UploadPage} />
-        <Route path="/loja" component={ItemStore} />
-        <Route path="/colecao-do-usuario/:id" component={CollectionPage} />
-        <Route path="/colecao" component={FormationMaterialPage} />
-        <Route path="/topico" component={FormationMaterialPage} />
-        <Route path="/iframe-colecao" component={FormationMaterialIframe} />
-        <Route path="/material-formacao" component={MaterialPage} />
-        
-        <Route 
-          path="/admin/home" 
-          exact={true} 
-          render={() => {
-            return <AdminTemplate inner={<Inframe/>}/>
-          }} 
-        />
-        <Route 
-          path="/admin/institutions" 
-          render={() => {
-            return <AdminTemplate inner={<Institution />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/institution" 
-          render={() => {
-            return <AdminTemplate inner={<InstitutionCard />}/>
-          }} 
-        />
-        <Route
-          path="/admin/institutionEdit"
-          render={() => {
-            return <AdminTemplate inner={<InstitutionsInput />}/>
-          }}
-        />
-        <Route
-          path="/admin/InstitutionCreate"
-          render={() => {
-            return <AdminTemplate inner={<CreateInstitution />}/>
-          }}
-        />
-        <Route 
-          path="/admin/noteVars" 
-          render={() => {
-            return <AdminTemplate inner={<NoteVariables />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/noteVar" 
-          render={() => {
-            return <AdminTemplate inner={<NoteVarCard />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/noteVarEdit" 
-          render={() => {
-            return <AdminTemplate inner={<NoteVarInputs />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/languages" 
-          render={() => {
-            return <AdminTemplate inner={<Languages />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/languageEdit" 
-          render={() => {
-            return <AdminTemplate inner={<EditLanguage />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/languageCreate" 
-          render={() => {
-            return <AdminTemplate inner={<CreateLanguage />}/>
-          }} 
-        />
-        <Route
-          path="/admin/CommunityQuestions"
-          render={() => {
-            return <AdminTemplate inner={<CommunityQuestions />}/>
-          }}
-        />
-        <Route
-          path="/admin/CommunityQuestion"
-          render={() => {
-            return <AdminTemplate inner={<CommunityCard />}/>
-          }}
-        />
-        <Route 
-          path="/admin/Collections" 
-          render={() => {
-            return <AdminTemplate inner={<Collections />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/Collection" 
-          render={() => {
-            return <AdminTemplate inner={<CollectionCard />}/>
-          }} 
-        />
-        <Route
-          path="/admin/EditCollection"
-          render={() => {
-            return <AdminTemplate inner={<EditCollection />}/>
-          }}
-        />
-        <Route 
-          path="/admin/Ratings" 
-          render={() => {
-            return <AdminTemplate inner={<Ratings />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/Rating" 
-          render={() => {
-            return <AdminTemplate inner={<RatingCard />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/EditRating" 
-          render={() => {
-            return <AdminTemplate inner={<EditRating />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/CreateRating" 
-          render={() => {
-            return <AdminTemplate inner={<CreateRating />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/Questions" 
-          render={() => {
-            return <AdminTemplate inner={<Questions />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/CreateQuestion" 
-          render={() => {
-            return <AdminTemplate inner={<CreateQuestions />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/activities" 
-          render={() => {
-            return <AdminTemplate inner={<Activity />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/activity" 
-          render={() => {
-            return <AdminTemplate inner={<ActivityCard />}/>
-          }} 
-        />
-        <Route
-          path="/admin/learningObjects"
-          render={() => {
-            return <AdminTemplate inner={<EducationalObject />}/>
-          }} 
-        />
-        <Route
-          path="/admin/learningObject"
-          render={() => {
-            return <AdminTemplate inner={<EducationalObjectCard />}/>
-          }} 
-        />
-        <Route
-          path="/admin/learningObjectEdit"
-          render={() => {
-            return <AdminTemplate inner={<EducationalObjectEdit />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/complaints" 
-          render={() => {
-            return <AdminTemplate inner={<Complaints />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/complaint" 
-          render={() => {
-            return <AdminTemplate inner={<ComplaintCard />}/>
-          }} 
-        />
-        <Route
-          path="/admin/users/teacher_requests"
-          render={() => {
-            return <AdminTemplate inner={<AproveTeacher />}/> 
-          }} />
-        <Route 
-          path="/admin/usersList" 
-          render={() => {
-            return <AdminTemplate inner={<UserList />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/user" 
-          render={() => {
-            return <AdminTemplate inner={<UserCard />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/EditUser" 
-          render={() => {
-            return <AdminTemplate inner={<EditUser />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/permissions" 
-          render={() => {
-            return <AdminTemplate inner={<UserPermissions />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/EditPermissions" 
-          render={() => {
-            return <AdminTemplate inner={<EditRole />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/CreateRole" 
-          render={() => {
-            return <AdminTemplate inner={<CreateRole />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/BlockedUsers" 
-          render={() => {
-            return <AdminTemplate inner={<BlockedUser />}/>
-          }} 
-        />
-        <Route 
-          path="/admin/sendEmail" 
-          render={() => {
-            return <AdminTemplate inner={<SendEmail />}/>
-          }} 
-        />
-
-        <Route path='*' component={PageNotFound} />
-      </Switch>
-      {!hideFooter && (
-        <div>
-          <EcFooter />
-          <GNUAGPLfooter />
-        </div>
-      )}
-    </BrowserRouter>
+    <>
+        {!awaitTest &&
+        <React.Suspense fallback={<LoadingScreen/>}>
+            <BrowserRouter>
+                <Header />
+                <div
+                    style={{
+                    backgroundImage:
+                        "linear-gradient(to right,#ff7f00,#e81f4f,#673ab7,#00bcd4)",
+                    height: "5px",
+                    }}
+                ></div>
+                <link
+                    href="https://fonts.googleapis.com/css?family=Kalam|Pompiere|Roboto&display=swap"
+                    rel="stylesheet"
+                />
+                <Switch>
+                    <Redirect from="/home" to="/" />
+                    <Route path="/" exact={true} component={Home} />
+                    <Route path="/busca" component={Search} />
+                    <Route path="/perfil" component={UserPage} />
+                    <Route path="/editarperfil" component={EditProfilePage} />
+                    <Route path="/recurso/:recursoId" component={ResourcePage} />
+                    <Route path="/termos-publicar-recurso" component={TermsPage} />
+                    <Route path="/permission" component={PublicationPermissionsPage} />
+                    {/*<Route path="termos-de-uso#publicacoes-de-usuario" component={}*/}
+                    <Route path="/ajuda" component={HelpCenter} />
+                    <Route path="/contato" component={Contact} />
+                    <Route path="/termos" component={UserTerms} />
+                    <Route path="/sobre" component={AboutPage} />
+                    <Route path="/mapa-site" component={SiteMap} />
+                    <Route path="/acessibilidade" component={Accessibility} />
+                    <Route path="/publicando-recurso" component={TabResoursePub} />
+                    <Route path="/encontrando-recurso" component={TabResourseFind} />
+                    <Route path="/participando-da-rede" component={TabNetPart} />
+                    <Route path="/gerenciando-conta" component={TabManageAc} />
+                    <Route path="/plataforma-mec" component={TabPlataformaMEC} />
+                    <Route path="/recuperar-senha" component={PasswordRecoveryPage} />
+                    <Route path="/usuario-publico/:userId" component={PublicUserPage} />
+                    <Route
+                    path="/editar-recurso/:recursoId"
+                    component={EditLearningObjectPage}
+                    />
+                    <Route path="/professor" component={PageProfessor} />
+                    <Route path="/upload" component={UploadPage} />
+                    <Route path="/loja" component={ItemStore} />
+                    <Route path="/colecao-do-usuario/:id" component={CollectionPage} />
+                    <Route path="/colecao" component={FormationMaterialPage} />
+                    <Route path="/topico" component={FormationMaterialPage} />
+                    <Route path="/iframe-colecao" component={FormationMaterialIframe} />
+                    <Route path="/material-formacao" component={MaterialPage} />
+                    
+                    <Route 
+                    path="/admin/home" 
+                    exact={true} 
+                    render={() => {
+                        return <AdminTemplate inner={<Inframe/>}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/institutions" 
+                    render={() => {
+                        return <AdminTemplate inner={<Institution />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/institution" 
+                    render={() => {
+                        return <AdminTemplate inner={<InstitutionCard />}/>
+                    }} 
+                    />
+                    <Route
+                    path="/admin/institutionEdit"
+                    render={() => {
+                        return <AdminTemplate inner={<InstitutionsInput />}/>
+                    }}
+                    />
+                    <Route
+                    path="/admin/InstitutionCreate"
+                    render={() => {
+                        return <AdminTemplate inner={<CreateInstitution />}/>
+                    }}
+                    />
+                    <Route 
+                    path="/admin/noteVars" 
+                    render={() => {
+                        return <AdminTemplate inner={<NoteVariables />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/noteVar" 
+                    render={() => {
+                        return <AdminTemplate inner={<NoteVarCard />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/noteVarEdit" 
+                    render={() => {
+                        return <AdminTemplate inner={<NoteVarInputs />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/languages" 
+                    render={() => {
+                        return <AdminTemplate inner={<Languages />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/languageEdit" 
+                    render={() => {
+                        return <AdminTemplate inner={<EditLanguage />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/languageCreate" 
+                    render={() => {
+                        return <AdminTemplate inner={<CreateLanguage />}/>
+                    }} 
+                    />
+                    <Route
+                    path="/admin/CommunityQuestions"
+                    render={() => {
+                        return <AdminTemplate inner={<CommunityQuestions />}/>
+                    }}
+                    />
+                    <Route
+                    path="/admin/CommunityQuestion"
+                    render={() => {
+                        return <AdminTemplate inner={<CommunityCard />}/>
+                    }}
+                    />
+                    <Route 
+                    path="/admin/Collections" 
+                    render={() => {
+                        return <AdminTemplate inner={<Collections />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/Collection" 
+                    render={() => {
+                        return <AdminTemplate inner={<CollectionCard />}/>
+                    }} 
+                    />
+                    <Route
+                    path="/admin/EditCollection"
+                    render={() => {
+                        return <AdminTemplate inner={<EditCollection />}/>
+                    }}
+                    />
+                    <Route 
+                    path="/admin/Ratings" 
+                    render={() => {
+                        return <AdminTemplate inner={<Ratings />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/Rating" 
+                    render={() => {
+                        return <AdminTemplate inner={<RatingCard />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/EditRating" 
+                    render={() => {
+                        return <AdminTemplate inner={<EditRating />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/CreateRating" 
+                    render={() => {
+                        return <AdminTemplate inner={<CreateRating />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/Questions" 
+                    render={() => {
+                        return <AdminTemplate inner={<Questions />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/CreateQuestion" 
+                    render={() => {
+                        return <AdminTemplate inner={<CreateQuestions />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/activities" 
+                    render={() => {
+                        return <AdminTemplate inner={<Activity />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/activity" 
+                    render={() => {
+                        return <AdminTemplate inner={<ActivityCard />}/>
+                    }} 
+                    />
+                    <Route
+                    path="/admin/learningObjects"
+                    render={() => {
+                        return <AdminTemplate inner={<EducationalObject />}/>
+                    }} 
+                    />
+                    <Route
+                    path="/admin/learningObject"
+                    render={() => {
+                        return <AdminTemplate inner={<EducationalObjectCard />}/>
+                    }} 
+                    />
+                    <Route
+                    path="/admin/learningObjectEdit"
+                    render={() => {
+                        return <AdminTemplate inner={<EducationalObjectEdit />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/complaints" 
+                    render={() => {
+                        return <AdminTemplate inner={<Complaints />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/complaint" 
+                    render={() => {
+                        return <AdminTemplate inner={<ComplaintCard />}/>
+                    }} 
+                    />
+                    <Route
+                    path="/admin/users/teacher_requests"
+                    render={() => {
+                        return <AdminTemplate inner={<AproveTeacher />}/> 
+                    }} />
+                    <Route 
+                    path="/admin/usersList" 
+                    render={() => {
+                        return <AdminTemplate inner={<UserList />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/user" 
+                    render={() => {
+                        return <AdminTemplate inner={<UserCard />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/EditUser" 
+                    render={() => {
+                        return <AdminTemplate inner={<EditUser />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/permissions" 
+                    render={() => {
+                        return <AdminTemplate inner={<UserPermissions />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/EditPermissions" 
+                    render={() => {
+                        return <AdminTemplate inner={<EditRole />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/CreateRole" 
+                    render={() => {
+                        return <AdminTemplate inner={<CreateRole />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/BlockedUsers" 
+                    render={() => {
+                        return <AdminTemplate inner={<BlockedUser />}/>
+                    }} 
+                    />
+                    <Route 
+                    path="/admin/sendEmail" 
+                    render={() => {
+                        return <AdminTemplate inner={<SendEmail />}/>
+                    }} 
+                    />
+                    <Route path='*' component={PageNotFound} />
+                </Switch>
+                {!hideFooter && (
+                    <div>
+                    <EcFooter />
+                    <GNUAGPLfooter />
+                    </div>
+                )}
+            </BrowserRouter>
+        </React.Suspense>
+        }
+    </>
   );
 }
\ No newline at end of file
diff --git a/src/Components/AGPLFooter.js b/src/Components/AGPLFooter.js
index a77d3bc1648d55f8d6e6e89c6bcf5d450223ad00..f4633420764b97b958081c2af3d47551bb07825a 100644
--- a/src/Components/AGPLFooter.js
+++ b/src/Components/AGPLFooter.js
@@ -18,7 +18,9 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React, {Component} from 'react';
 import {Row, Col, Container} from 'react-grid-system';
-import acessoInfo from '../img/acesso-a-informacao.png';
+//Image Import
+import { acessoInfo } from "ImportImages.js";
+
 const grayFooter={
   backgroundColor: "#434343",
   color: "white",
diff --git a/src/Components/AboutCarousel.js b/src/Components/AboutCarousel.js
index fc36515228cd3b234058e7e712d5630900be159e..204e5de622de184e6217f53d835a6f899bfd90a0 100644
--- a/src/Components/AboutCarousel.js
+++ b/src/Components/AboutCarousel.js
@@ -23,11 +23,12 @@ import { Carousel } from 'react-responsive-carousel';
 import styled from 'styled-components';
 import "./AboutCarousel.css"
 
-import Img1 from '../img/carousel/Icone_Grande (1).png'
-import Img2 from '../img/carousel/Icone_Grande (2).png'
-import Img3 from '../img/carousel/Icone_Grande (3).png'
-import Img4 from '../img/carousel/Icone_Grande (4).png'
-import Img5 from '../img/carousel/Icone_Grande (5).png'
+//Image Import
+import { Img1 } from "ImportImages.js";
+import { Img2 } from "ImportImages.js";
+import { Img3 } from "ImportImages.js";
+import { Img4 } from "ImportImages.js";
+import { Img5 } from "ImportImages.js";
 
 const CarouselAbout = styled(Carousel)`
 
diff --git a/src/Components/AboutCarouselPartner.js b/src/Components/AboutCarouselPartner.js
index eb9c9c2939dedce5bf90673951b2ffe29e6d431d..ba4800d6963383c5c2154fb3f89c95f1abdae188 100644
--- a/src/Components/AboutCarouselPartner.js
+++ b/src/Components/AboutCarouselPartner.js
@@ -22,27 +22,27 @@ import "react-responsive-carousel/lib/styles/carousel.min.css";
 import { Carousel } from 'react-responsive-carousel';
 import './AboutCarouselPartner.css'
 
-
-import LogoPortalDoProfessor from "../img/logo_parceiros/logo_portaldoprofessor.png";
-import LogoBioe from "../img/logo_parceiros/logo_bioe.png";
-import LogoDominioPublico from "../img/logo_parceiros/logo_dominiopublico.png";
-import LogoTvEscola from "../img/logo_parceiros/logo_tvescola.png";
-import Safer from "../img/logo_parceiros/safer.png";
-import FundacaoLemann from "../img/logo_parceiros/fundacao-lemann.png";
-import InstitutoCrescer from "../img/logo_parceiros/instituto-crescer.png";
-import RedeEscola from "../img/logo_parceiros/redeescola.png";
-import Educagital from "../img/logo_parceiros/educagital.png";
-import EnefAef from "../img/logo_parceiros/ENEF_AEF.png";
-import Impa from "../img/logo_parceiros/impa.png";
-import Futura from "../img/logo_parceiros/futura.png";
-import Impulsiona from "../img/logo_parceiros/impulsiona.png";
-import InstPeninsula from "../img/logo_parceiros/inst-peninsula.png";
-import Telefonica from "../img/logo_parceiros/telefonica.png";
+//Image Import
+import { LogoPortalDoProfessor } from "ImportImages.js";
+import { LogoBioe } from "ImportImages.js";
+import { LogoDominioPublico } from "ImportImages.js";
+import { LogoTvEscola } from "ImportImages.js";
+import { Safer } from "ImportImages.js";
+import { FundacaoLemann } from "ImportImages.js";
+import { InstitutoCrescer } from "ImportImages.js";
+import { RedeEscola } from "ImportImages.js";
+import { Educagital } from "ImportImages.js";
+import { EnefAef } from "ImportImages.js";
+import { Impa } from "ImportImages.js";
+import { Futura } from "ImportImages.js";
+import { Impulsiona } from "ImportImages.js";
+import { InstPeninsula } from "ImportImages.js";
+import { Telefonica } from "ImportImages.js";
 
 function AboutCarouselPartner(props) {
 
 
-  const itens = [
+  const items = [
     <a href="http://portaldoprofessor.mec.gov.br/index.html" rel="noreferrer" target="_blank">
       <img src={LogoPortalDoProfessor} alt="LogoPortalDoProfessor"/>
     </a>,
@@ -101,7 +101,7 @@ function AboutCarouselPartner(props) {
   var rows = []
   var partner_per_page = partnerPerPage()
   for(let i = 0; i < 15/partner_per_page; i++){
-    rows.push(itens.slice(i*partner_per_page, partner_per_page*(i+1)))
+    rows.push(items.slice(i*partner_per_page, partner_per_page*(i+1)))
   }
 
   return (
diff --git a/src/Components/AchievementDescriptionCard.js b/src/Components/AchievementDescriptionCard.js
deleted file mode 100644
index ad01fc46506825aef6570d3c342bdac2d088d8f2..0000000000000000000000000000000000000000
--- a/src/Components/AchievementDescriptionCard.js
+++ /dev/null
@@ -1,39 +0,0 @@
-import React from 'react'
-import styled from 'styled-components'
-import Paper from '@material-ui/core/Paper';
-import { Grid } from '@material-ui/core'
-import RequirementDialog from './RequirementsDialog.js';
-
-export default function AchievementDescriptionCard(props) {
-    return (
-            <Paper elevation={3}>
-                <Grid container direction="row" justify="space-around" alignItems="center">
-                    <Grid item xs={3}>
-                        <AchievementImg src={props.src}/>
-                    </Grid>
-                    <Grid item xs={7}>
-                        <AchievementTitle>{props.title}</AchievementTitle>
-                        <AchievementDescription>{props.description}</AchievementDescription>
-                        <RequirementDialog
-                            title={props.title}
-                            description={props.description}
-                            requirements={props.requirements}
-                        />
-                    </Grid>
-                </Grid>
-            </Paper>
-    );
-}
-
-const AchievementImg = styled.img`
-  border-radius: 100px;
-  width: 100px;
-  height: 100px;
-  margin: 30px;
-`
-
-const AchievementTitle = styled.h2`
-`
-
-const AchievementDescription = styled.p`
-`
diff --git a/src/Components/ActivityListItem.js b/src/Components/ActivityListItem.js
index 0d249401c851757d490eff07d316748ddad437c0..43402a8e5176dc14edaba476f2403d6a72f0f202 100644
--- a/src/Components/ActivityListItem.js
+++ b/src/Components/ActivityListItem.js
@@ -22,7 +22,6 @@ import ListItem from '@material-ui/core/ListItem';
 import ListItemAvatar from '@material-ui/core/ListItemAvatar';
 import ListItemText from '@material-ui/core/ListItemText';
 import Avatar from '@material-ui/core/Avatar';
-import noAvatar from "../img/default_profile.png";
 import { GetActivityProperties, Tag, ObjectColor } from './Activities/Definitions.js'
 //icons
 import FavoriteIcon from '@material-ui/icons/Favorite';
@@ -36,6 +35,9 @@ import ThumbDownIcon from '@material-ui/icons/ThumbDown';
 import DeleteIcon from '@material-ui/icons/Delete';
 import { Link } from 'react-router-dom'
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 const GetObjectColor = (tag) => {
     return ObjectColor[tag]
 }
diff --git a/src/Components/AreasSubPages.js b/src/Components/AreasSubPages.js
deleted file mode 100644
index b8d429a946ea7f27d93034d0baddef361cfc3582..0000000000000000000000000000000000000000
--- a/src/Components/AreasSubPages.js
+++ /dev/null
@@ -1,346 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, { Component } from "react";
-import "./carousel.css";
-import { Col, Row, Container, Hidden, Visible } from "react-grid-system";
-import MaterialCard from "./MaterialCard";
-import "react-responsive-carousel/lib/styles/carousel.min.css";
-import { Carousel } from "react-responsive-carousel";
-import recursos from "../img/ilustra_recursos_digitais.png";
-import materiais from "../img/ilustra_materiais.png";
-import colecoes from "../img/ilustra_colecoes.png";
-import ResourceCardFunction from "./ResourceCardFunction.js";
-import CollectionCardFunction from "./CollectionCardFunction.js";
-import colecoes_obj from './FormationMaterialsResources/formationMaterials';
-import ExpandedMaterial from './ExpandedMaterials';
-import {getRequest} from './HelperFunctions/getAxiosConfig.js'
-
-const materials = colecoes_obj();
-
-class ReqResources extends Component {
-  constructor(props) {
-    super(props);
-    this.state = {
-      resources: [],
-    };
-  }
-
-  componentDidMount() {
-    const url = `/learning_objects?limit=12&sort=["published_at", "desc"]`
-    getRequest(url, (data) => {this.setState({ resources: data })}, (error) => {console.log(error)})
-  }
-
-  resourcesPerPage() {
-    var pageWidth = window.innerWidth
-    if (pageWidth >= 1200) {
-      return 3
-    }
-    else {
-      if (pageWidth > 766) {
-        return 2
-      }
-      else {
-        return 1
-      }
-    }
-  }
-
-  render() {
-    var rows = []
-    var resources_per_page = this.resourcesPerPage()
-    for (let i = 0; i < 12 / resources_per_page; i++) {
-      rows.push(this.state.resources.slice(i * resources_per_page, resources_per_page * (i + 1)))
-    }
-    return (
-
-      <Carousel showThumbs={false} infiniteLoop={true} showStatus={false}>
-        {
-          rows.map((row, index) => (
-            <Row style={{ paddingBottom: "5px", margin: '0 auto', width: "80%", justifyContent: "center" }} key={(index + 1)}>
-              {row.map((card) => (
-                <div style={{ marginLeft: 10, display: 'flex' }} key={card.id * (index + 1)}>
-                  <ResourceCardFunction
-                    avatar={card.publisher.avatar}
-                    id={card.id}
-                    thumbnail={card.thumbnail}
-                    type={card.object_type ? card.object_type : "Outros"}
-                    title={card.name}
-                    published={card.state === "published" ? true : false}
-                    likeCount={card.likes_count}
-                    liked={card.liked}
-                    rating={card.review_average}
-                    author={card.publisher.name}
-                    tags={card.tags}
-                    href={"/recurso/" + card.id}
-                    downloadableLink={card.default_attachment_location}
-                  />
-                </div>
-              ))}
-            </Row>
-          ))}
-      </Carousel>
-    );
-  }
-}
-
-class ReqCollections extends Component {
-  constructor(props) {
-    super(props);
-    this.state = {
-      collections: [],
-    };
-  }
-  componentDidMount() {
-      const url = `/collections?limit=12&sort=["updated_at", "desc"]`
-
-      getRequest(url, (data) => {this.setState({ collections: data })}, (error) => {console.log(error)})
-  }
-  collectionsPerPage() {
-    var pageWidth = window.innerWidth
-    if (pageWidth >= 1200) {
-      return 3
-    }
-    else {
-      if (pageWidth > 766) {
-        return 2
-      }
-      else {
-        return 1
-      }
-    }
-  }
-
-  render() {
-    var rows = []
-    var collections_per_page = this.collectionsPerPage()
-    for (let i = 0; i < 12 / collections_per_page; i++) {
-      rows.push(this.state.collections.slice(i * collections_per_page, collections_per_page * (i + 1)))
-    }
-    return (
-      <Carousel showThumbs={false} infiniteLoop={true} showStatus={false}>
-        {
-          rows.map((row, index) => (
-            <Row style={{ paddingBottom: "5px", margin: '0 auto', width: "80%", justifyContent: "center" }} key={(index + 1)}>
-              {row.map((card) => (
-                <div style={{ marginLeft: 10, display: 'flex' }} key={card.id * (index + 1)}>
-                  <CollectionCardFunction
-                    name={card.name}
-                    tags={card.tags}
-                    rating={card.score}
-                    id={card.id}
-                    author={card.owner.name}
-                    description={card.description}
-                    thumbnails={card.items_thumbnails}
-                    avatar={card.owner.avatar}
-                    likeCount={card.likes_count}
-                    followed={card.followed}
-                    liked={card.liked}
-                    collections={card.collection_items}
-                    authorID={card.owner.id}
-                  />
-                </div>
-              ))}
-            </Row>
-          ))}
-      </Carousel>
-    );
-  }
-}
-
-class SubPages extends Component {
-  constructor(props) {
-    super(props);
-    this.state = {
-      currMaterial: {
-        open: false,
-        material: {}
-      },
-    };
-  }
-
-  areaRender() {
-    switch (this.props.banner) {
-      case "Recursos":
-        return (
-          <React.Fragment>
-            <div style={{ backgroundColor: "#ff7f00", position: "relative" }}>
-              <div style={{ textAlign: "justify", color: "#fff", minHeight: 195, paddingLeft: 10, paddingRight: 10, paddingTop: 20, paddingBottom: 20 }}>
-                <img
-                  src={recursos}
-                  alt="aba recursos"
-                  height="155"
-                  style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
-                />
-                <p style={{ textAlign: "justify", color: "#fff", marginRight: window.innerWidth >= 825 ? "25%" : "0px" }}>
-                  Nesta área, você tem acesso a Recursos Educacionais
-                  Digitais, isto é, a vídeos, animações e a outros recursos
-                  destinados à educação. São Recursos de portais parceiros
-                  do MEC e de professores que, como você, atuam na Educação
-                  Básica!
-                    </p>
-              </div>
-            </div>
-            <Container style={{ padding: "20px" }}>
-              <p
-                style={{
-                  paddingBottom: "5px",
-                  borderBottom: "1px solid #ff7f00",
-                  color: "#ff7f00",
-                }}
-              >
-                Recursos mais recentes{" "}
-              </p>
-              <Hidden sm xs>
-                <ReqResources />
-              </Hidden>
-              <Visible sm xs>
-                <ReqResources />
-              </Visible>
-            </Container>
-          </React.Fragment>
-        );
-      case "Materiais":
-
-        const HandleExpandMaterial = (id) => {
-          if (id !== this.state.currMaterial.material.id)
-            this.setState({
-              currMaterial: {
-                open: true,
-                material: { ...materials[id] }
-              }
-            })
-          else
-            this.setState({
-              currMaterial: {
-                open: false,
-                material: {}
-              }
-            })
-        }
-
-
-        return (
-          <React.Fragment>
-            <div style={{ backgroundColor: "#e81f4f", position: "relative" }}>
-              <div style={{ textAlign: "justify", color: "#fff", minHeight: 195, paddingLeft: 10, paddingRight: 10, paddingTop: 20, paddingBottom: 20 }}>
-                <img
-                  src={materiais}
-                  alt="aba recursos"
-                  height="155"
-                  style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
-                />
-                <p style={{ textAlign: "justify", color: "#fff", marginRight: window.innerWidth >= 825 ? "25%" : "0px" }}>
-                  Nesta área, você acessa livremente materiais completos de
-                  formação, como cursos já oferecidos pelo MEC e seus
-                  parceiros. São conteúdos elaborados por equipes
-                  multidisciplinares e de autoria de pesquisadores e
-                  educadores renomados nas áreas.
-                    </p>
-              </div>
-            </div>
-            <Container style={{ padding: "20px" }}>
-              <p
-                style={{
-                  paddingBottom: "5px",
-                  borderBottom: "1px solid #e81f4f",
-                  color: "#e81f4f",
-                }}
-              >
-                Materiais mais recentes{" "}
-              </p>
-
-              <Carousel
-                style={{ padding: "20px" }}
-                showThumbs={false}
-                infiniteLoop={true}
-                showStatus={false}
-              >
-                <Row>
-                  {
-                    materials.map((material, index) => {
-                      return (
-                        <Col md={3} key={index}>
-                          <MaterialCard
-                            name={material.name}
-                            thumb={material.img}
-                            score={material.score}
-                            modules={material.topics}
-                            handleExpand={HandleExpandMaterial}
-                            id={index}
-                          />
-                        </Col>
-                      )
-                    })
-                  }
-                </Row>
-              </Carousel>
-              {
-                this.state.currMaterial.open ?
-                  <ExpandedMaterial material={this.state.currMaterial.material} />
-                  :
-                  null
-              }
-            </Container>
-          </React.Fragment >
-        );
-      case "Colecoes":
-        return (
-          <React.Fragment>
-            <div style={{ backgroundColor: "#673ab7", position: "relative" }}>
-              <div style={{ textAlign: "justify", color: "#fff", minHeight: 195, paddingLeft: 10, paddingRight: 10, paddingTop: 20, paddingBottom: 20 }}>
-                <img
-                  src={colecoes}
-                  alt="aba recursos"
-                  height="155"
-                  style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
-                />
-                <p style={{ textAlign: "justify", color: "#fff", marginRight: window.innerWidth >= 825 ? "25%" : "0px" }}>
-                  Nesta área, você tem acesso às coleções criadas e
-                  organizadas pelos usuários da plataforma. É mais uma
-                  possibilidade de buscar recursos educacionais para sua
-                  aula!
-                    </p>
-              </div>
-            </div>
-            <Container style={{ padding: "20px" }}>
-              <p
-                style={{
-                  paddingBottom: "5px",
-                  borderBottom: "1px solid #673ab7",
-                  color: "#673ab7",
-                }}
-              >
-                Coleções mais recentes{" "}
-              </p>
-              <ReqCollections />
-            </Container>
-          </React.Fragment>
-        );
-      default:
-        return null;
-    }
-  }
-
-  render() {
-    return <div>{this.areaRender()}</div>;
-  }
-}
-
-
-export default SubPages;
diff --git a/src/Components/AreasSubPagesFunction.js b/src/Components/AreasSubPagesFunction.js
index 72046e4d265381f4029a7135eb4c7b8748c6e394..8670178587cacf74b98445342206d7a2a7b04f95 100644
--- a/src/Components/AreasSubPagesFunction.js
+++ b/src/Components/AreasSubPagesFunction.js
@@ -23,9 +23,6 @@ import styled from 'styled-components'
 import MaterialCard from "./MaterialCard";
 import "react-responsive-carousel/lib/styles/carousel.min.css";
 import { Carousel } from "react-responsive-carousel";
-import recursos from "../img/ilustra_recursos_digitais.png";
-import materiais from "../img/ilustra_materiais.png";
-import colecoes from "../img/ilustra_colecoes.png";
 import ResourceCardFunction from "./ResourceCardFunction.js";
 import CollectionCardFunction from "./CollectionCardFunction.js";
 import colecoes_obj from './FormationMaterialsResources/formationMaterials';
@@ -36,510 +33,520 @@ import { getRequest } from './HelperFunctions/getAxiosConfig.js'
 import Grid from '@material-ui/core/Grid';
 import { Link } from 'react-router-dom'
 import { CircularProgress } from "@material-ui/core";
-import ColecaoVazia from '../img/Pagina_vazia_colecao.png'
-import RecursoVazio from '../img/Pagina_vazia_Sem_publicar.png'
+
+//Image Import
+import { recursos } from "ImportImages.js";
+import { materiais } from "ImportImages.js";
+import { colecoes } from "ImportImages.js";
+import { ColecaoVazia } from "ImportImages.js";
+import { RecursoVazio } from "ImportImages.js";
 
 function objectsPerPage() {
-  var pageWidth = window.innerWidth
-  if (pageWidth >= 1200) {
-    return 3
-  }
-  else {
-    if (pageWidth > 766) {
-      return 2
+    var pageWidth = window.innerWidth
+    if (pageWidth >= 1200) {
+        return 3
     }
     else {
-      return 1
+        if (pageWidth > 766) {
+            return 2
+        }
+        else {
+            return 1
+        }
     }
-  }
 }
 
 function ReqResources(props) {
-  const [rows, setRows] = useState([])
-  const [isLoading, setIsLoading] = useState(false)
-
-  function onSuccessfulGet(data) {
-    var aux = []
-    var resources_per_page = objectsPerPage()
-    for (let i = 0; i < 12 / resources_per_page; i++) {
-      aux.push(data.slice(i * resources_per_page, resources_per_page * (i + 1)))
+    const [rows, setRows] = useState([])
+    const [isLoading, setIsLoading] = useState(false)
+
+    function onSuccessfulGet(data) {
+        var aux = []
+        var resources_per_page = objectsPerPage()
+        for (let i = 0; i < 12 / resources_per_page; i++) {
+        aux.push(data.slice(i * resources_per_page, resources_per_page * (i + 1)))
+        }
+        setRows(aux)
+        setIsLoading(false)
     }
-    setRows(aux)
-    setIsLoading(false)
-  }
 
-  useEffect(() => {
-    setIsLoading(true)
-    const url = `/search?page=0&results_per_page=12&order=${props.order}&query=*&search_class=LearningObject`
+    useEffect(() => {
+        setIsLoading(true)
+        const url = `/search?page=0&results_per_page=12&order=${props.order}&query=*&search_class=LearningObject`
 
-    getRequest(url, (data) => onSuccessfulGet(data), (error) => { console.log(error) })
-  }, [props.order])
+        getRequest(url, (data) => onSuccessfulGet(data), (error) => { console.log(error) })
+    }, [props.order])
 
-  return (
-    isLoading ?
-      <Grid container justify="center" alignItems="center" style={{ margin: "2em" }} >
-        <Grid item>
-          <CircularProgress size={24} color="#ff7f00" />
-        </Grid>
-      </Grid>
-      :
-      <Carousel showThumbs={false} infiniteLoop={true} showStatus={false}>
-        {
-          rows.length >= 1 ?
-            rows.map((row, index) => (
-              <Row style={{ paddingBottom: "5px", margin: '0 auto', width: "80%", justifyContent: "center", minHeight: "50px" }} key={(index + 1)}>
-                {row.map((card) => (
-                  <div style={{ marginLeft: 10, display: 'flex' }} key={card.id * (index + 1)}>
-                    <ResourceCardFunction
-                      avatar={card.publisher.avatar}
-                      id={card.id}
-                      thumbnail={card.thumbnail}
-                      type={card.object_type ? card.object_type : "Outros"}
-                      title={card.name}
-                      published={card.state === "published" ? true : false}
-                      likeCount={card.likes_count}
-                      liked={card.liked}
-                      rating={card.review_average}
-                      author={card.publisher.name}
-                      tags={card.tags}
-                      href={"/recurso/" + card.id}
-                      downloadableLink={card.default_attachment_location}
-                    />
-                  </div>
-                ))}
-              </Row>
-            ))
-            :
-            <Grid container justify="center" alignItems="center">
-              <Grid item>
-                <img src={RecursoVazio} alt="Não há recursos" />
-              </Grid>
+    return (
+        isLoading ?
+        <Grid container justify="center" alignItems="center" style={{ margin: "2em" }} >
+            <Grid item>
+            <CircularProgress size={24} color="#ff7f00" />
             </Grid>
-        }
-      </Carousel>
+        </Grid>
+        :
+        <Carousel showThumbs={false} infiniteLoop={true} showStatus={false}>
+            {
+            rows.length >= 1 ?
+                rows.map((row, index) => (
+                <Row style={{ paddingBottom: "5px", margin: '0 auto', width: "80%", justifyContent: "center", minHeight: "50px" }} key={(index + 1)}>
+                    {row.map((card) => (
+                    <div style={{ marginLeft: 10, display: 'flex' }} key={card.id * (index + 1)}>
+                        <ResourceCardFunction
+                        avatar={card.publisher.avatar}
+                        id={card.id}
+                        thumbnail={card.thumbnail}
+                        type={card.object_type ? card.object_type : "Outros"}
+                        title={card.name}
+                        published={card.state === "published" ? true : false}
+                        likeCount={card.likes_count}
+                        liked={card.liked}
+                        rating={card.review_average}
+                        author={card.publisher.name}
+                        tags={card.tags}
+                        href={"/recurso/" + card.id}
+                        downloadableLink={card.default_attachment_location}
+                        />
+                    </div>
+                    ))}
+                </Row>
+                ))
+                :
+                <Grid container justify="center" alignItems="center">
+                <Grid item>
+                    <img src={RecursoVazio} alt="Não há recursos" />
+                </Grid>
+                </Grid>
+            }
+        </Carousel>
 
-  )
+    )
 }
 
 function ReqCollections(props) {
-  const [rows, setRows] = useState([])
-  const [isLoading, setIsLoading] = useState(false)
-
-  function onSuccessfulGet(data) {
-    var aux = []
-    var collections_per_page = objectsPerPage()
-    for (let i = 0; i < 12 / collections_per_page; i++) {
-      aux.push(data.slice(i * collections_per_page, collections_per_page * (i + 1)))
+    const [rows, setRows] = useState([])
+    const [isLoading, setIsLoading] = useState(false)
+
+    function onSuccessfulGet(data) {
+        var aux = []
+        var collections_per_page = objectsPerPage()
+        for (let i = 0; i < 12 / collections_per_page; i++) {
+        aux.push(data.slice(i * collections_per_page, collections_per_page * (i + 1)))
+        }
+        setIsLoading(false)
+        setRows(aux)
     }
-    setIsLoading(false)
-    setRows(aux)
-  }
 
-  useEffect(() => {
-    setIsLoading(true)
-    const url = `/search?page=0&results_per_page=12&order=${props.order}&query=*&search_class=Collection`
+    useEffect(() => {
+        setIsLoading(true)
+        const url = `/search?page=0&results_per_page=12&order=${props.order}&query=*&search_class=Collection`
 
-    getRequest(url, (data) => onSuccessfulGet(data), (error) => { console.log(error) })
-  }, [props.order])
+        getRequest(url, (data) => onSuccessfulGet(data), (error) => { console.log(error) })
+    }, [props.order])
 
-  return (
-    isLoading ?
-      <Grid container justify="center" alignItems="center" style={{ marginTop: "2em" }}>
+    return (
+        isLoading ?
+        <Grid container justify="center" alignItems="center" style={{ marginTop: "2em" }}>
         <Grid item>
-          <CircularProgress size={24} color="#673ab7" />
+            <CircularProgress size={24} color="#673ab7" />
         </Grid>
-      </Grid>
-      :
-      rows.length >= 1 ?
-        <Carousel showThumbs={false} infiniteLoop={true} showStatus={false}>
-          {
-            rows.map((row, index) => (
-              <Row style={{ paddingBottom: "5px", margin: '0 auto', width: "80%", justifyContent: "center", minHeight: "50px" }} key={(index + 1)}>
-                {row.map((card) => (
-                  <div style={{ marginLeft: 10, display: 'flex' }} key={card.id * (index + 1)}>
-                    <CollectionCardFunction
-                      name={card.name}
-                      tags={card.tags}
-                      rating={card.score}
-                      id={card.id}
-                      author={card.owner ? card.owner.name : ""}
-                      description={card.description}
-                      thumbnails={card.items_thumbnails}
-                      avatar={card.owner ? card.owner.avatar : ""}
-                      likeCount={card.likes_count}
-                      followed={card.followed}
-                      liked={card.liked}
-                      collections={card.collection_items}
-                      authorID={card.owner ? card.owner.id : ""}
-                    />
-                  </div>
+        </Grid>
+        :
+        rows.length >= 1 ?
+            <Carousel showThumbs={false} infiniteLoop={true} showStatus={false}>
+                {
+                rows.map((row, index) => (
+                    <Row style={{ paddingBottom: "5px", margin: '0 auto', width: "80%", justifyContent: "center", minHeight: "50px" }} key={(index + 1)}>
+                    {row.map((card) => (
+                        <div style={{ marginLeft: 10, display: 'flex' }} key={card.id * (index + 1)}>
+                        <CollectionCardFunction
+                            name={card.name}
+                            tags={card.tags}
+                            rating={card.score}
+                            id={card.id}
+                            author={card.owner ? card.owner.name : ""}
+                            description={card.description}
+                            thumbnails={card.items_thumbnails}
+                            avatar={card.owner ? card.owner.avatar : ""}
+                            likeCount={card.likes_count}
+                            followed={card.followed}
+                            liked={card.liked}
+                            collections={card.collection_items}
+                            authorID={card.owner ? card.owner.id : ""}
+                        />
+                        </div>
+                    ))}
+                    </Row>
                 ))}
-              </Row>
-            ))}
-        </Carousel>
+            </Carousel>
         :
-        <Grid container justify="center" alignItems="center">
-          <Grid item>
-            <img src={ColecaoVazia} alt="Não há coleções" />
-          </Grid>
-        </Grid>
-  )
+            <Grid container justify="center" alignItems="center">
+                <Grid item>
+                <img src={ColecaoVazia} alt="Não há coleções" />
+                </Grid>
+            </Grid>
+    )
+}
+
+function ReqMaterials(props) {
+    const materials = colecoes_obj();
+  
+    const handleExpandMaterial = (id) => {
+        if (id !== props.currMaterial.material.id)
+            props.setCurrMaterial({
+                open: true,
+                material: { ...materials[id] }
+            })
+        else
+            props.setCurrMaterial({
+                open: false,
+                material: {}
+            })
+    }
+
+    return (
+        <Row>
+        {
+            materials.map((material, index) => {
+                return (
+                    <Col md={3} key={index}>
+                        <MaterialCard
+                        name={material.name}
+                        thumb={material.img}
+                        score={material.score}
+                        modules={material.topics}
+                        handleExpand={handleExpandMaterial}
+                        id={index}
+                        />
+                    </Col>
+                )
+            })
+        }
+        </Row>
+    )
 }
 
 function TabRecurso() {
-  const text = "Nesta área, você tem acesso a Recursos Educacionais Digitais, isto é, a vídeos, animações e a outros recursos destinados à educação. São Recursos de portais parceiros do MEC e de professores que, como você, atuam na Educação Básica!"
-  const [currOrder, setCurrOrder] = useState("Mais Relevante");
-  const [currValue, setCurrValue] = useState("score");
-  const [ordenar] = useState([
-    { label: "Mais Estrelas", value: "review_average" },
-    { label: "Mais Relevante", value: "score" },
-    { label: "Mais Baixados", value: "downloads" },
-    { label: "Mais Favoritados", value: "likes" },
-    { label: "Mais Recentes", value: "publicationdesc" },
-    { label: "Ordem Alfabética", value: "title" },
-  ]);
-
-  return (
-    <React.Fragment>
-      <div style={{ backgroundColor: "#ff7f00", position: "relative" }}>
-        <StyledTab container>
-          <Grid item md={3} xs={12}>
-            <img
-              src={recursos}
-              alt="aba recursos"
-              style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
-            />
-          </Grid>
-          {
-            window.innerWidth <= 501 &&
-            <h4>
-              Recursos Educacionais Digitais
-                        </h4>
-          }
-          <Grid item md={6} xs={12}>
-            <p>
-              {text}
-            </p>
-          </Grid>
-          {
-            window.innerWidth <= 501 &&
-            <div style={{ display: "flex", justifyContent: "center" }}>
-              <Link to={`/busca?page=0&results_per_page=12&order=review_average&query=*&search_class=LearningObject`} className="button-ver">VER RECURSOS</Link>
-            </div>
-          }
-        </StyledTab>
-      </div>
-      {
-        window.innerWidth > 501 &&
-        <Container style={{ padding: "20px" }}>
-          <Grid
-            container
-            direction="row"
-            justify="space-between"
-            alignItems="center"
-            style={{
-              paddingBottom: "5px",
-              borderBottom: "1px solid #ff7f00",
-              color: "#ff7f00",
-            }}
-          >
-            <Grid item>
-              <p
-                style={{ margin: 0, padding: 0 }}
-              >
-                {
-                  `Recursos ${currOrder}`
-                }
-              </p>
+    const text = "Nesta área, você tem acesso a Recursos Educacionais Digitais, isto é, a vídeos, animações e a outros recursos destinados à educação. São Recursos de portais parceiros do MEC e de professores que, como você, atuam na Educação Básica!"
+    const [currOrder, setCurrOrder] = useState("Mais Relevante");
+    const [currValue, setCurrValue] = useState("score");
+    const [ordenar] = useState([
+        { label: "Mais Estrelas", value: "review_average" },
+        { label: "Mais Relevante", value: "score" },
+        { label: "Mais Baixados", value: "downloads" },
+        { label: "Mais Favoritados", value: "likes" },
+        { label: "Mais Recentes", value: "publicationdesc" },
+        { label: "Ordem Alfabética", value: "title" },
+    ]);
+
+    return (
+        <React.Fragment>
+        <div style={{ backgroundColor: "#ff7f00", position: "relative" }}>
+            <StyledTab container>
+            <Grid item md={3} xs={12}>
+                <img
+                src={recursos}
+                alt="aba recursos"
+                style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
+                />
             </Grid>
-
-            <Grid item>
-              <Grid container direction="row" alignItems="center" spacing={1}>
+            {
+                window.innerWidth <= 501 &&
+                <h4>
+                Recursos Educacionais Digitais
+                            </h4>
+            }
+            <Grid item md={6} xs={12}>
+                <p>
+                {text}
+                </p>
+            </Grid>
+            {
+                window.innerWidth <= 501 &&
+                <div style={{ display: "flex", justifyContent: "center" }}>
+                <Link to={`/busca?page=0&results_per_page=12&order=review_average&query=*&search_class=LearningObject`} className="button-ver">VER RECURSOS</Link>
+                </div>
+            }
+            </StyledTab>
+        </div>
+        {
+            window.innerWidth > 501 &&
+            <Container style={{ padding: "20px" }}>
+            <Grid
+                container
+                direction="row"
+                justify="space-between"
+                alignItems="center"
+                style={{
+                paddingBottom: "5px",
+                borderBottom: "1px solid #ff7f00",
+                color: "#ff7f00",
+                }}
+            >
                 <Grid item>
-                  <p style={{ margin: 0, padding: 0 }}>
-                    Ordenar por:
-                  </p>
+                <p
+                    style={{ margin: 0, padding: 0 }}
+                >
+                    {
+                    `Recursos ${currOrder}`
+                    }
+                </p>
                 </Grid>
+
                 <Grid item>
-                  <TextField
-                    select
-                    fullWidth
-                    value={currValue}
-                    variant="outlined"
-                  >
-                    {ordenar.map((option) => (
-                      <MenuItem
-                        key={option.value}
-                        value={option.value}
-                        name={option.value}
-                        onClick={() => {
-                          setCurrOrder(option.label)
-                          setCurrValue(option.value)
-                        }}
-                      >
-                        <span style={currValue === option.value ? { color: "#ff7f00" } : null} >
-                          {option.label}
-                        </span>
-                      </MenuItem>
-                    ))}
-                  </TextField>
+                <Grid container direction="row" alignItems="center" spacing={1}>
+                    <Grid item>
+                    <p style={{ margin: 0, padding: 0 }}>
+                        Ordenar por:
+                    </p>
+                    </Grid>
+                    <Grid item>
+                    <TextField
+                        select
+                        fullWidth
+                        value={currValue}
+                        variant="outlined"
+                    >
+                        {ordenar.map((option) => (
+                        <MenuItem
+                            key={option.value}
+                            value={option.value}
+                            name={option.value}
+                            onClick={() => {
+                            setCurrOrder(option.label)
+                            setCurrValue(option.value)
+                            }}
+                        >
+                            <span style={currValue === option.value ? { color: "#ff7f00" } : null} >
+                            {option.label}
+                            </span>
+                        </MenuItem>
+                        ))}
+                    </TextField>
+                    </Grid>
+                </Grid>
                 </Grid>
-              </Grid>
             </Grid>
-          </Grid>
-          <Hidden sm xs>
-            <ReqResources order={currValue} />
-          </Hidden>
-          <Visible sm xs>
-            <ReqResources order={currValue} />
-          </Visible>
-        </Container>
-      }
-    </React.Fragment>
-  )
+            <Hidden sm xs>
+                <ReqResources order={currValue} />
+            </Hidden>
+            <Visible sm xs>
+                <ReqResources order={currValue} />
+            </Visible>
+            </Container>
+        }
+        </React.Fragment>
+    )
 }
 
 function TabColecoes() {
-  const text = "Nesta área, você tem acesso às coleções criadas e organizadas pelos usuários da plataforma. É mais uma possibilidade de buscar recursos educacionais para sua aula!"
-  const [currOrder, setCurrOrder] = useState("Mais Relevante");
-  const [currValue, setCurrValue] = useState("score");
-  const [ordenar] = useState([
-    { label: "Mais Estrelas", value: "review_average" },
-    { label: "Mais Relevante", value: "score" },
-    { label: "Mais Baixados", value: "downloads" },
-    { label: "Mais Favoritados", value: "likes" },
-    { label: "Mais Recentes", value: "publicationdesc" },
-    { label: "Ordem Alfabética", value: "title" },
-  ]);
-
-  return (
-    <React.Fragment>
-      <div style={{ backgroundColor: "#673ab7", position: "relative" }}>
-        <StyledTab container>
-          <Grid item md={3} xs={12}>
-            <img
-              src={colecoes}
-              alt="aba recursos"
-              style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
-            />
-          </Grid>
-          {
-            window.innerWidth <= 501 &&
-            <h4>
-              Coleções dos Usuários
-                        </h4>
-          }
-          <Grid item md={6} xs={12}>
-            <p>
-              {text}
-            </p>
-          </Grid>
-          {
-            window.innerWidth <= 501 &&
-            <div style={{ display: "flex", justifyContent: "center" }}>
-              <Link to={`/busca?page=0&results_per_page=12&order=review_average&query=*&search_class=Collection`} className="button-ver">VER COLEÇÕES</Link>
-            </div>
-          }
-        </StyledTab>
-      </div>
-      {
-        window.innerWidth > 501 &&
-        <Container style={{ padding: "20px" }}>
-          <Grid
-            container
-            direction="row"
-            justify="space-between"
-            alignItems="center"
-            style={{
-              paddingBottom: "5px",
-              borderBottom: "1px solid #673ab7",
-              color: "#673ab7",
-            }}
-          >
-            <Grid item>
-              <p
-                style={{ margin: 0, padding: 0 }}
-              >
-                {
-                  `Coleções ${currOrder}`
-                }
-              </p>
+    const text = "Nesta área, você tem acesso às coleções criadas e organizadas pelos usuários da plataforma. É mais uma possibilidade de buscar recursos educacionais para sua aula!"
+    const [currOrder, setCurrOrder] = useState("Mais Relevante");
+    const [currValue, setCurrValue] = useState("score");
+    const [ordenar] = useState([
+        { label: "Mais Estrelas", value: "review_average" },
+        { label: "Mais Relevante", value: "score" },
+        { label: "Mais Baixados", value: "downloads" },
+        { label: "Mais Favoritados", value: "likes" },
+        { label: "Mais Recentes", value: "publicationdesc" },
+        { label: "Ordem Alfabética", value: "title" },
+    ]);
+
+    return (
+        <React.Fragment>
+        <div style={{ backgroundColor: "#673ab7", position: "relative" }}>
+            <StyledTab container>
+            <Grid item md={3} xs={12}>
+                <img
+                src={colecoes}
+                alt="aba recursos"
+                style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
+                />
             </Grid>
-
-            <Grid item>
-              <Grid container direction="row" alignItems="center" spacing={1}>
+            {
+                window.innerWidth <= 501 &&
+                <h4>
+                Coleções dos Usuários
+                            </h4>
+            }
+            <Grid item md={6} xs={12}>
+                <p>
+                {text}
+                </p>
+            </Grid>
+            {
+                window.innerWidth <= 501 &&
+                <div style={{ display: "flex", justifyContent: "center" }}>
+                <Link to={`/busca?page=0&results_per_page=12&order=review_average&query=*&search_class=Collection`} className="button-ver">VER COLEÇÕES</Link>
+                </div>
+            }
+            </StyledTab>
+        </div>
+        {
+            window.innerWidth > 501 &&
+            <Container style={{ padding: "20px" }}>
+            <Grid
+                container
+                direction="row"
+                justify="space-between"
+                alignItems="center"
+                style={{
+                paddingBottom: "5px",
+                borderBottom: "1px solid #673ab7",
+                color: "#673ab7",
+                }}
+            >
                 <Grid item>
-                  <p style={{ margin: 0, padding: 0 }}>
-                    Ordenar por:
-                                    </p>
+                <p
+                    style={{ margin: 0, padding: 0 }}
+                >
+                    {
+                    `Coleções ${currOrder}`
+                    }
+                </p>
                 </Grid>
+
                 <Grid item>
-                  <TextField
-                    select
-                    fullWidth
-                    value={currValue}
-                    variant="outlined"
-                  >
-                    {ordenar.map((option) => (
-                      <MenuItem
-                        key={option.value}
-                        value={option.value}
-                        name={option.value}
-                        onClick={() => {
-                          setCurrOrder(option.label)
-                          setCurrValue(option.value)
-                        }}
-                      >
-                        <span style={currValue === option.value ? { color: "#673ab7" } : null} >
-                          {option.label}
-                        </span>
-                      </MenuItem>
-                    ))}
-                  </TextField>
+                <Grid container direction="row" alignItems="center" spacing={1}>
+                    <Grid item>
+                    <p style={{ margin: 0, padding: 0 }}>
+                        Ordenar por:
+                                        </p>
+                    </Grid>
+                    <Grid item>
+                    <TextField
+                        select
+                        fullWidth
+                        value={currValue}
+                        variant="outlined"
+                    >
+                        {ordenar.map((option) => (
+                        <MenuItem
+                            key={option.value}
+                            value={option.value}
+                            name={option.value}
+                            onClick={() => {
+                            setCurrOrder(option.label)
+                            setCurrValue(option.value)
+                            }}
+                        >
+                            <span style={currValue === option.value ? { color: "#673ab7" } : null} >
+                            {option.label}
+                            </span>
+                        </MenuItem>
+                        ))}
+                    </TextField>
+                    </Grid>
+                </Grid>
                 </Grid>
-              </Grid>
             </Grid>
-          </Grid>
-          <ReqCollections order={currValue} />
-        </Container>
-      }
-    </React.Fragment>
-  )
+            <ReqCollections order={currValue} />
+            </Container>
+        }
+        </React.Fragment>
+    )
 }
 
 function TabMateriais() {
-  const text = "Nesta área, você acessa livremente materiais completos de formação, como cursos já oferecidos pelo MEC e seus parceiros. São conteúdos elaborados por equipes multidisciplinares e de autoria de pesquisadores e educadores renomados nas áreas."
-
-  const materials = colecoes_obj()
-
-  const [currMaterial, setCurrMaterial] = useState({
-    open: false,
-    material: {}
-  })
+    const text = "Nesta área, você acessa livremente materiais completos de formação, como cursos já oferecidos pelo MEC e seus parceiros. São conteúdos elaborados por equipes multidisciplinares e de autoria de pesquisadores e educadores renomados nas áreas."
 
-  const handleExpandMaterial = (id) => {
-    if (id !== currMaterial.material.id)
-      setCurrMaterial({
-        open: true,
-        material: { ...materials[id] }
-      })
-    else {
-      setCurrMaterial({
+    const [currMaterial, setCurrMaterial] = useState({
         open: false,
         material: {}
-      })
-    }
-  }
-
-  return (
-    <React.Fragment>
-      <div style={{ backgroundColor: "#e81f4f", position: "relative" }}>
-        <StyledTab container>
-          <Grid item md={3} xs={12}>
-            <img
-              src={materiais}
-              alt="aba recursos"
-              style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
-            />
-          </Grid>
-          {
-            window.innerWidth <= 501 &&
-            <h4>
-              Materiais de formação
-                        </h4>
-          }
-          <Grid item md={6} xs={12}>
-            <p>
-              {text}
-            </p>
-          </Grid>
-          {
-            window.innerWidth <= 501 &&
-            <div style={{ display: "flex", justifyContent: "center" }}>
-              <Link to={`/material-formacao`} className="button-ver">VER MATERIAIS</Link>
+    })
+
+    return (
+        <React.Fragment>
+            <div style={{ backgroundColor: "#e81f4f", position: "relative" }}>
+                <StyledTab container>
+                <Grid item md={3} xs={12}>
+                    <img
+                    src={materiais}
+                    alt="aba recursos"
+                    style={{ float: "left", marginRight: 20, marginBottom: 20, marginLeft: window.innerWidth >= 825 ? "25%" : "0px" }}
+                    />
+                </Grid>
+                {
+                    window.innerWidth <= 501 &&
+                    <h4>
+                    Materiais de formação
+                                </h4>
+                }
+                <Grid item md={6} xs={12}>
+                    <p>
+                    {text}
+                    </p>
+                </Grid>
+                {
+                    window.innerWidth <= 501 &&
+                    <div style={{ display: "flex", justifyContent: "center" }}>
+                    <Link to={`/material-formacao`} className="button-ver">VER MATERIAIS</Link>
+                    </div>
+                }
+                </StyledTab>
             </div>
-          }
-        </StyledTab>
-      </div>
-      {
-        window.innerWidth > 501 &&
-        <Container style={{ padding: "20px" }}>
-          <p
-            style={{
-              paddingBottom: "5px",
-              borderBottom: "1px solid #e81f4f",
-              color: "#e81f4f",
-            }}
-          >
-            Materiais mais recentes{" "}
-          </p>
-          <Carousel
-            style={{ padding: "20px" }}
-            showThumbs={false}
-            infiniteLoop={true}
-            showStatus={false}
-          >
-            <Row>
-              {
-                materials.map((material, index) => {
-                  return (
-                    <Col md={3} key={index}>
-                      <MaterialCard
-                        name={material.name}
-                        thumb={material.img}
-                        score={material.score}
-                        modules={material.topics}
-                        handleExpand={handleExpandMaterial}
-                        id={index}
-                      />
-                    </Col>
-                  )
-                })
-              }
-            </Row>
-          </Carousel>
-          {
-            currMaterial.open ?
-              <ExpandedMaterial material={currMaterial.material} />
-              :
-              null
-          }
-        </Container>
-      }
+            {
+            window.innerWidth > 501 &&
+            <Container style={{ padding: "20px" }}>
+                <p
+                    style={{
+                        paddingBottom: "5px",
+                        borderBottom: "1px solid #e81f4f",
+                        color: "#e81f4f",
+                    }}
+                >
+                    Materiais mais recentes{" "}
+                </p>
+                <Carousel
+                    style={{ padding: "20px" }}
+                    showThumbs={false}
+                    infiniteLoop={true}
+                    showStatus={false}
+                >
+                    <ReqMaterials currMaterial={currMaterial} setCurrMaterial={setCurrMaterial} />
+                </Carousel>
+                {
+                    currMaterial.open ?
+                    <ExpandedMaterial material={currMaterial.material} />
+                    :
+                    null
+                }
+            </Container>
+        }
     </React.Fragment >
   )
 }
 
 export default function AreasSubPages(props) {
 
-  const areaRender = () => {
-    switch (props.banner) {
-      case "Recursos":
-        return <TabRecurso />
-      case "Materiais":
-        return <TabMateriais />
-      case "Colecoes":
-        return <TabColecoes />
-      default:
-        return null
+    const areaRender = () => {
+        switch (props.banner) {
+        case "Recursos":
+            return <TabRecurso />
+        case "Materiais":
+            return <TabMateriais />
+        case "Colecoes":
+            return <TabColecoes />
+        default:
+            return null
+        }
     }
-  }
-
-  return (
-    <React.Fragment>
-      {
-        window.innerWidth <= 501 ? (
-          <React.Fragment>
-            <TabRecurso />
-            <TabMateriais />
-            <TabColecoes />
-          </React.Fragment>
-        ) : (
-            areaRender()
-          )
-      }
-    </React.Fragment>
-  )
+
+    return (
+        <React.Fragment>
+        {
+            window.innerWidth <= 501 ? (
+            <React.Fragment>
+                <TabRecurso />
+                <TabMateriais />
+                <TabColecoes />
+            </React.Fragment>
+            ) : (
+                areaRender()
+            )
+        }
+        </React.Fragment>
+    )
 }
 
 const StyledTab = styled(Grid)`
diff --git a/src/Components/CardOptions.js b/src/Components/CardOptions.js
deleted file mode 100644
index 4c10b4239ef6950f63020e83d6f3631c81fb3e96..0000000000000000000000000000000000000000
--- a/src/Components/CardOptions.js
+++ /dev/null
@@ -1,77 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React from 'react';
-import Button from '@material-ui/core/Button';
-import Menu from '@material-ui/core/Menu';
-import ListItemIcon from '@material-ui/core/ListItemIcon';
-import MenuItem from '@material-ui/core/MenuItem';
-import MoreVertIcon from '@material-ui/icons/MoreVert';
-import OpenIcon from '@material-ui/icons/OpenInNew';
-import DownloadIcon from '@material-ui/icons/CloudDownload';
-import ShareIcon from '@material-ui/icons/Share';
-import AddIcon from '@material-ui/icons/CreateNewFolder';
-import ReportIcon from '@material-ui/icons/Error';
-
-export default function SimpleMenu() {
-  const [anchorEl, setAnchorEl] = React.useState(null);
-
-  function handleClick(event) {
-    setAnchorEl(event.currentTarget);
-  }
-
-  function handleClose() {
-    setAnchorEl(null);
-  }
-
-  return (
-    <div style={{fontSize: "12px"}}>
-      <Button aria-controls="simple-menu" aria-haspopup="true" onClick={handleClick} style={{color : "#666"}}>
-        OPÇÕES <MoreVertIcon style={{color : "inherit"}}/>
-      </Button>
-      <Menu
-        id="simple-menu"
-        anchorEl={anchorEl}
-        keepMounted
-        open={Boolean(anchorEl)}
-        onClose={handleClose}
-      >
-        <MenuItem onClick={handleClose}>
-          <ListItemIcon><OpenIcon /></ListItemIcon>Abrir
-        </MenuItem>
-
-        <MenuItem onClick={handleClose}>
-            <ListItemIcon><DownloadIcon /></ListItemIcon>Baixar
-        </MenuItem>
-
-        <MenuItem onClick={handleClose}>
-            <ListItemIcon><ShareIcon /></ListItemIcon>Compartilhar
-        </MenuItem>
-
-        <MenuItem onClick={handleClose}>
-            <ListItemIcon><AddIcon /></ListItemIcon>Guardar
-        </MenuItem>
-
-        <MenuItem onClick={handleClose}>
-            <ListItemIcon><ReportIcon /></ListItemIcon>Reportar
-        </MenuItem>
-
-      </Menu>
-    </div>
-  );
-}
diff --git a/src/Components/Carousel.js b/src/Components/Carousel.js
index ba3602311c2fa2b3607a89c7e196d01c828ffe4b..dde54bd232c55208fcae91ef2aee236250ac7cfc 100644
--- a/src/Components/Carousel.js
+++ b/src/Components/Carousel.js
@@ -30,20 +30,20 @@ import Handshake from "../img/termos/handshake.svg"
 import Pessoa from "../img/termos/Pessoa.svg"
 import Email from "../img/termos/Email.svg"
 import Seguranca from "../img/termos/Seguranca.svg"
-import Aberto from "../img/termos/Aberto.png";
-import Fechado from "../img/termos/Fechado.png";
 import Arrow_down from "../img/termos/Arrow_down.svg";
 import Arrow_double from "../img/termos/Arrow_double.svg";
-import Arrow_O from "../img/termos/Arrow_O que é a plataforma.png";
-import Arrow_O_1 from "../img/termos/Arrow_O que é a plataforma-1.png";
 import Like from "../img/termos/Like.svg";
 import Unlike from "../img/termos/Unlike.svg";
 import Line from "../img/termos/Line.svg";
 import Entenda from "../img/termos/Entenda.svg";
 import V from "../img/termos/V.svg";
-import OrthogonalLineUp from "../img/termos/OrthogonalLineUp.png"
-import OrthogonalLineDown from "../img/termos/OrthogonalLineDown.png"
-
+//Image Import
+import { Aberto } from "ImportImages.js";
+import { Fechado } from "ImportImages.js";
+import { Arrow_O } from "ImportImages.js";
+import { Arrow_O_1 } from "ImportImages.js";
+import { OrthogonalLineUp } from "ImportImages.js";
+import { OrthogonalLineDown } from "ImportImages.js";
 
 const Slide = styled.div`
 
diff --git a/src/Components/ColaborarModal.js b/src/Components/ColaborarModal.js
index f12fa1100e9976ec96e3155a4a0b5be45e485058..2b98dee6574f58a9134cd32e61884207cab03319 100644
--- a/src/Components/ColaborarModal.js
+++ b/src/Components/ColaborarModal.js
@@ -8,6 +8,8 @@ import CloseIcon from '@material-ui/icons/Close';
 import LabeledCheckbox from "../Components/Checkbox.js"
 import {Link} from 'react-router-dom'
 
+import { Publicar } from "ImportImages.js"; 
+
 const StyledDivContainer = styled.div`
     background-color : rgb(255,255,255);
     border-radius : 4px;
@@ -108,7 +110,7 @@ export default function ColaborarModal (props) {
                     <div style={{padding : "20px 30px"}}>
                         <StyledDivDialogContent>
                             <StyledDivContentInformation
-                            style={{backgroundImage :"url(https://plataformaintegrada.mec.gov.br/img/Publicar.png)",
+                            style={{backgroundImage : Publicar,
                                  backgroundSize : "130px", backgroundPositionY:"20px",
                                 backgroundRepeat:"no-repeat"
                             }}
diff --git a/src/Components/CollectionCard.js b/src/Components/CollectionCard.js
deleted file mode 100644
index a252100acd4083d796247c109c3f99da46ddb7e2..0000000000000000000000000000000000000000
--- a/src/Components/CollectionCard.js
+++ /dev/null
@@ -1,145 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, {Component} from 'react';
-import './CardsAnimation.css';
-import {apiDomain} from '../env';
-import {Col,Row, Container} from 'react-grid-system';
-import Card from '@material-ui/core/Card';
-import CardContent from '@material-ui/core/CardContent';
-import CardActions from '@material-ui/core/CardActions';
-import IconButton from '@material-ui/core/IconButton';
-import FolderIcon from '@material-ui/icons/Folder';
-import FavoriteIcon from '@material-ui/icons/Favorite';
-import noAvatar from "../img/default_profile.png";
-import Rating from '@material-ui/lab/Rating';
-import StarBorderIcon from '@material-ui/icons/StarBorder';
-
-var authorStyle={
-  position: "absolute",
-  display: "flex",
-  backgroundColor: "white",
-  opacity: "0.6",
-  bottom:"0",
-  width: "100%",
-  paddingTop: "20px"
-};
-var pictureStyle={
-  position: "absolute",
-  display: "flex",
-  backgroundColor: "white",
-  borderRadius: "50%",
-  bottom:"7%",
-  left: "37%",
-  height: "70px",
-  width: "70px",
-};
-const slideStyle={
-  height: "50px",
-  width: "50px",
-  backgroundColor: "white",
-  borderRadius: "50%",
-};
-const publisherStyle={
-  color: "white",
-  paddinLeft: "20px",
-  fontSize: "15px"
-
-};
-class RenderThumbs extends Component {
-  render(){
-    if (this.props.thumbs) {
-      var array = this.props.thumbs.slice(0,4);
-      if (array.length < 3) {
-        return(
-          <img height="160" src={apiDomain+array[0]} alt="Thumbnail dos Recursos"/>)
-      }
-    return(
-      <Row>
-        {array.map(thumb => <Col style={{padding: "0px"}} md={6}><img key={thumb.id} height="80" src={apiDomain+thumb} alt="Thumbnail dos Recursos"/> </Col>)}
-      </Row>
-    );
-    }
-    return(null);
-  }
-}
-class CollectionCard extends Component {
-  constructor(props){
-    super(props);
-    this.state={
-      userStyle: "animatiOff",
-      userAvatar: null,
-    };
-  }
-  onHover(){
-    this.setState({userStyle: "animatiOn"});
-  }
-  onIddle(){
-    this.setState({userStyle: "animatiOff"})
-  }
-  defAvatar(){
-    if (!this.state.userAvatar && (!this.props.avatar.length)){
-      this.setState({userAvatar: noAvatar});
-    }
-    if (!this.state.userAvatar && (this.props.avatar.length) ) {
-      this.setState({userAvatar:apiDomain+this.props.avatar});
-    }
-  }
-  render(){
-    this.defAvatar();
-   return (
-     <Card onMouseOver={this.onHover.bind(this)} onMouseOut={this.onIddle.bind(this)} >
-
-
-       <Container style={{padding:"0px", backgroundColor: "#673ab7"}}>
-         <div className={this.state.userStyle}>
-          <img style={slideStyle} src={this.state.userAvatar} alt="Avatar do usuário"/>
-          <div style={publisherStyle}>Enviado por: <br/>{this.props.author}</div>
-          <div> tags </div>
-         </div>
-         <RenderThumbs thumbs={this.props.thumbnail}/>
-         <div style={authorStyle}>
-          <div style={{textAlign: "center"}}>{this.props.name}</div>
-           </div>
-         <img style={pictureStyle} src={this.state.userAvatar} alt="Avatar do usuário"/>
-
-
-       </Container>
-       <CardContent style={{height: "60%", textAlign: "left", paddingBottom: "0px"}}>
-       </CardContent>
-       <Container style={{textAlign: "left"}}>
-       <Rating
-         name="customized-empty"
-         value={this.props.rating*100}
-         precision={0.5}
-         emptyIcon={<StarBorderIcon fontSize="inherit" />}
-       />
-       </Container>
-       <CardActions style={{justifyContent: "space-between"}}>
-         <FolderIcon style={{color:"#673ab7"}} />
-         <IconButton  aria-label="Favoritar" size="small">
-           <FavoriteIcon />
-         </IconButton>
-         </CardActions>
-
-     </Card>
-   );}
- }
-
-
-export default CollectionCard;
diff --git a/src/Components/CollectionCardFunction.js b/src/Components/CollectionCardFunction.js
index dd4e3d079b837960dd76e8621f494404c71ecb47..1a3057ddf92eb5c358443007ce25c7d700ab70be 100644
--- a/src/Components/CollectionCardFunction.js
+++ b/src/Components/CollectionCardFunction.js
@@ -19,7 +19,6 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 import React, { useState, useContext, useEffect } from 'react';
 import { Store } from '../Store.js'
 import { apiDomain } from '../env';
-import noAvatar from "../img/default_profile.png";
 import Button from '@material-ui/core/Button';
 import styled from 'styled-components'
 import Grid from '@material-ui/core/Grid';
@@ -40,6 +39,9 @@ import LoginModal from './LoginModal.js'
 import Snackbar from '@material-ui/core/Snackbar';
 import MuiAlert from '@material-ui/lab/Alert';
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 export default function CollectionCardFunction(props) {
   const { state } = useContext(Store)
 
diff --git a/src/Components/CollectionCommentSection.js b/src/Components/CollectionCommentSection.js
index 49f8861e07ab19e2403bad1e0a64fcee929b9f33..4f16d012eb2e8adf52e53e5aed76fb59e63c291d 100644
--- a/src/Components/CollectionCommentSection.js
+++ b/src/Components/CollectionCommentSection.js
@@ -26,7 +26,6 @@ import CommentForm from './ResourcePageComponents/CommentForm.js';
 import Comment from './Comment.js';
 import Snackbar from '@material-ui/core/Snackbar';
 import MuiAlert from '@material-ui/lab/Alert';
-import Comentario from '../img/comentarios.png';
 import { getRequest } from '../Components/HelperFunctions/getAxiosConfig'
 import ExitToAppIcon from '@material-ui/icons/ExitToApp';
 import SignUpModal from './SignUpModal.js';
@@ -36,6 +35,9 @@ import CircularProgress from '@material-ui/core/CircularProgress';
 import IconButton from '@material-ui/core/IconButton';
 import KeyboardArrowDownIcon from '@material-ui/icons/KeyboardArrowDown';
 
+//Image Import
+import { Comentarios } from "ImportImages.js";
+
 export default function CollectionCommentSection(props) {
 	const [post_snack_open, setPostSnackOpen] = useState(false);
 	const [delete_snack_open, setDeleteSnackOpen] = useState(false);
@@ -135,7 +137,7 @@ export default function CollectionCommentSection(props) {
 		`
 		return (
 			<NoCommentsContainer>
-				<Image src={Comentario} style={{ width: "100%", maxWidth: 234 }} />
+				<Image src={Comentarios} style={{ width: "100%", maxWidth: 234 }} />
 				<BlueTitle>Compartilhe sua opinião com a rede!</BlueTitle>
 				<Secondary>Gostou desta coleção? Comente e compartilhe com a rede sua opinião. Interagindo com a rede, você contribui para que mais coleções como esta sejam criadas.</Secondary>
 				<Button
diff --git a/src/Components/Comment.js b/src/Components/Comment.js
index 4388ec758a2cdc81a97f8b61f7fb3765b3ef5805..b3e1df7a9b286e598a758004a5a721adce5b58ad 100644
--- a/src/Components/Comment.js
+++ b/src/Components/Comment.js
@@ -23,7 +23,6 @@ import Grid from '@material-ui/core/Grid';
 import { Button } from '@material-ui/core';
 import { Link } from 'react-router-dom'
 import { apiDomain } from '../env';
-import noAvatar from "../img/default_profile.png";
 import Rating from '@material-ui/lab/Rating';
 import StarBorderIcon from '@material-ui/icons/StarBorder';
 import EditIcon from '@material-ui/icons/Edit';
@@ -33,6 +32,9 @@ import MenuItem from '@material-ui/core/MenuItem';
 import ModalExcluir from './ModalExcluirComentario.js'
 import { putRequest, deleteRequest } from './HelperFunctions/getAxiosConfig'
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 export default function Comment(props) {
     console.log(props)
     /*
diff --git a/src/Components/ContactButtons/FollowingButton.js b/src/Components/ContactButtons/FollowingButton.js
index 424e8f63a12cb10a40ae64112431b2152bb0c668..87ad2cba7242c0897deccc462eff2ce1c45c8c82 100644
--- a/src/Components/ContactButtons/FollowingButton.js
+++ b/src/Components/ContactButtons/FollowingButton.js
@@ -19,10 +19,12 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 import React, {useState} from 'react'
 import styled from 'styled-components'
 import Button from '@material-ui/core/Button';
-import FollowingIcon from '../../img/how_to_reg-24px.png'
 import ModalConfirmarUnfollow from '../ModalConfirmarUnfollow.js'
 import {putRequest} from '../HelperFunctions/getAxiosConfig'
 
+//Image Import
+import { FollowingIcon } from "ImportImages.js";
+
 export default function FollowingButton (props) {
 
     const [modalOpen, toggleModal] = useState(false)
diff --git a/src/Components/ContactCard.js b/src/Components/ContactCard.js
index bacf2c87feb01ee0f5a236eda286391518314d6c..fa51ee8d8c488679f3428d05c662d0d59d0c1597 100644
--- a/src/Components/ContactCard.js
+++ b/src/Components/ContactCard.js
@@ -19,7 +19,6 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 import React, { useState } from 'react';
 import Card from '@material-ui/core/Card';
 import CardContent from '@material-ui/core/CardContent';
-import noAvatar from "../img/default_profile.png";
 import CardMedia from '@material-ui/core/CardMedia';
 import styled from 'styled-components'
 import Options from './ContactCardOptions.js'
@@ -28,6 +27,9 @@ import FollowingButton from './ContactButtons/FollowingButton.js'
 import FollowersCountButton from './ContactButtons/FollowersCountButton.js'
 import { Link } from 'react-router-dom';
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 export default function ImgMediaCard(props) {
 
     const [followedBoolean, setFollowedBoolean] = useState(props.followed)
diff --git a/src/Components/EcFooter.js b/src/Components/EcFooter.js
index eca582f2730cc230d7554d97acbda3afcfac95f5..2b23f622c8514df9d387e9818d03128fc0c3f180 100644
--- a/src/Components/EcFooter.js
+++ b/src/Components/EcFooter.js
@@ -18,10 +18,12 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React, { Component } from 'react';
 import { Row, Col, Container } from 'react-grid-system';
-import eduConectada from '../img/educa-conectada.png';
 import styled from 'styled-components';
 import { HashLink as Link } from 'react-router-hash-link';
 
+//Image Import
+import { eduConectada } from "ImportImages.js";
+
 const BlueFooter = styled.div`
     background-color : #00bcd4;
     color : white;
diff --git a/src/Components/FormationMaterialDescription.js b/src/Components/FormationMaterialDescription.js
index 5771aef3448785bc86fc45db7f65a3a10e353bdc..dc984d1f8286f8f8e7237e8344c33a92ac1c0d5a 100644
--- a/src/Components/FormationMaterialDescription.js
+++ b/src/Components/FormationMaterialDescription.js
@@ -9,6 +9,9 @@ import MoveToInboxIcon from '@material-ui/icons/MoveToInbox';
 import LibraryBooksIcon from '@material-ui/icons/LibraryBooks';
 import TranslateIcon from '@material-ui/icons/Translate';
 
+import { IcNute } from "ImportImages.js"; 
+import { IcPeninsula } from "ImportImages.js"; 
+
 export default function FormationMaterialDescription(props) {
 	/* props
 		*
@@ -96,9 +99,9 @@ export default function FormationMaterialDescription(props) {
 							<br />
 							<StyledAnchor href={colecao_obj.developedurl}>
 								{
-									colecao_obj.id === 3 ? <LongUserIcon src={require("../img/logo_parceiros/ic_peninsula.png")} />
+									colecao_obj.id === 3 ? <LongUserIcon src={IcNute} />
 										: <div>
-											<UserIcon src={require("../img/logo_parceiros/ic_nute.png")} />
+											<UserIcon src={IcPeninsula} />
 											<Red>
 												{colecao_obj.developed}
 											</Red>
diff --git a/src/Components/Funcionalities.js b/src/Components/Funcionalities.js
index d183d855f2cc9e31146c26ec08ea8c4e0e7bfc9e..5a1750b99f1915ed3ca133bfa51038daa6e164f9 100644
--- a/src/Components/Funcionalities.js
+++ b/src/Components/Funcionalities.js
@@ -18,12 +18,14 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React, {Component} from 'react';
 import {Row, Col, Container} from 'react-grid-system';
-import acessar from '../img/nopub-Acessar-materiais.png';
-import baixar from '../img/nopub-Baixar.png';
-import compartilhar from '../img/nopub-Compartilhar.png';
-import relatar from '../img/nopub-Relatar.png';
-import seguir from '../img/nopub-Seguir.png';
-import guardar from '../img/nopub-Guardar.png';
+
+//Image Import
+import { acessar } from "ImportImages.js";
+import { baixar } from "ImportImages.js";
+import { compartilhar } from "ImportImages.js";
+import { relatar } from "ImportImages.js";
+import { seguir } from "ImportImages.js";
+import { guardar } from "ImportImages.js";
 
 const imgRow={
   textAlign: "center",
diff --git a/src/Components/GuardarModal.js b/src/Components/GuardarModal.js
index 2526d20c997cfd6b9433d4b414a282e6968ab384..9b49137c8ea6bfe1403308306be978219949ca02 100644
--- a/src/Components/GuardarModal.js
+++ b/src/Components/GuardarModal.js
@@ -140,7 +140,7 @@ export default function ReportModal(props) {
                         </Header>
                         <Content style={{ paddingTop: "0" }}>
                             <ResourceInfo>
-                                <img src={apiDomain + props.thumb} alt="thumbnail recurso" />
+                                <img src={props.thumb ? apiDomain + props.thumb : require('../img/logo_small.svg')} alt="thumbnail recurso" />
                                 <div className="text">
                                     <h3>{props.title}</h3>
                                 </div>
diff --git a/src/Components/HelpCenter/Cards/CardEncontrando.js b/src/Components/HelpCenter/Cards/CardEncontrando.js
index 173f179d24445dcc8aebdab0ef5ab7bfb59d3eda..fd8aa92928451d05560f0e5824c860d12401d98e 100644
--- a/src/Components/HelpCenter/Cards/CardEncontrando.js
+++ b/src/Components/HelpCenter/Cards/CardEncontrando.js
@@ -18,10 +18,12 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React from "react";
 import styled from "styled-components";
-import EncontrandoRecurso from "../../../img/ajuda/Encontrando_recursos.png";
 
 import { Link } from "react-router-dom";
 
+//Image Import
+import { EncontrandoRecurso } from "ImportImages.js";
+
 export default function CardEncontrando(props) {
   return (
     <CardAjuda>
diff --git a/src/Components/HelpCenter/Cards/CardGerenciando.js b/src/Components/HelpCenter/Cards/CardGerenciando.js
index d3e1daa3299815d50e1c948ce1810d172d49c9ae..3f4da6b0dba1b484aeeae15e935cf57828c10f12 100644
--- a/src/Components/HelpCenter/Cards/CardGerenciando.js
+++ b/src/Components/HelpCenter/Cards/CardGerenciando.js
@@ -18,10 +18,12 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React from "react";
 import styled from "styled-components";
-import GerenciandoConta from "../../../img/ajuda/Gerenciando_a_conta.png";
 
 import { Link } from "react-router-dom";
 
+//Image Import
+import { GerenciandoConta } from "ImportImages.js";
+
 export default function CardGerenciando(props) {
   return (
     <CardAjuda>
diff --git a/src/Components/HelpCenter/Cards/CardParticipando.js b/src/Components/HelpCenter/Cards/CardParticipando.js
index 5091e9908cf3a52399f0ce08907601f24b93618a..31f0ad95a5b97bc70c9931d5a35f4990da8e87ee 100644
--- a/src/Components/HelpCenter/Cards/CardParticipando.js
+++ b/src/Components/HelpCenter/Cards/CardParticipando.js
@@ -18,10 +18,12 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React from "react";
 import styled from "styled-components";
-import ParticipandoRede from "../../../img/ajuda/Participando_da_rede.png";
 
 import { Link } from "react-router-dom";
 
+//Image Import
+import { ParticipandoRede } from "ImportImages.js";
+
 export default function CardParticipando(props) {
   return (
     <CardAjuda>
diff --git a/src/Components/HelpCenter/Cards/CardPublicando.js b/src/Components/HelpCenter/Cards/CardPublicando.js
index c5fb0a3ff925d87a602f30ff467daf95182bc8b9..0c6f489df27ab92bc3cdb617bf90dd4e93a1bd1e 100644
--- a/src/Components/HelpCenter/Cards/CardPublicando.js
+++ b/src/Components/HelpCenter/Cards/CardPublicando.js
@@ -18,9 +18,11 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React from "react";
 import styled from "styled-components";
-import PublicandoRecursos from "../../../img/ajuda/Publicando_recursos.png";
 import { Link } from "react-router-dom";
 
+//Image Import
+import { PublicandoRecursos } from "ImportImages.js";
+
 export default function CardPublicando(props) {
   return (
     <CardAjuda>
diff --git a/src/Components/HelpCenter/TabsManageAc/Forget.js b/src/Components/HelpCenter/TabsManageAc/Forget.js
index c3c247a3a93834ae0bef65bf6e27d393e35b4063..21d598d30610c0463e84e88cad9ce332cd2be6cf 100644
--- a/src/Components/HelpCenter/TabsManageAc/Forget.js
+++ b/src/Components/HelpCenter/TabsManageAc/Forget.js
@@ -19,11 +19,9 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 import React from 'react';
 import styled from 'styled-components';
 
-import LoginImg from '../../../img/ajuda/login_img.jpg'
-import RecuperarSenhaImg from '../../../img/ajuda/recuperarsenha_img.jpg'
-
-
-
+//Image Import
+import { LoginImg } from "ImportImages.js";
+import { RecuperarSenhaImg } from "ImportImages.js";
 
 export default function Forget(props) {
   return(
diff --git a/src/Components/HelpCenter/TabsResourseFind/HowToDo.js b/src/Components/HelpCenter/TabsResourseFind/HowToDo.js
index 65934c1c01e640c5ad316674b38a6787708722f2..204ca709ed9eefa440feea703239043ff35997aa 100644
--- a/src/Components/HelpCenter/TabsResourseFind/HowToDo.js
+++ b/src/Components/HelpCenter/TabsResourseFind/HowToDo.js
@@ -19,10 +19,8 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 import React from 'react';
 import styled from 'styled-components';
 
-import Busca from '../../../img/ajuda/busca_img.jpg'
-
-
-
+//Image Import
+import { Busca } from "ImportImages.js";
 
 export default function HowToDo(props) {
   return(
diff --git a/src/Components/HelpCenter/TabsResourseFind/HowToFilter.js b/src/Components/HelpCenter/TabsResourseFind/HowToFilter.js
index 928d3dc99e598dd2fbc1204e162fc2e00f78e681..7ea8e558d04204d6d3ea97ad4ba15bab7295df9e 100644
--- a/src/Components/HelpCenter/TabsResourseFind/HowToFilter.js
+++ b/src/Components/HelpCenter/TabsResourseFind/HowToFilter.js
@@ -19,10 +19,8 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 import React from 'react';
 import styled from 'styled-components';
 
-import Filtros from '../../../img/ajuda/filtros_img.jpg'
-
-
-
+//Image Import
+import { Filtros } from "ImportImages.js";
 
 export default function HowToFilter(props) {
   return(
diff --git a/src/Components/HelperFunctions/checkAccessLevel.js b/src/Components/HelperFunctions/checkAccessLevel.js
deleted file mode 100644
index 5cc5ea4b77468376236fcb72af66df18f4ebb80c..0000000000000000000000000000000000000000
--- a/src/Components/HelperFunctions/checkAccessLevel.js
+++ /dev/null
@@ -1,14 +0,0 @@
-import React, {useContext} from 'react'
-import {Store} from '../../Store.js'
-
-export function checkAccessLevel (levelToCheck) {
-    const {state} = useContext(Store)
-
-    if (state.currentUser.id != '') {
-        return(checkUserRole(levelToCheck))
-    }
-
-    const checkUserRole = (userRole) => {
-        return(state.currentUser.roles.filter((role) => role.name === userRole).length > 0)
-    }
-}
diff --git a/src/Components/HelperFunctions/getDefaultThumbnail.js b/src/Components/HelperFunctions/getDefaultThumbnail.js
index cb92a38fcb6f7bc2d947021ae24d2658518c67eb..ad621a77c374713cb5d8e938b269204785913b42 100644
--- a/src/Components/HelperFunctions/getDefaultThumbnail.js
+++ b/src/Components/HelperFunctions/getDefaultThumbnail.js
@@ -1,17 +1,19 @@
-import Animacao from '../../img/laranja/ANIMACAO_SIMULACAO.jpg'
-import AplicativoMovel from '../../img/laranja/APP.jpg'
-import Apresentacao from '../../img/laranja/APRESENTACAO.jpg'
-import Audio from '../../img/laranja/AUDIO.jpg'
-import Empty from '../../img/laranja/EMPTY.jpg'
-import Imagem from '../../img/laranja/IMAGEM.jpg'
-import Infografico from '../../img/laranja/INFOGRAFICO.jpg'
-import Jogo from '../../img/laranja/JOGO.jpg'
-import LivroDigital from '../../img/laranja/LIVRO_DIGITAL.jpg'
-import Mapa from '../../img/laranja/MAPA.jpg'
-import Outros from '../../img/laranja/OUTROS.jpg'
-import SoftwareEducacional from '../../img/laranja/SOFTWARE.jpg'
-import Texto from '../../img/laranja/TEXTO.jpg'
-import Video from '../../img/laranja/VIDEO.jpg'
+
+//Image Import
+import { Animacao } from "ImportImages.js";
+import { AplicativoMovel } from "ImportImages.js";
+import { Apresentacao } from "ImportImages.js";
+import { Audio } from "ImportImages.js";
+import { Empty } from "ImportImages.js";
+import { Imagem } from "ImportImages.js";
+import { Infografico } from "ImportImages.js";
+import { Jogo } from "ImportImages.js";
+import { LivroDigital } from "ImportImages.js";
+import { Mapa } from "ImportImages.js";
+import { Outros } from "ImportImages.js";
+import { SoftwareEducacional } from "ImportImages.js";
+import { Texto } from "ImportImages.js";
+import { Video } from "ImportImages.js";
 
 export const getDefaultThumbnail = (objType) => {
     switch (objType.toLowerCase()) {
diff --git a/src/Components/IframeOverlay/ResourceCard.js b/src/Components/IframeOverlay/ResourceCard.js
index 365ea9a3d6574cd63503c060bf94d08308be7748..e500244b41aeef8c7a1adb756e21d91cd4916f72 100644
--- a/src/Components/IframeOverlay/ResourceCard.js
+++ b/src/Components/IframeOverlay/ResourceCard.js
@@ -5,12 +5,14 @@ import Paper from '@material-ui/core/Paper';
 import Grid from '@material-ui/core/Grid';
 import WhiteAreaOfCard from './WhiteAreaOfCard.js';
 
+import { Imagem } from "ImportImages.js"; 
+
 export default function ResourceCard(props) {
 
 	const getThumb = () => {
 		return props.thumb ? 
 		`https://api.portalmec.c3sl.ufpr.br${props.thumb}` 
-		: require('../../img/laranja/IMAGEM.jpg');
+		: Imagem;
 
 	}
 
diff --git a/src/Components/IframeOverlay/SmallFooter.js b/src/Components/IframeOverlay/SmallFooter.js
index 95350b07de94f7287391c608dd00c2cd9f4753bf..c629a25fd9ece1cc745f02417e535b29baea6502 100644
--- a/src/Components/IframeOverlay/SmallFooter.js
+++ b/src/Components/IframeOverlay/SmallFooter.js
@@ -1,6 +1,8 @@
 import React from 'react';
 import styled from 'styled-components';
-import ImgInfo from '../../img/acesso-a-informacao.png';
+
+//Image Import
+import { acessoInfo } from "ImportImages.js";
 
 export default function SmallFooter(props) {
 	return(
@@ -13,7 +15,7 @@ export default function SmallFooter(props) {
 					rel="noreferrer"
 					target="_blank"
 				>
-					<Img src={ImgInfo} />
+					<Img src={acessoInfo} />
 				</a>
 			</ImgDiv>
 			<TextDiv>
diff --git a/src/Components/LevelDescriptionCard.js b/src/Components/LevelDescriptionCard.js
deleted file mode 100644
index 7c55a81f33b75bcdb375ee02c1919df2ab4a3b24..0000000000000000000000000000000000000000
--- a/src/Components/LevelDescriptionCard.js
+++ /dev/null
@@ -1,67 +0,0 @@
-import React from 'react';
-
-import styled from 'styled-components'
-import ShinyProgressBar from './ShinyProgressBar.js'
-import { Grid } from '@material-ui/core'
-
-export default function LevelDescriptionCard(props) {
-
-  return (
-    <LevelDescDiv>
-      <Grid container direction="row" justify="space-between" alignItems="center">
-          <Grid item xs={6} md={4}>
-            <CurrentLevelNumber>
-              Nível {props.level}
-            </CurrentLevelNumber>
-            <CurrentLevelXP>
-              XP {props.xp}
-            </CurrentLevelXP>
-          </Grid>
-          <Grid item xs={6} md={4} alignContent='flex-end'>
-            <CurrentCoins>
-              {props.coins} COINS
-            </CurrentCoins>
-            <NextLevelXP>
-              {props.xp_to_next_lvl} XP PARA O NÍVEL {props.level+1}
-            </NextLevelXP>
-          </Grid>
-          <ShinyProgressBar percentage={props.bar_size} />
-      </Grid>
-    </LevelDescDiv>
-  );
-}
-
-const NextLevelXP = styled.p`
-  text-align: right;
-  font-size: large;
-  font-weight: 500;
-  color: #575757;
-  margin-right: 30px;
-`
-
-const CurrentCoins = styled.p`
-  text-align: right;
-  font-size: x-large;
-  font-weight: 500;
-  color: #575757;
-  margin-right: 30px;
-`
-
-const CurrentLevelNumber = styled.h1`
-  font-weight: 500;
-  font-size: 40px;
-  color: #646464;
-  margin-left: 30px;
-`
-
-const CurrentLevelXP = styled.h2`
-  font-size: x-large;
-  font-weight: 500;
-  color: #00A5B9;
-  margin-left: 30px;
-`
-
-const LevelDescDiv = styled.div`
-  margin: 20px;
-  padding: 20px;
-`
diff --git a/src/Components/MenuList.js b/src/Components/MenuList.js
index 65ab3c6b76925816bb26b17ce48e8793192667a2..b5b920c81a2e75ea9a2ae25b6c0f088eed7a1e9c 100644
--- a/src/Components/MenuList.js
+++ b/src/Components/MenuList.js
@@ -24,11 +24,13 @@ import KeyboardArrowDownIcon from '@material-ui/icons/KeyboardArrowDown';
 import { Link } from 'react-router-dom'
 import ExitToAppIcon from '@material-ui/icons/ExitToApp';
 import { Store } from '../Store';
-import Profile from '../img/default_profile0.png'
 import styled from 'styled-components'
 import {apiDomain} from '../env.js'
 import {deleteRequest} from './HelperFunctions/getAxiosConfig'
 
+//Image Import
+import { Profile } from "ImportImages.js";
+
 
 const OverrideButton = styled(Button)`
     text-transform : none !important;
diff --git a/src/Components/MobileDrawerMenu.js b/src/Components/MobileDrawerMenu.js
index f99498f24c46eec01ff1b6aa6ee1f20bbe8d4197..317b46b2deee315e534051f2c60b2129a5372d84 100644
--- a/src/Components/MobileDrawerMenu.js
+++ b/src/Components/MobileDrawerMenu.js
@@ -29,12 +29,14 @@ import AssignmentIcon from '@material-ui/icons/Assignment';
 import { ButtonStyled } from './MenuBar'
 import ExitToAppIcon from '@material-ui/icons/ExitToApp'
 import { Button } from '@material-ui/core';
-import DefaultAvatar from '../img/default_profile0.png'
 import SettingsIcon from '@material-ui/icons/Settings';
 import { apiDomain } from '../env.js'
 import { deleteRequest } from './HelperFunctions/getAxiosConfig'
 import CloudUploadIcon from '@material-ui/icons/CloudUpload';
 
+//Image Import
+import { Profile } from "ImportImages.js";
+
 export default function MobileDrawerMenu(props) {
     const { state, dispatch } = useContext(Store)
 
@@ -95,7 +97,7 @@ export default function MobileDrawerMenu(props) {
 
     const getUserAvatar = () => {
         if (state.currentUser.avatar === '' || state.currentUser.avatar == null) {
-            return DefaultAvatar
+            return Profile
         }
         else {
             return apiDomain + state.currentUser.avatar
diff --git a/src/Components/ModalAlterarAvatar/ComponentAlterarAvatar.js b/src/Components/ModalAlterarAvatar/ComponentAlterarAvatar.js
index 294bcdb0630ca4f6dceaaec40f1665973dc97e85..a3e6a895d2138935549d4adc8e4ab689410d1f71 100644
--- a/src/Components/ModalAlterarAvatar/ComponentAlterarAvatar.js
+++ b/src/Components/ModalAlterarAvatar/ComponentAlterarAvatar.js
@@ -22,10 +22,12 @@ import styled from 'styled-components'
 import {Store} from '../../Store.js'
 import {apiDomain} from '../../env';
 import CloseIcon from '@material-ui/icons/Close';
-import Profile from '../../img/default_profile0.png'
 import Cropper from '../Cropper.js'
 import {putRequest} from '../HelperFunctions/getAxiosConfig'
 
+//Image Import
+import { Profile } from "ImportImages.js";
+
 function ChooseImage (props) {
     return (
         <div style={{marginTop:"0"}}>
diff --git a/src/Components/Notifications.js b/src/Components/Notifications.js
index c8fbe2ae21be7c1b7897c603034785e9e345e2b9..854eb9807fa63dcee9367dc54fc78249b68e369b 100644
--- a/src/Components/Notifications.js
+++ b/src/Components/Notifications.js
@@ -205,6 +205,7 @@ export default function Notification(props) {
                     {
                         notifications.map((notification) =>
                             (notification.viewed === false) &&
+                            (notification.recipient_type !== "NilClass") &&
                             <ActivityListItem
                                 onMenuBar={true}
                                 avatar={notification.owner.avatar ? apiDomain + notification.owner.avatar : null}
diff --git a/src/Components/NotificationsInner.js b/src/Components/NotificationsInner.js
deleted file mode 100644
index 4630287968d81ff709a2fb3d4dd46e88ab70d38e..0000000000000000000000000000000000000000
--- a/src/Components/NotificationsInner.js
+++ /dev/null
@@ -1,70 +0,0 @@
-import React, {useState, useContext, useEffect} from 'react'
-import styled from 'styled-components'
-import {apiDomain} from '../env.js'
-import ActivityListItem from './ActivityListItem.js'
-import {getRequest} from './HelperFunctions/getAxiosConfig'
-
-export default function NotificationInner (props) {
-    const [notifications, setNotifications] = useState([]);
-    const [notificatonsLength, setLength] = useState(0);
-
-    function handleSuccess (data) {
-        setNotifications(data)
-        setLength(data.length)
-    }
-    useEffect(() => {
-        const url = `/feed?offset=0&limit=30`
-
-        getRequest(url, handleSuccess, (error) => {console.log('error while running getNotifications')})
-    }, [])
-
-    return (
-        <ContainerDiv>
-            <div className="cabecalho">
-                <span style={{fontSize : "15px"}}>NOTIFICAÇÕES •</span>
-                <span className="cabecalho-marcar">Marcar todas como lidas</span>
-            </div>
-            {
-                notifications.map( (notification) =>
-                    <ActivityListItem
-                        onMenuBar={true}
-                        avatar = {notification.owner.avatar ? apiDomain + notification.owner.avatar : null}
-                        activity = {notification.activity}
-                        actionType = {notification.trackable_type}
-                        objectType = {notification.recipient_type}
-                        createdAt = {notification.created_at}
-                        ownerName = {notification.owner.name}
-                        ownerHref = {'/usuario-publico/' + notification.owner.id}
-                        recipientName =  {notification.recipient.name}
-                    />
-                )
-            }
-        </ContainerDiv>
-
-    )
-}
-
-const ContainerDiv = styled.div`
-    margin-top : 10px;
-    right : 5%;
-    width : 360px;
-    max-height : 400px;
-    position : absolute;
-    box-shadow : 8px 8px 8px 8px
-    rgba(0,0,0,.1);
-    overflow-y : scroll;
-    padding : 5px 5px 5px 5px;
-    min-width : 160px;
-
-    .cabecalho {
-        border-bottom : 1px solid #666;
-
-        .cabecalho-marcar {
-            font-family: Lato,bold;
-            font-size: 12px;
-            -webkit-text-decoration-line: underline;
-            text-decoration-line: underline;
-            float: right;
-        }
-    }
-`
diff --git a/src/Components/PageProfessorComponents/SuccessfulRequest.js b/src/Components/PageProfessorComponents/SuccessfulRequest.js
index b6d479e6b9cf54d684da5aaacc794a6e1f10614c..ffd481b450846b031f7a209df95675646eaaa022 100644
--- a/src/Components/PageProfessorComponents/SuccessfulRequest.js
+++ b/src/Components/PageProfessorComponents/SuccessfulRequest.js
@@ -1,7 +1,9 @@
 import React from 'react'
 import styled from 'styled-components'
 import {ButtonConfirmar} from './PartOne.js'
-import Comentarios from '../../img/comentarios.png'
+
+//Image Import
+import { Comentarios } from "ImportImages.js";
 
 export default function SuccessfulRequest (props) {
     const h4Text = 'Obrigado por fazer parte dessa rede!'
diff --git a/src/Components/PasswordRecoveryComponents/Default.js b/src/Components/PasswordRecoveryComponents/Default.js
index ddbb4f43a3128596508fa1696a5fe4aa59820015..e7a45389a59a27e43ad925db4290a48d12b2c856 100644
--- a/src/Components/PasswordRecoveryComponents/Default.js
+++ b/src/Components/PasswordRecoveryComponents/Default.js
@@ -6,7 +6,7 @@ export default function Default (props) {
     return (
         <div style={{overflow:"hidden", display:"inline-block"}}>
             <h2 style={{fontSize:"32px", fontWeight:"200", marginBottom:"20px"}}>Vamos encontrar a sua conta</h2>
-            <form onSubmit={(e) => props.onSubmit(e)}>
+            <form onSubmit={(e) => { e.preventDefault(); props.onSubmit(e); }}>
                 <FormInput
                     inputType={"text"}
                     name={"email"}
diff --git a/src/Components/ReportCollectionForm.js b/src/Components/ReportCollectionForm.js
deleted file mode 100644
index 34fd87b2417016fa80fc43bce90300242a764901..0000000000000000000000000000000000000000
--- a/src/Components/ReportCollectionForm.js
+++ /dev/null
@@ -1,103 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-import React from 'react';
-import { Button } from '@material-ui/core';
-import styled from 'styled-components'
-import Radio from '@material-ui/core/Radio';
-import RadioGroup from '@material-ui/core/RadioGroup';
-import FormControlLabel from '@material-ui/core/FormControlLabel';
-import FormControl from '@material-ui/core/FormControl';
-import TextField from '@material-ui/core/TextField';
-import {StyledFormControl, StyledTextField, ButtonsDiv, ButtonCancelar, ButtonEnviar} from './ReportUserForm.js'
-
-export default function ReportRecursoForm (props) {
-    const [value, setValue] = React.useState(-1);
-
-    const handleChange = (event) => {
-        setValue(event.target.value);
-    };
-
-    /*values are set according to backend complaint id*/
-    const [options] = React.useState([
-        {value : "1", text : 'A Coleção viola os direitos autorais.'},
-        {value : "2", text : 'A Coleção contém conteúdo ofensivo/abusivo.'},
-        {value : "5", text : 'A descrição da Coleção não corresponde ao seu conteúdo.'}
-    ])
-
-    const [moreInfo, setMoreInfo] = React.useState({
-        key : false,
-        value : "",
-    })
-
-    const handleChangeMoreInfo = (e) => {
-        const userInput = e.target.value
-
-        const flag = userInput.length > 150 ? true : false
-
-        setMoreInfo({...moreInfo,
-            key : flag,
-            value : userInput
-        })
-    }
-
-    const handleSubmit = (e) => {
-        e.preventDefault()
-        const finalRadioValue = value
-        const finalMoreInfo = moreInfo
-
-        if( finalRadioValue != -1 && !(finalMoreInfo.key)) {
-            props.handleSubmit(finalRadioValue, finalMoreInfo.value)
-        }
-        else {
-            console.log('oops')
-        }
-    }
-
-    return (
-        <form onSubmit={(e) => handleSubmit(e)} style={{textAlign : "left"}}>
-        <StyledFormControl component="fieldset">
-            <RadioGroup value={value} onChange={handleChange}>
-                {
-                    options.map(option =>
-                        <FormControlLabel value={option.value} control={<Radio color="orange"/>} label={option.text} />
-                    )
-                }
-            </RadioGroup>
-        </StyledFormControl>
-
-        <StyledTextField
-            id = {"report-text-field"}
-            label={"Escreva mais sobre o problema"}
-            value = {moreInfo.value}
-            onChange = {e => handleChangeMoreInfo(e)}
-            helperText = {moreInfo.value.length + '/150'}
-            multiline={true}
-            rowsMax = {"5"}
-            error = {moreInfo.key}
-            required = {false}
-            helperText ={moreInfo.value.length + '/150'}
-            style={{width : "100%"}}
-        />
-
-        <ButtonsDiv>
-            <ButtonCancelar onClick={props.handleClose}>CANCELAR</ButtonCancelar>
-            <ButtonEnviar type="submit">ENVIAR</ButtonEnviar>
-        </ButtonsDiv>
-    </form>
-    )
-}
diff --git a/src/Components/RequirementsDialog.js b/src/Components/RequirementsDialog.js
deleted file mode 100644
index 49aeb47335556faa0d6fa700973c0541a217819b..0000000000000000000000000000000000000000
--- a/src/Components/RequirementsDialog.js
+++ /dev/null
@@ -1,61 +0,0 @@
-import React from 'react';
-import Button from '@material-ui/core/Button';
-import Dialog from '@material-ui/core/Dialog';
-import DialogActions from '@material-ui/core/DialogActions';
-import DialogContent from '@material-ui/core/DialogContent';
-import DialogContentText from '@material-ui/core/DialogContentText';
-import DialogTitle from '@material-ui/core/DialogTitle';
-
-export default function MaxWidthDialog(props) {
-  const [open, setOpen] = React.useState(false);
-  const fullWidth = true;
-  const maxWidth = 'sm';
-
-  const handleClickOpen = () => {
-    setOpen(true);
-  };
-
-  const handleClose = () => {
-    setOpen(false);
-  };
-
-  return (
-    <React.Fragment>
-      <Button variant="outlined" color="primary" onClick={handleClickOpen}>
-        Mais
-      </Button>
-      <Dialog
-        fullWidth={fullWidth}
-        maxWidth={maxWidth}
-        open={open}
-        onClose={handleClose}
-        aria-labelledby="max-width-dialog-title"
-      >
-        <DialogTitle id="max-width-dialog-title">{props.title}</DialogTitle>
-        <DialogContent>
-          <DialogContentText>
-            {props.description}
-            <h4>Requisitos</h4>
-            <dl>
-              {props.requirements.map(
-                (r) => {
-                return(
-                  <div>
-                    <dt>{r.name}</dt>
-                    <dd>{r.description}</dd>
-                  </div>
-                );
-                })}
-            </dl>
-          </DialogContentText>
-        </DialogContent>
-        <DialogActions>
-          <Button onClick={handleClose} color="primary">
-            Fechar
-          </Button>
-        </DialogActions>
-      </Dialog>
-    </React.Fragment>
-  );
-}
-
diff --git a/src/Components/ResourceCard.js b/src/Components/ResourceCard.js
deleted file mode 100644
index 2e76e5fc66116d288e3be56b7af41c85ef77878e..0000000000000000000000000000000000000000
--- a/src/Components/ResourceCard.js
+++ /dev/null
@@ -1,206 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, { Component } from "react";
-import "./CardsAnimation.css";
-import { Container } from "react-grid-system";
-import Card from "@material-ui/core/Card";
-import CardContent from "@material-ui/core/CardContent";
-import CardActions from "@material-ui/core/CardActions";
-import IconButton from "@material-ui/core/IconButton";
-import Typography from "@material-ui/core/Typography";
-import FavoriteIcon from "@material-ui/icons/Favorite";
-import styled from 'styled-components';
-import animacao from "../img/laranja/ANIMACAO_SIMULACAO.jpg";
-import apresentacao from "../img/laranja/APRESENTACAO.jpg";
-import aplicativo from "../img/laranja/APP.jpg";
-import audio from "../img/laranja/AUDIO.jpg";
-import vazio from "../img/laranja/EMPTY.jpg";
-import imagem from "../img/laranja/IMAGEM.jpg";
-import grafico from "../img/laranja/INFOGRAFICO.jpg";
-import jogo from "../img/laranja/JOGO.jpg";
-import livro from "../img/laranja/LIVRO_DIGITAL.jpg";
-import mapa from "../img/laranja/MAPA.jpg";
-import outros from "../img/laranja/OUTROS.jpg";
-import software from "../img/laranja/SOFTWARE.jpg";
-import texto from "../img/laranja/TEXTO.jpg";
-import video from "../img/laranja/VIDEO.jpg";
-import Rating from "@material-ui/lab/Rating";
-import StarBorderIcon from "@material-ui/icons/StarBorder";
-import { apiDomain } from "../env";
-import AddIcon from "@material-ui/icons/CreateNewFolder";
-import Options from "./CardOptions";
-import Video from "@material-ui/icons/OndemandVideo";
-import noAvatar from "../img/default_profile.png";
-
-const types = [
-  { label: "Animação", thumb: animacao },
-  { label: "Apresentação", thumb: apresentacao },
-  { label: "Aplicativo", thumb: aplicativo },
-  { label: "Áudio", thumb: audio },
-  { label: "Vazio", thumb: vazio },
-  { label: "Imagem", thumb: imagem },
-  { label: "Gráfico", thumb: grafico },
-  { label: "Jogo", thumb: jogo },
-  { label: "Livro", thumb: livro },
-  { label: "Livro digital", thumb: livro },
-  { label: "Mapa", thumb: mapa },
-  { label: "Outros", thumb: outros },
-  { label: "Software Educacional", thumb: software },
-  { label: "Software", thumb: software },
-  { label: "Texto", thumb: texto },
-  { label: "Vídeo", thumb: video }
-];
-const slideStyle = {
-  height: "50px",
-  width: "50px",
-  backgroundColor: "white",
-  borderRadius: "50%"
-};
-const publisherStyle = {
-  color: "white",
-  paddinLeft: "30px",
-  fontSize: "15px",
-};
-
-class ResourceCard extends Component {
-  constructor(props) {
-    super(props);
-    this.state = {
-      thumbnail: null,
-      userStyle: "animatiOff",
-      userAvatar: null
-    };
-  }
-  renderType(type) {
-    if (!this.state.thumbnail) {
-      if (!this.props.thumbnail) {
-        const aux = types.find(function (element) { return element.label === type });
-        this.setState({ thumbnail: aux.thumb });
-      }
-      else {
-        this.setState({ thumbnail: `${apiDomain}` + this.props.thumbnail });
-      }
-    }
-    // {/*if (!this.state.thumbnail && !this.props.thumbnail ) {
-    //   var aux = types.find(function(element){ return element.label === type});
-    //   this.setState({thumbnail: aux.thumb});
-    // }
-    // if (!this.state.thumbnail && this.props.thumbnail ) {
-    //   this.setState({thumbnail: apiDomain + this.props.thumbnail});
-    // }*/}
-  }
-  onHover() {
-    this.setState({ userStyle: "animatiOn" });
-  }
-  onIddle() {
-    this.setState({ userStyle: "animatiOff" });
-  }
-  defAvatar() {
-    if (!this.state.userAvatar && !this.props.avatar.length) {
-      this.setState({ userAvatar: noAvatar });
-    }
-    if (!this.state.userAvatar && this.props.avatar) {
-      this.setState({ userAvatar: apiDomain + this.props.avatar });
-    }
-  }
-  render() {
-    this.renderType(this.props.type);
-    this.defAvatar();
-    return (
-      <Card
-        onMouseOver={this.onHover.bind(this)}
-        onMouseOut={this.onIddle.bind(this)}
-      >
-        <Container
-          style={{
-            padding: "0px",
-            height: "175px",
-            backgroundColor: "#ff7f00"
-          }}
-        >
-          <div className={this.state.userStyle}>
-            <img style={slideStyle} src={this.state.userAvatar} alt="Avatar" />
-            <StyledPublisher style={publisherStyle}>
-              Enviado por: <br />
-              {this.props.author}
-            </StyledPublisher>
-          </div>
-          <img
-            src={this.state.thumbnail}
-            style={{ height: "100%" }}
-            alt="thumbnail do recurso"
-          />
-        </Container>
-        <CardContent
-          style={{ height: "60%", textAlign: "left", paddingBottom: "0px" }}
-        >
-          <Typography
-            variant="body2"
-            color="textSecondary"
-            component="p"
-            style={{ height: "45px", overflow: "hidden", fontSize: "0.8em" }}
-          >
-            {this.props.name}
-          </Typography>
-        </CardContent>
-        <Container style={{ textAlign: "left" }}>
-          <Rating
-            name="customized-empty"
-            value={this.props.rating * 10}
-            precision={0.5}
-            readOnly
-            emptyIcon={<StarBorderIcon fontSize="inherit" />}
-          />
-        </Container>
-        <CardActions
-          style={{ justifyContent: "space-between", padding: "0px" }}
-        >
-          {this.props.type === "Vídeo" ? (
-            <Video style={{ color: "#ff7f00" }} />
-          ) : (
-              <br />
-            )}
-          <IconButton aria-label="Favoritar" size="small">
-            <FavoriteIcon />
-          </IconButton>
-        </CardActions>
-        <CardActions
-          style={{
-            borderTop: "1px solid #e5e5e5",
-            justifyContent: "space-between"
-          }}
-        >
-          <IconButton aria-label="Guardar" size="small">
-            <AddIcon />
-          </IconButton>
-          <Options />
-        </CardActions>
-      </Card>
-    );
-  }
-}
-
-const StyledPublisher = styled(Typography)`
-  display: -webkit-box;
-  -webkit-line-clamp: 2;
-  -webkit-box-orient: vertical;
-  overflow: hidden;
-`
-
-export default ResourceCard;
diff --git a/src/Components/ResourceCardFunction.js b/src/Components/ResourceCardFunction.js
index 62aa64614e3427ad4f9617f1ac6ce3daf956ce28..5ccc03256fc9dddfe19b59dd2f02ced81906d973 100644
--- a/src/Components/ResourceCardFunction.js
+++ b/src/Components/ResourceCardFunction.js
@@ -20,7 +20,6 @@ import React, { useState, useEffect } from 'react';
 import Card from '@material-ui/core/Card';
 import { apiDomain } from '../env';
 import ResourceCardOptions from './ResourceCardOptions'
-import noAvatar from "../img/default_profile.png";
 import Button from '@material-ui/core/Button';
 import styled from 'styled-components'
 import Rating from '@material-ui/lab/Rating';
@@ -38,6 +37,10 @@ import LoginModal from './LoginModal.js'
 import Snackbar from '@material-ui/core/Snackbar';
 import MuiAlert from '@material-ui/lab/Alert';
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+import { IcDefault } from "ImportImages.js";
+
 export default function ResourceCardFunction(props) {
     const [thumbnail, setThumbnail] = useState(null)
     // eslint-disable-next-line
@@ -62,14 +65,14 @@ export default function ResourceCardFunction(props) {
             setThumbnail(`${apiDomain}` + props.thumbnail)
         }
         else {
-            setThumbnail(getDefaultThumbnail(label))
+            setThumbnail(getDefaultThumbnail(label))  
         }
 
         if (props.avatar) {
             setUserAvatar(`${apiDomain}` + props.avatar)
         }
         else {
-            setUserAvatar(require('../img/logo_parceiros/ic_default.png'))
+            setUserAvatar(IcDefault)
         }
 
     }, [])
diff --git a/src/Components/ResourcePageComponents/CommentsArea.js b/src/Components/ResourcePageComponents/CommentsArea.js
index e68a1a23893fa698241899c5a969005e0402e526..1ee202d977fc2d919a473fcb03ac6dbf13c11e47 100644
--- a/src/Components/ResourcePageComponents/CommentsArea.js
+++ b/src/Components/ResourcePageComponents/CommentsArea.js
@@ -22,7 +22,6 @@ import styled from 'styled-components'
 import Grid from '@material-ui/core/Grid';
 import { Button } from '@material-ui/core';
 import ExitToAppIcon from '@material-ui/icons/ExitToApp';
-import Comentarios from '../../img/comentarios.png'
 import { apiDomain } from '../../env';
 import CommentForm from './CommentForm.js'
 import Comment from '../Comment.js'
@@ -32,11 +31,14 @@ import Snackbar from '@material-ui/core/Snackbar';
 import SignUpModal from './../SignUpModal'
 import MuiAlert from '@material-ui/lab/Alert';
 import CircularProgress from '@material-ui/core/CircularProgress';
-import noAvatar from '../../img/default_profile.png';
 import IconButton from '@material-ui/core/IconButton';
 import KeyboardArrowDownIcon from '@material-ui/icons/KeyboardArrowDown';
 import SnackBarComponent from '../../Components/SnackbarComponent';
 
+//Image Import
+import { Comentarios } from "ImportImages.js"; 
+import { noAvatar } from "ImportImages.js"; 
+
 function Alert(props) {
     return <MuiAlert elevation={6} variant="filled" {...props} />;
 }
diff --git a/src/Components/ResourcePageComponents/Sobre.js b/src/Components/ResourcePageComponents/Sobre.js
index 2de37ad9f73eb7abd78231d078a02c91e6ba350d..f1e20fa480dc7e76b4c55a448258f44106e61e65 100644
--- a/src/Components/ResourcePageComponents/Sobre.js
+++ b/src/Components/ResourcePageComponents/Sobre.js
@@ -32,13 +32,15 @@ import ExpandLessIcon from '@material-ui/icons/ExpandLess';
 import DateRangeIcon from '@material-ui/icons/DateRange';
 import UpdateIcon from '@material-ui/icons/Update';
 import AssignmentIcon from '@material-ui/icons/Assignment';
-import License from '../../img/cc_license.png'
 import ContactCardOptions from '../ContactCardOptions.js'
 import LoginModal from './../LoginModal.js'
 import Snackbar from '@material-ui/core/Snackbar';
 import SignUpModal from './../SignUpModal'
 import MuiAlert from '@material-ui/lab/Alert';
 
+//Image Import
+import { License } from "ImportImages.js";
+
 function Alert(props) {
     return <MuiAlert elevation={6} variant="filled" {...props} />;
 }
diff --git a/src/Components/SearchExpansionPanel/SearchEPKeyWord.js b/src/Components/SearchExpansionPanel/SearchEPKeyWord.js
deleted file mode 100644
index 101a0e0609fe318817ab8b76b5d964daef1deba8..0000000000000000000000000000000000000000
--- a/src/Components/SearchExpansionPanel/SearchEPKeyWord.js
+++ /dev/null
@@ -1,167 +0,0 @@
-import React from "react";
-import { withStyles } from "@material-ui/core/styles";
-import MuiExpansionPanel from "@material-ui/core/ExpansionPanel";
-import MuiExpansionPanelSummary from "@material-ui/core/ExpansionPanelSummary";
-import MuiExpansionPanelDetails from "@material-ui/core/ExpansionPanelDetails";
-import Typography from "@material-ui/core/Typography";
-import ExpandMoreIcon from "@material-ui/icons/ExpandMore";
-import SearchList from "../SearchList";
-
-const ExpansionPanel = withStyles({
-  root: {
-    border: "1px solid rgba(0, 0, 0, .125)",
-    boxShadow: "none",
-    "&:not(:last-child)": {
-      borderBottom: 0
-    },
-    "&:before": {
-      display: "none"
-    },
-    "&$expanded": {
-      margin: "auto"
-    }
-  },
-  expanded: {}
-})(MuiExpansionPanel);
-
-const ExpansionPanelSummary = withStyles({
-  root: {
-    color: "#666",
-    marginBottom: -1,
-    minHeight: 56,
-    backgroundColor: "#fff",
-
-    "&$expanded": {
-      minHeight: 56,
-      backgroundColor: "#fff"
-    }
-  },
-  content: {
-    "&$expanded": {
-      margin: "12px 0"
-    }
-  },
-  expanded: {}
-})(MuiExpansionPanelSummary);
-
-const TesteTypography = withStyles({
-  root: {
-    fontSize: "17px"
-  }
-})(Typography);
-
-const ExpansionPanelDetails = withStyles(theme => ({
-  root: {
-    padding: theme.spacing(2)
-  }
-}))(MuiExpansionPanelDetails);
-
-export default function SearchExpansionPanels() {
-  return (
-    <div>
-      <link
-        href="https://fonts.googleapis.com/css?family=Roboto:400,500&display=swap"
-        rel="stylesheet"
-      />
-
-      <ExpansionPanel square>
-        <ExpansionPanelSummary
-          aria-controls="panel1d-content"
-          id="panel1d-header"
-        >
-          <Typography
-            style={{
-              fontSize: "18px",
-              textTransform: "uppercase",
-              fontWeight: "500"
-            }}
-          >
-            Filtros
-          </Typography>
-        </ExpansionPanelSummary>
-      </ExpansionPanel>
-      <ExpansionPanel square>
-        <ExpansionPanelSummary
-          expandIcon={<ExpandMoreIcon />}
-          aria-controls="panel2d-content"
-          id="panel2d-header"
-        >
-          <TesteTypography>Componentes Curriculares</TesteTypography>
-        </ExpansionPanelSummary>
-        <ExpansionPanelDetails>
-          <Typography>
-            <SearchList />
-          </Typography>
-        </ExpansionPanelDetails>
-      </ExpansionPanel>
-      <ExpansionPanel square>
-        <ExpansionPanelSummary
-          expandIcon={<ExpandMoreIcon />}
-          aria-controls="panel3d-content"
-          id="panel3d-header"
-        >
-          <Typography>Tipos de Recurso</Typography>
-        </ExpansionPanelSummary>
-        <ExpansionPanelDetails>
-          <Typography>
-            Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse
-            malesuada lacus ex, sit amet blandit leo lobortis eget. Lorem ipsum
-            dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada
-            lacus ex, sit amet blandit leo lobortis eget.
-          </Typography>
-        </ExpansionPanelDetails>
-      </ExpansionPanel>
-      <ExpansionPanel square>
-        <ExpansionPanelSummary
-          aria-controls="panel4d-content"
-          expandIcon={<ExpandMoreIcon />}
-          id="panel4d-header"
-        >
-          <Typography>Etapas de Ensino</Typography>
-        </ExpansionPanelSummary>
-        <ExpansionPanelDetails>
-          <Typography>
-            Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse
-            malesuada lacus ex, sit amet blandit leo lobortis eget. Lorem ipsum
-            dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada
-            lacus ex, sit amet blandit leo lobortis eget.
-          </Typography>
-        </ExpansionPanelDetails>
-      </ExpansionPanel>
-      <ExpansionPanel square>
-        <ExpansionPanelSummary
-          aria-controls="panel5d-content"
-          expandIcon={<ExpandMoreIcon />}
-          id="panel5d-header"
-        >
-          <Typography>Idiomas</Typography>
-        </ExpansionPanelSummary>
-        <ExpansionPanelDetails>
-          <Typography>
-            Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse
-            malesuada lacus ex, sit amet blandit leo lobortis eget. Lorem ipsum
-            dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada
-            lacus ex, sit amet blandit leo lobortis eget.
-          </Typography>
-        </ExpansionPanelDetails>
-      </ExpansionPanel>
-      <ExpansionPanel square>
-        <ExpansionPanelSummary
-          aria-controls="panel6d-content"
-          expandIcon={<ExpandMoreIcon />}
-          id="panel6d-header"
-        >
-          <Typography>Palavra-Chave</Typography>
-        </ExpansionPanelSummary>
-        <ExpansionPanelDetails>
-          <Typography>
-            Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse
-            malesuada lacus ex, sit amet blandit leo lobortis eget. Lorem ipsum
-            dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada
-            lacus ex, sit amet blandit leo lobortis eget.
-          </Typography>
-        </ExpansionPanelDetails>
-      </ExpansionPanel>
-    </div>
-  );
-}
diff --git a/src/Components/SearchList.js b/src/Components/SearchList.js
deleted file mode 100644
index 0f789ce11cbfdb21bb5a37df2379aff6d109e1b8..0000000000000000000000000000000000000000
--- a/src/Components/SearchList.js
+++ /dev/null
@@ -1,70 +0,0 @@
-import React from "react";
-import { makeStyles } from "@material-ui/core/styles";
-import List from "@material-ui/core/List";
-import ListItem from "@material-ui/core/ListItem";
-import ListItemIcon from "@material-ui/core/ListItemIcon";
-import ListItemSecondaryAction from "@material-ui/core/ListItemSecondaryAction";
-import ListItemText from "@material-ui/core/ListItemText";
-import Checkbox from "@material-ui/core/Checkbox";
-import IconButton from "@material-ui/core/IconButton";
-import CommentIcon from "@material-ui/icons/Comment";
-
-const useStyles = makeStyles(theme => ({
-  root: {
-    width: "100%",
-    maxWidth: 360,
-    backgroundColor: theme.palette.background.paper
-  }
-}));
-
-export default function SearchList() {
-  const classes = useStyles();
-  const [checked, setChecked] = React.useState([0]);
-
-  const handleToggle = value => () => {
-    const currentIndex = checked.indexOf(value);
-    const newChecked = [...checked];
-
-    if (currentIndex === -1) {
-      newChecked.push(value);
-    } else {
-      newChecked.splice(currentIndex, 1);
-    }
-
-    setChecked(newChecked);
-  };
-
-  return (
-    <List className={classes.root}>
-      {[0, 1, 2, 3].map(value => {
-        const labelId = `checkbox-list-label-${value}`;
-
-        return (
-          <ListItem
-            key={value}
-            role={undefined}
-            dense
-            button
-            onClick={handleToggle(value)}
-          >
-            <ListItemIcon>
-              <Checkbox
-                edge="start"
-                checked={checked.indexOf(value) !== -1}
-                tabIndex={-1}
-                disableRipple
-                inputProps={{ "aria-labelledby": labelId }}
-              />
-            </ListItemIcon>
-            <ListItemText id={labelId} primary={`Line item ${value + 1}`} />
-            <ListItemSecondaryAction>
-              <IconButton edge="end" aria-label="comments">
-                <CommentIcon />
-              </IconButton>
-            </ListItemSecondaryAction>
-          </ListItem>
-        );
-      })}
-    </List>
-  );
-}
diff --git a/src/Components/SearchPageComponents/CollectionTemplate.js b/src/Components/SearchPageComponents/CollectionTemplate.js
index c3bcb3ee5b8568430afcc2eacd19a5882cd85b13..d75c13a435210b70a5121fb1bf9c4faf664b30bd 100644
--- a/src/Components/SearchPageComponents/CollectionTemplate.js
+++ b/src/Components/SearchPageComponents/CollectionTemplate.js
@@ -3,12 +3,14 @@ import Paper from '@material-ui/core/Paper';
 import styled from 'styled-components';
 import Grid from '@material-ui/core/Grid';
 import LoadingSpinner from '../LoadingSpinner';
-import noCollections from '../../img/Pagina_vazia_colecao.png';
 import CollectionCardFunction from '../CollectionCardFunction';
 import IconButton from '@material-ui/core/IconButton';
 import ArrowBackIcon from '@material-ui/icons/ArrowBack';
 import ArrowForwardIcon from '@material-ui/icons/ArrowForward';
 
+//Image Import
+import { ColecaoVazia } from "ImportImages.js"; 
+
 export default function ResourceTemplate({ isLoading, resources, totalResources, currPage, handlePreviousPage, handleNextPage }) {
   const topRef = React.useRef();
   const totalPages = parseInt(totalResources) === 0 ? 0 : Math.ceil(totalResources / 12) - 1; //Dividing by 12 because i want to cath total pages, and results per page is 12
@@ -54,7 +56,7 @@ export default function ResourceTemplate({ isLoading, resources, totalResources,
                   <h3>
                     Desculpe, não há dados nessa página.
                   </h3>
-                  <img src={noCollections} alt='No cards' />
+                  <img src={ColecaoVazia} alt='No cards' />
                 </NoContentDiv>
             }
           </Grid>
diff --git a/src/Components/SearchPageComponents/ResourceTemplate.js b/src/Components/SearchPageComponents/ResourceTemplate.js
index 01f747366796e9d9a556861e6201399285622bea..362bf17d518ba1511233f4a1eebf46d942223351 100644
--- a/src/Components/SearchPageComponents/ResourceTemplate.js
+++ b/src/Components/SearchPageComponents/ResourceTemplate.js
@@ -3,12 +3,14 @@ import Paper from '@material-ui/core/Paper';
 import styled from 'styled-components';
 import Grid from '@material-ui/core/Grid';
 import LoadingSpinner from '../LoadingSpinner';
-import noResources from '../../img/Pagina_vazia_Sem_publicar.png';
 import ResourceCardFunction from '../ResourceCardFunction';
 import IconButton from '@material-ui/core/IconButton';
 import ArrowBackIcon from '@material-ui/icons/ArrowBack';
 import ArrowForwardIcon from '@material-ui/icons/ArrowForward';
 
+//Image Import
+import { RecursoVazio } from "ImportImages.js"; 
+
 export default function ResourceTemplate({ isLoading, resources, totalResources, currPage, handlePreviousPage, handleNextPage }) {
   const totalPages = parseInt(totalResources) === 0 ? 0 : Math.ceil(totalResources / 12) - 1; //Dividing by 12 because i want to cath total pages, and results per page is 12
   const topRef = React.useRef();
@@ -54,7 +56,7 @@ export default function ResourceTemplate({ isLoading, resources, totalResources,
                   <h3>
                     Desculpe, não há dados nessa página.
                   </h3>
-                  <img src={noResources} alt='No cards' />
+                  <img src={RecursoVazio} alt='No cards' />
                 </NoContentDiv>
             }
           </Grid>
diff --git a/src/Components/SearchSection.js b/src/Components/SearchSection.js
deleted file mode 100644
index 66380b80cb52a8eb34fd22066a5c2ebb62dc3b12..0000000000000000000000000000000000000000
--- a/src/Components/SearchSection.js
+++ /dev/null
@@ -1,98 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, {Component} from 'react';
-import '../App.css';
-import banner from '../img/bannerBusca.jpg';
-// import SearchBar from './SearchBar';
-import {Row} from 'react-grid-system';
-import {MdInfoOutline} from "react-icons/md"
-import { FaRegPlayCircle} from "react-icons/fa";
-import ModalVideoApresentacao from "./ModalVideoApresentacao.js"
-
-const bannerStyle = {
-    width: "100%",
-    backgroundImage: `url(${banner})`,
-    backgroundSize: "cover",
-    textAlign: "center"
-}
-const titleStyle = {
-    color: "white",
-    paddingTop: "5%",
-}
-const buttonStyle = {
-    alignItems: "flex-start",
-    fontSize: "0.7em",
-    textAlign: "center",
-    cursor: "pointer",
-    borderTopLeftRadius: "15px",
-    borderTopRightRadius: "15px",
-    lineHeight: 1.42857143,
-    width: "20%",
-    marginTop: "1%",
-    color: "white",
-    padding: "1.2%",
-    borderWidth: "5%",
-    borderStyle: "none",
-    borderImage: "initial"
-}
-
-class SearchSection extends Component{
-  constructor(props){
-    super(props);
-    this.state={
-      color: "#ff7f00",
-      modalOpen : false
-    };}
-
-    toggleModal = () => {
-        this.setState({modalOpen : !this.state.modalOpen})
-    }
-
-  render(){
-    return(
-    <React.Fragment>
-    <ModalVideoApresentacao open={this.state.modalOpen} handleClose={this.toggleModal}/>
-    <div style={bannerStyle}>
-      <div style={titleStyle}>
-        <h2 style={{color : "white"}}>Plataforma MEC de Recursos Educacionais Digitais</h2>
-        <h3 style={{fontWeight: "100", color: "white"}}>
-          Encontre e compartilhe vídeos, animações e muitos outros Recursos
-        </h3>
-      </div>
-      {/* <Container style={{backgroundColor: "white" ,width: "50%" ,float: "center", alignItems: "center", borderRadius: "5px", color: this.state.color}}>
-          <SearchBar/>
-      </Container> */}
-          <div style={{paddingBottom: "100px", color: "white"}}>
-            <a href="sobre" style={{color:"#fff",textDecoration: "none", outline:"none", paddingRight : "10px"}}><MdInfoOutline size="24px" style={{verticalAlign: "middle", paddingRight : "5px"}} />SOBRE A PLATAFORMA</a>
-            <span onClick={this.toggleModal} style={{cursor : "pointer"}}>
-            <FaRegPlayCircle size="20px" style={{verticalAlign: "middle", paddingRight : "5px"}}/>VÍDEO DE APRESENTAÇÃO
-            </span>
-          </div>
-      <Row justify="center" style={{marginLeft:0, marginRight:0}}>
-      <button style={{...buttonStyle, ...{backgroundColor: "#ff7f00",fontSize:"1.14em", outline:"none"}}} onClick={()=> {this.props.function("Recursos")}}>Recursos Educacionais Digitais</button>
-      <button style={{...buttonStyle, ...{backgroundColor: "#e81f4f",fontSize:"1.14em", outline:"none"}}} onClick={()=> {this.props.function("Materiais")}}>Materiais de Formação</button>
-      <button style={{...buttonStyle, ...{backgroundColor: "#673ab7",fontSize:"1.14em", outline:"none"}}} onClick={()=> {this.props.function("Colecoes")}}>Coleções dos Usuários</button>
-      </Row>
-    </div>
-    </React.Fragment>
-  );
-  }
-}
-
-export default SearchSection;
diff --git a/src/Components/SearchSectionFunction.js b/src/Components/SearchSectionFunction.js
index 97d5a43977d986fa5e890ec2f102375008f64f29..7921c9ffeebd4af460f533cc30cb92249211b6e8 100644
--- a/src/Components/SearchSectionFunction.js
+++ b/src/Components/SearchSectionFunction.js
@@ -19,8 +19,6 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 import React, {useState} from 'react';
 import '../App.css';
 import styled from 'styled-components'
-import banner from '../img/bannerBusca.jpg';
-import bannerMobile from '../img/banner-mobile.jpg'
 // import SearchBar from './SearchBar';
 import {Row} from 'react-grid-system';
 import {MdInfoOutline} from "react-icons/md"
@@ -30,6 +28,10 @@ import {Link} from 'react-router-dom'
 import Grid from '@material-ui/core/Grid';
 import HomeScreenSearchBar from './HomeScreenSearchBar'
 
+//Image Import
+import { banner } from "ImportImages.js";
+import { bannerMobile } from "ImportImages.js";
+
 export default function SearchSection (props) {
     const [modalOpen, handleModal] = useState(false)
     const toggleModal = () => {handleModal(!modalOpen)}
diff --git a/src/Components/Select.js b/src/Components/Select.js
deleted file mode 100644
index 5e7adefc1b704ed1e931021e0927b5d2b1327982..0000000000000000000000000000000000000000
--- a/src/Components/Select.js
+++ /dev/null
@@ -1,76 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React from 'react';
-import { withStyles } from '@material-ui/core/styles';
-import MenuItem from '@material-ui/core/MenuItem';
-import FormControl from '@material-ui/core/FormControl';
-import Select from '@material-ui/core/Select';
-import InputBase from '@material-ui/core/InputBase';
-
-const BootstrapInput = withStyles(theme => ({
-  input: {
-    position: 'relative',
-    fontSize: 16,
-    width: '80px',
-  },
-}))(InputBase);
-
-// const styles = theme => ({
-//   root: {
-//     display: 'flex',
-//     flexWrap: 'wrap',
-//   },
-//   margin: {
-//     margin: theme.spacing.unit,
-//   },
-//   bootstrapFormLabel: {
-//     fontSize: 18,
-//   },
-// });
-
-class CustomizedSelects extends React.Component {
-  state = {
-    filter: 1,
-  };
-
-  handleChange = event => {
-    this.setState({ filter: event.target.value });
-  };
-
-  render() {
-    // const { classes } = this.props;
-
-    return (
-        <FormControl>
-          <Select
-            value={this.state.filter}
-            onChange={this.handleChange}
-            input={<BootstrapInput name="filter"/>}
-           >
-            <MenuItem value={1}>Recursos</MenuItem>
-            <MenuItem value={2}>Materiais</MenuItem>
-            <MenuItem value={3}>Coleções</MenuItem>
-          </Select>
-        </FormControl>
-    );
-  }
-}
-
-
-export default (CustomizedSelects);
diff --git a/src/Components/ShareModal.js b/src/Components/ShareModal.js
index 93eb4828efc78e5cf0b8216caa8297d3c5c4331c..f721b4caf8785d0b6eda4424556f01b90a9ca7fc 100644
--- a/src/Components/ShareModal.js
+++ b/src/Components/ShareModal.js
@@ -62,7 +62,7 @@ export default function ReportModal (props) {
                     </Header>
                     <Content style={{paddingTop : "0"}}>
                         <ResourceInfo>
-                            <img src={apiDomain + props.thumb} alt="thumbnail recurso"/>
+                            <img src={props.thumb ? apiDomain + props.thumb : require('../img/logo_small.svg')} alt="thumbnail recurso"/>
                             <div className="text">
                                 <strong>{props.title}</strong>
                                 <span>{props.link}</span>
diff --git a/src/Components/ShinyProgressBar.js b/src/Components/ShinyProgressBar.js
deleted file mode 100644
index f2d1cc03c8c2df869499dd72d3dda7078fe2f7de..0000000000000000000000000000000000000000
--- a/src/Components/ShinyProgressBar.js
+++ /dev/null
@@ -1,55 +0,0 @@
-import React, {Component} from 'react';
-import {Container} from 'react-grid-system';
-import Card from '@material-ui/core/Card';
-import CardContent from '@material-ui/core/CardContent';
-import styled from 'styled-components'
-
-
-export default function ShinyProgressBar(props) {
-    return (
-      <ProgressBar>
-        <ShinyFiller percentage={props.percentage}/>    
-      </ProgressBar>
-    );
-}
-
-const ShinyFiller = (props) => {
-    return (
-        <StyledFiller style={{ width: `${props.percentage}%` }}>
-            <FillerShine/>
-        </StyledFiller>
-    );
-}
-
-const FillerShine = (props) => {
-    return <StyledShine/>
-}
-
-const ProgressBar = styled.div`
-    background: #C4C4C4;
-    position: relative;
-    height: 30px;
-    width: 100%;
-    border-radius: 50px;
-    margin-left:20px;
-    margin-right:20px;
-`
-
-const StyledFiller = styled.div`
-    background: #02A4B9;
-    height: 100%;
-    border-radius: 50px;
-    transition: width 1s ease-in;
-`
-
-const StyledShine = styled.div`
-    position: relative;
-    top: 5px;
-    left: 15px;
-    background: #03C0CE;
-    height: 25%;
-    width: 95%;
-    border-radius: 50px;
-    transition: width 1s ease-in;
-    z-index: +1;
-`
\ No newline at end of file
diff --git a/src/Components/Sidebar.js b/src/Components/Sidebar.js
deleted file mode 100644
index bc98fac07c3388387be291f684340eb98b2c8695..0000000000000000000000000000000000000000
--- a/src/Components/Sidebar.js
+++ /dev/null
@@ -1,88 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, {Component} from 'react';
-import '../App.css';
-import Sidebar from "react-sidebar";
-import BT from './Button';
-
-class SidebarMenu extends Component {
-    constructor(props) {
-      super(props);
-      this.state = {
-        sidebarOpen: false
-      };
-      this.onSetSidebarOpen = this.onSetSidebarOpen.bind(this);
-    }
-
-    onSetSidebarOpen(open) {
-      this.setState({ sidebarOpen: open });
-    }
-
-    render() {
-      return (
-          <Sidebar
-            sidebar={
-              <div>
-                <div>
-                  <BT name={"="} method={this.onSetSidebarOpen} parameter={false}/>
-                  <BT name={"FECHAR"} method={this.onSetSidebarOpen} parameter={false}/>
-                </div>
-                <BT name={"Página Inicial"}/>
-                <BT name={"Sobre a Plataforma"}/>
-                <BT name={"Contato"}/>
-                <BT name={"Central de Ajuda"}/>
-                <BT name={"Termos de Uso"}/>
-
-              </div>
-            }
-            open={this.state.sidebarOpen}
-            onSetOpen={this.onSetSidebarOpen}
-            styles={{root: {
-                      position: "inherit",
-                      overflow: "hidden"
-                    },
-                    sidebar: {
-                      zIndex: 2,
-                      position: "absolute",
-                      background: "white"
-                    },
-                    content: {
-                      position: "relative",
-                      overflowY: "auto",
-                      WebkitOverflowScrolling: "touch",
-                      transition: "left .3s ease-out, right .3s ease-out"
-                    },
-                    overlay: {
-                      zIndex: 1,
-                      position: "fixed",
-                      visibility: "hidden"
-                    },
-                    dragHandle: {
-                      zIndex: 1,
-                      position: "fixed"
-                    }
-                  }}
-           >
-           <BT name={"= MENU"} method={this.onSetSidebarOpen} parameter={true}/>
-          </Sidebar>
-      );
-    }
-  }
-
-export default SidebarMenu;
diff --git a/src/Components/StatsBar.js b/src/Components/StatsBar.js
deleted file mode 100644
index 0cdde4942b065244271cb8e5c82f44e0e96d36d2..0000000000000000000000000000000000000000
--- a/src/Components/StatsBar.js
+++ /dev/null
@@ -1,99 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, {Component} from 'react';
-import {Col,Row, Container} from 'react-grid-system';
-import { apiUrl } from "../env";
-import  axios from "axios";
-import mapaBrasil from '../img/mapa-brasil-line-icon.svg';
-const brasilStyle={
-  backgroundColor: "#00bcd4",
-  color: "white",
-  textAlign: "center",
-  display: "block",
-  paddingTop: "10px",
-  paddingBottom: "10px"
-};
-const numberStyle={
-  display: "block",
-  fontSize: "2.1em",
-  fontWeight: "Bold",
-  fontFamily: "Roboto, sans-serif",
-   textAlign: "center"
-};
-const statistcStyle={
-  display: "inline-block",
-  padding: "5px",
-  alignSelf:"flex-end"
-
-};
-class StatsBar extends Component{
-  constructor(props){
-    super(props)
-    this.state ={
-      available_resources: 0,
-      month_publications:0,
-      month_downloads:0
-    }
-  }
-  componentDidMount(){
-    // https://api.portalmec.c3sl.ufpr.br/v1/statistics
-    axios.get(`${apiUrl}/statistics`).then((res) => {
-      this.setState({available_resources:res.data.count, month_publications:res.data.month_publications, month_downloads:res.data.month_downloads})
-    })
-  }
-     
-  render(){
-    return(
-      <div style={brasilStyle}>
-      <Container>
-      <Row>
-        <Col md={6} sm={6} style={{borderRight:"2px dotted #fff", textAlign: "right", alignSelf: "center"}}>
-          <img src={mapaBrasil} height="83px" alt="mapa do brasil"/>
-          <span  style={statistcStyle}>
-            <span style={numberStyle}>
-              {this.state.available_resources}
-            </span>
-            <span>
-              Recursos disponíveis
-            </span>
-          </span>
-        </Col>
-        <Col md={6} sm={6} style={{textAlign: "left",
-        alignSelf:"center"}}>
-            ESSE MÊS:
-            <span style={statistcStyle}>
-            <span style={numberStyle}>
-              {this.state.month_downloads}
-            </span>
-            Baixados
-            </span>
-            <span style={statistcStyle}>
-            <span style={numberStyle}>
-              {this.state.month_publications}
-            </span>
-            Publicados
-          </span>
-        </Col>
-      </Row>
-      </Container>
-      </div>
-    )
-  }
-}
-export default StatsBar;
diff --git a/src/Components/TabPanels/PanelComponents/NoContent.js b/src/Components/TabPanels/PanelComponents/NoContent.js
index 7c8c7141476c3c2793931b448168ce3db00ddc50..f23eb76cd4506d803f8e05e632efa04310ba0b3e 100644
--- a/src/Components/TabPanels/PanelComponents/NoContent.js
+++ b/src/Components/TabPanels/PanelComponents/NoContent.js
@@ -18,9 +18,9 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React from 'react'
 import styled from 'styled-components'
-import defaultNoContent from '../../../img/img-16.png'
-
 
+//Image Import
+import { defaultNoContent } from "ImportImages.js";
 
 export default function NoContent({text, image}) {
 
diff --git a/src/Components/TabPanels/PanelComponents/TemplateColecao.js b/src/Components/TabPanels/PanelComponents/TemplateColecao.js
index b1526eb584834bb5c45f03436eef946c512b8512..b335fbd5110c947dd9979de68dce2d6dfd00bff7 100644
--- a/src/Components/TabPanels/PanelComponents/TemplateColecao.js
+++ b/src/Components/TabPanels/PanelComponents/TemplateColecao.js
@@ -24,7 +24,9 @@ import Title from './PanelTitle.js'
 import { WhiteContainer, StyledGrid } from '../StyledComponents.js'
 import { ButtonsAreaColecao } from './ButtonsArea'
 import LoadingSpinner from '../../LoadingSpinner.js'
-import noCollFound from '../../../img/Pagina_vazia_colecao.png'
+
+//Image Import
+import { ColecaoVazia } from "ImportImages.js";
 
 export default function PanelTemplateColecao(props) {
     const RenderFollowedColCard = (card, followerBoolean) => {
@@ -89,7 +91,7 @@ export default function PanelTemplateColecao(props) {
                         (
                             <NoContent 
                                 text={props.noContentText} 
-                                image={noCollFound}
+                                image={ColecaoVazia}
                                 />
                         )
                         :
diff --git a/src/Components/TabPanels/PanelComponents/TemplateRecurso.js b/src/Components/TabPanels/PanelComponents/TemplateRecurso.js
index d77f0208d3f072a5385a598d9d99c74e963cead2..68e1de28823b08115ab2697d9beebb3f5a972549 100644
--- a/src/Components/TabPanels/PanelComponents/TemplateRecurso.js
+++ b/src/Components/TabPanels/PanelComponents/TemplateRecurso.js
@@ -24,7 +24,9 @@ import Title from './PanelTitle.js'
 import { WhiteContainer, StyledGrid } from '../StyledComponents.js'
 import { ButtonsAreaRecurso } from './ButtonsArea'
 import LoadingSpinner from '../../LoadingSpinner.js'
-import noLearnObjFound from '../../../img/Pagina_vazia_Sem_publicar.png'
+
+//Image Import
+import { RecursoVazio } from "ImportImages.js";
 
 export default function Template(props) {
 
@@ -47,7 +49,7 @@ export default function Template(props) {
                         (
                             <NoContent
                                 text={props.noContentText}
-                                image={noLearnObjFound}
+                                image={RecursoVazio}
                             />
                         )
                         :
diff --git a/src/Components/TabPanels/PublicUserPageTabs/LastCollections.js b/src/Components/TabPanels/PublicUserPageTabs/LastCollections.js
deleted file mode 100644
index 6e32577f77617b47bda1298c2a583ce7a50cf249..0000000000000000000000000000000000000000
--- a/src/Components/TabPanels/PublicUserPageTabs/LastCollections.js
+++ /dev/null
@@ -1,82 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React from 'react'
-import Grid from '@material-ui/core/Grid';
-import { HeaderGrid, StyledGrid } from '../StyledComponents.js'
-import { NoContent } from './TabInicio.js'
-import CollectionCardFunction from '../../CollectionCardFunction.js'
-import NoCol from '../../../img/Pagina_vazia_colecao.png'
-
-export default function LastCols(props) {
-    return (
-        <React.Fragment>
-            <HeaderGrid container>
-                <Grid item xs={12}>
-                    <h3>Últimas alterações em coleções</h3>
-                </Grid>
-            </HeaderGrid>
-
-
-            {
-                props.count === 0 || props.collections.length === 0 ?
-                    (
-                        [
-                            <Grid container>
-                                <Grid item xs={12}>
-                                    <NoContent
-                                        image={NoCol}
-                                        text1={props.username + " ainda não disponibilizou nenhuma coleção."}
-                                        text2={"Quando disponibilizar, elas aparecerão aqui."}
-                                    />
-                                </Grid>
-                            </Grid>
-                        ]
-                    )
-                    :
-                    (
-                        [
-                            <StyledGrid container spacing={1} style={{ paddingLeft: "0.5em" }}>
-                                {
-                                    props.collections.slice(0, 4).map((card) =>
-                                        <Grid item container md={3} xs={12} key={card.id}>
-                                            <CollectionCardFunction
-                                                name={card.name}
-                                                tags={card.tags}
-                                                rating={card.review_average}
-                                                id={card.id}
-                                                author={card.owner.name}
-                                                description={card.description}
-                                                thumbnails={card.items_thumbnails}
-                                                avatar={card.owner.avatar}
-                                                likeCount={card.likes_count}
-                                                followed={card.followed}
-                                                liked={card.liked}
-                                                collections={card.collection_items}
-                                                authorID={card.owner.id}
-                                            />
-                                        </Grid>
-                                    )
-                                }
-                            </StyledGrid>
-                        ]
-                    )
-            }
-        </React.Fragment>
-    )
-}
diff --git a/src/Components/TabPanels/PublicUserPageTabs/LastLearnObj.js b/src/Components/TabPanels/PublicUserPageTabs/LastLearnObj.js
deleted file mode 100644
index 2a489ac6808bad38d577ef87125d56e60bcd4f7e..0000000000000000000000000000000000000000
--- a/src/Components/TabPanels/PublicUserPageTabs/LastLearnObj.js
+++ /dev/null
@@ -1,82 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React from 'react'
-import Grid from '@material-ui/core/Grid';
-import ResourceCardFunction from '../../ResourceCardFunction.js'
-import NoPub from '../../../img/Pagina_vazia_Sem_publicar.png'
-import { HeaderGrid, StyledGrid } from '../StyledComponents.js'
-import { NoContent } from './TabInicio.js'
-
-export default function LastLearnObjs(props) {
-    return (
-        <React.Fragment>
-            <HeaderGrid container>
-                <Grid item xs={9}>
-                    <h3>Últimos Recursos Publicados</h3>
-                </Grid>
-            </HeaderGrid>
-
-            {
-                props.count === 0 ?
-                    (
-                        [
-                            <Grid container>
-                                <Grid item xs={12}>
-                                    <NoContent
-                                        image={NoPub}
-                                        text1={props.username + " ainda não disponibilizou nenhum recurso."}
-                                        text2={"Quando disponibilizar, eles aparecerão aqui."}
-                                    />
-                                </Grid>
-                            </Grid>
-                        ]
-                    )
-                    :
-                    (
-                        [
-                            <StyledGrid container spacing={1} style={{ paddingLeft: "30px", paddingRight: "15px" }}>
-                                {
-                                    props.learningObjs.slice(0, 4).map((card) =>
-                                        <Grid item xs={12} sm={6} md={'auto'} lg={3} key={card.id}>
-                                            <ResourceCardFunction
-                                                avatar={card.publisher.avatar}
-                                                id={card.id}
-                                                thumbnail={card.thumbnail}
-                                                type={card.object_type ? card.object_type : "Outros"}
-                                                title={card.name}
-                                                published={card.state === "published" ? true : false}
-                                                likeCount={card.likes_count}
-                                                liked={card.liked}
-                                                rating={card.review_average}
-                                                author={card.publisher.name}
-                                                tags={card.tags}
-                                                href={"/recurso/" + card.id}
-                                                downloadableLink={card.default_attachment_location}
-
-                                            />
-                                        </Grid>
-                                    )
-                                }
-                            </StyledGrid>
-                        ]
-                    )
-            }
-        </React.Fragment>
-    )
-}
diff --git a/src/Components/TabPanels/TabPanelStatusEConquistas.js b/src/Components/TabPanels/TabPanelStatusEConquistas.js
deleted file mode 100644
index d9e0c20762cb1387ee0ab460f27fe5aeffd2dc07..0000000000000000000000000000000000000000
--- a/src/Components/TabPanels/TabPanelStatusEConquistas.js
+++ /dev/null
@@ -1,112 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-
-import React, {useContext, useState, useEffect} from 'react'
-import { Store } from '../../Store.js'
-import styled from 'styled-components'
-import Paper from '@material-ui/core/Paper';
-import {ContainerDivStyled} from './StyledComponents.js'
-import axios from 'axios'
-import {apiUrl} from '../../env';
-import LevelDescriptionCard from '../LevelDescriptionCard.js'
-import AchievementDescriptionCard from '../AchievementDescriptionCard.js'
-import { Grid } from '@material-ui/core'
-
-export default function TabPanelStatusEConquistas (props) {
-	// eslint-disable-next-line
-	const [achievements, setAchievements] = useState([]);
-	// eslint-disable-next-line
-	const [level, setLevel] = useState(0);
-	// eslint-disable-next-line
-	const [xp, setXP] = useState(0);
-	// eslint-disable-next-line
-	const [coins, setCoins] = useState(0);
-	// eslint-disable-next-line
-	const [barSize, setBarSize] = useState(0);
-	// eslint-disable-next-line
-	const [xpToNextLevel, setXpToNextLevel] = useState(0);
-	const { state } = useContext(Store)
-
-	useEffect(() => {
-		axios.all(
-				['xp_to_next_lvl', 'percent_to_next_level', 'points', 'xp', 'get_level',
-				'completed_achievements'].map((r) => {
-					return axios.get(apiUrl + '/' + r + '?id=' + state.currentUser.id);
-			})).then(axios.spread((xp_to_next_lvl, percent_to_next_level, points,
-							xp, level, completed_achievements) => {
-								this.setXpToNextLevel(xp_to_next_lvl);
-								this.setBarSize(100-percent_to_next_level);
-								this.setCoins(points);
-								this.setXP(xp);
-								this.setLevel(level);
-								this.setAchievements(completed_achievements);
-						}));
-	}, [])
-
-	return (
-		<div>
-		<ContainerDivStyled>
-			<Paper elevation={3}>
-			<LevelDescriptionCard
-				xp_to_next_lvl={xpToNextLevel}
-				bar_size={barSize}
-				coins={coins}
-				xp={xp}
-				level={level}
-				/>
-			</Paper>
-		</ContainerDivStyled>
-		<AchievementsContainer>
-			<AchievementsSectionTitle>
-			Conquistas
-			</AchievementsSectionTitle>
-			<AchievementsList>
-			<Grid container direction="row" justify="space-around" alignItems="center">
-				{achievements.map(
-					(a) => { return (
-							<Grid item xs={12} md={5}>
-								<AchievementDescriptionCard
-									name={a.title}
-									description={a.description}
-									src={a.imgsrc}
-									requirements={a.requirements}
-                                    />
-
-							</Grid>
-						)}
-				)}
-			</Grid>
-			</AchievementsList>
-		</AchievementsContainer>
-		</div>
-	);
-}
-
-const AchievementsSectionTitle = styled.h1`
-	font-weight: 400;
-`
-const AchievementsContainer = styled.div`
-	max-width : 1140px;
-	margin-left : auto;
-	margin-right : auto;
-	margin-bottom: 30px;
-	margin-top: 70px;
-`
-const AchievementsList = styled.div`
-`
diff --git a/src/Components/TabPanels/UserPageTabs/ContainerRedeVazia.js b/src/Components/TabPanels/UserPageTabs/ContainerRedeVazia.js
index 6d15099126be1f6637d77c754b1b21ddcb97284b..7a1451b29c5becca86e59a94c36a08fbc54359ef 100644
--- a/src/Components/TabPanels/UserPageTabs/ContainerRedeVazia.js
+++ b/src/Components/TabPanels/UserPageTabs/ContainerRedeVazia.js
@@ -18,13 +18,15 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React from 'react'
 import styled from 'styled-components'
-import NoRede1 from '../../../img/no-rede-1.png'
-import NoRede2 from '../../../img/no-rede-2.png'
-import NoRede3 from '../../../img/no-rede-3.png'
 import TabRedeImgDiv from './TabRedeImgDiv.js'
 import {WhiteContainer} from '../StyledComponents.js'
 import Grid from '@material-ui/core/Grid';
 
+//Image Import
+import { NoRede1 } from "ImportImages.js";
+import { NoRede2 } from "ImportImages.js";
+import { NoRede3 } from "ImportImages.js";
+
 export default function ContainerRedeVazia (props) {
     return (
         <React.Fragment>
diff --git a/src/Components/TabPanels/UserPageTabs/ModalExcluirConta.js b/src/Components/TabPanels/UserPageTabs/ModalExcluirConta.js
index 1d4410498bd71d489e4d8ccd9a3284bb8f890662..f8cf40d05116502b80295679b815932d28405f61 100644
--- a/src/Components/TabPanels/UserPageTabs/ModalExcluirConta.js
+++ b/src/Components/TabPanels/UserPageTabs/ModalExcluirConta.js
@@ -24,13 +24,15 @@ import Backdrop from '@material-ui/core/Backdrop';
 import Fade from '@material-ui/core/Fade';
 import styled from 'styled-components'
 import CloseIcon from '@material-ui/icons/Close';
-import ExcluirAvatar from '../../../img/Excluir.png'
 import GreyButton from '../../GreyButton'
 import FormInput from '../../FormInput'
 import {Link} from 'react-router-dom'
 import SnackbarComponent from '../../SnackbarComponent.js'
 import {deleteRequest} from '../../HelperFunctions/getAxiosConfig'
 
+//Image Import
+import { ExcluirAvatar } from "ImportImages.js";
+
 function CloseModalButton (props) {
     return (
         <StyledCloseModalButton onClick={props.handleClose}>
diff --git a/src/Components/TabPanels/UserPageTabs/PanelAtividades.js b/src/Components/TabPanels/UserPageTabs/PanelAtividades.js
index bd7fd73dce890f685a1e6aba0aa3f9b2e348a42c..90b6268081f645b6643444b5427c238de7eb013a 100644
--- a/src/Components/TabPanels/UserPageTabs/PanelAtividades.js
+++ b/src/Components/TabPanels/UserPageTabs/PanelAtividades.js
@@ -21,15 +21,16 @@ import styled from 'styled-components'
 import Paper from '@material-ui/core/Paper';
 import Button from '@material-ui/core/Button';
 import { apiDomain } from '../../../env';
-import Bolo from '../../../img/Bolo.png'
 import LoadingSpinner from '../../LoadingSpinner.js'
 import ActivityListItem from '../../ActivityListItem.js'
 import List from '@material-ui/core/List';
 import { getRequest } from '../../HelperFunctions/getAxiosConfig.js'
 import Grid from '@material-ui/core/Grid';
-import DefaultProfile from '../../../img/default_profile.png';
 import SnackBar from '../../SnackbarComponent'
 
+//Image Import
+import { Bolo } from "ImportImages.js";
+import { noAvatar } from "ImportImages.js";
 
 export default function TabPanelAtividades(props) {
 
@@ -187,10 +188,11 @@ export default function TabPanelAtividades(props) {
                                                             <List height={400} width={300}>
                                                                 {
                                                                     notifications.map((notification, id) =>
+                                                                    (notification.recipient_type !== "NilClass") &&
                                                                         <ActivityListItem
                                                                             key={id}
                                                                             onMenuBar={false}
-                                                                            avatar={notification.owner.avatar ? apiDomain + notification.owner.avatar : DefaultProfile}
+                                                                            avatar={notification.owner.avatar ? apiDomain + notification.owner.avatar : noAvatar}
                                                                             activity={notification.activity}
                                                                             actionType={notification.trackable_type}
                                                                             objectType={notification.recipient_type}
diff --git a/src/Components/TabPanels/UserPageTabs/PanelColecoes.js b/src/Components/TabPanels/UserPageTabs/PanelColecoes.js
index 3abc14f58d9dae31f8a949f890890dcfa0f85c25..427a7d5c13857e1ea40608128e61b85c8ce8d9e5 100644
--- a/src/Components/TabPanels/UserPageTabs/PanelColecoes.js
+++ b/src/Components/TabPanels/UserPageTabs/PanelColecoes.js
@@ -22,7 +22,6 @@ import styled from 'styled-components'
 import Grid from '@material-ui/core/Grid';
 import LoadingSpinner from '../../LoadingSpinner.js'
 import PanelTemplateColecao from '../PanelComponents/TemplateColecao.js'
-import PaginaVaziaColecao from '../../../img/Pagina_vazia_colecao.png'
 import { WhiteContainer, StyledGrid } from '../StyledComponents.js'
 import CreateNewFolderIcon from '@material-ui/icons/CreateNewFolder';
 import Title from '../PanelComponents/PanelTitle.js'
@@ -31,6 +30,9 @@ import { ButtonsAreaColecao } from '../PanelComponents/ButtonsArea'
 import CriarColecaoModal from '../../CriarColecaoModal.js'
 import { fetchAllRequest, getRequest } from '../../HelperFunctions/getAxiosConfig'
 
+//Image Import
+import { ColecaoVazia } from "ImportImages.js";
+
 export default function TabPanelColecoes(props) {
   const [loading, handleLoading] = useState(true)
 
@@ -163,7 +165,7 @@ export default function TabPanelColecoes(props) {
                   noContentText={
                     <Grid direction='column' justify='center' alignItems='center'>
                       <Grid item>
-                        <img src={PaginaVaziaColecao} alt="PaginaVaziaColecao" style={{ height: "150px", width: "150px", verticalAlign: "middle", border: "0" }} />
+                        <img src={ColecaoVazia} alt="ColecaoVazia" style={{ height: "150px", width: "150px", verticalAlign: "middle", border: "0" }} />
                       </Grid>
                       <Grid>
                         <span style={{ fontFamily: "Roboto", fontWeight: "lighter", fontSize: "24px", textAlign: 'center' }}>
diff --git a/src/Components/TabPanels/UserPageTabs/PanelEditarPerfil.js b/src/Components/TabPanels/UserPageTabs/PanelEditarPerfil.js
index f65e6417a460b08bf87221fb28aa8cec321a2c97..3857508b93610e27d08654e486e43561d52610d2 100644
--- a/src/Components/TabPanels/UserPageTabs/PanelEditarPerfil.js
+++ b/src/Components/TabPanels/UserPageTabs/PanelEditarPerfil.js
@@ -29,7 +29,9 @@ import ValidateUserInput from '../../HelperFunctions/FormValidationFunction.js'
 import { apiDomain } from '../../../env.js'
 import ModalAlterarCover from '../../ModalAlterarCover/ModalAlterarCover.js'
 import ModalAlterarAvatar from '../../ModalAlterarAvatar/ModalAlterarAvatar.js'
-import Profile from '../../../img/default_profile0.png'
+
+//Image Import
+import { Profile } from "ImportImages.js";
 
 export default function TabPanelEditarPerfil(props) {
     // eslint-disable-next-line
diff --git a/src/Components/Tags.js b/src/Components/Tags.js
deleted file mode 100644
index 6cc1077945ebf1882bbe67f75f505e227f0a5c21..0000000000000000000000000000000000000000
--- a/src/Components/Tags.js
+++ /dev/null
@@ -1,19 +0,0 @@
-import React, {Component} from 'react';
-const tagStyle={
-  borderRadius: "10px",
-  backgroundColor: "gray",
-  color: "white",
-  padding: "4px",
-  display: "table",
-
-};
-
-class Tags extends Component {
-  
-  render(){
-    return(
-      <div style={tagStyle}> {this.props.name} </div>
-    )
-  }
-}
-export default Tags;
diff --git a/src/Components/UploadPageComponents/FileToUpload.ts b/src/Components/UploadPageComponents/FileToUpload.ts
deleted file mode 100644
index 60b6ecb0435943d67b7eae390c06aefa47f167b7..0000000000000000000000000000000000000000
--- a/src/Components/UploadPageComponents/FileToUpload.ts
+++ /dev/null
@@ -1,106 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-export default class FileToUpload {
-    static chunkSize = 262144;
-    readonly request: XMLHttpRequest;
-    readonly uploadUrl: string;
-    readonly file: File;
-    readonly name: string;
-    readonly draftID: string;
-    readonly _chunkIdentifier: string;
-    private _chunkNumber: number;
-    currentChunkStartByte: number;
-    currentChunkFinalByte: number;
-
-    constructor(file: File, name: string, draftID : string) {
-        this.request = new XMLHttpRequest();
-        this.request.onreadystatechange = function(ev: Event) {
-            if(this.readyState === XMLHttpRequest.DONE){
-                if (this.getResponseHeader('access-token') != null) {
-                    console.log(this.getResponseHeader('access-token'))
-                    localStorage.setItem('@portalmec/accessToken', this.getResponseHeader('access-token')!)
-                }
-            }
-        }
-        this.request.overrideMimeType('application/octet-stream');
-
-        this.file = file;
-        this.name = name;
-        this.draftID = draftID;
-        this.uploadUrl = 'https://api.portalmec.c3sl.ufpr.br/v1/learning_objects/' + draftID + '/chunk'
-        this._chunkIdentifier = draftID + '-'  + this.name;
-        this._chunkNumber = 0;
-
-        this.currentChunkStartByte = 0;
-        this.currentChunkFinalByte = FileToUpload.chunkSize > this.file.size ? this.file.size : FileToUpload.chunkSize;
-    }
-
-    uploadFile() {
-        this.request.open('POST', this.uploadUrl, true);
-
-        let chunk: Blob = this.file.slice(this.currentChunkStartByte, this.currentChunkFinalByte);  // split the file according to the boundaries
-
-        //set necessary headers
-        this.request.setRequestHeader('Content-Range', `bytes ${this.currentChunkStartByte}-${this.currentChunkFinalByte}/${this.file.size}`);
-        if (localStorage.getItem('@portalmec/uid') != undefined) {
-            this.request.setRequestHeader('uid', localStorage.getItem('@portalmec/uid')!)
-        }
-        if (localStorage.getItem('@portalmec/clientToken') != undefined) {
-            this.request.setRequestHeader('client', String(localStorage.getItem('@portalmec/clientToken')))
-        }
-        if (localStorage.getItem('@portalmec/accessToken') != undefined) {
-            this.request.setRequestHeader('access-token', String(localStorage.getItem('@portalmec/accessToken')))
-        }
-
-        this.request.onload = () => {
-            const remainingBytes = this.file.size - this.currentChunkFinalByte;
-
-            if(this.currentChunkFinalByte === this.file.size) {
-                alert('Yay, upload completed! Chao!');
-                return('done');
-            } else if (remainingBytes < FileToUpload.chunkSize) {
-                // if the remaining chunk is smaller than the chunk size we defined
-                this.currentChunkStartByte = this.currentChunkFinalByte;
-                this.currentChunkFinalByte = this.currentChunkStartByte + remainingBytes;
-            }
-            else {
-                // keep chunking
-                this.currentChunkStartByte = this.currentChunkFinalByte;
-                this.currentChunkFinalByte = this.currentChunkStartByte + FileToUpload.chunkSize;
-            }
-
-            this._chunkNumber = this._chunkNumber + 1
-            this.uploadFile();
-        }
-
-        //add attributes
-        const formData = new FormData();
-        formData.append('_chunkFilename', this.file.name);
-        formData.append('_chunkIdentifier', this._chunkIdentifier);
-        formData.append('_totalChunks', String(Math.ceil(this.file.size/FileToUpload.chunkSize)));
-        formData.append('_chunkSize', String(FileToUpload.chunkSize));
-        formData.append('_currentChunkSize', String(this.currentChunkFinalByte - this.currentChunkStartByte));
-        formData.append('_chunkNumber', String(this._chunkNumber));
-        formData.append('_totalSize', String(this.file.size));
-        formData.append('file', chunk);
-
-        this.request.send(formData);// send it now!
-    }
-
-}
diff --git a/src/Components/UploadPageComponents/FileUploadStage.js b/src/Components/UploadPageComponents/FileUploadStage.js
deleted file mode 100644
index 880ff018ef65d34cdf952b8829dedfd819f647b6..0000000000000000000000000000000000000000
--- a/src/Components/UploadPageComponents/FileUploadStage.js
+++ /dev/null
@@ -1,65 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, {useState} from 'react'
-import styled from 'styled-components'
-import {WrapperBox} from './StyledComponents.js'
-import DoneIcon from '@material-ui/icons/Done';
-import DeleteIcon from '@material-ui/icons/Delete';
-import {deleteRequest} from '../HelperFunctions/getAxiosConfig.js'
-
-export default function FileUploadStage (props) {
-    const [uploading, toggleUploading] = useState(true)
-
-    function handleSuccess (data) {
-        props.handleNextStage("default")
-    }
-    const handleDelete = () => {
-        const url = `/learning_objects/${props.draftID}`
-
-        deleteRequest(url, handleSuccess, (error) => {console.log(error)})
-    }
-
-    return (
-        <WrapperBox>
-            <div className="inner">
-                <div className="upload-title">
-                    {uploading ? 'Carregando arquivo' : 'O arquivo foi carregado'}
-                </div>
-
-                <div className="uploading">
-                    <div className="upload-item">
-                        <div className="item-info">
-                            <div className="file-status">
-                                <DoneIcon className="icon icon-margin"/> {props.file.name}
-                            </div>
-                            <div className="remove-file" onClick={handleDelete}>
-                                Excluir <DeleteIcon className="icon icon-remove"/>
-                            </div>
-                        </div>
-                    </div>
-                    <div className="warning">
-                        <span>Não se esqueça de preencher as</span>
-                        <br/>
-                        <span>informações sobre o recurso ao lado.</span>
-                    </div>
-                </div>
-            </div>
-        </WrapperBox>
-    )
-}
diff --git a/src/Components/UploadPageComponents/ReactFileToUpload.js b/src/Components/UploadPageComponents/ReactFileToUpload.js
deleted file mode 100644
index ffbd6a452bddfe13eb14c996498ca17a897af2de..0000000000000000000000000000000000000000
--- a/src/Components/UploadPageComponents/ReactFileToUpload.js
+++ /dev/null
@@ -1,113 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, {useState, useEffect} from 'react'
-import CloudUploadIcon from '@material-ui/icons/CloudUpload';
-import {DottedBox, BlueButton} from './StyledComponents.js';
-import {getAxiosConfigFromJSON, updateHeaders} from '../HelperFunctions/getAxiosConfig.js'
-import AddAPhotoIcon from '@material-ui/icons/AddAPhoto';
-import axios from 'axios'
-import {apiUrl} from '../../env';
-
-export default function ReactFileToUpload (props) {
-    const [fileToUpload, setFileToUpload] = useState(null);
-    const chunkSize = 262144
-    const uploadUrl = `${apiUrl}/learning_objects/` + props.draftID + '/chunk'
-    const [fileName, setFileName] = useState(null)
-    const [fileSize, setFileSize] = useState(null)
-    const [fileDoneUploading, setFileDoneUploading] = useState(false)
-
-    async function onFileChange (e) {
-        const files = e.target.files;
-        if(!files) return;
-
-        let newFile = e.target.files[0]
-        console.log(newFile)
-        setFileToUpload(newFile);
-        setFileName(newFile.name)
-        setFileSize(newFile.size)
-
-        let total = Math.ceil(newFile.size/chunkSize)
-        let currentChunkStartByte = 0;
-        let currentChunkFinalByte = chunkSize > newFile.size ? newFile.size : chunkSize;
-        let chunkIdentifier = props.draftID + '-' + newFile.name;
-        let remainingBytes = 0
-
-        for (var i = 0; i < total; i++) {
-            let chunk = newFile.slice(currentChunkStartByte, currentChunkFinalByte)
-            let config = getAxiosConfigFromJSON()
-            let formData = new FormData()
-            formData.append('_chunkFilename', newFile.name);
-            formData.append('_chunkIdentifier', chunkIdentifier);
-            formData.append('_totalChunks', total);
-            formData.append('_chunkSize', chunkSize);
-            formData.append('_currentChunkSize', chunk.size);
-            formData.append('_chunkNumber', i);
-            formData.append('_totalSize', newFile.size);
-            formData.append('file', chunk);
-
-            try {
-                const response = await axios.post(uploadUrl, formData, config);
-                console.log(response)
-                if (response.headers['access-token']) {
-                    updateHeaders(response.headers)
-                }
-                remainingBytes = newFile.size - currentChunkFinalByte;
-                if (currentChunkFinalByte === newFile.size) {
-                    setFileDoneUploading(true)
-                }
-                else if (remainingBytes < chunkSize) {
-                    currentChunkStartByte = currentChunkFinalByte;
-                    currentChunkFinalByte = currentChunkStartByte + remainingBytes;
-                }
-                else {
-                    currentChunkStartByte = currentChunkFinalByte;
-                    currentChunkFinalByte = currentChunkStartByte + chunkSize;
-                }
-            } catch (error) {
-                console.log(error)
-            }
-        }
-    };
-
-    return (
-        <div className="upload-container">
-            <h2 className="upload-title">File Uploader</h2>
-            <div className="upload-form">
-                <form id="file_upload">
-                    <DottedBox
-                        >
-                        <AddAPhotoIcon className="icon"/>
-                        <input
-                            type="file"
-                            onChange = {onFileChange}
-                            id="upload-file-thumbnail"
-                            style={{display : "none"}}
-                            />
-                        <BlueButton>
-                            <label htmlFor="upload-file-thumbnail" style={{width : "inherit", cursor : "pointer"}}>
-                                ESCOLHER IMAGEM
-                            </label>
-                        </BlueButton>
-                        <span style={{marginTop : "6px"}}>Ou arrastar e soltar o arquivo aqui</span>
-                    </DottedBox>
-                </form>
-            </div>
-        </div>
-    )
-}
diff --git a/src/Components/UserPageComponents/Avatar.js b/src/Components/UserPageComponents/Avatar.js
index 8c381f197741f833d9171c58b780ffb37bb8ad1b..8f3c05b8ff5937ef8609e24ed3015dc136860a09 100644
--- a/src/Components/UserPageComponents/Avatar.js
+++ b/src/Components/UserPageComponents/Avatar.js
@@ -19,9 +19,11 @@ import React, {useState, useContext, useEffect} from 'react';
 import styled from 'styled-components'
 import { Store } from '../../Store.js';
 import { apiDomain} from '../../env';
-import noAvatar from "../../img/default_profile.png";
 import ModalAlterarAvatar from '../ModalAlterarAvatar/ModalAlterarAvatar.js'
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 export default function ProfileAvatar (props) {
     // eslint-disable-next-line
     const {state, dispatch} = useContext(Store)
diff --git a/src/Components/stars.js b/src/Components/stars.js
deleted file mode 100644
index 39ea6f90116b4356fa44d46b0d49e3c5e89f87e6..0000000000000000000000000000000000000000
--- a/src/Components/stars.js
+++ /dev/null
@@ -1,230 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import { randomNumber } from './app';
-
-import Widget from 'widget';
-
-class WidgetRatings extends React.Component {
-  constructor(props) {
-    super(props);
-    this.fillId = `widgetGrad${randomNumber()}`;
-    this.state = {
-      highestWidgetHovered: -Infinity
-    }
-  }
-  static Widget = Widget
-
-  get
-  widgetRatingsStyle() {
-    const widgetRatingsStyle = {
-      position: 'relative',
-      boxSizing: 'border-box',
-      display: 'inline-block'
-    };
-    return this.props.ignoreInlineStyles ? {} : widgetRatingsStyle;
-  }
-
-  get
-  widgetGradientStyle() {
-    const widgetGradientStyle = {
-      position: 'absolute',
-      zIndex: '0',
-      width: '0',
-      height: '0',
-      visibility: 'hidden'
-    };
-    return this.props.ignoreInlineStyles ? {} : widgetGradientStyle;
-  }
-
-  stopColorStyle(color) {
-    const stopColorStyle = {
-      stopColor: color,
-      stopOpacity: '1'
-    };
-    return this.props.ignoreInlineStyles ? {} : stopColorStyle;
-  }
-
-  get
-  titleText() {
-    const {
-      typeOfWidget,
-      rating: selectedRating
-    } = this.props;
-    const hoveredRating = this.state.highestWidgetHovered;
-    const currentRating = hoveredRating > 0 ? hoveredRating : selectedRating;
-    // fix it at 2 decimal places and remove trailing 0s
-    let formattedRating = parseFloat(currentRating.toFixed(2)).toString();
-    if (Number.isInteger(currentRating)) {
-      formattedRating = String(currentRating);
-    }
-    let widgetText = `${typeOfWidget}s`;
-    if (formattedRating === '1') {
-      widgetText = typeOfWidget;
-    }
-    return `${formattedRating} ${widgetText}`;
-  }
-
-  get
-  offsetValue() {
-    const rating = this.props.rating;
-    const ratingIsInteger = Number.isInteger(rating);
-    let offsetValue = '0%';
-    if (!ratingIsInteger) {
-      const firstTwoDecimals = rating.toFixed(2).split('.')[1].slice(0, 2);
-      offsetValue = `${firstTwoDecimals}%`;
-    }
-    return offsetValue;
-  }
-
-  unHoverOverWidget = () => {
-    this.setState({
-      highestWidgetHovered: -Infinity
-    })
-  }
-
-  hoverOverWidget = (rating) => {
-    return () => {
-      this.setState({
-        highestWidgetHovered: rating
-      })
-    }
-  }
-
-  get
-  childrenWithRatingState() {
-    const {
-      changeRating,
-      rating: selectedRating,
-      children,
-      ignoreInlineStyles,
-      gradientPathName,
-      widgetEmptyColors,
-      widgetHoverColors,
-      widgetRatedColors,
-      widgetDimensions,
-      widgetSpacings,
-      svgIconPaths,
-      svgIconViewBoxes,
-      svgs
-    } = this.props;
-    const { highestWidgetHovered } = this.state;
-
-    const numberOfWidgets = children.length;
-    return React.Children.map(children, (child, index) => {
-      const {
-        svgIconPath,
-        svgIconViewBox,
-        widgetHoverColor,
-        widgetEmptyColor,
-        widgetRatedColor,
-        widgetDimension,
-        widgetSpacing,
-        svg
-      } = child.props;
-
-      const widgetRating = index + 1;
-      const isSelected = widgetRating <= selectedRating;
-
-      // hovered only matters when changeRating is true
-      const hoverMode = highestWidgetHovered > 0;
-      const isHovered = widgetRating <= highestWidgetHovered;
-      const isCurrentHoveredWidget = widgetRating === highestWidgetHovered;
-
-      // only matters when changeRating is false
-      // given widget 5 and rating 4.2:  5 > 4.2 && 4 < 4.2;
-      const isPartiallyFullWidget = widgetRating > selectedRating && widgetRating - 1 < selectedRating
-
-      const isFirstWidget = widgetRating === 1;
-      const isLastWidget = widgetRating === numberOfWidgets;
-
-      return React.cloneElement(child, {
-        selectedRating: selectedRating,
-        ignoreInlineStyles,
-        gradientPathName,
-        changeRating: changeRating ? () => changeRating(widgetRating) : null,
-        hoverOverWidget: changeRating ? this.hoverOverWidget(widgetRating) : null,
-        unHoverOverWidget: changeRating ? this.unHoverOverWidget : null,
-        inheritFillId: this.fillId,
-        isSelected,
-        isHovered,
-        isCurrentHoveredWidget,
-        isPartiallyFullWidget,
-        isFirstWidget,
-        isLastWidget,
-        hoverMode,
-        hasCustomGradientColor: (widgetRatedColor || widgetEmptyColor) && isPartiallyFullWidget,
-        svgIconPath: svgIconPath || svgIconPaths,
-        svgIconViewBox: svgIconViewBox || svgIconViewBoxes,
-        widgetHoverColor: widgetHoverColor || widgetHoverColors,
-        widgetEmptyColor: widgetEmptyColor || widgetEmptyColors,
-        widgetRatedColor: widgetRatedColor || widgetRatedColors,
-        widgetDimension: widgetDimension || widgetDimensions,
-        widgetSpacing: widgetSpacing || widgetSpacings,
-        svg: svg || svgs
-      });
-    });
-  }
-
-  render() {
-    const {
-      widgetEmptyColors,
-      widgetRatedColors
-    } = this.props;
-
-    return (
-      <div
-        className="widget-ratings"
-        title={this.titleText}
-        style={this.widgetRatingsStyle}
-      >
-        <svg
-          className="widget-grad"
-          style={this.widgetGradientStyle}
-        >
-          <defs>
-            <linearGradient id={this.fillId} x1="0%" y1="0%" x2="100%" y2="0%">
-              <stop offset="0%" className="stop-color-first" style={this.stopColorStyle(widgetRatedColors)} />
-              <stop offset={this.offsetValue} className="stop-color-first" style={this.stopColorStyle(widgetRatedColors)} />
-              <stop offset={this.offsetValue} className="stop-color-final" style={this.stopColorStyle(widgetEmptyColors)} />
-              <stop offset="100%" className="stop-color-final" style={this.stopColorStyle(widgetEmptyColors)} />
-            </linearGradient>
-          </defs>
-        </svg>
-        {this.childrenWithRatingState}
-      </div>
-    );
-  }
-}
-
-WidgetRatings.defaultProps = {
-  rating: 0,
-  typeOfWidget: 'Star',
-  changeRating: null,
-  ignoreInlineStyles: false,
-  gradientPathName: '',
-  svgIconPaths: 'm25,1 6,17h18l-14,11 5,17-15-10-15,10 5-17-14-11h18z',
-  svgIconViewBoxes: '0 0 51 48',
-  widgetRatedColors: 'rgb(109, 122, 130)',
-  widgetEmptyColors: 'rgb(203, 211, 227)',
-  widgetHoverColors: 'rgb(230, 67, 47)',
-  widgetDimensions: '50px',
-  widgetSpacings: '7px',
-};
-
-export default WidgetRatings;
diff --git a/src/ImportImages.js b/src/ImportImages.js
new file mode 100644
index 0000000000000000000000000000000000000000..8b4e8c76e1257a0cb17c2100c21d23a5fa48d883
--- /dev/null
+++ b/src/ImportImages.js
@@ -0,0 +1,151 @@
+/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
+Departamento de Informatica - Universidade Federal do Parana
+
+This file is part of Plataforma Integrada MEC.
+
+Plataforma Integrada MEC is free software: you can redistribute it and/or modify
+it under the terms of the GNU Affero General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+
+Plataforma Integrada MEC is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+GNU Affero General Public License for more details.
+
+You should have received a copy of the GNU Affero General Public License
+along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
+
+/*
+
+//Image Import
+import { image } from "ImportImages.js"; 
+
+For an example of how to convert png and jpg images to webp:
+cwebp -q 80 filein.png -o filein.webp
+
+*/
+
+const webpSupport = localStorage.getItem('webpSupport');
+
+export const acessoInfo = (webpSupport ? require('./img/acesso-a-informacao.webp') : require('./img/acesso-a-informacao.png')); 
+export const Bolo = (webpSupport ? require('./img/Bolo.webp') : require('./img/Bolo.png')); 
+export const License = (webpSupport ? require('./img/cc_license.webp') : require('./img/cc_license.png')); 
+export const Comentarios = (webpSupport ? require('./img/comentarios.webp') : require('./img/comentarios.png')); 
+export const Profile = (webpSupport ? require('./img/default_profile0.webp') : require('./img/default_profile0.png')); 
+export const noAvatar = (webpSupport ? require('./img/default_profile.webp') : require('./img/default_profile.png')); 
+//export const  = (webpSupport ? require('./img/ecd.webp') : require('./img/ecd.png')); 
+export const eduConectada = (webpSupport ? require('./img/educa-conectada.webp') : require('./img/educa-conectada.png')); 
+export const ExcluirAvatar = (webpSupport ? require('./img/Excluir.webp') : require('./img/Excluir.png')); 
+export const FollowingIcon = (webpSupport ? require('./img/how_to_reg-24px.webp') : require('./img/how_to_reg-24px.png')); 
+export const colecoes = (webpSupport ? require('./img/ilustra_colecoes.webp') : require('./img/ilustra_colecoes.png')); 
+export const materiais = (webpSupport ? require('./img/ilustra_materiais.webp') : require('./img/ilustra_materiais.png')); 
+export const recursos = (webpSupport ? require('./img/ilustra_recursos_digitais.webp') : require('./img/ilustra_recursos_digitais.png')); 
+export const defaultNoContent = (webpSupport ? require('./img/img-16.webp') : require('./img/img-16.png')); 
+export const acessar = (webpSupport ? require('./img/nopub-Acessar-materiais.webp') : require('./img/nopub-Acessar-materiais.png')); 
+export const baixar = (webpSupport ? require('./img/nopub-Baixar.webp') : require('./img/nopub-Baixar.png')); 
+export const compartilhar = (webpSupport ? require('./img/nopub-Compartilhar.webp') : require('./img/nopub-Compartilhar.png')); 
+export const guardar = (webpSupport ? require('./img/nopub-Guardar.webp') : require('./img/nopub-Guardar.png')); 
+export const relatar = (webpSupport ? require('./img/nopub-Relatar.webp') : require('./img/nopub-Relatar.png')); 
+export const seguir = (webpSupport ? require('./img/nopub-Seguir.webp') : require('./img/nopub-Seguir.png')); 
+export const NoRede1 = (webpSupport ? require('./img/no-rede-1.webp') : require('./img/no-rede-1.png')); 
+export const NoRede2 = (webpSupport ? require('./img/no-rede-2.webp') : require('./img/no-rede-2.png')); 
+export const NoRede3 = (webpSupport ? require('./img/no-rede-3.webp') : require('./img/no-rede-3.png')); 
+export const ColecaoVazia = (webpSupport ? require('./img/Pagina_vazia_colecao.webp') : require('./img/Pagina_vazia_colecao.png')); 
+export const RecursoVazio = (webpSupport ? require('./img/Pagina_vazia_Sem_publicar.webp') : require('./img/Pagina_vazia_Sem_publicar.png')); 
+export const Publicar = (webpSupport ? require('./img/Publicar.webp') : require('./img/Publicar.png')); 
+export const banner = (webpSupport ? require('./img/bannerBusca.webp') : require('./img/bannerBusca.jpg')); 
+export const bannerMobile = (webpSupport ? require('./img/banner-mobile.webp') : require('./img/banner-mobile.jpg')); 
+export const Banner1 = (webpSupport ? require('./img/banner-sobre.webp') : require('./img/banner-sobre.jpg')); 
+//export const  = (webpSupport ? require('./img/girassol.webp') : require('./img/girassol.jpg')); 
+export const Banner3 = (webpSupport ? require('./img/ajuda/Banner3.webp') : require('./img/ajuda/Banner3.png')); 
+export const EncontrandoRecurso = (webpSupport ? require('./img/ajuda/Encontrando_recursos.webp') : require('./img/ajuda/Encontrando_recursos.png')); 
+export const GerenciandoConta = (webpSupport ? require('./img/ajuda/Gerenciando_a_conta.webp') : require('./img/ajuda/Gerenciando_a_conta.png')); 
+export const ParticipandoRede = (webpSupport ? require('./img/ajuda/Participando_da_rede.webp') : require('./img/ajuda/Participando_da_rede.png')); 
+export const PublicandoRecursos = (webpSupport ? require('./img/ajuda/Publicando_recursos.webp') : require('./img/ajuda/Publicando_recursos.png')); 
+export const Busca = (webpSupport ? require('./img/ajuda/busca_img.webp') : require('./img/ajuda/busca_img.jpg')); 
+export const Filtros = (webpSupport ? require('./img/ajuda/filtros_img.webp') : require('./img/ajuda/filtros_img.jpg')); 
+export const LoginImg = (webpSupport ? require('./img/ajuda/login_img.webp') : require('./img/ajuda/login_img.jpg')); 
+export const RecuperarSenhaImg = (webpSupport ? require('./img/ajuda/recuperarsenha_img.webp') : require('./img/ajuda/recuperarsenha_img.jpg')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Ativado_dot1.webp') : require('./img/carousel/Icone_Ativado_dot1.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Ativado_dot2.webp') : require('./img/carousel/Icone_Ativado_dot2.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Ativado_dot3.webp') : require('./img/carousel/Icone_Ativado_dot3.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Ativado_dot4.webp') : require('./img/carousel/Icone_Ativado_dot4.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Ativado_dot5.webp') : require('./img/carousel/Icone_Ativado_dot5.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Desativado_dot1.webp') : require('./img/carousel/Icone_Desativado_dot1.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Desativado_dot2.webp') : require('./img/carousel/Icone_Desativado_dot2.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Desativado_dot3.webp') : require('./img/carousel/Icone_Desativado_dot3.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Desativado_dot4.webp') : require('./img/carousel/Icone_Desativado_dot4.png')); 
+//export const  = (webpSupport ? require('./img/carousel/Icone_Desativado_dot5.webp') : require('./img/carousel/Icone_Desativado_dot5.png')); 
+export const Img1 = (webpSupport ? require('./img/carousel/Icone_Grande (1).webp') : require('./img/carousel/Icone_Grande (1).png')); 
+export const Img2 = (webpSupport ? require('./img/carousel/Icone_Grande (2).webp') : require('./img/carousel/Icone_Grande (2).png')); 
+export const Img3 = (webpSupport ? require('./img/carousel/Icone_Grande (3).webp') : require('./img/carousel/Icone_Grande (3).png')); 
+export const Img4 = (webpSupport ? require('./img/carousel/Icone_Grande (4).webp') : require('./img/carousel/Icone_Grande (4).png')); 
+export const Img5 = (webpSupport ? require('./img/carousel/Icone_Grande (5).webp') : require('./img/carousel/Icone_Grande (5).png')); 
+export const Animacao = (webpSupport ? require('./img/laranja/ANIMACAO_SIMULACAO.webp') : require('./img/laranja/ANIMACAO_SIMULACAO.jpg')); 
+export const AplicativoMovel = (webpSupport ? require('./img/laranja/APP.webp') : require('./img/laranja/APP.jpg')); 
+export const Apresentacao = (webpSupport ? require('./img/laranja/APRESENTACAO.webp') : require('./img/laranja/APRESENTACAO.jpg')); 
+export const Audio = (webpSupport ? require('./img/laranja/AUDIO.webp') : require('./img/laranja/AUDIO.jpg')); 
+export const Empty = (webpSupport ? require('./img/laranja/EMPTY.webp') : require('./img/laranja/EMPTY.jpg')); 
+export const Imagem = (webpSupport ? require('./img/laranja/IMAGEM.webp') : require('./img/laranja/IMAGEM.jpg')); 
+export const Infografico = (webpSupport ? require('./img/laranja/INFOGRAFICO.webp') : require('./img/laranja/INFOGRAFICO.jpg')); 
+export const Jogo = (webpSupport ? require('./img/laranja/JOGO.webp') : require('./img/laranja/JOGO.jpg')); 
+export const LivroDigital = (webpSupport ? require('./img/laranja/LIVRO_DIGITAL.webp') : require('./img/laranja/LIVRO_DIGITAL.jpg')); 
+export const Mapa = (webpSupport ? require('./img/laranja/MAPA.webp') : require('./img/laranja/MAPA.jpg')); 
+export const Outros = (webpSupport ? require('./img/laranja/OUTROS.webp') : require('./img/laranja/OUTROS.jpg')); 
+export const SoftwareEducacional = (webpSupport ? require('./img/laranja/SOFTWARE.webp') : require('./img/laranja/SOFTWARE.jpg')); 
+export const Texto = (webpSupport ? require('./img/laranja/TEXTO.webp') : require('./img/laranja/TEXTO.jpg')); 
+export const Video = (webpSupport ? require('./img/laranja/VIDEO.webp') : require('./img/laranja/VIDEO.jpg')); 
+export const Educagital = (webpSupport ? require('./img/logo_parceiros/educagital.webp') : require('./img/logo_parceiros/educagital.png')); 
+export const EnefAef = (webpSupport ? require('./img/logo_parceiros/ENEF_AEF.webp') : require('./img/logo_parceiros/ENEF_AEF.png')); 
+export const FundacaoLemann = (webpSupport ? require('./img/logo_parceiros/fundacao-lemann.webp') : require('./img/logo_parceiros/fundacao-lemann.png')); 
+export const Futura = (webpSupport ? require('./img/logo_parceiros/futura.webp') : require('./img/logo_parceiros/futura.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/ic_bioe.webp') : require('./img/logo_parceiros/ic_bioe.png')); 
+export const IcDefault = (webpSupport ? require('./img/logo_parceiros/ic_default.webp') : require('./img/logo_parceiros/ic_default.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/ic_diaadia.webp') : require('./img/logo_parceiros/ic_diaadia.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/ic_dominiopublico.webp') : require('./img/logo_parceiros/ic_dominiopublico.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/ic_escoladigital.webp') : require('./img/logo_parceiros/ic_escoladigital.png')); 
+export const IcNute = (webpSupport ? require('./img/logo_parceiros/ic_nute.webp') : require('./img/logo_parceiros/ic_nute.png')); 
+export const IcPeninsula = (webpSupport ? require('./img/logo_parceiros/ic_peninsula.webp') : require('./img/logo_parceiros/ic_peninsula.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/ic_phet.webp') : require('./img/logo_parceiros/ic_phet.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/ic_portaldoprofessor.webp') : require('./img/logo_parceiros/ic_portaldoprofessor.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/ic_tvescola.webp') : require('./img/logo_parceiros/ic_tvescola.png')); 
+export const Impa = (webpSupport ? require('./img/logo_parceiros/impa.webp') : require('./img/logo_parceiros/impa.png')); 
+export const Impulsiona = (webpSupport ? require('./img/logo_parceiros/impulsiona.webp') : require('./img/logo_parceiros/impulsiona.png')); 
+export const InstitutoCrescer = (webpSupport ? require('./img/logo_parceiros/instituto-crescer.webp') : require('./img/logo_parceiros/instituto-crescer.png')); 
+export const InstPeninsula = (webpSupport ? require('./img/logo_parceiros/inst-peninsula.webp') : require('./img/logo_parceiros/inst-peninsula.png')); 
+export const LogoBioe = (webpSupport ? require('./img/logo_parceiros/logo_bioe.webp') : require('./img/logo_parceiros/logo_bioe.png')); 
+export const LogoDominioPublico = (webpSupport ? require('./img/logo_parceiros/logo_dominiopublico.webp') : require('./img/logo_parceiros/logo_dominiopublico.png')); 
+//export const  = (webpSupport ? require('./img/logo_parceiros/logo_escoladigital.webp') : require('./img/logo_parceiros/logo_escoladigital.png')); 
+export const LogoPortalDoProfessor = (webpSupport ? require('./img/logo_parceiros/logo_portaldoprofessor.webp') : require('./img/logo_parceiros/logo_portaldoprofessor.png')); 
+export const LogoTvEscola = (webpSupport ? require('./img/logo_parceiros/logo_tvescola.webp') : require('./img/logo_parceiros/logo_tvescola.png')); 
+export const RedeEscola = (webpSupport ? require('./img/logo_parceiros/redeescola.webp') : require('./img/logo_parceiros/redeescola.png')); 
+export const Safer = (webpSupport ? require('./img/logo_parceiros/safer.webp') : require('./img/logo_parceiros/safer.png')); 
+export const Telefonica = (webpSupport ? require('./img/logo_parceiros/telefonica.webp') : require('./img/logo_parceiros/telefonica.png')); 
+export const Alunos = (webpSupport ? require('./img/sobre/Alunos.webp') : require('./img/sobre/Alunos.png')); 
+export const Comunidade = (webpSupport ? require('./img/sobre/comunidade.webp') : require('./img/sobre/comunidade.png')); 
+export const Gestores = (webpSupport ? require('./img/sobre/Gestores.webp') : require('./img/sobre/Gestores.png')); 
+export const Notebook = (webpSupport ? require('./img/sobre/Imagem_Notebook.webp') : require('./img/sobre/Imagem_Notebook.png')); 
+export const Banner2 = (webpSupport ? require('./img/sobre/banner-sobre-2.webp') : require('./img/sobre/banner-sobre-2.jpg')); 
+export const Professores = (webpSupport ? require('./img/sobre/professores.webp') : require('./img/sobre/professores.jpg')); 
+export const Aberto = (webpSupport ? require('./img/termos/Aberto.webp') : require('./img/termos/Aberto.png')); 
+//export const  = (webpSupport ? require('./img/termos/Arrow_aberto e fechado-1.webp') : require('./img/termos/Arrow_aberto e fechado-1.png')); 
+//export const  = (webpSupport ? require('./img/termos/Arrow_aberto e fechado.webp') : require('./img/termos/Arrow_aberto e fechado.png')); 
+//export const  = (webpSupport ? require('./img/termos/Arrow_Direito do autor.webp') : require('./img/termos/Arrow_Direito do autor.png')); 
+//export const  = (webpSupport ? require('./img/termos/Arrow_Direitos e Licença1.webp') : require('./img/termos/Arrow_Direitos e Licença1.png')); 
+//export const  = (webpSupport ? require('./img/termos/Arrow_Direitos e Licença2.webp') : require('./img/termos/Arrow_Direitos e Licença2.png')); 
+export const Arrow_O_1 = (webpSupport ? require('./img/termos/Arrow_O que é a plataforma-1.webp') : require('./img/termos/Arrow_O que é a plataforma-1.png')); 
+export const Arrow_O = (webpSupport ? require('./img/termos/Arrow_O que é a plataforma.webp') : require('./img/termos/Arrow_O que é a plataforma.png')); 
+export const BuscaTermos = (webpSupport ? require('./img/termos/Busca.webp') : require('./img/termos/Busca.png')); 
+//export const  = (webpSupport ? require('./img/termos/Compromisso.webp') : require('./img/termos/Compromisso.png')); 
+export const Fechado = (webpSupport ? require('./img/termos/Fechado.webp') : require('./img/termos/Fechado.png')); 
+//export const  = (webpSupport ? require('./img/termos/Mail.webp') : require('./img/termos/Mail.png')); 
+//export const  = (webpSupport ? require('./img/termos/Negativo.webp') : require('./img/termos/Negativo.png')); 
+export const OrthogonalLineDown = (webpSupport ? require('./img/termos/OrthogonalLineDown.webp') : require('./img/termos/OrthogonalLineDown.png')); 
+export const OrthogonalLineUp = (webpSupport ? require('./img/termos/OrthogonalLineUp.webp') : require('./img/termos/OrthogonalLineUp.png')); 
+//export const  = (webpSupport ? require('./img/termos/Positivo.webp') : require('./img/termos/Positivo.png')); 
+//export const  = (webpSupport ? require('./img/termos/Senha.webp') : require('./img/termos/Senha.png')); 
+//export const  = (webpSupport ? require('./img/termos/Usuário.webp') : require('./img/termos/Usuário.png')); 
+export const Banner = (webpSupport ? require('./img/termos/banner.webp') : require('./img/termos/banner.jpg')); 
+
+export default noAvatar;
\ No newline at end of file
diff --git a/src/Pages/AboutPage.js b/src/Pages/AboutPage.js
index 98fdfd0596c3aa455cac4ee0b3769a7cdac3a1cd..ab1b6bbbe3a74ce0f0d2ee7ad58b8b5b2e434956 100644
--- a/src/Pages/AboutPage.js
+++ b/src/Pages/AboutPage.js
@@ -26,12 +26,14 @@ import AboutCarouselPartner from '../Components/AboutCarouselPartner';
 
 /*Importação de imagens para o componente*/
 import Agpl from "../img/sobre/agpl.svg";
-import Banner from "../img/sobre/banner-sobre-2.jpg";
-import Notebook from "../img/sobre/Imagem_Notebook.png";
-import Professores from "../img/sobre/professores.jpg";
-import Alunos from "../img/sobre/Alunos.png";
-import Gestores from "../img/sobre/Gestores.png";
-import Comunidade from "../img/sobre/comunidade.png";
+
+//Image Import
+import { Banner2 } from "ImportImages.js";
+import { Notebook } from "ImportImages.js";
+import { Professores } from "ImportImages.js";
+import { Alunos } from "ImportImages.js";
+import { Gestores } from "ImportImages.js";
+import { Comunidade } from "ImportImages.js";
 
 
 const Secao1 = styled.div`
@@ -271,7 +273,7 @@ const Secao4 = styled.div`
 
 const Secao5 = styled.div`
   height: 370px;
-  background-image: url(${Banner});
+  background-image: url(${Banner2});
   background-position: top center;
   background-size: cover;
   text-align: center;
diff --git a/src/Pages/ChangePasswordPage.js b/src/Pages/ChangePasswordPage.js
new file mode 100644
index 0000000000000000000000000000000000000000..cf552c07180f6e589cb39e9c697c50f4df2641cc
--- /dev/null
+++ b/src/Pages/ChangePasswordPage.js
@@ -0,0 +1,335 @@
+import React, { useState } from "react";
+import { BackgroundDiv } from '../Components/TabPanels/StyledComponents.js'
+import Paper from '@material-ui/core/Paper'
+import styled from 'styled-components'
+import FormInput from "../Components/FormInput.js"
+import { CompletarCadastroButton } from '../Components/TabPanels/UserPageTabs/PanelSolicitarContaProfessor.js'
+import ValidateUserInput from '../Components/HelperFunctions/FormValidationFunction.js'
+import CustomizedBreadcrumbs from '../Components/TabPanels/Breadcrumbs.js'
+import { putRequest } from '../Components/HelperFunctions/getAxiosConfig'
+import Snackbar from '@material-ui/core/Snackbar'
+import MuiAlert from '@material-ui/lab/Alert'
+import Grid from '@material-ui/core/Grid'
+import IconButton from '@material-ui/core/IconButton'
+import VisibilityIcon from '@material-ui/icons/Visibility'
+import VisibilityOffIcon from '@material-ui/icons/VisibilityOff'
+
+function Alert(props) {
+    return <MuiAlert elevation={6} variant="filled" {...props} />;
+}
+
+export default function ChangePasswordPage(props) {
+
+    const [error, setError] = useState(false)
+    const [success, setSuccess] = useState(false)
+    const [time, setTime] = useState(5)
+
+    const [formPassword, setPassword] = useState(
+        {
+            key: false,
+            hidePass: true,
+            value: ""
+        }
+    )
+
+    const [formPasswordConfirmation, setPasswordConfirmation] = useState(
+        {
+            key: false,
+            hidePass: true,
+            value: ""
+        }
+    )
+
+    const [snackInfo, setSnackInfo] = useState({
+        open: false,
+        text: "",
+        severity: "",
+    });
+
+    const handleChange = (e, field) => {
+        const userInput = e.target.value;
+        const flag = ValidateUserInput('password', userInput);
+
+        if (field === "password") {
+            setPassword({
+                ...formPassword,
+                key: flag,
+                value: userInput
+            })
+        } else {
+            setPasswordConfirmation({
+                ...formPasswordConfirmation,
+                key: flag,
+                value: userInput
+            })
+        }
+
+    }
+
+    const onSubmit = () => {
+        const flag = ValidateUserInput('confirmation', formPassword.value, formPasswordConfirmation.value);
+
+        if (flag === true) {
+            const snackInfo = {
+                open: true,
+                text: "As senhas inseridas não são iguais",
+                severity: "warning",
+            }
+            handleSnackInfo(snackInfo)
+        } else {
+            //console.log("senha bate");
+            if (!formPassword.key && !formPasswordConfirmation.key) {
+                console.log("senha bate");
+
+                const urlParams = new URLSearchParams(window.location.search);
+                const clientId = urlParams.get("client_id");
+                const config = urlParams.get("config");
+                const expiry = urlParams.get("expiry");
+                const resetPassword = urlParams.get("reset_password");
+                const token = urlParams.get("token");
+                const uid = urlParams.get("uid");
+
+                const url = `/auth/password`
+
+                const payload = {
+                    "password": formPassword.value,
+                    "password_confirmation": formPasswordConfirmation.value,
+                    "client": clientId,
+                    "config": config,
+                    "expiry": expiry,
+                    "reset_password": resetPassword,
+                    "access-token": token,
+                    "uid": uid
+                }
+
+                putRequest(
+                    url,
+                    payload,
+                    () => {
+                        setSuccess(true)
+                        let count = 0;
+                        const snackInfo = {
+                            open: true,
+                            text: "Sua senha foi atualizada!",
+                            severity: "success",
+                        }
+                        handleSnackInfo(snackInfo)
+                        const intervalId = setInterval(() => {
+                            count++;
+                            setTime((previousTime) => previousTime - 1)
+                            if (count === 5) {
+                                window.location.href = "/"
+                                clearInterval(intervalId)
+                            }
+                        }, 1000)
+                    },
+                    (error) => {
+                        setError(true)
+                        let count = 0;
+                        const snackInfo = {
+                            open: true,
+                            text: "Houve um erro durante a requisição de troca de senha",
+                            severity: "error",
+                        }
+                        handleSnackInfo(snackInfo)
+                        const intervalId = setInterval(() => {
+                            count++;
+                            setTime((previousTime) => previousTime - 1)
+                            if (count === 5) {
+                                window.location.href = "/"
+                                clearInterval(intervalId)
+                            }
+                        }, 1000)
+                    }
+                )
+            }
+        }
+    }
+
+    const handleSnackInfo = (info) => {
+        setSnackInfo({ ...info })
+    }
+
+    const handleCloseSnack = () => {
+        const snackInfo = {
+            open: false,
+            text: "",
+            severity: "",
+        }
+        handleSnackInfo(snackInfo)
+    }
+
+    const handleStateHideFormPass = () => {
+        setPassword({
+            ...formPassword,
+            hidePass: !formPassword.hidePass
+        })
+    }
+
+    const handleStateHideConfFormPass = () => {
+        setPasswordConfirmation({
+            ...formPasswordConfirmation,
+            hidePass: !formPasswordConfirmation.hidePass
+        })
+    }
+
+    if (error)
+        return (
+            <BackgroundDiv>
+                <Snackbar
+                    open={snackInfo.open}
+                    autoHideDuration={6000}
+                    onClose={handleCloseSnack}
+                    anchorOrigin={{ vertical: 'top', horizontal: 'right' }}
+                >
+                    <Alert onClose={handleCloseSnack} severity={snackInfo.severity}>
+                        {snackInfo.text}
+                    </Alert>
+                </Snackbar>
+                <div>
+                    <CustomizedBreadcrumbs
+                        values={["Recuperar senha", "Alterar senha"]}
+                    />
+                </div>
+                <div style={{ justifyContent: "center", textAlign: "center", maxWidth: "600px", margin: "auto" }}>
+                    <Paper elevation={3}>
+                        <CardDiv>
+                            <div style={{ overflow: "hidden", display: "inline-block" }}>
+                                <h2 style={{ fontSize: "32px", fontWeight: "200", marginBottom: "20px", lineHeight: '35px' }}>
+                                    Ocorreu um erro. Por favor, tente novamente mais tarde. Você será redirecionado para a home em... <StyledTimer>{time}</StyledTimer>
+                                </h2>
+                            </div>
+                        </CardDiv>
+                    </Paper>
+                </div>
+            </BackgroundDiv>
+        )
+    else if (success)
+        return (
+            <BackgroundDiv>
+                <Snackbar
+                    open={snackInfo.open}
+                    autoHideDuration={6000}
+                    onClose={handleCloseSnack}
+                    anchorOrigin={{ vertical: 'top', horizontal: 'right' }}
+                >
+                    <Alert onClose={handleCloseSnack} severity={snackInfo.severity}>
+                        {snackInfo.text}
+                    </Alert>
+                </Snackbar>
+                <div>
+                    <CustomizedBreadcrumbs
+                        values={["Recuperar senha", "Alterar senha"]}
+                    />
+                </div>
+                <div style={{ justifyContent: "center", textAlign: "center", maxWidth: "600px", margin: "auto" }}>
+                    <Paper elevation={3}>
+                        <CardDiv>
+                            <div style={{ overflow: "hidden", display: "inline-block" }}>
+                                <h2 style={{ fontSize: "32px", fontWeight: "200", marginBottom: "20px", lineHeight: '35px' }}>
+                                    Sua senha foi alterada com sucesso. Você será redirecionado para a home em... <StyledTimer>{time}</StyledTimer>
+                                </h2>
+                            </div>
+                        </CardDiv>
+                    </Paper>
+                </div>
+            </BackgroundDiv>
+        )
+    else
+        return (
+            <BackgroundDiv>
+                <Snackbar
+                    open={snackInfo.open}
+                    autoHideDuration={6000}
+                    onClose={handleCloseSnack}
+                    anchorOrigin={{ vertical: 'top', horizontal: 'right' }}
+                >
+                    <Alert onClose={handleCloseSnack} severity={snackInfo.severity}>
+                        {snackInfo.text}
+                    </Alert>
+                </Snackbar>
+                <div>
+                    <CustomizedBreadcrumbs
+                        values={["Recuperar senha", "Alterar senha"]}
+                    />
+                </div>
+                <div style={{ justifyContent: "center", textAlign: "center", maxWidth: "600px", margin: "auto" }}>
+                    <Paper elevation={3}>
+                        <CardDiv>
+                            <div style={{ overflow: "hidden", display: "inline-block" }}>
+                                <h2 style={{ fontSize: "32px", fontWeight: "200", marginBottom: "20px" }}>Confirme a nova senha</h2>
+                                <form onSubmit={(e) => { e.preventDefault(); onSubmit(e); }}>
+                                    <Grid container direction='row' alignItems='center' spacing={1}>
+                                        <Grid item xs={10}>
+                                            <FormInput
+                                                inputType={formPassword.hidePass ? "password" : ""}
+                                                name={"senha"}
+                                                value={formPassword.value}
+                                                placeholder={"Senha"}
+                                                handleChange={e => handleChange(e, 'password')}
+                                                required={true}
+                                                error={formPassword.key}
+                                                help={formPassword.key ? (formPassword.value.length === 0 ? "Faltou digitar sua senha." : "A senha precisa ter no mínimo 8 caracteres.") : ""}
+                                            />
+                                        </Grid>
+                                        <Grid item xs={2}>
+                                            {
+                                                formPassword.hidePass ?
+                                                    <IconButton onClick={handleStateHideFormPass}>
+                                                        <VisibilityIcon />
+                                                    </IconButton>
+                                                    :
+                                                    <IconButton onClick={handleStateHideFormPass}>
+                                                        <VisibilityOffIcon />
+                                                    </IconButton>
+                                            }
+                                        </Grid>
+                                    </Grid>
+                                    <br />
+                                    <Grid container direction='row' alignItems='center' spacing={1}>
+                                        <Grid item xs={10}>
+                                            <FormInput
+                                                inputType={formPasswordConfirmation.hidePass ? "password" : ""}
+                                                name={"confirme a senha"}
+                                                value={formPasswordConfirmation.value}
+                                                placeholder={"Confirme a senha"}
+                                                handleChange={e => handleChange(e, 'confirmation')}
+                                                required={true}
+                                                error={formPasswordConfirmation.key}
+                                                help={formPasswordConfirmation.key ? (formPasswordConfirmation.value.length === 0 ? "Faltou confirmar sua senha." : "A confirmação precisa ser igual a senha.") : ""}
+                                            />
+                                        </Grid>
+                                        <Grid item xs={2}>
+                                            {
+                                                formPasswordConfirmation.hidePass ?
+                                                    <IconButton onClick={handleStateHideConfFormPass}>
+                                                        <VisibilityIcon />
+                                                    </IconButton>
+                                                    :
+                                                    <IconButton onClick={handleStateHideConfFormPass}>
+                                                        <VisibilityOffIcon />
+                                                    </IconButton>
+                                            }
+                                        </Grid>
+                                    </Grid>
+                                    <div style={{ display: "flex", justifyContent: "center" }}>
+                                        <CompletarCadastroButton type="submit" >ATUALIZAR SENHA</CompletarCadastroButton>
+                                    </div>
+                                </form>
+                            </div>
+                        </CardDiv>
+                    </Paper>
+                </div>
+            </BackgroundDiv>
+        )
+}
+
+const CardDiv = styled.div`
+    background-color : #fff;
+    box-shadow : 0 1px 3px rgba(0,0,0,.12),0 1px 2px rgba(0,0,0,.24);
+    padding : 20px 30px;
+    margin : 50px 0;
+`
+const StyledTimer = styled.span`
+    color: #00bcd4;
+`
\ No newline at end of file
diff --git a/src/Pages/CollectionPage.js b/src/Pages/CollectionPage.js
index 0c60a9603ce4290798e5598267e0cd8f9bb16372..3b06dd99ecead429793638aaff5fcb691fc2672b 100644
--- a/src/Pages/CollectionPage.js
+++ b/src/Pages/CollectionPage.js
@@ -31,9 +31,11 @@ import FollowCollectionButton from '../Components/FollowCollectionButton';
 import { Store } from '../Store.js';
 import Button from '@material-ui/core/Button';
 import { getRequest } from '../Components/HelperFunctions/getAxiosConfig.js';
-import noAvatar from '../img/default_profile.png';
 import { apiDomain } from '../env.js';
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 export default function CollectionPage(props) {
 	const { state } = useContext(Store);
 
diff --git a/src/Pages/Contact.js b/src/Pages/Contact.js
index 181e16d47158efdbdd9492fc29fe49b7d2df80de..211c9d8012c011391e6f4083a47f4ce2484cf870 100644
--- a/src/Pages/Contact.js
+++ b/src/Pages/Contact.js
@@ -18,9 +18,11 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 
 import React, { useEffect } from "react";
 import styled from "styled-components";
-import Banner1 from "../img/banner-sobre.jpg";
 import InputFormulario from "../Components/ContactForm.js";
 
+//Image Import
+import { Banner1 } from "ImportImages.js";
+
 const Secao1 = styled.div`
   width: 100%;
   background-image: url(${Banner1});
diff --git a/src/Pages/HelpCenter.js b/src/Pages/HelpCenter.js
index 8b5ae50935da62fd6dc530bd1b82d50e6d4df6eb..162dec27a45c6ae619739f1d6e22105429032fd4 100644
--- a/src/Pages/HelpCenter.js
+++ b/src/Pages/HelpCenter.js
@@ -21,16 +21,13 @@ import styled from 'styled-components';
 import Grid from '@material-ui/core/Grid';
 import { Link } from 'react-router-dom';
 
-
-
-
-import Banner3 from '../img/ajuda/Banner3.png';
 import CardPublicando from '../Components/HelpCenter/Cards/CardPublicando';
 import CardEncontrando from '../Components/HelpCenter/Cards/CardEncontrando';
 import CardParticipando from '../Components/HelpCenter/Cards/CardParticipando';
 import CardGerenciando from '../Components/HelpCenter/Cards/CardGerenciando';
 
-
+//Image Import
+import { Banner3 } from "ImportImages.js";
 
 
 function HelpCenter(props) {
diff --git a/src/Pages/Home.js b/src/Pages/Home.js
deleted file mode 100755
index 9e1ed689888c44d5f3f7ad22d6896f239980ab8d..0000000000000000000000000000000000000000
--- a/src/Pages/Home.js
+++ /dev/null
@@ -1,52 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, { Component } from 'react';
-import './Styles/Home.css';
-import SearchSection from '../Components/SearchSection';
-import SubPages from '../Components/AreasSubPages';
-import StatsBar from '../Components/StatsBar';
-import Funcionalities from '../Components/Funcionalities';
-class App extends Component {
-    constructor(props) {
-        super(props);
-        this.state = {
-            bannerState: "Recursos"
-        };
-        this.changeBanner = this.changeBanner.bind(this)
-    }
-
-    changeBanner(parameter) {
-        this.setState({
-            bannerState: parameter
-        });
-    }
-
-    render() {
-        return (
-            <React.Fragment>
-                <SearchSection function={this.changeBanner} banner={this.state.bannerState} />
-                <SubPages banner={this.state.bannerState} />
-                <StatsBar />
-                <Funcionalities />
-            </React.Fragment>
-        );
-    }
-}
-
-export default App;
diff --git a/src/Pages/PasswordRecoveryPage.js b/src/Pages/PasswordRecoveryPage.js
index 010a164ba112a342e7e01e14fc2c5ba2bc38a1ff..4a6b25728b3353b725ab5ad31287d67b3baf7abc 100644
--- a/src/Pages/PasswordRecoveryPage.js
+++ b/src/Pages/PasswordRecoveryPage.js
@@ -42,13 +42,13 @@ export default function PasswordRecoveryPage (props) {
         handleChangeSwitch((data.success ? "success" : "error"))
     }
     const onSubmit = (e) => {
-        e.stopPropagation()
+        e.preventDefault()
 
         const url = `/auth/password`
 
         const payload = {
             "email" : formEmail.value,
-            "redirect_url" : "https://plataformaintegrada.mec.gov.br/recuperar-senha#/alterar-senha"
+            "redirect_url" : "http://localhost:4000/recuperar-senha/alterar-senha" // ### arrumar "https://plataformaintegrada.mec.gov.br/recuperar-senha/alterar-senha"
         }
 
         postRequest(url, payload, handleSuccessfulSubmit, (error) => {console.log(error)})
@@ -77,7 +77,7 @@ export default function PasswordRecoveryPage (props) {
     return (
         <>
             <BackgroundDiv>
-                <div style={{minWidth:"1170px"}}>
+                <div>
                     <CustomizedBreadcrumbs
                         values={["Recuperar senha"]}
                     />
diff --git a/src/Pages/PublicUserPage.js b/src/Pages/PublicUserPage.js
index e853439ae47ad7504232d15d320353098d2db249..6cdb3ccb2b825f648570bc718e4215416cf9abba 100644
--- a/src/Pages/PublicUserPage.js
+++ b/src/Pages/PublicUserPage.js
@@ -25,7 +25,6 @@ import Grid from '@material-ui/core/Grid';
 import FollowButton from '../Components/ContactButtons/FollowButton.js'
 import FollowingButton from '../Components/ContactButtons/FollowingButton.js'
 import FollowersCountButton from '../Components/ContactButtons/FollowersCountButton.js'
-import noAvatar from "../img/default_profile.png";
 import Tab from '@material-ui/core/Tab';
 import TabInicio from '../Components/TabPanels/PublicUserPageTabs/TabInicio.js'
 import TabRecursos from '../Components/TabPanels/PublicUserPageTabs/TabRecursos.js'
@@ -41,6 +40,9 @@ import LoadingSpinner from '../Components/LoadingSpinner';
 import Button from '@material-ui/core/Button'
 import { Link } from 'react-router-dom'
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 function RenderFollowContainer(props) {
   const { state } = useContext(Store)
   const [followed, setFollowed] = useState(props.followed)
diff --git a/src/Pages/ResourcePage.js b/src/Pages/ResourcePage.js
index 317663da5c5d3b4f4f2ac2bd9c321e7cdcc494c7..e4a6c80f472493170804393c3b07410b55345bf1 100644
--- a/src/Pages/ResourcePage.js
+++ b/src/Pages/ResourcePage.js
@@ -25,7 +25,6 @@ import TextoObjeto from "../Components/ResourcePageComponents/TextoObjeto.js";
 import Footer from "../Components/ResourcePageComponents/Footer.js";
 import Sobre from "../Components/ResourcePageComponents/Sobre.js";
 import CommentsArea from "../Components/ResourcePageComponents/CommentsArea.js";
-import noAvatar from "../img/default_profile.png";
 import Snackbar from "@material-ui/core/Snackbar";
 import Alert from "../Components/Alert.js";
 import VideoPlayer from "../Components/ResourcePageComponents/VideoPlayer.js";
@@ -39,6 +38,9 @@ import { getRequest } from "../Components/HelperFunctions/getAxiosConfig";
 import Button from '@material-ui/core/Button';
 import { Link } from 'react-router-dom';
 
+//Image Import
+import { noAvatar } from "ImportImages.js";
+
 function urlVerify(url) {
   return url
     ? url.indexOf("youtu") !== -1 || url.indexOf("vimeo") !== -1
@@ -175,7 +177,6 @@ export default function LearningObjectPage(props) {
             {snackbarText[snackbarIndex]}
           </Alert>
         </Snackbar>
-
         <ModalAvaliarRecurso
           open={modalCuradoriaOpen}
           handleClose={() => {
diff --git a/src/Pages/TabsHelp/TabManageAc.js b/src/Pages/TabsHelp/TabManageAc.js
index a8280274999063167a3fe55b5eb46891df5e7e37..6a2edde41fc01a942aae5f7b655a43ebd19ca420 100644
--- a/src/Pages/TabsHelp/TabManageAc.js
+++ b/src/Pages/TabsHelp/TabManageAc.js
@@ -22,7 +22,6 @@ import Tabs from "@material-ui/core/Tabs";
 import Tab from "@material-ui/core/Tab";
 import Breadcrumbs from "@material-ui/core/Breadcrumbs";
 import Grid from "@material-ui/core/Grid";
-import GerenciandoConta from "../../img/ajuda/Gerenciando_a_conta.png";
 import Why from "../../Components/HelpCenter/TabsManageAc/Why";
 import HowToDo from "../../Components/HelpCenter/TabsManageAc/HowToDo";
 import HowToChange from "../../Components/HelpCenter/TabsManageAc/HowToChange";
@@ -33,6 +32,9 @@ import CardEncontrando from "../../Components/HelpCenter/Cards/CardEncontrando";
 import CardPublicando from "../../Components/HelpCenter/Cards/CardPublicando";
 import { Link } from "react-router-dom";
 
+//Image Import
+import { GerenciandoConta } from "ImportImages.js";
+
 export default function TabManageAc(props) {
   const tabs = [
     "Por que me cadastrar?",
diff --git a/src/Pages/TabsHelp/TabNetPart.js b/src/Pages/TabsHelp/TabNetPart.js
index c08e3ea1197c5a44ea33931e49c13079df6e57f5..13c13d8c212b6057b92c2dc6181afb1853d68c7e 100644
--- a/src/Pages/TabsHelp/TabNetPart.js
+++ b/src/Pages/TabsHelp/TabNetPart.js
@@ -22,7 +22,6 @@ import Tabs from '@material-ui/core/Tabs'
 import Tab from '@material-ui/core/Tab';
 import Breadcrumbs from '@material-ui/core/Breadcrumbs';
 import Grid from '@material-ui/core/Grid';
-import ParticipandoRede from '../../img/ajuda/Participando_da_rede.png';
 import How from '../../Components/HelpCenter/TabsNetPart/How'
 import What from '../../Components/HelpCenter/TabsNetPart/What'
 import CardEncontrando from '../../Components/HelpCenter/Cards/CardEncontrando';
@@ -30,11 +29,8 @@ import CardPublicando from '../../Components/HelpCenter/Cards/CardPublicando';
 import CardGerenciando from '../../Components/HelpCenter/Cards/CardGerenciando';
 import { Link } from 'react-router-dom';
 
-
-
-
-
-
+//Image Import
+import { ParticipandoRede } from "ImportImages.js";
 
 export default function TabNetPart(props) {
   const tabs = [
diff --git a/src/Pages/TabsHelp/TabResourseFind.js b/src/Pages/TabsHelp/TabResourseFind.js
index 3ea892563437144c7f79a1c482c16f475e21bde8..51765ca0d2b43c6f211122df59a00c0d5d7743b7 100644
--- a/src/Pages/TabsHelp/TabResourseFind.js
+++ b/src/Pages/TabsHelp/TabResourseFind.js
@@ -22,7 +22,6 @@ import Tabs from '@material-ui/core/Tabs'
 import Tab from '@material-ui/core/Tab';
 import Breadcrumbs from '@material-ui/core/Breadcrumbs';
 import Grid from '@material-ui/core/Grid';
-import EncontrandoRecurso from '../../img/ajuda/Encontrando_recursos.png';
 import HowToDo from '../../Components/HelpCenter/TabsResourseFind/HowToDo'
 import HowToRank from '../../Components/HelpCenter/TabsResourseFind/HowToRank'
 import HowToFilter from '../../Components/HelpCenter/TabsResourseFind/HowToFilter';
@@ -31,11 +30,8 @@ import CardParticipando from '../../Components/HelpCenter/Cards/CardParticipando
 import CardGerenciando from '../../Components/HelpCenter/Cards/CardGerenciando';
 import { Link } from 'react-router-dom';
 
-
-
-
-
-
+//Image Import
+import { EncontrandoRecurso } from "ImportImages.js";
 
 export default function TabResourseFind(props) {
   const tabs = [
diff --git a/src/Pages/TabsHelp/TabResoursePub.js b/src/Pages/TabsHelp/TabResoursePub.js
index 514362aa97d6a8f88a9653fb5dff007ccd51fb59..7ff00fa47e3afb43b53e748e970db42b8f43eb31 100644
--- a/src/Pages/TabsHelp/TabResoursePub.js
+++ b/src/Pages/TabsHelp/TabResoursePub.js
@@ -22,7 +22,6 @@ import Tabs from '@material-ui/core/Tabs'
 import Tab from '@material-ui/core/Tab';
 import Breadcrumbs from '@material-ui/core/Breadcrumbs';
 import Grid from '@material-ui/core/Grid';
-import PublicandoRecursos from '../../img/ajuda/Publicando_recursos.png';
 import Why from '../../Components/HelpCenter/TabsResoursePub/Why'
 import How from '../../Components/HelpCenter/TabsResoursePub/How'
 import Which from '../../Components/HelpCenter/TabsResoursePub/Which'
@@ -31,6 +30,9 @@ import CardParticipando from '../../Components/HelpCenter/Cards/CardParticipando
 import CardGerenciando from '../../Components/HelpCenter/Cards/CardGerenciando';
 import { Link } from 'react-router-dom';
 
+//Image Import
+import { PublicandoRecursos } from "ImportImages.js";
+
 export default function TabResoursePub(props) {
 
   console.log(props)
diff --git a/src/Pages/Teste.js b/src/Pages/Teste.js
deleted file mode 100644
index 0652c42d9da86c1950f9dbdaae7f08fb4f40e772..0000000000000000000000000000000000000000
--- a/src/Pages/Teste.js
+++ /dev/null
@@ -1,135 +0,0 @@
-/*Copyright (C) 2019 Centro de Computacao Cientifica e Software Livre
-Departamento de Informatica - Universidade Federal do Parana
-
-This file is part of Plataforma Integrada MEC.
-
-Plataforma Integrada MEC is free software: you can redistribute it and/or modify
-it under the terms of the GNU Affero General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-Plataforma Integrada MEC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Affero General Public License for more details.
-
-You should have received a copy of the GNU Affero General Public License
-along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
-
-import React, { Component } from 'react'
-import Dropdown from 'react-dropdown'
-
-class ObjectArrayExample extends Component {
-  constructor (props) {
-    super(props)
-    this.state = {
-      selected: { value: 'two', label: 'Two'}
-    }
-    this._onSelect = this._onSelect.bind(this)
-  }
-
-  _onSelect (option) {
-    console.log('You selected ', option.label)
-    this.setState({selected: option})
-  }
-
-  render () {
-    const { toggleClassName, togglePlaholderClassName, toggleMenuClassName, toggleOptionsClassName } = this.state
-
-    const options = [
-      { value: 'one', label: 'One' },
-      { value: 'two', label: 'Two', className: toggleOptionsClassName && 'my-custom-class' },
-      {
-       type: 'group', name: 'group1', items: [
-         { value: 'three', label: 'Three', className: toggleOptionsClassName && 'my-custom-class' },
-         { value: 'four', label: 'Four' }
-       ]
-      },
-      {
-       type: 'group', name: 'group2', items: [
-         { value: 'five', label: 'Five' },
-         { value: 'six', label: 'Six' }
-       ]
-      }
-    ]
-
-
-    const defaultOption = this.state.selected
-    const placeHolderValue = typeof this.state.selected === 'string' ? this.state.selected : this.state.selected.label
-
-    return (
-      <section>
-        <h3>Object Array and Custom ClassNames Example </h3>
-        <div className="buttons">
-          <button onClick={() => this.setState({ toggleClassName: !toggleClassName })}>
-            Toggle dropdown custom class
-          </button>
-          <button onClick={() => this.setState({ togglePlaholderClassName: !togglePlaholderClassName })}>
-            Toggle placeholder custom class
-          </button>
-          <button onClick={() => this.setState({ toggleMenuClassName: !toggleMenuClassName })}>
-            Toggle menu custom class
-          </button>
-          <button onClick={() => this.setState({ toggleOptionsClassName: !toggleOptionsClassName })}>
-            Toggle options custom class
-          </button>
-        </div>
-        <Dropdown
-          options={options}
-          onChange={this._onSelect}
-          value={defaultOption}
-          placeholder="Select an option"
-          className={ toggleClassName ? 'my-custom-class' : '' }
-          placeholderClassName={ togglePlaholderClassName ? 'my-custom-class' : '' }
-          menuClassName={ toggleMenuClassName ? 'my-custom-class' : '' }
-        />
-        <div className='result'>
-          You selected
-          <strong> {placeHolderValue} </strong>
-        </div>
-        <section>
-          <h4>Options: </h4>
-          <div className='code'>
-            <pre>
-              {`
-const options = [
-  { value: 'one', label: 'One' },
-  { value: 'two', label: 'Two'${toggleOptionsClassName ? ', classNames \'my-custom-class\'' : ''} },
-  {
-    type: 'group', name: 'group1', items: [
-      { value: 'three', label: 'Three' },
-      { value: 'four', label: 'Four'${toggleOptionsClassName ? ', className: \'my-custom-class\'' : ''} }
-    ]
-  },
-  {
-    type: 'group', name: 'group2', items: [
-      { value: 'five', label: 'Five' },
-      { value: 'six', label: 'Six' }
-    ]
-  }
-]
-`}
-            </pre>
-          </div>
-          <h4>Usage with custom classeNames: </h4>
-          <div className='code'>
-            <pre>{
-`
-<Dropdown
-  options={options}
-  value={defaultOption}
-  placeholder="Select an option"
-  className=${ toggleClassName ? '"my-custom-class"' : '""' }
-  placeholderClassName=${ togglePlaholderClassName ? '"my-custom-class"' : '""' }
-  menuClassName=${ toggleMenuClassName ? '"my-custom-class"' : '""' }
-/>
-`}
-            </pre>
-          </div>
-        </section>
-      </section>
-    )
-  }
-}
-
-export default ObjectArrayExample
\ No newline at end of file
diff --git a/src/Pages/UserTerms.js b/src/Pages/UserTerms.js
index e6c2e7cb6e9cb8f8583fd3b1d5c34a93c17332ac..d1df2973e336727e0517ecf7ba95716783865732 100644
--- a/src/Pages/UserTerms.js
+++ b/src/Pages/UserTerms.js
@@ -22,19 +22,19 @@ import Modal from '../Components/Modal'
 import styled from 'styled-components'
 
 /*Importação de imagens para a página*/
-import Busca from "../img/termos/Busca.png"
-import Banner1 from "../img/termos/banner.jpg";
-import Aberto from "../img/termos/Aberto.png";
 import CadeadoAberto from "../img/termos/AbertoG.svg";
-import Fechado from "../img/termos/Fechado.png";
 import CadeadoFechado from "../img/termos/FechadoG.svg";
 import Linha from "../img/termos/linha.svg";
 
-
+//Image Import
+import { BuscaTermos } from "ImportImages.js";
+import { Banner } from "ImportImages.js";
+import { Aberto } from "ImportImages.js";
+import { Fechado } from "ImportImages.js";
 
 const BannerStyle = styled.div`
   width: 100%;
-  background-image: url(${Banner1});
+  background-image: url(${Banner});
   background-size: cover;
   background-position: top center;
   height: 370px;
@@ -54,7 +54,7 @@ const ImagemSeçao2 = styled.div`
   font-family: Roboto, sans-serif;
 
   @media (min-width:1450px) {
-    background-image: url(${Busca});
+    background-image: url(${BuscaTermos});
     background-position: right;
     background-size: contain;
     background-repeat: no-repeat;
diff --git a/src/env.js b/src/env.js
index 95815e96e0a4b6d934c32704a85f04284e77d16e..7284c42754e5c679138196c2bae2a2f128779c2b 100644
--- a/src/env.js
+++ b/src/env.js
@@ -17,7 +17,7 @@ You should have received a copy of the GNU Affero General Public License
 along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>.*/
 
 
-var apiDomain = 'https://api.portalmec.c3sl.ufpr.br',
+var apiDomain = 'https://api.portalmectest.c3sl.ufpr.br',
   apiVersion = 'v1',
   apiUrl = apiDomain + '/' + apiVersion;
 
diff --git a/src/img/Bolo.webp b/src/img/Bolo.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a5aea4a2f084793d827176af0d586b3411763d86
Binary files /dev/null and b/src/img/Bolo.webp differ
diff --git a/src/img/Excluir.webp b/src/img/Excluir.webp
new file mode 100644
index 0000000000000000000000000000000000000000..1c738db6ea620483708217b176582ff4af6aa4c9
Binary files /dev/null and b/src/img/Excluir.webp differ
diff --git a/src/img/Pagina_vazia_Sem_publicar.webp b/src/img/Pagina_vazia_Sem_publicar.webp
new file mode 100644
index 0000000000000000000000000000000000000000..7747896d00cb857b2abe73569269475be054158b
Binary files /dev/null and b/src/img/Pagina_vazia_Sem_publicar.webp differ
diff --git a/src/img/Pagina_vazia_colecao.webp b/src/img/Pagina_vazia_colecao.webp
new file mode 100644
index 0000000000000000000000000000000000000000..dbdd3dba3e6625c291ffd5398b8a369f3a88ddb6
Binary files /dev/null and b/src/img/Pagina_vazia_colecao.webp differ
diff --git a/src/img/Publicar.webp b/src/img/Publicar.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a431fcaccd2ad0bdb0b0c7cc2dc825a9d1548db0
Binary files /dev/null and b/src/img/Publicar.webp differ
diff --git a/src/img/acesso-a-informacao.webp b/src/img/acesso-a-informacao.webp
new file mode 100644
index 0000000000000000000000000000000000000000..8c9c2fbd761a2cbd4f99bceeb741885fa4ecc794
Binary files /dev/null and b/src/img/acesso-a-informacao.webp differ
diff --git a/src/img/ajuda/Banner3.webp b/src/img/ajuda/Banner3.webp
new file mode 100644
index 0000000000000000000000000000000000000000..d8ffbff2ffd5ae79df5fee247b3c96a1a51ffafb
Binary files /dev/null and b/src/img/ajuda/Banner3.webp differ
diff --git a/src/img/ajuda/Encontrando_recursos.webp b/src/img/ajuda/Encontrando_recursos.webp
new file mode 100644
index 0000000000000000000000000000000000000000..aa55755cdcde85ca188dc3fa1ad04e9be74874a4
Binary files /dev/null and b/src/img/ajuda/Encontrando_recursos.webp differ
diff --git a/src/img/ajuda/Gerenciando_a_conta.webp b/src/img/ajuda/Gerenciando_a_conta.webp
new file mode 100644
index 0000000000000000000000000000000000000000..17b80d403cfeae0a56f59376bf08d9aea7be9875
Binary files /dev/null and b/src/img/ajuda/Gerenciando_a_conta.webp differ
diff --git a/src/img/ajuda/Participando_da_rede.webp b/src/img/ajuda/Participando_da_rede.webp
new file mode 100644
index 0000000000000000000000000000000000000000..969b2b118771c3ece47696a424c775cfba7d9996
Binary files /dev/null and b/src/img/ajuda/Participando_da_rede.webp differ
diff --git a/src/img/ajuda/Publicando_recursos.webp b/src/img/ajuda/Publicando_recursos.webp
new file mode 100644
index 0000000000000000000000000000000000000000..687e284919b74159839fd767ed5a80715896c37c
Binary files /dev/null and b/src/img/ajuda/Publicando_recursos.webp differ
diff --git a/src/img/ajuda/busca_img.webp b/src/img/ajuda/busca_img.webp
new file mode 100644
index 0000000000000000000000000000000000000000..e53b24afbe78ccdf38bbe412f071bab7ea908e00
Binary files /dev/null and b/src/img/ajuda/busca_img.webp differ
diff --git a/src/img/ajuda/filtros_img.webp b/src/img/ajuda/filtros_img.webp
new file mode 100644
index 0000000000000000000000000000000000000000..79b21b72d06ecd2690b680b9c5d47d25da043e14
Binary files /dev/null and b/src/img/ajuda/filtros_img.webp differ
diff --git a/src/img/ajuda/login_img.webp b/src/img/ajuda/login_img.webp
new file mode 100644
index 0000000000000000000000000000000000000000..d6c31cae87070a89a74c3b53ddca2faece70d3ba
Binary files /dev/null and b/src/img/ajuda/login_img.webp differ
diff --git a/src/img/ajuda/recuperarsenha_img.webp b/src/img/ajuda/recuperarsenha_img.webp
new file mode 100644
index 0000000000000000000000000000000000000000..f30adeb9c29a1487bb2bdc86bf844881e2b0fdda
Binary files /dev/null and b/src/img/ajuda/recuperarsenha_img.webp differ
diff --git a/src/img/banner-mobile.webp b/src/img/banner-mobile.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a788c3ddc6aa3ed258e27b23f4f00189bf12b95a
Binary files /dev/null and b/src/img/banner-mobile.webp differ
diff --git a/src/img/banner-sobre.webp b/src/img/banner-sobre.webp
new file mode 100644
index 0000000000000000000000000000000000000000..656ea7e39940c16ff0bd11a9858afa8cdc2b1009
Binary files /dev/null and b/src/img/banner-sobre.webp differ
diff --git a/src/img/bannerBusca.webp b/src/img/bannerBusca.webp
new file mode 100644
index 0000000000000000000000000000000000000000..d3a31a303d328aece3570a0119c0ac56e021d490
Binary files /dev/null and b/src/img/bannerBusca.webp differ
diff --git a/src/img/carousel/Icone_Ativado_dot1.webp b/src/img/carousel/Icone_Ativado_dot1.webp
new file mode 100644
index 0000000000000000000000000000000000000000..e0324134ff0324bd04f4526112353b5c0786d8c7
Binary files /dev/null and b/src/img/carousel/Icone_Ativado_dot1.webp differ
diff --git a/src/img/carousel/Icone_Ativado_dot2.webp b/src/img/carousel/Icone_Ativado_dot2.webp
new file mode 100644
index 0000000000000000000000000000000000000000..dbff6c4e1dc1f41409ce97aaccfebb14c13454ec
Binary files /dev/null and b/src/img/carousel/Icone_Ativado_dot2.webp differ
diff --git a/src/img/carousel/Icone_Ativado_dot3.webp b/src/img/carousel/Icone_Ativado_dot3.webp
new file mode 100644
index 0000000000000000000000000000000000000000..5cdb73393fac8c1b276c8e50a726963968f0d51c
Binary files /dev/null and b/src/img/carousel/Icone_Ativado_dot3.webp differ
diff --git a/src/img/carousel/Icone_Ativado_dot4.webp b/src/img/carousel/Icone_Ativado_dot4.webp
new file mode 100644
index 0000000000000000000000000000000000000000..002df883d787a474b5eb3b8b28cf292096b613bb
Binary files /dev/null and b/src/img/carousel/Icone_Ativado_dot4.webp differ
diff --git a/src/img/carousel/Icone_Ativado_dot5.webp b/src/img/carousel/Icone_Ativado_dot5.webp
new file mode 100644
index 0000000000000000000000000000000000000000..3d091dbcae5c4be4aa75e7b41e94dd9215503206
Binary files /dev/null and b/src/img/carousel/Icone_Ativado_dot5.webp differ
diff --git a/src/img/carousel/Icone_Desativado_dot1.webp b/src/img/carousel/Icone_Desativado_dot1.webp
new file mode 100644
index 0000000000000000000000000000000000000000..e44fcb38d63d964323c8bcb87252ff5ea325453f
Binary files /dev/null and b/src/img/carousel/Icone_Desativado_dot1.webp differ
diff --git a/src/img/carousel/Icone_Desativado_dot2.webp b/src/img/carousel/Icone_Desativado_dot2.webp
new file mode 100644
index 0000000000000000000000000000000000000000..513ed4a398beb243dc4bec5fc0c7406f4fe4d5c3
Binary files /dev/null and b/src/img/carousel/Icone_Desativado_dot2.webp differ
diff --git a/src/img/carousel/Icone_Desativado_dot3.webp b/src/img/carousel/Icone_Desativado_dot3.webp
new file mode 100644
index 0000000000000000000000000000000000000000..4da4d7eb0ea45317969f0cbaa51d1867b0059408
Binary files /dev/null and b/src/img/carousel/Icone_Desativado_dot3.webp differ
diff --git a/src/img/carousel/Icone_Desativado_dot4.webp b/src/img/carousel/Icone_Desativado_dot4.webp
new file mode 100644
index 0000000000000000000000000000000000000000..c07515656393875bb17ad89b8c46a4943e08b3cd
Binary files /dev/null and b/src/img/carousel/Icone_Desativado_dot4.webp differ
diff --git a/src/img/carousel/Icone_Desativado_dot5.webp b/src/img/carousel/Icone_Desativado_dot5.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a0e7e432362699304eadab8e74083f008c9444c7
Binary files /dev/null and b/src/img/carousel/Icone_Desativado_dot5.webp differ
diff --git a/src/img/carousel/Icone_Grande (1).webp b/src/img/carousel/Icone_Grande (1).webp
new file mode 100644
index 0000000000000000000000000000000000000000..bc4b94340544b6476f86d35a19f7856aed0757a5
Binary files /dev/null and b/src/img/carousel/Icone_Grande (1).webp differ
diff --git a/src/img/carousel/Icone_Grande (2).webp b/src/img/carousel/Icone_Grande (2).webp
new file mode 100644
index 0000000000000000000000000000000000000000..4e0580e19cb88e3973b40f033410dad189f2664b
Binary files /dev/null and b/src/img/carousel/Icone_Grande (2).webp differ
diff --git a/src/img/carousel/Icone_Grande (3).webp b/src/img/carousel/Icone_Grande (3).webp
new file mode 100644
index 0000000000000000000000000000000000000000..3843b4fc5df8821d6f34db3e2a4e189870ce1b74
Binary files /dev/null and b/src/img/carousel/Icone_Grande (3).webp differ
diff --git a/src/img/carousel/Icone_Grande (4).webp b/src/img/carousel/Icone_Grande (4).webp
new file mode 100644
index 0000000000000000000000000000000000000000..8c42f3eaf998e4ed891b4236a1c010aad894ab4e
Binary files /dev/null and b/src/img/carousel/Icone_Grande (4).webp differ
diff --git a/src/img/carousel/Icone_Grande (5).webp b/src/img/carousel/Icone_Grande (5).webp
new file mode 100644
index 0000000000000000000000000000000000000000..bd52ab183ce3e03c29298c0b9f52861caebae6fd
Binary files /dev/null and b/src/img/carousel/Icone_Grande (5).webp differ
diff --git a/src/img/cc_license.webp b/src/img/cc_license.webp
new file mode 100644
index 0000000000000000000000000000000000000000..dc75387fdd028632d0d13639ccea2f2d127c0015
Binary files /dev/null and b/src/img/cc_license.webp differ
diff --git a/src/img/comentarios.webp b/src/img/comentarios.webp
new file mode 100644
index 0000000000000000000000000000000000000000..80219ca06c2d7ede33a9ab97b4164b876d3ff065
Binary files /dev/null and b/src/img/comentarios.webp differ
diff --git a/src/img/default_profile.webp b/src/img/default_profile.webp
new file mode 100644
index 0000000000000000000000000000000000000000..99a278352a34f62fb26b2b1153321348a45cfc52
Binary files /dev/null and b/src/img/default_profile.webp differ
diff --git a/src/img/default_profile0.webp b/src/img/default_profile0.webp
new file mode 100644
index 0000000000000000000000000000000000000000..99a278352a34f62fb26b2b1153321348a45cfc52
Binary files /dev/null and b/src/img/default_profile0.webp differ
diff --git a/src/img/ecd.webp b/src/img/ecd.webp
new file mode 100644
index 0000000000000000000000000000000000000000..de5f18aa18190972edb1b318101f9a7f5544dfc6
Binary files /dev/null and b/src/img/ecd.webp differ
diff --git a/src/img/educa-conectada.webp b/src/img/educa-conectada.webp
new file mode 100644
index 0000000000000000000000000000000000000000..27c73f1dcc52d8f1b771961bdd1aa19508d0d73a
Binary files /dev/null and b/src/img/educa-conectada.webp differ
diff --git a/src/img/girassol.webp b/src/img/girassol.webp
new file mode 100644
index 0000000000000000000000000000000000000000..e3efd63ef7ddefb88d16ab0220dc1e4e39521e38
Binary files /dev/null and b/src/img/girassol.webp differ
diff --git a/src/img/horstmann.jpg b/src/img/horstmann.jpg
deleted file mode 100644
index a4e7e494f1615ddd3e2a650a2fc7099c8e4b3c1a..0000000000000000000000000000000000000000
Binary files a/src/img/horstmann.jpg and /dev/null differ
diff --git a/src/img/horstmann.webp b/src/img/horstmann.webp
new file mode 100644
index 0000000000000000000000000000000000000000..37a4a636007aae1b244dd0623e3f5070f526e849
Binary files /dev/null and b/src/img/horstmann.webp differ
diff --git a/src/img/how_to_reg-24px.webp b/src/img/how_to_reg-24px.webp
new file mode 100644
index 0000000000000000000000000000000000000000..b6982fd8c350b58aaecedf6b4cca2be06cd0d44e
Binary files /dev/null and b/src/img/how_to_reg-24px.webp differ
diff --git a/src/img/ilustra_colecoes.webp b/src/img/ilustra_colecoes.webp
new file mode 100644
index 0000000000000000000000000000000000000000..c7f16ad05f7f007c977d7cf46759577675396412
Binary files /dev/null and b/src/img/ilustra_colecoes.webp differ
diff --git a/src/img/ilustra_materiais.webp b/src/img/ilustra_materiais.webp
new file mode 100644
index 0000000000000000000000000000000000000000..503a3de82e49e0ab194af2b8a9ad6dcfa8208647
Binary files /dev/null and b/src/img/ilustra_materiais.webp differ
diff --git a/src/img/ilustra_recursos_digitais.webp b/src/img/ilustra_recursos_digitais.webp
new file mode 100644
index 0000000000000000000000000000000000000000..82fac027e2a946a3a4be0340ffafb0383c48ca01
Binary files /dev/null and b/src/img/ilustra_recursos_digitais.webp differ
diff --git a/src/img/img-16.webp b/src/img/img-16.webp
new file mode 100644
index 0000000000000000000000000000000000000000..e6080bbbf47597c0d0a9f94171592a2fbe0c087d
Binary files /dev/null and b/src/img/img-16.webp differ
diff --git a/src/img/laranja/ANIMACAO_SIMULACAO.webp b/src/img/laranja/ANIMACAO_SIMULACAO.webp
new file mode 100644
index 0000000000000000000000000000000000000000..26239d84d24ff9a0761b859f44b2957c4a4840b2
Binary files /dev/null and b/src/img/laranja/ANIMACAO_SIMULACAO.webp differ
diff --git a/src/img/laranja/APP.webp b/src/img/laranja/APP.webp
new file mode 100644
index 0000000000000000000000000000000000000000..0a8d09d04a16c977f54182f288c1f399468b56f0
Binary files /dev/null and b/src/img/laranja/APP.webp differ
diff --git a/src/img/laranja/APRESENTACAO.webp b/src/img/laranja/APRESENTACAO.webp
new file mode 100644
index 0000000000000000000000000000000000000000..19750c1ec9bb453ec010b4ea35d39b3d32aa526f
Binary files /dev/null and b/src/img/laranja/APRESENTACAO.webp differ
diff --git a/src/img/laranja/AUDIO.webp b/src/img/laranja/AUDIO.webp
new file mode 100644
index 0000000000000000000000000000000000000000..9058290554a827f3ddafe7950bf88a8035baf992
Binary files /dev/null and b/src/img/laranja/AUDIO.webp differ
diff --git a/src/img/laranja/EMPTY.webp b/src/img/laranja/EMPTY.webp
new file mode 100644
index 0000000000000000000000000000000000000000..71755d933a832758e2d4bf7b3ec29d1f826b2bae
Binary files /dev/null and b/src/img/laranja/EMPTY.webp differ
diff --git a/src/img/laranja/IMAGEM.webp b/src/img/laranja/IMAGEM.webp
new file mode 100644
index 0000000000000000000000000000000000000000..b63d5f661089286050d096d0419ba6a7352b8692
Binary files /dev/null and b/src/img/laranja/IMAGEM.webp differ
diff --git a/src/img/laranja/INFOGRAFICO.webp b/src/img/laranja/INFOGRAFICO.webp
new file mode 100644
index 0000000000000000000000000000000000000000..62b80e7b126cbe702216caf5cf88bef511690a1a
Binary files /dev/null and b/src/img/laranja/INFOGRAFICO.webp differ
diff --git a/src/img/laranja/JOGO.webp b/src/img/laranja/JOGO.webp
new file mode 100644
index 0000000000000000000000000000000000000000..2556b8c6cef0afcb3f355f358669071a1eeb84a2
Binary files /dev/null and b/src/img/laranja/JOGO.webp differ
diff --git a/src/img/laranja/LIVRO_DIGITAL.webp b/src/img/laranja/LIVRO_DIGITAL.webp
new file mode 100644
index 0000000000000000000000000000000000000000..25949f617639223902432aad7fc1fdf0598d31c3
Binary files /dev/null and b/src/img/laranja/LIVRO_DIGITAL.webp differ
diff --git a/src/img/laranja/MAPA.webp b/src/img/laranja/MAPA.webp
new file mode 100644
index 0000000000000000000000000000000000000000..75621202baa06ce0e5e3d67396a60b50925fa326
Binary files /dev/null and b/src/img/laranja/MAPA.webp differ
diff --git a/src/img/laranja/OUTROS.webp b/src/img/laranja/OUTROS.webp
new file mode 100644
index 0000000000000000000000000000000000000000..b63349aa923946e1b42b9534ae016ad3c464c747
Binary files /dev/null and b/src/img/laranja/OUTROS.webp differ
diff --git a/src/img/laranja/SOFTWARE.webp b/src/img/laranja/SOFTWARE.webp
new file mode 100644
index 0000000000000000000000000000000000000000..3ced350324a3892393ebd8410fa4ff9c3d0815c6
Binary files /dev/null and b/src/img/laranja/SOFTWARE.webp differ
diff --git a/src/img/laranja/TEXTO.webp b/src/img/laranja/TEXTO.webp
new file mode 100644
index 0000000000000000000000000000000000000000..cdc64052855437ab4d0255dca390b5c35b3fb15a
Binary files /dev/null and b/src/img/laranja/TEXTO.webp differ
diff --git a/src/img/laranja/VIDEO.webp b/src/img/laranja/VIDEO.webp
new file mode 100644
index 0000000000000000000000000000000000000000..067b178c409626cd3041c48bacb23abacaadf365
Binary files /dev/null and b/src/img/laranja/VIDEO.webp differ
diff --git a/src/img/logo_parceiros/ENEF_AEF.webp b/src/img/logo_parceiros/ENEF_AEF.webp
new file mode 100644
index 0000000000000000000000000000000000000000..7d325054deed3958a0af09c47418e9e8cc44f98d
Binary files /dev/null and b/src/img/logo_parceiros/ENEF_AEF.webp differ
diff --git a/src/img/logo_parceiros/educagital.webp b/src/img/logo_parceiros/educagital.webp
new file mode 100644
index 0000000000000000000000000000000000000000..219adefb7e0177a706c94ecc1b94e6a039e3504b
Binary files /dev/null and b/src/img/logo_parceiros/educagital.webp differ
diff --git a/src/img/logo_parceiros/fundacao-lemann.webp b/src/img/logo_parceiros/fundacao-lemann.webp
new file mode 100644
index 0000000000000000000000000000000000000000..33e4944645969f65f89ade9fc923ffdd06095190
Binary files /dev/null and b/src/img/logo_parceiros/fundacao-lemann.webp differ
diff --git a/src/img/logo_parceiros/futura.webp b/src/img/logo_parceiros/futura.webp
new file mode 100644
index 0000000000000000000000000000000000000000..0062490591399694125a39d6e437f6f0cb3689f5
Binary files /dev/null and b/src/img/logo_parceiros/futura.webp differ
diff --git a/src/img/logo_parceiros/ic_bioe.webp b/src/img/logo_parceiros/ic_bioe.webp
new file mode 100644
index 0000000000000000000000000000000000000000..3ce4ef8d373cd0b55ac4080867db1b4eace58150
Binary files /dev/null and b/src/img/logo_parceiros/ic_bioe.webp differ
diff --git a/src/img/logo_parceiros/ic_default.webp b/src/img/logo_parceiros/ic_default.webp
new file mode 100644
index 0000000000000000000000000000000000000000..19d67c8f656b1bdfce8543fe40840977db1a4d2b
Binary files /dev/null and b/src/img/logo_parceiros/ic_default.webp differ
diff --git a/src/img/logo_parceiros/ic_diaadia.webp b/src/img/logo_parceiros/ic_diaadia.webp
new file mode 100644
index 0000000000000000000000000000000000000000..bd09a8d2af336b1c83674a5820ddecdfa16c828c
Binary files /dev/null and b/src/img/logo_parceiros/ic_diaadia.webp differ
diff --git a/src/img/logo_parceiros/ic_dominiopublico.webp b/src/img/logo_parceiros/ic_dominiopublico.webp
new file mode 100644
index 0000000000000000000000000000000000000000..0c60c8d858e0dc27e387c701dfadf6fdcdc9d511
Binary files /dev/null and b/src/img/logo_parceiros/ic_dominiopublico.webp differ
diff --git a/src/img/logo_parceiros/ic_escoladigital.webp b/src/img/logo_parceiros/ic_escoladigital.webp
new file mode 100644
index 0000000000000000000000000000000000000000..b6794947efc5fe4f7de4fe14ccbb5d5caf504f21
Binary files /dev/null and b/src/img/logo_parceiros/ic_escoladigital.webp differ
diff --git a/src/img/logo_parceiros/ic_nute.webp b/src/img/logo_parceiros/ic_nute.webp
new file mode 100644
index 0000000000000000000000000000000000000000..0f7161466178ae36ea18a9134ff4d0b218f09f59
Binary files /dev/null and b/src/img/logo_parceiros/ic_nute.webp differ
diff --git a/src/img/logo_parceiros/ic_peninsula.webp b/src/img/logo_parceiros/ic_peninsula.webp
new file mode 100644
index 0000000000000000000000000000000000000000..e8e360d02743ff08069c99aaf8885b36f28e4905
Binary files /dev/null and b/src/img/logo_parceiros/ic_peninsula.webp differ
diff --git a/src/img/logo_parceiros/ic_phet.webp b/src/img/logo_parceiros/ic_phet.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a0420a0f9f38c1b17678b776eea5a04a9ae3c1a2
Binary files /dev/null and b/src/img/logo_parceiros/ic_phet.webp differ
diff --git a/src/img/logo_parceiros/ic_portaldoprofessor.webp b/src/img/logo_parceiros/ic_portaldoprofessor.webp
new file mode 100644
index 0000000000000000000000000000000000000000..05564d8786b29765477c245c09c3150ac5fb7889
Binary files /dev/null and b/src/img/logo_parceiros/ic_portaldoprofessor.webp differ
diff --git a/src/img/logo_parceiros/ic_tvescola.webp b/src/img/logo_parceiros/ic_tvescola.webp
new file mode 100644
index 0000000000000000000000000000000000000000..11892bddefe11fb9bdcecf93a6dcda1d9dd4f6bd
Binary files /dev/null and b/src/img/logo_parceiros/ic_tvescola.webp differ
diff --git a/src/img/logo_parceiros/impa.webp b/src/img/logo_parceiros/impa.webp
new file mode 100644
index 0000000000000000000000000000000000000000..70093517ca9e6fd254eadf3f816a6b4d4c27cf59
Binary files /dev/null and b/src/img/logo_parceiros/impa.webp differ
diff --git a/src/img/logo_parceiros/impulsiona.webp b/src/img/logo_parceiros/impulsiona.webp
new file mode 100644
index 0000000000000000000000000000000000000000..41030127d56dd1df3ab37ba2d6fcc230a597f516
Binary files /dev/null and b/src/img/logo_parceiros/impulsiona.webp differ
diff --git a/src/img/logo_parceiros/inst-peninsula.webp b/src/img/logo_parceiros/inst-peninsula.webp
new file mode 100644
index 0000000000000000000000000000000000000000..4ad67d5f370a6bda6b9ca523a1f1c9be1f4c8af8
Binary files /dev/null and b/src/img/logo_parceiros/inst-peninsula.webp differ
diff --git a/src/img/logo_parceiros/instituto-crescer.webp b/src/img/logo_parceiros/instituto-crescer.webp
new file mode 100644
index 0000000000000000000000000000000000000000..ede05c7d21a378d52b7c73ba3b6cde70e76cb0c2
Binary files /dev/null and b/src/img/logo_parceiros/instituto-crescer.webp differ
diff --git a/src/img/logo_parceiros/logo_bioe.webp b/src/img/logo_parceiros/logo_bioe.webp
new file mode 100644
index 0000000000000000000000000000000000000000..98f94389369302f0a26d5f4b1072b65fc1917aa1
Binary files /dev/null and b/src/img/logo_parceiros/logo_bioe.webp differ
diff --git a/src/img/logo_parceiros/logo_dominiopublico.webp b/src/img/logo_parceiros/logo_dominiopublico.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a8ce68a535495f8fc547fe9e9beb32e8471f9ef0
Binary files /dev/null and b/src/img/logo_parceiros/logo_dominiopublico.webp differ
diff --git a/src/img/logo_parceiros/logo_escoladigital.webp b/src/img/logo_parceiros/logo_escoladigital.webp
new file mode 100644
index 0000000000000000000000000000000000000000..16ccfa914e7fff84d87ed6878b8811a625a12973
Binary files /dev/null and b/src/img/logo_parceiros/logo_escoladigital.webp differ
diff --git a/src/img/logo_parceiros/logo_portaldoprofessor.webp b/src/img/logo_parceiros/logo_portaldoprofessor.webp
new file mode 100644
index 0000000000000000000000000000000000000000..752cf4ef3f1139910112c2fcaa612262e8ce5dab
Binary files /dev/null and b/src/img/logo_parceiros/logo_portaldoprofessor.webp differ
diff --git a/src/img/logo_parceiros/logo_tvescola.webp b/src/img/logo_parceiros/logo_tvescola.webp
new file mode 100644
index 0000000000000000000000000000000000000000..9becdc26c89dca604bd2ff3e94269b2f8b6b01c5
Binary files /dev/null and b/src/img/logo_parceiros/logo_tvescola.webp differ
diff --git a/src/img/logo_parceiros/redeescola.webp b/src/img/logo_parceiros/redeescola.webp
new file mode 100644
index 0000000000000000000000000000000000000000..00a76fcce926bf3beb395a536f288f7a919aedd0
Binary files /dev/null and b/src/img/logo_parceiros/redeescola.webp differ
diff --git a/src/img/logo_parceiros/safer.webp b/src/img/logo_parceiros/safer.webp
new file mode 100644
index 0000000000000000000000000000000000000000..63cbf087345a86f7b8710db0c3d7feeb83770679
Binary files /dev/null and b/src/img/logo_parceiros/safer.webp differ
diff --git a/src/img/logo_parceiros/telefonica.webp b/src/img/logo_parceiros/telefonica.webp
new file mode 100644
index 0000000000000000000000000000000000000000..17bbcfbc7de601597f8ea2e2154d39c840ce9909
Binary files /dev/null and b/src/img/logo_parceiros/telefonica.webp differ
diff --git a/src/img/no-rede-1.webp b/src/img/no-rede-1.webp
new file mode 100644
index 0000000000000000000000000000000000000000..43a7c1c358ef2784f47a8b26087a0eace9eabd88
Binary files /dev/null and b/src/img/no-rede-1.webp differ
diff --git a/src/img/no-rede-2.webp b/src/img/no-rede-2.webp
new file mode 100644
index 0000000000000000000000000000000000000000..187c8cc3063a8d4fe200cbc640c8e5124ece676c
Binary files /dev/null and b/src/img/no-rede-2.webp differ
diff --git a/src/img/no-rede-3.webp b/src/img/no-rede-3.webp
new file mode 100644
index 0000000000000000000000000000000000000000..83c05981f7e3edbfcb8ed1d0d83fb89b219c0aa8
Binary files /dev/null and b/src/img/no-rede-3.webp differ
diff --git a/src/img/nopub-Acessar-materiais.webp b/src/img/nopub-Acessar-materiais.webp
new file mode 100644
index 0000000000000000000000000000000000000000..79153ef596e5890cfe018cc3b796143018f419df
Binary files /dev/null and b/src/img/nopub-Acessar-materiais.webp differ
diff --git a/src/img/nopub-Baixar.webp b/src/img/nopub-Baixar.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a64df25e9fbb44fda89f8d6508f90c7919a1536a
Binary files /dev/null and b/src/img/nopub-Baixar.webp differ
diff --git a/src/img/nopub-Compartilhar.webp b/src/img/nopub-Compartilhar.webp
new file mode 100644
index 0000000000000000000000000000000000000000..522ddc3f292481b97c25c85ccff8e3ad286a798f
Binary files /dev/null and b/src/img/nopub-Compartilhar.webp differ
diff --git a/src/img/nopub-Guardar.webp b/src/img/nopub-Guardar.webp
new file mode 100644
index 0000000000000000000000000000000000000000..c641325797f035eda044cd46315a0e84c5d9a097
Binary files /dev/null and b/src/img/nopub-Guardar.webp differ
diff --git a/src/img/nopub-Relatar.webp b/src/img/nopub-Relatar.webp
new file mode 100644
index 0000000000000000000000000000000000000000..67a1741a50f1c2bdf5d76814de20e0d2d432cf16
Binary files /dev/null and b/src/img/nopub-Relatar.webp differ
diff --git a/src/img/nopub-Seguir.webp b/src/img/nopub-Seguir.webp
new file mode 100644
index 0000000000000000000000000000000000000000..03baf281fa76f0e66895edb6d2698d82e6897eef
Binary files /dev/null and b/src/img/nopub-Seguir.webp differ
diff --git a/src/img/sobre/Alunos.webp b/src/img/sobre/Alunos.webp
new file mode 100644
index 0000000000000000000000000000000000000000..cbb388db723020492f7c06dc8884efeafab72608
Binary files /dev/null and b/src/img/sobre/Alunos.webp differ
diff --git a/src/img/sobre/Gestores.webp b/src/img/sobre/Gestores.webp
new file mode 100644
index 0000000000000000000000000000000000000000..a9bb6dc867f1807111f7a1b2451199d166116384
Binary files /dev/null and b/src/img/sobre/Gestores.webp differ
diff --git a/src/img/sobre/Imagem_Notebook.webp b/src/img/sobre/Imagem_Notebook.webp
new file mode 100644
index 0000000000000000000000000000000000000000..b01cb7d3ecec6c341f7d6e30a12902b071d2b10e
Binary files /dev/null and b/src/img/sobre/Imagem_Notebook.webp differ
diff --git a/src/img/sobre/banner-sobre-2.webp b/src/img/sobre/banner-sobre-2.webp
new file mode 100644
index 0000000000000000000000000000000000000000..225157a71f1e6a6ceb2091a4a191c77e98485460
Binary files /dev/null and b/src/img/sobre/banner-sobre-2.webp differ
diff --git a/src/img/sobre/comunidade.webp b/src/img/sobre/comunidade.webp
new file mode 100644
index 0000000000000000000000000000000000000000..d222cbee209e9942a3c03923cd29973deeeed510
Binary files /dev/null and b/src/img/sobre/comunidade.webp differ
diff --git a/src/img/sobre/professores.webp b/src/img/sobre/professores.webp
new file mode 100644
index 0000000000000000000000000000000000000000..0e16ac302dd1753c114868d44ef8ba6a04176338
Binary files /dev/null and b/src/img/sobre/professores.webp differ
diff --git a/src/img/termos/Aberto.webp b/src/img/termos/Aberto.webp
new file mode 100644
index 0000000000000000000000000000000000000000..fa837ca11d8295e960291725c87794ccf6ff9aef
Binary files /dev/null and b/src/img/termos/Aberto.webp differ
diff --git a/src/img/termos/Arrow_Direito do autor.webp b/src/img/termos/Arrow_Direito do autor.webp
new file mode 100644
index 0000000000000000000000000000000000000000..b32fe65a499f7abd823dec668ebe28f4398ed86a
Binary files /dev/null and b/src/img/termos/Arrow_Direito do autor.webp differ
diff --git "a/src/img/termos/Arrow_Direitos e Licen\303\247a1.webp" "b/src/img/termos/Arrow_Direitos e Licen\303\247a1.webp"
new file mode 100644
index 0000000000000000000000000000000000000000..870a21120b95fdf0486eaed6dc1e9633c1f71769
Binary files /dev/null and "b/src/img/termos/Arrow_Direitos e Licen\303\247a1.webp" differ
diff --git "a/src/img/termos/Arrow_Direitos e Licen\303\247a2.webp" "b/src/img/termos/Arrow_Direitos e Licen\303\247a2.webp"
new file mode 100644
index 0000000000000000000000000000000000000000..75b93ecfeb9268dbafc58fb01db5459831654f77
Binary files /dev/null and "b/src/img/termos/Arrow_Direitos e Licen\303\247a2.webp" differ
diff --git "a/src/img/termos/Arrow_O que \303\251 a plataforma-1.webp" "b/src/img/termos/Arrow_O que \303\251 a plataforma-1.webp"
new file mode 100644
index 0000000000000000000000000000000000000000..35c1df389408f6519555c3b40814f93bea5243de
Binary files /dev/null and "b/src/img/termos/Arrow_O que \303\251 a plataforma-1.webp" differ
diff --git "a/src/img/termos/Arrow_O que \303\251 a plataforma.webp" "b/src/img/termos/Arrow_O que \303\251 a plataforma.webp"
new file mode 100644
index 0000000000000000000000000000000000000000..08b747a5fe4f50a6c7d84f02753e79db6402094b
Binary files /dev/null and "b/src/img/termos/Arrow_O que \303\251 a plataforma.webp" differ
diff --git a/src/img/termos/Arrow_aberto e fechado-1.webp b/src/img/termos/Arrow_aberto e fechado-1.webp
new file mode 100644
index 0000000000000000000000000000000000000000..260aec6d9221e9ebe5ad49d74fd1244ce58bbefa
Binary files /dev/null and b/src/img/termos/Arrow_aberto e fechado-1.webp differ
diff --git a/src/img/termos/Arrow_aberto e fechado.webp b/src/img/termos/Arrow_aberto e fechado.webp
new file mode 100644
index 0000000000000000000000000000000000000000..6cbd4d30c811718c4888f5e74b9380394d94c53a
Binary files /dev/null and b/src/img/termos/Arrow_aberto e fechado.webp differ
diff --git a/src/img/termos/Busca.webp b/src/img/termos/Busca.webp
new file mode 100644
index 0000000000000000000000000000000000000000..f8992ab03f00befe16fbb4841a12d65fce6665d5
Binary files /dev/null and b/src/img/termos/Busca.webp differ
diff --git a/src/img/termos/Compromisso.webp b/src/img/termos/Compromisso.webp
new file mode 100644
index 0000000000000000000000000000000000000000..066a59ea85c9e10baa30c303fa75a3e6449fae49
Binary files /dev/null and b/src/img/termos/Compromisso.webp differ
diff --git a/src/img/termos/Fechado.webp b/src/img/termos/Fechado.webp
new file mode 100644
index 0000000000000000000000000000000000000000..47c03a266e5365503a44161886b7b43ef3d69faf
Binary files /dev/null and b/src/img/termos/Fechado.webp differ
diff --git a/src/img/termos/Mail.webp b/src/img/termos/Mail.webp
new file mode 100644
index 0000000000000000000000000000000000000000..12ed4a38011ee945f0589992227b6561938fab89
Binary files /dev/null and b/src/img/termos/Mail.webp differ
diff --git a/src/img/termos/Negativo.webp b/src/img/termos/Negativo.webp
new file mode 100644
index 0000000000000000000000000000000000000000..c88f76f3c17b0d1919e91e4dd15e03d90b0dc439
Binary files /dev/null and b/src/img/termos/Negativo.webp differ
diff --git a/src/img/termos/OrthogonalLineDown.webp b/src/img/termos/OrthogonalLineDown.webp
new file mode 100644
index 0000000000000000000000000000000000000000..75b93ecfeb9268dbafc58fb01db5459831654f77
Binary files /dev/null and b/src/img/termos/OrthogonalLineDown.webp differ
diff --git a/src/img/termos/OrthogonalLineUp.webp b/src/img/termos/OrthogonalLineUp.webp
new file mode 100644
index 0000000000000000000000000000000000000000..870a21120b95fdf0486eaed6dc1e9633c1f71769
Binary files /dev/null and b/src/img/termos/OrthogonalLineUp.webp differ
diff --git a/src/img/termos/Positivo.webp b/src/img/termos/Positivo.webp
new file mode 100644
index 0000000000000000000000000000000000000000..2243599fb3e350730862ea69f9d9851b39dbf32f
Binary files /dev/null and b/src/img/termos/Positivo.webp differ
diff --git a/src/img/termos/Senha.webp b/src/img/termos/Senha.webp
new file mode 100644
index 0000000000000000000000000000000000000000..00e0ff888f411a96b08d8c4395b70add03ac5fce
Binary files /dev/null and b/src/img/termos/Senha.webp differ
diff --git "a/src/img/termos/Usu\303\241rio.webp" "b/src/img/termos/Usu\303\241rio.webp"
new file mode 100644
index 0000000000000000000000000000000000000000..7337241558cbdca9a18eeb5d228754f4f851b529
Binary files /dev/null and "b/src/img/termos/Usu\303\241rio.webp" differ
diff --git a/src/img/termos/banner.webp b/src/img/termos/banner.webp
new file mode 100644
index 0000000000000000000000000000000000000000..63999a705e244ee6f30ada78c99b7da5b54c22c4
Binary files /dev/null and b/src/img/termos/banner.webp differ
diff --git a/src/serviceWorker.js b/src/serviceWorker.js
index dd8e8701cad06d9489400fc59033d165f78e3a75..f78c04d9d92678a56cc3c72987b5d75e626ffb4c 100755
--- a/src/serviceWorker.js
+++ b/src/serviceWorker.js
@@ -29,125 +29,126 @@ along with Plataforma Integrada MEC.  If not, see <http://www.gnu.org/licenses/>
 // opt-in, read http://bit.ly/CRA-PWA
 
 const isLocalhost = Boolean(
-  window.location.hostname === 'localhost' ||
-    // [::1] is the IPv6 localhost address.
-    window.location.hostname === '[::1]' ||
-    // 127.0.0.1/8 is considered localhost for IPv4.
-    window.location.hostname.match(
-      /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/
-    )
+    window.location.hostname === 'localhost' ||
+        // [::1] is the IPv6 localhost address.
+        window.location.hostname === '[::1]' ||
+        // 127.0.0.1/8 is 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);
+    if ('serviceWorker' in navigator) {
+        //process.env.NODE_ENV === 'production' && 
+        // 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;
+        }
 
-        // 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 http://bit.ly/CRA-PWA'
-          );
+        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 http://bit.ly/CRA-PWA'
+            );
+            });
+        } else {
+            // Is not localhost. Just register service worker
+            registerValidSW(swUrl, config);
+        }
         });
-      } 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 http://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);
-              }
+    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 http://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);
-    });
+        })
+        .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)
-    .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();
-          });
+    // Check if the service worker can be found. If it can't reload the page.
+    fetch(swUrl)
+        .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.'
+        );
         });
-      } 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();
-    });
-  }
+    if ('serviceWorker' in navigator) {
+        navigator.serviceWorker.ready.then(registration => {
+        registration.unregister();
+        });
+    }
 }
diff --git a/tsconfig.json b/tsconfig.json
deleted file mode 100644
index ce12e006e2adffd753e4462829f288ad87393ca0..0000000000000000000000000000000000000000
--- a/tsconfig.json
+++ /dev/null
@@ -1,26 +0,0 @@
-{
-  "compilerOptions": {
-    "target": "es5",
-    "lib": [
-      "dom",
-      "dom.iterable",
-      "esnext"
-    ],
-    "allowJs": true,
-    "skipLibCheck": true,
-    "esModuleInterop": true,
-    "allowSyntheticDefaultImports": true,
-    "experimentalDecorators" : true,
-    "strict": true,
-    "forceConsistentCasingInFileNames": true,
-    "module": "esnext",
-    "moduleResolution": "node",
-    "resolveJsonModule": true,
-    "isolatedModules": true,
-    "noEmit": true,
-    "jsx": "preserve"
-  },
-  "include": [
-    "src"
-  ]
-}