├── .gitignore ├── .npmrc ├── .prettierignore ├── .prettierrc ├── README.md ├── frontend ├── .gitignore ├── index.html ├── package-lock.json ├── package.json ├── public │ └── vite.svg ├── src │ ├── main.ts │ ├── style.css │ ├── typescript.svg │ └── vite-env.d.ts └── tsconfig.json ├── generation ├── all.py ├── download │ ├── channels.py │ ├── members.py │ └── messages.py ├── main.py ├── process │ ├── filters.py │ ├── geojson.py │ ├── graph.py │ ├── labels.py │ └── similarity.py ├── query │ └── random_similarity_indices.py ├── requirements.txt ├── sample.env ├── slack_manifest.json └── util │ └── slack_client.py ├── jsconfig.json ├── package-lock.json ├── package.json ├── postcss.config.js ├── src ├── app.css ├── app.d.ts ├── app.html └── routes │ ├── +layout.svelte │ ├── +page.js │ └── +page.svelte ├── static ├── favicon.png ├── robots.txt └── style.json ├── svelte.config.js ├── tailwind.config.js └── vite.config.js /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules 3 | /build 4 | /.svelte-kit 5 | /package 6 | .env 7 | .env.* 8 | !.env.example 9 | .vercel 10 | .output 11 | vite.config.js.timestamp-* 12 | vite.config.ts.timestamp-* 13 | /.idea 14 | generation/json_data 15 | generation/output 16 | __pycache__ 17 | 18 | static/geojson.json 19 | *.mbtiles -------------------------------------------------------------------------------- /.npmrc: -------------------------------------------------------------------------------- 1 | engine-strict=true 2 | resolution-mode=highest 3 | -------------------------------------------------------------------------------- /.prettierignore: -------------------------------------------------------------------------------- 1 | .idea 2 | .svelte-kit 3 | .venv 4 | generation -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "plugins": ["prettier-plugin-svelte", "prettier-plugin-tailwindcss"] 3 | } 4 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # 🗺️ Map of the Slack 2 | 3 | A map of all the channels in the slack! 4 | 5 | ## Generating data 6 | 7 | All data generation/processing code is in Python, located in the `generation` directory. 8 | You must first install dependencies (use a venv): 9 | 10 | ``` 11 | pip install -r requirements.txt 12 | python -m spacy download en_core_web_lg 13 | ``` 14 | 15 | Then, create a `.env` file in that directory - use `sample.env` as guidance. 16 | To get started, run the "all" command: 17 | 18 | ``` 19 | python main.py all 20 | ``` 21 | 22 | **This will probably take a very long time**, especially when downloading data! 23 | Last time I ran it, it took about 48 minutes and also used up to 3 gigabytes of RAM. 24 | 25 | After this, you can run each command independently as needed, such as to update data or test new code. 26 | 27 | ## Running the website 28 | 29 | First, install all packages with `npm install`. Then, after generating all data, copy the `geojson.json` file from the `generation/json_data` directory into the `static` directory. 30 | 31 | You can now start the development server with `npm run dev`. 32 | -------------------------------------------------------------------------------- /frontend/.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | 26 | public/data 27 | -------------------------------------------------------------------------------- /frontend/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Map of the Slack 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /frontend/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "frontend", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "frontend", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "graphology": "^0.25.4", 12 | "sigma": "^3.0.0-beta.30" 13 | }, 14 | "devDependencies": { 15 | "typescript": "^5.5.3", 16 | "vite": "^5.4.1" 17 | } 18 | }, 19 | "node_modules/@esbuild/aix-ppc64": { 20 | "version": "0.21.5", 21 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", 22 | "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", 23 | "cpu": [ 24 | "ppc64" 25 | ], 26 | "dev": true, 27 | "optional": true, 28 | "os": [ 29 | "aix" 30 | ], 31 | "engines": { 32 | "node": ">=12" 33 | } 34 | }, 35 | "node_modules/@esbuild/android-arm": { 36 | "version": "0.21.5", 37 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", 38 | "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", 39 | "cpu": [ 40 | "arm" 41 | ], 42 | "dev": true, 43 | "optional": true, 44 | "os": [ 45 | "android" 46 | ], 47 | "engines": { 48 | "node": ">=12" 49 | } 50 | }, 51 | "node_modules/@esbuild/android-arm64": { 52 | "version": "0.21.5", 53 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", 54 | "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", 55 | "cpu": [ 56 | "arm64" 57 | ], 58 | "dev": true, 59 | "optional": true, 60 | "os": [ 61 | "android" 62 | ], 63 | "engines": { 64 | "node": ">=12" 65 | } 66 | }, 67 | "node_modules/@esbuild/android-x64": { 68 | "version": "0.21.5", 69 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", 70 | "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", 71 | "cpu": [ 72 | "x64" 73 | ], 74 | "dev": true, 75 | "optional": true, 76 | "os": [ 77 | "android" 78 | ], 79 | "engines": { 80 | "node": ">=12" 81 | } 82 | }, 83 | "node_modules/@esbuild/darwin-arm64": { 84 | "version": "0.21.5", 85 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", 86 | "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", 87 | "cpu": [ 88 | "arm64" 89 | ], 90 | "dev": true, 91 | "optional": true, 92 | "os": [ 93 | "darwin" 94 | ], 95 | "engines": { 96 | "node": ">=12" 97 | } 98 | }, 99 | "node_modules/@esbuild/darwin-x64": { 100 | "version": "0.21.5", 101 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", 102 | "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", 103 | "cpu": [ 104 | "x64" 105 | ], 106 | "dev": true, 107 | "optional": true, 108 | "os": [ 109 | "darwin" 110 | ], 111 | "engines": { 112 | "node": ">=12" 113 | } 114 | }, 115 | "node_modules/@esbuild/freebsd-arm64": { 116 | "version": "0.21.5", 117 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", 118 | "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", 119 | "cpu": [ 120 | "arm64" 121 | ], 122 | "dev": true, 123 | "optional": true, 124 | "os": [ 125 | "freebsd" 126 | ], 127 | "engines": { 128 | "node": ">=12" 129 | } 130 | }, 131 | "node_modules/@esbuild/freebsd-x64": { 132 | "version": "0.21.5", 133 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", 134 | "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", 135 | "cpu": [ 136 | "x64" 137 | ], 138 | "dev": true, 139 | "optional": true, 140 | "os": [ 141 | "freebsd" 142 | ], 143 | "engines": { 144 | "node": ">=12" 145 | } 146 | }, 147 | "node_modules/@esbuild/linux-arm": { 148 | "version": "0.21.5", 149 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", 150 | "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", 151 | "cpu": [ 152 | "arm" 153 | ], 154 | "dev": true, 155 | "optional": true, 156 | "os": [ 157 | "linux" 158 | ], 159 | "engines": { 160 | "node": ">=12" 161 | } 162 | }, 163 | "node_modules/@esbuild/linux-arm64": { 164 | "version": "0.21.5", 165 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", 166 | "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", 167 | "cpu": [ 168 | "arm64" 169 | ], 170 | "dev": true, 171 | "optional": true, 172 | "os": [ 173 | "linux" 174 | ], 175 | "engines": { 176 | "node": ">=12" 177 | } 178 | }, 179 | "node_modules/@esbuild/linux-ia32": { 180 | "version": "0.21.5", 181 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", 182 | "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", 183 | "cpu": [ 184 | "ia32" 185 | ], 186 | "dev": true, 187 | "optional": true, 188 | "os": [ 189 | "linux" 190 | ], 191 | "engines": { 192 | "node": ">=12" 193 | } 194 | }, 195 | "node_modules/@esbuild/linux-loong64": { 196 | "version": "0.21.5", 197 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", 198 | "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", 199 | "cpu": [ 200 | "loong64" 201 | ], 202 | "dev": true, 203 | "optional": true, 204 | "os": [ 205 | "linux" 206 | ], 207 | "engines": { 208 | "node": ">=12" 209 | } 210 | }, 211 | "node_modules/@esbuild/linux-mips64el": { 212 | "version": "0.21.5", 213 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", 214 | "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", 215 | "cpu": [ 216 | "mips64el" 217 | ], 218 | "dev": true, 219 | "optional": true, 220 | "os": [ 221 | "linux" 222 | ], 223 | "engines": { 224 | "node": ">=12" 225 | } 226 | }, 227 | "node_modules/@esbuild/linux-ppc64": { 228 | "version": "0.21.5", 229 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", 230 | "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", 231 | "cpu": [ 232 | "ppc64" 233 | ], 234 | "dev": true, 235 | "optional": true, 236 | "os": [ 237 | "linux" 238 | ], 239 | "engines": { 240 | "node": ">=12" 241 | } 242 | }, 243 | "node_modules/@esbuild/linux-riscv64": { 244 | "version": "0.21.5", 245 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", 246 | "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", 247 | "cpu": [ 248 | "riscv64" 249 | ], 250 | "dev": true, 251 | "optional": true, 252 | "os": [ 253 | "linux" 254 | ], 255 | "engines": { 256 | "node": ">=12" 257 | } 258 | }, 259 | "node_modules/@esbuild/linux-s390x": { 260 | "version": "0.21.5", 261 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", 262 | "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", 263 | "cpu": [ 264 | "s390x" 265 | ], 266 | "dev": true, 267 | "optional": true, 268 | "os": [ 269 | "linux" 270 | ], 271 | "engines": { 272 | "node": ">=12" 273 | } 274 | }, 275 | "node_modules/@esbuild/linux-x64": { 276 | "version": "0.21.5", 277 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", 278 | "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", 279 | "cpu": [ 280 | "x64" 281 | ], 282 | "dev": true, 283 | "optional": true, 284 | "os": [ 285 | "linux" 286 | ], 287 | "engines": { 288 | "node": ">=12" 289 | } 290 | }, 291 | "node_modules/@esbuild/netbsd-x64": { 292 | "version": "0.21.5", 293 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", 294 | "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", 295 | "cpu": [ 296 | "x64" 297 | ], 298 | "dev": true, 299 | "optional": true, 300 | "os": [ 301 | "netbsd" 302 | ], 303 | "engines": { 304 | "node": ">=12" 305 | } 306 | }, 307 | "node_modules/@esbuild/openbsd-x64": { 308 | "version": "0.21.5", 309 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", 310 | "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", 311 | "cpu": [ 312 | "x64" 313 | ], 314 | "dev": true, 315 | "optional": true, 316 | "os": [ 317 | "openbsd" 318 | ], 319 | "engines": { 320 | "node": ">=12" 321 | } 322 | }, 323 | "node_modules/@esbuild/sunos-x64": { 324 | "version": "0.21.5", 325 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", 326 | "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", 327 | "cpu": [ 328 | "x64" 329 | ], 330 | "dev": true, 331 | "optional": true, 332 | "os": [ 333 | "sunos" 334 | ], 335 | "engines": { 336 | "node": ">=12" 337 | } 338 | }, 339 | "node_modules/@esbuild/win32-arm64": { 340 | "version": "0.21.5", 341 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", 342 | "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", 343 | "cpu": [ 344 | "arm64" 345 | ], 346 | "dev": true, 347 | "optional": true, 348 | "os": [ 349 | "win32" 350 | ], 351 | "engines": { 352 | "node": ">=12" 353 | } 354 | }, 355 | "node_modules/@esbuild/win32-ia32": { 356 | "version": "0.21.5", 357 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", 358 | "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", 359 | "cpu": [ 360 | "ia32" 361 | ], 362 | "dev": true, 363 | "optional": true, 364 | "os": [ 365 | "win32" 366 | ], 367 | "engines": { 368 | "node": ">=12" 369 | } 370 | }, 371 | "node_modules/@esbuild/win32-x64": { 372 | "version": "0.21.5", 373 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", 374 | "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", 375 | "cpu": [ 376 | "x64" 377 | ], 378 | "dev": true, 379 | "optional": true, 380 | "os": [ 381 | "win32" 382 | ], 383 | "engines": { 384 | "node": ">=12" 385 | } 386 | }, 387 | "node_modules/@rollup/rollup-android-arm-eabi": { 388 | "version": "4.22.4", 389 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.22.4.tgz", 390 | "integrity": "sha512-Fxamp4aEZnfPOcGA8KSNEohV8hX7zVHOemC8jVBoBUHu5zpJK/Eu3uJwt6BMgy9fkvzxDaurgj96F/NiLukF2w==", 391 | "cpu": [ 392 | "arm" 393 | ], 394 | "dev": true, 395 | "optional": true, 396 | "os": [ 397 | "android" 398 | ] 399 | }, 400 | "node_modules/@rollup/rollup-android-arm64": { 401 | "version": "4.22.4", 402 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.22.4.tgz", 403 | "integrity": "sha512-VXoK5UMrgECLYaMuGuVTOx5kcuap1Jm8g/M83RnCHBKOqvPPmROFJGQaZhGccnsFtfXQ3XYa4/jMCJvZnbJBdA==", 404 | "cpu": [ 405 | "arm64" 406 | ], 407 | "dev": true, 408 | "optional": true, 409 | "os": [ 410 | "android" 411 | ] 412 | }, 413 | "node_modules/@rollup/rollup-darwin-arm64": { 414 | "version": "4.22.4", 415 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.22.4.tgz", 416 | "integrity": "sha512-xMM9ORBqu81jyMKCDP+SZDhnX2QEVQzTcC6G18KlTQEzWK8r/oNZtKuZaCcHhnsa6fEeOBionoyl5JsAbE/36Q==", 417 | "cpu": [ 418 | "arm64" 419 | ], 420 | "dev": true, 421 | "optional": true, 422 | "os": [ 423 | "darwin" 424 | ] 425 | }, 426 | "node_modules/@rollup/rollup-darwin-x64": { 427 | "version": "4.22.4", 428 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.22.4.tgz", 429 | "integrity": "sha512-aJJyYKQwbHuhTUrjWjxEvGnNNBCnmpHDvrb8JFDbeSH3m2XdHcxDd3jthAzvmoI8w/kSjd2y0udT+4okADsZIw==", 430 | "cpu": [ 431 | "x64" 432 | ], 433 | "dev": true, 434 | "optional": true, 435 | "os": [ 436 | "darwin" 437 | ] 438 | }, 439 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 440 | "version": "4.22.4", 441 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.22.4.tgz", 442 | "integrity": "sha512-j63YtCIRAzbO+gC2L9dWXRh5BFetsv0j0va0Wi9epXDgU/XUi5dJKo4USTttVyK7fGw2nPWK0PbAvyliz50SCQ==", 443 | "cpu": [ 444 | "arm" 445 | ], 446 | "dev": true, 447 | "optional": true, 448 | "os": [ 449 | "linux" 450 | ] 451 | }, 452 | "node_modules/@rollup/rollup-linux-arm-musleabihf": { 453 | "version": "4.22.4", 454 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.22.4.tgz", 455 | "integrity": "sha512-dJnWUgwWBX1YBRsuKKMOlXCzh2Wu1mlHzv20TpqEsfdZLb3WoJW2kIEsGwLkroYf24IrPAvOT/ZQ2OYMV6vlrg==", 456 | "cpu": [ 457 | "arm" 458 | ], 459 | "dev": true, 460 | "optional": true, 461 | "os": [ 462 | "linux" 463 | ] 464 | }, 465 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 466 | "version": "4.22.4", 467 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.22.4.tgz", 468 | "integrity": "sha512-AdPRoNi3NKVLolCN/Sp4F4N1d98c4SBnHMKoLuiG6RXgoZ4sllseuGioszumnPGmPM2O7qaAX/IJdeDU8f26Aw==", 469 | "cpu": [ 470 | "arm64" 471 | ], 472 | "dev": true, 473 | "optional": true, 474 | "os": [ 475 | "linux" 476 | ] 477 | }, 478 | "node_modules/@rollup/rollup-linux-arm64-musl": { 479 | "version": "4.22.4", 480 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.22.4.tgz", 481 | "integrity": "sha512-Gl0AxBtDg8uoAn5CCqQDMqAx22Wx22pjDOjBdmG0VIWX3qUBHzYmOKh8KXHL4UpogfJ14G4wk16EQogF+v8hmA==", 482 | "cpu": [ 483 | "arm64" 484 | ], 485 | "dev": true, 486 | "optional": true, 487 | "os": [ 488 | "linux" 489 | ] 490 | }, 491 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { 492 | "version": "4.22.4", 493 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.22.4.tgz", 494 | "integrity": "sha512-3aVCK9xfWW1oGQpTsYJJPF6bfpWfhbRnhdlyhak2ZiyFLDaayz0EP5j9V1RVLAAxlmWKTDfS9wyRyY3hvhPoOg==", 495 | "cpu": [ 496 | "ppc64" 497 | ], 498 | "dev": true, 499 | "optional": true, 500 | "os": [ 501 | "linux" 502 | ] 503 | }, 504 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 505 | "version": "4.22.4", 506 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.22.4.tgz", 507 | "integrity": "sha512-ePYIir6VYnhgv2C5Xe9u+ico4t8sZWXschR6fMgoPUK31yQu7hTEJb7bCqivHECwIClJfKgE7zYsh1qTP3WHUA==", 508 | "cpu": [ 509 | "riscv64" 510 | ], 511 | "dev": true, 512 | "optional": true, 513 | "os": [ 514 | "linux" 515 | ] 516 | }, 517 | "node_modules/@rollup/rollup-linux-s390x-gnu": { 518 | "version": "4.22.4", 519 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.22.4.tgz", 520 | "integrity": "sha512-GqFJ9wLlbB9daxhVlrTe61vJtEY99/xB3C8e4ULVsVfflcpmR6c8UZXjtkMA6FhNONhj2eA5Tk9uAVw5orEs4Q==", 521 | "cpu": [ 522 | "s390x" 523 | ], 524 | "dev": true, 525 | "optional": true, 526 | "os": [ 527 | "linux" 528 | ] 529 | }, 530 | "node_modules/@rollup/rollup-linux-x64-gnu": { 531 | "version": "4.22.4", 532 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.22.4.tgz", 533 | "integrity": "sha512-87v0ol2sH9GE3cLQLNEy0K/R0pz1nvg76o8M5nhMR0+Q+BBGLnb35P0fVz4CQxHYXaAOhE8HhlkaZfsdUOlHwg==", 534 | "cpu": [ 535 | "x64" 536 | ], 537 | "dev": true, 538 | "optional": true, 539 | "os": [ 540 | "linux" 541 | ] 542 | }, 543 | "node_modules/@rollup/rollup-linux-x64-musl": { 544 | "version": "4.22.4", 545 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.22.4.tgz", 546 | "integrity": "sha512-UV6FZMUgePDZrFjrNGIWzDo/vABebuXBhJEqrHxrGiU6HikPy0Z3LfdtciIttEUQfuDdCn8fqh7wiFJjCNwO+g==", 547 | "cpu": [ 548 | "x64" 549 | ], 550 | "dev": true, 551 | "optional": true, 552 | "os": [ 553 | "linux" 554 | ] 555 | }, 556 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 557 | "version": "4.22.4", 558 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.22.4.tgz", 559 | "integrity": "sha512-BjI+NVVEGAXjGWYHz/vv0pBqfGoUH0IGZ0cICTn7kB9PyjrATSkX+8WkguNjWoj2qSr1im/+tTGRaY+4/PdcQw==", 560 | "cpu": [ 561 | "arm64" 562 | ], 563 | "dev": true, 564 | "optional": true, 565 | "os": [ 566 | "win32" 567 | ] 568 | }, 569 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 570 | "version": "4.22.4", 571 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.22.4.tgz", 572 | "integrity": "sha512-SiWG/1TuUdPvYmzmYnmd3IEifzR61Tragkbx9D3+R8mzQqDBz8v+BvZNDlkiTtI9T15KYZhP0ehn3Dld4n9J5g==", 573 | "cpu": [ 574 | "ia32" 575 | ], 576 | "dev": true, 577 | "optional": true, 578 | "os": [ 579 | "win32" 580 | ] 581 | }, 582 | "node_modules/@rollup/rollup-win32-x64-msvc": { 583 | "version": "4.22.4", 584 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.22.4.tgz", 585 | "integrity": "sha512-j8pPKp53/lq9lMXN57S8cFz0MynJk8OWNuUnXct/9KCpKU7DgU3bYMJhwWmcqC0UU29p8Lr0/7KEVcaM6bf47Q==", 586 | "cpu": [ 587 | "x64" 588 | ], 589 | "dev": true, 590 | "optional": true, 591 | "os": [ 592 | "win32" 593 | ] 594 | }, 595 | "node_modules/@types/estree": { 596 | "version": "1.0.5", 597 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", 598 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", 599 | "dev": true 600 | }, 601 | "node_modules/esbuild": { 602 | "version": "0.21.5", 603 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz", 604 | "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==", 605 | "dev": true, 606 | "hasInstallScript": true, 607 | "bin": { 608 | "esbuild": "bin/esbuild" 609 | }, 610 | "engines": { 611 | "node": ">=12" 612 | }, 613 | "optionalDependencies": { 614 | "@esbuild/aix-ppc64": "0.21.5", 615 | "@esbuild/android-arm": "0.21.5", 616 | "@esbuild/android-arm64": "0.21.5", 617 | "@esbuild/android-x64": "0.21.5", 618 | "@esbuild/darwin-arm64": "0.21.5", 619 | "@esbuild/darwin-x64": "0.21.5", 620 | "@esbuild/freebsd-arm64": "0.21.5", 621 | "@esbuild/freebsd-x64": "0.21.5", 622 | "@esbuild/linux-arm": "0.21.5", 623 | "@esbuild/linux-arm64": "0.21.5", 624 | "@esbuild/linux-ia32": "0.21.5", 625 | "@esbuild/linux-loong64": "0.21.5", 626 | "@esbuild/linux-mips64el": "0.21.5", 627 | "@esbuild/linux-ppc64": "0.21.5", 628 | "@esbuild/linux-riscv64": "0.21.5", 629 | "@esbuild/linux-s390x": "0.21.5", 630 | "@esbuild/linux-x64": "0.21.5", 631 | "@esbuild/netbsd-x64": "0.21.5", 632 | "@esbuild/openbsd-x64": "0.21.5", 633 | "@esbuild/sunos-x64": "0.21.5", 634 | "@esbuild/win32-arm64": "0.21.5", 635 | "@esbuild/win32-ia32": "0.21.5", 636 | "@esbuild/win32-x64": "0.21.5" 637 | } 638 | }, 639 | "node_modules/events": { 640 | "version": "3.3.0", 641 | "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", 642 | "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", 643 | "engines": { 644 | "node": ">=0.8.x" 645 | } 646 | }, 647 | "node_modules/fsevents": { 648 | "version": "2.3.3", 649 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 650 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 651 | "dev": true, 652 | "hasInstallScript": true, 653 | "optional": true, 654 | "os": [ 655 | "darwin" 656 | ], 657 | "engines": { 658 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 659 | } 660 | }, 661 | "node_modules/graphology": { 662 | "version": "0.25.4", 663 | "resolved": "https://registry.npmjs.org/graphology/-/graphology-0.25.4.tgz", 664 | "integrity": "sha512-33g0Ol9nkWdD6ulw687viS8YJQBxqG5LWII6FI6nul0pq6iM2t5EKquOTFDbyTblRB3O9I+7KX4xI8u5ffekAQ==", 665 | "dependencies": { 666 | "events": "^3.3.0", 667 | "obliterator": "^2.0.2" 668 | }, 669 | "peerDependencies": { 670 | "graphology-types": ">=0.24.0" 671 | } 672 | }, 673 | "node_modules/graphology-types": { 674 | "version": "0.24.7", 675 | "resolved": "https://registry.npmjs.org/graphology-types/-/graphology-types-0.24.7.tgz", 676 | "integrity": "sha512-tdcqOOpwArNjEr0gNQKCXwaNCWnQJrog14nJNQPeemcLnXQUUGrsCWpWkVKt46zLjcS6/KGoayeJfHHyPDlvwA==", 677 | "peer": true 678 | }, 679 | "node_modules/graphology-utils": { 680 | "version": "2.5.2", 681 | "resolved": "https://registry.npmjs.org/graphology-utils/-/graphology-utils-2.5.2.tgz", 682 | "integrity": "sha512-ckHg8MXrXJkOARk56ZaSCM1g1Wihe2d6iTmz1enGOz4W/l831MBCKSayeFQfowgF8wd+PQ4rlch/56Vs/VZLDQ==", 683 | "peerDependencies": { 684 | "graphology-types": ">=0.23.0" 685 | } 686 | }, 687 | "node_modules/nanoid": { 688 | "version": "3.3.7", 689 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 690 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 691 | "dev": true, 692 | "funding": [ 693 | { 694 | "type": "github", 695 | "url": "https://github.com/sponsors/ai" 696 | } 697 | ], 698 | "bin": { 699 | "nanoid": "bin/nanoid.cjs" 700 | }, 701 | "engines": { 702 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 703 | } 704 | }, 705 | "node_modules/obliterator": { 706 | "version": "2.0.4", 707 | "resolved": "https://registry.npmjs.org/obliterator/-/obliterator-2.0.4.tgz", 708 | "integrity": "sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ==" 709 | }, 710 | "node_modules/picocolors": { 711 | "version": "1.1.0", 712 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.0.tgz", 713 | "integrity": "sha512-TQ92mBOW0l3LeMeyLV6mzy/kWr8lkd/hp3mTg7wYK7zJhuBStmGMBG0BdeDZS/dZx1IukaX6Bk11zcln25o1Aw==", 714 | "dev": true 715 | }, 716 | "node_modules/postcss": { 717 | "version": "8.4.47", 718 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz", 719 | "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==", 720 | "dev": true, 721 | "funding": [ 722 | { 723 | "type": "opencollective", 724 | "url": "https://opencollective.com/postcss/" 725 | }, 726 | { 727 | "type": "tidelift", 728 | "url": "https://tidelift.com/funding/github/npm/postcss" 729 | }, 730 | { 731 | "type": "github", 732 | "url": "https://github.com/sponsors/ai" 733 | } 734 | ], 735 | "dependencies": { 736 | "nanoid": "^3.3.7", 737 | "picocolors": "^1.1.0", 738 | "source-map-js": "^1.2.1" 739 | }, 740 | "engines": { 741 | "node": "^10 || ^12 || >=14" 742 | } 743 | }, 744 | "node_modules/rollup": { 745 | "version": "4.22.4", 746 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.22.4.tgz", 747 | "integrity": "sha512-vD8HJ5raRcWOyymsR6Z3o6+RzfEPCnVLMFJ6vRslO1jt4LO6dUo5Qnpg7y4RkZFM2DMe3WUirkI5c16onjrc6A==", 748 | "dev": true, 749 | "dependencies": { 750 | "@types/estree": "1.0.5" 751 | }, 752 | "bin": { 753 | "rollup": "dist/bin/rollup" 754 | }, 755 | "engines": { 756 | "node": ">=18.0.0", 757 | "npm": ">=8.0.0" 758 | }, 759 | "optionalDependencies": { 760 | "@rollup/rollup-android-arm-eabi": "4.22.4", 761 | "@rollup/rollup-android-arm64": "4.22.4", 762 | "@rollup/rollup-darwin-arm64": "4.22.4", 763 | "@rollup/rollup-darwin-x64": "4.22.4", 764 | "@rollup/rollup-linux-arm-gnueabihf": "4.22.4", 765 | "@rollup/rollup-linux-arm-musleabihf": "4.22.4", 766 | "@rollup/rollup-linux-arm64-gnu": "4.22.4", 767 | "@rollup/rollup-linux-arm64-musl": "4.22.4", 768 | "@rollup/rollup-linux-powerpc64le-gnu": "4.22.4", 769 | "@rollup/rollup-linux-riscv64-gnu": "4.22.4", 770 | "@rollup/rollup-linux-s390x-gnu": "4.22.4", 771 | "@rollup/rollup-linux-x64-gnu": "4.22.4", 772 | "@rollup/rollup-linux-x64-musl": "4.22.4", 773 | "@rollup/rollup-win32-arm64-msvc": "4.22.4", 774 | "@rollup/rollup-win32-ia32-msvc": "4.22.4", 775 | "@rollup/rollup-win32-x64-msvc": "4.22.4", 776 | "fsevents": "~2.3.2" 777 | } 778 | }, 779 | "node_modules/sigma": { 780 | "version": "3.0.0-beta.30", 781 | "resolved": "https://registry.npmjs.org/sigma/-/sigma-3.0.0-beta.30.tgz", 782 | "integrity": "sha512-jPKJD7GaUaWjohX0B6oeUt1T2W1f7a8Vri7DNxQmOjZN1EgxQchV1QpRxLVIc3ecIx9aTsDoxnB3WxR14elNYA==", 783 | "dependencies": { 784 | "events": "^3.3.0", 785 | "graphology-utils": "^2.5.2" 786 | } 787 | }, 788 | "node_modules/source-map-js": { 789 | "version": "1.2.1", 790 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", 791 | "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", 792 | "dev": true, 793 | "engines": { 794 | "node": ">=0.10.0" 795 | } 796 | }, 797 | "node_modules/typescript": { 798 | "version": "5.6.2", 799 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.2.tgz", 800 | "integrity": "sha512-NW8ByodCSNCwZeghjN3o+JX5OFH0Ojg6sadjEKY4huZ52TqbJTJnDo5+Tw98lSy63NZvi4n+ez5m2u5d4PkZyw==", 801 | "dev": true, 802 | "bin": { 803 | "tsc": "bin/tsc", 804 | "tsserver": "bin/tsserver" 805 | }, 806 | "engines": { 807 | "node": ">=14.17" 808 | } 809 | }, 810 | "node_modules/vite": { 811 | "version": "5.4.8", 812 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.8.tgz", 813 | "integrity": "sha512-FqrItQ4DT1NC4zCUqMB4c4AZORMKIa0m8/URVCZ77OZ/QSNeJ54bU1vrFADbDsuwfIPcgknRkmqakQcgnL4GiQ==", 814 | "dev": true, 815 | "dependencies": { 816 | "esbuild": "^0.21.3", 817 | "postcss": "^8.4.43", 818 | "rollup": "^4.20.0" 819 | }, 820 | "bin": { 821 | "vite": "bin/vite.js" 822 | }, 823 | "engines": { 824 | "node": "^18.0.0 || >=20.0.0" 825 | }, 826 | "funding": { 827 | "url": "https://github.com/vitejs/vite?sponsor=1" 828 | }, 829 | "optionalDependencies": { 830 | "fsevents": "~2.3.3" 831 | }, 832 | "peerDependencies": { 833 | "@types/node": "^18.0.0 || >=20.0.0", 834 | "less": "*", 835 | "lightningcss": "^1.21.0", 836 | "sass": "*", 837 | "sass-embedded": "*", 838 | "stylus": "*", 839 | "sugarss": "*", 840 | "terser": "^5.4.0" 841 | }, 842 | "peerDependenciesMeta": { 843 | "@types/node": { 844 | "optional": true 845 | }, 846 | "less": { 847 | "optional": true 848 | }, 849 | "lightningcss": { 850 | "optional": true 851 | }, 852 | "sass": { 853 | "optional": true 854 | }, 855 | "sass-embedded": { 856 | "optional": true 857 | }, 858 | "stylus": { 859 | "optional": true 860 | }, 861 | "sugarss": { 862 | "optional": true 863 | }, 864 | "terser": { 865 | "optional": true 866 | } 867 | } 868 | } 869 | } 870 | } 871 | -------------------------------------------------------------------------------- /frontend/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "frontend", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "tsc && vite build", 9 | "preview": "vite preview" 10 | }, 11 | "devDependencies": { 12 | "typescript": "^5.5.3", 13 | "vite": "^5.4.1" 14 | }, 15 | "dependencies": { 16 | "graphology": "^0.25.4", 17 | "sigma": "^3.0.0-beta.30" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /frontend/public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /frontend/src/main.ts: -------------------------------------------------------------------------------- 1 | import "./style.css"; 2 | import Graph from "graphology"; 3 | import Sigma from "sigma"; 4 | 5 | const graph = new Graph(); 6 | 7 | const nodesReq = fetch("/data/nodes.json").then((r) => r.json()); 8 | const edgesReq = fetch("/data/edges.json").then((r) => r.json()); 9 | const channelsReq = fetch("/data/filtered_channels.json").then((r) => r.json()); 10 | 11 | Promise.all([nodesReq, edgesReq, channelsReq]).then( 12 | ([nodes, edges, channels]) => { 13 | console.log(nodes); 14 | for (const node in nodes) { 15 | const name = channels.find((c: any) => c.id === node).name; 16 | graph.addNode(node, { 17 | label: name, 18 | x: nodes[node][0], 19 | y: nodes[node][1], 20 | size: 2, 21 | }); 22 | } 23 | 24 | for (const edge of edges) { 25 | graph.addEdge(edge.split("-")[0], edge.split("-")[1], { size: 0.5 }); 26 | } 27 | 28 | const sigmaInstance = new Sigma(graph, document.getElementById("app")!); 29 | }, 30 | ); 31 | -------------------------------------------------------------------------------- /frontend/src/style.css: -------------------------------------------------------------------------------- 1 | #app { 2 | height: 100vh; 3 | width: 100vw; 4 | } 5 | -------------------------------------------------------------------------------- /frontend/src/typescript.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /frontend/src/vite-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /frontend/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ES2020", 4 | "useDefineForClassFields": true, 5 | "module": "ESNext", 6 | "lib": ["ES2020", "DOM", "DOM.Iterable"], 7 | "skipLibCheck": true, 8 | 9 | /* Bundler mode */ 10 | "moduleResolution": "bundler", 11 | "allowImportingTsExtensions": true, 12 | "isolatedModules": true, 13 | "moduleDetection": "force", 14 | "noEmit": true, 15 | 16 | /* Linting */ 17 | "strict": true, 18 | "noUnusedLocals": true, 19 | "noUnusedParameters": true, 20 | "noFallthroughCasesInSwitch": true 21 | }, 22 | "include": ["src"] 23 | } 24 | -------------------------------------------------------------------------------- /generation/all.py: -------------------------------------------------------------------------------- 1 | from shutil import rmtree 2 | from os.path import exists 3 | import threading 4 | 5 | from download.channels import download_channels 6 | from download.messages import download_messages 7 | from download.members import download_members 8 | from process.similarity import process_similarity 9 | from process.labels import process_labels 10 | from process.filters import process_filters 11 | from process.graph import process_graph 12 | from process.geojson import process_geojson 13 | 14 | def run_all(): 15 | if exists("json_data"): 16 | rmtree("json_data") 17 | 18 | download_channels() 19 | 20 | t1 = threading.Thread(target=download_messages) 21 | t2 = threading.Thread(target=download_members) 22 | t1.start() 23 | t2.start() 24 | t1.join() 25 | t2.join() 26 | 27 | process_filters() 28 | process_labels() 29 | process_similarity() 30 | process_graph() 31 | process_geojson() -------------------------------------------------------------------------------- /generation/download/channels.py: -------------------------------------------------------------------------------- 1 | import json 2 | import click 3 | import util.slack_client as slack_client 4 | import os 5 | 6 | def download_channels(): 7 | client = slack_client.getClient() 8 | 9 | conversations = [] 10 | 11 | with click.progressbar(length=1000, label="Downloading public Slack channels...") as bar: 12 | currentConversationsRes = client.conversations_list(limit=1000, types='public_channel') 13 | 14 | while currentConversationsRes['response_metadata']['next_cursor'] != '': 15 | conversations += currentConversationsRes['channels'] 16 | 17 | currentConversationsRes = client.conversations_list(limit=1000, cursor=currentConversationsRes['response_metadata']['next_cursor']) 18 | if currentConversationsRes['response_metadata']['next_cursor'] == '': 19 | progress = 1 20 | else: 21 | progress = float(len(conversations)) / float(len(conversations) + 1000) 22 | 23 | bar.pos = int(progress * 999) + 1 24 | bar.update(1) 25 | 26 | with click.progressbar(length=1000, label="Downloading private Slack channels...") as bar: 27 | currentConversationsRes = client.conversations_list(limit=1000, types='private_channel') 28 | 29 | while currentConversationsRes['response_metadata']['next_cursor'] != '': 30 | conversations += currentConversationsRes['channels'] 31 | 32 | currentConversationsRes = client.conversations_list(limit=1000, cursor=currentConversationsRes['response_metadata']['next_cursor']) 33 | if currentConversationsRes['response_metadata']['next_cursor'] == '': 34 | progress = 1 35 | else: 36 | progress = float(len(conversations)) / float(len(conversations) + 1000) 37 | 38 | bar.pos = int(progress * 999) + 1 39 | bar.update(1) 40 | 41 | bar.update(1000) 42 | 43 | conversations += currentConversationsRes['channels'] 44 | conversations.sort(key=lambda x: x['name']) 45 | 46 | conversations = filter(lambda x: x['is_archived'] == False and not x['name'].startswith('zzz-') and x['num_members'] > 10, conversations) 47 | conversations = list(conversations) 48 | 49 | channelJson = json.dumps(conversations) 50 | 51 | if not os.path.exists("json_data"): 52 | os.mkdir("json_data") 53 | 54 | file = open('json_data/channels.json', 'w', encoding='utf-8') 55 | file.write(channelJson) 56 | 57 | return conversations 58 | 59 | -------------------------------------------------------------------------------- /generation/download/members.py: -------------------------------------------------------------------------------- 1 | import json 2 | import click 3 | import os 4 | from os.path import exists 5 | import util.slack_client as slack_client 6 | 7 | def download_members(): 8 | client = slack_client.getClient() 9 | 10 | if not exists("json_data/channels.json"): 11 | click.echo("Channels not downloaded. Please run `python main.py download channels` first.") 12 | return 13 | 14 | channelsFile = open('json_data/channels.json', 'r', encoding='utf-8') 15 | channels = json.loads(channelsFile.read()) 16 | 17 | existingMembers = {} 18 | 19 | if exists("json_data/members.json"): 20 | membersFile = open('json_data/members.json', 'r', encoding='utf-8') 21 | existingMembers = json.loads(membersFile.read()) 22 | 23 | members = {} 24 | 25 | with click.progressbar(channels, label="Downloading channel members...") as bar: 26 | for channel in bar: 27 | if channel['id'] in existingMembers: 28 | members[channel['id']] = existingMembers[channel['id']] 29 | continue 30 | 31 | currentMembersRes = client.conversations_members(limit=1000, channel=channel['id']) 32 | 33 | members[channel['id']] = [] 34 | 35 | while currentMembersRes['response_metadata']['next_cursor'] != '': 36 | members[channel['id']] += currentMembersRes['members'] 37 | 38 | currentMembersRes = client.conversations_members(limit=1000, channel=channel['id'], cursor=currentMembersRes['response_metadata']['next_cursor']) 39 | 40 | 41 | members[channel['id']] += currentMembersRes['members'] 42 | 43 | if not os.path.exists("json_data"): 44 | os.mkdir("json_data") 45 | 46 | membersJson = json.dumps(members) 47 | membersFile = open('json_data/members.json', 'w', encoding='utf-8') 48 | membersFile.write(membersJson) 49 | 50 | return members -------------------------------------------------------------------------------- /generation/download/messages.py: -------------------------------------------------------------------------------- 1 | import json 2 | import click 3 | import os 4 | from os.path import exists 5 | import util.slack_client as slack_client 6 | 7 | def download_messages(): 8 | client = slack_client.getClient() 9 | 10 | if not exists("json_data/channels.json"): 11 | click.echo("Channels not downloaded. Please run `python main.py download channels` first.") 12 | return 13 | 14 | channelsFile = open('json_data/channels.json', 'r', encoding='utf-8') 15 | channels = json.loads(channelsFile.read()) 16 | 17 | existingMessages = {} 18 | 19 | if exists("json_data/messages.json"): 20 | existingFile = open('json_data/messages.json', 'r', encoding='utf-8') 21 | existingMessages = json.loads(existingFile.read()) 22 | 23 | messages = {} 24 | 25 | with click.progressbar(channels, label="Downloading channel messages...") as bar: 26 | for channel in bar: 27 | if channel['id'] in existingMessages: 28 | messages[channel['id']] = existingMessages[channel['id']] 29 | continue 30 | 31 | if channel["is_private"] == False: 32 | client.conversations_join(channel=channel['id']) 33 | 34 | res = client.conversations_history(channel=channel['id'], limit=300) 35 | 36 | messages[channel['id']] = res['messages'] 37 | 38 | if not os.path.exists("json_data"): 39 | os.mkdir("json_data") 40 | 41 | messagesJson = json.dumps(messages) 42 | messagesFile = open('json_data/messages.json', 'w', encoding='utf-8') 43 | messagesFile.write(messagesJson) 44 | 45 | return messages -------------------------------------------------------------------------------- /generation/main.py: -------------------------------------------------------------------------------- 1 | import click 2 | from dotenv import load_dotenv 3 | 4 | from download.channels import download_channels 5 | from download.messages import download_messages 6 | from download.members import download_members 7 | from process.similarity import process_similarity 8 | from process.labels import process_labels 9 | from process.filters import process_filters 10 | from process.graph import process_graph 11 | from process.geojson import process_geojson 12 | from query.random_similarity_indices import query_random_similarity_indices 13 | from all import run_all 14 | 15 | load_dotenv() 16 | 17 | @click.group() 18 | def root(): 19 | pass 20 | 21 | @root.command() 22 | def all(): 23 | run_all() 24 | 25 | @root.group() 26 | def download(): 27 | pass 28 | 29 | @download.command() 30 | def channels(): 31 | download_channels() 32 | 33 | @download.command() 34 | def messages(): 35 | download_messages() 36 | 37 | @download.command() 38 | def members(): 39 | download_members() 40 | 41 | @root.group() 42 | def process(): 43 | pass 44 | 45 | @process.command() 46 | def similarity(): 47 | process_similarity() 48 | 49 | @process.command() 50 | def labels(): 51 | process_labels() 52 | 53 | @process.command() 54 | def filters(): 55 | process_filters() 56 | 57 | @process.command() 58 | def graph(): 59 | process_graph() 60 | 61 | @process.command() 62 | def geojson(): 63 | process_geojson() 64 | 65 | @root.group() 66 | def query(): 67 | pass 68 | 69 | @query.command() 70 | def random_similarity_indices(): 71 | query_random_similarity_indices() 72 | 73 | if __name__ == '__main__': 74 | root() 75 | 76 | 77 | -------------------------------------------------------------------------------- /generation/process/filters.py: -------------------------------------------------------------------------------- 1 | import json 2 | import click 3 | from os.path import exists 4 | from time import time 5 | 6 | def process_filters(): 7 | if not exists("json_data/channels.json"): 8 | click.echo("Channels not downloaded. Please run `python main.py download channels` first.") 9 | return 10 | 11 | channelsFile = open('json_data/channels.json', 'r', encoding='utf-8') 12 | channels = json.loads(channelsFile.read()) 13 | 14 | if not exists("json_data/messages.json"): 15 | click.echo("Messages not downloaded. Please run `python main.py download messages` first.") 16 | return 17 | 18 | messagesFile = open('json_data/messages.json', 'r', encoding='utf-8') 19 | raw_messages = json.loads(messagesFile.read()) 20 | 21 | filtered_channels = [] 22 | 23 | with click.progressbar(channels, label="Filtering channels...") as bar: 24 | for channel in bar: 25 | def is_usr_msg(m): 26 | if "subtype" in m: 27 | return False 28 | else: 29 | return True 30 | 31 | filtered_messages = list(filter(is_usr_msg, raw_messages[channel["id"]])) 32 | 33 | if len(filtered_messages) == 0: 34 | continue 35 | 36 | def get_ts(m): 37 | return float(m["ts"]) 38 | 39 | sorted_messages = filtered_messages 40 | sorted_messages.sort(key=get_ts, reverse=True) 41 | 42 | # has messages within a year 43 | has_recent_messages = time() - float(sorted_messages[0]["ts"]) < 31536000 44 | 45 | if (has_recent_messages): 46 | filtered_channels.append(channel) 47 | 48 | filtered_channels_json = json.dumps(filtered_channels) 49 | filtered_channels_file = open('json_data/filtered_channels.json', 'w', encoding='utf-8') 50 | filtered_channels_file.write(filtered_channels_json) 51 | 52 | return filtered_channels -------------------------------------------------------------------------------- /generation/process/geojson.py: -------------------------------------------------------------------------------- 1 | import click 2 | from os.path import exists 3 | import json 4 | 5 | def process_geojson(): 6 | if not exists("json_data/filtered_channels.json"): 7 | click.echo("Channels not filtered. Please run `python main.py process filters` first.") 8 | return 9 | 10 | channelsFile = open('json_data/filtered_channels.json', 'r', encoding='utf-8') 11 | channels = list(json.loads(channelsFile.read())) 12 | 13 | if not exists("json_data/nodes.json"): 14 | click.echo("Map nodes not generated. Please run `python main.py process graph` first.") 15 | return 16 | 17 | nodes_file = open('json_data/nodes.json', 'r', encoding='utf-8') 18 | nodes = dict(json.loads(nodes_file.read())) 19 | 20 | edges_file = open('json_data/edges.json', 'r', encoding='utf-8') 21 | edges = list(json.loads(edges_file.read())) 22 | 23 | click.echo("Generating geojson...") 24 | 25 | geojsons = [] 26 | for node in nodes.keys(): 27 | geojson = { 28 | "type": "Feature", 29 | "geometry": { 30 | "type": "Point", 31 | "coordinates": nodes[node] 32 | }, 33 | "properties": { 34 | "name": find_channel(channels, node)["name"] 35 | } 36 | } 37 | geojsons.append(geojson) 38 | 39 | lines = [] 40 | for edge in edges: 41 | edgeA = edge.split('-')[0] 42 | edgeB = edge.split('-')[1] 43 | geojson = [nodes[edgeA], nodes[edgeB]] 44 | lines.append(geojson) 45 | 46 | geojsons.append({ 47 | "type": "Feature", 48 | "geometry": { 49 | "type": "MultiLineString", 50 | "coordinates": lines 51 | }, 52 | "properties": { 53 | "name": "Connections" 54 | } 55 | }) 56 | 57 | full_geojson = { 58 | "type": "FeatureCollection", 59 | "features": geojsons 60 | } 61 | 62 | geojson_json = json.dumps(full_geojson) 63 | geojson_file = open('json_data/geojson.json', 'w', encoding='utf-8') 64 | geojson_file.write(geojson_json) 65 | 66 | def find_channel(channels, node): 67 | for channel in channels: 68 | if channel["id"] == node: 69 | return channel 70 | 71 | -------------------------------------------------------------------------------- /generation/process/graph.py: -------------------------------------------------------------------------------- 1 | import json 2 | import click 3 | import igraph as ig 4 | from os.path import exists 5 | import re 6 | 7 | def find_channel_name(channels, channelId): 8 | for channel in channels: 9 | if channel["id"] == channelId: 10 | return channel["name"] 11 | 12 | def process_graph(): 13 | g = ig.Graph() 14 | 15 | if not exists("json_data/similarity_indices.json"): 16 | click.echo("Similarities not processed. Please run `python main.py process similarity` first.") 17 | return 18 | 19 | file = open("json_data/similarity_indices.json", "r", encoding="utf-8") 20 | data = dict(json.load(file)) 21 | 22 | edges = [] 23 | 24 | with click.progressbar(list(data.items()), label="Building graph...") as bar: 25 | for (key, value) in bar: 26 | if float(value) < 0.2: 27 | continue 28 | 29 | channelA = str(key).split('-')[0] 30 | channelB = str(key).split('-')[1] 31 | 32 | try: 33 | g.vs.find(name=channelA) 34 | except: 35 | g.add_vertex(channelA) 36 | 37 | try: 38 | g.vs.find(name=channelB) 39 | except: 40 | g.add_vertex(channelB) 41 | 42 | g.add_edge(channelA, channelB, weight=float(value)) 43 | edges.append(f'{channelA}-{channelB}') 44 | 45 | click.echo("Plotting graph...") 46 | 47 | clustered = g.community_leiden(weights=g.es["weight"], resolution=0.1, n_iterations=50) 48 | click.echo(clustered.summary()) 49 | layout = g.layout("drl") 50 | 51 | cplot = ig.plot(clustered, None, layout=layout, bbox=(50, 50)) 52 | objstr = re.split(r'\[\s*\d\] ', str(cplot._objects[0][0])) 53 | objstr.pop(0) 54 | 55 | def mapc(c: str): 56 | ids = c.strip().split(',') 57 | ids = map(lambda id: id.strip(), ids) 58 | 59 | return ids 60 | 61 | clusters = map(mapc, objstr) 62 | objects = [] 63 | for cluster in clusters: 64 | for obj in cluster: 65 | # click.echo(obj) 66 | for n in obj.split('\n'): 67 | objects.append(re.split(r'\[.+\] ', n)[-1]) 68 | # click.echo("cluster") 69 | 70 | nodes = {} 71 | for i in range(len(objects)): 72 | key = objects[i] 73 | nodes[key] = cplot._objects[0][5]['layout'].__dict__['_coords'][i] 74 | 75 | nodes_json = json.dumps(nodes) 76 | nodes_file = open('json_data/nodes.json', 'w', encoding='utf-8') 77 | nodes_file.write(nodes_json) 78 | 79 | edges_json = json.dumps(edges) 80 | edges_file = open('json_data/edges.json', 'w', encoding='utf-8') 81 | edges_file.write(edges_json) -------------------------------------------------------------------------------- /generation/process/labels.py: -------------------------------------------------------------------------------- 1 | import json 2 | import spacy 3 | import click 4 | from os.path import exists 5 | 6 | def process_labels(): 7 | if not exists("json_data/filtered_channels.json"): 8 | click.echo("Channels not filtered. Please run `python main.py process filters` first.") 9 | return 10 | 11 | channelsFile = open('json_data/filtered_channels.json', 'r', encoding='utf-8') 12 | channels = json.loads(channelsFile.read()) 13 | 14 | if not exists("json_data/messages.json"): 15 | click.echo("Messages not downloaded. Please run `python main.py download messages` first.") 16 | return 17 | 18 | messagesFile = open('json_data/messages.json', 'r', encoding='utf-8') 19 | raw_messages = json.loads(messagesFile.read()) 20 | 21 | if not exists("json_data/members.json"): 22 | click.echo("Members not downloaded. Please run `python main.py download members` first.") 23 | return 24 | 25 | membersFile = open('json_data/members.json', 'r', encoding='utf-8') 26 | members = json.loads(membersFile.read()) 27 | 28 | nlp = spacy.load("en_core_web_lg") 29 | 30 | all_labels = {} 31 | 32 | with click.progressbar(channels, label="Generating labels...") as bar: 33 | for channel in bar: 34 | num_str = "" 35 | num = channel['num_members'] 36 | 37 | if num > 1000: 38 | num_str = "nm-2xl" 39 | elif num > 500: 40 | num_str = "nm-xl" 41 | elif num > 100: 42 | num_str = "nm-lg" 43 | elif num > 50: 44 | num_str = "nm-md" 45 | elif num > 20: 46 | num_str = "nm-sm" 47 | else: 48 | num_str = "nm-xs" 49 | 50 | description = channel['purpose']['value'] 51 | topic = channel['topic']['value'] 52 | 53 | messages_str = "" 54 | msgs = raw_messages[channel['id']] 55 | 56 | for message in msgs: 57 | if 'text' in message: 58 | messages_str = messages_str + " " + message['text'] 59 | 60 | nameBits = map(lambda b: (b, 10), channel['name'].split('-')) 61 | member_labels = map(lambda m: (m, 5), members[channel['id']]) 62 | descDoc = nlp(description[0:1000000]) 63 | topicDoc = nlp(topic) 64 | # Limiting to 1 million characters to avoid memory issues 65 | msgDoc = nlp(messages_str[0:1000000]) 66 | 67 | channel_labels = [*nameBits, *member_labels, (num_str, 5)] 68 | 69 | for ent in descDoc.ents: 70 | channel_labels.append((ent.text, 10)) 71 | 72 | for ent in topicDoc.ents: 73 | channel_labels.append((ent.text, 10)) 74 | 75 | for ent in msgDoc.ents: 76 | try: 77 | int(ent.text) 78 | except: 79 | channel_labels.append((ent.text, 3)) 80 | 81 | all_labels[channel['id']] = channel_labels 82 | 83 | labels_json = json.dumps(all_labels) 84 | channelsFile = open('json_data/labels.json', 'w', encoding='utf-8') 85 | channelsFile.write(labels_json) 86 | 87 | return all_labels -------------------------------------------------------------------------------- /generation/process/similarity.py: -------------------------------------------------------------------------------- 1 | import json 2 | from os.path import exists 3 | import click 4 | 5 | def process_similarity(): 6 | if not exists("json_data/labels.json"): 7 | click.echo("Labels not generated. Please run `python main.py process labels` first.") 8 | return 9 | 10 | labelsFile = open('json_data/labels.json', 'r', encoding='utf-8') 11 | labels = json.loads(labelsFile.read()) 12 | 13 | indices = {} 14 | 15 | with click.progressbar(labels, label="Generating similarity indices...") as bar: 16 | for channelA in bar: 17 | for channelB in labels: 18 | if channelA == channelB: 19 | continue 20 | 21 | channelALabels = list(map(lambda l: l[0], labels[channelA])) 22 | channelBLabels = list(map(lambda l: l[0], labels[channelB])) 23 | sum = labels[channelA] + labels[channelB] 24 | union = [] 25 | added = [] 26 | for l in sum: 27 | if not l[0] in added: 28 | union.append(l) 29 | added.append(l[0]) 30 | 31 | channelAList = list(map(lambda l: int(l[0] in channelALabels) * l[1], union)) 32 | channelBList = list(map(lambda l: int(l[0] in channelBLabels) * l[1], union)) 33 | 34 | numerator = 0; 35 | for i in range(len(channelAList)): 36 | numerator += min(channelAList[i], channelBList[i]) 37 | 38 | denominator = 0; 39 | for i in range(len(channelAList)): 40 | denominator += max(channelAList[i], channelBList[i]) 41 | 42 | jaccard = numerator / denominator 43 | 44 | indices[channelA + "-" + channelB] = jaccard 45 | 46 | similarityIndicesFile = open('json_data/similarity_indices.json', 'w', encoding='utf-8') 47 | similarityIndicesFile.write(json.dumps(indices)) 48 | 49 | return indices -------------------------------------------------------------------------------- /generation/query/random_similarity_indices.py: -------------------------------------------------------------------------------- 1 | import random 2 | import json 3 | from os.path import exists 4 | import click 5 | 6 | def query_random_similarity_indices(): 7 | if not exists("json_data/similarity_indices.json"): 8 | click.echo("Similarities not processed. Please run `python main.py process similarity` first.") 9 | return 10 | 11 | file = open("json_data/similarity_indices.json", "r", encoding="utf-8") 12 | similarity_indices = json.loads(file.read()) 13 | 14 | rand_indices = random.choices(list(similarity_indices.keys()), k=10) 15 | 16 | for i in range(0, len(rand_indices)): 17 | print(rand_indices[i] + ": " + str(similarity_indices[rand_indices[i]])) 18 | 19 | return rand_indices 20 | -------------------------------------------------------------------------------- /generation/requirements.txt: -------------------------------------------------------------------------------- 1 | annotated-types==0.6.0 2 | blis==0.7.11 3 | catalogue==2.0.10 4 | certifi==2023.7.22 5 | charset-normalizer==3.3.1 6 | click==8.1.7 7 | cloudpathlib==0.16.0 8 | confection==0.1.3 9 | cymem==2.0.8 10 | idna==3.4 11 | igraph==0.11.5 12 | Jinja2==3.1.2 13 | langcodes==3.3.0 14 | MarkupSafe==2.1.3 15 | murmurhash==1.0.10 16 | numpy==1.26.1 17 | packaging==23.2 18 | preshed==3.0.9 19 | pycairo==1.26.0 20 | pydantic==2.4.2 21 | pydantic_core==2.10.1 22 | python-dotenv==1.0.0 23 | requests==2.31.0 24 | slack-sdk==3.23.0 25 | smart-open==6.4.0 26 | spacy==3.7.2 27 | spacy-legacy==3.0.12 28 | spacy-loggers==1.0.5 29 | srsly==2.4.8 30 | texttable==1.7.0 31 | thinc==8.2.1 32 | tqdm==4.66.1 33 | typer==0.9.0 34 | typing_extensions==4.8.0 35 | urllib3==2.0.7 36 | wasabi==1.1.2 37 | weasel==0.3.3 38 | -------------------------------------------------------------------------------- /generation/sample.env: -------------------------------------------------------------------------------- 1 | # Bot token from Slack API, starts with xoxb 2 | SLACK_BOT_TOKEN= -------------------------------------------------------------------------------- /generation/slack_manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "display_information": { 3 | "name": "Map of the Slack" 4 | }, 5 | "features": { 6 | "bot_user": { 7 | "display_name": "Map of the Slack", 8 | "always_online": false 9 | } 10 | }, 11 | "oauth_config": { 12 | "scopes": { 13 | "bot": [ 14 | "channels:history", 15 | "channels:join", 16 | "channels:read", 17 | "groups:history", 18 | "groups:read" 19 | ] 20 | } 21 | }, 22 | "settings": { 23 | "org_deploy_enabled": false, 24 | "socket_mode_enabled": false, 25 | "token_rotation_enabled": false 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /generation/util/slack_client.py: -------------------------------------------------------------------------------- 1 | from slack_sdk.http_retry.builtin_handlers import RateLimitErrorRetryHandler 2 | from slack_sdk.web import WebClient 3 | import os 4 | 5 | def getClient(): 6 | client = WebClient(token=os.environ["SLACK_BOT_TOKEN"]) 7 | rate_limit_handler = RateLimitErrorRetryHandler(max_retry_count=1) 8 | 9 | client.retry_handlers.append(rate_limit_handler) 10 | 11 | return client -------------------------------------------------------------------------------- /jsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./.svelte-kit/tsconfig.json", 3 | "compilerOptions": { 4 | "allowJs": true, 5 | "checkJs": true, 6 | "esModuleInterop": true, 7 | "forceConsistentCasingInFileNames": true, 8 | "resolveJsonModule": true, 9 | "skipLibCheck": true, 10 | "sourceMap": true, 11 | "strict": true 12 | } 13 | // Path aliases are handled by https://kit.svelte.dev/docs/configuration#alias and https://kit.svelte.dev/docs/configuration#files 14 | // 15 | // If you want to overwrite includes/excludes, make sure to copy over the relevant includes/excludes 16 | // from the referenced tsconfig.json - TypeScript does not merge them in 17 | } 18 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "map-of-the-slack", 3 | "version": "0.0.1", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "map-of-the-slack", 9 | "version": "0.0.1", 10 | "dependencies": { 11 | "@prisma/client": "^4.15.0", 12 | "svelte-maplibre": "^0.7.5" 13 | }, 14 | "devDependencies": { 15 | "@fontsource/fira-mono": "^4.5.10", 16 | "@neoconfetti/svelte": "^1.0.0", 17 | "@sveltejs/adapter-auto": "^2.0.0", 18 | "@sveltejs/kit": "^1.5.0", 19 | "@types/cookie": "^0.5.1", 20 | "autoprefixer": "^10.4.19", 21 | "postcss": "^8.4.38", 22 | "prettier": "^3.2.5", 23 | "prettier-plugin-svelte": "^3.2.3", 24 | "prettier-plugin-tailwindcss": "^0.5.14", 25 | "prisma": "^4.15.0", 26 | "svelte": "^3.54.0", 27 | "svelte-check": "^3.0.1", 28 | "tailwindcss": "^3.4.3", 29 | "typescript": "^5.0.0", 30 | "vite": "^4.3.0" 31 | } 32 | }, 33 | "node_modules/@alloc/quick-lru": { 34 | "version": "5.2.0", 35 | "resolved": "https://registry.npmjs.org/@alloc/quick-lru/-/quick-lru-5.2.0.tgz", 36 | "integrity": "sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==", 37 | "dev": true, 38 | "engines": { 39 | "node": ">=10" 40 | }, 41 | "funding": { 42 | "url": "https://github.com/sponsors/sindresorhus" 43 | } 44 | }, 45 | "node_modules/@esbuild/android-arm": { 46 | "version": "0.17.19", 47 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", 48 | "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", 49 | "cpu": [ 50 | "arm" 51 | ], 52 | "dev": true, 53 | "optional": true, 54 | "os": [ 55 | "android" 56 | ], 57 | "engines": { 58 | "node": ">=12" 59 | } 60 | }, 61 | "node_modules/@esbuild/android-arm64": { 62 | "version": "0.17.19", 63 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", 64 | "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", 65 | "cpu": [ 66 | "arm64" 67 | ], 68 | "dev": true, 69 | "optional": true, 70 | "os": [ 71 | "android" 72 | ], 73 | "engines": { 74 | "node": ">=12" 75 | } 76 | }, 77 | "node_modules/@esbuild/android-x64": { 78 | "version": "0.17.19", 79 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", 80 | "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", 81 | "cpu": [ 82 | "x64" 83 | ], 84 | "dev": true, 85 | "optional": true, 86 | "os": [ 87 | "android" 88 | ], 89 | "engines": { 90 | "node": ">=12" 91 | } 92 | }, 93 | "node_modules/@esbuild/darwin-arm64": { 94 | "version": "0.17.19", 95 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", 96 | "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", 97 | "cpu": [ 98 | "arm64" 99 | ], 100 | "dev": true, 101 | "optional": true, 102 | "os": [ 103 | "darwin" 104 | ], 105 | "engines": { 106 | "node": ">=12" 107 | } 108 | }, 109 | "node_modules/@esbuild/darwin-x64": { 110 | "version": "0.17.19", 111 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", 112 | "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", 113 | "cpu": [ 114 | "x64" 115 | ], 116 | "dev": true, 117 | "optional": true, 118 | "os": [ 119 | "darwin" 120 | ], 121 | "engines": { 122 | "node": ">=12" 123 | } 124 | }, 125 | "node_modules/@esbuild/freebsd-arm64": { 126 | "version": "0.17.19", 127 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", 128 | "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", 129 | "cpu": [ 130 | "arm64" 131 | ], 132 | "dev": true, 133 | "optional": true, 134 | "os": [ 135 | "freebsd" 136 | ], 137 | "engines": { 138 | "node": ">=12" 139 | } 140 | }, 141 | "node_modules/@esbuild/freebsd-x64": { 142 | "version": "0.17.19", 143 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", 144 | "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", 145 | "cpu": [ 146 | "x64" 147 | ], 148 | "dev": true, 149 | "optional": true, 150 | "os": [ 151 | "freebsd" 152 | ], 153 | "engines": { 154 | "node": ">=12" 155 | } 156 | }, 157 | "node_modules/@esbuild/linux-arm": { 158 | "version": "0.17.19", 159 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", 160 | "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", 161 | "cpu": [ 162 | "arm" 163 | ], 164 | "dev": true, 165 | "optional": true, 166 | "os": [ 167 | "linux" 168 | ], 169 | "engines": { 170 | "node": ">=12" 171 | } 172 | }, 173 | "node_modules/@esbuild/linux-arm64": { 174 | "version": "0.17.19", 175 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", 176 | "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", 177 | "cpu": [ 178 | "arm64" 179 | ], 180 | "dev": true, 181 | "optional": true, 182 | "os": [ 183 | "linux" 184 | ], 185 | "engines": { 186 | "node": ">=12" 187 | } 188 | }, 189 | "node_modules/@esbuild/linux-ia32": { 190 | "version": "0.17.19", 191 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", 192 | "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", 193 | "cpu": [ 194 | "ia32" 195 | ], 196 | "dev": true, 197 | "optional": true, 198 | "os": [ 199 | "linux" 200 | ], 201 | "engines": { 202 | "node": ">=12" 203 | } 204 | }, 205 | "node_modules/@esbuild/linux-loong64": { 206 | "version": "0.17.19", 207 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", 208 | "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", 209 | "cpu": [ 210 | "loong64" 211 | ], 212 | "dev": true, 213 | "optional": true, 214 | "os": [ 215 | "linux" 216 | ], 217 | "engines": { 218 | "node": ">=12" 219 | } 220 | }, 221 | "node_modules/@esbuild/linux-mips64el": { 222 | "version": "0.17.19", 223 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", 224 | "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", 225 | "cpu": [ 226 | "mips64el" 227 | ], 228 | "dev": true, 229 | "optional": true, 230 | "os": [ 231 | "linux" 232 | ], 233 | "engines": { 234 | "node": ">=12" 235 | } 236 | }, 237 | "node_modules/@esbuild/linux-ppc64": { 238 | "version": "0.17.19", 239 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", 240 | "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", 241 | "cpu": [ 242 | "ppc64" 243 | ], 244 | "dev": true, 245 | "optional": true, 246 | "os": [ 247 | "linux" 248 | ], 249 | "engines": { 250 | "node": ">=12" 251 | } 252 | }, 253 | "node_modules/@esbuild/linux-riscv64": { 254 | "version": "0.17.19", 255 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", 256 | "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", 257 | "cpu": [ 258 | "riscv64" 259 | ], 260 | "dev": true, 261 | "optional": true, 262 | "os": [ 263 | "linux" 264 | ], 265 | "engines": { 266 | "node": ">=12" 267 | } 268 | }, 269 | "node_modules/@esbuild/linux-s390x": { 270 | "version": "0.17.19", 271 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", 272 | "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", 273 | "cpu": [ 274 | "s390x" 275 | ], 276 | "dev": true, 277 | "optional": true, 278 | "os": [ 279 | "linux" 280 | ], 281 | "engines": { 282 | "node": ">=12" 283 | } 284 | }, 285 | "node_modules/@esbuild/linux-x64": { 286 | "version": "0.17.19", 287 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", 288 | "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", 289 | "cpu": [ 290 | "x64" 291 | ], 292 | "dev": true, 293 | "optional": true, 294 | "os": [ 295 | "linux" 296 | ], 297 | "engines": { 298 | "node": ">=12" 299 | } 300 | }, 301 | "node_modules/@esbuild/netbsd-x64": { 302 | "version": "0.17.19", 303 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", 304 | "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", 305 | "cpu": [ 306 | "x64" 307 | ], 308 | "dev": true, 309 | "optional": true, 310 | "os": [ 311 | "netbsd" 312 | ], 313 | "engines": { 314 | "node": ">=12" 315 | } 316 | }, 317 | "node_modules/@esbuild/openbsd-x64": { 318 | "version": "0.17.19", 319 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", 320 | "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", 321 | "cpu": [ 322 | "x64" 323 | ], 324 | "dev": true, 325 | "optional": true, 326 | "os": [ 327 | "openbsd" 328 | ], 329 | "engines": { 330 | "node": ">=12" 331 | } 332 | }, 333 | "node_modules/@esbuild/sunos-x64": { 334 | "version": "0.17.19", 335 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", 336 | "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", 337 | "cpu": [ 338 | "x64" 339 | ], 340 | "dev": true, 341 | "optional": true, 342 | "os": [ 343 | "sunos" 344 | ], 345 | "engines": { 346 | "node": ">=12" 347 | } 348 | }, 349 | "node_modules/@esbuild/win32-arm64": { 350 | "version": "0.17.19", 351 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", 352 | "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", 353 | "cpu": [ 354 | "arm64" 355 | ], 356 | "dev": true, 357 | "optional": true, 358 | "os": [ 359 | "win32" 360 | ], 361 | "engines": { 362 | "node": ">=12" 363 | } 364 | }, 365 | "node_modules/@esbuild/win32-ia32": { 366 | "version": "0.17.19", 367 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", 368 | "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", 369 | "cpu": [ 370 | "ia32" 371 | ], 372 | "dev": true, 373 | "optional": true, 374 | "os": [ 375 | "win32" 376 | ], 377 | "engines": { 378 | "node": ">=12" 379 | } 380 | }, 381 | "node_modules/@esbuild/win32-x64": { 382 | "version": "0.17.19", 383 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", 384 | "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", 385 | "cpu": [ 386 | "x64" 387 | ], 388 | "dev": true, 389 | "optional": true, 390 | "os": [ 391 | "win32" 392 | ], 393 | "engines": { 394 | "node": ">=12" 395 | } 396 | }, 397 | "node_modules/@fontsource/fira-mono": { 398 | "version": "4.5.10", 399 | "resolved": "https://registry.npmjs.org/@fontsource/fira-mono/-/fira-mono-4.5.10.tgz", 400 | "integrity": "sha512-bxUnRP8xptGRo8YXeY073DSpfK74XpSb0ZyRNpHV9WvLnJ7TwPOjZll8hTMin7zLC6iOp59pDZ8EQDj1gzgAQQ==", 401 | "dev": true 402 | }, 403 | "node_modules/@isaacs/cliui": { 404 | "version": "8.0.2", 405 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", 406 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", 407 | "dev": true, 408 | "dependencies": { 409 | "string-width": "^5.1.2", 410 | "string-width-cjs": "npm:string-width@^4.2.0", 411 | "strip-ansi": "^7.0.1", 412 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", 413 | "wrap-ansi": "^8.1.0", 414 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" 415 | }, 416 | "engines": { 417 | "node": ">=12" 418 | } 419 | }, 420 | "node_modules/@jridgewell/gen-mapping": { 421 | "version": "0.3.5", 422 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", 423 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", 424 | "dev": true, 425 | "dependencies": { 426 | "@jridgewell/set-array": "^1.2.1", 427 | "@jridgewell/sourcemap-codec": "^1.4.10", 428 | "@jridgewell/trace-mapping": "^0.3.24" 429 | }, 430 | "engines": { 431 | "node": ">=6.0.0" 432 | } 433 | }, 434 | "node_modules/@jridgewell/resolve-uri": { 435 | "version": "3.1.0", 436 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 437 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 438 | "dev": true, 439 | "engines": { 440 | "node": ">=6.0.0" 441 | } 442 | }, 443 | "node_modules/@jridgewell/set-array": { 444 | "version": "1.2.1", 445 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 446 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 447 | "dev": true, 448 | "engines": { 449 | "node": ">=6.0.0" 450 | } 451 | }, 452 | "node_modules/@jridgewell/sourcemap-codec": { 453 | "version": "1.4.15", 454 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 455 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 456 | "dev": true 457 | }, 458 | "node_modules/@jridgewell/trace-mapping": { 459 | "version": "0.3.25", 460 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 461 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 462 | "dev": true, 463 | "dependencies": { 464 | "@jridgewell/resolve-uri": "^3.1.0", 465 | "@jridgewell/sourcemap-codec": "^1.4.14" 466 | } 467 | }, 468 | "node_modules/@mapbox/geojson-rewind": { 469 | "version": "0.5.2", 470 | "resolved": "https://registry.npmjs.org/@mapbox/geojson-rewind/-/geojson-rewind-0.5.2.tgz", 471 | "integrity": "sha512-tJaT+RbYGJYStt7wI3cq4Nl4SXxG8W7JDG5DMJu97V25RnbNg3QtQtf+KD+VLjNpWKYsRvXDNmNrBgEETr1ifA==", 472 | "dependencies": { 473 | "get-stream": "^6.0.1", 474 | "minimist": "^1.2.6" 475 | }, 476 | "bin": { 477 | "geojson-rewind": "geojson-rewind" 478 | } 479 | }, 480 | "node_modules/@mapbox/jsonlint-lines-primitives": { 481 | "version": "2.0.2", 482 | "resolved": "https://registry.npmjs.org/@mapbox/jsonlint-lines-primitives/-/jsonlint-lines-primitives-2.0.2.tgz", 483 | "integrity": "sha512-rY0o9A5ECsTQRVhv7tL/OyDpGAoUB4tTvLiW1DSzQGq4bvTPhNw1VpSNjDJc5GFZ2XuyOtSWSVN05qOtcD71qQ==", 484 | "engines": { 485 | "node": ">= 0.6" 486 | } 487 | }, 488 | "node_modules/@mapbox/point-geometry": { 489 | "version": "0.1.0", 490 | "resolved": "https://registry.npmjs.org/@mapbox/point-geometry/-/point-geometry-0.1.0.tgz", 491 | "integrity": "sha512-6j56HdLTwWGO0fJPlrZtdU/B13q8Uwmo18Ck2GnGgN9PCFyKTZ3UbXeEdRFh18i9XQ92eH2VdtpJHpBD3aripQ==" 492 | }, 493 | "node_modules/@mapbox/tiny-sdf": { 494 | "version": "2.0.6", 495 | "resolved": "https://registry.npmjs.org/@mapbox/tiny-sdf/-/tiny-sdf-2.0.6.tgz", 496 | "integrity": "sha512-qMqa27TLw+ZQz5Jk+RcwZGH7BQf5G/TrutJhspsca/3SHwmgKQ1iq+d3Jxz5oysPVYTGP6aXxCo5Lk9Er6YBAA==" 497 | }, 498 | "node_modules/@mapbox/unitbezier": { 499 | "version": "0.0.1", 500 | "resolved": "https://registry.npmjs.org/@mapbox/unitbezier/-/unitbezier-0.0.1.tgz", 501 | "integrity": "sha512-nMkuDXFv60aBr9soUG5q+GvZYL+2KZHVvsqFCzqnkGEf46U2fvmytHaEVc1/YZbiLn8X+eR3QzX1+dwDO1lxlw==" 502 | }, 503 | "node_modules/@mapbox/vector-tile": { 504 | "version": "1.3.1", 505 | "resolved": "https://registry.npmjs.org/@mapbox/vector-tile/-/vector-tile-1.3.1.tgz", 506 | "integrity": "sha512-MCEddb8u44/xfQ3oD+Srl/tNcQoqTw3goGk2oLsrFxOTc3dUp+kAnby3PvAeeBYSMSjSPD1nd1AJA6W49WnoUw==", 507 | "dependencies": { 508 | "@mapbox/point-geometry": "~0.1.0" 509 | } 510 | }, 511 | "node_modules/@mapbox/whoots-js": { 512 | "version": "3.1.0", 513 | "resolved": "https://registry.npmjs.org/@mapbox/whoots-js/-/whoots-js-3.1.0.tgz", 514 | "integrity": "sha512-Es6WcD0nO5l+2BOQS4uLfNPYQaNDfbot3X1XUoloz+x0mPDS3eeORZJl06HXjwBG1fOGwCRnzK88LMdxKRrd6Q==", 515 | "engines": { 516 | "node": ">=6.0.0" 517 | } 518 | }, 519 | "node_modules/@maplibre/maplibre-gl-style-spec": { 520 | "version": "19.3.3", 521 | "resolved": "https://registry.npmjs.org/@maplibre/maplibre-gl-style-spec/-/maplibre-gl-style-spec-19.3.3.tgz", 522 | "integrity": "sha512-cOZZOVhDSulgK0meTsTkmNXb1ahVvmTmWmfx9gRBwc6hq98wS9JP35ESIoNq3xqEan+UN+gn8187Z6E4NKhLsw==", 523 | "dependencies": { 524 | "@mapbox/jsonlint-lines-primitives": "~2.0.2", 525 | "@mapbox/unitbezier": "^0.0.1", 526 | "json-stringify-pretty-compact": "^3.0.0", 527 | "minimist": "^1.2.8", 528 | "rw": "^1.3.3", 529 | "sort-object": "^3.0.3" 530 | }, 531 | "bin": { 532 | "gl-style-format": "dist/gl-style-format.mjs", 533 | "gl-style-migrate": "dist/gl-style-migrate.mjs", 534 | "gl-style-validate": "dist/gl-style-validate.mjs" 535 | } 536 | }, 537 | "node_modules/@neoconfetti/svelte": { 538 | "version": "1.0.0", 539 | "resolved": "https://registry.npmjs.org/@neoconfetti/svelte/-/svelte-1.0.0.tgz", 540 | "integrity": "sha512-SmksyaJAdSlMa9cTidVSIqYo1qti+WTsviNDwgjNVm+KQ3DRP2Df9umDIzC4vCcpEYY+chQe0i2IKnLw03AT8Q==", 541 | "dev": true 542 | }, 543 | "node_modules/@nodelib/fs.scandir": { 544 | "version": "2.1.5", 545 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 546 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 547 | "dev": true, 548 | "dependencies": { 549 | "@nodelib/fs.stat": "2.0.5", 550 | "run-parallel": "^1.1.9" 551 | }, 552 | "engines": { 553 | "node": ">= 8" 554 | } 555 | }, 556 | "node_modules/@nodelib/fs.stat": { 557 | "version": "2.0.5", 558 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 559 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 560 | "dev": true, 561 | "engines": { 562 | "node": ">= 8" 563 | } 564 | }, 565 | "node_modules/@nodelib/fs.walk": { 566 | "version": "1.2.8", 567 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 568 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 569 | "dev": true, 570 | "dependencies": { 571 | "@nodelib/fs.scandir": "2.1.5", 572 | "fastq": "^1.6.0" 573 | }, 574 | "engines": { 575 | "node": ">= 8" 576 | } 577 | }, 578 | "node_modules/@pkgjs/parseargs": { 579 | "version": "0.11.0", 580 | "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", 581 | "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", 582 | "dev": true, 583 | "optional": true, 584 | "engines": { 585 | "node": ">=14" 586 | } 587 | }, 588 | "node_modules/@polka/url": { 589 | "version": "1.0.0-next.21", 590 | "resolved": "https://registry.npmjs.org/@polka/url/-/url-1.0.0-next.21.tgz", 591 | "integrity": "sha512-a5Sab1C4/icpTZVzZc5Ghpz88yQtGOyNqYXcZgOssB2uuAr+wF/MvN6bgtW32q7HHrvBki+BsZ0OuNv6EV3K9g==", 592 | "dev": true 593 | }, 594 | "node_modules/@prisma/client": { 595 | "version": "4.15.0", 596 | "resolved": "https://registry.npmjs.org/@prisma/client/-/client-4.15.0.tgz", 597 | "integrity": "sha512-xnROvyABcGiwqRNdrObHVZkD9EjkJYHOmVdlKy1yGgI+XOzvMzJ4tRg3dz1pUlsyhKxXGCnjIQjWW+2ur+YXuw==", 598 | "hasInstallScript": true, 599 | "dependencies": { 600 | "@prisma/engines-version": "4.15.0-28.8fbc245156db7124f997f4cecdd8d1219e360944" 601 | }, 602 | "engines": { 603 | "node": ">=14.17" 604 | }, 605 | "peerDependencies": { 606 | "prisma": "*" 607 | }, 608 | "peerDependenciesMeta": { 609 | "prisma": { 610 | "optional": true 611 | } 612 | } 613 | }, 614 | "node_modules/@prisma/engines": { 615 | "version": "4.15.0", 616 | "resolved": "https://registry.npmjs.org/@prisma/engines/-/engines-4.15.0.tgz", 617 | "integrity": "sha512-FTaOCGs0LL0OW68juZlGxFtYviZa4xdQj/rQEdat2txw0s3Vu/saAPKjNVXfIgUsGXmQ72HPgNr6935/P8FNAA==", 618 | "devOptional": true, 619 | "hasInstallScript": true 620 | }, 621 | "node_modules/@prisma/engines-version": { 622 | "version": "4.15.0-28.8fbc245156db7124f997f4cecdd8d1219e360944", 623 | "resolved": "https://registry.npmjs.org/@prisma/engines-version/-/engines-version-4.15.0-28.8fbc245156db7124f997f4cecdd8d1219e360944.tgz", 624 | "integrity": "sha512-sVOig4tjGxxlYaFcXgE71f/rtFhzyYrfyfNFUsxCIEJyVKU9rdOWIlIwQ2NQ7PntvGnn+x0XuFo4OC1jvPJKzg==" 625 | }, 626 | "node_modules/@sveltejs/adapter-auto": { 627 | "version": "2.1.0", 628 | "resolved": "https://registry.npmjs.org/@sveltejs/adapter-auto/-/adapter-auto-2.1.0.tgz", 629 | "integrity": "sha512-o2pZCfATFtA/Gw/BB0Xm7k4EYaekXxaPGER3xGSY3FvzFJGTlJlZjBseaXwYSM94lZ0HniOjTokN3cWaLX6fow==", 630 | "dev": true, 631 | "dependencies": { 632 | "import-meta-resolve": "^3.0.0" 633 | }, 634 | "peerDependencies": { 635 | "@sveltejs/kit": "^1.0.0" 636 | } 637 | }, 638 | "node_modules/@sveltejs/kit": { 639 | "version": "1.20.1", 640 | "resolved": "https://registry.npmjs.org/@sveltejs/kit/-/kit-1.20.1.tgz", 641 | "integrity": "sha512-iZ7PvbM45sdLR3KIXFTbwIwP4PmeO/7JdNdpKRc/T9xMgDabNlPhL1gnJ/Hi1w00g4nc3Zpo/HNrzbRmuOnUjQ==", 642 | "dev": true, 643 | "hasInstallScript": true, 644 | "dependencies": { 645 | "@sveltejs/vite-plugin-svelte": "^2.4.1", 646 | "@types/cookie": "^0.5.1", 647 | "cookie": "^0.5.0", 648 | "devalue": "^4.3.1", 649 | "esm-env": "^1.0.0", 650 | "kleur": "^4.1.5", 651 | "magic-string": "^0.30.0", 652 | "mime": "^3.0.0", 653 | "sade": "^1.8.1", 654 | "set-cookie-parser": "^2.6.0", 655 | "sirv": "^2.0.2", 656 | "tiny-glob": "^0.2.9", 657 | "undici": "~5.22.0" 658 | }, 659 | "bin": { 660 | "svelte-kit": "svelte-kit.js" 661 | }, 662 | "engines": { 663 | "node": "^16.14 || >=18" 664 | }, 665 | "peerDependencies": { 666 | "svelte": "^3.54.0 || ^4.0.0-next.0", 667 | "vite": "^4.0.0" 668 | } 669 | }, 670 | "node_modules/@sveltejs/vite-plugin-svelte": { 671 | "version": "2.4.1", 672 | "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-2.4.1.tgz", 673 | "integrity": "sha512-bNNKvoRY89ptY7udeBSCmTdCVwkjmMcZ0j/z9J5MuedT8jPjq0zrknAo/jF1sToAza4NVaAgR9AkZoD9oJJmnA==", 674 | "dev": true, 675 | "dependencies": { 676 | "@sveltejs/vite-plugin-svelte-inspector": "^1.0.2", 677 | "debug": "^4.3.4", 678 | "deepmerge": "^4.3.1", 679 | "kleur": "^4.1.5", 680 | "magic-string": "^0.30.0", 681 | "svelte-hmr": "^0.15.1", 682 | "vitefu": "^0.2.4" 683 | }, 684 | "engines": { 685 | "node": "^14.18.0 || >= 16" 686 | }, 687 | "peerDependencies": { 688 | "svelte": "^3.54.0 || ^4.0.0-next.0", 689 | "vite": "^4.0.0" 690 | } 691 | }, 692 | "node_modules/@sveltejs/vite-plugin-svelte-inspector": { 693 | "version": "1.0.2", 694 | "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte-inspector/-/vite-plugin-svelte-inspector-1.0.2.tgz", 695 | "integrity": "sha512-Cy1dUMcYCnDVV/hPLXa43YZJ2jGKVW5rA0xuNL9dlmYhT0yoS1g7+FOFSRlgk0BXKk/Oc7grs+8BVA5Iz2fr8A==", 696 | "dev": true, 697 | "dependencies": { 698 | "debug": "^4.3.4" 699 | }, 700 | "engines": { 701 | "node": "^14.18.0 || >= 16" 702 | }, 703 | "peerDependencies": { 704 | "@sveltejs/vite-plugin-svelte": "^2.2.0", 705 | "svelte": "^3.54.0 || ^4.0.0-next.0", 706 | "vite": "^4.0.0" 707 | } 708 | }, 709 | "node_modules/@types/cookie": { 710 | "version": "0.5.1", 711 | "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.5.1.tgz", 712 | "integrity": "sha512-COUnqfB2+ckwXXSFInsFdOAWQzCCx+a5hq2ruyj+Vjund94RJQd4LG2u9hnvJrTgunKAaax7ancBYlDrNYxA0g==", 713 | "dev": true 714 | }, 715 | "node_modules/@types/geojson": { 716 | "version": "7946.0.13", 717 | "resolved": "https://registry.npmjs.org/@types/geojson/-/geojson-7946.0.13.tgz", 718 | "integrity": "sha512-bmrNrgKMOhM3WsafmbGmC+6dsF2Z308vLFsQ3a/bT8X8Sv5clVYpPars/UPq+sAaJP+5OoLAYgwbkS5QEJdLUQ==" 719 | }, 720 | "node_modules/@types/mapbox__point-geometry": { 721 | "version": "0.1.4", 722 | "resolved": "https://registry.npmjs.org/@types/mapbox__point-geometry/-/mapbox__point-geometry-0.1.4.tgz", 723 | "integrity": "sha512-mUWlSxAmYLfwnRBmgYV86tgYmMIICX4kza8YnE/eIlywGe2XoOxlpVnXWwir92xRLjwyarqwpu2EJKD2pk0IUA==" 724 | }, 725 | "node_modules/@types/mapbox__vector-tile": { 726 | "version": "1.3.4", 727 | "resolved": "https://registry.npmjs.org/@types/mapbox__vector-tile/-/mapbox__vector-tile-1.3.4.tgz", 728 | "integrity": "sha512-bpd8dRn9pr6xKvuEBQup8pwQfD4VUyqO/2deGjfpe6AwC8YRlyEipvefyRJUSiCJTZuCb8Pl1ciVV5ekqJ96Bg==", 729 | "dependencies": { 730 | "@types/geojson": "*", 731 | "@types/mapbox__point-geometry": "*", 732 | "@types/pbf": "*" 733 | } 734 | }, 735 | "node_modules/@types/pbf": { 736 | "version": "3.0.5", 737 | "resolved": "https://registry.npmjs.org/@types/pbf/-/pbf-3.0.5.tgz", 738 | "integrity": "sha512-j3pOPiEcWZ34R6a6mN07mUkM4o4Lwf6hPNt8eilOeZhTFbxFXmKhvXl9Y28jotFPaI1bpPDJsbCprUoNke6OrA==" 739 | }, 740 | "node_modules/@types/pug": { 741 | "version": "2.0.6", 742 | "resolved": "https://registry.npmjs.org/@types/pug/-/pug-2.0.6.tgz", 743 | "integrity": "sha512-SnHmG9wN1UVmagJOnyo/qkk0Z7gejYxOYYmaAwr5u2yFYfsupN3sg10kyzN8Hep/2zbHxCnsumxOoRIRMBwKCg==", 744 | "dev": true 745 | }, 746 | "node_modules/@types/supercluster": { 747 | "version": "7.1.3", 748 | "resolved": "https://registry.npmjs.org/@types/supercluster/-/supercluster-7.1.3.tgz", 749 | "integrity": "sha512-Z0pOY34GDFl3Q6hUFYf3HkTwKEE02e7QgtJppBt+beEAxnyOpJua+voGFvxINBHa06GwLFFym7gRPY2SiKIfIA==", 750 | "dependencies": { 751 | "@types/geojson": "*" 752 | } 753 | }, 754 | "node_modules/ansi-regex": { 755 | "version": "6.0.1", 756 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 757 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 758 | "dev": true, 759 | "engines": { 760 | "node": ">=12" 761 | }, 762 | "funding": { 763 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 764 | } 765 | }, 766 | "node_modules/ansi-styles": { 767 | "version": "6.2.1", 768 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", 769 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", 770 | "dev": true, 771 | "engines": { 772 | "node": ">=12" 773 | }, 774 | "funding": { 775 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 776 | } 777 | }, 778 | "node_modules/any-promise": { 779 | "version": "1.3.0", 780 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", 781 | "integrity": "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==", 782 | "dev": true 783 | }, 784 | "node_modules/anymatch": { 785 | "version": "3.1.3", 786 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 787 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 788 | "dev": true, 789 | "dependencies": { 790 | "normalize-path": "^3.0.0", 791 | "picomatch": "^2.0.4" 792 | }, 793 | "engines": { 794 | "node": ">= 8" 795 | } 796 | }, 797 | "node_modules/arg": { 798 | "version": "5.0.2", 799 | "resolved": "https://registry.npmjs.org/arg/-/arg-5.0.2.tgz", 800 | "integrity": "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==", 801 | "dev": true 802 | }, 803 | "node_modules/arr-union": { 804 | "version": "3.1.0", 805 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", 806 | "integrity": "sha512-sKpyeERZ02v1FeCZT8lrfJq5u6goHCtpTAzPwJYe7c8SPFOboNjNg1vz2L4VTn9T4PQxEx13TbXLmYUcS6Ug7Q==", 807 | "engines": { 808 | "node": ">=0.10.0" 809 | } 810 | }, 811 | "node_modules/assign-symbols": { 812 | "version": "1.0.0", 813 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", 814 | "integrity": "sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw==", 815 | "engines": { 816 | "node": ">=0.10.0" 817 | } 818 | }, 819 | "node_modules/autoprefixer": { 820 | "version": "10.4.19", 821 | "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.19.tgz", 822 | "integrity": "sha512-BaENR2+zBZ8xXhM4pUaKUxlVdxZ0EZhjvbopwnXmxRUfqDmwSpC2lAi/QXvx7NRdPCo1WKEcEF6mV64si1z4Ew==", 823 | "dev": true, 824 | "funding": [ 825 | { 826 | "type": "opencollective", 827 | "url": "https://opencollective.com/postcss/" 828 | }, 829 | { 830 | "type": "tidelift", 831 | "url": "https://tidelift.com/funding/github/npm/autoprefixer" 832 | }, 833 | { 834 | "type": "github", 835 | "url": "https://github.com/sponsors/ai" 836 | } 837 | ], 838 | "dependencies": { 839 | "browserslist": "^4.23.0", 840 | "caniuse-lite": "^1.0.30001599", 841 | "fraction.js": "^4.3.7", 842 | "normalize-range": "^0.1.2", 843 | "picocolors": "^1.0.0", 844 | "postcss-value-parser": "^4.2.0" 845 | }, 846 | "bin": { 847 | "autoprefixer": "bin/autoprefixer" 848 | }, 849 | "engines": { 850 | "node": "^10 || ^12 || >=14" 851 | }, 852 | "peerDependencies": { 853 | "postcss": "^8.1.0" 854 | } 855 | }, 856 | "node_modules/balanced-match": { 857 | "version": "1.0.2", 858 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 859 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 860 | "dev": true 861 | }, 862 | "node_modules/binary-extensions": { 863 | "version": "2.2.0", 864 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 865 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 866 | "dev": true, 867 | "engines": { 868 | "node": ">=8" 869 | } 870 | }, 871 | "node_modules/brace-expansion": { 872 | "version": "1.1.11", 873 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 874 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 875 | "dev": true, 876 | "dependencies": { 877 | "balanced-match": "^1.0.0", 878 | "concat-map": "0.0.1" 879 | } 880 | }, 881 | "node_modules/braces": { 882 | "version": "3.0.2", 883 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 884 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 885 | "dev": true, 886 | "dependencies": { 887 | "fill-range": "^7.0.1" 888 | }, 889 | "engines": { 890 | "node": ">=8" 891 | } 892 | }, 893 | "node_modules/browserslist": { 894 | "version": "4.23.0", 895 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.0.tgz", 896 | "integrity": "sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ==", 897 | "dev": true, 898 | "funding": [ 899 | { 900 | "type": "opencollective", 901 | "url": "https://opencollective.com/browserslist" 902 | }, 903 | { 904 | "type": "tidelift", 905 | "url": "https://tidelift.com/funding/github/npm/browserslist" 906 | }, 907 | { 908 | "type": "github", 909 | "url": "https://github.com/sponsors/ai" 910 | } 911 | ], 912 | "dependencies": { 913 | "caniuse-lite": "^1.0.30001587", 914 | "electron-to-chromium": "^1.4.668", 915 | "node-releases": "^2.0.14", 916 | "update-browserslist-db": "^1.0.13" 917 | }, 918 | "bin": { 919 | "browserslist": "cli.js" 920 | }, 921 | "engines": { 922 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 923 | } 924 | }, 925 | "node_modules/buffer-crc32": { 926 | "version": "0.2.13", 927 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 928 | "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", 929 | "dev": true, 930 | "engines": { 931 | "node": "*" 932 | } 933 | }, 934 | "node_modules/busboy": { 935 | "version": "1.6.0", 936 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 937 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 938 | "dev": true, 939 | "dependencies": { 940 | "streamsearch": "^1.1.0" 941 | }, 942 | "engines": { 943 | "node": ">=10.16.0" 944 | } 945 | }, 946 | "node_modules/bytewise": { 947 | "version": "1.1.0", 948 | "resolved": "https://registry.npmjs.org/bytewise/-/bytewise-1.1.0.tgz", 949 | "integrity": "sha512-rHuuseJ9iQ0na6UDhnrRVDh8YnWVlU6xM3VH6q/+yHDeUH2zIhUzP+2/h3LIrhLDBtTqzWpE3p3tP/boefskKQ==", 950 | "dependencies": { 951 | "bytewise-core": "^1.2.2", 952 | "typewise": "^1.0.3" 953 | } 954 | }, 955 | "node_modules/bytewise-core": { 956 | "version": "1.2.3", 957 | "resolved": "https://registry.npmjs.org/bytewise-core/-/bytewise-core-1.2.3.tgz", 958 | "integrity": "sha512-nZD//kc78OOxeYtRlVk8/zXqTB4gf/nlguL1ggWA8FuchMyOxcyHR4QPQZMUmA7czC+YnaBrPUCubqAWe50DaA==", 959 | "dependencies": { 960 | "typewise-core": "^1.2" 961 | } 962 | }, 963 | "node_modules/callsites": { 964 | "version": "3.1.0", 965 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 966 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 967 | "dev": true, 968 | "engines": { 969 | "node": ">=6" 970 | } 971 | }, 972 | "node_modules/camelcase-css": { 973 | "version": "2.0.1", 974 | "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", 975 | "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==", 976 | "dev": true, 977 | "engines": { 978 | "node": ">= 6" 979 | } 980 | }, 981 | "node_modules/caniuse-lite": { 982 | "version": "1.0.30001621", 983 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001621.tgz", 984 | "integrity": "sha512-+NLXZiviFFKX0fk8Piwv3PfLPGtRqJeq2TiNoUff/qB5KJgwecJTvCXDpmlyP/eCI/GUEmp/h/y5j0yckiiZrA==", 985 | "dev": true, 986 | "funding": [ 987 | { 988 | "type": "opencollective", 989 | "url": "https://opencollective.com/browserslist" 990 | }, 991 | { 992 | "type": "tidelift", 993 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 994 | }, 995 | { 996 | "type": "github", 997 | "url": "https://github.com/sponsors/ai" 998 | } 999 | ] 1000 | }, 1001 | "node_modules/chokidar": { 1002 | "version": "3.5.3", 1003 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 1004 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 1005 | "dev": true, 1006 | "funding": [ 1007 | { 1008 | "type": "individual", 1009 | "url": "https://paulmillr.com/funding/" 1010 | } 1011 | ], 1012 | "dependencies": { 1013 | "anymatch": "~3.1.2", 1014 | "braces": "~3.0.2", 1015 | "glob-parent": "~5.1.2", 1016 | "is-binary-path": "~2.1.0", 1017 | "is-glob": "~4.0.1", 1018 | "normalize-path": "~3.0.0", 1019 | "readdirp": "~3.6.0" 1020 | }, 1021 | "engines": { 1022 | "node": ">= 8.10.0" 1023 | }, 1024 | "optionalDependencies": { 1025 | "fsevents": "~2.3.2" 1026 | } 1027 | }, 1028 | "node_modules/color-convert": { 1029 | "version": "2.0.1", 1030 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1031 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1032 | "dev": true, 1033 | "dependencies": { 1034 | "color-name": "~1.1.4" 1035 | }, 1036 | "engines": { 1037 | "node": ">=7.0.0" 1038 | } 1039 | }, 1040 | "node_modules/color-name": { 1041 | "version": "1.1.4", 1042 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1043 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1044 | "dev": true 1045 | }, 1046 | "node_modules/commander": { 1047 | "version": "4.1.1", 1048 | "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", 1049 | "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", 1050 | "dev": true, 1051 | "engines": { 1052 | "node": ">= 6" 1053 | } 1054 | }, 1055 | "node_modules/concat-map": { 1056 | "version": "0.0.1", 1057 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1058 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1059 | "dev": true 1060 | }, 1061 | "node_modules/cookie": { 1062 | "version": "0.5.0", 1063 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 1064 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 1065 | "dev": true, 1066 | "engines": { 1067 | "node": ">= 0.6" 1068 | } 1069 | }, 1070 | "node_modules/cross-spawn": { 1071 | "version": "7.0.3", 1072 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1073 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1074 | "dev": true, 1075 | "dependencies": { 1076 | "path-key": "^3.1.0", 1077 | "shebang-command": "^2.0.0", 1078 | "which": "^2.0.1" 1079 | }, 1080 | "engines": { 1081 | "node": ">= 8" 1082 | } 1083 | }, 1084 | "node_modules/cross-spawn/node_modules/which": { 1085 | "version": "2.0.2", 1086 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1087 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1088 | "dev": true, 1089 | "dependencies": { 1090 | "isexe": "^2.0.0" 1091 | }, 1092 | "bin": { 1093 | "node-which": "bin/node-which" 1094 | }, 1095 | "engines": { 1096 | "node": ">= 8" 1097 | } 1098 | }, 1099 | "node_modules/cssesc": { 1100 | "version": "3.0.0", 1101 | "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", 1102 | "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", 1103 | "dev": true, 1104 | "bin": { 1105 | "cssesc": "bin/cssesc" 1106 | }, 1107 | "engines": { 1108 | "node": ">=4" 1109 | } 1110 | }, 1111 | "node_modules/d3-array": { 1112 | "version": "3.2.4", 1113 | "resolved": "https://registry.npmjs.org/d3-array/-/d3-array-3.2.4.tgz", 1114 | "integrity": "sha512-tdQAmyA18i4J7wprpYq8ClcxZy3SC31QMeByyCFyRt7BVHdREQZ5lpzoe5mFEYZUWe+oq8HBvk9JjpibyEV4Jg==", 1115 | "dependencies": { 1116 | "internmap": "1 - 2" 1117 | }, 1118 | "engines": { 1119 | "node": ">=12" 1120 | } 1121 | }, 1122 | "node_modules/d3-geo": { 1123 | "version": "3.1.0", 1124 | "resolved": "https://registry.npmjs.org/d3-geo/-/d3-geo-3.1.0.tgz", 1125 | "integrity": "sha512-JEo5HxXDdDYXCaWdwLRt79y7giK8SbhZJbFWXqbRTolCHFI5jRqteLzCsq51NKbUoX0PjBVSohxrx+NoOUujYA==", 1126 | "dependencies": { 1127 | "d3-array": "2.5.0 - 3" 1128 | }, 1129 | "engines": { 1130 | "node": ">=12" 1131 | } 1132 | }, 1133 | "node_modules/debug": { 1134 | "version": "4.3.4", 1135 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1136 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1137 | "dev": true, 1138 | "dependencies": { 1139 | "ms": "2.1.2" 1140 | }, 1141 | "engines": { 1142 | "node": ">=6.0" 1143 | }, 1144 | "peerDependenciesMeta": { 1145 | "supports-color": { 1146 | "optional": true 1147 | } 1148 | } 1149 | }, 1150 | "node_modules/deepmerge": { 1151 | "version": "4.3.1", 1152 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", 1153 | "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", 1154 | "dev": true, 1155 | "engines": { 1156 | "node": ">=0.10.0" 1157 | } 1158 | }, 1159 | "node_modules/detect-indent": { 1160 | "version": "6.1.0", 1161 | "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.1.0.tgz", 1162 | "integrity": "sha512-reYkTUJAZb9gUuZ2RvVCNhVHdg62RHnJ7WJl8ftMi4diZ6NWlciOzQN88pUhSELEwflJht4oQDv0F0BMlwaYtA==", 1163 | "dev": true, 1164 | "engines": { 1165 | "node": ">=8" 1166 | } 1167 | }, 1168 | "node_modules/devalue": { 1169 | "version": "4.3.2", 1170 | "resolved": "https://registry.npmjs.org/devalue/-/devalue-4.3.2.tgz", 1171 | "integrity": "sha512-KqFl6pOgOW+Y6wJgu80rHpo2/3H07vr8ntR9rkkFIRETewbf5GaYYcakYfiKz89K+sLsuPkQIZaXDMjUObZwWg==", 1172 | "dev": true 1173 | }, 1174 | "node_modules/didyoumean": { 1175 | "version": "1.2.2", 1176 | "resolved": "https://registry.npmjs.org/didyoumean/-/didyoumean-1.2.2.tgz", 1177 | "integrity": "sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==", 1178 | "dev": true 1179 | }, 1180 | "node_modules/dlv": { 1181 | "version": "1.1.3", 1182 | "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", 1183 | "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==", 1184 | "dev": true 1185 | }, 1186 | "node_modules/earcut": { 1187 | "version": "2.2.4", 1188 | "resolved": "https://registry.npmjs.org/earcut/-/earcut-2.2.4.tgz", 1189 | "integrity": "sha512-/pjZsA1b4RPHbeWZQn66SWS8nZZWLQQ23oE3Eam7aroEFGEvwKAsJfZ9ytiEMycfzXWpca4FA9QIOehf7PocBQ==" 1190 | }, 1191 | "node_modules/eastasianwidth": { 1192 | "version": "0.2.0", 1193 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 1194 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 1195 | "dev": true 1196 | }, 1197 | "node_modules/electron-to-chromium": { 1198 | "version": "1.4.782", 1199 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.782.tgz", 1200 | "integrity": "sha512-JUfU61e8tr+i5Y1FKXcKs+Xe+rJ+CEqm4cgv1kMihPE2EvYHmYyVr3Im/+1+Z5B29Be2EEGCZCwAc6Tazdl1Yg==", 1201 | "dev": true 1202 | }, 1203 | "node_modules/emoji-regex": { 1204 | "version": "9.2.2", 1205 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 1206 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 1207 | "dev": true 1208 | }, 1209 | "node_modules/es6-promise": { 1210 | "version": "3.3.1", 1211 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz", 1212 | "integrity": "sha512-SOp9Phqvqn7jtEUxPWdWfWoLmyt2VaJ6MpvP9Comy1MceMXqE6bxvaTu4iaxpYYPzhny28Lc+M87/c2cPK6lDg==", 1213 | "dev": true 1214 | }, 1215 | "node_modules/esbuild": { 1216 | "version": "0.17.19", 1217 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", 1218 | "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", 1219 | "dev": true, 1220 | "hasInstallScript": true, 1221 | "bin": { 1222 | "esbuild": "bin/esbuild" 1223 | }, 1224 | "engines": { 1225 | "node": ">=12" 1226 | }, 1227 | "optionalDependencies": { 1228 | "@esbuild/android-arm": "0.17.19", 1229 | "@esbuild/android-arm64": "0.17.19", 1230 | "@esbuild/android-x64": "0.17.19", 1231 | "@esbuild/darwin-arm64": "0.17.19", 1232 | "@esbuild/darwin-x64": "0.17.19", 1233 | "@esbuild/freebsd-arm64": "0.17.19", 1234 | "@esbuild/freebsd-x64": "0.17.19", 1235 | "@esbuild/linux-arm": "0.17.19", 1236 | "@esbuild/linux-arm64": "0.17.19", 1237 | "@esbuild/linux-ia32": "0.17.19", 1238 | "@esbuild/linux-loong64": "0.17.19", 1239 | "@esbuild/linux-mips64el": "0.17.19", 1240 | "@esbuild/linux-ppc64": "0.17.19", 1241 | "@esbuild/linux-riscv64": "0.17.19", 1242 | "@esbuild/linux-s390x": "0.17.19", 1243 | "@esbuild/linux-x64": "0.17.19", 1244 | "@esbuild/netbsd-x64": "0.17.19", 1245 | "@esbuild/openbsd-x64": "0.17.19", 1246 | "@esbuild/sunos-x64": "0.17.19", 1247 | "@esbuild/win32-arm64": "0.17.19", 1248 | "@esbuild/win32-ia32": "0.17.19", 1249 | "@esbuild/win32-x64": "0.17.19" 1250 | } 1251 | }, 1252 | "node_modules/escalade": { 1253 | "version": "3.1.2", 1254 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", 1255 | "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", 1256 | "dev": true, 1257 | "engines": { 1258 | "node": ">=6" 1259 | } 1260 | }, 1261 | "node_modules/esm-env": { 1262 | "version": "1.0.0", 1263 | "resolved": "https://registry.npmjs.org/esm-env/-/esm-env-1.0.0.tgz", 1264 | "integrity": "sha512-Cf6VksWPsTuW01vU9Mk/3vRue91Zevka5SjyNf3nEpokFRuqt/KjUQoGAwq9qMmhpLTHmXzSIrFRw8zxWzmFBA==", 1265 | "dev": true 1266 | }, 1267 | "node_modules/extend-shallow": { 1268 | "version": "2.0.1", 1269 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 1270 | "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", 1271 | "dependencies": { 1272 | "is-extendable": "^0.1.0" 1273 | }, 1274 | "engines": { 1275 | "node": ">=0.10.0" 1276 | } 1277 | }, 1278 | "node_modules/fast-glob": { 1279 | "version": "3.3.2", 1280 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 1281 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 1282 | "dev": true, 1283 | "dependencies": { 1284 | "@nodelib/fs.stat": "^2.0.2", 1285 | "@nodelib/fs.walk": "^1.2.3", 1286 | "glob-parent": "^5.1.2", 1287 | "merge2": "^1.3.0", 1288 | "micromatch": "^4.0.4" 1289 | }, 1290 | "engines": { 1291 | "node": ">=8.6.0" 1292 | } 1293 | }, 1294 | "node_modules/fastq": { 1295 | "version": "1.15.0", 1296 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 1297 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 1298 | "dev": true, 1299 | "dependencies": { 1300 | "reusify": "^1.0.4" 1301 | } 1302 | }, 1303 | "node_modules/fflate": { 1304 | "version": "0.8.1", 1305 | "resolved": "https://registry.npmjs.org/fflate/-/fflate-0.8.1.tgz", 1306 | "integrity": "sha512-/exOvEuc+/iaUm105QIiOt4LpBdMTWsXxqR0HDF35vx3fmaKzw7354gTilCh5rkzEt8WYyG//ku3h3nRmd7CHQ==" 1307 | }, 1308 | "node_modules/fill-range": { 1309 | "version": "7.0.1", 1310 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1311 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1312 | "dev": true, 1313 | "dependencies": { 1314 | "to-regex-range": "^5.0.1" 1315 | }, 1316 | "engines": { 1317 | "node": ">=8" 1318 | } 1319 | }, 1320 | "node_modules/foreground-child": { 1321 | "version": "3.1.1", 1322 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.1.1.tgz", 1323 | "integrity": "sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==", 1324 | "dev": true, 1325 | "dependencies": { 1326 | "cross-spawn": "^7.0.0", 1327 | "signal-exit": "^4.0.1" 1328 | }, 1329 | "engines": { 1330 | "node": ">=14" 1331 | }, 1332 | "funding": { 1333 | "url": "https://github.com/sponsors/isaacs" 1334 | } 1335 | }, 1336 | "node_modules/fraction.js": { 1337 | "version": "4.3.7", 1338 | "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", 1339 | "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", 1340 | "dev": true, 1341 | "engines": { 1342 | "node": "*" 1343 | }, 1344 | "funding": { 1345 | "type": "patreon", 1346 | "url": "https://github.com/sponsors/rawify" 1347 | } 1348 | }, 1349 | "node_modules/fs.realpath": { 1350 | "version": "1.0.0", 1351 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1352 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1353 | "dev": true 1354 | }, 1355 | "node_modules/fsevents": { 1356 | "version": "2.3.2", 1357 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1358 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1359 | "dev": true, 1360 | "hasInstallScript": true, 1361 | "optional": true, 1362 | "os": [ 1363 | "darwin" 1364 | ], 1365 | "engines": { 1366 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1367 | } 1368 | }, 1369 | "node_modules/function-bind": { 1370 | "version": "1.1.2", 1371 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 1372 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 1373 | "dev": true, 1374 | "funding": { 1375 | "url": "https://github.com/sponsors/ljharb" 1376 | } 1377 | }, 1378 | "node_modules/geojson-vt": { 1379 | "version": "3.2.1", 1380 | "resolved": "https://registry.npmjs.org/geojson-vt/-/geojson-vt-3.2.1.tgz", 1381 | "integrity": "sha512-EvGQQi/zPrDA6zr6BnJD/YhwAkBP8nnJ9emh3EnHQKVMfg/MRVtPbMYdgVy/IaEmn4UfagD2a6fafPDL5hbtwg==" 1382 | }, 1383 | "node_modules/get-stream": { 1384 | "version": "6.0.1", 1385 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1386 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1387 | "engines": { 1388 | "node": ">=10" 1389 | }, 1390 | "funding": { 1391 | "url": "https://github.com/sponsors/sindresorhus" 1392 | } 1393 | }, 1394 | "node_modules/get-value": { 1395 | "version": "2.0.6", 1396 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", 1397 | "integrity": "sha512-Ln0UQDlxH1BapMu3GPtf7CuYNwRZf2gwCuPqbyG6pB8WfmFpzqcy4xtAaAMUhnNqjMKTiCPZG2oMT3YSx8U2NA==", 1398 | "engines": { 1399 | "node": ">=0.10.0" 1400 | } 1401 | }, 1402 | "node_modules/gl-matrix": { 1403 | "version": "3.4.3", 1404 | "resolved": "https://registry.npmjs.org/gl-matrix/-/gl-matrix-3.4.3.tgz", 1405 | "integrity": "sha512-wcCp8vu8FT22BnvKVPjXa/ICBWRq/zjFfdofZy1WSpQZpphblv12/bOQLBC1rMM7SGOFS9ltVmKOHil5+Ml7gA==" 1406 | }, 1407 | "node_modules/glob": { 1408 | "version": "7.2.3", 1409 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1410 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1411 | "dev": true, 1412 | "dependencies": { 1413 | "fs.realpath": "^1.0.0", 1414 | "inflight": "^1.0.4", 1415 | "inherits": "2", 1416 | "minimatch": "^3.1.1", 1417 | "once": "^1.3.0", 1418 | "path-is-absolute": "^1.0.0" 1419 | }, 1420 | "engines": { 1421 | "node": "*" 1422 | }, 1423 | "funding": { 1424 | "url": "https://github.com/sponsors/isaacs" 1425 | } 1426 | }, 1427 | "node_modules/glob-parent": { 1428 | "version": "5.1.2", 1429 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1430 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1431 | "dev": true, 1432 | "dependencies": { 1433 | "is-glob": "^4.0.1" 1434 | }, 1435 | "engines": { 1436 | "node": ">= 6" 1437 | } 1438 | }, 1439 | "node_modules/global-prefix": { 1440 | "version": "3.0.0", 1441 | "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-3.0.0.tgz", 1442 | "integrity": "sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==", 1443 | "dependencies": { 1444 | "ini": "^1.3.5", 1445 | "kind-of": "^6.0.2", 1446 | "which": "^1.3.1" 1447 | }, 1448 | "engines": { 1449 | "node": ">=6" 1450 | } 1451 | }, 1452 | "node_modules/globalyzer": { 1453 | "version": "0.1.0", 1454 | "resolved": "https://registry.npmjs.org/globalyzer/-/globalyzer-0.1.0.tgz", 1455 | "integrity": "sha512-40oNTM9UfG6aBmuKxk/giHn5nQ8RVz/SS4Ir6zgzOv9/qC3kKZ9v4etGTcJbEl/NyVQH7FGU7d+X1egr57Md2Q==", 1456 | "dev": true 1457 | }, 1458 | "node_modules/globrex": { 1459 | "version": "0.1.2", 1460 | "resolved": "https://registry.npmjs.org/globrex/-/globrex-0.1.2.tgz", 1461 | "integrity": "sha512-uHJgbwAMwNFf5mLst7IWLNg14x1CkeqglJb/K3doi4dw6q2IvAAmM/Y81kevy83wP+Sst+nutFTYOGg3d1lsxg==", 1462 | "dev": true 1463 | }, 1464 | "node_modules/graceful-fs": { 1465 | "version": "4.2.11", 1466 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1467 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1468 | "dev": true 1469 | }, 1470 | "node_modules/hasown": { 1471 | "version": "2.0.2", 1472 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 1473 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 1474 | "dev": true, 1475 | "dependencies": { 1476 | "function-bind": "^1.1.2" 1477 | }, 1478 | "engines": { 1479 | "node": ">= 0.4" 1480 | } 1481 | }, 1482 | "node_modules/ieee754": { 1483 | "version": "1.2.1", 1484 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 1485 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 1486 | "funding": [ 1487 | { 1488 | "type": "github", 1489 | "url": "https://github.com/sponsors/feross" 1490 | }, 1491 | { 1492 | "type": "patreon", 1493 | "url": "https://www.patreon.com/feross" 1494 | }, 1495 | { 1496 | "type": "consulting", 1497 | "url": "https://feross.org/support" 1498 | } 1499 | ] 1500 | }, 1501 | "node_modules/import-fresh": { 1502 | "version": "3.3.0", 1503 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1504 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1505 | "dev": true, 1506 | "dependencies": { 1507 | "parent-module": "^1.0.0", 1508 | "resolve-from": "^4.0.0" 1509 | }, 1510 | "engines": { 1511 | "node": ">=6" 1512 | }, 1513 | "funding": { 1514 | "url": "https://github.com/sponsors/sindresorhus" 1515 | } 1516 | }, 1517 | "node_modules/import-meta-resolve": { 1518 | "version": "3.0.0", 1519 | "resolved": "https://registry.npmjs.org/import-meta-resolve/-/import-meta-resolve-3.0.0.tgz", 1520 | "integrity": "sha512-4IwhLhNNA8yy445rPjD/lWh++7hMDOml2eHtd58eG7h+qK3EryMuuRbsHGPikCoAgIkkDnckKfWSk2iDla/ejg==", 1521 | "dev": true, 1522 | "funding": { 1523 | "type": "github", 1524 | "url": "https://github.com/sponsors/wooorm" 1525 | } 1526 | }, 1527 | "node_modules/inflight": { 1528 | "version": "1.0.6", 1529 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1530 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1531 | "dev": true, 1532 | "dependencies": { 1533 | "once": "^1.3.0", 1534 | "wrappy": "1" 1535 | } 1536 | }, 1537 | "node_modules/inherits": { 1538 | "version": "2.0.4", 1539 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1540 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1541 | "dev": true 1542 | }, 1543 | "node_modules/ini": { 1544 | "version": "1.3.8", 1545 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 1546 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" 1547 | }, 1548 | "node_modules/internmap": { 1549 | "version": "2.0.3", 1550 | "resolved": "https://registry.npmjs.org/internmap/-/internmap-2.0.3.tgz", 1551 | "integrity": "sha512-5Hh7Y1wQbvY5ooGgPbDaL5iYLAPzMTUrjMulskHLH6wnv/A+1q5rgEaiuqEjB+oxGXIVZs1FF+R/KPN3ZSQYYg==", 1552 | "engines": { 1553 | "node": ">=12" 1554 | } 1555 | }, 1556 | "node_modules/is-binary-path": { 1557 | "version": "2.1.0", 1558 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1559 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1560 | "dev": true, 1561 | "dependencies": { 1562 | "binary-extensions": "^2.0.0" 1563 | }, 1564 | "engines": { 1565 | "node": ">=8" 1566 | } 1567 | }, 1568 | "node_modules/is-core-module": { 1569 | "version": "2.13.1", 1570 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 1571 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 1572 | "dev": true, 1573 | "dependencies": { 1574 | "hasown": "^2.0.0" 1575 | }, 1576 | "funding": { 1577 | "url": "https://github.com/sponsors/ljharb" 1578 | } 1579 | }, 1580 | "node_modules/is-extendable": { 1581 | "version": "0.1.1", 1582 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1583 | "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", 1584 | "engines": { 1585 | "node": ">=0.10.0" 1586 | } 1587 | }, 1588 | "node_modules/is-extglob": { 1589 | "version": "2.1.1", 1590 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1591 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1592 | "dev": true, 1593 | "engines": { 1594 | "node": ">=0.10.0" 1595 | } 1596 | }, 1597 | "node_modules/is-fullwidth-code-point": { 1598 | "version": "3.0.0", 1599 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1600 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1601 | "dev": true, 1602 | "engines": { 1603 | "node": ">=8" 1604 | } 1605 | }, 1606 | "node_modules/is-glob": { 1607 | "version": "4.0.3", 1608 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1609 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1610 | "dev": true, 1611 | "dependencies": { 1612 | "is-extglob": "^2.1.1" 1613 | }, 1614 | "engines": { 1615 | "node": ">=0.10.0" 1616 | } 1617 | }, 1618 | "node_modules/is-number": { 1619 | "version": "7.0.0", 1620 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1621 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1622 | "dev": true, 1623 | "engines": { 1624 | "node": ">=0.12.0" 1625 | } 1626 | }, 1627 | "node_modules/is-plain-object": { 1628 | "version": "2.0.4", 1629 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1630 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1631 | "dependencies": { 1632 | "isobject": "^3.0.1" 1633 | }, 1634 | "engines": { 1635 | "node": ">=0.10.0" 1636 | } 1637 | }, 1638 | "node_modules/isexe": { 1639 | "version": "2.0.0", 1640 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1641 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" 1642 | }, 1643 | "node_modules/isobject": { 1644 | "version": "3.0.1", 1645 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1646 | "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==", 1647 | "engines": { 1648 | "node": ">=0.10.0" 1649 | } 1650 | }, 1651 | "node_modules/jackspeak": { 1652 | "version": "3.1.2", 1653 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.1.2.tgz", 1654 | "integrity": "sha512-kWmLKn2tRtfYMF/BakihVVRzBKOxz4gJMiL2Rj91WnAB5TPZumSH99R/Yf1qE1u4uRimvCSJfm6hnxohXeEXjQ==", 1655 | "dev": true, 1656 | "dependencies": { 1657 | "@isaacs/cliui": "^8.0.2" 1658 | }, 1659 | "engines": { 1660 | "node": ">=14" 1661 | }, 1662 | "funding": { 1663 | "url": "https://github.com/sponsors/isaacs" 1664 | }, 1665 | "optionalDependencies": { 1666 | "@pkgjs/parseargs": "^0.11.0" 1667 | } 1668 | }, 1669 | "node_modules/jiti": { 1670 | "version": "1.21.0", 1671 | "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.0.tgz", 1672 | "integrity": "sha512-gFqAIbuKyyso/3G2qhiO2OM6shY6EPP/R0+mkDbyspxKazh8BXDC5FiFsUjlczgdNz/vfra0da2y+aHrusLG/Q==", 1673 | "dev": true, 1674 | "bin": { 1675 | "jiti": "bin/jiti.js" 1676 | } 1677 | }, 1678 | "node_modules/json-stringify-pretty-compact": { 1679 | "version": "3.0.0", 1680 | "resolved": "https://registry.npmjs.org/json-stringify-pretty-compact/-/json-stringify-pretty-compact-3.0.0.tgz", 1681 | "integrity": "sha512-Rc2suX5meI0S3bfdZuA7JMFBGkJ875ApfVyq2WHELjBiiG22My/l7/8zPpH/CfFVQHuVLd8NLR0nv6vi0BYYKA==" 1682 | }, 1683 | "node_modules/just-compare": { 1684 | "version": "2.3.0", 1685 | "resolved": "https://registry.npmjs.org/just-compare/-/just-compare-2.3.0.tgz", 1686 | "integrity": "sha512-6shoR7HDT+fzfL3gBahx1jZG3hWLrhPAf+l7nCwahDdT9XDtosB9kIF0ZrzUp5QY8dJWfQVr5rnsPqsbvflDzg==" 1687 | }, 1688 | "node_modules/just-flush": { 1689 | "version": "2.3.0", 1690 | "resolved": "https://registry.npmjs.org/just-flush/-/just-flush-2.3.0.tgz", 1691 | "integrity": "sha512-fBuxQ1gJ61BurmhwKS5LYTzhkbrT5j/2U7ax+UbLm9aRvCTh2h6AfzLteOckE4KKomqOf0Y3zIG3Xu57sRsKUg==" 1692 | }, 1693 | "node_modules/kdbush": { 1694 | "version": "4.0.2", 1695 | "resolved": "https://registry.npmjs.org/kdbush/-/kdbush-4.0.2.tgz", 1696 | "integrity": "sha512-WbCVYJ27Sz8zi9Q7Q0xHC+05iwkm3Znipc2XTlrnJbsHMYktW4hPhXUE8Ys1engBrvffoSCqbil1JQAa7clRpA==" 1697 | }, 1698 | "node_modules/kind-of": { 1699 | "version": "6.0.3", 1700 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", 1701 | "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", 1702 | "engines": { 1703 | "node": ">=0.10.0" 1704 | } 1705 | }, 1706 | "node_modules/kleur": { 1707 | "version": "4.1.5", 1708 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", 1709 | "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==", 1710 | "dev": true, 1711 | "engines": { 1712 | "node": ">=6" 1713 | } 1714 | }, 1715 | "node_modules/lilconfig": { 1716 | "version": "2.1.0", 1717 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz", 1718 | "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==", 1719 | "dev": true, 1720 | "engines": { 1721 | "node": ">=10" 1722 | } 1723 | }, 1724 | "node_modules/lines-and-columns": { 1725 | "version": "1.2.4", 1726 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 1727 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 1728 | "dev": true 1729 | }, 1730 | "node_modules/lru-cache": { 1731 | "version": "10.2.2", 1732 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.2.2.tgz", 1733 | "integrity": "sha512-9hp3Vp2/hFQUiIwKo8XCeFVnrg8Pk3TYNPIR7tJADKi5YfcF7vEaK7avFHTlSy3kOKYaJQaalfEo6YuXdceBOQ==", 1734 | "dev": true, 1735 | "engines": { 1736 | "node": "14 || >=16.14" 1737 | } 1738 | }, 1739 | "node_modules/magic-string": { 1740 | "version": "0.30.0", 1741 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.0.tgz", 1742 | "integrity": "sha512-LA+31JYDJLs82r2ScLrlz1GjSgu66ZV518eyWT+S8VhyQn/JL0u9MeBOvQMGYiPk1DBiSN9DDMOcXvigJZaViQ==", 1743 | "dev": true, 1744 | "dependencies": { 1745 | "@jridgewell/sourcemap-codec": "^1.4.13" 1746 | }, 1747 | "engines": { 1748 | "node": ">=12" 1749 | } 1750 | }, 1751 | "node_modules/maplibre-gl": { 1752 | "version": "3.6.2", 1753 | "resolved": "https://registry.npmjs.org/maplibre-gl/-/maplibre-gl-3.6.2.tgz", 1754 | "integrity": "sha512-krg2KFIdOpLPngONDhP6ixCoWl5kbdMINP0moMSJFVX7wX1Clm2M9hlNKXS8vBGlVWwR5R3ZfI6IPrYz7c+aCQ==", 1755 | "dependencies": { 1756 | "@mapbox/geojson-rewind": "^0.5.2", 1757 | "@mapbox/jsonlint-lines-primitives": "^2.0.2", 1758 | "@mapbox/point-geometry": "^0.1.0", 1759 | "@mapbox/tiny-sdf": "^2.0.6", 1760 | "@mapbox/unitbezier": "^0.0.1", 1761 | "@mapbox/vector-tile": "^1.3.1", 1762 | "@mapbox/whoots-js": "^3.1.0", 1763 | "@maplibre/maplibre-gl-style-spec": "^19.3.3", 1764 | "@types/geojson": "^7946.0.13", 1765 | "@types/mapbox__point-geometry": "^0.1.4", 1766 | "@types/mapbox__vector-tile": "^1.3.4", 1767 | "@types/pbf": "^3.0.5", 1768 | "@types/supercluster": "^7.1.3", 1769 | "earcut": "^2.2.4", 1770 | "geojson-vt": "^3.2.1", 1771 | "gl-matrix": "^3.4.3", 1772 | "global-prefix": "^3.0.0", 1773 | "kdbush": "^4.0.2", 1774 | "murmurhash-js": "^1.0.0", 1775 | "pbf": "^3.2.1", 1776 | "potpack": "^2.0.0", 1777 | "quickselect": "^2.0.0", 1778 | "supercluster": "^8.0.1", 1779 | "tinyqueue": "^2.0.3", 1780 | "vt-pbf": "^3.1.3" 1781 | }, 1782 | "engines": { 1783 | "node": ">=16.14.0", 1784 | "npm": ">=8.1.0" 1785 | }, 1786 | "funding": { 1787 | "url": "https://github.com/maplibre/maplibre-gl-js?sponsor=1" 1788 | } 1789 | }, 1790 | "node_modules/merge2": { 1791 | "version": "1.4.1", 1792 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1793 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1794 | "dev": true, 1795 | "engines": { 1796 | "node": ">= 8" 1797 | } 1798 | }, 1799 | "node_modules/micromatch": { 1800 | "version": "4.0.5", 1801 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1802 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1803 | "dev": true, 1804 | "dependencies": { 1805 | "braces": "^3.0.2", 1806 | "picomatch": "^2.3.1" 1807 | }, 1808 | "engines": { 1809 | "node": ">=8.6" 1810 | } 1811 | }, 1812 | "node_modules/mime": { 1813 | "version": "3.0.0", 1814 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 1815 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 1816 | "dev": true, 1817 | "bin": { 1818 | "mime": "cli.js" 1819 | }, 1820 | "engines": { 1821 | "node": ">=10.0.0" 1822 | } 1823 | }, 1824 | "node_modules/min-indent": { 1825 | "version": "1.0.1", 1826 | "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", 1827 | "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==", 1828 | "dev": true, 1829 | "engines": { 1830 | "node": ">=4" 1831 | } 1832 | }, 1833 | "node_modules/minimatch": { 1834 | "version": "3.1.2", 1835 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1836 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1837 | "dev": true, 1838 | "dependencies": { 1839 | "brace-expansion": "^1.1.7" 1840 | }, 1841 | "engines": { 1842 | "node": "*" 1843 | } 1844 | }, 1845 | "node_modules/minimist": { 1846 | "version": "1.2.8", 1847 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 1848 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 1849 | "funding": { 1850 | "url": "https://github.com/sponsors/ljharb" 1851 | } 1852 | }, 1853 | "node_modules/minipass": { 1854 | "version": "7.1.2", 1855 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", 1856 | "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", 1857 | "dev": true, 1858 | "engines": { 1859 | "node": ">=16 || 14 >=14.17" 1860 | } 1861 | }, 1862 | "node_modules/mkdirp": { 1863 | "version": "0.5.6", 1864 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 1865 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 1866 | "dev": true, 1867 | "dependencies": { 1868 | "minimist": "^1.2.6" 1869 | }, 1870 | "bin": { 1871 | "mkdirp": "bin/cmd.js" 1872 | } 1873 | }, 1874 | "node_modules/mri": { 1875 | "version": "1.2.0", 1876 | "resolved": "https://registry.npmjs.org/mri/-/mri-1.2.0.tgz", 1877 | "integrity": "sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==", 1878 | "dev": true, 1879 | "engines": { 1880 | "node": ">=4" 1881 | } 1882 | }, 1883 | "node_modules/mrmime": { 1884 | "version": "1.0.1", 1885 | "resolved": "https://registry.npmjs.org/mrmime/-/mrmime-1.0.1.tgz", 1886 | "integrity": "sha512-hzzEagAgDyoU1Q6yg5uI+AorQgdvMCur3FcKf7NhMKWsaYg+RnbTyHRa/9IlLF9rf455MOCtcqqrQQ83pPP7Uw==", 1887 | "dev": true, 1888 | "engines": { 1889 | "node": ">=10" 1890 | } 1891 | }, 1892 | "node_modules/ms": { 1893 | "version": "2.1.2", 1894 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1895 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1896 | "dev": true 1897 | }, 1898 | "node_modules/murmurhash-js": { 1899 | "version": "1.0.0", 1900 | "resolved": "https://registry.npmjs.org/murmurhash-js/-/murmurhash-js-1.0.0.tgz", 1901 | "integrity": "sha512-TvmkNhkv8yct0SVBSy+o8wYzXjE4Zz3PCesbfs8HiCXXdcTuocApFv11UWlNFWKYsP2okqrhb7JNlSm9InBhIw==" 1902 | }, 1903 | "node_modules/mz": { 1904 | "version": "2.7.0", 1905 | "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", 1906 | "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", 1907 | "dev": true, 1908 | "dependencies": { 1909 | "any-promise": "^1.0.0", 1910 | "object-assign": "^4.0.1", 1911 | "thenify-all": "^1.0.0" 1912 | } 1913 | }, 1914 | "node_modules/nanoid": { 1915 | "version": "3.3.7", 1916 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 1917 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 1918 | "dev": true, 1919 | "funding": [ 1920 | { 1921 | "type": "github", 1922 | "url": "https://github.com/sponsors/ai" 1923 | } 1924 | ], 1925 | "bin": { 1926 | "nanoid": "bin/nanoid.cjs" 1927 | }, 1928 | "engines": { 1929 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1930 | } 1931 | }, 1932 | "node_modules/node-releases": { 1933 | "version": "2.0.14", 1934 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", 1935 | "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", 1936 | "dev": true 1937 | }, 1938 | "node_modules/normalize-path": { 1939 | "version": "3.0.0", 1940 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1941 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1942 | "dev": true, 1943 | "engines": { 1944 | "node": ">=0.10.0" 1945 | } 1946 | }, 1947 | "node_modules/normalize-range": { 1948 | "version": "0.1.2", 1949 | "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", 1950 | "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", 1951 | "dev": true, 1952 | "engines": { 1953 | "node": ">=0.10.0" 1954 | } 1955 | }, 1956 | "node_modules/object-assign": { 1957 | "version": "4.1.1", 1958 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1959 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1960 | "dev": true, 1961 | "engines": { 1962 | "node": ">=0.10.0" 1963 | } 1964 | }, 1965 | "node_modules/object-hash": { 1966 | "version": "3.0.0", 1967 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", 1968 | "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", 1969 | "dev": true, 1970 | "engines": { 1971 | "node": ">= 6" 1972 | } 1973 | }, 1974 | "node_modules/once": { 1975 | "version": "1.4.0", 1976 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1977 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1978 | "dev": true, 1979 | "dependencies": { 1980 | "wrappy": "1" 1981 | } 1982 | }, 1983 | "node_modules/parent-module": { 1984 | "version": "1.0.1", 1985 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1986 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1987 | "dev": true, 1988 | "dependencies": { 1989 | "callsites": "^3.0.0" 1990 | }, 1991 | "engines": { 1992 | "node": ">=6" 1993 | } 1994 | }, 1995 | "node_modules/path-is-absolute": { 1996 | "version": "1.0.1", 1997 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1998 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1999 | "dev": true, 2000 | "engines": { 2001 | "node": ">=0.10.0" 2002 | } 2003 | }, 2004 | "node_modules/path-key": { 2005 | "version": "3.1.1", 2006 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2007 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2008 | "dev": true, 2009 | "engines": { 2010 | "node": ">=8" 2011 | } 2012 | }, 2013 | "node_modules/path-parse": { 2014 | "version": "1.0.7", 2015 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2016 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2017 | "dev": true 2018 | }, 2019 | "node_modules/path-scurry": { 2020 | "version": "1.11.1", 2021 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", 2022 | "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", 2023 | "dev": true, 2024 | "dependencies": { 2025 | "lru-cache": "^10.2.0", 2026 | "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" 2027 | }, 2028 | "engines": { 2029 | "node": ">=16 || 14 >=14.18" 2030 | }, 2031 | "funding": { 2032 | "url": "https://github.com/sponsors/isaacs" 2033 | } 2034 | }, 2035 | "node_modules/pbf": { 2036 | "version": "3.2.1", 2037 | "resolved": "https://registry.npmjs.org/pbf/-/pbf-3.2.1.tgz", 2038 | "integrity": "sha512-ClrV7pNOn7rtmoQVF4TS1vyU0WhYRnP92fzbfF75jAIwpnzdJXf8iTd4CMEqO4yUenH6NDqLiwjqlh6QgZzgLQ==", 2039 | "dependencies": { 2040 | "ieee754": "^1.1.12", 2041 | "resolve-protobuf-schema": "^2.1.0" 2042 | }, 2043 | "bin": { 2044 | "pbf": "bin/pbf" 2045 | } 2046 | }, 2047 | "node_modules/picocolors": { 2048 | "version": "1.0.1", 2049 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", 2050 | "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", 2051 | "dev": true 2052 | }, 2053 | "node_modules/picomatch": { 2054 | "version": "2.3.1", 2055 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2056 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2057 | "dev": true, 2058 | "engines": { 2059 | "node": ">=8.6" 2060 | }, 2061 | "funding": { 2062 | "url": "https://github.com/sponsors/jonschlinkert" 2063 | } 2064 | }, 2065 | "node_modules/pify": { 2066 | "version": "2.3.0", 2067 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 2068 | "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", 2069 | "dev": true, 2070 | "engines": { 2071 | "node": ">=0.10.0" 2072 | } 2073 | }, 2074 | "node_modules/pirates": { 2075 | "version": "4.0.6", 2076 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", 2077 | "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", 2078 | "dev": true, 2079 | "engines": { 2080 | "node": ">= 6" 2081 | } 2082 | }, 2083 | "node_modules/pmtiles": { 2084 | "version": "2.11.0", 2085 | "resolved": "https://registry.npmjs.org/pmtiles/-/pmtiles-2.11.0.tgz", 2086 | "integrity": "sha512-dU9SzzaqmCGpdEuTnIba6bDHT6j09ZJFIXxwGpvkiEnce3ZnBB1VKt6+EOmJGueriweaZLAMTUmKVElU2CBe0g==", 2087 | "dependencies": { 2088 | "fflate": "^0.8.0" 2089 | } 2090 | }, 2091 | "node_modules/postcss": { 2092 | "version": "8.4.38", 2093 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", 2094 | "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", 2095 | "dev": true, 2096 | "funding": [ 2097 | { 2098 | "type": "opencollective", 2099 | "url": "https://opencollective.com/postcss/" 2100 | }, 2101 | { 2102 | "type": "tidelift", 2103 | "url": "https://tidelift.com/funding/github/npm/postcss" 2104 | }, 2105 | { 2106 | "type": "github", 2107 | "url": "https://github.com/sponsors/ai" 2108 | } 2109 | ], 2110 | "dependencies": { 2111 | "nanoid": "^3.3.7", 2112 | "picocolors": "^1.0.0", 2113 | "source-map-js": "^1.2.0" 2114 | }, 2115 | "engines": { 2116 | "node": "^10 || ^12 || >=14" 2117 | } 2118 | }, 2119 | "node_modules/postcss-import": { 2120 | "version": "15.1.0", 2121 | "resolved": "https://registry.npmjs.org/postcss-import/-/postcss-import-15.1.0.tgz", 2122 | "integrity": "sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==", 2123 | "dev": true, 2124 | "dependencies": { 2125 | "postcss-value-parser": "^4.0.0", 2126 | "read-cache": "^1.0.0", 2127 | "resolve": "^1.1.7" 2128 | }, 2129 | "engines": { 2130 | "node": ">=14.0.0" 2131 | }, 2132 | "peerDependencies": { 2133 | "postcss": "^8.0.0" 2134 | } 2135 | }, 2136 | "node_modules/postcss-js": { 2137 | "version": "4.0.1", 2138 | "resolved": "https://registry.npmjs.org/postcss-js/-/postcss-js-4.0.1.tgz", 2139 | "integrity": "sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==", 2140 | "dev": true, 2141 | "dependencies": { 2142 | "camelcase-css": "^2.0.1" 2143 | }, 2144 | "engines": { 2145 | "node": "^12 || ^14 || >= 16" 2146 | }, 2147 | "funding": { 2148 | "type": "opencollective", 2149 | "url": "https://opencollective.com/postcss/" 2150 | }, 2151 | "peerDependencies": { 2152 | "postcss": "^8.4.21" 2153 | } 2154 | }, 2155 | "node_modules/postcss-load-config": { 2156 | "version": "4.0.2", 2157 | "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-4.0.2.tgz", 2158 | "integrity": "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==", 2159 | "dev": true, 2160 | "funding": [ 2161 | { 2162 | "type": "opencollective", 2163 | "url": "https://opencollective.com/postcss/" 2164 | }, 2165 | { 2166 | "type": "github", 2167 | "url": "https://github.com/sponsors/ai" 2168 | } 2169 | ], 2170 | "dependencies": { 2171 | "lilconfig": "^3.0.0", 2172 | "yaml": "^2.3.4" 2173 | }, 2174 | "engines": { 2175 | "node": ">= 14" 2176 | }, 2177 | "peerDependencies": { 2178 | "postcss": ">=8.0.9", 2179 | "ts-node": ">=9.0.0" 2180 | }, 2181 | "peerDependenciesMeta": { 2182 | "postcss": { 2183 | "optional": true 2184 | }, 2185 | "ts-node": { 2186 | "optional": true 2187 | } 2188 | } 2189 | }, 2190 | "node_modules/postcss-load-config/node_modules/lilconfig": { 2191 | "version": "3.1.1", 2192 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.1.tgz", 2193 | "integrity": "sha512-O18pf7nyvHTckunPWCV1XUNXU1piu01y2b7ATJ0ppkUkk8ocqVWBrYjJBCwHDjD/ZWcfyrA0P4gKhzWGi5EINQ==", 2194 | "dev": true, 2195 | "engines": { 2196 | "node": ">=14" 2197 | }, 2198 | "funding": { 2199 | "url": "https://github.com/sponsors/antonk52" 2200 | } 2201 | }, 2202 | "node_modules/postcss-nested": { 2203 | "version": "6.0.1", 2204 | "resolved": "https://registry.npmjs.org/postcss-nested/-/postcss-nested-6.0.1.tgz", 2205 | "integrity": "sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ==", 2206 | "dev": true, 2207 | "dependencies": { 2208 | "postcss-selector-parser": "^6.0.11" 2209 | }, 2210 | "engines": { 2211 | "node": ">=12.0" 2212 | }, 2213 | "funding": { 2214 | "type": "opencollective", 2215 | "url": "https://opencollective.com/postcss/" 2216 | }, 2217 | "peerDependencies": { 2218 | "postcss": "^8.2.14" 2219 | } 2220 | }, 2221 | "node_modules/postcss-selector-parser": { 2222 | "version": "6.1.0", 2223 | "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.1.0.tgz", 2224 | "integrity": "sha512-UMz42UD0UY0EApS0ZL9o1XnLhSTtvvvLe5Dc2H2O56fvRZi+KulDyf5ctDhhtYJBGKStV2FL1fy6253cmLgqVQ==", 2225 | "dev": true, 2226 | "dependencies": { 2227 | "cssesc": "^3.0.0", 2228 | "util-deprecate": "^1.0.2" 2229 | }, 2230 | "engines": { 2231 | "node": ">=4" 2232 | } 2233 | }, 2234 | "node_modules/postcss-value-parser": { 2235 | "version": "4.2.0", 2236 | "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", 2237 | "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", 2238 | "dev": true 2239 | }, 2240 | "node_modules/potpack": { 2241 | "version": "2.0.0", 2242 | "resolved": "https://registry.npmjs.org/potpack/-/potpack-2.0.0.tgz", 2243 | "integrity": "sha512-Q+/tYsFU9r7xoOJ+y/ZTtdVQwTWfzjbiXBDMM/JKUux3+QPP02iUuIoeBQ+Ot6oEDlC+/PGjB/5A3K7KKb7hcw==" 2244 | }, 2245 | "node_modules/prettier": { 2246 | "version": "3.2.5", 2247 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.5.tgz", 2248 | "integrity": "sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A==", 2249 | "dev": true, 2250 | "bin": { 2251 | "prettier": "bin/prettier.cjs" 2252 | }, 2253 | "engines": { 2254 | "node": ">=14" 2255 | }, 2256 | "funding": { 2257 | "url": "https://github.com/prettier/prettier?sponsor=1" 2258 | } 2259 | }, 2260 | "node_modules/prettier-plugin-svelte": { 2261 | "version": "3.2.3", 2262 | "resolved": "https://registry.npmjs.org/prettier-plugin-svelte/-/prettier-plugin-svelte-3.2.3.tgz", 2263 | "integrity": "sha512-wJq8RunyFlWco6U0WJV5wNCM7zpBFakS76UBSbmzMGpncpK98NZABaE+s7n8/APDCEVNHXC5Mpq+MLebQtsRlg==", 2264 | "dev": true, 2265 | "peerDependencies": { 2266 | "prettier": "^3.0.0", 2267 | "svelte": "^3.2.0 || ^4.0.0-next.0 || ^5.0.0-next.0" 2268 | } 2269 | }, 2270 | "node_modules/prettier-plugin-tailwindcss": { 2271 | "version": "0.5.14", 2272 | "resolved": "https://registry.npmjs.org/prettier-plugin-tailwindcss/-/prettier-plugin-tailwindcss-0.5.14.tgz", 2273 | "integrity": "sha512-Puaz+wPUAhFp8Lo9HuciYKM2Y2XExESjeT+9NQoVFXZsPPnc9VYss2SpxdQ6vbatmt8/4+SN0oe0I1cPDABg9Q==", 2274 | "dev": true, 2275 | "engines": { 2276 | "node": ">=14.21.3" 2277 | }, 2278 | "peerDependencies": { 2279 | "@ianvs/prettier-plugin-sort-imports": "*", 2280 | "@prettier/plugin-pug": "*", 2281 | "@shopify/prettier-plugin-liquid": "*", 2282 | "@trivago/prettier-plugin-sort-imports": "*", 2283 | "@zackad/prettier-plugin-twig-melody": "*", 2284 | "prettier": "^3.0", 2285 | "prettier-plugin-astro": "*", 2286 | "prettier-plugin-css-order": "*", 2287 | "prettier-plugin-import-sort": "*", 2288 | "prettier-plugin-jsdoc": "*", 2289 | "prettier-plugin-marko": "*", 2290 | "prettier-plugin-organize-attributes": "*", 2291 | "prettier-plugin-organize-imports": "*", 2292 | "prettier-plugin-sort-imports": "*", 2293 | "prettier-plugin-style-order": "*", 2294 | "prettier-plugin-svelte": "*" 2295 | }, 2296 | "peerDependenciesMeta": { 2297 | "@ianvs/prettier-plugin-sort-imports": { 2298 | "optional": true 2299 | }, 2300 | "@prettier/plugin-pug": { 2301 | "optional": true 2302 | }, 2303 | "@shopify/prettier-plugin-liquid": { 2304 | "optional": true 2305 | }, 2306 | "@trivago/prettier-plugin-sort-imports": { 2307 | "optional": true 2308 | }, 2309 | "@zackad/prettier-plugin-twig-melody": { 2310 | "optional": true 2311 | }, 2312 | "prettier-plugin-astro": { 2313 | "optional": true 2314 | }, 2315 | "prettier-plugin-css-order": { 2316 | "optional": true 2317 | }, 2318 | "prettier-plugin-import-sort": { 2319 | "optional": true 2320 | }, 2321 | "prettier-plugin-jsdoc": { 2322 | "optional": true 2323 | }, 2324 | "prettier-plugin-marko": { 2325 | "optional": true 2326 | }, 2327 | "prettier-plugin-organize-attributes": { 2328 | "optional": true 2329 | }, 2330 | "prettier-plugin-organize-imports": { 2331 | "optional": true 2332 | }, 2333 | "prettier-plugin-sort-imports": { 2334 | "optional": true 2335 | }, 2336 | "prettier-plugin-style-order": { 2337 | "optional": true 2338 | }, 2339 | "prettier-plugin-svelte": { 2340 | "optional": true 2341 | } 2342 | } 2343 | }, 2344 | "node_modules/prisma": { 2345 | "version": "4.15.0", 2346 | "resolved": "https://registry.npmjs.org/prisma/-/prisma-4.15.0.tgz", 2347 | "integrity": "sha512-iKZZpobPl48gTcSZVawLMQ3lEy6BnXwtoMj7hluoGFYu2kQ6F9LBuBrUyF95zRVnNo8/3KzLXJXJ5TEnLSJFiA==", 2348 | "devOptional": true, 2349 | "hasInstallScript": true, 2350 | "dependencies": { 2351 | "@prisma/engines": "4.15.0" 2352 | }, 2353 | "bin": { 2354 | "prisma": "build/index.js", 2355 | "prisma2": "build/index.js" 2356 | }, 2357 | "engines": { 2358 | "node": ">=14.17" 2359 | } 2360 | }, 2361 | "node_modules/protocol-buffers-schema": { 2362 | "version": "3.6.0", 2363 | "resolved": "https://registry.npmjs.org/protocol-buffers-schema/-/protocol-buffers-schema-3.6.0.tgz", 2364 | "integrity": "sha512-TdDRD+/QNdrCGCE7v8340QyuXd4kIWIgapsE2+n/SaGiSSbomYl4TjHlvIoCWRpE7wFt02EpB35VVA2ImcBVqw==" 2365 | }, 2366 | "node_modules/queue-microtask": { 2367 | "version": "1.2.3", 2368 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2369 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2370 | "dev": true, 2371 | "funding": [ 2372 | { 2373 | "type": "github", 2374 | "url": "https://github.com/sponsors/feross" 2375 | }, 2376 | { 2377 | "type": "patreon", 2378 | "url": "https://www.patreon.com/feross" 2379 | }, 2380 | { 2381 | "type": "consulting", 2382 | "url": "https://feross.org/support" 2383 | } 2384 | ] 2385 | }, 2386 | "node_modules/quickselect": { 2387 | "version": "2.0.0", 2388 | "resolved": "https://registry.npmjs.org/quickselect/-/quickselect-2.0.0.tgz", 2389 | "integrity": "sha512-RKJ22hX8mHe3Y6wH/N3wCM6BWtjaxIyyUIkpHOvfFnxdI4yD4tBXEBKSbriGujF6jnSVkJrffuo6vxACiSSxIw==" 2390 | }, 2391 | "node_modules/read-cache": { 2392 | "version": "1.0.0", 2393 | "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", 2394 | "integrity": "sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==", 2395 | "dev": true, 2396 | "dependencies": { 2397 | "pify": "^2.3.0" 2398 | } 2399 | }, 2400 | "node_modules/readdirp": { 2401 | "version": "3.6.0", 2402 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2403 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2404 | "dev": true, 2405 | "dependencies": { 2406 | "picomatch": "^2.2.1" 2407 | }, 2408 | "engines": { 2409 | "node": ">=8.10.0" 2410 | } 2411 | }, 2412 | "node_modules/resolve": { 2413 | "version": "1.22.8", 2414 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 2415 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 2416 | "dev": true, 2417 | "dependencies": { 2418 | "is-core-module": "^2.13.0", 2419 | "path-parse": "^1.0.7", 2420 | "supports-preserve-symlinks-flag": "^1.0.0" 2421 | }, 2422 | "bin": { 2423 | "resolve": "bin/resolve" 2424 | }, 2425 | "funding": { 2426 | "url": "https://github.com/sponsors/ljharb" 2427 | } 2428 | }, 2429 | "node_modules/resolve-from": { 2430 | "version": "4.0.0", 2431 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2432 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2433 | "dev": true, 2434 | "engines": { 2435 | "node": ">=4" 2436 | } 2437 | }, 2438 | "node_modules/resolve-protobuf-schema": { 2439 | "version": "2.1.0", 2440 | "resolved": "https://registry.npmjs.org/resolve-protobuf-schema/-/resolve-protobuf-schema-2.1.0.tgz", 2441 | "integrity": "sha512-kI5ffTiZWmJaS/huM8wZfEMer1eRd7oJQhDuxeCLe3t7N7mX3z94CN0xPxBQxFYQTSNz9T0i+v6inKqSdK8xrQ==", 2442 | "dependencies": { 2443 | "protocol-buffers-schema": "^3.3.1" 2444 | } 2445 | }, 2446 | "node_modules/reusify": { 2447 | "version": "1.0.4", 2448 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2449 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2450 | "dev": true, 2451 | "engines": { 2452 | "iojs": ">=1.0.0", 2453 | "node": ">=0.10.0" 2454 | } 2455 | }, 2456 | "node_modules/rimraf": { 2457 | "version": "2.7.1", 2458 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 2459 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 2460 | "dev": true, 2461 | "dependencies": { 2462 | "glob": "^7.1.3" 2463 | }, 2464 | "bin": { 2465 | "rimraf": "bin.js" 2466 | } 2467 | }, 2468 | "node_modules/rollup": { 2469 | "version": "3.23.0", 2470 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.23.0.tgz", 2471 | "integrity": "sha512-h31UlwEi7FHihLe1zbk+3Q7z1k/84rb9BSwmBSr/XjOCEaBJ2YyedQDuM0t/kfOS0IxM+vk1/zI9XxYj9V+NJQ==", 2472 | "dev": true, 2473 | "bin": { 2474 | "rollup": "dist/bin/rollup" 2475 | }, 2476 | "engines": { 2477 | "node": ">=14.18.0", 2478 | "npm": ">=8.0.0" 2479 | }, 2480 | "optionalDependencies": { 2481 | "fsevents": "~2.3.2" 2482 | } 2483 | }, 2484 | "node_modules/run-parallel": { 2485 | "version": "1.2.0", 2486 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2487 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2488 | "dev": true, 2489 | "funding": [ 2490 | { 2491 | "type": "github", 2492 | "url": "https://github.com/sponsors/feross" 2493 | }, 2494 | { 2495 | "type": "patreon", 2496 | "url": "https://www.patreon.com/feross" 2497 | }, 2498 | { 2499 | "type": "consulting", 2500 | "url": "https://feross.org/support" 2501 | } 2502 | ], 2503 | "dependencies": { 2504 | "queue-microtask": "^1.2.2" 2505 | } 2506 | }, 2507 | "node_modules/rw": { 2508 | "version": "1.3.3", 2509 | "resolved": "https://registry.npmjs.org/rw/-/rw-1.3.3.tgz", 2510 | "integrity": "sha512-PdhdWy89SiZogBLaw42zdeqtRJ//zFd2PgQavcICDUgJT5oW10QCRKbJ6bg4r0/UY2M6BWd5tkxuGFRvCkgfHQ==" 2511 | }, 2512 | "node_modules/sade": { 2513 | "version": "1.8.1", 2514 | "resolved": "https://registry.npmjs.org/sade/-/sade-1.8.1.tgz", 2515 | "integrity": "sha512-xal3CZX1Xlo/k4ApwCFrHVACi9fBqJ7V+mwhBsuf/1IOKbBy098Fex+Wa/5QMubw09pSZ/u8EY8PWgevJsXp1A==", 2516 | "dev": true, 2517 | "dependencies": { 2518 | "mri": "^1.1.0" 2519 | }, 2520 | "engines": { 2521 | "node": ">=6" 2522 | } 2523 | }, 2524 | "node_modules/sander": { 2525 | "version": "0.5.1", 2526 | "resolved": "https://registry.npmjs.org/sander/-/sander-0.5.1.tgz", 2527 | "integrity": "sha512-3lVqBir7WuKDHGrKRDn/1Ye3kwpXaDOMsiRP1wd6wpZW56gJhsbp5RqQpA6JG/P+pkXizygnr1dKR8vzWaVsfA==", 2528 | "dev": true, 2529 | "dependencies": { 2530 | "es6-promise": "^3.1.2", 2531 | "graceful-fs": "^4.1.3", 2532 | "mkdirp": "^0.5.1", 2533 | "rimraf": "^2.5.2" 2534 | } 2535 | }, 2536 | "node_modules/set-cookie-parser": { 2537 | "version": "2.6.0", 2538 | "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.6.0.tgz", 2539 | "integrity": "sha512-RVnVQxTXuerk653XfuliOxBP81Sf0+qfQE73LIYKcyMYHG94AuH0kgrQpRDuTZnSmjpysHmzxJXKNfa6PjFhyQ==", 2540 | "dev": true 2541 | }, 2542 | "node_modules/set-value": { 2543 | "version": "2.0.1", 2544 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", 2545 | "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", 2546 | "dependencies": { 2547 | "extend-shallow": "^2.0.1", 2548 | "is-extendable": "^0.1.1", 2549 | "is-plain-object": "^2.0.3", 2550 | "split-string": "^3.0.1" 2551 | }, 2552 | "engines": { 2553 | "node": ">=0.10.0" 2554 | } 2555 | }, 2556 | "node_modules/shebang-command": { 2557 | "version": "2.0.0", 2558 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2559 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2560 | "dev": true, 2561 | "dependencies": { 2562 | "shebang-regex": "^3.0.0" 2563 | }, 2564 | "engines": { 2565 | "node": ">=8" 2566 | } 2567 | }, 2568 | "node_modules/shebang-regex": { 2569 | "version": "3.0.0", 2570 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2571 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2572 | "dev": true, 2573 | "engines": { 2574 | "node": ">=8" 2575 | } 2576 | }, 2577 | "node_modules/signal-exit": { 2578 | "version": "4.1.0", 2579 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 2580 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 2581 | "dev": true, 2582 | "engines": { 2583 | "node": ">=14" 2584 | }, 2585 | "funding": { 2586 | "url": "https://github.com/sponsors/isaacs" 2587 | } 2588 | }, 2589 | "node_modules/sirv": { 2590 | "version": "2.0.3", 2591 | "resolved": "https://registry.npmjs.org/sirv/-/sirv-2.0.3.tgz", 2592 | "integrity": "sha512-O9jm9BsID1P+0HOi81VpXPoDxYP374pkOLzACAoyUQ/3OUVndNpsz6wMnY2z+yOxzbllCKZrM+9QrWsv4THnyA==", 2593 | "dev": true, 2594 | "dependencies": { 2595 | "@polka/url": "^1.0.0-next.20", 2596 | "mrmime": "^1.0.0", 2597 | "totalist": "^3.0.0" 2598 | }, 2599 | "engines": { 2600 | "node": ">= 10" 2601 | } 2602 | }, 2603 | "node_modules/sorcery": { 2604 | "version": "0.11.0", 2605 | "resolved": "https://registry.npmjs.org/sorcery/-/sorcery-0.11.0.tgz", 2606 | "integrity": "sha512-J69LQ22xrQB1cIFJhPfgtLuI6BpWRiWu1Y3vSsIwK/eAScqJxd/+CJlUuHQRdX2C9NGFamq+KqNywGgaThwfHw==", 2607 | "dev": true, 2608 | "dependencies": { 2609 | "@jridgewell/sourcemap-codec": "^1.4.14", 2610 | "buffer-crc32": "^0.2.5", 2611 | "minimist": "^1.2.0", 2612 | "sander": "^0.5.0" 2613 | }, 2614 | "bin": { 2615 | "sorcery": "bin/sorcery" 2616 | } 2617 | }, 2618 | "node_modules/sort-asc": { 2619 | "version": "0.2.0", 2620 | "resolved": "https://registry.npmjs.org/sort-asc/-/sort-asc-0.2.0.tgz", 2621 | "integrity": "sha512-umMGhjPeHAI6YjABoSTrFp2zaBtXBej1a0yKkuMUyjjqu6FJsTF+JYwCswWDg+zJfk/5npWUUbd33HH/WLzpaA==", 2622 | "engines": { 2623 | "node": ">=0.10.0" 2624 | } 2625 | }, 2626 | "node_modules/sort-desc": { 2627 | "version": "0.2.0", 2628 | "resolved": "https://registry.npmjs.org/sort-desc/-/sort-desc-0.2.0.tgz", 2629 | "integrity": "sha512-NqZqyvL4VPW+RAxxXnB8gvE1kyikh8+pR+T+CXLksVRN9eiQqkQlPwqWYU0mF9Jm7UnctShlxLyAt1CaBOTL1w==", 2630 | "engines": { 2631 | "node": ">=0.10.0" 2632 | } 2633 | }, 2634 | "node_modules/sort-object": { 2635 | "version": "3.0.3", 2636 | "resolved": "https://registry.npmjs.org/sort-object/-/sort-object-3.0.3.tgz", 2637 | "integrity": "sha512-nK7WOY8jik6zaG9CRwZTaD5O7ETWDLZYMM12pqY8htll+7dYeqGfEUPcUBHOpSJg2vJOrvFIY2Dl5cX2ih1hAQ==", 2638 | "dependencies": { 2639 | "bytewise": "^1.1.0", 2640 | "get-value": "^2.0.2", 2641 | "is-extendable": "^0.1.1", 2642 | "sort-asc": "^0.2.0", 2643 | "sort-desc": "^0.2.0", 2644 | "union-value": "^1.0.1" 2645 | }, 2646 | "engines": { 2647 | "node": ">=0.10.0" 2648 | } 2649 | }, 2650 | "node_modules/source-map-js": { 2651 | "version": "1.2.0", 2652 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", 2653 | "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", 2654 | "dev": true, 2655 | "engines": { 2656 | "node": ">=0.10.0" 2657 | } 2658 | }, 2659 | "node_modules/split-string": { 2660 | "version": "3.1.0", 2661 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", 2662 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", 2663 | "dependencies": { 2664 | "extend-shallow": "^3.0.0" 2665 | }, 2666 | "engines": { 2667 | "node": ">=0.10.0" 2668 | } 2669 | }, 2670 | "node_modules/split-string/node_modules/extend-shallow": { 2671 | "version": "3.0.2", 2672 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", 2673 | "integrity": "sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q==", 2674 | "dependencies": { 2675 | "assign-symbols": "^1.0.0", 2676 | "is-extendable": "^1.0.1" 2677 | }, 2678 | "engines": { 2679 | "node": ">=0.10.0" 2680 | } 2681 | }, 2682 | "node_modules/split-string/node_modules/is-extendable": { 2683 | "version": "1.0.1", 2684 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 2685 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 2686 | "dependencies": { 2687 | "is-plain-object": "^2.0.4" 2688 | }, 2689 | "engines": { 2690 | "node": ">=0.10.0" 2691 | } 2692 | }, 2693 | "node_modules/streamsearch": { 2694 | "version": "1.1.0", 2695 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 2696 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 2697 | "dev": true, 2698 | "engines": { 2699 | "node": ">=10.0.0" 2700 | } 2701 | }, 2702 | "node_modules/string-width": { 2703 | "version": "5.1.2", 2704 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", 2705 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", 2706 | "dev": true, 2707 | "dependencies": { 2708 | "eastasianwidth": "^0.2.0", 2709 | "emoji-regex": "^9.2.2", 2710 | "strip-ansi": "^7.0.1" 2711 | }, 2712 | "engines": { 2713 | "node": ">=12" 2714 | }, 2715 | "funding": { 2716 | "url": "https://github.com/sponsors/sindresorhus" 2717 | } 2718 | }, 2719 | "node_modules/string-width-cjs": { 2720 | "name": "string-width", 2721 | "version": "4.2.3", 2722 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2723 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2724 | "dev": true, 2725 | "dependencies": { 2726 | "emoji-regex": "^8.0.0", 2727 | "is-fullwidth-code-point": "^3.0.0", 2728 | "strip-ansi": "^6.0.1" 2729 | }, 2730 | "engines": { 2731 | "node": ">=8" 2732 | } 2733 | }, 2734 | "node_modules/string-width-cjs/node_modules/ansi-regex": { 2735 | "version": "5.0.1", 2736 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2737 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2738 | "dev": true, 2739 | "engines": { 2740 | "node": ">=8" 2741 | } 2742 | }, 2743 | "node_modules/string-width-cjs/node_modules/emoji-regex": { 2744 | "version": "8.0.0", 2745 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2746 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2747 | "dev": true 2748 | }, 2749 | "node_modules/string-width-cjs/node_modules/strip-ansi": { 2750 | "version": "6.0.1", 2751 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2752 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2753 | "dev": true, 2754 | "dependencies": { 2755 | "ansi-regex": "^5.0.1" 2756 | }, 2757 | "engines": { 2758 | "node": ">=8" 2759 | } 2760 | }, 2761 | "node_modules/strip-ansi": { 2762 | "version": "7.1.0", 2763 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 2764 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 2765 | "dev": true, 2766 | "dependencies": { 2767 | "ansi-regex": "^6.0.1" 2768 | }, 2769 | "engines": { 2770 | "node": ">=12" 2771 | }, 2772 | "funding": { 2773 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 2774 | } 2775 | }, 2776 | "node_modules/strip-ansi-cjs": { 2777 | "name": "strip-ansi", 2778 | "version": "6.0.1", 2779 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2780 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2781 | "dev": true, 2782 | "dependencies": { 2783 | "ansi-regex": "^5.0.1" 2784 | }, 2785 | "engines": { 2786 | "node": ">=8" 2787 | } 2788 | }, 2789 | "node_modules/strip-ansi-cjs/node_modules/ansi-regex": { 2790 | "version": "5.0.1", 2791 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2792 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2793 | "dev": true, 2794 | "engines": { 2795 | "node": ">=8" 2796 | } 2797 | }, 2798 | "node_modules/strip-indent": { 2799 | "version": "3.0.0", 2800 | "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz", 2801 | "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==", 2802 | "dev": true, 2803 | "dependencies": { 2804 | "min-indent": "^1.0.0" 2805 | }, 2806 | "engines": { 2807 | "node": ">=8" 2808 | } 2809 | }, 2810 | "node_modules/sucrase": { 2811 | "version": "3.35.0", 2812 | "resolved": "https://registry.npmjs.org/sucrase/-/sucrase-3.35.0.tgz", 2813 | "integrity": "sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA==", 2814 | "dev": true, 2815 | "dependencies": { 2816 | "@jridgewell/gen-mapping": "^0.3.2", 2817 | "commander": "^4.0.0", 2818 | "glob": "^10.3.10", 2819 | "lines-and-columns": "^1.1.6", 2820 | "mz": "^2.7.0", 2821 | "pirates": "^4.0.1", 2822 | "ts-interface-checker": "^0.1.9" 2823 | }, 2824 | "bin": { 2825 | "sucrase": "bin/sucrase", 2826 | "sucrase-node": "bin/sucrase-node" 2827 | }, 2828 | "engines": { 2829 | "node": ">=16 || 14 >=14.17" 2830 | } 2831 | }, 2832 | "node_modules/sucrase/node_modules/brace-expansion": { 2833 | "version": "2.0.1", 2834 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2835 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2836 | "dev": true, 2837 | "dependencies": { 2838 | "balanced-match": "^1.0.0" 2839 | } 2840 | }, 2841 | "node_modules/sucrase/node_modules/glob": { 2842 | "version": "10.4.0", 2843 | "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.0.tgz", 2844 | "integrity": "sha512-+K6CicMIL11UEbC3gH/MVxgGG4gJDMu9tPD+nH+d6W3+y2fYuDSbpa2b+EGyvCGvSN/PT/7daJTH25NknJkcIQ==", 2845 | "dev": true, 2846 | "dependencies": { 2847 | "foreground-child": "^3.1.0", 2848 | "jackspeak": "^3.1.2", 2849 | "minimatch": "^9.0.4", 2850 | "minipass": "^7.1.2", 2851 | "path-scurry": "^1.11.1" 2852 | }, 2853 | "bin": { 2854 | "glob": "dist/esm/bin.mjs" 2855 | }, 2856 | "engines": { 2857 | "node": ">=16 || 14 >=14.18" 2858 | }, 2859 | "funding": { 2860 | "url": "https://github.com/sponsors/isaacs" 2861 | } 2862 | }, 2863 | "node_modules/sucrase/node_modules/minimatch": { 2864 | "version": "9.0.4", 2865 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.4.tgz", 2866 | "integrity": "sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw==", 2867 | "dev": true, 2868 | "dependencies": { 2869 | "brace-expansion": "^2.0.1" 2870 | }, 2871 | "engines": { 2872 | "node": ">=16 || 14 >=14.17" 2873 | }, 2874 | "funding": { 2875 | "url": "https://github.com/sponsors/isaacs" 2876 | } 2877 | }, 2878 | "node_modules/supercluster": { 2879 | "version": "8.0.1", 2880 | "resolved": "https://registry.npmjs.org/supercluster/-/supercluster-8.0.1.tgz", 2881 | "integrity": "sha512-IiOea5kJ9iqzD2t7QJq/cREyLHTtSmUT6gQsweojg9WH2sYJqZK9SswTu6jrscO6D1G5v5vYZ9ru/eq85lXeZQ==", 2882 | "dependencies": { 2883 | "kdbush": "^4.0.2" 2884 | } 2885 | }, 2886 | "node_modules/supports-preserve-symlinks-flag": { 2887 | "version": "1.0.0", 2888 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2889 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2890 | "dev": true, 2891 | "engines": { 2892 | "node": ">= 0.4" 2893 | }, 2894 | "funding": { 2895 | "url": "https://github.com/sponsors/ljharb" 2896 | } 2897 | }, 2898 | "node_modules/svelte": { 2899 | "version": "3.59.1", 2900 | "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.59.1.tgz", 2901 | "integrity": "sha512-pKj8fEBmqf6mq3/NfrB9SLtcJcUvjYSWyePlfCqN9gujLB25RitWK8PvFzlwim6hD/We35KbPlRteuA6rnPGcQ==", 2902 | "engines": { 2903 | "node": ">= 8" 2904 | } 2905 | }, 2906 | "node_modules/svelte-check": { 2907 | "version": "3.4.3", 2908 | "resolved": "https://registry.npmjs.org/svelte-check/-/svelte-check-3.4.3.tgz", 2909 | "integrity": "sha512-O07soQFY3X0VDt+bcGc6D5naz0cLtjwnmNP9JsEBPVyMemFEqUhL2OdLqvkl5H/u8Jwm50EiAU4BPRn5iin/kg==", 2910 | "dev": true, 2911 | "dependencies": { 2912 | "@jridgewell/trace-mapping": "^0.3.17", 2913 | "chokidar": "^3.4.1", 2914 | "fast-glob": "^3.2.7", 2915 | "import-fresh": "^3.2.1", 2916 | "picocolors": "^1.0.0", 2917 | "sade": "^1.7.4", 2918 | "svelte-preprocess": "^5.0.3", 2919 | "typescript": "^5.0.3" 2920 | }, 2921 | "bin": { 2922 | "svelte-check": "bin/svelte-check" 2923 | }, 2924 | "peerDependencies": { 2925 | "svelte": "^3.55.0 || ^4.0.0-next.0 || ^4.0.0" 2926 | } 2927 | }, 2928 | "node_modules/svelte-hmr": { 2929 | "version": "0.15.2", 2930 | "resolved": "https://registry.npmjs.org/svelte-hmr/-/svelte-hmr-0.15.2.tgz", 2931 | "integrity": "sha512-q/bAruCvFLwvNbeE1x3n37TYFb3mTBJ6TrCq6p2CoFbSTNhDE9oAtEfpy+wmc9So8AG0Tja+X0/mJzX9tSfvIg==", 2932 | "dev": true, 2933 | "engines": { 2934 | "node": "^12.20 || ^14.13.1 || >= 16" 2935 | }, 2936 | "peerDependencies": { 2937 | "svelte": "^3.19.0 || ^4.0.0-next.0" 2938 | } 2939 | }, 2940 | "node_modules/svelte-maplibre": { 2941 | "version": "0.7.5", 2942 | "resolved": "https://registry.npmjs.org/svelte-maplibre/-/svelte-maplibre-0.7.5.tgz", 2943 | "integrity": "sha512-1xgw9nvp4y1p2qSWRziL6UDhK4vmA1CzxeMaCYWKw0QyVcRp5Ly3to0bYQtnxva5MGasHpdQgoewwIon/mJOWg==", 2944 | "dependencies": { 2945 | "d3-geo": "^3.1.0", 2946 | "just-compare": "^2.3.0", 2947 | "just-flush": "^2.3.0", 2948 | "maplibre-gl": "^3.5.0", 2949 | "pmtiles": "^2.10.0" 2950 | }, 2951 | "peerDependencies": { 2952 | "@deck.gl/core": "^8.8.0", 2953 | "@deck.gl/layers": "^8.8.0", 2954 | "@deck.gl/mapbox": "^8.8.0", 2955 | "svelte": "^3.54.0 || ^4.0.0" 2956 | }, 2957 | "peerDependenciesMeta": { 2958 | "@deck.gl/core": { 2959 | "optional": true 2960 | }, 2961 | "@deck.gl/layers": { 2962 | "optional": true 2963 | }, 2964 | "@deck.gl/mapbox": { 2965 | "optional": true 2966 | } 2967 | } 2968 | }, 2969 | "node_modules/svelte-preprocess": { 2970 | "version": "5.0.4", 2971 | "resolved": "https://registry.npmjs.org/svelte-preprocess/-/svelte-preprocess-5.0.4.tgz", 2972 | "integrity": "sha512-ABia2QegosxOGsVlsSBJvoWeXy1wUKSfF7SWJdTjLAbx/Y3SrVevvvbFNQqrSJw89+lNSsM58SipmZJ5SRi5iw==", 2973 | "dev": true, 2974 | "hasInstallScript": true, 2975 | "dependencies": { 2976 | "@types/pug": "^2.0.6", 2977 | "detect-indent": "^6.1.0", 2978 | "magic-string": "^0.27.0", 2979 | "sorcery": "^0.11.0", 2980 | "strip-indent": "^3.0.0" 2981 | }, 2982 | "engines": { 2983 | "node": ">= 14.10.0" 2984 | }, 2985 | "peerDependencies": { 2986 | "@babel/core": "^7.10.2", 2987 | "coffeescript": "^2.5.1", 2988 | "less": "^3.11.3 || ^4.0.0", 2989 | "postcss": "^7 || ^8", 2990 | "postcss-load-config": "^2.1.0 || ^3.0.0 || ^4.0.0", 2991 | "pug": "^3.0.0", 2992 | "sass": "^1.26.8", 2993 | "stylus": "^0.55.0", 2994 | "sugarss": "^2.0.0 || ^3.0.0 || ^4.0.0", 2995 | "svelte": "^3.23.0 || ^4.0.0-next.0 || ^4.0.0", 2996 | "typescript": ">=3.9.5 || ^4.0.0 || ^5.0.0" 2997 | }, 2998 | "peerDependenciesMeta": { 2999 | "@babel/core": { 3000 | "optional": true 3001 | }, 3002 | "coffeescript": { 3003 | "optional": true 3004 | }, 3005 | "less": { 3006 | "optional": true 3007 | }, 3008 | "postcss": { 3009 | "optional": true 3010 | }, 3011 | "postcss-load-config": { 3012 | "optional": true 3013 | }, 3014 | "pug": { 3015 | "optional": true 3016 | }, 3017 | "sass": { 3018 | "optional": true 3019 | }, 3020 | "stylus": { 3021 | "optional": true 3022 | }, 3023 | "sugarss": { 3024 | "optional": true 3025 | }, 3026 | "typescript": { 3027 | "optional": true 3028 | } 3029 | } 3030 | }, 3031 | "node_modules/svelte-preprocess/node_modules/magic-string": { 3032 | "version": "0.27.0", 3033 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.27.0.tgz", 3034 | "integrity": "sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==", 3035 | "dev": true, 3036 | "dependencies": { 3037 | "@jridgewell/sourcemap-codec": "^1.4.13" 3038 | }, 3039 | "engines": { 3040 | "node": ">=12" 3041 | } 3042 | }, 3043 | "node_modules/tailwindcss": { 3044 | "version": "3.4.3", 3045 | "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.3.tgz", 3046 | "integrity": "sha512-U7sxQk/n397Bmx4JHbJx/iSOOv5G+II3f1kpLpY2QeUv5DcPdcTsYLlusZfq1NthHS1c1cZoyFmmkex1rzke0A==", 3047 | "dev": true, 3048 | "dependencies": { 3049 | "@alloc/quick-lru": "^5.2.0", 3050 | "arg": "^5.0.2", 3051 | "chokidar": "^3.5.3", 3052 | "didyoumean": "^1.2.2", 3053 | "dlv": "^1.1.3", 3054 | "fast-glob": "^3.3.0", 3055 | "glob-parent": "^6.0.2", 3056 | "is-glob": "^4.0.3", 3057 | "jiti": "^1.21.0", 3058 | "lilconfig": "^2.1.0", 3059 | "micromatch": "^4.0.5", 3060 | "normalize-path": "^3.0.0", 3061 | "object-hash": "^3.0.0", 3062 | "picocolors": "^1.0.0", 3063 | "postcss": "^8.4.23", 3064 | "postcss-import": "^15.1.0", 3065 | "postcss-js": "^4.0.1", 3066 | "postcss-load-config": "^4.0.1", 3067 | "postcss-nested": "^6.0.1", 3068 | "postcss-selector-parser": "^6.0.11", 3069 | "resolve": "^1.22.2", 3070 | "sucrase": "^3.32.0" 3071 | }, 3072 | "bin": { 3073 | "tailwind": "lib/cli.js", 3074 | "tailwindcss": "lib/cli.js" 3075 | }, 3076 | "engines": { 3077 | "node": ">=14.0.0" 3078 | } 3079 | }, 3080 | "node_modules/tailwindcss/node_modules/glob-parent": { 3081 | "version": "6.0.2", 3082 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 3083 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 3084 | "dev": true, 3085 | "dependencies": { 3086 | "is-glob": "^4.0.3" 3087 | }, 3088 | "engines": { 3089 | "node": ">=10.13.0" 3090 | } 3091 | }, 3092 | "node_modules/thenify": { 3093 | "version": "3.3.1", 3094 | "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", 3095 | "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", 3096 | "dev": true, 3097 | "dependencies": { 3098 | "any-promise": "^1.0.0" 3099 | } 3100 | }, 3101 | "node_modules/thenify-all": { 3102 | "version": "1.6.0", 3103 | "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", 3104 | "integrity": "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==", 3105 | "dev": true, 3106 | "dependencies": { 3107 | "thenify": ">= 3.1.0 < 4" 3108 | }, 3109 | "engines": { 3110 | "node": ">=0.8" 3111 | } 3112 | }, 3113 | "node_modules/tiny-glob": { 3114 | "version": "0.2.9", 3115 | "resolved": "https://registry.npmjs.org/tiny-glob/-/tiny-glob-0.2.9.tgz", 3116 | "integrity": "sha512-g/55ssRPUjShh+xkfx9UPDXqhckHEsHr4Vd9zX55oSdGZc/MD0m3sferOkwWtp98bv+kcVfEHtRJgBVJzelrzg==", 3117 | "dev": true, 3118 | "dependencies": { 3119 | "globalyzer": "0.1.0", 3120 | "globrex": "^0.1.2" 3121 | } 3122 | }, 3123 | "node_modules/tinyqueue": { 3124 | "version": "2.0.3", 3125 | "resolved": "https://registry.npmjs.org/tinyqueue/-/tinyqueue-2.0.3.tgz", 3126 | "integrity": "sha512-ppJZNDuKGgxzkHihX8v9v9G5f+18gzaTfrukGrq6ueg0lmH4nqVnA2IPG0AEH3jKEk2GRJCUhDoqpoiw3PHLBA==" 3127 | }, 3128 | "node_modules/to-regex-range": { 3129 | "version": "5.0.1", 3130 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3131 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3132 | "dev": true, 3133 | "dependencies": { 3134 | "is-number": "^7.0.0" 3135 | }, 3136 | "engines": { 3137 | "node": ">=8.0" 3138 | } 3139 | }, 3140 | "node_modules/totalist": { 3141 | "version": "3.0.1", 3142 | "resolved": "https://registry.npmjs.org/totalist/-/totalist-3.0.1.tgz", 3143 | "integrity": "sha512-sf4i37nQ2LBx4m3wB74y+ubopq6W/dIzXg0FDGjsYnZHVa1Da8FH853wlL2gtUhg+xJXjfk3kUZS3BRoQeoQBQ==", 3144 | "dev": true, 3145 | "engines": { 3146 | "node": ">=6" 3147 | } 3148 | }, 3149 | "node_modules/ts-interface-checker": { 3150 | "version": "0.1.13", 3151 | "resolved": "https://registry.npmjs.org/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz", 3152 | "integrity": "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==", 3153 | "dev": true 3154 | }, 3155 | "node_modules/typescript": { 3156 | "version": "5.1.3", 3157 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.1.3.tgz", 3158 | "integrity": "sha512-XH627E9vkeqhlZFQuL+UsyAXEnibT0kWR2FWONlr4sTjvxyJYnyefgrkyECLzM5NenmKzRAy2rR/OlYLA1HkZw==", 3159 | "dev": true, 3160 | "bin": { 3161 | "tsc": "bin/tsc", 3162 | "tsserver": "bin/tsserver" 3163 | }, 3164 | "engines": { 3165 | "node": ">=14.17" 3166 | } 3167 | }, 3168 | "node_modules/typewise": { 3169 | "version": "1.0.3", 3170 | "resolved": "https://registry.npmjs.org/typewise/-/typewise-1.0.3.tgz", 3171 | "integrity": "sha512-aXofE06xGhaQSPzt8hlTY+/YWQhm9P0jYUp1f2XtmW/3Bk0qzXcyFWAtPoo2uTGQj1ZwbDuSyuxicq+aDo8lCQ==", 3172 | "dependencies": { 3173 | "typewise-core": "^1.2.0" 3174 | } 3175 | }, 3176 | "node_modules/typewise-core": { 3177 | "version": "1.2.0", 3178 | "resolved": "https://registry.npmjs.org/typewise-core/-/typewise-core-1.2.0.tgz", 3179 | "integrity": "sha512-2SCC/WLzj2SbUwzFOzqMCkz5amXLlxtJqDKTICqg30x+2DZxcfZN2MvQZmGfXWKNWaKK9pBPsvkcwv8bF/gxKg==" 3180 | }, 3181 | "node_modules/undici": { 3182 | "version": "5.22.1", 3183 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.22.1.tgz", 3184 | "integrity": "sha512-Ji2IJhFXZY0x/0tVBXeQwgPlLWw13GVzpsWPQ3rV50IFMMof2I55PZZxtm4P6iNq+L5znYN9nSTAq0ZyE6lSJw==", 3185 | "dev": true, 3186 | "dependencies": { 3187 | "busboy": "^1.6.0" 3188 | }, 3189 | "engines": { 3190 | "node": ">=14.0" 3191 | } 3192 | }, 3193 | "node_modules/union-value": { 3194 | "version": "1.0.1", 3195 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", 3196 | "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", 3197 | "dependencies": { 3198 | "arr-union": "^3.1.0", 3199 | "get-value": "^2.0.6", 3200 | "is-extendable": "^0.1.1", 3201 | "set-value": "^2.0.1" 3202 | }, 3203 | "engines": { 3204 | "node": ">=0.10.0" 3205 | } 3206 | }, 3207 | "node_modules/update-browserslist-db": { 3208 | "version": "1.0.16", 3209 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.16.tgz", 3210 | "integrity": "sha512-KVbTxlBYlckhF5wgfyZXTWnMn7MMZjMu9XG8bPlliUOP9ThaF4QnhP8qrjrH7DRzHfSk0oQv1wToW+iA5GajEQ==", 3211 | "dev": true, 3212 | "funding": [ 3213 | { 3214 | "type": "opencollective", 3215 | "url": "https://opencollective.com/browserslist" 3216 | }, 3217 | { 3218 | "type": "tidelift", 3219 | "url": "https://tidelift.com/funding/github/npm/browserslist" 3220 | }, 3221 | { 3222 | "type": "github", 3223 | "url": "https://github.com/sponsors/ai" 3224 | } 3225 | ], 3226 | "dependencies": { 3227 | "escalade": "^3.1.2", 3228 | "picocolors": "^1.0.1" 3229 | }, 3230 | "bin": { 3231 | "update-browserslist-db": "cli.js" 3232 | }, 3233 | "peerDependencies": { 3234 | "browserslist": ">= 4.21.0" 3235 | } 3236 | }, 3237 | "node_modules/util-deprecate": { 3238 | "version": "1.0.2", 3239 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3240 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 3241 | "dev": true 3242 | }, 3243 | "node_modules/vite": { 3244 | "version": "4.3.9", 3245 | "resolved": "https://registry.npmjs.org/vite/-/vite-4.3.9.tgz", 3246 | "integrity": "sha512-qsTNZjO9NoJNW7KnOrgYwczm0WctJ8m/yqYAMAK9Lxt4SoySUfS5S8ia9K7JHpa3KEeMfyF8LoJ3c5NeBJy6pg==", 3247 | "dev": true, 3248 | "dependencies": { 3249 | "esbuild": "^0.17.5", 3250 | "postcss": "^8.4.23", 3251 | "rollup": "^3.21.0" 3252 | }, 3253 | "bin": { 3254 | "vite": "bin/vite.js" 3255 | }, 3256 | "engines": { 3257 | "node": "^14.18.0 || >=16.0.0" 3258 | }, 3259 | "optionalDependencies": { 3260 | "fsevents": "~2.3.2" 3261 | }, 3262 | "peerDependencies": { 3263 | "@types/node": ">= 14", 3264 | "less": "*", 3265 | "sass": "*", 3266 | "stylus": "*", 3267 | "sugarss": "*", 3268 | "terser": "^5.4.0" 3269 | }, 3270 | "peerDependenciesMeta": { 3271 | "@types/node": { 3272 | "optional": true 3273 | }, 3274 | "less": { 3275 | "optional": true 3276 | }, 3277 | "sass": { 3278 | "optional": true 3279 | }, 3280 | "stylus": { 3281 | "optional": true 3282 | }, 3283 | "sugarss": { 3284 | "optional": true 3285 | }, 3286 | "terser": { 3287 | "optional": true 3288 | } 3289 | } 3290 | }, 3291 | "node_modules/vitefu": { 3292 | "version": "0.2.4", 3293 | "resolved": "https://registry.npmjs.org/vitefu/-/vitefu-0.2.4.tgz", 3294 | "integrity": "sha512-fanAXjSaf9xXtOOeno8wZXIhgia+CZury481LsDaV++lSvcU2R9Ch2bPh3PYFyoHW+w9LqAeYRISVQjUIew14g==", 3295 | "dev": true, 3296 | "peerDependencies": { 3297 | "vite": "^3.0.0 || ^4.0.0" 3298 | }, 3299 | "peerDependenciesMeta": { 3300 | "vite": { 3301 | "optional": true 3302 | } 3303 | } 3304 | }, 3305 | "node_modules/vt-pbf": { 3306 | "version": "3.1.3", 3307 | "resolved": "https://registry.npmjs.org/vt-pbf/-/vt-pbf-3.1.3.tgz", 3308 | "integrity": "sha512-2LzDFzt0mZKZ9IpVF2r69G9bXaP2Q2sArJCmcCgvfTdCCZzSyz4aCLoQyUilu37Ll56tCblIZrXFIjNUpGIlmA==", 3309 | "dependencies": { 3310 | "@mapbox/point-geometry": "0.1.0", 3311 | "@mapbox/vector-tile": "^1.3.1", 3312 | "pbf": "^3.2.1" 3313 | } 3314 | }, 3315 | "node_modules/which": { 3316 | "version": "1.3.1", 3317 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3318 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3319 | "dependencies": { 3320 | "isexe": "^2.0.0" 3321 | }, 3322 | "bin": { 3323 | "which": "bin/which" 3324 | } 3325 | }, 3326 | "node_modules/wrap-ansi": { 3327 | "version": "8.1.0", 3328 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", 3329 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", 3330 | "dev": true, 3331 | "dependencies": { 3332 | "ansi-styles": "^6.1.0", 3333 | "string-width": "^5.0.1", 3334 | "strip-ansi": "^7.0.1" 3335 | }, 3336 | "engines": { 3337 | "node": ">=12" 3338 | }, 3339 | "funding": { 3340 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3341 | } 3342 | }, 3343 | "node_modules/wrap-ansi-cjs": { 3344 | "name": "wrap-ansi", 3345 | "version": "7.0.0", 3346 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3347 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3348 | "dev": true, 3349 | "dependencies": { 3350 | "ansi-styles": "^4.0.0", 3351 | "string-width": "^4.1.0", 3352 | "strip-ansi": "^6.0.0" 3353 | }, 3354 | "engines": { 3355 | "node": ">=10" 3356 | }, 3357 | "funding": { 3358 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3359 | } 3360 | }, 3361 | "node_modules/wrap-ansi-cjs/node_modules/ansi-regex": { 3362 | "version": "5.0.1", 3363 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 3364 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 3365 | "dev": true, 3366 | "engines": { 3367 | "node": ">=8" 3368 | } 3369 | }, 3370 | "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { 3371 | "version": "4.3.0", 3372 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3373 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3374 | "dev": true, 3375 | "dependencies": { 3376 | "color-convert": "^2.0.1" 3377 | }, 3378 | "engines": { 3379 | "node": ">=8" 3380 | }, 3381 | "funding": { 3382 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 3383 | } 3384 | }, 3385 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { 3386 | "version": "8.0.0", 3387 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3388 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 3389 | "dev": true 3390 | }, 3391 | "node_modules/wrap-ansi-cjs/node_modules/string-width": { 3392 | "version": "4.2.3", 3393 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3394 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3395 | "dev": true, 3396 | "dependencies": { 3397 | "emoji-regex": "^8.0.0", 3398 | "is-fullwidth-code-point": "^3.0.0", 3399 | "strip-ansi": "^6.0.1" 3400 | }, 3401 | "engines": { 3402 | "node": ">=8" 3403 | } 3404 | }, 3405 | "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": { 3406 | "version": "6.0.1", 3407 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3408 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3409 | "dev": true, 3410 | "dependencies": { 3411 | "ansi-regex": "^5.0.1" 3412 | }, 3413 | "engines": { 3414 | "node": ">=8" 3415 | } 3416 | }, 3417 | "node_modules/wrappy": { 3418 | "version": "1.0.2", 3419 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3420 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3421 | "dev": true 3422 | }, 3423 | "node_modules/yaml": { 3424 | "version": "2.4.2", 3425 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.4.2.tgz", 3426 | "integrity": "sha512-B3VqDZ+JAg1nZpaEmWtTXUlBneoGx6CPM9b0TENK6aoSu5t73dItudwdgmi6tHlIZZId4dZ9skcAQ2UbcyAeVA==", 3427 | "dev": true, 3428 | "bin": { 3429 | "yaml": "bin.mjs" 3430 | }, 3431 | "engines": { 3432 | "node": ">= 14" 3433 | } 3434 | } 3435 | } 3436 | } 3437 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "map-of-the-slack", 3 | "version": "0.0.1", 4 | "scripts": { 5 | "dev": "vite dev", 6 | "build": "vite build", 7 | "preview": "vite preview", 8 | "check": "svelte-kit sync && svelte-check --tsconfig ./jsconfig.json", 9 | "check:watch": "svelte-kit sync && svelte-check --tsconfig ./jsconfig.json --watch" 10 | }, 11 | "devDependencies": { 12 | "@fontsource/fira-mono": "^4.5.10", 13 | "@neoconfetti/svelte": "^1.0.0", 14 | "@sveltejs/adapter-auto": "^2.0.0", 15 | "@sveltejs/kit": "^1.5.0", 16 | "@types/cookie": "^0.5.1", 17 | "autoprefixer": "^10.4.19", 18 | "postcss": "^8.4.38", 19 | "prettier": "^3.2.5", 20 | "prettier-plugin-svelte": "^3.2.3", 21 | "prettier-plugin-tailwindcss": "^0.5.14", 22 | "prisma": "^4.15.0", 23 | "svelte": "^3.54.0", 24 | "svelte-check": "^3.0.1", 25 | "tailwindcss": "^3.4.3", 26 | "typescript": "^5.0.0", 27 | "vite": "^4.3.0" 28 | }, 29 | "type": "module", 30 | "dependencies": { 31 | "@prisma/client": "^4.15.0", 32 | "svelte-maplibre": "^0.7.5" 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /postcss.config.js: -------------------------------------------------------------------------------- 1 | export default { 2 | plugins: { 3 | tailwindcss: {}, 4 | autoprefixer: {}, 5 | }, 6 | }; 7 | -------------------------------------------------------------------------------- /src/app.css: -------------------------------------------------------------------------------- 1 | @tailwind base; 2 | @tailwind components; 3 | @tailwind utilities; 4 | -------------------------------------------------------------------------------- /src/app.d.ts: -------------------------------------------------------------------------------- 1 | // See https://kit.svelte.dev/docs/types#app 2 | // for information about these interfaces 3 | declare global { 4 | namespace App { 5 | // interface Error {} 6 | // interface Locals {} 7 | // interface PageData {} 8 | // interface Platform {} 9 | } 10 | } 11 | 12 | export {}; 13 | -------------------------------------------------------------------------------- /src/app.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | %sveltekit.head% 8 | 9 | 10 |
%sveltekit.body%
11 | 12 | 13 | -------------------------------------------------------------------------------- /src/routes/+layout.svelte: -------------------------------------------------------------------------------- 1 | 4 | 5 | 6 | Hack Club's Map of the Slack 7 | 11 | 12 | 13 |
14 |

15 | Hack Club's Map of the Slack 16 |

17 |
18 | 19 |
20 |
21 | -------------------------------------------------------------------------------- /src/routes/+page.js: -------------------------------------------------------------------------------- 1 | // since there's no dynamic data here, we can prerender 2 | // it so that it gets served as a static asset in production 3 | export const prerender = true; 4 | 5 | /** @type {import('./$types').PageLoad} */ 6 | export async function load({ fetch }) { 7 | const nodes = await (await fetch("/geojson.json")).json(); 8 | 9 | return { 10 | nodes, 11 | }; 12 | } 13 | -------------------------------------------------------------------------------- /src/routes/+page.svelte: -------------------------------------------------------------------------------- 1 | 6 | 7 |
8 | 14 | 15 | 16 | {@const props = feature.properties} 17 | {#if props?.name !== "Connections"} 18 |
19 | 29 |
30 | {props?.name} 31 | {/if} 32 |
33 | 41 |
42 |
43 |
44 | 45 | 50 | -------------------------------------------------------------------------------- /static/favicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/hackclub/map-of-the-slack/fbba17204f0f35596476958629968450605129d3/static/favicon.png -------------------------------------------------------------------------------- /static/robots.txt: -------------------------------------------------------------------------------- 1 | # https://www.robotstxt.org/robotstxt.html 2 | User-agent: * 3 | Disallow: 4 | -------------------------------------------------------------------------------- /static/style.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": 8, 3 | "name": "Empty", 4 | "sources": {}, 5 | "layers": [ 6 | { 7 | "id": "background", 8 | "type": "background", 9 | "paint": { 10 | "background-color": "rgba(0,0,0,0)" 11 | } 12 | } 13 | ] 14 | } 15 | -------------------------------------------------------------------------------- /svelte.config.js: -------------------------------------------------------------------------------- 1 | import adapter from "@sveltejs/adapter-auto"; 2 | import { vitePreprocess } from "@sveltejs/vite-plugin-svelte"; 3 | 4 | /** @type {import('@sveltejs/kit').Config} */ 5 | const config = { 6 | kit: { 7 | // adapter-auto only supports some environments, see https://kit.svelte.dev/docs/adapter-auto for a list. 8 | // If your environment is not supported or you settled on a specific environment, switch out the adapter. 9 | // See https://kit.svelte.dev/docs/adapters for more information about adapters. 10 | adapter: adapter(), 11 | }, 12 | preprocess: vitePreprocess(), 13 | }; 14 | 15 | export default config; 16 | -------------------------------------------------------------------------------- /tailwind.config.js: -------------------------------------------------------------------------------- 1 | /** @type {import('tailwindcss').Config} */ 2 | export default { 3 | content: ["./src/**/*.{html,js,svelte,ts}"], 4 | theme: { 5 | extend: {}, 6 | }, 7 | plugins: [], 8 | }; 9 | -------------------------------------------------------------------------------- /vite.config.js: -------------------------------------------------------------------------------- 1 | import { sveltekit } from "@sveltejs/kit/vite"; 2 | import { defineConfig } from "vite"; 3 | 4 | export default defineConfig({ 5 | plugins: [sveltekit()], 6 | }); 7 | --------------------------------------------------------------------------------