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 = 'data:image/webp;base64,UklGRh4AAABXRUJQVlA4TBEAAAAvAAAAAAfQ//73v/+BiOh/AAA='; + 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" - ] -}