From 4d5d1da95dc023f5a0d2a34073ed46817c8b58fb Mon Sep 17 00:00:00 2001 From: Alexander Menk Date: Sun, 21 May 2023 22:41:39 +0200 Subject: [PATCH 01/35] general: Update dependencies (next 13, react 18) (#152) --- next.config.js | 15 +- package.json | 11 +- .../HomepagePanel/HomepagePanel.tsx | 18 +- tsconfig.json | 3 +- yarn.lock | 4558 ++++++++--------- 5 files changed, 2030 insertions(+), 2575 deletions(-) diff --git a/next.config.js b/next.config.js index 876c85213..39d7463f8 100644 --- a/next.config.js +++ b/next.config.js @@ -1,12 +1,10 @@ /* eslint-disable */ const packageJson = require('./package.json'); -const withPWA = require('next-pwa'); +const withPWA = require('next-pwa')({ + dest: 'public', +}); module.exports = withPWA({ - pwa: { - dest: 'public', - }, - //TODO fails with current webpack config. Probably needs to get rid of sentry? (@sentry/nextjs was not cool) // future: { // webpack5: true, @@ -27,13 +25,8 @@ module.exports = withPWA({ }, }, webpack: (config, { dev, isServer }) => { - // Fixes npm packages that depend on `fs` module - config.node = { - fs: 'empty', - }; - if (!dev) { - config.devtool = 'source-maps'; + config.devtool = 'source-map'; for (const plugin of config.optimization.minimizer) { if (plugin.constructor.name === 'TerserPlugin') { plugin.options.sourceMap = true; diff --git a/package.json b/package.json index 7103c0650..16138edba 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,9 @@ { "name": "osmapp", "version": "1.3.0", + "engines": { + "node": "^18" + }, "scripts": { "dev": "next", "lint": "eslint . --report-unused-disable-directives", @@ -40,13 +43,13 @@ "jss": "^10.6.0", "lodash": "^4.17.21", "maplibre-gl": "^1.14.0", - "next": "^10.2.3", + "next": "^13.4.3", "next-cookies": "^2.0.3", "next-pwa": "^5.2.21", "osm-auth": "^1.1.1", - "react": "^17.0.2", + "react": "^18.2.0", "react-custom-scrollbars": "^4.2.1", - "react-dom": "^17.0.2", + "react-dom": "^18.2.0", "react-jss": "^10.6.0", "simple-opening-hours": "^0.1.1", "styled-components": "^5.3.0", @@ -67,6 +70,6 @@ "husky": "^4", "lint-staged": "^11.0.0", "prettier": "^2.3.0", - "typescript": "^4.3.2" + "typescript": "^5.0.4" } } diff --git a/src/components/HomepagePanel/HomepagePanel.tsx b/src/components/HomepagePanel/HomepagePanel.tsx index 503176133..3d7b0ebb0 100644 --- a/src/components/HomepagePanel/HomepagePanel.tsx +++ b/src/components/HomepagePanel/HomepagePanel.tsx @@ -156,16 +156,14 @@ export const HomepagePanel = () => {
- - - +
diff --git a/tsconfig.json b/tsconfig.json index f87cf1f73..8bd5c7f35 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -13,7 +13,8 @@ "moduleResolution": "node", "resolveJsonModule": true, "isolatedModules": true, - "jsx": "preserve" + "jsx": "preserve", + "incremental": true }, "include": [ "next-env.d.ts", diff --git a/yarn.lock b/yarn.lock index 4e1982cfc..46c728185 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2,6 +2,23 @@ # yarn lockfile v1 +"@ampproject/remapping@^2.2.0": + version "2.2.1" + resolved "https://registry.yarnpkg.com/@ampproject/remapping/-/remapping-2.2.1.tgz#99e8e11851128b8702cd57c33684f1d0f260b630" + integrity sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg== + dependencies: + "@jridgewell/gen-mapping" "^0.3.0" + "@jridgewell/trace-mapping" "^0.3.9" + +"@apideck/better-ajv-errors@^0.3.1": + version "0.3.6" + resolved "https://registry.yarnpkg.com/@apideck/better-ajv-errors/-/better-ajv-errors-0.3.6.tgz#957d4c28e886a64a8141f7522783be65733ff097" + integrity sha512-P+ZygBLZtkp0qqOAJJVX4oX/sFo5JR3eBWwwuqHHhK0GIgQOKWrAfiAaWX0aArHkRWHMuggFEgAZNxVPwPZYaA== + dependencies: + json-schema "^0.4.0" + jsonpointer "^5.0.0" + leven "^3.1.0" + "@babel/code-frame@7.12.11": version "7.12.11" resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.12.11.tgz#f4ad435aa263db935b8f10f2c552d23fb716a63f" @@ -9,24 +26,19 @@ dependencies: "@babel/highlight" "^7.10.4" -"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.12.13": +"@babel/code-frame@^7.0.0": version "7.12.13" resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.12.13.tgz#dcfc826beef65e75c50e21d3837d7d95798dd658" integrity sha512-HV1Cm0Q3ZrpCR93tkWOYiuYIgLxZXZFVG2VgK+MBWjUqZTundupbfx2aXarXuw5Ko5aMcjtJgbSs4vUGBS5v6g== dependencies: "@babel/highlight" "^7.12.13" -"@babel/code-frame@^7.10.4", "@babel/code-frame@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.14.5.tgz#23b08d740e83f49c5e59945fbf1b43e80bbf4edb" - integrity sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw== +"@babel/code-frame@^7.10.4", "@babel/code-frame@^7.12.13", "@babel/code-frame@^7.18.6", "@babel/code-frame@^7.21.4": + version "7.21.4" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.21.4.tgz#d0fa9e4413aca81f2b23b9442797bda1826edb39" + integrity sha512-LYvhNKfwWSPpocw8GI7gpK2nq3HSDuEPC/uSYaALSJu9xjsalaaYFOq0Pwt5KmVqwEbZlDu81aLXwBOmD/Fv9g== dependencies: - "@babel/highlight" "^7.14.5" - -"@babel/compat-data@^7.13.11", "@babel/compat-data@^7.14.5", "@babel/compat-data@^7.14.7": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.14.7.tgz#7b047d7a3a89a67d2258dc61f604f098f1bc7e08" - integrity sha512-nS6dZaISCXJ3+518CWiBfEr//gHyMO02uDxBkXTKZDN5POruCnOZ1N4YBRZDCabwF8nZMWBpRxIicmXtBs+fvw== + "@babel/highlight" "^7.18.6" "@babel/compat-data@^7.13.8": version "7.13.11" @@ -38,6 +50,11 @@ resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.14.4.tgz#45720fe0cecf3fd42019e1d12cc3d27fadc98d58" integrity sha512-i2wXrWQNkH6JplJQGn3Rd2I4Pij8GdHkXwHMxm+zV5YG/Jci+bCNrWZEWC4o+umiDkRrRs4dVzH3X4GP7vyjQQ== +"@babel/compat-data@^7.17.7", "@babel/compat-data@^7.20.5", "@babel/compat-data@^7.21.5": + version "7.21.7" + resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.21.7.tgz#61caffb60776e49a57ba61a88f02bedd8714f6bc" + integrity sha512-KYMqFYTaenzMK4yUtf4EW9wc4N9ef80FsbMtkwool5zpwl4YrT1SdWYSTRcT94KO4hannogdS+LxY7L+arP3gA== + "@babel/core@^7.1.0", "@babel/core@^7.7.5": version "7.13.10" resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.13.10.tgz#07de050bbd8193fcd8a3c27918c0890613a94559" @@ -61,25 +78,25 @@ source-map "^0.5.0" "@babel/core@^7.11.1": - version "7.14.6" - resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.14.6.tgz#e0814ec1a950032ff16c13a2721de39a8416fcab" - integrity sha512-gJnOEWSqTk96qG5BoIrl5bVtc23DCycmIePPYnamY9RboYdI4nFy5vAQMSl81O5K/W0sLDWfGysnOECC+KUUCA== - dependencies: - "@babel/code-frame" "^7.14.5" - "@babel/generator" "^7.14.5" - "@babel/helper-compilation-targets" "^7.14.5" - "@babel/helper-module-transforms" "^7.14.5" - "@babel/helpers" "^7.14.6" - "@babel/parser" "^7.14.6" - "@babel/template" "^7.14.5" - "@babel/traverse" "^7.14.5" - "@babel/types" "^7.14.5" + version "7.21.8" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.21.8.tgz#2a8c7f0f53d60100ba4c32470ba0281c92aa9aa4" + integrity sha512-YeM22Sondbo523Sz0+CirSPnbj9bG3P0CdHcBZdqUuaeOaYEFbOLoGU7lebvGP6P5J/WE9wOn7u7C4J9HvS1xQ== + dependencies: + "@ampproject/remapping" "^2.2.0" + "@babel/code-frame" "^7.21.4" + "@babel/generator" "^7.21.5" + "@babel/helper-compilation-targets" "^7.21.5" + "@babel/helper-module-transforms" "^7.21.5" + "@babel/helpers" "^7.21.5" + "@babel/parser" "^7.21.8" + "@babel/template" "^7.20.7" + "@babel/traverse" "^7.21.5" + "@babel/types" "^7.21.5" convert-source-map "^1.7.0" debug "^4.1.0" gensync "^1.0.0-beta.2" - json5 "^2.1.2" + json5 "^2.2.2" semver "^6.3.0" - source-map "^0.5.0" "@babel/core@^7.7.2": version "7.14.3" @@ -102,7 +119,17 @@ semver "^6.3.0" source-map "^0.5.0" -"@babel/generator@^7.13.0", "@babel/generator@^7.13.9": +"@babel/generator@^7.13.0", "@babel/generator@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.21.5.tgz#c0c0e5449504c7b7de8236d99338c3e2a340745f" + integrity sha512-SrKK/sRv8GesIW1bDagf9cCG38IOMYZusoe1dfg0D8aiUe3Amvoj1QtjTPAWcfrZFvIwlleLb0gxzQidL9w14w== + dependencies: + "@babel/types" "^7.21.5" + "@jridgewell/gen-mapping" "^0.3.2" + "@jridgewell/trace-mapping" "^0.3.17" + jsesc "^2.5.1" + +"@babel/generator@^7.13.9": version "7.13.9" resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.13.9.tgz#3a7aa96f9efb8e2be42d38d80e2ceb4c64d8de39" integrity sha512-mHOOmY0Axl/JCTkxTU6Lf5sWOg/v8nUa+Xkt4zMTftX0wqmb6Sh7J8gvcehBw7q0AhrhAR+FDacKjCZ2X8K+Sw== @@ -120,15 +147,6 @@ jsesc "^2.5.1" source-map "^0.5.0" -"@babel/generator@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.14.5.tgz#848d7b9f031caca9d0cd0af01b063f226f52d785" - integrity sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA== - dependencies: - "@babel/types" "^7.14.5" - jsesc "^2.5.1" - source-map "^0.5.0" - "@babel/helper-annotate-as-pure@^7.0.0": version "7.12.13" resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.12.13.tgz#0f58e86dfc4bb3b1fcd7db806570e177d439b6ab" @@ -136,30 +154,19 @@ dependencies: "@babel/types" "^7.12.13" -"@babel/helper-annotate-as-pure@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.14.5.tgz#7bf478ec3b71726d56a8ca5775b046fc29879e61" - integrity sha512-EivH9EgBIb+G8ij1B2jAwSH36WnGvkQSEC6CkX/6v6ZFlw5fVOHvsgGF4uiEHO2GzMvunZb6tDLQEQSdrdocrA== +"@babel/helper-annotate-as-pure@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz#eaa49f6f80d5a33f9a5dd2276e6d6e451be0a6bb" + integrity sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA== dependencies: - "@babel/types" "^7.14.5" + "@babel/types" "^7.18.6" -"@babel/helper-builder-binary-assignment-operator-visitor@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.14.5.tgz#b939b43f8c37765443a19ae74ad8b15978e0a191" - integrity sha512-YTA/Twn0vBXDVGJuAX6PwW7x5zQei1luDDo2Pl6q1qZ7hVNl0RZrhHCQG/ArGpR29Vl7ETiB8eJyrvpuRp300w== +"@babel/helper-builder-binary-assignment-operator-visitor@^7.18.6": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.21.5.tgz#817f73b6c59726ab39f6ba18c234268a519e5abb" + integrity sha512-uNrjKztPLkUk7bpCNC0jEKDJzzkvel/W+HguzbN8krA+LPfC1CEobJEvAvGka2A/M+ViOqXdcRL0GqPUJSjx9g== dependencies: - "@babel/helper-explode-assignable-expression" "^7.14.5" - "@babel/types" "^7.14.5" - -"@babel/helper-compilation-targets@^7.13.0", "@babel/helper-compilation-targets@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.14.5.tgz#7a99c5d0967911e972fe2c3411f7d5b498498ecf" - integrity sha512-v+QtZqXEiOnpO6EYvlImB6zCD2Lel06RzOPzmkz/D/XgQiUu3C/Jb1LOqSt/AIA34TYi/Q+KlT8vTQrgdxkbLw== - dependencies: - "@babel/compat-data" "^7.14.5" - "@babel/helper-validator-option" "^7.14.5" - browserslist "^4.16.6" - semver "^6.3.0" + "@babel/types" "^7.21.5" "@babel/helper-compilation-targets@^7.13.10": version "7.13.10" @@ -181,55 +188,65 @@ browserslist "^4.16.6" semver "^6.3.0" -"@babel/helper-create-class-features-plugin@^7.14.5": - version "7.14.6" - resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.14.6.tgz#f114469b6c06f8b5c59c6c4e74621f5085362542" - integrity sha512-Z6gsfGofTxH/+LQXqYEK45kxmcensbzmk/oi8DmaQytlQCgqNZt9XQF8iqlI/SeXWVjaMNxvYvzaYw+kh42mDg== +"@babel/helper-compilation-targets@^7.17.7", "@babel/helper-compilation-targets@^7.18.9", "@babel/helper-compilation-targets@^7.20.7", "@babel/helper-compilation-targets@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.21.5.tgz#631e6cc784c7b660417421349aac304c94115366" + integrity sha512-1RkbFGUKex4lvsB9yhIfWltJM5cZKUftB2eNajaDv3dCMEp49iBG0K14uH8NnX9IPux2+mK7JGEOB0jn48/J6w== dependencies: - "@babel/helper-annotate-as-pure" "^7.14.5" - "@babel/helper-function-name" "^7.14.5" - "@babel/helper-member-expression-to-functions" "^7.14.5" - "@babel/helper-optimise-call-expression" "^7.14.5" - "@babel/helper-replace-supers" "^7.14.5" - "@babel/helper-split-export-declaration" "^7.14.5" + "@babel/compat-data" "^7.21.5" + "@babel/helper-validator-option" "^7.21.0" + browserslist "^4.21.3" + lru-cache "^5.1.1" + semver "^6.3.0" -"@babel/helper-create-regexp-features-plugin@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.14.5.tgz#c7d5ac5e9cf621c26057722fb7a8a4c5889358c4" - integrity sha512-TLawwqpOErY2HhWbGJ2nZT5wSkR192QpN+nBg1THfBfftrlvOh+WbhrxXCH4q4xJ9Gl16BGPR/48JA+Ryiho/A== +"@babel/helper-create-class-features-plugin@^7.18.6", "@babel/helper-create-class-features-plugin@^7.21.0": + version "7.21.8" + resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.21.8.tgz#205b26330258625ef8869672ebca1e0dee5a0f02" + integrity sha512-+THiN8MqiH2AczyuZrnrKL6cAxFRRQDKW9h1YkBvbgKmAm6mwiacig1qT73DHIWMGo40GRnsEfN3LA+E6NtmSw== + dependencies: + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-environment-visitor" "^7.21.5" + "@babel/helper-function-name" "^7.21.0" + "@babel/helper-member-expression-to-functions" "^7.21.5" + "@babel/helper-optimise-call-expression" "^7.18.6" + "@babel/helper-replace-supers" "^7.21.5" + "@babel/helper-skip-transparent-expression-wrappers" "^7.20.0" + "@babel/helper-split-export-declaration" "^7.18.6" + semver "^6.3.0" + +"@babel/helper-create-regexp-features-plugin@^7.18.6", "@babel/helper-create-regexp-features-plugin@^7.20.5": + version "7.21.8" + resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.21.8.tgz#a7886f61c2e29e21fd4aaeaf1e473deba6b571dc" + integrity sha512-zGuSdedkFtsFHGbexAvNuipg1hbtitDLo2XE8/uf6Y9sOQV1xsYX/2pNbtedp/X0eU1pIt+kGvaqHCowkRbS5g== dependencies: - "@babel/helper-annotate-as-pure" "^7.14.5" - regexpu-core "^4.7.1" + "@babel/helper-annotate-as-pure" "^7.18.6" + regexpu-core "^5.3.1" + semver "^6.3.0" -"@babel/helper-define-polyfill-provider@^0.2.2": - version "0.2.3" - resolved "https://registry.yarnpkg.com/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.2.3.tgz#0525edec5094653a282688d34d846e4c75e9c0b6" - integrity sha512-RH3QDAfRMzj7+0Nqu5oqgO5q9mFtQEVvCRsi8qCEfzLR9p2BHfn5FzhSB2oj1fF7I2+DcTORkYaQ6aTR9Cofew== +"@babel/helper-define-polyfill-provider@^0.3.3": + version "0.3.3" + resolved "https://registry.yarnpkg.com/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz#8612e55be5d51f0cd1f36b4a5a83924e89884b7a" + integrity sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww== dependencies: - "@babel/helper-compilation-targets" "^7.13.0" - "@babel/helper-module-imports" "^7.12.13" - "@babel/helper-plugin-utils" "^7.13.0" - "@babel/traverse" "^7.13.0" + "@babel/helper-compilation-targets" "^7.17.7" + "@babel/helper-plugin-utils" "^7.16.7" debug "^4.1.1" lodash.debounce "^4.0.8" resolve "^1.14.2" semver "^6.1.2" -"@babel/helper-explode-assignable-expression@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.14.5.tgz#8aa72e708205c7bb643e45c73b4386cdf2a1f645" - integrity sha512-Htb24gnGJdIGT4vnRKMdoXiOIlqOLmdiUYpAQ0mYfgVT/GDm8GOYhgi4GL+hMKrkiPRohO4ts34ELFsGAPQLDQ== - dependencies: - "@babel/types" "^7.14.5" +"@babel/helper-environment-visitor@^7.18.9", "@babel/helper-environment-visitor@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.21.5.tgz#c769afefd41d171836f7cb63e295bedf689d48ba" + integrity sha512-IYl4gZ3ETsWocUWgsFZLM5i1BYx9SoemminVEXadgLBa9TdeorzgLKm8wWLA6J1N/kT3Kch8XIk1laNzYoHKvQ== -"@babel/helper-function-name@^7.12.13": - version "7.12.13" - resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.12.13.tgz#93ad656db3c3c2232559fd7b2c3dbdcbe0eb377a" - integrity sha512-TZvmPn0UOqmvi5G4vvw0qZTpVptGkB1GL61R6lKvrSdIxGm5Pky7Q3fpKiIkQCAtRCBUwB0PaThlx9vebCDSwA== +"@babel/helper-function-name@^7.12.13", "@babel/helper-function-name@^7.18.9", "@babel/helper-function-name@^7.19.0", "@babel/helper-function-name@^7.21.0": + version "7.21.0" + resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.21.0.tgz#d552829b10ea9f120969304023cd0645fa00b1b4" + integrity sha512-HfK1aMRanKHpxemaY2gqBmL04iAPOPRj7DxtNbiDOrJK+gdwkiNRVpCpUJYbUT+aZyemKN8brqTOxzCaG6ExRg== dependencies: - "@babel/helper-get-function-arity" "^7.12.13" - "@babel/template" "^7.12.13" - "@babel/types" "^7.12.13" + "@babel/template" "^7.20.7" + "@babel/types" "^7.21.0" "@babel/helper-function-name@^7.14.2": version "7.14.2" @@ -240,35 +257,19 @@ "@babel/template" "^7.12.13" "@babel/types" "^7.14.2" -"@babel/helper-function-name@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz#89e2c474972f15d8e233b52ee8c480e2cfcd50c4" - integrity sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ== - dependencies: - "@babel/helper-get-function-arity" "^7.14.5" - "@babel/template" "^7.14.5" - "@babel/types" "^7.14.5" - "@babel/helper-get-function-arity@^7.12.13": - version "7.12.13" - resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.12.13.tgz#bc63451d403a3b3082b97e1d8b3fe5bd4091e583" - integrity sha512-DjEVzQNz5LICkzN0REdpD5prGoidvbdYk1BVgRUOINaWJP2t6avB27X1guXK1kXNrX0WMfsrm1A/ZBthYuIMQg== + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.16.7.tgz#ea08ac753117a669f1508ba06ebcc49156387419" + integrity sha512-flc+RLSOBXzNzVhcLu6ujeHUrD6tANAOU5ojrRx/as+tbzf8+stUCj7+IfRRoAbEZqj/ahXEMsjhOhgeZsrnTw== dependencies: - "@babel/types" "^7.12.13" + "@babel/types" "^7.16.7" -"@babel/helper-get-function-arity@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz#25fbfa579b0937eee1f3b805ece4ce398c431815" - integrity sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg== +"@babel/helper-hoist-variables@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz#d4d2c8fb4baeaa5c68b99cc8245c56554f926678" + integrity sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q== dependencies: - "@babel/types" "^7.14.5" - -"@babel/helper-hoist-variables@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.14.5.tgz#e0dd27c33a78e577d7c8884916a3e7ef1f7c7f8d" - integrity sha512-R1PXiz31Uc0Vxy4OEOm07x0oSjKAdPPCh3tPivn/Eo8cvz6gveAeuyUUPB21Hoiif0uoPQSSdhIPS3352nvdyQ== - dependencies: - "@babel/types" "^7.14.5" + "@babel/types" "^7.18.6" "@babel/helper-member-expression-to-functions@^7.13.0": version "7.13.0" @@ -284,12 +285,12 @@ dependencies: "@babel/types" "^7.13.12" -"@babel/helper-member-expression-to-functions@^7.14.5": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.14.7.tgz#97e56244beb94211fe277bd818e3a329c66f7970" - integrity sha512-TMUt4xKxJn6ccjcOW7c4hlwyJArizskAhoSTOCkA0uZ+KghIaci0Qg9R043kUMWI9mtQfgny+NQ5QATnZ+paaA== +"@babel/helper-member-expression-to-functions@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.21.5.tgz#3b1a009af932e586af77c1030fba9ee0bde396c0" + integrity sha512-nIcGfgwpH2u4n9GG1HpStW5Ogx7x7ekiFHbjjFRKXbn5zUvqO9ZgotCO4x1aNbKn/x/xOUaXEhyNHCwtFCpxWg== dependencies: - "@babel/types" "^7.14.5" + "@babel/types" "^7.21.5" "@babel/helper-module-imports@7.12.5": version "7.12.5" @@ -298,19 +299,19 @@ dependencies: "@babel/types" "^7.12.5" -"@babel/helper-module-imports@^7.0.0", "@babel/helper-module-imports@^7.12.13": +"@babel/helper-module-imports@^7.0.0": version "7.12.13" resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.12.13.tgz#ec67e4404f41750463e455cc3203f6a32e93fcb0" integrity sha512-NGmfvRp9Rqxy0uHSSVP+SRIW1q31a7Ji10cLBcqSDUngGentY4FRiHOFZFE1CLU5eiL0oE8reH7Tg1y99TDM/g== dependencies: "@babel/types" "^7.12.13" -"@babel/helper-module-imports@^7.10.4", "@babel/helper-module-imports@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.14.5.tgz#6d1a44df6a38c957aa7c312da076429f11b422f3" - integrity sha512-SwrNHu5QWS84XlHwGYPDtCxcA0hrSlL2yhWYLgeOc0w7ccOl2qv4s/nARI0aYZW+bSwAL5CukeXA47B/1NKcnQ== +"@babel/helper-module-imports@^7.10.4", "@babel/helper-module-imports@^7.12.13", "@babel/helper-module-imports@^7.18.6", "@babel/helper-module-imports@^7.21.4": + version "7.21.4" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.21.4.tgz#ac88b2f76093637489e718a90cec6cf8a9b029af" + integrity sha512-orajc5T2PsRYUN3ZryCEFeMDYwyw09c/pZeaQEZPH0MpKzSvn3e0uXsDBu3k03VI+9DBiRo+l22BfKTpKwa/Wg== dependencies: - "@babel/types" "^7.14.5" + "@babel/types" "^7.21.4" "@babel/helper-module-imports@^7.13.12": version "7.13.12" @@ -348,19 +349,19 @@ "@babel/traverse" "^7.14.2" "@babel/types" "^7.14.2" -"@babel/helper-module-transforms@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.14.5.tgz#7de42f10d789b423eb902ebd24031ca77cb1e10e" - integrity sha512-iXpX4KW8LVODuAieD7MzhNjmM6dzYY5tfRqT+R9HDXWl0jPn/djKmA+G9s/2C2T9zggw5tK1QNqZ70USfedOwA== - dependencies: - "@babel/helper-module-imports" "^7.14.5" - "@babel/helper-replace-supers" "^7.14.5" - "@babel/helper-simple-access" "^7.14.5" - "@babel/helper-split-export-declaration" "^7.14.5" - "@babel/helper-validator-identifier" "^7.14.5" - "@babel/template" "^7.14.5" - "@babel/traverse" "^7.14.5" - "@babel/types" "^7.14.5" +"@babel/helper-module-transforms@^7.18.6", "@babel/helper-module-transforms@^7.20.11", "@babel/helper-module-transforms@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.21.5.tgz#d937c82e9af68d31ab49039136a222b17ac0b420" + integrity sha512-bI2Z9zBGY2q5yMHoBvJ2a9iX3ZOAzJPm7Q8Yz6YeoUjU/Cvhmi2G4QyTNyPBqqXSgTjUxRg3L0xV45HvkNWWBw== + dependencies: + "@babel/helper-environment-visitor" "^7.21.5" + "@babel/helper-module-imports" "^7.21.4" + "@babel/helper-simple-access" "^7.21.5" + "@babel/helper-split-export-declaration" "^7.18.6" + "@babel/helper-validator-identifier" "^7.19.1" + "@babel/template" "^7.20.7" + "@babel/traverse" "^7.21.5" + "@babel/types" "^7.21.5" "@babel/helper-optimise-call-expression@^7.12.13": version "7.12.13" @@ -369,31 +370,27 @@ dependencies: "@babel/types" "^7.12.13" -"@babel/helper-optimise-call-expression@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.14.5.tgz#f27395a8619e0665b3f0364cddb41c25d71b499c" - integrity sha512-IqiLIrODUOdnPU9/F8ib1Fx2ohlgDhxnIDU7OEVi+kAbEZcyiF7BLU8W6PfvPi9LzztjS7kcbzbmL7oG8kD6VA== +"@babel/helper-optimise-call-expression@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz#9369aa943ee7da47edab2cb4e838acf09d290ffe" + integrity sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA== dependencies: - "@babel/types" "^7.14.5" + "@babel/types" "^7.18.6" -"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.8.0": - version "7.13.0" - resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.13.0.tgz#806526ce125aed03373bc416a828321e3a6a33af" - integrity sha512-ZPafIPSwzUlAoWT8DKs1W2VyF2gOWthGd5NGFMsBcMMol+ZhK+EQY/e6V96poa6PA/Bh+C9plWN0hXO1uB8AfQ== +"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.16.7", "@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.18.9", "@babel/helper-plugin-utils@^7.19.0", "@babel/helper-plugin-utils@^7.20.2", "@babel/helper-plugin-utils@^7.21.5", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.21.5.tgz#345f2377d05a720a4e5ecfa39cbf4474a4daed56" + integrity sha512-0WDaIlXKOX/3KfBK/dwP1oQGiPh6rjMkT7HIRv7i5RR2VUMwrx5ZL0dwBkKx7+SW1zwNdgjHd34IMk5ZjTeHVg== -"@babel/helper-plugin-utils@^7.13.0", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.8.3": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.14.5.tgz#5ac822ce97eec46741ab70a517971e443a70c5a9" - integrity sha512-/37qQCE3K0vvZKwoK4XU/irIJQdIfCJuhU5eKnNxpFDsOkgFaUAwbv+RYw6eYgsC0E4hS7r5KqGULUogqui0fQ== - -"@babel/helper-remap-async-to-generator@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.14.5.tgz#51439c913612958f54a987a4ffc9ee587a2045d6" - integrity sha512-rLQKdQU+HYlxBwQIj8dk4/0ENOUEhA/Z0l4hN8BexpvmSMN9oA9EagjnhnDpNsRdWCfjwa4mn/HyBXO9yhQP6A== +"@babel/helper-remap-async-to-generator@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz#997458a0e3357080e54e1d79ec347f8a8cd28519" + integrity sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA== dependencies: - "@babel/helper-annotate-as-pure" "^7.14.5" - "@babel/helper-wrap-function" "^7.14.5" - "@babel/types" "^7.14.5" + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-wrap-function" "^7.18.9" + "@babel/types" "^7.18.9" "@babel/helper-replace-supers@^7.13.0": version "7.13.0" @@ -415,15 +412,17 @@ "@babel/traverse" "^7.14.2" "@babel/types" "^7.14.4" -"@babel/helper-replace-supers@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.14.5.tgz#0ecc0b03c41cd567b4024ea016134c28414abb94" - integrity sha512-3i1Qe9/8x/hCHINujn+iuHy+mMRLoc77b2nI9TB0zjH1hvn9qGlXjWlggdwUcju36PkPCy/lpM7LLUdcTyH4Ow== +"@babel/helper-replace-supers@^7.18.6", "@babel/helper-replace-supers@^7.20.7", "@babel/helper-replace-supers@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.21.5.tgz#a6ad005ba1c7d9bc2973dfde05a1bba7065dde3c" + integrity sha512-/y7vBgsr9Idu4M6MprbOVUfH3vs7tsIfnVWv/Ml2xgwvyH6LTngdfbf5AdsKwkJy4zgy1X/kuNrEKvhhK28Yrg== dependencies: - "@babel/helper-member-expression-to-functions" "^7.14.5" - "@babel/helper-optimise-call-expression" "^7.14.5" - "@babel/traverse" "^7.14.5" - "@babel/types" "^7.14.5" + "@babel/helper-environment-visitor" "^7.21.5" + "@babel/helper-member-expression-to-functions" "^7.21.5" + "@babel/helper-optimise-call-expression" "^7.18.6" + "@babel/template" "^7.20.7" + "@babel/traverse" "^7.21.5" + "@babel/types" "^7.21.5" "@babel/helper-simple-access@^7.12.13": version "7.12.13" @@ -439,68 +438,61 @@ dependencies: "@babel/types" "^7.13.12" -"@babel/helper-simple-access@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.14.5.tgz#66ea85cf53ba0b4e588ba77fc813f53abcaa41c4" - integrity sha512-nfBN9xvmCt6nrMZjfhkl7i0oTV3yxR4/FztsbOASyTvVcoYd0TRHh7eMLdlEcCqobydC0LAF3LtC92Iwxo0wyw== +"@babel/helper-simple-access@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.21.5.tgz#d697a7971a5c39eac32c7e63c0921c06c8a249ee" + integrity sha512-ENPDAMC1wAjR0uaCUwliBdiSl1KBJAVnMTzXqi64c2MG8MPR6ii4qf7bSXDqSFbr4W6W028/rf5ivoHop5/mkg== dependencies: - "@babel/types" "^7.14.5" + "@babel/types" "^7.21.5" -"@babel/helper-skip-transparent-expression-wrappers@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.14.5.tgz#96f486ac050ca9f44b009fbe5b7d394cab3a0ee4" - integrity sha512-dmqZB7mrb94PZSAOYtr+ZN5qt5owZIAgqtoTuqiFbHFtxgEcmQlRJVI+bO++fciBunXtB6MK7HrzrfcAzIz2NQ== +"@babel/helper-skip-transparent-expression-wrappers@^7.20.0": + version "7.20.0" + resolved "https://registry.yarnpkg.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz#fbe4c52f60518cab8140d77101f0e63a8a230684" + integrity sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg== dependencies: - "@babel/types" "^7.14.5" + "@babel/types" "^7.20.0" -"@babel/helper-split-export-declaration@^7.12.13": - version "7.12.13" - resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.12.13.tgz#e9430be00baf3e88b0e13e6f9d4eaf2136372b05" - integrity sha512-tCJDltF83htUtXx5NLcaDqRmknv652ZWCHyoTETf1CXYJdPC7nohZohjUgieXhv0hTJdRf2FjDueFehdNucpzg== +"@babel/helper-split-export-declaration@^7.12.13", "@babel/helper-split-export-declaration@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz#7367949bc75b20c6d5a5d4a97bba2824ae8ef075" + integrity sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA== dependencies: - "@babel/types" "^7.12.13" + "@babel/types" "^7.18.6" -"@babel/helper-split-export-declaration@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz#22b23a54ef51c2b7605d851930c1976dd0bc693a" - integrity sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA== - dependencies: - "@babel/types" "^7.14.5" +"@babel/helper-string-parser@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.21.5.tgz#2b3eea65443c6bdc31c22d037c65f6d323b6b2bd" + integrity sha512-5pTUx3hAJaZIdW99sJ6ZUUgWq/Y+Hja7TowEnLNMm1VivRgZQL3vpBY3qUACVsvw+yQU6+YgfBVmcbLaZtrA1w== -"@babel/helper-validator-identifier@^7.12.11": - version "7.12.11" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz#c9a1f021917dcb5ccf0d4e453e399022981fc9ed" - integrity sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw== +"@babel/helper-validator-identifier@^7.12.11", "@babel/helper-validator-identifier@^7.18.6", "@babel/helper-validator-identifier@^7.19.1": + version "7.19.1" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz#7eea834cf32901ffdc1a7ee555e2f9c27e249ca2" + integrity sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w== "@babel/helper-validator-identifier@^7.14.0": version "7.14.0" resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.0.tgz#d26cad8a47c65286b15df1547319a5d0bcf27288" integrity sha512-V3ts7zMSu5lfiwWDVWzRDGIN+lnCEUdaXgtVHJgLb1rGaA6jMrtB9EmE7L18foXJIE8Un/A/h6NJfGQp/e1J4A== -"@babel/helper-validator-identifier@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz#d0f0e277c512e0c938277faa85a3968c9a44c0e8" - integrity sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg== - "@babel/helper-validator-option@^7.12.17": version "7.12.17" resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.12.17.tgz#d1fbf012e1a79b7eebbfdc6d270baaf8d9eb9831" integrity sha512-TopkMDmLzq8ngChwRlyjR6raKD6gMSae4JdYDB8bByKreQgG0RBTuKe9LRxW3wFtUnjxOPRKBDwEH6Mg5KeDfw== -"@babel/helper-validator-option@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.14.5.tgz#6e72a1fff18d5dfcb878e1e62f1a021c4b72d5a3" - integrity sha512-OX8D5eeX4XwcroVW45NMvoYaIuFI+GQpA2a8Gi+X/U/cDUIRsV37qQfF905F0htTRCREQIB4KqPeaveRJUl3Ow== +"@babel/helper-validator-option@^7.21.0": + version "7.21.0" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.21.0.tgz#8224c7e13ace4bafdc4004da2cf064ef42673180" + integrity sha512-rmL/B8/f0mKS2baE9ZpyTcTavvEuWhTTW8amjzXNvYG4AwBsqTLikfXsEofsJEfKHf+HQVQbFOHy6o+4cnC/fQ== -"@babel/helper-wrap-function@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.14.5.tgz#5919d115bf0fe328b8a5d63bcb610f51601f2bff" - integrity sha512-YEdjTCq+LNuNS1WfxsDCNpgXkJaIyqco6DAelTUjT4f2KIWC1nBcaCaSdHTBqQVLnTBexBcVcFhLSU1KnYuePQ== +"@babel/helper-wrap-function@^7.18.9": + version "7.20.5" + resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.20.5.tgz#75e2d84d499a0ab3b31c33bcfe59d6b8a45f62e3" + integrity sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q== dependencies: - "@babel/helper-function-name" "^7.14.5" - "@babel/template" "^7.14.5" - "@babel/traverse" "^7.14.5" - "@babel/types" "^7.14.5" + "@babel/helper-function-name" "^7.19.0" + "@babel/template" "^7.18.10" + "@babel/traverse" "^7.20.5" + "@babel/types" "^7.20.5" "@babel/helpers@^7.13.10": version "7.13.10" @@ -520,184 +512,183 @@ "@babel/traverse" "^7.14.0" "@babel/types" "^7.14.0" -"@babel/helpers@^7.14.6": - version "7.14.6" - resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.14.6.tgz#5b58306b95f1b47e2a0199434fa8658fa6c21635" - integrity sha512-yesp1ENQBiLI+iYHSJdoZKUtRpfTlL1grDIX9NRlAVppljLw/4tTyYupIB7uIYmC3stW/imAv8EqaKaS/ibmeA== +"@babel/helpers@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.21.5.tgz#5bac66e084d7a4d2d9696bdf0175a93f7fb63c08" + integrity sha512-BSY+JSlHxOmGsPTydUkPf1MdMQ3M81x5xGCOVgWM3G8XH77sJ292Y2oqcp0CbbgxhqBuI46iUz1tT7hqP7EfgA== dependencies: - "@babel/template" "^7.14.5" - "@babel/traverse" "^7.14.5" - "@babel/types" "^7.14.5" + "@babel/template" "^7.20.7" + "@babel/traverse" "^7.21.5" + "@babel/types" "^7.21.5" -"@babel/highlight@^7.10.4", "@babel/highlight@^7.12.13": - version "7.13.10" - resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.13.10.tgz#a8b2a66148f5b27d666b15d81774347a731d52d1" - integrity sha512-5aPpe5XQPzflQrFwL1/QoeHkP2MsA4JCntcXHRhEsdsfPVkvPi2w7Qix4iV7t5S/oC9OodGrggd8aco1g3SZFg== - dependencies: - "@babel/helper-validator-identifier" "^7.12.11" - chalk "^2.0.0" - js-tokens "^4.0.0" - -"@babel/highlight@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.14.5.tgz#6861a52f03966405001f6aa534a01a24d99e8cd9" - integrity sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg== +"@babel/highlight@^7.10.4", "@babel/highlight@^7.12.13", "@babel/highlight@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.18.6.tgz#81158601e93e2563795adcbfbdf5d64be3f2ecdf" + integrity sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g== dependencies: - "@babel/helper-validator-identifier" "^7.14.5" + "@babel/helper-validator-identifier" "^7.18.6" chalk "^2.0.0" js-tokens "^4.0.0" -"@babel/parser@^7.1.0", "@babel/parser@^7.12.13", "@babel/parser@^7.13.0", "@babel/parser@^7.13.10", "@babel/parser@^7.7.0": +"@babel/parser@^7.1.0", "@babel/parser@^7.13.10", "@babel/parser@^7.7.0": version "7.13.11" resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.13.11.tgz#f93ebfc99d21c1772afbbaa153f47e7ce2f50b88" integrity sha512-PhuoqeHoO9fc4ffMEVk4qb/w/s2iOSWohvbHxLtxui0eBg3Lg5gN1U8wp1V1u61hOWkPQJJyJzGH6Y+grwkq8Q== +"@babel/parser@^7.12.13", "@babel/parser@^7.13.0", "@babel/parser@^7.20.7", "@babel/parser@^7.21.5", "@babel/parser@^7.21.8": + version "7.21.8" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.21.8.tgz#642af7d0333eab9c0ad70b14ac5e76dbde7bfdf8" + integrity sha512-6zavDGdzG3gUqAdWvlLFfk+36RilI+Pwyuuh7HItyeScCWP3k6i8vKclAQ0bM/0y/Kz/xiwvxhMv9MgTJP5gmA== + "@babel/parser@^7.14.2", "@babel/parser@^7.14.3", "@babel/parser@^7.7.2": version "7.14.4" resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.14.4.tgz#a5c560d6db6cd8e6ed342368dea8039232cbab18" integrity sha512-ArliyUsWDUqEGfWcmzpGUzNfLxTdTp6WU4IuP6QFSp9gGfWS6boxFCkJSJ/L4+RG8z/FnIU3WxCk6hPL9SSWeA== -"@babel/parser@^7.14.5", "@babel/parser@^7.14.6", "@babel/parser@^7.14.7": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.14.7.tgz#6099720c8839ca865a2637e6c85852ead0bdb595" - integrity sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA== +"@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz#da5b8f9a580acdfbe53494dba45ea389fb09a4d2" + integrity sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.14.5.tgz#4b467302e1548ed3b1be43beae2cc9cf45e0bb7e" - integrity sha512-ZoJS2XCKPBfTmL122iP6NM9dOg+d4lc9fFk3zxc8iDjvt8Pk4+TlsHSKhIPf6X+L5ORCdBzqMZDjL/WHj7WknQ== +"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.20.7": + version "7.20.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.20.7.tgz#d9c85589258539a22a901033853101a6198d4ef1" + integrity sha512-sbr9+wNE5aXMBBFBICk01tt7sBf2Oc9ikRFEcem/ZORup9IMUdNhW7/wVLEbbtlWOsEubJet46mHAL2C8+2jKQ== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-skip-transparent-expression-wrappers" "^7.14.5" - "@babel/plugin-proposal-optional-chaining" "^7.14.5" + "@babel/helper-plugin-utils" "^7.20.2" + "@babel/helper-skip-transparent-expression-wrappers" "^7.20.0" + "@babel/plugin-proposal-optional-chaining" "^7.20.7" -"@babel/plugin-proposal-async-generator-functions@^7.14.7": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.14.7.tgz#784a48c3d8ed073f65adcf30b57bcbf6c8119ace" - integrity sha512-RK8Wj7lXLY3bqei69/cc25gwS5puEc3dknoFPFbqfy3XxYQBQFvu4ioWpafMBAB+L9NyptQK4nMOa5Xz16og8Q== +"@babel/plugin-proposal-async-generator-functions@^7.20.7": + version "7.20.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.20.7.tgz#bfb7276d2d573cb67ba379984a2334e262ba5326" + integrity sha512-xMbiLsn/8RK7Wq7VeVytytS2L6qE69bXPB10YCmMdDZbKF4okCqY74pI/jJQ/8U0b/F6NrT2+14b8/P9/3AMGA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-remap-async-to-generator" "^7.14.5" + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-plugin-utils" "^7.20.2" + "@babel/helper-remap-async-to-generator" "^7.18.9" "@babel/plugin-syntax-async-generators" "^7.8.4" -"@babel/plugin-proposal-class-properties@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.14.5.tgz#40d1ee140c5b1e31a350f4f5eed945096559b42e" - integrity sha512-q/PLpv5Ko4dVc1LYMpCY7RVAAO4uk55qPwrIuJ5QJ8c6cVuAmhu7I/49JOppXL6gXf7ZHzpRVEUZdYoPLM04Gg== +"@babel/plugin-proposal-class-properties@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz#b110f59741895f7ec21a6fff696ec46265c446a3" + integrity sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ== dependencies: - "@babel/helper-create-class-features-plugin" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-create-class-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-proposal-class-static-block@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.14.5.tgz#158e9e10d449c3849ef3ecde94a03d9f1841b681" - integrity sha512-KBAH5ksEnYHCegqseI5N9skTdxgJdmDoAOc0uXa+4QMYKeZD0w5IARh4FMlTNtaHhbB8v+KzMdTgxMMzsIy6Yg== +"@babel/plugin-proposal-class-static-block@^7.21.0": + version "7.21.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.21.0.tgz#77bdd66fb7b605f3a61302d224bdfacf5547977d" + integrity sha512-XP5G9MWNUskFuP30IfFSEFB0Z6HzLIUcjYM4bYOPHXl7eiJ9HFv8tWj6TXTN5QODiEhDZAeI4hLok2iHFFV4hw== dependencies: - "@babel/helper-create-class-features-plugin" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-create-class-features-plugin" "^7.21.0" + "@babel/helper-plugin-utils" "^7.20.2" "@babel/plugin-syntax-class-static-block" "^7.14.5" -"@babel/plugin-proposal-dynamic-import@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.14.5.tgz#0c6617df461c0c1f8fff3b47cd59772360101d2c" - integrity sha512-ExjiNYc3HDN5PXJx+bwC50GIx/KKanX2HiggnIUAYedbARdImiCU4RhhHfdf0Kd7JNXGpsBBBCOm+bBVy3Gb0g== +"@babel/plugin-proposal-dynamic-import@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz#72bcf8d408799f547d759298c3c27c7e7faa4d94" + integrity sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-dynamic-import" "^7.8.3" -"@babel/plugin-proposal-export-namespace-from@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.14.5.tgz#dbad244310ce6ccd083072167d8cea83a52faf76" - integrity sha512-g5POA32bXPMmSBu5Dx/iZGLGnKmKPc5AiY7qfZgurzrCYgIztDlHFbznSNCoQuv57YQLnQfaDi7dxCtLDIdXdA== +"@babel/plugin-proposal-export-namespace-from@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz#5f7313ab348cdb19d590145f9247540e94761203" + integrity sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-syntax-export-namespace-from" "^7.8.3" -"@babel/plugin-proposal-json-strings@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.14.5.tgz#38de60db362e83a3d8c944ac858ddf9f0c2239eb" - integrity sha512-NSq2fczJYKVRIsUJyNxrVUMhB27zb7N7pOFGQOhBKJrChbGcgEAqyZrmZswkPk18VMurEeJAaICbfm57vUeTbQ== +"@babel/plugin-proposal-json-strings@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz#7e8788c1811c393aff762817e7dbf1ebd0c05f0b" + integrity sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-json-strings" "^7.8.3" -"@babel/plugin-proposal-logical-assignment-operators@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.14.5.tgz#6e6229c2a99b02ab2915f82571e0cc646a40c738" - integrity sha512-YGn2AvZAo9TwyhlLvCCWxD90Xq8xJ4aSgaX3G5D/8DW94L8aaT+dS5cSP+Z06+rCJERGSr9GxMBZ601xoc2taw== +"@babel/plugin-proposal-logical-assignment-operators@^7.20.7": + version "7.20.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.20.7.tgz#dfbcaa8f7b4d37b51e8bfb46d94a5aea2bb89d83" + integrity sha512-y7C7cZgpMIjWlKE5T7eJwp+tnRYM89HmRvWM5EQuB5BoHEONjmQ8lSNmBUwOyy/GFRsohJED51YBF79hE1djug== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.20.2" "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" -"@babel/plugin-proposal-nullish-coalescing-operator@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.14.5.tgz#ee38589ce00e2cc59b299ec3ea406fcd3a0fdaf6" - integrity sha512-gun/SOnMqjSb98Nkaq2rTKMwervfdAoz6NphdY0vTfuzMfryj+tDGb2n6UkDKwez+Y8PZDhE3D143v6Gepp4Hg== +"@babel/plugin-proposal-nullish-coalescing-operator@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz#fdd940a99a740e577d6c753ab6fbb43fdb9467e1" + integrity sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" -"@babel/plugin-proposal-numeric-separator@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.14.5.tgz#83631bf33d9a51df184c2102a069ac0c58c05f18" - integrity sha512-yiclALKe0vyZRZE0pS6RXgjUOt87GWv6FYa5zqj15PvhOGFO69R5DusPlgK/1K5dVnCtegTiWu9UaBSrLLJJBg== +"@babel/plugin-proposal-numeric-separator@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz#899b14fbafe87f053d2c5ff05b36029c62e13c75" + integrity sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-numeric-separator" "^7.10.4" -"@babel/plugin-proposal-object-rest-spread@^7.14.7": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.14.7.tgz#5920a2b3df7f7901df0205974c0641b13fd9d363" - integrity sha512-082hsZz+sVabfmDWo1Oct1u1AgbKbUAyVgmX4otIc7bdsRgHBXwTwb3DpDmD4Eyyx6DNiuz5UAATT655k+kL5g== +"@babel/plugin-proposal-object-rest-spread@^7.20.7": + version "7.20.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.20.7.tgz#aa662940ef425779c75534a5c41e9d936edc390a" + integrity sha512-d2S98yCiLxDVmBmE8UjGcfPvNEUbA1U5q5WxaWFUGRzJSVAZqm5W6MbPct0jxnegUZ0niLeNX+IOzEs7wYg9Dg== dependencies: - "@babel/compat-data" "^7.14.7" - "@babel/helper-compilation-targets" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/compat-data" "^7.20.5" + "@babel/helper-compilation-targets" "^7.20.7" + "@babel/helper-plugin-utils" "^7.20.2" "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-transform-parameters" "^7.14.5" + "@babel/plugin-transform-parameters" "^7.20.7" -"@babel/plugin-proposal-optional-catch-binding@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.14.5.tgz#939dd6eddeff3a67fdf7b3f044b5347262598c3c" - integrity sha512-3Oyiixm0ur7bzO5ybNcZFlmVsygSIQgdOa7cTfOYCMY+wEPAYhZAJxi3mixKFCTCKUhQXuCTtQ1MzrpL3WT8ZQ== +"@babel/plugin-proposal-optional-catch-binding@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz#f9400d0e6a3ea93ba9ef70b09e72dd6da638a2cb" + integrity sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" -"@babel/plugin-proposal-optional-chaining@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.14.5.tgz#fa83651e60a360e3f13797eef00b8d519695b603" - integrity sha512-ycz+VOzo2UbWNI1rQXxIuMOzrDdHGrI23fRiz/Si2R4kv2XZQ1BK8ccdHwehMKBlcH/joGW/tzrUmo67gbJHlQ== +"@babel/plugin-proposal-optional-chaining@^7.20.7", "@babel/plugin-proposal-optional-chaining@^7.21.0": + version "7.21.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.21.0.tgz#886f5c8978deb7d30f678b2e24346b287234d3ea" + integrity sha512-p4zeefM72gpmEe2fkUr/OnOXpWEf8nAgk7ZYVqqfFiyIG7oFfVZcCrU64hWn5xp4tQ9LkV4bTIa5rD0KANpKNA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-skip-transparent-expression-wrappers" "^7.14.5" + "@babel/helper-plugin-utils" "^7.20.2" + "@babel/helper-skip-transparent-expression-wrappers" "^7.20.0" "@babel/plugin-syntax-optional-chaining" "^7.8.3" -"@babel/plugin-proposal-private-methods@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.14.5.tgz#37446495996b2945f30f5be5b60d5e2aa4f5792d" - integrity sha512-838DkdUA1u+QTCplatfq4B7+1lnDa/+QMI89x5WZHBcnNv+47N8QEj2k9I2MUU9xIv8XJ4XvPCviM/Dj7Uwt9g== +"@babel/plugin-proposal-private-methods@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz#5209de7d213457548a98436fa2882f52f4be6bea" + integrity sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA== dependencies: - "@babel/helper-create-class-features-plugin" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-create-class-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-proposal-private-property-in-object@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.14.5.tgz#9f65a4d0493a940b4c01f8aa9d3f1894a587f636" - integrity sha512-62EyfyA3WA0mZiF2e2IV9mc9Ghwxcg8YTu8BS4Wss4Y3PY725OmS9M0qLORbJwLqFtGh+jiE4wAmocK2CTUK2Q== +"@babel/plugin-proposal-private-property-in-object@^7.21.0": + version "7.21.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.21.0.tgz#19496bd9883dd83c23c7d7fc45dcd9ad02dfa1dc" + integrity sha512-ha4zfehbJjc5MmXBlHec1igel5TJXXLDDRbuJ4+XT2TJcyD9/V1919BA8gMvsdHcNMBy4WBUBiRb3nw/EQUtBw== dependencies: - "@babel/helper-annotate-as-pure" "^7.14.5" - "@babel/helper-create-class-features-plugin" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-create-class-features-plugin" "^7.21.0" + "@babel/helper-plugin-utils" "^7.20.2" "@babel/plugin-syntax-private-property-in-object" "^7.14.5" -"@babel/plugin-proposal-unicode-property-regex@^7.14.5", "@babel/plugin-proposal-unicode-property-regex@^7.4.4": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.14.5.tgz#0f95ee0e757a5d647f378daa0eca7e93faa8bbe8" - integrity sha512-6axIeOU5LnY471KenAB9vI8I5j7NQ2d652hIYwVyRfgaZT5UpiqFKCuVXCDMSrU+3VFafnu2c5m3lrWIlr6A5Q== +"@babel/plugin-proposal-unicode-property-regex@^7.18.6", "@babel/plugin-proposal-unicode-property-regex@^7.4.4": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz#af613d2cd5e643643b65cded64207b15c85cb78e" + integrity sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w== dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-create-regexp-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-async-generators@^7.8.4": version "7.8.4" @@ -741,7 +732,14 @@ dependencies: "@babel/helper-plugin-utils" "^7.8.3" -"@babel/plugin-syntax-import-meta@^7.8.3": +"@babel/plugin-syntax-import-assertions@^7.20.0": + version "7.20.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz#bb50e0d4bea0957235390641209394e87bdb9cc4" + integrity sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ== + dependencies: + "@babel/helper-plugin-utils" "^7.19.0" + +"@babel/plugin-syntax-import-meta@^7.10.4", "@babel/plugin-syntax-import-meta@^7.8.3": version "7.10.4" resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz#ee601348c370fa334d2207be158777496521fd51" integrity sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g== @@ -825,284 +823,290 @@ dependencies: "@babel/helper-plugin-utils" "^7.12.13" -"@babel/plugin-transform-arrow-functions@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.14.5.tgz#f7187d9588a768dd080bf4c9ffe117ea62f7862a" - integrity sha512-KOnO0l4+tD5IfOdi4x8C1XmEIRWUjNRV8wc6K2vz/3e8yAOoZZvsRXRRIF/yo/MAOFb4QjtAw9xSxMXbSMRy8A== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-transform-async-to-generator@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.14.5.tgz#72c789084d8f2094acb945633943ef8443d39e67" - integrity sha512-szkbzQ0mNk0rpu76fzDdqSyPu0MuvpXgC+6rz5rpMb5OIRxdmHfQxrktL8CYolL2d8luMCZTR0DpIMIdL27IjA== - dependencies: - "@babel/helper-module-imports" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-remap-async-to-generator" "^7.14.5" - -"@babel/plugin-transform-block-scoped-functions@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.14.5.tgz#e48641d999d4bc157a67ef336aeb54bc44fd3ad4" - integrity sha512-dtqWqdWZ5NqBX3KzsVCWfQI3A53Ft5pWFCT2eCVUftWZgjc5DpDponbIF1+c+7cSGk2wN0YK7HGL/ezfRbpKBQ== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-transform-block-scoping@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.14.5.tgz#8cc63e61e50f42e078e6f09be775a75f23ef9939" - integrity sha512-LBYm4ZocNgoCqyxMLoOnwpsmQ18HWTQvql64t3GvMUzLQrNoV1BDG0lNftC8QKYERkZgCCT/7J5xWGObGAyHDw== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-transform-classes@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.14.5.tgz#0e98e82097b38550b03b483f9b51a78de0acb2cf" - integrity sha512-J4VxKAMykM06K/64z9rwiL6xnBHgB1+FVspqvlgCdwD1KUbQNfszeKVVOMh59w3sztHYIZDgnhOC4WbdEfHFDA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.14.5" - "@babel/helper-function-name" "^7.14.5" - "@babel/helper-optimise-call-expression" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-replace-supers" "^7.14.5" - "@babel/helper-split-export-declaration" "^7.14.5" +"@babel/plugin-transform-arrow-functions@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.21.5.tgz#9bb42a53de447936a57ba256fbf537fc312b6929" + integrity sha512-wb1mhwGOCaXHDTcsRYMKF9e5bbMgqwxtqa2Y1ifH96dXJPwbuLX9qHy3clhrxVqgMz7nyNXs8VkxdH8UBcjKqA== + dependencies: + "@babel/helper-plugin-utils" "^7.21.5" + +"@babel/plugin-transform-async-to-generator@^7.20.7": + version "7.20.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.20.7.tgz#dfee18623c8cb31deb796aa3ca84dda9cea94354" + integrity sha512-Uo5gwHPT9vgnSXQxqGtpdufUiWp96gk7yiP4Mp5bm1QMkEmLXBO7PAGYbKoJ6DhAwiNkcHFBol/x5zZZkL/t0Q== + dependencies: + "@babel/helper-module-imports" "^7.18.6" + "@babel/helper-plugin-utils" "^7.20.2" + "@babel/helper-remap-async-to-generator" "^7.18.9" + +"@babel/plugin-transform-block-scoped-functions@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz#9187bf4ba302635b9d70d986ad70f038726216a8" + integrity sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-block-scoping@^7.21.0": + version "7.21.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.21.0.tgz#e737b91037e5186ee16b76e7ae093358a5634f02" + integrity sha512-Mdrbunoh9SxwFZapeHVrwFmri16+oYotcZysSzhNIVDwIAb1UV+kvnxULSYq9J3/q5MDG+4X6w8QVgD1zhBXNQ== + dependencies: + "@babel/helper-plugin-utils" "^7.20.2" + +"@babel/plugin-transform-classes@^7.21.0": + version "7.21.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.21.0.tgz#f469d0b07a4c5a7dbb21afad9e27e57b47031665" + integrity sha512-RZhbYTCEUAe6ntPehC4hlslPWosNHDox+vAs4On/mCLRLfoDVHf6hVEd7kuxr1RnHwJmxFfUM3cZiZRmPxJPXQ== + dependencies: + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-compilation-targets" "^7.20.7" + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-function-name" "^7.21.0" + "@babel/helper-optimise-call-expression" "^7.18.6" + "@babel/helper-plugin-utils" "^7.20.2" + "@babel/helper-replace-supers" "^7.20.7" + "@babel/helper-split-export-declaration" "^7.18.6" globals "^11.1.0" -"@babel/plugin-transform-computed-properties@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.14.5.tgz#1b9d78987420d11223d41195461cc43b974b204f" - integrity sha512-pWM+E4283UxaVzLb8UBXv4EIxMovU4zxT1OPnpHJcmnvyY9QbPPTKZfEj31EUvG3/EQRbYAGaYEUZ4yWOBC2xg== +"@babel/plugin-transform-computed-properties@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.21.5.tgz#3a2d8bb771cd2ef1cd736435f6552fe502e11b44" + integrity sha512-TR653Ki3pAwxBxUe8srfF3e4Pe3FTA46uaNHYyQwIoM4oWKSoOZiDNyHJ0oIoDIUPSRQbQG7jzgVBX3FPVne1Q== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.21.5" + "@babel/template" "^7.20.7" -"@babel/plugin-transform-destructuring@^7.14.7": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.14.7.tgz#0ad58ed37e23e22084d109f185260835e5557576" - integrity sha512-0mDE99nK+kVh3xlc5vKwB6wnP9ecuSj+zQCa/n0voENtP/zymdT4HH6QEb65wjjcbqr1Jb/7z9Qp7TF5FtwYGw== +"@babel/plugin-transform-destructuring@^7.21.3": + version "7.21.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.21.3.tgz#73b46d0fd11cd6ef57dea8a381b1215f4959d401" + integrity sha512-bp6hwMFzuiE4HqYEyoGJ/V2LeIWn+hLVKc4pnj++E5XQptwhtcGmSayM029d/j2X1bPKGTlsyPwAubuU22KhMA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.20.2" -"@babel/plugin-transform-dotall-regex@^7.14.5", "@babel/plugin-transform-dotall-regex@^7.4.4": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.14.5.tgz#2f6bf76e46bdf8043b4e7e16cf24532629ba0c7a" - integrity sha512-loGlnBdj02MDsFaHhAIJzh7euK89lBrGIdM9EAtHFo6xKygCUGuuWe07o1oZVk287amtW1n0808sQM99aZt3gw== +"@babel/plugin-transform-dotall-regex@^7.18.6", "@babel/plugin-transform-dotall-regex@^7.4.4": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz#b286b3e7aae6c7b861e45bed0a2fafd6b1a4fef8" + integrity sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg== dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-create-regexp-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-duplicate-keys@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.14.5.tgz#365a4844881bdf1501e3a9f0270e7f0f91177954" - integrity sha512-iJjbI53huKbPDAsJ8EmVmvCKeeq21bAze4fu9GBQtSLqfvzj2oRuHVx4ZkDwEhg1htQ+5OBZh/Ab0XDf5iBZ7A== +"@babel/plugin-transform-duplicate-keys@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz#687f15ee3cdad6d85191eb2a372c4528eaa0ae0e" + integrity sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.9" -"@babel/plugin-transform-exponentiation-operator@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.14.5.tgz#5154b8dd6a3dfe6d90923d61724bd3deeb90b493" - integrity sha512-jFazJhMBc9D27o9jDnIE5ZErI0R0m7PbKXVq77FFvqFbzvTMuv8jaAwLZ5PviOLSFttqKIW0/wxNSDbjLk0tYA== +"@babel/plugin-transform-exponentiation-operator@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz#421c705f4521888c65e91fdd1af951bfefd4dacd" + integrity sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw== dependencies: - "@babel/helper-builder-binary-assignment-operator-visitor" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-builder-binary-assignment-operator-visitor" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-for-of@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.14.5.tgz#dae384613de8f77c196a8869cbf602a44f7fc0eb" - integrity sha512-CfmqxSUZzBl0rSjpoQSFoR9UEj3HzbGuGNL21/iFTmjb5gFggJp3ph0xR1YBhexmLoKRHzgxuFvty2xdSt6gTA== +"@babel/plugin-transform-for-of@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.21.5.tgz#e890032b535f5a2e237a18535f56a9fdaa7b83fc" + integrity sha512-nYWpjKW/7j/I/mZkGVgHJXh4bA1sfdFnJoOXwJuj4m3Q2EraO/8ZyrkCau9P5tbHQk01RMSt6KYLCsW7730SXQ== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.21.5" -"@babel/plugin-transform-function-name@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.14.5.tgz#e81c65ecb900746d7f31802f6bed1f52d915d6f2" - integrity sha512-vbO6kv0fIzZ1GpmGQuvbwwm+O4Cbm2NrPzwlup9+/3fdkuzo1YqOZcXw26+YUJB84Ja7j9yURWposEHLYwxUfQ== +"@babel/plugin-transform-function-name@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz#cc354f8234e62968946c61a46d6365440fc764e0" + integrity sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ== dependencies: - "@babel/helper-function-name" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-compilation-targets" "^7.18.9" + "@babel/helper-function-name" "^7.18.9" + "@babel/helper-plugin-utils" "^7.18.9" -"@babel/plugin-transform-literals@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-literals/-/plugin-transform-literals-7.14.5.tgz#41d06c7ff5d4d09e3cf4587bd3ecf3930c730f78" - integrity sha512-ql33+epql2F49bi8aHXxvLURHkxJbSmMKl9J5yHqg4PLtdE6Uc48CH1GS6TQvZ86eoB/ApZXwm7jlA+B3kra7A== +"@babel/plugin-transform-literals@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz#72796fdbef80e56fba3c6a699d54f0de557444bc" + integrity sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.9" -"@babel/plugin-transform-member-expression-literals@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.14.5.tgz#b39cd5212a2bf235a617d320ec2b48bcc091b8a7" - integrity sha512-WkNXxH1VXVTKarWFqmso83xl+2V3Eo28YY5utIkbsmXoItO8Q3aZxN4BTS2k0hz9dGUloHK26mJMyQEYfkn/+Q== +"@babel/plugin-transform-member-expression-literals@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz#ac9fdc1a118620ac49b7e7a5d2dc177a1bfee88e" + integrity sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-modules-amd@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.14.5.tgz#4fd9ce7e3411cb8b83848480b7041d83004858f7" - integrity sha512-3lpOU8Vxmp3roC4vzFpSdEpGUWSMsHFreTWOMMLzel2gNGfHE5UWIh/LN6ghHs2xurUp4jRFYMUIZhuFbody1g== +"@babel/plugin-transform-modules-amd@^7.20.11": + version "7.20.11" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.20.11.tgz#3daccca8e4cc309f03c3a0c4b41dc4b26f55214a" + integrity sha512-NuzCt5IIYOW0O30UvqktzHYR2ud5bOWbY0yaxWZ6G+aFzOMJvrs5YHNikrbdaT15+KNO31nPOy5Fim3ku6Zb5g== dependencies: - "@babel/helper-module-transforms" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" - babel-plugin-dynamic-import-node "^2.3.3" + "@babel/helper-module-transforms" "^7.20.11" + "@babel/helper-plugin-utils" "^7.20.2" -"@babel/plugin-transform-modules-commonjs@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.14.5.tgz#7aaee0ea98283de94da98b28f8c35701429dad97" - integrity sha512-en8GfBtgnydoao2PS+87mKyw62k02k7kJ9ltbKe0fXTHrQmG6QZZflYuGI1VVG7sVpx4E1n7KBpNlPb8m78J+A== +"@babel/plugin-transform-modules-commonjs@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.21.5.tgz#d69fb947eed51af91de82e4708f676864e5e47bc" + integrity sha512-OVryBEgKUbtqMoB7eG2rs6UFexJi6Zj6FDXx+esBLPTCxCNxAY9o+8Di7IsUGJ+AVhp5ncK0fxWUBd0/1gPhrQ== dependencies: - "@babel/helper-module-transforms" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-simple-access" "^7.14.5" - babel-plugin-dynamic-import-node "^2.3.3" + "@babel/helper-module-transforms" "^7.21.5" + "@babel/helper-plugin-utils" "^7.21.5" + "@babel/helper-simple-access" "^7.21.5" -"@babel/plugin-transform-modules-systemjs@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.14.5.tgz#c75342ef8b30dcde4295d3401aae24e65638ed29" - integrity sha512-mNMQdvBEE5DcMQaL5LbzXFMANrQjd2W7FPzg34Y4yEz7dBgdaC+9B84dSO+/1Wba98zoDbInctCDo4JGxz1VYA== +"@babel/plugin-transform-modules-systemjs@^7.20.11": + version "7.20.11" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.20.11.tgz#467ec6bba6b6a50634eea61c9c232654d8a4696e" + integrity sha512-vVu5g9BPQKSFEmvt2TA4Da5N+QVS66EX21d8uoOihC+OCpUoGvzVsXeqFdtAEfVa5BILAeFt+U7yVmLbQnAJmw== dependencies: - "@babel/helper-hoist-variables" "^7.14.5" - "@babel/helper-module-transforms" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-validator-identifier" "^7.14.5" - babel-plugin-dynamic-import-node "^2.3.3" + "@babel/helper-hoist-variables" "^7.18.6" + "@babel/helper-module-transforms" "^7.20.11" + "@babel/helper-plugin-utils" "^7.20.2" + "@babel/helper-validator-identifier" "^7.19.1" -"@babel/plugin-transform-modules-umd@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.14.5.tgz#fb662dfee697cce274a7cda525190a79096aa6e0" - integrity sha512-RfPGoagSngC06LsGUYyM9QWSXZ8MysEjDJTAea1lqRjNECE3y0qIJF/qbvJxc4oA4s99HumIMdXOrd+TdKaAAA== +"@babel/plugin-transform-modules-umd@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz#81d3832d6034b75b54e62821ba58f28ed0aab4b9" + integrity sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ== dependencies: - "@babel/helper-module-transforms" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-module-transforms" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-named-capturing-groups-regex@^7.14.7": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.14.7.tgz#60c06892acf9df231e256c24464bfecb0908fd4e" - integrity sha512-DTNOTaS7TkW97xsDMrp7nycUVh6sn/eq22VaxWfEdzuEbRsiaOU0pqU7DlyUGHVsbQbSghvjKRpEl+nUCKGQSg== +"@babel/plugin-transform-named-capturing-groups-regex@^7.20.5": + version "7.20.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.20.5.tgz#626298dd62ea51d452c3be58b285d23195ba69a8" + integrity sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA== dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.14.5" + "@babel/helper-create-regexp-features-plugin" "^7.20.5" + "@babel/helper-plugin-utils" "^7.20.2" -"@babel/plugin-transform-new-target@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.14.5.tgz#31bdae8b925dc84076ebfcd2a9940143aed7dbf8" - integrity sha512-Nx054zovz6IIRWEB49RDRuXGI4Gy0GMgqG0cII9L3MxqgXz/+rgII+RU58qpo4g7tNEx1jG7rRVH4ihZoP4esQ== +"@babel/plugin-transform-new-target@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz#d128f376ae200477f37c4ddfcc722a8a1b3246a8" + integrity sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-object-super@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.14.5.tgz#d0b5faeac9e98597a161a9cf78c527ed934cdc45" - integrity sha512-MKfOBWzK0pZIrav9z/hkRqIk/2bTv9qvxHzPQc12RcVkMOzpIKnFCNYJip00ssKWYkd8Sf5g0Wr7pqJ+cmtuFg== +"@babel/plugin-transform-object-super@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz#fb3c6ccdd15939b6ff7939944b51971ddc35912c" + integrity sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-replace-supers" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/helper-replace-supers" "^7.18.6" -"@babel/plugin-transform-parameters@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.14.5.tgz#49662e86a1f3ddccac6363a7dfb1ff0a158afeb3" - integrity sha512-Tl7LWdr6HUxTmzQtzuU14SqbgrSKmaR77M0OKyq4njZLQTPfOvzblNKyNkGwOfEFCEx7KeYHQHDI0P3F02IVkA== +"@babel/plugin-transform-parameters@^7.20.7", "@babel/plugin-transform-parameters@^7.21.3": + version "7.21.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.21.3.tgz#18fc4e797cf6d6d972cb8c411dbe8a809fa157db" + integrity sha512-Wxc+TvppQG9xWFYatvCGPvZ6+SIUxQ2ZdiBP+PHYMIjnPXD+uThCshaz4NZOnODAtBjjcVQQ/3OKs9LW28purQ== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.20.2" -"@babel/plugin-transform-property-literals@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.14.5.tgz#0ddbaa1f83db3606f1cdf4846fa1dfb473458b34" - integrity sha512-r1uilDthkgXW8Z1vJz2dKYLV1tuw2xsbrp3MrZmD99Wh9vsfKoob+JTgri5VUb/JqyKRXotlOtwgu4stIYCmnw== +"@babel/plugin-transform-property-literals@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz#e22498903a483448e94e032e9bbb9c5ccbfc93a3" + integrity sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-regenerator@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.14.5.tgz#9676fd5707ed28f522727c5b3c0aa8544440b04f" - integrity sha512-NVIY1W3ITDP5xQl50NgTKlZ0GrotKtLna08/uGY6ErQt6VEQZXla86x/CTddm5gZdcr+5GSsvMeTmWA5Ii6pkg== +"@babel/plugin-transform-regenerator@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.21.5.tgz#576c62f9923f94bcb1c855adc53561fd7913724e" + integrity sha512-ZoYBKDb6LyMi5yCsByQ5jmXsHAQDDYeexT1Szvlmui+lADvfSecr5Dxd/PkrTC3pAD182Fcju1VQkB4oCp9M+w== dependencies: - regenerator-transform "^0.14.2" + "@babel/helper-plugin-utils" "^7.21.5" + regenerator-transform "^0.15.1" -"@babel/plugin-transform-reserved-words@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.14.5.tgz#c44589b661cfdbef8d4300dcc7469dffa92f8304" - integrity sha512-cv4F2rv1nD4qdexOGsRQXJrOcyb5CrgjUH9PKrrtyhSDBNWGxd0UIitjyJiWagS+EbUGjG++22mGH1Pub8D6Vg== +"@babel/plugin-transform-reserved-words@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz#b1abd8ebf8edaa5f7fe6bbb8d2133d23b6a6f76a" + integrity sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-shorthand-properties@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.14.5.tgz#97f13855f1409338d8cadcbaca670ad79e091a58" - integrity sha512-xLucks6T1VmGsTB+GWK5Pl9Jl5+nRXD1uoFdA5TSO6xtiNjtXTjKkmPdFXVLGlK5A2/or/wQMKfmQ2Y0XJfn5g== +"@babel/plugin-transform-shorthand-properties@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz#6d6df7983d67b195289be24909e3f12a8f664dc9" + integrity sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-spread@^7.14.6": - version "7.14.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-spread/-/plugin-transform-spread-7.14.6.tgz#6bd40e57fe7de94aa904851963b5616652f73144" - integrity sha512-Zr0x0YroFJku7n7+/HH3A2eIrGMjbmAIbJSVv0IZ+t3U2WUQUA64S/oeied2e+MaGSjmt4alzBCsK9E8gh+fag== +"@babel/plugin-transform-spread@^7.20.7": + version "7.20.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-spread/-/plugin-transform-spread-7.20.7.tgz#c2d83e0b99d3bf83e07b11995ee24bf7ca09401e" + integrity sha512-ewBbHQ+1U/VnH1fxltbJqDeWBU1oNLG8Dj11uIv3xVf7nrQu0bPGe5Rf716r7K5Qz+SqtAOVswoVunoiBtGhxw== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-skip-transparent-expression-wrappers" "^7.14.5" + "@babel/helper-plugin-utils" "^7.20.2" + "@babel/helper-skip-transparent-expression-wrappers" "^7.20.0" -"@babel/plugin-transform-sticky-regex@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.14.5.tgz#5b617542675e8b7761294381f3c28c633f40aeb9" - integrity sha512-Z7F7GyvEMzIIbwnziAZmnSNpdijdr4dWt+FJNBnBLz5mwDFkqIXU9wmBcWWad3QeJF5hMTkRe4dAq2sUZiG+8A== +"@babel/plugin-transform-sticky-regex@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz#c6706eb2b1524028e317720339583ad0f444adcc" + integrity sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.6" -"@babel/plugin-transform-template-literals@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.14.5.tgz#a5f2bc233937d8453885dc736bdd8d9ffabf3d93" - integrity sha512-22btZeURqiepOfuy/VkFr+zStqlujWaarpMErvay7goJS6BWwdd6BY9zQyDLDa4x2S3VugxFb162IZ4m/S/+Gg== +"@babel/plugin-transform-template-literals@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz#04ec6f10acdaa81846689d63fae117dd9c243a5e" + integrity sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.9" -"@babel/plugin-transform-typeof-symbol@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.14.5.tgz#39af2739e989a2bd291bf6b53f16981423d457d4" - integrity sha512-lXzLD30ffCWseTbMQzrvDWqljvZlHkXU+CnseMhkMNqU1sASnCsz3tSzAaH3vCUXb9PHeUb90ZT1BdFTm1xxJw== +"@babel/plugin-transform-typeof-symbol@^7.18.9": + version "7.18.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz#c8cea68263e45addcd6afc9091429f80925762c0" + integrity sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.18.9" -"@babel/plugin-transform-unicode-escapes@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.14.5.tgz#9d4bd2a681e3c5d7acf4f57fa9e51175d91d0c6b" - integrity sha512-crTo4jATEOjxj7bt9lbYXcBAM3LZaUrbP2uUdxb6WIorLmjNKSpHfIybgY4B8SRpbf8tEVIWH3Vtm7ayCrKocA== +"@babel/plugin-transform-unicode-escapes@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.21.5.tgz#1e55ed6195259b0e9061d81f5ef45a9b009fb7f2" + integrity sha512-LYm/gTOwZqsYohlvFUe/8Tujz75LqqVC2w+2qPHLR+WyWHGCZPN1KBpJCJn+4Bk4gOkQy/IXKIge6az5MqwlOg== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-plugin-utils" "^7.21.5" -"@babel/plugin-transform-unicode-regex@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.14.5.tgz#4cd09b6c8425dd81255c7ceb3fb1836e7414382e" - integrity sha512-UygduJpC5kHeCiRw/xDVzC+wj8VaYSoKl5JNVmbP7MadpNinAm3SvZCxZ42H37KZBKztz46YC73i9yV34d0Tzw== +"@babel/plugin-transform-unicode-regex@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz#194317225d8c201bbae103364ffe9e2cea36cdca" + integrity sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA== dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" + "@babel/helper-create-regexp-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" "@babel/preset-env@^7.11.0": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.14.7.tgz#5c70b22d4c2d893b03d8c886a5c17422502b932a" - integrity sha512-itOGqCKLsSUl0Y+1nSfhbuuOlTs0MJk2Iv7iSH+XT/mR8U1zRLO7NjWlYXB47yhK4J/7j+HYty/EhFZDYKa/VA== - dependencies: - "@babel/compat-data" "^7.14.7" - "@babel/helper-compilation-targets" "^7.14.5" - "@babel/helper-plugin-utils" "^7.14.5" - "@babel/helper-validator-option" "^7.14.5" - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.14.5" - "@babel/plugin-proposal-async-generator-functions" "^7.14.7" - "@babel/plugin-proposal-class-properties" "^7.14.5" - "@babel/plugin-proposal-class-static-block" "^7.14.5" - "@babel/plugin-proposal-dynamic-import" "^7.14.5" - "@babel/plugin-proposal-export-namespace-from" "^7.14.5" - "@babel/plugin-proposal-json-strings" "^7.14.5" - "@babel/plugin-proposal-logical-assignment-operators" "^7.14.5" - "@babel/plugin-proposal-nullish-coalescing-operator" "^7.14.5" - "@babel/plugin-proposal-numeric-separator" "^7.14.5" - "@babel/plugin-proposal-object-rest-spread" "^7.14.7" - "@babel/plugin-proposal-optional-catch-binding" "^7.14.5" - "@babel/plugin-proposal-optional-chaining" "^7.14.5" - "@babel/plugin-proposal-private-methods" "^7.14.5" - "@babel/plugin-proposal-private-property-in-object" "^7.14.5" - "@babel/plugin-proposal-unicode-property-regex" "^7.14.5" + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.21.5.tgz#db2089d99efd2297716f018aeead815ac3decffb" + integrity sha512-wH00QnTTldTbf/IefEVyChtRdw5RJvODT/Vb4Vcxq1AZvtXj6T0YeX0cAcXhI6/BdGuiP3GcNIL4OQbI2DVNxg== + dependencies: + "@babel/compat-data" "^7.21.5" + "@babel/helper-compilation-targets" "^7.21.5" + "@babel/helper-plugin-utils" "^7.21.5" + "@babel/helper-validator-option" "^7.21.0" + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression" "^7.18.6" + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.20.7" + "@babel/plugin-proposal-async-generator-functions" "^7.20.7" + "@babel/plugin-proposal-class-properties" "^7.18.6" + "@babel/plugin-proposal-class-static-block" "^7.21.0" + "@babel/plugin-proposal-dynamic-import" "^7.18.6" + "@babel/plugin-proposal-export-namespace-from" "^7.18.9" + "@babel/plugin-proposal-json-strings" "^7.18.6" + "@babel/plugin-proposal-logical-assignment-operators" "^7.20.7" + "@babel/plugin-proposal-nullish-coalescing-operator" "^7.18.6" + "@babel/plugin-proposal-numeric-separator" "^7.18.6" + "@babel/plugin-proposal-object-rest-spread" "^7.20.7" + "@babel/plugin-proposal-optional-catch-binding" "^7.18.6" + "@babel/plugin-proposal-optional-chaining" "^7.21.0" + "@babel/plugin-proposal-private-methods" "^7.18.6" + "@babel/plugin-proposal-private-property-in-object" "^7.21.0" + "@babel/plugin-proposal-unicode-property-regex" "^7.18.6" "@babel/plugin-syntax-async-generators" "^7.8.4" "@babel/plugin-syntax-class-properties" "^7.12.13" "@babel/plugin-syntax-class-static-block" "^7.14.5" "@babel/plugin-syntax-dynamic-import" "^7.8.3" "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + "@babel/plugin-syntax-import-assertions" "^7.20.0" + "@babel/plugin-syntax-import-meta" "^7.10.4" "@babel/plugin-syntax-json-strings" "^7.8.3" "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" @@ -1112,50 +1116,50 @@ "@babel/plugin-syntax-optional-chaining" "^7.8.3" "@babel/plugin-syntax-private-property-in-object" "^7.14.5" "@babel/plugin-syntax-top-level-await" "^7.14.5" - "@babel/plugin-transform-arrow-functions" "^7.14.5" - "@babel/plugin-transform-async-to-generator" "^7.14.5" - "@babel/plugin-transform-block-scoped-functions" "^7.14.5" - "@babel/plugin-transform-block-scoping" "^7.14.5" - "@babel/plugin-transform-classes" "^7.14.5" - "@babel/plugin-transform-computed-properties" "^7.14.5" - "@babel/plugin-transform-destructuring" "^7.14.7" - "@babel/plugin-transform-dotall-regex" "^7.14.5" - "@babel/plugin-transform-duplicate-keys" "^7.14.5" - "@babel/plugin-transform-exponentiation-operator" "^7.14.5" - "@babel/plugin-transform-for-of" "^7.14.5" - "@babel/plugin-transform-function-name" "^7.14.5" - "@babel/plugin-transform-literals" "^7.14.5" - "@babel/plugin-transform-member-expression-literals" "^7.14.5" - "@babel/plugin-transform-modules-amd" "^7.14.5" - "@babel/plugin-transform-modules-commonjs" "^7.14.5" - "@babel/plugin-transform-modules-systemjs" "^7.14.5" - "@babel/plugin-transform-modules-umd" "^7.14.5" - "@babel/plugin-transform-named-capturing-groups-regex" "^7.14.7" - "@babel/plugin-transform-new-target" "^7.14.5" - "@babel/plugin-transform-object-super" "^7.14.5" - "@babel/plugin-transform-parameters" "^7.14.5" - "@babel/plugin-transform-property-literals" "^7.14.5" - "@babel/plugin-transform-regenerator" "^7.14.5" - "@babel/plugin-transform-reserved-words" "^7.14.5" - "@babel/plugin-transform-shorthand-properties" "^7.14.5" - "@babel/plugin-transform-spread" "^7.14.6" - "@babel/plugin-transform-sticky-regex" "^7.14.5" - "@babel/plugin-transform-template-literals" "^7.14.5" - "@babel/plugin-transform-typeof-symbol" "^7.14.5" - "@babel/plugin-transform-unicode-escapes" "^7.14.5" - "@babel/plugin-transform-unicode-regex" "^7.14.5" - "@babel/preset-modules" "^0.1.4" - "@babel/types" "^7.14.5" - babel-plugin-polyfill-corejs2 "^0.2.2" - babel-plugin-polyfill-corejs3 "^0.2.2" - babel-plugin-polyfill-regenerator "^0.2.2" - core-js-compat "^3.15.0" + "@babel/plugin-transform-arrow-functions" "^7.21.5" + "@babel/plugin-transform-async-to-generator" "^7.20.7" + "@babel/plugin-transform-block-scoped-functions" "^7.18.6" + "@babel/plugin-transform-block-scoping" "^7.21.0" + "@babel/plugin-transform-classes" "^7.21.0" + "@babel/plugin-transform-computed-properties" "^7.21.5" + "@babel/plugin-transform-destructuring" "^7.21.3" + "@babel/plugin-transform-dotall-regex" "^7.18.6" + "@babel/plugin-transform-duplicate-keys" "^7.18.9" + "@babel/plugin-transform-exponentiation-operator" "^7.18.6" + "@babel/plugin-transform-for-of" "^7.21.5" + "@babel/plugin-transform-function-name" "^7.18.9" + "@babel/plugin-transform-literals" "^7.18.9" + "@babel/plugin-transform-member-expression-literals" "^7.18.6" + "@babel/plugin-transform-modules-amd" "^7.20.11" + "@babel/plugin-transform-modules-commonjs" "^7.21.5" + "@babel/plugin-transform-modules-systemjs" "^7.20.11" + "@babel/plugin-transform-modules-umd" "^7.18.6" + "@babel/plugin-transform-named-capturing-groups-regex" "^7.20.5" + "@babel/plugin-transform-new-target" "^7.18.6" + "@babel/plugin-transform-object-super" "^7.18.6" + "@babel/plugin-transform-parameters" "^7.21.3" + "@babel/plugin-transform-property-literals" "^7.18.6" + "@babel/plugin-transform-regenerator" "^7.21.5" + "@babel/plugin-transform-reserved-words" "^7.18.6" + "@babel/plugin-transform-shorthand-properties" "^7.18.6" + "@babel/plugin-transform-spread" "^7.20.7" + "@babel/plugin-transform-sticky-regex" "^7.18.6" + "@babel/plugin-transform-template-literals" "^7.18.9" + "@babel/plugin-transform-typeof-symbol" "^7.18.9" + "@babel/plugin-transform-unicode-escapes" "^7.21.5" + "@babel/plugin-transform-unicode-regex" "^7.18.6" + "@babel/preset-modules" "^0.1.5" + "@babel/types" "^7.21.5" + babel-plugin-polyfill-corejs2 "^0.3.3" + babel-plugin-polyfill-corejs3 "^0.6.0" + babel-plugin-polyfill-regenerator "^0.4.1" + core-js-compat "^3.25.1" semver "^6.3.0" -"@babel/preset-modules@^0.1.4": - version "0.1.4" - resolved "https://registry.yarnpkg.com/@babel/preset-modules/-/preset-modules-0.1.4.tgz#362f2b68c662842970fdb5e254ffc8fc1c2e415e" - integrity sha512-J36NhwnfdzpmH41M1DrnkkgAqhZaqr/NBdPfQ677mLzlaXo+oDiv1deyCDtgAhz8p328otdob0Du7+xgHGZbKg== +"@babel/preset-modules@^0.1.5": + version "0.1.5" + resolved "https://registry.yarnpkg.com/@babel/preset-modules/-/preset-modules-0.1.5.tgz#ef939d6e7f268827e1841638dc6ff95515e115d9" + integrity sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA== dependencies: "@babel/helper-plugin-utils" "^7.0.0" "@babel/plugin-proposal-unicode-property-regex" "^7.4.4" @@ -1163,6 +1167,11 @@ "@babel/types" "^7.4.4" esutils "^2.0.2" +"@babel/regjsgen@^0.8.0": + version "0.8.0" + resolved "https://registry.yarnpkg.com/@babel/regjsgen/-/regjsgen-0.8.0.tgz#f0ba69b075e1f05fb2825b7fad991e7adbb18310" + integrity sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA== + "@babel/runtime-corejs3@^7.10.2": version "7.13.10" resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.13.10.tgz#14c3f4c85de22ba88e8e86685d13e8861a82fe86" @@ -1171,28 +1180,30 @@ core-js-pure "^3.0.0" regenerator-runtime "^0.13.4" -"@babel/runtime@7.12.5": - version "7.12.5" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.12.5.tgz#410e7e487441e1b360c29be715d870d9b985882e" - integrity sha512-plcc+hbExy3McchJCEQG3knOsuh3HH+Prx1P6cLIkET/0dLuQDEnrT+s27Axgc9bqfsmNUNHfscgMUdBpC9xfg== - dependencies: - regenerator-runtime "^0.13.4" - -"@babel/runtime@^7.10.2", "@babel/runtime@^7.11.2", "@babel/runtime@^7.3.1", "@babel/runtime@^7.4.4", "@babel/runtime@^7.5.5", "@babel/runtime@^7.8.3", "@babel/runtime@^7.8.7": +"@babel/runtime@^7.10.2", "@babel/runtime@^7.4.4", "@babel/runtime@^7.5.5", "@babel/runtime@^7.8.7": version "7.13.10" resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.13.10.tgz#47d42a57b6095f4468da440388fdbad8bebf0d7d" integrity sha512-4QPkjJq6Ns3V/RgpEahRk+AGfL0eO6RHHtTWoNNr5mO49G6B5+X6d6THgWEAvTrznU5xYpbAlVKRYcsCgh/Akw== dependencies: regenerator-runtime "^0.13.4" -"@babel/runtime@^7.8.4": - version "7.14.6" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.14.6.tgz#535203bc0892efc7dec60bdc27b2ecf6e409062d" - integrity sha512-/PCB2uJ7oM44tz8YhC4Z/6PeOKXp4K588f+5M3clr1M4zbqztlo0XEfJ2LEzj/FgwfgGcIdl8n7YYjTCI0BYwg== +"@babel/runtime@^7.11.2", "@babel/runtime@^7.3.1", "@babel/runtime@^7.8.3", "@babel/runtime@^7.8.4": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.21.5.tgz#8492dddda9644ae3bda3b45eabe87382caee7200" + integrity sha512-8jI69toZqqcsnqGGqwGS4Qb1VwLOEp4hz+CXPywcvjs60u3B4Pom/U/7rm4W8tMOYEB+E9wgD0mW1l3r8qlI9Q== dependencies: - regenerator-runtime "^0.13.4" + regenerator-runtime "^0.13.11" + +"@babel/template@^7.12.13", "@babel/template@^7.18.10", "@babel/template@^7.20.7": + version "7.20.7" + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.20.7.tgz#a15090c2839a83b02aa996c0b4994005841fd5a8" + integrity sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw== + dependencies: + "@babel/code-frame" "^7.18.6" + "@babel/parser" "^7.20.7" + "@babel/types" "^7.20.7" -"@babel/template@^7.12.13", "@babel/template@^7.3.3": +"@babel/template@^7.3.3": version "7.12.13" resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.12.13.tgz#530265be8a2589dbb37523844c5bcb55947fb327" integrity sha512-/7xxiGA57xMo/P2GVvdEumr8ONhFOhfgq2ihK3h1e6THqzTAkHbkXgB0xI9yeTfIUoH3+oAeHhqm/I43OTbbjA== @@ -1201,16 +1212,7 @@ "@babel/parser" "^7.12.13" "@babel/types" "^7.12.13" -"@babel/template@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.14.5.tgz#a9bc9d8b33354ff6e55a9c60d1109200a68974f4" - integrity sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g== - dependencies: - "@babel/code-frame" "^7.14.5" - "@babel/parser" "^7.14.5" - "@babel/types" "^7.14.5" - -"@babel/traverse@^7.1.0", "@babel/traverse@^7.13.0", "@babel/traverse@^7.4.5", "@babel/traverse@^7.7.0": +"@babel/traverse@^7.1.0", "@babel/traverse@^7.4.5", "@babel/traverse@^7.7.0": version "7.13.0" resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.13.0.tgz#6d95752475f86ee7ded06536de309a65fc8966cc" integrity sha512-xys5xi5JEhzC3RzEmSGrs/b3pJW/o87SypZ+G/PhaE7uqVQNv/jlmVIBXuoh5atqQ434LfXV+sf23Oxj0bchJQ== @@ -1225,6 +1227,22 @@ globals "^11.1.0" lodash "^4.17.19" +"@babel/traverse@^7.13.0", "@babel/traverse@^7.20.5", "@babel/traverse@^7.21.5": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.21.5.tgz#ad22361d352a5154b498299d523cf72998a4b133" + integrity sha512-AhQoI3YjWi6u/y/ntv7k48mcrCXmus0t79J9qPNlk/lAsFlCiJ047RmbfMOawySTHtywXhbXgpx/8nXMYd+oFw== + dependencies: + "@babel/code-frame" "^7.21.4" + "@babel/generator" "^7.21.5" + "@babel/helper-environment-visitor" "^7.21.5" + "@babel/helper-function-name" "^7.21.0" + "@babel/helper-hoist-variables" "^7.18.6" + "@babel/helper-split-export-declaration" "^7.18.6" + "@babel/parser" "^7.21.5" + "@babel/types" "^7.21.5" + debug "^4.1.0" + globals "^11.1.0" + "@babel/traverse@^7.14.0", "@babel/traverse@^7.14.2", "@babel/traverse@^7.7.2": version "7.14.2" resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.14.2.tgz#9201a8d912723a831c2679c7ebbf2fe1416d765b" @@ -1239,21 +1257,6 @@ debug "^4.1.0" globals "^11.1.0" -"@babel/traverse@^7.14.5": - version "7.14.7" - resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.14.7.tgz#64007c9774cfdc3abd23b0780bc18a3ce3631753" - integrity sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ== - dependencies: - "@babel/code-frame" "^7.14.5" - "@babel/generator" "^7.14.5" - "@babel/helper-function-name" "^7.14.5" - "@babel/helper-hoist-variables" "^7.14.5" - "@babel/helper-split-export-declaration" "^7.14.5" - "@babel/parser" "^7.14.7" - "@babel/types" "^7.14.5" - debug "^4.1.0" - globals "^11.1.0" - "@babel/types@7.8.3": version "7.8.3" resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.8.3.tgz#5a383dffa5416db1b73dedffd311ffd0788fb31c" @@ -1263,7 +1266,7 @@ lodash "^4.17.13" to-fast-properties "^2.0.0" -"@babel/types@^7.0.0", "@babel/types@^7.12.13", "@babel/types@^7.12.5", "@babel/types@^7.13.0", "@babel/types@^7.3.0", "@babel/types@^7.3.3", "@babel/types@^7.7.0": +"@babel/types@^7.0.0", "@babel/types@^7.12.5", "@babel/types@^7.3.0", "@babel/types@^7.3.3", "@babel/types@^7.7.0": version "7.13.0" resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.13.0.tgz#74424d2816f0171b4100f0ab34e9a374efdf7f80" integrity sha512-hE+HE8rnG1Z6Wzo+MhaKE5lM5eMx71T4EHJgku2E3xIfaULhDcxiiRxUYgwX8qwP1BBSlag+TdGOt6JAidIZTA== @@ -1272,6 +1275,15 @@ lodash "^4.17.19" to-fast-properties "^2.0.0" +"@babel/types@^7.12.13", "@babel/types@^7.13.0", "@babel/types@^7.16.7", "@babel/types@^7.18.6", "@babel/types@^7.18.9", "@babel/types@^7.20.0", "@babel/types@^7.20.5", "@babel/types@^7.20.7", "@babel/types@^7.21.0", "@babel/types@^7.21.4", "@babel/types@^7.21.5", "@babel/types@^7.4.4": + version "7.21.5" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.21.5.tgz#18dfbd47c39d3904d5db3d3dc2cc80bedb60e5b6" + integrity sha512-m4AfNvVF2mVC/F7fDEdH2El3HzUg9It/XsCxZiOTTA3m3qYfcSVSbTfM6Q9xG+hYDniZssYhlXKKUMD5m8tF4Q== + dependencies: + "@babel/helper-string-parser" "^7.21.5" + "@babel/helper-validator-identifier" "^7.19.1" + to-fast-properties "^2.0.0" + "@babel/types@^7.13.12", "@babel/types@^7.14.0", "@babel/types@^7.14.2", "@babel/types@^7.14.4": version "7.14.4" resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.14.4.tgz#bfd6980108168593b38b3eb48a24aa026b919bc0" @@ -1280,14 +1292,6 @@ "@babel/helper-validator-identifier" "^7.14.0" to-fast-properties "^2.0.0" -"@babel/types@^7.14.5", "@babel/types@^7.4.4": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.14.5.tgz#3bb997ba829a2104cedb20689c4a5b8121d383ff" - integrity sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg== - dependencies: - "@babel/helper-validator-identifier" "^7.14.5" - to-fast-properties "^2.0.0" - "@bcoe/v8-coverage@^0.2.3": version "0.2.3" resolved "https://registry.yarnpkg.com/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz#75a2e8b51cb758a7553d6804a5932d7aace75c39" @@ -1347,64 +1351,6 @@ minimatch "^3.0.4" strip-json-comments "^3.1.1" -"@hapi/accept@5.0.2": - version "5.0.2" - resolved "https://registry.yarnpkg.com/@hapi/accept/-/accept-5.0.2.tgz#ab7043b037e68b722f93f376afb05e85c0699523" - integrity sha512-CmzBx/bXUR8451fnZRuZAJRlzgm0Jgu5dltTX/bszmR2lheb9BpyN47Q1RbaGTsvFzn0PXAEs+lXDKfshccYZw== - dependencies: - "@hapi/boom" "9.x.x" - "@hapi/hoek" "9.x.x" - -"@hapi/address@^2.1.2": - version "2.1.4" - resolved "https://registry.yarnpkg.com/@hapi/address/-/address-2.1.4.tgz#5d67ed43f3fd41a69d4b9ff7b56e7c0d1d0a81e5" - integrity sha512-QD1PhQk+s31P1ixsX0H0Suoupp3VMXzIVMSwobR3F3MSUO2YCV0B7xqLcUw/Bh8yuvd3LhpyqLQWTNcRmp6IdQ== - -"@hapi/boom@9.x.x": - version "9.1.1" - resolved "https://registry.yarnpkg.com/@hapi/boom/-/boom-9.1.1.tgz#89e6f0e01637c2a4228da0d113e8157c93677b04" - integrity sha512-VNR8eDbBrOxBgbkddRYIe7+8DZ+vSbV6qlmaN2x7eWjsUjy2VmQgChkOKcVZIeupEZYj+I0dqNg430OhwzagjA== - dependencies: - "@hapi/hoek" "9.x.x" - -"@hapi/formula@^1.2.0": - version "1.2.0" - resolved "https://registry.yarnpkg.com/@hapi/formula/-/formula-1.2.0.tgz#994649c7fea1a90b91a0a1e6d983523f680e10cd" - integrity sha512-UFbtbGPjstz0eWHb+ga/GM3Z9EzqKXFWIbSOFURU0A/Gku0Bky4bCk9/h//K2Xr3IrCfjFNhMm4jyZ5dbCewGA== - -"@hapi/hoek@9.x.x": - version "9.1.1" - resolved "https://registry.yarnpkg.com/@hapi/hoek/-/hoek-9.1.1.tgz#9daf5745156fd84b8e9889a2dc721f0c58e894aa" - integrity sha512-CAEbWH7OIur6jEOzaai83jq3FmKmv4PmX1JYfs9IrYcGEVI/lyL1EXJGCj7eFVJ0bg5QR8LMxBlEtA+xKiLpFw== - -"@hapi/hoek@^8.2.4", "@hapi/hoek@^8.3.0": - version "8.5.1" - resolved "https://registry.yarnpkg.com/@hapi/hoek/-/hoek-8.5.1.tgz#fde96064ca446dec8c55a8c2f130957b070c6e06" - integrity sha512-yN7kbciD87WzLGc5539Tn0sApjyiGHAJgKvG9W8C7O+6c7qmoQMfVs0W4bX17eqz6C78QJqqFrtgdK5EWf6Qow== - -"@hapi/joi@^16.1.8": - version "16.1.8" - resolved "https://registry.yarnpkg.com/@hapi/joi/-/joi-16.1.8.tgz#84c1f126269489871ad4e2decc786e0adef06839" - integrity sha512-wAsVvTPe+FwSrsAurNt5vkg3zo+TblvC5Bb1zMVK6SJzZqw9UrJnexxR+76cpePmtUZKHAPxcQ2Bf7oVHyahhg== - dependencies: - "@hapi/address" "^2.1.2" - "@hapi/formula" "^1.2.0" - "@hapi/hoek" "^8.2.4" - "@hapi/pinpoint" "^1.0.2" - "@hapi/topo" "^3.1.3" - -"@hapi/pinpoint@^1.0.2": - version "1.0.2" - resolved "https://registry.yarnpkg.com/@hapi/pinpoint/-/pinpoint-1.0.2.tgz#025b7a36dbbf4d35bf1acd071c26b20ef41e0d13" - integrity sha512-dtXC/WkZBfC5vxscazuiJ6iq4j9oNx1SHknmIr8hofarpKUZKmlUVYVIhNVzIEgK5Wrc4GMHL5lZtt1uS2flmQ== - -"@hapi/topo@^3.1.3": - version "3.1.6" - resolved "https://registry.yarnpkg.com/@hapi/topo/-/topo-3.1.6.tgz#68d935fa3eae7fdd5ab0d7f953f3205d8b2bfc29" - integrity sha512-tAag0jEcjwH+P2quUfipd7liWCNX2F8NvYjQp2wtInsZxnMlypdw0FtAOLxtvvkO+GSRRbmNi8m/5y42PQJYCQ== - dependencies: - "@hapi/hoek" "^8.3.0" - "@istanbuljs/load-nyc-config@^1.0.0": version "1.1.0" resolved "https://registry.yarnpkg.com/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz#fd3db1d59ecf7cf121e80650bb86712f9b55eced" @@ -1601,6 +1547,51 @@ "@types/yargs" "^16.0.0" chalk "^4.0.0" +"@jridgewell/gen-mapping@^0.3.0", "@jridgewell/gen-mapping@^0.3.2": + version "0.3.3" + resolved "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz#7e02e6eb5df901aaedb08514203b096614024098" + integrity sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ== + dependencies: + "@jridgewell/set-array" "^1.0.1" + "@jridgewell/sourcemap-codec" "^1.4.10" + "@jridgewell/trace-mapping" "^0.3.9" + +"@jridgewell/resolve-uri@3.1.0": + version "3.1.0" + resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz#2203b118c157721addfe69d47b70465463066d78" + integrity sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w== + +"@jridgewell/set-array@^1.0.1": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@jridgewell/set-array/-/set-array-1.1.2.tgz#7c6cf998d6d20b914c0a55a91ae928ff25965e72" + integrity sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw== + +"@jridgewell/source-map@^0.3.2": + version "0.3.3" + resolved "https://registry.yarnpkg.com/@jridgewell/source-map/-/source-map-0.3.3.tgz#8108265659d4c33e72ffe14e33d6cc5eb59f2fda" + integrity sha512-b+fsZXeLYi9fEULmfBrhxn4IrPlINf8fiNarzTof004v3lFdntdwa9PF7vFJqm3mg7s+ScJMxXaE3Acp1irZcg== + dependencies: + "@jridgewell/gen-mapping" "^0.3.0" + "@jridgewell/trace-mapping" "^0.3.9" + +"@jridgewell/sourcemap-codec@1.4.14": + version "1.4.14" + resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz#add4c98d341472a289190b424efbdb096991bb24" + integrity sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw== + +"@jridgewell/sourcemap-codec@^1.4.10": + version "1.4.15" + resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz#d7c6e6755c78567a951e04ab52ef0fd26de59f32" + integrity sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg== + +"@jridgewell/trace-mapping@^0.3.17", "@jridgewell/trace-mapping@^0.3.9": + version "0.3.18" + resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz#25783b2086daf6ff1dcb53c9249ae480e4dd4cd6" + integrity sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA== + dependencies: + "@jridgewell/resolve-uri" "3.1.0" + "@jridgewell/sourcemap-codec" "1.4.14" + "@mapbox/geojson-rewind@^0.5.0": version "0.5.0" resolved "https://registry.yarnpkg.com/@mapbox/geojson-rewind/-/geojson-rewind-0.5.0.tgz#91f0ad56008c120caa19414b644d741249f4f560" @@ -1733,75 +1724,81 @@ prop-types "^15.7.2" react-is "^16.8.0 || ^17.0.0" -"@next/env@10.2.3": - version "10.2.3" - resolved "https://registry.yarnpkg.com/@next/env/-/env-10.2.3.tgz#ede3bbe68cec9939c37168ea2077f9adbc68334e" - integrity sha512-uBOjRBjsWC4C8X3DfmWWP6ekwLnf2JCCwQX9KVnJtJkqfDsv1yQPakdOEwvJzXQc3JC/v5KKffYPVmV2wHXCgQ== - -"@next/polyfill-module@10.2.3": - version "10.2.3" - resolved "https://registry.yarnpkg.com/@next/polyfill-module/-/polyfill-module-10.2.3.tgz#5a29f50c3ce3a56b8268d3b8331c691d8039467a" - integrity sha512-OkeY4cLhzfYbXxM4fd+6V4s5pTPuyfKSlavItfNRA6PpS7t1/R6YjO7S7rB8tu1pbTGuDHGIdE1ioDv15bAbDQ== - -"@next/react-dev-overlay@10.2.3": - version "10.2.3" - resolved "https://registry.yarnpkg.com/@next/react-dev-overlay/-/react-dev-overlay-10.2.3.tgz#95313d10a8848f6c7b9e31ae3bd2a3627d136841" - integrity sha512-E6g2jws4YW94l0lMMopBVKIZK2mEHfSBvM0d9dmzKG9L/A/kEq6LZCB4SiwGJbNsAdlk2y3USDa0oNbpA+m5Kw== - dependencies: - "@babel/code-frame" "7.12.11" - anser "1.4.9" - chalk "4.0.0" - classnames "2.2.6" - css.escape "1.5.1" - data-uri-to-buffer "3.0.1" - platform "1.3.6" - shell-quote "1.7.2" - source-map "0.8.0-beta.0" - stacktrace-parser "0.1.10" - strip-ansi "6.0.0" - -"@next/react-refresh-utils@10.2.3": - version "10.2.3" - resolved "https://registry.yarnpkg.com/@next/react-refresh-utils/-/react-refresh-utils-10.2.3.tgz#2f3e42fe6680798f276e3621345c2886b231348b" - integrity sha512-qtBF56vPC6d6a8p7LYd0iRjW89fhY80kAIzmj+VonvIGjK/nymBjcFUhbKiMFqlhsarCksnhwX+Zmn95Dw9qvA== - -"@nodelib/fs.scandir@2.1.4": - version "2.1.4" - resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz#d4b3549a5db5de2683e0c1071ab4f140904bbf69" - integrity sha512-33g3pMJk3bg5nXbL/+CY6I2eJDzZAni49PfJnL5fghPTggPvBd/pFNSgJsdAgWptuFu7qq/ERvOYFlhvsLTCKA== - dependencies: - "@nodelib/fs.stat" "2.0.4" +"@next/env@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/env/-/env-13.4.3.tgz#cb00bdd43a0619a79a52c9336df8a0aa84f8f4bf" + integrity sha512-pa1ErjyFensznttAk3EIv77vFbfSYT6cLzVRK5jx4uiRuCQo+m2wCFAREaHKIy63dlgvOyMlzh6R8Inu8H3KrQ== + +"@next/swc-darwin-arm64@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-darwin-arm64/-/swc-darwin-arm64-13.4.3.tgz#2d6c99dd5afbcce37e4ba0f64196317a1259034d" + integrity sha512-yx18udH/ZmR4Bw4M6lIIPE3JxsAZwo04iaucEfA2GMt1unXr2iodHUX/LAKNyi6xoLP2ghi0E+Xi1f4Qb8f1LQ== + +"@next/swc-darwin-x64@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-darwin-x64/-/swc-darwin-x64-13.4.3.tgz#162b15fb8a54d9f64e69c898ebeb55b7dac9bddd" + integrity sha512-Mi8xJWh2IOjryAM1mx18vwmal9eokJ2njY4nDh04scy37F0LEGJ/diL6JL6kTXi0UfUCGbMsOItf7vpReNiD2A== + +"@next/swc-linux-arm64-gnu@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-13.4.3.tgz#aee57422f11183d6a2e4a2e8aa23b9285873e18f" + integrity sha512-aBvtry4bxJ1xwKZ/LVPeBGBwWVwxa4bTnNkRRw6YffJnn/f4Tv4EGDPaVeYHZGQVA56wsGbtA6nZMuWs/EIk4Q== + +"@next/swc-linux-arm64-musl@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-13.4.3.tgz#c10b6aaaa47b341c6c9ea15f8b0ddb37e255d035" + integrity sha512-krT+2G3kEsEUvZoYte3/2IscscDraYPc2B+fDJFipPktJmrv088Pei/RjrhWm5TMIy5URYjZUoDZdh5k940Dyw== + +"@next/swc-linux-x64-gnu@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-13.4.3.tgz#3f85bc5591c6a0d4908404f7e88e3c04f4462039" + integrity sha512-AMdFX6EKJjC0G/CM6hJvkY8wUjCcbdj3Qg7uAQJ7PVejRWaVt0sDTMavbRfgMchx8h8KsAudUCtdFkG9hlEClw== + +"@next/swc-linux-x64-musl@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-13.4.3.tgz#f4535adc2374a86bc8e43af149b551567df065de" + integrity sha512-jySgSXE48shaLtcQbiFO9ajE9mqz7pcAVLnVLvRIlUHyQYR/WyZdK8ehLs65Mz6j9cLrJM+YdmdJPyV4WDaz2g== + +"@next/swc-win32-arm64-msvc@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-13.4.3.tgz#e76106d85391c308c5ed70cda2bca2c582d65536" + integrity sha512-5DxHo8uYcaADiE9pHrg8o28VMt/1kR8voDehmfs9AqS0qSClxAAl+CchjdboUvbCjdNWL1MISCvEfKY2InJ3JA== + +"@next/swc-win32-ia32-msvc@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-13.4.3.tgz#8eb5d9dd71ed7a971671291605ad64ad522fb3bc" + integrity sha512-LaqkF3d+GXRA5X6zrUjQUrXm2MN/3E2arXBtn5C7avBCNYfm9G3Xc646AmmmpN3DJZVaMYliMyCIQCMDEzk80w== + +"@next/swc-win32-x64-msvc@13.4.3": + version "13.4.3" + resolved "https://registry.yarnpkg.com/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-13.4.3.tgz#c7b2b1b9e158fd7749f8209e68ee8e43a997eb4c" + integrity sha512-jglUk/x7ZWeOJWlVoKyIAkHLTI+qEkOriOOV+3hr1GyiywzcqfI7TpFSiwC7kk1scOiH7NTFKp8mA3XPNO9bDw== + +"@nodelib/fs.scandir@2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== + dependencies: + "@nodelib/fs.stat" "2.0.5" run-parallel "^1.1.9" -"@nodelib/fs.stat@2.0.4", "@nodelib/fs.stat@^2.0.2": - version "2.0.4" - resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.4.tgz#a3f2dd61bab43b8db8fa108a121cfffe4c676655" - integrity sha512-IYlHJA0clt2+Vg7bccq+TzRdJvv19c2INqBSsoOLp1je7xjtr7J26+WXR72MCdvU9q1qTzIWDfhMf+DRvQJK4Q== +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== "@nodelib/fs.walk@^1.2.3": - version "1.2.6" - resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.6.tgz#cce9396b30aa5afe9e3756608f5831adcb53d063" - integrity sha512-8Broas6vTtW4GIXTAHDoE32hnN2M5ykgCpWGbuXHQ15vEMqr23pB76e/GZcYsZCHALv50ktd24qhEyKr6wBtow== + version "1.2.8" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== dependencies: - "@nodelib/fs.scandir" "2.1.4" + "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" -"@opentelemetry/api@0.14.0": - version "0.14.0" - resolved "https://registry.yarnpkg.com/@opentelemetry/api/-/api-0.14.0.tgz#4e17d8d2f1da72b19374efa7b6526aa001267cae" - integrity sha512-L7RMuZr5LzMmZiQSQDy9O1jo0q+DaLy6XpYJfIGfYSfoJA5qzYwUP3sP1uMIQ549DvxAgM3ng85EaPTM/hUHwQ== - dependencies: - "@opentelemetry/context-base" "^0.14.0" - -"@opentelemetry/context-base@^0.14.0": - version "0.14.0" - resolved "https://registry.yarnpkg.com/@opentelemetry/context-base/-/context-base-0.14.0.tgz#c67fc20a4d891447ca1a855d7d70fa79a3533001" - integrity sha512-sDOAZcYwynHFTbLo6n8kIbLiVF3a3BLkrmehJUyEbT9F+Smbi47kLGS2gG2g0fjBLR/Lr1InPD7kXL7FaTqEkw== - "@rollup/plugin-babel@^5.2.0": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@rollup/plugin-babel/-/plugin-babel-5.3.0.tgz#9cb1c5146ddd6a4968ad96f209c50c62f92f9879" - integrity sha512-9uIC8HZOnVLrLHxayq/PTzw+uS25E14KPUBh5ktF+18Mjo5yK0ToMMx6epY0uEgkjwJw0aBW4x2horYXh8juWw== + version "5.3.1" + resolved "https://registry.yarnpkg.com/@rollup/plugin-babel/-/plugin-babel-5.3.1.tgz#04bc0608f4aa4b2e4b1aebf284344d0f68fda283" + integrity sha512-WFfdLWU/xVWKeRQnKmIAQULUI7Il0gZnBIH/ZFO069wYIfPu+8zrfp/KMW0atmELoRDq8FbiP3VCss9MhCut7Q== dependencies: "@babel/helper-module-imports" "^7.10.4" "@rollup/pluginutils" "^3.1.0" @@ -1836,81 +1833,69 @@ picomatch "^2.2.2" "@sentry/browser@^6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/browser/-/browser-6.5.1.tgz#9a6ed5607b3b0f4e83f38720e3e202906f8c5bdb" - integrity sha512-iVLCdEFwsoWAzE/hNknexPQjjDpMQV7mmaq9Z1P63bD6MfhwVTx4hG4pHn8HEvC38VvCVf1wv0v/LxtoODAYXg== + version "6.19.7" + resolved "https://registry.yarnpkg.com/@sentry/browser/-/browser-6.19.7.tgz#a40b6b72d911b5f1ed70ed3b4e7d4d4e625c0b5f" + integrity sha512-oDbklp4O3MtAM4mtuwyZLrgO1qDVYIujzNJQzXmi9YzymJCuzMLSRDvhY83NNDCRxf0pds4DShgYeZdbSyKraA== dependencies: - "@sentry/core" "6.5.1" - "@sentry/types" "6.5.1" - "@sentry/utils" "6.5.1" + "@sentry/core" "6.19.7" + "@sentry/types" "6.19.7" + "@sentry/utils" "6.19.7" tslib "^1.9.3" -"@sentry/core@6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/core/-/core-6.5.1.tgz#c8b6c3ed86ed07b193c95d599c1b9a4a161e500e" - integrity sha512-Mh3sl/iUOT1myHmM6RlDy2ARzkUClx/g4DAt1rJ/IpQBOlDYQraplXSIW80i/hzRgQDfwhwgf4wUa5DicKBjKw== +"@sentry/core@6.19.7": + version "6.19.7" + resolved "https://registry.yarnpkg.com/@sentry/core/-/core-6.19.7.tgz#156aaa56dd7fad8c89c145be6ad7a4f7209f9785" + integrity sha512-tOfZ/umqB2AcHPGbIrsFLcvApdTm9ggpi/kQZFkej7kMphjT+SGBiQfYtjyg9jcRW+ilAR4JXC9BGKsdEQ+8Vw== dependencies: - "@sentry/hub" "6.5.1" - "@sentry/minimal" "6.5.1" - "@sentry/types" "6.5.1" - "@sentry/utils" "6.5.1" + "@sentry/hub" "6.19.7" + "@sentry/minimal" "6.19.7" + "@sentry/types" "6.19.7" + "@sentry/utils" "6.19.7" tslib "^1.9.3" -"@sentry/hub@6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/hub/-/hub-6.5.1.tgz#135ef09d07d32e87a53f664c0ae8fcc4f5963519" - integrity sha512-lBRMBVMYP8B4PfRiM70murbtJAXiIAao/asDEMIRNGMP6pI2ArqXfJCBYDkStukhikYD0Kqb4trXq+JYF07Hbg== +"@sentry/hub@6.19.7": + version "6.19.7" + resolved "https://registry.yarnpkg.com/@sentry/hub/-/hub-6.19.7.tgz#58ad7776bbd31e9596a8ec46365b45cd8b9cfd11" + integrity sha512-y3OtbYFAqKHCWezF0EGGr5lcyI2KbaXW2Ik7Xp8Mu9TxbSTuwTe4rTntwg8ngPjUQU3SUHzgjqVB8qjiGqFXCA== dependencies: - "@sentry/types" "6.5.1" - "@sentry/utils" "6.5.1" + "@sentry/types" "6.19.7" + "@sentry/utils" "6.19.7" tslib "^1.9.3" -"@sentry/minimal@6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/minimal/-/minimal-6.5.1.tgz#b8c1b382c2ea788eec3d32d203e5081b00eb6838" - integrity sha512-q9Do/oreu1RP695CXCLowVDuQyk7ilE6FGdz2QLpTXAfx8247qOwk6+zy9Kea/Djk93+BoSDVQUSneNiVwl0nQ== +"@sentry/minimal@6.19.7": + version "6.19.7" + resolved "https://registry.yarnpkg.com/@sentry/minimal/-/minimal-6.19.7.tgz#b3ee46d6abef9ef3dd4837ebcb6bdfd01b9aa7b4" + integrity sha512-wcYmSJOdvk6VAPx8IcmZgN08XTXRwRtB1aOLZm+MVHjIZIhHoBGZJYTVQS/BWjldsamj2cX3YGbGXNunaCfYJQ== dependencies: - "@sentry/hub" "6.5.1" - "@sentry/types" "6.5.1" + "@sentry/hub" "6.19.7" + "@sentry/types" "6.19.7" tslib "^1.9.3" "@sentry/node@^6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/node/-/node-6.5.1.tgz#a572b380858de5aeaf98eade6d8d3afcba13d364" - integrity sha512-Yh8J/QJ5e8gRBVL9VLCDpUvmiaxsxVZm0CInPHw3V/smgMkrzSKEiqxSeMq8ImPlaJrCFECqdpv4gnvYKI+mQQ== - dependencies: - "@sentry/core" "6.5.1" - "@sentry/hub" "6.5.1" - "@sentry/tracing" "6.5.1" - "@sentry/types" "6.5.1" - "@sentry/utils" "6.5.1" + version "6.19.7" + resolved "https://registry.yarnpkg.com/@sentry/node/-/node-6.19.7.tgz#32963b36b48daebbd559e6f13b1deb2415448592" + integrity sha512-gtmRC4dAXKODMpHXKfrkfvyBL3cI8y64vEi3fDD046uqYcrWdgoQsffuBbxMAizc6Ez1ia+f0Flue6p15Qaltg== + dependencies: + "@sentry/core" "6.19.7" + "@sentry/hub" "6.19.7" + "@sentry/types" "6.19.7" + "@sentry/utils" "6.19.7" cookie "^0.4.1" https-proxy-agent "^5.0.0" lru_map "^0.3.3" tslib "^1.9.3" -"@sentry/tracing@6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/tracing/-/tracing-6.5.1.tgz#a5f3e497d4f1f319f36475df050e135cf65af750" - integrity sha512-y1W/xFC2hAuKqSuuaovkElHY4pbli3XoXrreesg8PtO7ilX6ZbatOQbHsEsHQyoUv0F6aVA+MABOxWH2jt7tfw== - dependencies: - "@sentry/hub" "6.5.1" - "@sentry/minimal" "6.5.1" - "@sentry/types" "6.5.1" - "@sentry/utils" "6.5.1" - tslib "^1.9.3" - -"@sentry/types@6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/types/-/types-6.5.1.tgz#0a34ecfd1ae9275a416a105640eb4bed45a46a1d" - integrity sha512-b/7a6CMoytaeFPx4IBjfxPw3nPvsQh7ui1C8Vw0LxNNDgBwVhPLzUOWeLWbo5YZCVbGEMIWwtCUQYWxneceZSA== +"@sentry/types@6.19.7": + version "6.19.7" + resolved "https://registry.yarnpkg.com/@sentry/types/-/types-6.19.7.tgz#c6b337912e588083fc2896eb012526cf7cfec7c7" + integrity sha512-jH84pDYE+hHIbVnab3Hr+ZXr1v8QABfhx39KknxqKWr2l0oEItzepV0URvbEhB446lk/S/59230dlUUIBGsXbg== -"@sentry/utils@6.5.1": - version "6.5.1" - resolved "https://registry.yarnpkg.com/@sentry/utils/-/utils-6.5.1.tgz#046baf7d1a6564d6d555437ad3674dba9bc0806a" - integrity sha512-Wv86JYGQH+ZJ5XGFQX7h6ijl32667ikenoL9EyXMn8UoOYX/MLwZoQZin1P60wmKkYR9ifTNVmpaI9OoTaH+UQ== +"@sentry/utils@6.19.7": + version "6.19.7" + resolved "https://registry.yarnpkg.com/@sentry/utils/-/utils-6.19.7.tgz#6edd739f8185fd71afe49cbe351c1bbf5e7b7c79" + integrity sha512-z95ECmE3i9pbWoXQrD/7PgkBAzJYR+iXtPuTkpBjDKs86O3mT+PXOT3BAn79w2wkn7/i3vOGD2xVr1uiMl26dA== dependencies: - "@sentry/types" "6.5.1" + "@sentry/types" "6.19.7" tslib "^1.9.3" "@sinonjs/commons@^1.7.0": @@ -1927,13 +1912,22 @@ dependencies: "@sinonjs/commons" "^1.7.0" -"@surma/rollup-plugin-off-main-thread@^1.4.1": - version "1.4.2" - resolved "https://registry.yarnpkg.com/@surma/rollup-plugin-off-main-thread/-/rollup-plugin-off-main-thread-1.4.2.tgz#e6786b6af5799f82f7ab3a82e53f6182d2b91a58" - integrity sha512-yBMPqmd1yEJo/280PAMkychuaALyQ9Lkb5q1ck3mjJrFuEobIfhnQ4J3mbvBoISmR3SWMWV+cGB/I0lCQee79A== +"@surma/rollup-plugin-off-main-thread@^2.2.3": + version "2.2.3" + resolved "https://registry.yarnpkg.com/@surma/rollup-plugin-off-main-thread/-/rollup-plugin-off-main-thread-2.2.3.tgz#ee34985952ca21558ab0d952f00298ad2190c053" + integrity sha512-lR8q/9W7hZpMWweNiAKU7NQerBnzQQLvi8qnTDU/fxItPhtZVMbPV3lbCwjhIlNBe9Bbr5V+KHshvWmVSG9cxQ== dependencies: - ejs "^2.6.1" + ejs "^3.1.6" + json5 "^2.2.0" magic-string "^0.25.0" + string.prototype.matchall "^4.0.6" + +"@swc/helpers@0.5.1": + version "0.5.1" + resolved "https://registry.yarnpkg.com/@swc/helpers/-/helpers-0.5.1.tgz#e9031491aa3f26bfcc974a67f48bd456c8a5357a" + integrity sha512-sJ902EfIzn1Fa+qYmjdQqh8tPsoxyBz+8yBKC2HKUxyezKJFwPGOn7pv4WY6QuQW//ySQi5lJjA/ZT9sNWWNTg== + dependencies: + tslib "^2.4.0" "@tootallnate/once@1": version "1.1.2" @@ -2000,9 +1994,9 @@ integrity sha512-wE2v81i4C4Ol09RtsWFAqg3BUitWbHSpSlIo+bNdsCJijO9sjme+zm+73ZMCa/qMC8UEERxzGbvmr1cffo2SiQ== "@types/glob@^7.1.1": - version "7.1.3" - resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.1.3.tgz#e6ba80f36b7daad2c685acd9266382e68985c183" - integrity sha512-SEYeGAIQIQX8NN6LDKprLjbrd5dARM5EXsd8GI/A5l0apYI1fGMWgPHSe4ZKL4eozlAyI+doUE9XbYS4xCkQ1w== + version "7.2.0" + resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.2.0.tgz#bc1b5bf3aa92f25bd5dd39f35c57361bdce5b2eb" + integrity sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA== dependencies: "@types/minimatch" "*" "@types/node" "*" @@ -2041,7 +2035,12 @@ jest-diff "^26.0.0" pretty-format "^26.0.0" -"@types/json-schema@^7.0.5", "@types/json-schema@^7.0.6", "@types/json-schema@^7.0.7": +"@types/json-schema@^7.0.5", "@types/json-schema@^7.0.8": + version "7.0.11" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.11.tgz#d421b6c527a3037f7c84433fd2c4229e016863d3" + integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== + +"@types/json-schema@^7.0.7": version "7.0.7" resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.7.tgz#98a993516c859eb0d5c4c8f098317a9ea68db9ad" integrity sha512-cxWFQVseBm6O9Gbw1IWb8r6OS4OhSt3hPZLkFApLjM8TEXROBuQGLAH2i2gZpcXdLBIrpXuTDhH7Vbm1iXmNGA== @@ -2059,14 +2058,14 @@ "@types/geojson" "*" "@types/minimatch@*": - version "3.0.4" - resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.4.tgz#f0ec25dbf2f0e4b18647313ac031134ca5b24b21" - integrity sha512-1z8k4wzFnNjVK/tlxvrWuK5WMt6mydWWP7+zvH5eFep4oj+UkrfiJTRtjCeBXNpwaA/FYqqtb4/QS4ianFpIRA== + version "5.1.2" + resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-5.1.2.tgz#07508b45797cb81ec3f273011b054cd0755eddca" + integrity sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA== "@types/node@*": - version "14.14.35" - resolved "https://registry.yarnpkg.com/@types/node/-/node-14.14.35.tgz#42c953a4e2b18ab931f72477e7012172f4ffa313" - integrity sha512-Lt+wj8NVPx0zUmUwumiVXapmaLUcAk3yPuHCFVXras9k5VT9TdhJqKqGVUQCD60OTMCl0qxJ57OiTL0Mic3Iag== + version "20.2.1" + resolved "https://registry.yarnpkg.com/@types/node/-/node-20.2.1.tgz#de559d4b33be9a808fd43372ccee822c70f39704" + integrity sha512-DqJociPbZP1lbZ5SQPk4oag6W7AyaGMO6gSfRwq3PWl4PXTwJpRQJhDq4W0kzrg3w6tJ1SwlvGZ5uKFHY13LIg== "@types/parse-json@^4.0.0": version "4.0.0" @@ -2111,48 +2110,15 @@ resolved "https://registry.yarnpkg.com/@types/scheduler/-/scheduler-0.16.1.tgz#18845205e86ff0038517aab7a18a62a6b9f71275" integrity sha512-EaCxbanVeyxDRTQBkdLb3Bvl/HK7PBK6UJjsSixB0iHKoWxE5uu2Q/DgtpOhPIojN0Zl1whvOd7PoHs2P0s5eA== -"@types/source-list-map@*": - version "0.1.2" - resolved "https://registry.yarnpkg.com/@types/source-list-map/-/source-list-map-0.1.2.tgz#0078836063ffaf17412349bba364087e0ac02ec9" - integrity sha512-K5K+yml8LTo9bWJI/rECfIPrGgxdpeNbj+d53lwN4QjW1MCwlkhUms+gtdzigTeUyBr09+u8BwOIY3MXvHdcsA== - "@types/stack-utils@^2.0.0": version "2.0.0" resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-2.0.0.tgz#7036640b4e21cc2f259ae826ce843d277dad8cff" integrity sha512-RJJrrySY7A8havqpGObOB4W92QXKJo63/jFLLgpvOtsGUqbQZ9Sbgl35KMm1DjC6j7AvmmU2bIno+3IyEaemaw== -"@types/tapable@^1": - version "1.0.7" - resolved "https://registry.yarnpkg.com/@types/tapable/-/tapable-1.0.7.tgz#545158342f949e8fd3bfd813224971ecddc3fac4" - integrity sha512-0VBprVqfgFD7Ehb2vd8Lh9TG3jP98gvr8rgehQqzztZNI7o8zS8Ad4jyZneKELphpuE212D8J70LnSNQSyO6bQ== - -"@types/uglify-js@*": - version "3.13.0" - resolved "https://registry.yarnpkg.com/@types/uglify-js/-/uglify-js-3.13.0.tgz#1cad8df1fb0b143c5aba08de5712ea9d1ff71124" - integrity sha512-EGkrJD5Uy+Pg0NUR8uA4bJ5WMfljyad0G+784vLCNUkD+QwOJXUbBYExXfVGf7YtyzdQp3L/XMYcliB987kL5Q== - dependencies: - source-map "^0.6.1" - -"@types/webpack-sources@*": - version "2.1.0" - resolved "https://registry.yarnpkg.com/@types/webpack-sources/-/webpack-sources-2.1.0.tgz#8882b0bd62d1e0ce62f183d0d01b72e6e82e8c10" - integrity sha512-LXn/oYIpBeucgP1EIJbKQ2/4ZmpvRl+dlrFdX7+94SKRUV3Evy3FsfMZY318vGhkWUS5MPhtOM3w1/hCOAOXcg== - dependencies: - "@types/node" "*" - "@types/source-list-map" "*" - source-map "^0.7.3" - -"@types/webpack@^4.4.31": - version "4.41.29" - resolved "https://registry.yarnpkg.com/@types/webpack/-/webpack-4.41.29.tgz#2e66c1de8223c440366469415c50a47d97625773" - integrity sha512-6pLaORaVNZxiB3FSHbyBiWM7QdazAWda1zvAq4SbZObZqHSDbWLi62iFdblVea6SK9eyBIVp5yHhKt/yNQdR7Q== - dependencies: - "@types/node" "*" - "@types/tapable" "^1" - "@types/uglify-js" "*" - "@types/webpack-sources" "*" - anymatch "^3.0.0" - source-map "^0.6.0" +"@types/trusted-types@^2.0.2": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@types/trusted-types/-/trusted-types-2.0.3.tgz#a136f83b0758698df454e328759dbd3d44555311" + integrity sha512-NfQ4gyz38SL8sDNrSixxU2Os1a5xcdFxipAFxYEuLUlvU2uDwS4NUpsImcf1//SlWItCVMMLiylsxbmNMToV/g== "@types/xml2js@^0.4.2": version "0.4.8" @@ -2322,10 +2288,15 @@ acorn@^8.2.4: resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.3.0.tgz#1193f9b96c4e8232f00b11a9edff81b2c8b98b88" integrity sha512-tqPKHZ5CaBJw0Xmy0ZZvLs1qTV+BNFSyvn77ASXkpBNfIRk8ev26fKrD9iLGwGA9zedPao52GSHzq8lyZG0NUw== +acorn@^8.5.0: + version "8.8.2" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.2.tgz#1b2f25db02af965399b9776b0c2c391276d37c4a" + integrity sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw== + add-px-to-style@1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/add-px-to-style/-/add-px-to-style-1.0.0.tgz#d0c135441fa8014a8137904531096f67f28f263a" - integrity sha1-0ME1RB+oAUqBN5BFMQlvZ/KPJjo= + integrity sha512-YMyxSlXpPjD8uWekCQGuN40lV4bnZagUwqa2m/uFv1z/tNImSk9fnXVMUI5qwME/zzI3MMQRvjZ+69zyfSSyew== agent-base@6: version "6.0.2" @@ -2367,10 +2338,15 @@ ajv@^8.0.1: require-from-string "^2.0.2" uri-js "^4.2.2" -anser@1.4.9: - version "1.4.9" - resolved "https://registry.yarnpkg.com/anser/-/anser-1.4.9.tgz#1f85423a5dcf8da4631a341665ff675b96845760" - integrity sha512-AI+BjTeGt2+WFk4eWcqbQ7snZpDBt8SaLlj0RT2h5xfdWaiy51OjYvqwMrNzJLGy8iOAL6nKDITWO+rd4MkYEA== +ajv@^8.6.0: + version "8.12.0" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.12.0.tgz#d1a0527323e22f53562c567c00991577dfbe19d1" + integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA== + dependencies: + fast-deep-equal "^3.1.1" + json-schema-traverse "^1.0.0" + require-from-string "^2.0.2" + uri-js "^4.2.2" ansi-colors@^4.1.1: version "4.1.1" @@ -2385,9 +2361,9 @@ ansi-escapes@^4.2.1, ansi-escapes@^4.3.0: type-fest "^0.11.0" ansi-regex@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75" - integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg== + version "5.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" + integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== ansi-styles@^3.2.1: version "3.2.1" @@ -2408,15 +2384,7 @@ ansi-styles@^5.0.0: resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-5.2.0.tgz#07449690ad45777d1924ac2abb2fc8895dba836b" integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== -anymatch@^3.0.0: - version "3.1.2" - resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" - integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== - dependencies: - normalize-path "^3.0.0" - picomatch "^2.0.4" - -anymatch@^3.0.3, anymatch@~3.1.1: +anymatch@^3.0.3: version "3.1.1" resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.1.tgz#c55ecf02185e2469259399310c173ce31233b142" integrity sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg== @@ -2439,10 +2407,13 @@ aria-query@^4.2.2: "@babel/runtime" "^7.10.2" "@babel/runtime-corejs3" "^7.10.2" -array-filter@^1.0.0: +array-buffer-byte-length@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/array-filter/-/array-filter-1.0.0.tgz#baf79e62e6ef4c2a4c0b831232daffec251f9d83" - integrity sha1-uveeYubvTCpMC4MSMtr/7CUfnYM= + resolved "https://registry.yarnpkg.com/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz#fabe8bc193fea865f317fe7807085ee0dee5aead" + integrity sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A== + dependencies: + call-bind "^1.0.2" + is-array-buffer "^3.0.1" array-includes@^3.1.1, array-includes@^3.1.2, array-includes@^3.1.3: version "3.1.3" @@ -2458,7 +2429,7 @@ array-includes@^3.1.1, array-includes@^3.1.2, array-includes@^3.1.3: array-union@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/array-union/-/array-union-1.0.2.tgz#9a34410e4f4e3da23dea375be5be70f24778ec39" - integrity sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk= + integrity sha512-Dxr6QJj/RdU/hCaBjOfxW+q6lyuVE6JFWIrAUpuOOhoJJoQ99cUn3igRaHVB5P9WrgFVN0FfArM3x0cueOU8ng== dependencies: array-uniq "^1.0.1" @@ -2470,7 +2441,7 @@ array-union@^2.1.0: array-uniq@^1.0.1: version "1.0.3" resolved "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz#af6ac877a25cc7f74e058894753858dfdb24fdb6" - integrity sha1-r2rId6Jcx/dOBYiUdThY39sk/bY= + integrity sha512-MNha4BWQ6JbwhFhj03YK552f7cb3AzoE8SzeljgChvL1dl3IcvggXVz1DilzySZkCja+CXuZbdW7yATchWn8/Q== array.prototype.flat@^1.2.4: version "1.2.4" @@ -2491,49 +2462,21 @@ array.prototype.flatmap@^1.2.4: es-abstract "^1.18.0-next.1" function-bind "^1.1.1" -asn1.js@^5.2.0: - version "5.4.1" - resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-5.4.1.tgz#11a980b84ebb91781ce35b0fdc2ee294e3783f07" - integrity sha512-+I//4cYPccV8LdmBLiX8CYvf9Sp3vQsrqu2QNXRcrbiWvcx/UdlFiqUJJzxRQxgsZmvhXhn4cSKeSmoFjVdupA== - dependencies: - bn.js "^4.0.0" - inherits "^2.0.1" - minimalistic-assert "^1.0.0" - safer-buffer "^2.1.0" - -assert@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/assert/-/assert-2.0.0.tgz#95fc1c616d48713510680f2eaf2d10dd22e02d32" - integrity sha512-se5Cd+js9dXJnu6Ag2JFc00t+HmHOen+8Q+L7O9zI0PqQXr20uk2J0XQqMxZEeo5U50o8Nvmmx7dZrl+Ufr35A== - dependencies: - es6-object-assign "^1.1.0" - is-nan "^1.2.1" - object-is "^1.0.1" - util "^0.12.0" - -assert@^1.1.1: - version "1.5.0" - resolved "https://registry.yarnpkg.com/assert/-/assert-1.5.0.tgz#55c109aaf6e0aefdb3dc4b71240c70bf574b18eb" - integrity sha512-EDsgawzwoun2CZkCgtxJbv392v4nbk9XDD06zI+kQYoBM/3RBWLlEyJARDOmhAAosBjWACEkKL6S+lIZtcAubA== - dependencies: - object-assign "^4.1.1" - util "0.10.3" - ast-types-flow@^0.0.7: version "0.0.7" resolved "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.7.tgz#f70b735c6bca1a5c9c22d982c3e39e7feba3bdad" integrity sha1-9wtzXGvKGlycItmCw+Oef+ujva0= -ast-types@0.13.2: - version "0.13.2" - resolved "https://registry.yarnpkg.com/ast-types/-/ast-types-0.13.2.tgz#df39b677a911a83f3a049644fb74fdded23cea48" - integrity sha512-uWMHxJxtfj/1oZClOxDEV1sQ1HCDkA4MG8Gr69KKeBjEVH0R84WlejZ0y2DcwyBlpAEMltmVYkVgqfLFb2oyiA== - astral-regex@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ== +async@^3.2.3: + version "3.2.4" + resolved "https://registry.yarnpkg.com/async/-/async-3.2.4.tgz#2d22e00f8cddeb5fde5dd33522b56d1cf569a81c" + integrity sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ== + asynckit@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" @@ -2551,12 +2494,10 @@ autosuggest-highlight@^3.1.1: dependencies: diacritic "0.0.2" -available-typed-arrays@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.2.tgz#6b098ca9d8039079ee3f77f7b783c4480ba513f5" - integrity sha512-XWX3OX8Onv97LMk/ftVyBibpGwY5a8SmuxZPzeOxqmuEqUCOM9ZE+uIaD1VNJ5QnvU2UQusvmKbuM1FR8QWGfQ== - dependencies: - array-filter "^1.0.0" +available-typed-arrays@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz#92f95616501069d07d10edb2fc37d3e1c65123b7" + integrity sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw== axe-core@^4.0.2: version "4.1.3" @@ -2594,23 +2535,16 @@ babel-jest@^27.0.2: graceful-fs "^4.2.4" slash "^3.0.0" -babel-loader@^8.2.2: - version "8.2.2" - resolved "https://registry.yarnpkg.com/babel-loader/-/babel-loader-8.2.2.tgz#9363ce84c10c9a40e6c753748e1441b60c8a0b81" - integrity sha512-JvTd0/D889PQBtUXJ2PXaKU/pjZDMtHA9V2ecm+eNRmmBCMR09a+fmpGTNwnJtFmFl5Ei7Vy47LjBb+L0wQ99g== +babel-loader@^8.2.5: + version "8.3.0" + resolved "https://registry.yarnpkg.com/babel-loader/-/babel-loader-8.3.0.tgz#124936e841ba4fe8176786d6ff28add1f134d6a8" + integrity sha512-H8SvsMF+m9t15HNLMipppzkC+Y2Yq+v3SonZyU70RBL/h1gxPkH08Ot8pEE9Z4Kd+czyWJClmFS8qzIP9OZ04Q== dependencies: find-cache-dir "^3.3.1" - loader-utils "^1.4.0" + loader-utils "^2.0.0" make-dir "^3.1.0" schema-utils "^2.6.5" -babel-plugin-dynamic-import-node@^2.3.3: - version "2.3.3" - resolved "https://registry.yarnpkg.com/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz#84fda19c976ec5c6defef57f9427b3def66e17a3" - integrity sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ== - dependencies: - object.assign "^4.1.0" - babel-plugin-istanbul@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/babel-plugin-istanbul/-/babel-plugin-istanbul-6.0.0.tgz#e159ccdc9af95e0b570c75b4573b7c34d671d765" @@ -2632,29 +2566,29 @@ babel-plugin-jest-hoist@^27.0.1: "@types/babel__core" "^7.0.0" "@types/babel__traverse" "^7.0.6" -babel-plugin-polyfill-corejs2@^0.2.2: - version "0.2.2" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.2.2.tgz#e9124785e6fd94f94b618a7954e5693053bf5327" - integrity sha512-kISrENsJ0z5dNPq5eRvcctITNHYXWOA4DUZRFYCz3jYCcvTb/A546LIddmoGNMVYg2U38OyFeNosQwI9ENTqIQ== +babel-plugin-polyfill-corejs2@^0.3.3: + version "0.3.3" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz#5d1bd3836d0a19e1b84bbf2d9640ccb6f951c122" + integrity sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q== dependencies: - "@babel/compat-data" "^7.13.11" - "@babel/helper-define-polyfill-provider" "^0.2.2" + "@babel/compat-data" "^7.17.7" + "@babel/helper-define-polyfill-provider" "^0.3.3" semver "^6.1.1" -babel-plugin-polyfill-corejs3@^0.2.2: - version "0.2.3" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.2.3.tgz#72add68cf08a8bf139ba6e6dfc0b1d504098e57b" - integrity sha512-rCOFzEIJpJEAU14XCcV/erIf/wZQMmMT5l5vXOpL5uoznyOGfDIjPj6FVytMvtzaKSTSVKouOCTPJ5OMUZH30g== +babel-plugin-polyfill-corejs3@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz#56ad88237137eade485a71b52f72dbed57c6230a" + integrity sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA== dependencies: - "@babel/helper-define-polyfill-provider" "^0.2.2" - core-js-compat "^3.14.0" + "@babel/helper-define-polyfill-provider" "^0.3.3" + core-js-compat "^3.25.1" -babel-plugin-polyfill-regenerator@^0.2.2: - version "0.2.2" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.2.2.tgz#b310c8d642acada348c1fa3b3e6ce0e851bee077" - integrity sha512-Goy5ghsc21HgPDFtzRkSirpZVW35meGoTmTOb2bxqdl60ghub4xOidgNTHaZfQ2FaxQsKmwvXtOAkcIS4SMBWg== +babel-plugin-polyfill-regenerator@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz#390f91c38d90473592ed43351e801a9d3e0fd747" + integrity sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw== dependencies: - "@babel/helper-define-polyfill-provider" "^0.2.2" + "@babel/helper-define-polyfill-provider" "^0.3.3" "babel-plugin-styled-components@>= 1.12.0", babel-plugin-styled-components@^1.12.0: version "1.12.0" @@ -2698,35 +2632,15 @@ babel-preset-jest@^27.0.1: babel-preset-current-node-syntax "^1.0.0" balanced-match@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" - integrity sha1-ibTRmasr7kneFk6gK4nORi1xt2c= - -base64-js@^1.0.2: - version "1.5.1" - resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" - integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== + version "1.0.2" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" + integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== big.js@^5.2.2: version "5.2.2" resolved "https://registry.yarnpkg.com/big.js/-/big.js-5.2.2.tgz#65f0af382f578bcdc742bd9c281e9cb2d7768328" integrity sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ== -binary-extensions@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" - integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== - -bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.11.9: - version "4.12.0" - resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" - integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== - -bn.js@^5.0.0, bn.js@^5.1.1: - version "5.2.0" - resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.0.tgz#358860674396c6997771a9d051fcc1b57d4ae002" - integrity sha512-D7iWRBvnZE8ecXiLj/9wbxH7Tk79fAh8IHaTNq1RWRixsS02W+5qS+iE9yq6RYl0asXx5tw0bLhmT5pIfbSquw== - brace-expansion@^1.1.7: version "1.1.11" resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" @@ -2735,95 +2649,25 @@ brace-expansion@^1.1.7: balanced-match "^1.0.0" concat-map "0.0.1" -braces@^3.0.1, braces@~3.0.2: +brace-expansion@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" + integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== + dependencies: + balanced-match "^1.0.0" + +braces@^3.0.1: version "3.0.2" resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== dependencies: fill-range "^7.0.1" -brorand@^1.0.1, brorand@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f" - integrity sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8= - browser-process-hrtime@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz#3c9b4b7d782c8121e56f10106d84c0d0ffc94626" integrity sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow== -browserify-aes@^1.0.0, browserify-aes@^1.0.4: - version "1.2.0" - resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.2.0.tgz#326734642f403dabc3003209853bb70ad428ef48" - integrity sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA== - dependencies: - buffer-xor "^1.0.3" - cipher-base "^1.0.0" - create-hash "^1.1.0" - evp_bytestokey "^1.0.3" - inherits "^2.0.1" - safe-buffer "^5.0.1" - -browserify-cipher@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/browserify-cipher/-/browserify-cipher-1.0.1.tgz#8d6474c1b870bfdabcd3bcfcc1934a10e94f15f0" - integrity sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w== - dependencies: - browserify-aes "^1.0.4" - browserify-des "^1.0.0" - evp_bytestokey "^1.0.0" - -browserify-des@^1.0.0: - version "1.0.2" - resolved "https://registry.yarnpkg.com/browserify-des/-/browserify-des-1.0.2.tgz#3af4f1f59839403572f1c66204375f7a7f703e9c" - integrity sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A== - dependencies: - cipher-base "^1.0.1" - des.js "^1.0.0" - inherits "^2.0.1" - safe-buffer "^5.1.2" - -browserify-rsa@^4.0.0, browserify-rsa@^4.0.1: - version "4.1.0" - resolved "https://registry.yarnpkg.com/browserify-rsa/-/browserify-rsa-4.1.0.tgz#b2fd06b5b75ae297f7ce2dc651f918f5be158c8d" - integrity sha512-AdEER0Hkspgno2aR97SAf6vi0y0k8NuOpGnVH3O99rcA5Q6sh8QxcngtHuJ6uXwnfAXNM4Gn1Gb7/MV1+Ymbog== - dependencies: - bn.js "^5.0.0" - randombytes "^2.0.1" - -browserify-sign@^4.0.0: - version "4.2.1" - resolved "https://registry.yarnpkg.com/browserify-sign/-/browserify-sign-4.2.1.tgz#eaf4add46dd54be3bb3b36c0cf15abbeba7956c3" - integrity sha512-/vrA5fguVAKKAVTNJjgSm1tRQDHUU6DbwO9IROu/0WAzC8PKhucDSh18J0RMvVeHAn5puMd+QHC2erPRNf8lmg== - dependencies: - bn.js "^5.1.1" - browserify-rsa "^4.0.1" - create-hash "^1.2.0" - create-hmac "^1.1.7" - elliptic "^6.5.3" - inherits "^2.0.4" - parse-asn1 "^5.1.5" - readable-stream "^3.6.0" - safe-buffer "^5.2.0" - -browserify-zlib@0.2.0, browserify-zlib@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/browserify-zlib/-/browserify-zlib-0.2.0.tgz#2869459d9aa3be245fe8fe2ca1f46e2e7f54d73f" - integrity sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA== - dependencies: - pako "~1.0.5" - -browserslist@4.16.6, browserslist@^4.16.6: - version "4.16.6" - resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.16.6.tgz#d7901277a5a88e554ed305b183ec9b0c08f66fa2" - integrity sha512-Wspk/PqO+4W9qp5iUTJsa1B/QrYn1keNCcEP5OvP7WBwT4KaDly0uONYmC6Xa3Z5IqnUgS0KcgLYu1l74x0ZXQ== - dependencies: - caniuse-lite "^1.0.30001219" - colorette "^1.2.2" - electron-to-chromium "^1.3.723" - escalade "^3.1.1" - node-releases "^1.1.71" - browserslist@^4.14.5: version "4.16.3" resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.16.3.tgz#340aa46940d7db878748567c5dea24a48ddf3717" @@ -2835,6 +2679,16 @@ browserslist@^4.14.5: escalade "^3.1.1" node-releases "^1.1.70" +browserslist@^4.16.6, browserslist@^4.21.3, browserslist@^4.21.5: + version "4.21.5" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.21.5.tgz#75c5dae60063ee641f977e00edd3cfb2fb7af6a7" + integrity sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w== + dependencies: + caniuse-lite "^1.0.30001449" + electron-to-chromium "^1.4.284" + node-releases "^2.0.8" + update-browserslist-db "^1.0.10" + bser@2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/bser/-/bser-2.1.1.tgz#e6787da20ece9d07998533cfd9de6f5c38f4bc05" @@ -2843,46 +2697,21 @@ bser@2.1.1: node-int64 "^0.4.0" buffer-from@^1.0.0: - version "1.1.1" - resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef" - integrity sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A== - -buffer-xor@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9" - integrity sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk= - -buffer@5.6.0: - version "5.6.0" - resolved "https://registry.yarnpkg.com/buffer/-/buffer-5.6.0.tgz#a31749dc7d81d84db08abf937b6b8c4033f62786" - integrity sha512-/gDYp/UtU0eA1ys8bOs9J6a+E/KWIY+DZ+Q2WESNUA0jFRsJOc0SNUO6xJ5SGA1xueg3NL65W6s+NY5l9cunuw== - dependencies: - base64-js "^1.0.2" - ieee754 "^1.1.4" - -buffer@^4.3.0: - version "4.9.2" - resolved "https://registry.yarnpkg.com/buffer/-/buffer-4.9.2.tgz#230ead344002988644841ab0244af8c44bbe3ef8" - integrity sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg== - dependencies: - base64-js "^1.0.2" - ieee754 "^1.1.4" - isarray "^1.0.0" + version "1.1.2" + resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" + integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== builtin-modules@^3.1.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-3.2.0.tgz#45d5db99e7ee5e6bc4f362e008bf917ab5049887" - integrity sha512-lGzLKcioL90C7wMczpkY0n/oART3MbBa8R9OFGE1rJxoVI86u4WAGfEk8Wjv10eKSyTHVGkSo3bvBylCEtk7LA== - -builtin-status-codes@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz#85982878e21b98e1c66425e03d0174788f569ee8" - integrity sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug= + version "3.3.0" + resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-3.3.0.tgz#cae62812b89801e9656336e46223e030386be7b6" + integrity sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw== -bytes@3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.0.tgz#f6cf7933a360e0588fa9fde85651cdc7f805d1f6" - integrity sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg== +busboy@1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/busboy/-/busboy-1.6.0.tgz#966ea36a9502e43cdb9146962523b92f531f6893" + integrity sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA== + dependencies: + streamsearch "^1.1.0" call-bind@^1.0.0, call-bind@^1.0.2: version "1.0.2" @@ -2917,17 +2746,12 @@ caniuse-lite@^1.0.30001181: resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001200.tgz#25435af6ba907c2a9c86d21ce84950d4824e6620" integrity sha512-ic/jXfa6tgiPBAISWk16jRI2q8YfjxHnSG7ddSL1ptrIP8Uy11SayFrjXRAk3NumHpDb21fdTkbTxb/hOrFrnQ== -caniuse-lite@^1.0.30001202: - version "1.0.30001228" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001228.tgz#bfdc5942cd3326fa51ee0b42fbef4da9d492a7fa" - integrity sha512-QQmLOGJ3DEgokHbMSA8cj2a+geXqmnpyOFT0lhQV6P3/YOJvGDEwoedcwxEQ30gJIwIIunHIicunJ2rzK5gB2A== +caniuse-lite@^1.0.30001406, caniuse-lite@^1.0.30001449: + version "1.0.30001488" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001488.tgz#d19d7b6e913afae3e98f023db97c19e9ddc5e91f" + integrity sha512-NORIQuuL4xGpIy6iCCQGN4iFjlBXtfKWIenlUuyZJumLRIindLb7wXM+GO8erEhb7vXfcnf4BAg2PrSDN5TNLQ== -caniuse-lite@^1.0.30001219, caniuse-lite@^1.0.30001228: - version "1.0.30001234" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001234.tgz#8fc2e709e3b0679d7af7f073a1c661155c39b975" - integrity sha512-a3gjUVKkmwLdNysa1xkUAwN2VfJUJyVW47rsi3aCbkRCtbHAfo+rOsCqVw29G6coQ8gzAPb5XBXwiGHwme3isA== - -chalk@2.4.2, chalk@^2.0.0: +chalk@^2.0.0: version "2.4.2" resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== @@ -2936,14 +2760,6 @@ chalk@2.4.2, chalk@^2.0.0: escape-string-regexp "^1.0.5" supports-color "^5.3.0" -chalk@4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.0.0.tgz#6e98081ed2d17faab615eb52ac66ec1fe6209e72" - integrity sha512-N9oWFcegS0sFr9oh1oz2d7Npos6vNoWW9HvtCg5N1KRFpUhaAhvTv5Y58g880fZaEYSNm3qDz8SU1UrGvp+n7A== - dependencies: - ansi-styles "^4.1.0" - supports-color "^7.1.0" - chalk@^4.0.0, chalk@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.0.tgz#4e14870a618d9e2edd97dd8345fd9d9dc315646a" @@ -2952,6 +2768,14 @@ chalk@^4.0.0, chalk@^4.1.0: ansi-styles "^4.1.0" supports-color "^7.1.0" +chalk@^4.0.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + chalk@^4.1.1: version "4.1.1" resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.1.tgz#c80b3fab28bf6371e6863325eee67e618b77e6ad" @@ -2965,21 +2789,6 @@ char-regex@^1.0.2: resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-1.0.2.tgz#d744358226217f981ed58f479b1d6bcc29545dcf" integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== -chokidar@3.5.1: - version "3.5.1" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.1.tgz#ee9ce7bbebd2b79f49f304799d5468e31e14e68a" - integrity sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw== - dependencies: - anymatch "~3.1.1" - braces "~3.0.2" - glob-parent "~5.1.0" - is-binary-path "~2.1.0" - is-glob "~4.0.1" - normalize-path "~3.0.0" - readdirp "~3.5.0" - optionalDependencies: - fsevents "~2.3.1" - ci-info@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" @@ -2990,35 +2799,21 @@ ci-info@^3.1.1: resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-3.2.0.tgz#2876cb948a498797b5236f0095bc057d0dca38b6" integrity sha512-dVqRX7fLUm8J6FgHJ418XuIgDLZDkYcDFTeL6TA2gt5WlIZUQrrH6EZrNClwT/H0FateUsZkGIOPRrLbP+PR9A== -cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de" - integrity sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q== - dependencies: - inherits "^2.0.1" - safe-buffer "^5.0.1" - cjs-module-lexer@^1.0.0: version "1.2.1" resolved "https://registry.yarnpkg.com/cjs-module-lexer/-/cjs-module-lexer-1.2.1.tgz#2fd46d9906a126965aa541345c499aaa18e8cd73" integrity sha512-jVamGdJPDeuQilKhvVn1h3knuMOZzr8QDnpk+M9aMlCaMkTDd6fBWPhiDqFvFZ07pL0liqabAiuy8SY4jGHeaw== -classnames@2.2.6: - version "2.2.6" - resolved "https://registry.yarnpkg.com/classnames/-/classnames-2.2.6.tgz#43935bffdd291f326dad0a205309b38d00f650ce" - integrity sha512-JR/iSQOSt+LQIWwrwEzJ9uk0xfN3mTVYMwt1Ir5mUcSN6pU+V4zQFFaJsclJbPuAUQH+yfWef6tm7l1quW3C8Q== - clean-stack@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== -clean-webpack-plugin@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/clean-webpack-plugin/-/clean-webpack-plugin-3.0.0.tgz#a99d8ec34c1c628a4541567aa7b457446460c62b" - integrity sha512-MciirUH5r+cYLGCOL5JX/ZLzOZbVr1ot3Fw+KcvbhUb6PM+yycqd9ZhIlcigQ5gl+XhppNmw3bEFuaaMNyLj3A== +clean-webpack-plugin@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/clean-webpack-plugin/-/clean-webpack-plugin-4.0.0.tgz#72947d4403d452f38ed61a9ff0ada8122aacd729" + integrity sha512-WuWE1nyTNAyW5T7oNyys2EN0cfP2fdRxhxnIQWiAp0bMabPdHhoGxM8A6YL2GhqwgrPnnaemVE7nv5XJ2Fhh2w== dependencies: - "@types/webpack" "^4.4.31" del "^4.1.1" cli-cursor@^3.1.0: @@ -3036,6 +2831,11 @@ cli-truncate@^2.1.0: slice-ansi "^3.0.0" string-width "^4.2.0" +client-only@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/client-only/-/client-only-0.0.1.tgz#38bba5d403c41ab150bff64a95c85013cf73bca1" + integrity sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA== + cliui@^7.0.2: version "7.0.4" resolved "https://registry.yarnpkg.com/cliui/-/cliui-7.0.4.tgz#a0265ee655476fc807aea9df3df8df7783808b4f" @@ -3077,18 +2877,23 @@ color-convert@^2.0.1: color-name@1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" - integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU= + integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== color-name@~1.1.4: version "1.1.4" resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== -colorette@^1.2.1, colorette@^1.2.2: +colorette@^1.2.1: version "1.2.2" resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.2.2.tgz#cbcc79d5e99caea2dbf10eb3a26fd8b3e6acfa94" integrity sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w== +colorette@^1.2.2: + version "1.4.0" + resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.4.0.tgz#5190fbb87276259a86ad700bff2c6d6faa3fca40" + integrity sha512-Y2oEozpomLn7Q3HFP7dpww7AtMJplbM9lGZP6RDfHqmbeRjiwRg4n6VM6j4KLmRke85uWEI7JqF17f3pqdRA0g== + combined-stream@^1.0.8: version "1.0.8" resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" @@ -3107,14 +2912,14 @@ commander@^7.2.0: integrity sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw== common-tags@^1.8.0: - version "1.8.0" - resolved "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.0.tgz#8e3153e542d4a39e9b10554434afaaf98956a937" - integrity sha512-6P6g0uetGpW/sdyUy/iQQCbFF0kWVMSIVSyYz7Zgjcgh8mgw8PQzDNZeyZ5DQ2gM7LBoZPHmnjz8rUthkBG5tw== + version "1.8.2" + resolved "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.2.tgz#94ebb3c076d26032745fd54face7f688ef5ac9c6" + integrity sha512-gk/Z852D2Wtb//0I+kRFNKKE9dIIVirjoqPoA1wJU+XePVXZfGeBpk45+A1rKO4Q43prqWBNY/MiIeRLbPWUaA== commondir@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b" - integrity sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs= + integrity sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg== compare-versions@^3.6.0: version "3.6.0" @@ -3124,7 +2929,7 @@ compare-versions@^3.6.0: concat-map@0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" - integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== concat-stream@~2.0.0: version "2.0.0" @@ -3141,46 +2946,40 @@ confusing-browser-globals@^1.0.10: resolved "https://registry.yarnpkg.com/confusing-browser-globals/-/confusing-browser-globals-1.0.10.tgz#30d1e7f3d1b882b25ec4933d1d1adac353d20a59" integrity sha512-gNld/3lySHwuhaVluJUKLePYirM3QNCKzVxqAdhJII9/WXKVX5PURzMVJspS1jTslSqjeuG4KMVTSouit5YPHA== -console-browserify@^1.1.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/console-browserify/-/console-browserify-1.2.0.tgz#67063cef57ceb6cf4993a2ab3a55840ae8c49336" - integrity sha512-ZMkYO/LkF17QvCPqM0gxw8yUzigAOZOSWSHg91FH6orS7vcEj5dVZTidN2fQ14yBSdg97RqhSNwLUXInd52OTA== - -constants-browserify@1.0.0, constants-browserify@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/constants-browserify/-/constants-browserify-1.0.0.tgz#c20b96d8c617748aaf1c16021760cd27fcb8cb75" - integrity sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U= - -convert-source-map@1.7.0, convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: +convert-source-map@1.7.0, convert-source-map@^1.4.0, convert-source-map@^1.6.0: version "1.7.0" resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.7.0.tgz#17a2cb882d7f77d3490585e2ce6c524424a3a442" integrity sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA== dependencies: safe-buffer "~5.1.1" -cookie@^0.4.0, cookie@^0.4.1: +convert-source-map@^1.7.0: + version "1.9.0" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.9.0.tgz#7faae62353fb4213366d0ca98358d22e8368b05f" + integrity sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A== + +cookie@^0.4.0: + version "0.4.2" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.2.tgz#0e41f24de5ecf317947c82fc789e06a884824432" + integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== + +cookie@^0.4.1: version "0.4.1" resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.1.tgz#afd713fe26ebd21ba95ceb61f9a8116e50a537d1" integrity sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA== -core-js-compat@^3.14.0, core-js-compat@^3.15.0: - version "3.15.1" - resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.15.1.tgz#1afe233716d37ee021956ef097594071b2b585a7" - integrity sha512-xGhzYMX6y7oEGQGAJmP2TmtBLvR4nZmRGEcFa3ubHOq5YEp51gGN9AovVa0AoujGZIq+Wm6dISiYyGNfdflYww== +core-js-compat@^3.25.1: + version "3.30.2" + resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.30.2.tgz#83f136e375babdb8c80ad3c22d67c69098c1dd8b" + integrity sha512-nriW1nuJjUgvkEjIot1Spwakz52V9YkYHZAQG6A1eCgC8AA1p0zngrQEP9R0+V6hji5XilWKG1Bd0YRppmGimA== dependencies: - browserslist "^4.16.6" - semver "7.0.0" + browserslist "^4.21.5" core-js-pure@^3.0.0: version "3.9.1" resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.9.1.tgz#677b322267172bd490e4464696f790cbc355bec5" integrity sha512-laz3Zx0avrw9a4QEIdmIblnVuJz8W51leY9iLThatCsFawWxC3sE4guASC78JbCin+DkwMpCdp1AVAuzL/GN7A== -core-util-is@~1.0.0: - version "1.0.2" - resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" - integrity sha1-tf1UIgqivFq1eqtxQMlAdUUDwac= - cosmiconfig@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-7.0.0.tgz#ef9b44d773959cae63ddecd122de23853b60f8d3" @@ -3192,37 +2991,6 @@ cosmiconfig@^7.0.0: path-type "^4.0.0" yaml "^1.10.0" -create-ecdh@^4.0.0: - version "4.0.4" - resolved "https://registry.yarnpkg.com/create-ecdh/-/create-ecdh-4.0.4.tgz#d6e7f4bffa66736085a0762fd3a632684dabcc4e" - integrity sha512-mf+TCx8wWc9VpuxfP2ht0iSISLZnt0JgWlrOKZiNqyUZWnjIaCIVNQArMHnCZKfEYRg6IM7A+NeJoN8gf/Ws0A== - dependencies: - bn.js "^4.1.0" - elliptic "^6.5.3" - -create-hash@^1.1.0, create-hash@^1.1.2, create-hash@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.2.0.tgz#889078af11a63756bcfb59bd221996be3a9ef196" - integrity sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg== - dependencies: - cipher-base "^1.0.1" - inherits "^2.0.1" - md5.js "^1.3.4" - ripemd160 "^2.0.1" - sha.js "^2.4.0" - -create-hmac@^1.1.0, create-hmac@^1.1.4, create-hmac@^1.1.7: - version "1.1.7" - resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.7.tgz#69170c78b3ab957147b2b8b04572e47ead2243ff" - integrity sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg== - dependencies: - cipher-base "^1.0.3" - create-hash "^1.1.0" - inherits "^2.0.1" - ripemd160 "^2.0.0" - safe-buffer "^5.0.1" - sha.js "^2.4.8" - cross-spawn@^7.0.2, cross-spawn@^7.0.3: version "7.0.3" resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" @@ -3232,23 +3000,6 @@ cross-spawn@^7.0.2, cross-spawn@^7.0.3: shebang-command "^2.0.0" which "^2.0.1" -crypto-browserify@3.12.0, crypto-browserify@^3.11.0: - version "3.12.0" - resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz#396cf9f3137f03e4b8e532c58f698254e00f80ec" - integrity sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg== - dependencies: - browserify-cipher "^1.0.0" - browserify-sign "^4.0.0" - create-ecdh "^4.0.0" - create-hash "^1.1.0" - create-hmac "^1.1.0" - diffie-hellman "^5.0.0" - inherits "^2.0.1" - pbkdf2 "^3.0.3" - public-encrypt "^4.0.0" - randombytes "^2.0.0" - randomfill "^1.0.3" - crypto-random-string@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-2.0.0.tgz#ef2a7a966ec11083388369baa02ebead229b30d5" @@ -3259,14 +3010,14 @@ css-color-keywords@^1.0.0: resolved "https://registry.yarnpkg.com/css-color-keywords/-/css-color-keywords-1.0.0.tgz#fea2616dc676b2962686b3af8dbdbe180b244e05" integrity sha1-/qJhbcZ2spYmhrOvjb2+GAskTgU= -css-jss@10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/css-jss/-/css-jss-10.6.0.tgz#db5de90a4b53ca05d7e1c6bcec0c1ba8f1c1bcea" - integrity sha512-4SE0tWggVM6Y4UTcKMoZXFBuhzycY6fKEdONr7wn89SIFd4eXiUZ0f5f4tLwXyFOW2q13JReXp8n9vSLKp48/g== +css-jss@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/css-jss/-/css-jss-10.10.0.tgz#bd51fbd255cc24597ac0f0f32368394794d37ef3" + integrity sha512-YyMIS/LsSKEGXEaVJdjonWe18p4vXLo8CMA4FrW/kcaEyqdIGKCFXao31gbJddXEdIxSXFFURWrenBJPlKTgAA== dependencies: "@babel/runtime" "^7.3.1" - jss "10.6.0" - jss-preset-default "10.6.0" + jss "^10.10.0" + jss-preset-default "^10.10.0" css-to-react-native@^3.0.0: version "3.0.0" @@ -3285,30 +3036,11 @@ css-vendor@^2.0.8: "@babel/runtime" "^7.8.3" is-in-browser "^1.0.2" -css.escape@1.5.1: - version "1.5.1" - resolved "https://registry.yarnpkg.com/css.escape/-/css.escape-1.5.1.tgz#42e27d4fa04ae32f931a4b4d4191fa9cddee97cb" - integrity sha1-QuJ9T6BK4y+TGktNQZH6nN3ul8s= - csscolorparser@~1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/csscolorparser/-/csscolorparser-1.0.3.tgz#b34f391eea4da8f3e98231e2ccd8df9c041f171b" integrity sha1-s085HupNqPPpgjHizNjfnAQfFxs= -cssnano-preset-simple@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/cssnano-preset-simple/-/cssnano-preset-simple-2.0.0.tgz#b55e72cb970713f425560a0e141b0335249e2f96" - integrity sha512-HkufSLkaBJbKBFx/7aj5HmCK9Ni/JedRQm0mT2qBzMG/dEuJOLnMt2lK6K1rwOOyV4j9aSY+knbW9WoS7BYpzg== - dependencies: - caniuse-lite "^1.0.30001202" - -cssnano-simple@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/cssnano-simple/-/cssnano-simple-2.0.0.tgz#930d9dcd8ba105c5a62ce719cb00854da58b5c05" - integrity sha512-0G3TXaFxlh/szPEG/o3VcmCwl0N3E60XNb9YZZijew5eIs6fLjJuOPxQd9yEBaX2p/YfJtt49i4vYi38iH6/6w== - dependencies: - cssnano-preset-simple "^2.0.0" - cssom@^0.4.4: version "0.4.4" resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.4.4.tgz#5a66cf93d2d0b661d80bf6a44fb65f5c2e4e0a10" @@ -3332,20 +3064,15 @@ csstype@^2.5.2: integrity sha512-61FBWoDHp/gRtsoDkq/B1nWrCUG/ok1E3tUrcNbZjsE9Cxd9yzUirjS3+nAATB8U4cTtaQmAHbNndoFz5L6C9Q== csstype@^3.0.2: - version "3.0.7" - resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.0.7.tgz#2a5fb75e1015e84dd15692f71e89a1450290950b" - integrity sha512-KxnUB0ZMlnUWCsx2Z8MUsr6qV6ja1w9ArPErJaJaF8a5SOWoHLIszeCTKGRGRgtLgYrs1E8CHkNSP1VZTTPc9g== + version "3.1.2" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.1.2.tgz#1d4bf9d572f11c14031f0436e1c10bc1f571f50b" + integrity sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ== damerau-levenshtein@^1.0.6: version "1.0.6" resolved "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.6.tgz#143c1641cb3d85c60c32329e26899adea8701791" integrity sha512-JVrozIeElnj3QzfUIt8tB8YMluBJom4Vw9qTPpjGYQ9fYlB3D/rb6OordUxf3xeFB35LKWs0xqcO5U6ySvBtug== -data-uri-to-buffer@3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz#594b8973938c5bc2c33046535785341abc4f3636" - integrity sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og== - data-urls@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/data-urls/-/data-urls-2.0.0.tgz#156485a72963a970f5d5821aaf642bef2bf2db9b" @@ -3355,20 +3082,20 @@ data-urls@^2.0.0: whatwg-mimetype "^2.3.0" whatwg-url "^8.0.0" -debug@2, debug@^2.6.9: - version "2.6.9" - resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== - dependencies: - ms "2.0.0" - -debug@4, debug@^4.0.1, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1: +debug@4, debug@^4.0.1, debug@^4.3.1: version "4.3.1" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.1.tgz#f0d229c505e0c6d8c49ac553d1b13dc183f6b2ee" integrity sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ== dependencies: ms "2.1.2" +debug@^2.6.9: + version "2.6.9" + resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + debug@^3.2.7: version "3.2.7" resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" @@ -3376,6 +3103,13 @@ debug@^3.2.7: dependencies: ms "^2.1.1" +debug@^4.1.0, debug@^4.1.1: + version "4.3.4" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== + dependencies: + ms "2.1.2" + decimal.js@^10.2.1: version "10.2.1" resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.2.1.tgz#238ae7b0f0c793d3e3cea410108b35a2c01426a3" @@ -3392,16 +3126,17 @@ deep-is@^0.1.3, deep-is@~0.1.3: integrity sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ= deepmerge@^4.2.2: - version "4.2.2" - resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.2.2.tgz#44d2ea3679b8f4d4ffba33f03d865fc1e7bf4955" - integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== + version "4.3.1" + resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.3.1.tgz#44b5f2147cd3b00d4b56137685966f26fd25dd4a" + integrity sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A== -define-properties@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.3.tgz#cf88da6cbee26fe6db7094f61d870cbd84cee9f1" - integrity sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ== +define-properties@^1.1.3, define-properties@^1.1.4, define-properties@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.2.0.tgz#52988570670c9eacedd8064f4a990f2405849bd5" + integrity sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA== dependencies: - object-keys "^1.0.12" + has-property-descriptors "^1.0.0" + object-keys "^1.1.1" del@^4.1.1: version "4.1.1" @@ -3421,19 +3156,6 @@ delayed-stream@~1.0.0: resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk= -depd@~1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" - integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= - -des.js@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/des.js/-/des.js-1.0.1.tgz#5382142e1bdc53f85d86d53e5f4aa7deb91e0843" - integrity sha512-Q0I4pfFrv2VPd34/vfLrFOoRmlYj3OV50i7fskps1jZWK1kApMWWT9G6RRUeYedLcBDIhnSDaUvJMb3AhUlaEA== - dependencies: - inherits "^2.0.1" - minimalistic-assert "^1.0.0" - detect-newline@^3.0.0: version "3.1.0" resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651" @@ -3454,15 +3176,6 @@ diff-sequences@^27.0.1: resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-27.0.1.tgz#9c9801d52ed5f576ff0a20e3022a13ee6e297e7c" integrity sha512-XPLijkfJUh/PIBnfkcSHgvD6tlYixmcMAn3osTk6jt+H0v/mgURto1XUiD9DKuGX5NDoVS6dSlA23gd9FUaCFg== -diffie-hellman@^5.0.0: - version "5.0.3" - resolved "https://registry.yarnpkg.com/diffie-hellman/-/diffie-hellman-5.0.3.tgz#40e8ee98f55a2149607146921c63e1ae5f3d2875" - integrity sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg== - dependencies: - bn.js "^4.1.0" - miller-rabin "^4.0.0" - randombytes "^2.0.0" - dir-glob@^3.0.1: version "3.0.1" resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" @@ -3487,7 +3200,7 @@ doctrine@^3.0.0: dom-css@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/dom-css/-/dom-css-2.1.0.tgz#fdbc2d5a015d0a3e1872e11472bbd0e7b9e6a202" - integrity sha1-/bwtWgFdCj4YcuEUcrvQ57nmogI= + integrity sha512-w9kU7FAbaSh3QKijL6n59ofAhkkmMJ31GclJIz/vyQdjogfyxcB6Zf8CZyibOERI5o0Hxz30VmJS7+7r5fEj2Q== dependencies: add-px-to-style "1.0.0" prefix-style "2.0.1" @@ -3501,16 +3214,6 @@ dom-helpers@^5.0.1: "@babel/runtime" "^7.8.7" csstype "^3.0.2" -domain-browser@4.19.0: - version "4.19.0" - resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-4.19.0.tgz#1093e17c0a17dbd521182fe90d49ac1370054af1" - integrity sha512-fRA+BaAWOR/yr/t7T9E9GJztHPeFjj8U35ajyAjCDtAAnTn1Rc1f6W6VGPJrO1tkQv9zWu+JRof7z6oQtiYVFQ== - -domain-browser@^1.1.1: - version "1.2.0" - resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-1.2.0.tgz#3d31f50191a6749dd1375a7f522e823d42e54eda" - integrity sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA== - domexception@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/domexception/-/domexception-2.0.1.tgz#fb44aefba793e1574b0af6aed2801d057529f304" @@ -3523,33 +3226,22 @@ earcut@^2.2.2: resolved "https://registry.yarnpkg.com/earcut/-/earcut-2.2.2.tgz#41b0bc35f63e0fe80da7cddff28511e7e2e80d11" integrity sha512-eZoZPPJcUHnfRZ0PjLvx2qBordSiO8ofC3vt+qACLM95u+4DovnbYNpQtJh0DNsWj8RnxrQytD4WA8gj5cRIaQ== -ejs@^2.6.1: - version "2.7.4" - resolved "https://registry.yarnpkg.com/ejs/-/ejs-2.7.4.tgz#48661287573dcc53e366c7a1ae52c3a120eec9ba" - integrity sha512-7vmuyh5+kuUyJKePhQfRQBhXV5Ce+RnaeeQArKu1EAMpL3WbgMt5WG6uQZpEVvYSSsxMXRKOewtDk9RaTKXRlA== +ejs@^3.1.6: + version "3.1.9" + resolved "https://registry.yarnpkg.com/ejs/-/ejs-3.1.9.tgz#03c9e8777fe12686a9effcef22303ca3d8eeb361" + integrity sha512-rC+QVNMJWv+MtPgkt0y+0rVEIdbtxVADApW9JXrUVlzHetgcyczP/E7DJmWJ4fJCZF2cPcBk0laWO9ZHMG3DmQ== + dependencies: + jake "^10.8.5" electron-to-chromium@^1.3.649: version "1.3.688" resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.688.tgz#0ba54a3e77fca6561a337e6cca959b75db8683b0" integrity sha512-tbKinYX7BomVBcWHzwGolzv3kqCdk/vQ36ao3MC8tQMXqs1ZpevYU2RTr7+hkDvGWtoQbe+nvvl+GfMFmRna/A== -electron-to-chromium@^1.3.723: - version "1.3.748" - resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.748.tgz#16638a8130f407ae5bf2fc168f2173574deb36c5" - integrity sha512-fmIKfYALVeEybk/L2ucdgt7jN3JsbGtg3K9pmF/MRWgkeADBI1VSAa5IzdG2gZwTxsnsrFtdMpOTSM5mrBRKVQ== - -elliptic@^6.5.3: - version "6.5.4" - resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.4.tgz#da37cebd31e79a1367e941b592ed1fbebd58abbb" - integrity sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ== - dependencies: - bn.js "^4.11.9" - brorand "^1.1.0" - hash.js "^1.0.0" - hmac-drbg "^1.0.1" - inherits "^2.0.4" - minimalistic-assert "^1.0.1" - minimalistic-crypto-utils "^1.0.1" +electron-to-chromium@^1.4.284: + version "1.4.402" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.402.tgz#9aa7bbb63081513127870af6d22f829344c5ba57" + integrity sha512-gWYvJSkohOiBE6ecVYXkrDgNaUjo47QEKK0kQzmWyhkH+yoYiG44bwuicTGNSIQRG3WDMsWVZJLRnJnLNkbWvA== emittery@^0.8.1: version "0.8.1" @@ -3569,20 +3261,13 @@ emoji-regex@^9.0.0: emojis-list@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-2.1.0.tgz#4daa4d9db00f9819880c79fa457ae5b09a1fd389" - integrity sha1-TapNnbAPmBmIDHn6RXrlsJof04k= + integrity sha512-knHEZMgs8BB+MInokmNTg/OyPlAddghe1YBgNwJBc5zsJi/uyIcXoSDsL/W9ymOsBoBGdPIHXYJ9+qKFwRwDng== emojis-list@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-3.0.0.tgz#5570662046ad29e2e916e71aae260abdff4f6a78" integrity sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q== -encoding@0.1.13: - version "0.1.13" - resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" - integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== - dependencies: - iconv-lite "^0.6.2" - enquirer@^2.3.5, enquirer@^2.3.6: version "2.3.6" resolved "https://registry.yarnpkg.com/enquirer/-/enquirer-2.3.6.tgz#2a7fe5dd634a1e4125a975ec994ff5456dc3734d" @@ -3597,27 +3282,45 @@ error-ex@^1.3.1: dependencies: is-arrayish "^0.2.1" -es-abstract@^1.18.0-next.1, es-abstract@^1.18.0-next.2: - version "1.18.0" - resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.18.0.tgz#ab80b359eecb7ede4c298000390bc5ac3ec7b5a4" - integrity sha512-LJzK7MrQa8TS0ja2w3YNLzUgJCGPdPOV1yVvezjNnS89D+VR08+Szt2mz3YB2Dck/+w5tfIq/RoUAFqJJGM2yw== +es-abstract@^1.18.0-next.1, es-abstract@^1.18.0-next.2, es-abstract@^1.19.0, es-abstract@^1.20.4: + version "1.21.2" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.21.2.tgz#a56b9695322c8a185dc25975aa3b8ec31d0e7eff" + integrity sha512-y/B5POM2iBnIxCiernH1G7rC9qQoM77lLIMQLuob0zhp8C56Po81+2Nj0WFKnd0pNReDTnkYryc+zhOzpEIROg== dependencies: + array-buffer-byte-length "^1.0.0" + available-typed-arrays "^1.0.5" call-bind "^1.0.2" + es-set-tostringtag "^2.0.1" es-to-primitive "^1.2.1" - function-bind "^1.1.1" - get-intrinsic "^1.1.1" + function.prototype.name "^1.1.5" + get-intrinsic "^1.2.0" + get-symbol-description "^1.0.0" + globalthis "^1.0.3" + gopd "^1.0.1" has "^1.0.3" - has-symbols "^1.0.2" - is-callable "^1.2.3" - is-negative-zero "^2.0.1" - is-regex "^1.1.2" - is-string "^1.0.5" - object-inspect "^1.9.0" + has-property-descriptors "^1.0.0" + has-proto "^1.0.1" + has-symbols "^1.0.3" + internal-slot "^1.0.5" + is-array-buffer "^3.0.2" + is-callable "^1.2.7" + is-negative-zero "^2.0.2" + is-regex "^1.1.4" + is-shared-array-buffer "^1.0.2" + is-string "^1.0.7" + is-typed-array "^1.1.10" + is-weakref "^1.0.2" + object-inspect "^1.12.3" object-keys "^1.1.1" - object.assign "^4.1.2" - string.prototype.trimend "^1.0.4" - string.prototype.trimstart "^1.0.4" - unbox-primitive "^1.0.0" + object.assign "^4.1.4" + regexp.prototype.flags "^1.4.3" + safe-regex-test "^1.0.0" + string.prototype.trim "^1.2.7" + string.prototype.trimend "^1.0.6" + string.prototype.trimstart "^1.0.6" + typed-array-length "^1.0.4" + unbox-primitive "^1.0.2" + which-typed-array "^1.1.9" es-abstract@^1.18.2: version "1.18.3" @@ -3641,6 +3344,15 @@ es-abstract@^1.18.2: string.prototype.trimstart "^1.0.4" unbox-primitive "^1.0.1" +es-set-tostringtag@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/es-set-tostringtag/-/es-set-tostringtag-2.0.1.tgz#338d502f6f674301d710b80c8592de8a15f09cd8" + integrity sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg== + dependencies: + get-intrinsic "^1.1.3" + has "^1.0.3" + has-tostringtag "^1.0.0" + es-to-primitive@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.2.1.tgz#e55cd4c9cdc188bcefb03b366c736323fc5c898a" @@ -3650,11 +3362,6 @@ es-to-primitive@^1.2.1: is-date-object "^1.0.1" is-symbol "^1.0.2" -es6-object-assign@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/es6-object-assign/-/es6-object-assign-1.1.0.tgz#c2c3582656247c39ea107cb1e6652b6f9f24523c" - integrity sha1-wsNYJlYkfDnqEHyx5mUrb58kUjw= - escalade@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" @@ -3663,7 +3370,7 @@ escalade@^3.1.1: escape-string-regexp@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" - integrity sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ= + integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== escape-string-regexp@^2.0.0: version "2.0.0" @@ -3921,24 +3628,6 @@ esutils@^2.0.2: resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== -etag@1.8.1: - version "1.8.1" - resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" - integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= - -events@^3.0.0: - version "3.3.0" - resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" - integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== - -evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" - integrity sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA== - dependencies: - md5.js "^1.3.4" - safe-buffer "^5.1.1" - execa@^5.0.0: version "5.1.0" resolved "https://registry.yarnpkg.com/execa/-/execa-5.1.0.tgz#3ea50ee863d226bfa323528cce1684e7481dfe46" @@ -3976,17 +3665,16 @@ fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== -fast-glob@^3.1.1: - version "3.2.5" - resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.5.tgz#7939af2a656de79a4f1901903ee8adcaa7cb9661" - integrity sha512-2DtFcgT68wiTTiwZ2hNdJfcHNke9XOfnwmBRWXhmeKM8rF0TGwmC/Qto3S7RoZKp5cilZbxzO5iTNTQsJ+EeDg== +fast-glob@^3.1.1, fast-glob@^3.2.9: + version "3.2.12" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.12.tgz#7f39ec99c2e6ab030337142da9e0c18f37afae80" + integrity sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w== dependencies: "@nodelib/fs.stat" "^2.0.2" "@nodelib/fs.walk" "^1.2.3" - glob-parent "^5.1.0" + glob-parent "^5.1.2" merge2 "^1.3.0" - micromatch "^4.0.2" - picomatch "^2.2.1" + micromatch "^4.0.4" fast-json-stable-stringify@^2.0.0, fast-json-stable-stringify@^2.1.0: version "2.1.0" @@ -3999,9 +3687,9 @@ fast-levenshtein@^2.0.6, fast-levenshtein@~2.0.6: integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc= fastq@^1.6.0: - version "1.11.0" - resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.11.0.tgz#bb9fb955a07130a918eb63c1f5161cc32a5d0858" - integrity sha512-7Eczs8gIPDrVzT+EksYBcupqMyxSHXXrHOLRRxU2/DicV8789MRBRR8+Hc2uWzUupOs4YS4JzBmBxjjCVBxD/g== + version "1.15.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a" + integrity sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw== dependencies: reusify "^1.0.4" @@ -4019,6 +3707,13 @@ file-entry-cache@^6.0.1: dependencies: flat-cache "^3.0.4" +filelist@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/filelist/-/filelist-1.0.4.tgz#f78978a1e944775ff9e62e744424f215e58352b5" + integrity sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q== + dependencies: + minimatch "^5.0.1" + fill-range@^7.0.1: version "7.0.1" resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" @@ -4026,10 +3721,10 @@ fill-range@^7.0.1: dependencies: to-regex-range "^5.0.1" -find-cache-dir@3.3.1, find-cache-dir@^3.3.1: - version "3.3.1" - resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-3.3.1.tgz#89b33fad4a4670daa94f855f7fbe31d6d84fe880" - integrity sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ== +find-cache-dir@^3.3.1: + version "3.3.2" + resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-3.3.2.tgz#b30c5b6eff0730731aea9bbd9dbecbd80256d64b" + integrity sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig== dependencies: commondir "^1.0.1" make-dir "^3.0.2" @@ -4078,10 +3773,12 @@ flatted@^3.1.0: resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.1.1.tgz#c4b489e80096d9df1dfc97c79871aea7c617c469" integrity sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA== -foreach@^2.0.5: - version "2.0.5" - resolved "https://registry.yarnpkg.com/foreach/-/foreach-2.0.5.tgz#0bee005018aeb260d0a3af3ae658dd0136ec1b99" - integrity sha1-C+4AUBiusmDQo6865ljdATbsG5k= +for-each@^0.3.3: + version "0.3.3" + resolved "https://registry.yarnpkg.com/for-each/-/for-each-0.3.3.tgz#69b447e88a0a5d32c3e7084f3f1710034b21376e" + integrity sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw== + dependencies: + is-callable "^1.1.3" form-data@^3.0.0: version "3.0.1" @@ -4105,9 +3802,9 @@ fs-extra@^9.0.1: fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" - integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= + integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== -fsevents@^2.3.2, fsevents@~2.3.1, fsevents@~2.3.2: +fsevents@^2.3.2, fsevents@~2.3.2: version "2.3.2" resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== @@ -4117,11 +3814,26 @@ function-bind@^1.1.1: resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== +function.prototype.name@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/function.prototype.name/-/function.prototype.name-1.1.5.tgz#cce0505fe1ffb80503e6f9e46cc64e46a12a9621" + integrity sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.0" + functions-have-names "^1.2.2" + functional-red-black-tree@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" integrity sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc= +functions-have-names@^1.2.2, functions-have-names@^1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" + integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== + gensync@^1.0.0-beta.2: version "1.0.0-beta.2" resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" @@ -4137,7 +3849,17 @@ get-caller-file@^2.0.5: resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== -get-intrinsic@^1.0.2, get-intrinsic@^1.1.0, get-intrinsic@^1.1.1: +get-intrinsic@^1.0.2, get-intrinsic@^1.1.1, get-intrinsic@^1.1.3, get-intrinsic@^1.2.0: + version "1.2.1" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.1.tgz#d295644fed4505fc9cde952c37ee12b477a83d82" + integrity sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw== + dependencies: + function-bind "^1.1.1" + has "^1.0.3" + has-proto "^1.0.1" + has-symbols "^1.0.3" + +get-intrinsic@^1.1.0: version "1.1.1" resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.1.1.tgz#15f59f376f855c446963948f0d24cd3637b4abc6" integrity sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q== @@ -4146,13 +3868,6 @@ get-intrinsic@^1.0.2, get-intrinsic@^1.1.0, get-intrinsic@^1.1.1: has "^1.0.3" has-symbols "^1.0.1" -get-orientation@1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/get-orientation/-/get-orientation-1.1.2.tgz#20507928951814f8a91ded0a0e67b29dfab98947" - integrity sha512-/pViTfifW+gBbh/RnlFYHINvELT9Znt+SYyDKAUL6uV6By019AK/s+i9XP4jSwq7lwP38Fd8HVeTxym3+hkwmQ== - dependencies: - stream-parser "^0.3.1" - get-own-enumerable-property-symbols@^3.0.0: version "3.0.2" resolved "https://registry.yarnpkg.com/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz#b5fde77f22cbe35f390b4e089922c50bce6ef664" @@ -4168,36 +3883,39 @@ get-stream@^6.0.0: resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== +get-symbol-description@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" + integrity sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.1.1" + gl-matrix@^3.2.1: version "3.3.0" resolved "https://registry.yarnpkg.com/gl-matrix/-/gl-matrix-3.3.0.tgz#232eef60b1c8b30a28cbbe75b2caf6c48fd6358b" integrity sha512-COb7LDz+SXaHtl/h4LeaFcNdJdAQSDeVqjiIihSXNrkWObZLhDI4hIkZC11Aeqp7bcE72clzB0BnDXr2SmslRA== -glob-parent@^5.0.0, glob-parent@^5.1.0, glob-parent@~5.1.0: +glob-parent@^5.0.0, glob-parent@^5.1.2: version "5.1.2" resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== dependencies: is-glob "^4.0.1" -glob-to-regexp@^0.4.1: - version "0.4.1" - resolved "https://registry.yarnpkg.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz#c75297087c851b9a578bd217dd59a92f59fe546e" - integrity sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw== - -glob@^7.0.3, glob@^7.1.6: - version "7.1.7" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.7.tgz#3b193e9233f01d42d0b3f78294bbeeb418f94a90" - integrity sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ== +glob@^7.0.3, glob@^7.1.3, glob@^7.1.6: + version "7.2.3" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" + integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== dependencies: fs.realpath "^1.0.0" inflight "^1.0.4" inherits "2" - minimatch "^3.0.4" + minimatch "^3.1.1" once "^1.3.0" path-is-absolute "^1.0.0" -glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4: +glob@^7.1.1, glob@^7.1.2, glob@^7.1.4: version "7.1.6" resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== @@ -4228,6 +3946,13 @@ globals@^13.6.0: dependencies: type-fest "^0.20.2" +globalthis@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/globalthis/-/globalthis-1.0.3.tgz#5852882a52b80dc301b0660273e1ed082f0b6ccf" + integrity sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA== + dependencies: + define-properties "^1.1.3" + globby@^11.0.1: version "11.0.2" resolved "https://registry.yarnpkg.com/globby/-/globby-11.0.2.tgz#1af538b766a3b540ebfb58a32b2e2d5897321d83" @@ -4240,22 +3965,22 @@ globby@^11.0.1: merge2 "^1.3.0" slash "^3.0.0" -globby@^11.0.3: - version "11.0.3" - resolved "https://registry.yarnpkg.com/globby/-/globby-11.0.3.tgz#9b1f0cb523e171dd1ad8c7b2a9fb4b644b9593cb" - integrity sha512-ffdmosjA807y7+lA1NM0jELARVmYul/715xiILEjo3hBLPTcirgQNnXECn5g3mtR8TOLCVbkfua1Hpen25/Xcg== +globby@^11.0.3, globby@^11.0.4: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== dependencies: array-union "^2.1.0" dir-glob "^3.0.1" - fast-glob "^3.1.1" - ignore "^5.1.4" - merge2 "^1.3.0" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" slash "^3.0.0" globby@^6.1.0: version "6.1.0" resolved "https://registry.yarnpkg.com/globby/-/globby-6.1.0.tgz#f5a6d70e8395e21c858fb0489d64df02424d506c" - integrity sha1-9abXDoOV4hyFj7BInWTfAkJNUGw= + integrity sha512-KVbFv2TQtbzCoxAnfD6JcHZTYCzyliEaaeM/gH8qQdkKr5s0OP9scEgvdcngyk7AVdY6YVW/TJHd+lQ/Df3Daw== dependencies: array-union "^1.0.1" glob "^7.0.3" @@ -4263,7 +3988,19 @@ globby@^6.1.0: pify "^2.0.0" pinkie-promise "^2.0.0" -graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4: +gopd@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/gopd/-/gopd-1.0.1.tgz#29ff76de69dac7489b7c0918a5788e56477c332c" + integrity sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA== + dependencies: + get-intrinsic "^1.1.3" + +graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0: + version "4.2.11" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3" + integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== + +graceful-fs@^4.2.4: version "4.2.6" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.6.tgz#ff040b2b0853b23c3d31027523706f1885d76bee" integrity sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ== @@ -4273,25 +4010,49 @@ grid-index@^1.1.0: resolved "https://registry.yarnpkg.com/grid-index/-/grid-index-1.1.0.tgz#97f8221edec1026c8377b86446a7c71e79522ea7" integrity sha512-HZRwumpOGUrHyxO5bqKZL0B0GlUpwtCAzZ42sgxUPniu33R1LSFH5yrIcBCHjkctCAh3mtWKcKd9J4vDDdeVHA== -has-bigints@^1.0.0, has-bigints@^1.0.1: +has-bigints@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.1.tgz#64fe6acb020673e3b78db035a5af69aa9d07b113" integrity sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA== +has-bigints@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.2.tgz#0871bd3e3d51626f6ca0966668ba35d5602d6eaa" + integrity sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ== + has-flag@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" - integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= + integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== has-flag@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== -has-symbols@^1.0.0, has-symbols@^1.0.1, has-symbols@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.2.tgz#165d3070c00309752a1236a479331e3ac56f1423" - integrity sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw== +has-property-descriptors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz#610708600606d36961ed04c196193b6a607fa861" + integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== + dependencies: + get-intrinsic "^1.1.1" + +has-proto@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/has-proto/-/has-proto-1.0.1.tgz#1885c1305538958aff469fef37937c22795408e0" + integrity sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg== + +has-symbols@^1.0.1, has-symbols@^1.0.2, has-symbols@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" + integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== + +has-tostringtag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz#7e133818a7d394734f941e73c3d3f9291e658b25" + integrity sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ== + dependencies: + has-symbols "^1.0.2" has@^1.0.3: version "1.0.3" @@ -4300,37 +4061,6 @@ has@^1.0.3: dependencies: function-bind "^1.1.1" -hash-base@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.1.0.tgz#55c381d9e06e1d2997a883b4a3fddfe7f0d3af33" - integrity sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA== - dependencies: - inherits "^2.0.4" - readable-stream "^3.6.0" - safe-buffer "^5.2.0" - -hash.js@^1.0.0, hash.js@^1.0.3: - version "1.1.7" - resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.7.tgz#0babca538e8d4ee4a0f8988d68866537a003cf42" - integrity sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA== - dependencies: - inherits "^2.0.3" - minimalistic-assert "^1.0.1" - -he@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" - integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== - -hmac-drbg@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" - integrity sha1-0nRXAQJabHdabFRXk+1QL8DGSaE= - dependencies: - hash.js "^1.0.3" - minimalistic-assert "^1.0.0" - minimalistic-crypto-utils "^1.0.1" - hoist-non-react-statics@^3.0.0, hoist-non-react-statics@^3.2.0, hoist-non-react-statics@^3.3.0, hoist-non-react-statics@^3.3.2: version "3.3.2" resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" @@ -4355,17 +4085,6 @@ html-escaper@^2.0.0: resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== -http-errors@1.7.3: - version "1.7.3" - resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06" - integrity sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw== - dependencies: - depd "~1.1.2" - inherits "2.0.4" - setprototypeof "1.1.1" - statuses ">= 1.5.0 < 2" - toidentifier "1.0.0" - http-proxy-agent@^4.0.1: version "4.0.1" resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz#8a8c8ef7f5932ccf953c296ca8291b95aa74aa3a" @@ -4375,11 +4094,6 @@ http-proxy-agent@^4.0.1: agent-base "6" debug "4" -https-browserify@1.0.0, https-browserify@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73" - integrity sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM= - https-proxy-agent@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz#e2a90542abb68a762e0a0850f6c9edadfd8506b2" @@ -4421,14 +4135,12 @@ iconv-lite@0.4.24: dependencies: safer-buffer ">= 2.1.2 < 3" -iconv-lite@^0.6.2: - version "0.6.2" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.2.tgz#ce13d1875b0c3a674bd6a04b7f76b01b1b6ded01" - integrity sha512-2y91h5OpQlolefMPmUlivelittSWy0rP+oYVpn6A7GwVHNE8AWzoYOBNmlwks3LobaJxgHCYZAnyNo2GgpNRNQ== - dependencies: - safer-buffer ">= 2.1.2 < 3.0.0" +idb@^7.0.1: + version "7.1.1" + resolved "https://registry.yarnpkg.com/idb/-/idb-7.1.1.tgz#d910ded866d32c7ced9befc5bfdf36f572ced72b" + integrity sha512-gchesWBzyvGHRO9W8tzUWFDycow5gwjvFKfyV9FF32Y7F50yZMp7mP+T2mJIWFx49zicqyC4uefHM17o6xKIVQ== -ieee754@^1.1.12, ieee754@^1.1.4: +ieee754@^1.1.12: version "1.2.1" resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== @@ -4438,10 +4150,10 @@ ignore@^4.0.6: resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== -ignore@^5.1.4: - version "5.1.8" - resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.1.8.tgz#f150a8b50a34289b33e22f5889abd4d8016f0e57" - integrity sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw== +ignore@^5.1.4, ignore@^5.2.0: + version "5.2.4" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.4.tgz#a291c0c6178ff1b960befe47fcdec301674a6324" + integrity sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ== import-fresh@^3.0.0, import-fresh@^3.2.1: version "3.3.0" @@ -4479,26 +4191,16 @@ indent-string@^4.0.0: inflight@^1.0.4: version "1.0.6" resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" - integrity sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk= + integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== dependencies: once "^1.3.0" wrappy "1" -inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.1, inherits@~2.0.3, inherits@~2.0.4: +inherits@2, inherits@^2.0.3: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== -inherits@2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.1.tgz#b17d08d326b4423e568eff719f91b0b1cbdf69f1" - integrity sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE= - -inherits@2.0.3: - version "2.0.3" - resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" - integrity sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4= - internal-slot@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.3.tgz#7347e307deeea2faac2ac6205d4bc7d34967f59c" @@ -4508,12 +4210,23 @@ internal-slot@^1.0.3: has "^1.0.3" side-channel "^1.0.4" -is-arguments@^1.0.4: - version "1.1.0" - resolved "https://registry.yarnpkg.com/is-arguments/-/is-arguments-1.1.0.tgz#62353031dfbee07ceb34656a6bde59efecae8dd9" - integrity sha512-1Ij4lOMPl/xB5kBDn7I+b2ttPMKa8szhEIrXDuXQD/oe3HJLTLhqhgGspwgyGd6MOywBUqVvYicF72lkgDnIHg== +internal-slot@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.5.tgz#f2a2ee21f668f8627a4667f309dc0f4fb6674986" + integrity sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ== dependencies: - call-bind "^1.0.0" + get-intrinsic "^1.2.0" + has "^1.0.3" + side-channel "^1.0.4" + +is-array-buffer@^3.0.1, is-array-buffer@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/is-array-buffer/-/is-array-buffer-3.0.2.tgz#f2653ced8412081638ecb0ebbd0c41c6e0aecbbe" + integrity sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.2.0" + is-typed-array "^1.1.10" is-arrayish@^0.2.1: version "0.2.1" @@ -4521,28 +4234,24 @@ is-arrayish@^0.2.1: integrity sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0= is-bigint@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-bigint/-/is-bigint-1.0.1.tgz#6923051dfcbc764278540b9ce0e6b3213aa5ebc2" - integrity sha512-J0ELF4yHFxHy0cmSxZuheDOz2luOdVvqjwmEcj8H/L1JHeuEDSDbeRP+Dk9kFVk5RTFzbucJ2Kb9F7ixY2QaCg== - -is-binary-path@~2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" - integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-bigint/-/is-bigint-1.0.4.tgz#08147a1875bc2b32005d41ccd8291dffc6691df3" + integrity sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg== dependencies: - binary-extensions "^2.0.0" + has-bigints "^1.0.1" is-boolean-object@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/is-boolean-object/-/is-boolean-object-1.1.0.tgz#e2aaad3a3a8fca34c28f6eee135b156ed2587ff0" - integrity sha512-a7Uprx8UtD+HWdyYwnD1+ExtTgqQtD2k/1yJgtXP6wnMm8byhkoTZRl+95LLThpzNZJ5aEvi46cdH+ayMFRwmA== + version "1.1.2" + resolved "https://registry.yarnpkg.com/is-boolean-object/-/is-boolean-object-1.1.2.tgz#5c6dc200246dd9321ae4b885a114bb1f75f63719" + integrity sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA== dependencies: - call-bind "^1.0.0" + call-bind "^1.0.2" + has-tostringtag "^1.0.0" -is-callable@^1.1.4, is-callable@^1.2.3: - version "1.2.3" - resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.3.tgz#8b1e0500b73a1d76c70487636f368e519de8db8e" - integrity sha512-J1DcMe8UYTBSrKezuIUTUwjXsho29693unXM2YhJUTR2txK/eG47bvNa/wipPFmZFgr/N6f1GA66dv0mEyTIyQ== +is-callable@^1.1.3, is-callable@^1.1.4, is-callable@^1.2.3, is-callable@^1.2.7: + version "1.2.7" + resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.7.tgz#3bc2a85ea742d9e36205dcacdd72ca1fdc51b055" + integrity sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA== is-ci@^3.0.0: version "3.0.0" @@ -4551,10 +4260,10 @@ is-ci@^3.0.0: dependencies: ci-info "^3.1.1" -is-core-module@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.2.0.tgz#97037ef3d52224d85163f5597b2b63d9afed981a" - integrity sha512-XRAfAdyyY5F5cOXn7hYQDqh2Xmii+DEfIcQGxK/uNwMHhIkPWO0g8msXcbzLe+MpGoR951MlqM/2iIlU4vKDdQ== +is-core-module@^2.11.0, is-core-module@^2.2.0: + version "2.12.1" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.12.1.tgz#0c0b6885b6f80011c71541ce15c8d66cf5a4f9fd" + integrity sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg== dependencies: has "^1.0.3" @@ -4566,14 +4275,16 @@ is-core-module@^2.4.0: has "^1.0.3" is-date-object@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.2.tgz#bda736f2cd8fd06d32844e7743bfa7494c3bfd7e" - integrity sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g== + version "1.0.5" + resolved "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.5.tgz#0841d5536e724c25597bf6ea62e1bd38298df31f" + integrity sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ== + dependencies: + has-tostringtag "^1.0.0" is-extglob@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" - integrity sha1-qIwCU1eR8C7TfHahueqXc8gz+MI= + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== is-fullwidth-code-point@^3.0.0: version "3.0.0" @@ -4585,45 +4296,41 @@ is-generator-fn@^2.0.0: resolved "https://registry.yarnpkg.com/is-generator-fn/-/is-generator-fn-2.1.0.tgz#7d140adc389aaf3011a8f2a2a4cfa6faadffb118" integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== -is-generator-function@^1.0.7: - version "1.0.9" - resolved "https://registry.yarnpkg.com/is-generator-function/-/is-generator-function-1.0.9.tgz#e5f82c2323673e7fcad3d12858c83c4039f6399c" - integrity sha512-ZJ34p1uvIfptHCN7sFTjGibB9/oBg17sHqzDLfuwhvmN/qLVvIQXRQ8licZQ35WJ8KuEQt/etnnzQFI9C9Ue/A== - -is-glob@^4.0.0, is-glob@^4.0.1, is-glob@~4.0.1: +is-glob@^4.0.0: version "4.0.1" resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== dependencies: is-extglob "^2.1.1" +is-glob@^4.0.1: + version "4.0.3" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + is-in-browser@^1.0.2, is-in-browser@^1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/is-in-browser/-/is-in-browser-1.1.3.tgz#56ff4db683a078c6082eb95dad7dc62e1d04f835" - integrity sha1-Vv9NtoOgeMYILrldrX3GLh0E+DU= + integrity sha512-FeXIBgG/CPGd/WUxuEyvgGTEfwiG9Z4EKGxjNMRqviiIIfsmgrpnHLffEDdwUHqNva1VEW91o3xBT/m8Elgl9g== is-module@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/is-module/-/is-module-1.0.0.tgz#3258fb69f78c14d5b815d664336b4cffb6441591" - integrity sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE= - -is-nan@^1.2.1: - version "1.3.2" - resolved "https://registry.yarnpkg.com/is-nan/-/is-nan-1.3.2.tgz#043a54adea31748b55b6cd4e09aadafa69bd9e1d" - integrity sha512-E+zBKpQ2t6MEo1VsonYmluk9NxGrbzpeeLC2xIViuO2EjU2xsXsBPwTr3Ykv9l08UYEVEdWeRZNouaZqF6RN0w== - dependencies: - call-bind "^1.0.0" - define-properties "^1.1.3" + integrity sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g== -is-negative-zero@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.1.tgz#3de746c18dda2319241a53675908d8f766f11c24" - integrity sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w== +is-negative-zero@^2.0.1, is-negative-zero@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.2.tgz#7bf6f03a28003b8b3965de3ac26f664d765f3150" + integrity sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA== is-number-object@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.4.tgz#36ac95e741cf18b283fc1ddf5e83da798e3ec197" - integrity sha512-zohwelOAur+5uXtk8O3GPQ1eAcu4ZX3UwxQhUlfFFMNpUd83gXgjbhJh6HmB6LUNV/ieOLQuDwJO3dWJosUeMw== + version "1.0.7" + resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.7.tgz#59d50ada4c45251784e9904f5246c742f07a42fc" + integrity sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ== + dependencies: + has-tostringtag "^1.0.0" is-number@^7.0.0: version "7.0.0" @@ -4633,7 +4340,7 @@ is-number@^7.0.0: is-obj@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz#3e4729ac1f5fde025cd7d83a896dab9f4f67db0f" - integrity sha1-PkcprB9f3gJc19g6iW2rn09n2w8= + integrity sha512-l4RyHgRqGN4Y3+9JHVrNqO+tN0rV5My76uW5/nuO4K1b6vw5G8d/cmFjP9tRfEsdhZNt0IFdZuK/c2Vr4Nb+Qg== is-path-cwd@^2.0.0: version "2.2.0" @@ -4659,14 +4366,6 @@ is-potential-custom-element-name@^1.0.1: resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5" integrity sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ== -is-regex@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.2.tgz#81c8ebde4db142f2cf1c53fc86d6a45788266251" - integrity sha512-axvdhb5pdhEVThqJzYXwMlVuZwC+FF2DpcOhTS+y/8jVq4trxyPgfcwIxIKiyeuLlSQYKkmUaPQJ8ZE4yNKXDg== - dependencies: - call-bind "^1.0.2" - has-symbols "^1.0.1" - is-regex@^1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.3.tgz#d029f9aff6448b93ebbe3f33dac71511fdcbef9f" @@ -4675,20 +4374,37 @@ is-regex@^1.1.3: call-bind "^1.0.2" has-symbols "^1.0.2" +is-regex@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.4.tgz#eef5663cd59fa4c0ae339505323df6854bb15958" + integrity sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg== + dependencies: + call-bind "^1.0.2" + has-tostringtag "^1.0.0" + is-regexp@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/is-regexp/-/is-regexp-1.0.0.tgz#fd2d883545c46bac5a633e7b9a09e87fa2cb5069" - integrity sha1-/S2INUXEa6xaYz57mgnof6LLUGk= + integrity sha512-7zjFAPO4/gwyQAAgRRmqeEeyIICSdmCqa3tsVHMdBzaXXRiqopZL4Cyghg/XulGWrtABTpbnYYzzIRffLkP4oA== + +is-shared-array-buffer@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz#8f259c573b60b6a32d4058a1a07430c0a7344c79" + integrity sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA== + dependencies: + call-bind "^1.0.2" is-stream@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.0.tgz#bde9c32680d6fae04129d6ac9d921ce7815f78e3" - integrity sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw== + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" + integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== -is-string@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.5.tgz#40493ed198ef3ff477b8c7f92f644ec82a5cd3a6" - integrity sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ== +is-string@^1.0.5, is-string@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.7.tgz#0dd12bf2006f255bb58f695110eff7491eebc0fd" + integrity sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg== + dependencies: + has-tostringtag "^1.0.0" is-string@^1.0.6: version "1.0.6" @@ -4696,22 +4412,22 @@ is-string@^1.0.6: integrity sha512-2gdzbKUuqtQ3lYNrUTQYoClPhm7oQu4UdpSZMp1/DGgkHBT8E2Z1l0yMdb6D4zNAxwDiMv8MdulKROJGNl0Q0w== is-symbol@^1.0.2, is-symbol@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.3.tgz#38e1014b9e6329be0de9d24a414fd7441ec61937" - integrity sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ== + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.4.tgz#a6dac93b635b063ca6872236de88910a57af139c" + integrity sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg== dependencies: - has-symbols "^1.0.1" + has-symbols "^1.0.2" -is-typed-array@^1.1.3: - version "1.1.5" - resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.5.tgz#f32e6e096455e329eb7b423862456aa213f0eb4e" - integrity sha512-S+GRDgJlR3PyEbsX/Fobd9cqpZBuvUS+8asRqYDMLCb2qMzt1oz5m5oxQCxOgUDxiWsOVNi4yaF+/uvdlHlYug== +is-typed-array@^1.1.10, is-typed-array@^1.1.9: + version "1.1.10" + resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.10.tgz#36a5b5cb4189b575d1a3e4b08536bfb485801e3f" + integrity sha512-PJqgEHiWZvMpaFZ3uTc8kHPM4+4ADTlDniuQL7cU/UDA0Ql7F70yGfHph3cLNe+c9toaigv+DFzTJKhc2CtO6A== dependencies: - available-typed-arrays "^1.0.2" + available-typed-arrays "^1.0.5" call-bind "^1.0.2" - es-abstract "^1.18.0-next.2" - foreach "^2.0.5" - has-symbols "^1.0.1" + for-each "^0.3.3" + gopd "^1.0.1" + has-tostringtag "^1.0.0" is-typedarray@^1.0.0: version "1.0.0" @@ -4723,10 +4439,12 @@ is-unicode-supported@^0.1.0: resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== -isarray@^1.0.0, isarray@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" - integrity sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE= +is-weakref@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" + integrity sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ== + dependencies: + call-bind "^1.0.2" isexe@^2.0.0: version "2.0.0" @@ -4790,6 +4508,16 @@ istanbul-reports@^3.0.2: html-escaper "^2.0.0" istanbul-lib-report "^3.0.0" +jake@^10.8.5: + version "10.8.6" + resolved "https://registry.yarnpkg.com/jake/-/jake-10.8.6.tgz#227a96786a1e035214e0ba84b482d6223d41ef04" + integrity sha512-G43Ub9IYEFfu72sua6rzooi8V8Gz2lkfk48rW20vEWCGizeaEPlKB1Kh8JIA84yQbiAEfqlPmSpGgCKKxH3rDA== + dependencies: + async "^3.2.3" + chalk "^4.0.2" + filelist "^1.0.4" + minimatch "^3.1.2" + jest-changed-files@^27.0.2: version "27.0.2" resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-27.0.2.tgz#997253042b4a032950fc5f56abf3c5d1f8560801" @@ -5196,15 +4924,6 @@ jest-watcher@^27.0.2: jest-util "^27.0.2" string-length "^4.0.1" -jest-worker@27.0.0-next.5: - version "27.0.0-next.5" - resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.0.0-next.5.tgz#5985ee29b12a4e191f4aae4bb73b97971d86ec28" - integrity sha512-mk0umAQ5lT+CaOJ+Qp01N6kz48sJG2kr2n1rX0koqKf6FIygQV0qLOdN9SCYID4IVeSigDOcPeGLozdMLYfb5g== - dependencies: - "@types/node" "*" - merge-stream "^2.0.0" - supports-color "^8.0.0" - jest-worker@^26.2.1: version "26.6.2" resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-26.6.2.tgz#7f72cbc4d643c365e27b9fd775f9d0eaa9c7a8ed" @@ -5214,10 +4933,10 @@ jest-worker@^26.2.1: merge-stream "^2.0.0" supports-color "^7.0.0" -jest-worker@^27.0.2: - version "27.0.2" - resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.0.2.tgz#4ebeb56cef48b3e7514552f80d0d80c0129f0b05" - integrity sha512-EoBdilOTTyOgmHXtw/cPc+ZrCA0KJMrkXzkrPGNwLmnvvlN1nj7MPrxpT7m+otSv2e1TLaVffzDnE/LB14zJMg== +jest-worker@^27.0.2, jest-worker@^27.4.5: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.5.1.tgz#8d146f0900e8973b106b6f73cc1e9a8cb86f8db0" + integrity sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg== dependencies: "@types/node" "*" merge-stream "^2.0.0" @@ -5291,7 +5010,7 @@ jsesc@^2.5.1: jsesc@~0.5.0: version "0.5.0" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" - integrity sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0= + integrity sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA== jshashes@~1.0.8: version "1.0.8" @@ -5318,24 +5037,27 @@ json-schema-traverse@^1.0.0: resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== +json-schema@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.4.0.tgz#f7de4cf6efab838ebaeb3236474cbba5a1930ab5" + integrity sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA== + json-stable-stringify-without-jsonify@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" integrity sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE= json5@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.1.tgz#779fb0018604fa854eacbf6252180d83543e3dbe" - integrity sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow== + version "1.0.2" + resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.2.tgz#63d98d60f21b313b77c4d6da18bfa69d80e1d593" + integrity sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA== dependencies: minimist "^1.2.0" -json5@^2.1.2: - version "2.2.0" - resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.0.tgz#2dfefe720c6ba525d9ebd909950f0515316c89a3" - integrity sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA== - dependencies: - minimist "^1.2.5" +json5@^2.1.2, json5@^2.2.0, json5@^2.2.2: + version "2.2.3" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" + integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== jsonfile@^6.0.1: version "6.1.0" @@ -5346,7 +5068,21 @@ jsonfile@^6.0.1: optionalDependencies: graceful-fs "^4.1.6" -jss-plugin-camel-case@10.6.0, jss-plugin-camel-case@^10.5.1: +jsonpointer@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/jsonpointer/-/jsonpointer-5.0.1.tgz#2110e0af0900fd37467b5907ecd13a7884a1b559" + integrity sha512-p/nXbhSEcu3pZRdkW1OfJhpsVtW1gd4Wa1fnQc9YLiTfAjn0312eMKimbdIQzuZl9aa9xUGaRlP9T/CJE/ditQ== + +jss-plugin-camel-case@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-camel-case/-/jss-plugin-camel-case-10.10.0.tgz#27ea159bab67eb4837fa0260204eb7925d4daa1c" + integrity sha512-z+HETfj5IYgFxh1wJnUAU8jByI48ED+v0fuTuhKrPR+pRBYS2EDwbusU8aFOpCdYhtRc9zhN+PJ7iNE8pAWyPw== + dependencies: + "@babel/runtime" "^7.3.1" + hyphenate-style-name "^1.0.3" + jss "10.10.0" + +jss-plugin-camel-case@^10.5.1: version "10.6.0" resolved "https://registry.yarnpkg.com/jss-plugin-camel-case/-/jss-plugin-camel-case-10.6.0.tgz#93d2cd704bf0c4af70cc40fb52d74b8a2554b170" integrity sha512-JdLpA3aI/npwj3nDMKk308pvnhoSzkW3PXlbgHAzfx0yHWnPPVUjPhXFtLJzgKZge8lsfkUxvYSQ3X2OYIFU6A== @@ -5355,16 +5091,24 @@ jss-plugin-camel-case@10.6.0, jss-plugin-camel-case@^10.5.1: hyphenate-style-name "^1.0.3" jss "10.6.0" -jss-plugin-compose@10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/jss-plugin-compose/-/jss-plugin-compose-10.6.0.tgz#0bf058814ea9b47e87cc61f1261aab881daa403b" - integrity sha512-zBhI5ZDVX30h4N+rPunAfbwHVDWlme0JPiLBT0TSg24aX+QhjpogZSKHv9pn23NqIdiz3aIJmrNVnJ5rwNKQKA== +jss-plugin-compose@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-compose/-/jss-plugin-compose-10.10.0.tgz#00d7a79adf7fcfe4927a792febdf0deceb0a7cd2" + integrity sha512-F5kgtWpI2XfZ3Z8eP78tZEYFdgTIbpA/TMuX3a8vwrNolYtN1N4qJR/Ob0LAsqIwCMLojtxN7c7Oo/+Vz6THow== dependencies: "@babel/runtime" "^7.3.1" - jss "10.6.0" + jss "10.10.0" tiny-warning "^1.0.2" -jss-plugin-default-unit@10.6.0, jss-plugin-default-unit@^10.5.1: +jss-plugin-default-unit@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-default-unit/-/jss-plugin-default-unit-10.10.0.tgz#db3925cf6a07f8e1dd459549d9c8aadff9804293" + integrity sha512-SvpajxIECi4JDUbGLefvNckmI+c2VWmP43qnEy/0eiwzRUsafg5DVSIWSzZe4d2vFX1u9nRDP46WCFV/PXVBGQ== + dependencies: + "@babel/runtime" "^7.3.1" + jss "10.10.0" + +jss-plugin-default-unit@^10.5.1: version "10.6.0" resolved "https://registry.yarnpkg.com/jss-plugin-default-unit/-/jss-plugin-default-unit-10.6.0.tgz#af47972486819b375f0f3a9e0213403a84b5ef3b" integrity sha512-7y4cAScMHAxvslBK2JRK37ES9UT0YfTIXWgzUWD5euvR+JR3q+o8sQKzBw7GmkQRfZijrRJKNTiSt1PBsLI9/w== @@ -5372,24 +5116,32 @@ jss-plugin-default-unit@10.6.0, jss-plugin-default-unit@^10.5.1: "@babel/runtime" "^7.3.1" jss "10.6.0" -jss-plugin-expand@10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/jss-plugin-expand/-/jss-plugin-expand-10.6.0.tgz#7eabb6d14f407c38b4d6013588d6641a2e869723" - integrity sha512-TYVfKS3l8kNaClWW3PA9AhFr9ixhBnKcdGwZDRH3WRGDmdX0RYOhpfScscRXQM1HAlqaXLRqiP+NYGCK6QBgOg== +jss-plugin-expand@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-expand/-/jss-plugin-expand-10.10.0.tgz#5debd80554174ca2d9b9e38d85d4cb6f3e0393ab" + integrity sha512-ymT62W2OyDxBxr7A6JR87vVX9vTq2ep5jZLIdUSusfBIEENLdkkc0lL/Xaq8W9s3opUq7R0sZQpzRWELrfVYzA== dependencies: "@babel/runtime" "^7.3.1" - jss "10.6.0" + jss "10.10.0" -jss-plugin-extend@10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/jss-plugin-extend/-/jss-plugin-extend-10.6.0.tgz#7611d5d96781b833e5b4aa3eb8599525e790143b" - integrity sha512-eY/zKMT+aUOdHegTDzTznq8Nwsv0PEb5AyJfo8A1B9jPxzzLTGcFOl9S6JZoYRxMh9TWxA5lOULMIjgKAKzUcQ== +jss-plugin-extend@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-extend/-/jss-plugin-extend-10.10.0.tgz#94eb450847a8941777e77ea4533a579c1c578430" + integrity sha512-sKYrcMfr4xxigmIwqTjxNcHwXJIfvhvjTNxF+Tbc1NmNdyspGW47Ey6sGH8BcQ4FFQhLXctpWCQSpDwdNmXSwg== dependencies: "@babel/runtime" "^7.3.1" - jss "10.6.0" + jss "10.10.0" tiny-warning "^1.0.2" -jss-plugin-global@10.6.0, jss-plugin-global@^10.5.1: +jss-plugin-global@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-global/-/jss-plugin-global-10.10.0.tgz#1c55d3c35821fab67a538a38918292fc9c567efd" + integrity sha512-icXEYbMufiNuWfuazLeN+BNJO16Ge88OcXU5ZDC2vLqElmMybA31Wi7lZ3lf+vgufRocvPj8443irhYRgWxP+A== + dependencies: + "@babel/runtime" "^7.3.1" + jss "10.10.0" + +jss-plugin-global@^10.5.1: version "10.6.0" resolved "https://registry.yarnpkg.com/jss-plugin-global/-/jss-plugin-global-10.6.0.tgz#3e8011f760f399cbadcca7f10a485b729c50e3ed" integrity sha512-I3w7ji/UXPi3VuWrTCbHG9rVCgB4yoBQLehGDTmsnDfXQb3r1l3WIdcO8JFp9m0YMmyy2CU7UOV6oPI7/Tmu+w== @@ -5397,7 +5149,16 @@ jss-plugin-global@10.6.0, jss-plugin-global@^10.5.1: "@babel/runtime" "^7.3.1" jss "10.6.0" -jss-plugin-nested@10.6.0, jss-plugin-nested@^10.5.1: +jss-plugin-nested@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-nested/-/jss-plugin-nested-10.10.0.tgz#db872ed8925688806e77f1fc87f6e62264513219" + integrity sha512-9R4JHxxGgiZhurDo3q7LdIiDEgtA1bTGzAbhSPyIOWb7ZubrjQe8acwhEQ6OEKydzpl8XHMtTnEwHXCARLYqYA== + dependencies: + "@babel/runtime" "^7.3.1" + jss "10.10.0" + tiny-warning "^1.0.2" + +jss-plugin-nested@^10.5.1: version "10.6.0" resolved "https://registry.yarnpkg.com/jss-plugin-nested/-/jss-plugin-nested-10.6.0.tgz#5f83c5c337d3b38004834e8426957715a0251641" integrity sha512-fOFQWgd98H89E6aJSNkEh2fAXquC9aZcAVjSw4q4RoQ9gU++emg18encR4AT4OOIFl4lQwt5nEyBBRn9V1Rk8g== @@ -5406,7 +5167,15 @@ jss-plugin-nested@10.6.0, jss-plugin-nested@^10.5.1: jss "10.6.0" tiny-warning "^1.0.2" -jss-plugin-props-sort@10.6.0, jss-plugin-props-sort@^10.5.1: +jss-plugin-props-sort@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-props-sort/-/jss-plugin-props-sort-10.10.0.tgz#67f4dd4c70830c126f4ec49b4b37ccddb680a5d7" + integrity sha512-5VNJvQJbnq/vRfje6uZLe/FyaOpzP/IH1LP+0fr88QamVrGJa0hpRRyAa0ea4U/3LcorJfBFVyC4yN2QC73lJg== + dependencies: + "@babel/runtime" "^7.3.1" + jss "10.10.0" + +jss-plugin-props-sort@^10.5.1: version "10.6.0" resolved "https://registry.yarnpkg.com/jss-plugin-props-sort/-/jss-plugin-props-sort-10.6.0.tgz#297879f35f9fe21196448579fee37bcde28ce6bc" integrity sha512-oMCe7hgho2FllNc60d9VAfdtMrZPo9n1Iu6RNa+3p9n0Bkvnv/XX5San8fTPujrTBScPqv9mOE0nWVvIaohNuw== @@ -5414,7 +5183,16 @@ jss-plugin-props-sort@10.6.0, jss-plugin-props-sort@^10.5.1: "@babel/runtime" "^7.3.1" jss "10.6.0" -jss-plugin-rule-value-function@10.6.0, jss-plugin-rule-value-function@^10.5.1: +jss-plugin-rule-value-function@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-rule-value-function/-/jss-plugin-rule-value-function-10.10.0.tgz#7d99e3229e78a3712f78ba50ab342e881d26a24b" + integrity sha512-uEFJFgaCtkXeIPgki8ICw3Y7VMkL9GEan6SqmT9tqpwM+/t+hxfMUdU4wQ0MtOiMNWhwnckBV0IebrKcZM9C0g== + dependencies: + "@babel/runtime" "^7.3.1" + jss "10.10.0" + tiny-warning "^1.0.2" + +jss-plugin-rule-value-function@^10.5.1: version "10.6.0" resolved "https://registry.yarnpkg.com/jss-plugin-rule-value-function/-/jss-plugin-rule-value-function-10.6.0.tgz#3c1a557236a139d0151e70a82c810ccce1c1c5ea" integrity sha512-TKFqhRTDHN1QrPTMYRlIQUOC2FFQb271+AbnetURKlGvRl/eWLswcgHQajwuxI464uZk91sPiTtdGi7r7XaWfA== @@ -5423,25 +5201,34 @@ jss-plugin-rule-value-function@10.6.0, jss-plugin-rule-value-function@^10.5.1: jss "10.6.0" tiny-warning "^1.0.2" -jss-plugin-rule-value-observable@10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/jss-plugin-rule-value-observable/-/jss-plugin-rule-value-observable-10.6.0.tgz#2b3252cc1507d0154bd9e50f4527ad8073d67b6b" - integrity sha512-+N6S8UZ+Tu+G2Fbu/UrfLI/JyaTi/KfkPbKsVRfyg/C/IdI+p9+H67HncMIFYEi/KnNj5fqvMNSDe4ag/lqbHw== +jss-plugin-rule-value-observable@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-rule-value-observable/-/jss-plugin-rule-value-observable-10.10.0.tgz#d17b28c4401156bbe4cd0c4a73a80aad70613e8b" + integrity sha512-ZLMaYrR3QE+vD7nl3oNXuj79VZl9Kp8/u6A1IbTPDcuOu8b56cFdWRZNZ0vNr8jHewooEeq2doy8Oxtymr2ZPA== dependencies: "@babel/runtime" "^7.3.1" - jss "10.6.0" + jss "10.10.0" symbol-observable "^1.2.0" -jss-plugin-template@10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/jss-plugin-template/-/jss-plugin-template-10.6.0.tgz#75b1643044f3191b9d447589439053c597854704" - integrity sha512-P3iaIR6AqTOoutwP7Y2KVCq4jShEMACrwKf8W9gsS3ppnIeBg4OCAQvLKmqunApkEoIk0711xbW9XPi9CYy3zg== +jss-plugin-template@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-template/-/jss-plugin-template-10.10.0.tgz#072cda74a94c91b02d3a895d9e2408fd978ce033" + integrity sha512-ocXZBIOJOA+jISPdsgkTs8wwpK6UbsvtZK5JI7VUggTD6LWKbtoxUzadd2TpfF+lEtlhUmMsCkTRNkITdPKa6w== dependencies: "@babel/runtime" "^7.3.1" - jss "10.6.0" + jss "10.10.0" tiny-warning "^1.0.2" -jss-plugin-vendor-prefixer@10.6.0, jss-plugin-vendor-prefixer@^10.5.1: +jss-plugin-vendor-prefixer@10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-plugin-vendor-prefixer/-/jss-plugin-vendor-prefixer-10.10.0.tgz#c01428ef5a89f2b128ec0af87a314d0c767931c7" + integrity sha512-UY/41WumgjW8r1qMCO8l1ARg7NHnfRVWRhZ2E2m0DMYsr2DD91qIXLyNhiX83hHswR7Wm4D+oDYNC1zWCJWtqg== + dependencies: + "@babel/runtime" "^7.3.1" + css-vendor "^2.0.8" + jss "10.10.0" + +jss-plugin-vendor-prefixer@^10.5.1: version "10.6.0" resolved "https://registry.yarnpkg.com/jss-plugin-vendor-prefixer/-/jss-plugin-vendor-prefixer-10.6.0.tgz#e1fcd499352846890c38085b11dbd7aa1c4f2c78" integrity sha512-doJ7MouBXT1lypLLctCwb4nJ6lDYqrTfVS3LtXgox42Xz0gXusXIIDboeh6UwnSmox90QpVnub7au8ybrb0krQ== @@ -5450,25 +5237,35 @@ jss-plugin-vendor-prefixer@10.6.0, jss-plugin-vendor-prefixer@^10.5.1: css-vendor "^2.0.8" jss "10.6.0" -jss-preset-default@10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/jss-preset-default/-/jss-preset-default-10.6.0.tgz#b5471858adede57efd8d139c85dd44601b55dc94" - integrity sha512-TuHDZiuxGLLJ/LIMLAzO5uf2PnLOCR6yF5GHQLPp59YTascmwEldJfR0tuqjKa8B2F/v708ZvzE1Dw0Ao7UIcA== +jss-preset-default@10.10.0, jss-preset-default@^10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss-preset-default/-/jss-preset-default-10.10.0.tgz#c8209449a0f6d232526c2ba3a3a6ec69ee97e023" + integrity sha512-GL175Wt2FGhjE+f+Y3aWh+JioL06/QWFgZp53CbNNq6ZkVU0TDplD8Bxm9KnkotAYn3FlplNqoW5CjyLXcoJ7Q== dependencies: "@babel/runtime" "^7.3.1" - jss "10.6.0" - jss-plugin-camel-case "10.6.0" - jss-plugin-compose "10.6.0" - jss-plugin-default-unit "10.6.0" - jss-plugin-expand "10.6.0" - jss-plugin-extend "10.6.0" - jss-plugin-global "10.6.0" - jss-plugin-nested "10.6.0" - jss-plugin-props-sort "10.6.0" - jss-plugin-rule-value-function "10.6.0" - jss-plugin-rule-value-observable "10.6.0" - jss-plugin-template "10.6.0" - jss-plugin-vendor-prefixer "10.6.0" + jss "10.10.0" + jss-plugin-camel-case "10.10.0" + jss-plugin-compose "10.10.0" + jss-plugin-default-unit "10.10.0" + jss-plugin-expand "10.10.0" + jss-plugin-extend "10.10.0" + jss-plugin-global "10.10.0" + jss-plugin-nested "10.10.0" + jss-plugin-props-sort "10.10.0" + jss-plugin-rule-value-function "10.10.0" + jss-plugin-rule-value-observable "10.10.0" + jss-plugin-template "10.10.0" + jss-plugin-vendor-prefixer "10.10.0" + +jss@10.10.0, jss@^10.10.0: + version "10.10.0" + resolved "https://registry.yarnpkg.com/jss/-/jss-10.10.0.tgz#a75cc85b0108c7ac8c7b7d296c520a3e4fbc6ccc" + integrity sha512-cqsOTS7jqPsPMjtKYDUpdFC0AbhYFLTcuGRqymgmdJIeQ8cH7+AgX7YSgQy79wXloZq2VvATYxUOUQEvS1V/Zw== + dependencies: + "@babel/runtime" "^7.3.1" + csstype "^3.0.2" + is-in-browser "^1.1.3" + tiny-warning "^1.0.2" jss@10.6.0, jss@^10.5.1, jss@^10.6.0: version "10.6.0" @@ -5590,14 +5387,14 @@ loader-utils@1.2.3: emojis-list "^2.0.0" json5 "^1.0.1" -loader-utils@^1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-1.4.0.tgz#c579b5e34cb34b1a74edc6c1fb36bfa371d5a613" - integrity sha512-qH0WSMBtn/oHuwjy/NucEgbx5dbxxnxup9s4PVXJUDHZBQY+s0NWA9rJf53RBnQZxfch7euUui7hpoAPvALZdA== +loader-utils@^2.0.0: + version "2.0.4" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-2.0.4.tgz#8b5cb38b5c34a9a018ee1fc0e6a066d1dfcc528c" + integrity sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw== dependencies: big.js "^5.2.2" emojis-list "^3.0.0" - json5 "^1.0.1" + json5 "^2.1.2" locate-path@^2.0.0: version "2.0.0" @@ -5629,7 +5426,7 @@ lodash.clonedeep@^4.5.0: lodash.debounce@^4.0.8: version "4.0.8" resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" - integrity sha1-gteb/zCmfEAF/9XiUVMArZyk168= + integrity sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow== lodash.merge@^4.6.2: version "4.6.2" @@ -5639,7 +5436,7 @@ lodash.merge@^4.6.2: lodash.sortby@^4.7.0: version "4.7.0" resolved "https://registry.yarnpkg.com/lodash.sortby/-/lodash.sortby-4.7.0.tgz#edd14c824e2cc9c1e0b0a1b42bb5210516a42438" - integrity sha1-7dFMgk4sycHgsKG0K7UhBRakJDg= + integrity sha512-HDWXG8isMntAyRF5vZ7xKuEvOhT4AhlRt/3czTSjvGUxjYCBVRQY48ViDHyfYz9VIoBkW4TMGQNapx+l3RUwdA== lodash.truncate@^4.4.2: version "4.4.2" @@ -5676,6 +5473,13 @@ loose-envify@^1.1.0, loose-envify@^1.4.0: dependencies: js-tokens "^3.0.0 || ^4.0.0" +lru-cache@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920" + integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== + dependencies: + yallist "^3.0.2" + lru-cache@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" @@ -5689,11 +5493,11 @@ lru_map@^0.3.3: integrity sha1-tcg1G5Rky9dQM1p5ZQoOwOVhGN0= magic-string@^0.25.0, magic-string@^0.25.7: - version "0.25.7" - resolved "https://registry.yarnpkg.com/magic-string/-/magic-string-0.25.7.tgz#3f497d6fd34c669c6798dcb821f2ef31f5445051" - integrity sha512-4CrMT5DOHTDk4HYDlzmwu4FVCcIYI8gauveasrdCu2IKIFOJ3f0v/8MDGJCDL9oD2ppz/Av1b0Nj345H9M+XIA== + version "0.25.9" + resolved "https://registry.yarnpkg.com/magic-string/-/magic-string-0.25.9.tgz#de7f9faf91ef8a1c91d02c2e5314c8277dbcdd1c" + integrity sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ== dependencies: - sourcemap-codec "^1.4.4" + sourcemap-codec "^1.4.8" make-dir@^3.0.0, make-dir@^3.0.2, make-dir@^3.1.0: version "3.1.0" @@ -5738,33 +5542,16 @@ maplibre-gl@^1.14.0: tinyqueue "^2.0.3" vt-pbf "^3.1.1" -md5.js@^1.3.4: - version "1.3.5" - resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.5.tgz#b5d07b8e3216e3e27cd728d72f70d1e6a342005f" - integrity sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg== - dependencies: - hash-base "^3.0.0" - inherits "^2.0.1" - safe-buffer "^5.1.2" - merge-stream@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== -merge2@^1.3.0: +merge2@^1.3.0, merge2@^1.4.1: version "1.4.1" resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== -micromatch@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.2.tgz#4fcb0999bf9fbc2fcbdd212f6d629b9a56c39259" - integrity sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q== - dependencies: - braces "^3.0.1" - picomatch "^2.0.5" - micromatch@^4.0.4: version "4.0.4" resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.4.tgz#896d519dfe9db25fce94ceb7a500919bf881ebf9" @@ -5773,14 +5560,6 @@ micromatch@^4.0.4: braces "^3.0.1" picomatch "^2.2.3" -miller-rabin@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d" - integrity sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA== - dependencies: - bn.js "^4.0.0" - brorand "^1.0.1" - mime-db@1.46.0: version "1.46.0" resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.46.0.tgz#6267748a7f799594de3cbc8cde91def349661cee" @@ -5798,32 +5577,29 @@ mimic-fn@^2.1.0: resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== -minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" - integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== - -minimalistic-crypto-utils@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" - integrity sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo= - -minimatch@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" - integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== +minimatch@^3.0.4, minimatch@^3.1.1, minimatch@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== dependencies: brace-expansion "^1.1.7" +minimatch@^5.0.1: + version "5.1.6" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.6.tgz#1cfcb8cf5522ea69952cd2af95ae09477f122a96" + integrity sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g== + dependencies: + brace-expansion "^2.0.1" + minimist@^1.2.0, minimist@^1.2.5: - version "1.2.5" - resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" - integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== + version "1.2.8" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" + integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== ms@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" - integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= + integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== ms@2.1.2: version "2.1.2" @@ -5840,17 +5616,10 @@ murmurhash-js@^1.0.0: resolved "https://registry.yarnpkg.com/murmurhash-js/-/murmurhash-js-1.0.0.tgz#b06278e21fc6c37fa5313732b0412bcb6ae15f51" integrity sha1-sGJ44h/Gw3+lMTcysEEry2rhX1E= -nanoid@^3.1.22: - version "3.1.23" - resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.23.tgz#f744086ce7c2bc47ee0a8472574d5c78e4183a81" - integrity sha512-FiB0kzdP0FFVGDKlRLEQ1BgDzU87dy5NnzjeW9YZNt+/c3+q82EQDUwniSAUxp/F0gFNI1ZhKU1FqYsMuqZVnw== - -native-url@0.3.4: - version "0.3.4" - resolved "https://registry.yarnpkg.com/native-url/-/native-url-0.3.4.tgz#29c943172aed86c63cee62c8c04db7f5756661f8" - integrity sha512-6iM8R99ze45ivyH8vybJ7X0yekIcPf5GgLV5K0ENCbmRcaRIDoj37BC8iLEmaaBfqqb8enuZ5p0uhY+lVAbAcA== - dependencies: - querystring "^0.2.0" +nanoid@^3.3.4: + version "3.3.6" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.6.tgz#443380c856d6e9f9824267d960b4236ad583ea4c" + integrity sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA== natural-compare@^1.4.0: version "1.4.0" @@ -5865,119 +5634,50 @@ next-cookies@^2.0.3: universal-cookie "^4.0.2" next-pwa@^5.2.21: - version "5.2.21" - resolved "https://registry.yarnpkg.com/next-pwa/-/next-pwa-5.2.21.tgz#fb71ba35b1a984ec6641c5def64ca8c0ab9c2b0f" - integrity sha512-jL782UGX0E59TmmYi1xe5kgImeGPBO3me/b3RX7bLP0eG8oJeZiJqTVkc5DJNmXgdwOc6RSvRSOUdBQ9zLu4RA== - dependencies: - babel-loader "^8.2.2" - clean-webpack-plugin "^3.0.0" - globby "^11.0.3" - terser-webpack-plugin "^5.1.1" - workbox-webpack-plugin "^6.1.5" - workbox-window "^6.1.5" - -next@^10.2.3: - version "10.2.3" - resolved "https://registry.yarnpkg.com/next/-/next-10.2.3.tgz#5aa058a63626338cea91c198fda8f2715c058394" - integrity sha512-dkM1mIfnORtGyzw/Yme8RdqNxlCMZyi4Lqj56F01/yHbe1ZtOaJ0cyqqRB4RGiPhjGGh0319f8ddjDyO1605Ow== - dependencies: - "@babel/runtime" "7.12.5" - "@hapi/accept" "5.0.2" - "@next/env" "10.2.3" - "@next/polyfill-module" "10.2.3" - "@next/react-dev-overlay" "10.2.3" - "@next/react-refresh-utils" "10.2.3" - "@opentelemetry/api" "0.14.0" - assert "2.0.0" - ast-types "0.13.2" - browserify-zlib "0.2.0" - browserslist "4.16.6" - buffer "5.6.0" - caniuse-lite "^1.0.30001228" - chalk "2.4.2" - chokidar "3.5.1" - constants-browserify "1.0.0" - crypto-browserify "3.12.0" - cssnano-simple "2.0.0" - domain-browser "4.19.0" - encoding "0.1.13" - etag "1.8.1" - find-cache-dir "3.3.1" - get-orientation "1.1.2" - https-browserify "1.0.0" - jest-worker "27.0.0-next.5" - native-url "0.3.4" - node-fetch "2.6.1" - node-html-parser "1.4.9" - node-libs-browser "^2.2.1" - os-browserify "0.3.0" - p-limit "3.1.0" - path-browserify "1.0.1" - pnp-webpack-plugin "1.6.4" - postcss "8.2.13" - process "0.11.10" - prop-types "15.7.2" - querystring-es3 "0.2.1" - raw-body "2.4.1" - react-is "16.13.1" - react-refresh "0.8.3" - stream-browserify "3.0.0" - stream-http "3.1.1" - string_decoder "1.3.0" - styled-jsx "3.3.2" - timers-browserify "2.0.12" - tty-browserify "0.0.1" - use-subscription "1.5.1" - util "0.12.3" - vm-browserify "1.1.2" - watchpack "2.1.1" - -node-fetch@2.6.1, node-fetch@^2.6.1: + version "5.6.0" + resolved "https://registry.yarnpkg.com/next-pwa/-/next-pwa-5.6.0.tgz#f7b1960c4fdd7be4253eb9b41b612ac773392bf4" + integrity sha512-XV8g8C6B7UmViXU8askMEYhWwQ4qc/XqJGnexbLV68hzKaGHZDMtHsm2TNxFcbR7+ypVuth/wwpiIlMwpRJJ5A== + dependencies: + babel-loader "^8.2.5" + clean-webpack-plugin "^4.0.0" + globby "^11.0.4" + terser-webpack-plugin "^5.3.3" + workbox-webpack-plugin "^6.5.4" + workbox-window "^6.5.4" + +next@^13.4.3: + version "13.4.3" + resolved "https://registry.yarnpkg.com/next/-/next-13.4.3.tgz#7f417dec9fa2731d8c1d1819a1c7d0919ad6fc75" + integrity sha512-FV3pBrAAnAIfOclTvncw9dDohyeuEEXPe5KNcva91anT/rdycWbgtu3IjUj4n5yHnWK8YEPo0vrUecHmnmUNbA== + dependencies: + "@next/env" "13.4.3" + "@swc/helpers" "0.5.1" + busboy "1.6.0" + caniuse-lite "^1.0.30001406" + postcss "8.4.14" + styled-jsx "5.1.1" + zod "3.21.4" + optionalDependencies: + "@next/swc-darwin-arm64" "13.4.3" + "@next/swc-darwin-x64" "13.4.3" + "@next/swc-linux-arm64-gnu" "13.4.3" + "@next/swc-linux-arm64-musl" "13.4.3" + "@next/swc-linux-x64-gnu" "13.4.3" + "@next/swc-linux-x64-musl" "13.4.3" + "@next/swc-win32-arm64-msvc" "13.4.3" + "@next/swc-win32-ia32-msvc" "13.4.3" + "@next/swc-win32-x64-msvc" "13.4.3" + +node-fetch@^2.6.1: version "2.6.1" resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.1.tgz#045bd323631f76ed2e2b55573394416b639a0052" integrity sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw== -node-html-parser@1.4.9: - version "1.4.9" - resolved "https://registry.yarnpkg.com/node-html-parser/-/node-html-parser-1.4.9.tgz#3c8f6cac46479fae5800725edb532e9ae8fd816c" - integrity sha512-UVcirFD1Bn0O+TSmloHeHqZZCxHjvtIeGdVdGMhyZ8/PWlEiZaZ5iJzR189yKZr8p0FXN58BUeC7RHRkf/KYGw== - dependencies: - he "1.2.0" - node-int64@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" integrity sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs= -node-libs-browser@^2.2.1: - version "2.2.1" - resolved "https://registry.yarnpkg.com/node-libs-browser/-/node-libs-browser-2.2.1.tgz#b64f513d18338625f90346d27b0d235e631f6425" - integrity sha512-h/zcD8H9kaDZ9ALUWwlBUDo6TKF8a7qBSCSEGfjTVIYeqsioSKaAX+BN7NgiMGp6iSIXZ3PxgCu8KS3b71YK5Q== - dependencies: - assert "^1.1.1" - browserify-zlib "^0.2.0" - buffer "^4.3.0" - console-browserify "^1.1.0" - constants-browserify "^1.0.0" - crypto-browserify "^3.11.0" - domain-browser "^1.1.1" - events "^3.0.0" - https-browserify "^1.0.0" - os-browserify "^0.3.0" - path-browserify "0.0.1" - process "^0.11.10" - punycode "^1.2.4" - querystring-es3 "^0.2.0" - readable-stream "^2.3.3" - stream-browserify "^2.0.1" - stream-http "^2.7.2" - string_decoder "^1.0.0" - timers-browserify "^2.0.4" - tty-browserify "0.0.0" - url "^0.11.0" - util "^0.11.0" - vm-browserify "^1.0.1" - node-modules-regexp@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/node-modules-regexp/-/node-modules-regexp-1.0.0.tgz#8d9dbe28964a4ac5712e9131642107c71e90ec40" @@ -5988,10 +5688,10 @@ node-releases@^1.1.70: resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-1.1.71.tgz#cb1334b179896b1c89ecfdd4b725fb7bbdfc7dbb" integrity sha512-zR6HoT6LrLCRBwukmrVbHv0EpEQjksO6GmFcZQQuCAy139BEsoVKPYnf3jongYW83fAa1torLGYwxxky/p28sg== -node-releases@^1.1.71: - version "1.1.72" - resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-1.1.72.tgz#14802ab6b1039a79a0c7d662b610a5bbd76eacbe" - integrity sha512-LLUo+PpH3dU6XizX3iVoubUNheF/owjXCZZ5yACDxNnPtgFuludV1ZL3ayK1kVep42Rmm0+R9/Y60NQbZ2bifw== +node-releases@^2.0.8: + version "2.0.11" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.11.tgz#59d7cef999d13f908e43b5a70001cf3129542f0f" + integrity sha512-+M0PwXeU80kRohZ3aT4J/OnR+l9/KD2nVLNNoRgFtnf+umQVFdGBAO2N8+nCnEi0xlh/Wk3zOGC+vNNx+uM79Q== normalize-package-data@^2.3.2: version "2.5.0" @@ -6003,7 +5703,7 @@ normalize-package-data@^2.3.2: semver "2 || 3 || 4 || 5" validate-npm-package-license "^3.0.1" -normalize-path@^3.0.0, normalize-path@~3.0.0: +normalize-path@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== @@ -6023,39 +5723,31 @@ nwsapi@^2.2.0: object-assign@^4.0.1, object-assign@^4.1.1: version "4.1.1" resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" - integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== object-inspect@^1.10.3: version "1.10.3" resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.10.3.tgz#c2aa7d2d09f50c99375704f7a0adf24c5782d369" integrity sha512-e5mCJlSH7poANfC8z8S9s9S2IN5/4Zb3aZ33f5s8YqoazCFzNLloLU8r5VCG+G7WoqLvAAZoVMcy3tp/3X0Plw== -object-inspect@^1.9.0: - version "1.9.0" - resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.9.0.tgz#c90521d74e1127b67266ded3394ad6116986533a" - integrity sha512-i3Bp9iTqwhaLZBxGkRfo5ZbE07BQRT7MGu8+nNgwW9ItGp1TzCTw2DLEoWwjClxBjOFI/hWljTAmYGCEwmtnOw== - -object-is@^1.0.1: - version "1.1.5" - resolved "https://registry.yarnpkg.com/object-is/-/object-is-1.1.5.tgz#b9deeaa5fc7f1846a0faecdceec138e5778f53ac" - integrity sha512-3cyDsyHgtmi7I7DfSSI2LDp6SK2lwvtbg0p0R1e0RvTqF5ceGx+K2dfSjm1bKDMVCFEDAQvy+o8c6a7VujOddw== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.3" +object-inspect@^1.12.3, object-inspect@^1.9.0: + version "1.12.3" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.12.3.tgz#ba62dffd67ee256c8c086dfae69e016cd1f198b9" + integrity sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g== -object-keys@^1.0.12, object-keys@^1.1.1: +object-keys@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== -object.assign@^4.1.0, object.assign@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.2.tgz#0ed54a342eceb37b38ff76eb831a0e788cb63940" - integrity sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ== +object.assign@^4.1.2, object.assign@^4.1.4: + version "4.1.4" + resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.4.tgz#9673c7c7c351ab8c4d0b516f4343ebf4dfb7799f" + integrity sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ== dependencies: - call-bind "^1.0.0" - define-properties "^1.1.3" - has-symbols "^1.0.1" + call-bind "^1.0.2" + define-properties "^1.1.4" + has-symbols "^1.0.3" object-keys "^1.1.1" object.entries@^1.1.2: @@ -6116,7 +5808,7 @@ ohauth@~1.0.1: once@^1.3.0: version "1.4.0" resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" - integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= + integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== dependencies: wrappy "1" @@ -6156,11 +5848,6 @@ optionator@^0.9.1: type-check "^0.4.0" word-wrap "^1.2.3" -os-browserify@0.3.0, os-browserify@^0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/os-browserify/-/os-browserify-0.3.0.tgz#854373c7f5c2315914fc9bfc6bd8238fdda1ec27" - integrity sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc= - osm-auth@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/osm-auth/-/osm-auth-1.1.1.tgz#2a6be41fb45998d9276b879154f8b86628de17d7" @@ -6175,13 +5862,6 @@ p-each-series@^2.1.0: resolved "https://registry.yarnpkg.com/p-each-series/-/p-each-series-2.2.0.tgz#105ab0357ce72b202a8a8b94933672657b5e2a9a" integrity sha512-ycIL2+1V32th+8scbpTvyHNaHe02z0sjgh91XXjAk+ZeXoPN4Z46DVUnzdso0aX4KckKw0FNNFHdjZ2UsZvxiA== -p-limit@3.1.0, p-limit@^3.0.2, p-limit@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" - integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== - dependencies: - yocto-queue "^0.1.0" - p-limit@^1.1.0: version "1.3.0" resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.3.0.tgz#b86bd5f0c25690911c7590fcbfc2010d54b3ccb8" @@ -6196,6 +5876,13 @@ p-limit@^2.2.0: dependencies: p-try "^2.0.0" +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + p-locate@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" @@ -6239,11 +5926,6 @@ p-try@^2.0.0: resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== -pako@~1.0.5: - version "1.0.11" - resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf" - integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw== - parent-module@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" @@ -6251,17 +5933,6 @@ parent-module@^1.0.0: dependencies: callsites "^3.0.0" -parse-asn1@^5.0.0, parse-asn1@^5.1.5: - version "5.1.6" - resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.6.tgz#385080a3ec13cb62a62d39409cb3e88844cdaed4" - integrity sha512-RnZRo1EPU6JBnra2vGHj0yhp6ebyjBZpmUCLHWiFhxlzvBCCpAuZ7elsBp1PVAbQN0/04VD/19rfzlBSwLstMw== - dependencies: - asn1.js "^5.2.0" - browserify-aes "^1.0.0" - evp_bytestokey "^1.0.0" - pbkdf2 "^3.0.3" - safe-buffer "^5.1.1" - parse-json@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-4.0.0.tgz#be35f5425be1f7f6c747184f98a788cb99477ee0" @@ -6285,16 +5956,6 @@ parse5@6.0.1: resolved "https://registry.yarnpkg.com/parse5/-/parse5-6.0.1.tgz#e1a1c085c569b3dc08321184f19a39cc27f7c30b" integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== -path-browserify@0.0.1: - version "0.0.1" - resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-0.0.1.tgz#e6c4ddd7ed3aa27c68a20cc4e50e1a4ee83bbc4a" - integrity sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ== - -path-browserify@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-1.0.1.tgz#d98454a9c3753d5790860f16f68867b9e46be1fd" - integrity sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g== - path-exists@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" @@ -6308,22 +5969,22 @@ path-exists@^4.0.0: path-is-absolute@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" - integrity sha1-F0uSaHNVNP+8es5r9TpanhtcX18= + integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== path-is-inside@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/path-is-inside/-/path-is-inside-1.0.2.tgz#365417dede44430d1c11af61027facf074bdfc53" - integrity sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM= + integrity sha512-DUWJr3+ULp4zXmol/SZkFf3JGsS9/SIv+Y3Rt93/UjPpDpklB5f1er4O3POIbUuUJ3FXgqte2Q7SrU6zAqwk8w== path-key@^3.0.0, path-key@^3.1.0: version "3.1.1" resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== -path-parse@^1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.6.tgz#d62dbb5679405d72c4737ec58600e9ddcf06d24c" - integrity sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw== +path-parse@^1.0.6, path-parse@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" + integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== path-type@^3.0.0: version "3.0.0" @@ -6345,28 +6006,22 @@ pbf@^3.0.5, pbf@^3.2.1: ieee754 "^1.1.12" resolve-protobuf-schema "^2.1.0" -pbkdf2@^3.0.3: - version "3.1.1" - resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.1.1.tgz#cb8724b0fada984596856d1a6ebafd3584654b94" - integrity sha512-4Ejy1OPxi9f2tt1rRV7Go7zmfDQ+ZectEQz3VGUQhgq62HtIRPDyG/JtnwIxs6x3uNMwo2V7q1fMvKjb+Tnpqg== - dependencies: - create-hash "^1.1.2" - create-hmac "^1.1.4" - ripemd160 "^2.0.1" - safe-buffer "^5.0.1" - sha.js "^2.4.8" - performance-now@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" - integrity sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns= + integrity sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow== -picomatch@^2.0.4, picomatch@^2.0.5, picomatch@^2.2.1: - version "2.2.2" - resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" - integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== +picocolors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" + integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== + +picomatch@^2.0.4, picomatch@^2.2.2: + version "2.3.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== -picomatch@^2.2.2, picomatch@^2.2.3: +picomatch@^2.2.3: version "2.3.0" resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.0.tgz#f1f061de8f6a4bf022892e2d128234fb98302972" integrity sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw== @@ -6374,7 +6029,7 @@ picomatch@^2.2.2, picomatch@^2.2.3: pify@^2.0.0: version "2.3.0" resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" - integrity sha1-7RQaasBDqEnqWISY59yosVMw6Qw= + integrity sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog== pify@^3.0.0: version "3.0.0" @@ -6389,14 +6044,14 @@ pify@^4.0.1: pinkie-promise@^2.0.0: version "2.0.1" resolved "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz#2135d6dfa7a358c069ac9b178776288228450ffa" - integrity sha1-ITXW36ejWMBprJsXh3YogihFD/o= + integrity sha512-0Gni6D4UcLTbv9c57DfxDGdr41XfgUjqWZu492f0cIGr16zDU06BWP/RAEvOuo7CQ0CNjHaLlM59YJJFm3NWlw== dependencies: pinkie "^2.0.0" pinkie@^2.0.0: version "2.0.4" resolved "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870" - integrity sha1-clVrgM+g1IqXToDnckjoDtT3+HA= + integrity sha512-MnUuEycAemtSaeFSjXKW/aroV7akBbY+Sv+RkyqFjgAe73F+MR0TBWKBRDkmfWq/HiFmdavfZ1G7h4SPZXaCSg== pirates@^4.0.1: version "4.0.1" @@ -6433,11 +6088,6 @@ pkg-up@^2.0.0: dependencies: find-up "^2.1.0" -platform@1.3.6: - version "1.3.6" - resolved "https://registry.yarnpkg.com/platform/-/platform-1.3.6.tgz#48b4ce983164b209c2d45a107adb31f473a6e7a7" - integrity sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg== - please-upgrade-node@^3.2.0: version "3.2.0" resolved "https://registry.yarnpkg.com/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz#aeddd3f994c933e4ad98b99d9a556efa0e2fe942" @@ -6445,13 +6095,6 @@ please-upgrade-node@^3.2.0: dependencies: semver-compare "^1.0.0" -pnp-webpack-plugin@1.6.4: - version "1.6.4" - resolved "https://registry.yarnpkg.com/pnp-webpack-plugin/-/pnp-webpack-plugin-1.6.4.tgz#c9711ac4dc48a685dabafc86f8b6dd9f8df84149" - integrity sha512-7Wjy+9E3WwLOEL30D+m8TSTF7qJJUJLONBnwQp0518siuMxUQUbgZwssaFX+QKlZkjHZcw/IpZCt/H0srrntSg== - dependencies: - ts-pnp "^1.1.6" - popper.js@1.16.1-lts: version "1.16.1-lts" resolved "https://registry.yarnpkg.com/popper.js/-/popper.js-1.16.1-lts.tgz#cf6847b807da3799d80ee3d6d2f90df8a3f50b05" @@ -6462,14 +6105,14 @@ postcss-value-parser@^4.0.2: resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.1.0.tgz#443f6a20ced6481a2bda4fa8532a6e55d789a2cb" integrity sha512-97DXOFbQJhk71ne5/Mt6cOu6yxsSfM0QGQyl0L25Gca4yGWEGJaig7l7gbCX623VqTBNGLRLaVUCnNkcedlRSQ== -postcss@8.2.13: - version "8.2.13" - resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.2.13.tgz#dbe043e26e3c068e45113b1ed6375d2d37e2129f" - integrity sha512-FCE5xLH+hjbzRdpbRb1IMCvPv9yZx2QnDarBEYSN0N0HYk+TcXsEhwdFcFb+SRWOKzKGErhIEbBK2ogyLdTtfQ== +postcss@8.4.14: + version "8.4.14" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.14.tgz#ee9274d5622b4858c1007a74d76e42e56fd21caf" + integrity sha512-E398TUmfAYFPBSdzgeieK2Y1+1cpdxJx8yXbK/m57nRhKSmk1GB2tO4lbLBtlkfPQTDKfe4Xqv1ASWPpayPEig== dependencies: - colorette "^1.2.2" - nanoid "^3.1.22" - source-map "^0.6.1" + nanoid "^3.3.4" + picocolors "^1.0.0" + source-map-js "^1.0.2" potpack@^1.0.1: version "1.0.1" @@ -6479,7 +6122,7 @@ potpack@^1.0.1: prefix-style@2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/prefix-style/-/prefix-style-2.0.1.tgz#66bba9a870cfda308a5dc20e85e9120932c95a06" - integrity sha1-ZrupqHDP2jCKXcIOhekSCTLJWgY= + integrity sha512-gdr1MBNVT0drzTq95CbSNdsrBDoHGlb2aDJP/FoY+1e+jSDPOb1Cv554gH2MGiSr2WTcXi/zu+NaFzfcHQkfBQ== prelude-ls@^1.2.1: version "1.2.1" @@ -6521,16 +6164,6 @@ pretty-format@^27.0.2: ansi-styles "^5.0.0" react-is "^17.0.1" -process-nextick-args@~2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" - integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== - -process@0.11.10, process@^0.11.10: - version "0.11.10" - resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" - integrity sha1-czIwDoQBYb2j5podHZGn1LwW8YI= - progress@^2.0.0: version "2.0.3" resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" @@ -6544,7 +6177,16 @@ prompts@^2.0.1: kleur "^3.0.3" sisteransi "^1.0.5" -prop-types@15.7.2, prop-types@^15.5.10, prop-types@^15.5.8, prop-types@^15.6.0, prop-types@^15.6.2, prop-types@^15.7.2: +prop-types@^15.5.10, prop-types@^15.5.8, prop-types@^15.6.0: + version "15.8.1" + resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.8.1.tgz#67d87bf1a694f48435cf332c24af10214a3140b5" + integrity sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg== + dependencies: + loose-envify "^1.4.0" + object-assign "^4.1.1" + react-is "^16.13.1" + +prop-types@^15.6.2, prop-types@^15.7.2: version "15.7.2" resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.7.2.tgz#52c41e75b8c87e72b9d9360e0206b99dcbffa6c5" integrity sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ== @@ -6563,52 +6205,20 @@ psl@^1.1.33: resolved "https://registry.yarnpkg.com/psl/-/psl-1.8.0.tgz#9326f8bcfb013adcc005fdff056acce020e51c24" integrity sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ== -public-encrypt@^4.0.0: - version "4.0.3" - resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.3.tgz#4fcc9d77a07e48ba7527e7cbe0de33d0701331e0" - integrity sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q== - dependencies: - bn.js "^4.1.0" - browserify-rsa "^4.0.0" - create-hash "^1.1.0" - parse-asn1 "^5.0.0" - randombytes "^2.0.1" - safe-buffer "^5.1.2" - -punycode@1.3.2: - version "1.3.2" - resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d" - integrity sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0= - -punycode@^1.2.4: - version "1.4.1" - resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" - integrity sha1-wNWmOycYgArY4esPpSachN1BhF4= +punycode@^2.1.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.0.tgz#f67fa67c94da8f4d0cfff981aee4118064199b8f" + integrity sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA== -punycode@^2.1.0, punycode@^2.1.1: +punycode@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== -querystring-es3@0.2.1, querystring-es3@^0.2.0: - version "0.2.1" - resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.1.tgz#9ec61f79049875707d69414596fd907a4d711e73" - integrity sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM= - -querystring@0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.0.tgz#b209849203bb25df820da756e747005878521620" - integrity sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA= - -querystring@^0.2.0: - version "0.2.1" - resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.1.tgz#40d77615bb09d16902a85c3e38aa8b5ed761c2dd" - integrity sha512-wkvS7mL/JMugcup3/rMitHmd9ecIGd2lhFhK9N3UUQ450h66d1r3Y9nvXzQAW1Lq+wyx61k/1pfKS5KuKiyEbg== - queue-microtask@^1.2.2: - version "1.2.2" - resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.2.tgz#abf64491e6ecf0f38a6502403d4cda04f372dfd3" - integrity sha512-dB15eXv3p2jDlbOiNLyMabYg1/sXvppd8DP2J3EOCQ0AkuSXCW2tP7mnVouVLJKgUMY6yP0kcQDVpLCN13h4Xg== + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== quickselect@^2.0.0: version "2.0.0" @@ -6622,35 +6232,17 @@ raf@^3.1.0: dependencies: performance-now "^2.1.0" -randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5, randombytes@^2.1.0: +randombytes@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ== dependencies: safe-buffer "^5.1.0" -randomfill@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/randomfill/-/randomfill-1.0.4.tgz#c92196fc86ab42be983f1bf31778224931d61458" - integrity sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw== - dependencies: - randombytes "^2.0.5" - safe-buffer "^5.1.0" - -raw-body@2.4.1: - version "2.4.1" - resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.1.tgz#30ac82f98bb5ae8c152e67149dac8d55153b168c" - integrity sha512-9WmIKF6mkvA0SLmA2Knm9+qj89e+j1zqgyn8aXGd7+nAduPoqgI9lO57SAZNn/Byzo5P7JhXTyg9PzaJbH73bA== - dependencies: - bytes "3.1.0" - http-errors "1.7.3" - iconv-lite "0.4.24" - unpipe "1.0.0" - react-custom-scrollbars@^4.2.1: version "4.2.1" resolved "https://registry.yarnpkg.com/react-custom-scrollbars/-/react-custom-scrollbars-4.2.1.tgz#830fd9502927e97e8a78c2086813899b2a8b66db" - integrity sha1-gw/ZUCkn6X6KeMIIaBOJmyqLZts= + integrity sha512-VtJTUvZ7kPh/auZWIbBRceGPkE30XBYe+HktFxuMWBR2eVQQ+Ur6yFJMoaYcNpyGq22uYJ9Wx4UAEcC0K+LNPQ== dependencies: dom-css "^2.0.0" prop-types "^15.5.10" @@ -6661,16 +6253,15 @@ react-display-name@^0.2.4: resolved "https://registry.yarnpkg.com/react-display-name/-/react-display-name-0.2.5.tgz#304c7cbfb59ee40389d436e1a822c17fe27936c6" integrity sha512-I+vcaK9t4+kypiSgaiVWAipqHRXYmZIuAiS8vzFvXHHXVigg/sMKwlRgLy6LH2i3rmP+0Vzfl5lFsFRwF1r3pg== -react-dom@^17.0.2: - version "17.0.2" - resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-17.0.2.tgz#ecffb6845e3ad8dbfcdc498f0d0a939736502c23" - integrity sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA== +react-dom@^18.2.0: + version "18.2.0" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-18.2.0.tgz#22aaf38708db2674ed9ada224ca4aa708d821e3d" + integrity sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" - scheduler "^0.20.2" + scheduler "^0.23.0" -react-is@16.13.1, react-is@^16.7.0, react-is@^16.8.1: +react-is@^16.13.1, react-is@^16.7.0, react-is@^16.8.1: version "16.13.1" resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== @@ -6681,27 +6272,22 @@ react-is@16.13.1, react-is@^16.7.0, react-is@^16.8.1: integrity sha512-NAnt2iGDXohE5LI7uBnLnqvLQMtzhkiAOLXTmv+qnF9Ky7xAPcX8Up/xWIhxvLVGJvuLiNc4xQLtuqDRzb4fSA== react-jss@^10.6.0: - version "10.6.0" - resolved "https://registry.yarnpkg.com/react-jss/-/react-jss-10.6.0.tgz#3d1538d085c55f7b0bc3607a61943f588e56f0f6" - integrity sha512-uCvOHMoQrB+cD8l6K6+gIStqBhTyjPM/55sXHfujlr0E4GclQg0ZR26nyGyh7XB+v9a2FfMp6Y4L2Bc1Z+L1oQ== + version "10.10.0" + resolved "https://registry.yarnpkg.com/react-jss/-/react-jss-10.10.0.tgz#d08ab3257b0eed01e15d6d8275840055c279b0da" + integrity sha512-WLiq84UYWqNBF6579/uprcIUnM1TSywYq6AIjKTTTG5ziJl9Uy+pwuvpN3apuyVwflMbD60PraeTKT7uWH9XEQ== dependencies: "@babel/runtime" "^7.3.1" "@emotion/is-prop-valid" "^0.7.3" - css-jss "10.6.0" + css-jss "10.10.0" hoist-non-react-statics "^3.2.0" is-in-browser "^1.1.3" - jss "10.6.0" - jss-preset-default "10.6.0" + jss "10.10.0" + jss-preset-default "10.10.0" prop-types "^15.6.0" shallow-equal "^1.2.0" theming "^3.3.0" tiny-warning "^1.0.2" -react-refresh@0.8.3: - version "0.8.3" - resolved "https://registry.yarnpkg.com/react-refresh/-/react-refresh-0.8.3.tgz#721d4657672d400c5e3c75d063c4a85fb2d5d68f" - integrity sha512-X8jZHc7nCMjaCqoU+V2I0cOhNW+QMBwSUkeXnTi8IPe6zaRWfn60ZzvFDZqWPfmSJfjub7dDW1SP0jaHWLu/hg== - react-transition-group@^4.4.0: version "4.4.1" resolved "https://registry.yarnpkg.com/react-transition-group/-/react-transition-group-4.4.1.tgz#63868f9325a38ea5ee9535d828327f85773345c9" @@ -6712,13 +6298,12 @@ react-transition-group@^4.4.0: loose-envify "^1.4.0" prop-types "^15.6.2" -react@^17.0.2: - version "17.0.2" - resolved "https://registry.yarnpkg.com/react/-/react-17.0.2.tgz#d0b5cc516d29eb3eee383f75b62864cfb6800037" - integrity sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA== +react@^18.2.0: + version "18.2.0" + resolved "https://registry.yarnpkg.com/react/-/react-18.2.0.tgz#555bd98592883255fa00de14f1151a917b5d77d5" + integrity sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" read-pkg-up@^3.0.0: version "3.0.0" @@ -6737,20 +6322,7 @@ read-pkg@^3.0.0: normalize-package-data "^2.3.2" path-type "^3.0.0" -readable-stream@^2.0.2, readable-stream@^2.3.3, readable-stream@^2.3.6: - version "2.3.7" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" - integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== - dependencies: - 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" - -readable-stream@^3.0.2, readable-stream@^3.5.0, readable-stream@^3.6.0: +readable-stream@^3.0.2: version "3.6.0" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== @@ -6759,34 +6331,27 @@ readable-stream@^3.0.2, readable-stream@^3.5.0, readable-stream@^3.6.0: string_decoder "^1.1.1" util-deprecate "^1.0.1" -readdirp@~3.5.0: - version "3.5.0" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.5.0.tgz#9ba74c019b15d365278d2e91bb8c48d7b4d42c9e" - integrity sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ== - dependencies: - picomatch "^2.2.1" - -regenerate-unicode-properties@^8.2.0: - version "8.2.0" - resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-8.2.0.tgz#e5de7111d655e7ba60c057dbe9ff37c87e65cdec" - integrity sha512-F9DjY1vKLo/tPePDycuH3dn9H1OTPIkVD9Kz4LODu+F2C75mgjAJ7x/gwy6ZcSNRAAkhNlJSOHRe8k3p+K9WhA== +regenerate-unicode-properties@^10.1.0: + version "10.1.0" + resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz#7c3192cab6dd24e21cb4461e5ddd7dd24fa8374c" + integrity sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ== dependencies: - regenerate "^1.4.0" + regenerate "^1.4.2" -regenerate@^1.4.0: +regenerate@^1.4.2: version "1.4.2" resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.2.tgz#b9346d8827e8f5a32f7ba29637d398b69014848a" integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== -regenerator-runtime@^0.13.4: - version "0.13.7" - resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz#cac2dacc8a1ea675feaabaeb8ae833898ae46f55" - integrity sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew== +regenerator-runtime@^0.13.11, regenerator-runtime@^0.13.4: + version "0.13.11" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz#f6dca3e7ceec20590d07ada785636a90cdca17f9" + integrity sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg== -regenerator-transform@^0.14.2: - version "0.14.5" - resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.14.5.tgz#c98da154683671c9c4dcb16ece736517e1b7feb4" - integrity sha512-eOf6vka5IO151Jfsw2NO9WpGX58W6wWmefK3I1zEGr0lOD0u8rwPaNqQL1aRxUaxLeKO3ArNh3VYg1KbaD+FFw== +regenerator-transform@^0.15.1: + version "0.15.1" + resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.15.1.tgz#f6c4e99fc1b4591f780db2586328e4d9a9d8dc56" + integrity sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg== dependencies: "@babel/runtime" "^7.8.4" @@ -6798,32 +6363,36 @@ regexp.prototype.flags@^1.3.1: call-bind "^1.0.2" define-properties "^1.1.3" +regexp.prototype.flags@^1.4.3: + version "1.5.0" + resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz#fe7ce25e7e4cca8db37b6634c8a2c7009199b9cb" + integrity sha512-0SutC3pNudRKgquxGoRGIz946MZVHqbNfPjBdxeOhBrdgDKlRoXmYLQN9xRbrR09ZXWeGAdPuif7egofn6v5LA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.2.0" + functions-have-names "^1.2.3" + regexpp@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.1.0.tgz#206d0ad0a5648cffbdb8ae46438f3dc51c9f78e2" integrity sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q== -regexpu-core@^4.7.1: - version "4.7.1" - resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-4.7.1.tgz#2dea5a9a07233298fbf0db91fa9abc4c6e0f8ad6" - integrity sha512-ywH2VUraA44DZQuRKzARmw6S66mr48pQVva4LBeRhcOltJ6hExvWly5ZjFLYo67xbIxb6W1q4bAGtgfEl20zfQ== +regexpu-core@^5.3.1: + version "5.3.2" + resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.3.2.tgz#11a2b06884f3527aec3e93dbbf4a3b958a95546b" + integrity sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ== dependencies: - regenerate "^1.4.0" - regenerate-unicode-properties "^8.2.0" - regjsgen "^0.5.1" - regjsparser "^0.6.4" - unicode-match-property-ecmascript "^1.0.4" - unicode-match-property-value-ecmascript "^1.2.0" - -regjsgen@^0.5.1: - version "0.5.2" - resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.5.2.tgz#92ff295fb1deecbf6ecdab2543d207e91aa33733" - integrity sha512-OFFT3MfrH90xIW8OOSyUrk6QHD5E9JOTeGodiJeBS3J6IwlgzJMNE/1bZklWz5oTg+9dCMyEetclvCVXOPoN3A== + "@babel/regjsgen" "^0.8.0" + regenerate "^1.4.2" + regenerate-unicode-properties "^10.1.0" + regjsparser "^0.9.1" + unicode-match-property-ecmascript "^2.0.0" + unicode-match-property-value-ecmascript "^2.1.0" -regjsparser@^0.6.4: - version "0.6.9" - resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.6.9.tgz#b489eef7c9a2ce43727627011429cf833a7183e6" - integrity sha512-ZqbNRz1SNjLAiYuwY0zoXW8Ne675IX5q+YHioAGbCw4X96Mjl2+dcX9B2ciaeyYjViDAfvIjFpQjJgLttTEERQ== +regjsparser@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.9.1.tgz#272d05aa10c7c1f67095b1ff0addae8442fc5709" + integrity sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ== dependencies: jsesc "~0.5.0" @@ -6866,7 +6435,7 @@ resolve-url@~0.2.1: resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a" integrity sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo= -resolve@^1.10.0, resolve@^1.12.0, resolve@^1.13.1, resolve@^1.14.2, resolve@^1.19.0, resolve@^1.20.0: +resolve@^1.10.0, resolve@^1.12.0, resolve@^1.13.1, resolve@^1.20.0: version "1.20.0" resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.20.0.tgz#629a013fb3f70755d6f0b7935cc1c2c5378b1975" integrity sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A== @@ -6874,6 +6443,15 @@ resolve@^1.10.0, resolve@^1.12.0, resolve@^1.13.1, resolve@^1.14.2, resolve@^1.1 is-core-module "^2.2.0" path-parse "^1.0.6" +resolve@^1.14.2, resolve@^1.19.0: + version "1.22.2" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.2.tgz#0ed0943d4e301867955766c9f3e1ae6d01c6845f" + integrity sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g== + dependencies: + is-core-module "^2.11.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + resolve@^2.0.0-next.3: version "2.0.0-next.3" resolved "https://registry.yarnpkg.com/resolve/-/resolve-2.0.0-next.3.tgz#d41016293d4a8586a39ca5d9b5f15cbea1f55e46" @@ -6909,14 +6487,6 @@ rimraf@^3.0.0, rimraf@^3.0.2: dependencies: glob "^7.1.3" -ripemd160@^2.0.0, ripemd160@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.2.tgz#a1c1a6f624751577ba5d07914cbc92850585890c" - integrity sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA== - dependencies: - hash-base "^3.0.0" - inherits "^2.0.1" - rollup-plugin-terser@^7.0.0: version "7.0.2" resolved "https://registry.yarnpkg.com/rollup-plugin-terser/-/rollup-plugin-terser-7.0.2.tgz#e8fbba4869981b2dc35ae7e8a502d5c6c04d324d" @@ -6928,9 +6498,9 @@ rollup-plugin-terser@^7.0.0: terser "^5.0.0" rollup@^2.43.1: - version "2.52.3" - resolved "https://registry.yarnpkg.com/rollup/-/rollup-2.52.3.tgz#062fc3c85f67736d6758749310cfee64836c4e2a" - integrity sha512-QF3Sju8Kl2z0osI4unyOLyUudyhOMK6G0AeqJWgfiyigqLAlnNrfBcDWDx+f1cqn+JU2iIYVkDrgQ6/KtwEfrg== + version "2.79.1" + resolved "https://registry.yarnpkg.com/rollup/-/rollup-2.79.1.tgz#bedee8faef7c9f93a2647ac0108748f497f081c7" + integrity sha512-uKxbd0IhMZOhjAiD5oAFp7BqvkA4Dv47qpOCtaNvng4HBwdbWtdOh8f5nZNuk2rp51PMGk3bzfWu5oayNEuYnw== optionalDependencies: fsevents "~2.3.2" @@ -6953,17 +6523,26 @@ rxjs@^6.6.7: dependencies: tslib "^1.9.0" -safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@^5.1.2, safe-buffer@^5.2.0, safe-buffer@~5.2.0: +safe-buffer@^5.1.0, safe-buffer@~5.2.0: version "5.2.1" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== -safe-buffer@~5.1.0, safe-buffer@~5.1.1: +safe-buffer@~5.1.1: version "5.1.2" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== -"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0", safer-buffer@^2.1.0: +safe-regex-test@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/safe-regex-test/-/safe-regex-test-1.0.0.tgz#793b874d524eb3640d1873aad03596db2d4f2295" + integrity sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.1.3" + is-regex "^1.1.4" + +"safer-buffer@>= 2.1.2 < 3": version "2.1.2" resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== @@ -6980,13 +6559,12 @@ saxes@^5.0.1: dependencies: xmlchars "^2.2.0" -scheduler@^0.20.2: - version "0.20.2" - resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.20.2.tgz#4baee39436e34aa93b4874bddcbf0fe8b8b50e91" - integrity sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ== +scheduler@^0.23.0: + version "0.23.0" + resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.0.tgz#ba8041afc3d30eb206a487b6b384002e4e61fdfe" + integrity sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" schema-utils@^2.6.5: version "2.7.1" @@ -6997,12 +6575,12 @@ schema-utils@^2.6.5: ajv "^6.12.4" ajv-keywords "^3.5.2" -schema-utils@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.0.0.tgz#67502f6aa2b66a2d4032b4279a2944978a0913ef" - integrity sha512-6D82/xSzO094ajanoOSbe4YvXWMfn2A//8Y1+MUqFAJul5Bs+yn36xbK9OtNDcRVSBJ9jjeoXftM6CfztsjOAA== +schema-utils@^3.1.1: + version "3.1.2" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.1.2.tgz#36c10abca6f7577aeae136c804b0c741edeadc99" + integrity sha512-pvjEHOgWc9OWA/f/DE3ohBWTD6EleVLf7iFUkoSwAxttdBhB9QUebQgxER2kWueOvRJXPHNnyrvvh9eZINB8Eg== dependencies: - "@types/json-schema" "^7.0.6" + "@types/json-schema" "^7.0.8" ajv "^6.12.5" ajv-keywords "^3.5.2" @@ -7021,11 +6599,6 @@ semver-regex@^3.1.2: resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== -semver@7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/semver/-/semver-7.0.0.tgz#5f3ca35761e47e05b206c6daff2cf814f0316b8e" - integrity sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A== - semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.3.0: version "6.3.0" resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" @@ -7052,31 +6625,13 @@ serialize-javascript@^4.0.0: dependencies: randombytes "^2.1.0" -serialize-javascript@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.0.tgz#efae5d88f45d7924141da8b5c3a7a7e663fefeb8" - integrity sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag== +serialize-javascript@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.1.tgz#b206efb27c3da0b0ab6b52f48d170b7996458e5c" + integrity sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w== dependencies: randombytes "^2.1.0" -setimmediate@^1.0.4: - version "1.0.5" - resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" - integrity sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU= - -setprototypeof@1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.1.tgz#7e95acb24aa92f5885e0abef5ba131330d4ae683" - integrity sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw== - -sha.js@^2.4.0, sha.js@^2.4.8: - version "2.4.11" - resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.4.11.tgz#37a5cf0b81ecbc6943de109ba2960d1b26584ae7" - integrity sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ== - dependencies: - inherits "^2.0.1" - safe-buffer "^5.0.1" - shallow-equal@^1.2.0: version "1.2.1" resolved "https://registry.yarnpkg.com/shallow-equal/-/shallow-equal-1.2.1.tgz#4c16abfa56043aa20d050324efa68940b0da79da" @@ -7099,11 +6654,6 @@ shebang-regex@^3.0.0: resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== -shell-quote@1.7.2: - version "1.7.2" - resolved "https://registry.yarnpkg.com/shell-quote/-/shell-quote-1.7.2.tgz#67a7d02c76c9da24f99d20808fcaded0e0e04be2" - integrity sha512-mRz/m/JVscCrkMyPqHc/bczi3OQHkLTqXHEFu0zDhK/qfv3UcOA4SVmRCLmos4bhjr9ekVQubj/R7waKapmiQg== - side-channel@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" @@ -7156,7 +6706,12 @@ source-list-map@^2.0.0: resolved "https://registry.yarnpkg.com/source-list-map/-/source-list-map-2.0.1.tgz#3993bd873bfc48479cca9ea3a547835c7c154b34" integrity sha512-qnQ7gVMxGNxsiL4lEuJwe/To8UnK7fAnmbGEEH8RpLouuKbeEm0lhbQVFIrNSuB+G7tVrAlVsZgETT5nljf+Iw== -source-map-support@^0.5.6, source-map-support@~0.5.19: +source-map-js@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" + integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw== + +source-map-support@^0.5.6: version "0.5.19" resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.19.tgz#a98b62f86dcaf4f67399648c085291ab9e8fed61" integrity sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw== @@ -7164,34 +6719,42 @@ source-map-support@^0.5.6, source-map-support@~0.5.19: buffer-from "^1.0.0" source-map "^0.6.0" -source-map-url@^0.4.0: - version "0.4.1" - resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.1.tgz#0af66605a745a5a2f91cf1bbf8a7afbc283dec56" - integrity sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw== +source-map-support@~0.5.20: + version "0.5.21" + resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" + integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" -source-map@0.7.3, source-map@^0.7.3, source-map@~0.7.2: +source-map@0.7.3: version "0.7.3" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.3.tgz#5302f8169031735226544092e64981f751750383" integrity sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ== -source-map@0.8.0-beta.0, source-map@^0.8.0-beta.0: - version "0.8.0-beta.0" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.8.0-beta.0.tgz#d4c1bb42c3f7ee925f005927ba10709e0d1d1f11" - integrity sha512-2ymg6oRBpebeZi9UUNsgQ89bhx01TcTkmNTGnNO88imTmbSgy4nfujrgVEFKWpMTEGA11EDkTt7mqObTPdigIA== - dependencies: - whatwg-url "^7.0.0" - source-map@^0.5.0: version "0.5.7" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" - integrity sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w= + integrity sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ== source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: version "0.6.1" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== -sourcemap-codec@^1.4.4: +source-map@^0.7.3: + version "0.7.4" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.4.tgz#a9bbe705c9d8846f4e08ff6765acf0f1b0898656" + integrity sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA== + +source-map@^0.8.0-beta.0: + version "0.8.0-beta.0" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.8.0-beta.0.tgz#d4c1bb42c3f7ee925f005927ba10709e0d1d1f11" + integrity sha512-2ymg6oRBpebeZi9UUNsgQ89bhx01TcTkmNTGnNO88imTmbSgy4nfujrgVEFKWpMTEGA11EDkTt7mqObTPdigIA== + dependencies: + whatwg-url "^7.0.0" + +sourcemap-codec@^1.4.8: version "1.4.8" resolved "https://registry.yarnpkg.com/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz#ea804bd94857402e6992d05a38ef1ae35a9ab4c4" integrity sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA== @@ -7234,66 +6797,15 @@ stack-utils@^2.0.3: dependencies: escape-string-regexp "^2.0.0" -stacktrace-parser@0.1.10: - version "0.1.10" - resolved "https://registry.yarnpkg.com/stacktrace-parser/-/stacktrace-parser-0.1.10.tgz#29fb0cae4e0d0b85155879402857a1639eb6051a" - integrity sha512-KJP1OCML99+8fhOHxwwzyWrlUuVX5GQ0ZpJTd1DFXhdkrvg1szxfHhawXUZ3g9TkXORQd4/WG68jMlQZ2p8wlg== - dependencies: - type-fest "^0.7.1" - -"statuses@>= 1.5.0 < 2": - version "1.5.0" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" - integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= - store@~2.0.12: version "2.0.12" resolved "https://registry.yarnpkg.com/store/-/store-2.0.12.tgz#8c534e2a0b831f72b75fc5f1119857c44ef5d593" integrity sha1-jFNOKguDH3K3X8XxEZhXxE711ZM= -stream-browserify@3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-3.0.0.tgz#22b0a2850cdf6503e73085da1fc7b7d0c2122f2f" - integrity sha512-H73RAHsVBapbim0tU2JwwOiXUj+fikfiaoYAKHF3VJfA0pe2BCzkhAHBlLG6REzE+2WNZcxOXjK7lkso+9euLA== - dependencies: - inherits "~2.0.4" - readable-stream "^3.5.0" - -stream-browserify@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-2.0.2.tgz#87521d38a44aa7ee91ce1cd2a47df0cb49dd660b" - integrity sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg== - dependencies: - inherits "~2.0.1" - readable-stream "^2.0.2" - -stream-http@3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-3.1.1.tgz#0370a8017cf8d050b9a8554afe608f043eaff564" - integrity sha512-S7OqaYu0EkFpgeGFb/NPOoPLxFko7TPqtEeFg5DXPB4v/KETHG0Ln6fRFrNezoelpaDKmycEmmZ81cC9DAwgYg== - dependencies: - builtin-status-codes "^3.0.0" - inherits "^2.0.4" - readable-stream "^3.6.0" - xtend "^4.0.2" - -stream-http@^2.7.2: - version "2.8.3" - resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-2.8.3.tgz#b2d242469288a5a27ec4fe8933acf623de6514fc" - integrity sha512-+TSkfINHDo4J+ZobQLWiMouQYB+UVYFttRA94FpEzzJ7ZdqcL4uUUQ7WkdkI4DSozGmgBUE/a47L+38PenXhUw== - dependencies: - builtin-status-codes "^3.0.0" - inherits "^2.0.1" - readable-stream "^2.3.6" - to-arraybuffer "^1.0.0" - xtend "^4.0.0" - -stream-parser@^0.3.1: - version "0.3.1" - resolved "https://registry.yarnpkg.com/stream-parser/-/stream-parser-0.3.1.tgz#1618548694420021a1182ff0af1911c129761773" - integrity sha1-FhhUhpRCACGhGC/wrxkRwSl2F3M= - dependencies: - debug "2" +streamsearch@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/streamsearch/-/streamsearch-1.1.0.tgz#404dd1e2247ca94af554e841a8ef0eaa238da764" + integrity sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg== string-argv@0.3.1: version "0.3.1" @@ -7303,7 +6815,7 @@ string-argv@0.3.1: string-hash@1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/string-hash/-/string-hash-1.1.3.tgz#e8aafc0ac1855b4666929ed7dd1275df5d6c811b" - integrity sha1-6Kr8CsGFW0Zmkp7X3RJ1311sgRs= + integrity sha512-kJUvRUFK49aub+a7T1nNE66EJbZBMnBgoC1UbCZ5n6bsZKBRga4KgBRTMn/pFkeCZSYtNeSyMxPDM0AXWELk2A== string-length@^4.0.1: version "4.0.1" @@ -7336,36 +6848,54 @@ string.prototype.matchall@^4.0.5: regexp.prototype.flags "^1.3.1" side-channel "^1.0.4" -string.prototype.trimend@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz#e75ae90c2942c63504686c18b287b4a0b1a45f80" - integrity sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A== +string.prototype.matchall@^4.0.6: + version "4.0.8" + resolved "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.8.tgz#3bf85722021816dcd1bf38bb714915887ca79fd3" + integrity sha512-6zOCOcJ+RJAQshcTvXPHoxoQGONa3e/Lqx90wUA+wEzX78sg5Bo+1tQo4N0pohS0erG9qtCqJDjNCQBjeWVxyg== dependencies: call-bind "^1.0.2" - define-properties "^1.1.3" + define-properties "^1.1.4" + es-abstract "^1.20.4" + get-intrinsic "^1.1.3" + has-symbols "^1.0.3" + internal-slot "^1.0.3" + regexp.prototype.flags "^1.4.3" + side-channel "^1.0.4" -string.prototype.trimstart@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz#b36399af4ab2999b4c9c648bd7a3fb2bb26feeed" - integrity sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw== +string.prototype.trim@^1.2.7: + version "1.2.7" + resolved "https://registry.yarnpkg.com/string.prototype.trim/-/string.prototype.trim-1.2.7.tgz#a68352740859f6893f14ce3ef1bb3037f7a90533" + integrity sha512-p6TmeT1T3411M8Cgg9wBTMRtY2q9+PNy9EV1i2lIXUN/btt763oIfxwN3RR8VU6wHX8j/1CFy0L+YuThm6bgOg== dependencies: call-bind "^1.0.2" - define-properties "^1.1.3" + define-properties "^1.1.4" + es-abstract "^1.20.4" + +string.prototype.trimend@^1.0.4, string.prototype.trimend@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz#c4a27fa026d979d79c04f17397f250a462944533" + integrity sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.20.4" + +string.prototype.trimstart@^1.0.4, string.prototype.trimstart@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz#e90ab66aa8e4007d92ef591bbf3cd422c56bdcf4" + integrity sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.20.4" -string_decoder@1.3.0, string_decoder@^1.0.0, string_decoder@^1.1.1: +string_decoder@^1.1.1: version "1.3.0" resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== dependencies: safe-buffer "~5.2.0" -string_decoder@~1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" - integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== - dependencies: - safe-buffer "~5.1.0" - stringify-object@^3.3.0: version "3.3.0" resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" @@ -7375,7 +6905,7 @@ stringify-object@^3.3.0: is-obj "^1.0.1" is-regexp "^1.0.0" -strip-ansi@6.0.0, strip-ansi@^6.0.0: +strip-ansi@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w== @@ -7423,19 +6953,12 @@ styled-components@^5.3.0: shallowequal "^1.1.0" supports-color "^5.5.0" -styled-jsx@3.3.2: - version "3.3.2" - resolved "https://registry.yarnpkg.com/styled-jsx/-/styled-jsx-3.3.2.tgz#2474601a26670a6049fb4d3f94bd91695b3ce018" - integrity sha512-daAkGd5mqhbBhLd6jYAjYBa9LpxYCzsgo/f6qzPdFxVB8yoGbhxvzQgkC0pfmCVvW3JuAEBn0UzFLBfkHVZG1g== +styled-jsx@5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/styled-jsx/-/styled-jsx-5.1.1.tgz#839a1c3aaacc4e735fed0781b8619ea5d0009d1f" + integrity sha512-pW7uC1l4mBZ8ugbiZrcIsiIvVx1UmTfw7UkC3Um2tmfUq9Bhk8IiyEIPl6F8agHgjzku6j0xQEZbfA5uSgSaCw== dependencies: - "@babel/types" "7.8.3" - babel-plugin-syntax-jsx "6.18.0" - convert-source-map "1.7.0" - loader-utils "1.2.3" - source-map "0.7.3" - string-hash "1.1.3" - stylis "3.5.4" - stylis-rule-sheet "0.0.10" + client-only "0.0.1" styled-jsx@^3.4.4: version "3.4.4" @@ -7498,6 +7021,11 @@ supports-hyperlinks@^2.0.0: has-flag "^4.0.0" supports-color "^7.0.0" +supports-preserve-symlinks-flag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" + integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== + symbol-observable@1.2.0, symbol-observable@^1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.2.0.tgz#c22688aed4eab3cdc2dfeacbb561660560a00804" @@ -7543,26 +7071,26 @@ terminal-link@^2.0.0: ansi-escapes "^4.2.1" supports-hyperlinks "^2.0.0" -terser-webpack-plugin@^5.1.1: - version "5.1.4" - resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.1.4.tgz#c369cf8a47aa9922bd0d8a94fe3d3da11a7678a1" - integrity sha512-C2WkFwstHDhVEmsmlCxrXUtVklS+Ir1A7twrYzrDrQQOIMOaVAYykaoo/Aq1K0QRkMoY2hhvDQY1cm4jnIMFwA== +terser-webpack-plugin@^5.3.3: + version "5.3.9" + resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.9.tgz#832536999c51b46d468067f9e37662a3b96adfe1" + integrity sha512-ZuXsqE07EcggTWQjXUj+Aot/OMcD0bMKGgF63f7UxYcu5/AJF53aIpK1YoP5xR9l6s/Hy2b+t1AM0bLNPRuhwA== dependencies: - jest-worker "^27.0.2" - p-limit "^3.1.0" - schema-utils "^3.0.0" - serialize-javascript "^6.0.0" - source-map "^0.6.1" - terser "^5.7.0" + "@jridgewell/trace-mapping" "^0.3.17" + jest-worker "^27.4.5" + schema-utils "^3.1.1" + serialize-javascript "^6.0.1" + terser "^5.16.8" -terser@^5.0.0, terser@^5.7.0: - version "5.7.0" - resolved "https://registry.yarnpkg.com/terser/-/terser-5.7.0.tgz#a761eeec206bc87b605ab13029876ead938ae693" - integrity sha512-HP5/9hp2UaZt5fYkuhNBR8YyRcT8juw8+uFbAme53iN9hblvKnLUTKkmwJG6ocWpIKf8UK4DoeWG4ty0J6S6/g== +terser@^5.0.0, terser@^5.16.8: + version "5.17.4" + resolved "https://registry.yarnpkg.com/terser/-/terser-5.17.4.tgz#b0c2d94897dfeba43213ed5f90ed117270a2c696" + integrity sha512-jcEKZw6UPrgugz/0Tuk/PVyLAPfMBJf5clnGueo45wTweoV8yh7Q7PEkhkJ5uuUbC7zAxEcG3tqNr1bstkQ8nw== dependencies: + "@jridgewell/source-map" "^0.3.2" + acorn "^8.5.0" commander "^2.20.0" - source-map "~0.7.2" - source-map-support "~0.5.19" + source-map-support "~0.5.20" test-exclude@^6.0.0: version "6.0.0" @@ -7598,13 +7126,6 @@ through@^2.3.8: resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" integrity sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU= -timers-browserify@2.0.12, timers-browserify@^2.0.4: - version "2.0.12" - resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-2.0.12.tgz#44a45c11fbf407f34f97bccd1577c652361b00ee" - integrity sha512-9phl76Cqm6FhSX9Xe1ZUAMLtm1BLkKj2Qd5ApyWkXzsMRaA7dgr81kf4wJmQf/hAvg8EEyJxDo3du/0KlhPiKQ== - dependencies: - setimmediate "^1.0.4" - tiny-warning@^1.0.2: version "1.0.3" resolved "https://registry.yarnpkg.com/tiny-warning/-/tiny-warning-1.0.3.tgz#94a30db453df4c643d0fd566060d60a875d84754" @@ -7620,27 +7141,22 @@ tmpl@1.0.x: resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.4.tgz#23640dd7b42d00433911140820e5cf440e521dd1" integrity sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE= -to-arraybuffer@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz#7d229b1fcc637e466ca081180836a7aabff83f43" - integrity sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M= - to-camel-case@1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/to-camel-case/-/to-camel-case-1.0.0.tgz#1a56054b2f9d696298ce66a60897322b6f423e46" - integrity sha1-GlYFSy+daWKYzmamCJcyK29CPkY= + integrity sha512-nD8pQi5H34kyu1QDMFjzEIYqk0xa9Alt6ZfrdEMuHCFOfTLhDG5pgTu/aAM9Wt9lXILwlXmWP43b8sav0GNE8Q== dependencies: to-space-case "^1.0.0" to-fast-properties@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" - integrity sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4= + integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== to-no-case@^1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/to-no-case/-/to-no-case-1.0.2.tgz#c722907164ef6b178132c8e69930212d1b4aa16a" - integrity sha1-xyKQcWTvaxeBMsjmmTAhLRtKoWo= + integrity sha512-Z3g735FxuZY8rodxV4gH7LxClE4H0hTIyHNIHdk+vpQxjLm0cwnKXq/OFVZ76SOQmto7txVcwSCwkU5kqp+FKg== to-regex-range@^5.0.1: version "5.0.1" @@ -7652,15 +7168,10 @@ to-regex-range@^5.0.1: to-space-case@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/to-space-case/-/to-space-case-1.0.0.tgz#b052daafb1b2b29dc770cea0163e5ec0ebc9fc17" - integrity sha1-sFLar7Gysp3HcM6gFj5ewOvJ/Bc= + integrity sha512-rLdvwXZ39VOn1IxGL3V6ZstoTbwLRckQmn/U8ZDLuWwIXNpuZDhQ3AiRUlhTbOXFVE9C+dR51wM0CBDhk31VcA== dependencies: to-no-case "^1.0.0" -toidentifier@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553" - integrity sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw== - tough-cookie@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.0.0.tgz#d822234eeca882f991f0f908824ad2622ddbece4" @@ -7673,7 +7184,7 @@ tough-cookie@^4.0.0: tr46@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/tr46/-/tr46-1.0.1.tgz#a8b13fd6bfd2489519674ccde55ba3693b706d09" - integrity sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk= + integrity sha512-dTpowEjclQ7Kgx5SdBkqRzVhERQXov8/l9Ft9dVM9fmg0W0KQSVaXX9T4i6twCPNtYiZM53lpSSUAwJbFPOHxA== dependencies: punycode "^2.1.0" @@ -7684,11 +7195,6 @@ tr46@^2.0.2: dependencies: punycode "^2.1.1" -ts-pnp@^1.1.6: - version "1.2.0" - resolved "https://registry.yarnpkg.com/ts-pnp/-/ts-pnp-1.2.0.tgz#a500ad084b0798f1c3071af391e65912c86bca92" - integrity sha512-csd+vJOb/gkzvcCHgTGSChYpy5f1/XKNsmvBGO4JXS+z1v2HobugDz4s1IeFXM3wZB44uczs+eazB5Q/ccdhQw== - tsconfig-paths@^3.9.0: version "3.9.0" resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.9.0.tgz#098547a6c4448807e8fcb8eae081064ee9a3c90b" @@ -7704,6 +7210,11 @@ tslib@^1.8.1, tslib@^1.9.0, tslib@^1.9.3: resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== +tslib@^2.4.0: + version "2.5.2" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.5.2.tgz#1b6f07185c881557b0ffa84b111a0106989e8338" + integrity sha512-5svOrSA2w3iGFDs1HibEVBGbDrAY82bFQ3HZ3ixB+88nsbsWQoKqDRb5UBYAUPEzbBn6dAp5gRNXglySbx1MlA== + tsutils@^3.17.1, tsutils@^3.21.0: version "3.21.0" resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" @@ -7711,16 +7222,6 @@ tsutils@^3.17.1, tsutils@^3.21.0: dependencies: tslib "^1.8.1" -tty-browserify@0.0.0: - version "0.0.0" - resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.0.tgz#a157ba402da24e9bf957f9aa69d524eed42901a6" - integrity sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY= - -tty-browserify@0.0.1: - version "0.0.1" - resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.1.tgz#3f05251ee17904dfd0677546670db9651682b811" - integrity sha512-C3TaO7K81YvjCgQH9Q1S3R3P3BtN3RIM8n+OvX4il1K1zgE8ZhI0op7kClgkxtutIE8hQrcrHBXvIheqKUUCxw== - type-check@^0.4.0, type-check@~0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" @@ -7755,16 +7256,20 @@ type-fest@^0.20.2: resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== -type-fest@^0.7.1: - version "0.7.1" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.7.1.tgz#8dda65feaf03ed78f0a3f9678f1869147f7c5c48" - integrity sha512-Ne2YiiGN8bmrmJJEuTWTLJR32nh/JdL1+PSicowtNb0WFpn59GK8/lfD61bVtzguz7b3PBt74nxpv/Pw5po5Rg== - type-fest@^0.8.1: version "0.8.1" resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== +typed-array-length@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/typed-array-length/-/typed-array-length-1.0.4.tgz#89d83785e5c4098bec72e08b319651f0eac9c1bb" + integrity sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng== + dependencies: + call-bind "^1.0.2" + for-each "^0.3.3" + is-typed-array "^1.1.9" + typedarray-to-buffer@^3.1.5: version "3.1.5" resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" @@ -7777,20 +7282,10 @@ typedarray@^0.0.6: resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" integrity sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c= -typescript@^4.3.2: - version "4.3.2" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.3.2.tgz#399ab18aac45802d6f2498de5054fcbbe716a805" - integrity sha512-zZ4hShnmnoVnAHpVHWpTcxdv7dWP60S2FsydQLV8V5PbS3FifjWFFRiHSWpDJahly88PRyV5teTSLoq4eG7mKw== - -unbox-primitive@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.0.tgz#eeacbc4affa28e9b3d36b5eaeccc50b3251b1d3f" - integrity sha512-P/51NX+JXyxK/aigg1/ZgyccdAxm5K1+n8+tvqSntjOivPt19gvm1VC49RWYetsiub8WViUchdxl/KWHHB0kzA== - dependencies: - function-bind "^1.1.1" - has-bigints "^1.0.0" - has-symbols "^1.0.0" - which-boxed-primitive "^1.0.1" +typescript@^5.0.4: + version "5.0.4" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.0.4.tgz#b217fd20119bd61a94d4011274e0ab369058da3b" + integrity sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw== unbox-primitive@^1.0.1: version "1.0.1" @@ -7802,33 +7297,43 @@ unbox-primitive@^1.0.1: has-symbols "^1.0.2" which-boxed-primitive "^1.0.2" +unbox-primitive@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" + integrity sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw== + dependencies: + call-bind "^1.0.2" + has-bigints "^1.0.2" + has-symbols "^1.0.3" + which-boxed-primitive "^1.0.2" + unfetch@^4.2.0: version "4.2.0" resolved "https://registry.yarnpkg.com/unfetch/-/unfetch-4.2.0.tgz#7e21b0ef7d363d8d9af0fb929a5555f6ef97a3be" integrity sha512-F9p7yYCn6cIW9El1zi0HI6vqpeIvBsr3dSuRO6Xuppb1u5rXpCPmMvLSyECLhybr9isec8Ohl0hPekMVrEinDA== -unicode-canonical-property-names-ecmascript@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz#2619800c4c825800efdd8343af7dd9933cbe2818" - integrity sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ== +unicode-canonical-property-names-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz#301acdc525631670d39f6146e0e77ff6bbdebddc" + integrity sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ== -unicode-match-property-ecmascript@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz#8ed2a32569961bce9227d09cd3ffbb8fed5f020c" - integrity sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg== +unicode-match-property-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz#54fd16e0ecb167cf04cf1f756bdcc92eba7976c3" + integrity sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q== dependencies: - unicode-canonical-property-names-ecmascript "^1.0.4" - unicode-property-aliases-ecmascript "^1.0.4" + unicode-canonical-property-names-ecmascript "^2.0.0" + unicode-property-aliases-ecmascript "^2.0.0" -unicode-match-property-value-ecmascript@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.2.0.tgz#0d91f600eeeb3096aa962b1d6fc88876e64ea531" - integrity sha512-wjuQHGQVofmSJv1uVISKLE5zO2rNGzM/KCYZch/QQvez7C1hUhBIuZ701fYXExuufJFMPhv2SyL8CyoIfMLbIQ== +unicode-match-property-value-ecmascript@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz#cb5fffdcd16a05124f5a4b0bf7c3770208acbbe0" + integrity sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA== -unicode-property-aliases-ecmascript@^1.0.4: - version "1.1.0" - resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.1.0.tgz#dd57a99f6207bedff4628abefb94c50db941c8f4" - integrity sha512-PqSoPh/pWetQ2phoj5RLiaqIk4kCNwoV3CI+LfGmWLKI3rE3kl1h59XpX2BjgDrmbxD9ARtQobPGU1SguCYuQg== +unicode-property-aliases-ecmascript@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz#43d41e3be698bd493ef911077c9b131f827e8ccd" + integrity sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w== unique-string@^2.0.0: version "2.0.0" @@ -7855,16 +7360,19 @@ universalify@^2.0.0: resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== -unpipe@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" - integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= - upath@^1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/upath/-/upath-1.2.0.tgz#8f66dbcd55a883acdae4408af8b035a5044c1894" integrity sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg== +update-browserslist-db@^1.0.10: + version "1.0.11" + resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz#9a2a641ad2907ae7b3616506f4b977851db5b940" + integrity sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA== + dependencies: + escalade "^3.1.1" + picocolors "^1.0.0" + uri-js@^4.2.2: version "4.4.1" resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" @@ -7872,51 +7380,10 @@ uri-js@^4.2.2: dependencies: punycode "^2.1.0" -url@^0.11.0: - version "0.11.0" - resolved "https://registry.yarnpkg.com/url/-/url-0.11.0.tgz#3838e97cfc60521eb73c525a8e55bfdd9e2e28f1" - integrity sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE= - dependencies: - punycode "1.3.2" - querystring "0.2.0" - -use-subscription@1.5.1: - version "1.5.1" - resolved "https://registry.yarnpkg.com/use-subscription/-/use-subscription-1.5.1.tgz#73501107f02fad84c6dd57965beb0b75c68c42d1" - integrity sha512-Xv2a1P/yReAjAbhylMfFplFKj9GssgTwN7RlcTxBujFQcloStWNDQdc4g4NRWH9xS4i/FDk04vQBptAXoF3VcA== - dependencies: - object-assign "^4.1.1" - -util-deprecate@^1.0.1, util-deprecate@~1.0.1: +util-deprecate@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" - integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= - -util@0.10.3: - version "0.10.3" - resolved "https://registry.yarnpkg.com/util/-/util-0.10.3.tgz#7afb1afe50805246489e3db7fe0ed379336ac0f9" - integrity sha1-evsa/lCAUkZInj23/g7TeTNqwPk= - dependencies: - inherits "2.0.1" - -util@0.12.3, util@^0.12.0: - version "0.12.3" - resolved "https://registry.yarnpkg.com/util/-/util-0.12.3.tgz#971bb0292d2cc0c892dab7c6a5d37c2bec707888" - integrity sha512-I8XkoQwE+fPQEhy9v012V+TSdH2kp9ts29i20TaaDUXsg7x/onePbhFJUExBfv/2ay1ZOp/Vsm3nDlmnFGSAog== - dependencies: - inherits "^2.0.3" - is-arguments "^1.0.4" - is-generator-function "^1.0.7" - is-typed-array "^1.1.3" - safe-buffer "^5.1.2" - which-typed-array "^1.1.2" - -util@^0.11.0: - version "0.11.1" - resolved "https://registry.yarnpkg.com/util/-/util-0.11.1.tgz#3236733720ec64bb27f6e26f421aaa2e1b588d61" - integrity sha512-HShAsny+zS2TZfaXxD9tYj4HQGlBezXZMZuM/S5PKLLoZkShZiGk9o5CzukI1LVHZvjdvZ2Sj1aW/Ndn2NB/HQ== - dependencies: - inherits "2.0.3" + integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== v8-compile-cache@^2.0.3: version "2.3.0" @@ -7940,11 +7407,6 @@ validate-npm-package-license@^3.0.1: spdx-correct "^3.0.0" spdx-expression-parse "^3.0.0" -vm-browserify@1.1.2, vm-browserify@^1.0.1: - version "1.1.2" - resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-1.1.2.tgz#78641c488b8e6ca91a75f511e7a3b32a86e5dda0" - integrity sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ== - vt-pbf@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/vt-pbf/-/vt-pbf-3.1.1.tgz#b0f627e39a10ce91d943b898ed2363d21899fb82" @@ -7975,14 +7437,6 @@ walker@^1.0.7: dependencies: makeerror "1.0.x" -watchpack@2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-2.1.1.tgz#e99630550fca07df9f90a06056987baa40a689c7" - integrity sha512-Oo7LXCmc1eE1AjyuSBmtC3+Wy4HcV8PxWh2kP6fOl8yTlNS7r0K9l1ao2lrrUza7V39Y3D/BbJgY8VeSlc5JKw== - dependencies: - glob-to-regexp "^0.4.1" - graceful-fs "^4.1.2" - webidl-conversions@^4.0.2: version "4.0.2" resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-4.0.2.tgz#a855980b1f0b6b359ba1d5d9fb39ae941faa63ad" @@ -8045,7 +7499,7 @@ whatwg-url@^8.5.0: tr46 "^2.0.2" webidl-conversions "^6.1.0" -which-boxed-primitive@^1.0.1, which-boxed-primitive@^1.0.2: +which-boxed-primitive@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz#13757bc89b209b049fe5d86430e21cf40a89a8e6" integrity sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg== @@ -8061,18 +7515,17 @@ which-pm-runs@^1.0.0: resolved "https://registry.yarnpkg.com/which-pm-runs/-/which-pm-runs-1.0.0.tgz#670b3afbc552e0b55df6b7780ca74615f23ad1cb" integrity sha1-Zws6+8VS4LVd9rd4DKdGFfI60cs= -which-typed-array@^1.1.2: - version "1.1.4" - resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.4.tgz#8fcb7d3ee5adf2d771066fba7cf37e32fe8711ff" - integrity sha512-49E0SpUe90cjpoc7BOJwyPHRqSAd12c10Qm2amdEZrJPCY2NDxaW01zHITrem+rnETY3dwrbH3UUrUwagfCYDA== +which-typed-array@^1.1.9: + version "1.1.9" + resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.9.tgz#307cf898025848cf995e795e8423c7f337efbde6" + integrity sha512-w9c4xkx6mPidwp7180ckYWfMmvxpjlZuIudNtDf4N/tTAUB8VJbX25qZoAsrtGuYNnGw3pa0AXgbGKRB8/EceA== dependencies: - available-typed-arrays "^1.0.2" - call-bind "^1.0.0" - es-abstract "^1.18.0-next.1" - foreach "^2.0.5" - function-bind "^1.1.1" - has-symbols "^1.0.1" - is-typed-array "^1.1.3" + available-typed-arrays "^1.0.5" + call-bind "^1.0.2" + for-each "^0.3.3" + gopd "^1.0.1" + has-tostringtag "^1.0.0" + is-typed-array "^1.1.10" which@^2.0.1: version "2.0.2" @@ -8086,33 +7539,35 @@ word-wrap@^1.2.3, word-wrap@~1.2.3: resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== -workbox-background-sync@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-background-sync/-/workbox-background-sync-6.1.5.tgz#83904fc6487722db98ed9b19eaa39ab5f826c33e" - integrity sha512-VbUmPLsdz+sLzuNxHvMylzyRTiM4q+q7rwLBk3p2mtRL5NZozI8j/KgoGbno96vs84jx4b9zCZMEOIKEUTPf6w== +workbox-background-sync@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-background-sync/-/workbox-background-sync-6.5.4.tgz#3141afba3cc8aa2ae14c24d0f6811374ba8ff6a9" + integrity sha512-0r4INQZMyPky/lj4Ou98qxcThrETucOde+7mRGJl13MPJugQNKeZQOdIJe/1AchOP23cTqHcN/YVpD6r8E6I8g== dependencies: - workbox-core "^6.1.5" + idb "^7.0.1" + workbox-core "6.5.4" -workbox-broadcast-update@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-broadcast-update/-/workbox-broadcast-update-6.1.5.tgz#49a2a4cc50c7b1cfe86bed6d8f15edf1891d1e79" - integrity sha512-zGrTTs+n4wHpYtqYMqBg6kl/x5j1UrczGCQnODSHTxIDV8GXLb/GtA1BCZdysNxpMmdVSeLmTcgIYAAqWFamrA== +workbox-broadcast-update@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-broadcast-update/-/workbox-broadcast-update-6.5.4.tgz#8441cff5417cd41f384ba7633ca960a7ffe40f66" + integrity sha512-I/lBERoH1u3zyBosnpPEtcAVe5lwykx9Yg1k6f8/BGEPGaMMgZrwVrqL1uA9QZ1NGGFoyE6t9i7lBjOlDhFEEw== dependencies: - workbox-core "^6.1.5" + workbox-core "6.5.4" -workbox-build@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-build/-/workbox-build-6.1.5.tgz#31c3034a38527f1f7697335c15af9c5593168841" - integrity sha512-P+fakR5QFVqJN9l9xHVXtmafga72gh9I+jM3A9HiB/6UNRmOAejXnDgD+RMegOHgQHPwnB44TalMToFaXKWIyA== +workbox-build@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-build/-/workbox-build-6.5.4.tgz#7d06d31eb28a878817e1c991c05c5b93409f0389" + integrity sha512-kgRevLXEYvUW9WS4XoziYqZ8Q9j/2ziJYEtTrjdz5/L/cTUa2XfyMP2i7c3p34lgqJ03+mTiz13SdFef2POwbA== dependencies: + "@apideck/better-ajv-errors" "^0.3.1" "@babel/core" "^7.11.1" "@babel/preset-env" "^7.11.0" "@babel/runtime" "^7.11.2" - "@hapi/joi" "^16.1.8" "@rollup/plugin-babel" "^5.2.0" "@rollup/plugin-node-resolve" "^11.2.1" "@rollup/plugin-replace" "^2.4.1" - "@surma/rollup-plugin-off-main-thread" "^1.4.1" + "@surma/rollup-plugin-off-main-thread" "^2.2.3" + ajv "^8.6.0" common-tags "^1.8.0" fast-json-stable-stringify "^2.1.0" fs-extra "^9.0.1" @@ -8122,136 +7577,136 @@ workbox-build@^6.1.5: rollup "^2.43.1" rollup-plugin-terser "^7.0.0" source-map "^0.8.0-beta.0" - source-map-url "^0.4.0" stringify-object "^3.3.0" strip-comments "^2.0.1" tempy "^0.6.0" upath "^1.2.0" - workbox-background-sync "^6.1.5" - workbox-broadcast-update "^6.1.5" - workbox-cacheable-response "^6.1.5" - workbox-core "^6.1.5" - workbox-expiration "^6.1.5" - workbox-google-analytics "^6.1.5" - workbox-navigation-preload "^6.1.5" - workbox-precaching "^6.1.5" - workbox-range-requests "^6.1.5" - workbox-recipes "^6.1.5" - workbox-routing "^6.1.5" - workbox-strategies "^6.1.5" - workbox-streams "^6.1.5" - workbox-sw "^6.1.5" - workbox-window "^6.1.5" - -workbox-cacheable-response@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-cacheable-response/-/workbox-cacheable-response-6.1.5.tgz#2772e09a333cba47b0923ed91fd022416b69e75c" - integrity sha512-x8DC71lO/JCgiaJ194l9le8wc8lFPLgUpDkLhp2si7mXV6S/wZO+8Osvw1LLgYa8YYTWGbhbFhFTXIkEMknIIA== - dependencies: - workbox-core "^6.1.5" - -workbox-core@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-core/-/workbox-core-6.1.5.tgz#424ff600e2c5448b14ebd58b2f5ac8ed91b73fb9" - integrity sha512-9SOEle7YcJzg3njC0xMSmrPIiFjfsFm9WjwGd5enXmI8Lwk8wLdy63B0nzu5LXoibEmS9k+aWF8EzaKtOWjNSA== - -workbox-expiration@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-expiration/-/workbox-expiration-6.1.5.tgz#a62a4ac953bb654aa969ede13507ca5bd154adc2" - integrity sha512-6cN+FVbh8fNq56LFKPMchGNKCJeyboHsDuGBqmhDUPvD4uDjsegQpDQzn52VaE0cpywbSIsDF/BSq9E9Yjh5oQ== - dependencies: - workbox-core "^6.1.5" - -workbox-google-analytics@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-google-analytics/-/workbox-google-analytics-6.1.5.tgz#895fcc50e4976c176b5982e1a8fd08776f18d639" - integrity sha512-LYsJ/VxTkYVLxM1uJKXZLz4cJdemidY7kPyAYtKVZ6EiDG89noASqis75/5lhqM1m3HwQfp2DtoPrelKSpSDBA== - dependencies: - workbox-background-sync "^6.1.5" - workbox-core "^6.1.5" - workbox-routing "^6.1.5" - workbox-strategies "^6.1.5" - -workbox-navigation-preload@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-navigation-preload/-/workbox-navigation-preload-6.1.5.tgz#47a0d3a6d2e74bd3a52b58b72ca337cb5b654310" - integrity sha512-hDbNcWlffv0uvS21jCAC/mYk7NzaGRSWOQXv1p7bj2aONAX5l699D2ZK4D27G8TO0BaLHUmW/1A5CZcsvweQdg== - dependencies: - workbox-core "^6.1.5" - -workbox-precaching@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-precaching/-/workbox-precaching-6.1.5.tgz#9e0fecb5c567192f46783323fccea10bffc9f79e" - integrity sha512-yhm1kb6wgi141JeM5X7z42XJxCry53tbMLB3NgrxktrZbwbrJF8JILzYy+RFKC9tHC6u2bPmL789GPLT2NCDzw== - dependencies: - workbox-core "^6.1.5" - workbox-routing "^6.1.5" - workbox-strategies "^6.1.5" - -workbox-range-requests@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-range-requests/-/workbox-range-requests-6.1.5.tgz#047ccd12838bebe51a720256a4ca0cfa7197dfd3" - integrity sha512-iACChSapzB0yuIum3ascP/+cfBNuZi5DRrE+u4u5mCHigPlwfSWtlaY+y8p+a8EwcDTVTZVtnrGrRnF31SiLqQ== - dependencies: - workbox-core "^6.1.5" - -workbox-recipes@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-recipes/-/workbox-recipes-6.1.5.tgz#bb1f8976bcdb202618d967596e9f248e6077e69a" - integrity sha512-MD1yabHca6O/oj1hrRdfj9cRwhKA5zqIE53rWOAg/dKMMzWQsf9nyRbXRgzK3a13iQvYKuQzURU4Cx58tdnR+Q== - dependencies: - workbox-cacheable-response "^6.1.5" - workbox-core "^6.1.5" - workbox-expiration "^6.1.5" - workbox-precaching "^6.1.5" - workbox-routing "^6.1.5" - workbox-strategies "^6.1.5" - -workbox-routing@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-routing/-/workbox-routing-6.1.5.tgz#15884d6152dba03faef83f0b23331846d8b6ef8e" - integrity sha512-uC/Ctz+4GXGL42h1WxUNKxqKRik/38uS0NZ6VY/EHqL2F1ObLFqMHUZ4ZYvyQsKdyI82cxusvhJZHOrY0a2fIQ== - dependencies: - workbox-core "^6.1.5" - -workbox-strategies@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-strategies/-/workbox-strategies-6.1.5.tgz#2549a3e78f0eda371b760c4db21feb0d26143573" - integrity sha512-QhiOn9KT9YGBdbfWOmJT6pXZOIAxaVrs6J6AMYzRpkUegBTEcv36+ZhE/cfHoT0u2fxVtthHnskOQ/snEzaXQw== - dependencies: - workbox-core "^6.1.5" - -workbox-streams@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-streams/-/workbox-streams-6.1.5.tgz#bb7678677275fc23c9627565a1f238e4ca350290" - integrity sha512-OI1kLvRHGFXV+soDvs6aEwfBwdAkvPB0mRryqdh3/K17qUj/1gRXc8QtpgU+83xqx/I/ar2bTCIj0KPzI/ChCQ== - dependencies: - workbox-core "^6.1.5" - workbox-routing "^6.1.5" - -workbox-sw@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-sw/-/workbox-sw-6.1.5.tgz#06eb0c91f22e207422175b3f815cd2181c7074a0" - integrity sha512-IMDiqxYbKzPorZLGMUMacLB6r76iVQbdTzYthIZoPfy+uFURJFUtqiWQJKg1L+RMyuYXwKXTahCIGkgFs4jBeg== - -workbox-webpack-plugin@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-webpack-plugin/-/workbox-webpack-plugin-6.1.5.tgz#d573f959417c3dae49e112dae9c6b82cc1679229" - integrity sha512-tsgeNAYiFP4STNPDxBVT58eiU8nGUmcv7Lq9FFJkQf5MMu6tPw1OLp+KpszhbCWP+R/nEdu85Gjexs6fY647Kg== + workbox-background-sync "6.5.4" + workbox-broadcast-update "6.5.4" + workbox-cacheable-response "6.5.4" + workbox-core "6.5.4" + workbox-expiration "6.5.4" + workbox-google-analytics "6.5.4" + workbox-navigation-preload "6.5.4" + workbox-precaching "6.5.4" + workbox-range-requests "6.5.4" + workbox-recipes "6.5.4" + workbox-routing "6.5.4" + workbox-strategies "6.5.4" + workbox-streams "6.5.4" + workbox-sw "6.5.4" + workbox-window "6.5.4" + +workbox-cacheable-response@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-cacheable-response/-/workbox-cacheable-response-6.5.4.tgz#a5c6ec0c6e2b6f037379198d4ef07d098f7cf137" + integrity sha512-DCR9uD0Fqj8oB2TSWQEm1hbFs/85hXXoayVwFKLVuIuxwJaihBsLsp4y7J9bvZbqtPJ1KlCkmYVGQKrBU4KAug== + dependencies: + workbox-core "6.5.4" + +workbox-core@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-core/-/workbox-core-6.5.4.tgz#df48bf44cd58bb1d1726c49b883fb1dffa24c9ba" + integrity sha512-OXYb+m9wZm8GrORlV2vBbE5EC1FKu71GGp0H4rjmxmF4/HLbMCoTFws87M3dFwgpmg0v00K++PImpNQ6J5NQ6Q== + +workbox-expiration@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-expiration/-/workbox-expiration-6.5.4.tgz#501056f81e87e1d296c76570bb483ce5e29b4539" + integrity sha512-jUP5qPOpH1nXtjGGh1fRBa1wJL2QlIb5mGpct3NzepjGG2uFFBn4iiEBiI9GUmfAFR2ApuRhDydjcRmYXddiEQ== + dependencies: + idb "^7.0.1" + workbox-core "6.5.4" + +workbox-google-analytics@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-google-analytics/-/workbox-google-analytics-6.5.4.tgz#c74327f80dfa4c1954cbba93cd7ea640fe7ece7d" + integrity sha512-8AU1WuaXsD49249Wq0B2zn4a/vvFfHkpcFfqAFHNHwln3jK9QUYmzdkKXGIZl9wyKNP+RRX30vcgcyWMcZ9VAg== + dependencies: + workbox-background-sync "6.5.4" + workbox-core "6.5.4" + workbox-routing "6.5.4" + workbox-strategies "6.5.4" + +workbox-navigation-preload@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-navigation-preload/-/workbox-navigation-preload-6.5.4.tgz#ede56dd5f6fc9e860a7e45b2c1a8f87c1c793212" + integrity sha512-IIwf80eO3cr8h6XSQJF+Hxj26rg2RPFVUmJLUlM0+A2GzB4HFbQyKkrgD5y2d84g2IbJzP4B4j5dPBRzamHrng== + dependencies: + workbox-core "6.5.4" + +workbox-precaching@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-precaching/-/workbox-precaching-6.5.4.tgz#740e3561df92c6726ab5f7471e6aac89582cab72" + integrity sha512-hSMezMsW6btKnxHB4bFy2Qfwey/8SYdGWvVIKFaUm8vJ4E53JAY+U2JwLTRD8wbLWoP6OVUdFlXsTdKu9yoLTg== + dependencies: + workbox-core "6.5.4" + workbox-routing "6.5.4" + workbox-strategies "6.5.4" + +workbox-range-requests@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-range-requests/-/workbox-range-requests-6.5.4.tgz#86b3d482e090433dab38d36ae031b2bb0bd74399" + integrity sha512-Je2qR1NXCFC8xVJ/Lux6saH6IrQGhMpDrPXWZWWS8n/RD+WZfKa6dSZwU+/QksfEadJEr/NfY+aP/CXFFK5JFg== + dependencies: + workbox-core "6.5.4" + +workbox-recipes@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-recipes/-/workbox-recipes-6.5.4.tgz#cca809ee63b98b158b2702dcfb741b5cc3e24acb" + integrity sha512-QZNO8Ez708NNwzLNEXTG4QYSKQ1ochzEtRLGaq+mr2PyoEIC1xFW7MrWxrONUxBFOByksds9Z4//lKAX8tHyUA== + dependencies: + workbox-cacheable-response "6.5.4" + workbox-core "6.5.4" + workbox-expiration "6.5.4" + workbox-precaching "6.5.4" + workbox-routing "6.5.4" + workbox-strategies "6.5.4" + +workbox-routing@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-routing/-/workbox-routing-6.5.4.tgz#6a7fbbd23f4ac801038d9a0298bc907ee26fe3da" + integrity sha512-apQswLsbrrOsBUWtr9Lf80F+P1sHnQdYodRo32SjiByYi36IDyL2r7BH1lJtFX8fwNHDa1QOVY74WKLLS6o5Pg== + dependencies: + workbox-core "6.5.4" + +workbox-strategies@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-strategies/-/workbox-strategies-6.5.4.tgz#4edda035b3c010fc7f6152918370699334cd204d" + integrity sha512-DEtsxhx0LIYWkJBTQolRxG4EI0setTJkqR4m7r4YpBdxtWJH1Mbg01Cj8ZjNOO8etqfA3IZaOPHUxCs8cBsKLw== + dependencies: + workbox-core "6.5.4" + +workbox-streams@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-streams/-/workbox-streams-6.5.4.tgz#1cb3c168a6101df7b5269d0353c19e36668d7d69" + integrity sha512-FXKVh87d2RFXkliAIheBojBELIPnWbQdyDvsH3t74Cwhg0fDheL1T8BqSM86hZvC0ZESLsznSYWw+Va+KVbUzg== + dependencies: + workbox-core "6.5.4" + workbox-routing "6.5.4" + +workbox-sw@6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-sw/-/workbox-sw-6.5.4.tgz#d93e9c67924dd153a61367a4656ff4d2ae2ed736" + integrity sha512-vo2RQo7DILVRoH5LjGqw3nphavEjK4Qk+FenXeUsknKn14eCNedHOXWbmnvP4ipKhlE35pvJ4yl4YYf6YsJArA== + +workbox-webpack-plugin@^6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-webpack-plugin/-/workbox-webpack-plugin-6.5.4.tgz#baf2d3f4b8f435f3469887cf4fba2b7fac3d0fd7" + integrity sha512-LmWm/zoaahe0EGmMTrSLUi+BjyR3cdGEfU3fS6PN1zKFYbqAKuQ+Oy/27e4VSXsyIwAw8+QDfk1XHNGtZu9nQg== dependencies: fast-json-stable-stringify "^2.1.0" pretty-bytes "^5.4.1" - source-map-url "^0.4.0" upath "^1.2.0" webpack-sources "^1.4.3" - workbox-build "^6.1.5" + workbox-build "6.5.4" -workbox-window@^6.1.5: - version "6.1.5" - resolved "https://registry.yarnpkg.com/workbox-window/-/workbox-window-6.1.5.tgz#017b22342e10c6df6b9672326b575ec950b6cd80" - integrity sha512-akL0X6mAegai2yypnq78RgfazeqvKbsllRtEI4dnbhPcRINEY1NmecFmsQk8SD+zWLK1gw5OdwAOX+zHSRVmeA== +workbox-window@6.5.4, workbox-window@^6.5.4: + version "6.5.4" + resolved "https://registry.yarnpkg.com/workbox-window/-/workbox-window-6.5.4.tgz#d991bc0a94dff3c2dbb6b84558cff155ca878e91" + integrity sha512-HnLZJDwYBE+hpG25AQBO8RUWBJRaCsI9ksQJEp3aCOFCaG5kqaToAYXFRAHxzRluM2cQbGzdQF5rjKPWPA1fug== dependencies: - workbox-core "^6.1.5" + "@types/trusted-types" "^2.0.2" + workbox-core "6.5.4" wrap-ansi@^6.2.0: version "6.2.0" @@ -8274,7 +7729,7 @@ wrap-ansi@^7.0.0: wrappy@1: version "1.0.2" resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" - integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= + integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== write-file-atomic@^3.0.0: version "3.0.3" @@ -8314,16 +7769,16 @@ xmlchars@^2.2.0: resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw== -xtend@^4.0.0, xtend@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" - integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== - y18n@^5.0.5: version "5.0.8" resolved "https://registry.yarnpkg.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55" integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== +yallist@^3.0.2: + version "3.1.1" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" + integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== + yallist@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" @@ -8356,3 +7811,8 @@ yocto-queue@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== + +zod@3.21.4: + version "3.21.4" + resolved "https://registry.yarnpkg.com/zod/-/zod-3.21.4.tgz#10882231d992519f0a10b5dd58a38c9dabbb64db" + integrity sha512-m46AKbrzKVzOzs/DZgVnG5H55N1sv1M8qZU3A8RIKbs3mrACDNeIOeilDymVb2HdmP8uwshOCF4uJ8uM9rCqJw== From ccea732c3ead0f4beb0e6bc4c46bf97529d608c7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vladan=20Kudl=C3=A1=C4=8D?= Date: Mon, 22 May 2023 13:37:38 +0200 Subject: [PATCH 02/35] layers: Use the new satellite (#151) --- src/components/LayerSwitcher/osmappLayers.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/LayerSwitcher/osmappLayers.tsx b/src/components/LayerSwitcher/osmappLayers.tsx index 55421ad7a..54556a2c1 100644 --- a/src/components/LayerSwitcher/osmappLayers.tsx +++ b/src/components/LayerSwitcher/osmappLayers.tsx @@ -25,7 +25,7 @@ export const osmappLayers: Layers = { sat: { name: t('layers.sat'), type: 'basemap', - url: 'https://api.maptiler.com/tiles/satellite/tiles.json?key=7dlhLl3hiXQ1gsth0kGu', + url: 'https://api.maptiler.com/tiles/satellite-v2/tiles.json?key=7dlhLl3hiXQ1gsth0kGu', Icon: SatelliteIcon, }, // mtb: { From 928b18d5949aafc369608bb9c1f9c040bd45ee8d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Sat, 3 Jun 2023 14:33:18 +0200 Subject: [PATCH 03/35] general: add .nvmrc with node v18 --- .gitignore | 1 + .nvmrc | 1 + next-env.d.ts | 2 -- 3 files changed, 2 insertions(+), 2 deletions(-) create mode 100644 .nvmrc delete mode 100644 next-env.d.ts diff --git a/.gitignore b/.gitignore index f1ccaeae2..c1e03fc74 100644 --- a/.gitignore +++ b/.gitignore @@ -6,6 +6,7 @@ .DS_Store .env .idea +next-env.d.ts npm-debug.log* yarn-debug.log* yarn-error.log* diff --git a/.nvmrc b/.nvmrc new file mode 100644 index 000000000..3c032078a --- /dev/null +++ b/.nvmrc @@ -0,0 +1 @@ +18 diff --git a/next-env.d.ts b/next-env.d.ts deleted file mode 100644 index 7b7aa2c77..000000000 --- a/next-env.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -/// -/// From eae3f192643a966f149709ff473a7ece654b8533 Mon Sep 17 00:00:00 2001 From: Floh <48927090+Flohhhhh@users.noreply.github.com> Date: Wed, 14 Jun 2023 13:26:42 -0400 Subject: [PATCH 04/35] Map: increase trails minzoom in outdoorStyle (#158) --- src/components/Map/styles/outdoorStyle.ts | 56 +++++++++++------------ 1 file changed, 28 insertions(+), 28 deletions(-) diff --git a/src/components/Map/styles/outdoorStyle.ts b/src/components/Map/styles/outdoorStyle.ts index 67321a605..f9ce465ab 100644 --- a/src/components/Map/styles/outdoorStyle.ts +++ b/src/components/Map/styles/outdoorStyle.ts @@ -997,7 +997,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1039,7 +1039,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 13, + minzoom: 11, metadata: {}, 'source-layer': 'trail', }, @@ -1091,7 +1091,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 13, + minzoom: 11, metadata: {}, 'source-layer': 'trail', }, @@ -1133,7 +1133,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1170,7 +1170,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1206,7 +1206,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1248,7 +1248,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1284,7 +1284,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1322,7 +1322,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1365,7 +1365,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1392,7 +1392,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1422,7 +1422,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1449,7 +1449,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1479,7 +1479,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1590,7 +1590,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1617,7 +1617,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1644,7 +1644,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1755,7 +1755,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1782,7 +1782,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1809,7 +1809,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1836,7 +1836,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1863,7 +1863,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1890,7 +1890,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1917,7 +1917,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1944,7 +1944,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1981,7 +1981,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, @@ -1998,7 +1998,7 @@ export const outdoorStyle = addHoverPaint({ }, source: 'outdoor', maxzoom: 24, - minzoom: 14, + minzoom: 12, 'source-layer': 'trail', }, { @@ -2110,7 +2110,7 @@ export const outdoorStyle = addHoverPaint({ 'line-miter-limit': 3, }, source: 'outdoor', - minzoom: 14, + minzoom: 12, metadata: {}, 'source-layer': 'trail', }, From 92467f81bafe90d9ed9daf7d43eb9ab8758ec730 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Wed, 14 Jun 2023 20:04:04 +0200 Subject: [PATCH 05/35] layers: Add attribution to layers (#154) * layers: Add attribution to layers * fix window in SSR * mapfooter client-only * fix attribution for user layers --- .gitignore | 1 + src/components/LayerSwitcher/osmappLayers.tsx | 28 ++++- src/components/Map/MapFooter/MapFooter.tsx | 105 ++++++++++++------ src/components/Map/MapFooter/MaptilerLogo.tsx | 33 ++++-- src/components/utils/MapStateContext.tsx | 1 + src/locales/vocabulary.js | 1 + 6 files changed, 117 insertions(+), 52 deletions(-) diff --git a/.gitignore b/.gitignore index c1e03fc74..0796d356d 100644 --- a/.gitignore +++ b/.gitignore @@ -2,6 +2,7 @@ /coverage /build /dist +/tsconfig.tsbuildinfo .next .DS_Store .env diff --git a/src/components/LayerSwitcher/osmappLayers.tsx b/src/components/LayerSwitcher/osmappLayers.tsx index 54556a2c1..2a50ba32a 100644 --- a/src/components/LayerSwitcher/osmappLayers.tsx +++ b/src/components/LayerSwitcher/osmappLayers.tsx @@ -5,28 +5,42 @@ import SatelliteIcon from '@material-ui/icons/Satellite'; import DirectionsBikeIcon from '@material-ui/icons/DirectionsBike'; import { Layer } from '../utils/MapStateContext'; import { t } from '../../services/intl'; +import { isBrowser } from '../helpers'; interface Layers { [key: string]: Layer; } -const retina = (window.devicePixelRatio || 1) >= 2 ? '@2x' : ''; +const retina = + ((isBrowser() && window.devicePixelRatio) || 1) >= 2 ? '@2x' : ''; export const osmappLayers: Layers = { - basic: { name: t('layers.basic'), type: 'basemap', Icon: ExploreIcon }, - outdoor: { name: t('layers.outdoor'), type: 'basemap', Icon: FilterHdrIcon }, + basic: { + name: t('layers.basic'), + type: 'basemap', + Icon: ExploreIcon, + attribution: ['maptiler', 'osm'], + }, + outdoor: { + name: t('layers.outdoor'), + type: 'basemap', + Icon: FilterHdrIcon, + attribution: ['maptiler', 'osm'], + }, s1: { type: 'spacer' }, mapnik: { name: t('layers.mapnik'), type: 'basemap', url: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', Icon: MapIcon, + attribution: ['osm'], }, sat: { name: t('layers.sat'), type: 'basemap', url: 'https://api.maptiler.com/tiles/satellite-v2/tiles.json?key=7dlhLl3hiXQ1gsth0kGu', Icon: SatelliteIcon, + attribution: ['maptiler'], }, // mtb: { // name: t('layers.mtb'), @@ -36,12 +50,16 @@ export const osmappLayers: Layers = { bike: { name: t('layers.bike'), type: 'basemap', - url: `https://{s}.tile.thunderforest.com/cycle/{z}/{x}/{y}${retina}.png?apikey=00291b657a5d4c91bbacb0ff096e2c25`, + url: `https://{s}.tile.thunderforest.com/cycle/{z}/{x}/{y}${retina}.png?apikey=18c0cb31f2fd41d28ac90abe4059e359`, Icon: DirectionsBikeIcon, + attribution: [ + '© Thunderforest', + 'osm', + ], }, // snow: { // name: t('layers.snow'), - // type: 'basemap', + // type: 'overlay', // url: 'https://www.opensnowmap.org/tiles-pistes/{z}/{x}/{y}.png', // }, // s2: { type: 'spacer' }, diff --git a/src/components/Map/MapFooter/MapFooter.tsx b/src/components/Map/MapFooter/MapFooter.tsx index 97b3855be..d197b3f79 100644 --- a/src/components/Map/MapFooter/MapFooter.tsx +++ b/src/components/Map/MapFooter/MapFooter.tsx @@ -1,11 +1,14 @@ -import React from 'react'; +import React, { useEffect, useState } from 'react'; import styled from 'styled-components'; import getConfig from 'next/config'; import { Tooltip, useMediaQuery } from '@material-ui/core'; +import uniq from 'lodash/uniq'; import { t, Translation } from '../../../services/intl'; import GithubIcon from '../../../assets/GithubIcon'; import { MoreMenu } from './MoreMenu'; import { LangSwitcher } from './LangSwitcher'; +import { useMapStateContext } from '../../utils/MapStateContext'; +import { osmappLayers } from '../../LayerSwitcher/osmappLayers'; const { publicRuntimeConfig: { osmappVersion, commitHash, commitMessage }, @@ -49,46 +52,74 @@ const OsmappLink = () => ( ); +const Attribution = ({ label, link, title }) => ( + <> + ©{' '} + + + {label} + + + +); + const MapDataLink = () => { const short = useMediaQuery('(max-width: 500px)'); - - return ( - <> - ©{' '} - } - > - - MapTiler - - {' '} - ©{' '} - }> - - {short ? 'OSM' : 'OpenStreetMap'} - - - + const { activeLayers } = useMapStateContext(); + const attributions = uniq( + activeLayers.flatMap((layer) => + osmappLayers[layer] + ? osmappLayers[layer].attribution + : decodeURI(new URL(layer)?.hostname), + ), ); + + const nodes = attributions.map((attribution) => { + if (attribution === 'maptiler') + return ( + } + /> + ); + if (attribution === 'osm') + return ( + } + /> + ); + + return ; + }); + + // place a separator between attributions + for (let i = 1; i < nodes.length; i += 2) { + nodes.splice(i, 0, ' '); + } + + return nodes; +}; + +const ClientOnly = ({ children }) => { + const [mounted, setMounted] = useState(false); + useEffect(() => setMounted(true), []); + return mounted ? children : null; }; export const MapFooter = () => ( - - - {' | '} - - {' | '} - - {' | '} - - + // TODO find a way how to render this in SSR (keep layer in cookies?) + + + + {' | '} + + {' | '} + + {' | '} + + + ); diff --git a/src/components/Map/MapFooter/MaptilerLogo.tsx b/src/components/Map/MapFooter/MaptilerLogo.tsx index 81848fdab..a90b4144a 100644 --- a/src/components/Map/MapFooter/MaptilerLogo.tsx +++ b/src/components/Map/MapFooter/MaptilerLogo.tsx @@ -1,5 +1,7 @@ import React from 'react'; import styled from 'styled-components'; +import { useMapStateContext } from '../../utils/MapStateContext'; +import { osmappLayers } from '../../LayerSwitcher/osmappLayers'; const Link = styled.a` position: absolute; @@ -8,13 +10,24 @@ const Link = styled.a` z-index: 999; `; -export const MaptilerLogo = () => ( - - MapTiler logo - -); +export const MaptilerLogo = () => { + const { activeLayers } = useMapStateContext(); + const hasMaptiler = activeLayers.some((layer) => + osmappLayers[layer]?.attribution?.includes('maptiler'), + ); + + if (!hasMaptiler) { + return null; + } + + return ( + + MapTiler logo + + ); +}; diff --git a/src/components/utils/MapStateContext.tsx b/src/components/utils/MapStateContext.tsx index c6c5e6043..f041ce967 100644 --- a/src/components/utils/MapStateContext.tsx +++ b/src/components/utils/MapStateContext.tsx @@ -8,6 +8,7 @@ export interface Layer { url?: string; key?: string; Icon?: React.FC; + attribution?: string[]; // missing in spacer TODO refactor ugly } // // [b.getWest(), b.getNorth(), b.getEast(), b.getSouth()] diff --git a/src/locales/vocabulary.js b/src/locales/vocabulary.js index f34916c1f..5be998c2a 100644 --- a/src/locales/vocabulary.js +++ b/src/locales/vocabulary.js @@ -155,5 +155,6 @@ export default { 'layers.snow': 'Snow', 'layers.mapnik': 'OSM Mapnik', 'layers.sat': 'Satellite (z<14)', + 'layers.bingSat': 'Bing satellite', 'layers.bike': 'Bike', }; From 5db8b28ea2387570331243651a97e7c4afc6ed11 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Thu, 15 Jun 2023 08:35:28 +0200 Subject: [PATCH 06/35] layers: Add bing satellite (#155) * layers: Add bing satellite * maxzoom * locales --- src/components/LayerSwitcher/osmappLayers.tsx | 10 ++++++- .../Map/behaviour/useUpdateStyle.tsx | 1 + src/components/Map/styles/rasterStyle.ts | 28 ++++++++++++++----- src/components/utils/MapStateContext.tsx | 1 + src/locales/am.js | 3 +- src/locales/cs.js | 3 +- src/locales/de.js | 3 +- src/locales/es.js | 11 ++++---- src/locales/fr.js | 3 +- src/locales/it.js | 5 ++-- src/locales/pl.js | 3 +- src/locales/vocabulary.js | 4 +-- 12 files changed, 53 insertions(+), 22 deletions(-) diff --git a/src/components/LayerSwitcher/osmappLayers.tsx b/src/components/LayerSwitcher/osmappLayers.tsx index 2a50ba32a..951940ee2 100644 --- a/src/components/LayerSwitcher/osmappLayers.tsx +++ b/src/components/LayerSwitcher/osmappLayers.tsx @@ -36,12 +36,20 @@ export const osmappLayers: Layers = { attribution: ['osm'], }, sat: { - name: t('layers.sat'), + name: t('layers.maptilerSat'), type: 'basemap', url: 'https://api.maptiler.com/tiles/satellite-v2/tiles.json?key=7dlhLl3hiXQ1gsth0kGu', Icon: SatelliteIcon, attribution: ['maptiler'], }, + bingSat: { + name: t('layers.bingSat'), + type: 'basemap', + url: 'https://ecn.{bingSubdomains}.tiles.virtualearth.net/tiles/a{quadkey}.jpeg?g=13657', + Icon: SatelliteIcon, + attribution: ['© Microsoft'], + maxzoom: 19, + }, // mtb: { // name: t('layers.mtb'), // type: 'basemap', diff --git a/src/components/Map/behaviour/useUpdateStyle.tsx b/src/components/Map/behaviour/useUpdateStyle.tsx index adc8c376b..b2cb60b0d 100644 --- a/src/components/Map/behaviour/useUpdateStyle.tsx +++ b/src/components/Map/behaviour/useUpdateStyle.tsx @@ -12,6 +12,7 @@ export const getRasterLayer = (key) => { export const useUpdateStyle = useMapEffect((map, activeLayers) => { const key = activeLayers[0] ?? DEFAULT_MAP; + map.setMaxZoom(osmappLayers[key]?.maxzoom ?? 24); // TODO find a way how to zoom bing further (now it stops at 19) map.setStyle( key === 'basic' ? basicStyle diff --git a/src/components/Map/styles/rasterStyle.ts b/src/components/Map/styles/rasterStyle.ts index e0e999e5a..13ceef1bc 100644 --- a/src/components/Map/styles/rasterStyle.ts +++ b/src/components/Map/styles/rasterStyle.ts @@ -1,14 +1,28 @@ import maplibregl from 'maplibre-gl'; import { GLYPHS, OSMAPP_SOURCES, OSMAPP_SPRITE } from '../consts'; +const getSource = (url) => { + if (url.match('{bingSubdomains}')) { + return { + tiles: ['t0', 't1', 't2', 't3'].map((c) => + url?.replace('{bingSubdomains}', c), + ), + }; + } + + if (url.match('{x}')) { + return { + tiles: ['a', 'b', 'c'].map((c) => url?.replace('{s}', c)), + }; + } + + return { + url, // url as a tileset.json + }; +}; + export const rasterStyle = (id, url): maplibregl.Style => { - const source = url.match('{x}') - ? { - tiles: ['a', 'b', 'c'].map((c) => url?.replace('{s}', c)), - } - : { - url, // tileset.json - }; + const source = getSource(url); return { version: 8, sprite: OSMAPP_SPRITE, diff --git a/src/components/utils/MapStateContext.tsx b/src/components/utils/MapStateContext.tsx index f041ce967..8437e3622 100644 --- a/src/components/utils/MapStateContext.tsx +++ b/src/components/utils/MapStateContext.tsx @@ -9,6 +9,7 @@ export interface Layer { key?: string; Icon?: React.FC; attribution?: string[]; // missing in spacer TODO refactor ugly + maxzoom?: number; } // // [b.getWest(), b.getNorth(), b.getEast(), b.getSouth()] diff --git a/src/locales/am.js b/src/locales/am.js index 9224156f7..e443b970a 100644 --- a/src/locales/am.js +++ b/src/locales/am.js @@ -143,6 +143,7 @@ export default { 'layers.mtb': 'MTB', 'layers.snow': 'በረዶ', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'ሳተላይት (z<14)', + 'layers.maptilerSat': 'Maptiler ሳተላይት (z<14)', + 'layers.bingSat': 'Bing ሳተላይት', 'layers.bike': 'ሳይክል', }; diff --git a/src/locales/cs.js b/src/locales/cs.js index 8f1e5f9b1..97adebcda 100644 --- a/src/locales/cs.js +++ b/src/locales/cs.js @@ -148,6 +148,7 @@ export default { 'layers.mtb': 'MTB', 'layers.snow': 'Zimní', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'Satelitní', + 'layers.maptilerSat': 'Letecká Maptiler ', + 'layers.bingSat': 'Letecká Bing', 'layers.bike': 'Cyklo', }; diff --git a/src/locales/de.js b/src/locales/de.js index b373935dc..bf3f0e9b0 100644 --- a/src/locales/de.js +++ b/src/locales/de.js @@ -151,6 +151,7 @@ export default { 'layers.mtb': 'MTB', 'layers.snow': 'Schnee', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'Satellit (z<14)', + 'layers.maptilerSat': 'Maptiler Satellit (z<14)', + 'layers.bingSat': 'Bing Satellit', 'layers.bike': 'Fahrrad', }; diff --git a/src/locales/es.js b/src/locales/es.js index 4dc5ff811..8ee8a290d 100644 --- a/src/locales/es.js +++ b/src/locales/es.js @@ -24,7 +24,7 @@ export default { 'homepage.examples.eg': 'ej.', 'homepage.examples.charles_bridge_statues': 'Estatuas del puente Charles', 'homepage.screenshot_alt': 'Pantallazo de OsmAPP', - 'homepage.about_osm': `Todos los datos del mapa son de + 'homepage.about_osm': `Todos los datos del mapa son de OpenStreetMap, un mapa creado por millones de contribuidores — similar a Wikipedia. Puedes encontrar el botón Editar en cada elemento del mapa.`, @@ -106,9 +106,9 @@ export default { 'editdialog.comment': 'Commentar (opcional)', 'editdialog.comment_placeholder': 'enlace a la fuente de la información etc.', 'editdialog.info_edit': `Tu edición será guardada inmediatamente en OpenStreetMap. Por favor, - introduce únicamente información que tú poseas o que venga de fuentes verificadas. Está prohibido + introduce únicamente información que tú poseas o que venga de fuentes verificadas. Está prohibido copiar información con derechos de autor (por ej. Google Maps). Más información`, - 'editdialog.info_note': `Tu sugerencia será procesada por voluntarios de OpenStreetMap volunteers. Aquí + 'editdialog.info_note': `Tu sugerencia será procesada por voluntarios de OpenStreetMap volunteers. Aquí puedes añadir una nota adicional o describir un ajuste de la posición, etc También es apropiado apoyar tu contribución con un enlace a la fuente de la información (web, foto, etc.).`, @@ -117,7 +117,7 @@ export default { 'editdialog.other_tags.add': 'Añadir otra etiqueta', 'editdialog.other_tags.will_be_deleted': 'será borrado', 'editdialog.other_tags.info': `Las Etiquetas describen las propiedades - de cada elemento del mapa en un formato acordado. Aquí puedes encontrar una + de cada elemento del mapa en un formato acordado. Aquí puedes encontrar una descripción general de todas las etiquetas en OpenStreetMap.`, 'editsuccess.close_button': 'Cerrar', @@ -151,6 +151,7 @@ export default { 'layers.mtb': 'BTT', 'layers.snow': 'Nieve', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'Satélite (z<14)', + 'layers.maptilerSat': 'Maptiler Satélite (z<14)', + 'layers.bingSat': 'Bing Satélite', 'layers.bike': 'Bici', }; diff --git a/src/locales/fr.js b/src/locales/fr.js index c46f04787..5f040f919 100644 --- a/src/locales/fr.js +++ b/src/locales/fr.js @@ -154,6 +154,7 @@ export default { 'layers.mtb': 'VTT', 'layers.snow': 'Neige', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'Satellite (zoom < 14)', + 'layers.maptilerSat': 'Maptiler Satellite (zoom < 14)', + 'layers.bingSat': 'Bing Satellite', 'layers.bike': 'Vélo', }; diff --git a/src/locales/it.js b/src/locales/it.js index f1f32aa69..c49c56e6e 100644 --- a/src/locales/it.js +++ b/src/locales/it.js @@ -110,7 +110,7 @@ export default { È proibita la copia di dati protetti da copyright (ad es. Google Maps). Ulteriori informazioni`, 'editdialog.info_note': `Il tuo suggerimento verrà valutato dai volontari di OpenStreetMap. Qua puoi aggiungere un’ulteriore nota oppure descrivere la posizione precisa, etc. - Sarebbe anche appropriato supportare il tuo contributo con un link ad una fonte (sito web, + Sarebbe anche appropriato supportare il tuo contributo con un link ad una fonte (sito web, foto, etc.).`, 'editdialog.other_tags': 'Altre proprietà (etichette)', 'editdialog.other_tags.new_key': 'nuova chiave', @@ -151,6 +151,7 @@ export default { 'layers.mtb': 'MTB', 'layers.snow': 'Neve', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'Satellite (z<14)', + 'layers.maptilerSat': 'Maptiler Satellite (z<14)', + 'layers.bingSat': 'Bing Satellite', 'layers.bike': 'Bici', }; diff --git a/src/locales/pl.js b/src/locales/pl.js index 1cf90ee38..e9e6ef96b 100644 --- a/src/locales/pl.js +++ b/src/locales/pl.js @@ -150,6 +150,7 @@ export default { 'layers.mtb': 'MTB', 'layers.snow': 'Śnieg', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'Satelita (p<14)', + 'layers.maptilerSat': 'Maptiler Satelita (p<14)', + 'layers.bingSat': 'Bing Satelita', 'layers.bike': 'Rower', }; diff --git a/src/locales/vocabulary.js b/src/locales/vocabulary.js index 5be998c2a..727e0a867 100644 --- a/src/locales/vocabulary.js +++ b/src/locales/vocabulary.js @@ -154,7 +154,7 @@ export default { 'layers.mtb': 'MTB', 'layers.snow': 'Snow', 'layers.mapnik': 'OSM Mapnik', - 'layers.sat': 'Satellite (z<14)', - 'layers.bingSat': 'Bing satellite', + 'layers.maptilerSat': 'Maptiler Satellite (z<14)', + 'layers.bingSat': 'Bing Satellite', 'layers.bike': 'Bike', }; From b3c206bd9447220f68d4cc4b9cbc468689333f61 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Sat, 17 Jun 2023 16:55:49 +0200 Subject: [PATCH 07/35] =?UTF-8?q?tagging:=20add=20iD=20Tagging=20scheme=20?= =?UTF-8?q?to=20advanced=20mode=20=F0=9F=8E=89=20(#131)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * iD Tagging scheme exploration * fix build * fix build2 * show only unique fields * add typescript types * y lintfix * find Field for rest of tags * move schema to Feature + add UI * translate values in semiCombo * titles * hack address:* in * remove tags which are already covered by Preset name * experiment - clear sessionstorage * typeCombo is usually cleared by preset.tags * We need typeCombo after all, eg node/7002486683 * move units from label to value * finalize first prototype * allow language switching * fix buildAddress a little * extract PoiDescription.tsx * extract field helpers to fields.ts * refactoring restKeys->keysTodo, added publishDbgObject(), added test * fix access key - covers multiple tags * Use `@openstreetmap/id-tagging-schema` pkg Committed in-flight 5J814 :) * fix keysTodo (never commit 30k ft above ground) * y lintfix * fix [object object] in `subject:wikidata` * update osmApi.test.ts * hide under advanced mode * add Details above TagsTable --- package.json | 1 + src/components/FeaturePanel/FeaturePanel.tsx | 45 +++- src/components/FeaturePanel/FeaturedTags.tsx | 6 - .../FeaturePanel/IdSchemeFields.tsx | 136 +++++++++++ .../ImageSection/ImageSection.tsx | 33 +-- .../ImageSection/PoiDescription.tsx | 46 ++++ src/components/utils/FeatureContext.tsx | 3 + src/helpers/featureLabel.ts | 4 +- src/services/__tests__/osmApi.test.ts | 14 ++ src/services/fetchCache.ts | 5 + src/services/helpers.ts | 35 +-- src/services/intl.tsx | 2 + src/services/osmApi.ts | 7 +- .../tagging/__tests__/idTaggingScheme.test.ts | 64 +++++ src/services/tagging/data.ts | 30 +++ src/services/tagging/fields.ts | 74 ++++++ src/services/tagging/idTaggingScheme.ts | 174 ++++++++++++++ src/services/tagging/presets.ts | 85 +++++++ src/services/tagging/translations.ts | 42 ++++ src/services/tagging/types/Fields.ts | 223 ++++++++++++++++++ src/services/tagging/types/Presets.ts | 97 ++++++++ src/services/types.ts | 2 + src/utils.ts | 9 + yarn.lock | 5 + 24 files changed, 1074 insertions(+), 68 deletions(-) create mode 100644 src/components/FeaturePanel/IdSchemeFields.tsx create mode 100644 src/components/FeaturePanel/ImageSection/PoiDescription.tsx create mode 100644 src/services/tagging/__tests__/idTaggingScheme.test.ts create mode 100644 src/services/tagging/data.ts create mode 100644 src/services/tagging/fields.ts create mode 100644 src/services/tagging/idTaggingScheme.ts create mode 100644 src/services/tagging/presets.ts create mode 100644 src/services/tagging/translations.ts create mode 100644 src/services/tagging/types/Fields.ts create mode 100644 src/services/tagging/types/Presets.ts diff --git a/package.json b/package.json index 16138edba..f1e9bc15a 100644 --- a/package.json +++ b/package.json @@ -31,6 +31,7 @@ "@material-ui/core": "^4.11.4", "@material-ui/icons": "^4.11.2", "@material-ui/lab": "4.0.0-alpha.58", + "@openstreetmap/id-tagging-schema": "^6.1.0", "@sentry/browser": "^6.5.1", "@sentry/node": "^6.5.1", "@types/maplibre-gl": "^1.13.1", diff --git a/src/components/FeaturePanel/FeaturePanel.tsx b/src/components/FeaturePanel/FeaturePanel.tsx index 87ad36e3d..be0ab3b72 100644 --- a/src/components/FeaturePanel/FeaturePanel.tsx +++ b/src/components/FeaturePanel/FeaturePanel.tsx @@ -1,8 +1,8 @@ import React, { useState } from 'react'; +import { Typography } from '@material-ui/core'; import { FeatureHeading } from './FeatureHeading'; import Coordinates from './Coordinates'; import { useToggleState } from '../helpers'; -import { TagsTable } from './TagsTable'; import { getFullOsmappLink, getUrlOsmId } from '../../services/helpers'; import { EditDialog } from './EditDialog/EditDialog'; import { @@ -21,6 +21,8 @@ import { EditButton } from './EditButton'; import { FeaturedTags } from './FeaturedTags'; import { getLabel } from '../../helpers/featureLabel'; import { ImageSection } from './ImageSection/ImageSection'; +import { IdSchemeFields } from './IdSchemeFields'; +import { TagsTable } from './TagsTable'; const featuredKeys = [ 'website', @@ -69,17 +71,36 @@ const FeaturePanel = () => { setDialogOpenedWith={setDialogOpenedWith} /> - + {advanced && ( + + )} + {!advanced && ( + <> + {featuredTags.length && ( + + {t('featurepanel.other_info_heading')} + + )} + + + )} {advanced && } diff --git a/src/components/FeaturePanel/FeaturedTags.tsx b/src/components/FeaturePanel/FeaturedTags.tsx index d9ff4a818..14f37b0c5 100644 --- a/src/components/FeaturePanel/FeaturedTags.tsx +++ b/src/components/FeaturePanel/FeaturedTags.tsx @@ -1,7 +1,5 @@ -import Typography from '@material-ui/core/Typography'; import React from 'react'; import styled from 'styled-components'; -import { t } from '../../services/intl'; import { FeaturedTag } from './FeaturedTag'; const Spacer = styled.div` @@ -17,10 +15,6 @@ export const FeaturedTags = ({ featuredTags, setDialogOpenedWith }) => { ))} - - - {t('featurepanel.other_info_heading')} - ); }; diff --git a/src/components/FeaturePanel/IdSchemeFields.tsx b/src/components/FeaturePanel/IdSchemeFields.tsx new file mode 100644 index 000000000..d8f2cbd64 --- /dev/null +++ b/src/components/FeaturePanel/IdSchemeFields.tsx @@ -0,0 +1,136 @@ +import React, { ReactNode } from 'react'; +import styled from 'styled-components'; +import Typography from '@material-ui/core/Typography'; +import { Field } from '../../services/tagging/types/Fields'; +import { getUrlForTag } from './helpers/getUrlForTag'; +import { slashToOptionalBr } from '../helpers'; +import { buildAddress } from '../../services/helpers'; +import { Feature } from '../../services/types'; +import { t } from '../../services/intl'; + +// taken from src/components/FeaturePanel/TagsTable.tsx +const Table = styled.table` + font-size: 1rem; + width: 100%; + + th, + td { + padding: 0.1em; + overflow: hidden; + + &:hover .show-on-hover { + display: block !important; + } + } + + th { + width: 140px; + max-width: 140px; + color: rgba(0, 0, 0, 0.54); + text-align: left; + font-weight: normal; + vertical-align: baseline; + padding-left: 0; + } + + table { + padding-left: 1em; + padding-bottom: 1em; + } +`; + +// TODO move to helpers +const getEllipsisHumanUrl = (humanUrl) => { + const MAX_LENGTH = 40; + return humanUrl.replace(/^([^/]+.{0,5})(.*)$/, (full, hostname, rest) => { + const charsLeft = MAX_LENGTH - 10 - hostname.length; + return ( + hostname + + (full.length > MAX_LENGTH + ? `…${rest.substring(rest.length - charsLeft)}` + : rest) + ); + }); +}; + +// taken from src/components/FeaturePanel/TagsTable.tsx +const renderValue = (k, v): string | ReactNode => { + const url = getUrlForTag(k, v); + if (url) { + let humanUrl = v.replace(/^https?:\/\//, '').replace(/^([^/]+)\/$/, '$1'); + if (k === 'image') { + humanUrl = getEllipsisHumanUrl(humanUrl); + } + return {slashToOptionalBr(humanUrl)}; + } + return v; +}; + +const render = (field: Field, feature: Feature, k, v): string | ReactNode => { + if (field.type === 'address') { + return buildAddress(feature.tags, feature.center); + } + return renderValue(k, v); +}; + +const getTitle = (type: string, field: Field) => + `${type}: ${JSON.stringify(field, null, 2)}`; + +// TODO some fields eg. oneway/bicycle doesnt have units in brackets +const unitRegExp = / \((.+)\)$/i; +const removeUnits = (label) => label.replace(unitRegExp, ''); +const addUnits = (label, value: string | ReactNode) => { + if (typeof value !== 'string') return value; + const unit = label.match(unitRegExp); + return `${value}${unit ? ` (${unit[1]})` : ''}`; +}; + +export const IdSchemeFields = ({ feature, featuredTags }) => { + const { schema } = feature; + if (!schema) return null; + if (!Object.keys(schema).length) return null; + + return ( + <> + {featuredTags.length && + (schema.matchedFields.length || + schema.tagsWithFields.length || + schema.restKeys.length) ? ( + + {t('featurepanel.other_info_heading')} + + ) : null} + + + + {schema.matchedFields.map(({ key, value, label, field }) => ( + + + + + ))} + + + {schema.tagsWithFields.map(({ key, value, label, field }) => ( + + + + + ))} + + + {schema.keysTodo.map((key) => ( + + + + + ))} + +
+ {removeUnits(label)} + {addUnits(label, render(field, feature, key, value))}
+ {removeUnits(label)} + {render(field, feature, key, addUnits(label, value))}
{key}{renderValue(key, feature.tags[key])}
+ + ); +}; diff --git a/src/components/FeaturePanel/ImageSection/ImageSection.tsx b/src/components/FeaturePanel/ImageSection/ImageSection.tsx index b38045b91..9654dc74d 100644 --- a/src/components/FeaturePanel/ImageSection/ImageSection.tsx +++ b/src/components/FeaturePanel/ImageSection/ImageSection.tsx @@ -6,11 +6,9 @@ import React from 'react'; import styled from 'styled-components'; import { useFeatureContext } from '../../utils/FeatureContext'; import { FeatureImage } from './FeatureImage'; -import Maki from '../../utils/Maki'; -import { hasName } from '../../../helpers/featureLabel'; import { t } from '../../../services/intl'; import { SHOW_PROTOTYPE_UI } from '../../../config'; -import { Feature } from '../../../services/types'; +import { PoiDescription } from './PoiDescription'; const StyledIconButton = styled(IconButton)` svg { @@ -20,40 +18,13 @@ const StyledIconButton = styled(IconButton)` } `; -const PoiType = styled.div` - color: #fff; - margin: 0 auto 0 15px; - font-size: 13px; - position: relative; - width: 100%; - svg { - vertical-align: bottom; - } - span { - position: absolute; - left: 20px; - } -`; - -const getSubclass = ({ layer, osmMeta, properties }: Feature) => - properties.subclass?.replace(/_/g, ' ') || - (layer && layer.id) || // layer.id specified only when maplibre-gl skeleton displayed - osmMeta.type; - export const ImageSection = () => { const { feature } = useFeatureContext(); const { properties } = feature; - const poiType = hasName(feature) - ? getSubclass(feature) - : t('featurepanel.no_name'); - return ( - - - {poiType} - + {SHOW_PROTOTYPE_UI && ( <> diff --git a/src/components/FeaturePanel/ImageSection/PoiDescription.tsx b/src/components/FeaturePanel/ImageSection/PoiDescription.tsx new file mode 100644 index 000000000..2feeab9b3 --- /dev/null +++ b/src/components/FeaturePanel/ImageSection/PoiDescription.tsx @@ -0,0 +1,46 @@ +import React from 'react'; +import styled from 'styled-components'; +import { hasName } from '../../../helpers/featureLabel'; +import { useFeatureContext } from '../../utils/FeatureContext'; +import { t } from '../../../services/intl'; +import Maki from '../../utils/Maki'; +import { Feature } from '../../../services/types'; + +const PoiType = styled.div` + color: #fff; + margin: 0 auto 0 15px; + font-size: 13px; + position: relative; + width: 100%; + + svg { + vertical-align: bottom; + } + + span { + position: absolute; + left: 20px; + } +`; + +const getSubclass = ({ layer, osmMeta, properties, schema }: Feature) => + schema?.label || + properties.subclass?.replace(/_/g, ' ') || + (layer && layer.id) || // layer.id specified only when maplibre-gl skeleton displayed + osmMeta.type; + +export const PoiDescription = () => { + const { feature } = useFeatureContext(); + const { properties } = feature; + + const poiType = hasName(feature) + ? getSubclass(feature) + : t('featurepanel.no_name'); + + return ( + + + {poiType} + + ); +}; diff --git a/src/components/utils/FeatureContext.tsx b/src/components/utils/FeatureContext.tsx index e520ec02d..57c9e842a 100644 --- a/src/components/utils/FeatureContext.tsx +++ b/src/components/utils/FeatureContext.tsx @@ -9,6 +9,7 @@ import Router from 'next/router'; import Cookies from 'js-cookie'; import { Feature } from '../../services/types'; import { useBoolState } from '../helpers'; +import { publishDbgObject } from '../../utils'; export interface FeatureContextType { feature: Feature | null; @@ -43,6 +44,8 @@ export const FeatureProvider = ({ useEffect(() => { // set feature on next.js router transition setFeature(featureFromRouter); + publishDbgObject('feature', featureFromRouter); + publishDbgObject('schema', featureFromRouter?.schema); }, [featureFromRouter]); const [homepageShown, showHomepage, hideHomepage] = useBoolState( diff --git a/src/helpers/featureLabel.ts b/src/helpers/featureLabel.ts index 765633ddb..0115a938f 100644 --- a/src/helpers/featureLabel.ts +++ b/src/helpers/featureLabel.ts @@ -1,8 +1,8 @@ import { Feature } from '../services/types'; import { roundedToDeg } from '../utils'; -const getSubclass = ({ properties, osmMeta }: Feature) => - properties.subclass?.replace(/_/g, ' ') || osmMeta.type; // TODO translate ? maybe use iD editor logic (already with translations) +const getSubclass = ({ properties, osmMeta, schema }: Feature) => + schema?.label || properties.subclass?.replace(/_/g, ' ') || osmMeta.type; const getRef = (feature: Feature) => feature.tags.ref ? `${getSubclass(feature)} ${feature.tags.ref}` : ''; diff --git a/src/services/__tests__/osmApi.test.ts b/src/services/__tests__/osmApi.test.ts index 2ab93c2bb..d339f3b58 100644 --- a/src/services/__tests__/osmApi.test.ts +++ b/src/services/__tests__/osmApi.test.ts @@ -9,15 +9,29 @@ import { way, wayFeature, } from './osmApi.fixture'; +import { intl } from '../intl'; +import * as tagging from '../tagging/translations'; +import * as idTaggingScheme from '../tagging/idTaggingScheme'; const osm = (item) => ({ elements: [item] }); const overpass = { elements: [{ center: { lat: 50, lon: 14 } }], }; +// fetchFeature() fetches the translations for getSchemaForFeature() +// TODO maybe refactor it without need for intl? +intl.lang = 'en'; +jest.mock('next/config', () => () => ({ + publicRuntimeConfig: { languages: ['en'] }, +})); + describe('fetchFeature', () => { beforeEach(() => { jest.clearAllMocks(); + jest.spyOn(tagging, 'fetchSchemaTranslations').mockResolvedValue(true); + jest + .spyOn(idTaggingScheme, 'getSchemaForFeature') + .mockReturnValue(undefined); // this is covered in idTaggingScheme.test.ts }); const isServer = jest.spyOn(helpers, 'isServer').mockReturnValue(true); diff --git a/src/services/fetchCache.ts b/src/services/fetchCache.ts index 4125c0bfc..5a4ac2812 100644 --- a/src/services/fetchCache.ts +++ b/src/services/fetchCache.ts @@ -7,6 +7,7 @@ const fetchCache = isBrowser() get: (key) => sessionStorage.getItem(key), remove: (key) => sessionStorage.removeItem(key), put: (key, value) => sessionStorage.setItem(key, value), + clear: () => sessionStorage.clear(), } : { get: (key) => cache[key], @@ -14,6 +15,7 @@ const fetchCache = isBrowser() put: (key, value) => { cache[key] = value; }, + clear: () => {}, }; export const getKey = (url, opts) => url + JSON.stringify(opts); @@ -28,6 +30,9 @@ export const writeCacheSafe = (key, value) => { try { fetchCache.put(key, value); } catch (e) { + if (e.message.includes('exceeded the quota')) { + fetchCache.clear(); + } console.warn(`Item ${key} was not saved to cache: `, e); // eslint-disable-line no-console } }; diff --git a/src/services/helpers.ts b/src/services/helpers.ts index 5d0773a28..7fc11e83a 100644 --- a/src/services/helpers.ts +++ b/src/services/helpers.ts @@ -88,40 +88,43 @@ export const isValidImage = (url): Promise => { export const stringifyDomXml = (itemXml) => isString(itemXml) ? itemXml : new XMLSerializer().serializeToString(itemXml); -// TODO better mexico border + add Australia, New Zealand & South Africa +// TODO better mexico border + add Australia, New Zealand & South Africa const polygonUsCan = [[-143, 36], [-117, 32], [-96, 25], [-50, 19], [-56, 71], [-175, 70], [-143, 36]]; // prettier-ignore -const isInside = ([x, y]: Position, vs) => { - // ray-casting algorithm based on - // https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html/pnpoly.html +const isInside = ([x, y]: Position, points) => { + // ray-casting algorithm based on https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html let inside = false; - // eslint-disable-next-line no-plusplus - for (let i = 0, j = vs.length - 1; i < vs.length; j = i++) { - const [xi, yi] = vs[i]; - const [xj, yj] = vs[j]; + for (let i = 0, j = points.length - 1; i < points.length; j = i, i += 1) { + const [xi, yi] = points[i]; + const [xj, yj] = points[j]; const intersect = yi > y !== yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi; if (intersect) inside = !inside; } return inside; }; +const isNumberFirst = (loc: Position) => loc && isInside(loc, polygonUsCan); export const buildAddress = ( { 'addr:place': place, 'addr:street': street, 'addr:housenumber': hnum, - 'addr:conscriptionnumber': num1, // czech/slovak/hungary - 'addr:streetnumber': num2, + 'addr:conscriptionnumber': cnum, // czech/slovak/hungary + 'addr:streetnumber': snum, 'addr:city': city, + 'addr:state': state, + 'addr:postcode': postcode, }: Record, - loc: Position = undefined, + loc?: Position, ) => { - if (loc && isInside(loc, polygonUsCan)) { - return join(join(hnum ?? num2, ' ', street ?? place), ', ', city); - } + const number = hnum ?? join(cnum, '/', snum); + const streetPlace = street ?? place; + return join( - join(street ?? place, ' ', hnum ?? join(num1, '/', num2)), + isNumberFirst(loc) + ? join(number, ' ', streetPlace) + : join(streetPlace, ' ', number), ', ', - city, + join(join(postcode, ' ', city), ', ', state), ); }; diff --git a/src/services/intl.tsx b/src/services/intl.tsx index 2b3efdbe3..9e417086e 100644 --- a/src/services/intl.tsx +++ b/src/services/intl.tsx @@ -4,6 +4,7 @@ import Router from 'next/router'; import { MessagesType, TranslationId } from './types'; import { isBrowser, isServer } from '../components/helpers'; import { getServerIntl } from './intlServer'; +import { publishDbgObject } from '../utils'; type Values = { [variable: string]: string }; @@ -50,6 +51,7 @@ export const setIntl = (initialIntl: Intl) => { if (initialIntl) { intl.lang = initialIntl.lang; intl.messages = initialIntl.messages; + publishDbgObject('intl', intl); } }; diff --git a/src/services/osmApi.ts b/src/services/osmApi.ts index 3536f4d63..442a4ce26 100644 --- a/src/services/osmApi.ts +++ b/src/services/osmApi.ts @@ -5,6 +5,8 @@ import { removeFetchCache } from './fetchCache'; import { overpassAroundToSkeletons } from './overpassAroundToSkeletons'; import { getPoiClass } from './getPoiClass'; import { isBrowser } from '../components/helpers'; +import { getSchemaForFeature } from './tagging/idTaggingScheme'; +import { fetchSchemaTranslations } from './tagging/translations'; const getOsmUrl = ({ type, id }) => `https://www.openstreetmap.org/api/0.6/${type}/${id}.json`; @@ -98,6 +100,7 @@ export const fetchFeature = async (shortId): Promise => { const [element, center] = await Promise.all([ getOsmPromise(apiId), getCenterPromise(apiId), + fetchSchemaTranslations(), // TODO this should be mocked in test??? could be moved to setIntl or something ]); const feature = osmToFeature(element); @@ -105,7 +108,9 @@ export const fetchFeature = async (shortId): Promise => { feature.center = center; } - return feature; + const schema = getSchemaForFeature(feature); // TODO forward lang here ?? maybe full intl? + console.log('schema', schema); // eslint-disable-line no-console + return { ...feature, schema }; } catch (e) { console.error(`fetchFeature(${shortId}):`, e); // eslint-disable-line no-console diff --git a/src/services/tagging/__tests__/idTaggingScheme.test.ts b/src/services/tagging/__tests__/idTaggingScheme.test.ts new file mode 100644 index 000000000..943b9cbe1 --- /dev/null +++ b/src/services/tagging/__tests__/idTaggingScheme.test.ts @@ -0,0 +1,64 @@ +import translations from '@openstreetmap/id-tagging-schema/dist/translations/en.json'; +import { getSchemaForFeature } from '../idTaggingScheme'; +import { Feature } from '../../types'; +import { mockSchemaTranslations } from '../translations'; +import { intl } from '../../intl'; + +intl.lang = 'en'; + +jest.mock('next/config', () => () => ({ + publicRuntimeConfig: { languages: ['en'] }, +})); + +const feature = { + osmMeta: { type: 'way' }, + tags: { + bicycle: 'no', + bridge: 'yes', + foot: 'no', + hgv: 'designated', + highway: 'motorway', + horse: 'no', + lanes: '2', + layer: '1', + lit: 'no', + maxspeed: '55 mph', + oneway: 'yes', + ref: 'I 84', + surface: 'asphalt', + 'tiger:cfcc': 'A15', + 'tiger:county': 'Orange, NY', + 'tiger:name_base': 'I-84', + }, +} as unknown as Feature; + +describe('idTaggingScheme', () => { + it('should multiple access', () => { + mockSchemaTranslations(translations); + + const result = getSchemaForFeature(feature); + expect(result.label).toBe('Motorway'); + expect(result.presetKey).toBe('highway/motorway'); + expect(result.matchedFields).toMatchObject([ + { label: 'Road Number', value: 'I 84' }, + { label: 'One Way', value: 'Yes' }, + { label: 'Speed Limit', value: '55 mph' }, + { label: 'Lanes', value: '2' }, + { label: 'Surface', value: 'Asphalt' }, + { + label: 'Allowed Access', + value: 'Foot: Prohibited,\nBicycles: Prohibited,\nHorses: Prohibited', + }, + { label: 'Lit', value: 'no' }, + ]); + expect(result.tagsWithFields).toMatchObject([ + { label: 'Layer', value: '1' }, + ]); + expect(result.keysTodo).toMatchObject([ + 'hgv', + 'tiger:cfcc', + 'tiger:county', + 'tiger:name_base', + ]); + }); +}); diff --git a/src/services/tagging/data.ts b/src/services/tagging/data.ts new file mode 100644 index 000000000..52e0fad7d --- /dev/null +++ b/src/services/tagging/data.ts @@ -0,0 +1,30 @@ +import fieldsJson from '@openstreetmap/id-tagging-schema/dist/fields.json'; +import presetsJson from '@openstreetmap/id-tagging-schema/dist/presets.json'; +import { Fields } from './types/Fields'; +import { Presets } from './types/Presets'; +import { publishDbgObject } from '../../utils'; + +export const fields = fieldsJson as unknown as Fields; + +Object.keys(fieldsJson).forEach((fieldKey) => { + fields[fieldKey].fieldKey = fieldKey; +}); + +export const presets = presetsJson as unknown as Presets; +Object.keys(presetsJson).forEach((presetKey) => { + presets[presetKey].presetKey = presetKey; +}); + +publishDbgObject('presets', presets); +publishDbgObject('fields', fields); + +// TODO build a key lookup table for fields by osm key ? +// const fieldsByOsmKey = {}; +// Object.entries(fields).forEach(([fieldKey, field]) => { +// if (field.key) { +// fieldsByOsmKey[field.key] = fieldKey; +// } +// if (field.keys) { +// field.keys.forEach((key) => (fieldsByOsmKey[key] = fieldKey)); +// } +// }); diff --git a/src/services/tagging/fields.ts b/src/services/tagging/fields.ts new file mode 100644 index 000000000..bd5310330 --- /dev/null +++ b/src/services/tagging/fields.ts @@ -0,0 +1,74 @@ +// links like {shop}, are recursively resolved to their fields +import { Preset } from './types/Presets'; +import { presets } from './data'; + +const getResolvedFields = (fieldKeys: string[]): string[] => + fieldKeys.flatMap((key) => { + if (key.match(/^{.*}$/)) { + const presetKey = key.substr(1, key.length - 2); + return getResolvedFields(presets[presetKey].fields); // TODO does "{shop}" links to preset's fields or moreFields? + } + return key; + }); + +const getResolvedFieldsWithParents = ( + preset: Preset, + fieldType: 'fields' | 'moreFields', +): string[] => { + const parts = preset.presetKey.split('/'); + + if (parts.length > 1) { + const parentKey = parts.slice(0, parts.length - 1).join('/'); + const parentPreset = presets[parentKey]; + if (parentPreset) { + return [ + ...getResolvedFieldsWithParents(parentPreset, fieldType), + ...(preset[fieldType] ?? []), + ]; + } + } + + return preset[fieldType] ?? []; +}; + +export const computeAllFieldKeys = (preset: Preset) => { + const allFieldKeys = [ + ...getResolvedFields(getResolvedFieldsWithParents(preset, 'fields')), + ...getResolvedFields(getResolvedFieldsWithParents(preset, 'moreFields')), + ]; + + // @ts-ignore + return [...new Set(allFieldKeys)]; +}; + +export const getValueForField = ( + field, + fieldTranslation, + value: string, + tagsForField = [], +) => { + if (field.type === 'semiCombo') { + return value + .split(';') + .map((v) => fieldTranslation?.options?.[v] ?? v) + .join(',\n'); + } + // eg field.type === 'access' or 'structure' + if (fieldTranslation?.types && fieldTranslation?.options) { + return tagsForField + .map( + ({ key, value: value2 }) => + `${fieldTranslation.types[key]}: ${fieldTranslation.options[value2]?.title}`, + ) + .join(',\n'); + } + + // TODO this is not correct + if (tagsForField.length >= 2) { + return tagsForField + .map(({ key, value: value2 }) => `${key}: ${value2}`) + .join(',\n'); + } + + return fieldTranslation?.options?.[value] ?? value; +}; diff --git a/src/services/tagging/idTaggingScheme.ts b/src/services/tagging/idTaggingScheme.ts new file mode 100644 index 000000000..22ddf69c5 --- /dev/null +++ b/src/services/tagging/idTaggingScheme.ts @@ -0,0 +1,174 @@ +import { Feature } from '../types'; +import { getFieldTranslation, getPresetTranslation } from './translations'; +import { getPresetForFeature } from './presets'; +import { fields } from './data'; +import { computeAllFieldKeys, getValueForField } from './fields'; +import { Preset } from './types/Presets'; +import { publishDbgObject } from '../../utils'; + +// TODO move to shared place +const featuredKeys = [ + 'name', // this is not in the other place + 'website', + 'contact:website', + 'phone', + 'contact:phone', + 'contact:mobile', + 'opening_hours', + 'description', +]; + +const matchFieldsFromPreset = ( + preset: Preset, + keysTodo: any, + feature: Feature, +) => { + const computedAllFieldKeys = computeAllFieldKeys(preset); + publishDbgObject('computedAllFieldKeys', computedAllFieldKeys); + + return computedAllFieldKeys + .map((fieldKey: string) => { + const field = fields[fieldKey]; + const key = field?.key; + const keys = field?.keys; + const shouldWeIncludeThisField = + keysTodo.has(key) || keysTodo.hasAny(keys); + if (!shouldWeIncludeThisField) { + return {}; + } + if (field.type === 'typeCombo') { + keysTodo.remove(field.key); // ignore eg. railway=tram_stop on public_transport=stop_position + return {}; + } + + const value = feature.tags[key]; + + const keysInField = [ + ...(field.keys ?? []), + ...(field.key ? [field.key] : []), + ]; + const tagsForField = []; + keysInField.forEach((k) => { + if (feature.tags[k]) { + tagsForField.push({ key: k, value: feature.tags[k] }); + } + keysTodo.remove(k); // remove all "address:*" keys etc. + }); + + const fieldTranslation = getFieldTranslation(field); + + return { + key, + value: getValueForField(field, fieldTranslation, value, tagsForField), + field, + tagsForField, + fieldTranslation, + label: fieldTranslation?.label ?? field.label, + }; + }) + .filter((field) => field.value); +}; + +const matchRestToFields = (keysTodo: any, feature: Feature) => + keysTodo + .map((key) => { + const field = Object.values(fields).find( + (f) => f.key === key || f.keys?.includes(key), + ); // todo cache this + if (!field) { + return {}; + } + if (field.type === 'typeCombo') { + keysTodo.remove(field.key); // ignore eg. railway=tram_stop on public_transport=stop_position + return {}; + } + + const value = feature.tags[key]; + + const keysInField = [ + ...(field.keys ?? []), + ...(field.key ? [field.key] : []), + ]; + const tagsForField = []; + keysInField.forEach((k) => { + if (feature.tags[k]) { + tagsForField.push({ key: k, value: feature.tags[k] }); + } + keysTodo.remove(k); // remove all "address:*" keys etc. + }); + + const fieldTranslation = getFieldTranslation(field); + + return { + key, + value: getValueForField(field, fieldTranslation, value, tagsForField), + field, + tagsForField, + fieldTranslation, + label: fieldTranslation?.label ?? field.label ?? `[${key}]`, + }; + }) + .filter((field) => field.field); + +const keysTodo = { + state: [], + init(feature) { + this.state = Object.keys(feature.tags).filter( + (key) => !featuredKeys.includes(key), + ); + }, + resolve(tags) { + Object.keys(tags).forEach((key) => { + this.state.splice(this.state.indexOf(key), 1); + }); + }, + has(key) { + return this.state.includes(key); + }, + hasAny(keys) { + return keys?.some((key) => this.state.includes(key)); + }, + remove(key) { + const index = this.state.indexOf(key); + if (index > -1) { + this.state.splice(index, 1); + } + }, + resolveFields(fieldsArray) { + fieldsArray.forEach((field) => { + if (field?.field?.key) { + this.remove(field.field.key); + } + if (field?.field?.keys) { + field.field.keys.forEach((key) => this.remove(key)); + } + }); + }, + map(fn) { + return this.state.map(fn); + }, +}; + +export const getSchemaForFeature = (feature: Feature) => { + const preset = getPresetForFeature(feature); + + keysTodo.init(feature); + keysTodo.resolve(preset.tags); // remove tags which are already covered by Preset keys + + const matchedFields = matchFieldsFromPreset(preset, keysTodo, feature); + keysTodo.resolveFields(matchedFields); + + const tagsWithFields = matchRestToFields(keysTodo, feature); + keysTodo.resolveFields(tagsWithFields); + + // TODO fix one field with more tags! like address + return { + presetKey: preset.presetKey, + preset, + feature, + label: getPresetTranslation(preset.presetKey), + matchedFields, + tagsWithFields, + keysTodo: keysTodo.state, + }; +}; diff --git a/src/services/tagging/presets.ts b/src/services/tagging/presets.ts new file mode 100644 index 000000000..b1ce93f9f --- /dev/null +++ b/src/services/tagging/presets.ts @@ -0,0 +1,85 @@ +import { presets } from './data'; +import { Feature } from '../types'; +import { Preset } from './types/Presets'; + +// taken from iD codebase https://github.com/openstreetmap/iD/blob/dd30a39d7487e1084396712ce861f4b6c5a07849/modules/presets/preset.js#L61 +// _this is "preset" object with originalScore set +const matchScore = (_this, entityTags) => { + /* eslint-disable no-restricted-syntax,guard-for-in */ + const { tags } = _this; + const seen = {}; + let score = 0; + + // match on tags + for (const k in tags) { + seen[k] = true; + if (entityTags[k] === tags[k]) { + score += _this.originalScore; + } else if (tags[k] === '*' && k in entityTags) { + score += _this.originalScore / 2; + } else { + return -1; + } + } + + // boost score for additional matches in addTags - #6802 + const { addTags } = _this; + for (const k in addTags) { + if (!seen[k] && entityTags[k] === addTags[k]) { + score += _this.originalScore; + } + } + + if (_this.searchable === false) { + score *= 0.999; + } + + return score; + /* eslint-enable no-restricted-syntax,guard-for-in */ +}; + +const index = { + node: [], + way: [], + relation: [], +}; + +// build an index by geometry type +Object.values(presets).forEach((preset) => { + const { geometry } = preset; + + geometry.forEach((geometryType) => { + const record = { + originalScore: (preset as any).matchScore ?? 1, + ...preset, + }; + + // OsmAPP can't distinguish between points and vertices + if (geometryType === 'point' || geometryType === 'vertex') { + index.node.push(record); + } else if (geometryType === 'line') { + index.way.push(record); + } else if (geometryType === 'area') { + index.way.push(record); + index.relation.push(record); + } else if (geometryType === 'relation') { + index.relation.push(record); + } + }); +}); + +// inspired by _this.matchTags() in iD codebase +export const getPresetForFeature = (feature: Feature): Preset => { + const { tags, osmMeta } = feature; + const { type } = osmMeta; + const candidates = []; + + index[type].forEach((candidate) => { + const score = matchScore(candidate, tags); + if (score !== -1) { + candidates.push({ score, candidate }); + } + }); + + return candidates.sort((a, b) => b.score - a.score)[0].candidate; +}; diff --git a/src/services/tagging/translations.ts b/src/services/tagging/translations.ts new file mode 100644 index 000000000..16800b41e --- /dev/null +++ b/src/services/tagging/translations.ts @@ -0,0 +1,42 @@ +import { fetchJson } from '../fetch'; +import { Field } from './types/Fields'; +import { intl } from '../intl'; +import { publishDbgObject } from '../../utils'; + +// https://cdn.jsdelivr.net/npm/@openstreetmap/id-tagging-schema@6.1.0/dist/translations/en.min.json +const cdnUrl = `https://cdn.jsdelivr.net/npm/@openstreetmap/id-tagging-schema`; + +// TODO downloa up-to-date or use node_module? +let translations = {}; +export const fetchSchemaTranslations = async () => { + if (translations[intl.lang]) return; + + const presetsPackage = await fetchJson(`${cdnUrl}/package.json`); + const { version } = presetsPackage; + + // this request is cached in browser + translations = await fetchJson( + `${cdnUrl}@${version}/dist/translations/${intl.lang}.min.json`, + ); + publishDbgObject('schemaTranslations', translations); +}; + +export const mockSchemaTranslations = (mockTranslations) => { + translations = mockTranslations; +}; + +export const getPresetTranslation = (key: string) => + translations ? translations[intl.lang].presets.presets[key].name : undefined; + +export const getFieldTranslation = (field: Field) => { + if (!translations) return undefined; + + if (field.label?.match(/^{.*}$/)) { + const resolved = field.label.substr(1, field.label.length - 2); + return translations[intl.lang].presets.fields[resolved]; + } + + // The id 169522276 is different for each intl.language :( + // https://www.transifex.com/openstreetmap/id-editor/translate/#cs/presets/169522276?q=key%3Apresets.fields.XXX + return translations[intl.lang].presets.fields[field.fieldKey]; +}; diff --git a/src/services/tagging/types/Fields.ts b/src/services/tagging/types/Fields.ts new file mode 100644 index 000000000..38fd9add6 --- /dev/null +++ b/src/services/tagging/types/Fields.ts @@ -0,0 +1,223 @@ +// https://github.com/ideditor/schema-builder/blob/main/schemas/field.json + +type FieldType = + | 'access' + | 'address' + | 'check' + | 'colour' + | 'combo' + | 'date' + | 'defaultCheck' + | 'directionalCombo' + | 'email' + | 'identifier' + | 'lanes' + | 'localized' + | 'manyCombo' + | 'multiCombo' + | 'networkCombo' + | 'number' + | 'onewayCheck' + | 'radio' + | 'restrictions' + | 'roadheight' + | 'roadspeed' + | 'semiCombo' + | 'structureRadio' + | 'tel' + | 'text' + | 'textarea' + | 'typeCombo' + | 'url' + | 'wikidata' + | 'wikipedia'; + +/** + * A reusable form element for presets + */ +export type Field = { + // added by osmapp (not in schema) + fieldKey: string; + + /** + * Tag key whose value is to be displayed + */ + key?: string; + /** + * Tag keys whose value is to be displayed + */ + keys?: string[]; + /** + * Taginfo documentation parameters (to be used when a field manages multiple tags) + */ + reference?: + | { + /** + * For documentation of a key + */ + key?: string; + /** + * For documentation of a tag (key and value) + */ + value?: string; + } + | { + /** + * For documentation of a relation type + */ + rtype?: string; + }; + /** + * Type of field + */ + type?: FieldType; + /** + * English label for the field caption. A field can reference the label of another by using that field's identifier contained in brackets (e.g. {field}), in which case also the field's terms will be referenced from that field. + */ + label?: string; + /** + * If specified, only show the field for these kinds of geometry + */ + geometry?: [ + 'point' | 'vertex' | 'line' | 'area' | 'relation', // minimal one entry + ...('point' | 'vertex' | 'line' | 'area' | 'relation')[] + ]; + /** + * The default value for this field + */ + default?: string; + /** + * List of untranslatable string suggestions (combo fields) + */ + options?: string[]; + /** + * If true, the top values from TagInfo will be suggested in the dropdown (combo fields only) + */ + autoSuggestions?: boolean; + /** + * If true, the user can type their own value in addition to any listed in `options` or `strings.options` (combo fields only) + */ + customValues?: boolean; + /** + * If true, this field will appear in the Add Field list for all presets + */ + universal?: boolean; + /** + * Placeholder text for this field. A field can reference the placeholder text of another by using that field's identifier contained in brackets, like {field}. + */ + placeholder?: string; + /** + * Strings sent to transifex for translation + */ + strings?: { + /** + * Translatable options (combo fields). + */ + options?: { + [k: string]: unknown; + }; + /** + * Specialized fields can request translation of arbitrary strings + */ + [k: string]: { + [k: string]: unknown; + }; + }; + /** + * A field can reference strings of another by using that field's identifier contained in brackets, like {field}. + */ + stringsCrossReference?: string; + /** + * If true, replace spaces with underscores in the tag value (combo fields only) + */ + snake_case?: boolean; + /** + * If true, allow case sensitive field values (combo fields only) + */ + caseSensitive?: boolean; + /** + * Minimum field value (number fields only) + */ + minValue?: number; + /** + * Maximum field value (number fields only) + */ + maxValue?: number; + /** + * The amount the stepper control should add or subtract (number fields only) + */ + increment?: number; + /** + * Tagging constraint for showing this field in the editor + */ + prerequisiteTag?: + | { + /** + * The key of the required tag + */ + key: string; + } + | { + /** + * The key of the required tag + */ + key: string; + /** + * The value that the tag must have. (alternative to 'valueNot') + */ + value: string; + } + | { + /** + * The key of the required tag + */ + key: string; + /** + * The value that the tag cannot have. (alternative to 'value') + */ + valueNot: string; + } + | { + /** + * A key that must not be present + */ + keyNot: string; + }; + /** + * English synonyms or related search terms + */ + terms?: string[]; + /** + * An object specifying the IDs of regions where this field is or isn't valid. See: https://github.com/ideditor/location-conflation + */ + locationSet?: { + include?: string[]; + exclude?: string[]; + }; + /** + * Permalink URL for `identifier` fields. Must contain a {value} placeholder + */ + urlFormat?: string; + /** + * Regular expression that a valid `identifier` value is expected to match + */ + pattern?: string; + /** + * The manner and context in which the field is used + */ + usage?: 'preset' | 'changeset' | 'manual' | 'group'; + /** + * For combo fields: Name of icons which represents different values of this field + */ + icons?: { + [k: string]: unknown; + }; + /** + * A field can reference icons of another by using that field's identifier contained in brackets, like {field}. + */ + iconsCrossReference?: string; +}; + +export type Fields = { + [fieldKey: string]: Field; +}; diff --git a/src/services/tagging/types/Presets.ts b/src/services/tagging/types/Presets.ts new file mode 100644 index 000000000..a96788694 --- /dev/null +++ b/src/services/tagging/types/Presets.ts @@ -0,0 +1,97 @@ +/** + * Associates an icon, form fields, and other UI with a set of OSM tags + */ +export interface Preset { + // added by osmapp (not in schema) + presetKey: string; + + /** + * The English name for the feature. A preset can reference the label of another by using that preset's identifier contained in brackets (e.g. {preset}), in which case also the preset's aliases and terms will also be referenced from that preset. + */ + name?: string; + /** + * Valid geometry types for the feature, in order of preference + */ + geometry?: [ + 'point' | 'vertex' | 'line' | 'area' | 'relation', + ...('point' | 'vertex' | 'line' | 'area' | 'relation')[] + ]; + /** + * Tags that must be present for the preset to match + */ + tags?: { + [k: string]: string; + }; + /** + * Tags that are added when changing to the preset (default is the same value as 'tags') + */ + addTags?: { + [k: string]: string; + }; + /** + * Tags that are removed when changing to another preset (default is the same value as 'addTags' which in turn defaults to 'tags') + */ + removeTags?: { + [k: string]: string; + }; + /** + * Default form fields that are displayed for the preset. A preset can reference the fields of another by using that preset's identifier contained in brackets, like {preset}. + */ + fields?: string[]; + /** + * Additional form fields that can be attached with the 'Add field' dropdown. A preset can reference the "moreFields" of another by using that preset's identifier contained in brackets, like {preset}. + */ + moreFields?: string[]; + /** + * Name of preset icon which represents this preset + */ + icon?: string; + /** + * The URL of a remote image that is more specific than 'icon' + */ + imageURL?: string; + /** + * English search terms or related keywords + */ + terms?: string[]; + /** + * Display-ready English synonyms for the `name` + */ + aliases?: string[]; + /** + * Whether or not the preset will be suggested via search + */ + searchable?: boolean; + /** + * The quality score this preset will receive when being compared with other matches (higher is better) + */ + matchScore?: number; + /** + * Taginfo documentation parameters (to be used when a preset manages multiple tags) + */ + reference?: { + /** + * For documentation of a key + */ + key?: string; + /** + * For documentation of a tag (key and value) + */ + value?: string; + }; + /** + * The ID of a preset that is preferable to this one + */ + replacement?: string; + /** + * An object specifying the IDs of regions where this preset is or isn't valid. See: https://github.com/ideditor/location-conflation + */ + locationSet?: { + include?: string[]; + exclude?: string[]; + }; +} + +export type Presets = { + [presetKey: string]: Preset; +}; diff --git a/src/services/types.ts b/src/services/types.ts index 4e5832fea..e4810b703 100644 --- a/src/services/types.ts +++ b/src/services/types.ts @@ -1,4 +1,5 @@ import type Vocabulary from '../locales/vocabulary'; +import type { getSchemaForFeature } from './tagging/idTaggingScheme'; export interface ImageUrls { source?: string; @@ -74,6 +75,7 @@ export interface Feature { roundedCenter?: LonLatRounded; ssrFeatureImage?: Image; error?: 'deleted' | 'network' | 'unknown' | '404' | '500'; // etc. + schema?: ReturnType; // skeleton layer?: { id: string }; diff --git a/src/utils.ts b/src/utils.ts index 891f96ac2..ab1d7f39c 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -53,3 +53,12 @@ export const getUtfStrikethrough = (text) => .join(''); export const join = (a, sep, b) => `${a || ''}${a && b ? sep : ''}${b || ''}`; + +export const publishDbgObject = (key, value) => { + if (typeof window !== 'undefined') { + // @ts-ignore + if (!window.dbg) window.dbg = {}; + // @ts-ignore + window.dbg[key] = value; + } +}; diff --git a/yarn.lock b/yarn.lock index 46c728185..21de4b3cc 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1795,6 +1795,11 @@ "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" +"@openstreetmap/id-tagging-schema@^6.1.0": + version "6.3.0" + resolved "https://registry.yarnpkg.com/@openstreetmap/id-tagging-schema/-/id-tagging-schema-6.3.0.tgz#4e58045a2489fc3aedff680757f2676a7894c490" + integrity sha512-Qe8cHI58bya8AjbVmWicPxwaJE7xq98ffcZ/M7AwYdM2QbxfsQHooBjh1HYBpxSWgd9JVT6d3g4uaUYftvyhtw== + "@rollup/plugin-babel@^5.2.0": version "5.3.1" resolved "https://registry.yarnpkg.com/@rollup/plugin-babel/-/plugin-babel-5.3.1.tgz#04bc0608f4aa4b2e4b1aebf284344d0f68fda283" From 7e3d3bf62e99526f20a7e1ee12926c54c9235444 Mon Sep 17 00:00:00 2001 From: Will Hubsch Date: Tue, 20 Jun 2023 02:15:38 -0400 Subject: [PATCH 08/35] FeaturePanel: Add operator dropdown (#161) --- src/components/FeaturePanel/TagsTable.tsx | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/components/FeaturePanel/TagsTable.tsx b/src/components/FeaturePanel/TagsTable.tsx index 6bbefb7bc..173de615a 100644 --- a/src/components/FeaturePanel/TagsTable.tsx +++ b/src/components/FeaturePanel/TagsTable.tsx @@ -67,6 +67,7 @@ const isBuilding = (k) => k.match(/building|roof|^min_level|^max_level|height$/); const isNetwork = (k) => k.match(/network/); const isBrand = (k) => k.match(/^brand/); +const isOperator = (k) => k.match(/^operator/); const isPayment = (k) => k.match(/^payment/); const TagsGroup = ({ tags, label, value, hideArrow = false, onEdit }) => { @@ -119,6 +120,7 @@ export const TagsTable = ({ tags, center, except, onEdit }) => { const buildings = tagsEntries.filter(([k]) => isBuilding(k)); const networks = tagsEntries.filter(([k]) => isNetwork(k)); const brands = tagsEntries.filter(([k]) => isBrand(k)); + const operator = tagsEntries.filter(([k]) => isOperator(k)); const payments = tagsEntries.filter(([k]) => isPayment(k)); const rest = tagsEntries.filter( ([k]) => @@ -130,6 +132,7 @@ export const TagsTable = ({ tags, center, except, onEdit }) => { !isAddr(k) && !isBuilding(k) && !isNetwork(k) && + !isOperator(k) && !isPayment(k) && !isBrand(k), ); @@ -210,6 +213,12 @@ export const TagsTable = ({ tags, center, except, onEdit }) => { value={tags.network} onEdit={onEdit} /> + Date: Tue, 20 Jun 2023 22:56:03 +0200 Subject: [PATCH 09/35] tagging: fix "0" bug in FeaturePanel --- src/components/FeaturePanel/FeaturePanel.tsx | 2 +- src/components/Map/MapFooter/MapFooter.tsx | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/FeaturePanel/FeaturePanel.tsx b/src/components/FeaturePanel/FeaturePanel.tsx index be0ab3b72..c45483b38 100644 --- a/src/components/FeaturePanel/FeaturePanel.tsx +++ b/src/components/FeaturePanel/FeaturePanel.tsx @@ -79,7 +79,7 @@ const FeaturePanel = () => { )} {!advanced && ( <> - {featuredTags.length && ( + {!!featuredTags.length && ( { /> ); - return ; + return ; // eslint-disable-line react/no-danger }); // place a separator between attributions From 9e68a4bc89cca6aa60ea1defa1f539d5e4ca8e80 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Wed, 21 Jun 2023 22:58:48 +0200 Subject: [PATCH 10/35] general: add tailwind-refactor to README.md --- README.md | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index f82c86aa4..dba211546 100644 --- a/README.md +++ b/README.md @@ -2,8 +2,12 @@ Lets create a universal OpenStreetMap app for broad public. It should be as easy to use as Google Maps, including clickable POIs and editing capabilites. See also [SotM 2021 talk](https://github.com/zbycz/osmapp-talk). -- master branch: https://osmapp.org -- examples: [Empire State Building](https://osmapp.org/way/34633854#17.00/40.7483/-73.9864), [Prague Castle](https://osmapp.org/relation/3312247#17.00/50.0900/14.4000) or click just anything +- **production**: https://osmapp.org + - examples: [Empire State Building](https://osmapp.org/way/34633854#17.00/40.7483/-73.9864), [Prague Castle](https://osmapp.org/relation/3312247#17.00/50.0900/14.4000) or click just anything +- **master branch**: https://osmapp-git-master-zbycz.vercel.app/ + - it is currently undergoing a [major refactoring to TailwindCSS](https://github.com/zbycz/osmapp/issues/165) thanks to [@Flohhhhh](https://github.com/Flohhhhh) + - until finished, some components would be MUI and some new design + - some functionality may be broken ## How to contribute 🐱‍💻 From 2093782a8d4ee62afe5db026a13328e89803a412 Mon Sep 17 00:00:00 2001 From: Dlurak <84224239+Dlurak@users.noreply.github.com> Date: Wed, 16 Aug 2023 19:53:37 +0200 Subject: [PATCH 11/35] FeaturePanel: add public transport labels (#175) * added a LineNumber component * added a function to get information about train routes from a trainstation * improved the new function to also get different routes * combined all components so it works now * added a test * added error handling * improved the overpass query to also work with certain bus stops * changed the default colour of the LineNumber component * added more public transport facilities and route types * implemented that the LineNumbers default color respects a forced theme --- src/components/FeaturePanel/FeaturePanel.tsx | 3 + .../PublicTransport/LineNumber.tsx | 41 +++++++++ .../PublicTransport/PublicTransport.tsx | 92 +++++++++++++++++++ .../PublicTransportWrapper.tsx | 14 +++ .../PublicTransport/requestRoutes.ts | 47 ++++++++++ src/services/__tests__/osmApi.test.ts | 15 +++ 6 files changed, 212 insertions(+) create mode 100644 src/components/FeaturePanel/PublicTransport/LineNumber.tsx create mode 100644 src/components/FeaturePanel/PublicTransport/PublicTransport.tsx create mode 100644 src/components/FeaturePanel/PublicTransport/PublicTransportWrapper.tsx create mode 100644 src/components/FeaturePanel/PublicTransport/requestRoutes.ts diff --git a/src/components/FeaturePanel/FeaturePanel.tsx b/src/components/FeaturePanel/FeaturePanel.tsx index c45483b38..e1a9c3a39 100644 --- a/src/components/FeaturePanel/FeaturePanel.tsx +++ b/src/components/FeaturePanel/FeaturePanel.tsx @@ -23,6 +23,7 @@ import { getLabel } from '../../helpers/featureLabel'; import { ImageSection } from './ImageSection/ImageSection'; import { IdSchemeFields } from './IdSchemeFields'; import { TagsTable } from './TagsTable'; +import { PublicTransport } from './PublicTransport/PublicTransport'; const featuredKeys = [ 'website', @@ -104,6 +105,8 @@ const FeaturePanel = () => { {advanced && } + + {editEnabled && ( <> 125 ? 'black' : 'white'; +} + +export const LineNumber: React.FC = ({ name, color }) => { + const { currentTheme } = useUserThemeContext(); + const darkmode = currentTheme === 'dark'; + + let bgcolor: string; + if (!color) bgcolor = darkmode ? '#898989' : '#dddddd'; + // set the default color + else bgcolor = color.toLowerCase(); + + const divStyle: React.CSSProperties = { + backgroundColor: bgcolor, + paddingBlock: '0.2rem', + paddingInline: '0.4rem', + borderRadius: '0.125rem', + display: 'inline', + color: whiteOrBlackText(bgcolor), + }; + + return
{name}
; +}; diff --git a/src/components/FeaturePanel/PublicTransport/PublicTransport.tsx b/src/components/FeaturePanel/PublicTransport/PublicTransport.tsx new file mode 100644 index 000000000..12419b9d5 --- /dev/null +++ b/src/components/FeaturePanel/PublicTransport/PublicTransport.tsx @@ -0,0 +1,92 @@ +import React, { useState, useEffect } from 'react'; +import { useRouter } from 'next/router'; +import { Typography } from '@material-ui/core'; +import { LineInformation, requestLines } from './requestRoutes'; +import { PublicTransportWrapper } from './PublicTransportWrapper'; +import { FeatureTags } from '../../../services/types'; +import { LineNumber } from './LineNumber'; + +interface PublicTransportProps { + tags: FeatureTags; +} + +const useLoadingState = () => { + const [routes, setRoutes] = useState([]); + const [error, setError] = useState(); + const [loading, setLoading] = useState(true); + + const finishRoutes = (payload) => { + setLoading(false); + setRoutes(payload); + }; + + const startRoutes = () => { + setLoading(true); + setRoutes([]); + setError(undefined); + }; + + const failRoutes = () => { + setError('Could not load routes'); + setLoading(false); + }; + + return { routes, error, loading, startRoutes, finishRoutes, failRoutes }; +}; + +const PublicTransportInner = () => { + const router = useRouter(); + + const { routes, error, loading, startRoutes, finishRoutes, failRoutes } = + useLoadingState(); + + useEffect(() => { + const loadData = async () => { + startRoutes(); + const lines = await requestLines( + router.query.all[0] as any, + Number(router.query.all[1]), + ).catch(failRoutes); + finishRoutes(lines); + }; + + loadData(); + }, []); + + return ( +
+ {loading ? ( + <> + . + . + . + + ) : ( + + {routes.map((line) => ( + + ))} + + )} + {error && ( + + Error: {error} + + )} +
+ ); +}; + +export const PublicTransport: React.FC = ({ tags }) => { + const isPublicTransport = + Object.keys(tags).includes('public_transport') || + tags.railway === 'station' || + tags.railway === 'halt' || + tags.railway === 'subway_entrance'; + + if (!isPublicTransport) { + return null; + } + + return PublicTransportInner(); +}; diff --git a/src/components/FeaturePanel/PublicTransport/PublicTransportWrapper.tsx b/src/components/FeaturePanel/PublicTransport/PublicTransportWrapper.tsx new file mode 100644 index 000000000..9d621eea6 --- /dev/null +++ b/src/components/FeaturePanel/PublicTransport/PublicTransportWrapper.tsx @@ -0,0 +1,14 @@ +import React from 'react'; + +export const PublicTransportWrapper = ({ children }) => { + const divStyle: React.CSSProperties = { + display: 'flex', + flexDirection: 'row', + alignItems: 'start', + justifyContent: 'start', + gap: '0.5rem', + flexWrap: 'wrap', + }; + + return
{children}
; +}; diff --git a/src/components/FeaturePanel/PublicTransport/requestRoutes.ts b/src/components/FeaturePanel/PublicTransport/requestRoutes.ts new file mode 100644 index 000000000..c7c8d667a --- /dev/null +++ b/src/components/FeaturePanel/PublicTransport/requestRoutes.ts @@ -0,0 +1,47 @@ +import { fetchText } from '../../../services/fetch'; + +export interface LineInformation { + ref: string; + colour: string | undefined; +} + +export async function requestLines( + featureType: 'node' | 'way' | 'relation', + id: number, + radius = 150, +) { + // use the overpass api to request the lines in + const overpassQuery = `[out:csv(ref, colour; false; ';')]; + ${featureType}(${id})->.center; + ( + node(around.center:${radius})["public_transport"="stop_position"]; + nw(around.center:${radius})["highway"="bus_stop"]; + nwr(around.center:${radius})["amenity"="ferry_terminal"]; + ) -> .stops; + rel(bn.stops)["route"~"bus|train|tram|subway|light_rail|ferry|monorail"]; + out;`; + + // send the request + const response: string = await fetchText( + `https://overpass-api.de/api/interpreter?data=${encodeURIComponent( + overpassQuery, + )}`, + ); + + let resData = response.split('\n').map((line) => { + const ref = line.split(';').slice(0, -1).join(';'); + let colour = line.split(';')[line.split(';').length - 1]; + + // set colour to undefined if it is empty + if (colour === '') colour = undefined; + return { ref, colour } as LineInformation; + }); + + resData = resData.filter((line) => line.ref !== ''); + // remove duplicats + resData = resData.filter( + (line, index) => resData.findIndex((l) => l.ref === line.ref) === index, + ); + resData.sort((a, b) => a.ref.localeCompare(b.ref)); + return resData; +} diff --git a/src/services/__tests__/osmApi.test.ts b/src/services/__tests__/osmApi.test.ts index d339f3b58..ade80e42d 100644 --- a/src/services/__tests__/osmApi.test.ts +++ b/src/services/__tests__/osmApi.test.ts @@ -12,6 +12,7 @@ import { import { intl } from '../intl'; import * as tagging from '../tagging/translations'; import * as idTaggingScheme from '../tagging/idTaggingScheme'; +import { requestLines } from '../../components/FeaturePanel/PublicTransport/requestRoutes'; const osm = (item) => ({ elements: [item] }); const overpass = { @@ -71,6 +72,20 @@ describe('fetchFeature', () => { expect(feature).toEqual(relationFeature); }); + it('should return some fetched routes', async () => { + const features = await requestLines('node', 3862767512); + + features.forEach((feature) => { + expect(feature).toHaveProperty('ref'); + expect(feature.ref).not.toBe(''); + expect(feature.ref).toEqual(expect.any(String)); + expect(feature).toHaveProperty('colour'); + expect( + typeof feature.colour === 'string' || feature.colour === undefined, + ).toBeTruthy(); + }); + }); + it('should return cached center for a way in BROWSER', async () => { isBrowser.mockReturnValue(true); isServer.mockReturnValue(false); From d63896491f3562fbf3c7354cd109c07ec26254ee Mon Sep 17 00:00:00 2001 From: Dlurak <84224239+Dlurak@users.noreply.github.com> Date: Tue, 22 Aug 2023 08:17:40 +0200 Subject: [PATCH 12/35] FeaturePanel: fix contrast issue in IdScheme (#178) --- src/components/FeaturePanel/IdSchemeFields.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/FeaturePanel/IdSchemeFields.tsx b/src/components/FeaturePanel/IdSchemeFields.tsx index d8f2cbd64..21147b22e 100644 --- a/src/components/FeaturePanel/IdSchemeFields.tsx +++ b/src/components/FeaturePanel/IdSchemeFields.tsx @@ -26,7 +26,7 @@ const Table = styled.table` th { width: 140px; max-width: 140px; - color: rgba(0, 0, 0, 0.54); + color: ${({ theme }) => theme.palette.text.secondary}; text-align: left; font-weight: normal; vertical-align: baseline; From 3c837135a6a7b60de837c33313ce39d01cf74f28 Mon Sep 17 00:00:00 2001 From: Dlurak <84224239+Dlurak@users.noreply.github.com> Date: Tue, 29 Aug 2023 14:20:49 +0200 Subject: [PATCH 13/35] FeaturePanel: add Food hygiene rating scheme (#179) --- src/components/FeaturePanel/FeaturePanel.tsx | 1 + src/components/FeaturePanel/FeaturedTag.tsx | 6 +- .../renderers/FoodHygieneRatingScheme.tsx | 101 ++++++++++++++++++ src/services/__tests__/fhrsApi.test.ts | 47 ++++++++ src/services/fhrsApi.ts | 16 +++ 5 files changed, 170 insertions(+), 1 deletion(-) create mode 100644 src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx create mode 100644 src/services/__tests__/fhrsApi.test.ts create mode 100644 src/services/fhrsApi.ts diff --git a/src/components/FeaturePanel/FeaturePanel.tsx b/src/components/FeaturePanel/FeaturePanel.tsx index e1a9c3a39..2071f0b19 100644 --- a/src/components/FeaturePanel/FeaturePanel.tsx +++ b/src/components/FeaturePanel/FeaturePanel.tsx @@ -33,6 +33,7 @@ const featuredKeys = [ 'contact:mobile', 'opening_hours', 'description', + 'fhrs:id', ]; const FeaturePanel = () => { diff --git a/src/components/FeaturePanel/FeaturedTag.tsx b/src/components/FeaturePanel/FeaturedTag.tsx index f68d327ee..c6b28f55b 100644 --- a/src/components/FeaturePanel/FeaturedTag.tsx +++ b/src/components/FeaturePanel/FeaturedTag.tsx @@ -5,6 +5,7 @@ import WebsiteRenderer from './renderers/WebsiteRenderer'; import OpeningHoursRenderer from './renderers/OpeningHoursRenderer'; import PhoneRenderer from './renderers/PhoneRenderer'; import { EditIconButton } from './helpers/EditIconButton'; +import { FoodHygieneRatingSchemeRenderer } from './renderers/FoodHygieneRatingScheme'; const Wrapper = styled.div` position: relative; @@ -29,13 +30,16 @@ const Value = styled.div` `; const DefaultRenderer = ({ v }) => v; -const renderers = { +const renderers: { + [key: string]: React.FC<{ v: string }>; +} = { website: WebsiteRenderer, 'contact:website': WebsiteRenderer, phone: PhoneRenderer, 'contact:phone': PhoneRenderer, 'contact:mobile': PhoneRenderer, opening_hours: OpeningHoursRenderer, + 'fhrs:id': FoodHygieneRatingSchemeRenderer, }; export const FeaturedTag = ({ k, v, onEdit }) => { diff --git a/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx b/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx new file mode 100644 index 000000000..8d2ef1f30 --- /dev/null +++ b/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx @@ -0,0 +1,101 @@ +import React, { useEffect, useState } from 'react'; +import { Typography } from '@material-ui/core'; +import { Restaurant } from '@material-ui/icons'; +import { getEstablishmentRatingValue } from '../../../services/fhrsApi'; + +interface StarRatingProps { + stars: number; + maxStars: number; +} + +const StarRating = ({ stars, maxStars }: StarRatingProps) => { + const starArray = new Array(maxStars).fill(0); + return ( +
+ {starArray.map((_, i) => ( + {i < stars ? '★' : '☆'} + ))} +
+ ); +}; + +const useLoadingState = () => { + const [rating, setRating] = useState(); + const [error, setError] = useState(); + const [loading, setLoading] = useState(true); + + const finishRating = (payload) => { + setLoading(false); + setRating(payload); + }; + + const startRating = () => { + setLoading(true); + setRating(undefined); + setError(undefined); + }; + + const failRating = () => { + setError('Could not load rating'); + setLoading(false); + }; + + return { rating, error, loading, startRating, finishRating, failRating }; +}; + +export const FoodHygieneRatingSchemeRenderer = ({ v }) => { + const { rating, error, loading, startRating, finishRating, failRating } = + useLoadingState(); + + useEffect(() => { + const loadData = async () => { + startRating(); + const ratingValue = await getEstablishmentRatingValue(v); + if (Number.isNaN(rating)) { + failRating(); + } + finishRating(ratingValue); + }; + + loadData(); + }, []); + + const linkStyle: React.CSSProperties = { + display: 'flex', + alignItems: 'center', + gap: '0.5rem', + }; + const pStyle: React.CSSProperties = { + marginBlock: '0', + }; + + return ( + <> + {loading ? ( + <> + + + + + ) : ( + <> + + {Number.isNaN(rating) || error ? ( + No rating available + ) : ( + <> + +

FHRS

+ +
+ + )} + + )} + + ); +}; diff --git a/src/services/__tests__/fhrsApi.test.ts b/src/services/__tests__/fhrsApi.test.ts new file mode 100644 index 000000000..57294d66a --- /dev/null +++ b/src/services/__tests__/fhrsApi.test.ts @@ -0,0 +1,47 @@ +import * as fetchModule from '../fetch'; +import { getEstablishmentRatingValue } from '../fhrsApi'; + +describe('fetchRating', () => { + it('should return a rating between 0 and 5', async () => { + const fetchJsonMock = jest + .spyOn(fetchModule, 'fetchJson') + .mockResolvedValue({ + FHRSID: 423824, + ChangesByServerID: 0, + LocalAuthorityBusinessID: '13359', + BusinessName: 'Caffe Nero', + BusinessType: 'Restaurant/Cafe/Canteen', + BusinessTypeID: 1, + AddressLine1: '', + AddressLine2: '30 Monmouth Street', + AddressLine3: '', + AddressLine4: 'London', + PostCode: 'WC2H 9HA', + Phone: '', + RatingValue: '5', + RatingKey: 'fhrs_5_en-gb', + RatingDate: '2019-09-11T00:00:00', + LocalAuthorityCode: '506', + LocalAuthorityName: 'Camden', + LocalAuthorityWebSite: 'http://www.camden.gov.uk', + LocalAuthorityEmailAddress: 'foodsafety@camden.gov.uk', + scores: { + Hygiene: 0, + Structural: 0, + ConfidenceInManagement: 0, + }, + SchemeType: 'FHRS', + geocode: { + longitude: '-0.1272279', + latitude: '51.5136148', + }, + RightToReply: '', + Distance: null, + NewRatingPending: false, + }); + + const rating = await getEstablishmentRatingValue(269382); + expect(rating).toBeLessThanOrEqual(5); + fetchJsonMock.mockRestore(); + }); +}); diff --git a/src/services/fhrsApi.ts b/src/services/fhrsApi.ts new file mode 100644 index 000000000..787bb2ef8 --- /dev/null +++ b/src/services/fhrsApi.ts @@ -0,0 +1,16 @@ +import { fetchJson } from './fetch'; + +function fetchEstablishmentData(id: number) { + return fetchJson(`https://api.ratings.food.gov.uk/Establishments/${id}`, { + headers: { + 'x-api-version': '2', + }, + }); +} + +export async function getEstablishmentRatingValue(id: number) { + const allData = await fetchEstablishmentData(id).catch(() => null); + const ratingString = allData?.RatingValue; + const ratingValue = parseInt(ratingString, 10); + return ratingValue; +} From 974d1acc305ecb9b46e6967edef8d5816ddff03a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Sun, 10 Sep 2023 20:19:51 +0200 Subject: [PATCH 14/35] FeaturePanel: small refactorings of FHRS (#181) --- .../renderers/FoodHygieneRatingScheme.tsx | 76 ++++++++++--------- src/helpers/theme.tsx | 4 + src/services/__tests__/fhrsApi.test.ts | 2 +- 3 files changed, 45 insertions(+), 37 deletions(-) diff --git a/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx b/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx index 8d2ef1f30..6d0685f8f 100644 --- a/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx +++ b/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx @@ -1,24 +1,9 @@ import React, { useEffect, useState } from 'react'; -import { Typography } from '@material-ui/core'; +import { Tooltip, Typography } from '@material-ui/core'; import { Restaurant } from '@material-ui/icons'; +import styled from 'styled-components'; import { getEstablishmentRatingValue } from '../../../services/fhrsApi'; -interface StarRatingProps { - stars: number; - maxStars: number; -} - -const StarRating = ({ stars, maxStars }: StarRatingProps) => { - const starArray = new Array(maxStars).fill(0); - return ( -
- {starArray.map((_, i) => ( - {i < stars ? '★' : '☆'} - ))} -
- ); -}; - const useLoadingState = () => { const [rating, setRating] = useState(); const [error, setError] = useState(); @@ -43,6 +28,26 @@ const useLoadingState = () => { return { rating, error, loading, startRating, finishRating, failRating }; }; +const Wrapper = styled.div` + display: flex; + gap: 0.5rem; + + .MuiRating-root { + margin-top: -2px; + } +`; + +const RatingRound = styled.span` + border-radius: 50%; + background-color: #1a6500; + color: #fff; + padding: 0.25rem 0.5rem; + font-size: 0.75rem; + font-weight: bold; + position: relative; + top: -1px; +`; + export const FoodHygieneRatingSchemeRenderer = ({ v }) => { const { rating, error, loading, startRating, finishRating, failRating } = useLoadingState(); @@ -60,15 +65,6 @@ export const FoodHygieneRatingSchemeRenderer = ({ v }) => { loadData(); }, []); - const linkStyle: React.CSSProperties = { - display: 'flex', - alignItems: 'center', - gap: '0.5rem', - }; - const pStyle: React.CSSProperties = { - marginBlock: '0', - }; - return ( <> {loading ? ( @@ -80,20 +76,28 @@ export const FoodHygieneRatingSchemeRenderer = ({ v }) => { ) : ( <> - {Number.isNaN(rating) || error ? ( - No rating available - ) : ( - <> + + -

FHRS

- + FHRS{' '} + {Number.isNaN(rating) || error ? ( + + (Error while fetching rating) + + ) : ( + {rating} + )}
- - )} +
+
)} diff --git a/src/helpers/theme.tsx b/src/helpers/theme.tsx index 44b4958c7..9dea0853d 100644 --- a/src/helpers/theme.tsx +++ b/src/helpers/theme.tsx @@ -24,6 +24,8 @@ const lightTheme = createMuiTheme({ }, text: { panelHeading: 'rgba(0, 0, 0, 0.7)', + primary: '#000', + primaryInvert: '#fff', }, appBackground: '#f8f4f0', panelBackground: '#fafafa', @@ -52,6 +54,8 @@ const darkTheme = createMuiTheme({ }, text: { panelHeading: 'rgba(255, 255, 255, 0.85)', + primary: '#fff', + primaryInvert: '#000', }, appBackground: grey['900'], panelBackground: grey['800'], diff --git a/src/services/__tests__/fhrsApi.test.ts b/src/services/__tests__/fhrsApi.test.ts index 57294d66a..798eddfa8 100644 --- a/src/services/__tests__/fhrsApi.test.ts +++ b/src/services/__tests__/fhrsApi.test.ts @@ -41,7 +41,7 @@ describe('fetchRating', () => { }); const rating = await getEstablishmentRatingValue(269382); - expect(rating).toBeLessThanOrEqual(5); + expect(rating).toBe(5); fetchJsonMock.mockRestore(); }); }); From 0342b29f5886c8cee370e65cc780d9046bcdbfba Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Thu, 14 Sep 2023 07:34:51 +0200 Subject: [PATCH 15/35] FeaturePanel: fix import in FHRS (#183) --- .../renderers/FoodHygieneRatingScheme.tsx | 68 +++++++++---------- 1 file changed, 34 insertions(+), 34 deletions(-) diff --git a/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx b/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx index 6d0685f8f..e0021230d 100644 --- a/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx +++ b/src/components/FeaturePanel/renderers/FoodHygieneRatingScheme.tsx @@ -1,6 +1,6 @@ import React, { useEffect, useState } from 'react'; import { Tooltip, Typography } from '@material-ui/core'; -import { Restaurant } from '@material-ui/icons'; +import RestaurantIcon from '@material-ui/icons/Restaurant'; import styled from 'styled-components'; import { getEstablishmentRatingValue } from '../../../services/fhrsApi'; @@ -65,41 +65,41 @@ export const FoodHygieneRatingSchemeRenderer = ({ v }) => { loadData(); }, []); + if (loading) { + return ( + <> + + + + + ); + } + return ( <> - {loading ? ( - <> - - - - - ) : ( - <> - - - - - FHRS{' '} - {Number.isNaN(rating) || error ? ( - - (Error while fetching rating) - - ) : ( - {rating} - )} - - - - - )} + + + + + FHRS{' '} + {Number.isNaN(rating) || error ? ( + + (Error while fetching rating) + + ) : ( + {rating} + )} + + + ); }; From c80c173810050e0b421639c0edadccf5cfb69669 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Mon, 18 Sep 2023 19:49:30 +0200 Subject: [PATCH 16/35] Map: add 3D terrain control when user tilts (#184) --- package.json | 2 +- src/components/FeaturePanel/Coordinates.tsx | 4 +- src/components/Map/BrowserMap.tsx | 6 +- .../Map/behaviour/useToggleTerrainControl.tsx | 38 ++ src/components/Map/consts.ts | 6 + src/components/Map/helpers.ts | 23 ++ src/components/Map/styles/rasterStyle.ts | 4 +- src/helpers/GlobalStyle.tsx | 8 +- src/services/__tests__/osmApi.test.ts | 2 +- yarn.lock | 390 ++++++++++++------ 10 files changed, 351 insertions(+), 132 deletions(-) create mode 100644 src/components/Map/behaviour/useToggleTerrainControl.tsx diff --git a/package.json b/package.json index f1e9bc15a..0071da758 100644 --- a/package.json +++ b/package.json @@ -43,7 +43,7 @@ "js-cookie": "^2.2.1", "jss": "^10.6.0", "lodash": "^4.17.21", - "maplibre-gl": "^1.14.0", + "maplibre-gl": "^3.3.1", "next": "^13.4.3", "next-cookies": "^2.0.3", "next-pwa": "^5.2.21", diff --git a/src/components/FeaturePanel/Coordinates.tsx b/src/components/FeaturePanel/Coordinates.tsx index fc83f606f..a3c24a9d2 100644 --- a/src/components/FeaturePanel/Coordinates.tsx +++ b/src/components/FeaturePanel/Coordinates.tsx @@ -59,14 +59,14 @@ const LinkItem = ({ href, label }) => ( // Our map uses 512 tiles, so our zoom is "one less" // https://wiki.openstreetmap.org/wiki/Zoom_levels#Mapbox_GL -const MAPBOXGL_ZOOM_DIFFERENCE = 1; +const MAPLIBREGL_ZOOM_DIFFERENCE = 1; const useGetItems = ([lon, lat]: PositionBoth) => { const { feature } = useFeatureContext(); const { view } = useMapStateContext(); const [ourZoom] = view; - const zoom = parseFloat(ourZoom) + MAPBOXGL_ZOOM_DIFFERENCE; + const zoom = parseFloat(ourZoom) + MAPLIBREGL_ZOOM_DIFFERENCE; const zoomInt = Math.round(zoom); const osmQuery = feature?.osmMeta?.id ? `${feature.osmMeta.type}/${feature.osmMeta.id}` diff --git a/src/components/Map/BrowserMap.tsx b/src/components/Map/BrowserMap.tsx index ad430d5ec..10403ac83 100644 --- a/src/components/Map/BrowserMap.tsx +++ b/src/components/Map/BrowserMap.tsx @@ -1,6 +1,5 @@ import React from 'react'; import 'maplibre-gl/dist/maplibre-gl.css'; -import maplibregl from 'maplibre-gl'; import { useAddMapEvent, useMapEffect, useMobileMode } from '../helpers'; import { useMapStateContext } from '../utils/MapStateContext'; import { useFeatureContext } from '../utils/FeatureContext'; @@ -10,6 +9,8 @@ import { useUpdateViewOnMove } from './behaviour/useUpdateViewOnMove'; import { useUpdateStyle } from './behaviour/useUpdateStyle'; import { useInitMap } from './behaviour/useInitMap'; import { Translation } from '../../services/intl'; +import { useToggleTerrainControl } from './behaviour/useToggleTerrainControl'; +import { isWebglSupported } from './helpers'; const useOnMapLoaded = useAddMapEvent((map, onMapLoaded) => ({ eventType: 'load', @@ -32,7 +33,7 @@ const NotSupportedMessage = () => ( // TODO https://cdn.klokantech.com/openmaptiles-language/v1.0/openmaptiles-language.js + use localized name in FeaturePanel const BrowserMap = ({ onMapLoaded }) => { - if (!maplibregl.supported()) { + if (!isWebglSupported()) { onMapLoaded(); return ; } @@ -46,6 +47,7 @@ const BrowserMap = ({ onMapLoaded }) => { const { viewForMap, setViewFromMap, setBbox, activeLayers } = useMapStateContext(); useUpdateViewOnMove(map, setViewFromMap, setBbox); + useToggleTerrainControl(map); useUpdateMap(map, viewForMap); useUpdateStyle(map, activeLayers); diff --git a/src/components/Map/behaviour/useToggleTerrainControl.tsx b/src/components/Map/behaviour/useToggleTerrainControl.tsx new file mode 100644 index 000000000..05dd38f91 --- /dev/null +++ b/src/components/Map/behaviour/useToggleTerrainControl.tsx @@ -0,0 +1,38 @@ +/* eslint-disable no-underscore-dangle */ +import maplibregl from 'maplibre-gl'; +import { useAddMapEvent } from '../../helpers'; + +class OsmappTerrainControl extends maplibregl.TerrainControl { + _toggleTerrain = () => { + if (this._map.getTerrain()) { + this._map.setTerrain(null); + this._map.setMaxPitch(60); + } else { + this._map.setTerrain(this.options); + this._map.setMaxPitch(85); + } + this._updateTerrainIcon(); + }; +} + +const terrainControl = new OsmappTerrainControl({ + source: 'terrain', + exaggeration: 1, +}); + +let added = false; + +export const useToggleTerrainControl = useAddMapEvent((map) => ({ + eventType: 'move', + eventHandler: () => { + if (map.getPitch() > 0) { + if (!added) { + map.addControl(terrainControl); + added = true; + } + } else if (added) { + map.removeControl(terrainControl); + added = false; + } + }, +})); diff --git a/src/components/Map/consts.ts b/src/components/Map/consts.ts index 3bd35c7d0..09871320d 100644 --- a/src/components/Map/consts.ts +++ b/src/components/Map/consts.ts @@ -17,6 +17,12 @@ export const OSMAPP_SOURCES = { 'terrain-rgb': { url: `https://api.maptiler.com/tiles/terrain-rgb/tiles.json?key=${apiKey}`, type: 'raster-dem' as const, + tileSize: 256, + }, + terrain: { + url: `https://api.maptiler.com/tiles/terrain-rgb/tiles.json?key=${apiKey}`, + type: 'raster-dem' as const, + tileSize: 256, }, outdoor: { url: `https://api.maptiler.com/tiles/outdoor/tiles.json?key=${apiKey}`, diff --git a/src/components/Map/helpers.ts b/src/components/Map/helpers.ts index 14ab1493d..d63ccd8d6 100644 --- a/src/components/Map/helpers.ts +++ b/src/components/Map/helpers.ts @@ -41,3 +41,26 @@ export const convertOsmIdToMapId = (apiId: OsmApiId) => { const osmToMapType = { node: 0, way: 1, relation: 4 }; return parseInt(`${apiId.id}${osmToMapType[apiId.type]}`, 10); }; + +// maplibregl.supported() no longer exists +// copied from https://maplibre.org/maplibre-gl-js/docs/examples/check-for-support/ +export const isWebglSupported = () => { + if (window.WebGLRenderingContext) { + const canvas = document.createElement('canvas'); + try { + // Note that { failIfMajorPerformanceCaveat: true } can be passed as a second argument + // to canvas.getContext(), causing the check to fail if hardware rendering is not available. See + // https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/getContext + // for more details. + const context = canvas.getContext('webgl2') || canvas.getContext('webgl'); + if (context && typeof context.getParameter === 'function') { + return true; + } + } catch (e) { + // WebGL is supported, but disabled + } + return false; + } + // WebGL not supported + return false; +}; diff --git a/src/components/Map/styles/rasterStyle.ts b/src/components/Map/styles/rasterStyle.ts index 13ceef1bc..5f8ac514d 100644 --- a/src/components/Map/styles/rasterStyle.ts +++ b/src/components/Map/styles/rasterStyle.ts @@ -1,4 +1,4 @@ -import maplibregl from 'maplibre-gl'; +import type { StyleSpecification } from '@maplibre/maplibre-gl-style-spec'; import { GLYPHS, OSMAPP_SOURCES, OSMAPP_SPRITE } from '../consts'; const getSource = (url) => { @@ -21,7 +21,7 @@ const getSource = (url) => { }; }; -export const rasterStyle = (id, url): maplibregl.Style => { +export const rasterStyle = (id, url): StyleSpecification => { const source = getSource(url); return { version: 8, diff --git a/src/helpers/GlobalStyle.tsx b/src/helpers/GlobalStyle.tsx index 1d6f458d6..1bebd5edb 100644 --- a/src/helpers/GlobalStyle.tsx +++ b/src/helpers/GlobalStyle.tsx @@ -46,9 +46,9 @@ export const GlobalStyle = createGlobalStyle` margin-top: 0; } - .mapboxgl-ctrl-group { + .maplibregl-ctrl-group { background: ${({ theme }) => theme.palette.background.default} !important; - .mapboxgl-ctrl-icon { + .maplibregl-ctrl-icon { filter: ${({ theme }) => theme.palette.invertFilter}; } button+button { @@ -56,7 +56,7 @@ export const GlobalStyle = createGlobalStyle` } } - .mapboxgl-ctrl-top-right { + .maplibregl-ctrl-top-right { top: ${83 + 72}px !important; @media ${isDesktop} { @@ -64,7 +64,7 @@ export const GlobalStyle = createGlobalStyle` } } - .mapboxgl-canvas:not(:focus) { + .maplibregl-canvas:not(:focus) { outline: 0; } diff --git a/src/services/__tests__/osmApi.test.ts b/src/services/__tests__/osmApi.test.ts index ade80e42d..105a7ead2 100644 --- a/src/services/__tests__/osmApi.test.ts +++ b/src/services/__tests__/osmApi.test.ts @@ -29,7 +29,7 @@ jest.mock('next/config', () => () => ({ describe('fetchFeature', () => { beforeEach(() => { jest.clearAllMocks(); - jest.spyOn(tagging, 'fetchSchemaTranslations').mockResolvedValue(true); + jest.spyOn(tagging, 'fetchSchemaTranslations').mockResolvedValue(undefined); jest .spyOn(idTaggingScheme, 'getSchemaForFeature') .mockReturnValue(undefined); // this is covered in idTaggingScheme.test.ts diff --git a/yarn.lock b/yarn.lock index 21de4b3cc..e12636902 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1592,43 +1592,33 @@ "@jridgewell/resolve-uri" "3.1.0" "@jridgewell/sourcemap-codec" "1.4.14" -"@mapbox/geojson-rewind@^0.5.0": - version "0.5.0" - resolved "https://registry.yarnpkg.com/@mapbox/geojson-rewind/-/geojson-rewind-0.5.0.tgz#91f0ad56008c120caa19414b644d741249f4f560" - integrity sha512-73l/qJQgj/T/zO1JXVfuVvvKDgikD/7D/rHAD28S9BG1OTstgmftrmqfCx4U+zQAmtsB6HcDA3a7ymdnJZAQgg== +"@mapbox/geojson-rewind@^0.5.2": + version "0.5.2" + resolved "https://registry.yarnpkg.com/@mapbox/geojson-rewind/-/geojson-rewind-0.5.2.tgz#591a5d71a9cd1da1a0bf3420b3bea31b0fc7946a" + integrity sha512-tJaT+RbYGJYStt7wI3cq4Nl4SXxG8W7JDG5DMJu97V25RnbNg3QtQtf+KD+VLjNpWKYsRvXDNmNrBgEETr1ifA== dependencies: - concat-stream "~2.0.0" - minimist "^1.2.5" - -"@mapbox/geojson-types@^1.0.2": - version "1.0.2" - resolved "https://registry.yarnpkg.com/@mapbox/geojson-types/-/geojson-types-1.0.2.tgz#9aecf642cb00eab1080a57c4f949a65b4a5846d6" - integrity sha512-e9EBqHHv3EORHrSfbR9DqecPNn+AmuAoQxV6aL8Xu30bJMJR1o8PZLZzpk1Wq7/NfCbuhmakHTPYRhoqLsXRnw== + get-stream "^6.0.1" + minimist "^1.2.6" -"@mapbox/jsonlint-lines-primitives@^2.0.2": +"@mapbox/jsonlint-lines-primitives@^2.0.2", "@mapbox/jsonlint-lines-primitives@~2.0.2": version "2.0.2" resolved "https://registry.yarnpkg.com/@mapbox/jsonlint-lines-primitives/-/jsonlint-lines-primitives-2.0.2.tgz#ce56e539f83552b58d10d672ea4d6fc9adc7b234" integrity sha1-zlblOfg1UrWNENZy6k1vya3HsjQ= -"@mapbox/mapbox-gl-supported@^1.5.0": - version "1.5.0" - resolved "https://registry.yarnpkg.com/@mapbox/mapbox-gl-supported/-/mapbox-gl-supported-1.5.0.tgz#f60b6a55a5d8e5ee908347d2ce4250b15103dc8e" - integrity sha512-/PT1P6DNf7vjEEiPkVIRJkvibbqWtqnyGaBz3nfRdcxclNSnSdaLU5tfAgcD7I8Yt5i+L19s406YLl1koLnLbg== - "@mapbox/point-geometry@0.1.0", "@mapbox/point-geometry@^0.1.0", "@mapbox/point-geometry@~0.1.0": version "0.1.0" resolved "https://registry.yarnpkg.com/@mapbox/point-geometry/-/point-geometry-0.1.0.tgz#8a83f9335c7860effa2eeeca254332aa0aeed8f2" integrity sha1-ioP5M1x4YO/6Lu7KJUMyqgru2PI= -"@mapbox/tiny-sdf@^1.1.1": - version "1.2.5" - resolved "https://registry.yarnpkg.com/@mapbox/tiny-sdf/-/tiny-sdf-1.2.5.tgz#424c620a96442b20402552be70a7f62a8407cc59" - integrity sha512-cD8A/zJlm6fdJOk6DqPUV8mcpyJkRz2x2R+/fYcWDYG3oWbG7/L7Yl/WqQ1VZCjnL9OTIMAn6c+BC5Eru4sQEw== +"@mapbox/tiny-sdf@^2.0.6": + version "2.0.6" + resolved "https://registry.yarnpkg.com/@mapbox/tiny-sdf/-/tiny-sdf-2.0.6.tgz#9a1d33e5018093e88f6a4df2343e886056287282" + integrity sha512-qMqa27TLw+ZQz5Jk+RcwZGH7BQf5G/TrutJhspsca/3SHwmgKQ1iq+d3Jxz5oysPVYTGP6aXxCo5Lk9Er6YBAA== -"@mapbox/unitbezier@^0.0.0": - version "0.0.0" - resolved "https://registry.yarnpkg.com/@mapbox/unitbezier/-/unitbezier-0.0.0.tgz#15651bd553a67b8581fb398810c98ad86a34524e" - integrity sha1-FWUb1VOme4WB+zmIEMmK2Go0Uk4= +"@mapbox/unitbezier@^0.0.1": + version "0.0.1" + resolved "https://registry.yarnpkg.com/@mapbox/unitbezier/-/unitbezier-0.0.1.tgz#d32deb66c7177e9e9dfc3bbd697083e2e657ff01" + integrity sha512-nMkuDXFv60aBr9soUG5q+GvZYL+2KZHVvsqFCzqnkGEf46U2fvmytHaEVc1/YZbiLn8X+eR3QzX1+dwDO1lxlw== "@mapbox/vector-tile@^1.3.1": version "1.3.1" @@ -1642,6 +1632,18 @@ resolved "https://registry.yarnpkg.com/@mapbox/whoots-js/-/whoots-js-3.1.0.tgz#497c67a1cef50d1a2459ba60f315e448d2ad87fe" integrity sha512-Es6WcD0nO5l+2BOQS4uLfNPYQaNDfbot3X1XUoloz+x0mPDS3eeORZJl06HXjwBG1fOGwCRnzK88LMdxKRrd6Q== +"@maplibre/maplibre-gl-style-spec@^19.3.0": + version "19.3.1" + resolved "https://registry.yarnpkg.com/@maplibre/maplibre-gl-style-spec/-/maplibre-gl-style-spec-19.3.1.tgz#f0e74e8e6db2afcc4fed53f325f850c12dcdd5c5" + integrity sha512-ss5+b3/a8I1wD5PYmAYPYxg0Nag0cxvw4GGOnQroTP59sobTPI3KeHP9OjUr/es7uNtYEodr54fgoEnCBF6gaQ== + dependencies: + "@mapbox/jsonlint-lines-primitives" "~2.0.2" + "@mapbox/unitbezier" "^0.0.1" + json-stringify-pretty-compact "^3.0.0" + minimist "^1.2.8" + rw "^1.3.3" + sort-object "^3.0.3" + "@material-ui/core@^4.11.4": version "4.11.4" resolved "https://registry.yarnpkg.com/@material-ui/core/-/core-4.11.4.tgz#4fb9fe5dec5dcf780b687e3a40cff78b2b9640a4" @@ -1998,6 +2000,11 @@ resolved "https://registry.yarnpkg.com/@types/geojson/-/geojson-7946.0.7.tgz#c8fa532b60a0042219cdf173ca21a975ef0666ad" integrity sha512-wE2v81i4C4Ol09RtsWFAqg3BUitWbHSpSlIo+bNdsCJijO9sjme+zm+73ZMCa/qMC8UEERxzGbvmr1cffo2SiQ== +"@types/geojson@^7946.0.10": + version "7946.0.10" + resolved "https://registry.yarnpkg.com/@types/geojson/-/geojson-7946.0.10.tgz#6dfbf5ea17142f7f9a043809f1cd4c448cb68249" + integrity sha512-Nmh0K3iWQJzniTuPRcJn5hxXkfB1T1pgB89SBig5PlJQU5yocazeu4jATJlaA0GYFKWMqDdvYemoSnF2pXgLVA== + "@types/glob@^7.1.1": version "7.2.0" resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.2.0.tgz#bc1b5bf3aa92f25bd5dd39f35c57361bdce5b2eb" @@ -2055,6 +2062,20 @@ resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" integrity sha1-7ihweulOEdK4J7y+UnC86n8+ce4= +"@types/mapbox__point-geometry@*", "@types/mapbox__point-geometry@^0.1.2": + version "0.1.2" + resolved "https://registry.yarnpkg.com/@types/mapbox__point-geometry/-/mapbox__point-geometry-0.1.2.tgz#488a9b76e8457d6792ea2504cdd4ecdd9860a27e" + integrity sha512-D0lgCq+3VWV85ey1MZVkE8ZveyuvW5VAfuahVTQRpXFQTxw03SuIf1/K4UQ87MMIXVKzpFjXFiFMZzLj2kU+iA== + +"@types/mapbox__vector-tile@^1.3.0": + version "1.3.0" + resolved "https://registry.yarnpkg.com/@types/mapbox__vector-tile/-/mapbox__vector-tile-1.3.0.tgz#8fa1379dbaead1e1b639b8d96cfd174404c379d6" + integrity sha512-kDwVreQO5V4c8yAxzZVQLE5tyWF+IPToAanloQaSnwfXmIcJ7cyOrv8z4Ft4y7PsLYmhWXmON8MBV8RX0Rgr8g== + dependencies: + "@types/geojson" "*" + "@types/mapbox__point-geometry" "*" + "@types/pbf" "*" + "@types/maplibre-gl@^1.13.1": version "1.13.1" resolved "https://registry.yarnpkg.com/@types/maplibre-gl/-/maplibre-gl-1.13.1.tgz#d043f48e9f08e1b6a9aa7e924d2b86306f843f2b" @@ -2077,6 +2098,11 @@ resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== +"@types/pbf@*", "@types/pbf@^3.0.2": + version "3.0.2" + resolved "https://registry.yarnpkg.com/@types/pbf/-/pbf-3.0.2.tgz#8d291ad68b4b8c533e96c174a2e3e6399a59ed61" + integrity sha512-EDrLIPaPXOZqDjrkzxxbX7UlJSeQVgah3i0aA4pOSzmK9zq3BIh7/MZIQxED7slJByvKM4Gc6Hypyu2lJzh3SQ== + "@types/prettier@^2.1.5": version "2.2.3" resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-2.2.3.tgz#ef65165aea2924c9359205bf748865b8881753c0" @@ -2120,6 +2146,13 @@ resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-2.0.0.tgz#7036640b4e21cc2f259ae826ce843d277dad8cff" integrity sha512-RJJrrySY7A8havqpGObOB4W92QXKJo63/jFLLgpvOtsGUqbQZ9Sbgl35KMm1DjC6j7AvmmU2bIno+3IyEaemaw== +"@types/supercluster@^7.1.0": + version "7.1.0" + resolved "https://registry.yarnpkg.com/@types/supercluster/-/supercluster-7.1.0.tgz#67b7466c93a7d25b6e79a3c7cad885a79420aeb4" + integrity sha512-6JapQ2GmEkH66r23BK49I+u6zczVDGTtiJEVvKDYZVSm/vepWaJuTq6BXzJ6I4agG5s8vA1KM7m/gXWDg03O4Q== + dependencies: + "@types/geojson" "*" + "@types/trusted-types@^2.0.2": version "2.0.3" resolved "https://registry.yarnpkg.com/@types/trusted-types/-/trusted-types-2.0.3.tgz#a136f83b0758698df454e328759dbd3d44555311" @@ -2412,6 +2445,11 @@ aria-query@^4.2.2: "@babel/runtime" "^7.10.2" "@babel/runtime-corejs3" "^7.10.2" +arr-union@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz#e39b09aea9def866a8f206e288af63919bae39c4" + integrity sha512-sKpyeERZ02v1FeCZT8lrfJq5u6goHCtpTAzPwJYe7c8SPFOboNjNg1vz2L4VTn9T4PQxEx13TbXLmYUcS6Ug7Q== + array-buffer-byte-length@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz#fabe8bc193fea865f317fe7807085ee0dee5aead" @@ -2467,6 +2505,11 @@ array.prototype.flatmap@^1.2.4: es-abstract "^1.18.0-next.1" function-bind "^1.1.1" +assign-symbols@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367" + integrity sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw== + ast-types-flow@^0.0.7: version "0.0.7" resolved "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.7.tgz#f70b735c6bca1a5c9c22d982c3e39e7feba3bdad" @@ -2718,6 +2761,21 @@ busboy@1.6.0: dependencies: streamsearch "^1.1.0" +bytewise-core@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/bytewise-core/-/bytewise-core-1.2.3.tgz#3fb410c7e91558eb1ab22a82834577aa6bd61d42" + integrity sha512-nZD//kc78OOxeYtRlVk8/zXqTB4gf/nlguL1ggWA8FuchMyOxcyHR4QPQZMUmA7czC+YnaBrPUCubqAWe50DaA== + dependencies: + typewise-core "^1.2" + +bytewise@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/bytewise/-/bytewise-1.1.0.tgz#1d13cbff717ae7158094aa881b35d081b387253e" + integrity sha512-rHuuseJ9iQ0na6UDhnrRVDh8YnWVlU6xM3VH6q/+yHDeUH2zIhUzP+2/h3LIrhLDBtTqzWpE3p3tP/boefskKQ== + dependencies: + bytewise-core "^1.2.2" + typewise "^1.0.3" + call-bind@^1.0.0, call-bind@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" @@ -2936,16 +2994,6 @@ concat-map@0.0.1: resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== -concat-stream@~2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-2.0.0.tgz#414cf5af790a48c60ab9be4527d56d5e41133cb1" - integrity sha512-MWufYdFw53ccGjCA+Ol7XJYpAlW6/prSMzuPOTRnJGcGzuhLn4Scrz7qf6o8bROZ514ltazcIFJZevcfbo0x7A== - dependencies: - buffer-from "^1.0.0" - inherits "^2.0.3" - readable-stream "^3.0.2" - typedarray "^0.0.6" - confusing-browser-globals@^1.0.10: version "1.0.10" resolved "https://registry.yarnpkg.com/confusing-browser-globals/-/confusing-browser-globals-1.0.10.tgz#30d1e7f3d1b882b25ec4933d1d1adac353d20a59" @@ -3041,11 +3089,6 @@ css-vendor@^2.0.8: "@babel/runtime" "^7.8.3" is-in-browser "^1.0.2" -csscolorparser@~1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/csscolorparser/-/csscolorparser-1.0.3.tgz#b34f391eea4da8f3e98231e2ccd8df9c041f171b" - integrity sha1-s085HupNqPPpgjHizNjfnAQfFxs= - cssom@^0.4.4: version "0.4.4" resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.4.4.tgz#5a66cf93d2d0b661d80bf6a44fb65f5c2e4e0a10" @@ -3226,10 +3269,10 @@ domexception@^2.0.1: dependencies: webidl-conversions "^5.0.0" -earcut@^2.2.2: - version "2.2.2" - resolved "https://registry.yarnpkg.com/earcut/-/earcut-2.2.2.tgz#41b0bc35f63e0fe80da7cddff28511e7e2e80d11" - integrity sha512-eZoZPPJcUHnfRZ0PjLvx2qBordSiO8ofC3vt+qACLM95u+4DovnbYNpQtJh0DNsWj8RnxrQytD4WA8gj5cRIaQ== +earcut@^2.2.4: + version "2.2.4" + resolved "https://registry.yarnpkg.com/earcut/-/earcut-2.2.4.tgz#6d02fd4d68160c114825d06890a92ecaae60343a" + integrity sha512-/pjZsA1b4RPHbeWZQn66SWS8nZZWLQQ23oE3Eam7aroEFGEvwKAsJfZ9ytiEMycfzXWpca4FA9QIOehf7PocBQ== ejs@^3.1.6: version "3.1.9" @@ -3665,6 +3708,21 @@ expect@^27.0.2: jest-message-util "^27.0.2" jest-regex-util "^27.0.1" +extend-shallow@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f" + integrity sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug== + dependencies: + is-extendable "^0.1.0" + +extend-shallow@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz#26a71aaf073b39fb2127172746131c2704028db8" + integrity sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q== + dependencies: + assign-symbols "^1.0.0" + is-extendable "^1.0.1" + fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: version "3.1.3" resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" @@ -3883,7 +3941,7 @@ get-package-type@^0.1.0: resolved "https://registry.yarnpkg.com/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== -get-stream@^6.0.0: +get-stream@^6.0.0, get-stream@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== @@ -3896,10 +3954,15 @@ get-symbol-description@^1.0.0: call-bind "^1.0.2" get-intrinsic "^1.1.1" -gl-matrix@^3.2.1: - version "3.3.0" - resolved "https://registry.yarnpkg.com/gl-matrix/-/gl-matrix-3.3.0.tgz#232eef60b1c8b30a28cbbe75b2caf6c48fd6358b" - integrity sha512-COb7LDz+SXaHtl/h4LeaFcNdJdAQSDeVqjiIihSXNrkWObZLhDI4hIkZC11Aeqp7bcE72clzB0BnDXr2SmslRA== +get-value@^2.0.2, get-value@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" + integrity sha512-Ln0UQDlxH1BapMu3GPtf7CuYNwRZf2gwCuPqbyG6pB8WfmFpzqcy4xtAaAMUhnNqjMKTiCPZG2oMT3YSx8U2NA== + +gl-matrix@^3.4.3: + version "3.4.3" + resolved "https://registry.yarnpkg.com/gl-matrix/-/gl-matrix-3.4.3.tgz#fc1191e8320009fd4d20e9339595c6041ddc22c9" + integrity sha512-wcCp8vu8FT22BnvKVPjXa/ICBWRq/zjFfdofZy1WSpQZpphblv12/bOQLBC1rMM7SGOFS9ltVmKOHil5+Ml7gA== glob-parent@^5.0.0, glob-parent@^5.1.2: version "5.1.2" @@ -3932,6 +3995,15 @@ glob@^7.1.1, glob@^7.1.2, glob@^7.1.4: once "^1.3.0" path-is-absolute "^1.0.0" +global-prefix@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/global-prefix/-/global-prefix-3.0.0.tgz#fc85f73064df69f50421f47f883fe5b913ba9b97" + integrity sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg== + dependencies: + ini "^1.3.5" + kind-of "^6.0.2" + which "^1.3.1" + globals@^11.1.0: version "11.12.0" resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" @@ -4010,11 +4082,6 @@ graceful-fs@^4.2.4: resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.6.tgz#ff040b2b0853b23c3d31027523706f1885d76bee" integrity sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ== -grid-index@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/grid-index/-/grid-index-1.1.0.tgz#97f8221edec1026c8377b86446a7c71e79522ea7" - integrity sha512-HZRwumpOGUrHyxO5bqKZL0B0GlUpwtCAzZ42sgxUPniu33R1LSFH5yrIcBCHjkctCAh3mtWKcKd9J4vDDdeVHA== - has-bigints@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.1.tgz#64fe6acb020673e3b78db035a5af69aa9d07b113" @@ -4201,11 +4268,16 @@ inflight@^1.0.4: once "^1.3.0" wrappy "1" -inherits@2, inherits@^2.0.3: +inherits@2: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== +ini@^1.3.5: + version "1.3.8" + resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" + integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== + internal-slot@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.3.tgz#7347e307deeea2faac2ac6205d4bc7d34967f59c" @@ -4286,6 +4358,18 @@ is-date-object@^1.0.1: dependencies: has-tostringtag "^1.0.0" +is-extendable@^0.1.0, is-extendable@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" + integrity sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw== + +is-extendable@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz#a7470f9e426733d81bd81e1155264e3a3507cab4" + integrity sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA== + dependencies: + is-plain-object "^2.0.4" + is-extglob@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" @@ -4366,6 +4450,13 @@ is-path-inside@^2.1.0: dependencies: path-is-inside "^1.0.2" +is-plain-object@^2.0.3, is-plain-object@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" + integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== + dependencies: + isobject "^3.0.1" + is-potential-custom-element-name@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5" @@ -4456,6 +4547,11 @@ isexe@^2.0.0: resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" integrity sha1-6PvzdNxVb/iUehDcsFctYz8s+hA= +isobject@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" + integrity sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg== + isomorphic-unfetch@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/isomorphic-unfetch/-/isomorphic-unfetch-3.1.0.tgz#87341d5f4f7b63843d468438128cb087b7c3e98f" @@ -5052,6 +5148,11 @@ json-stable-stringify-without-jsonify@^1.0.1: resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" integrity sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE= +json-stringify-pretty-compact@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/json-stringify-pretty-compact/-/json-stringify-pretty-compact-3.0.0.tgz#f71ef9d82ef16483a407869556588e91b681d9ab" + integrity sha512-Rc2suX5meI0S3bfdZuA7JMFBGkJ875ApfVyq2WHELjBiiG22My/l7/8zPpH/CfFVQHuVLd8NLR0nv6vi0BYYKA== + json5@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.2.tgz#63d98d60f21b313b77c4d6da18bfa69d80e1d593" @@ -5291,10 +5392,15 @@ jss@10.6.0, jss@^10.5.1, jss@^10.6.0: array-includes "^3.1.2" object.assign "^4.1.2" -kdbush@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/kdbush/-/kdbush-3.0.0.tgz#f8484794d47004cc2d85ed3a79353dbe0abc2bf0" - integrity sha512-hRkd6/XW4HTsA9vjVpY9tuXJYLSlelnkTmVFu4M9/7MIYQtFcHpbugAU7UbOfjOiVSVYl2fqgBuJ32JUmRo5Ew== +kdbush@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/kdbush/-/kdbush-4.0.2.tgz#2f7b7246328b4657dd122b6c7f025fbc2c868e39" + integrity sha512-WbCVYJ27Sz8zi9Q7Q0xHC+05iwkm3Znipc2XTlrnJbsHMYktW4hPhXUE8Ys1engBrvffoSCqbil1JQAa7clRpA== + +kind-of@^6.0.2: + version "6.0.3" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" + integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== kleur@^3.0.3: version "3.0.3" @@ -5518,34 +5624,36 @@ makeerror@1.0.x: dependencies: tmpl "1.0.x" -maplibre-gl@^1.14.0: - version "1.14.0" - resolved "https://registry.yarnpkg.com/maplibre-gl/-/maplibre-gl-1.14.0.tgz#035663dae6cbaaca5b06024f6c5b51a42db1fc84" - integrity sha512-pqr/nsoZHx1rUY2Bpp0EFVcFVgrVOLkDDh2DhZcLVZVHYXdFOH/LyKUoLZda/3/CDTmlZy9ldJeZN8O0g1Ocpg== +maplibre-gl@^3.3.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/maplibre-gl/-/maplibre-gl-3.3.1.tgz#150e48d80813b72b66b89156446298c72dca4ca0" + integrity sha512-SfRq9bT68GytDzCOG0IoTGg2rASbgdYunW/6xhnp55QuLmwG1M/YOlXxqHaphwia7kZbMvBOocvY0fp5yfTjZA== dependencies: - "@mapbox/geojson-rewind" "^0.5.0" - "@mapbox/geojson-types" "^1.0.2" + "@mapbox/geojson-rewind" "^0.5.2" "@mapbox/jsonlint-lines-primitives" "^2.0.2" - "@mapbox/mapbox-gl-supported" "^1.5.0" "@mapbox/point-geometry" "^0.1.0" - "@mapbox/tiny-sdf" "^1.1.1" - "@mapbox/unitbezier" "^0.0.0" + "@mapbox/tiny-sdf" "^2.0.6" + "@mapbox/unitbezier" "^0.0.1" "@mapbox/vector-tile" "^1.3.1" "@mapbox/whoots-js" "^3.1.0" - csscolorparser "~1.0.3" - earcut "^2.2.2" + "@maplibre/maplibre-gl-style-spec" "^19.3.0" + "@types/geojson" "^7946.0.10" + "@types/mapbox__point-geometry" "^0.1.2" + "@types/mapbox__vector-tile" "^1.3.0" + "@types/pbf" "^3.0.2" + "@types/supercluster" "^7.1.0" + earcut "^2.2.4" geojson-vt "^3.2.1" - gl-matrix "^3.2.1" - grid-index "^1.1.0" - minimist "^1.2.5" + gl-matrix "^3.4.3" + global-prefix "^3.0.0" + kdbush "^4.0.2" murmurhash-js "^1.0.0" pbf "^3.2.1" - potpack "^1.0.1" + potpack "^2.0.0" quickselect "^2.0.0" - rw "^1.3.3" - supercluster "^7.1.0" + supercluster "^8.0.1" tinyqueue "^2.0.3" - vt-pbf "^3.1.1" + vt-pbf "^3.1.3" merge-stream@^2.0.0: version "2.0.0" @@ -5596,7 +5704,7 @@ minimatch@^5.0.1: dependencies: brace-expansion "^2.0.1" -minimist@^1.2.0, minimist@^1.2.5: +minimist@^1.2.0, minimist@^1.2.6, minimist@^1.2.8: version "1.2.8" resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== @@ -6003,7 +6111,7 @@ path-type@^4.0.0: resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== -pbf@^3.0.5, pbf@^3.2.1: +pbf@^3.2.1: version "3.2.1" resolved "https://registry.yarnpkg.com/pbf/-/pbf-3.2.1.tgz#b4c1b9e72af966cd82c6531691115cc0409ffe2a" integrity sha512-ClrV7pNOn7rtmoQVF4TS1vyU0WhYRnP92fzbfF75jAIwpnzdJXf8iTd4CMEqO4yUenH6NDqLiwjqlh6QgZzgLQ== @@ -6119,10 +6227,10 @@ postcss@8.4.14: picocolors "^1.0.0" source-map-js "^1.0.2" -potpack@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/potpack/-/potpack-1.0.1.tgz#d1b1afd89e4c8f7762865ec30bd112ab767e2ebf" - integrity sha512-15vItUAbViaYrmaB/Pbw7z6qX2xENbFSTA7Ii4tgbPtasxm5v6ryKhKtL91tpWovDJzTiZqdwzhcFBCwiMVdVw== +potpack@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/potpack/-/potpack-2.0.0.tgz#61f4dd2dc4b3d5e996e3698c0ec9426d0e169104" + integrity sha512-Q+/tYsFU9r7xoOJ+y/ZTtdVQwTWfzjbiXBDMM/JKUux3+QPP02iUuIoeBQ+Ot6oEDlC+/PGjB/5A3K7KKb7hcw== prefix-style@2.0.1: version "2.0.1" @@ -6327,15 +6435,6 @@ read-pkg@^3.0.0: normalize-package-data "^2.3.2" path-type "^3.0.0" -readable-stream@^3.0.2: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" - integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== - dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" - regenerate-unicode-properties@^10.1.0: version "10.1.0" resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz#7c3192cab6dd24e21cb4461e5ddd7dd24fa8374c" @@ -6528,7 +6627,7 @@ rxjs@^6.6.7: dependencies: tslib "^1.9.0" -safe-buffer@^5.1.0, safe-buffer@~5.2.0: +safe-buffer@^5.1.0: version "5.2.1" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== @@ -6637,6 +6736,16 @@ serialize-javascript@^6.0.1: dependencies: randombytes "^2.1.0" +set-value@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz#a18d40530e6f07de4228c7defe4227af8cad005b" + integrity sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw== + dependencies: + extend-shallow "^2.0.1" + is-extendable "^0.1.1" + is-plain-object "^2.0.3" + split-string "^3.0.1" + shallow-equal@^1.2.0: version "1.2.1" resolved "https://registry.yarnpkg.com/shallow-equal/-/shallow-equal-1.2.1.tgz#4c16abfa56043aa20d050324efa68940b0da79da" @@ -6706,6 +6815,28 @@ slice-ansi@^4.0.0: astral-regex "^2.0.0" is-fullwidth-code-point "^3.0.0" +sort-asc@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/sort-asc/-/sort-asc-0.2.0.tgz#00a49e947bc25d510bfde2cbb8dffda9f50eb2fc" + integrity sha512-umMGhjPeHAI6YjABoSTrFp2zaBtXBej1a0yKkuMUyjjqu6FJsTF+JYwCswWDg+zJfk/5npWUUbd33HH/WLzpaA== + +sort-desc@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/sort-desc/-/sort-desc-0.2.0.tgz#280c1bdafc6577887cedbad1ed2e41c037976646" + integrity sha512-NqZqyvL4VPW+RAxxXnB8gvE1kyikh8+pR+T+CXLksVRN9eiQqkQlPwqWYU0mF9Jm7UnctShlxLyAt1CaBOTL1w== + +sort-object@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/sort-object/-/sort-object-3.0.3.tgz#945727165f244af9dc596ad4c7605a8dee80c269" + integrity sha512-nK7WOY8jik6zaG9CRwZTaD5O7ETWDLZYMM12pqY8htll+7dYeqGfEUPcUBHOpSJg2vJOrvFIY2Dl5cX2ih1hAQ== + dependencies: + bytewise "^1.1.0" + get-value "^2.0.2" + is-extendable "^0.1.1" + sort-asc "^0.2.0" + sort-desc "^0.2.0" + union-value "^1.0.1" + source-list-map@^2.0.0: version "2.0.1" resolved "https://registry.yarnpkg.com/source-list-map/-/source-list-map-2.0.1.tgz#3993bd873bfc48479cca9ea3a547835c7c154b34" @@ -6790,6 +6921,13 @@ spdx-license-ids@^3.0.0: resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.7.tgz#e9c18a410e5ed7e12442a549fbd8afa767038d65" integrity sha512-U+MTEOO0AiDzxwFvoa4JVnMV6mZlJKk2sBLt90s7G0Gd0Mlknc7kxEn3nuDPNZRta7O2uy8oLcZLVT+4sqNZHQ== +split-string@^3.0.1: + version "3.1.0" + resolved "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz#7cb09dda3a86585705c64b39a6466038682e8fe2" + integrity sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw== + dependencies: + extend-shallow "^3.0.0" + sprintf-js@~1.0.2: version "1.0.3" resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" @@ -6894,13 +7032,6 @@ string.prototype.trimstart@^1.0.4, string.prototype.trimstart@^1.0.6: define-properties "^1.1.4" es-abstract "^1.20.4" -string_decoder@^1.1.1: - version "1.3.0" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" - integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== - dependencies: - safe-buffer "~5.2.0" - stringify-object@^3.3.0: version "3.3.0" resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" @@ -6990,12 +7121,12 @@ stylis@3.5.4: resolved "https://registry.yarnpkg.com/stylis/-/stylis-3.5.4.tgz#f665f25f5e299cf3d64654ab949a57c768b73fbe" integrity sha512-8/3pSmthWM7lsPBKv7NXkzn2Uc9W7NotcwGNpJaa3k7WMM1XDCA4MgT5k/8BIexd5ydZdboXtU90XH9Ec4Bv/Q== -supercluster@^7.1.0: - version "7.1.2" - resolved "https://registry.yarnpkg.com/supercluster/-/supercluster-7.1.2.tgz#cf02a60283a0118212024f3bf02e4e63bb148e2c" - integrity sha512-bGA0pk3DYMjLTY1h+rbh0imi/I8k/Lg0rzdBGfyQs0Xkiix7jK2GUmH1qSD8+jq6U0Vu382QHr3+rbbiHqdKJA== +supercluster@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/supercluster/-/supercluster-8.0.1.tgz#9946ba123538e9e9ab15de472531f604e7372df5" + integrity sha512-IiOea5kJ9iqzD2t7QJq/cREyLHTtSmUT6gQsweojg9WH2sYJqZK9SswTu6jrscO6D1G5v5vYZ9ru/eq85lXeZQ== dependencies: - kdbush "^3.0.0" + kdbush "^4.0.2" supports-color@^5.3.0, supports-color@^5.5.0: version "5.5.0" @@ -7282,16 +7413,23 @@ typedarray-to-buffer@^3.1.5: dependencies: is-typedarray "^1.0.0" -typedarray@^0.0.6: - version "0.0.6" - resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" - integrity sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c= - typescript@^5.0.4: version "5.0.4" resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.0.4.tgz#b217fd20119bd61a94d4011274e0ab369058da3b" integrity sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw== +typewise-core@^1.2, typewise-core@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/typewise-core/-/typewise-core-1.2.0.tgz#97eb91805c7f55d2f941748fa50d315d991ef195" + integrity sha512-2SCC/WLzj2SbUwzFOzqMCkz5amXLlxtJqDKTICqg30x+2DZxcfZN2MvQZmGfXWKNWaKK9pBPsvkcwv8bF/gxKg== + +typewise@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/typewise/-/typewise-1.0.3.tgz#1067936540af97937cc5dcf9922486e9fa284651" + integrity sha512-aXofE06xGhaQSPzt8hlTY+/YWQhm9P0jYUp1f2XtmW/3Bk0qzXcyFWAtPoo2uTGQj1ZwbDuSyuxicq+aDo8lCQ== + dependencies: + typewise-core "^1.2.0" + unbox-primitive@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.1.tgz#085e215625ec3162574dc8859abee78a59b14471" @@ -7340,6 +7478,16 @@ unicode-property-aliases-ecmascript@^2.0.0: resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz#43d41e3be698bd493ef911077c9b131f827e8ccd" integrity sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w== +union-value@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/union-value/-/union-value-1.0.1.tgz#0b6fe7b835aecda61c6ea4d4f02c14221e109847" + integrity sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg== + dependencies: + arr-union "^3.1.0" + get-value "^2.0.6" + is-extendable "^0.1.1" + set-value "^2.0.1" + unique-string@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-2.0.0.tgz#39c6451f81afb2749de2b233e3f7c5e8843bd89d" @@ -7385,11 +7533,6 @@ uri-js@^4.2.2: dependencies: punycode "^2.1.0" -util-deprecate@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" - integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== - v8-compile-cache@^2.0.3: version "2.3.0" resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" @@ -7412,14 +7555,14 @@ validate-npm-package-license@^3.0.1: spdx-correct "^3.0.0" spdx-expression-parse "^3.0.0" -vt-pbf@^3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/vt-pbf/-/vt-pbf-3.1.1.tgz#b0f627e39a10ce91d943b898ed2363d21899fb82" - integrity sha512-pHjWdrIoxurpmTcbfBWXaPwSmtPAHS105253P1qyEfSTV2HJddqjM+kIHquaT/L6lVJIk9ltTGc0IxR/G47hYA== +vt-pbf@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/vt-pbf/-/vt-pbf-3.1.3.tgz#68fd150756465e2edae1cc5c048e063916dcfaac" + integrity sha512-2LzDFzt0mZKZ9IpVF2r69G9bXaP2Q2sArJCmcCgvfTdCCZzSyz4aCLoQyUilu37Ll56tCblIZrXFIjNUpGIlmA== dependencies: "@mapbox/point-geometry" "0.1.0" "@mapbox/vector-tile" "^1.3.1" - pbf "^3.0.5" + pbf "^3.2.1" w3c-hr-time@^1.0.2: version "1.0.2" @@ -7532,6 +7675,13 @@ which-typed-array@^1.1.9: has-tostringtag "^1.0.0" is-typed-array "^1.1.10" +which@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a" + integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== + dependencies: + isexe "^2.0.0" + which@^2.0.1: version "2.0.2" resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" From 36d719c13d62d5608b42e8df9b59123c2c089f97 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Mon, 18 Sep 2023 19:54:01 +0200 Subject: [PATCH 17/35] general: README - add features, master is prod again --- README.md | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index dba211546..f9ceb9296 100644 --- a/README.md +++ b/README.md @@ -2,12 +2,8 @@ Lets create a universal OpenStreetMap app for broad public. It should be as easy to use as Google Maps, including clickable POIs and editing capabilites. See also [SotM 2021 talk](https://github.com/zbycz/osmapp-talk). -- **production**: https://osmapp.org - - examples: [Empire State Building](https://osmapp.org/way/34633854#17.00/40.7483/-73.9864), [Prague Castle](https://osmapp.org/relation/3312247#17.00/50.0900/14.4000) or click just anything -- **master branch**: https://osmapp-git-master-zbycz.vercel.app/ - - it is currently undergoing a [major refactoring to TailwindCSS](https://github.com/zbycz/osmapp/issues/165) thanks to [@Flohhhhh](https://github.com/Flohhhhh) - - until finished, some components would be MUI and some new design - - some functionality may be broken +- master branch: https://osmapp.org +- examples: [Empire State Building](https://osmapp.org/way/34633854#17.00/40.7483/-73.9864), [Prague Castle](https://osmapp.org/relation/3312247#17.00/50.0900/14.4000) or click just anything ## How to contribute 🐱‍💻 @@ -24,10 +20,11 @@ You may [add issues](https://github.com/zbycz/osmapp/issues) here on github, or ## Features 🗺 📱 🖥 - **clickable map** – poi, cities, localities, ponds (more coming soon) -- **info panel** – images from Wikipedia, Mapillary or Fody +- **info panel** – images from Wikipedia, Mapillary or Fody, line numbers on public transport stops - **editing** – for anonymous users inserts a note - **search engine** – try for example "Tesco, London" - **vector maps** – with the possibility of tilting to 3D (drag the compass, or two fingers drag) +- **3D terrain** - tilt to 3D and then click terrain icon to show 3D terrain - **tourist map** – from MapTiler: vector, including marked routes - **layer switcher** – still basic, but you can add your own layers - **mobile applications** – see [osmapp.org/install](https://osmapp.org/install) From 103eaf886ef597c816a63d9d2e1293caaa5996ac Mon Sep 17 00:00:00 2001 From: zbycz Date: Fri, 15 Sep 2023 10:50:22 +0200 Subject: [PATCH 18/35] global: disable overscroll on mobile MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 1. full app overscroll – to prevent pull down to refresh in chrome 2. Panel content overscroll – only x disabled, y left for natural experience --- src/components/utils/PanelHelpers.tsx | 7 +++++++ src/helpers/GlobalStyle.tsx | 3 +++ 2 files changed, 10 insertions(+) diff --git a/src/components/utils/PanelHelpers.tsx b/src/components/utils/PanelHelpers.tsx index 43ec6cf36..bcc9f5b12 100644 --- a/src/components/utils/PanelHelpers.tsx +++ b/src/components/utils/PanelHelpers.tsx @@ -22,6 +22,13 @@ export const PanelWrapper = styled.div` @media ${isDesktop} { width: 410px; } + + & > div > div { + // disable pulling panel around on mobile + // second div due to implementation of react-custom-scrollbars + overscroll-behavior: none; + overscroll-behavior-y: auto; + } `; export const PanelScrollbars = ({ children }) => ( diff --git a/src/helpers/GlobalStyle.tsx b/src/helpers/GlobalStyle.tsx index 1bebd5edb..359cfd282 100644 --- a/src/helpers/GlobalStyle.tsx +++ b/src/helpers/GlobalStyle.tsx @@ -9,6 +9,9 @@ export const GlobalStyle = createGlobalStyle` border: 0; font-family: 'Roboto', sans-serif; background-color: ${({ theme }) => theme.palette.appBackground}; + + // disable pulling the page around on mobile + overscroll-behavior: none; } body { From 1b6af16c05cba766f776e40158fae7ce7cbc3416 Mon Sep 17 00:00:00 2001 From: Dlurak <84224239+Dlurak@users.noreply.github.com> Date: Sun, 24 Sep 2023 18:39:26 +0200 Subject: [PATCH 19/35] FeaturePanel: public transport labels colors + new query (#187) --- .../PublicTransport/LineNumber.tsx | 48 ++++++++++++++++++- .../PublicTransport/PublicTransport.tsx | 3 +- .../PublicTransport/requestRoutes.ts | 10 ++-- 3 files changed, 51 insertions(+), 10 deletions(-) diff --git a/src/components/FeaturePanel/PublicTransport/LineNumber.tsx b/src/components/FeaturePanel/PublicTransport/LineNumber.tsx index 72ac43b8e..c57733adf 100644 --- a/src/components/FeaturePanel/PublicTransport/LineNumber.tsx +++ b/src/components/FeaturePanel/PublicTransport/LineNumber.tsx @@ -6,6 +6,52 @@ interface LineNumberProps { color: string; } +/** + * A function to map a color name to hex. When a color is not found, it is returned as is, the same goes for hex colors. + * @param color The color to map to hex + * @returns The color in hex format, e.g. #ff0000 + */ +function mapColorToHex(color: string) { + switch (color.toLowerCase()) { + case 'black': + return '#000000'; + case 'gray': + case 'grey': + return '#808080'; + case 'maroon': + return '#800000'; + case 'olive': + return '#808000'; + case 'green': + return '#008000'; + case 'teal': + return '#008080'; + case 'navy': + return '#000080'; + case 'purple': + return '#800080'; + case 'white': + return '#ffffff'; + case 'silver': + return '#c0c0c0'; + case 'red': + return '#ff0000'; + case 'yellow': + return '#ffff00'; + case 'lime': + return '#00ff00'; + case 'aqua': + case 'cyan': + return '#00ffff'; + case 'blue': + return '#0000ff'; + case 'fuchsia': + case 'magenta': + return '#ff00ff'; + default: + return color; + } +} /** * A function to determine whether the text color should be black or white * @param hexBgColor The background color in hex format, e.g. #ff0000 @@ -26,7 +72,7 @@ export const LineNumber: React.FC = ({ name, color }) => { let bgcolor: string; if (!color) bgcolor = darkmode ? '#898989' : '#dddddd'; // set the default color - else bgcolor = color.toLowerCase(); + else bgcolor = mapColorToHex(color); const divStyle: React.CSSProperties = { backgroundColor: bgcolor, diff --git a/src/components/FeaturePanel/PublicTransport/PublicTransport.tsx b/src/components/FeaturePanel/PublicTransport/PublicTransport.tsx index 12419b9d5..ec9f3fd1c 100644 --- a/src/components/FeaturePanel/PublicTransport/PublicTransport.tsx +++ b/src/components/FeaturePanel/PublicTransport/PublicTransport.tsx @@ -81,8 +81,7 @@ export const PublicTransport: React.FC = ({ tags }) => { const isPublicTransport = Object.keys(tags).includes('public_transport') || tags.railway === 'station' || - tags.railway === 'halt' || - tags.railway === 'subway_entrance'; + tags.railway === 'halt'; if (!isPublicTransport) { return null; diff --git a/src/components/FeaturePanel/PublicTransport/requestRoutes.ts b/src/components/FeaturePanel/PublicTransport/requestRoutes.ts index c7c8d667a..fb21ac6e0 100644 --- a/src/components/FeaturePanel/PublicTransport/requestRoutes.ts +++ b/src/components/FeaturePanel/PublicTransport/requestRoutes.ts @@ -8,16 +8,12 @@ export interface LineInformation { export async function requestLines( featureType: 'node' | 'way' | 'relation', id: number, - radius = 150, ) { // use the overpass api to request the lines in const overpassQuery = `[out:csv(ref, colour; false; ';')]; - ${featureType}(${id})->.center; - ( - node(around.center:${radius})["public_transport"="stop_position"]; - nw(around.center:${radius})["highway"="bus_stop"]; - nwr(around.center:${radius})["amenity"="ferry_terminal"]; - ) -> .stops; + ${featureType}(${id}); + rel(bn)["public_transport"="stop_area"]; +node(r: "stop") -> .stops; rel(bn.stops)["route"~"bus|train|tram|subway|light_rail|ferry|monorail"]; out;`; From d7651e99dfb24e6957c0d725b91047b968f8933f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Sat, 30 Sep 2023 18:30:26 +0200 Subject: [PATCH 20/35] SearchBox: add search by categories + overpass (#186) --- .gitpod.yml | 3 + package.json | 3 +- src/components/FeaturePanel/OsmError.tsx | 8 + .../Map/behaviour/useUpdateStyle.tsx | 4 +- src/components/Map/consts.ts | 8 + src/components/Map/helpers.ts | 7 +- src/components/Map/styles/basicStyle.ts | 2 + .../Map/styles/layers/overpassLayers.ts | 120 ++++++++++ src/components/Map/styles/layers/poiLayers.ts | 5 +- src/components/Map/styles/outdoorStyle.ts | 2 + src/components/Map/styles/rasterStyle.ts | 2 + .../SearchBox/AutocompleteInput.tsx | 45 +++- src/components/SearchBox/SearchBox.tsx | 133 ++++++++++- src/components/SearchBox/highlightText.tsx | 6 +- src/components/SearchBox/onSelectedFactory.ts | 20 +- .../SearchBox/renderOptionFactory.tsx | 125 ++++++++--- src/components/utils/Maki.tsx | 1 + src/components/utils/MapStateContext.tsx | 24 ++ src/locales/cs.js | 4 + src/locales/vocabulary.js | 4 + src/services/__tests__/overpassSearch.test.ts | 206 ++++++++++++++++++ src/services/fetch.ts | 31 ++- src/services/intl.tsx | 4 +- src/services/osmApi.ts | 11 +- src/services/overpassSearch.ts | 96 ++++++++ src/services/tagging/translations.ts | 5 +- src/services/types.ts | 2 +- yarn.lock | 12 +- 28 files changed, 818 insertions(+), 75 deletions(-) create mode 100644 .gitpod.yml create mode 100644 src/components/Map/styles/layers/overpassLayers.ts create mode 100644 src/services/__tests__/overpassSearch.test.ts create mode 100644 src/services/overpassSearch.ts diff --git a/.gitpod.yml b/.gitpod.yml new file mode 100644 index 000000000..a98171fc1 --- /dev/null +++ b/.gitpod.yml @@ -0,0 +1,3 @@ +tasks: + - init: yarn + command: yarn dev diff --git a/package.json b/package.json index 0071da758..884b8af24 100644 --- a/package.json +++ b/package.json @@ -6,6 +6,7 @@ }, "scripts": { "dev": "next", + "test": "jest", "lint": "eslint . --report-unused-disable-directives", "lintfix": "prettier . --write && eslint ./src ./pages --report-unused-disable-directives --fix", "prettify": "prettier . --write", @@ -34,7 +35,6 @@ "@openstreetmap/id-tagging-schema": "^6.1.0", "@sentry/browser": "^6.5.1", "@sentry/node": "^6.5.1", - "@types/maplibre-gl": "^1.13.1", "accept-language-parser": "^1.5.0", "autosuggest-highlight": "^3.1.1", "isomorphic-unfetch": "^3.1.0", @@ -57,6 +57,7 @@ "styled-jsx": "^3.4.4" }, "devDependencies": { + "@types/autosuggest-highlight": "^3.2.0", "@types/jest": "^26.0.23", "@typescript-eslint/eslint-plugin": "^4.26.0", "babel-eslint": "^10.1.0", diff --git a/src/components/FeaturePanel/OsmError.tsx b/src/components/FeaturePanel/OsmError.tsx index 85a63d1be..bd8ff8716 100644 --- a/src/components/FeaturePanel/OsmError.tsx +++ b/src/components/FeaturePanel/OsmError.tsx @@ -52,5 +52,13 @@ export const OsmError = () => { ); } + if (Object.keys(feature.tags).length === 0 && !feature.point) { + return ( + + {t('featurepanel.info_no_tags')} + + ); + } + return null; }; diff --git a/src/components/Map/behaviour/useUpdateStyle.tsx b/src/components/Map/behaviour/useUpdateStyle.tsx index b2cb60b0d..dbc6c3a9a 100644 --- a/src/components/Map/behaviour/useUpdateStyle.tsx +++ b/src/components/Map/behaviour/useUpdateStyle.tsx @@ -5,7 +5,7 @@ import { osmappLayers } from '../../LayerSwitcher/osmappLayers'; import { rasterStyle } from '../styles/rasterStyle'; import { DEFAULT_MAP } from '../../../config'; -export const getRasterLayer = (key) => { +export const getRasterStyle = (key) => { const url = osmappLayers[key]?.url ?? key; // if `key` not found, it contains tiles URL return rasterStyle(key, url); }; @@ -18,6 +18,6 @@ export const useUpdateStyle = useMapEffect((map, activeLayers) => { ? basicStyle : key === 'outdoor' ? outdoorStyle - : getRasterLayer(key), + : getRasterStyle(key), ); }); diff --git a/src/components/Map/consts.ts b/src/components/Map/consts.ts index 09871320d..d43126b20 100644 --- a/src/components/Map/consts.ts +++ b/src/components/Map/consts.ts @@ -1,4 +1,5 @@ // https://cloud.maptiler.com/account + const apiKey = '7dlhLl3hiXQ1gsth0kGu'; export const OSMAPP_SPRITE = `${window.location.protocol}//${window.location.host}/sprites/osmapp`; @@ -28,6 +29,13 @@ export const OSMAPP_SOURCES = { url: `https://api.maptiler.com/tiles/outdoor/tiles.json?key=${apiKey}`, type: 'vector' as const, }, + overpass: { + type: 'geojson' as const, + data: { + type: 'FeatureCollection', + features: [], + }, + }, }; export const BACKGROUND = [ diff --git a/src/components/Map/helpers.ts b/src/components/Map/helpers.ts index d63ccd8d6..672163024 100644 --- a/src/components/Map/helpers.ts +++ b/src/components/Map/helpers.ts @@ -5,7 +5,7 @@ const isOsmLayer = (id) => { if (id.startsWith('place-country-')) return false; // https://github.com/zbycz/osmapp/issues/35 if (id === 'place-continent') return false; if (id === 'water-name-ocean') return false; - const prefixes = ['water-name-', 'poi-', 'place-']; + const prefixes = ['water-name-', 'poi-', 'place-', 'overpass-']; return prefixes.some((prefix) => id.startsWith(prefix)); }; @@ -23,6 +23,11 @@ export const getIsOsmObject = ({ id, layer }) => { if (layer.id === 'water-name-other' && id < 10e5) { return false; } + + if (layer.id?.startsWith('overpass')) { + return true; + } + return layersWithOsmId.includes(layer.id); }; diff --git a/src/components/Map/styles/basicStyle.ts b/src/components/Map/styles/basicStyle.ts index e57fb32a6..7ad848bf3 100644 --- a/src/components/Map/styles/basicStyle.ts +++ b/src/components/Map/styles/basicStyle.ts @@ -9,6 +9,7 @@ import { poiLayers } from './layers/poiLayers'; import { addHoverPaint } from '../behaviour/featureHover'; import { BACKGROUND, GLYPHS, OSMAPP_SOURCES, OSMAPP_SPRITE } from '../consts'; import { motorwayConstruction } from './layers/contruction'; +import { overpassLayers } from './layers/overpassLayers'; export const basicStyle = addHoverPaint({ version: 8, @@ -2835,6 +2836,7 @@ export const basicStyle = addHoverPaint({ }, }, ...poiLayers, + ...overpassLayers, ], id: 'ciw6czz2n00242kmg6hw20box', }); diff --git a/src/components/Map/styles/layers/overpassLayers.ts b/src/components/Map/styles/layers/overpassLayers.ts new file mode 100644 index 000000000..b9ff5278f --- /dev/null +++ b/src/components/Map/styles/layers/overpassLayers.ts @@ -0,0 +1,120 @@ +import type { LayerSpecification } from '@maplibre/maplibre-gl-style-spec'; + +export const overpassLayers: LayerSpecification[] = [ + { + id: 'overpass-line-casing', + type: 'line', + source: 'overpass', + paint: { + 'line-color': '#f8f4f0', + 'line-width': 6, + }, + }, + { + id: 'overpass-line', + type: 'line', + source: 'overpass', + paint: { + 'line-color': '#f00', + 'line-width': 2, + 'line-opacity': [ + 'case', + ['boolean', ['feature-state', 'hover'], false], + 0.5, + 1, + ], + }, + }, + { + id: 'overpass-line-text', + type: 'symbol', + source: 'overpass', + layout: { + 'symbol-placement': 'line', + 'text-font': ['Noto Sans Regular'], + 'text-field': '{name}', + 'text-size': 12, + 'text-rotation-alignment': 'map', + }, + paint: { + 'text-color': '#000000', + 'text-halo-width': 1.5, + 'text-halo-color': 'rgba(255,255,255,0.7)', + 'text-opacity': [ + 'case', + ['boolean', ['feature-state', 'hover'], false], + 0.5, + 1, + ], + }, + }, + { + id: 'overpass-fill', + type: 'fill', + source: 'overpass', + filter: ['all', ['==', '$type', 'Polygon']], + paint: { + 'fill-color': '#f00', + 'fill-opacity': [ + 'case', + ['boolean', ['feature-state', 'hover'], false], + 0.2, + 0.5, + ], + }, + }, + { + id: 'overpass-circle', + type: 'circle', + source: 'overpass', + filter: ['all', ['==', '$type', 'Point']], + paint: { + 'circle-color': 'rgba(255,255,255,0.9)', + 'circle-radius': 12, + 'circle-stroke-width': 1, + 'circle-stroke-color': 'rgba(255,0,0,0.9)', + 'circle-opacity': [ + 'case', + ['boolean', ['feature-state', 'hover'], false], + 0.5, + 1, + ], + }, + }, + { + id: 'overpass-symbol', + type: 'symbol', + source: 'overpass', + filter: ['all', ['==', '$type', 'Point']], + layout: { + 'text-padding': 2, + 'text-font': ['Noto Sans Regular'], + 'text-anchor': 'top', + 'icon-image': '{class}_11', + 'text-field': '{name}', + 'text-offset': [0, 0.6], + 'text-size': 12, + 'text-max-width': 9, + 'icon-allow-overlap': true, + 'icon-ignore-placement': true, + }, + paint: { + // 'text-halo-blur': 0.5, + 'text-color': '#000', + 'text-halo-width': 1.5, + 'text-halo-color': 'rgba(255,255,255,0.7)', + 'icon-opacity': [ + 'case', + ['boolean', ['feature-state', 'hover'], false], + 0.5, + 1, + ], + 'text-opacity': [ + 'case', + ['boolean', ['feature-state', 'hover'], false], + 0.5, + 1, + ], + }, + }, +]; diff --git a/src/components/Map/styles/layers/poiLayers.ts b/src/components/Map/styles/layers/poiLayers.ts index 4e7af7f18..a97a9e472 100644 --- a/src/components/Map/styles/layers/poiLayers.ts +++ b/src/components/Map/styles/layers/poiLayers.ts @@ -1,6 +1,7 @@ -// originaly from basicStyle +import type { LayerSpecification } from '@maplibre/maplibre-gl-style-spec'; -export const poiLayers = [ +// originaly from basicStyle +export const poiLayers: LayerSpecification[] = [ { id: 'poi-level-3', type: 'symbol', diff --git a/src/components/Map/styles/outdoorStyle.ts b/src/components/Map/styles/outdoorStyle.ts index f9ce465ab..f683d3dd9 100644 --- a/src/components/Map/styles/outdoorStyle.ts +++ b/src/components/Map/styles/outdoorStyle.ts @@ -6,6 +6,7 @@ import { poiLayers } from './layers/poiLayers'; import { addHoverPaint } from '../behaviour/featureHover'; import { BACKGROUND, GLYPHS, OSMAPP_SOURCES, OSMAPP_SPRITE } from '../consts'; import { motorwayConstruction } from './layers/contruction'; +import { overpassLayers } from './layers/overpassLayers'; // TODO add icons for outdoor to our sprite (guideposts, benches, etc) // https://api.maptiler.com/maps/outdoor/sprite.png?key=7dlhLl3hiXQ1gsth0kGu @@ -3884,6 +3885,7 @@ export const outdoorStyle = addHoverPaint({ 'source-layer': 'place', }, ...poiLayers, + ...overpassLayers, ], bearing: 0, sources: OSMAPP_SOURCES, diff --git a/src/components/Map/styles/rasterStyle.ts b/src/components/Map/styles/rasterStyle.ts index 5f8ac514d..06f94591f 100644 --- a/src/components/Map/styles/rasterStyle.ts +++ b/src/components/Map/styles/rasterStyle.ts @@ -1,5 +1,6 @@ import type { StyleSpecification } from '@maplibre/maplibre-gl-style-spec'; import { GLYPHS, OSMAPP_SOURCES, OSMAPP_SPRITE } from '../consts'; +import { overpassLayers } from './layers/overpassLayers'; const getSource = (url) => { if (url.match('{bingSubdomains}')) { @@ -38,6 +39,7 @@ export const rasterStyle = (id, url): StyleSpecification => { minzoom: 0, }, // ...poiLayers, // TODO maybe add POIs + ...overpassLayers, ], sources: { ...OSMAPP_SOURCES, // keep default sources for faster switching diff --git a/src/components/SearchBox/AutocompleteInput.tsx b/src/components/SearchBox/AutocompleteInput.tsx index 6d23948e0..797f66d28 100644 --- a/src/components/SearchBox/AutocompleteInput.tsx +++ b/src/components/SearchBox/AutocompleteInput.tsx @@ -7,8 +7,30 @@ import { t } from '../../services/intl'; import { onHighlightFactory, onSelectedFactory } from './onSelectedFactory'; import { useMobileMode } from '../helpers'; import { useUserThemeContext } from '../../helpers/theme'; +import { useMapStateContext } from '../utils/MapStateContext'; + +const useFocusOnSlash = () => { + const inputRef = React.useRef(null); + + useEffect(() => { + const onKeydown = (e) => { + if (e.key === '/') { + e.preventDefault(); + inputRef.current?.focus(); + } + }; + window.addEventListener('keydown', onKeydown); + + return () => { + window.removeEventListener('keydown', onKeydown); + }; + }, []); + + return inputRef; +}; const SearchBoxInput = ({ params, setInputValue, autocompleteRef }) => { + const inputRef = useFocusOnSlash(); const { InputLabelProps, InputProps, ...restParams } = params; useEffect(() => { @@ -21,8 +43,9 @@ const SearchBoxInput = ({ params, setInputValue, autocompleteRef }) => { return ( @@ -36,18 +59,34 @@ export const AutocompleteInput = ({ autocompleteRef, }) => { const { setFeature, setPreview } = useFeatureContext(); + const { bbox, showToast } = useMapStateContext(); const mobileMode = useMobileMode(); const { currentTheme } = useUserThemeContext(); return ( x} getOptionLabel={(option) => - option.properties.name || buildPhotonAddress(option.properties) + option.properties?.name || + option.preset?.presetForSearch?.name || + (option.overpass && + Object.entries(option.overpass) + ?.map(([k, v]) => `${k}=${v}`) + .join(' ')) || + (option.loader ? '' : buildPhotonAddress(option.properties)) } - onChange={onSelectedFactory(setFeature, setPreview, mobileMode)} + onChange={onSelectedFactory( + setFeature, + setPreview, + mobileMode, + bbox, + showToast, + )} onHighlightChange={onHighlightFactory(setPreview)} + getOptionDisabled={(o) => o.loader} autoComplete disableClearable autoHighlight diff --git a/src/components/SearchBox/SearchBox.tsx b/src/components/SearchBox/SearchBox.tsx index b334f8ed7..f2a1d9a81 100644 --- a/src/components/SearchBox/SearchBox.tsx +++ b/src/components/SearchBox/SearchBox.tsx @@ -1,17 +1,25 @@ import React, { useRef, useState } from 'react'; import styled from 'styled-components'; -import throttle from 'lodash/throttle'; +import debounce from 'lodash/debounce'; import SearchIcon from '@material-ui/icons/Search'; import Paper from '@material-ui/core/Paper'; import IconButton from '@material-ui/core/IconButton'; import Router from 'next/router'; +import match from 'autosuggest-highlight/match'; + import { fetchJson } from '../../services/fetch'; import { useMapStateContext } from '../utils/MapStateContext'; import { useFeatureContext } from '../utils/FeatureContext'; import { AutocompleteInput } from './AutocompleteInput'; -import { t } from '../../services/intl'; +import { intl, t } from '../../services/intl'; import { ClosePanelButton } from '../utils/ClosePanelButton'; import { isDesktop, useMobileMode } from '../helpers'; +import { presets } from '../../services/tagging/data'; +import { + fetchSchemaTranslations, + getPresetTermsTranslation, + getPresetTranslation, +} from '../../services/tagging/translations'; const TopPanel = styled.div` position: absolute; @@ -47,18 +55,112 @@ const SearchIconButton = styled(IconButton)` } `; +const PHOTON_SUPPORTED_LANGS = ['en', 'de', 'fr']; + const getApiUrl = (inputValue, view) => { const [zoom, lat, lon] = view; const lvl = Math.max(0, Math.min(16, Math.round(zoom))); const q = encodeURIComponent(inputValue); - return `https://photon.komoot.io/api/?q=${q}&lon=${lon}&lat=${lat}&zoom=${lvl}`; + const lang = intl.lang in PHOTON_SUPPORTED_LANGS ? intl.lang : 'default'; + return `https://photon.komoot.io/api/?q=${q}&lon=${lon}&lat=${lat}&zoom=${lvl}&lang=${lang}`; +}; + +// https://docs.mapbox.com/help/troubleshooting/working-with-large-geojson-data/ + +let presetsForSearch = []; + +fetchSchemaTranslations().then(() => { + // resolve symlinks to {landuse...} etc + presetsForSearch = Object.values(presets) + .filter(({ searchable }) => searchable === undefined || searchable) + .filter(({ locationSet }) => !locationSet?.include) + .map(({ name, presetKey, tags, terms }) => { + const tagsAsStrings = Object.entries(tags).map(([k, v]) => `${k}=${v}`); + return { + key: presetKey, + name: getPresetTranslation(presetKey) ?? name ?? 'x', + tags, + tagsAsOneString: tagsAsStrings.join(', '), + texts: [ + ...(getPresetTermsTranslation(presetKey) ?? terms ?? 'x').split(','), + ...tagsAsStrings, + presetKey, + ], + }; + }); +}); + +const num = (text, inputValue) => + match(text, inputValue, { + insideWords: true, + findAllOccurrences: true, + }).length; +// return text.toLowerCase().includes(inputValue.toLowerCase()); + +const findInPresets = (inputValue) => { + // const start = performance.now(); + + const results = presetsForSearch.map((preset) => { + const name = num(preset.name, inputValue) * 10; + const textsByOne = preset.texts.map((term) => num(term, inputValue)); + const sum = name + textsByOne.reduce((a, b) => a + b, 0); + return { name, textsByOne, sum, presetForSearch: preset }; // TODO refactor this, not needed anymore + }); + + const nameMatches = results + .filter((result) => result.name > 0) + .map((result) => ({ preset: result })); + + const rest = results + .filter((result) => result.name === 0 && result.sum > 0) + .map((result) => ({ preset: result })); + + // // experiment with sorting by number of matches + // const options = results + // .filter((result) => result.sum > 0) + // .sort((a, b) => { + // // by number of matches + // if (a.sum > b.sum) return -1; + // if (a.sum < b.sum) return 1; + // return 0; + // }) + // .map((result) => ({ preset: result })); + // console.log('results time', performance.now() - start, options); + + return nameMatches.length + ? { nameMatches, rest } + : { nameMatches: rest, rest: [] }; }; -const fetchOptions = throttle(async (inputValue, view, setOptions) => { - const searchResponse = await fetchJson(getApiUrl(inputValue, view)); - const options = searchResponse.features; - setOptions(options || []); -}, 400); +const getOverpassQuery = (inputValue: string) => { + if (inputValue.match(/^[-:_a-zA-Z]+=/)) { + const [key, value] = inputValue.split('=', 2); + + return [{ overpass: { [key]: value || '*' } }]; + } + + return []; +}; + +const fetchOptions = debounce( + async (inputValue, view, setOptions, nameMatches = [], rest = []) => { + try { + const searchResponse = await fetchJson(getApiUrl(inputValue, view), { + abortableQueueName: 'search', + }); + const options = searchResponse.features; + + const before = nameMatches.slice(0, 2); + const after = [...nameMatches.slice(2), ...rest]; + + setOptions([...before, ...(options || []), ...after]); + } catch (e) { + // eslint-disable-next-line no-console + console.log('search aborted', e); + } + }, + 400, +); const SearchBox = () => { const { featureShown, feature, setFeature, setPreview } = useFeatureContext(); @@ -73,7 +175,20 @@ const SearchBox = () => { setOptions([]); return; } - fetchOptions(inputValue, view, setOptions); + if (inputValue.length > 2) { + const overpassQuery = getOverpassQuery(inputValue); + const { nameMatches, rest } = findInPresets(inputValue); + setOptions([ + ...overpassQuery, + ...nameMatches.slice(0, 2), + { loader: true }, + ]); + const before = [...overpassQuery, ...nameMatches]; + fetchOptions(inputValue, view, setOptions, before, rest); + } else { + setOptions([{ loader: true }]); + fetchOptions(inputValue, view, setOptions); + } }, [inputValue]); const closePanel = () => { diff --git a/src/components/SearchBox/highlightText.tsx b/src/components/SearchBox/highlightText.tsx index d40f2270d..aa4f6a89e 100644 --- a/src/components/SearchBox/highlightText.tsx +++ b/src/components/SearchBox/highlightText.tsx @@ -3,7 +3,11 @@ import match from 'autosuggest-highlight/match'; import parse from 'autosuggest-highlight/parse'; export const highlightText = (resultText, inputValue) => { - const parts = parse(resultText, match(resultText, inputValue)); + const matches = match(resultText, inputValue, { + insideWords: true, + findAllOccurrences: true, + }); + const parts = parse(resultText, matches); const map = parts.map((part, index) => ( // eslint-disable-next-line react/no-array-index-key diff --git a/src/components/SearchBox/onSelectedFactory.ts b/src/components/SearchBox/onSelectedFactory.ts index 312cd94aa..5df9372ac 100644 --- a/src/components/SearchBox/onSelectedFactory.ts +++ b/src/components/SearchBox/onSelectedFactory.ts @@ -3,6 +3,8 @@ import maplibregl from 'maplibre-gl'; import { getShortId, getUrlOsmId } from '../../services/helpers'; import { addFeatureCenterToCache } from '../../services/osmApi'; import { getGlobalMap } from '../../services/mapStorage'; +import { performOverpassSearch } from '../../services/overpassSearch'; +import { t } from '../../services/intl'; const getElementType = (osmType) => { switch (osmType) { @@ -54,7 +56,23 @@ const fitBounds = (option, panelShown = false) => { }; export const onSelectedFactory = - (setFeature, setPreview, mobileMode) => (e, option) => { + (setFeature, setPreview, mobileMode, bbox, showToast) => (_, option) => { + if (option.overpass || option.preset) { + const tags = option.overpass || option.preset.presetForSearch.tags; + performOverpassSearch(bbox, tags) + .then((geojson) => { + const count = geojson.features.length; + const content = t('searchbox.overpass_success', { count }); + showToast({ content }); + getGlobalMap().getSource('overpass')?.setData(geojson); + }) + .catch((e) => { + const message = `${e}`.substring(0, 100); + const content = t('searchbox.overpass_error', { message }); + showToast({ content, type: 'error' }); + }); + return; + } if (!option?.geometry.coordinates) return; const skeleton = getSkeleton(option); diff --git a/src/components/SearchBox/renderOptionFactory.tsx b/src/components/SearchBox/renderOptionFactory.tsx index a5d423b40..a6fe9f76c 100644 --- a/src/components/SearchBox/renderOptionFactory.tsx +++ b/src/components/SearchBox/renderOptionFactory.tsx @@ -2,11 +2,14 @@ import Grid from '@material-ui/core/Grid'; import Typography from '@material-ui/core/Typography'; import React from 'react'; import styled from 'styled-components'; +import FolderIcon from '@material-ui/icons/Folder'; +import SearchIcon from '@material-ui/icons/Search'; import { useMapStateContext } from '../utils/MapStateContext'; import Maki from '../utils/Maki'; import { highlightText } from './highlightText'; import { join } from '../../utils'; import { getPoiClass } from '../../services/getPoiClass'; +import { t } from '../../services/intl'; /** photon { @@ -115,36 +118,98 @@ export const buildPhotonAddress = ({ streetnumber: snum, }) => join(street ?? place ?? city, ' ', hnum ? hnum.replace(' ', '/') : snum); -export const renderOptionFactory = (inputValue, currentTheme) => (option) => { - const { properties, geometry } = option; - const { name, osm_key: tagKey, osm_value: tagValue } = properties; +export const renderOptionFactory = + (inputValue, currentTheme) => + ({ geometry, preset, properties, overpass, loader }) => { + if (overpass) { + return ( + <> + + + + + + {Object.entries(overpass) + .map(([k, v]) => `${k} = ${v}`) + .join(' ')} + + + overpass search + {/* {t('searchbox.category')} */} + + + + ); + } - const [lon, lat] = geometry.coordinates; - const mapCenter = useMapCenter(); - const dist = getDistance(mapCenter, { lon, lat }) / 1000; - const distKm = dist < 10 ? Math.round(dist * 10) / 10 : Math.round(dist); // TODO save imperial to mapState and multiply 0.621371192 + if (loader) { + return ( + <> + + + + {t('loading')} + . + . + . + + + + ); + } - const text = name || buildPhotonAddress(properties); - const additionalText = getAdditionalText(properties); - const poiClass = getPoiClass({ [tagKey]: tagValue }); + if (preset) { + const { name } = preset.presetForSearch; + const additionalText = + preset.name === 0 + ? ` (${preset.presetForSearch.texts.find( + (_, idx) => preset.textsByOne[idx] > 0, + )}…)` + : ''; - return ( - <> - - -
{distKm} km
-
- - {highlightText(text, inputValue)} - - {additionalText} - - - - ); -}; + return ( + <> + + + + + {highlightText(`${name}${additionalText}`, inputValue)} + + {t('searchbox.category')} + + + + ); + } + + const { name, osm_key: tagKey, osm_value: tagValue } = properties; + + const [lon, lat] = geometry.coordinates; + const mapCenter = useMapCenter(); + const dist = getDistance(mapCenter, { lon, lat }) / 1000; + const distKm = dist < 10 ? Math.round(dist * 10) / 10 : Math.round(dist); // TODO save imperial to mapState and multiply 0.621371192 + + const text = name || buildPhotonAddress(properties); + const additionalText = getAdditionalText(properties); + const poiClass = getPoiClass({ [tagKey]: tagValue }); + + return ( + <> + + +
{distKm} km
+
+ + {highlightText(text, inputValue)} + + {additionalText} + + + + ); + }; diff --git a/src/components/utils/Maki.tsx b/src/components/utils/Maki.tsx index 06b5721e2..eb26a03d7 100644 --- a/src/components/utils/Maki.tsx +++ b/src/components/utils/Maki.tsx @@ -16,6 +16,7 @@ const Maki = ({ middle = undefined, }) => { const icon = icons.includes(ico) ? ico : 'information'; + // console.log(icon, ' was: ',ico) return ( { setViewForMap(newView); }, []); + const [open, setOpen] = React.useState(false); + const [msg, setMsg] = React.useState(undefined); + + const handleClose = (event?: React.SyntheticEvent, reason?: string) => { + if (reason === 'clickaway') { + return; + } + + setOpen(false); + }; + + const showToast = (message) => { + setMsg(message); + setOpen(true); + }; + const mapState = { bbox, setBbox, @@ -52,11 +70,17 @@ export const MapStateProvider = ({ children, initialMapView }) => { setViewFromMap: setView, activeLayers, setActiveLayers, + showToast, }; return ( {children} + + + {msg?.content} + + ); }; diff --git a/src/locales/cs.js b/src/locales/cs.js index 97adebcda..0e1727d8d 100644 --- a/src/locales/cs.js +++ b/src/locales/cs.js @@ -43,6 +43,9 @@ export default { 'homepage.maptiler': 'MapTiler – za skvělé vektorové mapy
a za podporu tohoto projektu ❤️ ', 'searchbox.placeholder': 'Prohledat OpenStreetMap', + 'searchbox.category': 'kategorie', + 'searchbox.overpass_success': 'Nalezeno výsledků: __count__', + 'searchbox.overpass_error': 'Chyba při načítání výsledků. __message__', 'featurepanel.no_name': 'beze jména', 'featurepanel.share_button': 'Sdílet', @@ -52,6 +55,7 @@ export default { 'featurepanel.error_unknown': 'Při stahování prvku z OpenStreetMap se stala neznámá chyba.', 'featurepanel.error_network': 'Nelze stáhnout prvek, zkontrolujte připojení k internetu.', 'featurepanel.error_deleted': 'Tento prvek je v OpenStreetMap označen jako smazaný.', + 'featurepanel.info_no_tags': 'Tento prvek nemá žádné vlastnosti (tagy). Obvykle to znamená, že nese pouze geometrii/polohu pro nadřazený objekt.', 'featurepanel.history_button': 'Historie »', 'featurepanel.other_info_heading': 'Další informace', 'featurepanel.edit_button_title': 'Upravit v databázi OpenStreetMap', diff --git a/src/locales/vocabulary.js b/src/locales/vocabulary.js index 727e0a867..0bd407435 100644 --- a/src/locales/vocabulary.js +++ b/src/locales/vocabulary.js @@ -50,6 +50,9 @@ export default { 'homepage.maptiler': 'MapTiler – for awesome vector maps
and for supporting this project ❤️ ', 'searchbox.placeholder': 'Search OpenStreetMap', + 'searchbox.category': 'category', + 'searchbox.overpass_success': 'Results found: __count__', + 'searchbox.overpass_error': 'Error fetching results. __message__', 'featurepanel.no_name': 'No name', 'featurepanel.share_button': 'Share', @@ -59,6 +62,7 @@ export default { 'featurepanel.error_unknown': 'Unknown error while fetching feature from OpenStreetMap.', 'featurepanel.error_network': "Can't get the feature, check your network cable.", 'featurepanel.error_deleted': 'This object is marked as deleted in OpenStreetMap.', + 'featurepanel.info_no_tags': 'This object has no tags. Usually it means that it only carries geometry/location for a parent object.', 'featurepanel.history_button': 'History »', 'featurepanel.other_info_heading': 'Details', 'featurepanel.edit_button_title': 'Edit in OpenStreetMap database', diff --git a/src/services/__tests__/overpassSearch.test.ts b/src/services/__tests__/overpassSearch.test.ts new file mode 100644 index 000000000..e95e9fcfb --- /dev/null +++ b/src/services/__tests__/overpassSearch.test.ts @@ -0,0 +1,206 @@ +import { osmJsonToSkeletons } from '../overpassSearch'; + +/* +[out:json][timeout:25]; + ( + node["type"="route"]["route"="bus"](49.93841,14.28715,49.97035,14.34812); + way["type"="route"]["route"="bus"](49.93841,14.28715,49.97035,14.34812); + relation["type"="route"]["route"="bus"](49.93841,14.28715,49.97035,14.34812); + ); + out body geom; +*/ + +const response = { + version: 0.6, + generator: 'Overpass API 0.7.61.5 4133829e', + osm3s: { + timestamp_osm_base: '2023-09-28T10:25:11Z', + copyright: + 'The data included in this document is from www.openstreetmap.org. The data is made available under ODbL.', + }, + elements: [ + { + type: 'relation', + id: 8337908, + bounds: { + minlat: 49.9510996, + minlon: 14.3394962, + maxlat: 49.9602015, + maxlon: 14.3530042, + }, + members: [ + { + type: 'node', + ref: 4303193142, + role: 'platform', + lat: 49.9511921, + lon: 14.3409309, + }, + { + type: 'node', + ref: 4303193147, + role: 'platform', + lat: 49.9560895, + lon: 14.3420546, + }, + { + type: 'node', + ref: 5650107055, + role: 'platform', + lat: 49.95976, + lon: 14.35261, + }, + { + type: 'way', + ref: 143079042, + role: '', + geometry: [ + { lat: 49.9510996, lon: 14.3406283 }, + { lat: 49.9512392, lon: 14.340966 }, + { lat: 49.9512882, lon: 14.3409961 }, + ], + }, + { + type: 'way', + ref: 431070311, + role: '', + geometry: [ + { lat: 49.9512882, lon: 14.3409961 }, + { lat: 49.9513048, lon: 14.3408764 }, + { lat: 49.9512958, lon: 14.3406756 }, + { lat: 49.9512723, lon: 14.3405453 }, + ], + }, + { + type: 'way', + ref: 143079039, + role: '', + geometry: [ + { lat: 49.9512723, lon: 14.3405453 }, + { lat: 49.9512769, lon: 14.3403348 }, + { lat: 49.9512638, lon: 14.3402265 }, + { lat: 49.9512376, lon: 14.3399046 }, + { lat: 49.9512538, lon: 14.3397224 }, + { lat: 49.9513307, lon: 14.3396011 }, + { lat: 49.9514674, lon: 14.339525 }, + { lat: 49.9516502, lon: 14.3394962 }, + { lat: 49.9519514, lon: 14.3395323 }, + { lat: 49.9524812, lon: 14.3397353 }, + { lat: 49.9528361, lon: 14.3398737 }, + { lat: 49.9529293, lon: 14.3399175 }, + { lat: 49.9533275, lon: 14.3401047 }, + { lat: 49.9536045, lon: 14.3402959 }, + { lat: 49.9543101, lon: 14.340794 }, + { lat: 49.9555376, lon: 14.3415765 }, + { lat: 49.9564591, lon: 14.3422582 }, + { lat: 49.9569866, lon: 14.3425944 }, + { lat: 49.9574162, lon: 14.3429583 }, + { lat: 49.9576284, lon: 14.3431366 }, + { lat: 49.9578467, lon: 14.3434496 }, + { lat: 49.9582484, lon: 14.3441399 }, + { lat: 49.9588316, lon: 14.3454072 }, + { lat: 49.9589787, lon: 14.3459137 }, + { lat: 49.9590815, lon: 14.3465416 }, + ], + }, + { + type: 'way', + ref: 538959927, + role: '', + geometry: [ + { lat: 49.9590815, lon: 14.3465416 }, + { lat: 49.9596598, lon: 14.3496964 }, + { lat: 49.9598834, lon: 14.3509159 }, + { lat: 49.959959, lon: 14.3513285 }, + { lat: 49.9600528, lon: 14.3518402 }, + { lat: 49.9600898, lon: 14.3520419 }, + { lat: 49.9602015, lon: 14.3522125 }, + ], + }, + { + type: 'way', + ref: 311389592, + role: '', + geometry: [ + { lat: 49.9598062, lon: 14.3530042 }, + { lat: 49.9598857, lon: 14.3529381 }, + { lat: 49.9599703, lon: 14.3528484 }, + { lat: 49.9600301, lon: 14.3527557 }, + { lat: 49.9600872, lon: 14.3526668 }, + { lat: 49.9601506, lon: 14.3525137 }, + { lat: 49.9602015, lon: 14.3522125 }, + ], + }, + { + type: 'way', + ref: 166349501, + role: '', + geometry: [ + { lat: 49.9598062, lon: 14.3530042 }, + { lat: 49.9597388, lon: 14.3526991 }, + { lat: 49.9596846, lon: 14.3526796 }, + { lat: 49.9595677, lon: 14.3527257 }, + ], + }, + ], + tags: { + from: 'Kazín', + name: '243: Kazín ⇒ Lipence', + network: 'PID', + operator: 'cz:DPP', + 'public_transport:version': '2', + ref: '243', + route: 'bus', + source: 'survey', + to: 'Lipence', + type: 'route', + website: 'https://pid.cz/linka/243', + }, + }, + ], +}; + +const skeletons = [ + { + geometry: { + type: 'LineString', + }, + osmMeta: { + id: 8337908, + type: 'relation', + }, + properties: { + class: 'bus', + from: 'Kazín', + name: '243: Kazín ⇒ Lipence', + network: 'PID', + operator: 'cz:DPP', + 'public_transport:version': '2', + ref: '243', + route: 'bus', + source: 'survey', + subclass: 'bus', + to: 'Lipence', + type: 'route', + website: 'https://pid.cz/linka/243', + }, + tags: { + from: 'Kazín', + name: '243: Kazín ⇒ Lipence', + network: 'PID', + operator: 'cz:DPP', + 'public_transport:version': '2', + ref: '243', + route: 'bus', + source: 'survey', + to: 'Lipence', + type: 'route', + website: 'https://pid.cz/linka/243', + }, + type: 'Feature', + }, +]; + +test('conversion', () => { + expect(osmJsonToSkeletons(response)).toEqual(skeletons); +}); diff --git a/src/services/fetch.ts b/src/services/fetch.ts index 9980e0609..62a95b593 100644 --- a/src/services/fetch.ts +++ b/src/services/fetch.ts @@ -18,14 +18,10 @@ export class FetchError extends Error { } // TODO cancel request in map.on('click', ...) -const noRequestRunning = { - abort: () => {}, - signal: null, -}; -let abortController = noRequestRunning; +const abortableQueues: Record = {}; interface FetchOpts extends RequestInit { - putInAbortableQueue?: boolean; + abortableQueueName?: string; nocache?: boolean; } @@ -34,18 +30,21 @@ export const fetchText = async (url, opts: FetchOpts = {}) => { const item = getCache(key); if (item) return item; - if (isBrowser() && opts?.putInAbortableQueue) { - abortController.abort(); - abortController = new AbortController(); + const name = isBrowser() ? opts?.abortableQueueName : undefined; + if (name) { + abortableQueues[name]?.abort(); + abortableQueues[name] = new AbortController(); } try { const res = await fetch(url, { ...opts, - signal: abortController.signal, + signal: abortableQueues[name]?.signal, }); - abortController = noRequestRunning; + if (name) { + delete abortableQueues[name]; + } if (!res.ok || res.status < 200 || res.status >= 300) { const data = await res.text(); @@ -62,15 +61,23 @@ export const fetchText = async (url, opts: FetchOpts = {}) => { } return text; } catch (e) { + if (e instanceof DOMException && e.name === 'AbortError') { + throw e; + } + throw new FetchError(`${e.message} at ${url}`, e.code || 'network', e.data); // TODO how to tell network error from code exception? } }; -export const fetchJson = async (url, opts = {}) => { +export const fetchJson = async (url, opts: FetchOpts = {}) => { const text = await fetchText(url, opts); try { return JSON.parse(text); } catch (e) { + if (e instanceof DOMException && e.name === 'AbortError') { + throw e; + } + throw new Error(`fetchJson: ${e.message}, in "${text?.substr(0, 30)}..."`); } }; diff --git a/src/services/intl.tsx b/src/services/intl.tsx index 9e417086e..73512c35d 100644 --- a/src/services/intl.tsx +++ b/src/services/intl.tsx @@ -6,7 +6,7 @@ import { isBrowser, isServer } from '../components/helpers'; import { getServerIntl } from './intlServer'; import { publishDbgObject } from '../utils'; -type Values = { [variable: string]: string }; +type Values = { [variable: string]: string | number }; interface Intl { lang: string; @@ -23,7 +23,7 @@ const VARIABLE_REGEX = /__(?[a-zA-Z_]+)__/g; const replaceValues = (text: string, values: Values) => text.replace(VARIABLE_REGEX, (match, variableName) => { const value = values && values[variableName]; - return value != null ? value : '?'; + return value != null ? `${value}` : '?'; }); export const t = (id: TranslationId, values?: Values) => { diff --git a/src/services/osmApi.ts b/src/services/osmApi.ts index 442a4ce26..3c39aaed6 100644 --- a/src/services/osmApi.ts +++ b/src/services/osmApi.ts @@ -76,8 +76,15 @@ export const clearFeatureCache = (apiId) => { }; const osmToFeature = (element): Feature => { - const { tags, lat, lon, nodes, members, osmappDeletedMarker, ...osmMeta } = - element; + const { + tags = {}, + lat, + lon, + nodes, + members, + osmappDeletedMarker, + ...osmMeta + } = element; return { type: 'Feature' as const, geometry: undefined, diff --git a/src/services/overpassSearch.ts b/src/services/overpassSearch.ts new file mode 100644 index 000000000..17c58eec6 --- /dev/null +++ b/src/services/overpassSearch.ts @@ -0,0 +1,96 @@ +import { Feature, LineString, Point } from './types'; +import { getPoiClass } from './getPoiClass'; +import { getCenter } from './getCenter'; +import { OsmApiId } from './helpers'; +import { fetchJson } from './fetch'; + +const overpassQuery = (bbox, tags) => { + const query = tags + .map(([k, v]) => (v === '*' ? `["${k}"]` : `["${k}"="${v}"]`)) + .join(''); + + return `[out:json][timeout:25]; + ( + node${query}(${bbox}); + way${query}(${bbox}); + relation${query}(${bbox}); + ); + out body; + >; + out skel qt;`; + // consider: out body geom +}; + +const getOverpassUrl = ([a, b, c, d], tags) => + `https://overpass-api.de/api/interpreter?data=${encodeURIComponent( + overpassQuery([d, a, b, c], tags), + )}`; + +const notNull = (x) => x != null; + +// maybe take inspiration from https://github.com/tyrasd/osmtogeojson/blob/gh-pages/index.js +export const osmJsonToSkeletons = (response: any): Feature[] => { + const nodesById = response.elements + .filter((element) => element.type === 'node') + .reduce((acc, node) => { + acc[node.id] = node; + return acc; + }, {}); + + const getGeometry2 = { + node: ({ lat, lon }): Point => ({ type: 'Point', coordinates: [lon, lat] }), + way: (way): LineString => { + const { nodes } = way; + return { + type: 'LineString', // TODO distinguish area - match id-presets, then add icon for polygons + coordinates: nodes + ?.map((nodeId) => nodesById[nodeId]) + .map(({ lat, lon }) => [lon, lat]), + }; + }, + relation: ({ members }): LineString => ({ + type: 'LineString', + coordinates: members[0]?.geometry // TODO make proper relation handling + ?.filter(notNull) + ?.map(({ lat, lon }) => [lon, lat]), + }), + }; + + return response.elements.map((element) => { + const { type, id, tags = {} } = element; + const geometry = getGeometry2[type]?.(element); + return { + type: 'Feature', + osmMeta: { type, id }, + tags, + properties: { ...getPoiClass(tags), ...tags }, + geometry, + center: getCenter(geometry) ?? undefined, + }; + }); +}; + +const convertOsmIdToMapId = (apiId: OsmApiId) => { + const osmToMapType = { node: 0, way: 1, relation: 4 }; + return parseInt(`${apiId.id}${osmToMapType[apiId.type]}`, 10); +}; + +export async function performOverpassSearch( + bbox, + tags: Record, +) { + console.log('seaching overpass for tags: ', tags); // eslint-disable-line no-console + const overpass = await fetchJson(getOverpassUrl(bbox, Object.entries(tags))); + console.log('overpass result:', overpass); // eslint-disable-line no-console + + const features = osmJsonToSkeletons(overpass) + .filter((feature) => feature.center && Object.keys(feature.tags).length > 0) + .map((feature) => ({ + ...feature, + id: convertOsmIdToMapId(feature.osmMeta), + })); + + console.log('overpass geojson', features); // eslint-disable-line no-console + + return { type: 'FeatureCollection', features }; +} diff --git a/src/services/tagging/translations.ts b/src/services/tagging/translations.ts index 16800b41e..7cce21eb6 100644 --- a/src/services/tagging/translations.ts +++ b/src/services/tagging/translations.ts @@ -26,7 +26,10 @@ export const mockSchemaTranslations = (mockTranslations) => { }; export const getPresetTranslation = (key: string) => - translations ? translations[intl.lang].presets.presets[key].name : undefined; + translations?.[intl.lang]?.presets?.presets?.[key]?.name; + +export const getPresetTermsTranslation = (key: string) => + translations?.[intl.lang]?.presets?.presets?.[key]?.terms; export const getFieldTranslation = (field: Field) => { if (!translations) return undefined; diff --git a/src/services/types.ts b/src/services/types.ts index e4810b703..294218366 100644 --- a/src/services/types.ts +++ b/src/services/types.ts @@ -50,7 +50,7 @@ interface RelationMember { // TODO split in two types /extend/ export interface Feature { - point?: boolean; + point?: boolean; // TODO rename to isMarker or isCoords type: 'Feature'; geometry?: FeatureGeometry; osmMeta: { diff --git a/yarn.lock b/yarn.lock index e12636902..6675bc961 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1941,6 +1941,11 @@ resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82" integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== +"@types/autosuggest-highlight@^3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@types/autosuggest-highlight/-/autosuggest-highlight-3.2.0.tgz#716a1408b8d987a6b636cf30048cba101d9f1cae" + integrity sha512-bTcsL4YYypjhKfPaImxuoMPiTyiUp7VGKytMr15/413IoazrOIfV/gca2ysI/IW0ftZYCPI5xppRm6IVX1Efqw== + "@types/babel__core@^7.0.0": version "7.1.13" resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.13.tgz#bc6eea53975fdf163aff66c086522c6f293ae4cf" @@ -2076,13 +2081,6 @@ "@types/mapbox__point-geometry" "*" "@types/pbf" "*" -"@types/maplibre-gl@^1.13.1": - version "1.13.1" - resolved "https://registry.yarnpkg.com/@types/maplibre-gl/-/maplibre-gl-1.13.1.tgz#d043f48e9f08e1b6a9aa7e924d2b86306f843f2b" - integrity sha512-AD7gFneLUYOWKhiwUvfD3LmQy4agJ2k2fe2V6XWCmt6R41d1q1H+BuyHJxFg31OTtDCag4u9ZZpQbjUmUG0gjQ== - dependencies: - "@types/geojson" "*" - "@types/minimatch@*": version "5.1.2" resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-5.1.2.tgz#07508b45797cb81ec3f273011b054cd0755eddca" From 523fbd4367b235ceb6f8de1c59b7309add836e4e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Thu, 5 Oct 2023 20:52:13 +0200 Subject: [PATCH 21/35] SearchBox: add loader for overpass queries (#192) --- .../SearchBox/AutocompleteInput.tsx | 2 + src/components/SearchBox/SearchBox.tsx | 39 +++++++++++++------ src/components/SearchBox/onSelectedFactory.ts | 12 +++++- 3 files changed, 41 insertions(+), 12 deletions(-) diff --git a/src/components/SearchBox/AutocompleteInput.tsx b/src/components/SearchBox/AutocompleteInput.tsx index 797f66d28..b95aa17ca 100644 --- a/src/components/SearchBox/AutocompleteInput.tsx +++ b/src/components/SearchBox/AutocompleteInput.tsx @@ -57,6 +57,7 @@ export const AutocompleteInput = ({ setInputValue, options, autocompleteRef, + setOverpassLoading, }) => { const { setFeature, setPreview } = useFeatureContext(); const { bbox, showToast } = useMapStateContext(); @@ -84,6 +85,7 @@ export const AutocompleteInput = ({ mobileMode, bbox, showToast, + setOverpassLoading, )} onHighlightChange={onHighlightFactory(setPreview)} getOptionDisabled={(o) => o.loader} diff --git a/src/components/SearchBox/SearchBox.tsx b/src/components/SearchBox/SearchBox.tsx index f2a1d9a81..c455af7be 100644 --- a/src/components/SearchBox/SearchBox.tsx +++ b/src/components/SearchBox/SearchBox.tsx @@ -1,4 +1,4 @@ -import React, { useRef, useState } from 'react'; +import React, { useEffect, useRef, useState } from 'react'; import styled from 'styled-components'; import debounce from 'lodash/debounce'; import SearchIcon from '@material-ui/icons/Search'; @@ -7,6 +7,7 @@ import IconButton from '@material-ui/core/IconButton'; import Router from 'next/router'; import match from 'autosuggest-highlight/match'; +import { CircularProgress } from '@material-ui/core'; import { fetchJson } from '../../services/fetch'; import { useMapStateContext } from '../utils/MapStateContext'; import { useFeatureContext } from '../utils/FeatureContext'; @@ -55,6 +56,10 @@ const SearchIconButton = styled(IconButton)` } `; +const OverpassCircularProgress = styled(CircularProgress)` + padding: 10px; +`; + const PHOTON_SUPPORTED_LANGS = ['en', 'de', 'fr']; const getApiUrl = (inputValue, view) => { @@ -162,15 +167,9 @@ const fetchOptions = debounce( 400, ); -const SearchBox = () => { - const { featureShown, feature, setFeature, setPreview } = useFeatureContext(); +const useFetchOptions = (inputValue: string, setOptions) => { const { view } = useMapStateContext(); - const [inputValue, setInputValue] = useState(''); - const [options, setOptions] = useState([]); - const autocompleteRef = useRef(); - const mobileMode = useMobileMode(); - - React.useEffect(() => { + useEffect(() => { if (inputValue === '') { setOptions([]); return; @@ -190,8 +189,13 @@ const SearchBox = () => { fetchOptions(inputValue, view, setOptions); } }, [inputValue]); +}; - const closePanel = () => { +const useOnClosePanel = (setInputValue) => { + const { feature, setFeature, setPreview } = useFeatureContext(); + const mobileMode = useMobileMode(); + + return () => { setInputValue(''); if (mobileMode) { setPreview(feature); @@ -199,6 +203,17 @@ const SearchBox = () => { setFeature(null); Router.push(`/${window.location.hash}`); }; +}; + +const SearchBox = () => { + const { featureShown } = useFeatureContext(); + const [inputValue, setInputValue] = useState(''); + const [options, setOptions] = useState([]); + const [overpassLoading, setOverpassLoading] = useState(false); + const autocompleteRef = useRef(); + const onClosePanel = useOnClosePanel(setInputValue); + + useFetchOptions(inputValue, setOptions); return ( @@ -212,9 +227,11 @@ const SearchBox = () => { setInputValue={setInputValue} options={options} autocompleteRef={autocompleteRef} + setOverpassLoading={setOverpassLoading} /> - {featureShown && } + {featureShown && } + {overpassLoading && } ); diff --git a/src/components/SearchBox/onSelectedFactory.ts b/src/components/SearchBox/onSelectedFactory.ts index 5df9372ac..8dd6900e2 100644 --- a/src/components/SearchBox/onSelectedFactory.ts +++ b/src/components/SearchBox/onSelectedFactory.ts @@ -56,9 +56,15 @@ const fitBounds = (option, panelShown = false) => { }; export const onSelectedFactory = - (setFeature, setPreview, mobileMode, bbox, showToast) => (_, option) => { + (setFeature, setPreview, mobileMode, bbox, showToast, setOverpassLoading) => + (_, option) => { if (option.overpass || option.preset) { const tags = option.overpass || option.preset.presetForSearch.tags; + + const timeout = setTimeout(() => { + setOverpassLoading(true); + }, 300); + performOverpassSearch(bbox, tags) .then((geojson) => { const count = geojson.features.length; @@ -70,6 +76,10 @@ export const onSelectedFactory = const message = `${e}`.substring(0, 100); const content = t('searchbox.overpass_error', { message }); showToast({ content, type: 'error' }); + }) + .finally(() => { + clearTimeout(timeout); + setOverpassLoading(false); }); return; } From 410faaf00e407934a509d3ce7e73efbeb3582881 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Sat, 7 Oct 2023 08:37:53 +0200 Subject: [PATCH 22/35] Map: turn on 3D terrain when user tilts (#193) --- .../Map/behaviour/useToggleTerrainControl.tsx | 38 +++++++++++-------- 1 file changed, 22 insertions(+), 16 deletions(-) diff --git a/src/components/Map/behaviour/useToggleTerrainControl.tsx b/src/components/Map/behaviour/useToggleTerrainControl.tsx index 05dd38f91..82a1adc10 100644 --- a/src/components/Map/behaviour/useToggleTerrainControl.tsx +++ b/src/components/Map/behaviour/useToggleTerrainControl.tsx @@ -2,37 +2,43 @@ import maplibregl from 'maplibre-gl'; import { useAddMapEvent } from '../../helpers'; +const TERRAIN = { + source: 'terrain', + exaggeration: 1, +}; + +const turnOnTerrain = (map) => { + map.setTerrain(TERRAIN); + map.setMaxPitch(85); +}; + +const turnOffTerrain = (map) => { + map.setTerrain(null); + map.setMaxPitch(60); +}; + class OsmappTerrainControl extends maplibregl.TerrainControl { _toggleTerrain = () => { if (this._map.getTerrain()) { - this._map.setTerrain(null); - this._map.setMaxPitch(60); + turnOffTerrain(this._map); } else { - this._map.setTerrain(this.options); - this._map.setMaxPitch(85); + turnOnTerrain(this._map); } this._updateTerrainIcon(); }; } -const terrainControl = new OsmappTerrainControl({ - source: 'terrain', - exaggeration: 1, -}); +const terrainControl = new OsmappTerrainControl(TERRAIN); let added = false; export const useToggleTerrainControl = useAddMapEvent((map) => ({ eventType: 'move', eventHandler: () => { - if (map.getPitch() > 0) { - if (!added) { - map.addControl(terrainControl); - added = true; - } - } else if (added) { - map.removeControl(terrainControl); - added = false; + if (map.getPitch() > 0 && !added) { + map.addControl(terrainControl); + turnOnTerrain(map); + added = true; } }, })); From d02edd8f969c31c9df8ceb371df22ae8a59cdd4d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Thu, 12 Oct 2023 22:47:22 +0200 Subject: [PATCH 23/35] general: clickable POIs broken message (#195) --- src/components/utils/MapStateContext.tsx | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/src/components/utils/MapStateContext.tsx b/src/components/utils/MapStateContext.tsx index e8c2f2600..35471a3c5 100644 --- a/src/components/utils/MapStateContext.tsx +++ b/src/components/utils/MapStateContext.tsx @@ -73,6 +73,12 @@ export const MapStateProvider = ({ children, initialMapView }) => { showToast, }; + const [brokenShown, setBrokenShown] = React.useState(true); + const onBrokenClose = (event?: React.SyntheticEvent, reason?: string) => { + if (reason !== 'clickaway') { + setBrokenShown(false); + } + }; return ( {children} @@ -81,6 +87,18 @@ export const MapStateProvider = ({ children, initialMapView }) => { {msg?.content} + + + Clickable POIs are currently broken on Maptiler –{' '} + + issue here + + . + + ); }; From 69431e8a21b0a9e4bdc63a530f2bd11335e984e3 Mon Sep 17 00:00:00 2001 From: danieldegroot2 <67521919+danieldegroot2@users.noreply.github.com> Date: Thu, 12 Oct 2023 22:57:25 +0200 Subject: [PATCH 24/35] osmApi: switch to api.openstreetmap.org API host (#194) --- src/services/osmApi.ts | 6 +++--- src/services/osmApiAuth.ts | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/services/osmApi.ts b/src/services/osmApi.ts index 3c39aaed6..90c047ebc 100644 --- a/src/services/osmApi.ts +++ b/src/services/osmApi.ts @@ -9,9 +9,9 @@ import { getSchemaForFeature } from './tagging/idTaggingScheme'; import { fetchSchemaTranslations } from './tagging/translations'; const getOsmUrl = ({ type, id }) => - `https://www.openstreetmap.org/api/0.6/${type}/${id}.json`; + `https://api.openstreetmap.org/api/0.6/${type}/${id}.json`; const getOsmHistoryUrl = ({ type, id }) => - `https://www.openstreetmap.org/api/0.6/${type}/${id}/history.json`; + `https://api.openstreetmap.org/api/0.6/${type}/${id}/history.json`; // Overpass API is used only for getting cetroids of ways and relations const getOverpassUrl = ({ type, id }) => { @@ -146,7 +146,7 @@ export const insertOsmNote = async (point: Position, text: string) => { body.append('text', text); const osmUrl = prod - ? 'https://www.openstreetmap.org' + ? 'https://api.openstreetmap.org' : 'https://master.apis.dev.openstreetmap.org'; // {"type":"Feature","geometry":{"type":"Point","coordinates":[14.3244982,50.0927863]},"properties":{"id":26569,"url":"https://master.apis.dev.openstreetmap.org/api/0.6/notes/26569.json","comment_url":"https://master.apis.dev.openstreetmap.org/api/0.6/notes/26569/comment.json","close_url":"https://master.apis.dev.openstreetmap.org/api/0.6/notes/26569/close.json","date_created":"2021-04-17 10:37:44 UTC","status":"open","comments":[{"date":"2021-04-17 10:37:44 UTC","action":"opened","text":"way/39695868! Place was marked permanently closed.From https://osmapp.org/way/39695868","html":"\u003cp\u003eway/39695868! Place was marked permanently closed.From \u003ca href=\"https://osmapp.org/way/39695868\" rel=\"nofollow noopener noreferrer\"\u003ehttps://osmapp.org/way/39695868\u003c/a\u003e\u003c/p\u003e"}]}} diff --git a/src/services/osmApiAuth.ts b/src/services/osmApiAuth.ts index f9db3b8b7..069251460 100644 --- a/src/services/osmApiAuth.ts +++ b/src/services/osmApiAuth.ts @@ -20,7 +20,7 @@ const { } = getConfig(); const osmUrl = prod - ? 'https://www.openstreetmap.org' + ? 'https://api.openstreetmap.org' : 'https://master.apis.dev.openstreetmap.org'; const oauth = prod From 6fdb1a8be18419d3a79d45b541046fadc7da07be Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Mon, 16 Oct 2023 20:37:36 +0200 Subject: [PATCH 25/35] Map: round zoom when switching to raster #103 --- src/components/Map/behaviour/useUpdateStyle.tsx | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/src/components/Map/behaviour/useUpdateStyle.tsx b/src/components/Map/behaviour/useUpdateStyle.tsx index dbc6c3a9a..f63c8202e 100644 --- a/src/components/Map/behaviour/useUpdateStyle.tsx +++ b/src/components/Map/behaviour/useUpdateStyle.tsx @@ -12,12 +12,13 @@ export const getRasterStyle = (key) => { export const useUpdateStyle = useMapEffect((map, activeLayers) => { const key = activeLayers[0] ?? DEFAULT_MAP; + map.setMaxZoom(osmappLayers[key]?.maxzoom ?? 24); // TODO find a way how to zoom bing further (now it stops at 19) - map.setStyle( - key === 'basic' - ? basicStyle - : key === 'outdoor' - ? outdoorStyle - : getRasterStyle(key), - ); + + if (key === 'basic' || key === 'outdoor') { + map.setStyle(key === 'basic' ? basicStyle : outdoorStyle); + } else { + map.setStyle(getRasterStyle(key)); + map.setZoom(Math.round(map.getZoom())); + } }); From b8eb30aad6e023ee99ebd4e140696b21641ab35b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Fri, 20 Oct 2023 12:39:40 +0200 Subject: [PATCH 26/35] osmApi: fix edit URL (#199) --- src/services/osmApiAuth.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/services/osmApiAuth.ts b/src/services/osmApiAuth.ts index 069251460..5840de776 100644 --- a/src/services/osmApiAuth.ts +++ b/src/services/osmApiAuth.ts @@ -19,8 +19,8 @@ const { publicRuntimeConfig: { osmappVersion }, } = getConfig(); -const osmUrl = prod - ? 'https://api.openstreetmap.org' +const osmEditUrl = prod + ? 'https://www.openstreetmap.org' // iD uses same URL https://ideditor.netlify.app/ : 'https://master.apis.dev.openstreetmap.org'; const oauth = prod @@ -39,7 +39,7 @@ const auth = new OsmAuth({ ...oauth, auto: true, landing: '/oauth-token.html', - url: osmUrl, + url: osmEditUrl, }); const authFetch = async (options) => @@ -235,7 +235,7 @@ export const editOsmFeature = async ( return { type: 'edit', text: changesetComment, - url: `${osmUrl}/changeset/${changesetId}`, + url: `${osmEditUrl}/changeset/${changesetId}`, redirect: `${getOsmappLink(feature)}`, }; }; @@ -271,7 +271,7 @@ export const addOsmFeature = async ( return { type: 'edit', text: changesetComment, - url: `${osmUrl}/changeset/${changesetId}`, + url: `${osmEditUrl}/changeset/${changesetId}`, redirect: `/${getUrlOsmId(apiId)}`, }; }; From ba366bfcc6e9a9642c28e66442d8c8617ed963b6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Mon, 30 Oct 2023 21:40:22 +0100 Subject: [PATCH 27/35] =?UTF-8?q?FeaturePanel:=20display=20id-tagging-sche?= =?UTF-8?q?ma=20=F0=9F=8E=89=20=20(#197)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/assets/WikipediaIcon.tsx | 19 ++ src/components/App/App.tsx | 7 +- src/components/FeaturePanel/Coordinates.tsx | 4 +- src/components/FeaturePanel/EditButton.tsx | 6 +- .../FeaturePanel/EditDialog/EditDialog.tsx | 19 +- .../FeaturePanel/FeatureHeading.tsx | 17 +- src/components/FeaturePanel/FeaturePanel.tsx | 123 +++------ src/components/FeaturePanel/FeaturedTag.tsx | 13 +- src/components/FeaturePanel/FeaturedTags.tsx | 7 +- .../FeaturePanel/IdSchemeFields.tsx | 136 ---------- src/components/FeaturePanel/OsmError.tsx | 2 +- .../Properties/IdSchemeFields.tsx | 173 +++++++++++++ .../FeaturePanel/Properties/Properties.tsx | 38 +++ .../FeaturePanel/Properties/Table.tsx | 32 +++ .../Properties/TagsTableInner.tsx | 180 +++++++++++++ .../FeaturePanel/Properties/Wrapper.tsx | 6 + .../{helpers => Properties}/getUrlForTag.tsx | 4 + .../FeaturePanel/Properties/helpers.tsx | 27 ++ .../FeaturePanel/Properties/renderValue.tsx | 50 ++++ src/components/FeaturePanel/TagsTable.tsx | 232 ----------------- .../helpers/EditDialogContext.tsx | 36 +++ .../FeaturePanel/helpers/Subheading.tsx | 8 + .../FeaturePanel/renderers/PhoneRenderer.tsx | 10 +- .../renderers/WikidataRenderer.tsx | 10 + .../renderers/WikipediaRenderer.tsx | 10 + .../Map/behaviour/useOnMapClicked.tsx | 5 +- src/helpers/TitleAndMetaTags.tsx | 2 +- src/locales/am.js | 2 +- src/locales/cs.js | 7 +- src/locales/de.js | 2 +- src/locales/es.js | 2 +- src/locales/fr.js | 2 +- src/locales/it.js | 2 +- src/locales/pl.js | 2 +- src/locales/vocabulary.js | 6 +- src/services/__tests__/osmApi.test.ts | 4 +- src/services/osmApi.ts | 8 +- src/services/osmApiAuth.ts | 18 +- .../tagging/__tests__/idTaggingScheme.test.ts | 152 +++++++++-- src/services/tagging/fields.ts | 28 ++- src/services/tagging/idTaggingScheme.ts | 236 ++++++++++-------- src/services/tagging/presets.ts | 25 +- src/services/tagging/translations.ts | 9 +- src/services/tagging/types/Fields.ts | 2 + src/services/tagging/types/Presets.ts | 23 ++ src/services/types.ts | 5 +- src/utils.ts | 4 + 47 files changed, 1070 insertions(+), 645 deletions(-) create mode 100644 src/assets/WikipediaIcon.tsx delete mode 100644 src/components/FeaturePanel/IdSchemeFields.tsx create mode 100644 src/components/FeaturePanel/Properties/IdSchemeFields.tsx create mode 100644 src/components/FeaturePanel/Properties/Properties.tsx create mode 100644 src/components/FeaturePanel/Properties/Table.tsx create mode 100644 src/components/FeaturePanel/Properties/TagsTableInner.tsx create mode 100644 src/components/FeaturePanel/Properties/Wrapper.tsx rename src/components/FeaturePanel/{helpers => Properties}/getUrlForTag.tsx (86%) create mode 100644 src/components/FeaturePanel/Properties/helpers.tsx create mode 100644 src/components/FeaturePanel/Properties/renderValue.tsx delete mode 100644 src/components/FeaturePanel/TagsTable.tsx create mode 100644 src/components/FeaturePanel/helpers/EditDialogContext.tsx create mode 100644 src/components/FeaturePanel/helpers/Subheading.tsx create mode 100644 src/components/FeaturePanel/renderers/WikidataRenderer.tsx create mode 100644 src/components/FeaturePanel/renderers/WikipediaRenderer.tsx diff --git a/src/assets/WikipediaIcon.tsx b/src/assets/WikipediaIcon.tsx new file mode 100644 index 000000000..686a67c3c --- /dev/null +++ b/src/assets/WikipediaIcon.tsx @@ -0,0 +1,19 @@ +import React from 'react'; + +// source https://icon-sets.iconify.design/tabler/brand-wikipedia/ +// license MIT +export const WikipediaIcon = (props) => ( + // eslint-disable-next-line react/jsx-props-no-spreading + +); diff --git a/src/components/App/App.tsx b/src/components/App/App.tsx index 88fbc6784..9b2d5d08a 100644 --- a/src/components/App/App.tsx +++ b/src/components/App/App.tsx @@ -3,7 +3,7 @@ import Cookies from 'js-cookie'; import nextCookies from 'next-cookies'; import Router, { useRouter } from 'next/router'; -import FeaturePanel from '../FeaturePanel/FeaturePanel'; +import { FeaturePanel } from '../FeaturePanel/FeaturePanel'; import Map from '../Map/Map'; import SearchBox from '../SearchBox/SearchBox'; import { MapStateProvider, useMapStateContext } from '../utils/MapStateContext'; @@ -16,6 +16,7 @@ import { FeaturePreview } from '../FeaturePreview/FeaturePreview'; import { TitleAndMetaTags } from '../../helpers/TitleAndMetaTags'; import { InstallDialog } from '../HomepagePanel/InstallDialog'; import { setIntlForSSR } from '../../services/intl'; +import { EditDialogProvider } from '../FeaturePanel/helpers/EditDialogContext'; const usePersistMapView = () => { const { view } = useMapStateContext(); @@ -87,7 +88,9 @@ const App = ({ featureFromRouter, initialMapView, hpCookie }) => { - + + + diff --git a/src/components/FeaturePanel/Coordinates.tsx b/src/components/FeaturePanel/Coordinates.tsx index a3c24a9d2..577547dce 100644 --- a/src/components/FeaturePanel/Coordinates.tsx +++ b/src/components/FeaturePanel/Coordinates.tsx @@ -106,7 +106,7 @@ export const Coords = ({ coords }: Props) => { const osmappLink = getFullOsmappLink(feature); return ( - + {positionToDeg(coords)} { - + ); }; diff --git a/src/components/FeaturePanel/EditButton.tsx b/src/components/FeaturePanel/EditButton.tsx index 8ab624e1a..f41aaf5df 100644 --- a/src/components/FeaturePanel/EditButton.tsx +++ b/src/components/FeaturePanel/EditButton.tsx @@ -5,6 +5,7 @@ import React from 'react'; import { Box } from '@material-ui/core'; import { t } from '../../services/intl'; import { useOsmAuthContext } from '../utils/OsmAuthContext'; +import { useEditDialogContext } from './helpers/EditDialogContext'; const getLabel = (loggedIn, isAddPlace, isUndelete) => { if (isAddPlace) return t('featurepanel.add_place_button'); @@ -13,8 +14,9 @@ const getLabel = (loggedIn, isAddPlace, isUndelete) => { return t('featurepanel.note_button'); }; -export const EditButton = ({ isAddPlace, isUndelete, setDialogOpenedWith }) => { +export const EditButton = ({ isAddPlace, isUndelete }) => { const { loggedIn } = useOsmAuthContext(); + const { open } = useEditDialogContext(); return ( @@ -25,7 +27,7 @@ export const EditButton = ({ isAddPlace, isUndelete, setDialogOpenedWith }) => { } variant="outlined" color="primary" - onClick={() => setDialogOpenedWith(true)} + onClick={open} > {getLabel(loggedIn, isAddPlace, isUndelete)} diff --git a/src/components/FeaturePanel/EditDialog/EditDialog.tsx b/src/components/FeaturePanel/EditDialog/EditDialog.tsx index ea79044a0..3d3f13d77 100644 --- a/src/components/FeaturePanel/EditDialog/EditDialog.tsx +++ b/src/components/FeaturePanel/EditDialog/EditDialog.tsx @@ -31,6 +31,7 @@ import Maki from '../../utils/Maki'; import { FeatureTypeSelect } from './FeatureTypeSelect'; import { getLabel } from '../../../helpers/featureLabel'; import { useUserThemeContext } from '../../../helpers/theme'; +import { useEditDialogContext } from '../helpers/EditDialogContext'; const useIsFullScreen = () => { const theme = useTheme(); @@ -62,9 +63,6 @@ const StyledDialog = styled(Dialog)` interface Props { feature: Feature; - open: boolean; - handleClose: () => void; - focusTag: boolean | string; isAddPlace: boolean; isUndelete: boolean; } @@ -119,17 +117,12 @@ const saveDialog = ({ }); }; -export const EditDialog = ({ - feature, - open, - handleClose, - focusTag, - isAddPlace, - isUndelete, -}: Props) => { +export const EditDialog = ({ feature, isAddPlace, isUndelete }: Props) => { const { currentTheme } = useUserThemeContext(); const router = useRouter(); const { loggedIn, handleLogout } = useOsmAuthContext(); + const { opened, close, focusTag } = useEditDialogContext(); + const fullScreen = useIsFullScreen(); const [typeTag, setTypeTag] = useState(''); const [tags, setTag] = useTagsState(feature.tags); // TODO all these should go into `values`, consider Formik @@ -141,7 +134,7 @@ export const EditDialog = ({ const [successInfo, setSuccessInfo] = useState(false); const onClose = () => { - handleClose(); + close(); if (successInfo.redirect) { router.replace(successInfo.redirect); // only useRouter reloads the panel client-side } @@ -168,7 +161,7 @@ export const EditDialog = ({ return ( diff --git a/src/components/FeaturePanel/FeatureHeading.tsx b/src/components/FeaturePanel/FeatureHeading.tsx index bf857a31a..5e816b128 100644 --- a/src/components/FeaturePanel/FeatureHeading.tsx +++ b/src/components/FeaturePanel/FeatureHeading.tsx @@ -1,6 +1,7 @@ import React from 'react'; import styled from 'styled-components'; import { EditIconButton } from './helpers/EditIconButton'; +import { useEditDialogContext } from './helpers/EditDialogContext'; const Wrapper = styled.div` font-size: 36px; @@ -15,9 +16,13 @@ const Wrapper = styled.div` } `; -export const FeatureHeading = ({ title, onEdit, deleted, editEnabled }) => ( - - {editEnabled && onEdit('name')} />} - {title} - -); +export const FeatureHeading = ({ title, deleted, editEnabled }) => { + const { openWithTag } = useEditDialogContext(); + + return ( + + {editEnabled && openWithTag('name')} />} + {title} + + ); +}; diff --git a/src/components/FeaturePanel/FeaturePanel.tsx b/src/components/FeaturePanel/FeaturePanel.tsx index 2071f0b19..15f5af01a 100644 --- a/src/components/FeaturePanel/FeaturePanel.tsx +++ b/src/components/FeaturePanel/FeaturePanel.tsx @@ -1,5 +1,4 @@ import React, { useState } from 'react'; -import { Typography } from '@material-ui/core'; import { FeatureHeading } from './FeatureHeading'; import Coordinates from './Coordinates'; import { useToggleState } from '../helpers'; @@ -18,40 +17,23 @@ import { ObjectsAround } from './ObjectsAround'; import { OsmError } from './OsmError'; import { Members } from './Members'; import { EditButton } from './EditButton'; -import { FeaturedTags } from './FeaturedTags'; import { getLabel } from '../../helpers/featureLabel'; import { ImageSection } from './ImageSection/ImageSection'; -import { IdSchemeFields } from './IdSchemeFields'; -import { TagsTable } from './TagsTable'; import { PublicTransport } from './PublicTransport/PublicTransport'; +import { Properties } from './Properties/Properties'; -const featuredKeys = [ - 'website', - 'contact:website', - 'phone', - 'contact:phone', - 'contact:mobile', - 'opening_hours', - 'description', - 'fhrs:id', -]; - -const FeaturePanel = () => { +export const FeaturePanel = () => { const { feature } = useFeatureContext(); const [advanced, setAdvanced] = useState(false); const [showAround, toggleShowAround] = useToggleState(false); - const [dialogOpenedWith, setDialogOpenedWith] = - useState(false); + const [showTags, toggleShowTags] = useToggleState(false); - const { point, tags, osmMeta, skeleton, error } = feature; - const deleted = error === 'deleted'; - const editEnabled = !skeleton && (!error || deleted); + const { point, tags, osmMeta, skeleton, deleted } = feature; + const editEnabled = !skeleton; + const showTagsTable = deleted || showTags || (!skeleton && !feature.schema); const osmappLink = getFullOsmappLink(feature); - const featuredTags = featuredKeys - .map((k) => [k, tags[k]]) - .filter(([, v]) => v); const label = getLabel(feature); return ( @@ -63,81 +45,55 @@ const FeaturePanel = () => { deleted={deleted} title={label} editEnabled={editEnabled && !point} - onEdit={setDialogOpenedWith} - /> - - - - - {advanced && ( - - )} - {!advanced && ( + {!skeleton && ( <> - {!!featuredTags.length && ( - - {t('featurepanel.other_info_heading')} - - )} - + + - - )} - {advanced && } + {advanced && } - + - {editEnabled && ( - <> - + {editEnabled && ( + <> + - setDialogOpenedWith(false)} - feature={feature} - isAddPlace={point} - isUndelete={deleted} - focusTag={dialogOpenedWith} - key={ - getUrlOsmId(osmMeta) + (deleted && 'del') // we need to refresh inner state - } - /> + + + )} + + {point && } )} - {point && } -
{osmappLink}
+ {' '} - {!point && showAround && }
@@ -155,5 +110,3 @@ const FeaturePanel = () => { ); }; - -export default FeaturePanel; diff --git a/src/components/FeaturePanel/FeaturedTag.tsx b/src/components/FeaturePanel/FeaturedTag.tsx index c6b28f55b..34019fa87 100644 --- a/src/components/FeaturePanel/FeaturedTag.tsx +++ b/src/components/FeaturePanel/FeaturedTag.tsx @@ -6,6 +6,8 @@ import OpeningHoursRenderer from './renderers/OpeningHoursRenderer'; import PhoneRenderer from './renderers/PhoneRenderer'; import { EditIconButton } from './helpers/EditIconButton'; import { FoodHygieneRatingSchemeRenderer } from './renderers/FoodHygieneRatingScheme'; +import { WikipediaRenderer } from './renderers/WikipediaRenderer'; +import { WikidataRenderer } from './renderers/WikidataRenderer'; const Wrapper = styled.div` position: relative; @@ -27,11 +29,16 @@ const Value = styled.div` margin: 0 10px -6px 2px; opacity: 0.4; } + + :last-child { + min-width: 0; + overflow: hidden; + } `; const DefaultRenderer = ({ v }) => v; const renderers: { - [key: string]: React.FC<{ v: string }>; + [key: string]: React.FC<{ k: string; v: string }>; } = { website: WebsiteRenderer, 'contact:website': WebsiteRenderer, @@ -40,6 +47,8 @@ const renderers: { 'contact:mobile': PhoneRenderer, opening_hours: OpeningHoursRenderer, 'fhrs:id': FoodHygieneRatingSchemeRenderer, + wikipedia: WikipediaRenderer, + wikidata: WikidataRenderer, }; export const FeaturedTag = ({ k, v, onEdit }) => { @@ -50,7 +59,7 @@ export const FeaturedTag = ({ k, v, onEdit }) => { onEdit(k)} /> - + ); diff --git a/src/components/FeaturePanel/FeaturedTags.tsx b/src/components/FeaturePanel/FeaturedTags.tsx index 14f37b0c5..8eb49cc05 100644 --- a/src/components/FeaturePanel/FeaturedTags.tsx +++ b/src/components/FeaturePanel/FeaturedTags.tsx @@ -1,18 +1,21 @@ import React from 'react'; import styled from 'styled-components'; import { FeaturedTag } from './FeaturedTag'; +import { useEditDialogContext } from './helpers/EditDialogContext'; const Spacer = styled.div` padding-bottom: 10px; `; -export const FeaturedTags = ({ featuredTags, setDialogOpenedWith }) => { +export const FeaturedTags = ({ featuredTags }) => { + const { openWithTag } = useEditDialogContext(); + if (!featuredTags.length) return null; return ( <> {featuredTags.map(([k, v]) => ( - + ))} diff --git a/src/components/FeaturePanel/IdSchemeFields.tsx b/src/components/FeaturePanel/IdSchemeFields.tsx deleted file mode 100644 index 21147b22e..000000000 --- a/src/components/FeaturePanel/IdSchemeFields.tsx +++ /dev/null @@ -1,136 +0,0 @@ -import React, { ReactNode } from 'react'; -import styled from 'styled-components'; -import Typography from '@material-ui/core/Typography'; -import { Field } from '../../services/tagging/types/Fields'; -import { getUrlForTag } from './helpers/getUrlForTag'; -import { slashToOptionalBr } from '../helpers'; -import { buildAddress } from '../../services/helpers'; -import { Feature } from '../../services/types'; -import { t } from '../../services/intl'; - -// taken from src/components/FeaturePanel/TagsTable.tsx -const Table = styled.table` - font-size: 1rem; - width: 100%; - - th, - td { - padding: 0.1em; - overflow: hidden; - - &:hover .show-on-hover { - display: block !important; - } - } - - th { - width: 140px; - max-width: 140px; - color: ${({ theme }) => theme.palette.text.secondary}; - text-align: left; - font-weight: normal; - vertical-align: baseline; - padding-left: 0; - } - - table { - padding-left: 1em; - padding-bottom: 1em; - } -`; - -// TODO move to helpers -const getEllipsisHumanUrl = (humanUrl) => { - const MAX_LENGTH = 40; - return humanUrl.replace(/^([^/]+.{0,5})(.*)$/, (full, hostname, rest) => { - const charsLeft = MAX_LENGTH - 10 - hostname.length; - return ( - hostname + - (full.length > MAX_LENGTH - ? `…${rest.substring(rest.length - charsLeft)}` - : rest) - ); - }); -}; - -// taken from src/components/FeaturePanel/TagsTable.tsx -const renderValue = (k, v): string | ReactNode => { - const url = getUrlForTag(k, v); - if (url) { - let humanUrl = v.replace(/^https?:\/\//, '').replace(/^([^/]+)\/$/, '$1'); - if (k === 'image') { - humanUrl = getEllipsisHumanUrl(humanUrl); - } - return {slashToOptionalBr(humanUrl)}; - } - return v; -}; - -const render = (field: Field, feature: Feature, k, v): string | ReactNode => { - if (field.type === 'address') { - return buildAddress(feature.tags, feature.center); - } - return renderValue(k, v); -}; - -const getTitle = (type: string, field: Field) => - `${type}: ${JSON.stringify(field, null, 2)}`; - -// TODO some fields eg. oneway/bicycle doesnt have units in brackets -const unitRegExp = / \((.+)\)$/i; -const removeUnits = (label) => label.replace(unitRegExp, ''); -const addUnits = (label, value: string | ReactNode) => { - if (typeof value !== 'string') return value; - const unit = label.match(unitRegExp); - return `${value}${unit ? ` (${unit[1]})` : ''}`; -}; - -export const IdSchemeFields = ({ feature, featuredTags }) => { - const { schema } = feature; - if (!schema) return null; - if (!Object.keys(schema).length) return null; - - return ( - <> - {featuredTags.length && - (schema.matchedFields.length || - schema.tagsWithFields.length || - schema.restKeys.length) ? ( - - {t('featurepanel.other_info_heading')} - - ) : null} - - - - {schema.matchedFields.map(({ key, value, label, field }) => ( - - - - - ))} - - - {schema.tagsWithFields.map(({ key, value, label, field }) => ( - - - - - ))} - - - {schema.keysTodo.map((key) => ( - - - - - ))} - -
- {removeUnits(label)} - {addUnits(label, render(field, feature, key, value))}
- {removeUnits(label)} - {render(field, feature, key, addUnits(label, value))}
{key}{renderValue(key, feature.tags[key])}
- - ); -}; diff --git a/src/components/FeaturePanel/OsmError.tsx b/src/components/FeaturePanel/OsmError.tsx index bd8ff8716..794c03e4f 100644 --- a/src/components/FeaturePanel/OsmError.tsx +++ b/src/components/FeaturePanel/OsmError.tsx @@ -9,7 +9,7 @@ export const OsmError = () => { const { feature } = useFeatureContext(); const code = feature.error; - if (code === 'deleted') { + if (feature.deleted) { return ( diff --git a/src/components/FeaturePanel/Properties/IdSchemeFields.tsx b/src/components/FeaturePanel/Properties/IdSchemeFields.tsx new file mode 100644 index 000000000..d03ca6a0d --- /dev/null +++ b/src/components/FeaturePanel/Properties/IdSchemeFields.tsx @@ -0,0 +1,173 @@ +import React, { ReactNode } from 'react'; +import styled from 'styled-components'; +import { Field } from '../../../services/tagging/types/Fields'; +import { useToggleState } from '../../helpers'; +import { buildAddress } from '../../../services/helpers'; +import { Feature } from '../../../services/types'; +import { t } from '../../../services/intl'; +import { TagsTableInner } from './TagsTableInner'; +import { EditIconButton } from '../helpers/EditIconButton'; +import { useEditDialogContext } from '../helpers/EditDialogContext'; +import { renderValue } from './renderValue'; +import { Table } from './Table'; +import { ShowMoreButton } from './helpers'; +import { useFeatureContext } from '../../utils/FeatureContext'; +import { Subheading } from '../helpers/Subheading'; +import { UiField } from '../../../services/tagging/types/Presets'; + +const Spacer = styled.div` + width: 100%; + height: 50px; +`; + +const render = (uiField: UiField, feature: Feature): string | ReactNode => { + const { field, key: k, value: v, tagsForField, fieldTranslation } = uiField; + + if (field.type === 'address') { + return buildAddress(feature.tags, feature.center); + } + + if (field.fieldKey === 'wikidata') { + return renderValue('wikidata', feature.tags.wikidata); + } + + if (fieldTranslation?.types && fieldTranslation?.options) { + return tagsForField.map(({ key, value: value2 }) => ( +
+ {fieldTranslation.types[key]}:{' '} + {renderValue(key, fieldTranslation.options[value2]?.title)} +
+ )); + } + + if (field?.type === 'manyCombo') { + return tagsForField.map(({ key, value: value2 }) => ( +
+ {fieldTranslation.options[key]}:{' '} + {renderValue(key, fieldTranslation.options[value2]?.title ?? value2)} +
+ )); + } + + if (tagsForField?.length >= 2) { + return ( + <> + {tagsForField.map(({ key, value: value2 }) => ( +
{renderValue(key, value2)}
+ ))} + + ); + } + + if (!k) { + return renderValue(tagsForField[0].key, tagsForField[0].value); + } + + return renderValue(k, v); +}; + +// TODO some fields eg. oneway/bicycle doesnt have units in brackets +const unitRegExp = / \((.+)\)$/i; +const removeUnits = (label) => label.replace(unitRegExp, ''); +const addUnits = (label, value: string | ReactNode) => { + if (typeof value !== 'string') return value; + const unit = label.match(unitRegExp); + return `${value}${unit ? ` (${unit[1]})` : ''}`; +}; + +const getTooltip = (field: Field, key: string) => + `field: ${field.fieldKey}${key === field.fieldKey ? '' : `, key: ${key}`} (${ + field.type + })`; + +const UiFields = ({ fields }: { fields: UiField[] }) => { + const { openWithTag } = useEditDialogContext(); + const { feature } = useFeatureContext(); + + return ( + <> + {fields.map((uiField) => { + const { key, label, field, tagsForField } = uiField; + return ( + + {removeUnits(label)} + + openWithTag(tagsForField?.[0]?.key ?? key)} + /> + {addUnits(label, render(uiField, feature))} + + + ); + })} + + ); +}; + +const OtherTagsSection = () => { + const [otherTagsShown, toggleOtherTagsShown] = useToggleState(false); + const { feature } = useFeatureContext(); + const { schema } = feature; + + return ( + <> + + + + + + {otherTagsShown && ( + <> + + ({ ...acc, [key]: feature.tags[key] }), + {}, + )} + center={feature.center} + /> + + )} + + ); +}; + +export const IdSchemeFields = () => { + const { feature } = useFeatureContext(); + const { schema } = feature; + const { keysTodo, featuredTags, matchedFields, tagsWithFields } = schema; + + // TODO add link to osm key reference as Tooltip https://wiki.openstreetmap.org/w/api.php?action=wbgetentities&format=json&languagefallback=1&languages=en%7Ccs%7Cen-us%7Csk&origin=*&sites=wiki&titles=Locale%3Acs%7CLocale%3Aen-us%7CLocale%3Ask%7CKey%3Astart%20date%7CTag%3Astart%20date%3D1752 + // TODO preset translations https://github.com/zbycz/osmapp/issues/190 + + const numberOfItems = + featuredTags.length + + matchedFields.length + + tagsWithFields.length + + keysTodo.length; + + if (!numberOfItems) { + return ; + } + + const showDetailsHeading = !!(featuredTags.length && matchedFields.length); + const showOtherTagsSection = !!(tagsWithFields.length || keysTodo.length); + + return ( + <> + {showDetailsHeading && ( + {t('featurepanel.details_heading')} + )} + + + + + {showOtherTagsSection && } + +
+ + ); +}; diff --git a/src/components/FeaturePanel/Properties/Properties.tsx b/src/components/FeaturePanel/Properties/Properties.tsx new file mode 100644 index 000000000..a4237c110 --- /dev/null +++ b/src/components/FeaturePanel/Properties/Properties.tsx @@ -0,0 +1,38 @@ +import React from 'react'; +import { FeaturedTags } from '../FeaturedTags'; +import { IdSchemeFields } from './IdSchemeFields'; +import { t } from '../../../services/intl'; +import { TagsTableInner } from './TagsTableInner'; +import { useFeatureContext } from '../../utils/FeatureContext'; +import { Subheading } from '../helpers/Subheading'; +import { Wrapper } from './Wrapper'; +import { Table } from './Table'; + +export const Properties = ({ showTags }) => { + const { feature } = useFeatureContext(); + + return ( + <> + {!showTags && ( + <> + + + + )} + {showTags && ( + <> + {!!Object.keys(feature.tags).length && ( + {t('featurepanel.all_tags_heading')} + )} + + + + + +
+
+ + )} + + ); +}; diff --git a/src/components/FeaturePanel/Properties/Table.tsx b/src/components/FeaturePanel/Properties/Table.tsx new file mode 100644 index 000000000..b680c5a93 --- /dev/null +++ b/src/components/FeaturePanel/Properties/Table.tsx @@ -0,0 +1,32 @@ +import styled from 'styled-components'; + +export const Table = styled.table` + font-size: 1rem; + width: 100%; + + th, + td { + padding: 0.1em; + overflow: hidden; + vertical-align: baseline; + + &:hover .show-on-hover { + display: block !important; + } + } + + th { + width: 140px; + max-width: 140px; + color: ${({ theme }) => theme.palette.text.secondary}; + text-align: left; + font-weight: normal; + vertical-align: baseline; + padding-left: 0; + } + + table { + padding-left: 1em; + padding-bottom: 1em; + } +`; diff --git a/src/components/FeaturePanel/Properties/TagsTableInner.tsx b/src/components/FeaturePanel/Properties/TagsTableInner.tsx new file mode 100644 index 000000000..ac6b28d75 --- /dev/null +++ b/src/components/FeaturePanel/Properties/TagsTableInner.tsx @@ -0,0 +1,180 @@ +import React from 'react'; +import truncate from 'lodash/truncate'; + +import { useToggleState } from '../../helpers'; +import { EditIconButton } from '../helpers/EditIconButton'; +import { buildAddress } from '../../../services/helpers'; +import { ToggleButton } from '../helpers/ToggleButton'; +import { renderValue } from './renderValue'; +import { useEditDialogContext } from '../helpers/EditDialogContext'; + +const isAddr = (k) => k.match(/^addr:|uir_adr|:addr/); +const isName = (k) => k.match(/^name(:|$)/); +const isShortName = (k) => k.match(/^short_name(:|$)/); +const isAltName = (k) => k.match(/^alt_name(:|$)/); +const isOfficialName = (k) => k.match(/^official_name(:|$)/); +const isOldName = (k) => k.match(/^old_name(:|$)/); +const isBuilding = (k) => + k.match(/building|roof|^min_level|^max_level|height$/); +const isNetwork = (k) => k.match(/network/); +const isBrand = (k) => k.match(/^brand/); +const isOperator = (k) => k.match(/^operator/); +const isPayment = (k) => k.match(/^payment/); + +const TagsGroup = ({ tags, label, value, hideArrow = false, onEdit }) => { + const [isShown, toggle] = useToggleState(false); + + if (!tags.length) { + return null; + } + + return ( + <> + + {label} + + onEdit(tags[0][0])} /> + {value || tags[0]?.[1]} + {!hideArrow && } + + + {isShown && ( + + + + + {tags.map(([k, v]) => ( + + + + + ))} + +
{k}{renderValue(k, v)}
+ + + )} + + ); +}; + +// TODO make it dynamic - count how many "first parts before :" are there, and group all >= 2 + +export const TagsTableInner = ({ tags, center, except = [] }) => { + const { openWithTag: onEdit } = useEditDialogContext(); + + const tagsEntries = Object.entries(tags).filter(([k]) => !except.includes(k)); + + const addrs = tagsEntries.filter(([k]) => isAddr(k)); + const names = tagsEntries.filter(([k]) => isName(k)); + const shortNames = tagsEntries.filter(([k]) => isShortName(k)); + const altNames = tagsEntries.filter(([k]) => isAltName(k)); + const officialNames = tagsEntries.filter(([k]) => isOfficialName(k)); + const oldNames = tagsEntries.filter(([k]) => isOldName(k)); + const buildings = tagsEntries.filter(([k]) => isBuilding(k)); + const networks = tagsEntries.filter(([k]) => isNetwork(k)); + const brands = tagsEntries.filter(([k]) => isBrand(k)); + const operator = tagsEntries.filter(([k]) => isOperator(k)); + const payments = tagsEntries.filter(([k]) => isPayment(k)); + const rest = tagsEntries.filter( + ([k]) => + !isName(k) && + !isShortName(k) && + !isAltName(k) && + !isOfficialName(k) && + !isOldName(k) && + !isAddr(k) && + !isBuilding(k) && + !isNetwork(k) && + !isOperator(k) && + !isPayment(k) && + !isBrand(k), + ); + + return ( + <> + + + + + + + {rest.map(([k, v]) => ( + + {k} + + onEdit(k)} /> + {renderValue(k, v)} + + + ))} + + + + + + + ); +}; diff --git a/src/components/FeaturePanel/Properties/Wrapper.tsx b/src/components/FeaturePanel/Properties/Wrapper.tsx new file mode 100644 index 000000000..b35e02735 --- /dev/null +++ b/src/components/FeaturePanel/Properties/Wrapper.tsx @@ -0,0 +1,6 @@ +import styled from 'styled-components'; + +export const Wrapper = styled.div` + position: relative; + margin-bottom: 2em; +`; diff --git a/src/components/FeaturePanel/helpers/getUrlForTag.tsx b/src/components/FeaturePanel/Properties/getUrlForTag.tsx similarity index 86% rename from src/components/FeaturePanel/helpers/getUrlForTag.tsx rename to src/components/FeaturePanel/Properties/getUrlForTag.tsx index 90be731f7..4be68437c 100644 --- a/src/components/FeaturePanel/helpers/getUrlForTag.tsx +++ b/src/components/FeaturePanel/Properties/getUrlForTag.tsx @@ -31,6 +31,10 @@ export const getUrlForTag = (k, v) => { if (k === 'ref:edubase') { return `https://get-information-schools.service.gov.uk/Establishments/Establishment/Details/${v}`; } + if (k === 'gnis:feature_id') { + // alternative url in https://github.com/openstreetmap/id-tagging-schema/issues/272 + return `https://edits.nationalmap.gov/apps/gaz-domestic/public/search/names/${v}`; + } if (k === 'website') { return v.match(urlRegExp) ? v : `http://${v}`; } diff --git a/src/components/FeaturePanel/Properties/helpers.tsx b/src/components/FeaturePanel/Properties/helpers.tsx new file mode 100644 index 000000000..079841819 --- /dev/null +++ b/src/components/FeaturePanel/Properties/helpers.tsx @@ -0,0 +1,27 @@ +import styled from 'styled-components'; +import Button from '@material-ui/core/Button'; +import ChevronRight from '@material-ui/icons/ChevronRight'; +import ExpandLessIcon from '@material-ui/icons/ExpandLess'; +import React from 'react'; +import { t } from '../../../services/intl'; + +const StyledToggleButton = styled(Button)` + svg { + font-size: 17px; + } +`; + +export const ShowMoreButton = ({ onClick, isShown }) => ( + + {!isShown && ( + <> + {t('show_more')} + + )} + {isShown && ( + <> + {t('show_less')} + + )} + +); diff --git a/src/components/FeaturePanel/Properties/renderValue.tsx b/src/components/FeaturePanel/Properties/renderValue.tsx new file mode 100644 index 000000000..01ec4d657 --- /dev/null +++ b/src/components/FeaturePanel/Properties/renderValue.tsx @@ -0,0 +1,50 @@ +import React from 'react'; +import { getUrlForTag } from './getUrlForTag'; +import { slashToOptionalBr } from '../../helpers'; + +const getEllipsisHumanUrl = (humanUrl) => { + const MAX_LENGTH = 40; + return humanUrl.replace(/^([^/]+.{0,5})(.*)$/, (full, hostname, rest) => { + const charsLeft = MAX_LENGTH - 10 - hostname.length; + return ( + hostname + + (full.length > MAX_LENGTH + ? `…${rest.substring(rest.length - charsLeft)}` + : rest) + ); + }); +}; + +const getHumanValue = (k, v, featured: boolean) => { + const humanValue = v.replace(/^https?:\/\//, '').replace(/^([^/]+)\/$/, '$1'); + + if (v.startsWith('https://commons.wikimedia.org/wiki/')) { + return v + .substring('https://commons.wikimedia.org/wiki/'.length) + .replace(/_/g, ' '); + } + if (k === 'image') { + return getEllipsisHumanUrl(humanValue); + } + if (k.match(/:?wikipedia$/) && v.match(/:/)) { + return v.split(':', 2)[1]; + } + if (featured && k === 'wikidata') { + return `Wikipedia (wikidata)`; // TODO fetch label from wikidata + } + if (v === 'yes') { + return '✓'; + } + if (v === 'no') { + return '✗'; + } + + return humanValue; +}; + +export const renderValue = (k, v, featured = false) => { + const url = getUrlForTag(k, v); + const humanValue = getHumanValue(k, v, featured); + + return url ? {slashToOptionalBr(humanValue)} : humanValue; +}; diff --git a/src/components/FeaturePanel/TagsTable.tsx b/src/components/FeaturePanel/TagsTable.tsx deleted file mode 100644 index 173de615a..000000000 --- a/src/components/FeaturePanel/TagsTable.tsx +++ /dev/null @@ -1,232 +0,0 @@ -import React from 'react'; -import styled from 'styled-components'; -import truncate from 'lodash/truncate'; - -import { slashToOptionalBr, useToggleState } from '../helpers'; -import { getUrlForTag } from './helpers/getUrlForTag'; -import { EditIconButton } from './helpers/EditIconButton'; -import { buildAddress } from '../../services/helpers'; -import { ToggleButton } from './helpers/ToggleButton'; - -const Wrapper = styled.div` - position: relative; - margin-bottom: 2em; -`; - -const Table = styled.table` - font-size: 1rem; - width: 100%; - - th, - td { - padding: 0.1em; - overflow: hidden; - - &:hover .show-on-hover { - display: block !important; - } - } - - th { - width: 140px; - max-width: 140px; - color: ${({ theme }) => theme.palette.text.secondary}; - text-align: left; - font-weight: normal; - vertical-align: baseline; - padding-left: 0; - } - - table { - padding-left: 1em; - padding-bottom: 1em; - } -`; - -const renderValue = (k, v) => { - const url = getUrlForTag(k, v); - let humanUrl = v.replace(/^https?:\/\//, '').replace(/^([^/]+)\/$/, '$1'); - if (k === 'image') { - humanUrl = humanUrl.replace(/^([^/]+.{0,5})(.*)$/, (full, p1, p2) => { - const charsLeft = 30 - p1.length; - return ( - p1 + (full.length > 40 ? `…${p2.substring(p2.length - charsLeft)}` : p2) - ); - }); - } - return url ? {slashToOptionalBr(humanUrl)} : v; -}; - -const isAddr = (k) => k.match(/^addr:|uir_adr|:addr/); -const isName = (k) => k.match(/^name(:|$)/); -const isShortName = (k) => k.match(/^short_name(:|$)/); -const isAltName = (k) => k.match(/^alt_name(:|$)/); -const isOfficialName = (k) => k.match(/^official_name(:|$)/); -const isOldName = (k) => k.match(/^old_name(:|$)/); -const isBuilding = (k) => - k.match(/building|roof|^min_level|^max_level|height$/); -const isNetwork = (k) => k.match(/network/); -const isBrand = (k) => k.match(/^brand/); -const isOperator = (k) => k.match(/^operator/); -const isPayment = (k) => k.match(/^payment/); - -const TagsGroup = ({ tags, label, value, hideArrow = false, onEdit }) => { - const [isShown, toggle] = useToggleState(false); - - if (!tags.length) { - return null; - } - - return ( - <> - - {label} - - onEdit(tags[0][0])} /> - {value || tags[0]?.join(' = ')} - {!hideArrow && } - - - {isShown && ( - - - - - {tags.map(([k, v]) => ( - - - - - ))} - -
{k}{renderValue(k, v)}
- - - )} - - ); -}; - -// This is supposed to be replaced by iD presets in future (see https://github.com/zbycz/osmapp/issues/116) -export const TagsTable = ({ tags, center, except, onEdit }) => { - const tagsEntries = Object.entries(tags).filter(([k]) => !except.includes(k)); - - const addrs = tagsEntries.filter(([k]) => isAddr(k)); - const names = tagsEntries.filter(([k]) => isName(k)); - const shortNames = tagsEntries.filter(([k]) => isShortName(k)); - const altNames = tagsEntries.filter(([k]) => isAltName(k)); - const officialNames = tagsEntries.filter(([k]) => isOfficialName(k)); - const oldNames = tagsEntries.filter(([k]) => isOldName(k)); - const buildings = tagsEntries.filter(([k]) => isBuilding(k)); - const networks = tagsEntries.filter(([k]) => isNetwork(k)); - const brands = tagsEntries.filter(([k]) => isBrand(k)); - const operator = tagsEntries.filter(([k]) => isOperator(k)); - const payments = tagsEntries.filter(([k]) => isPayment(k)); - const rest = tagsEntries.filter( - ([k]) => - !isName(k) && - !isShortName(k) && - !isAltName(k) && - !isOfficialName(k) && - !isOldName(k) && - !isAddr(k) && - !isBuilding(k) && - !isNetwork(k) && - !isOperator(k) && - !isPayment(k) && - !isBrand(k), - ); - - return ( - - - - - - - - - - {rest.map(([k, v]) => ( - - - - - ))} - - - - - - -
{k} - onEdit(k)} /> - {renderValue(k, v)} -
-
- ); -}; diff --git a/src/components/FeaturePanel/helpers/EditDialogContext.tsx b/src/components/FeaturePanel/helpers/EditDialogContext.tsx new file mode 100644 index 000000000..809efbcfb --- /dev/null +++ b/src/components/FeaturePanel/helpers/EditDialogContext.tsx @@ -0,0 +1,36 @@ +import React, { createContext, useContext, useState } from 'react'; +import Router from 'next/router'; +import { isBrowser } from '../../helpers'; + +interface EditDialogType { + opened: boolean; + focusTag: string | boolean; + open: () => void; + close: () => void; + openWithTag: (tag: string) => void; +} + +export const EditDialogContext = createContext(undefined); + +// lives in App.tsx because it needs ctx in SSR +export const EditDialogProvider = ({ children }) => { + const initialState = isBrowser() ? Router.query.all?.[2] === 'edit' : false; // TODO supply router.query in SSR + const [openedWithTag, setOpenedWithTag] = + useState(initialState); + + const value = { + opened: !!openedWithTag, + focusTag: openedWithTag, + open: () => setOpenedWithTag(true), + close: () => setOpenedWithTag(false), + openWithTag: setOpenedWithTag, + }; + + return ( + + {children} + + ); +}; + +export const useEditDialogContext = () => useContext(EditDialogContext); diff --git a/src/components/FeaturePanel/helpers/Subheading.tsx b/src/components/FeaturePanel/helpers/Subheading.tsx new file mode 100644 index 000000000..8c3b5f90c --- /dev/null +++ b/src/components/FeaturePanel/helpers/Subheading.tsx @@ -0,0 +1,8 @@ +import { Typography } from '@material-ui/core'; +import React from 'react'; + +export const Subheading = ({ children }) => ( + + {children} + +); diff --git a/src/components/FeaturePanel/renderers/PhoneRenderer.tsx b/src/components/FeaturePanel/renderers/PhoneRenderer.tsx index 9dfa49db8..6b4850be3 100644 --- a/src/components/FeaturePanel/renderers/PhoneRenderer.tsx +++ b/src/components/FeaturePanel/renderers/PhoneRenderer.tsx @@ -4,8 +4,14 @@ import LocalPhone from '@material-ui/icons/LocalPhone'; export const WebsiteRenderer = ({ v }) => ( <> - - {v} + + {v.split(';').map((v2, index) => ( + <> + {index === 0 ? '' : ', '} + {v2} + + ))} + ); diff --git a/src/components/FeaturePanel/renderers/WikidataRenderer.tsx b/src/components/FeaturePanel/renderers/WikidataRenderer.tsx new file mode 100644 index 000000000..c14731833 --- /dev/null +++ b/src/components/FeaturePanel/renderers/WikidataRenderer.tsx @@ -0,0 +1,10 @@ +import React from 'react'; +import { renderValue } from '../Properties/renderValue'; +import { WikipediaIcon } from '../../../assets/WikipediaIcon'; + +export const WikidataRenderer = ({ k, v }) => ( + <> + + {renderValue(k, v, true)} + +); diff --git a/src/components/FeaturePanel/renderers/WikipediaRenderer.tsx b/src/components/FeaturePanel/renderers/WikipediaRenderer.tsx new file mode 100644 index 000000000..ed5798496 --- /dev/null +++ b/src/components/FeaturePanel/renderers/WikipediaRenderer.tsx @@ -0,0 +1,10 @@ +import React from 'react'; +import { WikipediaIcon } from '../../../assets/WikipediaIcon'; +import { renderValue } from '../Properties/renderValue'; + +export const WikipediaRenderer = ({ k, v }) => ( + <> + + {renderValue(k, v)} + +); diff --git a/src/components/Map/behaviour/useOnMapClicked.tsx b/src/components/Map/behaviour/useOnMapClicked.tsx index 8c63cce87..5b3426898 100644 --- a/src/components/Map/behaviour/useOnMapClicked.tsx +++ b/src/components/Map/behaviour/useOnMapClicked.tsx @@ -6,7 +6,7 @@ import { getUrlOsmId, isSameOsmId, } from '../../../services/helpers'; -import { getRoundedPosition } from '../../../utils'; +import { getRoundedPosition, publishDbgObject } from '../../../utils'; import { getCenter } from '../../../services/getCenter'; import { convertMapIdToOsmId, getIsOsmObject } from '../helpers'; import { getCoordsFeature } from '../../../services/getCoordsFeature'; @@ -42,7 +42,8 @@ export const useOnMapClicked = useAddMapEvent( const skeleton = getSkeleton(features[0], coords); addFeatureCenterToCache(getShortId(skeleton.osmMeta), skeleton.center); // for ways/relations we dont receive center from OSM API - console.log(`clicked map feature (id=${features[0].id}): `, skeleton); // eslint-disable-line no-console + console.log(`clicked map feature (id=${features[0].id}): `, features[0]); // eslint-disable-line no-console + publishDbgObject('last skeleton', skeleton); if (skeleton.nonOsmObject) { const roundedPosition = getRoundedPosition(coords, map.getZoom()); diff --git a/src/helpers/TitleAndMetaTags.tsx b/src/helpers/TitleAndMetaTags.tsx index d38b284a8..725020082 100644 --- a/src/helpers/TitleAndMetaTags.tsx +++ b/src/helpers/TitleAndMetaTags.tsx @@ -27,7 +27,7 @@ export const OpenGraphTags = ({ const getTitle = (feature: Feature) => { const label = getLabel(feature); - return feature.error === 'deleted' ? getUtfStrikethrough(label) : label; + return feature.deleted ? getUtfStrikethrough(label) : label; }; export const TitleAndMetaTags = () => { diff --git a/src/locales/am.js b/src/locales/am.js index e443b970a..174c03bda 100644 --- a/src/locales/am.js +++ b/src/locales/am.js @@ -53,7 +53,7 @@ export default { 'featurepanel.error_network': 'ማምጣት አልቻልኩም, የመገናኛ መረብዎን ገመዶች ይመርምሩ', 'featurepanel.error_deleted': 'ይህ አካል በOpenStreetMap ላይ ተሰርዟል የሚል ምልክት ተደርጎበታል', 'featurepanel.history_button': 'ታሪኮች »', - 'featurepanel.other_info_heading': 'ተጨማሪ መረጃ', + 'featurepanel.details_heading': 'ተጨማሪ መረጃ', 'featurepanel.edit_button_title': 'በOpenStreetMap የመረጃ ቋት ውስጥ አርትእ', 'featurepanel.edit_button': 'ይህን አካባቢ አርትእ', 'featurepanel.add_place_button': 'አዲስ ቦታን ጨምር', diff --git a/src/locales/cs.js b/src/locales/cs.js index 0e1727d8d..e85b624da 100644 --- a/src/locales/cs.js +++ b/src/locales/cs.js @@ -6,6 +6,8 @@ export default { darkmode_auto: 'Tmavý režim: auto', darkmode_on: 'Tmavý režim: zap.', darkmode_off: 'Tmavý režim: vyp.', + show_more: 'Zobrazit více', + show_less: 'Zobrazit méně', 'install.button': 'Stáhnout aplikaci', 'install.tabs_aria_label': 'Vyberte si svou platformu', @@ -57,14 +59,17 @@ export default { 'featurepanel.error_deleted': 'Tento prvek je v OpenStreetMap označen jako smazaný.', 'featurepanel.info_no_tags': 'Tento prvek nemá žádné vlastnosti (tagy). Obvykle to znamená, že nese pouze geometrii/polohu pro nadřazený objekt.', 'featurepanel.history_button': 'Historie »', - 'featurepanel.other_info_heading': 'Další informace', + 'featurepanel.all_tags_heading': 'Tagy', + 'featurepanel.details_heading': 'Detaily', 'featurepanel.edit_button_title': 'Upravit v databázi OpenStreetMap', + 'featurepanel.note_button': 'Navrhnout úpravu', 'featurepanel.edit_button': 'Upravit místo', 'featurepanel.add_place_button': 'Přidat místo', 'featurepanel.undelete_button': 'Znovu přidat', 'featurepanel.feature_description_nonosm': 'Mapový prvek __type__', 'featurepanel.feature_description_osm': '__type__ v databázi OpenStreetMap', 'featurepanel.feature_description_point': 'Mapové souřadnice', + 'featurepanel.show_tags': 'Zobrazit tagy', 'featurepanel.show_objects_around': 'Zobrazit objekty v okolí', 'featurepanel.uncertain_image': 'Je zobrazena nejbližší fotka uliční úrovně. Může ukazovat jiný objekt.', 'featurepanel.inline_edit_title': 'Upravit', diff --git a/src/locales/de.js b/src/locales/de.js index bf3f0e9b0..b2b4d971c 100644 --- a/src/locales/de.js +++ b/src/locales/de.js @@ -54,7 +54,7 @@ export default { 'featurepanel.error_network': 'Kann das Objekt nicht abrufen, bitte überprüfe die Netzwerkverbindung.', 'featurepanel.error_deleted': 'Das Objekt wurde in OpenStreetMap als gelöscht markiert.', 'featurepanel.history_button': 'Versionsverlauf »', - 'featurepanel.other_info_heading': 'Weitere Informationen', + 'featurepanel.details_heading': 'Weitere Informationen', 'featurepanel.edit_button_title': 'In OpenStreetMap Datenbank bearbeiten', 'featurepanel.edit_button': 'Ort bearbeiten', 'featurepanel.add_place_button': 'Ort hinzufügen', diff --git a/src/locales/es.js b/src/locales/es.js index 8ee8a290d..989113769 100644 --- a/src/locales/es.js +++ b/src/locales/es.js @@ -54,7 +54,7 @@ export default { 'featurepanel.error_network': 'No es posible obtener, comprueba tu cable de red.', 'featurepanel.error_deleted': 'Este objeto está marcado como borrado en OpenStreetMap.', 'featurepanel.history_button': 'Historia »', - 'featurepanel.other_info_heading': 'Más información', + 'featurepanel.details_heading': 'Más información', 'featurepanel.edit_button_title': 'Editar en la base de datos de OpenStreetMap', 'featurepanel.edit_button': 'Editar lugar', 'featurepanel.add_place_button': 'Añadir lugar', diff --git a/src/locales/fr.js b/src/locales/fr.js index 5f040f919..2a2b2364f 100644 --- a/src/locales/fr.js +++ b/src/locales/fr.js @@ -61,7 +61,7 @@ export default { 'featurepanel.error_network': 'Requête impossible, veuillez vérifier votre connexion.', 'featurepanel.error_deleted': 'Cet élément n’existe plus sur OpenStreetMap.', 'featurepanel.history_button': 'Historique»', - 'featurepanel.other_info_heading': 'Plus d’informations', + 'featurepanel.details_heading': 'Plus d’informations', 'featurepanel.edit_button_title': 'Modifier sur OpenStreetMap', 'featurepanel.edit_button': 'Modifier l’élément', 'featurepanel.add_place_button': 'Ajouter un élément', diff --git a/src/locales/it.js b/src/locales/it.js index c49c56e6e..81e1374ca 100644 --- a/src/locales/it.js +++ b/src/locales/it.js @@ -54,7 +54,7 @@ export default { 'featurepanel.error_network': 'Impossibile recuperare l’elemento, controlla il tuo cavo di rete.', 'featurepanel.error_deleted': 'Questo oggetto è segnato come eliminato su OpenStreetMap.', 'featurepanel.history_button': 'Cronologia »', - 'featurepanel.other_info_heading': 'Altre informationi', + 'featurepanel.details_heading': 'Altre informationi', 'featurepanel.edit_button_title': 'Modifica nel database OpenStreetMap', 'featurepanel.edit_button': 'Modifica luogo', 'featurepanel.add_place_button': 'Aggiungi luogo', diff --git a/src/locales/pl.js b/src/locales/pl.js index e9e6ef96b..29f1e3967 100644 --- a/src/locales/pl.js +++ b/src/locales/pl.js @@ -54,7 +54,7 @@ export default { 'featurepanel.error_network': 'Nie można uzyskać tej funkcji, sprawdź połączenie sieciowe.', 'featurepanel.error_deleted': 'Ten obiekt jest oznaczony jako usunięty w OpenStreetMap.', 'featurepanel.history_button': 'Historia »', - 'featurepanel.other_info_heading': 'Więcej informacji', + 'featurepanel.details_heading': 'Więcej informacji', 'featurepanel.edit_button_title': 'Edytuj w bazie danych OpenStreetMap', 'featurepanel.edit_button': 'Edytuj miejsce', 'featurepanel.add_place_button': 'Dodaj miejsce', diff --git a/src/locales/vocabulary.js b/src/locales/vocabulary.js index 0bd407435..c56c8f0dc 100644 --- a/src/locales/vocabulary.js +++ b/src/locales/vocabulary.js @@ -11,6 +11,8 @@ export default { darkmode_auto: 'Dark mode: auto', darkmode_on: 'Dark mode: on', darkmode_off: 'Dark mode: off', + show_more: 'Show more', + show_less: 'Show less', 'install.button': 'Install app', 'install.tabs_aria_label': 'Choose your platform', @@ -64,7 +66,8 @@ export default { 'featurepanel.error_deleted': 'This object is marked as deleted in OpenStreetMap.', 'featurepanel.info_no_tags': 'This object has no tags. Usually it means that it only carries geometry/location for a parent object.', 'featurepanel.history_button': 'History »', - 'featurepanel.other_info_heading': 'Details', + 'featurepanel.details_heading': 'Details', + 'featurepanel.all_tags_heading': 'All tags', 'featurepanel.edit_button_title': 'Edit in OpenStreetMap database', 'featurepanel.note_button': 'Suggest an edit', 'featurepanel.edit_button': 'Edit details', @@ -73,6 +76,7 @@ export default { 'featurepanel.feature_description_nonosm': 'Map feature __type__', 'featurepanel.feature_description_osm': '__type__ in OpenStreetMap database', 'featurepanel.feature_description_point': 'Map coordinates', + 'featurepanel.show_tags': 'Show tags', 'featurepanel.show_objects_around': 'Show nearby objects', 'featurepanel.uncertain_image': 'This is the closest street view image from Mapillary. It may be inaccurate.', 'featurepanel.inline_edit_title': 'Edit', diff --git a/src/services/__tests__/osmApi.test.ts b/src/services/__tests__/osmApi.test.ts index 105a7ead2..70f28bb73 100644 --- a/src/services/__tests__/osmApi.test.ts +++ b/src/services/__tests__/osmApi.test.ts @@ -31,8 +31,8 @@ describe('fetchFeature', () => { jest.clearAllMocks(); jest.spyOn(tagging, 'fetchSchemaTranslations').mockResolvedValue(undefined); jest - .spyOn(idTaggingScheme, 'getSchemaForFeature') - .mockReturnValue(undefined); // this is covered in idTaggingScheme.test.ts + .spyOn(idTaggingScheme, 'addSchemaToFeature') + .mockImplementation((f) => f); // this is covered in idTaggingScheme.test.ts }); const isServer = jest.spyOn(helpers, 'isServer').mockReturnValue(true); diff --git a/src/services/osmApi.ts b/src/services/osmApi.ts index 90c047ebc..291490dff 100644 --- a/src/services/osmApi.ts +++ b/src/services/osmApi.ts @@ -5,7 +5,7 @@ import { removeFetchCache } from './fetchCache'; import { overpassAroundToSkeletons } from './overpassAroundToSkeletons'; import { getPoiClass } from './getPoiClass'; import { isBrowser } from '../components/helpers'; -import { getSchemaForFeature } from './tagging/idTaggingScheme'; +import { addSchemaToFeature } from './tagging/idTaggingScheme'; import { fetchSchemaTranslations } from './tagging/translations'; const getOsmUrl = ({ type, id }) => @@ -93,7 +93,7 @@ const osmToFeature = (element): Feature => { tags, members, properties: getPoiClass(tags), - error: osmappDeletedMarker ? 'deleted' : undefined, + deleted: osmappDeletedMarker, }; }; @@ -115,9 +115,7 @@ export const fetchFeature = async (shortId): Promise => { feature.center = center; } - const schema = getSchemaForFeature(feature); // TODO forward lang here ?? maybe full intl? - console.log('schema', schema); // eslint-disable-line no-console - return { ...feature, schema }; + return addSchemaToFeature(feature); } catch (e) { console.error(`fetchFeature(${shortId}):`, e); // eslint-disable-line no-console diff --git a/src/services/osmApiAuth.ts b/src/services/osmApiAuth.ts index 5840de776..1f2a19927 100644 --- a/src/services/osmApiAuth.ts +++ b/src/services/osmApiAuth.ts @@ -167,9 +167,9 @@ const getItemOrLastHistoric = async (apiId: OsmApiId) => { } }; -const getDescription = (isDelete, feature) => { - const undelete = feature.error === 'deleted'; - const action = undelete ? 'Undeleted' : isDelete ? 'Deleted' : 'Edited'; +const getDescription = (isCancelled, feature) => { + const undelete = feature.deleted; + const action = undelete ? 'Undeleted' : isCancelled ? 'Deleted' : 'Edited'; const { subclass } = feature.properties; const name = feature.tags.name || subclass || getUrlOsmId(feature.osmMeta); return `${action} ${name}`; @@ -177,10 +177,10 @@ const getDescription = (isDelete, feature) => { const getChangesetComment = ( comment: string, - isDelete: boolean, + isCancelled: boolean, feature: Feature, ) => { - const description = getDescription(isDelete, feature); + const description = getDescription(isCancelled, feature); return join(comment, ' • ', `${description} #osmapp`); }; @@ -208,10 +208,10 @@ export const editOsmFeature = async ( feature: Feature, comment: string, newTags: FeatureTags, - isDelete: boolean, + isCancelled: boolean, ) => { const apiId = prod ? feature.osmMeta : TEST_OSM_ID; - const changesetComment = getChangesetComment(comment, isDelete, feature); + const changesetComment = getChangesetComment(comment, isCancelled, feature); const changesetXml = getChangesetXml({ changesetComment, feature }); const changesetId = await putChangeset(changesetXml); @@ -224,10 +224,10 @@ export const editOsmFeature = async ( apiId, changesetId, newTags, - isDelete, + isCancelled, ); - await putOrDeleteItem(isDelete, apiId, newItem); + await putOrDeleteItem(isCancelled, apiId, newItem); await putChangesetClose(changesetId); clearFeatureCache(feature.osmMeta); diff --git a/src/services/tagging/__tests__/idTaggingScheme.test.ts b/src/services/tagging/__tests__/idTaggingScheme.test.ts index 943b9cbe1..235f9d20c 100644 --- a/src/services/tagging/__tests__/idTaggingScheme.test.ts +++ b/src/services/tagging/__tests__/idTaggingScheme.test.ts @@ -3,6 +3,7 @@ import { getSchemaForFeature } from '../idTaggingScheme'; import { Feature } from '../../types'; import { mockSchemaTranslations } from '../translations'; import { intl } from '../../intl'; +import { computeAllFieldKeys } from '../fields'; intl.lang = 'en'; @@ -10,33 +11,36 @@ jest.mock('next/config', () => () => ({ publicRuntimeConfig: { languages: ['en'] }, })); -const feature = { - osmMeta: { type: 'way' }, - tags: { - bicycle: 'no', - bridge: 'yes', - foot: 'no', - hgv: 'designated', - highway: 'motorway', - horse: 'no', - lanes: '2', - layer: '1', - lit: 'no', - maxspeed: '55 mph', - oneway: 'yes', - ref: 'I 84', - surface: 'asphalt', - 'tiger:cfcc': 'A15', - 'tiger:county': 'Orange, NY', - 'tiger:name_base': 'I-84', - }, -} as unknown as Feature; - describe('idTaggingScheme', () => { - it('should multiple access', () => { + beforeEach(() => { mockSchemaTranslations(translations); + }); + + it('should multiple access', () => { + const feature = { + osmMeta: { type: 'way' }, + tags: { + bicycle: 'no', + bridge: 'yes', + foot: 'no', + hgv: 'designated', + highway: 'motorway', + horse: 'no', + lanes: '2', + layer: '1', + lit: 'no', + maxspeed: '55 mph', + oneway: 'yes', + ref: 'I 84', + surface: 'asphalt', + 'tiger:cfcc': 'A15', + 'tiger:county': 'Orange, NY', + 'tiger:name_base': 'I-84', + }, + } as unknown as Feature; const result = getSchemaForFeature(feature); + expect(result.label).toBe('Motorway'); expect(result.presetKey).toBe('highway/motorway'); expect(result.matchedFields).toMatchObject([ @@ -61,4 +65,106 @@ describe('idTaggingScheme', () => { 'tiger:name_base', ]); }); + + it('should use @template field', () => { + const featureWithTemplate = { + osmMeta: { type: 'way' }, + tags: { amenity: 'school' }, + } as unknown as Feature; + + const schema = getSchemaForFeature(featureWithTemplate); + const computedAllFieldKeys = computeAllFieldKeys(schema.preset); + + expect(computedAllFieldKeys).toEqual([ + 'amenity', + 'name', + 'operator', + 'operator/type', + 'address', + 'grades', + 'religion', + 'denomination', + 'website', + 'building_area', + 'email', + 'fax', + 'mobile', + 'phone', + 'internet_access', + 'internet_access/fee', + 'internet_access/ssid', + 'capacity', + 'charge_fee', + 'fee', + 'gnis/feature_id-US', + 'level', + 'polling_station', + 'wheelchair', + 'wikimedia_commons', + 'wikidata', + 'start_date', + 'note', + 'mapillary', + 'fixme', + 'ele_node', + 'description', + 'ref/linz/place_id-NZ', + 'architect', + ]); + }); + + it('should map all tags to fields', () => { + const feature = { + osmMeta: { + type: 'way', + id: 149398903, + }, + tags: { + amenity: 'fountain', + natural: 'water', + source: 'CZ:IPRPraha:ortofoto', + water: 'fountain', + wikidata: 'Q94435643', + wikimedia_commons: 'Category:Fountain (metro Malostranská)', + }, + } as unknown as Feature; + + const schema = getSchemaForFeature(feature); + + expect(schema.label).toBe('Fountain'); + expect(schema.featuredTags).toEqual([['wikidata', 'Q94435643']]); + expect(schema.matchedFields.map((x: any) => x.field.fieldKey)).toEqual([ + 'wikimedia_commons', + ]); + expect(schema.tagsWithFields.map((x: any) => x.field.fieldKey)).toEqual([ + 'source', + 'water', + ]); + expect(schema.keysTodo).toEqual(['natural']); + }); + + it('should remove from keysTodo if address is in restTags', () => { + // TOOD find better tags which have some multikey field in tagsWithFields + const feature = { + osmMeta: { + type: 'way', + id: 149398903, + }, + tags: { + 'addr:city': 'Brno', + 'addr:country': 'CZ', + historic: 'city_gate', + source: 'cuzk:km', + tourism: 'museum', + asdf: 'asdf', + }, + } as unknown as Feature; + + const schema = getSchemaForFeature(feature); + + expect(schema.presetKey).toEqual('historic/city_gate'); + expect(schema.tagsWithFields.map((x: any) => x.field.fieldKey)).toEqual([ + 'source', + ]); + }); }); diff --git a/src/services/tagging/fields.ts b/src/services/tagging/fields.ts index bd5310330..2015f0c3c 100644 --- a/src/services/tagging/fields.ts +++ b/src/services/tagging/fields.ts @@ -1,12 +1,21 @@ // links like {shop}, are recursively resolved to their fields import { Preset } from './types/Presets'; -import { presets } from './data'; +import { fields, presets } from './data'; const getResolvedFields = (fieldKeys: string[]): string[] => fieldKeys.flatMap((key) => { if (key.match(/^{.*}$/)) { const presetKey = key.substr(1, key.length - 2); - return getResolvedFields(presets[presetKey].fields); // TODO does "{shop}" links to preset's fields or moreFields? + return getResolvedFields(presets[presetKey].fields); + } + return key; + }); + +const getResolvedMoreFields = (fieldKeys: string[]): string[] => + fieldKeys.flatMap((key) => { + if (key.match(/^{.*}$/)) { + const presetKey = key.substr(1, key.length - 2); + return getResolvedMoreFields(presets[presetKey].moreFields); } return key; }); @@ -34,8 +43,19 @@ const getResolvedFieldsWithParents = ( export const computeAllFieldKeys = (preset: Preset) => { const allFieldKeys = [ ...getResolvedFields(getResolvedFieldsWithParents(preset, 'fields')), - ...getResolvedFields(getResolvedFieldsWithParents(preset, 'moreFields')), - ]; + ...getResolvedMoreFields( + getResolvedFieldsWithParents(preset, 'moreFields'), + ), + ...Object.values(fields) + .filter((f) => f.universal) + .map((f) => f.fieldKey), + 'operator', + 'architect', + 'address', + ] + .filter((f) => f !== 'wikipedia') // already covered in featuredKeys + .filter((f) => f !== 'image') // already covered in feature image + .filter((f) => f !== 'source' && f !== 'check_date'); // lets leave these to tagsWithFields // @ts-ignore return [...new Set(allFieldKeys)]; diff --git a/src/services/tagging/idTaggingScheme.ts b/src/services/tagging/idTaggingScheme.ts index 22ddf69c5..625a4aba4 100644 --- a/src/services/tagging/idTaggingScheme.ts +++ b/src/services/tagging/idTaggingScheme.ts @@ -1,28 +1,68 @@ -import { Feature } from '../types'; +import { Feature, FeatureTags } from '../types'; import { getFieldTranslation, getPresetTranslation } from './translations'; import { getPresetForFeature } from './presets'; import { fields } from './data'; import { computeAllFieldKeys, getValueForField } from './fields'; -import { Preset } from './types/Presets'; +import { Preset, UiField } from './types/Presets'; import { publishDbgObject } from '../../utils'; +import { getShortId } from '../helpers'; +import { Field } from './types/Fields'; + +const logMoreMatchingFields = (matchingFields: Field[], key: string) => { + if (matchingFields.length > 1) { + // eslint-disable-next-line no-console + console.warn( + `More fields matching key ${key}: ${matchingFields.map( + (f) => f.fieldKey, + )}`, + ); + } +}; + +const deduplicate = (strings: string[]) => Array.from(new Set(strings)); + +const getUiField = ( + field: Field, + keysTodo: KeysTodo, + feature: Feature, + key: string, +): UiField => { + if (field.type === 'typeCombo') { + keysTodo.remove(field.key); // ignores eg. railway=tram_stop on public_transport=stop_position + return undefined; + } + + const value = feature.tags[key]; + + const keysInField = deduplicate([ + ...(field.keys ?? []), + ...(field.key ? [field.key] : []), + ]); + const tagsForField = []; + keysInField.forEach((k) => { + if (feature.tags[k]) { + tagsForField.push({ key: k, value: feature.tags[k] }); + } + keysTodo.remove(k); // remove all "address:*" keys etc. + }); + + const fieldTranslation = getFieldTranslation(field); -// TODO move to shared place -const featuredKeys = [ - 'name', // this is not in the other place - 'website', - 'contact:website', - 'phone', - 'contact:phone', - 'contact:mobile', - 'opening_hours', - 'description', -]; + return { + key, + value: getValueForField(field, fieldTranslation, value, tagsForField), // TODO this may be removed + label: fieldTranslation?.label ?? field.label ?? `[${key}]`, + tagsForField, + field, + fieldTranslation, + }; +}; const matchFieldsFromPreset = ( preset: Preset, keysTodo: any, feature: Feature, -) => { +): UiField[] => { const computedAllFieldKeys = computeAllFieldKeys(preset); publishDbgObject('computedAllFieldKeys', computedAllFieldKeys); @@ -31,96 +71,42 @@ const matchFieldsFromPreset = ( const field = fields[fieldKey]; const key = field?.key; const keys = field?.keys; - const shouldWeIncludeThisField = - keysTodo.has(key) || keysTodo.hasAny(keys); - if (!shouldWeIncludeThisField) { - return {}; - } - if (field.type === 'typeCombo') { - keysTodo.remove(field.key); // ignore eg. railway=tram_stop on public_transport=stop_position - return {}; + const includeThisField = keysTodo.has(key) || keysTodo.hasAny(keys); + + if (!includeThisField) { + return undefined; } - const value = feature.tags[key]; - - const keysInField = [ - ...(field.keys ?? []), - ...(field.key ? [field.key] : []), - ]; - const tagsForField = []; - keysInField.forEach((k) => { - if (feature.tags[k]) { - tagsForField.push({ key: k, value: feature.tags[k] }); - } - keysTodo.remove(k); // remove all "address:*" keys etc. - }); - - const fieldTranslation = getFieldTranslation(field); - - return { - key, - value: getValueForField(field, fieldTranslation, value, tagsForField), - field, - tagsForField, - fieldTranslation, - label: fieldTranslation?.label ?? field.label, - }; + return getUiField(field, keysTodo, feature, key); }) - .filter((field) => field.value); + .filter((field) => field?.value); }; -const matchRestToFields = (keysTodo: any, feature: Feature) => - keysTodo - .map((key) => { - const field = Object.values(fields).find( - (f) => f.key === key || f.keys?.includes(key), - ); // todo cache this - if (!field) { - return {}; - } - if (field.type === 'typeCombo') { - keysTodo.remove(field.key); // ignore eg. railway=tram_stop on public_transport=stop_position - return {}; - } +const matchRestToFields = (keysTodo: KeysTodo, feature: Feature): UiField[] => + keysTodo.mapOrSkip((key) => { + const matchingFields = Object.values(fields).filter( + (f) => f.key === key || f.keys?.includes(key), // todo cache this + ); + logMoreMatchingFields(matchingFields, key); - const value = feature.tags[key]; - - const keysInField = [ - ...(field.keys ?? []), - ...(field.key ? [field.key] : []), - ]; - const tagsForField = []; - keysInField.forEach((k) => { - if (feature.tags[k]) { - tagsForField.push({ key: k, value: feature.tags[k] }); - } - keysTodo.remove(k); // remove all "address:*" keys etc. - }); - - const fieldTranslation = getFieldTranslation(field); - - return { - key, - value: getValueForField(field, fieldTranslation, value, tagsForField), - field, - tagsForField, - fieldTranslation, - label: fieldTranslation?.label ?? field.label ?? `[${key}]`, - }; - }) - .filter((field) => field.field); + // if more fields are matching, select the one which has fieldKey equal key + const field = + matchingFields.find((f) => f.fieldKey === key) ?? matchingFields?.[0]; + + if (!field) { + return undefined; + } + return getUiField(field, keysTodo, feature, key); + }); +type KeysTodo = typeof keysTodo; const keysTodo = { - state: [], + state: [] as string[], init(feature) { - this.state = Object.keys(feature.tags).filter( - (key) => !featuredKeys.includes(key), - ); + this.state = Object.keys(feature.tags); }, - resolve(tags) { - Object.keys(tags).forEach((key) => { - this.state.splice(this.state.indexOf(key), 1); - }); + resolveTags(tags) { + Object.keys(tags).forEach((key) => this.remove(key)); }, has(key) { return this.state.includes(key); @@ -144,16 +130,56 @@ const keysTodo = { } }); }, - map(fn) { - return this.state.map(fn); + mapOrSkip(fn: (key: string) => T): NonNullable[] { + const skippedFields = []; + const output = []; + + while (this.state.length) { + const field = this.state.shift(); + const result = fn(field); // this can remove items from this.state + if (result) { + output.push(result); + } else { + skippedFields.push(field); + } + } + + this.state = skippedFields; + return output; }, }; +const getFeaturedTags = (feature: Feature) => { + const { tags } = feature; + + // more ideas in here, run in browser: Object.values(dbg.fields).filter(f=>f.universal) + const keys = [ + 'website', + 'contact:website', + 'phone', + 'contact:phone', + 'contact:mobile', + 'opening_hours', + ...(tags.wikipedia ? ['wikipedia'] : tags.wikidata ? ['wikidata'] : []), + 'fhrs:id', + 'description', + ]; + + return keys.reduce( + (acc, key) => (tags[key] ? { ...acc, [key]: tags[key] } : acc), + {} as FeatureTags, + ); +}; + export const getSchemaForFeature = (feature: Feature) => { const preset = getPresetForFeature(feature); keysTodo.init(feature); - keysTodo.resolve(preset.tags); // remove tags which are already covered by Preset keys + keysTodo.resolveTags(preset.tags); // remove tags which are already covered by Preset + keysTodo.remove('name'); // always rendered by FeaturePanel + + const featuredTags = feature.deleted ? [] : getFeaturedTags(feature); + keysTodo.resolveTags(featuredTags); const matchedFields = matchFieldsFromPreset(preset, keysTodo, feature); keysTodo.resolveFields(matchedFields); @@ -161,14 +187,26 @@ export const getSchemaForFeature = (feature: Feature) => { const tagsWithFields = matchRestToFields(keysTodo, feature); keysTodo.resolveFields(tagsWithFields); - // TODO fix one field with more tags! like address return { presetKey: preset.presetKey, preset, - feature, label: getPresetTranslation(preset.presetKey), + featuredTags: Object.entries(featuredTags), matchedFields, tagsWithFields, keysTodo: keysTodo.state, }; }; + +export const addSchemaToFeature = (feature: Feature) => { + let schema; + try { + schema = getSchemaForFeature(feature); // TODO forward lang here ?? maybe full intl? + } catch (e) { + // TODO sentry + console.error(`getSchemaForFeature(${getShortId(feature.osmMeta)}):`, e); // eslint-disable-line no-console + return feature; + } + + return { ...feature, schema }; +}; diff --git a/src/services/tagging/presets.ts b/src/services/tagging/presets.ts index b1ce93f9f..37b665759 100644 --- a/src/services/tagging/presets.ts +++ b/src/services/tagging/presets.ts @@ -3,6 +3,7 @@ import { Feature } from '../types'; import { Preset } from './types/Presets'; // taken from iD codebase https://github.com/openstreetmap/iD/blob/dd30a39d7487e1084396712ce861f4b6c5a07849/modules/presets/preset.js#L61 +// added code for addr:* matching // _this is "preset" object with originalScore set const matchScore = (_this, entityTags) => { /* eslint-disable no-restricted-syntax,guard-for-in */ @@ -10,11 +11,18 @@ const matchScore = (_this, entityTags) => { const seen = {}; let score = 0; + const entityKeys = Object.keys(entityTags); + // match on tags for (const k in tags) { seen[k] = true; if (entityTags[k] === tags[k]) { score += _this.originalScore; + } else if ( + k === 'addr:*' && + entityKeys.some((key) => key.startsWith('addr:')) + ) { + score += _this.originalScore; } else if (tags[k] === '*' && k in entityTags) { score += _this.originalScore / 2; } else { @@ -81,5 +89,20 @@ export const getPresetForFeature = (feature: Feature): Preset => { } }); - return candidates.sort((a, b) => b.score - a.score)[0].candidate; + // iD editor has index by keys, which is sorted by alphabet. So amenities (eg.amenity=fountain) is sooner than natural=water .. LOL + const sortedByKey = candidates.sort((a, b) => + Object.keys(a.candidate.tags)?.[0]?.localeCompare( + Object.keys(b.candidate.tags)?.[0], + ), + ); + const sortedByScore = sortedByKey.sort((a, b) => b.score - a.score); + const winner = sortedByScore[0]; + + const winners = sortedByScore.filter((c) => c.score === winner.score); + if (winners.length > 1) { + // eslint-disable-next-line no-console + console.info('This feature matches more presets by same score:', winners); + } + + return winner.candidate; }; diff --git a/src/services/tagging/translations.ts b/src/services/tagging/translations.ts index 7cce21eb6..628952611 100644 --- a/src/services/tagging/translations.ts +++ b/src/services/tagging/translations.ts @@ -2,6 +2,7 @@ import { fetchJson } from '../fetch'; import { Field } from './types/Fields'; import { intl } from '../intl'; import { publishDbgObject } from '../../utils'; +import { FieldTranslation } from './types/Presets'; // https://cdn.jsdelivr.net/npm/@openstreetmap/id-tagging-schema@6.1.0/dist/translations/en.min.json const cdnUrl = `https://cdn.jsdelivr.net/npm/@openstreetmap/id-tagging-schema`; @@ -25,17 +26,17 @@ export const mockSchemaTranslations = (mockTranslations) => { translations = mockTranslations; }; -export const getPresetTranslation = (key: string) => - translations?.[intl.lang]?.presets?.presets?.[key]?.name; +export const getPresetTranslation = (key: string): string => + translations?.[intl.lang]?.presets?.presets?.[key]?.name ?? `[${key}]`; export const getPresetTermsTranslation = (key: string) => translations?.[intl.lang]?.presets?.presets?.[key]?.terms; -export const getFieldTranslation = (field: Field) => { +export const getFieldTranslation = (field: Field): FieldTranslation => { if (!translations) return undefined; if (field.label?.match(/^{.*}$/)) { - const resolved = field.label.substr(1, field.label.length - 2); + const resolved = field.label.substring(1, field.label.length - 1); return translations[intl.lang].presets.fields[resolved]; } diff --git a/src/services/tagging/types/Fields.ts b/src/services/tagging/types/Fields.ts index 38fd9add6..4251c4b8c 100644 --- a/src/services/tagging/types/Fields.ts +++ b/src/services/tagging/types/Fields.ts @@ -41,10 +41,12 @@ export type Field = { /** * Tag key whose value is to be displayed + * https://github.com/ideditor/schema-builder#keykeys */ key?: string; /** * Tag keys whose value is to be displayed + * https://github.com/ideditor/schema-builder#keykeys */ keys?: string[]; /** diff --git a/src/services/tagging/types/Presets.ts b/src/services/tagging/types/Presets.ts index a96788694..0141d8fb3 100644 --- a/src/services/tagging/types/Presets.ts +++ b/src/services/tagging/types/Presets.ts @@ -1,3 +1,5 @@ +import { Field } from './Fields'; + /** * Associates an icon, form fields, and other UI with a set of OSM tags */ @@ -95,3 +97,24 @@ export interface Preset { export type Presets = { [presetKey: string]: Preset; }; + +export type FieldTranslation = { + label: string; + placeholder: string; + terms: string; + options: { + [key: string]: { title: string; description: string }; + }; + types: { + [key: string]: string; + }; +}; + +export interface UiField { + key: string; + value: string; + label: string; + tagsForField: Array<{ key: string; value: string }>; + fieldTranslation?: FieldTranslation; + field: Field; // debug only +} diff --git a/src/services/types.ts b/src/services/types.ts index 294218366..fd5abe26f 100644 --- a/src/services/types.ts +++ b/src/services/types.ts @@ -74,8 +74,9 @@ export interface Feature { center: Position; roundedCenter?: LonLatRounded; ssrFeatureImage?: Image; - error?: 'deleted' | 'network' | 'unknown' | '404' | '500'; // etc. - schema?: ReturnType; + error?: 'network' | 'unknown' | '404' | '500'; // etc. + deleted?: boolean; + schema?: ReturnType; // undefined means error // skeleton layer?: { id: string }; diff --git a/src/utils.ts b/src/utils.ts index ab1d7f39c..8cb0139ff 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -60,5 +60,9 @@ export const publishDbgObject = (key, value) => { if (!window.dbg) window.dbg = {}; // @ts-ignore window.dbg[key] = value; + // @ts-ignore + if (!window.d) window.d = {}; + // @ts-ignore + window.d[key] = value; } }; From b8a14c2cc69db9f76d685e02b27608f982567bbc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Thu, 2 Nov 2023 20:56:06 +0100 Subject: [PATCH 28/35] general: allow unused _ variable --- .eslintrc.js | 8 ++++++++ .../FeaturePanel/renderers/OpeningHoursRenderer.tsx | 2 +- src/components/SearchBox/AutocompleteInput.tsx | 3 +-- src/services/osmApi.ts | 1 - 4 files changed, 10 insertions(+), 4 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index 586633ece..395e4e03c 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -34,5 +34,13 @@ module.exports = { 'react/require-default-props': OFF, 'no-nested-ternary': OFF, 'no-irregular-whitespace': OFF, + '@typescript-eslint/no-unused-vars': [ + 'error', + { + argsIgnorePattern: '^_', + varsIgnorePattern: '^_', + caughtErrorsIgnorePattern: '^_', + }, + ], }, }; diff --git a/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx b/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx index 7d5449b3a..6c713ed3b 100644 --- a/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx +++ b/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx @@ -61,7 +61,7 @@ const formatDescription = (isOpen: boolean, days: SimpleOpeningHoursTable) => { const OpeningHoursRenderer = ({ v }) => { const [isExpanded, toggle] = useToggleState(false); const { daysTable, isOpen } = parseOpeningHours(v); - const { ph, ...days } = daysTable; + const { ph, ...days } = daysTable; // eslint-disable-line @typescript-eslint/no-unused-vars const timesByDay = Object.values(days).map((times, idx) => ({ times, day: weekDays[idx], diff --git a/src/components/SearchBox/AutocompleteInput.tsx b/src/components/SearchBox/AutocompleteInput.tsx index b95aa17ca..5bb2b0d61 100644 --- a/src/components/SearchBox/AutocompleteInput.tsx +++ b/src/components/SearchBox/AutocompleteInput.tsx @@ -31,7 +31,6 @@ const useFocusOnSlash = () => { const SearchBoxInput = ({ params, setInputValue, autocompleteRef }) => { const inputRef = useFocusOnSlash(); - const { InputLabelProps, InputProps, ...restParams } = params; useEffect(() => { // @ts-ignore @@ -43,7 +42,7 @@ const SearchBoxInput = ({ params, setInputValue, autocompleteRef }) => { return ( { tags = {}, lat, lon, - nodes, members, osmappDeletedMarker, ...osmMeta From 790c91f751bed5faa16c6b0016e702e8d19a2446 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Thu, 2 Nov 2023 21:10:10 +0100 Subject: [PATCH 29/35] Revert "general: allow unused _ variable" This reverts commit b8a14c2c --- .eslintrc.js | 8 -------- .../FeaturePanel/renderers/OpeningHoursRenderer.tsx | 2 +- src/components/SearchBox/AutocompleteInput.tsx | 3 ++- src/services/osmApi.ts | 1 + 4 files changed, 4 insertions(+), 10 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index 395e4e03c..586633ece 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -34,13 +34,5 @@ module.exports = { 'react/require-default-props': OFF, 'no-nested-ternary': OFF, 'no-irregular-whitespace': OFF, - '@typescript-eslint/no-unused-vars': [ - 'error', - { - argsIgnorePattern: '^_', - varsIgnorePattern: '^_', - caughtErrorsIgnorePattern: '^_', - }, - ], }, }; diff --git a/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx b/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx index 6c713ed3b..7d5449b3a 100644 --- a/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx +++ b/src/components/FeaturePanel/renderers/OpeningHoursRenderer.tsx @@ -61,7 +61,7 @@ const formatDescription = (isOpen: boolean, days: SimpleOpeningHoursTable) => { const OpeningHoursRenderer = ({ v }) => { const [isExpanded, toggle] = useToggleState(false); const { daysTable, isOpen } = parseOpeningHours(v); - const { ph, ...days } = daysTable; // eslint-disable-line @typescript-eslint/no-unused-vars + const { ph, ...days } = daysTable; const timesByDay = Object.values(days).map((times, idx) => ({ times, day: weekDays[idx], diff --git a/src/components/SearchBox/AutocompleteInput.tsx b/src/components/SearchBox/AutocompleteInput.tsx index 5bb2b0d61..b95aa17ca 100644 --- a/src/components/SearchBox/AutocompleteInput.tsx +++ b/src/components/SearchBox/AutocompleteInput.tsx @@ -31,6 +31,7 @@ const useFocusOnSlash = () => { const SearchBoxInput = ({ params, setInputValue, autocompleteRef }) => { const inputRef = useFocusOnSlash(); + const { InputLabelProps, InputProps, ...restParams } = params; useEffect(() => { // @ts-ignore @@ -42,7 +43,7 @@ const SearchBoxInput = ({ params, setInputValue, autocompleteRef }) => { return ( { tags = {}, lat, lon, + nodes, members, osmappDeletedMarker, ...osmMeta From 8a07d490c422c86e3bb34e4ffc7bc8670631cf46 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Fri, 3 Nov 2023 07:40:59 +0100 Subject: [PATCH 30/35] layers: add OpenPlaceGuide Africa - makina maps (#205) --- .../LayerSwitcher/LayerSwitcherContent.tsx | 27 ++++++++++++------- src/components/LayerSwitcher/osmappLayers.tsx | 9 +++++++ .../Map/behaviour/useUpdateStyle.tsx | 23 ++++++++++++---- .../Map/styles/makinaAfricaStyle.ts | 23 ++++++++++++++++ src/locales/vocabulary.js | 1 + 5 files changed, 68 insertions(+), 15 deletions(-) create mode 100644 src/components/Map/styles/makinaAfricaStyle.ts diff --git a/src/components/LayerSwitcher/LayerSwitcherContent.tsx b/src/components/LayerSwitcher/LayerSwitcherContent.tsx index b5802358b..00632a81b 100644 --- a/src/components/LayerSwitcher/LayerSwitcherContent.tsx +++ b/src/components/LayerSwitcher/LayerSwitcherContent.tsx @@ -13,8 +13,9 @@ import { RemoveUserLayerAction, } from './helpers'; import { osmappLayers } from './osmappLayers'; -import { Layer, useMapStateContext } from '../utils/MapStateContext'; +import { Layer, useMapStateContext, View } from '../utils/MapStateContext'; import { usePersistedState } from '../utils/usePersistedState'; +import { isViewInsideAfrica } from '../Map/styles/makinaAfricaStyle'; const StyledList = styled(List)` .MuiListItemIcon-root { @@ -36,14 +37,16 @@ const Spacer = styled.div` padding-bottom: 1.5em; `; -const getAllLayers = (userLayers: Layer[]): Layer[] => { - const spacer = { type: 'spacer' as const, key: 'userSpacer' }; +const getAllLayers = (userLayers: Layer[], view: View): Layer[] => { + const spacer: Layer = { type: 'spacer' as const, key: 'userSpacer' }; + const toLayer = ([key, layer]) => ({ ...layer, key }); + + // eslint-disable-next-line @typescript-eslint/no-unused-vars + const filterMakina = ([key, _]) => + key === 'makinaAfrica' ? isViewInsideAfrica(view) : true; // needs suppressHydrationWarning return [ - ...Object.entries(osmappLayers).map(([key, layer]) => ({ - ...layer, - key, - })), + ...Object.entries(osmappLayers).filter(filterMakina).map(toLayer), ...(userLayers.length ? [spacer] : []), ...userLayers.map((layer) => ({ ...layer, @@ -55,15 +58,19 @@ const getAllLayers = (userLayers: Layer[]): Layer[] => { }; export const LayerSwitcherContent = () => { - const { activeLayers, setActiveLayers } = useMapStateContext(); + const { view, activeLayers, setActiveLayers } = useMapStateContext(); const [userLayers, setUserLayers] = usePersistedState('userLayers', []); - const layers = getAllLayers(userLayers); + const layers = getAllLayers(userLayers, view); return ( <> - + {layers.map(({ key, name, type, url, Icon }) => { if (type === 'spacer') { return ; diff --git a/src/components/LayerSwitcher/osmappLayers.tsx b/src/components/LayerSwitcher/osmappLayers.tsx index 951940ee2..d392d2c29 100644 --- a/src/components/LayerSwitcher/osmappLayers.tsx +++ b/src/components/LayerSwitcher/osmappLayers.tsx @@ -21,6 +21,15 @@ export const osmappLayers: Layers = { Icon: ExploreIcon, attribution: ['maptiler', 'osm'], }, + makinaAfrica: { + name: t('layers.makina_africa'), + type: 'basemap', + Icon: ExploreIcon, + attribution: [ + 'OPG © OpenMapTiles', + 'osm', + ], + }, outdoor: { name: t('layers.outdoor'), type: 'basemap', diff --git a/src/components/Map/behaviour/useUpdateStyle.tsx b/src/components/Map/behaviour/useUpdateStyle.tsx index f63c8202e..e1aff4b4b 100644 --- a/src/components/Map/behaviour/useUpdateStyle.tsx +++ b/src/components/Map/behaviour/useUpdateStyle.tsx @@ -4,6 +4,7 @@ import { outdoorStyle } from '../styles/outdoorStyle'; import { osmappLayers } from '../../LayerSwitcher/osmappLayers'; import { rasterStyle } from '../styles/rasterStyle'; import { DEFAULT_MAP } from '../../../config'; +import { makinaAfricaStyle } from '../styles/makinaAfricaStyle'; export const getRasterStyle = (key) => { const url = osmappLayers[key]?.url ?? key; // if `key` not found, it contains tiles URL @@ -15,10 +16,22 @@ export const useUpdateStyle = useMapEffect((map, activeLayers) => { map.setMaxZoom(osmappLayers[key]?.maxzoom ?? 24); // TODO find a way how to zoom bing further (now it stops at 19) - if (key === 'basic' || key === 'outdoor') { - map.setStyle(key === 'basic' ? basicStyle : outdoorStyle); - } else { - map.setStyle(getRasterStyle(key)); - map.setZoom(Math.round(map.getZoom())); + switch (key) { + case 'basic': + map.setStyle(basicStyle); + break; + + case 'makinaAfrica': + map.setStyle(makinaAfricaStyle); + break; + + case 'outdoor': + map.setStyle(outdoorStyle); + break; + + default: + map.setStyle(getRasterStyle(key)); + map.setZoom(Math.round(map.getZoom())); + break; } }); diff --git a/src/components/Map/styles/makinaAfricaStyle.ts b/src/components/Map/styles/makinaAfricaStyle.ts new file mode 100644 index 000000000..44bec846c --- /dev/null +++ b/src/components/Map/styles/makinaAfricaStyle.ts @@ -0,0 +1,23 @@ +import { OSMAPP_SOURCES } from '../consts'; +import { basicStyle } from './basicStyle'; +import { View } from '../../utils/MapStateContext'; + +const sources = JSON.parse(JSON.stringify(OSMAPP_SOURCES)); + +sources.maptiler_planet.url = + 'https://africa.tiles.openplaceguide.org/data/v3.json'; + +export const makinaAfricaStyle = { ...basicStyle, sources }; + +const africaBbox = [ + -20, // west + -35, // south + 55, // east + 40, // north +]; + +export const isViewInsideAfrica = ([, lat, lon]: View) => + parseFloat(lat) > africaBbox[1] && + parseFloat(lat) < africaBbox[3] && + parseFloat(lon) > africaBbox[0] && + parseFloat(lon) < africaBbox[2]; diff --git a/src/locales/vocabulary.js b/src/locales/vocabulary.js index c56c8f0dc..90bb57a13 100644 --- a/src/locales/vocabulary.js +++ b/src/locales/vocabulary.js @@ -158,6 +158,7 @@ export default { 'layerswitcher.add_layer_prompt': 'Add custom TMS layer – needs correct CORS:\n(beta feature)', 'layers.basic': 'Basic', + 'layers.makina_africa': 'OpenPlaceGuide Africa', 'layers.outdoor': 'Outdoor', 'layers.mtb': 'MTB', 'layers.snow': 'Snow', From db0d83d059f07d9b4e5cd3352985f6c66348b3e4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Thu, 9 Nov 2023 20:46:43 +0100 Subject: [PATCH 31/35] intl: support language prefixes for all URLs (#141) --- next.config.js | 28 ++++++++++++------- pages/_document.tsx | 23 +++++++++++++-- src/components/App/App.tsx | 25 +++++++++++++++++ .../HomepagePanel/InstallDialog.tsx | 18 ++++++------ src/components/Map/MapFooter/LangSwitcher.tsx | 17 +++++++---- .../Map/behaviour/useOnMapClicked.tsx | 3 +- src/components/utils/MapStateContext.tsx | 18 ------------ src/services/intl.tsx | 1 + src/services/intlServer.tsx | 22 +++++++++++---- 9 files changed, 104 insertions(+), 51 deletions(-) diff --git a/next.config.js b/next.config.js index 39d7463f8..8b3d133af 100644 --- a/next.config.js +++ b/next.config.js @@ -4,6 +4,17 @@ const withPWA = require('next-pwa')({ dest: 'public', }); +const languages = { + de: 'Deutsch', + cs: 'Česky', + en: 'English', + es: 'Español', + fr: 'Français', + it: 'Italiano', + pl: 'Polski', + am: 'አማርኛ', +}; + module.exports = withPWA({ //TODO fails with current webpack config. Probably needs to get rid of sentry? (@sentry/nextjs was not cool) // future: { @@ -13,16 +24,13 @@ module.exports = withPWA({ osmappVersion: packageJson.version.replace(/\.0$/, ''), commitHash: (process.env.VERCEL_GIT_COMMIT_SHA || '').substr(0, 7), commitMessage: process.env.VERCEL_GIT_COMMIT_MESSAGE || 'dev', - languages: { - de: 'Deutsch', - cs: 'Česky', - en: 'English', - es: 'Español', - fr: 'Français', - it: 'Italiano', - pl: 'Polski', - am: 'አማርኛ', - }, + languages, + }, + i18n: { + // we let next only handle URL, but chosen locale is in getServerIntl() + locales: ['default', ...Object.keys(languages)], + defaultLocale: 'default', + localeDetection: false, }, webpack: (config, { dev, isServer }) => { if (!dev) { diff --git a/pages/_document.tsx b/pages/_document.tsx index 27b0c3788..1c471ccfd 100644 --- a/pages/_document.tsx +++ b/pages/_document.tsx @@ -1,5 +1,11 @@ import React from 'react'; -import Document, { Head, Html, Main, NextScript } from 'next/document'; +import Document, { + DocumentInitialProps, + Head, + Html, + Main, + NextScript, +} from 'next/document'; import { ServerStyleSheets } from '@material-ui/core/styles'; import { ServerStyleSheet } from 'styled-components'; import { getServerIntl } from '../src/services/intlServer'; @@ -8,7 +14,7 @@ import { Favicons } from '../src/helpers/Favicons'; export default class MyDocument extends Document { render() { - const { serverIntl } = this.props as any; + const { serverIntl, asPath } = this.props as any; return ( @@ -23,6 +29,16 @@ export default class MyDocument extends Document { + {/* we dont need this to change after SSR */} + {Object.keys(serverIntl.languages).map((lang) => ( + + ))} + {/* */} @@ -83,5 +99,6 @@ MyDocument.getInitialProps = async (ctx) => { sheets2.getStyleElement(), ], serverIntl, - }; + asPath: ctx.asPath, + } as DocumentInitialProps; }; diff --git a/src/components/App/App.tsx b/src/components/App/App.tsx index 9b2d5d08a..22a26e17e 100644 --- a/src/components/App/App.tsx +++ b/src/components/App/App.tsx @@ -3,6 +3,8 @@ import Cookies from 'js-cookie'; import nextCookies from 'next-cookies'; import Router, { useRouter } from 'next/router'; +import { Snackbar } from '@material-ui/core'; +import { Alert } from '@material-ui/lab'; import { FeaturePanel } from '../FeaturePanel/FeaturePanel'; import Map from '../Map/Map'; import SearchBox from '../SearchBox/SearchBox'; @@ -67,6 +69,14 @@ const IndexWithProviders = () => { usePersistMapView(); useUpdateViewFromHash(); + // temporary Alert until the issue is fixed + const [brokenShown, setBrokenShown] = React.useState(true); + const onBrokenClose = (event?: React.SyntheticEvent, reason?: string) => { + if (reason !== 'clickaway') { + setBrokenShown(false); + } + }; + // TODO add correct error boundaries return ( <> @@ -78,6 +88,21 @@ const IndexWithProviders = () => { {preview && } + + {!featureShown && !preview && ( + + + Some clickable POIs are broken on Maptiler –{' '} + + issue here + + . + + + )} ); }; diff --git a/src/components/HomepagePanel/InstallDialog.tsx b/src/components/HomepagePanel/InstallDialog.tsx index e6e299114..54c2c694c 100644 --- a/src/components/HomepagePanel/InstallDialog.tsx +++ b/src/components/HomepagePanel/InstallDialog.tsx @@ -140,25 +140,25 @@ export function InstallDialog() {
  • {' '} share icon
    - +
  • {' '} add icon
    - +
  • @@ -178,12 +178,12 @@ export function InstallDialog() {

  • - +

  • - +
  • @@ -203,13 +203,13 @@ export function InstallDialog() {
  • {' '} add icon
    - +
  • diff --git a/src/components/Map/MapFooter/LangSwitcher.tsx b/src/components/Map/MapFooter/LangSwitcher.tsx index 1fe8014bb..96a859868 100644 --- a/src/components/Map/MapFooter/LangSwitcher.tsx +++ b/src/components/Map/MapFooter/LangSwitcher.tsx @@ -1,6 +1,7 @@ import getConfig from 'next/config'; import React from 'react'; import { Menu, MenuItem } from '@material-ui/core'; +import { useRouter } from 'next/router'; import { useBoolState } from '../../helpers'; import { changeLang, intl, t } from '../../../services/intl'; @@ -8,15 +9,16 @@ export const LangSwitcher = () => { const { publicRuntimeConfig: { languages }, } = getConfig(); + const { asPath } = useRouter(); const anchorRef = React.useRef(); const [opened, open, close] = useBoolState(false); - const setLang = (k) => { - changeLang(k); + const getLangSetter = (lang) => (e) => { + e.preventDefault(); + changeLang(lang); close(); }; - // TODO make a link and allow google to index all langs return ( <> { open={opened} onClose={close} > - {Object.entries(languages).map(([k, name]) => ( - setLang(k)}> + {Object.entries(languages).map(([lang, name]) => ( + {name} ))} diff --git a/src/components/Map/behaviour/useOnMapClicked.tsx b/src/components/Map/behaviour/useOnMapClicked.tsx index 5b3426898..da957c27b 100644 --- a/src/components/Map/behaviour/useOnMapClicked.tsx +++ b/src/components/Map/behaviour/useOnMapClicked.tsx @@ -64,7 +64,8 @@ export const useOnMapClicked = useAddMapEvent( ); setPreview(null); - Router.push(`/${getUrlOsmId(skeleton.osmMeta)}${window.location.hash}`); + const url = `/${getUrlOsmId(skeleton.osmMeta)}${window.location.hash}`; + Router.push(url, undefined, { locale: 'default' }); }, }), ); diff --git a/src/components/utils/MapStateContext.tsx b/src/components/utils/MapStateContext.tsx index 35471a3c5..e8c2f2600 100644 --- a/src/components/utils/MapStateContext.tsx +++ b/src/components/utils/MapStateContext.tsx @@ -73,12 +73,6 @@ export const MapStateProvider = ({ children, initialMapView }) => { showToast, }; - const [brokenShown, setBrokenShown] = React.useState(true); - const onBrokenClose = (event?: React.SyntheticEvent, reason?: string) => { - if (reason !== 'clickaway') { - setBrokenShown(false); - } - }; return ( {children} @@ -87,18 +81,6 @@ export const MapStateProvider = ({ children, initialMapView }) => { {msg?.content} - - - Clickable POIs are currently broken on Maptiler –{' '} - - issue here - - . - - ); }; diff --git a/src/services/intl.tsx b/src/services/intl.tsx index 73512c35d..b83f321b9 100644 --- a/src/services/intl.tsx +++ b/src/services/intl.tsx @@ -65,6 +65,7 @@ export const InjectIntl = ({ intl: globalIntl }) => ( ); if (isBrowser()) { + // GLOBAL_INTL is set in _document.tsx setIntl((window as any).GLOBAL_INTL); } diff --git a/src/services/intlServer.tsx b/src/services/intlServer.tsx index d5e17f607..e0be2693a 100644 --- a/src/services/intlServer.tsx +++ b/src/services/intlServer.tsx @@ -17,20 +17,32 @@ const { publicRuntimeConfig: { languages }, } = getConfig(); -const getLangFromCtx = (ctx) => { +const resolveCurrentLang = (ctx) => { + const langInUrl = ctx.locale; + + // language is forced by URL prefix + if (languages[langInUrl]) { + ctx.res.setHeader('set-cookie', `lang=${langInUrl}; Path=/`); + return langInUrl; + } + + // app is usually used without lang prefix (cookie or accept-language) const { lang } = nextCookies(ctx); - if (lang && languages[lang]) return lang; + if (lang && languages[lang]) { + return lang; + } return getLangFromAcceptHeader(ctx, Object.keys(languages)) ?? DEFAULT_LANG; }; export const getServerIntl = async (ctx) => { - const lang = getLangFromCtx(ctx); + const lang = resolveCurrentLang(ctx); const vocabulary = await getMessages('vocabulary'); const messages = lang === DEFAULT_LANG ? {} : await getMessages(lang); - const intl = { + + return { lang, + languages, messages: { ...vocabulary, ...messages }, }; - return intl; }; From ab1969cc22fb7e2e2ec98432fdd3f0552f89d462 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Mon, 13 Nov 2023 21:52:53 +0100 Subject: [PATCH 32/35] general: sitemap experiment (#209) --- pages/sitemap.txt.tsx | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) create mode 100644 pages/sitemap.txt.tsx diff --git a/pages/sitemap.txt.tsx b/pages/sitemap.txt.tsx new file mode 100644 index 000000000..3d9db7cf4 --- /dev/null +++ b/pages/sitemap.txt.tsx @@ -0,0 +1,19 @@ +import { fetchText } from '../src/services/fetch'; + +const Sitemap = () => null; + +export const getServerSideProps = async ({ res }) => { + const content = await fetchText( + 'https://zbycz.github.io/osm-static/sitemap.txt', + ); + + res.setHeader('Content-Type', 'text/plain'); + res.write(content); + res.end(); + + return { + props: {}, + }; +}; + +export default Sitemap; From ba168305bea3fcf0fbcc648eddb6281016c579cf Mon Sep 17 00:00:00 2001 From: Alexander Menk Date: Mon, 20 Nov 2023 10:39:21 +0100 Subject: [PATCH 33/35] general: add proper Docker Build (#210) * Replace docker file with template from https://github.com/vercel/next.js/blob/canary/examples/with-docker/Dockerfile * Uses node 18 instead of Node 10 which is no longer compatible * Add the option via ENV to build to config standalone and use this for the docker image --- .dockerignore | 7 ++++++ Dockerfile | 66 ++++++++++++++++++++++++++++++++++++++++++++------ next.config.js | 1 + 3 files changed, 66 insertions(+), 8 deletions(-) create mode 100644 .dockerignore diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 000000000..c5500558b --- /dev/null +++ b/.dockerignore @@ -0,0 +1,7 @@ +Dockerfile +.dockerignore +node_modules +npm-debug.log +README.md +.next +.git diff --git a/Dockerfile b/Dockerfile index 7e8a042cf..3f3eee01e 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,14 +1,64 @@ -FROM mhart/alpine-node:10 as build-stage +FROM node:18-alpine AS base + +# Install dependencies only when needed +FROM base AS deps +# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed. +RUN apk add --no-cache libc6-compat +WORKDIR /app + +# Install dependencies based on the preferred package manager +COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* ./ +RUN \ + if [ -f yarn.lock ]; then yarn --frozen-lockfile; \ + elif [ -f package-lock.json ]; then npm ci; \ + elif [ -f pnpm-lock.yaml ]; then yarn global add pnpm && pnpm i --frozen-lockfile; \ + else echo "Lockfile not found." && exit 1; \ + fi + + +# Rebuild the source code only when needed +FROM base AS builder WORKDIR /app +COPY --from=deps /app/node_modules ./node_modules COPY . . -RUN yarn install --pure-lockfile -RUN yarn build -RUN yarn --production -FROM mhart/alpine-node:base-10 +# Next.js collects completely anonymous telemetry data about general usage. +# Learn more here: https://nextjs.org/telemetry +# Uncomment the following line in case you want to disable telemetry during the build. +# ENV NEXT_TELEMETRY_DISABLED 1 + +RUN NEXTJS_OUTPUT=standalone yarn build + +# Production image, copy all the files and run next +FROM base AS runner WORKDIR /app -ENV NODE_ENV="production" -COPY --from=build-stage /app . + +ENV NODE_ENV production +# Uncomment the following line in case you want to disable telemetry during runtime. +# ENV NEXT_TELEMETRY_DISABLED 1 + +RUN addgroup --system --gid 1001 nodejs +RUN adduser --system --uid 1001 nextjs + +COPY --from=builder /app/public ./public + +# Set the correct permission for prerender cache +RUN mkdir .next +RUN chown nextjs:nodejs .next + +# Automatically leverage output traces to reduce image size +# https://nextjs.org/docs/advanced-features/output-file-tracing +COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./ +COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static + +USER nextjs + EXPOSE 3000 -CMD ["node", "./node_modules/.bin/next", "start"] +ENV PORT 3000 +# set hostname to localhost +ENV HOSTNAME "0.0.0.0" + +# server.js is created by next build from the standalone output +# https://nextjs.org/docs/pages/api-reference/next-config-js/output +CMD ["node", "server.js"] diff --git a/next.config.js b/next.config.js index 8b3d133af..50b2131e4 100644 --- a/next.config.js +++ b/next.config.js @@ -16,6 +16,7 @@ const languages = { }; module.exports = withPWA({ + output: process.env.NEXTJS_OUTPUT || undefined, //TODO fails with current webpack config. Probably needs to get rid of sentry? (@sentry/nextjs was not cool) // future: { // webpack5: true, From cecbf65ec45a6b18ca0a358745ff47b4e4fffb84 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Sun, 3 Dec 2023 11:08:03 +0100 Subject: [PATCH 34/35] images: fix mapillary without computed_geometry (#212) --- src/services/images/getMapillaryImage.ts | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/services/images/getMapillaryImage.ts b/src/services/images/getMapillaryImage.ts index d50b38bb5..79741afce 100644 --- a/src/services/images/getMapillaryImage.ts +++ b/src/services/images/getMapillaryImage.ts @@ -16,11 +16,16 @@ const debugOutput = (sorted) => { console.log('Sorted photos:', sorted); // eslint-disable-line no-console sorted.forEach((item) => { new maplibregl.Marker({ rotation: item.compass_angle }) - .setLngLat(item.computed_geometry.coordinates) + .setLngLat( + item.computed_geometry?.coordinates ?? item.geometry.coordinates, + ) .addTo(getGlobalMap()); }); new maplibregl.Marker({ rotation: sorted[0].compass_angle, color: '#f55' }) - .setLngLat(sorted[0].computed_geometry.coordinates) + .setLngLat( + sorted[0].computed_geometry?.coordinates ?? + sorted[0].geometry.coordinates, + ) .addTo(getGlobalMap()); } }; @@ -35,7 +40,7 @@ const getMapillaryImageRaw = async (poiCoords: Position): Promise => { poiCoords[1] + 0.0004, ]; // consider computed_compass_angle - but it is zero for many images, so we would have to fallback to compass_angle - const url = `https://graph.mapillary.com/images?access_token=MLY|4742193415884187|44e43b57d0211d8283a7ca1c3e6a63f2&fields=compass_angle,computed_geometry,captured_at,thumb_1024_url&bbox=${bbox}`; + const url = `https://graph.mapillary.com/images?access_token=MLY|4742193415884187|44e43b57d0211d8283a7ca1c3e6a63f2&fields=compass_angle,computed_geometry,geometry,captured_at,thumb_1024_url&bbox=${bbox}`; const { data } = await fetchJson(url); if (!data.length) { @@ -43,7 +48,8 @@ const getMapillaryImageRaw = async (poiCoords: Position): Promise => { } const photos = data.map((item) => { - const photoCoords = item.computed_geometry.coordinates; + const photoCoords = + item.computed_geometry?.coordinates ?? item.geometry.coordinates; const angleFromPhotoToPoi = getBearing(photoCoords, poiCoords); const deviationFromStraightSight = subtractAngle( angleFromPhotoToPoi, From 6fa9080fcce4fb3d29608d411c1478d569cb99a7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pavel=20Zbytovsk=C3=BD?= Date: Sun, 3 Dec 2023 18:05:05 +0100 Subject: [PATCH 35/35] SearchBox: render relations in overpass search (#213) --- .../Map/styles/layers/overpassLayers.ts | 32 ++- src/components/SearchBox/SearchBox.tsx | 12 +- src/services/__tests__/overpassSearch.test.ts | 202 +++++++++--------- src/services/getCenter.ts | 28 ++- src/services/overpassSearch.ts | 89 ++++---- src/services/types.ts | 10 +- 6 files changed, 206 insertions(+), 167 deletions(-) diff --git a/src/components/Map/styles/layers/overpassLayers.ts b/src/components/Map/styles/layers/overpassLayers.ts index b9ff5278f..db8e70b21 100644 --- a/src/components/Map/styles/layers/overpassLayers.ts +++ b/src/components/Map/styles/layers/overpassLayers.ts @@ -9,7 +9,7 @@ export const overpassLayers: LayerSpecification[] = [ 'line-color': '#f8f4f0', 'line-width': 6, }, - }, + } as LayerSpecification, { id: 'overpass-line', type: 'line', @@ -24,7 +24,7 @@ export const overpassLayers: LayerSpecification[] = [ 1, ], }, - }, + } as LayerSpecification, { id: 'overpass-line-text', type: 'symbol', @@ -47,7 +47,7 @@ export const overpassLayers: LayerSpecification[] = [ 1, ], }, - }, + } as LayerSpecification, { id: 'overpass-fill', type: 'fill', @@ -62,12 +62,12 @@ export const overpassLayers: LayerSpecification[] = [ 0.5, ], }, - }, + } as LayerSpecification, { id: 'overpass-circle', type: 'circle', source: 'overpass', - filter: ['all', ['==', '$type', 'Point']], + filter: ['all', ['==', '$type', 'Point'], ['!=', 'osmappType', 'relation']], paint: { 'circle-color': 'rgba(255,255,255,0.9)', 'circle-radius': 12, @@ -80,12 +80,28 @@ export const overpassLayers: LayerSpecification[] = [ 1, ], }, - }, + } as LayerSpecification, + { + id: 'overpass-circle-relation', + type: 'circle', + source: 'overpass', + filter: ['all', ['==', '$type', 'Point'], ['==', 'osmappType', 'relation']], + paint: { + 'circle-color': 'rgba(255,0,0,0.7)', + 'circle-radius': 5, + 'circle-opacity': [ + 'case', + ['boolean', ['feature-state', 'hover'], false], + 0.5, + 1, + ], + }, + } as LayerSpecification, { id: 'overpass-symbol', type: 'symbol', source: 'overpass', - filter: ['all', ['==', '$type', 'Point']], + filter: ['all', ['==', '$type', 'Point'], ['!=', 'osmappType', 'relation']], layout: { 'text-padding': 2, 'text-font': ['Noto Sans Regular'], @@ -116,5 +132,5 @@ export const overpassLayers: LayerSpecification[] = [ 1, ], }, - }, + } as LayerSpecification, ]; diff --git a/src/components/SearchBox/SearchBox.tsx b/src/components/SearchBox/SearchBox.tsx index c455af7be..639256e2f 100644 --- a/src/components/SearchBox/SearchBox.tsx +++ b/src/components/SearchBox/SearchBox.tsx @@ -79,6 +79,7 @@ fetchSchemaTranslations().then(() => { presetsForSearch = Object.values(presets) .filter(({ searchable }) => searchable === undefined || searchable) .filter(({ locationSet }) => !locationSet?.include) + .filter(({ tags }) => Object.keys(tags).length > 0) .map(({ name, presetKey, tags, terms }) => { const tagsAsStrings = Object.entries(tags).map(([k, v]) => `${k}=${v}`); return { @@ -120,7 +121,7 @@ const findInPresets = (inputValue) => { .filter((result) => result.name === 0 && result.sum > 0) .map((result) => ({ preset: result })); - // // experiment with sorting by number of matches + // // experiment with sorting by number of matches // TODO search in all words // const options = results // .filter((result) => result.sum > 0) // .sort((a, b) => { @@ -169,11 +170,13 @@ const fetchOptions = debounce( const useFetchOptions = (inputValue: string, setOptions) => { const { view } = useMapStateContext(); + useEffect(() => { if (inputValue === '') { setOptions([]); return; } + if (inputValue.length > 2) { const overpassQuery = getOverpassQuery(inputValue); const { nameMatches, rest } = findInPresets(inputValue); @@ -184,10 +187,11 @@ const useFetchOptions = (inputValue: string, setOptions) => { ]); const before = [...overpassQuery, ...nameMatches]; fetchOptions(inputValue, view, setOptions, before, rest); - } else { - setOptions([{ loader: true }]); - fetchOptions(inputValue, view, setOptions); + return; } + + setOptions([{ loader: true }]); + fetchOptions(inputValue, view, setOptions); }, [inputValue]); }; diff --git a/src/services/__tests__/overpassSearch.test.ts b/src/services/__tests__/overpassSearch.test.ts index e95e9fcfb..380d56674 100644 --- a/src/services/__tests__/overpassSearch.test.ts +++ b/src/services/__tests__/overpassSearch.test.ts @@ -1,4 +1,4 @@ -import { osmJsonToSkeletons } from '../overpassSearch'; +import { overpassGeomToGeojson } from '../overpassSearch'; /* [out:json][timeout:25]; @@ -19,6 +19,36 @@ const response = { 'The data included in this document is from www.openstreetmap.org. The data is made available under ODbL.', }, elements: [ + { + type: 'node', + id: 761541677, + lat: 49.9594996, + lon: 14.3231551, + tags: { + highway: 'crossing', + crossing: 'marked', + }, + }, + { + type: 'way', + id: 11005021, + bounds: { + minlat: 49.9414065, + minlon: 14.2801555, + maxlat: 49.944281, + maxlon: 14.2929424, + }, + nodes: [73359754, 9441919612, 97951778], + geometry: [ + { lat: 49.9414065, lon: 14.2929424 }, + { lat: 49.942755, lon: 14.2892883 }, + { lat: 49.944281, lon: 14.2801555 }, + ], + tags: { + highway: 'track', + tracktype: 'grade3', + }, + }, { type: 'relation', id: 8337908, @@ -36,30 +66,6 @@ const response = { lat: 49.9511921, lon: 14.3409309, }, - { - type: 'node', - ref: 4303193147, - role: 'platform', - lat: 49.9560895, - lon: 14.3420546, - }, - { - type: 'node', - ref: 5650107055, - role: 'platform', - lat: 49.95976, - lon: 14.35261, - }, - { - type: 'way', - ref: 143079042, - role: '', - geometry: [ - { lat: 49.9510996, lon: 14.3406283 }, - { lat: 49.9512392, lon: 14.340966 }, - { lat: 49.9512882, lon: 14.3409961 }, - ], - }, { type: 'way', ref: 431070311, @@ -72,75 +78,9 @@ const response = { ], }, { - type: 'way', - ref: 143079039, - role: '', - geometry: [ - { lat: 49.9512723, lon: 14.3405453 }, - { lat: 49.9512769, lon: 14.3403348 }, - { lat: 49.9512638, lon: 14.3402265 }, - { lat: 49.9512376, lon: 14.3399046 }, - { lat: 49.9512538, lon: 14.3397224 }, - { lat: 49.9513307, lon: 14.3396011 }, - { lat: 49.9514674, lon: 14.339525 }, - { lat: 49.9516502, lon: 14.3394962 }, - { lat: 49.9519514, lon: 14.3395323 }, - { lat: 49.9524812, lon: 14.3397353 }, - { lat: 49.9528361, lon: 14.3398737 }, - { lat: 49.9529293, lon: 14.3399175 }, - { lat: 49.9533275, lon: 14.3401047 }, - { lat: 49.9536045, lon: 14.3402959 }, - { lat: 49.9543101, lon: 14.340794 }, - { lat: 49.9555376, lon: 14.3415765 }, - { lat: 49.9564591, lon: 14.3422582 }, - { lat: 49.9569866, lon: 14.3425944 }, - { lat: 49.9574162, lon: 14.3429583 }, - { lat: 49.9576284, lon: 14.3431366 }, - { lat: 49.9578467, lon: 14.3434496 }, - { lat: 49.9582484, lon: 14.3441399 }, - { lat: 49.9588316, lon: 14.3454072 }, - { lat: 49.9589787, lon: 14.3459137 }, - { lat: 49.9590815, lon: 14.3465416 }, - ], - }, - { - type: 'way', - ref: 538959927, - role: '', - geometry: [ - { lat: 49.9590815, lon: 14.3465416 }, - { lat: 49.9596598, lon: 14.3496964 }, - { lat: 49.9598834, lon: 14.3509159 }, - { lat: 49.959959, lon: 14.3513285 }, - { lat: 49.9600528, lon: 14.3518402 }, - { lat: 49.9600898, lon: 14.3520419 }, - { lat: 49.9602015, lon: 14.3522125 }, - ], - }, - { - type: 'way', - ref: 311389592, - role: '', - geometry: [ - { lat: 49.9598062, lon: 14.3530042 }, - { lat: 49.9598857, lon: 14.3529381 }, - { lat: 49.9599703, lon: 14.3528484 }, - { lat: 49.9600301, lon: 14.3527557 }, - { lat: 49.9600872, lon: 14.3526668 }, - { lat: 49.9601506, lon: 14.3525137 }, - { lat: 49.9602015, lon: 14.3522125 }, - ], - }, - { - type: 'way', - ref: 166349501, - role: '', - geometry: [ - { lat: 49.9598062, lon: 14.3530042 }, - { lat: 49.9597388, lon: 14.3526991 }, - { lat: 49.9596846, lon: 14.3526796 }, - { lat: 49.9595677, lon: 14.3527257 }, - ], + type: 'relation', + ref: 388266, + role: 'subarea', }, ], tags: { @@ -160,11 +100,80 @@ const response = { ], }; -const skeletons = [ +const geojson = [ { + center: [14.3231551, 49.9594996], geometry: { + coordinates: [14.3231551, 49.9594996], + type: 'Point', + }, + id: 7615416770, + osmMeta: { + id: 761541677, + type: 'node', + }, + properties: { + class: 'information', + crossing: 'marked', + highway: 'crossing', + osmappType: 'node', + subclass: 'crossing', + }, + tags: { + crossing: 'marked', + highway: 'crossing', + }, + type: 'Feature', + }, + { + center: [14.28654895, 49.942843749999994], + geometry: { + coordinates: [ + [14.2929424, 49.9414065], + [14.2892883, 49.942755], + [14.2801555, 49.944281], + ], type: 'LineString', }, + id: 110050211, + osmMeta: { + id: 11005021, + type: 'way', + }, + properties: { + class: 'information', + highway: 'track', + osmappType: 'way', + subclass: 'track', + tracktype: 'grade3', + }, + tags: { + highway: 'track', + tracktype: 'grade3', + }, + type: 'Feature', + }, + { + center: [14.3407707, 49.95124845], + geometry: { + geometries: [ + { + coordinates: [14.3409309, 49.9511921], + type: 'Point', + }, + { + coordinates: [ + [14.3409961, 49.9512882], + [14.3408764, 49.9513048], + [14.3406756, 49.9512958], + [14.3405453, 49.9512723], + ], + type: 'LineString', + }, + ], + type: 'GeometryCollection', + }, + id: 83379084, osmMeta: { id: 8337908, type: 'relation', @@ -175,6 +184,7 @@ const skeletons = [ name: '243: Kazín ⇒ Lipence', network: 'PID', operator: 'cz:DPP', + osmappType: 'relation', 'public_transport:version': '2', ref: '243', route: 'bus', @@ -202,5 +212,5 @@ const skeletons = [ ]; test('conversion', () => { - expect(osmJsonToSkeletons(response)).toEqual(skeletons); + expect(overpassGeomToGeojson(response)).toEqual(geojson); }); diff --git a/src/services/getCenter.ts b/src/services/getCenter.ts index 6e89fb0f1..6e1bf59d5 100644 --- a/src/services/getCenter.ts +++ b/src/services/getCenter.ts @@ -1,4 +1,4 @@ -import { FeatureGeometry, isPoint, isWay, Position } from './types'; +import { FeatureGeometry, isPoint, isRelation, isWay, Position } from './types'; interface NamedBbox { w: number; @@ -22,18 +22,32 @@ const getBbox = (coordinates: Position[]): NamedBbox => { ); }; +const getCenterOfBbox = (coordinates: Position[]) => { + if (!coordinates.length) return undefined; + + const { w, s, e, n } = getBbox(coordinates); // [WSEN] + const lon = (w + e) / 2; // flat earth rulezz + const lat = (s + n) / 2; + return [lon, lat]; +}; + export const getCenter = (geometry: FeatureGeometry): Position => { if (isPoint(geometry)) { return geometry.coordinates; } - if (isWay(geometry) && geometry.coordinates?.length) { - const { w, s, e, n } = getBbox(geometry.coordinates); // [WSEN] - const lon = (w + e) / 2; // flat earth rulezz - const lat = (s + n) / 2; - return [lon, lat]; + if (isWay(geometry)) { + return getCenterOfBbox(geometry.coordinates); + } + + if (isRelation(geometry)) { + const allCoords = geometry.geometries.flatMap((subGeometry) => + isPoint(subGeometry) + ? [subGeometry.coordinates] + : subGeometry.coordinates, + ); + return getCenterOfBbox(allCoords); } - // relation return undefined; }; diff --git a/src/services/overpassSearch.ts b/src/services/overpassSearch.ts index 17c58eec6..f7513b07b 100644 --- a/src/services/overpassSearch.ts +++ b/src/services/overpassSearch.ts @@ -1,4 +1,4 @@ -import { Feature, LineString, Point } from './types'; +import { Feature, GeometryCollection, LineString, Point } from './types'; import { getPoiClass } from './getPoiClass'; import { getCenter } from './getCenter'; import { OsmApiId } from './helpers'; @@ -15,10 +15,7 @@ const overpassQuery = (bbox, tags) => { way${query}(${bbox}); relation${query}(${bbox}); ); - out body; - >; - out skel qt;`; - // consider: out body geom + out geom qt;`; // "out geom;>;out geom qt;" to get all full subitems as well }; const getOverpassUrl = ([a, b, c, d], tags) => @@ -26,71 +23,61 @@ const getOverpassUrl = ([a, b, c, d], tags) => overpassQuery([d, a, b, c], tags), )}`; -const notNull = (x) => x != null; +const GEOMETRY = { + node: ({ lat, lon }): Point => ({ type: 'Point', coordinates: [lon, lat] }), -// maybe take inspiration from https://github.com/tyrasd/osmtogeojson/blob/gh-pages/index.js -export const osmJsonToSkeletons = (response: any): Feature[] => { - const nodesById = response.elements - .filter((element) => element.type === 'node') - .reduce((acc, node) => { - acc[node.id] = node; - return acc; - }, {}); + way: ({ geometry }): LineString => ({ + type: 'LineString', + coordinates: geometry.map(({ lat, lon }) => [lon, lat]), + }), + + relation: ({ members }): GeometryCollection => ({ + type: 'GeometryCollection', + geometries: + members + ?.map((el) => + el.type === 'node' + ? GEOMETRY.node(el) + : el.type === 'way' + ? GEOMETRY.way(el) + : null, + ) + .filter(Boolean) ?? [], + }), +}; - const getGeometry2 = { - node: ({ lat, lon }): Point => ({ type: 'Point', coordinates: [lon, lat] }), - way: (way): LineString => { - const { nodes } = way; - return { - type: 'LineString', // TODO distinguish area - match id-presets, then add icon for polygons - coordinates: nodes - ?.map((nodeId) => nodesById[nodeId]) - .map(({ lat, lon }) => [lon, lat]), - }; - }, - relation: ({ members }): LineString => ({ - type: 'LineString', - coordinates: members[0]?.geometry // TODO make proper relation handling - ?.filter(notNull) - ?.map(({ lat, lon }) => [lon, lat]), - }), - }; +const convertOsmIdToMapId = (apiId: OsmApiId) => { + const osmToMapType = { node: 0, way: 1, relation: 4 }; + return parseInt(`${apiId.id}${osmToMapType[apiId.type]}`, 10); +}; + +// maybe take inspiration from https://github.com/tyrasd/osmtogeojson/blob/gh-pages/index.js - return response.elements.map((element) => { +export const overpassGeomToGeojson = (response: any): Feature[] => + response.elements.map((element) => { const { type, id, tags = {} } = element; - const geometry = getGeometry2[type]?.(element); + const geometry = GEOMETRY[type]?.(element); return { type: 'Feature', + id: convertOsmIdToMapId({ type, id }), osmMeta: { type, id }, tags, - properties: { ...getPoiClass(tags), ...tags }, + properties: { ...getPoiClass(tags), ...tags, osmappType: type }, geometry, center: getCenter(geometry) ?? undefined, }; }); -}; - -const convertOsmIdToMapId = (apiId: OsmApiId) => { - const osmToMapType = { node: 0, way: 1, relation: 4 }; - return parseInt(`${apiId.id}${osmToMapType[apiId.type]}`, 10); -}; -export async function performOverpassSearch( +export const performOverpassSearch = async ( bbox, tags: Record, -) { +) => { console.log('seaching overpass for tags: ', tags); // eslint-disable-line no-console const overpass = await fetchJson(getOverpassUrl(bbox, Object.entries(tags))); console.log('overpass result:', overpass); // eslint-disable-line no-console - const features = osmJsonToSkeletons(overpass) - .filter((feature) => feature.center && Object.keys(feature.tags).length > 0) - .map((feature) => ({ - ...feature, - id: convertOsmIdToMapId(feature.osmMeta), - })); - + const features = overpassGeomToGeojson(overpass); console.log('overpass geojson', features); // eslint-disable-line no-console return { type: 'FeatureCollection', features }; -} +}; diff --git a/src/services/types.ts b/src/services/types.ts index fd5abe26f..14b2b9278 100644 --- a/src/services/types.ts +++ b/src/services/types.ts @@ -31,12 +31,20 @@ export interface LineString { coordinates: Position[]; } -export type FeatureGeometry = Point | LineString; +export interface GeometryCollection { + type: 'GeometryCollection'; + geometries: Array; +} + +export type FeatureGeometry = Point | LineString | GeometryCollection; export const isPoint = (geometry: FeatureGeometry): geometry is Point => geometry?.type === 'Point'; export const isWay = (geometry: FeatureGeometry): geometry is LineString => geometry?.type === 'LineString'; +export const isRelation = ( + geometry: FeatureGeometry, +): geometry is GeometryCollection => geometry?.type === 'GeometryCollection'; export interface FeatureTags { [key: string]: string;