diff --git a/index.html b/index.html index fefe10d..f99b382 100644 --- a/index.html +++ b/index.html @@ -119,10 +119,10 @@
@@ -159,10 +167,15 @@ +
+
+
+ ...coming soon +
+
diff --git a/package-lock.json b/package-lock.json index 0a6bf6f..d70a4d6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -50,9 +50,9 @@ } }, "node_modules/@babel/compat-data": { - "version": "7.13.11", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.13.11.tgz", - "integrity": "sha512-BwKEkO+2a67DcFeS3RLl0Z3Gs2OvdXewuWjc1Hfokhb5eQWP9YRYH1/+VrVZvql2CfjOiNGqSAFOYt4lsqTHzg==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.13.12.tgz", + "integrity": "sha512-3eJJ841uKxeV8dcN/2yGEUy+RfgQspPEgQat85umsE1rotuquQ2AbIub4S6j7c50a2d+4myc+zSlnXeIHrOnhQ==", "dev": true }, "node_modules/@babel/core": { @@ -219,38 +219,37 @@ } }, "node_modules/@babel/helper-member-expression-to-functions": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.13.0.tgz", - "integrity": "sha512-yvRf8Ivk62JwisqV1rFRMxiSMDGnN6KH1/mDMmIrij4jztpQNRoHqqMG3U6apYbGRPJpgPalhva9Yd06HlUxJQ==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.13.12.tgz", + "integrity": "sha512-48ql1CLL59aKbU94Y88Xgb2VFy7a95ykGRbJJaaVv+LX5U8wFpLfiGXJJGUozsmA1oEh/o5Bp60Voq7ACyA/Sw==", "dev": true, "dependencies": { - "@babel/types": "^7.13.0" + "@babel/types": "^7.13.12" } }, "node_modules/@babel/helper-module-imports": { - "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.12.13.tgz", - "integrity": "sha512-NGmfvRp9Rqxy0uHSSVP+SRIW1q31a7Ji10cLBcqSDUngGentY4FRiHOFZFE1CLU5eiL0oE8reH7Tg1y99TDM/g==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.13.12.tgz", + "integrity": "sha512-4cVvR2/1B693IuOvSI20xqqa/+bl7lqAMR59R4iu39R9aOX8/JoYY1sFaNvUMyMBGnHdwvJgUrzNLoUZxXypxA==", "dev": true, "dependencies": { - "@babel/types": "^7.12.13" + "@babel/types": "^7.13.12" } }, "node_modules/@babel/helper-module-transforms": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.13.0.tgz", - "integrity": "sha512-Ls8/VBwH577+pw7Ku1QkUWIyRRNHpYlts7+qSqBBFCW3I8QteB9DxfcZ5YJpOwH6Ihe/wn8ch7fMGOP1OhEIvw==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.13.12.tgz", + "integrity": "sha512-7zVQqMO3V+K4JOOj40kxiCrMf6xlQAkewBB0eu2b03OO/Q21ZutOzjpfD79A5gtE/2OWi1nv625MrDlGlkbknQ==", "dev": true, "dependencies": { - "@babel/helper-module-imports": "^7.12.13", - "@babel/helper-replace-supers": "^7.13.0", - "@babel/helper-simple-access": "^7.12.13", + "@babel/helper-module-imports": "^7.13.12", + "@babel/helper-replace-supers": "^7.13.12", + "@babel/helper-simple-access": "^7.13.12", "@babel/helper-split-export-declaration": "^7.12.13", "@babel/helper-validator-identifier": "^7.12.11", "@babel/template": "^7.12.13", "@babel/traverse": "^7.13.0", - "@babel/types": "^7.13.0", - "lodash": "^4.17.19" + "@babel/types": "^7.13.12" } }, "node_modules/@babel/helper-optimise-call-expression": { @@ -280,24 +279,24 @@ } }, "node_modules/@babel/helper-replace-supers": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.13.0.tgz", - "integrity": "sha512-Segd5me1+Pz+rmN/NFBOplMbZG3SqRJOBlY+mA0SxAv6rjj7zJqr1AVr3SfzUVTLCv7ZLU5FycOM/SBGuLPbZw==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.13.12.tgz", + "integrity": "sha512-Gz1eiX+4yDO8mT+heB94aLVNCL+rbuT2xy4YfyNqu8F+OI6vMvJK891qGBTqL9Uc8wxEvRW92Id6G7sDen3fFw==", "dev": true, "dependencies": { - "@babel/helper-member-expression-to-functions": "^7.13.0", + "@babel/helper-member-expression-to-functions": "^7.13.12", "@babel/helper-optimise-call-expression": "^7.12.13", "@babel/traverse": "^7.13.0", - "@babel/types": "^7.13.0" + "@babel/types": "^7.13.12" } }, "node_modules/@babel/helper-simple-access": { - "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.12.13.tgz", - "integrity": "sha512-0ski5dyYIHEfwpWGx5GPWhH35j342JaflmCeQmsPWcrOQDtCN6C1zKAVRFVbK53lPW2c9TsuLLSUDf0tIGJ5hA==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.13.12.tgz", + "integrity": "sha512-7FEjbrx5SL9cWvXioDbnlYTppcZGuCY6ow3/D5vMggb2Ywgu4dMrpTJX0JdQAIcRRUElOIxF3yEooa9gUb9ZbA==", "dev": true, "dependencies": { - "@babel/types": "^7.12.13" + "@babel/types": "^7.13.12" } }, "node_modules/@babel/helper-skip-transparent-expression-wrappers": { @@ -365,9 +364,9 @@ } }, "node_modules/@babel/parser": { - "version": "7.13.11", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.13.11.tgz", - "integrity": "sha512-PhuoqeHoO9fc4ffMEVk4qb/w/s2iOSWohvbHxLtxui0eBg3Lg5gN1U8wp1V1u61hOWkPQJJyJzGH6Y+grwkq8Q==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.13.12.tgz", + "integrity": "sha512-4T7Pb244rxH24yR116LAuJ+adxXXnHhZaLJjegJVKSdoNCe4x1eDBaud5YIcQFcqzsaD5BHvJw5BQ0AZapdCRw==", "dev": true, "bin": { "parser": "bin/babel-parser.js" @@ -376,6 +375,20 @@ "node": ">=6.0.0" } }, + "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.13.12.tgz", + "integrity": "sha512-d0u3zWKcoZf379fOeJdr1a5WPDny4aOFZ6hlfKivgK0LY7ZxNfoaHL2fWwdGtHyVvra38FC+HVYkO+byfSA8AQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.13.0", + "@babel/helper-skip-transparent-expression-wrappers": "^7.12.1", + "@babel/plugin-proposal-optional-chaining": "^7.13.12" + }, + "peerDependencies": { + "@babel/core": "^7.13.0" + } + }, "node_modules/@babel/plugin-proposal-async-generator-functions": { "version": "7.13.8", "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.13.8.tgz", @@ -525,9 +538,9 @@ } }, "node_modules/@babel/plugin-proposal-optional-chaining": { - "version": "7.13.8", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.13.8.tgz", - "integrity": "sha512-hpbBwbTgd7Cz1QryvwJZRo1U0k1q8uyBmeXOSQUjdg/A2TASkhR/rz7AyqZ/kS8kbpsNA80rOYbxySBJAqmhhQ==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.13.12.tgz", + "integrity": "sha512-fcEdKOkIB7Tf4IxrgEVeFC4zeJSTr78no9wTdBuZZbqF64kzllU0ybo2zrzm7gUQfxGhBgq4E39oRs8Zx/RMYQ==", "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.13.0", @@ -1149,15 +1162,16 @@ } }, "node_modules/@babel/preset-env": { - "version": "7.13.10", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.13.10.tgz", - "integrity": "sha512-nOsTScuoRghRtUsRr/c69d042ysfPHcu+KOB4A9aAO9eJYqrkat+LF8G1yp1HD18QiwixT2CisZTr/0b3YZPXQ==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.13.12.tgz", + "integrity": "sha512-JzElc6jk3Ko6zuZgBtjOd01pf9yYDEIH8BcqVuYIuOkzOwDesoa/Nz4gIo4lBG6K861KTV9TvIgmFuT6ytOaAA==", "dev": true, "dependencies": { - "@babel/compat-data": "^7.13.8", + "@babel/compat-data": "^7.13.12", "@babel/helper-compilation-targets": "^7.13.10", "@babel/helper-plugin-utils": "^7.13.0", "@babel/helper-validator-option": "^7.12.17", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.13.12", "@babel/plugin-proposal-async-generator-functions": "^7.13.8", "@babel/plugin-proposal-class-properties": "^7.13.0", "@babel/plugin-proposal-dynamic-import": "^7.13.8", @@ -1168,7 +1182,7 @@ "@babel/plugin-proposal-numeric-separator": "^7.12.13", "@babel/plugin-proposal-object-rest-spread": "^7.13.8", "@babel/plugin-proposal-optional-catch-binding": "^7.13.8", - "@babel/plugin-proposal-optional-chaining": "^7.13.8", + "@babel/plugin-proposal-optional-chaining": "^7.13.12", "@babel/plugin-proposal-private-methods": "^7.13.0", "@babel/plugin-proposal-unicode-property-regex": "^7.12.13", "@babel/plugin-syntax-async-generators": "^7.8.4", @@ -1216,7 +1230,7 @@ "@babel/plugin-transform-unicode-escapes": "^7.12.13", "@babel/plugin-transform-unicode-regex": "^7.12.13", "@babel/preset-modules": "^0.1.4", - "@babel/types": "^7.13.0", + "@babel/types": "^7.13.12", "babel-plugin-polyfill-corejs2": "^0.1.4", "babel-plugin-polyfill-corejs3": "^0.1.3", "babel-plugin-polyfill-regenerator": "^0.1.2", @@ -1281,9 +1295,9 @@ } }, "node_modules/@babel/types": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.13.0.tgz", - "integrity": "sha512-hE+HE8rnG1Z6Wzo+MhaKE5lM5eMx71T4EHJgku2E3xIfaULhDcxiiRxUYgwX8qwP1BBSlag+TdGOt6JAidIZTA==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.13.12.tgz", + "integrity": "sha512-K4nY2xFN4QMvQwkQ+zmBDp6ANMbVNw6BbxWmYA4qNjhR9W+Lj/8ky5MEY2Me5r+B2c6/v6F53oMndG+f9s3IiA==", "dev": true, "dependencies": { "@babel/helper-validator-identifier": "^7.12.11", @@ -2009,9 +2023,9 @@ } }, "node_modules/caniuse-lite": { - "version": "1.0.30001202", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001202.tgz", - "integrity": "sha512-ZcijQNqrcF8JNLjzvEiXqX4JUYxoZa7Pvcsd9UD8Kz4TvhTonOSNRsK+qtvpVL4l6+T1Rh4LFtLfnNWg6BGWCQ==", + "version": "1.0.30001204", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001204.tgz", + "integrity": "sha512-JUdjWpcxfJ9IPamy2f5JaRDCaqJOxDzOSKtbdx4rH9VivMd1vIzoPumsJa9LoMIi4Fx2BV2KZOxWhNkBjaYivQ==", "dev": true }, "node_modules/caseless": { @@ -2434,9 +2448,9 @@ } }, "node_modules/css-loader/node_modules/semver": { - "version": "7.3.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", - "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", "dev": true, "dependencies": { "lru-cache": "^6.0.0" @@ -2611,9 +2625,9 @@ } }, "node_modules/electron-to-chromium": { - "version": "1.3.690", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.690.tgz", - "integrity": "sha512-zPbaSv1c8LUKqQ+scNxJKv01RYFkVVF1xli+b+3Ty8ONujHjAMg+t/COmdZqrtnS1gT+g4hbSodHillymt1Lww==", + "version": "1.3.695", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.695.tgz", + "integrity": "sha512-lz66RliUqLHU1Ojxx1A4QUxKydjiQ79Y4dZyPobs2Dmxj5aVL2TM3KoQ2Gs7HS703Bfny+ukI3KOxwAB0xceHQ==", "dev": true }, "node_modules/emoji-regex": { @@ -4132,9 +4146,9 @@ } }, "node_modules/node-gyp/node_modules/semver": { - "version": "7.3.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", - "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", "dev": true, "dependencies": { "lru-cache": "^6.0.0" @@ -4678,9 +4692,9 @@ } }, "node_modules/queue-microtask": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.2.tgz", - "integrity": "sha512-dB15eXv3p2jDlbOiNLyMabYg1/sXvppd8DP2J3EOCQ0AkuSXCW2tP7mnVouVLJKgUMY6yP0kcQDVpLCN13h4Xg==", + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", "dev": true, "funding": [ { @@ -4891,9 +4905,9 @@ "dev": true }, "node_modules/regjsparser": { - "version": "0.6.7", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.7.tgz", - "integrity": "sha512-ib77G0uxsA2ovgiYbCVGx4Pv3PSttAx2vIwidqQzbL2U5S4Q+j00HdSAneSBuyVcMvEnTXMjiGgB+DlXozVhpQ==", + "version": "0.6.8", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.8.tgz", + "integrity": "sha512-3weFrFQREJhJ2PW+iCGaG6TenyzNSZgsBKZ/oEf6Trme31COSeIWhHw9O6FPkuXktfx+b6Hf/5e6dKPHaROq2g==", "dev": true, "dependencies": { "jsesc": "~0.5.0" @@ -5834,9 +5848,9 @@ } }, "node_modules/terser": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.6.0.tgz", - "integrity": "sha512-vyqLMoqadC1uR0vywqOZzriDYzgEkNJFK4q9GeyOBHIbiECHiWLKcWfbQWAUaPfxkjDhapSlZB9f7fkMrvkVjA==", + "version": "5.6.1", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.6.1.tgz", + "integrity": "sha512-yv9YLFQQ+3ZqgWCUk+pvNJwgUTdlIxUk1WTN+RnaFJe2L7ipG2csPT0ra2XRm7Cs8cxN7QXmK1rFzEwYEQkzXw==", "dev": true, "dependencies": { "commander": "^2.20.0", @@ -6211,9 +6225,9 @@ } }, "node_modules/webpack": { - "version": "5.26.3", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.26.3.tgz", - "integrity": "sha512-z/F2lt2N1fZqaud1B4SzjL3OW03eULThbBXQ2OX4LSrZX4N9k1A5d0Rje3zS2g887DTWyAV0KGqEf64ois2dhg==", + "version": "5.27.2", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.27.2.tgz", + "integrity": "sha512-brNF3N/EdvMzkaZ/Xzb8sqPn5Si3iw6meqCnmNFtcnkorZsFZCBFMa2ElpIMjx6sKWYsnUpBO2dnX+7xgj+mjg==", "dev": true, "dependencies": { "@types/eslint-scope": "^3.7.0", @@ -6305,9 +6319,9 @@ } }, "node_modules/webpack-cli/node_modules/commander": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-7.1.0.tgz", - "integrity": "sha512-pRxBna3MJe6HKnBGsDyMv8ETbptw3axEdYHoqNh7gu5oDcew8fs0xnivZGm06Ogk8zGAJ9VX+OPEr2GXEQK4dg==", + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", + "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", "dev": true, "engines": { "node": ">= 10" @@ -6636,9 +6650,9 @@ } }, "@babel/compat-data": { - "version": "7.13.11", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.13.11.tgz", - "integrity": "sha512-BwKEkO+2a67DcFeS3RLl0Z3Gs2OvdXewuWjc1Hfokhb5eQWP9YRYH1/+VrVZvql2CfjOiNGqSAFOYt4lsqTHzg==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.13.12.tgz", + "integrity": "sha512-3eJJ841uKxeV8dcN/2yGEUy+RfgQspPEgQat85umsE1rotuquQ2AbIub4S6j7c50a2d+4myc+zSlnXeIHrOnhQ==", "dev": true }, "@babel/core": { @@ -6786,38 +6800,37 @@ } }, "@babel/helper-member-expression-to-functions": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.13.0.tgz", - "integrity": "sha512-yvRf8Ivk62JwisqV1rFRMxiSMDGnN6KH1/mDMmIrij4jztpQNRoHqqMG3U6apYbGRPJpgPalhva9Yd06HlUxJQ==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.13.12.tgz", + "integrity": "sha512-48ql1CLL59aKbU94Y88Xgb2VFy7a95ykGRbJJaaVv+LX5U8wFpLfiGXJJGUozsmA1oEh/o5Bp60Voq7ACyA/Sw==", "dev": true, "requires": { - "@babel/types": "^7.13.0" + "@babel/types": "^7.13.12" } }, "@babel/helper-module-imports": { - "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.12.13.tgz", - "integrity": "sha512-NGmfvRp9Rqxy0uHSSVP+SRIW1q31a7Ji10cLBcqSDUngGentY4FRiHOFZFE1CLU5eiL0oE8reH7Tg1y99TDM/g==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.13.12.tgz", + "integrity": "sha512-4cVvR2/1B693IuOvSI20xqqa/+bl7lqAMR59R4iu39R9aOX8/JoYY1sFaNvUMyMBGnHdwvJgUrzNLoUZxXypxA==", "dev": true, "requires": { - "@babel/types": "^7.12.13" + "@babel/types": "^7.13.12" } }, "@babel/helper-module-transforms": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.13.0.tgz", - "integrity": "sha512-Ls8/VBwH577+pw7Ku1QkUWIyRRNHpYlts7+qSqBBFCW3I8QteB9DxfcZ5YJpOwH6Ihe/wn8ch7fMGOP1OhEIvw==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.13.12.tgz", + "integrity": "sha512-7zVQqMO3V+K4JOOj40kxiCrMf6xlQAkewBB0eu2b03OO/Q21ZutOzjpfD79A5gtE/2OWi1nv625MrDlGlkbknQ==", "dev": true, "requires": { - "@babel/helper-module-imports": "^7.12.13", - "@babel/helper-replace-supers": "^7.13.0", - "@babel/helper-simple-access": "^7.12.13", + "@babel/helper-module-imports": "^7.13.12", + "@babel/helper-replace-supers": "^7.13.12", + "@babel/helper-simple-access": "^7.13.12", "@babel/helper-split-export-declaration": "^7.12.13", "@babel/helper-validator-identifier": "^7.12.11", "@babel/template": "^7.12.13", "@babel/traverse": "^7.13.0", - "@babel/types": "^7.13.0", - "lodash": "^4.17.19" + "@babel/types": "^7.13.12" } }, "@babel/helper-optimise-call-expression": { @@ -6847,24 +6860,24 @@ } }, "@babel/helper-replace-supers": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.13.0.tgz", - "integrity": "sha512-Segd5me1+Pz+rmN/NFBOplMbZG3SqRJOBlY+mA0SxAv6rjj7zJqr1AVr3SfzUVTLCv7ZLU5FycOM/SBGuLPbZw==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.13.12.tgz", + "integrity": "sha512-Gz1eiX+4yDO8mT+heB94aLVNCL+rbuT2xy4YfyNqu8F+OI6vMvJK891qGBTqL9Uc8wxEvRW92Id6G7sDen3fFw==", "dev": true, "requires": { - "@babel/helper-member-expression-to-functions": "^7.13.0", + "@babel/helper-member-expression-to-functions": "^7.13.12", "@babel/helper-optimise-call-expression": "^7.12.13", "@babel/traverse": "^7.13.0", - "@babel/types": "^7.13.0" + "@babel/types": "^7.13.12" } }, "@babel/helper-simple-access": { - "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.12.13.tgz", - "integrity": "sha512-0ski5dyYIHEfwpWGx5GPWhH35j342JaflmCeQmsPWcrOQDtCN6C1zKAVRFVbK53lPW2c9TsuLLSUDf0tIGJ5hA==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.13.12.tgz", + "integrity": "sha512-7FEjbrx5SL9cWvXioDbnlYTppcZGuCY6ow3/D5vMggb2Ywgu4dMrpTJX0JdQAIcRRUElOIxF3yEooa9gUb9ZbA==", "dev": true, "requires": { - "@babel/types": "^7.12.13" + "@babel/types": "^7.13.12" } }, "@babel/helper-skip-transparent-expression-wrappers": { @@ -6932,11 +6945,22 @@ } }, "@babel/parser": { - "version": "7.13.11", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.13.11.tgz", - "integrity": "sha512-PhuoqeHoO9fc4ffMEVk4qb/w/s2iOSWohvbHxLtxui0eBg3Lg5gN1U8wp1V1u61hOWkPQJJyJzGH6Y+grwkq8Q==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.13.12.tgz", + "integrity": "sha512-4T7Pb244rxH24yR116LAuJ+adxXXnHhZaLJjegJVKSdoNCe4x1eDBaud5YIcQFcqzsaD5BHvJw5BQ0AZapdCRw==", "dev": true }, + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.13.12.tgz", + "integrity": "sha512-d0u3zWKcoZf379fOeJdr1a5WPDny4aOFZ6hlfKivgK0LY7ZxNfoaHL2fWwdGtHyVvra38FC+HVYkO+byfSA8AQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.13.0", + "@babel/helper-skip-transparent-expression-wrappers": "^7.12.1", + "@babel/plugin-proposal-optional-chaining": "^7.13.12" + } + }, "@babel/plugin-proposal-async-generator-functions": { "version": "7.13.8", "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.13.8.tgz", @@ -7053,9 +7077,9 @@ } }, "@babel/plugin-proposal-optional-chaining": { - "version": "7.13.8", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.13.8.tgz", - "integrity": "sha512-hpbBwbTgd7Cz1QryvwJZRo1U0k1q8uyBmeXOSQUjdg/A2TASkhR/rz7AyqZ/kS8kbpsNA80rOYbxySBJAqmhhQ==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.13.12.tgz", + "integrity": "sha512-fcEdKOkIB7Tf4IxrgEVeFC4zeJSTr78no9wTdBuZZbqF64kzllU0ybo2zrzm7gUQfxGhBgq4E39oRs8Zx/RMYQ==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.13.0", @@ -7527,15 +7551,16 @@ } }, "@babel/preset-env": { - "version": "7.13.10", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.13.10.tgz", - "integrity": "sha512-nOsTScuoRghRtUsRr/c69d042ysfPHcu+KOB4A9aAO9eJYqrkat+LF8G1yp1HD18QiwixT2CisZTr/0b3YZPXQ==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.13.12.tgz", + "integrity": "sha512-JzElc6jk3Ko6zuZgBtjOd01pf9yYDEIH8BcqVuYIuOkzOwDesoa/Nz4gIo4lBG6K861KTV9TvIgmFuT6ytOaAA==", "dev": true, "requires": { - "@babel/compat-data": "^7.13.8", + "@babel/compat-data": "^7.13.12", "@babel/helper-compilation-targets": "^7.13.10", "@babel/helper-plugin-utils": "^7.13.0", "@babel/helper-validator-option": "^7.12.17", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.13.12", "@babel/plugin-proposal-async-generator-functions": "^7.13.8", "@babel/plugin-proposal-class-properties": "^7.13.0", "@babel/plugin-proposal-dynamic-import": "^7.13.8", @@ -7546,7 +7571,7 @@ "@babel/plugin-proposal-numeric-separator": "^7.12.13", "@babel/plugin-proposal-object-rest-spread": "^7.13.8", "@babel/plugin-proposal-optional-catch-binding": "^7.13.8", - "@babel/plugin-proposal-optional-chaining": "^7.13.8", + "@babel/plugin-proposal-optional-chaining": "^7.13.12", "@babel/plugin-proposal-private-methods": "^7.13.0", "@babel/plugin-proposal-unicode-property-regex": "^7.12.13", "@babel/plugin-syntax-async-generators": "^7.8.4", @@ -7594,7 +7619,7 @@ "@babel/plugin-transform-unicode-escapes": "^7.12.13", "@babel/plugin-transform-unicode-regex": "^7.12.13", "@babel/preset-modules": "^0.1.4", - "@babel/types": "^7.13.0", + "@babel/types": "^7.13.12", "babel-plugin-polyfill-corejs2": "^0.1.4", "babel-plugin-polyfill-corejs3": "^0.1.3", "babel-plugin-polyfill-regenerator": "^0.1.2", @@ -7653,9 +7678,9 @@ } }, "@babel/types": { - "version": "7.13.0", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.13.0.tgz", - "integrity": "sha512-hE+HE8rnG1Z6Wzo+MhaKE5lM5eMx71T4EHJgku2E3xIfaULhDcxiiRxUYgwX8qwP1BBSlag+TdGOt6JAidIZTA==", + "version": "7.13.12", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.13.12.tgz", + "integrity": "sha512-K4nY2xFN4QMvQwkQ+zmBDp6ANMbVNw6BbxWmYA4qNjhR9W+Lj/8ky5MEY2Me5r+B2c6/v6F53oMndG+f9s3IiA==", "dev": true, "requires": { "@babel/helper-validator-identifier": "^7.12.11", @@ -8258,9 +8283,9 @@ } }, "caniuse-lite": { - "version": "1.0.30001202", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001202.tgz", - "integrity": "sha512-ZcijQNqrcF8JNLjzvEiXqX4JUYxoZa7Pvcsd9UD8Kz4TvhTonOSNRsK+qtvpVL4l6+T1Rh4LFtLfnNWg6BGWCQ==", + "version": "1.0.30001204", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001204.tgz", + "integrity": "sha512-JUdjWpcxfJ9IPamy2f5JaRDCaqJOxDzOSKtbdx4rH9VivMd1vIzoPumsJa9LoMIi4Fx2BV2KZOxWhNkBjaYivQ==", "dev": true }, "caseless": { @@ -8606,9 +8631,9 @@ } }, "semver": { - "version": "7.3.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", - "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", "dev": true, "requires": { "lru-cache": "^6.0.0" @@ -8725,9 +8750,9 @@ } }, "electron-to-chromium": { - "version": "1.3.690", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.690.tgz", - "integrity": "sha512-zPbaSv1c8LUKqQ+scNxJKv01RYFkVVF1xli+b+3Ty8ONujHjAMg+t/COmdZqrtnS1gT+g4hbSodHillymt1Lww==", + "version": "1.3.695", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.695.tgz", + "integrity": "sha512-lz66RliUqLHU1Ojxx1A4QUxKydjiQ79Y4dZyPobs2Dmxj5aVL2TM3KoQ2Gs7HS703Bfny+ukI3KOxwAB0xceHQ==", "dev": true }, "emoji-regex": { @@ -9910,9 +9935,9 @@ }, "dependencies": { "semver": { - "version": "7.3.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", - "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", "dev": true, "requires": { "lru-cache": "^6.0.0" @@ -10310,9 +10335,9 @@ "dev": true }, "queue-microtask": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.2.tgz", - "integrity": "sha512-dB15eXv3p2jDlbOiNLyMabYg1/sXvppd8DP2J3EOCQ0AkuSXCW2tP7mnVouVLJKgUMY6yP0kcQDVpLCN13h4Xg==", + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", "dev": true, "peer": true }, @@ -10481,9 +10506,9 @@ "dev": true }, "regjsparser": { - "version": "0.6.7", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.7.tgz", - "integrity": "sha512-ib77G0uxsA2ovgiYbCVGx4Pv3PSttAx2vIwidqQzbL2U5S4Q+j00HdSAneSBuyVcMvEnTXMjiGgB+DlXozVhpQ==", + "version": "0.6.8", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.8.tgz", + "integrity": "sha512-3weFrFQREJhJ2PW+iCGaG6TenyzNSZgsBKZ/oEf6Trme31COSeIWhHw9O6FPkuXktfx+b6Hf/5e6dKPHaROq2g==", "dev": true, "requires": { "jsesc": "~0.5.0" @@ -11219,9 +11244,9 @@ } }, "terser": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.6.0.tgz", - "integrity": "sha512-vyqLMoqadC1uR0vywqOZzriDYzgEkNJFK4q9GeyOBHIbiECHiWLKcWfbQWAUaPfxkjDhapSlZB9f7fkMrvkVjA==", + "version": "5.6.1", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.6.1.tgz", + "integrity": "sha512-yv9YLFQQ+3ZqgWCUk+pvNJwgUTdlIxUk1WTN+RnaFJe2L7ipG2csPT0ra2XRm7Cs8cxN7QXmK1rFzEwYEQkzXw==", "dev": true, "requires": { "commander": "^2.20.0", @@ -11498,9 +11523,9 @@ } }, "webpack": { - "version": "5.26.3", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.26.3.tgz", - "integrity": "sha512-z/F2lt2N1fZqaud1B4SzjL3OW03eULThbBXQ2OX4LSrZX4N9k1A5d0Rje3zS2g887DTWyAV0KGqEf64ois2dhg==", + "version": "5.27.2", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.27.2.tgz", + "integrity": "sha512-brNF3N/EdvMzkaZ/Xzb8sqPn5Si3iw6meqCnmNFtcnkorZsFZCBFMa2ElpIMjx6sKWYsnUpBO2dnX+7xgj+mjg==", "dev": true, "requires": { "@types/eslint-scope": "^3.7.0", @@ -11580,9 +11605,9 @@ }, "dependencies": { "commander": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-7.1.0.tgz", - "integrity": "sha512-pRxBna3MJe6HKnBGsDyMv8ETbptw3axEdYHoqNh7gu5oDcew8fs0xnivZGm06Ogk8zGAJ9VX+OPEr2GXEQK4dg==", + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", + "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", "dev": true } } diff --git a/src/js/clip/Picking.js b/src/js/clip/Picking.js index fa08bb9..7532949 100644 --- a/src/js/clip/Picking.js +++ b/src/js/clip/Picking.js @@ -17,6 +17,8 @@ export class Picking { plane; touchCapable = false; isDraging = false; + enabled = true; + defaultMapCursor; constructor(size, center, simulation) { this.size = size; @@ -43,6 +45,7 @@ export class Picking { simulation.scene.add(this.plane); this.domElement = simulation.renderer.domElement; + this.defaultMapCursor = this.domElement.style.cursor; domEvent.on(this.domElement, 'mousemove', this.mouseMove, this); if (this.touchCapable == true) { domEvent.on(this.domElement, 'touchstart', this.beginDrag, this); @@ -78,7 +81,7 @@ export class Picking { } mouseMove(event) { - if (this.isDraging == true || this.simulation.selection.visible == false) { + if (this.isDraging == true || this.simulation.selection.visible == false || this.enabled == false) { return; } let point = this._getCanvasPoint(event); @@ -110,14 +113,14 @@ export class Picking { // cursor is not selecting the box this.intersected.guardian.rayOut(); this.intersected = null; - this.simulation.renderer.domElement.style.cursor = 'auto'; + this.simulation.renderer.domElement.style.cursor = this.defaultMapCursor; // this.simulation.throttledRender(); this.simulation.deferringThrottle(); } } beginDrag(event) { - if (this.simulation.selection.visible == false) { + if (this.simulation.selection.visible == false && this.enabled == false) { return; } // exit drag method, if not left mouse button was clicked @@ -225,5 +228,25 @@ export class Picking { } } + disable () { + domEvent.off(this.domElement, 'mousemove', this.mouseMove, this); + if (this.touchCapable == true) { + domEvent.off(this.domElement, 'touchstart', this.beginDrag, this); + } else { + domEvent.off(this.domElement, 'mousedown', this.beginDrag, this); + } + this.enabled = false; + } + + enable() { + domEvent.on(this.domElement, 'mousemove', this.mouseMove, this); + if (this.touchCapable == true) { + domEvent.on(this.domElement, 'touchstart', this.beginDrag, this); + } else { + domEvent.on(this.domElement, 'mousedown', this.beginDrag, this); + } + this.enabled = true; + } + } \ No newline at end of file diff --git a/src/js/controls/BoreholeControl.css b/src/js/controls/BoreholeControl.css new file mode 100644 index 0000000..a00c724 --- /dev/null +++ b/src/js/controls/BoreholeControl.css @@ -0,0 +1,51 @@ +.gba-maptool-control { + border-radius: 4px; + border: 1px solid #bbb; + box-shadow: none; + margin:0; + padding:0; + overflow:hidden; +} +.gba-maptool-control a { + background-position: 50% 50%; + margin: 0; + background-repeat: no-repeat; + display: block; + height: 30px; + width: 30px; + background-image: url('') /*img/drill2.png*/; + float: left; +} +.measure-enabled .gba-maptool-control a{ + background-color:skyblue; +} +#radio{ + float: left; +} + +.gba-maptool-toggle { + display: inline-block; + vertical-align: middle; +} +.gba-maptool-control input:checked + label:before { + content: '✓'; + padding-left: -2em; +} +.gba-maptool-control input[type=radio] { + display: none; +} +.gba-maptool-control input[type=radio] + label { + display: none; + line-height: 30px; + height: 30px; + width: 30px; + margin: 0; + padding: 0; + font-size: 12px; + text-align: center; + vertical-align: middle; + cursor: pointer; +} +.measure-enabled .gba-maptool-control input[type=radio] + label { + display: inline-block; +} \ No newline at end of file diff --git a/src/js/controls/BoreholeControl.js b/src/js/controls/BoreholeControl.js new file mode 100644 index 0000000..bb40060 --- /dev/null +++ b/src/js/controls/BoreholeControl.js @@ -0,0 +1,34 @@ +import { Control } from "./Control"; +import * as dom from '../core/domUtil'; +import * as util from '../core/utilities'; +import * as domEvent from '../core/domEvent'; +import { BoreholeTool } from '../tools/BoreholeTool'; + +import './BoreholeControl.css'; + +export class BoreholeControl extends Control { + + onAdd (map) { + this.map = map; + + // var b = this._nls = util.mixin({}, N.widgets.boreholetool); + this._container = dom.createDom("div", { "class": 'gba-maptool-control gba-control' }); + //new L.Measurable(map); + let mapTool = new BoreholeTool(this.map); + + //var inputDiv = dom.createDom("div", { id: "radio" }, this._container); + //this.addUnit(inputDiv, 'km', 'km', 'kilometers', true); + //this.addUnit(inputDiv, 'mi', 'mi', 'miles'); + ////this.addUnit(inputDiv, 'nm', 'NM', 'nautical miles'); + let toggle = dom.createDom('a', { "class": "gba-maptool-toggle", href: "#", title: "b.title" }, this._container); + + domEvent.disableClickPropagation(this._container); + domEvent + // .on(toggle, 'click', domEvent.stop) + // .on(toggle, 'click', domEvent.preventDefault) + .on(toggle, 'click', mapTool.toggle, mapTool); + + return this._container; + } + +} \ No newline at end of file diff --git a/src/js/core/BaseEditor.js b/src/js/core/BaseEditor.js new file mode 100644 index 0000000..7abbe1e --- /dev/null +++ b/src/js/core/BaseEditor.js @@ -0,0 +1,150 @@ +import * as util from './utilities'; + +var Editable = { + + makeCancellable: function (e) { + e.cancel = function () { + e._cancelled = true; + }; + } +}; + +export class BaseEditor { + + map; + marker; + mapTool; + + + constructor(map, featureLayer, options = {}) { + util.setOptions(this, options); + this.map = map; + this.marker = featureLayer; + this.marker.editor = this; + //this.editLayer = new LayerGroup(); + this.mapTool = map.mapTool; //this.options.editTools || map.mapTool; + + // this.marker.bindPopup(map._controls.boreholePopup); + } + + enable() { + if (this._enabled) return this; + //if (this.isConnected() == true) { + // this.mapTool.editLayer.addLayer(this.editLayer); + //} + this.onEnable(); + this._enabled = true; + this.marker.on('remove', this.disable.bind(this)); + return this; + } + + disable() { + this.marker.off('remove', this.disable.bind(this)); + //this.editLayer.clearLayers(); + //this.mapTool.editLayer.removeLayer(this.editLayer); + this.onDisable(); + delete this._enabled; + if (this._drawing) this.cancelDrawing(); + return this; + } + + isConnected() { + return this.map.hasLayer(this.marker); + } + + drawing() { + return !!this._drawing; + } + + fireAndForward(type, e) { + e = e || {}; + e.layer = this.marker; + this.marker.emit(type, e); + this.mapTool.fireAndForward(type, e); + } + + onEnable() { + this.fireAndForward('editable:enable'); + } + + onDisable() { + this.fireAndForward('editable:disable'); + } + + onEditing() { + this.fireAndForward('editable:editing'); + } + + + onDrawingMouseDown(e) { + this.fireAndForward('editable:drawing:mousedown', e); + } + + + startDrawing() { + if (!this._drawing) { + this._drawing = 1;// L.Editable.FORWARD; + } + this.mapTool.registerForDrawing(this); + this._onStartDrawing(); + } + + _onStartDrawing() { + this.fireAndForward('editable:drawing:start'); + } + + + onDrawingClick(e) { + if (!this.drawing) return; + Editable.makeCancellable(e); + this.fireAndForward('editable:drawing:click', e); + if (e._cancelled) return; + //if (!this.isConnected()) { + // this.connect(e); + //} + var dxfIdentifyParams = {}; + dxfIdentifyParams.clientX = e.clientX; + dxfIdentifyParams.clientY = e.clientY; + dxfIdentifyParams.width = this.map.container.clientWidth; + dxfIdentifyParams.height = this.map.container.clientHeight; + // var deferred = this.mapTool.drillTask.execute(dxfIdentifyParams); + // deferred.then(this.handleQueryResults3.bind(this)); + + this._processDrawingClick(e); + } + + _processDrawingClick (e) { + this.fireAndForward('editable:drawing:clicked', e); + this._commitDrawing(e); + } + + _commitDrawing (e) { + this._onCommitDrawing(e); + } + + _onCommitDrawing(e) { + this.fireAndForward('editable:drawing:commit', e); + } + + + + + cancelDrawing() { + this._onCancelDrawing(); + this._endDrawing(); + } + + _onCancelDrawing () { + this.fireAndForward('editable:drawing:cancel'); + } + + _endDrawing () { + this._drawing = false; + this.mapTool.unregisterForDrawing(this); + this._onEndDrawing(); + } + + _onEndDrawing() { + this.fireAndForward('editable:drawing:end'); + } +} \ No newline at end of file diff --git a/src/js/core/Map.js b/src/js/core/Map.js index c64c860..ecbab4b 100644 --- a/src/js/core/Map.js +++ b/src/js/core/Map.js @@ -2,6 +2,7 @@ import { OrbitControls } from '../lib/OrbitControls'; import * as dom from './domUtil'; import { HomeButton } from '../controls/HomeButton'; import { ZoomControl } from '../controls/ZoomControl'; +import { BoreholeControl } from '../controls/BoreholeControl'; import * as util from './utilities'; import { TinLayer } from '../layer/TinLayer'; @@ -125,6 +126,8 @@ class Map extends OrbitControls { let zoomControl = this._controls.zoomControl = new ZoomControl(); zoomControl.addTo(this); + + this._controls.maptoolControl = new BoreholeControl().addTo(this); } async addLayer(layer) { @@ -150,6 +153,10 @@ class Map extends OrbitControls { return !!layer && (util.stamp(layer) in this._layers); } + getCenter () { // (Boolean) -> LatLng + return this.target; + } + } export { Map }; \ No newline at end of file diff --git a/src/js/core/domUtil.js b/src/js/core/domUtil.js index 6aec6fd..d8602ca 100644 --- a/src/js/core/domUtil.js +++ b/src/js/core/domUtil.js @@ -86,6 +86,17 @@ export function setProperties(element, properties) { } } + +// @function hasClass(el: HTMLElement, name: String): Boolean +// Returns `true` if the element's class attribute contains `name`. +export function hasClass(el, name) { + if (el.classList !== undefined) { + return el.classList.contains(name); + } + var className = getClass(el); + return className.length > 0 && new RegExp('(^|\\s)' + name + '(\\s|$)').test(className); +} + // @function addClass(el: HTMLElement, name: String) // Adds `name` to the element's class attribute. export function addClass(el, name) { diff --git a/src/js/layer/Layer.js b/src/js/layer/Layer.js index 2365e66..5026537 100644 --- a/src/js/layer/Layer.js +++ b/src/js/layer/Layer.js @@ -41,7 +41,58 @@ class Layer extends EventEmitter { getScene() { return this._map.scene; } - + + // @method bindPopup(content: String|HTMLElement|Function|Popup, options?: Popup options): this + // Binds a popup to the layer with the passed `content` and sets up the + // neccessary event listeners. If a `Function` is passed it will receive + // the layer as the first argument and should return a `String` or `HTMLElement`. + bindPopup(content) { + + if (content instanceof BoreholePopup) { + //util.setOptions(content, options); + this._popup = content; + content._source = this; + } + + if (!this._popup) { + //this._popup = new L.Popup(options, this); + this._popup = new BoreholePopup({}, this); + this._popup.addTo(this._map); + this._popup.setChartContent(content); + } + + + + if (!this._popupHandlersAdded) { + this.on("click", this.openPopup, this); //remove: this.closePopup //move: this._movePopup + this.on('remove', this.closePopup, this); + this._popupHandlersAdded = true; + } + + //// save the originally passed offset + //this._originalPopupOffset = this._popup.options.offset; + + return this; + } + + setPopupChartData(content) { + this._popup.setChartContent(content); + } + + openPopup() { + this._popup.show(); + } + + // @method closePopup(): this + // Closes the popup bound to this layer if it is open. + closePopup() { + if (this._popup) { + this._popup._close(); + //this._popup.removeFrom(this._map); + } + return this; + } + } export { Layer }; \ No newline at end of file diff --git a/src/js/layer/MarkerLayer.js b/src/js/layer/MarkerLayer.js new file mode 100644 index 0000000..5404f88 --- /dev/null +++ b/src/js/layer/MarkerLayer.js @@ -0,0 +1,131 @@ +import { Layer } from './Layer'; +import * as util from '../core/utilities'; +import { BaseEditor } from '../core/BaseEditor'; + +export class MarkerLayer extends Layer { + + createEditor(map) { + map = map || this._map; + var Klass = this.options.editorClass || this.getEditorClass(map); + return new Klass(map, this, this.options.editOptions); + } + + enableEdit(map) { + if (!this.editor) { + this.createEditor(map); + } + return this.editor.enable(); + } + + getEditorClass(map) { + return BaseEditor; + } + + options = { + pane: 'markerPane', + nonBubblingEvents: ['click', 'dblclick', 'mouseover', 'mouseout', 'contextmenu'], + //icon: new L.Icon.Default(), + opacity: 1, + clickable: true, + }; + + constructor(latlng, options) { + super(); + util.setOptions(this, options); + this._latlng = latlng; + + } + + onAdd(map) { + //this._zoomAnimated = this._zoomAnimated && map.options.markerZoomAnimation; + + this._initIcon(); + this.update(); + this.emit('add'); + } + + onRemove() { + //if (this.dragging && this.dragging.enabled()) { + // this.options.draggable = true; + // this.dragging.removeHooks(); + //} + + this._removeIcon(); + //this._removeShadow(); + this.emit('remove'); + this._map = null; + } + + update() { + if (this._icon) { + var pos = this._latlng; + this._setPos(pos); + } + this._map.emit("change"); + return this; + } + + getElement() { + return this._icon; + } + + _initIcon() { + //create default icon + var opt = { r: 0.25, c: 0xffff00, o: 0.8 }; + var icon = new THREE.Mesh(new THREE.CylinderGeometry(0, 0.5, 2), + new THREE.MeshLambertMaterial({ color: 0x38eeff, opacity: opt.o, transparent: (opt.o < 1) })); + icon.rotation.x = THREE.Math.degToRad(-90); + icon.visible = true; + //app.scene.add(app.boreholeMarker); + var addIcon = false; + + // if we're not reusing the icon, remove the old one and init new one + if (icon !== this._icon) { + if (this._icon) { + this._removeIcon(); + } + addIcon = true; + + //if (options.title) { + // icon.title = options.title; + //} + //if (options.alt) { + // icon.alt = options.alt; + //} + } + this._icon = icon; + + //this._initInteraction(); + + if (addIcon === true) { + this.getPane().add(this._icon); + } + } + + _removeIcon() { + //if (this.options.riseOnHover) { + // this.off({ + // mouseover: this._bringToFront, + // mouseout: this._resetZIndex + // }); + //} + + //L.DomUtil.remove(this._icon); + this.getPane().remove(this._icon); + //this.removeInteractiveTarget(this._icon); + + this._icon = null; + } + + _setPos(pos) { + //L.DomUtil.setPosition(this._icon, pos); + this._icon.position.set(pos.x, pos.y, pos.z); + + } + + setLatLng(latlng) { + this._latlng = latlng; + this.update(); + } + +} \ No newline at end of file diff --git a/src/js/main.js b/src/js/main.js index 472ac1e..1346641 100644 --- a/src/js/main.js +++ b/src/js/main.js @@ -13,7 +13,6 @@ import { NorthArrow } from './controls/NorthArrow'; import { LayerControl } from './controls/LayerControl'; import { BasemapControl } from './controls/BasemapControl'; import { SliderControl } from './controls/SliderControl'; -// import { SlicerControl } from './controls/SlicerControl'; import { Mesh } from 'three/src/objects/Mesh'; import { SphereGeometry } from 'three/src/geometries/SphereGeometry'; import { MeshLambertMaterial } from 'three/src/materials/MeshLambertMaterial'; @@ -196,7 +195,7 @@ class Application { ); this.map.addLayer(this.selection); - new Picking(size, center, this); + this.map.picking = new Picking(size, center, this); // let boxLayer = new BoxLayer({ diff --git a/src/js/tools/BoreholeTool.js b/src/js/tools/BoreholeTool.js new file mode 100644 index 0000000..ab73a57 --- /dev/null +++ b/src/js/tools/BoreholeTool.js @@ -0,0 +1,185 @@ +import { EventEmitter } from '../core/EventEmitter'; +import { MeshLambertMaterial } from 'three/src/materials/MeshLambertMaterial'; +import * as domEvent from '../core/domEvent'; +import { MarkerLayer } from '../layer/MarkerLayer'; +import * as dom from '../core/domUtil'; +import * as util from '../core/utilities'; + +export class BoreholeTool extends EventEmitter { + + options = { + zIndex: 1000, + markerClass: MarkerLayer,//THREE.CylinderGeometry, + drawingCSSClass: 'gba-editable-drawing', + drawingCursor: 'crosshair' + }; + + constructor(map, options = {}) { + super(); + + util.setOptions(this, options); + this._lastZIndex = this.options.zIndex; + this.map = map; + // this.featuresLayer = this._createFeaturesLayer(); + //this.forwardLineGuide = this.createLineGuide(); + //this.backwardLineGuide = this.createLineGuide(); + + this.map.mapTool = this; + //this.on('editable:drawing:end', function () { + // if (this.enabled()) this.startMarker(); + //}); + + let highlightMaterial = new MeshLambertMaterial({ emissive: 0x999900, transparent: true, opacity: 0.5 }); + this.defaultMapCursor = this.map.domElement.style.cursor; + } + + // _createFeaturesLayer () { + // return new LayerGroup().addTo(this.map); + // } + + enabled() { + return dom.hasClass(this.map.container, 'measure-enabled'); + } + + toggle() { + if (this.enabled()) { + this.disable(); + } + else { + this.enable(); + } + } + + enable() { + //if (this.map.mapTool) this.map.mapTool.on('editable:drawing:start', this.disable.bind(this)); + dom.addClass(this.map.container, 'measure-enabled'); + //this.fireAndForward('showmeasure'); + this._startMarker(); + } + + disable() { + //if (this.map.mapTool) this.map.mapTool.off('editable:drawing:start', this.disable.bind(this)); + dom.removeClass(this.map.container, 'measure-enabled'); + // this.featuresLayer.clearLayers(); + //this.fireAndForward('hidemeasure'); + if (this._drawingEditor) { + this._drawingEditor.cancelDrawing(); + } + } + + fireAndForward(type, e) { + e = e || {}; + e.mapTool = this; + this.emit(type, e); + this.map.emit(type, e); + } + + _startMarker(latlng, options) { + latlng = latlng || this.map.getCenter().clone(); + let markerLayer = this._createMarker(latlng, options);//.addTo(this.map); + //this.map.addLayer(marker); + //marker.enableEdit(this.map).startDrawing(); //editor.startDrawing() -> registerForDrawing + let baseEditor = markerLayer.enableEdit(this.map); + baseEditor.startDrawing(); + return markerLayer; + } + + _createMarker(latlng, options) { + return this._createLayer(options && options.markerClass || this.options.markerClass, latlng, options); + } + + _createLayer(klass, latlngs, options) { + options = util.extend({ editOptions: { mapTool: this } }, options); + let layer = new klass(latlngs, options); + //this.fireAndForward('editable:created', { layer: layer }); + return layer; + } + + + registerForDrawing(editor) { + if (this._drawingEditor) { + this.unregisterForDrawing(this._drawingEditor); + } + //this.map.on('mousemove touchmove', editor.onDrawingMouseMove, editor); + this._blockEvents(); + this._drawingEditor = editor; + this.map.on('mousedown', this._onMousedown); + this.map.on('clicked', this._onMouseup); + dom.addClass(this.map.domElement, this.options.drawingCSSClass); + // this.defaultMapCursor = this.map.domElement.style.cursor; + //this.map.domElement.style.cursor = this.options.drawingCursor; + // this.map.domElement.style.cursor = "crosshair"; + this.map.domElement.style.cursor = "url('') 3 31, crosshair"; + //background-image:url(/content/img/drill.png); + } + + unregisterForDrawing(editor) { + this._unblockEvents(); + dom.removeClass(this.map.domElement, this.options.drawingCSSClass); + this.map.domElement.style.cursor = this.defaultMapCursor; + editor = editor || this._drawingEditor; + if (!editor) return; + //this.map.off('mousemove touchmove', editor.onDrawingMouseMove, editor); + this.map.off('mousedown', this._onMousedown); + this.map.off('clicked', this._onMouseup); + if (editor !== this._drawingEditor) return; + delete this._drawingEditor; + //if (editor._drawing) { + // editor.cancelDrawing(); + //} + } + + _blockEvents() { + // Hack: force map not to listen to other layers events while drawing. + //if (!this._oldTargets) { + //this._oldTargets = this.map._events; + //this.map._events = {}; + //} + if (!this._oldClickTargets) { + this._oldClickTargets = this.map._events.clicked; + this.map._events.clicked = []; + } + if (this.map.picking) { + this.map.picking.disable(); + } + } + + _unblockEvents() { + //if (this._oldTargets) { + // // Reset, but keep targets created while drawing. + // this.map._events = util.extend(this.map._events, this._oldTargets); + // delete this._oldTargets; + //} + if (this._oldClickTargets) { + // Reset, but keep targets created while drawing. + this.map._events.clicked = this.map._events.clicked.concat(this._oldClickTargets); + delete this._oldClickTargets; + } + if (this.map.picking) { + this.map.picking.enable(); + } + } + + _onMousedown(e) { + //var canvasOffset = $(this.domElement).offset(); + //var xClickedOnCanvas = e.clientX - canvasOffset.left; + //var yClickedonCanvas = e.clientY - canvasOffset.top; + //var event = { x: xClickedOnCanvas, y: yClickedonCanvas }; + this.mapTool._mouseDown = e; + this.mapTool._drawingEditor.onDrawingMouseDown(e); + } + + _onMouseup(e) { + if (this.mapTool._mouseDown) { + //var originPoint = new Point(this.mapTool._mouseDown.clientX, this.mapTool._mouseDown.clientY); + //var endPoint = new Point(e.clientX, e.clientY); + //var distance = endPoint.distanceTo(originPoint); + //if (Math.abs(distance) < 9 * (window.devicePixelRatio || 1)) this.mapTool._drawingEditor.onDrawingClick(e); + //else this._drawingEditor.onDrawingMouseUp(e); + this.mapTool._drawingEditor.onDrawingClick(this.mapTool._mouseDown); + } + this.mapTool._mouseDown = null; + } + + +} \ No newline at end of file